-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathdemo-3.tsx
62 lines (51 loc) · 1.87 KB
/
demo-3.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
import type { NextPage } from 'next'
import { useAccount, useConnect, useDisconnect } from 'wagmi'
import { InjectedConnector } from 'wagmi/connectors/injected'
import Nav from '../components/Nav'
import Heading from '../components/Heading'
import DaiBox from '../components/DaiBox'
import CdaiBox from '../components/CdaiBox'
import Footer from '../components/Footer'
import AuthorizeCompoundOverlay from '../components/AuthorizeCompoundOverlay'
import ConnectOverlay from '../components/ConnectOverlay'
import useCdaiAllowance from '../hooks/useCdaiAllowance'
import useDaiBalance from '../hooks/useDaiBalance'
import useCdaiUnderlyingBalance from '../hooks/useCdaiUnderlyingBalance'
import styles from '../styles/Home.module.css'
/**
* Paso 3: conectamos la billetera del usuario
*/
const Home: NextPage = () => {
// Connection
const { connect } = useConnect({
connector: new InjectedConnector(),
})
const { disconnect } = useDisconnect()
const { address, isConnected } = useAccount()
// Read
const daiBalance = useDaiBalance(address)
const cdaiBalance = useCdaiUnderlyingBalance(address)
const cdaiAllowance = useCdaiAllowance(address)
return (
<div>
<Nav address={address} onConnectPress={connect} onDisconnectPress={disconnect} />
<main className={styles.main}>
<Heading />
<div className={styles.content}>
<DaiBox balance={daiBalance.formatted} isLoading={daiBalance.isLoading} />
< >
<CdaiBox balance={cdaiBalance.formatted} isLoading={cdaiBalance.isLoading} />
{isConnected && !cdaiAllowance.isAuthorized && (
<AuthorizeCompoundOverlay isLoading={cdaiAllowance.isLoading} />
)}
{!isConnected && <ConnectOverlay onConnectPress={connect} />}
</div>
</main>
<Footer />
</div>
)
}
/**
* Exports
*/
export default Home