2020-08-14 08:46:34 +02:00
|
|
|
import events from 'jellyfin-apiclient';
|
|
|
|
import playbackManager from '../components/playback/playbackmanager';
|
|
|
|
import pluginManager from '../components/pluginManager';
|
|
|
|
import inputManager from '../scripts/inputManager';
|
|
|
|
import connectionManager from 'jellyfin-apiclient';
|
|
|
|
import * as userSettings from '../scripts/settings/userSettings';
|
2020-07-28 21:28:16 +01:00
|
|
|
|
|
|
|
function getMinIdleTime() {
|
|
|
|
// Returns the minimum amount of idle time required before the screen saver can be displayed
|
|
|
|
//time units used Millisecond
|
|
|
|
return 180000;
|
|
|
|
}
|
|
|
|
|
|
|
|
let lastFunctionalEvent = 0;
|
|
|
|
|
|
|
|
function getFunctionalEventIdleTime() {
|
|
|
|
return new Date().getTime() - lastFunctionalEvent;
|
|
|
|
}
|
|
|
|
|
|
|
|
events.on(playbackManager, 'playbackstop', function (e, stopInfo) {
|
|
|
|
const state = stopInfo.state;
|
|
|
|
if (state.NowPlayingItem && state.NowPlayingItem.MediaType == 'Video') {
|
|
|
|
lastFunctionalEvent = new Date().getTime();
|
2019-11-23 23:00:44 +03:00
|
|
|
}
|
2020-07-28 21:28:16 +01:00
|
|
|
});
|
2019-11-23 23:00:44 +03:00
|
|
|
|
2020-07-28 21:28:16 +01:00
|
|
|
function getScreensaverPlugin(isLoggedIn) {
|
|
|
|
let option;
|
|
|
|
try {
|
|
|
|
option = userSettings.get('screensaver', false);
|
|
|
|
} catch (err) {
|
|
|
|
option = isLoggedIn ? 'backdropscreensaver' : 'logoscreensaver';
|
2019-11-23 23:00:44 +03:00
|
|
|
}
|
|
|
|
|
2020-07-28 21:28:16 +01:00
|
|
|
const plugins = pluginManager.ofType('screensaver');
|
2019-11-23 23:00:44 +03:00
|
|
|
|
2020-08-07 09:27:11 +01:00
|
|
|
for (const plugin of plugins) {
|
2020-07-28 21:28:16 +01:00
|
|
|
if (plugin.id === option) {
|
|
|
|
return plugin;
|
2019-11-27 18:02:38 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-07-28 21:28:16 +01:00
|
|
|
return null;
|
|
|
|
}
|
2019-11-23 23:00:44 +03:00
|
|
|
|
2020-07-28 21:28:16 +01:00
|
|
|
function ScreenSaverManager() {
|
|
|
|
let activeScreenSaver;
|
2019-11-23 23:00:44 +03:00
|
|
|
|
2020-07-28 21:28:16 +01:00
|
|
|
function showScreenSaver(screensaver) {
|
|
|
|
if (activeScreenSaver) {
|
|
|
|
throw new Error('An existing screensaver is already active.');
|
|
|
|
}
|
2019-11-23 23:00:44 +03:00
|
|
|
|
2020-07-28 21:28:16 +01:00
|
|
|
console.debug('Showing screensaver ' + screensaver.name);
|
2019-11-23 23:00:44 +03:00
|
|
|
|
2020-07-28 21:28:16 +01:00
|
|
|
screensaver.show();
|
|
|
|
activeScreenSaver = screensaver;
|
2019-11-23 23:00:44 +03:00
|
|
|
|
2020-07-28 21:28:16 +01:00
|
|
|
if (screensaver.hideOnClick !== false) {
|
|
|
|
window.addEventListener('click', hide, true);
|
2019-11-23 23:00:44 +03:00
|
|
|
}
|
2020-07-28 21:28:16 +01:00
|
|
|
if (screensaver.hideOnMouse !== false) {
|
|
|
|
window.addEventListener('mousemove', hide, true);
|
2019-11-23 23:00:44 +03:00
|
|
|
}
|
2020-07-28 21:28:16 +01:00
|
|
|
if (screensaver.hideOnKey !== false) {
|
|
|
|
window.addEventListener('keydown', hide, true);
|
|
|
|
}
|
|
|
|
}
|
2019-11-23 23:00:44 +03:00
|
|
|
|
2020-07-28 21:28:16 +01:00
|
|
|
function hide() {
|
|
|
|
if (activeScreenSaver) {
|
|
|
|
console.debug('Hiding screensaver');
|
|
|
|
activeScreenSaver.hide();
|
|
|
|
activeScreenSaver = null;
|
|
|
|
}
|
2019-11-23 23:00:44 +03:00
|
|
|
|
2020-07-28 21:28:16 +01:00
|
|
|
window.removeEventListener('click', hide, true);
|
|
|
|
window.removeEventListener('mousemove', hide, true);
|
|
|
|
window.removeEventListener('keydown', hide, true);
|
|
|
|
}
|
2019-11-27 20:39:45 +03:00
|
|
|
|
2020-07-28 21:28:16 +01:00
|
|
|
this.isShowing = () => {
|
|
|
|
return activeScreenSaver != null;
|
|
|
|
};
|
2019-11-27 20:39:45 +03:00
|
|
|
|
2020-07-28 21:28:16 +01:00
|
|
|
this.show = function () {
|
|
|
|
let isLoggedIn;
|
2020-08-30 06:06:47 +02:00
|
|
|
const apiClient = window.connectionManager.currentApiClient();
|
2019-11-23 23:00:44 +03:00
|
|
|
|
2020-07-28 21:28:16 +01:00
|
|
|
if (apiClient && apiClient.isLoggedIn()) {
|
|
|
|
isLoggedIn = true;
|
|
|
|
}
|
2019-11-23 23:00:44 +03:00
|
|
|
|
2020-07-28 21:28:16 +01:00
|
|
|
const screensaver = getScreensaverPlugin(isLoggedIn);
|
2019-11-23 23:00:44 +03:00
|
|
|
|
2020-07-28 21:28:16 +01:00
|
|
|
if (screensaver) {
|
|
|
|
showScreenSaver(screensaver);
|
|
|
|
}
|
|
|
|
};
|
2019-11-23 23:00:44 +03:00
|
|
|
|
2020-07-28 21:28:16 +01:00
|
|
|
this.hide = function () {
|
|
|
|
hide();
|
|
|
|
};
|
2019-11-23 23:00:44 +03:00
|
|
|
|
2020-07-28 21:28:16 +01:00
|
|
|
const onInterval = () => {
|
|
|
|
if (this.isShowing()) {
|
|
|
|
return;
|
|
|
|
}
|
2019-11-23 23:00:44 +03:00
|
|
|
|
2020-07-28 21:28:16 +01:00
|
|
|
if (inputManager.idleTime() < getMinIdleTime()) {
|
|
|
|
return;
|
|
|
|
}
|
2019-11-23 23:00:44 +03:00
|
|
|
|
2020-07-28 21:28:16 +01:00
|
|
|
if (getFunctionalEventIdleTime < getMinIdleTime()) {
|
|
|
|
return;
|
|
|
|
}
|
2019-11-23 23:00:44 +03:00
|
|
|
|
2020-07-28 21:28:16 +01:00
|
|
|
if (playbackManager.isPlayingVideo()) {
|
|
|
|
return;
|
2019-11-23 23:00:44 +03:00
|
|
|
}
|
|
|
|
|
2020-07-28 21:28:16 +01:00
|
|
|
this.show();
|
|
|
|
};
|
2019-11-23 23:00:44 +03:00
|
|
|
|
2020-07-28 21:28:16 +01:00
|
|
|
setInterval(onInterval, 10000);
|
|
|
|
}
|
|
|
|
|
|
|
|
export default new ScreenSaverManager;
|