Skip to content

Conversation

@LeCarbonator
Copy link
Contributor

@LeCarbonator LeCarbonator commented Jun 8, 2025

  • React
  • Solid
  • Vue
  • Angular (Feedback appreciated)

This PR adds some code snippets to get users started on the three common types of errors:

  • Sync user errors
  • Async user errors
  • Server errors

The user errors are implemented using form / field validators (with links to the validation guide page). The Server error example is implemented using TanStack Query.

Comment on lines +46 to +49
if (response.isError) {
// Username is taken, return an error for the username field
return 'Username is already taken!'
}
Copy link
Contributor

Choose a reason for hiding this comment

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

This says

return an error for the username field

but the error seems to go to the Form not to the Field

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Good catch! The comment is kind of redundant now. I'll remove it!

onSubmit: async ({ value }) => {
// If an error happens, they are accessible through
// `createAccountMutation.error`
await createAccountMutation.mutateAsync(value)
Copy link
Contributor

@Pascalmh Pascalmh Jun 12, 2025

Choose a reason for hiding this comment

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

Promoting "mutateAsync" here feels off:

you should almost always use mutate
– https://tkdodo.eu/blog/mastering-mutations-in-react-query#mutate-or-mutateasync

Suggested change
await createAccountMutation.mutateAsync(value)
createAccountMutation.mutate(value, {
onSuccess: () => {
// handle success by navigate to another route e.g.
}
})

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Here's the thought process behind it:

  • Is mutate synchronous? If not, onSubmit would finish immediately and isSubmitting would flash true for a moment
  • Error handling informs TSF about isSubmitSuccessful, which would cause a disconnect if mutate errors

Copy link
Contributor

Choose a reason for hiding this comment

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

Then this seems like one of those exceptions to not prefere mutate over mutateAsync ;-)

It's perfect as it is, thanks for clarifying!

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Do you reckon this should be mentioned somewhere? I assume there's lots of users combining Tanstack Form with TansStack Query

Copy link
Contributor

Choose a reason for hiding this comment

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

There's some explenation here: https://tanstack.com/form/latest/docs/reference/type-aliases/baseformstate#issubmitting

I think it would be good to mention it on the "Submission Handling"-Page as well as it clears up a lot of questions.

Pascalmh and others added 2 commits June 12, 2025 09:55
docs: expand submission handling in angular
Comment on lines +22 to +29
<form.Field
name="age"
validators={{
onChange: ({ value }) =>
value < 13 ? 'You must be 13 to make an account' : undefined,
}}
children={{() => <>{/* ... */}</>}}
/>
Copy link
Contributor

Choose a reason for hiding this comment

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

IIRC @crutchcorn wanted to favor Form-Level-Validation over Field-Level-Validation, switching to Form-Level here would keep this guide on Form-Level throughout (reduced complexity).

Another Idea I want to pitch where this would help is: The "Error handling" should end with a "Putting it all together" chapter that shows a full useForm example with onChange, onSubmitAsync validators and the onSubmit.

Ayush pointed out that it wasn't clear enough yet.
I think he's asking why createAccount is called once in form.validators.onSubmitAsync and then again in form.onsubmit (ony that it's now using TSQ and is called createAccountMutation.mutateAsync)

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Good idea! Then it could represent three use cases that don't conflict name-wise!

@LeCarbonator
Copy link
Contributor Author

This has sparked some discussion internally. Since it's not clear how big the changes to the diffs will be, I'll mark it as draft for now.

@LeCarbonator LeCarbonator marked this pull request as draft June 24, 2025 17:41
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants