-
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
Attach css and js to patterns #61881
Comments
I'm on board with this, but I’m concerned there might be a technical issue in managing the logic. Technically, patterns can be saved to and removed from the database. The first challenge would be how to reliably identify a pattern using a slug. This might not be a significant issue since the pattern is saved with the slug as the 'post_name.' However, if the slug were ever changed, the logic connecting the pattern to the enqueued script or style could break. The same risk applies if the pattern were removed from the database, potentially leaving redundant logic in plugins or themes. This might not be a problem with pattern files but could certainly become an issue with database-saved patterns. |
For patterns saved in database, a copy of css/js could be saved to database as well, either as post meta or in separate table, or alternatively together with pattern. Having this in database would solve the problem of orphaned files, as this would be removed together with pattern when user chooses to delete pattern. |
@fabiankaegy proposed: It made me think there might be some overlap between Section Styling and the need for custom CSS for Patterns. I'm not familiar enough with the work championed by @aaronrobertshaw, but it would be great to have a coherent vision of the best approach for adding additional design tweaks to existing patterns. Regarding the need for JavaScript, could you expand what type of functionality would you like to add to patterns on the frontend? That's the area where Interactivity API should eventually become the solution, so maybe we need some way to automatically enqueue scripts based on the directives included in the HTML markup. |
Thanks for the ping, and for writing up this @Lovor01 👍 Styling patterns might be an easier first step than augmenting them with custom JS.
The styling of patterns using the "Section Styles" feature (aka enhanced block style variations) is on the radar and might already be employed by some themes. I believe the approach taken to date is to define a block style variation for a container block. Then use that container block as the root for the pattern with the block style variation applied. The CSS for the block style variation is only generated and added to the page when a block with the variation applied is present.
@richtabor might be best positioned to share a vision around this aspect.
I had the same initial thoughts. So hopefully in the not too distant future this will all come together with section styles and the interactivity API both augmenting patterns in a way that satisfies the needs expressed in this issue. |
@gziolo : |
You are wellcome!
It still seems to me this is somewhat clumsy solution - I heard several complaints about patterns not being nearly useful as they could since they do not pack with css to style them in certain way. I believe creating pattern as a container which can have content and optionally styling and javascript would significantly modularize that approach and making patterns more useful. Additionally, themes would be allowed to override pattern styling, so they can style colors, fonts, borders etc. to fit overall look of the theme. But what theme would probably not style for the pattern is layout of the pattern (e.g. special flexbox or grid styles, which possibly could not be achieved with built-in block editor features), transparency of some elements, filters, positioning, transformations and many more, since block editor supports only subset of possible css styling Further, Sections styles do not pack css together with pattern, so you have to have variation registered in code - it is not easy to share such pattern. |
Appreciate the continued feedback @Lovor01 👍 As more discussion takes place, things can definitely evolve on this front. I don't think anything is set in stone at this point.
There's a little more to this approach that should be considered. By defining a block style variation that is somewhat generic in name, e.g. In my opinion, bundling one set of opinionated CSS within a pattern greatly reduces its potential applications and flexibility. JS on the other hand I can understand being more 1:1 with a pattern and the interactivity API should serve that need well.
I believe these layouts are achievable using the layout block supports already available. The best place to explore these is probably the controls on the Group block first, see the Row, Stack, and Grid block variations. If there are specific style values not supported in the UI yet, the custom CSS field within theme.json and Global Styles allows for those to be set as well.
As noted above, these can be covered by the Custom CSS feature of Global Styles or the
This is a good point. It could be debated though whether patterns in general should require such opinionated styling. There has been some work done to allow Theme.json settings to be defined within block markup but so far this doesn't extend to embedding style variations values. The difficulty here is likely down to those styles blocking the expected ability for the theme and site receiving the pattern to override them effectively. Perhaps some form of opt-in capability to receive such styles would be beneficial but it needs further thought and exploration. I hope that helps some 🤞 |
Isn't that a problem - naming should be unique to whole wordpress.org,
As I wrote earlier, theme should be able to override pattern embedded css. There are many css styles which could be necessary for pattern to display correctly. These include image positioning and other related properties, special css grid properties which are not available in editor, animations, etc... Theme can't know specifics of some pattern and that should be left to css embedded in pattern. Theme should be able to override all of these properties, but theme would be most concerned with colors, font styles, margins and paddings and similar. |
What I meant is that many css properties are lacking in the block editor and it may not be feasible to add them all as GUI options, but they might be needed for some patterns (it was so in my case) - so why don't let pattern creators share that embedded css together with pattern, so pattern displays correctly without additional interventions? |
Thanks for the continued feedback @Lovor01 👍
The primary use case for the generic block style variation names/classes e.g. If patterns are being defined within a specific theme and styled via variations, there's no restriction on what the naming could be.
Block style variations can define both a slug, used for the CSS class name, and a label which can convey meaning to the user about the variation. I'm not sure block style variations should be responsible for communicating information about a pattern itself though.
Most blocks already have a
This is where the custom CSS property for block types or block style variations within Global Styles can help. |
Hey, thanks for taking time to answer @aaronrobertshaw !
That's my mistake, the class name should not communicate information about pattern, but about style variation. I see the point in making style generic so I can agree to that. On the other hand, I would return to the point of this issue, attaching css and js to pattern. Perhaps Gutenberg authors would like to avoid that in order to not make patterns too opinionated. Yet, in my work I find constant need for specifically styled patterns which are unique to some page or unique to the site. This means that I have to put a lot of custom css in theme.json, or in the site editor styling text area and this css is not easy to handle. It is not well readable, does not have linting nor other editor features like suggestions. My proposal remains to allow attaching css and js as files in theme or plugins and that these files can be distributed together with pattern (either as zipped file consisting of more files or embedded inside pattern definition and hence single file). This css should be written in such way that theme can still style colors, fonts, etc. inside pattern if desired. |
This is definitely a valid use case. No arguments here.
Future iterations of the section styling feature might also allow for a combination of the traditional and theme.json approaches to defining block style variations. This may help reduce a little friction while still allowing Global Styles supported styles to be configurable by end users. |
Problem
In the early days of Gutenberg, I used to build block for everything to create pages. That was such, because I needed that user can insert complex unit as a whole. Nowadays, it is much faster working with patterns, creating a group of elements and creating pattern out of that. However, there is still problem with optimising css/js if those patterns require special css or js and most of them do.
I can either enqueue all needed css/js on every post/page or eventually guess on which pages user will need those patterns and enqueue css/js only there. It would be much more useful that system remembers a pattern being used on a page and enqueues given css/js only there where pattern is used, much like with blocks.
Solution
Developing a system which would somehow store occurence of pattern on post/page, either as another comment in content (similar to block) or post metadata. Also, enhancing pattern definition so css/js could be attached to it. This part would be very easy, since pattern has a unique slug, css and js could be enqueued with dedicated functions receiving css/js url and pattern slug.
e.g.
The text was updated successfully, but these errors were encountered: