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

Link Shortcut: Only trigger the link shortcut if there's a text selection #66056

Merged
merged 3 commits into from
Oct 23, 2024

Conversation

youknowriad
Copy link
Contributor

@youknowriad youknowriad commented Oct 11, 2024

Related #51737

What?

The cmd + k shortcut conflicts between links and command palette. So when you're in a RichText, it's not possible to trigger the command palette. That said, the link is only useful if you actually have a text selection.

So while this doesn't solve the problem 100%, I think it's a decent a reasonable fix for 99% of the cases.

Testing Instructions

1- Create a post.
2- Type some text.
3- Type cmd + k, it should trigger the command palette.
4- Select some text and then hit cmd+k, it should open the link format popup.

@youknowriad youknowriad added [Type] Bug An existing feature does not function as intended [Feature] Link Editing Link components (LinkControl, URLInput) and integrations (RichText link formatting) [Package] Commands /packages/commands labels Oct 11, 2024
@youknowriad youknowriad self-assigned this Oct 11, 2024
@youknowriad youknowriad requested a review from ellatrix as a code owner October 11, 2024 10:33
Copy link

github-actions bot commented Oct 11, 2024

The following accounts have interacted with this PR and/or linked issues. I will continue to update these lists as activity occurs. You can also manually ask me to refresh this list by adding the props-bot label.

If you're merging code through a pull request on GitHub, copy and paste the following into the bottom of the merge commit message.

Co-authored-by: youknowriad <youknowriad@git.wordpress.org>
Co-authored-by: ellatrix <ellatrix@git.wordpress.org>
Co-authored-by: richtabor <richtabor@git.wordpress.org>
Co-authored-by: stokesman <presstoke@git.wordpress.org>
Co-authored-by: getdave <get_dave@git.wordpress.org>

To understand the WordPress project's expectations around crediting contributors, please review the Contributor Attribution page in the Core Handbook.

Copy link

github-actions bot commented Oct 11, 2024

Size Change: +13 B (0%)

Total Size: 1.77 MB

