This commit is contained in:
Vanessa 2023-05-08 12:35:56 +08:00
parent 4312e46d27
commit 683bb5cf50
2 changed files with 63 additions and 0 deletions

View file

@ -2,10 +2,72 @@ import {confirmDialog} from "../dialog/confirmDialog";
import {Plugin} from "./index";
import {showMessage} from "../dialog/message";
import {Dialog} from "../dialog";
import {MenuItem} from "../menus/Menu";
import {Menu as SiyuanMenu} from "../menus/Menu";
export class Menu {
private menu: SiyuanMenu;
private isOpen: boolean
constructor(id?: string, closeCB?: () => void) {
this.menu = window.siyuan.menus.menu;
this.isOpen = false;
if (id) {
const dataName = this.menu.element.getAttribute('data-name');
if (dataName && dataName === id) {
this.isOpen = true
}
}
this.menu.remove();
if (!this.isOpen) {
this.menu.element.setAttribute('data-name', id);
this.menu.removeCB = closeCB;
}
}
showSubMenu(subMenuElement: HTMLElement) {
this.menu.showSubMenu(subMenuElement);
}
addItem(option: IMenu) {
if (this.isOpen) {
return;
}
const menuItem = new MenuItem(option);
this.menu.append(menuItem.element);
return menuItem.element;
}
addSeparator() {
if (this.isOpen) {
return;
}
this.addItem({type: 'separator'});
}
open(options: { x: number, y: number, h?: number, w?: number, isLeft: false }) {
if (this.isOpen) {
return;
}
this.menu.popup(options, options.isLeft);
}
fullscreen(position: { x: number; y: number }) {
if (this.isOpen) {
return;
}
this.menu.popup({x: position.x, y: position.y});
}
close() {
this.menu.remove();
}
}
export const API = {
Plugin: Plugin,
confirm: confirmDialog,
showMessage,
Dialog,
Menu,
};

View file

@ -24,6 +24,7 @@ export class Plugin {
const iconElement = document.createElement("div");
iconElement.className = "toolbar__item b3-tooltips b3-tooltips__sw";
iconElement.setAttribute("aria-label", options.title);
iconElement.setAttribute("data-menu", "true");
iconElement.innerHTML = options.icon.startsWith("icon") ? `<svg><use xlink:href="#${options.icon}"></use></svg>` : options.icon;
iconElement.addEventListener("click", options.callback);
document.querySelector("#" + (options.position === "right" ? "barSearch" : "drag")).before(iconElement);