mirror of
https://github.com/zadam/trilium.git
synced 2025-12-21 06:44:24 +01:00
feat(breadcrumb): color selector
This commit is contained in:
parent
d1575a28ad
commit
d1820a6bc3
@ -16,7 +16,7 @@ function openContextMenu(notePath: string, e: ContextMenuEvent, viewScope: ViewS
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
function getItems(e: ContextMenuEvent | LeafletMouseEvent): MenuItem<CommandNames>[] {
|
function getItems(e: ContextMenuEvent | LeafletMouseEvent): MenuItem<"openNoteInNewTab" | "openNoteInNewSplit" | "openNoteInNewWindow" | "openNoteInPopup">[] {
|
||||||
const ntxId = getNtxId(e);
|
const ntxId = getNtxId(e);
|
||||||
const isMobileSplitOpen = isMobile() && appContext.tabManager.getNoteContextById(ntxId).getMainContext().getSubContexts().length > 1;
|
const isMobileSplitOpen = isMobile() && appContext.tabManager.getNoteContextById(ntxId).getMainContext().getSubContexts().length > 1;
|
||||||
|
|
||||||
|
|||||||
@ -3,11 +3,13 @@ import "./Breadcrumb.css";
|
|||||||
import { useContext, useRef, useState } from "preact/hooks";
|
import { useContext, useRef, useState } from "preact/hooks";
|
||||||
import { Fragment } from "preact/jsx-runtime";
|
import { Fragment } from "preact/jsx-runtime";
|
||||||
|
|
||||||
import appContext from "../../components/app_context";
|
import appContext, { CommandNames } from "../../components/app_context";
|
||||||
import NoteContext from "../../components/note_context";
|
import NoteContext from "../../components/note_context";
|
||||||
import FNote from "../../entities/fnote";
|
import FNote from "../../entities/fnote";
|
||||||
import contextMenu from "../../menus/context_menu";
|
import contextMenu, { MenuItem } from "../../menus/context_menu";
|
||||||
|
import NoteColorPicker from "../../menus/custom-items/NoteColorPicker";
|
||||||
import link_context_menu from "../../menus/link_context_menu";
|
import link_context_menu from "../../menus/link_context_menu";
|
||||||
|
import { TreeCommandNames } from "../../menus/tree_context_menu";
|
||||||
import attributes from "../../services/attributes";
|
import attributes from "../../services/attributes";
|
||||||
import branches from "../../services/branches";
|
import branches from "../../services/branches";
|
||||||
import { executeBulkActions } from "../../services/bulk_action";
|
import { executeBulkActions } from "../../services/bulk_action";
|
||||||
@ -186,8 +188,7 @@ function BreadcrumbItem({ index, notePath, noteContext, notePathLength }: { inde
|
|||||||
const parentNote = isNotRoot && branch ? await froca.getNote(branch.parentNoteId) : null;
|
const parentNote = isNotRoot && branch ? await froca.getNote(branch.parentNoteId) : null;
|
||||||
const parentNotSearch = !parentNote || parentNote.type !== "search";
|
const parentNotSearch = !parentNote || parentNote.type !== "search";
|
||||||
|
|
||||||
contextMenu.show({
|
const items = [
|
||||||
items: [
|
|
||||||
...link_context_menu.getItems(e),
|
...link_context_menu.getItems(e),
|
||||||
{
|
{
|
||||||
title: `${t("tree-context-menu.hoist-note")}`,
|
title: `${t("tree-context-menu.hoist-note")}`,
|
||||||
@ -237,8 +238,18 @@ function BreadcrumbItem({ index, notePath, noteContext, notePathLength }: { inde
|
|||||||
uiIcon: "bx bx-trash destructive-action-icon",
|
uiIcon: "bx bx-trash destructive-action-icon",
|
||||||
enabled: isNotRoot && !isHoisted && parentNotSearch && notOptionsOrHelp,
|
enabled: isNotRoot && !isHoisted && parentNotSearch && notOptionsOrHelp,
|
||||||
handler: () => branches.deleteNotes([ branchId ])
|
handler: () => branches.deleteNotes([ branchId ])
|
||||||
|
},
|
||||||
|
{ kind: "separator"},
|
||||||
|
(notOptionsOrHelp ? {
|
||||||
|
kind: "custom",
|
||||||
|
componentFn: () => {
|
||||||
|
return NoteColorPicker({note});
|
||||||
}
|
}
|
||||||
],
|
} : null),
|
||||||
|
];
|
||||||
|
|
||||||
|
contextMenu.show({
|
||||||
|
items: items.filter(Boolean) as MenuItem<TreeCommandNames>[],
|
||||||
x: e.pageX,
|
x: e.pageX,
|
||||||
y: e.pageY,
|
y: e.pageY,
|
||||||
selectMenuItemHandler: ({ command }) => {
|
selectMenuItemHandler: ({ command }) => {
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user