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

81 lines
2.1 KiB
JavaScript
Raw Normal View History

2020-08-16 20:24:45 +02:00
import { appHost } from './apphost';
2020-08-14 06:36:46 +02:00
import browser from '../scripts/browser';
2020-10-18 18:58:09 +01:00
import appSettings from '../scripts/settings/appSettings';
import Events from '../utils/events.ts';
2018-10-23 01:05:09 +03:00
function setLayout(instance, layout, selectedLayout) {
if (layout === selectedLayout) {
instance[layout] = true;
document.documentElement.classList.add('layout-' + layout);
} else {
instance[layout] = false;
document.documentElement.classList.remove('layout-' + layout);
}
}
class LayoutManager {
tv = false;
mobile = false;
desktop = false;
setLayout(layout, save) {
if (!layout || layout === 'auto') {
this.autoLayout();
if (save !== false) {
2020-10-18 18:58:09 +01:00
appSettings.set('layout', '');
}
} else {
setLayout(this, 'mobile', layout);
setLayout(this, 'tv', layout);
setLayout(this, 'desktop', layout);
2023-01-13 10:48:47 -05:00
if (layout === 'experimental') {
const legacyLayoutMode = browser.mobile ? 'mobile' : this.defaultLayout || 'desktop';
setLayout(this, legacyLayoutMode, legacyLayoutMode);
}
if (save !== false) {
2020-10-18 18:58:09 +01:00
appSettings.set('layout', layout);
}
}
2020-09-08 02:05:02 -04:00
Events.trigger(this, 'modechange');
}
2020-08-14 06:36:46 +02:00
getSavedLayout() {
2020-10-18 18:58:09 +01:00
return appSettings.get('layout');
}
autoLayout() {
// Take a guess at initial layout. The consuming app can override
if (browser.mobile) {
this.setLayout('mobile', false);
2020-04-24 21:44:18 +02:00
} else if (browser.tv || browser.xboxOne || browser.ps4) {
this.setLayout('tv', false);
} else {
this.setLayout(this.defaultLayout || 'tv', false);
}
}
init() {
const saved = this.getSavedLayout();
if (saved) {
this.setLayout(saved, false);
} else {
this.autoLayout();
}
}
}
2020-08-14 06:36:46 +02:00
const layoutManager = new LayoutManager();
if (appHost.getDefaultLayout) {
layoutManager.defaultLayout = appHost.getDefaultLayout();
}
layoutManager.init();
export default layoutManager;