import React, { useState, FC } from "react"; import { useRouter } from "next/router"; import Link from "next/link"; import { Disclosure, Transition } from "@headlessui/react"; import useSWR from "swr"; // icons import { ContrastIcon, LayerDiagonalIcon, PeopleGroupIcon } from "components/icons"; import { ChevronDownIcon, PlusIcon, Cog6ToothIcon } from "@heroicons/react/24/outline"; // hooks import useToast from "hooks/use-toast"; import useTheme from "hooks/use-theme"; // services import projectService from "services/project.service"; // components import { CreateProjectModal } from "components/project"; // ui import { CustomMenu, Loader } from "components/ui"; // helpers import { copyTextToClipboard, truncateText } from "helpers/string.helper"; // fetch-keys import { FAVORITE_PROJECTS_LIST, PROJECTS_LIST } from "constants/fetch-keys"; const navigation = (workspaceSlug: string, projectId: string) => [ { name: "Issues", href: `/${workspaceSlug}/projects/${projectId}/issues`, icon: LayerDiagonalIcon, }, { name: "Cycles", href: `/${workspaceSlug}/projects/${projectId}/cycles`, icon: ContrastIcon, }, { name: "Modules", href: `/${workspaceSlug}/projects/${projectId}/modules`, icon: PeopleGroupIcon, }, { name: "Settings", href: `/${workspaceSlug}/projects/${projectId}/settings`, icon: Cog6ToothIcon, }, ]; export const ProjectSidebarList: FC = () => { // router const router = useRouter(); const { workspaceSlug, projectId } = router.query; // states const [isCreateProjectModal, setCreateProjectModal] = useState(false); // theme const { collapsed: sidebarCollapse } = useTheme(); // toast handler const { setToastAlert } = useToast(); const { data: favoriteProjects } = useSWR( workspaceSlug ? FAVORITE_PROJECTS_LIST(workspaceSlug as string) : null, () => (workspaceSlug ? projectService.getFavoriteProjects(workspaceSlug as string) : null) ); const { data: projects } = useSWR( workspaceSlug ? PROJECTS_LIST(workspaceSlug as string) : null, () => (workspaceSlug ? projectService.getProjects(workspaceSlug as string) : null) ); const normalProjects = projects?.filter((p) => !p.is_favourite) ?? []; const handleCopyText = (projectId: string) => { const originURL = typeof window !== "undefined" && window.location.origin ? window.location.origin : ""; copyTextToClipboard(`${originURL}/${workspaceSlug}/projects/${projectId}/issues`).then(() => { setToastAlert({ type: "success", title: "Link Copied!", message: "Project link copied to clipboard.", }); }); }; return ( <>
{favoriteProjects && favoriteProjects.length > 0 && (
{!sidebarCollapse &&
Favorites
} {favoriteProjects.map((favoriteProject) => { const project = favoriteProject.project_detail; return ( {({ open }) => ( <>
{project.icon ? ( {String.fromCodePoint(parseInt(project.icon))} ) : ( {project?.name.charAt(0)} )} {!sidebarCollapse && (

{truncateText(project?.name, 20)}

)}
{!sidebarCollapse && ( handleCopyText(project.id)}> Copy project link )} {!sidebarCollapse && ( )}
{navigation(workspaceSlug as string, project?.id).map((item) => { if (item.name === "Cycles" && !project.cycle_view) return; if (item.name === "Modules" && !project.module_view) return; return (
{!sidebarCollapse && item.name}
); })}
)}
); })}
)}
{!sidebarCollapse &&
Projects
} {projects ? ( <> {normalProjects.length > 0 ? ( normalProjects.map((project) => ( {({ open }) => ( <>
{project.icon ? ( {String.fromCodePoint(parseInt(project.icon))} ) : ( {project?.name.charAt(0)} )} {!sidebarCollapse && (

{truncateText(project?.name, 20)}

)}
{!sidebarCollapse && ( handleCopyText(project.id)}> Copy project link )} {!sidebarCollapse && ( )}
{navigation(workspaceSlug as string, project?.id).map((item) => { if (item.name === "Cycles" && !project.cycle_view) return; if (item.name === "Modules" && !project.module_view) return; return (
{!sidebarCollapse && item.name}
); })}
)}
)) ) : (
{!sidebarCollapse && (

You don{"'"}t have any project yet

)}
)} ) : (
)}
); };