1
0
Fork 0
mirror of https://github.com/jellyfin/jellyfin-web synced 2025-03-30 19:56:21 +00:00
jellyfin-web/src/scripts/site.js

1141 lines
47 KiB
JavaScript
Raw Normal View History

2018-10-23 01:05:09 +03:00
function getWindowLocationSearch(win) {
2020-05-04 12:44:12 +02:00
'use strict';
2018-10-23 01:05:09 +03:00
var search = (win || window).location.search;
2018-10-23 01:05:09 +03:00
if (!search) {
2020-05-04 12:44:12 +02:00
var index = window.location.href.indexOf('?');
if (-1 != index) {
search = window.location.href.substring(index);
}
2018-10-23 01:05:09 +03:00
}
2020-05-04 12:44:12 +02:00
return search || '';
2018-10-23 01:05:09 +03:00
}
function getParameterByName(name, url) {
2020-05-04 12:44:12 +02:00
'use strict';
2020-05-04 12:44:12 +02:00
name = name.replace(/[\[]/, '\\[').replace(/[\]]/, '\\]');
var regexS = '[\\?&]' + name + '=([^&#]*)';
var regex = new RegExp(regexS, 'i');
var results = regex.exec(url || getWindowLocationSearch());
if (null == results) {
2020-05-04 12:44:12 +02:00
return '';
}
2020-05-04 12:44:12 +02:00
return decodeURIComponent(results[1].replace(/\+/g, ' '));
2018-10-23 01:05:09 +03:00
}
function pageClassOn(eventName, className, fn) {
2020-05-04 12:44:12 +02:00
'use strict';
2019-03-04 20:38:39 +00:00
document.addEventListener(eventName, function (event) {
var target = event.target;
if (target.classList.contains(className)) {
2019-03-04 20:38:39 +00:00
fn.call(target, event);
}
});
2018-10-23 01:05:09 +03:00
}
function pageIdOn(eventName, id, fn) {
2020-05-04 12:44:12 +02:00
'use strict';
2019-03-04 20:38:39 +00:00
document.addEventListener(eventName, function (event) {
var target = event.target;
if (target.id === id) {
2019-03-04 20:38:39 +00:00
fn.call(target, event);
}
});
2018-10-23 01:05:09 +03:00
}
2018-10-23 01:05:09 +03:00
var Dashboard = {
getCurrentUser: function () {
return window.ApiClient.getCurrentUser(false);
},
//TODO: investigate url prefix support for serverAddress function
serverAddress: function () {
if (AppInfo.isNativeApp) {
var apiClient = window.ApiClient;
if (apiClient) {
return apiClient.serverAddress();
}
return null;
}
var urlLower = window.location.href.toLowerCase();
2020-05-04 12:44:12 +02:00
var index = urlLower.lastIndexOf('/web');
if (-1 != index) {
return urlLower.substring(0, index);
}
var loc = window.location;
2020-05-04 12:44:12 +02:00
var address = loc.protocol + '//' + loc.hostname;
if (loc.port) {
2020-05-04 12:44:12 +02:00
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) {
2020-05-04 12:44:12 +02:00
loginPage = 'selectserver.html';
window.ApiClient = null;
} else {
2020-05-04 12:44:12 +02:00
loginPage = 'login.html';
2018-10-23 01:05:09 +03:00
}
Dashboard.navigate(loginPage);
});
},
getConfigurationPageUrl: function (name) {
2020-05-04 12:44:12 +02:00
return 'configurationpage?name=' + encodeURIComponent(name);
},
getConfigurationResourceUrl: function (name) {
if (AppInfo.isNativeApp) {
2020-05-04 12:44:12 +02:00
return ApiClient.getUrl('web/ConfigurationPage', {
2018-10-23 01:05:09 +03:00
name: name
});
}
return Dashboard.getConfigurationPageUrl(name);
},
navigate: function (url, preserveQueryString) {
if (!url) {
2020-05-04 12:44:12 +02:00
throw new Error('url cannot be null or empty');
}
var queryString = getWindowLocationSearch();
if (preserveQueryString && queryString) {
url += queryString;
}
return new Promise(function (resolve, reject) {
2020-05-04 12:44:12 +02:00
require(['appRouter'], function (appRouter) {
return appRouter.show(url).then(resolve, reject);
});
});
},
navigate_direct: function (path) {
return new Promise(function (resolve, reject) {
2020-05-04 12:44:12 +02:00
require(['appRouter'], function (appRouter) {
return appRouter.showDirect(path).then(resolve, reject);
});
});
},
processPluginConfigurationUpdateResult: function () {
2020-05-04 12:44:12 +02:00
require(['loading', 'toast'], function (loading, toast) {
loading.hide();
2020-05-04 12:44:12 +02:00
toast(Globalize.translate('MessageSettingsSaved'));
});
},
processServerConfigurationUpdateResult: function (result) {
2020-05-04 12:44:12 +02:00
require(['loading', 'toast'], function (loading, toast) {
loading.hide();
2020-05-04 12:44:12 +02:00
toast(Globalize.translate('MessageSettingsSaved'));
});
},
processErrorResponse: function (response) {
2020-05-04 12:44:12 +02:00
require(['loading'], function (loading) {
loading.hide();
});
2020-05-04 12:44:12 +02:00
var status = '' + response.status;
if (response.statusText) {
status = response.statusText;
}
Dashboard.alert({
title: status,
2020-05-04 12:44:12 +02:00
message: response.headers ? response.headers.get('X-Application-Error-Code') : null
});
},
alert: function (options) {
2020-05-04 12:44:12 +02:00
if ('string' == typeof options) {
return void require(['toast'], function (toast) {
2018-10-23 01:05:09 +03:00
toast({
text: options
});
2018-10-23 01:05:09 +03:00
});
}
2020-05-04 12:44:12 +02:00
require(['alert'], function (alert) {
alert({
2020-05-04 12:44:12 +02:00
title: options.title || Globalize.translate('HeaderAlert'),
text: options.message
}).then(options.callback || function () {});
});
},
restartServer: function () {
var apiClient = window.ApiClient;
if (apiClient) {
2020-05-04 12:44:12 +02:00
require(['serverRestartDialog', 'events'], function (ServerRestartDialog, events) {
2018-10-23 01:05:09 +03:00
var dialog = new ServerRestartDialog({
apiClient: apiClient
});
2020-05-04 12:44:12 +02: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
}
},
capabilities: function (appHost) {
var capabilities = {
2020-05-04 12:44:12 +02:00
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
};
appHost.getPushTokenInfo();
return capabilities = Object.assign(capabilities, appHost.getPushTokenInfo());
},
selectServer: function () {
2020-05-04 12:44:12 +02:00
if (window.NativeShell && typeof window.NativeShell.selectServer === 'function') {
window.NativeShell.selectServer();
} else {
2020-05-04 12:44:12 +02:00
Dashboard.navigate('selectserver.html');
}
}
};
var AppInfo = {};
!function () {
2020-05-04 12:44:12 +02:00
'use strict';
2018-10-23 01:05:09 +03:00
function defineConnectionManager(connectionManager) {
window.ConnectionManager = connectionManager;
2020-05-04 12:44:12 +02:00
define('connectionManager', [], function () {
return connectionManager;
});
2018-10-23 01:05:09 +03:00
}
function bindConnectionManagerEvents(connectionManager, events, userSettings) {
window.Events = events;
connectionManager.currentApiClient = function () {
2018-10-23 01:05:09 +03:00
if (!localApiClient) {
var server = connectionManager.getLastUsedServer();
if (server) {
localApiClient = connectionManager.getApiClient(server.Id);
}
2018-10-23 01:05:09 +03:00
}
return localApiClient;
};
connectionManager.onLocalUserSignedIn = function (user) {
localApiClient = connectionManager.getApiClient(user.ServerId);
window.ApiClient = localApiClient;
return userSettings.setUserInfo(user.Id, localApiClient);
};
2020-05-04 12:44:12 +02:00
events.on(connectionManager, 'localusersignedout', function () {
userSettings.setUserInfo(null, null);
});
2018-10-23 01:05:09 +03:00
}
function createConnectionManager() {
2020-05-04 12:44:12 +02:00
return require(['connectionManagerFactory', 'apphost', 'credentialprovider', 'events', 'userSettings'], function (ConnectionManager, apphost, credentialProvider, events, userSettings) {
var credentialProviderInstance = new credentialProvider();
var promises = [apphost.getSyncProfile(), apphost.init()];
2019-03-17 22:24:49 +01:00
return Promise.all(promises).then(function (responses) {
var deviceProfile = responses[0];
var capabilities = Dashboard.capabilities(apphost);
capabilities.DeviceProfile = deviceProfile;
2020-03-11 21:31:04 +01:00
var connectionManager = new ConnectionManager(credentialProviderInstance, apphost.appName(), apphost.appVersion(), apphost.deviceName(), apphost.deviceId(), capabilities);
defineConnectionManager(connectionManager);
bindConnectionManagerEvents(connectionManager, events, userSettings);
if (!AppInfo.isNativeApp) {
2020-05-04 12:44:12 +02:00
console.debug('loading ApiClient singleton');
2020-05-04 12:44:12 +02:00
return require(['apiclient'], function (apiClientFactory) {
console.debug('creating ApiClient singleton');
var apiClient = new apiClientFactory(Dashboard.serverAddress(), apphost.appName(), apphost.appVersion(), apphost.deviceName(), apphost.deviceId());
2019-03-17 22:24:49 +01:00
apiClient.enableAutomaticNetworking = false;
apiClient.manualAddressOnly = true;
connectionManager.addApiClient(apiClient);
window.ApiClient = apiClient;
localApiClient = apiClient;
2020-05-04 12:44:12 +02:00
console.debug('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) {
return obj;
2018-10-23 01:05:09 +03:00
}
function getBowerPath() {
2020-05-04 12:44:12 +02:00
return 'libraries';
2018-10-23 01:05:09 +03:00
}
function getComponentsPath() {
2020-05-04 12:44:12 +02:00
return 'components';
}
function getElementsPath() {
2020-05-04 12:44:12 +02:00
return 'elements';
}
function getScriptsPath() {
2020-05-04 12:44:12 +02:00
return 'scripts';
}
2018-10-23 01:05:09 +03:00
function getPlaybackManager(playbackManager) {
2020-05-04 12:44:12 +02: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) {
2020-05-04 12:44:12 +02:00
console.error('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-01-21 17:47:10 +09:00
layoutManager.init();
return layoutManager;
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) {
2020-05-04 12:44:12 +02:00
console.error('RequireJS error: ' + (requireType || 'unknown') + '. Failed modules: ' + (requireModules || []).join(','));
2018-10-23 01:05:09 +03:00
}
function defineResizeObserver() {
if (self.ResizeObserver) {
2020-05-04 12:44:12 +02:00
define('ResizeObserver', [], function () {
return self.ResizeObserver;
});
} else {
2020-05-04 12:44:12 +02:00
define('ResizeObserver', ['resize-observer-polyfill'], returnFirstDependency);
}
2018-10-23 01:05:09 +03:00
}
function initRequireWithBrowser(browser) {
2019-01-16 02:47:29 +09:00
var bowerPath = getBowerPath();
var componentsPath = getComponentsPath();
var scriptsPath = getScriptsPath();
2019-01-16 02:47:29 +09:00
2020-05-04 12:44:12 +02:00
define('filesystem', [scriptsPath + '/filesystem'], returnFirstDependency);
define('lazyLoader', [componentsPath + '/lazyloader/lazyloader-intersectionobserver'], returnFirstDependency);
2020-05-04 12:44:12 +02:00
define('shell', [componentsPath + '/shell'], returnFirstDependency);
2020-05-04 12:44:12 +02:00
if ('registerElement' in document) {
define('registerElement', []);
} else if (browser.msie) {
2020-05-04 12:44:12 +02:00
define('registerElement', ['webcomponents'], returnFirstDependency);
} else {
2020-05-04 12:44:12 +02:00
define('registerElement', ['document-register-element'], returnFirstDependency);
}
2020-05-04 12:44:12 +02:00
define('alert', [componentsPath + '/alert'], returnFirstDependency);
2019-01-16 02:47:29 +09:00
defineResizeObserver();
2020-05-04 12:44:12 +02:00
define('dialog', [componentsPath + '/dialog/dialog'], returnFirstDependency);
2020-05-04 12:44:12 +02:00
define('confirm', [componentsPath + '/confirm/confirm'], returnFirstDependency);
2020-05-04 12:44:12 +02:00
define('prompt', [componentsPath + '/prompt/prompt'], returnFirstDependency);
2020-05-04 12:44:12 +02:00
define('loading', [componentsPath + '/loading/loading'], returnFirstDependency);
define('multi-download', [componentsPath + '/multidownload'], returnFirstDependency);
define('fileDownloader', [componentsPath + '/filedownloader'], returnFirstDependency);
2020-05-04 12:44:12 +02:00
define('castSenderApiLoader', [componentsPath + '/castSenderApi'], returnFirstDependency);
}
2018-10-23 01:05:09 +03:00
function init() {
2020-05-04 12:44:12 +02:00
define('livetvcss', ['css!assets/css/livetv.css'], returnFirstDependency);
define('detailtablecss', ['css!assets/css/detailtable.css'], returnFirstDependency);
var promises = [];
2019-05-05 23:55:42 +02:00
if (!window.fetch) {
2020-05-04 12:44:12 +02:00
promises.push(require(['fetch']));
2019-05-05 23:55:42 +02:00
}
Promise.all(promises).then(function () {
createConnectionManager().then(function () {
2020-05-04 12:44:12 +02:00
console.debug('initAfterDependencies promises resolved');
2020-05-04 12:44:12 +02:00
require(['globalize', 'browser'], function (globalize, browser) {
window.Globalize = globalize;
loadCoreDictionary(globalize).then(function () {
onGlobalizeInit(browser);
});
});
2020-05-04 12:44:12 +02:00
require(['keyboardnavigation'], function(keyboardnavigation) {
keyboardnavigation.enable();
});
2020-05-04 12:44:12 +02:00
require(['mouseManager']);
require(['focusPreventScroll']);
require(['autoFocuser'], function(autoFocuser) {
2019-11-02 20:38:58 +03:00
autoFocuser.enable();
});
require(['globalize', 'connectionManager', 'events'], function (globalize, connectionManager, events) {
events.on(connectionManager, 'localusersignedin', globalize.updateCurrentCulture);
});
});
});
2018-10-23 01:05:09 +03:00
}
function loadCoreDictionary(globalize) {
2020-05-04 12:44:12 +02: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) {
return {
2019-03-04 20:38:39 +00:00
lang: language,
2020-05-04 12:44:12 +02:00
path: 'strings/' + language + '.json'
};
});
2020-05-04 12:44:12 +02:00
globalize.defaultModule('core');
return globalize.loadStrings({
2020-05-04 12:44:12 +02:00
name: 'core',
2018-10-23 01:05:09 +03:00
translations: translations
});
2018-10-23 01:05:09 +03:00
}
function onGlobalizeInit(browser) {
2020-05-04 12:44:12 +02:00
if ('android' === self.appMode) {
if (-1 !== self.location.href.toString().toLowerCase().indexOf('start=backgroundsync')) {
return onAppReady(browser);
}
2018-10-23 01:05:09 +03:00
}
2020-05-04 12:44:12 +02:00
document.title = Globalize.translateDocument(document.title, 'core');
if (browser.tv && !browser.android) {
2020-05-04 12:44:12 +02:00
console.debug('using system fonts with explicit sizes');
require(['systemFontsSizedCss']);
} else {
2020-05-04 12:44:12 +02:00
console.debug('using default fonts');
require(['systemFontsCss']);
}
2020-05-04 12:44:12 +02:00
require(['apphost', 'css!assets/css/librarybrowser'], function (appHost) {
2019-05-21 22:28:48 +01:00
loadPlugins(appHost, browser).then(function () {
2019-01-21 17:47:10 +09:00
onAppReady(browser);
});
});
2018-10-23 01:05:09 +03:00
}
2019-05-21 22:28:48 +01:00
function loadPlugins(appHost, browser, shell) {
2020-05-04 12:44:12 +02:00
console.debug('loading installed plugins');
var list = [
2020-05-04 12:44:12 +02:00
'components/playback/playaccessvalidation',
'components/playback/experimentalwarnings',
'components/htmlaudioplayer/plugin',
'components/htmlvideoplayer/plugin',
'components/photoplayer/plugin',
'components/youtubeplayer/plugin',
'components/backdropscreensaver/plugin',
'components/logoscreensaver/plugin'
];
2020-05-04 12:44:12 +02:00
if (appHost.supports('remotecontrol')) {
list.push('components/sessionplayer');
if (browser.chrome || browser.opera) {
2020-05-04 12:44:12 +02:00
list.push('components/chromecast/chromecastplayer');
}
}
2019-05-21 22:28:48 +01:00
if (window.NativeShell) {
list = list.concat(window.NativeShell.getPlugins());
}
return new Promise(function (resolve, reject) {
Promise.all(list.map(loadPlugin)).then(function () {
2020-05-04 12:44:12 +02:00
require(['packageManager'], function (packageManager) {
packageManager.init().then(resolve, reject);
});
}, reject);
});
2018-10-23 01:05:09 +03:00
}
function loadPlugin(url) {
return new Promise(function (resolve, reject) {
2020-05-04 12:44:12 +02:00
require(['pluginManager'], function (pluginManager) {
pluginManager.loadPlugin(url).then(resolve, reject);
});
});
2018-10-23 01:05:09 +03:00
}
function onAppReady(browser) {
2020-05-04 12:44:12 +02:00
console.debug('begin onAppReady');
// ensure that appHost is loaded in this point
require(['apphost', 'appRouter'], function (appHost, appRouter) {
window.Emby = {};
2020-05-04 12:44:12 +02:00
console.debug('onAppReady: loading dependencies');
if (browser.iOS) {
require(['css!assets/css/ios.css']);
}
window.Emby.Page = appRouter;
require(['emby-button', 'scripts/themeloader', 'libraryMenu', 'scripts/routes'], function () {
Emby.Page.start({
click: false,
hashbang: true
});
2020-05-04 12:44:12 +02:00
require(['components/thememediaplayer', 'scripts/autobackdrops']);
if (!browser.tv && !browser.xboxOne && !browser.ps4) {
2020-05-04 12:44:12 +02:00
require(['components/nowplayingbar/nowplayingbar']);
}
2020-05-04 12:44:12 +02:00
if (appHost.supports('remotecontrol')) {
require(['playerSelectionMenu', 'components/playback/remotecontrolautoplay']);
}
2020-05-04 12:44:12 +02:00
require(['libraries/screensavermanager']);
2019-11-23 23:25:10 +03:00
2020-05-04 12:44:12 +02:00
if (!appHost.supports('physicalvolumecontrol') || browser.touch) {
require(['components/playback/volumeosd']);
}
if (navigator.mediaSession || window.NativeShell) {
require(['mediaSession']);
}
require(['serverNotifications']);
2020-05-04 12:44:12 +02:00
require(['date-fns', 'date-fns/locale']);
if (!browser.tv && !browser.xboxOne) {
2020-05-04 12:44:12 +02:00
require(['components/playback/playbackorientation']);
registerServiceWorker();
if (window.Notification) {
2020-05-04 12:44:12 +02:00
require(['components/notifications/notifications']);
}
}
2020-05-04 12:44:12 +02:00
require(['playerSelectionMenu']);
2020-02-04 15:40:32 -05:00
var apiClient = window.ConnectionManager && window.ConnectionManager.currentApiClient();
if (apiClient) {
2020-05-04 12:44:12 +02:00
fetch(apiClient.getUrl('Branding/Css'))
2020-02-04 15:40:32 -05:00
.then(function(response) {
if (!response.ok) {
throw new Error(response.status + ' ' + response.statusText);
}
return response.text();
})
.then(function(css) {
// Inject the branding css as a dom element in body so it will take
// precedence over other stylesheets
var style = document.createElement('style');
style.appendChild(document.createTextNode(css));
document.body.appendChild(style);
})
.catch(function(err) {
console.warn('Error applying custom css', err);
});
}
});
});
2018-10-23 01:05:09 +03:00
}
function registerServiceWorker() {
/* eslint-disable compat/compat */
2020-05-04 12:44:12 +02:00
if (navigator.serviceWorker && self.appMode !== 'cordova' && self.appMode !== 'android') {
try {
2020-05-04 12:44:12 +02:00
navigator.serviceWorker.register('serviceworker.js');
} catch (err) {
2020-05-04 12:44:12 +02:00
console.error('error registering serviceWorker: ' + err);
}
} else {
2020-05-04 12:44:12 +02:00
console.warn('serviceWorker unsupported');
2018-10-23 01:05:09 +03:00
}
/* eslint-enable compat/compat */
2018-10-23 01:05:09 +03:00
}
function onWebComponentsReady(browser) {
initRequireWithBrowser(browser);
if (self.appMode === 'cordova' || self.appMode === 'android' || self.appMode === 'standalone') {
AppInfo.isNativeApp = true;
}
init();
2018-10-23 01:05:09 +03:00
}
2018-10-23 01:05:09 +03:00
var localApiClient;
(function () {
2020-05-04 12:44:12 +02:00
var urlArgs = 'v=' + (window.dashboardVersion || new Date().getDate());
2019-01-21 17:47:10 +09:00
var bowerPath = getBowerPath();
var componentsPath = getComponentsPath();
var elementsPath = getElementsPath();
var scriptsPath = getScriptsPath();
2019-01-21 17:47:10 +09:00
var paths = {
2020-05-04 12:44:12 +02:00
browserdeviceprofile: 'scripts/browserdeviceprofile',
browser: 'scripts/browser',
libraryBrowser: 'scripts/librarybrowser',
inputManager: 'scripts/inputManager',
datetime: 'scripts/datetime',
globalize: 'scripts/globalize',
dfnshelper: 'scripts/dfnshelper',
libraryMenu: 'scripts/librarymenu',
playlisteditor: componentsPath + '/playlisteditor/playlisteditor',
medialibrarycreator: componentsPath + '/medialibrarycreator/medialibrarycreator',
medialibraryeditor: componentsPath + '/medialibraryeditor/medialibraryeditor',
imageoptionseditor: componentsPath + '/imageoptionseditor/imageoptionseditor',
apphost: componentsPath + '/apphost',
visibleinviewport: bowerPath + '/visibleinviewport',
qualityoptions: componentsPath + '/qualityoptions',
focusManager: componentsPath + '/focusManager',
itemHelper: componentsPath + '/itemhelper',
itemShortcuts: componentsPath + '/shortcuts',
playQueueManager: componentsPath + '/playback/playqueuemanager',
nowPlayingHelper: componentsPath + '/playback/nowplayinghelper',
pluginManager: componentsPath + '/pluginManager',
packageManager: componentsPath + '/packagemanager',
screensaverManager: componentsPath + '/screensavermanager'
2019-01-21 17:47:10 +09:00
};
2019-09-30 00:05:20 -04:00
requirejs.onError = onRequireJsError;
2019-09-30 00:05:20 -04:00
requirejs.config({
waitSeconds: 0,
map: {
2020-05-04 12:44:12 +02:00
'*': {
css: 'components/require/requirecss',
text: 'components/require/requiretext'
2019-09-30 00:05:20 -04:00
}
},
bundles: {
bundle: [
2020-05-04 12:44:12 +02:00
'document-register-element',
'fetch',
'flvjs',
'jstree',
'jQuery',
'hlsjs',
'howler',
'native-promise-only',
'resize-observer-polyfill',
'shaka',
'swiper',
'queryString',
'sortable',
'webcomponents',
'material-icons',
'jellyfin-noto',
'date-fns',
'page',
'polyfill',
'fast-text-encoding',
'intersection-observer',
'classlist-polyfill',
'screenfull',
'headroom',
'apiclient',
'events',
'credentialprovider',
'connectionManagerFactory',
'appStorage'
]
2019-09-30 00:05:20 -04:00
},
urlArgs: urlArgs,
paths: paths,
onError: onRequireJsError
});
2020-05-04 12:44:12 +02:00
require(['fetch']);
require(['polyfill']);
require(['fast-text-encoding']);
require(['intersection-observer']);
require(['classlist-polyfill']);
2020-03-13 09:43:30 +01:00
2019-09-30 00:05:20 -04:00
// Expose jQuery globally
2020-05-04 12:44:12 +02:00
require(['jQuery'], function(jQuery) {
2019-09-30 00:05:20 -04:00
window.$ = jQuery;
window.jQuery = jQuery;
});
2020-05-04 12:44:12 +02:00
require(['css!assets/css/site']);
require(['jellyfin-noto']);
2019-10-03 02:33:21 +09:00
// define styles
// TODO determine which of these files can be moved to the components themselves
2020-05-04 12:44:12 +02:00
define('systemFontsCss', ['css!assets/css/fonts'], returnFirstDependency);
define('systemFontsSizedCss', ['css!assets/css/fonts.sized'], returnFirstDependency);
define('scrollStyles', ['css!assets/css/scrollstyles'], returnFirstDependency);
define('dashboardcss', ['css!assets/css/dashboard'], returnFirstDependency);
define('programStyles', ['css!' + componentsPath + '/guide/programs'], returnFirstDependency);
define('listViewStyle', ['css!' + componentsPath + '/listview/listview'], returnFirstDependency);
define('formDialogStyle', ['css!' + componentsPath + '/formdialog'], returnFirstDependency);
define('clearButtonStyle', ['css!assets/css/clearbutton'], returnFirstDependency);
define('cardStyle', ['css!' + componentsPath + '/cardbuilder/card'], returnFirstDependency);
define('flexStyles', ['css!assets/css/flexstyles'], returnFirstDependency);
2019-10-03 02:33:21 +09:00
// define legacy features
// TODO delete the rest of these
2020-05-04 12:44:12 +02:00
define('fnchecked', ['legacy/fnchecked'], returnFirstDependency);
define('legacyDashboard', ['legacy/dashboard'], returnFirstDependency);
define('legacySelectMenu', ['legacy/selectmenu'], returnFirstDependency);
2019-10-03 02:33:21 +09:00
// there are several objects that need to be instantiated
// TODO find a better way to do this
2020-05-04 12:44:12 +02:00
define('appFooter', [componentsPath + '/appfooter/appfooter'], returnFirstDependency);
define('appFooter-shared', ['appFooter'], createSharedAppFooter);
2019-10-03 02:33:21 +09:00
2019-11-11 01:59:23 +09:00
// TODO remove these libraries
2020-01-05 14:17:25 +09:00
// all of these have been modified so we need to fix that first
2020-05-04 12:44:12 +02:00
define('scroller', [bowerPath + '/scroller'], returnFirstDependency);
define('navdrawer', [bowerPath + '/navdrawer/navdrawer'], returnFirstDependency);
define('emby-button', [elementsPath + '/emby-button/emby-button'], returnFirstDependency);
define('paper-icon-button-light', [elementsPath + '/emby-button/paper-icon-button-light'], returnFirstDependency);
define('emby-checkbox', [elementsPath + '/emby-checkbox/emby-checkbox'], returnFirstDependency);
define('emby-collapse', [elementsPath + '/emby-collapse/emby-collapse'], returnFirstDependency);
define('emby-input', [elementsPath + '/emby-input/emby-input'], returnFirstDependency);
define('emby-progressring', [elementsPath + '/emby-progressring/emby-progressring'], returnFirstDependency);
define('emby-radio', [elementsPath + '/emby-radio/emby-radio'], returnFirstDependency);
define('emby-select', [elementsPath + '/emby-select/emby-select'], returnFirstDependency);
define('emby-slider', [elementsPath + '/emby-slider/emby-slider'], returnFirstDependency);
define('emby-textarea', [elementsPath + '/emby-textarea/emby-textarea'], returnFirstDependency);
define('emby-toggle', [elementsPath + '/emby-toggle/emby-toggle'], returnFirstDependency);
define('emby-scroller', [elementsPath + '/emby-scroller/emby-scroller'], returnFirstDependency);
define('emby-tabs', [elementsPath + '/emby-tabs/emby-tabs'], returnFirstDependency);
define('emby-scrollbuttons', [elementsPath + '/emby-scrollbuttons/emby-scrollbuttons'], returnFirstDependency);
define('emby-itemrefreshindicator', [elementsPath + '/emby-itemrefreshindicator/emby-itemrefreshindicator'], returnFirstDependency);
define('emby-itemscontainer', [elementsPath + '/emby-itemscontainer/emby-itemscontainer'], returnFirstDependency);
define('emby-playstatebutton', [elementsPath + '/emby-playstatebutton/emby-playstatebutton'], returnFirstDependency);
define('emby-ratingbutton', [elementsPath + '/emby-ratingbutton/emby-ratingbutton'], returnFirstDependency);
define('emby-progressbar', [elementsPath + '/emby-progressbar/emby-progressbar'], returnFirstDependency);
define('emby-programcell', [elementsPath + '/emby-programcell/emby-programcell'], returnFirstDependency);
define('webSettings', [scriptsPath + '/settings/webSettings'], returnFirstDependency);
define('appSettings', [scriptsPath + '/settings/appSettings'], returnFirstDependency);
define('userSettings', [scriptsPath + '/settings/userSettings'], returnFirstDependency);
define('chromecastHelper', [componentsPath + '/chromecast/chromecasthelpers'], returnFirstDependency);
define('mediaSession', [componentsPath + '/playback/mediasession'], returnFirstDependency);
define('actionsheet', [componentsPath + '/actionsheet/actionsheet'], returnFirstDependency);
define('tunerPicker', [componentsPath + '/tunerpicker'], returnFirstDependency);
define('mainTabsManager', [componentsPath + '/maintabsmanager'], returnFirstDependency);
define('imageLoader', [componentsPath + '/images/imageLoader'], returnFirstDependency);
define('directorybrowser', [componentsPath + '/directorybrowser/directorybrowser'], returnFirstDependency);
define('metadataEditor', [componentsPath + '/metadataeditor/metadataeditor'], returnFirstDependency);
define('personEditor', [componentsPath + '/metadataeditor/personeditor'], returnFirstDependency);
define('playerSelectionMenu', [componentsPath + '/playback/playerSelectionMenu'], returnFirstDependency);
define('playerSettingsMenu', [componentsPath + '/playback/playersettingsmenu'], returnFirstDependency);
define('playMethodHelper', [componentsPath + '/playback/playmethodhelper'], returnFirstDependency);
define('brightnessOsd', [componentsPath + '/playback/brightnessosd'], returnFirstDependency);
define('alphaNumericShortcuts', [scriptsPath + '/alphanumericshortcuts'], returnFirstDependency);
define('multiSelect', [componentsPath + '/multiselect/multiselect'], returnFirstDependency);
define('alphaPicker', [componentsPath + '/alphapicker/alphapicker'], returnFirstDependency);
define('tabbedView', [componentsPath + '/tabbedview/tabbedview'], returnFirstDependency);
define('itemsTab', [componentsPath + '/tabbedview/itemstab'], returnFirstDependency);
define('collectionEditor', [componentsPath + '/collectioneditor/collectioneditor'], returnFirstDependency);
define('serverRestartDialog', [componentsPath + '/serverRestartDialog'], returnFirstDependency);
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('subtitleSync', [componentsPath + '/subtitlesync/subtitlesync'], returnFirstDependency);
define('itemIdentifier', [componentsPath + '/itemidentifier/itemidentifier'], returnFirstDependency);
define('itemMediaInfo', [componentsPath + '/itemMediaInfo/itemMediaInfo'], 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', [scriptsPath + '/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('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('playbackManager', [componentsPath + '/playback/playbackmanager'], getPlaybackManager);
2020-04-01 17:53:14 +02:00
define('syncplayManager', [componentsPath + '/syncplay/syncplaymanager'], returnFirstDependency);
2020-05-04 12:44:12 +02:00
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('cardBuilder', [componentsPath + '/cardbuilder/cardBuilder'], returnFirstDependency);
define('peoplecardbuilder', [componentsPath + '/cardbuilder/peoplecardbuilder'], returnFirstDependency);
define('chaptercardbuilder', [componentsPath + '/cardbuilder/chaptercardbuilder'], returnFirstDependency);
define('deleteHelper', [componentsPath + '/deletehelper'], returnFirstDependency);
define('tvguide', [componentsPath + '/guide/guide'], returnFirstDependency);
define('guide-settings-dialog', [componentsPath + '/guide/guide-settings'], returnFirstDependency);
define('loadingDialog', [componentsPath + '/loadingdialog/loadingdialog'], returnFirstDependency);
define('viewManager', [componentsPath + '/viewManager/viewManager'], function (viewManager) {
window.ViewManager = viewManager;
viewManager.dispatchPageEvents(true);
return viewManager;
2019-01-21 17:47:10 +09:00
});
2020-05-04 12:44:12 +02:00
define('slideshow', [componentsPath + '/slideshow/slideshow'], returnFirstDependency);
define('focusPreventScroll', ['legacy/focusPreventScroll'], returnFirstDependency);
define('userdataButtons', [componentsPath + '/userdatabuttons/userdatabuttons'], returnFirstDependency);
define('listView', [componentsPath + '/listview/listview'], 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);
define('idb', [componentsPath + '/idb'], returnFirstDependency);
define('sanitizefilename', [componentsPath + '/sanitizefilename'], returnFirstDependency);
define('toast', [componentsPath + '/toast/toast'], returnFirstDependency);
define('scrollHelper', [componentsPath + '/scrollhelper'], returnFirstDependency);
define('touchHelper', [componentsPath + '/touchhelper'], returnFirstDependency);
define('imageUploader', [componentsPath + '/imageuploader/imageuploader'], returnFirstDependency);
define('htmlMediaHelper', [componentsPath + '/htmlMediaHelper'], returnFirstDependency);
define('viewContainer', [componentsPath + '/viewContainer'], returnFirstDependency);
define('dialogHelper', [componentsPath + '/dialogHelper/dialogHelper'], returnFirstDependency);
define('serverNotifications', [componentsPath + '/serverNotifications'], returnFirstDependency);
define('skinManager', [componentsPath + '/skinManager'], returnFirstDependency);
define('keyboardnavigation', [scriptsPath + '/keyboardnavigation'], returnFirstDependency);
define('mouseManager', [scriptsPath + '/mouseManager'], returnFirstDependency);
define('scrollManager', [componentsPath + '/scrollManager'], returnFirstDependency);
define('autoFocuser', [componentsPath + '/autoFocuser'], returnFirstDependency);
define('connectionManager', [], function () {
return ConnectionManager;
2019-01-21 17:47:10 +09:00
});
2020-05-04 12:44:12 +02:00
define('apiClientResolver', [], function () {
return function () {
return window.ApiClient;
};
2019-01-21 17:47:10 +09:00
});
2020-05-04 12:44:12 +02:00
define('appRouter', [componentsPath + '/appRouter', 'itemHelper'], function (appRouter, itemHelper) {
2018-10-23 01:05:09 +03:00
function showItem(item, serverId, options) {
2020-05-04 12:44:12 +02: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];
}
2020-05-04 12:44:12 +02:00
appRouter.show('/' + appRouter.getRouteUrl(item, options), {
item: item
});
}
2018-10-23 01:05:09 +03:00
}
appRouter.showLocalLogin = function (serverId, manualLogin) {
2020-05-04 12:44:12 +02:00
Dashboard.navigate('login.html?serverid=' + serverId);
};
appRouter.showVideoOsd = function () {
2020-05-04 12:44:12 +02:00
return Dashboard.navigate('videoosd.html');
};
appRouter.showSelectServer = function () {
2020-05-04 12:44:12 +02:00
Dashboard.navigate(AppInfo.isNativeApp ? 'selectserver.html' : 'login.html');
};
appRouter.showWelcome = function () {
2020-05-04 12:44:12 +02:00
Dashboard.navigate(AppInfo.isNativeApp ? 'selectserver.html' : 'login.html');
};
appRouter.showSettings = function () {
2020-05-04 12:44:12 +02:00
Dashboard.navigate('mypreferencesmenu.html');
};
appRouter.showGuide = function () {
2020-05-04 12:44:12 +02:00
Dashboard.navigate('livetv.html?tab=1');
};
appRouter.goHome = function () {
2020-05-04 12:44:12 +02:00
Dashboard.navigate('home.html');
};
appRouter.showSearch = function () {
2020-05-04 12:44:12 +02:00
Dashboard.navigate('search.html');
};
appRouter.showLiveTV = function () {
2020-05-04 12:44:12 +02:00
Dashboard.navigate('livetv.html');
};
appRouter.showRecordedTV = function () {
2020-05-04 12:44:12 +02:00
Dashboard.navigate('livetv.html?tab=3');
};
appRouter.showFavorites = function () {
2020-05-04 12:44:12 +02:00
Dashboard.navigate('home.html?tab=1');
};
appRouter.showSettings = function () {
2020-05-04 12:44:12 +02:00
Dashboard.navigate('mypreferencesmenu.html');
};
appRouter.setTitle = function (title) {
LibraryMenu.setTitle(title);
};
appRouter.getRouteUrl = function (item, options) {
if (!item) {
2020-05-04 12:44:12 +02:00
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;
2020-05-04 12:44:12 +02:00
if ('settings' === item) {
return 'mypreferencesmenu.html';
}
2020-05-04 12:44:12 +02:00
if ('wizard' === item) {
return 'wizardstart.html';
}
2020-05-04 12:44:12 +02:00
if ('manageserver' === item) {
return 'dashboard.html';
}
2020-05-04 12:44:12 +02:00
if ('recordedtv' === item) {
return 'livetv.html?tab=3&serverId=' + options.serverId;
}
2020-05-04 12:44:12 +02:00
if ('nextup' === item) {
return 'list.html?type=nextup&serverId=' + options.serverId;
}
2020-05-04 12:44:12 +02:00
if ('list' === item) {
var url = 'list.html?serverId=' + options.serverId + '&type=' + options.itemTypes;
if (options.isFavorite) {
2020-05-04 12:44:12 +02:00
url += '&IsFavorite=true';
}
return url;
}
2020-05-04 12:44:12 +02:00
if ('livetv' === item) {
if ('programs' === options.section) {
return 'livetv.html?tab=0&serverId=' + options.serverId;
2019-09-11 03:22:22 -07:00
}
2020-05-04 12:44:12 +02:00
if ('guide' === options.section) {
return 'livetv.html?tab=1&serverId=' + options.serverId;
}
2020-05-04 12:44:12 +02:00
if ('movies' === options.section) {
return 'list.html?type=Programs&IsMovie=true&serverId=' + options.serverId;
}
2020-05-04 12:44:12 +02:00
if ('shows' === options.section) {
return 'list.html?type=Programs&IsSeries=true&IsMovie=false&IsNews=false&serverId=' + options.serverId;
}
2020-05-04 12:44:12 +02:00
if ('sports' === options.section) {
return 'list.html?type=Programs&IsSports=true&serverId=' + options.serverId;
}
2020-05-04 12:44:12 +02:00
if ('kids' === options.section) {
return 'list.html?type=Programs&IsKids=true&serverId=' + options.serverId;
}
2020-05-04 12:44:12 +02:00
if ('news' === options.section) {
return 'list.html?type=Programs&IsNews=true&serverId=' + options.serverId;
}
2020-05-04 12:44:12 +02:00
if ('onnow' === options.section) {
return 'list.html?type=Programs&IsAiring=true&serverId=' + options.serverId;
}
2020-05-04 12:44:12 +02:00
if ('dvrschedule' === options.section) {
return 'livetv.html?tab=4&serverId=' + options.serverId;
}
2020-05-04 12:44:12 +02:00
if ('seriesrecording' === options.section) {
return 'livetv.html?tab=5&serverId=' + options.serverId;
}
2020-05-04 12:44:12 +02:00
return 'livetv.html?serverId=' + options.serverId;
}
2020-05-04 12:44:12 +02:00
if ('SeriesTimer' == itemType) {
return 'itemdetails.html?seriesTimerId=' + id + '&serverId=' + serverId;
}
2020-05-04 12:44:12 +02:00
if ('livetv' == item.CollectionType) {
return 'livetv.html';
}
2020-05-04 12:44:12 +02:00
if ('Genre' === item.Type) {
url = 'list.html?genreId=' + item.Id + '&serverId=' + serverId;
2020-05-04 12:44:12 +02:00
if ('livetv' === context) {
url += '&type=Programs';
}
if (options.parentId) {
2020-05-04 12:44:12 +02:00
url += '&parentId=' + options.parentId;
}
return url;
}
2020-05-04 12:44:12 +02:00
if ('MusicGenre' === item.Type) {
url = 'list.html?musicGenreId=' + item.Id + '&serverId=' + serverId;
if (options.parentId) {
2020-05-04 12:44:12 +02:00
url += '&parentId=' + options.parentId;
}
return url;
}
2020-05-04 12:44:12 +02:00
if ('Studio' === item.Type) {
url = 'list.html?studioId=' + item.Id + '&serverId=' + serverId;
if (options.parentId) {
2020-05-04 12:44:12 +02:00
url += '&parentId=' + options.parentId;
}
return url;
2018-10-23 01:05:09 +03:00
}
2020-05-04 12:44:12 +02:00
if ('folders' !== context && !itemHelper.isLocalItem(item)) {
if ('movies' == item.CollectionType) {
url = 'movies.html?topParentId=' + item.Id;
2020-05-04 12:44:12 +02:00
if (options && 'latest' === options.section) {
url += '&tab=1';
}
return url;
}
2020-05-04 12:44:12 +02:00
if ('tvshows' == item.CollectionType) {
url = 'tv.html?topParentId=' + item.Id;
2020-05-04 12:44:12 +02:00
if (options && 'latest' === options.section) {
url += '&tab=2';
}
return url;
}
2020-05-04 12:44:12 +02:00
if ('music' == item.CollectionType) {
return 'music.html?topParentId=' + item.Id;
}
}
2020-05-04 12:44:12 +02:00
var itemTypes = ['Playlist', 'TvChannel', 'Program', 'BoxSet', 'MusicAlbum', 'MusicGenre', 'Person', 'Recording', 'MusicArtist'];
if (itemTypes.indexOf(itemType) >= 0) {
2020-05-04 12:44:12 +02:00
return 'itemdetails.html?id=' + id + '&serverId=' + serverId;
2018-10-23 01:05:09 +03:00
}
2020-05-04 12:44:12 +02:00
var contextSuffix = context ? '&context=' + context : '';
2019-01-21 17:47:10 +09:00
2020-05-04 12:44:12 +02:00
if ('Series' == itemType || 'Season' == itemType || 'Episode' == itemType) {
return 'itemdetails.html?id=' + id + contextSuffix + '&serverId=' + serverId;
}
if (item.IsFolder) {
if (id) {
2020-05-04 12:44:12 +02:00
return 'list.html?parentId=' + id + '&serverId=' + serverId;
}
2020-05-04 12:44:12 +02:00
return '#';
}
2020-05-04 12:44:12 +02:00
return 'itemdetails.html?id=' + id + '&serverId=' + serverId;
};
appRouter.showItem = showItem;
return appRouter;
});
})();
2020-05-04 12:44:12 +02:00
return require(['browser'], onWebComponentsReady);
}();
2020-05-04 12:44:12 +02:00
pageClassOn('viewshow', 'standalonePage', function () {
document.querySelector('.skinHeader').classList.add('noHeaderRight');
2019-01-21 17:47:10 +09:00
});
2020-05-04 12:44:12 +02:00
pageClassOn('viewhide', 'standalonePage', function () {
document.querySelector('.skinHeader').classList.remove('noHeaderRight');
2018-12-11 00:46:50 -05:00
});