Browse Source

fix: Container breakage after unifying

master
Muthu Kumar 7 months ago
parent
commit
65cb9bde31
Failed to extract signature
  1. 82
      src/components/Container.tsx
  2. 1
      src/components/Menu.tsx

82
src/components/Container.tsx

@ -5,7 +5,7 @@ import useLocation from "wouter/use-location";
import { ReactComponent as Logo } from "../assets/logo.svg"; import { ReactComponent as Logo } from "../assets/logo.svg";
import { ReactComponent as Right } from "../assets/arrow-right.svg"; import { ReactComponent as Right } from "../assets/arrow-right.svg";
import { get, getTimeout } from "../util"; import { get, getTimeout } from "../util";
import Menu, { MenuEntries } from "./Menu"; import Menu, { MenuEntries, MenuPaths } from "./Menu";
import useMediaQuery from "../util/useMediaQuery"; import useMediaQuery from "../util/useMediaQuery";
import { AnimateEntry } from "./AnimateEntry"; import { AnimateEntry } from "./AnimateEntry";
@ -28,32 +28,6 @@ const Container: React.FC<{
const [showMenu, setShowMenu] = useState(false); const [showMenu, setShowMenu] = useState(false);
useEffect(() => {
// scroll back to top when new page is loaded
window.scrollTo({ top: 0 });
if (highlightCircle.current) {
highlightCircle.current.classList.add("highlight");
timer(
() =>
highlightCircle.current &&
highlightCircle.current.classList.remove("highlight"),
1500,
);
}
if (nextBtn.current) {
nextBtn.current.style.width = "4rem";
timer(
() => nextBtn.current && (nextBtn.current.style.right = "10vw"),
300,
);
}
// cleanup
return clear;
}, []);
const handleResize = () => { const handleResize = () => {
if (containerChild.current && logoContainer.current) if (containerChild.current && logoContainer.current)
logoContainer.current.style.left = `${ logoContainer.current.style.left = `${
@ -86,44 +60,64 @@ const Container: React.FC<{
} catch {} } catch {}
}; };
const current = MenuEntries.findIndex(
([, path]) => location === path || location.startsWith(path + "/"),
);
const next = get.next(MenuEntries, current)[1];
const prev = get.prev(MenuEntries, current)[1];
const end = current === MenuEntries.length - 1;
const handlePrev = (e: MouseKb) => { const handlePrev = (e: MouseKb) => {
animateArrow(e); animateArrow(e);
timer(() => prev && navigate(prev), 300);
const current = MenuPaths.findIndex(path => location === path);
const index = (current - 1) % MenuPaths.length;
const prev = MenuPaths.at(index)!;
timer(() => navigate(prev), 300);
}; };
const handleNext = (e: MouseKb) => { const handleNext = (e: MouseKb) => {
animateArrow(e); animateArrow(e);
timer(() => next && navigate(next), 300);
const current = MenuPaths.findIndex(path => location === path);
const index = (current + 1) % MenuPaths.length;
const next = MenuPaths.at(index)!;
timer(() => navigate(next), 300);
}; };
function kbnav(e: KeyboardEvent) { function kbnav(e: KeyboardEvent) {
if (e.altKey || e.ctrlKey || e.metaKey || e.shiftKey) return; if (e.altKey || e.ctrlKey || e.metaKey || e.shiftKey) return;
switch (e.key) { if (e.key === "ArrowLeft") return handlePrev(e);
case "ArrowLeft": else if (e.key === "ArrowRight") return handleNext(e);
return handlePrev(e);
case "ArrowRight":
return handleNext(e);
}
} }
useEffect(() => { useEffect(() => {
// scroll back to top when new page is loaded
window.scrollTo({ top: 0 });
if (highlightCircle.current) {
highlightCircle.current.classList.add("highlight");
timer(
() =>
highlightCircle.current &&
highlightCircle.current.classList.remove("highlight"),
1500,
);
}
if (nextBtn.current) {
nextBtn.current.style.width = "3rem";
timer(
() => nextBtn.current && (nextBtn.current.style.right = "10vw"),
300,
);
}
window.addEventListener("keydown", kbnav); window.addEventListener("keydown", kbnav);
// cleanup // cleanup
return () => window.removeEventListener("keydown", kbnav); return () => (window.removeEventListener("keydown", kbnav), clear());
}, []); }, [location]);
// on first render // on first render
useLayoutEffect(handleResize, []); useLayoutEffect(handleResize, []);
const end = location === MenuEntries[MenuEntries.length - 1][1];
return ( return (
<div <div
className={css` className={css`

1
src/components/Menu.tsx

@ -12,6 +12,7 @@ export const MENU = {
} as const; } as const;
export const MenuEntries = Object.entries(MENU); export const MenuEntries = Object.entries(MENU);
export const MenuPaths = Object.values(MENU);
const desktopNav = css` const desktopNav = css`
float: right; float: right;

Loading…
Cancel
Save