-
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
The wp:pattern
block
#48458
Comments
+1. Ever since the pre-block era, I've wanted an instantiable thing in between patterns and custom (innner-enabled) blocks. There were whole communities around "parts-based" classic themes using cruder tools of the day, and widget architecture was never quite enough. I'd like a souped-up wp:pattern to support a Javascript hook (preferably ESM enabled), sort of like what was added to block.json. Would open many options and DX improvement too. |
I dabbled with a solution to this but didn't quite get there. I tried creating a post type for creating layouts. In these layouts I would add some layout blocks and some content. I would also add a custom "slot" block wherever I wanted to be able to add editable content when using the layout. The idea is this:
The layout works like the wp:pattern block. It server side renders all of the rendered html and creates InnerBlocks areas wherever there are slot blocks. Imagine a block version of |
@mfinell This is exactly the missing link of what is needed (IMHO). I'd love see this in action :) |
@mfinell There was a good example of your "slot" idea reported at #50060. Did you end up implementing it, or is it just an idea? |
The video above suggests that the "sync" attribute is something you define in the reference pattern while I think it's something that should be defined in the "instance". Also, I think we should still keep the difference between "fully synced" and "partially synced", because that's a behavior that existing reusable blocks rely to and we can't just update it without notice. |
@youknowriad can explain full vs partial syncing behaviour from a users perspective? What's the difference? I may not have a complete picture of existing experience. Re sync attribute on reference vs instance. I was originally leaning towards the direction you suggest (prompting to sync on insertion) but the more I've thought about this the more I think that would be a difficult transition to make from the way reusable blocks and patterns currently work (UX not technically). I was hoping there would be a natural pathway towards that point if it makes sense in future. |
@SaxonF The difference is that when "full sync" is applied, the entire pattern is used as is with no change, any change made to the pattern is also applied to all the instances that are also "full synced" including "content". |
@youknowriad sorry I was referring to existing reusable block behaviour. We don't have partial syncing do we? You could just lock all layers by default so the experience is reversed ie blocks are marked as overrideable by unlocking them |
A fully synced pattern is what we today call a Reusable block (in the future, this pattern could also be sourced from the Pattern Directory, the theme, or registered by the site). You can edit every aspect of the block in a single place, and it gets propagated in all places on the site (or sites for patterns from Pattern Directory). A partially synced pattern is going to be a combination of the source pattern that provides the design. The design could be sourced from a static representation of the pattern from the Pattern Directory, from the theme, or from another fully synced pattern (Reusable block). The nuance here is that the user would be able to override locally the content displayed in the pattern. Still, all the changes applied to the design externally would get dynamically reflected on the site. |
It's important to note that "locking editing" and "syncing" is not the same at all: locking only applies in the editor (in fact you can even edit everything in the pattern if you go to the code/HTML view) while syncing is about "rendering" (applies both in editor and in frontend). |
I was personally imagining the opposite 😄 With the idea being that for editorial flows, a design team can create a pattern, and an author can fill it out without messing with the design. What are the use cases for the other way around? It could also be both, the pattern creator can define what the inserter of the pattern can do, but maybe that's too complex.
I quite like this idea (although I haven't really thought about implementation 😆 ), kind of like the pattern would have locked/synced islands of blocks, but the rest is freeform. It removes the simplicity of the editing experience (editing is the same as any other blocks rather than using content only mode), so I think we need more understanding of the motivation behind content only mode. For me, content only mode is great as it makes the implementation of partial syncing much easier, but as Riad has mentioned it is really a separate concept to partial syncing, though one we lean on. |
Great exploration. From an UI perspective I have only on concern so far. I'm not sure the 'Edit pattern' button shoul dbe placed within the Settings sidebar. The Settings sidebar should only contain complementari settings and secondary actions. All basic operations like editing should be available in the main interface. This is a principle that was established long time ago, for good reasons of usability and accessibility, and it's mentioned in a few places in the documentation as well, for example here and here. While the documentation mentions the Block settings sidebar, the general principle still applies here. |
If I can offer two cents as an agency developer working daily on building Wordpress sites/custom themes for business clients:
|
+1 to this comment. The block editor is both used as a design tool and a writing tool. Global styles and theme.json help maintain consistency across a site but patterns don't offer anything in the way of design consistency. The more you use a pattern, the more places you need to go and manually update the pattern. In most cases the site designer is concerned with updating styles and not content. The site editor/writer would care more about consistent messaging/content. |
Note
This is an integral part of the block API #41236
Pattern block tracking issue - #50159
We've so far treated patterns as a block instantiation feature but not a permanent object. This was a useful lens with which to introduce patterns and enabled many workflows (like copy and paste from the directory) without adding further edges to the block API. With time, we also introduced a utility block called
wp:pattern
to allow block theme authors to reference individually registered patterns dynamically, which has also helped with translations.There are a series of upcoming features around #39281 we want to unlock that now require us to look more seriously into making this block fully powered:
templateLock
iscontentOnly
#44581contentOnly
property further to establish a set of attributes (role == content
) that the pattern is then injected with dynamically.theme.json
child objects to define a new set of style properties that only apply to the pattern contained within.All of these features can be better conceptualized with the help of such a block.
Task list:
The text was updated successfully, but these errors were encountered: