gecko-dev/mobile/android/components/ContentDispatchChooser.js
Kris Maglione a259026c9d Bug 1456035: Part 4 - Convert callers of XPCOMUtils.generateQI to ChromeUtils.generateQI. r=mccr8
This also removes any redundant Ci.nsISupports elements in the interface
lists.

This was done using the following script:

acecb401b7/processors/chromeutils-generateQI.jsm

MozReview-Commit-ID: AIx10P8GpZY

--HG--
extra : rebase_source : a29c07530586dc18ba040f19215475ac20fcfb3b
2018-04-22 20:55:06 -07:00

99 lines
3.4 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/. */
ChromeUtils.import("resource://gre/modules/XPCOMUtils.jsm");
ChromeUtils.import("resource://gre/modules/Services.jsm");
ChromeUtils.import("resource://gre/modules/Messaging.jsm");
function ContentDispatchChooser() {}
ContentDispatchChooser.prototype =
{
classID: Components.ID("5a072a22-1e66-4100-afc1-07aed8b62fc5"),
QueryInterface: ChromeUtils.generateQI([Ci.nsIContentDispatchChooser]),
get protoSvc() {
if (!this._protoSvc) {
this._protoSvc = Cc["@mozilla.org/uriloader/external-protocol-service;1"].getService(Ci.nsIExternalProtocolService);
}
return this._protoSvc;
},
_getChromeWin: function getChromeWin() {
try {
return Services.wm.getMostRecentWindow("navigator:browser");
} catch (e) {
throw Cr.NS_ERROR_FAILURE;
}
},
_closeBlankWindow: function(aWindow) {
if (!aWindow || aWindow.history.length) {
return;
}
if (!aWindow.location.href || aWindow.location.href === "about:blank") {
aWindow.close();
}
},
ask: function ask(aHandler, aWindowContext, aURI, aReason) {
let window = null;
try {
if (aWindowContext)
window = aWindowContext.getInterface(Ci.nsIDOMWindow);
} catch (e) { /* it's OK to not have a window */ }
// The current list is based purely on the scheme. Redo the query using the url to get more
// specific results.
aHandler = this.protoSvc.getProtocolHandlerInfoFromOS(aURI.spec, {});
// The first handler in the set is the Android Application Chooser (which will fall back to a default if one is set)
// If we have more than one option, let the OS handle showing a list (if needed).
if (aHandler.possibleApplicationHandlers.length > 1) {
aHandler.launchWithURI(aURI, aWindowContext);
this._closeBlankWindow(window);
} else {
// xpcshell tests do not have an Android Bridge but we require Android
// Bridge when using Messaging so we guard against this case. xpcshell
// tests also do not have a window, so we use this state to guard.
let win = this._getChromeWin();
if (!win) {
return;
}
let msg = {
type: "Intent:OpenNoHandler",
uri: aURI.spec,
};
EventDispatcher.instance.sendRequestForResult(msg).then(() => {
// Java opens an app on success: take no action.
this._closeBlankWindow(window);
}, (data) => {
if (data.isFallback) {
// We always want to open a fallback url
window.location.href = data.uri;
return;
}
// We couldn't open this. If this was from a click, it's likely that we just
// want this to fail silently. If the user entered this on the address bar, though,
// we want to show the neterror page.
let dwu = window.QueryInterface(Ci.nsIInterfaceRequestor).getInterface(Ci.nsIDOMWindowUtils);
let millis = dwu.millisSinceLastUserInput;
if (millis < 0 || millis >= 1000) {
window.document.docShell.displayLoadError(Cr.NS_ERROR_UNKNOWN_PROTOCOL, aURI, null);
} else {
this._closeBlankWindow(window);
}
});
}
},
};
this.NSGetFactory = XPCOMUtils.generateNSGetFactory([ContentDispatchChooser]);