2024-05-13 23:40:18 +02:00
|
|
|
// Copyright 2024, Command Line Inc.
|
|
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
|
2024-05-10 05:24:24 +02:00
|
|
|
import * as React from "react";
|
|
|
|
import * as jotai from "jotai";
|
2024-05-14 06:42:25 +02:00
|
|
|
import { Provider } from "jotai";
|
2024-05-13 22:59:44 +02:00
|
|
|
import { clsx } from "clsx";
|
2024-05-14 06:42:25 +02:00
|
|
|
import { TabContent } from "@/app/tab/tab";
|
2024-05-14 08:45:41 +02:00
|
|
|
import { globalStore, atoms } from "@/store/global";
|
2024-05-10 05:24:24 +02:00
|
|
|
|
2024-05-12 18:52:12 +02:00
|
|
|
import "/public/style.less";
|
|
|
|
|
2024-05-10 05:24:24 +02:00
|
|
|
const App = () => {
|
|
|
|
return (
|
2024-05-14 08:45:41 +02:00
|
|
|
<Provider store={globalStore}>
|
2024-05-10 05:24:24 +02:00
|
|
|
<AppInner />
|
|
|
|
</Provider>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
2024-05-14 08:45:41 +02:00
|
|
|
const Tab = ({ tab }: { tab: TabData }) => {
|
|
|
|
const [activeTab, setActiveTab] = jotai.useAtom(atoms.activeTabId);
|
|
|
|
return (
|
|
|
|
<div className={clsx("tab", { active: activeTab === tab.tabid })} onClick={() => setActiveTab(tab.tabid)}>
|
|
|
|
{tab.name}
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
2024-05-14 00:10:31 +02:00
|
|
|
const TabBar = () => {
|
2024-05-14 08:45:41 +02:00
|
|
|
const [activeTab, setActiveTab] = jotai.useAtom(atoms.activeTabId);
|
|
|
|
const tabs = jotai.useAtomValue(atoms.tabsAtom);
|
2024-05-13 22:59:44 +02:00
|
|
|
return (
|
2024-05-14 00:10:31 +02:00
|
|
|
<div className="tab-bar">
|
2024-05-14 08:45:41 +02:00
|
|
|
{tabs.map((tab, idx) => {
|
|
|
|
return <Tab key={idx} tab={tab} />;
|
2024-05-14 00:40:52 +02:00
|
|
|
})}
|
2024-05-13 22:59:44 +02:00
|
|
|
</div>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
const Workspace = () => {
|
2024-05-14 08:45:41 +02:00
|
|
|
const activeTabId = jotai.useAtomValue(atoms.activeTabId);
|
2024-05-13 22:59:44 +02:00
|
|
|
return (
|
|
|
|
<div className="workspace">
|
2024-05-14 00:10:31 +02:00
|
|
|
<TabBar />
|
2024-05-14 00:40:52 +02:00
|
|
|
<TabContent tabId={activeTabId} />
|
2024-05-13 22:59:44 +02:00
|
|
|
</div>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
2024-05-10 05:24:24 +02:00
|
|
|
const AppInner = () => {
|
|
|
|
return (
|
2024-05-13 22:59:44 +02:00
|
|
|
<div className="mainapp">
|
|
|
|
<div className="titlebar"></div>
|
|
|
|
<Workspace />
|
2024-05-10 05:24:24 +02:00
|
|
|
</div>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
export { App };
|