Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

FIO-8723: Clear values from submission for hidden comp with clearOnHide flag #137

Merged
Merged
2 changes: 1 addition & 1 deletion src/process/__tests__/process.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3129,7 +3129,7 @@ describe('Process Tests', () => {
processSync(context);

expect(context.data).to.deep.equal({
candidates:[{candidate:{data:{section6:{}}}}],
candidates:[{candidate:{data:{section6:{ "c":{}, "d":[]}}}}],
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This test appeared to be doing invalid assertion, since clearOnHide is false in this case, the fields should be left. Corrected it.

submit: true
});
});
Expand Down
5 changes: 3 additions & 2 deletions src/process/conditions/__tests__/conditions.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -53,8 +53,9 @@ describe('Condition processor', () => {
form,
submission
);
expect(context.components[1]).to.haveOwnProperty('hidden');
expect(context.components[1].hidden).to.be.true;
expect(context.scope.conditionals).to.have.length(1);
expect(context.scope.conditionals?.[0].path).to.equal(form.components[1].key);
expect(context.scope.conditionals?.[0].conditionallyHidden).to.be.true;
});

it('Should not define a conditional component (that condition is based on selectBoxes value) as hidden', async () => {
Expand Down
7 changes: 0 additions & 7 deletions src/process/conditions/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -83,10 +83,6 @@ export const conditionalProcess = (context: ConditionsContext, isHidden: Conditi
if (!hasConditions(context)) {
return;
}
// Reset 'hidden' property to recalculate the conditions for every component
if (component.hidden) {
delete component.hidden;
}
if (!scope.conditionals) {
scope.conditionals = [];
}
Expand All @@ -97,9 +93,6 @@ export const conditionalProcess = (context: ConditionsContext, isHidden: Conditi
}

conditionalComp.conditionallyHidden = conditionalComp.conditionallyHidden || isHidden(context);
if (conditionalComp.conditionallyHidden) {
set(component, 'hidden', true);
}
};

export const customConditionProcess: ProcessorFn<ConditionsScope> = async (context: ConditionsContext) => {
Expand Down
18 changes: 6 additions & 12 deletions src/process/hideChildren.ts
Original file line number Diff line number Diff line change
Expand Up @@ -19,25 +19,19 @@ export const hideChildrenProcessor: ProcessorFnSync<ConditionsScope> = (context)
const isConditionallyHidden = scope.conditionals?.find((cond) => {
return path === cond.path && cond.conditionallyHidden;
});
if (component.hidden && isConditionallyHidden) {

if (!scope.conditionals) {
scope.conditionals = [];
}

if (isConditionallyHidden || component.hidden) {
const info = componentInfo(component);
if (info.hasColumns || info.hasComps || info.hasRows) {
// If this is a container component, we need to make the mutation to all the child components as well.
eachComponentData([component], row, (comp: Component, data: any, compRow: any, compPath: string) => {
if (comp !== component) {
// the path set here is not the absolute path, but the path relative to the parent component
(scope as ConditionsScope).conditionals?.push({ path: getComponentPath(comp, compPath), conditionallyHidden: true });
set(comp, 'hidden', true);
}
});
}
} else if (component.hidden) {
const info = componentInfo(component);
if (info.hasColumns || info.hasComps || info.hasRows) {
// If this is a container component, we need to make the mutation to all the child components as well.
eachComponentData([component], row, (comp: Component, data: any, compRow: any, compPath: string) => {
if (comp !== component) {
set(comp, 'hidden', true);
}
});
}
Expand Down
5 changes: 0 additions & 5 deletions src/utils/logic.ts
Original file line number Diff line number Diff line change
Expand Up @@ -69,7 +69,6 @@ export function setActionBooleanProperty(context: LogicContext, action: LogicAct
conditionallyHidden: !!component.hidden,
});
}
set(component, 'hidden', !!component.hidden);
}
return true;
}
Expand Down Expand Up @@ -141,10 +140,6 @@ export const applyActions = (context: LogicContext): boolean => {
if (!logic || !logic.length) {
return false;
}
// Reset 'hidden' property to recalculate the logic for every component
if (component.hidden) {
delete component.hidden
}
return logic.reduce((changed, logicItem) => {
const { actions, trigger } = logicItem;
if (!trigger || !actions || !actions.length || !checkTrigger(context, trigger)) {
Expand Down
Loading