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

FormDataConsumer component cause rerendering or glitching the input upon selection/reset the value #10415

Open
tnoct opened this issue Dec 16, 2024 · 7 comments · Fixed by #10417

Comments

@tnoct
Copy link

tnoct commented Dec 16, 2024

What you were expecting:

In the create post form, selecting a value for user from the autocomplete input should be smooth, without glitches or triggering a full component re-render.

What happened instead:

In the create post form, selecting a user value from the autocomplete input causes glitches or triggers a full component re-render. When I move the ReferenceInput component outside of the FormDataConsumer component, the issue is resolved, but it should work even when wrapped inside the FormDataConsumer component.

Steps to reproduce:

Preferably, a sandbox forked for reproducing the code.
https://stackblitz.com/edit/github-uaewfaxm?file=src%2Fposts.tsx

 <Create>
    <SimpleForm>
      <FormDataConsumer<any>>
        {({ formData }) => {
          if (!(formData.someField === 'someFieldValue')) {
            return (
              <ReferenceInput source="userId" reference="users">
                <AutocompleteInput
                  shouldUnregister
                  label="User"
                  optionText={(choice) => `${choice.name} /  (${choice.id})`}
                  // optionValue="userId"
                  noOptionsText="User does'nt exist"
                  isRequired
                  validate={[required('User is Required.')]}
                />
              </ReferenceInput>
            );
          } else return null;
        }}
      </FormDataConsumer>
      <TextInput source="title" />
      <TextInput source="body" multiline rows={5} />

    </SimpleForm>
  </Create>

Other information:
Screeen Cast of issue here
https://github.com/user-attachments/assets/4c6ed69a-e9ac-4b95-851b-7efca0dfc008
Environment

React-admin version: ^5.4.2
Last version that did not exhibit the issue (if applicable): 4.12.0 does not have this issue
React version: ^18.3.1
Browser: chrome

@tnoct
Copy link
Author

tnoct commented Dec 16, 2024

issue.webm

issue screencast

@tnoct
Copy link
Author

tnoct commented Dec 16, 2024

Is this the expected behavior when using FormDataConsumer to hide or unhide an input based on another input? I referenced this approach from our documentation.
https://marmelab.com/react-admin/Inputs.html#hiding-inputs-based-on-other-inputs

@tnoct
Copy link
Author

tnoct commented Dec 16, 2024

This same issue is also present on the edit page of a post, i have make the change in the given sand box you can see that too.

@slax57
Copy link
Contributor

slax57 commented Dec 16, 2024

Reproduced. I confirm the flickering is not intended behavior.
However this requires more investigation to understand the root cause.
In any case, thanks for the report!

@djhi
Copy link
Collaborator

djhi commented Jan 20, 2025

Unfortunately we had to revert #10417 as it caused issues with our <StackFilters> component. I'm reopening this issue

@djhi djhi reopened this Jan 20, 2025
@tnoct
Copy link
Author

tnoct commented Jan 20, 2025

Hi @djhi, with all due respect, when can this issue be fixed again?

@djhi
Copy link
Collaborator

djhi commented Jan 23, 2025

I don't have a fix yet but I have a workaround at least: avoid passing unstable object references to the <AutocompleteInput>. In your case, extract the optionText function in a variable outside the component. Do the same for the validate.

You can see the result here: https://stackblitz.com/edit/github-uaewfaxm-redmaeg8?file=src%2Fposts.tsx

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 a pull request may close this issue.

3 participants