import type { ReactNode } from 'react'; import { useState } from 'react'; import { format, formatDuration, intervalToDuration } from 'date-fns'; import { ExternalLink, Intent, NotificationBanner, } from '@vegaprotocol/ui-toolkit'; import type { MarketViewProposalFieldsFragment } from '@vegaprotocol/proposals'; import { marketViewProposalsDataProvider } from '@vegaprotocol/proposals'; import * as Types from '@vegaprotocol/types'; import type { Market } from '@vegaprotocol/markets'; import { getQuoteName } from '@vegaprotocol/markets'; import { addDecimalsFormatNumber } from '@vegaprotocol/utils'; import sortBy from 'lodash/sortBy'; import { DApp, TOKEN_PROPOSAL, TOKEN_PROPOSALS, useLinks, } from '@vegaprotocol/environment'; import { useDataProvider } from '@vegaprotocol/data-provider'; import { useT } from '../../lib/use-t'; const filterProposals = ( data: MarketViewProposalFieldsFragment[] | null, marketId: string, now: number ) => sortBy( (data || []).filter( (item) => item.terms.change.__typename === 'UpdateMarketState' && item.terms.change.market.id === marketId && item.terms.change.updateType === Types.MarketUpdateType.MARKET_STATE_UPDATE_TYPE_TERMINATE && item.terms.enactmentDatetime && new Date(item.terms.enactmentDatetime).getTime() > now ), (item) => item.terms.enactmentDatetime ); const getMessageVariables = (proposal: MarketViewProposalFieldsFragment) => { const enactmentDatetime = new Date(proposal.terms.enactmentDatetime); const date = format(enactmentDatetime, 'dd MMMM'); const duration = formatDuration( intervalToDuration({ start: new Date(), end: enactmentDatetime, }), { format: ['days', 'hours'], } ); const price = proposal.terms.change.__typename === 'UpdateMarketState' ? proposal.terms.change.price : ''; return { date, duration, price, }; }; export const MarketTerminationBanner = ({ market, }: { market: Market | null; }) => { const t = useT(); const [visible, setVisible] = useState(true); const skip = !market || !visible; const { data: passedProposalsData } = useDataProvider({ dataProvider: marketViewProposalsDataProvider, skip, variables: { inState: Types.ProposalState.STATE_PASSED, proposalType: Types.ProposalType.TYPE_UPDATE_MARKET_STATE, }, }); const { data: openProposalsData } = useDataProvider({ dataProvider: marketViewProposalsDataProvider, skip, variables: { inState: Types.ProposalState.STATE_OPEN, proposalType: Types.ProposalType.TYPE_UPDATE_MARKET_STATE, }, }); const governanceLink = useLinks(DApp.Governance); if (!market) return null; const now = Date.now(); const passedProposals = filterProposals(passedProposalsData, market.id, now); const openProposals = filterProposals(openProposalsData, market.id, now); const name = market.tradableInstrument.instrument.code; if (!passedProposals.length && !openProposals.length) { return null; } const assetSymbol = getQuoteName(market); const proposalLink = !passedProposals.length && openProposals[0]?.id ? governanceLink(TOKEN_PROPOSAL.replace(':id', openProposals[0]?.id)) : undefined; const proposalsLink = openProposals.length > 1 ? governanceLink(TOKEN_PROPOSALS) : undefined; let content: ReactNode; if (passedProposals.length) { const { date, duration, price } = getMessageVariables(passedProposals[0]); content = ( <>