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

Fix tab/focus order issue in Media & text block #40806

Merged
merged 4 commits into from
Jul 21, 2022

Conversation

carolinan
Copy link
Contributor

@carolinan carolinan commented May 4, 2022

What?

Changes the HTML markup of the block depending on the position of the media.

Closes #38537

Why?

When elements are repositioned using only CSS, the visual order does not always match the source order, and that is the case when we move the media in the media & text block from the left to right position. When elements are linked, and you focus on the links, the focus moves unexpectedly.

How?

The figure element is placed before or after the content, depending on the mediaPosition block attribute.

Testing Instructions

Screenshots or screencast

@github-actions
Copy link

github-actions bot commented May 4, 2022

Size Change: +10.1 kB (+1%)

Total Size: 1.25 MB

Filename Size Change
build/annotations/index.min.js 2.76 kB +27 B (+1%)
build/block-editor/index.min.js 152 kB +878 B (+1%)
build/block-editor/style-rtl.css 14.5 kB +9 B (0%)
build/block-editor/style.css 14.5 kB +8 B (0%)
build/block-library/blocks/file/style-rtl.css 224 B -28 B (-11%) 👏
build/block-library/blocks/file/style.css 225 B -28 B (-11%) 👏
build/block-library/blocks/navigation-submenu/view.min.js 402 B +27 B (+7%) 🔍
build/block-library/blocks/navigation/style-rtl.css 1.96 kB +25 B (+1%)
build/block-library/blocks/navigation/style.css 1.95 kB +25 B (+1%)
build/block-library/blocks/navigation/view.min.js 423 B +30 B (+8%) 🔍
build/block-library/blocks/post-comments-form/editor-rtl.css 96 B +27 B (+39%) 🚨
build/block-library/blocks/post-comments-form/editor.css 96 B +27 B (+39%) 🚨
build/block-library/blocks/post-template/style-rtl.css 282 B -41 B (-13%) 👏
build/block-library/blocks/post-template/style.css 282 B -41 B (-13%) 👏
build/block-library/blocks/search/style-rtl.css 379 B -23 B (-6%)
build/block-library/blocks/search/style.css 380 B -23 B (-6%)
build/block-library/editor-rtl.css 10.2 kB +15 B (0%)
build/block-library/editor.css 10.2 kB +15 B (0%)
build/block-library/index.min.js 184 kB +2.43 kB (+1%)
build/block-library/style-rtl.css 11.4 kB -43 B (0%)
build/block-library/style.css 11.4 kB -44 B (0%)
build/blocks/index.min.js 47 kB +60 B (0%)
build/components/index.min.js 229 kB +2.05 kB (+1%)
build/components/style-rtl.css 14 kB +93 B (+1%)
build/components/style.css 14 kB +92 B (+1%)
build/core-data/index.min.js 14.7 kB +187 B (+1%)
build/customize-widgets/index.min.js 11.2 kB +26 B (0%)
build/date/index.min.js 32 kB +10 B (0%)
build/edit-post/index.min.js 30.4 kB +30 B (0%)
build/edit-post/style-rtl.css 7.08 kB +29 B (0%)
build/edit-post/style.css 7.08 kB +29 B (0%)
build/edit-site/index.min.js 50.7 kB +2.8 kB (+6%) 🔍
build/edit-site/style-rtl.css 8.14 kB +445 B (+6%) 🔍
build/edit-site/style.css 8.12 kB +450 B (+6%) 🔍
build/edit-widgets/index.min.js 16.4 kB +34 B (0%)
build/editor/index.min.js 38.6 kB +494 B (+1%)
build/element/index.min.js 4.27 kB +10 B (0%)
build/format-library/index.min.js 6.62 kB +22 B (0%)
build/media-utils/index.min.js 2.9 kB +12 B (0%)
build/plugins/index.min.js 1.94 kB -15 B (-1%)
build/shortcode/index.min.js 1.52 kB +1 B (0%)
build/token-list/index.min.js 644 B -18 B (-3%)
build/wordcount/index.min.js 1.06 kB -6 B (-1%)
ℹ️ View Unchanged
Filename Size
build/a11y/index.min.js 982 B
build/api-fetch/index.min.js 2.26 kB
build/autop/index.min.js 2.14 kB
build/blob/index.min.js 475 B
build/block-directory/index.min.js 6.58 kB
build/block-directory/style-rtl.css 990 B
build/block-directory/style.css 991 B
build/block-editor/default-editor-styles-rtl.css 378 B
build/block-editor/default-editor-styles.css 378 B
build/block-library/blocks/archives/editor-rtl.css 61 B
build/block-library/blocks/archives/editor.css 60 B
build/block-library/blocks/archives/style-rtl.css 65 B
build/block-library/blocks/archives/style.css 65 B
build/block-library/blocks/audio/editor-rtl.css 150 B
build/block-library/blocks/audio/editor.css 150 B
build/block-library/blocks/audio/style-rtl.css 103 B
build/block-library/blocks/audio/style.css 103 B
build/block-library/blocks/audio/theme-rtl.css 110 B
build/block-library/blocks/audio/theme.css 110 B
build/block-library/blocks/avatar/editor-rtl.css 116 B
build/block-library/blocks/avatar/editor.css 116 B
build/block-library/blocks/avatar/style-rtl.css 59 B
build/block-library/blocks/avatar/style.css 59 B
build/block-library/blocks/block/editor-rtl.css 161 B
build/block-library/blocks/block/editor.css 161 B
build/block-library/blocks/button/editor-rtl.css 441 B
build/block-library/blocks/button/editor.css 441 B
build/block-library/blocks/button/style-rtl.css 514 B
build/block-library/blocks/button/style.css 514 B
build/block-library/blocks/buttons/editor-rtl.css 292 B
build/block-library/blocks/buttons/editor.css 292 B
build/block-library/blocks/buttons/style-rtl.css 275 B
build/block-library/blocks/buttons/style.css 275 B
build/block-library/blocks/calendar/style-rtl.css 207 B
build/block-library/blocks/calendar/style.css 207 B
build/block-library/blocks/categories/editor-rtl.css 84 B
build/block-library/blocks/categories/editor.css 83 B
build/block-library/blocks/categories/style-rtl.css 79 B
build/block-library/blocks/categories/style.css 79 B
build/block-library/blocks/code/style-rtl.css 103 B
build/block-library/blocks/code/style.css 103 B
build/block-library/blocks/code/theme-rtl.css 124 B
build/block-library/blocks/code/theme.css 124 B
build/block-library/blocks/columns/editor-rtl.css 108 B
build/block-library/blocks/columns/editor.css 108 B
build/block-library/blocks/columns/style-rtl.css 406 B
build/block-library/blocks/columns/style.css 406 B
build/block-library/blocks/comment-author-avatar/editor-rtl.css 125 B
build/block-library/blocks/comment-author-avatar/editor.css 125 B
build/block-library/blocks/comment-content/style-rtl.css 92 B
build/block-library/blocks/comment-content/style.css 92 B
build/block-library/blocks/comment-template/style-rtl.css 127 B
build/block-library/blocks/comment-template/style.css 127 B
build/block-library/blocks/comments-pagination-numbers/editor-rtl.css 123 B
build/block-library/blocks/comments-pagination-numbers/editor.css 121 B
build/block-library/blocks/comments-pagination/editor-rtl.css 222 B
build/block-library/blocks/comments-pagination/editor.css 209 B
build/block-library/blocks/comments-pagination/style-rtl.css 235 B
build/block-library/blocks/comments-pagination/style.css 231 B
build/block-library/blocks/comments-title/editor-rtl.css 75 B
build/block-library/blocks/comments-title/editor.css 75 B
build/block-library/blocks/comments/editor-rtl.css 95 B
build/block-library/blocks/comments/editor.css 95 B
build/block-library/blocks/cover/editor-rtl.css 615 B
build/block-library/blocks/cover/editor.css 616 B
build/block-library/blocks/cover/style-rtl.css 1.55 kB
build/block-library/blocks/cover/style.css 1.55 kB
build/block-library/blocks/embed/editor-rtl.css 293 B
build/block-library/blocks/embed/editor.css 293 B
build/block-library/blocks/embed/style-rtl.css 410 B
build/block-library/blocks/embed/style.css 410 B
build/block-library/blocks/embed/theme-rtl.css 110 B
build/block-library/blocks/embed/theme.css 110 B
build/block-library/blocks/file/editor-rtl.css 300 B
build/block-library/blocks/file/editor.css 300 B
build/block-library/blocks/file/view.min.js 346 B
build/block-library/blocks/freeform/editor-rtl.css 2.44 kB
build/block-library/blocks/freeform/editor.css 2.44 kB
build/block-library/blocks/gallery/editor-rtl.css 948 B
build/block-library/blocks/gallery/editor.css 950 B
build/block-library/blocks/gallery/style-rtl.css 1.5 kB
build/block-library/blocks/gallery/style.css 1.49 kB
build/block-library/blocks/gallery/theme-rtl.css 108 B
build/block-library/blocks/gallery/theme.css 108 B
build/block-library/blocks/group/editor-rtl.css 333 B
build/block-library/blocks/group/editor.css 333 B
build/block-library/blocks/group/style-rtl.css 57 B
build/block-library/blocks/group/style.css 57 B
build/block-library/blocks/group/theme-rtl.css 78 B
build/block-library/blocks/group/theme.css 78 B
build/block-library/blocks/heading/style-rtl.css 76 B
build/block-library/blocks/heading/style.css 76 B
build/block-library/blocks/html/editor-rtl.css 327 B
build/block-library/blocks/html/editor.css 329 B
build/block-library/blocks/image/editor-rtl.css 738 B
build/block-library/blocks/image/editor.css 737 B
build/block-library/blocks/image/style-rtl.css 524 B
build/block-library/blocks/image/style.css 530 B
build/block-library/blocks/image/theme-rtl.css 110 B
build/block-library/blocks/image/theme.css 110 B
build/block-library/blocks/latest-comments/style-rtl.css 284 B
build/block-library/blocks/latest-comments/style.css 284 B
build/block-library/blocks/latest-posts/editor-rtl.css 199 B
build/block-library/blocks/latest-posts/editor.css 198 B
build/block-library/blocks/latest-posts/style-rtl.css 463 B
build/block-library/blocks/latest-posts/style.css 462 B
build/block-library/blocks/list/style-rtl.css 88 B
build/block-library/blocks/list/style.css 88 B
build/block-library/blocks/media-text/editor-rtl.css 266 B
build/block-library/blocks/media-text/editor.css 263 B
build/block-library/blocks/media-text/style-rtl.css 493 B
build/block-library/blocks/media-text/style.css 490 B
build/block-library/blocks/more/editor-rtl.css 431 B
build/block-library/blocks/more/editor.css 431 B
build/block-library/blocks/navigation-link/editor-rtl.css 705 B
build/block-library/blocks/navigation-link/editor.css 703 B
build/block-library/blocks/navigation-link/style-rtl.css 115 B
build/block-library/blocks/navigation-link/style.css 115 B
build/block-library/blocks/navigation-submenu/editor-rtl.css 296 B
build/block-library/blocks/navigation-submenu/editor.css 295 B
build/block-library/blocks/navigation/editor-rtl.css 2.03 kB
build/block-library/blocks/navigation/editor.css 2.04 kB
build/block-library/blocks/navigation/view-modal.min.js 2.78 kB
build/block-library/blocks/nextpage/editor-rtl.css 395 B
build/block-library/blocks/nextpage/editor.css 395 B
build/block-library/blocks/page-list/editor-rtl.css 363 B
build/block-library/blocks/page-list/editor.css 363 B
build/block-library/blocks/page-list/style-rtl.css 175 B
build/block-library/blocks/page-list/style.css 175 B
build/block-library/blocks/paragraph/editor-rtl.css 157 B
build/block-library/blocks/paragraph/editor.css 157 B
build/block-library/blocks/paragraph/style-rtl.css 260 B
build/block-library/blocks/paragraph/style.css 260 B
build/block-library/blocks/post-author/style-rtl.css 175 B
build/block-library/blocks/post-author/style.css 176 B
build/block-library/blocks/post-comments-form/style-rtl.css 495 B
build/block-library/blocks/post-comments-form/style.css 495 B
build/block-library/blocks/post-comments/editor-rtl.css 77 B
build/block-library/blocks/post-comments/editor.css 77 B
build/block-library/blocks/post-comments/style-rtl.css 628 B
build/block-library/blocks/post-comments/style.css 628 B
build/block-library/blocks/post-excerpt/editor-rtl.css 73 B
build/block-library/blocks/post-excerpt/editor.css 73 B
build/block-library/blocks/post-excerpt/style-rtl.css 69 B
build/block-library/blocks/post-excerpt/style.css 69 B
build/block-library/blocks/post-featured-image/editor-rtl.css 605 B
build/block-library/blocks/post-featured-image/editor.css 605 B
build/block-library/blocks/post-featured-image/style-rtl.css 153 B
build/block-library/blocks/post-featured-image/style.css 153 B
build/block-library/blocks/post-template/editor-rtl.css 99 B
build/block-library/blocks/post-template/editor.css 98 B
build/block-library/blocks/post-terms/style-rtl.css 73 B
build/block-library/blocks/post-terms/style.css 73 B
build/block-library/blocks/post-title/style-rtl.css 80 B
build/block-library/blocks/post-title/style.css 80 B
build/block-library/blocks/preformatted/style-rtl.css 103 B
build/block-library/blocks/preformatted/style.css 103 B
build/block-library/blocks/pullquote/editor-rtl.css 198 B
build/block-library/blocks/pullquote/editor.css 198 B
build/block-library/blocks/pullquote/style-rtl.css 370 B
build/block-library/blocks/pullquote/style.css 370 B
build/block-library/blocks/pullquote/theme-rtl.css 167 B
build/block-library/blocks/pullquote/theme.css 167 B
build/block-library/blocks/query-pagination-numbers/editor-rtl.css 122 B
build/block-library/blocks/query-pagination-numbers/editor.css 121 B
build/block-library/blocks/query-pagination/editor-rtl.css 221 B
build/block-library/blocks/query-pagination/editor.css 211 B
build/block-library/blocks/query-pagination/style-rtl.css 234 B
build/block-library/blocks/query-pagination/style.css 231 B
build/block-library/blocks/query/editor-rtl.css 369 B
build/block-library/blocks/query/editor.css 369 B
build/block-library/blocks/quote/style-rtl.css 213 B
build/block-library/blocks/quote/style.css 213 B
build/block-library/blocks/quote/theme-rtl.css 223 B
build/block-library/blocks/quote/theme.css 226 B
build/block-library/blocks/read-more/style-rtl.css 132 B
build/block-library/blocks/read-more/style.css 132 B
build/block-library/blocks/rss/editor-rtl.css 202 B
build/block-library/blocks/rss/editor.css 204 B
build/block-library/blocks/rss/style-rtl.css 289 B
build/block-library/blocks/rss/style.css 288 B
build/block-library/blocks/search/editor-rtl.css 165 B
build/block-library/blocks/search/editor.css 165 B
build/block-library/blocks/search/theme-rtl.css 64 B
build/block-library/blocks/search/theme.css 64 B
build/block-library/blocks/separator/editor-rtl.css 146 B
build/block-library/blocks/separator/editor.css 146 B
build/block-library/blocks/separator/style-rtl.css 233 B
build/block-library/blocks/separator/style.css 233 B
build/block-library/blocks/separator/theme-rtl.css 194 B
build/block-library/blocks/separator/theme.css 194 B
build/block-library/blocks/shortcode/editor-rtl.css 464 B
build/block-library/blocks/shortcode/editor.css 464 B
build/block-library/blocks/site-logo/editor-rtl.css 708 B
build/block-library/blocks/site-logo/editor.css 708 B
build/block-library/blocks/site-logo/style-rtl.css 192 B
build/block-library/blocks/site-logo/style.css 192 B
build/block-library/blocks/site-tagline/editor-rtl.css 86 B
build/block-library/blocks/site-tagline/editor.css 86 B
build/block-library/blocks/site-title/editor-rtl.css 84 B
build/block-library/blocks/site-title/editor.css 84 B
build/block-library/blocks/social-link/editor-rtl.css 177 B
build/block-library/blocks/social-link/editor.css 177 B
build/block-library/blocks/social-links/editor-rtl.css 674 B
build/block-library/blocks/social-links/editor.css 673 B
build/block-library/blocks/social-links/style-rtl.css 1.37 kB
build/block-library/blocks/social-links/style.css 1.36 kB
build/block-library/blocks/spacer/editor-rtl.css 322 B
build/block-library/blocks/spacer/editor.css 322 B
build/block-library/blocks/spacer/style-rtl.css 48 B
build/block-library/blocks/spacer/style.css 48 B
build/block-library/blocks/table/editor-rtl.css 494 B
build/block-library/blocks/table/editor.css 494 B
build/block-library/blocks/table/style-rtl.css 611 B
build/block-library/blocks/table/style.css 609 B
build/block-library/blocks/table/theme-rtl.css 175 B
build/block-library/blocks/table/theme.css 175 B
build/block-library/blocks/tag-cloud/style-rtl.css 226 B
build/block-library/blocks/tag-cloud/style.css 227 B
build/block-library/blocks/template-part/editor-rtl.css 149 B
build/block-library/blocks/template-part/editor.css 149 B
build/block-library/blocks/template-part/theme-rtl.css 101 B
build/block-library/blocks/template-part/theme.css 101 B
build/block-library/blocks/text-columns/editor-rtl.css 95 B
build/block-library/blocks/text-columns/editor.css 95 B
build/block-library/blocks/text-columns/style-rtl.css 166 B
build/block-library/blocks/text-columns/style.css 166 B
build/block-library/blocks/verse/style-rtl.css 87 B
build/block-library/blocks/verse/style.css 87 B
build/block-library/blocks/video/editor-rtl.css 561 B
build/block-library/blocks/video/editor.css 563 B
build/block-library/blocks/video/style-rtl.css 159 B
build/block-library/blocks/video/style.css 159 B
build/block-library/blocks/video/theme-rtl.css 110 B
build/block-library/blocks/video/theme.css 110 B
build/block-library/common-rtl.css 987 B
build/block-library/common.css 984 B
build/block-library/reset-rtl.css 478 B
build/block-library/reset.css 478 B
build/block-library/theme-rtl.css 677 B
build/block-library/theme.css 682 B
build/block-serialization-default-parser/index.min.js 1.11 kB
build/block-serialization-spec-parser/index.min.js 2.83 kB
build/compose/index.min.js 11.7 kB
build/customize-widgets/style-rtl.css 1.4 kB
build/customize-widgets/style.css 1.4 kB
build/data-controls/index.min.js 653 B
build/data/index.min.js 7.95 kB
build/deprecated/index.min.js 507 B
build/dom-ready/index.min.js 324 B
build/dom/index.min.js 4.65 kB
build/edit-navigation/index.min.js 16 kB
build/edit-navigation/style-rtl.css 4.03 kB
build/edit-navigation/style.css 4.04 kB
build/edit-post/classic-rtl.css 546 B
build/edit-post/classic.css 547 B
build/edit-widgets/style-rtl.css 4.39 kB
build/edit-widgets/style.css 4.38 kB
build/editor/style-rtl.css 3.63 kB
build/editor/style.css 3.62 kB
build/escape-html/index.min.js 537 B
build/format-library/style-rtl.css 571 B
build/format-library/style.css 571 B
build/hooks/index.min.js 1.64 kB
build/html-entities/index.min.js 448 B
build/i18n/index.min.js 3.77 kB
build/is-shallow-equal/index.min.js 527 B
build/keyboard-shortcuts/index.min.js 1.79 kB
build/keycodes/index.min.js 1.38 kB
build/list-reusable-blocks/index.min.js 1.74 kB
build/list-reusable-blocks/style-rtl.css 835 B
build/list-reusable-blocks/style.css 835 B
build/notices/index.min.js 945 B
build/nux/index.min.js 2.05 kB
build/nux/style-rtl.css 732 B
build/nux/style.css 728 B
build/preferences-persistence/index.min.js 2.22 kB
build/preferences/index.min.js 1.3 kB
build/primitives/index.min.js 933 B
build/priority-queue/index.min.js 612 B
build/react-i18n/index.min.js 696 B
build/react-refresh-entry/index.min.js 8.44 kB
build/react-refresh-runtime/index.min.js 7.31 kB
build/redux-routine/index.min.js 2.69 kB
build/reusable-blocks/index.min.js 2.22 kB
build/reusable-blocks/style-rtl.css 256 B
build/reusable-blocks/style.css 256 B
build/rich-text/index.min.js 11.1 kB
build/server-side-render/index.min.js 1.61 kB
build/url/index.min.js 3.61 kB
build/vendors/react-dom.min.js 38.5 kB
build/vendors/react.min.js 4.34 kB
build/viewport/index.min.js 1.08 kB
build/warning/index.min.js 268 B
build/widgets/index.min.js 7.19 kB
build/widgets/style-rtl.css 1.16 kB
build/widgets/style.css 1.16 kB

