-
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 template duplication + concept of active templates #67125
base: trunk
Are you sure you want to change the base?
Conversation
The following accounts have interacted with this PR and/or linked issues. I will continue to update these lists as activity occurs. You can also manually ask me to refresh this list by adding the If you're merging code through a pull request on GitHub, copy and paste the following into the bottom of the merge commit message.
To understand the WordPress project's expectations around crediting contributors, please review the Contributor Attribution page in the Core Handbook. |
9e9eafc
to
1d75cf3
Compare
Size Change: +1.34 kB (+0.07%) Total Size: 1.84 MB
ℹ️ View Unchanged
|
name === 'wp_template' && | ||
typeof key === 'string' | ||
) { | ||
name = '_wp_static_template'; |
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.
Is the _
at the beginning necessary?
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.
We can change it to whatever we want. I was wondering though if we should make the endpoint private by making it a random path. But the post type can stay the same.
@@ -187,9 +296,13 @@ export default function PageTemplates() { | |||
context: 'list', | |||
} ); | |||
const editAction = useEditPostAction(); | |||
const setActiveTemplateAction = useSetActiveTemplateAction(); |
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.
Why is this action defined here and not in the "fields" package like all the other actions?
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.
Cause I didn't really know where they should be defined.
205296d
to
0676add
Compare
Flaky tests detected in 0cb1a2d. 🔍 Workflow run URL: https://github.com/WordPress/gutenberg/actions/runs/12558533055
|
Pinging @WordPress/block-themers and @WordPress/outreach to get as many eyes on this as possible :) And help testing this would be much appreciated! |
One possible option would be to consider these "custom page templates" as always active (you can't really disable them). I noticed that right now, you can active/deactive them but it doesn't do anything really and they don't show up in "active templates" either. |
@youknowriad Yes, we should think about those.
Maybe some in-between state. "Active on a page" would be a bit long. We're seem to be calling these elsewhere "for a specific item", so maybe a gold badge with "Specific"? Not sure. It would be good if you can hover over the badge and see more info.
Yes, it's complex, because there's two scenarios: either you assign an existing template to be the page template. In which case the template in not active except for this specific page. Or you create a new specific template that has the slug I think we should do something here in this PR, but there's probably some details left to figure out later. |
For example, one option is to deprecate |
I found myself missing a way to name the templates that I create. I believe we need to:
I think this is the kind of details that can be addressed in a follow-up though, once the whole mechanic and UX is agreed upon. |
This is very cool. Some initial observations: After building this branch, a bunch of templates appeared in the 'Custom templates' section, many of which are duplicates of the same template. It's not clear why. Perhaps they're revisions? The point being that we should think about the upgrade process, expected results etc. Something feels wrong with the logic around the active state of the Front Page template. I have one (several actually, see previous point) in 'Custom templates', but none of them are active. It doesn't appear in 'Active templates' either. It seems to be ignoring the template hierarchy, maybe that's intended? :) I'm able to click into and 'edit' theme templates. Two issues around this; it's not clear what happens, I assume the template is duplicated, but is it also activated? It's inconsistent with theme patterns, which are entirely uneditable until duplicated. In general I think this part of the UX needs more thought, but for the initial implementation perhaps they should be consistent to help unify the concept? Potentially a big can of worms, but communicating the template hierarchy in the UI is quite challenging :) As a provocation, and to define the scope of design, do we need to do that with custom templates? Theoretically could any template be assigned to any page? I suppose this relates to the previous point about the 'Front Page' template. For The A couple of very small points on the design;
|
That is weird, it shouldn't be happening since you can only have one custom template per "hierarchy slug" in trunk. I wonder if you had some lingering broken templates (that were hidden in trunk) from very old branches or something.
I think it probably relates to the previous point. I think upon upgrade, all user templates should be "active" by default.
I agree, I think for me the ideal is to be explicit about what's happening (no edit) but there are some challenges with that:
|
@@ -170,7 +171,7 @@ const getNavigationCommandLoaderPerTemplate = ( templateType ) => | |||
return { | |||
isBlockBasedTheme: | |||
select( coreStore ).getCurrentTheme()?.is_block_theme, | |||
canCreateTemplate: select( coreStore ).canUser( 'create', { | |||
canCreateTemplate: select( coreStore ).canUser( 'read', { |
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.
Why did we change the perm? Seems natural to check for create in canCreate...
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.
Why? The commands are meant to navigate to templates, not create new 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.
But yes this variable should be renamed 😃
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.
I agree that using the create
capability check here is odd but necessary. Users who can read templates might not have access to the Site Editor.
See #60317 (comment).
P.S. We should extract similar minor and unrelated fixes into separate PRs. There's already a lot going on here and that would make reviewing bit easier.
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.
Then this check should be called differently and we should use something else to check if the user has access to the site editor. This is not a good proxy for checking site editor access, it is more restrictive now. Also we should then use it as a condition to prevent all site editor commands from loading?
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.
Also we should then use it as a condition to prevent all site editor commands from loading?
It's hard to generalize it. The Site Editor needs more granular capability checks, but those should be mapped out separately - maybe even incorporated into the router.
As I mentioned, I would remove and extract similar fixes into separate PRs.
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, here the change is necessary because you cannot create
static templates through the endpoint, you can only create custom 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.
So I guess we need another additional check, not sure what
The following accounts have interacted with this PR and/or linked issues. I will continue to update these lists as activity occurs. You can also manually ask me to refresh this list by adding the Unlinked AccountsThe following contributors have not linked their GitHub and WordPress.org accounts: @erikjoling. Contributors, please read how to link your accounts to ensure your work is properly credited in WordPress releases. If you're merging code through a pull request on GitHub, copy and paste the following into the bottom of the merge commit message.
To understand the WordPress project's expectations around crediting contributors, please review the Contributor Attribution page in the Core Handbook. |
9b8d5bd
to
b0537eb
Compare
b0537eb
to
2b0264c
Compare
7f3f955
to
458a82f
Compare
Fixed with the migration.
Added renaming.
You mean viewing the theme's template, then modifying and saving? Yes, it will take over the theme as the author. I think that's fine? Can be changed later if needed. |
Worth mentioning:
|
I left these things out for now because I think it's all polish and not essential, and to keep this PR as small as possible. |
To clarify the above comments, there are in my understanding 3 types of templates:
So imo, when adding it in the future, the "Used" (or whatever) label will have to be separate from the "Active" label, and we might need to improve the wording. |
Maybe deactivating these means, you can't actually select them and if they were selected, they get ignored by the rendering algorithm? So for a "theme" provided one, it's the same behavior as "deleting the file". |
You mean they are ignored by even if they are used by specific pages? But then that also means that deactivating other kinds of templates can mean two things: deactivate in the hierarchy and deactivate for specific pages. Perhaps when clicking "deactivate", in the future there should be a modal with checkboxes where you can fine tune it. |
I'd love to get this merged, but let's see more opinions on it. I think most bugs and issues will come from things that weren't previously possible before, so honestly I don't think it's a big deal. |
I feel like the simplest for users would be to just "always disable for everything" (hierarchy and specific pages) regardless of template. |
Apologies as I haven't caught up on the above feedback but wanted to take some time to explore this. In testing this, it's not clear that when deactivating a template where that template then goes. I eventually realized, I needed to look at "Twenty Twenty Five" but I don't think that's clear. I also would expect more friction in deactivating a template with some sort of a warning considering this isn't an action I expect people to take very often and it is, in a way, destructive. unclear.where.deactivated.template.goes.movRelated to this, I find duplicating to be a bit confusing as is since you duplicate but then don't see the template you just created. Perhaps we can have the snackbar have a link where you can see where the template you just took action on went? duplicate.template.movI find the differences in three dot menus to be confusing as well, depending on if you're looking at active templates vs custom templates. Shouldn't we at least show an edit option in both places? three.dot.menu.movIn any case, when we do merge this, I'd encourage putting it behind an experimental flag potentially and doing a call for testing (I can help with that) to refine it a bit further before releasing it fully. I imagine there's stuff we haven't yet caught. |
Creating a new PR to squash all commits and preserve the history of #66951.
What?
Fixes #66950.
Why?
See above.
How?
active_templates
that contains a maps of slugs to active template IDs. To disable default templates, it can be set tofalse
.auto-draft
user template is created behind the scenes in case edits are made. If no edits are made this disappears. The active template is also set to the draft. If the user makes edits and wants to save it, changing active templates can be unticked in the multi-entity saving panel. There's potential to improve the UX here with this new paradigm.Testing Instructions
Testing Instructions for Keyboard
Screenshots or screencast
Screen.Recording.2024-11-13.at.09.20.16.mov