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

Hide block toolbar when spacing visualizer is showing #45131

Merged
merged 11 commits into from
Nov 3, 2022

Conversation

glendaviesnz
Copy link
Contributor

What?

Hides the selected block toolbar when the padding/margin visualiser is showing.

Why?

Part of the visualizer improvements from #44700

How?

Adds new store action/reducer/selector to indicate when the spacing visualizer is showing, and uses the selector to show/hide the toolbar

Testing Instructions

  • Add a group block and adjust the margins and padding
  • Make sure the block toolbar disappears when the visualizer appears

Screenshots or screencast

Before:

toolbar-before.mp4

After:

toolbar-after.mp4

@glendaviesnz glendaviesnz added the [Feature] Design Tools Tools that impact the appearance of blocks both to expand the number of tools and improve the experi label Oct 19, 2022
@glendaviesnz glendaviesnz self-assigned this Oct 19, 2022
@codesandbox
Copy link

codesandbox bot commented Oct 19, 2022

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

@glendaviesnz
Copy link
Contributor Author

glendaviesnz commented Oct 19, 2022

@talldan the previous idea I mentioned of adding a visualize editor mode fell apart when also using the zoomed in mode, so have gone with a more targetted approach of adding a specific selector/reducer to handle when the visualizer is showing.

@github-actions
Copy link

github-actions bot commented Oct 19, 2022

Size Change: +7.65 kB (+1%)

Total Size: 1.28 MB

