Skip to content

Commit

Permalink
Add undo level after input timeout
Browse files Browse the repository at this point in the history
  • Loading branch information
ellatrix committed Nov 15, 2018
1 parent 30205fc commit e6e9151
Show file tree
Hide file tree
Showing 3 changed files with 21 additions and 51 deletions.
30 changes: 13 additions & 17 deletions packages/editor/src/components/rich-text/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ import {
getScrollContainer,
} from '@wordpress/dom';
import { createBlobURL } from '@wordpress/blob';
import { BACKSPACE, DELETE, ENTER, LEFT, RIGHT, UP, DOWN } from '@wordpress/keycodes';
import { BACKSPACE, DELETE, ENTER } from '@wordpress/keycodes';
import { withDispatch, withSelect } from '@wordpress/data';
import { pasteHandler, children, getBlockTransforms, findTransform } from '@wordpress/blocks';
import { withInstanceId, withSafeTimeout, compose } from '@wordpress/compose';
Expand Down Expand Up @@ -130,6 +130,14 @@ export class RichText extends Component {
this.lastHistoryValue = value;
}

componentDidMount() {
document.addEventListener( 'selectionchange', this.onSelectionChange );
}

componentWillUnmount() {
document.removeEventListener( 'selectionchange', this.onSelectionChange );
}

setRef( node ) {
this.editableRef = node;
}
Expand Down Expand Up @@ -371,6 +379,10 @@ export class RichText extends Component {
this.onChange( transformed, {
withoutHistory: true,
} );

// Create an undo level when input stops for over a second.
this.props.clearTimeout( this.onInput.timeout );
this.onInput.timeout = this.props.setTimeout( this.onCreateUndoLevel, 1000 );
}

onCompositionEnd() {
Expand Down Expand Up @@ -580,10 +592,6 @@ export class RichText extends Component {
this.splitContent();
}
}

if ( [ LEFT, RIGHT, UP, DOWN ].indexOf( keyCode ) >= 0 ) {
this.onCreateUndoLevel();
}
}

/**
Expand Down Expand Up @@ -763,18 +771,6 @@ export class RichText extends Component {
const record = this.formatToValue( value );
this.applyRecord( record );
}

if ( isSelected && ! prevProps.isSelected ) {
document.addEventListener( 'selectionchange', this.onSelectionChange );
window.addEventListener( 'mousedown', this.onCreateUndoLevel );
window.addEventListener( 'touchstart', this.onCreateUndoLevel );
}

if ( ! isSelected && prevProps.isSelected ) {
document.removeEventListener( 'selectionchange', this.onSelectionChange );
window.removeEventListener( 'mousedown', this.onCreateUndoLevel );
window.removeEventListener( 'touchstart', this.onCreateUndoLevel );
}
}

formatToValue( value ) {
Expand Down
20 changes: 4 additions & 16 deletions test/e2e/specs/__snapshots__/undo.test.js.snap
Original file line number Diff line number Diff line change
Expand Up @@ -14,27 +14,15 @@ exports[`undo Should undo to expected level intervals 1`] = `
<!-- /wp:paragraph -->"
`;

exports[`undo should undo typing after arrow navigation 1`] = `
exports[`undo should undo typing after a pause 1`] = `
"<!-- wp:paragraph -->
<p>before keyboard after keyboard</p>
<p>before pause after pause</p>
<!-- /wp:paragraph -->"
`;

exports[`undo should undo typing after arrow navigation 2`] = `
exports[`undo should undo typing after a pause 2`] = `
"<!-- wp:paragraph -->
<p>before keyboard</p>
<!-- /wp:paragraph -->"
`;

exports[`undo should undo typing after mouse move 1`] = `
"<!-- wp:paragraph -->
<p>before move after move</p>
<!-- /wp:paragraph -->"
`;

exports[`undo should undo typing after mouse move 2`] = `
"<!-- wp:paragraph -->
<p>before move</p>
<p>before pause</p>
<!-- /wp:paragraph -->"
`;

Expand Down
22 changes: 4 additions & 18 deletions test/e2e/specs/undo.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -14,12 +14,12 @@ describe( 'undo', () => {
await newPost();
} );

it( 'should undo typing after mouse move', async () => {
it( 'should undo typing after a pause', async () => {
await clickBlockAppender();

await page.keyboard.type( 'before move' );
await page.mouse.down();
await page.keyboard.type( ' after move' );
await page.keyboard.type( 'before pause' );
await new Promise( ( resolve ) => setTimeout( resolve, 1000 ) );
await page.keyboard.type( ' after pause' );

expect( await getEditedPostContent() ).toMatchSnapshot();

Expand All @@ -42,20 +42,6 @@ describe( 'undo', () => {
expect( await getEditedPostContent() ).toMatchSnapshot();
} );

it( 'should undo typing after arrow navigation', async () => {
await clickBlockAppender();

await page.keyboard.type( 'before keyboard' );
await page.keyboard.press( 'ArrowRight' );
await page.keyboard.type( ' after keyboard' );

expect( await getEditedPostContent() ).toMatchSnapshot();

await pressWithModifier( META_KEY, 'z' );

expect( await getEditedPostContent() ).toMatchSnapshot();
} );

it( 'Should undo to expected level intervals', async () => {
await clickBlockAppender();

Expand Down

0 comments on commit e6e9151

Please sign in to comment.