From 2e1760e8aab9a5b99e426731665fe84802d8462c Mon Sep 17 00:00:00 2001 From: "Michael S. Molina" Date: Thu, 30 Sep 2021 11:23:38 -0300 Subject: [PATCH] fix: Native filters cyclic dependency --- .../nativeFilters/FiltersConfigModal/utils.ts | 18 ++++++++++++++---- 1 file changed, 14 insertions(+), 4 deletions(-) diff --git a/superset-frontend/src/dashboard/components/nativeFilters/FiltersConfigModal/utils.ts b/superset-frontend/src/dashboard/components/nativeFilters/FiltersConfigModal/utils.ts index fd699e9479880..a6698d2b84ebe 100644 --- a/superset-frontend/src/dashboard/components/nativeFilters/FiltersConfigModal/utils.ts +++ b/superset-frontend/src/dashboard/components/nativeFilters/FiltersConfigModal/utils.ts @@ -42,6 +42,7 @@ export const validateForm = async ( errors: [error], }; form.setFields([fieldError]); + setCurrentFilterId(filterId); }; try { @@ -57,25 +58,34 @@ export const validateForm = async ( } } - const validateCycles = (filterId: string, trace: string[] = []) => { + const validateCycles = ( + filterId: string, + trace: string[] = [], + ): boolean => { if (trace.includes(filterId)) { addValidationError( filterId, 'parentFilter', 'Cannot create cyclic hierarchy', ); + return false; } const parentId = formValues.filters?.[filterId] ? formValues.filters[filterId]?.parentFilter?.value : filterConfigMap[filterId]?.cascadeParentIds?.[0]; if (parentId) { - validateCycles(parentId, [...trace, filterId]); + return validateCycles(parentId, [...trace, filterId]); } + return true; }; - filterIds + const invalid = filterIds .filter(id => !removedFilters[id]) - .forEach(filterId => validateCycles(filterId)); + .some(filterId => !validateCycles(filterId)); + + if (invalid) { + return null; + } return formValues; } catch (error) {