-
Notifications
You must be signed in to change notification settings - Fork 4.3k
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
RichText: Removing/merging richtext should only trigger if the selection is collapsed #8651
Changes from 2 commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -437,8 +437,10 @@ export class RichText extends Component { | |
const { keyCode } = event; | ||
|
||
if ( | ||
( keyCode === BACKSPACE && isHorizontalEdge( rootNode, true ) ) || | ||
( keyCode === DELETE && isHorizontalEdge( rootNode, false ) ) | ||
window.getSelection().isCollapsed && ( | ||
( keyCode === BACKSPACE && isHorizontalEdge( rootNode, true ) ) || | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. For some reason I would have thought that There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Yes, I noticed it was also checked in the There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Maybe. As it reads, I see no reason why |
||
( keyCode === DELETE && isHorizontalEdge( rootNode, false ) ) | ||
) | ||
) { | ||
if ( ! this.props.onMerge && ! this.props.onRemove ) { | ||
return; | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -12,6 +12,16 @@ exports[`splitting and merging blocks Should merge into inline boundary position | |
<!-- /wp:paragraph -->" | ||
`; | ||
|
||
exports[`splitting and merging blocks Should not merge paragraphs if the selection is not collapsed 1`] = ` | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. As mentioned, it does make these specs read weirdly though. |
||
"<!-- wp:paragraph --> | ||
<p>Foo</p> | ||
<!-- /wp:paragraph --> | ||
|
||
<!-- wp:paragraph --> | ||
<p></p> | ||
<!-- /wp:paragraph -->" | ||
`; | ||
|
||
exports[`splitting and merging blocks Should split and merge paragraph blocks using Enter and Backspace 1`] = ` | ||
"<!-- wp:paragraph --> | ||
<p>First</p> | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -87,4 +87,18 @@ describe( 'splitting and merging blocks', () => { | |
|
||
expect( await getEditedPostContent() ).toMatchSnapshot(); | ||
} ); | ||
|
||
it( 'Should not merge paragraphs if the selection is not collapsed', async () => { | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. We should have a rule but I think in general these should be lowercase. It's inconsistent now in the code though so whatever 😆 There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Starting today (if I remember :P) |
||
await insertBlock( 'Paragraph' ); | ||
await page.keyboard.type( 'Foo' ); | ||
await insertBlock( 'Paragraph' ); | ||
await page.keyboard.type( 'Bar' ); | ||
|
||
await page.keyboard.down( 'Shift' ); | ||
await pressTimes( 'ArrowLeft', 3 ); | ||
await page.keyboard.up( 'Shift' ); | ||
await page.keyboard.press( 'Backspace' ); | ||
|
||
expect( await getEditedPostContent() ).toMatchSnapshot(); | ||
} ); | ||
} ); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Should we continue with setting it at the top as browser dependencies?
const { getSelection } = window;