chore(react/ribbon): add all ribbon tab titles & icon

This commit is contained in:
Elian Doran
2025-08-21 19:27:18 +03:00
parent 45fbcec805
commit 5597f4e2e0
17 changed files with 123 additions and 41 deletions

View File

@@ -1020,6 +1020,10 @@ class FNote {
return this.noteId.startsWith("_options");
}
isTriliumSqlite() {
return this.mime === "text/x-sqlite;schema=trilium";
}
/**
* Provides note's date metadata.
*/

View File

@@ -0,0 +1,3 @@
export default function BasicPropertiesTab() {
return <p>Hi</p>;
}

View File

@@ -1,15 +1,112 @@
import FNote from "../../entities/fnote";
import { t } from "../../services/i18n";
import { useNoteContext } from "../react/hooks";
import "./style.css";
type TitleFn = string | ((context: TabContext) => string);
interface TabContext {
note: FNote | null | undefined;
}
interface TabConfiguration {
title: TitleFn;
icon: string;
}
const TAB_CONFIGURATION: TabConfiguration[] = [
{
title: t("classic_editor_toolbar.title"),
icon: "bx bx-text"
// ClassicEditorToolbar
},
{
title: ({ note }) => note?.isTriliumSqlite() ? t("script_executor.query") : t("script_executor.script"),
icon: "bx bx-play"
// ScriptExecutorWidget
},
{
// SearchDefinitionWidget
title: t("search_definition.search_parameters"),
icon: "bx bx-search"
},
{
// Edited NotesWidget
title: t("edited_notes.title"),
icon: "bx bx-calendar-edit"
},
{
// BookPropertiesWidget
title: t("book_properties.book_properties"),
icon: "bx bx-book"
},
{
// NotePropertiesWidget
title: t("note_properties.info"),
icon: "bx bx-info-square"
},
{
// FilePropertiesWidget
title: t("file_properties.title"),
icon: "bx bx-file"
},
{
// ImagePropertiesWidget
title: t("image_properties.title"),
icon: "bx bx-image"
},
{
// BasicProperties
title: t("basic_properties.basic_properties"),
icon: "bx bx-slider"
},
{
// OwnedAttributeListWidget
title: t("owned_attribute_list.owned_attributes"),
icon: "bx bx-list-check"
},
{
// InheritedAttributesWidget
title: t("inherited_attribute_list.title"),
icon: "bx bx-list-plus"
},
{
// NotePathsWidget
title: t("note_paths.title"),
icon: "bx bx-collection"
},
{
// NoteMapRibbonWidget
title: t("note_map.title"),
icon: "bx bxs-network-chart"
},
{
// SimilarNotesWidget
title: t("similar_notes.title"),
icon: "bx bx-bar-chart"
},
{
// NoteInfoWidget
title: t("note_info_widget.title"),
icon: "bx bx-info-circle"
},
];
export default function Ribbon() {
const { note } = useNoteContext();
const context: TabContext = { note };
return (
<div class="ribbon-container" style={{ contain: "none" }}>
<div className="ribbon-top-row">
<div className="ribbon-tab-container">
<RibbonTab
title={t("basic_properties.basic_properties")}
icon="bx bx-slider"
/>
{TAB_CONFIGURATION.map(({ title, icon }) => (
<RibbonTab
icon={icon}
title={typeof title === "string" ? title : title(context)}
/>
))}
</div>
<div className="ribbon-button-container"></div>
</div>
@@ -34,4 +131,5 @@ function RibbonTab({ icon, title }: { icon: string; title: string }) {
<div class="ribbon-tab-spacer" />
</>
)
}
}

View File

