mars-v2-frontend/src/hooks/queries/useCreditAccounts.tsx
Linkie Link 6efa380a98
Ux and details update (#77)
* fix: added the metadata base

* tidy: refactor the config structure

* fix: fixed the denom and fetching shenanigans

* fix: get rid of injective

* fix: removed logs

* tidy: updated dependencies

* fix: replaced static fallbacks with networkConfig.asset.base

* fix: remove memo

* tidy: added TODO comment

* fix: fixed the accountDetails

* fix: fixed the wallet connector suffix
2022-12-23 12:23:00 +01:00

51 lines
1.4 KiB
TypeScript

import { useQuery } from '@tanstack/react-query'
import { useMemo } from 'react'
import { useAccountDetailsStore, useNetworkConfigStore, useWalletStore } from 'stores'
import { queryKeys } from 'types/query-keys-factory'
type Result = {
tokens: string[]
}
export const useCreditAccounts = () => {
const address = useWalletStore((s) => s.address)
const client = useWalletStore((s) => s.signingClient)
const selectedAccount = useAccountDetailsStore((s) => s.selectedAccount)
const accountNftAddress = useNetworkConfigStore((s) => s.contracts.accountNft)
const setSelectedAccount = (account: string) => {
useAccountDetailsStore.setState({ selectedAccount: account })
}
const queryMsg = useMemo(() => {
return {
tokens: {
owner: address,
},
}
}, [address])
const result = useQuery<Result>(
queryKeys.creditAccounts(address ?? ''),
async () => client?.queryContractSmart(accountNftAddress, queryMsg),
{
staleTime: Infinity,
enabled: !!address && !!client,
onSuccess: (data) => {
if (!data.tokens.includes(selectedAccount || '') && data.tokens.length > 0) {
setSelectedAccount(data.tokens[0])
}
},
},
)
return {
...result,
data: useMemo(() => {
if (!address) return []
return result?.data && result.data.tokens
}, [address, result?.data]),
}
}