Filename Size Change
build/format-library/index.min.js 8.05 kB +13 B (+0.16%)
ℹ️ View Unchanged
Filename Size
build-module/a11y/index.min.js 482 B
build-module/block-library/file/view.min.js 447 B
build-module/block-library/image/view.min.js 1.78 kB
build-module/block-library/navigation/view.min.js 1.16 kB
build-module/block-library/query/view.min.js 742 B
build-module/block-library/search/view.min.js 616 B
build-module/interactivity-router/index.min.js 3.03 kB
build-module/interactivity/debug.min.js 17.2 kB
build-module/interactivity/index.min.js 13.6 kB
build/a11y/index.min.js 952 B
build/annotations/index.min.js 2.26 kB
build/api-fetch/index.min.js 2.32 kB
build/autop/index.min.js 2.12 kB
build/blob/index.min.js 579 B
build/block-directory/index.min.js 7.26 kB
build/block-directory/style-rtl.css 1.07 kB
build/block-directory/style.css 1.07 kB
build/block-editor/content-rtl.css 4.46 kB
build/block-editor/content.css 4.45 kB
build/block-editor/default-editor-styles-rtl.css 394 B
build/block-editor/default-editor-styles.css 394 B
build/block-editor/index.min.js 255 kB
build/block-editor/style-rtl.css 15.3 kB
build/block-editor/style.css 15.3 kB
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 149 B
build/block-library/blocks/audio/editor.css 151 B
build/block-library/blocks/audio/style-rtl.css 132 B
build/block-library/blocks/audio/style.css 132 B
build/block-library/blocks/audio/theme-rtl.css 134 B
build/block-library/blocks/audio/theme.css 134 B
build/block-library/blocks/avatar/editor-rtl.css 115 B
build/block-library/blocks/avatar/editor.css 115 B
build/block-library/blocks/avatar/style-rtl.css 104 B
build/block-library/blocks/avatar/style.css 104 B
build/block-library/blocks/button/editor-rtl.css 265 B
build/block-library/blocks/button/editor.css 265 B
build/block-library/blocks/button/style-rtl.css 538 B
build/block-library/blocks/button/style.css 538 B
build/block-library/blocks/buttons/editor-rtl.css 291 B
build/block-library/blocks/buttons/editor.css 291 B
build/block-library/blocks/buttons/style-rtl.css 345 B
build/block-library/blocks/buttons/style.css 345 B
build/block-library/blocks/calendar/style-rtl.css 240 B
build/block-library/blocks/calendar/style.css 240 B
build/block-library/blocks/categories/editor-rtl.css 132 B
build/block-library/blocks/categories/editor.css 131 B
build/block-library/blocks/categories/style-rtl.css 152 B
build/block-library/blocks/categories/style.css 152 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 139 B
build/block-library/blocks/code/style.css 139 B
build/block-library/blocks/code/theme-rtl.css 122 B
build/block-library/blocks/code/theme.css 122 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 420 B
build/block-library/blocks/columns/style.css 420 B
build/block-library/blocks/comment-author-avatar/editor-rtl.css 124 B
build/block-library/blocks/comment-author-avatar/editor.css 124 B
build/block-library/blocks/comment-author-name/style-rtl.css 72 B
build/block-library/blocks/comment-author-name/style.css 72 B
build/block-library/blocks/comment-content/style-rtl.css 120 B
build/block-library/blocks/comment-content/style.css 120 B
build/block-library/blocks/comment-date/style-rtl.css 65 B
build/block-library/blocks/comment-date/style.css 65 B
build/block-library/blocks/comment-edit-link/style-rtl.css 70 B
build/block-library/blocks/comment-edit-link/style.css 70 B
build/block-library/blocks/comment-reply-link/style-rtl.css 71 B
build/block-library/blocks/comment-reply-link/style.css 71 B
build/block-library/blocks/comment-template/style-rtl.css 200 B
build/block-library/blocks/comment-template/style.css 199 B
build/block-library/blocks/comments-pagination-numbers/editor-rtl.css 122 B
build/block-library/blocks/comments-pagination-numbers/editor.css 121 B
build/block-library/blocks/comments-pagination/editor-rtl.css 228 B
build/block-library/blocks/comments-pagination/editor.css 217 B
build/block-library/blocks/comments-pagination/style-rtl.css 234 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 832 B
build/block-library/blocks/comments/editor.css 832 B
build/block-library/blocks/comments/style-rtl.css 632 B
build/block-library/blocks/comments/style.css 631 B
build/block-library/blocks/cover/editor-rtl.css 641 B
build/block-library/blocks/cover/editor.css 642 B
build/block-library/blocks/cover/style-rtl.css 1.64 kB
build/block-library/blocks/cover/style.css 1.63 kB
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 86 B
build/block-library/blocks/details/style.css 86 B
build/block-library/blocks/embed/editor-rtl.css 331 B
build/block-library/blocks/embed/editor.css 331 B
build/block-library/blocks/embed/style-rtl.css 419 B
build/block-library/blocks/embed/style.css 419 B
build/block-library/blocks/embed/theme-rtl.css 133 B
build/block-library/blocks/embed/theme.css 133 B
build/block-library/blocks/file/editor-rtl.css 326 B
build/block-library/blocks/file/editor.css 326 B
build/block-library/blocks/file/style-rtl.css 278 B
build/block-library/blocks/file/style.css 279 B
build/block-library/blocks/footnotes/style-rtl.css 198 B
build/block-library/blocks/footnotes/style.css 197 B
build/block-library/blocks/form-input/editor-rtl.css 229 B
build/block-library/blocks/form-input/editor.css 229 B
build/block-library/blocks/form-input/style-rtl.css 357 B
build/block-library/blocks/form-input/style.css 357 B
build/block-library/blocks/form-submission-notification/editor-rtl.css 344 B
build/block-library/blocks/form-submission-notification/editor.css 341 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 470 B
build/block-library/blocks/freeform/editor-rtl.css 2.6 kB
build/block-library/blocks/freeform/editor.css 2.6 kB
build/block-library/blocks/gallery/editor-rtl.css 946 B
build/block-library/blocks/gallery/editor.css 951 B
build/block-library/blocks/gallery/style-rtl.css 1.83 kB
build/block-library/blocks/gallery/style.css 1.82 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 334 B
build/block-library/blocks/group/editor.css 334 B
build/block-library/blocks/group/style-rtl.css 103 B
build/block-library/blocks/group/style.css 103 B
build/block-library/blocks/group/theme-rtl.css 79 B
build/block-library/blocks/group/theme.css 79 B
build/block-library/blocks/heading/style-rtl.css 188 B
build/block-library/blocks/heading/style.css 188 B
build/block-library/blocks/html/editor-rtl.css 346 B
build/block-library/blocks/html/editor.css 347 B
build/block-library/blocks/image/editor-rtl.css 785 B
build/block-library/blocks/image/editor.css 787 B
build/block-library/blocks/image/style-rtl.css 1.59 kB
build/block-library/blocks/image/style.css 1.59 kB
build/block-library/blocks/image/theme-rtl.css 137 B
build/block-library/blocks/image/theme.css 137 B
build/block-library/blocks/latest-comments/style-rtl.css 355 B
build/block-library/blocks/latest-comments/style.css 354 B
build/block-library/blocks/latest-posts/editor-rtl.css 179 B
build/block-library/blocks/latest-posts/editor.css 179 B
build/block-library/blocks/latest-posts/style-rtl.css 509 B
build/block-library/blocks/latest-posts/style.css 510 B
build/block-library/blocks/list/style-rtl.css 107 B
build/block-library/blocks/list/style.css 107 B
build/block-library/blocks/loginout/style-rtl.css 61 B
build/block-library/blocks/loginout/style.css 61 B
build/block-library/blocks/media-text/editor-rtl.css 321 B
build/block-library/blocks/media-text/editor.css 320 B
build/block-library/blocks/media-text/style-rtl.css 558 B
build/block-library/blocks/media-text/style.css 556 B
build/block-library/blocks/more/editor-rtl.css 427 B
build/block-library/blocks/more/editor.css 427 B
build/block-library/blocks/navigation-link/editor-rtl.css 644 B
build/block-library/blocks/navigation-link/editor.css 645 B
build/block-library/blocks/navigation-link/style-rtl.css 192 B
build/block-library/blocks/navigation-link/style.css 191 B
build/block-library/blocks/navigation-submenu/editor-rtl.css 295 B
build/block-library/blocks/navigation-submenu/editor.css 294 B
build/block-library/blocks/navigation/editor-rtl.css 2.2 kB
build/block-library/blocks/navigation/editor.css 2.2 kB
build/block-library/blocks/navigation/style-rtl.css 2.25 kB
build/block-library/blocks/navigation/style.css 2.23 kB
build/block-library/blocks/nextpage/editor-rtl.css 392 B
build/block-library/blocks/nextpage/editor.css 392 B
build/block-library/blocks/page-list/editor-rtl.css 378 B
build/block-library/blocks/page-list/editor.css 378 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 236 B
build/block-library/blocks/paragraph/editor.css 236 B
build/block-library/blocks/paragraph/style-rtl.css 341 B
build/block-library/blocks/paragraph/style.css 340 B
build/block-library/blocks/post-author-biography/style-rtl.css 74 B
build/block-library/blocks/post-author-biography/style.css 74 B
build/block-library/blocks/post-author-name/style-rtl.css 69 B
build/block-library/blocks/post-author-name/style.css 69 B
build/block-library/blocks/post-author/editor-rtl.css 107 B
build/block-library/blocks/post-author/editor.css 107 B
build/block-library/blocks/post-author/style-rtl.css 188 B
build/block-library/blocks/post-author/style.css 189 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 527 B
build/block-library/blocks/post-comments-form/style.css 528 B
build/block-library/blocks/post-content/style-rtl.css 61 B
build/block-library/blocks/post-content/style.css 61 B
build/block-library/blocks/post-date/style-rtl.css 62 B
build/block-library/blocks/post-date/style.css 62 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 155 B
build/block-library/blocks/post-excerpt/style.css 155 B
build/block-library/blocks/post-featured-image/editor-rtl.css 729 B
build/block-library/blocks/post-featured-image/editor.css 726 B
build/block-library/blocks/post-featured-image/style-rtl.css 347 B
build/block-library/blocks/post-featured-image/style.css 347 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 399 B
build/block-library/blocks/post-template/style.css 398 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 70 B
build/block-library/blocks/post-time-to-read/style.css 70 B
build/block-library/blocks/post-title/style-rtl.css 162 B
build/block-library/blocks/post-title/style.css 162 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 134 B
build/block-library/blocks/pullquote/editor.css 134 B
build/block-library/blocks/pullquote/style-rtl.css 342 B
build/block-library/blocks/pullquote/style.css 342 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 121 B
build/block-library/blocks/query-pagination-numbers/editor.css 118 B
build/block-library/blocks/query-pagination/editor-rtl.css 154 B
build/block-library/blocks/query-pagination/editor.css 154 B
build/block-library/blocks/query-pagination/style-rtl.css 237 B
build/block-library/blocks/query-pagination/style.css 237 B
build/block-library/blocks/query-title/style-rtl.css 64 B
build/block-library/blocks/query-title/style.css 64 B
build/block-library/blocks/query/editor-rtl.css 452 B
build/block-library/blocks/query/editor.css 451 B
build/block-library/blocks/quote/style-rtl.css 238 B
build/block-library/blocks/quote/style.css 238 B
build/block-library/blocks/quote/theme-rtl.css 233 B
build/block-library/blocks/quote/theme.css 236 B
build/block-library/blocks/read-more/style-rtl.css 138 B
build/block-library/blocks/read-more/style.css 138 B
build/block-library/blocks/rss/editor-rtl.css 101 B
build/block-library/blocks/rss/editor.css 101 B
build/block-library/blocks/rss/style-rtl.css 288 B
build/block-library/blocks/rss/style.css 287 B
build/block-library/blocks/search/editor-rtl.css 199 B
build/block-library/blocks/search/editor.css 199 B
build/block-library/blocks/search/style-rtl.css 672 B
build/block-library/blocks/search/style.css 671 B
build/block-library/blocks/search/theme-rtl.css 113 B
build/block-library/blocks/search/theme.css 113 B
build/block-library/blocks/separator/editor-rtl.css 100 B
build/block-library/blocks/separator/editor.css 100 B
build/block-library/blocks/separator/style-rtl.css 248 B
build/block-library/blocks/separator/style.css 248 B
build/block-library/blocks/separator/theme-rtl.css 195 B
build/block-library/blocks/separator/theme.css 195 B
build/block-library/blocks/shortcode/editor-rtl.css 286 B
build/block-library/blocks/shortcode/editor.css 286 B
build/block-library/blocks/site-logo/editor-rtl.css 806 B
build/block-library/blocks/site-logo/editor.css 803 B
build/block-library/blocks/site-logo/style-rtl.css 218 B
build/block-library/blocks/site-logo/style.css 218 B
build/block-library/blocks/site-tagline/editor-rtl.css 87 B
build/block-library/blocks/site-tagline/editor.css 87 B
build/block-library/blocks/site-tagline/style-rtl.css 65 B
build/block-library/blocks/site-tagline/style.css 65 B
build/block-library/blocks/site-title/editor-rtl.css 85 B
build/block-library/blocks/site-title/editor.css 85 B
build/block-library/blocks/site-title/style-rtl.css 143 B
build/block-library/blocks/site-title/style.css 143 B
build/block-library/blocks/social-link/editor-rtl.css 338 B
build/block-library/blocks/social-link/editor.css 338 B
build/block-library/blocks/social-links/editor-rtl.css 729 B
build/block-library/blocks/social-links/editor.css 727 B
build/block-library/blocks/social-links/style-rtl.css 1.51 kB
build/block-library/blocks/social-links/style.css 1.5 kB
build/block-library/blocks/spacer/editor-rtl.css 346 B
build/block-library/blocks/spacer/editor.css 346 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-of-contents/style-rtl.css 83 B
build/block-library/blocks/table-of-contents/style.css 83 B
build/block-library/blocks/table/editor-rtl.css 394 B
build/block-library/blocks/table/editor.css 394 B
build/block-library/blocks/table/style-rtl.css 640 B
build/block-library/blocks/table/style.css 639 B
build/block-library/blocks/table/theme-rtl.css 152 B
build/block-library/blocks/table/theme.css 152 B
build/block-library/blocks/tag-cloud/editor-rtl.css 144 B
build/block-library/blocks/tag-cloud/editor.css 144 B
build/block-library/blocks/tag-cloud/style-rtl.css 266 B
build/block-library/blocks/tag-cloud/style.css 265 B
build/block-library/blocks/template-part/editor-rtl.css 368 B
build/block-library/blocks/template-part/editor.css 368 B
build/block-library/blocks/template-part/theme-rtl.css 113 B
build/block-library/blocks/template-part/theme.css 113 B
build/block-library/blocks/term-description/style-rtl.css 126 B
build/block-library/blocks/term-description/style.css 126 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 165 B
build/block-library/blocks/text-columns/style.css 165 B
build/block-library/blocks/verse/style-rtl.css 98 B
build/block-library/blocks/verse/style.css 98 B
build/block-library/blocks/video/editor-rtl.css 396 B
build/block-library/blocks/video/editor.css 397 B
build/block-library/blocks/video/style-rtl.css 192 B
build/block-library/blocks/video/style.css 192 B
build/block-library/blocks/video/theme-rtl.css 134 B
build/block-library/blocks/video/theme.css 134 B
build/block-library/classic-rtl.css 179 B
build/block-library/classic.css 179 B
build/block-library/common-rtl.css 1.08 kB
build/block-library/common.css 1.08 kB
build/block-library/editor-elements-rtl.css 75 B
build/block-library/editor-elements.css 75 B
build/block-library/editor-rtl.css 11.7 kB
build/block-library/editor.css 11.7 kB
build/block-library/elements-rtl.css 54 B
build/block-library/elements.css 54 B
build/block-library/index.min.js 220 kB
build/block-library/reset-rtl.css 472 B
build/block-library/reset.css 472 B
build/block-library/style-rtl.css 14.9 kB
build/block-library/style.css 14.9 kB
build/block-library/theme-rtl.css 708 B
build/block-library/theme.css 712 B
build/block-serialization-default-parser/index.min.js 1.12 kB
build/block-serialization-spec-parser/index.min.js 2.87 kB
build/blocks/index.min.js 52.5 kB
build/commands/index.min.js 16.1 kB
build/commands/style-rtl.css 955 B
build/commands/style.css 952 B
build/components/index.min.js 227 kB
build/components/style-rtl.css 12.4 kB
build/components/style.css 12.4 kB
build/compose/index.min.js 12.7 kB
build/core-commands/index.min.js 3.11 kB
build/core-data/index.min.js 73.4 kB
build/customize-widgets/index.min.js 11 kB
build/customize-widgets/style-rtl.css 1.35 kB
build/customize-widgets/style.css 1.35 kB
build/data-controls/index.min.js 641 B
build/data/index.min.js 8.97 kB
build/date/index.min.js 18 kB
build/deprecated/index.min.js 458 B
build/dom-ready/index.min.js 325 B
build/dom/index.min.js 4.66 kB
build/edit-post/classic-rtl.css 578 B
build/edit-post/classic.css 580 B
build/edit-post/index.min.js 13.7 kB
build/edit-post/style-rtl.css 2.76 kB
build/edit-post/style.css 2.75 kB
build/edit-site/index.min.js 218 kB
build/edit-site/posts-rtl.css 7.32 kB
build/edit-site/posts.css 7.32 kB
build/edit-site/style-rtl.css 12.6 kB
build/edit-site/style.css 12.6 kB
build/edit-widgets/index.min.js 17.7 kB
build/edit-widgets/style-rtl.css 4.19 kB
build/edit-widgets/style.css 4.19 kB
build/editor/index.min.js 103 kB
build/editor/style-rtl.css 9.37 kB
build/editor/style.css 9.38 kB
build/element/index.min.js 4.82 kB
build/escape-html/index.min.js 537 B
build/format-library/style-rtl.css 476 B
build/format-library/style.css 476 B
build/hooks/index.min.js 1.65 kB
build/html-entities/index.min.js 445 B
build/i18n/index.min.js 3.58 kB
build/is-shallow-equal/index.min.js 526 B
build/keyboard-shortcuts/index.min.js 1.31 kB
build/keycodes/index.min.js 1.46 kB
build/list-reusable-blocks/index.min.js 2.13 kB
build/list-reusable-blocks/style-rtl.css 852 B
build/list-reusable-blocks/style.css 852 B
build/media-utils/index.min.js 3.2 kB
build/notices/index.min.js 946 B
build/nux/index.min.js 1.62 kB
build/nux/style-rtl.css 749 B
build/nux/style.css 745 B
build/patterns/index.min.js 7.34 kB
build/patterns/style-rtl.css 687 B
build/patterns/style.css 685 B
build/plugins/index.min.js 1.81 kB
build/preferences-persistence/index.min.js 2.06 kB
build/preferences/index.min.js 2.9 kB
build/preferences/style-rtl.css 554 B
build/preferences/style.css 554 B
build/primitives/index.min.js 829 B
build/priority-queue/index.min.js 1.54 kB
build/private-apis/index.min.js 960 B
build/react-i18n/index.min.js 630 B
build/react-refresh-entry/index.min.js 9.47 kB
build/react-refresh-runtime/index.min.js 6.76 kB
build/redux-routine/index.min.js 2.7 kB
build/reusable-blocks/index.min.js 2.55 kB
build/reusable-blocks/style-rtl.css 256 B
build/reusable-blocks/style.css 256 B
build/rich-text/index.min.js 10.1 kB
build/router/index.min.js 1.96 kB
build/server-side-render/index.min.js 1.94 kB
build/shortcode/index.min.js 1.4 kB
build/style-engine/index.min.js 2.04 kB
build/token-list/index.min.js 581 B
build/url/index.min.js 3.9 kB
build/vendors/react-dom.min.js 41.7 kB
build/vendors/react-jsx-runtime.min.js 556 B
build/vendors/react.min.js 4.02 kB
build/viewport/index.min.js 965 B
build/warning/index.min.js 250 B
build/widgets/index.min.js 7.16 kB
build/widgets/style-rtl.css 1.16 kB
build/widgets/style.css 1.16 kB
build/wordcount/index.min.js 1.03 kB

