mirror of
https://github.com/zadam/trilium.git
synced 2025-12-16 21:29:56 +01:00
feat(layout/formatting_toolbar): render cached components
This commit is contained in:
@@ -1,4 +1,4 @@
|
|||||||
import { useRef } from "preact/hooks";
|
import { useEffect, useRef, useState } from "preact/hooks";
|
||||||
|
|
||||||
import { useActiveNoteContext, useIsNoteReadOnly, useNoteProperty, useTriliumEvent, useTriliumOption } from "../react/hooks";
|
import { useActiveNoteContext, useIsNoteReadOnly, useNoteProperty, useTriliumEvent, useTriliumOption } from "../react/hooks";
|
||||||
import { TabContext } from "./ribbon-interface";
|
import { TabContext } from "./ribbon-interface";
|
||||||
@@ -37,22 +37,52 @@ export default function FormattingToolbar({ hidden, ntxId }: TabContext) {
|
|||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
const toolbarCache = new Map<string, HTMLElement | null | undefined>();
|
||||||
|
|
||||||
export function FixedFormattingToolbar() {
|
export function FixedFormattingToolbar() {
|
||||||
const containerRef = useRef<HTMLDivElement>(null);
|
const containerRef = useRef<HTMLDivElement>(null);
|
||||||
const [ textNoteEditorType ] = useTriliumOption("textNoteEditorType");
|
const [ textNoteEditorType ] = useTriliumOption("textNoteEditorType");
|
||||||
const { note, noteContext } = useActiveNoteContext();
|
const { note, noteContext, ntxId, viewScope } = useActiveNoteContext();
|
||||||
const noteType = useNoteProperty(note, "type");
|
const noteType = useNoteProperty(note, "type");
|
||||||
const { isReadOnly } = useIsNoteReadOnly(note, noteContext);
|
const { isReadOnly } = useIsNoteReadOnly(note, noteContext);
|
||||||
const shown = (
|
const shown = (
|
||||||
|
viewScope?.viewMode === "default" &&
|
||||||
textNoteEditorType === "ckeditor-classic" &&
|
textNoteEditorType === "ckeditor-classic" &&
|
||||||
noteType === "text" &&
|
noteType === "text" &&
|
||||||
!isReadOnly
|
!isReadOnly
|
||||||
);
|
);
|
||||||
|
const [ toolbarToRender, setToolbarToRender ] = useState<HTMLElement | null | undefined>();
|
||||||
|
|
||||||
|
// Populate the cache with the toolbar of every note context.
|
||||||
|
useTriliumEvent("textEditorRefreshed", ({ ntxId: eventNtxId, editor }) => {
|
||||||
|
if (!eventNtxId) return;
|
||||||
|
const toolbar = editor.ui.view.toolbar?.element;
|
||||||
|
toolbarCache.set(eventNtxId, toolbar);
|
||||||
|
// Replace on the spot if the editor crashed.
|
||||||
|
if (eventNtxId === ntxId) {
|
||||||
|
setToolbarToRender(toolbar);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
// Switch between the cached toolbar when user navigates to a different note context.
|
||||||
|
useEffect(() => {
|
||||||
|
if (!ntxId) return;
|
||||||
|
setToolbarToRender(toolbarCache.get(ntxId));
|
||||||
|
}, [ ntxId, noteContext ]);
|
||||||
|
|
||||||
|
// Render the toolbar.
|
||||||
|
useEffect(() => {
|
||||||
|
if (toolbarToRender) {
|
||||||
|
containerRef.current?.replaceChildren(toolbarToRender);
|
||||||
|
} else {
|
||||||
|
containerRef.current?.replaceChildren();
|
||||||
|
}
|
||||||
|
}, [ toolbarToRender ]);
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div
|
<div
|
||||||
ref={containerRef}
|
ref={containerRef}
|
||||||
className={`classic-toolbar-widget ${!shown ? "hidden-ext" : ""}`}
|
className={`classic-toolbar-widget ${!shown ? "hidden-ext" : ""}`}
|
||||||
>Hi</div>
|
/>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user