|
@@ -1,8 +1,11 @@
|
|
import { h } from 'preact';
|
|
import { h } from 'preact';
|
|
import Button from './Button';
|
|
import Button from './Button';
|
|
import LinkedLogo from './LinkedLogo';
|
|
import LinkedLogo from './LinkedLogo';
|
|
|
|
+import Menu, { MenuItem } from './Menu';
|
|
import MenuIcon from '../icons/Menu';
|
|
import MenuIcon from '../icons/Menu';
|
|
-import { useLayoutEffect, useCallback, useState } from 'preact/hooks';
|
|
|
|
|
|
+import MoreIcon from '../icons/More';
|
|
|
|
+import { useDarkMode } from '../context';
|
|
|
|
+import { useLayoutEffect, useCallback, useRef, useState } from 'preact/hooks';
|
|
|
|
|
|
// We would typically preserve these in component state
|
|
// We would typically preserve these in component state
|
|
// But need to avoid too many re-renders
|
|
// But need to avoid too many re-renders
|
|
@@ -13,6 +16,18 @@ export default function AppBar({ title }) {
|
|
const [show, setShow] = useState(true);
|
|
const [show, setShow] = useState(true);
|
|
const [atZero, setAtZero] = useState(window.scrollY === 0);
|
|
const [atZero, setAtZero] = useState(window.scrollY === 0);
|
|
const [sidebarVisible, setSidebarVisible] = useState(true);
|
|
const [sidebarVisible, setSidebarVisible] = useState(true);
|
|
|
|
+ const [showMoreMenu, setShowMoreMenu] = useState(false);
|
|
|
|
+ const { currentMode, persistedMode, setDarkMode } = useDarkMode();
|
|
|
|
+
|
|
|
|
+ const handleSelectDarkMode = useCallback(
|
|
|
|
+ (value, label) => {
|
|
|
|
+ setDarkMode(value);
|
|
|
|
+ setShowMoreMenu(false);
|
|
|
|
+ },
|
|
|
|
+ [setDarkMode, setShowMoreMenu]
|
|
|
|
+ );
|
|
|
|
+
|
|
|
|
+ const moreRef = useRef(null);
|
|
|
|
|
|
const scrollListener = useCallback(
|
|
const scrollListener = useCallback(
|
|
(event) => {
|
|
(event) => {
|
|
@@ -38,9 +53,17 @@ export default function AppBar({ title }) {
|
|
};
|
|
};
|
|
}, []);
|
|
}, []);
|
|
|
|
|
|
|
|
+ const handleShowMenu = useCallback(() => {
|
|
|
|
+ setShowMoreMenu(true);
|
|
|
|
+ }, [setShowMoreMenu]);
|
|
|
|
+
|
|
|
|
+ const handleDismissMoreMenu = useCallback(() => {
|
|
|
|
+ setShowMoreMenu(false);
|
|
|
|
+ }, [setShowMoreMenu]);
|
|
|
|
+
|
|
return (
|
|
return (
|
|
<div
|
|
<div
|
|
- className={`w-full border-b border-color-gray-100 flex items-center align-middle p-4 space-x-2 fixed left-0 right-0 z-10 bg-white dark:bg-gray-800 transform transition-all duration-200 translate-y-0 ${
|
|
|
|
|
|
+ className={`w-full border-b border-gray-100 dark:border-gray-700 flex items-center align-middle p-4 space-x-2 fixed left-0 right-0 z-10 bg-white dark:bg-gray-900 transform transition-all duration-200 translate-y-0 ${
|
|
!show ? '-translate-y-full' : ''
|
|
!show ? '-translate-y-full' : ''
|
|
} ${!atZero ? 'shadow' : ''}`}
|
|
} ${!atZero ? 'shadow' : ''}`}
|
|
>
|
|
>
|
|
@@ -50,6 +73,20 @@ export default function AppBar({ title }) {
|
|
</Button>
|
|
</Button>
|
|
</div>
|
|
</div>
|
|
<LinkedLogo />
|
|
<LinkedLogo />
|
|
|
|
+ <div className="flex-grow-1 flex justify-end w-full">
|
|
|
|
+ <div ref={moreRef}>
|
|
|
|
+ <Button className="rounded-full w-12 h-12" onClick={handleShowMenu} type="text">
|
|
|
|
+ <MoreIcon />
|
|
|
|
+ </Button>
|
|
|
|
+ </div>
|
|
|
|
+ </div>
|
|
|
|
+ {showMoreMenu ? (
|
|
|
|
+ <Menu onDismiss={handleDismissMoreMenu} relativeTo={moreRef}>
|
|
|
|
+ <MenuItem label="Auto" value="media" onSelect={handleSelectDarkMode} />
|
|
|
|
+ <MenuItem label="Light" value="light" onSelect={handleSelectDarkMode} />
|
|
|
|
+ <MenuItem label="Dark" value="dark" onSelect={handleSelectDarkMode} />
|
|
|
|
+ </Menu>
|
|
|
|
+ ) : null}
|
|
</div>
|
|
</div>
|
|
);
|
|
);
|
|
}
|
|
}
|