import { useState } from "react"; import { useRouter } from "next/router"; import useSWR from "swr"; // mobx import { useMobxStore } from "lib/mobx/store-provider"; // services import projectService from "services/project.service"; import inboxService from "services/inbox.service"; // layouts import { ProjectAuthorizationWrapper } from "layouts/auth-layout"; // helper import { truncateText } from "helpers/string.helper"; // components import { AllViews } from "components/core"; import { AnalyticsProjectModal } from "components/analytics"; import { ProjectIssuesHeader } from "components/headers"; // ui import { BreadcrumbItem, Breadcrumbs } from "components/breadcrumbs"; // icons import { PlusIcon } from "@heroicons/react/24/outline"; // types import type { NextPage } from "next"; // fetch-keys import { PROJECT_DETAILS, INBOX_LIST } from "constants/fetch-keys"; const ProjectIssues: NextPage = () => { const [analyticsModal, setAnalyticsModal] = useState(false); const router = useRouter(); const { workspaceSlug, projectId } = router.query; const { issueFilter: issueFilterStore, project: projectStore } = useMobxStore(); const { data: projectDetails } = useSWR( workspaceSlug && projectId ? PROJECT_DETAILS(projectId as string) : null, workspaceSlug && projectId ? () => projectService.getProject(workspaceSlug as string, projectId as string) : null ); const { data: inboxList } = useSWR( workspaceSlug && projectId ? INBOX_LIST(projectId as string) : null, workspaceSlug && projectId ? () => inboxService.getInboxes(workspaceSlug as string, projectId as string) : null ); // TODO: update the fetch keys useSWR( workspaceSlug && projectId ? "REVALIDATE_USER_PROJECT_FILTERS" : null, workspaceSlug && projectId ? () => issueFilterStore.fetchUserProjectFilters(workspaceSlug.toString(), projectId.toString()) : null ); useSWR( workspaceSlug && projectId ? "REVALIDATE_PROJECT_STATES_LIST" : null, workspaceSlug && projectId ? () => projectStore.fetchProjectStates(workspaceSlug.toString(), projectId.toString()) : null ); useSWR( workspaceSlug && projectId ? "REVALIDATE_PROJECT_LABELS_LIST" : null, workspaceSlug && projectId ? () => projectStore.fetchProjectLabels(workspaceSlug.toString(), projectId.toString()) : null ); useSWR( workspaceSlug && projectId ? "REVALIDATE_PROJECT_MEMBERS_LIST" : null, workspaceSlug && projectId ? () => projectStore.fetchProjectMembers(workspaceSlug.toString(), projectId.toString()) : null ); return ( } right={ //
// setAnalyticsModal(true)} // className="!py-1.5 rounded-md font-normal text-custom-sidebar-text-200 border-custom-border-200 hover:text-custom-text-100 hover:bg-custom-sidebar-background-90" // outline // > // Analytics // // {projectDetails && projectDetails.inbox_view && ( // // // // Inbox // {inboxList && inboxList?.[0]?.pending_issue_count !== 0 && ( // // {inboxList?.[0]?.pending_issue_count} // // )} // // // // )} // { // const e = new KeyboardEvent("keydown", { key: "c" }); // document.dispatchEvent(e); // }} // > // // Add Issue // //
} bg="secondary" > setAnalyticsModal(false)} />
); }; export default ProjectIssues;