From 5206ce6339defe6a4cff55320e914e031f8e7b0b Mon Sep 17 00:00:00 2001 From: WRadoslaw Date: Wed, 11 Oct 2023 15:33:10 +0200 Subject: [PATCH] Initial work on CrtHoldersTab.tsx --- .../CrtDashboard/tabs/CrtHoldersTab.tsx | 50 +++++++++++++------ 1 file changed, 36 insertions(+), 14 deletions(-) diff --git a/packages/atlas/src/views/studio/CrtDashboard/tabs/CrtHoldersTab.tsx b/packages/atlas/src/views/studio/CrtDashboard/tabs/CrtHoldersTab.tsx index 863017c997..c4ae1ffdc4 100644 --- a/packages/atlas/src/views/studio/CrtDashboard/tabs/CrtHoldersTab.tsx +++ b/packages/atlas/src/views/studio/CrtDashboard/tabs/CrtHoldersTab.tsx @@ -1,19 +1,41 @@ +import { useMemo } from 'react' + +import { useGetCreatorTokenHoldersQuery } from '@/api/queries/__generated__/creatorTokens.generated' +import { FullCreatorTokenFragment } from '@/api/queries/__generated__/fragments.generated' import { HoldersTable } from '@/components/_crt/HoldersTable/HoldersTable' -export const CrtHoldersTab = () => { - return ( - { + const { data } = useGetCreatorTokenHoldersQuery({ + variables: { + where: { + token: { + id_eq: token.id, }, - ]} - isLoading={true} - currentMemberId="1" - /> + }, + }, + }) + + const mappedData = useMemo( + () => + data?.tokenAccounts + ? data.tokenAccounts.map((holder) => ({ + member: holder.member, + transferable: +holder.totalAmount - +(holder.stakedAmount ?? 0), + allocation: Math.round((+holder.totalAmount / +token.totalSupply) * 100), + total: +holder.totalAmount, + vested: +( + holder.vestingSchedules.find( + (vesting) => vesting.vestingSource.__typename === 'InitialIssuanceVestingSource' + )?.totalVestingAmount ?? 0 + ), + })) + : [], + [data?.tokenAccounts, token.totalSupply] ) + + return }