Skip to content
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

Ensure post-featured-image block is in_the_loop() for BC with core and plugins, and to fix lazy-loading #45534

Merged
merged 1 commit into from
Nov 16, 2022

Conversation

felixarntz
Copy link
Member

What?

This PR is part of the solution from WordPress/wordpress-develop#3560 (see that PR for additional context), which addresses https://core.trac.wordpress.org/ticket/56930. The problem here specifically also addresses #41783.

Why?

Currently the logic to not lazy-load the first featured image or in-content image is not working for block themes. WordPress/wordpress-develop#3560 is the full solution to that problem, however this PR here is necessary since the block itself comes from Gutenberg. We should therefore merge and port this to WP core's blocks soon (in time for WP 6.2).

How?

WP core's logic to determine whether to lazy-load an image expects to run in_the_loop() when the main content is rendered. Since block themes by default may not enter the loop initially, this extra call here needs to be added, as currently the lack of it is a backward compatibility break causing the problem outlined above. This fix is already present in the post-content block, so it's simply brought over here as well.

Testing Instructions

  1. Test this as part of Ensure that first content image is not lazy-loaded in block themes either wordpress-develop#3560 as by itself here it is not going to solve the entire problem.
  2. Use a block theme and view a post with a featured image in the frontend.
  3. With WordPress trunk, the first featured image will have loading="lazy" on it, which is incorrect. With Ensure that first content image is not lazy-loaded in block themes either wordpress-develop#3560, it will not have the attribute as expected.

@felixarntz felixarntz added [Type] Bug An existing feature does not function as intended [Type] WP Core Ticket Requires an upstream change from WordPress. Core Trac ticket should be linked. [Type] Performance Related to performance efforts [Feature] Full Site Editing [Block] Post Featured Image Affects the Post Featured Image Block labels Nov 3, 2022
@felixarntz felixarntz requested a review from ajitbohra as a code owner November 3, 2022 22:31
@codesandbox
Copy link

codesandbox bot commented Nov 3, 2022

CodeSandbox logoCodeSandbox logo  Open in CodeSandbox Web Editor | VS Code | VS Code Insiders

@felixarntz felixarntz changed the title Ensure post-featured-image block is in_the_loop() for BC with core and plugins Ensure post-featured-image block is in_the_loop() for BC with core and plugins, and to fix lazy-loading Nov 3, 2022
@felixarntz felixarntz requested a review from Mamaduka November 14, 2022 18:13
@felixarntz
Copy link
Member Author

@Mamaduka I'd like to get this on your radar. Can we prioritize this PR for an upcoming Gutenberg release and then a merge to WP core trunk, to unblock https://core.trac.wordpress.org/ticket/56930 and WordPress/wordpress-develop#3560, which are scheduled for WP 6.2?

@Mamaduka
Copy link
Member

Thanks for the ping, @felixarntz!

This is on my to-do list, and I will try to test it as soon as possible thoroughly.

Copy link
Member

@Mamaduka Mamaduka left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The changes test well for me, and considering we already have similar code in the Post Content block for BC, I think this is safe to land.

Tests

A follow-up

We'll need a similar follow-up for the Cover block when it renders the featured image, but this doesn't have to be a blocker for WordPress/wordpress-develop#3560.

if ( ! in_the_loop() && have_posts() ) {
the_post();
}

$is_link = isset( $attributes['isLink'] ) && $attributes['isLink'];
$size_slug = isset( $attributes['sizeSlug'] ) ? $attributes['sizeSlug'] : 'post-thumbnail';
$post_title = trim( strip_tags( get_the_title( $post_ID ) ) );
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Should we remove the $post_ID usage from the context now that we set the global post object? I think we did something similar in #37622.

Copy link
Member Author

@felixarntz felixarntz Nov 16, 2022

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@Mamaduka Oh you mean not pass $post_ID to these functions and instead rely on the default which would be the same current post anyway? That seems reasonable to me.

We could do this here and also further down on get_the_post_thumbnail() and get_the_permalink().

Do you think I should add it to this PR or rather in a separate PR?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Oh you mean not pass $post_ID to these functions and instead rely on the default which would be the same current post anyway? That seems reasonable to me.
We could do this here and also further down on get_the_post_thumbnail() and get_the_permalink().