compressed-size-action

@carolinan
Copy link
Contributor Author

carolinan commented May 4, 2022

Help wanted:

  • Is changing the markup this way the right approach to solving the problem?
  • I don't know how to do the deprecation to solve the block markup issues for existing blocks and patterns.
  • Is it safe, in terms of backwards compatibility, to remove the CSS grid styles?
  • On smaller screens, removing the CSS grid will mean that the visual order of the images will change. When the media is on the right, the image will show after the content. While correct, this may be an unexpected change for users, how can we solve it better?

Still in progress:
The CSS grid still applies to the responsive view, meaning that the focus order is still wrong.

@carolinan carolinan added [Type] Bug An existing feature does not function as intended Needs Technical Feedback Needs testing from a developer perspective. [Block] Media & Text Affects the Media & Text Block labels May 4, 2022
@carolinan carolinan requested a review from aristath May 4, 2022 07:04
@aristath aristath force-pushed the update/media-text-markup branch 2 times, most recently from 34ae243 to 9da71ee Compare May 6, 2022 06:23
Copy link
Member

@aristath aristath left a comment

Choose a reason for hiding this comment

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

This is a great starting point!

Some things that need fixing:

@carolinan
Copy link
Contributor Author

137 themes https://wpdirectory.net/search/01G2VJ8W8V3ETYE34T8Q9B51DJ and 25 plugins https://wpdirectory.net/search/01G2VJY1GKY7K1H9S3H9DCHT1W uses has-media-on-the-right but these results are not limited to css.

