2023-06-17 08:50:56 +02:00
|
|
|
import React, { useEffect, useRef, useState } from "react";
|
2024-03-07 02:22:36 +01:00
|
|
|
import { Plus, List } from "@phosphor-icons/react";
|
2023-06-04 04:28:07 +02:00
|
|
|
import NewWorkspaceModal, {
|
|
|
|
useNewWorkspaceModal,
|
|
|
|
} from "../Modals/NewWorkspace";
|
|
|
|
import ActiveWorkspaces from "./ActiveWorkspaces";
|
2023-12-07 18:09:01 +01:00
|
|
|
import { USER_BACKGROUND_COLOR } from "@/utils/constants";
|
|
|
|
import useLogo from "@/hooks/useLogo";
|
|
|
|
import useUser from "@/hooks/useUser";
|
2024-02-08 21:17:01 +01:00
|
|
|
import Footer from "../Footer";
|
2024-03-07 02:22:36 +01:00
|
|
|
import SettingsButton from "../SettingsButton";
|
|
|
|
import { Link } from "react-router-dom";
|
|
|
|
import paths from "@/utils/paths";
|
2023-06-04 04:28:07 +02:00
|
|
|
|
|
|
|
export default function Sidebar() {
|
2023-11-13 23:51:16 +01:00
|
|
|
const { user } = useUser();
|
2023-08-15 00:22:55 +02:00
|
|
|
const { logo } = useLogo();
|
2023-06-04 04:28:07 +02:00
|
|
|
const sidebarRef = useRef(null);
|
|
|
|
const {
|
|
|
|
showing: showingNewWsModal,
|
|
|
|
showModal: showNewWsModal,
|
|
|
|
hideModal: hideNewWsModal,
|
|
|
|
} = useNewWorkspaceModal();
|
|
|
|
|
|
|
|
return (
|
2024-03-07 02:22:36 +01:00
|
|
|
<div>
|
|
|
|
<Link
|
|
|
|
to={paths.home()}
|
|
|
|
className="flex shrink-0 max-w-[55%] items-center justify-start mx-[38px] my-[18px]"
|
|
|
|
>
|
|
|
|
<img
|
|
|
|
src={logo}
|
|
|
|
alt="Logo"
|
|
|
|
className="rounded max-h-[24px]"
|
|
|
|
style={{ objectFit: "contain" }}
|
|
|
|
/>
|
|
|
|
</Link>
|
2023-06-04 04:28:07 +02:00
|
|
|
<div
|
|
|
|
ref={sidebarRef}
|
2024-03-07 02:22:36 +01:00
|
|
|
style={{ height: "calc(100% - 76px)" }}
|
2024-03-12 18:45:03 +01:00
|
|
|
className="relative m-[16px] rounded-[16px] bg-sidebar border-2 border-outline min-w-[250px] p-[10px]"
|
2023-06-04 04:28:07 +02:00
|
|
|
>
|
2023-10-23 22:10:34 +02:00
|
|
|
<div className="flex flex-col h-full overflow-x-hidden">
|
2024-03-12 18:45:03 +01:00
|
|
|
<div className="flex-grow flex flex-col min-w-[235px]">
|
2023-11-27 22:09:55 +01:00
|
|
|
<div className="flex flex-col gap-y-2 pb-8 overflow-y-scroll no-scroll">
|
2023-10-23 22:10:34 +02:00
|
|
|
<div className="flex gap-x-2 items-center justify-between">
|
2023-11-13 23:51:16 +01:00
|
|
|
{(!user || user?.role !== "default") && (
|
|
|
|
<button
|
|
|
|
onClick={showNewWsModal}
|
2024-03-07 02:22:36 +01:00
|
|
|
className="flex flex-grow w-[75%] h-[44px] gap-x-2 py-[5px] px-2.5 mb-2 bg-white rounded-[8px] text-sidebar justify-center items-center hover:bg-opacity-80 transition-all duration-300"
|
2023-11-13 23:51:16 +01:00
|
|
|
>
|
2024-03-07 02:22:36 +01:00
|
|
|
<Plus size={18} weight="bold" />
|
2023-11-13 23:51:16 +01:00
|
|
|
<p className="text-sidebar text-sm font-semibold">
|
|
|
|
New Workspace
|
|
|
|
</p>
|
|
|
|
</button>
|
|
|
|
)}
|
2023-06-04 04:28:07 +02:00
|
|
|
</div>
|
2023-10-23 22:10:34 +02:00
|
|
|
<ActiveWorkspaces />
|
2023-06-04 04:28:07 +02:00
|
|
|
</div>
|
2023-10-23 22:10:34 +02:00
|
|
|
<div className="flex flex-col flex-grow justify-end mb-2">
|
2024-02-08 21:17:01 +01:00
|
|
|
<Footer />
|
2023-06-04 04:28:07 +02:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
{showingNewWsModal && <NewWorkspaceModal hideModal={hideNewWsModal} />}
|
2024-03-07 02:22:36 +01:00
|
|
|
</div>
|
2023-06-04 04:28:07 +02:00
|
|
|
);
|
|
|
|
}
|
2023-06-17 08:50:56 +02:00
|
|
|
|
|
|
|
export function SidebarMobileHeader() {
|
2023-08-15 00:22:55 +02:00
|
|
|
const { logo } = useLogo();
|
2023-07-25 19:37:04 +02:00
|
|
|
const sidebarRef = useRef(null);
|
2023-06-17 08:50:56 +02:00
|
|
|
const [showSidebar, setShowSidebar] = useState(false);
|
|
|
|
const [showBgOverlay, setShowBgOverlay] = useState(false);
|
|
|
|
const {
|
|
|
|
showing: showingNewWsModal,
|
|
|
|
showModal: showNewWsModal,
|
|
|
|
hideModal: hideNewWsModal,
|
|
|
|
} = useNewWorkspaceModal();
|
2023-11-13 23:51:16 +01:00
|
|
|
const { user } = useUser();
|
2023-06-17 08:50:56 +02:00
|
|
|
|
|
|
|
useEffect(() => {
|
2023-08-18 23:36:58 +02:00
|
|
|
// Darkens the rest of the screen
|
|
|
|
// when sidebar is open.
|
2023-06-17 08:50:56 +02:00
|
|
|
function handleBg() {
|
|
|
|
if (showSidebar) {
|
|
|
|
setTimeout(() => {
|
|
|
|
setShowBgOverlay(true);
|
|
|
|
}, 300);
|
|
|
|
} else {
|
|
|
|
setShowBgOverlay(false);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
handleBg();
|
|
|
|
}, [showSidebar]);
|
|
|
|
|
|
|
|
return (
|
|
|
|
<>
|
2023-10-23 22:10:34 +02:00
|
|
|
<div className="fixed top-0 left-0 right-0 z-10 flex justify-between items-center px-4 py-2 bg-sidebar text-slate-200 shadow-lg h-16">
|
2023-06-17 08:50:56 +02:00
|
|
|
<button
|
|
|
|
onClick={() => setShowSidebar(true)}
|
2023-10-23 22:10:34 +02:00
|
|
|
className="rounded-md p-2 flex items-center justify-center text-slate-200"
|
2023-06-17 08:50:56 +02:00
|
|
|
>
|
2023-11-09 17:55:20 +01:00
|
|
|
<List className="h-6 w-6" />
|
2023-06-17 08:50:56 +02:00
|
|
|
</button>
|
2023-10-23 22:10:34 +02:00
|
|
|
<div className="flex items-center justify-center flex-grow">
|
2023-08-15 00:22:55 +02:00
|
|
|
<img
|
|
|
|
src={logo}
|
|
|
|
alt="Logo"
|
2023-10-23 22:10:34 +02:00
|
|
|
className="block mx-auto h-6 w-auto"
|
|
|
|
style={{ maxHeight: "40px", objectFit: "contain" }}
|
2023-08-15 00:22:55 +02:00
|
|
|
/>
|
|
|
|
</div>
|
2023-10-23 22:10:34 +02:00
|
|
|
<div className="w-12"></div>
|
2023-06-17 08:50:56 +02:00
|
|
|
</div>
|
|
|
|
<div
|
|
|
|
style={{
|
|
|
|
transform: showSidebar ? `translateX(0vw)` : `translateX(-100vw)`,
|
|
|
|
}}
|
|
|
|
className={`z-99 fixed top-0 left-0 transition-all duration-500 w-[100vw] h-[100vh]`}
|
|
|
|
>
|
|
|
|
<div
|
2023-08-12 02:33:17 +02:00
|
|
|
className={`${
|
|
|
|
showBgOverlay
|
|
|
|
? "transition-all opacity-1"
|
|
|
|
: "transition-none opacity-0"
|
2023-10-23 22:10:34 +02:00
|
|
|
} duration-500 fixed top-0 left-0 ${USER_BACKGROUND_COLOR} bg-opacity-75 w-screen h-screen`}
|
2023-06-17 08:50:56 +02:00
|
|
|
onClick={() => setShowSidebar(false)}
|
|
|
|
/>
|
|
|
|
<div
|
|
|
|
ref={sidebarRef}
|
2023-10-23 22:10:34 +02:00
|
|
|
className="relative h-[100vh] fixed top-0 left-0 rounded-r-[26px] bg-sidebar w-[80%] p-[18px] "
|
2023-06-17 08:50:56 +02:00
|
|
|
>
|
|
|
|
<div className="w-full h-full flex flex-col overflow-x-hidden items-between">
|
|
|
|
{/* Header Information */}
|
2023-08-18 23:36:58 +02:00
|
|
|
<div className="flex w-full items-center justify-between gap-x-4">
|
|
|
|
<div className="flex shrink-1 w-fit items-center justify-start">
|
2023-08-15 00:22:55 +02:00
|
|
|
<img
|
|
|
|
src={logo}
|
|
|
|
alt="Logo"
|
|
|
|
className="rounded w-full max-h-[40px]"
|
|
|
|
style={{ objectFit: "contain" }}
|
|
|
|
/>
|
|
|
|
</div>
|
2024-03-12 18:45:03 +01:00
|
|
|
{(!user || user?.role !== "default") && (
|
|
|
|
<div className="flex gap-x-2 items-center text-slate-500 shink-0">
|
|
|
|
<SettingsButton />
|
|
|
|
</div>
|
|
|
|
)}
|
2023-06-17 08:50:56 +02:00
|
|
|
</div>
|
|
|
|
|
|
|
|
{/* Primary Body */}
|
|
|
|
<div className="h-full flex flex-col w-full justify-between pt-4 overflow-y-hidden ">
|
2023-10-23 22:10:34 +02:00
|
|
|
<div className="h-auto md:sidebar-items">
|
2023-06-17 08:50:56 +02:00
|
|
|
<div
|
|
|
|
style={{ height: "calc(100vw - -3rem)" }}
|
|
|
|
className=" flex flex-col gap-y-4 pb-8 overflow-y-scroll no-scroll"
|
|
|
|
>
|
|
|
|
<div className="flex gap-x-2 items-center justify-between">
|
2023-11-13 23:51:16 +01:00
|
|
|
{(!user || user?.role !== "default") && (
|
|
|
|
<button
|
|
|
|
onClick={showNewWsModal}
|
|
|
|
className="flex flex-grow w-[75%] h-[44px] gap-x-2 py-[5px] px-4 bg-white rounded-lg text-sidebar justify-center items-center hover:bg-opacity-80 transition-all duration-300"
|
|
|
|
>
|
|
|
|
<Plus className="h-5 w-5" />
|
|
|
|
<p className="text-sidebar text-sm font-semibold">
|
|
|
|
New Workspace
|
|
|
|
</p>
|
|
|
|
</button>
|
|
|
|
)}
|
2023-06-17 08:50:56 +02:00
|
|
|
</div>
|
|
|
|
<ActiveWorkspaces />
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div>
|
2024-02-08 21:17:01 +01:00
|
|
|
<Footer />
|
2023-06-17 08:50:56 +02:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
{showingNewWsModal && <NewWorkspaceModal hideModal={hideNewWsModal} />}
|
|
|
|
</div>
|
|
|
|
</>
|
|
|
|
);
|
|
|
|
}
|