43 lines
1.5 KiB
TypeScript
43 lines
1.5 KiB
TypeScript
import { useContext } from "react";
|
|
import { MenubarCheckboxItem, MenubarContent, MenubarItem, MenubarMenu, MenubarSeparator, MenubarTrigger } from "@/components/ui/menubar";
|
|
|
|
import { DialogContext } from "@/context/Dialog";
|
|
import { SettingsContext } from "@/context/Settings";
|
|
|
|
function ViewMenu() {
|
|
const openDialog = useContext(DialogContext);
|
|
const { settings, setSetting } = useContext(SettingsContext);
|
|
|
|
const onCheckedChange = (key: keyof Settings) => (value: boolean) => {
|
|
setSetting(key, value);
|
|
};
|
|
|
|
return (
|
|
<MenubarMenu>
|
|
<MenubarTrigger>View</MenubarTrigger>
|
|
<MenubarContent>
|
|
<MenubarItem onClick={() => openDialog("SetScale")}>Set Scale</MenubarItem>
|
|
<MenubarSeparator />
|
|
<MenubarCheckboxItem checked={settings.grid} onCheckedChange={onCheckedChange("grid")}>
|
|
Grid
|
|
</MenubarCheckboxItem>
|
|
<MenubarCheckboxItem checked={settings.canvasBorder} onCheckedChange={onCheckedChange("canvasBorder")}>
|
|
Canvas Border
|
|
</MenubarCheckboxItem>
|
|
|
|
<MenubarSeparator />
|
|
<MenubarCheckboxItem checked={settings.colorPicker} onCheckedChange={onCheckedChange("colorPicker")}>
|
|
Color Picker
|
|
</MenubarCheckboxItem>
|
|
<MenubarCheckboxItem checked={settings.radiusChanger} onCheckedChange={onCheckedChange("radiusChanger")}>
|
|
Radius Changer
|
|
</MenubarCheckboxItem>
|
|
<MenubarCheckboxItem checked={settings.blockSelector} onCheckedChange={onCheckedChange("blockSelector")}>
|
|
Block Selector
|
|
</MenubarCheckboxItem>
|
|
</MenubarContent>
|
|
</MenubarMenu>
|
|
);
|
|
}
|
|
|
|
export default ViewMenu;
|