waveterm/frontend/app/workspace/workspace.tsx

105 lines
3.4 KiB
TypeScript
Raw Normal View History

// Copyright 2024, Command Line Inc.
// SPDX-License-Identifier: Apache-2.0
2024-06-18 06:50:33 +02:00
import { TabBar } from "@/app/tab/tabbar";
import { TabContent } from "@/app/tab/tabcontent";
import { atoms, createBlock } from "@/store/global";
import * as services from "@/store/services";
import * as util from "@/util/util";
2024-05-28 21:12:28 +02:00
import * as jotai from "jotai";
import * as React from "react";
2024-05-28 21:12:28 +02:00
import { CenteredDiv } from "../element/quickelems";
import "./workspace.less";
function Widgets() {
const settingsConfig = jotai.useAtomValue(atoms.settingsConfigAtom);
const newWidgetModalVisible = React.useState(false);
async function clickTerminal() {
const termBlockDef = {
controller: "shell",
view: "term",
};
createBlock(termBlockDef);
}
async function clickHome() {
const editDef: BlockDef = {
view: "preview",
meta: {
file: "~",
},
};
createBlock(editDef);
}
async function handleWidgetSelect(blockDef: BlockDef) {
createBlock(blockDef);
}
async function handleCreateWidget(newWidget: WidgetsConfigType) {
await services.FileService.AddWidget(newWidget);
}
async function handleRemoveWidget(idx: number) {
await services.FileService.RemoveWidget(idx);
}
return (
<div className="workspace-widgets">
<div className="widget" onClick={() => clickTerminal()}>
<div className="widget-icon">
<i className="fa fa-solid fa-square-terminal fa-fw" />
</div>
<div className="widget-label">terminal</div>
</div>
<div className="widget" onClick={() => clickHome()}>
<div className="widget-icon">
<i className="fa-sharp fa-solid fa-house"></i>
</div>
<div className="widget-label">home</div>
</div>
{settingsConfig.widgets.map((data, idx) => (
<div
className="widget"
style={{ color: data.color }}
onClick={() => handleWidgetSelect(data.blockdef)}
key={`widget-${idx}`}
title={data.description || data.label}
>
<div className="widget-icon">
<i className={data.icon}></i>
</div>
{!util.isBlank(data.label) ? <div className="widget-label">{data.label}</div> : null}
</div>
))}
<div className="widget no-hover">
<i className="fa fa-solid fa-plus fa-fw" />
</div>
</div>
);
}
function WorkspaceElem() {
const windowData = jotai.useAtomValue(atoms.waveWindow);
const activeTabId = windowData?.activetabid;
const ws = jotai.useAtomValue(atoms.workspace);
2024-06-18 06:50:33 +02:00
console.log("ws", ws);
return (
<div className="workspace">
<TabBar workspace={ws} />
<div className="workspace-tabcontent">
2024-05-28 01:33:31 +02:00
{activeTabId == "" ? (
<CenteredDiv>No Active Tab</CenteredDiv>
) : (
<>
<TabContent key={windowData.workspaceid} tabId={activeTabId} />
<Widgets />
</>
)}
</div>
</div>
);
}
export { WorkspaceElem as Workspace };