2023-11-16 17:08:20 +00:00
|
|
|
import { Route, Routes } from 'react-router-dom';
|
2023-10-16 18:18:26 +00:00
|
|
|
import { VegaIconNames } from '@vegaprotocol/ui-toolkit';
|
|
|
|
import {
|
|
|
|
SidebarButton,
|
|
|
|
SidebarDivider,
|
|
|
|
ViewType,
|
2023-12-14 14:12:19 +00:00
|
|
|
useSidebar,
|
2023-10-16 18:18:26 +00:00
|
|
|
} from '../../components/sidebar';
|
|
|
|
import { useGetCurrentRouteId } from '../../lib/hooks/use-get-current-route-id';
|
2023-11-16 03:10:39 +00:00
|
|
|
import { useT } from '../../lib/use-t';
|
2023-12-14 14:12:19 +00:00
|
|
|
import { useScreenDimensions } from '@vegaprotocol/react-helpers';
|
|
|
|
import { useEffect } from 'react';
|
|
|
|
|
|
|
|
const ViewInitializer = () => {
|
|
|
|
const currentRouteId = useGetCurrentRouteId();
|
|
|
|
const { setViews, getView } = useSidebar();
|
|
|
|
const view = getView(currentRouteId);
|
|
|
|
const { screenSize } = useScreenDimensions();
|
|
|
|
const largeScreen = ['lg', 'xl', 'xxl', 'xxxl'].includes(screenSize);
|
|
|
|
useEffect(() => {
|
|
|
|
if (largeScreen && view === undefined) {
|
|
|
|
setViews({ type: ViewType.Order }, currentRouteId);
|
|
|
|
}
|
|
|
|
}, [setViews, view, currentRouteId, largeScreen]);
|
|
|
|
return null;
|
|
|
|
};
|
2023-10-16 18:18:26 +00:00
|
|
|
|
|
|
|
export const MarketsSidebar = () => {
|
2023-11-16 03:10:39 +00:00
|
|
|
const t = useT();
|
2023-10-16 18:18:26 +00:00
|
|
|
const currentRouteId = useGetCurrentRouteId();
|
|
|
|
|
|
|
|
return (
|
|
|
|
<>
|
|
|
|
<SidebarButton
|
|
|
|
view={ViewType.Deposit}
|
|
|
|
icon={VegaIconNames.DEPOSIT}
|
|
|
|
tooltip={t('Deposit')}
|
|
|
|
routeId={currentRouteId}
|
|
|
|
/>
|
|
|
|
<SidebarButton
|
|
|
|
view={ViewType.Withdraw}
|
|
|
|
icon={VegaIconNames.WITHDRAW}
|
|
|
|
tooltip={t('Withdraw')}
|
|
|
|
routeId={currentRouteId}
|
|
|
|
/>
|
|
|
|
<SidebarButton
|
|
|
|
view={ViewType.Transfer}
|
|
|
|
icon={VegaIconNames.TRANSFER}
|
|
|
|
tooltip={t('Transfer')}
|
|
|
|
routeId={currentRouteId}
|
|
|
|
/>
|
|
|
|
<Routes>
|
|
|
|
<Route
|
|
|
|
path=":marketId"
|
|
|
|
element={
|
|
|
|
<>
|
2023-12-14 14:12:19 +00:00
|
|
|
<ViewInitializer />
|
2023-10-16 18:18:26 +00:00
|
|
|
<SidebarDivider />
|
2023-11-16 17:08:20 +00:00
|
|
|
<SidebarButton
|
|
|
|
view={ViewType.Order}
|
|
|
|
icon={VegaIconNames.TICKET}
|
|
|
|
tooltip={t('Order')}
|
|
|
|
routeId={currentRouteId}
|
|
|
|
/>
|
2023-10-16 18:18:26 +00:00
|
|
|
<SidebarButton
|
|
|
|
view={ViewType.Info}
|
|
|
|
icon={VegaIconNames.BREAKDOWN}
|
|
|
|
tooltip={t('Market specification')}
|
|
|
|
routeId={currentRouteId}
|
|
|
|
/>
|
|
|
|
</>
|
|
|
|
}
|
|
|
|
/>
|
|
|
|
</Routes>
|
|
|
|
</>
|
|
|
|
);
|
|
|
|
};
|