-
Notifications
You must be signed in to change notification settings - Fork 4.3k
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
a11y: Respect prefers-reduced-motion for all animations #68282
Comments
Hey @t-hamano, Thanks for raising this. I will raise a PR to fix this. |
@himanshupathak95 Thanks for addressing this issue. If you don't mind, could you provide some screenshots of which components each of the reduce-motion mixins affects so we can make sure they work as expected? Also, you don't need to tackle them all at once. If there are too many to tackle, you can tackle them package by package. |
@t-hamano, I am thinking of doing this package by package since there are a lot of places that need to change and there must be distinction amongst them to test and discuss each package correctly in isolation. I am thinking maybe we can create separate PRs to track packages specifically and execute the changes so we don't break anything. Please let me know what you think. |
Yes, I think it's a good idea to submit a PR for each package 👍 |
No strong opinion, but I wanted to note that in @media not ( prefers-reduced-motion ) {
transition: all 400ms linear;
} It isn't any less ergonomic, it's immediately understandable without knowledge of a custom mixin implementation, and we end up with fewer lines of CSS. Would it be worth considering this pattern for the wider codebase as well? |
@mirka Thanks for the feedback!
That's a good idea. I think it might be better to proceed in the following order:
|
It turns out that this formatting isn't available in the sass version used by Gutenberg. I've submitted a PR to update the sass: #68380 |
@Mayank-Tripathi32 Can the block library PRs be consolidated into one or two PRs? Otherwise, there will be too many PRs. For other packages, if the changes are small, I think it's ok to consolidate multiple packages into one PR. |
@t-hamano, In my former PR, as I mentioned earlier, I have consolidated all the changes to the block library. I think it's better to consolidate the changes else as you correctly mentioned there will be too many PRs with small changes. |
@t-hamano cherry-picked all the branches into #68413, please have a look |
If you work on this issue, I recommend that you also check that |
reduce-motion
mixin
Thanks to everyone working on this issue. I've scanned the whole project, and once all the current dubmitted PRs are merged, all the work should be done. @Mayank-Tripathi32 @im3dabasia Feel free to let us know when you're ready to publish your PR. |
@t-hamano I encountered some difficulty in locating all the component implementations for testing. Do you have any suggestions or tools to help test the PRs more efficiently? |
@Mayank-Tripathi32 If the component that the CSS is applied to is exposed in Storybook, you'll be able to use that to test it, if not, you'll probably need to parse the code to figure out where it's actually used. |
What problem does this address?
If we use transition or animation CSS, we are expected to use the
reduce-motion
mixin. Example:This code compiles to the following to respect the user's preference and disable animations:
However, there are many places where
transition
oranimation
is used without this mixin.What is your proposed solution?
We could update stylelint to enforce this rule, but since this is a custom rule, we would need to add our own plugin. I'm not sure if it would be worth creating a custom plugin to enforce this rule. For now, I think it's best to find the missing mixin and add it.
Steps to get started
transition:
oranimation:
in the.scss
files in the Gutenberg project.none
.reduce-motion
mixin exists. If it doesn't exist, we may need one.reduce
.https://developer.chrome.com/docs/devtools/rendering/emulate-css#emulate_css_media_feature_prefers-reduced-motion
Update: We aim to use standard patterns across projects rather than using mixins.
Submitted PRs
The text was updated successfully, but these errors were encountered: