plane/apps/space/store/project.ts

89 lines
2.4 KiB
TypeScript
Raw Normal View History

// mobx
import { observable, action, makeObservable, runInAction } from "mobx";
// service
import ProjectService from "services/project.service";
// types
2023-08-30 15:03:21 +00:00
import { IWorkspace, IProject, IProjectSettings } from "../types";
2023-08-30 12:09:11 +00:00
export interface IProjectStore {
loader: boolean;
error: any | null;
workspace: IWorkspace | null;
project: IProject | null;
2023-08-31 11:05:26 +00:00
deploySettings: IProjectSettings | null;
2023-08-30 12:09:11 +00:00
viewOptions: any;
2023-08-30 13:03:18 +00:00
activeBoard: string | null;
2023-08-30 12:09:11 +00:00
fetchProjectSettings: (workspace_slug: string, project_slug: string) => Promise<void>;
2023-08-30 13:03:18 +00:00
setActiveBoard: (value: string) => void;
2023-08-30 12:09:11 +00:00
}
class ProjectStore implements IProjectStore {
loader: boolean = false;
error: any | null = null;
2023-08-30 12:09:11 +00:00
// data
workspace: IWorkspace | null = null;
project: IProject | null = null;
2023-08-31 11:05:26 +00:00
deploySettings: IProjectSettings | null = null;
2023-08-30 12:09:11 +00:00
viewOptions: any = null;
2023-08-30 13:03:18 +00:00
activeBoard: string | null = null;
// root store
rootStore;
// service
projectService;
constructor(_rootStore: any | null = null) {
makeObservable(this, {
2023-08-30 12:09:11 +00:00
// loaders and error observables
loader: observable,
error: observable.ref,
// observable
workspace: observable.ref,
project: observable.ref,
2023-08-31 11:05:26 +00:00
deploySettings: observable.ref,
2023-08-30 12:09:11 +00:00
viewOptions: observable.ref,
2023-08-30 13:03:18 +00:00
activeBoard: observable.ref,
2023-08-30 12:09:11 +00:00
// actions
fetchProjectSettings: action,
2023-08-30 13:03:18 +00:00
setActiveBoard: action,
// computed
});
this.rootStore = _rootStore;
this.projectService = new ProjectService();
}
2023-08-30 12:09:11 +00:00
fetchProjectSettings = async (workspace_slug: string, project_slug: string) => {
try {
this.loader = true;
this.error = null;
2023-08-30 12:09:11 +00:00
const response = await this.projectService.getProjectSettings(workspace_slug, project_slug);
if (response) {
const _project: IProject = { ...response?.project_details };
const _workspace: IWorkspace = { ...response?.workspace_detail };
2023-08-30 12:09:11 +00:00
const _viewOptions = { ...response?.views };
2023-08-31 11:05:26 +00:00
const _deploySettings = { ...response };
runInAction(() => {
this.project = _project;
this.workspace = _workspace;
2023-08-30 12:09:11 +00:00
this.viewOptions = _viewOptions;
2023-08-31 11:05:26 +00:00
this.deploySettings = _deploySettings;
this.loader = false;
});
}
return response;
} catch (error) {
this.loader = false;
this.error = error;
return error;
}
};
2023-08-30 13:03:18 +00:00
setActiveBoard = (boardValue: string) => {
this.activeBoard = boardValue;
};
}
export default ProjectStore;