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

List View: Add keyboard clipboard events for cut, copy, paste #57838

Merged
merged 10 commits into from
Jan 25, 2024

Conversation

andrewserong
Copy link
Contributor

@andrewserong andrewserong commented Jan 15, 2024

What?

Part of: #49563

Allow clipboard events within the list view to cut, copy, and paste blocks via keyboard shortcut.

Why?

When focus is within the list view, it can be very helpful to quickly copy blocks, or paste blocks over particular selected blocks. This PR allows that to happen.

How?

Make a copy of the useClipboardHandler and attach it to the list view so that it can handle copying, cutting, and pasting both individual and multi-selections of blocks.

The copied useClipboardHandler differs from the one used in the editor canvas in some key ways:

  • Acts on the currently focused list view item if the focused list view item is not part of the selected blocks — this is so that when navigating up and down the list view via keyboard, your actions are being applied to the thing you're working on, not the "block selection". If the focused block is part of a block selection, then we apply the action to the whole block selection, just as we do on trunk when pressing backspace to delete blocks.
  • Intentionally does not handle or deal with partial selections as the list view only deals with whole blocks
  • Keep focus within the list view after cutting or pasting list view items

Testing Instructions

  • In a post with a variety of blocks, open up the list view and click on a list view item a couple of times to ensure that focus is within the list view.
  • Navigate up and down the list view and try CMD+C and CMD+X to copy and cut blocks, and CMD+V to paste blocks.
  • Note that, following the logic used within the editor canvas, when pasting on to a container block, the copied blocks will be added as the last child. When pasting on to a non-container block, it will be replaced with the copied blocks

Screenshots or screencast

2024-01-18.11.46.00.mp4

@andrewserong andrewserong added [Type] Enhancement A suggestion for improvement. [Feature] List View Menu item in the top toolbar to select blocks from a list of links. labels Jan 15, 2024
@andrewserong andrewserong self-assigned this Jan 15, 2024
Copy link

github-actions bot commented Jan 15, 2024

Size Change: -3.52 kB (0%)

Total Size: 1.7 MB

