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:
jasquat 2023-05-12 15:14:35 -04:00
parent 52d1df5c0f
commit 0bda287c81
2 changed files with 100 additions and 52 deletions

View File

@ -162,9 +162,6 @@ export default function ProcessInstanceListTable({
const [requiresRefilter, setRequiresRefilter] = useState<boolean>(false); const [requiresRefilter, setRequiresRefilter] = useState<boolean>(false);
const [lastColumnFilter, setLastColumnFilter] = useState<string>(''); const [lastColumnFilter, setLastColumnFilter] = useState<string>('');
const [listHasBeenFiltered, setListHasBeenFiltered] =
useState<boolean>(false);
const preferredUsername = UserService.getPreferredUsername(); const preferredUsername = UserService.getPreferredUsername();
const userEmail = UserService.getUserEmail(); 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 [reportHash, setReportHash] = useState<string | null>(null);
const [ const [
@ -321,14 +321,35 @@ export default function ProcessInstanceListTable({
// so use a variable instead // so use a variable instead
const processModelSelectionItemsForUseEffect = useRef<ProcessModel[]>([]); 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( const getProcessInstances = useCallback(
( (
processInstanceReport: ProcessInstanceReport | null = null processInstanceReport: ProcessInstanceReport | null = null
// eslint-disable-next-line sonarjs/cognitive-complexity // eslint-disable-next-line sonarjs/cognitive-complexity
) => { ) => {
if (listHasBeenFiltered) {
return;
}
let reportMetadataBodyToUse: ReportMetadata = { let reportMetadataBodyToUse: ReportMetadata = {
columns: [], columns: [],
filter_by: [], 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 // this is the code to re-populate the widgets on the page
// with values from the report metadata, which is derived // with values from the report metadata, which is derived
// from the searchParams (often report_hash) // from the searchParams (often report_hash)
@ -433,7 +459,6 @@ export default function ProcessInstanceListTable({
additionalReportFilters, additionalReportFilters,
dateParametersToAlwaysFilterBy, dateParametersToAlwaysFilterBy,
filtersEnabled, filtersEnabled,
listHasBeenFiltered,
paginationQueryParamPrefix, paginationQueryParamPrefix,
perPageOptions, perPageOptions,
processInstanceApiSearchPath, processInstanceApiSearchPath,
@ -441,6 +466,7 @@ export default function ProcessInstanceListTable({
setProcessInstancesFromResult, setProcessInstancesFromResult,
stopRefreshing, stopRefreshing,
systemReportOptions, systemReportOptions,
clearFilters,
] ]
); );
@ -448,11 +474,7 @@ export default function ProcessInstanceListTable({
if (!permissionsLoaded) { if (!permissionsLoaded) {
return undefined; return undefined;
} }
function getReportMetadataWithReportHash() { function getReportMetadataWithReportHash() {
if (listHasBeenFiltered) {
return;
}
const queryParams: string[] = []; const queryParams: string[] = [];
['report_hash', 'report_id'].forEach((paramName: string) => { ['report_hash', 'report_id'].forEach((paramName: string) => {
if (searchParams.get(paramName)) { if (searchParams.get(paramName)) {
@ -517,7 +539,6 @@ export default function ProcessInstanceListTable({
autoReload, autoReload,
filtersEnabled, filtersEnabled,
getProcessInstances, getProcessInstances,
listHasBeenFiltered,
permissionsLoaded, permissionsLoaded,
reportIdentifier, reportIdentifier,
searchParams, searchParams,
@ -632,17 +653,34 @@ export default function ProcessInstanceListTable({
reportMetadataToUse.filter_by = filtersToKeep; 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 = ( const insertOrUpdateFieldInReportMetadata = (
reportMetadataToUse: ReportMetadata, reportMetadataToUse: ReportMetadata,
fieldName: string, fieldName: string,
fieldValue: any fieldValue: any
) => { ) => {
removeFieldFromReportMetadata(reportMetadataToUse, fieldName);
if (fieldValue) { if (fieldValue) {
reportMetadataToUse.filter_by.push({ let existingReportFilter = getFilterByFromReportMetadata(fieldName);
if (existingReportFilter) {
existingReportFilter.field_value = fieldValue;
} else {
existingReportFilter = {
field_name: fieldName, field_name: fieldName,
field_value: fieldValue, 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 page = 1; // Reset page back to 0
const newReportMetadata = getNewReportMetadataBasedOnPageWidgets(); const newReportMetadata = getNewReportMetadataBasedOnPageWidgets();
setListHasBeenFiltered(true);
setReportMetadata(newReportMetadata); setReportMetadata(newReportMetadata);
searchParams.set('per_page', perPage.toString());
searchParams.set('page', page.toString());
setSearchParams(searchParams);
const queryParamString = `per_page=${perPage}&page=${page}`; const queryParamString = `per_page=${perPage}&page=${page}`;
HttpService.makeCallToBackend({ HttpService.makeCallToBackend({
@ -820,6 +854,7 @@ export default function ProcessInstanceListTable({
const formatProcessInstanceStatus = (_row: any, value: any) => { const formatProcessInstanceStatus = (_row: any, value: any) => {
return titleizeString((value || '').replaceAll('_', ' ')); return titleizeString((value || '').replaceAll('_', ' '));
}; };
const processStatusSearch = () => { const processStatusSearch = () => {
return ( return (
<MultiSelect <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) => { const processInstanceReportDidChange = (selection: any, mode?: string) => {
clearFilters(); clearFilters();
const selectedReport = selection.selectedItem; const selectedReport = selection.selectedItem;
setProcessInstanceReportSelection(selectedReport); setProcessInstanceReportSelection(selectedReport);
removeError(); removeError();
setProcessInstanceReportJustSaved(mode || null); setProcessInstanceReportJustSaved(mode || null);
setListHasBeenFiltered(false);
let queryParamString = ''; let queryParamString = '';
if (selectedReport) { if (selectedReport) {
@ -939,15 +952,6 @@ export default function ProcessInstanceListTable({
setReportColumnToOperateOn(null); setReportColumnToOperateOn(null);
}; };
const getFilterByFromReportMetadata = (reportColumnAccessor: string) => {
if (reportMetadata) {
return reportMetadata.filter_by.find((reportFilter: ReportFilter) => {
return reportColumnAccessor === reportFilter.field_name;
});
}
return null;
};
const getNewFiltersFromReportForEditing = ( const getNewFiltersFromReportForEditing = (
reportColumnForEditing: ReportColumnForEditing reportColumnForEditing: ReportColumnForEditing
) => { ) => {

View 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);
}