compressed-size-action

@getdave
Copy link
Contributor

getdave commented Oct 11, 2024

Just noting that this was proposed in #51737 (comment) but didn't make it into 6.5. Has the consensus changed?

@youknowriad
Copy link
Contributor Author

Why was it closed in the first place, I was personally not aware of that fix. It seems like a good approach to me.

@getdave
Copy link
Contributor

getdave commented Oct 11, 2024

#51737 (comment)

I can't add much more than what's conveyed in that comment. It boils down to:

...there is an established convention in the editor that pressing Cmd + K within richtext will create a link even if no text is selected.

@draganescu summed it up here

Logically I agree with your proposal but it seems there's always been the expectation around creating links this way.

@youknowriad
Copy link
Contributor Author

It's obviously hard to measure but I think triggering the shortcut and writing a link before actually writing text doesn't feel like something folks would do much.

@richtabor
Copy link
Member

It's obviously hard to measure but I think triggering the shortcut and writing a link before actually writing text doesn't feel like something folks would do much.

I agree.

@stokesman
Copy link
Contributor

I sympathize with this idea as practical but it doesn’t seem like the shortcut should be contextually dependent in the first place (i.e. the same shortcut used for two separate features).

I think triggering the shortcut and writing a link before actually writing text doesn't feel like something folks would do much

