forked from mirrors/gecko-dev
		
	 a32ab22c8c
			
		
	
	
		a32ab22c8c
		
	
	
	
	
		
			
			On Mac, ctrl-click will send a context menu event from the widget, so we don't want to bring up the panel when ctrl key is pressed. Differential Revision: https://phabricator.services.mozilla.com/D66384 --HG-- extra : moz-landing-system : lando
		
			
				
	
	
		
			147 lines
		
	
	
	
		
			4.6 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			147 lines
		
	
	
	
		
			4.6 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| /* Any copyright is dedicated to the Public Domain.
 | |
|  * http://creativecommons.org/publicdomain/zero/1.0/ */
 | |
| 
 | |
| const { PlacesTestUtils } = ChromeUtils.import(
 | |
|   "resource://testing-common/PlacesTestUtils.jsm"
 | |
| );
 | |
| 
 | |
| function promisePageActionPanelOpen(eventDict = {}) {
 | |
|   let dwu = window.windowUtils;
 | |
|   return BrowserTestUtils.waitForCondition(() => {
 | |
|     // Wait for the main page action button to become visible.  It's hidden for
 | |
|     // some URIs, so depending on when this is called, it may not yet be quite
 | |
|     // visible.  It's up to the caller to make sure it will be visible.
 | |
|     info("Waiting for main page action button to have non-0 size");
 | |
|     let bounds = dwu.getBoundsWithoutFlushing(
 | |
|       BrowserPageActions.mainButtonNode
 | |
|     );
 | |
|     return bounds.width > 0 && bounds.height > 0;
 | |
|   })
 | |
|     .then(() => {
 | |
|       // Wait for the panel to become open, by clicking the button if necessary.
 | |
|       info("Waiting for main page action panel to be open");
 | |
|       if (BrowserPageActions.panelNode.state == "open") {
 | |
|         return Promise.resolve();
 | |
|       }
 | |
|       let shownPromise = promisePageActionPanelShown();
 | |
|       EventUtils.synthesizeMouseAtCenter(
 | |
|         BrowserPageActions.mainButtonNode,
 | |
|         eventDict
 | |
|       );
 | |
|       return shownPromise;
 | |
|     })
 | |
|     .then(() => {
 | |
|       // Wait for items in the panel to become visible.
 | |
|       return promisePageActionViewChildrenVisible(
 | |
|         BrowserPageActions.mainViewNode
 | |
|       );
 | |
|     });
 | |
| }
 | |
| 
 | |
| async function waitForActivatedActionPanel() {
 | |
|   if (!BrowserPageActions.activatedActionPanelNode) {
 | |
|     info("Waiting for activated-action panel to be added to mainPopupSet");
 | |
|     await new Promise(resolve => {
 | |
|       let observer = new MutationObserver(mutations => {
 | |
|         if (BrowserPageActions.activatedActionPanelNode) {
 | |
|           observer.disconnect();
 | |
|           resolve();
 | |
|         }
 | |
|       });
 | |
|       let popupSet = document.getElementById("mainPopupSet");
 | |
|       observer.observe(popupSet, { childList: true });
 | |
|     });
 | |
|     info("Activated-action panel added to mainPopupSet");
 | |
|   }
 | |
|   if (!BrowserPageActions.activatedActionPanelNode.state == "open") {
 | |
|     info("Waiting for activated-action panel popupshown");
 | |
|     await promisePanelShown(BrowserPageActions.activatedActionPanelNode);
 | |
|     info("Got activated-action panel popupshown");
 | |
|   }
 | |
|   let panelView = BrowserPageActions.activatedActionPanelNode.querySelector(
 | |
|     "panelview"
 | |
|   );
 | |
|   if (panelView) {
 | |
|     await BrowserTestUtils.waitForEvent(
 | |
|       BrowserPageActions.activatedActionPanelNode,
 | |
|       "ViewShown"
 | |
|     );
 | |
|     await promisePageActionViewChildrenVisible(panelView);
 | |
|   }
 | |
|   return panelView;
 | |
| }
 | |
| 
 | |
| function promisePageActionPanelShown() {
 | |
|   return promisePanelShown(BrowserPageActions.panelNode);
 | |
| }
 | |
| 
 | |
| function promisePageActionPanelHidden() {
 | |
|   return promisePanelHidden(BrowserPageActions.panelNode);
 | |
| }
 | |
| 
 | |
| function promisePanelShown(panelIDOrNode) {
 | |
|   return promisePanelEvent(panelIDOrNode, "popupshown");
 | |
| }
 | |
| 
 | |
| function promisePanelHidden(panelIDOrNode) {
 | |
|   return promisePanelEvent(panelIDOrNode, "popuphidden");
 | |
| }
 | |
| 
 | |
| function promisePanelEvent(panelIDOrNode, eventType) {
 | |
|   return new Promise(resolve => {
 | |
|     let panel = panelIDOrNode;
 | |
|     if (typeof panel == "string") {
 | |
|       panel = document.getElementById(panelIDOrNode);
 | |
|       if (!panel) {
 | |
|         throw new Error(`Panel with ID "${panelIDOrNode}" does not exist.`);
 | |
|       }
 | |
|     }
 | |
|     if (
 | |
|       (eventType == "popupshown" && panel.state == "open") ||
 | |
|       (eventType == "popuphidden" && panel.state == "closed")
 | |
|     ) {
 | |
|       executeSoon(resolve);
 | |
|       return;
 | |
|     }
 | |
|     panel.addEventListener(
 | |
|       eventType,
 | |
|       () => {
 | |
|         executeSoon(resolve);
 | |
|       },
 | |
|       { once: true }
 | |
|     );
 | |
|   });
 | |
| }
 | |
| 
 | |
| function promisePageActionViewShown() {
 | |
|   info("promisePageActionViewShown waiting for ViewShown");
 | |
|   return BrowserTestUtils.waitForEvent(
 | |
|     BrowserPageActions.panelNode,
 | |
|     "ViewShown"
 | |
|   ).then(async event => {
 | |
|     let panelViewNode = event.originalTarget;
 | |
|     await promisePageActionViewChildrenVisible(panelViewNode);
 | |
|     return panelViewNode;
 | |
|   });
 | |
| }
 | |
| 
 | |
| function promisePageActionViewChildrenVisible(panelViewNode) {
 | |
|   return promiseNodeVisible(panelViewNode.firstElementChild.firstElementChild);
 | |
| }
 | |
| 
 | |
| function promiseNodeVisible(node) {
 | |
|   info(
 | |
|     `promiseNodeVisible waiting, node.id=${node.id} node.localeName=${node.localName}\n`
 | |
|   );
 | |
|   let dwu = window.windowUtils;
 | |
|   return BrowserTestUtils.waitForCondition(() => {
 | |
|     let bounds = dwu.getBoundsWithoutFlushing(node);
 | |
|     if (bounds.width > 0 && bounds.height > 0) {
 | |
|       info(
 | |
|         `promiseNodeVisible OK, node.id=${node.id} node.localeName=${node.localName}\n`
 | |
|       );
 | |
|       return true;
 | |
|     }
 | |
|     return false;
 | |
|   });
 | |
| }
 |