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

Inserter: Clarify that when the Inserter is open clicking the + button in the top bar will close it again #29759

Merged
merged 10 commits into from
Mar 31, 2021

Conversation

jameskoster
Copy link
Contributor

Trying out @paaljoachim's idea from #22871 to see how it feels. Video demo in both the post editor and the site editor:

inserter.mp4

Suggestions welcome for the context and tooltip label on the button when in close orientation.

@jameskoster jameskoster added [Focus] Accessibility (a11y) Changes that impact accessibility and need corresponding review (e.g. markup changes). [Feature] Inserter The main way to insert blocks using the + button in the editing interface Needs Design Feedback Needs general design feedback. labels Mar 11, 2021
@github-actions
Copy link

github-actions bot commented Mar 11, 2021

Size Change: +11.7 kB (+1%)

Total Size: 1.42 MB

Filename Size Change
build/annotations/index.js 3.78 kB +9 B (0%)
build/api-fetch/index.js 3.42 kB +18 B (+1%)
build/autop/index.js 2.82 kB -1 B (0%)
build/block-directory/index.js 8.63 kB +3 B (0%)
build/block-editor/index.js 127 kB +542 B (0%)
build/block-editor/style-rtl.css 12.4 kB +29 B (0%)
build/block-editor/style.css 12.4 kB +27 B (0%)
build/block-library/blocks/button/style-rtl.css 551 B +72 B (+15%) ⚠️
build/block-library/blocks/button/style.css 551 B +72 B (+15%) ⚠️
build/block-library/blocks/buttons/style-rtl.css 370 B +6 B (+2%)
build/block-library/blocks/buttons/style.css 370 B +7 B (+2%)
build/block-library/blocks/columns/style-rtl.css 436 B +15 B (+4%)
build/block-library/blocks/columns/style.css 435 B +14 B (+3%)
build/block-library/blocks/file/editor-rtl.css 175 B -24 B (-12%) 👏
build/block-library/blocks/file/editor.css 174 B -24 B (-12%) 👏
build/block-library/blocks/freeform/editor-rtl.css 2.45 kB -9 B (0%)
build/block-library/blocks/freeform/editor.css 2.45 kB -9 B (0%)
build/block-library/blocks/latest-comments/editor-rtl.css 0 B -159 B (removed) 🏆
build/block-library/blocks/latest-comments/editor.css 0 B -158 B (removed) 🏆
build/block-library/blocks/latest-comments/style-rtl.css 281 B +12 B (+4%)
build/block-library/blocks/latest-comments/style.css 282 B +13 B (+5%) 🔍
build/block-library/blocks/list/editor-rtl.css 0 B -65 B (removed) 🏆
build/block-library/blocks/list/editor.css 0 B -65 B (removed) 🏆
build/block-library/blocks/navigation-link/editor-rtl.css 651 B +25 B (+4%)
build/block-library/blocks/navigation-link/editor.css 651 B +24 B (+4%)
build/block-library/blocks/navigation-link/style-rtl.css 957 B +272 B (+40%) 🚨
build/block-library/blocks/navigation-link/style.css 955 B +273 B (+40%) 🚨
build/block-library/blocks/navigation/editor-rtl.css 1.13 kB +17 B (+2%)
build/block-library/blocks/navigation/editor.css 1.13 kB +16 B (+1%)
build/block-library/blocks/page-list/style-rtl.css 167 B -370 B (-69%) 🏆
build/block-library/blocks/page-list/style.css 167 B -369 B (-69%) 🏆
build/block-library/blocks/preformatted/style-rtl.css 103 B +40 B (+63%) 🆘
build/block-library/blocks/preformatted/style.css 103 B +40 B (+63%) 🆘
build/block-library/blocks/quote/editor-rtl.css 0 B -61 B (removed) 🏆
build/block-library/blocks/quote/editor.css 0 B -61 B (removed) 🏆
build/block-library/blocks/separator/style-rtl.css 251 B +15 B (+6%) 🔍
build/block-library/blocks/separator/style.css 251 B +15 B (+6%) 🔍
build/block-library/editor-rtl.css 9.56 kB +93 B (+1%)
build/block-library/editor.css 9.55 kB +82 B (+1%)
build/block-library/index.js 151 kB +3.57 kB (+2%)
build/block-library/reset-rtl.css 375 B +1 B (0%)
build/block-library/style-rtl.css 9.11 kB +222 B (+2%)
build/block-library/style.css 9.11 kB +225 B (+3%)
build/block-library/theme-rtl.css 692 B -8 B (-1%)
build/block-library/theme.css 693 B -8 B (-1%)
build/block-serialization-default-parser/index.js 1.87 kB -1 B (0%)
build/blocks/index.js 48.4 kB +23 B (0%)
build/components/index.js 284 kB +106 B (0%)
build/components/style-rtl.css 16.2 kB +7 B (0%)
build/components/style.css 16.2 kB +8 B (0%)
build/compose/index.js 11.2 kB +95 B (+1%)
build/core-data/index.js 16.8 kB +48 B (0%)
build/customize-widgets/index.js 7.33 kB +1.34 kB (+22%) 🚨
build/customize-widgets/style-rtl.css 676 B +298 B (+79%) 🆘
build/customize-widgets/style.css 677 B +298 B (+79%) 🆘
build/data-controls/index.js 838 B +7 B (+1%)
build/data/index.js 8.89 kB +19 B (0%)
build/date/index.js 31.9 kB +18 B (0%)
build/dom-ready/index.js 576 B -1 B (0%)
build/dom/index.js 4.99 kB +8 B (0%)
build/edit-navigation/index.js 17.4 kB +5.47 kB (+46%) 🚨
build/edit-navigation/style-rtl.css 2.86 kB +1.55 kB (+118%) 🆘
build/edit-navigation/style.css 2.86 kB +1.55 kB (+119%) 🆘
build/edit-post/index.js 307 kB -439 B (0%)
build/edit-post/style-rtl.css 7.13 kB +11 B (0%)
build/edit-post/style.css 7.12 kB +15 B (0%)
build/edit-site/index.js 27.5 kB +346 B (+1%)
build/edit-site/style-rtl.css 4.58 kB +18 B (0%)
build/edit-site/style.css 4.57 kB +18 B (0%)
build/edit-widgets/index.js 15.8 kB -4.4 kB (-22%) 🎉
build/edit-widgets/style-rtl.css 2.98 kB -226 B (-7%)
build/edit-widgets/style.css 2.98 kB -225 B (-7%)
build/editor/index.js 42.7 kB +876 B (+2%)
build/editor/style-rtl.css 3.96 kB +53 B (+1%)
build/editor/style.css 3.96 kB +53 B (+1%)
build/element/index.js 4.62 kB +14 B (0%)
build/format-library/index.js 6.76 kB +4 B (0%)
build/hooks/index.js 2.28 kB +1 B (0%)
build/i18n/index.js 4.02 kB +8 B (0%)
build/keyboard-shortcuts/index.js 2.53 kB +9 B (0%)
build/keycodes/index.js 1.96 kB +7 B (0%)
build/list-reusable-blocks/index.js 3.19 kB +49 B (+2%)
build/media-utils/index.js 5.39 kB +47 B (+1%)
build/notices/index.js 1.85 kB +3 B (0%)
build/nux/index.js 3.42 kB +14 B (0%)
build/plugins/index.js 2.95 kB +63 B (+2%)
build/primitives/index.js 1.42 kB +6 B (0%)
build/react-i18n/index.js 1.46 kB +1 B (0%)
build/redux-routine/index.js 2.84 kB +2 B (0%)
build/reusable-blocks/index.js 3.79 kB +8 B (0%)
build/rich-text/index.js 13.5 kB +128 B (+1%)
build/server-side-render/index.js 2.6 kB +16 B (+1%)
build/token-list/index.js 1.27 kB -3 B (0%)
build/url/index.js 3.02 kB +4 B (0%)
build/wordcount/index.js 1.22 kB -1 B (0%)
ℹ️ View Unchanged
Filename Size Change
build/a11y/index.js 1.14 kB 0 B
build/blob/index.js 664 B 0 B
build/block-directory/style-rtl.css 1 kB 0 B
build/block-directory/style.css 1.01 kB 0 B
build/block-library/blocks/archives/editor-rtl.css 61 B 0 B
build/block-library/blocks/archives/editor.css 60 B 0 B
build/block-library/blocks/audio/editor-rtl.css 58 B 0 B
build/block-library/blocks/audio/editor.css 58 B 0 B
build/block-library/blocks/audio/style-rtl.css 112 B 0 B
build/block-library/blocks/audio/style.css 112 B 0 B
build/block-library/blocks/block/editor-rtl.css 161 B 0 B
build/block-library/blocks/block/editor.css 161 B 0 B
build/block-library/blocks/button/editor-rtl.css 475 B 0 B
build/block-library/blocks/button/editor.css 474 B 0 B
build/block-library/blocks/buttons/editor-rtl.css 315 B 0 B
build/block-library/blocks/buttons/editor.css 315 B 0 B
build/block-library/blocks/calendar/style-rtl.css 208 B 0 B
build/block-library/blocks/calendar/style.css 208 B 0 B
build/block-library/blocks/categories/editor-rtl.css 84 B 0 B
build/block-library/blocks/categories/editor.css 83 B 0 B
build/block-library/blocks/categories/style-rtl.css 79 B 0 B
build/block-library/blocks/categories/style.css 79 B 0 B
build/block-library/blocks/code/style-rtl.css 90 B 0 B
build/block-library/blocks/code/style.css 90 B 0 B
build/block-library/blocks/columns/editor-rtl.css 190 B 0 B
build/block-library/blocks/columns/editor.css 190 B 0 B
build/block-library/blocks/cover/editor-rtl.css 605 B 0 B
build/block-library/blocks/cover/editor.css 605 B 0 B
build/block-library/blocks/cover/style-rtl.css 1.24 kB 0 B
build/block-library/blocks/cover/style.css 1.24 kB 0 B
build/block-library/blocks/embed/editor-rtl.css 486 B 0 B
build/block-library/blocks/embed/editor.css 486 B 0 B
build/block-library/blocks/embed/style-rtl.css 401 B 0 B
build/block-library/blocks/embed/style.css 400 B 0 B
build/block-library/blocks/file/style-rtl.css 248 B 0 B
build/block-library/blocks/file/style.css 248 B 0 B
build/block-library/blocks/gallery/editor-rtl.css 704 B 0 B
build/block-library/blocks/gallery/editor.css 705 B 0 B
build/block-library/blocks/gallery/style-rtl.css 1.11 kB 0 B
build/block-library/blocks/gallery/style.css 1.1 kB 0 B
build/block-library/blocks/group/editor-rtl.css 160 B 0 B
build/block-library/blocks/group/editor.css 160 B 0 B
build/block-library/blocks/group/style-rtl.css 57 B 0 B
build/block-library/blocks/group/style.css 57 B 0 B
build/block-library/blocks/heading/editor-rtl.css 129 B 0 B
build/block-library/blocks/heading/editor.css 129 B 0 B
build/block-library/blocks/heading/style-rtl.css 76 B 0 B
build/block-library/blocks/heading/style.css 76 B 0 B
build/block-library/blocks/html/editor-rtl.css 281 B 0 B
build/block-library/blocks/html/editor.css 281 B 0 B
build/block-library/blocks/image/editor-rtl.css 717 B 0 B
build/block-library/blocks/image/editor.css 716 B 0 B
build/block-library/blocks/image/style-rtl.css 476 B 0 B
build/block-library/blocks/image/style.css 478 B 0 B
build/block-library/blocks/latest-posts/editor-rtl.css 137 B 0 B
build/block-library/blocks/latest-posts/editor.css 137 B 0 B
build/block-library/blocks/latest-posts/style-rtl.css 523 B 0 B
build/block-library/blocks/latest-posts/style.css 522 B 0 B
build/block-library/blocks/legacy-widget/editor-rtl.css 398 B 0 B
build/block-library/blocks/legacy-widget/editor.css 399 B 0 B
build/block-library/blocks/list/style-rtl.css 63 B 0 B
build/block-library/blocks/list/style.css 63 B 0 B
build/block-library/blocks/media-text/editor-rtl.css 191 B 0 B
build/block-library/blocks/media-text/editor.css 191 B 0 B
build/block-library/blocks/media-text/style-rtl.css 535 B 0 B
build/block-library/blocks/media-text/style.css 532 B 0 B
build/block-library/blocks/more/editor-rtl.css 434 B 0 B
build/block-library/blocks/more/editor.css 434 B 0 B
build/block-library/blocks/navigation/style-rtl.css 204 B 0 B
build/block-library/blocks/navigation/style.css 205 B 0 B
build/block-library/blocks/nextpage/editor-rtl.css 395 B 0 B
build/block-library/blocks/nextpage/editor.css 395 B 0 B
build/block-library/blocks/page-list/editor-rtl.css 170 B 0 B
build/block-library/blocks/page-list/editor.css 170 B 0 B
build/block-library/blocks/paragraph/editor-rtl.css 157 B 0 B
build/block-library/blocks/paragraph/editor.css 157 B 0 B
build/block-library/blocks/paragraph/style-rtl.css 247 B 0 B
build/block-library/blocks/paragraph/style.css 248 B 0 B
build/block-library/blocks/post-author/editor-rtl.css 209 B 0 B
build/block-library/blocks/post-author/editor.css 209 B 0 B
build/block-library/blocks/post-author/style-rtl.css 183 B 0 B
build/block-library/blocks/post-author/style.css 184 B 0 B
build/block-library/blocks/post-comments-form/style-rtl.css 250 B 0 B
build/block-library/blocks/post-comments-form/style.css 250 B 0 B
build/block-library/blocks/post-content/editor-rtl.css 139 B 0 B
build/block-library/blocks/post-content/editor.css 139 B 0 B
build/block-library/blocks/post-excerpt/editor-rtl.css 73 B 0 B
build/block-library/blocks/post-excerpt/editor.css 73 B 0 B
build/block-library/blocks/post-featured-image/editor-rtl.css 338 B 0 B
build/block-library/blocks/post-featured-image/editor.css 338 B 0 B
build/block-library/blocks/post-featured-image/style-rtl.css 100 B 0 B
build/block-library/blocks/post-featured-image/style.css 100 B 0 B
build/block-library/blocks/pullquote/editor-rtl.css 183 B 0 B
build/block-library/blocks/pullquote/editor.css 183 B 0 B
build/block-library/blocks/pullquote/style-rtl.css 318 B 0 B
build/block-library/blocks/pullquote/style.css 318 B 0 B
build/block-library/blocks/query-loop/editor-rtl.css 83 B 0 B
build/block-library/blocks/query-loop/editor.css 82 B 0 B
build/block-library/blocks/query-loop/style-rtl.css 315 B 0 B
build/block-library/blocks/query-loop/style.css 317 B 0 B
build/block-library/blocks/query-pagination-numbers/editor-rtl.css 122 B 0 B
build/block-library/blocks/query-pagination-numbers/editor.css 121 B 0 B
build/block-library/blocks/query-pagination/editor-rtl.css 270 B 0 B
build/block-library/blocks/query-pagination/editor.css 262 B 0 B
build/block-library/blocks/query-pagination/style-rtl.css 168 B 0 B
build/block-library/blocks/query-pagination/style.css 168 B 0 B
build/block-library/blocks/query-title/editor-rtl.css 86 B 0 B
build/block-library/blocks/query-title/editor.css 86 B 0 B
build/block-library/blocks/query/editor-rtl.css 795 B 0 B
build/block-library/blocks/query/editor.css 794 B 0 B
build/block-library/blocks/quote/style-rtl.css 169 B 0 B
build/block-library/blocks/quote/style.css 169 B 0 B
build/block-library/blocks/rss/editor-rtl.css 201 B 0 B
build/block-library/blocks/rss/editor.css 202 B 0 B
build/block-library/blocks/rss/style-rtl.css 290 B 0 B
build/block-library/blocks/rss/style.css 290 B 0 B
build/block-library/blocks/search/editor-rtl.css 165 B 0 B
build/block-library/blocks/search/editor.css 165 B 0 B
build/block-library/blocks/search/style-rtl.css 342 B 0 B
build/block-library/blocks/search/style.css 344 B 0 B
build/block-library/blocks/separator/editor-rtl.css 99 B 0 B
build/block-library/blocks/separator/editor.css 99 B 0 B
build/block-library/blocks/shortcode/editor-rtl.css 512 B 0 B
build/block-library/blocks/shortcode/editor.css 512 B 0 B
build/block-library/blocks/site-logo/editor-rtl.css 201 B 0 B
build/block-library/blocks/site-logo/editor.css 201 B 0 B
build/block-library/blocks/site-logo/style-rtl.css 115 B 0 B
build/block-library/blocks/site-logo/style.css 115 B 0 B
build/block-library/blocks/social-link/editor-rtl.css 164 B 0 B
build/block-library/blocks/social-link/editor.css 165 B 0 B
build/block-library/blocks/social-links/editor-rtl.css 776 B 0 B
build/block-library/blocks/social-links/editor.css 776 B 0 B
build/block-library/blocks/social-links/style-rtl.css 1.32 kB 0 B
build/block-library/blocks/social-links/style.css 1.33 kB 0 B
build/block-library/blocks/spacer/editor-rtl.css 317 B 0 B
build/block-library/blocks/spacer/editor.css 317 B 0 B
build/block-library/blocks/spacer/style-rtl.css 48 B 0 B
build/block-library/blocks/spacer/style.css 48 B 0 B
build/block-library/blocks/table/editor-rtl.css 478 B 0 B
build/block-library/blocks/table/editor.css 478 B 0 B
build/block-library/blocks/table/style-rtl.css 402 B 0 B
build/block-library/blocks/table/style.css 402 B 0 B
build/block-library/blocks/tag-cloud/editor-rtl.css 118 B 0 B
build/block-library/blocks/tag-cloud/editor.css 118 B 0 B
build/block-library/blocks/tag-cloud/style-rtl.css 94 B 0 B
build/block-library/blocks/tag-cloud/style.css 94 B 0 B
build/block-library/blocks/template-part/editor-rtl.css 552 B 0 B
build/block-library/blocks/template-part/editor.css 551 B 0 B
build/block-library/blocks/term-description/editor-rtl.css 90 B 0 B
build/block-library/blocks/term-description/editor.css 90 B 0 B
build/block-library/blocks/text-columns/editor-rtl.css 95 B 0 B
build/block-library/blocks/text-columns/editor.css 95 B 0 B
build/block-library/blocks/text-columns/style-rtl.css 166 B 0 B
build/block-library/blocks/text-columns/style.css 166 B 0 B
build/block-library/blocks/verse/editor-rtl.css 50 B 0 B
build/block-library/blocks/verse/editor.css 50 B 0 B
build/block-library/blocks/verse/style-rtl.css 87 B 0 B
build/block-library/blocks/verse/style.css 87 B 0 B
build/block-library/blocks/video/editor-rtl.css 504 B 0 B
build/block-library/blocks/video/editor.css 503 B 0 B
build/block-library/blocks/video/style-rtl.css 187 B 0 B
build/block-library/blocks/video/style.css 187 B 0 B
build/block-library/common-rtl.css 1.1 kB 0 B
build/block-library/common.css 1.1 kB 0 B
build/block-library/reset.css 376 B 0 B
build/block-serialization-spec-parser/index.js 3.06 kB 0 B
build/deprecated/index.js 787 B 0 B
build/escape-html/index.js 735 B 0 B
build/format-library/style-rtl.css 637 B 0 B
build/format-library/style.css 639 B 0 B
build/html-entities/index.js 622 B 0 B
build/is-shallow-equal/index.js 699 B 0 B
build/list-reusable-blocks/style-rtl.css 629 B 0 B
build/list-reusable-blocks/style.css 628 B 0 B
build/nux/style-rtl.css 731 B 0 B
build/nux/style.css 727 B 0 B
build/priority-queue/index.js 791 B 0 B
build/reusable-blocks/style-rtl.css 225 B 0 B
build/reusable-blocks/style.css 225 B 0 B
build/shortcode/index.js 1.7 kB 0 B
build/viewport/index.js 1.86 kB 0 B
build/warning/index.js 1.14 kB 0 B

