5d0fbf705d
* feat: make some check optional (e.g. connected peers > 0 or funded chequebook) * fix: alter setup step text to better describe what needs to be done * refactor: rename isOk from boolean value to checkState enum * fix: add checking for any error
70 lines
2.9 KiB
TypeScript
70 lines
2.9 KiB
TypeScript
import { useContext } from 'react'
|
|
import DepositModal from '../../../containers/DepositModal'
|
|
import type { ReactElement, ReactNode } from 'react'
|
|
import ExpandableList from '../../../components/ExpandableList'
|
|
import ExpandableListItemKey from '../../../components/ExpandableListItemKey'
|
|
import ExpandableListItemActions from '../../../components/ExpandableListItemActions'
|
|
import ExpandableListItemNote from '../../../components/ExpandableListItemNote'
|
|
import StatusIcon from '../../../components/StatusIcon'
|
|
import { CheckState, Context } from '../../../providers/Bee'
|
|
|
|
const ChequebookDeployFund = (): ReactElement | null => {
|
|
const { status, isLoading, chequebookAddress } = useContext(Context)
|
|
const { checkState, isEnabled } = status.chequebook
|
|
|
|
if (!isEnabled) return null
|
|
|
|
let text: ReactNode
|
|
|
|
switch (checkState) {
|
|
case CheckState.OK:
|
|
text = 'Your chequebook is deployed and funded'
|
|
break
|
|
case CheckState.WARNING:
|
|
text = (
|
|
<>
|
|
Your chequebook is not funded. Please deposit some xBZZ to your chequebook address. You may need to aquire BZZ
|
|
(e.g. <a href="https://bzz.exchange/">bzz.exchange</a>) and bridge it to the xDai network through the{' '}
|
|
<a href="https://omni.xdaichain.com/bridge">omni bridge</a>. To pay the transaction fees, you will also need
|
|
xDAI token. You can purchase DAI on the network and bridge it to xDai network through the{' '}
|
|
<a href="https://bridge.xdaichain.com/">xDai Bridge</a>. See the{' '}
|
|
<a href="https://www.xdaichain.com/#xdai-stable-chain">official xDai website</a> for more information.
|
|
</>
|
|
)
|
|
break
|
|
default:
|
|
text = (
|
|
<>
|
|
Your chequebook is either not deployed nor funded. To run the node you will need xDAI and xBZZ on the xDai
|
|
network. You may need to aquire BZZ (e.g. <a href="https://bzz.exchange/">bzz.exchange</a>) and bridge it to
|
|
the xDai network through the <a href="https://omni.xdaichain.com/bridge">omni bridge</a>. To pay the
|
|
transaction fees, you will also need xDAI token. You can purchase DAI on the network and bridge it to xDai
|
|
network through the <a href="https://bridge.xdaichain.com/">xDai Bridge</a>. See the{' '}
|
|
<a href="https://www.xdaichain.com/#xdai-stable-chain">official xDai website</a> for more information.
|
|
</>
|
|
)
|
|
}
|
|
|
|
return (
|
|
<ExpandableList
|
|
label={
|
|
<>
|
|
<StatusIcon checkState={checkState} isLoading={isLoading} /> Chequebook Deployment & Funding
|
|
</>
|
|
}
|
|
>
|
|
<ExpandableListItemNote>{text}</ExpandableListItemNote>
|
|
{chequebookAddress && (
|
|
<>
|
|
<ExpandableListItemKey label="Chequebook Address" value={chequebookAddress.chequebookAddress} />
|
|
<ExpandableListItemActions>
|
|
<DepositModal />
|
|
</ExpandableListItemActions>
|
|
</>
|
|
)}
|
|
</ExpandableList>
|
|
)
|
|
}
|
|
|
|
export default ChequebookDeployFund
|