mirror of
https://github.com/TriliumNext/Notes.git
synced 2025-08-12 20:02:28 +08:00
feat(in-app-help): contextual help button for geo notes
This commit is contained in:
parent
64654290be
commit
868ca2d982
@ -86,6 +86,7 @@ import ClassicEditorToolbar from "../widgets/ribbon_widgets/classic_editor_toolb
|
|||||||
import options from "../services/options.js";
|
import options from "../services/options.js";
|
||||||
import utils from "../services/utils.js";
|
import utils from "../services/utils.js";
|
||||||
import GeoMapButtons from "../widgets/floating_buttons/geo_map_button.js";
|
import GeoMapButtons from "../widgets/floating_buttons/geo_map_button.js";
|
||||||
|
import ContextualHelpButton from "../widgets/floating_buttons/help_button.js";
|
||||||
|
|
||||||
export default class DesktopLayout {
|
export default class DesktopLayout {
|
||||||
constructor(customWidgets) {
|
constructor(customWidgets) {
|
||||||
@ -205,6 +206,7 @@ export default class DesktopLayout {
|
|||||||
.child(new CopyImageReferenceButton())
|
.child(new CopyImageReferenceButton())
|
||||||
.child(new SvgExportButton())
|
.child(new SvgExportButton())
|
||||||
.child(new BacklinksWidget())
|
.child(new BacklinksWidget())
|
||||||
|
.child(new ContextualHelpButton())
|
||||||
.child(new HideFloatingButtonsButton())
|
.child(new HideFloatingButtonsButton())
|
||||||
)
|
)
|
||||||
.child(new MermaidWidget())
|
.child(new MermaidWidget())
|
||||||
|
62
src/public/app/widgets/floating_buttons/help_button.ts
Normal file
62
src/public/app/widgets/floating_buttons/help_button.ts
Normal file
@ -0,0 +1,62 @@
|
|||||||
|
import appContext from "../../components/app_context.js";
|
||||||
|
import type { NoteType } from "../../entities/fnote.js";
|
||||||
|
import { t } from "../../services/i18n.js";
|
||||||
|
import NoteContextAwareWidget from "../note_context_aware_widget.js";
|
||||||
|
|
||||||
|
const TPL = `
|
||||||
|
<button class="open-contextual-help-button" title="${t("help-button.title")}">
|
||||||
|
<span class="bx bx-help-circle"></span>
|
||||||
|
</button>
|
||||||
|
`;
|
||||||
|
|
||||||
|
const byNoteType: Record<NoteType, string | null> = {
|
||||||
|
book: null,
|
||||||
|
canvas: null,
|
||||||
|
code: null,
|
||||||
|
contentWidget: null,
|
||||||
|
doc: null,
|
||||||
|
file: null,
|
||||||
|
geoMap: "foPEtsL51pD2",
|
||||||
|
image: null,
|
||||||
|
launcher: null,
|
||||||
|
mermaid: null,
|
||||||
|
mindMap: null,
|
||||||
|
noteMap: null,
|
||||||
|
relationMap: null,
|
||||||
|
render: null,
|
||||||
|
search: null,
|
||||||
|
text: null,
|
||||||
|
webView: null
|
||||||
|
};
|
||||||
|
|
||||||
|
export default class ContextualHelpButton extends NoteContextAwareWidget {
|
||||||
|
|
||||||
|
private helpNoteIdToOpen?: string | null;
|
||||||
|
|
||||||
|
isEnabled() {
|
||||||
|
this.helpNoteIdToOpen = null;
|
||||||
|
|
||||||
|
if (!super.isEnabled()) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (this.note && byNoteType[this.note.type]) {
|
||||||
|
this.helpNoteIdToOpen = byNoteType[this.note.type];
|
||||||
|
}
|
||||||
|
|
||||||
|
return !!this.helpNoteIdToOpen;
|
||||||
|
}
|
||||||
|
|
||||||
|
doRender() {
|
||||||
|
this.$widget = $(TPL);
|
||||||
|
this.$widget.on("click", () => {
|
||||||
|
const subContexts = appContext.tabManager.getActiveContext().getSubContexts();
|
||||||
|
const { ntxId } = subContexts[subContexts.length - 1];
|
||||||
|
this.triggerCommand("openNewNoteSplit", {
|
||||||
|
ntxId,
|
||||||
|
notePath: `_help_${this.helpNoteIdToOpen}`
|
||||||
|
})
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -1644,5 +1644,8 @@
|
|||||||
"geo-map-context": {
|
"geo-map-context": {
|
||||||
"open-location": "Open location",
|
"open-location": "Open location",
|
||||||
"remove-from-map": "Remove from map"
|
"remove-from-map": "Remove from map"
|
||||||
|
},
|
||||||
|
"help-button": {
|
||||||
|
"title": "Open the relevant help page"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user