2024-05-16 09:29:58 +02:00
|
|
|
// 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";
|
2024-06-18 07:38:48 +02:00
|
|
|
import { atoms, createBlock } from "@/store/global";
|
2024-06-20 08:59:41 +02:00
|
|
|
import * as services from "@/store/services";
|
2024-06-20 22:03:50 +02:00
|
|
|
import * as util from "@/util/util";
|
2024-05-28 21:12:28 +02:00
|
|
|
import * as jotai from "jotai";
|
2024-06-20 08:59:41 +02:00
|
|
|
import * as React from "react";
|
2024-05-28 21:12:28 +02:00
|
|
|
import { CenteredDiv } from "../element/quickelems";
|
2024-05-16 09:29:58 +02:00
|
|
|
|
|
|
|
import "./workspace.less";
|
|
|
|
|
|
|
|
function Widgets() {
|
2024-06-20 08:59:41 +02:00
|
|
|
const settingsConfig = jotai.useAtomValue(atoms.settingsConfigAtom);
|
|
|
|
const newWidgetModalVisible = React.useState(false);
|
2024-05-16 09:29:58 +02:00
|
|
|
async function clickTerminal() {
|
2024-05-28 00:44:57 +02:00
|
|
|
const termBlockDef = {
|
2024-05-16 09:29:58 +02:00
|
|
|
controller: "shell",
|
|
|
|
view: "term",
|
2024-05-28 00:44:57 +02:00
|
|
|
};
|
2024-05-16 09:29:58 +02:00
|
|
|
createBlock(termBlockDef);
|
|
|
|
}
|
|
|
|
|
2024-06-20 22:03:50 +02:00
|
|
|
async function clickHome() {
|
2024-06-03 20:35:06 +02:00
|
|
|
const editDef: BlockDef = {
|
2024-06-20 22:03:50 +02:00
|
|
|
view: "preview",
|
|
|
|
meta: {
|
|
|
|
file: "~",
|
|
|
|
},
|
2024-06-03 20:35:06 +02:00
|
|
|
};
|
|
|
|
createBlock(editDef);
|
|
|
|
}
|
2024-06-20 08:59:41 +02:00
|
|
|
async function handleWidgetSelect(blockDef: BlockDef) {
|
|
|
|
createBlock(blockDef);
|
|
|
|
}
|
|
|
|
|
|
|
|
async function handleCreateWidget(newWidget: WidgetsConfigType) {
|
|
|
|
await services.FileService.AddWidget(newWidget);
|
|
|
|
}
|
|
|
|
|
|
|
|
async function handleRemoveWidget(idx: number) {
|
2024-06-20 22:03:50 +02:00
|
|
|
await services.FileService.RemoveWidget(idx);
|
2024-06-20 08:59:41 +02:00
|
|
|
}
|
2024-06-03 20:35:06 +02:00
|
|
|
|
2024-05-16 09:29:58 +02:00
|
|
|
return (
|
|
|
|
<div className="workspace-widgets">
|
|
|
|
<div className="widget" onClick={() => clickTerminal()}>
|
2024-06-20 22:03:50 +02:00
|
|
|
<div className="widget-icon">
|
|
|
|
<i className="fa fa-solid fa-square-terminal fa-fw" />
|
|
|
|
</div>
|
|
|
|
<div className="widget-label">terminal</div>
|
2024-05-16 09:29:58 +02:00
|
|
|
</div>
|
2024-06-20 22:03:50 +02:00
|
|
|
<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>
|
2024-06-03 20:35:06 +02:00
|
|
|
</div>
|
2024-06-20 08:59:41 +02:00
|
|
|
{settingsConfig.widgets.map((data, idx) => (
|
2024-06-20 22:03:50 +02:00
|
|
|
<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}
|
2024-06-20 08:59:41 +02:00
|
|
|
</div>
|
|
|
|
))}
|
2024-05-16 09:29:58 +02:00
|
|
|
<div className="widget no-hover">
|
|
|
|
<i className="fa fa-solid fa-plus fa-fw" />
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2024-05-24 23:08:24 +02:00
|
|
|
function WorkspaceElem() {
|
2024-05-27 22:59:58 +02:00
|
|
|
const windowData = jotai.useAtomValue(atoms.waveWindow);
|
2024-05-27 09:47:10 +02:00
|
|
|
const activeTabId = windowData?.activetabid;
|
2024-05-27 22:59:58 +02:00
|
|
|
const ws = jotai.useAtomValue(atoms.workspace);
|
2024-06-18 06:50:33 +02:00
|
|
|
console.log("ws", ws);
|
2024-05-16 09:29:58 +02:00
|
|
|
return (
|
|
|
|
<div className="workspace">
|
2024-05-28 00:44:57 +02:00
|
|
|
<TabBar workspace={ws} />
|
2024-05-16 09:29:58 +02:00
|
|
|
<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 />
|
|
|
|
</>
|
|
|
|
)}
|
2024-05-16 09:29:58 +02:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2024-05-24 23:08:24 +02:00
|
|
|
export { WorkspaceElem as Workspace };
|