* use common getIssues from issue service instead of multiple different services for modules and cycles * Use SQLite to store issues locally and load issues from it. * Fix incorrect total count and filtering on assignees. * enable parallel API calls * use common getIssues from issue service instead of multiple different services for modules and cycles * Use SQLite to store issues locally and load issues from it. * Fix incorrect total count and filtering on assignees. * enable parallel API calls * chore: deleted issue list * - Handle local mutations - Implement getting the updates - Use SWR to update/sync data * Wait for sync to complete in get issues * Fix build errors * Fix build issue * - Sync updates to local-db - Fallback to server when the local data is loading - Wait when the updates are being fetched * Add issues in batches * Disable skeleton loaders for first 10 issues * Load issues in bulk * working version of sql lite with grouped issues * Use window queries for group by * - Fix sort by date fields - Fix the total count * - Fix grouping by created by - Fix order by and limit * fix pagination * Fix sorting on issue priority * - Add secondary sort order - Fix group by priority * chore: added timestamp filter for deleted issues * - Extract local DB into its own class - Implement sorting by label names * Implement subgroup by * sub group by changes * Refactor query constructor * Insert or update issues instead of directly adding them. * Segregated queries. Not working though!! * - Get filtered issues and then group them. - Cleanup code. - Implement order by labels. * Fix build issues * Remove debuggers * remove loaders while changing sorting or applying filters * fix loader while clearing all filters * Fix issue with project being synced twice * Improve project sync * Optimize the queries * Make create dummy data more realistic * dev: added total pages in the global paginator * chore: updated total_paged count * chore: added state_group in the issues pagination * chore: removed deleted_at from the issue pagination payload * chore: replaced state_group with state__group * Integrate new getIssues API, and fix sync issues bug. * Fix issue with SWR running twice in workspace wrapper * Fix DB initialization called when opening project for the first time. * Add all the tables required for sorting * Exclude description from getIssues * Add getIssue function. * Add only selected fields to get query. * Fix the count query * Minor query optimization when no joins are required. * fetch issue description from local db * clear local db on signout * Correct dummy data creation * Fix sort by assignee * sync to local changes * chore: added archived issues in the deleted endpoint * Sync deletes to local db. * - Add missing indexes for tables used in sorting in spreadsheet layout. - Add options table * Make fallback optional in getOption * Kanban column virtualization * persist project sync readiness to sqlite and use that as the source of truth for the project issues to be ready * fix build errors * Fix calendar view * fetch slimed down version of modules in project wrapper * fetch toned down modules and then fetch complete modules * Fix multi value order by in spread sheet layout * Fix sort by * Fix the query when ordering by multi field names * Remove unused import * Fix sort by multi value fields * Format queries and fix order by * fix order by for multi issue * fix loaders for spreadsheet * Fallback to manual order whn moving away from spreadsheet layout * fix minor bug * Move fix for order_by when switching from spreadsheet layout to translateQueryParams * fix default rendering of kanban groups * Fix none priority being saved as null * Remove debugger statement * Fix issue load * chore: updated isue paginated query from to * Fix sub issues and start and target date filters * Fix active and backlog filter * Add default order by * Update the Query param to match with backend. * local sqlite db versioning * When window is hidden, do not perform any db versioning * fix error handling and fall back to server when database errors out * Add ability to disable local db cache * remove db version check from getIssues function * change db version to number and remove workspaceInitPromise in storage.sqlite * - Sync the entire workspace in the background - Add get sub issue method with distribution * Make changes to get issues for sync to match backend. * chore: handled workspace and project in v2 paginted issues * disable issue description and title until fetched from server * sync issues post bulk operations * fix server error * fix front end build * Remove full workspace sync * - Remove the toast message on sync. - Update the disable local message. * Add Hardcoded constant to disable the local db caching * fix lint errors * Fix order by in grouping * update yarn lock * fix build * fix plane-web imports * address review comments --------- Co-authored-by: rahulramesha <rahulramesham@gmail.com> Co-authored-by: NarayanBavisetti <narayan3119@gmail.com> Co-authored-by: gurusainath <gurusainath007@gmail.com>
134 lines
3.8 KiB
TypeScript
134 lines
3.8 KiB
TypeScript
import pick from "lodash/pick";
|
|
import { TIssue } from "@plane/types";
|
|
import { rootStore } from "@/lib/store-context";
|
|
import { updateIssue } from "./load-issues";
|
|
|
|
export const log = console.log;
|
|
|
|
// export const log = () => {};
|
|
|
|
export const updatePersistentLayer = async (issueIds: string | string[]) => {
|
|
if (typeof issueIds === "string") {
|
|
issueIds = [issueIds];
|
|
}
|
|
issueIds.forEach((issueId) => {
|
|
const issue = rootStore.issue.issues.getIssueById(issueId);
|
|
|
|
if (issue) {
|
|
const issuePartial = pick(JSON.parse(JSON.stringify(issue)), [
|
|
"id",
|
|
"name",
|
|
"state_id",
|
|
"sort_order",
|
|
"completed_at",
|
|
"estimate_point",
|
|
"priority",
|
|
"start_date",
|
|
"target_date",
|
|
"sequence_id",
|
|
"project_id",
|
|
"parent_id",
|
|
"created_at",
|
|
"updated_at",
|
|
"created_by",
|
|
"updated_by",
|
|
"is_draft",
|
|
"archived_at",
|
|
"state__group",
|
|
"cycle_id",
|
|
"link_count",
|
|
"attachment_count",
|
|
"sub_issues_count",
|
|
"assignee_ids",
|
|
"label_ids",
|
|
"module_ids",
|
|
"type_id",
|
|
]);
|
|
updateIssue(issuePartial);
|
|
}
|
|
});
|
|
};
|
|
|
|
export const wrapDateTime = (field: string) => {
|
|
const DATE_TIME_FIELDS = ["created_at", "updated_at", "completed_at", "start_date", "target_date"];
|
|
|
|
if (DATE_TIME_FIELDS.includes(field)) {
|
|
return `datetime(${field})`;
|
|
}
|
|
return field;
|
|
};
|
|
|
|
export const getGroupedIssueResults = (issueResults: (TIssue & { group_id: string; total_issues: number })[]): any => {
|
|
const groupedResults: {
|
|
[key: string]: {
|
|
results: TIssue[];
|
|
total_results: number;
|
|
};
|
|
} = {};
|
|
|
|
for (const issue of issueResults) {
|
|
const { group_id, total_issues } = issue;
|
|
const groupId = group_id ? group_id : "None";
|
|
if (groupedResults?.[groupId] !== undefined && Array.isArray(groupedResults?.[groupId]?.results)) {
|
|
groupedResults?.[groupId]?.results.push(issue);
|
|
} else {
|
|
groupedResults[groupId] = { results: [issue], total_results: total_issues };
|
|
}
|
|
}
|
|
|
|
return groupedResults;
|
|
};
|
|
|
|
export const getSubGroupedIssueResults = (
|
|
issueResults: (TIssue & { group_id: string; total_issues: number; sub_group_id: string })[]
|
|
): any => {
|
|
const subGroupedResults: {
|
|
[key: string]: {
|
|
results: {
|
|
[key: string]: {
|
|
results: TIssue[];
|
|
total_results: number;
|
|
};
|
|
};
|
|
total_results: number;
|
|
};
|
|
} = {};
|
|
|
|
for (const issue of issueResults) {
|
|
const { group_id, total_issues, sub_group_id } = issue;
|
|
const groupId = group_id ? group_id : "None";
|
|
const subGroupId = sub_group_id ? sub_group_id : "None";
|
|
|
|
if (subGroupedResults?.[groupId] === undefined) {
|
|
subGroupedResults[groupId] = { results: {}, total_results: 0 };
|
|
}
|
|
|
|
if (
|
|
subGroupedResults[groupId].results[subGroupId] !== undefined &&
|
|
Array.isArray(subGroupedResults[groupId].results[subGroupId]?.results)
|
|
) {
|
|
subGroupedResults[groupId].results[subGroupId]?.results.push(issue);
|
|
} else {
|
|
subGroupedResults[groupId].results[subGroupId] = { results: [issue], total_results: total_issues };
|
|
}
|
|
}
|
|
|
|
const groupByKeys = Object.keys(subGroupedResults);
|
|
|
|
for (const groupByKey of groupByKeys) {
|
|
let totalIssues = 0;
|
|
const groupedResults = subGroupedResults[groupByKey]?.results ?? {};
|
|
const subGroupByKeys = Object.keys(groupedResults);
|
|
|
|
for (const subGroupByKey of subGroupByKeys) {
|
|
const subGroupedResultsCount = groupedResults[subGroupByKey].total_results ?? 0;
|
|
totalIssues += subGroupedResultsCount;
|
|
}
|
|
|
|
subGroupedResults[groupByKey].total_results = totalIssues;
|
|
}
|
|
|
|
return subGroupedResults;
|
|
};
|
|
|
|
export const delay = (ms: number) => new Promise((resolve) => setTimeout(resolve, ms));
|