2020-07-28 21:28:16 +01:00
|
|
|
import events from 'events';
|
|
|
|
import playbackManager from 'playbackManager';
|
|
|
|
import pluginManager from 'pluginManager';
|
|
|
|
import inputManager from 'inputManager';
|
|
|
|
import connectionManager from 'connectionManager';
|
|
|
|
import * as userSettings from 'userSettings';
|
|
|
|
|
|
|
|
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-07-28 21:28:16 +01:00
|
|
|
for (let i = 0, length = plugins.length; i < length; i++) {
|
|
|
|
const plugin = plugins[i];
|
2019-11-27 18:02:38 +03:00
|
|
|
|
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;
|
|
|
|
const apiClient = 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;
|