forked from mirrors/gecko-dev
		
	 a3e99a2057
			
		
	
	
		a3e99a2057
		
	
	
	
	
		
			
			Unify the values of "source" and "page" as used in FeatureCallout.sys.mjs: - Explicitly pass in a value for "page" when instantiating a Feature Callout and use this for the value of "page" when sending Feature Callout telemetry and as the "source" when making calls to `sendTriggerMessage`. This avoids the risk of including non-about: page URLs or PDF file extensions in our telemetry. - Set the value of "page" in an HTML data attribute that can be accessed for use in about:welcome telemetry for Spotlight and Feature Callouts. - Update references to the page value previously used as the page/source for telemetry from `about:firefoxview` Feature Callouts from "firefoxview" to "about:firefoxview" - Pass the token "chrome" when creating a callout from the browser chrome and update references to the source in PDF.js messages' targeting - Update the page value expected in automated tests as needed Differential Revision: https://phabricator.services.mozilla.com/D165910
		
			
				
	
	
		
			70 lines
		
	
	
	
		
			2.2 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			70 lines
		
	
	
	
		
			2.2 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| /* This Source Code Form is subject to the terms of the Mozilla Public
 | |
|  * License, v. 2.0. If a copy of the MPL was not distributed with this
 | |
|  * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
 | |
| 
 | |
| const { FeatureCallout } = ChromeUtils.importESModule(
 | |
|   "resource:///modules/FeatureCallout.sys.mjs"
 | |
| );
 | |
| 
 | |
| const MediaQueryDOMSorting = {
 | |
|   init() {
 | |
|     this.recentlyClosedTabs = document.getElementById(
 | |
|       "recently-closed-tabs-container"
 | |
|     );
 | |
|     this.colorways = document.getElementById("colorways");
 | |
|     this.mql = window.matchMedia("(max-width: 65rem)");
 | |
|     this.mql.addEventListener("change", () => this.changeHandler());
 | |
|     this.changeHandler();
 | |
|   },
 | |
|   cleanup() {
 | |
|     this.mql.removeEventListener("change", () => this.changeHandler());
 | |
|   },
 | |
|   changeHandler() {
 | |
|     const oldFocus = document.activeElement;
 | |
|     if (this.mql.matches) {
 | |
|       this.recentlyClosedTabs.before(this.colorways);
 | |
|     } else {
 | |
|       this.colorways.before(this.recentlyClosedTabs);
 | |
|     }
 | |
|     if (oldFocus) {
 | |
|       Services.focus.setFocus(oldFocus, Ci.nsIFocusManager.FLAG_NOSCROLL);
 | |
|     }
 | |
|   },
 | |
| };
 | |
| 
 | |
| const launchFeatureTour = () => {
 | |
|   let callout = new FeatureCallout({
 | |
|     win: window,
 | |
|     prefName: "browser.firefox-view.feature-tour",
 | |
|     page: "about:firefoxview",
 | |
|   });
 | |
|   callout.showFeatureCallout();
 | |
| };
 | |
| 
 | |
| window.addEventListener("DOMContentLoaded", async () => {
 | |
|   Services.telemetry.setEventRecordingEnabled("firefoxview", true);
 | |
|   Services.telemetry.recordEvent("firefoxview", "entered", "firefoxview", null);
 | |
|   document.getElementById("recently-closed-tabs-container").onLoad();
 | |
|   MediaQueryDOMSorting.init();
 | |
|   // If Firefox View was reloaded by the user, force syncing of tabs
 | |
|   // to get the most up to date synced tabs.
 | |
|   if (
 | |
|     performance
 | |
|       .getEntriesByType("navigation")
 | |
|       .map(nav => nav.type)
 | |
|       .includes("reload")
 | |
|   ) {
 | |
|     await document.getElementById("tab-pickup-container").onReload();
 | |
|   }
 | |
|   launchFeatureTour();
 | |
| });
 | |
| 
 | |
| window.addEventListener("unload", () => {
 | |
|   const tabPickupList = document.querySelector("tab-pickup-list");
 | |
|   if (tabPickupList) {
 | |
|     tabPickupList.cleanup();
 | |
|   }
 | |
|   document.getElementById("tab-pickup-container").cleanup();
 | |
|   document.getElementById("recently-closed-tabs-container").cleanup();
 | |
|   MediaQueryDOMSorting.cleanup();
 | |
| });
 |