add: remove addon elements

This commit is contained in:
xiangyu 2022-12-15 21:07:08 +08:00
parent c8b92a8ff9
commit 06bc324b5e
4 changed files with 29 additions and 14 deletions

View File

@ -8,7 +8,7 @@ class Addon {
public events: AddonEvents;
public views: AddonViews;
public prefs: AddonPrefs;
public utils: AddonUtils;
public Utils: AddonUtils;
// root path to access the resources
public rootURI: string;
@ -16,7 +16,7 @@ class Addon {
this.events = new AddonEvents(this);
this.views = new AddonViews(this);
this.prefs = new AddonPrefs(this);
this.utils = new AddonUtils(this);
this.Utils = new AddonUtils(this);
}
}

View File

@ -94,6 +94,7 @@ class AddonUtils extends AddonModule {
},
};
this.UI = {
addonElements: [],
createElement: (
doc: Document,
tagName: string,
@ -107,13 +108,26 @@ class AddonUtils extends AddonModule {
if (tagName === "fragment") {
return doc.createDocumentFragment();
} else if (namespace === "xul") {
return this.Compat.createXULElement(doc, tagName);
const e = this.Compat.createXULElement(doc, tagName);
this.UI.addonElements.push(e);
return e;
} else {
return doc.createElementNS(namespaces[namespace], tagName) as
const e = doc.createElementNS(namespaces[namespace], tagName) as
| HTMLElement
| SVGAElement;
this.UI.addonElements.push(e);
return e;
}
},
removeAddonElements: () => {
this.UI.addonElements.forEach((e) => {
try {
e?.remove();
} catch (e) {
this._Addon.Utils.Tool.log(e);
}
});
},
creatElementsFromJSON: (doc: Document, options: ElementOptions) => {
this.Tool.log(options);
if (

View File

@ -4,7 +4,6 @@ const { addonRef, addonID } = require("../package.json");
class AddonViews extends AddonModule {
// You can store some element in the object attributes
private testButton: XUL.Button;
private progressWindowIcon: object;
constructor(parent: Addon) {
@ -24,7 +23,7 @@ class AddonViews extends AddonModule {
const menuIcon =
"";
// item menuitem with icon
this._Addon.utils.UI.insertMenuItem("item", {
this._Addon.Utils.UI.insertMenuItem("item", {
tag: "menuitem",
id: "zotero-itemmenu-addontemplate-test",
label: "Addon Template: Menuitem",
@ -32,7 +31,7 @@ class AddonViews extends AddonModule {
icon: menuIcon,
});
// item menupopup with sub-menuitems
this._Addon.utils.UI.insertMenuItem(
this._Addon.Utils.UI.insertMenuItem(
"item",
{
tag: "menu",
@ -50,8 +49,11 @@ class AddonViews extends AddonModule {
"#zotero-itemmenu-addontemplate-test"
)
);
this._Addon.Utils.UI.insertMenuItem("menuFile", {
tag: "menuseparator",
});
// menu->File menuitem
this._Addon.utils.UI.insertMenuItem("menuFile", {
this._Addon.Utils.UI.insertMenuItem("menuFile", {
tag: "menuitem",
label: "Addon Template: File Menuitem",
oncommand: "alert('Hello World! File Menuitem.')",
@ -70,10 +72,7 @@ class AddonViews extends AddonModule {
public unInitViews() {
const Zotero = this._Addon.Zotero;
Zotero.debug("Uninitializing UI");
const _window: Window = Zotero.getMainWindow();
_window.document
.querySelector("#zotero-itemmenu-addontemplate-test")
?.remove();
this._Addon.Utils.UI.removeAddonElements();
}
public showProgressWindow(

6
typing/global.d.ts vendored
View File

@ -17,11 +17,13 @@ declare interface ZoteroTool {
}
declare interface ZoteroUI {
addonElements: Element[];
createElement: (
doc: Document,
tagName: string,
namespace: "html" | "svg" | "xul"
) => XUL.Element | DocumentFragment | HTMLElement | SVGAElement;
removeAddonElements: () => void;
creatElementsFromJSON: (
doc: Document,
options: ElementOptions
@ -60,9 +62,9 @@ declare interface ElementOptions {
}
declare interface MenuitemOptions {
tag: "menuitem" | "menu";
tag: "menuitem" | "menu" | "menuseparator";
id?: string;
label: string;
label?: string;
// data url (chrome://xxx.png) or base64 url ()
icon?: string;
class?: string;