2022-01-30 00:27:26 +03:00
|
|
|
import escapeHtml from 'escape-html';
|
2022-05-06 13:30:10 -04:00
|
|
|
import Headroom from 'headroom.js';
|
2022-05-22 20:20:25 +03:00
|
|
|
|
2020-08-14 08:46:34 +02:00
|
|
|
import dom from './dom';
|
|
|
|
import layoutManager from '../components/layoutManager';
|
|
|
|
import inputManager from './inputManager';
|
|
|
|
import viewManager from '../components/viewManager/viewManager';
|
2023-05-01 10:04:13 -04:00
|
|
|
import { appRouter } from '../components/router/appRouter';
|
2020-08-16 20:24:45 +02:00
|
|
|
import { appHost } from '../components/apphost';
|
|
|
|
import { playbackManager } from '../components/playback/playbackmanager';
|
2022-10-02 03:55:35 -04:00
|
|
|
import { pluginManager } from '../components/pluginManager';
|
2022-10-01 02:57:30 -04:00
|
|
|
import groupSelectionMenu from '../plugins/syncPlay/ui/groupSelectionMenu';
|
2020-08-14 08:46:34 +02:00
|
|
|
import browser from './browser';
|
|
|
|
import globalize from './globalize';
|
|
|
|
import imageHelper from './imagehelper';
|
2021-06-10 13:38:24 -04:00
|
|
|
import { getMenuLinks } from '../scripts/settings/webSettings';
|
2022-05-21 05:40:25 -05:00
|
|
|
import Dashboard, { pageClassOn } from '../utils/dashboard';
|
2022-05-06 13:30:10 -04:00
|
|
|
import ServerConnections from '../components/ServerConnections';
|
2023-03-08 11:49:19 -05:00
|
|
|
import { PluginType } from '../types/plugin.ts';
|
2022-10-14 10:53:16 -04:00
|
|
|
import Events from '../utils/events.ts';
|
2022-05-21 23:37:30 +03:00
|
|
|
import { getParameterByName } from '../utils/url.ts';
|
2023-03-22 20:30:06 +03:00
|
|
|
import datetime from '../scripts/datetime';
|
2022-05-22 20:20:25 +03:00
|
|
|
|
2020-08-14 08:46:34 +02:00
|
|
|
import '../elements/emby-button/paper-icon-button-light';
|
2022-05-22 20:20:25 +03:00
|
|
|
|
2020-08-14 08:46:34 +02:00
|
|
|
import 'material-design-icons-iconfont';
|
2023-02-26 01:01:31 +02:00
|
|
|
import '../styles/scrollstyles.scss';
|
|
|
|
import '../styles/flexstyles.scss';
|
2020-07-28 22:04:01 +01:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
function renderHeader() {
|
|
|
|
let html = '';
|
|
|
|
html += '<div class="flex align-items-center flex-grow headerTop">';
|
|
|
|
html += '<div class="headerLeft">';
|
|
|
|
html += '<button type="button" is="paper-icon-button-light" class="headerButton headerButtonLeft headerBackButton hide"><span class="material-icons ' + (browser.safari ? 'chevron_left' : 'arrow_back') + '" aria-hidden="true"></span></button>';
|
|
|
|
html += '<button type="button" is="paper-icon-button-light" class="headerButton headerHomeButton hide barsMenuButton headerButtonLeft"><span class="material-icons home" aria-hidden="true"></span></button>';
|
|
|
|
html += '<button type="button" is="paper-icon-button-light" class="headerButton mainDrawerButton barsMenuButton headerButtonLeft hide"><span class="material-icons menu" aria-hidden="true"></span></button>';
|
|
|
|
html += '<h3 class="pageTitle" aria-hidden="true"></h3>';
|
|
|
|
html += '</div>';
|
|
|
|
html += '<div class="headerRight">';
|
|
|
|
html += '<button is="paper-icon-button-light" class="headerSyncButton syncButton headerButton headerButtonRight hide"><span class="material-icons groups" aria-hidden="true"></span></button>';
|
|
|
|
html += '<span class="headerSelectedPlayer"></span>';
|
|
|
|
html += '<button is="paper-icon-button-light" class="headerAudioPlayerButton audioPlayerButton headerButton headerButtonRight hide"><span class="material-icons music_note" aria-hidden="true"></span></button>';
|
|
|
|
html += '<button is="paper-icon-button-light" class="headerCastButton castButton headerButton headerButtonRight hide"><span class="material-icons cast" aria-hidden="true"></span></button>';
|
|
|
|
html += '<button type="button" is="paper-icon-button-light" class="headerButton headerButtonRight headerSearchButton hide"><span class="material-icons search" aria-hidden="true"></span></button>';
|
|
|
|
html += '<button is="paper-icon-button-light" class="headerButton headerButtonRight headerUserButton hide"><span class="material-icons person" aria-hidden="true"></span></button>';
|
|
|
|
html += '<div class="currentTimeText hide"></div>';
|
|
|
|
html += '</div>';
|
|
|
|
html += '</div>';
|
|
|
|
html += '<div class="headerTabs sectionTabs hide">';
|
|
|
|
html += '</div>';
|
|
|
|
|
|
|
|
skinHeader.classList.add('skinHeader-withBackground');
|
|
|
|
skinHeader.classList.add('skinHeader-blurred');
|
|
|
|
skinHeader.innerHTML = html;
|
|
|
|
|
|
|
|
headerBackButton = skinHeader.querySelector('.headerBackButton');
|
|
|
|
headerHomeButton = skinHeader.querySelector('.headerHomeButton');
|
|
|
|
mainDrawerButton = skinHeader.querySelector('.mainDrawerButton');
|
|
|
|
headerUserButton = skinHeader.querySelector('.headerUserButton');
|
|
|
|
headerCastButton = skinHeader.querySelector('.headerCastButton');
|
|
|
|
headerAudioPlayerButton = skinHeader.querySelector('.headerAudioPlayerButton');
|
|
|
|
headerSearchButton = skinHeader.querySelector('.headerSearchButton');
|
|
|
|
headerSyncButton = skinHeader.querySelector('.headerSyncButton');
|
|
|
|
currentTimeText = skinHeader.querySelector('.currentTimeText');
|
|
|
|
|
|
|
|
retranslateUi();
|
|
|
|
lazyLoadViewMenuBarImages();
|
|
|
|
bindMenuEvents();
|
|
|
|
updateCastIcon();
|
|
|
|
updateClock();
|
|
|
|
}
|
|
|
|
|
|
|
|
function getCurrentApiClient() {
|
2023-07-06 13:39:48 -04:00
|
|
|
if (currentUser?.localUser) {
|
2023-04-19 01:56:05 -04:00
|
|
|
return ServerConnections.getApiClient(currentUser.localUser.ServerId);
|
|
|
|
}
|
2018-10-23 01:05:09 +03:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
return ServerConnections.currentApiClient();
|
|
|
|
}
|
2020-01-22 03:31:15 +03:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
function lazyLoadViewMenuBarImages() {
|
|
|
|
import('../components/images/imageLoader').then((imageLoader) => {
|
|
|
|
imageLoader.lazyChildren(skinHeader);
|
|
|
|
});
|
|
|
|
}
|
2020-01-22 03:31:15 +03:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
function onBackClick() {
|
|
|
|
appRouter.back();
|
|
|
|
}
|
2019-01-16 10:34:09 -05:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
function retranslateUi() {
|
|
|
|
if (headerBackButton) {
|
|
|
|
headerBackButton.title = globalize.translate('ButtonBack');
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
if (headerHomeButton) {
|
|
|
|
headerHomeButton.title = globalize.translate('Home');
|
2019-01-16 10:34:09 -05:00
|
|
|
}
|
2018-10-23 01:05:09 +03:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
if (mainDrawerButton) {
|
|
|
|
mainDrawerButton.title = globalize.translate('Menu');
|
2019-01-16 10:34:09 -05:00
|
|
|
}
|
2018-10-23 01:05:09 +03:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
if (headerSyncButton) {
|
|
|
|
headerSyncButton.title = globalize.translate('ButtonSyncPlay');
|
|
|
|
}
|
2022-02-24 19:03:42 +03:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
if (headerAudioPlayerButton) {
|
|
|
|
headerAudioPlayerButton.title = globalize.translate('ButtonPlayer');
|
|
|
|
}
|
2022-02-24 19:03:42 +03:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
if (headerCastButton) {
|
|
|
|
headerCastButton.title = globalize.translate('ButtonCast');
|
|
|
|
}
|
2022-02-24 19:03:42 +03:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
if (headerSearchButton) {
|
|
|
|
headerSearchButton.title = globalize.translate('Search');
|
|
|
|
}
|
2020-09-26 19:43:38 +03:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
if (headerUserButton) {
|
|
|
|
headerUserButton.title = globalize.translate('Settings');
|
|
|
|
}
|
|
|
|
}
|
2020-09-26 19:43:38 +03:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
function updateUserInHeader(user) {
|
|
|
|
retranslateUi();
|
2020-09-26 19:43:38 +03:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
let hasImage;
|
2022-02-24 19:03:42 +03:00
|
|
|
|
2023-07-06 13:39:48 -04:00
|
|
|
if (user?.name) {
|
2023-04-19 01:56:05 -04:00
|
|
|
if (user.imageUrl) {
|
|
|
|
const url = user.imageUrl;
|
|
|
|
updateHeaderUserButton(url);
|
|
|
|
hasImage = true;
|
2022-02-24 19:03:42 +03:00
|
|
|
}
|
2023-04-19 01:56:05 -04:00
|
|
|
headerUserButton.title = user.name;
|
|
|
|
headerUserButton.classList.remove('hide');
|
|
|
|
} else {
|
|
|
|
headerUserButton.classList.add('hide');
|
2020-09-26 19:43:38 +03:00
|
|
|
}
|
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
if (!hasImage) {
|
|
|
|
updateHeaderUserButton(null);
|
|
|
|
}
|
2018-10-23 01:05:09 +03:00
|
|
|
|
2023-07-06 13:39:48 -04:00
|
|
|
if (user?.localUser) {
|
2023-04-19 01:56:05 -04:00
|
|
|
if (headerHomeButton) {
|
|
|
|
headerHomeButton.classList.remove('hide');
|
2019-01-16 10:34:09 -05:00
|
|
|
}
|
2018-10-23 01:05:09 +03:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
if (headerSearchButton) {
|
|
|
|
headerSearchButton.classList.remove('hide');
|
2019-01-16 10:34:09 -05:00
|
|
|
}
|
2018-10-23 01:05:09 +03:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
if (!layoutManager.tv) {
|
|
|
|
headerCastButton.classList.remove('hide');
|
|
|
|
}
|
2020-04-04 18:20:39 +02:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
const policy = user.Policy ? user.Policy : user.localUser.Policy;
|
2020-04-04 18:20:39 +02:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
if (
|
|
|
|
// Button is present
|
|
|
|
headerSyncButton
|
2022-10-02 03:55:35 -04:00
|
|
|
// SyncPlay plugin is loaded
|
2023-03-08 11:49:19 -05:00
|
|
|
&& pluginManager.ofType(PluginType.SyncPlay).length > 0
|
2022-10-02 03:55:35 -04:00
|
|
|
// SyncPlay enabled for user
|
|
|
|
&& policy?.SyncPlayAccess !== 'None'
|
2023-04-19 01:56:05 -04:00
|
|
|
) {
|
|
|
|
headerSyncButton.classList.remove('hide');
|
2019-01-16 09:32:47 -05:00
|
|
|
}
|
2023-04-19 01:56:05 -04:00
|
|
|
} else {
|
|
|
|
headerHomeButton.classList.add('hide');
|
|
|
|
headerCastButton.classList.add('hide');
|
|
|
|
headerSyncButton.classList.add('hide');
|
2018-10-23 01:05:09 +03:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
if (headerSearchButton) {
|
|
|
|
headerSearchButton.classList.add('hide');
|
2019-01-16 10:34:09 -05:00
|
|
|
}
|
|
|
|
}
|
2018-10-23 01:05:09 +03:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
requiresUserRefresh = false;
|
|
|
|
}
|
2023-03-22 20:30:06 +03:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
function updateHeaderUserButton(src) {
|
|
|
|
if (src) {
|
|
|
|
headerUserButton.classList.add('headerUserButtonRound');
|
|
|
|
headerUserButton.innerHTML = '<div class="headerButton headerButtonRight paper-icon-button-light headerUserButtonRound" style="background-image:url(\'' + src + "');\"></div>";
|
|
|
|
} else {
|
|
|
|
headerUserButton.classList.remove('headerUserButtonRound');
|
|
|
|
headerUserButton.innerHTML = '<span class="material-icons person" aria-hidden="true"></span>';
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
2023-04-19 01:56:05 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
function updateClock() {
|
|
|
|
if (layoutManager.tv) {
|
|
|
|
currentTimeText.classList.remove('hide');
|
|
|
|
setInterval(function() {
|
|
|
|
currentTimeText.innerText = datetime.getDisplayTime(new Date());
|
|
|
|
}, 1000);
|
|
|
|
} else {
|
|
|
|
currentTimeText.classList.add('hide');
|
2019-01-16 10:34:09 -05:00
|
|
|
}
|
2023-04-19 01:56:05 -04:00
|
|
|
}
|
2019-01-16 10:34:09 -05:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
function showSearch() {
|
|
|
|
inputManager.handleCommand('search');
|
|
|
|
}
|
2018-10-23 01:05:09 +03:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
function onHeaderUserButtonClick() {
|
|
|
|
Dashboard.navigate('mypreferencesmenu.html');
|
|
|
|
}
|
2020-02-15 03:47:07 +03:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
function onHeaderHomeButtonClick() {
|
|
|
|
Dashboard.navigate('home.html');
|
|
|
|
}
|
2019-01-16 10:34:09 -05:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
function showAudioPlayer() {
|
|
|
|
return appRouter.showNowPlaying();
|
|
|
|
}
|
2018-10-23 01:05:09 +03:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
function bindMenuEvents() {
|
|
|
|
if (mainDrawerButton) {
|
|
|
|
mainDrawerButton.addEventListener('click', toggleMainDrawer);
|
2020-02-15 03:47:07 +03:00
|
|
|
}
|
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
if (headerBackButton) {
|
|
|
|
headerBackButton.addEventListener('click', onBackClick);
|
2020-02-15 03:47:07 +03:00
|
|
|
}
|
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
if (headerSearchButton) {
|
|
|
|
headerSearchButton.addEventListener('click', showSearch);
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
headerUserButton.addEventListener('click', onHeaderUserButtonClick);
|
|
|
|
headerHomeButton.addEventListener('click', onHeaderHomeButtonClick);
|
2018-10-23 01:05:09 +03:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
if (!layoutManager.tv) {
|
|
|
|
headerCastButton.addEventListener('click', onCastButtonClicked);
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
headerAudioPlayerButton.addEventListener('click', showAudioPlayer);
|
|
|
|
headerSyncButton.addEventListener('click', onSyncButtonClicked);
|
2020-04-01 17:53:14 +02:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
if (layoutManager.mobile) {
|
|
|
|
initHeadRoom(skinHeader);
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
2023-04-19 01:56:05 -04:00
|
|
|
Events.on(playbackManager, 'playbackstart', onPlaybackStart);
|
|
|
|
Events.on(playbackManager, 'playbackstop', onPlaybackStop);
|
|
|
|
}
|
|
|
|
|
|
|
|
function onPlaybackStart() {
|
|
|
|
if (playbackManager.isPlayingAudio() && layoutManager.tv) {
|
|
|
|
headerAudioPlayerButton.classList.remove('hide');
|
|
|
|
} else {
|
|
|
|
headerAudioPlayerButton.classList.add('hide');
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
2023-04-19 01:56:05 -04:00
|
|
|
}
|
2018-10-23 01:05:09 +03:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
function onPlaybackStop(e, stopInfo) {
|
|
|
|
if (stopInfo.nextMediaType != 'Audio') {
|
|
|
|
headerAudioPlayerButton.classList.add('hide');
|
2019-01-16 10:34:09 -05:00
|
|
|
}
|
2023-04-19 01:56:05 -04:00
|
|
|
}
|
2019-01-16 09:32:47 -05:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
function onCastButtonClicked() {
|
|
|
|
const btn = this;
|
2019-01-16 09:32:47 -05:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
import('../components/playback/playerSelectionMenu').then((playerSelectionMenu) => {
|
|
|
|
playerSelectionMenu.show(btn);
|
|
|
|
});
|
|
|
|
}
|
2018-10-23 01:05:09 +03:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
function onSyncButtonClicked() {
|
|
|
|
const btn = this;
|
|
|
|
groupSelectionMenu.show(btn);
|
|
|
|
}
|
|
|
|
|
|
|
|
function getItemHref(item, context) {
|
|
|
|
return appRouter.getRouteUrl(item, {
|
|
|
|
context: context
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
function toggleMainDrawer() {
|
|
|
|
if (navDrawerInstance.isVisible) {
|
|
|
|
closeMainDrawer();
|
|
|
|
} else {
|
|
|
|
openMainDrawer();
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
2023-04-19 01:56:05 -04:00
|
|
|
}
|
2018-10-23 01:05:09 +03:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
function openMainDrawer() {
|
|
|
|
navDrawerInstance.open();
|
|
|
|
}
|
2019-01-16 10:34:09 -05:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
function onMainDrawerOpened() {
|
|
|
|
if (layoutManager.mobile) {
|
|
|
|
document.body.classList.add('bodyWithPopupOpen');
|
|
|
|
}
|
|
|
|
}
|
2019-10-08 01:01:20 +03:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
function closeMainDrawer() {
|
|
|
|
navDrawerInstance.close();
|
|
|
|
}
|
2019-10-08 01:01:20 +03:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
function onMainDrawerSelect() {
|
|
|
|
if (navDrawerInstance.isVisible) {
|
|
|
|
onMainDrawerOpened();
|
|
|
|
} else {
|
|
|
|
document.body.classList.remove('bodyWithPopupOpen');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function refreshLibraryInfoInDrawer(user) {
|
|
|
|
let html = '';
|
|
|
|
html += '<div style="height:.5em;"></div>';
|
|
|
|
html += `<a is="emby-linkbutton" class="navMenuOption lnkMediaFolder" href="#/home.html"><span class="material-icons navMenuOptionIcon home" aria-hidden="true"></span><span class="navMenuOptionText">${globalize.translate('Home')}</span></a>`;
|
|
|
|
|
|
|
|
// placeholder for custom menu links
|
|
|
|
html += '<div class="customMenuOptions"></div>';
|
|
|
|
|
|
|
|
// libraries are added here
|
|
|
|
html += '<div class="libraryMenuOptions"></div>';
|
|
|
|
|
2023-07-06 13:39:48 -04:00
|
|
|
if (user.localUser?.Policy.IsAdministrator) {
|
2023-04-19 01:56:05 -04:00
|
|
|
html += '<div class="adminMenuOptions">';
|
|
|
|
html += '<h3 class="sidebarHeader">';
|
|
|
|
html += globalize.translate('HeaderAdmin');
|
|
|
|
html += '</h3>';
|
|
|
|
html += `<a is="emby-linkbutton" class="navMenuOption lnkMediaFolder lnkManageServer" data-itemid="dashboard" href="#/dashboard.html"><span class="material-icons navMenuOptionIcon dashboard" aria-hidden="true"></span><span class="navMenuOptionText">${globalize.translate('TabDashboard')}</span></a>`;
|
|
|
|
html += `<a is="emby-linkbutton" class="navMenuOption lnkMediaFolder editorViewMenu" data-itemid="editor" href="#/edititemmetadata.html"><span class="material-icons navMenuOptionIcon mode_edit" aria-hidden="true"></span><span class="navMenuOptionText">${globalize.translate('Metadata')}</span></a>`;
|
|
|
|
html += '</div>';
|
|
|
|
}
|
2022-01-12 10:39:21 +11:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
if (user.localUser) {
|
|
|
|
html += '<div class="userMenuOptions">';
|
|
|
|
html += '<h3 class="sidebarHeader">';
|
|
|
|
html += globalize.translate('HeaderUser');
|
|
|
|
html += '</h3>';
|
2022-01-12 10:39:21 +11:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
if (appHost.supports('multiserver')) {
|
|
|
|
html += `<a is="emby-linkbutton" class="navMenuOption lnkMediaFolder btnSelectServer" data-itemid="selectserver" href="#"><span class="material-icons navMenuOptionIcon storage" aria-hidden="true"></span><span class="navMenuOptionText">${globalize.translate('SelectServer')}</span></a>`;
|
2019-10-08 19:54:02 +03:00
|
|
|
}
|
2019-10-08 01:01:20 +03:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
html += `<a is="emby-linkbutton" class="navMenuOption lnkMediaFolder btnSettings" data-itemid="settings" href="#"><span class="material-icons navMenuOptionIcon settings" aria-hidden="true"></span><span class="navMenuOptionText">${globalize.translate('Settings')}</span></a>`;
|
|
|
|
html += `<a is="emby-linkbutton" class="navMenuOption lnkMediaFolder btnLogout" data-itemid="logout" href="#"><span class="material-icons navMenuOptionIcon exit_to_app" aria-hidden="true"></span><span class="navMenuOptionText">${globalize.translate('ButtonSignOut')}</span></a>`;
|
2019-10-08 01:01:20 +03:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
if (appHost.supports('exitmenu')) {
|
|
|
|
html += `<a is="emby-linkbutton" class="navMenuOption lnkMediaFolder exitApp" data-itemid="exitapp" href="#"><span class="material-icons navMenuOptionIcon close" aria-hidden="true"></span><span class="navMenuOptionText">${globalize.translate('ButtonExitApp')}</span></a>`;
|
2020-12-04 01:21:46 +01:00
|
|
|
}
|
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
html += '</div>';
|
|
|
|
}
|
2020-03-22 21:09:10 +01:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
// add buttons to navigation drawer
|
|
|
|
navDrawerScrollContainer.innerHTML = html;
|
2022-01-17 08:26:26 +11:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
const btnSelectServer = navDrawerScrollContainer.querySelector('.btnSelectServer');
|
|
|
|
if (btnSelectServer) {
|
|
|
|
btnSelectServer.addEventListener('click', onSelectServerClick);
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
const btnSettings = navDrawerScrollContainer.querySelector('.btnSettings');
|
|
|
|
if (btnSettings) {
|
|
|
|
btnSettings.addEventListener('click', onSettingsClick);
|
|
|
|
}
|
2019-01-16 10:34:09 -05:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
const btnExit = navDrawerScrollContainer.querySelector('.exitApp');
|
|
|
|
if (btnExit) {
|
|
|
|
btnExit.addEventListener('click', onExitAppClick);
|
2019-01-16 10:34:09 -05:00
|
|
|
}
|
2019-01-16 09:32:47 -05:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
const btnLogout = navDrawerScrollContainer.querySelector('.btnLogout');
|
|
|
|
if (btnLogout) {
|
|
|
|
btnLogout.addEventListener('click', onLogoutClick);
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
2023-04-19 01:56:05 -04:00
|
|
|
}
|
2018-10-23 01:05:09 +03:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
function refreshDashboardInfoInDrawer(page, apiClient) {
|
|
|
|
currentDrawerType = 'admin';
|
|
|
|
loadNavDrawer();
|
2019-01-16 10:34:09 -05:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
if (navDrawerScrollContainer.querySelector('.adminDrawerLogo')) {
|
|
|
|
updateDashboardMenuSelectedItem(page);
|
|
|
|
} else {
|
|
|
|
createDashboardMenu(page, apiClient);
|
|
|
|
}
|
|
|
|
}
|
2019-01-16 10:34:09 -05:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
function isUrlInCurrentView(url) {
|
|
|
|
return window.location.href.toString().toLowerCase().indexOf(url.toLowerCase()) !== -1;
|
|
|
|
}
|
2019-01-16 09:32:47 -05:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
function updateDashboardMenuSelectedItem(page) {
|
|
|
|
const links = navDrawerScrollContainer.querySelectorAll('.navMenuOption');
|
|
|
|
const currentViewId = page.id;
|
2019-01-16 10:34:09 -05:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
for (let i = 0, length = links.length; i < length; i++) {
|
|
|
|
let link = links[i];
|
|
|
|
let selected = false;
|
|
|
|
let pageIds = link.getAttribute('data-pageids');
|
2019-10-08 01:01:20 +03:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
if (pageIds) {
|
|
|
|
pageIds = pageIds.split('|');
|
|
|
|
selected = pageIds.indexOf(currentViewId) != -1;
|
2019-01-16 10:34:09 -05:00
|
|
|
}
|
2019-01-16 09:32:47 -05:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
let pageUrls = link.getAttribute('data-pageurls');
|
|
|
|
|
|
|
|
if (pageUrls) {
|
|
|
|
pageUrls = pageUrls.split('|');
|
|
|
|
selected = pageUrls.filter(isUrlInCurrentView).length > 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (selected) {
|
|
|
|
link.classList.add('navMenuOption-selected');
|
|
|
|
let title = '';
|
|
|
|
link = link.querySelector('.navMenuOptionText') || link;
|
|
|
|
title += (link.innerText || link.textContent).trim();
|
|
|
|
LibraryMenu.setTitle(title);
|
|
|
|
} else {
|
|
|
|
link.classList.remove('navMenuOption-selected');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function createToolsMenuList(pluginItems) {
|
|
|
|
const links = [{
|
|
|
|
name: globalize.translate('TabServer')
|
|
|
|
}, {
|
|
|
|
name: globalize.translate('TabDashboard'),
|
|
|
|
href: '#/dashboard.html',
|
|
|
|
pageIds: ['dashboardPage'],
|
|
|
|
icon: 'dashboard'
|
|
|
|
}, {
|
|
|
|
name: globalize.translate('General'),
|
|
|
|
href: '#/dashboardgeneral.html',
|
|
|
|
pageIds: ['dashboardGeneralPage'],
|
|
|
|
icon: 'settings'
|
|
|
|
}, {
|
|
|
|
name: globalize.translate('HeaderUsers'),
|
|
|
|
href: '#/userprofiles.html',
|
|
|
|
pageIds: ['userProfilesPage', 'newUserPage', 'editUserPage', 'userLibraryAccessPage', 'userParentalControlPage', 'userPasswordPage'],
|
|
|
|
icon: 'people'
|
|
|
|
}, {
|
|
|
|
name: globalize.translate('HeaderLibraries'),
|
|
|
|
href: '#/library.html',
|
|
|
|
pageIds: ['mediaLibraryPage', 'librarySettingsPage', 'libraryDisplayPage', 'metadataImagesConfigurationPage', 'metadataNfoPage'],
|
|
|
|
icon: 'folder'
|
|
|
|
}, {
|
|
|
|
name: globalize.translate('TitlePlayback'),
|
|
|
|
icon: 'play_arrow',
|
|
|
|
href: '#/encodingsettings.html',
|
|
|
|
pageIds: ['encodingSettingsPage', 'playbackConfigurationPage', 'streamingSettingsPage']
|
|
|
|
}];
|
|
|
|
addPluginPagesToMainMenu(links, pluginItems, 'server');
|
|
|
|
links.push({
|
|
|
|
divider: true,
|
|
|
|
name: globalize.translate('HeaderDevices')
|
|
|
|
});
|
|
|
|
links.push({
|
|
|
|
name: globalize.translate('HeaderDevices'),
|
|
|
|
href: '#/devices.html',
|
|
|
|
pageIds: ['devicesPage', 'devicePage'],
|
|
|
|
icon: 'devices'
|
|
|
|
});
|
|
|
|
links.push({
|
|
|
|
name: globalize.translate('HeaderActivity'),
|
2023-06-09 03:01:27 -04:00
|
|
|
href: '#/dashboard/activity',
|
2023-04-19 01:56:05 -04:00
|
|
|
pageIds: ['serverActivityPage'],
|
|
|
|
icon: 'assessment'
|
|
|
|
});
|
|
|
|
links.push({
|
|
|
|
name: globalize.translate('DLNA'),
|
|
|
|
href: '#/dlnasettings.html',
|
|
|
|
pageIds: ['dlnaSettingsPage', 'dlnaProfilesPage', 'dlnaProfilePage'],
|
|
|
|
icon: 'input'
|
|
|
|
});
|
|
|
|
links.push({
|
|
|
|
divider: true,
|
|
|
|
name: globalize.translate('LiveTV')
|
|
|
|
});
|
|
|
|
links.push({
|
|
|
|
name: globalize.translate('LiveTV'),
|
|
|
|
href: '#/livetvstatus.html',
|
|
|
|
pageIds: ['liveTvStatusPage', 'liveTvTunerPage'],
|
|
|
|
icon: 'live_tv'
|
|
|
|
});
|
|
|
|
links.push({
|
|
|
|
name: globalize.translate('HeaderDVR'),
|
|
|
|
href: '#/livetvsettings.html',
|
|
|
|
pageIds: ['liveTvSettingsPage'],
|
|
|
|
icon: 'dvr'
|
|
|
|
});
|
|
|
|
addPluginPagesToMainMenu(links, pluginItems, 'livetv');
|
|
|
|
links.push({
|
|
|
|
divider: true,
|
|
|
|
name: globalize.translate('TabAdvanced')
|
|
|
|
});
|
|
|
|
links.push({
|
|
|
|
name: globalize.translate('TabNetworking'),
|
|
|
|
icon: 'cloud',
|
|
|
|
href: '#/networking.html',
|
|
|
|
pageIds: ['networkingPage']
|
|
|
|
});
|
|
|
|
links.push({
|
|
|
|
name: globalize.translate('HeaderApiKeys'),
|
|
|
|
icon: 'vpn_key',
|
|
|
|
href: '#/apikeys.html',
|
|
|
|
pageIds: ['apiKeysPage']
|
|
|
|
});
|
|
|
|
links.push({
|
|
|
|
name: globalize.translate('TabLogs'),
|
|
|
|
href: '#/log.html',
|
|
|
|
pageIds: ['logPage'],
|
|
|
|
icon: 'bug_report'
|
|
|
|
});
|
|
|
|
links.push({
|
2023-05-19 11:43:25 -04:00
|
|
|
name: globalize.translate('Notifications'),
|
2023-04-19 01:56:05 -04:00
|
|
|
icon: 'notifications',
|
2023-05-19 11:43:25 -04:00
|
|
|
href: '#/notificationsettings.html'
|
2023-04-19 01:56:05 -04:00
|
|
|
});
|
|
|
|
links.push({
|
|
|
|
name: globalize.translate('TabPlugins'),
|
|
|
|
icon: 'shopping_cart',
|
|
|
|
href: '#/installedplugins.html',
|
|
|
|
pageIds: ['pluginsPage', 'pluginCatalogPage']
|
|
|
|
});
|
|
|
|
links.push({
|
|
|
|
name: globalize.translate('TabScheduledTasks'),
|
|
|
|
href: '#/scheduledtasks.html',
|
|
|
|
pageIds: ['scheduledTasksPage', 'scheduledTaskPage'],
|
|
|
|
icon: 'schedule'
|
|
|
|
});
|
|
|
|
if (hasUnsortedPlugins(pluginItems)) {
|
2019-01-16 10:34:09 -05:00
|
|
|
links.push({
|
|
|
|
divider: true,
|
2023-04-19 01:56:05 -04:00
|
|
|
name: globalize.translate('TabPlugins')
|
2019-01-16 10:34:09 -05:00
|
|
|
});
|
2023-04-19 01:56:05 -04:00
|
|
|
addPluginPagesToMainMenu(links, pluginItems);
|
2019-01-16 10:34:09 -05:00
|
|
|
}
|
2023-04-19 01:56:05 -04:00
|
|
|
return links;
|
|
|
|
}
|
2019-01-16 10:34:09 -05:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
function hasUnsortedPlugins(pluginItems) {
|
|
|
|
for (const pluginItem of pluginItems) {
|
|
|
|
if (pluginItem.EnableInMainMenu && pluginItem.MenuSection === undefined) {
|
|
|
|
return true;
|
2021-01-11 21:34:31 -06:00
|
|
|
}
|
|
|
|
}
|
2023-04-19 01:56:05 -04:00
|
|
|
return false;
|
|
|
|
}
|
2021-01-11 21:34:31 -06:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
function addPluginPagesToMainMenu(links, pluginItems, section) {
|
|
|
|
for (const pluginItem of pluginItems) {
|
|
|
|
if (pluginItem.EnableInMainMenu && pluginItem.MenuSection === section) {
|
|
|
|
links.push({
|
|
|
|
name: pluginItem.DisplayName,
|
|
|
|
icon: pluginItem.MenuIcon || 'folder',
|
|
|
|
href: Dashboard.getPluginUrl(pluginItem.Name),
|
|
|
|
pageUrls: [Dashboard.getPluginUrl(pluginItem.Name)]
|
|
|
|
});
|
2019-01-16 10:34:09 -05:00
|
|
|
}
|
|
|
|
}
|
2023-04-19 01:56:05 -04:00
|
|
|
}
|
2019-01-16 09:32:47 -05:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
function getToolsMenuLinks(apiClient) {
|
|
|
|
return apiClient.getJSON(apiClient.getUrl('web/configurationpages') + '?pageType=PluginConfiguration&EnableInMainMenu=true').then(createToolsMenuList, function () {
|
|
|
|
return createToolsMenuList([]);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
function getToolsLinkHtml(item) {
|
|
|
|
let menuHtml = '';
|
|
|
|
let pageIds = item.pageIds ? item.pageIds.join('|') : '';
|
|
|
|
pageIds = pageIds ? ' data-pageids="' + pageIds + '"' : '';
|
|
|
|
let pageUrls = item.pageUrls ? item.pageUrls.join('|') : '';
|
|
|
|
pageUrls = pageUrls ? ' data-pageurls="' + pageUrls + '"' : '';
|
|
|
|
menuHtml += '<a is="emby-linkbutton" class="navMenuOption" href="' + item.href + '"' + pageIds + pageUrls + '>';
|
|
|
|
|
|
|
|
if (item.icon) {
|
|
|
|
menuHtml += '<span class="material-icons navMenuOptionIcon ' + item.icon + '" aria-hidden="true"></span>';
|
2019-01-16 09:32:47 -05:00
|
|
|
}
|
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
menuHtml += '<span class="navMenuOptionText">';
|
|
|
|
menuHtml += escapeHtml(item.name);
|
|
|
|
menuHtml += '</span>';
|
|
|
|
return menuHtml + '</a>';
|
|
|
|
}
|
|
|
|
|
|
|
|
function getToolsMenuHtml(apiClient) {
|
|
|
|
return getToolsMenuLinks(apiClient).then(function (items) {
|
2020-07-28 22:04:01 +01:00
|
|
|
let menuHtml = '';
|
2023-04-19 01:56:05 -04:00
|
|
|
menuHtml += '<div class="drawerContent">';
|
2019-01-16 09:32:47 -05:00
|
|
|
|
2023-05-04 11:27:15 -04:00
|
|
|
for (const item of items) {
|
2023-04-19 01:56:05 -04:00
|
|
|
if (item.href) {
|
|
|
|
menuHtml += getToolsLinkHtml(item);
|
|
|
|
} else if (item.name) {
|
|
|
|
menuHtml += '<h3 class="sidebarHeader">';
|
|
|
|
menuHtml += escapeHtml(item.name);
|
|
|
|
menuHtml += '</h3>';
|
2019-01-16 10:34:09 -05:00
|
|
|
}
|
2023-04-19 01:56:05 -04:00
|
|
|
}
|
2019-01-16 10:34:09 -05:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
return menuHtml + '</div>';
|
|
|
|
});
|
|
|
|
}
|
2019-01-16 10:34:09 -05:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
function createDashboardMenu(page, apiClient) {
|
|
|
|
return getToolsMenuHtml(apiClient).then(function (toolsMenuHtml) {
|
|
|
|
let html = '';
|
|
|
|
html += '<a class="adminDrawerLogo clearLink" is="emby-linkbutton" href="#/home.html">';
|
|
|
|
html += '<img src="assets/img/icon-transparent.png" />';
|
|
|
|
html += '</a>';
|
|
|
|
html += toolsMenuHtml;
|
|
|
|
navDrawerScrollContainer.innerHTML = html;
|
|
|
|
updateDashboardMenuSelectedItem(page);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
function onSidebarLinkClick() {
|
|
|
|
const section = this.getElementsByClassName('sectionName')[0];
|
|
|
|
const text = section ? section.innerHTML : this.innerHTML;
|
|
|
|
LibraryMenu.setTitle(text);
|
|
|
|
}
|
|
|
|
|
|
|
|
function getUserViews(apiClient, userId) {
|
|
|
|
return apiClient.getUserViews({}, userId).then(function (result) {
|
|
|
|
const items = result.Items;
|
|
|
|
const list = [];
|
|
|
|
|
|
|
|
for (let i = 0, length = items.length; i < length; i++) {
|
|
|
|
const view = items[i];
|
|
|
|
list.push(view);
|
|
|
|
|
|
|
|
if (view.CollectionType == 'livetv') {
|
|
|
|
view.ImageTags = {};
|
|
|
|
view.icon = 'live_tv';
|
|
|
|
const guideView = Object.assign({}, view);
|
|
|
|
guideView.Name = globalize.translate('Guide');
|
|
|
|
guideView.ImageTags = {};
|
|
|
|
guideView.icon = 'dvr';
|
|
|
|
guideView.url = '#/livetv.html?tab=1';
|
|
|
|
list.push(guideView);
|
2019-01-16 10:34:09 -05:00
|
|
|
}
|
2023-04-19 01:56:05 -04:00
|
|
|
}
|
2019-01-16 10:34:09 -05:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
return list;
|
|
|
|
});
|
|
|
|
}
|
2019-01-16 09:32:47 -05:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
function showBySelector(selector, show) {
|
|
|
|
const elem = document.querySelector(selector);
|
2019-01-16 09:32:47 -05:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
if (elem) {
|
|
|
|
if (show) {
|
|
|
|
elem.classList.remove('hide');
|
|
|
|
} else {
|
|
|
|
elem.classList.add('hide');
|
2019-01-16 10:34:09 -05:00
|
|
|
}
|
2019-01-16 09:32:47 -05:00
|
|
|
}
|
2023-04-19 01:56:05 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
function updateLibraryMenu(user) {
|
|
|
|
if (!user) {
|
|
|
|
showBySelector('.libraryMenuDownloads', false);
|
|
|
|
showBySelector('.lnkSyncToOtherDevices', false);
|
|
|
|
showBySelector('.userMenuOptions', false);
|
|
|
|
return;
|
|
|
|
}
|
2019-01-16 09:32:47 -05:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
if (user.Policy.EnableContentDownloading) {
|
|
|
|
showBySelector('.lnkSyncToOtherDevices', true);
|
|
|
|
} else {
|
|
|
|
showBySelector('.lnkSyncToOtherDevices', false);
|
|
|
|
}
|
2019-01-16 09:32:47 -05:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
if (user.Policy.EnableContentDownloading && appHost.supports('sync')) {
|
|
|
|
showBySelector('.libraryMenuDownloads', true);
|
|
|
|
} else {
|
|
|
|
showBySelector('.libraryMenuDownloads', false);
|
|
|
|
}
|
2019-01-16 10:34:09 -05:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
const userId = Dashboard.getCurrentUserId();
|
|
|
|
const apiClient = getCurrentApiClient();
|
|
|
|
|
|
|
|
const customMenuOptions = document.querySelector('.customMenuOptions');
|
|
|
|
if (customMenuOptions) {
|
|
|
|
getMenuLinks().then(links => {
|
|
|
|
links.forEach(link => {
|
|
|
|
const option = document.createElement('a', 'emby-linkbutton');
|
|
|
|
option.classList.add('navMenuOption', 'lnkMediaFolder');
|
|
|
|
option.rel = 'noopener noreferrer';
|
|
|
|
option.target = '_blank';
|
|
|
|
option.href = link.url;
|
|
|
|
|
|
|
|
const icon = document.createElement('span');
|
|
|
|
icon.className = `material-icons navMenuOptionIcon ${link.icon || 'link'}`;
|
|
|
|
icon.setAttribute('aria-hidden', 'true');
|
|
|
|
option.appendChild(icon);
|
|
|
|
|
|
|
|
const label = document.createElement('span');
|
|
|
|
label.className = 'navMenuOptionText';
|
|
|
|
label.textContent = link.name;
|
|
|
|
option.appendChild(label);
|
|
|
|
|
|
|
|
customMenuOptions.appendChild(option);
|
2021-06-10 13:38:24 -04:00
|
|
|
});
|
2023-04-19 01:56:05 -04:00
|
|
|
});
|
|
|
|
}
|
2021-06-10 13:38:24 -04:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
const libraryMenuOptions = document.querySelector('.libraryMenuOptions');
|
2019-01-16 10:34:09 -05:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
if (libraryMenuOptions) {
|
|
|
|
getUserViews(apiClient, userId).then(function (result) {
|
|
|
|
const items = result;
|
|
|
|
let html = `<h3 class="sidebarHeader">${globalize.translate('HeaderMedia')}</h3>`;
|
|
|
|
html += items.map(function (i) {
|
|
|
|
const icon = i.icon || imageHelper.getLibraryIcon(i.CollectionType);
|
|
|
|
const itemId = i.Id;
|
2019-10-08 01:01:20 +03:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
return `<a is="emby-linkbutton" data-itemid="${itemId}" class="lnkMediaFolder navMenuOption" href="${getItemHref(i, i.CollectionType)}">
|
2022-02-24 20:15:24 +03:00
|
|
|
<span class="material-icons navMenuOptionIcon ${icon}" aria-hidden="true"></span>
|
2022-01-30 00:27:26 +03:00
|
|
|
<span class="sectionName navMenuOptionText">${escapeHtml(i.Name)}</span>
|
2020-05-14 23:25:22 +02:00
|
|
|
</a>`;
|
2023-04-19 01:56:05 -04:00
|
|
|
}).join('');
|
|
|
|
libraryMenuOptions.innerHTML = html;
|
|
|
|
const elem = libraryMenuOptions;
|
|
|
|
const sidebarLinks = elem.querySelectorAll('.navMenuOption');
|
|
|
|
|
|
|
|
for (const sidebarLink of sidebarLinks) {
|
|
|
|
sidebarLink.removeEventListener('click', onSidebarLinkClick);
|
|
|
|
sidebarLink.addEventListener('click', onSidebarLinkClick);
|
|
|
|
}
|
|
|
|
});
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
2023-04-19 01:56:05 -04:00
|
|
|
}
|
2018-10-23 01:05:09 +03:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
function getTopParentId() {
|
|
|
|
return getParameterByName('topParentId') || null;
|
|
|
|
}
|
2018-10-23 01:05:09 +03:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
function onMainDrawerClick(e) {
|
|
|
|
if (dom.parentWithTag(e.target, 'A')) {
|
|
|
|
setTimeout(closeMainDrawer, 30);
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
2023-04-19 01:56:05 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
function onSelectServerClick() {
|
|
|
|
Dashboard.selectServer();
|
|
|
|
}
|
|
|
|
|
|
|
|
function onSettingsClick() {
|
|
|
|
Dashboard.navigate('mypreferencesmenu.html');
|
|
|
|
}
|
|
|
|
|
|
|
|
function onExitAppClick() {
|
|
|
|
appHost.exit();
|
|
|
|
}
|
|
|
|
|
|
|
|
function onLogoutClick() {
|
|
|
|
Dashboard.logout();
|
|
|
|
}
|
|
|
|
|
|
|
|
function updateCastIcon() {
|
|
|
|
const context = document;
|
|
|
|
const info = playbackManager.getPlayerInfo();
|
|
|
|
const icon = headerCastButton.querySelector('.material-icons');
|
|
|
|
|
|
|
|
icon.classList.remove('cast_connected', 'cast');
|
|
|
|
|
|
|
|
if (info && !info.isLocalPlayer) {
|
|
|
|
icon.classList.add('cast_connected');
|
|
|
|
headerCastButton.classList.add('castButton-active');
|
|
|
|
context.querySelector('.headerSelectedPlayer').innerText = info.deviceName || info.name;
|
|
|
|
} else {
|
|
|
|
icon.classList.add('cast');
|
|
|
|
headerCastButton.classList.remove('castButton-active');
|
|
|
|
context.querySelector('.headerSelectedPlayer').innerHTML = '';
|
2020-12-04 01:21:46 +01:00
|
|
|
}
|
2023-04-19 01:56:05 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
function updateLibraryNavLinks(page) {
|
|
|
|
const isLiveTvPage = page.classList.contains('liveTvPage');
|
|
|
|
const isChannelsPage = page.classList.contains('channelsPage');
|
|
|
|
const isEditorPage = page.classList.contains('metadataEditorPage');
|
|
|
|
const isMySyncPage = page.classList.contains('mySyncPage');
|
|
|
|
const id = isLiveTvPage || isChannelsPage || isEditorPage || isMySyncPage || page.classList.contains('allLibraryPage') ? '' : getTopParentId() || '';
|
|
|
|
const elems = document.getElementsByClassName('lnkMediaFolder');
|
|
|
|
|
|
|
|
for (let i = 0, length = elems.length; i < length; i++) {
|
|
|
|
const lnkMediaFolder = elems[i];
|
|
|
|
const itemId = lnkMediaFolder.getAttribute('data-itemid');
|
|
|
|
|
|
|
|
if (isChannelsPage && itemId === 'channels') {
|
|
|
|
lnkMediaFolder.classList.add('navMenuOption-selected');
|
|
|
|
} else if (isLiveTvPage && itemId === 'livetv') {
|
|
|
|
lnkMediaFolder.classList.add('navMenuOption-selected');
|
|
|
|
} else if (isEditorPage && itemId === 'editor') {
|
|
|
|
lnkMediaFolder.classList.add('navMenuOption-selected');
|
|
|
|
} else if (isMySyncPage && itemId === 'manageoffline' && window.location.href.toString().indexOf('mode=download') != -1) {
|
|
|
|
lnkMediaFolder.classList.add('navMenuOption-selected');
|
|
|
|
} else if (isMySyncPage && itemId === 'syncotherdevices' && window.location.href.toString().indexOf('mode=download') == -1) {
|
|
|
|
lnkMediaFolder.classList.add('navMenuOption-selected');
|
|
|
|
} else if (id && itemId == id) {
|
|
|
|
lnkMediaFolder.classList.add('navMenuOption-selected');
|
|
|
|
} else {
|
|
|
|
lnkMediaFolder.classList.remove('navMenuOption-selected');
|
|
|
|
}
|
2022-01-17 08:26:26 +11:00
|
|
|
}
|
2023-04-19 01:56:05 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
function updateMenuForPageType(isDashboardPage, isLibraryPage) {
|
|
|
|
let newPageType = 3;
|
|
|
|
if (isDashboardPage) {
|
|
|
|
newPageType = 2;
|
|
|
|
} else if (isLibraryPage) {
|
|
|
|
newPageType = 1;
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
if (currentPageType !== newPageType) {
|
|
|
|
currentPageType = newPageType;
|
2019-01-16 09:32:47 -05:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
if (isDashboardPage && !layoutManager.mobile) {
|
|
|
|
skinHeader.classList.add('headroomDisabled');
|
2019-01-16 09:32:47 -05:00
|
|
|
} else {
|
2023-04-19 01:56:05 -04:00
|
|
|
skinHeader.classList.remove('headroomDisabled');
|
2019-01-16 10:34:09 -05:00
|
|
|
}
|
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
const bodyClassList = document.body.classList;
|
2019-01-16 09:32:47 -05:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
if (isLibraryPage) {
|
|
|
|
bodyClassList.add('libraryDocument');
|
|
|
|
bodyClassList.remove('dashboardDocument');
|
|
|
|
bodyClassList.remove('hideMainDrawer');
|
2019-01-16 09:32:47 -05:00
|
|
|
|
2023-09-12 17:02:06 -04:00
|
|
|
if (navDrawerInstance) {
|
|
|
|
navDrawerInstance.setEdgeSwipeEnabled(true);
|
|
|
|
}
|
|
|
|
} else if (isDashboardPage) {
|
|
|
|
bodyClassList.remove('libraryDocument');
|
|
|
|
bodyClassList.add('dashboardDocument');
|
|
|
|
bodyClassList.remove('hideMainDrawer');
|
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
if (navDrawerInstance) {
|
|
|
|
navDrawerInstance.setEdgeSwipeEnabled(true);
|
2019-01-16 10:34:09 -05:00
|
|
|
}
|
2023-04-19 01:56:05 -04:00
|
|
|
} else {
|
2023-09-12 17:02:06 -04:00
|
|
|
bodyClassList.remove('libraryDocument');
|
|
|
|
bodyClassList.remove('dashboardDocument');
|
|
|
|
bodyClassList.add('hideMainDrawer');
|
|
|
|
|
|
|
|
if (navDrawerInstance) {
|
|
|
|
navDrawerInstance.setEdgeSwipeEnabled(false);
|
2019-01-16 10:34:09 -05:00
|
|
|
}
|
|
|
|
}
|
2019-01-16 09:32:47 -05:00
|
|
|
}
|
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
if (requiresUserRefresh) {
|
|
|
|
ServerConnections.user(getCurrentApiClient()).then(updateUserInHeader);
|
2019-01-16 09:32:47 -05:00
|
|
|
}
|
2023-04-19 01:56:05 -04:00
|
|
|
}
|
2019-01-16 09:32:47 -05:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
function updateTitle(page) {
|
|
|
|
const title = page.getAttribute('data-title');
|
2019-01-16 09:32:47 -05:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
if (title) {
|
|
|
|
LibraryMenu.setTitle(title);
|
|
|
|
} else if (page.classList.contains('standalonePage')) {
|
|
|
|
LibraryMenu.setDefaultTitle();
|
2019-01-16 09:32:47 -05:00
|
|
|
}
|
2023-04-19 01:56:05 -04:00
|
|
|
}
|
2019-01-16 09:32:47 -05:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
function updateBackButton(page) {
|
|
|
|
if (headerBackButton) {
|
|
|
|
if (page.getAttribute('data-backbutton') !== 'false' && appRouter.canGoBack()) {
|
|
|
|
headerBackButton.classList.remove('hide');
|
2019-01-19 11:05:30 -05:00
|
|
|
} else {
|
2023-04-19 01:56:05 -04:00
|
|
|
headerBackButton.classList.add('hide');
|
2019-01-19 11:05:30 -05:00
|
|
|
}
|
2019-01-16 09:32:47 -05:00
|
|
|
}
|
2023-04-19 01:56:05 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
function initHeadRoom(elem) {
|
|
|
|
const headroom = new Headroom(elem);
|
|
|
|
headroom.init();
|
|
|
|
}
|
2019-01-16 09:32:47 -05:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
function refreshLibraryDrawer(user) {
|
|
|
|
loadNavDrawer();
|
|
|
|
currentDrawerType = 'library';
|
|
|
|
|
|
|
|
if (user) {
|
|
|
|
Promise.resolve(user);
|
|
|
|
} else {
|
|
|
|
ServerConnections.user(getCurrentApiClient()).then(function (userResult) {
|
|
|
|
refreshLibraryInfoInDrawer(userResult);
|
|
|
|
updateLibraryMenu(userResult.localUser);
|
|
|
|
});
|
2019-01-16 10:34:09 -05:00
|
|
|
}
|
2023-04-19 01:56:05 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
function getNavDrawerOptions() {
|
|
|
|
let drawerWidth = window.screen.availWidth - 50;
|
|
|
|
drawerWidth = Math.max(drawerWidth, 240);
|
|
|
|
drawerWidth = Math.min(drawerWidth, 320);
|
|
|
|
return {
|
|
|
|
target: navDrawerElement,
|
|
|
|
onChange: onMainDrawerSelect,
|
|
|
|
width: drawerWidth
|
|
|
|
};
|
|
|
|
}
|
2019-01-16 09:32:47 -05:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
function loadNavDrawer() {
|
|
|
|
if (navDrawerInstance) {
|
|
|
|
return Promise.resolve(navDrawerInstance);
|
|
|
|
}
|
2019-01-16 09:32:47 -05:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
navDrawerElement = document.querySelector('.mainDrawer');
|
|
|
|
navDrawerScrollContainer = navDrawerElement.querySelector('.scrollContainer');
|
|
|
|
navDrawerScrollContainer.addEventListener('click', onMainDrawerClick);
|
|
|
|
return new Promise(function (resolve) {
|
|
|
|
import('../libraries/navdrawer/navdrawer').then(({ default: NavDrawer }) => {
|
|
|
|
navDrawerInstance = new NavDrawer(getNavDrawerOptions());
|
2019-10-08 01:01:20 +03:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
if (!layoutManager.tv) {
|
|
|
|
navDrawerElement.classList.remove('hide');
|
|
|
|
}
|
2019-10-08 01:01:20 +03:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
resolve(navDrawerInstance);
|
2019-01-16 10:34:09 -05:00
|
|
|
});
|
2023-04-19 01:56:05 -04:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
let navDrawerElement;
|
|
|
|
let navDrawerScrollContainer;
|
|
|
|
let navDrawerInstance;
|
|
|
|
let mainDrawerButton;
|
|
|
|
let headerHomeButton;
|
|
|
|
let currentDrawerType;
|
|
|
|
let pageTitleElement;
|
|
|
|
let headerBackButton;
|
|
|
|
let headerUserButton;
|
|
|
|
let currentUser;
|
|
|
|
let headerCastButton;
|
|
|
|
let headerSearchButton;
|
|
|
|
let headerAudioPlayerButton;
|
|
|
|
let headerSyncButton;
|
|
|
|
let currentTimeText;
|
|
|
|
const enableLibraryNavDrawer = layoutManager.desktop;
|
|
|
|
const enableLibraryNavDrawerHome = !layoutManager.tv;
|
|
|
|
const skinHeader = document.querySelector('.skinHeader');
|
|
|
|
let requiresUserRefresh = true;
|
|
|
|
|
|
|
|
function setTabs (type, selectedIndex, builder) {
|
|
|
|
import('../components/maintabsmanager').then((mainTabsManager) => {
|
|
|
|
if (type) {
|
|
|
|
mainTabsManager.setTabs(viewManager.currentView(), selectedIndex, builder, function () {
|
|
|
|
return [];
|
|
|
|
});
|
|
|
|
} else {
|
|
|
|
mainTabsManager.setTabs(null);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
2019-01-16 10:34:09 -05:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
function setDefaultTitle () {
|
|
|
|
if (!pageTitleElement) {
|
|
|
|
pageTitleElement = document.querySelector('.pageTitle');
|
2020-07-28 22:09:56 +01:00
|
|
|
}
|
2019-01-16 09:32:47 -05:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
if (pageTitleElement) {
|
|
|
|
pageTitleElement.classList.add('pageTitleWithLogo');
|
|
|
|
pageTitleElement.classList.add('pageTitleWithDefaultLogo');
|
|
|
|
pageTitleElement.style.backgroundImage = null;
|
|
|
|
pageTitleElement.innerHTML = '';
|
|
|
|
}
|
2019-01-16 09:32:47 -05:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
document.title = 'Jellyfin';
|
|
|
|
}
|
2019-01-16 09:32:47 -05:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
function setTitle (title) {
|
|
|
|
if (title == null) {
|
|
|
|
LibraryMenu.setDefaultTitle();
|
|
|
|
return;
|
2020-07-28 22:09:56 +01:00
|
|
|
}
|
2019-01-16 09:32:47 -05:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
if (title === '-') {
|
|
|
|
title = '';
|
|
|
|
}
|
2019-01-16 09:32:47 -05:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
const html = title;
|
2019-01-16 09:32:47 -05:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
if (!pageTitleElement) {
|
|
|
|
pageTitleElement = document.querySelector('.pageTitle');
|
|
|
|
}
|
2019-01-16 09:32:47 -05:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
if (pageTitleElement) {
|
|
|
|
pageTitleElement.classList.remove('pageTitleWithLogo');
|
|
|
|
pageTitleElement.classList.remove('pageTitleWithDefaultLogo');
|
|
|
|
pageTitleElement.style.backgroundImage = null;
|
|
|
|
pageTitleElement.innerText = html || '';
|
|
|
|
}
|
2020-07-28 22:09:56 +01:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
document.title = title || 'Jellyfin';
|
|
|
|
}
|
2020-07-28 22:09:56 +01:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
function setTransparentMenu (transparent) {
|
|
|
|
if (transparent) {
|
|
|
|
skinHeader.classList.add('semiTransparent');
|
|
|
|
} else {
|
|
|
|
skinHeader.classList.remove('semiTransparent');
|
2020-07-28 22:09:56 +01:00
|
|
|
}
|
2023-04-19 01:56:05 -04:00
|
|
|
}
|
2020-07-28 22:09:56 +01:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
let currentPageType;
|
|
|
|
pageClassOn('pagebeforeshow', 'page', function () {
|
|
|
|
if (!this.classList.contains('withTabs')) {
|
|
|
|
LibraryMenu.setTabs(null);
|
2020-07-28 22:09:56 +01:00
|
|
|
}
|
2023-04-19 01:56:05 -04:00
|
|
|
});
|
2020-07-28 22:09:56 +01:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
pageClassOn('pageshow', 'page', function (e) {
|
|
|
|
const page = this;
|
|
|
|
const isDashboardPage = page.classList.contains('type-interior');
|
|
|
|
const isHomePage = page.classList.contains('homePage');
|
|
|
|
const isLibraryPage = !isDashboardPage && page.classList.contains('libraryPage');
|
|
|
|
const apiClient = getCurrentApiClient();
|
2020-07-28 22:09:56 +01:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
if (isDashboardPage) {
|
|
|
|
if (mainDrawerButton) {
|
|
|
|
mainDrawerButton.classList.remove('hide');
|
|
|
|
}
|
2019-01-16 09:32:47 -05:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
refreshDashboardInfoInDrawer(page, apiClient);
|
|
|
|
} else {
|
|
|
|
if (mainDrawerButton) {
|
|
|
|
if (enableLibraryNavDrawer || (isHomePage && enableLibraryNavDrawerHome)) {
|
2020-05-04 12:44:12 +02:00
|
|
|
mainDrawerButton.classList.remove('hide');
|
2023-04-19 01:56:05 -04:00
|
|
|
} else {
|
|
|
|
mainDrawerButton.classList.add('hide');
|
2019-01-16 10:34:09 -05:00
|
|
|
}
|
2023-04-19 01:56:05 -04:00
|
|
|
}
|
2019-01-16 09:32:47 -05:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
if (currentDrawerType !== 'library') {
|
|
|
|
refreshLibraryDrawer();
|
2019-01-16 10:34:09 -05:00
|
|
|
}
|
2023-04-19 01:56:05 -04:00
|
|
|
}
|
2019-01-16 10:34:09 -05:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
updateMenuForPageType(isDashboardPage, isLibraryPage);
|
2019-01-16 10:34:09 -05:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
// TODO: Seems to do nothing? Check if needed (also in other views).
|
|
|
|
if (!e.detail.isRestored) {
|
|
|
|
window.scrollTo(0, 0);
|
|
|
|
}
|
2019-01-16 10:34:09 -05:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
updateTitle(page);
|
|
|
|
updateBackButton(page);
|
|
|
|
updateLibraryNavLinks(page);
|
|
|
|
});
|
2019-01-16 10:34:09 -05:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
Events.on(ServerConnections, 'localusersignedin', function (e, user) {
|
|
|
|
const currentApiClient = ServerConnections.getApiClient(user.ServerId);
|
2020-05-01 12:07:36 +02:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
currentDrawerType = null;
|
|
|
|
currentUser = {
|
|
|
|
localUser: user
|
|
|
|
};
|
2020-05-01 12:07:36 +02:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
loadNavDrawer();
|
2020-05-01 12:07:36 +02:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
ServerConnections.user(currentApiClient).then(function (userResult) {
|
|
|
|
currentUser = userResult;
|
|
|
|
updateUserInHeader(userResult);
|
2019-01-16 10:34:09 -05:00
|
|
|
});
|
2023-04-19 01:56:05 -04:00
|
|
|
});
|
2020-07-28 22:09:56 +01:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
Events.on(ServerConnections, 'localusersignedout', function () {
|
|
|
|
currentUser = {};
|
|
|
|
updateUserInHeader();
|
|
|
|
});
|
2020-07-28 22:09:56 +01:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
Events.on(playbackManager, 'playerchange', updateCastIcon);
|
2020-07-22 18:49:35 +02:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
loadNavDrawer();
|
2020-07-28 22:04:01 +01:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
const LibraryMenu = {
|
|
|
|
getTopParentId: getTopParentId,
|
|
|
|
onHardwareMenuButtonClick: function () {
|
|
|
|
toggleMainDrawer();
|
|
|
|
},
|
|
|
|
setTabs: setTabs,
|
|
|
|
setDefaultTitle: setDefaultTitle,
|
|
|
|
setTitle: setTitle,
|
|
|
|
setTransparentMenu: setTransparentMenu
|
|
|
|
};
|
2020-07-28 22:09:56 +01:00
|
|
|
|
2023-04-19 01:56:05 -04:00
|
|
|
window.LibraryMenu = LibraryMenu;
|
|
|
|
renderHeader();
|
2020-07-28 22:04:01 +01:00
|
|
|
|
|
|
|
export default LibraryMenu;
|
|
|
|
|