forked from github/plane
187 lines
4.8 KiB
TypeScript
187 lines
4.8 KiB
TypeScript
import { observable, action, makeObservable, runInAction } from "mobx";
|
|
// types
|
|
import { RootStore } from "../root";
|
|
// services
|
|
import { ProjectIssuesServices } from "services/issues.service";
|
|
|
|
export type IPeekMode = "side" | "modal" | "full";
|
|
|
|
export interface IIssueViewDetailStore {
|
|
loader: boolean;
|
|
error: any | null;
|
|
|
|
peekId: string | null;
|
|
peekMode: IPeekMode | null;
|
|
|
|
issue_detail: {
|
|
workspace: {
|
|
[key: string]: {
|
|
issues: {
|
|
[key: string]: any;
|
|
};
|
|
};
|
|
};
|
|
};
|
|
|
|
setPeekId: (issueId: string | null) => void;
|
|
setPeekMode: (issueId: IPeekMode | null) => void;
|
|
|
|
// fetch issue details
|
|
fetchIssueDetailsAsync: (workspaceId: string, projectId: string, issueId: string) => void;
|
|
// creating issue
|
|
createIssueAsync: (workspaceId: string, projectId: string, issueId: string, data: any) => void;
|
|
// updating issue
|
|
updateIssueAsync: (workspaceId: string, projectId: string, issueId: string, data: any) => void;
|
|
// deleting issue
|
|
deleteIssueAsync: (workspaceId: string, projectId: string, issueId: string) => void;
|
|
}
|
|
|
|
class IssueViewDetailStore implements IIssueViewDetailStore {
|
|
loader: boolean = false;
|
|
error: any | null = null;
|
|
|
|
peekId: string | null = null;
|
|
peekMode: IPeekMode | null = null;
|
|
|
|
issue_detail: {
|
|
workspace: {
|
|
[key: string]: {
|
|
issues: {
|
|
[key: string]: any;
|
|
};
|
|
};
|
|
};
|
|
} = {
|
|
workspace: {},
|
|
};
|
|
|
|
// root store
|
|
rootStore;
|
|
// service
|
|
issueService;
|
|
|
|
constructor(_rootStore: RootStore) {
|
|
makeObservable(this, {
|
|
// observable
|
|
loader: observable,
|
|
error: observable,
|
|
|
|
peekId: observable,
|
|
peekMode: observable,
|
|
issue_detail: observable,
|
|
|
|
setPeekId: action,
|
|
setPeekMode: action,
|
|
|
|
fetchIssueDetailsAsync: action,
|
|
createIssueAsync: action,
|
|
updateIssueAsync: action,
|
|
deleteIssueAsync: action,
|
|
});
|
|
|
|
this.rootStore = _rootStore;
|
|
this.issueService = new ProjectIssuesServices();
|
|
}
|
|
|
|
setPeekId = (issueId: string | null) => (this.peekId = issueId);
|
|
setPeekMode = (mode: IPeekMode | null) => (this.peekMode = mode);
|
|
|
|
fetchIssueDetailsAsync = async (workspaceId: string, projectId: string, issueId: string) => {
|
|
try {
|
|
this.loader = true;
|
|
this.error = null;
|
|
|
|
console.log("workspaceId", workspaceId);
|
|
console.log("projectId", projectId);
|
|
console.log("issueId", issueId);
|
|
|
|
runInAction(() => {
|
|
this.loader = false;
|
|
this.error = null;
|
|
});
|
|
} catch (error) {
|
|
console.log("error in fetching issue details", error);
|
|
this.loader = false;
|
|
this.error = error;
|
|
return error;
|
|
}
|
|
};
|
|
|
|
createIssueAsync = async (workspaceId: string, projectId: string, issueId: string, data: any) => {
|
|
try {
|
|
this.loader = true;
|
|
this.error = null;
|
|
|
|
console.log("workspaceId", workspaceId);
|
|
console.log("projectId", projectId);
|
|
console.log("issueId", issueId);
|
|
console.log("data", data);
|
|
|
|
runInAction(() => {
|
|
this.loader = false;
|
|
this.error = null;
|
|
});
|
|
} catch (error) {
|
|
console.log("error in fetching issue details", error);
|
|
this.loader = false;
|
|
this.error = error;
|
|
return error;
|
|
}
|
|
};
|
|
|
|
updateIssueAsync = async (workspaceId: string, projectId: string, issueId: string, data: any) => {
|
|
try {
|
|
this.loader = true;
|
|
this.error = null;
|
|
|
|
const filteredParams = this.rootStore.issueFilters.getComputedFilters(
|
|
workspaceId,
|
|
projectId,
|
|
null,
|
|
null,
|
|
null,
|
|
this.rootStore.issueFilters.issueView || "issues"
|
|
);
|
|
const issueResponse = await this.issueService.patchIssue(workspaceId, projectId, issueId, data, undefined);
|
|
const issueList = await this.issueService.getIssuesWithParams(workspaceId, projectId, filteredParams);
|
|
console.log("issueList", issueList);
|
|
|
|
if (issueResponse) {
|
|
runInAction(() => {
|
|
this.loader = false;
|
|
this.error = null;
|
|
this.rootStore.issueView.issues[workspaceId].project_issues[projectId].issues.list = issueList;
|
|
});
|
|
}
|
|
} catch (error) {
|
|
console.log("error in fetching issue details", error);
|
|
this.loader = false;
|
|
this.error = error;
|
|
return error;
|
|
}
|
|
};
|
|
|
|
deleteIssueAsync = async (workspaceId: string, projectId: string, issueId: string) => {
|
|
try {
|
|
this.loader = true;
|
|
this.error = null;
|
|
|
|
console.log("workspaceId", workspaceId);
|
|
console.log("projectId", projectId);
|
|
console.log("issueId", issueId);
|
|
|
|
runInAction(() => {
|
|
this.loader = false;
|
|
this.error = null;
|
|
});
|
|
} catch (error) {
|
|
console.log("error in fetching issue details", error);
|
|
this.loader = false;
|
|
this.error = error;
|
|
return error;
|
|
}
|
|
};
|
|
}
|
|
|
|
export default IssueViewDetailStore;
|