import type { RouteObject } from 'react-router-dom'; import { Navigate, useRoutes } from 'react-router-dom'; import { lazy, Suspense } from 'react'; import { Loader, Splash } from '@vegaprotocol/ui-toolkit'; import { LayoutWithSidebar } from '../components/layouts'; import { LayoutCentered } from '../components/layouts/layout-centered'; import { Home } from '../client-pages/home'; import { Liquidity } from '../client-pages/liquidity'; import { MarketsPage } from '../client-pages/markets'; import { Disclaimer } from '../client-pages/disclaimer'; import { Assets } from '../client-pages/assets'; import { Deposit } from '../client-pages/deposit'; import { Withdraw } from '../client-pages/withdraw'; import { Transfer } from '../client-pages/transfer'; import { Fees } from '../client-pages/fees'; import { Rewards } from '../client-pages/rewards'; import { Routes as AppRoutes } from '../lib/links'; import { LayoutWithSky } from '../client-pages/referrals/layout'; import { Referrals } from '../client-pages/referrals/referrals'; import { ReferralStatistics } from '../client-pages/referrals/referral-statistics'; import { ApplyCodeFormContainer } from '../client-pages/referrals/apply-code-form'; import { CreateCodeContainer } from '../client-pages/referrals/create-code-form'; import { NotFound as ReferralNotFound } from '../client-pages/referrals/error-boundary'; import { compact } from 'lodash'; import { FLAGS } from '@vegaprotocol/environment'; import { LiquidityHeader } from '../components/liquidity-header'; import { MarketHeader } from '../components/market-header'; import { PortfolioSidebar } from '../client-pages/portfolio/portfolio-sidebar'; import { LiquiditySidebar } from '../client-pages/liquidity/liquidity-sidebar'; import { MarketsSidebar } from '../client-pages/markets/markets-sidebar'; import { useT } from '../lib/use-t'; // These must remain dynamically imported as pennant cannot be compiled by nextjs due to ESM // Using dynamic imports is a workaround for this until pennant is published as ESM const MarketPage = lazy(() => import('../client-pages/market')); const Portfolio = lazy(() => import('../client-pages/portfolio')); const NotFound = () => { const t = useT(); return (

{t('Page not found')}

); }; export const routerConfig: RouteObject[] = compact([ { index: true, element: , id: AppRoutes.HOME, }, { path: 'disclaimer', element: , id: AppRoutes.DISCLAIMER, children: [{ index: true, element: }], }, // Referrals routing (the pages should be available if the feature flag is on) FLAGS.REFERRALS ? { path: AppRoutes.REFERRALS, element: } />, children: [ { element: ( ), children: [ { index: true, element: , }, { path: AppRoutes.REFERRALS_CREATE_CODE, element: , }, { path: AppRoutes.REFERRALS_APPLY_CODE, element: , }, ], }, { path: '*', element: , }, ], } : undefined, { path: 'fees/*', element: } />, children: [ { index: true, element: , }, ], }, { path: 'rewards/*', element: } />, children: [ { index: true, element: , }, ], }, { path: 'markets/*', element: ( } sidebar={} /> ), children: [ { index: true, element: , id: AppRoutes.MARKETS, }, { path: 'all', element: , }, { path: ':marketId', element: , id: AppRoutes.MARKET, }, ], }, { path: 'portfolio/*', element: } />, children: [ { index: true, element: , id: AppRoutes.PORTFOLIO, }, { path: 'assets', element: , id: AppRoutes.ASSETS, children: [ { index: true, element: }, { path: 'deposit', element: , id: AppRoutes.DEPOSIT }, { path: 'withdraw', element: , id: AppRoutes.WITHDRAW }, { path: 'transfer', element: , id: AppRoutes.TRANSFER }, ], }, ], }, { path: 'liquidity/*', element: ( } sidebar={} /> ), id: AppRoutes.LIQUIDITY, children: [ { path: ':marketId', element: , }, ], }, { path: '*', element: , }, ]); export const ClientRouter = () => { const routes = useRoutes(routerConfig); return ( } > {routes} ); };