-
Notifications
You must be signed in to change notification settings - Fork 182
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
Core / ACF -> Blocks essential markup differences for innerBlocks #465
Comments
With regards to the above quote, can you please elaborate a little more on what you are stating here? I can confirm that we are not rolling any custom wrapper container for the I wonder if this issue is related to a recent change in the block API that is affecting how blocks wrapping elements are rendered. There are tickets (WordPress/gutenberg#25088) and (#358) which may be related. These tickets discuss a change in the block API effecting how blocks are wrapped, which effects how the alignment classes are applied. I wonder if these are all related. |
@elliotcondon I don't know how to explain it any easier? I've already mentioned everything to understand this issue. I'll try again and create a screen so that it's easier to understand. This is an ACF issue because the WordPress blocks work as expected. But the ACF blocks don't do it in the block editor. I will come back soon with the screens. @elliotcondon your linked Gutenberg issues are not related to my issue. |
@elliotcondon Now I will try to explain it again. I'm a theme WordPress developer. I'm trying to get the same result from frontend in the block editor. The main issue I'm addressing here is the result of ACF nested (inner) blocks in the block editor.I don't know if you've already dealt with this topic, but to always correctly display nested (inner) blocks with all their setting options is a difficult task. Especially when it comes to inner blocks with a depth of 2, 3 or more levels. The big mission is to get always the same result on frontend and in the block editor (backend). All WordPress core blocks using a wrapper parent container for inner blocks. It's always the same scheme:
or
Each time, if I use ACF to include inner blocks, I always use the same scheme:
This are the frontend basics to deal with inner blocks and to get always the same result for inner blocks. Imagine you have about 10 blocks supporting the inner blocks. But they all use the same scheme. That's great, because we can control all block types with the same CSS rules, like this:
The selector All this things are working correctly for WordPress core and ACF blocks on the frontend case. The main issue I'm addressing here is the result of ACF nested (inner) blocks in the block editor. Now let's look at the backend side inside the block editor.We want to get the same result from the frontend in the backend block editor. It is therefore important that the markup of the parent blocks and inner blocks is the same or follows the same scheme. The WordPress way to show inner blocks follows exactly the same scheme like the frontend:
CSS rules like the following working as expected also for frontend and backend (block editor):
What is not going as expected and causing issues?Now I am going to describe the problem what it is about. ACF uses two additional HTML parent containers, which are located between the parent container block and the inner blocks. These two additional parent containers are: " and " You can see it in the example below:
For this reason the css rules like the following example do not work for ACF inner blocks in the block editor case:
The result of the frontend and backend output is different. Because nested (inner) blocks are displayed incorrectly in the block editor if you have further settings such as "alignfull", "alignwide", "alignleft" or "alignright". That's because the CSS rules don't work. Because the markup of ACF inner blocks is different from the frontend. I hope you can understand it now :-) Here you can see this issue in pictures: Frontend Output - (Core Parent Block)Here are a WordPress core parent block with nested inner blocks. All blocks (parent + inner blocks) are "aligned full": Block Editor Output - (Core Parent Block)This upper example looks exactly same in the block editor, because all CSS rules matches perfectly: Frontend Output - (ACF Parent Block)At the frontend, it works as expected in the case, a ACF parent block wraps the inner blocks: Block Editor Output - (ACF Parent Block)--> HERE <-- you can see the differences: In the case of the ACF Parent block, the inner "aligned full" blocks are not displayed correctly. The result of the inner blocks is not aligned, but "aligned full" is active for all inner blocks. This is not working, because the CSS rules are not matching in the case of the block editor. Because ACF uses two more other parent blocks between the main parent block and the inner blocks: How we can solve this?In short, the problem is that the representation of the ACF inner blocks in the block editor is not as expected. We could solve this, if we could remove this two additional parent blocks: " and " ... in this case, all inner blocks follows directly after the block markup we use for the frontend or we can add an additional class to the last parent container, directly before all inner blocks. With an additional class this could be like the following: Change " A possible solution would be a filter, to allow us to add an additional class name depending on the ACF parent block name. |
@elliotcondon Many descriptions will show you this issue. A correct solution, however, would be to save that many additional CSS rules. It is very important to always use a simple method to correctly display nested blocks with two or more levels. |
@elliotcondon the best practice would be: Best practiceChanging the markup like the default WordPress way. From:
To:
This follows the same scheme like WordPress core blocks:
How can we solve it?There is one little difficulty that you need to be aware of. If we use ACF inner blocks, we creating templates like this:
This upper example is the best practice, because it follows the WordPress default way. The difficulty now is that the inner container " The result in the block editor would be:
You can see the " Therefore a better solution would be perfect. A solution by ACF, which insert the " Please believe me, this way is consistent and very important, to get always the same result. At the end it is so much easier to deal with inner block settings. It's possible for ACF to create a fix or an optional option, to allow us to going the same way like all other WordPress default block, which can include inner blocks? @elliotcondon what do you think about this issue? |
Maybe a solution like this:
or if we can't pass the name of the parent block to the innerBlocks element:
|
Hi @CreativeDive. Thanks for the further detail. I think there may have been some misunderstanding from my previous reply. Please know that I do understand the issue, and see from your comparisons that there is a difference in HTML output between core and ACF blocks. I also understand the importance of consistency for CSS rules, and how this issue presents a major problem for theme developers. With that said, I want to confirm that the ACF PRO plugin is not intentionally adding these two additional HTML parent containers (".block-editor-inner-blocks" and ".block-editor-block-list__layout"). I have searched our source code and can confirm there is no occurrence of these elements. When implementing the To solve this issue, we need to discover why there is a difference of HTML output between core and ACF block types. I suspect that in a recent version of Gutenberg, the API has changed which is causing 3rd party block type (such as ACF blocks) to use a legacy or "non experimental" render function. Can you help identify when this issue started? Perhaps the bug was introduced in WP 5.1, 5.2, 5.3, 5.4, 5.5 or 5.6? Looking forward to hearing from you. |
@elliotcondon I can't remember it ever being any different in WordPress / Gutenberg versions in the past. If I remember correctly, the two parent containers were always set. But that doesn't solve the problem. Now that you mention that this containers are not from ACF, can we analyze it like this: If we look at the inner block component without adding more template containers with the ACF, we only get this: I can see the element will wrap from two parent container each time.
And this inner block component content, is wrapped always from the first block parent container:
The result is always:
It looks to me as if it follows exactly the scheme that WordPress uses for the core blocks. With the ecxeption of the " If we continue to follow the scheme of the core blocks, the container " But the container " Default CSS rules, like the following, dosen't work now:
The core block scheme of block including inner blocksHowever, this hierarchy would be correct:
Now we know that this leads to a display issues in the block editor. But how can you solve this issue? The easiest fix would be, to add the my-acf-block__inner-container class to the container ".block-editor-block-list__layout". |
@elliotcondon I have also detect other inconsistencies depending with ACF blocks: The WordPress core blocks wayIf a block alignment is selected for a core block, inside the block editor, a container
The ACF blocks wayIf a block alignment is selected for an ACF block, inside the block editor, a container Additionally the alignment attribute [data-align="full"] was added directly to the block itself. However, this cannot be observed in the case of the core blocks.
This is totally different to the scheme of the core blocks. This is another issue that can cause problems designing the correct view in the block editor. In the core blocks way, ACF blocks alignment should be like this markup:
@elliotcondon do you have any idea, why this is totally different to the core blocks? |
This is all I could found about possible innerBlocks API changes: https://make.wordpress.org/core/2021/02/23/inner-blocks-api-changes/ https://make.wordpress.org/core/2020/11/18/new-createblocksfrominnerblockstemplate-block-api/ https://developer.wordpress.org/block-editor/developers/block-api/block-deprecation/ |
@elliotcondon I can confirm, this is a main issue by the Gutenberg innerBlocks component. I have tested some other plugins which add blocks with inner blocks. Always the same inconsistencies. This is horror. I wonder why the same markup is not used here? This will cause many design problems in the block editor in the future, because the markup does not correspond to the frontend. |
@elliotcondon Now I have created a new issue for the Gutenberg editor. I hope someone of the Gutenberg Team will see this issue. Unfortunately, such tickets usually wait a long time until someone answers them or something happens at all. But the current state of the different markup is really horror. |
@elliotcondon I've feedback to my Gutenberg issue from @talldan: WordPress/gutenberg#29513 (comment) What do you say about his comment? Could be solve this the markup issues? |
@elliotcondon here you can find all about, how we can solve this issue: https://make.wordpress.org/core/2020/11/18/block-api-version-2/ Including the possibility to support both, the old and the new API. This sounds like a solution :-) I am happy to test the changes. This will avoid a lot of headaches for theme developers in the future. |
@elliotcondon Can we hope that this will change in the next version? :-) |
Thank you for all the additional info and Gutenberg Ticket. It looks like we will need to investigate the Block API version 2, and begin testing the new "props" filters / functions. One major issue when adopting a new API version is the question of backwards compatibility. Our focus for ACF Blocks is to support as many versions of WordPress as possible, not just the latest one. The Block API version2 is quite new, and some parts are still considered "experimental". Please don't anticipate us resolving this ticket quickly. This change will require time and considerations for all users. |
@CreativeDive I was having the same issue and solved it using editor CSS. In my case I was using a Originally I made a JS fix (on the linked ticket) which got me some way there - but was incredibly unrobust in the editor. It's like the blocks are continually rendering new versions of themselves, so you can't persist DOM changes. Anyway.... that forced me to look for a CSS way of doing it, which I found using |
@simonseddon Thank you for your input, but this really sounds like a dirty fix that doesn't work in every way. In some cases, however, it can work with the completely different frontend and backend outputs. But in truth, the backend output must be exactly the same as in the frontend. That is the only correct solution. I hope we don't have to wait very long for changes to the ACF blocks. |
@elliotcondon thank you for response. I am glad that you recognized the importance. But it is important for me to know how long we have to wait until ACF supports the block API v2? I'm here for testing and to speed up development at the end. You can attach me, if you have worked out a new solution. After this I can send you feedback after testing. This can help you to speed up development. I think this is really a VERY important change for anyone using ACF blocks. Because the longer these differences exist, the more often people will have difficulties with them and the more often there will be inquiries and tickets. |
@CreativeDive Yes as stated my solution doesn't work for all scenarios. Hopefully it'll help some people, though. Switching to the new API would be better but it'll take some time for ACF to roll that out and I have deadlines to consider :/ When that happens my solution won't break anything, as the divs I'm styling won't be there, and the original front-end styles will apply 😀 Best of luck getting your stuff working. |
Hit this same issue multiple times. It's very difficult to get around. Some blocks are easier than others, and some are just impossible to make work in the editor because of the different markup. This comment sounds extremely promising though. WordPress/gutenberg#29513 (comment) @elliotcondon as far as backwards compatibility, I think an "opt in" attribute would make the most sense. Something like @CreativeDive already mentioned:
|
@CreativeDive @JiveDig @simonseddon Just a heads up that in the upcoming 5.10 release we've transitioned to v2 of the blocks API. That alone doesn't fix this issue, but it does let us start focusing on a proper fix for this. We may still squeeze that fix into the 5.10 release, but otherwise, it will be one of the first blocks-related items we tackle in 5.11. |
@mattgrshaw Great news! If the editor markup will change to fix this it will be an amazing change for the better, but one that will require some dev on our end. As long as it's an opt-in thing or some way to not break existing instances of the blocks, can't wait to see this one get fixed. It'd be a great update for us in the editor. |
I'm 100% with @mattgrshaw in terms of not breaking existing blocks... |
Hey @mattgrshaw, thanks for the update. First of all, I would like to emphasize that in my case the new version breaks the ACF block styles in the editor. I think that an opt-in may be necessary here. On the other hand, it is difficult to use an opt-in, since all new users who are working with ACF for the first time would have to activate the Block API 2 manually. I've worked out the differences between ACF blocks markup before and after the block API 2 was used. With the block API 1:
With the block API 2:
At the end only one DIV container per ACF block has disappeared in the new version. The result is not what I expected. A DIV container was simply dispensed with. This change does not lead us to the same markup as the core blocks use. Here, too, we still have to use workaround CSS for ACF blocks in order to get the same editor result as in the frontend. Is ACF's PHP block solution limited here? Is there no way to match the ACF block markup with the core block markup? @JiveDig @nick6352683 @simonseddon What is your experience with the new version? |
If there are any wrapping elements/levels removed in this update it will certainly break things for us. Due to these extra layers we have some ridiculous but necessary CSS selectors like this:
These blocks can all be nested so it has to be this precise. If the wrapping elements from below could be removed, we'd be super happy :) |
On another note, my SVGs that are used as Tab labels are getting stripped out in this version. Did something change there? Where should I report? In |
@JiveDig Are you achieving this by using an Depending on your specific SVG, you might need to add more attributes (or tags) as allowed. add_filter( 'wp_kses_allowed_html', function( $tags, $context ){
if( $context === 'acf' ) {
$tags['svg'] = array(
'xmlns' => array(),
'fill' => array(),
'viewbox' => array(),
'role' => array(),
'aria-hidden' => array(),
'focusable' => array(),
);
$tags['path'] = array(
'd' => array(),
'fill' => array(),
);
}
return $tags;
}, 10, 2 ); |
It's the same scenario as the others here, and my example CSS above. When dealing with flexbox or CSS grid the hierarchy/descendants are extremely important. On front end it won't break, because we have the expected structure: On the back end we need to hack this stuff to make it work: This means we currently have CSS selectors like mentioned earlier: All of these blocks can be nested inside each other so we have to target with this specificity. If you remove one of those divs we'll have to update our CSS to do so. That's fine to do, but if the plan is to match the markup directly and remove the extra divs so flexbox/grid can work as expected (plus a ton of other benefits) then it'd be better to match the v1 markup for now until a bigger change later when we all update our CSS to match. |
Yes, exactly. Are there other options I'm missing besides hijacking the entire kses filter? I want an icon that isn't a dashicon, I wonder if there's an easier way. Maybe I can run |
@JiveDig The kses escaping happens as the last possible thing before output (as it's designed to, for security!) so I think the kses filter would be the only way forward here. We do apply the ACF context in the kses filter I provided above, so it will only affect any ACF escaped output rather than the whole of WordPress. That said, your use case here is interesting and something we could probably support better. If you're already loading css into the editor, would it be helpful it we supported adding a custom class to a |
The SVG stuff probably should have been a separate issue, sorry about this. I can probably do it with all CSS via a background-image or mask-image. I just need to find the time to do it before the release ;P |
Just a heads up that we've pushed out 5.10.0-RC2 which adds back in the missing div brought up by @CreativeDive. So just to summarize, with this release we'll be on Blocks API v2, but with the same markup as we had on v1. And we're discussing some ways to move towards the new/proper markup in the next release without breaking any workarounds already in place for the old markup. |
@JiveDig Yeh - GitHub didn't let me split your comment out to a new issue so I figured I'd just deal with it here! Either way, the kses filter will be our recommended way of solving this in 5.10, we'll make sure we get that snippet up on the acf website for release for other people - so thanks for pointing it out! |
@lgladdy Thanks. This would probably benefit others but I was already able to do it via CSS so I'm ready for an update of our plugin when the ACF update is out. |
Hey again, this issue here is essential ... good thinks take time. But at the long run, to make the ACF block markup more WordPress core friendly will be the best decision here for the future. @mattgrshaw I can confirm, for step one the best option is to match the old ACF block markup by introduce the block API 2 with the upcoming ACF release. Only matching exactly the old markup will prevent that block styles will break. @mattgrshaw thanks for the RC2 update. It seems everything is working like before with API 1, but now with the API 2. @lgladdy it's hard to find universal examples. In my opinion there is no way, to change the ACF block markup (by introduce the block API 2) to be more like the frontend markup, without breaking editor styles. In the past it was very hard and very frustrating to get the same result for ACF blocks in the editor like the frontend view. Here is only one example of CSS I use to get ACF blocks working like the frontend:
Partially there are very very confusing parent / child CSS rules to get it to work. There are a thousand other examples that we don't see right now. @JiveDig mentioned a good example. But what happens after the next release? I don't know if the "Opt-In" or the "Opt-Out" is the better way to change the ACF block markup? Opt-In means, many of ACF users will still work with the old (bad) markup, when the release will be there. I assume that many users will never use this Opt-In. Because they don't know about it or don't know how to deal with it. On the other hand, maybe the "Opt-Out" is the better decision? All new users automatically use the better markup. Users who are negatively affected by the change will inform themselves and could then Opt-Out. Ultimately, that's a decision by @deliciousbrains But the change will be necessary. I know the styles will break in my case, but I'm ready to invest some more days the finalize the ACF block markup in the right direction. Because I know it will be worth it in the end. |
Worth noting, I'm totally fine with it being opt-out and a breaking change when the time comes. It'd be really easy to remove our complex editor styles and just use what we're already using on the front end. |
I have recently been dealing with the same issues related to InnerBlock markup in the editor. Let me preface this by saying I fully appreciate that this issue is a WordPress problem and not directly an ACF problem. Researching this led me to plenty of similar complaints from developers using the vanilla block API. Things like One solution I saw in another thread was to apply The recommended WordPress solution at the moment is to switch using You can see a great example of this on the core/button block edit logic here: https://github.com/WordPress/gutenberg/blob/HEAD/packages/block-library/src/buttons/edit.js Im wondering if its possible for us to use that hook somehow within our render_callback with JSX enabled. I had a very quick attempt at it using the following: 'render_callback' => function ($block) {
$nested_blocks = [
[
'acf/expander-label',
[
'placeholder' => 'Add a label'
]
],
[
'acf/expander-content',
[
'placeholder' => 'Add content'
]
]
];
$inner_block_props = [
'template' => $nested_blocks
];
echo esc_attr(wp_json_encode($inner_block_props));
echo '<><div innerBlockProps="' .esc_attr(wp_json_encode($inner_block_props)) . '" /></>';
} This didnt work but the above div did get rendered in the backend as so <>
<div innerBlockProps=[object, Object]></div> I'm guessing that this isn't going to be possible right now but if it is possible in the future I think |
I am wondering how it is scheduled to solve this issue? I keep having issues with the different markup and would like to have them solved. Is there hope for the next release? |
|
@lgladdy @mattgrshaw any update on this? This Github issue addresses the similar topic with the different markup. With the 12.7.0 RC1 from Gutenberg something was apparently changed here, but only in a special case it seems. Could this still be helpful for you? Changelog
|
No updated on this yet I'm afraid. This change will require us to implement some kind of versioning or opt-in system for ACF Blocks features, as we can't change the current markup unilaterally. So this will likely have to come as part of #569, which was held up by the significant work we've had to do in ACF 5.12 to support WordPress 5.9. |
@lgladdy thanks for the feedback. Seeing this in 5.13 would be very helpful. I finally want to get started and continue on a good basis. Don't forget to reply to #605 please. I've found a lot of scenarios where copying, pasting, duplicating ACF blocks doesn't work. |
I haven't read through the whole thread but a simple workaround we've been using is adding this to our editor stylesheet, hope it helps! // Remove ACF additional preview markup from affecting our styles
.block-editor-inner-blocks,
.block-editor-block-list__layout {
display: contents
} |
@mike-sheppard thanks for sharing. But this is not working in cases like this:
or in block editor style:
If you have a nested block and only want to format the parent block but not the child blocks, then this type of selectors is required. And this case is not working here. |
Yep, def. not a magic bullet to fix all our innerBlock markup woes, but if you want 90% of grid/flex issues fixed in the editor while we wait for block v2 markup (in v5.13 🙏) that's a nice & simple workaround |
@mike-sheppard I hope so too. |
Hello everyone, This issue should be resolved in our ACF Blocks Developer Preview we released earlier today, if you opt-in to our new blockVersion 2. Please try it out and give us your feedback on that issue! |
Resurrecting this one to ask about I have display: contents; on these elements, scoped to my blocks:
but I lose the toolbar on my inner (ACF) blocks. |
@JiveDig yes correct. That's the reason why this fix is no longer working. The (inline) block toolbar no longer works with |
Uggghhhh. I didn't realize. This sets me back days worth of work. If I can't figure out how to get the toolbar to display, I'll have to revert a ton of changes I had planned for ACF 6.0 release. This limitation is quite a big deal IMO. |
@JiveDig actually |
Yeah that works but then breaks flexbox, which is the whole point of using display: contents in the first place. Looking at issues like this too -- WordPress/gutenberg#7694 |
Hey @elliotcondon;
while working on optimizing the user experience of ACF blocks, I encountered a markup issue:
The way of WordPress to create innerBlocks for Cover, Group or other block types, is to use an inner parent container like ".wp-block-cover__inner-container" or ".wp-block-group__inner-container" for inner blocks. All children inner blocks follows directly after this parent container.
or
Therefore we can use very simple css rules to manage inner block alignment like "align-full" or "align-wide" and so much other important things:
or
This is working perfectly for frontend and backend (block editor) output, to show the correct sizing of inner aligned blocks.
BUT in the case of ACF blocks, this follows not the WordPress way in the case of the backend (block editor). For the frontend output, the upper CSS rules works fine with ACF, but not inside the block editor.
In the case of the block editor, ACF use own wrapper container for innerBlocks:
This means that the above CSS rules have no effect on the inner blocks. But it's very important to use CSS selectors like ">" to style only the first level and not all other nested inner block levels.
There are two ACF container which breaks this CSS rules
".block-editor-inner-blocks"
and".block-editor-block-list__layout"
.The WordPress core blocks inside the block editor follows the same way like the frontend markup and everything works fine:
How we can manage this issue, without create a bloated CSS rules especially for ACF blocks?
Are the parent containers "
.block-editor-inner-blocks
" and ".block-editor-block-list__layout
" very essential for correct working of ACF blocks? Yes I suppose :-)Would be possible to remove this parent containers or rename this? For example "
.block-editor-block-list__layout
" to ".block-editor-inner-blocks__inner-container
".Or do you could add a filter to the core of ACF which allow us to add additional class names to this container?
This would be VERY VERY helpful.
The text was updated successfully, but these errors were encountered: