2018-10-23 01:05:09 +03:00
|
|
|
function getWindowLocationSearch(win) {
|
|
|
|
"use strict";
|
2019-02-23 16:38:53 +00:00
|
|
|
|
2018-10-23 01:05:09 +03:00
|
|
|
var search = (win || window).location.search;
|
2019-02-23 16:38:53 +00:00
|
|
|
|
2018-10-23 01:05:09 +03:00
|
|
|
if (!search) {
|
2019-02-23 16:38:53 +00:00
|
|
|
var index = window.location.href.indexOf("?");
|
|
|
|
|
|
|
|
if (-1 != index) {
|
|
|
|
search = window.location.href.substring(index);
|
|
|
|
}
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
2019-02-23 16:38:53 +00:00
|
|
|
|
|
|
|
return search || "";
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
function getParameterByName(name, url) {
|
|
|
|
"use strict";
|
2019-02-23 16:38:53 +00:00
|
|
|
|
2018-10-23 01:05:09 +03:00
|
|
|
name = name.replace(/[\[]/, "\\[").replace(/[\]]/, "\\]");
|
2019-02-23 16:38:53 +00:00
|
|
|
var regexS = "[\\?&]" + name + "=([^&#]*)";
|
|
|
|
var regex = new RegExp(regexS, "i");
|
|
|
|
var results = regex.exec(url || getWindowLocationSearch());
|
|
|
|
|
|
|
|
if (null == results) {
|
|
|
|
return "";
|
|
|
|
}
|
|
|
|
|
|
|
|
return decodeURIComponent(results[1].replace(/\+/g, " "));
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
function pageClassOn(eventName, className, fn) {
|
|
|
|
"use strict";
|
2019-02-23 16:38:53 +00:00
|
|
|
|
2019-03-04 20:38:39 +00:00
|
|
|
document.addEventListener(eventName, function (event) {
|
|
|
|
var target = event.target;
|
2019-02-23 16:38:53 +00:00
|
|
|
|
|
|
|
if (target.classList.contains(className)) {
|
2019-03-04 20:38:39 +00:00
|
|
|
fn.call(target, event);
|
2019-02-23 16:38:53 +00:00
|
|
|
}
|
|
|
|
});
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
function pageIdOn(eventName, id, fn) {
|
|
|
|
"use strict";
|
2019-02-23 16:38:53 +00:00
|
|
|
|
2019-03-04 20:38:39 +00:00
|
|
|
document.addEventListener(eventName, function (event) {
|
|
|
|
var target = event.target;
|
2019-02-23 16:38:53 +00:00
|
|
|
|
|
|
|
if (target.id === id) {
|
2019-03-04 20:38:39 +00:00
|
|
|
fn.call(target, event);
|
2019-02-23 16:38:53 +00:00
|
|
|
}
|
|
|
|
});
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
2019-02-23 16:38:53 +00:00
|
|
|
|
2018-10-23 01:05:09 +03:00
|
|
|
var Dashboard = {
|
2019-02-23 16:38:53 +00:00
|
|
|
getCurrentUser: function () {
|
|
|
|
return window.ApiClient.getCurrentUser(false);
|
|
|
|
},
|
2019-03-11 20:52:12 +00:00
|
|
|
|
|
|
|
//TODO: investigate url prefix support for serverAddress function
|
2019-02-23 16:38:53 +00:00
|
|
|
serverAddress: function () {
|
|
|
|
if (AppInfo.isNativeApp) {
|
|
|
|
var apiClient = window.ApiClient;
|
|
|
|
|
|
|
|
if (apiClient) {
|
|
|
|
return apiClient.serverAddress();
|
|
|
|
}
|
|
|
|
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
var urlLower = window.location.href.toLowerCase();
|
|
|
|
var index = urlLower.lastIndexOf("/web");
|
|
|
|
|
|
|
|
if (-1 != index) {
|
|
|
|
return urlLower.substring(0, index);
|
|
|
|
}
|
|
|
|
|
|
|
|
var loc = window.location;
|
|
|
|
var address = loc.protocol + "//" + loc.hostname;
|
|
|
|
|
|
|
|
if (loc.port) {
|
|
|
|
address += ":" + loc.port;
|
|
|
|
}
|
|
|
|
|
|
|
|
return address;
|
|
|
|
},
|
|
|
|
getCurrentUserId: function () {
|
|
|
|
var apiClient = window.ApiClient;
|
|
|
|
|
|
|
|
if (apiClient) {
|
|
|
|
return apiClient.getCurrentUserId();
|
|
|
|
}
|
|
|
|
|
|
|
|
return null;
|
|
|
|
},
|
|
|
|
onServerChanged: function (userId, accessToken, apiClient) {
|
|
|
|
apiClient = apiClient || window.ApiClient;
|
|
|
|
window.ApiClient = apiClient;
|
|
|
|
},
|
|
|
|
logout: function () {
|
|
|
|
ConnectionManager.logout().then(function () {
|
|
|
|
var loginPage;
|
|
|
|
|
2019-01-04 12:32:24 +01:00
|
|
|
if (AppInfo.isNativeApp) {
|
2019-02-23 16:38:53 +00:00
|
|
|
loginPage = "selectserver.html";
|
|
|
|
window.ApiClient = null;
|
|
|
|
} else {
|
|
|
|
loginPage = "login.html";
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
2019-02-23 16:38:53 +00:00
|
|
|
|
|
|
|
Dashboard.navigate(loginPage);
|
|
|
|
});
|
|
|
|
},
|
|
|
|
getConfigurationPageUrl: function (name) {
|
|
|
|
return "configurationpage?name=" + encodeURIComponent(name);
|
|
|
|
},
|
|
|
|
getConfigurationResourceUrl: function (name) {
|
|
|
|
if (AppInfo.isNativeApp) {
|
|
|
|
return ApiClient.getUrl("web/ConfigurationPage", {
|
2018-10-23 01:05:09 +03:00
|
|
|
name: name
|
|
|
|
});
|
2019-02-23 16:38:53 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return Dashboard.getConfigurationPageUrl(name);
|
|
|
|
},
|
|
|
|
navigate: function (url, preserveQueryString) {
|
|
|
|
if (!url) {
|
|
|
|
throw new Error("url cannot be null or empty");
|
|
|
|
}
|
|
|
|
|
|
|
|
var queryString = getWindowLocationSearch();
|
|
|
|
|
|
|
|
if (preserveQueryString && queryString) {
|
|
|
|
url += queryString;
|
|
|
|
}
|
|
|
|
|
|
|
|
return new Promise(function (resolve, reject) {
|
|
|
|
require(["appRouter"], function (appRouter) {
|
|
|
|
return appRouter.show(url).then(resolve, reject);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
},
|
|
|
|
navigate_direct: function (path) {
|
|
|
|
return new Promise(function (resolve, reject) {
|
|
|
|
require(["appRouter"], function (appRouter) {
|
|
|
|
return appRouter.showDirect(path).then(resolve, reject);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
},
|
|
|
|
processPluginConfigurationUpdateResult: function () {
|
|
|
|
require(["loading", "toast"], function (loading, toast) {
|
|
|
|
loading.hide();
|
|
|
|
toast(Globalize.translate("MessageSettingsSaved"));
|
|
|
|
});
|
|
|
|
},
|
|
|
|
processServerConfigurationUpdateResult: function (result) {
|
|
|
|
require(["loading", "toast"], function (loading, toast) {
|
|
|
|
loading.hide();
|
|
|
|
toast(Globalize.translate("MessageSettingsSaved"));
|
|
|
|
});
|
|
|
|
},
|
|
|
|
processErrorResponse: function (response) {
|
|
|
|
require(["loading"], function (loading) {
|
|
|
|
loading.hide();
|
|
|
|
});
|
|
|
|
|
|
|
|
var status = "" + response.status;
|
|
|
|
|
|
|
|
if (response.statusText) {
|
|
|
|
status = response.statusText;
|
|
|
|
}
|
|
|
|
|
|
|
|
Dashboard.alert({
|
|
|
|
title: status,
|
|
|
|
message: response.headers ? response.headers.get("X-Application-Error-Code") : null
|
|
|
|
});
|
|
|
|
},
|
|
|
|
alert: function (options) {
|
|
|
|
if ("string" == typeof options) {
|
|
|
|
return void require(["toast"], function (toast) {
|
2018-10-23 01:05:09 +03:00
|
|
|
toast({
|
|
|
|
text: options
|
2019-02-23 16:38:53 +00:00
|
|
|
});
|
2018-10-23 01:05:09 +03:00
|
|
|
});
|
2019-02-23 16:38:53 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
require(["alert"], function (alert) {
|
|
|
|
alert({
|
|
|
|
title: options.title || Globalize.translate("HeaderAlert"),
|
|
|
|
text: options.message
|
|
|
|
}).then(options.callback || function () {});
|
|
|
|
});
|
|
|
|
},
|
|
|
|
restartServer: function () {
|
|
|
|
var apiClient = window.ApiClient;
|
|
|
|
|
|
|
|
if (apiClient) {
|
|
|
|
require(["serverRestartDialog", "events"], function (ServerRestartDialog, events) {
|
2018-10-23 01:05:09 +03:00
|
|
|
var dialog = new ServerRestartDialog({
|
|
|
|
apiClient: apiClient
|
|
|
|
});
|
2019-02-23 16:38:53 +00:00
|
|
|
events.on(dialog, "restarted", function () {
|
|
|
|
if (AppInfo.isNativeApp) {
|
|
|
|
apiClient.ensureWebSocket();
|
|
|
|
} else {
|
|
|
|
window.location.reload(true);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
dialog.show();
|
|
|
|
});
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
|
|
|
},
|
2019-02-23 16:38:53 +00:00
|
|
|
capabilities: function (appHost) {
|
|
|
|
var caps = {
|
|
|
|
PlayableMediaTypes: ["Audio", "Video"],
|
|
|
|
SupportedCommands: ["MoveUp", "MoveDown", "MoveLeft", "MoveRight", "PageUp", "PageDown", "PreviousLetter", "NextLetter", "ToggleOsd", "ToggleContextMenu", "Select", "Back", "SendKey", "SendString", "GoHome", "GoToSettings", "VolumeUp", "VolumeDown", "Mute", "Unmute", "ToggleMute", "SetVolume", "SetAudioStreamIndex", "SetSubtitleStreamIndex", "DisplayContent", "GoToSearch", "DisplayMessage", "SetRepeatMode", "ChannelUp", "ChannelDown", "PlayMediaSource", "PlayTrailers"],
|
|
|
|
SupportsPersistentIdentifier: "cordova" === self.appMode || "android" === self.appMode,
|
|
|
|
SupportsMediaControl: true
|
|
|
|
};
|
|
|
|
caps.IconUrl = appHost.deviceIconUrl();
|
|
|
|
caps.SupportsSync = appHost.supports("sync");
|
|
|
|
caps.SupportsContentUploading = appHost.supports("cameraupload");
|
|
|
|
appHost.getPushTokenInfo();
|
|
|
|
return caps = Object.assign(caps, appHost.getPushTokenInfo());
|
|
|
|
}
|
|
|
|
};
|
|
|
|
var AppInfo = {};
|
|
|
|
!function () {
|
2018-10-23 01:05:09 +03:00
|
|
|
"use strict";
|
|
|
|
|
|
|
|
function onApiClientCreated(e, newApiClient) {
|
2019-02-23 16:38:53 +00:00
|
|
|
if (window.$) {
|
|
|
|
$.ajax = newApiClient.ajax;
|
|
|
|
}
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
function defineConnectionManager(connectionManager) {
|
2019-02-23 16:38:53 +00:00
|
|
|
window.ConnectionManager = connectionManager;
|
|
|
|
define("connectionManager", [], function () {
|
|
|
|
return connectionManager;
|
|
|
|
});
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
function bindConnectionManagerEvents(connectionManager, events, userSettings) {
|
2019-02-23 16:38:53 +00:00
|
|
|
window.Events = events;
|
|
|
|
events.on(ConnectionManager, "apiclientcreated", onApiClientCreated);
|
|
|
|
|
|
|
|
connectionManager.currentApiClient = function () {
|
2018-10-23 01:05:09 +03:00
|
|
|
if (!localApiClient) {
|
|
|
|
var server = connectionManager.getLastUsedServer();
|
2019-02-23 16:38:53 +00:00
|
|
|
|
|
|
|
if (server) {
|
|
|
|
localApiClient = connectionManager.getApiClient(server.Id);
|
|
|
|
}
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
2019-02-23 16:38:53 +00:00
|
|
|
|
|
|
|
return localApiClient;
|
|
|
|
};
|
|
|
|
|
|
|
|
connectionManager.onLocalUserSignedIn = function (user) {
|
|
|
|
localApiClient = connectionManager.getApiClient(user.ServerId);
|
|
|
|
window.ApiClient = localApiClient;
|
|
|
|
return userSettings.setUserInfo(user.Id, localApiClient);
|
|
|
|
};
|
|
|
|
|
|
|
|
events.on(connectionManager, "localusersignedout", function () {
|
|
|
|
userSettings.setUserInfo(null, null);
|
|
|
|
});
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
function createConnectionManager() {
|
2019-02-23 17:12:14 +00:00
|
|
|
return require(["connectionManagerFactory", "apphost", "credentialprovider", "events", "userSettings"], function (ConnectionManager, apphost, credentialProvider, events, userSettings) {
|
2019-03-04 20:30:42 +00:00
|
|
|
var credentialProviderInstance = new credentialProvider();
|
2019-03-04 20:25:42 +00:00
|
|
|
var promises = [apphost.getSyncProfile(), apphost.init()];
|
2019-02-23 16:38:53 +00:00
|
|
|
|
2019-03-17 22:24:49 +01:00
|
|
|
return Promise.all(promises).then(function (responses) {
|
2019-03-04 20:30:42 +00:00
|
|
|
var deviceProfile = responses[0];
|
|
|
|
var capabilities = Dashboard.capabilities(apphost);
|
2019-02-23 17:12:14 +00:00
|
|
|
|
|
|
|
capabilities.DeviceProfile = deviceProfile;
|
|
|
|
|
|
|
|
var connectionManager = new ConnectionManager(credentialProviderInstance, apphost.appName(), apphost.appVersion(), apphost.deviceName(), apphost.deviceId(), capabilities, window.devicePixelRatio);
|
|
|
|
|
|
|
|
defineConnectionManager(connectionManager);
|
|
|
|
bindConnectionManagerEvents(connectionManager, events, userSettings);
|
|
|
|
|
|
|
|
if (!AppInfo.isNativeApp) {
|
|
|
|
console.log("loading ApiClient singleton");
|
|
|
|
|
|
|
|
return require(["apiclient"], function (apiClientFactory) {
|
|
|
|
console.log("creating ApiClient singleton");
|
|
|
|
|
|
|
|
var apiClient = new apiClientFactory(Dashboard.serverAddress(), apphost.appName(), apphost.appVersion(), apphost.deviceName(), apphost.deviceId(), window.devicePixelRatio);
|
2019-03-17 22:24:49 +01:00
|
|
|
|
2019-02-23 17:12:14 +00:00
|
|
|
apiClient.enableAutomaticNetworking = false;
|
2019-03-04 20:27:29 +00:00
|
|
|
apiClient.manualAddressOnly = true;
|
2019-02-23 17:12:14 +00:00
|
|
|
|
|
|
|
connectionManager.addApiClient(apiClient);
|
|
|
|
|
|
|
|
window.ApiClient = apiClient;
|
|
|
|
localApiClient = apiClient;
|
|
|
|
|
|
|
|
console.log("loaded ApiClient singleton");
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
return Promise.resolve();
|
2019-01-21 17:47:10 +09:00
|
|
|
});
|
|
|
|
});
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
function returnFirstDependency(obj) {
|
2019-02-23 16:38:53 +00:00
|
|
|
return obj;
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
function getSettingsBuilder(UserSettings, layoutManager, browser) {
|
2019-01-21 17:47:10 +09:00
|
|
|
return UserSettings;
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
function getBowerPath() {
|
2019-01-21 17:47:10 +09:00
|
|
|
return "bower_components";
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
function getPlaybackManager(playbackManager) {
|
2019-03-04 20:38:39 +00:00
|
|
|
window.addEventListener("beforeunload", function () {
|
2018-10-23 01:05:09 +03:00
|
|
|
try {
|
2019-01-21 17:47:10 +09:00
|
|
|
playbackManager.onAppClose();
|
2018-10-23 01:05:09 +03:00
|
|
|
} catch (err) {
|
2019-01-21 17:47:10 +09:00
|
|
|
console.log("error in onAppClose: " + err);
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
2019-01-21 17:47:10 +09:00
|
|
|
});
|
|
|
|
return playbackManager;
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
function getLayoutManager(layoutManager, appHost) {
|
2019-01-21 17:47:10 +09:00
|
|
|
if (appHost.getDefaultLayout) {
|
|
|
|
layoutManager.defaultLayout = appHost.getDefaultLayout();
|
|
|
|
}
|
2019-02-23 16:38:53 +00:00
|
|
|
|
2019-01-21 17:47:10 +09:00
|
|
|
layoutManager.init();
|
|
|
|
return layoutManager;
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
function createWindowHeadroom(Headroom) {
|
|
|
|
var headroom = new Headroom([], {});
|
2019-01-21 17:47:10 +09:00
|
|
|
return headroom;
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
function getCastSenderApiLoader() {
|
2019-01-21 17:47:10 +09:00
|
|
|
var ccLoaded = false;
|
2018-10-23 01:05:09 +03:00
|
|
|
return {
|
2019-02-23 16:38:53 +00:00
|
|
|
load: function () {
|
|
|
|
if (ccLoaded) {
|
|
|
|
return Promise.resolve();
|
|
|
|
}
|
|
|
|
|
|
|
|
return new Promise(function (resolve, reject) {
|
2018-10-23 01:05:09 +03:00
|
|
|
var fileref = document.createElement("script");
|
2019-01-21 17:47:10 +09:00
|
|
|
fileref.setAttribute("type", "text/javascript");
|
2019-02-23 16:38:53 +00:00
|
|
|
|
|
|
|
fileref.onload = function () {
|
|
|
|
ccLoaded = true;
|
|
|
|
resolve();
|
2019-01-21 17:47:10 +09:00
|
|
|
};
|
2019-02-23 16:38:53 +00:00
|
|
|
|
2019-01-21 17:47:10 +09:00
|
|
|
fileref.setAttribute("src", "https://www.gstatic.com/cv/js/sender/v1/cast_sender.js");
|
|
|
|
document.querySelector("head").appendChild(fileref);
|
2019-02-23 16:38:53 +00:00
|
|
|
});
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
2019-02-23 16:38:53 +00:00
|
|
|
};
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
function getDummyCastSenderApiLoader() {
|
|
|
|
return {
|
2019-02-23 16:38:53 +00:00
|
|
|
load: function () {
|
|
|
|
window.chrome = window.chrome || {};
|
|
|
|
return Promise.resolve();
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
2019-02-23 16:38:53 +00:00
|
|
|
};
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
function createSharedAppFooter(appFooter) {
|
2019-01-21 17:47:10 +09:00
|
|
|
return new appFooter({});
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
function onRequireJsError(requireType, requireModules) {
|
2019-01-21 17:47:10 +09:00
|
|
|
console.log("RequireJS error: " + (requireType || "unknown") + ". Failed modules: " + (requireModules || []).join(","));
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
function defineResizeObserver() {
|
2019-02-23 16:38:53 +00:00
|
|
|
if (self.ResizeObserver) {
|
|
|
|
define("ResizeObserver", [], function () {
|
|
|
|
return self.ResizeObserver;
|
|
|
|
});
|
|
|
|
} else {
|
2019-03-22 11:56:15 -07:00
|
|
|
define("ResizeObserver", ["thirdparty/resize-observer-polyfill/ResizeObserver"], returnFirstDependency);
|
2019-02-23 16:38:53 +00:00
|
|
|
}
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
function initRequireWithBrowser(browser) {
|
2019-01-16 02:47:29 +09:00
|
|
|
var bowerPath = getBowerPath();
|
2019-02-24 20:07:41 +00:00
|
|
|
var apiClientBowerPath = bowerPath + "/apiclient";
|
2019-03-12 23:28:26 +00:00
|
|
|
var componentsPath = "components";
|
2019-01-16 02:47:29 +09:00
|
|
|
|
2019-03-16 19:19:24 +00:00
|
|
|
define("filesystem", [componentsPath + "/filesystem"], returnFirstDependency);
|
2019-02-23 16:38:53 +00:00
|
|
|
|
|
|
|
if (window.IntersectionObserver && !browser.edge) {
|
2019-03-12 23:28:26 +00:00
|
|
|
define("lazyLoader", [componentsPath + "/lazyloader/lazyloader-intersectionobserver"], returnFirstDependency);
|
2019-02-23 16:38:53 +00:00
|
|
|
} else {
|
2019-03-12 23:28:26 +00:00
|
|
|
define("lazyLoader", [componentsPath + "/lazyloader/lazyloader-scroll"], returnFirstDependency);
|
2019-02-23 16:38:53 +00:00
|
|
|
}
|
|
|
|
|
2019-03-16 18:13:26 +00:00
|
|
|
define("shell", [componentsPath + "/shell"], returnFirstDependency);
|
2019-02-23 16:38:53 +00:00
|
|
|
|
2019-02-24 20:07:41 +00:00
|
|
|
define("apiclient", ["bower_components/apiclient/apiclient"], returnFirstDependency);
|
2019-02-23 16:38:53 +00:00
|
|
|
|
|
|
|
if ("registerElement" in document) {
|
|
|
|
define("registerElement", []);
|
2019-03-04 20:36:51 +00:00
|
|
|
} else if (browser.msie) {
|
|
|
|
define("registerElement", [bowerPath + "/webcomponentsjs/webcomponents-lite.min.js"], returnFirstDependency);
|
2019-02-23 16:38:53 +00:00
|
|
|
} else {
|
2019-03-04 20:36:51 +00:00
|
|
|
define("registerElement", [bowerPath + "/document-register-element/build/document-register-element"], returnFirstDependency);
|
2019-02-23 16:38:53 +00:00
|
|
|
}
|
|
|
|
|
2019-02-28 00:36:12 +00:00
|
|
|
define("imageFetcher", [componentsPath + "/images/imageFetcher"], returnFirstDependency);
|
2019-01-16 02:47:29 +09:00
|
|
|
|
2018-10-23 01:05:09 +03:00
|
|
|
var preferNativeAlerts = browser.tv;
|
2019-02-23 16:38:53 +00:00
|
|
|
|
2019-03-12 23:28:26 +00:00
|
|
|
define("alert", [componentsPath + "/alert"], returnFirstDependency);
|
2019-02-23 16:38:53 +00:00
|
|
|
|
2019-01-16 02:47:29 +09:00
|
|
|
defineResizeObserver();
|
2019-03-12 23:28:26 +00:00
|
|
|
define("dialog", [componentsPath + "/dialog/dialog"], returnFirstDependency);
|
2019-02-23 16:38:53 +00:00
|
|
|
|
|
|
|
if (preferNativeAlerts && window.confirm) {
|
2019-03-12 23:28:26 +00:00
|
|
|
define("confirm", [componentsPath + "/confirm/nativeconfirm"], returnFirstDependency);
|
2019-02-23 16:38:53 +00:00
|
|
|
} else {
|
2019-03-12 23:28:26 +00:00
|
|
|
define("confirm", [componentsPath + "/confirm/confirm"], returnFirstDependency);
|
2019-02-23 16:38:53 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if ((preferNativeAlerts || browser.xboxOne) && window.confirm) {
|
2019-03-12 23:28:26 +00:00
|
|
|
define("prompt", [componentsPath + "/prompt/nativeprompt"], returnFirstDependency);
|
2019-02-23 16:38:53 +00:00
|
|
|
} else {
|
2019-03-12 23:28:26 +00:00
|
|
|
define("prompt", [componentsPath + "/prompt/prompt"], returnFirstDependency);
|
2019-02-23 16:38:53 +00:00
|
|
|
}
|
|
|
|
|
2019-02-28 00:32:37 +00:00
|
|
|
define("loading", [componentsPath + "/loading/loading"], returnFirstDependency);
|
2019-03-12 23:28:26 +00:00
|
|
|
define("multi-download", [componentsPath + "/multidownload"], returnFirstDependency);
|
2019-03-16 21:49:05 +00:00
|
|
|
define("fileDownloader", [componentsPath + "/filedownloader"], returnFirstDependency);
|
2019-01-16 02:47:29 +09:00
|
|
|
define("localassetmanager", [apiClientBowerPath + "/localassetmanager"], returnFirstDependency);
|
2019-02-23 16:38:53 +00:00
|
|
|
|
|
|
|
if ("cordova" === self.appMode || "android" === self.appMode) {
|
|
|
|
define("castSenderApiLoader", [], getDummyCastSenderApiLoader);
|
|
|
|
} else {
|
|
|
|
define("castSenderApiLoader", [], getCastSenderApiLoader);
|
|
|
|
}
|
|
|
|
|
2019-03-16 21:21:40 +00:00
|
|
|
define("transfermanager", [apiClientBowerPath + "/sync/transfermanager"], returnFirstDependency);
|
|
|
|
define("filerepository", [apiClientBowerPath + "/sync/filerepository"], returnFirstDependency);
|
2019-03-16 19:34:19 +00:00
|
|
|
define("localsync", [apiClientBowerPath + "/sync/localsync"], returnFirstDependency);
|
|
|
|
}
|
2018-10-23 01:05:09 +03:00
|
|
|
|
|
|
|
function init() {
|
2019-02-23 16:38:53 +00:00
|
|
|
define("livetvcss", ["css!css/livetv.css"], returnFirstDependency);
|
|
|
|
define("detailtablecss", ["css!css/detailtable.css"], returnFirstDependency);
|
|
|
|
define("buttonenabled", ["legacy/buttonenabled"], returnFirstDependency);
|
2019-02-23 17:12:14 +00:00
|
|
|
var promises = [];
|
2019-02-23 16:38:53 +00:00
|
|
|
|
2019-02-23 17:12:14 +00:00
|
|
|
Promise.all(promises).then(function () {
|
2019-02-23 16:38:53 +00:00
|
|
|
createConnectionManager().then(function () {
|
|
|
|
console.log("initAfterDependencies promises resolved");
|
|
|
|
|
|
|
|
require(["globalize", "browser"], function (globalize, browser) {
|
|
|
|
window.Globalize = globalize;
|
|
|
|
loadCoreDictionary(globalize).then(function () {
|
|
|
|
onGlobalizeInit(browser);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
function loadCoreDictionary(globalize) {
|
2019-02-03 02:31:09 +09:00
|
|
|
var languages = ["ar", "be-by", "bg-bg", "ca", "cs", "da", "de", "el", "en-gb", "en-us", "es", "es-ar", "es-mx", "fa", "fi", "fr", "fr-ca", "gsw", "he", "hi-in", "hr", "hu", "id", "it", "kk", "ko", "lt-lt", "ms", "nb", "nl", "pl", "pt-br", "pt-pt", "ro", "ru", "sk", "sl-si", "sv", "tr", "uk", "vi", "zh-cn", "zh-hk", "zh-tw"];
|
2019-03-04 20:38:39 +00:00
|
|
|
var translations = languages.map(function (language) {
|
2019-02-03 02:31:09 +09:00
|
|
|
return {
|
2019-03-04 20:38:39 +00:00
|
|
|
lang: language,
|
|
|
|
path: "strings/" + language + ".json"
|
2019-02-23 16:38:53 +00:00
|
|
|
};
|
2019-02-03 02:31:09 +09:00
|
|
|
});
|
|
|
|
globalize.defaultModule("core");
|
|
|
|
return globalize.loadStrings({
|
2018-10-23 01:05:09 +03:00
|
|
|
name: "core",
|
|
|
|
translations: translations
|
2019-02-03 02:31:09 +09:00
|
|
|
});
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
function onGlobalizeInit(browser) {
|
|
|
|
if ("android" === self.appMode) {
|
2019-02-23 16:38:53 +00:00
|
|
|
if (-1 !== self.location.href.toString().toLowerCase().indexOf("start=backgroundsync")) {
|
|
|
|
return onAppReady(browser);
|
|
|
|
}
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
2019-02-23 16:38:53 +00:00
|
|
|
|
2018-10-23 01:05:09 +03:00
|
|
|
document.title = Globalize.translateDocument(document.title, "core");
|
2019-02-23 16:38:53 +00:00
|
|
|
|
|
|
|
if (browser.tv && !browser.android) {
|
|
|
|
console.log("Using system fonts with explicit sizes");
|
2019-02-23 17:12:14 +00:00
|
|
|
require(["systemFontsSizedCss"]);
|
2019-02-23 16:38:53 +00:00
|
|
|
} else {
|
|
|
|
console.log("Using default fonts");
|
2019-02-23 17:12:14 +00:00
|
|
|
require(["systemFontsCss"]);
|
2019-02-23 16:38:53 +00:00
|
|
|
}
|
|
|
|
|
2019-02-23 17:12:14 +00:00
|
|
|
require(["apphost", "css!css/librarybrowser"], function (appHost) {
|
2019-02-23 16:38:53 +00:00
|
|
|
loadPlugins([], appHost, browser).then(function () {
|
2019-01-21 17:47:10 +09:00
|
|
|
onAppReady(browser);
|
2019-02-23 16:38:53 +00:00
|
|
|
});
|
|
|
|
});
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
function loadPlugins(externalPlugins, appHost, browser, shell) {
|
|
|
|
console.log("Loading installed plugins");
|
2019-03-04 20:40:13 +00:00
|
|
|
var list = [
|
2019-03-12 21:41:16 +00:00
|
|
|
"components/playback/playaccessvalidation",
|
|
|
|
"components/playback/experimentalwarnings",
|
|
|
|
"components/htmlaudioplayer/plugin",
|
|
|
|
"components/htmlvideoplayer/plugin",
|
|
|
|
"components/photoplayer/plugin",
|
|
|
|
"components/youtubeplayer/plugin"
|
2019-03-04 20:40:13 +00:00
|
|
|
];
|
2019-02-23 16:38:53 +00:00
|
|
|
|
2019-02-01 10:22:26 +00:00
|
|
|
if (appHost.supports("remotecontrol")) {
|
2019-02-23 18:05:42 +00:00
|
|
|
list.push("components/sessionplayer");
|
2019-02-23 16:38:53 +00:00
|
|
|
|
2019-02-01 10:22:26 +00:00
|
|
|
if (browser.chrome || browser.opera) {
|
2019-02-23 18:05:42 +00:00
|
|
|
list.push("components/chromecast/chromecastplayer");
|
2019-02-01 10:22:26 +00:00
|
|
|
}
|
|
|
|
}
|
2019-02-23 16:38:53 +00:00
|
|
|
|
2019-03-04 20:38:39 +00:00
|
|
|
for (var index = 0, length = externalPlugins.length; index < length; index++) {
|
|
|
|
list.push(externalPlugins[index]);
|
2019-02-23 16:38:53 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return new Promise(function (resolve, reject) {
|
|
|
|
Promise.all(list.map(loadPlugin)).then(function () {
|
|
|
|
require(["packageManager"], function (packageManager) {
|
|
|
|
packageManager.init().then(resolve, reject);
|
|
|
|
});
|
|
|
|
}, reject);
|
|
|
|
});
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
function loadPlugin(url) {
|
2019-02-23 16:38:53 +00:00
|
|
|
return new Promise(function (resolve, reject) {
|
|
|
|
require(["pluginManager"], function (pluginManager) {
|
|
|
|
pluginManager.loadPlugin(url).then(resolve, reject);
|
|
|
|
});
|
|
|
|
});
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
function onAppReady(browser) {
|
|
|
|
console.log("Begin onAppReady");
|
2019-02-23 16:38:53 +00:00
|
|
|
|
2019-03-09 17:35:38 +00:00
|
|
|
// ensure that appHost is loaded in this point
|
2019-03-16 15:48:53 +00:00
|
|
|
require(['apphost', 'appRouter'], function (appHost, appRouter) {
|
2019-03-09 17:35:38 +00:00
|
|
|
var isInBackground = -1 !== self.location.href.toString().toLowerCase().indexOf("start=backgroundsync");
|
2019-02-23 16:38:53 +00:00
|
|
|
|
2019-03-09 17:35:38 +00:00
|
|
|
window.Emby = {};
|
2019-02-23 16:38:53 +00:00
|
|
|
|
2019-03-09 17:35:38 +00:00
|
|
|
console.log("onAppReady - loading dependencies");
|
2019-02-23 16:38:53 +00:00
|
|
|
|
2019-03-09 17:35:38 +00:00
|
|
|
if (isInBackground) {
|
|
|
|
syncNow();
|
|
|
|
} else {
|
2019-02-23 17:12:14 +00:00
|
|
|
|
2019-03-09 17:35:38 +00:00
|
|
|
if (browser.iOS) {
|
2019-03-22 02:58:34 -07:00
|
|
|
require(['css!css/ios.css']);
|
2019-03-09 17:35:38 +00:00
|
|
|
}
|
2019-02-23 16:38:53 +00:00
|
|
|
|
2019-03-16 15:48:53 +00:00
|
|
|
window.Emby.Page = appRouter;
|
2019-02-23 16:38:53 +00:00
|
|
|
|
2019-03-16 15:48:53 +00:00
|
|
|
require(['scripts/themeloader', 'libraryMenu', 'scripts/routes'], function () {
|
2019-03-09 17:35:38 +00:00
|
|
|
Emby.Page.start({
|
|
|
|
click: false,
|
|
|
|
hashbang: true
|
|
|
|
});
|
2019-02-23 17:12:14 +00:00
|
|
|
|
2019-03-12 21:41:16 +00:00
|
|
|
require(["components/thememediaplayer", "scripts/autobackdrops"]);
|
2019-02-23 17:12:14 +00:00
|
|
|
|
2019-03-09 17:35:38 +00:00
|
|
|
if (!browser.tv && !browser.xboxOne && !browser.ps4) {
|
2019-03-12 21:41:16 +00:00
|
|
|
require(["components/nowplayingbar/nowplayingbar"]);
|
2019-02-23 16:38:53 +00:00
|
|
|
}
|
|
|
|
|
2019-03-09 17:35:38 +00:00
|
|
|
if (appHost.supports("remotecontrol")) {
|
2019-03-12 21:41:16 +00:00
|
|
|
require(["playerSelectionMenu", "components/playback/remotecontrolautoplay"]);
|
2019-03-09 17:35:38 +00:00
|
|
|
}
|
2019-02-23 16:38:53 +00:00
|
|
|
|
2019-03-14 23:40:56 +00:00
|
|
|
if (!appHost.supports("physicalvolumecontrol") || browser.touch) {
|
2019-03-12 21:41:16 +00:00
|
|
|
require(["components/playback/volumeosd"]);
|
2019-03-09 17:35:38 +00:00
|
|
|
}
|
2019-02-23 16:38:53 +00:00
|
|
|
|
2019-03-17 00:32:15 +00:00
|
|
|
require(["mediaSession", "serverNotifications"]);
|
2019-02-23 16:38:53 +00:00
|
|
|
|
2019-03-09 17:35:38 +00:00
|
|
|
if (!browser.tv && !browser.xboxOne) {
|
2019-03-12 21:41:16 +00:00
|
|
|
require(["components/playback/playbackorientation"]);
|
2019-03-09 17:35:38 +00:00
|
|
|
registerServiceWorker();
|
2019-02-23 16:38:53 +00:00
|
|
|
|
2019-03-09 17:35:38 +00:00
|
|
|
if (window.Notification) {
|
2019-03-12 21:41:16 +00:00
|
|
|
require(["components/notifications/notifications"]);
|
2019-03-09 17:35:38 +00:00
|
|
|
}
|
2019-02-23 17:12:14 +00:00
|
|
|
}
|
2019-02-23 16:38:53 +00:00
|
|
|
|
2019-02-27 22:48:30 +00:00
|
|
|
require(["playerSelectionMenu", "fullscreenManager"]);
|
2019-02-23 16:38:53 +00:00
|
|
|
|
2019-03-09 17:35:38 +00:00
|
|
|
if (appHost.supports("sync")) {
|
|
|
|
initLocalSyncEvents();
|
|
|
|
}
|
2019-02-23 16:38:53 +00:00
|
|
|
|
2019-03-09 17:35:38 +00:00
|
|
|
if (!AppInfo.isNativeApp && window.ApiClient) {
|
2019-02-23 17:12:14 +00:00
|
|
|
require(["css!" + ApiClient.getUrl("Branding/Css")]);
|
|
|
|
}
|
2019-03-09 17:35:38 +00:00
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
function registerServiceWorker() {
|
2019-02-23 16:38:53 +00:00
|
|
|
if (navigator.serviceWorker && "cordova" !== self.appMode && "android" !== self.appMode) {
|
|
|
|
try {
|
2019-03-05 18:52:53 +00:00
|
|
|
navigator.serviceWorker.register("serviceworker.js");
|
2019-02-23 16:38:53 +00:00
|
|
|
} catch (err) {
|
|
|
|
console.log("Error registering serviceWorker: " + err);
|
|
|
|
}
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function syncNow() {
|
2019-02-23 16:38:53 +00:00
|
|
|
require(["localsync"], function (localSync) {
|
|
|
|
localSync.sync();
|
|
|
|
});
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
function initLocalSyncEvents() {
|
2019-02-23 16:38:53 +00:00
|
|
|
require(["serverNotifications", "events"], function (serverNotifications, events) {
|
|
|
|
events.on(serverNotifications, "SyncJobItemReady", syncNow);
|
|
|
|
events.on(serverNotifications, "SyncJobCancelled", syncNow);
|
|
|
|
events.on(serverNotifications, "SyncJobItemCancelled", syncNow);
|
|
|
|
});
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
function onWebComponentsReady(browser) {
|
2019-02-05 03:50:16 +09:00
|
|
|
initRequireWithBrowser(browser);
|
2019-02-23 16:38:53 +00:00
|
|
|
|
2019-02-05 03:50:16 +09:00
|
|
|
if (self.appMode === 'cordova' || self.appMode === 'android' || self.appMode === 'standalone') {
|
|
|
|
AppInfo.isNativeApp = true;
|
|
|
|
}
|
2019-02-23 16:38:53 +00:00
|
|
|
|
2019-02-23 17:12:14 +00:00
|
|
|
if (!window.Promise || browser.web0s) {
|
2019-03-22 11:56:15 -07:00
|
|
|
require(["thirdparty/native-promise-only/lib/npo.src"], init);
|
2019-02-23 17:12:14 +00:00
|
|
|
} else {
|
|
|
|
init();
|
|
|
|
}
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
2019-02-05 03:50:16 +09:00
|
|
|
|
2018-10-23 01:05:09 +03:00
|
|
|
var localApiClient;
|
2019-02-23 16:38:53 +00:00
|
|
|
|
|
|
|
(function () {
|
|
|
|
var urlArgs = "v=" + (window.dashboardVersion || new Date().getDate());
|
2019-01-21 17:47:10 +09:00
|
|
|
var bowerPath = getBowerPath();
|
2019-02-24 20:07:41 +00:00
|
|
|
var apiClientBowerPath = bowerPath + "/apiclient";
|
2019-03-12 23:28:26 +00:00
|
|
|
var componentsPath = "components";
|
2019-01-21 17:47:10 +09:00
|
|
|
var paths = {
|
2019-02-23 16:38:53 +00:00
|
|
|
velocity: bowerPath + "/velocity/velocity.min",
|
|
|
|
vibrant: bowerPath + "/vibrant/dist/vibrant",
|
2019-03-12 23:28:26 +00:00
|
|
|
staticBackdrops: componentsPath + "/staticbackdrops",
|
2019-02-23 16:38:53 +00:00
|
|
|
ironCardList: "components/ironcardlist/ironcardlist",
|
|
|
|
scrollThreshold: "components/scrollthreshold",
|
|
|
|
playlisteditor: "components/playlisteditor/playlisteditor",
|
|
|
|
medialibrarycreator: "components/medialibrarycreator/medialibrarycreator",
|
|
|
|
medialibraryeditor: "components/medialibraryeditor/medialibraryeditor",
|
|
|
|
imageoptionseditor: "components/imageoptionseditor/imageoptionseditor",
|
|
|
|
howler: bowerPath + "/howlerjs/dist/howler.min",
|
|
|
|
sortable: bowerPath + "/Sortable/Sortable.min",
|
|
|
|
isMobile: bowerPath + "/isMobile/isMobile.min",
|
|
|
|
masonry: bowerPath + "/masonry/dist/masonry.pkgd.min",
|
|
|
|
humanedate: "components/humanedate",
|
|
|
|
libraryBrowser: "scripts/librarybrowser",
|
|
|
|
events: apiClientBowerPath + "/events",
|
|
|
|
credentialprovider: apiClientBowerPath + "/credentials",
|
2019-02-24 20:07:41 +00:00
|
|
|
connectionManagerFactory: bowerPath + "/apiclient/connectionmanager",
|
2019-03-12 23:28:26 +00:00
|
|
|
visibleinviewport: componentsPath + "/visibleinviewport",
|
|
|
|
browserdeviceprofile: componentsPath + "/browserdeviceprofile",
|
|
|
|
browser: componentsPath + "/browser",
|
|
|
|
inputManager: componentsPath + "/inputmanager",
|
|
|
|
qualityoptions: componentsPath + "/qualityoptions",
|
2019-02-23 16:38:53 +00:00
|
|
|
hammer: bowerPath + "/hammerjs/hammer.min",
|
2019-02-28 00:32:37 +00:00
|
|
|
page: "thirdparty/page",
|
2019-03-12 23:28:26 +00:00
|
|
|
focusManager: componentsPath + "/focusmanager",
|
|
|
|
datetime: componentsPath + "/datetime",
|
|
|
|
globalize: componentsPath + "/globalize",
|
|
|
|
itemHelper: componentsPath + "/itemhelper",
|
|
|
|
itemShortcuts: componentsPath + "/shortcuts",
|
|
|
|
playQueueManager: componentsPath + "/playback/playqueuemanager",
|
2019-02-27 00:20:20 +00:00
|
|
|
autoPlayDetect: componentsPath + "/playback/autoPlayDetect",
|
2019-03-12 23:28:26 +00:00
|
|
|
nowPlayingHelper: componentsPath + "/playback/nowplayinghelper",
|
|
|
|
pluginManager: componentsPath + "/pluginmanager",
|
|
|
|
packageManager: componentsPath + "/packagemanager"
|
2019-01-21 17:47:10 +09:00
|
|
|
};
|
|
|
|
paths.hlsjs = bowerPath + "/hlsjs/dist/hls.min";
|
2019-03-22 11:56:15 -07:00
|
|
|
paths.flvjs = "thirdparty/flvjs/flv.min";
|
|
|
|
paths.shaka = "thirdparty/shaka/shaka-player.compiled";
|
2019-03-12 23:28:26 +00:00
|
|
|
define("chromecastHelper", [componentsPath + "/chromecast/chromecasthelpers"], returnFirstDependency);
|
|
|
|
define("mediaSession", [componentsPath + "/playback/mediasession"], returnFirstDependency);
|
|
|
|
define("actionsheet", [componentsPath + "/actionsheet/actionsheet"], returnFirstDependency);
|
2019-01-21 17:47:10 +09:00
|
|
|
define("libjass", [bowerPath + "/libjass/libjass.min", "css!" + bowerPath + "/libjass/libjass"], returnFirstDependency);
|
|
|
|
define("tunerPicker", ["components/tunerpicker"], returnFirstDependency);
|
2019-03-12 23:28:26 +00:00
|
|
|
define("mainTabsManager", [componentsPath + "/maintabsmanager"], returnFirstDependency);
|
2019-02-28 00:36:12 +00:00
|
|
|
define("imageLoader", [componentsPath + "/images/imageLoader"], returnFirstDependency);
|
2019-03-12 23:28:26 +00:00
|
|
|
define("appFooter", [componentsPath + "/appfooter/appfooter"], returnFirstDependency);
|
2019-01-21 17:47:10 +09:00
|
|
|
define("directorybrowser", ["components/directorybrowser/directorybrowser"], returnFirstDependency);
|
2019-03-12 23:28:26 +00:00
|
|
|
define("metadataEditor", [componentsPath + "/metadataeditor/metadataeditor"], returnFirstDependency);
|
|
|
|
define("personEditor", [componentsPath + "/metadataeditor/personeditor"], returnFirstDependency);
|
2019-02-28 00:32:37 +00:00
|
|
|
define("playerSelectionMenu", [componentsPath + "/playback/playerSelectionMenu"], returnFirstDependency);
|
2019-03-12 23:28:26 +00:00
|
|
|
define("playerSettingsMenu", [componentsPath + "/playback/playersettingsmenu"], returnFirstDependency);
|
|
|
|
define("playMethodHelper", [componentsPath + "/playback/playmethodhelper"], returnFirstDependency);
|
|
|
|
define("brightnessOsd", [componentsPath + "/playback/brightnessosd"], returnFirstDependency);
|
2019-01-21 17:47:10 +09:00
|
|
|
define("libraryMenu", ["scripts/librarymenu"], returnFirstDependency);
|
2019-03-12 23:28:26 +00:00
|
|
|
define("emby-collapse", [componentsPath + "/emby-collapse/emby-collapse"], returnFirstDependency);
|
|
|
|
define("emby-button", [componentsPath + "/emby-button/emby-button"], returnFirstDependency);
|
|
|
|
define("emby-itemscontainer", [componentsPath + "/emby-itemscontainer/emby-itemscontainer"], returnFirstDependency);
|
|
|
|
define("alphaNumericShortcuts", [componentsPath + "/alphanumericshortcuts/alphanumericshortcuts"], returnFirstDependency);
|
|
|
|
define("emby-scroller", [componentsPath + "/emby-scroller/emby-scroller"], returnFirstDependency);
|
|
|
|
define("emby-tabs", [componentsPath + "/emby-tabs/emby-tabs"], returnFirstDependency);
|
|
|
|
define("emby-scrollbuttons", [componentsPath + "/emby-scrollbuttons/emby-scrollbuttons"], returnFirstDependency);
|
|
|
|
define("emby-progressring", [componentsPath + "/emby-progressring/emby-progressring"], returnFirstDependency);
|
|
|
|
define("emby-itemrefreshindicator", [componentsPath + "/emby-itemrefreshindicator/emby-itemrefreshindicator"], returnFirstDependency);
|
|
|
|
define("multiSelect", [componentsPath + "/multiselect/multiselect"], returnFirstDependency);
|
|
|
|
define("alphaPicker", [componentsPath + "/alphapicker/alphapicker"], returnFirstDependency);
|
|
|
|
define("paper-icon-button-light", [componentsPath + "/emby-button/paper-icon-button-light"], returnFirstDependency);
|
|
|
|
define("tabbedView", [componentsPath + "/tabbedview/tabbedview"], returnFirstDependency);
|
|
|
|
define("itemsTab", [componentsPath + "/tabbedview/itemstab"], returnFirstDependency);
|
|
|
|
define("emby-input", [componentsPath + "/emby-input/emby-input"], returnFirstDependency);
|
|
|
|
define("emby-select", [componentsPath + "/emby-select/emby-select"], returnFirstDependency);
|
|
|
|
define("emby-slider", [componentsPath + "/emby-slider/emby-slider"], returnFirstDependency);
|
|
|
|
define("emby-checkbox", [componentsPath + "/emby-checkbox/emby-checkbox"], returnFirstDependency);
|
|
|
|
define("emby-toggle", [componentsPath + "/emby-toggle/emby-toggle"], returnFirstDependency);
|
|
|
|
define("emby-radio", [componentsPath + "/emby-radio/emby-radio"], returnFirstDependency);
|
|
|
|
define("emby-textarea", [componentsPath + "/emby-textarea/emby-textarea"], returnFirstDependency);
|
|
|
|
define("collectionEditor", [componentsPath + "/collectioneditor/collectioneditor"], returnFirstDependency);
|
2019-02-28 00:01:07 +00:00
|
|
|
define("serverRestartDialog", [componentsPath + "/serverRestartDialog"], returnFirstDependency);
|
2019-03-12 23:28:26 +00:00
|
|
|
define("playlistEditor", [componentsPath + "/playlisteditor/playlisteditor"], returnFirstDependency);
|
|
|
|
define("recordingCreator", [componentsPath + "/recordingcreator/recordingcreator"], returnFirstDependency);
|
|
|
|
define("recordingEditor", [componentsPath + "/recordingcreator/recordingeditor"], returnFirstDependency);
|
|
|
|
define("seriesRecordingEditor", [componentsPath + "/recordingcreator/seriesrecordingeditor"], returnFirstDependency);
|
|
|
|
define("recordingFields", [componentsPath + "/recordingcreator/recordingfields"], returnFirstDependency);
|
|
|
|
define("recordingButton", [componentsPath + "/recordingcreator/recordingbutton"], returnFirstDependency);
|
|
|
|
define("recordingHelper", [componentsPath + "/recordingcreator/recordinghelper"], returnFirstDependency);
|
|
|
|
define("subtitleEditor", [componentsPath + "/subtitleeditor/subtitleeditor"], returnFirstDependency);
|
|
|
|
define("itemIdentifier", [componentsPath + "/itemidentifier/itemidentifier"], returnFirstDependency);
|
|
|
|
define("mediaInfo", [componentsPath + "/mediainfo/mediainfo"], returnFirstDependency);
|
|
|
|
define("itemContextMenu", [componentsPath + "/itemcontextmenu"], returnFirstDependency);
|
|
|
|
define("imageEditor", [componentsPath + "/imageeditor/imageeditor"], returnFirstDependency);
|
|
|
|
define("imageDownloader", [componentsPath + "/imagedownloader/imagedownloader"], returnFirstDependency);
|
|
|
|
define("dom", [componentsPath + "/dom"], returnFirstDependency);
|
|
|
|
define("playerStats", [componentsPath + "/playerstats/playerstats"], returnFirstDependency);
|
|
|
|
define("searchFields", [componentsPath + "/search/searchfields"], returnFirstDependency);
|
|
|
|
define("searchResults", [componentsPath + "/search/searchresults"], returnFirstDependency);
|
|
|
|
define("upNextDialog", [componentsPath + "/upnextdialog/upnextdialog"], returnFirstDependency);
|
|
|
|
define("fullscreen-doubleclick", [componentsPath + "/fullscreen/fullscreen-dc"], returnFirstDependency);
|
2019-02-27 22:48:30 +00:00
|
|
|
define("fullscreenManager", [componentsPath + "/fullscreenManager", "events"], returnFirstDependency);
|
2019-03-12 23:28:26 +00:00
|
|
|
define("headroom", [componentsPath + "/headroom/headroom"], returnFirstDependency);
|
|
|
|
define("subtitleAppearanceHelper", [componentsPath + "/subtitlesettings/subtitleappearancehelper"], returnFirstDependency);
|
|
|
|
define("subtitleSettings", [componentsPath + "/subtitlesettings/subtitlesettings"], returnFirstDependency);
|
|
|
|
define("displaySettings", [componentsPath + "/displaysettings/displaysettings"], returnFirstDependency);
|
|
|
|
define("playbackSettings", [componentsPath + "/playbacksettings/playbacksettings"], returnFirstDependency);
|
|
|
|
define("homescreenSettings", [componentsPath + "/homescreensettings/homescreensettings"], returnFirstDependency);
|
|
|
|
define("homescreenSettingsDialog", [componentsPath + "/homescreensettings/homescreensettingsdialog"], returnFirstDependency);
|
|
|
|
define("playbackManager", [componentsPath + "/playback/playbackmanager"], getPlaybackManager);
|
|
|
|
define("layoutManager", [componentsPath + "/layoutmanager", "apphost"], getLayoutManager);
|
|
|
|
define("homeSections", [componentsPath + "/homesections/homesections"], returnFirstDependency);
|
|
|
|
define("playMenu", [componentsPath + "/playmenu"], returnFirstDependency);
|
|
|
|
define("refreshDialog", [componentsPath + "/refreshdialog/refreshdialog"], returnFirstDependency);
|
|
|
|
define("backdrop", [componentsPath + "/backdrop/backdrop"], returnFirstDependency);
|
|
|
|
define("fetchHelper", [componentsPath + "/fetchhelper"], returnFirstDependency);
|
|
|
|
define("roundCardStyle", ["cardStyle", "css!" + componentsPath + "/cardbuilder/roundcard"], returnFirstDependency);
|
|
|
|
define("cardStyle", ["css!" + componentsPath + "/cardbuilder/card"], returnFirstDependency);
|
|
|
|
define("cardBuilder", [componentsPath + "/cardbuilder/cardbuilder"], returnFirstDependency);
|
|
|
|
define("peoplecardbuilder", [componentsPath + "/cardbuilder/peoplecardbuilder"], returnFirstDependency);
|
|
|
|
define("chaptercardbuilder", [componentsPath + "/cardbuilder/chaptercardbuilder"], returnFirstDependency);
|
|
|
|
define("flexStyles", ["css!" + componentsPath + "/flexstyles"], returnFirstDependency);
|
|
|
|
define("deleteHelper", [componentsPath + "/deletehelper"], returnFirstDependency);
|
|
|
|
define("tvguide", [componentsPath + "/guide/guide"], returnFirstDependency);
|
|
|
|
define("programStyles", ["css!" + componentsPath + "/guide/programs"], returnFirstDependency);
|
|
|
|
define("guide-settings-dialog", [componentsPath + "/guide/guide-settings"], returnFirstDependency);
|
|
|
|
define("loadingDialog", [componentsPath + "/loadingdialog/loadingdialog"], returnFirstDependency);
|
2019-02-27 23:26:11 +00:00
|
|
|
define("viewManager", [componentsPath + "/viewManager/viewManager"], function (viewManager) {
|
2019-02-23 16:38:53 +00:00
|
|
|
window.ViewManager = viewManager;
|
|
|
|
viewManager.dispatchPageEvents(true);
|
|
|
|
return viewManager;
|
2019-01-21 17:47:10 +09:00
|
|
|
});
|
|
|
|
|
2019-03-17 23:23:59 +00:00
|
|
|
paths.apphost = "components/apphost";
|
2019-02-26 23:28:16 +00:00
|
|
|
define('appStorage', [apiClientBowerPath + '/appStorage'], returnFirstDependency);
|
2019-03-21 21:46:55 +00:00
|
|
|
|
2019-02-23 16:38:53 +00:00
|
|
|
requirejs.config({
|
2018-10-23 01:05:09 +03:00
|
|
|
waitSeconds: 0,
|
|
|
|
map: {
|
|
|
|
"*": {
|
2019-02-23 18:05:42 +00:00
|
|
|
css: "components/require/requirecss",
|
|
|
|
text: "components/require/requiretext"
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
|
|
|
},
|
|
|
|
urlArgs: urlArgs,
|
|
|
|
paths: paths,
|
|
|
|
onError: onRequireJsError
|
2019-01-21 17:47:10 +09:00
|
|
|
});
|
|
|
|
requirejs.onError = onRequireJsError;
|
|
|
|
define("jstree", ["thirdparty/jstree/jstree", "css!thirdparty/jstree/themes/default/style.css"], returnFirstDependency);
|
|
|
|
define("dashboardcss", ["css!css/dashboard"], returnFirstDependency);
|
2019-03-12 23:28:26 +00:00
|
|
|
define("slideshow", [componentsPath + "/slideshow/slideshow"], returnFirstDependency);
|
|
|
|
define("clearButtonStyle", ["css!" + componentsPath + "/clearbutton"], returnFirstDependency);
|
|
|
|
define("userdataButtons", [componentsPath + "/userdatabuttons/userdatabuttons"], returnFirstDependency);
|
|
|
|
define("emby-playstatebutton", [componentsPath + "/userdatabuttons/emby-playstatebutton"], returnFirstDependency);
|
|
|
|
define("emby-ratingbutton", [componentsPath + "/userdatabuttons/emby-ratingbutton"], returnFirstDependency);
|
|
|
|
define("listView", [componentsPath + "/listview/listview"], returnFirstDependency);
|
|
|
|
define("listViewStyle", ["css!" + componentsPath + "/listview/listview"], returnFirstDependency);
|
|
|
|
define("formDialogStyle", ["css!" + componentsPath + "/formdialog"], returnFirstDependency);
|
|
|
|
define("indicators", [componentsPath + "/indicators/indicators"], returnFirstDependency);
|
|
|
|
define("viewSettings", [componentsPath + "/viewsettings/viewsettings"], returnFirstDependency);
|
|
|
|
define("filterMenu", [componentsPath + "/filtermenu/filtermenu"], returnFirstDependency);
|
|
|
|
define("sortMenu", [componentsPath + "/sortmenu/sortmenu"], returnFirstDependency);
|
2019-01-21 17:47:10 +09:00
|
|
|
define("connectionmanager", [apiClientBowerPath + "/connectionmanager"]);
|
|
|
|
define("serversync", [apiClientBowerPath + "/sync/serversync"], returnFirstDependency);
|
|
|
|
define("multiserversync", [apiClientBowerPath + "/sync/multiserversync"], returnFirstDependency);
|
|
|
|
define("mediasync", [apiClientBowerPath + "/sync/mediasync"], returnFirstDependency);
|
2019-03-12 23:28:26 +00:00
|
|
|
define("idb", [componentsPath + "/idb"], returnFirstDependency);
|
|
|
|
define("sanitizefilename", [componentsPath + "/sanitizefilename"], returnFirstDependency);
|
2019-01-21 17:47:10 +09:00
|
|
|
define("itemrepository", [apiClientBowerPath + "/sync/itemrepository"], returnFirstDependency);
|
|
|
|
define("useractionrepository", [apiClientBowerPath + "/sync/useractionrepository"], returnFirstDependency);
|
|
|
|
define("swiper", [bowerPath + "/Swiper/dist/js/swiper.min", "css!" + bowerPath + "/Swiper/dist/css/swiper.min"], returnFirstDependency);
|
2019-02-28 00:10:39 +00:00
|
|
|
define("scroller", [componentsPath + "/scroller"], returnFirstDependency);
|
2019-03-12 23:28:26 +00:00
|
|
|
define("toast", [componentsPath + "/toast/toast"], returnFirstDependency);
|
|
|
|
define("scrollHelper", [componentsPath + "/scrollhelper"], returnFirstDependency);
|
|
|
|
define("touchHelper", [componentsPath + "/touchhelper"], returnFirstDependency);
|
|
|
|
define("appSettings", [componentsPath + "/appsettings"], returnFirstDependency);
|
|
|
|
define("userSettings", [componentsPath + "/usersettings/usersettings"], returnFirstDependency);
|
|
|
|
define("userSettingsBuilder", [componentsPath + "/usersettings/usersettingsbuilder", "layoutManager", "browser"], getSettingsBuilder);
|
2019-03-22 11:56:15 -07:00
|
|
|
define("material-icons", ["css!css/material-icons/style"], returnFirstDependency);
|
|
|
|
define("systemFontsCss", ["css!css/fonts"], returnFirstDependency);
|
|
|
|
define("systemFontsSizedCss", ["css!css/fonts.sized"], returnFirstDependency);
|
2019-03-12 23:28:26 +00:00
|
|
|
define("scrollStyles", ["css!" + componentsPath + "/scrollstyles"], returnFirstDependency);
|
|
|
|
define("imageUploader", [componentsPath + "/imageuploader/imageuploader"], returnFirstDependency);
|
2019-01-21 17:47:10 +09:00
|
|
|
define("navdrawer", ["components/navdrawer/navdrawer"], returnFirstDependency);
|
2019-03-12 23:28:26 +00:00
|
|
|
define("htmlMediaHelper", [componentsPath + "/htmlvideoplayer/htmlmediahelper"], returnFirstDependency);
|
2019-02-27 23:29:13 +00:00
|
|
|
define("viewcontainer", ["components/viewContainer"], returnFirstDependency);
|
2019-02-23 16:38:53 +00:00
|
|
|
define("queryString", [bowerPath + "/query-string/index"], function () {
|
|
|
|
return queryString;
|
2019-01-21 17:47:10 +09:00
|
|
|
});
|
2019-02-23 16:38:53 +00:00
|
|
|
define("jQuery", [bowerPath + "/jquery/dist/jquery.slim.min"], function () {
|
|
|
|
if (window.ApiClient) {
|
|
|
|
jQuery.ajax = ApiClient.ajax;
|
|
|
|
}
|
|
|
|
|
|
|
|
return jQuery;
|
2019-01-21 17:47:10 +09:00
|
|
|
});
|
|
|
|
define("fnchecked", ["legacy/fnchecked"], returnFirstDependency);
|
2019-02-27 22:26:23 +00:00
|
|
|
define("dialogHelper", [componentsPath + "/dialogHelper/dialogHelper"], returnFirstDependency);
|
2019-01-21 17:47:10 +09:00
|
|
|
define("inputmanager", ["inputManager"], returnFirstDependency);
|
2019-02-28 00:06:23 +00:00
|
|
|
define("serverNotifications", [componentsPath + "/serverNotifications/serverNotifications"], returnFirstDependency);
|
2019-01-21 17:47:10 +09:00
|
|
|
define("appFooter-shared", ["appFooter"], createSharedAppFooter);
|
2019-02-24 23:44:41 +00:00
|
|
|
define("skinManager", [componentsPath + "/skinManager"], returnFirstDependency);
|
2019-02-23 16:38:53 +00:00
|
|
|
define("connectionManager", [], function () {
|
|
|
|
return ConnectionManager;
|
2019-01-21 17:47:10 +09:00
|
|
|
});
|
2019-02-23 16:38:53 +00:00
|
|
|
define("apiClientResolver", [], function () {
|
|
|
|
return function () {
|
|
|
|
return window.ApiClient;
|
|
|
|
};
|
2019-01-21 17:47:10 +09:00
|
|
|
});
|
2019-02-24 20:07:41 +00:00
|
|
|
define("appRouter", [componentsPath + "/appRouter", "itemHelper"], function (appRouter, itemHelper) {
|
2018-10-23 01:05:09 +03:00
|
|
|
function showItem(item, serverId, options) {
|
2019-02-23 16:38:53 +00:00
|
|
|
if ("string" == typeof item) {
|
|
|
|
require(["connectionManager"], function (connectionManager) {
|
|
|
|
var apiClient = connectionManager.currentApiClient();
|
|
|
|
apiClient.getItem(apiClient.getCurrentUserId(), item).then(function (item) {
|
|
|
|
appRouter.showItem(item, options);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
} else {
|
|
|
|
if (2 == arguments.length) {
|
|
|
|
options = arguments[1];
|
|
|
|
}
|
|
|
|
|
|
|
|
appRouter.show("/" + appRouter.getRouteUrl(item, options), {
|
|
|
|
item: item
|
|
|
|
});
|
|
|
|
}
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
2019-02-23 16:38:53 +00:00
|
|
|
|
|
|
|
appRouter.showLocalLogin = function (serverId, manualLogin) {
|
|
|
|
Dashboard.navigate("login.html?serverid=" + serverId);
|
|
|
|
};
|
|
|
|
|
|
|
|
appRouter.showVideoOsd = function () {
|
|
|
|
return Dashboard.navigate("videoosd.html");
|
|
|
|
};
|
|
|
|
|
|
|
|
appRouter.showSelectServer = function () {
|
|
|
|
Dashboard.navigate(AppInfo.isNativeApp ? "selectserver.html" : "login.html");
|
|
|
|
};
|
|
|
|
|
|
|
|
appRouter.showWelcome = function () {
|
|
|
|
Dashboard.navigate(AppInfo.isNativeApp ? "selectserver.html" : "login.html");
|
|
|
|
};
|
|
|
|
|
|
|
|
appRouter.showSettings = function () {
|
|
|
|
Dashboard.navigate("mypreferencesmenu.html");
|
|
|
|
};
|
|
|
|
|
|
|
|
appRouter.showGuide = function () {
|
|
|
|
Dashboard.navigate("livetv.html?tab=1");
|
|
|
|
};
|
|
|
|
|
|
|
|
appRouter.goHome = function () {
|
|
|
|
Dashboard.navigate("home.html");
|
|
|
|
};
|
|
|
|
|
|
|
|
appRouter.showSearch = function () {
|
|
|
|
Dashboard.navigate("search.html");
|
|
|
|
};
|
|
|
|
|
|
|
|
appRouter.showLiveTV = function () {
|
|
|
|
Dashboard.navigate("livetv.html");
|
|
|
|
};
|
|
|
|
|
|
|
|
appRouter.showRecordedTV = function () {
|
|
|
|
Dashboard.navigate("livetv.html?tab=3");
|
|
|
|
};
|
|
|
|
|
|
|
|
appRouter.showFavorites = function () {
|
|
|
|
Dashboard.navigate("home.html?tab=1");
|
|
|
|
};
|
|
|
|
|
|
|
|
appRouter.showSettings = function () {
|
|
|
|
Dashboard.navigate("mypreferencesmenu.html");
|
|
|
|
};
|
|
|
|
|
|
|
|
appRouter.showNowPlaying = function () {
|
|
|
|
Dashboard.navigate("nowplaying.html");
|
|
|
|
};
|
|
|
|
|
|
|
|
appRouter.setTitle = function (title) {
|
|
|
|
LibraryMenu.setTitle(title);
|
|
|
|
};
|
|
|
|
|
|
|
|
appRouter.getRouteUrl = function (item, options) {
|
|
|
|
if (!item) {
|
|
|
|
throw new Error("item cannot be null");
|
|
|
|
}
|
|
|
|
|
|
|
|
if (item.url) {
|
|
|
|
return item.url;
|
|
|
|
}
|
|
|
|
|
|
|
|
var context = options ? options.context : null;
|
|
|
|
var id = item.Id || item.ItemId;
|
|
|
|
|
|
|
|
if (!options) {
|
|
|
|
options = {};
|
|
|
|
}
|
|
|
|
|
|
|
|
var url;
|
|
|
|
var itemType = item.Type || (options ? options.itemType : null);
|
|
|
|
var serverId = item.ServerId || options.serverId;
|
|
|
|
|
|
|
|
if ("settings" === item) {
|
|
|
|
return "mypreferencesmenu.html";
|
|
|
|
}
|
|
|
|
|
|
|
|
if ("wizard" === item) {
|
|
|
|
return "wizardstart.html";
|
|
|
|
}
|
|
|
|
|
|
|
|
if ("manageserver" === item) {
|
|
|
|
return "dashboard.html";
|
|
|
|
}
|
|
|
|
|
|
|
|
if ("recordedtv" === item) {
|
|
|
|
return "livetv.html?tab=3&serverId=" + options.serverId;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ("nextup" === item) {
|
|
|
|
return "list/list.html?type=nextup&serverId=" + options.serverId;
|
|
|
|
}
|
|
|
|
|
2018-10-23 01:05:09 +03:00
|
|
|
if ("list" === item) {
|
|
|
|
var url = "list/list.html?serverId=" + options.serverId + "&type=" + options.itemTypes;
|
2019-02-23 16:38:53 +00:00
|
|
|
|
|
|
|
if (options.isFavorite) {
|
|
|
|
url += "&IsFavorite=true";
|
|
|
|
}
|
|
|
|
|
|
|
|
return url;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ("livetv" === item) {
|
|
|
|
if ("guide" === options.section) {
|
|
|
|
return "livetv.html?tab=1&serverId=" + options.serverId;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ("movies" === options.section) {
|
|
|
|
return "list/list.html?type=Programs&IsMovie=true&serverId=" + options.serverId;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ("shows" === options.section) {
|
|
|
|
return "list/list.html?type=Programs&IsSeries=true&IsMovie=false&IsNews=false&serverId=" + options.serverId;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ("sports" === options.section) {
|
|
|
|
return "list/list.html?type=Programs&IsSports=true&serverId=" + options.serverId;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ("kids" === options.section) {
|
|
|
|
return "list/list.html?type=Programs&IsKids=true&serverId=" + options.serverId;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ("news" === options.section) {
|
|
|
|
return "list/list.html?type=Programs&IsNews=true&serverId=" + options.serverId;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ("onnow" === options.section) {
|
|
|
|
return "list/list.html?type=Programs&IsAiring=true&serverId=" + options.serverId;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ("dvrschedule" === options.section) {
|
|
|
|
return "livetv.html?tab=4&serverId=" + options.serverId;
|
|
|
|
}
|
|
|
|
|
|
|
|
return "livetv.html?serverId=" + options.serverId;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ("SeriesTimer" == itemType) {
|
|
|
|
return "itemdetails.html?seriesTimerId=" + id + "&serverId=" + serverId;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ("livetv" == item.CollectionType) {
|
|
|
|
return "livetv.html";
|
|
|
|
}
|
|
|
|
|
|
|
|
if ("Genre" === item.Type) {
|
|
|
|
url = "list/list.html?genreId=" + item.Id + "&serverId=" + serverId;
|
|
|
|
|
|
|
|
if ("livetv" === context) {
|
|
|
|
url += "&type=Programs";
|
|
|
|
}
|
|
|
|
|
|
|
|
if (options.parentId) {
|
|
|
|
url += "&parentId=" + options.parentId;
|
|
|
|
}
|
|
|
|
|
|
|
|
return url;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ("MusicGenre" === item.Type) {
|
|
|
|
url = "list/list.html?musicGenreId=" + item.Id + "&serverId=" + serverId;
|
|
|
|
|
|
|
|
if (options.parentId) {
|
|
|
|
url += "&parentId=" + options.parentId;
|
|
|
|
}
|
|
|
|
|
|
|
|
return url;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ("Studio" === item.Type) {
|
|
|
|
url = "list/list.html?studioId=" + item.Id + "&serverId=" + serverId;
|
|
|
|
|
|
|
|
if (options.parentId) {
|
|
|
|
url += "&parentId=" + options.parentId;
|
|
|
|
}
|
|
|
|
|
|
|
|
return url;
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
2019-02-23 16:38:53 +00:00
|
|
|
|
2018-10-23 01:05:09 +03:00
|
|
|
if ("folders" !== context && !itemHelper.isLocalItem(item)) {
|
2019-02-23 16:38:53 +00:00
|
|
|
if ("movies" == item.CollectionType) {
|
|
|
|
url = "movies.html?topParentId=" + item.Id;
|
|
|
|
|
|
|
|
if (options && "latest" === options.section) {
|
|
|
|
url += "&tab=1";
|
|
|
|
}
|
|
|
|
|
|
|
|
return url;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ("tvshows" == item.CollectionType) {
|
|
|
|
url = "tv.html?topParentId=" + item.Id;
|
|
|
|
|
|
|
|
if (options && "latest" === options.section) {
|
|
|
|
url += "&tab=2";
|
|
|
|
}
|
|
|
|
|
|
|
|
return url;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ("music" == item.CollectionType) {
|
|
|
|
return "music.html?topParentId=" + item.Id;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-03-05 19:10:03 +00:00
|
|
|
var itemTypes = ["Playlist", "TvChannel", "Program", "BoxSet", "MusicAlbum", "MusicGenre", "Person", "Recording", "MusicArtist"];
|
2019-02-23 16:38:53 +00:00
|
|
|
|
2019-03-05 19:10:03 +00:00
|
|
|
if (itemTypes.indexOf(itemType) >= 0) {
|
2019-02-23 16:38:53 +00:00
|
|
|
return "itemdetails.html?id=" + id + "&serverId=" + serverId;
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
2019-02-23 16:38:53 +00:00
|
|
|
|
2018-10-23 01:05:09 +03:00
|
|
|
var contextSuffix = context ? "&context=" + context : "";
|
2019-01-21 17:47:10 +09:00
|
|
|
|
2019-02-23 16:38:53 +00:00
|
|
|
if ("Series" == itemType || "Season" == itemType || "Episode" == itemType) {
|
|
|
|
return "itemdetails.html?id=" + id + contextSuffix + "&serverId=" + serverId;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (item.IsFolder) {
|
|
|
|
if (id) {
|
|
|
|
return "list/list.html?parentId=" + id + "&serverId=" + serverId;
|
|
|
|
}
|
|
|
|
|
|
|
|
return "#";
|
|
|
|
}
|
|
|
|
|
|
|
|
return "itemdetails.html?id=" + id + "&serverId=" + serverId;
|
|
|
|
};
|
|
|
|
|
|
|
|
appRouter.showItem = showItem;
|
|
|
|
return appRouter;
|
|
|
|
});
|
|
|
|
})();
|
|
|
|
|
|
|
|
require(["css!css/site"]);
|
|
|
|
|
|
|
|
return require(["browser"], onWebComponentsReady);
|
|
|
|
}();
|
|
|
|
pageClassOn("viewshow", "standalonePage", function () {
|
2019-01-21 17:47:10 +09:00
|
|
|
document.querySelector(".skinHeader").classList.add("noHeaderRight");
|
|
|
|
});
|
2019-02-23 16:38:53 +00:00
|
|
|
pageClassOn("viewhide", "standalonePage", function () {
|
2019-01-21 17:47:10 +09:00
|
|
|
document.querySelector(".skinHeader").classList.remove("noHeaderRight");
|
2018-12-11 00:46:50 -05:00
|
|
|
});
|