Skip to content

Commit

Permalink
[WEB-383] fix: rendering state and members from different projects in…
Browse files Browse the repository at this point in the history
… sub-issues (#3996)

* fix: rendering the state and memebers from different projects in sub issues and exception handling while creating an issue from different project

* chore: handled different project issue properties in a new function handler
  • Loading branch information
gurusainath authored Mar 20, 2024
1 parent 4ea616f commit 621624e
Show file tree
Hide file tree
Showing 2 changed files with 46 additions and 4 deletions.
4 changes: 2 additions & 2 deletions web/components/issues/sub-issues/properties.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -72,8 +72,8 @@ export const IssueProperty: React.FC<IIssueProperty> = (props) => {
}
disabled={!disabled}
multiple
buttonVariant={issue.assignee_ids.length > 0 ? "transparent-without-text" : "border-without-text"}
buttonClassName={issue.assignee_ids.length > 0 ? "hover:bg-transparent px-0" : ""}
buttonVariant={(issue?.assignee_ids || []).length > 0 ? "transparent-without-text" : "border-without-text"}
buttonClassName={(issue?.assignee_ids || []).length > 0 ? "hover:bg-transparent px-0" : ""}
/>
</div>
</div>
Expand Down
46 changes: 44 additions & 2 deletions web/store/issue/issue-details/sub_issues.store.ts
Original file line number Diff line number Diff line change
@@ -1,10 +1,9 @@
import concat from "lodash/concat";
import pull from "lodash/pull";
import set from "lodash/set";
import uniq from "lodash/uniq";
import update from "lodash/update";
import { action, makeObservable, observable, runInAction } from "mobx";
// services
import { IssueService } from "@/services/issue";
// types
import {
TIssue,
Expand All @@ -13,6 +12,9 @@ import {
TIssueSubIssuesIdMap,
TSubIssuesStateDistribution,
} from "@plane/types";
// services
import { IssueService } from "@/services/issue";
// store
import { IIssueDetail } from "./root.store";

export interface IIssueSubIssuesStoreActions {
Expand Down Expand Up @@ -48,6 +50,7 @@ export interface IIssueSubIssuesStore extends IIssueSubIssuesStoreActions {
subIssuesByIssueId: (issueId: string) => string[] | undefined;
subIssueHelpersByIssueId: (issueId: string) => TSubIssueHelpers;
// actions
fetchOtherProjectProperties: (workspaceSlug: string, projectIds: string[]) => Promise<void>;
setSubIssueHelpers: (parentIssueId: string, key: TSubIssueHelpersKeys, value: string) => void;
}

Expand All @@ -74,6 +77,7 @@ export class IssueSubIssuesStore implements IIssueSubIssuesStore {
updateSubIssue: action,
removeSubIssue: action,
deleteSubIssue: action,
fetchOtherProjectProperties: action,
});
// root store
this.rootIssueDetailStore = rootStore;
Expand Down Expand Up @@ -116,6 +120,12 @@ export class IssueSubIssuesStore implements IIssueSubIssuesStore {

this.rootIssueDetailStore.rootIssueStore.issues.addIssue(subIssues);

// fetch other issues states and members when sub-issues are from different project
if (subIssues && subIssues.length > 0) {
const otherProjectIds = uniq(subIssues.map((issue) => issue.project_id).filter((id) => id !== projectId));
this.fetchOtherProjectProperties(workspaceSlug, otherProjectIds);
}

runInAction(() => {
set(this.subIssuesStateDistribution, parentIssueId, subIssuesStateDistribution);
set(
Expand All @@ -140,6 +150,12 @@ export class IssueSubIssuesStore implements IIssueSubIssuesStore {
const subIssuesStateDistribution = response?.state_distribution;
const subIssues = response.sub_issues as TIssue[];

// fetch other issues states and members when sub-issues are from different project
if (subIssues && subIssues.length > 0) {
const otherProjectIds = uniq(subIssues.map((issue) => issue.project_id).filter((id) => id !== projectId));
this.fetchOtherProjectProperties(workspaceSlug, otherProjectIds);
}

runInAction(() => {
Object.keys(subIssuesStateDistribution).forEach((key) => {
const stateGroup = key as keyof TSubIssuesStateDistribution;
Expand Down Expand Up @@ -292,4 +308,30 @@ export class IssueSubIssuesStore implements IIssueSubIssuesStore {
throw error;
}
};

fetchOtherProjectProperties = async (workspaceSlug: string, projectIds: string[]) => {
try {
if (projectIds.length > 0) {
for (const projectId of projectIds) {
// fetching other project states
this.rootIssueDetailStore.rootIssueStore.rootStore.state.fetchProjectStates(workspaceSlug, projectId);
// fetching other project members
this.rootIssueDetailStore.rootIssueStore.rootStore.memberRoot.project.fetchProjectMembers(
workspaceSlug,
projectId
);
// fetching other project labels
this.rootIssueDetailStore.rootIssueStore.rootStore.label.fetchProjectLabels(workspaceSlug, projectId);
// fetching other project cycles
this.rootIssueDetailStore.rootIssueStore.rootStore.cycle.fetchAllCycles(workspaceSlug, projectId);
// fetching other project modules
this.rootIssueDetailStore.rootIssueStore.rootStore.module.fetchModules(workspaceSlug, projectId);
// fetching other project estimates
this.rootIssueDetailStore.rootIssueStore.rootStore.estimate.fetchProjectEstimates(workspaceSlug, projectId);
}
}
} catch (error) {
throw error;
}
};
}

0 comments on commit 621624e

Please sign in to comment.