2023-12-20 22:06:22 +00:00
|
|
|
import { createContext, useContext, useMemo } from 'react'
|
|
|
|
import { useQuery } from '@apollo/client'
|
2024-03-20 00:37:31 +00:00
|
|
|
import { SSR } from '@/lib/constants'
|
|
|
|
import { CHAIN_FEE } from '@/fragments/chainFee'
|
2023-12-20 22:06:22 +00:00
|
|
|
|
|
|
|
export const ChainFeeContext = createContext({
|
|
|
|
fee: 0
|
|
|
|
})
|
|
|
|
|
|
|
|
export const useChainFee = () => useContext(ChainFeeContext)
|
|
|
|
|
|
|
|
export const ChainFeeProvider = ({ chainFee, children }) => {
|
|
|
|
const { data } = useQuery(CHAIN_FEE, {
|
|
|
|
...(SSR
|
|
|
|
? {}
|
|
|
|
: {
|
|
|
|
pollInterval: 30000,
|
|
|
|
nextFetchPolicy: 'cache-and-network'
|
|
|
|
})
|
|
|
|
})
|
|
|
|
const value = useMemo(() => ({
|
2023-12-21 23:45:03 +00:00
|
|
|
fee: Math.floor(data?.chainFee ?? chainFee ?? 0)
|
2024-03-06 19:53:46 +00:00
|
|
|
}), [data?.chainFee, chainFee])
|
2023-12-20 22:06:22 +00:00
|
|
|
return (
|
|
|
|
<ChainFeeContext.Provider value={value}>
|
|
|
|
{children}
|
|
|
|
</ChainFeeContext.Provider>
|
|
|
|
)
|
|
|
|
}
|