Agreed, however as mentioned by Ella #58179 (comment) it’s also consistent with other formats that have shortcuts (like bold). It does seem like for some folks it’s a standby feature. I didn’t see the comment but I remember someone mentioning they commonly insert links where the URL is the displayed text and that feature is most seamless way to do it.

@youknowriad
Copy link
Contributor Author

youknowriad commented Oct 11, 2024

I agree that it's not 100% a perfect solution (at least it's better than trunk for me) but I think this is the closest we have to an agreeable/simple path forward. I feel like we can try this since we're early on the WP lifecycle and adapt to feedback if needed.

@stokesman
Copy link
Contributor

stokesman commented Oct 11, 2024

I feel like we can try this since we're early on the WP lifecycle and adapt to feedback if needed.

This seems reasonable, yet I doubt that all folks this is important to are users of the plugin.

Back to the broader consideration, assuming this is a net win and we keep it, we’re still limited by the same shortcut for both features. Conceivably there are uses for selecting text and commands that operate from that. One idea is a "replace all occurrences" command.

@youknowriad
Copy link
Contributor Author

This seems reasonable, yet I doubt that all folks this is important to are users of the plugin.

The plugin is used in .com so I think if this is ever a problem with regular users, we'll know about it very quickly.

Back to the broader consideration, assuming this is a net win and we keep it, we’re still limited by the same shortcut for both features. Conceivably there are uses for selecting text and commands that operate from that. One idea is a "replace all occurrences" command.

