mirror of
				https://github.com/zadam/trilium.git
				synced 2025-10-31 18:36:30 +01:00 
			
		
		
		
	chore(client/ts): port type_widget
This commit is contained in:
		| @@ -24,6 +24,7 @@ import type { Attribute } from "../services/attribute_parser.js"; | |||||||
| import type NoteTreeWidget from "../widgets/note_tree.js"; | import type NoteTreeWidget from "../widgets/note_tree.js"; | ||||||
| import type { default as NoteContext, GetTextEditorCallback } from "./note_context.js"; | import type { default as NoteContext, GetTextEditorCallback } from "./note_context.js"; | ||||||
| import type { ContextMenuEvent } from "../menus/context_menu.js"; | import type { ContextMenuEvent } from "../menus/context_menu.js"; | ||||||
|  | import type TypeWidget from "../widgets/type_widgets/type_widget.js"; | ||||||
|  |  | ||||||
| interface Layout { | interface Layout { | ||||||
|     getRootWidget: (appContext: AppContext) => RootWidget; |     getRootWidget: (appContext: AppContext) => RootWidget; | ||||||
| @@ -161,7 +162,7 @@ export type CommandMappings = { | |||||||
|      * Generally should not be invoked manually, as it is used by {@link NoteContext.getContentElement}. |      * Generally should not be invoked manually, as it is used by {@link NoteContext.getContentElement}. | ||||||
|      */ |      */ | ||||||
|     executeWithContentElement: CommandData & ExecuteCommandData<JQuery<HTMLElement>>; |     executeWithContentElement: CommandData & ExecuteCommandData<JQuery<HTMLElement>>; | ||||||
|     executeWithTypeWidget: CommandData & ExecuteCommandData<null>; |     executeWithTypeWidget: CommandData & ExecuteCommandData<TypeWidget | null>; | ||||||
|     addTextToActiveEditor: CommandData & { |     addTextToActiveEditor: CommandData & { | ||||||
|         text: string; |         text: string; | ||||||
|     }; |     }; | ||||||
| @@ -208,6 +209,7 @@ export type CommandMappings = { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     reEvaluateRightPaneVisibility: CommandData; |     reEvaluateRightPaneVisibility: CommandData; | ||||||
|  |     runActiveNote: CommandData; | ||||||
|  |  | ||||||
|     // Geomap |     // Geomap | ||||||
|     deleteFromMap: { noteId: string }, |     deleteFromMap: { noteId: string }, | ||||||
| @@ -311,6 +313,8 @@ type EventMappings = { | |||||||
|     showToc: { |     showToc: { | ||||||
|         noteId: string; |         noteId: string; | ||||||
|     }; |     }; | ||||||
|  |     scrollToEnd: { ntxId: string }; | ||||||
|  |     noteTypeMimeChanged: { noteId: string }; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| export type EventListener<T extends EventNames> = { | export type EventListener<T extends EventNames> = { | ||||||
|   | |||||||
| @@ -22,11 +22,7 @@ interface CreateNoteOpts { | |||||||
|     focus?: "title" | "content"; |     focus?: "title" | "content"; | ||||||
|     target?: string; |     target?: string; | ||||||
|     targetBranchId?: string; |     targetBranchId?: string; | ||||||
|     textEditor?: { |     textEditor?: TextEditor; | ||||||
|         // TODO: Replace with interface once note_context.js is converted. |  | ||||||
|         getSelectedHtml(): string; |  | ||||||
|         removeSelection(): void; |  | ||||||
|     }; |  | ||||||
| } | } | ||||||
|  |  | ||||||
| interface Response { | interface Response { | ||||||
|   | |||||||
							
								
								
									
										2
									
								
								src/public/app/types.d.ts
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								src/public/app/types.d.ts
									
									
									
									
										vendored
									
									
								
							| @@ -239,6 +239,8 @@ declare global { | |||||||
|         }, |         }, | ||||||
|         getData(): string; |         getData(): string; | ||||||
|         setData(data: string): void; |         setData(data: string): void; | ||||||
|  |         getSelectedHtml(): string; | ||||||
|  |         removeSelection(): void; | ||||||
|         sourceElement: HTMLElement; |         sourceElement: HTMLElement; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -4,7 +4,7 @@ import protectedSessionHolder from "../services/protected_session_holder.js"; | |||||||
| import SpacedUpdate from "../services/spaced_update.js"; | import SpacedUpdate from "../services/spaced_update.js"; | ||||||
| import server from "../services/server.js"; | import server from "../services/server.js"; | ||||||
| import libraryLoader from "../services/library_loader.js"; | import libraryLoader from "../services/library_loader.js"; | ||||||
| import appContext from "../components/app_context.js"; | import appContext, { type CommandListenerData, type EventData } from "../components/app_context.js"; | ||||||
| import keyboardActionsService from "../services/keyboard_actions.js"; | import keyboardActionsService from "../services/keyboard_actions.js"; | ||||||
| import noteCreateService from "../services/note_create.js"; | import noteCreateService from "../services/note_create.js"; | ||||||
| import attributeService from "../services/attributes.js"; | import attributeService from "../services/attributes.js"; | ||||||
| @@ -33,6 +33,8 @@ import MindMapWidget from "./type_widgets/mind_map.js"; | |||||||
| import { getStylesheetUrl, isSyntaxHighlightEnabled } from "../services/syntax_highlight.js"; | import { getStylesheetUrl, isSyntaxHighlightEnabled } from "../services/syntax_highlight.js"; | ||||||
| import GeoMapTypeWidget from "./type_widgets/geo_map.js"; | import GeoMapTypeWidget from "./type_widgets/geo_map.js"; | ||||||
| import utils from "../services/utils.js"; | import utils from "../services/utils.js"; | ||||||
|  | import type { NoteType } from "../entities/fnote.js"; | ||||||
|  | import type TypeWidget from "./type_widgets/type_widget.js"; | ||||||
| 
 | 
 | ||||||
| const TPL = ` | const TPL = ` | ||||||
| <div class="note-detail"> | <div class="note-detail"> | ||||||
| @@ -73,14 +75,34 @@ const typeWidgetClasses = { | |||||||
|     geoMap: GeoMapTypeWidget |     geoMap: GeoMapTypeWidget | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  | /** | ||||||
|  |  * A `NoteType` altered by the note detail widget, taking into consideration whether the note is editable or not and adding special note types such as an empty one, | ||||||
|  |  * for protected session or attachment information. | ||||||
|  |  */ | ||||||
|  | type ExtendedNoteType = Exclude<NoteType, "mermaid" | "launcher" | "text" | "code"> | "empty" | "readOnlyCode" | "readOnlyText" | "editableText" | "editableCode" | "attachmentDetail" | "attachmentList" | "protectedSession"; | ||||||
|  | 
 | ||||||
| export default class NoteDetailWidget extends NoteContextAwareWidget { | export default class NoteDetailWidget extends NoteContextAwareWidget { | ||||||
|  | 
 | ||||||
|  |     private typeWidgets: Record<string, TypeWidget>; | ||||||
|  |     private spacedUpdate: SpacedUpdate; | ||||||
|  |     private type?: ExtendedNoteType; | ||||||
|  |     private mime?: string; | ||||||
|  | 
 | ||||||
|     constructor() { |     constructor() { | ||||||
|         super(); |         super(); | ||||||
| 
 | 
 | ||||||
|         this.typeWidgets = {}; |         this.typeWidgets = {}; | ||||||
| 
 | 
 | ||||||
|         this.spacedUpdate = new SpacedUpdate(async () => { |         this.spacedUpdate = new SpacedUpdate(async () => { | ||||||
|  |             if (!this.noteContext) { | ||||||
|  |                 return; | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|             const { note } = this.noteContext; |             const { note } = this.noteContext; | ||||||
|  |             if (!note) { | ||||||
|  |                 return; | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|             const { noteId } = note; |             const { noteId } = note; | ||||||
| 
 | 
 | ||||||
|             const data = await this.getTypeWidget().getData(); |             const data = await this.getTypeWidget().getData(); | ||||||
| @@ -94,7 +116,7 @@ export default class NoteDetailWidget extends NoteContextAwareWidget { | |||||||
| 
 | 
 | ||||||
|             await server.put(`notes/${noteId}/data`, data, this.componentId); |             await server.put(`notes/${noteId}/data`, data, this.componentId); | ||||||
| 
 | 
 | ||||||
|             this.getTypeWidget().dataSaved?.(); |             this.getTypeWidget().dataSaved(); | ||||||
|         }); |         }); | ||||||
| 
 | 
 | ||||||
|         appContext.addBeforeUnloadListener(this); |         appContext.addBeforeUnloadListener(this); | ||||||
| @@ -129,13 +151,17 @@ export default class NoteDetailWidget extends NoteContextAwareWidget { | |||||||
| 
 | 
 | ||||||
|             this.$widget.append($renderedWidget); |             this.$widget.append($renderedWidget); | ||||||
| 
 | 
 | ||||||
|             await typeWidget.handleEvent("setNoteContext", { noteContext: this.noteContext }); |             if (this.noteContext) { | ||||||
|  |                 await typeWidget.handleEvent("setNoteContext", { noteContext: this.noteContext }); | ||||||
|  |             } | ||||||
| 
 | 
 | ||||||
|             // this is happening in update(), so note has been already set, and we need to reflect this
 |             // this is happening in update(), so note has been already set, and we need to reflect this
 | ||||||
|             await typeWidget.handleEvent("noteSwitched", { |             if (this.noteContext && this.noteContext.notePath) { | ||||||
|                 noteContext: this.noteContext, |                 await typeWidget.handleEvent("noteSwitched", { | ||||||
|                 notePath: this.noteContext.notePath |                     noteContext: this.noteContext, | ||||||
|             }); |                     notePath: this.noteContext.notePath | ||||||
|  |                 }); | ||||||
|  |             } | ||||||
| 
 | 
 | ||||||
|             this.child(typeWidget); |             this.child(typeWidget); | ||||||
|         } |         } | ||||||
| @@ -150,57 +176,60 @@ export default class NoteDetailWidget extends NoteContextAwareWidget { | |||||||
|         // https://github.com/zadam/trilium/issues/2522
 |         // https://github.com/zadam/trilium/issues/2522
 | ||||||
|         const isBackendNote = this.noteContext?.noteId === "_backendLog"; |         const isBackendNote = this.noteContext?.noteId === "_backendLog"; | ||||||
|         const isSqlNote = this.mime === "text/x-sqlite;schema=trilium"; |         const isSqlNote = this.mime === "text/x-sqlite;schema=trilium"; | ||||||
|         const isFullHeightNoteType = ["canvas", "webView", "noteMap", "mindMap", "geoMap"].includes(this.type); |         const isFullHeightNoteType = ["canvas", "webView", "noteMap", "mindMap", "geoMap"].includes(this.type ?? ""); | ||||||
|         const isFullHeight = (!this.noteContext.hasNoteList() && isFullHeightNoteType && !isSqlNote) |         const isFullHeight = (!this.noteContext?.hasNoteList() && isFullHeightNoteType && !isSqlNote) | ||||||
|             || this.noteContext.viewScope.viewMode === "attachments" |             || this.noteContext?.viewScope?.viewMode === "attachments" | ||||||
|             || isBackendNote; |             || isBackendNote; | ||||||
| 
 | 
 | ||||||
|         this.$widget.toggleClass("full-height", isFullHeight); |         this.$widget.toggleClass("full-height", isFullHeight); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     getTypeWidget() { |     getTypeWidget() { | ||||||
|         if (!this.typeWidgets[this.type]) { |         if (!this.type || !this.typeWidgets[this.type]) { | ||||||
|             throw new Error(t(`note_detail.could_not_find_typewidget`, { type: this.type })); |             throw new Error(t(`note_detail.could_not_find_typewidget`, { type: this.type })); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         return this.typeWidgets[this.type]; |         return this.typeWidgets[this.type]; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     async getWidgetType() { |     async getWidgetType(): Promise<ExtendedNoteType> { | ||||||
|         const note = this.note; |         const note = this.note; | ||||||
| 
 | 
 | ||||||
|         if (!note) { |         if (!note) { | ||||||
|             return "empty"; |             return "empty"; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         let type = note.type; |         let type: NoteType = note.type; | ||||||
|         const viewScope = this.noteContext.viewScope; |         let resultingType: ExtendedNoteType; | ||||||
|  |         const viewScope = this.noteContext?.viewScope; | ||||||
| 
 | 
 | ||||||
|         if (viewScope.viewMode === "source") { |         if (viewScope?.viewMode === "source") { | ||||||
|             type = "readOnlyCode"; |             resultingType = "readOnlyCode"; | ||||||
|         } else if (viewScope.viewMode === "attachments") { |         } else if (viewScope && viewScope.viewMode === "attachments") { | ||||||
|             type = viewScope.attachmentId ? "attachmentDetail" : "attachmentList"; |             resultingType = viewScope.attachmentId ? "attachmentDetail" : "attachmentList"; | ||||||
|         } else if (type === "text" && (await this.noteContext.isReadOnly())) { |         } else if (type === "text" && (await this.noteContext?.isReadOnly())) { | ||||||
|             type = "readOnlyText"; |             resultingType = "readOnlyText"; | ||||||
|         } else if ((type === "code" || type === "mermaid") && (await this.noteContext.isReadOnly())) { |         } else if ((type === "code" || type === "mermaid") && (await this.noteContext?.isReadOnly())) { | ||||||
|             type = "readOnlyCode"; |             resultingType = "readOnlyCode"; | ||||||
|         } else if (type === "text") { |         } else if (type === "text") { | ||||||
|             type = "editableText"; |             resultingType = "editableText"; | ||||||
|         } else if (type === "code" || type === "mermaid") { |         } else if (type === "code" || type === "mermaid") { | ||||||
|             type = "editableCode"; |             resultingType = "editableCode"; | ||||||
|         } else if (type === "launcher") { |         } else if (type === "launcher") { | ||||||
|             type = "doc"; |             resultingType = "doc"; | ||||||
|  |         } else { | ||||||
|  |             resultingType = type; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         if (note.isProtected && !protectedSessionHolder.isProtectedSessionAvailable()) { |         if (note.isProtected && !protectedSessionHolder.isProtectedSessionAvailable()) { | ||||||
|             type = "protectedSession"; |             resultingType = "protectedSession"; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         return type; |         return resultingType; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     async focusOnDetailEvent({ ntxId }) { |     async focusOnDetailEvent({ ntxId }: EventData<"focusOnDetail">) { | ||||||
|         if (this.noteContext.ntxId !== ntxId) { |         if (this.noteContext?.ntxId !== ntxId) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
| @@ -210,8 +239,8 @@ export default class NoteDetailWidget extends NoteContextAwareWidget { | |||||||
|         widget.focus(); |         widget.focus(); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     async scrollToEndEvent({ ntxId }) { |     async scrollToEndEvent({ ntxId }: EventData<"scrollToEnd">) { | ||||||
|         if (this.noteContext.ntxId !== ntxId) { |         if (this.noteContext?.ntxId !== ntxId) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
| @@ -224,29 +253,29 @@ export default class NoteDetailWidget extends NoteContextAwareWidget { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     async beforeNoteSwitchEvent({ noteContext }) { |     async beforeNoteSwitchEvent({ noteContext }: EventData<"beforeNoteSwitch">) { | ||||||
|         if (this.isNoteContext(noteContext.ntxId)) { |         if (this.isNoteContext(noteContext.ntxId)) { | ||||||
|             await this.spacedUpdate.updateNowIfNecessary(); |             await this.spacedUpdate.updateNowIfNecessary(); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     async beforeNoteContextRemoveEvent({ ntxIds }) { |     async beforeNoteContextRemoveEvent({ ntxIds }: EventData<"beforeNoteContextRemove">) { | ||||||
|         if (this.isNoteContext(ntxIds)) { |         if (this.isNoteContext(ntxIds)) { | ||||||
|             await this.spacedUpdate.updateNowIfNecessary(); |             await this.spacedUpdate.updateNowIfNecessary(); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     async runActiveNoteCommand(params) { |     async runActiveNoteCommand(params: CommandListenerData<"runActiveNote">) { | ||||||
|         if (this.isNoteContext(params.ntxId)) { |         if (this.isNoteContext(params.ntxId)) { | ||||||
|             // make sure that script is saved before running it #4028
 |             // make sure that script is saved before running it #4028
 | ||||||
|             await this.spacedUpdate.updateNowIfNecessary(); |             await this.spacedUpdate.updateNowIfNecessary(); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         return await this.parent.triggerCommand("runActiveNote", params); |         return await this.parent?.triggerCommand("runActiveNote", params); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     async printActiveNoteEvent() { |     async printActiveNoteEvent() { | ||||||
|         if (!this.noteContext.isActive()) { |         if (!this.noteContext?.isActive()) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
| @@ -254,7 +283,7 @@ export default class NoteDetailWidget extends NoteContextAwareWidget { | |||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     async exportAsPdfEvent() { |     async exportAsPdfEvent() { | ||||||
|         if (!this.noteContext.isActive()) { |         if (!this.noteContext?.isActive() || !this.note) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
| @@ -266,18 +295,18 @@ export default class NoteDetailWidget extends NoteContextAwareWidget { | |||||||
|         }); |         }); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     hoistedNoteChangedEvent({ ntxId }) { |     hoistedNoteChangedEvent({ ntxId }: EventData<"hoistedNoteChanged">) { | ||||||
|         if (this.isNoteContext(ntxId)) { |         if (this.isNoteContext(ntxId)) { | ||||||
|             this.refresh(); |             this.refresh(); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     async entitiesReloadedEvent({ loadResults }) { |     async entitiesReloadedEvent({ loadResults }: EventData<"entitiesReloaded">) { | ||||||
|         // we're detecting note type change on the note_detail level, but triggering the noteTypeMimeChanged
 |         // 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
 |         // 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.
 |         // times if the same note is open in several tabs.
 | ||||||
| 
 | 
 | ||||||
|         if (loadResults.isNoteContentReloaded(this.noteId, this.componentId)) { |         if (this.noteId && loadResults.isNoteContentReloaded(this.noteId, this.componentId)) { | ||||||
|             // probably incorrect event
 |             // probably incorrect event
 | ||||||
|             // calling this.refresh() is not enough since the event needs to be propagated to children as well
 |             // calling this.refresh() is not enough since the event needs to be propagated to children as well
 | ||||||
|             // FIXME: create a separate event to force hierarchical refresh
 |             // FIXME: create a separate event to force hierarchical refresh
 | ||||||
| @@ -285,7 +314,7 @@ export default class NoteDetailWidget extends NoteContextAwareWidget { | |||||||
|             // this uses handleEvent to make sure that the ordinary content updates are propagated only in the subtree
 |             // this uses handleEvent to make sure that the ordinary content updates are propagated only in the subtree
 | ||||||
|             // to avoid the problem in #3365
 |             // to avoid the problem in #3365
 | ||||||
|             this.handleEvent("noteTypeMimeChanged", { noteId: this.noteId }); |             this.handleEvent("noteTypeMimeChanged", { noteId: this.noteId }); | ||||||
|         } else if (loadResults.isNoteReloaded(this.noteId, this.componentId) && (this.type !== (await this.getWidgetType()) || this.mime !== this.note.mime)) { |         } else if (this.noteId && loadResults.isNoteReloaded(this.noteId, this.componentId) && (this.type !== (await this.getWidgetType()) || this.mime !== this.note?.mime)) { | ||||||
|             // this needs to have a triggerEvent so that e.g., note type (not in the component subtree) is updated
 |             // this needs to have a triggerEvent so that e.g., note type (not in the component subtree) is updated
 | ||||||
|             this.triggerEvent("noteTypeMimeChanged", { noteId: this.noteId }); |             this.triggerEvent("noteTypeMimeChanged", { noteId: this.noteId }); | ||||||
|         } else { |         } else { | ||||||
| @@ -293,12 +322,12 @@ export default class NoteDetailWidget extends NoteContextAwareWidget { | |||||||
| 
 | 
 | ||||||
|             const label = attrs.find( |             const label = attrs.find( | ||||||
|                 (attr) => |                 (attr) => | ||||||
|                     attr.type === "label" && ["readOnly", "autoReadOnlyDisabled", "cssClass", "displayRelations", "hideRelations"].includes(attr.name) && attributeService.isAffecting(attr, this.note) |                     attr.type === "label" && ["readOnly", "autoReadOnlyDisabled", "cssClass", "displayRelations", "hideRelations"].includes(attr.name ?? "") && attributeService.isAffecting(attr, this.note) | ||||||
|             ); |             ); | ||||||
| 
 | 
 | ||||||
|             const relation = attrs.find((attr) => attr.type === "relation" && ["template", "inherit", "renderNote"].includes(attr.name) && attributeService.isAffecting(attr, this.note)); |             const relation = attrs.find((attr) => attr.type === "relation" && ["template", "inherit", "renderNote"].includes(attr.name ?? "") && attributeService.isAffecting(attr, this.note)); | ||||||
| 
 | 
 | ||||||
|             if (label || relation) { |             if (this.noteId && (label || relation)) { | ||||||
|                 // probably incorrect event
 |                 // probably incorrect event
 | ||||||
|                 // calling this.refresh() is not enough since the event needs to be propagated to children as well
 |                 // calling this.refresh() is not enough since the event needs to be propagated to children as well
 | ||||||
|                 this.triggerEvent("noteTypeMimeChanged", { noteId: this.noteId }); |                 this.triggerEvent("noteTypeMimeChanged", { noteId: this.noteId }); | ||||||
| @@ -310,13 +339,13 @@ export default class NoteDetailWidget extends NoteContextAwareWidget { | |||||||
|         return this.spacedUpdate.isAllSavedAndTriggerUpdate(); |         return this.spacedUpdate.isAllSavedAndTriggerUpdate(); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     readOnlyTemporarilyDisabledEvent({ noteContext }) { |     readOnlyTemporarilyDisabledEvent({ noteContext }: EventData<"readOnlyTemporarilyDisabled">) { | ||||||
|         if (this.isNoteContext(noteContext.ntxId)) { |         if (this.isNoteContext(noteContext.ntxId)) { | ||||||
|             this.refresh(); |             this.refresh(); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     async executeInActiveNoteDetailWidgetEvent({ callback }) { |     async executeInActiveNoteDetailWidgetEvent({ callback }: EventData<"executeInActiveNoteDetailWidget">) { | ||||||
|         if (!this.isActiveNoteContext()) { |         if (!this.isActiveNoteContext()) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
| @@ -334,11 +363,14 @@ export default class NoteDetailWidget extends NoteContextAwareWidget { | |||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         // without await as this otherwise causes deadlock through component mutex
 |         // without await as this otherwise causes deadlock through component mutex
 | ||||||
|         noteCreateService.createNote(appContext.tabManager.getActiveContextNotePath(), { |         const parentNotePath = appContext.tabManager.getActiveContextNotePath(); | ||||||
|             isProtected: note.isProtected, |         if (this.noteContext && parentNotePath) { | ||||||
|             saveSelection: true, |             noteCreateService.createNote(parentNotePath, { | ||||||
|             textEditor: await this.noteContext.getTextEditor() |                 isProtected: note.isProtected, | ||||||
|         }); |                 saveSelection: true, | ||||||
|  |                 textEditor: await this.noteContext.getTextEditor() | ||||||
|  |             }); | ||||||
|  |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     // used by cutToNote in CKEditor build
 |     // used by cutToNote in CKEditor build
 | ||||||
| @@ -347,12 +379,12 @@ export default class NoteDetailWidget extends NoteContextAwareWidget { | |||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     renderActiveNoteEvent() { |     renderActiveNoteEvent() { | ||||||
|         if (this.noteContext.isActive()) { |         if (this.noteContext?.isActive()) { | ||||||
|             this.refresh(); |             this.refresh(); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     async executeWithTypeWidgetEvent({ resolve, ntxId }) { |     async executeWithTypeWidgetEvent({ resolve, ntxId }: EventData<"executeWithTypeWidget">) { | ||||||
|         if (!this.isNoteContext(ntxId)) { |         if (!this.isNoteContext(ntxId)) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
| @@ -6,7 +6,7 @@ import type SpacedUpdate from "../../services/spaced_update.js"; | |||||||
|  |  | ||||||
| export default abstract class TypeWidget extends NoteContextAwareWidget { | export default abstract class TypeWidget extends NoteContextAwareWidget { | ||||||
|  |  | ||||||
|     protected spacedUpdate!: SpacedUpdate; |     spacedUpdate!: SpacedUpdate; | ||||||
|  |  | ||||||
|     // for overriding |     // for overriding | ||||||
|     static getType() {} |     static getType() {} | ||||||
| @@ -45,6 +45,14 @@ export default abstract class TypeWidget extends NoteContextAwareWidget { | |||||||
|  |  | ||||||
|     focus() {} |     focus() {} | ||||||
|  |  | ||||||
|  |     scrollToEnd() { | ||||||
|  |         // Do nothing by default. | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     dataSaved() { | ||||||
|  |         // Do nothing by default. | ||||||
|  |     } | ||||||
|  |  | ||||||
|     async readOnlyTemporarilyDisabledEvent({ noteContext }: EventData<"readOnlyTemporarilyDisabled">) { |     async readOnlyTemporarilyDisabledEvent({ noteContext }: EventData<"readOnlyTemporarilyDisabled">) { | ||||||
|         if (this.isNoteContext(noteContext.ntxId)) { |         if (this.isNoteContext(noteContext.ntxId)) { | ||||||
|             await this.refresh(); |             await this.refresh(); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user