Skip to content
This repository has been archived by the owner on Oct 1, 2024. It is now read-only.

Commit

Permalink
✨ use deep equals to reconcile form state if onInitialValueChangedpro…
Browse files Browse the repository at this point in the history
…p is reset-where-changed
  • Loading branch information
allyshiasewdat committed Jan 9, 2019
1 parent 88abec3 commit 24dbc51
Show file tree
Hide file tree
Showing 3 changed files with 65 additions and 1 deletion.
6 changes: 6 additions & 0 deletions packages/react-form-state/CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,12 @@ All notable changes to this project will be documented in this file.

The format is based on [Keep a Changelog](http://keepachangelog.com/en/1.0.0/).

## Unreleased

### Added

- You can now use the onInitialValueChanged prop with fields having nested properties.

## [0.6]

### Added
Expand Down
2 changes: 1 addition & 1 deletion packages/react-form-state/src/FormState.ts
Original file line number Diff line number Diff line change
Expand Up @@ -395,7 +395,7 @@ function reconcileFormState<Fields>(
const fields: FieldStates<Fields> = mapObject(values, (value, key) => {
const oldField = oldFields[key];

if (value === oldField.initialValue) {
if (isEqual(value, oldField.initialValue)) {
return oldField;
}

Expand Down
58 changes: 58 additions & 0 deletions packages/react-form-state/src/tests/FormState.test.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -182,6 +182,64 @@ describe('<FormState />', () => {
});
});

it('does not reset a field when initial value has not changed and deep comparison is required', () => {
const renderPropSpy = jest.fn(() => null);
const originalOption = 'color';
const originalVariant1 = faker.commerce.color();
const originalVariant2 = faker.commerce.color();
const originalValues = {
variants: [
{
option: originalOption,
values: [originalVariant1, originalVariant2],
},
],
};

const form = mount(
<FormState
initialValues={originalValues}
onInitialValuesChange="reset-where-changed"
>
{renderPropSpy}
</FormState>,
);

const formDetails = lastCallArgs(renderPropSpy);
const changedVariants = [
{
option: 'material',
values: [
faker.commerce.productMaterial(),
faker.commerce.productMaterial(),
],
},
];
formDetails.fields.variants.onChange(changedVariants);

const unchangedInitialVariants = [
{
option: originalOption,
values: [originalVariant1, originalVariant2],
},
];

form.setProps({
initialValues: {
variants: unchangedInitialVariants,
},
});

const {fields} = lastCallArgs(renderPropSpy);
expect(fields).toMatchObject({
variants: {
value: changedVariants,
initialValue: originalValues.variants,
dirty: true,
},
});
});

it('does not reset errors when the initialValues prop is updated', async () => {
const renderPropSpy = jest.fn(() => null);
const originalValues = {
Expand Down

0 comments on commit 24dbc51

Please sign in to comment.