compressed-size-action

@paaljoachim
Copy link
Contributor

paaljoachim commented Mar 11, 2021

Hey James.

I am comparing directly to the Settings gear icon. How we open and close Settings today.

Open-close-settings-gear-icon.mp4

Comparing to opening and closing Settings.

Suggestions welcome for the context and tooltip label on the button when in close orientation.

I am wondering if the tooltip should stay as it is today. Similar to Settings has the tooltip "Settings".
Independent if Settings is open or not.

@MichaelArestad
Copy link
Contributor

This makes sense to me. I don't love losing the experience of my content bouncing around when I'm using the Inserter. I would rather it remain open.

The only slightly strange thing to me is the + animating to the close button. I'm not sure that's necessary as it deviates from the other panel buttons' open state. I might change the background to black and leave the + icon as is.

@hedgefield
Copy link

Turning the plus into a cross was immediately what I thought of when reading this issue title, so that's a +1 from me.

Copy link
Contributor

@jasmussen jasmussen left a comment

Choose a reason for hiding this comment

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

I'm happy to try this, because it's so simple. I left a few comments to address.

label={
isInserterOpened
? _x(
'Close block inserter',
Copy link
Contributor

Choose a reason for hiding this comment

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

Could we replace this with a single "Toggle block inserter" instead of the ternery? That way the label doesn't need to change, which I suspect might be better for screen readers.


&.is-pressed {
svg {
transform: rotate(45deg);
Copy link
Contributor

Choose a reason for hiding this comment

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

If we go and keep this, it might be nice to update the Figma "small x" icon to be more or less identical to the plus as rotated.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Agreed, let's assess in a follow up.

Copy link
Contributor

Choose a reason for hiding this comment

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

(It might already be!)

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 checked, it's close but no cigar 😅

Screenshot 2021-03-17 at 15 01 19

Copy link
Contributor

Choose a reason for hiding this comment

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

Hah, I bet that when the pixels antialias together the difference is barely perceptible.

Of course that won't be good enough for you or me, because we'll know! But I'm happy to push the vectors once we get to it 😄

)
: _x(
'Add block',
'Generic label for block inserter button'
Copy link
Contributor

Choose a reason for hiding this comment

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

Same as before, it seems simpler and safer to have a single "toggle" label.

@@ -81,6 +81,16 @@ body.is-navigation-sidebar-open {
width: $grid-unit-40;
height: $grid-unit-40;
padding: 0;

svg {
transition: transform cubic-bezier(0.165, 0.84, 0.44, 1) 0.2s;
Copy link
Contributor

Choose a reason for hiding this comment

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

Same as before, include the mixin.

@jasmussen
Copy link
Contributor

You're getting this test failure:

No node found for selector: .edit-post-header [aria-label="Add block"], .edit-site-header [aria-label="Add block"]

So it looks like you need to update that test (can probably just search the codebase for .edit-post-header [aria-label="Add block"] and update it to the new toggle text. In case it's the snapshots, which I don't think it is, you can run npm run test-unit -- --updateSnapshot and commit the files it generates.

@jameskoster
Copy link
Contributor Author

Let's give that a try 🤞

@paaljoachim
Copy link
Contributor

This is what I see:

Add-block-Inserter-X.mp4

It looks nice with the switch to the X. The panel does not stay open when clicking into the Gutenberg layout area.

@paaljoachim
Copy link
Contributor

Hey James. @jameskoster
Let me know when the panel stays open even when I click outside into the Gutenberg layout area. As I can then download the special Gutenberg plugin again and retest.

@jasmussen
Copy link
Contributor

Let me know when the panel stays open even when I click outside into the Gutenberg layout area.

This is not intended. When you click outside the inserter, it should close, same as if you press Escape, because the inserter traps focus like a modal. The inserter should stay open when you click a block to insert it, or drag and drop it.

@paaljoachim
Copy link
Contributor

Hi Joen

Understand. Here is a comment in relation to keeping the Add block panel open as if it was a sidebar. As the Add block Inserter looks like a sidebar. #22871 (comment)

@jasmussen
Copy link
Contributor

Yep, I don't disagree with the basic premise, and it's the reason why the List View stays permanently open. It is, however, a delicate balance that strives to ensure powerful access to inserting block and navigating the canvas for both mouse and screen reader users. It can be revisited, of course, but it's very non-trivial, and probably not something that should block this PR.

@@ -41,7 +41,7 @@ export async function closeGlobalBlockInserter() {
async function isGlobalInserterOpen() {
return await page.evaluate( () => {
return !! document.querySelector(
'.edit-post-header [aria-label="Add block"].is-pressed, .edit-site-header [aria-label="Add block"].is-pressed'
'.edit-post-header [aria-label="Toggle block inserter"].is-pressed, .edit-site-header [aria-label="Add block"].is-pressed'
Copy link
Member

@david-szabo97 david-szabo97 Mar 26, 2021

Choose a reason for hiding this comment

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

There is a second instance of "Add block" there. (Used for site editor)

@@ -50,7 +50,7 @@ async function isGlobalInserterOpen() {
*/
export async function toggleGlobalBlockInserter() {
await page.click(
'.edit-post-header [aria-label="Add block"], .edit-site-header [aria-label="Add block"]'
'.edit-post-header [aria-label="Toggle block inserter"], .edit-site-header [aria-label="Add block"]'
Copy link
Member

@david-szabo97 david-szabo97 Mar 26, 2021

Choose a reason for hiding this comment

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

There is a second instance of "Add block" there. (Used for site editor)

Copy link
Member

@david-szabo97 david-szabo97 left a comment

Choose a reason for hiding this comment

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

LGTM 🚀 🚢

Note: It's safe to merge. Performance test will never pass because the tests will always fail on trunk since the selectors have been changed. We need to update the tests to be compatible with both this and trunk branch.

@jameskoster
Copy link
Contributor Author

@david-szabo97 but it is un-mergeable until all tests pass 😬

Copy link

@hedgefield hedgefield left a comment

Choose a reason for hiding this comment

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

I'd say it looks good from a design point of view 👍

@@ -41,7 +41,7 @@ export async function closeGlobalBlockInserter() {
async function isGlobalInserterOpen() {
return await page.evaluate( () => {
return !! document.querySelector(
'.edit-post-header [aria-label="Toggle block inserter"].is-pressed, .edit-site-header [aria-label="Toggle block inserter"].is-pressed'
'.edit-post-header [aria-label="Add block"].is-pressed, .edit-site-header [aria-label="Add block"].is-pressed, .edit-post-header [aria-label="Toggle block inserter"].is-pressed, .edit-site-header [aria-label="Toggle block inserter"].is-pressed'
Copy link
Contributor

Choose a reason for hiding this comment

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

Can we add a comment explaining why we need both, so future contributors can make good decisions about when to remove.

@jameskoster jameskoster merged commit cf7d5b1 into trunk Mar 31, 2021
@jameskoster jameskoster deleted the try/close-inserter-button branch March 31, 2021 15:28
@github-actions github-actions bot added this to the Gutenberg 10.4 milestone Mar 31, 2021
@gziolo gziolo changed the title Clarify that when the Inserter is open clicking the + button in the top bar will close it again Inserter: Clarify that when the Inserter is open clicking the + button in the top bar will close it again Apr 6, 2021
@paaljoachim paaljoachim added [Type] Enhancement A suggestion for improvement. and removed Needs Design Feedback Needs general design feedback. labels Apr 6, 2021
@Copons Copons mentioned this pull request Apr 21, 2021
7 tasks
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
[Feature] Inserter The main way to insert blocks using the + button in the editing interface [Focus] Accessibility (a11y) Changes that impact accessibility and need corresponding review (e.g. markup changes). [Type] Enhancement A suggestion for improvement.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

7 participants