@@ -93,8 +93,7 @@ export default class BookPropertiesWidget extends NoteContextAwareWidget {
getTitle() {
return {
show: this.isEnabled(),
title: t("book_properties.book_properties"),
icon: "bx bx-book"
};
}

View File

@@ -64,8 +64,6 @@ export default class ClassicEditorToolbar extends NoteContextAwareWidget {
return {
show: await this.#shouldDisplay(),
activate: true,
title: t("classic_editor_toolbar.title"),
icon: "bx bx-text"
};
}

View File

@@ -49,8 +49,7 @@ export default class EditedNotesWidget extends NoteContextAwareWidget {
show: this.isEnabled(),
// promoted attributes have priority over edited notes
activate: (this.note?.getPromotedDefinitionAttributes().length === 0 || !options.is("promotedAttributesOpenInRibbon")) && options.is("editedNotesOpenInRibbon"),
title: t("edited_notes.title"),
icon: "bx bx-calendar-edit"
};
}

View File

@@ -93,8 +93,7 @@ export default class FilePropertiesWidget extends NoteContextAwareWidget {
return {
show: this.isEnabled(),
activate: true,
title: t("file_properties.title"),
icon: "bx bx-file"
};
}

View File

@@ -77,8 +77,7 @@ export default class ImagePropertiesWidget extends NoteContextAwareWidget {
return {
show: this.isEnabled(),
activate: true,
title: t("image_properties.title"),
icon: "bx bx-image"
};
}

View File

@@ -48,9 +48,7 @@ export default class InheritedAttributesWidget extends NoteContextAwareWidget {
getTitle() {
return {
show: !this.note?.isLaunchBarConfig(),
title: t("inherited_attribute_list.title"),
icon: "bx bx-list-plus"
show: !this.note?.isLaunchBarConfig()
};
}

View File

@@ -105,8 +105,7 @@ export default class NoteInfoWidget extends NoteContextAwareWidget {
getTitle() {
return {
show: this.isEnabled(),
title: t("note_info_widget.title"),
icon: "bx bx-info-circle"
};
}

View File

@@ -57,9 +57,7 @@ export default class NoteMapRibbonWidget extends NoteContextAwareWidget {
getTitle() {
return {
show: this.isEnabled(),
title: t("note_map.title"),
icon: "bx bxs-network-chart"
show: this.isEnabled()
};
}

View File

@@ -55,8 +55,7 @@ export default class NotePathsWidget extends NoteContextAwareWidget {
getTitle() {
return {
show: true,
title: t("note_paths.title"),
icon: "bx bx-collection"
};
}

View File

@@ -31,8 +31,7 @@ export default class NotePropertiesWidget extends NoteContextAwareWidget {
return {
show: this.isEnabled(),
activate: true,
title: t("note_properties.info"),
icon: "bx bx-info-square"
};
}

View File

@@ -52,8 +52,7 @@ export default class OwnedAttributeListWidget extends NoteContextAwareWidget {
getTitle() {
return {
show: !this.note?.isLaunchBarConfig(),
title: t("owned_attribute_list.owned_attributes"),
icon: "bx bx-list-check"
};
}

View File

@@ -37,16 +37,10 @@ export default class ScriptExecutorWidget extends NoteContextAwareWidget {
);
}
isTriliumSqlite() {
return this.note?.mime === "text/x-sqlite;schema=trilium";
}
getTitle() {
return {
show: this.isEnabled(),
activate: true,
title: this.isTriliumSqlite() ? t("script_executor.query") : t("script_executor.script"),
icon: "bx bx-play"
activate: true
};
}

View File

@@ -187,9 +187,7 @@ export default class SearchDefinitionWidget extends NoteContextAwareWidget {
getTitle() {
return {
show: this.isEnabled(),
activate: true,
title: t("search_definition.search_parameters"),
icon: "bx bx-search"
activate: true
};
}

View File

@@ -61,8 +61,7 @@ export default class SimilarNotesWidget extends NoteContextAwareWidget {
getTitle() {
return {
show: this.isEnabled(),
title: t("similar_notes.title"),
icon: "bx bx-bar-chart"
};
}