mirror of
https://github.com/sartography/spiff-arena.git
synced 2025-01-11 18:14:20 +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 [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
|
||||||
) => {
|
) => {
|
||||||
|
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