2023-12-11 09:06:34 +00:00
|
|
|
import { IIssueUnGroupedStructure } from "store_legacy/issue";
|
2023-11-23 09:17:04 +00:00
|
|
|
import { SpreadsheetView } from "./spreadsheet-view";
|
2023-11-27 08:45:33 +00:00
|
|
|
import { FC, useCallback } from "react";
|
2023-11-23 09:17:04 +00:00
|
|
|
import { IIssue, IIssueDisplayFilterOptions } from "types";
|
|
|
|
import { useRouter } from "next/router";
|
|
|
|
import { useMobxStore } from "lib/mobx/store-provider";
|
|
|
|
import {
|
|
|
|
ICycleIssuesFilterStore,
|
|
|
|
ICycleIssuesStore,
|
|
|
|
IModuleIssuesFilterStore,
|
|
|
|
IModuleIssuesStore,
|
|
|
|
IProjectIssuesFilterStore,
|
|
|
|
IProjectIssuesStore,
|
|
|
|
IViewIssuesFilterStore,
|
|
|
|
IViewIssuesStore,
|
2023-12-11 09:06:34 +00:00
|
|
|
} from "store_legacy/issues";
|
2023-11-23 09:17:04 +00:00
|
|
|
import { observer } from "mobx-react-lite";
|
2023-12-11 09:06:34 +00:00
|
|
|
import { EFilterType, TUnGroupedIssues } from "store_legacy/issues/types";
|
2023-11-27 08:45:33 +00:00
|
|
|
import { EIssueActions } from "../types";
|
|
|
|
import { IQuickActionProps } from "../list/list-view-types";
|
2023-12-04 14:33:23 +00:00
|
|
|
import { EUserWorkspaceRoles } from "constants/workspace";
|
2023-11-23 09:17:04 +00:00
|
|
|
|
|
|
|
interface IBaseSpreadsheetRoot {
|
|
|
|
issueFiltersStore:
|
|
|
|
| IViewIssuesFilterStore
|
|
|
|
| ICycleIssuesFilterStore
|
|
|
|
| IModuleIssuesFilterStore
|
|
|
|
| IProjectIssuesFilterStore;
|
|
|
|
issueStore: IProjectIssuesStore | IModuleIssuesStore | ICycleIssuesStore | IViewIssuesStore;
|
|
|
|
viewId?: string;
|
2023-11-27 08:45:33 +00:00
|
|
|
QuickActions: FC<IQuickActionProps>;
|
|
|
|
issueActions: {
|
|
|
|
[EIssueActions.DELETE]: (issue: IIssue) => void;
|
|
|
|
[EIssueActions.UPDATE]?: (issue: IIssue) => void;
|
|
|
|
[EIssueActions.REMOVE]?: (issue: IIssue) => void;
|
|
|
|
};
|
2023-12-07 14:16:57 +00:00
|
|
|
canEditPropertiesBasedOnProject?: (projectId: string) => boolean;
|
2023-11-23 09:17:04 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
export const BaseSpreadsheetRoot = observer((props: IBaseSpreadsheetRoot) => {
|
2023-12-07 14:16:57 +00:00
|
|
|
const { issueFiltersStore, issueStore, viewId, QuickActions, issueActions, canEditPropertiesBasedOnProject } = props;
|
2023-11-23 09:17:04 +00:00
|
|
|
|
|
|
|
const router = useRouter();
|
|
|
|
const { workspaceSlug, projectId } = router.query as { workspaceSlug: string; projectId: string };
|
|
|
|
|
|
|
|
const {
|
|
|
|
projectMember: { projectMembers },
|
|
|
|
projectState: projectStateStore,
|
|
|
|
projectLabel: { projectLabels },
|
|
|
|
user: userStore,
|
|
|
|
} = useMobxStore();
|
|
|
|
|
2023-12-07 14:16:57 +00:00
|
|
|
const { enableInlineEditing, enableQuickAdd } = issueStore?.viewFlags || {};
|
|
|
|
|
2023-11-29 14:28:27 +00:00
|
|
|
const { currentProjectRole } = userStore;
|
2023-12-04 14:33:23 +00:00
|
|
|
const isEditingAllowed = !!currentProjectRole && currentProjectRole >= EUserWorkspaceRoles.MEMBER;
|
2023-11-23 09:17:04 +00:00
|
|
|
|
2023-12-07 14:16:57 +00:00
|
|
|
const canEditProperties = (projectId: string | undefined) => {
|
|
|
|
const isEditingAllowedBasedOnProject =
|
|
|
|
canEditPropertiesBasedOnProject && projectId ? canEditPropertiesBasedOnProject(projectId) : isEditingAllowed;
|
|
|
|
|
|
|
|
return enableInlineEditing && isEditingAllowedBasedOnProject;
|
|
|
|
};
|
|
|
|
|
2023-11-23 09:17:04 +00:00
|
|
|
const issuesResponse = issueStore.getIssues;
|
|
|
|
const issueIds = (issueStore.getIssuesIds ?? []) as TUnGroupedIssues;
|
|
|
|
|
2023-11-27 08:45:33 +00:00
|
|
|
const issues = issueIds?.filter((id) => id && issuesResponse?.[id]).map((id) => issuesResponse?.[id]);
|
2023-11-23 09:17:04 +00:00
|
|
|
|
2023-11-27 08:45:33 +00:00
|
|
|
const handleIssues = useCallback(
|
|
|
|
async (issue: IIssue, action: EIssueActions) => {
|
|
|
|
if (issueActions[action]) {
|
|
|
|
issueActions[action]!(issue);
|
|
|
|
}
|
|
|
|
},
|
2023-12-06 15:01:42 +00:00
|
|
|
[issueActions]
|
2023-11-27 08:45:33 +00:00
|
|
|
);
|
2023-11-23 09:17:04 +00:00
|
|
|
|
|
|
|
const handleDisplayFiltersUpdate = useCallback(
|
|
|
|
(updatedDisplayFilter: Partial<IIssueDisplayFilterOptions>) => {
|
|
|
|
if (!workspaceSlug || !projectId) return;
|
|
|
|
|
|
|
|
issueFiltersStore.updateFilters(
|
|
|
|
workspaceSlug,
|
|
|
|
projectId,
|
|
|
|
EFilterType.DISPLAY_FILTERS,
|
|
|
|
{
|
|
|
|
...updatedDisplayFilter,
|
|
|
|
},
|
|
|
|
viewId
|
|
|
|
);
|
|
|
|
},
|
2023-12-06 15:01:42 +00:00
|
|
|
[issueFiltersStore, projectId, workspaceSlug, viewId]
|
2023-11-23 09:17:04 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
return (
|
|
|
|
<SpreadsheetView
|
|
|
|
displayProperties={issueFiltersStore.issueFilters?.displayProperties ?? {}}
|
|
|
|
displayFilters={issueFiltersStore.issueFilters?.displayFilters ?? {}}
|
|
|
|
handleDisplayFilterUpdate={handleDisplayFiltersUpdate}
|
|
|
|
issues={issues as IIssueUnGroupedStructure}
|
2023-12-06 13:51:24 +00:00
|
|
|
quickActions={(issue, customActionButton) => (
|
2023-11-27 08:45:33 +00:00
|
|
|
<QuickActions
|
2023-12-06 13:51:24 +00:00
|
|
|
customActionButton={customActionButton}
|
2023-11-27 08:45:33 +00:00
|
|
|
issue={issue}
|
|
|
|
handleDelete={async () => handleIssues(issue, EIssueActions.DELETE)}
|
|
|
|
handleUpdate={
|
|
|
|
issueActions[EIssueActions.UPDATE] ? async (data) => handleIssues(data, EIssueActions.UPDATE) : undefined
|
|
|
|
}
|
|
|
|
handleRemoveFromView={
|
|
|
|
issueActions[EIssueActions.REMOVE] ? async () => handleIssues(issue, EIssueActions.REMOVE) : undefined
|
|
|
|
}
|
|
|
|
/>
|
|
|
|
)}
|
2023-11-23 09:17:04 +00:00
|
|
|
members={projectMembers?.map((m) => m.member)}
|
|
|
|
labels={projectLabels || undefined}
|
|
|
|
states={projectId ? projectStateStore.states?.[projectId.toString()] : undefined}
|
2023-11-27 08:45:33 +00:00
|
|
|
handleIssues={handleIssues}
|
2023-12-07 14:16:57 +00:00
|
|
|
canEditProperties={canEditProperties}
|
2023-11-23 09:17:04 +00:00
|
|
|
quickAddCallback={issueStore.quickAddIssue}
|
|
|
|
viewId={viewId}
|
2023-12-07 14:16:57 +00:00
|
|
|
enableQuickCreateIssue={enableQuickAdd}
|
2023-11-23 09:17:04 +00:00
|
|
|
/>
|
|
|
|
);
|
|
|
|
});
|