You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
93 lines
2.4 KiB
JavaScript
93 lines
2.4 KiB
JavaScript
5 years ago
|
/*
|
||
|
* 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/.
|
||
|
*/
|
||
|
|
||
|
var platform_type = "";
|
||
|
|
||
|
var platform_theme = "auto";
|
||
|
|
||
|
var nw_tray = null;
|
||
|
|
||
|
var openBrowser = function (url) {
|
||
|
|
||
|
}
|
||
|
|
||
|
function initCordova() {
|
||
|
platform_type = "cordova";
|
||
|
|
||
|
try {
|
||
|
eval('"use strict"; class foo {}');
|
||
|
} catch (e) {
|
||
|
alert("Your device's webview is out of date and won't work with this app. Please update it.");
|
||
|
}
|
||
|
|
||
|
// Handle back button to close things
|
||
|
document.addEventListener("backbutton", function (event) {
|
||
|
router.navigate("/home");
|
||
|
}, false);
|
||
|
|
||
|
document.addEventListener("deviceready", function () {
|
||
|
if (cordova.platformId == 'android') {
|
||
|
StatusBar.backgroundColorByHexString("#D32F2F");
|
||
|
StatusBar.styleLightContent();
|
||
|
}
|
||
|
}, false);
|
||
|
|
||
|
openBrowser = function (url) {
|
||
|
cordova.InAppBrowser.open(url, '_blank', 'location=yes');
|
||
|
}
|
||
|
}
|
||
|
|
||
|
function initNW() {
|
||
|
platform_type = "nw";
|
||
|
platform_theme = "aurora";
|
||
|
|
||
|
openBrowser = function (url) {
|
||
|
nw.Window.open(url, {
|
||
|
id: url
|
||
|
}, function (browserwin) {
|
||
|
// Add menubar so the user can navigate around if they click a link
|
||
|
var browsermenu = new nw.Menu({type: 'menubar'});
|
||
|
browsermenu.append(new nw.MenuItem({
|
||
|
label: "Back",
|
||
|
click: function () {
|
||
|
browserwin.window.history.back();
|
||
|
}
|
||
|
}));
|
||
|
browsermenu.append(new nw.MenuItem({
|
||
|
label: "Forward",
|
||
|
click: function () {
|
||
|
browserwin.window.history.forward();
|
||
|
}
|
||
|
}));
|
||
|
browsermenu.append(new nw.MenuItem({
|
||
|
label: "Home",
|
||
|
click: function () {
|
||
|
browserwin.window.location.href = url;
|
||
|
}
|
||
|
}));
|
||
|
browserwin.menu = browsermenu;
|
||
|
});
|
||
|
}
|
||
|
}
|
||
|
|
||
|
function initBrowser() {
|
||
|
platform_type = "browser";
|
||
|
platform_theme = "aurora";
|
||
|
|
||
|
openBrowser = function (url) {
|
||
|
window.open(url);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
function initPlatform() {
|
||
|
if (typeof cordova !== 'undefined') {
|
||
|
initCordova();
|
||
|
} else if (typeof nw !== 'undefined') {
|
||
|
initNW();
|
||
|
} else {
|
||
|
initBrowser();
|
||
|
}
|
||
|
}
|