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

Focus ring helper and utilities #33125

Merged
merged 13 commits into from
Dec 29, 2022
Merged

Focus ring helper and utilities #33125

merged 13 commits into from
Dec 29, 2022

Conversation

mdo
Copy link
Member

@mdo mdo commented Feb 16, 2021

  • Adds new global Sass variables for :focus styling
  • Reassigns $input-btn-focus-* variables to new global variables (come v6, we'll simplify these variables)
  • Adds focus styles to all navigation styles (including base .nav, .nav-pills, and .nav-tabs)

Closes #32357.

Live previews

@ffoodd
Copy link
Member

ffoodd commented Feb 17, 2021

Loving the way you did this.

Couldn't we jump on the opportunity to improve our overall focus styles, regarding non-text contrasts? @MartijnCuppens's suggestion in #29422 (comment) using two solid shadows (also pretty much what's done in Boosted, however using outline) — and followed by some references in my own next comment in that thread — would be quite easy to implement and apply everywhere with this new focus variables superset, wouldn't it?

Might also wait for another PR, but IMHO it'd make a lot of sense.

@XhmikosR
Copy link
Member

I'm all for having a consistent focus style, but wouldn't this be considered a breaking change for some people?

I mean, we've seen numerous times people asking how to drop focus styles because they probably don't know that they shouldn't, unless they provide some kind of replacement.

@ffoodd
Copy link
Member

ffoodd commented Feb 22, 2021

Well, this is another consideration that's unrelated to the kind of focus styles we set.

Dropping the focus styles while ensuring accessibility requires :focus-visible, and even if we don't implement it as of now my latest PR using the polyfill might be given as an example for such questions.

However depending on how we'd like to implement a new focus style, we need caution to prevent BC. That might not be possible, didn't try that much.

@mdo
Copy link
Member Author

mdo commented Feb 26, 2021

Taking off Beta 3—let's discuss further and figure out a plan :).

Copy link
Member

@ffoodd ffoodd left a comment

Choose a reason for hiding this comment

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

Coming back to this, it's really helpful and should be shipped, so :shipit:

We'll try to improve our focus styles later 👍

@mdo mdo force-pushed the global-focus-vars branch from 433a148 to ebd385f Compare November 26, 2021 00:15
Copy link
Member

@ffoodd ffoodd left a comment

Choose a reason for hiding this comment

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

Looks good!

Could be a great opportunity to handle double shadows to improve focus indicator contrasts too, and maybe use :focus-visible as a progressive enhancement?

I keep this in mind for later 👌

scss/_nav.scss Show resolved Hide resolved
@ffoodd
Copy link
Member

ffoodd commented Nov 30, 2021

Oh and we already had this discussion, obviously 😅

@mdo
Copy link
Member Author

mdo commented Dec 1, 2021

Thanks @ffoodd! Going to wait for v5.3.0 for this—want to see where I can build this into our other components with additional CSS variables.

@mdo
Copy link
Member Author

mdo commented Nov 14, 2022

@julien-deramond Tried resurrecting this one—still needs a bit of work to apply the updated focus shadow to other components. Maybe that could wait until later though, like in v6, and we just have an extra helper/utilities for now?

Copy link
Member

@julien-deramond julien-deramond left a comment

Choose a reason for hiding this comment

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

I haven't looked at all the source code yet but do we plan to have also a focus-visible-ring utility?


## Example

Click into the example below and press <kbd>Tab</kbd> to see the focus ring in action.
Copy link
Member

Choose a reason for hiding this comment

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

Maybe we can tell that users can also simply click on the link to see the custom focus ring. IDK if it can be helpful but we could also remind folks that :focus is for keyboard and mouse in the description.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
No open projects
Status: Done
Development

Successfully merging this pull request may close these issues.

5 participants