forked from github/plane
refactor: update draft issue grouping
This commit is contained in:
parent
82e65c44a4
commit
adda14e8bf
@ -29,13 +29,18 @@ export const DraftIssueListLayout: FC = observer(() => {
|
|||||||
(group_by: string | null, issue: IIssue, action: "update" | "delete" | "convertToIssue") => {
|
(group_by: string | null, issue: IIssue, action: "update" | "delete" | "convertToIssue") => {
|
||||||
if (!workspaceSlug || !projectId) return;
|
if (!workspaceSlug || !projectId) return;
|
||||||
|
|
||||||
|
const grouping = {
|
||||||
|
group_id: group_by,
|
||||||
|
sub_group_id: null,
|
||||||
|
};
|
||||||
|
|
||||||
if (action === "update") {
|
if (action === "update") {
|
||||||
draftIssuesStore.updateDraftIssue(workspaceSlug.toString(), projectId.toString(), issue);
|
draftIssuesStore.updateDraftIssue(workspaceSlug.toString(), projectId.toString(), grouping, issue);
|
||||||
draftIssuesStore.updateIssueStructure(group_by, null, issue);
|
draftIssuesStore.updateIssueStructure(group_by, null, issue);
|
||||||
} else if (action === "delete") {
|
} else if (action === "delete") {
|
||||||
draftIssuesStore.deleteDraftIssue(workspaceSlug.toString(), projectId.toString(), issue.id);
|
draftIssuesStore.deleteDraftIssue(workspaceSlug.toString(), projectId.toString(), issue.id);
|
||||||
} else if (action === "convertToIssue") {
|
} else if (action === "convertToIssue") {
|
||||||
draftIssuesStore.convertDraftIssueToIssue(workspaceSlug.toString(), projectId.toString(), issue.id);
|
draftIssuesStore.convertDraftIssueToIssue(workspaceSlug.toString(), projectId.toString(), grouping, issue.id);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
[workspaceSlug, projectId, draftIssuesStore]
|
[workspaceSlug, projectId, draftIssuesStore]
|
||||||
|
@ -57,8 +57,24 @@ export interface IIssueDraftStore {
|
|||||||
createDraftIssue: (workspaceSlug: string, projectId: string, issueForm: Partial<IIssue>) => Promise<any>;
|
createDraftIssue: (workspaceSlug: string, projectId: string, issueForm: Partial<IIssue>) => Promise<any>;
|
||||||
updateIssueStructure: (group_id: string | null, sub_group_id: string | null, issue: IIssue) => void;
|
updateIssueStructure: (group_id: string | null, sub_group_id: string | null, issue: IIssue) => void;
|
||||||
deleteDraftIssue: (workspaceSlug: string, projectId: string, issueId: string) => Promise<any>;
|
deleteDraftIssue: (workspaceSlug: string, projectId: string, issueId: string) => Promise<any>;
|
||||||
updateDraftIssue: (workspaceSlug: string, projectId: string, issueForm: Partial<IIssue>) => Promise<any>;
|
updateDraftIssue: (
|
||||||
convertDraftIssueToIssue: (workspaceSlug: string, projectId: string, issueId: string) => Promise<any>;
|
workspaceSlug: string,
|
||||||
|
projectId: string,
|
||||||
|
grouping: {
|
||||||
|
group_id: string | null;
|
||||||
|
sub_group_id: string | null;
|
||||||
|
},
|
||||||
|
issueForm: Partial<IIssue>
|
||||||
|
) => Promise<any>;
|
||||||
|
convertDraftIssueToIssue: (
|
||||||
|
workspaceSlug: string,
|
||||||
|
projectId: string,
|
||||||
|
grouping: {
|
||||||
|
group_id: string | null;
|
||||||
|
sub_group_id: string | null;
|
||||||
|
},
|
||||||
|
issueId: string
|
||||||
|
) => Promise<any>;
|
||||||
|
|
||||||
// service
|
// service
|
||||||
draftIssueService: IssueDraftService;
|
draftIssueService: IssueDraftService;
|
||||||
@ -96,8 +112,8 @@ export class IssueDraftStore implements IIssueDraftStore {
|
|||||||
|
|
||||||
get getIssueType() {
|
get getIssueType() {
|
||||||
// FIXME: this is temporary for development
|
// FIXME: this is temporary for development
|
||||||
return "grouped";
|
// return "grouped";
|
||||||
// return "ungrouped";
|
return "ungrouped";
|
||||||
|
|
||||||
const groupedLayouts = ["kanban", "list", "calendar"];
|
const groupedLayouts = ["kanban", "list", "calendar"];
|
||||||
const ungroupedLayouts = ["spreadsheet", "gantt_chart"];
|
const ungroupedLayouts = ["spreadsheet", "gantt_chart"];
|
||||||
@ -136,7 +152,7 @@ export class IssueDraftStore implements IIssueDraftStore {
|
|||||||
// const params = this.rootStore?.issueFilter?.appliedFilters;
|
// const params = this.rootStore?.issueFilter?.appliedFilters;
|
||||||
// TODO: use actual params using applied filters
|
// TODO: use actual params using applied filters
|
||||||
const params = {
|
const params = {
|
||||||
group_by: "state",
|
// group_by: "state",
|
||||||
};
|
};
|
||||||
const issueResponse = await this.draftIssueService.getDraftIssues(workspaceSlug, projectId, params);
|
const issueResponse = await this.draftIssueService.getDraftIssues(workspaceSlug, projectId, params);
|
||||||
|
|
||||||
@ -275,12 +291,18 @@ export class IssueDraftStore implements IIssueDraftStore {
|
|||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
updateDraftIssue = async (workspaceSlug: string, projectId: string, issueForm: Partial<IIssue>) => {
|
updateDraftIssue = async (
|
||||||
|
workspaceSlug: string,
|
||||||
|
projectId: string,
|
||||||
|
grouping: {
|
||||||
|
group_id: string | null;
|
||||||
|
sub_group_id: string | null;
|
||||||
|
},
|
||||||
|
issueForm: Partial<IIssue>
|
||||||
|
) => {
|
||||||
const originalIssues = { ...this.draftIssues };
|
const originalIssues = { ...this.draftIssues };
|
||||||
|
|
||||||
// FIXME: use real group_id and sub_group_id from filters
|
const { group_id, sub_group_id } = grouping;
|
||||||
const group_id = "1";
|
|
||||||
const sub_group_id = "1";
|
|
||||||
|
|
||||||
runInAction(() => {
|
runInAction(() => {
|
||||||
this.loader = true;
|
this.loader = true;
|
||||||
@ -314,9 +336,17 @@ export class IssueDraftStore implements IIssueDraftStore {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
convertDraftIssueToIssue = async (workspaceSlug: string, projectId: string, issueId: string) =>
|
convertDraftIssueToIssue = async (
|
||||||
|
workspaceSlug: string,
|
||||||
|
projectId: string,
|
||||||
|
grouping: {
|
||||||
|
group_id: string | null;
|
||||||
|
sub_group_id: string | null;
|
||||||
|
},
|
||||||
|
issueId: string
|
||||||
|
) =>
|
||||||
// TODO: add removing item from draft issue list
|
// TODO: add removing item from draft issue list
|
||||||
await this.updateDraftIssue(workspaceSlug, projectId, { id: issueId, is_draft: false });
|
await this.updateDraftIssue(workspaceSlug, projectId, grouping, { id: issueId, is_draft: false });
|
||||||
|
|
||||||
deleteDraftIssue = async (workspaceSlug: string, projectId: string, issueId: string) => {
|
deleteDraftIssue = async (workspaceSlug: string, projectId: string, issueId: string) => {
|
||||||
const originalIssues = { ...this.draftIssues };
|
const originalIssues = { ...this.draftIssues };
|
||||||
|
Loading…
Reference in New Issue
Block a user