diff --git a/package.json b/package.json
index 724c533fcb..b30b457fbd 100644
--- a/package.json
+++ b/package.json
@@ -122,6 +122,7 @@
"src/components/maintabsmanager.js",
"src/components/mediaLibraryCreator/mediaLibraryCreator.js",
"src/components/mediaLibraryEditor/mediaLibraryEditor.js",
+ "src/components/nowPlayingBar/nowPlayingBar.js",
"src/components/listview/listview.js",
"src/components/playback/brightnessosd.js",
"src/components/playback/mediasession.js",
@@ -148,15 +149,28 @@
"src/components/syncPlay/playbackPermissionManager.js",
"src/components/syncPlay/syncPlayManager.js",
"src/components/syncPlay/timeSyncManager.js",
+ "src/controllers/auth/addserver.js",
+ "src/controllers/auth/forgotpassword.js",
+ "src/controllers/auth/forgotpasswordpin.js",
+ "src/controllers/auth/login.js",
+ "src/controllers/auth/selectserver.js",
"src/controllers/dashboard/apikeys.js",
"src/controllers/dashboard/dashboard.js",
"src/controllers/dashboard/encodingsettings.js",
"src/controllers/dashboard/logs.js",
"src/controllers/user/subtitles.js",
+ "src/controllers/dashboard/general.js",
+ "src/controllers/dashboard/librarydisplay.js",
+ "src/controllers/dashboard/metadataImages.js",
+ "src/controllers/dashboard/metadatanfo.js",
+ "src/controllers/dashboard/plugins/repositories.js",
+ "src/controllers/dashboard/streaming.js",
"src/controllers/dashboard/mediaLibrary.js",
"src/controllers/dashboard/networking.js",
"src/controllers/dashboard/playback.js",
"src/controllers/dashboard/plugins/repositories.js",
+ "src/controllers/dashboard/scheduledtasks/scheduledtask.js",
+ "src/controllers/dashboard/scheduledtasks/scheduledtasks.js",
"src/controllers/dashboard/dlna/profile.js",
"src/controllers/dashboard/dlna/profiles.js",
"src/controllers/dashboard/dlna/settings.js",
diff --git a/src/components/nowPlayingBar/nowPlayingBar.js b/src/components/nowPlayingBar/nowPlayingBar.js
index bc9c3c1a88..ec413cb7ae 100644
--- a/src/components/nowPlayingBar/nowPlayingBar.js
+++ b/src/components/nowPlayingBar/nowPlayingBar.js
@@ -1,31 +1,46 @@
-define(['require', 'datetime', 'itemHelper', 'events', 'browser', 'imageLoader', 'layoutManager', 'playbackManager', 'nowPlayingHelper', 'apphost', 'dom', 'connectionManager', 'itemContextMenu', 'paper-icon-button-light', 'emby-ratingbutton'], function (require, datetime, itemHelper, events, browser, imageLoader, layoutManager, playbackManager, nowPlayingHelper, appHost, dom, connectionManager, itemContextMenu) {
- 'use strict';
+import require from 'require';
+import datetime from 'datetime';
+import itemHelper from 'itemHelper';
+import events from 'events';
+import browser from 'browser';
+import imageLoader from 'imageLoader';
+import layoutManager from 'layoutManager';
+import playbackManager from 'playbackManager';
+import nowPlayingHelper from 'nowPlayingHelper';
+import appHost from 'apphost';
+import dom from 'dom';
+import connectionManager from 'connectionManager';
+import itemContextMenu from 'itemContextMenu';
+import 'paper-icon-button-light';
+import 'emby-ratingbutton';
- var currentPlayer;
- var currentPlayerSupportedCommands = [];
+/* eslint-disable indent */
- var currentTimeElement;
- var nowPlayingImageElement;
- var nowPlayingTextElement;
- var nowPlayingUserData;
- var muteButton;
- var volumeSlider;
- var volumeSliderContainer;
- var playPauseButtons;
- var positionSlider;
- var toggleRepeatButton;
- var toggleRepeatButtonIcon;
+ let currentPlayer;
+ let currentPlayerSupportedCommands = [];
- var lastUpdateTime = 0;
- var lastPlayerState = {};
- var isEnabled;
- var currentRuntimeTicks = 0;
+ let currentTimeElement;
+ let nowPlayingImageElement;
+ let nowPlayingTextElement;
+ let nowPlayingUserData;
+ let muteButton;
+ let volumeSlider;
+ let volumeSliderContainer;
+ let playPauseButtons;
+ let positionSlider;
+ let toggleRepeatButton;
+ let toggleRepeatButtonIcon;
- var isVisibilityAllowed = true;
+ let lastUpdateTime = 0;
+ let lastPlayerState = {};
+ let isEnabled;
+ let currentRuntimeTicks = 0;
+
+ let isVisibilityAllowed = true;
function getNowPlayingBarHtml() {
- var html = '';
+ let html = '';
html += '
';
@@ -198,7 +213,7 @@ define(['require', 'datetime', 'itemHelper', 'events', 'browser', 'imageLoader',
if (currentPlayer) {
- var newPercent = parseFloat(this.value);
+ const newPercent = parseFloat(this.value);
playbackManager.seekPercent(newPercent, currentPlayer);
}
@@ -207,13 +222,13 @@ define(['require', 'datetime', 'itemHelper', 'events', 'browser', 'imageLoader',
positionSlider.getBubbleText = function (value) {
- var state = lastPlayerState;
+ const state = lastPlayerState;
if (!state || !state.NowPlayingItem || !currentRuntimeTicks) {
return '--:--';
}
- var ticks = currentRuntimeTicks;
+ let ticks = currentRuntimeTicks;
ticks /= 100;
ticks *= value;
@@ -230,12 +245,12 @@ define(['require', 'datetime', 'itemHelper', 'events', 'browser', 'imageLoader',
function showRemoteControl() {
- require(['appRouter'], function (appRouter) {
+ import('appRouter').then(({default: appRouter}) => {
appRouter.showNowPlaying();
});
}
- var nowPlayingBarElement;
+ let nowPlayingBarElement;
function getNowPlayingBar() {
if (nowPlayingBarElement) {
@@ -243,10 +258,15 @@ define(['require', 'datetime', 'itemHelper', 'events', 'browser', 'imageLoader',
}
return new Promise(function (resolve, reject) {
-
- require(['appFooter-shared', 'itemShortcuts', 'css!./nowPlayingBar.css', 'emby-slider'], function (appfooter, itemShortcuts) {
-
- var parentContainer = appfooter.element;
+ Promise.all([
+ import('appFooter-shared'),
+ import('itemShortcuts'),
+ import('css!./nowPlayingBar.css'),
+ import('emby-slider')
+ ])
+ .then(([appfooter, itemShortcuts]) => {
+ console.log(appfooter);
+ const parentContainer = appfooter.element;
nowPlayingBarElement = parentContainer.querySelector('.nowPlayingBar');
if (nowPlayingBarElement) {
@@ -294,13 +314,13 @@ define(['require', 'datetime', 'itemHelper', 'events', 'browser', 'imageLoader',
lastPlayerState = state;
- var playerInfo = playbackManager.getPlayerInfo();
+ const playerInfo = playbackManager.getPlayerInfo();
- var playState = state.PlayState || {};
+ const playState = state.PlayState || {};
updatePlayPauseState(playState.IsPaused);
- var supportedCommands = playerInfo.supportedCommands;
+ const supportedCommands = playerInfo.supportedCommands;
currentPlayerSupportedCommands = supportedCommands;
if (supportedCommands.indexOf('SetRepeatMode') === -1) {
@@ -317,11 +337,11 @@ define(['require', 'datetime', 'itemHelper', 'events', 'browser', 'imageLoader',
positionSlider.disabled = !playState.CanSeek;
// determines if both forward and backward buffer progress will be visible
- var isProgressClear = state.MediaSource && state.MediaSource.RunTimeTicks == null;
+ const isProgressClear = state.MediaSource && state.MediaSource.RunTimeTicks == null;
positionSlider.setIsClear(isProgressClear);
}
- var nowPlayingItem = state.NowPlayingItem || {};
+ const nowPlayingItem = state.NowPlayingItem || {};
updateTimeDisplay(playState.PositionTicks, nowPlayingItem.RunTimeTicks, playbackManager.getBufferedRanges(player));
updateNowPlayingInfo(state);
@@ -348,7 +368,7 @@ define(['require', 'datetime', 'itemHelper', 'events', 'browser', 'imageLoader',
if (positionSlider && !positionSlider.dragging) {
if (runtimeTicks) {
- var pct = positionTicks / runtimeTicks;
+ let pct = positionTicks / runtimeTicks;
pct *= 100;
positionSlider.value = pct;
@@ -365,7 +385,7 @@ define(['require', 'datetime', 'itemHelper', 'events', 'browser', 'imageLoader',
if (currentTimeElement) {
- var timeText = positionTicks == null ? '--:--' : datetime.getDisplayRunningTime(positionTicks);
+ let timeText = positionTicks == null ? '--:--' : datetime.getDisplayRunningTime(positionTicks);
if (runtimeTicks) {
timeText += ' / ' + datetime.getDisplayRunningTime(runtimeTicks);
@@ -377,10 +397,10 @@ define(['require', 'datetime', 'itemHelper', 'events', 'browser', 'imageLoader',
function updatePlayerVolumeState(isMuted, volumeLevel) {
- var supportedCommands = currentPlayerSupportedCommands;
+ const supportedCommands = currentPlayerSupportedCommands;
- var showMuteButton = true;
- var showVolumeSlider = true;
+ let showMuteButton = true;
+ let showVolumeSlider = true;
if (supportedCommands.indexOf('ToggleMute') === -1) {
showMuteButton = false;
@@ -495,37 +515,37 @@ define(['require', 'datetime', 'itemHelper', 'events', 'browser', 'imageLoader',
return null;
}
- var currentImgUrl;
+ let currentImgUrl;
function updateNowPlayingInfo(state) {
- var nowPlayingItem = state.NowPlayingItem;
+ const nowPlayingItem = state.NowPlayingItem;
- var textLines = nowPlayingItem ? nowPlayingHelper.getNowPlayingNames(nowPlayingItem) : [];
+ const textLines = nowPlayingItem ? nowPlayingHelper.getNowPlayingNames(nowPlayingItem) : [];
if (textLines.length > 1) {
textLines[1].secondary = true;
}
nowPlayingTextElement.innerHTML = textLines.map(function (nowPlayingName) {
- var cssClass = nowPlayingName.secondary ? ' class="nowPlayingBarSecondaryText"' : '';
+ const cssClass = nowPlayingName.secondary ? ' class="nowPlayingBarSecondaryText"' : '';
if (nowPlayingName.item) {
- var nowPlayingText = getTextActionButton(nowPlayingName.item, nowPlayingName.text);
+ const nowPlayingText = getTextActionButton(nowPlayingName.item, nowPlayingName.text);
return `
${nowPlayingText}
`;
}
-
+ let nowPlayingText = '';
return `
${nowPlayingText}
`;
}).join('');
- var imgHeight = 70;
+ const imgHeight = 70;
- var url = nowPlayingItem ? (seriesImageUrl(nowPlayingItem, {
+ const url = nowPlayingItem ? (seriesImageUrl(nowPlayingItem, {
height: imgHeight
}) || imageUrl(nowPlayingItem, {
height: imgHeight
})) : null;
- var isRefreshing = false;
+ let isRefreshing = false;
if (url !== currentImgUrl) {
currentImgUrl = url;
@@ -541,12 +561,12 @@ define(['require', 'datetime', 'itemHelper', 'events', 'browser', 'imageLoader',
if (nowPlayingItem.Id) {
if (isRefreshing) {
- var apiClient = connectionManager.getApiClient(nowPlayingItem.ServerId);
+ const apiClient = connectionManager.getApiClient(nowPlayingItem.ServerId);
apiClient.getItem(apiClient.getCurrentUserId(), nowPlayingItem.Id).then(function (item) {
- var userData = item.UserData || {};
- var likes = userData.Likes == null ? '' : userData.Likes;
- var contextButton = document.querySelector('.btnToggleContextMenu');
- var options = {
+ const userData = item.UserData || {};
+ const likes = userData.Likes == null ? '' : userData.Likes;
+ const contextButton = document.querySelector('.btnToggleContextMenu');
+ const options = {
play: false,
queue: false,
positionTo: contextButton
@@ -570,7 +590,7 @@ define(['require', 'datetime', 'itemHelper', 'events', 'browser', 'imageLoader',
function onPlaybackStart(e, state) {
console.debug('nowplaying event: ' + e.type);
- var player = this;
+ const player = this;
onStateChanged.call(player, e, state);
}
@@ -581,7 +601,7 @@ define(['require', 'datetime', 'itemHelper', 'events', 'browser', 'imageLoader',
return;
}
- var player = this;
+ const player = this;
updateRepeatModeDisplay(playbackManager.getRepeatMode(player));
}
@@ -604,7 +624,7 @@ define(['require', 'datetime', 'itemHelper', 'events', 'browser', 'imageLoader',
// in the event of a stop->play command
// Don't call getNowPlayingBar here because we don't want to end up creating it just to hide it
- var elem = document.getElementsByClassName('nowPlayingBar')[0];
+ const elem = document.getElementsByClassName('nowPlayingBar')[0];
if (elem) {
slideDown(elem);
@@ -614,7 +634,7 @@ define(['require', 'datetime', 'itemHelper', 'events', 'browser', 'imageLoader',
function onPlaybackStopped(e, state) {
console.debug('nowplaying event: ' + e.type);
- var player = this;
+ const player = this;
if (player.isLocalPlayer) {
if (state.NextMediaType !== 'Audio') {
@@ -633,14 +653,14 @@ define(['require', 'datetime', 'itemHelper', 'events', 'browser', 'imageLoader',
return;
}
- var player = this;
+ const player = this;
updatePlayPauseState(player.paused());
}
function onStateChanged(event, state) {
console.debug('nowplaying event: ' + event.type);
- var player = this;
+ const player = this;
if (!state.NowPlayingItem || layoutManager.tv) {
hideNowPlayingBar();
@@ -671,21 +691,21 @@ define(['require', 'datetime', 'itemHelper', 'events', 'browser', 'imageLoader',
}
// Try to avoid hammering the document with changes
- var now = new Date().getTime();
+ const now = new Date().getTime();
if ((now - lastUpdateTime) < 700) {
return;
}
lastUpdateTime = now;
- var player = this;
+ const player = this;
currentRuntimeTicks = playbackManager.duration(player);
updateTimeDisplay(playbackManager.currentTime(player), currentRuntimeTicks, playbackManager.getBufferedRanges(player));
}
function releaseCurrentPlayer() {
- var player = currentPlayer;
+ const player = currentPlayer;
if (player) {
events.off(player, 'playbackstart', onPlaybackStart);
@@ -708,14 +728,14 @@ define(['require', 'datetime', 'itemHelper', 'events', 'browser', 'imageLoader',
return;
}
- var player = this;
+ const player = this;
updatePlayerVolumeState(player.isMuted(), player.getVolume());
}
function refreshFromPlayer(player) {
- var state = playbackManager.getPlayerState(player);
+ const state = playbackManager.getPlayerState(player);
onStateChanged.call(player, { type: 'init' }, state);
}
@@ -771,4 +791,5 @@ define(['require', 'datetime', 'itemHelper', 'events', 'browser', 'imageLoader',
}
}
});
-});
+
+/* eslint-enable indent */
diff --git a/src/controllers/auth/addserver.js b/src/controllers/auth/addserver.js
index 622d19082e..1129283246 100644
--- a/src/controllers/auth/addserver.js
+++ b/src/controllers/auth/addserver.js
@@ -1,14 +1,20 @@
-define(['appSettings', 'loading', 'browser', 'globalize', 'emby-button'], function(appSettings, loading, browser, globalize) {
- 'use strict';
+import appSettings from 'appSettings';
+import loading from 'loading';
+import browser from 'browser';
+import globalize from 'globalize';
+import 'emby-button';
+
+/* eslint-disable indent */
function handleConnectionResult(page, result) {
loading.hide();
switch (result.State) {
- case 'SignedIn':
- var apiClient = result.ApiClient;
+ case 'SignedIn': {
+ const apiClient = result.ApiClient;
Dashboard.onServerChanged(apiClient.getCurrentUserId(), apiClient.accessToken(), apiClient);
Dashboard.navigate('home.html');
break;
+ }
case 'ServerSignIn':
Dashboard.navigate('login.html?serverid=' + result.Servers[0].Id, false, 'none');
break;
@@ -30,7 +36,7 @@ define(['appSettings', 'loading', 'browser', 'globalize', 'emby-button'], functi
function submitServer(page) {
loading.show();
- var host = page.querySelector('#txtServerHost').value;
+ const host = page.querySelector('#txtServerHost').value;
ConnectionManager.connectToAddress(host, {
enableAutoLogin: appSettings.enableAutoLogin()
}).then(function(result) {
@@ -42,11 +48,11 @@ define(['appSettings', 'loading', 'browser', 'globalize', 'emby-button'], functi
});
}
- return function(view, params) {
+ export default function(view, params) {
view.querySelector('.addServerForm').addEventListener('submit', onServerSubmit);
view.querySelector('.btnCancel').addEventListener('click', goBack);
- require(['autoFocuser'], function (autoFocuser) {
+ import('autoFocuser').then(({default: autoFocuser}) => {
autoFocuser.autoFocus(view);
});
@@ -57,9 +63,10 @@ define(['appSettings', 'loading', 'browser', 'globalize', 'emby-button'], functi
}
function goBack() {
- require(['appRouter'], function(appRouter) {
+ import('appRouter').then(({default: appRouter}) => {
appRouter.back();
});
}
- };
-});
+ }
+
+/* eslint-enable indent */
diff --git a/src/controllers/auth/forgotpassword.js b/src/controllers/auth/forgotpassword.js
index 3756bf814d..ace5a3ec15 100644
--- a/src/controllers/auth/forgotpassword.js
+++ b/src/controllers/auth/forgotpassword.js
@@ -1,5 +1,6 @@
-define(['globalize'], function (globalize) {
- 'use strict';
+import globalize from 'globalize';
+
+/* eslint-disable indent */
function processForgotPasswordResult(result) {
if ('ContactAdmin' == result.Action) {
@@ -17,7 +18,7 @@ define(['globalize'], function (globalize) {
}
if ('PinCode' == result.Action) {
- var msg = globalize.translate('MessageForgotPasswordFileCreated');
+ let msg = globalize.translate('MessageForgotPasswordFileCreated');
msg += '
';
msg += '
';
msg += 'Enter PIN here to finish Password Reset
';
@@ -34,7 +35,7 @@ define(['globalize'], function (globalize) {
}
}
- return function (view, params) {
+ export default function (view, params) {
function onSubmit(e) {
ApiClient.ajax({
type: 'POST',
@@ -49,5 +50,6 @@ define(['globalize'], function (globalize) {
}
view.querySelector('form').addEventListener('submit', onSubmit);
- };
-});
+ }
+
+/* eslint-enable indent */
diff --git a/src/controllers/auth/forgotpasswordpin.js b/src/controllers/auth/forgotpasswordpin.js
index 2a51890d2f..a88e131eea 100644
--- a/src/controllers/auth/forgotpasswordpin.js
+++ b/src/controllers/auth/forgotpasswordpin.js
@@ -1,9 +1,10 @@
-define(['globalize'], function (globalize) {
- 'use strict';
+import globalize from 'globalize';
+
+/* eslint-disable indent */
function processForgotPasswordResult(result) {
if (result.Success) {
- var msg = globalize.translate('MessagePasswordResetForUsers');
+ let msg = globalize.translate('MessagePasswordResetForUsers');
msg += '
';
msg += '
';
msg += result.UsersReset.join('
');
@@ -22,7 +23,7 @@ define(['globalize'], function (globalize) {
});
}
- return function (view, params) {
+ export default function (view, params) {
function onSubmit(e) {
ApiClient.ajax({
type: 'POST',
@@ -37,5 +38,6 @@ define(['globalize'], function (globalize) {
}
view.querySelector('form').addEventListener('submit', onSubmit);
- };
-});
+ }
+
+/* eslint-enable indent */
diff --git a/src/controllers/auth/login.js b/src/controllers/auth/login.js
index c0c37e27d6..fb16413ae7 100644
--- a/src/controllers/auth/login.js
+++ b/src/controllers/auth/login.js
@@ -1,14 +1,24 @@
-define(['apphost', 'appSettings', 'dom', 'connectionManager', 'loading', 'layoutManager', 'browser', 'globalize', 'cardStyle', 'emby-checkbox'], function (appHost, appSettings, dom, connectionManager, loading, layoutManager, browser, globalize) {
- 'use strict';
+import appHost from 'apphost';
+import appSettings from 'appSettings';
+import dom from 'dom';
+import connectionManager from 'connectionManager';
+import loading from 'loading';
+import layoutManager from 'layoutManager';
+import browser from 'browser';
+import globalize from 'globalize';
+import 'cardStyle';
+import 'emby-checkbox';
- var enableFocusTransform = !browser.slow && !browser.edge;
+/* eslint-disable indent */
+
+ const enableFocusTransform = !browser.slow && !browser.edge;
function authenticateUserByName(page, apiClient, username, password) {
loading.show();
apiClient.authenticateUserByName(username, password).then(function (result) {
- var user = result.User;
- var serverId = getParameterByName('serverid');
- var newUrl;
+ const user = result.User;
+ const serverId = getParameterByName('serverid');
+ let newUrl;
if (user.Policy.IsAdministrator && !serverId) {
newUrl = 'dashboard.html';
@@ -26,7 +36,7 @@ define(['apphost', 'appSettings', 'dom', 'connectionManager', 'loading', 'layout
const UnauthorizedOrForbidden = [401, 403];
if (UnauthorizedOrForbidden.includes(response.status)) {
- require(['toast'], function (toast) {
+ import('toast').then(({default: toast}) => {
const messageKey = response.status === 401 ? 'MessageInvalidUser' : 'MessageUnauthorizedUser';
toast(globalize.translate(messageKey));
});
@@ -58,23 +68,23 @@ define(['apphost', 'appSettings', 'dom', 'connectionManager', 'loading', 'layout
}
}
- var metroColors = ['#6FBD45', '#4BB3DD', '#4164A5', '#E12026', '#800080', '#E1B222', '#008040', '#0094FF', '#FF00C7', '#FF870F', '#7F0037'];
+ const metroColors = ['#6FBD45', '#4BB3DD', '#4164A5', '#E12026', '#800080', '#E1B222', '#008040', '#0094FF', '#FF00C7', '#FF870F', '#7F0037'];
function getRandomMetroColor() {
- var index = Math.floor(Math.random() * (metroColors.length - 1));
+ const index = Math.floor(Math.random() * (metroColors.length - 1));
return metroColors[index];
}
function getMetroColor(str) {
if (str) {
- var character = String(str.substr(0, 1).charCodeAt());
- var sum = 0;
+ const character = String(str.substr(0, 1).charCodeAt());
+ let sum = 0;
- for (var i = 0; i < character.length; i++) {
+ for (let i = 0; i < character.length; i++) {
sum += parseInt(character.charAt(i));
}
- var index = String(sum).substr(-1);
+ const index = String(sum).substr(-1);
return metroColors[index];
}
@@ -82,13 +92,13 @@ define(['apphost', 'appSettings', 'dom', 'connectionManager', 'loading', 'layout
}
function loadUserList(context, apiClient, users) {
- var html = '';
+ let html = '';
- for (var i = 0; i < users.length; i++) {
- var user = users[i];
+ for (let i = 0; i < users.length; i++) {
+ const user = users[i];
// TODO move card creation code to Card component
- var cssClass = 'card squareCard scalableCard squareCard-scalable';
+ let cssClass = 'card squareCard scalableCard squareCard-scalable';
if (layoutManager.tv) {
cssClass += ' show-focus';
@@ -98,13 +108,13 @@ define(['apphost', 'appSettings', 'dom', 'connectionManager', 'loading', 'layout
}
}
- var cardBoxCssClass = 'cardBox cardBox-bottompadded';
+ const cardBoxCssClass = 'cardBox cardBox-bottompadded';
html += '