update: main window hooks
This commit is contained in:
		
							parent
							
								
									b48953f405
								
							
						
					
					
						commit
						1e12c84ba6
					
				
							
								
								
									
										85
									
								
								addon/bootstrap.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										85
									
								
								addon/bootstrap.js
									
									
									
									
										vendored
									
									
								
							@ -5,86 +5,11 @@
 | 
			
		||||
 * [2] https://www.zotero.org/support/dev/zotero_7_for_developers
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
if (typeof Zotero == "undefined") {
 | 
			
		||||
  var Zotero;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
var chromeHandle;
 | 
			
		||||
 | 
			
		||||
var windowListener;
 | 
			
		||||
 | 
			
		||||
// In Zotero 6, bootstrap methods are called before Zotero is initialized, and using include.js
 | 
			
		||||
// to get the Zotero XPCOM service would risk breaking Zotero startup. Instead, wait for the main
 | 
			
		||||
// Zotero window to open and get the Zotero object from there.
 | 
			
		||||
//
 | 
			
		||||
// In Zotero 7, bootstrap methods are not called until Zotero is initialized, and the 'Zotero' is
 | 
			
		||||
// automatically made available.
 | 
			
		||||
async function waitForZotero() {
 | 
			
		||||
  await new Promise(async (resolve) => {
 | 
			
		||||
    if (typeof Zotero != "undefined") {
 | 
			
		||||
      resolve();
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    const { Services } = ChromeUtils.import(
 | 
			
		||||
      "resource://gre/modules/Services.jsm",
 | 
			
		||||
    );
 | 
			
		||||
    const windows = Services.wm.getEnumerator("navigator:browser");
 | 
			
		||||
    let found = false;
 | 
			
		||||
    while (windows.hasMoreElements()) {
 | 
			
		||||
      let win = windows.getNext();
 | 
			
		||||
      if (win.Zotero) {
 | 
			
		||||
        Zotero = win.Zotero;
 | 
			
		||||
        found = true;
 | 
			
		||||
        resolve();
 | 
			
		||||
        break;
 | 
			
		||||
      }
 | 
			
		||||
    }
 | 
			
		||||
    windowListener = {
 | 
			
		||||
      onOpenWindow: function (aWindow) {
 | 
			
		||||
        // Wait for the window to finish loading
 | 
			
		||||
        const domWindow = aWindow
 | 
			
		||||
          .QueryInterface(Ci.nsIInterfaceRequestor)
 | 
			
		||||
          .getInterface(Ci.nsIDOMWindowInternal || Ci.nsIDOMWindow);
 | 
			
		||||
        domWindow.addEventListener(
 | 
			
		||||
          "load",
 | 
			
		||||
          async function () {
 | 
			
		||||
            domWindow.removeEventListener("load", arguments.callee, false);
 | 
			
		||||
            if (!found && domWindow.Zotero) {
 | 
			
		||||
              Zotero = domWindow.Zotero;
 | 
			
		||||
              resolve();
 | 
			
		||||
            } else if (
 | 
			
		||||
              domWindow.location.href ===
 | 
			
		||||
              "chrome://zotero/content/zoteroPane.xhtml"
 | 
			
		||||
            ) {
 | 
			
		||||
              // Call the hook for the main window load event
 | 
			
		||||
              // Note that this is not called the first time the window is opened
 | 
			
		||||
              // (when Zotero is initialized), but only when the window is re-opened
 | 
			
		||||
              // after being closed
 | 
			
		||||
              await Zotero.__addonInstance__?.hooks.onMainWindowLoad(domWindow);
 | 
			
		||||
            }
 | 
			
		||||
          },
 | 
			
		||||
          false,
 | 
			
		||||
        );
 | 
			
		||||
      },
 | 
			
		||||
      onCloseWindow: function (aWindow) {
 | 
			
		||||
        const domWindow = aWindow
 | 
			
		||||
          .QueryInterface(Ci.nsIInterfaceRequestor)
 | 
			
		||||
          .getInterface(Ci.nsIDOMWindowInternal || Ci.nsIDOMWindow);
 | 
			
		||||
        if (
 | 
			
		||||
          domWindow.location.href === "chrome://zotero/content/zoteroPane.xhtml"
 | 
			
		||||
        ) {
 | 
			
		||||
          Zotero.__addonInstance__?.hooks.onMainWindowUnload(domWindow);
 | 
			
		||||
        }
 | 
			
		||||
      },
 | 
			
		||||
    };
 | 
			
		||||
    Services.wm.addListener(windowListener);
 | 
			
		||||
  });
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function install(data, reason) {}
 | 
			
		||||
 | 
			
		||||
async function startup({ id, version, resourceURI, rootURI }, reason) {
 | 
			
		||||
  await waitForZotero();
 | 
			
		||||
  await Zotero.initializationPromise;
 | 
			
		||||
 | 
			
		||||
  // String 'rootURI' introduced in Zotero 7
 | 
			
		||||
@ -117,6 +42,14 @@ async function startup({ id, version, resourceURI, rootURI }, reason) {
 | 
			
		||||
  );
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
async function onMainWindowLoad(window) {
 | 
			
		||||
  Zotero.__addonInstance__?.hooks.onMainWindowLoad(window);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
async function onMainWindowUnload(window) {
 | 
			
		||||
  Zotero.__addonInstance__?.hooks.onMainWindowUnload(window);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function shutdown({ id, version, resourceURI, rootURI }, reason) {
 | 
			
		||||
  if (reason === APP_SHUTDOWN) {
 | 
			
		||||
    return;
 | 
			
		||||
@ -128,7 +61,7 @@ function shutdown({ id, version, resourceURI, rootURI }, reason) {
 | 
			
		||||
      Components.interfaces.nsISupports,
 | 
			
		||||
    ).wrappedJSObject;
 | 
			
		||||
  }
 | 
			
		||||
  Zotero.__addonInstance__.hooks.onShutdown();
 | 
			
		||||
  Zotero.__addonInstance__?.hooks.onShutdown();
 | 
			
		||||
 | 
			
		||||
  Cc["@mozilla.org/intl/stringbundle;1"]
 | 
			
		||||
    .getService(Components.interfaces.nsIStringBundleService)
 | 
			
		||||
 | 
			
		||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user