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 { List } from "./default"; import { ModuleIssueQuickActions } from "components/issues"; // types import { IIssue } from "types"; // constants import { ISSUE_STATE_GROUPS, ISSUE_PRIORITIES } from "constants/issue"; export interface IModuleListLayout {} export const ModuleListLayout: React.FC = observer(() => { const router = useRouter(); const { workspaceSlug, moduleId } = router.query; const { project: projectStore, issueFilter: issueFilterStore, moduleIssue: moduleIssueStore, issueDetail: issueDetailStore, } = useMobxStore(); const issues = moduleIssueStore?.getIssues; const group_by: string | null = issueFilterStore?.userDisplayFilters?.group_by || null; const display_properties = issueFilterStore?.userDisplayProperties || null; const handleIssues = useCallback( (group_by: string | null, issue: IIssue, action: "update" | "delete" | "remove") => { if (!workspaceSlug || !moduleId) return; if (action === "update") { moduleIssueStore.updateIssueStructure(group_by, null, issue); issueDetailStore.updateIssue(workspaceSlug.toString(), issue.project, issue.id, issue); } if (action === "delete") moduleIssueStore.deleteIssue(group_by, null, issue); if (action === "remove" && issue.bridge_id) { moduleIssueStore.deleteIssue(group_by, null, issue); moduleIssueStore.removeIssueFromModule( workspaceSlug.toString(), issue.project, moduleId.toString(), issue.bridge_id ); } }, [moduleIssueStore, issueDetailStore, moduleId, workspaceSlug] ); const states = projectStore?.projectStates || null; const priorities = ISSUE_PRIORITIES || null; const labels = projectStore?.projectLabels || null; const members = projectStore?.projectMembers || null; const stateGroups = ISSUE_STATE_GROUPS || null; const projects = projectStore?.projectStates || null; const estimates = null; return (
( handleIssues(group_by, issue, "delete")} handleUpdate={async (data) => handleIssues(group_by, data, "update")} handleRemoveFromModule={async () => handleIssues(group_by, issue, "remove")} /> )} display_properties={display_properties} states={states} stateGroups={stateGroups} priorities={priorities} labels={labels} members={members} projects={projects} estimates={estimates} />
); });