import set from "lodash/set"; import { makeObservable, observable, runInAction, action } from "mobx"; // services // types import { TIssue, TInboxIssue, TInboxIssueStatus } from "@plane/types"; import { InboxIssueService } from "@/services/inbox"; export interface IInboxIssueStore { isLoading: boolean; id: string; status: TInboxIssueStatus; issue: Partial; snoozed_till: Date | undefined; duplicate_to: string | undefined; created_by: string | undefined; // actions updateInboxIssueStatus: (status: TInboxIssueStatus) => Promise; // accept, decline updateInboxIssueDuplicateTo: (issueId: string) => Promise; // connecting the inbox issue to the project existing issue updateInboxIssueSnoozeTill: (date: Date) => Promise; // snooze the issue updateIssue: (issue: Partial) => Promise; // updating the issue } export class InboxIssueStore implements IInboxIssueStore { // observables isLoading: boolean = false; id: string; status: TInboxIssueStatus = -2; issue: Partial = {}; snoozed_till: Date | undefined; duplicate_to: string | undefined; created_by: string | undefined; workspaceSlug: string; projectId: string; // services inboxIssueService; constructor(workspaceSlug: string, projectId: string, data: TInboxIssue) { this.id = data.id; this.status = data.status; this.issue = data?.issue; this.snoozed_till = data?.snoozed_till ? new Date(data.snoozed_till) : undefined; this.duplicate_to = data?.duplicate_to || undefined; this.created_by = data?.created_by || undefined; this.workspaceSlug = workspaceSlug; this.projectId = projectId; // services this.inboxIssueService = new InboxIssueService(); // observable variables should be defined after the initialization of the values makeObservable(this, { id: observable, status: observable, issue: observable, snoozed_till: observable, duplicate_to: observable, created_by: observable, // actions updateInboxIssueStatus: action, updateInboxIssueDuplicateTo: action, updateInboxIssueSnoozeTill: action, updateIssue: action, }); } updateInboxIssueStatus = async (status: TInboxIssueStatus) => { const previousData: Partial = { status: this.status, }; try { if (!this.issue.id) return; set(this, "status", status); await this.inboxIssueService.update(this.workspaceSlug, this.projectId, this.issue.id, { status: status, }); } catch { runInAction(() => set(this, "status", previousData.status)); } }; updateInboxIssueDuplicateTo = async (issueId: string) => { const inboxStatus = 2; const previousData: Partial = { status: this.status, duplicate_to: this.duplicate_to, }; try { if (!this.issue.id) return; set(this, "status", inboxStatus); set(this, "duplicate_to", issueId); await this.inboxIssueService.update(this.workspaceSlug, this.projectId, this.issue.id, { status: inboxStatus, duplicate_to: issueId, }); } catch { runInAction(() => { set(this, "status", previousData.status); set(this, "duplicate_to", previousData.duplicate_to); }); } }; updateInboxIssueSnoozeTill = async (date: Date) => { const inboxStatus = 0; const previousData: Partial = { status: this.status, snoozed_till: this.snoozed_till, }; try { if (!this.issue.id) return; set(this, "status", inboxStatus); set(this, "snoozed_till", date); await this.inboxIssueService.update(this.workspaceSlug, this.projectId, this.issue.id, { status: inboxStatus, snoozed_till: new Date(date), }); } catch { runInAction(() => { set(this, "status", previousData.status); set(this, "snoozed_till", previousData.snoozed_till); }); } }; updateIssue = async (issue: Partial) => { const inboxIssue = this.issue; try { if (!this.issue.id) return; Object.keys(issue).forEach((key) => { const issueKey = key as keyof TIssue; set(inboxIssue, issueKey, issue[issueKey]); }); await this.inboxIssueService.updateIssue(this.workspaceSlug, this.projectId, this.issue.id, issue); } catch { Object.keys(issue).forEach((key) => { const issueKey = key as keyof TIssue; set(inboxIssue, issueKey, inboxIssue[issueKey]); }); } }; }