diff --git a/src/hooks/use-query.ts b/src/hooks/use-query.ts index bab8578..657a21c 100644 --- a/src/hooks/use-query.ts +++ b/src/hooks/use-query.ts @@ -109,14 +109,16 @@ export function useGroupHistoricalProposals(groupId?: string) { if (!client) { throw Error('graphql client not initialized') } - const proposals = await Promise.all( - policyIds.map(async (address) => { - const res = await client.request(ProposalsByGroupPolicyAddressDocument, { - groupPolicyAddress: address, - }) - return res.allProposals?.nodes.map((p) => { - const proposal = getFragmentData(ProposalItemFragmentDoc, p) - if (proposal) { + const result = [] + for (const address of policyIds) { + const res = await client.request(ProposalsByGroupPolicyAddressDocument, { + groupPolicyAddress: address, + }) + if (!!res.allProposals && !!res.allProposals.nodes) { + const { nodes } = res.allProposals + for (const node of nodes) { + const proposal = getFragmentData(ProposalItemFragmentDoc, node) + if (!!proposal) { const executorResult = { PROPOSAL_EXECUTOR_RESULT_UNSPECIFIED: 0, @@ -140,12 +142,12 @@ export function useGroupHistoricalProposals(groupId?: string) { votingPeriodEnd: proposal.votingPeriodEnd, historical: true, } - return uiProposal + result.push(uiProposal) } - }) - }), - ) - return proposals.flat() + } + } + } + return result }, enabled: !isLoading, }) diff --git a/src/pages/group-page.tsx b/src/pages/group-page.tsx index f242562..23177b0 100644 --- a/src/pages/group-page.tsx +++ b/src/pages/group-page.tsx @@ -35,10 +35,7 @@ export default function GroupPage() { isRefetching: isRefetchingBalances, } = useBalances(groupPolicy?.address) - const derivedProposals = useDerivedProposals( - proposals, - historicalProposals as UIProposal[], - ) + const derivedProposals = useDerivedProposals(proposals, historicalProposals) if ( isLoadingGroup ||