Skip to content
This repository has been archived by the owner on Apr 21, 2023. It is now read-only.

Image dimensions are erroneously supplied to amp-img>img elements #2067

Open
westonruter opened this issue May 12, 2021 · 2 comments
Open

Image dimensions are erroneously supplied to amp-img>img elements #2067

westonruter opened this issue May 12, 2021 · 2 comments

Comments

@westonruter
Copy link

A user of the AMP plugin for WordPress reported an issue with images on an AMP page where the server-side rendered img in the amp-img light shadow DOM was getting a width and height attribute supplied:

<amp-img width="150" height="150" src="https://www.example.com/150x150.jpeg" class="attachment-thumbnail size-thumbnail wp-post-image amp-wp-enforced-sizes i-amphtml-layout-intrinsic i-amphtml-layout-size-defined i-amphtml-element i-amphtml-built i-amphtml-layout" alt="" data-hero-candidate="" layout="intrinsic" disable-inline-width="" i-amphtml-layout="intrinsic" data-hero="" i-amphtml-ssr="" i-amphtml-auto-lightbox-visited="">
    <i-amphtml-sizer class="i-amphtml-sizer" slot="i-amphtml-svc"><img alt="" aria-hidden="true" class="i-amphtml-intrinsic-sizer" role="presentation" src=""></i-amphtml-sizer>
    <img width="150" height="150" class="i-amphtml-fill-content i-amphtml-replaced-content" decoding="async" loading="lazy" alt="" src="https://www.example.com/150x150.jpeg" data-hero-candidate="" data-hero="">
</amp-img>

The img inside of an amp-img gets position:absolute and stretches to fill its container element, so the width and height are irrelevant. Since the attributes are not expected, they cause AMP validation errors and the AMP base stylesheet inadvertently gives the img a position:relative styling, which causes the image to be hidden by being positioned outside of the parent's overflow.

All this to say, when an img is the child of amp-img it should be skipped from having its width and height supplied.

@Lofesa
Copy link
Contributor

Lofesa commented May 12, 2021

Hi @westonruter
As far as I know only the filters resize_images and resize_rendered_image_dimensions can be related to this issue.
Pagespeed by default has a rewrite level core that enables the resize_images.

There are some ways to disable these filters:

pagespeed DisableFilters filtera,filterb; (nginx)
ModPagespeedDisableFilters filtera,filterb (apache)

But these disables the filters for all request, not only for amp pages.
Maybe some type of logic can disable these filters only for amp request. If I remember the AMP Plugin put amp as an arg to the url, so some like this may work:

if ($args = amp) {
             set $disable_filters "resize_images,resize_rendered_image_dimensions";
      }

 pagespeed DisableFilters "$disable_filters";

That´s nginx syntax, I don´t know if in apache can be done.

@jmarantz
Copy link
Contributor

jmarantz commented May 12, 2021 via email

Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants