add: views example for menu

This commit is contained in:
xiangyu 2022-12-15 20:50:17 +08:00
parent 8db7a7502c
commit c8b92a8ff9

View File

@ -1,4 +1,4 @@
import { Addon, getZotero, createXULElement } from "./addon";
import Addon from "./addon";
import AddonModule from "./module";
const { addonRef, addonID } = require("../package.json");
@ -17,23 +17,49 @@ class AddonViews extends AddonModule {
}
public initViews() {
const Zotero = getZotero();
const Zotero = this._Addon.Zotero;
// You can init the UI elements that
// cannot be initialized with overlay.xul
Zotero.debug("Initializing UI");
const _window: Window = Zotero.getMainWindow();
const menuitem = createXULElement(_window.document, "menuitem");
menuitem.id = "zotero-itemmenu-addontemplate-test";
menuitem.setAttribute("label", "Addon Template");
menuitem.setAttribute("oncommand", "alert('Hello World!')");
// menuitem.className = "menuitem-iconic";
// menuitem.style["list-style-image"] =
// "url('chrome/skin/default/addontemplate/favicon@0.5x.png')";
_window.document.querySelector("#zotero-itemmenu").appendChild(menuitem);
const menuIcon =
"";
// item menuitem with icon
this._Addon.utils.UI.insertMenuItem("item", {
tag: "menuitem",
id: "zotero-itemmenu-addontemplate-test",
label: "Addon Template: Menuitem",
oncommand: "alert('Hello World! Default Menuitem.')",
icon: menuIcon,
});
// item menupopup with sub-menuitems
this._Addon.utils.UI.insertMenuItem(
"item",
{
tag: "menu",
label: "Addon Template: Menupopup",
subElementOptions: [
{
tag: "menuitem",
label: "Addon Template",
oncommand: "alert('Hello World! Sub Menuitem.')",
},
],
},
"before",
this._Addon.Zotero.getMainWindow().document.querySelector(
"#zotero-itemmenu-addontemplate-test"
)
);
// menu->File menuitem
this._Addon.utils.UI.insertMenuItem("menuFile", {
tag: "menuitem",
label: "Addon Template: File Menuitem",
oncommand: "alert('Hello World! File Menuitem.')",
});
}
public initPrefs() {
const Zotero = getZotero();
const Zotero = this._Addon.Zotero;
Zotero.PreferencePanes.register({
pluginID: addonID,
src: `${this._Addon.rootURI}/chrome/content/preferences.xhtml`,
@ -42,7 +68,7 @@ class AddonViews extends AddonModule {
}
public unInitViews() {
const Zotero = getZotero();
const Zotero = this._Addon.Zotero;
Zotero.debug("Uninitializing UI");
const _window: Window = Zotero.getMainWindow();
_window.document