github-actions[bot]
Sync to HuggingFace Spaces
f152ae2
import { Button } from "@mantine/core";
import { Suspense, lazy, useCallback, useEffect, useState } from "react";
import { addLogEntry } from "../../../../modules/logEntries";
const MenuDrawer = lazy(() => import("./MenuDrawer"));
export default function MenuButton() {
const [isDrawerOpen, setDrawerOpen] = useState(false);
const [isDrawerLoaded, setDrawerLoaded] = useState(false);
const openDrawer = useCallback(() => {
setDrawerOpen(true);
addLogEntry("User opened the menu");
}, []);
const closeDrawer = useCallback(() => {
setDrawerOpen(false);
addLogEntry("User closed the menu");
}, []);
const handleDrawerLoad = useCallback(() => {
if (!isDrawerLoaded) {
addLogEntry("Menu drawer loaded");
setDrawerLoaded(true);
}
}, [isDrawerLoaded]);
return (
<>
<Button
size="xs"
onClick={openDrawer}
variant="default"
loading={isDrawerOpen && !isDrawerLoaded}
>
Menu
</Button>
{(isDrawerOpen || isDrawerLoaded) && (
<Suspense fallback={<SuspenseListener onUnload={handleDrawerLoad} />}>
<MenuDrawer onClose={closeDrawer} opened={isDrawerOpen} />
</Suspense>
)}
</>
);
}
function SuspenseListener({ onUnload }: { onUnload: () => void }) {
useEffect(() => {
return () => onUnload();
}, [onUnload]);
return null;
}