import { useMemo } from 'react'; import { useDataProvider } from '@vegaprotocol/data-provider'; import { proposalsDataProvider } from '@vegaprotocol/proposals'; import take from 'lodash/take'; import * as Types from '@vegaprotocol/types'; import { ExternalLink } from '@vegaprotocol/ui-toolkit'; import { DApp, TOKEN_NEW_MARKET_PROPOSAL, TOKEN_PROPOSAL, TOKEN_PROPOSALS, useLinks, } from '@vegaprotocol/environment'; import { useT } from '../../lib/use-t'; export const ProposedMarkets = () => { const t = useT(); const variables = useMemo(() => { return { proposalType: Types.ProposalType.TYPE_NEW_MARKET, }; }, []); const { data } = useDataProvider({ dataProvider: proposalsDataProvider, variables, skipUpdates: true, }); const newMarkets = take( (data || []).filter((proposal) => [ Types.ProposalState.STATE_OPEN, Types.ProposalState.STATE_PASSED, Types.ProposalState.STATE_WAITING_FOR_NODE_VOTE, ].includes(proposal.state) ), 3 ).map((proposal) => ({ id: proposal.id, displayName: proposal.terms.change.__typename === 'NewMarket' && proposal.terms.change.instrument.code, })); const tokenLink = useLinks(DApp.Governance); return useMemo( () => (