@carolinan
Copy link
Contributor Author

If this can't be solved with ease, I think a better alternative is to deprecate the block and replace it with block patterns
(two columns, one with the media on the left and one with media on the right).

The current block is more limited than using separate blocks to create the same design.

Copy link
Member

@jorgefilipecosta jorgefilipecosta left a comment

Choose a reason for hiding this comment

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

Thank you @carolinan, @aristath for your work on this.

After making the above changes, is the has-media-on-the-right class even needed? Should we remove it? 🤔

We need to keep the class, when a website updates the old blocks will still output the class on the frontend they will only be migrated if opened again on the editor.

This seems like a case where a migration should be possible and we don't need to deprecate, I will look into the issues we are having with the migration and try to fix them.

@jorgefilipecosta jorgefilipecosta force-pushed the update/media-text-markup branch from 9da71ee to 96b8804 Compare June 14, 2022 10:38
@jorgefilipecosta
Copy link
Member

jorgefilipecosta commented Jun 14, 2022

I applied a fix to the deprecations it seems to work well, I tested it with several different blocks created on the trunk (with the old markup) and everything still looks as expected on the frontend on this branch and also load well on the editor without any issue. Let me know if there is any issue pending.

@carolinan
Copy link
Contributor Author

Thank you @jorgefilipecosta.
Locally, I do not see any block validation issues.

Besides the native changes and the tests, there is the remaining issue of the "stack on mobile" setting.

This feature still uses the grid columns, and the focus order is incorrect.
What I hear -including in the discussions about deprecating the block - is that users are choosing this block because they can display the media on top, on smaller screens.

What options do we have? I feel that accessibility should always be the strongest case.
People do not only use keyboard navigation on large screens.

  • Stack, but don't reposition the media
  • Only reposition media if the media is not linked
  • Leave it and take the win for the desktop width

I'm not mentioning JS solutions because I don't think we should add another script to the front.

@bgardner can you think of anything more?


A question for @ryelle:
When I apply this PR which changes the markup of the media & text block, I see two block validation errors from the pattern directory. How do we solve that? Is the pattern markup updated when Gutenberg is updated?

@carolinan carolinan marked this pull request as ready for review June 28, 2022 04:57
@carolinan carolinan requested a review from ajitbohra as a code owner June 28, 2022 04:57
Copy link
Member

@aristath aristath left a comment

Choose a reason for hiding this comment

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

LGTM, works as expected and fixes the accessibility issue.

@carolinan carolinan changed the title WIP Try: Fix tab/focus order issue in Media & text block Fix tab/focus order issue in Media & text block Jul 13, 2022
@carolinan carolinan merged commit 18f94fa into trunk Jul 21, 2022
@carolinan carolinan deleted the update/media-text-markup branch July 21, 2022 04:19
@github-actions github-actions bot added this to the Gutenberg 13.8 milestone Jul 21, 2022
@Mamaduka
Copy link
Member

