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>
92 lines
3.4 KiB
TypeScript
92 lines
3.4 KiB
TypeScript
import classNames from "classnames";
|
|
import { useAtom, useAtomValue } from "jotai";
|
|
import { memo } from "react";
|
|
import { activeWorkspaceAtom, activeWorkspaceMetaAtom } from "../hooks/useActiveWorkspace";
|
|
import { useToggleCommandPalette } from "../hooks/useToggleCommandPalette";
|
|
import { workspaceLayoutAtom } from "../lib/atoms";
|
|
import { setupOrConfigureEncryption } from "../lib/setupOrConfigureEncryption";
|
|
import { CookieDropdown } from "./CookieDropdown";
|
|
import { Icon } from "./core/Icon";
|
|
import { IconButton } from "./core/IconButton";
|
|
import { PillButton } from "./core/PillButton";
|
|
import { HStack } from "./core/Stacks";
|
|
import { EnvironmentActionsDropdown } from "./EnvironmentActionsDropdown";
|
|
import { ImportCurlButton } from "./ImportCurlButton";
|
|
import { LicenseBadge } from "./LicenseBadge";
|
|
import { RecentRequestsDropdown } from "./RecentRequestsDropdown";
|
|
import { SettingsDropdown } from "./SettingsDropdown";
|
|
import { SidebarActions } from "./SidebarActions";
|
|
import { WorkspaceActionsDropdown } from "./WorkspaceActionsDropdown";
|
|
|
|
interface Props {
|
|
className?: string;
|
|
}
|
|
|
|
export const WorkspaceHeader = memo(function WorkspaceHeader({ className }: Props) {
|
|
const togglePalette = useToggleCommandPalette();
|
|
const [workspaceLayout, setWorkspaceLayout] = useAtom(workspaceLayoutAtom);
|
|
const workspace = useAtomValue(activeWorkspaceAtom);
|
|
const workspaceMeta = useAtomValue(activeWorkspaceMetaAtom);
|
|
const showEncryptionSetup =
|
|
workspace != null &&
|
|
workspaceMeta != null &&
|
|
workspace.encryptionKeyChallenge != null &&
|
|
workspaceMeta.encryptionKey == null;
|
|
|
|
return (
|
|
<div
|
|
className={classNames(
|
|
className,
|
|
"grid grid-cols-[auto_minmax(0,1fr)_auto] items-center w-full h-full",
|
|
)}
|
|
>
|
|
<HStack space={0.5} className={classNames("flex-1 pointer-events-none")}>
|
|
<SidebarActions />
|
|
<CookieDropdown />
|
|
<HStack className="min-w-0">
|
|
<WorkspaceActionsDropdown />
|
|
<Icon icon="chevron_right" color="secondary" />
|
|
<EnvironmentActionsDropdown className="w-auto pointer-events-auto" />
|
|
</HStack>
|
|
</HStack>
|
|
<div className="pointer-events-none w-full max-w-[30vw] mx-auto flex justify-center">
|
|
<RecentRequestsDropdown />
|
|
</div>
|
|
<div className="flex-1 flex gap-1 items-center h-full justify-end pointer-events-none pr-1">
|
|
<ImportCurlButton />
|
|
{showEncryptionSetup ? (
|
|
<PillButton color="danger" onClick={setupOrConfigureEncryption}>
|
|
Enter Encryption Key
|
|
</PillButton>
|
|
) : (
|
|
<LicenseBadge />
|
|
)}
|
|
<IconButton
|
|
icon={
|
|
workspaceLayout === "responsive"
|
|
? "magic_wand"
|
|
: workspaceLayout === "horizontal"
|
|
? "columns_2"
|
|
: "rows_2"
|
|
}
|
|
title={`Change to ${workspaceLayout === "horizontal" ? "vertical" : "horizontal"} layout`}
|
|
size="sm"
|
|
iconColor="secondary"
|
|
onClick={() =>
|
|
setWorkspaceLayout((prev) => (prev === "horizontal" ? "vertical" : "horizontal"))
|
|
}
|
|
/>
|
|
<IconButton
|
|
icon="search"
|
|
title="Search or execute a command"
|
|
size="sm"
|
|
hotkeyAction="command_palette.toggle"
|
|
iconColor="secondary"
|
|
onClick={togglePalette}
|
|
/>
|
|
<SettingsDropdown />
|
|
</div>
|
|
</div>
|
|
);
|
|
});
|