mirror of
https://github.com/mountain-loop/yaak.git
synced 2026-03-25 02:41:21 +01:00
Add .oxfmtignore to skip generated bindings and wasm-pack output. Add npm format script, update DEVELOPMENT.md for Vite+ toolchain, and format all non-generated files with oxfmt. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
40 lines
1.5 KiB
TypeScript
40 lines
1.5 KiB
TypeScript
import { useMemo } from "react";
|
|
import { useFloatingSidebarHidden } from "../hooks/useFloatingSidebarHidden";
|
|
import { useShouldFloatSidebar } from "../hooks/useShouldFloatSidebar";
|
|
import { useSidebarHidden } from "../hooks/useSidebarHidden";
|
|
import { CreateDropdown } from "./CreateDropdown";
|
|
import { IconButton } from "./core/IconButton";
|
|
import { HStack } from "./core/Stacks";
|
|
|
|
export function SidebarActions() {
|
|
const floating = useShouldFloatSidebar();
|
|
const [normalHidden, setNormalHidden] = useSidebarHidden();
|
|
const [floatingHidden, setFloatingHidden] = useFloatingSidebarHidden();
|
|
|
|
const hidden = floating ? floatingHidden : normalHidden;
|
|
const setHidden = useMemo(
|
|
() => (floating ? setFloatingHidden : setNormalHidden),
|
|
[floating, setFloatingHidden, setNormalHidden],
|
|
);
|
|
|
|
return (
|
|
<HStack className="h-full">
|
|
<IconButton
|
|
onClick={async () => {
|
|
// NOTE: We're not using the (h) => !h pattern here because the data
|
|
// might be different if another window changed it (out of sync)
|
|
await setHidden(!hidden);
|
|
}}
|
|
className="pointer-events-auto"
|
|
size="sm"
|
|
title="Toggle sidebar"
|
|
icon={hidden ? "left_panel_hidden" : "left_panel_visible"}
|
|
iconColor="secondary"
|
|
/>
|
|
<CreateDropdown hotKeyAction="model.create">
|
|
<IconButton size="sm" icon="plus_circle" iconColor="secondary" title="Add Resource" />
|
|
</CreateDropdown>
|
|
</HStack>
|
|
);
|
|
}
|