mirror of
https://github.com/TriliumNext/Notes.git
synced 2025-07-29 19:12:27 +08:00
chore(client/ts): port type_widget
This commit is contained in:
parent
7fa0ad336e
commit
5173e37d8f
@ -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();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user