@carolinan, I'm seeing the following error when using the 2020 theme.

CleanShot 2022-07-21 at 13 26 09

@ntsekouras
Copy link
Contributor

ntsekouras commented Jul 22, 2022

@carolinan, I'm seeing the following error when using the 2020 theme.

This seems to introduced a deprecation issue, yes. I saw it now with 2022 as well.

@carolinan
Copy link
Contributor Author

carolinan commented Jul 22, 2022

Those errors are from patterns in the pattern directory. I tried asking @ryelle about them earlier.

@Mamaduka
Copy link
Member

@carolinan, you're right; the errors are coming from the patterns.

It also might mean that deprecation introduced in this PR is failing, so we need to double-check that.

@carolinan
Copy link
Contributor Author

Still unable to reproduce this with local media & text blocks.

@ndiego
Copy link
Member

ndiego commented Jul 25, 2022

I just tested with Frost, where we use Media & Text blocks in patterns. I am getting the same errors that @Mamaduka got, but they are related to patterns from the directory. The patterns in Frost are all working correctly without errors. This leads me to believe that the patterns in the directory just need updating.

image

The two culprit patterns are the following:

image

@ntsekouras
Copy link
Contributor

ntsekouras commented Jul 25, 2022

If a pattern had some markup that worked before and now it doesn't, it means we missed some deprecation logic. It doesn't matter where this comes from and it seems we were lucky to find out through the patterns directory patterns 😄 .

