-
Notifications
You must be signed in to change notification settings - Fork 1
/
Counter.tsx
93 lines (82 loc) · 2.08 KB
/
Counter.tsx
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
import { BigNumber } from 'ethers'
import { useState } from 'react'
import { useNetwork, useWaitForTransaction } from 'wagmi'
import {
useCounterIncrement,
useCounterNumber,
useCounterSetNumber,
usePrepareCounterIncrement,
usePrepareCounterSetNumber,
} from '../generated'
export function Counter() {
return (
<div>
<Count />
<SetNumber />
<Increment />
</div>
)
}
function Count() {
const { data: count } = useCounterNumber()
return <div>Count: {count?.toString()}</div>
}
function SetNumber() {
const [value, setValue] = useState('')
const { config } = usePrepareCounterSetNumber({
args: value ? [BigNumber.from(value)] : undefined,
enabled: Boolean(value),
})
const { data, write } = useCounterSetNumber({
...config,
onSuccess: () => setValue(''),
})
const { refetch } = useCounterNumber()
const { isLoading } = useWaitForTransaction({
hash: data?.hash,
onSuccess: () => refetch(),
})
return (
<div>
Set Number:
<input
disabled={isLoading}
onChange={(e) => setValue(e.target.value)}
value={value}
/>
<button disabled={!write || isLoading} onClick={() => write?.()}>
Set
</button>
{isLoading && <ProcessingMessage hash={data?.hash} />}
</div>
)
}
function Increment() {
const { config } = usePrepareCounterIncrement()
const { data, write } = useCounterIncrement(config)
const { refetch } = useCounterNumber()
const { isLoading } = useWaitForTransaction({
hash: data?.hash,
onSuccess: () => refetch(),
})
return (
<div>
<button disabled={!write || isLoading} onClick={() => write?.()}>
Increment
</button>
{isLoading && <ProcessingMessage hash={data?.hash} />}
</div>
)
}
function ProcessingMessage({ hash }: { hash?: `0x${string}` }) {
const { chain } = useNetwork()
const etherscan = chain?.blockExplorers?.etherscan
return (
<span>
Processing transaction...{' '}
{etherscan && (
<a href={`${etherscan.url}/tx/${hash}`}>{etherscan.name}</a>
)}
</span>
)
}