2023-12-13 05:54:05 +00:00
|
|
|
import get from "lodash/get";
|
2023-12-13 05:12:06 +00:00
|
|
|
// store
|
|
|
|
import { action, makeObservable, observable, runInAction } from "mobx";
|
|
|
|
import { IIssueRootStore } from "./root.store";
|
|
|
|
// types
|
|
|
|
import { IIssue } from "types";
|
|
|
|
|
|
|
|
export interface IIssueStore {
|
2023-12-13 05:54:05 +00:00
|
|
|
allIssues: { [key: string]: IIssue };
|
2023-12-13 05:12:06 +00:00
|
|
|
// actions
|
|
|
|
addIssue(issues: IIssue[]): void;
|
|
|
|
updateIssue(issueId: string, issue: Partial<IIssue>): void;
|
|
|
|
removeIssue(issueId: string): void;
|
|
|
|
// helper Methods
|
|
|
|
getIssueById(id: string): undefined | IIssue;
|
2023-12-13 05:54:05 +00:00
|
|
|
getIssuesByKey(issueKey: string, value: string): undefined | { [key: string]: IIssue };
|
2023-12-13 05:12:06 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
export class IssueStore implements IIssueStore {
|
2023-12-13 05:54:05 +00:00
|
|
|
allIssues: { [key: string]: IIssue } = {};
|
2023-12-13 05:12:06 +00:00
|
|
|
// root store
|
|
|
|
rootStore: IIssueRootStore;
|
|
|
|
|
|
|
|
constructor(rootStore: IIssueRootStore) {
|
|
|
|
this.rootStore = rootStore;
|
|
|
|
|
|
|
|
makeObservable(this, {
|
|
|
|
// observable
|
2023-12-13 05:54:05 +00:00
|
|
|
allIssues: observable.ref,
|
2023-12-13 05:12:06 +00:00
|
|
|
// actions
|
|
|
|
addIssue: action,
|
|
|
|
updateIssue: action,
|
|
|
|
removeIssue: action,
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
addIssue = (issues: IIssue[]) => {
|
|
|
|
if (issues && issues.length <= 0) return;
|
|
|
|
|
2023-12-13 05:54:05 +00:00
|
|
|
const _issues = { ...this.allIssues };
|
2023-12-13 05:12:06 +00:00
|
|
|
issues.forEach((issue) => {
|
|
|
|
_issues[issue.id] = issue;
|
|
|
|
});
|
2023-12-13 05:54:05 +00:00
|
|
|
|
2023-12-13 05:12:06 +00:00
|
|
|
runInAction(() => {
|
2023-12-13 05:54:05 +00:00
|
|
|
this.allIssues = _issues;
|
2023-12-13 05:12:06 +00:00
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
updateIssue = (issueId: string, issue: Partial<IIssue>) => {
|
2023-12-13 05:54:05 +00:00
|
|
|
if (!issue || !issueId || !this.allIssues[issueId]) return;
|
|
|
|
this.allIssues[issueId] = { ...this.allIssues[issueId], ...issue };
|
2023-12-13 05:12:06 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
removeIssue = (issueId: string) => {
|
|
|
|
if (issueId) return;
|
2023-12-13 05:54:05 +00:00
|
|
|
delete this.allIssues[issueId];
|
2023-12-13 05:12:06 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
// helper methods
|
|
|
|
getIssueById = (id: string) => {
|
|
|
|
if (!id) return undefined;
|
2023-12-13 05:54:05 +00:00
|
|
|
return this.allIssues[id];
|
2023-12-13 05:12:06 +00:00
|
|
|
};
|
|
|
|
|
2023-12-13 05:54:05 +00:00
|
|
|
getIssuesByKey = (issueKey: keyof IIssue, value: string) => {
|
|
|
|
if (!issueKey || !value || !this.allIssues) return undefined;
|
2023-12-13 05:12:06 +00:00
|
|
|
const filteredIssues: { [key: string]: IIssue } = {};
|
|
|
|
|
2023-12-13 05:54:05 +00:00
|
|
|
Object.values(this.allIssues).forEach((issue) => {
|
|
|
|
const issueKeyValue = get(issue, issueKey);
|
|
|
|
if (issueKeyValue == value) {
|
|
|
|
filteredIssues[issue.id] = issue;
|
|
|
|
}
|
2023-12-13 05:12:06 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
return filteredIssues;
|
|
|
|
};
|
|
|
|
}
|