mirror of
https://github.com/zadam/trilium.git
synced 2025-10-20 15:19:01 +02:00
102 lines
3.8 KiB
TypeScript
102 lines
3.8 KiB
TypeScript
import NoteContextAwareWidget from "../note_context_aware_widget.js";
|
|
import NoteTypeWidget from "../note_type.js";
|
|
import ProtectedNoteSwitchWidget from "../protected_note_switch.js";
|
|
import EditabilitySelectWidget from "../editability_select.js";
|
|
import BookmarkSwitchWidget from "../bookmark_switch.js";
|
|
import SharedSwitchWidget from "../shared_switch.js";
|
|
import { t } from "../../services/i18n.js";
|
|
import TemplateSwitchWidget from "../template_switch.js";
|
|
import type FNote from "../../entities/fnote.js";
|
|
import NoteLanguageWidget from "../note_language.js";
|
|
|
|
const TPL = /*html*/`
|
|
<div class="note-type-container">
|
|
<span>${t("basic_properties.note_type")}:</span>
|
|
</div>
|
|
|
|
<div class="protected-note-switch-container"></div>
|
|
|
|
<div class="editability-select-container">
|
|
<span>${t("basic_properties.editable")}:</span>
|
|
</div>
|
|
|
|
<div class="bookmark-switch-container"></div>
|
|
|
|
<div class="shared-switch-container"></div>
|
|
|
|
<div class="template-switch-container"></div>
|
|
|
|
<div class="note-language-container">
|
|
<span>${t("basic_properties.language")}:</span>
|
|
</div>
|
|
`;
|
|
|
|
export default class BasicPropertiesWidget extends NoteContextAwareWidget {
|
|
|
|
private noteTypeWidget: NoteTypeWidget;
|
|
private protectedNoteSwitchWidget: ProtectedNoteSwitchWidget;
|
|
private editabilitySelectWidget: EditabilitySelectWidget;
|
|
private bookmarkSwitchWidget: BookmarkSwitchWidget;
|
|
private sharedSwitchWidget: SharedSwitchWidget;
|
|
private templateSwitchWidget: TemplateSwitchWidget;
|
|
private noteLanguageWidget: NoteLanguageWidget;
|
|
|
|
constructor() {
|
|
super();
|
|
|
|
this.noteTypeWidget = new NoteTypeWidget().contentSized();
|
|
this.protectedNoteSwitchWidget = new ProtectedNoteSwitchWidget().contentSized();
|
|
this.editabilitySelectWidget = new EditabilitySelectWidget().contentSized();
|
|
this.bookmarkSwitchWidget = new BookmarkSwitchWidget().contentSized();
|
|
this.sharedSwitchWidget = new SharedSwitchWidget().contentSized();
|
|
this.templateSwitchWidget = new TemplateSwitchWidget().contentSized();
|
|
this.noteLanguageWidget = new NoteLanguageWidget().contentSized();
|
|
|
|
this.child(
|
|
this.noteTypeWidget,
|
|
this.protectedNoteSwitchWidget,
|
|
this.editabilitySelectWidget,
|
|
this.bookmarkSwitchWidget,
|
|
this.sharedSwitchWidget,
|
|
this.templateSwitchWidget,
|
|
this.noteLanguageWidget);
|
|
}
|
|
|
|
get name() {
|
|
return "basicProperties";
|
|
}
|
|
|
|
get toggleCommand() {
|
|
return "toggleRibbonBasicProperties";
|
|
}
|
|
|
|
getTitle() {
|
|
return {
|
|
show: !this.note?.isLaunchBarConfig(),
|
|
};
|
|
}
|
|
|
|
doRender() {
|
|
this.$widget = $(TPL);
|
|
this.contentSized();
|
|
|
|
this.$widget.find(".note-type-container").append(this.noteTypeWidget.render());
|
|
this.$widget.find(".protected-note-switch-container").append(this.protectedNoteSwitchWidget.render());
|
|
this.$widget.find(".editability-select-container").append(this.editabilitySelectWidget.render());
|
|
this.$widget.find(".bookmark-switch-container").append(this.bookmarkSwitchWidget.render());
|
|
this.$widget.find(".shared-switch-container").append(this.sharedSwitchWidget.render());
|
|
this.$widget.find(".template-switch-container").append(this.templateSwitchWidget.render());
|
|
this.$widget.find(".note-language-container").append(this.noteLanguageWidget.render());
|
|
}
|
|
|
|
async refreshWithNote(note: FNote) {
|
|
await super.refreshWithNote(note);
|
|
if (!this.note) {
|
|
return;
|
|
}
|
|
|
|
this.$widget.find(".editability-select-container").toggle(this.note && ["text", "code", "mermaid"].includes(this.note.type));
|
|
this.$widget.find(".note-language-container").toggle(this.note && ["text"].includes(this.note.type));
|
|
}
|
|
}
|