import { useCallback, useState } from "react"; import { useRouter } from "next/router"; import useSWR, { mutate } from "swr"; // react-beautiful-dnd import { DropResult } from "react-beautiful-dnd"; // services import issuesService from "services/issues.service"; // hooks import useMyIssues from "hooks/my-issues/use-my-issues"; import useMyIssuesFilters from "hooks/my-issues/use-my-issues-filter"; import useUserAuth from "hooks/use-user-auth"; // components import { AllViews, FiltersList } from "components/core"; import { CreateUpdateIssueModal, DeleteIssueModal } from "components/issues"; import { CreateUpdateViewModal } from "components/views"; // types import { IIssue, IIssueFilterOptions } from "types"; // fetch-keys import { USER_ISSUES, WORKSPACE_LABELS } from "constants/fetch-keys"; import { orderArrayBy } from "helpers/array.helper"; type Props = { openIssuesListModal?: () => void; disableUserActions?: false; }; export const MyIssuesView: React.FC = ({ openIssuesListModal, disableUserActions = false, }) => { // create issue modal const [createIssueModal, setCreateIssueModal] = useState(false); const [createViewModal, setCreateViewModal] = useState(null); const [preloadedData, setPreloadedData] = useState< (Partial & { actionType: "createIssue" | "edit" | "delete" }) | undefined >(undefined); // update issue modal const [editIssueModal, setEditIssueModal] = useState(false); const [issueToEdit, setIssueToEdit] = useState< (IIssue & { actionType: "edit" | "delete" }) | undefined >(undefined); // delete issue modal const [deleteIssueModal, setDeleteIssueModal] = useState(false); const [issueToDelete, setIssueToDelete] = useState(null); // trash box const [trashBox, setTrashBox] = useState(false); const router = useRouter(); const { workspaceSlug } = router.query; const { user } = useUserAuth(); const { groupedIssues, isEmpty, params } = useMyIssues(workspaceSlug?.toString()); const { filters, setFilters, issueView, groupBy, orderBy, properties, showEmptyGroups } = useMyIssuesFilters(workspaceSlug?.toString()); const { data: labels } = useSWR( workspaceSlug && (filters.labels ?? []).length > 0 ? WORKSPACE_LABELS(workspaceSlug.toString()) : null, workspaceSlug && (filters.labels ?? []).length > 0 ? () => issuesService.getWorkspaceLabels(workspaceSlug.toString()) : null ); const handleDeleteIssue = useCallback( (issue: IIssue) => { setDeleteIssueModal(true); setIssueToDelete(issue); }, [setDeleteIssueModal, setIssueToDelete] ); const handleOnDragEnd = useCallback( async (result: DropResult) => { setTrashBox(false); console.log(result); if (!result.destination || !workspaceSlug || !groupedIssues || groupBy !== "priority") return; const { source, destination } = result; if (source.droppableId === destination.droppableId) return; const draggedItem = groupedIssues[source.droppableId][source.index]; if (!draggedItem) return; if (destination.droppableId === "trashBox") handleDeleteIssue(draggedItem); else { const sourceGroup = source.droppableId; const destinationGroup = destination.droppableId; draggedItem[groupBy] = destinationGroup; mutate<{ [key: string]: IIssue[]; }>( USER_ISSUES(workspaceSlug.toString(), params), (prevData) => { if (!prevData) return prevData; const sourceGroupArray = [...groupedIssues[sourceGroup]]; const destinationGroupArray = [...groupedIssues[destinationGroup]]; sourceGroupArray.splice(source.index, 1); destinationGroupArray.splice(destination.index, 0, draggedItem); return { ...prevData, [sourceGroup]: orderArrayBy(sourceGroupArray, orderBy), [destinationGroup]: orderArrayBy(destinationGroupArray, orderBy), }; }, false ); // patch request issuesService .patchIssue( workspaceSlug as string, draggedItem.project, draggedItem.id, { priority: draggedItem.priority, }, user ) .catch(() => mutate(USER_ISSUES(workspaceSlug.toString(), params))); } }, [groupBy, groupedIssues, handleDeleteIssue, orderBy, params, user, workspaceSlug] ); const addIssueToGroup = useCallback( (groupTitle: string) => { setCreateIssueModal(true); let preloadedValue: string | string[] = groupTitle; if (groupBy === "labels") { if (groupTitle === "None") preloadedValue = []; else preloadedValue = [groupTitle]; } if (groupBy) setPreloadedData({ [groupBy]: preloadedValue, actionType: "createIssue", }); else setPreloadedData({ actionType: "createIssue" }); }, [setCreateIssueModal, setPreloadedData, groupBy] ); const addIssueToDate = useCallback( (date: string) => { setCreateIssueModal(true); setPreloadedData({ target_date: date, actionType: "createIssue", }); }, [setCreateIssueModal, setPreloadedData] ); const makeIssueCopy = useCallback( (issue: IIssue) => { setCreateIssueModal(true); setPreloadedData({ ...issue, name: `${issue.name} (Copy)`, actionType: "createIssue" }); }, [setCreateIssueModal, setPreloadedData] ); const handleEditIssue = useCallback( (issue: IIssue) => { setEditIssueModal(true); setIssueToEdit({ ...issue, actionType: "edit", cycle: issue.issue_cycle ? issue.issue_cycle.cycle : null, module: issue.issue_module ? issue.issue_module.module : null, }); }, [setEditIssueModal, setIssueToEdit] ); const handleIssueAction = useCallback( (issue: IIssue, action: "copy" | "edit" | "delete") => { if (action === "copy") makeIssueCopy(issue); else if (action === "edit") handleEditIssue(issue); else if (action === "delete") handleDeleteIssue(issue); }, [makeIssueCopy, handleEditIssue, handleDeleteIssue] ); const filtersToDisplay = { ...filters, assignees: null, created_by: null }; const nullFilters = Object.keys(filtersToDisplay).filter( (key) => filtersToDisplay[key as keyof IIssueFilterOptions] === null ); const areFiltersApplied = Object.keys(filtersToDisplay).length > 0 && nullFilters.length !== Object.keys(filtersToDisplay).length; return ( <> setCreateViewModal(null)} preLoadedData={createViewModal} user={user} /> setCreateIssueModal(false)} prePopulateData={{ ...preloadedData, }} /> setEditIssueModal(false)} data={issueToEdit} /> setDeleteIssueModal(false)} isOpen={deleteIssueModal} data={issueToDelete} user={user} /> {areFiltersApplied && ( <>
setFilters({ labels: null, priority: null, state_group: null, target_date: null, type: null, }) } />
{
} )} ); };