diff --git a/app/components/SimpleEditor/ContainerEditor.js b/app/components/SimpleEditor/ContainerEditor.js index db78b1facfb12012bbc3c8ca34fea453adb32dba..2a65916a751066e8d220b368e6599cdc67af876c 100644 --- a/app/components/SimpleEditor/ContainerEditor.js +++ b/app/components/SimpleEditor/ContainerEditor.js @@ -50,7 +50,7 @@ class ContainerEditor extends SubstanceContainerEditor { this.props.history.listenBefore((location, callback) => { const commandStates = this.getCommandStates() - if (commandStates['save'].disabled === false) { + if (this.editorSession.hasUnsavedChanges()) { const editor = this.getEditor() editor.send('changesNotSaved') @@ -63,18 +63,20 @@ class ContainerEditor extends SubstanceContainerEditor { }) } - window.history.pushState(null, null, document.URL) + // window.history.pushState(null, null, document.URL) window.addEventListener('popstate', this.controlBackButton) } // TODO -- review // messes up browser history controlBackButton () { const commandStates = this.getCommandStates() + if (!commandStates['save']) return + const url = '/books/' + this.props.book.id + '/book-builder' window.removeEventListener('popstate', this.controlBackButton) - if (commandStates['save'].disabled === false) { + if (this.editorSession.hasUnsavedChanges()) { const editor = this.getEditor() window.history.pushState(null, null, document.URL) @@ -82,7 +84,7 @@ class ContainerEditor extends SubstanceContainerEditor { editor.send('changesNotSaved') editor.emit('send:route', {location: url, back: true}) } else { - this.props.history.goBack() + this.props.history.push(url) } } onTextInput (event) { diff --git a/app/components/SimpleEditor/elements/modal_warning/ModalWarning.js b/app/components/SimpleEditor/elements/modal_warning/ModalWarning.js index c92e365e8c5eecf052c35c26736b4c977dc3916d..56198ebed13274dcfab61b8999142d5e74ea4101 100644 --- a/app/components/SimpleEditor/elements/modal_warning/ModalWarning.js +++ b/app/components/SimpleEditor/elements/modal_warning/ModalWarning.js @@ -70,7 +70,7 @@ class ModalWarning extends Modal { _saveExitWriter () { this.context.editor.editorSession.save() if (this.backButton) { - setTimeout(() => { this.context.editor.props.history.go(-2) }, 200) + setTimeout(() => { this.context.editor.props.history.go(-1) }, 200) } else { setTimeout(() => { this.context.editor.props.history.push(this.route) }, 200) } @@ -86,7 +86,7 @@ class ModalWarning extends Modal { this.context.editor.editorSession.save() if (this.backButton) { - setTimeout(() => { this.context.editor.props.history.go(-2) }, 200) + setTimeout(() => { this.context.editor.props.history.go(-1) }, 200) } else { // TODO: Hack Check why cannot rerender editor so can push to url setTimeout(() => { this.context.editor.props.history.push(this.route) }, 200) diff --git a/app/components/SimpleEditor/miniEditor/miniEditor.js b/app/components/SimpleEditor/miniEditor/miniEditor.js index 025b1e93e79aa19c52a8ea6b4a5c8dbe97c06582..aefce9d7c70dab1e37c651cdd9d922626c5cc11c 100644 --- a/app/components/SimpleEditor/miniEditor/miniEditor.js +++ b/app/components/SimpleEditor/miniEditor/miniEditor.js @@ -64,10 +64,12 @@ class MiniEditor extends ProseEditor { _renderEditor ($$) { return $$(ContainerEditor, { + book: this.props.book, comments: this.props.comments, containerId: this.props.containerId, editorSession: this.editorSession, disabled: this.props.disabled, + history: this.props.history, fragment: this.props.fragment, spellcheck: 'native', trackChanges: this.props.trackChanges, diff --git a/app/components/SimpleEditor/panes/Notes/Notes.js b/app/components/SimpleEditor/panes/Notes/Notes.js index a044440df3f7f1aa81df9564783021823dc17056..14bdcaf5f918faa0c1dd7b87e09872697724a93c 100644 --- a/app/components/SimpleEditor/panes/Notes/Notes.js +++ b/app/components/SimpleEditor/panes/Notes/Notes.js @@ -44,22 +44,19 @@ class Notes extends Component { const el = $$('div') .addClass('notes-container').append(resizer) - const comments = this.getComments() - const fragment = this.getFragment() - const user = this.getUser() - const update = this.getUpdate() - const trackChanges = this.trackChanges() - const disabled = this.isInReadOnlyMode() + const miniEditorProps = this.getParentProps() el.append($$(MiniEditor, { - comments: comments, - containerId: 'mini', - disabled: disabled, + book: miniEditorProps.book, editorSession: miniEditorSession, - fragment: fragment, - trackChanges: trackChanges, - update: update, - user: user + comments: miniEditorProps.comments, + containerId: 'mini', + history: miniEditorProps.history, + disabled: miniEditorProps.disabled, + fragment: miniEditorProps.fragment, + trackChanges: miniEditorProps.trackChanges, + update: miniEditorProps.update, + user: miniEditorProps.user })) resizer.addEventListener('mousedown', this.initResize, false) @@ -118,29 +115,17 @@ class Notes extends Component { getProvider () { return this.context.notesProvider } - - getComments () { - return this.context.commentsProvider.config.comments - } - - getUser () { - return this.context.editor.props.user - } - - isInReadOnlyMode () { - return this.context.editor.props.disabled - } - - getFragment () { - return this.context.editor.props.fragment - } - - getUpdate () { - return this.context.editor.props.update - } - - trackChanges () { - return this.context.editor.props.trackChanges + getParentProps () { + return { + comments: this.context.commentsProvider.config.comments, + disabled: this.context.editor.props.disabled, + book: this.context.editor.props.book, + fragment: this.context.editor.props.fragment, + history: this.context.editor.props.history, + trackChanges: this.context.editor.props.trackChanges, + update: this.context.editor.props.update, + user: this.context.editor.props.user + } } onNotesUpdated (change) {