mirror of
https://github.com/kremalicious/blog.git
synced 2025-01-23 16:23:30 +01:00
web3 tweaks
This commit is contained in:
parent
3246979e6e
commit
476a3813e8
@ -1,3 +1,8 @@
|
||||
.link {
|
||||
margin-bottom: var(--spacer);
|
||||
display: inline-block;
|
||||
}
|
||||
|
||||
.accountWrap {
|
||||
font-size: var(--font-size-small);
|
||||
color: var(--text-color-light);
|
||||
|
@ -1,15 +1,16 @@
|
||||
import React, { ReactElement, useState, useEffect } from 'react'
|
||||
import { toDataUrl } from 'ethereum-blockies'
|
||||
import { formatEther } from '@ethersproject/units'
|
||||
import useWeb3 from '../../../hooks/use-web3'
|
||||
import useWeb3, { connectors } from '../../../hooks/use-web3'
|
||||
import {
|
||||
accountWrap,
|
||||
blockies as styleBlockies,
|
||||
balance
|
||||
balance,
|
||||
link
|
||||
} from './Account.module.css'
|
||||
|
||||
export default function Account(): ReactElement {
|
||||
const { library, account } = useWeb3()
|
||||
const { library, account, activate } = useWeb3()
|
||||
const [ethBalance, setEthBalance] = useState(0)
|
||||
const blockies = account && toDataUrl(account)
|
||||
|
||||
@ -29,7 +30,14 @@ export default function Account(): ReactElement {
|
||||
const balanceDisplay =
|
||||
ethBalance && `Ξ${parseFloat(formatEther(ethBalance)).toPrecision(4)}`
|
||||
|
||||
return (
|
||||
return !account ? (
|
||||
<button
|
||||
className={`link ${link}`}
|
||||
onClick={() => activate(connectors.MetaMask)}
|
||||
>
|
||||
MetaMask
|
||||
</button>
|
||||
) : (
|
||||
<div className={accountWrap} title={account}>
|
||||
<span>
|
||||
<img className={styleBlockies} src={blockies} alt="Blockies" />
|
||||
|
@ -1,6 +1,6 @@
|
||||
import React, { ReactElement, useState } from 'react'
|
||||
import useWeb3 from '../../../hooks/use-web3'
|
||||
import Input from '../../atoms/Input'
|
||||
import Account from './Account'
|
||||
import Conversion from './Conversion'
|
||||
import { inputGroup, input, currency } from './InputGroup.module.css'
|
||||
|
||||
@ -9,15 +9,15 @@ export default function InputGroup({
|
||||
}: {
|
||||
sendTransaction(amount: number): void
|
||||
}): ReactElement {
|
||||
const [amount, setAmount] = useState(0.03)
|
||||
const { account } = useWeb3()
|
||||
const [amount, setAmount] = useState(0.01)
|
||||
|
||||
const onAmountChange = ({ target }: { target: any }) => {
|
||||
setAmount(target.value)
|
||||
}
|
||||
|
||||
return (
|
||||
<div>
|
||||
<Account />
|
||||
<>
|
||||
<div className={inputGroup}>
|
||||
<div className={input}>
|
||||
<Input
|
||||
@ -34,11 +34,12 @@ export default function InputGroup({
|
||||
<button
|
||||
className="btn btn-primary"
|
||||
onClick={() => sendTransaction(amount)}
|
||||
disabled={!account}
|
||||
>
|
||||
Make it rain
|
||||
</button>
|
||||
</div>
|
||||
<Conversion amount={amount} />
|
||||
</div>
|
||||
</>
|
||||
)
|
||||
}
|
||||
|
@ -1,8 +1,6 @@
|
||||
.web3 {
|
||||
min-height: 77px;
|
||||
display: flex;
|
||||
align-items: center;
|
||||
justify-content: center;
|
||||
composes: container from '../../Layout.module.css';
|
||||
max-width: 20rem;
|
||||
}
|
||||
|
||||
.web3:empty {
|
||||
|
@ -1,24 +1,17 @@
|
||||
import React, { ReactElement, useState, useEffect } from 'react'
|
||||
import { parseEther } from '@ethersproject/units'
|
||||
import useWeb3, { connectors, getErrorMessage } from '../../../hooks/use-web3'
|
||||
import useWeb3, { getErrorMessage } from '../../../hooks/use-web3'
|
||||
import InputGroup from './InputGroup'
|
||||
import Alert, { getTransactionMessage } from './Alert'
|
||||
import { web3 } from './index.module.css'
|
||||
import { web3 as styleWeb3 } from './index.module.css'
|
||||
import Account from './Account'
|
||||
|
||||
export default function Web3Donation({
|
||||
address
|
||||
}: {
|
||||
address: string
|
||||
}): ReactElement {
|
||||
const {
|
||||
connector,
|
||||
library,
|
||||
chainId,
|
||||
account,
|
||||
activate,
|
||||
active,
|
||||
error
|
||||
} = useWeb3()
|
||||
const { connector, library, chainId, account, active, error } = useWeb3()
|
||||
const [message, setMessage] = useState({})
|
||||
|
||||
useEffect(() => {
|
||||
@ -67,15 +60,12 @@ export default function Web3Donation({
|
||||
}
|
||||
|
||||
return (
|
||||
<div className={web3}>
|
||||
{!active && !message ? (
|
||||
<button className="link" onClick={() => activate(connectors.MetaMask)}>
|
||||
Activate Web3
|
||||
</button>
|
||||
) : library && account && !message ? (
|
||||
<InputGroup sendTransaction={sendTransaction} />
|
||||
<div className={styleWeb3}>
|
||||
<Account />
|
||||
{message ? (
|
||||
<Alert message={message} transactionHash={transactionHash} />
|
||||
) : (
|
||||
message && <Alert message={message} transactionHash={transactionHash} />
|
||||
<InputGroup sendTransaction={sendTransaction} />
|
||||
)}
|
||||
</div>
|
||||
)
|
||||
|
Loading…
Reference in New Issue
Block a user