// Copyright 2024, Command Line Inc. // SPDX-License-Identifier: Apache-2.0 import { TabContent } from "@/app/tab/tab"; import { atoms } from "@/store/global"; import * as WOS from "@/store/wos"; import { clsx } from "clsx"; import * as jotai from "jotai"; import { CenteredDiv } from "../element/quickelems"; import { LayoutTreeActionType, LayoutTreeInsertNodeAction, newLayoutNode } from "@/faraday/index"; import { deleteLayoutStateAtomForTab, getLayoutStateAtomForTab, useLayoutTreeStateReducerAtom, } from "@/faraday/lib/layoutAtom"; import { useCallback, useMemo } from "react"; import "./workspace.less"; function Tab({ tabId }: { tabId: string }) { const windowData = jotai.useAtomValue(atoms.waveWindow); const [tabData, tabLoading] = WOS.useWaveObjectValue(WOS.makeORef("tab", tabId)); function setActiveTab() { WOS.SetActiveTab(tabId); } function handleCloseTab() { WOS.CloseTab(tabId); deleteLayoutStateAtomForTab(tabId); } return (
setActiveTab()} >
handleCloseTab()}>
{tabData?.name ?? "..."}
); } function TabBar({ workspace }: { workspace: Workspace }) { function handleAddTab() { const newTabName = `Tab-${workspace.tabids.length + 1}`; WOS.AddTabToWorkspace(newTabName, true); } const tabIds = workspace?.tabids ?? []; return (
{tabIds.map((tabid, idx) => { return ; })}
handleAddTab()}>
); } function Widgets() { const windowData = jotai.useAtomValue(atoms.waveWindow); const activeTabAtom = useMemo(() => { return getLayoutStateAtomForTab( windowData.activetabid, WOS.getWaveObjectAtom(WOS.makeORef("tab", windowData.activetabid)) ); }, [windowData.activetabid]); const [, dispatchLayoutStateAction] = useLayoutTreeStateReducerAtom(activeTabAtom); const addBlockToTab = useCallback( (blockId: string) => { const insertNodeAction: LayoutTreeInsertNodeAction = { type: LayoutTreeActionType.InsertNode, node: newLayoutNode(undefined, undefined, undefined, { blockId }), }; dispatchLayoutStateAction(insertNodeAction); }, [activeTabAtom, dispatchLayoutStateAction] ); async function createBlock(blockDef: BlockDef) { const rtOpts: RuntimeOpts = { termsize: { rows: 25, cols: 80 } }; const { blockId } = await WOS.CreateBlock(blockDef, rtOpts); addBlockToTab(blockId); } async function clickTerminal() { const termBlockDef = { controller: "shell", view: "term", }; createBlock(termBlockDef); } async function clickPreview(fileName: string) { const markdownDef = { view: "preview", meta: { file: fileName }, }; createBlock(markdownDef); } async function clickPlot() { const plotDef: BlockDef = { view: "plot", }; createBlock(plotDef); } async function clickEdit() { const editDef: BlockDef = { view: "codeedit", }; createBlock(editDef); } return (
clickTerminal()}>
clickPreview("README.md")}>
clickPreview("go.mod")}>
clickPreview("build/appicon.png")}>
clickPreview("~")}>
clickPlot()}>
clickEdit()}>
); } function WorkspaceElem() { const windowData = jotai.useAtomValue(atoms.waveWindow); const activeTabId = windowData?.activetabid; const ws = jotai.useAtomValue(atoms.workspace); return (
{activeTabId == "" ? ( No Active Tab ) : ( <> )}
); } export { WorkspaceElem as Workspace };