From 4116fe0a20ee4f670bfcc9fd2da95fe09d3c0c2b Mon Sep 17 00:00:00 2001 From: zadam Date: Fri, 14 Oct 2022 20:36:40 +0200 Subject: [PATCH] fix propagation of noteTypeMimeChanged event to global scope to fix e.g. edit button switching depending on note type --- src/public/app/services/note_context.js | 2 +- src/public/app/widgets/note_detail.js | 14 +++++++++----- 2 files changed, 10 insertions(+), 6 deletions(-) diff --git a/src/public/app/services/note_context.js b/src/public/app/services/note_context.js index 9b35157ce..9025884ac 100644 --- a/src/public/app/services/note_context.js +++ b/src/public/app/services/note_context.js @@ -184,7 +184,7 @@ class NoteContext extends Component { } // "readOnly" is a state valid only for text/code notes - if (!this.note || this.note.type !== 'text' && this.note.type !== 'code') { + if (!this.note || (this.note.type !== 'text' && this.note.type !== 'code')) { return false; } diff --git a/src/public/app/widgets/note_detail.js b/src/public/app/widgets/note_detail.js index 0bffc6e74..dd122067d 100644 --- a/src/public/app/widgets/note_detail.js +++ b/src/public/app/widgets/note_detail.js @@ -121,7 +121,7 @@ export default class NoteDetailWidget extends NoteContextAwareWidget { async refresh() { this.type = await this.getWidgetType(); - this.mime = this.note ? this.note.mime : null; + this.mime = this.note?.mime; if (!(this.type in this.typeWidgets)) { const clazz = typeWidgetClasses[this.type]; @@ -273,10 +273,14 @@ export default class NoteDetailWidget extends NoteContextAwareWidget { } async entitiesReloadedEvent({loadResults}) { - if (loadResults.isNoteContentReloaded(this.noteId, this.componentId) - || (loadResults.isNoteReloaded(this.noteId, this.componentId) && (this.type !== await this.getWidgetType() || this.mime !== this.note.mime))) { + // we're detecting note type change on the note_detail level, but triggering the noteTypeMimeChanged + // globally, so it gets also to e.g. ribbon components. But this means that the event can be generated multiple + // times if the same note is open in several tabs. - this.handleEvent('noteTypeMimeChanged', {noteId: this.noteId}); + if (loadResults.isNoteReloaded(this.noteId, this.componentId) + && (this.type !== await this.getWidgetType() || this.mime !== this.note.mime)) { + + this.triggerEvent('noteTypeMimeChanged', {noteId: this.noteId}); } else { const attrs = loadResults.getAttributes(); @@ -294,7 +298,7 @@ export default class NoteDetailWidget extends NoteContextAwareWidget { if (label || relation) { // probably incorrect event // calling this.refresh() is not enough since the event needs to be propagated to children as well - this.handleEvent('noteTypeMimeChanged', {noteId: this.noteId}); + this.triggerEvent('noteTypeMimeChanged', {noteId: this.noteId}); } } }