-
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
Image: Lightbox buggy retrieval of alt attribute and insufficient accessibility #54971
Comments
@afercia Thanks for taking a thorough look at the lightbox and for opening this issue. I see that you've already opened a PR to begin addressing these issues; here I'll leave a couple of hopefully helpful note:
This one will be hard to achieve. The reason the button lives alongside the image is that we're unable to put the The render method requires that we return a single HTML structure, and from what I've seen, the
The line setting the |
Thanks a lot for the feedback here as well 🙂
After this fix, I believe we can use
Regarding this, we discussed it here, and it seems we decided to postpone it because it wasn't considered urgent at that time. Anyway, I think it should be possible to add an effect that is triggered when the width or height changes. I added this commit in an experimental branch to showcase what I mean. It seems to work but I didn't test it thoroughly. |
That's what I did in my PR, so it is also consistent with similar code for the navigation.
I'm not sure I understand how a feature can be released when the user experience is clearly subpar on some devices e.g. tablets. Also on desktop, when changing the browser window size. I don't think these are edge cases. Anyways, I'm leaving this out from my PR. |
Didn't see the PR, sorry. Glad you were able to fix it.
I'm not saying this doesn't need to be fixed. I believe it does. What I was trying to say is that, as it only happens when you resize the screen while the lightbox is opened, and it works fine after closing and opening again, it seems back then it was considered that there were more important bugs/functionalities to solve. I'm happy to create a proper PR if @artemiomorales thinks the approach I suggested here makes sense. |
I understand the underlying issue. Still, that is not how a |
What about a base64 encoded small gif (26 bytes)? Yes it would be 'loaded' but it would be very small.
|
@SantosGuillamot Thanks for taking a look at this. The approach you have here looks good to me — opening a PR sounds great. I may have a small comment on the implementation, but we can review that once the PR is up 🙏 |
@afercia That sounds good to me 👍 |
Pull request created: |
Description
See also discussion on #53026
The image lightbox needs some fixes and improvements:
1
Bug: at this point:
gutenberg/packages/block-library/src/image/index.php
Lines 123 to 127 in 3e260aa
the alt attribute is always null because the HTML processor points to the first element of the block content, which is a
figure
element: no alt attribute can be retrieved. As such, the button to open the lightbox is always labeledEnlarge image
even when the image does have an alt attribute. Right now, theEnlarge image
button doesn't tell anything about what the image is.2
The button to open the lightbox should be moved after the image in the DOM order. This is important especially for screen reader users. In a linearized content navigation experienc, it makes sense to place the 'what' first and then the action button after.
3
I'd argue the
Enlarge image
button placement inside the<figure>
element isn't great from a semantics perspective. Ideally, the button should be moved outisde of the figure.4
I still see an empty
role
attribute in the DOM before the lightbox is open. This is invalid HTML. Although seems to me this does not have an actual impact on accessibility because the modal dialog isaria-hidden="true"
, WordPress has a tradition to always output valid markup on the front end. It would be great to focus more on the quality of the actual output markup.Bad value for attribute role on element [div]
5
In the same way, an empty
src=""
attribute is output in the DOM. This is invalid HTML.Bad value for attribute src on element [img]: Must be non-empty.
Edut: to clarify, this applies to the second image within the modal dialog, i.e. the 'scaled' one. Initially, the
src
attribute is empty and it gets populated only when opening the modal dialog and the second image gets loaded.6
The
div
element meant to be used for the modal dialog of the enlarged image is either labelledImage
or it is labelled witht he image alt attribute:<div role="" ... aria-label="Image" ...
<div role="" ... aria-label="{image alt attribute}" ...
Some more meaningful labelling would be nice. This is the dialog element, not the image. The labelling should clarify what the dialog is about.
Users click a button that saysEnlarge image: {alt text}
and they get a modal dialog that is only labelledImage
.7
The Close button target size is too small. With Twenty Twenty-Four is aproximately only 15 by 18 pixels.
8
The Close button dosn't visually expose its accessible name. All icon buttons must always visually expose their name in some way. In the editor, we use the Tooltip component for this reason and it's already a compromise between design and accessibility. If this isn't possible on the front end, then tbe button must have visible text.
9
The enlarged image doesn't scale when resizing the window or changing device orientation. See the attached GIF for better clarity.
10
Performance: with large images, the modal dialog contains two images: theresponsive-image
and theenlarged-image
. While I do realize why two images are necessary, I'm not sure this is OK from a performance perspective, as there is always one image that is unnecessary given a certain viewport size.Edit: after a testing session together with @carolinan @aristath and @SergeyBiryukov we noticed this. may be not an issue, as on page load only one image is loaded. The second image is loaded when opening the modal dialog.
Step-by-step reproduction instructions
Screenshots, screen recording, code snippet
When changing device orientation (or resizine the browser window), the image in the open modal dialog doesn't scale correctly. It is cut-off on the left and right edges:
Environment info
No response
Please confirm that you have searched existing issues in the repo.
Yes
Please confirm that you have tested with all plugins deactivated except Gutenberg.
Yes
The text was updated successfully, but these errors were encountered: