2024-02-21 13:50:46 +00:00
|
|
|
import React, { useCallback } from "react";
|
|
|
|
import xor from "lodash/xor";
|
2024-03-06 13:09:14 +00:00
|
|
|
import { observer } from "mobx-react-lite";
|
|
|
|
import { useRouter } from "next/router";
|
2024-03-19 14:38:35 +00:00
|
|
|
import { TIssue } from "@plane/types";
|
2024-02-21 13:50:46 +00:00
|
|
|
// hooks
|
2024-03-19 14:38:35 +00:00
|
|
|
import { ModuleDropdown } from "@/components/dropdowns";
|
2024-04-29 09:02:05 +00:00
|
|
|
// constants
|
|
|
|
import { E_SPREADSHEET_LAYOUT } from "@/constants/event-tracker";
|
2024-03-19 14:38:35 +00:00
|
|
|
import { EIssuesStoreType } from "@/constants/issue";
|
|
|
|
import { useEventTracker, useIssues } from "@/hooks/store";
|
2024-02-21 13:50:46 +00:00
|
|
|
// components
|
|
|
|
// types
|
|
|
|
|
|
|
|
type Props = {
|
|
|
|
issue: TIssue;
|
|
|
|
onClose: () => void;
|
|
|
|
disabled: boolean;
|
|
|
|
};
|
|
|
|
|
|
|
|
export const SpreadsheetModuleColumn: React.FC<Props> = observer((props) => {
|
|
|
|
// router
|
|
|
|
const router = useRouter();
|
|
|
|
const { workspaceSlug } = router.query;
|
|
|
|
// props
|
|
|
|
const { issue, disabled, onClose } = props;
|
|
|
|
// hooks
|
|
|
|
const { captureIssueEvent } = useEventTracker();
|
|
|
|
const {
|
|
|
|
issues: { addModulesToIssue, removeModulesFromIssue },
|
|
|
|
} = useIssues(EIssuesStoreType.MODULE);
|
|
|
|
|
|
|
|
const handleModule = useCallback(
|
|
|
|
async (moduleIds: string[] | null) => {
|
|
|
|
if (!workspaceSlug || !issue || !issue.module_ids || !moduleIds) return;
|
|
|
|
|
|
|
|
const updatedModuleIds = xor(issue.module_ids, moduleIds);
|
|
|
|
const modulesToAdd: string[] = [];
|
|
|
|
const modulesToRemove: string[] = [];
|
|
|
|
for (const moduleId of updatedModuleIds)
|
|
|
|
if (issue.module_ids.includes(moduleId)) modulesToRemove.push(moduleId);
|
|
|
|
else modulesToAdd.push(moduleId);
|
|
|
|
if (modulesToAdd.length > 0)
|
|
|
|
addModulesToIssue(workspaceSlug.toString(), issue.project_id, issue.id, modulesToAdd);
|
|
|
|
if (modulesToRemove.length > 0)
|
|
|
|
removeModulesFromIssue(workspaceSlug.toString(), issue.project_id, issue.id, modulesToRemove);
|
|
|
|
|
|
|
|
captureIssueEvent({
|
|
|
|
eventName: "Issue updated",
|
|
|
|
payload: {
|
|
|
|
...issue,
|
|
|
|
module_ids: moduleIds,
|
2024-03-15 06:34:34 +00:00
|
|
|
element: E_SPREADSHEET_LAYOUT,
|
2024-02-21 13:50:46 +00:00
|
|
|
},
|
|
|
|
updates: { changed_property: "module_ids", change_details: { module_ids: moduleIds } },
|
2024-03-08 13:27:12 +00:00
|
|
|
routePath: router.asPath,
|
2024-02-21 13:50:46 +00:00
|
|
|
});
|
|
|
|
},
|
|
|
|
[workspaceSlug, issue, addModulesToIssue, removeModulesFromIssue, captureIssueEvent, router.asPath]
|
|
|
|
);
|
|
|
|
|
|
|
|
return (
|
|
|
|
<div className="h-11 border-b-[0.5px] border-custom-border-200">
|
|
|
|
<ModuleDropdown
|
|
|
|
projectId={issue?.project_id}
|
|
|
|
value={issue?.module_ids ?? []}
|
|
|
|
onChange={handleModule}
|
|
|
|
disabled={disabled}
|
|
|
|
placeholder="Select modules"
|
|
|
|
buttonVariant="transparent-with-text"
|
|
|
|
buttonContainerClassName="w-full relative flex items-center p-2"
|
|
|
|
buttonClassName="relative border-[0.5px] border-custom-border-400 h-4.5"
|
|
|
|
onClose={onClose}
|
|
|
|
multiple
|
2024-03-06 13:09:14 +00:00
|
|
|
showCount
|
2024-02-21 13:50:46 +00:00
|
|
|
showTooltip
|
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
});
|