mirror of
https://github.com/jellyfin/jellyfin-web
synced 2025-03-30 19:56:21 +00:00

Fix video osd not hiding in experimental layout
Original-merge: ea1d069e90
Merged-by: thornbill <thornbill@users.noreply.github.com>
Backported-by: Joshua M. Boniface <joshua@boniface.me>
97 lines
3 KiB
TypeScript
97 lines
3 KiB
TypeScript
import ArrowBack from '@mui/icons-material/ArrowBack';
|
|
import MenuIcon from '@mui/icons-material/Menu';
|
|
import Box from '@mui/material/Box';
|
|
import IconButton from '@mui/material/IconButton';
|
|
import Toolbar from '@mui/material/Toolbar';
|
|
import Tooltip from '@mui/material/Tooltip';
|
|
import React, { FC, ReactNode } from 'react';
|
|
|
|
import { appRouter } from 'components/router/appRouter';
|
|
import { useApi } from 'hooks/useApi';
|
|
import globalize from 'scripts/globalize';
|
|
|
|
import UserMenuButton from './UserMenuButton';
|
|
|
|
interface AppToolbarProps {
|
|
buttons?: ReactNode
|
|
isDrawerAvailable: boolean
|
|
isDrawerOpen: boolean
|
|
onDrawerButtonClick?: (event: React.MouseEvent<HTMLElement>) => void,
|
|
isUserMenuAvailable?: boolean
|
|
}
|
|
|
|
const onBackButtonClick = () => {
|
|
appRouter.back()
|
|
.catch(err => {
|
|
console.error('[AppToolbar] error calling appRouter.back', err);
|
|
});
|
|
};
|
|
|
|
const AppToolbar: FC<AppToolbarProps> = ({
|
|
buttons,
|
|
children,
|
|
isDrawerAvailable,
|
|
isDrawerOpen,
|
|
onDrawerButtonClick = () => { /* no-op */ },
|
|
isUserMenuAvailable = true
|
|
}) => {
|
|
const { user } = useApi();
|
|
const isUserLoggedIn = Boolean(user);
|
|
|
|
const isBackButtonAvailable = appRouter.canGoBack();
|
|
|
|
return (
|
|
<Toolbar
|
|
variant='dense'
|
|
sx={{
|
|
flexWrap: {
|
|
xs: 'wrap',
|
|
lg: 'nowrap'
|
|
}
|
|
}}
|
|
>
|
|
{isUserLoggedIn && isDrawerAvailable && (
|
|
<Tooltip title={globalize.translate(isDrawerOpen ? 'MenuClose' : 'MenuOpen')}>
|
|
<IconButton
|
|
size='large'
|
|
edge='start'
|
|
color='inherit'
|
|
aria-label={globalize.translate(isDrawerOpen ? 'MenuClose' : 'MenuOpen')}
|
|
onClick={onDrawerButtonClick}
|
|
>
|
|
<MenuIcon />
|
|
</IconButton>
|
|
</Tooltip>
|
|
)}
|
|
|
|
{isBackButtonAvailable && (
|
|
<Tooltip title={globalize.translate('ButtonBack')}>
|
|
<IconButton
|
|
size='large'
|
|
// Set the edge if the drawer button is not shown
|
|
edge={!(isUserLoggedIn && isDrawerAvailable) ? 'start' : undefined}
|
|
color='inherit'
|
|
aria-label={globalize.translate('ButtonBack')}
|
|
onClick={onBackButtonClick}
|
|
>
|
|
<ArrowBack />
|
|
</IconButton>
|
|
</Tooltip>
|
|
)}
|
|
|
|
{children}
|
|
|
|
<Box sx={{ display: 'flex', flexGrow: 1, justifyContent: 'flex-end' }}>
|
|
{buttons}
|
|
</Box>
|
|
|
|
{isUserLoggedIn && isUserMenuAvailable && (
|
|
<Box sx={{ flexGrow: 0 }}>
|
|
<UserMenuButton />
|
|
</Box>
|
|
)}
|
|
</Toolbar>
|
|
);
|
|
};
|
|
|
|
export default AppToolbar;
|