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][Select] Adding <fieldset disabled> doesn't disable it #39634

Open
2 tasks done
jonnylink opened this issue Oct 27, 2023 · 3 comments
Open
2 tasks done

[material-ui][Select] Adding <fieldset disabled> doesn't disable it #39634

jonnylink opened this issue Oct 27, 2023 · 3 comments
Labels
component: select This is the name of the generic UI component, not the React module! enhancement This is not a bug, nor a new feature package: material-ui Specific to @mui/material

Comments

@jonnylink
Copy link

Duplicates

  • I have searched the existing issues

Latest version

  • I have tested the latest version

Steps to reproduce 🕹

Link to live example: https://codesandbox.io/s/friendly-dijkstra-g62dv9?file=/src/Demo.js

Steps:

  1. add "disabled" to a surrounding a select component

Current behavior 😯

The form element is active

Expected behavior 🤔

Form element should be disabled like the rest of the elements when the fieldset is marked disabled

Context 🔦

I need to disable all form elements on page with a huge form.

I think I'm also supposed to mention we have a license: Order #72705

Your environment 🌎

npx @mui/envinfo
  System:
    OS: macOS 14.0
  Binaries:
    Node: 20.3.0 - ~/.nvm/versions/node/v20.3.0/bin/node
    Yarn: 3.2.2 - /opt/homebrew/bin/yarn
    npm: 9.6.7 - ~/.nvm/versions/node/v20.3.0/bin/npm
  Browsers:
    Chrome: 118.0.5993.70
    Edge: Not Found
    Safari: 17.0
@jonnylink jonnylink added the status: waiting for maintainer These issues haven't been looked at yet by a maintainer label Oct 27, 2023
@danilo-leal danilo-leal changed the title Select boxes are not disabled by fieldset disabled [material-ui][Select] Adding <fieldset disabled> doesn't disable it Oct 27, 2023
@danilo-leal danilo-leal added component: select This is the name of the generic UI component, not the React module! package: material-ui Specific to @mui/material labels Oct 27, 2023
@mj12albert
Copy link
Member

mj12albert commented Nov 6, 2023

@jonnylink <fieldset disabled> can only affect native form control elements (e.g. <input>, <button>), since the Select component does not use any internally this wouldn't work

A workaround is to have the FormControl render a fieldset and pass disabled there:

<FormControl component="fieldset" disabled>
  <InputLabel id="demo-simple-select-label">Age</InputLabel>
  <Select
    labelId="demo-simple-select-label"
    id="demo-simple-select"
    value={age}
    label="Age"
    onChange={handleChange}
  >
    <MenuItem value={10}>Ten</MenuItem>
    <MenuItem value={20}>Twenty</MenuItem>
    <MenuItem value={30}>Thirty</MenuItem>
  </Select>
</FormControl>

Example sandbox: https://codesandbox.io/s/https-github-com-mui-material-ui-issues-39634-l9n4zh

Another alternative is to use the Select component in native mode, so it can be affected by a native fieldset: https://codesandbox.io/s/disabled-fieldset-native-select-577p9j

@mj12albert mj12albert added enhancement This is not a bug, nor a new feature and removed status: waiting for maintainer These issues haven't been looked at yet by a maintainer labels Nov 6, 2023
@jonnylink
Copy link
Author

Thanks for the feedback Albert. I suspected that this would be the reason it isn't working correctly. It still seems like it should be possible for components to adhere to expected behaviors.

@mj12albert mj12albert added this to the Material UI with Base UI milestone Dec 4, 2024
@mj12albert
Copy link
Member

Base UI will have Form/Fieldset/Field to solve this: https://master--base-ui.netlify.app/components/react-fieldset#usage-with-fields

@mj12albert mj12albert removed their assignment Dec 5, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
component: select This is the name of the generic UI component, not the React module! enhancement This is not a bug, nor a new feature package: material-ui Specific to @mui/material
Projects
None yet
Development

No branches or pull requests

3 participants