mirror of
https://github.com/makeplane/plane
synced 2024-06-14 14:31:34 +00:00
94 lines
2.2 KiB
TypeScript
94 lines
2.2 KiB
TypeScript
import { observable, action, makeObservable, runInAction, autorun } from "mobx";
|
|
// types
|
|
import { RootStore } from "../root";
|
|
// services
|
|
import { InboxService } from "services/inbox.service";
|
|
// types
|
|
import { IInboxIssue } from "types";
|
|
|
|
export interface IInboxIssuesStore {
|
|
// states
|
|
loader: boolean;
|
|
error: any | null;
|
|
|
|
// observables
|
|
inboxIssues: {
|
|
[inboxId: string]: IInboxIssue[];
|
|
};
|
|
|
|
// actions
|
|
fetchInboxIssues: (workspaceSlug: string, projectId: string, inboxId: string) => Promise<IInboxIssue[]>;
|
|
}
|
|
|
|
export class InboxIssuesStore implements IInboxIssuesStore {
|
|
// states
|
|
loader: boolean = false;
|
|
error: any | null = null;
|
|
|
|
// observables
|
|
inboxIssues: {
|
|
[inboxId: string]: IInboxIssue[];
|
|
} = {};
|
|
|
|
// root store
|
|
rootStore;
|
|
|
|
// services
|
|
inboxService;
|
|
|
|
constructor(_rootStore: RootStore) {
|
|
makeObservable(this, {
|
|
// states
|
|
loader: observable.ref,
|
|
error: observable.ref,
|
|
|
|
// observables
|
|
inboxIssues: observable.ref,
|
|
|
|
// actions
|
|
fetchInboxIssues: action,
|
|
});
|
|
|
|
this.rootStore = _rootStore;
|
|
this.inboxService = new InboxService();
|
|
|
|
autorun(() => {
|
|
const workspaceSlug = this.rootStore.workspace.workspaceSlug;
|
|
const projectId = this.rootStore.project.projectId;
|
|
const inboxId = this.rootStore.inbox.inboxId;
|
|
|
|
if (workspaceSlug && projectId && inboxId && this.rootStore.inboxFilters.inboxFilters[inboxId])
|
|
this.fetchInboxIssues(workspaceSlug, projectId, inboxId);
|
|
});
|
|
}
|
|
|
|
fetchInboxIssues = async (workspaceSlug: string, projectId: string, inboxId: string) => {
|
|
try {
|
|
runInAction(() => {
|
|
this.loader = true;
|
|
});
|
|
|
|
const queryParams = this.rootStore.inboxFilters.appliedFilters ?? undefined;
|
|
|
|
const issuesResponse = await this.inboxService.getInboxIssues(workspaceSlug, projectId, inboxId, queryParams);
|
|
|
|
runInAction(() => {
|
|
this.loader = false;
|
|
this.inboxIssues = {
|
|
...this.inboxIssues,
|
|
[inboxId]: issuesResponse,
|
|
};
|
|
});
|
|
|
|
return issuesResponse;
|
|
} catch (error) {
|
|
runInAction(() => {
|
|
this.loader = false;
|
|
this.error = error;
|
|
});
|
|
|
|
throw error;
|
|
}
|
|
};
|
|
}
|