Merge branch 'feat/pagination' of github.com:makeplane/plane into feat/pagination

This commit is contained in:
pablohashescobar 2024-03-22 20:59:02 +05:30
commit 6491b40e04

View File

@ -34,12 +34,14 @@ import { IssueArchiveService, IssueDraftService, IssueService } from "services/i
import set from "lodash/set"; import set from "lodash/set";
import { get } from "lodash"; import { get } from "lodash";
import { computedFn } from "mobx-utils"; import { computedFn } from "mobx-utils";
import isEqual from "date-fns/isEqual";
export type TIssueDisplayFilterOptions = Exclude<TIssueGroupByOptions, null> | "target_date"; export type TIssueDisplayFilterOptions = Exclude<TIssueGroupByOptions, null> | "target_date";
export enum EIssueGroupedAction { export enum EIssueGroupedAction {
ADD, ADD,
DELETE, DELETE,
REORDER,
} }
export const ALL_ISSUES = "All Issues"; export const ALL_ISSUES = "All Issues";
@ -79,6 +81,38 @@ const ISSUE_FILTER_DEFAULT_DATA: Record<TIssueDisplayFilterOptions, keyof TIssue
module: "module_ids", module: "module_ids",
}; };
const ISSUE_ORDERBY_KEY: Record<TIssueOrderByOptions, keyof TIssue> = {
created_at: "created_at",
"-created_at": "created_at",
updated_at: "updated_at",
"-updated_at": "updated_at",
priority: "priority",
"-priority": "priority",
sort_order: "sort_order",
state__name: "state_id",
"-state__name": "state_id",
assignees__first_name: "assignee_ids",
"-assignees__first_name": "assignee_ids",
labels__name: "label_ids",
"-labels__name": "label_ids",
modules__name: "module_ids",
"-modules__name": "module_ids",
cycle__name: "cycle_id",
"-cycle__name": "cycle_id",
target_date: "target_date",
"-target_date": "target_date",
estimate_point: "estimate_point",
"-estimate_point": "estimate_point",
start_date: "start_date",
"-start_date": "start_date",
link_count: "link_count",
"-link_count": "link_count",
attachment_count: "attachment_count",
"-attachment_count": "attachment_count",
sub_issues_count: "sub_issues_count",
"-sub_issues_count": "sub_issues_count",
};
export class BaseIssuesStore implements IBaseIssuesStore { export class BaseIssuesStore implements IBaseIssuesStore {
loader: TLoader = "init-loader"; loader: TLoader = "init-loader";
groupedIssueIds: TIssues | undefined = undefined; groupedIssueIds: TIssues | undefined = undefined;
@ -164,6 +198,13 @@ export class BaseIssuesStore implements IBaseIssuesStore {
return displayFilters?.layout === "kanban" ? displayFilters?.sub_group_by : undefined; return displayFilters?.layout === "kanban" ? displayFilters?.sub_group_by : undefined;
} }
get orderByKey() {
const orderBy = this.orderBy;
if (!orderBy) return;
return ISSUE_ORDERBY_KEY[orderBy];
}
get issueGroupKey() { get issueGroupKey() {
const groupBy = this.groupBy; const groupBy = this.groupBy;
@ -427,6 +468,13 @@ export class BaseIssuesStore implements IBaseIssuesStore {
}); });
this.updateIssueCount(issueUpdate.path, -1); this.updateIssueCount(issueUpdate.path, -1);
} }
//if update is reorder, reorder it at a particular path
if (issueUpdate.action === EIssueGroupedAction.REORDER) {
update(this, ["groupedIssueIds", ...issueUpdate.path], (issueIds: string[] = []) => {
return this.issuesSortWithOrderBy(issueIds, this.orderBy);
});
}
} }
}); });
} }
@ -459,7 +507,9 @@ export class BaseIssuesStore implements IBaseIssuesStore {
issueBeforeUpdate?: Partial<TIssue>, issueBeforeUpdate?: Partial<TIssue>,
action?: EIssueGroupedAction action?: EIssueGroupedAction
): { path: string[]; action: EIssueGroupedAction }[] => { ): { path: string[]; action: EIssueGroupedAction }[] => {
if (!this.issueGroupKey || !issue) return action ? [{ path: [ALL_ISSUES], action }] : []; const orderByUpdates = this.getOrderByUpdateDetails(issue, issueBeforeUpdate);
if (!this.issueGroupKey || !issue)
return action ? [{ path: [ALL_ISSUES], action }, ...orderByUpdates] : orderByUpdates;
const groupActionsArray = this.getDifference( const groupActionsArray = this.getDifference(
this.getArrayStringArray(issue[this.issueGroupKey], this.groupBy), this.getArrayStringArray(issue[this.issueGroupKey], this.groupBy),
@ -467,32 +517,71 @@ export class BaseIssuesStore implements IBaseIssuesStore {
); );
if (!this.issueSubGroupKey) if (!this.issueSubGroupKey)
return this.getGroupIssueKeyActions( return [
groupActionsArray[EIssueGroupedAction.ADD], ...this.getGroupIssueKeyActions(
groupActionsArray[EIssueGroupedAction.DELETE] groupActionsArray[EIssueGroupedAction.ADD],
); groupActionsArray[EIssueGroupedAction.DELETE]
),
...orderByUpdates,
];
const subGroupActionsArray = this.getDifference( const subGroupActionsArray = this.getDifference(
this.getArrayStringArray(issue[this.issueSubGroupKey], this.subGroupBy), this.getArrayStringArray(issue[this.issueSubGroupKey], this.subGroupBy),
this.getArrayStringArray(issueBeforeUpdate?.[this.issueSubGroupKey], this.subGroupBy) this.getArrayStringArray(issueBeforeUpdate?.[this.issueSubGroupKey], this.subGroupBy)
); );
return this.getSubGroupIssueKeyActions( return [
groupActionsArray, ...this.getSubGroupIssueKeyActions(
subGroupActionsArray, groupActionsArray,
this.getArrayStringArray(issueBeforeUpdate?.[this.issueGroupKey] ?? issue[this.issueGroupKey], this.groupBy), subGroupActionsArray,
this.getArrayStringArray(issue[this.issueGroupKey], this.groupBy), this.getArrayStringArray(issueBeforeUpdate?.[this.issueGroupKey] ?? issue[this.issueGroupKey], this.groupBy),
this.getArrayStringArray( this.getArrayStringArray(issue[this.issueGroupKey], this.groupBy),
issueBeforeUpdate?.[this.issueSubGroupKey] ?? issue[this.issueSubGroupKey], this.getArrayStringArray(
this.subGroupBy issueBeforeUpdate?.[this.issueSubGroupKey] ?? issue[this.issueSubGroupKey],
this.subGroupBy
),
this.getArrayStringArray(issue[this.issueSubGroupKey], this.subGroupBy)
), ),
this.getArrayStringArray(issue[this.issueSubGroupKey], this.subGroupBy) ...orderByUpdates,
); ];
}; };
getOrderByUpdateDetails(issue: Partial<TIssue> | undefined, issueBeforeUpdate: Partial<TIssue> | undefined) {
if (
!issue ||
!issueBeforeUpdate ||
!this.orderByKey ||
isEqual(issue[this.orderByKey], issueBeforeUpdate[this.orderByKey])
)
return [];
if (!this.issueGroupKey) return [{ path: [ALL_ISSUES], action: EIssueGroupedAction.REORDER }];
const issueKeyActions = [];
const groupByValues = this.getArrayStringArray(issue[this.issueGroupKey]);
if (!this.issueSubGroupKey) {
for (const groupKey of groupByValues) {
issueKeyActions.push({ path: [groupKey], action: EIssueGroupedAction.REORDER });
}
return issueKeyActions;
}
const subGroupByValues = this.getArrayStringArray(issue[this.issueSubGroupKey]);
for (const groupKey of groupByValues) {
for (const subGroupKey of subGroupByValues) {
issueKeyActions.push({ path: [groupKey, subGroupKey], action: EIssueGroupedAction.REORDER });
}
}
return issueKeyActions;
}
getArrayStringArray = ( getArrayStringArray = (
value: string | string[] | undefined | null, value: string | string[] | undefined | null,
groupByKey: TIssueGroupByOptions | undefined groupByKey?: TIssueGroupByOptions | undefined
): string[] => { ): string[] => {
if (!value) return []; if (!value) return [];
if (Array.isArray(value)) return value; if (Array.isArray(value)) return value;