Filename Size Change
build/a11y/index.min.js 955 B -9 B (-1%)
build/annotations/index.min.js 2.69 kB -20 B (-1%)
build/api-fetch/index.min.js 2.32 kB -12 B (-1%)
build/autop/index.min.js 2.1 kB -7 B (0%)
build/blob/index.min.js 578 B -12 B (-2%)
build/block-directory/index.min.js 7.22 kB -32 B (0%)
build/block-directory/style-rtl.css 1.02 kB -28 B (-3%)
build/block-directory/style.css 1.02 kB -27 B (-3%)
build/block-editor/content-rtl.css 4.38 kB -48 B (-1%)
build/block-editor/content.css 4.38 kB -51 B (-1%)
build/block-editor/default-editor-styles-rtl.css 381 B -22 B (-5%)
build/block-editor/default-editor-styles.css 381 B -22 B (-5%)
build/block-editor/index.min.js 250 kB +1.68 kB (+1%)
build/block-editor/style-rtl.css 15.3 kB -379 B (-2%)
build/block-editor/style.css 15.3 kB -380 B (-2%)
build/block-library/blocks/audio/theme-rtl.css 126 B -12 B (-9%)
build/block-library/blocks/audio/theme.css 126 B -12 B (-9%)
build/block-library/blocks/button/editor-rtl.css 415 B -4 B (-1%)
build/block-library/blocks/button/editor.css 414 B -3 B (-1%)
build/block-library/blocks/button/style-rtl.css 627 B -5 B (-1%)
build/block-library/blocks/button/style.css 626 B -5 B (-1%)
build/block-library/blocks/cover/style-rtl.css 1.69 kB -11 B (-1%)
build/block-library/blocks/cover/style.css 1.68 kB -12 B (-1%)
build/block-library/blocks/embed/theme-rtl.css 126 B -12 B (-9%)
build/block-library/blocks/embed/theme.css 126 B -12 B (-9%)
build/block-library/blocks/file/view.min.js 316 B -6 B (-2%)
build/block-library/blocks/form-input/editor-rtl.css 227 B -2 B (-1%)
build/block-library/blocks/form-input/editor.css 227 B -1 B (0%)
build/block-library/blocks/form-submission-notification/editor-rtl.css 340 B -3 B (-1%)
build/block-library/blocks/form-submission-notification/editor.css 340 B -2 B (-1%)
build/block-library/blocks/freeform/editor-rtl.css 2.61 kB -1 B (0%)
build/block-library/blocks/gallery/editor-rtl.css 947 B -10 B (-1%)
build/block-library/blocks/gallery/editor.css 952 B -10 B (-1%)
build/block-library/blocks/gallery/style-rtl.css 1.72 kB -26 B (-1%)
build/block-library/blocks/gallery/style.css 1.72 kB -27 B (-2%)
build/block-library/blocks/gallery/theme-rtl.css 108 B -14 B (-11%) 👏
build/block-library/blocks/gallery/theme.css 108 B -14 B (-11%) 👏
build/block-library/blocks/html/editor-rtl.css 336 B -4 B (-1%)
build/block-library/blocks/html/editor.css 337 B -4 B (-1%)
build/block-library/blocks/image/editor-rtl.css 863 B +29 B (+3%)
build/block-library/blocks/image/editor.css 862 B +29 B (+3%)
build/block-library/blocks/image/style-rtl.css 1.6 kB -7 B (0%)
build/block-library/blocks/image/style.css 1.59 kB -8 B (0%)
build/block-library/blocks/image/theme-rtl.css 126 B -11 B (-8%)
build/block-library/blocks/image/theme.css 126 B -11 B (-8%)
build/block-library/blocks/image/view.min.js 2.01 kB -2 B (0%)
build/block-library/blocks/navigation-link/editor-rtl.css 668 B -3 B (0%)
build/block-library/blocks/navigation-link/editor.css 669 B -3 B (0%)
build/block-library/blocks/navigation-submenu/editor-rtl.css 296 B -3 B (-1%)
build/block-library/blocks/navigation-submenu/editor.css 295 B -4 B (-1%)
build/block-library/blocks/navigation/editor-rtl.css 2.25 kB -5 B (0%)
build/block-library/blocks/navigation/editor.css 2.26 kB -5 B (0%)
build/block-library/blocks/navigation/style-rtl.css 2.24 kB -11 B (0%)
build/block-library/blocks/navigation/style.css 2.23 kB -9 B (0%)
build/block-library/blocks/navigation/view.min.js 1.1 kB -6 B (-1%)
build/block-library/blocks/page-list/editor-rtl.css 377 B -24 B (-6%)
build/block-library/blocks/page-list/editor.css 377 B -24 B (-6%)
build/block-library/blocks/post-featured-image/style-rtl.css 342 B -3 B (-1%)
build/block-library/blocks/post-featured-image/style.css 342 B -3 B (-1%)
build/block-library/blocks/query/view.min.js 1.1 kB +458 B (+71%) 🆘
build/block-library/blocks/search/style-rtl.css 614 B +12 B (+2%)
build/block-library/blocks/search/style.css 614 B +12 B (+2%)
build/block-library/blocks/search/view.min.js 471 B -4 B (-1%)
build/block-library/blocks/shortcode/editor-rtl.css 323 B -6 B (-2%)
build/block-library/blocks/shortcode/editor.css 323 B -6 B (-2%)
build/block-library/blocks/site-logo/editor-rtl.css 754 B -6 B (-1%)
build/block-library/blocks/site-logo/editor.css 754 B -6 B (-1%)
build/block-library/blocks/spacer/editor-rtl.css 348 B -11 B (-3%)
build/block-library/blocks/spacer/editor.css 348 B -11 B (-3%)
build/block-library/blocks/table/style-rtl.css 639 B -7 B (-1%)
build/block-library/blocks/table/style.css 639 B -6 B (-1%)
build/block-library/blocks/table/theme-rtl.css 146 B -11 B (-7%)
build/block-library/blocks/table/theme.css 146 B -11 B (-7%)
build/block-library/blocks/video/style-rtl.css 185 B -6 B (-3%)
build/block-library/blocks/video/style.css 185 B -6 B (-3%)
build/block-library/blocks/video/theme-rtl.css 126 B -13 B (-9%)
build/block-library/blocks/video/theme.css 126 B -13 B (-9%)
build/block-library/common-rtl.css 1.1 kB -12 B (-1%)
build/block-library/common.css 1.1 kB -13 B (-1%)
build/block-library/editor-rtl.css 12.3 kB -20 B (0%)
build/block-library/editor.css 12.3 kB -22 B (0%)
build/block-library/index.min.js 215 kB -289 B (0%)
build/block-library/style-rtl.css 14.7 kB -49 B (0%)
build/block-library/style.css 14.7 kB -39 B (0%)
build/block-library/theme-rtl.css 688 B -12 B (-2%)
build/block-library/theme.css 693 B -12 B (-2%)
build/block-serialization-default-parser/index.min.js 1.12 kB -8 B (-1%)
build/block-serialization-spec-parser/index.min.js 2.87 kB -2 B (0%)
build/blocks/index.min.js 51.5 kB -98 B (0%)
build/commands/index.min.js 15.5 kB -2 B (0%)
build/commands/style-rtl.css 921 B -26 B (-3%)
build/commands/style.css 918 B -24 B (-3%)
build/components/index.min.js 235 kB -609 B (0%)
build/components/style-rtl.css 12 kB -87 B (-1%)
build/components/style.css 12.1 kB -86 B (-1%)
build/compose/index.min.js 12.6 kB -16 B (0%)
build/core-commands/index.min.js 2.71 kB -15 B (-1%)
build/core-data/index.min.js 72.7 kB -80 B (0%)
build/customize-widgets/index.min.js 12.1 kB -9 B (0%)
build/customize-widgets/style-rtl.css 1.34 kB -25 B (-2%)
build/customize-widgets/style.css 1.33 kB -25 B (-2%)
build/data-controls/index.min.js 640 B -11 B (-2%)
build/data/index.min.js 8.92 kB -43 B (0%)
build/date/index.min.js 17.8 kB -10 B (0%)
build/deprecated/index.min.js 451 B -11 B (-2%)
build/dom-ready/index.min.js 324 B -12 B (-4%)
build/dom/index.min.js 4.65 kB -40 B (-1%)
build/edit-post/classic-rtl.css 544 B -27 B (-5%)
build/edit-post/classic.css 545 B -26 B (-5%)
build/edit-post/index.min.js 25 kB +125 B (+1%)
build/edit-post/style-rtl.css 5.62 kB -63 B (-1%)
build/edit-post/style.css 5.61 kB -62 B (-1%)
build/edit-site/index.min.js 195 kB -873 B (0%)
build/edit-site/style-rtl.css 15.2 kB +15 B (0%)
build/edit-site/style.css 15.2 kB +18 B (0%)
build/edit-widgets/index.min.js 17.3 kB -64 B (0%)
build/edit-widgets/style-rtl.css 4.39 kB -50 B (-1%)
build/edit-widgets/style.css 4.39 kB -47 B (-1%)
build/editor/index.min.js 61.5 kB -287 B (0%)
build/editor/style-rtl.css 5.42 kB -60 B (-1%)
build/editor/style.css 5.42 kB -62 B (-1%)
build/element/index.min.js 4.83 kB -41 B (-1%)
build/escape-html/index.min.js 537 B -11 B (-2%)
build/format-library/index.min.js 7.93 kB -48 B (-1%)
build/format-library/style-rtl.css 478 B -22 B (-4%)
build/format-library/style.css 477 B -23 B (-5%)
build/hooks/index.min.js 1.55 kB -23 B (-1%)
build/html-entities/index.min.js 448 B -6 B (-1%)
build/i18n/index.min.js 3.58 kB -28 B (-1%)
build/interactivity/file.min.js 440 B -2 B (0%)
build/interactivity/image.min.js 2.15 kB -4 B (0%)
build/interactivity/index.min.js 12.9 kB -235 B (-2%)
build/interactivity/navigation.min.js 1.23 kB +3 B (0%)
build/interactivity/query.min.js 884 B +93 B (+12%) ⚠️
build/is-shallow-equal/index.min.js 527 B -8 B (-1%)
build/keyboard-shortcuts/index.min.js 1.74 kB -18 B (-1%)
build/keycodes/index.min.js 1.46 kB -33 B (-2%)
build/list-reusable-blocks/index.min.js 2.11 kB +4 B (0%)
build/list-reusable-blocks/style-rtl.css 836 B -29 B (-3%)
build/list-reusable-blocks/style.css 836 B -29 B (-3%)
build/media-utils/index.min.js 2.9 kB -16 B (-1%)
build/notices/index.min.js 948 B -16 B (-2%)
build/nux/index.min.js 2 kB -16 B (-1%)
build/nux/style-rtl.css 735 B -40 B (-5%)
build/nux/style.css 732 B -39 B (-5%)
build/patterns/index.min.js 5.47 kB +38 B (+1%)
build/patterns/style-rtl.css 540 B -24 B (-4%)
build/patterns/style.css 539 B -25 B (-4%)
build/plugins/index.min.js 1.8 kB -14 B (-1%)
build/preferences-persistence/index.min.js 2.07 kB -9 B (0%)
build/preferences/index.min.js 2.81 kB -17 B (-1%)
build/preferences/style-rtl.css 698 B -27 B (-4%)
build/preferences/style.css 700 B -28 B (-4%)
build/primitives/index.min.js 975 B -19 B (-2%)
build/priority-queue/index.min.js 1.52 kB -2 B (0%)
build/private-apis/index.min.js 1 kB -13 B (-1%)
build/react-i18n/index.min.js 623 B -8 B (-1%)
build/react-refresh-entry/index.min.js 9.47 kB +2 B (0%)
build/react-refresh-runtime/index.min.js 6.78 kB +1 B (0%)
build/redux-routine/index.min.js 2.7 kB -3 B (0%)
build/reusable-blocks/index.min.js 2.72 kB -21 B (-1%)
build/reusable-blocks/style-rtl.css 243 B -22 B (-8%)
build/reusable-blocks/style.css 243 B -22 B (-8%)
build/rich-text/index.min.js 10.4 kB -38 B (0%)
build/router/index.min.js 1.79 kB +2 B (0%)
build/server-side-render/index.min.js 1.95 kB -11 B (-1%)
build/shortcode/index.min.js 1.39 kB -8 B (-1%)
build/style-engine/index.min.js 2.07 kB +11 B (+1%)
build/token-list/index.min.js 582 B -5 B (-1%)
build/url/index.min.js 3.72 kB -104 B (-3%)
build/viewport/index.min.js 957 B -10 B (-1%)
build/warning/index.min.js 249 B -10 B (-4%)
build/widgets/index.min.js 7.21 kB -10 B (0%)
build/widgets/style-rtl.css 1.15 kB -27 B (-2%)
build/widgets/style.css 1.16 kB -26 B (-2%)
build/wordcount/index.min.js 1.02 kB -4 B (0%)
ℹ️ View Unchanged
Filename Size
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/avatar/editor-rtl.css 116 B
build/block-library/blocks/avatar/editor.css 116 B
build/block-library/blocks/avatar/style-rtl.css 104 B
build/block-library/blocks/avatar/style.css 104 B
build/block-library/blocks/block/editor-rtl.css 305 B
build/block-library/blocks/block/editor.css 305 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 113 B
build/block-library/blocks/categories/editor.css 112 B
build/block-library/blocks/categories/style-rtl.css 124 B
build/block-library/blocks/categories/style.css 124 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 421 B
build/block-library/blocks/columns/style.css 421 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 199 B
build/block-library/blocks/comment-template/style.css 198 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 647 B
build/block-library/blocks/cover/editor.css 650 B
build/block-library/blocks/details/editor-rtl.css 65 B
build/block-library/blocks/details/editor.css 65 B
build/block-library/blocks/details/style-rtl.css 98 B
build/block-library/blocks/details/style.css 98 B
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/file/editor-rtl.css 316 B
build/block-library/blocks/file/editor.css 316 B
build/block-library/blocks/file/style-rtl.css 280 B
build/block-library/blocks/file/style.css 281 B
build/block-library/blocks/footnotes/style-rtl.css 201 B
build/block-library/blocks/footnotes/style.css 199 B
build/block-library/blocks/form-input/style-rtl.css 343 B
build/block-library/blocks/form-input/style.css 343 B
build/block-library/blocks/form-submit-button/style-rtl.css 69 B
build/block-library/blocks/form-submit-button/style.css 69 B
build/block-library/blocks/form/view.min.js 452 B
build/block-library/blocks/freeform/editor.css 2.61 kB
build/block-library/blocks/group/editor-rtl.css 654 B
build/block-library/blocks/group/editor.css 654 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 189 B
build/block-library/blocks/heading/style.css 189 B
build/block-library/blocks/latest-comments/style-rtl.css 357 B
build/block-library/blocks/latest-comments/style.css 357 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 478 B
build/block-library/blocks/latest-posts/style.css 478 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 505 B
build/block-library/blocks/media-text/style.css 503 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/style-rtl.css 103 B
build/block-library/blocks/navigation-link/style.css 103 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/style-rtl.css 175 B
build/block-library/blocks/page-list/style.css 175 B
build/block-library/blocks/paragraph/editor-rtl.css 235 B
build/block-library/blocks/paragraph/editor.css 235 B
build/block-library/blocks/paragraph/style-rtl.css 335 B
build/block-library/blocks/paragraph/style.css 335 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-comments-form/style-rtl.css 508 B
build/block-library/blocks/post-comments-form/style.css 508 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 71 B
build/block-library/blocks/post-excerpt/editor.css 71 B
build/block-library/blocks/post-excerpt/style-rtl.css 141 B
build/block-library/blocks/post-excerpt/style.css 141 B
build/block-library/blocks/post-featured-image/editor-rtl.css 666 B
build/block-library/blocks/post-featured-image/editor.css 662 B
build/block-library/blocks/post-navigation-link/style-rtl.css 215 B
build/block-library/blocks/post-navigation-link/style.css 214 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 409 B
build/block-library/blocks/post-template/style.css 408 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-time-to-read/style-rtl.css 69 B
build/block-library/blocks/post-time-to-read/style.css 69 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 125 B
build/block-library/blocks/preformatted/style.css 125 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 354 B
build/block-library/blocks/pullquote/style.css 354 B
build/block-library/blocks/pullquote/theme-rtl.css 168 B
build/block-library/blocks/pullquote/theme.css 168 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 288 B
build/block-library/blocks/query-pagination/style.css 284 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 486 B
build/block-library/blocks/query/editor.css 486 B
build/block-library/blocks/query/style-rtl.css 312 B
build/block-library/blocks/query/style.css 308 B
build/block-library/blocks/quote/style-rtl.css 237 B
build/block-library/blocks/quote/style.css 237 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 140 B
build/block-library/blocks/read-more/style.css 140 B
build/block-library/blocks/rss/editor-rtl.css 149 B
build/block-library/blocks/rss/editor.css 149 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 184 B
build/block-library/blocks/search/editor.css 184 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/site-logo/style-rtl.css 204 B
build/block-library/blocks/site-logo/style.css 204 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 682 B
build/block-library/blocks/social-links/editor.css 681 B
build/block-library/blocks/social-links/style-rtl.css 1.49 kB
build/block-library/blocks/social-links/style.css 1.49 kB
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 395 B
build/block-library/blocks/table/editor.css 395 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 403 B
build/block-library/blocks/template-part/editor.css 403 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/term-description/style-rtl.css 111 B
build/block-library/blocks/term-description/style.css 111 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 99 B
build/block-library/blocks/verse/style.css 99 B
build/block-library/blocks/video/editor-rtl.css 552 B
build/block-library/blocks/video/editor.css 555 B
build/block-library/classic-rtl.css 179 B
build/block-library/classic.css 179 B
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 472 B
build/block-library/reset.css 472 B
build/interactivity/router.min.js 952 B
build/interactivity/search.min.js 610 B
build/modules/importmap-polyfill.min.js 12.2 kB
build/vendors/inert-polyfill.min.js 2.48 kB
build/vendors/react-dom.min.js 41.8 kB
build/vendors/react.min.js 4.02 kB

