Skip to content

Commit

Permalink
Editor: Fix move to trash redirect save race conditions. (#18275)
Browse files Browse the repository at this point in the history
* Editor: Fix move to trash redirect save race conditions.

* Editor: Add e2e test.

* Editor: Expand comment.

* Fix BrowserURL capitalization

* Revert "Editor: Add e2e test."

This reverts commit 4d58c79.
  • Loading branch information
epiqueras authored and jorgefilipecosta committed Nov 5, 2019
1 parent 43d2866 commit ee7f679
Show file tree
Hide file tree
Showing 2 changed files with 13 additions and 6 deletions.
9 changes: 6 additions & 3 deletions packages/edit-post/src/components/browser-url/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -42,10 +42,12 @@ export class BrowserURL extends Component {
}

componentDidUpdate( prevProps ) {
const { postId, postStatus, postType } = this.props;
const { postId, postStatus, postType, isSavingPost } = this.props;
const { historyId } = this.state;

if ( postStatus === 'trash' ) {
// Posts are still dirty while saving so wait for saving to finish
// to avoid the unsaved changes warning when trashing posts.
if ( postStatus === 'trash' && ! isSavingPost ) {
this.setTrashURL( postId, postType );
return;
}
Expand Down Expand Up @@ -92,12 +94,13 @@ export class BrowserURL extends Component {
}

export default withSelect( ( select ) => {
const { getCurrentPost } = select( 'core/editor' );
const { getCurrentPost, isSavingPost } = select( 'core/editor' );
const { id, status, type } = getCurrentPost();

return {
postId: id,
postStatus: status,
postType: type,
isSavingPost: isSavingPost(),
};
} )( BrowserURL );
10 changes: 7 additions & 3 deletions packages/editor/src/components/unsaved-changes-warning/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -27,9 +27,9 @@ class UnsavedChangesWarning extends Component {
* @return {?string} Warning prompt message, if unsaved changes exist.
*/
warnIfUnsavedChanges( event ) {
const { isDirty } = this.props;
const { isEditedPostDirty } = this.props;

if ( isDirty ) {
if ( isEditedPostDirty() ) {
event.returnValue = __( 'You have unsaved changes. If you proceed, they will be lost.' );
return event.returnValue;
}
Expand All @@ -41,5 +41,9 @@ class UnsavedChangesWarning extends Component {
}

export default withSelect( ( select ) => ( {
isDirty: select( 'core/editor' ).isEditedPostDirty(),
// We need to call the selector directly in the listener to avoid race
// conditions with `BrowserURL` where `componentDidUpdate` gets the
// new value of `isEditedPostDirty` before this component does,
// causing this component to incorrectly think a trashed post is still dirty.
isEditedPostDirty: select( 'core/editor' ).isEditedPostDirty,
} ) )( UnsavedChangesWarning );

0 comments on commit ee7f679

Please sign in to comment.