Correct.

Do you think I should add it to this PR or rather in a separate PR?

We can do it in a separate PR if you prefer.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@Mamaduka Sounds good, I'll open a follow up PR once this is merged. Is this waiting for anything else or should we merge it?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Feel free to merge 👍

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yeah, that's the main reason I'm asking. Is there any way we can cherry-pick / backport this change to core sooner? Happy to help as much as I can.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We'll have to do a minor release for the packages outside the release scope, but I don't know what's the policy here. I'm going to ping folks who have done more release than me.

Cc. @noisysocks, @youknowriad

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We'll have to do a minor release for the packages outside the release scope, but I don't know what's the policy here. I'm going to ping folks who have done more release than me.

This is something we do often I think. We'll have to cherry-pick the commits to the right wp/* branch and perform a npm patch release from there. I'm not entirely certain with the process (as it changed lately a bit) but I know that it's documented.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks, Riad! I'm familiar with the new process and can do a patch release.

@felixarntz, I can do a package release and prepare core PR early next week.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Perfect, thanks both! Let me know if I can help with anything like reviews or so.

@felixarntz felixarntz merged commit 799c416 into trunk Nov 16, 2022
@felixarntz felixarntz deleted the fix/41783-post-featured-image-bc-break branch November 16, 2022 20:51
@github-actions github-actions bot added this to the Gutenberg 14.7 milestone Nov 16, 2022
pento pushed a commit to WordPress/wordpress-develop that referenced this pull request Jan 16, 2023
Fixing the issue that featured images are always lazy-loaded in block themes required an upstream Gutenberg change WordPress/gutenberg#45534. This changeset updates packages in order to unblock the remainder of the fix in `trunk`.

Props mamaduka.
See #56930.


git-svn-id: https://develop.svn.wordpress.org/trunk@55079 602fd350-edb4-49c9-b593-d223f7449a82
markjaquith pushed a commit to markjaquith/WordPress that referenced this pull request Jan 16, 2023
Fixing the issue that featured images are always lazy-loaded in block themes required an upstream Gutenberg change WordPress/gutenberg#45534. This changeset updates packages in order to unblock the remainder of the fix in `trunk`.

Props mamaduka.
See #56930.

Built from https://develop.svn.wordpress.org/trunk@55079


git-svn-id: http://core.svn.wordpress.org/trunk@54612 1a063a9b-81f0-0310-95a4-ce76da25c4cd
github-actions bot pushed a commit to platformsh/wordpress-performance that referenced this pull request Jan 16, 2023
Fixing the issue that featured images are always lazy-loaded in block themes required an upstream Gutenberg change WordPress/gutenberg#45534. This changeset updates packages in order to unblock the remainder of the fix in `trunk`.

Props mamaduka.
See #56930.

Built from https://develop.svn.wordpress.org/trunk@55079


git-svn-id: https://core.svn.wordpress.org/trunk@54612 1a063a9b-81f0-0310-95a4-ce76da25c4cd
VenusPR added a commit to VenusPR/Wordpress_Richard that referenced this pull request Mar 9, 2023
Fixing the issue that featured images are always lazy-loaded in block themes required an upstream Gutenberg change WordPress/gutenberg#45534. This changeset updates packages in order to unblock the remainder of the fix in `trunk`.

Props mamaduka.
See #56930.

Built from https://develop.svn.wordpress.org/trunk@55079


git-svn-id: http://core.svn.wordpress.org/trunk@54612 1a063a9b-81f0-0310-95a4-ce76da25c4cd
@tomusborne
Copy link

@felixarntz Just a heads up that this PR seems to have broken the core loop if the Post Featured Image block is hooked before it: https://core.trac.wordpress.org/ticket/58027

@felixarntz
Copy link
Member Author

@tomusborne Thank you, looking into it!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
[Block] Post Featured Image Affects the Post Featured Image Block [Type] Bug An existing feature does not function as intended [Type] Performance Related to performance efforts [Type] WP Core Ticket Requires an upstream change from WordPress. Core Trac ticket should be linked.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

6 participants