import React, { useCallback } from "react"; import { useRouter } from "next/router"; import { observer } from "mobx-react-lite"; // mobx store import { useMobxStore } from "lib/mobx/store-provider"; // components import { SpreadsheetView } from "components/issues"; // types import { IIssue, IIssueDisplayFilterOptions } from "types"; // constants import { IIssueUnGroupedStructure } from "store/issue"; export const CycleSpreadsheetLayout: React.FC = observer(() => { const router = useRouter(); const { workspaceSlug, projectId } = router.query; const { issueFilter: issueFilterStore, cycleIssue: cycleIssueStore, issueDetail: issueDetailStore, project: projectStore, } = useMobxStore(); const issues = cycleIssueStore.getIssues; const handleDisplayFiltersUpdate = useCallback( (updatedDisplayFilter: Partial) => { if (!workspaceSlug || !projectId) return; issueFilterStore.updateUserFilters(workspaceSlug.toString(), projectId.toString(), { display_filters: { ...updatedDisplayFilter, }, }); }, [issueFilterStore, projectId, workspaceSlug] ); const handleUpdateIssue = useCallback( (issue: IIssue, data: Partial) => { if (!workspaceSlug || !projectId) return; const payload = { ...issue, ...data, }; cycleIssueStore.updateIssueStructure(null, null, payload); issueDetailStore.updateIssue(workspaceSlug.toString(), projectId.toString(), issue.id, data); }, [issueDetailStore, cycleIssueStore, projectId, workspaceSlug] ); return ( m.member) : undefined} labels={projectId ? projectStore.labels?.[projectId.toString()] ?? undefined : undefined} states={projectId ? projectStore.states?.[projectId.toString()] : undefined} handleIssueAction={() => {}} handleUpdateIssue={handleUpdateIssue} disableUserActions={false} /> ); });