fix issue mutation and count (#4804)

This commit is contained in:
rahulramesha 2024-06-13 16:55:42 +05:30 committed by GitHub
parent ab3a00dd6e
commit d75e33ccf0
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 35 additions and 35 deletions

View File

@ -137,30 +137,24 @@ export const getDifference = (
const DELETE = []; const DELETE = [];
// For all the current issues values that are not in the previous array, Add them to the ADD array // For all the current issues values that are not in the previous array, Add them to the ADD array
if (isEmpty(current)) ADD.push("None");
else {
for (const currentValue of current) { for (const currentValue of current) {
if (previous.includes(currentValue)) continue; if (previous.includes(currentValue)) continue;
ADD.push(currentValue); ADD.push(currentValue);
} }
}
// For all the previous issues values that are not in the current array, Add them to the ADD array // For all the previous issues values that are not in the current array, Add them to the ADD array
if (isEmpty(previous)) DELETE.push("None");
else {
for (const previousValue of previous) { for (const previousValue of previous) {
if (current.includes(previousValue)) continue; if (current.includes(previousValue)) continue;
DELETE.push(previousValue); DELETE.push(previousValue);
} }
}
// if there are no action provided, return the arrays // if there are no action provided, return the arrays
if (!action) return { [EIssueGroupedAction.ADD]: ADD, [EIssueGroupedAction.DELETE]: DELETE }; if (!action) return { [EIssueGroupedAction.ADD]: ADD, [EIssueGroupedAction.DELETE]: DELETE };
// If there is an action provided, return the values of both arrays under that array // If there is an action provided, return the values of both arrays under that array
if (action === EIssueGroupedAction.ADD) if (action === EIssueGroupedAction.ADD)
return { [EIssueGroupedAction.ADD]: uniq([...ADD, ...DELETE]), [EIssueGroupedAction.DELETE]: [] }; return { [EIssueGroupedAction.ADD]: uniq([...ADD]), [EIssueGroupedAction.DELETE]: [] };
else return { [EIssueGroupedAction.DELETE]: uniq([...ADD, ...DELETE]), [EIssueGroupedAction.ADD]: [] }; else return { [EIssueGroupedAction.DELETE]: uniq([...DELETE]), [EIssueGroupedAction.ADD]: [] };
}; };
/** /**

View File

@ -45,6 +45,7 @@ import {
getSubGroupIssueKeyActions, getSubGroupIssueKeyActions,
} from "./base-issues-utils"; } from "./base-issues-utils";
import { convertToISODateString } from "@/helpers/date-time.helper"; import { convertToISODateString } from "@/helpers/date-time.helper";
import isEmpty from "lodash/isEmpty";
export type TIssueDisplayFilterOptions = Exclude<TIssueGroupByOptions, null> | "target_date"; export type TIssueDisplayFilterOptions = Exclude<TIssueGroupByOptions, null> | "target_date";
@ -413,7 +414,7 @@ export abstract class BaseIssuesStore implements IBaseIssuesStore {
let subGroupCumulativeCount = 0; let subGroupCumulativeCount = 0;
for (const groupKey of groupIssuesKeys) { for (const groupKey of groupIssuesKeys) {
if (groupKey.includes(subGroupId)) subGroupCumulativeCount += this.groupedIssueCount[groupKey]; if (groupKey.includes(`_${subGroupId}`)) subGroupCumulativeCount += this.groupedIssueCount[groupKey];
} }
return subGroupCumulativeCount; return subGroupCumulativeCount;
@ -1130,7 +1131,7 @@ export abstract class BaseIssuesStore implements IBaseIssuesStore {
*/ */
removeIssueFromList(issueId: string) { removeIssueFromList(issueId: string) {
const issue = this.rootIssueStore.issues.getIssueById(issueId); const issue = this.rootIssueStore.issues.getIssueById(issueId);
this.updateIssueList(issue, undefined, EIssueGroupedAction.DELETE); this.updateIssueList(undefined, issue, EIssueGroupedAction.DELETE);
} }
/** /**
@ -1148,7 +1149,12 @@ export abstract class BaseIssuesStore implements IBaseIssuesStore {
issueBeforeUpdate?: TIssue, issueBeforeUpdate?: TIssue,
action?: EIssueGroupedAction.ADD | EIssueGroupedAction.DELETE action?: EIssueGroupedAction.ADD | EIssueGroupedAction.DELETE
) { ) {
if (!issue) return; if (!issue && !issueBeforeUpdate) return;
// get Issue ID from one of the issue objects
const issueId = issue?.id ?? issueBeforeUpdate?.id;
if (!issueId) return;
// get issueUpdates from another method by passing down the three arguments // get issueUpdates from another method by passing down the three arguments
// issueUpdates is nothing but an array of objects that contain the path of the issueId list that need updating and also the action that needs to be performed at the path // issueUpdates is nothing but an array of objects that contain the path of the issueId list that need updating and also the action that needs to be performed at the path
const issueUpdates = this.getUpdateDetails(issue, issueBeforeUpdate, action); const issueUpdates = this.getUpdateDetails(issue, issueBeforeUpdate, action);
@ -1160,7 +1166,7 @@ export abstract class BaseIssuesStore implements IBaseIssuesStore {
if (issueUpdate.action === EIssueGroupedAction.ADD) { if (issueUpdate.action === EIssueGroupedAction.ADD) {
// add issue Id at the path // add issue Id at the path
update(this, ["groupedIssueIds", ...issueUpdate.path], (issueIds: string[] = []) => { update(this, ["groupedIssueIds", ...issueUpdate.path], (issueIds: string[] = []) => {
return this.issuesSortWithOrderBy(uniq(concat(issueIds, issue.id)), this.orderBy); return this.issuesSortWithOrderBy(uniq(concat(issueIds, issueId)), this.orderBy);
}); });
} }
@ -1168,7 +1174,7 @@ export abstract class BaseIssuesStore implements IBaseIssuesStore {
if (issueUpdate.action === EIssueGroupedAction.DELETE) { if (issueUpdate.action === EIssueGroupedAction.DELETE) {
// remove issue Id from the path // remove issue Id from the path
update(this, ["groupedIssueIds", ...issueUpdate.path], (issueIds: string[] = []) => { update(this, ["groupedIssueIds", ...issueUpdate.path], (issueIds: string[] = []) => {
return pull(issueIds, issue.id); return pull(issueIds, issueId);
}); });
} }
@ -1455,7 +1461,7 @@ export abstract class BaseIssuesStore implements IBaseIssuesStore {
* @returns an array of object that contains the path at which issue to be updated and the action to be performed at the path * @returns an array of object that contains the path at which issue to be updated and the action to be performed at the path
*/ */
getUpdateDetails = ( getUpdateDetails = (
issue: Partial<TIssue>, issue?: Partial<TIssue>,
issueBeforeUpdate?: Partial<TIssue>, issueBeforeUpdate?: Partial<TIssue>,
action?: EIssueGroupedAction.ADD | EIssueGroupedAction.DELETE action?: EIssueGroupedAction.ADD | EIssueGroupedAction.DELETE
): { path: string[]; action: EIssueGroupedAction }[] => { ): { path: string[]; action: EIssueGroupedAction }[] => {
@ -1466,8 +1472,8 @@ export abstract class BaseIssuesStore implements IBaseIssuesStore {
// if grouped, the get the Difference between the two issue properties (this.issueGroupKey) on which groupBy is performed // if grouped, the get the Difference between the two issue properties (this.issueGroupKey) on which groupBy is performed
const groupActionsArray = getDifference( const groupActionsArray = getDifference(
this.getArrayStringArray(issue[this.issueGroupKey], this.groupBy), this.getArrayStringArray(issue, issue?.[this.issueGroupKey], this.groupBy),
this.getArrayStringArray(issueBeforeUpdate?.[this.issueGroupKey], this.groupBy), this.getArrayStringArray(issueBeforeUpdate, issueBeforeUpdate?.[this.issueGroupKey], this.groupBy),
action action
); );
@ -1483,8 +1489,8 @@ export abstract class BaseIssuesStore implements IBaseIssuesStore {
// if subGrouped, the get the Difference between the two issue properties (this.issueGroupKey) on which subGroupBy is performed // if subGrouped, the get the Difference between the two issue properties (this.issueGroupKey) on which subGroupBy is performed
const subGroupActionsArray = getDifference( const subGroupActionsArray = getDifference(
this.getArrayStringArray(issue[this.issueSubGroupKey], this.subGroupBy), this.getArrayStringArray(issue, issue?.[this.issueSubGroupKey], this.subGroupBy),
this.getArrayStringArray(issueBeforeUpdate?.[this.issueSubGroupKey], this.subGroupBy), this.getArrayStringArray(issueBeforeUpdate, issueBeforeUpdate?.[this.issueSubGroupKey], this.subGroupBy),
action action
); );
@ -1493,13 +1499,10 @@ export abstract class BaseIssuesStore implements IBaseIssuesStore {
...getSubGroupIssueKeyActions( ...getSubGroupIssueKeyActions(
groupActionsArray, groupActionsArray,
subGroupActionsArray, subGroupActionsArray,
this.getArrayStringArray(issueBeforeUpdate?.[this.issueGroupKey] ?? issue[this.issueGroupKey], this.groupBy), this.getArrayStringArray(issueBeforeUpdate, issueBeforeUpdate?.[this.issueGroupKey], this.groupBy),
this.getArrayStringArray(issue[this.issueGroupKey], this.groupBy), this.getArrayStringArray(issue, issue?.[this.issueGroupKey], this.groupBy),
this.getArrayStringArray( this.getArrayStringArray(issueBeforeUpdate, issueBeforeUpdate?.[this.issueSubGroupKey], this.subGroupBy),
issueBeforeUpdate?.[this.issueSubGroupKey] ?? issue[this.issueSubGroupKey], this.getArrayStringArray(issue, issue?.[this.issueSubGroupKey], this.subGroupBy)
this.subGroupBy
),
this.getArrayStringArray(issue[this.issueSubGroupKey], this.subGroupBy)
), ),
...orderByUpdates, ...orderByUpdates,
]; ];
@ -1529,7 +1532,7 @@ export abstract class BaseIssuesStore implements IBaseIssuesStore {
// if they are grouped then identify the paths based on props on which group by is dependent on // if they are grouped then identify the paths based on props on which group by is dependent on
const issueKeyActions: { path: string[]; action: EIssueGroupedAction.REORDER }[] = []; const issueKeyActions: { path: string[]; action: EIssueGroupedAction.REORDER }[] = [];
const groupByValues = this.getArrayStringArray(issue[this.issueGroupKey]); const groupByValues = this.getArrayStringArray(issue, issue[this.issueGroupKey]);
// if issues are not subGrouped then, provide path from groupByValues // if issues are not subGrouped then, provide path from groupByValues
if (!this.issueSubGroupKey) { if (!this.issueSubGroupKey) {
@ -1541,7 +1544,7 @@ export abstract class BaseIssuesStore implements IBaseIssuesStore {
} }
// if they are grouped then identify the paths based on props on which sub group by is dependent on // if they are grouped then identify the paths based on props on which sub group by is dependent on
const subGroupByValues = this.getArrayStringArray(issue[this.issueSubGroupKey]); const subGroupByValues = this.getArrayStringArray(issue, issue[this.issueSubGroupKey]);
// if issues are subGrouped then, provide path from subGroupByValues // if issues are subGrouped then, provide path from subGroupByValues
for (const groupKey of groupByValues) { for (const groupKey of groupByValues) {
@ -1560,11 +1563,14 @@ export abstract class BaseIssuesStore implements IBaseIssuesStore {
* @returns an array of issue property values * @returns an array of issue property values
*/ */
getArrayStringArray = ( getArrayStringArray = (
issueObject: Partial<TIssue> | undefined,
value: string | string[] | undefined | null, value: string | string[] | undefined | null,
groupByKey?: TIssueGroupByOptions | undefined groupByKey?: TIssueGroupByOptions | undefined
): string[] => { ): string[] => {
// if value is not defined, return empty array // if issue object is undefined return empty array
if (!value) return []; if (!issueObject) return [];
// if value is not defined, return None value in array
if (!value || isEmpty(value)) return ["None"];
// if array return the array // if array return the array
if (Array.isArray(value)) return value; if (Array.isArray(value)) return value;