Yeah, for me the long term thing is to have a way to merge the "link" popover as part of the command palette (make it a contextual command or something)

Copy link
Member

@ellatrix ellatrix left a comment

Choose a reason for hiding this comment

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

Let's try it

@youknowriad youknowriad enabled auto-merge (squash) October 15, 2024 13:57
@richtabor
Copy link
Member

This seems reasonable, yet I doubt that all folks this is important to are users of the plugin.
The plugin is used in .com so I think if this is ever a problem with regular users, we'll know about it very quickly.

Agreed. Let's try it early in this cycle and report feedback.

Copy link

Flaky tests detected in 3d93f3d.
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/11348197458
📝 Reported issues:

@stokesman
Copy link
Contributor

The plugin is used in .com so I think if this is ever a problem with regular users, we'll know about it very quickly.

That seems a good point.

Yeah, for me the long term thing is to have a way to merge the "link" popover as part of the command palette (make it a contextual command or something)

I know getting into that is digressing but I can’t envision how it would not be a poorer UX for creating links. I liked the idea way back when I first heard it and would like for it to be workable so I’d be glad to be proven wrong.


Overall, there’s some practicality to this but it seems it will make it easier to remain stuck without a complete fix. It also sacrifices an existing convention and self-consistency.

I think we should continue to feel the pain of the issue in hopes it eventually spurs its complete removal.

@youknowriad
Copy link
Contributor Author

I think we should continue to feel the pain of the issue in hopes it eventually spurs its complete removal.

Can you clarify what you mean here just to make sure I understand properly. Removal of what?

@stokesman
Copy link
Contributor

The removal of the actual issue that two features share a shortcut.

@youknowriad youknowriad disabled auto-merge October 15, 2024 15:09
@youknowriad
Copy link
Contributor Author

So just to be clear, you prefer we do not merge this and instead keep the statusquo? I think for me it's clear at this point that we're not going to change the command bar shortcut (as it's also a common shortcut) and the same can be said for links. So this felt let the best path forward for me to avoid getting stuck.

@stokesman
Copy link
Contributor

stokesman commented Oct 15, 2024

I think for me it's clear at this point that we're not going to change the command bar shortcut (as it's also a common shortcut)

I still think changing the command bar shortcut is the proper fix. cmd + K is common for that but most places I encounter it cmd + / does the same thing. Also, cmd + K for commands actually seems uncommon in content-editing apps (because of link creation). Eventually, shortcuts can be user configured and folks can have it their way.

Merging this feels like a step toward the assumption that we can obviate the link creation interface with the command bar and I would be happy to see that work just as well. Yet I think it has to be evidenced before we move toward that.

Otherwise, we land in a spot where both features still depend on the same shortcut yet advanced commands that operate on text selections are blocked.

I'm not happy with the status quo and don’t intend to block this. I appreciate your consideration.

@youknowriad
Copy link
Contributor Author

I still think changing the command bar shortcut is the proper fix. cmd + K is common for that but most places I encounter it cmd + / does the same thing. Eventually, shortcuts can be user configured and folks can have it their way.

Fair, I think it seems that an agreement/consensus on this is going to be hard to find. I'm going to keep the issue open so we can continue this discussion.

Merging this feels like a step toward the assumption that we can obviate the link creation interface with the command bar and I would be happy to see that work just as well. Yet I think it has to be evidenced before we move toward that.

Yes, It definitely is a path towards that. Obviously that's a bit more involved to implement.

I feel this PR is a bit better than what we have but I'm happy to revert it if there's evidence that it's not.

@stokesman
Copy link
Contributor

Yes, It definitely is a path towards that. Obviously that's a bit more involved to implement.

Right. Though, it wouldn’t take a working implementation to prove. A design POC could do. I think we’ll find it would be workable but unable to match the directness of the current link creation popover.

@youknowriad
Copy link
Contributor Author

@mtias @jasmussen @richtabor Do we have ideas/mockups about how we could merge the "link popover" with the "command palette" UI?

Also, what are your current thoughts on changing the shortcut of the command palette.

@youknowriad
Copy link
Contributor Author

Maybe it's fair to acknowledge here that we don't have enough cycles to explore a full "link merged with command palette" at the moment and that we should make a decision only based on whether this PR is better than trunk or not.

@stokesman
Copy link
Contributor

stokesman commented Oct 17, 2024

should make a decision only based on whether this PR is better than trunk or not

It’s myopic yet doesn’t mean we can’t redirect later so not that’s not to argue it should not be done. I just think effort needs to go toward a full resolution and that is either:

  • proving that replacing the link popover with a command can be done without worsening the UX for link creation
  • changing one of the shortcuts (link creation has seniority so probably not that one)

If the first point can’t be realized, then the second has to be done unless we don’t care about:

  • enabling commands that operate on text selections
  • cognitive/UX funk that two features use the same shortcut
  • the minority that expect link creation to work without a text selection
  • the case that text is selected yet one intends to run a command anyway

@youknowriad
Copy link
Contributor Author

For me it's not about not caring about any of that, it's about tactical moves. Right now, there's no consensus on the shortcut and not enough cycles to explore the full selection of command palette for text selections. So I want to be pragmatic here.

Merge or close the PR, I don't want to keep this open forever.

Copy link
Contributor

@stokesman stokesman left a comment

Choose a reason for hiding this comment

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

Some of the e2e test removals don’t seem right to me.

test/e2e/specs/editor/blocks/links.spec.js Outdated Show resolved Hide resolved
test/e2e/specs/editor/blocks/links.spec.js Show resolved Hide resolved
@stokesman
Copy link
Contributor

For me it's not about not caring about any of that, it's about tactical moves.

For me this is fudging in lieu of fully addressing the issues. I see the pragmatism but also see it as a shame that it’s pragmatic because of either social/network ennui or priorities and not inherent requirements or limitations.

Merge or close the PR, I don't want to keep this open forever.

Your call since you’ve got the approvals and my concerns over e2e tests are addressed. Thanks for that and in general for being so responsive and considerate.

@richtabor
Copy link
Member

Also, what are your current thoughts on changing the shortcut of the command palette.

I'm quite opposed to changing the shortcut of the command palette.

@richtabor
Copy link
Member

richtabor commented Oct 22, 2024

@mtias @jasmussen @richtabor Do we have ideas/mockups about how we could merge the "link popover" with the "command palette" UI?

I was thinking that adding a link would open a modal to engage with, not necessarily use the command palette UI explicitly.

But otherwise, could there be a command for "Add Link" that essentially just triggers the link control wherever the cursor is?

@youknowriad
Copy link
Contributor Author

Ok, let's move forward here. This seems like the "only" programmatic approach for the moment. I'm happy to take a look at follow-ups and reconsider this.

@youknowriad youknowriad merged commit 8d1f222 into trunk Oct 23, 2024
63 checks passed
@youknowriad youknowriad deleted the fix/link-cmd-k branch October 23, 2024 07:20
@github-actions github-actions bot added this to the Gutenberg 19.6 milestone Oct 23, 2024
@stokesman
Copy link
Contributor

could there be a command for "Add Link" that essentially just triggers the link control wherever the cursor is?

Right, so link creation would require another step. It’s not the worst thing, but I don’t see how it’d be justified. Anyway, it’s not something that we’d have to look at until one or more of the following points are important enough to address:

  • enabling commands that operate on text selections
  • cognitive/UX funk that two features use the same shortcut
  • the minority that expect link creation to work without a text selection
  • the case that text is selected yet one intends to run a command anyway

I think they’re important enough already and would have been non-issues by using a separate shortcut yet this probably isn’t place to advance this.

karthick-murugan pushed a commit to karthick-murugan/gutenberg that referenced this pull request Nov 13, 2024
…tion (WordPress#66056)

Co-authored-by: youknowriad <youknowriad@git.wordpress.org>
Co-authored-by: ellatrix <ellatrix@git.wordpress.org>
Co-authored-by: richtabor <richtabor@git.wordpress.org>
Co-authored-by: stokesman <presstoke@git.wordpress.org>
Co-authored-by: getdave <get_dave@git.wordpress.org>
@afercia
Copy link
Contributor

afercia commented Jan 2, 2025

I think triggering the shortcut and writing a link before actually writing text doesn't feel like something folks would do much.

While I understand the need for a temporary pragmaqtic approach, I do think the main point here is that this change removes a long established interaction pattern in WordPress where Cmd+K opens the link UI even when there's no text selection.

the link is only useful if you actually have a text selection

This is an assumption that should be validated with user testing.

I understand all the concerns expressed above but I do think this change is only acceptable as a temporary workaround and should be reverted as soon as a decision about the conflicting keyboard shortcuts is made. This change only cures the symptom and not the real cause.

More importantly:
I'd like to stress the fact that long-established conventions in WordPress should not be changed based only on personal opinions. They should be validated with user testing.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
[Feature] Link Editing Link components (LinkControl, URLInput) and integrations (RichText link formatting) [Package] Commands /packages/commands [Type] Bug An existing feature does not function as intended
Projects
None yet
Development

Successfully merging this pull request may close these issues.

6 participants