2023-07-24 08:37:18 +00:00
|
|
|
import { Outlet, Routes, Route } from 'react-router-dom';
|
|
|
|
import { Sidebar, SidebarContent, useSidebar } from '../sidebar';
|
|
|
|
import classNames from 'classnames';
|
|
|
|
import { MarketHeader } from '../market-header';
|
|
|
|
import { LiquidityHeader } from '../liquidity-header';
|
2023-09-15 12:36:08 +00:00
|
|
|
import { useGetCurrentRouteId } from '../../lib/hooks/use-get-current-route-id';
|
2023-07-24 08:37:18 +00:00
|
|
|
|
|
|
|
export const LayoutWithSidebar = () => {
|
2023-09-15 12:36:08 +00:00
|
|
|
const currentRouteId = useGetCurrentRouteId();
|
|
|
|
const views = useSidebar((store) => store.views);
|
|
|
|
const sidebarView = views[currentRouteId] || null;
|
2023-07-24 08:37:18 +00:00
|
|
|
const sidebarOpen = sidebarView !== null;
|
|
|
|
const gridClasses = classNames(
|
|
|
|
'h-full relative z-0 grid',
|
2023-07-31 16:08:55 +00:00
|
|
|
'grid-rows-[min-content_1fr_40px]',
|
|
|
|
'lg:grid-rows-[min-content_1fr]',
|
2023-09-15 12:24:47 +00:00
|
|
|
'lg:grid-cols-[1fr_280px_40px]',
|
|
|
|
'xxxl:grid-cols-[1fr_320px_40px]'
|
2023-07-24 08:37:18 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
return (
|
|
|
|
<div className={gridClasses}>
|
|
|
|
<div className="col-span-full">
|
|
|
|
<Routes>
|
2023-09-20 20:28:34 +00:00
|
|
|
<Route path="markets/:marketId" element={<MarketHeader />} />
|
2023-10-03 10:08:30 +00:00
|
|
|
<Route
|
|
|
|
path="markets/all/closed/:marketId"
|
|
|
|
element={<MarketHeader />}
|
|
|
|
/>
|
2023-09-20 20:28:34 +00:00
|
|
|
<Route path="liquidity/:marketId" element={<LiquidityHeader />} />
|
2023-07-24 08:37:18 +00:00
|
|
|
</Routes>
|
|
|
|
</div>
|
|
|
|
<main
|
|
|
|
className={classNames('col-start-1 col-end-1', {
|
|
|
|
'lg:col-end-3': !sidebarOpen,
|
|
|
|
'hidden lg:block lg:col-end-2': sidebarOpen,
|
|
|
|
})}
|
|
|
|
>
|
|
|
|
<Outlet />
|
|
|
|
</main>
|
|
|
|
<aside
|
|
|
|
// min-h-0 is needed as this element is part of a grid, we want the content to be scrollable, without it it will push the grid element taller
|
2023-10-13 18:30:04 +00:00
|
|
|
className={classNames(
|
|
|
|
'col-start-1 lg:col-start-2 min-h-0 lg:border-l border-default lg:bg-vega-clight-800 dark:lg:bg-vega-cdark-800',
|
|
|
|
{
|
|
|
|
hidden: !sidebarOpen,
|
|
|
|
}
|
|
|
|
)}
|
2023-07-24 08:37:18 +00:00
|
|
|
>
|
|
|
|
<SidebarContent />
|
|
|
|
</aside>
|
2023-07-31 16:08:55 +00:00
|
|
|
<div
|
|
|
|
className={classNames(
|
|
|
|
'bg-vega-clight-800 dark:bg-vega-cdark-800',
|
|
|
|
'border-t lg:border-l lg:border-t-0 border-default',
|
|
|
|
'row-start-3 col-start-1 cols-span-full',
|
|
|
|
'lg:row-start-2 lg:row-span-full lg:col-start-3'
|
|
|
|
)}
|
|
|
|
>
|
2023-07-24 08:37:18 +00:00
|
|
|
<Sidebar />
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
};
|