jellyfish-web/src/scripts/libraryMenu.js

854 lines
28 KiB
JavaScript
Raw Normal View History

2022-01-30 00:27:26 +03:00
import escapeHtml from 'escape-html';
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';
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';
import { getMenuLinks } from '../scripts/settings/webSettings';
2022-05-21 05:40:25 -05:00
import Dashboard, { pageClassOn } from '../utils/dashboard';
import ServerConnections from '../components/ServerConnections';
2023-03-08 11:49:19 -05:00
import { PluginType } from '../types/plugin.ts';
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';
import '../styles/scrollstyles.scss';
import '../styles/flexstyles.scss';
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();
}
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');
}
2018-10-23 01:05:09 +03:00
2023-04-19 01:56:05 -04:00
if (mainDrawerButton) {
mainDrawerButton.title = globalize.translate('Menu');
}
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');
}
2023-04-19 01:56:05 -04:00
if (headerUserButton) {
headerUserButton.title = globalize.translate('Settings');
}
}
2023-04-19 01:56:05 -04:00
function updateUserInHeader(user) {
retranslateUi();
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');
}
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');
}
2018-10-23 01:05:09 +03:00
2023-04-19 01:56:05 -04:00
if (headerSearchButton) {
headerSearchButton.classList.remove('hide');
}
2018-10-23 01:05:09 +03:00
2023-04-19 01:56:05 -04:00
if (!layoutManager.tv) {
headerCastButton.classList.remove('hide');
}
2023-04-19 01:56:05 -04:00
const policy = user.Policy ? user.Policy : user.localUser.Policy;
2023-04-19 01:56:05 -04:00
if (
// Button is present
headerSyncButton
// SyncPlay plugin is loaded
2023-03-08 11:49:19 -05:00
&& pluginManager.ofType(PluginType.SyncPlay).length > 0
// SyncPlay enabled for user
&& policy?.SyncPlayAccess !== 'None'
2023-04-19 01:56:05 -04:00
) {
headerSyncButton.classList.remove('hide');
}
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');
}
}
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');
}
2023-04-19 01:56:05 -04: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');
}
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');
}
2023-04-19 01:56:05 -04:00
}
2023-04-19 01:56:05 -04:00
function onCastButtonClicked() {
const btn = this;
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();
}
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>';
2023-09-25 00:00:36 -04:00
html += `<a is="emby-linkbutton" class="navMenuOption lnkMediaFolder lnkManageServer" data-itemid="dashboard" href="#/dashboard"><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="#/metadata"><span class="material-icons navMenuOptionIcon mode_edit" aria-hidden="true"></span><span class="navMenuOptionText">${globalize.translate('Metadata')}</span></a>`;
2023-04-19 01:56:05 -04:00
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>';
}
2023-04-19 01:56:05 -04:00
// add buttons to navigation drawer
navDrawerScrollContainer.innerHTML = html;
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);
}
2023-04-19 01:56:05 -04:00
const btnExit = navDrawerScrollContainer.querySelector('.exitApp');
if (btnExit) {
btnExit.addEventListener('click', onExitAppClick);
}
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 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);
}
2023-04-19 01:56:05 -04:00
}
2023-04-19 01:56:05 -04:00
return list;
});
}
2023-04-19 01:56:05 -04:00
function showBySelector(selector, show) {
const elem = document.querySelector(selector);
2023-04-19 01:56:05 -04:00
if (elem) {
if (show) {
elem.classList.remove('hide');
} else {
elem.classList.add('hide');
}
}
2023-04-19 01:56:05 -04:00
}
function updateLibraryMenu(user) {
if (!user) {
showBySelector('.libraryMenuDownloads', false);
showBySelector('.lnkSyncToOtherDevices', false);
showBySelector('.userMenuOptions', false);
return;
}
2023-04-19 01:56:05 -04:00
if (user.Policy.EnableContentDownloading) {
showBySelector('.lnkSyncToOtherDevices', true);
} else {
showBySelector('.lnkSyncToOtherDevices', false);
}
2023-04-19 01:56:05 -04:00
if (user.Policy.EnableContentDownloading && appHost.supports('sync')) {
showBySelector('.libraryMenuDownloads', true);
} else {
showBySelector('.libraryMenuDownloads', false);
}
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);
});
2023-04-19 01:56:05 -04:00
});
}
2023-04-19 01:56:05 -04:00
const libraryMenuOptions = document.querySelector('.libraryMenuOptions');
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');
}
}
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;
2023-04-19 01:56:05 -04:00
if (isDashboardPage && !layoutManager.mobile) {
skinHeader.classList.add('headroomDisabled');
} else {
2023-04-19 01:56:05 -04:00
skinHeader.classList.remove('headroomDisabled');
}
2023-04-19 01:56:05 -04:00
const bodyClassList = document.body.classList;
2023-04-19 01:56:05 -04:00
if (isLibraryPage) {
bodyClassList.add('libraryDocument');
bodyClassList.remove('dashboardDocument');
bodyClassList.remove('hideMainDrawer');
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);
}
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);
}
}
}
2023-04-19 01:56:05 -04:00
if (requiresUserRefresh) {
ServerConnections.user(getCurrentApiClient()).then(updateUserInHeader);
}
2023-04-19 01:56:05 -04:00
}
2023-04-19 01:56:05 -04:00
function updateTitle(page) {
const title = page.getAttribute('data-title');
2023-04-19 01:56:05 -04:00
if (title) {
LibraryMenu.setTitle(title);
} else if (page.classList.contains('standalonePage')) {
LibraryMenu.setDefaultTitle();
}
2023-04-19 01:56:05 -04: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');
} else {
2023-04-19 01:56:05 -04:00
headerBackButton.classList.add('hide');
}
}
2023-04-19 01:56:05 -04:00
}
function initHeadRoom(elem) {
const headroom = new Headroom(elem);
headroom.init();
}
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);
});
}
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
};
}
2023-04-19 01:56:05 -04:00
function loadNavDrawer() {
if (navDrawerInstance) {
return Promise.resolve(navDrawerInstance);
}
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);
});
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);
}
});
}
2023-04-19 01:56:05 -04:00
function setDefaultTitle () {
if (!pageTitleElement) {
pageTitleElement = document.querySelector('.pageTitle');
2020-07-28 22:09:56 +01: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 = '';
}
2023-04-19 01:56:05 -04:00
document.title = 'Jellyfin';
}
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
}
2023-04-19 01:56:05 -04:00
if (title === '-') {
title = '';
}
2023-04-19 01:56:05 -04:00
const html = title;
2023-04-19 01:56:05 -04:00
if (!pageTitleElement) {
pageTitleElement = document.querySelector('.pageTitle');
}
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');
2023-09-25 00:16:10 -04:00
if (!isDashboardPage) {
2023-04-19 01:56:05 -04:00
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');
}
2023-04-19 01:56:05 -04:00
}
2023-04-19 01:56:05 -04:00
if (currentDrawerType !== 'library') {
refreshLibraryDrawer();
}
2023-04-19 01:56:05 -04:00
}
2023-04-19 01:56:05 -04:00
updateMenuForPageType(isDashboardPage, isLibraryPage);
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);
}
2023-04-19 01:56:05 -04:00
updateTitle(page);
updateBackButton(page);
updateLibraryNavLinks(page);
});
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);
});
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();
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();
export default LibraryMenu;