forked from mirrors/gecko-dev
		
	
		
			
				
	
	
		
			60 lines
		
	
	
	
		
			2 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			60 lines
		
	
	
	
		
			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/. */
 | |
| /* eslint-env mozilla/browser-window */
 | |
| 
 | |
| "use strict";
 | |
| 
 | |
| // This is loaded into chrome windows with the subscript loader. Wrap in
 | |
| // a block to prevent accidentally leaking globals onto `window`.
 | |
| {
 | |
|   class ScreenshotsButtons extends MozXULElement {
 | |
|     static get markup() {
 | |
|       return `
 | |
|       <html:link rel="stylesheet" href="chrome://global/skin/in-content/common.css"/>
 | |
|       <html:link rel="stylesheet" href="chrome://browser/content/screenshots/screenshots-buttons.css"/>
 | |
|       <html:div id="screenshots-buttons" class="all-buttons-container">
 | |
|         <html:button class="visible-page" data-l10n-id="screenshots-save-visible-button"></html:button>
 | |
|         <html:button class="full-page" data-l10n-id="screenshots-save-page-button"></html:button>
 | |
|       </html:div>
 | |
|       `;
 | |
|     }
 | |
| 
 | |
|     connectedCallback() {
 | |
|       const shadowRoot = this.attachShadow({ mode: "open" });
 | |
|       document.l10n.connectRoot(shadowRoot);
 | |
| 
 | |
|       let fragment = MozXULElement.parseXULToFragment(this.constructor.markup);
 | |
|       this.shadowRoot.append(fragment);
 | |
| 
 | |
|       let button1 = shadowRoot.querySelector(".visible-page");
 | |
|       button1.onclick = function () {
 | |
|         Services.obs.notifyObservers(
 | |
|           gBrowser.ownerGlobal,
 | |
|           "screenshots-take-screenshot",
 | |
|           "visible"
 | |
|         );
 | |
|       };
 | |
| 
 | |
|       let button2 = shadowRoot.querySelector(".full-page");
 | |
|       button2.onclick = function () {
 | |
|         Services.obs.notifyObservers(
 | |
|           gBrowser.ownerGlobal,
 | |
|           "screenshots-take-screenshot",
 | |
|           "full-page"
 | |
|         );
 | |
|       };
 | |
|     }
 | |
| 
 | |
|     disconnectedCallback() {
 | |
|       document.l10n.disconnectRoot(this.shadowRoot);
 | |
|     }
 | |
| 
 | |
|     focusFirst(focusOptions) {
 | |
|       this.shadowRoot.querySelector("button:enabled").focus(focusOptions);
 | |
|     }
 | |
|   }
 | |
|   customElements.define("screenshots-buttons", ScreenshotsButtons, {
 | |
|     extends: "toolbar",
 | |
|   });
 | |
| }
 | 
