Skip to content

Commit

Permalink
Revert "Clear errors on form reset (#1568)"
Browse files Browse the repository at this point in the history
This reverts commit 74d682c.
  • Loading branch information
jessarcher committed Oct 31, 2023
1 parent 1e27141 commit 02307bb
Show file tree
Hide file tree
Showing 7 changed files with 30 additions and 37 deletions.
6 changes: 5 additions & 1 deletion CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -7,10 +7,14 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0

For changes prior to v1.0.0, see the [legacy releases](https://legacy.inertiajs.com/releases).

## [Unreleased](https://github.com/inertiajs/inertia/compare/v1.0.13...HEAD)
## [Unreleased](https://github.com/inertiajs/inertia/compare/v1.0.14...HEAD)

- Nothing

## [v1.0.14](https://github.com/inertiajs/inertia/compare/v1.0.13...v1.0.14)

- Revert: Clear errors on form reset ([#1568](https://github.com/inertiajs/inertia/pull/1568))

## [v1.0.13](https://github.com/inertiajs/inertia/compare/v1.0.12...v1.0.13)

- Clear errors on form reset ([#1568](https://github.com/inertiajs/inertia/pull/1568))
Expand Down
31 changes: 13 additions & 18 deletions packages/react/src/useForm.ts
Original file line number Diff line number Diff line change
Expand Up @@ -166,20 +166,6 @@ export default function useForm<TForm extends FormDataType>(
[data, setErrors],
)

function clearErrors(...fields) {
setErrors((errors) => {
const newErrors = (Object.keys(errors) as Array<keyof TForm>).reduce(
(carry, field) => ({
...carry,
...(fields.length > 0 && !fields.includes(field) ? { [field]: errors[field] } : {}),
}),
{},
)
setHasErrors(Object.keys(newErrors).length > 0)
return newErrors
})
}

return {
data,
setData(keyOrData: keyof TForm | Function | TForm, maybeValue?: TForm[keyof TForm]) {
Expand Down Expand Up @@ -214,8 +200,6 @@ export default function useForm<TForm extends FormDataType>(
reset(...fields) {
if (fields.length === 0) {
setData(defaults)
setErrors({})
setHasErrors(false)
} else {
setData(
(Object.keys(defaults) as Array<keyof TForm>)
Expand All @@ -228,7 +212,6 @@ export default function useForm<TForm extends FormDataType>(
{ ...data },
),
)
clearErrors(...fields)
}
},
setError(fieldOrFields: keyof TForm | Record<keyof TForm, string>, maybeValue?: string) {
Expand All @@ -243,7 +226,19 @@ export default function useForm<TForm extends FormDataType>(
return newErrors
})
},
clearErrors,
clearErrors(...fields) {
setErrors((errors) => {
const newErrors = (Object.keys(errors) as Array<keyof TForm>).reduce(
(carry, field) => ({
...carry,
...(fields.length > 0 && !fields.includes(field) ? { [field]: errors[field] } : {}),
}),
{},
)
setHasErrors(Object.keys(newErrors).length > 0)
return newErrors
})
},
submit,
get(url, options) {
submit('get', url, options)
Expand Down
4 changes: 1 addition & 3 deletions packages/svelte/src/useForm.js
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import { router } from '@inertiajs/core'
import cloneDeep from 'lodash.clonedeep'
import isEqual from 'lodash.isequal'
import cloneDeep from 'lodash.clonedeep'
import { writable } from 'svelte/store'

function useForm(...args) {
Expand Down Expand Up @@ -52,7 +52,6 @@ function useForm(...args) {
let clonedDefaults = cloneDeep(defaults)
if (fields.length === 0) {
this.setStore(clonedDefaults)
this.clearErrors()
} else {
this.setStore(
Object.keys(clonedDefaults)
Expand All @@ -62,7 +61,6 @@ function useForm(...args) {
return carry
}, {}),
)
this.clearErrors(...fields)
}

return this
Expand Down
2 changes: 0 additions & 2 deletions packages/vue2/src/useForm.ts
Original file line number Diff line number Diff line change
Expand Up @@ -88,15 +88,13 @@ export default function useForm<TForm extends FormDataType>(...args): InertiaFor
if (fields.length === 0) {
defaults = clonedData
Object.assign(this, resolvedData)
this.clearErrors()
} else {
Object.keys(resolvedData)
.filter((key) => fields.includes(key))
.forEach((key) => {
defaults[key] = clonedData[key]
this[key] = resolvedData[key]
})
this.clearErrors(...fields)
}

return this
Expand Down
18 changes: 9 additions & 9 deletions packages/vue2/tests/cypress/integration/form-helper.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -340,7 +340,7 @@ describe('Form Helper', () => {
cy.get('#remember').should('be.checked')
})

it('resets error when it resets a field to its initial value', () => {
it('does not reset errors when it resets a field to its initial value', () => {
cy.get('#name').clear().type('A')
cy.get('#handle').clear().type('B')
cy.get('#remember').check()
Expand All @@ -361,11 +361,11 @@ describe('Form Helper', () => {
cy.get('#remember').should('be.checked')
cy.get('.errors-status').should('have.text', 'Form has errors')
cy.get('.name_error').should('have.text', 'Some name error')
cy.get('.handle_error').should('not.exist')
cy.get('.handle_error').should('have.text', 'The Handle was invalid')
cy.get('.remember_error').should('not.exist')
})

it('reset errors when it resets all fields to their initial values', () => {
it('does not reset errors when it resets all fields to their initial values', () => {
cy.get('#name').clear().type('A')
cy.get('#handle').clear().type('B')
cy.get('#remember').check()
Expand All @@ -379,14 +379,14 @@ describe('Form Helper', () => {
cy.get('.name_error').should('have.text', 'Some name error')
cy.get('.handle_error').should('have.text', 'The Handle was invalid')

cy.get('.reset').click()
cy.get('.reset-one').click()

cy.get('#name').should('have.value', 'foo')
cy.get('#name').should('have.value', 'A')
cy.get('#handle').should('have.value', 'example')
cy.get('#remember').should('not.be.checked')
cy.get('.errors-status').should('have.text', 'Form has no errors')
cy.get('.name_error').should('not.exist')
cy.get('.handle_error').should('not.exist')
cy.get('#remember').should('be.checked')
cy.get('.errors-status').should('have.text', 'Form has errors')
cy.get('.name_error').should('have.text', 'Some name error')
cy.get('.handle_error').should('have.text', 'The Handle was invalid')
cy.get('.remember_error').should('not.exist')
})

Expand Down
4 changes: 2 additions & 2 deletions packages/vue2/tests/cypress/integration/remember.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -273,7 +273,7 @@ describe('Remember (local state caching)', () => {
cy.get('#remember').should('be.checked')
cy.get('#untracked').should('have.value', 'C') // Unchanged from above
cy.get('.name_error').should('not.exist')
cy.get('.handle_error').should('not.exist')
cy.get('.handle_error').should('have.text', 'The Handle was invalid')
cy.get('.remember_error').should('not.exist')

cy.get('.link').click()
Expand All @@ -287,7 +287,7 @@ describe('Remember (local state caching)', () => {
cy.get('#remember').should('be.checked')
cy.get('#untracked').should('not.have.value', 'C') // Untracked, so now reset (page state was lost)
cy.get('.name_error').should('not.exist')
cy.get('.handle_error').should('not.exist')
cy.get('.handle_error').should('have.text', 'The Handle was invalid')
cy.get('.remember_error').should('not.exist')
})
})
Expand Down
2 changes: 0 additions & 2 deletions packages/vue3/src/useForm.ts
Original file line number Diff line number Diff line change
Expand Up @@ -95,15 +95,13 @@ export default function useForm<TForm extends FormDataType>(
if (fields.length === 0) {
defaults = clonedData
Object.assign(this, resolvedData)
this.clearErrors()
} else {
Object.keys(resolvedData)
.filter((key) => fields.includes(key))
.forEach((key) => {
defaults[key] = clonedData[key]
this[key] = resolvedData[key]
})
this.clearErrors(...fields)
}

return this
Expand Down

0 comments on commit 02307bb

Please sign in to comment.