add: views example for menu
This commit is contained in:
		
							parent
							
								
									8db7a7502c
								
							
						
					
					
						commit
						c8b92a8ff9
					
				
							
								
								
									
										52
									
								
								src/views.ts
									
									
									
									
									
								
							
							
						
						
									
										52
									
								
								src/views.ts
									
									
									
									
									
								
							@ -1,4 +1,4 @@
 | 
				
			|||||||
import { Addon, getZotero, createXULElement } from "./addon";
 | 
					import Addon from "./addon";
 | 
				
			||||||
import AddonModule from "./module";
 | 
					import AddonModule from "./module";
 | 
				
			||||||
const { addonRef, addonID } = require("../package.json");
 | 
					const { addonRef, addonID } = require("../package.json");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -17,23 +17,49 @@ class AddonViews extends AddonModule {
 | 
				
			|||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  public initViews() {
 | 
					  public initViews() {
 | 
				
			||||||
    const Zotero = getZotero();
 | 
					    const Zotero = this._Addon.Zotero;
 | 
				
			||||||
    // You can init the UI elements that
 | 
					    // You can init the UI elements that
 | 
				
			||||||
    // cannot be initialized with overlay.xul
 | 
					    // cannot be initialized with overlay.xul
 | 
				
			||||||
    Zotero.debug("Initializing UI");
 | 
					    Zotero.debug("Initializing UI");
 | 
				
			||||||
    const _window: Window = Zotero.getMainWindow();
 | 
					    const menuIcon =
 | 
				
			||||||
    const menuitem = createXULElement(_window.document, "menuitem");
 | 
					      "";
 | 
				
			||||||
    menuitem.id = "zotero-itemmenu-addontemplate-test";
 | 
					    // item menuitem with icon
 | 
				
			||||||
    menuitem.setAttribute("label", "Addon Template");
 | 
					    this._Addon.utils.UI.insertMenuItem("item", {
 | 
				
			||||||
    menuitem.setAttribute("oncommand", "alert('Hello World!')");
 | 
					      tag: "menuitem",
 | 
				
			||||||
    // menuitem.className = "menuitem-iconic";
 | 
					      id: "zotero-itemmenu-addontemplate-test",
 | 
				
			||||||
    // menuitem.style["list-style-image"] =
 | 
					      label: "Addon Template: Menuitem",
 | 
				
			||||||
    //   "url('chrome/skin/default/addontemplate/favicon@0.5x.png')";
 | 
					      oncommand: "alert('Hello World! Default Menuitem.')",
 | 
				
			||||||
    _window.document.querySelector("#zotero-itemmenu").appendChild(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() {
 | 
					  public initPrefs() {
 | 
				
			||||||
    const Zotero = getZotero();
 | 
					    const Zotero = this._Addon.Zotero;
 | 
				
			||||||
    Zotero.PreferencePanes.register({
 | 
					    Zotero.PreferencePanes.register({
 | 
				
			||||||
      pluginID: addonID,
 | 
					      pluginID: addonID,
 | 
				
			||||||
      src: `${this._Addon.rootURI}/chrome/content/preferences.xhtml`,
 | 
					      src: `${this._Addon.rootURI}/chrome/content/preferences.xhtml`,
 | 
				
			||||||
@ -42,7 +68,7 @@ class AddonViews extends AddonModule {
 | 
				
			|||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  public unInitViews() {
 | 
					  public unInitViews() {
 | 
				
			||||||
    const Zotero = getZotero();
 | 
					    const Zotero = this._Addon.Zotero;
 | 
				
			||||||
    Zotero.debug("Uninitializing UI");
 | 
					    Zotero.debug("Uninitializing UI");
 | 
				
			||||||
    const _window: Window = Zotero.getMainWindow();
 | 
					    const _window: Window = Zotero.getMainWindow();
 | 
				
			||||||
    _window.document
 | 
					    _window.document
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user