2023-09-05 00:21:46 +00:00
|
|
|
import {
|
|
|
|
LocalStoragePersistTabs as Tabs,
|
|
|
|
Tab,
|
|
|
|
TradingAnchorButton,
|
|
|
|
} from '@vegaprotocol/ui-toolkit';
|
2023-09-12 18:52:03 +00:00
|
|
|
import { OpenMarkets } from './open-markets';
|
2022-11-16 14:36:03 +00:00
|
|
|
import { Proposed } from './proposed';
|
2023-05-02 17:41:21 +00:00
|
|
|
import { Closed } from './closed';
|
2023-09-05 00:21:46 +00:00
|
|
|
import {
|
|
|
|
DApp,
|
|
|
|
TOKEN_NEW_MARKET_PROPOSAL,
|
|
|
|
useLinks,
|
|
|
|
} from '@vegaprotocol/environment';
|
2023-11-16 03:10:39 +00:00
|
|
|
import { useT } from '../../lib/use-t';
|
2023-12-06 13:31:40 +00:00
|
|
|
import { ErrorBoundary } from '../../components/error-boundary';
|
2023-12-28 12:33:18 +00:00
|
|
|
import { MarketsSettings } from './markets-settings';
|
2024-02-13 16:17:00 +00:00
|
|
|
import { usePageTitle } from '../../lib/hooks/use-page-title';
|
2022-11-16 14:36:03 +00:00
|
|
|
|
|
|
|
export const MarketsPage = () => {
|
2023-11-16 03:10:39 +00:00
|
|
|
const t = useT();
|
2023-09-14 20:57:15 +00:00
|
|
|
const governanceLink = useLinks(DApp.Governance);
|
|
|
|
const externalLink = governanceLink(TOKEN_NEW_MARKET_PROPOSAL);
|
2023-09-05 00:21:46 +00:00
|
|
|
|
2024-02-13 16:17:00 +00:00
|
|
|
usePageTitle(t('Markets'));
|
2023-09-05 00:21:46 +00:00
|
|
|
|
2022-11-16 14:36:03 +00:00
|
|
|
return (
|
2023-07-24 08:37:18 +00:00
|
|
|
<div className="h-full pt-0.5 pb-3 px-1.5">
|
2023-09-05 00:21:46 +00:00
|
|
|
<div className="h-full my-1 border rounded-sm border-default">
|
2023-07-24 08:37:18 +00:00
|
|
|
<Tabs storageKey="console-markets">
|
2023-12-28 12:33:18 +00:00
|
|
|
<Tab
|
|
|
|
id="open-markets"
|
|
|
|
name={t('Open markets')}
|
|
|
|
settings={<MarketsSettings />}
|
|
|
|
>
|
2023-12-06 13:31:40 +00:00
|
|
|
<ErrorBoundary feature="markets-open">
|
|
|
|
<OpenMarkets />
|
|
|
|
</ErrorBoundary>
|
2023-07-24 08:37:18 +00:00
|
|
|
</Tab>
|
2023-09-05 00:21:46 +00:00
|
|
|
<Tab
|
|
|
|
id="proposed-markets"
|
|
|
|
name={t('Proposed markets')}
|
2023-12-28 12:33:18 +00:00
|
|
|
settings={<MarketsSettings />}
|
2023-09-05 00:21:46 +00:00
|
|
|
menu={
|
2023-09-07 09:25:26 +00:00
|
|
|
<TradingAnchorButton
|
|
|
|
size="extra-small"
|
|
|
|
data-testid="propose-new-market"
|
|
|
|
href={externalLink}
|
2024-01-15 15:26:13 +00:00
|
|
|
target="_blank"
|
2023-09-07 09:25:26 +00:00
|
|
|
>
|
2023-09-05 00:21:46 +00:00
|
|
|
{t('Propose a new market')}
|
|
|
|
</TradingAnchorButton>
|
|
|
|
}
|
|
|
|
>
|
2023-12-06 13:31:40 +00:00
|
|
|
<ErrorBoundary feature="markets-proposed">
|
|
|
|
<Proposed />
|
|
|
|
</ErrorBoundary>
|
2023-07-24 08:37:18 +00:00
|
|
|
</Tab>
|
2023-12-28 12:33:18 +00:00
|
|
|
<Tab
|
|
|
|
id="closed-markets"
|
|
|
|
name={t('Closed markets')}
|
|
|
|
settings={<MarketsSettings />}
|
|
|
|
>
|
2023-12-06 13:31:40 +00:00
|
|
|
<ErrorBoundary feature="markets-closed">
|
|
|
|
<Closed />
|
|
|
|
</ErrorBoundary>
|
2023-07-24 08:37:18 +00:00
|
|
|
</Tab>
|
|
|
|
</Tabs>
|
|
|
|
</div>
|
|
|
|
</div>
|
2022-11-16 14:36:03 +00:00
|
|
|
);
|
|
|
|
};
|