compressed-size-action

@andrewserong andrewserong force-pushed the try/add-clipboard-events-to-the-list-view branch from 9924e91 to 8edc4c6 Compare January 17, 2024 00:03
@andrewserong andrewserong changed the title List View: Try adding keyboard clipboard events for cut, copy, paste List View: Add keyboard clipboard events for cut, copy, paste Jan 18, 2024
@andrewserong andrewserong marked this pull request as ready for review January 18, 2024 00:49
@andrewserong andrewserong force-pushed the try/add-clipboard-events-to-the-list-view branch from 674638d to b4143f1 Compare January 18, 2024 03:23
@noisysocks
Copy link
Member

This is testing beautifully. Looking at the code now 👀

@andrewserong andrewserong force-pushed the try/add-clipboard-events-to-the-list-view branch from b4143f1 to 75d06fa Compare January 23, 2024 00:58
@andrewserong
Copy link
Contributor Author

Thanks for taking a look! I've just given this a rebase to keep things current now that #56625 has landed.

Copy link

github-actions bot commented Jan 23, 2024

Flaky tests detected in 68ed6c7.
Some tests passed with failed attempts. The failures may not be related to this commit but are still reported for visibility. See the documentation for more information.

🔍 Workflow run URL: https://github.com/WordPress/gutenberg/actions/runs/7621336864
📝 Reported issues:

