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

[material-ui][Autocomplete] Initial render with a default value set always causes input label to perform the shrink animation #44506

Closed
ShotSkydiver opened this issue Nov 21, 2024 · 8 comments · Fixed by #44873
Assignees
Labels
bug 🐛 Something doesn't work component: autocomplete This is the name of the generic UI component, not the React module! package: material-ui Specific to @mui/material

Comments

@ShotSkydiver
Copy link

ShotSkydiver commented Nov 21, 2024

Steps to reproduce

Steps:

  1. Open this link to live example: https://codesandbox.io/p/sandbox/stoic-fire-zz67mz-zz67mz?from-embed=&workspaceId=edc4f89e-5831-4c48-b5ed-57fcd105b256
  2. Click show/hide autocomplete button
  3. Watch the input label do its shrink animation despite there being a value set initially

Current behavior

When providing a value to Autocomplete, on initial render it'll animate the input label shrinking as if a value was entered after the component was rendered, which gets extra visually annoying when having large groups of autocomplete fields that are contained within Steps or show/hide buttons

Expected behavior

The input label is already shrunk at initial render without any animation, like it is for TextField, Select, etc

Context

N/A

Your environment

npx @mui/envinfo
    System:
    OS: macOS 15.2
  Binaries:
    Node: 23.2.0 - /opt/homebrew/bin/node
    npm: 10.9.0 - /opt/homebrew/bin/npm
    pnpm: Not Found
  Browsers:
    Chrome: Not Found
    Edge: Not Found
    Safari: 18.2
  npmPackages:
    @emotion/react: 11.13.3 => 11.13.3 
    @emotion/styled: 11.13.0 => 11.13.0 
    @mui/base: 5.0.0-beta.61 => 5.0.0-beta.61 
    @mui/codemod: 6.1.7 => 6.1.7 
    @mui/core-downloads-tracker:  6.1.4 
    @mui/icons-material: 6.1.7 => 6.1.7 
    @mui/lab: 6.0.0-beta.15 => 6.0.0-beta.15 
    @mui/material: 6.1.7 => 6.1.7 
    @mui/private-theming:  6.1.7 
    @mui/styled-engine:  6.1.4 
    @mui/styles: 6.1.7 => 6.1.7 
    @mui/system: 6.1.7 => 6.1.7 
    @mui/types:  7.2.19 
    @mui/utils:  6.1.4 
    @mui/x-charts: 7.22.2 => 7.22.2 
    @mui/x-charts-vendor:  7.20.0 
    @mui/x-data-grid: 7.22.2 => 7.22.2 
    @mui/x-date-pickers: 7.22.2 => 7.22.2 
    @mui/x-internals:  7.21.0 
    @types/react:  18.3.11 
    react: 18.3.1 => 18.3.1 
    react-dom: 18.3.1 => 18.3.1 

Search keywords: autocomplete shrink animation initial value

@ShotSkydiver ShotSkydiver added the status: waiting for maintainer These issues haven't been looked at yet by a maintainer label Nov 21, 2024
@zannager zannager added the component: autocomplete This is the name of the generic UI component, not the React module! label Nov 25, 2024
@DiegoAndai DiegoAndai assigned DiegoAndai and unassigned mj12albert Nov 29, 2024
@DiegoAndai DiegoAndai added bug 🐛 Something doesn't work package: material-ui Specific to @mui/material and removed status: waiting for maintainer These issues haven't been looked at yet by a maintainer labels Nov 29, 2024
@DiegoAndai DiegoAndai changed the title [Autocomplete] Initial render with a value set always causes input label to perform the shrink animation [material-ui][Autocomplete] Initial render with a value set always causes input label to perform the shrink animation Nov 29, 2024
@DiegoAndai DiegoAndai added the ready to take Help wanted. Guidance available. There is a high chance the change will be accepted label Nov 29, 2024
@DiegoAndai
Copy link
Member

Hey @ShotSkydiver, thanks for the report. I can confirm this is a bug.

@yash49
Copy link
Contributor

yash49 commented Dec 3, 2024

@ShotSkydiver you can use display: 'none'

export default function LimitTags() {
  const [showAutocomplete, setShowAutocomplete] = useState(false);
  return (
    <>
      <Button onClick={() => setShowAutocomplete(!showAutocomplete)}>
        Show/Hide Autocomplete
      </Button>

      <Autocomplete
        id="render-label"
        options={top100Films}
        getOptionLabel={(option) => option.title}
        value={top100Films[11]}
        renderInput={(params) => <TextField {...params} label="limitTags" />}
        sx={{
          width: "500px",
          m: 4,
          display: showAutocomplete ? undefined : "none",
        }}
      />
    </>
  );
}

@ShotSkydiver
Copy link
Author

@yash49 that doesn't work for my use case, I'm building a multi-step form that renders each step separately, so it's that initial render when switching steps that makes the label shrink which is visually jarring

@ZeeshanTamboli
Copy link
Member

ZeeshanTamboli commented Jan 1, 2025

@ShotSkydiver A similar issue existed in #36548 for inputValue. It works when you pass inputValue:

<Autocomplete
  id="render-label"
  options={top100Films}
  getOptionLabel={(option) => option.title}
  inputValue={top100Films[11].title}
  renderInput={(params) => <TextField {...params} label="limitTags" />}
  sx={{ width: '500px', m: 4 }}
/>;

However, it should also work with value and defaultValue. I am trying to fix it in #44873

@ShotSkydiver
Copy link
Author

@ZeeshanTamboli thanks for the further info! Seems like that doesn't work when using an object as the value prop though, it just displays the value as [object Object] and crashes when clicking into the field because it's trying to treat the inputValue like a string

@ZeeshanTamboli
Copy link
Member

ZeeshanTamboli commented Jan 4, 2025

@ShotSkydiver Pass the title for the input value: inputValue={top100Films[11].title}.

However, you’ll need a controlled Autocomplete using value/onChange and inputValue/onInputChange props combinations. This is a workaround. See the example here: https://codesandbox.io/p/sandbox/stoic-fire-zz67mz-forked-8k9lmg.

@ZeeshanTamboli
Copy link
Member

ZeeshanTamboli commented Jan 4, 2025

@ShotSkydiver I also noticed you are using value in your Autocomplete to show a default value. This doesn't work when you select option a second time. Only the selected value is shown in the options list.
To show a default value, you need to use defaultValue prop. So this bug is with the defaultValue prop, not value prop.

@ZeeshanTamboli ZeeshanTamboli changed the title [material-ui][Autocomplete] Initial render with a value set always causes input label to perform the shrink animation [material-ui][Autocomplete] Initial render with a default value set always causes input label to perform the shrink animation Jan 4, 2025
@DiegoAndai DiegoAndai removed the ready to take Help wanted. Guidance available. There is a high chance the change will be accepted label Jan 8, 2025
Copy link

This issue has been closed. If you have a similar problem but not exactly the same, please open a new issue.
Now, if you have additional information related to this issue or things that could help future readers, feel free to leave a comment.

Note

@ShotSkydiver How did we do? Your experience with our support team matters to us. If you have a moment, please share your thoughts in this short Support Satisfaction survey.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug 🐛 Something doesn't work component: autocomplete This is the name of the generic UI component, not the React module! package: material-ui Specific to @mui/material
Projects
None yet
6 participants