-
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
Add a way to identify which .JSON style variation that is in use #43405
Comments
+1000 for this. Thanks for opening an Issue. 👏 |
If I understand correctly, the resulting styles from the variation.json is stored as a revision of the original wp_global_styles database entry, but the data does not include the variation file name, which we would need to determine which variation is in use. |
I'm going to test out @pbking PR this week and drop any feedback. I wonder if this may be considered for WP 6.4 release? |
I would love to hear input from @mikachan @annezazu @richtabor @carolinan on whether this might be considered for the WP 6.4 release. It seems like a simple enhancement for extenders, but sometimes, the tiny things offer nuance and complexity 😄 |
The last Gutenberg release that's scheduled to be included with WP 6.4 is 16.7, and the RC for this is being released tomorrow, so I don't believe we have enough time to get this into WP 6.4 I'm afraid. Please correct me if I'm wrong! This will be a great enhancement when it lands. |
That makes sense 👍 |
I've noticed that #51512 has just been approved, so when this is merged I'm happy for it to go into GB 16.7 for WP 6.4 🎉 I'm sorry that I didn't spot this before I ran the 16.7 RC process, but happy to cherry-pick this into the 16.7 release when it's merged. |
@mikachan no worries! There are a lot of moving pieces and we never want to rush things. I appreciate the response and clarification. 🤘 |
Why is this necessary again? I’m not following. |
|
You shouldn't need that much custom CSS (ideally none, but we're getting there), especially for a variation of a theme. And I don't think most folks need the variation title in the body class name. I think it's fine to have an easy way to get the active variation title, but not append it to the body class. Then if the developer wants to do add it to the body, they can easily enough. |
Not without the change to the variation setting in the PR. |
In what way is the body class damaging? It already outputs data that only some people will use: |
@richtabor I'm not clear on the hesitation for introducing this functionality. Even after reading this and this.
I would add that JavaScript is a possibility here too and not just CSS. JavaScript that targets the additional
Yes.
This is anecdotal. I've been asked several times by extenders about this functionality and this is why I wrote a post for a workaround. |
FWIW, access to the variation name/slug is one of the most-requested features by theme authors I've talked to who ship style variations. It's one of the reasons I still push child themes, even in cases where they wouldn't be necessary. They're generally less concerned about the I mostly agree that you shouldn't need much custom CSS for variations. Most CSS overrides in variations can happen via the |
That's very specific to a functionality not available in WordPress core, but extended upon. I'm all for making it easier for developers to add a variation class to the body tag — but not a wholesale approach that's not needed for most folks.
Yes, let's make it easy to get the variation slug/filename/title (whichever makes most sense; can't change/break things when edited is a big consideration). But not auto-apply it to the body tag. Make room for developers to do that easily. |
There are two pieces of functionality at play here:
I do agree that the first is more important and would allow extenders something to hook onto. The second item is less crucial. I would be fine with just the slug being surfaced. |
This additional explanation helps land some of the nuance here and I appreciate @richtabor offering additional clarity. ❤️ |
So is there a way yet to access the variation slug/filename/title? And if not is there any timeline for this? |
Something like this? class Styles {
public function __construct() {
add_action( 'admin_init', [ $this, 'variation_styles' ] );
add_filter( 'body_class', [ $this, 'body_class' ] );
}
public function variation_styles() {
$variation = wp_get_global_settings( [ 'custom', 'variation' ] );
if ( empty( $variation ) || is_array( $variation ) ) {
return;
}
$file = '/styles/css/' . $variation . '.css';
$styles = file_get_contents( get_theme_file_path( $file ) );
if ( $styles === false ) {
return;
}
wp_add_inline_style( 'core-block-supports', $styles );
add_editor_style( $file );
}
public function body_class( $classes ) {
$variation_class = wp_get_global_settings( [ 'custom', 'variation' ] );
if ( empty( $variation_class ) || is_array( $variation_class ) ) {
return $classes;
}
$classes[] = 'is-variation-' . $variation_class;
return $classes;
}
}
new Styles(); |
Hey folks 👋 We needed a quick workaround for it in our Course theme. This is how we ended up solving it for us for now Automattic/themes#7432. Just wanted to share our approach in case you wanted to take a look <3 |
Related #62686 |
There should be a way to identify which theme.json style variation that is in use:
is-variation-name
,has-variation-name
or similar.The text was updated successfully, but these errors were encountered: