2023-12-11 14:45:07 +00:00
|
|
|
import { observable, action, makeObservable, computed } from "mobx";
|
|
|
|
// types
|
|
|
|
import { RootStore } from "../root.store";
|
|
|
|
// services
|
|
|
|
import { ProjectService } from "services/project";
|
|
|
|
import { PageService } from "services/page.service";
|
|
|
|
|
|
|
|
export enum EProjectStore {
|
|
|
|
PROJECT = "ProjectStore",
|
|
|
|
PROJECT_VIEW = "ProjectViewStore",
|
|
|
|
PROFILE = "ProfileStore",
|
|
|
|
MODULE = "ModuleStore",
|
|
|
|
CYCLE = "CycleStore",
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface ModalData {
|
|
|
|
store: EProjectStore;
|
|
|
|
viewId: string;
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface ICommandPaletteStore {
|
|
|
|
isCommandPaletteOpen: boolean;
|
|
|
|
isShortcutModalOpen: boolean;
|
|
|
|
isCreateProjectModalOpen: boolean;
|
|
|
|
isCreateCycleModalOpen: boolean;
|
|
|
|
isCreateModuleModalOpen: boolean;
|
|
|
|
isCreateViewModalOpen: boolean;
|
|
|
|
isCreatePageModalOpen: boolean;
|
|
|
|
isCreateIssueModalOpen: boolean;
|
|
|
|
isDeleteIssueModalOpen: boolean;
|
|
|
|
isBulkDeleteIssueModalOpen: boolean;
|
|
|
|
|
|
|
|
// computed
|
|
|
|
isAnyModalOpen: boolean;
|
|
|
|
|
|
|
|
toggleCommandPaletteModal: (value?: boolean) => void;
|
|
|
|
toggleShortcutModal: (value?: boolean) => void;
|
|
|
|
toggleCreateProjectModal: (value?: boolean) => void;
|
|
|
|
toggleCreateCycleModal: (value?: boolean) => void;
|
|
|
|
toggleCreateViewModal: (value?: boolean) => void;
|
|
|
|
toggleCreatePageModal: (value?: boolean) => void;
|
|
|
|
toggleCreateIssueModal: (value?: boolean, storeType?: EProjectStore) => void;
|
|
|
|
toggleCreateModuleModal: (value?: boolean) => void;
|
|
|
|
toggleDeleteIssueModal: (value?: boolean) => void;
|
|
|
|
toggleBulkDeleteIssueModal: (value?: boolean) => void;
|
|
|
|
|
|
|
|
createIssueStoreType: EProjectStore;
|
|
|
|
}
|
|
|
|
|
|
|
|
export class CommandPaletteStore implements ICommandPaletteStore {
|
|
|
|
isCommandPaletteOpen: boolean = false;
|
|
|
|
isShortcutModalOpen: boolean = false;
|
|
|
|
isCreateProjectModalOpen: boolean = false;
|
|
|
|
isCreateCycleModalOpen: boolean = false;
|
|
|
|
isCreateModuleModalOpen: boolean = false;
|
|
|
|
isCreateViewModalOpen: boolean = false;
|
|
|
|
isCreatePageModalOpen: boolean = false;
|
|
|
|
isCreateIssueModalOpen: boolean = false;
|
|
|
|
isDeleteIssueModalOpen: boolean = false;
|
|
|
|
isBulkDeleteIssueModalOpen: boolean = false;
|
|
|
|
// root store
|
|
|
|
rootStore;
|
|
|
|
// service
|
|
|
|
projectService;
|
|
|
|
pageService;
|
|
|
|
|
|
|
|
createIssueStoreType: EProjectStore = EProjectStore.PROJECT;
|
|
|
|
|
|
|
|
constructor(_rootStore: RootStore) {
|
|
|
|
makeObservable(this, {
|
|
|
|
// observable
|
|
|
|
isCommandPaletteOpen: observable.ref,
|
|
|
|
isShortcutModalOpen: observable.ref,
|
|
|
|
isCreateProjectModalOpen: observable.ref,
|
|
|
|
isCreateCycleModalOpen: observable.ref,
|
|
|
|
isCreateModuleModalOpen: observable.ref,
|
|
|
|
isCreateViewModalOpen: observable.ref,
|
|
|
|
isCreatePageModalOpen: observable.ref,
|
|
|
|
isCreateIssueModalOpen: observable.ref,
|
|
|
|
isDeleteIssueModalOpen: observable.ref,
|
|
|
|
isBulkDeleteIssueModalOpen: observable.ref,
|
|
|
|
// computed
|
|
|
|
isAnyModalOpen: computed,
|
|
|
|
// projectPages: computed,
|
|
|
|
// action
|
|
|
|
toggleCommandPaletteModal: action,
|
|
|
|
toggleShortcutModal: action,
|
|
|
|
toggleCreateProjectModal: action,
|
|
|
|
toggleCreateCycleModal: action,
|
|
|
|
toggleCreateViewModal: action,
|
|
|
|
toggleCreatePageModal: action,
|
|
|
|
toggleCreateIssueModal: action,
|
|
|
|
toggleCreateModuleModal: action,
|
|
|
|
toggleDeleteIssueModal: action,
|
|
|
|
toggleBulkDeleteIssueModal: action,
|
|
|
|
});
|
|
|
|
|
|
|
|
this.rootStore = _rootStore;
|
|
|
|
this.projectService = new ProjectService();
|
|
|
|
this.pageService = new PageService();
|
|
|
|
}
|
|
|
|
|
|
|
|
get isAnyModalOpen() {
|
|
|
|
return Boolean(
|
|
|
|
this.isCreateIssueModalOpen ||
|
|
|
|
this.isCreateCycleModalOpen ||
|
|
|
|
this.isCreatePageModalOpen ||
|
|
|
|
this.isCreateProjectModalOpen ||
|
|
|
|
this.isCreateModuleModalOpen ||
|
|
|
|
this.isCreateViewModalOpen ||
|
|
|
|
this.isShortcutModalOpen ||
|
|
|
|
this.isBulkDeleteIssueModalOpen ||
|
|
|
|
this.isDeleteIssueModalOpen
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
toggleCommandPaletteModal = (value?: boolean) => {
|
|
|
|
if (value !== undefined) {
|
|
|
|
this.isCommandPaletteOpen = value;
|
|
|
|
} else {
|
|
|
|
this.isCommandPaletteOpen = !this.isCommandPaletteOpen;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
toggleShortcutModal = (value?: boolean) => {
|
|
|
|
if (value !== undefined) {
|
|
|
|
this.isShortcutModalOpen = value;
|
|
|
|
} else {
|
|
|
|
this.isShortcutModalOpen = !this.isShortcutModalOpen;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
toggleCreateProjectModal = (value?: boolean) => {
|
|
|
|
if (value !== undefined) {
|
|
|
|
this.isCreateProjectModalOpen = value;
|
|
|
|
} else {
|
|
|
|
this.isCreateProjectModalOpen = !this.isCreateProjectModalOpen;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
toggleCreateCycleModal = (value?: boolean) => {
|
|
|
|
if (value !== undefined) {
|
|
|
|
this.isCreateCycleModalOpen = value;
|
|
|
|
} else {
|
|
|
|
this.isCreateCycleModalOpen = !this.isCreateCycleModalOpen;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
toggleCreateViewModal = (value?: boolean) => {
|
|
|
|
if (value !== undefined) {
|
|
|
|
this.isCreateViewModalOpen = value;
|
|
|
|
} else {
|
|
|
|
this.isCreateViewModalOpen = !this.isCreateViewModalOpen;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
toggleCreatePageModal = (value?: boolean) => {
|
|
|
|
if (value !== undefined) {
|
|
|
|
this.isCreatePageModalOpen = value;
|
|
|
|
} else {
|
|
|
|
this.isCreatePageModalOpen = !this.isCreatePageModalOpen;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
toggleCreateIssueModal = (value?: boolean, storeType?: EProjectStore) => {
|
|
|
|
if (value !== undefined) {
|
|
|
|
this.isCreateIssueModalOpen = value;
|
|
|
|
this.createIssueStoreType = storeType || EProjectStore.PROJECT;
|
|
|
|
} else {
|
|
|
|
this.isCreateIssueModalOpen = !this.isCreateIssueModalOpen;
|
|
|
|
this.createIssueStoreType = EProjectStore.PROJECT;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
toggleDeleteIssueModal = (value?: boolean) => {
|
|
|
|
if (value !== undefined) {
|
|
|
|
this.isDeleteIssueModalOpen = value;
|
|
|
|
} else {
|
|
|
|
this.isDeleteIssueModalOpen = !this.isDeleteIssueModalOpen;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
toggleCreateModuleModal = (value?: boolean) => {
|
|
|
|
if (value !== undefined) {
|
|
|
|
this.isCreateModuleModalOpen = value;
|
|
|
|
} else {
|
|
|
|
this.isCreateModuleModalOpen = !this.isCreateModuleModalOpen;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
toggleBulkDeleteIssueModal = (value?: boolean) => {
|
|
|
|
if (value !== undefined) {
|
|
|
|
this.isBulkDeleteIssueModalOpen = value;
|
|
|
|
} else {
|
|
|
|
this.isBulkDeleteIssueModalOpen = !this.isBulkDeleteIssueModalOpen;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
}
|