1
0
Fork 0
mirror of https://github.com/jellyfin/jellyfin-web synced 2025-03-30 19:56:21 +00:00
jellyfin-web/src/apps/dashboard/AppLayout.tsx

101 lines
3.6 KiB
TypeScript
Raw Normal View History

2023-09-25 02:13:16 -04:00
import AppBar from '@mui/material/AppBar';
import Box from '@mui/material/Box';
2023-11-28 10:26:14 -05:00
import { type Theme } from '@mui/material/styles';
import useMediaQuery from '@mui/material/useMediaQuery';
2024-08-29 01:59:33 -04:00
import { LocalizationProvider } from '@mui/x-date-pickers';
import { AdapterDateFns } from '@mui/x-date-pickers/AdapterDateFns';
import React, { FC, useCallback, useEffect, useState } from 'react';
2023-09-25 02:13:16 -04:00
import { Outlet, useLocation } from 'react-router-dom';
2023-09-20 00:02:26 -04:00
import AppBody from 'components/AppBody';
2023-09-25 13:54:33 -04:00
import AppToolbar from 'components/toolbar/AppToolbar';
2023-09-25 02:13:16 -04:00
import ElevationScroll from 'components/ElevationScroll';
import { DRAWER_WIDTH } from 'components/ResponsiveDrawer';
import { useApi } from 'hooks/useApi';
2024-08-29 01:59:33 -04:00
import { useLocale } from 'hooks/useLocale';
import AppTabs from './components/AppTabs';
2023-09-25 02:13:16 -04:00
import AppDrawer from './components/drawer/AppDrawer';
import { DASHBOARD_APP_PATHS } from './routes/routes';
2023-09-25 02:13:16 -04:00
2023-09-25 13:54:33 -04:00
import './AppOverrides.scss';
const DRAWERLESS_PATHS = [ DASHBOARD_APP_PATHS.MetadataManager ];
2023-09-25 02:13:16 -04:00
export const Component: FC = () => {
2023-11-28 10:26:14 -05:00
const [ isDrawerActive, setIsDrawerActive ] = useState(false);
2023-09-25 02:13:16 -04:00
const location = useLocation();
const { user } = useApi();
2024-08-29 01:59:33 -04:00
const { dateFnsLocale } = useLocale();
2023-09-25 02:13:16 -04:00
2024-01-07 02:48:29 -05:00
const isMediumScreen = useMediaQuery((t: Theme) => t.breakpoints.up('md'));
const isDrawerAvailable = Boolean(user)
&& !DRAWERLESS_PATHS.some(path => location.pathname.startsWith(`/${path}`));
const isDrawerOpen = isDrawerActive && isDrawerAvailable;
2023-09-25 02:13:16 -04:00
const onToggleDrawer = useCallback(() => {
setIsDrawerActive(!isDrawerActive);
}, [ isDrawerActive, setIsDrawerActive ]);
// Update body class
useEffect(() => {
document.body.classList.add('dashboardDocument');
return () => {
document.body.classList.remove('dashboardDocument');
};
}, []);
2023-09-20 00:02:26 -04:00
return (
2024-08-29 01:59:33 -04:00
<LocalizationProvider dateAdapter={AdapterDateFns} adapterLocale={dateFnsLocale}>
<Box sx={{ display: 'flex' }}>
<ElevationScroll elevate={false}>
<AppBar
position='fixed'
sx={{
width: {
xs: '100%',
md: isDrawerAvailable ? `calc(100% - ${DRAWER_WIDTH}px)` : '100%'
},
ml: {
xs: 0,
md: isDrawerAvailable ? DRAWER_WIDTH : 0
}
}}
>
2024-08-29 01:59:33 -04:00
<AppToolbar
isDrawerAvailable={!isMediumScreen && isDrawerAvailable}
isDrawerOpen={isDrawerOpen}
onDrawerButtonClick={onToggleDrawer}
>
<AppTabs isDrawerOpen={isDrawerOpen} />
</AppToolbar>
</AppBar>
</ElevationScroll>
2023-09-25 02:13:16 -04:00
2024-08-29 01:59:33 -04:00
{
isDrawerAvailable && (
<AppDrawer
open={isDrawerOpen}
onClose={onToggleDrawer}
onOpen={onToggleDrawer}
/>
)
}
2023-09-25 02:13:16 -04:00
2024-08-29 01:59:33 -04:00
<Box
component='main'
sx={{
width: '100%',
flexGrow: 1
}}
>
<AppBody>
<Outlet />
</AppBody>
</Box>
2023-09-25 02:13:16 -04:00
</Box>
2024-08-29 01:59:33 -04:00
</LocalizationProvider>
2023-09-20 00:02:26 -04:00
);
};