1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586 |
- import { h, Fragment } from 'preact';
- import BaseAppBar from './components/AppBar';
- import LinkedLogo from './components/LinkedLogo';
- import Menu, { MenuItem, MenuSeparator } from './components/Menu';
- import AutoAwesomeIcon from './icons/AutoAwesome';
- import LightModeIcon from './icons/LightMode';
- import DarkModeIcon from './icons/DarkMode';
- import FrigateRestartIcon from './icons/FrigateRestart';
- import Dialog from './components/Dialog';
- import { useDarkMode } from './context';
- import { useCallback, useRef, useState } from 'preact/hooks';
- import { useRestart } from './api/mqtt';
- export default function AppBar() {
- const [showMoreMenu, setShowMoreMenu] = useState(false);
- const [showDialog, setShowDialog] = useState(false);
- const [showDialogWait, setShowDialogWait] = useState(false);
- const { setDarkMode } = useDarkMode();
- const { send: sendRestart } = useRestart();
- const handleSelectDarkMode = useCallback(
- (value, label) => {
- setDarkMode(value);
- setShowMoreMenu(false);
- },
- [setDarkMode, setShowMoreMenu]
- );
- const moreRef = useRef(null);
- const handleShowMenu = useCallback(() => {
- setShowMoreMenu(true);
- }, [setShowMoreMenu]);
- const handleDismissMoreMenu = useCallback(() => {
- setShowMoreMenu(false);
- }, [setShowMoreMenu]);
- const handleClickRestartDialog = useCallback(() => {
- setShowDialog(false);
- setShowDialogWait(true);
- sendRestart();
- }, [setShowDialog]); // eslint-disable-line react-hooks/exhaustive-deps
- const handleDismissRestartDialog = useCallback(() => {
- setShowDialog(false);
- }, [setShowDialog]);
- const handleRestart = useCallback(() => {
- setShowMoreMenu(false);
- setShowDialog(true);
- }, [setShowDialog]);
- return (
- <Fragment>
- <BaseAppBar title={LinkedLogo} overflowRef={moreRef} onOverflowClick={handleShowMenu} />
- {showMoreMenu ? (
- <Menu onDismiss={handleDismissMoreMenu} relativeTo={moreRef}>
- <MenuItem icon={AutoAwesomeIcon} label="Auto dark mode" value="media" onSelect={handleSelectDarkMode} />
- <MenuSeparator />
- <MenuItem icon={LightModeIcon} label="Light" value="light" onSelect={handleSelectDarkMode} />
- <MenuItem icon={DarkModeIcon} label="Dark" value="dark" onSelect={handleSelectDarkMode} />
- <MenuSeparator />
- <MenuItem icon={FrigateRestartIcon} label="Restart Frigate" onSelect={handleRestart} />
- </Menu>
- ) : null}
- {showDialog ? (
- <Dialog
- onDismiss={handleDismissRestartDialog}
- title="Restart Frigate"
- text="Are you sure?"
- actions={[
- { text: 'Yes', color: 'red', onClick: handleClickRestartDialog },
- { text: 'Cancel', onClick: handleDismissRestartDialog },
- ]}
- />
- ) : null}
- {showDialogWait ? (
- <Dialog
- title="Restart in progress"
- text="Please wait a few seconds for the restart to complete before reloading the page."
- />
- ) : null}
- </Fragment>
- );
- }
|