-
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
Use the Style Engine for global-styles #42592
Conversation
$layout_selector, | ||
array( | ||
array( | ||
'name' => 'display', |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
While I think of it, one potential issue with this one is that display
is being manually injected here because it is not included in the allow-listed list of CSS properties (here's the core PR: WordPress/wordpress-develop#2928 where display
was discussed), so it has special handling here to determine that the value is from a hard-coded list of valid display modes.
Do we need to have a mechanism to allow potentially unsafe declarations to bypass calling safecss_filter_attr
? I'm imagining some kind of approach where we can say to the style engine (at some point), here is an already validated declaration, please trust it 😅
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Do we need to have a mechanism to allow potentially unsafe declarations to bypass calling
safecss_filter_attr
?
We kind of already have that... 😉 I was allowing CSS variables in the Declarations
object in this PR, so I added display
when the value is not none
(I believe display:none
is the reason we don't allow display
in safe-css, so this implementation accounts for that scenario)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
For context, check out the tweaks in packages/style-engine/class-wp-style-engine-css-declarations.php
in this PR. If the property starts with --
it skips safecss_filter_attr()
(to account for CSS variables), and the same thing happens for display
if the value is not none
👍
e29310a
to
28342e4
Compare
8ebaf85
to
326aca1
Compare
After #42452 was merged, it's impossible to get this PR to a working state (well actually not exactly impossible, but it would take me days to refactor). |
Sorry! If you want to save yourself some refactoring grief, I suspect that migrating global styles and the theme json class to the style engine isn't targeted for 6.1 anyway, so we can revisit this work after September, or whenever the code freeze is. |
Well, we can definitely take the first step, without completely refactoring global styles! #42893 makes use of the style engine in a simple way, taking advantage of some improvements that style-engine implements but without all the hassle of a refactor 😉 |
What?
Uses the Style Engine objects in global-styles.
Why?
body { margin: 0; } body { color: #000; }
becomesbody { margin: 0; color: #000; }
. Similarly, if 2 selectors have the same styles, they get combined. So.foo { color: red; } .bar { color: red; }
becomes.foo,.bar { color: red; }
.body { color: red; } body { color: black; }
, the new output will bebody { color: black; }
keeping only the last item which overrides the previous ones.How?
Converted the string-concatenation method in global styles with style-engine objects and methods. This required adding new methods to get the stores. For example, we previously had a method called
get_css_variables
, which was generating the styles for CSS variables. This PR added a newget_css_variables_store
method, moved & converted the previous code in there, and then theget_css_variables
method simply gets the store fromget_css_variables_store
and returns the CSS from said store. This was done for all methods that required it.Some tweaks were also made to the Style-Engine objects to ensure sanitization & all props work properly.
There were a few failing tests because the generated CSS is different. I went through all instances of failing tests, manually compared the before/after results and confirmed that they are identical - the only difference being whitespace changes and the optimizations outlined above (combining selectors & deduping styles).
Testing Instructions
I manually tested it thoroughly... Used a few block themes, opened a site on trunk, copied the generated styles on trunk to my editor. Then switched to this branch, repeated the process, and finally compared the 2 CSS snippets.
There were no visual differences in the browser, and the CSS diff was the reasonable optimizations that I would have made if I were manually trying to optimize the styles.