mango-token-sale/hooks/useWallet.tsx

125 lines
3.1 KiB
TypeScript
Raw Normal View History

2021-04-25 08:03:30 -07:00
import { useEffect, useMemo } from 'react'
import { WalletAdapter } from '../@types/types'
import useWalletStore from '../stores/useWalletStore'
import { notify } from '../utils/notifications'
import {
2021-07-16 04:50:43 -07:00
DEFAULT_PROVIDER,
getWalletProviderByUrl,
2021-04-25 08:03:30 -07:00
} from '../utils/wallet-adapters'
2021-07-16 04:50:43 -07:00
2021-04-25 08:03:30 -07:00
import useInterval from './useInterval'
import useLocalStorageState from './useLocalStorageState'
2021-08-11 13:55:05 -07:00
import usePool from './usePool'
2021-04-25 08:03:30 -07:00
const SECONDS = 1000
export default function useWallet() {
const {
connected,
connection: { endpoint },
current: wallet,
providerUrl: selectedProviderUrl,
set: setWalletStore,
actions,
} = useWalletStore((state) => state)
2021-08-11 13:55:05 -07:00
const { endIdo } = usePool()
2021-04-25 08:03:30 -07:00
const [savedProviderUrl, setSavedProviderUrl] = useLocalStorageState(
'walletProvider',
DEFAULT_PROVIDER.url
)
2021-07-16 04:50:43 -07:00
const provider = useMemo(() => getWalletProviderByUrl(selectedProviderUrl), [
selectedProviderUrl,
])
2021-04-25 08:03:30 -07:00
useEffect(() => {
2021-07-16 04:50:43 -07:00
if (selectedProviderUrl && selectedProviderUrl != savedProviderUrl) {
2021-04-25 08:03:30 -07:00
setSavedProviderUrl(selectedProviderUrl)
}
}, [selectedProviderUrl])
useEffect(() => {
if (provider) {
const updateWallet = () => {
// hack to also update wallet synchronously in case it disconnects
2021-07-16 04:50:43 -07:00
const wallet = new provider.adapter(
provider.url,
2021-04-25 08:03:30 -07:00
endpoint
) as WalletAdapter
setWalletStore((state) => {
state.current = wallet
})
}
if (document.readyState !== 'complete') {
// wait to ensure that browser extensions are loaded
const listener = () => {
updateWallet()
window.removeEventListener('load', listener)
}
window.addEventListener('load', listener)
return () => window.removeEventListener('load', listener)
} else {
updateWallet()
}
}
2021-07-16 04:50:43 -07:00
}, [provider, endpoint])
2021-04-25 08:03:30 -07:00
useEffect(() => {
if (!wallet) return
wallet.on('connect', async () => {
setWalletStore((state) => {
state.connected = true
})
notify({
message: 'Wallet connected',
description:
'Connected to wallet ' +
wallet.publicKey.toString().substr(0, 5) +
'...' +
wallet.publicKey.toString().substr(-5),
})
2021-05-05 05:02:16 -07:00
await actions.fetchPool()
await actions.fetchWalletTokenAccounts()
2021-04-25 08:03:30 -07:00
})
wallet.on('disconnect', () => {
setWalletStore((state) => {
state.connected = false
state.tokenAccounts = []
2021-04-25 08:03:30 -07:00
})
notify({
type: 'info',
message: 'Disconnected from wallet',
})
})
return () => {
2021-07-22 09:39:05 -07:00
wallet?.disconnect?.()
2021-04-25 08:03:30 -07:00
setWalletStore((state) => {
state.connected = false
})
}
2021-07-16 04:50:43 -07:00
}, [wallet])
2021-04-25 08:03:30 -07:00
// fetch pool on page load
useEffect(() => {
2021-07-05 08:32:33 -07:00
const pageLoad = async () => {
await actions.fetchPool()
actions.fetchMints()
2021-07-05 08:32:33 -07:00
}
pageLoad()
}, [])
// refresh usdc vault regularly
useInterval(async () => {
2021-08-11 13:55:05 -07:00
if (endIdo.isAfter()) {
await actions.fetchUsdcVault()
} else {
await actions.fetchMNGOVault()
await actions.fetchRedeemableMint()
}
2021-08-11 12:20:39 -07:00
}, 10 * SECONDS)
2021-04-25 08:03:30 -07:00
2021-07-16 04:50:43 -07:00
return { connected, wallet }
2021-04-25 08:03:30 -07:00
}