Skip to content

Commit

Permalink
Try moving logic to block level
Browse files Browse the repository at this point in the history
  • Loading branch information
ellatrix committed Jun 14, 2017
1 parent d17cc7b commit 69d3fe3
Show file tree
Hide file tree
Showing 2 changed files with 66 additions and 36 deletions.
37 changes: 3 additions & 34 deletions blocks/editable/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ import 'element-closest';
/**
* WordPress dependencies
*/
import { BACKSPACE, DELETE, UP, DOWN, LEFT, RIGHT } from 'utils/keycodes';
import { BACKSPACE, DELETE } from 'utils/keycodes';

/**
* Internal dependencies
Expand Down Expand Up @@ -194,41 +194,10 @@ export default class Editable extends wp.element.Component {
}

onKeyDown( event ) {
const { keyCode } = event;
const moveUp = ( keyCode === UP || keyCode === LEFT ) && this.isStartOfEditor();
const moveDown = ( keyCode === DOWN || keyCode === RIGHT ) && this.isEndOfEditor();
const selectors = [
'*[contenteditable="true"]',
'*[tabindex]',
'textarea',
'input',
].join( ',' );

if ( moveUp || moveDown ) {
const rootNode = this.editor.getBody();
const focusableNodes = Array.from( document.querySelectorAll( selectors ) );

if ( moveUp ) {
focusableNodes.reverse();
}

const targetNode = focusableNodes
.slice( focusableNodes.indexOf( rootNode ) )
.reduce( ( result, node ) => {
return result || ( node.contains( rootNode ) ? null : node );
}, null );

if ( targetNode ) {
targetNode.focus();
event.preventDefault();
event.stopImmediatePropagation();
}
}

if (
this.props.onMerge && (
( keyCode === BACKSPACE && this.isStartOfEditor() ) ||
( keyCode === DELETE && this.isEndOfEditor() )
( event.keyCode === BACKSPACE && this.isStartOfEditor() ) ||
( event.keyCode === DELETE && this.isEndOfEditor() )
)
) {
const forward = event.keyCode === DELETE;
Expand Down
65 changes: 63 additions & 2 deletions editor/modes/visual-editor/block.js
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ import CSSTransitionGroup from 'react-transition-group/CSSTransitionGroup';
*/
import { Children } from 'element';
import { Toolbar } from 'components';
import { BACKSPACE, ESCAPE } from 'utils/keycodes';
import { BACKSPACE, ESCAPE, UP, DOWN, LEFT, RIGHT } from 'utils/keycodes';

/**
* Internal dependencies
Expand Down Expand Up @@ -54,6 +54,9 @@ class VisualEditorBlock extends wp.element.Component {
this.mergeBlocks = this.mergeBlocks.bind( this );
this.onFocus = this.onFocus.bind( this );
this.onPointerDown = this.onPointerDown.bind( this );
this.onKeyDown = this.onKeyDown.bind( this );
this.onKeyUp = this.onKeyUp.bind( this );
this.handleArrowKey = this.handleArrowKey.bind( this );
this.previousOffset = null;
}

Expand Down Expand Up @@ -184,6 +187,63 @@ class VisualEditorBlock extends wp.element.Component {
this.props.onSelectionStart();
}

onKeyDown( event ) {
const { keyCode } = event;

this.handleArrowKey( event );

if ( keyCode === UP || keyCode === LEFT || keyCode === DOWN || keyCode === RIGHT ) {
const selection = window.getSelection();
this.lastRange = selection.rangeCount ? selection.getRangeAt( 0 ) : null;
}
}

onKeyUp( event ) {
this.removeOrDeselect( event );
this.handleArrowKey( event );
}

handleArrowKey( event ) {
const { keyCode, target } = event;
const moveUp = ( keyCode === UP || keyCode === LEFT );
const moveDown = ( keyCode === DOWN || keyCode === RIGHT );
const selectors = [
'*[contenteditable="true"]',
'*[tabindex]',
'textarea',
'input',
].join( ',' );

if ( moveUp || moveDown ) {
const selection = window.getSelection();
const range = selection.rangeCount ? selection.getRangeAt( 0 ) : null;

// If there's no movement, so we're either at the end of start, or
// no text input at all.
if ( range !== this.lastRange ) {
return;
}

const focusableNodes = Array.from( document.querySelectorAll( selectors ) );

if ( moveUp ) {
focusableNodes.reverse();
}

const targetNode = focusableNodes
.slice( focusableNodes.indexOf( target ) )
.reduce( ( result, node ) => {
return result || ( node.contains( target ) ? null : node );
}, null );

if ( targetNode ) {
targetNode.focus();
}
}

delete this.lastRange;
}

render() {
const { block, multiSelectedBlockUids } = this.props;
const blockType = wp.blocks.getBlockType( block.name );
Expand Down Expand Up @@ -225,7 +285,8 @@ class VisualEditorBlock extends wp.element.Component {
return (
<div
ref={ this.bindBlockNode }
onKeyDown={ this.removeOrDeselect }
onKeyDown={ this.onKeyDown }
onKeyUp={ this.onKeyUp }
onFocus={ this.onFocus }
onMouseDown={ this.onPointerDown }
onTouchStart={ this.onPointerDown }
Expand Down

0 comments on commit 69d3fe3

Please sign in to comment.