Copy link
Member

@noisysocks noisysocks left a comment

Choose a reason for hiding this comment

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

Tests really really well, like I said 👍

How do you feel about extracting some of the common parts of packages/block-editor/src/components/list-view/use-clipboard-handler.js and packages/block-editor/src/components/writing-flow/use-clipboard-handler.js?

Right now there's a lot of overlap which I think will bite us in the future when a contributor makes a fix or performance improvement to one hook but forgets (or doesn't know about) the other.

Perhaps both hooks could live in the same file and call the same set of util functions that do all of the block creation, serialisation, setting of clipboard data, block transform handling, block insertion, etc. Only the code that deals with block selection would differ.

packages/block-editor/src/components/list-view/utils.js Outdated Show resolved Hide resolved
await pageUtils.pressKeys( 'primary+v' );

await expect
.poll(
Copy link
Member

Choose a reason for hiding this comment

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

TIL about expect.poll. Just for my own understanding, what's the reason for using it here? Is it not enough to rely on Playwright's default behaviour of waiting for the selector to appear?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

That's a great question! I was just following the examples from the other tests, which use poll. In this case we're polling for an expected object that is returned by a function call, rather than for a particular selector. Internally, getBlocksWithA11yAttributes is calling getByRole etc to grab the row element itself, so I imagine this was an abstraction so that we can just focus on the shape of the block data, rather than selectors within these particular tests?

It looks like the abstraction was added in #50422 by @kevin940726. To my eyes it improves readability quite a bit, but Kai might have more context to offer 🙂

Copy link
Member

Choose a reason for hiding this comment

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

I don't think we need it here, but it's just a preference of mine to make the assertion retryable to reduce potential flakiness.

It might be a common misconception that Playwright automatically waits for the elements when you query them, but it doesn't. It only waits for the element when you perform some "actions" on them (like clicking, or asserting). In getBlocksWithA11yAttributes we're not performing any actions so they might be outdated.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Great, thanks for confirming the reasoning, Kai!

@andrewserong
Copy link
Contributor Author

How do you feel about extracting some of the common parts of packages/block-editor/src/components/list-view/use-clipboard-handler.js and packages/block-editor/src/components/writing-flow/use-clipboard-handler.js?

Oh, I like that idea, but at the same time, there's a bit of a trade-off to be made with consolidating behaviour within the writing flow and list views. When folks go to make changes to one or the other, it can be handy to know that you're not going to accidentally adversely affect the other environment, which is why I tend to lean a bit more toward duplication when dealing with the list view, as it has some nuances that we want to keep separate. Beyond block selection there's also:

  • The list view shouldn't deal with partial selections so we would need to skip those parts of the writing flow logic
  • The list view needs to determine which blocks to update based on the currently focused block
  • The list view needs to update selection and focus once the action is complete

But I do very much like the idea of seeing what we can split out into utility functions. If that works neatly enough, perhaps we can have cleaner to read hooks that could help reduce some of the duplication while still having separate logic where needed 🤔

I'll have a hack around tomorrow and see what's feasible!

@andrewserong
Copy link
Contributor Author

Thanks @noisysocks! I struggled a bit at first trying to consolidate between the two hooks, but the low hanging fruit wound up being consolidating the logic inside the copy and paste handling, so I've created a couple of utility functions in 885b147 for the bits that could be consolidated without creating messy function signatures.

From a quick re-test, I don't think I've broken anything in the process, but it'd be good to give this another whirl to be sure 😄

Copy link
Member

@noisysocks noisysocks left a comment

Choose a reason for hiding this comment

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

LGTM 👍

I think you've struck a perfect balance with splitting out getPasteBlocks and setClipboardBlocks.

Everything's testing well for me locally.

@andrewserong
Copy link
Contributor Author

Thanks for all the help, Rob!

@andrewserong andrewserong merged commit a2d9738 into trunk Jan 25, 2024
56 checks passed
@andrewserong andrewserong deleted the try/add-clipboard-events-to-the-list-view branch January 25, 2024 00:26
@github-actions github-actions bot added this to the Gutenberg 17.7 milestone Jan 25, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
[Feature] List View Menu item in the top toolbar to select blocks from a list of links. [Type] Enhancement A suggestion for improvement.
Projects
No open projects
Status: Done
Development

Successfully merging this pull request may close these issues.

3 participants