import React from "react"; import { Avatar, DiceIcon, PhotoFilterIcon } from "@plane/ui"; // mobx store import { useMobxStore } from "lib/mobx/store-provider"; // react-hook-form import { Control, Controller, UseFormSetValue } from "react-hook-form"; // types import { IWorkspace } from "types"; // icons import { BarChart2, Briefcase, CheckCircle, ChevronDown, ContrastIcon, FileText, LayersIcon, LayoutGrid, PenSquare, Search, Settings, } from "lucide-react"; const workspaceLinks = [ { Icon: LayoutGrid, name: "Dashboard", }, { Icon: BarChart2, name: "Analytics", }, { Icon: Briefcase, name: "Projects", }, { Icon: CheckCircle, name: "All Issues", }, { Icon: CheckCircle, name: "Notifications", }, ]; const projectLinks = [ { name: "Issues", Icon: LayersIcon, }, { name: "Cycles", Icon: ContrastIcon, }, { name: "Modules", Icon: DiceIcon, }, { name: "Views", Icon: PhotoFilterIcon, }, { name: "Pages", Icon: FileText, }, { name: "Settings", Icon: Settings, }, ]; type Props = { workspaceName: string; showProject: boolean; control?: Control; setValue?: UseFormSetValue; }; var timer: number = 0; var lastWorkspaceName: string = ""; const DummySidebar: React.FC = (props) => { const { workspaceName, showProject, control, setValue } = props; const { workspace: workspaceStore, user: userStore } = useMobxStore(); const workspace = workspaceStore.workspaces ? workspaceStore.workspaces[0] : null; const handleZoomWorkspace = (value: string) => { // console.log(lastWorkspaceName,value); if (lastWorkspaceName === value) return; lastWorkspaceName = value; if (timer > 0) { timer += 2; timer = Math.min(timer, 4); } else { timer = 2; timer = Math.min(timer, 4); const interval = setInterval(() => { if (timer < 0) { setValue!("name", lastWorkspaceName); clearInterval(interval); } timer--; }, 1000); } }; console.log("CALLED"); return (
{control && setValue ? ( { if (value.length > 0) { handleZoomWorkspace(value); } return timer > 0 ? (
0 ? value[0].toLocaleUpperCase() : "N"} src={""} size={30} shape="square" fallbackBackgroundColor="black" className="!text-base" />
{value}
) : (
0 ? value : workspace ? workspace.name[0].toLocaleUpperCase() : "N"} src={""} size={24} shape="square" className="!text-base" />

{workspaceName}

); }} /> ) : (

{workspaceName}

)}
{New Issue}
{workspaceLinks.map((link) => { return (
{} {link.name}
); })}
{showProject && (

Projects

{" "}
Plane web
{projectLinks.map((link) => { return (
{} {link.name}
); })}
)}
); }; export default DummySidebar;