-
Notifications
You must be signed in to change notification settings - Fork 219
Explore if we can limit the Legacy Template block to only show in the block inserter on Woo block templates #5193
Comments
@frontdevde I did a bunch of research, here is what I found as a conversation starter: 1. Enabling a block in the inserterThis is, theoretically, as simple as setting: This is because the legacy template block has been abstracted and its default properties as seen by the inserter are here: While we hard-code the template type in the blocks themselves. See: So, at the moment, there is no front-end way to change that as that attribute is not exposed in the editor AFAIU. That means that, even if we solve the issue which is the focus of this research, we'll have to decide how to handle that: do we show a dropdown in the attribute sidebar? Do we show them as separate blocks in the inserter? I suppose we'd also have to limit which one we show depending on the location. 2. Conditionally enabling the inserterI did scour around whatever we could have had available to do something like that. Initially, I was happy to find some useful data in the {
editedPost: [{
type: "wp_template",
id: "tt1-blocks//taxonomy-product_cat",
page: {
context: {
templateSlug: "taxonomy-product_cat"
}
}
}]
} Unfortunately, this data is not available at the time we register our blocks, but is hydrated a bit later through the However, I noticed that import { getQueryArg } from '@wordpress/url';
const url = window.location.href;
const postType = getQueryArg( url, 'postType' );
const templateSlug = getQueryArg( url, 'postId' ).split( '//' )[ 1 ];
const ALLOWED_LEGACY_TEMPLATES = [ 'archive-product', 'single-product', /* ... */ ];
const isAllowedInInserter = postType === 'wp_template' && ALLOWED_LEGACY_TEMPLATES.includes( templateSlug );
// ...
registerBlockType( 'woocommerce/legacy-template', {
supports: {
inserter: isAllowedInInserter,
}
}); Of course, this still means we'd have to take in consideration what's mentioned in (1.) above. 3. AlternativesOther than this, I couldn't find any other data which is already exposed either in any data store, nor in globals which I know of that's any useful to determine where the user is within the editor. However, if the URL approach above is not deemed solid enough, we could expose some useful data from the server through the In this way we can definitely find the best and most solid approach. ConclusionAs far as I understand, the goal of this issue was more the research spike and exploration itself than the implementation. If that's the case, I'd say the answer to the question posed in the OP is: yes. There are ways in which we could limit how legacy blocks show up in the inserter depending on where the user is. None of them are a one-liner, though. The follow-up questions would then be:
|
Thanks for looking into this, @sunyatasattva!
That is correct!
Operating under the assumption that we would want users to only be able to use a block template that is relevant to their context, showing them a dropdown with all options is probably not ideal. So we'd want to look into the latter. Note: if the above assumption holds true, we'd want users to only have access to the one block template that is relevant to their current context. This would mean regardless of what shows in the inserter, it would have to show the context-relevant block template upon insertion. Thinking out loud here, maybe this could be achieved by registering a block variation for each template and only surfacing the context-relevant variation in the inserter. If I understand you correctly you're already thinking along these lines.
Nothing more permanent than temporary solutions, right? 🙂 Jokes aside though, if there were a quick and clean solution, I'd argue for implementing it. If we feel like there isn't really, we should hold off to see how much user feedback we get of this being an actual problem. Based on what you found, if you had to make a call, what would you recommend? |
Great work investigating and presenting us all of the above options @sunyatasattva!
If we have the ability to do this, we could further reduce the scope of the work by leaving the Legacy Template block as-is and once inserted we then immediately set the template attribute depending on its context. This means we don't have to do any filtering on blocks in the inserter to ensure only the correct variation is present. |
Thanks both of you for the replies!
I'd probably go with the fastest-to-implement solution. Adding more fine-tuned data from the server seems prone to polluting the scope and easy to forget when we move on. The solution proposed by @tjcafferkey is my favorite: we show one block in the template and it automatically gets the correct attribute upon insertion. I wouldn't know exactly how to react to insertion, however, so I'd appreciate some guidance/pairing there if I have to implement it. Otherwise, surfacing only the appropriate one in the inserter seems also doable and I might have a clue on how to make it work :) |
We could use |
Here is a proof of concept of my idea but we would need to limit the legacy template block to only show up on the inserter for Woo templates. Edit: I've added a bit of a hack for the inserter issue mentioned above. It works but I am open to better work arounds for that part of the problem. |
Reopening this issue as we had to revert the PR that closed this #5643 |
This issue has been marked as Internal: After 10 days with no activity this issue will be automatically be closed. |
For full context of the overall issue please take a look at #5180 first.
Following another round of testing of the 6.3.1 release, we decided to revert our previous decision to prevent the block deletion of the Legacy Template block, as this had the unintended side effect of limiting the user's creative ability to create compelling templates.
The goal of this issue is to explore (research spike) if there's a way to limit a block to only appear in the block inserter on specific block templates. It'd be the preferred solution for only showing the Legacy Template block in the block inserter on Woo block templates.
If that's not possible, it might potentially be easier to implement hiding the block from the inserter in the post/page editor but show it in the site editor.
The text was updated successfully, but these errors were encountered: