Skip to content

Commit

Permalink
Blocks: Handle forward backspace
Browse files Browse the repository at this point in the history
  • Loading branch information
youknowriad committed May 16, 2017
1 parent 092fe89 commit 4a89530
Show file tree
Hide file tree
Showing 7 changed files with 86 additions and 14 deletions.
29 changes: 27 additions & 2 deletions blocks/editable/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@ import FormatToolbar from './format-toolbar';
import TinyMCE from './tinymce';

const KEYCODE_BACKSPACE = 8;
const KEYCODE_DELETE = 46;

const alignmentMap = {
alignleft: 'left',
Expand Down Expand Up @@ -177,10 +178,34 @@ export default class Editable extends wp.element.Component {
return true;
}

isEndOfEditor() {
const range = this.editor.selection.getRng();
if ( range.endOffset !== range.endContainer.textContent.length || ! range.collapsed ) {
return false;
}
const start = range.endContainer;
const body = this.editor.getBody();
let element = start;
while ( element !== body ) {
const child = element;
element = element.parentNode;
if ( element.lastChild !== child ) {
return false;
}
}
return true;
}

onKeyDown( event ) {
if ( this.props.onMerge && event.keyCode === KEYCODE_BACKSPACE && this.isStartOfEditor() ) {
if (
this.props.onMerge && (
( event.keyCode === KEYCODE_BACKSPACE && this.isStartOfEditor() ) ||
( event.keyCode === KEYCODE_DELETE && this.isEndOfEditor() )
)
) {
const forward = event.keyCode === KEYCODE_DELETE;
this.onChange();
this.props.onMerge( this.editor.getContent() );
this.props.onMerge( forward );
event.preventDefault();
event.stopImmediatePropagation();
}
Expand Down
4 changes: 2 additions & 2 deletions blocks/library/heading/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -79,7 +79,7 @@ registerBlock( 'core/heading', {
};
},

edit( { attributes, setAttributes, focus, setFocus, mergeWithPrevious } ) {
edit( { attributes, setAttributes, focus, setFocus, mergeBlocks } ) {
const { content, nodeName = 'H2' } = attributes;

return (
Expand All @@ -89,7 +89,7 @@ registerBlock( 'core/heading', {
focus={ focus }
onFocus={ setFocus }
onChange={ ( value ) => setAttributes( { content: value } ) }
onMerge={ mergeWithPrevious }
onMerge={ mergeBlocks }
inline
/>
);
Expand Down
4 changes: 2 additions & 2 deletions blocks/library/quote/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -110,7 +110,7 @@ registerBlock( 'core/quote', {
],
},

edit( { attributes, setAttributes, focus, setFocus, mergeWithPrevious } ) {
edit( { attributes, setAttributes, focus, setFocus, mergeBlocks } ) {
const { value, citation, style = 1 } = attributes;
const focusedEditable = focus ? focus.editable || 'value' : null;

Expand All @@ -125,7 +125,7 @@ registerBlock( 'core/quote', {
}
focus={ focusedEditable === 'value' ? focus : null }
onFocus={ () => setFocus( { editable: 'value' } ) }
onMerge={ mergeWithPrevious }
onMerge={ mergeBlocks }
showAlignments
/>
{ ( ( citation && citation.length > 0 ) || !! focus ) && (
Expand Down
4 changes: 2 additions & 2 deletions blocks/library/text/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@ registerBlock( 'core/text', {
};
},

edit( { attributes, setAttributes, insertBlockAfter, focus, setFocus, mergeWithPrevious } ) {
edit( { attributes, setAttributes, insertBlockAfter, focus, setFocus, mergeBlocks } ) {
const { content } = attributes;

return (
Expand All @@ -46,7 +46,7 @@ registerBlock( 'core/text', {
content: after,
} ) );
} }
onMerge={ mergeWithPrevious }
onMerge={ mergeBlocks }
showAlignments
/>
);
Expand Down
21 changes: 15 additions & 6 deletions editor/modes/visual-editor/block.js
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@ import BlockSwitcher from '../../block-switcher';
import { focusBlock, mergeBlocks } from '../../actions';
import {
getPreviousBlock,
getNextBlock,
getBlock,
getBlockFocus,
getBlockOrder,
Expand All @@ -36,7 +37,7 @@ class VisualEditorBlock extends wp.element.Component {
this.maybeHover = this.maybeHover.bind( this );
this.maybeStartTyping = this.maybeStartTyping.bind( this );
this.removeOnBackspace = this.removeOnBackspace.bind( this );
this.mergeWithPrevious = this.mergeWithPrevious.bind( this );
this.mergeBlocks = this.mergeBlocks.bind( this );
this.previousOffset = null;
}

Expand Down Expand Up @@ -101,15 +102,22 @@ class VisualEditorBlock extends wp.element.Component {
}
}

mergeWithPrevious() {
const { block, previousBlock, onMerge } = this.props;
mergeBlocks( forward = false ) {
const { block, previousBlock, nextBlock, onMerge } = this.props;

// Do nothing when it's the first block
if ( ! previousBlock ) {
if (
( ! forward && ! previousBlock ) ||
( forward && ! nextBlock )
) {
return;
}

onMerge( previousBlock, block );
if ( forward ) {
onMerge( block, nextBlock );
} else {
onMerge( previousBlock, block );
}
}

componentDidUpdate( prevProps ) {
Expand Down Expand Up @@ -200,7 +208,7 @@ class VisualEditorBlock extends wp.element.Component {
setAttributes={ this.setAttributes }
insertBlockAfter={ onInsertAfter }
setFocus={ partial( onFocus, block.uid ) }
mergeWithPrevious={ this.mergeWithPrevious }
mergeBlocks={ this.mergeBlocks }
/>
</div>
{ isSelected &&
Expand All @@ -223,6 +231,7 @@ export default connect(
( state, ownProps ) => {
return {
previousBlock: getPreviousBlock( state, ownProps.uid ),
nextBlock: getNextBlock( state, ownProps.uid ),
block: getBlock( state, ownProps.uid ),
isSelected: isBlockSelected( state, ownProps.uid ),
isHovered: isBlockHovered( state, ownProps.uid ),
Expand Down
5 changes: 5 additions & 0 deletions editor/selectors.js
Original file line number Diff line number Diff line change
Expand Up @@ -82,6 +82,11 @@ export function getPreviousBlock( state, uid ) {
return state.editor.blocksByUid[ state.editor.blockOrder[ order - 1 ] ] || null;
}

export function getNextBlock( state, uid ) {
const order = getBlockOrder( state, uid );
return state.editor.blocksByUid[ state.editor.blockOrder[ order + 1 ] ] || null;
}

export function isBlockSelected( state, uid ) {
return state.selectedBlock.uid === uid;
}
Expand Down
33 changes: 33 additions & 0 deletions editor/test/selectors.js
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@ import {
isFirstBlock,
isLastBlock,
getPreviousBlock,
getNextBlock,
isBlockSelected,
isBlockHovered,
getBlockFocus,
Expand Down Expand Up @@ -343,6 +344,38 @@ describe( 'selectors', () => {
} );
} );

describe( 'getNextBlock', () => {
it( 'should return the following block', () => {
const state = {
editor: {
blocksByUid: {
23: { uid: 23, blockType: 'core/heading' },
123: { uid: 123, blockType: 'core/text' },
},
blockOrder: [ 123, 23 ],
},
};

expect( getNextBlock( state, 123 ) ).to.eql(
{ uid: 23, blockType: 'core/heading' },
);
} );

it( 'should return null for the last block', () => {
const state = {
editor: {
blocksByUid: {
23: { uid: 23, blockType: 'core/heading' },
123: { uid: 123, blockType: 'core/text' },
},
blockOrder: [ 123, 23 ],
},
};

expect( getNextBlock( state, 23 ) ).to.be.null();
} );
} );

describe( 'isBlockSelected', () => {
it( 'should return true if the block is selected', () => {
const state = {
Expand Down

0 comments on commit 4a89530

Please sign in to comment.