mirror of
https://github.com/sartography/spiff-arena.git
synced 2025-01-11 10:06:09 +00:00
removed conditional to not load useEffect on process instance list table page so page changes and switching tabs works w/ burnettk
This commit is contained in:
parent
52d1df5c0f
commit
0bda287c81
@ -162,9 +162,6 @@ export default function ProcessInstanceListTable({
|
||||
const [requiresRefilter, setRequiresRefilter] = useState<boolean>(false);
|
||||
const [lastColumnFilter, setLastColumnFilter] = useState<string>('');
|
||||
|
||||
const [listHasBeenFiltered, setListHasBeenFiltered] =
|
||||
useState<boolean>(false);
|
||||
|
||||
const preferredUsername = UserService.getPreferredUsername();
|
||||
const userEmail = UserService.getUserEmail();
|
||||
|
||||
@ -223,6 +220,9 @@ export default function ProcessInstanceListTable({
|
||||
];
|
||||
}, []);
|
||||
|
||||
// this is used from pages like the home page that have multiple tables
|
||||
// and cannot store the report hash in the query params.
|
||||
// it can be used to create a link to the process instances list page to reconstruct the report.
|
||||
const [reportHash, setReportHash] = useState<string | null>(null);
|
||||
|
||||
const [
|
||||
@ -321,14 +321,35 @@ export default function ProcessInstanceListTable({
|
||||
// so use a variable instead
|
||||
const processModelSelectionItemsForUseEffect = useRef<ProcessModel[]>([]);
|
||||
|
||||
const clearFilters = useCallback((updateRequiresRefilter: boolean = true) => {
|
||||
setProcessModelSelection(null);
|
||||
setProcessStatusSelection([]);
|
||||
setStartFromDate('');
|
||||
setStartFromTime('');
|
||||
setStartToDate('');
|
||||
setStartToTime('');
|
||||
setEndFromDate('');
|
||||
setEndFromTime('');
|
||||
setEndToDate('');
|
||||
setEndToTime('');
|
||||
setProcessInitiatorSelection(null);
|
||||
setWithOldestOpenTask(false);
|
||||
setSystemReport(null);
|
||||
setSelectedUserGroup(null);
|
||||
if (updateRequiresRefilter) {
|
||||
setRequiresRefilter(true);
|
||||
}
|
||||
if (reportMetadata) {
|
||||
reportMetadata.filter_by = [];
|
||||
}
|
||||
// eslint-disable-next-line react-hooks/exhaustive-deps
|
||||
}, []);
|
||||
|
||||
const getProcessInstances = useCallback(
|
||||
(
|
||||
processInstanceReport: ProcessInstanceReport | null = null
|
||||
// eslint-disable-next-line sonarjs/cognitive-complexity
|
||||
) => {
|
||||
if (listHasBeenFiltered) {
|
||||
return;
|
||||
}
|
||||
let reportMetadataBodyToUse: ReportMetadata = {
|
||||
columns: [],
|
||||
filter_by: [],
|
||||
@ -341,6 +362,11 @@ export default function ProcessInstanceListTable({
|
||||
}
|
||||
}
|
||||
|
||||
// a bit hacky, clear out all filters before setting them from report metadata
|
||||
// to ensure old filters are cleared out.
|
||||
// this is really for going between the 'For Me' and 'All' tabs.
|
||||
clearFilters(false);
|
||||
|
||||
// this is the code to re-populate the widgets on the page
|
||||
// with values from the report metadata, which is derived
|
||||
// from the searchParams (often report_hash)
|
||||
@ -433,7 +459,6 @@ export default function ProcessInstanceListTable({
|
||||
additionalReportFilters,
|
||||
dateParametersToAlwaysFilterBy,
|
||||
filtersEnabled,
|
||||
listHasBeenFiltered,
|
||||
paginationQueryParamPrefix,
|
||||
perPageOptions,
|
||||
processInstanceApiSearchPath,
|
||||
@ -441,6 +466,7 @@ export default function ProcessInstanceListTable({
|
||||
setProcessInstancesFromResult,
|
||||
stopRefreshing,
|
||||
systemReportOptions,
|
||||
clearFilters,
|
||||
]
|
||||
);
|
||||
|
||||
@ -448,11 +474,7 @@ export default function ProcessInstanceListTable({
|
||||
if (!permissionsLoaded) {
|
||||
return undefined;
|
||||
}
|
||||
|
||||
function getReportMetadataWithReportHash() {
|
||||
if (listHasBeenFiltered) {
|
||||
return;
|
||||
}
|
||||
const queryParams: string[] = [];
|
||||
['report_hash', 'report_id'].forEach((paramName: string) => {
|
||||
if (searchParams.get(paramName)) {
|
||||
@ -517,7 +539,6 @@ export default function ProcessInstanceListTable({
|
||||
autoReload,
|
||||
filtersEnabled,
|
||||
getProcessInstances,
|
||||
listHasBeenFiltered,
|
||||
permissionsLoaded,
|
||||
reportIdentifier,
|
||||
searchParams,
|
||||
@ -632,17 +653,34 @@ export default function ProcessInstanceListTable({
|
||||
reportMetadataToUse.filter_by = filtersToKeep;
|
||||
};
|
||||
|
||||
const getFilterByFromReportMetadata = (reportColumnAccessor: string) => {
|
||||
if (reportMetadata) {
|
||||
return reportMetadata.filter_by.find((reportFilter: ReportFilter) => {
|
||||
return reportColumnAccessor === reportFilter.field_name;
|
||||
});
|
||||
}
|
||||
return null;
|
||||
};
|
||||
|
||||
const insertOrUpdateFieldInReportMetadata = (
|
||||
reportMetadataToUse: ReportMetadata,
|
||||
fieldName: string,
|
||||
fieldValue: any
|
||||
) => {
|
||||
removeFieldFromReportMetadata(reportMetadataToUse, fieldName);
|
||||
if (fieldValue) {
|
||||
reportMetadataToUse.filter_by.push({
|
||||
field_name: fieldName,
|
||||
field_value: fieldValue,
|
||||
});
|
||||
let existingReportFilter = getFilterByFromReportMetadata(fieldName);
|
||||
if (existingReportFilter) {
|
||||
existingReportFilter.field_value = fieldValue;
|
||||
} else {
|
||||
existingReportFilter = {
|
||||
field_name: fieldName,
|
||||
field_value: fieldValue,
|
||||
operator: 'equals',
|
||||
};
|
||||
reportMetadataToUse.filter_by.push(existingReportFilter);
|
||||
}
|
||||
} else {
|
||||
removeFieldFromReportMetadata(reportMetadataToUse, fieldName);
|
||||
}
|
||||
};
|
||||
|
||||
@ -747,11 +785,7 @@ export default function ProcessInstanceListTable({
|
||||
page = 1; // Reset page back to 0
|
||||
|
||||
const newReportMetadata = getNewReportMetadataBasedOnPageWidgets();
|
||||
setListHasBeenFiltered(true);
|
||||
setReportMetadata(newReportMetadata);
|
||||
searchParams.set('per_page', perPage.toString());
|
||||
searchParams.set('page', page.toString());
|
||||
setSearchParams(searchParams);
|
||||
|
||||
const queryParamString = `per_page=${perPage}&page=${page}`;
|
||||
HttpService.makeCallToBackend({
|
||||
@ -820,6 +854,7 @@ export default function ProcessInstanceListTable({
|
||||
const formatProcessInstanceStatus = (_row: any, value: any) => {
|
||||
return titleizeString((value || '').replaceAll('_', ' '));
|
||||
};
|
||||
|
||||
const processStatusSearch = () => {
|
||||
return (
|
||||
<MultiSelect
|
||||
@ -841,34 +876,12 @@ export default function ProcessInstanceListTable({
|
||||
);
|
||||
};
|
||||
|
||||
const clearFilters = () => {
|
||||
setProcessModelSelection(null);
|
||||
setProcessStatusSelection([]);
|
||||
setStartFromDate('');
|
||||
setStartFromTime('');
|
||||
setStartToDate('');
|
||||
setStartToTime('');
|
||||
setEndFromDate('');
|
||||
setEndFromTime('');
|
||||
setEndToDate('');
|
||||
setEndToTime('');
|
||||
setProcessInitiatorSelection(null);
|
||||
setWithOldestOpenTask(false);
|
||||
setSystemReport(null);
|
||||
setSelectedUserGroup(null);
|
||||
setRequiresRefilter(true);
|
||||
if (reportMetadata) {
|
||||
reportMetadata.filter_by = [];
|
||||
}
|
||||
};
|
||||
|
||||
const processInstanceReportDidChange = (selection: any, mode?: string) => {
|
||||
clearFilters();
|
||||
const selectedReport = selection.selectedItem;
|
||||
setProcessInstanceReportSelection(selectedReport);
|
||||
removeError();
|
||||
setProcessInstanceReportJustSaved(mode || null);
|
||||
setListHasBeenFiltered(false);
|
||||
|
||||
let queryParamString = '';
|
||||
if (selectedReport) {
|
||||
@ -939,15 +952,6 @@ export default function ProcessInstanceListTable({
|
||||
setReportColumnToOperateOn(null);
|
||||
};
|
||||
|
||||
const getFilterByFromReportMetadata = (reportColumnAccessor: string) => {
|
||||
if (reportMetadata) {
|
||||
return reportMetadata.filter_by.find((reportFilter: ReportFilter) => {
|
||||
return reportColumnAccessor === reportFilter.field_name;
|
||||
});
|
||||
}
|
||||
return null;
|
||||
};
|
||||
|
||||
const getNewFiltersFromReportForEditing = (
|
||||
reportColumnForEditing: ReportColumnForEditing
|
||||
) => {
|
||||
|
44
spiffworkflow-frontend/src/hooks/useEffectDebugger.tsx
Normal file
44
spiffworkflow-frontend/src/hooks/useEffectDebugger.tsx
Normal file
@ -0,0 +1,44 @@
|
||||
import { useEffect, useRef } from 'react';
|
||||
|
||||
// https://stackoverflow.com/a/59843241/6090676
|
||||
// useful for determining what state has changed that caused useEffect to trigger.
|
||||
// just change the useEffect in question to useEffectDebugger
|
||||
const usePrevious = (value: any, initialValue: any) => {
|
||||
const ref = useRef(initialValue);
|
||||
useEffect(() => {
|
||||
ref.current = value;
|
||||
});
|
||||
return ref.current;
|
||||
};
|
||||
export default function useEffectDebugger(
|
||||
effectHook: any,
|
||||
dependencies: any,
|
||||
dependencyNames: any = []
|
||||
) {
|
||||
const previousDeps = usePrevious(dependencies, []);
|
||||
|
||||
const changedDeps = dependencies.reduce(
|
||||
(accum: any, dependency: any, index: any) => {
|
||||
if (dependency !== previousDeps[index]) {
|
||||
const keyName = dependencyNames[index] || index;
|
||||
return {
|
||||
...accum,
|
||||
[keyName]: {
|
||||
before: previousDeps[index],
|
||||
after: dependency,
|
||||
},
|
||||
};
|
||||
}
|
||||
|
||||
return accum;
|
||||
},
|
||||
{}
|
||||
);
|
||||
|
||||
if (Object.keys(changedDeps).length) {
|
||||
console.log('[use-effect-debugger] ', changedDeps);
|
||||
}
|
||||
|
||||
// eslint-disable-next-line react-hooks/exhaustive-deps
|
||||
useEffect(effectHook, dependencies);
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user