Filename Size Change
build/block-editor/index.min.js 169 kB +647 B (0%)
build/block-editor/style-rtl.css 15.8 kB -35 B (0%)
build/block-editor/style.css 15.8 kB -32 B (0%)
build/block-library/blocks/button/style-rtl.css 532 B +9 B (+2%)
build/block-library/blocks/button/style.css 532 B +9 B (+2%)
build/block-library/blocks/comment-template/style-rtl.css 199 B +12 B (+6%) 🔍
build/block-library/blocks/comment-template/style.css 198 B +13 B (+7%) 🔍
build/block-library/blocks/navigation/editor-rtl.css 2.04 kB +11 B (+1%)
build/block-library/blocks/navigation/editor.css 2.04 kB +11 B (+1%)
build/block-library/blocks/navigation/style-rtl.css 2.19 kB +22 B (+1%)
build/block-library/blocks/navigation/style.css 2.18 kB +21 B (+1%)
build/block-library/blocks/post-comments-form/style-rtl.css 501 B +8 B (+2%)
build/block-library/blocks/post-comments-form/style.css 501 B +8 B (+2%)
build/block-library/editor-rtl.css 11.2 kB +16 B (0%)
build/block-library/editor.css 11.2 kB +16 B (0%)
build/block-library/index.min.js 192 kB +901 B (0%)
build/block-library/style-rtl.css 12.3 kB +36 B (0%)
build/block-library/style.css 12.3 kB +37 B (0%)
build/blocks/index.min.js 49.9 kB +65 B (0%)
build/components/index.min.js 203 kB +928 B (0%)
build/components/style-rtl.css 11.3 kB -1 B (0%)
build/components/style.css 11.3 kB -6 B (0%)
build/core-data/index.min.js 15.5 kB +4 B (0%)
build/customize-widgets/index.min.js 11.3 kB -5 B (0%)
build/edit-post/index.min.js 34.1 kB +2.41 kB (+8%) 🔍
build/edit-post/style-rtl.css 7.33 kB +195 B (+3%)
build/edit-post/style.css 7.32 kB +193 B (+3%)
build/edit-site/index.min.js 58.1 kB +254 B (0%)
build/edit-site/style-rtl.css 8.37 kB +3 B (0%)
build/edit-site/style.css 8.35 kB +4 B (0%)
build/editor/index.min.js 43.6 kB +1.93 kB (+5%) 🔍
build/editor/style-rtl.css 3.6 kB -20 B (-1%)
build/editor/style.css 3.59 kB -21 B (-1%)
build/format-library/index.min.js 6.95 kB -6 B (0%)
build/keycodes/index.min.js 1.83 kB -4 B (0%)
build/preferences/index.min.js 1.33 kB -4 B (0%)
build/primitives/index.min.js 944 B +11 B (+1%)
build/rich-text/index.min.js 10.6 kB -10 B (0%)
build/style-engine/index.min.js 1.48 kB +24 B (+2%)
ℹ️ View Unchanged
Filename Size
build/a11y/index.min.js 982 B
build/annotations/index.min.js 2.76 kB
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 7.09 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 90 B
build/block-library/blocks/archives/style.css 90 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 122 B
build/block-library/blocks/audio/style.css 122 B
build/block-library/blocks/audio/theme-rtl.css 126 B
build/block-library/blocks/audio/theme.css 126 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 84 B
build/block-library/blocks/avatar/style.css 84 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 482 B
build/block-library/blocks/button/editor.css 482 B
build/block-library/blocks/buttons/editor-rtl.css 337 B
build/block-library/blocks/buttons/editor.css 337 B
build/block-library/blocks/buttons/style-rtl.css 332 B
build/block-library/blocks/buttons/style.css 332 B
build/block-library/blocks/calendar/style-rtl.css 239 B
build/block-library/blocks/calendar/style.css 239 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 100 B
build/block-library/blocks/categories/style.css 100 B
build/block-library/blocks/code/editor-rtl.css 53 B
build/block-library/blocks/code/editor.css 53 B
build/block-library/blocks/code/style-rtl.css 121 B
build/block-library/blocks/code/style.css 121 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/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 840 B
build/block-library/blocks/comments/editor.css 839 B
build/block-library/blocks/comments/style-rtl.css 637 B
build/block-library/blocks/comments/style.css 636 B
build/block-library/blocks/cover/editor-rtl.css 612 B
build/block-library/blocks/cover/editor.css 613 B
build/block-library/blocks/cover/style-rtl.css 1.57 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 126 B
build/block-library/blocks/embed/theme.css 126 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/style-rtl.css 253 B
build/block-library/blocks/file/style.css 254 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.53 kB
build/block-library/blocks/gallery/style.css 1.53 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 394 B
build/block-library/blocks/group/editor.css 394 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 880 B
build/block-library/blocks/image/editor.css 880 B
build/block-library/blocks/image/style-rtl.css 627 B
build/block-library/blocks/image/style.css 630 B
build/block-library/blocks/image/theme-rtl.css 126 B
build/block-library/blocks/image/theme.css 126 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 213 B
build/block-library/blocks/latest-posts/editor.css 212 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 507 B
build/block-library/blocks/media-text/style.css 505 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/view-modal.min.js 2.78 kB
build/block-library/blocks/navigation/view.min.js 443 B
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 174 B
build/block-library/blocks/paragraph/editor.css 174 B
build/block-library/blocks/paragraph/style-rtl.css 279 B
build/block-library/blocks/paragraph/style.css 281 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/editor-rtl.css 96 B
build/block-library/blocks/post-comments-form/editor.css 96 B
build/block-library/blocks/post-date/style-rtl.css 61 B
build/block-library/blocks/post-date/style.css 61 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 586 B
build/block-library/blocks/post-featured-image/editor.css 584 B
build/block-library/blocks/post-featured-image/style-rtl.css 315 B
build/block-library/blocks/post-featured-image/style.css 315 B
build/block-library/blocks/post-navigation-link/style-rtl.css 153 B
build/block-library/blocks/post-navigation-link/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-template/style-rtl.css 282 B
build/block-library/blocks/post-template/style.css 282 B
build/block-library/blocks/post-terms/style-rtl.css 96 B
build/block-library/blocks/post-terms/style.css 96 B
build/block-library/blocks/post-title/style-rtl.css 100 B
build/block-library/blocks/post-title/style.css 100 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 135 B
build/block-library/blocks/pullquote/editor.css 135 B
build/block-library/blocks/pullquote/style-rtl.css 326 B
build/block-library/blocks/pullquote/style.css 325 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 282 B
build/block-library/blocks/query-pagination/style.css 278 B
build/block-library/blocks/query-title/style-rtl.css 63 B
build/block-library/blocks/query-title/style.css 63 B
build/block-library/blocks/query/editor-rtl.css 439 B
build/block-library/blocks/query/editor.css 439 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/style-rtl.css 409 B
build/block-library/blocks/search/style.css 406 B
build/block-library/blocks/search/theme-rtl.css 114 B
build/block-library/blocks/search/theme.css 114 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 234 B
build/block-library/blocks/separator/style.css 234 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 490 B
build/block-library/blocks/site-logo/editor.css 490 B
build/block-library/blocks/site-logo/style-rtl.css 203 B
build/block-library/blocks/site-logo/style.css 203 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 116 B
build/block-library/blocks/site-title/editor.css 116 B
build/block-library/blocks/site-title/style-rtl.css 57 B
build/block-library/blocks/site-title/style.css 57 B
build/block-library/blocks/social-link/editor-rtl.css 184 B
build/block-library/blocks/social-link/editor.css 184 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.4 kB
build/block-library/blocks/social-links/style.css 1.39 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 190 B
build/block-library/blocks/table/theme.css 190 B
build/block-library/blocks/tag-cloud/style-rtl.css 251 B
build/block-library/blocks/tag-cloud/style.css 253 B
build/block-library/blocks/template-part/editor-rtl.css 235 B
build/block-library/blocks/template-part/editor.css 235 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 691 B
build/block-library/blocks/video/editor.css 694 B
build/block-library/blocks/video/style-rtl.css 174 B
build/block-library/blocks/video/style.css 174 B
build/block-library/blocks/video/theme-rtl.css 126 B
build/block-library/blocks/video/theme.css 126 B
build/block-library/classic-rtl.css 162 B
build/block-library/classic.css 162 B
build/block-library/common-rtl.css 1.02 kB
build/block-library/common.css 1.02 kB
build/block-library/editor-elements-rtl.css 75 B
build/block-library/editor-elements.css 75 B
build/block-library/elements-rtl.css 54 B
build/block-library/elements.css 54 B
build/block-library/reset-rtl.css 478 B
build/block-library/reset.css 478 B
build/block-library/theme-rtl.css 719 B
build/block-library/theme.css 722 B
build/block-serialization-default-parser/index.min.js 1.12 kB
build/block-serialization-spec-parser/index.min.js 2.83 kB
build/compose/index.min.js 12.2 kB
build/customize-widgets/style-rtl.css 1.38 kB
build/customize-widgets/style.css 1.38 kB
build/data-controls/index.min.js 653 B
build/data/index.min.js 8.08 kB
build/date/index.min.js 32.1 kB
build/deprecated/index.min.js 507 B
build/dom-ready/index.min.js 324 B
build/dom/index.min.js 4.7 kB
build/edit-navigation/index.min.js 16.1 kB
build/edit-navigation/style-rtl.css 3.99 kB
build/edit-navigation/style.css 4 kB
build/edit-post/classic-rtl.css 546 B
build/edit-post/classic.css 547 B
build/edit-widgets/index.min.js 16.7 kB
build/edit-widgets/style-rtl.css 4.34 kB
build/edit-widgets/style.css 4.34 kB
build/element/index.min.js 4.68 kB
build/escape-html/index.min.js 537 B
build/experiments/index.min.js 868 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.78 kB
build/list-reusable-blocks/index.min.js 2.13 kB
build/list-reusable-blocks/style-rtl.css 835 B
build/list-reusable-blocks/style.css 835 B
build/media-utils/index.min.js 2.93 kB
build/notices/index.min.js 963 B
build/nux/index.min.js 2.06 kB
build/nux/style-rtl.css 732 B
build/nux/style.css 728 B
build/plugins/index.min.js 1.94 kB
build/preferences-persistence/index.min.js 2.22 kB
build/priority-queue/index.min.js 1.58 kB
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.74 kB
build/reusable-blocks/index.min.js 2.21 kB
build/reusable-blocks/style-rtl.css 256 B
build/reusable-blocks/style.css 256 B
build/server-side-render/index.min.js 1.77 kB
build/shortcode/index.min.js 1.53 kB
build/token-list/index.min.js 644 B
build/url/index.min.js 3.61 kB
build/vendors/inert-polyfill.min.js 2.48 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.21 kB
build/widgets/style-rtl.css 1.18 kB
build/widgets/style.css 1.19 kB
build/wordcount/index.min.js 1.06 kB

