* add useModal hook and ModalWrapper component that will be used to replace all <dialog> modals for better browser support * implement useModal hook and ModalWrapper component to replace all exisiting <dialog>
116 lines
3.9 KiB
JavaScript
116 lines
3.9 KiB
JavaScript
import { useEffect, useState } from "react";
|
|
import Sidebar, { SidebarMobileHeader } from "@/components/SettingsSidebar";
|
|
import { isMobile } from "react-device-detect";
|
|
import * as Skeleton from "react-loading-skeleton";
|
|
import "react-loading-skeleton/dist/skeleton.css";
|
|
import { BookOpen } from "@phosphor-icons/react";
|
|
import usePrefersDarkMode from "@/hooks/usePrefersDarkMode";
|
|
import Admin from "@/models/admin";
|
|
import WorkspaceRow from "./WorkspaceRow";
|
|
import NewWorkspaceModal from "./NewWorkspaceModal";
|
|
import { useModal } from "@/hooks/useModal";
|
|
import ModalWrapper from "@/components/ModalWrapper";
|
|
|
|
export default function AdminWorkspaces() {
|
|
const { isOpen, openModal, closeModal } = useModal();
|
|
return (
|
|
<div className="w-screen h-screen overflow-hidden bg-sidebar flex">
|
|
{!isMobile && <Sidebar />}
|
|
<div
|
|
style={{ height: isMobile ? "100%" : "calc(100% - 32px)" }}
|
|
className="transition-all duration-500 relative md:ml-[2px] md:mr-[16px] md:my-[16px] md:rounded-[26px] bg-main-gradient w-full h-full overflow-y-scroll border-4 border-accent"
|
|
>
|
|
{isMobile && <SidebarMobileHeader />}
|
|
<div className="flex flex-col w-full px-1 md:px-20 md:py-12 py-16">
|
|
<div className="w-full flex flex-col gap-y-1 pb-6 border-white border-b-2 border-opacity-10">
|
|
<div className="items-center flex gap-x-4">
|
|
<p className="text-2xl font-semibold text-white">
|
|
Instance workspaces
|
|
</p>
|
|
<button
|
|
onClick={openModal}
|
|
className="border border-slate-200 px-4 py-1 rounded-lg text-slate-200 text-sm items-center flex gap-x-2 hover:bg-slate-200 hover:text-slate-800"
|
|
>
|
|
<BookOpen className="h-4 w-4" /> New Workspace
|
|
</button>
|
|
</div>
|
|
<p className="text-sm font-base text-white text-opacity-60">
|
|
These are all the workspaces that exist on this instance. Removing
|
|
a workspace will delete all of it's associated chats and settings.
|
|
</p>
|
|
</div>
|
|
<WorkspacesContainer />
|
|
</div>
|
|
<ModalWrapper isOpen={isOpen}>
|
|
<NewWorkspaceModal closeModal={closeModal} />
|
|
</ModalWrapper>
|
|
</div>
|
|
</div>
|
|
);
|
|
}
|
|
|
|
function WorkspacesContainer() {
|
|
const darkMode = usePrefersDarkMode();
|
|
const [loading, setLoading] = useState(true);
|
|
const [users, setUsers] = useState([]);
|
|
const [workspaces, setWorkspaces] = useState([]);
|
|
|
|
useEffect(() => {
|
|
async function fetchData() {
|
|
const _users = await Admin.users();
|
|
const _workspaces = await Admin.workspaces();
|
|
setUsers(_users);
|
|
setWorkspaces(_workspaces);
|
|
setLoading(false);
|
|
}
|
|
fetchData();
|
|
}, []);
|
|
|
|
if (loading) {
|
|
return (
|
|
<Skeleton.default
|
|
height="80vh"
|
|
width="100%"
|
|
highlightColor="#3D4147"
|
|
baseColor="#2C2F35"
|
|
count={1}
|
|
className="w-full p-4 rounded-b-2xl rounded-tr-2xl rounded-tl-sm mt-6"
|
|
containerClassName="flex w-full"
|
|
/>
|
|
);
|
|
}
|
|
|
|
return (
|
|
<table className="md:w-3/4 w-full text-sm text-left rounded-lg mt-5">
|
|
<thead className="text-white text-opacity-80 text-sm font-bold uppercase border-white border-b border-opacity-60">
|
|
<tr>
|
|
<th scope="col" className="px-6 py-3 rounded-tl-lg">
|
|
Name
|
|
</th>
|
|
<th scope="col" className="px-6 py-3">
|
|
Link
|
|
</th>
|
|
<th scope="col" className="px-6 py-3">
|
|
Users
|
|
</th>
|
|
<th scope="col" className="px-6 py-3">
|
|
Created On
|
|
</th>
|
|
<th scope="col" className="px-6 py-3 rounded-tr-lg">
|
|
{" "}
|
|
</th>
|
|
</tr>
|
|
</thead>
|
|
<tbody>
|
|
{workspaces.map((workspace) => (
|
|
<WorkspaceRow
|
|
key={workspace.id}
|
|
workspace={workspace}
|
|
users={users}
|
|
/>
|
|
))}
|
|
</tbody>
|
|
</table>
|
|
);
|
|
}
|