mirror of
https://github.com/makeplane/plane
synced 2024-06-14 14:31:34 +00:00
chore: store setup
This commit is contained in:
parent
906caa636b
commit
491592614d
@ -8,7 +8,7 @@ import { observer } from "mobx-react-lite";
|
|||||||
import { useMobxStore } from "lib/mobx/store-provider";
|
import { useMobxStore } from "lib/mobx/store-provider";
|
||||||
import { RootStore } from "store/root";
|
import { RootStore } from "store/root";
|
||||||
// default data
|
// default data
|
||||||
import { issueFilterVisibilityData } from "store/issue-views/issue_data";
|
import { issueFilterVisibilityData } from "store/helpers/issue-data";
|
||||||
|
|
||||||
export const FilterExtraOptions = observer(() => {
|
export const FilterExtraOptions = observer(() => {
|
||||||
const store: RootStore = useMobxStore();
|
const store: RootStore = useMobxStore();
|
||||||
|
@ -11,7 +11,7 @@ import { observer } from "mobx-react-lite";
|
|||||||
import { useMobxStore } from "lib/mobx/store-provider";
|
import { useMobxStore } from "lib/mobx/store-provider";
|
||||||
import { RootStore } from "store/root";
|
import { RootStore } from "store/root";
|
||||||
// default data
|
// default data
|
||||||
import { issueFilterVisibilityData } from "store/issue-views/issue_data";
|
import { issueFilterVisibilityData } from "store/helpers/issue-data";
|
||||||
|
|
||||||
export const DisplayFiltersSelection = observer(() => {
|
export const DisplayFiltersSelection = observer(() => {
|
||||||
const store: RootStore = useMobxStore();
|
const store: RootStore = useMobxStore();
|
||||||
|
@ -14,7 +14,7 @@ import { observer } from "mobx-react-lite";
|
|||||||
import { useMobxStore } from "lib/mobx/store-provider";
|
import { useMobxStore } from "lib/mobx/store-provider";
|
||||||
import { RootStore } from "store/root";
|
import { RootStore } from "store/root";
|
||||||
// default data
|
// default data
|
||||||
import { issueFilterVisibilityData } from "store/issue-views/issue_data";
|
import { issueFilterVisibilityData } from "store/helpers/issue-data";
|
||||||
|
|
||||||
export const FilterPreview = observer(() => {
|
export const FilterPreview = observer(() => {
|
||||||
const store: RootStore = useMobxStore();
|
const store: RootStore = useMobxStore();
|
||||||
|
@ -10,7 +10,7 @@ import { observer } from "mobx-react-lite";
|
|||||||
import { useMobxStore } from "lib/mobx/store-provider";
|
import { useMobxStore } from "lib/mobx/store-provider";
|
||||||
import { RootStore } from "store/root";
|
import { RootStore } from "store/root";
|
||||||
// store default data
|
// store default data
|
||||||
import { stateGroups } from "store/issue-views/issue_data";
|
import { stateGroups } from "store/helpers/issue-data";
|
||||||
|
|
||||||
export const FilterState = observer(() => {
|
export const FilterState = observer(() => {
|
||||||
const store: RootStore = useMobxStore();
|
const store: RootStore = useMobxStore();
|
||||||
|
@ -14,7 +14,7 @@ import { observer } from "mobx-react-lite";
|
|||||||
import { useMobxStore } from "lib/mobx/store-provider";
|
import { useMobxStore } from "lib/mobx/store-provider";
|
||||||
import { RootStore } from "store/root";
|
import { RootStore } from "store/root";
|
||||||
// default data
|
// default data
|
||||||
import { issueFilterVisibilityData } from "store/issue-views/issue_data";
|
import { issueFilterVisibilityData } from "store/helpers/issue-data";
|
||||||
|
|
||||||
export const FilterSelection = observer(() => {
|
export const FilterSelection = observer(() => {
|
||||||
const store: RootStore = useMobxStore();
|
const store: RootStore = useMobxStore();
|
||||||
|
@ -9,7 +9,7 @@ import { observer } from "mobx-react-lite";
|
|||||||
import { useMobxStore } from "lib/mobx/store-provider";
|
import { useMobxStore } from "lib/mobx/store-provider";
|
||||||
import { RootStore } from "store/root";
|
import { RootStore } from "store/root";
|
||||||
// store default data
|
// store default data
|
||||||
import { stateGroups } from "store/issue-views/issue_data";
|
import { stateGroups } from "store/helpers/issue-data";
|
||||||
|
|
||||||
export const FilterState = observer(() => {
|
export const FilterState = observer(() => {
|
||||||
const store: RootStore = useMobxStore();
|
const store: RootStore = useMobxStore();
|
||||||
|
@ -7,8 +7,8 @@ import { observer } from "mobx-react-lite";
|
|||||||
import { RootStore } from "store/root";
|
import { RootStore } from "store/root";
|
||||||
import { useMobxStore } from "lib/mobx/store-provider";
|
import { useMobxStore } from "lib/mobx/store-provider";
|
||||||
// types and default data
|
// types and default data
|
||||||
import { TIssueLayouts } from "store/issue-views/issue_filters";
|
import { TIssueLayouts } from "store/issue-filters";
|
||||||
import { issueFilterVisibilityData } from "store/issue-views/issue_data";
|
import { issueFilterVisibilityData } from "store/helpers/issue-data";
|
||||||
|
|
||||||
export const LayoutSelection = observer(() => {
|
export const LayoutSelection = observer(() => {
|
||||||
const store: RootStore = useMobxStore();
|
const store: RootStore = useMobxStore();
|
||||||
|
@ -19,7 +19,42 @@ import { useMobxStore } from "lib/mobx/store-provider";
|
|||||||
import { RootStore } from "store/root";
|
import { RootStore } from "store/root";
|
||||||
|
|
||||||
export const IssuesRoot = observer(() => {
|
export const IssuesRoot = observer(() => {
|
||||||
const { issueFilters: issueFilterStore }: RootStore = useMobxStore();
|
const {
|
||||||
|
workspace: workspaceStore,
|
||||||
|
project: projectStore,
|
||||||
|
issue: issueStore,
|
||||||
|
issueFilter: issueFilterStore,
|
||||||
|
}: RootStore = useMobxStore();
|
||||||
|
|
||||||
|
// console.log("---");
|
||||||
|
// console.log("--- workspace store");
|
||||||
|
// console.log("workspaces", workspaceStore?.workspaces);
|
||||||
|
// console.log("workspace id", workspaceStore?.workspaceId);
|
||||||
|
// console.log("current workspace", workspaceStore?.currentWorkspace);
|
||||||
|
// console.log("workspace by id", workspaceStore?.workspaceById("plane"));
|
||||||
|
// console.log("workspace labels", workspaceStore?.workspaceLabels);
|
||||||
|
// console.log("workspace label by id", workspaceStore?.workspaceLabelById("1fe1031b-8986-4e6a-86cc-0d2fe3ac272f"));
|
||||||
|
|
||||||
|
// console.log("--- project store");
|
||||||
|
// console.log("workspace projects", projectStore?.workspaceProjects);
|
||||||
|
// console.log("project id", projectStore?.projectId);
|
||||||
|
// console.log("project state by groups", projectStore?.projectStatesByGroups);
|
||||||
|
// console.log("project states", projectStore?.projectStates);
|
||||||
|
// console.log("project labels", projectStore?.projectLabels);
|
||||||
|
// console.log("project members", projectStore?.projectMembers);
|
||||||
|
// projectStore?.projectStates &&
|
||||||
|
// console.log("project state by id", projectStore?.projectStateById(projectStore?.projectStates?.[0]?.id));
|
||||||
|
// projectStore?.projectLabels &&
|
||||||
|
// console.log("project label by id", projectStore?.projectLabelById(projectStore?.projectLabels?.[0]?.id));
|
||||||
|
// projectStore?.projectMembers &&
|
||||||
|
// console.log("project member by id", projectStore?.projectMemberById(projectStore?.projectMembers?.[0]?.id));
|
||||||
|
|
||||||
|
// console.log("--- issue filter store");
|
||||||
|
// console.log("issues filters", issueFilterStore?.issueFilters);
|
||||||
|
|
||||||
|
// console.log("--- issue store");
|
||||||
|
// console.log("issues", issueStore?.issues);
|
||||||
|
// console.log("---");
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div className="w-full h-full relative flex flex-col overflow-hidden">
|
<div className="w-full h-full relative flex flex-col overflow-hidden">
|
||||||
|
@ -115,9 +115,7 @@ export const WorkspaceAuthorizationLayout: React.FC<Props> = ({
|
|||||||
noHeader={noHeader}
|
noHeader={noHeader}
|
||||||
/>
|
/>
|
||||||
<div className="h-full w-full overflow-hidden">
|
<div className="h-full w-full overflow-hidden">
|
||||||
<div className="relative h-full w-full overflow-x-hidden overflow-y-scroll">
|
<div className="relative h-full w-full overflow-x-hidden overflow-y-scroll">{children}</div>
|
||||||
{children}
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
</main>
|
</main>
|
||||||
)}
|
)}
|
||||||
|
@ -14,15 +14,26 @@ const KanBanViewRoot = () => {
|
|||||||
project_slug: string;
|
project_slug: string;
|
||||||
};
|
};
|
||||||
|
|
||||||
const store: RootStore = useMobxStore();
|
const { issue: issueViewStore, workspace: workspaceStore, project: projectStore }: RootStore = useMobxStore();
|
||||||
const { issueView: issueViewStore } = store;
|
|
||||||
|
|
||||||
React.useEffect(() => {
|
React.useEffect(() => {
|
||||||
console.log("request init--->");
|
console.log("request init--->");
|
||||||
const init = async () => await issueViewStore.getProjectIssuesAsync(workspace_slug, project_slug);
|
const init = async () => {
|
||||||
|
workspaceStore.setWorkspaceId(workspace_slug);
|
||||||
|
await workspaceStore.getWorkspaces();
|
||||||
|
await workspaceStore.getWorkspaceLabels(workspace_slug);
|
||||||
|
|
||||||
|
projectStore.setProject(project_slug);
|
||||||
|
await projectStore.getWorkspaceProjects(workspace_slug);
|
||||||
|
await projectStore.getProjectStates(workspace_slug, project_slug);
|
||||||
|
await projectStore.getProjectLabels(workspace_slug, project_slug);
|
||||||
|
await projectStore.getProjectMembers(workspace_slug, project_slug);
|
||||||
|
|
||||||
|
await issueViewStore.getProjectIssuesAsync(workspace_slug, project_slug);
|
||||||
|
};
|
||||||
if (workspace_slug && project_slug) init();
|
if (workspace_slug && project_slug) init();
|
||||||
console.log("request completed--->");
|
console.log("request completed--->");
|
||||||
}, [workspace_slug, project_slug, issueViewStore]);
|
}, [workspace_slug, project_slug, issueViewStore, workspaceStore, projectStore]);
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div className="w-screen min-h-[600px] h-screen">
|
<div className="w-screen min-h-[600px] h-screen">
|
||||||
|
@ -87,11 +87,7 @@ export class ProjectServices extends APIService {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
async deleteProject(
|
async deleteProject(workspaceSlug: string, projectId: string, user: ICurrentUserResponse | undefined): Promise<any> {
|
||||||
workspaceSlug: string,
|
|
||||||
projectId: string,
|
|
||||||
user: ICurrentUserResponse | undefined
|
|
||||||
): Promise<any> {
|
|
||||||
return this.delete(`/api/workspaces/${workspaceSlug}/projects/${projectId}/`)
|
return this.delete(`/api/workspaces/${workspaceSlug}/projects/${projectId}/`)
|
||||||
.then((response) => {
|
.then((response) => {
|
||||||
trackEventServices.trackProjectEvent({ projectId }, "DELETE_PROJECT", user);
|
trackEventServices.trackProjectEvent({ projectId }, "DELETE_PROJECT", user);
|
||||||
@ -136,11 +132,7 @@ export class ProjectServices extends APIService {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
async leaveProject(
|
async leaveProject(workspaceSlug: string, projectId: string, user: ICurrentUserResponse): Promise<any> {
|
||||||
workspaceSlug: string,
|
|
||||||
projectId: string,
|
|
||||||
user: ICurrentUserResponse
|
|
||||||
): Promise<any> {
|
|
||||||
return this.delete(`/api/workspaces/${workspaceSlug}/projects/${projectId}/members/leave/`)
|
return this.delete(`/api/workspaces/${workspaceSlug}/projects/${projectId}/members/leave/`)
|
||||||
.then((response) => {
|
.then((response) => {
|
||||||
trackEventServices.trackProjectEvent(
|
trackEventServices.trackProjectEvent(
|
||||||
@ -175,10 +167,7 @@ export class ProjectServices extends APIService {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
async projectMembersWithEmail(
|
async projectMembersWithEmail(workspaceSlug: string, projectId: string): Promise<IProjectMember[]> {
|
||||||
workspaceSlug: string,
|
|
||||||
projectId: string
|
|
||||||
): Promise<IProjectMember[]> {
|
|
||||||
return this.get(`/api/workspaces/${workspaceSlug}/projects/${projectId}/members/`)
|
return this.get(`/api/workspaces/${workspaceSlug}/projects/${projectId}/members/`)
|
||||||
.then((response) => response?.data)
|
.then((response) => response?.data)
|
||||||
.catch((error) => {
|
.catch((error) => {
|
||||||
@ -194,11 +183,7 @@ export class ProjectServices extends APIService {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
async getProjectMember(
|
async getProjectMember(workspaceSlug: string, projectId: string, memberId: string): Promise<IProjectMember> {
|
||||||
workspaceSlug: string,
|
|
||||||
projectId: string,
|
|
||||||
memberId: string
|
|
||||||
): Promise<IProjectMember> {
|
|
||||||
return this.get(`/api/workspaces/${workspaceSlug}/projects/${projectId}/members/${memberId}/`)
|
return this.get(`/api/workspaces/${workspaceSlug}/projects/${projectId}/members/${memberId}/`)
|
||||||
.then((response) => response?.data)
|
.then((response) => response?.data)
|
||||||
.catch((error) => {
|
.catch((error) => {
|
||||||
@ -212,34 +197,22 @@ export class ProjectServices extends APIService {
|
|||||||
memberId: string,
|
memberId: string,
|
||||||
data: Partial<IProjectMember>
|
data: Partial<IProjectMember>
|
||||||
): Promise<IProjectMember> {
|
): Promise<IProjectMember> {
|
||||||
return this.patch(
|
return this.patch(`/api/workspaces/${workspaceSlug}/projects/${projectId}/members/${memberId}/`, data)
|
||||||
`/api/workspaces/${workspaceSlug}/projects/${projectId}/members/${memberId}/`,
|
|
||||||
data
|
|
||||||
)
|
|
||||||
.then((response) => response?.data)
|
.then((response) => response?.data)
|
||||||
.catch((error) => {
|
.catch((error) => {
|
||||||
throw error?.response?.data;
|
throw error?.response?.data;
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
async deleteProjectMember(
|
async deleteProjectMember(workspaceSlug: string, projectId: string, memberId: string): Promise<any> {
|
||||||
workspaceSlug: string,
|
return this.delete(`/api/workspaces/${workspaceSlug}/projects/${projectId}/members/${memberId}/`)
|
||||||
projectId: string,
|
|
||||||
memberId: string
|
|
||||||
): Promise<any> {
|
|
||||||
return this.delete(
|
|
||||||
`/api/workspaces/${workspaceSlug}/projects/${projectId}/members/${memberId}/`
|
|
||||||
)
|
|
||||||
.then((response) => response?.data)
|
.then((response) => response?.data)
|
||||||
.catch((error) => {
|
.catch((error) => {
|
||||||
throw error?.response?.data;
|
throw error?.response?.data;
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
async projectInvitations(
|
async projectInvitations(workspaceSlug: string, projectId: string): Promise<IProjectMemberInvitation[]> {
|
||||||
workspaceSlug: string,
|
|
||||||
projectId: string
|
|
||||||
): Promise<IProjectMemberInvitation[]> {
|
|
||||||
return this.get(`/api/workspaces/${workspaceSlug}/projects/${projectId}/invitations/`)
|
return this.get(`/api/workspaces/${workspaceSlug}/projects/${projectId}/invitations/`)
|
||||||
.then((response) => response?.data)
|
.then((response) => response?.data)
|
||||||
.catch((error) => {
|
.catch((error) => {
|
||||||
@ -247,10 +220,7 @@ export class ProjectServices extends APIService {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
async projectInvitationsWithEmail(
|
async projectInvitationsWithEmail(workspaceSlug: string, projectId: string): Promise<IProjectMemberInvitation[]> {
|
||||||
workspaceSlug: string,
|
|
||||||
projectId: string
|
|
||||||
): Promise<IProjectMemberInvitation[]> {
|
|
||||||
return this.get(`/api/workspaces/${workspaceSlug}/projects/${projectId}/invitations/`)
|
return this.get(`/api/workspaces/${workspaceSlug}/projects/${projectId}/invitations/`)
|
||||||
.then((response) => response?.data)
|
.then((response) => response?.data)
|
||||||
.catch((error) => {
|
.catch((error) => {
|
||||||
@ -258,28 +228,16 @@ export class ProjectServices extends APIService {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
async updateProjectInvitation(
|
async updateProjectInvitation(workspaceSlug: string, projectId: string, invitationId: string): Promise<any> {
|
||||||
workspaceSlug: string,
|
return this.put(`/api/workspaces/${workspaceSlug}/projects/${projectId}/invitations/${invitationId}/`)
|
||||||
projectId: string,
|
|
||||||
invitationId: string
|
|
||||||
): Promise<any> {
|
|
||||||
return this.put(
|
|
||||||
`/api/workspaces/${workspaceSlug}/projects/${projectId}/invitations/${invitationId}/`
|
|
||||||
)
|
|
||||||
.then((response) => response?.data)
|
.then((response) => response?.data)
|
||||||
.catch((error) => {
|
.catch((error) => {
|
||||||
throw error?.response?.data;
|
throw error?.response?.data;
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
async deleteProjectInvitation(
|
async deleteProjectInvitation(workspaceSlug: string, projectId: string, invitationId: string): Promise<any> {
|
||||||
workspaceSlug: string,
|
return this.delete(`/api/workspaces/${workspaceSlug}/projects/${projectId}/invitations/${invitationId}/`)
|
||||||
projectId: string,
|
|
||||||
invitationId: string
|
|
||||||
): Promise<any> {
|
|
||||||
return this.delete(
|
|
||||||
`/api/workspaces/${workspaceSlug}/projects/${projectId}/invitations/${invitationId}/`
|
|
||||||
)
|
|
||||||
.then((response) => response?.data)
|
.then((response) => response?.data)
|
||||||
.catch((error) => {
|
.catch((error) => {
|
||||||
throw error?.response?.data;
|
throw error?.response?.data;
|
||||||
@ -332,11 +290,7 @@ export class ProjectServices extends APIService {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
async getProjectGithubRepository(
|
async getProjectGithubRepository(workspaceSlug: string, projectId: string, integrationId: string): Promise<any> {
|
||||||
workspaceSlug: string,
|
|
||||||
projectId: string,
|
|
||||||
integrationId: string
|
|
||||||
): Promise<any> {
|
|
||||||
return this.get(
|
return this.get(
|
||||||
`/api/workspaces/${workspaceSlug}/projects/${projectId}/workspace-integrations/${integrationId}/github-repository-sync/`
|
`/api/workspaces/${workspaceSlug}/projects/${projectId}/workspace-integrations/${integrationId}/github-repository-sync/`
|
||||||
)
|
)
|
||||||
|
@ -37,10 +37,7 @@ export class WorkspaceService extends APIService {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
async createWorkspace(
|
async createWorkspace(data: Partial<IWorkspace>, user: ICurrentUserResponse | undefined): Promise<IWorkspace> {
|
||||||
data: Partial<IWorkspace>,
|
|
||||||
user: ICurrentUserResponse | undefined
|
|
||||||
): Promise<IWorkspace> {
|
|
||||||
return this.post("/api/workspaces/", data)
|
return this.post("/api/workspaces/", data)
|
||||||
.then((response) => {
|
.then((response) => {
|
||||||
trackEventServices.trackWorkspaceEvent(response.data, "CREATE_WORKSPACE", user);
|
trackEventServices.trackWorkspaceEvent(response.data, "CREATE_WORKSPACE", user);
|
||||||
@ -66,10 +63,7 @@ export class WorkspaceService extends APIService {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
async deleteWorkspace(
|
async deleteWorkspace(workspaceSlug: string, user: ICurrentUserResponse | undefined): Promise<any> {
|
||||||
workspaceSlug: string,
|
|
||||||
user: ICurrentUserResponse | undefined
|
|
||||||
): Promise<any> {
|
|
||||||
return this.delete(`/api/workspaces/${workspaceSlug}/`)
|
return this.delete(`/api/workspaces/${workspaceSlug}/`)
|
||||||
.then((response) => {
|
.then((response) => {
|
||||||
trackEventServices.trackWorkspaceEvent({ workspaceSlug }, "DELETE_WORKSPACE", user);
|
trackEventServices.trackWorkspaceEvent({ workspaceSlug }, "DELETE_WORKSPACE", user);
|
||||||
@ -101,13 +95,9 @@ export class WorkspaceService extends APIService {
|
|||||||
data: any,
|
data: any,
|
||||||
user: ICurrentUserResponse | undefined
|
user: ICurrentUserResponse | undefined
|
||||||
): Promise<any> {
|
): Promise<any> {
|
||||||
return this.post(
|
return this.post(`/api/users/me/invitations/workspaces/${workspaceSlug}/${invitationId}/join/`, data, {
|
||||||
`/api/users/me/invitations/workspaces/${workspaceSlug}/${invitationId}/join/`,
|
|
||||||
data,
|
|
||||||
{
|
|
||||||
headers: {},
|
headers: {},
|
||||||
}
|
})
|
||||||
)
|
|
||||||
.then((response) => {
|
.then((response) => {
|
||||||
trackEventServices.trackWorkspaceEvent(response.data, "WORKSPACE_USER_INVITE_ACCEPT", user);
|
trackEventServices.trackWorkspaceEvent(response.data, "WORKSPACE_USER_INVITE_ACCEPT", user);
|
||||||
return response?.data;
|
return response?.data;
|
||||||
@ -165,10 +155,7 @@ export class WorkspaceService extends APIService {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
async updateWorkspaceView(
|
async updateWorkspaceView(workspaceSlug: string, data: { view_props: IWorkspaceViewProps }): Promise<any> {
|
||||||
workspaceSlug: string,
|
|
||||||
data: { view_props: IWorkspaceViewProps }
|
|
||||||
): Promise<any> {
|
|
||||||
return this.post(`/api/workspaces/${workspaceSlug}/workspace-views/`, data)
|
return this.post(`/api/workspaces/${workspaceSlug}/workspace-views/`, data)
|
||||||
.then((response) => response?.data)
|
.then((response) => response?.data)
|
||||||
.catch((error) => {
|
.catch((error) => {
|
||||||
@ -204,9 +191,7 @@ export class WorkspaceService extends APIService {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
async workspaceInvitationsWithEmail(
|
async workspaceInvitationsWithEmail(workspaceSlug: string): Promise<IWorkspaceMemberInvitation[]> {
|
||||||
workspaceSlug: string
|
|
||||||
): Promise<IWorkspaceMemberInvitation[]> {
|
|
||||||
return this.get(`/api/workspaces/${workspaceSlug}/invitations/`)
|
return this.get(`/api/workspaces/${workspaceSlug}/invitations/`)
|
||||||
.then((response) => response?.data)
|
.then((response) => response?.data)
|
||||||
.catch((error) => {
|
.catch((error) => {
|
||||||
|
55
web/store/cycles.ts
Normal file
55
web/store/cycles.ts
Normal file
@ -0,0 +1,55 @@
|
|||||||
|
import { action, computed, observable, makeObservable, runInAction } from "mobx";
|
||||||
|
// types
|
||||||
|
import { RootStore } from "./root";
|
||||||
|
// services
|
||||||
|
import { ProjectServices } from "services/project.service";
|
||||||
|
import { ProjectIssuesServices as IssueServices } from "services/issues.service";
|
||||||
|
|
||||||
|
export interface ICycleStore {
|
||||||
|
loader: boolean;
|
||||||
|
error: any | null;
|
||||||
|
|
||||||
|
cycleId: string | null;
|
||||||
|
|
||||||
|
setCycleId: (cycleSlug: string) => void;
|
||||||
|
}
|
||||||
|
|
||||||
|
class CycleStore implements ICycleStore {
|
||||||
|
loader: boolean = false;
|
||||||
|
error: any | null = null;
|
||||||
|
|
||||||
|
cycleId: string | null = null;
|
||||||
|
|
||||||
|
// root store
|
||||||
|
rootStore;
|
||||||
|
// services
|
||||||
|
projectService;
|
||||||
|
issueService;
|
||||||
|
|
||||||
|
constructor(_rootStore: RootStore) {
|
||||||
|
makeObservable(this, {
|
||||||
|
loader: observable,
|
||||||
|
error: observable.ref,
|
||||||
|
|
||||||
|
cycleId: observable.ref,
|
||||||
|
|
||||||
|
// computed
|
||||||
|
|
||||||
|
// actions
|
||||||
|
setCycleId: action,
|
||||||
|
});
|
||||||
|
|
||||||
|
this.rootStore = _rootStore;
|
||||||
|
this.projectService = new ProjectServices();
|
||||||
|
this.issueService = new IssueServices();
|
||||||
|
}
|
||||||
|
|
||||||
|
// computed
|
||||||
|
|
||||||
|
// actions
|
||||||
|
setCycleId = (cycleSlug: string) => {
|
||||||
|
this.cycleId = cycleSlug ?? null;
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
export default CycleStore;
|
@ -1,6 +1,6 @@
|
|||||||
import { renderDateFormat } from "helpers/date-time.helper";
|
import { renderDateFormat } from "helpers/date-time.helper";
|
||||||
// types
|
// types
|
||||||
import { TIssueLayouts, TIssueParams } from "./issue_filters";
|
import { TIssueLayouts, TIssueParams } from "../issue-filters";
|
||||||
|
|
||||||
export type TStateGroup = "backlog" | "unstarted" | "started" | "completed" | "cancelled";
|
export type TStateGroup = "backlog" | "unstarted" | "started" | "completed" | "cancelled";
|
||||||
|
|
1085
web/store/issue-filters.ts
Normal file
1085
web/store/issue-filters.ts
Normal file
File diff suppressed because it is too large
Load Diff
417
web/store/issue-store.ts
Normal file
417
web/store/issue-store.ts
Normal file
@ -0,0 +1,417 @@
|
|||||||
|
import { observable, action, computed, makeObservable, runInAction } from "mobx";
|
||||||
|
// types
|
||||||
|
import { RootStore } from "./root";
|
||||||
|
// services
|
||||||
|
import { UserService } from "services/user.service";
|
||||||
|
import { ProjectIssuesServices } from "services/issues.service";
|
||||||
|
import { ProjectIssuesServices as ProjectModuleServices } from "services/modules.service";
|
||||||
|
import { ProjectCycleServices } from "services/cycles.service";
|
||||||
|
// types
|
||||||
|
import { TIssueLayouts, TIssueViews } from "./issue-filters";
|
||||||
|
|
||||||
|
export interface IIssues {
|
||||||
|
[key: string]: any;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface IIssuesLayout {
|
||||||
|
list: IIssues[];
|
||||||
|
kanban: IIssues[];
|
||||||
|
calendar: IIssues[];
|
||||||
|
spreadsheet: IIssues[];
|
||||||
|
gantt_chart: IIssues[];
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface IIssueState {
|
||||||
|
[key: string]: {
|
||||||
|
// project_id: layout_view
|
||||||
|
issues: {
|
||||||
|
[key: string]: IIssuesLayout; // project_id: layout_key: ...issues, It's always one project id here
|
||||||
|
};
|
||||||
|
cycles: {
|
||||||
|
[key: string]: IIssuesLayout; // cycle_id: layout_key: ...issues
|
||||||
|
};
|
||||||
|
modules: {
|
||||||
|
[key: string]: IIssuesLayout; // module_id: layout_key: ...issues
|
||||||
|
};
|
||||||
|
views: {
|
||||||
|
[key: string]: IIssuesLayout; // view_id: layout_key: ...issues
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface IIssueStore {
|
||||||
|
loader: boolean;
|
||||||
|
error: any | null;
|
||||||
|
issues: IIssueState;
|
||||||
|
// computed
|
||||||
|
getIssues: IIssues | null | undefined;
|
||||||
|
// actions
|
||||||
|
updateIssues: (data: any) => void;
|
||||||
|
getProjectIssuesAsync: (workspaceId: string, projectId: string, fetchFilterToggle?: boolean) => null | Promise<any>;
|
||||||
|
getIssuesForModulesAsync: (
|
||||||
|
workspaceId: string,
|
||||||
|
projectId: string,
|
||||||
|
moduleId: string,
|
||||||
|
fetchFilterToggle: boolean
|
||||||
|
) => null | Promise<any>;
|
||||||
|
getIssuesForCyclesAsync: (
|
||||||
|
workspaceId: string,
|
||||||
|
projectId: string,
|
||||||
|
cycleId: string,
|
||||||
|
fetchFilterToggle: boolean
|
||||||
|
) => null | Promise<any>;
|
||||||
|
getIssuesForViewsAsync: (
|
||||||
|
workspaceId: string,
|
||||||
|
projectId: string,
|
||||||
|
viewId: string,
|
||||||
|
fetchFilterToggle: boolean
|
||||||
|
) => null | Promise<any>;
|
||||||
|
}
|
||||||
|
|
||||||
|
class IssueStore implements IIssueStore {
|
||||||
|
loader: boolean = false;
|
||||||
|
error: any | null = null;
|
||||||
|
issues: IIssueState = {};
|
||||||
|
// root store
|
||||||
|
rootStore;
|
||||||
|
// service
|
||||||
|
issueService;
|
||||||
|
userService;
|
||||||
|
modulesService;
|
||||||
|
cyclesService;
|
||||||
|
|
||||||
|
constructor(_rootStore: RootStore) {
|
||||||
|
makeObservable(this, {
|
||||||
|
// observable
|
||||||
|
loader: observable,
|
||||||
|
error: observable,
|
||||||
|
issues: observable.ref,
|
||||||
|
// computed
|
||||||
|
getIssues: computed,
|
||||||
|
// action
|
||||||
|
updateIssues: action,
|
||||||
|
getProjectIssuesAsync: action,
|
||||||
|
getIssuesForModulesAsync: action,
|
||||||
|
getIssuesForCyclesAsync: action,
|
||||||
|
getIssuesForViewsAsync: action,
|
||||||
|
});
|
||||||
|
|
||||||
|
this.rootStore = _rootStore;
|
||||||
|
this.issueService = new ProjectIssuesServices();
|
||||||
|
this.userService = new UserService();
|
||||||
|
this.modulesService = new ProjectModuleServices();
|
||||||
|
this.cyclesService = new ProjectCycleServices();
|
||||||
|
}
|
||||||
|
|
||||||
|
// computed
|
||||||
|
get getIssues() {
|
||||||
|
if (this.issues != null) {
|
||||||
|
const issueView: TIssueViews | null = this.rootStore.issueFilter.issueView;
|
||||||
|
const projectId: string | null = this.rootStore.project.projectId;
|
||||||
|
const moduleId: string | null = this.rootStore.module.moduleId;
|
||||||
|
const cycleId: string | null = this.rootStore.cycle.cycleId;
|
||||||
|
const viewId: string | null = this.rootStore.view.viewId;
|
||||||
|
const issueLayout: TIssueLayouts | null = this.rootStore.issueFilter.issueLayout;
|
||||||
|
|
||||||
|
if (!issueView || !projectId) return null;
|
||||||
|
|
||||||
|
const currentViewIdIndex: string | null =
|
||||||
|
issueView === "issues" && projectId
|
||||||
|
? projectId
|
||||||
|
: issueView === "modules" && moduleId
|
||||||
|
? moduleId
|
||||||
|
: issueView === "cycles" && cycleId
|
||||||
|
? cycleId
|
||||||
|
: issueView === "cycles" && viewId
|
||||||
|
? viewId
|
||||||
|
: null;
|
||||||
|
|
||||||
|
if (!issueLayout || !currentViewIdIndex) return null;
|
||||||
|
return this.issues[projectId][issueView][currentViewIdIndex][issueLayout];
|
||||||
|
}
|
||||||
|
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
updateIssues = (data: any) => {
|
||||||
|
const issueView: TIssueViews | null = this.rootStore.issueFilter.issueView;
|
||||||
|
const projectId: string | null = this.rootStore.project.projectId;
|
||||||
|
const moduleId: string | null = this.rootStore.module.moduleId;
|
||||||
|
const cycleId: string | null = this.rootStore.cycle.cycleId;
|
||||||
|
const viewId: string | null = this.rootStore.view.viewId;
|
||||||
|
const issueLayout: TIssueLayouts | null = this.rootStore.issueFilter.issueLayout;
|
||||||
|
|
||||||
|
const { groupId, issueId, issueData } = data as {
|
||||||
|
groupId?: any;
|
||||||
|
issueId: string | null;
|
||||||
|
issueData: any;
|
||||||
|
};
|
||||||
|
|
||||||
|
if (!issueView || !projectId) return null;
|
||||||
|
|
||||||
|
const currentViewIdIndex: string | null =
|
||||||
|
issueView === "issues" && projectId
|
||||||
|
? projectId
|
||||||
|
: issueView === "modules" && moduleId
|
||||||
|
? moduleId
|
||||||
|
: issueView === "cycles" && cycleId
|
||||||
|
? cycleId
|
||||||
|
: issueView === "cycles" && viewId
|
||||||
|
? viewId
|
||||||
|
: null;
|
||||||
|
|
||||||
|
if (!issueLayout || !currentViewIdIndex) return null;
|
||||||
|
|
||||||
|
let _issues = this?.issues?.[projectId]?.[issueView]?.[currentViewIdIndex]?.[issueLayout];
|
||||||
|
if (groupId && groupId != null && ["list", "kanban"].includes(issueLayout)) {
|
||||||
|
_issues = {
|
||||||
|
..._issues,
|
||||||
|
[groupId]:
|
||||||
|
_issues?.[groupId] && _issues?.[groupId].length > 0
|
||||||
|
? _issues?.[groupId]?.map((item: any) => (item.id === issueId ? { ...item, ...issueData } : { ...item }))
|
||||||
|
: [],
|
||||||
|
};
|
||||||
|
} else {
|
||||||
|
_issues = {
|
||||||
|
..._issues,
|
||||||
|
..._issues.map((item: any) => (item.id === issueId ? { ...item, ...issueData } : { ...item })),
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
this.issues = {
|
||||||
|
...this.issues,
|
||||||
|
[projectId]: {
|
||||||
|
...this?.issues?.[projectId],
|
||||||
|
[issueView]: {
|
||||||
|
...this?.issues?.[projectId]?.[issueView],
|
||||||
|
[currentViewIdIndex]: {
|
||||||
|
...this?.issues?.[projectId]?.[issueView]?.[currentViewIdIndex],
|
||||||
|
[issueLayout]: {
|
||||||
|
...this?.issues?.[projectId]?.[issueView]?.[currentViewIdIndex]?.[issueLayout],
|
||||||
|
..._issues,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
// fetching project issues
|
||||||
|
getProjectIssuesAsync = async (workspaceId: string, projectId: string, fetchFilterToggle: boolean = true) => {
|
||||||
|
try {
|
||||||
|
this.loader = true;
|
||||||
|
this.error = null;
|
||||||
|
|
||||||
|
if (fetchFilterToggle) await this.rootStore.issueFilter.getProjectIssueFilters(workspaceId, projectId);
|
||||||
|
// const filteredParams = this.rootStore.issueFilter.getComputedFilters(
|
||||||
|
// workspaceId,
|
||||||
|
// projectId,
|
||||||
|
// null,
|
||||||
|
// null,
|
||||||
|
// null,
|
||||||
|
// "issues"
|
||||||
|
// );
|
||||||
|
// const issuesResponse = await this.issueService.getIssuesWithParams(workspaceId, projectId, filteredParams);
|
||||||
|
|
||||||
|
// if (issuesResponse) {
|
||||||
|
// const _issueResponse: any = {
|
||||||
|
// ...this.issues,
|
||||||
|
// [projectId]: {
|
||||||
|
// ...this?.issues?.[projectId],
|
||||||
|
// issues: {
|
||||||
|
// ...this?.issues?.[projectId]?.issues,
|
||||||
|
// [this.rootStore?.issueFilter?.userFilters?.display_filters?.layout as string]: issuesResponse,
|
||||||
|
// },
|
||||||
|
// },
|
||||||
|
// };
|
||||||
|
|
||||||
|
// runInAction(() => {
|
||||||
|
// this.issues = _issueResponse;
|
||||||
|
// this.loader = false;
|
||||||
|
// this.error = null;
|
||||||
|
// });
|
||||||
|
// }
|
||||||
|
|
||||||
|
// return issuesResponse;
|
||||||
|
} catch (error) {
|
||||||
|
console.warn("error in fetching the project issues", error);
|
||||||
|
this.loader = false;
|
||||||
|
this.error = null;
|
||||||
|
return error;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
// fetching project issues for modules
|
||||||
|
getIssuesForModulesAsync = async (
|
||||||
|
workspaceId: string,
|
||||||
|
projectId: string,
|
||||||
|
moduleId: string,
|
||||||
|
fetchFilterToggle: boolean = true
|
||||||
|
) => {
|
||||||
|
try {
|
||||||
|
this.loader = true;
|
||||||
|
this.error = null;
|
||||||
|
|
||||||
|
if (fetchFilterToggle)
|
||||||
|
await this.rootStore.issueFilter.getProjectIssueModuleFilters(workspaceId, projectId, moduleId);
|
||||||
|
const filteredParams = this.rootStore.issueFilter.getComputedFilters(
|
||||||
|
workspaceId,
|
||||||
|
projectId,
|
||||||
|
moduleId,
|
||||||
|
null,
|
||||||
|
null,
|
||||||
|
"modules"
|
||||||
|
);
|
||||||
|
const issuesResponse = await this.modulesService.getModuleIssuesWithParams(
|
||||||
|
workspaceId,
|
||||||
|
projectId,
|
||||||
|
moduleId,
|
||||||
|
filteredParams
|
||||||
|
);
|
||||||
|
|
||||||
|
if (issuesResponse) {
|
||||||
|
const _issueResponse: any = {
|
||||||
|
...this.issues,
|
||||||
|
[projectId]: {
|
||||||
|
...this?.issues?.[projectId],
|
||||||
|
modules: {
|
||||||
|
...this?.issues?.[projectId]?.modules,
|
||||||
|
[moduleId]: {
|
||||||
|
...this?.issues?.[projectId]?.modules?.[moduleId],
|
||||||
|
[this.rootStore?.issueFilter?.userFilters?.display_filters?.layout as string]: issuesResponse,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
runInAction(() => {
|
||||||
|
this.issues = _issueResponse;
|
||||||
|
this.loader = false;
|
||||||
|
this.error = null;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
return issuesResponse;
|
||||||
|
} catch (error) {
|
||||||
|
console.warn("error in fetching the project module issues", error);
|
||||||
|
this.loader = false;
|
||||||
|
this.error = null;
|
||||||
|
return error;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
// fetching project issues for cycles
|
||||||
|
getIssuesForCyclesAsync = async (
|
||||||
|
workspaceId: string,
|
||||||
|
projectId: string,
|
||||||
|
cycleId: string,
|
||||||
|
fetchFilterToggle: boolean = true
|
||||||
|
) => {
|
||||||
|
try {
|
||||||
|
this.loader = true;
|
||||||
|
this.error = null;
|
||||||
|
|
||||||
|
if (fetchFilterToggle)
|
||||||
|
await this.rootStore.issueFilter.getProjectIssueCyclesFilters(workspaceId, projectId, cycleId);
|
||||||
|
const filteredParams = this.rootStore.issueFilter.getComputedFilters(
|
||||||
|
workspaceId,
|
||||||
|
projectId,
|
||||||
|
null,
|
||||||
|
cycleId,
|
||||||
|
null,
|
||||||
|
"cycles"
|
||||||
|
);
|
||||||
|
const issuesResponse = await this.cyclesService.getCycleIssuesWithParams(
|
||||||
|
workspaceId,
|
||||||
|
projectId,
|
||||||
|
cycleId,
|
||||||
|
filteredParams
|
||||||
|
);
|
||||||
|
|
||||||
|
if (issuesResponse) {
|
||||||
|
const _issueResponse: any = {
|
||||||
|
...this.issues,
|
||||||
|
[projectId]: {
|
||||||
|
...this?.issues?.[projectId],
|
||||||
|
cycles: {
|
||||||
|
...this?.issues?.[projectId]?.cycles,
|
||||||
|
[cycleId]: {
|
||||||
|
...this?.issues?.[projectId]?.cycles?.[cycleId],
|
||||||
|
[this.rootStore?.issueFilter?.userFilters?.display_filters?.layout as string]: issuesResponse,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
runInAction(() => {
|
||||||
|
this.issues = _issueResponse;
|
||||||
|
this.loader = false;
|
||||||
|
this.error = null;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
return issuesResponse;
|
||||||
|
} catch (error) {
|
||||||
|
console.warn("error in fetching the project cycles issues", error);
|
||||||
|
this.loader = false;
|
||||||
|
this.error = null;
|
||||||
|
return error;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
// fetching project issues for views
|
||||||
|
getIssuesForViewsAsync = async (
|
||||||
|
workspaceId: string,
|
||||||
|
projectId: string,
|
||||||
|
viewId: string,
|
||||||
|
fetchFilterToggle: boolean = true
|
||||||
|
) => {
|
||||||
|
try {
|
||||||
|
this.loader = true;
|
||||||
|
this.error = null;
|
||||||
|
|
||||||
|
if (fetchFilterToggle)
|
||||||
|
await this.rootStore.issueFilter.getProjectIssueViewsFilters(workspaceId, projectId, viewId);
|
||||||
|
const filteredParams = this.rootStore.issueFilter.getComputedFilters(
|
||||||
|
workspaceId,
|
||||||
|
projectId,
|
||||||
|
null,
|
||||||
|
null,
|
||||||
|
viewId,
|
||||||
|
"views"
|
||||||
|
);
|
||||||
|
const issuesResponse = await this.issueService.getIssuesWithParams(workspaceId, projectId, filteredParams);
|
||||||
|
|
||||||
|
if (issuesResponse) {
|
||||||
|
const _issueResponse: any = {
|
||||||
|
...this.issues,
|
||||||
|
[projectId]: {
|
||||||
|
...this?.issues?.[projectId],
|
||||||
|
views: {
|
||||||
|
...this?.issues?.[projectId]?.views,
|
||||||
|
[viewId]: {
|
||||||
|
...this?.issues?.[projectId]?.views?.[viewId],
|
||||||
|
[this.rootStore?.issueFilter?.userFilters?.display_filters?.layout as string]: issuesResponse,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
runInAction(() => {
|
||||||
|
this.issues = _issueResponse;
|
||||||
|
this.loader = false;
|
||||||
|
this.error = null;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
return issuesResponse;
|
||||||
|
} catch (error) {
|
||||||
|
console.warn("error in fetching the project view issues", error);
|
||||||
|
this.loader = false;
|
||||||
|
this.error = null;
|
||||||
|
return error;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
export default IssueStore;
|
@ -1,524 +0,0 @@
|
|||||||
import { observable, action, computed, makeObservable, runInAction } from "mobx";
|
|
||||||
// types
|
|
||||||
import { RootStore } from "../root";
|
|
||||||
// services
|
|
||||||
import { UserService } from "services/user.service";
|
|
||||||
import { ProjectIssuesServices } from "services/issues.service";
|
|
||||||
import { ProjectIssuesServices as ProjectModuleServices } from "services/modules.service";
|
|
||||||
import { ProjectCycleServices } from "services/cycles.service";
|
|
||||||
// types
|
|
||||||
import { TIssueLayouts, TIssueViews } from "./issue_filters";
|
|
||||||
|
|
||||||
export interface IIssues {
|
|
||||||
[key: string]: any;
|
|
||||||
}
|
|
||||||
|
|
||||||
export interface IIssuesLayout {
|
|
||||||
list: IIssues[];
|
|
||||||
kanban: IIssues[];
|
|
||||||
calendar: IIssues[];
|
|
||||||
spreadsheet: IIssues[];
|
|
||||||
gantt_chart: IIssues[];
|
|
||||||
}
|
|
||||||
|
|
||||||
export interface IIssueState {
|
|
||||||
[key: string]: {
|
|
||||||
my_issues: IIssuesLayout;
|
|
||||||
project_issues: {
|
|
||||||
[key: string]: {
|
|
||||||
issues: IIssuesLayout;
|
|
||||||
cycles: {
|
|
||||||
[key: string]: IIssuesLayout;
|
|
||||||
};
|
|
||||||
modules: {
|
|
||||||
[key: string]: IIssuesLayout;
|
|
||||||
};
|
|
||||||
views: {
|
|
||||||
[key: string]: IIssuesLayout;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
export interface IIssueViewStore {
|
|
||||||
loader: boolean;
|
|
||||||
error: any | null;
|
|
||||||
issues: IIssueState;
|
|
||||||
// computed
|
|
||||||
getIssues: IIssues | null | undefined;
|
|
||||||
// actions
|
|
||||||
getMyIssuesAsync: (workspaceId: string, fetchFilterToggle: boolean) => null | Promise<any>;
|
|
||||||
getProjectIssuesAsync: (workspaceId: string, projectId: string, fetchFilterToggle: boolean) => null | Promise<any>;
|
|
||||||
getIssuesForModulesAsync: (
|
|
||||||
workspaceId: string,
|
|
||||||
projectId: string,
|
|
||||||
moduleId: string,
|
|
||||||
fetchFilterToggle: boolean
|
|
||||||
) => null | Promise<any>;
|
|
||||||
getIssuesForCyclesAsync: (
|
|
||||||
workspaceId: string,
|
|
||||||
projectId: string,
|
|
||||||
cycleId: string,
|
|
||||||
fetchFilterToggle: boolean
|
|
||||||
) => null | Promise<any>;
|
|
||||||
getIssuesForViewsAsync: (
|
|
||||||
workspaceId: string,
|
|
||||||
projectId: string,
|
|
||||||
viewId: string,
|
|
||||||
fetchFilterToggle: boolean
|
|
||||||
) => null | Promise<any>;
|
|
||||||
}
|
|
||||||
|
|
||||||
class IssueViewStore implements IIssueViewStore {
|
|
||||||
loader: boolean = false;
|
|
||||||
error: any | null = null;
|
|
||||||
issues: IIssueState = {};
|
|
||||||
// root store
|
|
||||||
rootStore;
|
|
||||||
// service
|
|
||||||
issueService;
|
|
||||||
userService;
|
|
||||||
modulesService;
|
|
||||||
cyclesService;
|
|
||||||
|
|
||||||
constructor(_rootStore: RootStore) {
|
|
||||||
makeObservable(this, {
|
|
||||||
// observable
|
|
||||||
loader: observable,
|
|
||||||
error: observable,
|
|
||||||
issues: observable.ref,
|
|
||||||
// action
|
|
||||||
getMyIssuesAsync: action,
|
|
||||||
getProjectIssuesAsync: action,
|
|
||||||
getIssuesForModulesAsync: action,
|
|
||||||
getIssuesForCyclesAsync: action,
|
|
||||||
getIssuesForViewsAsync: action,
|
|
||||||
updateIssues: action,
|
|
||||||
// computed
|
|
||||||
getIssues: computed,
|
|
||||||
});
|
|
||||||
|
|
||||||
this.rootStore = _rootStore;
|
|
||||||
this.issueService = new ProjectIssuesServices();
|
|
||||||
this.userService = new UserService();
|
|
||||||
this.modulesService = new ProjectModuleServices();
|
|
||||||
this.cyclesService = new ProjectCycleServices();
|
|
||||||
}
|
|
||||||
|
|
||||||
// computed
|
|
||||||
get getIssues() {
|
|
||||||
if (this.issues != null) {
|
|
||||||
const currentView: TIssueViews | null = this.rootStore.issueFilters.issueView;
|
|
||||||
const currentWorkspaceId: string | null = this.rootStore.issueFilters.workspaceId;
|
|
||||||
const currentProjectId: string | null = this.rootStore.issueFilters.projectId;
|
|
||||||
const currentModuleId: string | null = this.rootStore.issueFilters.moduleId;
|
|
||||||
const currentCycleId: string | null = this.rootStore.issueFilters.cycleId;
|
|
||||||
const currentViewId: string | null = this.rootStore.issueFilters.viewId;
|
|
||||||
|
|
||||||
if (!currentView || !currentWorkspaceId) return null;
|
|
||||||
|
|
||||||
const currentLayout: TIssueLayouts = currentProjectId
|
|
||||||
? this.rootStore.issueFilters.issueFilters?.[currentWorkspaceId]?.project_issue_properties?.[currentProjectId]
|
|
||||||
?.issues?.display_filters?.layout
|
|
||||||
: this.rootStore.issueFilters.issueFilters?.[currentWorkspaceId]?.my_issue_properties?.display_filters?.layout;
|
|
||||||
|
|
||||||
if (currentView === "my_issues") return this.issues?.[currentWorkspaceId]?.my_issues?.[currentLayout];
|
|
||||||
else if (currentView === "issues" && currentProjectId)
|
|
||||||
return this.issues?.[currentWorkspaceId]?.project_issues?.[currentProjectId]?.issues?.[currentLayout];
|
|
||||||
else if (currentView === "modules" && currentProjectId && currentModuleId)
|
|
||||||
return this.issues?.[currentWorkspaceId]?.project_issues?.[currentProjectId]?.modules?.[currentModuleId]?.[
|
|
||||||
currentLayout
|
|
||||||
];
|
|
||||||
else if (currentView === "cycles" && currentProjectId && currentCycleId)
|
|
||||||
return this.issues?.[currentWorkspaceId]?.project_issues?.[currentProjectId]?.cycles?.[currentCycleId]?.[
|
|
||||||
currentLayout
|
|
||||||
];
|
|
||||||
else if (currentView === "views" && currentProjectId && currentViewId)
|
|
||||||
return this.issues?.[currentWorkspaceId]?.project_issues?.[currentProjectId]?.views?.[currentViewId]?.[
|
|
||||||
currentLayout
|
|
||||||
];
|
|
||||||
}
|
|
||||||
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
updateIssues = (group_id: any = null, issue_id: string | null, data: any) => {
|
|
||||||
const currentWorkspaceId: string | null = this.rootStore.issueFilters.workspaceId;
|
|
||||||
const currentProjectId: string | null = this.rootStore.issueFilters.projectId;
|
|
||||||
// const currentModuleId: string | null = this.rootStore.issueFilters.moduleId;
|
|
||||||
// const currentCycleId: string | null = this.rootStore.issueFilters.cycleId;
|
|
||||||
// const currentViewId: string | null = this.rootStore.issueFilters.viewId;
|
|
||||||
const currentView: TIssueViews | null = this.rootStore.issueFilters.issueView;
|
|
||||||
const currentLayout: TIssueLayouts | null = this.rootStore.issueFilters.issueLayout;
|
|
||||||
|
|
||||||
if (!currentView || !currentWorkspaceId || !currentLayout || !issue_id) return null;
|
|
||||||
|
|
||||||
if (currentView === "my_issues") {
|
|
||||||
if (group_id) {
|
|
||||||
this.issues = {
|
|
||||||
...this.issues,
|
|
||||||
[currentWorkspaceId]: {
|
|
||||||
...this?.issues?.[currentWorkspaceId],
|
|
||||||
my_issues: {
|
|
||||||
...this?.issues?.[currentWorkspaceId]?.my_issues,
|
|
||||||
[currentLayout]: {
|
|
||||||
...this?.issues?.[currentWorkspaceId]?.my_issues?.[currentLayout],
|
|
||||||
[group_id]: this?.issues?.[currentWorkspaceId]?.my_issues?.[currentLayout]?.[group_id].map(
|
|
||||||
(item: any) => (item.id === issue_id ? { ...item, ...data } : { ...item })
|
|
||||||
),
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
} as any;
|
|
||||||
} else {
|
|
||||||
this.issues = {
|
|
||||||
...this.issues,
|
|
||||||
[currentWorkspaceId]: {
|
|
||||||
...this?.issues?.[currentWorkspaceId],
|
|
||||||
my_issues: {
|
|
||||||
...this?.issues?.[currentWorkspaceId]?.my_issues,
|
|
||||||
[currentLayout]: this?.issues?.[currentWorkspaceId]?.my_issues?.[currentLayout].map((item: any) =>
|
|
||||||
item.id === issue_id ? { ...item, ...data } : { ...item }
|
|
||||||
),
|
|
||||||
},
|
|
||||||
},
|
|
||||||
} as any;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!currentProjectId) return null;
|
|
||||||
if (currentView) {
|
|
||||||
if (group_id) {
|
|
||||||
this.issues = {
|
|
||||||
...this.issues,
|
|
||||||
[currentWorkspaceId]: {
|
|
||||||
...this?.issues?.[currentWorkspaceId],
|
|
||||||
project_issues: {
|
|
||||||
...this?.issues?.[currentWorkspaceId]?.project_issues,
|
|
||||||
[currentProjectId]: {
|
|
||||||
...this?.issues?.[currentWorkspaceId]?.project_issues?.[currentProjectId],
|
|
||||||
[currentView]: {
|
|
||||||
...this?.issues?.[currentWorkspaceId]?.project_issues?.[currentProjectId]?.issues,
|
|
||||||
[currentLayout]: {
|
|
||||||
...this?.issues?.[currentWorkspaceId]?.project_issues?.[currentProjectId]?.issues?.[currentLayout],
|
|
||||||
[group_id]: this?.issues?.[currentWorkspaceId]?.project_issues?.[currentProjectId]?.issues?.[
|
|
||||||
currentLayout
|
|
||||||
]?.[group_id].map((item: any) => (item.id === issue_id ? { ...item, ...data } : { ...item })),
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
} as any;
|
|
||||||
} else {
|
|
||||||
this.issues = {
|
|
||||||
...this.issues,
|
|
||||||
[currentWorkspaceId]: {
|
|
||||||
...this?.issues?.[currentWorkspaceId],
|
|
||||||
project_issues: {
|
|
||||||
...this?.issues?.[currentWorkspaceId]?.project_issues,
|
|
||||||
[currentProjectId]: {
|
|
||||||
...this?.issues?.[currentWorkspaceId]?.project_issues?.[currentProjectId],
|
|
||||||
[currentView]: {
|
|
||||||
...this?.issues?.[currentWorkspaceId]?.project_issues?.[currentProjectId]?.issues,
|
|
||||||
[currentLayout]: this?.issues?.[currentWorkspaceId]?.project_issues?.[currentProjectId]?.issues?.[
|
|
||||||
currentLayout
|
|
||||||
].map((item: any) => (item.id === issue_id ? { ...item, ...data } : { ...item })),
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
} as any;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
// fetching my issues
|
|
||||||
getMyIssuesAsync = async (workspaceId: string, fetchFilterToggle: boolean = true) => {
|
|
||||||
try {
|
|
||||||
this.loader = true;
|
|
||||||
this.error = null;
|
|
||||||
|
|
||||||
if (fetchFilterToggle) await this.rootStore.issueFilters.getWorkspaceMyIssuesFilters(workspaceId);
|
|
||||||
const filteredParams = this.rootStore.issueFilters.getComputedFilters(
|
|
||||||
workspaceId,
|
|
||||||
null,
|
|
||||||
null,
|
|
||||||
null,
|
|
||||||
null,
|
|
||||||
"my_issues"
|
|
||||||
);
|
|
||||||
const issuesResponse = await this.userService.userIssues(workspaceId, filteredParams);
|
|
||||||
|
|
||||||
if (issuesResponse) {
|
|
||||||
const _issueResponse: any = {
|
|
||||||
...this.issues,
|
|
||||||
[workspaceId]: {
|
|
||||||
...this?.issues[workspaceId],
|
|
||||||
my_issues: {
|
|
||||||
...this?.issues[workspaceId]?.my_issues,
|
|
||||||
[this.rootStore?.issueFilters?.userFilters?.display_filters?.layout as string]: issuesResponse,
|
|
||||||
},
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
runInAction(() => {
|
|
||||||
this.issues = _issueResponse;
|
|
||||||
this.loader = false;
|
|
||||||
this.error = null;
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
return issuesResponse;
|
|
||||||
} catch (error) {
|
|
||||||
console.warn("error in fetching the my issues", error);
|
|
||||||
this.loader = false;
|
|
||||||
this.error = null;
|
|
||||||
return error;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
// fetching project issues
|
|
||||||
getProjectIssuesAsync = async (workspaceId: string, projectId: string, fetchFilterToggle: boolean = true) => {
|
|
||||||
try {
|
|
||||||
this.loader = true;
|
|
||||||
this.error = null;
|
|
||||||
|
|
||||||
if (fetchFilterToggle) await this.rootStore.issueFilters.getProjectIssueFilters(workspaceId, projectId);
|
|
||||||
const filteredParams = this.rootStore.issueFilters.getComputedFilters(
|
|
||||||
workspaceId,
|
|
||||||
projectId,
|
|
||||||
null,
|
|
||||||
null,
|
|
||||||
null,
|
|
||||||
"issues"
|
|
||||||
);
|
|
||||||
const issuesResponse = await this.issueService.getIssuesWithParams(workspaceId, projectId, filteredParams);
|
|
||||||
|
|
||||||
if (issuesResponse) {
|
|
||||||
const _issueResponse: any = {
|
|
||||||
...this.issues,
|
|
||||||
[workspaceId]: {
|
|
||||||
...this?.issues?.[workspaceId],
|
|
||||||
project_issues: {
|
|
||||||
...this?.issues?.[workspaceId]?.project_issues,
|
|
||||||
[projectId]: {
|
|
||||||
...this?.issues?.[workspaceId]?.project_issues?.[projectId],
|
|
||||||
issues: {
|
|
||||||
...this?.issues[workspaceId]?.project_issues?.[projectId]?.issues,
|
|
||||||
[this.rootStore?.issueFilters?.userFilters?.display_filters?.layout as string]: issuesResponse,
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
runInAction(() => {
|
|
||||||
this.issues = _issueResponse;
|
|
||||||
this.loader = false;
|
|
||||||
this.error = null;
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
return issuesResponse;
|
|
||||||
} catch (error) {
|
|
||||||
console.warn("error in fetching the project issues", error);
|
|
||||||
this.loader = false;
|
|
||||||
this.error = null;
|
|
||||||
return error;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
// fetching project issues for modules
|
|
||||||
getIssuesForModulesAsync = async (
|
|
||||||
workspaceId: string,
|
|
||||||
projectId: string,
|
|
||||||
moduleId: string,
|
|
||||||
fetchFilterToggle: boolean = true
|
|
||||||
) => {
|
|
||||||
try {
|
|
||||||
this.loader = true;
|
|
||||||
this.error = null;
|
|
||||||
|
|
||||||
if (fetchFilterToggle)
|
|
||||||
await this.rootStore.issueFilters.getProjectIssueModuleFilters(workspaceId, projectId, moduleId);
|
|
||||||
const filteredParams = this.rootStore.issueFilters.getComputedFilters(
|
|
||||||
workspaceId,
|
|
||||||
projectId,
|
|
||||||
moduleId,
|
|
||||||
null,
|
|
||||||
null,
|
|
||||||
"modules"
|
|
||||||
);
|
|
||||||
const issuesResponse = await this.modulesService.getModuleIssuesWithParams(
|
|
||||||
workspaceId,
|
|
||||||
projectId,
|
|
||||||
moduleId,
|
|
||||||
filteredParams
|
|
||||||
);
|
|
||||||
|
|
||||||
if (issuesResponse) {
|
|
||||||
const _issueResponse: any = {
|
|
||||||
...this.issues,
|
|
||||||
[workspaceId]: {
|
|
||||||
...this?.issues?.[workspaceId],
|
|
||||||
project_issues: {
|
|
||||||
...this?.issues?.[workspaceId]?.project_issues,
|
|
||||||
[projectId]: {
|
|
||||||
...this?.issues?.[workspaceId]?.project_issues?.[projectId],
|
|
||||||
modules: {
|
|
||||||
...this?.issues[workspaceId]?.project_issues?.[projectId]?.modules,
|
|
||||||
[moduleId]: {
|
|
||||||
...this?.issues[workspaceId]?.project_issues?.[projectId]?.modules?.[moduleId],
|
|
||||||
[this.rootStore?.issueFilters?.userFilters?.display_filters?.layout as string]: issuesResponse,
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
runInAction(() => {
|
|
||||||
this.issues = _issueResponse;
|
|
||||||
this.loader = false;
|
|
||||||
this.error = null;
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
return issuesResponse;
|
|
||||||
} catch (error) {
|
|
||||||
console.warn("error in fetching the project module issues", error);
|
|
||||||
this.loader = false;
|
|
||||||
this.error = null;
|
|
||||||
return error;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
// fetching project issues for cycles
|
|
||||||
getIssuesForCyclesAsync = async (
|
|
||||||
workspaceId: string,
|
|
||||||
projectId: string,
|
|
||||||
cycleId: string,
|
|
||||||
fetchFilterToggle: boolean = true
|
|
||||||
) => {
|
|
||||||
try {
|
|
||||||
this.loader = true;
|
|
||||||
this.error = null;
|
|
||||||
|
|
||||||
if (fetchFilterToggle)
|
|
||||||
await this.rootStore.issueFilters.getProjectIssueCyclesFilters(workspaceId, projectId, cycleId);
|
|
||||||
const filteredParams = this.rootStore.issueFilters.getComputedFilters(
|
|
||||||
workspaceId,
|
|
||||||
projectId,
|
|
||||||
null,
|
|
||||||
cycleId,
|
|
||||||
null,
|
|
||||||
"cycles"
|
|
||||||
);
|
|
||||||
const issuesResponse = await this.cyclesService.getCycleIssuesWithParams(
|
|
||||||
workspaceId,
|
|
||||||
projectId,
|
|
||||||
cycleId,
|
|
||||||
filteredParams
|
|
||||||
);
|
|
||||||
|
|
||||||
if (issuesResponse) {
|
|
||||||
const _issueResponse: any = {
|
|
||||||
...this.issues,
|
|
||||||
[workspaceId]: {
|
|
||||||
...this?.issues?.[workspaceId],
|
|
||||||
project_issues: {
|
|
||||||
...this?.issues?.[workspaceId]?.project_issues,
|
|
||||||
[projectId]: {
|
|
||||||
...this?.issues?.[workspaceId]?.project_issues?.[projectId],
|
|
||||||
cycles: {
|
|
||||||
...this?.issues[workspaceId]?.project_issues?.[projectId]?.cycles,
|
|
||||||
[cycleId]: {
|
|
||||||
...this?.issues[workspaceId]?.project_issues?.[projectId]?.cycles?.[cycleId],
|
|
||||||
[this.rootStore?.issueFilters?.userFilters?.display_filters?.layout as string]: issuesResponse,
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
runInAction(() => {
|
|
||||||
this.issues = _issueResponse;
|
|
||||||
this.loader = false;
|
|
||||||
this.error = null;
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
return issuesResponse;
|
|
||||||
} catch (error) {
|
|
||||||
console.warn("error in fetching the project cycles issues", error);
|
|
||||||
this.loader = false;
|
|
||||||
this.error = null;
|
|
||||||
return error;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
// fetching project issues for views
|
|
||||||
getIssuesForViewsAsync = async (
|
|
||||||
workspaceId: string,
|
|
||||||
projectId: string,
|
|
||||||
viewId: string,
|
|
||||||
fetchFilterToggle: boolean = true
|
|
||||||
) => {
|
|
||||||
try {
|
|
||||||
this.loader = true;
|
|
||||||
this.error = null;
|
|
||||||
|
|
||||||
if (fetchFilterToggle)
|
|
||||||
await this.rootStore.issueFilters.getProjectIssueViewsFilters(workspaceId, projectId, viewId);
|
|
||||||
const filteredParams = this.rootStore.issueFilters.getComputedFilters(
|
|
||||||
workspaceId,
|
|
||||||
projectId,
|
|
||||||
null,
|
|
||||||
null,
|
|
||||||
viewId,
|
|
||||||
"views"
|
|
||||||
);
|
|
||||||
const issuesResponse = await this.issueService.getIssuesWithParams(workspaceId, projectId, filteredParams);
|
|
||||||
|
|
||||||
if (issuesResponse) {
|
|
||||||
const _issueResponse: any = {
|
|
||||||
...this.issues,
|
|
||||||
[workspaceId]: {
|
|
||||||
...this?.issues?.[workspaceId],
|
|
||||||
project_issues: {
|
|
||||||
...this?.issues?.[workspaceId]?.project_issues,
|
|
||||||
[projectId]: {
|
|
||||||
...this?.issues?.[workspaceId]?.project_issues?.[projectId],
|
|
||||||
views: {
|
|
||||||
...this?.issues[workspaceId]?.project_issues?.[projectId]?.views,
|
|
||||||
[viewId]: {
|
|
||||||
...this?.issues[workspaceId]?.project_issues?.[projectId]?.views?.[viewId],
|
|
||||||
[this.rootStore?.issueFilters?.userFilters?.display_filters?.layout as string]: issuesResponse,
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
runInAction(() => {
|
|
||||||
this.issues = _issueResponse;
|
|
||||||
this.loader = false;
|
|
||||||
this.error = null;
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
return issuesResponse;
|
|
||||||
} catch (error) {
|
|
||||||
console.warn("error in fetching the project view issues", error);
|
|
||||||
this.loader = false;
|
|
||||||
this.error = null;
|
|
||||||
return error;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
export default IssueViewStore;
|
|
File diff suppressed because it is too large
Load Diff
@ -1,21 +0,0 @@
|
|||||||
import { action, computed, makeObservable } from "mobx";
|
|
||||||
// types
|
|
||||||
import { RootStore } from "../root";
|
|
||||||
|
|
||||||
export interface IIssueProject {}
|
|
||||||
|
|
||||||
class IssueProject implements IIssueProject {
|
|
||||||
// root store
|
|
||||||
rootStore;
|
|
||||||
|
|
||||||
constructor(_rootStore: RootStore) {
|
|
||||||
makeObservable(this, {
|
|
||||||
// computed
|
|
||||||
// actions
|
|
||||||
});
|
|
||||||
|
|
||||||
this.rootStore = _rootStore;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
export default IssueProject;
|
|
@ -1,21 +0,0 @@
|
|||||||
import { action, computed, makeObservable } from "mobx";
|
|
||||||
// types
|
|
||||||
import { RootStore } from "../root";
|
|
||||||
|
|
||||||
export interface IIssueWorkspace {}
|
|
||||||
|
|
||||||
class IssueWorkspace implements IIssueWorkspace {
|
|
||||||
// root store
|
|
||||||
rootStore;
|
|
||||||
|
|
||||||
constructor(_rootStore: RootStore) {
|
|
||||||
makeObservable(this, {
|
|
||||||
// computed
|
|
||||||
// actions
|
|
||||||
});
|
|
||||||
|
|
||||||
this.rootStore = _rootStore;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
export default IssueWorkspace;
|
|
@ -1,6 +1,6 @@
|
|||||||
import { observable, action, makeObservable, runInAction } from "mobx";
|
import { observable, action, makeObservable, runInAction } from "mobx";
|
||||||
// types
|
// types
|
||||||
import { RootStore } from "../root";
|
import { RootStore } from "./root";
|
||||||
// services
|
// services
|
||||||
import { ProjectIssuesServices } from "services/issues.service";
|
import { ProjectIssuesServices } from "services/issues.service";
|
||||||
|
|
@ -31,10 +31,7 @@ class IssuesStore {
|
|||||||
loadIssues = async (workspaceSlug: string, projectId: string) => {
|
loadIssues = async (workspaceSlug: string, projectId: string) => {
|
||||||
this.isIssuesLoading = true;
|
this.isIssuesLoading = true;
|
||||||
try {
|
try {
|
||||||
const issuesResponse: IIssue[] = (await issueService.getIssuesWithParams(
|
const issuesResponse: IIssue[] = (await issueService.getIssuesWithParams(workspaceSlug, projectId)) as IIssue[];
|
||||||
workspaceSlug,
|
|
||||||
projectId
|
|
||||||
)) as IIssue[];
|
|
||||||
|
|
||||||
const issues: { [kye: string]: IIssue } = {};
|
const issues: { [kye: string]: IIssue } = {};
|
||||||
issuesResponse.forEach((issue) => {
|
issuesResponse.forEach((issue) => {
|
||||||
@ -51,11 +48,7 @@ class IssuesStore {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
getIssueById = async (
|
getIssueById = async (workspaceSlug: string, projectId: string, issueId: string): Promise<IIssue> => {
|
||||||
workspaceSlug: string,
|
|
||||||
projectId: string,
|
|
||||||
issueId: string
|
|
||||||
): Promise<IIssue> => {
|
|
||||||
if (this.issues[issueId]) return this.issues[issueId];
|
if (this.issues[issueId]) return this.issues[issueId];
|
||||||
|
|
||||||
try {
|
try {
|
||||||
@ -83,12 +76,7 @@ class IssuesStore {
|
|||||||
user: ICurrentUserResponse
|
user: ICurrentUserResponse
|
||||||
): Promise<IIssue> => {
|
): Promise<IIssue> => {
|
||||||
try {
|
try {
|
||||||
const issueResponse = await issueService.createIssues(
|
const issueResponse = await issueService.createIssues(workspaceSlug, projectId, issueForm, user);
|
||||||
workspaceSlug,
|
|
||||||
projectId,
|
|
||||||
issueForm,
|
|
||||||
user
|
|
||||||
);
|
|
||||||
|
|
||||||
const issues = {
|
const issues = {
|
||||||
...this.issues,
|
...this.issues,
|
||||||
@ -125,13 +113,7 @@ class IssuesStore {
|
|||||||
});
|
});
|
||||||
|
|
||||||
// make a patch request to update the issue
|
// make a patch request to update the issue
|
||||||
const issueResponse: IIssue = await issueService.patchIssue(
|
const issueResponse: IIssue = await issueService.patchIssue(workspaceSlug, projectId, issueId, issueForm, user);
|
||||||
workspaceSlug,
|
|
||||||
projectId,
|
|
||||||
issueId,
|
|
||||||
issueForm,
|
|
||||||
user
|
|
||||||
);
|
|
||||||
|
|
||||||
const updatedIssues = { ...this.issues };
|
const updatedIssues = { ...this.issues };
|
||||||
updatedIssues[issueId] = { ...issueResponse };
|
updatedIssues[issueId] = { ...issueResponse };
|
||||||
@ -149,12 +131,7 @@ class IssuesStore {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
deleteIssue = async (
|
deleteIssue = async (workspaceSlug: string, projectId: string, issueId: string, user: ICurrentUserResponse) => {
|
||||||
workspaceSlug: string,
|
|
||||||
projectId: string,
|
|
||||||
issueId: string,
|
|
||||||
user: ICurrentUserResponse
|
|
||||||
) => {
|
|
||||||
const issues = { ...this.issues };
|
const issues = { ...this.issues };
|
||||||
delete issues[issueId];
|
delete issues[issueId];
|
||||||
|
|
||||||
|
55
web/store/modules.ts
Normal file
55
web/store/modules.ts
Normal file
@ -0,0 +1,55 @@
|
|||||||
|
import { action, computed, observable, makeObservable, runInAction } from "mobx";
|
||||||
|
// types
|
||||||
|
import { RootStore } from "./root";
|
||||||
|
// services
|
||||||
|
import { ProjectServices } from "services/project.service";
|
||||||
|
import { ProjectIssuesServices as IssueServices } from "services/issues.service";
|
||||||
|
|
||||||
|
export interface IModuleStore {
|
||||||
|
loader: boolean;
|
||||||
|
error: any | null;
|
||||||
|
|
||||||
|
moduleId: string | null;
|
||||||
|
|
||||||
|
setModuleId: (moduleSlug: string) => void;
|
||||||
|
}
|
||||||
|
|
||||||
|
class ModuleStore implements IModuleStore {
|
||||||
|
loader: boolean = false;
|
||||||
|
error: any | null = null;
|
||||||
|
|
||||||
|
moduleId: string | null = null;
|
||||||
|
|
||||||
|
// root store
|
||||||
|
rootStore;
|
||||||
|
// services
|
||||||
|
projectService;
|
||||||
|
issueService;
|
||||||
|
|
||||||
|
constructor(_rootStore: RootStore) {
|
||||||
|
makeObservable(this, {
|
||||||
|
loader: observable,
|
||||||
|
error: observable.ref,
|
||||||
|
|
||||||
|
moduleId: observable.ref,
|
||||||
|
|
||||||
|
// computed
|
||||||
|
|
||||||
|
// actions
|
||||||
|
setModuleId: action,
|
||||||
|
});
|
||||||
|
|
||||||
|
this.rootStore = _rootStore;
|
||||||
|
this.projectService = new ProjectServices();
|
||||||
|
this.issueService = new IssueServices();
|
||||||
|
}
|
||||||
|
|
||||||
|
// computed
|
||||||
|
|
||||||
|
// actions
|
||||||
|
setModuleId = (moduleSlug: string) => {
|
||||||
|
this.moduleId = moduleSlug ?? null;
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
export default ModuleStore;
|
@ -1,86 +0,0 @@
|
|||||||
import { observable, action, computed, makeObservable, runInAction } from "mobx";
|
|
||||||
// types
|
|
||||||
import { RootStore } from "./root";
|
|
||||||
// services
|
|
||||||
import { ProjectServices } from "services/project.service";
|
|
||||||
|
|
||||||
export interface IProject {
|
|
||||||
id: string;
|
|
||||||
name: string;
|
|
||||||
workspaceSlug: string;
|
|
||||||
}
|
|
||||||
|
|
||||||
export interface IProjectStore {
|
|
||||||
loader: boolean;
|
|
||||||
error: any | null;
|
|
||||||
|
|
||||||
projectLeaveModal: boolean;
|
|
||||||
projectLeaveDetails: IProject | any;
|
|
||||||
|
|
||||||
handleProjectLeaveModal: (project: IProject | null) => void;
|
|
||||||
|
|
||||||
leaveProject: (workspace_slug: string, project_slug: string, user: any) => Promise<void>;
|
|
||||||
}
|
|
||||||
|
|
||||||
class ProjectStore implements IProjectStore {
|
|
||||||
loader: boolean = false;
|
|
||||||
error: any | null = null;
|
|
||||||
|
|
||||||
projectLeaveModal: boolean = false;
|
|
||||||
projectLeaveDetails: IProject | null = null;
|
|
||||||
|
|
||||||
// root store
|
|
||||||
rootStore;
|
|
||||||
// service
|
|
||||||
projectService;
|
|
||||||
|
|
||||||
constructor(_rootStore: RootStore) {
|
|
||||||
makeObservable(this, {
|
|
||||||
// observable
|
|
||||||
loader: observable,
|
|
||||||
error: observable,
|
|
||||||
|
|
||||||
projectLeaveModal: observable,
|
|
||||||
projectLeaveDetails: observable.ref,
|
|
||||||
// action
|
|
||||||
handleProjectLeaveModal: action,
|
|
||||||
leaveProject: action,
|
|
||||||
// computed
|
|
||||||
});
|
|
||||||
|
|
||||||
this.rootStore = _rootStore;
|
|
||||||
this.projectService = new ProjectServices();
|
|
||||||
}
|
|
||||||
|
|
||||||
handleProjectLeaveModal = (project: IProject | null = null) => {
|
|
||||||
if (project && project?.id) {
|
|
||||||
this.projectLeaveModal = !this.projectLeaveModal;
|
|
||||||
this.projectLeaveDetails = project;
|
|
||||||
} else {
|
|
||||||
this.projectLeaveModal = !this.projectLeaveModal;
|
|
||||||
this.projectLeaveDetails = null;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
leaveProject = async (workspace_slug: string, project_slug: string, user: any) => {
|
|
||||||
try {
|
|
||||||
this.loader = true;
|
|
||||||
this.error = null;
|
|
||||||
|
|
||||||
const response = await this.projectService.leaveProject(workspace_slug, project_slug, user);
|
|
||||||
|
|
||||||
runInAction(() => {
|
|
||||||
this.loader = false;
|
|
||||||
this.error = null;
|
|
||||||
});
|
|
||||||
|
|
||||||
return response;
|
|
||||||
} catch (error) {
|
|
||||||
this.loader = false;
|
|
||||||
this.error = error;
|
|
||||||
return error;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
export default ProjectStore;
|
|
309
web/store/projects.ts
Normal file
309
web/store/projects.ts
Normal file
@ -0,0 +1,309 @@
|
|||||||
|
import { observable, action, computed, makeObservable, runInAction } from "mobx";
|
||||||
|
// types
|
||||||
|
import { RootStore } from "./root";
|
||||||
|
import { IProject, IIssueLabels, IProjectMember, IStateResponse, IState } from "types";
|
||||||
|
// services
|
||||||
|
import { ProjectServices } from "services/project.service";
|
||||||
|
import { ProjectIssuesServices } from "services/issues.service";
|
||||||
|
import { ProjectStateServices } from "services/state.service";
|
||||||
|
|
||||||
|
export interface IProjectStore {
|
||||||
|
loader: boolean;
|
||||||
|
error: any | null;
|
||||||
|
|
||||||
|
projectLeaveModal: boolean;
|
||||||
|
projectLeaveDetails: IProject | any;
|
||||||
|
|
||||||
|
projectId: string | null;
|
||||||
|
projects: {
|
||||||
|
[key: string]: { [key: string]: IProject }; // workspace_id: project_id: projects
|
||||||
|
} | null;
|
||||||
|
states: {
|
||||||
|
[key: string]: IStateResponse; // project_id: states
|
||||||
|
} | null;
|
||||||
|
labels: {
|
||||||
|
[key: string]: IIssueLabels[]; // project_id: labels
|
||||||
|
} | null;
|
||||||
|
members: {
|
||||||
|
[key: string]: IProjectMember[]; // project_id: members
|
||||||
|
} | null;
|
||||||
|
|
||||||
|
// computed
|
||||||
|
projectStatesByGroups: IStateResponse | null;
|
||||||
|
projectStates: IState[] | null;
|
||||||
|
projectLabels: IIssueLabels[] | null;
|
||||||
|
projectMembers: IProjectMember[] | null;
|
||||||
|
workspaceProjects: { [key: string]: IProject } | null;
|
||||||
|
|
||||||
|
// actions
|
||||||
|
projectStateById: (stateId: string) => IState | null;
|
||||||
|
projectLabelById: (labelId: string) => IIssueLabels | null;
|
||||||
|
projectMemberById: (memberId: string) => IProjectMember | null;
|
||||||
|
|
||||||
|
setProject: (projectSlug: string) => void;
|
||||||
|
|
||||||
|
getWorkspaceProjects: (workspaceSlug: string, is_favorite?: "all" | boolean) => Promise<void>;
|
||||||
|
getProjectStates: (workspaceSlug: string, projectSlug: string) => Promise<void>;
|
||||||
|
getProjectLabels: (workspaceSlug: string, projectSlug: string) => Promise<void>;
|
||||||
|
getProjectMembers: (workspaceSlug: string, projectSlug: string) => Promise<void>;
|
||||||
|
|
||||||
|
handleProjectLeaveModal: (project: IProject | null) => void;
|
||||||
|
|
||||||
|
leaveProject: (workspaceSlug: string, projectSlug: string, user: any) => Promise<void>;
|
||||||
|
}
|
||||||
|
|
||||||
|
class ProjectStore implements IProjectStore {
|
||||||
|
loader: boolean = false;
|
||||||
|
error: any | null = null;
|
||||||
|
|
||||||
|
projectLeaveModal: boolean = false;
|
||||||
|
projectLeaveDetails: IProject | null = null;
|
||||||
|
|
||||||
|
projectId: string | null = null;
|
||||||
|
projects: {
|
||||||
|
[key: string]: { [key: string]: IProject }; // workspace_id: project_id: projects
|
||||||
|
} | null = null;
|
||||||
|
states: {
|
||||||
|
[key: string]: IStateResponse; // project_id: states
|
||||||
|
} | null = null;
|
||||||
|
labels: {
|
||||||
|
[key: string]: IIssueLabels[]; // project_id: labels
|
||||||
|
} | null = null;
|
||||||
|
members: {
|
||||||
|
[key: string]: IProjectMember[]; // project_id: members
|
||||||
|
} | null = null;
|
||||||
|
|
||||||
|
// root store
|
||||||
|
rootStore;
|
||||||
|
// service
|
||||||
|
projectService;
|
||||||
|
issueService;
|
||||||
|
stateService;
|
||||||
|
|
||||||
|
constructor(_rootStore: RootStore) {
|
||||||
|
makeObservable(this, {
|
||||||
|
// observable
|
||||||
|
loader: observable,
|
||||||
|
error: observable,
|
||||||
|
|
||||||
|
projectId: observable.ref,
|
||||||
|
projects: observable.ref,
|
||||||
|
states: observable.ref,
|
||||||
|
labels: observable.ref,
|
||||||
|
members: observable.ref,
|
||||||
|
|
||||||
|
projectLeaveModal: observable,
|
||||||
|
projectLeaveDetails: observable.ref,
|
||||||
|
|
||||||
|
// computed
|
||||||
|
workspaceProjects: computed,
|
||||||
|
projectStatesByGroups: computed,
|
||||||
|
projectStates: computed,
|
||||||
|
projectLabels: computed,
|
||||||
|
projectMembers: computed,
|
||||||
|
|
||||||
|
// action
|
||||||
|
setProject: action,
|
||||||
|
|
||||||
|
projectStateById: action,
|
||||||
|
projectLabelById: action,
|
||||||
|
projectMemberById: action,
|
||||||
|
|
||||||
|
getWorkspaceProjects: action,
|
||||||
|
getProjectStates: action,
|
||||||
|
getProjectLabels: action,
|
||||||
|
getProjectMembers: action,
|
||||||
|
|
||||||
|
handleProjectLeaveModal: action,
|
||||||
|
leaveProject: action,
|
||||||
|
});
|
||||||
|
|
||||||
|
this.rootStore = _rootStore;
|
||||||
|
this.projectService = new ProjectServices();
|
||||||
|
this.issueService = new ProjectIssuesServices();
|
||||||
|
this.stateService = new ProjectStateServices();
|
||||||
|
}
|
||||||
|
|
||||||
|
// computed
|
||||||
|
get workspaceProjects() {
|
||||||
|
if (!this.rootStore.workspace.workspaceId) return null;
|
||||||
|
return this.projects?.[this.rootStore.workspace.workspaceId] || null;
|
||||||
|
}
|
||||||
|
get projectStatesByGroups() {
|
||||||
|
if (!this.projectId) return null;
|
||||||
|
return this.states?.[this.projectId] || null;
|
||||||
|
}
|
||||||
|
get projectStates() {
|
||||||
|
if (!this.projectId) return null;
|
||||||
|
const stateByGroups: IStateResponse | null = this.projectStatesByGroups;
|
||||||
|
if (!stateByGroups) return null;
|
||||||
|
const _states: IState[] = [];
|
||||||
|
Object.keys(stateByGroups).forEach((_stateGroup: string) => {
|
||||||
|
stateByGroups[_stateGroup].map((state) => {
|
||||||
|
_states.push(state);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
return _states && _states.length > 0 ? _states : null;
|
||||||
|
}
|
||||||
|
get projectLabels() {
|
||||||
|
if (!this.projectId) return null;
|
||||||
|
return this.labels?.[this.projectId] || null;
|
||||||
|
}
|
||||||
|
get projectMembers() {
|
||||||
|
if (!this.projectId) return null;
|
||||||
|
return this.members?.[this.projectId] || null;
|
||||||
|
}
|
||||||
|
|
||||||
|
// actions
|
||||||
|
projectStateById = (stateId: string) => {
|
||||||
|
if (!this.projectId) return null;
|
||||||
|
const states = this.projectStates;
|
||||||
|
if (!states) return null;
|
||||||
|
const stateInfo: IState | null = states.find((state) => state.id === stateId) || null;
|
||||||
|
return stateInfo;
|
||||||
|
};
|
||||||
|
projectLabelById = (labelId: string) => {
|
||||||
|
if (!this.projectId) return null;
|
||||||
|
const labels = this.projectLabels;
|
||||||
|
if (!labels) return null;
|
||||||
|
const labelInfo: IIssueLabels | null = labels.find((label) => label.id === labelId) || null;
|
||||||
|
return labelInfo;
|
||||||
|
};
|
||||||
|
projectMemberById = (memberId: string) => {
|
||||||
|
if (!this.projectId) return null;
|
||||||
|
const members = this.projectMembers;
|
||||||
|
if (!members) return null;
|
||||||
|
const memberInfo: IProjectMember | null = members.find((member) => member.id === memberId) || null;
|
||||||
|
return memberInfo;
|
||||||
|
};
|
||||||
|
|
||||||
|
setProject = (projectSlug: string) => {
|
||||||
|
this.projectId = projectSlug ?? null;
|
||||||
|
};
|
||||||
|
|
||||||
|
getWorkspaceProjects = async (workspaceSlug: string, is_favorite: "all" | boolean = "all") => {
|
||||||
|
try {
|
||||||
|
this.loader = true;
|
||||||
|
this.error = null;
|
||||||
|
|
||||||
|
const params: { is_favorite: "all" | boolean } = { is_favorite: is_favorite };
|
||||||
|
const projectsResponse = await this.projectService.getProjects(workspaceSlug, params);
|
||||||
|
|
||||||
|
let _projects: { [key: string]: IProject } = {};
|
||||||
|
projectsResponse.map((project) => {
|
||||||
|
_projects = { ..._projects, [project.id]: project };
|
||||||
|
});
|
||||||
|
|
||||||
|
runInAction(() => {
|
||||||
|
this.projects = {
|
||||||
|
...this.projects,
|
||||||
|
[workspaceSlug]: _projects,
|
||||||
|
};
|
||||||
|
this.loader = false;
|
||||||
|
this.error = null;
|
||||||
|
});
|
||||||
|
} catch (error) {
|
||||||
|
console.error(error);
|
||||||
|
this.loader = false;
|
||||||
|
this.error = error;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
getProjectStates = async (workspaceSlug: string, projectSlug: string) => {
|
||||||
|
try {
|
||||||
|
this.loader = true;
|
||||||
|
this.error = null;
|
||||||
|
|
||||||
|
const stateResponse = await this.stateService.getStates(workspaceSlug, projectSlug);
|
||||||
|
const _states = {
|
||||||
|
...this.states,
|
||||||
|
[projectSlug]: stateResponse,
|
||||||
|
};
|
||||||
|
|
||||||
|
runInAction(() => {
|
||||||
|
this.states = _states;
|
||||||
|
this.loader = false;
|
||||||
|
this.error = null;
|
||||||
|
});
|
||||||
|
} catch (error) {
|
||||||
|
console.error(error);
|
||||||
|
this.loader = false;
|
||||||
|
this.error = error;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
getProjectLabels = async (workspaceSlug: string, projectSlug: string) => {
|
||||||
|
try {
|
||||||
|
this.loader = true;
|
||||||
|
this.error = null;
|
||||||
|
|
||||||
|
const labelResponse = await this.issueService.getIssueLabels(workspaceSlug, projectSlug);
|
||||||
|
const _labels = {
|
||||||
|
...this.labels,
|
||||||
|
[projectSlug]: labelResponse,
|
||||||
|
};
|
||||||
|
|
||||||
|
runInAction(() => {
|
||||||
|
this.labels = _labels;
|
||||||
|
this.loader = false;
|
||||||
|
this.error = null;
|
||||||
|
});
|
||||||
|
} catch (error) {
|
||||||
|
console.error(error);
|
||||||
|
this.loader = false;
|
||||||
|
this.error = error;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
getProjectMembers = async (workspaceSlug: string, projectSlug: string) => {
|
||||||
|
try {
|
||||||
|
this.loader = true;
|
||||||
|
this.error = null;
|
||||||
|
|
||||||
|
const membersResponse = await this.projectService.projectMembers(workspaceSlug, projectSlug);
|
||||||
|
const _members = {
|
||||||
|
...this.members,
|
||||||
|
[projectSlug]: membersResponse,
|
||||||
|
};
|
||||||
|
|
||||||
|
runInAction(() => {
|
||||||
|
this.members = _members;
|
||||||
|
this.loader = false;
|
||||||
|
this.error = null;
|
||||||
|
});
|
||||||
|
} catch (error) {
|
||||||
|
console.error(error);
|
||||||
|
this.loader = false;
|
||||||
|
this.error = error;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
handleProjectLeaveModal = (project: IProject | null = null) => {
|
||||||
|
if (project && project?.id) {
|
||||||
|
this.projectLeaveModal = !this.projectLeaveModal;
|
||||||
|
this.projectLeaveDetails = project;
|
||||||
|
} else {
|
||||||
|
this.projectLeaveModal = !this.projectLeaveModal;
|
||||||
|
this.projectLeaveDetails = null;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
leaveProject = async (workspaceSlug: string, projectSlug: string, user: any) => {
|
||||||
|
try {
|
||||||
|
this.loader = true;
|
||||||
|
this.error = null;
|
||||||
|
|
||||||
|
const response = await this.projectService.leaveProject(workspaceSlug, projectSlug, user);
|
||||||
|
|
||||||
|
runInAction(() => {
|
||||||
|
this.loader = false;
|
||||||
|
this.error = null;
|
||||||
|
});
|
||||||
|
|
||||||
|
return response;
|
||||||
|
} catch (error) {
|
||||||
|
this.loader = false;
|
||||||
|
this.error = error;
|
||||||
|
return error;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
export default ProjectStore;
|
@ -3,15 +3,18 @@ import { enableStaticRendering } from "mobx-react-lite";
|
|||||||
// store imports
|
// store imports
|
||||||
import UserStore from "./user";
|
import UserStore from "./user";
|
||||||
import ThemeStore from "./theme";
|
import ThemeStore from "./theme";
|
||||||
import ProjectStore, { IProjectStore } from "./project";
|
|
||||||
import ProjectPublishStore, { IProjectPublishStore } from "./project-publish";
|
import ProjectPublishStore, { IProjectPublishStore } from "./project-publish";
|
||||||
import IssuesStore from "./issues";
|
import IssuesStore from "./issues";
|
||||||
// issues views and filters
|
|
||||||
import IssueWorkspace from "./issue-views/workspace";
|
import WorkspaceStore, { IWorkspaceStore } from "./workspaces";
|
||||||
import IssueProject from "./issue-views/project";
|
import ProjectStore, { IProjectStore } from "./projects";
|
||||||
import IssueFilterStore from "./issue-views/issue_filters";
|
import IssueStore, { IIssueStore } from "./issue-store";
|
||||||
import IssueViewStore from "./issue-views/Issues";
|
import ModuleStore, { IModuleStore } from "./modules";
|
||||||
import IssueViewDetailStore from "./issue-views/issue_detail";
|
import CycleStore, { ICycleStore } from "./cycles";
|
||||||
|
import ViewStore, { IViewStore } from "./views";
|
||||||
|
import IssueFilterStore, { IIssueFilterStore } from "./issue-filters";
|
||||||
|
|
||||||
|
import IssueViewDetailStore from "./issue_detail";
|
||||||
import IssueKanBanViewStore from "./issue-views/kanban-view";
|
import IssueKanBanViewStore from "./issue-views/kanban-view";
|
||||||
|
|
||||||
enableStaticRendering(typeof window === "undefined");
|
enableStaticRendering(typeof window === "undefined");
|
||||||
@ -19,28 +22,33 @@ enableStaticRendering(typeof window === "undefined");
|
|||||||
export class RootStore {
|
export class RootStore {
|
||||||
user;
|
user;
|
||||||
theme;
|
theme;
|
||||||
project: IProjectStore;
|
|
||||||
projectPublish: IProjectPublishStore;
|
projectPublish: IProjectPublishStore;
|
||||||
issues: IssuesStore;
|
issues: IssuesStore;
|
||||||
// issues views and filters
|
|
||||||
issueWorkspace: IssueWorkspace;
|
workspace: IWorkspaceStore;
|
||||||
issueProject: IssueProject;
|
project: IProjectStore;
|
||||||
issueFilters: IssueFilterStore;
|
issue: IIssueStore;
|
||||||
issueView: IssueViewStore;
|
module: IModuleStore;
|
||||||
|
cycle: ICycleStore;
|
||||||
|
view: IViewStore;
|
||||||
|
issueFilter: IIssueFilterStore;
|
||||||
issueDetail: IssueViewDetailStore;
|
issueDetail: IssueViewDetailStore;
|
||||||
issueKanBanView: IssueKanBanViewStore;
|
issueKanBanView: IssueKanBanViewStore;
|
||||||
|
|
||||||
constructor() {
|
constructor() {
|
||||||
this.user = new UserStore(this);
|
this.user = new UserStore(this);
|
||||||
this.theme = new ThemeStore(this);
|
this.theme = new ThemeStore(this);
|
||||||
this.project = new ProjectStore(this);
|
|
||||||
this.projectPublish = new ProjectPublishStore(this);
|
this.projectPublish = new ProjectPublishStore(this);
|
||||||
this.issues = new IssuesStore(this);
|
this.issues = new IssuesStore(this);
|
||||||
// issues views and filters
|
|
||||||
this.issueWorkspace = new IssueWorkspace(this);
|
this.workspace = new WorkspaceStore(this);
|
||||||
this.issueProject = new IssueProject(this);
|
this.project = new ProjectStore(this);
|
||||||
this.issueFilters = new IssueFilterStore(this);
|
this.issue = new IssueStore(this);
|
||||||
this.issueView = new IssueViewStore(this);
|
this.module = new ModuleStore(this);
|
||||||
|
this.cycle = new CycleStore(this);
|
||||||
|
this.view = new ViewStore(this);
|
||||||
|
this.issueFilter = new IssueFilterStore(this);
|
||||||
|
|
||||||
this.issueDetail = new IssueViewDetailStore(this);
|
this.issueDetail = new IssueViewDetailStore(this);
|
||||||
this.issueKanBanView = new IssueKanBanViewStore(this);
|
this.issueKanBanView = new IssueKanBanViewStore(this);
|
||||||
}
|
}
|
||||||
|
55
web/store/views.ts
Normal file
55
web/store/views.ts
Normal file
@ -0,0 +1,55 @@
|
|||||||
|
import { action, computed, observable, makeObservable, runInAction } from "mobx";
|
||||||
|
// types
|
||||||
|
import { RootStore } from "./root";
|
||||||
|
// services
|
||||||
|
import { ProjectServices } from "services/project.service";
|
||||||
|
import { ProjectIssuesServices as IssueServices } from "services/issues.service";
|
||||||
|
|
||||||
|
export interface IViewStore {
|
||||||
|
loader: boolean;
|
||||||
|
error: any | null;
|
||||||
|
|
||||||
|
viewId: string | null;
|
||||||
|
|
||||||
|
setViewId: (viewSlug: string) => void;
|
||||||
|
}
|
||||||
|
|
||||||
|
class ViewStore implements IViewStore {
|
||||||
|
loader: boolean = false;
|
||||||
|
error: any | null = null;
|
||||||
|
|
||||||
|
viewId: string | null = null;
|
||||||
|
|
||||||
|
// root store
|
||||||
|
rootStore;
|
||||||
|
// services
|
||||||
|
projectService;
|
||||||
|
issueService;
|
||||||
|
|
||||||
|
constructor(_rootStore: RootStore) {
|
||||||
|
makeObservable(this, {
|
||||||
|
loader: observable,
|
||||||
|
error: observable.ref,
|
||||||
|
|
||||||
|
viewId: observable.ref,
|
||||||
|
|
||||||
|
// computed
|
||||||
|
|
||||||
|
// actions
|
||||||
|
setViewId: action,
|
||||||
|
});
|
||||||
|
|
||||||
|
this.rootStore = _rootStore;
|
||||||
|
this.projectService = new ProjectServices();
|
||||||
|
this.issueService = new IssueServices();
|
||||||
|
}
|
||||||
|
|
||||||
|
// computed
|
||||||
|
|
||||||
|
// actions
|
||||||
|
setViewId = (viewSlug: string) => {
|
||||||
|
this.viewId = viewSlug ?? null;
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
export default ViewStore;
|
198
web/store/workspaces.ts
Normal file
198
web/store/workspaces.ts
Normal file
@ -0,0 +1,198 @@
|
|||||||
|
import { action, computed, observable, makeObservable, runInAction } from "mobx";
|
||||||
|
// types
|
||||||
|
import { RootStore } from "./root";
|
||||||
|
import { IIssueLabels, IWorkspace } from "types";
|
||||||
|
// services
|
||||||
|
import { WorkspaceService } from "services/workspace.service";
|
||||||
|
import { ProjectServices } from "services/project.service";
|
||||||
|
import { ProjectIssuesServices as IssueServices } from "services/issues.service";
|
||||||
|
|
||||||
|
export interface IWorkspaceStore {
|
||||||
|
loader: boolean;
|
||||||
|
error: any | null;
|
||||||
|
|
||||||
|
workspaces: {
|
||||||
|
[key: string]: IWorkspace; // workspace_id: workspace
|
||||||
|
} | null;
|
||||||
|
labels: { [key: string]: { [key: string]: IIssueLabels } } | null; // workspace_id: label_id: labels
|
||||||
|
workspaceId: string | null;
|
||||||
|
|
||||||
|
// computed
|
||||||
|
currentWorkspace: IWorkspace | null;
|
||||||
|
workspaceLabels: { [key: string]: IIssueLabels } | null;
|
||||||
|
|
||||||
|
// actions
|
||||||
|
setWorkspaceId: (workspaceSlug: string) => void;
|
||||||
|
|
||||||
|
workspaceById: (workspaceId: string) => IWorkspace | null;
|
||||||
|
workspaceLabelById: (labelId: string) => IIssueLabels | null;
|
||||||
|
|
||||||
|
getWorkspaces: () => Promise<void>;
|
||||||
|
getWorkspaceLabels: (workspaceSlug: string) => Promise<void>;
|
||||||
|
}
|
||||||
|
|
||||||
|
class WorkspaceStore implements IWorkspaceStore {
|
||||||
|
loader: boolean = false;
|
||||||
|
error: any | null = null;
|
||||||
|
|
||||||
|
workspaces: {
|
||||||
|
[key: string]: IWorkspace;
|
||||||
|
} | null = null;
|
||||||
|
labels: {
|
||||||
|
[key: string]: { [key: string]: IIssueLabels };
|
||||||
|
} | null = null;
|
||||||
|
workspaceId: string | null = null;
|
||||||
|
|
||||||
|
// root store
|
||||||
|
rootStore;
|
||||||
|
// services
|
||||||
|
workspaceService;
|
||||||
|
projectService;
|
||||||
|
issueService;
|
||||||
|
|
||||||
|
constructor(_rootStore: RootStore) {
|
||||||
|
makeObservable(this, {
|
||||||
|
loader: observable,
|
||||||
|
error: observable.ref,
|
||||||
|
|
||||||
|
workspaces: observable.ref,
|
||||||
|
labels: observable.ref,
|
||||||
|
workspaceId: observable.ref,
|
||||||
|
|
||||||
|
// computed
|
||||||
|
currentWorkspace: computed,
|
||||||
|
workspaceLabels: computed,
|
||||||
|
|
||||||
|
// actions
|
||||||
|
setWorkspaceId: action,
|
||||||
|
workspaceById: action,
|
||||||
|
workspaceLabelById: action,
|
||||||
|
|
||||||
|
getWorkspaces: action,
|
||||||
|
getWorkspaceLabels: action,
|
||||||
|
});
|
||||||
|
|
||||||
|
this.rootStore = _rootStore;
|
||||||
|
this.workspaceService = new WorkspaceService();
|
||||||
|
this.projectService = new ProjectServices();
|
||||||
|
this.issueService = new IssueServices();
|
||||||
|
}
|
||||||
|
|
||||||
|
// computed
|
||||||
|
get currentWorkspace() {
|
||||||
|
if (!this.workspaceId) return null;
|
||||||
|
return this.workspaces?.[this.workspaceId] || null;
|
||||||
|
}
|
||||||
|
get workspaceLabels() {
|
||||||
|
if (!this.workspaceId) return null;
|
||||||
|
const _labels = this.labels?.[this.workspaceId];
|
||||||
|
return _labels && Object.keys(_labels).length > 0 ? _labels : null;
|
||||||
|
}
|
||||||
|
|
||||||
|
// actions
|
||||||
|
workspaceById = (workspaceId: string) => this.workspaces?.[workspaceId] || null;
|
||||||
|
workspaceLabelById = (labelId: string) => {
|
||||||
|
if (!this.workspaceId) return null;
|
||||||
|
return this.labels?.[this.workspaceId]?.[labelId] || null;
|
||||||
|
};
|
||||||
|
|
||||||
|
setWorkspaceId = (workspaceSlug: string) => {
|
||||||
|
this.workspaceId = workspaceSlug ?? null;
|
||||||
|
};
|
||||||
|
|
||||||
|
getWorkspaces = async () => {
|
||||||
|
try {
|
||||||
|
this.loader = true;
|
||||||
|
this.error = null;
|
||||||
|
|
||||||
|
const workspaceResponse = await this.workspaceService.userWorkspaces();
|
||||||
|
|
||||||
|
let _workspaces: { [key: string]: IWorkspace } = {};
|
||||||
|
workspaceResponse.map((_workspace) => {
|
||||||
|
_workspaces = { ..._workspaces, [_workspace.slug]: _workspace };
|
||||||
|
});
|
||||||
|
|
||||||
|
runInAction(() => {
|
||||||
|
this.workspaces = _workspaces;
|
||||||
|
this.loader = false;
|
||||||
|
this.error = null;
|
||||||
|
});
|
||||||
|
} catch (error) {
|
||||||
|
console.log(error);
|
||||||
|
this.loader = false;
|
||||||
|
this.error = error;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
getWorkspaceLabels = async (workspaceSlug: string) => {
|
||||||
|
try {
|
||||||
|
this.loader = true;
|
||||||
|
this.error = null;
|
||||||
|
|
||||||
|
const labelsResponse = await this.issueService.getWorkspaceLabels(workspaceSlug);
|
||||||
|
let _labels: { [key: string]: IIssueLabels } = {};
|
||||||
|
labelsResponse.map((_label) => {
|
||||||
|
_labels = { ..._labels, [_label.id]: _label };
|
||||||
|
});
|
||||||
|
|
||||||
|
runInAction(() => {
|
||||||
|
this.labels = {
|
||||||
|
...this.labels,
|
||||||
|
[workspaceSlug]: _labels,
|
||||||
|
};
|
||||||
|
this.loader = false;
|
||||||
|
this.error = null;
|
||||||
|
});
|
||||||
|
} catch (error) {
|
||||||
|
console.log(error);
|
||||||
|
this.loader = false;
|
||||||
|
this.error = error;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
// getMyIssuesAsync = async (workspaceId: string, fetchFilterToggle: boolean = true) => {
|
||||||
|
// try {
|
||||||
|
// this.loader = true;
|
||||||
|
// this.error = null;
|
||||||
|
|
||||||
|
// if (fetchFilterToggle) await this.rootStore.issueFilters.getWorkspaceMyIssuesFilters(workspaceId);
|
||||||
|
// const filteredParams = this.rootStore.issueFilters.getComputedFilters(
|
||||||
|
// workspaceId,
|
||||||
|
// null,
|
||||||
|
// null,
|
||||||
|
// null,
|
||||||
|
// null,
|
||||||
|
// "my_issues"
|
||||||
|
// );
|
||||||
|
// const issuesResponse = await this.userService.userIssues(workspaceId, filteredParams);
|
||||||
|
|
||||||
|
// if (issuesResponse) {
|
||||||
|
// const _issueResponse: any = {
|
||||||
|
// ...this.issues,
|
||||||
|
// [workspaceId]: {
|
||||||
|
// ...this?.issues[workspaceId],
|
||||||
|
// my_issues: {
|
||||||
|
// ...this?.issues[workspaceId]?.my_issues,
|
||||||
|
// [this.rootStore?.issueFilters?.userFilters?.display_filters?.layout as string]: issuesResponse,
|
||||||
|
// },
|
||||||
|
// },
|
||||||
|
// };
|
||||||
|
|
||||||
|
// runInAction(() => {
|
||||||
|
// this.issues = _issueResponse;
|
||||||
|
// this.loader = false;
|
||||||
|
// this.error = null;
|
||||||
|
// });
|
||||||
|
// }
|
||||||
|
|
||||||
|
// return issuesResponse;
|
||||||
|
// } catch (error) {
|
||||||
|
// console.warn("error in fetching the my issues", error);
|
||||||
|
// this.loader = false;
|
||||||
|
// this.error = null;
|
||||||
|
// return error;
|
||||||
|
// }
|
||||||
|
// };
|
||||||
|
}
|
||||||
|
|
||||||
|
export default WorkspaceStore;
|
Loading…
Reference in New Issue
Block a user