Roll src/third_party/WebKit d9c6159:8139f33 (svn 201974:201975)
[chromium-blink-merge.git] / chrome / browser / resources / pdf / browser_api.js
blob5ba5c49d4910a74ddc4b70cfa25637c7fac943f8
1 // Copyright 2015 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 'use strict';
7 /**
8 * Returns a promise that will resolve to the default zoom factor.
9 * @param {!Object} streamInfo The stream object pointing to the data contained
10 * in the PDF.
11 * @return {Promise<number>} A promise that will resolve to the default zoom
12 * factor.
14 function lookupDefaultZoom(streamInfo) {
15 // Webviews don't run in tabs so |streamInfo.tabId| is -1 when running within
16 // a webview.
17 if (!chrome.tabs || streamInfo.tabId < 0)
18 return Promise.resolve(1);
20 return new Promise(function(resolve, reject) {
21 chrome.tabs.getZoomSettings(streamInfo.tabId, function(zoomSettings) {
22 resolve(zoomSettings.defaultZoomFactor);
23 });
24 });
27 /**
28 * A class providing an interface to the browser.
30 class BrowserApi {
31 /**
32 * @constructor
33 * @param {!Object} streamInfo The stream object which points to the data
34 * contained in the PDF.
35 * @param {number} defaultZoom The default browser zoom.
36 * @param {boolean} manageZoom Whether to manage zoom.
38 constructor(streamInfo, defaultZoom, manageZoom) {
39 this.streamInfo_ = streamInfo;
40 this.defaultZoom_ = defaultZoom;
41 this.manageZoom_ = manageZoom;
44 /**
45 * Returns a promise to a BrowserApi.
46 * @param {!Object} streamInfo The stream object pointing to the data
47 * contained in the PDF.
48 * @param {boolean} manageZoom Whether to manage zoom.
50 static create(streamInfo, manageZoom) {
51 return lookupDefaultZoom(streamInfo).then(function(defaultZoom) {
52 return new BrowserApi(streamInfo, defaultZoom, manageZoom);
53 });
56 /**
57 * Returns the stream info pointing to the data contained in the PDF.
58 * @return {Object} The stream info object.
60 getStreamInfo() {
61 return this.streamInfo_;
64 /**
65 * Aborts the stream.
67 abortStream() {
68 if (chrome.mimeHandlerPrivate)
69 chrome.mimeHandlerPrivate.abortStream();
72 /**
73 * Sets the browser zoom.
74 * @param {number} zoom The zoom factor to send to the browser.
75 * @return {Promise} A promise that will be resolved when the browser zoom
76 * has been updated.
78 setZoom(zoom) {
79 if (!this.manageZoom_)
80 return Promise.resolve();
81 return new Promise(function(resolve, reject) {
82 chrome.tabs.setZoom(this.streamInfo_.tabId, zoom, resolve);
83 }.bind(this));
86 /**
87 * Returns the default browser zoom factor.
88 * @return {number} The default browser zoom factor.
90 getDefaultZoom() {
91 return this.defaultZoom_;
94 /**
95 * Adds an event listener to be notified when the browser zoom changes.
96 * @param {function} listener The listener to be called with the new zoom
97 * factor.
99 addZoomEventListener(listener) {
100 if (!this.manageZoom_)
101 return;
103 chrome.tabs.onZoomChange.addListener(function(zoomChangeInfo) {
104 if (zoomChangeInfo.tabId != this.streamInfo_.tabId)
105 return;
106 listener(zoomChangeInfo.newZoomFactor);
107 }.bind(this));
112 * Creates a BrowserApi for an extension running as a mime handler.
113 * @return {Promise<BrowserApi>} A promise to a BrowserApi instance constructed
114 * using the mimeHandlerPrivate API.
116 function createBrowserApiForMimeHandlerView() {
117 return new Promise(function(resolve, reject) {
118 chrome.mimeHandlerPrivate.getStreamInfo(resolve);
119 }).then(function(streamInfo) {
120 let manageZoom = !streamInfo.embedded && streamInfo.tabId != -1;
121 return new Promise(function(resolve, reject) {
122 if (!manageZoom) {
123 resolve();
124 return;
126 chrome.tabs.setZoomSettings(
127 streamInfo.tabId, {mode: 'manual', scope: 'per-tab'}, resolve);
128 }).then(function() { return BrowserApi.create(streamInfo, manageZoom); });
133 * Creates a BrowserApi instance for an extension not running as a mime handler.
134 * @return {Promise<BrowserApi>} A promise to a BrowserApi instance constructed
135 * from the URL.
137 function createBrowserApiForStandaloneExtension() {
138 let url = window.location.search.substring(1);
139 let streamInfo = {
140 streamUrl: url,
141 originalUrl: url,
142 responseHeaders: {},
143 embedded: window.parent != window,
144 tabId: -1,
146 return new Promise(function(resolve, reject) {
147 if (!chrome.tabs) {
148 resolve();
149 return;
151 chrome.tabs.getCurrent(function(tab) {
152 streamInfo.tabId = tab.id;
153 resolve();
155 }).then(function() { return BrowserApi.create(streamInfo, false); });
159 * Returns a promise that will resolve to a BrowserApi instance.
160 * @return {Promise<BrowserApi>} A promise to a BrowserApi instance for the
161 * current environment.
163 function createBrowserApi() {
164 if (window.location.search)
165 return createBrowserApiForStandaloneExtension();
167 return createBrowserApiForMimeHandlerView();