-
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
Allow creating custom block templates in classic themes #30438
Conversation
Size Change: +827 B (0%) Total Size: 1.42 MB
ℹ️ View Unchanged
|
This PR is not ready yet but it's ready to get thoughts and designs. |
I think that would be necessary in many situations... and it should also be filterable so users can install a plugin to enable it on their old, not-updated theme. See PR #30465 for a suggestion |
Thinking about the theme-support thing some more, perhaps it should be opt-out instead of opt-in? 🤔 I believe opt-out would make more sense... (updated the PR on #30465 to reflect that) |
* Change the prefix for custom templates * Update comment
* Introduce gutenberg_is_fse_enabled * typo & reverse logic * update filter name * Remove filter * Rename function * don't use "disable"theme-supports * rename theme-support
What an intriguing PR! I am using the Twenty Twenty One theme. Then followed the instructions added by Riad. |
If there is a theme.json file with template parts assigned to template areas, I think those header and footer template parts should be included, but it is too early to guess if these themes will include a theme.json or not. I think the UX needs to be improved and that the option needs to be integrated somehow with the existing "page attribute" where you select templates, but this would work for a POC and first version. |
I've added an e2e test and a paragraph to docs to opt-out of this and also added some site blocks (site title, logo, tagline) to the default template. I agree that the flows and design need to be iterated on. What do you think. Ship it or not? |
Yes!! |
Then click the green button :P |
3853828
to
d64964a
Compare
From my perspective this feature is a good one to have. Merging a bare bones version seems like a good idea. Of course there are a lot of followups based on the tests that I shared that needs to be done, but that is something one gradually can get to through various PR's. Thanks for creating the PR, Riad! |
d64964a
to
7006394
Compare
@@ -177,3 +177,4 @@ function register_site_icon_url( $response ) { | |||
add_filter( 'rest_index', 'register_site_icon_url' ); | |||
|
|||
add_theme_support( 'widgets-block-editor' ); | |||
add_theme_support( 'block-templates' ); |
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.
@youknowriad I find this part a bit unexpected. Why are we unconditionally declaring theme support in the plugin/core? 🤔
If we want to have this active by default, we could remove the theme support part altogether, and modify the activation checks to use the filter for opt-out, instead of:
Theme authors can opt-out of this feature by removing the
block-templates
theme support in theirfunctions.php
file.
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.
This is something I explain here #30465 (comment)
Instead of having a "disable-something" theme support, Core prefer to have theme supports enabled by default and plugins/themes can do remove_theme_support
as it reads better. Adding a theme support calls "disable-something" doesn't read very well.
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.
Thanks for clarifying! While reading the activation conditions I assumed that this will be only enabled for themes that explicitly declare support, so I was a bit surprised afterward when I found out in testing that it actually works for all themes.
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.
yes, I the moment, this is opt-out because we want people to experience this, depending how the betas of WP go though, we might reconsider.
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.
To close the loop, #32858 makes it opt-in on classic themes and opt-out for themes using theme.json.
The idea of this PR is to allow creating custom block templates (starting blank) for a given page in classic themes. It's a way for classic themes to enable some FSE features without any change.
How to test it
It's very rough at the moment, more a POC, but here's how you do it:
Now, on the frontend, your page is using its own custom template and not the regular
page.php
orsingular.php
that comes from the theme itself.Notes
This PR can be seen as a migration strategy for classic themes, it highlights a few things in terms of code/architecture:
Todo