What we need to do is get the failing markup from the patterns and fix the deprecation logic. We should probably test first if it worked before this PR though.

@ndiego
Copy link
Member

ndiego commented Jul 25, 2022

I just tested in 6.0.1 and Gutenberg 13.7.2 with Twenty Twenty-Two, and I am not seeing the errors.

@carolinan
Copy link
Contributor Author

With Gutenberg trunk active, I copy pasted this pattern into the block editor https://wordpress.org/patterns/pattern/event/.
Besides the position of the content div and the <figure>:

The order of the colors in the style tag is different in the body and save function.
Body: style="color:#fffdc7;background-color:#121c1c;grid-template-columns:auto 60%"
Save: style="background-color:#121c1c;color:#fffdc7;grid-template-columns:auto 60%"

Body: The content div is empty:
<div class="wp-block-media-text__content"></div>

Save: The content div has spacing:

<div class="wp-block-media-text__content">

</div>

@carolinan
Copy link
Contributor Author

When the color is removed from the markup there is no block validation error.

</div>
<!-- /wp:media-text -->
<figure class="wp-block-media-text__media">
Copy link
Contributor

Choose a reason for hiding this comment

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

This is the issue with deprecations. Did you manually update this file? Because normally we keep the deprecated .html file intact and the one that will be updated to the new markup is the generated serialized.html..

Copy link
Contributor Author

Choose a reason for hiding this comment

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

I don't recall anymore. I think I just ran the fixture script.

Copy link
Contributor

Choose a reason for hiding this comment

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

That's fine, but everything is produced from the html files. I'll open a PR for the fix.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
[Block] Media & Text Affects the Media & Text Block Needs Technical Feedback Needs testing from a developer perspective. [Type] Bug An existing feature does not function as intended
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Media & Text block - 'Show media on right' tab/focus order issue
6 participants