compressed-size-action

const { startShowingVisualizer, stopShowingVisualizer } =
useDispatch( blockEditorStore );
const onMouseOver = () => {
startShowingVisualizer();
Copy link
Contributor

@talldan talldan Oct 20, 2022

Choose a reason for hiding this comment

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

This is an interesting problem to solve.

From the point of a public API, if a plugin calls startShowingVisualizer it has the effect of hiding the block toolbar, which I think would be unexpected. I see why it's like that though—startTyping also works the same way. It does leave open the possibility of triggering other effects when a user starts or stops typing.

I'd question if it's needed though, and I think code like this might cause more confusion (e.g. I can imagine plugins calling startTyping to hide the toolbar when the user isn't actually typing, just to get the desired result).

One option is that the actions/selectors/reducer can be more specific to what it does, e.g. hideBlockToolbar / showBlockToolbar.

That way there's the possibility of converging the isTyping code and the visualizer code to use the same system for hiding revealing the toolbar. Possibly deprecating isTyping along the way.

I think @ellatrix might be familiar with this code, so it'd be good to get a second opinion.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

yeh, as I was adding this I was thinking to myself "the naming isn't right", hideBlockToolbar / showBlockToolbar is much better from the external API point of view so have switched it to that.

@glendaviesnz
Copy link
Contributor Author

glendaviesnz commented Oct 24, 2022

@talldan because isTyping is used for a couple of other things besides hiding the block toolbar (useBlockClassnames && DownloadableBlocksPanel) I couldn't see a way that hideBlockToolbar could be used to deprecate isTyping completely.

We could have the START_TYPING action type trigger the isBlockToolbarHidden reducer as well as the HIDE_BLOCK_TOOLBAR action type so that in SelectedBlockPopover we only have to check for isBlockToolbarHidden ... but not sure that having the START_TYPING action trigger the isBlockToolbarHidden reducer provides a much better API than the isTyping selector hiding the toolbar directly 🤔

@talldan
Copy link
Contributor

talldan commented Oct 25, 2022

It looks like DownloadableBlocksPanel doesn't use the isTyping state.

useBlockClassnames is interesting as it's used for hiding the block outline. In #45056 I have the same need to hide the block outline as part of showing a visualizer component.

Maybe hideBlockToolbar is too specific then, and it could be hideBlockInterface / showBlockInterface, that could also then be used to hide the block outline. 🤔

@glendaviesnz
Copy link
Contributor Author

It looks like DownloadableBlocksPanel doesn't use the isTyping state.

Ah, yeh, same name, different source.

Maybe hideBlockToolbar is too specific then, and it could be hideBlockInterface / showBlockInterface, that could also
then be used to hide the block outline. 🤔

I guess then the problem might be that in cases where you want to hide the outline you may not always want to hide the toolbar and vice versa ? 🤔

@talldan
Copy link
Contributor

talldan commented Oct 28, 2022

I guess then the problem might be that in cases where you want to hide the outline you may not always want to hide the toolbar and vice versa ? 🤔

It's a difficult choice 🤔 . I don't think showBlockInterface/hideBlockInterface precludes this, as the action can accept additional parameters. However, right now this use case doesn't exist, and there are a few use cases for hiding or showing both the toolbar and the outline at the same time (margin/padding/alignment visualizers and typing).

The alternative is separate isBlockToolbarHidden and isBlockOutlineHidden state, but it might be too granular. If we merge this though, it'll be the only choice I have in solving for #45056, so that's why I'm a little bit hesitant. 😄

The main points for me are that it's undesirable having two APIs (isTyping and isBlockToolbarHidden) that do the same thing. However at the same time we know there are problems* trying to make them using a single bit of state. Whether that problem can be solved is probably the thing that determines what solution is best. I think it may be worth trying a few different things to solve that to see what works best.

  • moving the mouse triggers isTyping and shows the block toolbar. This conflicts with the desired outcome for the visualizers, where the block toolbar is hidden while the user is moving the mouse.

@glendaviesnz
Copy link
Contributor Author

@talldan I have changed it to isBlockInterfaceHidden so it can be used for your use case - as you not we can add additional params in the future if there ever arises a case where only specific parts of the interface should be hidden.

The difference in mouse actions between the current isTyping and the visualizer use case is tricky, I haven't been able to think of a way of combining them into a single API yet, but will keep thinking about it.

@glendaviesnz
Copy link
Contributor Author

@talldan if we stop propagation of the mouse event in the context of the dimensions control then the stopTyping actions are not fired in my testing, so I think this would open the way for combining isTyping with isBlockInterfaceHidden 🤔 . Should we explore that in this PR, or look to get this merged as is and then explore that?

Copy link
Contributor

@talldan talldan 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 nice improvement, thanks for iterating on the code.

I had a few observations in testing, and they may or may not lead to small adjustments in how this works:

  • When there's no padding or margin, the toolbar is still hidden, but there's no visualization, which doesn't feel quite right to me when using it. Not sure if this is something that's easy to fix.
  • When changing a value and hovering off, the toolbar can reappear momentarily before the visualizer is hidden. I think that's because there's a timeout related to changing the value.
  • Hiding the toolbar is possibly only needed for the margin visualizer, as the padding can't overlap the toolbar. I'm completely on the fence on this one, in some ways it's nice to have it work consistently and hide the toolbar in both cases. Not sure, what do you think?

I would consider these things as low priority though and they shouldn't block merge.

Comment on lines +55 to +64
const onMouseOver = ( e ) => {
e.stopPropagation();
hideBlockInterface();
setIsMouseOver( true );
};
const onMouseOut = ( e ) => {
e.stopPropagation();
showBlockInterface();
setIsMouseOver( false );
};
Copy link
Contributor

Choose a reason for hiding this comment

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

Are the stopPropagation calls still needed here?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

It is there to prevent these mouse events from triggering the stopTyping action in anticipation of us merging that with the showBlockInterface. I could remove them until we actually do that work, but thought it might be worth adding them to prevent this inadvertently breaking when we do get to it.

@glendaviesnz
Copy link
Contributor Author

Thanks @talldan

When there's no padding or margin, the toolbar is still hidden, but there's no visualization, which doesn't feel quite right to me when using it. Not sure if this is something that's easy to fix.

I thought this would be easy but it opened a can of worms, partly related to the timeout mentioned below.

When changing a value and hovering off, the toolbar can reappear momentarily before the visualizer is hidden. I think that's because there's a timeout related to changing the value.

This is related to keeping it working for the Select list when a theme has more than 7 spacing values. I tried fixing this, but combined with the option of not showing 0 values above turned out to cause a rabbit hole of problems 😄

I am going to merge it as is so you can pick up those actions and will add some follow-up issues to deal with the above problems.

Hiding the toolbar is possibly only needed for the margin visualizer, as the padding can't overlap the toolbar. I'm completely on the fence on this one, in some ways it's nice to have it work consistently and hide the toolbar in both cases. Not sure, what do you think?

Yeh, I wondered that, will leave as is and see what wider feedback is, easy to pull out of padding if the consensus is that it is not needed.

@talldan
Copy link
Contributor

talldan commented Nov 3, 2022

I am going to merge it as is so you can pick up those actions and will add some follow-up issues to deal with the above problems.

Sounds good, thanks!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
[Feature] Design Tools Tools that impact the appearance of blocks both to expand the number of tools and improve the experi
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants