From 8205936f00fbf8e3dbe0848a3b581b96a4a29009 Mon Sep 17 00:00:00 2001 From: "ICX\\Tatsiana.Hashtold" Date: Wed, 26 Jun 2024 15:28:13 +0300 Subject: [PATCH] FIO-8512: fixed an issue where conditionally visible data inside layout components inside editGrid/dataGrid is unset on server side --- src/utils/__tests__/formUtil.test.ts | 51 +++++++++++++++++++++++++++- src/utils/conditions.ts | 9 +++-- src/utils/formUtil.ts | 14 ++++++-- 3 files changed, 68 insertions(+), 6 deletions(-) diff --git a/src/utils/__tests__/formUtil.test.ts b/src/utils/__tests__/formUtil.test.ts index 8a86f0e1..3493a3e1 100644 --- a/src/utils/__tests__/formUtil.test.ts +++ b/src/utils/__tests__/formUtil.test.ts @@ -19,7 +19,8 @@ import { findComponent, findComponents, getComponent, - flattenComponents + flattenComponents, + getComponentActualValue } from "../formUtil"; import { fastCloneDeep } from 'utils/fastCloneDeep'; @@ -1747,3 +1748,51 @@ describe('eachComponentData', () => { ]); }); }); + +describe('getComponentActualValue', () => { + it('Should return correct value for component inside inside panel inside editGrid', () => { + const component = { + label: 'Radio', + optionsLabelPosition: 'right', + inline: false, + tableView: false, + values: [ + { label: 'yes', value: 'yes', shortcut: '' }, + { label: 'no', value: 'no', shortcut: '' }, + ], + key: 'radio', + type: 'radio', + input: true, + path: 'editGrid.radio', + parent: { + collapsible: false, + key: 'panel', + type: 'panel', + label: 'Panel', + input: false, + tableView: false, + path: 'editGrid[0].panel', + parent: { + label: 'Edit Grid', + tableView: false, + rowDrafts: false, + key: 'editGrid', + type: 'editgrid', + path: 'editGrid', + displayAsTable: false, + input: true, + }, + }, + }; + const compPath = 'editGrid.radio'; + const data = { + editGrid: [{ radio: 'yes', textArea: 'test' }], + submit: true, + }; + const row = { radio: 'yes', textArea: 'test' }; + + const value = getComponentActualValue(component, compPath, data, row); + expect(value).to.equal('yes'); + }); + }); + \ No newline at end of file diff --git a/src/utils/conditions.ts b/src/utils/conditions.ts index d0198a98..d426e396 100644 --- a/src/utils/conditions.ts +++ b/src/utils/conditions.ts @@ -1,6 +1,6 @@ import { ConditionsContext, JSONConditional, LegacyConditional, SimpleConditional } from "types"; import { EvaluatorFn, evaluate, JSONLogicEvaluator } from 'modules/jsonlogic'; -import { getComponentActualValue } from "./formUtil"; +import { getComponent, getComponentActualValue } from "./formUtil"; import { has, isObject, map, every, some, find, filter } from 'lodash'; import ConditionOperators from './operators'; @@ -95,7 +95,7 @@ export function checkJsonConditional(conditional: JSONConditional, context: Cond * @returns */ export function checkSimpleConditional(conditional: SimpleConditional, context: ConditionsContext): boolean | null { - const { component, data, row, instance } = context; + const { component, data, row, instance, form } = context; if (!conditional || !isSimpleConditional(conditional)) { return null; } @@ -110,7 +110,10 @@ export function checkSimpleConditional(conditional: SimpleConditional, context: // Ignore conditions if there is no component path. return null; } - const value = getComponentActualValue(component, conditionComponentPath, data, row); + + const conditionComp = getComponent(form?.components || [], conditionComponentPath, true); + const value = conditionComp ? getComponentActualValue(conditionComp, conditionComponentPath, data, row) : null; + const ConditionOperator = ConditionOperators[operator]; return ConditionOperator ? new ConditionOperator().getResult({ value, comparedValue, instance, component, conditionComponentPath }) diff --git a/src/utils/formUtil.ts b/src/utils/formUtil.ts index 1c4248b5..66c14174 100644 --- a/src/utils/formUtil.ts +++ b/src/utils/formUtil.ts @@ -596,8 +596,18 @@ export function getComponentActualValue(component: Component, compPath: string, // // a[0].b[2].c[3].d => a.b.c.d // - if (component.parent?.path) { - const parentCompPath = component.parent?.path.replace(/\[[0-9]+\]/g, ''); + let parentInputComponent: any = null; + let parent = component; + + while (parent?.parent?.path && !parentInputComponent) { + parent = parent.parent; + if (parent.input) { + parentInputComponent = parent; + } + } + + if (parentInputComponent) { + const parentCompPath = parentInputComponent.path.replace(/\[[0-9]+\]/g, ''); compPath = compPath.replace(parentCompPath, ''); compPath = trim(compPath, '. '); }