plane/apps/space/store/issue.ts

110 lines
2.9 KiB
TypeScript
Raw Normal View History

import { observable, action, computed, makeObservable, runInAction, reaction } from "mobx";
2023-08-30 15:03:21 +00:00
// services
import IssueService from "services/issue.service";
2023-08-30 15:03:21 +00:00
// store
import { RootStore } from "./root";
// types
2023-08-30 15:03:21 +00:00
// import { IssueDetailType, TIssueBoardKeys } from "types/issue";
import { IIssue, IIssueState, IIssueLabel } from "types/issue";
2023-08-30 12:09:11 +00:00
export interface IIssueStore {
loader: boolean;
2023-08-30 15:03:21 +00:00
error: any;
// issue options
issues: IIssue[] | null;
2023-08-30 12:09:11 +00:00
states: IIssueState[] | null;
labels: IIssueLabel[] | null;
2023-08-30 15:03:21 +00:00
// filtering
filteredStates: string[];
filteredLabels: string[];
filteredPriorities: string[];
// peek info
peekId: string | null;
// service
issueService: any;
// actions
fetchPublicIssues: (workspace_slug: string, project_slug: string, params: any) => void;
2023-08-30 15:05:10 +00:00
setPeekId: (issueId: string | null) => void;
2023-08-30 12:09:11 +00:00
getFilteredIssuesByState: (state: string) => IIssue[];
}
2023-08-30 15:03:21 +00:00
class IssueStore implements IIssueStore {
loader: boolean = false;
error: any | null = null;
2023-08-30 15:03:21 +00:00
states: IIssueState[] | null = [];
labels: IIssueLabel[] | null = [];
2023-08-30 15:03:21 +00:00
filteredStates: string[] = [];
filteredLabels: string[] = [];
filteredPriorities: string[] = [];
2023-08-30 15:03:21 +00:00
issues: IIssue[] | null = [];
issue_detail: any = {};
2023-08-30 15:03:21 +00:00
peekId: string | null = null;
rootStore: RootStore;
issueService: any;
constructor(_rootStore: any) {
makeObservable(this, {
// observable
loader: observable,
error: observable,
2023-08-30 15:03:21 +00:00
// issue options
states: observable.ref,
labels: observable.ref,
2023-08-30 15:03:21 +00:00
// filtering
filteredStates: observable.ref,
filteredLabels: observable.ref,
filteredPriorities: observable.ref,
// issues
issues: observable.ref,
issue_detail: observable.ref,
2023-08-30 15:03:21 +00:00
// peek
peekId: observable.ref,
// actions
2023-08-30 12:09:11 +00:00
fetchPublicIssues: action,
2023-08-30 15:03:21 +00:00
setPeekId: action,
getFilteredIssuesByState: action,
});
this.rootStore = _rootStore;
this.issueService = new IssueService();
}
2023-08-30 12:09:11 +00:00
fetchPublicIssues = async (workspaceSlug: string, projectId: string, params: any) => {
try {
this.loader = true;
this.error = null;
const response = await this.issueService.getPublicIssues(workspaceSlug, projectId, params);
if (response) {
const _states: IIssueState[] = [...response?.states];
const _labels: IIssueLabel[] = [...response?.labels];
const _issues: IIssue[] = [...response?.issues];
runInAction(() => {
this.states = _states;
this.labels = _labels;
this.issues = _issues;
this.loader = false;
});
}
} catch (error) {
this.loader = false;
this.error = error;
}
};
2023-08-30 15:05:10 +00:00
setPeekId = (issueId: string | null) => {
2023-08-30 15:03:21 +00:00
this.peekId = issueId;
};
2023-08-30 15:03:21 +00:00
getFilteredIssuesByState = (state_id: string): IIssue[] | [] =>
this.issues?.filter((issue) => issue.state == state_id) || [];
}
export default IssueStore;