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

[Inputs] Styles should prioritize disabled over readOnly #8239

Open
nickofthyme opened this issue Dec 13, 2024 · 4 comments · May be fixed by #8271
Open

[Inputs] Styles should prioritize disabled over readOnly #8239

nickofthyme opened this issue Dec 13, 2024 · 4 comments · May be fixed by #8271
Assignees
Labels
design decision feature request help wanted The EUI team is looking for community members to pick up and implement this issue low hanging fruit An issue, often a bug, that is lower effort and clearly ought to be fixed

Comments

@nickofthyme
Copy link
Contributor

nickofthyme commented Dec 13, 2024

Is your feature request related to a problem? Please describe.

Related to #8238, a solution to this would be to set readOnly whenever disabled is set, so something like this...

const MyCustomInput = ({ disabled, readOnly }) => (
  <input
    type="text"
    disabled={disabled}
    readOnly={readOnly ?? disabled}
  >
)

The issue in this case is that the current styles prioritize readOnly whenever both readOnly and disabled are applied together.

Image

See demo https://codesandbox.io/p/sandbox/adoring-christian-jk8t45

Describe the solution you'd like

The input styles prioritize disabled over readOnly. This is the same behavior as the basic html input.

Describe alternatives you've considered

An alternate fix to #8238 would be to just check disabled before triggering onChange from a consumers perspective, but this is not ideal.

Desired timeline
Unknown

cc: @MichaelMarcialis

@JasonStoltz JasonStoltz added the help wanted The EUI team is looking for community members to pick up and implement this issue label Dec 17, 2024
Copy link

👋 Thank you for your suggestion or request! While the EUI team agrees that it's valid, it's unlikely that we will prioritize this issue on our roadmap. We'll leave the issue open if you or anyone else in the community wants to implement it by contributing to EUI. If not, this issue will auto close in one year.

@JasonStoltz
Copy link
Member

We estimated this as a Large size effort because of the potential impact on Kibana and the potential to break a large number of FTR tests.

@nickofthyme nickofthyme linked a pull request Jan 13, 2025 that will close this issue
12 tasks
@nickofthyme
Copy link
Contributor Author

@JasonStoltz That does not appear to be true.

I made the changes in #8271 then built, packed and install them in kibana, see elastic/kibana#206372. The CI passed just fine, minus a few flaky tests.

In general, I don't think tests assert the applied styles, rather they assert that the attribute is present.

expect(getByText(/Click me/i).closest('button')).toBeDisabled();

@nickofthyme nickofthyme self-assigned this Jan 13, 2025
@tkajtoch
Copy link
Member

After revisiting this issue, I think we should just go forward and prioritize readonly over disabled look and feel to match the native UI. This is a small effort.

@MichaelMarcialis just to make sure - are you fine with this change from the design point of view?

@tkajtoch tkajtoch added the low hanging fruit An issue, often a bug, that is lower effort and clearly ought to be fixed label Jan 14, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
design decision feature request help wanted The EUI team is looking for community members to pick up and implement this issue low hanging fruit An issue, often a bug, that is lower effort and clearly ought to be fixed
Projects
None yet
Development

Successfully merging a pull request may close this issue.

3 participants