From 8fb8dacdf1bca533c4021dc9adff35cfd98b9aea Mon Sep 17 00:00:00 2001 From: MrTimscampi Date: Sun, 26 Jul 2020 22:45:00 +0200 Subject: [PATCH 001/301] Migrate shell, serverNotifications to ES6 + remove searchtab --- package.json | 2 + src/assets/css/librarybrowser.css | 6 - src/components/guide/guide.js | 2 + src/components/itemsrefresher.js | 2 + src/components/notifications/notifications.js | 2 + src/components/playback/playbackmanager.js | 1 + .../recordingcreator/recordingfields.js | 2 + src/controllers/livetv/livetvsuggested.js | 6 - src/controllers/movies/moviesrecommended.js | 6 - src/controllers/music/musicrecommended.js | 6 - src/controllers/shows/tvrecommended.js | 7 - src/plugins/sessionPlayer/plugin.js | 2 + src/scripts/searchtab.js | 57 --- src/scripts/serverNotifications.js | 407 +++++++++--------- src/scripts/shell.js | 43 +- 15 files changed, 239 insertions(+), 312 deletions(-) delete mode 100644 src/scripts/searchtab.js diff --git a/package.json b/package.json index d1831b13ee..12ed63929a 100644 --- a/package.json +++ b/package.json @@ -250,9 +250,11 @@ "src/scripts/inputManager.js", "src/scripts/keyboardNavigation.js", "src/scripts/playlists.js", + "src/scripts/serverNotifications.js", "src/scripts/settings/appSettings.js", "src/scripts/settings/userSettings.js", "src/scripts/settings/webSettings.js", + "src/scripts/shell.js", "src/scripts/taskbutton.js", "src/scripts/themeLoader.js", "src/scripts/touchHelper.js" diff --git a/src/assets/css/librarybrowser.css b/src/assets/css/librarybrowser.css index 61815a590f..644dba9371 100644 --- a/src/assets/css/librarybrowser.css +++ b/src/assets/css/librarybrowser.css @@ -236,12 +236,6 @@ text-align: center; } -.layout-desktop .searchTabButton, -.layout-mobile .searchTabButton, -.layout-tv .headerSearchButton { - display: none !important; -} - .mainDrawer-scrollContainer { padding-bottom: 10vh; } diff --git a/src/components/guide/guide.js b/src/components/guide/guide.js index bb4a36497c..e18f053a5a 100644 --- a/src/components/guide/guide.js +++ b/src/components/guide/guide.js @@ -1,6 +1,8 @@ define(['require', 'inputManager', 'browser', 'globalize', 'connectionManager', 'scrollHelper', 'serverNotifications', 'loading', 'datetime', 'focusManager', 'playbackManager', 'userSettings', 'imageLoader', 'events', 'layoutManager', 'itemShortcuts', 'dom', 'css!./guide.css', 'programStyles', 'material-icons', 'scrollStyles', 'emby-programcell', 'emby-button', 'paper-icon-button-light', 'emby-tabs', 'emby-scroller', 'flexStyles', 'webcomponents'], function (require, inputManager, browser, globalize, connectionManager, scrollHelper, serverNotifications, loading, datetime, focusManager, playbackManager, userSettings, imageLoader, events, layoutManager, itemShortcuts, dom) { 'use strict'; + serverNotifications = serverNotifications.default || serverNotifications; + function showViewSettings(instance) { require(['guide-settings-dialog'], function (guideSettingsDialog) { diff --git a/src/components/itemsrefresher.js b/src/components/itemsrefresher.js index 6da74eef80..f50813a7e0 100644 --- a/src/components/itemsrefresher.js +++ b/src/components/itemsrefresher.js @@ -1,6 +1,8 @@ define(['playbackManager', 'serverNotifications', 'events'], function (playbackManager, serverNotifications, events) { 'use strict'; + serverNotifications = serverNotifications.default || serverNotifications; + function onUserDataChanged(e, apiClient, userData) { var instance = this; diff --git a/src/components/notifications/notifications.js b/src/components/notifications/notifications.js index c8480e4f15..d12b14cc01 100644 --- a/src/components/notifications/notifications.js +++ b/src/components/notifications/notifications.js @@ -1,6 +1,8 @@ define(['serverNotifications', 'playbackManager', 'events', 'globalize', 'require'], function (serverNotifications, playbackManager, events, globalize, require) { 'use strict'; + serverNotifications = serverNotifications.default || serverNotifications; + function onOneDocumentClick() { document.removeEventListener('click', onOneDocumentClick); document.removeEventListener('keydown', onOneDocumentClick); diff --git a/src/components/playback/playbackmanager.js b/src/components/playback/playbackmanager.js index fe3ff11250..a6fc3942be 100644 --- a/src/components/playback/playbackmanager.js +++ b/src/components/playback/playbackmanager.js @@ -3455,6 +3455,7 @@ define(['events', 'datetime', 'appSettings', 'itemHelper', 'pluginManager', 'pla if (apphost.supports('remotecontrol')) { require(['serverNotifications'], function (serverNotifications) { + serverNotifications = serverNotifications.default || serverNotifications; events.on(serverNotifications, 'ServerShuttingDown', self.setDefaultPlayerActive.bind(self)); events.on(serverNotifications, 'ServerRestarting', self.setDefaultPlayerActive.bind(self)); }); diff --git a/src/components/recordingcreator/recordingfields.js b/src/components/recordingcreator/recordingfields.js index 84348fcfbc..5fc0f24af4 100644 --- a/src/components/recordingcreator/recordingfields.js +++ b/src/components/recordingcreator/recordingfields.js @@ -1,6 +1,8 @@ define(['globalize', 'connectionManager', 'serverNotifications', 'require', 'loading', 'apphost', 'dom', 'recordingHelper', 'events', 'paper-icon-button-light', 'emby-button', 'css!./recordingfields', 'flexStyles'], function (globalize, connectionManager, serverNotifications, require, loading, appHost, dom, recordingHelper, events) { 'use strict'; + serverNotifications = serverNotifications.default || serverNotifications; + function loadData(parent, program, apiClient) { if (program.IsSeries) { parent.querySelector('.recordSeriesContainer').classList.remove('hide'); diff --git a/src/controllers/livetv/livetvsuggested.js b/src/controllers/livetv/livetvsuggested.js index 036eee9fc6..16cee8a496 100644 --- a/src/controllers/livetv/livetvsuggested.js +++ b/src/controllers/livetv/livetvsuggested.js @@ -167,9 +167,6 @@ define(['layoutManager', 'userSettings', 'inputManager', 'loading', 'globalize', name: globalize.translate('HeaderSchedule') }, { name: globalize.translate('TabSeries') - }, { - name: globalize.translate('ButtonSearch'), - cssClass: 'searchTabButton' }]; } @@ -253,9 +250,6 @@ define(['layoutManager', 'userSettings', 'inputManager', 'loading', 'globalize', case 5: depends.push('controllers/livetv/livetvseriestimers'); break; - - case 6: - depends.push('scripts/searchtab'); } require(depends, function (controllerFactory) { diff --git a/src/controllers/movies/moviesrecommended.js b/src/controllers/movies/moviesrecommended.js index d948c1cef7..11aa6e3fec 100644 --- a/src/controllers/movies/moviesrecommended.js +++ b/src/controllers/movies/moviesrecommended.js @@ -222,9 +222,6 @@ define(['events', 'layoutManager', 'inputManager', 'userSettings', 'libraryMenu' name: globalize.translate('TabCollections') }, { name: globalize.translate('TabGenres') - }, { - name: globalize.translate('ButtonSearch'), - cssClass: 'searchTabButton' }]; } @@ -291,9 +288,6 @@ define(['events', 'layoutManager', 'inputManager', 'userSettings', 'libraryMenu' case 5: depends.push('controllers/movies/moviegenres'); break; - - case 6: - depends.push('scripts/searchtab'); } require(depends, function (controllerFactory) { diff --git a/src/controllers/music/musicrecommended.js b/src/controllers/music/musicrecommended.js index 3f025799f6..1409d6de3f 100644 --- a/src/controllers/music/musicrecommended.js +++ b/src/controllers/music/musicrecommended.js @@ -180,9 +180,6 @@ define(['browser', 'layoutManager', 'userSettings', 'inputManager', 'loading', ' name: globalize.translate('TabSongs') }, { name: globalize.translate('TabGenres') - }, { - name: globalize.translate('ButtonSearch'), - cssClass: 'searchTabButton' }]; } @@ -283,9 +280,6 @@ define(['browser', 'layoutManager', 'userSettings', 'inputManager', 'loading', ' case 6: depends.push('controllers/music/musicgenres'); break; - - case 7: - depends.push('scripts/searchtab'); } require(depends, function (controllerFactory) { diff --git a/src/controllers/shows/tvrecommended.js b/src/controllers/shows/tvrecommended.js index 7edd2ab501..25459b7b6a 100644 --- a/src/controllers/shows/tvrecommended.js +++ b/src/controllers/shows/tvrecommended.js @@ -30,9 +30,6 @@ import 'emby-button'; name: globalize.translate('TabNetworks') }, { name: globalize.translate('TabEpisodes') - }, { - name: globalize.translate('ButtonSearch'), - cssClass: 'searchTabButton' }]; } @@ -217,10 +214,6 @@ import 'emby-button'; case 6: depends = 'controllers/shows/episodes'; break; - - case 7: - depends = 'scripts/searchtab'; - break; } import(depends).then(({default: controllerFactory}) => { diff --git a/src/plugins/sessionPlayer/plugin.js b/src/plugins/sessionPlayer/plugin.js index 084aa027cf..a8cb1e3579 100644 --- a/src/plugins/sessionPlayer/plugin.js +++ b/src/plugins/sessionPlayer/plugin.js @@ -1,6 +1,8 @@ define(['playbackManager', 'events', 'serverNotifications', 'connectionManager'], function (playbackManager, events, serverNotifications, connectionManager) { 'use strict'; + serverNotifications = serverNotifications.default || serverNotifications; + function getActivePlayerId() { var info = playbackManager.getPlayerInfo(); return info ? info.id : null; diff --git a/src/scripts/searchtab.js b/src/scripts/searchtab.js deleted file mode 100644 index e012b8a4b2..0000000000 --- a/src/scripts/searchtab.js +++ /dev/null @@ -1,57 +0,0 @@ -define(['searchFields', 'searchResults', 'events'], function (SearchFields, SearchResults, events) { - 'use strict'; - - SearchFields = SearchFields.default || SearchFields; - SearchResults = SearchResults.default || SearchResults; - - function init(instance, tabContent, options) { - tabContent.innerHTML = '
'; - instance.searchFields = new SearchFields({ - element: tabContent.querySelector('.searchFields') - }); - instance.searchResults = new SearchResults({ - element: tabContent.querySelector('.searchResults'), - serverId: ApiClient.serverId(), - parentId: options.parentId, - collectionType: options.collectionType - }); - events.on(instance.searchFields, 'search', function (e, value) { - instance.searchResults.search(value); - }); - } - - function SearchTab(view, tabContent, options) { - var self = this; - options = options || {}; - init(this, tabContent, options); - - self.preRender = function () {}; - - self.renderTab = function () { - var searchFields = this.searchFields; - - if (searchFields) { - searchFields.focus(); - } - }; - } - - SearchTab.prototype.destroy = function () { - var searchFields = this.searchFields; - - if (searchFields) { - searchFields.destroy(); - } - - this.searchFields = null; - var searchResults = this.searchResults; - - if (searchResults) { - searchResults.destroy(); - } - - this.searchResults = null; - }; - - return SearchTab; -}); diff --git a/src/scripts/serverNotifications.js b/src/scripts/serverNotifications.js index 331a75329c..83af40c4e6 100644 --- a/src/scripts/serverNotifications.js +++ b/src/scripts/serverNotifications.js @@ -1,211 +1,216 @@ -define(['connectionManager', 'playbackManager', 'syncPlayManager', 'events', 'inputManager', 'focusManager', 'appRouter'], function (connectionManager, playbackManager, syncPlayManager, events, inputManager, focusManager, appRouter) { - 'use strict'; +import connectionManager from 'connectionManager'; +import playbackManager from 'playbackManager'; +import syncPlayManager from 'syncPlayManager'; +import events from 'events'; +import inputManager from 'inputManager'; +import focusManager from 'focusManager'; +import appRouter from 'appRouter'; - var serverNotifications = {}; +const serverNotifications = {}; - function notifyApp() { - inputManager.notify(); - } +function notifyApp() { + inputManager.notify(); +} - function displayMessage(cmd) { - var args = cmd.Arguments; - if (args.TimeoutMs) { - require(['toast'], function (toast) { - toast({ title: args.Header, text: args.Text }); - }); - } else { - require(['alert'], function (alert) { - alert.default({ title: args.Header, text: args.Text }); - }); - } - } - - function displayContent(cmd, apiClient) { - if (!playbackManager.isPlayingLocally(['Video', 'Book'])) { - appRouter.showItem(cmd.Arguments.ItemId, apiClient.serverId()); - } - } - - function playTrailers(apiClient, itemId) { - apiClient.getItem(apiClient.getCurrentUserId(), itemId).then(function (item) { - playbackManager.playTrailers(item); +function displayMessage(cmd) { + const args = cmd.Arguments; + if (args.TimeoutMs) { + require(['toast'], function (toast) { + toast({ title: args.Header, text: args.Text }); + }); + } else { + require(['alert'], function (alert) { + alert.default({ title: args.Header, text: args.Text }); }); } +} - function processGeneralCommand(cmd, apiClient) { - console.debug('Received command: ' + cmd.Name); - switch (cmd.Name) { - case 'Select': - inputManager.handleCommand('select'); - return; - case 'Back': - inputManager.handleCommand('back'); - return; - case 'MoveUp': - inputManager.handleCommand('up'); - return; - case 'MoveDown': - inputManager.handleCommand('down'); - return; - case 'MoveLeft': - inputManager.handleCommand('left'); - return; - case 'MoveRight': - inputManager.handleCommand('right'); - return; - case 'PageUp': - inputManager.handleCommand('pageup'); - return; - case 'PageDown': - inputManager.handleCommand('pagedown'); - return; - case 'PlayTrailers': - playTrailers(apiClient, cmd.Arguments.ItemId); - break; - case 'SetRepeatMode': - playbackManager.setRepeatMode(cmd.Arguments.RepeatMode); - break; - case 'SetShuffleQueue': - playbackManager.setQueueShuffleMode(cmd.Arguments.ShuffleMode); - break; - case 'VolumeUp': - inputManager.handleCommand('volumeup'); - return; - case 'VolumeDown': - inputManager.handleCommand('volumedown'); - return; - case 'ChannelUp': - inputManager.handleCommand('channelup'); - return; - case 'ChannelDown': - inputManager.handleCommand('channeldown'); - return; - case 'Mute': - inputManager.handleCommand('mute'); - return; - case 'Unmute': - inputManager.handleCommand('unmute'); - return; - case 'ToggleMute': - inputManager.handleCommand('togglemute'); - return; - case 'SetVolume': - notifyApp(); - playbackManager.setVolume(cmd.Arguments.Volume); - break; - case 'SetAudioStreamIndex': - notifyApp(); - playbackManager.setAudioStreamIndex(parseInt(cmd.Arguments.Index)); - break; - case 'SetSubtitleStreamIndex': - notifyApp(); - playbackManager.setSubtitleStreamIndex(parseInt(cmd.Arguments.Index)); - break; - case 'ToggleFullscreen': - inputManager.handleCommand('togglefullscreen'); - return; - case 'GoHome': - inputManager.handleCommand('home'); - return; - case 'GoToSettings': - inputManager.handleCommand('settings'); - return; - case 'DisplayContent': - displayContent(cmd, apiClient); - break; - case 'GoToSearch': - inputManager.handleCommand('search'); - return; - case 'DisplayMessage': - displayMessage(cmd); - break; - case 'ToggleOsd': - // todo - break; - case 'ToggleContextMenu': - // todo - break; - case 'TakeScreenShot': - // todo - break; - case 'SendKey': - // todo - break; - case 'SendString': - // todo - focusManager.sendText(cmd.Arguments.String); - break; - default: - console.debug('processGeneralCommand does not recognize: ' + cmd.Name); - break; - } - - notifyApp(); +function displayContent(cmd, apiClient) { + if (!playbackManager.isPlayingLocally(['Video', 'Book'])) { + appRouter.showItem(cmd.Arguments.ItemId, apiClient.serverId()); } +} - function onMessageReceived(e, msg) { - var apiClient = this; - if (msg.MessageType === 'Play') { - notifyApp(); - var serverId = apiClient.serverInfo().Id; - if (msg.Data.PlayCommand === 'PlayNext') { - playbackManager.queueNext({ ids: msg.Data.ItemIds, serverId: serverId }); - } else if (msg.Data.PlayCommand === 'PlayLast') { - playbackManager.queue({ ids: msg.Data.ItemIds, serverId: serverId }); - } else { - playbackManager.play({ - ids: msg.Data.ItemIds, - startPositionTicks: msg.Data.StartPositionTicks, - mediaSourceId: msg.Data.MediaSourceId, - audioStreamIndex: msg.Data.AudioStreamIndex, - subtitleStreamIndex: msg.Data.SubtitleStreamIndex, - startIndex: msg.Data.StartIndex, - serverId: serverId - }); - } - } else if (msg.MessageType === 'Playstate') { - if (msg.Data.Command === 'Stop') { - inputManager.handleCommand('stop'); - } else if (msg.Data.Command === 'Pause') { - inputManager.handleCommand('pause'); - } else if (msg.Data.Command === 'Unpause') { - inputManager.handleCommand('play'); - } else if (msg.Data.Command === 'PlayPause') { - inputManager.handleCommand('playpause'); - } else if (msg.Data.Command === 'Seek') { - playbackManager.seek(msg.Data.SeekPositionTicks); - } else if (msg.Data.Command === 'NextTrack') { - inputManager.handleCommand('next'); - } else if (msg.Data.Command === 'PreviousTrack') { - inputManager.handleCommand('previous'); - } else { - notifyApp(); - } - } else if (msg.MessageType === 'GeneralCommand') { - var cmd = msg.Data; - processGeneralCommand(cmd, apiClient); - } else if (msg.MessageType === 'UserDataChanged') { - if (msg.Data.UserId === apiClient.getCurrentUserId()) { - for (var i = 0, length = msg.Data.UserDataList.length; i < length; i++) { - events.trigger(serverNotifications, 'UserDataChanged', [apiClient, msg.Data.UserDataList[i]]); - } - } - } else if (msg.MessageType === 'SyncPlayCommand') { - syncPlayManager.processCommand(msg.Data, apiClient); - } else if (msg.MessageType === 'SyncPlayGroupUpdate') { - syncPlayManager.processGroupUpdate(msg.Data, apiClient); - } else { - events.trigger(serverNotifications, msg.MessageType, [apiClient, msg.Data]); - } - } - function bindEvents(apiClient) { - events.off(apiClient, 'message', onMessageReceived); - events.on(apiClient, 'message', onMessageReceived); - } - - connectionManager.getApiClients().forEach(bindEvents); - events.on(connectionManager, 'apiclientcreated', function (e, newApiClient) { - bindEvents(newApiClient); +function playTrailers(apiClient, itemId) { + apiClient.getItem(apiClient.getCurrentUserId(), itemId).then(function (item) { + playbackManager.playTrailers(item); }); - return serverNotifications; +} + +function processGeneralCommand(cmd, apiClient) { + console.debug('Received command: ' + cmd.Name); + switch (cmd.Name) { + case 'Select': + inputManager.handleCommand('select'); + return; + case 'Back': + inputManager.handleCommand('back'); + return; + case 'MoveUp': + inputManager.handleCommand('up'); + return; + case 'MoveDown': + inputManager.handleCommand('down'); + return; + case 'MoveLeft': + inputManager.handleCommand('left'); + return; + case 'MoveRight': + inputManager.handleCommand('right'); + return; + case 'PageUp': + inputManager.handleCommand('pageup'); + return; + case 'PageDown': + inputManager.handleCommand('pagedown'); + return; + case 'PlayTrailers': + playTrailers(apiClient, cmd.Arguments.ItemId); + break; + case 'SetRepeatMode': + playbackManager.setRepeatMode(cmd.Arguments.RepeatMode); + break; + case 'SetShuffleQueue': + playbackManager.setQueueShuffleMode(cmd.Arguments.ShuffleMode); + break; + case 'VolumeUp': + inputManager.handleCommand('volumeup'); + return; + case 'VolumeDown': + inputManager.handleCommand('volumedown'); + return; + case 'ChannelUp': + inputManager.handleCommand('channelup'); + return; + case 'ChannelDown': + inputManager.handleCommand('channeldown'); + return; + case 'Mute': + inputManager.handleCommand('mute'); + return; + case 'Unmute': + inputManager.handleCommand('unmute'); + return; + case 'ToggleMute': + inputManager.handleCommand('togglemute'); + return; + case 'SetVolume': + notifyApp(); + playbackManager.setVolume(cmd.Arguments.Volume); + break; + case 'SetAudioStreamIndex': + notifyApp(); + playbackManager.setAudioStreamIndex(parseInt(cmd.Arguments.Index)); + break; + case 'SetSubtitleStreamIndex': + notifyApp(); + playbackManager.setSubtitleStreamIndex(parseInt(cmd.Arguments.Index)); + break; + case 'ToggleFullscreen': + inputManager.handleCommand('togglefullscreen'); + return; + case 'GoHome': + inputManager.handleCommand('home'); + return; + case 'GoToSettings': + inputManager.handleCommand('settings'); + return; + case 'DisplayContent': + displayContent(cmd, apiClient); + break; + case 'GoToSearch': + inputManager.handleCommand('search'); + return; + case 'DisplayMessage': + displayMessage(cmd); + break; + case 'ToggleOsd': + // todo + break; + case 'ToggleContextMenu': + // todo + break; + case 'TakeScreenShot': + // todo + break; + case 'SendKey': + // todo + break; + case 'SendString': + // todo + focusManager.sendText(cmd.Arguments.String); + break; + default: + console.debug('processGeneralCommand does not recognize: ' + cmd.Name); + break; + } + + notifyApp(); +} + +function onMessageReceived(e, msg) { + const apiClient = this; + if (msg.MessageType === 'Play') { + notifyApp(); + const serverId = apiClient.serverInfo().Id; + if (msg.Data.PlayCommand === 'PlayNext') { + playbackManager.queueNext({ ids: msg.Data.ItemIds, serverId: serverId }); + } else if (msg.Data.PlayCommand === 'PlayLast') { + playbackManager.queue({ ids: msg.Data.ItemIds, serverId: serverId }); + } else { + playbackManager.play({ + ids: msg.Data.ItemIds, + startPositionTicks: msg.Data.StartPositionTicks, + mediaSourceId: msg.Data.MediaSourceId, + audioStreamIndex: msg.Data.AudioStreamIndex, + subtitleStreamIndex: msg.Data.SubtitleStreamIndex, + startIndex: msg.Data.StartIndex, + serverId: serverId + }); + } + } else if (msg.MessageType === 'Playstate') { + if (msg.Data.Command === 'Stop') { + inputManager.handleCommand('stop'); + } else if (msg.Data.Command === 'Pause') { + inputManager.handleCommand('pause'); + } else if (msg.Data.Command === 'Unpause') { + inputManager.handleCommand('play'); + } else if (msg.Data.Command === 'PlayPause') { + inputManager.handleCommand('playpause'); + } else if (msg.Data.Command === 'Seek') { + playbackManager.seek(msg.Data.SeekPositionTicks); + } else if (msg.Data.Command === 'NextTrack') { + inputManager.handleCommand('next'); + } else if (msg.Data.Command === 'PreviousTrack') { + inputManager.handleCommand('previous'); + } else { + notifyApp(); + } + } else if (msg.MessageType === 'GeneralCommand') { + const cmd = msg.Data; + processGeneralCommand(cmd, apiClient); + } else if (msg.MessageType === 'UserDataChanged') { + if (msg.Data.UserId === apiClient.getCurrentUserId()) { + for (let i = 0, length = msg.Data.UserDataList.length; i < length; i++) { + events.trigger(serverNotifications, 'UserDataChanged', [apiClient, msg.Data.UserDataList[i]]); + } + } + } else if (msg.MessageType === 'SyncPlayCommand') { + syncPlayManager.processCommand(msg.Data, apiClient); + } else if (msg.MessageType === 'SyncPlayGroupUpdate') { + syncPlayManager.processGroupUpdate(msg.Data, apiClient); + } else { + events.trigger(serverNotifications, msg.MessageType, [apiClient, msg.Data]); + } +} +function bindEvents(apiClient) { + events.off(apiClient, 'message', onMessageReceived); + events.on(apiClient, 'message', onMessageReceived); +} + +connectionManager.getApiClients().forEach(bindEvents); +events.on(connectionManager, 'apiclientcreated', function (e, newApiClient) { + bindEvents(newApiClient); }); + +export default serverNotifications; diff --git a/src/scripts/shell.js b/src/scripts/shell.js index 4f1aa0c8de..390ddae82c 100644 --- a/src/scripts/shell.js +++ b/src/scripts/shell.js @@ -1,24 +1,21 @@ -define([], function () { - 'use strict'; - - return { - openUrl: function (url, target) { - if (window.NativeShell) { - window.NativeShell.openUrl(url, target); - } else { - window.open(url, target || '_blank'); - } - - }, - enableFullscreen: function () { - if (window.NativeShell) { - window.NativeShell.enableFullscreen(); - } - }, - disableFullscreen: function () { - if (window.NativeShell) { - window.NativeShell.disableFullscreen(); - } +// TODO: This seems like a good candidate for deprecation +export default { + openUrl: function (url, target) { + if (window.NativeShell) { + window.NativeShell.openUrl(url, target); + } else { + window.open(url, target || '_blank'); } - }; -}); + + }, + enableFullscreen: function () { + if (window.NativeShell) { + window.NativeShell.enableFullscreen(); + } + }, + disableFullscreen: function () { + if (window.NativeShell) { + window.NativeShell.disableFullscreen(); + } + } +}; From 4fce7f8be5076cb8cc05546c6ef0b33ebee6f14e Mon Sep 17 00:00:00 2001 From: MrTimscampi Date: Sun, 26 Jul 2020 22:52:55 +0200 Subject: [PATCH 002/301] Migrate scrollHelper to ES6 --- package.json | 1 + .../collectionEditor/collectionEditor.js | 2 +- src/components/dialogHelper/dialogHelper.js | 2 +- src/components/filtermenu/filtermenu.js | 1 + src/components/guide/guide-settings.js | 2 + src/components/guide/guide.js | 2 + .../imageDownloader/imageDownloader.js | 2 + src/components/imageeditor/imageeditor.js | 2 + .../playlisteditor/playlisteditor.js | 2 +- .../recordingcreator/recordingcreator.js | 2 + .../recordingcreator/recordingeditor.js | 2 + .../recordingcreator/seriesrecordingeditor.js | 2 + src/components/refreshdialog/refreshdialog.js | 1 + src/components/sortmenu/sortmenu.js | 1 + .../subtitleeditor/subtitleeditor.js | 1 + src/components/tunerPicker.js | 2 + src/components/viewSettings/viewSettings.js | 1 + src/scripts/scrollHelper.js | 250 +++++++++--------- 18 files changed, 150 insertions(+), 128 deletions(-) diff --git a/package.json b/package.json index 12ed63929a..7a80b89140 100644 --- a/package.json +++ b/package.json @@ -250,6 +250,7 @@ "src/scripts/inputManager.js", "src/scripts/keyboardNavigation.js", "src/scripts/playlists.js", + "src/scripts/scrollHelper.js", "src/scripts/serverNotifications.js", "src/scripts/settings/appSettings.js", "src/scripts/settings/userSettings.js", diff --git a/src/components/collectionEditor/collectionEditor.js b/src/components/collectionEditor/collectionEditor.js index 18cc0d311f..67daad9f2e 100644 --- a/src/components/collectionEditor/collectionEditor.js +++ b/src/components/collectionEditor/collectionEditor.js @@ -212,7 +212,7 @@ import 'flexStyles'; } function centerFocus(elem, horiz, on) { - import('scrollHelper').then(scrollHelper => { + import('scrollHelper').then((scrollHelper) => { const fn = on ? 'on' : 'off'; scrollHelper.centerFocus[fn](elem, horiz); }); diff --git a/src/components/dialogHelper/dialogHelper.js b/src/components/dialogHelper/dialogHelper.js index ca7c94a416..af1a278cb4 100644 --- a/src/components/dialogHelper/dialogHelper.js +++ b/src/components/dialogHelper/dialogHelper.js @@ -376,7 +376,7 @@ import 'scrollStyles'; } function centerFocus(elem, horiz, on) { - import('scrollHelper').then(scrollHelper => { + import('scrollHelper').then((scrollHelper) => { const fn = on ? 'on' : 'off'; scrollHelper.centerFocus[fn](elem, horiz); }); diff --git a/src/components/filtermenu/filtermenu.js b/src/components/filtermenu/filtermenu.js index 936e2b0407..075af143d2 100644 --- a/src/components/filtermenu/filtermenu.js +++ b/src/components/filtermenu/filtermenu.js @@ -194,6 +194,7 @@ define(['require', 'dom', 'focusManager', 'dialogHelper', 'loading', 'apphost', function centerFocus(elem, horiz, on) { require(['scrollHelper'], function (scrollHelper) { + scrollHelper = scrollHelper.default || scrollHelper; var fn = on ? 'on' : 'off'; scrollHelper.centerFocus[fn](elem, horiz); }); diff --git a/src/components/guide/guide-settings.js b/src/components/guide/guide-settings.js index 77a3637251..aded7ac5dd 100644 --- a/src/components/guide/guide-settings.js +++ b/src/components/guide/guide-settings.js @@ -1,6 +1,8 @@ define(['dialogHelper', 'globalize', 'userSettings', 'layoutManager', 'connectionManager', 'require', 'loading', 'scrollHelper', 'emby-checkbox', 'emby-radio', 'css!./../formdialog', 'material-icons'], function (dialogHelper, globalize, userSettings, layoutManager, connectionManager, require, loading, scrollHelper) { 'use strict'; + scrollHelper = scrollHelper.default || scrollHelper; + function saveCategories(context, options) { var categories = []; diff --git a/src/components/guide/guide.js b/src/components/guide/guide.js index e18f053a5a..0d3c721e2d 100644 --- a/src/components/guide/guide.js +++ b/src/components/guide/guide.js @@ -1,6 +1,8 @@ define(['require', 'inputManager', 'browser', 'globalize', 'connectionManager', 'scrollHelper', 'serverNotifications', 'loading', 'datetime', 'focusManager', 'playbackManager', 'userSettings', 'imageLoader', 'events', 'layoutManager', 'itemShortcuts', 'dom', 'css!./guide.css', 'programStyles', 'material-icons', 'scrollStyles', 'emby-programcell', 'emby-button', 'paper-icon-button-light', 'emby-tabs', 'emby-scroller', 'flexStyles', 'webcomponents'], function (require, inputManager, browser, globalize, connectionManager, scrollHelper, serverNotifications, loading, datetime, focusManager, playbackManager, userSettings, imageLoader, events, layoutManager, itemShortcuts, dom) { 'use strict'; + scrollHelper = scrollHelper.default || scrollHelper; + serverNotifications = serverNotifications.default || serverNotifications; function showViewSettings(instance) { diff --git a/src/components/imageDownloader/imageDownloader.js b/src/components/imageDownloader/imageDownloader.js index fbe98c532f..9ad65dd157 100644 --- a/src/components/imageDownloader/imageDownloader.js +++ b/src/components/imageDownloader/imageDownloader.js @@ -1,6 +1,8 @@ define(['dom', 'loading', 'apphost', 'dialogHelper', 'connectionManager', 'imageLoader', 'browser', 'layoutManager', 'scrollHelper', 'globalize', 'require', 'emby-checkbox', 'paper-icon-button-light', 'emby-button', 'formDialogStyle', 'cardStyle'], function (dom, loading, appHost, dialogHelper, connectionManager, imageLoader, browser, layoutManager, scrollHelper, globalize, require) { 'use strict'; + scrollHelper = scrollHelper.default || scrollHelper; + var enableFocusTransform = !browser.slow && !browser.edge; var currentItemId; diff --git a/src/components/imageeditor/imageeditor.js b/src/components/imageeditor/imageeditor.js index 0a873fa4c7..766304f9aa 100644 --- a/src/components/imageeditor/imageeditor.js +++ b/src/components/imageeditor/imageeditor.js @@ -1,6 +1,8 @@ define(['dialogHelper', 'connectionManager', 'loading', 'dom', 'layoutManager', 'focusManager', 'globalize', 'scrollHelper', 'imageLoader', 'require', 'browser', 'apphost', 'cardStyle', 'formDialogStyle', 'emby-button', 'paper-icon-button-light', 'css!./imageeditor'], function (dialogHelper, connectionManager, loading, dom, layoutManager, focusManager, globalize, scrollHelper, imageLoader, require, browser, appHost) { 'use strict'; + scrollHelper = scrollHelper.default || scrollHelper; + var enableFocusTransform = !browser.slow && !browser.edge; var currentItem; diff --git a/src/components/playlisteditor/playlisteditor.js b/src/components/playlisteditor/playlisteditor.js index 7b1e915e1f..78f0cf3dec 100644 --- a/src/components/playlisteditor/playlisteditor.js +++ b/src/components/playlisteditor/playlisteditor.js @@ -210,7 +210,7 @@ import 'emby-button'; } function centerFocus(elem, horiz, on) { - import('scrollHelper').then(scrollHelper => { + import('scrollHelper').then((scrollHelper) => { const fn = on ? 'on' : 'off'; scrollHelper.centerFocus[fn](elem, horiz); }); diff --git a/src/components/recordingcreator/recordingcreator.js b/src/components/recordingcreator/recordingcreator.js index d18d5fcb6c..3b7cbe49aa 100644 --- a/src/components/recordingcreator/recordingcreator.js +++ b/src/components/recordingcreator/recordingcreator.js @@ -1,6 +1,8 @@ define(['dialogHelper', 'globalize', 'layoutManager', 'mediaInfo', 'apphost', 'connectionManager', 'require', 'loading', 'scrollHelper', 'datetime', 'imageLoader', 'recordingFields', 'events', 'emby-checkbox', 'emby-button', 'emby-collapse', 'emby-input', 'paper-icon-button-light', 'css!./../formdialog', 'css!./recordingcreator', 'material-icons'], function (dialogHelper, globalize, layoutManager, mediaInfo, appHost, connectionManager, require, loading, scrollHelper, datetime, imageLoader, recordingFields, events) { 'use strict'; + scrollHelper = scrollHelper.default || scrollHelper; + var currentDialog; var closeAction; var currentRecordingFields; diff --git a/src/components/recordingcreator/recordingeditor.js b/src/components/recordingcreator/recordingeditor.js index c3f40fcddb..2fde735404 100644 --- a/src/components/recordingcreator/recordingeditor.js +++ b/src/components/recordingcreator/recordingeditor.js @@ -1,6 +1,8 @@ define(['dialogHelper', 'globalize', 'layoutManager', 'mediaInfo', 'apphost', 'connectionManager', 'require', 'loading', 'scrollHelper', 'imageLoader', 'scrollStyles', 'emby-button', 'emby-collapse', 'emby-input', 'paper-icon-button-light', 'css!./../formdialog', 'css!./recordingcreator', 'material-icons', 'flexStyles'], function (dialogHelper, globalize, layoutManager, mediaInfo, appHost, connectionManager, require, loading, scrollHelper, imageLoader) { 'use strict'; + scrollHelper = scrollHelper.default || scrollHelper; + var currentDialog; var recordingDeleted = false; var currentItemId; diff --git a/src/components/recordingcreator/seriesrecordingeditor.js b/src/components/recordingcreator/seriesrecordingeditor.js index a101ce53ec..053dd1a12c 100644 --- a/src/components/recordingcreator/seriesrecordingeditor.js +++ b/src/components/recordingcreator/seriesrecordingeditor.js @@ -1,6 +1,8 @@ define(['dialogHelper', 'globalize', 'layoutManager', 'mediaInfo', 'apphost', 'connectionManager', 'require', 'loading', 'scrollHelper', 'imageLoader', 'datetime', 'scrollStyles', 'emby-button', 'emby-checkbox', 'emby-input', 'emby-select', 'paper-icon-button-light', 'css!./../formdialog', 'css!./recordingcreator', 'material-icons', 'flexStyles'], function (dialogHelper, globalize, layoutManager, mediaInfo, appHost, connectionManager, require, loading, scrollHelper, imageLoader, datetime) { 'use strict'; + scrollHelper = scrollHelper.default || scrollHelper; + var currentDialog; var recordingUpdated = false; var recordingDeleted = false; diff --git a/src/components/refreshdialog/refreshdialog.js b/src/components/refreshdialog/refreshdialog.js index 3edb725c4a..593cc0dc2d 100644 --- a/src/components/refreshdialog/refreshdialog.js +++ b/src/components/refreshdialog/refreshdialog.js @@ -42,6 +42,7 @@ define(['dom', 'shell', 'dialogHelper', 'loading', 'layoutManager', 'connectionM function centerFocus(elem, horiz, on) { require(['scrollHelper'], function (scrollHelper) { + scrollHelper = scrollHelper.default || scrollHelper; var fn = on ? 'on' : 'off'; scrollHelper.centerFocus[fn](elem, horiz); }); diff --git a/src/components/sortmenu/sortmenu.js b/src/components/sortmenu/sortmenu.js index dbf7ef1a7f..abe55a6092 100644 --- a/src/components/sortmenu/sortmenu.js +++ b/src/components/sortmenu/sortmenu.js @@ -17,6 +17,7 @@ define(['require', 'dom', 'focusManager', 'dialogHelper', 'loading', 'layoutMana function centerFocus(elem, horiz, on) { require(['scrollHelper'], function (scrollHelper) { + scrollHelper = scrollHelper.default || scrollHelper; var fn = on ? 'on' : 'off'; scrollHelper.centerFocus[fn](elem, horiz); }); diff --git a/src/components/subtitleeditor/subtitleeditor.js b/src/components/subtitleeditor/subtitleeditor.js index 9c0992c53c..4c33252574 100644 --- a/src/components/subtitleeditor/subtitleeditor.js +++ b/src/components/subtitleeditor/subtitleeditor.js @@ -420,6 +420,7 @@ define(['dialogHelper', 'require', 'layoutManager', 'globalize', 'userSettings', function centerFocus(elem, horiz, on) { require(['scrollHelper'], function (scrollHelper) { + scrollHelper = scrollHelper.default || scrollHelper; var fn = on ? 'on' : 'off'; scrollHelper.centerFocus[fn](elem, horiz); }); diff --git a/src/components/tunerPicker.js b/src/components/tunerPicker.js index e7c92851a4..f064f95152 100644 --- a/src/components/tunerPicker.js +++ b/src/components/tunerPicker.js @@ -1,6 +1,8 @@ define(['dialogHelper', 'dom', 'layoutManager', 'connectionManager', 'globalize', 'loading', 'browser', 'focusManager', 'scrollHelper', 'material-icons', 'formDialogStyle', 'emby-button', 'emby-itemscontainer', 'cardStyle'], function (dialogHelper, dom, layoutManager, connectionManager, globalize, loading, browser, focusManager, scrollHelper) { 'use strict'; + scrollHelper = scrollHelper.default || scrollHelper; + var enableFocusTransform = !browser.slow && !browser.edge; function getEditorHtml() { diff --git a/src/components/viewSettings/viewSettings.js b/src/components/viewSettings/viewSettings.js index 28a9854c34..198c0a541c 100644 --- a/src/components/viewSettings/viewSettings.js +++ b/src/components/viewSettings/viewSettings.js @@ -33,6 +33,7 @@ define(['require', 'dialogHelper', 'loading', 'apphost', 'layoutManager', 'conne function centerFocus(elem, horiz, on) { require(['scrollHelper'], function (scrollHelper) { + scrollHelper = scrollHelper.default || scrollHelper; var fn = on ? 'on' : 'off'; scrollHelper.centerFocus[fn](elem, horiz); }); diff --git a/src/scripts/scrollHelper.js b/src/scripts/scrollHelper.js index 1a36594026..020888a2e3 100644 --- a/src/scripts/scrollHelper.js +++ b/src/scripts/scrollHelper.js @@ -1,137 +1,137 @@ -define(['focusManager', 'dom', 'scrollStyles'], function (focusManager, dom) { - 'use strict'; +import focusManager from 'focusManager'; +import dom from 'dom'; +import 'scrollStyles'; - function getBoundingClientRect(elem) { +function getBoundingClientRect(elem) { - // Support: BlackBerry 5, iOS 3 (original iPhone) - // If we don't have gBCR, just use 0,0 rather than error - if (elem.getBoundingClientRect) { - return elem.getBoundingClientRect(); - } else { - return { top: 0, left: 0 }; - } + // Support: BlackBerry 5, iOS 3 (original iPhone) + // If we don't have gBCR, just use 0,0 rather than error + if (elem.getBoundingClientRect) { + return elem.getBoundingClientRect(); + } else { + return { top: 0, left: 0 }; + } +} + +export function getPosition(scrollContainer, item, horizontal) { + + const slideeOffset = getBoundingClientRect(scrollContainer); + const itemOffset = getBoundingClientRect(item); + + let offset = horizontal ? itemOffset.left - slideeOffset.left : itemOffset.top - slideeOffset.top; + let size = horizontal ? itemOffset.width : itemOffset.height; + if (!size && size !== 0) { + size = item[horizontal ? 'offsetWidth' : 'offsetHeight']; } - function getPosition(scrollContainer, item, horizontal) { + const currentStart = horizontal ? scrollContainer.scrollLeft : scrollContainer.scrollTop; - var slideeOffset = getBoundingClientRect(scrollContainer); - var itemOffset = getBoundingClientRect(item); + offset += currentStart; - var offset = horizontal ? itemOffset.left - slideeOffset.left : itemOffset.top - slideeOffset.top; - var size = horizontal ? itemOffset.width : itemOffset.height; - if (!size && size !== 0) { - size = item[horizontal ? 'offsetWidth' : 'offsetHeight']; - } + const frameSize = horizontal ? scrollContainer.offsetWidth : scrollContainer.offsetHeight; - var currentStart = horizontal ? scrollContainer.scrollLeft : scrollContainer.scrollTop; + const currentEnd = currentStart + frameSize; - offset += currentStart; - - var frameSize = horizontal ? scrollContainer.offsetWidth : scrollContainer.offsetHeight; - - var currentEnd = currentStart + frameSize; - - var isVisible = offset >= currentStart && (offset + size) <= currentEnd; - - return { - start: offset, - center: (offset - (frameSize / 2) + (size / 2)), - end: offset - frameSize + size, - size: size, - isVisible: isVisible - }; - } - - function toCenter(container, elem, horizontal, skipWhenVisible) { - var pos = getPosition(container, elem, horizontal); - - if (skipWhenVisible && pos.isVisible) { - return; - } - - if (container.scrollTo) { - if (horizontal) { - container.scrollTo(pos.center, 0); - } else { - container.scrollTo(0, pos.center); - } - } else { - if (horizontal) { - container.scrollLeft = Math.round(pos.center); - } else { - container.scrollTop = Math.round(pos.center); - } - } - } - - function toStart(container, elem, horizontal, skipWhenVisible) { - var pos = getPosition(container, elem, horizontal); - - if (skipWhenVisible && pos.isVisible) { - return; - } - - if (container.scrollTo) { - if (horizontal) { - container.scrollTo(pos.start, 0); - } else { - container.scrollTo(0, pos.start); - } - } else { - if (horizontal) { - container.scrollLeft = Math.round(pos.start); - } else { - container.scrollTop = Math.round(pos.start); - } - } - } - - function centerOnFocus(e, scrollSlider, horizontal) { - var focused = focusManager.focusableParent(e.target); - - if (focused) { - toCenter(scrollSlider, focused, horizontal); - } - } - - function centerOnFocusHorizontal(e) { - centerOnFocus(e, this, true); - } - function centerOnFocusVertical(e) { - centerOnFocus(e, this, false); - } + const isVisible = offset >= currentStart && (offset + size) <= currentEnd; return { - getPosition: getPosition, - centerFocus: { - on: function (element, horizontal) { - if (horizontal) { - dom.addEventListener(element, 'focus', centerOnFocusHorizontal, { - capture: true, - passive: true - }); - } else { - dom.addEventListener(element, 'focus', centerOnFocusVertical, { - capture: true, - passive: true - }); - } - }, - off: function (element, horizontal) { - if (horizontal) { - dom.removeEventListener(element, 'focus', centerOnFocusHorizontal, { - capture: true, - passive: true - }); - } else { - dom.removeEventListener(element, 'focus', centerOnFocusVertical, { - capture: true, - passive: true - }); - } + start: offset, + center: (offset - (frameSize / 2) + (size / 2)), + end: offset - frameSize + size, + size: size, + isVisible: isVisible + }; +} + +export function toCenter(container, elem, horizontal, skipWhenVisible) { + const pos = getPosition(container, elem, horizontal); + + if (skipWhenVisible && pos.isVisible) { + return; + } + + if (container.scrollTo) { + if (horizontal) { + container.scrollTo(pos.center, 0); + } else { + container.scrollTo(0, pos.center); + } + } else { + if (horizontal) { + container.scrollLeft = Math.round(pos.center); + } else { + container.scrollTop = Math.round(pos.center); + } + } +} + +export function toStart(container, elem, horizontal, skipWhenVisible) { + const pos = getPosition(container, elem, horizontal); + + if (skipWhenVisible && pos.isVisible) { + return; + } + + if (container.scrollTo) { + if (horizontal) { + container.scrollTo(pos.start, 0); + } else { + container.scrollTo(0, pos.start); + } + } else { + if (horizontal) { + container.scrollLeft = Math.round(pos.start); + } else { + container.scrollTop = Math.round(pos.start); + } + } +} + +function centerOnFocus(e, scrollSlider, horizontal) { + const focused = focusManager.focusableParent(e.target); + + if (focused) { + toCenter(scrollSlider, focused, horizontal); + } +} + +function centerOnFocusHorizontal(e) { + centerOnFocus(e, this, true); +} +function centerOnFocusVertical(e) { + centerOnFocus(e, this, false); +} + +export default { + getPosition: getPosition, + centerFocus: { + on: function (element, horizontal) { + if (horizontal) { + dom.addEventListener(element, 'focus', centerOnFocusHorizontal, { + capture: true, + passive: true + }); + } else { + dom.addEventListener(element, 'focus', centerOnFocusVertical, { + capture: true, + passive: true + }); } }, - toCenter: toCenter, - toStart: toStart - }; -}); + off: function (element, horizontal) { + if (horizontal) { + dom.removeEventListener(element, 'focus', centerOnFocusHorizontal, { + capture: true, + passive: true + }); + } else { + dom.removeEventListener(element, 'focus', centerOnFocusVertical, { + capture: true, + passive: true + }); + } + } + }, + toCenter: toCenter, + toStart: toStart +}; From f9e79c0a4eda2b6aca51244eb59d7541c47a7fdb Mon Sep 17 00:00:00 2001 From: Cameron Date: Tue, 28 Jul 2020 21:28:16 +0100 Subject: [PATCH 003/301] Migration of list.js and screensavermanager to ES6 modules --- .eslintignore | 1 - package.json | 2 + src/controllers/list.js | 270 ++++++++++++++-------------- src/libraries/screensavermanager.js | 256 +++++++++++++------------- 4 files changed, 264 insertions(+), 265 deletions(-) diff --git a/.eslintignore b/.eslintignore index 8e3aee83fb..74b18ddcf6 100644 --- a/.eslintignore +++ b/.eslintignore @@ -2,4 +2,3 @@ node_modules dist .idea .vscode -src/libraries diff --git a/package.json b/package.json index 30c0c481e6..f412c0671a 100644 --- a/package.json +++ b/package.json @@ -188,6 +188,7 @@ "src/controllers/dashboard/users/userparentalcontrol.js", "src/controllers/dashboard/users/userpasswordpage.js", "src/controllers/dashboard/users/userprofilespage.js", + "src/controllers/list.js", "src/controllers/playback/queue/index.js", "src/controllers/playback/video/index.js", "src/controllers/searchpage.js", @@ -230,6 +231,7 @@ "src/elements/emby-tabs/emby-tabs.js", "src/elements/emby-textarea/emby-textarea.js", "src/elements/emby-toggle/emby-toggle.js", + "src/libraries/screensavermanager.js", "src/plugins/backdropScreensaver/plugin.js", "src/plugins/bookPlayer/plugin.js", "src/plugins/bookPlayer/tableOfContents.js", diff --git a/src/controllers/list.js b/src/controllers/list.js index e550b535f4..c7c4b2a31d 100644 --- a/src/controllers/list.js +++ b/src/controllers/list.js @@ -1,8 +1,21 @@ -define(['globalize', 'listView', 'layoutManager', 'userSettings', 'focusManager', 'cardBuilder', 'loading', 'connectionManager', 'alphaNumericShortcuts', 'scroller', 'playbackManager', 'alphaPicker', 'emby-itemscontainer', 'emby-scroller'], function (globalize, listView, layoutManager, userSettings, focusManager, cardBuilder, loading, connectionManager, AlphaNumericShortcuts, scroller, playbackManager, AlphaPicker) { - 'use strict'; +import globalize from 'globalize'; +import listView from 'listView'; +import layoutManager from 'layoutManager'; +import * as userSettings from 'userSettings'; +import focusManager from 'focusManager'; +import cardBuilder from 'cardBuilder'; +import loading from 'loading'; +import connectionManager from 'connectionManager'; +import AlphaNumericShortcuts from 'alphaNumericShortcuts'; +import playbackManager from 'playbackManager'; +import AlphaPicker from 'alphaPicker'; +import 'emby-itemscontainer'; +import 'emby-scroller'; + +/* eslint-disable indent */ function getInitialLiveTvQuery(instance, params) { - var query = { + const query = { UserId: connectionManager.getApiClient(params.serverId).getCurrentUserId(), StartIndex: 0, Fields: 'ChannelInfo,PrimaryImageAspectRatio', @@ -59,7 +72,7 @@ define(['globalize', 'listView', 'layoutManager', 'userSettings', 'focusManager' } function modifyQueryWithFilters(instance, query) { - var sortValues = instance.getSortValues(); + const sortValues = instance.getSortValues(); if (!query.SortBy) { query.SortBy = sortValues.sortBy; @@ -68,9 +81,9 @@ define(['globalize', 'listView', 'layoutManager', 'userSettings', 'focusManager' query.Fields = query.Fields ? query.Fields + ',PrimaryImageAspectRatio' : 'PrimaryImageAspectRatio'; query.ImageTypeLimit = 1; - var hasFilters; - var queryFilters = []; - var filters = instance.getFilters(); + let hasFilters; + const queryFilters = []; + const filters = instance.getFilters(); if (filters.IsPlayed) { queryFilters.push('IsPlayed'); @@ -164,21 +177,21 @@ define(['globalize', 'listView', 'layoutManager', 'userSettings', 'focusManager' } function updateSortText(instance) { - var btnSortText = instance.btnSortText; + const btnSortText = instance.btnSortText; if (btnSortText) { - var options = instance.getSortMenuOptions(); - var values = instance.getSortValues(); - var sortBy = values.sortBy; + const options = instance.getSortMenuOptions(); + const values = instance.getSortValues(); + const sortBy = values.sortBy; - for (var i = 0, length = options.length; i < length; i++) { + for (let i = 0, length = options.length; i < length; i++) { if (sortBy === options[i].value) { btnSortText.innerHTML = globalize.translate('SortByValue', options[i].name); break; } } - var btnSortIcon = instance.btnSortIcon; + const btnSortIcon = instance.btnSortIcon; if (btnSortIcon) { setSortButtonIcon(btnSortIcon, 'Descending' === values.sortOrder ? 'arrow_downward' : 'arrow_upward'); @@ -198,10 +211,10 @@ define(['globalize', 'listView', 'layoutManager', 'userSettings', 'focusManager' function updateAlphaPickerState(instance, numItems) { if (instance.alphaPicker) { - var alphaPicker = instance.alphaPickerElement; + const alphaPicker = instance.alphaPickerElement; if (alphaPicker) { - var values = instance.getSortValues(); + const values = instance.getSortValues(); if (null == numItems) { numItems = 100; @@ -219,7 +232,7 @@ define(['globalize', 'listView', 'layoutManager', 'userSettings', 'focusManager' } function getItems(instance, params, item, sortBy, startIndex, limit) { - var apiClient = connectionManager.getApiClient(params.serverId); + const apiClient = connectionManager.getApiClient(params.serverId); instance.queryRecursive = false; if ('Recordings' === params.type) { @@ -248,7 +261,7 @@ define(['globalize', 'listView', 'layoutManager', 'userSettings', 'focusManager' if (!item) { instance.queryRecursive = true; - var method = 'getItems'; + let method = 'getItems'; if ('MusicArtist' === params.type) { method = 'getArtists'; @@ -271,7 +284,7 @@ define(['globalize', 'listView', 'layoutManager', 'userSettings', 'focusManager' if ('Genre' === item.Type || 'MusicGenre' === item.Type || 'Studio' === item.Type || 'Person' === item.Type) { instance.queryRecursive = true; - var query = { + const query = { StartIndex: startIndex, Limit: limit, Fields: 'PrimaryImageAspectRatio,SortName', @@ -320,8 +333,8 @@ define(['globalize', 'listView', 'layoutManager', 'userSettings', 'focusManager' return Promise.resolve(null); } - var apiClient = connectionManager.getApiClient(params.serverId); - var itemId = params.genreId || params.musicGenreId || params.studioId || params.personId || params.parentId; + const apiClient = connectionManager.getApiClient(params.serverId); + const itemId = params.genreId || params.musicGenreId || params.studioId || params.personId || params.parentId; if (itemId) { return apiClient.getItem(apiClient.getCurrentUserId(), itemId); @@ -331,9 +344,9 @@ define(['globalize', 'listView', 'layoutManager', 'userSettings', 'focusManager' } function showViewSettingsMenu() { - var instance = this; + const instance = this; - require(['viewSettings'], function (ViewSettings) { + import('viewSettings').then(({default: ViewSettings}) => { new ViewSettings().show({ settingsKey: instance.getSettingsKey(), settings: instance.getViewSettings(), @@ -346,9 +359,9 @@ define(['globalize', 'listView', 'layoutManager', 'userSettings', 'focusManager' } function showFilterMenu() { - var instance = this; + const instance = this; - require(['filterMenu'], function (FilterMenu) { + import('filterMenu').then(({default: FilterMenu}) => { new FilterMenu().show({ settingsKey: instance.getSettingsKey(), settings: instance.getFilters(), @@ -365,9 +378,9 @@ define(['globalize', 'listView', 'layoutManager', 'userSettings', 'focusManager' } function showSortMenu() { - var instance = this; + const instance = this; - require(['sortMenu'], function (SortMenu) { + import('sortMenu').then(({default: SortMenu}) => { new SortMenu().show({ settingsKey: instance.getSettingsKey(), settings: instance.getSortValues(), @@ -383,9 +396,9 @@ define(['globalize', 'listView', 'layoutManager', 'userSettings', 'focusManager' } function onNewItemClick() { - var instance = this; + const instance = this; - require(['playlistEditor'], function (playlistEditor) { + import('playlistEditor').then(({default: playlistEditor}) => { new playlistEditor.showEditor({ items: [], serverId: instance.params.serverId @@ -394,7 +407,7 @@ define(['globalize', 'listView', 'layoutManager', 'userSettings', 'focusManager' } function hideOrShowAll(elems, hide) { - for (var i = 0, length = elems.length; i < length; i++) { + for (let i = 0, length = elems.length; i < length; i++) { if (hide) { elems[i].classList.add('hide'); } else { @@ -404,12 +417,13 @@ define(['globalize', 'listView', 'layoutManager', 'userSettings', 'focusManager' } function bindAll(elems, eventName, fn) { - for (var i = 0, length = elems.length; i < length; i++) { + for (let i = 0, length = elems.length; i < length; i++) { elems[i].addEventListener(eventName, fn); } } - function ItemsView(view, params) { +class ItemsView { + constructor(view, params) { function fetchData() { return getItems(self, params, self.currentItem).then(function (result) { if (null == self.totalItemCount) { @@ -422,7 +436,7 @@ define(['globalize', 'listView', 'layoutManager', 'userSettings', 'focusManager' } function getItemsHtml(items) { - var settings = self.getViewSettings(); + const settings = self.getViewSettings(); if ('list' === settings.imageType) { return listView.getListViewHtml({ @@ -430,13 +444,13 @@ define(['globalize', 'listView', 'layoutManager', 'userSettings', 'focusManager' }); } - var shape; - var preferThumb; - var preferDisc; - var preferLogo; - var defaultShape; - var item = self.currentItem; - var lines = settings.showTitle ? 2 : 0; + let shape; + let preferThumb; + let preferDisc; + let preferLogo; + let defaultShape; + const item = self.currentItem; + let lines = settings.showTitle ? 2 : 0; if ('banner' === settings.imageType) { shape = 'banner'; @@ -460,7 +474,7 @@ define(['globalize', 'listView', 'layoutManager', 'userSettings', 'focusManager' shape = 'autoVertical'; } - var posterOptions = { + let posterOptions = { shape: shape, showTitle: settings.showTitle, showYear: settings.showTitle, @@ -493,19 +507,19 @@ define(['globalize', 'listView', 'layoutManager', 'userSettings', 'focusManager' lines = 1; } else if ('Programs' === params.type) { lines = settings.showTitle ? 1 : 0; - var showParentTitle = settings.showTitle && 'true' !== params.IsMovie; + const showParentTitle = settings.showTitle && 'true' !== params.IsMovie; if (showParentTitle) { lines++; } - var showAirTime = settings.showTitle && 'Recordings' !== params.type; + const showAirTime = settings.showTitle && 'Recordings' !== params.type; if (showAirTime) { lines++; } - var showYear = settings.showTitle && 'true' === params.IsMovie && 'Recordings' === params.type; + const showYear = settings.showTitle && 'true' === params.IsMovie && 'Recordings' === params.type; if (showYear) { lines++; @@ -538,7 +552,7 @@ define(['globalize', 'listView', 'layoutManager', 'userSettings', 'focusManager' function initAlphaPicker() { self.scroller = view.querySelector('.scrollFrameY'); - var alphaPickerElement = self.alphaPickerElement; + const alphaPickerElement = self.alphaPickerElement; alphaPickerElement.classList.add('alphaPicker-fixed-right'); alphaPickerElement.classList.add('focuscontainer-right'); @@ -649,7 +663,7 @@ define(['globalize', 'listView', 'layoutManager', 'userSettings', 'focusManager' } function play() { - var currentItem = self.currentItem; + const currentItem = self.currentItem; if (currentItem && !self.hasFilters) { playbackManager.play({ @@ -665,7 +679,7 @@ define(['globalize', 'listView', 'layoutManager', 'userSettings', 'focusManager' } function queue() { - var currentItem = self.currentItem; + const currentItem = self.currentItem; if (currentItem && !self.hasFilters) { playbackManager.queue({ @@ -681,7 +695,7 @@ define(['globalize', 'listView', 'layoutManager', 'userSettings', 'focusManager' } function shuffle() { - var currentItem = self.currentItem; + const currentItem = self.currentItem; if (currentItem && !self.hasFilters) { playbackManager.shuffle(currentItem); @@ -694,7 +708,7 @@ define(['globalize', 'listView', 'layoutManager', 'userSettings', 'focusManager' } } - var self = this; + const self = this; self.params = params; this.itemsContainer = view.querySelector('.itemsContainer'); @@ -708,20 +722,20 @@ define(['globalize', 'listView', 'layoutManager', 'userSettings', 'focusManager' this.itemsContainer.setAttribute('data-refreshinterval', '300000'); } - var i; - var length; - var btnViewSettings = view.querySelectorAll('.btnViewSettings'); + let i; + let length; + const btnViewSettings = view.querySelectorAll('.btnViewSettings'); for (i = 0, length = btnViewSettings.length; i < length; i++) { btnViewSettings[i].addEventListener('click', showViewSettingsMenu.bind(this)); } - var filterButtons = view.querySelectorAll('.btnFilter'); + const filterButtons = view.querySelectorAll('.btnFilter'); this.filterButtons = filterButtons; - var hasVisibleFilters = this.getVisibleFilters().length; + const hasVisibleFilters = this.getVisibleFilters().length; for (i = 0, length = filterButtons.length; i < length; i++) { - var btnFilter = filterButtons[i]; + const btnFilter = filterButtons[i]; btnFilter.addEventListener('click', showFilterMenu.bind(this)); if (hasVisibleFilters) { @@ -731,10 +745,10 @@ define(['globalize', 'listView', 'layoutManager', 'userSettings', 'focusManager' } } - var sortButtons = view.querySelectorAll('.btnSort'); + const sortButtons = view.querySelectorAll('.btnSort'); for (this.sortButtons = sortButtons, i = 0, length = sortButtons.length; i < length; i++) { - var sortButton = sortButtons[i]; + const sortButton = sortButtons[i]; sortButton.addEventListener('click', showSortMenu.bind(this)); if ('nextup' !== params.type) { @@ -749,7 +763,7 @@ define(['globalize', 'listView', 'layoutManager', 'userSettings', 'focusManager' self.itemsContainer.fetchData = fetchData; self.itemsContainer.getItemsHtml = getItemsHtml; view.addEventListener('viewshow', function (e) { - var isRestored = e.detail.isRestored; + const isRestored = e.detail.isRestored; if (!isRestored) { loading.show(); @@ -761,7 +775,7 @@ define(['globalize', 'listView', 'layoutManager', 'userSettings', 'focusManager' getItem(params).then(function (item) { setTitle(item); self.currentItem = item; - var refresh = !isRestored; + const refresh = !isRestored; self.itemsContainer.resume({ refresh: refresh }).then(function () { @@ -776,7 +790,7 @@ define(['globalize', 'listView', 'layoutManager', 'userSettings', 'focusManager' initAlphaPicker(); } - var itemType = item ? item.Type : null; + const itemType = item ? item.Type : null; if ('MusicGenre' === itemType || 'Programs' !== params.type && 'Channel' !== itemType) { hideOrShowAll(view.querySelectorAll('.btnPlay'), false); @@ -808,13 +822,13 @@ define(['globalize', 'listView', 'layoutManager', 'userSettings', 'focusManager' }); }); view.addEventListener('viewhide', function (e) { - var itemsContainer = self.itemsContainer; + const itemsContainer = self.itemsContainer; if (itemsContainer) { itemsContainer.pause(); } - var alphaNumericShortcuts = self.alphaNumericShortcuts; + const alphaNumericShortcuts = self.alphaNumericShortcuts; if (alphaNumericShortcuts) { alphaNumericShortcuts.destroy(); @@ -841,9 +855,8 @@ define(['globalize', 'listView', 'layoutManager', 'userSettings', 'focusManager' self.alphaPickerElement = null; }); } - - ItemsView.prototype.getFilters = function () { - var basekey = this.getSettingsKey(); + getFilters() { + const basekey = this.getSettingsKey(); return { IsPlayed: 'true' === userSettings.getFilter(basekey + '-filter-IsPlayed'), IsUnplayed: 'true' === userSettings.getFilter(basekey + '-filter-IsUnplayed'), @@ -862,30 +875,27 @@ define(['globalize', 'listView', 'layoutManager', 'userSettings', 'focusManager' HasThemeVideo: userSettings.getFilter(basekey + '-filter-HasThemeVideo'), GenreIds: userSettings.getFilter(basekey + '-filter-GenreIds') }; - }; - - ItemsView.prototype.getSortValues = function () { - var basekey = this.getSettingsKey(); + } + getSortValues() { + const basekey = this.getSettingsKey(); return { sortBy: userSettings.getFilter(basekey + '-sortby') || this.getDefaultSortBy(), sortOrder: 'Descending' === userSettings.getFilter(basekey + '-sortorder') ? 'Descending' : 'Ascending' }; - }; - - ItemsView.prototype.getDefaultSortBy = function () { - var params = this.params; - var sortNameOption = this.getNameSortOption(params); + } + getDefaultSortBy() { + const params = this.params; + const sortNameOption = this.getNameSortOption(params); if (params.type) { return sortNameOption.value; } return 'IsFolder,' + sortNameOption.value; - }; - - ItemsView.prototype.getSortMenuOptions = function () { - var sortBy = []; - var params = this.params; + } + getSortMenuOptions() { + const sortBy = []; + const params = this.params; if ('Programs' === params.type) { sortBy.push({ @@ -894,7 +904,7 @@ define(['globalize', 'listView', 'layoutManager', 'userSettings', 'focusManager' }); } - var option = this.getNameSortOption(params); + let option = this.getNameSortOption(params); if (option) { sortBy.push(option); @@ -952,9 +962,8 @@ define(['globalize', 'listView', 'layoutManager', 'userSettings', 'focusManager' value: 'Runtime,SortName' }); return sortBy; - }; - - ItemsView.prototype.getNameSortOption = function (params) { + } + getNameSortOption(params) { if ('Episode' === params.type) { return { name: globalize.translate('Name'), @@ -966,9 +975,8 @@ define(['globalize', 'listView', 'layoutManager', 'userSettings', 'focusManager' name: globalize.translate('Name'), value: 'SortName' }; - }; - - ItemsView.prototype.getPlayCountSortOption = function () { + } + getPlayCountSortOption() { if ('Programs' === this.params.type) { return null; } @@ -977,9 +985,8 @@ define(['globalize', 'listView', 'layoutManager', 'userSettings', 'focusManager' name: globalize.translate('PlayCount'), value: 'PlayCount,SortName' }; - }; - - ItemsView.prototype.getDatePlayedSortOption = function () { + } + getDatePlayedSortOption() { if ('Programs' === this.params.type) { return null; } @@ -988,9 +995,8 @@ define(['globalize', 'listView', 'layoutManager', 'userSettings', 'focusManager' name: globalize.translate('DatePlayed'), value: 'DatePlayed,SortName' }; - }; - - ItemsView.prototype.getCriticRatingSortOption = function () { + } + getCriticRatingSortOption() { if ('Programs' === this.params.type) { return null; } @@ -999,18 +1005,16 @@ define(['globalize', 'listView', 'layoutManager', 'userSettings', 'focusManager' name: globalize.translate('CriticRating'), value: 'CriticRating,SortName' }; - }; - - ItemsView.prototype.getCommunityRatingSortOption = function () { + } + getCommunityRatingSortOption() { return { name: globalize.translate('CommunityRating'), value: 'CommunityRating,SortName' }; - }; - - ItemsView.prototype.getVisibleFilters = function () { - var filters = []; - var params = this.params; + } + getVisibleFilters() { + const filters = []; + const params = this.params; if (!('nextup' === params.type)) { if ('Programs' === params.type) { @@ -1034,16 +1038,15 @@ define(['globalize', 'listView', 'layoutManager', 'userSettings', 'focusManager' } return filters; - }; - - ItemsView.prototype.setFilterStatus = function (hasFilters) { + } + setFilterStatus(hasFilters) { this.hasFilters = hasFilters; - var filterButtons = this.filterButtons; + const filterButtons = this.filterButtons; if (filterButtons.length) { - for (var i = 0, length = filterButtons.length; i < length; i++) { - var btnFilter = filterButtons[i]; - var bubble = btnFilter.querySelector('.filterButtonBubble'); + for (let i = 0, length = filterButtons.length; i < length; i++) { + const btnFilter = filterButtons[i]; + let bubble = btnFilter.querySelector('.filterButtonBubble'); if (!bubble) { if (!hasFilters) { @@ -1062,10 +1065,9 @@ define(['globalize', 'listView', 'layoutManager', 'userSettings', 'focusManager' } } } - }; - - ItemsView.prototype.getFilterMenuOptions = function () { - var params = this.params; + } + getFilterMenuOptions() { + const params = this.params; return { IsAiring: params.IsAiring, IsMovie: params.IsMovie, @@ -1075,11 +1077,10 @@ define(['globalize', 'listView', 'layoutManager', 'userSettings', 'focusManager' IsSeries: params.IsSeries, Recursive: this.queryRecursive }; - }; - - ItemsView.prototype.getVisibleViewSettings = function () { - var item = (this.params, this.currentItem); - var fields = ['showTitle']; + } + getVisibleViewSettings() { + const item = (this.params, this.currentItem); + const fields = ['showTitle']; if (!item || 'PhotoAlbum' !== item.Type && 'ChannelFolderItem' !== item.Type) { fields.push('imageType'); @@ -1087,13 +1088,12 @@ define(['globalize', 'listView', 'layoutManager', 'userSettings', 'focusManager' fields.push('viewType'); return fields; - }; - - ItemsView.prototype.getViewSettings = function () { - var basekey = this.getSettingsKey(); - var params = this.params; - var item = this.currentItem; - var showTitle = userSettings.get(basekey + '-showTitle'); + } + getViewSettings() { + const basekey = this.getSettingsKey(); + const params = this.params; + const item = this.currentItem; + let showTitle = userSettings.get(basekey + '-showTitle'); if ('true' === showTitle) { showTitle = true; @@ -1105,7 +1105,7 @@ define(['globalize', 'listView', 'layoutManager', 'userSettings', 'focusManager' showTitle = true; } - var imageType = userSettings.get(basekey + '-imageType'); + let imageType = userSettings.get(basekey + '-imageType'); if (!imageType && 'nextup' === params.type) { imageType = 'thumb'; @@ -1117,10 +1117,9 @@ define(['globalize', 'listView', 'layoutManager', 'userSettings', 'focusManager' imageType: imageType || 'primary', viewType: userSettings.get(basekey + '-viewType') || 'images' }; - }; - - ItemsView.prototype.getItemTypes = function () { - var params = this.params; + } + getItemTypes() { + const params = this.params; if ('nextup' === params.type) { return ['Episode']; @@ -1131,12 +1130,11 @@ define(['globalize', 'listView', 'layoutManager', 'userSettings', 'focusManager' } return []; - }; - - ItemsView.prototype.getSettingsKey = function () { - var values = []; + } + getSettingsKey() { + const values = []; values.push('items'); - var params = this.params; + const params = this.params; if (params.type) { values.push(params.type); @@ -1193,7 +1191,9 @@ define(['globalize', 'listView', 'layoutManager', 'userSettings', 'focusManager' } return values.join('-'); - }; + } +} - return ItemsView; -}); +export default ItemsView; + +/* eslint-enable indent */ diff --git a/src/libraries/screensavermanager.js b/src/libraries/screensavermanager.js index b9d7082850..61d128ff14 100644 --- a/src/libraries/screensavermanager.js +++ b/src/libraries/screensavermanager.js @@ -1,132 +1,130 @@ -define(["events", "playbackManager", "pluginManager", "inputManager", "connectionManager", "userSettings"], function (events, playbackManager, pluginManager, inputManager, connectionManager, userSettings) { - "use strict"; +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; +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(); } - - var lastFunctionalEvent = 0; - - function getFunctionalEventIdleTime() { - return new Date().getTime() - lastFunctionalEvent; - } - - events.on(playbackManager, "playbackstop", function (e, stopInfo) { - var state = stopInfo.state; - if (state.NowPlayingItem && state.NowPlayingItem.MediaType == "Video") { - lastFunctionalEvent = new Date().getTime(); - } - }); - - function getScreensaverPlugin(isLoggedIn) { - - var option; - try { - option = userSettings.get("screensaver", false); - } catch (err) { - option = isLoggedIn ? "backdropscreensaver" : "logoscreensaver"; - } - - var plugins = pluginManager.ofType("screensaver"); - - for (var i = 0, length = plugins.length; i < length; i++) { - var plugin = plugins[i]; - - if (plugin.id === option) { - return plugin; - } - } - - return null; - } - - function ScreenSaverManager() { - - var self = this; - var activeScreenSaver; - - function showScreenSaver(screensaver) { - - if (activeScreenSaver) { - throw new Error("An existing screensaver is already active."); - } - - console.debug("Showing screensaver " + screensaver.name); - - screensaver.show(); - activeScreenSaver = screensaver; - - if (screensaver.hideOnClick !== false) { - window.addEventListener("click", hide, true); - } - if (screensaver.hideOnMouse !== false) { - window.addEventListener("mousemove", hide, true); - } - if (screensaver.hideOnKey !== false) { - window.addEventListener("keydown", hide, true); - } - } - - function hide() { - if (activeScreenSaver) { - console.debug("Hiding screensaver"); - activeScreenSaver.hide(); - activeScreenSaver = null; - } - - window.removeEventListener("click", hide, true); - window.removeEventListener("mousemove", hide, true); - window.removeEventListener("keydown", hide, true); - } - - self.isShowing = function () { - return activeScreenSaver != null; - }; - - self.show = function () { - var isLoggedIn; - var apiClient = connectionManager.currentApiClient(); - - if (apiClient && apiClient.isLoggedIn()) { - isLoggedIn = true; - } - - var screensaver = getScreensaverPlugin(isLoggedIn); - - if (screensaver) { - showScreenSaver(screensaver); - } - }; - - self.hide = function () { - hide(); - }; - - function onInterval() { - - if (self.isShowing()) { - return; - } - - if (inputManager.idleTime() < getMinIdleTime()) { - return; - } - - if (getFunctionalEventIdleTime < getMinIdleTime()) { - return; - } - - if (playbackManager.isPlayingVideo()) { - return; - } - - self.show(); - } - - setInterval(onInterval, 10000); - } - - return new ScreenSaverManager(); }); + +function getScreensaverPlugin(isLoggedIn) { + let option; + try { + option = userSettings.get('screensaver', false); + } catch (err) { + option = isLoggedIn ? 'backdropscreensaver' : 'logoscreensaver'; + } + + const plugins = pluginManager.ofType('screensaver'); + + for (let i = 0, length = plugins.length; i < length; i++) { + const plugin = plugins[i]; + + if (plugin.id === option) { + return plugin; + } + } + + return null; +} + +function ScreenSaverManager() { + let activeScreenSaver; + + function showScreenSaver(screensaver) { + if (activeScreenSaver) { + throw new Error('An existing screensaver is already active.'); + } + + console.debug('Showing screensaver ' + screensaver.name); + + screensaver.show(); + activeScreenSaver = screensaver; + + if (screensaver.hideOnClick !== false) { + window.addEventListener('click', hide, true); + } + if (screensaver.hideOnMouse !== false) { + window.addEventListener('mousemove', hide, true); + } + if (screensaver.hideOnKey !== false) { + window.addEventListener('keydown', hide, true); + } + } + + function hide() { + if (activeScreenSaver) { + console.debug('Hiding screensaver'); + activeScreenSaver.hide(); + activeScreenSaver = null; + } + + window.removeEventListener('click', hide, true); + window.removeEventListener('mousemove', hide, true); + window.removeEventListener('keydown', hide, true); + } + + this.isShowing = () => { + return activeScreenSaver != null; + }; + + this.show = function () { + let isLoggedIn; + const apiClient = connectionManager.currentApiClient(); + + if (apiClient && apiClient.isLoggedIn()) { + isLoggedIn = true; + } + + const screensaver = getScreensaverPlugin(isLoggedIn); + + if (screensaver) { + showScreenSaver(screensaver); + } + }; + + this.hide = function () { + hide(); + }; + + const onInterval = () => { + if (this.isShowing()) { + return; + } + + if (inputManager.idleTime() < getMinIdleTime()) { + return; + } + + if (getFunctionalEventIdleTime < getMinIdleTime()) { + return; + } + + if (playbackManager.isPlayingVideo()) { + return; + } + + this.show(); + }; + + setInterval(onInterval, 10000); +} + +export default new ScreenSaverManager; From d63a229e0ef0573af125e29d8981faf2a89a040f Mon Sep 17 00:00:00 2001 From: Cameron Date: Tue, 28 Jul 2020 21:43:46 +0100 Subject: [PATCH 004/301] fix lint --- src/libraries/navdrawer/navdrawer.js | 86 ++++++++++++++-------------- src/libraries/scroller.js | 39 ------------- 2 files changed, 43 insertions(+), 82 deletions(-) diff --git a/src/libraries/navdrawer/navdrawer.js b/src/libraries/navdrawer/navdrawer.js index d9c246b406..750dd510b8 100644 --- a/src/libraries/navdrawer/navdrawer.js +++ b/src/libraries/navdrawer/navdrawer.js @@ -1,5 +1,5 @@ -define(["browser", "dom", "css!./navdrawer", "scrollStyles"], function (browser, dom) { - "use strict"; +define(['browser', 'dom', 'css!./navdrawer', 'scrollStyles'], function (browser, dom) { + 'use strict'; return function (options) { function getTouches(e) { @@ -7,7 +7,7 @@ define(["browser", "dom", "css!./navdrawer", "scrollStyles"], function (browser, } function onMenuTouchStart(e) { - options.target.classList.remove("transition"); + options.target.classList.remove('transition'); var touches = getTouches(e); var touch = touches[0] || {}; menuTouchStartX = touch.clientX; @@ -36,7 +36,7 @@ define(["browser", "dom", "css!./navdrawer", "scrollStyles"], function (browser, if (0 === dragMode && (!isOpen || Math.abs(deltaX) >= 10) && Math.abs(deltaY) < 5) { dragMode = 1; - scrollContainer.addEventListener("scroll", disableEvent); + scrollContainer.addEventListener('scroll', disableEvent); self.showMask(); } else if (0 === dragMode && Math.abs(deltaY) >= 5) { dragMode = 2; @@ -49,8 +49,8 @@ define(["browser", "dom", "css!./navdrawer", "scrollStyles"], function (browser, } function onMenuTouchEnd(e) { - options.target.classList.add("transition"); - scrollContainer.removeEventListener("scroll", disableEvent); + options.target.classList.add('transition'); + scrollContainer.removeEventListener('scroll', disableEvent); dragMode = 0; var touches = getTouches(e); var touch = touches[0] || {}; @@ -69,9 +69,9 @@ define(["browser", "dom", "css!./navdrawer", "scrollStyles"], function (browser, if (((getTouches(e)[0] || {}).clientX || 0) <= options.handleSize) { isPeeking = true; - if (e.type === "touchstart") { - dom.removeEventListener(edgeContainer, "touchmove", onEdgeTouchMove, {}); - dom.addEventListener(edgeContainer, "touchmove", onEdgeTouchMove, {}); + if (e.type === 'touchstart') { + dom.removeEventListener(edgeContainer, 'touchmove', onEdgeTouchMove, {}); + dom.addEventListener(edgeContainer, 'touchmove', onEdgeTouchMove, {}); } onMenuTouchStart(e); @@ -88,7 +88,7 @@ define(["browser", "dom", "css!./navdrawer", "scrollStyles"], function (browser, function onEdgeTouchEnd(e) { if (isPeeking) { isPeeking = false; - dom.removeEventListener(edgeContainer, "touchmove", onEdgeTouchMove, {}); + dom.removeEventListener(edgeContainer, 'touchmove', onEdgeTouchMove, {}); onMenuTouchEnd(e); } } @@ -142,8 +142,8 @@ define(["browser", "dom", "css!./navdrawer", "scrollStyles"], function (browser, function onMaskTransitionEnd() { var classList = mask.classList; - if (!classList.contains("backdrop")) { - classList.add("hide"); + if (!classList.contains('backdrop')) { + classList.add('hide'); } } @@ -155,10 +155,10 @@ define(["browser", "dom", "css!./navdrawer", "scrollStyles"], function (browser, var startPoint = 0; var countStart = 0; var velocity = 0; - options.target.classList.add("transition"); + options.target.classList.add('transition'); var dragMode = 0; - var scrollContainer = options.target.querySelector(".mainDrawer-scrollContainer"); - scrollContainer.classList.add("scrollY"); + var scrollContainer = options.target.querySelector('.mainDrawer-scrollContainer'); + scrollContainer.classList.add('scrollY'); var TouchMenuLA = function () { self = this; @@ -173,13 +173,13 @@ define(["browser", "dom", "css!./navdrawer", "scrollStyles"], function (browser, }; TouchMenuLA.prototype.initElements = function () { - options.target.classList.add("touch-menu-la"); - options.target.style.width = options.width + "px"; - options.target.style.left = -options.width + "px"; + options.target.classList.add('touch-menu-la'); + options.target.style.width = options.width + 'px'; + options.target.style.left = -options.width + 'px'; if (!options.disableMask) { - mask = document.createElement("div"); - mask.className = "tmla-mask hide"; + mask = document.createElement('div'); + mask.className = 'tmla-mask hide'; document.body.appendChild(mask); dom.addEventListener(mask, dom.whichTransitionEvent(), onMaskTransitionEnd, { passive: true @@ -190,12 +190,12 @@ define(["browser", "dom", "css!./navdrawer", "scrollStyles"], function (browser, var menuTouchStartX; var menuTouchStartY; var menuTouchStartTime; - var edgeContainer = document.querySelector(".mainDrawerHandle"); + var edgeContainer = document.querySelector('.mainDrawerHandle'); var isPeeking = false; TouchMenuLA.prototype.animateToPosition = function (pos) { requestAnimationFrame(function () { - options.target.style.transform = pos ? "translateX(" + pos + "px)" : "none"; + options.target.style.transform = pos ? 'translateX(' + pos + 'px)' : 'none'; }); }; @@ -206,7 +206,7 @@ define(["browser", "dom", "css!./navdrawer", "scrollStyles"], function (browser, }; TouchMenuLA.prototype.clickMaskClose = function () { - mask.addEventListener("click", function () { + mask.addEventListener('click', function () { self.close(); }); }; @@ -233,7 +233,7 @@ define(["browser", "dom", "css!./navdrawer", "scrollStyles"], function (browser, this.animateToPosition(options.width); currentPos = options.width; this.isVisible = true; - options.target.classList.add("drawer-open"); + options.target.classList.add('drawer-open'); self.showMask(); self.invoke(options.onChange); }; @@ -242,7 +242,7 @@ define(["browser", "dom", "css!./navdrawer", "scrollStyles"], function (browser, this.animateToPosition(0); currentPos = 0; self.isVisible = false; - options.target.classList.remove("drawer-open"); + options.target.classList.remove('drawer-open'); self.hideMask(); self.invoke(options.onChange); }; @@ -259,13 +259,13 @@ define(["browser", "dom", "css!./navdrawer", "scrollStyles"], function (browser, var backgroundTouchStartTime; TouchMenuLA.prototype.showMask = function () { - mask.classList.remove("hide"); - mask.classList.add("backdrop"); + mask.classList.remove('hide'); + mask.classList.add('backdrop'); }; TouchMenuLA.prototype.hideMask = function () { - mask.classList.add("hide"); - mask.classList.remove("backdrop"); + mask.classList.add('hide'); + mask.classList.remove('backdrop'); }; TouchMenuLA.prototype.invoke = function (fn) { @@ -282,26 +282,26 @@ define(["browser", "dom", "css!./navdrawer", "scrollStyles"], function (browser, if (enabled) { if (!_edgeSwipeEnabled) { _edgeSwipeEnabled = true; - dom.addEventListener(edgeContainer, "touchstart", onEdgeTouchStart, { + dom.addEventListener(edgeContainer, 'touchstart', onEdgeTouchStart, { passive: true }); - dom.addEventListener(edgeContainer, "touchend", onEdgeTouchEnd, { + dom.addEventListener(edgeContainer, 'touchend', onEdgeTouchEnd, { passive: true }); - dom.addEventListener(edgeContainer, "touchcancel", onEdgeTouchEnd, { + dom.addEventListener(edgeContainer, 'touchcancel', onEdgeTouchEnd, { passive: true }); } } else { if (_edgeSwipeEnabled) { _edgeSwipeEnabled = false; - dom.removeEventListener(edgeContainer, "touchstart", onEdgeTouchStart, { + dom.removeEventListener(edgeContainer, 'touchstart', onEdgeTouchStart, { passive: true }); - dom.removeEventListener(edgeContainer, "touchend", onEdgeTouchEnd, { + dom.removeEventListener(edgeContainer, 'touchend', onEdgeTouchEnd, { passive: true }); - dom.removeEventListener(edgeContainer, "touchcancel", onEdgeTouchEnd, { + dom.removeEventListener(edgeContainer, 'touchcancel', onEdgeTouchEnd, { passive: true }); } @@ -320,26 +320,26 @@ define(["browser", "dom", "css!./navdrawer", "scrollStyles"], function (browser, self.initElements(); if (browser.touch) { - dom.addEventListener(options.target, "touchstart", onMenuTouchStart, { + dom.addEventListener(options.target, 'touchstart', onMenuTouchStart, { passive: true }); - dom.addEventListener(options.target, "touchmove", onMenuTouchMove, { + dom.addEventListener(options.target, 'touchmove', onMenuTouchMove, { passive: true }); - dom.addEventListener(options.target, "touchend", onMenuTouchEnd, { + dom.addEventListener(options.target, 'touchend', onMenuTouchEnd, { passive: true }); - dom.addEventListener(options.target, "touchcancel", onMenuTouchEnd, { + dom.addEventListener(options.target, 'touchcancel', onMenuTouchEnd, { passive: true }); - dom.addEventListener(mask, "touchstart", onBackgroundTouchStart, { + dom.addEventListener(mask, 'touchstart', onBackgroundTouchStart, { passive: true }); - dom.addEventListener(mask, "touchmove", onBackgroundTouchMove, {}); - dom.addEventListener(mask, "touchend", onBackgroundTouchEnd, { + dom.addEventListener(mask, 'touchmove', onBackgroundTouchMove, {}); + dom.addEventListener(mask, 'touchend', onBackgroundTouchEnd, { passive: true }); - dom.addEventListener(mask, "touchcancel", onBackgroundTouchEnd, { + dom.addEventListener(mask, 'touchcancel', onBackgroundTouchEnd, { passive: true }); } diff --git a/src/libraries/scroller.js b/src/libraries/scroller.js index 645a8ea85c..464b31059d 100644 --- a/src/libraries/scroller.js +++ b/src/libraries/scroller.js @@ -52,8 +52,6 @@ define(['browser', 'layoutManager', 'dom', 'focusManager', 'ResizeObserver', 'sc var dragTouchEvents = ['touchmove', 'touchend']; var wheelEvent = (document.implementation.hasFeature('Event.wheel', '3.0') ? 'wheel' : 'mousewheel'); var interactiveElements = ['INPUT', 'SELECT', 'TEXTAREA']; - var tmpArray = []; - var time; // Math shorthands var abs = Math.abs; @@ -61,10 +59,8 @@ define(['browser', 'layoutManager', 'dom', 'focusManager', 'ResizeObserver', 'sc var pow = Math.pow; var round = Math.round; var max = Math.max; - var min = Math.min; var scrollerFactory = function (frame, options) { - // Extend options var o = Object.assign({}, { slidee: null, // Selector, DOM element, or jQuery object with DOM element representing SLIDEE. @@ -97,11 +93,9 @@ define(['browser', 'layoutManager', 'dom', 'focusManager', 'ResizeObserver', 'sc // native smooth scroll options.enableNativeScroll = true; } else if (options.requireAnimation && (browser.animate || browser.supportsCssAnimation())) { - // transform is the only way to guarantee animation options.enableNativeScroll = false; } else if (!layoutManager.tv || !browser.animate) { - options.enableNativeScroll = true; } @@ -162,9 +156,7 @@ define(['browser', 'layoutManager', 'dom', 'focusManager', 'ResizeObserver', 'sc var frameSize = 0; var slideeSize = 0; function ensureSizeInfo() { - if (requiresReflow) { - requiresReflow = false; // Reset global variables @@ -186,11 +178,9 @@ define(['browser', 'layoutManager', 'dom', 'focusManager', 'ResizeObserver', 'sc * @return {Void} */ function load(isInit) { - requiresReflow = true; if (!isInit) { - ensureSizeInfo(); // Fix possible overflowing @@ -200,7 +190,6 @@ define(['browser', 'layoutManager', 'dom', 'focusManager', 'ResizeObserver', 'sc } function initFrameResizeObserver() { - var observerOptions = {}; self.frameResizeObserver = new ResizeObserver(onResize, observerOptions); @@ -225,16 +214,13 @@ define(['browser', 'layoutManager', 'dom', 'focusManager', 'ResizeObserver', 'sc }; function nativeScrollTo(container, pos, immediate) { - if (container.scroll) { if (o.horizontal) { - container.scroll({ left: pos, behavior: immediate ? 'instant' : 'smooth' }); } else { - container.scroll({ top: pos, behavior: immediate ? 'instant' : 'smooth' @@ -266,14 +252,12 @@ define(['browser', 'layoutManager', 'dom', 'focusManager', 'ResizeObserver', 'sc * @return {Void} */ self.slideTo = function (newPos, immediate, fullItemPos) { - ensureSizeInfo(); var pos = self._pos; newPos = within(newPos, pos.start, pos.end); if (!transform) { - nativeScrollTo(nativeScrollElement, newPos, immediate); return; } @@ -291,7 +275,6 @@ define(['browser', 'layoutManager', 'dom', 'focusManager', 'ResizeObserver', 'sc } if (!immediate && o.skipSlideToWhenVisible && fullItemPos && fullItemPos.isVisible) { - return; } @@ -303,7 +286,6 @@ define(['browser', 'layoutManager', 'dom', 'focusManager', 'ResizeObserver', 'sc }; function setStyleProperty(elem, name, value, speed, resetTransition) { - var style = elem.style; if (resetTransition || browser.edge) { @@ -325,7 +307,6 @@ define(['browser', 'layoutManager', 'dom', 'focusManager', 'ResizeObserver', 'sc } function renderAnimateWithTransform(fromPosition, toPosition, immediate) { - var speed = o.speed; if (immediate) { @@ -343,7 +324,6 @@ define(['browser', 'layoutManager', 'dom', 'focusManager', 'ResizeObserver', 'sc } function getBoundingClientRect(elem) { - // Support: BlackBerry 5, iOS 3 (original iPhone) // If we don't have gBCR, just use 0,0 rather than error if (elem.getBoundingClientRect) { @@ -361,14 +341,10 @@ define(['browser', 'layoutManager', 'dom', 'focusManager', 'ResizeObserver', 'sc * @return {Object} */ self.getPos = function (item) { - var scrollElement = transform ? slideeElement : nativeScrollElement; var slideeOffset = getBoundingClientRect(scrollElement); var itemOffset = getBoundingClientRect(item); - var slideeStartPos = o.horizontal ? slideeOffset.left : slideeOffset.top; - var slideeEndPos = o.horizontal ? slideeOffset.right : slideeOffset.bottom; - var offset = o.horizontal ? itemOffset.left - slideeOffset.left : itemOffset.top - slideeOffset.top; var size = o.horizontal ? itemOffset.width : itemOffset.height; @@ -405,7 +381,6 @@ define(['browser', 'layoutManager', 'dom', 'focusManager', 'ResizeObserver', 'sc }; self.getCenterPosition = function (item) { - ensureSizeInfo(); var pos = self.getPos(item); @@ -450,7 +425,6 @@ define(['browser', 'layoutManager', 'dom', 'focusManager', 'ResizeObserver', 'sc // Bind dragging events if (transform) { - if (isTouch) { dragTouchEvents.forEach(function (eventName) { dom.addEventListener(document, eventName, dragHandler, { @@ -554,9 +528,7 @@ define(['browser', 'layoutManager', 'dom', 'focusManager', 'ResizeObserver', 'sc * @return {Boolean} */ function isInteractive(element) { - while (element) { - if (interactiveElements.indexOf(element.tagName) !== -1) { return true; } @@ -592,7 +564,6 @@ define(['browser', 'layoutManager', 'dom', 'focusManager', 'ResizeObserver', 'sc * @return {Void} */ function scrollHandler(event) { - ensureSizeInfo(); var pos = self._pos; // Ignore if there is no scrolling to be done @@ -609,7 +580,6 @@ define(['browser', 'layoutManager', 'dom', 'focusManager', 'ResizeObserver', 'sc self.slideBy(o.scrollBy * delta); } else { - if (isSmoothScrollSupported) { delta *= 12; } @@ -628,7 +598,6 @@ define(['browser', 'layoutManager', 'dom', 'focusManager', 'ResizeObserver', 'sc * @return {Void} */ self.destroy = function () { - if (self.frameResizeObserver) { self.frameResizeObserver.disconnect(); self.frameResizeObserver = null; @@ -664,11 +633,9 @@ define(['browser', 'layoutManager', 'dom', 'focusManager', 'ResizeObserver', 'sc var contentRect = {}; function onResize(entries) { - var entry = entries[0]; if (entry) { - var newRect = entry.contentRect; // handle element being hidden @@ -677,7 +644,6 @@ define(['browser', 'layoutManager', 'dom', 'focusManager', 'ResizeObserver', 'sc } if (newRect.width !== contentRect.width || newRect.height !== contentRect.height) { - contentRect = newRect; load(false); @@ -703,7 +669,6 @@ define(['browser', 'layoutManager', 'dom', 'focusManager', 'ResizeObserver', 'sc } self.getScrollPosition = function () { - if (transform) { return self._pos.cur; } @@ -716,7 +681,6 @@ define(['browser', 'layoutManager', 'dom', 'focusManager', 'ResizeObserver', 'sc }; self.getScrollSize = function () { - if (transform) { return slideeSize; } @@ -792,7 +756,6 @@ define(['browser', 'layoutManager', 'dom', 'focusManager', 'ResizeObserver', 'sc initFrameResizeObserver(); if (transform) { - dom.addEventListener(dragSourceElement, 'touchstart', dragInitSlidee, { passive: true }); @@ -809,9 +772,7 @@ define(['browser', 'layoutManager', 'dom', 'focusManager', 'ResizeObserver', 'sc passive: true }); } - } else if (o.horizontal) { - // Don't bind to mouse events with vertical scroll since the mouse wheel can handle this natively if (o.mouseWheel) { From 612d74fd2c2054c17f96549238935ebab4c2d4ab Mon Sep 17 00:00:00 2001 From: Cameron Date: Tue, 28 Jul 2020 22:04:01 +0100 Subject: [PATCH 005/301] Migration of home and librarymenu to ES6 modules --- package.json | 2 + .../dashboard/plugins/available/index.js | 2 + .../dashboard/plugins/installed/index.js | 2 + src/controllers/home.js | 118 +++++----- src/controllers/itemDetails/index.js | 2 + src/controllers/movies/moviesrecommended.js | 2 + src/controllers/music/musicrecommended.js | 2 + src/scripts/libraryMenu.js | 216 ++++++++++-------- 8 files changed, 190 insertions(+), 156 deletions(-) diff --git a/package.json b/package.json index edda337f2c..6276da0e43 100644 --- a/package.json +++ b/package.json @@ -188,6 +188,7 @@ "src/controllers/dashboard/users/userparentalcontrol.js", "src/controllers/dashboard/users/userpasswordpage.js", "src/controllers/dashboard/users/userprofilespage.js", + "src/controllers/home.js", "src/controllers/playback/queue/index.js", "src/controllers/playback/video/index.js", "src/controllers/searchpage.js", @@ -248,6 +249,7 @@ "src/scripts/imagehelper.js", "src/scripts/inputManager.js", "src/scripts/keyboardNavigation.js", + "src/scripts/libraryMenu.js", "src/scripts/playlists.js", "src/scripts/settings/appSettings.js", "src/scripts/settings/userSettings.js", diff --git a/src/controllers/dashboard/plugins/available/index.js b/src/controllers/dashboard/plugins/available/index.js index 1f202d6ff6..473b1b8961 100644 --- a/src/controllers/dashboard/plugins/available/index.js +++ b/src/controllers/dashboard/plugins/available/index.js @@ -1,6 +1,8 @@ define(['loading', 'libraryMenu', 'globalize', 'cardStyle', 'emby-button', 'emby-checkbox', 'emby-select'], function (loading, libraryMenu, globalize) { 'use strict'; + libraryMenu = LibraryMenu.default || libraryMenu; + function reloadList(page) { loading.show(); var promise1 = ApiClient.getAvailablePlugins(); diff --git a/src/controllers/dashboard/plugins/installed/index.js b/src/controllers/dashboard/plugins/installed/index.js index d28a04cb2b..014fbf16c2 100644 --- a/src/controllers/dashboard/plugins/installed/index.js +++ b/src/controllers/dashboard/plugins/installed/index.js @@ -1,6 +1,8 @@ define(['loading', 'libraryMenu', 'dom', 'globalize', 'cardStyle', 'emby-button'], function (loading, libraryMenu, dom, globalize) { 'use strict'; + libraryMenu = LibraryMenu.default || libraryMenu; + function deletePlugin(page, uniqueid, name) { var msg = globalize.translate('UninstallPluginConfirmation', name); diff --git a/src/controllers/home.js b/src/controllers/home.js index 9a4cea2227..f3e9e8e22b 100644 --- a/src/controllers/home.js +++ b/src/controllers/home.js @@ -1,75 +1,77 @@ -define(['tabbedView', 'globalize', 'require', 'emby-tabs', 'emby-button', 'emby-scroller'], function (TabbedView, globalize, require) { - 'use strict'; +import TabbedView from 'tabbedView'; +import globalize from 'globalize'; +import require from 'require'; +import 'emby-tabs'; +import 'emby-button'; +import 'emby-scroller'; - function getTabs() { - return [{ - name: globalize.translate('Home') - }, { - name: globalize.translate('Favorites') - }]; +function getTabs() { + return [{ + name: globalize.translate('Home') + }, { + name: globalize.translate('Favorites') + }]; +} + +function getDefaultTabIndex() { + return 0; +} + +function getRequirePromise(deps) { + return new Promise(function (resolve, reject) { + require(deps, resolve); + }); +} + +function getTabController(index) { + if (null == index) { + throw new Error('index cannot be null'); } - function getDefaultTabIndex() { - return 0; + const depends = []; + + switch (index) { + case 0: + depends.push('controllers/hometab'); + break; + + case 1: + depends.push('controllers/favorites'); } - function getRequirePromise(deps) { - return new Promise(function (resolve, reject) { - require(deps, resolve); - }); - } + const instance = this; + return getRequirePromise(depends).then(function (controllerFactory) { + let controller = instance.tabControllers[index]; - function getTabController(index) { - if (null == index) { - throw new Error('index cannot be null'); + if (!controller) { + controller = new controllerFactory(instance.view.querySelector(".tabContent[data-index='" + index + "']"), instance.params); + instance.tabControllers[index] = controller; } - var depends = []; + return controller; + }); +} - switch (index) { - case 0: - depends.push('controllers/hometab'); - break; - - case 1: - depends.push('controllers/favorites'); - } - - var instance = this; - return getRequirePromise(depends).then(function (controllerFactory) { - var controller = instance.tabControllers[index]; - - if (!controller) { - controller = new controllerFactory(instance.view.querySelector(".tabContent[data-index='" + index + "']"), instance.params); - instance.tabControllers[index] = controller; - } - - return controller; - }); - } - - function HomeView(view, params) { +class HomeView { + constructor(view, params) { TabbedView.call(this, view, params); } - - Object.assign(HomeView.prototype, TabbedView.prototype); - HomeView.prototype.getTabs = getTabs; - HomeView.prototype.getDefaultTabIndex = getDefaultTabIndex; - HomeView.prototype.getTabController = getTabController; - - HomeView.prototype.setTitle = function () { + setTitle() { Emby.Page.setTitle(null); - }; - - HomeView.prototype.onPause = function () { + } + onPause() { TabbedView.prototype.onPause.call(this); document.querySelector('.skinHeader').classList.remove('noHomeButtonHeader'); - }; - - HomeView.prototype.onResume = function (options) { + } + onResume(options) { TabbedView.prototype.onResume.call(this, options); document.querySelector('.skinHeader').classList.add('noHomeButtonHeader'); - }; + } +} - return HomeView; -}); +Object.assign(HomeView.prototype, TabbedView.prototype); +HomeView.prototype.getTabs = getTabs; +HomeView.prototype.getDefaultTabIndex = getDefaultTabIndex; +HomeView.prototype.getTabController = getTabController; + +export default HomeView; diff --git a/src/controllers/itemDetails/index.js b/src/controllers/itemDetails/index.js index 29aa8ad1e1..49412c4ac4 100644 --- a/src/controllers/itemDetails/index.js +++ b/src/controllers/itemDetails/index.js @@ -1,6 +1,8 @@ define(['loading', 'appRouter', 'layoutManager', 'connectionManager', 'userSettings', 'cardBuilder', 'datetime', 'mediaInfo', 'backdrop', 'listView', 'itemContextMenu', 'itemHelper', 'dom', 'indicators', 'imageLoader', 'libraryMenu', 'globalize', 'browser', 'events', 'playbackManager', 'scrollStyles', 'emby-itemscontainer', 'emby-checkbox', 'emby-button', 'emby-playstatebutton', 'emby-ratingbutton', 'emby-scroller', 'emby-select'], function (loading, appRouter, layoutManager, connectionManager, userSettings, cardBuilder, datetime, mediaInfo, backdrop, listView, itemContextMenu, itemHelper, dom, indicators, imageLoader, libraryMenu, globalize, browser, events, playbackManager) { 'use strict'; + libraryMenu = LibraryMenu.default || libraryMenu; + function getPromise(apiClient, params) { var id = params.id; diff --git a/src/controllers/movies/moviesrecommended.js b/src/controllers/movies/moviesrecommended.js index 4ffe7888cf..96e98452db 100644 --- a/src/controllers/movies/moviesrecommended.js +++ b/src/controllers/movies/moviesrecommended.js @@ -1,6 +1,8 @@ define(['events', 'layoutManager', 'inputManager', 'userSettings', 'libraryMenu', 'mainTabsManager', 'cardBuilder', 'dom', 'imageLoader', 'playbackManager', 'globalize', 'emby-scroller', 'emby-itemscontainer', 'emby-tabs', 'emby-button'], function (events, layoutManager, inputManager, userSettings, libraryMenu, mainTabsManager, cardBuilder, dom, imageLoader, playbackManager, globalize) { 'use strict'; + libraryMenu = LibraryMenu.default || libraryMenu; + function enableScrollX() { return !layoutManager.desktop; } diff --git a/src/controllers/music/musicrecommended.js b/src/controllers/music/musicrecommended.js index 0eecef0bfb..01b907a893 100644 --- a/src/controllers/music/musicrecommended.js +++ b/src/controllers/music/musicrecommended.js @@ -1,6 +1,8 @@ define(['browser', 'layoutManager', 'userSettings', 'inputManager', 'loading', 'cardBuilder', 'dom', 'apphost', 'imageLoader', 'libraryMenu', 'playbackManager', 'mainTabsManager', 'globalize', 'scrollStyles', 'emby-itemscontainer', 'emby-tabs', 'emby-button', 'flexStyles'], function (browser, layoutManager, userSettings, inputManager, loading, cardBuilder, dom, appHost, imageLoader, libraryMenu, playbackManager, mainTabsManager, globalize) { 'use strict'; + libraryMenu = LibraryMenu.default || libraryMenu; + function itemsPerRow() { var screenWidth = dom.getWindowSize().innerWidth; diff --git a/src/scripts/libraryMenu.js b/src/scripts/libraryMenu.js index 961d89dc05..86a8d38079 100644 --- a/src/scripts/libraryMenu.js +++ b/src/scripts/libraryMenu.js @@ -1,8 +1,26 @@ -define(['dom', 'layoutManager', 'inputManager', 'connectionManager', 'events', 'viewManager', 'libraryBrowser', 'appRouter', 'apphost', 'playbackManager', 'syncPlayManager', 'groupSelectionMenu', 'browser', 'globalize', 'scripts/imagehelper', 'paper-icon-button-light', 'material-icons', 'scrollStyles', 'flexStyles'], function (dom, layoutManager, inputManager, connectionManager, events, viewManager, libraryBrowser, appRouter, appHost, playbackManager, syncPlayManager, groupSelectionMenu, browser, globalize, imageHelper) { - 'use strict'; +import dom from 'dom'; +import layoutManager from 'layoutManager'; +import inputManager from 'inputManager'; +import connectionManager from 'connectionManager'; +import events from 'events'; +import viewManager from 'viewManager'; +import appRouter from 'appRouter'; +import appHost from 'apphost'; +import playbackManager from 'playbackManager'; +import syncPlayManager from 'syncPlayManager'; +import groupSelectionMenu from 'groupSelectionMenu'; +import browser from 'browser'; +import globalize from 'globalize'; +import imageHelper from 'scripts/imagehelper'; +import 'paper-icon-button-light'; +import 'material-icons'; +import 'scrollStyles'; +import 'flexStyles'; + +/* eslint-disable indent */ function renderHeader() { - var html = ''; + let html = ''; html += '
'; html += '
'; html += ''; @@ -56,11 +74,11 @@ define(['dom', 'layoutManager', 'inputManager', 'connectionManager', 'events', ' } function updateUserInHeader(user) { - var hasImage; + let hasImage; if (user && user.name) { if (user.imageUrl) { - var url = user.imageUrl; + const url = user.imageUrl; updateHeaderUserButton(url); hasImage = true; } @@ -87,9 +105,9 @@ define(['dom', 'layoutManager', 'inputManager', 'connectionManager', 'events', ' headerCastButton.classList.remove('hide'); } - var policy = user.Policy ? user.Policy : user.localUser.Policy; + const policy = user.Policy ? user.Policy : user.localUser.Policy; - var apiClient = getCurrentApiClient(); + const apiClient = getCurrentApiClient(); if (headerSyncButton && policy && policy.SyncPlayAccess !== 'None' && apiClient.isMinServerVersion('10.6.0')) { headerSyncButton.classList.remove('hide'); } @@ -139,7 +157,7 @@ define(['dom', 'layoutManager', 'inputManager', 'connectionManager', 'events', ' mainDrawerButton.addEventListener('click', toggleMainDrawer); } - var headerBackButton = skinHeader.querySelector('.headerBackButton'); + const headerBackButton = skinHeader.querySelector('.headerBackButton'); if (headerBackButton) { headerBackButton.addEventListener('click', onBackClick); @@ -181,7 +199,7 @@ define(['dom', 'layoutManager', 'inputManager', 'connectionManager', 'events', ' } function onCastButtonClicked() { - var btn = this; + const btn = this; require(['playerSelectionMenu'], function (playerSelectionMenu) { playerSelectionMenu.show(btn); @@ -189,12 +207,12 @@ define(['dom', 'layoutManager', 'inputManager', 'connectionManager', 'events', ' } function onSyncButtonClicked() { - var btn = this; + const btn = this; groupSelectionMenu.show(btn); } function onSyncPlayEnabled(event, enabled) { - var icon = headerSyncButton.querySelector('span'); + const icon = headerSyncButton.querySelector('span'); icon.classList.remove('sync', 'sync_disabled', 'sync_problem'); if (enabled) { icon.classList.add('sync'); @@ -204,7 +222,7 @@ define(['dom', 'layoutManager', 'inputManager', 'connectionManager', 'events', ' } function onSyncPlaySyncing(event, is_syncing, syncMethod) { - var icon = headerSyncButton.querySelector('span'); + const icon = headerSyncButton.querySelector('span'); icon.classList.remove('sync', 'sync_disabled', 'sync_problem'); if (is_syncing) { icon.classList.add('sync_problem'); @@ -250,7 +268,7 @@ define(['dom', 'layoutManager', 'inputManager', 'connectionManager', 'events', ' } function refreshLibraryInfoInDrawer(user, drawer) { - var html = ''; + let html = ''; html += '
'; html += '' + globalize.translate('ButtonHome') + ''; @@ -286,12 +304,12 @@ define(['dom', 'layoutManager', 'inputManager', 'connectionManager', 'events', ' // add buttons to navigation drawer navDrawerScrollContainer.innerHTML = html; - var btnSettings = navDrawerScrollContainer.querySelector('.btnSettings'); + const btnSettings = navDrawerScrollContainer.querySelector('.btnSettings'); if (btnSettings) { btnSettings.addEventListener('click', onSettingsClick); } - var btnLogout = navDrawerScrollContainer.querySelector('.btnLogout'); + const btnLogout = navDrawerScrollContainer.querySelector('.btnLogout'); if (btnLogout) { btnLogout.addEventListener('click', onLogoutClick); } @@ -313,20 +331,20 @@ define(['dom', 'layoutManager', 'inputManager', 'connectionManager', 'events', ' } function updateDashboardMenuSelectedItem() { - var links = navDrawerScrollContainer.querySelectorAll('.navMenuOption'); - var currentViewId = viewManager.currentView().id; + const links = navDrawerScrollContainer.querySelectorAll('.navMenuOption'); + const currentViewId = viewManager.currentView().id; - for (var i = 0, length = links.length; i < length; i++) { - var link = links[i]; - var selected = false; - var pageIds = link.getAttribute('data-pageids'); + for (let i = 0, length = links.length; i < length; i++) { + let link = links[i]; + let selected = false; + let pageIds = link.getAttribute('data-pageids'); if (pageIds) { pageIds = pageIds.split('|'); selected = -1 != pageIds.indexOf(currentViewId); } - var pageUrls = link.getAttribute('data-pageurls'); + let pageUrls = link.getAttribute('data-pageurls'); if (pageUrls) { pageUrls = pageUrls.split('|'); @@ -335,7 +353,7 @@ define(['dom', 'layoutManager', 'inputManager', 'connectionManager', 'events', ' if (selected) { link.classList.add('navMenuOption-selected'); - var title = ''; + let title = ''; link = link.querySelector('.navMenuOptionText') || link; title += (link.innerText || link.textContent).trim(); LibraryMenu.setTitle(title); @@ -346,7 +364,7 @@ define(['dom', 'layoutManager', 'inputManager', 'connectionManager', 'events', ' } function createToolsMenuList(pluginItems) { - var links = [{ + const links = [{ name: globalize.translate('TabServer') }, { name: globalize.translate('TabDashboard'), @@ -458,8 +476,8 @@ define(['dom', 'layoutManager', 'inputManager', 'connectionManager', 'events', ' } function addPluginPagesToMainMenu(links, pluginItems, section) { - for (var i = 0, length = pluginItems.length; i < length; i++) { - var pluginItem = pluginItems[i]; + for (let i = 0, length = pluginItems.length; i < length; i++) { + const pluginItem = pluginItems[i]; if (pluginItem.EnableInMainMenu && pluginItem.MenuSection === section) { links.push({ @@ -479,10 +497,10 @@ define(['dom', 'layoutManager', 'inputManager', 'connectionManager', 'events', ' } function getToolsLinkHtml(item) { - var menuHtml = ''; - var pageIds = item.pageIds ? item.pageIds.join('|') : ''; + let menuHtml = ''; + let pageIds = item.pageIds ? item.pageIds.join('|') : ''; pageIds = pageIds ? ' data-pageids="' + pageIds + '"' : ''; - var pageUrls = item.pageUrls ? item.pageUrls.join('|') : ''; + let pageUrls = item.pageUrls ? item.pageUrls.join('|') : ''; pageUrls = pageUrls ? ' data-pageurls="' + pageUrls + '"' : ''; menuHtml += ''; @@ -498,11 +516,11 @@ define(['dom', 'layoutManager', 'inputManager', 'connectionManager', 'events', ' function getToolsMenuHtml(apiClient) { return getToolsMenuLinks(apiClient).then(function (items) { - var item; - var menuHtml = ''; + let item; + let menuHtml = ''; menuHtml += '
'; - for (var i = 0; i < items.length; i++) { + for (let i = 0; i < items.length; i++) { item = items[i]; if (item.href) { @@ -520,7 +538,7 @@ define(['dom', 'layoutManager', 'inputManager', 'connectionManager', 'events', ' function createDashboardMenu(apiClient) { return getToolsMenuHtml(apiClient).then(function (toolsMenuHtml) { - var html = ''; + let html = ''; html += ''; @@ -531,24 +549,24 @@ define(['dom', 'layoutManager', 'inputManager', 'connectionManager', 'events', ' } function onSidebarLinkClick() { - var section = this.getElementsByClassName('sectionName')[0]; - var text = section ? section.innerHTML : this.innerHTML; + 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) { - var items = result.Items; - var list = []; + const items = result.Items; + const list = []; - for (var i = 0, length = items.length; i < length; i++) { - var view = items[i]; + for (let i = 0, length = items.length; i < length; i++) { + const view = items[i]; list.push(view); if ('livetv' == view.CollectionType) { view.ImageTags = {}; view.icon = 'live_tv'; - var guideView = Object.assign({}, view); + const guideView = Object.assign({}, view); guideView.Name = globalize.translate('ButtonGuide'); guideView.ImageTags = {}; guideView.icon = 'dvr'; @@ -562,7 +580,7 @@ define(['dom', 'layoutManager', 'inputManager', 'connectionManager', 'events', ' } function showBySelector(selector, show) { - var elem = document.querySelector(selector); + const elem = document.querySelector(selector); if (elem) { if (show) { @@ -592,17 +610,17 @@ define(['dom', 'layoutManager', 'inputManager', 'connectionManager', 'events', ' showBySelector('.libraryMenuDownloads', false); } - var userId = Dashboard.getCurrentUserId(); - var apiClient = getCurrentApiClient(); - var libraryMenuOptions = document.querySelector('.libraryMenuOptions'); + const userId = Dashboard.getCurrentUserId(); + const apiClient = getCurrentApiClient(); + const libraryMenuOptions = document.querySelector('.libraryMenuOptions'); if (libraryMenuOptions) { getUserViews(apiClient, userId).then(function (result) { - var items = result; - var html = `

${globalize.translate('HeaderMedia')}

`; + const items = result; + let html = `

${globalize.translate('HeaderMedia')}

`; html += items.map(function (i) { - var icon = i.icon || imageHelper.getLibraryIcon(i.CollectionType); - var itemId = i.Id; + const icon = i.icon || imageHelper.getLibraryIcon(i.CollectionType); + const itemId = i.Id; const linkHtml = ` @@ -612,8 +630,8 @@ define(['dom', 'layoutManager', 'inputManager', 'connectionManager', 'events', ' return linkHtml; }).join(''); libraryMenuOptions.innerHTML = html; - var elem = libraryMenuOptions; - var sidebarLinks = elem.querySelectorAll('.navMenuOption'); + const elem = libraryMenuOptions; + const sidebarLinks = elem.querySelectorAll('.navMenuOption'); for (const sidebarLink of sidebarLinks) { sidebarLink.removeEventListener('click', onSidebarLinkClick); @@ -642,9 +660,9 @@ define(['dom', 'layoutManager', 'inputManager', 'connectionManager', 'events', ' } function updateCastIcon() { - var context = document; - var info = playbackManager.getPlayerInfo(); - var icon = headerCastButton.querySelector('.material-icons'); + const context = document; + const info = playbackManager.getPlayerInfo(); + const icon = headerCastButton.querySelector('.material-icons'); icon.classList.remove('cast_connected', 'cast'); @@ -660,18 +678,16 @@ define(['dom', 'layoutManager', 'inputManager', 'connectionManager', 'events', ' } function updateLibraryNavLinks(page) { - var i; - var length; - var isLiveTvPage = page.classList.contains('liveTvPage'); - var isChannelsPage = page.classList.contains('channelsPage'); - var isEditorPage = page.classList.contains('metadataEditorPage'); - var isMySyncPage = page.classList.contains('mySyncPage'); - var id = isLiveTvPage || isChannelsPage || isEditorPage || isMySyncPage || page.classList.contains('allLibraryPage') ? '' : getTopParentId() || ''; - var elems = document.getElementsByClassName('lnkMediaFolder'); + 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 (var i = 0, length = elems.length; i < length; i++) { - var lnkMediaFolder = elems[i]; - var itemId = lnkMediaFolder.getAttribute('data-itemid'); + for (let i = 0, length = elems.length; i < length; i++) { + const lnkMediaFolder = elems[i]; + const itemId = lnkMediaFolder.getAttribute('data-itemid'); if (isChannelsPage && 'channels' === itemId) { lnkMediaFolder.classList.add('navMenuOption-selected'); @@ -692,7 +708,7 @@ define(['dom', 'layoutManager', 'inputManager', 'connectionManager', 'events', ' } function updateMenuForPageType(isDashboardPage, isLibraryPage) { - var newPageType = isDashboardPage ? 2 : isLibraryPage ? 1 : 3; + const newPageType = isDashboardPage ? 2 : isLibraryPage ? 1 : 3; if (currentPageType !== newPageType) { currentPageType = newPageType; @@ -703,7 +719,7 @@ define(['dom', 'layoutManager', 'inputManager', 'connectionManager', 'events', ' skinHeader.classList.remove('headroomDisabled'); } - var bodyClassList = document.body.classList; + const bodyClassList = document.body.classList; if (isLibraryPage) { bodyClassList.add('libraryDocument'); @@ -740,7 +756,7 @@ define(['dom', 'layoutManager', 'inputManager', 'connectionManager', 'events', ' } function updateTitle(page) { - var title = page.getAttribute('data-title'); + const title = page.getAttribute('data-title'); if (title) { LibraryMenu.setTitle(title); @@ -765,7 +781,7 @@ define(['dom', 'layoutManager', 'inputManager', 'connectionManager', 'events', ' function initHeadRoom(elem) { require(['headroom'], function (Headroom) { - var headroom = new Headroom(elem); + const headroom = new Headroom(elem); headroom.init(); }); } @@ -785,7 +801,7 @@ define(['dom', 'layoutManager', 'inputManager', 'connectionManager', 'events', ' } function getNavDrawerOptions() { - var drawerWidth = screen.availWidth - 50; + let drawerWidth = screen.availWidth - 50; drawerWidth = Math.max(drawerWidth, 240); drawerWidth = Math.min(drawerWidth, 320); return { @@ -816,25 +832,25 @@ define(['dom', 'layoutManager', 'inputManager', 'connectionManager', 'events', ' }); } - var navDrawerElement; - var navDrawerScrollContainer; - var navDrawerInstance; - var mainDrawerButton; - var headerHomeButton; - var currentDrawerType; - var pageTitleElement; - var headerBackButton; - var headerUserButton; - var currentUser; - var headerCastButton; - var headerSearchButton; - var headerAudioPlayerButton; - var headerSyncButton; - var enableLibraryNavDrawer = layoutManager.desktop; - var enableLibraryNavDrawerHome = !layoutManager.tv; - var skinHeader = document.querySelector('.skinHeader'); - var requiresUserRefresh = true; - window.LibraryMenu = { + 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; + const enableLibraryNavDrawer = layoutManager.desktop; + const enableLibraryNavDrawerHome = !layoutManager.tv; + const skinHeader = document.querySelector('.skinHeader'); + let requiresUserRefresh = true; + const LibraryMenu = { getTopParentId: getTopParentId, onHardwareMenuButtonClick: function () { toggleMainDrawer(); @@ -873,7 +889,7 @@ define(['dom', 'layoutManager', 'inputManager', 'connectionManager', 'events', ' title = ''; } - var html = title; + const html = title; if (!pageTitleElement) { pageTitleElement = document.querySelector('.pageTitle'); @@ -896,18 +912,18 @@ define(['dom', 'layoutManager', 'inputManager', 'connectionManager', 'events', ' } } }; - var currentPageType; + let currentPageType; pageClassOn('pagebeforeshow', 'page', function (e) { if (!this.classList.contains('withTabs')) { LibraryMenu.setTabs(null); } }); pageClassOn('pageshow', 'page', function (e) { - var page = this; - var isDashboardPage = page.classList.contains('type-interior'); - var isHomePage = page.classList.contains('homePage'); - var isLibraryPage = !isDashboardPage && page.classList.contains('libraryPage'); - var apiClient = getCurrentApiClient(); + const page = this; + const isDashboardPage = page.classList.contains('type-interior'); + const isHomePage = page.classList.contains('homePage'); + const isLibraryPage = !isDashboardPage && page.classList.contains('libraryPage'); + const apiClient = getCurrentApiClient(); if (isDashboardPage) { if (mainDrawerButton) { @@ -944,7 +960,7 @@ define(['dom', 'layoutManager', 'inputManager', 'connectionManager', 'events', ' renderHeader(); events.on(connectionManager, 'localusersignedin', function (e, user) { - var currentApiClient = connectionManager.getApiClient(user.ServerId); + const currentApiClient = connectionManager.getApiClient(user.ServerId); currentDrawerType = null; currentUser = { @@ -968,5 +984,9 @@ define(['dom', 'layoutManager', 'inputManager', 'connectionManager', 'events', ' events.on(syncPlayManager, 'syncing', onSyncPlaySyncing); loadNavDrawer(); - return LibraryMenu; -}); + + window.LibraryMenu = LibraryMenu; + +export default LibraryMenu; + +/* eslint-enable indent */ From 00a545dae350daf20b671ee184ebb9f7e5430534 Mon Sep 17 00:00:00 2001 From: Cameron Date: Tue, 28 Jul 2020 22:09:56 +0100 Subject: [PATCH 006/301] extraction of functions --- src/scripts/libraryMenu.js | 129 ++++++++++++++++++++----------------- 1 file changed, 71 insertions(+), 58 deletions(-) diff --git a/src/scripts/libraryMenu.js b/src/scripts/libraryMenu.js index 86a8d38079..594bb79f20 100644 --- a/src/scripts/libraryMenu.js +++ b/src/scripts/libraryMenu.js @@ -850,74 +850,74 @@ import 'flexStyles'; const enableLibraryNavDrawerHome = !layoutManager.tv; const skinHeader = document.querySelector('.skinHeader'); let requiresUserRefresh = true; - const LibraryMenu = { - getTopParentId: getTopParentId, - onHardwareMenuButtonClick: function () { - toggleMainDrawer(); - }, - setTabs: function (type, selectedIndex, builder) { - require(['mainTabsManager'], function (mainTabsManager) { - if (type) { - mainTabsManager.setTabs(viewManager.currentView(), selectedIndex, builder, function () { - return []; - }); - } else { - mainTabsManager.setTabs(null); - } - }); - }, - setDefaultTitle: function () { - if (!pageTitleElement) { - pageTitleElement = document.querySelector('.pageTitle'); - } - if (pageTitleElement) { - pageTitleElement.classList.add('pageTitleWithLogo'); - pageTitleElement.classList.add('pageTitleWithDefaultLogo'); - pageTitleElement.style.backgroundImage = null; - pageTitleElement.innerHTML = ''; - } - - document.title = 'Jellyfin'; - }, - setTitle: function (title) { - if (null == title) { - return void LibraryMenu.setDefaultTitle(); - } - - if ('-' === title) { - title = ''; - } - - const html = title; - - if (!pageTitleElement) { - pageTitleElement = document.querySelector('.pageTitle'); - } - - if (pageTitleElement) { - pageTitleElement.classList.remove('pageTitleWithLogo'); - pageTitleElement.classList.remove('pageTitleWithDefaultLogo'); - pageTitleElement.style.backgroundImage = null; - pageTitleElement.innerHTML = html || ''; - } - - document.title = title || 'Jellyfin'; - }, - setTransparentMenu: function (transparent) { - if (transparent) { - skinHeader.classList.add('semiTransparent'); + function setTabs (type, selectedIndex, builder) { + require(['mainTabsManager'], function (mainTabsManager) { + if (type) { + mainTabsManager.setTabs(viewManager.currentView(), selectedIndex, builder, function () { + return []; + }); } else { - skinHeader.classList.remove('semiTransparent'); + mainTabsManager.setTabs(null); } + }); + } + + function setDefaultTitle () { + if (!pageTitleElement) { + pageTitleElement = document.querySelector('.pageTitle'); } - }; + + if (pageTitleElement) { + pageTitleElement.classList.add('pageTitleWithLogo'); + pageTitleElement.classList.add('pageTitleWithDefaultLogo'); + pageTitleElement.style.backgroundImage = null; + pageTitleElement.innerHTML = ''; + } + + document.title = 'Jellyfin'; + } + + function setTitle (title) { + if (null == title) { + return void LibraryMenu.setDefaultTitle(); + } + + if ('-' === title) { + title = ''; + } + + const html = title; + + if (!pageTitleElement) { + pageTitleElement = document.querySelector('.pageTitle'); + } + + if (pageTitleElement) { + pageTitleElement.classList.remove('pageTitleWithLogo'); + pageTitleElement.classList.remove('pageTitleWithDefaultLogo'); + pageTitleElement.style.backgroundImage = null; + pageTitleElement.innerHTML = html || ''; + } + + document.title = title || 'Jellyfin'; + } + + function setTransparentMenu (transparent) { + if (transparent) { + skinHeader.classList.add('semiTransparent'); + } else { + skinHeader.classList.remove('semiTransparent'); + } + } + let currentPageType; pageClassOn('pagebeforeshow', 'page', function (e) { if (!this.classList.contains('withTabs')) { LibraryMenu.setTabs(null); } }); + pageClassOn('pageshow', 'page', function (e) { const page = this; const isDashboardPage = page.classList.contains('type-interior'); @@ -974,10 +974,12 @@ import 'flexStyles'; updateUserInHeader(user); }); }); + events.on(connectionManager, 'localusersignedout', function () { currentUser = {}; updateUserInHeader(); }); + events.on(playbackManager, 'playerchange', updateCastIcon); events.on(syncPlayManager, 'enabled', onSyncPlayEnabled); @@ -985,6 +987,17 @@ import 'flexStyles'; loadNavDrawer(); + const LibraryMenu = { + getTopParentId: getTopParentId, + onHardwareMenuButtonClick: function () { + toggleMainDrawer(); + }, + setTabs: setTabs, + setDefaultTitle: setDefaultTitle, + setTitle: setTitle, + setTransparentMenu: setTransparentMenu + }; + window.LibraryMenu = LibraryMenu; export default LibraryMenu; From 215a623a18cf859414cadb4051fefbce7051812e Mon Sep 17 00:00:00 2001 From: Cameron Date: Tue, 28 Jul 2020 22:13:49 +0100 Subject: [PATCH 007/301] remove require --- src/scripts/libraryMenu.js | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/src/scripts/libraryMenu.js b/src/scripts/libraryMenu.js index 594bb79f20..f010fa15e3 100644 --- a/src/scripts/libraryMenu.js +++ b/src/scripts/libraryMenu.js @@ -64,7 +64,7 @@ import 'flexStyles'; } function lazyLoadViewMenuBarImages() { - require(['imageLoader'], function (imageLoader) { + import('imageLoader').then(({default: imageLoader}) => { imageLoader.lazyChildren(skinHeader); }); } @@ -201,7 +201,7 @@ import 'flexStyles'; function onCastButtonClicked() { const btn = this; - require(['playerSelectionMenu'], function (playerSelectionMenu) { + import('playerSelectionMenu').then(({default: playerSelectionMenu}) => { playerSelectionMenu.show(btn); }); } @@ -780,7 +780,7 @@ import 'flexStyles'; } function initHeadRoom(elem) { - require(['headroom'], function (Headroom) { + import('headroom').then(({default: Headroom}) => { const headroom = new Headroom(elem); headroom.init(); }); @@ -820,7 +820,7 @@ import 'flexStyles'; navDrawerScrollContainer = navDrawerElement.querySelector('.scrollContainer'); navDrawerScrollContainer.addEventListener('click', onMainDrawerClick); return new Promise(function (resolve, reject) { - require(['navdrawer'], function (navdrawer) { + import('navdrawer').then(({default: navdrawer}) => { navDrawerInstance = new navdrawer(getNavDrawerOptions()); if (!layoutManager.tv) { @@ -852,7 +852,7 @@ import 'flexStyles'; let requiresUserRefresh = true; function setTabs (type, selectedIndex, builder) { - require(['mainTabsManager'], function (mainTabsManager) { + import('mainTabsManager').then(({default: mainTabsManager}) => { if (type) { mainTabsManager.setTabs(viewManager.currentView(), selectedIndex, builder, function () { return []; From 997054ab12572c52000cc1ec0186bfbf4f609679 Mon Sep 17 00:00:00 2001 From: Cameron Date: Fri, 31 Jul 2020 15:54:47 +0100 Subject: [PATCH 008/301] remove require This reverts commit bef8a4509d0b151e7a2e85f549bfca49ce952341. --- src/controllers/home.js | 15 ++++----------- 1 file changed, 4 insertions(+), 11 deletions(-) diff --git a/src/controllers/home.js b/src/controllers/home.js index f3e9e8e22b..392da0e2d2 100644 --- a/src/controllers/home.js +++ b/src/controllers/home.js @@ -1,6 +1,5 @@ import TabbedView from 'tabbedView'; import globalize from 'globalize'; -import require from 'require'; import 'emby-tabs'; import 'emby-button'; import 'emby-scroller'; @@ -17,30 +16,24 @@ function getDefaultTabIndex() { return 0; } -function getRequirePromise(deps) { - return new Promise(function (resolve, reject) { - require(deps, resolve); - }); -} - function getTabController(index) { if (null == index) { throw new Error('index cannot be null'); } - const depends = []; + let depends = ''; switch (index) { case 0: - depends.push('controllers/hometab'); + depends = 'controllers/hometab'; break; case 1: - depends.push('controllers/favorites'); + depends = 'controllers/favorites'; } const instance = this; - return getRequirePromise(depends).then(function (controllerFactory) { + return import(depends).then(({ default: controllerFactory }) => { let controller = instance.tabControllers[index]; if (!controller) { From 39627f364a52bd1103ca72496a3a3a4e1fd0340e Mon Sep 17 00:00:00 2001 From: Cameron Date: Fri, 31 Jul 2020 16:12:49 +0100 Subject: [PATCH 009/301] Migration of tabbedview to ES6 module --- package.json | 1 + src/components/tabbedview/tabbedview.js | 60 +++++++++++++------------ 2 files changed, 32 insertions(+), 29 deletions(-) diff --git a/package.json b/package.json index 2fd4b90ce5..07ac3f4b54 100644 --- a/package.json +++ b/package.json @@ -158,6 +158,7 @@ "src/components/syncPlay/playbackPermissionManager.js", "src/components/syncPlay/syncPlayManager.js", "src/components/syncPlay/timeSyncManager.js", + "src/components/tabbedview/tabbedview.js", "src/controllers/session/addServer/index.js", "src/controllers/session/forgotPassword/index.js", "src/controllers/session/redeemPassword/index.js", diff --git a/src/components/tabbedview/tabbedview.js b/src/components/tabbedview/tabbedview.js index 8bd3afd372..710a0e3c40 100644 --- a/src/components/tabbedview/tabbedview.js +++ b/src/components/tabbedview/tabbedview.js @@ -1,30 +1,33 @@ -define(['backdrop', 'mainTabsManager', 'layoutManager', 'emby-tabs'], function (backdrop, mainTabsManager, layoutManager) { - 'use strict'; +import backdrop from 'backdrop'; +import * as mainTabsManager from 'mainTabsManager'; +import layoutManager from 'layoutManager'; +import 'emby-tabs'; - function onViewDestroy(e) { - var tabControllers = this.tabControllers; +function onViewDestroy(e) { + var tabControllers = this.tabControllers; - if (tabControllers) { - tabControllers.forEach(function (t) { - if (t.destroy) { - t.destroy(); - } - }); + if (tabControllers) { + tabControllers.forEach(function (t) { + if (t.destroy) { + t.destroy(); + } + }); - this.tabControllers = null; - } - - this.view = null; - this.params = null; - this.currentTabController = null; - this.initialTabIndex = null; + this.tabControllers = null; } - function onBeforeTabChange() { + this.view = null; + this.params = null; + this.currentTabController = null; + this.initialTabIndex = null; +} - } +function onBeforeTabChange() { - function TabbedView(view, params) { +} + +class TabbedView { + constructor(view, params) { this.tabControllers = []; this.view = view; this.params = params; @@ -85,7 +88,7 @@ define(['backdrop', 'mainTabsManager', 'layoutManager', 'emby-tabs'], function ( view.addEventListener('viewdestroy', onViewDestroy.bind(this)); } - TabbedView.prototype.onResume = function (options) { + onResume(options) { this.setTitle(); backdrop.clearBackdrop(); @@ -96,19 +99,18 @@ define(['backdrop', 'mainTabsManager', 'layoutManager', 'emby-tabs'], function ( } else if (currentTabController && currentTabController.onResume) { currentTabController.onResume({}); } - }; + } - TabbedView.prototype.onPause = function () { + onPause() { var currentTabController = this.currentTabController; if (currentTabController && currentTabController.onPause) { currentTabController.onPause(); } - }; - - TabbedView.prototype.setTitle = function () { + } + setTitle() { Emby.Page.setTitle(''); - }; + } +} - return TabbedView; -}); +export default TabbedView; From 38d25172d5def42c19de33153fed8e7accaee286 Mon Sep 17 00:00:00 2001 From: Cameron Date: Fri, 31 Jul 2020 17:06:04 +0100 Subject: [PATCH 010/301] Fix type and applysuggestions to home.js --- .../dashboard/plugins/available/index.js | 2 +- .../dashboard/plugins/installed/index.js | 2 +- src/controllers/home.js | 98 +++++++++---------- src/controllers/itemDetails/index.js | 2 +- src/controllers/movies/moviesrecommended.js | 2 +- 5 files changed, 52 insertions(+), 54 deletions(-) diff --git a/src/controllers/dashboard/plugins/available/index.js b/src/controllers/dashboard/plugins/available/index.js index 473b1b8961..274cde8824 100644 --- a/src/controllers/dashboard/plugins/available/index.js +++ b/src/controllers/dashboard/plugins/available/index.js @@ -1,7 +1,7 @@ define(['loading', 'libraryMenu', 'globalize', 'cardStyle', 'emby-button', 'emby-checkbox', 'emby-select'], function (loading, libraryMenu, globalize) { 'use strict'; - libraryMenu = LibraryMenu.default || libraryMenu; + libraryMenu = libraryMenu.default || libraryMenu; function reloadList(page) { loading.show(); diff --git a/src/controllers/dashboard/plugins/installed/index.js b/src/controllers/dashboard/plugins/installed/index.js index 014fbf16c2..02fd954620 100644 --- a/src/controllers/dashboard/plugins/installed/index.js +++ b/src/controllers/dashboard/plugins/installed/index.js @@ -1,7 +1,7 @@ define(['loading', 'libraryMenu', 'dom', 'globalize', 'cardStyle', 'emby-button'], function (loading, libraryMenu, dom, globalize) { 'use strict'; - libraryMenu = LibraryMenu.default || libraryMenu; + libraryMenu = libraryMenu.default || libraryMenu; function deletePlugin(page, uniqueid, name) { var msg = globalize.translate('UninstallPluginConfirmation', name); diff --git a/src/controllers/home.js b/src/controllers/home.js index 392da0e2d2..bfee2c50fb 100644 --- a/src/controllers/home.js +++ b/src/controllers/home.js @@ -4,67 +4,65 @@ import 'emby-tabs'; import 'emby-button'; import 'emby-scroller'; -function getTabs() { - return [{ - name: globalize.translate('Home') - }, { - name: globalize.translate('Favorites') - }]; -} - -function getDefaultTabIndex() { - return 0; -} - -function getTabController(index) { - if (null == index) { - throw new Error('index cannot be null'); - } - - let depends = ''; - - switch (index) { - case 0: - depends = 'controllers/hometab'; - break; - - case 1: - depends = 'controllers/favorites'; - } - - const instance = this; - return import(depends).then(({ default: controllerFactory }) => { - let controller = instance.tabControllers[index]; - - if (!controller) { - controller = new controllerFactory(instance.view.querySelector(".tabContent[data-index='" + index + "']"), instance.params); - instance.tabControllers[index] = controller; - } - - return controller; - }); -} - -class HomeView { +class HomeView extends TabbedView { constructor(view, params) { - TabbedView.call(this, view, params); + super(view, params); } + setTitle() { Emby.Page.setTitle(null); } + onPause() { - TabbedView.prototype.onPause.call(this); + super.onPause(this); document.querySelector('.skinHeader').classList.remove('noHomeButtonHeader'); } + onResume(options) { - TabbedView.prototype.onResume.call(this, options); + super.onResume(this, options); document.querySelector('.skinHeader').classList.add('noHomeButtonHeader'); } + + getDefaultTabIndex() { + return 0; + } + + getTabs() { + return [{ + name: globalize.translate('Home') + }, { + name: globalize.translate('Favorites') + }]; + } + + getTabController(index) { + if (null == index) { + throw new Error('index cannot be null'); + } + + let depends = ''; + + switch (index) { + case 0: + depends = 'controllers/hometab'; + break; + + case 1: + depends = 'controllers/favorites'; + } + + const instance = this; + return import(depends).then(({ default: controllerFactory }) => { + let controller = instance.tabControllers[index]; + + if (!controller) { + controller = new controllerFactory(instance.view.querySelector(".tabContent[data-index='" + index + "']"), instance.params); + instance.tabControllers[index] = controller; + } + + return controller; + }); + } } -Object.assign(HomeView.prototype, TabbedView.prototype); -HomeView.prototype.getTabs = getTabs; -HomeView.prototype.getDefaultTabIndex = getDefaultTabIndex; -HomeView.prototype.getTabController = getTabController; - export default HomeView; diff --git a/src/controllers/itemDetails/index.js b/src/controllers/itemDetails/index.js index 49412c4ac4..d02268b9d4 100644 --- a/src/controllers/itemDetails/index.js +++ b/src/controllers/itemDetails/index.js @@ -1,7 +1,7 @@ define(['loading', 'appRouter', 'layoutManager', 'connectionManager', 'userSettings', 'cardBuilder', 'datetime', 'mediaInfo', 'backdrop', 'listView', 'itemContextMenu', 'itemHelper', 'dom', 'indicators', 'imageLoader', 'libraryMenu', 'globalize', 'browser', 'events', 'playbackManager', 'scrollStyles', 'emby-itemscontainer', 'emby-checkbox', 'emby-button', 'emby-playstatebutton', 'emby-ratingbutton', 'emby-scroller', 'emby-select'], function (loading, appRouter, layoutManager, connectionManager, userSettings, cardBuilder, datetime, mediaInfo, backdrop, listView, itemContextMenu, itemHelper, dom, indicators, imageLoader, libraryMenu, globalize, browser, events, playbackManager) { 'use strict'; - libraryMenu = LibraryMenu.default || libraryMenu; + libraryMenu = libraryMenu.default || libraryMenu; function getPromise(apiClient, params) { var id = params.id; diff --git a/src/controllers/movies/moviesrecommended.js b/src/controllers/movies/moviesrecommended.js index 96e98452db..09ecd3c034 100644 --- a/src/controllers/movies/moviesrecommended.js +++ b/src/controllers/movies/moviesrecommended.js @@ -1,7 +1,7 @@ define(['events', 'layoutManager', 'inputManager', 'userSettings', 'libraryMenu', 'mainTabsManager', 'cardBuilder', 'dom', 'imageLoader', 'playbackManager', 'globalize', 'emby-scroller', 'emby-itemscontainer', 'emby-tabs', 'emby-button'], function (events, layoutManager, inputManager, userSettings, libraryMenu, mainTabsManager, cardBuilder, dom, imageLoader, playbackManager, globalize) { 'use strict'; - libraryMenu = LibraryMenu.default || libraryMenu; + libraryMenu = libraryMenu.default || libraryMenu; function enableScrollX() { return !layoutManager.desktop; From 9da6f2d6bca7de2b3170fc1528c4eef2b44d4ed4 Mon Sep 17 00:00:00 2001 From: matjaz321 Date: Sat, 1 Aug 2020 15:21:25 +0200 Subject: [PATCH 011/301] Migrated livetvsuggested.js to es6 module --- package.json | 1 + src/controllers/livetv/livetvsuggested.js | 711 +++++++++++----------- 2 files changed, 361 insertions(+), 351 deletions(-) diff --git a/package.json b/package.json index 17d175b7e7..2c6eccb75e 100644 --- a/package.json +++ b/package.json @@ -206,6 +206,7 @@ "src/controllers/playback/video/index.js", "src/controllers/searchpage.js", "src/controllers/livetvtuner.js", + "src/controllers/livetvsuggested.js", "src/controllers/livetvstatus.js", "src/controllers/shows/episodes.js", "src/controllers/shows/tvgenres.js", diff --git a/src/controllers/livetv/livetvsuggested.js b/src/controllers/livetv/livetvsuggested.js index 36ba825a34..8e8fe0c3c6 100644 --- a/src/controllers/livetv/livetvsuggested.js +++ b/src/controllers/livetv/livetvsuggested.js @@ -1,393 +1,402 @@ -define(['layoutManager', 'userSettings', 'inputManager', 'loading', 'globalize', 'libraryBrowser', 'mainTabsManager', 'cardBuilder', 'apphost', 'imageLoader', 'scrollStyles', 'emby-itemscontainer', 'emby-tabs', 'emby-button'], function (layoutManager, userSettings, inputManager, loading, globalize, libraryBrowser, mainTabsManager, cardBuilder, appHost, imageLoader) { - 'use strict'; +import layoutManager from 'layoutManager'; +import * as userSettings from 'userSettings'; +import inputManager from 'inputManager'; +import loading from 'loading'; +import globalize from 'globalize'; +import * as mainTabsManager from 'mainTabsManager'; +import cardBuilder from 'cardBuilder'; +import imageLoader from 'imageLoader'; +import 'scrollStyles'; +import 'emby-itemscontainer'; +import 'emby-tabs'; +import 'emby-button'; - function enableScrollX() { - return !layoutManager.desktop; +function enableScrollX() { + return !layoutManager.desktop; +} + +function getBackdropShape() { + if (enableScrollX()) { + return 'overflowBackdrop'; + } + return 'backdrop'; +} + +function getPortraitShape() { + if (enableScrollX()) { + return 'overflowPortrait'; + } + return 'portrait'; +} + +function getLimit() { + if (enableScrollX()) { + return 12; } - function getBackdropShape() { - if (enableScrollX()) { - return 'overflowBackdrop'; - } - return 'backdrop'; + return 9; +} + +function loadRecommendedPrograms(page) { + loading.show(); + let limit = getLimit(); + + if (enableScrollX()) { + limit *= 2; } - function getPortraitShape() { - if (enableScrollX()) { - return 'overflowPortrait'; - } - return 'portrait'; - } + ApiClient.getLiveTvRecommendedPrograms({ + userId: Dashboard.getCurrentUserId(), + IsAiring: true, + limit: limit, + ImageTypeLimit: 1, + EnableImageTypes: 'Primary,Thumb,Backdrop', + EnableTotalRecordCount: false, + Fields: 'ChannelInfo,PrimaryImageAspectRatio' + }).then(function (result) { + renderItems(page, result.Items, 'activeProgramItems', 'play', { + showAirDateTime: false, + showAirEndTime: true + }); + loading.hide(); - function getLimit() { - if (enableScrollX()) { - return 12; - } + import('autoFocuser').then(({default: autoFocuser}) => { + autoFocuser.autoFocus(page); + }); + }); +} - return 9; - } - - function loadRecommendedPrograms(page) { - loading.show(); - var limit = getLimit(); - - if (enableScrollX()) { - limit *= 2; - } - - ApiClient.getLiveTvRecommendedPrograms({ +function reload(page, enableFullRender) { + if (enableFullRender) { + loadRecommendedPrograms(page); + ApiClient.getLiveTvPrograms({ userId: Dashboard.getCurrentUserId(), - IsAiring: true, - limit: limit, - ImageTypeLimit: 1, - EnableImageTypes: 'Primary,Thumb,Backdrop', + HasAired: false, + limit: getLimit(), + IsMovie: false, + IsSports: false, + IsKids: false, + IsNews: false, + IsSeries: true, EnableTotalRecordCount: false, - Fields: 'ChannelInfo,PrimaryImageAspectRatio' + Fields: 'ChannelInfo,PrimaryImageAspectRatio', + EnableImageTypes: 'Primary,Thumb' }).then(function (result) { - renderItems(page, result.Items, 'activeProgramItems', 'play', { - showAirDateTime: false, - showAirEndTime: true + renderItems(page, result.Items, 'upcomingEpisodeItems'); + }); + ApiClient.getLiveTvPrograms({ + userId: Dashboard.getCurrentUserId(), + HasAired: false, + limit: getLimit(), + IsMovie: true, + EnableTotalRecordCount: false, + Fields: 'ChannelInfo', + EnableImageTypes: 'Primary,Thumb' + }).then(function (result) { + renderItems(page, result.Items, 'upcomingTvMovieItems', null, { + shape: getPortraitShape(), + preferThumb: null, + showParentTitle: false }); - loading.hide(); - - require(['autoFocuser'], function (autoFocuser) { - autoFocuser.autoFocus(page); + }); + ApiClient.getLiveTvPrograms({ + userId: Dashboard.getCurrentUserId(), + HasAired: false, + limit: getLimit(), + IsSports: true, + EnableTotalRecordCount: false, + Fields: 'ChannelInfo,PrimaryImageAspectRatio', + EnableImageTypes: 'Primary,Thumb' + }).then(function (result) { + renderItems(page, result.Items, 'upcomingSportsItems'); + }); + ApiClient.getLiveTvPrograms({ + userId: Dashboard.getCurrentUserId(), + HasAired: false, + limit: getLimit(), + IsKids: true, + EnableTotalRecordCount: false, + Fields: 'ChannelInfo,PrimaryImageAspectRatio', + EnableImageTypes: 'Primary,Thumb' + }).then(function (result) { + renderItems(page, result.Items, 'upcomingKidsItems'); + }); + ApiClient.getLiveTvPrograms({ + userId: Dashboard.getCurrentUserId(), + HasAired: false, + limit: getLimit(), + IsNews: true, + EnableTotalRecordCount: false, + Fields: 'ChannelInfo,PrimaryImageAspectRatio', + EnableImageTypes: 'Primary,Thumb' + }).then(function (result) { + renderItems(page, result.Items, 'upcomingNewsItems', null, { + showParentTitleOrTitle: true, + showTitle: false, + showParentTitle: false }); }); } +} - function reload(page, enableFullRender) { - if (enableFullRender) { - loadRecommendedPrograms(page); - ApiClient.getLiveTvPrograms({ - userId: Dashboard.getCurrentUserId(), - HasAired: false, - limit: getLimit(), - IsMovie: false, - IsSports: false, - IsKids: false, - IsNews: false, - IsSeries: true, - EnableTotalRecordCount: false, - Fields: 'ChannelInfo,PrimaryImageAspectRatio', - EnableImageTypes: 'Primary,Thumb' - }).then(function (result) { - renderItems(page, result.Items, 'upcomingEpisodeItems'); - }); - ApiClient.getLiveTvPrograms({ - userId: Dashboard.getCurrentUserId(), - HasAired: false, - limit: getLimit(), - IsMovie: true, - EnableTotalRecordCount: false, - Fields: 'ChannelInfo', - EnableImageTypes: 'Primary,Thumb' - }).then(function (result) { - renderItems(page, result.Items, 'upcomingTvMovieItems', null, { - shape: getPortraitShape(), - preferThumb: null, - showParentTitle: false - }); - }); - ApiClient.getLiveTvPrograms({ - userId: Dashboard.getCurrentUserId(), - HasAired: false, - limit: getLimit(), - IsSports: true, - EnableTotalRecordCount: false, - Fields: 'ChannelInfo,PrimaryImageAspectRatio', - EnableImageTypes: 'Primary,Thumb' - }).then(function (result) { - renderItems(page, result.Items, 'upcomingSportsItems'); - }); - ApiClient.getLiveTvPrograms({ - userId: Dashboard.getCurrentUserId(), - HasAired: false, - limit: getLimit(), - IsKids: true, - EnableTotalRecordCount: false, - Fields: 'ChannelInfo,PrimaryImageAspectRatio', - EnableImageTypes: 'Primary,Thumb' - }).then(function (result) { - renderItems(page, result.Items, 'upcomingKidsItems'); - }); - ApiClient.getLiveTvPrograms({ - userId: Dashboard.getCurrentUserId(), - HasAired: false, - limit: getLimit(), - IsNews: true, - EnableTotalRecordCount: false, - Fields: 'ChannelInfo,PrimaryImageAspectRatio', - EnableImageTypes: 'Primary,Thumb' - }).then(function (result) { - renderItems(page, result.Items, 'upcomingNewsItems', null, { - showParentTitleOrTitle: true, - showTitle: false, - showParentTitle: false - }); - }); +function renderItems(page, items, sectionClass, overlayButton, cardOptions) { + const html = cardBuilder.getCardsHtml(Object.assign({ + items: items, + preferThumb: 'auto', + inheritThumb: false, + shape: enableScrollX() ? 'autooverflow' : 'auto', + defaultShape: getBackdropShape(), + showParentTitle: true, + showTitle: true, + centerText: true, + coverImage: true, + overlayText: false, + lazy: true, + overlayPlayButton: overlayButton === 'play', + overlayMoreButton: overlayButton === 'more', + overlayInfoButton: overlayButton === 'info', + allowBottomPadding: !enableScrollX(), + showAirTime: true, + showAirDateTime: true + }, cardOptions || {})); + const elem = page.querySelector('.' + sectionClass); + elem.innerHTML = html; + imageLoader.lazyChildren(elem); +} + +function getTabs() { + return [{ + name: globalize.translate('Programs') + }, { + name: globalize.translate('TabGuide') + }, { + name: globalize.translate('TabChannels') + }, { + name: globalize.translate('TabRecordings') + }, { + name: globalize.translate('HeaderSchedule') + }, { + name: globalize.translate('TabSeries') + }, { + name: globalize.translate('ButtonSearch'), + cssClass: 'searchTabButton' + }]; +} + +function setScrollClasses(elem, scrollX) { + if (scrollX) { + elem.classList.add('hiddenScrollX'); + + if (layoutManager.tv) { + elem.classList.add('smoothScrollX'); } + + elem.classList.add('scrollX'); + elem.classList.remove('vertical-wrap'); + } else { + elem.classList.remove('hiddenScrollX'); + elem.classList.remove('smoothScrollX'); + elem.classList.remove('scrollX'); + elem.classList.add('vertical-wrap'); + } +} + +function getDefaultTabIndex(folderId) { + if (userSettings.get('landing-' + folderId) === 'guide') { + return 1; } - function renderItems(page, items, sectionClass, overlayButton, cardOptions) { - var html = cardBuilder.getCardsHtml(Object.assign({ - items: items, - preferThumb: 'auto', - inheritThumb: false, - shape: enableScrollX() ? 'autooverflow' : 'auto', - defaultShape: getBackdropShape(), - showParentTitle: true, - showTitle: true, - centerText: true, - coverImage: true, - overlayText: false, - lazy: true, - overlayPlayButton: overlayButton === 'play', - overlayMoreButton: overlayButton === 'more', - overlayInfoButton: overlayButton === 'info', - allowBottomPadding: !enableScrollX(), - showAirTime: true, - showAirDateTime: true - }, cardOptions || {})); - var elem = page.querySelector('.' + sectionClass); - elem.innerHTML = html; - imageLoader.lazyChildren(elem); + return 0; +} + +export default function (view, params) { + function enableFullRender() { + return new Date().getTime() - lastFullRender > 3e5; } - function getTabs() { - return [{ - name: globalize.translate('Programs') - }, { - name: globalize.translate('TabGuide') - }, { - name: globalize.translate('TabChannels') - }, { - name: globalize.translate('TabRecordings') - }, { - name: globalize.translate('HeaderSchedule') - }, { - name: globalize.translate('TabSeries') - }, { - name: globalize.translate('ButtonSearch'), - cssClass: 'searchTabButton' - }]; + function onBeforeTabChange(evt) { + preLoadTab(view, parseInt(evt.detail.selectedTabIndex)); } - function setScrollClasses(elem, scrollX) { - if (scrollX) { - elem.classList.add('hiddenScrollX'); + function onTabChange(evt) { + const previousTabController = tabControllers[parseInt(evt.detail.previousIndex)]; - if (layoutManager.tv) { - elem.classList.add('smoothScrollX'); + if (previousTabController && previousTabController.onHide) { + previousTabController.onHide(); + } + + loadTab(view, parseInt(evt.detail.selectedTabIndex)); + } + + function getTabContainers() { + return view.querySelectorAll('.pageTabContent'); + } + + function initTabs() { + mainTabsManager.setTabs(view, currentTabIndex, getTabs, getTabContainers, onBeforeTabChange, onTabChange); + } + + function getTabController(page, index, callback) { + const depends = []; + + // TODO int is a little hard to read + switch (index) { + case 0: + break; + + case 1: + depends.push('controllers/livetv/livetvguide'); + break; + + case 2: + depends.push('controllers/livetv/livetvchannels'); + break; + + case 3: + depends.push('controllers/livetv/livetvrecordings'); + break; + + case 4: + depends.push('controllers/livetv/livetvschedule'); + break; + + case 5: + depends.push('controllers/livetv/livetvseriestimers'); + break; + + case 6: + depends.push('scripts/searchtab'); + } + + import(depends).then(({default: controllerFactory}) => { + let tabContent; + + if (index === 0) { + tabContent = view.querySelector('.pageTabContent[data-index=\'' + index + '\']'); + self.tabContent = tabContent; } - elem.classList.add('scrollX'); - elem.classList.remove('vertical-wrap'); - } else { - elem.classList.remove('hiddenScrollX'); - elem.classList.remove('smoothScrollX'); - elem.classList.remove('scrollX'); - elem.classList.add('vertical-wrap'); - } - } + let controller = tabControllers[index]; - function getDefaultTabIndex(folderId) { - if (userSettings.get('landing-' + folderId) === 'guide') { - return 1; - } + if (!controller) { + tabContent = view.querySelector('.pageTabContent[data-index=\'' + index + '\']'); - return 0; - } - - return function (view, params) { - function enableFullRender() { - return new Date().getTime() - lastFullRender > 3e5; - } - - function onBeforeTabChange(evt) { - preLoadTab(view, parseInt(evt.detail.selectedTabIndex)); - } - - function onTabChange(evt) { - var previousTabController = tabControllers[parseInt(evt.detail.previousIndex)]; - - if (previousTabController && previousTabController.onHide) { - previousTabController.onHide(); - } - - loadTab(view, parseInt(evt.detail.selectedTabIndex)); - } - - function getTabContainers() { - return view.querySelectorAll('.pageTabContent'); - } - - function initTabs() { - mainTabsManager.setTabs(view, currentTabIndex, getTabs, getTabContainers, onBeforeTabChange, onTabChange); - } - - function getTabController(page, index, callback) { - var depends = []; - - // TODO int is a little hard to read - switch (index) { - case 0: - break; - - case 1: - depends.push('controllers/livetv/livetvguide'); - break; - - case 2: - depends.push('controllers/livetv/livetvchannels'); - break; - - case 3: - depends.push('controllers/livetv/livetvrecordings'); - break; - - case 4: - depends.push('controllers/livetv/livetvschedule'); - break; - - case 5: - depends.push('controllers/livetv/livetvseriestimers'); - break; - - case 6: - depends.push('scripts/searchtab'); - } - - require(depends, function (controllerFactory) { - var tabContent; - - if (index == 0) { - tabContent = view.querySelector(".pageTabContent[data-index='" + index + "']"); - self.tabContent = tabContent; + if (index === 0) { + controller = self; + } else if (index === 6) { + controller = new controllerFactory(view, tabContent, { + collectionType: 'livetv' + }); + } else { + controller = new controllerFactory(view, params, tabContent); } - var controller = tabControllers[index]; + tabControllers[index] = controller; - if (!controller) { - tabContent = view.querySelector(".pageTabContent[data-index='" + index + "']"); + if (controller.initTab) { + controller.initTab(); + } + } - if (index === 0) { - controller = self; - } else if (index === 6) { - controller = new controllerFactory(view, tabContent, { - collectionType: 'livetv' - }); - } else { - controller = new controllerFactory(view, params, tabContent); - } + callback(controller); + }); + } - tabControllers[index] = controller; + function preLoadTab(page, index) { + getTabController(page, index, function (controller) { + if (renderedTabs.indexOf(index) === -1 && controller.preRender) { + controller.preRender(); + } + }); + } - if (controller.initTab) { - controller.initTab(); - } + function loadTab(page, index) { + currentTabIndex = index; + getTabController(page, index, function (controller) { + initialTabIndex = null; + + if (renderedTabs.indexOf(index) === -1) { + if (index === 1) { + renderedTabs.push(index); } - callback(controller); - }); + controller.renderTab(); + } else if (controller.onShow) { + controller.onShow(); + } + + currentTabController = controller; + }); + } + + function onInputCommand(evt) { + if (evt.detail.command === 'search') { + evt.preventDefault(); + Dashboard.navigate('search.html?collectionType=livetv'); } + } - function preLoadTab(page, index) { - getTabController(page, index, function (controller) { - if (renderedTabs.indexOf(index) === -1 && controller.preRender) { - controller.preRender(); - } - }); + let isViewRestored; + const self = this; + let currentTabIndex = parseInt(params.tab || getDefaultTabIndex('livetv')); + let initialTabIndex = currentTabIndex; + let lastFullRender = 0; + [].forEach.call(view.querySelectorAll('.sectionTitleTextButton-programs'), function (link) { + const href = link.href; + + if (href) { + link.href = href + '&serverId=' + ApiClient.serverId(); } + }); - function loadTab(page, index) { - currentTabIndex = index; - getTabController(page, index, function (controller) { - initialTabIndex = null; + self.initTab = function () { + const tabContent = view.querySelector('.pageTabContent[data-index=\'0\']'); + const containers = tabContent.querySelectorAll('.itemsContainer'); - if (renderedTabs.indexOf(index) == -1) { - if (index === 1) { - renderedTabs.push(index); - } - - controller.renderTab(); - } else if (controller.onShow) { - controller.onShow(); - } - - currentTabController = controller; - }); + for (let i = 0, length = containers.length; i < length; i++) { + setScrollClasses(containers[i], enableScrollX()); } - - function onInputCommand(evt) { - if (evt.detail.command === 'search') { - evt.preventDefault(); - Dashboard.navigate('search.html?collectionType=livetv'); - } - } - - var isViewRestored; - var self = this; - var currentTabIndex = parseInt(params.tab || getDefaultTabIndex('livetv')); - var initialTabIndex = currentTabIndex; - var lastFullRender = 0; - [].forEach.call(view.querySelectorAll('.sectionTitleTextButton-programs'), function (link) { - var href = link.href; - - if (href) { - link.href = href + '&serverId=' + ApiClient.serverId(); - } - }); - - self.initTab = function () { - var tabContent = view.querySelector(".pageTabContent[data-index='0']"); - var containers = tabContent.querySelectorAll('.itemsContainer'); - - for (var i = 0, length = containers.length; i < length; i++) { - setScrollClasses(containers[i], enableScrollX()); - } - }; - - self.renderTab = function () { - var tabContent = view.querySelector(".pageTabContent[data-index='0']"); - - if (enableFullRender()) { - reload(tabContent, true); - lastFullRender = new Date().getTime(); - } else { - reload(tabContent); - } - }; - - var currentTabController; - var tabControllers = []; - var renderedTabs = []; - view.addEventListener('viewbeforeshow', function (evt) { - isViewRestored = evt.detail.isRestored; - initTabs(); - }); - view.addEventListener('viewshow', function (evt) { - isViewRestored = evt.detail.isRestored; - - if (!isViewRestored) { - mainTabsManager.selectedTabIndex(initialTabIndex); - } - - inputManager.on(window, onInputCommand); - }); - view.addEventListener('viewbeforehide', function (e) { - if (currentTabController && currentTabController.onHide) { - currentTabController.onHide(); - } - - inputManager.off(window, onInputCommand); - }); - view.addEventListener('viewdestroy', function (evt) { - tabControllers.forEach(function (tabController) { - if (tabController.destroy) { - tabController.destroy(); - } - }); - }); }; -}); + + self.renderTab = function () { + const tabContent = view.querySelector('.pageTabContent[data-index=\'0\']'); + + if (enableFullRender()) { + reload(tabContent, true); + lastFullRender = new Date().getTime(); + } else { + reload(tabContent); + } + }; + + let currentTabController; + const tabControllers = []; + const renderedTabs = []; + view.addEventListener('viewbeforeshow', function (evt) { + isViewRestored = evt.detail.isRestored; + initTabs(); + }); + view.addEventListener('viewshow', function (evt) { + isViewRestored = evt.detail.isRestored; + + if (!isViewRestored) { + mainTabsManager.selectedTabIndex(initialTabIndex); + } + + inputManager.on(window, onInputCommand); + }); + view.addEventListener('viewbeforehide', function () { + if (currentTabController && currentTabController.onHide) { + currentTabController.onHide(); + } + + inputManager.off(window, onInputCommand); + }); + view.addEventListener('viewdestroy', function () { + tabControllers.forEach(function (tabController) { + if (tabController.destroy) { + tabController.destroy(); + } + }); + }); +} From b082613ed98bd550a9e6a6abdb5bf6aff687264f Mon Sep 17 00:00:00 2001 From: Cameron Date: Sun, 2 Aug 2020 17:44:03 +0100 Subject: [PATCH 012/301] Migration of viewManager to ES6 module --- package.json | 1 + src/components/appRouter.js | 2 + src/components/viewManager/viewManager.js | 229 +++++++++++----------- src/scripts/libraryMenu.js | 2 + src/scripts/site.js | 4 +- 5 files changed, 123 insertions(+), 115 deletions(-) diff --git a/package.json b/package.json index 5db40a0efe..d8306aa9e2 100644 --- a/package.json +++ b/package.json @@ -158,6 +158,7 @@ "src/components/syncPlay/playbackPermissionManager.js", "src/components/syncPlay/syncPlayManager.js", "src/components/syncPlay/timeSyncManager.js", + "src/components/viewManager/viewManager.js", "src/controllers/session/addServer/index.js", "src/controllers/session/forgotPassword/index.js", "src/controllers/session/redeemPassword/index.js", diff --git a/src/components/appRouter.js b/src/components/appRouter.js index 138d58e5c0..9ed6e39d22 100644 --- a/src/components/appRouter.js +++ b/src/components/appRouter.js @@ -1,6 +1,8 @@ define(['loading', 'globalize', 'events', 'viewManager', 'skinManager', 'backdrop', 'browser', 'page', 'appSettings', 'apphost', 'connectionManager'], function (loading, globalize, events, viewManager, skinManager, backdrop, browser, page, appSettings, appHost, connectionManager) { 'use strict'; + viewManager = viewManager.default || viewManager; + var appRouter = { showLocalLogin: function (serverId, manualLogin) { var pageName = manualLogin ? 'manuallogin' : 'login'; diff --git a/src/components/viewManager/viewManager.js b/src/components/viewManager/viewManager.js index 058ba4ebb2..695535e7b8 100644 --- a/src/components/viewManager/viewManager.js +++ b/src/components/viewManager/viewManager.js @@ -1,134 +1,137 @@ -define(['viewContainer', 'focusManager', 'queryString', 'layoutManager'], function (viewContainer, focusManager, queryString, layoutManager) { - 'use strict'; +import viewContainer from 'viewContainer'; +import focusManager from 'focusManager'; +import queryString from 'queryString'; +import layoutManager from 'layoutManager'; - var currentView; - var dispatchPageEvents; +let currentView; +let dispatchPageEvents; - viewContainer.setOnBeforeChange(function (newView, isRestored, options) { - var lastView = currentView; - if (lastView) { - var beforeHideResult = dispatchViewEvent(lastView, null, 'viewbeforehide', true); +viewContainer.setOnBeforeChange(function (newView, isRestored, options) { + const lastView = currentView; + if (lastView) { + const beforeHideResult = dispatchViewEvent(lastView, null, 'viewbeforehide', true); - if (!beforeHideResult) { - // todo: cancel - } - } - - var eventDetail = getViewEventDetail(newView, options, isRestored); - - if (!newView.initComplete) { - newView.initComplete = true; - - if (typeof options.controllerFactory === 'function') { - new options.controllerFactory(newView, eventDetail.detail.params); - } else if (options.controllerFactory && typeof options.controllerFactory.default === 'function') { - new options.controllerFactory.default(newView, eventDetail.detail.params); - } - - if (!options.controllerFactory || dispatchPageEvents) { - dispatchViewEvent(newView, eventDetail, 'viewinit'); - } - } - - dispatchViewEvent(newView, eventDetail, 'viewbeforeshow'); - }); - - function onViewChange(view, options, isRestore) { - var lastView = currentView; - if (lastView) { - dispatchViewEvent(lastView, null, 'viewhide'); - } - - currentView = view; - - var eventDetail = getViewEventDetail(view, options, isRestore); - - if (!isRestore) { - if (options.autoFocus !== false) { - focusManager.autoFocus(view); - } - } else if (!layoutManager.mobile) { - if (view.activeElement && document.body.contains(view.activeElement) && focusManager.isCurrentlyFocusable(view.activeElement)) { - focusManager.focus(view.activeElement); - } else { - focusManager.autoFocus(view); - } - } - - view.dispatchEvent(new CustomEvent('viewshow', eventDetail)); - - if (dispatchPageEvents) { - view.dispatchEvent(new CustomEvent('pageshow', eventDetail)); + if (!beforeHideResult) { + // todo: cancel } } - function getProperties(view) { - var props = view.getAttribute('data-properties'); + const eventDetail = getViewEventDetail(newView, options, isRestored); - if (props) { - return props.split(','); + if (!newView.initComplete) { + newView.initComplete = true; + + if (typeof options.controllerFactory === 'function') { + new options.controllerFactory(newView, eventDetail.detail.params); + } else if (options.controllerFactory && typeof options.controllerFactory.default === 'function') { + new options.controllerFactory.default(newView, eventDetail.detail.params); } - return []; + if (!options.controllerFactory || dispatchPageEvents) { + dispatchViewEvent(newView, eventDetail, 'viewinit'); + } } - function dispatchViewEvent(view, eventInfo, eventName, isCancellable) { - if (!eventInfo) { - eventInfo = { - detail: { - type: view.getAttribute('data-type'), - properties: getProperties(view) - }, - bubbles: true, - cancelable: isCancellable - }; - } + dispatchViewEvent(newView, eventDetail, 'viewbeforeshow'); +}); - eventInfo.cancelable = isCancellable || false; - - var eventResult = view.dispatchEvent(new CustomEvent(eventName, eventInfo)); - - if (dispatchPageEvents) { - eventInfo.cancelable = false; - view.dispatchEvent(new CustomEvent(eventName.replace('view', 'page'), eventInfo)); - } - - return eventResult; +function onViewChange(view, options, isRestore) { + const lastView = currentView; + if (lastView) { + dispatchViewEvent(lastView, null, 'viewhide'); } - function getViewEventDetail(view, options, isRestore) { - var url = options.url; - var index = url.indexOf('?'); - var params = index === -1 ? {} : queryString.parse(url.substring(index + 1)); + currentView = view; - return { + const eventDetail = getViewEventDetail(view, options, isRestore); + + if (!isRestore) { + if (options.autoFocus !== false) { + focusManager.autoFocus(view); + } + } else if (!layoutManager.mobile) { + if (view.activeElement && document.body.contains(view.activeElement) && focusManager.isCurrentlyFocusable(view.activeElement)) { + focusManager.focus(view.activeElement); + } else { + focusManager.autoFocus(view); + } + } + + view.dispatchEvent(new CustomEvent('viewshow', eventDetail)); + + if (dispatchPageEvents) { + view.dispatchEvent(new CustomEvent('pageshow', eventDetail)); + } +} + +function getProperties(view) { + const props = view.getAttribute('data-properties'); + + if (props) { + return props.split(','); + } + + return []; +} + +function dispatchViewEvent(view, eventInfo, eventName, isCancellable) { + if (!eventInfo) { + eventInfo = { detail: { type: view.getAttribute('data-type'), - properties: getProperties(view), - params: params, - isRestored: isRestore, - state: options.state, - - // The route options - options: options.options || {} + properties: getProperties(view) }, bubbles: true, - cancelable: false + cancelable: isCancellable }; } - function resetCachedViews() { - // Reset all cached views whenever the skin changes - viewContainer.reset(); + eventInfo.cancelable = isCancellable || false; + + const eventResult = view.dispatchEvent(new CustomEvent(eventName, eventInfo)); + + if (dispatchPageEvents) { + eventInfo.cancelable = false; + view.dispatchEvent(new CustomEvent(eventName.replace('view', 'page'), eventInfo)); } - document.addEventListener('skinunload', resetCachedViews); + return eventResult; +} - function ViewManager() { +function getViewEventDetail(view, options, isRestore) { + const url = options.url; + const index = url.indexOf('?'); + const params = index === -1 ? {} : queryString.parse(url.substring(index + 1)); + + return { + detail: { + type: view.getAttribute('data-type'), + properties: getProperties(view), + params: params, + isRestored: isRestore, + state: options.state, + + // The route options + options: options.options || {} + }, + bubbles: true, + cancelable: false + }; +} + +function resetCachedViews() { + // Reset all cached views whenever the skin changes + viewContainer.reset(); +} + +document.addEventListener('skinunload', resetCachedViews); + +class ViewManager { + constructor() { } - ViewManager.prototype.loadView = function (options) { - var lastView = currentView; + loadView(options) { + const lastView = currentView; // Record the element that has focus if (lastView) { @@ -142,9 +145,9 @@ define(['viewContainer', 'focusManager', 'queryString', 'layoutManager'], functi viewContainer.loadView(options).then(function (view) { onViewChange(view, options); }); - }; + } - ViewManager.prototype.tryRestoreView = function (options, onViewChanging) { + tryRestoreView(options, onViewChanging) { if (options.cancel) { return Promise.reject({ cancelled: true }); } @@ -158,15 +161,15 @@ define(['viewContainer', 'focusManager', 'queryString', 'layoutManager'], functi onViewChanging(); onViewChange(view, options, true); }); - }; + } - ViewManager.prototype.currentView = function () { + currentView() { return currentView; - }; + } - ViewManager.prototype.dispatchPageEvents = function (value) { + dispatchPageEvents(value) { dispatchPageEvents = value; - }; + } +} - return new ViewManager(); -}); +export default new ViewManager(); diff --git a/src/scripts/libraryMenu.js b/src/scripts/libraryMenu.js index 961d89dc05..d199af0ede 100644 --- a/src/scripts/libraryMenu.js +++ b/src/scripts/libraryMenu.js @@ -1,6 +1,8 @@ define(['dom', 'layoutManager', 'inputManager', 'connectionManager', 'events', 'viewManager', 'libraryBrowser', 'appRouter', 'apphost', 'playbackManager', 'syncPlayManager', 'groupSelectionMenu', 'browser', 'globalize', 'scripts/imagehelper', 'paper-icon-button-light', 'material-icons', 'scrollStyles', 'flexStyles'], function (dom, layoutManager, inputManager, connectionManager, events, viewManager, libraryBrowser, appRouter, appHost, playbackManager, syncPlayManager, groupSelectionMenu, browser, globalize, imageHelper) { 'use strict'; + viewManager = viewManager.default || viewManager; + function renderHeader() { var html = ''; html += '
'; diff --git a/src/scripts/site.js b/src/scripts/site.js index 2beb45959a..6aec5379a8 100644 --- a/src/scripts/site.js +++ b/src/scripts/site.js @@ -827,8 +827,8 @@ function initClient() { define('tvguide', [componentsPath + '/guide/guide'], returnFirstDependency); define('guide-settings-dialog', [componentsPath + '/guide/guide-settings'], returnFirstDependency); define('viewManager', [componentsPath + '/viewManager/viewManager'], function (viewManager) { - window.ViewManager = viewManager; - viewManager.dispatchPageEvents(true); + window.ViewManager = viewManager.default; + viewManager.default.dispatchPageEvents(true); return viewManager; }); define('slideshow', [componentsPath + '/slideshow/slideshow'], returnFirstDependency); From 275676f7126655981fa4600661be4519049da358 Mon Sep 17 00:00:00 2001 From: Cameron Date: Sun, 2 Aug 2020 17:58:21 +0100 Subject: [PATCH 013/301] remove defaults --- src/controllers/list.js | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/controllers/list.js b/src/controllers/list.js index c7c4b2a31d..aea791c167 100644 --- a/src/controllers/list.js +++ b/src/controllers/list.js @@ -558,7 +558,7 @@ class ItemsView { alphaPickerElement.classList.add('focuscontainer-right'); self.itemsContainer.parentNode.classList.add('padded-right-withalphapicker'); - self.alphaPicker = new AlphaPicker.default({ + self.alphaPicker = new AlphaPicker({ element: alphaPickerElement, itemsContainer: layoutManager.tv ? self.itemsContainer : null, itemClass: 'card', @@ -817,7 +817,7 @@ class ItemsView { bindAll(view.querySelectorAll('.btnShuffle'), 'click', shuffle); } - self.alphaNumericShortcuts = new AlphaNumericShortcuts.default({ + self.alphaNumericShortcuts = new AlphaNumericShortcuts({ itemsContainer: self.itemsContainer }); }); From 6b54d25b4d36b44eb357244ea8a06028d240c567 Mon Sep 17 00:00:00 2001 From: Cameron Date: Sun, 2 Aug 2020 18:06:40 +0100 Subject: [PATCH 014/301] Update list.js --- src/controllers/list.js | 26 +++++++++++++++++--------- 1 file changed, 17 insertions(+), 9 deletions(-) diff --git a/src/controllers/list.js b/src/controllers/list.js index 7dab6f5f35..b9237887d0 100644 --- a/src/controllers/list.js +++ b/src/controllers/list.js @@ -14,9 +14,6 @@ import 'emby-scroller'; /* eslint-disable indent */ - playbackManager = playbackManager.default || playbackManager; - loading = loading.default || loading; - function getInitialLiveTvQuery(instance, params) { const query = { UserId: connectionManager.getApiClient(params.serverId).getCurrentUserId(), @@ -523,7 +520,7 @@ class ItemsView { } const showYear = settings.showTitle && params.IsMovie === 'true' && params.type === 'Recordings'; - + if (showYear) { lines++; } @@ -858,6 +855,7 @@ class ItemsView { self.alphaPickerElement = null; }); } + getFilters() { const basekey = this.getSettingsKey(); return { @@ -879,6 +877,7 @@ class ItemsView { GenreIds: userSettings.getFilter(basekey + '-filter-GenreIds') }; } + getSortValues() { const basekey = this.getSettingsKey(); return { @@ -886,6 +885,7 @@ class ItemsView { sortOrder: userSettings.getFilter(basekey + '-sortorder') === 'Descending' ? 'Descending' : 'Ascending' }; } + getDefaultSortBy() { const params = this.params; const sortNameOption = this.getNameSortOption(params); @@ -896,6 +896,7 @@ class ItemsView { return 'IsFolder,' + sortNameOption.value; } + getSortMenuOptions() { const sortBy = []; const params = this.params; @@ -966,6 +967,7 @@ class ItemsView { }); return sortBy; } + getNameSortOption(params) { if (params.type === 'Episode') { return { @@ -979,6 +981,7 @@ class ItemsView { value: 'SortName' }; } + getPlayCountSortOption() { if (this.params.type === 'Programs') { return null; @@ -988,8 +991,8 @@ class ItemsView { name: globalize.translate('PlayCount'), value: 'PlayCount,SortName' }; - } + getDatePlayedSortOption() { if (this.params.type === 'Programs') { return null; @@ -1000,12 +1003,9 @@ class ItemsView { value: 'DatePlayed,SortName' }; } + getCriticRatingSortOption() { if (this.params.type === 'Programs') { - }; - - ItemsView.prototype.getCriticRatingSortOption = function () { - if () { return null; } @@ -1014,12 +1014,14 @@ class ItemsView { value: 'CriticRating,SortName' }; } + getCommunityRatingSortOption() { return { name: globalize.translate('CommunityRating'), value: 'CommunityRating,SortName' }; } + getVisibleFilters() { const filters = []; const params = this.params; @@ -1047,6 +1049,7 @@ class ItemsView { return filters; } + setFilterStatus(hasFilters) { this.hasFilters = hasFilters; const filterButtons = this.filterButtons; @@ -1074,6 +1077,7 @@ class ItemsView { } } } + getFilterMenuOptions() { const params = this.params; return { @@ -1086,6 +1090,7 @@ class ItemsView { Recursive: this.queryRecursive }; } + getVisibleViewSettings() { const item = (this.params, this.currentItem); const fields = ['showTitle']; @@ -1097,6 +1102,7 @@ class ItemsView { fields.push('viewType'); return fields; } + getViewSettings() { const basekey = this.getSettingsKey(); const params = this.params; @@ -1126,6 +1132,7 @@ class ItemsView { viewType: userSettings.get(basekey + '-viewType') || 'images' }; } + getItemTypes() { const params = this.params; @@ -1139,6 +1146,7 @@ class ItemsView { return []; } + getSettingsKey() { const values = []; values.push('items'); From 57fb1331666e1f57cfe0111cbb15a5d5a071c969 Mon Sep 17 00:00:00 2001 From: Cameron Date: Sun, 2 Aug 2020 18:09:17 +0100 Subject: [PATCH 015/301] fix yoda --- src/libraries/navdrawer/navdrawer.js | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/src/libraries/navdrawer/navdrawer.js b/src/libraries/navdrawer/navdrawer.js index d70ef90961..41e7af3339 100644 --- a/src/libraries/navdrawer/navdrawer.js +++ b/src/libraries/navdrawer/navdrawer.js @@ -32,19 +32,19 @@ define(['browser', 'dom', 'css!./navdrawer', 'scrollStyles'], function (browser, var deltaY = endY - (menuTouchStartY || 0); setVelocity(deltaX); - if (isOpen && 1 !== dragMode && deltaX > 0) { + if (isOpen && dragMode !== 1 && deltaX > 0) { dragMode = 2; } - if (0 === dragMode && (!isOpen || Math.abs(deltaX) >= 10) && Math.abs(deltaY) < 5) { + if (dragMode === 0 && (!isOpen || Math.abs(deltaX) >= 10) && Math.abs(deltaY) < 5) { dragMode = 1; scrollContainer.addEventListener('scroll', disableEvent); self.showMask(); - } else if (0 === dragMode && Math.abs(deltaY) >= 5) { + } else if (dragMode === 0 && Math.abs(deltaY) >= 5) { dragMode = 2; } - if (1 === dragMode) { + if (dragMode === 1) { newPos = currentPos + deltaX; self.changeMenuPos(); } From 742372cd55b83e837f3c2ad868a0fb45505d4c07 Mon Sep 17 00:00:00 2001 From: matjaz321 Date: Mon, 3 Aug 2020 20:55:07 +0200 Subject: [PATCH 016/301] CR fixes --- package.json | 2 +- src/controllers/livetv/livetvsuggested.js | 14 +++++++------- 2 files changed, 8 insertions(+), 8 deletions(-) diff --git a/package.json b/package.json index 2c6eccb75e..4241271a8f 100644 --- a/package.json +++ b/package.json @@ -206,7 +206,7 @@ "src/controllers/playback/video/index.js", "src/controllers/searchpage.js", "src/controllers/livetvtuner.js", - "src/controllers/livetvsuggested.js", + "src/controllers/livetv/livetvsuggested.js", "src/controllers/livetvstatus.js", "src/controllers/shows/episodes.js", "src/controllers/shows/tvgenres.js", diff --git a/src/controllers/livetv/livetvsuggested.js b/src/controllers/livetv/livetvsuggested.js index 8e8fe0c3c6..c25431060a 100644 --- a/src/controllers/livetv/livetvsuggested.js +++ b/src/controllers/livetv/livetvsuggested.js @@ -237,7 +237,7 @@ export default function (view, params) { } function getTabController(page, index, callback) { - const depends = []; + let depends; // TODO int is a little hard to read switch (index) { @@ -245,27 +245,27 @@ export default function (view, params) { break; case 1: - depends.push('controllers/livetv/livetvguide'); + depends = 'controllers/livetv/livetvguide'; break; case 2: - depends.push('controllers/livetv/livetvchannels'); + depends = 'controllers/livetv/livetvchannels'; break; case 3: - depends.push('controllers/livetv/livetvrecordings'); + depends = 'controllers/livetv/livetvrecordings'; break; case 4: - depends.push('controllers/livetv/livetvschedule'); + depends = 'controllers/livetv/livetvschedule'; break; case 5: - depends.push('controllers/livetv/livetvseriestimers'); + depends = 'controllers/livetv/livetvseriestimers'; break; case 6: - depends.push('scripts/searchtab'); + depends = 'scripts/searchtab'; } import(depends).then(({default: controllerFactory}) => { From 36f389e8f9e9d41db4c900ddb85452d06bd6f665 Mon Sep 17 00:00:00 2001 From: Cameron Date: Mon, 3 Aug 2020 20:57:54 +0100 Subject: [PATCH 017/301] Migration of htmlAudioPlayer to ES6 module --- package.json | 1 + src/plugins/htmlAudioPlayer/plugin.js | 342 +++++++++++++------------- 2 files changed, 173 insertions(+), 170 deletions(-) diff --git a/package.json b/package.json index 1d7cf770d3..3de5ede240 100644 --- a/package.json +++ b/package.json @@ -155,6 +155,7 @@ "src/components/refreshdialog/refreshdialog.js", "src/components/sanatizefilename.js", "src/components/scrollManager.js", + "src/plugins/htmlAudioPlayer/plugin.js", "src/plugins/htmlVideoPlayer/plugin.js", "src/components/search/searchfields.js", "src/components/search/searchresults.js", diff --git a/src/plugins/htmlAudioPlayer/plugin.js b/src/plugins/htmlAudioPlayer/plugin.js index 16fce8c9d1..c60349c5af 100644 --- a/src/plugins/htmlAudioPlayer/plugin.js +++ b/src/plugins/htmlAudioPlayer/plugin.js @@ -1,91 +1,94 @@ -define(['events', 'browser', 'require', 'apphost', 'appSettings', 'htmlMediaHelper'], function (events, browser, require, appHost, appSettings, htmlMediaHelper) { - 'use strict'; +import events from 'events'; +import browser from 'browser'; +import appHost from 'apphost'; +import * as htmlMediaHelper from 'htmlMediaHelper'; - function getDefaultProfile() { - return new Promise(function (resolve, reject) { - require(['browserdeviceprofile'], function (profileBuilder) { - resolve(profileBuilder({})); - }); +function getDefaultProfile() { + return new Promise(function (resolve, reject) { + import('browserdeviceprofile').then(({default: profileBuilder}) => { + resolve(profileBuilder({})); }); + }); +} + +let fadeTimeout; +function fade(instance, elem, startingVolume) { + instance._isFadingOut = true; + + // Need to record the starting volume on each pass rather than querying elem.volume + // This is due to iOS safari not allowing volume changes and always returning the system volume value + const newVolume = Math.max(0, startingVolume - 0.15); + console.debug('fading volume to ' + newVolume); + elem.volume = newVolume; + + if (newVolume <= 0) { + instance._isFadingOut = false; + return Promise.resolve(); } - var fadeTimeout; - function fade(instance, elem, startingVolume) { - instance._isFadingOut = true; + return new Promise(function (resolve, reject) { + cancelFadeTimeout(); + fadeTimeout = setTimeout(function () { + fade(instance, elem, newVolume).then(resolve, reject); + }, 100); + }); +} - // Need to record the starting volume on each pass rather than querying elem.volume - // This is due to iOS safari not allowing volume changes and always returning the system volume value - var newVolume = Math.max(0, startingVolume - 0.15); - console.debug('fading volume to ' + newVolume); - elem.volume = newVolume; +function cancelFadeTimeout() { + const timeout = fadeTimeout; + if (timeout) { + clearTimeout(timeout); + fadeTimeout = null; + } +} - if (newVolume <= 0) { - instance._isFadingOut = false; - return Promise.resolve(); - } +function supportsFade() { + if (browser.tv) { + // Not working on tizen. + // We could possibly enable on other tv's, but all smart tv browsers tend to be pretty primitive + return false; + } - return new Promise(function (resolve, reject) { - cancelFadeTimeout(); - fadeTimeout = setTimeout(function () { - fade(instance, elem, newVolume).then(resolve, reject); - }, 100); + return true; +} + +function requireHlsPlayer(callback) { + import('hlsjs').then(({default: hls}) => { + window.Hls = hls; + callback(); + }); +} + +function enableHlsPlayer(url, item, mediaSource, mediaType) { + if (!htmlMediaHelper.enableHlsJsPlayer(mediaSource.RunTimeTicks, mediaType)) { + return Promise.reject(); + } + + if (url.indexOf('.m3u8') !== -1) { + return Promise.resolve(); + } + + // issue head request to get content type + return new Promise(function (resolve, reject) { + import('fetchHelper').then(({default: fetchHelper}) => { + fetchHelper.ajax({ + url: url, + type: 'HEAD' + }).then(function (response) { + const contentType = (response.headers.get('Content-Type') || '').toLowerCase(); + if (contentType === 'application/x-mpegurl') { + resolve(); + } else { + reject(); + } + }, reject); }); - } + }); +} - function cancelFadeTimeout() { - var timeout = fadeTimeout; - if (timeout) { - clearTimeout(timeout); - fadeTimeout = null; - } - } - - function supportsFade() { - if (browser.tv) { - // Not working on tizen. - // We could possibly enable on other tv's, but all smart tv browsers tend to be pretty primitive - return false; - } - - return true; - } - - function requireHlsPlayer(callback) { - require(['hlsjs'], function (hls) { - window.Hls = hls; - callback(); - }); - } - - function enableHlsPlayer(url, item, mediaSource, mediaType) { - if (!htmlMediaHelper.enableHlsJsPlayer(mediaSource.RunTimeTicks, mediaType)) { - return Promise.reject(); - } - - if (url.indexOf('.m3u8') !== -1) { - return Promise.resolve(); - } - - // issue head request to get content type - return new Promise(function (resolve, reject) { - require(['fetchHelper'], function (fetchHelper) { - fetchHelper.ajax({ - url: url, - type: 'HEAD' - }).then(function (response) { - var contentType = (response.headers.get('Content-Type') || '').toLowerCase(); - if (contentType === 'application/x-mpegurl') { - resolve(); - } else { - reject(); - } - }, reject); - }); - }); - } - - function HtmlAudioPlayer() { - var self = this; +class HtmlAudioPlayer { + constructor() { + const self = this; self.name = 'Html Audio Player'; self.type = 'mediaplayer'; @@ -99,7 +102,7 @@ define(['events', 'browser', 'require', 'apphost', 'appSettings', 'htmlMediaHelp self._timeUpdated = false; self._currentTime = null; - var elem = createMediaElement(); + const elem = createMediaElement(); return setCurrentSrc(elem, options); }; @@ -109,11 +112,11 @@ define(['events', 'browser', 'require', 'apphost', 'appSettings', 'htmlMediaHelp unBindEvents(elem); bindEvents(elem); - var val = options.url; + let val = options.url; console.debug('playing url: ' + val); // Convert to seconds - var seconds = (options.playerStartPositionTicks || 0) / 10000000; + const seconds = (options.playerStartPositionTicks || 0) / 10000000; if (seconds) { val += '#t=' + seconds; } @@ -122,7 +125,7 @@ define(['events', 'browser', 'require', 'apphost', 'appSettings', 'htmlMediaHelp self._currentPlayOptions = options; - var crossOrigin = htmlMediaHelper.getCrossOriginValue(options.mediaSource); + const crossOrigin = htmlMediaHelper.getCrossOriginValue(options.mediaSource); if (crossOrigin) { elem.crossOrigin = crossOrigin; } @@ -130,9 +133,9 @@ define(['events', 'browser', 'require', 'apphost', 'appSettings', 'htmlMediaHelp return enableHlsPlayer(val, options.item, options.mediaSource, 'Audio').then(function () { return new Promise(function (resolve, reject) { requireHlsPlayer(function () { - var hls = new Hls({ + const hls = new Hls({ manifestLoadingTimeOut: 20000, - xhrSetup: function(xhr, url) { + xhrSetup: function (xhr, url) { xhr.withCredentials = true; } }); @@ -183,8 +186,8 @@ define(['events', 'browser', 'require', 'apphost', 'appSettings', 'htmlMediaHelp self.stop = function (destroyPlayer) { cancelFadeTimeout(); - var elem = self._mediaElement; - var src = self._currentSrc; + const elem = self._mediaElement; + const src = self._currentSrc; if (elem && src) { if (!destroyPlayer || !supportsFade()) { @@ -198,7 +201,7 @@ define(['events', 'browser', 'require', 'apphost', 'appSettings', 'htmlMediaHelp return Promise.resolve(); } - var originalVolume = elem.volume; + const originalVolume = elem.volume; return fade(self, elem, elem.volume).then(function () { elem.pause(); @@ -219,7 +222,7 @@ define(['events', 'browser', 'require', 'apphost', 'appSettings', 'htmlMediaHelp }; function createMediaElement() { - var elem = self._mediaElement; + let elem = self._mediaElement; if (elem) { return elem; @@ -248,7 +251,7 @@ define(['events', 'browser', 'require', 'apphost', 'appSettings', 'htmlMediaHelp function onTimeUpdate() { // Get the player position + the transcoding offset - var time = this.currentTime; + const time = this.currentTime; // Don't trigger events after user stop if (!self._isFadingOut) { @@ -287,11 +290,11 @@ define(['events', 'browser', 'require', 'apphost', 'appSettings', 'htmlMediaHelp } function onError() { - var errorCode = this.error ? (this.error.code || 0) : 0; - var errorMessage = this.error ? (this.error.message || '') : ''; + const errorCode = this.error ? (this.error.code || 0) : 0; + const errorMessage = this.error ? (this.error.message || '') : ''; console.error('media element error: ' + errorCode.toString() + ' ' + errorMessage); - var type; + let type; switch (errorCode) { case 1: @@ -325,59 +328,59 @@ define(['events', 'browser', 'require', 'apphost', 'appSettings', 'htmlMediaHelp } } - HtmlAudioPlayer.prototype.currentSrc = function () { + currentSrc() { return this._currentSrc; - }; + } - HtmlAudioPlayer.prototype.canPlayMediaType = function (mediaType) { + canPlayMediaType(mediaType) { return (mediaType || '').toLowerCase() === 'audio'; - }; + } - HtmlAudioPlayer.prototype.getDeviceProfile = function (item) { + getDeviceProfile(item) { if (appHost.getDeviceProfile) { return appHost.getDeviceProfile(item); } return getDefaultProfile(); - }; + } // Save this for when playback stops, because querying the time at that point might return 0 - HtmlAudioPlayer.prototype.currentTime = function (val) { - var mediaElement = this._mediaElement; + currentTime(val) { + const mediaElement = this._mediaElement; if (mediaElement) { if (val != null) { mediaElement.currentTime = val / 1000; return; } - var currentTime = this._currentTime; + const currentTime = this._currentTime; if (currentTime) { return currentTime * 1000; } return (mediaElement.currentTime || 0) * 1000; } - }; + } - HtmlAudioPlayer.prototype.duration = function (val) { - var mediaElement = this._mediaElement; + duration(val) { + const mediaElement = this._mediaElement; if (mediaElement) { - var duration = mediaElement.duration; + const duration = mediaElement.duration; if (htmlMediaHelper.isValidDuration(duration)) { return duration * 1000; } } return null; - }; + } - HtmlAudioPlayer.prototype.seekable = function () { - var mediaElement = this._mediaElement; + seekable() { + const mediaElement = this._mediaElement; if (mediaElement) { - var seekable = mediaElement.seekable; + const seekable = mediaElement.seekable; if (seekable && seekable.length) { - var start = seekable.start(0); - var end = seekable.end(0); + let start = seekable.start(0); + let end = seekable.end(0); if (!htmlMediaHelper.isValidDuration(start)) { start = 0; @@ -391,124 +394,123 @@ define(['events', 'browser', 'require', 'apphost', 'appSettings', 'htmlMediaHelp return false; } - }; + } - HtmlAudioPlayer.prototype.getBufferedRanges = function () { - var mediaElement = this._mediaElement; + getBufferedRanges() { + const mediaElement = this._mediaElement; if (mediaElement) { return htmlMediaHelper.getBufferedRanges(this, mediaElement); } return []; - }; + } - HtmlAudioPlayer.prototype.pause = function () { - var mediaElement = this._mediaElement; + pause() { + const mediaElement = this._mediaElement; if (mediaElement) { mediaElement.pause(); } - }; + } // This is a retry after error - HtmlAudioPlayer.prototype.resume = function () { - var mediaElement = this._mediaElement; + resume() { + const mediaElement = this._mediaElement; if (mediaElement) { mediaElement.play(); } - }; + } - HtmlAudioPlayer.prototype.unpause = function () { - var mediaElement = this._mediaElement; + unpause() { + const mediaElement = this._mediaElement; if (mediaElement) { mediaElement.play(); } - }; + } - HtmlAudioPlayer.prototype.paused = function () { - var mediaElement = this._mediaElement; + paused() { + const mediaElement = this._mediaElement; if (mediaElement) { return mediaElement.paused; } return false; - }; + } - HtmlAudioPlayer.prototype.setPlaybackRate = function (value) { - var mediaElement = this._mediaElement; + setPlaybackRate(value) { + const mediaElement = this._mediaElement; if (mediaElement) { mediaElement.playbackRate = value; } - }; + } - HtmlAudioPlayer.prototype.getPlaybackRate = function () { - var mediaElement = this._mediaElement; + getPlaybackRate() { + const mediaElement = this._mediaElement; if (mediaElement) { return mediaElement.playbackRate; } return null; - }; + } - HtmlAudioPlayer.prototype.setVolume = function (val) { - var mediaElement = this._mediaElement; + setVolume(val) { + const mediaElement = this._mediaElement; if (mediaElement) { mediaElement.volume = val / 100; } - }; + } - HtmlAudioPlayer.prototype.getVolume = function () { - var mediaElement = this._mediaElement; + getVolume() { + const mediaElement = this._mediaElement; if (mediaElement) { return Math.min(Math.round(mediaElement.volume * 100), 100); } - }; + } - HtmlAudioPlayer.prototype.volumeUp = function () { + volumeUp() { this.setVolume(Math.min(this.getVolume() + 2, 100)); - }; + } - HtmlAudioPlayer.prototype.volumeDown = function () { + volumeDown() { this.setVolume(Math.max(this.getVolume() - 2, 0)); - }; + } - HtmlAudioPlayer.prototype.setMute = function (mute) { - var mediaElement = this._mediaElement; + setMute(mute) { + const mediaElement = this._mediaElement; if (mediaElement) { mediaElement.muted = mute; } - }; + } - HtmlAudioPlayer.prototype.isMuted = function () { - var mediaElement = this._mediaElement; + isMuted() { + const mediaElement = this._mediaElement; if (mediaElement) { return mediaElement.muted; } return false; - }; - - HtmlAudioPlayer.prototype.destroy = function () { - - }; - - var supportedFeatures; - - function getSupportedFeatures() { - var list = []; - var audio = document.createElement('audio'); - - if (typeof audio.playbackRate === 'number') { - list.push('PlaybackRate'); - } - - return list; } - HtmlAudioPlayer.prototype.supports = function (feature) { + destroy() { + } + + supports(feature) { if (!supportedFeatures) { supportedFeatures = getSupportedFeatures(); } return supportedFeatures.indexOf(feature) !== -1; - }; + } +} - return HtmlAudioPlayer; -}); +let supportedFeatures; + +function getSupportedFeatures() { + const list = []; + const audio = document.createElement('audio'); + + if (typeof audio.playbackRate === 'number') { + list.push('PlaybackRate'); + } + + return list; +} + +export default HtmlAudioPlayer; From 2b492f7aa0563ef1558ae7a601f80e7c26ffaaf9 Mon Sep 17 00:00:00 2001 From: Matjaz Zavski Date: Tue, 4 Aug 2020 09:11:56 +0200 Subject: [PATCH 018/301] Update src/controllers/livetv/livetvsuggested.js Co-authored-by: Cameron --- src/controllers/livetv/livetvsuggested.js | 1 + 1 file changed, 1 insertion(+) diff --git a/src/controllers/livetv/livetvsuggested.js b/src/controllers/livetv/livetvsuggested.js index c25431060a..d66f3733b5 100644 --- a/src/controllers/livetv/livetvsuggested.js +++ b/src/controllers/livetv/livetvsuggested.js @@ -242,6 +242,7 @@ export default function (view, params) { // TODO int is a little hard to read switch (index) { case 0: + depends = 'controllers/livetv/livetvsuggested'; break; case 1: From 947f8ba05de15e4723d9317a28ea419c21c5d078 Mon Sep 17 00:00:00 2001 From: Cameron Date: Tue, 4 Aug 2020 08:55:54 +0100 Subject: [PATCH 019/301] Migration of livetvguide and livetvcomponents to ES6 moduoles --- package.json | 2 + src/controllers/livetv/livetvguide.js | 50 +++--- src/scripts/livetvcomponents.js | 209 ++++++++++++-------------- 3 files changed, 125 insertions(+), 136 deletions(-) diff --git a/package.json b/package.json index 22fd43308a..e3d0c4d144 100644 --- a/package.json +++ b/package.json @@ -209,6 +209,7 @@ "src/controllers/playback/queue/index.js", "src/controllers/playback/video/index.js", "src/controllers/searchpage.js", + "src/controllers/livetv/livetvguide.js", "src/controllers/livetvtuner.js", "src/controllers/livetvstatus.js", "src/controllers/livetvsettings.js", @@ -270,6 +271,7 @@ "src/scripts/inputManager.js", "src/scripts/keyboardNavigation.js", "src/scripts/libraryBrowser.js", + "src/scripts/livetvcomponents.js", "src/scripts/mouseManager.js", "src/scripts/multiDownload.js", "src/scripts/playlists.js", diff --git a/src/controllers/livetv/livetvguide.js b/src/controllers/livetv/livetvguide.js index ec7a7a3f81..77214a87b3 100644 --- a/src/controllers/livetv/livetvguide.js +++ b/src/controllers/livetv/livetvguide.js @@ -1,29 +1,27 @@ -define(['tvguide'], function (tvguide) { - 'use strict'; +import tvguide from 'tvguide'; - return function (view, params, tabContent) { - var guideInstance; - var self = this; +export default function (view, params, tabContent) { + let guideInstance; + const self = this; - self.renderTab = function () { - if (!guideInstance) { - guideInstance = new tvguide({ - element: tabContent, - serverId: ApiClient.serverId() - }); - } - }; - - self.onShow = function () { - if (guideInstance) { - guideInstance.resume(); - } - }; - - self.onHide = function () { - if (guideInstance) { - guideInstance.pause(); - } - }; + self.renderTab = function () { + if (!guideInstance) { + guideInstance = new tvguide({ + element: tabContent, + serverId: ApiClient.serverId() + }); + } }; -}); + + self.onShow = function () { + if (guideInstance) { + guideInstance.resume(); + } + }; + + self.onHide = function () { + if (guideInstance) { + guideInstance.pause(); + } + }; +}; diff --git a/src/scripts/livetvcomponents.js b/src/scripts/livetvcomponents.js index fd1b48d0eb..387972d996 100644 --- a/src/scripts/livetvcomponents.js +++ b/src/scripts/livetvcomponents.js @@ -1,115 +1,104 @@ -define(['layoutManager', 'datetime', 'cardBuilder', 'apphost'], function (layoutManager, datetime, cardBuilder, appHost) { - 'use strict'; +import layoutManager from 'layoutManager'; +import datetime from 'datetime'; +import cardBuilder from 'cardBuilder'; - function enableScrollX() { - return !layoutManager.desktop; +function enableScrollX() { + return !layoutManager.desktop; +} + +function getBackdropShape() { + return enableScrollX() ? 'overflowBackdrop' : 'backdrop'; +} + +function getTimersHtml(timers, options) { + options = options || {}; + const items = timers.map(function (t) { + t.Type = 'Timer'; + return t; + }); + const groups = []; + let currentGroupName = ''; + let currentGroup = []; + + for (let i = 0, length = items.length; i < length; i++) { + const item = items[i]; + let dateText = ''; + + if (options.indexByDate !== false && item.StartDate) { + try { + const premiereDate = datetime.parseISO8601Date(item.StartDate, true); + dateText = datetime.toLocaleDateString(premiereDate, { + weekday: 'long', + month: 'short', + day: 'numeric' + }); + } catch (err) { + console.error('error parsing premiereDate:' + item.StartDate + '; error: ' + err); + } + } + + if (dateText != currentGroupName) { + if (currentGroup.length) { + groups.push({ + name: currentGroupName, + items: currentGroup + }); + } + + currentGroupName = dateText; + currentGroup = [item]; + } else { + currentGroup.push(item); + } } - - function getBackdropShape() { - return enableScrollX() ? 'overflowBackdrop' : 'backdrop'; - } - - function getTimersHtml(timers, options) { - options = options || {}; - var i; - var length; - var items = timers.map(function (t) { - t.Type = 'Timer'; - return t; + if (currentGroup.length) { + groups.push({ + name: currentGroupName, + items: currentGroup }); - var groups = []; - var currentGroupName = ''; - var currentGroup = []; - - for (i = 0, length = items.length; i < length; i++) { - var item = items[i]; - var dateText = ''; - - if (options.indexByDate !== false && item.StartDate) { - try { - var premiereDate = datetime.parseISO8601Date(item.StartDate, true); - dateText = datetime.toLocaleDateString(premiereDate, { - weekday: 'long', - month: 'short', - day: 'numeric' - }); - } catch (err) { - console.error('error parsing premiereDate:' + item.StartDate + '; error: ' + err); - } - } - - if (dateText != currentGroupName) { - if (currentGroup.length) { - groups.push({ - name: currentGroupName, - items: currentGroup - }); - } - - currentGroupName = dateText; - currentGroup = [item]; - } else { - currentGroup.push(item); - } - } - - if (currentGroup.length) { - groups.push({ - name: currentGroupName, - items: currentGroup - }); - } - - var html = ''; - - for (i = 0, length = groups.length; i < length; i++) { - var group = groups[i]; - - if (group.name) { - html += '
'; - html += '

' + group.name + '

'; - } - if (enableScrollX()) { - var scrollXClass = 'scrollX hiddenScrollX'; - - if (layoutManager.tv) { - scrollXClass += ' smoothScrollX'; - } - - html += '
'; - } else { - html += '
'; - } - - html += cardBuilder.getCardsHtml({ - items: group.items, - shape: getBackdropShape(), - showParentTitleOrTitle: true, - showAirTime: true, - showAirEndTime: true, - showChannelName: false, - cardLayout: true, - centerText: false, - action: 'edit', - cardFooterAside: 'none', - preferThumb: true, - defaultShape: null, - coverImage: true, - allowBottomPadding: false, - overlayText: false, - showChannelLogo: true - }); - html += '
'; - - if (group.name) { - html += '
'; - } - } - - return Promise.resolve(html); } + let html = ''; + for (let i = 0, length = groups.length; i < length; i++) { + const group = groups[i]; + if (group.name) { + html += '
'; + html += '

' + group.name + '

'; + } + if (enableScrollX()) { + let scrollXClass = 'scrollX hiddenScrollX'; + if (layoutManager.tv) { + scrollXClass += ' smoothScrollX'; + } + html += '
'; + } else { + html += '
'; + } + html += cardBuilder.getCardsHtml({ + items: group.items, + shape: getBackdropShape(), + showParentTitleOrTitle: true, + showAirTime: true, + showAirEndTime: true, + showChannelName: false, + cardLayout: true, + centerText: false, + action: 'edit', + cardFooterAside: 'none', + preferThumb: true, + defaultShape: null, + coverImage: true, + allowBottomPadding: false, + overlayText: false, + showChannelLogo: true + }); + html += '
'; + if (group.name) { + html += '
'; + } + } + return Promise.resolve(html); +} - window.LiveTvHelpers = { - getTimersHtml: getTimersHtml - }; -}); +window.LiveTvHelpers = { + getTimersHtml: getTimersHtml +}; From 44800858e5181abb1df1b875db7e571d8308acdb Mon Sep 17 00:00:00 2001 From: Cameron Date: Tue, 4 Aug 2020 09:03:02 +0100 Subject: [PATCH 020/301] lint and replace for with for...of --- src/controllers/livetv/livetvguide.js | 2 +- src/scripts/livetvcomponents.js | 13 +++++++++---- 2 files changed, 10 insertions(+), 5 deletions(-) diff --git a/src/controllers/livetv/livetvguide.js b/src/controllers/livetv/livetvguide.js index 77214a87b3..f8b49bd22a 100644 --- a/src/controllers/livetv/livetvguide.js +++ b/src/controllers/livetv/livetvguide.js @@ -24,4 +24,4 @@ export default function (view, params, tabContent) { guideInstance.pause(); } }; -}; +} diff --git a/src/scripts/livetvcomponents.js b/src/scripts/livetvcomponents.js index 387972d996..f1d0b2d3da 100644 --- a/src/scripts/livetvcomponents.js +++ b/src/scripts/livetvcomponents.js @@ -12,16 +12,17 @@ function getBackdropShape() { function getTimersHtml(timers, options) { options = options || {}; + const items = timers.map(function (t) { t.Type = 'Timer'; return t; }); + const groups = []; let currentGroupName = ''; let currentGroup = []; - for (let i = 0, length = items.length; i < length; i++) { - const item = items[i]; + for (const item in items) { let dateText = ''; if (options.indexByDate !== false && item.StartDate) { @@ -51,6 +52,7 @@ function getTimersHtml(timers, options) { currentGroup.push(item); } } + if (currentGroup.length) { groups.push({ name: currentGroupName, @@ -58,12 +60,12 @@ function getTimersHtml(timers, options) { }); } let html = ''; - for (let i = 0, length = groups.length; i < length; i++) { - const group = groups[i]; + for (const group in groups) { if (group.name) { html += '
'; html += '

' + group.name + '

'; } + if (enableScrollX()) { let scrollXClass = 'scrollX hiddenScrollX'; if (layoutManager.tv) { @@ -73,6 +75,7 @@ function getTimersHtml(timers, options) { } else { html += '
'; } + html += cardBuilder.getCardsHtml({ items: group.items, shape: getBackdropShape(), @@ -91,7 +94,9 @@ function getTimersHtml(timers, options) { overlayText: false, showChannelLogo: true }); + html += '
'; + if (group.name) { html += '
'; } From 2feb4c966f8473b95fca2742a1dc29ec3f57c3e3 Mon Sep 17 00:00:00 2001 From: Cameron Date: Tue, 4 Aug 2020 10:33:16 +0100 Subject: [PATCH 021/301] Migration of recordingbutton and recordingcreator to ES6 modules --- package.json | 2 + .../recordingcreator/recordingbutton.js | 129 +++---- .../recordingcreator/recordingcreator.js | 333 +++++++++--------- 3 files changed, 245 insertions(+), 219 deletions(-) diff --git a/package.json b/package.json index 5ad12d2011..72036d04e6 100644 --- a/package.json +++ b/package.json @@ -152,6 +152,8 @@ "src/components/playlisteditor/playlisteditor.js", "src/components/playmenu.js", "src/components/prompt/prompt.js", + "src/components/recordingcreator/recordingbutton.js", + "src/components/recordingcreator/recordingcreator.js", "src/components/refreshdialog/refreshdialog.js", "src/components/sanatizefilename.js", "src/components/scrollManager.js", diff --git a/src/components/recordingcreator/recordingbutton.js b/src/components/recordingcreator/recordingbutton.js index 3ad4ffa594..78fb0563cf 100644 --- a/src/components/recordingcreator/recordingbutton.js +++ b/src/components/recordingcreator/recordingbutton.js @@ -1,35 +1,42 @@ -define(['globalize', 'connectionManager', 'require', 'loading', 'apphost', 'dom', 'recordingHelper', 'events', 'paper-icon-button-light', 'emby-button', 'css!./recordingfields'], function (globalize, connectionManager, require, loading, appHost, dom, recordingHelper, events) { - 'use strict'; +import connectionManager from 'connectionManager'; +import dom from 'dom'; +import recordingHelper from 'recordingHelper'; +import 'paper-icon-button-light'; +import 'emby-button'; +import 'css!./recordingfields'; - function onRecordingButtonClick(e) { - var item = this.item; +/*eslint prefer-const: "error"*/ - if (item) { - var serverId = item.ServerId; - var programId = item.Id; - var timerId = item.TimerId; - var timerStatus = item.Status; - var seriesTimerId = item.SeriesTimerId; +function onRecordingButtonClick(e) { + const item = this.item; - var instance = this; + if (item) { + const serverId = item.ServerId; + const programId = item.Id; + const timerId = item.TimerId; + const timerStatus = item.Status; + const seriesTimerId = item.SeriesTimerId; - recordingHelper.toggleRecording(serverId, programId, timerId, timerStatus, seriesTimerId).then(function () { - instance.refresh(serverId, programId); - }); - } + const instance = this; + + recordingHelper.toggleRecording(serverId, programId, timerId, timerStatus, seriesTimerId).then(function () { + instance.refresh(serverId, programId); + }); } +} - function setButtonIcon(button, icon) { - var inner = button.querySelector('.material-icons'); - inner.classList.remove('fiber_smart_record'); - inner.classList.remove('fiber_manual_record'); - inner.classList.add(icon); - } +function setButtonIcon(button, icon) { + const inner = button.querySelector('.material-icons'); + inner.classList.remove('fiber_smart_record'); + inner.classList.remove('fiber_manual_record'); + inner.classList.add(icon); +} - function RecordingButton(options) { +class RecordingButton { + constructor(options) { this.options = options; - var button = options.button; + const button = options.button; setButtonIcon(button, 'fiber_manual_record'); @@ -39,7 +46,7 @@ define(['globalize', 'connectionManager', 'require', 'loading', 'apphost', 'dom' this.refresh(options.itemId, options.serverId); } - var clickFn = onRecordingButtonClick.bind(this); + const clickFn = onRecordingButtonClick.bind(this); this.clickFn = clickFn; dom.addEventListener(button, 'click', clickFn, { @@ -47,39 +54,17 @@ define(['globalize', 'connectionManager', 'require', 'loading', 'apphost', 'dom' }); } - function getIndicatorIcon(item) { - var status; - - if (item.Type === 'SeriesTimer') { - return 'fiber_smart_record'; - } else if (item.TimerId || item.SeriesTimerId) { - status = item.Status || 'Cancelled'; - } else if (item.Type === 'Timer') { - status = item.Status; - } else { - return 'fiber_manual_record'; - } - - if (item.SeriesTimerId) { - if (status !== 'Cancelled') { - return 'fiber_smart_record'; - } - } - - return 'fiber_manual_record'; - } - - RecordingButton.prototype.refresh = function (serverId, itemId) { - var apiClient = connectionManager.getApiClient(serverId); - var self = this; + refresh(serverId, itemId) { + const apiClient = connectionManager.getApiClient(serverId); + const self = this; apiClient.getItem(apiClient.getCurrentUserId(), itemId).then(function (item) { self.refreshItem(item); }); - }; + } - RecordingButton.prototype.refreshItem = function (item) { - var options = this.options; - var button = options.button; + refreshItem(item) { + const options = this.options; + const button = options.button; this.item = item; setButtonIcon(button, getIndicatorIcon(item)); @@ -88,15 +73,15 @@ define(['globalize', 'connectionManager', 'require', 'loading', 'apphost', 'dom' } else { button.classList.remove('recordingIcon-active'); } - }; + } - RecordingButton.prototype.destroy = function () { - var options = this.options; + destroy() { + const options = this.options; if (options) { - var button = options.button; + const button = options.button; - var clickFn = this.clickFn; + const clickFn = this.clickFn; if (clickFn) { dom.removeEventListener(button, 'click', clickFn, { @@ -107,7 +92,29 @@ define(['globalize', 'connectionManager', 'require', 'loading', 'apphost', 'dom' this.options = null; this.item = null; - }; + } +} - return RecordingButton; -}); +function getIndicatorIcon(item) { + let status; + + if (item.Type === 'SeriesTimer') { + return 'fiber_smart_record'; + } else if (item.TimerId || item.SeriesTimerId) { + status = item.Status || 'Cancelled'; + } else if (item.Type === 'Timer') { + status = item.Status; + } else { + return 'fiber_manual_record'; + } + + if (item.SeriesTimerId) { + if (status !== 'Cancelled') { + return 'fiber_smart_record'; + } + } + + return 'fiber_manual_record'; +} + +export default RecordingButton; diff --git a/src/components/recordingcreator/recordingcreator.js b/src/components/recordingcreator/recordingcreator.js index ca5c475829..b8001fc35e 100644 --- a/src/components/recordingcreator/recordingcreator.js +++ b/src/components/recordingcreator/recordingcreator.js @@ -1,187 +1,204 @@ -define(['dialogHelper', 'globalize', 'layoutManager', 'mediaInfo', 'apphost', 'connectionManager', 'require', 'loading', 'scrollHelper', 'datetime', 'imageLoader', 'recordingFields', 'events', 'emby-checkbox', 'emby-button', 'emby-collapse', 'emby-input', 'paper-icon-button-light', 'css!./../formdialog', 'css!./recordingcreator', 'material-icons'], function (dialogHelper, globalize, layoutManager, mediaInfo, appHost, connectionManager, require, loading, scrollHelper, datetime, imageLoader, recordingFields, events) { - 'use strict'; +import dialogHelper from 'dialogHelper'; +import globalize from 'globalize'; +import layoutManager from 'layoutManager'; +import mediaInfo from 'mediaInfo'; +import connectionManager from 'connectionManager'; +import require from 'require'; +import loading from 'loading'; +import scrollHelper from 'scrollHelper'; +import datetime from 'datetime'; +import imageLoader from 'imageLoader'; +import recordingFields from 'recordingFields'; +import events from 'events'; +import 'emby-checkbox'; +import 'emby-button'; +import 'emby-collapse'; +import 'emby-input'; +import 'paper-icon-button-light'; +import 'css!./../formdialog'; +import 'css!./recordingcreator'; +import 'material-icons'; - var currentDialog; - var closeAction; - var currentRecordingFields; +let currentDialog; +let closeAction; +let currentRecordingFields; - function closeDialog() { - dialogHelper.close(currentDialog); +function closeDialog() { + dialogHelper.close(currentDialog); +} + +function init(context) { + context.querySelector('.btnPlay').addEventListener('click', function () { + closeAction = 'play'; + closeDialog(); + }); + + context.querySelector('.btnCancel').addEventListener('click', function () { + closeAction = null; + closeDialog(); + }); +} + +function getImageUrl(item, apiClient, imageHeight) { + const imageTags = item.ImageTags || {}; + + if (item.PrimaryImageTag) { + imageTags.Primary = item.PrimaryImageTag; } - function init(context) { - context.querySelector('.btnPlay').addEventListener('click', function () { - closeAction = 'play'; - closeDialog(); + if (imageTags.Primary) { + return apiClient.getScaledImageUrl(item.Id, { + type: 'Primary', + maxHeight: imageHeight, + tag: item.ImageTags.Primary }); - - context.querySelector('.btnCancel').addEventListener('click', function () { - closeAction = null; - closeDialog(); + } else if (imageTags.Thumb) { + return apiClient.getScaledImageUrl(item.Id, { + type: 'Thumb', + maxHeight: imageHeight, + tag: item.ImageTags.Thumb }); } - function getImageUrl(item, apiClient, imageHeight) { - var imageTags = item.ImageTags || {}; + return null; +} - if (item.PrimaryImageTag) { - imageTags.Primary = item.PrimaryImageTag; +function renderRecording(context, defaultTimer, program, apiClient, refreshRecordingStateOnly) { + if (!refreshRecordingStateOnly) { + const imgUrl = getImageUrl(program, apiClient, 200); + const imageContainer = context.querySelector('.recordingDialog-imageContainer'); + + if (imgUrl) { + imageContainer.innerHTML = ''; + imageContainer.classList.remove('hide'); + + imageLoader.lazyChildren(imageContainer); + } else { + imageContainer.innerHTML = ''; + imageContainer.classList.add('hide'); } - if (imageTags.Primary) { - return apiClient.getScaledImageUrl(item.Id, { - type: 'Primary', - maxHeight: imageHeight, - tag: item.ImageTags.Primary - }); - } else if (imageTags.Thumb) { - return apiClient.getScaledImageUrl(item.Id, { - type: 'Thumb', - maxHeight: imageHeight, - tag: item.ImageTags.Thumb - }); + context.querySelector('.recordingDialog-itemName').innerHTML = program.Name; + context.querySelector('.formDialogHeaderTitle').innerHTML = program.Name; + context.querySelector('.itemGenres').innerHTML = (program.Genres || []).join(' / '); + context.querySelector('.itemOverview').innerHTML = program.Overview || ''; + + const formDialogFooter = context.querySelector('.formDialogFooter'); + const now = new Date(); + if (now >= datetime.parseISO8601Date(program.StartDate, true) && now < datetime.parseISO8601Date(program.EndDate, true)) { + formDialogFooter.classList.remove('hide'); + } else { + formDialogFooter.classList.add('hide'); } - return null; + context.querySelector('.itemMiscInfoPrimary').innerHTML = mediaInfo.getPrimaryMediaInfoHtml(program); } - function renderRecording(context, defaultTimer, program, apiClient, refreshRecordingStateOnly) { - if (!refreshRecordingStateOnly) { - var imgUrl = getImageUrl(program, apiClient, 200); - var imageContainer = context.querySelector('.recordingDialog-imageContainer'); + context.querySelector('.itemMiscInfoSecondary').innerHTML = mediaInfo.getSecondaryMediaInfoHtml(program, { + }); - if (imgUrl) { - imageContainer.innerHTML = ''; - imageContainer.classList.remove('hide'); + loading.hide(); +} - imageLoader.lazyChildren(imageContainer); - } else { - imageContainer.innerHTML = ''; - imageContainer.classList.add('hide'); - } +function reload(context, programId, serverId, refreshRecordingStateOnly) { + loading.show(); - context.querySelector('.recordingDialog-itemName').innerHTML = program.Name; - context.querySelector('.formDialogHeaderTitle').innerHTML = program.Name; - context.querySelector('.itemGenres').innerHTML = (program.Genres || []).join(' / '); - context.querySelector('.itemOverview').innerHTML = program.Overview || ''; + const apiClient = connectionManager.getApiClient(serverId); - var formDialogFooter = context.querySelector('.formDialogFooter'); - var now = new Date(); - if (now >= datetime.parseISO8601Date(program.StartDate, true) && now < datetime.parseISO8601Date(program.EndDate, true)) { - formDialogFooter.classList.remove('hide'); - } else { - formDialogFooter.classList.add('hide'); - } + const promise1 = apiClient.getNewLiveTvTimerDefaults({ programId: programId }); + const promise2 = apiClient.getLiveTvProgram(programId, apiClient.getCurrentUserId()); - context.querySelector('.itemMiscInfoPrimary').innerHTML = mediaInfo.getPrimaryMediaInfoHtml(program); - } + Promise.all([promise1, promise2]).then(function (responses) { + const defaults = responses[0]; + const program = responses[1]; - context.querySelector('.itemMiscInfoSecondary').innerHTML = mediaInfo.getSecondaryMediaInfoHtml(program, { - }); + renderRecording(context, defaults, program, apiClient, refreshRecordingStateOnly); + }); +} - loading.hide(); - } +function executeCloseAction(action, programId, serverId) { + if (action === 'play') { + import('playbackManager').then(({default: playbackManager}) => { + const apiClient = connectionManager.getApiClient(serverId); - function reload(context, programId, serverId, refreshRecordingStateOnly) { - loading.show(); - - var apiClient = connectionManager.getApiClient(serverId); - - var promise1 = apiClient.getNewLiveTvTimerDefaults({ programId: programId }); - var promise2 = apiClient.getLiveTvProgram(programId, apiClient.getCurrentUserId()); - - Promise.all([promise1, promise2]).then(function (responses) { - var defaults = responses[0]; - var program = responses[1]; - - renderRecording(context, defaults, program, apiClient, refreshRecordingStateOnly); - }); - } - - function executeCloseAction(action, programId, serverId) { - if (action === 'play') { - require(['playbackManager'], function (playbackManager) { - var apiClient = connectionManager.getApiClient(serverId); - - apiClient.getLiveTvProgram(programId, apiClient.getCurrentUserId()).then(function (item) { - playbackManager.default.play({ - ids: [item.ChannelId], - serverId: serverId - }); - }); - }); - return; - } - } - - function showEditor(itemId, serverId) { - return new Promise(function (resolve, reject) { - closeAction = null; - - loading.show(); - - require(['text!./recordingcreator.template.html'], function (template) { - var dialogOptions = { - removeOnClose: true, - scrollY: false - }; - - if (layoutManager.tv) { - dialogOptions.size = 'fullscreen'; - } else { - dialogOptions.size = 'small'; - } - - var dlg = dialogHelper.createDialog(dialogOptions); - - dlg.classList.add('formDialog'); - dlg.classList.add('recordingDialog'); - - var html = ''; - - html += globalize.translateHtml(template, 'core'); - - dlg.innerHTML = html; - - currentDialog = dlg; - - function onRecordingChanged() { - reload(dlg, itemId, serverId, true); - } - - dlg.addEventListener('close', function () { - events.off(currentRecordingFields, 'recordingchanged', onRecordingChanged); - executeCloseAction(closeAction, itemId, serverId); - - if (currentRecordingFields && currentRecordingFields.hasChanged()) { - resolve(); - } else { - reject(); - } - }); - - if (layoutManager.tv) { - scrollHelper.centerFocus.on(dlg.querySelector('.formDialogContent'), false); - } - - init(dlg); - - reload(dlg, itemId, serverId); - - currentRecordingFields = new recordingFields({ - parent: dlg.querySelector('.recordingFields'), - programId: itemId, + apiClient.getLiveTvProgram(programId, apiClient.getCurrentUserId()).then(function (item) { + playbackManager.default.play({ + ids: [item.ChannelId], serverId: serverId }); - - events.on(currentRecordingFields, 'recordingchanged', onRecordingChanged); - - dialogHelper.open(dlg); }); }); + return; } +} - return { - show: showEditor - }; -}); +function showEditor(itemId, serverId) { + return new Promise(function (resolve, reject) { + closeAction = null; + + loading.show(); + + import('text!./recordingcreator.template.html').then(({default: template}) => { + const dialogOptions = { + removeOnClose: true, + scrollY: false + }; + + if (layoutManager.tv) { + dialogOptions.size = 'fullscreen'; + } else { + dialogOptions.size = 'small'; + } + + const dlg = dialogHelper.createDialog(dialogOptions); + + dlg.classList.add('formDialog'); + dlg.classList.add('recordingDialog'); + + let html = ''; + + html += globalize.translateHtml(template, 'core'); + + dlg.innerHTML = html; + + currentDialog = dlg; + + function onRecordingChanged() { + reload(dlg, itemId, serverId, true); + } + + dlg.addEventListener('close', function () { + events.off(currentRecordingFields, 'recordingchanged', onRecordingChanged); + executeCloseAction(closeAction, itemId, serverId); + + if (currentRecordingFields && currentRecordingFields.hasChanged()) { + resolve(); + } else { + reject(); + } + }); + + if (layoutManager.tv) { + scrollHelper.centerFocus.on(dlg.querySelector('.formDialogContent'), false); + } + + init(dlg); + + reload(dlg, itemId, serverId); + + currentRecordingFields = new recordingFields({ + parent: dlg.querySelector('.recordingFields'), + programId: itemId, + serverId: serverId + }); + + events.on(currentRecordingFields, 'recordingchanged', onRecordingChanged); + + dialogHelper.open(dlg); + }); + }); +} + +export default { + show: showEditor +}; From 3a35a9c5f2ee664fd9409de1d47acdaac54be1d2 Mon Sep 17 00:00:00 2001 From: Cameron Date: Tue, 4 Aug 2020 11:55:00 +0100 Subject: [PATCH 022/301] lint --- src/controllers/itemDetails/index.js | 2 -- src/controllers/music/musicrecommended.js | 2 -- src/scripts/libraryMenu.js | 3 --- 3 files changed, 7 deletions(-) diff --git a/src/controllers/itemDetails/index.js b/src/controllers/itemDetails/index.js index 15c437d684..df2855d69a 100644 --- a/src/controllers/itemDetails/index.js +++ b/src/controllers/itemDetails/index.js @@ -29,8 +29,6 @@ import 'emby-select'; /* eslint-disable indent */ - libraryMenu = libraryMenu.default || libraryMenu; - function getPromise(apiClient, params) { const id = params.id; diff --git a/src/controllers/music/musicrecommended.js b/src/controllers/music/musicrecommended.js index ad031e42b4..db7dac9547 100644 --- a/src/controllers/music/musicrecommended.js +++ b/src/controllers/music/musicrecommended.js @@ -17,8 +17,6 @@ import 'flexStyles'; /* eslint-disable indent */ - libraryMenu = LibraryMenu.default || libraryMenu; - function itemsPerRow() { const screenWidth = dom.getWindowSize().innerWidth; diff --git a/src/scripts/libraryMenu.js b/src/scripts/libraryMenu.js index 8b5fce14d3..0780916a7c 100644 --- a/src/scripts/libraryMenu.js +++ b/src/scripts/libraryMenu.js @@ -19,9 +19,6 @@ import 'flexStyles'; /* eslint-disable indent */ - playbackManager = playbackManager.default || playbackManager; - browser = browser.default || browser; - function renderHeader() { let html = ''; html += '
'; From 73bb781c6a2a4028dc1bd92c497dbe0ffc0ccb8c Mon Sep 17 00:00:00 2001 From: Cameron Date: Tue, 4 Aug 2020 13:47:40 +0100 Subject: [PATCH 023/301] Migration of layoutManager and itemsrefresher to ES6 module --- package.json | 2 + src/components/itemsrefresher.js | 324 +++++++++++++++---------------- src/components/layoutManager.js | 51 +++-- 3 files changed, 189 insertions(+), 188 deletions(-) diff --git a/package.json b/package.json index 5ad12d2011..97784fa2e2 100644 --- a/package.json +++ b/package.json @@ -124,6 +124,8 @@ "src/components/itemHelper.js", "src/components/itemidentifier/itemidentifier.js", "src/components/itemMediaInfo/itemMediaInfo.js", + "src/components/itemsrefresher.js", + "src/components/layoutManager.js", "src/components/lazyLoader/lazyLoaderIntersectionObserver.js", "src/components/libraryoptionseditor/libraryoptionseditor.js", "src/components/listview/listview.js", diff --git a/src/components/itemsrefresher.js b/src/components/itemsrefresher.js index 74b08db07f..3883e6e490 100644 --- a/src/components/itemsrefresher.js +++ b/src/components/itemsrefresher.js @@ -1,130 +1,130 @@ -define(['playbackManager', 'serverNotifications', 'events'], function (playbackManager, serverNotifications, events) { - 'use strict'; +import playbackManager from 'playbackManager'; +import serverNotifications from 'serverNotifications'; +import events from 'events'; - playbackManager = playbackManager.default || playbackManager; +function onUserDataChanged(e, apiClient, userData) { + const instance = this; - function onUserDataChanged(e, apiClient, userData) { - var instance = this; - - var eventsToMonitor = getEventsToMonitor(instance); - - // TODO: Check user data change reason? - if (eventsToMonitor.indexOf('markfavorite') !== -1) { - instance.notifyRefreshNeeded(); - } else if (eventsToMonitor.indexOf('markplayed') !== -1) { - instance.notifyRefreshNeeded(); - } - } - - function getEventsToMonitor(instance) { - var options = instance.options; - var monitor = options ? options.monitorEvents : null; - if (monitor) { - return monitor.split(','); - } - - return []; - } - - function onTimerCreated(e, apiClient, data) { - var instance = this; - - if (getEventsToMonitor(instance).indexOf('timers') !== -1) { - instance.notifyRefreshNeeded(); - return; - } - } - - function onSeriesTimerCreated(e, apiClient, data) { - var instance = this; - if (getEventsToMonitor(instance).indexOf('seriestimers') !== -1) { - instance.notifyRefreshNeeded(); - return; - } - } - - function onTimerCancelled(e, apiClient, data) { - var instance = this; - - if (getEventsToMonitor(instance).indexOf('timers') !== -1) { - instance.notifyRefreshNeeded(); - return; - } - } - - function onSeriesTimerCancelled(e, apiClient, data) { - var instance = this; - if (getEventsToMonitor(instance).indexOf('seriestimers') !== -1) { - instance.notifyRefreshNeeded(); - return; - } - } - - function onLibraryChanged(e, apiClient, data) { - var instance = this; - var eventsToMonitor = getEventsToMonitor(instance); - if (eventsToMonitor.indexOf('seriestimers') !== -1 || eventsToMonitor.indexOf('timers') !== -1) { - // yes this is an assumption - return; - } - - var itemsAdded = data.ItemsAdded || []; - var itemsRemoved = data.ItemsRemoved || []; - if (!itemsAdded.length && !itemsRemoved.length) { - return; - } - - var options = instance.options || {}; - var parentId = options.parentId; - if (parentId) { - var foldersAddedTo = data.FoldersAddedTo || []; - var foldersRemovedFrom = data.FoldersRemovedFrom || []; - var collectionFolders = data.CollectionFolders || []; - - if (foldersAddedTo.indexOf(parentId) === -1 && foldersRemovedFrom.indexOf(parentId) === -1 && collectionFolders.indexOf(parentId) === -1) { - return; - } - } + const eventsToMonitor = getEventsToMonitor(instance); + // TODO: Check user data change reason? + if (eventsToMonitor.indexOf('markfavorite') !== -1) { + instance.notifyRefreshNeeded(); + } else if (eventsToMonitor.indexOf('markplayed') !== -1) { instance.notifyRefreshNeeded(); } +} - function onPlaybackStopped(e, stopInfo) { - var instance = this; +function getEventsToMonitor(instance) { + const options = instance.options; + const monitor = options ? options.monitorEvents : null; + if (monitor) { + return monitor.split(','); + } - var state = stopInfo.state; + return []; +} - var eventsToMonitor = getEventsToMonitor(instance); - if (state.NowPlayingItem && state.NowPlayingItem.MediaType === 'Video') { - if (eventsToMonitor.indexOf('videoplayback') !== -1) { - instance.notifyRefreshNeeded(true); - return; - } - } else if (state.NowPlayingItem && state.NowPlayingItem.MediaType === 'Audio') { - if (eventsToMonitor.indexOf('audioplayback') !== -1) { - instance.notifyRefreshNeeded(true); - return; - } +function onTimerCreated(e, apiClient, data) { + const instance = this; + + if (getEventsToMonitor(instance).indexOf('timers') !== -1) { + instance.notifyRefreshNeeded(); + return; + } +} + +function onSeriesTimerCreated(e, apiClient, data) { + const instance = this; + if (getEventsToMonitor(instance).indexOf('seriestimers') !== -1) { + instance.notifyRefreshNeeded(); + return; + } +} + +function onTimerCancelled(e, apiClient, data) { + const instance = this; + + if (getEventsToMonitor(instance).indexOf('timers') !== -1) { + instance.notifyRefreshNeeded(); + return; + } +} + +function onSeriesTimerCancelled(e, apiClient, data) { + const instance = this; + if (getEventsToMonitor(instance).indexOf('seriestimers') !== -1) { + instance.notifyRefreshNeeded(); + return; + } +} + +function onLibraryChanged(e, apiClient, data) { + const instance = this; + const eventsToMonitor = getEventsToMonitor(instance); + if (eventsToMonitor.indexOf('seriestimers') !== -1 || eventsToMonitor.indexOf('timers') !== -1) { + // yes this is an assumption + return; + } + + const itemsAdded = data.ItemsAdded || []; + const itemsRemoved = data.ItemsRemoved || []; + if (!itemsAdded.length && !itemsRemoved.length) { + return; + } + + const options = instance.options || {}; + const parentId = options.parentId; + if (parentId) { + const foldersAddedTo = data.FoldersAddedTo || []; + const foldersRemovedFrom = data.FoldersRemovedFrom || []; + const collectionFolders = data.CollectionFolders || []; + + if (foldersAddedTo.indexOf(parentId) === -1 && foldersRemovedFrom.indexOf(parentId) === -1 && collectionFolders.indexOf(parentId) === -1) { + return; } } - function addNotificationEvent(instance, name, handler, owner) { - var localHandler = handler.bind(instance); + instance.notifyRefreshNeeded(); +} + +function onPlaybackStopped(e, stopInfo) { + const instance = this; + + const state = stopInfo.state; + + const eventsToMonitor = getEventsToMonitor(instance); + if (state.NowPlayingItem && state.NowPlayingItem.MediaType === 'Video') { + if (eventsToMonitor.indexOf('videoplayback') !== -1) { + instance.notifyRefreshNeeded(true); + return; + } + } else if (state.NowPlayingItem && state.NowPlayingItem.MediaType === 'Audio') { + if (eventsToMonitor.indexOf('audioplayback') !== -1) { + instance.notifyRefreshNeeded(true); + return; + } + } +} + +function addNotificationEvent(instance, name, handler, owner) { + const localHandler = handler.bind(instance); + owner = owner || serverNotifications; + events.on(owner, name, localHandler); + instance['event_' + name] = localHandler; +} + +function removeNotificationEvent(instance, name, owner) { + const handler = instance['event_' + name]; + if (handler) { owner = owner || serverNotifications; - events.on(owner, name, localHandler); - instance['event_' + name] = localHandler; + events.off(owner, name, handler); + instance['event_' + name] = null; } +} - function removeNotificationEvent(instance, name, owner) { - var handler = instance['event_' + name]; - if (handler) { - owner = owner || serverNotifications; - events.off(owner, name, handler); - instance['event_' + name] = null; - } - } - - function ItemsRefresher(options) { +class ItemsRefresher { + constructor(options) { this.options = options || {}; addNotificationEvent(this, 'UserDataChanged', onUserDataChanged); @@ -136,18 +136,18 @@ define(['playbackManager', 'serverNotifications', 'events'], function (playbackM addNotificationEvent(this, 'playbackstop', onPlaybackStopped, playbackManager); } - ItemsRefresher.prototype.pause = function () { + pause() { clearRefreshInterval(this, true); this.paused = true; - }; + } - ItemsRefresher.prototype.resume = function (options) { + resume(options) { this.paused = false; - var refreshIntervalEndTime = this.refreshIntervalEndTime; + const refreshIntervalEndTime = this.refreshIntervalEndTime; if (refreshIntervalEndTime) { - var remainingMs = refreshIntervalEndTime - new Date().getTime(); + const remainingMs = refreshIntervalEndTime - new Date().getTime(); if (remainingMs > 0 && !this.needsRefresh) { resetRefreshInterval(this, remainingMs); } else { @@ -161,9 +161,9 @@ define(['playbackManager', 'serverNotifications', 'events'], function (playbackM } return Promise.resolve(); - }; + } - ItemsRefresher.prototype.refreshItems = function () { + refreshItems() { if (!this.fetchData) { return Promise.resolve(); } @@ -176,15 +176,15 @@ define(['playbackManager', 'serverNotifications', 'events'], function (playbackM this.needsRefresh = false; return this.fetchData().then(onDataFetched.bind(this)); - }; + } - ItemsRefresher.prototype.notifyRefreshNeeded = function (isInForeground) { + notifyRefreshNeeded(isInForeground) { if (this.paused) { this.needsRefresh = true; return; } - var timeout = this.refreshTimeout; + const timeout = this.refreshTimeout; if (timeout) { clearTimeout(timeout); } @@ -194,44 +194,9 @@ define(['playbackManager', 'serverNotifications', 'events'], function (playbackM } else { this.refreshTimeout = setTimeout(this.refreshItems.bind(this), 10000); } - }; - - function clearRefreshInterval(instance, isPausing) { - if (instance.refreshInterval) { - clearInterval(instance.refreshInterval); - instance.refreshInterval = null; - - if (!isPausing) { - instance.refreshIntervalEndTime = null; - } - } } - function resetRefreshInterval(instance, intervalMs) { - clearRefreshInterval(instance); - - if (!intervalMs) { - var options = instance.options; - if (options) { - intervalMs = options.refreshIntervalMs; - } - } - - if (intervalMs) { - instance.refreshInterval = setInterval(instance.notifyRefreshNeeded.bind(instance), intervalMs); - instance.refreshIntervalEndTime = new Date().getTime() + intervalMs; - } - } - - function onDataFetched(result) { - resetRefreshInterval(this); - - if (this.afterRefresh) { - this.afterRefresh(result); - } - } - - ItemsRefresher.prototype.destroy = function () { + destroy() { clearRefreshInterval(this); removeNotificationEvent(this, 'UserDataChanged'); @@ -244,7 +209,42 @@ define(['playbackManager', 'serverNotifications', 'events'], function (playbackM this.fetchData = null; this.options = null; - }; + } +} - return ItemsRefresher; -}); +function clearRefreshInterval(instance, isPausing) { + if (instance.refreshInterval) { + clearInterval(instance.refreshInterval); + instance.refreshInterval = null; + + if (!isPausing) { + instance.refreshIntervalEndTime = null; + } + } +} + +function resetRefreshInterval(instance, intervalMs) { + clearRefreshInterval(instance); + + if (!intervalMs) { + const options = instance.options; + if (options) { + intervalMs = options.refreshIntervalMs; + } + } + + if (intervalMs) { + instance.refreshInterval = setInterval(instance.notifyRefreshNeeded.bind(instance), intervalMs); + instance.refreshIntervalEndTime = new Date().getTime() + intervalMs; + } +} + +function onDataFetched(result) { + resetRefreshInterval(this); + + if (this.afterRefresh) { + this.afterRefresh(result); + } +} + +export default ItemsRefresher; diff --git a/src/components/layoutManager.js b/src/components/layoutManager.js index 85d78f8ff4..d104632573 100644 --- a/src/components/layoutManager.js +++ b/src/components/layoutManager.js @@ -1,23 +1,22 @@ -define(['browser', 'appSettings', 'events'], function (browser, appSettings, events) { - 'use strict'; +import browser from 'browser'; +import appSettings from 'appSettings'; +import events from 'events'; - browser = browser.default || browser; +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); + } +} - 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 { + constructor() { } - function LayoutManager() { - - } - - LayoutManager.prototype.setLayout = function (layout, save) { + setLayout(layout, save) { if (!layout || layout === 'auto') { this.autoLayout(); @@ -35,13 +34,13 @@ define(['browser', 'appSettings', 'events'], function (browser, appSettings, eve } events.trigger(this, 'modechange'); - }; + } - LayoutManager.prototype.getSavedLayout = function (layout) { + getSavedLayout(layout) { return appSettings.get('layout'); - }; + } - LayoutManager.prototype.autoLayout = function () { + autoLayout() { // Take a guess at initial layout. The consuming app can override if (browser.mobile) { this.setLayout('mobile', false); @@ -50,16 +49,16 @@ define(['browser', 'appSettings', 'events'], function (browser, appSettings, eve } else { this.setLayout(this.defaultLayout || 'tv', false); } - }; + } - LayoutManager.prototype.init = function () { - var saved = this.getSavedLayout(); + init() { + const saved = this.getSavedLayout(); if (saved) { this.setLayout(saved, false); } else { this.autoLayout(); } - }; + } +} - return new LayoutManager(); -}); +export default new LayoutManager(); From aaad59cca6044f90b02ce53118cd575e42fef604 Mon Sep 17 00:00:00 2001 From: Cameron Date: Tue, 4 Aug 2020 13:47:47 +0100 Subject: [PATCH 024/301] addition of defaults --- src/components/filtermenu/filtermenu.js | 2 ++ src/components/guide/guide-settings.js | 2 ++ src/components/guide/guide.js | 1 + src/components/recordingcreator/recordingcreator.js | 2 ++ src/components/recordingcreator/recordingeditor.js | 1 + src/components/recordingcreator/seriesrecordingeditor.js | 1 + src/components/remotecontrol/remotecontrol.js | 1 + src/components/slideshow/slideshow.js | 1 + src/components/sortmenu/sortmenu.js | 2 ++ src/components/subtitleeditor/subtitleeditor.js | 1 + src/components/subtitlesync/subtitlesync.js | 1 + src/components/tabbedview/tabbedview.js | 2 ++ src/components/tunerPicker.js | 1 + src/components/upnextdialog/upnextdialog.js | 1 + src/components/viewManager/viewManager.js | 2 ++ src/components/viewSettings/viewSettings.js | 2 ++ src/controllers/list.js | 1 + src/controllers/livetv/livetvrecordings.js | 1 + src/controllers/livetv/livetvschedule.js | 1 + src/controllers/livetv/livetvsuggested.js | 1 + src/controllers/movies/moviegenres.js | 1 + src/controllers/movies/movies.js | 1 + src/controllers/movies/moviesrecommended.js | 1 + src/controllers/movies/movietrailers.js | 1 + src/libraries/scroller.js | 1 + src/scripts/libraryMenu.js | 1 + src/scripts/livetvcomponents.js | 2 ++ src/scripts/site.js | 1 + 28 files changed, 36 insertions(+) diff --git a/src/components/filtermenu/filtermenu.js b/src/components/filtermenu/filtermenu.js index 20399fb52d..03a1706fb5 100644 --- a/src/components/filtermenu/filtermenu.js +++ b/src/components/filtermenu/filtermenu.js @@ -1,6 +1,8 @@ define(['require', 'dom', 'focusManager', 'dialogHelper', 'loading', 'apphost', 'inputManager', 'layoutManager', 'connectionManager', 'appRouter', 'globalize', 'userSettings', 'emby-checkbox', 'emby-input', 'paper-icon-button-light', 'emby-select', 'material-icons', 'css!./../formdialog', 'emby-button', 'flexStyles'], function (require, dom, focusManager, dialogHelper, loading, appHost, inputManager, layoutManager, connectionManager, appRouter, globalize, userSettings) { 'use strict'; + layoutManager = layoutManager.default || layoutManager; + function onSubmit(e) { e.preventDefault(); return false; diff --git a/src/components/guide/guide-settings.js b/src/components/guide/guide-settings.js index c3ba49f283..437dd5fcec 100644 --- a/src/components/guide/guide-settings.js +++ b/src/components/guide/guide-settings.js @@ -1,6 +1,8 @@ define(['dialogHelper', 'globalize', 'userSettings', 'layoutManager', 'connectionManager', 'require', 'loading', 'scrollHelper', 'emby-checkbox', 'emby-radio', 'css!./../formdialog', 'material-icons'], function (dialogHelper, globalize, userSettings, layoutManager, connectionManager, require, loading, scrollHelper) { 'use strict'; + layoutManager = layoutManager.default || layoutManager; + function saveCategories(context, options) { var categories = []; diff --git a/src/components/guide/guide.js b/src/components/guide/guide.js index 61caa9188f..6057375ec2 100644 --- a/src/components/guide/guide.js +++ b/src/components/guide/guide.js @@ -4,6 +4,7 @@ define(['require', 'inputManager', 'browser', 'globalize', 'connectionManager', playbackManager = playbackManager.default || playbackManager; browser = browser.default || browser; loading = loading.default || loading; + layoutManager = layoutManager.default || layoutManager; function showViewSettings(instance) { require(['guide-settings-dialog'], function (guideSettingsDialog) { diff --git a/src/components/recordingcreator/recordingcreator.js b/src/components/recordingcreator/recordingcreator.js index ca5c475829..fb452fa8a4 100644 --- a/src/components/recordingcreator/recordingcreator.js +++ b/src/components/recordingcreator/recordingcreator.js @@ -1,6 +1,8 @@ define(['dialogHelper', 'globalize', 'layoutManager', 'mediaInfo', 'apphost', 'connectionManager', 'require', 'loading', 'scrollHelper', 'datetime', 'imageLoader', 'recordingFields', 'events', 'emby-checkbox', 'emby-button', 'emby-collapse', 'emby-input', 'paper-icon-button-light', 'css!./../formdialog', 'css!./recordingcreator', 'material-icons'], function (dialogHelper, globalize, layoutManager, mediaInfo, appHost, connectionManager, require, loading, scrollHelper, datetime, imageLoader, recordingFields, events) { 'use strict'; + layoutManager = layoutManager.default || layoutManager; + var currentDialog; var closeAction; var currentRecordingFields; diff --git a/src/components/recordingcreator/recordingeditor.js b/src/components/recordingcreator/recordingeditor.js index 2086129a9e..2ac8c826e1 100644 --- a/src/components/recordingcreator/recordingeditor.js +++ b/src/components/recordingcreator/recordingeditor.js @@ -2,6 +2,7 @@ define(['dialogHelper', 'globalize', 'layoutManager', 'mediaInfo', 'apphost', 'c 'use strict'; loading = loading.default || loading; + layoutManager = layoutManager.default || layoutManager; var currentDialog; var recordingDeleted = false; diff --git a/src/components/recordingcreator/seriesrecordingeditor.js b/src/components/recordingcreator/seriesrecordingeditor.js index b115e273e6..b5d8eee82b 100644 --- a/src/components/recordingcreator/seriesrecordingeditor.js +++ b/src/components/recordingcreator/seriesrecordingeditor.js @@ -2,6 +2,7 @@ define(['dialogHelper', 'globalize', 'layoutManager', 'mediaInfo', 'apphost', 'c 'use strict'; loading = loading.default || loading; + layoutManager = layoutManager.default || layoutManager; var currentDialog; var recordingUpdated = false; diff --git a/src/components/remotecontrol/remotecontrol.js b/src/components/remotecontrol/remotecontrol.js index b5ac4c9a8b..c6c2a123b4 100644 --- a/src/components/remotecontrol/remotecontrol.js +++ b/src/components/remotecontrol/remotecontrol.js @@ -2,6 +2,7 @@ define(['browser', 'datetime', 'backdrop', 'libraryBrowser', 'listView', 'imageL 'use strict'; playbackManager = playbackManager.default || playbackManager; + layoutManager = layoutManager.default || layoutManager; var showMuteButton = true; var showVolumeSlider = true; diff --git a/src/components/slideshow/slideshow.js b/src/components/slideshow/slideshow.js index 60c458e234..e29a3c8fb9 100644 --- a/src/components/slideshow/slideshow.js +++ b/src/components/slideshow/slideshow.js @@ -6,6 +6,7 @@ define(['dialogHelper', 'inputManager', 'connectionManager', 'layoutManager', 'f 'use strict'; browser = browser.default || browser; + layoutManager = layoutManager.default || layoutManager; /** * Name of transition event. diff --git a/src/components/sortmenu/sortmenu.js b/src/components/sortmenu/sortmenu.js index f62e5bb3a4..56f33001e7 100644 --- a/src/components/sortmenu/sortmenu.js +++ b/src/components/sortmenu/sortmenu.js @@ -1,6 +1,8 @@ define(['require', 'dom', 'focusManager', 'dialogHelper', 'loading', 'layoutManager', 'connectionManager', 'globalize', 'userSettings', 'emby-select', 'paper-icon-button-light', 'material-icons', 'css!./../formdialog', 'emby-button', 'flexStyles'], function (require, dom, focusManager, dialogHelper, loading, layoutManager, connectionManager, globalize, userSettings) { 'use strict'; + layoutManager = layoutManager.default || layoutManager; + function onSubmit(e) { e.preventDefault(); return false; diff --git a/src/components/subtitleeditor/subtitleeditor.js b/src/components/subtitleeditor/subtitleeditor.js index 7df24b5da8..093bbe7a4d 100644 --- a/src/components/subtitleeditor/subtitleeditor.js +++ b/src/components/subtitleeditor/subtitleeditor.js @@ -2,6 +2,7 @@ define(['dialogHelper', 'require', 'layoutManager', 'globalize', 'userSettings', 'use strict'; loading = loading.default || loading; + layoutManager = layoutManager.default || layoutManager; var currentItem; var hasChanges; diff --git a/src/components/subtitlesync/subtitlesync.js b/src/components/subtitlesync/subtitlesync.js index 203d88535f..4433c8d958 100644 --- a/src/components/subtitlesync/subtitlesync.js +++ b/src/components/subtitlesync/subtitlesync.js @@ -2,6 +2,7 @@ define(['playbackManager', 'layoutManager', 'text!./subtitlesync.template.html', 'use strict'; playbackManager = playbackManager.default || playbackManager; + layoutManager = layoutManager.default || layoutManager; var player; var subtitleSyncSlider; diff --git a/src/components/tabbedview/tabbedview.js b/src/components/tabbedview/tabbedview.js index 8bd3afd372..c8c0f232be 100644 --- a/src/components/tabbedview/tabbedview.js +++ b/src/components/tabbedview/tabbedview.js @@ -1,6 +1,8 @@ define(['backdrop', 'mainTabsManager', 'layoutManager', 'emby-tabs'], function (backdrop, mainTabsManager, layoutManager) { 'use strict'; + layoutManager = layoutManager.default || layoutManager; + function onViewDestroy(e) { var tabControllers = this.tabControllers; diff --git a/src/components/tunerPicker.js b/src/components/tunerPicker.js index 5bc9386053..6391a84e3a 100644 --- a/src/components/tunerPicker.js +++ b/src/components/tunerPicker.js @@ -3,6 +3,7 @@ define(['dialogHelper', 'dom', 'layoutManager', 'connectionManager', 'globalize' browser = browser.default || browser; loading = loading.default || loading; + layoutManager = layoutManager.default || layoutManager; var enableFocusTransform = !browser.slow && !browser.edge; diff --git a/src/components/upnextdialog/upnextdialog.js b/src/components/upnextdialog/upnextdialog.js index 5eb2a2ffcc..fdf7c056f5 100644 --- a/src/components/upnextdialog/upnextdialog.js +++ b/src/components/upnextdialog/upnextdialog.js @@ -2,6 +2,7 @@ define(['dom', 'playbackManager', 'connectionManager', 'events', 'mediaInfo', 'l 'use strict'; playbackManager = playbackManager.default || playbackManager; + layoutManager = layoutManager.default || layoutManager; var transitionEndEventName = dom.whichTransitionEvent(); diff --git a/src/components/viewManager/viewManager.js b/src/components/viewManager/viewManager.js index 058ba4ebb2..8c9840fec3 100644 --- a/src/components/viewManager/viewManager.js +++ b/src/components/viewManager/viewManager.js @@ -1,6 +1,8 @@ define(['viewContainer', 'focusManager', 'queryString', 'layoutManager'], function (viewContainer, focusManager, queryString, layoutManager) { 'use strict'; + layoutManager = layoutManager.default || layoutManager; + var currentView; var dispatchPageEvents; diff --git a/src/components/viewSettings/viewSettings.js b/src/components/viewSettings/viewSettings.js index 67abc25a9c..9356f991fc 100644 --- a/src/components/viewSettings/viewSettings.js +++ b/src/components/viewSettings/viewSettings.js @@ -1,6 +1,8 @@ define(['require', 'dialogHelper', 'loading', 'apphost', 'layoutManager', 'connectionManager', 'appRouter', 'globalize', 'userSettings', 'emby-checkbox', 'emby-input', 'paper-icon-button-light', 'emby-select', 'material-icons', 'css!./../formdialog', 'emby-button', 'flexStyles'], function (require, dialogHelper, loading, appHost, layoutManager, connectionManager, appRouter, globalize, userSettings) { 'use strict'; + layoutManager = layoutManager.default || layoutManager; + function onSubmit(e) { e.preventDefault(); return false; diff --git a/src/controllers/list.js b/src/controllers/list.js index 68e81f05dd..3cfa7ce281 100644 --- a/src/controllers/list.js +++ b/src/controllers/list.js @@ -3,6 +3,7 @@ define(['globalize', 'listView', 'layoutManager', 'userSettings', 'focusManager' playbackManager = playbackManager.default || playbackManager; loading = loading.default || loading; + layoutManager = layoutManager.default || layoutManager; function getInitialLiveTvQuery(instance, params) { var query = { diff --git a/src/controllers/livetv/livetvrecordings.js b/src/controllers/livetv/livetvrecordings.js index b0259bc89b..ab92770336 100644 --- a/src/controllers/livetv/livetvrecordings.js +++ b/src/controllers/livetv/livetvrecordings.js @@ -2,6 +2,7 @@ define(['layoutManager', 'loading', 'cardBuilder', 'apphost', 'imageLoader', 'sc 'use strict'; loading = loading.default || loading; + layoutManager = layoutManager.default || layoutManager; function renderRecordings(elem, recordings, cardOptions, scrollX) { if (!elem) { diff --git a/src/controllers/livetv/livetvschedule.js b/src/controllers/livetv/livetvschedule.js index 4427bef5d1..a7c3f56279 100644 --- a/src/controllers/livetv/livetvschedule.js +++ b/src/controllers/livetv/livetvschedule.js @@ -2,6 +2,7 @@ define(['layoutManager', 'cardBuilder', 'apphost', 'imageLoader', 'loading', 'sc 'use strict'; loading = loading.default || loading; + layoutManager = layoutManager.default || layoutManager; function enableScrollX() { return !layoutManager.desktop; diff --git a/src/controllers/livetv/livetvsuggested.js b/src/controllers/livetv/livetvsuggested.js index 79d9aac6e9..b3adc4fa85 100644 --- a/src/controllers/livetv/livetvsuggested.js +++ b/src/controllers/livetv/livetvsuggested.js @@ -2,6 +2,7 @@ define(['layoutManager', 'userSettings', 'inputManager', 'loading', 'globalize', 'use strict'; loading = loading.default || loading; + layoutManager = layoutManager.default || layoutManager; function enableScrollX() { return !layoutManager.desktop; diff --git a/src/controllers/movies/moviegenres.js b/src/controllers/movies/moviegenres.js index 82ab4d4d4b..716b9b94cd 100644 --- a/src/controllers/movies/moviegenres.js +++ b/src/controllers/movies/moviegenres.js @@ -3,6 +3,7 @@ define(['layoutManager', 'loading', 'libraryBrowser', 'cardBuilder', 'lazyLoader loading = loading.default || loading; libraryBrowser = libraryBrowser.default || libraryBrowser; + layoutManager = layoutManager.default || layoutManager; return function (view, params, tabContent) { function getPageData() { diff --git a/src/controllers/movies/movies.js b/src/controllers/movies/movies.js index ade9dc4b89..48f9fa8f5d 100644 --- a/src/controllers/movies/movies.js +++ b/src/controllers/movies/movies.js @@ -3,6 +3,7 @@ define(['loading', 'layoutManager', 'userSettings', 'events', 'libraryBrowser', loading = loading.default || loading; libraryBrowser = libraryBrowser.default || libraryBrowser; + layoutManager = layoutManager.default || layoutManager; return function (view, params, tabContent, options) { function onViewStyleChange() { diff --git a/src/controllers/movies/moviesrecommended.js b/src/controllers/movies/moviesrecommended.js index a633d654cd..1d50f85919 100644 --- a/src/controllers/movies/moviesrecommended.js +++ b/src/controllers/movies/moviesrecommended.js @@ -2,6 +2,7 @@ define(['events', 'layoutManager', 'inputManager', 'userSettings', 'libraryMenu' 'use strict'; playbackManager = playbackManager.default || playbackManager; + layoutManager = layoutManager.default || layoutManager; function enableScrollX() { return !layoutManager.desktop; diff --git a/src/controllers/movies/movietrailers.js b/src/controllers/movies/movietrailers.js index 8d9fe8d090..7dc3b577da 100644 --- a/src/controllers/movies/movietrailers.js +++ b/src/controllers/movies/movietrailers.js @@ -3,6 +3,7 @@ define(['layoutManager', 'loading', 'events', 'libraryBrowser', 'imageLoader', ' loading = loading.default || loading; libraryBrowser = libraryBrowser.default || libraryBrowser; + layoutManager = layoutManager.default || layoutManager; return function (view, params, tabContent) { function getPageData(context) { diff --git a/src/libraries/scroller.js b/src/libraries/scroller.js index c0cb3e557c..9b441da012 100644 --- a/src/libraries/scroller.js +++ b/src/libraries/scroller.js @@ -2,6 +2,7 @@ define(['browser', 'layoutManager', 'dom', 'focusManager', 'ResizeObserver', 'sc 'use strict'; browser = browser.default || browser; + layoutManager = layoutManager.default || layoutManager; /** * Return type of the value. diff --git a/src/scripts/libraryMenu.js b/src/scripts/libraryMenu.js index bbe01276ba..773804f84b 100644 --- a/src/scripts/libraryMenu.js +++ b/src/scripts/libraryMenu.js @@ -3,6 +3,7 @@ define(['dom', 'layoutManager', 'inputManager', 'connectionManager', 'events', ' playbackManager = playbackManager.default || playbackManager; browser = browser.default || browser; + layoutManager = layoutManager.default || layoutManager; function renderHeader() { var html = ''; diff --git a/src/scripts/livetvcomponents.js b/src/scripts/livetvcomponents.js index fd1b48d0eb..2f4e71642c 100644 --- a/src/scripts/livetvcomponents.js +++ b/src/scripts/livetvcomponents.js @@ -1,6 +1,8 @@ define(['layoutManager', 'datetime', 'cardBuilder', 'apphost'], function (layoutManager, datetime, cardBuilder, appHost) { 'use strict'; + layoutManager = layoutManager.default || layoutManager; + function enableScrollX() { return !layoutManager.desktop; } diff --git a/src/scripts/site.js b/src/scripts/site.js index 87402635f5..ab44d03834 100644 --- a/src/scripts/site.js +++ b/src/scripts/site.js @@ -350,6 +350,7 @@ function initClient() { } function getLayoutManager(layoutManager, appHost) { + layoutManager = layoutManager.default || layoutManager; if (appHost.getDefaultLayout) { layoutManager.defaultLayout = appHost.getDefaultLayout(); } From 234a70875df1cc047c5fc546291036ccfb0cb20f Mon Sep 17 00:00:00 2001 From: Cameron Date: Tue, 4 Aug 2020 15:15:59 +0100 Subject: [PATCH 025/301] Remove Missed Required --- src/components/imageDownloader/imageDownloader.js | 2 +- src/components/metadataEditor/metadataEditor.js | 9 ++++----- src/scripts/libraryBrowser.js | 5 ++++- 3 files changed, 9 insertions(+), 7 deletions(-) diff --git a/src/components/imageDownloader/imageDownloader.js b/src/components/imageDownloader/imageDownloader.js index 2be2ef09b2..3a5f2f56ce 100644 --- a/src/components/imageDownloader/imageDownloader.js +++ b/src/components/imageDownloader/imageDownloader.js @@ -317,7 +317,7 @@ import 'cardStyle'; function showEditor(itemId, serverId, itemType) { loading.show(); - require(['text!./imageDownloader.template.html'], function (template) { + import('text!./imageDownloader.template.html').then(({default: template}) => { const apiClient = connectionManager.getApiClient(serverId); currentItemId = itemId; diff --git a/src/components/metadataEditor/metadataEditor.js b/src/components/metadataEditor/metadataEditor.js index be44e86b44..162da8984a 100644 --- a/src/components/metadataEditor/metadataEditor.js +++ b/src/components/metadataEditor/metadataEditor.js @@ -6,7 +6,6 @@ import loading from 'loading'; import focusManager from 'focusManager'; import connectionManager from 'connectionManager'; import globalize from 'globalize'; -import require from 'require'; import shell from 'shell'; import 'emby-checkbox'; import 'emby-input'; @@ -37,7 +36,7 @@ import 'flexStyles'; function submitUpdatedItem(form, item) { function afterContentTypeUpdated() { - require(['toast'], function (toast) { + import('toast').then(({default: toast}) => { toast(globalize.translate('MessageItemSaved')); }); @@ -227,7 +226,7 @@ import 'flexStyles'; } function editPerson(context, person, index) { - require(['personEditor'], function (personEditor) { + import('personEditor').then(({default: personEditor}) => { personEditor.show(person).then(function (updatedPerson) { const isNew = index === -1; @@ -246,14 +245,14 @@ import 'flexStyles'; if (parentId) { reload(context, parentId, item.ServerId); } else { - require(['appRouter'], function (appRouter) { + import('appRouter').then(({default: appRouter}) => { appRouter.goHome(); }); } } function showMoreMenu(context, button, user) { - require(['itemContextMenu'], function (itemContextMenu) { + import('itemContextMenu').then(({default: itemContextMenu}) => { var item = currentItem; itemContextMenu.show({ diff --git a/src/scripts/libraryBrowser.js b/src/scripts/libraryBrowser.js index 46cda51e55..4f2a0fdb47 100644 --- a/src/scripts/libraryBrowser.js +++ b/src/scripts/libraryBrowser.js @@ -119,7 +119,10 @@ export function getQueryPagingHtml (options) { } export function showSortMenu (options) { - require(['dialogHelper', 'emby-radio'], function (dialogHelper) { + Promise.All([ + import('dialogHelper'), + import('emby-radio') + ]).then(({default: dialogHelper}) => { function onSortByChange() { var newValue = this.value; From 9576769924f1e009c1cd669014230543c04fc5ac Mon Sep 17 00:00:00 2001 From: Matjaz Zavski Date: Tue, 4 Aug 2020 18:51:16 +0200 Subject: [PATCH 026/301] Update src/controllers/livetv/livetvsuggested.js Co-authored-by: Julien Machiels --- src/controllers/livetv/livetvsuggested.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/controllers/livetv/livetvsuggested.js b/src/controllers/livetv/livetvsuggested.js index d66f3733b5..0b72799093 100644 --- a/src/controllers/livetv/livetvsuggested.js +++ b/src/controllers/livetv/livetvsuggested.js @@ -351,7 +351,7 @@ export default function (view, params) { }); self.initTab = function () { - const tabContent = view.querySelector('.pageTabContent[data-index=\'0\']'); + const tabContent = view.querySelector('.pageTabContent[data-index="0"]'); const containers = tabContent.querySelectorAll('.itemsContainer'); for (let i = 0, length = containers.length; i < length; i++) { From 19af050453aafcec287ca77038da58a0c759adea Mon Sep 17 00:00:00 2001 From: Matjaz Zavski Date: Tue, 4 Aug 2020 18:51:52 +0200 Subject: [PATCH 027/301] Update src/controllers/livetv/livetvsuggested.js Co-authored-by: Julien Machiels --- src/controllers/livetv/livetvsuggested.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/controllers/livetv/livetvsuggested.js b/src/controllers/livetv/livetvsuggested.js index 0b72799093..1ff5c71d05 100644 --- a/src/controllers/livetv/livetvsuggested.js +++ b/src/controllers/livetv/livetvsuggested.js @@ -273,7 +273,7 @@ export default function (view, params) { let tabContent; if (index === 0) { - tabContent = view.querySelector('.pageTabContent[data-index=\'' + index + '\']'); + tabContent = view.querySelector(`.pageTabContent[data-index="${index}"]`); self.tabContent = tabContent; } From 4b7554c84e899d0eef3375922f6d424926b95461 Mon Sep 17 00:00:00 2001 From: Matjaz Zavski Date: Tue, 4 Aug 2020 18:52:03 +0200 Subject: [PATCH 028/301] Update src/controllers/livetv/livetvsuggested.js Co-authored-by: Julien Machiels --- src/controllers/livetv/livetvsuggested.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/controllers/livetv/livetvsuggested.js b/src/controllers/livetv/livetvsuggested.js index 1ff5c71d05..9dc85466f7 100644 --- a/src/controllers/livetv/livetvsuggested.js +++ b/src/controllers/livetv/livetvsuggested.js @@ -280,7 +280,7 @@ export default function (view, params) { let controller = tabControllers[index]; if (!controller) { - tabContent = view.querySelector('.pageTabContent[data-index=\'' + index + '\']'); + tabContent = view.querySelector('.pageTabContent[data-index="${index}"]'); if (index === 0) { controller = self; From 5e81f4d741eb3d66a405d41439234ae0ef929f3c Mon Sep 17 00:00:00 2001 From: matjaz321 Date: Tue, 4 Aug 2020 18:57:47 +0200 Subject: [PATCH 029/301] CR fix --- src/controllers/livetv/livetvsuggested.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/controllers/livetv/livetvsuggested.js b/src/controllers/livetv/livetvsuggested.js index 9dc85466f7..51ff549dc4 100644 --- a/src/controllers/livetv/livetvsuggested.js +++ b/src/controllers/livetv/livetvsuggested.js @@ -360,7 +360,7 @@ export default function (view, params) { }; self.renderTab = function () { - const tabContent = view.querySelector('.pageTabContent[data-index=\'0\']'); + const tabContent = view.querySelector('.pageTabContent[data-index="0"]'); if (enableFullRender()) { reload(tabContent, true); From 89f0fe8564ceb9996e63534c0fcc0fb74b876517 Mon Sep 17 00:00:00 2001 From: matjaz321 Date: Tue, 4 Aug 2020 19:33:20 +0200 Subject: [PATCH 030/301] Migrates itembynamedetailpage.js to es6 module --- src/scripts/itembynamedetailpage.js | 713 ++++++++++++++-------------- 1 file changed, 359 insertions(+), 354 deletions(-) diff --git a/src/scripts/itembynamedetailpage.js b/src/scripts/itembynamedetailpage.js index eaeecba275..f464f3b9e9 100644 --- a/src/scripts/itembynamedetailpage.js +++ b/src/scripts/itembynamedetailpage.js @@ -1,369 +1,374 @@ -define(['connectionManager', 'listView', 'cardBuilder', 'imageLoader', 'libraryBrowser', 'globalize', 'emby-itemscontainer', 'emby-button'], function (connectionManager, listView, cardBuilder, imageLoader, libraryBrowser, globalize) { - 'use strict'; +import connectionManager from 'connectionManager'; +import listView from 'listView'; +import cardBuilder from 'cardBuilder'; +import imageLoader from 'imageLoader'; +import globalize from 'globalize'; +import 'emby-itemscontainer'; +import 'emby-button'; - function renderItems(page, item) { - var sections = []; +function renderItems(page, item) { + const sections = []; - if (item.ArtistCount) { - sections.push({ - name: globalize.translate('TabArtists'), - type: 'MusicArtist' - }); - } - - if (item.ProgramCount && item.Type == 'Person') { - sections.push({ - name: globalize.translate('HeaderUpcomingOnTV'), - type: 'Program' - }); - } - - if (item.MovieCount) { - sections.push({ - name: globalize.translate('TabMovies'), - type: 'Movie' - }); - } - - if (item.SeriesCount) { - sections.push({ - name: globalize.translate('TabShows'), - type: 'Series' - }); - } - - if (item.EpisodeCount) { - sections.push({ - name: globalize.translate('TabEpisodes'), - type: 'Episode' - }); - } - - if (item.TrailerCount) { - sections.push({ - name: globalize.translate('TabTrailers'), - type: 'Trailer' - }); - } - - if (item.AlbumCount) { - sections.push({ - name: globalize.translate('TabAlbums'), - type: 'MusicAlbum' - }); - } - - if (item.MusicVideoCount) { - sections.push({ - name: globalize.translate('TabMusicVideos'), - type: 'MusicVideo' - }); - } - - var elem = page.querySelector('#childrenContent'); - elem.innerHTML = sections.map(function (section) { - var html = ''; - var sectionClass = 'verticalSection'; - - if (section.type === 'Audio') { - sectionClass += ' verticalSection-extrabottompadding'; - } - - html += ''; - }).join(''); - var sectionElems = elem.querySelectorAll('.verticalSection'); - - for (var i = 0, length = sectionElems.length; i < length; i++) { - renderSection(page, item, sectionElems[i], sectionElems[i].getAttribute('data-type')); - } - } - - function renderSection(page, item, element, type) { - switch (type) { - case 'Program': - loadItems(element, item, type, { - MediaTypes: '', - IncludeItemTypes: 'Program', - PersonTypes: '', - ArtistIds: '', - AlbumArtistIds: '', - Limit: 10, - SortBy: 'StartDate' - }, { - shape: 'overflowBackdrop', - showTitle: true, - centerText: true, - overlayMoreButton: true, - preferThumb: true, - overlayText: false, - showAirTime: true, - showAirDateTime: true, - showChannelName: true - }); - break; - - case 'Movie': - loadItems(element, item, type, { - MediaTypes: '', - IncludeItemTypes: 'Movie', - PersonTypes: '', - ArtistIds: '', - AlbumArtistIds: '', - Limit: 10, - SortBy: 'SortName' - }, { - shape: 'overflowPortrait', - showTitle: true, - centerText: true, - overlayMoreButton: true, - overlayText: false, - showYear: true - }); - break; - - case 'MusicVideo': - loadItems(element, item, type, { - MediaTypes: '', - IncludeItemTypes: 'MusicVideo', - PersonTypes: '', - ArtistIds: '', - AlbumArtistIds: '', - Limit: 10, - SortBy: 'SortName' - }, { - shape: 'overflowPortrait', - showTitle: true, - centerText: true, - overlayPlayButton: true - }); - break; - - case 'Trailer': - loadItems(element, item, type, { - MediaTypes: '', - IncludeItemTypes: 'Trailer', - PersonTypes: '', - ArtistIds: '', - AlbumArtistIds: '', - Limit: 10, - SortBy: 'SortName' - }, { - shape: 'overflowPortrait', - showTitle: true, - centerText: true, - overlayPlayButton: true - }); - break; - - case 'Series': - loadItems(element, item, type, { - MediaTypes: '', - IncludeItemTypes: 'Series', - PersonTypes: '', - ArtistIds: '', - AlbumArtistIds: '', - Limit: 10, - SortBy: 'SortName' - }, { - shape: 'overflowPortrait', - showTitle: true, - centerText: true, - overlayMoreButton: true - }); - break; - - case 'MusicAlbum': - loadItems(element, item, type, { - MediaTypes: '', - IncludeItemTypes: 'MusicAlbum', - PersonTypes: '', - ArtistIds: '', - AlbumArtistIds: '', - SortOrder: 'Descending', - SortBy: 'ProductionYear,Sortname' - }, { - shape: 'overflowSquare', - playFromHere: true, - showTitle: true, - showYear: true, - coverImage: true, - centerText: true, - overlayPlayButton: true - }); - break; - - case 'MusicArtist': - loadItems(element, item, type, { - MediaTypes: '', - IncludeItemTypes: 'MusicArtist', - PersonTypes: '', - ArtistIds: '', - AlbumArtistIds: '', - Limit: 8, - SortBy: 'SortName' - }, { - shape: 'overflowSquare', - playFromHere: true, - showTitle: true, - showParentTitle: true, - coverImage: true, - centerText: true, - overlayPlayButton: true - }); - break; - - case 'Episode': - loadItems(element, item, type, { - MediaTypes: '', - IncludeItemTypes: 'Episode', - PersonTypes: '', - ArtistIds: '', - AlbumArtistIds: '', - Limit: 6, - SortBy: 'SortName' - }, { - shape: 'overflowBackdrop', - showTitle: true, - showParentTitle: true, - centerText: true, - overlayPlayButton: true - }); - break; - - case 'Audio': - loadItems(element, item, type, { - MediaTypes: '', - IncludeItemTypes: 'Audio', - PersonTypes: '', - ArtistIds: '', - AlbumArtistIds: '', - SortBy: 'AlbumArtist,Album,SortName' - }, { - playFromHere: true, - action: 'playallfromhere', - smallIcon: true, - artist: true - }); - } - } - - function loadItems(element, item, type, query, listOptions) { - query = getQuery(query, item); - getItemsFunction(query, item)(query.StartIndex, query.Limit, query.Fields).then(function (result) { - var html = ''; - - if (query.Limit && result.TotalRecordCount > query.Limit) { - var link = element.querySelector('a'); - link.classList.remove('hide'); - link.setAttribute('href', getMoreItemsHref(item, type)); - } else { - element.querySelector('a').classList.add('hide'); - } - - listOptions.items = result.Items; - var itemsContainer = element.querySelector('.itemsContainer'); - - if (type == 'Audio') { - html = listView.getListViewHtml(listOptions); - itemsContainer.classList.remove('vertical-wrap'); - itemsContainer.classList.add('vertical-list'); - } else { - html = cardBuilder.getCardsHtml(listOptions); - itemsContainer.classList.add('vertical-wrap'); - itemsContainer.classList.remove('vertical-list'); - } - - itemsContainer.innerHTML = html; - imageLoader.lazyChildren(itemsContainer); + if (item.ArtistCount) { + sections.push({ + name: globalize.translate('TabArtists'), + type: 'MusicArtist' }); } - function getMoreItemsHref(item, type) { - if (item.Type == 'Genre') { - return 'list.html?type=' + type + '&genreId=' + item.Id + '&serverId=' + item.ServerId; - } - - if (item.Type == 'MusicGenre') { - return 'list.html?type=' + type + '&musicGenreId=' + item.Id + '&serverId=' + item.ServerId; - } - - if (item.Type == 'Studio') { - return 'list.html?type=' + type + '&studioId=' + item.Id + '&serverId=' + item.ServerId; - } - - if (item.Type == 'MusicArtist') { - return 'list.html?type=' + type + '&artistId=' + item.Id + '&serverId=' + item.ServerId; - } - - if (item.Type == 'Person') { - return 'list.html?type=' + type + '&personId=' + item.Id + '&serverId=' + item.ServerId; - } - - return 'list.html?type=' + type + '&parentId=' + item.Id + '&serverId=' + item.ServerId; + if (item.ProgramCount && item.Type === 'Person') { + sections.push({ + name: globalize.translate('HeaderUpcomingOnTV'), + type: 'Program' + }); } - function addCurrentItemToQuery(query, item) { - if (item.Type == 'Person') { - query.PersonIds = item.Id; - } else if (item.Type == 'Genre') { - query.Genres = item.Name; - } else if (item.Type == 'MusicGenre') { - query.Genres = item.Name; - } else if (item.Type == 'GameGenre') { - query.Genres = item.Name; - } else if (item.Type == 'Studio') { - query.StudioIds = item.Id; - } else if (item.Type == 'MusicArtist') { - query.AlbumArtistIds = item.Id; + if (item.MovieCount) { + sections.push({ + name: globalize.translate('TabMovies'), + type: 'Movie' + }); + } + + if (item.SeriesCount) { + sections.push({ + name: globalize.translate('TabShows'), + type: 'Series' + }); + } + + if (item.EpisodeCount) { + sections.push({ + name: globalize.translate('TabEpisodes'), + type: 'Episode' + }); + } + + if (item.TrailerCount) { + sections.push({ + name: globalize.translate('TabTrailers'), + type: 'Trailer' + }); + } + + if (item.AlbumCount) { + sections.push({ + name: globalize.translate('TabAlbums'), + type: 'MusicAlbum' + }); + } + + if (item.MusicVideoCount) { + sections.push({ + name: globalize.translate('TabMusicVideos'), + type: 'MusicVideo' + }); + } + + const elem = page.querySelector('#childrenContent'); + elem.innerHTML = sections.map(function (section) { + let html = ''; + let sectionClass = 'verticalSection'; + + if (section.type === 'Audio') { + sectionClass += ' verticalSection-extrabottompadding'; } + + html += '
'; + html += '
'; + html += '

'; + html += section.name; + html += '

'; + html += ''; + html += '
'; + html += '
'; + html += '
'; + html += '
'; + return html; + }).join(''); + const sectionElems = elem.querySelectorAll('.verticalSection'); + + for (let i = 0, length = sectionElems.length; i < length; i++) { + renderSection(page, item, sectionElems[i], sectionElems[i].getAttribute('data-type')); + } +} + +function renderSection(page, item, element, type) { + switch (type) { + case 'Program': + loadItems(element, item, type, { + MediaTypes: '', + IncludeItemTypes: 'Program', + PersonTypes: '', + ArtistIds: '', + AlbumArtistIds: '', + Limit: 10, + SortBy: 'StartDate' + }, { + shape: 'overflowBackdrop', + showTitle: true, + centerText: true, + overlayMoreButton: true, + preferThumb: true, + overlayText: false, + showAirTime: true, + showAirDateTime: true, + showChannelName: true + }); + break; + + case 'Movie': + loadItems(element, item, type, { + MediaTypes: '', + IncludeItemTypes: 'Movie', + PersonTypes: '', + ArtistIds: '', + AlbumArtistIds: '', + Limit: 10, + SortBy: 'SortName' + }, { + shape: 'overflowPortrait', + showTitle: true, + centerText: true, + overlayMoreButton: true, + overlayText: false, + showYear: true + }); + break; + + case 'MusicVideo': + loadItems(element, item, type, { + MediaTypes: '', + IncludeItemTypes: 'MusicVideo', + PersonTypes: '', + ArtistIds: '', + AlbumArtistIds: '', + Limit: 10, + SortBy: 'SortName' + }, { + shape: 'overflowPortrait', + showTitle: true, + centerText: true, + overlayPlayButton: true + }); + break; + + case 'Trailer': + loadItems(element, item, type, { + MediaTypes: '', + IncludeItemTypes: 'Trailer', + PersonTypes: '', + ArtistIds: '', + AlbumArtistIds: '', + Limit: 10, + SortBy: 'SortName' + }, { + shape: 'overflowPortrait', + showTitle: true, + centerText: true, + overlayPlayButton: true + }); + break; + + case 'Series': + loadItems(element, item, type, { + MediaTypes: '', + IncludeItemTypes: 'Series', + PersonTypes: '', + ArtistIds: '', + AlbumArtistIds: '', + Limit: 10, + SortBy: 'SortName' + }, { + shape: 'overflowPortrait', + showTitle: true, + centerText: true, + overlayMoreButton: true + }); + break; + + case 'MusicAlbum': + loadItems(element, item, type, { + MediaTypes: '', + IncludeItemTypes: 'MusicAlbum', + PersonTypes: '', + ArtistIds: '', + AlbumArtistIds: '', + SortOrder: 'Descending', + SortBy: 'ProductionYear,Sortname' + }, { + shape: 'overflowSquare', + playFromHere: true, + showTitle: true, + showYear: true, + coverImage: true, + centerText: true, + overlayPlayButton: true + }); + break; + + case 'MusicArtist': + loadItems(element, item, type, { + MediaTypes: '', + IncludeItemTypes: 'MusicArtist', + PersonTypes: '', + ArtistIds: '', + AlbumArtistIds: '', + Limit: 8, + SortBy: 'SortName' + }, { + shape: 'overflowSquare', + playFromHere: true, + showTitle: true, + showParentTitle: true, + coverImage: true, + centerText: true, + overlayPlayButton: true + }); + break; + + case 'Episode': + loadItems(element, item, type, { + MediaTypes: '', + IncludeItemTypes: 'Episode', + PersonTypes: '', + ArtistIds: '', + AlbumArtistIds: '', + Limit: 6, + SortBy: 'SortName' + }, { + shape: 'overflowBackdrop', + showTitle: true, + showParentTitle: true, + centerText: true, + overlayPlayButton: true + }); + break; + + case 'Audio': + loadItems(element, item, type, { + MediaTypes: '', + IncludeItemTypes: 'Audio', + PersonTypes: '', + ArtistIds: '', + AlbumArtistIds: '', + SortBy: 'AlbumArtist,Album,SortName' + }, { + playFromHere: true, + action: 'playallfromhere', + smallIcon: true, + artist: true + }); + } +} + +function loadItems(element, item, type, query, listOptions) { + query = getQuery(query, item); + getItemsFunction(query, item)(query.StartIndex, query.Limit, query.Fields).then(function (result) { + let html = ''; + + if (query.Limit && result.TotalRecordCount > query.Limit) { + const link = element.querySelector('a'); + link.classList.remove('hide'); + link.setAttribute('href', getMoreItemsHref(item, type)); + } else { + element.querySelector('a').classList.add('hide'); + } + + listOptions.items = result.Items; + const itemsContainer = element.querySelector('.itemsContainer'); + + if (type === 'Audio') { + html = listView.getListViewHtml(listOptions); + itemsContainer.classList.remove('vertical-wrap'); + itemsContainer.classList.add('vertical-list'); + } else { + html = cardBuilder.getCardsHtml(listOptions); + itemsContainer.classList.add('vertical-wrap'); + itemsContainer.classList.remove('vertical-list'); + } + + itemsContainer.innerHTML = html; + imageLoader.lazyChildren(itemsContainer); + }); +} + +function getMoreItemsHref(item, type) { + if (item.Type === 'Genre') { + return 'list.html?type=' + type + '&genreId=' + item.Id + '&serverId=' + item.ServerId; } - function getQuery(options, item) { - var query = { - SortOrder: 'Ascending', - IncludeItemTypes: '', - Recursive: true, - Fields: 'AudioInfo,SeriesInfo,ParentId,PrimaryImageAspectRatio,BasicSyncInfo', - Limit: 100, - StartIndex: 0, - CollapseBoxSetItems: false - }; - query = Object.assign(query, options || {}); - addCurrentItemToQuery(query, item); - return query; + if (item.Type === 'MusicGenre') { + return 'list.html?type=' + type + '&musicGenreId=' + item.Id + '&serverId=' + item.ServerId; } - function getItemsFunction(options, item) { - var query = getQuery(options, item); - return function (index, limit, fields) { - query.StartIndex = index; - query.Limit = limit; - - if (fields) { - query.Fields += ',' + fields; - } - - var apiClient = connectionManager.getApiClient(item.ServerId); - - if (query.IncludeItemTypes === 'MusicArtist') { - query.IncludeItemTypes = null; - return apiClient.getAlbumArtists(apiClient.getCurrentUserId(), query); - } - - return apiClient.getItems(apiClient.getCurrentUserId(), query); - }; + if (item.Type === 'Studio') { + return 'list.html?type=' + type + '&studioId=' + item.Id + '&serverId=' + item.ServerId; } - window.ItemsByName = { - renderItems: renderItems + if (item.Type === 'MusicArtist') { + return 'list.html?type=' + type + '&artistId=' + item.Id + '&serverId=' + item.ServerId; + } + + if (item.Type === 'Person') { + return 'list.html?type=' + type + '&personId=' + item.Id + '&serverId=' + item.ServerId; + } + + return 'list.html?type=' + type + '&parentId=' + item.Id + '&serverId=' + item.ServerId; +} + +function addCurrentItemToQuery(query, item) { + if (item.Type === 'Person') { + query.PersonIds = item.Id; + } else if (item.Type === 'Genre') { + query.Genres = item.Name; + } else if (item.Type === 'MusicGenre') { + query.Genres = item.Name; + } else if (item.Type === 'GameGenre') { + query.Genres = item.Name; + } else if (item.Type === 'Studio') { + query.StudioIds = item.Id; + } else if (item.Type === 'MusicArtist') { + query.AlbumArtistIds = item.Id; + } +} + +function getQuery(options, item) { + let query = { + SortOrder: 'Ascending', + IncludeItemTypes: '', + Recursive: true, + Fields: 'AudioInfo,SeriesInfo,ParentId,PrimaryImageAspectRatio,BasicSyncInfo', + Limit: 100, + StartIndex: 0, + CollapseBoxSetItems: false }; -}); + query = Object.assign(query, options || {}); + addCurrentItemToQuery(query, item); + return query; +} + +function getItemsFunction(options, item) { + const query = getQuery(options, item); + return function (index, limit, fields) { + query.StartIndex = index; + query.Limit = limit; + + if (fields) { + query.Fields += ',' + fields; + } + + const apiClient = connectionManager.getApiClient(item.ServerId); + + if (query.IncludeItemTypes === 'MusicArtist') { + query.IncludeItemTypes = null; + return apiClient.getAlbumArtists(apiClient.getCurrentUserId(), query); + } + + return apiClient.getItems(apiClient.getCurrentUserId(), query); + }; +} + +window.ItemsByName = { + renderItems: renderItems +}; From f9c2a666237f967f9ff0a0d5e8852fb700fed426 Mon Sep 17 00:00:00 2001 From: matjaz321 Date: Tue, 4 Aug 2020 19:33:20 +0200 Subject: [PATCH 031/301] Migrates itembynamedetailpage.js to es6 module From 8e17d603a87dc7581334b362c6c5c54048e542e2 Mon Sep 17 00:00:00 2001 From: Cameron Date: Tue, 4 Aug 2020 21:43:24 +0100 Subject: [PATCH 032/301] Update list.js --- src/controllers/list.js | 6 ++---- 1 file changed, 2 insertions(+), 4 deletions(-) diff --git a/src/controllers/list.js b/src/controllers/list.js index b9237887d0..7d35bcf5cb 100644 --- a/src/controllers/list.js +++ b/src/controllers/list.js @@ -722,11 +722,9 @@ class ItemsView { this.itemsContainer.setAttribute('data-refreshinterval', '300000'); } - let i; - let length; const btnViewSettings = view.querySelectorAll('.btnViewSettings'); - for (i = 0, length = btnViewSettings.length; i < length; i++) { + for (let i = 0, length = btnViewSettings.length; i < length; i++) { btnViewSettings[i].addEventListener('click', showViewSettingsMenu.bind(this)); } @@ -734,7 +732,7 @@ class ItemsView { this.filterButtons = filterButtons; const hasVisibleFilters = this.getVisibleFilters().length; - for (i = 0, length = filterButtons.length; i < length; i++) { + for (let i = 0, length = filterButtons.length; i < length; i++) { const btnFilter = filterButtons[i]; btnFilter.addEventListener('click', showFilterMenu.bind(this)); From fbb98bdd2f8adab4451793c998d543c4c03ba378 Mon Sep 17 00:00:00 2001 From: Cameron Date: Wed, 5 Aug 2020 09:00:24 +0100 Subject: [PATCH 033/301] Migration of guide and guide-settings to ES6 modules --- package.json | 2 + src/components/guide/guide-settings.js | 250 +-- src/components/guide/guide.js | 2306 ++++++++++++------------ src/controllers/livetv/livetvguide.js | 2 +- 4 files changed, 1294 insertions(+), 1266 deletions(-) diff --git a/package.json b/package.json index 5ad12d2011..ad9b19d242 100644 --- a/package.json +++ b/package.json @@ -111,6 +111,8 @@ "src/components/fetchhelper.js", "src/components/filterdialog/filterdialog.js", "src/components/groupedcards.js", + "src/components/guide/guide.js", + "src/components/guide/guide-settings.js", "src/components/homeScreenSettings/homeScreenSettings.js", "src/components/homesections/homesections.js", "src/components/htmlMediaHelper.js", diff --git a/src/components/guide/guide-settings.js b/src/components/guide/guide-settings.js index c3ba49f283..b62604ab98 100644 --- a/src/components/guide/guide-settings.js +++ b/src/components/guide/guide-settings.js @@ -1,147 +1,153 @@ -define(['dialogHelper', 'globalize', 'userSettings', 'layoutManager', 'connectionManager', 'require', 'loading', 'scrollHelper', 'emby-checkbox', 'emby-radio', 'css!./../formdialog', 'material-icons'], function (dialogHelper, globalize, userSettings, layoutManager, connectionManager, require, loading, scrollHelper) { - 'use strict'; +import dialogHelper from 'dialogHelper'; +import globalize from 'globalize'; +import * as userSettings from 'userSettings'; +import layoutManager from 'layoutManager'; +import scrollHelper from 'scrollHelper'; +import 'emby-checkbox'; +import 'emby-radio'; +import 'css!./../formdialog'; +import 'material-icons'; - function saveCategories(context, options) { - var categories = []; +function saveCategories(context, options) { + const categories = []; - var chkCategorys = context.querySelectorAll('.chkCategory'); - for (var i = 0, length = chkCategorys.length; i < length; i++) { - var type = chkCategorys[i].getAttribute('data-type'); + const chkCategorys = context.querySelectorAll('.chkCategory'); + for (let i = 0, length = chkCategorys.length; i < length; i++) { + const type = chkCategorys[i].getAttribute('data-type'); - if (chkCategorys[i].checked) { - categories.push(type); - } - } - - if (categories.length >= 4) { - categories.push('series'); - } - - // differentiate between none and all - categories.push('all'); - options.categories = categories; - } - - function loadCategories(context, options) { - var selectedCategories = options.categories || []; - - var chkCategorys = context.querySelectorAll('.chkCategory'); - for (var i = 0, length = chkCategorys.length; i < length; i++) { - var type = chkCategorys[i].getAttribute('data-type'); - - chkCategorys[i].checked = !selectedCategories.length || selectedCategories.indexOf(type) !== -1; + if (chkCategorys[i].checked) { + categories.push(type); } } - function save(context) { - var i; - var length; + if (categories.length >= 4) { + categories.push('series'); + } - var chkIndicators = context.querySelectorAll('.chkIndicator'); - for (i = 0, length = chkIndicators.length; i < length; i++) { - var type = chkIndicators[i].getAttribute('data-type'); - userSettings.set('guide-indicator-' + type, chkIndicators[i].checked); + // differentiate between none and all + categories.push('all'); + options.categories = categories; +} + +function loadCategories(context, options) { + const selectedCategories = options.categories || []; + + const chkCategorys = context.querySelectorAll('.chkCategory'); + for (let i = 0, length = chkCategorys.length; i < length; i++) { + const type = chkCategorys[i].getAttribute('data-type'); + + chkCategorys[i].checked = !selectedCategories.length || selectedCategories.indexOf(type) !== -1; + } +} + +function save(context) { + let i; + let length; + + const chkIndicators = context.querySelectorAll('.chkIndicator'); + for (i = 0, length = chkIndicators.length; i < length; i++) { + const type = chkIndicators[i].getAttribute('data-type'); + userSettings.set('guide-indicator-' + type, chkIndicators[i].checked); + } + + userSettings.set('guide-colorcodedbackgrounds', context.querySelector('.chkColorCodedBackgrounds').checked); + userSettings.set('livetv-favoritechannelsattop', context.querySelector('.chkFavoriteChannelsAtTop').checked); + + const sortBys = context.querySelectorAll('.chkSortOrder'); + for (i = 0, length = sortBys.length; i < length; i++) { + if (sortBys[i].checked) { + userSettings.set('livetv-channelorder', sortBys[i].value); + break; } + } +} - userSettings.set('guide-colorcodedbackgrounds', context.querySelector('.chkColorCodedBackgrounds').checked); - userSettings.set('livetv-favoritechannelsattop', context.querySelector('.chkFavoriteChannelsAtTop').checked); +function load(context) { + let i; + let length; - var sortBys = context.querySelectorAll('.chkSortOrder'); - for (i = 0, length = sortBys.length; i < length; i++) { - if (sortBys[i].checked) { - userSettings.set('livetv-channelorder', sortBys[i].value); - break; - } + const chkIndicators = context.querySelectorAll('.chkIndicator'); + for (i = 0, length = chkIndicators.length; i < length; i++) { + const type = chkIndicators[i].getAttribute('data-type'); + + if (chkIndicators[i].getAttribute('data-default') === 'true') { + chkIndicators[i].checked = userSettings.get('guide-indicator-' + type) !== 'false'; + } else { + chkIndicators[i].checked = userSettings.get('guide-indicator-' + type) === 'true'; } } - function load(context) { - var i; - var length; + context.querySelector('.chkColorCodedBackgrounds').checked = userSettings.get('guide-colorcodedbackgrounds') === 'true'; + context.querySelector('.chkFavoriteChannelsAtTop').checked = userSettings.get('livetv-favoritechannelsattop') !== 'false'; - var chkIndicators = context.querySelectorAll('.chkIndicator'); - for (i = 0, length = chkIndicators.length; i < length; i++) { - var type = chkIndicators[i].getAttribute('data-type'); + const sortByValue = userSettings.get('livetv-channelorder') || 'Number'; - if (chkIndicators[i].getAttribute('data-default') === 'true') { - chkIndicators[i].checked = userSettings.get('guide-indicator-' + type) !== 'false'; + const sortBys = context.querySelectorAll('.chkSortOrder'); + for (i = 0, length = sortBys.length; i < length; i++) { + sortBys[i].checked = sortBys[i].value === sortByValue; + } +} + +function showEditor(options) { + return new Promise(function (resolve, reject) { + let settingsChanged = false; + + import('text!./guide-settings.template.html').then(({default: template}) => { + const dialogOptions = { + removeOnClose: true, + scrollY: false + }; + + if (layoutManager.tv) { + dialogOptions.size = 'fullscreen'; } else { - chkIndicators[i].checked = userSettings.get('guide-indicator-' + type) === 'true'; + dialogOptions.size = 'small'; } - } - context.querySelector('.chkColorCodedBackgrounds').checked = userSettings.get('guide-colorcodedbackgrounds') === 'true'; - context.querySelector('.chkFavoriteChannelsAtTop').checked = userSettings.get('livetv-favoritechannelsattop') !== 'false'; + const dlg = dialogHelper.createDialog(dialogOptions); - var sortByValue = userSettings.get('livetv-channelorder') || 'Number'; + dlg.classList.add('formDialog'); - var sortBys = context.querySelectorAll('.chkSortOrder'); - for (i = 0, length = sortBys.length; i < length; i++) { - sortBys[i].checked = sortBys[i].value === sortByValue; - } - } + let html = ''; - function showEditor(options) { - return new Promise(function (resolve, reject) { - var settingsChanged = false; + html += globalize.translateHtml(template, 'core'); - require(['text!./guide-settings.template.html'], function (template) { - var dialogOptions = { - removeOnClose: true, - scrollY: false - }; + dlg.innerHTML = html; - if (layoutManager.tv) { - dialogOptions.size = 'fullscreen'; - } else { - dialogOptions.size = 'small'; - } - - var dlg = dialogHelper.createDialog(dialogOptions); - - dlg.classList.add('formDialog'); - - var html = ''; - - html += globalize.translateHtml(template, 'core'); - - dlg.innerHTML = html; - - dlg.addEventListener('change', function () { - settingsChanged = true; - }); - - dlg.addEventListener('close', function () { - if (layoutManager.tv) { - scrollHelper.centerFocus.off(dlg.querySelector('.formDialogContent'), false); - } - - save(dlg); - saveCategories(dlg, options); - - if (settingsChanged) { - resolve(); - } else { - reject(); - } - }); - - dlg.querySelector('.btnCancel').addEventListener('click', function () { - dialogHelper.close(dlg); - }); - - if (layoutManager.tv) { - scrollHelper.centerFocus.on(dlg.querySelector('.formDialogContent'), false); - } - - load(dlg); - loadCategories(dlg, options); - dialogHelper.open(dlg); + dlg.addEventListener('change', function () { + settingsChanged = true; }); - }); - } - return { - show: showEditor - }; -}); + dlg.addEventListener('close', function () { + if (layoutManager.tv) { + scrollHelper.centerFocus.off(dlg.querySelector('.formDialogContent'), false); + } + + save(dlg); + saveCategories(dlg, options); + + if (settingsChanged) { + resolve(); + } else { + reject(); + } + }); + + dlg.querySelector('.btnCancel').addEventListener('click', function () { + dialogHelper.close(dlg); + }); + + if (layoutManager.tv) { + scrollHelper.centerFocus.on(dlg.querySelector('.formDialogContent'), false); + } + + load(dlg); + loadCategories(dlg, options); + dialogHelper.open(dlg); + }); + }); +} + +export default { + show: showEditor +}; diff --git a/src/components/guide/guide.js b/src/components/guide/guide.js index 61caa9188f..e48d4646c0 100644 --- a/src/components/guide/guide.js +++ b/src/components/guide/guide.js @@ -1,1178 +1,1198 @@ -define(['require', 'inputManager', 'browser', 'globalize', 'connectionManager', 'scrollHelper', 'serverNotifications', 'loading', 'datetime', 'focusManager', 'playbackManager', 'userSettings', 'imageLoader', 'events', 'layoutManager', 'itemShortcuts', 'dom', 'css!./guide.css', 'programStyles', 'material-icons', 'scrollStyles', 'emby-programcell', 'emby-button', 'paper-icon-button-light', 'emby-tabs', 'emby-scroller', 'flexStyles', 'webcomponents'], function (require, inputManager, browser, globalize, connectionManager, scrollHelper, serverNotifications, loading, datetime, focusManager, playbackManager, userSettings, imageLoader, events, layoutManager, itemShortcuts, dom) { - 'use strict'; +import inputManager from 'inputManager'; +import browser from 'browser'; +import globalize from 'globalize'; +import connectionManager from 'connectionManager'; +import scrollHelper from 'scrollHelper'; +import serverNotifications from 'serverNotifications'; +import loading from 'loading'; +import datetime from 'datetime'; +import focusManager from 'focusManager'; +import playbackManager from 'playbackManager'; +import * as userSettings from 'userSettings'; +import imageLoader from 'imageLoader'; +import events from 'events'; +import layoutManager from 'layoutManager'; +import itemShortcuts from 'itemShortcuts'; +import dom from 'dom'; +import 'css!./guide.css'; +import 'programStyles'; +import 'material-icons'; +import 'scrollStyles'; +import 'emby-programcell'; +import 'emby-button'; +import 'paper-icon-button-light'; +import 'emby-tabs'; +import 'emby-scroller'; +import 'flexStyles'; +import 'webcomponents'; - playbackManager = playbackManager.default || playbackManager; - browser = browser.default || browser; - loading = loading.default || loading; - - function showViewSettings(instance) { - require(['guide-settings-dialog'], function (guideSettingsDialog) { - guideSettingsDialog.show(instance.categoryOptions).then(function () { - instance.refresh(); - }); +function showViewSettings(instance) { + import('guide-settings-dialog').then(({default: guideSettingsDialog}) => { + guideSettingsDialog.show(instance.categoryOptions).then(function () { + instance.refresh(); }); + }); +} + +function updateProgramCellOnScroll(cell, scrollPct) { + let left = cell.posLeft; + if (!left) { + left = parseFloat(cell.style.left.replace('%', '')); + cell.posLeft = left; + } + let width = cell.posWidth; + if (!width) { + width = parseFloat(cell.style.width.replace('%', '')); + cell.posWidth = width; } - function updateProgramCellOnScroll(cell, scrollPct) { - var left = cell.posLeft; - if (!left) { - left = parseFloat(cell.style.left.replace('%', '')); - cell.posLeft = left; - } - var width = cell.posWidth; - if (!width) { - width = parseFloat(cell.style.width.replace('%', '')); - cell.posWidth = width; - } + const right = left + width; + const newPct = Math.max(Math.min(scrollPct, right), left); - var right = left + width; - var newPct = Math.max(Math.min(scrollPct, right), left); + const offset = newPct - left; + const pctOfWidth = (offset / width) * 100; - var offset = newPct - left; - var pctOfWidth = (offset / width) * 100; - - var guideProgramName = cell.guideProgramName; - if (!guideProgramName) { - guideProgramName = cell.querySelector('.guideProgramName'); - cell.guideProgramName = guideProgramName; - } - - var caret = cell.caret; - if (!caret) { - caret = cell.querySelector('.guide-programNameCaret'); - cell.caret = caret; - } - - if (guideProgramName) { - if (pctOfWidth > 0 && pctOfWidth <= 100) { - guideProgramName.style.transform = 'translateX(' + pctOfWidth + '%)'; - caret.classList.remove('hide'); - } else { - guideProgramName.style.transform = 'none'; - caret.classList.add('hide'); - } - } + let guideProgramName = cell.guideProgramName; + if (!guideProgramName) { + guideProgramName = cell.querySelector('.guideProgramName'); + cell.guideProgramName = guideProgramName; } - var isUpdatingProgramCellScroll = false; - function updateProgramCellsOnScroll(programGrid, programCells) { - if (isUpdatingProgramCellScroll) { - return; - } - - isUpdatingProgramCellScroll = true; - - requestAnimationFrame(function () { - var scrollLeft = programGrid.scrollLeft; - - var scrollPct = scrollLeft ? (scrollLeft / programGrid.scrollWidth) * 100 : 0; - - for (var i = 0, length = programCells.length; i < length; i++) { - updateProgramCellOnScroll(programCells[i], scrollPct); - } - - isUpdatingProgramCellScroll = false; - }); + let caret = cell.caret; + if (!caret) { + caret = cell.querySelector('.guide-programNameCaret'); + cell.caret = caret; } - function onProgramGridClick(e) { - if (!layoutManager.tv) { - return; - } - - var programCell = dom.parentWithClass(e.target, 'programCell'); - if (programCell) { - var startDate = programCell.getAttribute('data-startdate'); - var endDate = programCell.getAttribute('data-enddate'); - startDate = datetime.parseISO8601Date(startDate, { toLocal: true }).getTime(); - endDate = datetime.parseISO8601Date(endDate, { toLocal: true }).getTime(); - - var now = new Date().getTime(); - if (now >= startDate && now < endDate) { - var channelId = programCell.getAttribute('data-channelid'); - var serverId = programCell.getAttribute('data-serverid'); - - e.preventDefault(); - e.stopPropagation(); - - playbackManager.play({ - ids: [channelId], - serverId: serverId - }); - } + if (guideProgramName) { + if (pctOfWidth > 0 && pctOfWidth <= 100) { + guideProgramName.style.transform = 'translateX(' + pctOfWidth + '%)'; + caret.classList.remove('hide'); + } else { + guideProgramName.style.transform = 'none'; + caret.classList.add('hide'); } } +} - function Guide(options) { - var self = this; - var items = {}; +let isUpdatingProgramCellScroll = false; +function updateProgramCellsOnScroll(programGrid, programCells) { + if (isUpdatingProgramCellScroll) { + return; + } - self.options = options; - self.categoryOptions = { categories: [] }; + isUpdatingProgramCellScroll = true; - // 30 mins - var cellCurationMinutes = 30; - var cellDurationMs = cellCurationMinutes * 60 * 1000; - var msPerDay = 86400000; + requestAnimationFrame(function () { + const scrollLeft = programGrid.scrollLeft; - var currentDate; - var currentStartIndex = 0; - var currentChannelLimit = 0; - var autoRefreshInterval; - var programCells; - var lastFocusDirection; - var programGrid; + const scrollPct = scrollLeft ? (scrollLeft / programGrid.scrollWidth) * 100 : 0; - self.refresh = function () { - currentDate = null; - reloadPage(options.element); - restartAutoRefresh(); - }; - - self.pause = function () { - stopAutoRefresh(); - }; - - self.resume = function (refreshData) { - if (refreshData) { - self.refresh(); - } else { - restartAutoRefresh(); - } - }; - - self.destroy = function () { - stopAutoRefresh(); - - events.off(serverNotifications, 'TimerCreated', onTimerCreated); - events.off(serverNotifications, 'SeriesTimerCreated', onSeriesTimerCreated); - events.off(serverNotifications, 'TimerCancelled', onTimerCancelled); - events.off(serverNotifications, 'SeriesTimerCancelled', onSeriesTimerCancelled); - - setScrollEvents(options.element, false); - itemShortcuts.off(options.element); - items = {}; - }; - - function restartAutoRefresh() { - stopAutoRefresh(); - - var intervalMs = 60000 * 15; // (minutes) - - autoRefreshInterval = setInterval(function () { - self.refresh(); - }, intervalMs); + for (let i = 0, length = programCells.length; i < length; i++) { + updateProgramCellOnScroll(programCells[i], scrollPct); } - function stopAutoRefresh() { - if (autoRefreshInterval) { - clearInterval(autoRefreshInterval); - autoRefreshInterval = null; - } - } - - function normalizeDateToTimeslot(date) { - var minutesOffset = date.getMinutes() - cellCurationMinutes; - - if (minutesOffset >= 0) { - date.setHours(date.getHours(), cellCurationMinutes, 0, 0); - } else { - date.setHours(date.getHours(), 0, 0, 0); - } - - return date; - } - - function showLoading() { - loading.show(); - } - - function hideLoading() { - loading.hide(); - } - - function reloadGuide(context, newStartDate, scrollToTimeMs, focusToTimeMs, startTimeOfDayMs, focusProgramOnRender) { - var apiClient = connectionManager.getApiClient(options.serverId); - - var channelQuery = { - - StartIndex: 0, - EnableFavoriteSorting: userSettings.get('livetv-favoritechannelsattop') !== 'false' - }; - - channelQuery.UserId = apiClient.getCurrentUserId(); - - var channelLimit = 500; - currentChannelLimit = channelLimit; - - showLoading(); - - channelQuery.StartIndex = currentStartIndex; - channelQuery.Limit = channelLimit; - channelQuery.AddCurrentProgram = false; - channelQuery.EnableUserData = false; - channelQuery.EnableImageTypes = 'Primary'; - - var categories = self.categoryOptions.categories || []; - var displayMovieContent = !categories.length || categories.indexOf('movies') !== -1; - var displaySportsContent = !categories.length || categories.indexOf('sports') !== -1; - var displayNewsContent = !categories.length || categories.indexOf('news') !== -1; - var displayKidsContent = !categories.length || categories.indexOf('kids') !== -1; - var displaySeriesContent = !categories.length || categories.indexOf('series') !== -1; - - if (displayMovieContent && displaySportsContent && displayNewsContent && displayKidsContent) { - channelQuery.IsMovie = null; - channelQuery.IsSports = null; - channelQuery.IsKids = null; - channelQuery.IsNews = null; - channelQuery.IsSeries = null; - } else { - if (displayNewsContent) { - channelQuery.IsNews = true; - } - if (displaySportsContent) { - channelQuery.IsSports = true; - } - if (displayKidsContent) { - channelQuery.IsKids = true; - } - if (displayMovieContent) { - channelQuery.IsMovie = true; - } - if (displaySeriesContent) { - channelQuery.IsSeries = true; - } - } - - if (userSettings.get('livetv-channelorder') === 'DatePlayed') { - channelQuery.SortBy = 'DatePlayed'; - channelQuery.SortOrder = 'Descending'; - } else { - channelQuery.SortBy = null; - channelQuery.SortOrder = null; - } - - var date = newStartDate; - // Add one second to avoid getting programs that are just ending - date = new Date(date.getTime() + 1000); - - // Subtract to avoid getting programs that are starting when the grid ends - var nextDay = new Date(date.getTime() + msPerDay - 2000); - - // Normally we'd want to just let responsive css handle this, - // but since mobile browsers are often underpowered, - // it can help performance to get them out of the markup - var allowIndicators = dom.getWindowSize().innerWidth >= 600; - - var renderOptions = { - showHdIcon: allowIndicators && userSettings.get('guide-indicator-hd') === 'true', - showLiveIndicator: allowIndicators && userSettings.get('guide-indicator-live') !== 'false', - showPremiereIndicator: allowIndicators && userSettings.get('guide-indicator-premiere') !== 'false', - showNewIndicator: allowIndicators && userSettings.get('guide-indicator-new') !== 'false', - showRepeatIndicator: allowIndicators && userSettings.get('guide-indicator-repeat') === 'true', - showEpisodeTitle: layoutManager.tv ? false : true - }; - - apiClient.getLiveTvChannels(channelQuery).then(function (channelsResult) { - var btnPreviousPage = context.querySelector('.btnPreviousPage'); - var btnNextPage = context.querySelector('.btnNextPage'); - - if (channelsResult.TotalRecordCount > channelLimit) { - context.querySelector('.guideOptions').classList.remove('hide'); - - btnPreviousPage.classList.remove('hide'); - btnNextPage.classList.remove('hide'); - - if (channelQuery.StartIndex) { - context.querySelector('.btnPreviousPage').disabled = false; - } else { - context.querySelector('.btnPreviousPage').disabled = true; - } - - if ((channelQuery.StartIndex + channelLimit) < channelsResult.TotalRecordCount) { - btnNextPage.disabled = false; - } else { - btnNextPage.disabled = true; - } - } else { - context.querySelector('.guideOptions').classList.add('hide'); - } - - var programFields = []; - - var programQuery = { - UserId: apiClient.getCurrentUserId(), - MaxStartDate: nextDay.toISOString(), - MinEndDate: date.toISOString(), - channelIds: channelsResult.Items.map(function (c) { - return c.Id; - }).join(','), - ImageTypeLimit: 1, - EnableImages: false, - //EnableImageTypes: layoutManager.tv ? "Primary,Backdrop" : "Primary", - SortBy: 'StartDate', - EnableTotalRecordCount: false, - EnableUserData: false - }; - - if (renderOptions.showHdIcon) { - programFields.push('IsHD'); - } - - if (programFields.length) { - programQuery.Fields = programFields.join(''); - } - - apiClient.getLiveTvPrograms(programQuery).then(function (programsResult) { - renderGuide(context, date, channelsResult.Items, programsResult.Items, renderOptions, apiClient, scrollToTimeMs, focusToTimeMs, startTimeOfDayMs, focusProgramOnRender); - - hideLoading(); - }); - }); - } - - function getDisplayTime(date) { - if ((typeof date).toString().toLowerCase() === 'string') { - try { - date = datetime.parseISO8601Date(date, { toLocal: true }); - } catch (err) { - return date; - } - } - - return datetime.getDisplayTime(date).toLowerCase(); - } - - function getTimeslotHeadersHtml(startDate, endDateTime) { - var html = ''; - - // clone - startDate = new Date(startDate.getTime()); - - html += '
'; - - while (startDate.getTime() < endDateTime) { - html += '
'; - - html += getDisplayTime(startDate); - html += '
'; - - // Add 30 mins - startDate.setTime(startDate.getTime() + cellDurationMs); - } - - return html; - } - - function parseDates(program) { - if (!program.StartDateLocal) { - try { - program.StartDateLocal = datetime.parseISO8601Date(program.StartDate, { toLocal: true }); - } catch (err) { - console.error('error parsing timestamp for start date'); - } - } - - if (!program.EndDateLocal) { - try { - program.EndDateLocal = datetime.parseISO8601Date(program.EndDate, { toLocal: true }); - } catch (err) { - console.error('error parsing timestamp for end date'); - } - } - - return null; - } - - function getTimerIndicator(item) { - var status; - - if (item.Type === 'SeriesTimer') { - return ''; - } else if (item.TimerId || item.SeriesTimerId) { - status = item.Status || 'Cancelled'; - } else if (item.Type === 'Timer') { - status = item.Status; - } else { - return ''; - } - - if (item.SeriesTimerId) { - if (status !== 'Cancelled') { - return ''; - } - - return ''; - } - - return ''; - } - - function getChannelProgramsHtml(context, date, channel, programs, options, listInfo) { - var html = ''; - - var startMs = date.getTime(); - var endMs = startMs + msPerDay - 1; - - var outerCssClass = layoutManager.tv ? 'channelPrograms channelPrograms-tv' : 'channelPrograms'; - - html += '
'; - - var clickAction = layoutManager.tv ? 'link' : 'programdialog'; - - var categories = self.categoryOptions.categories || []; - var displayMovieContent = !categories.length || categories.indexOf('movies') !== -1; - var displaySportsContent = !categories.length || categories.indexOf('sports') !== -1; - var displayNewsContent = !categories.length || categories.indexOf('news') !== -1; - var displayKidsContent = !categories.length || categories.indexOf('kids') !== -1; - var displaySeriesContent = !categories.length || categories.indexOf('series') !== -1; - var enableColorCodedBackgrounds = userSettings.get('guide-colorcodedbackgrounds') === 'true'; - - var programsFound; - var now = new Date().getTime(); - - for (var i = listInfo.startIndex, length = programs.length; i < length; i++) { - var program = programs[i]; - - if (program.ChannelId !== channel.Id) { - if (programsFound) { - break; - } - - continue; - } - - programsFound = true; - listInfo.startIndex++; - - parseDates(program); - - var startDateLocalMs = program.StartDateLocal.getTime(); - var endDateLocalMs = program.EndDateLocal.getTime(); - - if (endDateLocalMs < startMs) { - continue; - } - - if (startDateLocalMs > endMs) { - break; - } - - items[program.Id] = program; - - var renderStartMs = Math.max(startDateLocalMs, startMs); - var startPercent = (startDateLocalMs - startMs) / msPerDay; - startPercent *= 100; - startPercent = Math.max(startPercent, 0); - - var renderEndMs = Math.min(endDateLocalMs, endMs); - var endPercent = (renderEndMs - renderStartMs) / msPerDay; - endPercent *= 100; - - var cssClass = 'programCell itemAction'; - var accentCssClass = null; - var displayInnerContent = true; - - if (program.IsKids) { - displayInnerContent = displayKidsContent; - accentCssClass = 'kids'; - } else if (program.IsSports) { - displayInnerContent = displaySportsContent; - accentCssClass = 'sports'; - } else if (program.IsNews) { - displayInnerContent = displayNewsContent; - accentCssClass = 'news'; - } else if (program.IsMovie) { - displayInnerContent = displayMovieContent; - accentCssClass = 'movie'; - } else if (program.IsSeries) { - displayInnerContent = displaySeriesContent; - } else { - displayInnerContent = displayMovieContent && displayNewsContent && displaySportsContent && displayKidsContent && displaySeriesContent; - } - - if (displayInnerContent && enableColorCodedBackgrounds && accentCssClass) { - cssClass += ' programCell-' + accentCssClass; - } - - if (now >= startDateLocalMs && now < endDateLocalMs) { - cssClass += ' programCell-active'; - } - - var timerAttributes = ''; - if (program.TimerId) { - timerAttributes += ' data-timerid="' + program.TimerId + '"'; - } - if (program.SeriesTimerId) { - timerAttributes += ' data-seriestimerid="' + program.SeriesTimerId + '"'; - } - - var isAttribute = endPercent >= 2 ? ' is="emby-programcell"' : ''; - - html += ''; - - if (displayInnerContent) { - var guideProgramNameClass = 'guideProgramName'; - - html += '
'; - - html += '
'; - - html += '
' + program.Name; - - var indicatorHtml = null; - if (program.IsLive && options.showLiveIndicator) { - indicatorHtml = '' + globalize.translate('Live') + ''; - } else if (program.IsPremiere && options.showPremiereIndicator) { - indicatorHtml = '' + globalize.translate('Premiere') + ''; - } else if (program.IsSeries && !program.IsRepeat && options.showNewIndicator) { - indicatorHtml = '' + globalize.translate('AttributeNew') + ''; - } else if (program.IsSeries && program.IsRepeat && options.showRepeatIndicator) { - indicatorHtml = '' + globalize.translate('Repeat') + ''; - } - html += indicatorHtml || ''; - - if ((program.EpisodeTitle && options.showEpisodeTitle)) { - html += '
'; - - if (program.EpisodeTitle && options.showEpisodeTitle) { - html += '' + program.EpisodeTitle + ''; - } - html += '
'; - } - - html += '
'; - - if (program.IsHD && options.showHdIcon) { - if (layoutManager.tv) { - html += '
HD
'; - } else { - html += '
HD
'; - } - } - - html += getTimerIndicator(program); - - html += '
'; - } - - html += ''; - } - - html += '
'; - - return html; - } - - function renderChannelHeaders(context, channels, apiClient) { - var html = ''; - - for (var i = 0, length = channels.length; i < length; i++) { - var channel = channels[i]; - var hasChannelImage = channel.ImageTags.Primary; - - var cssClass = 'guide-channelHeaderCell itemAction'; - - if (layoutManager.tv) { - cssClass += ' guide-channelHeaderCell-tv'; - } - - var title = []; - if (channel.ChannelNumber) { - title.push(channel.ChannelNumber); - } - if (channel.Name) { - title.push(channel.Name); - } - - html += ''; - } - - var channelList = context.querySelector('.channelsContainer'); - channelList.innerHTML = html; - imageLoader.lazyChildren(channelList); - } - - function renderPrograms(context, date, channels, programs, options) { - var listInfo = { - startIndex: 0 - }; - - var html = []; - - for (var i = 0, length = channels.length; i < length; i++) { - html.push(getChannelProgramsHtml(context, date, channels[i], programs, options, listInfo)); - } - - programGrid.innerHTML = html.join(''); - - programCells = programGrid.querySelectorAll('[is=emby-programcell]'); - - updateProgramCellsOnScroll(programGrid, programCells); - } - - function getProgramSortOrder(program, channels) { - var channelId = program.ChannelId; - var channelIndex = -1; - - for (var i = 0, length = channels.length; i < length; i++) { - if (channelId === channels[i].Id) { - channelIndex = i; - break; - } - } - - var start = datetime.parseISO8601Date(program.StartDate, { toLocal: true }); - - return (channelIndex * 10000000) + (start.getTime() / 60000); - } - - function renderGuide(context, date, channels, programs, renderOptions, apiClient, scrollToTimeMs, focusToTimeMs, startTimeOfDayMs, focusProgramOnRender) { - programs.sort(function (a, b) { - return getProgramSortOrder(a, channels) - getProgramSortOrder(b, channels); - }); - - var activeElement = document.activeElement; - var itemId = activeElement && activeElement.getAttribute ? activeElement.getAttribute('data-id') : null; - var channelRowId = null; - - if (activeElement) { - channelRowId = dom.parentWithClass(activeElement, 'channelPrograms'); - channelRowId = channelRowId && channelRowId.getAttribute ? channelRowId.getAttribute('data-channelid') : null; - } - - renderChannelHeaders(context, channels, apiClient); - - var startDate = date; - var endDate = new Date(startDate.getTime() + msPerDay); - context.querySelector('.timeslotHeaders').innerHTML = getTimeslotHeadersHtml(startDate, endDate); - items = {}; - renderPrograms(context, date, channels, programs, renderOptions); - - if (focusProgramOnRender) { - focusProgram(context, itemId, channelRowId, focusToTimeMs, startTimeOfDayMs); - } - - scrollProgramGridToTimeMs(context, scrollToTimeMs, startTimeOfDayMs); - } - - function scrollProgramGridToTimeMs(context, scrollToTimeMs, startTimeOfDayMs) { - scrollToTimeMs -= startTimeOfDayMs; - - var pct = scrollToTimeMs / msPerDay; - - programGrid.scrollTop = 0; - - var scrollPos = pct * programGrid.scrollWidth; - - nativeScrollTo(programGrid, scrollPos, true); - } - - function focusProgram(context, itemId, channelRowId, focusToTimeMs, startTimeOfDayMs) { - var focusElem; - if (itemId) { - focusElem = context.querySelector('[data-id="' + itemId + '"]'); - } - - if (focusElem) { - focusManager.focus(focusElem); - } else { - var autoFocusParent; - - if (channelRowId) { - autoFocusParent = context.querySelector('[data-channelid="' + channelRowId + '"]'); - } - - if (!autoFocusParent) { - autoFocusParent = programGrid; - } - - focusToTimeMs -= startTimeOfDayMs; - - var pct = (focusToTimeMs / msPerDay) * 100; - - var programCell = autoFocusParent.querySelector('.programCell'); - - while (programCell) { - var left = (programCell.style.left || '').replace('%', ''); - left = left ? parseFloat(left) : 0; - var width = (programCell.style.width || '').replace('%', ''); - width = width ? parseFloat(width) : 0; - - if (left >= pct || (left + width) >= pct) { - break; - } - programCell = programCell.nextSibling; - } - - if (programCell) { - focusManager.focus(programCell); - } else { - focusManager.autoFocus(autoFocusParent, true); - } - } - } - - function nativeScrollTo(container, pos, horizontal) { - if (container.scrollTo) { - if (horizontal) { - container.scrollTo(pos, 0); - } else { - container.scrollTo(0, pos); - } - } else { - if (horizontal) { - container.scrollLeft = Math.round(pos); - } else { - container.scrollTop = Math.round(pos); - } - } - } - - var lastGridScroll = 0; - var lastHeaderScroll = 0; - var scrollXPct = 0; - function onProgramGridScroll(context, elem, timeslotHeaders) { - if ((new Date().getTime() - lastHeaderScroll) >= 1000) { - lastGridScroll = new Date().getTime(); - - var scrollLeft = elem.scrollLeft; - scrollXPct = (scrollLeft * 100) / elem.scrollWidth; - nativeScrollTo(timeslotHeaders, scrollLeft, true); - } - - updateProgramCellsOnScroll(elem, programCells); - } - - function onTimeslotHeadersScroll(context, elem) { - if ((new Date().getTime() - lastGridScroll) >= 1000) { - lastHeaderScroll = new Date().getTime(); - nativeScrollTo(programGrid, elem.scrollLeft, true); - } - } - - function changeDate(page, date, scrollToTimeMs, focusToTimeMs, startTimeOfDayMs, focusProgramOnRender) { - var newStartDate = normalizeDateToTimeslot(date); - currentDate = newStartDate; - - reloadGuide(page, newStartDate, scrollToTimeMs, focusToTimeMs, startTimeOfDayMs, focusProgramOnRender); - } - - function getDateTabText(date, isActive, tabIndex) { - var cssClass = isActive ? 'emby-tab-button guide-date-tab-button emby-tab-button-active' : 'emby-tab-button guide-date-tab-button'; - - var html = ''; - - return html; - } - - function setDateRange(page, guideInfo) { - var today = new Date(); - var nowHours = today.getHours(); - today.setHours(nowHours, 0, 0, 0); - - var start = datetime.parseISO8601Date(guideInfo.StartDate, { toLocal: true }); - var end = datetime.parseISO8601Date(guideInfo.EndDate, { toLocal: true }); - - start.setHours(nowHours, 0, 0, 0); - end.setHours(0, 0, 0, 0); - - if (start.getTime() >= end.getTime()) { - end.setDate(start.getDate() + 1); - } - - start = new Date(Math.max(today, start)); - - var dateTabsHtml = ''; - var tabIndex = 0; - - // TODO: Use date-fns - var date = new Date(); - - if (currentDate) { - date.setTime(currentDate.getTime()); - } - - date.setHours(nowHours, 0, 0, 0); - - var startTimeOfDayMs = (start.getHours() * 60 * 60 * 1000); - startTimeOfDayMs += start.getMinutes() * 60 * 1000; - - while (start <= end) { - var isActive = date.getDate() === start.getDate() && date.getMonth() === start.getMonth() && date.getFullYear() === start.getFullYear(); - - dateTabsHtml += getDateTabText(start, isActive, tabIndex); - - start.setDate(start.getDate() + 1); - start.setHours(0, 0, 0, 0); - tabIndex++; - } - - page.querySelector('.emby-tabs-slider').innerHTML = dateTabsHtml; - page.querySelector('.guideDateTabs').refresh(); - - var newDate = new Date(); - var newDateHours = newDate.getHours(); - var scrollToTimeMs = newDateHours * 60 * 60 * 1000; - - var minutes = newDate.getMinutes(); - if (minutes >= 30) { - scrollToTimeMs += 30 * 60 * 1000; - } - - var focusToTimeMs = ((newDateHours * 60) + minutes) * 60 * 1000; - changeDate(page, date, scrollToTimeMs, focusToTimeMs, startTimeOfDayMs, layoutManager.tv); - } - - function reloadPage(page) { - showLoading(); - - var apiClient = connectionManager.getApiClient(options.serverId); - - apiClient.getLiveTvGuideInfo().then(function (guideInfo) { - setDateRange(page, guideInfo); - }); - } - - function getChannelProgramsFocusableElements(container) { - var elements = container.querySelectorAll('.programCell'); - - var list = []; - // add 1 to avoid programs that are out of view to the left - var currentScrollXPct = scrollXPct + 1; - - for (var i = 0, length = elements.length; i < length; i++) { - var elem = elements[i]; - - var left = (elem.style.left || '').replace('%', ''); - left = left ? parseFloat(left) : 0; - var width = (elem.style.width || '').replace('%', ''); - width = width ? parseFloat(width) : 0; - - if ((left + width) >= currentScrollXPct) { - list.push(elem); - } - } - - return list; - } - - function onInputCommand(e) { - var target = e.target; - var programCell = dom.parentWithClass(target, 'programCell'); - var container; - var channelPrograms; - var focusableElements; - var newRow; - - switch (e.detail.command) { - case 'up': - if (programCell) { - container = programGrid; - channelPrograms = dom.parentWithClass(programCell, 'channelPrograms'); - - newRow = channelPrograms.previousSibling; - if (newRow) { - focusableElements = getChannelProgramsFocusableElements(newRow); - if (focusableElements.length) { - container = newRow; - } else { - focusableElements = null; - } - } else { - container = null; - } - } else { - container = null; - } - lastFocusDirection = e.detail.command; - - focusManager.moveUp(target, { - container: container, - focusableElements: focusableElements - }); - break; - case 'down': - if (programCell) { - container = programGrid; - channelPrograms = dom.parentWithClass(programCell, 'channelPrograms'); - - newRow = channelPrograms.nextSibling; - if (newRow) { - focusableElements = getChannelProgramsFocusableElements(newRow); - if (focusableElements.length) { - container = newRow; - } else { - focusableElements = null; - } - } else { - container = null; - } - } else { - container = null; - } - lastFocusDirection = e.detail.command; - - focusManager.moveDown(target, { - container: container, - focusableElements: focusableElements - }); - break; - case 'left': - container = programCell ? dom.parentWithClass(programCell, 'channelPrograms') : null; - // allow left outside the channelProgramsContainer when the first child is currently focused - if (container && !programCell.previousSibling) { - container = null; - } - lastFocusDirection = e.detail.command; - - focusManager.moveLeft(target, { - container: container - }); - break; - case 'right': - container = programCell ? dom.parentWithClass(programCell, 'channelPrograms') : null; - lastFocusDirection = e.detail.command; - - focusManager.moveRight(target, { - container: container - }); - break; - default: - return; - } + isUpdatingProgramCellScroll = false; + }); +} + +function onProgramGridClick(e) { + if (!layoutManager.tv) { + return; + } + + const programCell = dom.parentWithClass(e.target, 'programCell'); + if (programCell) { + let startDate = programCell.getAttribute('data-startdate'); + let endDate = programCell.getAttribute('data-enddate'); + startDate = datetime.parseISO8601Date(startDate, { toLocal: true }).getTime(); + endDate = datetime.parseISO8601Date(endDate, { toLocal: true }).getTime(); + + const now = new Date().getTime(); + if (now >= startDate && now < endDate) { + const channelId = programCell.getAttribute('data-channelid'); + const serverId = programCell.getAttribute('data-serverid'); e.preventDefault(); e.stopPropagation(); - } - function onScrollerFocus(e) { - var target = e.target; - var programCell = dom.parentWithClass(target, 'programCell'); - - if (programCell) { - var focused = target; - - var id = focused.getAttribute('data-id'); - var item = items[id]; - - if (item) { - events.trigger(self, 'focus', [ - { - item: item - }]); - } - } - - if (lastFocusDirection === 'left') { - if (programCell) { - scrollHelper.toStart(programGrid, programCell, true, true); - } - } else if (lastFocusDirection === 'right') { - if (programCell) { - scrollHelper.toCenter(programGrid, programCell, true, true); - } - } else if (lastFocusDirection === 'up' || lastFocusDirection === 'down') { - var verticalScroller = dom.parentWithClass(target, 'guideVerticalScroller'); - if (verticalScroller) { - var focusedElement = programCell || dom.parentWithTag(target, 'BUTTON'); - verticalScroller.toCenter(focusedElement, true); - } - } - } - - function setScrollEvents(view, enabled) { - if (layoutManager.tv) { - var guideVerticalScroller = view.querySelector('.guideVerticalScroller'); - - if (enabled) { - inputManager.on(guideVerticalScroller, onInputCommand); - } else { - inputManager.off(guideVerticalScroller, onInputCommand); - } - } - } - - function onTimerCreated(e, apiClient, data) { - var programId = data.ProgramId; - // This could be null, not supported by all tv providers - var newTimerId = data.Id; - - // find guide cells by program id, ensure timer icon - var cells = options.element.querySelectorAll('.programCell[data-id="' + programId + '"]'); - for (var i = 0, length = cells.length; i < length; i++) { - var cell = cells[i]; - - var icon = cell.querySelector('.timerIcon'); - if (!icon) { - cell.querySelector('.guideProgramName').insertAdjacentHTML('beforeend', ''); - } - - if (newTimerId) { - cell.setAttribute('data-timerid', newTimerId); - } - } - } - - function onSeriesTimerCreated(e, apiClient, data) { - } - - function onTimerCancelled(e, apiClient, data) { - var id = data.Id; - // find guide cells by timer id, remove timer icon - var cells = options.element.querySelectorAll('.programCell[data-timerid="' + id + '"]'); - for (var i = 0, length = cells.length; i < length; i++) { - var cell = cells[i]; - var icon = cell.querySelector('.timerIcon'); - if (icon) { - icon.parentNode.removeChild(icon); - } - cell.removeAttribute('data-timerid'); - } - } - - function onSeriesTimerCancelled(e, apiClient, data) { - var id = data.Id; - // find guide cells by timer id, remove timer icon - var cells = options.element.querySelectorAll('.programCell[data-seriestimerid="' + id + '"]'); - for (var i = 0, length = cells.length; i < length; i++) { - var cell = cells[i]; - var icon = cell.querySelector('.seriesTimerIcon'); - if (icon) { - icon.parentNode.removeChild(icon); - } - cell.removeAttribute('data-seriestimerid'); - } - } - - require(['text!./tvguide.template.html'], function (template) { - var context = options.element; - - context.classList.add('tvguide'); - - context.innerHTML = globalize.translateHtml(template, 'core'); - - programGrid = context.querySelector('.programGrid'); - var timeslotHeaders = context.querySelector('.timeslotHeaders'); - - if (layoutManager.tv) { - dom.addEventListener(context.querySelector('.guideVerticalScroller'), 'focus', onScrollerFocus, { - capture: true, - passive: true - }); - } else if (layoutManager.desktop) { - timeslotHeaders.classList.add('timeslotHeaders-desktop'); - } - - if (browser.iOS || browser.osx) { - context.querySelector('.channelsContainer').classList.add('noRubberBanding'); - - programGrid.classList.add('noRubberBanding'); - } - - dom.addEventListener(programGrid, 'scroll', function (e) { - onProgramGridScroll(context, this, timeslotHeaders); - }, { - passive: true + playbackManager.play({ + ids: [channelId], + serverId: serverId }); + } + } +} - dom.addEventListener(timeslotHeaders, 'scroll', function () { - onTimeslotHeadersScroll(context, this); - }, { - passive: true - }); +function Guide(options) { + const self = this; + let items = {}; - programGrid.addEventListener('click', onProgramGridClick); + self.options = options; + self.categoryOptions = { categories: [] }; - context.querySelector('.btnNextPage').addEventListener('click', function () { - currentStartIndex += currentChannelLimit; - reloadPage(context); - restartAutoRefresh(); - }); + // 30 mins + const cellCurationMinutes = 30; + const cellDurationMs = cellCurationMinutes * 60 * 1000; + const msPerDay = 86400000; - context.querySelector('.btnPreviousPage').addEventListener('click', function () { - currentStartIndex = Math.max(currentStartIndex - currentChannelLimit, 0); - reloadPage(context); - restartAutoRefresh(); - }); + let currentDate; + let currentStartIndex = 0; + let currentChannelLimit = 0; + let autoRefreshInterval; + let programCells; + let lastFocusDirection; + let programGrid; - context.querySelector('.btnGuideViewSettings').addEventListener('click', function () { - showViewSettings(self); - restartAutoRefresh(); - }); + self.refresh = function () { + currentDate = null; + reloadPage(options.element); + restartAutoRefresh(); + }; - context.querySelector('.guideDateTabs').addEventListener('tabchange', function (e) { - var allTabButtons = e.target.querySelectorAll('.guide-date-tab-button'); - - var tabButton = allTabButtons[parseInt(e.detail.selectedTabIndex)]; - if (tabButton) { - var previousButton = e.detail.previousIndex == null ? null : allTabButtons[parseInt(e.detail.previousIndex)]; - - var date = new Date(); - date.setTime(parseInt(tabButton.getAttribute('data-date'))); - - var scrollWidth = programGrid.scrollWidth; - var scrollToTimeMs; - if (scrollWidth) { - scrollToTimeMs = (programGrid.scrollLeft / scrollWidth) * msPerDay; - } else { - scrollToTimeMs = 0; - } - - if (previousButton) { - var previousDate = new Date(); - previousDate.setTime(parseInt(previousButton.getAttribute('data-date'))); - - scrollToTimeMs += (previousDate.getHours() * 60 * 60 * 1000); - scrollToTimeMs += (previousDate.getMinutes() * 60 * 1000); - } - - var startTimeOfDayMs = (date.getHours() * 60 * 60 * 1000); - startTimeOfDayMs += (date.getMinutes() * 60 * 1000); - - changeDate(context, date, scrollToTimeMs, scrollToTimeMs, startTimeOfDayMs, false); - } - }); - - setScrollEvents(context, true); - itemShortcuts.on(context); - - events.trigger(self, 'load'); - - events.on(serverNotifications, 'TimerCreated', onTimerCreated); - events.on(serverNotifications, 'SeriesTimerCreated', onSeriesTimerCreated); - events.on(serverNotifications, 'TimerCancelled', onTimerCancelled); - events.on(serverNotifications, 'SeriesTimerCancelled', onSeriesTimerCancelled); + self.pause = function () { + stopAutoRefresh(); + }; + self.resume = function (refreshData) { + if (refreshData) { self.refresh(); + } else { + restartAutoRefresh(); + } + }; + + self.destroy = function () { + stopAutoRefresh(); + + events.off(serverNotifications, 'TimerCreated', onTimerCreated); + events.off(serverNotifications, 'SeriesTimerCreated', onSeriesTimerCreated); + events.off(serverNotifications, 'TimerCancelled', onTimerCancelled); + events.off(serverNotifications, 'SeriesTimerCancelled', onSeriesTimerCancelled); + + setScrollEvents(options.element, false); + itemShortcuts.off(options.element); + items = {}; + }; + + function restartAutoRefresh() { + stopAutoRefresh(); + + const intervalMs = 60000 * 15; // (minutes) + + autoRefreshInterval = setInterval(function () { + self.refresh(); + }, intervalMs); + } + + function stopAutoRefresh() { + if (autoRefreshInterval) { + clearInterval(autoRefreshInterval); + autoRefreshInterval = null; + } + } + + function normalizeDateToTimeslot(date) { + const minutesOffset = date.getMinutes() - cellCurationMinutes; + + if (minutesOffset >= 0) { + date.setHours(date.getHours(), cellCurationMinutes, 0, 0); + } else { + date.setHours(date.getHours(), 0, 0, 0); + } + + return date; + } + + function showLoading() { + loading.show(); + } + + function hideLoading() { + loading.hide(); + } + + function reloadGuide(context, newStartDate, scrollToTimeMs, focusToTimeMs, startTimeOfDayMs, focusProgramOnRender) { + const apiClient = connectionManager.getApiClient(options.serverId); + + const channelQuery = { + + StartIndex: 0, + EnableFavoriteSorting: userSettings.get('livetv-favoritechannelsattop') !== 'false' + }; + + channelQuery.UserId = apiClient.getCurrentUserId(); + + const channelLimit = 500; + currentChannelLimit = channelLimit; + + showLoading(); + + channelQuery.StartIndex = currentStartIndex; + channelQuery.Limit = channelLimit; + channelQuery.AddCurrentProgram = false; + channelQuery.EnableUserData = false; + channelQuery.EnableImageTypes = 'Primary'; + + const categories = self.categoryOptions.categories || []; + const displayMovieContent = !categories.length || categories.indexOf('movies') !== -1; + const displaySportsContent = !categories.length || categories.indexOf('sports') !== -1; + const displayNewsContent = !categories.length || categories.indexOf('news') !== -1; + const displayKidsContent = !categories.length || categories.indexOf('kids') !== -1; + const displaySeriesContent = !categories.length || categories.indexOf('series') !== -1; + + if (displayMovieContent && displaySportsContent && displayNewsContent && displayKidsContent) { + channelQuery.IsMovie = null; + channelQuery.IsSports = null; + channelQuery.IsKids = null; + channelQuery.IsNews = null; + channelQuery.IsSeries = null; + } else { + if (displayNewsContent) { + channelQuery.IsNews = true; + } + if (displaySportsContent) { + channelQuery.IsSports = true; + } + if (displayKidsContent) { + channelQuery.IsKids = true; + } + if (displayMovieContent) { + channelQuery.IsMovie = true; + } + if (displaySeriesContent) { + channelQuery.IsSeries = true; + } + } + + if (userSettings.get('livetv-channelorder') === 'DatePlayed') { + channelQuery.SortBy = 'DatePlayed'; + channelQuery.SortOrder = 'Descending'; + } else { + channelQuery.SortBy = null; + channelQuery.SortOrder = null; + } + + let date = newStartDate; + // Add one second to avoid getting programs that are just ending + date = new Date(date.getTime() + 1000); + + // Subtract to avoid getting programs that are starting when the grid ends + const nextDay = new Date(date.getTime() + msPerDay - 2000); + + // Normally we'd want to just let responsive css handle this, + // but since mobile browsers are often underpowered, + // it can help performance to get them out of the markup + const allowIndicators = dom.getWindowSize().innerWidth >= 600; + + const renderOptions = { + showHdIcon: allowIndicators && userSettings.get('guide-indicator-hd') === 'true', + showLiveIndicator: allowIndicators && userSettings.get('guide-indicator-live') !== 'false', + showPremiereIndicator: allowIndicators && userSettings.get('guide-indicator-premiere') !== 'false', + showNewIndicator: allowIndicators && userSettings.get('guide-indicator-new') !== 'false', + showRepeatIndicator: allowIndicators && userSettings.get('guide-indicator-repeat') === 'true', + showEpisodeTitle: layoutManager.tv ? false : true + }; + + apiClient.getLiveTvChannels(channelQuery).then(function (channelsResult) { + const btnPreviousPage = context.querySelector('.btnPreviousPage'); + const btnNextPage = context.querySelector('.btnNextPage'); + + if (channelsResult.TotalRecordCount > channelLimit) { + context.querySelector('.guideOptions').classList.remove('hide'); + + btnPreviousPage.classList.remove('hide'); + btnNextPage.classList.remove('hide'); + + if (channelQuery.StartIndex) { + context.querySelector('.btnPreviousPage').disabled = false; + } else { + context.querySelector('.btnPreviousPage').disabled = true; + } + + if ((channelQuery.StartIndex + channelLimit) < channelsResult.TotalRecordCount) { + btnNextPage.disabled = false; + } else { + btnNextPage.disabled = true; + } + } else { + context.querySelector('.guideOptions').classList.add('hide'); + } + + const programFields = []; + + const programQuery = { + UserId: apiClient.getCurrentUserId(), + MaxStartDate: nextDay.toISOString(), + MinEndDate: date.toISOString(), + channelIds: channelsResult.Items.map(function (c) { + return c.Id; + }).join(','), + ImageTypeLimit: 1, + EnableImages: false, + //EnableImageTypes: layoutManager.tv ? "Primary,Backdrop" : "Primary", + SortBy: 'StartDate', + EnableTotalRecordCount: false, + EnableUserData: false + }; + + if (renderOptions.showHdIcon) { + programFields.push('IsHD'); + } + + if (programFields.length) { + programQuery.Fields = programFields.join(''); + } + + apiClient.getLiveTvPrograms(programQuery).then(function (programsResult) { + renderGuide(context, date, channelsResult.Items, programsResult.Items, renderOptions, apiClient, scrollToTimeMs, focusToTimeMs, startTimeOfDayMs, focusProgramOnRender); + + hideLoading(); + }); }); } - return Guide; -}); + function getDisplayTime(date) { + if ((typeof date).toString().toLowerCase() === 'string') { + try { + date = datetime.parseISO8601Date(date, { toLocal: true }); + } catch (err) { + return date; + } + } + + return datetime.getDisplayTime(date).toLowerCase(); + } + + function getTimeslotHeadersHtml(startDate, endDateTime) { + let html = ''; + + // clone + startDate = new Date(startDate.getTime()); + + html += '
'; + + while (startDate.getTime() < endDateTime) { + html += '
'; + + html += getDisplayTime(startDate); + html += '
'; + + // Add 30 mins + startDate.setTime(startDate.getTime() + cellDurationMs); + } + + return html; + } + + function parseDates(program) { + if (!program.StartDateLocal) { + try { + program.StartDateLocal = datetime.parseISO8601Date(program.StartDate, { toLocal: true }); + } catch (err) { + console.error('error parsing timestamp for start date'); + } + } + + if (!program.EndDateLocal) { + try { + program.EndDateLocal = datetime.parseISO8601Date(program.EndDate, { toLocal: true }); + } catch (err) { + console.error('error parsing timestamp for end date'); + } + } + + return null; + } + + function getTimerIndicator(item) { + let status; + + if (item.Type === 'SeriesTimer') { + return ''; + } else if (item.TimerId || item.SeriesTimerId) { + status = item.Status || 'Cancelled'; + } else if (item.Type === 'Timer') { + status = item.Status; + } else { + return ''; + } + + if (item.SeriesTimerId) { + if (status !== 'Cancelled') { + return ''; + } + + return ''; + } + + return ''; + } + + function getChannelProgramsHtml(context, date, channel, programs, options, listInfo) { + let html = ''; + + const startMs = date.getTime(); + const endMs = startMs + msPerDay - 1; + + const outerCssClass = layoutManager.tv ? 'channelPrograms channelPrograms-tv' : 'channelPrograms'; + + html += '
'; + + const clickAction = layoutManager.tv ? 'link' : 'programdialog'; + + const categories = self.categoryOptions.categories || []; + const displayMovieContent = !categories.length || categories.indexOf('movies') !== -1; + const displaySportsContent = !categories.length || categories.indexOf('sports') !== -1; + const displayNewsContent = !categories.length || categories.indexOf('news') !== -1; + const displayKidsContent = !categories.length || categories.indexOf('kids') !== -1; + const displaySeriesContent = !categories.length || categories.indexOf('series') !== -1; + const enableColorCodedBackgrounds = userSettings.get('guide-colorcodedbackgrounds') === 'true'; + + let programsFound; + const now = new Date().getTime(); + + for (let i = listInfo.startIndex, length = programs.length; i < length; i++) { + const program = programs[i]; + + if (program.ChannelId !== channel.Id) { + if (programsFound) { + break; + } + + continue; + } + + programsFound = true; + listInfo.startIndex++; + + parseDates(program); + + const startDateLocalMs = program.StartDateLocal.getTime(); + const endDateLocalMs = program.EndDateLocal.getTime(); + + if (endDateLocalMs < startMs) { + continue; + } + + if (startDateLocalMs > endMs) { + break; + } + + items[program.Id] = program; + + const renderStartMs = Math.max(startDateLocalMs, startMs); + let startPercent = (startDateLocalMs - startMs) / msPerDay; + startPercent *= 100; + startPercent = Math.max(startPercent, 0); + + const renderEndMs = Math.min(endDateLocalMs, endMs); + let endPercent = (renderEndMs - renderStartMs) / msPerDay; + endPercent *= 100; + + let cssClass = 'programCell itemAction'; + let accentCssClass = null; + let displayInnerContent = true; + + if (program.IsKids) { + displayInnerContent = displayKidsContent; + accentCssClass = 'kids'; + } else if (program.IsSports) { + displayInnerContent = displaySportsContent; + accentCssClass = 'sports'; + } else if (program.IsNews) { + displayInnerContent = displayNewsContent; + accentCssClass = 'news'; + } else if (program.IsMovie) { + displayInnerContent = displayMovieContent; + accentCssClass = 'movie'; + } else if (program.IsSeries) { + displayInnerContent = displaySeriesContent; + } else { + displayInnerContent = displayMovieContent && displayNewsContent && displaySportsContent && displayKidsContent && displaySeriesContent; + } + + if (displayInnerContent && enableColorCodedBackgrounds && accentCssClass) { + cssClass += ' programCell-' + accentCssClass; + } + + if (now >= startDateLocalMs && now < endDateLocalMs) { + cssClass += ' programCell-active'; + } + + let timerAttributes = ''; + if (program.TimerId) { + timerAttributes += ' data-timerid="' + program.TimerId + '"'; + } + if (program.SeriesTimerId) { + timerAttributes += ' data-seriestimerid="' + program.SeriesTimerId + '"'; + } + + const isAttribute = endPercent >= 2 ? ' is="emby-programcell"' : ''; + + html += ''; + + if (displayInnerContent) { + const guideProgramNameClass = 'guideProgramName'; + + html += '
'; + + html += '
'; + + html += '
' + program.Name; + + let indicatorHtml = null; + if (program.IsLive && options.showLiveIndicator) { + indicatorHtml = '' + globalize.translate('Live') + ''; + } else if (program.IsPremiere && options.showPremiereIndicator) { + indicatorHtml = '' + globalize.translate('Premiere') + ''; + } else if (program.IsSeries && !program.IsRepeat && options.showNewIndicator) { + indicatorHtml = '' + globalize.translate('AttributeNew') + ''; + } else if (program.IsSeries && program.IsRepeat && options.showRepeatIndicator) { + indicatorHtml = '' + globalize.translate('Repeat') + ''; + } + html += indicatorHtml || ''; + + if ((program.EpisodeTitle && options.showEpisodeTitle)) { + html += '
'; + + if (program.EpisodeTitle && options.showEpisodeTitle) { + html += '' + program.EpisodeTitle + ''; + } + html += '
'; + } + + html += '
'; + + if (program.IsHD && options.showHdIcon) { + if (layoutManager.tv) { + html += '
HD
'; + } else { + html += '
HD
'; + } + } + + html += getTimerIndicator(program); + + html += '
'; + } + + html += ''; + } + + html += '
'; + + return html; + } + + function renderChannelHeaders(context, channels, apiClient) { + let html = ''; + + for (let i = 0, length = channels.length; i < length; i++) { + const channel = channels[i]; + const hasChannelImage = channel.ImageTags.Primary; + + let cssClass = 'guide-channelHeaderCell itemAction'; + + if (layoutManager.tv) { + cssClass += ' guide-channelHeaderCell-tv'; + } + + const title = []; + if (channel.ChannelNumber) { + title.push(channel.ChannelNumber); + } + if (channel.Name) { + title.push(channel.Name); + } + + html += ''; + } + + const channelList = context.querySelector('.channelsContainer'); + channelList.innerHTML = html; + imageLoader.lazyChildren(channelList); + } + + function renderPrograms(context, date, channels, programs, options) { + const listInfo = { + startIndex: 0 + }; + + const html = []; + + for (let i = 0, length = channels.length; i < length; i++) { + html.push(getChannelProgramsHtml(context, date, channels[i], programs, options, listInfo)); + } + + programGrid.innerHTML = html.join(''); + + programCells = programGrid.querySelectorAll('[is=emby-programcell]'); + + updateProgramCellsOnScroll(programGrid, programCells); + } + + function getProgramSortOrder(program, channels) { + const channelId = program.ChannelId; + let channelIndex = -1; + + for (let i = 0, length = channels.length; i < length; i++) { + if (channelId === channels[i].Id) { + channelIndex = i; + break; + } + } + + const start = datetime.parseISO8601Date(program.StartDate, { toLocal: true }); + + return (channelIndex * 10000000) + (start.getTime() / 60000); + } + + function renderGuide(context, date, channels, programs, renderOptions, apiClient, scrollToTimeMs, focusToTimeMs, startTimeOfDayMs, focusProgramOnRender) { + programs.sort(function (a, b) { + return getProgramSortOrder(a, channels) - getProgramSortOrder(b, channels); + }); + + const activeElement = document.activeElement; + const itemId = activeElement && activeElement.getAttribute ? activeElement.getAttribute('data-id') : null; + let channelRowId = null; + + if (activeElement) { + channelRowId = dom.parentWithClass(activeElement, 'channelPrograms'); + channelRowId = channelRowId && channelRowId.getAttribute ? channelRowId.getAttribute('data-channelid') : null; + } + + renderChannelHeaders(context, channels, apiClient); + + const startDate = date; + const endDate = new Date(startDate.getTime() + msPerDay); + context.querySelector('.timeslotHeaders').innerHTML = getTimeslotHeadersHtml(startDate, endDate); + items = {}; + renderPrograms(context, date, channels, programs, renderOptions); + + if (focusProgramOnRender) { + focusProgram(context, itemId, channelRowId, focusToTimeMs, startTimeOfDayMs); + } + + scrollProgramGridToTimeMs(context, scrollToTimeMs, startTimeOfDayMs); + } + + function scrollProgramGridToTimeMs(context, scrollToTimeMs, startTimeOfDayMs) { + scrollToTimeMs -= startTimeOfDayMs; + + const pct = scrollToTimeMs / msPerDay; + + programGrid.scrollTop = 0; + + const scrollPos = pct * programGrid.scrollWidth; + + nativeScrollTo(programGrid, scrollPos, true); + } + + function focusProgram(context, itemId, channelRowId, focusToTimeMs, startTimeOfDayMs) { + let focusElem; + if (itemId) { + focusElem = context.querySelector('[data-id="' + itemId + '"]'); + } + + if (focusElem) { + focusManager.focus(focusElem); + } else { + let autoFocusParent; + + if (channelRowId) { + autoFocusParent = context.querySelector('[data-channelid="' + channelRowId + '"]'); + } + + if (!autoFocusParent) { + autoFocusParent = programGrid; + } + + focusToTimeMs -= startTimeOfDayMs; + + const pct = (focusToTimeMs / msPerDay) * 100; + + let programCell = autoFocusParent.querySelector('.programCell'); + + while (programCell) { + let left = (programCell.style.left || '').replace('%', ''); + left = left ? parseFloat(left) : 0; + let width = (programCell.style.width || '').replace('%', ''); + width = width ? parseFloat(width) : 0; + + if (left >= pct || (left + width) >= pct) { + break; + } + programCell = programCell.nextSibling; + } + + if (programCell) { + focusManager.focus(programCell); + } else { + focusManager.autoFocus(autoFocusParent, true); + } + } + } + + function nativeScrollTo(container, pos, horizontal) { + if (container.scrollTo) { + if (horizontal) { + container.scrollTo(pos, 0); + } else { + container.scrollTo(0, pos); + } + } else { + if (horizontal) { + container.scrollLeft = Math.round(pos); + } else { + container.scrollTop = Math.round(pos); + } + } + } + + let lastGridScroll = 0; + let lastHeaderScroll = 0; + let scrollXPct = 0; + function onProgramGridScroll(context, elem, timeslotHeaders) { + if ((new Date().getTime() - lastHeaderScroll) >= 1000) { + lastGridScroll = new Date().getTime(); + + const scrollLeft = elem.scrollLeft; + scrollXPct = (scrollLeft * 100) / elem.scrollWidth; + nativeScrollTo(timeslotHeaders, scrollLeft, true); + } + + updateProgramCellsOnScroll(elem, programCells); + } + + function onTimeslotHeadersScroll(context, elem) { + if ((new Date().getTime() - lastGridScroll) >= 1000) { + lastHeaderScroll = new Date().getTime(); + nativeScrollTo(programGrid, elem.scrollLeft, true); + } + } + + function changeDate(page, date, scrollToTimeMs, focusToTimeMs, startTimeOfDayMs, focusProgramOnRender) { + const newStartDate = normalizeDateToTimeslot(date); + currentDate = newStartDate; + + reloadGuide(page, newStartDate, scrollToTimeMs, focusToTimeMs, startTimeOfDayMs, focusProgramOnRender); + } + + function getDateTabText(date, isActive, tabIndex) { + const cssClass = isActive ? 'emby-tab-button guide-date-tab-button emby-tab-button-active' : 'emby-tab-button guide-date-tab-button'; + + let html = ''; + + return html; + } + + function setDateRange(page, guideInfo) { + const today = new Date(); + const nowHours = today.getHours(); + today.setHours(nowHours, 0, 0, 0); + + let start = datetime.parseISO8601Date(guideInfo.StartDate, { toLocal: true }); + const end = datetime.parseISO8601Date(guideInfo.EndDate, { toLocal: true }); + + start.setHours(nowHours, 0, 0, 0); + end.setHours(0, 0, 0, 0); + + if (start.getTime() >= end.getTime()) { + end.setDate(start.getDate() + 1); + } + + start = new Date(Math.max(today, start)); + + let dateTabsHtml = ''; + let tabIndex = 0; + + // TODO: Use date-fns + const date = new Date(); + + if (currentDate) { + date.setTime(currentDate.getTime()); + } + + date.setHours(nowHours, 0, 0, 0); + + let startTimeOfDayMs = (start.getHours() * 60 * 60 * 1000); + startTimeOfDayMs += start.getMinutes() * 60 * 1000; + + while (start <= end) { + const isActive = date.getDate() === start.getDate() && date.getMonth() === start.getMonth() && date.getFullYear() === start.getFullYear(); + + dateTabsHtml += getDateTabText(start, isActive, tabIndex); + + start.setDate(start.getDate() + 1); + start.setHours(0, 0, 0, 0); + tabIndex++; + } + + page.querySelector('.emby-tabs-slider').innerHTML = dateTabsHtml; + page.querySelector('.guideDateTabs').refresh(); + + const newDate = new Date(); + const newDateHours = newDate.getHours(); + let scrollToTimeMs = newDateHours * 60 * 60 * 1000; + + const minutes = newDate.getMinutes(); + if (minutes >= 30) { + scrollToTimeMs += 30 * 60 * 1000; + } + + const focusToTimeMs = ((newDateHours * 60) + minutes) * 60 * 1000; + changeDate(page, date, scrollToTimeMs, focusToTimeMs, startTimeOfDayMs, layoutManager.tv); + } + + function reloadPage(page) { + showLoading(); + + const apiClient = connectionManager.getApiClient(options.serverId); + + apiClient.getLiveTvGuideInfo().then(function (guideInfo) { + setDateRange(page, guideInfo); + }); + } + + function getChannelProgramsFocusableElements(container) { + const elements = container.querySelectorAll('.programCell'); + + const list = []; + // add 1 to avoid programs that are out of view to the left + const currentScrollXPct = scrollXPct + 1; + + for (let i = 0, length = elements.length; i < length; i++) { + const elem = elements[i]; + + let left = (elem.style.left || '').replace('%', ''); + left = left ? parseFloat(left) : 0; + let width = (elem.style.width || '').replace('%', ''); + width = width ? parseFloat(width) : 0; + + if ((left + width) >= currentScrollXPct) { + list.push(elem); + } + } + + return list; + } + + function onInputCommand(e) { + const target = e.target; + const programCell = dom.parentWithClass(target, 'programCell'); + let container; + let channelPrograms; + let focusableElements; + let newRow; + + switch (e.detail.command) { + case 'up': + if (programCell) { + container = programGrid; + channelPrograms = dom.parentWithClass(programCell, 'channelPrograms'); + + newRow = channelPrograms.previousSibling; + if (newRow) { + focusableElements = getChannelProgramsFocusableElements(newRow); + if (focusableElements.length) { + container = newRow; + } else { + focusableElements = null; + } + } else { + container = null; + } + } else { + container = null; + } + lastFocusDirection = e.detail.command; + + focusManager.moveUp(target, { + container: container, + focusableElements: focusableElements + }); + break; + case 'down': + if (programCell) { + container = programGrid; + channelPrograms = dom.parentWithClass(programCell, 'channelPrograms'); + + newRow = channelPrograms.nextSibling; + if (newRow) { + focusableElements = getChannelProgramsFocusableElements(newRow); + if (focusableElements.length) { + container = newRow; + } else { + focusableElements = null; + } + } else { + container = null; + } + } else { + container = null; + } + lastFocusDirection = e.detail.command; + + focusManager.moveDown(target, { + container: container, + focusableElements: focusableElements + }); + break; + case 'left': + container = programCell ? dom.parentWithClass(programCell, 'channelPrograms') : null; + // allow left outside the channelProgramsContainer when the first child is currently focused + if (container && !programCell.previousSibling) { + container = null; + } + lastFocusDirection = e.detail.command; + + focusManager.moveLeft(target, { + container: container + }); + break; + case 'right': + container = programCell ? dom.parentWithClass(programCell, 'channelPrograms') : null; + lastFocusDirection = e.detail.command; + + focusManager.moveRight(target, { + container: container + }); + break; + default: + return; + } + + e.preventDefault(); + e.stopPropagation(); + } + + function onScrollerFocus(e) { + const target = e.target; + const programCell = dom.parentWithClass(target, 'programCell'); + + if (programCell) { + const focused = target; + + const id = focused.getAttribute('data-id'); + const item = items[id]; + + if (item) { + events.trigger(self, 'focus', [ + { + item: item + }]); + } + } + + if (lastFocusDirection === 'left') { + if (programCell) { + scrollHelper.toStart(programGrid, programCell, true, true); + } + } else if (lastFocusDirection === 'right') { + if (programCell) { + scrollHelper.toCenter(programGrid, programCell, true, true); + } + } else if (lastFocusDirection === 'up' || lastFocusDirection === 'down') { + const verticalScroller = dom.parentWithClass(target, 'guideVerticalScroller'); + if (verticalScroller) { + const focusedElement = programCell || dom.parentWithTag(target, 'BUTTON'); + verticalScroller.toCenter(focusedElement, true); + } + } + } + + function setScrollEvents(view, enabled) { + if (layoutManager.tv) { + const guideVerticalScroller = view.querySelector('.guideVerticalScroller'); + + if (enabled) { + inputManager.on(guideVerticalScroller, onInputCommand); + } else { + inputManager.off(guideVerticalScroller, onInputCommand); + } + } + } + + function onTimerCreated(e, apiClient, data) { + const programId = data.ProgramId; + // This could be null, not supported by all tv providers + const newTimerId = data.Id; + + // find guide cells by program id, ensure timer icon + const cells = options.element.querySelectorAll('.programCell[data-id="' + programId + '"]'); + for (let i = 0, length = cells.length; i < length; i++) { + const cell = cells[i]; + + const icon = cell.querySelector('.timerIcon'); + if (!icon) { + cell.querySelector('.guideProgramName').insertAdjacentHTML('beforeend', ''); + } + + if (newTimerId) { + cell.setAttribute('data-timerid', newTimerId); + } + } + } + + function onSeriesTimerCreated(e, apiClient, data) { + } + + function onTimerCancelled(e, apiClient, data) { + const id = data.Id; + // find guide cells by timer id, remove timer icon + const cells = options.element.querySelectorAll('.programCell[data-timerid="' + id + '"]'); + for (let i = 0, length = cells.length; i < length; i++) { + const cell = cells[i]; + const icon = cell.querySelector('.timerIcon'); + if (icon) { + icon.parentNode.removeChild(icon); + } + cell.removeAttribute('data-timerid'); + } + } + + function onSeriesTimerCancelled(e, apiClient, data) { + const id = data.Id; + // find guide cells by timer id, remove timer icon + const cells = options.element.querySelectorAll('.programCell[data-seriestimerid="' + id + '"]'); + for (let i = 0, length = cells.length; i < length; i++) { + const cell = cells[i]; + const icon = cell.querySelector('.seriesTimerIcon'); + if (icon) { + icon.parentNode.removeChild(icon); + } + cell.removeAttribute('data-seriestimerid'); + } + } + + import('text!./tvguide.template.html').then(({default: template}) => { + const context = options.element; + + context.classList.add('tvguide'); + + context.innerHTML = globalize.translateHtml(template, 'core'); + + programGrid = context.querySelector('.programGrid'); + const timeslotHeaders = context.querySelector('.timeslotHeaders'); + + if (layoutManager.tv) { + dom.addEventListener(context.querySelector('.guideVerticalScroller'), 'focus', onScrollerFocus, { + capture: true, + passive: true + }); + } else if (layoutManager.desktop) { + timeslotHeaders.classList.add('timeslotHeaders-desktop'); + } + + if (browser.iOS || browser.osx) { + context.querySelector('.channelsContainer').classList.add('noRubberBanding'); + + programGrid.classList.add('noRubberBanding'); + } + + dom.addEventListener(programGrid, 'scroll', function (e) { + onProgramGridScroll(context, this, timeslotHeaders); + }, { + passive: true + }); + + dom.addEventListener(timeslotHeaders, 'scroll', function () { + onTimeslotHeadersScroll(context, this); + }, { + passive: true + }); + + programGrid.addEventListener('click', onProgramGridClick); + + context.querySelector('.btnNextPage').addEventListener('click', function () { + currentStartIndex += currentChannelLimit; + reloadPage(context); + restartAutoRefresh(); + }); + + context.querySelector('.btnPreviousPage').addEventListener('click', function () { + currentStartIndex = Math.max(currentStartIndex - currentChannelLimit, 0); + reloadPage(context); + restartAutoRefresh(); + }); + + context.querySelector('.btnGuideViewSettings').addEventListener('click', function () { + showViewSettings(self); + restartAutoRefresh(); + }); + + context.querySelector('.guideDateTabs').addEventListener('tabchange', function (e) { + const allTabButtons = e.target.querySelectorAll('.guide-date-tab-button'); + + const tabButton = allTabButtons[parseInt(e.detail.selectedTabIndex)]; + if (tabButton) { + const previousButton = e.detail.previousIndex == null ? null : allTabButtons[parseInt(e.detail.previousIndex)]; + + const date = new Date(); + date.setTime(parseInt(tabButton.getAttribute('data-date'))); + + const scrollWidth = programGrid.scrollWidth; + let scrollToTimeMs; + if (scrollWidth) { + scrollToTimeMs = (programGrid.scrollLeft / scrollWidth) * msPerDay; + } else { + scrollToTimeMs = 0; + } + + if (previousButton) { + const previousDate = new Date(); + previousDate.setTime(parseInt(previousButton.getAttribute('data-date'))); + + scrollToTimeMs += (previousDate.getHours() * 60 * 60 * 1000); + scrollToTimeMs += (previousDate.getMinutes() * 60 * 1000); + } + + let startTimeOfDayMs = (date.getHours() * 60 * 60 * 1000); + startTimeOfDayMs += (date.getMinutes() * 60 * 1000); + + changeDate(context, date, scrollToTimeMs, scrollToTimeMs, startTimeOfDayMs, false); + } + }); + + setScrollEvents(context, true); + itemShortcuts.on(context); + + events.trigger(self, 'load'); + + events.on(serverNotifications, 'TimerCreated', onTimerCreated); + events.on(serverNotifications, 'SeriesTimerCreated', onSeriesTimerCreated); + events.on(serverNotifications, 'TimerCancelled', onTimerCancelled); + events.on(serverNotifications, 'SeriesTimerCancelled', onSeriesTimerCancelled); + + self.refresh(); + }); +} + +export default Guide; diff --git a/src/controllers/livetv/livetvguide.js b/src/controllers/livetv/livetvguide.js index ec7a7a3f81..f89c2693be 100644 --- a/src/controllers/livetv/livetvguide.js +++ b/src/controllers/livetv/livetvguide.js @@ -7,7 +7,7 @@ define(['tvguide'], function (tvguide) { self.renderTab = function () { if (!guideInstance) { - guideInstance = new tvguide({ + guideInstance = new tvguide.default({ element: tabContent, serverId: ApiClient.serverId() }); From 1b69c89b3119b8b4017d94b0ec048ff76a0ca1a1 Mon Sep 17 00:00:00 2001 From: Cameron Date: Wed, 5 Aug 2020 09:13:46 +0100 Subject: [PATCH 034/301] replace for with for...of --- src/components/guide/guide-settings.js | 48 ++++++++++++-------------- src/components/guide/guide.js | 32 ++++++++--------- 2 files changed, 38 insertions(+), 42 deletions(-) diff --git a/src/components/guide/guide-settings.js b/src/components/guide/guide-settings.js index b62604ab98..35f0d3e06e 100644 --- a/src/components/guide/guide-settings.js +++ b/src/components/guide/guide-settings.js @@ -12,10 +12,10 @@ function saveCategories(context, options) { const categories = []; const chkCategorys = context.querySelectorAll('.chkCategory'); - for (let i = 0, length = chkCategorys.length; i < length; i++) { - const type = chkCategorys[i].getAttribute('data-type'); + for (const chkCategory of chkCategorys) { + const type = chkCategory.getAttribute('data-type'); - if (chkCategorys[i].checked) { + if (chkCategory.checked) { categories.push(type); } } @@ -33,47 +33,43 @@ function loadCategories(context, options) { const selectedCategories = options.categories || []; const chkCategorys = context.querySelectorAll('.chkCategory'); - for (let i = 0, length = chkCategorys.length; i < length; i++) { - const type = chkCategorys[i].getAttribute('data-type'); + for (const chkCategory of chkCategorys) { + const type = chkCategory.getAttribute('data-type'); - chkCategorys[i].checked = !selectedCategories.length || selectedCategories.indexOf(type) !== -1; + chkCategory.checked = !selectedCategories.length || selectedCategories.indexOf(type) !== -1; } } function save(context) { - let i; - let length; - const chkIndicators = context.querySelectorAll('.chkIndicator'); - for (i = 0, length = chkIndicators.length; i < length; i++) { - const type = chkIndicators[i].getAttribute('data-type'); - userSettings.set('guide-indicator-' + type, chkIndicators[i].checked); + + for (const chkIndicator of chkIndicators) { + const type = chkIndicator.getAttribute('data-type'); + userSettings.set('guide-indicator-' + type, chkIndicator.checked); } userSettings.set('guide-colorcodedbackgrounds', context.querySelector('.chkColorCodedBackgrounds').checked); userSettings.set('livetv-favoritechannelsattop', context.querySelector('.chkFavoriteChannelsAtTop').checked); const sortBys = context.querySelectorAll('.chkSortOrder'); - for (i = 0, length = sortBys.length; i < length; i++) { - if (sortBys[i].checked) { - userSettings.set('livetv-channelorder', sortBys[i].value); + for (const sortBy of sortBys) { + if (sortBy.checked) { + userSettings.set('livetv-channelorder', sortBy.value); break; } } } function load(context) { - let i; - let length; - const chkIndicators = context.querySelectorAll('.chkIndicator'); - for (i = 0, length = chkIndicators.length; i < length; i++) { - const type = chkIndicators[i].getAttribute('data-type'); - if (chkIndicators[i].getAttribute('data-default') === 'true') { - chkIndicators[i].checked = userSettings.get('guide-indicator-' + type) !== 'false'; + for (const chkIndicator of chkIndicators) { + const type = chkIndicator.getAttribute('data-type'); + + if (chkIndicator.getAttribute('data-default') === 'true') { + chkIndicator.checked = userSettings.get('guide-indicator-' + type) !== 'false'; } else { - chkIndicators[i].checked = userSettings.get('guide-indicator-' + type) === 'true'; + chkIndicator.checked = userSettings.get('guide-indicator-' + type) === 'true'; } } @@ -83,8 +79,8 @@ function load(context) { const sortByValue = userSettings.get('livetv-channelorder') || 'Number'; const sortBys = context.querySelectorAll('.chkSortOrder'); - for (i = 0, length = sortBys.length; i < length; i++) { - sortBys[i].checked = sortBys[i].value === sortByValue; + for (const sortBy of sortBys) { + sortBy.checked = sortBy.value === sortByValue; } } @@ -92,7 +88,7 @@ function showEditor(options) { return new Promise(function (resolve, reject) { let settingsChanged = false; - import('text!./guide-settings.template.html').then(({default: template}) => { + import('text!./guide-settings.template.html').then(({ default: template }) => { const dialogOptions = { removeOnClose: true, scrollY: false diff --git a/src/components/guide/guide.js b/src/components/guide/guide.js index e48d4646c0..a7b32d887d 100644 --- a/src/components/guide/guide.js +++ b/src/components/guide/guide.js @@ -88,8 +88,8 @@ function updateProgramCellsOnScroll(programGrid, programCells) { const scrollPct = scrollLeft ? (scrollLeft / programGrid.scrollWidth) * 100 : 0; - for (let i = 0, length = programCells.length; i < length; i++) { - updateProgramCellOnScroll(programCells[i], scrollPct); + for (const programCell of programCells) { + updateProgramCellOnScroll(programCell, scrollPct); } isUpdatingProgramCellScroll = false; @@ -588,8 +588,7 @@ function Guide(options) { function renderChannelHeaders(context, channels, apiClient) { let html = ''; - for (let i = 0, length = channels.length; i < length; i++) { - const channel = channels[i]; + for (const channel of channels) { const hasChannelImage = channel.ImageTags.Primary; let cssClass = 'guide-channelHeaderCell itemAction'; @@ -641,8 +640,8 @@ function Guide(options) { const html = []; - for (let i = 0, length = channels.length; i < length; i++) { - html.push(getChannelProgramsHtml(context, date, channels[i], programs, options, listInfo)); + for (const channel of channels) { + html.push(getChannelProgramsHtml(context, date, channel, programs, options, listInfo)); } programGrid.innerHTML = html.join(''); @@ -888,11 +887,10 @@ function Guide(options) { // add 1 to avoid programs that are out of view to the left const currentScrollXPct = scrollXPct + 1; - for (let i = 0, length = elements.length; i < length; i++) { - const elem = elements[i]; - + for (const elem of elements) { let left = (elem.style.left || '').replace('%', ''); left = left ? parseFloat(left) : 0; + let width = (elem.style.width || '').replace('%', ''); width = width ? parseFloat(width) : 0; @@ -1047,9 +1045,7 @@ function Guide(options) { // find guide cells by program id, ensure timer icon const cells = options.element.querySelectorAll('.programCell[data-id="' + programId + '"]'); - for (let i = 0, length = cells.length; i < length; i++) { - const cell = cells[i]; - + for (const cell of cells) { const icon = cell.querySelector('.timerIcon'); if (!icon) { cell.querySelector('.guideProgramName').insertAdjacentHTML('beforeend', ''); @@ -1068,12 +1064,14 @@ function Guide(options) { const id = data.Id; // find guide cells by timer id, remove timer icon const cells = options.element.querySelectorAll('.programCell[data-timerid="' + id + '"]'); - for (let i = 0, length = cells.length; i < length; i++) { - const cell = cells[i]; + + for (const cell of cells) { const icon = cell.querySelector('.timerIcon'); + if (icon) { icon.parentNode.removeChild(icon); } + cell.removeAttribute('data-timerid'); } } @@ -1082,12 +1080,14 @@ function Guide(options) { const id = data.Id; // find guide cells by timer id, remove timer icon const cells = options.element.querySelectorAll('.programCell[data-seriestimerid="' + id + '"]'); - for (let i = 0, length = cells.length; i < length; i++) { - const cell = cells[i]; + + for (const cell of cells) { const icon = cell.querySelector('.seriesTimerIcon'); + if (icon) { icon.parentNode.removeChild(icon); } + cell.removeAttribute('data-seriestimerid'); } } From 84b9dc95f66237bfbeac58c9c7eff8114c4c8c27 Mon Sep 17 00:00:00 2001 From: Cameron Date: Wed, 5 Aug 2020 10:13:11 +0100 Subject: [PATCH 035/301] Migration of recording editor and fields to ES6 modules --- package.json | 2 + .../recordingcreator/recordingcreator.js | 2 +- .../recordingcreator/recordingeditor.js | 275 ++++++------ .../recordingcreator/recordingfields.js | 402 +++++++++--------- 4 files changed, 353 insertions(+), 328 deletions(-) diff --git a/package.json b/package.json index 8408217bf3..b38116cc5b 100644 --- a/package.json +++ b/package.json @@ -153,6 +153,8 @@ "src/components/playmenu.js", "src/components/prompt/prompt.js", "src/components/refreshdialog/refreshdialog.js", + "src/components/recordingcreator/recordingeditor.js", + "src/components/recordingcreator/recordingfields.js", "src/components/sanatizefilename.js", "src/components/scrollManager.js", "src/plugins/htmlVideoPlayer/plugin.js", diff --git a/src/components/recordingcreator/recordingcreator.js b/src/components/recordingcreator/recordingcreator.js index ca5c475829..511ba00fcd 100644 --- a/src/components/recordingcreator/recordingcreator.js +++ b/src/components/recordingcreator/recordingcreator.js @@ -168,7 +168,7 @@ define(['dialogHelper', 'globalize', 'layoutManager', 'mediaInfo', 'apphost', 'c reload(dlg, itemId, serverId); - currentRecordingFields = new recordingFields({ + currentRecordingFields = new recordingFields.default({ parent: dlg.querySelector('.recordingFields'), programId: itemId, serverId: serverId diff --git a/src/components/recordingcreator/recordingeditor.js b/src/components/recordingcreator/recordingeditor.js index 2086129a9e..047d491c02 100644 --- a/src/components/recordingcreator/recordingeditor.js +++ b/src/components/recordingcreator/recordingeditor.js @@ -1,147 +1,160 @@ -define(['dialogHelper', 'globalize', 'layoutManager', 'mediaInfo', 'apphost', 'connectionManager', 'require', 'loading', 'scrollHelper', 'imageLoader', 'scrollStyles', 'emby-button', 'emby-collapse', 'emby-input', 'paper-icon-button-light', 'css!./../formdialog', 'css!./recordingcreator', 'material-icons', 'flexStyles'], function (dialogHelper, globalize, layoutManager, mediaInfo, appHost, connectionManager, require, loading, scrollHelper, imageLoader) { - 'use strict'; +import dialogHelper from 'dialogHelper'; +import globalize from 'globalize'; +import layoutManager from 'layoutManager'; +import connectionManager from 'connectionManager'; +import require from 'require'; +import loading from 'loading'; +import scrollHelper from 'scrollHelper'; +import 'scrollStyles'; +import 'emby-button'; +import 'emby-collapse'; +import 'emby-input'; +import 'paper-icon-button-light'; +import 'css!./../formdialog'; +import 'css!./recordingcreator'; +import 'material-icons'; +import 'flexStyles'; - loading = loading.default || loading; +/*eslint prefer-const: "error"*/ - var currentDialog; - var recordingDeleted = false; - var currentItemId; - var currentServerId; - var currentResolve; +let currentDialog; +let recordingDeleted = false; +let currentItemId; +let currentServerId; +let currentResolve; - function deleteTimer(apiClient, timerId) { - return new Promise(function (resolve, reject) { - require(['recordingHelper'], function (recordingHelper) { - recordingHelper.cancelTimerWithConfirmation(timerId, apiClient.serverId()).then(resolve, reject); - }); +function deleteTimer(apiClient, timerId) { + return new Promise(function (resolve, reject) { + require(['recordingHelper'], function (recordingHelper) { + recordingHelper.cancelTimerWithConfirmation(timerId, apiClient.serverId()).then(resolve, reject); }); - } + }); +} - function renderTimer(context, item, apiClient) { - context.querySelector('#txtPrePaddingMinutes').value = item.PrePaddingSeconds / 60; - context.querySelector('#txtPostPaddingMinutes').value = item.PostPaddingSeconds / 60; +function renderTimer(context, item, apiClient) { + context.querySelector('#txtPrePaddingMinutes').value = item.PrePaddingSeconds / 60; + context.querySelector('#txtPostPaddingMinutes').value = item.PostPaddingSeconds / 60; + loading.hide(); +} + +function closeDialog(isDeleted) { + recordingDeleted = isDeleted; + + dialogHelper.close(currentDialog); +} + +function onSubmit(e) { + const form = this; + + const apiClient = connectionManager.getApiClient(currentServerId); + + apiClient.getLiveTvTimer(currentItemId).then(function (item) { + item.PrePaddingSeconds = form.querySelector('#txtPrePaddingMinutes').value * 60; + item.PostPaddingSeconds = form.querySelector('#txtPostPaddingMinutes').value * 60; + apiClient.updateLiveTvTimer(item).then(currentResolve); + }); + + e.preventDefault(); + + // Disable default form submission + return false; +} + +function init(context) { + context.querySelector('.btnCancel').addEventListener('click', function () { + closeDialog(false); + }); + + context.querySelector('.btnCancelRecording').addEventListener('click', function () { + const apiClient = connectionManager.getApiClient(currentServerId); + deleteTimer(apiClient, currentItemId).then(function () { + closeDialog(true); + }); + }); + + context.querySelector('form').addEventListener('submit', onSubmit); +} + +function reload(context, id) { + loading.show(); + currentItemId = id; + + const apiClient = connectionManager.getApiClient(currentServerId); + apiClient.getLiveTvTimer(id).then(function (result) { + renderTimer(context, result, apiClient); loading.hide(); - } + }); +} - function closeDialog(isDeleted) { - recordingDeleted = isDeleted; - - dialogHelper.close(currentDialog); - } - - function onSubmit(e) { - var form = this; - - var apiClient = connectionManager.getApiClient(currentServerId); - - apiClient.getLiveTvTimer(currentItemId).then(function (item) { - item.PrePaddingSeconds = form.querySelector('#txtPrePaddingMinutes').value * 60; - item.PostPaddingSeconds = form.querySelector('#txtPostPaddingMinutes').value * 60; - apiClient.updateLiveTvTimer(item).then(currentResolve); - }); - - e.preventDefault(); - - // Disable default form submission - return false; - } - - function init(context) { - context.querySelector('.btnCancel').addEventListener('click', function () { - closeDialog(false); - }); - - context.querySelector('.btnCancelRecording').addEventListener('click', function () { - var apiClient = connectionManager.getApiClient(currentServerId); - deleteTimer(apiClient, currentItemId).then(function () { - closeDialog(true); - }); - }); - - context.querySelector('form').addEventListener('submit', onSubmit); - } - - function reload(context, id) { +function showEditor(itemId, serverId, options) { + return new Promise(function (resolve, reject) { + recordingDeleted = false; + currentServerId = serverId; loading.show(); - currentItemId = id; + options = options || {}; + currentResolve = resolve; - var apiClient = connectionManager.getApiClient(currentServerId); - apiClient.getLiveTvTimer(id).then(function (result) { - renderTimer(context, result, apiClient); - loading.hide(); - }); - } + require(['text!./recordingeditor.template.html'], function (template) { + const dialogOptions = { + removeOnClose: true, + scrollY: false + }; - function showEditor(itemId, serverId, options) { - return new Promise(function (resolve, reject) { - recordingDeleted = false; - currentServerId = serverId; - loading.show(); - options = options || {}; - currentResolve = resolve; + if (layoutManager.tv) { + dialogOptions.size = 'fullscreen'; + } - require(['text!./recordingeditor.template.html'], function (template) { - var dialogOptions = { - removeOnClose: true, - scrollY: false - }; + const dlg = dialogHelper.createDialog(dialogOptions); - if (layoutManager.tv) { - dialogOptions.size = 'fullscreen'; + dlg.classList.add('formDialog'); + dlg.classList.add('recordingDialog'); + + if (!layoutManager.tv) { + dlg.style['min-width'] = '20%'; + dlg.classList.add('dialog-fullscreen-lowres'); + } + + let html = ''; + + html += globalize.translateHtml(template, 'core'); + + dlg.innerHTML = html; + + if (options.enableCancel === false) { + dlg.querySelector('.formDialogFooter').classList.add('hide'); + } + + currentDialog = dlg; + + dlg.addEventListener('closing', function () { + if (!recordingDeleted) { + dlg.querySelector('.btnSubmit').click(); } - - var dlg = dialogHelper.createDialog(dialogOptions); - - dlg.classList.add('formDialog'); - dlg.classList.add('recordingDialog'); - - if (!layoutManager.tv) { - dlg.style['min-width'] = '20%'; - dlg.classList.add('dialog-fullscreen-lowres'); - } - - var html = ''; - - html += globalize.translateHtml(template, 'core'); - - dlg.innerHTML = html; - - if (options.enableCancel === false) { - dlg.querySelector('.formDialogFooter').classList.add('hide'); - } - - currentDialog = dlg; - - dlg.addEventListener('closing', function () { - if (!recordingDeleted) { - dlg.querySelector('.btnSubmit').click(); - } - }); - - dlg.addEventListener('close', function () { - if (recordingDeleted) { - resolve({ - updated: true, - deleted: true - }); - } - }); - - if (layoutManager.tv) { - scrollHelper.centerFocus.on(dlg.querySelector('.formDialogContent'), false); - } - - init(dlg); - - reload(dlg, itemId); - - dialogHelper.open(dlg); }); - }); - } - return { - show: showEditor - }; -}); + dlg.addEventListener('close', function () { + if (recordingDeleted) { + resolve({ + updated: true, + deleted: true + }); + } + }); + + if (layoutManager.tv) { + scrollHelper.centerFocus.on(dlg.querySelector('.formDialogContent'), false); + } + + init(dlg); + + reload(dlg, itemId); + + dialogHelper.open(dlg); + }); + }); +} + +export default { + show: showEditor +}; diff --git a/src/components/recordingcreator/recordingfields.js b/src/components/recordingcreator/recordingfields.js index e3739f1cfe..d9d7c0098c 100644 --- a/src/components/recordingcreator/recordingfields.js +++ b/src/components/recordingcreator/recordingfields.js @@ -1,221 +1,126 @@ -define(['globalize', 'connectionManager', 'serverNotifications', 'require', 'loading', 'apphost', 'dom', 'recordingHelper', 'events', 'paper-icon-button-light', 'emby-button', 'css!./recordingfields', 'flexStyles'], function (globalize, connectionManager, serverNotifications, require, loading, appHost, dom, recordingHelper, events) { - 'use strict'; +import globalize from 'globalize'; +import connectionManager from 'connectionManager'; +import serverNotifications from 'serverNotifications'; +import loading from 'loading'; +import dom from 'dom'; +import recordingHelper from 'recordingHelper'; +import events from 'events'; +import 'paper-icon-button-light'; +import 'emby-button'; +import 'css!./recordingfields'; +import 'flexStyles'; - loading = loading.default || loading; +/*eslint prefer-const: "error"*/ - function loadData(parent, program, apiClient) { - if (program.IsSeries) { - parent.querySelector('.recordSeriesContainer').classList.remove('hide'); +function loadData(parent, program, apiClient) { + if (program.IsSeries) { + parent.querySelector('.recordSeriesContainer').classList.remove('hide'); + } else { + parent.querySelector('.recordSeriesContainer').classList.add('hide'); + } + + if (program.SeriesTimerId) { + parent.querySelector('.btnManageSeriesRecording').classList.remove('hide'); + parent.querySelector('.seriesRecordingButton .recordingIcon').classList.add('recordingIcon-active'); + parent.querySelector('.seriesRecordingButton .buttonText').innerHTML = globalize.translate('CancelSeries'); + } else { + parent.querySelector('.btnManageSeriesRecording').classList.add('hide'); + parent.querySelector('.seriesRecordingButton .recordingIcon').classList.remove('recordingIcon-active'); + parent.querySelector('.seriesRecordingButton .buttonText').innerHTML = globalize.translate('RecordSeries'); + } + + if (program.TimerId && program.Status !== 'Cancelled') { + parent.querySelector('.btnManageRecording').classList.remove('hide'); + parent.querySelector('.singleRecordingButton .recordingIcon').classList.add('recordingIcon-active'); + if (program.Status === 'InProgress') { + parent.querySelector('.singleRecordingButton .buttonText').innerHTML = globalize.translate('StopRecording'); } else { - parent.querySelector('.recordSeriesContainer').classList.add('hide'); + parent.querySelector('.singleRecordingButton .buttonText').innerHTML = globalize.translate('DoNotRecord'); } + } else { + parent.querySelector('.btnManageRecording').classList.add('hide'); + parent.querySelector('.singleRecordingButton .recordingIcon').classList.remove('recordingIcon-active'); + parent.querySelector('.singleRecordingButton .buttonText').innerHTML = globalize.translate('Record'); + } +} - if (program.SeriesTimerId) { - parent.querySelector('.btnManageSeriesRecording').classList.remove('hide'); - parent.querySelector('.seriesRecordingButton .recordingIcon').classList.add('recordingIcon-active'); - parent.querySelector('.seriesRecordingButton .buttonText').innerHTML = globalize.translate('CancelSeries'); - } else { - parent.querySelector('.btnManageSeriesRecording').classList.add('hide'); - parent.querySelector('.seriesRecordingButton .recordingIcon').classList.remove('recordingIcon-active'); - parent.querySelector('.seriesRecordingButton .buttonText').innerHTML = globalize.translate('RecordSeries'); +function fetchData(instance) { + const options = instance.options; + const apiClient = connectionManager.getApiClient(options.serverId); + + options.parent.querySelector('.recordingFields').classList.remove('hide'); + return apiClient.getLiveTvProgram(options.programId, apiClient.getCurrentUserId()).then(function (program) { + instance.TimerId = program.TimerId; + instance.Status = program.Status; + instance.SeriesTimerId = program.SeriesTimerId; + loadData(options.parent, program, apiClient); + }); +} + +function onTimerChangedExternally(e, apiClient, data) { + const options = this.options; + let refresh = false; + + if (data.Id) { + if (this.TimerId === data.Id) { + refresh = true; } - - if (program.TimerId && program.Status !== 'Cancelled') { - parent.querySelector('.btnManageRecording').classList.remove('hide'); - parent.querySelector('.singleRecordingButton .recordingIcon').classList.add('recordingIcon-active'); - if (program.Status === 'InProgress') { - parent.querySelector('.singleRecordingButton .buttonText').innerHTML = globalize.translate('StopRecording'); - } else { - parent.querySelector('.singleRecordingButton .buttonText').innerHTML = globalize.translate('DoNotRecord'); - } - } else { - parent.querySelector('.btnManageRecording').classList.add('hide'); - parent.querySelector('.singleRecordingButton .recordingIcon').classList.remove('recordingIcon-active'); - parent.querySelector('.singleRecordingButton .buttonText').innerHTML = globalize.translate('Record'); + } + if (data.ProgramId && options) { + if (options.programId === data.ProgramId) { + refresh = true; } } - function fetchData(instance) { - var options = instance.options; - var apiClient = connectionManager.getApiClient(options.serverId); - - options.parent.querySelector('.recordingFields').classList.remove('hide'); - return apiClient.getLiveTvProgram(options.programId, apiClient.getCurrentUserId()).then(function (program) { - instance.TimerId = program.TimerId; - instance.Status = program.Status; - instance.SeriesTimerId = program.SeriesTimerId; - loadData(options.parent, program, apiClient); - }); + if (refresh) { + this.refresh(); } +} - function onTimerChangedExternally(e, apiClient, data) { - var options = this.options; - var refresh = false; +function onSeriesTimerChangedExternally(e, apiClient, data) { + const options = this.options; + let refresh = false; - if (data.Id) { - if (this.TimerId === data.Id) { - refresh = true; - } + if (data.Id) { + if (this.SeriesTimerId === data.Id) { + refresh = true; } - if (data.ProgramId && options) { - if (options.programId === data.ProgramId) { - refresh = true; - } - } - - if (refresh) { - this.refresh(); + } + if (data.ProgramId && options) { + if (options.programId === data.ProgramId) { + refresh = true; } } - function onSeriesTimerChangedExternally(e, apiClient, data) { - var options = this.options; - var refresh = false; - - if (data.Id) { - if (this.SeriesTimerId === data.Id) { - refresh = true; - } - } - if (data.ProgramId && options) { - if (options.programId === data.ProgramId) { - refresh = true; - } - } - - if (refresh) { - this.refresh(); - } + if (refresh) { + this.refresh(); } +} - function RecordingEditor(options) { +class RecordingEditor { + constructor(options) { this.options = options; this.embed(); - var timerChangedHandler = onTimerChangedExternally.bind(this); + const timerChangedHandler = onTimerChangedExternally.bind(this); this.timerChangedHandler = timerChangedHandler; events.on(serverNotifications, 'TimerCreated', timerChangedHandler); events.on(serverNotifications, 'TimerCancelled', timerChangedHandler); - var seriesTimerChangedHandler = onSeriesTimerChangedExternally.bind(this); + const seriesTimerChangedHandler = onSeriesTimerChangedExternally.bind(this); this.seriesTimerChangedHandler = seriesTimerChangedHandler; events.on(serverNotifications, 'SeriesTimerCreated', seriesTimerChangedHandler); events.on(serverNotifications, 'SeriesTimerCancelled', seriesTimerChangedHandler); } - function onManageRecordingClick(e) { - var options = this.options; - if (!this.TimerId || this.Status === 'Cancelled') { - return; - } - - var self = this; - require(['recordingEditor'], function (recordingEditor) { - recordingEditor.show(self.TimerId, options.serverId, { - enableCancel: false - }).then(function () { - self.changed = true; - }); - }); - } - - function onManageSeriesRecordingClick(e) { - var options = this.options; - - if (!this.SeriesTimerId) { - return; - } - - var self = this; - - require(['seriesRecordingEditor'], function (seriesRecordingEditor) { - seriesRecordingEditor.show(self.SeriesTimerId, options.serverId, { - - enableCancel: false - - }).then(function () { - self.changed = true; - }); - }); - } - - function onRecordChange(e) { - this.changed = true; - - var self = this; - var options = this.options; - var apiClient = connectionManager.getApiClient(options.serverId); - - var button = dom.parentWithTag(e.target, 'BUTTON'); - var isChecked = !button.querySelector('.material-icons').classList.contains('recordingIcon-active'); - - var hasEnabledTimer = this.TimerId && this.Status !== 'Cancelled'; - - if (isChecked) { - if (!hasEnabledTimer) { - loading.show(); - recordingHelper.createRecording(apiClient, options.programId, false).then(function () { - events.trigger(self, 'recordingchanged'); - fetchData(self); - loading.hide(); - }); - } - } else { - if (hasEnabledTimer) { - loading.show(); - recordingHelper.cancelTimer(apiClient, this.TimerId, true).then(function () { - events.trigger(self, 'recordingchanged'); - fetchData(self); - loading.hide(); - }); - } - } - } - - function sendToast(msg) { - require(['toast'], function (toast) { - toast(msg); - }); - } - - function onRecordSeriesChange(e) { - this.changed = true; - - var self = this; - var options = this.options; - var apiClient = connectionManager.getApiClient(options.serverId); - - var button = dom.parentWithTag(e.target, 'BUTTON'); - var isChecked = !button.querySelector('.material-icons').classList.contains('recordingIcon-active'); - - if (isChecked) { - options.parent.querySelector('.recordSeriesContainer').classList.remove('hide'); - if (!this.SeriesTimerId) { - var promise = this.TimerId ? - recordingHelper.changeRecordingToSeries(apiClient, this.TimerId, options.programId) : - recordingHelper.createRecording(apiClient, options.programId, true); - promise.then(function () { - fetchData(self); - }); - } - } else { - if (this.SeriesTimerId) { - apiClient.cancelLiveTvSeriesTimer(this.SeriesTimerId).then(function () { - sendToast(globalize.translate('RecordingCancelled')); - fetchData(self); - }); - } - } - } - - RecordingEditor.prototype.embed = function () { - var self = this; + embed() { + const self = this; return new Promise(function (resolve, reject) { - require(['text!./recordingfields.template.html'], function (template) { - var options = self.options; - var context = options.parent; + import('text!./recordingfields.template.html').then(({default: template}) => { + const options = self.options; + const context = options.parent; context.innerHTML = globalize.translateHtml(template, 'core'); context.querySelector('.singleRecordingButton').addEventListener('click', onRecordChange.bind(self)); @@ -226,29 +131,134 @@ define(['globalize', 'connectionManager', 'serverNotifications', 'require', 'loa fetchData(self).then(resolve); }); }); - }; + } - RecordingEditor.prototype.hasChanged = function () { + hasChanged() { return this.changed; - }; + } - RecordingEditor.prototype.refresh = function () { + refresh() { fetchData(this); - }; + } - RecordingEditor.prototype.destroy = function () { - var timerChangedHandler = this.timerChangedHandler; + destroy() { + const timerChangedHandler = this.timerChangedHandler; this.timerChangedHandler = null; events.off(serverNotifications, 'TimerCreated', timerChangedHandler); events.off(serverNotifications, 'TimerCancelled', timerChangedHandler); - var seriesTimerChangedHandler = this.seriesTimerChangedHandler; + const seriesTimerChangedHandler = this.seriesTimerChangedHandler; this.seriesTimerChangedHandler = null; events.off(serverNotifications, 'SeriesTimerCreated', seriesTimerChangedHandler); events.off(serverNotifications, 'SeriesTimerCancelled', seriesTimerChangedHandler); - }; + } +} - return RecordingEditor; -}); +function onManageRecordingClick(e) { + const options = this.options; + if (!this.TimerId || this.Status === 'Cancelled') { + return; + } + + const self = this; + import('recordingEditor').then(({default: recordingEditor}) => { + recordingEditor.show(self.TimerId, options.serverId, { + enableCancel: false + }).then(function () { + self.changed = true; + }); + }); +} + +function onManageSeriesRecordingClick(e) { + const options = this.options; + + if (!this.SeriesTimerId) { + return; + } + + const self = this; + + import('seriesRecordingEditor').then(({default: seriesRecordingEditor}) => { + seriesRecordingEditor.show(self.SeriesTimerId, options.serverId, { + + enableCancel: false + + }).then(function () { + self.changed = true; + }); + }); +} + +function onRecordChange(e) { + this.changed = true; + + const self = this; + const options = this.options; + const apiClient = connectionManager.getApiClient(options.serverId); + + const button = dom.parentWithTag(e.target, 'BUTTON'); + const isChecked = !button.querySelector('.material-icons').classList.contains('recordingIcon-active'); + + const hasEnabledTimer = this.TimerId && this.Status !== 'Cancelled'; + + if (isChecked) { + if (!hasEnabledTimer) { + loading.show(); + recordingHelper.createRecording(apiClient, options.programId, false).then(function () { + events.trigger(self, 'recordingchanged'); + fetchData(self); + loading.hide(); + }); + } + } else { + if (hasEnabledTimer) { + loading.show(); + recordingHelper.cancelTimer(apiClient, this.TimerId, true).then(function () { + events.trigger(self, 'recordingchanged'); + fetchData(self); + loading.hide(); + }); + } + } +} + +function sendToast(msg) { + import('toast').then(({default: toast}) => { + toast(msg); + }); +} + +function onRecordSeriesChange(e) { + this.changed = true; + + const self = this; + const options = this.options; + const apiClient = connectionManager.getApiClient(options.serverId); + + const button = dom.parentWithTag(e.target, 'BUTTON'); + const isChecked = !button.querySelector('.material-icons').classList.contains('recordingIcon-active'); + + if (isChecked) { + options.parent.querySelector('.recordSeriesContainer').classList.remove('hide'); + if (!this.SeriesTimerId) { + const promise = this.TimerId ? + recordingHelper.changeRecordingToSeries(apiClient, this.TimerId, options.programId) : + recordingHelper.createRecording(apiClient, options.programId, true); + promise.then(function () { + fetchData(self); + }); + } + } else { + if (this.SeriesTimerId) { + apiClient.cancelLiveTvSeriesTimer(this.SeriesTimerId).then(function () { + sendToast(globalize.translate('RecordingCancelled')); + fetchData(self); + }); + } + } +} + +export default RecordingEditor; From 60be236f1c04c93e2ed0a5b93e38a43786ba568f Mon Sep 17 00:00:00 2001 From: Cameron Date: Wed, 5 Aug 2020 19:24:22 +0100 Subject: [PATCH 036/301] Remove empy Constructor --- src/components/layoutManager.js | 3 --- 1 file changed, 3 deletions(-) diff --git a/src/components/layoutManager.js b/src/components/layoutManager.js index d104632573..88a7265f8b 100644 --- a/src/components/layoutManager.js +++ b/src/components/layoutManager.js @@ -13,9 +13,6 @@ function setLayout(instance, layout, selectedLayout) { } class LayoutManager { - constructor() { - } - setLayout(layout, save) { if (!layout || layout === 'auto') { this.autoLayout(); From 3925c8eddb93854e0bce6aa8aa96bedd45e3ff2a Mon Sep 17 00:00:00 2001 From: Cameron Date: Wed, 5 Aug 2020 19:25:22 +0100 Subject: [PATCH 037/301] remove empty destory --- src/plugins/htmlAudioPlayer/plugin.js | 3 --- 1 file changed, 3 deletions(-) diff --git a/src/plugins/htmlAudioPlayer/plugin.js b/src/plugins/htmlAudioPlayer/plugin.js index c60349c5af..86d59aa54d 100644 --- a/src/plugins/htmlAudioPlayer/plugin.js +++ b/src/plugins/htmlAudioPlayer/plugin.js @@ -488,9 +488,6 @@ class HtmlAudioPlayer { return false; } - destroy() { - } - supports(feature) { if (!supportedFeatures) { supportedFeatures = getSupportedFeatures(); From 2e47b89ada6e6b65089b74b471460fe276b71eb5 Mon Sep 17 00:00:00 2001 From: Cameron Date: Wed, 5 Aug 2020 19:59:25 +0100 Subject: [PATCH 038/301] remove constructor --- src/components/viewManager/viewManager.js | 3 --- 1 file changed, 3 deletions(-) diff --git a/src/components/viewManager/viewManager.js b/src/components/viewManager/viewManager.js index 695535e7b8..00c3018590 100644 --- a/src/components/viewManager/viewManager.js +++ b/src/components/viewManager/viewManager.js @@ -127,9 +127,6 @@ function resetCachedViews() { document.addEventListener('skinunload', resetCachedViews); class ViewManager { - constructor() { - } - loadView(options) { const lastView = currentView; From 6e5dc7f7d11672ad70567cc3953220f6cd242611 Mon Sep 17 00:00:00 2001 From: Cameron Date: Wed, 5 Aug 2020 20:08:42 +0100 Subject: [PATCH 039/301] lint --- src/controllers/list.js | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/src/controllers/list.js b/src/controllers/list.js index 7d35bcf5cb..979bb76a20 100644 --- a/src/controllers/list.js +++ b/src/controllers/list.js @@ -744,7 +744,8 @@ class ItemsView { } const sortButtons = view.querySelectorAll('.btnSort'); - + let i; + let length; for (this.sortButtons = sortButtons, i = 0, length = sortButtons.length; i < length; i++) { const sortButton = sortButtons[i]; sortButton.addEventListener('click', showSortMenu.bind(this)); From 9d822d911af4fa09ef67a41bd20048d194ffeb13 Mon Sep 17 00:00:00 2001 From: Cameron Date: Thu, 6 Aug 2020 08:43:52 +0100 Subject: [PATCH 040/301] Migration of sortMenu to ES6 module --- package.json | 1 + src/components/sortmenu/sortmenu.js | 87 +++++++++++++++-------------- src/controllers/list.js | 2 +- 3 files changed, 48 insertions(+), 42 deletions(-) diff --git a/package.json b/package.json index 1d7cf770d3..33c4670d5d 100644 --- a/package.json +++ b/package.json @@ -155,6 +155,7 @@ "src/components/refreshdialog/refreshdialog.js", "src/components/sanatizefilename.js", "src/components/scrollManager.js", + "src/components/sortmenu/sortmenu.js", "src/plugins/htmlVideoPlayer/plugin.js", "src/components/search/searchfields.js", "src/components/search/searchresults.js", diff --git a/src/components/sortmenu/sortmenu.js b/src/components/sortmenu/sortmenu.js index f62e5bb3a4..d38d98c090 100644 --- a/src/components/sortmenu/sortmenu.js +++ b/src/components/sortmenu/sortmenu.js @@ -1,46 +1,51 @@ -define(['require', 'dom', 'focusManager', 'dialogHelper', 'loading', 'layoutManager', 'connectionManager', 'globalize', 'userSettings', 'emby-select', 'paper-icon-button-light', 'material-icons', 'css!./../formdialog', 'emby-button', 'flexStyles'], function (require, dom, focusManager, dialogHelper, loading, layoutManager, connectionManager, globalize, userSettings) { - 'use strict'; +import dialogHelper from 'dialogHelper'; +import layoutManager from 'layoutManager'; +import globalize from 'globalize'; +import * as userSettings from 'userSettings'; +import 'emby-select'; +import 'paper-icon-button-light'; +import 'material-icons'; +import 'css!./../formdialog'; +import 'emby-button'; +import 'flexStyles'; - function onSubmit(e) { - e.preventDefault(); - return false; - } +function onSubmit(e) { + e.preventDefault(); + return false; +} - function initEditor(context, settings) { - context.querySelector('form').addEventListener('submit', onSubmit); +function initEditor(context, settings) { + context.querySelector('form').addEventListener('submit', onSubmit); - context.querySelector('.selectSortOrder').value = settings.sortOrder; - context.querySelector('.selectSortBy').value = settings.sortBy; - } + context.querySelector('.selectSortOrder').value = settings.sortOrder; + context.querySelector('.selectSortBy').value = settings.sortBy; +} - function centerFocus(elem, horiz, on) { - require(['scrollHelper'], function (scrollHelper) { - var fn = on ? 'on' : 'off'; - scrollHelper.centerFocus[fn](elem, horiz); - }); - } +function centerFocus(elem, horiz, on) { + import('scrollHelper').then(({default: scrollHelper}) => { + const fn = on ? 'on' : 'off'; + scrollHelper.centerFocus[fn](elem, horiz); + }); +} - function fillSortBy(context, options) { - var selectSortBy = context.querySelector('.selectSortBy'); +function fillSortBy(context, options) { + const selectSortBy = context.querySelector('.selectSortBy'); - selectSortBy.innerHTML = options.map(function (o) { - return ''; - }).join(''); - } + selectSortBy.innerHTML = options.map(function (o) { + return ''; + }).join(''); +} - function saveValues(context, settings, settingsKey) { - userSettings.setFilter(settingsKey + '-sortorder', context.querySelector('.selectSortOrder').value); - userSettings.setFilter(settingsKey + '-sortby', context.querySelector('.selectSortBy').value); - } +function saveValues(context, settingsKey) { + userSettings.setFilter(settingsKey + '-sortorder', context.querySelector('.selectSortOrder').value); + userSettings.setFilter(settingsKey + '-sortby', context.querySelector('.selectSortBy').value); +} - function SortMenu() { - - } - - SortMenu.prototype.show = function (options) { +class SortMenu { + show(options) { return new Promise(function (resolve, reject) { - require(['text!./sortmenu.template.html'], function (template) { - var dialogOptions = { + import('text!./sortmenu.template.html').then(({default: template}) => { + const dialogOptions = { removeOnClose: true, scrollY: false }; @@ -51,11 +56,11 @@ define(['require', 'dom', 'focusManager', 'dialogHelper', 'loading', 'layoutMana dialogOptions.size = 'small'; } - var dlg = dialogHelper.createDialog(dialogOptions); + const dlg = dialogHelper.createDialog(dialogOptions); dlg.classList.add('formDialog'); - var html = ''; + let html = ''; html += '
'; html += ''; @@ -78,7 +83,7 @@ define(['require', 'dom', 'focusManager', 'dialogHelper', 'loading', 'layoutMana centerFocus(dlg.querySelector('.formDialogContent'), false, true); } - var submitted; + let submitted; dlg.querySelector('form').addEventListener('change', function () { submitted = true; @@ -90,7 +95,7 @@ define(['require', 'dom', 'focusManager', 'dialogHelper', 'loading', 'layoutMana } if (submitted) { - saveValues(dlg, options.settings, options.settingsKey); + saveValues(dlg, options.settingsKey); resolve(); return; } @@ -99,7 +104,7 @@ define(['require', 'dom', 'focusManager', 'dialogHelper', 'loading', 'layoutMana }); }); }); - }; + } +} - return SortMenu; -}); +export default SortMenu; diff --git a/src/controllers/list.js b/src/controllers/list.js index 68e81f05dd..904ef5aa66 100644 --- a/src/controllers/list.js +++ b/src/controllers/list.js @@ -371,7 +371,7 @@ define(['globalize', 'listView', 'layoutManager', 'userSettings', 'focusManager' var instance = this; require(['sortMenu'], function (SortMenu) { - new SortMenu().show({ + new SortMenu.default().show({ settingsKey: instance.getSettingsKey(), settings: instance.getSortValues(), onChange: instance.itemsContainer.refreshItems.bind(instance.itemsContainer), From f3c00499824d6664bc26e705817c1a655aaf82b3 Mon Sep 17 00:00:00 2001 From: Cameron Date: Thu, 6 Aug 2020 08:44:04 +0100 Subject: [PATCH 041/301] Migration of slideshow to ES6 module --- package.json | 1 + src/components/slideshow/slideshow.js | 1290 +++++++++++++------------ 2 files changed, 649 insertions(+), 642 deletions(-) diff --git a/package.json b/package.json index 33c4670d5d..fa20c96339 100644 --- a/package.json +++ b/package.json @@ -155,6 +155,7 @@ "src/components/refreshdialog/refreshdialog.js", "src/components/sanatizefilename.js", "src/components/scrollManager.js", + "src/components/slideshow/slideshow.js", "src/components/sortmenu/sortmenu.js", "src/plugins/htmlVideoPlayer/plugin.js", "src/components/search/searchfields.js", diff --git a/src/components/slideshow/slideshow.js b/src/components/slideshow/slideshow.js index 60c458e234..82f541a116 100644 --- a/src/components/slideshow/slideshow.js +++ b/src/components/slideshow/slideshow.js @@ -2,666 +2,672 @@ * Image viewer component * @module components/slideshow/slideshow */ -define(['dialogHelper', 'inputManager', 'connectionManager', 'layoutManager', 'focusManager', 'browser', 'apphost', 'dom', 'css!./style', 'material-icons', 'paper-icon-button-light'], function (dialogHelper, inputManager, connectionManager, layoutManager, focusManager, browser, appHost, dom) { - 'use strict'; +import dialogHelper from 'dialogHelper'; +import inputManager from 'inputManager'; +import connectionManager from 'connectionManager'; +import layoutManager from 'layoutManager'; +import focusManager from 'focusManager'; +import browser from 'browser'; +import appHost from 'apphost'; +import dom from 'dom'; +import 'css!./style'; +import 'material-icons'; +import 'paper-icon-button-light'; - browser = browser.default || browser; +/** + * Name of transition event. + */ +const transitionEndEventName = dom.whichTransitionEvent(); - /** - * Name of transition event. - */ - const transitionEndEventName = dom.whichTransitionEvent(); +/** + * Flag to use fake image to fix blurry zoomed image. + * At least WebKit doesn't restore quality for zoomed images. + */ +const useFakeZoomImage = browser.safari; - /** - * Flag to use fake image to fix blurry zoomed image. - * At least WebKit doesn't restore quality for zoomed images. - */ - const useFakeZoomImage = browser.safari; +/** + * Retrieves an item's image URL from the API. + * @param {object|string} item - Item used to generate the image URL. + * @param {object} options - Options of the image. + * @param {object} apiClient - API client instance used to retrieve the image. + * @returns {null|string} URL of the item's image. + */ +function getImageUrl(item, options, apiClient) { + options = options || {}; + options.type = options.type || 'Primary'; - /** - * Retrieves an item's image URL from the API. - * @param {object|string} item - Item used to generate the image URL. - * @param {object} options - Options of the image. - * @param {object} apiClient - API client instance used to retrieve the image. - * @returns {null|string} URL of the item's image. - */ - function getImageUrl(item, options, apiClient) { - options = options || {}; - options.type = options.type || 'Primary'; + if (typeof (item) === 'string') { + return apiClient.getScaledImageUrl(item, options); + } - if (typeof (item) === 'string') { - return apiClient.getScaledImageUrl(item, options); + if (item.ImageTags && item.ImageTags[options.type]) { + options.tag = item.ImageTags[options.type]; + return apiClient.getScaledImageUrl(item.Id, options); + } + + if (options.type === 'Primary') { + if (item.AlbumId && item.AlbumPrimaryImageTag) { + options.tag = item.AlbumPrimaryImageTag; + return apiClient.getScaledImageUrl(item.AlbumId, options); } + } - if (item.ImageTags && item.ImageTags[options.type]) { - options.tag = item.ImageTags[options.type]; - return apiClient.getScaledImageUrl(item.Id, options); + return null; +} + +/** + * Retrieves a backdrop's image URL from the API. + * @param {object} item - Item used to generate the image URL. + * @param {object} options - Options of the image. + * @param {object} apiClient - API client instance used to retrieve the image. + * @returns {null|string} URL of the item's backdrop. + */ +function getBackdropImageUrl(item, options, apiClient) { + options = options || {}; + options.type = options.type || 'Backdrop'; + + // If not resizing, get the original image + if (!options.maxWidth && !options.width && !options.maxHeight && !options.height) { + options.quality = 100; + } + + if (item.BackdropImageTags && item.BackdropImageTags.length) { + options.tag = item.BackdropImageTags[0]; + return apiClient.getScaledImageUrl(item.Id, options); + } + + return null; +} + +/** + * Dispatches a request for an item's image to its respective handler. + * @param {object} item - Item used to generate the image URL. + * @returns {string} URL of the item's image. + */ +function getImgUrl(item, user) { + const apiClient = connectionManager.getApiClient(item.ServerId); + const imageOptions = {}; + + if (item.BackdropImageTags && item.BackdropImageTags.length) { + return getBackdropImageUrl(item, imageOptions, apiClient); + } else { + if (item.MediaType === 'Photo' && user && user.Policy.EnableContentDownloading) { + return apiClient.getItemDownloadUrl(item.Id); } + imageOptions.type = 'Primary'; + return getImageUrl(item, imageOptions, apiClient); + } +} - if (options.type === 'Primary') { - if (item.AlbumId && item.AlbumPrimaryImageTag) { - options.tag = item.AlbumPrimaryImageTag; - return apiClient.getScaledImageUrl(item.AlbumId, options); +/** + * Generates a button using the specified icon, classes and properties. + * @param {string} icon - Name of the material icon on the button + * @param {string} cssClass - CSS classes to assign to the button + * @param {boolean} canFocus - Flag to set the tabindex attribute on the button to -1. + * @param {boolean} autoFocus - Flag to set the autofocus attribute on the button. + * @returns {string} The HTML markup of the button. + */ +function getIcon(icon, cssClass, canFocus, autoFocus) { + const tabIndex = canFocus ? '' : ' tabindex="-1"'; + autoFocus = autoFocus ? ' autofocus' : ''; + return ''; +} + +/** + * Sets the viewport meta tag to enable or disable scaling by the user. + * @param {boolean} scalable - Flag to set the scalability of the viewport. + */ +function setUserScalable(scalable) { + try { + appHost.setUserScalable(scalable); + } catch (err) { + console.error('error in appHost.setUserScalable: ' + err); + } +} + +export default function (options) { + const self = this; + /** Initialized instance of Swiper. */ + let swiperInstance; + /** Initialized instance of the dialog containing the Swiper instance. */ + let dialog; + /** Options of the slideshow components */ + let currentOptions; + /** ID of the timeout used to hide the OSD. */ + let hideTimeout; + /** Last coordinates of the mouse pointer. */ + let lastMouseMoveData; + + /** + * Creates the HTML markup for the dialog and the OSD. + * @param {Object} options - Options used to create the dialog and slideshow. + */ + function createElements(options) { + currentOptions = options; + + dialog = dialogHelper.createDialog({ + exitAnimationDuration: options.interactive ? 400 : 800, + size: 'fullscreen', + autoFocus: false, + scrollY: false, + exitAnimation: 'fadeout', + removeOnClose: true + }); + + dialog.classList.add('slideshowDialog'); + + let html = ''; + + html += '
'; + + if (options.interactive && !layoutManager.tv) { + const actionButtonsOnTop = layoutManager.mobile; + + html += getIcon('keyboard_arrow_left', 'btnSlideshowPrevious slideshowButton hide-mouse-idle-tv', false); + html += getIcon('keyboard_arrow_right', 'btnSlideshowNext slideshowButton hide-mouse-idle-tv', false); + + html += '
'; + if (actionButtonsOnTop) { + if (appHost.supports('filedownload') && options.user && options.user.Policy.EnableContentDownloading) { + html += getIcon('file_download', 'btnDownload slideshowButton', true); + } + if (appHost.supports('sharing')) { + html += getIcon('share', 'btnShare slideshowButton', true); + } } - } + html += getIcon('close', 'slideshowButton btnSlideshowExit hide-mouse-idle-tv', false); + html += '
'; - return null; - } + if (!actionButtonsOnTop) { + html += '
'; - /** - * Retrieves a backdrop's image URL from the API. - * @param {object} item - Item used to generate the image URL. - * @param {object} options - Options of the image. - * @param {object} apiClient - API client instance used to retrieve the image. - * @returns {null|string} URL of the item's backdrop. - */ - function getBackdropImageUrl(item, options, apiClient) { - options = options || {}; - options.type = options.type || 'Backdrop'; + html += getIcon('play_arrow', 'btnSlideshowPause slideshowButton', true, true); + if (appHost.supports('filedownload') && options.user && options.user.Policy.EnableContentDownloading) { + html += getIcon('file_download', 'btnDownload slideshowButton', true); + } + if (appHost.supports('sharing')) { + html += getIcon('share', 'btnShare slideshowButton', true); + } - // If not resizing, get the original image - if (!options.maxWidth && !options.width && !options.maxHeight && !options.height) { - options.quality = 100; - } - - if (item.BackdropImageTags && item.BackdropImageTags.length) { - options.tag = item.BackdropImageTags[0]; - return apiClient.getScaledImageUrl(item.Id, options); - } - - return null; - } - - /** - * Dispatches a request for an item's image to its respective handler. - * @param {object} item - Item used to generate the image URL. - * @returns {string} URL of the item's image. - */ - function getImgUrl(item, user) { - var apiClient = connectionManager.getApiClient(item.ServerId); - var imageOptions = {}; - - if (item.BackdropImageTags && item.BackdropImageTags.length) { - return getBackdropImageUrl(item, imageOptions, apiClient); + html += '
'; + } } else { - if (item.MediaType === 'Photo' && user && user.Policy.EnableContentDownloading) { - return apiClient.getItemDownloadUrl(item.Id); - } - imageOptions.type = 'Primary'; - return getImageUrl(item, imageOptions, apiClient); - } - } - - /** - * Generates a button using the specified icon, classes and properties. - * @param {string} icon - Name of the material icon on the button - * @param {string} cssClass - CSS classes to assign to the button - * @param {boolean} canFocus - Flag to set the tabindex attribute on the button to -1. - * @param {boolean} autoFocus - Flag to set the autofocus attribute on the button. - * @returns {string} The HTML markup of the button. - */ - function getIcon(icon, cssClass, canFocus, autoFocus) { - var tabIndex = canFocus ? '' : ' tabindex="-1"'; - autoFocus = autoFocus ? ' autofocus' : ''; - return ''; - } - - /** - * Sets the viewport meta tag to enable or disable scaling by the user. - * @param {boolean} scalable - Flag to set the scalability of the viewport. - */ - function setUserScalable(scalable) { - try { - appHost.setUserScalable(scalable); - } catch (err) { - console.error('error in appHost.setUserScalable: ' + err); - } - } - - return function (options) { - var self = this; - /** Initialized instance of Swiper. */ - var swiperInstance; - /** Initialized instance of the dialog containing the Swiper instance. */ - var dialog; - /** Options of the slideshow components */ - var currentOptions; - /** ID of the timeout used to hide the OSD. */ - var hideTimeout; - /** Last coordinates of the mouse pointer. */ - var lastMouseMoveData; - - /** - * Creates the HTML markup for the dialog and the OSD. - * @param {Object} options - Options used to create the dialog and slideshow. - */ - function createElements(options) { - currentOptions = options; - - dialog = dialogHelper.createDialog({ - exitAnimationDuration: options.interactive ? 400 : 800, - size: 'fullscreen', - autoFocus: false, - scrollY: false, - exitAnimation: 'fadeout', - removeOnClose: true - }); - - dialog.classList.add('slideshowDialog'); - - var html = ''; - - html += '
'; - - if (options.interactive && !layoutManager.tv) { - var actionButtonsOnTop = layoutManager.mobile; - - html += getIcon('keyboard_arrow_left', 'btnSlideshowPrevious slideshowButton hide-mouse-idle-tv', false); - html += getIcon('keyboard_arrow_right', 'btnSlideshowNext slideshowButton hide-mouse-idle-tv', false); - - html += '
'; - if (actionButtonsOnTop) { - if (appHost.supports('filedownload') && options.user && options.user.Policy.EnableContentDownloading) { - html += getIcon('file_download', 'btnDownload slideshowButton', true); - } - if (appHost.supports('sharing')) { - html += getIcon('share', 'btnShare slideshowButton', true); - } - } - html += getIcon('close', 'slideshowButton btnSlideshowExit hide-mouse-idle-tv', false); - html += '
'; - - if (!actionButtonsOnTop) { - html += '
'; - - html += getIcon('play_arrow', 'btnSlideshowPause slideshowButton', true, true); - if (appHost.supports('filedownload') && options.user && options.user.Policy.EnableContentDownloading) { - html += getIcon('file_download', 'btnDownload slideshowButton', true); - } - if (appHost.supports('sharing')) { - html += getIcon('share', 'btnShare slideshowButton', true); - } - - html += '
'; - } - } else { - html += '

'; - } - - dialog.innerHTML = html; - - if (options.interactive && !layoutManager.tv) { - dialog.querySelector('.btnSlideshowExit').addEventListener('click', function (e) { - dialogHelper.close(dialog); - }); - - var btnPause = dialog.querySelector('.btnSlideshowPause'); - if (btnPause) { - btnPause.addEventListener('click', playPause); - } - - var btnDownload = dialog.querySelector('.btnDownload'); - if (btnDownload) { - btnDownload.addEventListener('click', download); - } - - var btnShare = dialog.querySelector('.btnShare'); - if (btnShare) { - btnShare.addEventListener('click', share); - } - } - - setUserScalable(true); - - dialogHelper.open(dialog).then(function () { - setUserScalable(false); - }); - - inputManager.on(window, onInputCommand); - /* eslint-disable-next-line compat/compat */ - document.addEventListener((window.PointerEvent ? 'pointermove' : 'mousemove'), onPointerMove); - - dialog.addEventListener('close', onDialogClosed); - - loadSwiper(dialog, options); + html += '

'; } - /** - * Handles OSD changes when the autoplay is started. - */ - function onAutoplayStart() { - var btnSlideshowPause = dialog.querySelector('.btnSlideshowPause .material-icons'); - if (btnSlideshowPause) { - btnSlideshowPause.classList.replace('play_arrow', 'pause'); - } - } + dialog.innerHTML = html; - /** - * Handles OSD changes when the autoplay is stopped. - */ - function onAutoplayStop() { - var btnSlideshowPause = dialog.querySelector('.btnSlideshowPause .material-icons'); - if (btnSlideshowPause) { - btnSlideshowPause.classList.replace('pause', 'play_arrow'); - } - } - - /** - * Handles zoom changes. - */ - function onZoomChange(scale, imageEl, slideEl) { - const zoomImage = slideEl.querySelector('.swiper-zoom-fakeimg'); - - if (zoomImage) { - zoomImage.style.width = zoomImage.style.height = scale * 100 + '%'; - - if (scale > 1) { - if (zoomImage.classList.contains('swiper-zoom-fakeimg-hidden')) { - // Await for Swiper style changes - setTimeout(() => { - const callback = () => { - imageEl.removeEventListener(transitionEndEventName, callback); - zoomImage.classList.remove('swiper-zoom-fakeimg-hidden'); - }; - - // Swiper set 'transition-duration: 300ms' for auto zoom - // and 'transition-duration: 0s' for touch zoom - const transitionDuration = parseFloat(imageEl.style.transitionDuration.replace(/[a-z]/i, '')); - - if (transitionDuration > 0) { - imageEl.addEventListener(transitionEndEventName, callback); - } else { - callback(); - } - }, 0); - } - } else { - zoomImage.classList.add('swiper-zoom-fakeimg-hidden'); - } - } - } - - /** - * Initializes the Swiper instance and binds the relevant events. - * @param {HTMLElement} dialog - Element containing the dialog. - * @param {Object} options - Options used to initialize the Swiper instance. - */ - function loadSwiper(dialog, options) { - var slides; - if (currentOptions.slides) { - slides = currentOptions.slides; - } else { - slides = currentOptions.items; - } - - require(['swiper'], function (Swiper) { - swiperInstance = new Swiper(dialog.querySelector('.slideshowSwiperContainer'), { - direction: 'horizontal', - // Loop is disabled due to the virtual slides option not supporting it. - loop: false, - zoom: { - minRatio: 1, - toggle: true - }, - autoplay: !options.interactive, - keyboard: { - enabled: true - }, - preloadImages: true, - slidesPerView: 1, - slidesPerColumn: 1, - initialSlide: options.startIndex || 0, - speed: 240, - navigation: { - nextEl: '.btnSlideshowNext', - prevEl: '.btnSlideshowPrevious' - }, - // Virtual slides reduce memory consumption for large libraries while allowing preloading of images; - virtual: { - slides: slides, - cache: true, - renderSlide: getSwiperSlideHtml, - addSlidesBefore: 1, - addSlidesAfter: 1 - } - }); - - swiperInstance.on('autoplayStart', onAutoplayStart); - swiperInstance.on('autoplayStop', onAutoplayStop); - - if (useFakeZoomImage) { - swiperInstance.on('zoomChange', onZoomChange); - } - }); - } - - /** - * Renders the HTML markup of a slide for an item or a slide. - * @param {Object} item - The item used to render the slide. - * @param {number} index - The index of the item in the Swiper instance. - * @returns {string} The HTML markup of the slide. - */ - function getSwiperSlideHtml(item, index) { - if (currentOptions.slides) { - return getSwiperSlideHtmlFromSlide(item); - } else { - return getSwiperSlideHtmlFromItem(item); - } - } - - /** - * Renders the HTML markup of a slide for an item. - * @param {Object} item - Item used to generate the slide. - * @returns {string} The HTML markup of the slide. - */ - function getSwiperSlideHtmlFromItem(item) { - return getSwiperSlideHtmlFromSlide({ - originalImage: getImgUrl(item, currentOptions.user), - Id: item.Id, - ServerId: item.ServerId - }); - } - - /** - * Renders the HTML markup of a slide for a slide object. - * @param {Object} item - Slide object used to generate the slide. - * @returns {string} The HTML markup of the slide. - */ - function getSwiperSlideHtmlFromSlide(item) { - var html = ''; - html += '
'; - html += '
'; - if (useFakeZoomImage) { - html += `
`; - } - html += ''; - html += '
'; - if (item.title || item.subtitle) { - html += '
'; - html += '
'; - if (item.title) { - html += '

'; - html += item.title; - html += '

'; - } - if (item.description) { - html += '
'; - html += item.description; - html += '
'; - } - html += '
'; - html += '
'; - } - html += '
'; - - return html; - } - - /** - * Fetches the information of the currently displayed slide. - * @returns {null|{itemId: string, shareUrl: string, serverId: string, url: string}} Object containing the information of the currently displayed slide. - */ - function getCurrentImageInfo() { - if (swiperInstance) { - var slide = document.querySelector('.swiper-slide-active'); - - if (slide) { - return { - url: slide.getAttribute('data-original'), - shareUrl: slide.getAttribute('data-original'), - itemId: slide.getAttribute('data-itemid'), - serverId: slide.getAttribute('data-serverid') - }; - } - return null; - } else { - return null; - } - } - - /** - * Starts a download for the currently displayed slide. - */ - function download() { - var imageInfo = getCurrentImageInfo(); - - require(['fileDownloader'], function (fileDownloader) { - fileDownloader.download([imageInfo]); - }); - } - - /** - * Shares the currently displayed slide using the browser's built-in sharing feature. - */ - function share() { - var imageInfo = getCurrentImageInfo(); - - navigator.share({ - url: imageInfo.shareUrl - }); - } - - /** - * Starts the autoplay feature of the Swiper instance. - */ - function play() { - if (swiperInstance.autoplay) { - swiperInstance.autoplay.start(); - } - } - - /** - * Pauses the autoplay feature of the Swiper instance; - */ - function pause() { - if (swiperInstance.autoplay) { - swiperInstance.autoplay.stop(); - } - } - - /** - * Toggles the autoplay feature of the Swiper instance. - */ - function playPause() { - var paused = !dialog.querySelector('.btnSlideshowPause .material-icons').classList.contains('pause'); - if (paused) { - play(); - } else { - pause(); - } - } - - /** - * Closes the dialog and destroys the Swiper instance. - */ - function onDialogClosed() { - var swiper = swiperInstance; - if (swiper) { - swiper.destroy(true, true); - swiperInstance = null; - } - - inputManager.off(window, onInputCommand); - /* eslint-disable-next-line compat/compat */ - document.removeEventListener((window.PointerEvent ? 'pointermove' : 'mousemove'), onPointerMove); - // Shows page scrollbar - document.body.classList.remove('hide-scroll'); - document.body.classList.add('force-scroll'); - } - - /** - * Shows the OSD. - */ - function showOsd() { - var bottom = dialog.querySelector('.slideshowBottomBar'); - if (bottom) { - slideUpToShow(bottom); - startHideTimer(); - } - } - - /** - * Hides the OSD. - */ - function hideOsd() { - var bottom = dialog.querySelector('.slideshowBottomBar'); - if (bottom) { - slideDownToHide(bottom); - } - } - - /** - * Starts the timer used to automatically hide the OSD. - */ - function startHideTimer() { - stopHideTimer(); - hideTimeout = setTimeout(hideOsd, 3000); - } - - /** - * Stops the timer used to automatically hide the OSD. - */ - function stopHideTimer() { - if (hideTimeout) { - clearTimeout(hideTimeout); - hideTimeout = null; - } - } - - /** - * Shows the OSD by sliding it into view. - * @param {HTMLElement} element - Element containing the OSD. - */ - function slideUpToShow(element) { - if (!element.classList.contains('hide')) { - return; - } - - element.classList.remove('hide'); - - var onFinish = function () { - focusManager.focus(element.querySelector('.btnSlideshowPause')); - }; - - if (!element.animate) { - onFinish(); - return; - } - - requestAnimationFrame(function () { - var keyframes = [ - { transform: 'translate3d(0,' + element.offsetHeight + 'px,0)', opacity: '.3', offset: 0 }, - { transform: 'translate3d(0,0,0)', opacity: '1', offset: 1 } - ]; - var timing = { duration: 300, iterations: 1, easing: 'ease-out' }; - element.animate(keyframes, timing).onfinish = onFinish; - }); - } - - /** - * Hides the OSD by sliding it out of view. - * @param {HTMLElement} element - Element containing the OSD. - */ - function slideDownToHide(element) { - if (element.classList.contains('hide')) { - return; - } - - var onFinish = function () { - element.classList.add('hide'); - }; - - if (!element.animate) { - onFinish(); - return; - } - - requestAnimationFrame(function () { - var keyframes = [ - { transform: 'translate3d(0,0,0)', opacity: '1', offset: 0 }, - { transform: 'translate3d(0,' + element.offsetHeight + 'px,0)', opacity: '.3', offset: 1 } - ]; - var timing = { duration: 300, iterations: 1, easing: 'ease-out' }; - element.animate(keyframes, timing).onfinish = onFinish; - }); - } - - /** - * Shows the OSD when moving the mouse pointer or touching the screen. - * @param {Event} event - Pointer movement event. - */ - function onPointerMove(event) { - var pointerType = event.pointerType || (layoutManager.mobile ? 'touch' : 'mouse'); - - if (pointerType === 'mouse') { - var eventX = event.screenX || 0; - var eventY = event.screenY || 0; - - var obj = lastMouseMoveData; - if (!obj) { - lastMouseMoveData = { - x: eventX, - y: eventY - }; - return; - } - - // if coord are same, it didn't move - if (Math.abs(eventX - obj.x) < 10 && Math.abs(eventY - obj.y) < 10) { - return; - } - - obj.x = eventX; - obj.y = eventY; - - showOsd(); - } - } - - /** - * Dispatches keyboard inputs to their proper handlers. - * @param {Event} event - Keyboard input event. - */ - function onInputCommand(event) { - switch (event.detail.command) { - case 'up': - case 'down': - case 'select': - case 'menu': - case 'info': - showOsd(); - break; - case 'play': - play(); - break; - case 'pause': - pause(); - break; - case 'playpause': - playPause(); - break; - default: - break; - } - } - - /** - * Shows the slideshow component. - */ - self.show = function () { - createElements(options); - // Hides page scrollbar - document.body.classList.remove('force-scroll'); - document.body.classList.add('hide-scroll'); - }; - - /** - * Hides the slideshow element. - */ - self.hide = function () { - if (dialog) { + if (options.interactive && !layoutManager.tv) { + dialog.querySelector('.btnSlideshowExit').addEventListener('click', function (e) { dialogHelper.close(dialog); + }); + + const btnPause = dialog.querySelector('.btnSlideshowPause'); + if (btnPause) { + btnPause.addEventListener('click', playPause); } + + const btnDownload = dialog.querySelector('.btnDownload'); + if (btnDownload) { + btnDownload.addEventListener('click', download); + } + + const btnShare = dialog.querySelector('.btnShare'); + if (btnShare) { + btnShare.addEventListener('click', share); + } + } + + setUserScalable(true); + + dialogHelper.open(dialog).then(function () { + setUserScalable(false); + }); + + inputManager.on(window, onInputCommand); + /* eslint-disable-next-line compat/compat */ + document.addEventListener((window.PointerEvent ? 'pointermove' : 'mousemove'), onPointerMove); + + dialog.addEventListener('close', onDialogClosed); + + loadSwiper(dialog, options); + } + + /** + * Handles OSD changes when the autoplay is started. + */ + function onAutoplayStart() { + const btnSlideshowPause = dialog.querySelector('.btnSlideshowPause .material-icons'); + if (btnSlideshowPause) { + btnSlideshowPause.classList.replace('play_arrow', 'pause'); + } + } + + /** + * Handles OSD changes when the autoplay is stopped. + */ + function onAutoplayStop() { + const btnSlideshowPause = dialog.querySelector('.btnSlideshowPause .material-icons'); + if (btnSlideshowPause) { + btnSlideshowPause.classList.replace('pause', 'play_arrow'); + } + } + + /** + * Handles zoom changes. + */ + function onZoomChange(scale, imageEl, slideEl) { + const zoomImage = slideEl.querySelector('.swiper-zoom-fakeimg'); + + if (zoomImage) { + zoomImage.style.width = zoomImage.style.height = scale * 100 + '%'; + + if (scale > 1) { + if (zoomImage.classList.contains('swiper-zoom-fakeimg-hidden')) { + // Await for Swiper style changes + setTimeout(() => { + const callback = () => { + imageEl.removeEventListener(transitionEndEventName, callback); + zoomImage.classList.remove('swiper-zoom-fakeimg-hidden'); + }; + + // Swiper set 'transition-duration: 300ms' for auto zoom + // and 'transition-duration: 0s' for touch zoom + const transitionDuration = parseFloat(imageEl.style.transitionDuration.replace(/[a-z]/i, '')); + + if (transitionDuration > 0) { + imageEl.addEventListener(transitionEndEventName, callback); + } else { + callback(); + } + }, 0); + } + } else { + zoomImage.classList.add('swiper-zoom-fakeimg-hidden'); + } + } + } + + /** + * Initializes the Swiper instance and binds the relevant events. + * @param {HTMLElement} dialog - Element containing the dialog. + * @param {Object} options - Options used to initialize the Swiper instance. + */ + function loadSwiper(dialog, options) { + let slides; + if (currentOptions.slides) { + slides = currentOptions.slides; + } else { + slides = currentOptions.items; + } + + import('swiper').then(({default: Swiper}) => { + swiperInstance = new Swiper(dialog.querySelector('.slideshowSwiperContainer'), { + direction: 'horizontal', + // Loop is disabled due to the virtual slides option not supporting it. + loop: false, + zoom: { + minRatio: 1, + toggle: true + }, + autoplay: !options.interactive, + keyboard: { + enabled: true + }, + preloadImages: true, + slidesPerView: 1, + slidesPerColumn: 1, + initialSlide: options.startIndex || 0, + speed: 240, + navigation: { + nextEl: '.btnSlideshowNext', + prevEl: '.btnSlideshowPrevious' + }, + // Virtual slides reduce memory consumption for large libraries while allowing preloading of images; + virtual: { + slides: slides, + cache: true, + renderSlide: getSwiperSlideHtml, + addSlidesBefore: 1, + addSlidesAfter: 1 + } + }); + + swiperInstance.on('autoplayStart', onAutoplayStart); + swiperInstance.on('autoplayStop', onAutoplayStop); + + if (useFakeZoomImage) { + swiperInstance.on('zoomChange', onZoomChange); + } + }); + } + + /** + * Renders the HTML markup of a slide for an item or a slide. + * @param {Object} item - The item used to render the slide. + * @param {number} index - The index of the item in the Swiper instance. + * @returns {string} The HTML markup of the slide. + */ + function getSwiperSlideHtml(item, index) { + if (currentOptions.slides) { + return getSwiperSlideHtmlFromSlide(item); + } else { + return getSwiperSlideHtmlFromItem(item); + } + } + + /** + * Renders the HTML markup of a slide for an item. + * @param {Object} item - Item used to generate the slide. + * @returns {string} The HTML markup of the slide. + */ + function getSwiperSlideHtmlFromItem(item) { + return getSwiperSlideHtmlFromSlide({ + originalImage: getImgUrl(item, currentOptions.user), + Id: item.Id, + ServerId: item.ServerId + }); + } + + /** + * Renders the HTML markup of a slide for a slide object. + * @param {Object} item - Slide object used to generate the slide. + * @returns {string} The HTML markup of the slide. + */ + function getSwiperSlideHtmlFromSlide(item) { + let html = ''; + html += '
'; + html += '
'; + if (useFakeZoomImage) { + html += `
`; + } + html += ''; + html += '
'; + if (item.title || item.subtitle) { + html += '
'; + html += '
'; + if (item.title) { + html += '

'; + html += item.title; + html += '

'; + } + if (item.description) { + html += '
'; + html += item.description; + html += '
'; + } + html += '
'; + html += '
'; + } + html += '
'; + + return html; + } + + /** + * Fetches the information of the currently displayed slide. + * @returns {null|{itemId: string, shareUrl: string, serverId: string, url: string}} Object containing the information of the currently displayed slide. + */ + function getCurrentImageInfo() { + if (swiperInstance) { + const slide = document.querySelector('.swiper-slide-active'); + + if (slide) { + return { + url: slide.getAttribute('data-original'), + shareUrl: slide.getAttribute('data-original'), + itemId: slide.getAttribute('data-itemid'), + serverId: slide.getAttribute('data-serverid') + }; + } + return null; + } else { + return null; + } + } + + /** + * Starts a download for the currently displayed slide. + */ + function download() { + const imageInfo = getCurrentImageInfo(); + + import('fileDownloader').then(({default: fileDownloader}) => { + fileDownloader.download([imageInfo]); + }); + } + + /** + * Shares the currently displayed slide using the browser's built-in sharing feature. + */ + function share() { + const imageInfo = getCurrentImageInfo(); + + navigator.share({ + url: imageInfo.shareUrl + }); + } + + /** + * Starts the autoplay feature of the Swiper instance. + */ + function play() { + if (swiperInstance.autoplay) { + swiperInstance.autoplay.start(); + } + } + + /** + * Pauses the autoplay feature of the Swiper instance; + */ + function pause() { + if (swiperInstance.autoplay) { + swiperInstance.autoplay.stop(); + } + } + + /** + * Toggles the autoplay feature of the Swiper instance. + */ + function playPause() { + const paused = !dialog.querySelector('.btnSlideshowPause .material-icons').classList.contains('pause'); + if (paused) { + play(); + } else { + pause(); + } + } + + /** + * Closes the dialog and destroys the Swiper instance. + */ + function onDialogClosed() { + const swiper = swiperInstance; + if (swiper) { + swiper.destroy(true, true); + swiperInstance = null; + } + + inputManager.off(window, onInputCommand); + /* eslint-disable-next-line compat/compat */ + document.removeEventListener((window.PointerEvent ? 'pointermove' : 'mousemove'), onPointerMove); + // Shows page scrollbar + document.body.classList.remove('hide-scroll'); + document.body.classList.add('force-scroll'); + } + + /** + * Shows the OSD. + */ + function showOsd() { + const bottom = dialog.querySelector('.slideshowBottomBar'); + if (bottom) { + slideUpToShow(bottom); + startHideTimer(); + } + } + + /** + * Hides the OSD. + */ + function hideOsd() { + const bottom = dialog.querySelector('.slideshowBottomBar'); + if (bottom) { + slideDownToHide(bottom); + } + } + + /** + * Starts the timer used to automatically hide the OSD. + */ + function startHideTimer() { + stopHideTimer(); + hideTimeout = setTimeout(hideOsd, 3000); + } + + /** + * Stops the timer used to automatically hide the OSD. + */ + function stopHideTimer() { + if (hideTimeout) { + clearTimeout(hideTimeout); + hideTimeout = null; + } + } + + /** + * Shows the OSD by sliding it into view. + * @param {HTMLElement} element - Element containing the OSD. + */ + function slideUpToShow(element) { + if (!element.classList.contains('hide')) { + return; + } + + element.classList.remove('hide'); + + const onFinish = function () { + focusManager.focus(element.querySelector('.btnSlideshowPause')); }; + + if (!element.animate) { + onFinish(); + return; + } + + requestAnimationFrame(function () { + const keyframes = [ + { transform: 'translate3d(0,' + element.offsetHeight + 'px,0)', opacity: '.3', offset: 0 }, + { transform: 'translate3d(0,0,0)', opacity: '1', offset: 1 } + ]; + const timing = { duration: 300, iterations: 1, easing: 'ease-out' }; + element.animate(keyframes, timing).onfinish = onFinish; + }); + } + + /** + * Hides the OSD by sliding it out of view. + * @param {HTMLElement} element - Element containing the OSD. + */ + function slideDownToHide(element) { + if (element.classList.contains('hide')) { + return; + } + + const onFinish = function () { + element.classList.add('hide'); + }; + + if (!element.animate) { + onFinish(); + return; + } + + requestAnimationFrame(function () { + const keyframes = [ + { transform: 'translate3d(0,0,0)', opacity: '1', offset: 0 }, + { transform: 'translate3d(0,' + element.offsetHeight + 'px,0)', opacity: '.3', offset: 1 } + ]; + const timing = { duration: 300, iterations: 1, easing: 'ease-out' }; + element.animate(keyframes, timing).onfinish = onFinish; + }); + } + + /** + * Shows the OSD when moving the mouse pointer or touching the screen. + * @param {Event} event - Pointer movement event. + */ + function onPointerMove(event) { + const pointerType = event.pointerType || (layoutManager.mobile ? 'touch' : 'mouse'); + + if (pointerType === 'mouse') { + const eventX = event.screenX || 0; + const eventY = event.screenY || 0; + + const obj = lastMouseMoveData; + if (!obj) { + lastMouseMoveData = { + x: eventX, + y: eventY + }; + return; + } + + // if coord are same, it didn't move + if (Math.abs(eventX - obj.x) < 10 && Math.abs(eventY - obj.y) < 10) { + return; + } + + obj.x = eventX; + obj.y = eventY; + + showOsd(); + } + } + + /** + * Dispatches keyboard inputs to their proper handlers. + * @param {Event} event - Keyboard input event. + */ + function onInputCommand(event) { + switch (event.detail.command) { + case 'up': + case 'down': + case 'select': + case 'menu': + case 'info': + showOsd(); + break; + case 'play': + play(); + break; + case 'pause': + pause(); + break; + case 'playpause': + playPause(); + break; + default: + break; + } + } + + /** + * Shows the slideshow component. + */ + self.show = function () { + createElements(options); + // Hides page scrollbar + document.body.classList.remove('force-scroll'); + document.body.classList.add('hide-scroll'); }; -}); + + /** + * Hides the slideshow element. + */ + self.hide = function () { + if (dialog) { + dialogHelper.close(dialog); + } + }; +} From b7d29eae1b971eae3be7483109da3297f1c7df3f Mon Sep 17 00:00:00 2001 From: Cameron Date: Thu, 6 Aug 2020 09:02:45 +0100 Subject: [PATCH 042/301] Migration of subtitleeditor to ES6 module --- package.json | 1 + .../subtitleeditor/subtitleeditor.js | 725 +++++++++--------- 2 files changed, 369 insertions(+), 357 deletions(-) diff --git a/package.json b/package.json index 1d7cf770d3..a7dcc43114 100644 --- a/package.json +++ b/package.json @@ -160,6 +160,7 @@ "src/components/search/searchresults.js", "src/components/settingshelper.js", "src/components/shortcuts.js", + "src/components/subtitleeditor/subtitleeditor.js", "src/components/subtitlesettings/subtitleappearancehelper.js", "src/components/subtitlesettings/subtitlesettings.js", "src/components/syncPlay/groupSelectionMenu.js", diff --git a/src/components/subtitleeditor/subtitleeditor.js b/src/components/subtitleeditor/subtitleeditor.js index 7df24b5da8..dfd7f9446c 100644 --- a/src/components/subtitleeditor/subtitleeditor.js +++ b/src/components/subtitleeditor/subtitleeditor.js @@ -1,426 +1,437 @@ -define(['dialogHelper', 'require', 'layoutManager', 'globalize', 'userSettings', 'connectionManager', 'loading', 'focusManager', 'dom', 'apphost', 'emby-select', 'listViewStyle', 'paper-icon-button-light', 'css!./../formdialog', 'material-icons', 'css!./subtitleeditor', 'emby-button', 'flexStyles'], function (dialogHelper, require, layoutManager, globalize, userSettings, connectionManager, loading, focusManager, dom, appHost) { - 'use strict'; +import dialogHelper from 'dialogHelper'; +import layoutManager from 'layoutManager'; +import globalize from 'globalize'; +import * as userSettings from 'userSettings'; +import connectionManager from 'connectionManager'; +import loading from 'loading'; +import focusManager from 'focusManager'; +import dom from 'dom'; +import 'emby-select'; +import 'listViewStyle'; +import 'paper-icon-button-light'; +import 'css!./../formdialog'; +import 'material-icons'; +import 'css!./subtitleeditor'; +import 'emby-button'; +import 'flexStyles'; - loading = loading.default || loading; +let currentItem; +let hasChanges; - var currentItem; - var hasChanges; +function downloadRemoteSubtitles(context, id) { + let url = 'Items/' + currentItem.Id + '/RemoteSearch/Subtitles/' + id; - function downloadRemoteSubtitles(context, id) { - var url = 'Items/' + currentItem.Id + '/RemoteSearch/Subtitles/' + id; + let apiClient = connectionManager.getApiClient(currentItem.ServerId); + apiClient.ajax({ - var apiClient = connectionManager.getApiClient(currentItem.ServerId); - apiClient.ajax({ + type: 'POST', + url: apiClient.getUrl(url) - type: 'POST', - url: apiClient.getUrl(url) + }).then(function () { + hasChanges = true; + + import('toast').then(({default: toast}) => { + toast(globalize.translate('MessageDownloadQueued')); + }); + + focusManager.autoFocus(context); + }); +} + +function deleteLocalSubtitle(context, index) { + let msg = globalize.translate('MessageAreYouSureDeleteSubtitles'); + + import('confirm').then(({default: confirm}) => { + confirm({ + + title: globalize.translate('ConfirmDeletion'), + text: msg, + confirmText: globalize.translate('Delete'), + primary: 'delete' }).then(function () { - hasChanges = true; + loading.show(); - require(['toast'], function (toast) { - toast(globalize.translate('MessageDownloadQueued')); - }); + let itemId = currentItem.Id; + let url = 'Videos/' + itemId + '/Subtitles/' + index; - focusManager.autoFocus(context); - }); - } + let apiClient = connectionManager.getApiClient(currentItem.ServerId); - function deleteLocalSubtitle(context, index) { - var msg = globalize.translate('MessageAreYouSureDeleteSubtitles'); + apiClient.ajax({ - require(['confirm'], function (confirm) { - confirm.default({ - - title: globalize.translate('ConfirmDeletion'), - text: msg, - confirmText: globalize.translate('Delete'), - primary: 'delete' + type: 'DELETE', + url: apiClient.getUrl(url) }).then(function () { - loading.show(); - - var itemId = currentItem.Id; - var url = 'Videos/' + itemId + '/Subtitles/' + index; - - var apiClient = connectionManager.getApiClient(currentItem.ServerId); - - apiClient.ajax({ - - type: 'DELETE', - url: apiClient.getUrl(url) - - }).then(function () { - hasChanges = true; - reload(context, apiClient, itemId); - }); + hasChanges = true; + reload(context, apiClient, itemId); }); }); - } + }); +} - function fillSubtitleList(context, item) { - var streams = item.MediaStreams || []; +function fillSubtitleList(context, item) { + let streams = item.MediaStreams || []; - var subs = streams.filter(function (s) { - return s.Type === 'Subtitle'; - }); + let subs = streams.filter(function (s) { + return s.Type === 'Subtitle'; + }); - var html = ''; + let html = ''; - if (subs.length) { - html += '

' + globalize.translate('MySubtitles') + '

'; + if (subs.length) { + html += '

' + globalize.translate('MySubtitles') + '

'; - html += '
'; + html += '
'; - html += subs.map(function (s) { - var itemHtml = ''; + html += subs.map(function (s) { + let itemHtml = ''; - var tagName = layoutManager.tv ? 'button' : 'div'; - var className = layoutManager.tv && s.Path ? 'listItem listItem-border btnDelete' : 'listItem listItem-border'; + let tagName = layoutManager.tv ? 'button' : 'div'; + let className = layoutManager.tv && s.Path ? 'listItem listItem-border btnDelete' : 'listItem listItem-border'; - if (layoutManager.tv) { - className += ' listItem-focusscale listItem-button'; - } - - className += ' listItem-noborder'; - - itemHtml += '<' + tagName + ' class="' + className + '" data-index="' + s.Index + '">'; - - itemHtml += ''; - - itemHtml += '
'; - - itemHtml += '
'; - itemHtml += s.DisplayTitle || ''; - itemHtml += '
'; - - if (s.Path) { - itemHtml += '
' + (s.Path) + '
'; - } - - itemHtml += ''; - itemHtml += '
'; - - if (!layoutManager.tv) { - if (s.Path) { - itemHtml += ''; - } - } - - itemHtml += ''; - - return itemHtml; - }).join(''); - - html += '
'; - } - - var elem = context.querySelector('.subtitleList'); - - if (subs.length) { - elem.classList.remove('hide'); - } else { - elem.classList.add('hide'); - } - elem.innerHTML = html; - } - - function fillLanguages(context, apiClient, languages) { - var selectLanguage = context.querySelector('#selectLanguage'); - - selectLanguage.innerHTML = languages.map(function (l) { - return ''; - }); - - var lastLanguage = userSettings.get('subtitleeditor-language'); - if (lastLanguage) { - selectLanguage.value = lastLanguage; - } else { - apiClient.getCurrentUser().then(function (user) { - var lang = user.Configuration.SubtitleLanguagePreference; - - if (lang) { - selectLanguage.value = lang; - } - }); - } - } - - function renderSearchResults(context, results) { - var lastProvider = ''; - var html = ''; - - if (!results.length) { - context.querySelector('.noSearchResults').classList.remove('hide'); - context.querySelector('.subtitleResults').innerHTML = ''; - loading.hide(); - return; - } - - context.querySelector('.noSearchResults').classList.add('hide'); - - for (var i = 0, length = results.length; i < length; i++) { - var result = results[i]; - - var provider = result.ProviderName; - - if (provider !== lastProvider) { - if (i > 0) { - html += '
'; - } - html += '

' + provider + '

'; - html += '
'; - lastProvider = provider; - } - - var tagName = layoutManager.tv ? 'button' : 'div'; - var className = layoutManager.tv ? 'listItem listItem-border btnOptions' : 'listItem listItem-border'; if (layoutManager.tv) { className += ' listItem-focusscale listItem-button'; } - html += '<' + tagName + ' class="' + className + '" data-subid="' + result.Id + '">'; + className += ' listItem-noborder'; - html += ''; + itemHtml += '<' + tagName + ' class="' + className + '" data-index="' + s.Index + '">'; - var bodyClass = result.Comment || result.IsHashMatch ? 'three-line' : 'two-line'; + itemHtml += ''; - html += '
'; + itemHtml += '
'; - html += '
' + (result.Name) + '
'; - html += '
'; + itemHtml += '
'; + itemHtml += s.DisplayTitle || ''; + itemHtml += '
'; - if (result.Format) { - html += '' + globalize.translate('FormatValue', result.Format) + ''; + if (s.Path) { + itemHtml += '
' + (s.Path) + '
'; } - if (result.DownloadCount != null) { - html += '' + globalize.translate('DownloadsValue', result.DownloadCount) + ''; - } - html += '
'; - - if (result.Comment) { - html += '
' + (result.Comment) + '
'; - } - - if (result.IsHashMatch) { - html += '
' + globalize.translate('PerfectMatch') + '
'; - } - - html += '
'; + itemHtml += ''; + itemHtml += '
'; if (!layoutManager.tv) { - html += ''; + if (s.Path) { + itemHtml += ''; + } } - html += ''; + itemHtml += ''; + + return itemHtml; + }).join(''); + + html += '
'; + } + + let elem = context.querySelector('.subtitleList'); + + if (subs.length) { + elem.classList.remove('hide'); + } else { + elem.classList.add('hide'); + } + elem.innerHTML = html; +} + +function fillLanguages(context, apiClient, languages) { + let selectLanguage = context.querySelector('#selectLanguage'); + + selectLanguage.innerHTML = languages.map(function (l) { + return ''; + }); + + let lastLanguage = userSettings.get('subtitleeditor-language'); + if (lastLanguage) { + selectLanguage.value = lastLanguage; + } else { + apiClient.getCurrentUser().then(function (user) { + let lang = user.Configuration.SubtitleLanguagePreference; + + if (lang) { + selectLanguage.value = lang; + } + }); + } +} + +function renderSearchResults(context, results) { + let lastProvider = ''; + let html = ''; + + if (!results.length) { + context.querySelector('.noSearchResults').classList.remove('hide'); + context.querySelector('.subtitleResults').innerHTML = ''; + loading.hide(); + return; + } + + context.querySelector('.noSearchResults').classList.add('hide'); + + for (let i = 0, length = results.length; i < length; i++) { + let result = results[i]; + + let provider = result.ProviderName; + + if (provider !== lastProvider) { + if (i > 0) { + html += '
'; + } + html += '

' + provider + '

'; + html += '
'; + lastProvider = provider; } - if (results.length) { - html += '
'; + let tagName = layoutManager.tv ? 'button' : 'div'; + let className = layoutManager.tv ? 'listItem listItem-border btnOptions' : 'listItem listItem-border'; + if (layoutManager.tv) { + className += ' listItem-focusscale listItem-button'; } - var elem = context.querySelector('.subtitleResults'); - elem.innerHTML = html; + html += '<' + tagName + ' class="' + className + '" data-subid="' + result.Id + '">'; + + html += ''; + + let bodyClass = result.Comment || result.IsHashMatch ? 'three-line' : 'two-line'; + + html += '
'; + + html += '
' + (result.Name) + '
'; + html += '
'; + + if (result.Format) { + html += '' + globalize.translate('FormatValue', result.Format) + ''; + } + + if (result.DownloadCount != null) { + html += '' + globalize.translate('DownloadsValue', result.DownloadCount) + ''; + } + html += '
'; + + if (result.Comment) { + html += '
' + (result.Comment) + '
'; + } + + if (result.IsHashMatch) { + html += '
' + globalize.translate('PerfectMatch') + '
'; + } + + html += '
'; + + if (!layoutManager.tv) { + html += ''; + } + + html += ''; + } + + if (results.length) { + html += '
'; + } + + let elem = context.querySelector('.subtitleResults'); + elem.innerHTML = html; + + loading.hide(); +} + +function searchForSubtitles(context, language) { + userSettings.set('subtitleeditor-language', language); + + loading.show(); + + let apiClient = connectionManager.getApiClient(currentItem.ServerId); + let url = apiClient.getUrl('Items/' + currentItem.Id + '/RemoteSearch/Subtitles/' + language); + + apiClient.getJSON(url).then(function (results) { + renderSearchResults(context, results); + }); +} + +function reload(context, apiClient, itemId) { + context.querySelector('.noSearchResults').classList.add('hide'); + + function onGetItem(item) { + currentItem = item; + + fillSubtitleList(context, item); + let file = item.Path || ''; + let index = Math.max(file.lastIndexOf('/'), file.lastIndexOf('\\')); + if (index > -1) { + file = file.substring(index + 1); + } + + if (file) { + context.querySelector('.pathValue').innerHTML = file; + context.querySelector('.originalFile').classList.remove('hide'); + } else { + context.querySelector('.pathValue').innerHTML = ''; + context.querySelector('.originalFile').classList.add('hide'); + } loading.hide(); } - function searchForSubtitles(context, language) { - userSettings.set('subtitleeditor-language', language); + if (typeof itemId === 'string') { + apiClient.getItem(apiClient.getCurrentUserId(), itemId).then(onGetItem); + } else { + onGetItem(itemId); + } +} - loading.show(); +function onSearchSubmit(e) { + let form = this; - var apiClient = connectionManager.getApiClient(currentItem.ServerId); - var url = apiClient.getUrl('Items/' + currentItem.Id + '/RemoteSearch/Subtitles/' + language); + let lang = form.querySelector('#selectLanguage', form).value; - apiClient.getJSON(url).then(function (results) { - renderSearchResults(context, results); - }); + searchForSubtitles(dom.parentWithClass(form, 'formDialogContent'), lang); + + e.preventDefault(); + return false; +} + +function onSubtitleListClick(e) { + let btnDelete = dom.parentWithClass(e.target, 'btnDelete'); + if (btnDelete) { + let index = btnDelete.getAttribute('data-index'); + let context = dom.parentWithClass(btnDelete, 'subtitleEditorDialog'); + deleteLocalSubtitle(context, index); + } +} + +function onSubtitleResultsClick(e) { + let subtitleId; + let context; + + let btnOptions = dom.parentWithClass(e.target, 'btnOptions'); + if (btnOptions) { + subtitleId = btnOptions.getAttribute('data-subid'); + context = dom.parentWithClass(btnOptions, 'subtitleEditorDialog'); + showDownloadOptions(btnOptions, context, subtitleId); } - function reload(context, apiClient, itemId) { - context.querySelector('.noSearchResults').classList.add('hide'); + let btnDownload = dom.parentWithClass(e.target, 'btnDownload'); + if (btnDownload) { + subtitleId = btnDownload.getAttribute('data-subid'); + context = dom.parentWithClass(btnDownload, 'subtitleEditorDialog'); + downloadRemoteSubtitles(context, subtitleId); + } +} - function onGetItem(item) { - currentItem = item; +function showDownloadOptions(button, context, subtitleId) { + let items = []; - fillSubtitleList(context, item); - var file = item.Path || ''; - var index = Math.max(file.lastIndexOf('/'), file.lastIndexOf('\\')); - if (index > -1) { - file = file.substring(index + 1); + items.push({ + name: globalize.translate('Download'), + id: 'download' + }); + + import('actionsheet').then(({default: actionsheet}) => { + actionsheet.show({ + items: items, + positionTo: button + + }).then(function (id) { + switch (id) { + case 'download': + downloadRemoteSubtitles(context, subtitleId); + break; + default: + break; } + }); + }); +} - if (file) { - context.querySelector('.pathValue').innerHTML = file; - context.querySelector('.originalFile').classList.remove('hide'); - } else { - context.querySelector('.pathValue').innerHTML = ''; - context.querySelector('.originalFile').classList.add('hide'); - } +function centerFocus(elem, horiz, on) { + import('scrollHelper').then(({default: scrollHelper}) => { + let fn = on ? 'on' : 'off'; + scrollHelper.centerFocus[fn](elem, horiz); + }); +} - loading.hide(); - } +function showEditorInternal(itemId, serverId, template) { + hasChanges = false; - if (typeof itemId === 'string') { - apiClient.getItem(apiClient.getCurrentUserId(), itemId).then(onGetItem); + let apiClient = connectionManager.getApiClient(serverId); + return apiClient.getItem(apiClient.getCurrentUserId(), itemId).then(function (item) { + let dialogOptions = { + removeOnClose: true, + scrollY: false + }; + + if (layoutManager.tv) { + dialogOptions.size = 'fullscreen'; } else { - onGetItem(itemId); - } - } - - function onSearchSubmit(e) { - var form = this; - - var lang = form.querySelector('#selectLanguage', form).value; - - searchForSubtitles(dom.parentWithClass(form, 'formDialogContent'), lang); - - e.preventDefault(); - return false; - } - - function onSubtitleListClick(e) { - var btnDelete = dom.parentWithClass(e.target, 'btnDelete'); - if (btnDelete) { - var index = btnDelete.getAttribute('data-index'); - var context = dom.parentWithClass(btnDelete, 'subtitleEditorDialog'); - deleteLocalSubtitle(context, index); - } - } - - function onSubtitleResultsClick(e) { - var subtitleId; - var context; - - var btnOptions = dom.parentWithClass(e.target, 'btnOptions'); - if (btnOptions) { - subtitleId = btnOptions.getAttribute('data-subid'); - context = dom.parentWithClass(btnOptions, 'subtitleEditorDialog'); - showDownloadOptions(btnOptions, context, subtitleId); + dialogOptions.size = 'small'; } - var btnDownload = dom.parentWithClass(e.target, 'btnDownload'); - if (btnDownload) { - subtitleId = btnDownload.getAttribute('data-subid'); - context = dom.parentWithClass(btnDownload, 'subtitleEditorDialog'); - downloadRemoteSubtitles(context, subtitleId); + let dlg = dialogHelper.createDialog(dialogOptions); + + dlg.classList.add('formDialog'); + dlg.classList.add('subtitleEditorDialog'); + + dlg.innerHTML = globalize.translateHtml(template, 'core'); + + dlg.querySelector('.originalSubtitleFileLabel').innerHTML = globalize.translate('File'); + + dlg.querySelector('.subtitleSearchForm').addEventListener('submit', onSearchSubmit); + + let btnSubmit = dlg.querySelector('.btnSubmit'); + + if (layoutManager.tv) { + centerFocus(dlg.querySelector('.formDialogContent'), false, true); + dlg.querySelector('.btnSearchSubtitles').classList.add('hide'); + } else { + btnSubmit.classList.add('hide'); } - } - function showDownloadOptions(button, context, subtitleId) { - var items = []; + let editorContent = dlg.querySelector('.formDialogContent'); - items.push({ - name: globalize.translate('Download'), - id: 'download' + dlg.querySelector('.subtitleList').addEventListener('click', onSubtitleListClick); + dlg.querySelector('.subtitleResults').addEventListener('click', onSubtitleResultsClick); + + apiClient.getCultures().then(function (languages) { + fillLanguages(editorContent, apiClient, languages); }); - require(['actionsheet'], function (actionsheet) { - actionsheet.show({ - items: items, - positionTo: button - - }).then(function (id) { - switch (id) { - case 'download': - downloadRemoteSubtitles(context, subtitleId); - break; - default: - break; - } - }); + dlg.querySelector('.btnCancel').addEventListener('click', function () { + dialogHelper.close(dlg); }); - } - - function centerFocus(elem, horiz, on) { - require(['scrollHelper'], function (scrollHelper) { - var fn = on ? 'on' : 'off'; - scrollHelper.centerFocus[fn](elem, horiz); - }); - } - - function showEditorInternal(itemId, serverId, template) { - hasChanges = false; - - var apiClient = connectionManager.getApiClient(serverId); - return apiClient.getItem(apiClient.getCurrentUserId(), itemId).then(function (item) { - var dialogOptions = { - removeOnClose: true, - scrollY: false - }; - - if (layoutManager.tv) { - dialogOptions.size = 'fullscreen'; - } else { - dialogOptions.size = 'small'; - } - - var dlg = dialogHelper.createDialog(dialogOptions); - - dlg.classList.add('formDialog'); - dlg.classList.add('subtitleEditorDialog'); - - dlg.innerHTML = globalize.translateHtml(template, 'core'); - - dlg.querySelector('.originalSubtitleFileLabel').innerHTML = globalize.translate('File'); - - dlg.querySelector('.subtitleSearchForm').addEventListener('submit', onSearchSubmit); - - var btnSubmit = dlg.querySelector('.btnSubmit'); - - if (layoutManager.tv) { - centerFocus(dlg.querySelector('.formDialogContent'), false, true); - dlg.querySelector('.btnSearchSubtitles').classList.add('hide'); - } else { - btnSubmit.classList.add('hide'); - } - - var editorContent = dlg.querySelector('.formDialogContent'); - - dlg.querySelector('.subtitleList').addEventListener('click', onSubtitleListClick); - dlg.querySelector('.subtitleResults').addEventListener('click', onSubtitleResultsClick); - - apiClient.getCultures().then(function (languages) { - fillLanguages(editorContent, apiClient, languages); - }); - - dlg.querySelector('.btnCancel').addEventListener('click', function () { - dialogHelper.close(dlg); - }); - - return new Promise(function (resolve, reject) { - dlg.addEventListener('close', function () { - if (layoutManager.tv) { - centerFocus(dlg.querySelector('.formDialogContent'), false, false); - } - - if (hasChanges) { - resolve(); - } else { - reject(); - } - }); - - dialogHelper.open(dlg); - - reload(editorContent, apiClient, item); - }); - }); - } - - function showEditor(itemId, serverId) { - loading.show(); return new Promise(function (resolve, reject) { - require(['text!./subtitleeditor.template.html'], function (template) { - showEditorInternal(itemId, serverId, template).then(resolve, reject); - }); - }); - } + dlg.addEventListener('close', function () { + if (layoutManager.tv) { + centerFocus(dlg.querySelector('.formDialogContent'), false, false); + } - return { - show: showEditor - }; -}); + if (hasChanges) { + resolve(); + } else { + reject(); + } + }); + + dialogHelper.open(dlg); + + reload(editorContent, apiClient, item); + }); + }); +} + +function showEditor(itemId, serverId) { + loading.show(); + + return new Promise(function (resolve, reject) { + import('text!./subtitleeditor.template.html').then(({default: template}) => { + showEditorInternal(itemId, serverId, template).then(resolve, reject); + }); + }); +} + +export default { + show: showEditor +}; From cdb07e94436052d3d3fcc7b7f61f9160a935a93d Mon Sep 17 00:00:00 2001 From: Cameron Date: Thu, 6 Aug 2020 09:03:30 +0100 Subject: [PATCH 043/301] Migration of subtitlesync to ES6 module --- package.json | 1 + src/components/subtitlesync/subtitlesync.js | 219 ++++++++++---------- 2 files changed, 111 insertions(+), 109 deletions(-) diff --git a/package.json b/package.json index a7dcc43114..6409981f9c 100644 --- a/package.json +++ b/package.json @@ -161,6 +161,7 @@ "src/components/settingshelper.js", "src/components/shortcuts.js", "src/components/subtitleeditor/subtitleeditor.js", + "src/components/subtitlesync/subtitlesync.js", "src/components/subtitlesettings/subtitleappearancehelper.js", "src/components/subtitlesettings/subtitlesettings.js", "src/components/syncPlay/groupSelectionMenu.js", diff --git a/src/components/subtitlesync/subtitlesync.js b/src/components/subtitlesync/subtitlesync.js index 203d88535f..efb2087a1b 100644 --- a/src/components/subtitlesync/subtitlesync.js +++ b/src/components/subtitlesync/subtitlesync.js @@ -1,147 +1,148 @@ -define(['playbackManager', 'layoutManager', 'text!./subtitlesync.template.html', 'css!./subtitlesync'], function (playbackManager, layoutManager, template, css) { - 'use strict'; +import playbackManager from 'playbackManager'; +import layoutManager from 'layoutManager'; +import template from 'text!./subtitlesync.template.html'; +import 'css!./subtitlesync'; - playbackManager = playbackManager.default || playbackManager; +let player; +let subtitleSyncSlider; +let subtitleSyncTextField; +let subtitleSyncCloseButton; +let subtitleSyncContainer; - var player; - var subtitleSyncSlider; - var subtitleSyncTextField; - var subtitleSyncCloseButton; - var subtitleSyncContainer; +function init(instance) { + const parent = document.createElement('div'); + document.body.appendChild(parent); + parent.innerHTML = template; - function init(instance) { - var parent = document.createElement('div'); - document.body.appendChild(parent); - parent.innerHTML = template; + subtitleSyncSlider = parent.querySelector('.subtitleSyncSlider'); + subtitleSyncTextField = parent.querySelector('.subtitleSyncTextField'); + subtitleSyncCloseButton = parent.querySelector('.subtitleSync-closeButton'); + subtitleSyncContainer = parent.querySelector('.subtitleSyncContainer'); - subtitleSyncSlider = parent.querySelector('.subtitleSyncSlider'); - subtitleSyncTextField = parent.querySelector('.subtitleSyncTextField'); - subtitleSyncCloseButton = parent.querySelector('.subtitleSync-closeButton'); - subtitleSyncContainer = parent.querySelector('.subtitleSyncContainer'); + if (layoutManager.tv) { + subtitleSyncSlider.classList.add('focusable'); + // HACK: Delay to give time for registered element attach (Firefox) + setTimeout(function () { + subtitleSyncSlider.enableKeyboardDragging(); + }, 0); + } - if (layoutManager.tv) { - subtitleSyncSlider.classList.add('focusable'); - // HACK: Delay to give time for registered element attach (Firefox) - setTimeout(function () { - subtitleSyncSlider.enableKeyboardDragging(); - }, 0); - } + subtitleSyncContainer.classList.add('hide'); - subtitleSyncContainer.classList.add('hide'); + subtitleSyncTextField.updateOffset = function (offset) { + this.textContent = offset + 's'; + }; - subtitleSyncTextField.updateOffset = function(offset) { - this.textContent = offset + 's'; - }; + subtitleSyncTextField.addEventListener('click', function () { + // keep focus to prevent fade with osd + this.hasFocus = true; + }); - subtitleSyncTextField.addEventListener('click', function () { + subtitleSyncTextField.addEventListener('keydown', function (event) { + if (event.key === 'Enter') { + // if input key is enter search for float pattern + let inputOffset = /[-+]?\d+\.?\d*/g.exec(this.textContent); + if (inputOffset) { + inputOffset = inputOffset[0]; + + // replace current text by considered offset + this.textContent = inputOffset + 's'; + + inputOffset = parseFloat(inputOffset); + // set new offset + playbackManager.setSubtitleOffset(inputOffset, player); + // synchronize with slider value + subtitleSyncSlider.updateOffset( + getPercentageFromOffset(inputOffset)); + } else { + this.textContent = (playbackManager.getPlayerSubtitleOffset(player) || 0) + 's'; + } + this.hasFocus = false; + event.preventDefault(); + } else { // keep focus to prevent fade with osd this.hasFocus = true; - }); - - subtitleSyncTextField.addEventListener('keydown', function(event) { - if (event.key === 'Enter') { - // if input key is enter search for float pattern - var inputOffset = /[-+]?\d+\.?\d*/g.exec(this.textContent); - if (inputOffset) { - inputOffset = inputOffset[0]; - - // replace current text by considered offset - this.textContent = inputOffset + 's'; - - inputOffset = parseFloat(inputOffset); - // set new offset - playbackManager.setSubtitleOffset(inputOffset, player); - // synchronize with slider value - subtitleSyncSlider.updateOffset( - getPercentageFromOffset(inputOffset)); - } else { - this.textContent = (playbackManager.getPlayerSubtitleOffset(player) || 0) + 's'; - } - this.hasFocus = false; + if (event.key.match(/[+-\d.s]/) === null) { event.preventDefault(); - } else { - // keep focus to prevent fade with osd - this.hasFocus = true; - if (event.key.match(/[+-\d.s]/) === null) { - event.preventDefault(); - } } + } - // FIXME: TV layout will require special handling for navigation keys. But now field is not focusable - event.stopPropagation(); - }); + // FIXME: TV layout will require special handling for navigation keys. But now field is not focusable + event.stopPropagation(); + }); - subtitleSyncTextField.blur = function() { - // prevent textfield to blur while element has focus - if (!this.hasFocus && this.prototype) { - this.prototype.blur(); - } - }; + subtitleSyncTextField.blur = function () { + // prevent textfield to blur while element has focus + if (!this.hasFocus && this.prototype) { + this.prototype.blur(); + } + }; - subtitleSyncSlider.updateOffset = function(percent) { - // default value is 0s = 50% - this.value = percent === undefined ? 50 : percent; - }; + subtitleSyncSlider.updateOffset = function (percent) { + // default value is 0s = 50% + this.value = percent === undefined ? 50 : percent; + }; - subtitleSyncSlider.addEventListener('change', function () { - // set new offset - playbackManager.setSubtitleOffset(getOffsetFromPercentage(this.value), player); - // synchronize with textField value - subtitleSyncTextField.updateOffset( - getOffsetFromPercentage(this.value)); - }); + subtitleSyncSlider.addEventListener('change', function () { + // set new offset + playbackManager.setSubtitleOffset(getOffsetFromPercentage(this.value), player); + // synchronize with textField value + subtitleSyncTextField.updateOffset( + getOffsetFromPercentage(this.value)); + }); - subtitleSyncSlider.getBubbleHtml = function (value) { - var newOffset = getOffsetFromPercentage(value); - return '

' + + subtitleSyncSlider.getBubbleHtml = function (value) { + const newOffset = getOffsetFromPercentage(value); + return '

' + (newOffset > 0 ? '+' : '') + parseFloat(newOffset) + 's' + '

'; - }; + }; - subtitleSyncCloseButton.addEventListener('click', function() { - playbackManager.disableShowingSubtitleOffset(player); - SubtitleSync.prototype.toggle('forceToHide'); - }); + subtitleSyncCloseButton.addEventListener('click', function () { + playbackManager.disableShowingSubtitleOffset(player); + SubtitleSync.prototype.toggle('forceToHide'); + }); - instance.element = parent; - } + instance.element = parent; +} - function getOffsetFromPercentage(value) { - // convert percent to fraction - var offset = (value - 50) / 50; - // multiply by offset min/max range value (-x to +x) : - offset *= 30; - return offset.toFixed(1); - } +function getOffsetFromPercentage(value) { + // convert percent to fraction + let offset = (value - 50) / 50; + // multiply by offset min/max range value (-x to +x) : + offset *= 30; + return offset.toFixed(1); +} - function getPercentageFromOffset(value) { - // divide by offset min/max range value (-x to +x) : - var percentValue = value / 30; - // convert fraction to percent - percentValue *= 50; - percentValue += 50; - return Math.min(100, Math.max(0, percentValue.toFixed())); - } +function getPercentageFromOffset(value) { + // divide by offset min/max range value (-x to +x) : + let percentValue = value / 30; + // convert fraction to percent + percentValue *= 50; + percentValue += 50; + return Math.min(100, Math.max(0, percentValue.toFixed())); +} - function SubtitleSync(currentPlayer) { +class SubtitleSync { + constructor(currentPlayer) { player = currentPlayer; init(this); } - SubtitleSync.prototype.destroy = function() { + destroy() { SubtitleSync.prototype.toggle('forceToHide'); if (player) { playbackManager.disableShowingSubtitleOffset(player); playbackManager.setSubtitleOffset(0, player); } - var elem = this.element; + const elem = this.element; if (elem) { elem.parentNode.removeChild(elem); this.element = null; } - }; + } - SubtitleSync.prototype.toggle = function(action) { + toggle(action) { if (player && playbackManager.supportSubtitleOffset(player)) { /* eslint-disable no-fallthrough */ switch (action) { @@ -170,7 +171,7 @@ define(['playbackManager', 'layoutManager', 'text!./subtitlesync.template.html', } /* eslint-enable no-fallthrough */ } - }; + } +} - return SubtitleSync; -}); +export default SubtitleSync; From 42ac558a17dde06fed9f0be9736dd63eb91a8caa Mon Sep 17 00:00:00 2001 From: Cameron Date: Thu, 6 Aug 2020 11:41:18 +0100 Subject: [PATCH 044/301] Migration of notification to ES6 module --- package.json | 1 + src/components/notifications/notifications.js | 404 +++++++++--------- 2 files changed, 203 insertions(+), 202 deletions(-) diff --git a/package.json b/package.json index 1d7cf770d3..f729f60723 100644 --- a/package.json +++ b/package.json @@ -135,6 +135,7 @@ "src/components/metadataEditor/metadataEditor.js", "src/components/metadataEditor/personEditor.js", "src/components/multiSelect/multiSelect.js", + "src/components/notifications/notifications.js", "src/components/nowPlayingBar/nowPlayingBar.js", "src/components/playback/brightnessosd.js", "src/components/playback/mediasession.js", diff --git a/src/components/notifications/notifications.js b/src/components/notifications/notifications.js index 0bf270f2a1..020d9953ef 100644 --- a/src/components/notifications/notifications.js +++ b/src/components/notifications/notifications.js @@ -1,181 +1,181 @@ -define(['serverNotifications', 'playbackManager', 'events', 'globalize', 'require'], function (serverNotifications, playbackManager, events, globalize, require) { - 'use strict'; +import serverNotifications from 'serverNotifications'; +import playbackManager from 'playbackManager'; +import events from 'events'; +import globalize from 'globalize'; - playbackManager = playbackManager.default || playbackManager; +function onOneDocumentClick() { + document.removeEventListener('click', onOneDocumentClick); + document.removeEventListener('keydown', onOneDocumentClick); - function onOneDocumentClick() { - document.removeEventListener('click', onOneDocumentClick); - document.removeEventListener('keydown', onOneDocumentClick); - - // don't request notification permissions if they're already granted or denied - if (window.Notification && window.Notification.permission === 'default') { - /* eslint-disable-next-line compat/compat */ - Notification.requestPermission(); - } - } - - document.addEventListener('click', onOneDocumentClick); - document.addEventListener('keydown', onOneDocumentClick); - - var serviceWorkerRegistration; - - function closeAfter(notification, timeoutMs) { - setTimeout(function () { - if (notification.close) { - notification.close(); - } else if (notification.cancel) { - notification.cancel(); - } - }, timeoutMs); - } - - function resetRegistration() { + // don't request notification permissions if they're already granted or denied + if (window.Notification && window.Notification.permission === 'default') { /* eslint-disable-next-line compat/compat */ - var serviceWorker = navigator.serviceWorker; - if (serviceWorker) { - serviceWorker.ready.then(function (registration) { - serviceWorkerRegistration = registration; - }); + Notification.requestPermission(); + } +} + +document.addEventListener('click', onOneDocumentClick); +document.addEventListener('keydown', onOneDocumentClick); + +let serviceWorkerRegistration; + +function closeAfter(notification, timeoutMs) { + setTimeout(function () { + if (notification.close) { + notification.close(); + } else if (notification.cancel) { + notification.cancel(); + } + }, timeoutMs); +} + +function resetRegistration() { + /* eslint-disable-next-line compat/compat */ + let serviceWorker = navigator.serviceWorker; + if (serviceWorker) { + serviceWorker.ready.then(function (registration) { + serviceWorkerRegistration = registration; + }); + } +} + +resetRegistration(); + +function showPersistentNotification(title, options, timeoutMs) { + serviceWorkerRegistration.showNotification(title, options); +} + +function showNonPersistentNotification(title, options, timeoutMs) { + try { + let notif = new Notification(title, options); /* eslint-disable-line compat/compat */ + + if (notif.show) { + notif.show(); + } + + if (timeoutMs) { + closeAfter(notif, timeoutMs); + } + } catch (err) { + if (options.actions) { + options.actions = []; + showNonPersistentNotification(title, options, timeoutMs); + } else { + throw err; } } +} + +function showNotification(options, timeoutMs, apiClient) { + let title = options.title; + + options.data = options.data || {}; + options.data.serverId = apiClient.serverInfo().Id; + options.icon = options.icon || getIconUrl(); + options.badge = options.badge || getIconUrl('badge.png'); resetRegistration(); - function showPersistentNotification(title, options, timeoutMs) { - serviceWorkerRegistration.showNotification(title, options); + if (serviceWorkerRegistration) { + showPersistentNotification(title, options, timeoutMs); + return; } - function showNonPersistentNotification(title, options, timeoutMs) { - try { - var notif = new Notification(title, options); /* eslint-disable-line compat/compat */ + showNonPersistentNotification(title, options, timeoutMs); +} - if (notif.show) { - notif.show(); - } - - if (timeoutMs) { - closeAfter(notif, timeoutMs); - } - } catch (err) { - if (options.actions) { - options.actions = []; - showNonPersistentNotification(title, options, timeoutMs); - } else { - throw err; - } - } +function showNewItemNotification(item, apiClient) { + if (playbackManager.isPlayingLocally(['Video'])) { + return; } - function showNotification(options, timeoutMs, apiClient) { - var title = options.title; + let body = item.Name; - options.data = options.data || {}; - options.data.serverId = apiClient.serverInfo().Id; - options.icon = options.icon || getIconUrl(); - options.badge = options.badge || getIconUrl('badge.png'); - - resetRegistration(); - - if (serviceWorkerRegistration) { - showPersistentNotification(title, options, timeoutMs); - return; - } - - showNonPersistentNotification(title, options, timeoutMs); + if (item.SeriesName) { + body = item.SeriesName + ' - ' + body; } - function showNewItemNotification(item, apiClient) { - if (playbackManager.isPlayingLocally(['Video'])) { - return; - } + let notification = { + title: 'New ' + item.Type, + body: body, + vibrate: true, + tag: 'newItem' + item.Id, + data: {} + }; - var body = item.Name; + let imageTags = item.ImageTags || {}; - if (item.SeriesName) { - body = item.SeriesName + ' - ' + body; - } - - var notification = { - title: 'New ' + item.Type, - body: body, - vibrate: true, - tag: 'newItem' + item.Id, - data: {} - }; - - var imageTags = item.ImageTags || {}; - - if (imageTags.Primary) { - notification.icon = apiClient.getScaledImageUrl(item.Id, { - width: 80, - tag: imageTags.Primary, - type: 'Primary' - }); - } - - showNotification(notification, 15000, apiClient); - } - - function onLibraryChanged(data, apiClient) { - var newItems = data.ItemsAdded; - - if (!newItems.length) { - return; - } - - // Don't put a massive number of Id's onto the query string - if (newItems.length > 12) { - newItems.length = 12; - } - - apiClient.getItems(apiClient.getCurrentUserId(), { - - Recursive: true, - Limit: 3, - Filters: 'IsNotFolder', - SortBy: 'DateCreated', - SortOrder: 'Descending', - Ids: newItems.join(','), - MediaTypes: 'Audio,Video', - EnableTotalRecordCount: false - - }).then(function (result) { - var items = result.Items; - - for (var i = 0, length = items.length ; i < length; i++) { - showNewItemNotification(items[i], apiClient); - } + if (imageTags.Primary) { + notification.icon = apiClient.getScaledImageUrl(item.Id, { + width: 80, + tag: imageTags.Primary, + type: 'Primary' }); } - function getIconUrl(name) { - name = name || 'notificationicon.png'; - return require.toUrl('.').split('?')[0] + '/' + name; + showNotification(notification, 15000, apiClient); +} + +function onLibraryChanged(data, apiClient) { + let newItems = data.ItemsAdded; + + if (!newItems.length) { + return; } - function showPackageInstallNotification(apiClient, installation, status) { - apiClient.getCurrentUser().then(function (user) { - if (!user.Policy.IsAdministrator) { - return; - } + // Don't put a massive number of Id's onto the query string + if (newItems.length > 12) { + newItems.length = 12; + } - var notification = { - tag: 'install' + installation.Id, - data: {} - }; + apiClient.getItems(apiClient.getCurrentUserId(), { - if (status === 'completed') { - notification.title = globalize.translate('PackageInstallCompleted', installation.Name, installation.Version); - notification.vibrate = true; - } else if (status === 'cancelled') { - notification.title = globalize.translate('PackageInstallCancelled', installation.Name, installation.Version); - } else if (status === 'failed') { - notification.title = globalize.translate('PackageInstallFailed', installation.Name, installation.Version); - notification.vibrate = true; - } else if (status === 'progress') { - notification.title = globalize.translate('InstallingPackage', installation.Name, installation.Version); + Recursive: true, + Limit: 3, + Filters: 'IsNotFolder', + SortBy: 'DateCreated', + SortOrder: 'Descending', + Ids: newItems.join(','), + MediaTypes: 'Audio,Video', + EnableTotalRecordCount: false - notification.actions = + }).then(function (result) { + let items = result.Items; + + for (const item of items) { + showNewItemNotification(item, apiClient); + } + }); +} + +function getIconUrl(name) { + name = name || 'notificationicon.png'; + return './components/notifications/' + name; +} + +function showPackageInstallNotification(apiClient, installation, status) { + apiClient.getCurrentUser().then(function (user) { + if (!user.Policy.IsAdministrator) { + return; + } + + let notification = { + tag: 'install' + installation.Id, + data: {} + }; + + if (status === 'completed') { + notification.title = globalize.translate('PackageInstallCompleted', installation.Name, installation.Version); + notification.vibrate = true; + } else if (status === 'cancelled') { + notification.title = globalize.translate('PackageInstallCancelled', installation.Name, installation.Version); + } else if (status === 'failed') { + notification.title = globalize.translate('PackageInstallFailed', installation.Name, installation.Version); + notification.vibrate = true; + } else if (status === 'progress') { + notification.title = globalize.translate('InstallingPackage', installation.Name, installation.Version); + + notification.actions = [ { action: 'cancel-install', @@ -184,67 +184,67 @@ define(['serverNotifications', 'playbackManager', 'events', 'globalize', 'requir } ]; - notification.data.id = installation.id; - } + notification.data.id = installation.id; + } - if (status === 'progress') { - var percentComplete = Math.round(installation.PercentComplete || 0); + if (status === 'progress') { + let percentComplete = Math.round(installation.PercentComplete || 0); - notification.body = percentComplete + '% complete.'; - } + notification.body = percentComplete + '% complete.'; + } - var timeout = status === 'cancelled' ? 5000 : 0; + let timeout = status === 'cancelled' ? 5000 : 0; - showNotification(notification, timeout, apiClient); - }); - } - - events.on(serverNotifications, 'LibraryChanged', function (e, apiClient, data) { - onLibraryChanged(data, apiClient); + showNotification(notification, timeout, apiClient); }); +} - events.on(serverNotifications, 'PackageInstallationCompleted', function (e, apiClient, data) { - showPackageInstallNotification(apiClient, data, 'completed'); - }); +events.on(serverNotifications, 'LibraryChanged', function (e, apiClient, data) { + onLibraryChanged(data, apiClient); +}); - events.on(serverNotifications, 'PackageInstallationFailed', function (e, apiClient, data) { - showPackageInstallNotification(apiClient, data, 'failed'); - }); +events.on(serverNotifications, 'PackageInstallationCompleted', function (e, apiClient, data) { + showPackageInstallNotification(apiClient, data, 'completed'); +}); - events.on(serverNotifications, 'PackageInstallationCancelled', function (e, apiClient, data) { - showPackageInstallNotification(apiClient, data, 'cancelled'); - }); +events.on(serverNotifications, 'PackageInstallationFailed', function (e, apiClient, data) { + showPackageInstallNotification(apiClient, data, 'failed'); +}); - events.on(serverNotifications, 'PackageInstalling', function (e, apiClient, data) { - showPackageInstallNotification(apiClient, data, 'progress'); - }); +events.on(serverNotifications, 'PackageInstallationCancelled', function (e, apiClient, data) { + showPackageInstallNotification(apiClient, data, 'cancelled'); +}); - events.on(serverNotifications, 'ServerShuttingDown', function (e, apiClient, data) { - var serverId = apiClient.serverInfo().Id; - var notification = { - tag: 'restart' + serverId, - title: globalize.translate('ServerNameIsShuttingDown', apiClient.serverInfo().Name) - }; - showNotification(notification, 0, apiClient); - }); +events.on(serverNotifications, 'PackageInstalling', function (e, apiClient, data) { + showPackageInstallNotification(apiClient, data, 'progress'); +}); - events.on(serverNotifications, 'ServerRestarting', function (e, apiClient, data) { - var serverId = apiClient.serverInfo().Id; - var notification = { - tag: 'restart' + serverId, - title: globalize.translate('ServerNameIsRestarting', apiClient.serverInfo().Name) - }; - showNotification(notification, 0, apiClient); - }); +events.on(serverNotifications, 'ServerShuttingDown', function (e, apiClient, data) { + let serverId = apiClient.serverInfo().Id; + let notification = { + tag: 'restart' + serverId, + title: globalize.translate('ServerNameIsShuttingDown', apiClient.serverInfo().Name) + }; + showNotification(notification, 0, apiClient); +}); - events.on(serverNotifications, 'RestartRequired', function (e, apiClient) { - var serverId = apiClient.serverInfo().Id; - var notification = { - tag: 'restart' + serverId, - title: globalize.translate('PleaseRestartServerName', apiClient.serverInfo().Name) - }; +events.on(serverNotifications, 'ServerRestarting', function (e, apiClient, data) { + let serverId = apiClient.serverInfo().Id; + let notification = { + tag: 'restart' + serverId, + title: globalize.translate('ServerNameIsRestarting', apiClient.serverInfo().Name) + }; + showNotification(notification, 0, apiClient); +}); - notification.actions = +events.on(serverNotifications, 'RestartRequired', function (e, apiClient) { + let serverId = apiClient.serverInfo().Id; + let notification = { + tag: 'restart' + serverId, + title: globalize.translate('PleaseRestartServerName', apiClient.serverInfo().Name) + }; + + notification.actions = [ { action: 'restart', @@ -253,6 +253,6 @@ define(['serverNotifications', 'playbackManager', 'events', 'globalize', 'requir } ]; - showNotification(notification, 0, apiClient); - }); + showNotification(notification, 0, apiClient); }); + From e813f64cd2d92ce9f8069b8f53ac9231b5e5b970 Mon Sep 17 00:00:00 2001 From: Cameron Date: Thu, 6 Aug 2020 11:41:45 +0100 Subject: [PATCH 045/301] Migration of themeMediaPlayer to ES6 module --- package.json | 1 + src/components/themeMediaPlayer.js | 175 ++++++++++++++--------------- 2 files changed, 88 insertions(+), 88 deletions(-) diff --git a/package.json b/package.json index f729f60723..aceef6b67e 100644 --- a/package.json +++ b/package.json @@ -167,6 +167,7 @@ "src/components/syncPlay/playbackPermissionManager.js", "src/components/syncPlay/syncPlayManager.js", "src/components/syncPlay/timeSyncManager.js", + "src/components/themeMediaPlayer.js", "src/components/toast/toast.js", "src/components/upnextdialog/upnextdialog.js", "src/components/viewContainer.js", diff --git a/src/components/themeMediaPlayer.js b/src/components/themeMediaPlayer.js index 60f0986884..4ee9e0c910 100644 --- a/src/components/themeMediaPlayer.js +++ b/src/components/themeMediaPlayer.js @@ -1,103 +1,102 @@ -define(['playbackManager', 'userSettings', 'connectionManager'], function (playbackManager, userSettings, connectionManager) { - 'use strict'; +import playbackManager from 'playbackManager'; +import userSettings from 'userSettings'; +import connectionManager from 'connectionManager'; - playbackManager = playbackManager.default || playbackManager; +let currentOwnerId; +let currentThemeIds = []; - var currentOwnerId; - var currentThemeIds = []; +function playThemeMedia(items, ownerId) { + const currentThemeItems = items.filter(function (i) { + return enabled(i.MediaType); + }); - function playThemeMedia(items, ownerId) { - var currentThemeItems = items.filter(function (i) { - return enabled(i.MediaType); + if (currentThemeItems.length) { + // Stop if a theme song from another ownerId + // Leave it alone if anything else (e.g user playing a movie) + if (!currentOwnerId && playbackManager.isPlaying()) { + return; + } + + currentThemeIds = currentThemeItems.map(function (i) { + return i.Id; }); - if (currentThemeItems.length) { - // Stop if a theme song from another ownerId - // Leave it alone if anything else (e.g user playing a movie) - if (!currentOwnerId && playbackManager.isPlaying()) { - return; - } - - currentThemeIds = currentThemeItems.map(function (i) { - return i.Id; - }); - - playbackManager.play({ - items: currentThemeItems, - fullscreen: false, - enableRemotePlayers: false - }).then(function () { - currentOwnerId = ownerId; - }); - } else { - stopIfPlaying(); - } - } - - function stopIfPlaying() { - if (currentOwnerId) { - playbackManager.stop(); - } - - currentOwnerId = null; - } - - function enabled(mediaType) { - if (mediaType === 'Video') { - return userSettings.enableThemeVideos(); - } - - return userSettings.enableThemeSongs(); - } - - var excludeTypes = ['CollectionFolder', 'UserView', 'Program', 'SeriesTimer', 'Person', 'TvChannel', 'Channel']; - - function loadThemeMedia(item) { - if (item.CollectionType) { - stopIfPlaying(); - return; - } - - if (excludeTypes.indexOf(item.Type) !== -1) { - stopIfPlaying(); - return; - } - - var apiClient = connectionManager.getApiClient(item.ServerId); - apiClient.getThemeMedia(apiClient.getCurrentUserId(), item.Id, true).then(function (themeMediaResult) { - var ownerId = themeMediaResult.ThemeVideosResult.Items.length ? themeMediaResult.ThemeVideosResult.OwnerId : themeMediaResult.ThemeSongsResult.OwnerId; - - if (ownerId !== currentOwnerId) { - var items = themeMediaResult.ThemeVideosResult.Items.length ? themeMediaResult.ThemeVideosResult.Items : themeMediaResult.ThemeSongsResult.Items; - - playThemeMedia(items, ownerId); - } + playbackManager.play({ + items: currentThemeItems, + fullscreen: false, + enableRemotePlayers: false + }).then(function () { + currentOwnerId = ownerId; }); + } else { + stopIfPlaying(); + } +} + +function stopIfPlaying() { + if (currentOwnerId) { + playbackManager.stop(); } - document.addEventListener('viewshow', function (e) { - var state = e.detail.state || {}; - var item = state.item; + currentOwnerId = null; +} - if (item && item.ServerId) { - loadThemeMedia(item); - return; - } +function enabled(mediaType) { + if (mediaType === 'Video') { + return userSettings.enableThemeVideos(); + } - var viewOptions = e.detail.options || {}; + return userSettings.enableThemeSongs(); +} - if (viewOptions.supportsThemeMedia) { - // Do nothing here, allow it to keep playing - } else { - playThemeMedia([], null); - } - }, true); +const excludeTypes = ['CollectionFolder', 'UserView', 'Program', 'SeriesTimer', 'Person', 'TvChannel', 'Channel']; - Events.on(playbackManager, 'playbackstart', function (e, player) { - var item = playbackManager.currentItem(player); - // User played something manually - if (currentThemeIds.indexOf(item.Id) == -1) { - currentOwnerId = null; +function loadThemeMedia(item) { + if (item.CollectionType) { + stopIfPlaying(); + return; + } + + if (excludeTypes.indexOf(item.Type) !== -1) { + stopIfPlaying(); + return; + } + + const apiClient = connectionManager.getApiClient(item.ServerId); + apiClient.getThemeMedia(apiClient.getCurrentUserId(), item.Id, true).then(function (themeMediaResult) { + const ownerId = themeMediaResult.ThemeVideosResult.Items.length ? themeMediaResult.ThemeVideosResult.OwnerId : themeMediaResult.ThemeSongsResult.OwnerId; + + if (ownerId !== currentOwnerId) { + const items = themeMediaResult.ThemeVideosResult.Items.length ? themeMediaResult.ThemeVideosResult.Items : themeMediaResult.ThemeSongsResult.Items; + + playThemeMedia(items, ownerId); } }); +} + +document.addEventListener('viewshow', function (e) { + const state = e.detail.state || {}; + const item = state.item; + + if (item && item.ServerId) { + loadThemeMedia(item); + return; + } + + const viewOptions = e.detail.options || {}; + + if (viewOptions.supportsThemeMedia) { + // Do nothing here, allow it to keep playing + } else { + playThemeMedia([], null); + } +}, true); + +Events.on(playbackManager, 'playbackstart', function (e, player) { + const item = playbackManager.currentItem(player); + // User played something manually + if (currentThemeIds.indexOf(item.Id) == -1) { + currentOwnerId = null; + } }); + From 5dbf93d42d41aa0fff2f7a4ed16370fff6eecb61 Mon Sep 17 00:00:00 2001 From: Cameron Date: Thu, 6 Aug 2020 11:41:58 +0100 Subject: [PATCH 046/301] Migration of viewSettings to ES6 module --- package.json | 1 + src/components/viewSettings/viewSettings.js | 121 +++++++++++--------- 2 files changed, 66 insertions(+), 56 deletions(-) diff --git a/package.json b/package.json index aceef6b67e..7e0e76c6d7 100644 --- a/package.json +++ b/package.json @@ -171,6 +171,7 @@ "src/components/toast/toast.js", "src/components/upnextdialog/upnextdialog.js", "src/components/viewContainer.js", + "src/components/viewSettings/viewSettings.js", "src/controllers/session/addServer/index.js", "src/controllers/session/forgotPassword/index.js", "src/controllers/session/redeemPassword/index.js", diff --git a/src/components/viewSettings/viewSettings.js b/src/components/viewSettings/viewSettings.js index 67abc25a9c..fd5b5c3f9e 100644 --- a/src/components/viewSettings/viewSettings.js +++ b/src/components/viewSettings/viewSettings.js @@ -1,57 +1,66 @@ -define(['require', 'dialogHelper', 'loading', 'apphost', 'layoutManager', 'connectionManager', 'appRouter', 'globalize', 'userSettings', 'emby-checkbox', 'emby-input', 'paper-icon-button-light', 'emby-select', 'material-icons', 'css!./../formdialog', 'emby-button', 'flexStyles'], function (require, dialogHelper, loading, appHost, layoutManager, connectionManager, appRouter, globalize, userSettings) { - 'use strict'; +import dialogHelper from 'dialogHelper'; +import layoutManager from 'layoutManager'; +import globalize from 'globalize'; +import * as userSettings from 'userSettings'; +import 'emby-checkbox'; +import 'emby-input'; +import 'paper-icon-button-light'; +import 'emby-select'; +import 'material-icons'; +import 'css!./../formdialog'; +import 'emby-button'; +import 'flexStyles'; - function onSubmit(e) { - e.preventDefault(); - return false; +function onSubmit(e) { + e.preventDefault(); + return false; +} + +function initEditor(context, settings) { + context.querySelector('form').addEventListener('submit', onSubmit); + + const elems = context.querySelectorAll('.viewSetting-checkboxContainer'); + + for (const elem of elems) { + elem.querySelector('input').checked = settings[elem.getAttribute('data-settingname')] || false; } - function initEditor(context, settings) { - context.querySelector('form').addEventListener('submit', onSubmit); + context.querySelector('.selectImageType').value = settings.imageType || 'primary'; +} - var elems = context.querySelectorAll('.viewSetting-checkboxContainer'); - - for (var i = 0, length = elems.length; i < length; i++) { - elems[i].querySelector('input').checked = settings[elems[i].getAttribute('data-settingname')] || false; - } - - context.querySelector('.selectImageType').value = settings.imageType || 'primary'; +function saveValues(context, settings, settingsKey) { + const elems = context.querySelectorAll('.viewSetting-checkboxContainer'); + for (const elem of elems) { + userSettings.set(settingsKey + '-' + elem.getAttribute('data-settingname'), elem.querySelector('input').checked); } - function saveValues(context, settings, settingsKey) { - var elems = context.querySelectorAll('.viewSetting-checkboxContainer'); - for (var i = 0, length = elems.length; i < length; i++) { - userSettings.set(settingsKey + '-' + elems[i].getAttribute('data-settingname'), elems[i].querySelector('input').checked); - } + userSettings.set(settingsKey + '-imageType', context.querySelector('.selectImageType').value); +} - userSettings.set(settingsKey + '-imageType', context.querySelector('.selectImageType').value); +function centerFocus(elem, horiz, on) { + import('scrollHelper').then(({default: scrollHelper}) => { + const fn = on ? 'on' : 'off'; + scrollHelper.centerFocus[fn](elem, horiz); + }); +} + +function showIfAllowed(context, selector, visible) { + const elem = context.querySelector(selector); + + if (visible && !elem.classList.contains('hiddenFromViewSettings')) { + elem.classList.remove('hide'); + } else { + elem.classList.add('hide'); } +} - function centerFocus(elem, horiz, on) { - require(['scrollHelper'], function (scrollHelper) { - var fn = on ? 'on' : 'off'; - scrollHelper.centerFocus[fn](elem, horiz); - }); +class ViewSettings { + constructor() { } - - function showIfAllowed(context, selector, visible) { - var elem = context.querySelector(selector); - - if (visible && !elem.classList.contains('hiddenFromViewSettings')) { - elem.classList.remove('hide'); - } else { - elem.classList.add('hide'); - } - } - - function ViewSettings() { - - } - - ViewSettings.prototype.show = function (options) { + show(options) { return new Promise(function (resolve, reject) { - require(['text!./viewSettings.template.html'], function (template) { - var dialogOptions = { + import('text!./viewSettings.template.html').then(({default: template}) => { + const dialogOptions = { removeOnClose: true, scrollY: false }; @@ -62,11 +71,11 @@ define(['require', 'dialogHelper', 'loading', 'apphost', 'layoutManager', 'conne dialogOptions.size = 'small'; } - var dlg = dialogHelper.createDialog(dialogOptions); + const dlg = dialogHelper.createDialog(dialogOptions); dlg.classList.add('formDialog'); - var html = ''; + let html = ''; html += '
'; html += ''; @@ -78,14 +87,14 @@ define(['require', 'dialogHelper', 'loading', 'apphost', 'layoutManager', 'conne dlg.innerHTML = globalize.translateHtml(html, 'core'); - var settingElements = dlg.querySelectorAll('.viewSetting'); - for (var i = 0, length = settingElements.length; i < length; i++) { - if (options.visibleSettings.indexOf(settingElements[i].getAttribute('data-settingname')) === -1) { - settingElements[i].classList.add('hide'); - settingElements[i].classList.add('hiddenFromViewSettings'); + const settingElements = dlg.querySelectorAll('.viewSetting'); + for (const settingElement of settingElements) { + if (options.visibleSettings.indexOf(settingElement.getAttribute('data-settingname')) === -1) { + settingElement.classList.add('hide'); + settingElement.classList.add('hiddenFromViewSettings'); } else { - settingElements[i].classList.remove('hide'); - settingElements[i].classList.remove('hiddenFromViewSettings'); + settingElement.classList.remove('hide'); + settingElement.classList.remove('hiddenFromViewSettings'); } } @@ -104,7 +113,7 @@ define(['require', 'dialogHelper', 'loading', 'apphost', 'layoutManager', 'conne centerFocus(dlg.querySelector('.formDialogContent'), false, true); } - var submitted; + let submitted; dlg.querySelector('.selectImageType').dispatchEvent(new CustomEvent('change', {})); @@ -127,7 +136,7 @@ define(['require', 'dialogHelper', 'loading', 'apphost', 'layoutManager', 'conne }); }); }); - }; + } +} - return ViewSettings; -}); +export default ViewSettings; From e694f0918aa10a211a4b12a8930de0dfd4667334 Mon Sep 17 00:00:00 2001 From: Cameron Date: Thu, 6 Aug 2020 15:55:10 +0100 Subject: [PATCH 047/301] Migration of remotecontrol to ES6 module --- package.json | 1 + src/components/remotecontrol/remotecontrol.js | 1713 +++++++++-------- 2 files changed, 865 insertions(+), 849 deletions(-) diff --git a/package.json b/package.json index 246b4b5cf5..271fc8e601 100644 --- a/package.json +++ b/package.json @@ -154,6 +154,7 @@ "src/components/playmenu.js", "src/components/prompt/prompt.js", "src/components/refreshdialog/refreshdialog.js", + "src/components/remotecontrol/remotecontrol.js", "src/components/sanatizefilename.js", "src/components/scrollManager.js", "src/plugins/htmlVideoPlayer/plugin.js", diff --git a/src/components/remotecontrol/remotecontrol.js b/src/components/remotecontrol/remotecontrol.js index b5ac4c9a8b..b9f33b4e1a 100644 --- a/src/components/remotecontrol/remotecontrol.js +++ b/src/components/remotecontrol/remotecontrol.js @@ -1,939 +1,954 @@ -define(['browser', 'datetime', 'backdrop', 'libraryBrowser', 'listView', 'imageLoader', 'playbackManager', 'nowPlayingHelper', 'events', 'connectionManager', 'apphost', 'globalize', 'layoutManager', 'userSettings', 'cardBuilder', 'itemContextMenu', 'cardStyle', 'emby-itemscontainer', 'css!./remotecontrol.css', 'emby-ratingbutton'], function (browser, datetime, backdrop, libraryBrowser, listView, imageLoader, playbackManager, nowPlayingHelper, events, connectionManager, appHost, globalize, layoutManager, userSettings, cardBuilder, itemContextMenu) { - 'use strict'; +import datetime from 'datetime'; +import backdrop from 'backdrop'; +import listView from 'listView'; +import imageLoader from 'imageLoader'; +import playbackManager from 'playbackManager'; +import nowPlayingHelper from 'nowPlayingHelper'; +import events from 'events'; +import connectionManager from 'connectionManager'; +import appHost from 'apphost'; +import globalize from 'globalize'; +import layoutManager from 'layoutManager'; +import * as userSettings from 'userSettings'; +import cardBuilder from 'cardBuilder'; +import itemContextMenu from 'itemContextMenu'; +import 'cardStyle'; +import 'emby-itemscontainer'; +import 'css!./remotecontrol.css'; +import 'emby-ratingbutton'; - playbackManager = playbackManager.default || playbackManager; +/*eslint prefer-const: "error"*/ - var showMuteButton = true; - var showVolumeSlider = true; +let showMuteButton = true; +let showVolumeSlider = true; - function showAudioMenu(context, player, button, item) { - var currentIndex = playbackManager.getAudioStreamIndex(player); - var streams = playbackManager.audioTracks(player); - var menuItems = streams.map(function (s) { - var menuItem = { - name: s.DisplayTitle, - id: s.Index - }; +function showAudioMenu(context, player, button, item) { + const currentIndex = playbackManager.getAudioStreamIndex(player); + const streams = playbackManager.audioTracks(player); + const menuItems = streams.map(function (s) { + const menuItem = { + name: s.DisplayTitle, + id: s.Index + }; - if (s.Index == currentIndex) { - menuItem.selected = true; - } - - return menuItem; - }); - - require(['actionsheet'], function (actionsheet) { - actionsheet.show({ - items: menuItems, - positionTo: button, - callback: function (id) { - playbackManager.setAudioStreamIndex(parseInt(id), player); - } - }); - }); - } - - function showSubtitleMenu(context, player, button, item) { - var currentIndex = playbackManager.getSubtitleStreamIndex(player); - var streams = playbackManager.subtitleTracks(player); - var menuItems = streams.map(function (s) { - var menuItem = { - name: s.DisplayTitle, - id: s.Index - }; - - if (s.Index == currentIndex) { - menuItem.selected = true; - } - - return menuItem; - }); - menuItems.unshift({ - id: -1, - name: globalize.translate('ButtonOff'), - selected: currentIndex == null - }); - - require(['actionsheet'], function (actionsheet) { - actionsheet.show({ - items: menuItems, - positionTo: button, - callback: function (id) { - playbackManager.setSubtitleStreamIndex(parseInt(id), player); - } - }); - }); - } - - function getNowPlayingNameHtml(nowPlayingItem, includeNonNameInfo) { - return nowPlayingHelper.getNowPlayingNames(nowPlayingItem, includeNonNameInfo).map(function (i) { - return i.text; - }).join('
'); - } - - function seriesImageUrl(item, options) { - if (item.Type !== 'Episode') { - return null; + if (s.Index == currentIndex) { + menuItem.selected = true; } - options = options || {}; - options.type = options.type || 'Primary'; - if (options.type === 'Primary' && item.SeriesPrimaryImageTag) { - options.tag = item.SeriesPrimaryImageTag; + return menuItem; + }); + + import('actionsheet').then(({ default: actionsheet }) => { + actionsheet.show({ + items: menuItems, + positionTo: button, + callback: function (id) { + playbackManager.setAudioStreamIndex(parseInt(id), player); + } + }); + }); +} + +function showSubtitleMenu(context, player, button, item) { + const currentIndex = playbackManager.getSubtitleStreamIndex(player); + const streams = playbackManager.subtitleTracks(player); + const menuItems = streams.map(function (s) { + const menuItem = { + name: s.DisplayTitle, + id: s.Index + }; + + if (s.Index == currentIndex) { + menuItem.selected = true; + } + + return menuItem; + }); + menuItems.unshift({ + id: -1, + name: globalize.translate('ButtonOff'), + selected: currentIndex == null + }); + + import('actionsheet').then(({ default: actionsheet }) => { + actionsheet.show({ + items: menuItems, + positionTo: button, + callback: function (id) { + playbackManager.setSubtitleStreamIndex(parseInt(id), player); + } + }); + }); +} + +function getNowPlayingNameHtml(nowPlayingItem, includeNonNameInfo) { + return nowPlayingHelper.getNowPlayingNames(nowPlayingItem, includeNonNameInfo).map(function (i) { + return i.text; + }).join('
'); +} + +function seriesImageUrl(item, options) { + if (item.Type !== 'Episode') { + return null; + } + + options = options || {}; + options.type = options.type || 'Primary'; + if (options.type === 'Primary' && item.SeriesPrimaryImageTag) { + options.tag = item.SeriesPrimaryImageTag; + return connectionManager.getApiClient(item.ServerId).getScaledImageUrl(item.SeriesId, options); + } + + if (options.type === 'Thumb') { + if (item.SeriesThumbImageTag) { + options.tag = item.SeriesThumbImageTag; return connectionManager.getApiClient(item.ServerId).getScaledImageUrl(item.SeriesId, options); } - if (options.type === 'Thumb') { - if (item.SeriesThumbImageTag) { - options.tag = item.SeriesThumbImageTag; - return connectionManager.getApiClient(item.ServerId).getScaledImageUrl(item.SeriesId, options); - } - - if (item.ParentThumbImageTag) { - options.tag = item.ParentThumbImageTag; - return connectionManager.getApiClient(item.ServerId).getScaledImageUrl(item.ParentThumbItemId, options); - } + if (item.ParentThumbImageTag) { + options.tag = item.ParentThumbImageTag; + return connectionManager.getApiClient(item.ServerId).getScaledImageUrl(item.ParentThumbItemId, options); } - - return null; } - function imageUrl(item, options) { - options = options || {}; - options.type = options.type || 'Primary'; + return null; +} - if (item.ImageTags && item.ImageTags[options.type]) { - options.tag = item.ImageTags[options.type]; - return connectionManager.getApiClient(item.ServerId).getScaledImageUrl(item.PrimaryImageItemId || item.Id, options); - } +function imageUrl(item, options) { + options = options || {}; + options.type = options.type || 'Primary'; - if (item.AlbumId && item.AlbumPrimaryImageTag) { - options.tag = item.AlbumPrimaryImageTag; - return connectionManager.getApiClient(item.ServerId).getScaledImageUrl(item.AlbumId, options); - } - - return null; + if (item.ImageTags && item.ImageTags[options.type]) { + options.tag = item.ImageTags[options.type]; + return connectionManager.getApiClient(item.ServerId).getScaledImageUrl(item.PrimaryImageItemId || item.Id, options); } - function updateNowPlayingInfo(context, state, serverId) { - var item = state.NowPlayingItem; - var displayName = item ? getNowPlayingNameHtml(item).replace('
', ' - ') : ''; - if (typeof item !== 'undefined') { - var nowPlayingServerId = (item.ServerId || serverId); - if (item.Type == 'Audio' || item.MediaStreams[0].Type == 'Audio') { - var songName = item.Name; - var artistsSeries = ''; - var albumName = ''; - if (item.Artists != null) { - if (item.ArtistItems != null) { - for (const artist of item.ArtistItems) { - let artistName = artist.Name; - let artistId = artist.Id; - artistsSeries += `${artistName}`; - if (artist !== item.ArtistItems.slice(-1)[0]) { - artistsSeries += ', '; - } + if (item.AlbumId && item.AlbumPrimaryImageTag) { + options.tag = item.AlbumPrimaryImageTag; + return connectionManager.getApiClient(item.ServerId).getScaledImageUrl(item.AlbumId, options); + } + + return null; +} + +function updateNowPlayingInfo(context, state, serverId) { + const item = state.NowPlayingItem; + const displayName = item ? getNowPlayingNameHtml(item).replace('
', ' - ') : ''; + if (typeof item !== 'undefined') { + const nowPlayingServerId = (item.ServerId || serverId); + if (item.Type == 'Audio' || item.MediaStreams[0].Type == 'Audio') { + const songName = item.Name; + let artistsSeries = ''; + let albumName = ''; + if (item.Artists != null) { + if (item.ArtistItems != null) { + for (const artist of item.ArtistItems) { + const artistName = artist.Name; + const artistId = artist.Id; + artistsSeries += `${artistName}`; + if (artist !== item.ArtistItems.slice(-1)[0]) { + artistsSeries += ', '; } - } else if (item.Artists) { - // For some reason, Chromecast Player doesn't return a item.ArtistItems object, so we need to fallback - // to normal item.Artists item. - // TODO: Normalise fields returned by all the players - for (const artist of item.Artists) { - artistsSeries += `${artist}`; - if (artist !== item.Artists.slice(-1)[0]) { - artistsSeries += ', '; - } + } + } else if (item.Artists) { + // For some reason, Chromecast Player doesn't return a item.ArtistItems object, so we need to fallback + // to normal item.Artists item. + // TODO: Normalise fields returned by all the players + for (const artist of item.Artists) { + artistsSeries += `${artist}`; + if (artist !== item.Artists.slice(-1)[0]) { + artistsSeries += ', '; } } } - if (item.Album != null) { - albumName = '` + item.Album + ''; - } - context.querySelector('.nowPlayingAlbum').innerHTML = albumName; - context.querySelector('.nowPlayingArtist').innerHTML = artistsSeries; - context.querySelector('.nowPlayingSongName').innerHTML = songName; - } else if (item.Type == 'Episode') { - if (item.SeasonName != null) { - var seasonName = item.SeasonName; - context.querySelector('.nowPlayingSeason').innerHTML = '${seasonName}`; - } - if (item.SeriesName != null) { - var seriesName = item.SeriesName; - if (item.SeriesId != null) { - context.querySelector('.nowPlayingSerie').innerHTML = '${seriesName}`; - } else { - context.querySelector('.nowPlayingSerie').innerHTML = seriesName; - } - } - context.querySelector('.nowPlayingEpisode').innerHTML = item.Name; - } else { - context.querySelector('.nowPlayingPageTitle').innerHTML = displayName; } - - if (displayName.length > 0 && item.Type != 'Audio' && item.Type != 'Episode') { - context.querySelector('.nowPlayingPageTitle').classList.remove('hide'); - } else { - context.querySelector('.nowPlayingPageTitle').classList.add('hide'); + if (item.Album != null) { + albumName = '` + item.Album + ''; } - - var url = item ? seriesImageUrl(item, { - maxHeight: 300 - }) || imageUrl(item, { - maxHeight: 300 - }) : null; - - let contextButton = context.querySelector('.btnToggleContextMenu'); - // We remove the previous event listener by replacing the item in each update event - const autoFocusContextButton = document.activeElement === contextButton; - let contextButtonClone = contextButton.cloneNode(true); - contextButton.parentNode.replaceChild(contextButtonClone, contextButton); - contextButton = context.querySelector('.btnToggleContextMenu'); - if (autoFocusContextButton) { - contextButton.focus(); + context.querySelector('.nowPlayingAlbum').innerHTML = albumName; + context.querySelector('.nowPlayingArtist').innerHTML = artistsSeries; + context.querySelector('.nowPlayingSongName').innerHTML = songName; + } else if (item.Type == 'Episode') { + if (item.SeasonName != null) { + const seasonName = item.SeasonName; + context.querySelector('.nowPlayingSeason').innerHTML = '${seasonName}`; } - const stopPlayback = !!layoutManager.mobile; - var options = { - play: false, - queue: false, - stopPlayback: stopPlayback, - clearQueue: true, - openAlbum: false, - positionTo: contextButton - }; - var apiClient = connectionManager.getApiClient(item.ServerId); - apiClient.getItem(apiClient.getCurrentUserId(), item.Id).then(function (fullItem) { - apiClient.getCurrentUser().then(function (user) { - contextButton.addEventListener('click', function () { - itemContextMenu.show(Object.assign({ - item: fullItem, - user: user - }, options)); - }); - }); - }); - setImageUrl(context, state, url); - if (item) { - backdrop.setBackdrops([item]); - apiClient.getItem(apiClient.getCurrentUserId(), item.Id).then(function (fullItem) { - var userData = fullItem.UserData || {}; - var likes = userData.Likes == null ? '' : userData.Likes; - context.querySelector('.nowPlayingPageUserDataButtonsTitle').innerHTML = ''; - context.querySelector('.nowPlayingPageUserDataButtons').innerHTML = ''; - }); - } else { - backdrop.clearBackdrop(); - context.querySelector('.nowPlayingPageUserDataButtons').innerHTML = ''; - } - } - } - - function setImageUrl(context, state, url) { - var item = state.NowPlayingItem; - var imgContainer = context.querySelector('.nowPlayingPageImageContainer'); - - if (url) { - imgContainer.innerHTML = ''; - if (item.Type == 'Audio') { - context.querySelector('.nowPlayingPageImage').classList.add('nowPlayingPageImageAudio'); - context.querySelector('.nowPlayingPageImageContainer').classList.remove('nowPlayingPageImageAudio'); - } else { - context.querySelector('.nowPlayingPageImageContainer').classList.add('nowPlayingPageImagePoster'); - context.querySelector('.nowPlayingPageImage').classList.remove('nowPlayingPageImageAudio'); - } - } else { - imgContainer.innerHTML = '
'; - } - } - - function buttonVisible(btn, enabled) { - if (enabled) { - btn.classList.remove('hide'); - } else { - btn.classList.add('hide'); - } - } - - function updateSupportedCommands(context, commands) { - var all = context.querySelectorAll('.btnCommand'); - - for (var i = 0, length = all.length; i < length; i++) { - var enableButton = commands.indexOf(all[i].getAttribute('data-command')) !== -1; - all[i].disabled = !enableButton; - } - } - - return function () { - function toggleRepeat() { - switch (playbackManager.getRepeatMode()) { - case 'RepeatAll': - playbackManager.setRepeatMode('RepeatOne'); - break; - case 'RepeatOne': - playbackManager.setRepeatMode('RepeatNone'); - break; - case 'RepeatNone': - playbackManager.setRepeatMode('RepeatAll'); - } - } - - function updatePlayerState(player, context, state) { - lastPlayerState = state; - var item = state.NowPlayingItem; - var playerInfo = playbackManager.getPlayerInfo(); - var supportedCommands = playerInfo.supportedCommands; - currentPlayerSupportedCommands = supportedCommands; - var playState = state.PlayState || {}; - var isSupportedCommands = supportedCommands.includes('DisplayMessage') || supportedCommands.includes('SendString') || supportedCommands.includes('Select'); - buttonVisible(context.querySelector('.btnToggleFullscreen'), item && item.MediaType == 'Video' && supportedCommands.includes('ToggleFullscreen')); - updateAudioTracksDisplay(player, context); - updateSubtitleTracksDisplay(player, context); - - if (supportedCommands.includes('DisplayMessage') && !currentPlayer.isLocalPlayer) { - context.querySelector('.sendMessageSection').classList.remove('hide'); - } else { - context.querySelector('.sendMessageSection').classList.add('hide'); - } - - if (supportedCommands.includes('SendString') && !currentPlayer.isLocalPlayer) { - context.querySelector('.sendTextSection').classList.remove('hide'); - } else { - context.querySelector('.sendTextSection').classList.add('hide'); - } - - if (supportedCommands.includes('Select') && !currentPlayer.isLocalPlayer) { - context.querySelector('.navigationSection').classList.remove('hide'); - } else { - context.querySelector('.navigationSection').classList.add('hide'); - } - - if (isSupportedCommands && !currentPlayer.isLocalPlayer) { - context.querySelector('.remoteControlSection').classList.remove('hide'); - } else { - context.querySelector('.remoteControlSection').classList.add('hide'); - } - - buttonVisible(context.querySelector('.btnStop'), item != null); - buttonVisible(context.querySelector('.btnNextTrack'), item != null); - buttonVisible(context.querySelector('.btnPreviousTrack'), item != null); - if (layoutManager.mobile) { - buttonVisible(context.querySelector('.btnRewind'), false); - buttonVisible(context.querySelector('.btnFastForward'), false); - } else { - buttonVisible(context.querySelector('.btnRewind'), item != null); - buttonVisible(context.querySelector('.btnFastForward'), item != null); - } - var positionSlider = context.querySelector('.nowPlayingPositionSlider'); - - if (positionSlider && item && item.RunTimeTicks) { - positionSlider.setKeyboardSteps(userSettings.skipBackLength() * 1000000 / item.RunTimeTicks, - userSettings.skipForwardLength() * 1000000 / item.RunTimeTicks); - } - - if (positionSlider && !positionSlider.dragging) { - positionSlider.disabled = !playState.CanSeek; - var isProgressClear = state.MediaSource && state.MediaSource.RunTimeTicks == null; - positionSlider.setIsClear(isProgressClear); - } - - updatePlayPauseState(playState.IsPaused, item != null); - updateTimeDisplay(playState.PositionTicks, item ? item.RunTimeTicks : null); - updatePlayerVolumeState(context, playState.IsMuted, playState.VolumeLevel); - - if (item && item.MediaType == 'Video') { - context.classList.remove('hideVideoButtons'); - } else { - context.classList.add('hideVideoButtons'); - } - - updateRepeatModeDisplay(playbackManager.getRepeatMode()); - onShuffleQueueModeChange(false); - updateNowPlayingInfo(context, state); - } - - function updateAudioTracksDisplay(player, context) { - var supportedCommands = currentPlayerSupportedCommands; - buttonVisible(context.querySelector('.btnAudioTracks'), playbackManager.audioTracks(player).length > 1 && supportedCommands.indexOf('SetAudioStreamIndex') != -1); - } - - function updateSubtitleTracksDisplay(player, context) { - var supportedCommands = currentPlayerSupportedCommands; - buttonVisible(context.querySelector('.btnSubtitles'), playbackManager.subtitleTracks(player).length && supportedCommands.indexOf('SetSubtitleStreamIndex') != -1); - } - - function updateRepeatModeDisplay(repeatMode) { - var context = dlg; - let toggleRepeatButtons = context.querySelectorAll('.repeatToggleButton'); - const cssClass = 'buttonActive'; - let innHtml = ''; - let repeatOn = true; - - switch (repeatMode) { - case 'RepeatAll': - break; - case 'RepeatOne': - innHtml = ''; - break; - case 'RepeatNone': - default: - repeatOn = false; - break; - } - - for (const toggleRepeatButton of toggleRepeatButtons) { - toggleRepeatButton.classList.toggle(cssClass, repeatOn); - toggleRepeatButton.innerHTML = innHtml; - } - } - - function updatePlayerVolumeState(context, isMuted, volumeLevel) { - var view = context; - var supportedCommands = currentPlayerSupportedCommands; - - if (supportedCommands.indexOf('Mute') === -1) { - showMuteButton = false; - } - - if (supportedCommands.indexOf('SetVolume') === -1) { - showVolumeSlider = false; - } - - if (currentPlayer.isLocalPlayer && appHost.supports('physicalvolumecontrol')) { - showMuteButton = false; - showVolumeSlider = false; - } - - const buttonMute = view.querySelector('.buttonMute'); - const buttonMuteIcon = buttonMute.querySelector('.material-icons'); - - buttonMuteIcon.classList.remove('volume_off', 'volume_up'); - - if (isMuted) { - buttonMute.setAttribute('title', globalize.translate('Unmute')); - buttonMuteIcon.classList.add('volume_off'); - } else { - buttonMute.setAttribute('title', globalize.translate('Mute')); - buttonMuteIcon.classList.add('volume_up'); - } - - if (!showMuteButton && !showVolumeSlider) { - context.querySelector('.volumecontrol').classList.add('hide'); - } else { - buttonMute.classList.toggle('hide', !showMuteButton); - - var nowPlayingVolumeSlider = context.querySelector('.nowPlayingVolumeSlider'); - var nowPlayingVolumeSliderContainer = context.querySelector('.nowPlayingVolumeSliderContainer'); - - if (nowPlayingVolumeSlider) { - nowPlayingVolumeSliderContainer.classList.toggle('hide', !showVolumeSlider); - - if (!nowPlayingVolumeSlider.dragging) { - nowPlayingVolumeSlider.value = volumeLevel || 0; - } - } - } - } - - function updatePlayPauseState(isPaused, isActive) { - var context = dlg; - var btnPlayPause = context.querySelector('.btnPlayPause'); - const btnPlayPauseIcon = btnPlayPause.querySelector('.material-icons'); - - btnPlayPauseIcon.classList.remove('play_circle_filled', 'pause_circle_filled'); - btnPlayPauseIcon.classList.add(isPaused ? 'play_circle_filled' : 'pause_circle_filled'); - - buttonVisible(btnPlayPause, isActive); - } - - function updateTimeDisplay(positionTicks, runtimeTicks) { - var context = dlg; - var positionSlider = context.querySelector('.nowPlayingPositionSlider'); - - if (positionSlider && !positionSlider.dragging) { - if (runtimeTicks) { - var pct = positionTicks / runtimeTicks; - pct *= 100; - positionSlider.value = pct; + if (item.SeriesName != null) { + const seriesName = item.SeriesName; + if (item.SeriesId != null) { + context.querySelector('.nowPlayingSerie').innerHTML = '${seriesName}`; } else { - positionSlider.value = 0; + context.querySelector('.nowPlayingSerie').innerHTML = seriesName; } } - - context.querySelector('.positionTime').innerHTML = positionTicks == null ? '--:--' : datetime.getDisplayRunningTime(positionTicks); - context.querySelector('.runtime').innerHTML = runtimeTicks != null ? datetime.getDisplayRunningTime(runtimeTicks) : '--:--'; + context.querySelector('.nowPlayingEpisode').innerHTML = item.Name; + } else { + context.querySelector('.nowPlayingPageTitle').innerHTML = displayName; } - function getPlaylistItems(player) { - return playbackManager.getPlaylist(player); + if (displayName.length > 0 && item.Type != 'Audio' && item.Type != 'Episode') { + context.querySelector('.nowPlayingPageTitle').classList.remove('hide'); + } else { + context.querySelector('.nowPlayingPageTitle').classList.add('hide'); } - function loadPlaylist(context, player) { - getPlaylistItems(player).then(function (items) { - var html = ''; - let favoritesEnabled = true; - if (layoutManager.mobile) { - if (items.length > 0) { - context.querySelector('.btnTogglePlaylist').classList.remove('hide'); - } else { - context.querySelector('.btnTogglePlaylist').classList.add('hide'); - } - favoritesEnabled = false; - } + const url = item ? seriesImageUrl(item, { + maxHeight: 300 + }) || imageUrl(item, { + maxHeight: 300 + }) : null; - html += listView.getListViewHtml({ - items: items, - smallIcon: true, - action: 'setplaylistindex', - enableUserDataButtons: favoritesEnabled, - rightButtons: [{ - icon: 'remove_circle_outline', - title: globalize.translate('ButtonRemove'), - id: 'remove' - }], - dragHandle: true + let contextButton = context.querySelector('.btnToggleContextMenu'); + // We remove the previous event listener by replacing the item in each update event + const autoFocusContextButton = document.activeElement === contextButton; + const contextButtonClone = contextButton.cloneNode(true); + contextButton.parentNode.replaceChild(contextButtonClone, contextButton); + contextButton = context.querySelector('.btnToggleContextMenu'); + if (autoFocusContextButton) { + contextButton.focus(); + } + const stopPlayback = !!layoutManager.mobile; + const options = { + play: false, + queue: false, + stopPlayback: stopPlayback, + clearQueue: true, + openAlbum: false, + positionTo: contextButton + }; + const apiClient = connectionManager.getApiClient(item.ServerId); + apiClient.getItem(apiClient.getCurrentUserId(), item.Id).then(function (fullItem) { + apiClient.getCurrentUser().then(function (user) { + contextButton.addEventListener('click', function () { + itemContextMenu.show(Object.assign({ + item: fullItem, + user: user + }, options)); }); - - var itemsContainer = context.querySelector('.playlist'); - let focusedItemPlaylistId = itemsContainer.querySelector('button:focus'); - itemsContainer.innerHTML = html; - if (focusedItemPlaylistId !== null) { - focusedItemPlaylistId = focusedItemPlaylistId.getAttribute('data-playlistitemid'); - const newFocusedItem = itemsContainer.querySelector(`button[data-playlistitemid="${focusedItemPlaylistId}"]`); - if (newFocusedItem !== null) { - newFocusedItem.focus(); - } - } - - var playlistItemId = playbackManager.getCurrentPlaylistItemId(player); - - if (playlistItemId) { - var img = itemsContainer.querySelector(`.listItem[data-playlistItemId="${playlistItemId}"] .listItemImage`); - - if (img) { - img.classList.remove('lazy'); - img.classList.add('playlistIndexIndicatorImage'); - } - } - - imageLoader.lazyChildren(itemsContainer); }); + }); + setImageUrl(context, state, url); + if (item) { + backdrop.setBackdrops([item]); + apiClient.getItem(apiClient.getCurrentUserId(), item.Id).then(function (fullItem) { + const userData = fullItem.UserData || {}; + const likes = userData.Likes == null ? '' : userData.Likes; + context.querySelector('.nowPlayingPageUserDataButtonsTitle').innerHTML = ''; + context.querySelector('.nowPlayingPageUserDataButtons').innerHTML = ''; + }); + } else { + backdrop.clearBackdrop(); + context.querySelector('.nowPlayingPageUserDataButtons').innerHTML = ''; + } + } +} + +function setImageUrl(context, state, url) { + const item = state.NowPlayingItem; + const imgContainer = context.querySelector('.nowPlayingPageImageContainer'); + + if (url) { + imgContainer.innerHTML = ''; + if (item.Type == 'Audio') { + context.querySelector('.nowPlayingPageImage').classList.add('nowPlayingPageImageAudio'); + context.querySelector('.nowPlayingPageImageContainer').classList.remove('nowPlayingPageImageAudio'); + } else { + context.querySelector('.nowPlayingPageImageContainer').classList.add('nowPlayingPageImagePoster'); + context.querySelector('.nowPlayingPageImage').classList.remove('nowPlayingPageImageAudio'); + } + } else { + imgContainer.innerHTML = '
'; + } +} + +function buttonVisible(btn, enabled) { + if (enabled) { + btn.classList.remove('hide'); + } else { + btn.classList.add('hide'); + } +} + +function updateSupportedCommands(context, commands) { + const all = context.querySelectorAll('.btnCommand'); + + for (let i = 0, length = all.length; i < length; i++) { + const enableButton = commands.indexOf(all[i].getAttribute('data-command')) !== -1; + all[i].disabled = !enableButton; + } +} + +export default function () { + function toggleRepeat() { + switch (playbackManager.getRepeatMode()) { + case 'RepeatAll': + playbackManager.setRepeatMode('RepeatOne'); + break; + case 'RepeatOne': + playbackManager.setRepeatMode('RepeatNone'); + break; + case 'RepeatNone': + playbackManager.setRepeatMode('RepeatAll'); + } + } + + function updatePlayerState(player, context, state) { + lastPlayerState = state; + const item = state.NowPlayingItem; + const playerInfo = playbackManager.getPlayerInfo(); + const supportedCommands = playerInfo.supportedCommands; + currentPlayerSupportedCommands = supportedCommands; + const playState = state.PlayState || {}; + const isSupportedCommands = supportedCommands.includes('DisplayMessage') || supportedCommands.includes('SendString') || supportedCommands.includes('Select'); + buttonVisible(context.querySelector('.btnToggleFullscreen'), item && item.MediaType == 'Video' && supportedCommands.includes('ToggleFullscreen')); + updateAudioTracksDisplay(player, context); + updateSubtitleTracksDisplay(player, context); + + if (supportedCommands.includes('DisplayMessage') && !currentPlayer.isLocalPlayer) { + context.querySelector('.sendMessageSection').classList.remove('hide'); + } else { + context.querySelector('.sendMessageSection').classList.add('hide'); } - function onPlaybackStart(e, state) { - console.debug('remotecontrol event: ' + e.type); - var player = this; - onStateChanged.call(player, e, state); + if (supportedCommands.includes('SendString') && !currentPlayer.isLocalPlayer) { + context.querySelector('.sendTextSection').classList.remove('hide'); + } else { + context.querySelector('.sendTextSection').classList.add('hide'); } - function onRepeatModeChange() { - updateRepeatModeDisplay(playbackManager.getRepeatMode()); + if (supportedCommands.includes('Select') && !currentPlayer.isLocalPlayer) { + context.querySelector('.navigationSection').classList.remove('hide'); + } else { + context.querySelector('.navigationSection').classList.add('hide'); } - function onShuffleQueueModeChange(updateView = true) { - let shuffleMode = playbackManager.getQueueShuffleMode(this); - let context = dlg; - const cssClass = 'buttonActive'; - let shuffleButtons = context.querySelectorAll('.btnShuffleQueue'); + if (isSupportedCommands && !currentPlayer.isLocalPlayer) { + context.querySelector('.remoteControlSection').classList.remove('hide'); + } else { + context.querySelector('.remoteControlSection').classList.add('hide'); + } - for (let shuffleButton of shuffleButtons) { - switch (shuffleMode) { - case 'Shuffle': - shuffleButton.classList.add(cssClass); - break; - case 'Sorted': - default: - shuffleButton.classList.remove(cssClass); - break; + buttonVisible(context.querySelector('.btnStop'), item != null); + buttonVisible(context.querySelector('.btnNextTrack'), item != null); + buttonVisible(context.querySelector('.btnPreviousTrack'), item != null); + if (layoutManager.mobile) { + buttonVisible(context.querySelector('.btnRewind'), false); + buttonVisible(context.querySelector('.btnFastForward'), false); + } else { + buttonVisible(context.querySelector('.btnRewind'), item != null); + buttonVisible(context.querySelector('.btnFastForward'), item != null); + } + const positionSlider = context.querySelector('.nowPlayingPositionSlider'); + + if (positionSlider && item && item.RunTimeTicks) { + positionSlider.setKeyboardSteps(userSettings.skipBackLength() * 1000000 / item.RunTimeTicks, + userSettings.skipForwardLength() * 1000000 / item.RunTimeTicks); + } + + if (positionSlider && !positionSlider.dragging) { + positionSlider.disabled = !playState.CanSeek; + const isProgressClear = state.MediaSource && state.MediaSource.RunTimeTicks == null; + positionSlider.setIsClear(isProgressClear); + } + + updatePlayPauseState(playState.IsPaused, item != null); + updateTimeDisplay(playState.PositionTicks, item ? item.RunTimeTicks : null); + updatePlayerVolumeState(context, playState.IsMuted, playState.VolumeLevel); + + if (item && item.MediaType == 'Video') { + context.classList.remove('hideVideoButtons'); + } else { + context.classList.add('hideVideoButtons'); + } + + updateRepeatModeDisplay(playbackManager.getRepeatMode()); + onShuffleQueueModeChange(false); + updateNowPlayingInfo(context, state); + } + + function updateAudioTracksDisplay(player, context) { + const supportedCommands = currentPlayerSupportedCommands; + buttonVisible(context.querySelector('.btnAudioTracks'), playbackManager.audioTracks(player).length > 1 && supportedCommands.indexOf('SetAudioStreamIndex') != -1); + } + + function updateSubtitleTracksDisplay(player, context) { + const supportedCommands = currentPlayerSupportedCommands; + buttonVisible(context.querySelector('.btnSubtitles'), playbackManager.subtitleTracks(player).length && supportedCommands.indexOf('SetSubtitleStreamIndex') != -1); + } + + function updateRepeatModeDisplay(repeatMode) { + const context = dlg; + const toggleRepeatButtons = context.querySelectorAll('.repeatToggleButton'); + const cssClass = 'buttonActive'; + let innHtml = ''; + let repeatOn = true; + + switch (repeatMode) { + case 'RepeatAll': + break; + case 'RepeatOne': + innHtml = ''; + break; + case 'RepeatNone': + default: + repeatOn = false; + break; + } + + for (const toggleRepeatButton of toggleRepeatButtons) { + toggleRepeatButton.classList.toggle(cssClass, repeatOn); + toggleRepeatButton.innerHTML = innHtml; + } + } + + function updatePlayerVolumeState(context, isMuted, volumeLevel) { + const view = context; + const supportedCommands = currentPlayerSupportedCommands; + + if (supportedCommands.indexOf('Mute') === -1) { + showMuteButton = false; + } + + if (supportedCommands.indexOf('SetVolume') === -1) { + showVolumeSlider = false; + } + + if (currentPlayer.isLocalPlayer && appHost.supports('physicalvolumecontrol')) { + showMuteButton = false; + showVolumeSlider = false; + } + + const buttonMute = view.querySelector('.buttonMute'); + const buttonMuteIcon = buttonMute.querySelector('.material-icons'); + + buttonMuteIcon.classList.remove('volume_off', 'volume_up'); + + if (isMuted) { + buttonMute.setAttribute('title', globalize.translate('Unmute')); + buttonMuteIcon.classList.add('volume_off'); + } else { + buttonMute.setAttribute('title', globalize.translate('Mute')); + buttonMuteIcon.classList.add('volume_up'); + } + + if (!showMuteButton && !showVolumeSlider) { + context.querySelector('.volumecontrol').classList.add('hide'); + } else { + buttonMute.classList.toggle('hide', !showMuteButton); + + const nowPlayingVolumeSlider = context.querySelector('.nowPlayingVolumeSlider'); + const nowPlayingVolumeSliderContainer = context.querySelector('.nowPlayingVolumeSliderContainer'); + + if (nowPlayingVolumeSlider) { + nowPlayingVolumeSliderContainer.classList.toggle('hide', !showVolumeSlider); + + if (!nowPlayingVolumeSlider.dragging) { + nowPlayingVolumeSlider.value = volumeLevel || 0; } } - - if (updateView) { - onPlaylistUpdate(); - } } + } - function onPlaylistUpdate(e) { - loadPlaylist(dlg, this); - } + function updatePlayPauseState(isPaused, isActive) { + const context = dlg; + const btnPlayPause = context.querySelector('.btnPlayPause'); + const btnPlayPauseIcon = btnPlayPause.querySelector('.material-icons'); - function onPlaylistItemRemoved(e, info) { - var context = dlg; - if (info !== undefined) { - var playlistItemIds = info.playlistItemIds; + btnPlayPauseIcon.classList.remove('play_circle_filled', 'pause_circle_filled'); + btnPlayPauseIcon.classList.add(isPaused ? 'play_circle_filled' : 'pause_circle_filled'); - for (var i = 0, length = playlistItemIds.length; i < length; i++) { - var listItem = context.querySelector('.listItem[data-playlistItemId="' + playlistItemIds[i] + '"]'); + buttonVisible(btnPlayPause, isActive); + } - if (listItem) { - listItem.parentNode.removeChild(listItem); - } - } + function updateTimeDisplay(positionTicks, runtimeTicks) { + const context = dlg; + const positionSlider = context.querySelector('.nowPlayingPositionSlider'); + + if (positionSlider && !positionSlider.dragging) { + if (runtimeTicks) { + let pct = positionTicks / runtimeTicks; + pct *= 100; + positionSlider.value = pct; } else { - onPlaylistUpdate(); + positionSlider.value = 0; } } - function onPlaybackStopped(e, state) { - console.debug('remotecontrol event: ' + e.type); - var player = this; + context.querySelector('.positionTime').innerHTML = positionTicks == null ? '--:--' : datetime.getDisplayRunningTime(positionTicks); + context.querySelector('.runtime').innerHTML = runtimeTicks != null ? datetime.getDisplayRunningTime(runtimeTicks) : '--:--'; + } - if (!state.NextMediaType) { - updatePlayerState(player, dlg, {}); - Emby.Page.back(); + function getPlaylistItems(player) { + return playbackManager.getPlaylist(player); + } + + function loadPlaylist(context, player) { + getPlaylistItems(player).then(function (items) { + let html = ''; + let favoritesEnabled = true; + if (layoutManager.mobile) { + if (items.length > 0) { + context.querySelector('.btnTogglePlaylist').classList.remove('hide'); + } else { + context.querySelector('.btnTogglePlaylist').classList.add('hide'); + } + favoritesEnabled = false; + } + + html += listView.getListViewHtml({ + items: items, + smallIcon: true, + action: 'setplaylistindex', + enableUserDataButtons: favoritesEnabled, + rightButtons: [{ + icon: 'remove_circle_outline', + title: globalize.translate('ButtonRemove'), + id: 'remove' + }], + dragHandle: true + }); + + const itemsContainer = context.querySelector('.playlist'); + let focusedItemPlaylistId = itemsContainer.querySelector('button:focus'); + itemsContainer.innerHTML = html; + if (focusedItemPlaylistId !== null) { + focusedItemPlaylistId = focusedItemPlaylistId.getAttribute('data-playlistitemid'); + const newFocusedItem = itemsContainer.querySelector(`button[data-playlistitemid="${focusedItemPlaylistId}"]`); + if (newFocusedItem !== null) { + newFocusedItem.focus(); + } + } + + const playlistItemId = playbackManager.getCurrentPlaylistItemId(player); + + if (playlistItemId) { + const img = itemsContainer.querySelector(`.listItem[data-playlistItemId="${playlistItemId}"] .listItemImage`); + + if (img) { + img.classList.remove('lazy'); + img.classList.add('playlistIndexIndicatorImage'); + } + } + + imageLoader.lazyChildren(itemsContainer); + }); + } + + function onPlaybackStart(e, state) { + console.debug('remotecontrol event: ' + e.type); + const player = this; + onStateChanged.call(player, e, state); + } + + function onRepeatModeChange() { + updateRepeatModeDisplay(playbackManager.getRepeatMode()); + } + + function onShuffleQueueModeChange(updateView = true) { + const shuffleMode = playbackManager.getQueueShuffleMode(this); + const context = dlg; + const cssClass = 'buttonActive'; + const shuffleButtons = context.querySelectorAll('.btnShuffleQueue'); + + for (const shuffleButton of shuffleButtons) { + switch (shuffleMode) { + case 'Shuffle': + shuffleButton.classList.add(cssClass); + break; + case 'Sorted': + default: + shuffleButton.classList.remove(cssClass); + break; } } - function onPlayPauseStateChanged(e) { - updatePlayPauseState(this.paused(), true); - } - - function onStateChanged(event, state) { - var player = this; - updatePlayerState(player, dlg, state); + if (updateView) { onPlaylistUpdate(); } + } - function onTimeUpdate(e) { - var now = new Date().getTime(); + function onPlaylistUpdate(e) { + loadPlaylist(dlg, this); + } - if (!(now - lastUpdateTime < 700)) { - lastUpdateTime = now; - var player = this; - currentRuntimeTicks = playbackManager.duration(player); - updateTimeDisplay(playbackManager.currentTime(player), currentRuntimeTicks); + function onPlaylistItemRemoved(e, info) { + const context = dlg; + if (info !== undefined) { + const playlistItemIds = info.playlistItemIds; + + for (let i = 0, length = playlistItemIds.length; i < length; i++) { + const listItem = context.querySelector('.listItem[data-playlistItemId="' + playlistItemIds[i] + '"]'); + + if (listItem) { + listItem.parentNode.removeChild(listItem); + } + } + } else { + onPlaylistUpdate(); + } + } + + function onPlaybackStopped(e, state) { + console.debug('remotecontrol event: ' + e.type); + const player = this; + + if (!state.NextMediaType) { + updatePlayerState(player, dlg, {}); + Emby.Page.back(); + } + } + + function onPlayPauseStateChanged(e) { + updatePlayPauseState(this.paused(), true); + } + + function onStateChanged(event, state) { + const player = this; + updatePlayerState(player, dlg, state); + onPlaylistUpdate(); + } + + function onTimeUpdate(e) { + const now = new Date().getTime(); + + if (!(now - lastUpdateTime < 700)) { + lastUpdateTime = now; + const player = this; + currentRuntimeTicks = playbackManager.duration(player); + updateTimeDisplay(playbackManager.currentTime(player), currentRuntimeTicks); + } + } + + function onVolumeChanged(e) { + const player = this; + updatePlayerVolumeState(dlg, player.isMuted(), player.getVolume()); + } + + function releaseCurrentPlayer() { + const player = currentPlayer; + + if (player) { + events.off(player, 'playbackstart', onPlaybackStart); + events.off(player, 'statechange', onStateChanged); + events.off(player, 'repeatmodechange', onRepeatModeChange); + events.off(player, 'shufflequeuemodechange', onShuffleQueueModeChange); + events.off(player, 'playlistitemremove', onPlaylistItemRemoved); + events.off(player, 'playlistitemmove', onPlaylistUpdate); + events.off(player, 'playlistitemadd', onPlaylistUpdate); + events.off(player, 'playbackstop', onPlaybackStopped); + events.off(player, 'volumechange', onVolumeChanged); + events.off(player, 'pause', onPlayPauseStateChanged); + events.off(player, 'unpause', onPlayPauseStateChanged); + events.off(player, 'timeupdate', onTimeUpdate); + currentPlayer = null; + } + } + + function bindToPlayer(context, player) { + if (releaseCurrentPlayer(), currentPlayer = player, player) { + const state = playbackManager.getPlayerState(player); + onStateChanged.call(player, { + type: 'init' + }, state); + events.on(player, 'playbackstart', onPlaybackStart); + events.on(player, 'statechange', onStateChanged); + events.on(player, 'repeatmodechange', onRepeatModeChange); + events.on(player, 'shufflequeuemodechange', onShuffleQueueModeChange); + events.on(player, 'playlistitemremove', onPlaylistItemRemoved); + events.on(player, 'playlistitemmove', onPlaylistUpdate); + events.on(player, 'playlistitemadd', onPlaylistUpdate); + events.on(player, 'playbackstop', onPlaybackStopped); + events.on(player, 'volumechange', onVolumeChanged); + events.on(player, 'pause', onPlayPauseStateChanged); + events.on(player, 'unpause', onPlayPauseStateChanged); + events.on(player, 'timeupdate', onTimeUpdate); + const playerInfo = playbackManager.getPlayerInfo(); + const supportedCommands = playerInfo.supportedCommands; + currentPlayerSupportedCommands = supportedCommands; + updateSupportedCommands(context, supportedCommands); + } + } + + function onBtnCommandClick() { + if (currentPlayer) { + if (this.classList.contains('repeatToggleButton')) { + toggleRepeat(); + } else { + playbackManager.sendCommand({ + Name: this.getAttribute('data-command') + }, currentPlayer); } } + } - function onVolumeChanged(e) { - var player = this; - updatePlayerVolumeState(dlg, player.isMuted(), player.getVolume()); + function getSaveablePlaylistItems() { + return getPlaylistItems(currentPlayer).then(function (items) { + return items.filter(function (i) { + return i.Id && i.ServerId; + }); + }); + } + + function savePlaylist() { + import('playlistEditor').then(({ default: playlistEditor }) => { + getSaveablePlaylistItems().then(function (items) { + const serverId = items.length ? items[0].ServerId : ApiClient.serverId(); + new playlistEditor.showEditor({ + items: items.map(function (i) { + return i.Id; + }), + serverId: serverId, + enableAddToPlayQueue: false, + defaultValue: 'new' + }); + }); + }); + } + + function bindEvents(context) { + const btnCommand = context.querySelectorAll('.btnCommand'); + const positionSlider = context.querySelector('.nowPlayingPositionSlider'); + + for (let i = 0, length = btnCommand.length; i < length; i++) { + btnCommand[i].addEventListener('click', onBtnCommandClick); } - function releaseCurrentPlayer() { - var player = currentPlayer; - - if (player) { - events.off(player, 'playbackstart', onPlaybackStart); - events.off(player, 'statechange', onStateChanged); - events.off(player, 'repeatmodechange', onRepeatModeChange); - events.off(player, 'shufflequeuemodechange', onShuffleQueueModeChange); - events.off(player, 'playlistitemremove', onPlaylistItemRemoved); - events.off(player, 'playlistitemmove', onPlaylistUpdate); - events.off(player, 'playlistitemadd', onPlaylistUpdate); - events.off(player, 'playbackstop', onPlaybackStopped); - events.off(player, 'volumechange', onVolumeChanged); - events.off(player, 'pause', onPlayPauseStateChanged); - events.off(player, 'unpause', onPlayPauseStateChanged); - events.off(player, 'timeupdate', onTimeUpdate); - currentPlayer = null; - } - } - - function bindToPlayer(context, player) { - if (releaseCurrentPlayer(), currentPlayer = player, player) { - var state = playbackManager.getPlayerState(player); - onStateChanged.call(player, { - type: 'init' - }, state); - events.on(player, 'playbackstart', onPlaybackStart); - events.on(player, 'statechange', onStateChanged); - events.on(player, 'repeatmodechange', onRepeatModeChange); - events.on(player, 'shufflequeuemodechange', onShuffleQueueModeChange); - events.on(player, 'playlistitemremove', onPlaylistItemRemoved); - events.on(player, 'playlistitemmove', onPlaylistUpdate); - events.on(player, 'playlistitemadd', onPlaylistUpdate); - events.on(player, 'playbackstop', onPlaybackStopped); - events.on(player, 'volumechange', onVolumeChanged); - events.on(player, 'pause', onPlayPauseStateChanged); - events.on(player, 'unpause', onPlayPauseStateChanged); - events.on(player, 'timeupdate', onTimeUpdate); - var playerInfo = playbackManager.getPlayerInfo(); - var supportedCommands = playerInfo.supportedCommands; - currentPlayerSupportedCommands = supportedCommands; - updateSupportedCommands(context, supportedCommands); - } - } - - function onBtnCommandClick() { + context.querySelector('.btnToggleFullscreen').addEventListener('click', function (e) { if (currentPlayer) { - if (this.classList.contains('repeatToggleButton')) { - toggleRepeat(); + playbackManager.sendCommand({ + Name: e.target.getAttribute('data-command') + }, currentPlayer); + } + }); + context.querySelector('.btnAudioTracks').addEventListener('click', function (e) { + if (currentPlayer && lastPlayerState && lastPlayerState.NowPlayingItem) { + showAudioMenu(context, currentPlayer, e.target, lastPlayerState.NowPlayingItem); + } + }); + context.querySelector('.btnSubtitles').addEventListener('click', function (e) { + if (currentPlayer && lastPlayerState && lastPlayerState.NowPlayingItem) { + showSubtitleMenu(context, currentPlayer, e.target, lastPlayerState.NowPlayingItem); + } + }); + context.querySelector('.btnStop').addEventListener('click', function () { + if (currentPlayer) { + playbackManager.stop(currentPlayer); + } + }); + context.querySelector('.btnPlayPause').addEventListener('click', function () { + if (currentPlayer) { + playbackManager.playPause(currentPlayer); + } + }); + context.querySelector('.btnNextTrack').addEventListener('click', function () { + if (currentPlayer) { + playbackManager.nextTrack(currentPlayer); + } + }); + context.querySelector('.btnRewind').addEventListener('click', function () { + if (currentPlayer) { + playbackManager.rewind(currentPlayer); + } + }); + context.querySelector('.btnFastForward').addEventListener('click', function () { + if (currentPlayer) { + playbackManager.fastForward(currentPlayer); + } + }); + for (const shuffleButton of context.querySelectorAll('.btnShuffleQueue')) { + shuffleButton.addEventListener('click', function () { + if (currentPlayer) { + playbackManager.toggleQueueShuffleMode(currentPlayer); + } + }); + } + + context.querySelector('.btnPreviousTrack').addEventListener('click', function (e) { + if (currentPlayer) { + if (lastPlayerState.NowPlayingItem.MediaType === 'Audio' && (currentPlayer._currentTime >= 5 || !playbackManager.previousTrack(currentPlayer))) { + // Cancel this event if doubleclick is fired + if (e.detail > 1 && playbackManager.previousTrack(currentPlayer)) { + return; + } + playbackManager.seekPercent(0, currentPlayer); + // This is done automatically by playbackManager. However, setting this here gives instant visual feedback. + // TODO: Check why seekPercentage doesn't reflect the changes inmmediately, so we can remove this workaround. + positionSlider.value = 0; } else { - playbackManager.sendCommand({ - Name: this.getAttribute('data-command') - }, currentPlayer); - } - } - } - - function getSaveablePlaylistItems() { - return getPlaylistItems(currentPlayer).then(function (items) { - return items.filter(function (i) { - return i.Id && i.ServerId; - }); - }); - } - - function savePlaylist() { - require(['playlistEditor'], function (playlistEditor) { - getSaveablePlaylistItems().then(function (items) { - var serverId = items.length ? items[0].ServerId : ApiClient.serverId(); - new playlistEditor.showEditor({ - items: items.map(function (i) { - return i.Id; - }), - serverId: serverId, - enableAddToPlayQueue: false, - defaultValue: 'new' - }); - }); - }); - } - - function bindEvents(context) { - var btnCommand = context.querySelectorAll('.btnCommand'); - var positionSlider = context.querySelector('.nowPlayingPositionSlider'); - - for (var i = 0, length = btnCommand.length; i < length; i++) { - btnCommand[i].addEventListener('click', onBtnCommandClick); - } - - context.querySelector('.btnToggleFullscreen').addEventListener('click', function (e) { - if (currentPlayer) { - playbackManager.sendCommand({ - Name: e.target.getAttribute('data-command') - }, currentPlayer); - } - }); - context.querySelector('.btnAudioTracks').addEventListener('click', function (e) { - if (currentPlayer && lastPlayerState && lastPlayerState.NowPlayingItem) { - showAudioMenu(context, currentPlayer, e.target, lastPlayerState.NowPlayingItem); - } - }); - context.querySelector('.btnSubtitles').addEventListener('click', function (e) { - if (currentPlayer && lastPlayerState && lastPlayerState.NowPlayingItem) { - showSubtitleMenu(context, currentPlayer, e.target, lastPlayerState.NowPlayingItem); - } - }); - context.querySelector('.btnStop').addEventListener('click', function () { - if (currentPlayer) { - playbackManager.stop(currentPlayer); - } - }); - context.querySelector('.btnPlayPause').addEventListener('click', function () { - if (currentPlayer) { - playbackManager.playPause(currentPlayer); - } - }); - context.querySelector('.btnNextTrack').addEventListener('click', function () { - if (currentPlayer) { - playbackManager.nextTrack(currentPlayer); - } - }); - context.querySelector('.btnRewind').addEventListener('click', function () { - if (currentPlayer) { - playbackManager.rewind(currentPlayer); - } - }); - context.querySelector('.btnFastForward').addEventListener('click', function () { - if (currentPlayer) { - playbackManager.fastForward(currentPlayer); - } - }); - for (const shuffleButton of context.querySelectorAll('.btnShuffleQueue')) { - shuffleButton.addEventListener('click', function () { - if (currentPlayer) { - playbackManager.toggleQueueShuffleMode(currentPlayer); - } - }); - } - - context.querySelector('.btnPreviousTrack').addEventListener('click', function (e) { - if (currentPlayer) { - if (lastPlayerState.NowPlayingItem.MediaType === 'Audio' && (currentPlayer._currentTime >= 5 || !playbackManager.previousTrack(currentPlayer))) { - // Cancel this event if doubleclick is fired - if (e.detail > 1 && playbackManager.previousTrack(currentPlayer)) { - return; - } - playbackManager.seekPercent(0, currentPlayer); - // This is done automatically by playbackManager. However, setting this here gives instant visual feedback. - // TODO: Check why seekPercentage doesn't reflect the changes inmmediately, so we can remove this workaround. - positionSlider.value = 0; - } else { - playbackManager.previousTrack(currentPlayer); - } - } - }); - - context.querySelector('.btnPreviousTrack').addEventListener('dblclick', function () { - if (currentPlayer) { playbackManager.previousTrack(currentPlayer); } - }); - positionSlider.addEventListener('change', function () { - var value = this.value; + } + }); - if (currentPlayer) { - var newPercent = parseFloat(value); - playbackManager.seekPercent(newPercent, currentPlayer); - } - }); + context.querySelector('.btnPreviousTrack').addEventListener('dblclick', function () { + if (currentPlayer) { + playbackManager.previousTrack(currentPlayer); + } + }); + positionSlider.addEventListener('change', function () { + const value = this.value; - positionSlider.getBubbleText = function (value) { - var state = lastPlayerState; + if (currentPlayer) { + const newPercent = parseFloat(value); + playbackManager.seekPercent(newPercent, currentPlayer); + } + }); - if (!state || !state.NowPlayingItem || !currentRuntimeTicks) { - return '--:--'; - } + positionSlider.getBubbleText = function (value) { + const state = lastPlayerState; - var ticks = currentRuntimeTicks; - ticks /= 100; - ticks *= value; - return datetime.getDisplayRunningTime(ticks); - }; + if (!state || !state.NowPlayingItem || !currentRuntimeTicks) { + return '--:--'; + } - context.querySelector('.nowPlayingVolumeSlider').addEventListener('input', (e) => { - playbackManager.setVolume(e.target.value, currentPlayer); - }); + let ticks = currentRuntimeTicks; + ticks /= 100; + ticks *= value; + return datetime.getDisplayRunningTime(ticks); + }; - context.querySelector('.buttonMute').addEventListener('click', function () { - playbackManager.toggleMute(currentPlayer); - }); - var playlistContainer = context.querySelector('.playlist'); - playlistContainer.addEventListener('action-remove', function (e) { - playbackManager.removeFromPlaylist([e.detail.playlistItemId], currentPlayer); - }); - playlistContainer.addEventListener('itemdrop', function (e) { - var newIndex = e.detail.newIndex; - var playlistItemId = e.detail.playlistItemId; - playbackManager.movePlaylistItem(playlistItemId, newIndex, currentPlayer); - }); - context.querySelector('.btnSavePlaylist').addEventListener('click', savePlaylist); - context.querySelector('.btnTogglePlaylist').addEventListener('click', function () { - if (context.querySelector('.playlist').classList.contains('hide')) { - context.querySelector('.playlist').classList.remove('hide'); - context.querySelector('.btnSavePlaylist').classList.remove('hide'); - context.querySelector('.volumecontrol').classList.add('hide'); - if (layoutManager.mobile) { - context.querySelector('.playlistSectionButton').classList.remove('playlistSectionButtonTransparent'); - } - } else { - context.querySelector('.playlist').classList.add('hide'); - context.querySelector('.btnSavePlaylist').classList.add('hide'); - if (showMuteButton || showVolumeSlider) { - context.querySelector('.volumecontrol').classList.remove('hide'); - } - if (layoutManager.mobile) { - context.querySelector('.playlistSectionButton').classList.add('playlistSectionButtonTransparent'); - } - } - }); - } + context.querySelector('.nowPlayingVolumeSlider').addEventListener('input', (e) => { + playbackManager.setVolume(e.target.value, currentPlayer); + }); - function onPlayerChange() { - bindToPlayer(dlg, playbackManager.getCurrentPlayer()); - } - - function onMessageSubmit(e) { - var form = e.target; - playbackManager.sendCommand({ - Name: 'DisplayMessage', - Arguments: { - Header: form.querySelector('#txtMessageTitle').value, - Text: form.querySelector('#txtMessageText', form).value - } - }, currentPlayer); - form.querySelector('input').value = ''; - - require(['toast'], function (toast) { - toast('Message sent.'); - }); - - e.preventDefault(); - e.stopPropagation(); - return false; - } - - function onSendStringSubmit(e) { - var form = e.target; - playbackManager.sendCommand({ - Name: 'SendString', - Arguments: { - String: form.querySelector('#txtTypeText', form).value - } - }, currentPlayer); - form.querySelector('input').value = ''; - - require(['toast'], function (toast) { - toast('Text sent.'); - }); - - e.preventDefault(); - e.stopPropagation(); - return false; - } - - function init(ownerView, context) { - let volumecontrolHtml = '
'; - volumecontrolHtml += ``; - volumecontrolHtml += '
'; - volumecontrolHtml += '
'; - let optionsSection = context.querySelector('.playlistSectionButton'); - if (!layoutManager.mobile) { - context.querySelector('.nowPlayingSecondaryButtons').insertAdjacentHTML('beforeend', volumecontrolHtml); - optionsSection.classList.remove('align-items-center', 'justify-content-center'); - optionsSection.classList.add('align-items-right', 'justify-content-flex-end'); + context.querySelector('.buttonMute').addEventListener('click', function () { + playbackManager.toggleMute(currentPlayer); + }); + const playlistContainer = context.querySelector('.playlist'); + playlistContainer.addEventListener('action-remove', function (e) { + playbackManager.removeFromPlaylist([e.detail.playlistItemId], currentPlayer); + }); + playlistContainer.addEventListener('itemdrop', function (e) { + const newIndex = e.detail.newIndex; + const playlistItemId = e.detail.playlistItemId; + playbackManager.movePlaylistItem(playlistItemId, newIndex, currentPlayer); + }); + context.querySelector('.btnSavePlaylist').addEventListener('click', savePlaylist); + context.querySelector('.btnTogglePlaylist').addEventListener('click', function () { + if (context.querySelector('.playlist').classList.contains('hide')) { context.querySelector('.playlist').classList.remove('hide'); context.querySelector('.btnSavePlaylist').classList.remove('hide'); - context.classList.add('padded-bottom'); + context.querySelector('.volumecontrol').classList.add('hide'); + if (layoutManager.mobile) { + context.querySelector('.playlistSectionButton').classList.remove('playlistSectionButtonTransparent'); + } } else { - optionsSection.querySelector('.btnTogglePlaylist').insertAdjacentHTML('afterend', volumecontrolHtml); - optionsSection.classList.add('playlistSectionButtonTransparent'); - context.querySelector('.btnTogglePlaylist').classList.remove('hide'); - context.querySelector('.playlistSectionButton').classList.remove('justify-content-center'); - context.querySelector('.playlistSectionButton').classList.add('justify-content-space-between'); + context.querySelector('.playlist').classList.add('hide'); + context.querySelector('.btnSavePlaylist').classList.add('hide'); + if (showMuteButton || showVolumeSlider) { + context.querySelector('.volumecontrol').classList.remove('hide'); + } + if (layoutManager.mobile) { + context.querySelector('.playlistSectionButton').classList.add('playlistSectionButtonTransparent'); + } } + }); + } - bindEvents(context); - context.querySelector('.sendMessageForm').addEventListener('submit', onMessageSubmit); - context.querySelector('.typeTextForm').addEventListener('submit', onSendStringSubmit); - events.on(playbackManager, 'playerchange', onPlayerChange); + function onPlayerChange() { + bindToPlayer(dlg, playbackManager.getCurrentPlayer()); + } - if (layoutManager.tv) { - var positionSlider = context.querySelector('.nowPlayingPositionSlider'); - positionSlider.classList.add('focusable'); - positionSlider.enableKeyboardDragging(); + function onMessageSubmit(e) { + const form = e.target; + playbackManager.sendCommand({ + Name: 'DisplayMessage', + Arguments: { + Header: form.querySelector('#txtMessageTitle').value, + Text: form.querySelector('#txtMessageText', form).value } + }, currentPlayer); + form.querySelector('input').value = ''; + + import('toast').then(({ default: toast }) => { + toast('Message sent.'); + }); + + e.preventDefault(); + e.stopPropagation(); + return false; + } + + function onSendStringSubmit(e) { + const form = e.target; + playbackManager.sendCommand({ + Name: 'SendString', + Arguments: { + String: form.querySelector('#txtTypeText', form).value + } + }, currentPlayer); + form.querySelector('input').value = ''; + + import('toast').then(({ default: toast }) => { + toast('Text sent.'); + }); + + e.preventDefault(); + e.stopPropagation(); + return false; + } + + function init(ownerView, context) { + let volumecontrolHtml = '
'; + volumecontrolHtml += ``; + volumecontrolHtml += '
'; + volumecontrolHtml += '
'; + const optionsSection = context.querySelector('.playlistSectionButton'); + if (!layoutManager.mobile) { + context.querySelector('.nowPlayingSecondaryButtons').insertAdjacentHTML('beforeend', volumecontrolHtml); + optionsSection.classList.remove('align-items-center', 'justify-content-center'); + optionsSection.classList.add('align-items-right', 'justify-content-flex-end'); + context.querySelector('.playlist').classList.remove('hide'); + context.querySelector('.btnSavePlaylist').classList.remove('hide'); + context.classList.add('padded-bottom'); + } else { + optionsSection.querySelector('.btnTogglePlaylist').insertAdjacentHTML('afterend', volumecontrolHtml); + optionsSection.classList.add('playlistSectionButtonTransparent'); + context.querySelector('.btnTogglePlaylist').classList.remove('hide'); + context.querySelector('.playlistSectionButton').classList.remove('justify-content-center'); + context.querySelector('.playlistSectionButton').classList.add('justify-content-space-between'); } - function onDialogClosed(e) { - releaseCurrentPlayer(); - events.off(playbackManager, 'playerchange', onPlayerChange); - lastPlayerState = null; + bindEvents(context); + context.querySelector('.sendMessageForm').addEventListener('submit', onMessageSubmit); + context.querySelector('.typeTextForm').addEventListener('submit', onSendStringSubmit); + events.on(playbackManager, 'playerchange', onPlayerChange); + + if (layoutManager.tv) { + const positionSlider = context.querySelector('.nowPlayingPositionSlider'); + positionSlider.classList.add('focusable'); + positionSlider.enableKeyboardDragging(); } + } - function onShow(context, tab) { - bindToPlayer(context, playbackManager.getCurrentPlayer()); - } + function onDialogClosed(e) { + releaseCurrentPlayer(); + events.off(playbackManager, 'playerchange', onPlayerChange); + lastPlayerState = null; + } - var dlg; - var currentPlayer; - var lastPlayerState; - var currentPlayerSupportedCommands = []; - var lastUpdateTime = 0; - var currentRuntimeTicks = 0; - var self = this; + function onShow(context, tab) { + bindToPlayer(context, playbackManager.getCurrentPlayer()); + } - self.init = function (ownerView, context) { - dlg = context; - init(ownerView, dlg); - }; + let dlg; + let currentPlayer; + let lastPlayerState; + let currentPlayerSupportedCommands = []; + let lastUpdateTime = 0; + let currentRuntimeTicks = 0; + const self = this; - self.onShow = function () { - onShow(dlg, window.location.hash); - }; - - self.destroy = function () { - onDialogClosed(); - }; + self.init = function (ownerView, context) { + dlg = context; + init(ownerView, dlg); }; -}); + + self.onShow = function () { + onShow(dlg, window.location.hash); + }; + + self.destroy = function () { + onDialogClosed(); + }; +} From 9640f13830409b9b12e228f5556b88ca6aadc727 Mon Sep 17 00:00:00 2001 From: MrTimscampi Date: Thu, 16 Jul 2020 22:17:36 +0200 Subject: [PATCH 048/301] Prefer const over let when possible --- .eslintrc.js | 1 + 1 file changed, 1 insertion(+) diff --git a/.eslintrc.js b/.eslintrc.js index ff12e198c3..426bb73083 100644 --- a/.eslintrc.js +++ b/.eslintrc.js @@ -44,6 +44,7 @@ module.exports = { 'no-unused-vars': ['error', { 'vars': 'all', 'args': 'none', 'ignoreRestSiblings': true }], 'one-var': ['error', 'never'], 'padded-blocks': ['error', 'never'], + 'prefer-const': ['error', {'destructuring': 'all'}], 'quotes': ['error', 'single', { 'avoidEscape': true, 'allowTemplateLiterals': false }], 'semi': ['error'], 'space-before-blocks': ['error'], From f16df9788a6b773b2a309345f11d18c589d4aee3 Mon Sep 17 00:00:00 2001 From: MrTimscampi Date: Thu, 16 Jul 2020 22:19:09 +0200 Subject: [PATCH 049/301] Migrate bundle, qualityOptions, appHost and appLoader --- package.json | 2 + src/bundle.js | 60 +- src/components/actionSheet/actionSheet.js | 14 +- src/components/appRouter.js | 4 +- src/components/apphost.js | 776 +++++++++--------- src/components/cardbuilder/cardBuilder.js | 28 +- .../displaySettings/displaySettings.js | 6 +- .../imageDownloader/imageDownloader.js | 2 +- src/components/images/imageLoader.js | 14 +- src/components/indicators/indicators.js | 2 +- src/components/itemContextMenu.js | 2 +- src/components/multiSelect/multiSelect.js | 2 +- src/components/nowPlayingBar/nowPlayingBar.js | 2 +- src/components/playback/mediasession.js | 8 +- src/components/playback/playbackmanager.js | 2 +- .../playback/playerSelectionMenu.js | 2 +- .../playbackSettings/playbackSettings.js | 6 +- src/components/qualityOptions.js | 305 +++---- src/components/remotecontrol/remotecontrol.js | 2 +- src/components/scrollManager.js | 2 +- src/components/skinManager.js | 184 +++++ src/components/slideshow/slideshow.js | 10 +- .../dashboard/plugins/repositories/index.js | 2 +- src/controllers/music/musicrecommended.js | 1 - src/controllers/playback/video/index.js | 2 +- src/controllers/session/login/index.js | 2 +- src/controllers/user/menu.js | 58 ++ src/controllers/user/profile.js | 106 +++ src/plugins/bookPlayer/plugin.js | 36 +- src/plugins/bookPlayer/tableOfContents.js | 18 +- src/plugins/experimentalWarnings/plugin.js | 2 +- src/plugins/htmlAudioPlayer/plugin.js | 4 +- src/plugins/htmlVideoPlayer/plugin.js | 4 +- src/scripts/apploader.js | 92 +-- src/scripts/deleteHelper.js | 4 +- src/scripts/gamepadtokey.js | 2 +- src/scripts/inputManager.js | 4 +- src/scripts/libraryMenu.js | 4 +- src/scripts/site.js | 22 +- 39 files changed, 1075 insertions(+), 723 deletions(-) create mode 100644 src/components/skinManager.js create mode 100644 src/controllers/user/menu.js create mode 100644 src/controllers/user/profile.js diff --git a/package.json b/package.json index 6e2480ca05..ce29b55eae 100644 --- a/package.json +++ b/package.json @@ -95,6 +95,7 @@ "src/components/alert.js", "src/components/alphaPicker/alphaPicker.js", "src/components/appFooter/appFooter.js", + "src/components/apphost.js", "src/components/autoFocuser.js", "src/components/backdrop/backdrop.js", "src/components/cardbuilder/cardBuilder.js", @@ -156,6 +157,7 @@ "src/components/recordingcreator/seriesrecordingeditor.js", "src/components/recordingcreator/recordinghelper.js", "src/components/refreshdialog/refreshdialog.js", + "src/components/qualityOptions.js", "src/components/sanatizefilename.js", "src/components/scrollManager.js", "src/plugins/htmlVideoPlayer/plugin.js", diff --git a/src/bundle.js b/src/bundle.js index ae2a59f0d5..86ebb1ccdf 100644 --- a/src/bundle.js +++ b/src/bundle.js @@ -2,159 +2,165 @@ * require.js module definitions bundled by webpack */ // Use define from require.js not webpack's define -var _define = window.define; +const _define = window.define; // fetch -var fetch = require('whatwg-fetch'); +const fetch = require('whatwg-fetch'); _define('fetch', function() { return fetch; }); // Blurhash -var blurhash = require('blurhash'); +const blurhash = require('blurhash'); _define('blurhash', function() { return blurhash; }); // query-string -var query = require('query-string'); +const query = require('query-string'); _define('queryString', function() { return query; }); // flvjs -var flvjs = require('flv.js/dist/flv').default; +const flvjs = require('flv.js/dist/flv').default; _define('flvjs', function() { return flvjs; }); // jstree -var jstree = require('jstree'); +const jstree = require('jstree'); require('jstree/dist/themes/default/style.css'); _define('jstree', function() { return jstree; }); // jquery -var jquery = require('jquery'); +const jquery = require('jquery'); _define('jQuery', function() { return jquery; }); // hlsjs -var hlsjs = require('hls.js'); +const hlsjs = require('hls.js'); _define('hlsjs', function() { return hlsjs; }); // howler -var howler = require('howler'); +const howler = require('howler'); _define('howler', function() { return howler; }); // resize-observer-polyfill -var resize = require('resize-observer-polyfill').default; +const resize = require('resize-observer-polyfill').default; _define('resize-observer-polyfill', function() { return resize; }); // swiper -var swiper = require('swiper/js/swiper'); +const swiper = require('swiper/js/swiper'); require('swiper/css/swiper.min.css'); _define('swiper', function() { return swiper; }); // sortable -var sortable = require('sortablejs').default; +const sortable = require('sortablejs').default; _define('sortable', function() { return sortable; }); // webcomponents -var webcomponents = require('webcomponents.js/webcomponents-lite'); +const webcomponents = require('webcomponents.js/webcomponents-lite'); _define('webcomponents', function() { return webcomponents; }); +// shaka +const shaka = require('shaka-player'); +_define('shaka', function() { + return shaka; +}); + // libass-wasm -var libassWasm = require('libass-wasm'); +const libassWasm = require('libass-wasm'); _define('JavascriptSubtitlesOctopus', function() { return libassWasm; }); // material-icons -var materialIcons = require('material-design-icons-iconfont/dist/material-design-icons.css'); +const materialIcons = require('material-design-icons-iconfont/dist/material-design-icons.css'); _define('material-icons', function() { return materialIcons; }); // noto font -var noto = require('jellyfin-noto'); +const noto = require('jellyfin-noto'); _define('jellyfin-noto', function () { return noto; }); -var epubjs = require('epubjs'); +const epubjs = require('epubjs'); _define('epubjs', function () { return epubjs; }); // page.js -var page = require('page'); +const page = require('page'); _define('page', function() { return page; }); // core-js -var polyfill = require('@babel/polyfill/dist/polyfill'); +const polyfill = require('@babel/polyfill/dist/polyfill'); _define('polyfill', function () { return polyfill; }); // domtokenlist-shim -var classlist = require('classlist.js'); +const classlist = require('classlist.js'); _define('classlist-polyfill', function () { return classlist; }); // Date-FNS -var dateFns = require('date-fns'); +const dateFns = require('date-fns'); _define('date-fns', function () { return dateFns; }); -var dateFnsLocale = require('date-fns/locale'); +const dateFnsLocale = require('date-fns/locale'); _define('date-fns/locale', function () { return dateFnsLocale; }); -var fast_text_encoding = require('fast-text-encoding'); +const fast_text_encoding = require('fast-text-encoding'); _define('fast-text-encoding', function () { return fast_text_encoding; }); // intersection-observer -var intersection_observer = require('intersection-observer'); +const intersection_observer = require('intersection-observer'); _define('intersection-observer', function () { return intersection_observer; }); // screenfull -var screenfull = require('screenfull'); +const screenfull = require('screenfull'); _define('screenfull', function () { return screenfull; }); // headroom.js -var headroom = require('headroom.js/dist/headroom'); +const headroom = require('headroom.js/dist/headroom'); _define('headroom', function () { return headroom; }); // apiclient -var apiclient = require('jellyfin-apiclient'); +const apiclient = require('jellyfin-apiclient'); _define('apiclient', function () { return apiclient.ApiClient; diff --git a/src/components/actionSheet/actionSheet.js b/src/components/actionSheet/actionSheet.js index 937cd2afe5..be84cf0a06 100644 --- a/src/components/actionSheet/actionSheet.js +++ b/src/components/actionSheet/actionSheet.js @@ -9,14 +9,14 @@ import 'scrollStyles'; import 'listViewStyle'; function getOffsets(elems) { - let results = []; + const results = []; if (!document) { return results; } for (const elem of elems) { - let box = elem.getBoundingClientRect(); + const box = elem.getBoundingClientRect(); results.push({ top: box.top, @@ -34,7 +34,7 @@ function getPosition(options, dlg) { const windowHeight = windowSize.innerHeight; const windowWidth = windowSize.innerWidth; - let pos = getOffsets([options.positionTo])[0]; + const pos = getOffsets([options.positionTo])[0]; if (options.positionY !== 'top') { pos.top += (pos.height || 0) / 2; @@ -82,7 +82,7 @@ export function show(options) { // positionTo // showCancel // title - let dialogOptions = { + const dialogOptions = { removeOnClose: true, enableHistory: options.enableHistory, scrollY: false @@ -103,7 +103,7 @@ export function show(options) { dialogOptions.autoFocus = false; } - let dlg = dialogHelper.createDialog(dialogOptions); + const dlg = dialogHelper.createDialog(dialogOptions); if (isFullscreen) { dlg.classList.add('actionsheet-fullscreen'); @@ -129,7 +129,7 @@ export function show(options) { } let renderIcon = false; - let icons = []; + const icons = []; let itemIcon; for (const item of options.items) { itemIcon = item.icon || (item.selected ? 'check' : null); @@ -241,7 +241,7 @@ export function show(options) { centerFocus(dlg.querySelector('.actionSheetScroller'), false, true); } - let btnCloseActionSheet = dlg.querySelector('.btnCloseActionSheet'); + const btnCloseActionSheet = dlg.querySelector('.btnCloseActionSheet'); if (btnCloseActionSheet) { btnCloseActionSheet.addEventListener('click', function () { dialogHelper.close(dlg); diff --git a/src/components/appRouter.js b/src/components/appRouter.js index da3b08317c..efabdab1cb 100644 --- a/src/components/appRouter.js +++ b/src/components/appRouter.js @@ -329,8 +329,8 @@ define(['loading', 'globalize', 'events', 'viewManager', 'skinManager', 'backdro } if (shouldExitApp) { - if (appHost.supports('exit')) { - appHost.exit(); + if (appHost.default.supports('exit')) { + appHost.default.exit(); return; } return; diff --git a/src/components/apphost.js b/src/components/apphost.js index 3ed590b546..90ae418de6 100644 --- a/src/components/apphost.js +++ b/src/components/apphost.js @@ -1,447 +1,445 @@ -define(['appSettings', 'browser', 'events', 'htmlMediaHelper', 'webSettings', 'globalize'], function (appSettings, browser, events, htmlMediaHelper, webSettings, globalize) { - 'use strict'; +import appSettings from 'appSettings'; +import browser from 'browser'; +import events from 'events'; +import htmlMediaHelper from 'htmlMediaHelper'; +import * as webSettings from 'webSettings'; +import globalize from 'globalize'; - browser = browser.default || browser; +function getBaseProfileOptions(item) { + const disableHlsVideoAudioCodecs = []; - function getBaseProfileOptions(item) { - var disableHlsVideoAudioCodecs = []; + if (item && htmlMediaHelper.enableHlsJsPlayer(item.RunTimeTicks, item.MediaType)) { + if (browser.edge) { + disableHlsVideoAudioCodecs.push('mp3'); + } - if (item && htmlMediaHelper.enableHlsJsPlayer(item.RunTimeTicks, item.MediaType)) { - if (browser.edge) { - disableHlsVideoAudioCodecs.push('mp3'); + disableHlsVideoAudioCodecs.push('ac3'); + disableHlsVideoAudioCodecs.push('eac3'); + disableHlsVideoAudioCodecs.push('opus'); + } + + return { + enableMkvProgressive: false, + disableHlsVideoAudioCodecs: disableHlsVideoAudioCodecs + }; +} + +function getDeviceProfile(item, options = {}) { + return new Promise(function (resolve) { + import(['browserdeviceprofile']).then(({default: profileBuilder}) => { + let profile; + + if (window.NativeShell) { + profile = window.NativeShell.AppHost.getDeviceProfile(profileBuilder); + } else { + const builderOpts = getBaseProfileOptions(item); + builderOpts.enableSsaRender = (item && !options.isRetry && appSettings.get('subtitleburnin') !== 'allcomplexformats'); + profile = profileBuilder(builderOpts); } - disableHlsVideoAudioCodecs.push('ac3'); - disableHlsVideoAudioCodecs.push('eac3'); - disableHlsVideoAudioCodecs.push('opus'); - } - - return { - enableMkvProgressive: false, - disableHlsVideoAudioCodecs: disableHlsVideoAudioCodecs - }; - } - - function getDeviceProfileForWindowsUwp(item) { - return new Promise(function (resolve, reject) { - require(['browserdeviceprofile', 'environments/windows-uwp/mediacaps'], function (profileBuilder, uwpMediaCaps) { - var profileOptions = getBaseProfileOptions(item); - profileOptions.supportsDts = uwpMediaCaps.supportsDTS(); - profileOptions.supportsTrueHd = uwpMediaCaps.supportsDolby(); - profileOptions.audioChannels = uwpMediaCaps.getAudioChannels(); - resolve(profileBuilder(profileOptions)); - }); + resolve(profile); }); + }); +} + +function escapeRegExp(str) { + return str.replace(/([.*+?^=!:${}()|[\]/\\])/g, '\\$1'); +} + +function replaceAll(originalString, strReplace, strWith) { + const strReplace2 = escapeRegExp(strReplace); + const reg = new RegExp(strReplace2, 'ig'); + return originalString.replace(reg, strWith); +} + +function generateDeviceId() { + const keys = []; + + if (keys.push(navigator.userAgent), keys.push(new Date().getTime()), self.btoa) { + const result = replaceAll(btoa(keys.join('|')), '=', '1'); + return Promise.resolve(result); } - function getDeviceProfile(item, options) { - options = options || {}; + return Promise.resolve(new Date().getTime()); +} - if (self.Windows) { - return getDeviceProfileForWindowsUwp(item); - } +function getDeviceId() { + const key = '_deviceId2'; + const deviceId = appSettings.get(key); - return new Promise(function (resolve) { - require(['browserdeviceprofile'], function (profileBuilder) { - var profile; - - if (window.NativeShell) { - profile = window.NativeShell.AppHost.getDeviceProfile(profileBuilder); - } else { - var builderOpts = getBaseProfileOptions(item); - builderOpts.enableSsaRender = (item && !options.isRetry && appSettings.get('subtitleburnin') !== 'allcomplexformats'); - profile = profileBuilder(builderOpts); - } - - resolve(profile); - }); - }); + if (deviceId) { + return Promise.resolve(deviceId); } - function escapeRegExp(str) { - return str.replace(/([.*+?^=!:${}()|\[\]\/\\])/g, '\\$1'); + return generateDeviceId().then(function (deviceId) { + appSettings.set(key, deviceId); + return deviceId; + }); +} + +function getDeviceName() { + var deviceName; + if (browser.tizen) { + deviceName = 'Samsung Smart TV'; + } else if (browser.web0s) { + deviceName = 'LG Smart TV'; + } else if (browser.operaTv) { + deviceName = 'Opera TV'; + } else if (browser.xboxOne) { + deviceName = 'Xbox One'; + } else if (browser.ps4) { + deviceName = 'Sony PS4'; + } else if (browser.chrome) { + deviceName = 'Chrome'; + } else if (browser.edgeChromium) { + deviceName = 'Edge Chromium'; + } else if (browser.edge) { + deviceName = 'Edge'; + } else if (browser.firefox) { + deviceName = 'Firefox'; + } else if (browser.opera) { + deviceName = 'Opera'; + } else if (browser.safari) { + deviceName = 'Safari'; + } else { + deviceName = 'Web Browser'; } - function replaceAll(originalString, strReplace, strWith) { - var strReplace2 = escapeRegExp(strReplace); - var reg = new RegExp(strReplace2, 'ig'); - return originalString.replace(reg, strWith); + if (browser.ipad) { + deviceName += ' iPad'; + } else if (browser.iphone) { + deviceName += ' iPhone'; + } else if (browser.android) { + deviceName += ' Android'; } - function generateDeviceId() { - var keys = []; - - if (keys.push(navigator.userAgent), keys.push(new Date().getTime()), self.btoa) { - var result = replaceAll(btoa(keys.join('|')), '=', '1'); - return Promise.resolve(result); - } - - return Promise.resolve(new Date().getTime()); + if (browser.ipad) { + deviceName += ' iPad'; + } else if (browser.iphone) { + deviceName += ' iPhone'; + } else if (browser.android) { + deviceName += ' Android'; } - function getDeviceId() { - var key = '_deviceId2'; - var deviceId = appSettings.get(key); + return deviceName; +} - if (deviceId) { - return Promise.resolve(deviceId); - } - - return generateDeviceId().then(function (deviceId) { - appSettings.set(key, deviceId); - return deviceId; - }); +function supportsVoiceInput() { + if (!browser.tv) { + return window.SpeechRecognition || window.webkitSpeechRecognition || window.mozSpeechRecognition || window.oSpeechRecognition || window.msSpeechRecognition; } - function getDeviceName() { - var deviceName; - if (browser.tizen) { - deviceName = 'Samsung Smart TV'; - } else if (browser.web0s) { - deviceName = 'LG Smart TV'; - } else if (browser.operaTv) { - deviceName = 'Opera TV'; - } else if (browser.xboxOne) { - deviceName = 'Xbox One'; - } else if (browser.ps4) { - deviceName = 'Sony PS4'; - } else if (browser.chrome) { - deviceName = 'Chrome'; - } else if (browser.edgeChromium) { - deviceName = 'Edge Chromium'; - } else if (browser.edge) { - deviceName = 'Edge'; - } else if (browser.firefox) { - deviceName = 'Firefox'; - } else if (browser.opera) { - deviceName = 'Opera'; - } else if (browser.safari) { - deviceName = 'Safari'; - } else { - deviceName = 'Web Browser'; - } - - if (browser.ipad) { - deviceName += ' iPad'; - } else if (browser.iphone) { - deviceName += ' iPhone'; - } else if (browser.android) { - deviceName += ' Android'; - } - - return deviceName; - } - - function supportsVoiceInput() { - if (!browser.tv) { - return window.SpeechRecognition || window.webkitSpeechRecognition || window.mozSpeechRecognition || window.oSpeechRecognition || window.msSpeechRecognition; - } + return false; +} +function supportsFullscreen() { + if (browser.tv) { return false; } - function supportsFullscreen() { - if (browser.tv) { - return false; - } + const element = document.documentElement; + return (element.requestFullscreen || element.mozRequestFullScreen || element.webkitRequestFullscreen || element.msRequestFullscreen) || document.createElement('video').webkitEnterFullscreen; +} - var element = document.documentElement; - return (element.requestFullscreen || element.mozRequestFullScreen || element.webkitRequestFullscreen || element.msRequestFullscreen) || document.createElement('video').webkitEnterFullscreen; - } +function getSyncProfile() { + return new Promise(function (resolve) { + require(['browserdeviceprofile', 'appSettings'], function (profileBuilder, appSettings) { + let profile; - function getSyncProfile() { - return new Promise(function (resolve) { - require(['browserdeviceprofile', 'appSettings'], function (profileBuilder, appSettings) { - var profile; + if (window.NativeShell) { + profile = window.NativeShell.AppHost.getSyncProfile(profileBuilder, appSettings); + } else { + profile = profileBuilder(); + profile.MaxStaticMusicBitrate = appSettings.maxStaticMusicBitrate(); + } - if (window.NativeShell) { - profile = window.NativeShell.AppHost.getSyncProfile(profileBuilder, appSettings); - } else { - profile = profileBuilder(); - profile.MaxStaticMusicBitrate = appSettings.maxStaticMusicBitrate(); - } - - resolve(profile); - }); + resolve(profile); }); - } + }); +} - function getDefaultLayout() { - return 'desktop'; - } - - function supportsHtmlMediaAutoplay() { - if (browser.edgeUwp || browser.tizen || browser.web0s || browser.orsay || browser.operaTv || browser.ps4 || browser.xboxOne) { - return true; - } - - if (browser.mobile) { - return false; - } +function getDefaultLayout() { + return 'desktop'; +} +function supportsHtmlMediaAutoplay() { + if (browser.edgeUwp || browser.tizen || browser.web0s || browser.orsay || browser.operaTv || browser.ps4 || browser.xboxOne) { return true; } - function supportsCue() { - try { - var video = document.createElement('video'); - var style = document.createElement('style'); - - style.textContent = 'video::cue {background: inherit}'; - document.body.appendChild(style); - document.body.appendChild(video); - - var cue = window.getComputedStyle(video, '::cue').background; - document.body.removeChild(style); - document.body.removeChild(video); - - return !!cue.length; - } catch (err) { - console.error('error detecting cue support: ' + err); - return false; - } + if (browser.mobile) { + return false; } - function onAppVisible() { - if (isHidden) { - isHidden = false; - console.debug('triggering app resume event'); - events.trigger(appHost, 'resume'); - } + return true; +} + +function supportsCue() { + try { + const video = document.createElement('video'); + const style = document.createElement('style'); + + style.textContent = 'video::cue {background: inherit}'; + document.body.appendChild(style); + document.body.appendChild(video); + + const cue = window.getComputedStyle(video, '::cue').background; + document.body.removeChild(style); + document.body.removeChild(video); + + return !!cue.length; + } catch (err) { + console.error('error detecting cue support: ' + err); + return false; + } +} + +function onAppVisible() { + if (isHidden) { + isHidden = false; + console.debug('triggering app resume event'); + events.trigger(appHost, 'resume'); + } +} + +function onAppHidden() { + if (!isHidden) { + isHidden = true; + console.debug('app is hidden'); + } +} + +const supportedFeatures = function () { + const features = []; + + if (navigator.share) { + features.push('sharing'); } - function onAppHidden() { - if (!isHidden) { - isHidden = true; - console.debug('app is hidden'); - } + if (!browser.edgeUwp && !browser.tv && !browser.xboxOne && !browser.ps4) { + features.push('filedownload'); } - var supportedFeatures = function () { - var features = []; + if (browser.operaTv || browser.tizen || browser.orsay || browser.web0s) { + features.push('exit'); + } else { + features.push('exitmenu'); + features.push('plugins'); + } - if (navigator.share) { - features.push('sharing'); - } + if (!browser.operaTv && !browser.tizen && !browser.orsay && !browser.web0s && !browser.ps4) { + features.push('externallinks'); + features.push('externalpremium'); + } - if (!browser.edgeUwp && !browser.tv && !browser.xboxOne && !browser.ps4) { - features.push('filedownload'); - } + if (!browser.operaTv) { + features.push('externallinkdisplay'); + } - if (browser.operaTv || browser.tizen || browser.orsay || browser.web0s) { - features.push('exit'); + if (supportsVoiceInput()) { + features.push('voiceinput'); + } + + if (supportsHtmlMediaAutoplay()) { + features.push('htmlaudioautoplay'); + features.push('htmlvideoautoplay'); + } + + if (browser.edgeUwp) { + features.push('sync'); + } + + if (supportsFullscreen()) { + features.push('fullscreenchange'); + } + + if (browser.tv || browser.xboxOne || browser.ps4 || browser.mobile) { + features.push('physicalvolumecontrol'); + } + + if (!browser.tv && !browser.xboxOne && !browser.ps4) { + features.push('remotecontrol'); + } + + if (!browser.operaTv && !browser.tizen && !browser.orsay && !browser.web0s && !browser.edgeUwp) { + features.push('remotevideo'); + } + + features.push('displaylanguage'); + features.push('otherapppromotions'); + features.push('displaymode'); + features.push('targetblank'); + features.push('screensaver'); + + webSettings.enableMultiServer().then(enabled => { + if (enabled) features.push('multiserver'); + }); + + if (!browser.orsay && (browser.firefox || browser.ps4 || browser.edge || supportsCue())) { + features.push('subtitleappearancesettings'); + } + + if (!browser.orsay) { + features.push('subtitleburnsettings'); + } + + if (!browser.tv && !browser.ps4 && !browser.xboxOne) { + features.push('fileinput'); + } + + if (browser.chrome) { + features.push('chromecast'); + } + + return features; +}(); + +/** + * Do exit according to platform + */ +function doExit() { + try { + if (window.NativeShell) { + window.NativeShell.AppHost.exit(); + } else if (browser.tizen) { + tizen.application.getCurrentApplication().exit(); + } else if (browser.web0s) { + webOS.platformBack(); } else { - features.push('exitmenu'); - features.push('plugins'); + window.close(); } + } catch (err) { + console.error('error closing application: ' + err); + } +} - if (!browser.operaTv && !browser.tizen && !browser.orsay && !browser.web0s && !browser.ps4) { - features.push('externallinks'); - features.push('externalpremium'); - } +let exitPromise; - if (!browser.operaTv) { - features.push('externallinkdisplay'); - } - - if (supportsVoiceInput()) { - features.push('voiceinput'); - } - - if (supportsHtmlMediaAutoplay()) { - features.push('htmlaudioautoplay'); - features.push('htmlvideoautoplay'); - } - - if (browser.edgeUwp) { - features.push('sync'); - } - - if (supportsFullscreen()) { - features.push('fullscreenchange'); - } - - if (browser.tv || browser.xboxOne || browser.ps4 || browser.mobile) { - features.push('physicalvolumecontrol'); - } - - if (!browser.tv && !browser.xboxOne && !browser.ps4) { - features.push('remotecontrol'); - } - - if (!browser.operaTv && !browser.tizen && !browser.orsay && !browser.web0s && !browser.edgeUwp) { - features.push('remotevideo'); - } - - features.push('displaylanguage'); - features.push('otherapppromotions'); - features.push('displaymode'); - features.push('targetblank'); - features.push('screensaver'); - - webSettings.getMultiServer().then(enabled => { - if (enabled) features.push('multiserver'); - }); - - if (!browser.orsay && (browser.firefox || browser.ps4 || browser.edge || supportsCue())) { - features.push('subtitleappearancesettings'); - } - - if (!browser.orsay) { - features.push('subtitleburnsettings'); - } - - if (!browser.tv && !browser.ps4 && !browser.xboxOne) { - features.push('fileinput'); - } - - if (browser.chrome || browser.edgeChromium) { - features.push('chromecast'); - } - - return features; - }(); - - /** - * Do exit according to platform - */ - function doExit() { - try { - if (window.NativeShell) { - window.NativeShell.AppHost.exit(); - } else if (browser.tizen) { - tizen.application.getCurrentApplication().exit(); - } else if (browser.web0s) { - webOS.platformBack(); - } else { - window.close(); - } - } catch (err) { - console.error('error closing application: ' + err); - } +/** + * Ask user for exit + */ +function askForExit() { + if (exitPromise) { + return; } - var exitPromise; - - /** - * Ask user for exit - */ - function askForExit() { - if (exitPromise) { - return; - } - - require(['actionsheet'], function (actionsheet) { - exitPromise = actionsheet.show({ - title: globalize.translate('MessageConfirmAppExit'), - items: [ - {id: 'yes', name: globalize.translate('Yes')}, - {id: 'no', name: globalize.translate('No')} - ] - }).then(function (value) { - if (value === 'yes') { - doExit(); - } - }).finally(function () { - exitPromise = null; - }); - }); - } - - var deviceId; - var deviceName; - var appName = 'Jellyfin Web'; - var appVersion = '10.7.0'; - - var appHost = { - getWindowState: function () { - return document.windowState || 'Normal'; - }, - setWindowState: function (state) { - alert('setWindowState is not supported and should not be called'); - }, - exit: function () { - if (!!window.appMode && browser.tizen) { - askForExit(); - } else { + require(['actionsheet'], function (actionsheet) { + exitPromise = actionsheet.show({ + title: globalize.translate('MessageConfirmAppExit'), + items: [ + {id: 'yes', name: globalize.translate('Yes')}, + {id: 'no', name: globalize.translate('No')} + ] + }).then(function (value) { + if (value === 'yes') { doExit(); } - }, - supports: function (command) { - if (window.NativeShell) { - return window.NativeShell.AppHost.supports(command); - } + }).finally(function () { + exitPromise = null; + }); + }); +} - return supportedFeatures.indexOf(command.toLowerCase()) !== -1; - }, - preferVisualCards: browser.android || browser.chrome, - getSyncProfile: getSyncProfile, - getDefaultLayout: function () { - if (window.NativeShell) { - return window.NativeShell.AppHost.getDefaultLayout(); - } +let deviceId; +let deviceName; +const appName = 'Jellyfin Web'; +const appVersion = '10.6.0'; - return getDefaultLayout(); - }, - getDeviceProfile: getDeviceProfile, - init: function () { - if (window.NativeShell) { - return window.NativeShell.AppHost.init(); - } - - deviceName = getDeviceName(); - getDeviceId().then(function (id) { - deviceId = id; - }); - }, - deviceName: function () { - return window.NativeShell ? window.NativeShell.AppHost.deviceName() : deviceName; - }, - deviceId: function () { - return window.NativeShell ? window.NativeShell.AppHost.deviceId() : deviceId; - }, - appName: function () { - return window.NativeShell ? window.NativeShell.AppHost.appName() : appName; - }, - appVersion: function () { - return window.NativeShell ? window.NativeShell.AppHost.appVersion() : appVersion; - }, - getPushTokenInfo: function () { - return {}; - }, - setUserScalable: function (scalable) { - if (!browser.tv) { - var att = scalable ? 'width=device-width, initial-scale=1, minimum-scale=1, user-scalable=yes' : 'width=device-width, initial-scale=1, minimum-scale=1, maximum-scale=1, user-scalable=no'; - document.querySelector('meta[name=viewport]').setAttribute('content', att); - } - } - }; - - var isHidden = false; - var hidden; - var visibilityChange; - - if (typeof document.hidden !== 'undefined') { /* eslint-disable-line compat/compat */ - hidden = 'hidden'; - visibilityChange = 'visibilitychange'; - } else if (typeof document.webkitHidden !== 'undefined') { - hidden = 'webkitHidden'; - visibilityChange = 'webkitvisibilitychange'; - } - - document.addEventListener(visibilityChange, function () { - /* eslint-disable-next-line compat/compat */ - if (document[hidden]) { - onAppHidden(); +const appHost = { + getWindowState: function () { + return document.windowState || 'Normal'; + }, + setWindowState: function () { + alert('setWindowState is not supported and should not be called'); + }, + exit: function () { + if (!!window.appMode && browser.tizen) { + askForExit(); } else { - onAppVisible(); + doExit(); + } + }, + supports: function (command) { + if (window.NativeShell) { + return window.NativeShell.AppHost.supports(command); } - }, false); - if (self.addEventListener) { - self.addEventListener('focus', onAppVisible); - self.addEventListener('blur', onAppHidden); + return supportedFeatures.indexOf(command.toLowerCase()) !== -1; + }, + preferVisualCards: browser.android || browser.chrome, + getSyncProfile: getSyncProfile, + getDefaultLayout: function () { + if (window.NativeShell) { + return window.NativeShell.AppHost.getDefaultLayout(); + } + + return getDefaultLayout(); + }, + getDeviceProfile: getDeviceProfile, + init: function () { + if (window.NativeShell) { + return window.NativeShell.AppHost.init(); + } + + deviceName = getDeviceName(); + getDeviceId().then(function (id) { + deviceId = id; + }); + }, + deviceName: function () { + return window.NativeShell ? window.NativeShell.AppHost.deviceName() : deviceName; + }, + deviceId: function () { + return window.NativeShell ? window.NativeShell.AppHost.deviceId() : deviceId; + }, + appName: function () { + return window.NativeShell ? window.NativeShell.AppHost.appName() : appName; + }, + appVersion: function () { + return window.NativeShell ? window.NativeShell.AppHost.appVersion() : appVersion; + }, + getPushTokenInfo: function () { + return {}; + }, + setThemeColor: function (color) { + const metaThemeColor = document.querySelector('meta[name=theme-color]'); + + if (metaThemeColor) { + metaThemeColor.setAttribute('content', color); + } + }, + setUserScalable: function (scalable) { + if (!browser.tv) { + const att = scalable ? 'width=device-width, initial-scale=1, minimum-scale=1, user-scalable=yes' : 'width=device-width, initial-scale=1, minimum-scale=1, maximum-scale=1, user-scalable=no'; + document.querySelector('meta[name=viewport]').setAttribute('content', att); + } } +}; - return appHost; -}); +let isHidden = false; +let hidden; +let visibilityChange; + +if (typeof document.hidden !== 'undefined') { /* eslint-disable-line compat/compat */ + hidden = 'hidden'; + visibilityChange = 'visibilitychange'; +} else if (typeof document.webkitHidden !== 'undefined') { + hidden = 'webkitHidden'; + visibilityChange = 'webkitvisibilitychange'; +} + +document.addEventListener(visibilityChange, function () { + /* eslint-disable-next-line compat/compat */ + if (document[hidden]) { + onAppHidden(); + } else { + onAppVisible(); + } +}, false); + +if (self.addEventListener) { + self.addEventListener('focus', onAppVisible); + self.addEventListener('blur', onAppHidden); +} + +export default appHost; diff --git a/src/components/cardbuilder/cardBuilder.js b/src/components/cardbuilder/cardBuilder.js index 4a37331ef4..e644365906 100644 --- a/src/components/cardbuilder/cardBuilder.js +++ b/src/components/cardbuilder/cardBuilder.js @@ -362,12 +362,12 @@ import 'programStyles'; let hasOpenRow; let hasOpenSection; - let sectionTitleTagName = options.sectionTitleTagName || 'div'; + const sectionTitleTagName = options.sectionTitleTagName || 'div'; let apiClient; let lastServerId; for (const [i, item] of items.entries()) { - let serverId = item.ServerId || options.serverId; + const serverId = item.ServerId || options.serverId; if (serverId !== lastServerId) { lastServerId = serverId; @@ -621,7 +621,7 @@ import 'programStyles'; }); } - let blurHashes = options.imageBlurhashes || item.ImageBlurHashes || {}; + const blurHashes = options.imageBlurhashes || item.ImageBlurHashes || {}; return { imgUrl: imgUrl, @@ -656,7 +656,7 @@ import 'programStyles'; for (let i = 0; i < character.length; i++) { sum += parseInt(character.charAt(i)); } - let index = String(sum).substr(-1); + const index = String(sum).substr(-1); return (index % numRandomColors) + 1; } else { @@ -682,7 +682,7 @@ import 'programStyles'; for (let i = 0; i < lines.length; i++) { let currentCssClass = cssClass; - let text = lines[i]; + const text = lines[i]; if (valid > 0 && isOuterFooter) { currentCssClass += ' cardText-secondary'; @@ -707,7 +707,7 @@ import 'programStyles'; } if (forceLines) { - let linesLength = maxLines || Math.min(lines.length, maxLines || lines.length); + const linesLength = maxLines || Math.min(lines.length, maxLines || lines.length); while (valid < linesLength) { html += "
 
"; @@ -1036,7 +1036,7 @@ import 'programStyles'; * @returns {string} HTML markup for the item count indicator. */ function getItemCountsHtml(options, item) { - let counts = []; + const counts = []; let childText; if (item.Type === 'Playlist') { @@ -1318,7 +1318,7 @@ import 'programStyles'; let cardBoxClose = ''; let cardScalableClose = ''; - let cardContentClass = 'cardContent'; + const cardContentClass = 'cardContent'; let blurhashAttrib = ''; if (blurhash && blurhash.length > 0) { @@ -1337,7 +1337,7 @@ import 'programStyles'; cardImageContainerClose = ''; } - let cardScalableClass = 'cardScalable'; + const cardScalableClass = 'cardScalable'; cardImageContainerOpen = '
' + cardImageContainerOpen; cardBoxClose = '
'; @@ -1681,7 +1681,7 @@ import 'programStyles'; const cells = itemsContainer.querySelectorAll('.card[data-id="' + programId + '"]'); for (let i = 0, length = cells.length; i < length; i++) { - let cell = cells[i]; + const cell = cells[i]; const icon = cell.querySelector('.timerIndicator'); if (!icon) { const indicatorsElem = ensureIndicators(cell); @@ -1700,8 +1700,8 @@ import 'programStyles'; const cells = itemsContainer.querySelectorAll('.card[data-timerid="' + timerId + '"]'); for (let i = 0; i < cells.length; i++) { - let cell = cells[i]; - let icon = cell.querySelector('.timerIndicator'); + const cell = cells[i]; + const icon = cell.querySelector('.timerIndicator'); if (icon) { icon.parentNode.removeChild(icon); } @@ -1718,8 +1718,8 @@ import 'programStyles'; const cells = itemsContainer.querySelectorAll('.card[data-seriestimerid="' + cancelledTimerId + '"]'); for (let i = 0; i < cells.length; i++) { - let cell = cells[i]; - let icon = cell.querySelector('.timerIndicator'); + const cell = cells[i]; + const icon = cell.querySelector('.timerIndicator'); if (icon) { icon.parentNode.removeChild(icon); } diff --git a/src/components/displaySettings/displaySettings.js b/src/components/displaySettings/displaySettings.js index ae7647f98b..641faa7f3b 100644 --- a/src/components/displaySettings/displaySettings.js +++ b/src/components/displaySettings/displaySettings.js @@ -75,13 +75,13 @@ import 'emby-button'; context.querySelector('.languageSection').classList.add('hide'); } - if (appHost.supports('displaymode')) { + if (appHost.default.supports('displaymode')) { context.querySelector('.fldDisplayMode').classList.remove('hide'); } else { context.querySelector('.fldDisplayMode').classList.add('hide'); } - if (appHost.supports('externallinks')) { + if (appHost.default.supports('externallinks')) { context.querySelector('.learnHowToContributeContainer').classList.remove('hide'); } else { context.querySelector('.learnHowToContributeContainer').classList.add('hide'); @@ -136,7 +136,7 @@ import 'emby-button'; function saveUser(context, user, userSettingsInstance, apiClient) { user.Configuration.DisplayMissingEpisodes = context.querySelector('.chkDisplayMissingEpisodes').checked; - if (appHost.supports('displaylanguage')) { + if (appHost.default.supports('displaylanguage')) { userSettingsInstance.language(context.querySelector('#selectLanguage').value); } diff --git a/src/components/imageDownloader/imageDownloader.js b/src/components/imageDownloader/imageDownloader.js index 2be2ef09b2..5141ff73e5 100644 --- a/src/components/imageDownloader/imageDownloader.js +++ b/src/components/imageDownloader/imageDownloader.js @@ -208,7 +208,7 @@ import 'cardStyle'; html += '
'; html += '
'; - if (layoutManager.tv || !appHost.supports('externallinks')) { + if (layoutManager.tv || !appHost.default.supports('externallinks')) { html += '
'; } else { html += ''; diff --git a/src/components/images/imageLoader.js b/src/components/images/imageLoader.js index 0effcc7a57..39dc6c2622 100644 --- a/src/components/images/imageLoader.js +++ b/src/components/images/imageLoader.js @@ -17,8 +17,8 @@ import 'css!./style'; // Although the default values recommended by Blurhash developers is 32x32, a size of 18x18 seems to be the sweet spot for us, // improving the performance and reducing the memory usage, while retaining almost full blur quality. // Lower values had more visible pixelation - let width = 18; - let height = 18; + const width = 18; + const height = 18; let pixels; try { pixels = blurhash.decode(blurhashstr, width, height); @@ -27,11 +27,11 @@ import 'css!./style'; target.classList.add('non-blurhashable'); return; } - let canvas = document.createElement('canvas'); + const canvas = document.createElement('canvas'); canvas.width = width; canvas.height = height; - let ctx = canvas.getContext('2d'); - let imgData = ctx.createImageData(width, height); + const ctx = canvas.getContext('2d'); + const imgData = ctx.createImageData(width, height); imgData.data.set(pixels); ctx.putImageData(imgData, 0, 0); @@ -55,7 +55,7 @@ import 'css!./style'; if (!entry) { throw new Error('entry cannot be null'); } - let target = entry.target; + const target = entry.target; var source = undefined; if (target) { @@ -78,7 +78,7 @@ import 'css!./style'; throw new TypeError('url cannot be undefined'); } - let preloaderImg = new Image(); + const preloaderImg = new Image(); preloaderImg.src = url; elem.classList.add('lazy-hidden'); diff --git a/src/components/indicators/indicators.js b/src/components/indicators/indicators.js index 604f480f1d..bbd672ef72 100644 --- a/src/components/indicators/indicators.js +++ b/src/components/indicators/indicators.js @@ -82,7 +82,7 @@ export function enablePlayedIndicator(item) { export function getPlayedIndicatorHtml(item) { if (enablePlayedIndicator(item)) { - let userData = item.UserData || {}; + const userData = item.UserData || {}; if (userData.UnplayedItemCount) { return '
' + userData.UnplayedItemCount + '
'; } diff --git a/src/components/itemContextMenu.js b/src/components/itemContextMenu.js index 173383d064..3471057139 100644 --- a/src/components/itemContextMenu.js +++ b/src/components/itemContextMenu.js @@ -158,7 +158,7 @@ import actionsheet from 'actionsheet'; } // Books are promoted to major download Button and therefor excluded in the context menu - if ((item.CanDownload && appHost.supports('filedownload')) && item.Type !== 'Book') { + if ((item.CanDownload && appHost.default.supports('filedownload')) && item.Type !== 'Book') { commands.push({ name: globalize.translate('Download'), id: 'download', diff --git a/src/components/multiSelect/multiSelect.js b/src/components/multiSelect/multiSelect.js index d922aee84a..feba0ade5d 100644 --- a/src/components/multiSelect/multiSelect.js +++ b/src/components/multiSelect/multiSelect.js @@ -196,7 +196,7 @@ import 'css!./multiSelect'; }); } - if (user.Policy.EnableContentDownloading && appHost.supports('filedownload')) { + if (user.Policy.EnableContentDownloading && appHost.default.supports('filedownload')) { menuItems.push({ name: globalize.translate('ButtonDownload'), id: 'download', diff --git a/src/components/nowPlayingBar/nowPlayingBar.js b/src/components/nowPlayingBar/nowPlayingBar.js index d411dcc620..aeba8fedf9 100644 --- a/src/components/nowPlayingBar/nowPlayingBar.js +++ b/src/components/nowPlayingBar/nowPlayingBar.js @@ -415,7 +415,7 @@ import 'emby-ratingbutton'; showVolumeSlider = false; } - if (currentPlayer.isLocalPlayer && appHost.supports('physicalvolumecontrol')) { + if (currentPlayer.isLocalPlayer && appHost.default.supports('physicalvolumecontrol')) { showMuteButton = false; showVolumeSlider = false; } diff --git a/src/components/playback/mediasession.js b/src/components/playback/mediasession.js index 0f275c88f7..5c7ddf45dd 100644 --- a/src/components/playback/mediasession.js +++ b/src/components/playback/mediasession.js @@ -127,7 +127,7 @@ import connectionManager from 'connectionManager'; artwork: getImageUrls(item) }); } else { - let itemImageUrl = seriesImageUrl(item, { maxHeight: 3000 }) || imageUrl(item, { maxHeight: 3000 }); + const itemImageUrl = seriesImageUrl(item, { maxHeight: 3000 }) || imageUrl(item, { maxHeight: 3000 }); window.NativeShell.updateMediaSession({ action: eventName, @@ -244,10 +244,10 @@ import connectionManager from 'connectionManager'; /* eslint-disable-next-line compat/compat */ navigator.mediaSession.setActionHandler('seekto', function (object) { - let item = playbackManager.getPlayerState(currentPlayer).NowPlayingItem; + const item = playbackManager.getPlayerState(currentPlayer).NowPlayingItem; // Convert to ms - let duration = parseInt(item.RunTimeTicks ? (item.RunTimeTicks / 10000) : 0); - let wantedTime = object.seekTime * 1000; + const duration = parseInt(item.RunTimeTicks ? (item.RunTimeTicks / 10000) : 0); + const wantedTime = object.seekTime * 1000; playbackManager.seekPercent(wantedTime / duration * 100, currentPlayer); }); } diff --git a/src/components/playback/playbackmanager.js b/src/components/playback/playbackmanager.js index 437127be18..ed06e3eef3 100644 --- a/src/components/playback/playbackmanager.js +++ b/src/components/playback/playbackmanager.js @@ -3520,7 +3520,7 @@ class PlaybackManager { 'PlayTrailers' ]; - if (apphost.supports('fullscreenchange')) { + if (appHost.default.supports('fullscreenchange')) { list.push('ToggleFullscreen'); } diff --git a/src/components/playback/playerSelectionMenu.js b/src/components/playback/playerSelectionMenu.js index 7799613400..878fccb6da 100644 --- a/src/components/playback/playerSelectionMenu.js +++ b/src/components/playback/playerSelectionMenu.js @@ -121,7 +121,7 @@ export function show(button) { // Unfortunately we can't allow the url to change or chromecast will throw a security error // Might be able to solve this in the future by moving the dialogs to hashbangs - if (!(!browser.chrome && !browser.edgeChromium || appHost.supports('castmenuhashchange'))) { + if (!(!browser.chrome && !browser.edgeChromium || appHost.default.supports('castmenuhashchange'))) { menuOptions.enableHistory = false; } diff --git a/src/components/playbackSettings/playbackSettings.js b/src/components/playbackSettings/playbackSettings.js index 66e1ae777f..14dc742dfd 100644 --- a/src/components/playbackSettings/playbackSettings.js +++ b/src/components/playbackSettings/playbackSettings.js @@ -98,7 +98,7 @@ import 'emby-checkbox'; context.querySelector('.videoQualitySection').classList.add('hide'); } - if (appHost.supports('multiserver')) { + if (appHost.default.supports('multiserver')) { context.querySelector('.fldVideoInNetworkQuality').classList.remove('hide'); context.querySelector('.fldVideoInternetQuality').classList.remove('hide'); @@ -162,7 +162,7 @@ import 'emby-checkbox'; } }); - if (appHost.supports('externalplayerintent') && userId === loggedInUserId) { + if (appHost.default.supports('externalplayerintent') && userId === loggedInUserId) { context.querySelector('.fldExternalPlayer').classList.remove('hide'); } else { context.querySelector('.fldExternalPlayer').classList.add('hide'); @@ -171,7 +171,7 @@ import 'emby-checkbox'; if (userId === loggedInUserId && (user.Policy.EnableVideoPlaybackTranscoding || user.Policy.EnableAudioPlaybackTranscoding)) { context.querySelector('.qualitySections').classList.remove('hide'); - if (appHost.supports('chromecast') && user.Policy.EnableVideoPlaybackTranscoding) { + if (appHost.default.supports('chromecast') && user.Policy.EnableVideoPlaybackTranscoding) { context.querySelector('.fldChromecastQuality').classList.remove('hide'); } else { context.querySelector('.fldChromecastQuality').classList.add('hide'); diff --git a/src/components/qualityOptions.js b/src/components/qualityOptions.js index 10a5df39ba..d6bced83f7 100644 --- a/src/components/qualityOptions.js +++ b/src/components/qualityOptions.js @@ -1,160 +1,165 @@ -define(['globalize'], function (globalize) { - 'use strict'; +import globalize from 'globalize'; - function getVideoQualityOptions(options) { - var maxStreamingBitrate = options.currentMaxBitrate; - var videoWidth = options.videoWidth; - var videoHeight = options.videoHeight; +export function getVideoQualityOptions(options) { - // If the aspect ratio is less than 16/9 (1.77), set the width as if it were pillarboxed. - // 4:3 1440x1080 -> 1920x1080 - if (videoWidth / videoHeight < 16 / 9) { - videoWidth = videoHeight * (16 / 9); - } + var maxStreamingBitrate = options.currentMaxBitrate; + var videoWidth = options.videoWidth; + var videoHeight = options.videoHeight; - var maxAllowedWidth = videoWidth || 4096; - - var qualityOptions = []; - - if (maxAllowedWidth >= 3800) { - qualityOptions.push({ name: '4K - 120 Mbps', maxHeight: 2160, bitrate: 120000000 }); - qualityOptions.push({ name: '4K - 100 Mbps', maxHeight: 2160, bitrate: 100000000 }); - qualityOptions.push({ name: '4K - 80 Mbps', maxHeight: 2160, bitrate: 80000000 }); - } - - // Some 1080- videos are reported as 1912? - if (maxAllowedWidth >= 1900) { - qualityOptions.push({ name: '1080p - 60 Mbps', maxHeight: 1080, bitrate: 60000000 }); - qualityOptions.push({ name: '1080p - 50 Mbps', maxHeight: 1080, bitrate: 50000000 }); - qualityOptions.push({ name: '1080p - 40 Mbps', maxHeight: 1080, bitrate: 40000000 }); - qualityOptions.push({ name: '1080p - 30 Mbps', maxHeight: 1080, bitrate: 30000000 }); - qualityOptions.push({ name: '1080p - 25 Mbps', maxHeight: 1080, bitrate: 25000000 }); - qualityOptions.push({ name: '1080p - 20 Mbps', maxHeight: 1080, bitrate: 20000000 }); - qualityOptions.push({ name: '1080p - 15 Mbps', maxHeight: 1080, bitrate: 15000000 }); - qualityOptions.push({ name: '1080p - 10 Mbps', maxHeight: 1080, bitrate: 10000001 }); - qualityOptions.push({ name: '1080p - 8 Mbps', maxHeight: 1080, bitrate: 8000001 }); - qualityOptions.push({ name: '1080p - 6 Mbps', maxHeight: 1080, bitrate: 6000001 }); - qualityOptions.push({ name: '1080p - 5 Mbps', maxHeight: 1080, bitrate: 5000001 }); - qualityOptions.push({ name: '1080p - 4 Mbps', maxHeight: 1080, bitrate: 4000002 }); - } else if (maxAllowedWidth >= 1260) { - qualityOptions.push({ name: '720p - 10 Mbps', maxHeight: 720, bitrate: 10000000 }); - qualityOptions.push({ name: '720p - 8 Mbps', maxHeight: 720, bitrate: 8000000 }); - qualityOptions.push({ name: '720p - 6 Mbps', maxHeight: 720, bitrate: 6000000 }); - qualityOptions.push({ name: '720p - 5 Mbps', maxHeight: 720, bitrate: 5000000 }); - } else if (maxAllowedWidth >= 620) { - qualityOptions.push({ name: '480p - 4 Mbps', maxHeight: 480, bitrate: 4000001 }); - qualityOptions.push({ name: '480p - 3 Mbps', maxHeight: 480, bitrate: 3000001 }); - qualityOptions.push({ name: '480p - 2.5 Mbps', maxHeight: 480, bitrate: 2500000 }); - qualityOptions.push({ name: '480p - 2 Mbps', maxHeight: 480, bitrate: 2000001 }); - qualityOptions.push({ name: '480p - 1.5 Mbps', maxHeight: 480, bitrate: 1500001 }); - } - - if (maxAllowedWidth >= 1260) { - qualityOptions.push({ name: '720p - 4 Mbps', maxHeight: 720, bitrate: 4000000 }); - qualityOptions.push({ name: '720p - 3 Mbps', maxHeight: 720, bitrate: 3000000 }); - qualityOptions.push({ name: '720p - 2 Mbps', maxHeight: 720, bitrate: 2000000 }); - - // The extra 1 is because they're keyed off the bitrate value - qualityOptions.push({ name: '720p - 1.5 Mbps', maxHeight: 720, bitrate: 1500000 }); - qualityOptions.push({ name: '720p - 1 Mbps', maxHeight: 720, bitrate: 1000001 }); - } - - qualityOptions.push({ name: '480p - 1 Mbps', maxHeight: 480, bitrate: 1000000 }); - qualityOptions.push({ name: '480p - 720 kbps', maxHeight: 480, bitrate: 720000 }); - qualityOptions.push({ name: '480p - 420 kbps', maxHeight: 480, bitrate: 420000 }); - qualityOptions.push({ name: '360p', maxHeight: 360, bitrate: 400000 }); - qualityOptions.push({ name: '240p', maxHeight: 240, bitrate: 320000 }); - qualityOptions.push({ name: '144p', maxHeight: 144, bitrate: 192000 }); - - var autoQualityOption = { - name: globalize.translate('Auto'), - bitrate: 0, - selected: options.isAutomaticBitrateEnabled - }; - - if (options.enableAuto) { - qualityOptions.push(autoQualityOption); - } - - if (maxStreamingBitrate) { - var selectedIndex = -1; - for (var i = 0, length = qualityOptions.length; i < length; i++) { - var option = qualityOptions[i]; - - if (selectedIndex === -1 && option.bitrate <= maxStreamingBitrate) { - selectedIndex = i; - } - } - - if (selectedIndex === -1) { - selectedIndex = qualityOptions.length - 1; - } - - var currentQualityOption = qualityOptions[selectedIndex]; - - if (!options.isAutomaticBitrateEnabled) { - currentQualityOption.selected = true; - } else { - autoQualityOption.autoText = currentQualityOption.name; - } - } - - return qualityOptions; + // If the aspect ratio is less than 16/9 (1.77), set the width as if it were pillarboxed. + // 4:3 1440x1080 -> 1920x1080 + if (videoWidth / videoHeight < 16 / 9) { + videoWidth = videoHeight * (16 / 9); } - function getAudioQualityOptions(options) { - var maxStreamingBitrate = options.currentMaxBitrate; + var maxAllowedWidth = videoWidth || 4096; + //var maxAllowedHeight = videoHeight || 2304; - var qualityOptions = []; + var qualityOptions = []; - qualityOptions.push({ name: '2 Mbps', bitrate: 2000000 }); - qualityOptions.push({ name: '1.5 Mbps', bitrate: 1500000 }); - qualityOptions.push({ name: '1 Mbps', bitrate: 1000000 }); - qualityOptions.push({ name: '320 kbps', bitrate: 320000 }); - qualityOptions.push({ name: '256 kbps', bitrate: 256000 }); - qualityOptions.push({ name: '192 kbps', bitrate: 192000 }); - qualityOptions.push({ name: '128 kbps', bitrate: 128000 }); - qualityOptions.push({ name: '96 kbps', bitrate: 96000 }); - qualityOptions.push({ name: '64 kbps', bitrate: 64000 }); - - var autoQualityOption = { - name: globalize.translate('Auto'), - bitrate: 0, - selected: options.isAutomaticBitrateEnabled - }; - - if (options.enableAuto) { - qualityOptions.push(autoQualityOption); - } - - if (maxStreamingBitrate) { - var selectedIndex = -1; - for (var i = 0, length = qualityOptions.length; i < length; i++) { - var option = qualityOptions[i]; - - if (selectedIndex === -1 && option.bitrate <= maxStreamingBitrate) { - selectedIndex = i; - } - } - - if (selectedIndex === -1) { - selectedIndex = qualityOptions.length - 1; - } - - var currentQualityOption = qualityOptions[selectedIndex]; - - if (!options.isAutomaticBitrateEnabled) { - currentQualityOption.selected = true; - } else { - autoQualityOption.autoText = currentQualityOption.name; - } - } - - return qualityOptions; + if (maxAllowedWidth >= 3800) { + qualityOptions.push({ name: '4K - 120 Mbps', maxHeight: 2160, bitrate: 120000000 }); + qualityOptions.push({ name: '4K - 100 Mbps', maxHeight: 2160, bitrate: 100000000 }); + qualityOptions.push({ name: '4K - 80 Mbps', maxHeight: 2160, bitrate: 80000000 }); } - return { - getVideoQualityOptions: getVideoQualityOptions, - getAudioQualityOptions: getAudioQualityOptions + // Some 1080- videos are reported as 1912? + if (maxAllowedWidth >= 1900) { + + qualityOptions.push({ name: '1080p - 60 Mbps', maxHeight: 1080, bitrate: 60000000 }); + qualityOptions.push({ name: '1080p - 50 Mbps', maxHeight: 1080, bitrate: 50000000 }); + qualityOptions.push({ name: '1080p - 40 Mbps', maxHeight: 1080, bitrate: 40000000 }); + qualityOptions.push({ name: '1080p - 30 Mbps', maxHeight: 1080, bitrate: 30000000 }); + qualityOptions.push({ name: '1080p - 25 Mbps', maxHeight: 1080, bitrate: 25000000 }); + qualityOptions.push({ name: '1080p - 20 Mbps', maxHeight: 1080, bitrate: 20000000 }); + qualityOptions.push({ name: '1080p - 15 Mbps', maxHeight: 1080, bitrate: 15000000 }); + qualityOptions.push({ name: '1080p - 10 Mbps', maxHeight: 1080, bitrate: 10000001 }); + qualityOptions.push({ name: '1080p - 8 Mbps', maxHeight: 1080, bitrate: 8000001 }); + qualityOptions.push({ name: '1080p - 6 Mbps', maxHeight: 1080, bitrate: 6000001 }); + qualityOptions.push({ name: '1080p - 5 Mbps', maxHeight: 1080, bitrate: 5000001 }); + qualityOptions.push({ name: '1080p - 4 Mbps', maxHeight: 1080, bitrate: 4000002 }); + + } else if (maxAllowedWidth >= 1260) { + qualityOptions.push({ name: '720p - 10 Mbps', maxHeight: 720, bitrate: 10000000 }); + qualityOptions.push({ name: '720p - 8 Mbps', maxHeight: 720, bitrate: 8000000 }); + qualityOptions.push({ name: '720p - 6 Mbps', maxHeight: 720, bitrate: 6000000 }); + qualityOptions.push({ name: '720p - 5 Mbps', maxHeight: 720, bitrate: 5000000 }); + + } else if (maxAllowedWidth >= 620) { + qualityOptions.push({ name: '480p - 4 Mbps', maxHeight: 480, bitrate: 4000001 }); + qualityOptions.push({ name: '480p - 3 Mbps', maxHeight: 480, bitrate: 3000001 }); + qualityOptions.push({ name: '480p - 2.5 Mbps', maxHeight: 480, bitrate: 2500000 }); + qualityOptions.push({ name: '480p - 2 Mbps', maxHeight: 480, bitrate: 2000001 }); + qualityOptions.push({ name: '480p - 1.5 Mbps', maxHeight: 480, bitrate: 1500001 }); + } + + if (maxAllowedWidth >= 1260) { + qualityOptions.push({ name: '720p - 4 Mbps', maxHeight: 720, bitrate: 4000000 }); + qualityOptions.push({ name: '720p - 3 Mbps', maxHeight: 720, bitrate: 3000000 }); + qualityOptions.push({ name: '720p - 2 Mbps', maxHeight: 720, bitrate: 2000000 }); + + // The extra 1 is because they're keyed off the bitrate value + qualityOptions.push({ name: '720p - 1.5 Mbps', maxHeight: 720, bitrate: 1500000 }); + qualityOptions.push({ name: '720p - 1 Mbps', maxHeight: 720, bitrate: 1000001 }); + } + + qualityOptions.push({ name: '480p - 1 Mbps', maxHeight: 480, bitrate: 1000000 }); + qualityOptions.push({ name: '480p - 720 kbps', maxHeight: 480, bitrate: 720000 }); + qualityOptions.push({ name: '480p - 420 kbps', maxHeight: 480, bitrate: 420000 }); + qualityOptions.push({ name: '360p', maxHeight: 360, bitrate: 400000 }); + qualityOptions.push({ name: '240p', maxHeight: 240, bitrate: 320000 }); + qualityOptions.push({ name: '144p', maxHeight: 144, bitrate: 192000 }); + + var autoQualityOption = { + name: globalize.translate('Auto'), + bitrate: 0, + selected: options.isAutomaticBitrateEnabled }; -}); + + if (options.enableAuto) { + qualityOptions.push(autoQualityOption); + } + + if (maxStreamingBitrate) { + var selectedIndex = -1; + for (var i = 0, length = qualityOptions.length; i < length; i++) { + + var option = qualityOptions[i]; + + if (selectedIndex === -1 && option.bitrate <= maxStreamingBitrate) { + selectedIndex = i; + } + } + + if (selectedIndex === -1) { + selectedIndex = qualityOptions.length - 1; + } + + var currentQualityOption = qualityOptions[selectedIndex]; + + if (!options.isAutomaticBitrateEnabled) { + currentQualityOption.selected = true; + } else { + autoQualityOption.autoText = currentQualityOption.name; + } + } + + return qualityOptions; +} + +export function getAudioQualityOptions(options) { + var maxStreamingBitrate = options.currentMaxBitrate; + + var qualityOptions = []; + + qualityOptions.push({ name: '2 Mbps', bitrate: 2000000 }); + qualityOptions.push({ name: '1.5 Mbps', bitrate: 1500000 }); + qualityOptions.push({ name: '1 Mbps', bitrate: 1000000 }); + qualityOptions.push({ name: '320 kbps', bitrate: 320000 }); + qualityOptions.push({ name: '256 kbps', bitrate: 256000 }); + qualityOptions.push({ name: '192 kbps', bitrate: 192000 }); + qualityOptions.push({ name: '128 kbps', bitrate: 128000 }); + qualityOptions.push({ name: '96 kbps', bitrate: 96000 }); + qualityOptions.push({ name: '64 kbps', bitrate: 64000 }); + + var autoQualityOption = { + name: globalize.translate('Auto'), + bitrate: 0, + selected: options.isAutomaticBitrateEnabled + }; + + if (options.enableAuto) { + qualityOptions.push(autoQualityOption); + } + + if (maxStreamingBitrate) { + var selectedIndex = -1; + for (var i = 0, length = qualityOptions.length; i < length; i++) { + var option = qualityOptions[i]; + + if (selectedIndex === -1 && option.bitrate <= maxStreamingBitrate) { + selectedIndex = i; + } + } + + if (selectedIndex === -1) { + + selectedIndex = qualityOptions.length - 1; + } + + var currentQualityOption = qualityOptions[selectedIndex]; + + if (!options.isAutomaticBitrateEnabled) { + currentQualityOption.selected = true; + } else { + autoQualityOption.autoText = currentQualityOption.name; + } + } + + return qualityOptions; +} + +export default { + getVideoQualityOptions, + getAudioQualityOptions +}; diff --git a/src/components/remotecontrol/remotecontrol.js b/src/components/remotecontrol/remotecontrol.js index b5ac4c9a8b..8668202424 100644 --- a/src/components/remotecontrol/remotecontrol.js +++ b/src/components/remotecontrol/remotecontrol.js @@ -397,7 +397,7 @@ define(['browser', 'datetime', 'backdrop', 'libraryBrowser', 'listView', 'imageL showVolumeSlider = false; } - if (currentPlayer.isLocalPlayer && appHost.supports('physicalvolumecontrol')) { + if (currentPlayer.isLocalPlayer && appHost.default.supports('physicalvolumecontrol')) { showMuteButton = false; showVolumeSlider = false; } diff --git a/src/components/scrollManager.js b/src/components/scrollManager.js index 4ee31a6275..549cb9445c 100644 --- a/src/components/scrollManager.js +++ b/src/components/scrollManager.js @@ -251,7 +251,7 @@ import layoutManager from 'layoutManager'; * @return {ScrollerData} Scroller data. */ function getScrollerData(scroller, vertical) { - let data = {}; + const data = {}; if (!vertical) { data.scrollPos = scroller.scrollLeft; diff --git a/src/components/skinManager.js b/src/components/skinManager.js new file mode 100644 index 0000000000..e157854850 --- /dev/null +++ b/src/components/skinManager.js @@ -0,0 +1,184 @@ +define(['apphost', 'userSettings', 'browser', 'events', 'backdrop', 'globalize', 'require', 'appSettings'], function (appHost, userSettings, browser, events, backdrop, globalize, require, appSettings) { + 'use strict'; + + var themeStyleElement; + var currentThemeId; + + function unloadTheme() { + var elem = themeStyleElement; + if (elem) { + elem.parentNode.removeChild(elem); + themeStyleElement = null; + currentThemeId = null; + } + } + + function loadUserSkin(options) { + options = options || {}; + if (options.start) { + Emby.Page.invokeShortcut(options.start); + } else { + Emby.Page.goHome(); + } + } + + function getThemes() { + return [{ + name: 'Apple TV', + id: 'appletv' + }, { + name: 'Blue Radiance', + id: 'blueradiance' + }, { + name: 'Dark', + id: 'dark', + isDefault: true, + isDefaultServerDashboard: true + }, { + name: 'Light', + id: 'light' + }, { + name: 'Purple Haze', + id: 'purplehaze' + }, { + name: 'Windows Media Center', + id: 'wmc' + }]; + } + + var skinManager = { + getThemes: getThemes, + loadUserSkin: loadUserSkin + }; + + function getThemeStylesheetInfo(id, isDefaultProperty) { + var themes = skinManager.getThemes(); + var defaultTheme; + var selectedTheme; + + for (var i = 0, length = themes.length; i < length; i++) { + var theme = themes[i]; + if (theme[isDefaultProperty]) { + defaultTheme = theme; + } + if (id === theme.id) { + selectedTheme = theme; + } + } + + selectedTheme = selectedTheme || defaultTheme; + return { + stylesheetPath: require.toUrl('themes/' + selectedTheme.id + '/theme.css'), + themeId: selectedTheme.id + }; + } + + var themeResources = {}; + var lastSound = 0; + var currentSound; + + function loadThemeResources(id) { + lastSound = 0; + if (currentSound) { + currentSound.stop(); + currentSound = null; + } + + backdrop.clearBackdrop(); + } + + function onThemeLoaded() { + document.documentElement.classList.remove('preload'); + try { + var color = getComputedStyle(document.querySelector('.skinHeader')).getPropertyValue('background-color'); + if (color) { + appHost.default.setThemeColor(color); + } + } catch (err) { + console.error('error setting theme color: ' + err); + } + } + + skinManager.setTheme = function (id, context) { + return new Promise(function (resolve, reject) { + if (currentThemeId && currentThemeId === id) { + resolve(); + return; + } + + var isDefaultProperty = context === 'serverdashboard' ? 'isDefaultServerDashboard' : 'isDefault'; + var info = getThemeStylesheetInfo(id, isDefaultProperty); + if (currentThemeId && currentThemeId === info.themeId) { + resolve(); + return; + } + + var linkUrl = info.stylesheetPath; + unloadTheme(); + + var link = document.createElement('link'); + link.setAttribute('rel', 'stylesheet'); + link.setAttribute('type', 'text/css'); + link.onload = function () { + onThemeLoaded(); + resolve(); + }; + + link.setAttribute('href', linkUrl); + document.head.appendChild(link); + themeStyleElement = link; + currentThemeId = info.themeId; + loadThemeResources(info.themeId); + + onViewBeforeShow({}); + }); + }; + + function onViewBeforeShow(e) { + if (e.detail && e.detail.type === 'video-osd') { + // This removes the space that the scrollbar takes while playing a video + document.body.classList.remove('force-scroll'); + return; + } + + if (themeResources.backdrop) { + backdrop.setBackdrop(themeResources.backdrop); + } + + if (!browser.mobile && userSettings.enableThemeSongs()) { + if (lastSound === 0) { + if (themeResources.themeSong) { + playSound(themeResources.themeSong); + } + } else if ((new Date().getTime() - lastSound) > 30000) { + if (themeResources.effect) { + playSound(themeResources.effect); + } + } + } + // This keeps the scrollbar always present in all pages, so we avoid clipping while switching between pages + // that need the scrollbar and pages that don't. + document.body.classList.add('force-scroll'); + } + + document.addEventListener('viewshow', onViewBeforeShow); + + function playSound(path, volume) { + lastSound = new Date().getTime(); + require(['howler'], function (howler) { + /* globals Howl */ + try { + var sound = new Howl({ + src: [path], + volume: volume || 0.1 + }); + sound.play(); + currentSound = sound; + } catch (err) { + console.error('error playing sound: ' + err); + } + }); + } + + return skinManager; +}); diff --git a/src/components/slideshow/slideshow.js b/src/components/slideshow/slideshow.js index 38728ec6c6..f76adbd6c5 100644 --- a/src/components/slideshow/slideshow.js +++ b/src/components/slideshow/slideshow.js @@ -113,7 +113,7 @@ define(['dialogHelper', 'inputManager', 'connectionManager', 'layoutManager', 'f */ function setUserScalable(scalable) { try { - appHost.setUserScalable(scalable); + appHost.default.setUserScalable(scalable); } catch (err) { console.error('error in appHost.setUserScalable: ' + err); } @@ -162,10 +162,10 @@ define(['dialogHelper', 'inputManager', 'connectionManager', 'layoutManager', 'f html += '
'; if (actionButtonsOnTop) { - if (appHost.supports('filedownload') && options.user && options.user.Policy.EnableContentDownloading) { + if (appHost.default.supports('filedownload') && options.user && options.user.Policy.EnableContentDownloading) { html += getIcon('file_download', 'btnDownload slideshowButton', true); } - if (appHost.supports('sharing')) { + if (appHost.default.supports('sharing')) { html += getIcon('share', 'btnShare slideshowButton', true); } } @@ -176,10 +176,10 @@ define(['dialogHelper', 'inputManager', 'connectionManager', 'layoutManager', 'f html += '
'; html += getIcon('play_arrow', 'btnSlideshowPause slideshowButton', true, true); - if (appHost.supports('filedownload') && options.user && options.user.Policy.EnableContentDownloading) { + if (appHost.default.supports('filedownload') && options.user && options.user.Policy.EnableContentDownloading) { html += getIcon('file_download', 'btnDownload slideshowButton', true); } - if (appHost.supports('sharing')) { + if (appHost.default.supports('sharing')) { html += getIcon('share', 'btnShare slideshowButton', true); } diff --git a/src/controllers/dashboard/plugins/repositories/index.js b/src/controllers/dashboard/plugins/repositories/index.js index 3087cdd927..25cbbac38a 100644 --- a/src/controllers/dashboard/plugins/repositories/index.js +++ b/src/controllers/dashboard/plugins/repositories/index.js @@ -105,7 +105,7 @@ export default function(view, params) { }); view.querySelector('.btnNewRepository').addEventListener('click', () => { - let dialog = dialogHelper.createDialog({ + const dialog = dialogHelper.createDialog({ scrollY: false, size: 'large', modal: false, diff --git a/src/controllers/music/musicrecommended.js b/src/controllers/music/musicrecommended.js index db7dac9547..34aee4e6a0 100644 --- a/src/controllers/music/musicrecommended.js +++ b/src/controllers/music/musicrecommended.js @@ -104,7 +104,6 @@ import 'flexStyles'; } var itemsContainer = elem.querySelector('.itemsContainer'); - itemsContainer.innerHTML = cardBuilder.getCardsHtml({ items: result.Items, showUnplayedIndicator: false, diff --git a/src/controllers/playback/video/index.js b/src/controllers/playback/video/index.js index a8bd0e01f3..2129061a35 100644 --- a/src/controllers/playback/video/index.js +++ b/src/controllers/playback/video/index.js @@ -898,7 +898,7 @@ import 'css!assets/css/videoosd'; showVolumeSlider = false; } - if (player.isLocalPlayer && appHost.supports('physicalvolumecontrol')) { + if (player.isLocalPlayer && appHost.default.supports('physicalvolumecontrol')) { showMuteButton = false; showVolumeSlider = false; } diff --git a/src/controllers/session/login/index.js b/src/controllers/session/login/index.js index 8bac557a20..c53c59f3b2 100644 --- a/src/controllers/session/login/index.js +++ b/src/controllers/session/login/index.js @@ -199,7 +199,7 @@ import 'emby-checkbox'; loading.show(); libraryMenu.setTransparentMenu(true); - if (!appHost.supports('multiserver')) { + if (!appHost.default.supports('multiserver')) { view.querySelector('.btnSelectServer').classList.add('hide'); } diff --git a/src/controllers/user/menu.js b/src/controllers/user/menu.js new file mode 100644 index 0000000000..bd6f4de8a2 --- /dev/null +++ b/src/controllers/user/menu.js @@ -0,0 +1,58 @@ +define(['apphost', 'connectionManager', 'layoutManager', 'listViewStyle', 'emby-button'], function(appHost, connectionManager, layoutManager) { + 'use strict'; + + return function(view, params) { + view.querySelector('.btnLogout').addEventListener('click', function() { + Dashboard.logout(); + }); + + view.querySelector('.selectServer').addEventListener('click', function () { + Dashboard.selectServer(); + }); + + view.querySelector('.clientSettings').addEventListener('click', function () { + window.NativeShell.openClientSettings(); + }); + + view.addEventListener('viewshow', function() { + // this page can also be used by admins to change user preferences from the user edit page + var userId = params.userId || Dashboard.getCurrentUserId(); + var page = this; + + page.querySelector('.lnkMyProfile').setAttribute('href', 'myprofile.html?userId=' + userId); + page.querySelector('.lnkDisplayPreferences').setAttribute('href', 'mypreferencesdisplay.html?userId=' + userId); + page.querySelector('.lnkHomePreferences').setAttribute('href', 'mypreferenceshome.html?userId=' + userId); + page.querySelector('.lnkPlaybackPreferences').setAttribute('href', 'mypreferencesplayback.html?userId=' + userId); + page.querySelector('.lnkSubtitlePreferences').setAttribute('href', 'mypreferencessubtitles.html?userId=' + userId); + + if (window.NativeShell && window.NativeShell.AppHost.supports('clientsettings')) { + page.querySelector('.clientSettings').classList.remove('hide'); + } else { + page.querySelector('.clientSettings').classList.add('hide'); + } + + if (appHost.default.supports('multiserver')) { + page.querySelector('.selectServer').classList.remove('hide'); + } else { + page.querySelector('.selectServer').classList.add('hide'); + } + + // hide the actions if user preferences are being edited for a different user + if (params.userId && params.userId !== Dashboard.getCurrentUserId) { + page.querySelector('.userSection').classList.add('hide'); + page.querySelector('.adminSection').classList.add('hide'); + } + + ApiClient.getUser(userId).then(function(user) { + page.querySelector('.headerUsername').innerHTML = user.Name; + if (!user.Policy.IsAdministrator) { + page.querySelector('.adminSection').classList.add('hide'); + } + }); + + require(['autoFocuser'], function (autoFocuser) { + autoFocuser.autoFocus(view); + }); + }); + }; +}); diff --git a/src/controllers/user/profile.js b/src/controllers/user/profile.js new file mode 100644 index 0000000000..eb912418fd --- /dev/null +++ b/src/controllers/user/profile.js @@ -0,0 +1,106 @@ +define(['controllers/dashboard/users/userpasswordpage', 'loading', 'libraryMenu', 'apphost', 'globalize', 'emby-button'], function (UserPasswordPage, loading, libraryMenu, appHost, globalize) { + 'use strict'; + + function reloadUser(page) { + var userId = getParameterByName('userId'); + loading.show(); + ApiClient.getUser(userId).then(function (user) { + page.querySelector('.username').innerHTML = user.Name; + libraryMenu.setTitle(user.Name); + + var imageUrl = 'assets/img/avatar.png'; + if (user.PrimaryImageTag) { + imageUrl = ApiClient.getUserImageUrl(user.Id, { + tag: user.PrimaryImageTag, + type: 'Primary' + }); + } + + var userImage = page.querySelector('#image'); + userImage.style.backgroundImage = 'url(' + imageUrl + ')'; + + Dashboard.getCurrentUser().then(function (loggedInUser) { + if (user.PrimaryImageTag) { + page.querySelector('#btnAddImage').classList.add('hide'); + page.querySelector('#btnDeleteImage').classList.remove('hide'); + } else if (appHost.default.supports('fileinput') && (loggedInUser.Policy.IsAdministrator || user.Policy.EnableUserPreferenceAccess)) { + page.querySelector('#btnDeleteImage').classList.add('hide'); + page.querySelector('#btnAddImage').classList.remove('hide'); + } + }); + loading.hide(); + }); + } + + function onFileReaderError(evt) { + loading.hide(); + switch (evt.target.error.code) { + case evt.target.error.NOT_FOUND_ERR: + require(['toast'], function (toast) { + toast(globalize.translate('FileNotFound')); + }); + break; + case evt.target.error.ABORT_ERR: + onFileReaderAbort(); + break; + case evt.target.error.NOT_READABLE_ERR: + default: + require(['toast'], function (toast) { + toast(globalize.translate('FileReadError')); + }); + } + } + + function onFileReaderAbort(evt) { + loading.hide(); + require(['toast'], function (toast) { + toast(globalize.translate('FileReadCancelled')); + }); + } + + function setFiles(page, files) { + var userImage = page.querySelector('#image'); + var file = files[0]; + + if (!file || !file.type.match('image.*')) { + return false; + } + + var reader = new FileReader(); + reader.onerror = onFileReaderError; + reader.onabort = onFileReaderAbort; + reader.onload = function (evt) { + userImage.style.backgroundImage = 'url(' + evt.target.result + ')'; + var userId = getParameterByName('userId'); + ApiClient.uploadUserImage(userId, 'Primary', file).then(function () { + loading.hide(); + reloadUser(page); + }); + }; + + reader.readAsDataURL(file); + } + + return function (view, params) { + reloadUser(view); + new UserPasswordPage(view, params); + view.querySelector('#btnDeleteImage').addEventListener('click', function () { + require(['confirm'], function (confirm) { + confirm(globalize.translate('DeleteImageConfirmation'), globalize.translate('DeleteImage')).then(function () { + loading.show(); + var userId = getParameterByName('userId'); + ApiClient.deleteUserImage(userId, 'primary').then(function () { + loading.hide(); + reloadUser(view); + }); + }); + }); + }); + view.querySelector('#btnAddImage').addEventListener('click', function (evt) { + view.querySelector('#uploadImage').click(); + }); + view.querySelector('#uploadImage').addEventListener('change', function (evt) { + setFiles(view, evt.target.files); + }); + }; +}); diff --git a/src/plugins/bookPlayer/plugin.js b/src/plugins/bookPlayer/plugin.js index c167046cb9..afd7052e1d 100644 --- a/src/plugins/bookPlayer/plugin.js +++ b/src/plugins/bookPlayer/plugin.js @@ -27,16 +27,16 @@ export class BookPlayer { this._loaded = false; loading.show(); - let elem = this.createMediaElement(); + const elem = this.createMediaElement(); return this.setCurrentSrc(elem, options); } stop() { this.unbindEvents(); - let elem = this._mediaElement; - let tocElement = this._tocElement; - let rendition = this._rendition; + const elem = this._mediaElement; + const tocElement = this._tocElement; + const rendition = this._rendition; if (elem) { dialogHelper.close(elem); @@ -93,11 +93,9 @@ export class BookPlayer { } onWindowKeyUp(e) { - let key = keyboardnavigation.getKeyName(e); - - // TODO: depending on the event this can be the document or the rendition itself - let rendition = this._rendition || this; - let book = rendition.book; + const key = keyboardnavigation.getKeyName(e); + const rendition = this._rendition; + const book = rendition.book; if (this._loaded === false) return; switch (key) { @@ -147,7 +145,7 @@ export class BookPlayer { } bindMediaElementEvents() { - let elem = this._mediaElement; + const elem = this._mediaElement; elem.addEventListener('close', this.onDialogClosed, {once: true}); elem.querySelector('.btnBookplayerExit').addEventListener('click', this.onDialogClosed, {once: true}); @@ -166,7 +164,7 @@ export class BookPlayer { } unbindMediaElementEvents() { - let elem = this._mediaElement; + const elem = this._mediaElement; elem.removeEventListener('close', this.onDialogClosed); elem.querySelector('.btnBookplayerExit').removeEventListener('click', this.onDialogClosed); @@ -231,7 +229,7 @@ export class BookPlayer { } setCurrentSrc(elem, options) { - let item = options.items[0]; + const item = options.items[0]; this._currentItem = item; this.streamInfo = { started: true, @@ -241,25 +239,25 @@ export class BookPlayer { } }; - let serverId = item.ServerId; - let apiClient = connectionManager.getApiClient(serverId); + const serverId = item.ServerId; + const apiClient = connectionManager.getApiClient(serverId); return new Promise((resolve, reject) => { import('epubjs').then(({default: epubjs}) => { - let downloadHref = apiClient.getItemDownloadUrl(item.Id); - let book = epubjs(downloadHref, {openAs: 'epub'}); - let rendition = book.renderTo(elem, {width: '100%', height: '97%'}); + const downloadHref = apiClient.getItemDownloadUrl(item.Id); + const book = epubjs(downloadHref, {openAs: 'epub'}); + const rendition = book.renderTo(elem, {width: '100%', height: '97%'}); this._currentSrc = downloadHref; this._rendition = rendition; - let cancellationToken = { + const cancellationToken = { shouldCancel: false }; this._cancellationToken = cancellationToken; return rendition.display().then(() => { - let epubElem = document.querySelector('.epub-container'); + const epubElem = document.querySelector('.epub-container'); epubElem.style.display = 'none'; this.bindEvents(); diff --git a/src/plugins/bookPlayer/tableOfContents.js b/src/plugins/bookPlayer/tableOfContents.js index 23e288aff5..a1c5d8f220 100644 --- a/src/plugins/bookPlayer/tableOfContents.js +++ b/src/plugins/bookPlayer/tableOfContents.js @@ -11,7 +11,7 @@ export default class TableOfContents { } destroy() { - let elem = this._elem; + const elem = this._elem; if (elem) { this.unbindEvents(); dialogHelper.close(elem); @@ -21,14 +21,14 @@ export default class TableOfContents { } bindEvents() { - let elem = this._elem; + const elem = this._elem; elem.addEventListener('close', this.onDialogClosed, {once: true}); elem.querySelector('.btnBookplayerTocClose').addEventListener('click', this.onDialogClosed, {once: true}); } unbindEvents() { - let elem = this._elem; + const elem = this._elem; elem.removeEventListener('close', this.onDialogClosed); elem.querySelector('.btnBookplayerTocClose').removeEventListener('click', this.onDialogClosed); @@ -39,10 +39,10 @@ export default class TableOfContents { } replaceLinks(contents, f) { - let links = contents.querySelectorAll('a[href]'); + const links = contents.querySelectorAll('a[href]'); links.forEach((link) => { - let href = link.getAttribute('href'); + const href = link.getAttribute('href'); link.onclick = () => { f(href); @@ -52,9 +52,9 @@ export default class TableOfContents { } createMediaElement() { - let rendition = this._rendition; + const rendition = this._rendition; - let elem = dialogHelper.createDialog({ + const elem = dialogHelper.createDialog({ size: 'small', autoFocus: false, removeOnClose: true @@ -69,7 +69,7 @@ export default class TableOfContents { rendition.book.navigation.forEach((chapter) => { tocHtml += '
  • '; // Remove '../' from href - let link = chapter.href.startsWith('../') ? chapter.href.substr(3) : chapter.href; + const link = chapter.href.startsWith('../') ? chapter.href.substr(3) : chapter.href; tocHtml += `${chapter.label}`; tocHtml += '
  • '; }); @@ -78,7 +78,7 @@ export default class TableOfContents { elem.innerHTML = tocHtml; this.replaceLinks(elem, (href) => { - let relative = rendition.book.path.relative(href); + const relative = rendition.book.path.relative(href); rendition.display(relative); this.destroy(); }); diff --git a/src/plugins/experimentalWarnings/plugin.js b/src/plugins/experimentalWarnings/plugin.js index c39612d45b..d97bd9a1a7 100644 --- a/src/plugins/experimentalWarnings/plugin.js +++ b/src/plugins/experimentalWarnings/plugin.js @@ -12,7 +12,7 @@ define(['connectionManager', 'globalize', 'userSettings', 'apphost'], function ( } function showMessage(text, userSettingsKey, appHostFeature) { - if (appHost.supports(appHostFeature)) { + if (appHost.default.supports(appHostFeature)) { return Promise.resolve(); } diff --git a/src/plugins/htmlAudioPlayer/plugin.js b/src/plugins/htmlAudioPlayer/plugin.js index 16fce8c9d1..f550e3dd0f 100644 --- a/src/plugins/htmlAudioPlayer/plugin.js +++ b/src/plugins/htmlAudioPlayer/plugin.js @@ -334,8 +334,8 @@ define(['events', 'browser', 'require', 'apphost', 'appSettings', 'htmlMediaHelp }; HtmlAudioPlayer.prototype.getDeviceProfile = function (item) { - if (appHost.getDeviceProfile) { - return appHost.getDeviceProfile(item); + if (appHost.default.getDeviceProfile) { + return appHost.default.getDeviceProfile(item); } return getDefaultProfile(); diff --git a/src/plugins/htmlVideoPlayer/plugin.js b/src/plugins/htmlVideoPlayer/plugin.js index d52f0eb5b3..40d8e57c45 100644 --- a/src/plugins/htmlVideoPlayer/plugin.js +++ b/src/plugins/htmlVideoPlayer/plugin.js @@ -105,7 +105,7 @@ function tryRemoveElement(elem) { } function hidePrePlaybackPage() { - let animatedPage = document.querySelector('.page:not(.hide)'); + const animatedPage = document.querySelector('.page:not(.hide)'); animatedPage.classList.add('hide'); // At this point, we must hide the scrollbar placeholder, so it's not being displayed while the item is being loaded document.body.classList.remove('force-scroll'); @@ -1288,7 +1288,7 @@ function tryRemoveElement(elem) { } let html = ''; - let cssClass = 'htmlvideoplayer'; + const cssClass = 'htmlvideoplayer'; // Can't autoplay in these browsers so we need to use the full controls, at least until playback starts if (!appHost.supports('htmlvideoautoplay')) { diff --git a/src/scripts/apploader.js b/src/scripts/apploader.js index 183b765d16..e5f85e1119 100644 --- a/src/scripts/apploader.js +++ b/src/scripts/apploader.js @@ -1,52 +1,48 @@ -(function() { - 'use strict'; +function injectScriptElement(src, onload) { + if (!src) { + return; + } - function injectScriptElement(src, onload) { - if (!src) { - return; + const script = document.createElement('script'); + if (self.dashboardVersion) { + src += `?v=${self.dashboardVersion}`; + } + script.src = src; + script.setAttribute('async', ''); + + if (onload) { + script.onload = onload; + } + + document.head.appendChild(script); +} + +function loadSite() { + injectScriptElement( + './libraries/alameda.js', + function() { + // onload of require library + injectScriptElement('./scripts/site.js'); } + ); +} - var script = document.createElement('script'); - if (self.dashboardVersion) { - src += `?v=${self.dashboardVersion}`; - } - script.src = src; - script.setAttribute('async', ''); +try { + Promise.resolve(); +} catch (ex) { + // this checks for several cases actually, typical is + // Promise() being missing on some legacy browser, and a funky one + // is Promise() present but buggy on WebOS 2 + window.Promise = undefined; + self.Promise = undefined; +} - if (onload) { - script.onload = onload; - } - - document.head.appendChild(script); - } - - function loadSite() { - injectScriptElement( - './libraries/alameda.js', - function() { - // onload of require library - injectScriptElement('./scripts/site.js'); - } - ); - } - - try { - Promise.resolve(); - } catch (ex) { - // this checks for several cases actually, typical is - // Promise() being missing on some legacy browser, and a funky one - // is Promise() present but buggy on WebOS 2 - window.Promise = undefined; - self.Promise = undefined; - } - - if (!self.Promise) { - // Load Promise polyfill if they are not natively supported - injectScriptElement( - './libraries/npo.js', - loadSite - ); - } else { - loadSite(); - } -})(); +if (!self.Promise) { + // Load Promise polyfill if they are not natively supported + injectScriptElement( + './libraries/npo.js', + loadSite + ); +} else { + loadSite(); +} diff --git a/src/scripts/deleteHelper.js b/src/scripts/deleteHelper.js index e10a1568c7..44876c75b3 100644 --- a/src/scripts/deleteHelper.js +++ b/src/scripts/deleteHelper.js @@ -15,7 +15,7 @@ export function deleteItem(options) { const item = options.item; const parentId = item.SeasonId || item.SeriesId || item.ParentId; - let apiClient = connectionManager.getApiClient(item.ServerId); + const apiClient = connectionManager.getApiClient(item.ServerId); return confirm({ @@ -34,7 +34,7 @@ export function deleteItem(options) { } } }, function (err) { - let result = function () { + const result = function () { return Promise.reject(err); }; diff --git a/src/scripts/gamepadtokey.js b/src/scripts/gamepadtokey.js index 870429ee09..20c01bdcba 100644 --- a/src/scripts/gamepadtokey.js +++ b/src/scripts/gamepadtokey.js @@ -187,7 +187,7 @@ require(['apphost'], function (appHost) { return false; } - if (appHost.getWindowState() === 'Minimized') { + if (appHost.default.getWindowState() === 'Minimized') { return false; } diff --git a/src/scripts/inputManager.js b/src/scripts/inputManager.js index 3432c9e351..9225d07f0a 100644 --- a/src/scripts/inputManager.js +++ b/src/scripts/inputManager.js @@ -39,7 +39,7 @@ import appHost from 'apphost'; dom.removeEventListener(scope, 'command', fn, {}); } - let commandTimes = {}; + const commandTimes = {}; function checkCommandTime(command) { const last = commandTimes[command] || 0; @@ -113,7 +113,7 @@ import appHost from 'apphost'; 'back': () => { if (appRouter.canGoBack()) { appRouter.back(); - } else if (appHost.supports('exit')) { + } else if (appHost.default.supports('exit')) { appHost.exit(); } }, diff --git a/src/scripts/libraryMenu.js b/src/scripts/libraryMenu.js index bbe01276ba..e7ce344301 100644 --- a/src/scripts/libraryMenu.js +++ b/src/scripts/libraryMenu.js @@ -277,7 +277,7 @@ define(['dom', 'layoutManager', 'inputManager', 'connectionManager', 'events', ' html += globalize.translate('HeaderUser'); html += ''; - if (appHost.supports('multiserver')) { + if (appHost.default.supports('multiserver')) { html += '' + globalize.translate('ButtonSelectServer') + ''; } @@ -589,7 +589,7 @@ define(['dom', 'layoutManager', 'inputManager', 'connectionManager', 'events', ' showBySelector('.lnkSyncToOtherDevices', false); } - if (user.Policy.EnableContentDownloading && appHost.supports('sync')) { + if (user.Policy.EnableContentDownloading && appHost.default.supports('sync')) { showBySelector('.libraryMenuDownloads', true); } else { showBySelector('.libraryMenuDownloads', false); diff --git a/src/scripts/site.js b/src/scripts/site.js index cd85c35e83..0879c11344 100644 --- a/src/scripts/site.js +++ b/src/scripts/site.js @@ -200,8 +200,8 @@ var Dashboard = { SupportsPersistentIdentifier: self.appMode === 'cordova' || self.appMode === 'android', SupportsMediaControl: true }; - appHost.getPushTokenInfo(); - return capabilities = Object.assign(capabilities, appHost.getPushTokenInfo()); + appHost.default.getPushTokenInfo(); + return capabilities = Object.assign(capabilities, appHost.default.getPushTokenInfo()); }, selectServer: function () { if (window.NativeShell && typeof window.NativeShell.selectServer === 'function') { @@ -271,17 +271,17 @@ function initClient() { } function createConnectionManager() { - return require(['connectionManagerFactory', 'apphost', 'credentialprovider', 'events', 'userSettings'], function (ConnectionManager, apphost, credentialProvider, events, userSettings) { + return require(['connectionManagerFactory', 'apphost', 'credentialprovider', 'events', 'userSettings'], function (ConnectionManager, appHost, credentialProvider, events, userSettings) { var credentialProviderInstance = new credentialProvider(); - var promises = [apphost.getSyncProfile(), apphost.init()]; + var promises = [appHost.default.getSyncProfile(), appHost.default.init()]; return Promise.all(promises).then(function (responses) { var deviceProfile = responses[0]; - var capabilities = Dashboard.capabilities(apphost); + var capabilities = Dashboard.capabilities(appHost); capabilities.DeviceProfile = deviceProfile; - var connectionManager = new ConnectionManager(credentialProviderInstance, apphost.appName(), apphost.appVersion(), apphost.deviceName(), apphost.deviceId(), capabilities); + var connectionManager = new ConnectionManager(credentialProviderInstance, appHost.default.appName(), appHost.default.appVersion(), appHost.default.deviceName(), appHost.default.deviceId(), capabilities); defineConnectionManager(connectionManager); bindConnectionManagerEvents(connectionManager, events, userSettings); @@ -292,7 +292,7 @@ function initClient() { return require(['apiclient'], function (apiClientFactory) { console.debug('creating ApiClient singleton'); - var apiClient = new apiClientFactory(Dashboard.serverAddress(), apphost.appName(), apphost.appVersion(), apphost.deviceName(), apphost.deviceId()); + var apiClient = new apiClientFactory(Dashboard.serverAddress(), appHost.default.appName(), appHost.default.appVersion(), appHost.default.deviceName(), appHost.default.deviceId()); apiClient.enableAutomaticNetworking = false; apiClient.manualAddressOnly = true; @@ -350,8 +350,8 @@ function initClient() { } function getLayoutManager(layoutManager, appHost) { - if (appHost.getDefaultLayout) { - layoutManager.defaultLayout = appHost.getDefaultLayout(); + if (appHost.default.getDefaultLayout) { + layoutManager.defaultLayout = appHost.default.getDefaultLayout(); } layoutManager.init(); @@ -538,13 +538,13 @@ function initClient() { require(['components/nowPlayingBar/nowPlayingBar']); } - if (appHost.supports('remotecontrol')) { + if (appHost.default.supports('remotecontrol')) { require(['playerSelectionMenu', 'components/playback/remotecontrolautoplay']); } require(['libraries/screensavermanager']); - if (!appHost.supports('physicalvolumecontrol') || browser.touch) { + if (!appHost.default.supports('physicalvolumecontrol') || browser.touch) { require(['components/playback/volumeosd']); } From 8f098dc26dd1d284dd0f2187fd8d8cfefe26b1c5 Mon Sep 17 00:00:00 2001 From: MrTimscampi Date: Fri, 17 Jul 2020 10:33:31 +0200 Subject: [PATCH 050/301] Fix linting errors --- src/components/dialogHelper/dialogHelper.js | 7 ++-- src/components/remotecontrol/remotecontrol.js | 4 +++ .../subtitleappearancehelper.js | 6 ++-- .../subtitlesettings/subtitlesettings.js | 34 +++++++++---------- src/elements/emby-checkbox/emby-checkbox.js | 4 +-- .../emby-itemrefreshindicator.js | 2 +- .../emby-progressbar/emby-progressbar.js | 2 +- .../emby-progressring/emby-progressring.js | 4 +-- src/elements/emby-radio/emby-radio.js | 6 ++-- src/elements/emby-scroller/emby-scroller.js | 2 +- src/elements/emby-slider/emby-slider.js | 4 +-- src/elements/emby-tabs/emby-tabs.js | 8 ++--- 12 files changed, 42 insertions(+), 41 deletions(-) diff --git a/src/components/dialogHelper/dialogHelper.js b/src/components/dialogHelper/dialogHelper.js index 1f11d8a195..2b682dd71a 100644 --- a/src/components/dialogHelper/dialogHelper.js +++ b/src/components/dialogHelper/dialogHelper.js @@ -391,11 +391,8 @@ import 'scrollStyles'; dlg.setAttribute('data-autofocus', 'true'); } - let defaultEntryAnimation; - let defaultExitAnimation; - - defaultEntryAnimation = 'scaleup'; - defaultExitAnimation = 'scaledown'; + const defaultEntryAnimation = 'scaleup'; + const defaultExitAnimation = 'scaledown'; const entryAnimation = options.entryAnimation || defaultEntryAnimation; const exitAnimation = options.exitAnimation || defaultExitAnimation; diff --git a/src/components/remotecontrol/remotecontrol.js b/src/components/remotecontrol/remotecontrol.js index 8668202424..fd5a6902ab 100644 --- a/src/components/remotecontrol/remotecontrol.js +++ b/src/components/remotecontrol/remotecontrol.js @@ -873,6 +873,10 @@ define(['browser', 'datetime', 'backdrop', 'libraryBrowser', 'listView', 'imageL } function init(ownerView, context) { +<<<<<<< HEAD +======= + const contextmenuHtml = ``; +>>>>>>> 4f0443b2d... Fix linting errors let volumecontrolHtml = '
    '; volumecontrolHtml += ``; volumecontrolHtml += '
    '; diff --git a/src/components/subtitlesettings/subtitleappearancehelper.js b/src/components/subtitlesettings/subtitleappearancehelper.js index 7e3e2de7ac..fab1d6a9f7 100644 --- a/src/components/subtitlesettings/subtitleappearancehelper.js +++ b/src/components/subtitlesettings/subtitleappearancehelper.js @@ -4,7 +4,7 @@ */ function getTextStyles(settings, isCue) { - let list = []; + const list = []; if (isCue) { switch (settings.textSize || '') { @@ -123,14 +123,14 @@ export function getStyles(settings, isCue) { function applyStyleList(styles, elem) { for (let i = 0, length = styles.length; i < length; i++) { - let style = styles[i]; + const style = styles[i]; elem.style[style.name] = style.value; } } export function applyStyles(elements, appearanceSettings) { - let styles = getStyles(appearanceSettings); + const styles = getStyles(appearanceSettings); if (elements.text) { applyStyleList(styles.text, elements.text); diff --git a/src/components/subtitlesettings/subtitlesettings.js b/src/components/subtitlesettings/subtitlesettings.js index 79fa289ab0..1621c0ea2c 100644 --- a/src/components/subtitlesettings/subtitlesettings.js +++ b/src/components/subtitlesettings/subtitlesettings.js @@ -20,7 +20,7 @@ import 'flexStyles'; */ function getSubtitleAppearanceObject(context) { - let appearanceSettings = {}; + const appearanceSettings = {}; appearanceSettings.textSize = context.querySelector('#selectTextSize').value; appearanceSettings.dropShadow = context.querySelector('#selectDropShadow').value; @@ -37,7 +37,7 @@ function loadForm(context, user, userSettings, appearanceSettings, apiClient) { context.querySelector('.fldBurnIn').classList.remove('hide'); } - let selectSubtitleLanguage = context.querySelector('#selectSubtitleLanguage'); + const selectSubtitleLanguage = context.querySelector('#selectSubtitleLanguage'); settingsHelper.populateLanguages(selectSubtitleLanguage, allCultures); @@ -96,9 +96,9 @@ function save(instance, context, userId, userSettings, apiClient, enableSaveConf } function onSubtitleModeChange(e) { - let view = dom.parentWithClass(e.target, 'subtitlesettings'); + const view = dom.parentWithClass(e.target, 'subtitlesettings'); - let subtitlesHelp = view.querySelectorAll('.subtitlesHelp'); + const subtitlesHelp = view.querySelectorAll('.subtitlesHelp'); for (let i = 0, length = subtitlesHelp.length; i < length; i++) { subtitlesHelp[i].classList.add('hide'); } @@ -106,11 +106,11 @@ function onSubtitleModeChange(e) { } function onAppearanceFieldChange(e) { - let view = dom.parentWithClass(e.target, 'subtitlesettings'); + const view = dom.parentWithClass(e.target, 'subtitlesettings'); - let appearanceSettings = getSubtitleAppearanceObject(view); + const appearanceSettings = getSubtitleAppearanceObject(view); - let elements = { + const elements = { window: view.querySelector('.subtitleappearance-preview-window'), text: view.querySelector('.subtitleappearance-preview-text') }; @@ -156,20 +156,20 @@ export class SubtitleSettings { } loadData() { - let self = this; - let context = self.options.element; + const self = this; + const context = self.options.element; loading.show(); - let userId = self.options.userId; - let apiClient = connectionManager.getApiClient(self.options.serverId); - let userSettings = self.options.userSettings; + const userId = self.options.userId; + const apiClient = connectionManager.getApiClient(self.options.serverId); + const userSettings = self.options.userSettings; apiClient.getUser(userId).then(function (user) { userSettings.setUserInfo(userId, apiClient).then(function () { self.dataLoaded = true; - let appearanceSettings = userSettings.getSubtitleAppearanceSettings(self.options.appearanceKey); + const appearanceSettings = userSettings.getSubtitleAppearanceSettings(self.options.appearanceKey); loadForm(context, user, userSettings, appearanceSettings, apiClient); }); @@ -186,12 +186,12 @@ export class SubtitleSettings { onSubmit(e) { const self = this; - let apiClient = connectionManager.getApiClient(self.options.serverId); - let userId = self.options.userId; - let userSettings = self.options.userSettings; + const apiClient = connectionManager.getApiClient(self.options.serverId); + const userId = self.options.userId; + const userSettings = self.options.userSettings; userSettings.setUserInfo(userId, apiClient).then(function () { - let enableSaveConfirmation = self.options.enableSaveConfirmation; + const enableSaveConfirmation = self.options.enableSaveConfirmation; save(self, self.options.element, userId, userSettings, apiClient, enableSaveConfirmation); }); diff --git a/src/elements/emby-checkbox/emby-checkbox.js b/src/elements/emby-checkbox/emby-checkbox.js index d3f24d6f82..84961848c6 100644 --- a/src/elements/emby-checkbox/emby-checkbox.js +++ b/src/elements/emby-checkbox/emby-checkbox.js @@ -5,7 +5,7 @@ import 'webcomponents'; /* eslint-disable indent */ - let EmbyCheckboxPrototype = Object.create(HTMLInputElement.prototype); + const EmbyCheckboxPrototype = Object.create(HTMLInputElement.prototype); function onKeyDown(e) { // Don't submit form on enter @@ -26,7 +26,7 @@ import 'webcomponents'; const enableRefreshHack = browser.tizen || browser.orsay || browser.operaTv || browser.web0s ? true : false; function forceRefresh(loading) { - let elem = this.parentNode; + const elem = this.parentNode; elem.style.webkitAnimationName = 'repaintChrome'; elem.style.webkitAnimationDelay = (loading === true ? '500ms' : ''); diff --git a/src/elements/emby-itemrefreshindicator/emby-itemrefreshindicator.js b/src/elements/emby-itemrefreshindicator/emby-itemrefreshindicator.js index 67eacf3db9..51f3fc5be9 100644 --- a/src/elements/emby-itemrefreshindicator/emby-itemrefreshindicator.js +++ b/src/elements/emby-itemrefreshindicator/emby-itemrefreshindicator.js @@ -40,7 +40,7 @@ import 'webcomponents'; } } - let EmbyItemRefreshIndicatorPrototype = Object.create(EmbyProgressRing); + const EmbyItemRefreshIndicatorPrototype = Object.create(EmbyProgressRing); EmbyItemRefreshIndicatorPrototype.createdCallback = function () { // base method diff --git a/src/elements/emby-progressbar/emby-progressbar.js b/src/elements/emby-progressbar/emby-progressbar.js index 54fcb1999e..e232bbcde0 100644 --- a/src/elements/emby-progressbar/emby-progressbar.js +++ b/src/elements/emby-progressbar/emby-progressbar.js @@ -1,6 +1,6 @@ /* eslint-disable indent */ - let ProgressBarPrototype = Object.create(HTMLDivElement.prototype); + const ProgressBarPrototype = Object.create(HTMLDivElement.prototype); function onAutoTimeProgress() { const start = parseInt(this.getAttribute('data-starttime')); diff --git a/src/elements/emby-progressring/emby-progressring.js b/src/elements/emby-progressring/emby-progressring.js index 10db8b9a27..929b80a573 100644 --- a/src/elements/emby-progressring/emby-progressring.js +++ b/src/elements/emby-progressring/emby-progressring.js @@ -3,7 +3,7 @@ import 'webcomponents'; /* eslint-disable indent */ - let EmbyProgressRing = Object.create(HTMLDivElement.prototype); + const EmbyProgressRing = Object.create(HTMLDivElement.prototype); EmbyProgressRing.createdCallback = function () { this.classList.add('progressring'); @@ -79,7 +79,7 @@ import 'webcomponents'; }; EmbyProgressRing.detachedCallback = function () { - let observer = this.observer; + const observer = this.observer; if (observer) { // later, you can stop observing diff --git a/src/elements/emby-radio/emby-radio.js b/src/elements/emby-radio/emby-radio.js index b31d436444..6fd2529085 100644 --- a/src/elements/emby-radio/emby-radio.js +++ b/src/elements/emby-radio/emby-radio.js @@ -4,7 +4,7 @@ import 'webcomponents'; /* eslint-disable indent */ - let EmbyRadioPrototype = Object.create(HTMLInputElement.prototype); + const EmbyRadioPrototype = Object.create(HTMLInputElement.prototype); function onKeyDown(e) { // Don't submit form on enter @@ -35,7 +35,7 @@ import 'webcomponents'; this.classList.add('mdl-radio__button'); - let labelElement = this.parentNode; + const labelElement = this.parentNode; labelElement.classList.add('mdl-radio'); labelElement.classList.add('mdl-js-radio'); labelElement.classList.add('mdl-js-ripple-effect'); @@ -43,7 +43,7 @@ import 'webcomponents'; labelElement.classList.add('show-focus'); } - let labelTextElement = labelElement.querySelector('span'); + const labelTextElement = labelElement.querySelector('span'); labelTextElement.classList.add('radioButtonLabel'); labelTextElement.classList.add('mdl-radio__label'); diff --git a/src/elements/emby-scroller/emby-scroller.js b/src/elements/emby-scroller/emby-scroller.js index fb903d839c..d7133e317a 100644 --- a/src/elements/emby-scroller/emby-scroller.js +++ b/src/elements/emby-scroller/emby-scroller.js @@ -9,7 +9,7 @@ import 'css!./emby-scroller'; /* eslint-disable indent */ - let ScrollerPrototype = Object.create(HTMLDivElement.prototype); + const ScrollerPrototype = Object.create(HTMLDivElement.prototype); ScrollerPrototype.createdCallback = function () { this.classList.add('emby-scroller'); diff --git a/src/elements/emby-slider/emby-slider.js b/src/elements/emby-slider/emby-slider.js index 2439331144..9b451044b4 100644 --- a/src/elements/emby-slider/emby-slider.js +++ b/src/elements/emby-slider/emby-slider.js @@ -8,7 +8,7 @@ import 'emby-input'; /* eslint-disable indent */ - let EmbySliderPrototype = Object.create(HTMLInputElement.prototype); + const EmbySliderPrototype = Object.create(HTMLInputElement.prototype); let supportsValueSetOverride = false; @@ -94,7 +94,7 @@ import 'emby-input'; // Keep only one per slider frame request cancelAnimationFrame(range.updateValuesFrame); range.updateValuesFrame = requestAnimationFrame(function () { - let backgroundLower = range.backgroundLower; + const backgroundLower = range.backgroundLower; if (backgroundLower) { let fraction = (value - range.min) / (range.max - range.min); diff --git a/src/elements/emby-tabs/emby-tabs.js b/src/elements/emby-tabs/emby-tabs.js index 320a14e2cb..db7ad56f5d 100644 --- a/src/elements/emby-tabs/emby-tabs.js +++ b/src/elements/emby-tabs/emby-tabs.js @@ -8,7 +8,7 @@ import 'scrollStyles'; /* eslint-disable indent */ - let EmbyTabs = Object.create(HTMLDivElement.prototype); + const EmbyTabs = Object.create(HTMLDivElement.prototype); const buttonClass = 'emby-tab-button'; const activeButtonClass = buttonClass + '-active'; @@ -21,7 +21,7 @@ import 'scrollStyles'; } function removeActivePanelClass(tabs, index) { - let tabPanel = getTabPanel(tabs, index); + const tabPanel = getTabPanel(tabs, index); if (tabPanel) { tabPanel.classList.remove('is-active'); } @@ -52,7 +52,7 @@ import 'scrollStyles'; removeActivePanelClass(tabs, previousIndex); } - let newPanel = getTabPanel(tabs, index); + const newPanel = getTabPanel(tabs, index); if (newPanel) { // animate new panel ? @@ -225,7 +225,7 @@ import 'scrollStyles'; } })); - let currentTabButton = tabButtons[current]; + const currentTabButton = tabButtons[current]; setActiveTabButton(tabs, tabButtons[selected], currentTabButton, false); if (current !== selected && currentTabButton) { From 9675bd57b803cedfb911e68c86fa221ae2d02931 Mon Sep 17 00:00:00 2001 From: Julien Machiels Date: Sun, 19 Jul 2020 17:20:00 +0200 Subject: [PATCH 051/301] Update src/components/apphost.js Co-authored-by: Cameron --- src/components/apphost.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/components/apphost.js b/src/components/apphost.js index 90ae418de6..060d56832a 100644 --- a/src/components/apphost.js +++ b/src/components/apphost.js @@ -1,7 +1,7 @@ import appSettings from 'appSettings'; import browser from 'browser'; import events from 'events'; -import htmlMediaHelper from 'htmlMediaHelper'; +import * as htmlMediaHelper from 'htmlMediaHelper'; import * as webSettings from 'webSettings'; import globalize from 'globalize'; From a7df7ad720e6fd0f62676a2ad8cda76f470214f5 Mon Sep 17 00:00:00 2001 From: MrTimscampi Date: Sun, 19 Jul 2020 17:38:42 +0200 Subject: [PATCH 052/301] Fix appHost.supports --- src/bundle.js | 6 ----- src/components/itemContextMenu.js | 4 ++-- .../metadataEditor/metadataEditor.js | 2 +- src/components/nowPlayingBar/nowPlayingBar.js | 18 +++++++-------- src/components/qualityOptions.js | 6 ----- src/components/remotecontrol/remotecontrol.js | 22 ++++++++----------- .../subtitlesettings/subtitlesettings.js | 2 +- src/controllers/dashboard/dashboard.js | 2 +- src/controllers/dashboard/devices/devices.js | 2 +- src/controllers/dashboard/dlna/profile.js | 6 ++--- src/controllers/dashboard/dlna/profiles.js | 2 +- .../dashboard/scheduledtasks/scheduledtask.js | 6 ++--- .../scheduledtasks/scheduledtasks.js | 6 ++--- src/controllers/itemDetails/index.js | 2 +- src/controllers/playback/video/index.js | 6 ++--- .../emby-itemscontainer.js | 10 ++++----- .../emby-playstatebutton.js | 2 +- .../emby-scrollbuttons/emby-scrollbuttons.js | 4 ++-- src/scripts/datetime.js | 2 +- src/scripts/globalize.js | 4 ++-- 20 files changed, 48 insertions(+), 66 deletions(-) diff --git a/src/bundle.js b/src/bundle.js index 86ebb1ccdf..5a7ffed075 100644 --- a/src/bundle.js +++ b/src/bundle.js @@ -78,12 +78,6 @@ _define('webcomponents', function() { return webcomponents; }); -// shaka -const shaka = require('shaka-player'); -_define('shaka', function() { - return shaka; -}); - // libass-wasm const libassWasm = require('libass-wasm'); _define('JavascriptSubtitlesOctopus', function() { diff --git a/src/components/itemContextMenu.js b/src/components/itemContextMenu.js index 3471057139..5f4906fd88 100644 --- a/src/components/itemContextMenu.js +++ b/src/components/itemContextMenu.js @@ -16,7 +16,7 @@ import actionsheet from 'actionsheet'; const canPlay = playbackManager.canPlay(item); const restrictOptions = (browser.operaTv || browser.web0s) && !user.Policy.IsAdministrator; - let commands = []; + const commands = []; if (canPlay && item.MediaType !== 'Photo') { if (options.play !== false) { @@ -367,7 +367,7 @@ import actionsheet from 'actionsheet'; case 'copy-stream': { const downloadHref = apiClient.getItemDownloadUrl(itemId); const textAreaCopy = function () { - let textArea = document.createElement('textarea'); + const textArea = document.createElement('textarea'); textArea.value = downloadHref; document.body.appendChild(textArea); textArea.focus(); diff --git a/src/components/metadataEditor/metadataEditor.js b/src/components/metadataEditor/metadataEditor.js index be44e86b44..0acf55e646 100644 --- a/src/components/metadataEditor/metadataEditor.js +++ b/src/components/metadataEditor/metadataEditor.js @@ -907,7 +907,7 @@ import 'flexStyles'; } function populatePeople(context, people) { - let lastType = ''; + const lastType = ''; let html = ''; const elem = context.querySelector('#peopleList'); diff --git a/src/components/nowPlayingBar/nowPlayingBar.js b/src/components/nowPlayingBar/nowPlayingBar.js index aeba8fedf9..efd09fcba3 100644 --- a/src/components/nowPlayingBar/nowPlayingBar.js +++ b/src/components/nowPlayingBar/nowPlayingBar.js @@ -500,20 +500,20 @@ import 'emby-ratingbutton'; const textLines = nowPlayingItem ? nowPlayingHelper.getNowPlayingNames(nowPlayingItem) : []; nowPlayingTextElement.innerHTML = ''; if (textLines) { - let itemText = document.createElement('div'); - let secondaryText = document.createElement('div'); + const itemText = document.createElement('div'); + const secondaryText = document.createElement('div'); secondaryText.classList.add('nowPlayingBarSecondaryText'); if (textLines.length > 1) { textLines[1].secondary = true; if (textLines[1].text) { - let text = document.createElement('a'); + const text = document.createElement('a'); text.innerHTML = textLines[1].text; secondaryText.appendChild(text); } } if (textLines[0].text) { - let text = document.createElement('a'); + const text = document.createElement('a'); text.innerHTML = textLines[0].text; itemText.appendChild(text); } @@ -555,10 +555,10 @@ import 'emby-ratingbutton'; if (!layoutManager.mobile) { let contextButton = nowPlayingBarElement.querySelector('.btnToggleContextMenu'); // We remove the previous event listener by replacing the item in each update event - let contextButtonClone = contextButton.cloneNode(true); + const contextButtonClone = contextButton.cloneNode(true); contextButton.parentNode.replaceChild(contextButtonClone, contextButton); contextButton = nowPlayingBarElement.querySelector('.btnToggleContextMenu'); - let options = { + const options = { play: false, queue: false, clearQueue: true, @@ -600,10 +600,10 @@ import 'emby-ratingbutton'; return; } - let shuffleMode = playbackManager.getQueueShuffleMode(); - let context = nowPlayingBarElement; + const shuffleMode = playbackManager.getQueueShuffleMode(); + const context = nowPlayingBarElement; const cssClass = 'buttonActive'; - let toggleShuffleButton = context.querySelector('.btnShuffleQueue'); + const toggleShuffleButton = context.querySelector('.btnShuffleQueue'); switch (shuffleMode) { case 'Shuffle': toggleShuffleButton.classList.add(cssClass); diff --git a/src/components/qualityOptions.js b/src/components/qualityOptions.js index d6bced83f7..ff6b04d1f1 100644 --- a/src/components/qualityOptions.js +++ b/src/components/qualityOptions.js @@ -1,7 +1,6 @@ import globalize from 'globalize'; export function getVideoQualityOptions(options) { - var maxStreamingBitrate = options.currentMaxBitrate; var videoWidth = options.videoWidth; var videoHeight = options.videoHeight; @@ -25,7 +24,6 @@ export function getVideoQualityOptions(options) { // Some 1080- videos are reported as 1912? if (maxAllowedWidth >= 1900) { - qualityOptions.push({ name: '1080p - 60 Mbps', maxHeight: 1080, bitrate: 60000000 }); qualityOptions.push({ name: '1080p - 50 Mbps', maxHeight: 1080, bitrate: 50000000 }); qualityOptions.push({ name: '1080p - 40 Mbps', maxHeight: 1080, bitrate: 40000000 }); @@ -38,13 +36,11 @@ export function getVideoQualityOptions(options) { qualityOptions.push({ name: '1080p - 6 Mbps', maxHeight: 1080, bitrate: 6000001 }); qualityOptions.push({ name: '1080p - 5 Mbps', maxHeight: 1080, bitrate: 5000001 }); qualityOptions.push({ name: '1080p - 4 Mbps', maxHeight: 1080, bitrate: 4000002 }); - } else if (maxAllowedWidth >= 1260) { qualityOptions.push({ name: '720p - 10 Mbps', maxHeight: 720, bitrate: 10000000 }); qualityOptions.push({ name: '720p - 8 Mbps', maxHeight: 720, bitrate: 8000000 }); qualityOptions.push({ name: '720p - 6 Mbps', maxHeight: 720, bitrate: 6000000 }); qualityOptions.push({ name: '720p - 5 Mbps', maxHeight: 720, bitrate: 5000000 }); - } else if (maxAllowedWidth >= 620) { qualityOptions.push({ name: '480p - 4 Mbps', maxHeight: 480, bitrate: 4000001 }); qualityOptions.push({ name: '480p - 3 Mbps', maxHeight: 480, bitrate: 3000001 }); @@ -83,7 +79,6 @@ export function getVideoQualityOptions(options) { if (maxStreamingBitrate) { var selectedIndex = -1; for (var i = 0, length = qualityOptions.length; i < length; i++) { - var option = qualityOptions[i]; if (selectedIndex === -1 && option.bitrate <= maxStreamingBitrate) { @@ -143,7 +138,6 @@ export function getAudioQualityOptions(options) { } if (selectedIndex === -1) { - selectedIndex = qualityOptions.length - 1; } diff --git a/src/components/remotecontrol/remotecontrol.js b/src/components/remotecontrol/remotecontrol.js index fd5a6902ab..e9df5e6a09 100644 --- a/src/components/remotecontrol/remotecontrol.js +++ b/src/components/remotecontrol/remotecontrol.js @@ -127,8 +127,8 @@ define(['browser', 'datetime', 'backdrop', 'libraryBrowser', 'listView', 'imageL if (item.Artists != null) { if (item.ArtistItems != null) { for (const artist of item.ArtistItems) { - let artistName = artist.Name; - let artistId = artist.Id; + const artistName = artist.Name; + const artistId = artist.Id; artistsSeries += `${artistName}`; if (artist !== item.ArtistItems.slice(-1)[0]) { artistsSeries += ', '; @@ -185,7 +185,7 @@ define(['browser', 'datetime', 'backdrop', 'libraryBrowser', 'listView', 'imageL let contextButton = context.querySelector('.btnToggleContextMenu'); // We remove the previous event listener by replacing the item in each update event const autoFocusContextButton = document.activeElement === contextButton; - let contextButtonClone = contextButton.cloneNode(true); + const contextButtonClone = contextButton.cloneNode(true); contextButton.parentNode.replaceChild(contextButtonClone, contextButton); contextButton = context.querySelector('.btnToggleContextMenu'); if (autoFocusContextButton) { @@ -362,7 +362,7 @@ define(['browser', 'datetime', 'backdrop', 'libraryBrowser', 'listView', 'imageL function updateRepeatModeDisplay(repeatMode) { var context = dlg; - let toggleRepeatButtons = context.querySelectorAll('.repeatToggleButton'); + const toggleRepeatButtons = context.querySelectorAll('.repeatToggleButton'); const cssClass = 'buttonActive'; let innHtml = ''; let repeatOn = true; @@ -529,12 +529,12 @@ define(['browser', 'datetime', 'backdrop', 'libraryBrowser', 'listView', 'imageL } function onShuffleQueueModeChange(updateView = true) { - let shuffleMode = playbackManager.getQueueShuffleMode(this); - let context = dlg; + const shuffleMode = playbackManager.getQueueShuffleMode(this); + const context = dlg; const cssClass = 'buttonActive'; - let shuffleButtons = context.querySelectorAll('.btnShuffleQueue'); + const shuffleButtons = context.querySelectorAll('.btnShuffleQueue'); - for (let shuffleButton of shuffleButtons) { + for (const shuffleButton of shuffleButtons) { switch (shuffleMode) { case 'Shuffle': shuffleButton.classList.add(cssClass); @@ -873,15 +873,11 @@ define(['browser', 'datetime', 'backdrop', 'libraryBrowser', 'listView', 'imageL } function init(ownerView, context) { -<<<<<<< HEAD -======= - const contextmenuHtml = ``; ->>>>>>> 4f0443b2d... Fix linting errors let volumecontrolHtml = '
    '; volumecontrolHtml += ``; volumecontrolHtml += '
    '; volumecontrolHtml += '
    '; - let optionsSection = context.querySelector('.playlistSectionButton'); + const optionsSection = context.querySelector('.playlistSectionButton'); if (!layoutManager.mobile) { context.querySelector('.nowPlayingSecondaryButtons').insertAdjacentHTML('beforeend', volumecontrolHtml); optionsSection.classList.remove('align-items-center', 'justify-content-center'); diff --git a/src/components/subtitlesettings/subtitlesettings.js b/src/components/subtitlesettings/subtitlesettings.js index 1621c0ea2c..3569e114fa 100644 --- a/src/components/subtitlesettings/subtitlesettings.js +++ b/src/components/subtitlesettings/subtitlesettings.js @@ -136,7 +136,7 @@ function embed(options, self) { options.element.querySelector('.btnSave').classList.remove('hide'); } - if (appHost.supports('subtitleappearancesettings')) { + if (appHost.default.supports('subtitleappearancesettings')) { options.element.querySelector('.subtitleAppearanceSection').classList.remove('hide'); } diff --git a/src/controllers/dashboard/dashboard.js b/src/controllers/dashboard/dashboard.js index 61fc345382..a36aa3ce68 100644 --- a/src/controllers/dashboard/dashboard.js +++ b/src/controllers/dashboard/dashboard.js @@ -24,7 +24,7 @@ import 'emby-itemscontainer'; function showPlaybackInfo(btn, session) { import('alert').then(({default: alert}) => { let title; - let text = []; + const text = []; const displayPlayMethod = playMethodHelper.getDisplayPlayMethod(session); if (displayPlayMethod === 'DirectStream') { diff --git a/src/controllers/dashboard/devices/devices.js b/src/controllers/dashboard/devices/devices.js index 93ae62c43f..bc9dd19764 100644 --- a/src/controllers/dashboard/devices/devices.js +++ b/src/controllers/dashboard/devices/devices.js @@ -38,7 +38,7 @@ import 'cardStyle'; } function showDeviceMenu(view, btn, deviceId) { - let menuItems = []; + const menuItems = []; if (canEdit) { menuItems.push({ diff --git a/src/controllers/dashboard/dlna/profile.js b/src/controllers/dashboard/dlna/profile.js index 17dc9f78cb..85cb399662 100644 --- a/src/controllers/dashboard/dlna/profile.js +++ b/src/controllers/dashboard/dlna/profile.js @@ -315,7 +315,7 @@ import 'listViewStyle'; let currentType; for (let i = 0, length = profiles.length; i < length; i++) { - let profile = profiles[i]; + const profile = profiles[i]; if (profile.Type !== currentType) { html += '
  • ' + profile.Type + '
  • '; @@ -401,7 +401,7 @@ import 'listViewStyle'; let currentType; for (let i = 0, length = profiles.length; i < length; i++) { - let profile = profiles[i]; + const profile = profiles[i]; if (profile.Type !== currentType) { html += '
  • ' + profile.Type + '
  • '; @@ -472,7 +472,7 @@ import 'listViewStyle'; let currentType; for (let i = 0, length = profiles.length; i < length; i++) { - let profile = profiles[i]; + const profile = profiles[i]; const type = profile.Type.replace('VideoAudio', 'Video Audio'); if (type !== currentType) { diff --git a/src/controllers/dashboard/dlna/profiles.js b/src/controllers/dashboard/dlna/profiles.js index 7fd3bdb525..f1d57eef3c 100644 --- a/src/controllers/dashboard/dlna/profiles.js +++ b/src/controllers/dashboard/dlna/profiles.js @@ -36,7 +36,7 @@ import 'emby-button'; } for (let i = 0, length = profiles.length; i < length; i++) { - let profile = profiles[i]; + const profile = profiles[i]; html += '
    '; html += ''; html += '
    '; diff --git a/src/controllers/dashboard/scheduledtasks/scheduledtask.js b/src/controllers/dashboard/scheduledtasks/scheduledtask.js index 7944eb8a60..0bf0fc5c3c 100644 --- a/src/controllers/dashboard/scheduledtasks/scheduledtask.js +++ b/src/controllers/dashboard/scheduledtasks/scheduledtask.js @@ -33,7 +33,7 @@ import 'emby-select'; const ScheduledTaskPage = { refreshScheduledTask: function (view) { loading.show(); - let id = getParameterByName('id'); + const id = getParameterByName('id'); ApiClient.getScheduledTask(id).then(function (task) { ScheduledTaskPage.loadScheduledTask(view, task); }); @@ -143,7 +143,7 @@ import 'emby-select'; }, deleteTrigger: function (view, index) { loading.show(); - let id = getParameterByName('id'); + const id = getParameterByName('id'); ApiClient.getScheduledTask(id).then(function (task) { task.Triggers.remove(index); ApiClient.updateScheduledTaskTriggers(task.Id, task.Triggers).then(function () { @@ -211,7 +211,7 @@ import 'emby-select'; export default function (view, params) { function onSubmit(e) { loading.show(); - let id = getParameterByName('id'); + const id = getParameterByName('id'); ApiClient.getScheduledTask(id).then(function (task) { task.Triggers.push(ScheduledTaskPage.getTriggerToAdd(view)); ApiClient.updateScheduledTaskTriggers(task.Id, task.Triggers).then(function () { diff --git a/src/controllers/dashboard/scheduledtasks/scheduledtasks.js b/src/controllers/dashboard/scheduledtasks/scheduledtasks.js index af96f34c15..81a34d4fa6 100644 --- a/src/controllers/dashboard/scheduledtasks/scheduledtasks.js +++ b/src/controllers/dashboard/scheduledtasks/scheduledtasks.js @@ -103,7 +103,7 @@ import 'emby-button'; } function setTaskButtonIcon(button, icon) { - let inner = button.querySelector('.material-icons'); + const inner = button.querySelector('.material-icons'); inner.classList.remove('stop', 'play_arrow'); inner.classList.add(icon); } @@ -160,7 +160,7 @@ import 'emby-button'; $('.divScheduledTasks', view).on('click', '.btnStartTask', function() { const button = this; - let id = button.getAttribute('data-taskid'); + const id = button.getAttribute('data-taskid'); ApiClient.startScheduledTask(id).then(function() { updateTaskButton(button, 'Running'); reloadList(view); @@ -169,7 +169,7 @@ import 'emby-button'; $('.divScheduledTasks', view).on('click', '.btnStopTask', function() { const button = this; - let id = button.getAttribute('data-taskid'); + const id = button.getAttribute('data-taskid'); ApiClient.stopScheduledTask(id).then(function() { updateTaskButton(button, ''); reloadList(view); diff --git a/src/controllers/itemDetails/index.js b/src/controllers/itemDetails/index.js index df2855d69a..d42eb37701 100644 --- a/src/controllers/itemDetails/index.js +++ b/src/controllers/itemDetails/index.js @@ -373,7 +373,7 @@ import 'emby-select'; } function getArtistLinksHtml(artists, serverId, context) { - let html = []; + const html = []; for (const artist of artists) { const href = appRouter.getRouteUrl(artist, { diff --git a/src/controllers/playback/video/index.js b/src/controllers/playback/video/index.js index 2129061a35..c1c311a226 100644 --- a/src/controllers/playback/video/index.js +++ b/src/controllers/playback/video/index.js @@ -172,9 +172,7 @@ import 'css!assets/css/videoosd'; } setTitle(displayItem, parentName); - let titleElement; - const osdTitle = view.querySelector('.osdTitle'); - titleElement = osdTitle; + const titleElement = view.querySelector('.osdTitle'); let displayName = itemHelper.getDisplayName(displayItem, { includeParentInfo: displayItem.Type !== 'Program', includeIndexNumber: displayItem.Type !== 'Program' @@ -1619,7 +1617,7 @@ import 'css!assets/css/videoosd'; const item = currentItem; if (item && item.Chapters && item.Chapters.length && item.Chapters[0].ImageTag) { - let html = getChapterBubbleHtml(connectionManager.getApiClient(item.ServerId), item, item.Chapters, ticks); + const html = getChapterBubbleHtml(connectionManager.getApiClient(item.ServerId), item, item.Chapters, ticks); if (html) { return html; diff --git a/src/elements/emby-itemscontainer/emby-itemscontainer.js b/src/elements/emby-itemscontainer/emby-itemscontainer.js index 691552c074..ef30d1e663 100644 --- a/src/elements/emby-itemscontainer/emby-itemscontainer.js +++ b/src/elements/emby-itemscontainer/emby-itemscontainer.js @@ -18,7 +18,7 @@ import 'webcomponents'; function onClick(e) { const itemsContainer = this; - let multiSelect = itemsContainer.multiSelect; + const multiSelect = itemsContainer.multiSelect; if (multiSelect) { if (multiSelect.onContainerClick.call(itemsContainer, e) === false) { @@ -164,7 +164,7 @@ import 'webcomponents'; } function getEventsToMonitor(itemsContainer) { - let monitor = itemsContainer.getAttribute('data-monitor'); + const monitor = itemsContainer.getAttribute('data-monitor'); if (monitor) { return monitor.split(','); } @@ -356,7 +356,7 @@ import 'webcomponents'; ItemsContainerPrototype.resume = function (options) { this.paused = false; - let refreshIntervalEndTime = this.refreshIntervalEndTime; + const refreshIntervalEndTime = this.refreshIntervalEndTime; if (refreshIntervalEndTime) { const remainingMs = refreshIntervalEndTime - new Date().getTime(); if (remainingMs > 0 && !this.needsRefresh) { @@ -395,7 +395,7 @@ import 'webcomponents'; return; } - let timeout = this.refreshTimeout; + const timeout = this.refreshTimeout; if (timeout) { clearTimeout(timeout); } @@ -434,7 +434,7 @@ import 'webcomponents'; function onDataFetched(result) { const items = result.Items || result; - let parentContainer = this.parentContainer; + const parentContainer = this.parentContainer; if (parentContainer) { if (items.length) { parentContainer.classList.remove('hide'); diff --git a/src/elements/emby-playstatebutton/emby-playstatebutton.js b/src/elements/emby-playstatebutton/emby-playstatebutton.js index 7b5c344095..322b7b3722 100644 --- a/src/elements/emby-playstatebutton/emby-playstatebutton.js +++ b/src/elements/emby-playstatebutton/emby-playstatebutton.js @@ -75,7 +75,7 @@ import EmbyButtonPrototype from 'emby-button'; button.title = globalize.translate('Played'); } - let text = button.querySelector('.button-text'); + const text = button.querySelector('.button-text'); if (text) { text.innerHTML = button.title; } diff --git a/src/elements/emby-scrollbuttons/emby-scrollbuttons.js b/src/elements/emby-scrollbuttons/emby-scrollbuttons.js index fcff587392..f7665c0618 100644 --- a/src/elements/emby-scrollbuttons/emby-scrollbuttons.js +++ b/src/elements/emby-scrollbuttons/emby-scrollbuttons.js @@ -118,7 +118,7 @@ const EmbyScrollButtonsPrototype = Object.create(HTMLDivElement.prototype); } function onScrollButtonClick(e) { - let scroller = this.parentNode.nextSibling; + const scroller = this.parentNode.nextSibling; const direction = this.getAttribute('data-direction'); const scrollSize = getScrollSize(scroller); @@ -161,7 +161,7 @@ const EmbyScrollButtonsPrototype = Object.create(HTMLDivElement.prototype); const parent = this.scroller; this.scroller = null; - let scrollHandler = this.scrollHandler; + const scrollHandler = this.scrollHandler; if (parent && scrollHandler) { parent.removeScrollEventListener(scrollHandler, { capture: false, diff --git a/src/scripts/datetime.js b/src/scripts/datetime.js index dcac41089e..c6baa28ed3 100644 --- a/src/scripts/datetime.js +++ b/src/scripts/datetime.js @@ -24,7 +24,7 @@ import globalize from 'globalize'; // parse strings, leading zeros into proper ints const a = [1, 2, 3, 4, 5, 6, 10, 11]; - for (let i in a) { + for (const i in a) { d[a[i]] = parseInt(d[a[i]], 10); } d[7] = parseFloat(d[7]); diff --git a/src/scripts/globalize.js b/src/scripts/globalize.js index 4af1ea6cbf..d237fdcce0 100644 --- a/src/scripts/globalize.js +++ b/src/scripts/globalize.js @@ -63,11 +63,11 @@ import events from 'events'; } function ensureTranslations(culture) { - for (let i in allTranslations) { + for (const i in allTranslations) { ensureTranslation(allTranslations[i], culture); } if (culture !== fallbackCulture) { - for (let i in allTranslations) { + for (const i in allTranslations) { ensureTranslation(allTranslations[i], fallbackCulture); } } From 21152040ec7036ff03ac57f12c08b6c52759d34c Mon Sep 17 00:00:00 2001 From: MrTimscampi Date: Thu, 6 Aug 2020 20:34:49 +0200 Subject: [PATCH 053/301] Fix lint --- src/components/playback/playbackmanager.js | 10 +++++----- src/controllers/livetvstatus.js | 8 +++----- src/plugins/bookPlayer/plugin.js | 7 ++++--- 3 files changed, 12 insertions(+), 13 deletions(-) diff --git a/src/components/playback/playbackmanager.js b/src/components/playback/playbackmanager.js index ed06e3eef3..8502b551af 100644 --- a/src/components/playback/playbackmanager.js +++ b/src/components/playback/playbackmanager.js @@ -8,7 +8,7 @@ import * as userSettings from 'userSettings'; import globalize from 'globalize'; import connectionManager from 'connectionManager'; import loading from 'loading'; -import apphost from 'apphost'; +import appHost from 'apphost'; import screenfull from 'screenfull'; function enableLocalPlaylistManagement(player) { @@ -322,7 +322,7 @@ function getAudioStreamUrl(item, transcodingProfile, directPlayContainers, maxBi PlaySessionId: startingPlaySession, StartTimeTicks: startPosition || 0, EnableRedirection: true, - EnableRemoteMedia: apphost.supports('remoteaudio') + EnableRemoteMedia: appHost.supports('remoteaudio') }); } @@ -606,7 +606,7 @@ function supportsDirectPlay(apiClient, item, mediaSource) { const isFolderRip = mediaSource.VideoType === 'BluRay' || mediaSource.VideoType === 'Dvd' || mediaSource.VideoType === 'HdDvd'; if (mediaSource.SupportsDirectPlay || isFolderRip) { - if (mediaSource.IsRemote && !apphost.supports('remotevideo')) { + if (mediaSource.IsRemote && !appHost.supports('remotevideo')) { return Promise.resolve(false); } @@ -3156,7 +3156,7 @@ class PlaybackManager { return streamInfo ? streamInfo.playbackStartTimeTicks : null; }; - if (apphost.supports('remotecontrol')) { + if (appHost.supports('remotecontrol')) { import('serverNotifications').then(({ default: serverNotifications }) => { events.on(serverNotifications, 'ServerShuttingDown', self.setDefaultPlayerActive.bind(self)); events.on(serverNotifications, 'ServerRestarting', self.setDefaultPlayerActive.bind(self)); @@ -3520,7 +3520,7 @@ class PlaybackManager { 'PlayTrailers' ]; - if (appHost.default.supports('fullscreenchange')) { + if (appHost.supports('fullscreenchange')) { list.push('ToggleFullscreen'); } diff --git a/src/controllers/livetvstatus.js b/src/controllers/livetvstatus.js index f37760808a..7555b04b99 100644 --- a/src/controllers/livetvstatus.js +++ b/src/controllers/livetvstatus.js @@ -15,12 +15,10 @@ import 'emby-button'; const enableFocusTransform = !browser.slow && !browser.edge; function getDeviceHtml(device) { - let padderClass; + const padderClass = 'cardPadder-backdrop'; + let cssClass = 'card scalableCard backdropCard backdropCard-scalable'; + const cardBoxCssClass = 'cardBox visualCardBox'; let html = ''; - let cssClass = 'card scalableCard'; - let cardBoxCssClass = 'cardBox visualCardBox'; - cssClass += ' backdropCard backdropCard-scalable'; - padderClass = 'cardPadder-backdrop'; // TODO move card creation code to Card component diff --git a/src/plugins/bookPlayer/plugin.js b/src/plugins/bookPlayer/plugin.js index afd7052e1d..d35e248893 100644 --- a/src/plugins/bookPlayer/plugin.js +++ b/src/plugins/bookPlayer/plugin.js @@ -123,8 +123,8 @@ export class BookPlayer { onTouchStart(e) { // TODO: depending on the event this can be the document or the rendition itself - let rendition = this._rendition || this; - let book = rendition.book; + const rendition = this._rendition || this; + const book = rendition.book; // check that the event is from the book or the document if (!book || this._loaded === false) return; @@ -132,7 +132,8 @@ export class BookPlayer { // epubjs stores pages off the screen or something for preloading // get the modulus of the touch event to account for the increased width if (!e.touches || e.touches.length === 0) return; - let touch = e.touches[0].clientX % dom.getWindowSize().innerWidth; + + const touch = e.touches[0].clientX % dom.getWindowSize().innerWidth; if (touch < dom.getWindowSize().innerWidth / 2) { book.package.metadata.direction === 'rtl' ? rendition.next() : rendition.prev(); } else { From 0cd82da8f2aa441650900d882a82c15f457759e6 Mon Sep 17 00:00:00 2001 From: MrTimscampi Date: Thu, 6 Aug 2020 20:59:14 +0200 Subject: [PATCH 054/301] Migrate navdrawer to ES6 --- .eslintignore | 1 - package.json | 1 + src/libraries/navdrawer/navdrawer.js | 639 ++++++++++++++------------- src/scripts/libraryMenu.js | 2 + 4 files changed, 324 insertions(+), 319 deletions(-) diff --git a/.eslintignore b/.eslintignore index 8e3aee83fb..74b18ddcf6 100644 --- a/.eslintignore +++ b/.eslintignore @@ -2,4 +2,3 @@ node_modules dist .idea .vscode -src/libraries diff --git a/package.json b/package.json index bf3ac42f97..7b895bc367 100644 --- a/package.json +++ b/package.json @@ -275,6 +275,7 @@ "src/elements/emby-tabs/emby-tabs.js", "src/elements/emby-textarea/emby-textarea.js", "src/elements/emby-toggle/emby-toggle.js", + "src/libraries/navdrawer/navdrawer.js", "src/plugins/backdropScreensaver/plugin.js", "src/plugins/bookPlayer/plugin.js", "src/plugins/bookPlayer/tableOfContents.js", diff --git a/src/libraries/navdrawer/navdrawer.js b/src/libraries/navdrawer/navdrawer.js index 4733c617f3..965b68aee4 100644 --- a/src/libraries/navdrawer/navdrawer.js +++ b/src/libraries/navdrawer/navdrawer.js @@ -1,354 +1,357 @@ -define(["browser", "dom", "css!./navdrawer", "scrollStyles"], function (browser, dom) { - "use strict"; +/* Cleaning this file properly is not neecessary, since it's an outdated library + * and will be replaced soon by a Vue component. + */ - browser = browser.default || browser; +import browser from 'browser'; +import dom from 'dom'; +import 'css!./navdrawer'; +import 'scrollStyles'; - return function (options) { - function getTouches(e) { - return e.changedTouches || e.targetTouches || e.touches; +export default function (options) { + function getTouches(e) { + return e.changedTouches || e.targetTouches || e.touches; + } + + function onMenuTouchStart(e) { + options.target.classList.remove('transition'); + var touches = getTouches(e); + var touch = touches[0] || {}; + menuTouchStartX = touch.clientX; + menuTouchStartY = touch.clientY; + menuTouchStartTime = new Date().getTime(); + } + + function setVelocity(deltaX) { + var time = new Date().getTime() - (menuTouchStartTime || 0); + velocity = Math.abs(deltaX) / time; + } + + function onMenuTouchMove(e) { + var isOpen = self.visible; + var touches = getTouches(e); + var touch = touches[0] || {}; + var endX = touch.clientX || 0; + var endY = touch.clientY || 0; + var deltaX = endX - (menuTouchStartX || 0); + var deltaY = endY - (menuTouchStartY || 0); + setVelocity(deltaX); + + if (isOpen && dragMode !== 1 && deltaX > 0) { + dragMode = 2; } - function onMenuTouchStart(e) { - options.target.classList.remove("transition"); - var touches = getTouches(e); - var touch = touches[0] || {}; - menuTouchStartX = touch.clientX; - menuTouchStartY = touch.clientY; - menuTouchStartTime = new Date().getTime(); + if (dragMode === 0 && (!isOpen || Math.abs(deltaX) >= 10) && Math.abs(deltaY) < 5) { + dragMode = 1; + scrollContainer.addEventListener('scroll', disableEvent); + self.showMask(); + } else if (dragMode === 0 && Math.abs(deltaY) >= 5) { + dragMode = 2; } - function setVelocity(deltaX) { - var time = new Date().getTime() - (menuTouchStartTime || 0); - velocity = Math.abs(deltaX) / time; + if (dragMode === 1) { + newPos = currentPos + deltaX; + self.changeMenuPos(); } + } - function onMenuTouchMove(e) { - var isOpen = self.visible; - var touches = getTouches(e); - var touch = touches[0] || {}; - var endX = touch.clientX || 0; - var endY = touch.clientY || 0; - var deltaX = endX - (menuTouchStartX || 0); - var deltaY = endY - (menuTouchStartY || 0); - setVelocity(deltaX); + function onMenuTouchEnd(e) { + options.target.classList.add('transition'); + scrollContainer.removeEventListener('scroll', disableEvent); + dragMode = 0; + var touches = getTouches(e); + var touch = touches[0] || {}; + var endX = touch.clientX || 0; + var endY = touch.clientY || 0; + var deltaX = endX - (menuTouchStartX || 0); + var deltaY = endY - (menuTouchStartY || 0); + currentPos = deltaX; + self.checkMenuState(deltaX, deltaY); + } - if (isOpen && 1 !== dragMode && deltaX > 0) { - dragMode = 2; - } + function onEdgeTouchStart(e) { + if (isPeeking) { + onMenuTouchMove(e); + } else { + if (((getTouches(e)[0] || {}).clientX || 0) <= options.handleSize) { + isPeeking = true; - if (0 === dragMode && (!isOpen || Math.abs(deltaX) >= 10) && Math.abs(deltaY) < 5) { - dragMode = 1; - scrollContainer.addEventListener("scroll", disableEvent); - self.showMask(); - } else if (0 === dragMode && Math.abs(deltaY) >= 5) { - dragMode = 2; - } - - if (1 === dragMode) { - newPos = currentPos + deltaX; - self.changeMenuPos(); - } - } - - function onMenuTouchEnd(e) { - options.target.classList.add("transition"); - scrollContainer.removeEventListener("scroll", disableEvent); - dragMode = 0; - var touches = getTouches(e); - var touch = touches[0] || {}; - var endX = touch.clientX || 0; - var endY = touch.clientY || 0; - var deltaX = endX - (menuTouchStartX || 0); - var deltaY = endY - (menuTouchStartY || 0); - currentPos = deltaX; - self.checkMenuState(deltaX, deltaY); - } - - function onEdgeTouchStart(e) { - if (isPeeking) { - onMenuTouchMove(e); - } else { - if (((getTouches(e)[0] || {}).clientX || 0) <= options.handleSize) { - isPeeking = true; - - if (e.type === "touchstart") { - dom.removeEventListener(edgeContainer, "touchmove", onEdgeTouchMove, {}); - dom.addEventListener(edgeContainer, "touchmove", onEdgeTouchMove, {}); - } - - onMenuTouchStart(e); + if (e.type === 'touchstart') { + dom.removeEventListener(edgeContainer, 'touchmove', onEdgeTouchMove, {}); + dom.addEventListener(edgeContainer, 'touchmove', onEdgeTouchMove, {}); } + + onMenuTouchStart(e); } } + } - function onEdgeTouchMove(e) { - e.preventDefault(); - e.stopPropagation(); - onEdgeTouchStart(e); + function onEdgeTouchMove(e) { + e.preventDefault(); + e.stopPropagation(); + onEdgeTouchStart(e); + } + + function onEdgeTouchEnd(e) { + if (isPeeking) { + isPeeking = false; + dom.removeEventListener(edgeContainer, 'touchmove', onEdgeTouchMove, {}); + onMenuTouchEnd(e); } + } - function onEdgeTouchEnd(e) { - if (isPeeking) { - isPeeking = false; - dom.removeEventListener(edgeContainer, "touchmove", onEdgeTouchMove, {}); - onMenuTouchEnd(e); - } - } + function disableEvent(e) { + e.preventDefault(); + e.stopPropagation(); + } - function disableEvent(e) { - e.preventDefault(); - e.stopPropagation(); - } + function onBackgroundTouchStart(e) { + var touches = getTouches(e); + var touch = touches[0] || {}; + backgroundTouchStartX = touch.clientX; + backgroundTouchStartTime = new Date().getTime(); + } - function onBackgroundTouchStart(e) { - var touches = getTouches(e); - var touch = touches[0] || {}; - backgroundTouchStartX = touch.clientX; - backgroundTouchStartTime = new Date().getTime(); - } + function onBackgroundTouchMove(e) { + var touches = getTouches(e); + var touch = touches[0] || {}; + var endX = touch.clientX || 0; - function onBackgroundTouchMove(e) { - var touches = getTouches(e); - var touch = touches[0] || {}; - var endX = touch.clientX || 0; - - if (endX <= options.width && self.isVisible) { - countStart++; - var deltaX = endX - (backgroundTouchStartX || 0); - - if (countStart == 1) { - startPoint = deltaX; - } - if (deltaX < 0 && dragMode !== 2) { - dragMode = 1; - newPos = deltaX - startPoint + options.width; - self.changeMenuPos(); - var time = new Date().getTime() - (backgroundTouchStartTime || 0); - velocity = Math.abs(deltaX) / time; - } - } - - e.preventDefault(); - e.stopPropagation(); - } - - function onBackgroundTouchEnd(e) { - var touches = getTouches(e); - var touch = touches[0] || {}; - var endX = touch.clientX || 0; + if (endX <= options.width && self.isVisible) { + countStart++; var deltaX = endX - (backgroundTouchStartX || 0); - self.checkMenuState(deltaX); - countStart = 0; - } - function onMaskTransitionEnd() { - var classList = mask.classList; - - if (!classList.contains("backdrop")) { - classList.add("hide"); + if (countStart == 1) { + startPoint = deltaX; + } + if (deltaX < 0 && dragMode !== 2) { + dragMode = 1; + newPos = deltaX - startPoint + options.width; + self.changeMenuPos(); + var time = new Date().getTime() - (backgroundTouchStartTime || 0); + velocity = Math.abs(deltaX) / time; } } - var self; - var defaults; - var mask; - var newPos = 0; - var currentPos = 0; - var startPoint = 0; - var countStart = 0; - var velocity = 0; - options.target.classList.add("transition"); - var dragMode = 0; - var scrollContainer = options.target.querySelector(".mainDrawer-scrollContainer"); - scrollContainer.classList.add("scrollY"); + e.preventDefault(); + e.stopPropagation(); + } - var TouchMenuLA = function () { - self = this; - defaults = { - width: 260, - handleSize: 10, - disableMask: false, - maxMaskOpacity: 0.5 - }; - this.isVisible = false; - this.initialize(); + function onBackgroundTouchEnd(e) { + var touches = getTouches(e); + var touch = touches[0] || {}; + var endX = touch.clientX || 0; + var deltaX = endX - (backgroundTouchStartX || 0); + self.checkMenuState(deltaX); + countStart = 0; + } + + function onMaskTransitionEnd() { + var classList = mask.classList; + + if (!classList.contains('backdrop')) { + classList.add('hide'); + } + } + + var self; + var defaults; + var mask; + var newPos = 0; + var currentPos = 0; + var startPoint = 0; + var countStart = 0; + var velocity = 0; + options.target.classList.add('transition'); + var dragMode = 0; + var scrollContainer = options.target.querySelector('.mainDrawer-scrollContainer'); + scrollContainer.classList.add('scrollY'); + + var TouchMenuLA = function () { + self = this; + defaults = { + width: 260, + handleSize: 10, + disableMask: false, + maxMaskOpacity: 0.5 }; + this.isVisible = false; + this.initialize(); + }; - TouchMenuLA.prototype.initElements = function () { - options.target.classList.add("touch-menu-la"); - options.target.style.width = options.width + "px"; - options.target.style.left = -options.width + "px"; + TouchMenuLA.prototype.initElements = function () { + options.target.classList.add('touch-menu-la'); + options.target.style.width = options.width + 'px'; + options.target.style.left = -options.width + 'px'; - if (!options.disableMask) { - mask = document.createElement("div"); - mask.className = "tmla-mask hide"; - document.body.appendChild(mask); - dom.addEventListener(mask, dom.whichTransitionEvent(), onMaskTransitionEnd, { - passive: true - }); - } - }; - - var menuTouchStartX; - var menuTouchStartY; - var menuTouchStartTime; - var edgeContainer = document.querySelector(".mainDrawerHandle"); - var isPeeking = false; - - TouchMenuLA.prototype.animateToPosition = function (pos) { - requestAnimationFrame(function () { - options.target.style.transform = pos ? "translateX(" + pos + "px)" : "none"; + if (!options.disableMask) { + mask = document.createElement('div'); + mask.className = 'tmla-mask hide'; + document.body.appendChild(mask); + dom.addEventListener(mask, dom.whichTransitionEvent(), onMaskTransitionEnd, { + passive: true }); - }; + } + }; - TouchMenuLA.prototype.changeMenuPos = function () { - if (newPos <= options.width) { - this.animateToPosition(newPos); - } - }; + var menuTouchStartX; + var menuTouchStartY; + var menuTouchStartTime; + var edgeContainer = document.querySelector('.mainDrawerHandle'); + var isPeeking = false; - TouchMenuLA.prototype.clickMaskClose = function () { - mask.addEventListener("click", function () { + TouchMenuLA.prototype.animateToPosition = function (pos) { + requestAnimationFrame(function () { + options.target.style.transform = pos ? 'translateX(' + pos + 'px)' : 'none'; + }); + }; + + TouchMenuLA.prototype.changeMenuPos = function () { + if (newPos <= options.width) { + this.animateToPosition(newPos); + } + }; + + TouchMenuLA.prototype.clickMaskClose = function () { + mask.addEventListener('click', function () { + self.close(); + }); + }; + + TouchMenuLA.prototype.checkMenuState = function (deltaX, deltaY) { + if (velocity >= 0.4) { + if (deltaX >= 0 || Math.abs(deltaY || 0) >= 70) { + self.open(); + } else { self.close(); - }); - }; - - TouchMenuLA.prototype.checkMenuState = function (deltaX, deltaY) { - if (velocity >= 0.4) { - if (deltaX >= 0 || Math.abs(deltaY || 0) >= 70) { - self.open(); - } else { + } + } else { + if (newPos >= 100) { + self.open(); + } else { + if (newPos) { self.close(); } - } else { - if (newPos >= 100) { - self.open(); - } else { - if (newPos) { - self.close(); - } - } } - }; - - TouchMenuLA.prototype.open = function () { - this.animateToPosition(options.width); - currentPos = options.width; - this.isVisible = true; - options.target.classList.add("drawer-open"); - self.showMask(); - self.invoke(options.onChange); - }; - - TouchMenuLA.prototype.close = function () { - this.animateToPosition(0); - currentPos = 0; - self.isVisible = false; - options.target.classList.remove("drawer-open"); - self.hideMask(); - self.invoke(options.onChange); - }; - - TouchMenuLA.prototype.toggle = function () { - if (self.isVisible) { - self.close(); - } else { - self.open(); - } - }; - - var backgroundTouchStartX; - var backgroundTouchStartTime; - - TouchMenuLA.prototype.showMask = function () { - mask.classList.remove("hide"); - mask.classList.add("backdrop"); - }; - - TouchMenuLA.prototype.hideMask = function () { - mask.classList.add("hide"); - mask.classList.remove("backdrop"); - }; - - TouchMenuLA.prototype.invoke = function (fn) { - if (fn) { - fn.apply(self); - } - }; - - var _edgeSwipeEnabled; - - TouchMenuLA.prototype.setEdgeSwipeEnabled = function (enabled) { - if (!options.disableEdgeSwipe) { - if (browser.touch) { - if (enabled) { - if (!_edgeSwipeEnabled) { - _edgeSwipeEnabled = true; - dom.addEventListener(edgeContainer, "touchstart", onEdgeTouchStart, { - passive: true - }); - dom.addEventListener(edgeContainer, "touchend", onEdgeTouchEnd, { - passive: true - }); - dom.addEventListener(edgeContainer, "touchcancel", onEdgeTouchEnd, { - passive: true - }); - } - } else { - if (_edgeSwipeEnabled) { - _edgeSwipeEnabled = false; - dom.removeEventListener(edgeContainer, "touchstart", onEdgeTouchStart, { - passive: true - }); - dom.removeEventListener(edgeContainer, "touchend", onEdgeTouchEnd, { - passive: true - }); - dom.removeEventListener(edgeContainer, "touchcancel", onEdgeTouchEnd, { - passive: true - }); - } - } - } - } - }; - - TouchMenuLA.prototype.initialize = function () { - options = Object.assign(defaults, options || {}); - - if (browser.edge) { - options.disableEdgeSwipe = true; - } - - self.initElements(); - - if (browser.touch) { - dom.addEventListener(options.target, "touchstart", onMenuTouchStart, { - passive: true - }); - dom.addEventListener(options.target, "touchmove", onMenuTouchMove, { - passive: true - }); - dom.addEventListener(options.target, "touchend", onMenuTouchEnd, { - passive: true - }); - dom.addEventListener(options.target, "touchcancel", onMenuTouchEnd, { - passive: true - }); - dom.addEventListener(mask, "touchstart", onBackgroundTouchStart, { - passive: true - }); - dom.addEventListener(mask, "touchmove", onBackgroundTouchMove, {}); - dom.addEventListener(mask, "touchend", onBackgroundTouchEnd, { - passive: true - }); - dom.addEventListener(mask, "touchcancel", onBackgroundTouchEnd, { - passive: true - }); - } - - self.clickMaskClose(); - }; - - return new TouchMenuLA(); + } }; -}); + + TouchMenuLA.prototype.open = function () { + this.animateToPosition(options.width); + currentPos = options.width; + this.isVisible = true; + options.target.classList.add('drawer-open'); + self.showMask(); + self.invoke(options.onChange); + }; + + TouchMenuLA.prototype.close = function () { + this.animateToPosition(0); + currentPos = 0; + self.isVisible = false; + options.target.classList.remove('drawer-open'); + self.hideMask(); + self.invoke(options.onChange); + }; + + TouchMenuLA.prototype.toggle = function () { + if (self.isVisible) { + self.close(); + } else { + self.open(); + } + }; + + var backgroundTouchStartX; + var backgroundTouchStartTime; + + TouchMenuLA.prototype.showMask = function () { + mask.classList.remove('hide'); + mask.classList.add('backdrop'); + }; + + TouchMenuLA.prototype.hideMask = function () { + mask.classList.add('hide'); + mask.classList.remove('backdrop'); + }; + + TouchMenuLA.prototype.invoke = function (fn) { + if (fn) { + fn.apply(self); + } + }; + + var _edgeSwipeEnabled; + + TouchMenuLA.prototype.setEdgeSwipeEnabled = function (enabled) { + if (!options.disableEdgeSwipe) { + if (browser.touch) { + if (enabled) { + if (!_edgeSwipeEnabled) { + _edgeSwipeEnabled = true; + dom.addEventListener(edgeContainer, 'touchstart', onEdgeTouchStart, { + passive: true + }); + dom.addEventListener(edgeContainer, 'touchend', onEdgeTouchEnd, { + passive: true + }); + dom.addEventListener(edgeContainer, 'touchcancel', onEdgeTouchEnd, { + passive: true + }); + } + } else { + if (_edgeSwipeEnabled) { + _edgeSwipeEnabled = false; + dom.removeEventListener(edgeContainer, 'touchstart', onEdgeTouchStart, { + passive: true + }); + dom.removeEventListener(edgeContainer, 'touchend', onEdgeTouchEnd, { + passive: true + }); + dom.removeEventListener(edgeContainer, 'touchcancel', onEdgeTouchEnd, { + passive: true + }); + } + } + } + } + }; + + TouchMenuLA.prototype.initialize = function () { + options = Object.assign(defaults, options || {}); + + if (browser.edge) { + options.disableEdgeSwipe = true; + } + + self.initElements(); + + if (browser.touch) { + dom.addEventListener(options.target, 'touchstart', onMenuTouchStart, { + passive: true + }); + dom.addEventListener(options.target, 'touchmove', onMenuTouchMove, { + passive: true + }); + dom.addEventListener(options.target, 'touchend', onMenuTouchEnd, { + passive: true + }); + dom.addEventListener(options.target, 'touchcancel', onMenuTouchEnd, { + passive: true + }); + dom.addEventListener(mask, 'touchstart', onBackgroundTouchStart, { + passive: true + }); + dom.addEventListener(mask, 'touchmove', onBackgroundTouchMove, {}); + dom.addEventListener(mask, 'touchend', onBackgroundTouchEnd, { + passive: true + }); + dom.addEventListener(mask, 'touchcancel', onBackgroundTouchEnd, { + passive: true + }); + } + + self.clickMaskClose(); + }; + + return new TouchMenuLA(); +} diff --git a/src/scripts/libraryMenu.js b/src/scripts/libraryMenu.js index bbe01276ba..6149717647 100644 --- a/src/scripts/libraryMenu.js +++ b/src/scripts/libraryMenu.js @@ -806,6 +806,8 @@ define(['dom', 'layoutManager', 'inputManager', 'connectionManager', 'events', ' navDrawerScrollContainer.addEventListener('click', onMainDrawerClick); return new Promise(function (resolve, reject) { require(['navdrawer'], function (navdrawer) { + navdrawer = navdrawer.default || navdrawer; + navDrawerInstance = new navdrawer(getNavDrawerOptions()); if (!layoutManager.tv) { From f2e1d03ae98925a1788dbb577b608649e9004ee1 Mon Sep 17 00:00:00 2001 From: MrTimscampi Date: Thu, 6 Aug 2020 21:15:16 +0200 Subject: [PATCH 055/301] Migrate scroller to ES6 --- package.json | 1 + src/controllers/list.js | 2 +- src/libraries/scroller.js | 1714 ++++++++++++++++++------------------- 3 files changed, 838 insertions(+), 879 deletions(-) diff --git a/package.json b/package.json index 7b895bc367..7ed4cb8b9c 100644 --- a/package.json +++ b/package.json @@ -276,6 +276,7 @@ "src/elements/emby-textarea/emby-textarea.js", "src/elements/emby-toggle/emby-toggle.js", "src/libraries/navdrawer/navdrawer.js", + "src/libraries/scroller.js", "src/plugins/backdropScreensaver/plugin.js", "src/plugins/bookPlayer/plugin.js", "src/plugins/bookPlayer/tableOfContents.js", diff --git a/src/controllers/list.js b/src/controllers/list.js index afa0a60fa8..14c6768757 100644 --- a/src/controllers/list.js +++ b/src/controllers/list.js @@ -1,4 +1,4 @@ -define(['globalize', 'listView', 'layoutManager', 'userSettings', 'focusManager', 'cardBuilder', 'loading', 'connectionManager', 'alphaNumericShortcuts', 'scroller', 'playbackManager', 'alphaPicker', 'emby-itemscontainer', 'emby-scroller'], function (globalize, listView, layoutManager, userSettings, focusManager, cardBuilder, loading, connectionManager, AlphaNumericShortcuts, scroller, playbackManager, AlphaPicker) { +define(['globalize', 'listView', 'layoutManager', 'userSettings', 'focusManager', 'cardBuilder', 'loading', 'connectionManager', 'alphaNumericShortcuts', 'playbackManager', 'alphaPicker', 'emby-itemscontainer', 'emby-scroller'], function (globalize, listView, layoutManager, userSettings, focusManager, cardBuilder, loading, connectionManager, AlphaNumericShortcuts, playbackManager, AlphaPicker) { 'use strict'; playbackManager = playbackManager.default || playbackManager; diff --git a/src/libraries/scroller.js b/src/libraries/scroller.js index cc75dcdeef..03c6306511 100644 --- a/src/libraries/scroller.js +++ b/src/libraries/scroller.js @@ -1,928 +1,886 @@ -define(['browser', 'layoutManager', 'dom', 'focusManager', 'ResizeObserver', 'scrollStyles'], function (browser, layoutManager, dom, focusManager, ResizeObserver) { - 'use strict'; +/* Cleaning this file properly is not neecessary, since it's an outdated library + * and will be replaced soon by a Vue component. + */ - browser = browser.default || browser; - focusManager = focusManager.default || focusManager; + import browser from 'browser'; +import layoutManager from 'layoutManager'; +import dom from 'dom'; +import focusManager from 'focusManager'; +import ResizeObserver from 'ResizeObserver'; +import 'scrollStyles'; - /** +/** * Return type of the value. * * @param {Mixed} value * * @return {String} */ - function type(value) { - if (value == null) { - return String(value); - } - - if (typeof value === 'object' || typeof value === 'function') { - return Object.prototype.toString.call(value).match(/\s([a-z]+)/i)[1].toLowerCase() || 'object'; - } - - return typeof value; +function type(value) { + if (value == null) { + return String(value); } - /** - * Disables an event it was triggered on and unbinds itself. - * - * @param {Event} event - * - * @return {Void} - */ - function disableOneEvent(event) { - /*jshint validthis:true */ - event.preventDefault(); - event.stopPropagation(); - this.removeEventListener(event.type, disableOneEvent); + if (typeof value === 'object' || typeof value === 'function') { + return Object.prototype.toString.call(value).match(/\s([a-z]+)/i)[1].toLowerCase() || 'object'; } - /** - * Make sure that number is within the limits. - * - * @param {Number} number - * @param {Number} min - * @param {Number} max - * - * @return {Number} - */ - function within(number, min, max) { - return number < min ? min : number > max ? max : number; + return typeof value; +} + +/** + * Disables an event it was triggered on and unbinds itself. + * + * @param {Event} event + * + * @return {Void} + */ +function disableOneEvent(event) { + /*jshint validthis:true */ + event.preventDefault(); + event.stopPropagation(); + this.removeEventListener(event.type, disableOneEvent); +} + +/** + * Make sure that number is within the limits. + * + * @param {Number} number + * @param {Number} min + * @param {Number} max + * + * @return {Number} + */ +function within(number, min, max) { + return number < min ? min : number > max ? max : number; +} + +// Other global values +var dragMouseEvents = ['mousemove', 'mouseup']; +var dragTouchEvents = ['touchmove', 'touchend']; +var wheelEvent = (document.implementation.hasFeature('Event.wheel', '3.0') ? 'wheel' : 'mousewheel'); +var interactiveElements = ['INPUT', 'SELECT', 'TEXTAREA']; + +var scrollerFactory = function (frame, options) { + // Extend options + var o = Object.assign({}, { + slidee: null, // Selector, DOM element, or jQuery object with DOM element representing SLIDEE. + horizontal: false, // Switch to horizontal mode. + + // Scrolling + mouseWheel: true, + scrollBy: 0, // Pixels or items to move per one mouse scroll. 0 to disable scrolling + + // Dragging + dragSource: null, // Selector or DOM element for catching dragging events. Default is FRAME. + mouseDragging: 1, // Enable navigation by dragging the SLIDEE with mouse cursor. + touchDragging: 1, // Enable navigation by dragging the SLIDEE with touch events. + dragThreshold: 3, // Distance in pixels before Sly recognizes dragging. + intervactive: null, // Selector for special interactive elements. + + // Mixed options + speed: 0 // Animations speed in milliseconds. 0 to disable animations. + + }, options); + + var isSmoothScrollSupported = 'scrollBehavior' in document.documentElement.style; + + // native scroll is a must with touch input + // also use native scroll when scrolling vertically in desktop mode - excluding horizontal because the mouse wheel support is choppy at the moment + // in cases with firefox, if the smooth scroll api is supported then use that because their implementation is very good + if (options.allowNativeScroll === false) { + options.enableNativeScroll = false; + } else if (isSmoothScrollSupported && ((browser.firefox && !layoutManager.tv) || options.allowNativeSmoothScroll)) { + // native smooth scroll + options.enableNativeScroll = true; + } else if (options.requireAnimation && (browser.animate || browser.supportsCssAnimation())) { + // transform is the only way to guarantee animation + options.enableNativeScroll = false; + } else if (!layoutManager.tv || !browser.animate) { + options.enableNativeScroll = true; } - // Other global values - var dragMouseEvents = ['mousemove', 'mouseup']; - var dragTouchEvents = ['touchmove', 'touchend']; - var wheelEvent = (document.implementation.hasFeature('Event.wheel', '3.0') ? 'wheel' : 'mousewheel'); - var interactiveElements = ['INPUT', 'SELECT', 'TEXTAREA']; - var tmpArray = []; - var time; - - // Math shorthands - var abs = Math.abs; - var sqrt = Math.sqrt; - var pow = Math.pow; - var round = Math.round; - var max = Math.max; - var min = Math.min; - - var scrollerFactory = function (frame, options) { - - // Extend options - var o = Object.assign({}, { - slidee: null, // Selector, DOM element, or jQuery object with DOM element representing SLIDEE. - horizontal: false, // Switch to horizontal mode. - - // Scrolling - mouseWheel: true, - scrollBy: 0, // Pixels or items to move per one mouse scroll. 0 to disable scrolling - - // Dragging - dragSource: null, // Selector or DOM element for catching dragging events. Default is FRAME. - mouseDragging: 1, // Enable navigation by dragging the SLIDEE with mouse cursor. - touchDragging: 1, // Enable navigation by dragging the SLIDEE with touch events. - dragThreshold: 3, // Distance in pixels before Sly recognizes dragging. - intervactive: null, // Selector for special interactive elements. - - // Mixed options - speed: 0 // Animations speed in milliseconds. 0 to disable animations. - - }, options); - - var isSmoothScrollSupported = 'scrollBehavior' in document.documentElement.style; - - // native scroll is a must with touch input - // also use native scroll when scrolling vertically in desktop mode - excluding horizontal because the mouse wheel support is choppy at the moment - // in cases with firefox, if the smooth scroll api is supported then use that because their implementation is very good - if (options.allowNativeScroll === false) { - options.enableNativeScroll = false; - } else if (isSmoothScrollSupported && ((browser.firefox && !layoutManager.tv) || options.allowNativeSmoothScroll)) { - // native smooth scroll - options.enableNativeScroll = true; - } else if (options.requireAnimation && (browser.animate || browser.supportsCssAnimation())) { - - // transform is the only way to guarantee animation - options.enableNativeScroll = false; - } else if (!layoutManager.tv || !browser.animate) { - - options.enableNativeScroll = true; - } - - // Need this for the magic wheel. With the animated scroll the magic wheel will run off of the screen - if (browser.web0s) { - options.enableNativeScroll = true; - } - - // Private variables - var self = this; - self.options = o; - - // Frame - var slideeElement = o.slidee ? o.slidee : sibling(frame.firstChild)[0]; - self._pos = { - start: 0, - center: 0, - end: 0, - cur: 0, - dest: 0 - }; - - var transform = !options.enableNativeScroll; - - // Miscellaneous - var scrollSource = frame; - var dragSourceElement = o.dragSource ? o.dragSource : frame; - var dragging = { - released: 1 - }; - var scrolling = { - last: 0, - delta: 0, - resetTime: 200 - }; - - // Expose properties - self.initialized = 0; - self.slidee = slideeElement; - self.options = o; - self.dragging = dragging; - - var nativeScrollElement = frame; - - function sibling(n, elem) { - var matched = []; - - for (; n; n = n.nextSibling) { - if (n.nodeType === 1 && n !== elem) { - matched.push(n); - } - } - return matched; - } - - var requiresReflow = true; - - var frameSize = 0; - var slideeSize = 0; - function ensureSizeInfo() { - - if (requiresReflow) { - - requiresReflow = false; - - // Reset global variables - frameSize = o.horizontal ? (frame).offsetWidth : (frame).offsetHeight; - - slideeSize = o.scrollWidth || Math.max(slideeElement[o.horizontal ? 'offsetWidth' : 'offsetHeight'], slideeElement[o.horizontal ? 'scrollWidth' : 'scrollHeight']); - - // Set position limits & relativess - self._pos.end = max(slideeSize - frameSize, 0); - } - } - - /** - * Loading function. - * - * Populate arrays, set sizes, bind events, ... - * - * @param {Boolean} [isInit] Whether load is called from within self.init(). - * @return {Void} - */ - function load(isInit) { - - requiresReflow = true; - - if (!isInit) { - - ensureSizeInfo(); - - // Fix possible overflowing - var pos = self._pos; - self.slideTo(within(pos.dest, pos.start, pos.end)); - } - } - - function initFrameResizeObserver() { - - var observerOptions = {}; - - self.frameResizeObserver = new ResizeObserver(onResize, observerOptions); - - self.frameResizeObserver.observe(frame); - } - - self.reload = function () { - load(); - }; - - self.getScrollEventName = function () { - return transform ? 'scrollanimate' : 'scroll'; - }; - - self.getScrollSlider = function () { - return slideeElement; - }; - - self.getScrollFrame = function () { - return frame; - }; - - function nativeScrollTo(container, pos, immediate) { - - if (container.scroll) { - if (o.horizontal) { - - container.scroll({ - left: pos, - behavior: immediate ? 'instant' : 'smooth' - }); - } else { - - container.scroll({ - top: pos, - behavior: immediate ? 'instant' : 'smooth' - }); - } - } else if (!immediate && container.scrollTo) { - if (o.horizontal) { - container.scrollTo(Math.round(pos), 0); - } else { - container.scrollTo(0, Math.round(pos)); - } - } else { - if (o.horizontal) { - container.scrollLeft = Math.round(pos); - } else { - container.scrollTop = Math.round(pos); - } - } - } - - var lastAnimate; - - /** - * Animate to a position. - * - * @param {Int} newPos New position. - * @param {Bool} immediate Reposition immediately without an animation. - * - * @return {Void} - */ - self.slideTo = function (newPos, immediate, fullItemPos) { - - ensureSizeInfo(); - var pos = self._pos; - - newPos = within(newPos, pos.start, pos.end); - - if (!transform) { - - nativeScrollTo(nativeScrollElement, newPos, immediate); - return; - } - - // Update the animation object - var from = pos.cur; - immediate = immediate || dragging.init || !o.speed; - - var now = new Date().getTime(); - - if (o.autoImmediate) { - if (!immediate && (now - (lastAnimate || 0)) <= 50) { - immediate = true; - } - } - - if (!immediate && o.skipSlideToWhenVisible && fullItemPos && fullItemPos.isVisible) { - - return; - } - - // Start animation rendering - // NOTE the dependency was modified here to fix a scrollbutton issue - pos.dest = newPos; - renderAnimateWithTransform(from, newPos, immediate); - lastAnimate = now; - }; - - function setStyleProperty(elem, name, value, speed, resetTransition) { - - var style = elem.style; - - if (resetTransition || browser.edge) { - style.transition = 'none'; - void elem.offsetWidth; - } - - style.transition = 'transform ' + speed + 'ms ease-out'; - style[name] = value; - } - - function dispatchScrollEventIfNeeded() { - if (o.dispatchScrollEvent) { - frame.dispatchEvent(new CustomEvent(self.getScrollEventName(), { - bubbles: true, - cancelable: false - })); - } - } - - function renderAnimateWithTransform(fromPosition, toPosition, immediate) { - - var speed = o.speed; - - if (immediate) { - speed = o.immediateSpeed || 50; - } - - if (o.horizontal) { - setStyleProperty(slideeElement, 'transform', 'translateX(' + (-round(toPosition)) + 'px)', speed); - } else { - setStyleProperty(slideeElement, 'transform', 'translateY(' + (-round(toPosition)) + 'px)', speed); - } - self._pos.cur = toPosition; - - dispatchScrollEventIfNeeded(); - } - - function getBoundingClientRect(elem) { - - // Support: BlackBerry 5, iOS 3 (original iPhone) - // If we don't have gBCR, just use 0,0 rather than error - if (elem.getBoundingClientRect) { - return elem.getBoundingClientRect(); - } else { - return { top: 0, left: 0 }; - } - } - - /** - * Returns the position object. - * - * @param {Mixed} item - * - * @return {Object} - */ - self.getPos = function (item) { - - var scrollElement = transform ? slideeElement : nativeScrollElement; - var slideeOffset = getBoundingClientRect(scrollElement); - var itemOffset = getBoundingClientRect(item); - - var slideeStartPos = o.horizontal ? slideeOffset.left : slideeOffset.top; - var slideeEndPos = o.horizontal ? slideeOffset.right : slideeOffset.bottom; - - var offset = o.horizontal ? itemOffset.left - slideeOffset.left : itemOffset.top - slideeOffset.top; - - var size = o.horizontal ? itemOffset.width : itemOffset.height; - if (!size && size !== 0) { - size = item[o.horizontal ? 'offsetWidth' : 'offsetHeight']; - } - - var centerOffset = o.centerOffset || 0; - - if (!transform) { - centerOffset = 0; - if (o.horizontal) { - offset += nativeScrollElement.scrollLeft; - } else { - offset += nativeScrollElement.scrollTop; - } - } - - ensureSizeInfo(); - - var currentStart = self._pos.cur; - var currentEnd = currentStart + frameSize; - - console.debug('offset:' + offset + ' currentStart:' + currentStart + ' currentEnd:' + currentEnd); - var isVisible = offset >= currentStart && (offset + size) <= currentEnd; - - return { - start: offset, - center: offset + centerOffset - (frameSize / 2) + (size / 2), - end: offset - frameSize + size, - size: size, - isVisible: isVisible - }; - }; - - self.getCenterPosition = function (item) { - - ensureSizeInfo(); - - var pos = self.getPos(item); - return within(pos.center, pos.start, pos.end); - }; - - function dragInitSlidee(event) { - var isTouch = event.type === 'touchstart'; - - // Ignore when already in progress, or interactive element in non-touch navivagion - if (dragging.init || !isTouch && isInteractive(event.target)) { - return; - } - - // SLIDEE dragging conditions - if (!(isTouch ? o.touchDragging : o.mouseDragging && event.which < 2)) { - return; - } - - if (!isTouch) { - // prevents native image dragging in Firefox - event.preventDefault(); - } - - // Reset dragging object - dragging.released = 0; - - // Properties used in dragHandler - dragging.init = 0; - dragging.source = event.target; - dragging.touch = isTouch; - var pointer = isTouch ? event.touches[0] : event; - dragging.initX = pointer.pageX; - dragging.initY = pointer.pageY; - dragging.initPos = self._pos.cur; - dragging.start = +new Date(); - dragging.time = 0; - dragging.path = 0; - dragging.delta = 0; - dragging.locked = 0; - dragging.pathToLock = isTouch ? 30 : 10; - - // Bind dragging events - if (transform) { - - if (isTouch) { - dragTouchEvents.forEach(function (eventName) { - dom.addEventListener(document, eventName, dragHandler, { - passive: true - }); - }); - } else { - dragMouseEvents.forEach(function (eventName) { - dom.addEventListener(document, eventName, dragHandler, { - passive: true - }); - }); - } - } - } - - /** - * Handler for dragging scrollbar handle or SLIDEE. - * - * @param {Event} event - * - * @return {Void} - */ - function dragHandler(event) { - dragging.released = event.type === 'mouseup' || event.type === 'touchend'; - var pointer = dragging.touch ? event[dragging.released ? 'changedTouches' : 'touches'][0] : event; - dragging.pathX = pointer.pageX - dragging.initX; - dragging.pathY = pointer.pageY - dragging.initY; - dragging.path = sqrt(pow(dragging.pathX, 2) + pow(dragging.pathY, 2)); - dragging.delta = o.horizontal ? dragging.pathX : dragging.pathY; - - if (!dragging.released && dragging.path < 1) { - return; - } - - // We haven't decided whether this is a drag or not... - if (!dragging.init) { - // If the drag path was very short, maybe it's not a drag? - if (dragging.path < o.dragThreshold) { - // If the pointer was released, the path will not become longer and it's - // definitely not a drag. If not released yet, decide on next iteration - return dragging.released ? dragEnd() : undefined; - } else { - // If dragging path is sufficiently long we can confidently start a drag - // if drag is in different direction than scroll, ignore it - if (o.horizontal ? abs(dragging.pathX) > abs(dragging.pathY) : abs(dragging.pathX) < abs(dragging.pathY)) { - dragging.init = 1; - } else { - return dragEnd(); - } - } - } - - //event.preventDefault(); - - // Disable click on a source element, as it is unwelcome when dragging - if (!dragging.locked && dragging.path > dragging.pathToLock) { - dragging.locked = 1; - dragging.source.addEventListener('click', disableOneEvent); - } - - // Cancel dragging on release - if (dragging.released) { - dragEnd(); - } - - self.slideTo(round(dragging.initPos - dragging.delta)); - } - - /** - * Stops dragging and cleans up after it. - * - * @return {Void} - */ - function dragEnd() { - dragging.released = true; - - dragTouchEvents.forEach(function (eventName) { - dom.removeEventListener(document, eventName, dragHandler, { - passive: true - }); - }); - - dragMouseEvents.forEach(function (eventName) { - dom.removeEventListener(document, eventName, dragHandler, { - passive: true - }); - }); - - // Make sure that disableOneEvent is not active in next tick. - setTimeout(function () { - dragging.source.removeEventListener('click', disableOneEvent); - }); - - dragging.init = 0; - } - - /** - * Check whether element is interactive. - * - * @return {Boolean} - */ - function isInteractive(element) { - - while (element) { - - if (interactiveElements.indexOf(element.tagName) !== -1) { - return true; - } - - element = element.parentNode; - } - return false; - } - - /** - * Mouse wheel delta normalization. - * - * @param {Event} event - * - * @return {Int} - */ - function normalizeWheelDelta(event) { - // JELLYFIN MOD: Only use deltaX for horizontal scroll and remove IE8 support - scrolling.curDelta = o.horizontal ? event.deltaX : event.deltaY; - // END JELLYFIN MOD - - if (transform) { - scrolling.curDelta /= event.deltaMode === 1 ? 3 : 100; - } - return scrolling.curDelta; - } - - /** - * Mouse scrolling handler. - * - * @param {Event} event - * - * @return {Void} - */ - function scrollHandler(event) { - - ensureSizeInfo(); - var pos = self._pos; - // Ignore if there is no scrolling to be done - if (!o.scrollBy || pos.start === pos.end) { - return; - } - var delta = normalizeWheelDelta(event); - - if (transform) { - // Trap scrolling only when necessary and/or requested - if (delta > 0 && pos.dest < pos.end || delta < 0 && pos.dest > pos.start) { - //stopDefault(event, 1); - } - - self.slideBy(o.scrollBy * delta); - } else { - - if (isSmoothScrollSupported) { - delta *= 12; - } - - if (o.horizontal) { - nativeScrollElement.scrollLeft += delta; - } else { - nativeScrollElement.scrollTop += delta; - } - } - } - - /** - * Destroys instance and everything it created. - * - * @return {Void} - */ - self.destroy = function () { - - if (self.frameResizeObserver) { - self.frameResizeObserver.disconnect(); - self.frameResizeObserver = null; - } - - // Reset native FRAME element scroll - dom.removeEventListener(frame, 'scroll', resetScroll, { - passive: true - }); - - dom.removeEventListener(scrollSource, wheelEvent, scrollHandler, { - passive: true - }); - - dom.removeEventListener(dragSourceElement, 'touchstart', dragInitSlidee, { - passive: true - }); - - dom.removeEventListener(frame, 'click', onFrameClick, { - passive: true, - capture: true - }); - - dom.removeEventListener(dragSourceElement, 'mousedown', dragInitSlidee, { - //passive: true - }); - - // Reset initialized status and return the instance - self.initialized = 0; - return self; - }; - - var contentRect = {}; - - function onResize(entries) { - - var entry = entries[0]; - - if (entry) { - - var newRect = entry.contentRect; - - // handle element being hidden - if (newRect.width === 0 || newRect.height === 0) { - return; - } - - if (newRect.width !== contentRect.width || newRect.height !== contentRect.height) { - - contentRect = newRect; - - load(false); - } - } - } - - function resetScroll() { - if (o.horizontal) { - this.scrollLeft = 0; - } else { - this.scrollTop = 0; - } - } - - function onFrameClick(e) { - if (e.which === 1) { - var focusableParent = focusManager.focusableParent(e.target); - if (focusableParent && focusableParent !== document.activeElement) { - focusableParent.focus(); - } - } - } - - self.getScrollPosition = function () { - - if (transform) { - return self._pos.cur; - } - - if (o.horizontal) { - return nativeScrollElement.scrollLeft; - } else { - return nativeScrollElement.scrollTop; - } - }; - - self.getScrollSize = function () { - - if (transform) { - return slideeSize; - } - - if (o.horizontal) { - return nativeScrollElement.scrollWidth; - } else { - return nativeScrollElement.scrollHeight; - } - }; - - /** - * Initialize. - * - * @return {Object} - */ - self.init = function () { - if (self.initialized) { - return; - } - - if (!transform) { - if (o.horizontal) { - if (layoutManager.desktop && !o.hideScrollbar) { - nativeScrollElement.classList.add('scrollX'); - } else { - nativeScrollElement.classList.add('scrollX'); - nativeScrollElement.classList.add('hiddenScrollX'); - - if (layoutManager.tv && o.allowNativeSmoothScroll !== false) { - nativeScrollElement.classList.add('smoothScrollX'); - } - } - - if (o.forceHideScrollbars) { - nativeScrollElement.classList.add('hiddenScrollX-forced'); - } - } else { - if (layoutManager.desktop && !o.hideScrollbar) { - nativeScrollElement.classList.add('scrollY'); - } else { - nativeScrollElement.classList.add('scrollY'); - nativeScrollElement.classList.add('hiddenScrollY'); - - if (layoutManager.tv && o.allowNativeSmoothScroll !== false) { - nativeScrollElement.classList.add('smoothScrollY'); - } - } - - if (o.forceHideScrollbars) { - nativeScrollElement.classList.add('hiddenScrollY-forced'); - } - } - } else { - frame.style.overflow = 'hidden'; - slideeElement.style['will-change'] = 'transform'; - slideeElement.style.transition = 'transform ' + o.speed + 'ms ease-out'; - - if (o.horizontal) { - slideeElement.classList.add('animatedScrollX'); - } else { - slideeElement.classList.add('animatedScrollY'); - } - } - - if (transform || layoutManager.tv) { - // This can prevent others from being able to listen to mouse events - dom.addEventListener(dragSourceElement, 'mousedown', dragInitSlidee, { - //passive: true - }); - } - - initFrameResizeObserver(); - - if (transform) { - - dom.addEventListener(dragSourceElement, 'touchstart', dragInitSlidee, { - passive: true - }); - - if (!o.horizontal) { - dom.addEventListener(frame, 'scroll', resetScroll, { - passive: true - }); - } - - if (o.mouseWheel) { - // Scrolling navigation - dom.addEventListener(scrollSource, wheelEvent, scrollHandler, { - passive: true - }); - } - - } else if (o.horizontal) { - - // Don't bind to mouse events with vertical scroll since the mouse wheel can handle this natively - - if (o.mouseWheel) { - // Scrolling navigation - dom.addEventListener(scrollSource, wheelEvent, scrollHandler, { - passive: true - }); - } - } - - dom.addEventListener(frame, 'click', onFrameClick, { - passive: true, - capture: true - }); - - // Mark instance as initialized - self.initialized = 1; - - // Load - load(true); - - // Return instance - return self; - }; + // Need this for the magic wheel. With the animated scroll the magic wheel will run off of the screen + if (browser.web0s) { + options.enableNativeScroll = true; + } + + // Private variables + var self = this; + self.options = o; + + // Frame + var slideeElement = o.slidee ? o.slidee : sibling(frame.firstChild)[0]; + self._pos = { + start: 0, + center: 0, + end: 0, + cur: 0, + dest: 0 }; + var transform = !options.enableNativeScroll; + + // Miscellaneous + var scrollSource = frame; + var dragSourceElement = o.dragSource ? o.dragSource : frame; + var dragging = { + released: 1 + }; + var scrolling = { + last: 0, + delta: 0, + resetTime: 200 + }; + + // Expose properties + self.initialized = 0; + self.slidee = slideeElement; + self.options = o; + self.dragging = dragging; + + var nativeScrollElement = frame; + + function sibling(n, elem) { + var matched = []; + + for (; n; n = n.nextSibling) { + if (n.nodeType === 1 && n !== elem) { + matched.push(n); + } + } + return matched; + } + + var requiresReflow = true; + + var frameSize = 0; + var slideeSize = 0; + function ensureSizeInfo() { + if (requiresReflow) { + requiresReflow = false; + + // Reset global variables + frameSize = o.horizontal ? (frame).offsetWidth : (frame).offsetHeight; + + slideeSize = o.scrollWidth || Math.max(slideeElement[o.horizontal ? 'offsetWidth' : 'offsetHeight'], slideeElement[o.horizontal ? 'scrollWidth' : 'scrollHeight']); + + // Set position limits & relativess + self._pos.end = Math.max(slideeSize - frameSize, 0); + } + } + /** - * Slide SLIDEE by amount of pixels. + * Loading function. * - * @param {Int} delta Pixels/Items. Positive means forward, negative means backward. - * @param {Bool} immediate Reposition immediately without an animation. + * Populate arrays, set sizes, bind events, ... * + * @param {Boolean} [isInit] Whether load is called from within self.init(). * @return {Void} */ - scrollerFactory.prototype.slideBy = function (delta, immediate) { - if (!delta) { + function load(isInit) { + requiresReflow = true; + + if (!isInit) { + ensureSizeInfo(); + + // Fix possible overflowing + var pos = self._pos; + self.slideTo(within(pos.dest, pos.start, pos.end)); + } + } + + function initFrameResizeObserver() { + var observerOptions = {}; + + self.frameResizeObserver = new ResizeObserver(onResize, observerOptions); + + self.frameResizeObserver.observe(frame); + } + + self.reload = function () { + load(); + }; + + self.getScrollEventName = function () { + return transform ? 'scrollanimate' : 'scroll'; + }; + + self.getScrollSlider = function () { + return slideeElement; + }; + + self.getScrollFrame = function () { + return frame; + }; + + function nativeScrollTo(container, pos, immediate) { + if (container.scroll) { + if (o.horizontal) { + container.scroll({ + left: pos, + behavior: immediate ? 'instant' : 'smooth' + }); + } else { + container.scroll({ + top: pos, + behavior: immediate ? 'instant' : 'smooth' + }); + } + } else if (!immediate && container.scrollTo) { + if (o.horizontal) { + container.scrollTo(Math.Math.round(pos), 0); + } else { + container.scrollTo(0, Math.Math.round(pos)); + } + } else { + if (o.horizontal) { + container.scrollLeft = Math.Math.round(pos); + } else { + container.scrollTop = Math.Math.round(pos); + } + } + } + + var lastAnimate; + + /** + * Animate to a position. + * + * @param {Int} newPos New position. + * @param {Bool} immediate Reposition immediately without an animation. + * + * @return {Void} + */ + self.slideTo = function (newPos, immediate, fullItemPos) { + ensureSizeInfo(); + var pos = self._pos; + + newPos = within(newPos, pos.start, pos.end); + + if (!transform) { + nativeScrollTo(nativeScrollElement, newPos, immediate); return; } - this.slideTo(this._pos.dest + delta, immediate); - }; - /** - * Core method for handling `toLocation` methods. - * - * @param {String} location - * @param {Mixed} item - * @param {Bool} immediate - * - * @return {Void} - */ - scrollerFactory.prototype.to = function (location, item, immediate) { - // Optional arguments logic - if (type(item) === 'boolean') { - immediate = item; - item = undefined; - } + // Update the animation object + var from = pos.cur; + immediate = immediate || dragging.init || !o.speed; - if (item === undefined) { - this.slideTo(this._pos[location], immediate); - } else { - var itemPos = this.getPos(item); + var now = new Date().getTime(); - if (itemPos) { - this.slideTo(itemPos[location], immediate, itemPos); + if (o.autoImmediate) { + if (!immediate && (now - (lastAnimate || 0)) <= 50) { + immediate = true; } } + + if (!immediate && o.skipSlideToWhenVisible && fullItemPos && fullItemPos.isVisible) { + return; + } + + // Start animation rendering + // NOTE the dependency was modified here to fix a scrollbutton issue + pos.dest = newPos; + renderAnimateWithTransform(from, newPos, immediate); + lastAnimate = now; }; + function setStyleProperty(elem, name, value, speed, resetTransition) { + var style = elem.style; + + if (resetTransition || browser.edge) { + style.transition = 'none'; + void elem.offsetWidth; + } + + style.transition = 'transform ' + speed + 'ms ease-out'; + style[name] = value; + } + + function dispatchScrollEventIfNeeded() { + if (o.dispatchScrollEvent) { + frame.dispatchEvent(new CustomEvent(self.getScrollEventName(), { + bubbles: true, + cancelable: false + })); + } + } + + function renderAnimateWithTransform(fromPosition, toPosition, immediate) { + var speed = o.speed; + + if (immediate) { + speed = o.immediateSpeed || 50; + } + + if (o.horizontal) { + setStyleProperty(slideeElement, 'transform', 'translateX(' + (-Math.round(toPosition)) + 'px)', speed); + } else { + setStyleProperty(slideeElement, 'transform', 'translateY(' + (-Math.round(toPosition)) + 'px)', speed); + } + self._pos.cur = toPosition; + + dispatchScrollEventIfNeeded(); + } + + function getBoundingClientRect(elem) { + // Support: BlackBerry 5, iOS 3 (original iPhone) + // If we don't have gBCR, just use 0,0 rather than error + if (elem.getBoundingClientRect) { + return elem.getBoundingClientRect(); + } else { + return { top: 0, left: 0 }; + } + } + /** - * Animate element or the whole SLIDEE to the start of the frame. + * Returns the position object. * - * @param {Mixed} item Item DOM element, or index starting at 0. Omitting will animate SLIDEE. - * @param {Bool} immediate Reposition immediately without an animation. + * @param {Mixed} item + * + * @return {Object} + */ + self.getPos = function (item) { + var scrollElement = transform ? slideeElement : nativeScrollElement; + var slideeOffset = getBoundingClientRect(scrollElement); + var itemOffset = getBoundingClientRect(item); + + var offset = o.horizontal ? itemOffset.left - slideeOffset.left : itemOffset.top - slideeOffset.top; + + var size = o.horizontal ? itemOffset.width : itemOffset.height; + if (!size && size !== 0) { + size = item[o.horizontal ? 'offsetWidth' : 'offsetHeight']; + } + + var centerOffset = o.centerOffset || 0; + + if (!transform) { + centerOffset = 0; + if (o.horizontal) { + offset += nativeScrollElement.scrollLeft; + } else { + offset += nativeScrollElement.scrollTop; + } + } + + ensureSizeInfo(); + + var currentStart = self._pos.cur; + var currentEnd = currentStart + frameSize; + + console.debug('offset:' + offset + ' currentStart:' + currentStart + ' currentEnd:' + currentEnd); + var isVisible = offset >= currentStart && (offset + size) <= currentEnd; + + return { + start: offset, + center: offset + centerOffset - (frameSize / 2) + (size / 2), + end: offset - frameSize + size, + size: size, + isVisible: isVisible + }; + }; + + self.getCenterPosition = function (item) { + ensureSizeInfo(); + + var pos = self.getPos(item); + return within(pos.center, pos.start, pos.end); + }; + + function dragInitSlidee(event) { + var isTouch = event.type === 'touchstart'; + + // Ignore when already in progress, or interactive element in non-touch navivagion + if (dragging.init || !isTouch && isInteractive(event.target)) { + return; + } + + // SLIDEE dragging conditions + if (!(isTouch ? o.touchDragging : o.mouseDragging && event.which < 2)) { + return; + } + + if (!isTouch) { + // prevents native image dragging in Firefox + event.preventDefault(); + } + + // Reset dragging object + dragging.released = 0; + + // Properties used in dragHandler + dragging.init = 0; + dragging.source = event.target; + dragging.touch = isTouch; + var pointer = isTouch ? event.touches[0] : event; + dragging.initX = pointer.pageX; + dragging.initY = pointer.pageY; + dragging.initPos = self._pos.cur; + dragging.start = +new Date(); + dragging.time = 0; + dragging.path = 0; + dragging.delta = 0; + dragging.locked = 0; + dragging.pathToLock = isTouch ? 30 : 10; + + // Bind dragging events + if (transform) { + if (isTouch) { + dragTouchEvents.forEach(function (eventName) { + dom.addEventListener(document, eventName, dragHandler, { + passive: true + }); + }); + } else { + dragMouseEvents.forEach(function (eventName) { + dom.addEventListener(document, eventName, dragHandler, { + passive: true + }); + }); + } + } + } + + /** + * Handler for dragging scrollbar handle or SLIDEE. + * + * @param {Event} event * * @return {Void} */ - scrollerFactory.prototype.toStart = function (item, immediate) { - this.to('start', item, immediate); - }; + function dragHandler(event) { + dragging.released = event.type === 'mouseup' || event.type === 'touchend'; + var pointer = dragging.touch ? event[dragging.released ? 'changedTouches' : 'touches'][0] : event; + dragging.pathX = pointer.pageX - dragging.initX; + dragging.pathY = pointer.pageY - dragging.initY; + dragging.path = Math.sqrt(Math.pow(dragging.pathX, 2) + Math.pow(dragging.pathY, 2)); + dragging.delta = o.horizontal ? dragging.pathX : dragging.pathY; + + if (!dragging.released && dragging.path < 1) { + return; + } + + // We haven't decided whether this is a drag or not... + if (!dragging.init) { + // If the drag path was very short, maybe it's not a drag? + if (dragging.path < o.dragThreshold) { + // If the pointer was released, the path will not become longer and it's + // definitely not a drag. If not released yet, decide on next iteration + return dragging.released ? dragEnd() : undefined; + } else { + // If dragging path is sufficiently long we can confidently start a drag + // if drag is in different direction than scroll, ignore it + if (o.horizontal ? Math.abs(dragging.pathX) > Math.abs(dragging.pathY) : Math.abs(dragging.pathX) < Math.abs(dragging.pathY)) { + dragging.init = 1; + } else { + return dragEnd(); + } + } + } + + //event.preventDefault(); + + // Disable click on a source element, as it is unwelcome when dragging + if (!dragging.locked && dragging.path > dragging.pathToLock) { + dragging.locked = 1; + dragging.source.addEventListener('click', disableOneEvent); + } + + // Cancel dragging on release + if (dragging.released) { + dragEnd(); + } + + self.slideTo(Math.round(dragging.initPos - dragging.delta)); + } /** - * Animate element or the whole SLIDEE to the end of the frame. - * - * @param {Mixed} item Item DOM element, or index starting at 0. Omitting will animate SLIDEE. - * @param {Bool} immediate Reposition immediately without an animation. + * Stops dragging and cleans up after it. * * @return {Void} */ - scrollerFactory.prototype.toEnd = function (item, immediate) { - this.to('end', item, immediate); - }; + function dragEnd() { + dragging.released = true; + + dragTouchEvents.forEach(function (eventName) { + dom.removeEventListener(document, eventName, dragHandler, { + passive: true + }); + }); + + dragMouseEvents.forEach(function (eventName) { + dom.removeEventListener(document, eventName, dragHandler, { + passive: true + }); + }); + + // Make sure that disableOneEvent is not active in next tick. + setTimeout(function () { + dragging.source.removeEventListener('click', disableOneEvent); + }); + + dragging.init = 0; + } /** - * Animate element or the whole SLIDEE to the center of the frame. + * Check whether element is interactive. * - * @param {Mixed} item Item DOM element, or index starting at 0. Omitting will animate SLIDEE. - * @param {Bool} immediate Reposition immediately without an animation. + * @return {Boolean} + */ + function isInteractive(element) { + while (element) { + if (interactiveElements.indexOf(element.tagName) !== -1) { + return true; + } + + element = element.parentNode; + } + return false; + } + + /** + * Mouse wheel delta normalization. + * + * @param {Event} event + * + * @return {Int} + */ + function normalizeWheelDelta(event) { + // JELLYFIN MOD: Only use deltaX for horizontal scroll and remove IE8 support + scrolling.curDelta = o.horizontal ? event.deltaX : event.deltaY; + // END JELLYFIN MOD + + if (transform) { + scrolling.curDelta /= event.deltaMode === 1 ? 3 : 100; + } + return scrolling.curDelta; + } + + /** + * Mouse scrolling handler. + * + * @param {Event} event * * @return {Void} */ - scrollerFactory.prototype.toCenter = function (item, immediate) { - this.to('center', item, immediate); + function scrollHandler(event) { + ensureSizeInfo(); + var pos = self._pos; + // Ignore if there is no scrolling to be done + if (!o.scrollBy || pos.start === pos.end) { + return; + } + var delta = normalizeWheelDelta(event); + + if (transform) { + // Trap scrolling only when necessary and/or requested + if (delta > 0 && pos.dest < pos.end || delta < 0 && pos.dest > pos.start) { + //stopDefault(event, 1); + } + + self.slideBy(o.scrollBy * delta); + } else { + if (isSmoothScrollSupported) { + delta *= 12; + } + + if (o.horizontal) { + nativeScrollElement.scrollLeft += delta; + } else { + nativeScrollElement.scrollTop += delta; + } + } + } + + /** + * Destroys instance and everything it created. + * + * @return {Void} + */ + self.destroy = function () { + if (self.frameResizeObserver) { + self.frameResizeObserver.disconnect(); + self.frameResizeObserver = null; + } + + // Reset native FRAME element scroll + dom.removeEventListener(frame, 'scroll', resetScroll, { + passive: true + }); + + dom.removeEventListener(scrollSource, wheelEvent, scrollHandler, { + passive: true + }); + + dom.removeEventListener(dragSourceElement, 'touchstart', dragInitSlidee, { + passive: true + }); + + dom.removeEventListener(frame, 'click', onFrameClick, { + passive: true, + capture: true + }); + + dom.removeEventListener(dragSourceElement, 'mousedown', dragInitSlidee, { + //passive: true + }); + + // Reset initialized status and return the instance + self.initialized = 0; + return self; }; - scrollerFactory.create = function (frame, options) { - var instance = new scrollerFactory(frame, options); - return Promise.resolve(instance); + var contentRect = {}; + + function onResize(entries) { + var entry = entries[0]; + + if (entry) { + var newRect = entry.contentRect; + + // handle element being hidden + if (newRect.width === 0 || newRect.height === 0) { + return; + } + + if (newRect.width !== contentRect.width || newRect.height !== contentRect.height) { + contentRect = newRect; + + load(false); + } + } + } + + function resetScroll() { + if (o.horizontal) { + this.scrollLeft = 0; + } else { + this.scrollTop = 0; + } + } + + function onFrameClick(e) { + if (e.which === 1) { + var focusableParent = focusManager.focusableParent(e.target); + if (focusableParent && focusableParent !== document.activeElement) { + focusableParent.focus(); + } + } + } + + self.getScrollPosition = function () { + if (transform) { + return self._pos.cur; + } + + if (o.horizontal) { + return nativeScrollElement.scrollLeft; + } else { + return nativeScrollElement.scrollTop; + } }; - return scrollerFactory; -}); + self.getScrollSize = function () { + if (transform) { + return slideeSize; + } + + if (o.horizontal) { + return nativeScrollElement.scrollWidth; + } else { + return nativeScrollElement.scrollHeight; + } + }; + + /** + * Initialize. + * + * @return {Object} + */ + self.init = function () { + if (self.initialized) { + return; + } + + if (!transform) { + if (o.horizontal) { + if (layoutManager.desktop && !o.hideScrollbar) { + nativeScrollElement.classList.add('scrollX'); + } else { + nativeScrollElement.classList.add('scrollX'); + nativeScrollElement.classList.add('hiddenScrollX'); + + if (layoutManager.tv && o.allowNativeSmoothScroll !== false) { + nativeScrollElement.classList.add('smoothScrollX'); + } + } + + if (o.forceHideScrollbars) { + nativeScrollElement.classList.add('hiddenScrollX-forced'); + } + } else { + if (layoutManager.desktop && !o.hideScrollbar) { + nativeScrollElement.classList.add('scrollY'); + } else { + nativeScrollElement.classList.add('scrollY'); + nativeScrollElement.classList.add('hiddenScrollY'); + + if (layoutManager.tv && o.allowNativeSmoothScroll !== false) { + nativeScrollElement.classList.add('smoothScrollY'); + } + } + + if (o.forceHideScrollbars) { + nativeScrollElement.classList.add('hiddenScrollY-forced'); + } + } + } else { + frame.style.overflow = 'hidden'; + slideeElement.style['will-change'] = 'transform'; + slideeElement.style.transition = 'transform ' + o.speed + 'ms ease-out'; + + if (o.horizontal) { + slideeElement.classList.add('animatedScrollX'); + } else { + slideeElement.classList.add('animatedScrollY'); + } + } + + if (transform || layoutManager.tv) { + // This can prevent others from being able to listen to mouse events + dom.addEventListener(dragSourceElement, 'mousedown', dragInitSlidee, { + //passive: true + }); + } + + initFrameResizeObserver(); + + if (transform) { + dom.addEventListener(dragSourceElement, 'touchstart', dragInitSlidee, { + passive: true + }); + + if (!o.horizontal) { + dom.addEventListener(frame, 'scroll', resetScroll, { + passive: true + }); + } + + if (o.mouseWheel) { + // Scrolling navigation + dom.addEventListener(scrollSource, wheelEvent, scrollHandler, { + passive: true + }); + } + } else if (o.horizontal) { + // Don't bind to mouse events with vertical scroll since the mouse wheel can handle this natively + + if (o.mouseWheel) { + // Scrolling navigation + dom.addEventListener(scrollSource, wheelEvent, scrollHandler, { + passive: true + }); + } + } + + dom.addEventListener(frame, 'click', onFrameClick, { + passive: true, + capture: true + }); + + // Mark instance as initialized + self.initialized = 1; + + // Load + load(true); + + // Return instance + return self; + }; +}; + +/** + * Slide SLIDEE by amount of pixels. + * + * @param {Int} delta Pixels/Items. Positive means forward, negative means backward. + * @param {Bool} immediate Reposition immediately without an animation. + * + * @return {Void} + */ +scrollerFactory.prototype.slideBy = function (delta, immediate) { + if (!delta) { + return; + } + this.slideTo(this._pos.dest + delta, immediate); +}; + +/** + * Core method for handling `toLocation` methods. + * + * @param {String} location + * @param {Mixed} item + * @param {Bool} immediate + * + * @return {Void} + */ +scrollerFactory.prototype.to = function (location, item, immediate) { + // Optional arguments logic + if (type(item) === 'boolean') { + immediate = item; + item = undefined; + } + + if (item === undefined) { + this.slideTo(this._pos[location], immediate); + } else { + var itemPos = this.getPos(item); + + if (itemPos) { + this.slideTo(itemPos[location], immediate, itemPos); + } + } +}; + +/** + * Animate element or the whole SLIDEE to the start of the frame. + * + * @param {Mixed} item Item DOM element, or index starting at 0. Omitting will animate SLIDEE. + * @param {Bool} immediate Reposition immediately without an animation. + * + * @return {Void} + */ +scrollerFactory.prototype.toStart = function (item, immediate) { + this.to('start', item, immediate); +}; + +/** + * Animate element or the whole SLIDEE to the end of the frame. + * + * @param {Mixed} item Item DOM element, or index starting at 0. Omitting will animate SLIDEE. + * @param {Bool} immediate Reposition immediately without an animation. + * + * @return {Void} + */ +scrollerFactory.prototype.toEnd = function (item, immediate) { + this.to('end', item, immediate); +}; + +/** + * Animate element or the whole SLIDEE to the center of the frame. + * + * @param {Mixed} item Item DOM element, or index starting at 0. Omitting will animate SLIDEE. + * @param {Bool} immediate Reposition immediately without an animation. + * + * @return {Void} + */ +scrollerFactory.prototype.toCenter = function (item, immediate) { + this.to('center', item, immediate); +}; + +scrollerFactory.create = function (frame, options) { + var instance = new scrollerFactory(frame, options); + return Promise.resolve(instance); +}; + +export default scrollerFactory; From 1ef55292446b4cfddb7389671dc23b9934ad92b9 Mon Sep 17 00:00:00 2001 From: MrTimscampi Date: Sat, 1 Aug 2020 03:01:32 +0200 Subject: [PATCH 056/301] Migrate PluginManager to ES6 --- package.json | 1 + src/components/packageManager.js | 2 + src/components/pluginManager.js | 214 +++++++++++++------------- src/plugins/logoScreensaver/plugin.js | 2 + src/scripts/site.js | 5 +- 5 files changed, 117 insertions(+), 107 deletions(-) diff --git a/package.json b/package.json index bf3ac42f97..819d27a1f6 100644 --- a/package.json +++ b/package.json @@ -152,6 +152,7 @@ "src/components/playerstats/playerstats.js", "src/components/playlisteditor/playlisteditor.js", "src/components/playmenu.js", + "src/components/pluginManager.js", "src/components/prompt/prompt.js", "src/components/recordingcreator/seriesrecordingeditor.js", "src/components/recordingcreator/recordinghelper.js", diff --git a/src/components/packageManager.js b/src/components/packageManager.js index 936f5a4029..d2b3ed5857 100644 --- a/src/components/packageManager.js +++ b/src/components/packageManager.js @@ -1,6 +1,8 @@ define(['appSettings', 'pluginManager'], function (appSettings, pluginManager) { 'use strict'; + pluginManager = pluginManager.default || pluginManager; + var settingsKey = 'installedpackages1'; function addPackage(packageManager, pkg) { diff --git a/src/components/pluginManager.js b/src/components/pluginManager.js index df4a0c42b7..14f4fdecf9 100644 --- a/src/components/pluginManager.js +++ b/src/components/pluginManager.js @@ -1,37 +1,38 @@ -define(['events', 'globalize'], function (events, globalize) { - 'use strict'; +import events from 'events'; +import globalize from 'globalize'; +/* eslint-disable indent */ // TODO: replace with each plugin version var cacheParam = new Date().getTime(); - function loadStrings(plugin) { - var strings = plugin.getTranslations ? plugin.getTranslations() : []; - return globalize.loadStrings({ - name: plugin.id || plugin.packageName, - strings: strings - }); - } + class PluginManager { + pluginsList = []; - function definePluginRoute(pluginManager, route, plugin) { - route.contentPath = pluginManager.mapPath(plugin, route.path); - route.path = pluginManager.mapRoute(plugin, route); + get plugins() { + return this.pluginsList; + } - Emby.App.defineRoute(route, plugin.id); - } + #loadStrings(plugin) { + var strings = plugin.getTranslations ? plugin.getTranslations() : []; + return globalize.loadStrings({ + name: plugin.id || plugin.packageName, + strings: strings + }); + } - function PluginManager() { - this.pluginsList = []; - } + #definePluginRoute(route, plugin) { + route.contentPath = this.#mapPath(plugin, route.path); + route.path = this.mapRoute(plugin, route); - PluginManager.prototype.loadPlugin = function(pluginSpec) { - var instance = this; + Emby.App.defineRoute(route, plugin.id); + } - function registerPlugin(plugin) { - instance.register(plugin); + #registerPlugin(plugin) { + this.#register(plugin); if (plugin.getRoutes) { - plugin.getRoutes().forEach(function (route) { - definePluginRoute(instance, route, plugin); + plugin.getRoutes().forEach((route) => { + this.#definePluginRoute(route, plugin); }); } @@ -40,7 +41,7 @@ define(['events', 'globalize'], function (events, globalize) { return Promise.resolve(plugin); } else { return new Promise((resolve, reject) => { - loadStrings(plugin) + this.#loadStrings(plugin) .then(function () { resolve(plugin); }) @@ -49,103 +50,106 @@ define(['events', 'globalize'], function (events, globalize) { } } - if (typeof pluginSpec === 'string') { - console.debug('Loading plugin (via deprecated requirejs method): ' + pluginSpec); + loadPlugin(pluginSpec) { + var instance = this; - return new Promise(function (resolve, reject) { - require([pluginSpec], (pluginFactory) => { - var plugin = pluginFactory.default ? new pluginFactory.default() : new pluginFactory(); + if (typeof pluginSpec === 'string') { + console.debug('Loading plugin (via deprecated requirejs method): ' + pluginSpec); - // See if it's already installed - var existing = instance.pluginsList.filter(function (p) { - return p.id === plugin.id; - })[0]; + return new Promise((resolve, reject) => { + require([pluginSpec], (pluginFactory) => { + var plugin = pluginFactory.default ? new pluginFactory.default() : new pluginFactory(); - if (existing) { - resolve(pluginSpec); - } + // See if it's already installed + var existing = this.pluginsList.filter(function (p) { + return p.id === plugin.id; + })[0]; - plugin.installUrl = pluginSpec; + if (existing) { + resolve(pluginSpec); + } - var separatorIndex = Math.max(pluginSpec.lastIndexOf('/'), pluginSpec.lastIndexOf('\\')); - plugin.baseUrl = pluginSpec.substring(0, separatorIndex); + plugin.installUrl = pluginSpec; - var paths = {}; - paths[plugin.id] = plugin.baseUrl; + var separatorIndex = Math.max(pluginSpec.lastIndexOf('/'), pluginSpec.lastIndexOf('\\')); + plugin.baseUrl = pluginSpec.substring(0, separatorIndex); - requirejs.config({ - waitSeconds: 0, - paths: paths + var paths = {}; + paths[plugin.id] = plugin.baseUrl; + + requirejs.config({ + waitSeconds: 0, + paths: paths + }); + + this.#registerPlugin(plugin).then(resolve).catch(reject); }); - - registerPlugin(plugin).then(resolve).catch(reject); }); + } else if (pluginSpec.then) { + return pluginSpec.then(pluginBuilder => { + return pluginBuilder(); + }).then((plugin) => { + console.debug(`Plugin loaded: ${plugin.id}`); + return this.#registerPlugin(plugin); + }); + } else { + const err = new TypeError('Plugins have to be a Promise that resolves to a plugin builder function or a RequireJS url (deprecated)'); + console.error(err); + return Promise.reject(err); + } + } + + // In lieu of automatic discovery, plugins will register dynamic objects + // Each object will have the following properties: + // name + // type (skin, screensaver, etc) + #register(obj) { + this.pluginsList.push(obj); + events.trigger(this, 'registered', [obj]); + } + + ofType(type) { + return this.pluginsList.filter((o) => { + return o.type === type; }); - } else if (pluginSpec.then) { - return pluginSpec.then(pluginBuilder => { - return pluginBuilder(); - }).then(plugin => { - console.debug(`Plugin loaded: ${plugin.id}`); - return registerPlugin(plugin); - }); - } else { - const err = new Error('Plugins have to be a Promise that resolves to a plugin builder function or a requirejs urls (deprecated)'); - console.error(err); - return Promise.reject(err); - } - }; - - // In lieu of automatic discovery, plugins will register dynamic objects - // Each object will have the following properties: - // name - // type (skin, screensaver, etc) - PluginManager.prototype.register = function (obj) { - this.pluginsList.push(obj); - events.trigger(this, 'registered', [obj]); - }; - - PluginManager.prototype.ofType = function (type) { - return this.pluginsList.filter(function (o) { - return o.type === type; - }); - }; - - PluginManager.prototype.plugins = function () { - return this.pluginsList; - }; - - PluginManager.prototype.mapRoute = function (plugin, route) { - if (typeof plugin === 'string') { - plugin = this.pluginsList.filter(function (p) { - return (p.id || p.packageName) === plugin; - })[0]; } - route = route.path || route; + #mapRoute(plugin, route) { + if (typeof plugin === 'string') { + plugin = this.pluginsList.filter((p) => { + return (p.id || p.packageName) === plugin; + })[0]; + } - if (route.toLowerCase().indexOf('http') === 0) { - return route; + route = route.path || route; + + if (route.toLowerCase().startsWith('http')) { + return route; + } + + return '/plugins/' + plugin.id + '/' + route; } - return '/plugins/' + plugin.id + '/' + route; - }; + #mapPath(plugin, path, addCacheParam) { + if (typeof plugin === 'string') { + plugin = this.pluginsList.filter((p) => { + return (p.id || p.packageName) === plugin; + })[0]; + } - PluginManager.prototype.mapPath = function (plugin, path, addCacheParam) { - if (typeof plugin === 'string') { - plugin = this.pluginsList.filter(function (p) { - return (p.id || p.packageName) === plugin; - })[0]; + console.dir(plugin); + + var url = plugin.baseUrl + '/' + path; + + if (addCacheParam) { + url += url.includes('?') ? '&' : '?'; + url += 'v=' + cacheParam; + } + + return url; } + } - var url = plugin.baseUrl + '/' + path; +/* eslint-enable indent */ - if (addCacheParam) { - url += url.indexOf('?') === -1 ? '?' : '&'; - url += 'v=' + cacheParam; - } - - return url; - }; - - return new PluginManager(); -}); +export default new PluginManager(); diff --git a/src/plugins/logoScreensaver/plugin.js b/src/plugins/logoScreensaver/plugin.js index bdd1d34e79..542649ecef 100644 --- a/src/plugins/logoScreensaver/plugin.js +++ b/src/plugins/logoScreensaver/plugin.js @@ -1,4 +1,6 @@ define(['pluginManager'], function (pluginManager) { + pluginManager = pluginManager.default || pluginManager; + return function () { var self = this; diff --git a/src/scripts/site.js b/src/scripts/site.js index cd85c35e83..876b717877 100644 --- a/src/scripts/site.js +++ b/src/scripts/site.js @@ -476,7 +476,7 @@ function initClient() { } function loadPlugins(appHost, browser, shell) { - console.debug('loading installed plugins'); + console.groupCollapsed('loading installed plugins'); return new Promise(function (resolve, reject) { require(['webSettings'], function (webSettings) { webSettings.getPlugins().then(function (list) { @@ -495,6 +495,7 @@ function initClient() { } Promise.all(list.map(loadPlugin)).then(function () { + console.groupEnd('loading installed plugins'); require(['packageManager'], function (packageManager) { packageManager.init().then(resolve, reject); }); @@ -507,7 +508,7 @@ function initClient() { function loadPlugin(url) { return new Promise(function (resolve, reject) { require(['pluginManager'], function (pluginManager) { - pluginManager.loadPlugin(url).then(resolve, reject); + pluginManager.default.loadPlugin(url).then(resolve, reject); }); }); } From ca5f194ee6ca2bd27081fb0d5f00e75d5e5ec14b Mon Sep 17 00:00:00 2001 From: MrTimscampi Date: Sat, 1 Aug 2020 03:51:44 +0200 Subject: [PATCH 057/301] Migrate packageManager to ES6 --- package.json | 1 + src/components/packageManager.js | 223 ++++++++++++++++--------------- src/scripts/site.js | 2 +- 3 files changed, 114 insertions(+), 112 deletions(-) diff --git a/package.json b/package.json index 819d27a1f6..46e5691c34 100644 --- a/package.json +++ b/package.json @@ -137,6 +137,7 @@ "src/components/metadataEditor/personEditor.js", "src/components/multiSelect/multiSelect.js", "src/components/nowPlayingBar/nowPlayingBar.js", + "src/components/packageManager.js", "src/components/playback/brightnessosd.js", "src/components/playback/mediasession.js", "src/components/playback/nowplayinghelper.js", diff --git a/src/components/packageManager.js b/src/components/packageManager.js index d2b3ed5857..7e2b1362c7 100644 --- a/src/components/packageManager.js +++ b/src/components/packageManager.js @@ -1,136 +1,137 @@ -define(['appSettings', 'pluginManager'], function (appSettings, pluginManager) { - 'use strict'; +import appSettings from 'appSettings'; +import pluginManager from 'pluginManager'; +/* eslint-disable indent */ - pluginManager = pluginManager.default || pluginManager; + class PackageManager { + #packagesList = []; + #settingsKey = 'installedpackages1'; - var settingsKey = 'installedpackages1'; + init() { + console.groupCollapsed('loading packages'); + var manifestUrls = JSON.parse(appSettings.get(this.#settingsKey) || '[]'); - function addPackage(packageManager, pkg) { - packageManager.packagesList = packageManager.packagesList.filter(function (p) { - return p.name !== pkg.name; - }); + var instance = this; + return Promise.all(manifestUrls.map((u) => { + return this.loadPackage(instance, u); + })).then(() => { + console.groupEnd('loading packages'); + return Promise.resolve(); + }, () => { + return Promise.resolve(); + }); + } - packageManager.packagesList.push(pkg); - } + get packages() { + return this.#packagesList.slice(0); + } - function removeUrl(url) { - var manifestUrls = JSON.parse(appSettings.get(settingsKey) || '[]'); + install(url) { + return this.loadPackage(this, url, true).then((pkg) => { + var manifestUrls = JSON.parse(appSettings.get(this.#settingsKey) || '[]'); - manifestUrls = manifestUrls.filter(function (i) { - return i !== url; - }); - - appSettings.set(settingsKey, JSON.stringify(manifestUrls)); - } - - function loadPackage(packageManager, url, throwError) { - return new Promise(function (resolve, reject) { - var xhr = new XMLHttpRequest(); - var originalUrl = url; - url += url.indexOf('?') === -1 ? '?' : '&'; - url += 't=' + new Date().getTime(); - - xhr.open('GET', url, true); - - var onError = function () { - if (throwError === true) { - reject(); - } else { - removeUrl(originalUrl); - resolve(); + if (!manifestUrls.includes(url)) { + manifestUrls.push(url); + appSettings.set(this.#settingsKey, JSON.stringify(manifestUrls)); } - }; - xhr.onload = function (e) { - if (this.status < 400) { - var pkg = JSON.parse(this.response); - pkg.url = originalUrl; + return pkg; + }); + } - addPackage(packageManager, pkg); + uninstall(name) { + var pkg = this.#packagesList.filter((p) => { + return p.name === name; + })[0]; - var plugins = pkg.plugins || []; - if (pkg.plugin) { - plugins.push(pkg.plugin); - } - var promises = plugins.map(function (pluginUrl) { - return pluginManager.loadPlugin(packageManager.mapPath(pkg, pluginUrl)); - }); - Promise.all(promises).then(resolve, resolve); - } else { - onError(); - } - }; + if (pkg) { + this.#packagesList = this.#packagesList.filter((p) => { + return p.name !== name; + }); - xhr.onerror = onError; - - xhr.send(); - }); - } - - function PackageManager() { - this.packagesList = []; - } - - PackageManager.prototype.init = function () { - var manifestUrls = JSON.parse(appSettings.get(settingsKey) || '[]'); - - var instance = this; - return Promise.all(manifestUrls.map(function (u) { - return loadPackage(instance, u); - })).then(function () { - return Promise.resolve(); - }, function () { - return Promise.resolve(); - }); - }; - - PackageManager.prototype.packages = function () { - return this.packagesList.slice(0); - }; - - PackageManager.prototype.install = function (url) { - return loadPackage(this, url, true).then(function (pkg) { - var manifestUrls = JSON.parse(appSettings.get(settingsKey) || '[]'); - - if (manifestUrls.indexOf(url) === -1) { - manifestUrls.push(url); - appSettings.set(settingsKey, JSON.stringify(manifestUrls)); + this.removeUrl(pkg.url); } - return pkg; - }); - }; + return Promise.resolve(); + } - PackageManager.prototype.uninstall = function (name) { - var pkg = this.packagesList.filter(function (p) { - return p.name === name; - })[0]; + mapPath(pkg, pluginUrl) { + var urlLower = pluginUrl.toLowerCase(); + if (urlLower.startsWith('http:') || urlLower.startsWith('https:') || urlLower.startsWith('file:')) { + return pluginUrl; + } - if (pkg) { - this.packagesList = this.packagesList.filter(function (p) { - return p.name !== name; + var packageUrl = pkg.url; + packageUrl = packageUrl.substring(0, packageUrl.lastIndexOf('/')); + + packageUrl += '/'; + packageUrl += pluginUrl; + + return packageUrl; + } + + addPackage(packageManager, pkg) { + packageManager.packagesList = packageManager.packagesList.filter((p) => { + return p.name !== pkg.name; }); - removeUrl(pkg.url); + packageManager.packagesList.push(pkg); } - return Promise.resolve(); - }; + removeUrl(url) { + var manifestUrls = JSON.parse(appSettings.get(this.#settingsKey) || '[]'); - PackageManager.prototype.mapPath = function (pkg, pluginUrl) { - var urlLower = pluginUrl.toLowerCase(); - if (urlLower.indexOf('http:') === 0 || urlLower.indexOf('https:') === 0 || urlLower.indexOf('file:') === 0) { - return pluginUrl; + manifestUrls = manifestUrls.filter((i) => { + return i !== url; + }); + + appSettings.set(this.#settingsKey, JSON.stringify(manifestUrls)); } - var packageUrl = pkg.url; - packageUrl = packageUrl.substring(0, packageUrl.lastIndexOf('/')); + loadPackage(packageManager, url, throwError) { + return new Promise((resolve, reject) => { + var xhr = new XMLHttpRequest(); + var originalUrl = url; + url += url.indexOf('?') === -1 ? '?' : '&'; + url += 't=' + new Date().getTime(); - packageUrl += '/'; - packageUrl += pluginUrl; + xhr.open('GET', url, true); - return packageUrl; - }; + var onError = () => { + if (throwError === true) { + reject(); + } else { + this.removeUrl(originalUrl); + resolve(); + } + }; - return new PackageManager(); -}); + xhr.onload = (e) => { + if (this.status < 400) { + var pkg = JSON.parse(this.response); + pkg.url = originalUrl; + + this.addPackage(packageManager, pkg); + + var plugins = pkg.plugins || []; + if (pkg.plugin) { + plugins.push(pkg.plugin); + } + var promises = plugins.map((pluginUrl) => { + return pluginManager.loadPlugin(packageManager.mapPath(pkg, pluginUrl)); + }); + Promise.all(promises).then(resolve, resolve); + } else { + onError(); + } + }; + + xhr.onerror = onError; + + xhr.send(); + }); + } + } + +/* eslint-enable indent */ + +export default new PackageManager(); diff --git a/src/scripts/site.js b/src/scripts/site.js index 876b717877..7b5a72c042 100644 --- a/src/scripts/site.js +++ b/src/scripts/site.js @@ -497,7 +497,7 @@ function initClient() { Promise.all(list.map(loadPlugin)).then(function () { console.groupEnd('loading installed plugins'); require(['packageManager'], function (packageManager) { - packageManager.init().then(resolve, reject); + packageManager.default.init().then(resolve, reject); }); }, reject); }); From 4cd83e6f73a7c21e01881e0c2cae2399222bcde6 Mon Sep 17 00:00:00 2001 From: MrTimscampi Date: Sat, 1 Aug 2020 04:07:00 +0200 Subject: [PATCH 058/301] Fix linting errors --- .eslintrc.js | 7 ++++--- src/components/cardbuilder/cardBuilder.js | 6 +++--- src/plugins/htmlVideoPlayer/plugin.js | 22 +++++++++++----------- src/scripts/editorsidebar.js | 2 +- src/scripts/keyboardNavigation.js | 2 +- 5 files changed, 20 insertions(+), 19 deletions(-) diff --git a/.eslintrc.js b/.eslintrc.js index ff12e198c3..c9d5ed917c 100644 --- a/.eslintrc.js +++ b/.eslintrc.js @@ -40,12 +40,12 @@ module.exports = { 'no-multi-spaces': ['error'], 'no-multiple-empty-lines': ['error', { 'max': 1 }], 'no-trailing-spaces': ['error'], - 'no-unused-expressions': ['error', { 'allowShortCircuit': true, 'allowTernary': true, 'allowTaggedTemplates': true }], - 'no-unused-vars': ['error', { 'vars': 'all', 'args': 'none', 'ignoreRestSiblings': true }], + '@babel/no-unused-expressions': ['error', { 'allowShortCircuit': true, 'allowTernary': true, 'allowTaggedTemplates': true }], + //'no-unused-vars': ['error', { 'vars': 'all', 'args': 'none', 'ignoreRestSiblings': true }], 'one-var': ['error', 'never'], 'padded-blocks': ['error', 'never'], 'quotes': ['error', 'single', { 'avoidEscape': true, 'allowTemplateLiterals': false }], - 'semi': ['error'], + '@babel/semi': ['error'], 'space-before-blocks': ['error'], 'space-infix-ops': 'error', 'yoda': 'error' @@ -105,6 +105,7 @@ module.exports = { // TODO: Fix warnings and remove these rules 'no-redeclare': ['off'], 'no-useless-escape': ['off'], + 'no-unused-vars': ['off'], // TODO: Remove after ES6 migration is complete 'import/no-unresolved': ['off'] }, diff --git a/src/components/cardbuilder/cardBuilder.js b/src/components/cardbuilder/cardBuilder.js index 4a37331ef4..64cc7dab9b 100644 --- a/src/components/cardbuilder/cardBuilder.js +++ b/src/components/cardbuilder/cardBuilder.js @@ -1117,7 +1117,7 @@ import 'programStyles'; function importRefreshIndicator() { if (!refreshIndicatorLoaded) { refreshIndicatorLoaded = true; - /* eslint-disable-next-line no-unused-expressions */ + /* eslint-disable-next-line @babel/no-unused-expressions */ import('emby-itemrefreshindicator'); } } @@ -1449,7 +1449,7 @@ import 'programStyles'; const userData = item.UserData || {}; if (itemHelper.canMarkPlayed(item)) { - /* eslint-disable-next-line no-unused-expressions */ + /* eslint-disable-next-line @babel/no-unused-expressions */ import('emby-playstatebutton'); html += ''; } @@ -1457,7 +1457,7 @@ import 'programStyles'; if (itemHelper.canRate(item)) { const likes = userData.Likes == null ? '' : userData.Likes; - /* eslint-disable-next-line no-unused-expressions */ + /* eslint-disable-next-line @babel/no-unused-expressions */ import('emby-ratingbutton'); html += ''; } diff --git a/src/plugins/htmlVideoPlayer/plugin.js b/src/plugins/htmlVideoPlayer/plugin.js index d52f0eb5b3..7789061677 100644 --- a/src/plugins/htmlVideoPlayer/plugin.js +++ b/src/plugins/htmlVideoPlayer/plugin.js @@ -150,7 +150,7 @@ function tryRemoveElement(elem) { /** * @type {string} */ - name + name; /** * @type {string} */ @@ -730,7 +730,7 @@ function tryRemoveElement(elem) { const elem = e.target; this.destroyCustomTrack(elem); onEndedInternal(this, elem, this.onError); - } + }; /** * @private @@ -760,7 +760,7 @@ function tryRemoveElement(elem) { } events.trigger(this, 'timeupdate'); - } + }; /** * @private @@ -773,7 +773,7 @@ function tryRemoveElement(elem) { const elem = e.target; saveVolume(elem.volume); events.trigger(this, 'volumechange'); - } + }; /** * @private @@ -785,7 +785,7 @@ function tryRemoveElement(elem) { this.onStartedAndNavigatedToOsd(); } - } + }; /** * @private @@ -832,14 +832,14 @@ function tryRemoveElement(elem) { } } events.trigger(this, 'playing'); - } + }; /** * @private */ onPlay = () => { events.trigger(this, 'unpause'); - } + }; /** * @private @@ -865,21 +865,21 @@ function tryRemoveElement(elem) { */ onClick = () => { events.trigger(this, 'click'); - } + }; /** * @private */ onDblClick = () => { events.trigger(this, 'dblclick'); - } + }; /** * @private */ onPause = () => { events.trigger(this, 'pause'); - } + }; onWaiting() { events.trigger(this, 'waiting'); @@ -929,7 +929,7 @@ function tryRemoveElement(elem) { } onErrorInternal(this, type); - } + }; /** * @private diff --git a/src/scripts/editorsidebar.js b/src/scripts/editorsidebar.js index 2489335969..d10407c7bb 100644 --- a/src/scripts/editorsidebar.js +++ b/src/scripts/editorsidebar.js @@ -302,7 +302,7 @@ import 'material-icons'; $(document).on('itemsaved', '.metadataEditorPage', function (e, item) { updateEditorNode(this, item); }).on('pagebeforeshow', '.metadataEditorPage', function () { - /* eslint-disable-next-line no-unused-expressions */ + /* eslint-disable-next-line @babel/no-unused-expressions */ import('css!assets/css/metadataeditor.css'); }).on('pagebeforeshow', '.metadataEditorPage', function () { var page = this; diff --git a/src/scripts/keyboardNavigation.js b/src/scripts/keyboardNavigation.js index 10a9611c33..ec354a7ba3 100644 --- a/src/scripts/keyboardNavigation.js +++ b/src/scripts/keyboardNavigation.js @@ -155,7 +155,7 @@ export function enable() { function attachGamepadScript(e) { console.log('Gamepad connected! Attaching gamepadtokey.js script'); window.removeEventListener('gamepadconnected', attachGamepadScript); - /* eslint-disable-next-line no-unused-expressions */ + /* eslint-disable-next-line @babel/no-unused-expressions */ import('scripts/gamepadtokey'); } From 57fb43fb04b80e467821a69825b34a0e52c28164 Mon Sep 17 00:00:00 2001 From: MrTimscampi Date: Sat, 1 Aug 2020 16:04:24 +0200 Subject: [PATCH 059/301] Fix suggestions --- src/components/packageManager.js | 32 ++++++++++++++++------------- src/libraries/screensavermanager.js | 1 + src/scripts/site.js | 19 +++++++++++------ 3 files changed, 32 insertions(+), 20 deletions(-) diff --git a/src/components/packageManager.js b/src/components/packageManager.js index 7e2b1362c7..358529ba79 100644 --- a/src/components/packageManager.js +++ b/src/components/packageManager.js @@ -11,13 +11,17 @@ import pluginManager from 'pluginManager'; var manifestUrls = JSON.parse(appSettings.get(this.#settingsKey) || '[]'); var instance = this; - return Promise.all(manifestUrls.map((u) => { - return this.loadPackage(instance, u); - })).then(() => { + return Promise.all(manifestUrls.map((url) => { + return this.loadPackage(url); + })) + .then(() => { + console.debug('finished loading packages'); + return Promise.resolve(); + }) + .catch(() => { + return Promise.resolve(); + }).finally(() => { console.groupEnd('loading packages'); - return Promise.resolve(); - }, () => { - return Promise.resolve(); }); } @@ -26,7 +30,7 @@ import pluginManager from 'pluginManager'; } install(url) { - return this.loadPackage(this, url, true).then((pkg) => { + return this.loadPackage(url, true).then((pkg) => { var manifestUrls = JSON.parse(appSettings.get(this.#settingsKey) || '[]'); if (!manifestUrls.includes(url)) { @@ -69,12 +73,12 @@ import pluginManager from 'pluginManager'; return packageUrl; } - addPackage(packageManager, pkg) { - packageManager.packagesList = packageManager.packagesList.filter((p) => { + addPackage(pkg) { + this.packagesList = this.packagesList.filter((p) => { return p.name !== pkg.name; }); - packageManager.packagesList.push(pkg); + this.packagesList.push(pkg); } removeUrl(url) { @@ -87,7 +91,7 @@ import pluginManager from 'pluginManager'; appSettings.set(this.#settingsKey, JSON.stringify(manifestUrls)); } - loadPackage(packageManager, url, throwError) { + loadPackage(url, throwError = false) { return new Promise((resolve, reject) => { var xhr = new XMLHttpRequest(); var originalUrl = url; @@ -105,19 +109,19 @@ import pluginManager from 'pluginManager'; } }; - xhr.onload = (e) => { + xhr.onload = () => { if (this.status < 400) { var pkg = JSON.parse(this.response); pkg.url = originalUrl; - this.addPackage(packageManager, pkg); + this.addPackage(pkg); var plugins = pkg.plugins || []; if (pkg.plugin) { plugins.push(pkg.plugin); } var promises = plugins.map((pluginUrl) => { - return pluginManager.loadPlugin(packageManager.mapPath(pkg, pluginUrl)); + return pluginManager.loadPlugin(this.mapPath(pkg, pluginUrl)); }); Promise.all(promises).then(resolve, resolve); } else { diff --git a/src/libraries/screensavermanager.js b/src/libraries/screensavermanager.js index 557b31e0f4..6d025ac67f 100644 --- a/src/libraries/screensavermanager.js +++ b/src/libraries/screensavermanager.js @@ -2,6 +2,7 @@ define(["events", "playbackManager", "pluginManager", "inputManager", "connectio "use strict"; playbackManager = playbackManager.default || playbackManager; + pluginManager = pluginManager.default || pluginManager; function getMinIdleTime() { // Returns the minimum amount of idle time required before the screen saver can be displayed diff --git a/src/scripts/site.js b/src/scripts/site.js index 7b5a72c042..7919ed510f 100644 --- a/src/scripts/site.js +++ b/src/scripts/site.js @@ -470,6 +470,7 @@ function initClient() { require(['apphost', 'css!assets/css/librarybrowser'], function (appHost) { loadPlugins(appHost, browser).then(function () { + console.groupEnd('loading packages'); onAppReady(browser); }); }); @@ -494,12 +495,18 @@ function initClient() { list = list.concat(window.NativeShell.getPlugins()); } - Promise.all(list.map(loadPlugin)).then(function () { - console.groupEnd('loading installed plugins'); - require(['packageManager'], function (packageManager) { - packageManager.default.init().then(resolve, reject); - }); - }, reject); + Promise.all(list.map(loadPlugin)) + .then(function () { + console.debug('finished loading plugins'); + }) + .catch(() => reject) + .finally(() => { + console.groupEnd('loading installed plugins'); + require(['packageManager'], function (packageManager) { + packageManager.default.init().then(resolve, reject); + }); + }) + ; }); }); }); From feb49dd42982c46f2dcc44abaabcc9493749e3d1 Mon Sep 17 00:00:00 2001 From: MrTimscampi Date: Thu, 6 Aug 2020 22:09:24 +0200 Subject: [PATCH 060/301] Fix suggestions and cleanup --- src/components/apphost.js | 22 ++----------------- .../displaySettings/displaySettings.js | 6 ++--- .../imageDownloader/imageDownloader.js | 2 +- src/components/itemContextMenu.js | 2 +- src/components/nowPlayingBar/nowPlayingBar.js | 2 +- .../playback/playerSelectionMenu.js | 2 +- .../playbackSettings/playbackSettings.js | 6 ++--- .../subtitlesettings/subtitlesettings.js | 2 +- src/controllers/playback/video/index.js | 2 +- src/controllers/session/login/index.js | 2 +- src/scripts/inputManager.js | 2 +- src/scripts/site.js | 7 ++---- 12 files changed, 18 insertions(+), 39 deletions(-) diff --git a/src/components/apphost.js b/src/components/apphost.js index 060d56832a..8563321957 100644 --- a/src/components/apphost.js +++ b/src/components/apphost.js @@ -141,23 +141,6 @@ function supportsFullscreen() { return (element.requestFullscreen || element.mozRequestFullScreen || element.webkitRequestFullscreen || element.msRequestFullscreen) || document.createElement('video').webkitEnterFullscreen; } -function getSyncProfile() { - return new Promise(function (resolve) { - require(['browserdeviceprofile', 'appSettings'], function (profileBuilder, appSettings) { - let profile; - - if (window.NativeShell) { - profile = window.NativeShell.AppHost.getSyncProfile(profileBuilder, appSettings); - } else { - profile = profileBuilder(); - profile.MaxStaticMusicBitrate = appSettings.maxStaticMusicBitrate(); - } - - resolve(profile); - }); - }); -} - function getDefaultLayout() { return 'desktop'; } @@ -271,7 +254,7 @@ const supportedFeatures = function () { features.push('targetblank'); features.push('screensaver'); - webSettings.enableMultiServer().then(enabled => { + webSettings.getMultiServer().then(enabled => { if (enabled) features.push('multiserver'); }); @@ -323,7 +306,7 @@ function askForExit() { return; } - require(['actionsheet'], function (actionsheet) { + import('actionsheet').then(({default: actionsheet}) => { exitPromise = actionsheet.show({ title: globalize.translate('MessageConfirmAppExit'), items: [ @@ -367,7 +350,6 @@ const appHost = { return supportedFeatures.indexOf(command.toLowerCase()) !== -1; }, preferVisualCards: browser.android || browser.chrome, - getSyncProfile: getSyncProfile, getDefaultLayout: function () { if (window.NativeShell) { return window.NativeShell.AppHost.getDefaultLayout(); diff --git a/src/components/displaySettings/displaySettings.js b/src/components/displaySettings/displaySettings.js index 641faa7f3b..ae7647f98b 100644 --- a/src/components/displaySettings/displaySettings.js +++ b/src/components/displaySettings/displaySettings.js @@ -75,13 +75,13 @@ import 'emby-button'; context.querySelector('.languageSection').classList.add('hide'); } - if (appHost.default.supports('displaymode')) { + if (appHost.supports('displaymode')) { context.querySelector('.fldDisplayMode').classList.remove('hide'); } else { context.querySelector('.fldDisplayMode').classList.add('hide'); } - if (appHost.default.supports('externallinks')) { + if (appHost.supports('externallinks')) { context.querySelector('.learnHowToContributeContainer').classList.remove('hide'); } else { context.querySelector('.learnHowToContributeContainer').classList.add('hide'); @@ -136,7 +136,7 @@ import 'emby-button'; function saveUser(context, user, userSettingsInstance, apiClient) { user.Configuration.DisplayMissingEpisodes = context.querySelector('.chkDisplayMissingEpisodes').checked; - if (appHost.default.supports('displaylanguage')) { + if (appHost.supports('displaylanguage')) { userSettingsInstance.language(context.querySelector('#selectLanguage').value); } diff --git a/src/components/imageDownloader/imageDownloader.js b/src/components/imageDownloader/imageDownloader.js index 5141ff73e5..2be2ef09b2 100644 --- a/src/components/imageDownloader/imageDownloader.js +++ b/src/components/imageDownloader/imageDownloader.js @@ -208,7 +208,7 @@ import 'cardStyle'; html += '
    '; html += '
    '; - if (layoutManager.tv || !appHost.default.supports('externallinks')) { + if (layoutManager.tv || !appHost.supports('externallinks')) { html += '
    '; } else { html += ''; diff --git a/src/components/itemContextMenu.js b/src/components/itemContextMenu.js index 5f4906fd88..c1cac11d87 100644 --- a/src/components/itemContextMenu.js +++ b/src/components/itemContextMenu.js @@ -158,7 +158,7 @@ import actionsheet from 'actionsheet'; } // Books are promoted to major download Button and therefor excluded in the context menu - if ((item.CanDownload && appHost.default.supports('filedownload')) && item.Type !== 'Book') { + if ((item.CanDownload && appHost.supports('filedownload')) && item.Type !== 'Book') { commands.push({ name: globalize.translate('Download'), id: 'download', diff --git a/src/components/nowPlayingBar/nowPlayingBar.js b/src/components/nowPlayingBar/nowPlayingBar.js index efd09fcba3..7aa8c623b3 100644 --- a/src/components/nowPlayingBar/nowPlayingBar.js +++ b/src/components/nowPlayingBar/nowPlayingBar.js @@ -415,7 +415,7 @@ import 'emby-ratingbutton'; showVolumeSlider = false; } - if (currentPlayer.isLocalPlayer && appHost.default.supports('physicalvolumecontrol')) { + if (currentPlayer.isLocalPlayer && appHost.supports('physicalvolumecontrol')) { showMuteButton = false; showVolumeSlider = false; } diff --git a/src/components/playback/playerSelectionMenu.js b/src/components/playback/playerSelectionMenu.js index 878fccb6da..7799613400 100644 --- a/src/components/playback/playerSelectionMenu.js +++ b/src/components/playback/playerSelectionMenu.js @@ -121,7 +121,7 @@ export function show(button) { // Unfortunately we can't allow the url to change or chromecast will throw a security error // Might be able to solve this in the future by moving the dialogs to hashbangs - if (!(!browser.chrome && !browser.edgeChromium || appHost.default.supports('castmenuhashchange'))) { + if (!(!browser.chrome && !browser.edgeChromium || appHost.supports('castmenuhashchange'))) { menuOptions.enableHistory = false; } diff --git a/src/components/playbackSettings/playbackSettings.js b/src/components/playbackSettings/playbackSettings.js index 14dc742dfd..66e1ae777f 100644 --- a/src/components/playbackSettings/playbackSettings.js +++ b/src/components/playbackSettings/playbackSettings.js @@ -98,7 +98,7 @@ import 'emby-checkbox'; context.querySelector('.videoQualitySection').classList.add('hide'); } - if (appHost.default.supports('multiserver')) { + if (appHost.supports('multiserver')) { context.querySelector('.fldVideoInNetworkQuality').classList.remove('hide'); context.querySelector('.fldVideoInternetQuality').classList.remove('hide'); @@ -162,7 +162,7 @@ import 'emby-checkbox'; } }); - if (appHost.default.supports('externalplayerintent') && userId === loggedInUserId) { + if (appHost.supports('externalplayerintent') && userId === loggedInUserId) { context.querySelector('.fldExternalPlayer').classList.remove('hide'); } else { context.querySelector('.fldExternalPlayer').classList.add('hide'); @@ -171,7 +171,7 @@ import 'emby-checkbox'; if (userId === loggedInUserId && (user.Policy.EnableVideoPlaybackTranscoding || user.Policy.EnableAudioPlaybackTranscoding)) { context.querySelector('.qualitySections').classList.remove('hide'); - if (appHost.default.supports('chromecast') && user.Policy.EnableVideoPlaybackTranscoding) { + if (appHost.supports('chromecast') && user.Policy.EnableVideoPlaybackTranscoding) { context.querySelector('.fldChromecastQuality').classList.remove('hide'); } else { context.querySelector('.fldChromecastQuality').classList.add('hide'); diff --git a/src/components/subtitlesettings/subtitlesettings.js b/src/components/subtitlesettings/subtitlesettings.js index 3569e114fa..1621c0ea2c 100644 --- a/src/components/subtitlesettings/subtitlesettings.js +++ b/src/components/subtitlesettings/subtitlesettings.js @@ -136,7 +136,7 @@ function embed(options, self) { options.element.querySelector('.btnSave').classList.remove('hide'); } - if (appHost.default.supports('subtitleappearancesettings')) { + if (appHost.supports('subtitleappearancesettings')) { options.element.querySelector('.subtitleAppearanceSection').classList.remove('hide'); } diff --git a/src/controllers/playback/video/index.js b/src/controllers/playback/video/index.js index c1c311a226..73540cd636 100644 --- a/src/controllers/playback/video/index.js +++ b/src/controllers/playback/video/index.js @@ -896,7 +896,7 @@ import 'css!assets/css/videoosd'; showVolumeSlider = false; } - if (player.isLocalPlayer && appHost.default.supports('physicalvolumecontrol')) { + if (player.isLocalPlayer && appHost.supports('physicalvolumecontrol')) { showMuteButton = false; showVolumeSlider = false; } diff --git a/src/controllers/session/login/index.js b/src/controllers/session/login/index.js index c53c59f3b2..8bac557a20 100644 --- a/src/controllers/session/login/index.js +++ b/src/controllers/session/login/index.js @@ -199,7 +199,7 @@ import 'emby-checkbox'; loading.show(); libraryMenu.setTransparentMenu(true); - if (!appHost.default.supports('multiserver')) { + if (!appHost.supports('multiserver')) { view.querySelector('.btnSelectServer').classList.add('hide'); } diff --git a/src/scripts/inputManager.js b/src/scripts/inputManager.js index 9225d07f0a..077af39bf7 100644 --- a/src/scripts/inputManager.js +++ b/src/scripts/inputManager.js @@ -113,7 +113,7 @@ import appHost from 'apphost'; 'back': () => { if (appRouter.canGoBack()) { appRouter.back(); - } else if (appHost.default.supports('exit')) { + } else if (appHost.supports('exit')) { appHost.exit(); } }, diff --git a/src/scripts/site.js b/src/scripts/site.js index 0879c11344..7f2caf4629 100644 --- a/src/scripts/site.js +++ b/src/scripts/site.js @@ -273,14 +273,11 @@ function initClient() { function createConnectionManager() { return require(['connectionManagerFactory', 'apphost', 'credentialprovider', 'events', 'userSettings'], function (ConnectionManager, appHost, credentialProvider, events, userSettings) { var credentialProviderInstance = new credentialProvider(); - var promises = [appHost.default.getSyncProfile(), appHost.default.init()]; + var promises = [appHost.default.init()]; return Promise.all(promises).then(function (responses) { - var deviceProfile = responses[0]; var capabilities = Dashboard.capabilities(appHost); - capabilities.DeviceProfile = deviceProfile; - var connectionManager = new ConnectionManager(credentialProviderInstance, appHost.default.appName(), appHost.default.appVersion(), appHost.default.deviceName(), appHost.default.deviceId(), capabilities); defineConnectionManager(connectionManager); @@ -481,7 +478,7 @@ function initClient() { require(['webSettings'], function (webSettings) { webSettings.getPlugins().then(function (list) { // these two plugins are dependent on features - if (!appHost.supports('remotecontrol')) { + if (!appHost.default.supports('remotecontrol')) { list.splice(list.indexOf('sessionPlayer'), 1); if (!browser.chrome && !browser.opera) { From e7d6bc288956e3643c1c204bd413cf48725ccd17 Mon Sep 17 00:00:00 2001 From: MrTimscampi Date: Thu, 6 Aug 2020 22:25:14 +0200 Subject: [PATCH 061/301] Don't math twice --- src/libraries/scroller.js | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/src/libraries/scroller.js b/src/libraries/scroller.js index 03c6306511..ada13403bf 100644 --- a/src/libraries/scroller.js +++ b/src/libraries/scroller.js @@ -229,15 +229,15 @@ var scrollerFactory = function (frame, options) { } } else if (!immediate && container.scrollTo) { if (o.horizontal) { - container.scrollTo(Math.Math.round(pos), 0); + container.scrollTo(Math.round(pos), 0); } else { - container.scrollTo(0, Math.Math.round(pos)); + container.scrollTo(0, Math.round(pos)); } } else { if (o.horizontal) { - container.scrollLeft = Math.Math.round(pos); + container.scrollLeft = Math.round(pos); } else { - container.scrollTop = Math.Math.round(pos); + container.scrollTop = Math.round(pos); } } } From 161488616f5dc789f54c8965f955a08d5402001a Mon Sep 17 00:00:00 2001 From: MrTimscampi Date: Thu, 6 Aug 2020 22:28:52 +0200 Subject: [PATCH 062/301] Fix suggestions --- src/scripts/scrollHelper.js | 59 +++++++++++++++++++------------------ 1 file changed, 31 insertions(+), 28 deletions(-) diff --git a/src/scripts/scrollHelper.js b/src/scripts/scrollHelper.js index 020888a2e3..1ce30768af 100644 --- a/src/scripts/scrollHelper.js +++ b/src/scripts/scrollHelper.js @@ -98,40 +98,43 @@ function centerOnFocus(e, scrollSlider, horizontal) { function centerOnFocusHorizontal(e) { centerOnFocus(e, this, true); } + function centerOnFocusVertical(e) { centerOnFocus(e, this, false); } -export default { - getPosition: getPosition, - centerFocus: { - on: function (element, horizontal) { - if (horizontal) { - dom.addEventListener(element, 'focus', centerOnFocusHorizontal, { - capture: true, - passive: true - }); - } else { - dom.addEventListener(element, 'focus', centerOnFocusVertical, { - capture: true, - passive: true - }); - } - }, - off: function (element, horizontal) { - if (horizontal) { - dom.removeEventListener(element, 'focus', centerOnFocusHorizontal, { - capture: true, - passive: true - }); - } else { - dom.removeEventListener(element, 'focus', centerOnFocusVertical, { - capture: true, - passive: true - }); - } +export const centerFocus = { + on: function (element, horizontal) { + if (horizontal) { + dom.addEventListener(element, 'focus', centerOnFocusHorizontal, { + capture: true, + passive: true + }); + } else { + dom.addEventListener(element, 'focus', centerOnFocusVertical, { + capture: true, + passive: true + }); } }, + off: function (element, horizontal) { + if (horizontal) { + dom.removeEventListener(element, 'focus', centerOnFocusHorizontal, { + capture: true, + passive: true + }); + } else { + dom.removeEventListener(element, 'focus', centerOnFocusVertical, { + capture: true, + passive: true + }); + } + } +} + +export default { + getPosition: getPosition, + centerFocus: centerFocus, toCenter: toCenter, toStart: toStart }; From 453079fe068250dca9d4964ad15692e474b7b8af Mon Sep 17 00:00:00 2001 From: MrTimscampi Date: Thu, 6 Aug 2020 22:48:26 +0200 Subject: [PATCH 063/301] Fix require --- src/components/guide/guide.js | 3 ++- src/scripts/scrollHelper.js | 4 +--- src/scripts/serverNotifications.js | 6 +++--- 3 files changed, 6 insertions(+), 7 deletions(-) diff --git a/src/components/guide/guide.js b/src/components/guide/guide.js index 50eb55f834..05fa2b608d 100644 --- a/src/components/guide/guide.js +++ b/src/components/guide/guide.js @@ -4,7 +4,8 @@ define(['require', 'inputManager', 'browser', 'globalize', 'connectionManager', playbackManager = playbackManager.default || playbackManager; browser = browser.default || browser; loading = loading.default || loading; - focusManager = focusManager.default || focusManager;scrollHelper = scrollHelper.default || scrollHelper; + focusManager = focusManager.default || focusManager; + scrollHelper = scrollHelper.default || scrollHelper; serverNotifications = serverNotifications.default || serverNotifications; function showViewSettings(instance) { diff --git a/src/scripts/scrollHelper.js b/src/scripts/scrollHelper.js index 1ce30768af..b867123683 100644 --- a/src/scripts/scrollHelper.js +++ b/src/scripts/scrollHelper.js @@ -3,7 +3,6 @@ import dom from 'dom'; import 'scrollStyles'; function getBoundingClientRect(elem) { - // Support: BlackBerry 5, iOS 3 (original iPhone) // If we don't have gBCR, just use 0,0 rather than error if (elem.getBoundingClientRect) { @@ -14,7 +13,6 @@ function getBoundingClientRect(elem) { } export function getPosition(scrollContainer, item, horizontal) { - const slideeOffset = getBoundingClientRect(scrollContainer); const itemOffset = getBoundingClientRect(item); @@ -130,7 +128,7 @@ export const centerFocus = { }); } } -} +}; export default { getPosition: getPosition, diff --git a/src/scripts/serverNotifications.js b/src/scripts/serverNotifications.js index 83af40c4e6..2345cf327a 100644 --- a/src/scripts/serverNotifications.js +++ b/src/scripts/serverNotifications.js @@ -15,12 +15,12 @@ function notifyApp() { function displayMessage(cmd) { const args = cmd.Arguments; if (args.TimeoutMs) { - require(['toast'], function (toast) { + import('toast').then((toast) => { toast({ title: args.Header, text: args.Text }); }); } else { - require(['alert'], function (alert) { - alert.default({ title: args.Header, text: args.Text }); + import('alert').then((alert) => { + alert({ title: args.Header, text: args.Text }); }); } } From 4aa0ef49368508805321aaf901830df65bed2b1f Mon Sep 17 00:00:00 2001 From: MrTimscampi Date: Thu, 30 Jul 2020 20:34:21 +0200 Subject: [PATCH 064/301] Migrate appRouter to ES6 --- .eslintrc.js | 1 + package.json | 1 + src/components/actionSheet/actionSheet.js | 14 +- src/components/appRouter.js | 893 +++++++++++------- src/components/cardbuilder/cardBuilder.js | 28 +- src/components/dialogHelper/dialogHelper.js | 9 +- src/components/filtermenu/filtermenu.js | 2 + src/components/images/imageLoader.js | 14 +- src/components/indicators/indicators.js | 2 +- src/components/itemContextMenu.js | 5 +- src/components/mediainfo/mediainfo.js | 1 - .../metadataEditor/metadataEditor.js | 2 +- src/components/nowPlayingBar/nowPlayingBar.js | 18 +- src/components/playback/mediasession.js | 8 +- src/components/remotecontrol/remotecontrol.js | 18 +- src/components/scrollManager.js | 2 +- src/components/viewSettings/viewSettings.js | 2 + .../dashboard/plugins/repositories/index.js | 2 +- src/controllers/playback/video/index.js | 8 +- src/plugins/bookPlayer/plugin.js | 22 +- src/plugins/bookPlayer/tableOfContents.js | 18 +- src/plugins/htmlVideoPlayer/plugin.js | 6 +- src/plugins/youtubePlayer/plugin.js | 2 +- src/scripts/deleteHelper.js | 4 +- src/scripts/inputManager.js | 2 +- src/scripts/libraryMenu.js | 1 + src/scripts/serverNotifications.js | 1 + src/scripts/site.js | 275 +----- 28 files changed, 652 insertions(+), 709 deletions(-) diff --git a/.eslintrc.js b/.eslintrc.js index ff12e198c3..a4e972c83e 100644 --- a/.eslintrc.js +++ b/.eslintrc.js @@ -44,6 +44,7 @@ module.exports = { 'no-unused-vars': ['error', { 'vars': 'all', 'args': 'none', 'ignoreRestSiblings': true }], 'one-var': ['error', 'never'], 'padded-blocks': ['error', 'never'], + //'prefer-const': ['error', {'destructuring': 'all'}], 'quotes': ['error', 'single', { 'avoidEscape': true, 'allowTemplateLiterals': false }], 'semi': ['error'], 'space-before-blocks': ['error'], diff --git a/package.json b/package.json index bf3ac42f97..744f080124 100644 --- a/package.json +++ b/package.json @@ -95,6 +95,7 @@ "src/components/alert.js", "src/components/alphaPicker/alphaPicker.js", "src/components/appFooter/appFooter.js", + "src/components/appRouter.js", "src/components/autoFocuser.js", "src/components/backdrop/backdrop.js", "src/components/cardbuilder/cardBuilder.js", diff --git a/src/components/actionSheet/actionSheet.js b/src/components/actionSheet/actionSheet.js index 937cd2afe5..be84cf0a06 100644 --- a/src/components/actionSheet/actionSheet.js +++ b/src/components/actionSheet/actionSheet.js @@ -9,14 +9,14 @@ import 'scrollStyles'; import 'listViewStyle'; function getOffsets(elems) { - let results = []; + const results = []; if (!document) { return results; } for (const elem of elems) { - let box = elem.getBoundingClientRect(); + const box = elem.getBoundingClientRect(); results.push({ top: box.top, @@ -34,7 +34,7 @@ function getPosition(options, dlg) { const windowHeight = windowSize.innerHeight; const windowWidth = windowSize.innerWidth; - let pos = getOffsets([options.positionTo])[0]; + const pos = getOffsets([options.positionTo])[0]; if (options.positionY !== 'top') { pos.top += (pos.height || 0) / 2; @@ -82,7 +82,7 @@ export function show(options) { // positionTo // showCancel // title - let dialogOptions = { + const dialogOptions = { removeOnClose: true, enableHistory: options.enableHistory, scrollY: false @@ -103,7 +103,7 @@ export function show(options) { dialogOptions.autoFocus = false; } - let dlg = dialogHelper.createDialog(dialogOptions); + const dlg = dialogHelper.createDialog(dialogOptions); if (isFullscreen) { dlg.classList.add('actionsheet-fullscreen'); @@ -129,7 +129,7 @@ export function show(options) { } let renderIcon = false; - let icons = []; + const icons = []; let itemIcon; for (const item of options.items) { itemIcon = item.icon || (item.selected ? 'check' : null); @@ -241,7 +241,7 @@ export function show(options) { centerFocus(dlg.querySelector('.actionSheetScroller'), false, true); } - let btnCloseActionSheet = dlg.querySelector('.btnCloseActionSheet'); + const btnCloseActionSheet = dlg.querySelector('.btnCloseActionSheet'); if (btnCloseActionSheet) { btnCloseActionSheet.addEventListener('click', function () { dialogHelper.close(dlg); diff --git a/src/components/appRouter.js b/src/components/appRouter.js index da3b08317c..c7495d6460 100644 --- a/src/components/appRouter.js +++ b/src/components/appRouter.js @@ -1,66 +1,294 @@ -define(['loading', 'globalize', 'events', 'viewManager', 'skinManager', 'backdrop', 'browser', 'page', 'appSettings', 'apphost', 'connectionManager'], function (loading, globalize, events, viewManager, skinManager, backdrop, browser, page, appSettings, appHost, connectionManager) { - 'use strict'; +import appHost from 'apphost'; +import appSettings from 'appSettings'; +import backdrop from 'backdrop'; +import browser from 'browser'; +import connectionManager from 'connectionManager'; +import events from 'events'; +import globalize from 'globalize'; +import itemHelper from 'itemHelper'; +import loading from 'loading'; +import page from 'page'; +import viewManager from 'viewManager'; - browser = browser.default || browser; - loading = loading.default || loading; +class AppRouter { + allRoutes = []; + backdropContainer; + backgroundContainer; + currentRouteInfo; + currentViewLoadRequest; + firstConnectionResult; + forcedLogoutMsg; + handleAnchorClick = page.clickHandler; + isDummyBackToHome; + msgTimeout; + popstateOccurred = false; + resolveOnNextShow; + /** + * Pages of "no return" (when "Go back" should behave differently, probably quitting the application). + */ + startPages = ['home', 'login', 'selectserver']; - var appRouter = { - showLocalLogin: function (serverId, manualLogin) { - var pageName = manualLogin ? 'manuallogin' : 'login'; - show('/startup/' + pageName + '.html?serverid=' + serverId); - }, - showSelectServer: function () { - show('/startup/selectserver.html'); - }, - showWelcome: function () { - show('/startup/welcome.html'); - }, - showSettings: function () { - show('/settings/settings.html'); - }, - showNowPlaying: function () { - show('queue'); + constructor() { + window.addEventListener('popstate', () => { + this.popstateOccurred = true; + }); + + document.addEventListener('viewshow', () => { + const resolve = this.resolveOnNextShow; + if (resolve) { + this.resolveOnNextShow = null; + resolve(); + } + }); + + this.baseRoute = self.location.href.split('?')[0].replace(this.getRequestFile(), ''); + // support hashbang + this.baseRoute = this.baseRoute.split('#')[0]; + if (this.baseRoute.endsWith('/') && !this.baseRoute.endsWith('://')) { + this.baseRoute = this.baseRoute.substring(0, this.baseRoute.length - 1); } - }; - function beginConnectionWizard() { - backdrop.clearBackdrop(); + this.setBaseRoute(); + } + + /** + * @private + */ + setBaseRoute() { + let baseRoute = self.location.pathname.replace(this.getRequestFile(), ''); + if (baseRoute.lastIndexOf('/') === baseRoute.length - 1) { + baseRoute = baseRoute.substring(0, baseRoute.length - 1); + } + console.debug('setting page base to ' + baseRoute); + page.base(baseRoute); + } + + addRoute(path, newRoute) { + page(path, this.getHandler(newRoute)); + this.allRoutes.push(newRoute); + } + + showLocalLogin(serverId) { + this.show('login.html?serverid=' + serverId); + } + + showSelectServer() { + this.show(AppInfo.isNativeApp ? 'selectserver.html' : 'login.html'); + } + + showWelcome() { + this.show(AppInfo.isNativeApp ? 'selectserver.html' : 'login.html'); + } + + showSettings() { + this.show('mypreferencesmenu.html'); + } + + showNowPlaying() { + this.show('/nowplaying.html'); + } + + beginConnectionWizard() { + backdrop.clear(); loading.show(); connectionManager.connect({ enableAutoLogin: appSettings.enableAutoLogin() - }).then(function (result) { - handleConnectionResult(result); + }).then((result) => { + this.handleConnectionResult(result); }); } - function handleConnectionResult(result) { + param(name, url) { + name = name.replace(/[[]/, '\\[').replace(/[\]]/, '\\]'); + const regexS = '[\\?&]' + name + '=([^&#]*)'; + const regex = new RegExp(regexS, 'i'); + + const results = regex.exec(url || getWindowLocationSearch()); + if (results == null) { + return ''; + } else { + return decodeURIComponent(results[1].replace(/\+/g, ' ')); + } + } + + back() { + page.back(); + } + + show(path, options) { + if (path.indexOf('/') !== 0 && path.indexOf('://') === -1) { + path = '/' + path; + } + + path = path.replace(this.baseUrl(), ''); + + if (this.currentRouteInfo && this.currentRouteInfo.path === path) { + // can't use this with home right now due to the back menu + if (this.currentRouteInfo.route.type !== 'home') { + loading.hide(); + return Promise.resolve(); + } + } + + return new Promise((resolve) => { + this.resolveOnNextShow = resolve; + page.show(path, options); + }); + } + + showDirect(path) { + return new Promise(function(resolve) { + this.resolveOnNextShow = resolve; + page.show(this.baseUrl() + path); + }); + } + + start(options) { + loading.show(); + this.initApiClients(); + + events.on(appHost, 'beforeexit', this.onBeforeExit); + events.on(appHost, 'resume', this.onAppResume); + + connectionManager.connect({ + enableAutoLogin: appSettings.enableAutoLogin() + }).then((result) => { + this.firstConnectionResult = result; + options = options || {}; + page({ + click: options.click !== false, + hashbang: options.hashbang !== false + }); + }).catch().then(() => { + loading.hide(); + }); + } + + baseUrl() { + return this.baseRoute; + } + + canGoBack() { + const curr = this.current(); + if (!curr) { + return false; + } + + if (!document.querySelector('.dialogContainer') && this.startPages.indexOf(curr.type) !== -1) { + return false; + } + + return history.length > 1; + } + + current() { + return this.currentRouteInfo ? this.currentRouteInfo.route : null; + } + + invokeShortcut(id) { + if (id.indexOf('library-') === 0) { + id = id.replace('library-', ''); + id = id.split('_'); + + this.showItem(id[0], id[1]); + } else if (id.indexOf('item-') === 0) { + id = id.replace('item-', ''); + id = id.split('_'); + this.showItem(id[0], id[1]); + } else { + id = id.split('_'); + this.show(this.getRouteUrl(id[0], { + serverId: id[1] + })); + } + } + + showItem(item, serverId, options) { + // TODO: Refactor this so it only gets items, not strings. + if (typeof (item) === 'string') { + const apiClient = serverId ? connectionManager.getApiClient(serverId) : connectionManager.currentApiClient(); + apiClient.getItem(apiClient.getCurrentUserId(), item).then((itemObject) => { + this.showItem(itemObject, options); + }); + } else { + if (arguments.length === 2) { + options = arguments[1]; + } + + const url = this.getRouteUrl(item, options); + this.show(url, { + item: item + }); + } + } + + setTransparency(level) { + if (!this.backdropContainer) { + this.backdropContainer = document.querySelector('.backdropContainer'); + } + if (!this.backgroundContainer) { + this.backgroundContainer = document.querySelector('.backgroundContainer'); + } + + if (level === 'full' || level === 2) { + backdrop.clear(true); + document.documentElement.classList.add('transparentDocument'); + this.backgroundContainer.classList.add('backgroundContainer-transparent'); + this.backdropContainer.classList.add('hide'); + } else if (level === 'backdrop' || level === 1) { + backdrop.externalBackdrop(true); + document.documentElement.classList.add('transparentDocument'); + this.backgroundContainer.classList.add('backgroundContainer-transparent'); + this.backdropContainer.classList.add('hide'); + } else { + backdrop.externalBackdrop(false); + document.documentElement.classList.remove('transparentDocument'); + this.backgroundContainer.classList.remove('backgroundContainer-transparent'); + this.backdropContainer.classList.remove('hide'); + } + } + + getRoutes() { + return this.allRoutes; + } + + pushState(state, title, url) { + state.navigate = false; + history.pushState(state, title, url); + } + + enableNativeHistory() { + return false; + } + + handleConnectionResult(result) { switch (result.State) { case 'SignedIn': loading.hide(); Emby.Page.goHome(); break; case 'ServerSignIn': - result.ApiClient.getPublicUsers().then(function (users) { + result.ApiClient.getPublicUsers().then((users) => { if (users.length) { - appRouter.showLocalLogin(result.Servers[0].Id); + this.showLocalLogin(result.Servers[0].Id); } else { - appRouter.showLocalLogin(result.Servers[0].Id, true); + this.showLocalLogin(result.Servers[0].Id, true); } }); break; case 'ServerSelection': - appRouter.showSelectServer(); + this.showSelectServer(); break; case 'ConnectSignIn': - appRouter.showWelcome(); + this.showWelcome(); break; case 'ServerUpdateNeeded': - require(['alert'], function (alert) { - alert.default({ + require(['alert'], (alert) => { + alert({ text: globalize.translate('ServerUpdateNeeded', 'https://github.com/jellyfin/jellyfin'), html: globalize.translate('ServerUpdateNeeded', 'https://github.com/jellyfin/jellyfin') - }).then(function () { - appRouter.showSelectServer(); + }).then(() => { + this.showSelectServer(); }); }); break; @@ -69,8 +297,8 @@ define(['loading', 'globalize', 'events', 'viewManager', 'skinManager', 'backdro } } - function loadContentUrl(ctx, next, route, request) { - var url; + loadContentUrl(ctx, next, route, request) { + let url; if (route.contentPath && typeof (route.contentPath) === 'function') { url = route.contentPath(ctx.querystring); } else { @@ -83,27 +311,27 @@ define(['loading', 'globalize', 'events', 'viewManager', 'skinManager', 'backdro url = '/' + url; } - url = baseUrl() + url; + url = this.baseUrl() + url; } if (ctx.querystring && route.enableContentQueryString) { url += '?' + ctx.querystring; } - require(['text!' + url], function (html) { - loadContent(ctx, route, html, request); + require(['text!' + url], (html) => { + this.loadContent(ctx, route, html, request); }); } - function handleRoute(ctx, next, route) { - authenticate(ctx, route, function () { - initRoute(ctx, next, route); + handleRoute(ctx, next, route) { + this.authenticate(ctx, route, () => { + this.initRoute(ctx, next, route); }); } - function initRoute(ctx, next, route) { - var onInitComplete = function (controllerFactory) { - sendRouteToViewManager(ctx, next, route, controllerFactory); + initRoute(ctx, next, route) { + const onInitComplete = (controllerFactory) => { + this.sendRouteToViewManager(ctx, next, route, controllerFactory); }; if (route.controller) { @@ -113,25 +341,24 @@ define(['loading', 'globalize', 'events', 'viewManager', 'skinManager', 'backdro } } - function cancelCurrentLoadRequest() { - var currentRequest = currentViewLoadRequest; + cancelCurrentLoadRequest() { + const currentRequest = this.currentViewLoadRequest; if (currentRequest) { currentRequest.cancel = true; } } - var currentViewLoadRequest; - function sendRouteToViewManager(ctx, next, route, controllerFactory) { - if (isDummyBackToHome && route.type === 'home') { - isDummyBackToHome = false; + sendRouteToViewManager(ctx, next, route, controllerFactory) { + if (this.isDummyBackToHome && route.type === 'home') { + this.isDummyBackToHome = false; return; } - cancelCurrentLoadRequest(); - var isBackNav = ctx.isBack; + this.cancelCurrentLoadRequest(); + const isBackNav = ctx.isBack; - var currentRequest = { - url: baseUrl() + ctx.path, + const currentRequest = { + url: this.baseUrl() + ctx.path, transition: route.transition, isBack: isBackNav, state: ctx.state, @@ -144,11 +371,11 @@ define(['loading', 'globalize', 'events', 'viewManager', 'skinManager', 'backdro }, autoFocus: route.autoFocus }; - currentViewLoadRequest = currentRequest; + this.currentViewLoadRequest = currentRequest; - var onNewViewNeeded = function () { + const onNewViewNeeded = () => { if (typeof route.path === 'string') { - loadContentUrl(ctx, next, route, currentRequest); + this.loadContentUrl(ctx, next, route, currentRequest); } else { next(); } @@ -158,64 +385,62 @@ define(['loading', 'globalize', 'events', 'viewManager', 'skinManager', 'backdro onNewViewNeeded(); return; } - viewManager.tryRestoreView(currentRequest, function () { - currentRouteInfo = { + viewManager.tryRestoreView(currentRequest, () => { + this.currentRouteInfo = { route: route, path: ctx.path }; - }).catch(function (result) { + }).catch((result) => { if (!result || !result.cancelled) { onNewViewNeeded(); } }); } - var msgTimeout; - var forcedLogoutMsg; - function onForcedLogoutMessageTimeout() { - var msg = forcedLogoutMsg; - forcedLogoutMsg = null; + onForcedLogoutMessageTimeout() { + const msg = this.forcedLogoutMsg; + this.forcedLogoutMsg = null; if (msg) { - require(['alert'], function (alert) { + require(['alert'], (alert) => { alert(msg); }); } } - function showForcedLogoutMessage(msg) { - forcedLogoutMsg = msg; - if (msgTimeout) { - clearTimeout(msgTimeout); + showForcedLogoutMessage(msg) { + this.forcedLogoutMsg = msg; + if (this.msgTimeout) { + clearTimeout(this.msgTimeout); } - msgTimeout = setTimeout(onForcedLogoutMessageTimeout, 100); + this.msgTimeout = setTimeout(this.onForcedLogoutMessageTimeout, 100); } - function onRequestFail(e, data) { - var apiClient = this; + onRequestFail(e, data) { + const apiClient = this; if (data.status === 403) { if (data.errorCode === 'ParentalControl') { - var isCurrentAllowed = currentRouteInfo ? (currentRouteInfo.route.anonymous || currentRouteInfo.route.startup) : true; + const isCurrentAllowed = this.currentRouteInfo ? (this.currentRouteInfo.route.anonymous || this.currentRouteInfo.route.startup) : true; // Bounce to the login screen, but not if a password entry fails, obviously if (!isCurrentAllowed) { - showForcedLogoutMessage(globalize.translate('AccessRestrictedTryAgainLater')); - appRouter.showLocalLogin(apiClient.serverId()); + this.showForcedLogoutMessage(globalize.translate('AccessRestrictedTryAgainLater')); + this.showLocalLogin(apiClient.serverId()); } } } } - function onBeforeExit(e) { + onBeforeExit() { if (browser.web0s) { page.restorePreviousState(); } } - function normalizeImageOptions(options) { - var setQuality; + normalizeImageOptions(options) { + let setQuality; if (options.maxWidth || options.width || options.maxHeight || options.height) { setQuality = true; } @@ -225,10 +450,10 @@ define(['loading', 'globalize', 'events', 'viewManager', 'skinManager', 'backdro } } - function getMaxBandwidth() { + getMaxBandwidth() { /* eslint-disable compat/compat */ if (navigator.connection) { - var max = navigator.connection.downlinkMax; + let max = navigator.connection.downlinkMax; if (max && max > 0 && max < Number.POSITIVE_INFINITY) { max /= 8; max *= 1000000; @@ -241,90 +466,65 @@ define(['loading', 'globalize', 'events', 'viewManager', 'skinManager', 'backdro return null; } - function getMaxBandwidthIOS() { + getMaxBandwidthIOS() { return 800000; } - function onApiClientCreated(e, newApiClient) { - newApiClient.normalizeImageOptions = normalizeImageOptions; + onApiClientCreated(e, newApiClient) { + newApiClient.normalizeImageOptions = this.normalizeImageOptions; if (browser.iOS) { - newApiClient.getMaxBandwidth = getMaxBandwidthIOS; + newApiClient.getMaxBandwidth = this.getMaxBandwidthIOS; } else { - newApiClient.getMaxBandwidth = getMaxBandwidth; + newApiClient.getMaxBandwidth = this.getMaxBandwidth; } - events.off(newApiClient, 'requestfail', onRequestFail); - events.on(newApiClient, 'requestfail', onRequestFail); + events.off(newApiClient, 'requestfail', this.onRequestFail); + events.on(newApiClient, 'requestfail', this.onRequestFail); } - function initApiClient(apiClient) { - onApiClientCreated({}, apiClient); + initApiClient(apiClient, instance) { + instance.onApiClientCreated({}, apiClient); } - function initApiClients() { - connectionManager.getApiClients().forEach(initApiClient); + initApiClients() { + connectionManager.getApiClients().forEach((apiClient) => { + this.initApiClient(apiClient, this); + }); - events.on(connectionManager, 'apiclientcreated', onApiClientCreated); + events.on(connectionManager, 'apiclientcreated', this.onApiClientCreated); } - function onAppResume() { - var apiClient = connectionManager.currentApiClient(); + onAppResume() { + const apiClient = connectionManager.currentApiClient(); if (apiClient) { apiClient.ensureWebSocket(); } } - var firstConnectionResult; - function start(options) { - loading.show(); - - initApiClients(); - - events.on(appHost, 'beforeexit', onBeforeExit); - events.on(appHost, 'resume', onAppResume); - - connectionManager.connect({ - enableAutoLogin: appSettings.enableAutoLogin() - }).then(function (result) { - firstConnectionResult = result; - options = options || {}; - page({ - click: options.click !== false, - hashbang: options.hashbang !== false - }); - }).catch().then(function() { - loading.hide(); - }); - } - - function enableNativeHistory() { - return false; - } - - function authenticate(ctx, route, callback) { - var firstResult = firstConnectionResult; + authenticate(ctx, route, callback) { + const firstResult = this.firstConnectionResult; if (firstResult) { - firstConnectionResult = null; + this.firstConnectionResult = null; if (firstResult.State !== 'SignedIn' && !route.anonymous) { - handleConnectionResult(firstResult); + this.handleConnectionResult(firstResult); return; } } - var apiClient = connectionManager.currentApiClient(); - var pathname = ctx.pathname.toLowerCase(); + const apiClient = connectionManager.currentApiClient(); + const pathname = ctx.pathname.toLowerCase(); console.debug('appRouter - processing path request ' + pathname); - var isCurrentRouteStartup = currentRouteInfo ? currentRouteInfo.route.startup : true; - var shouldExitApp = ctx.isBack && route.isDefaultRoute && isCurrentRouteStartup; + const isCurrentRouteStartup = this.currentRouteInfo ? this.currentRouteInfo.route.startup : true; + const shouldExitApp = ctx.isBack && route.isDefaultRoute && isCurrentRouteStartup; if (!shouldExitApp && (!apiClient || !apiClient.isLoggedIn()) && !route.anonymous) { console.debug('appRouter - route does not allow anonymous access, redirecting to login'); - beginConnectionWizard(); + this.beginConnectionWizard(); return; } @@ -344,9 +544,9 @@ define(['loading', 'globalize', 'events', 'viewManager', 'skinManager', 'backdro Emby.Page.goHome(); return; } else if (route.roles) { - validateRoles(apiClient, route.roles).then(function () { + this.validateRoles(apiClient, route.roles).then(() => { callback(); - }, beginConnectionWizard); + }, this.beginConnectionWizard); return; } } @@ -355,15 +555,15 @@ define(['loading', 'globalize', 'events', 'viewManager', 'skinManager', 'backdro callback(); } - function validateRoles(apiClient, roles) { - return Promise.all(roles.split(',').map(function (role) { - return validateRole(apiClient, role); + validateRoles(apiClient, roles) { + return Promise.all(roles.split(',').map((role) => { + return this.validateRole(apiClient, role); })); } - function validateRole(apiClient, role) { + validateRole(apiClient, role) { if (role === 'admin') { - return apiClient.getCurrentUser().then(function (user) { + return apiClient.getCurrentUser().then((user) => { if (user.Policy.IsAdministrator) { return Promise.resolve(); } @@ -375,15 +575,13 @@ define(['loading', 'globalize', 'events', 'viewManager', 'skinManager', 'backdro return Promise.resolve(); } - var isDummyBackToHome; - - function loadContent(ctx, route, html, request) { + loadContent(ctx, route, html, request) { html = globalize.translateHtml(html, route.dictionary); request.view = html; viewManager.loadView(request); - currentRouteInfo = { + this.currentRouteInfo = { route: route, path: ctx.path }; @@ -391,10 +589,10 @@ define(['loading', 'globalize', 'events', 'viewManager', 'skinManager', 'backdro ctx.handled = true; } - function getRequestFile() { - var path = self.location.pathname || ''; + getRequestFile() { + let path = self.location.pathname || ''; - var index = path.lastIndexOf('/'); + const index = path.lastIndexOf('/'); if (index !== -1) { path = path.substring(index); } else { @@ -408,39 +606,19 @@ define(['loading', 'globalize', 'events', 'viewManager', 'skinManager', 'backdro return path; } - function endsWith(str, srch) { - return str.lastIndexOf(srch) === srch.length - 1; - } - - var baseRoute = self.location.href.split('?')[0].replace(getRequestFile(), ''); - // support hashbang - baseRoute = baseRoute.split('#')[0]; - if (endsWith(baseRoute, '/') && !endsWith(baseRoute, '://')) { - baseRoute = baseRoute.substring(0, baseRoute.length - 1); - } - - function baseUrl() { - return baseRoute; - } - - var popstateOccurred = false; - window.addEventListener('popstate', function () { - popstateOccurred = true; - }); - - function getHandler(route) { - return function (ctx, next) { - ctx.isBack = popstateOccurred; - handleRoute(ctx, next, route); - popstateOccurred = false; + getHandler(route) { + return (ctx, next) => { + ctx.isBack = this.popstateOccurred; + this.handleRoute(ctx, next, route); + this.popstateOccurred = false; }; } - function getWindowLocationSearch(win) { - var currentPath = currentRouteInfo ? (currentRouteInfo.path || '') : ''; + getWindowLocationSearch() { + const currentPath = this.currentRouteInfo ? (this.currentRouteInfo.path || '') : ''; - var index = currentPath.indexOf('?'); - var search = ''; + const index = currentPath.indexOf('?'); + let search = ''; if (index !== -1) { search = currentPath.substring(index); @@ -449,199 +627,218 @@ define(['loading', 'globalize', 'events', 'viewManager', 'skinManager', 'backdro return search || ''; } - function param(name, url) { - name = name.replace(/[\[]/, '\\\[').replace(/[\]]/, '\\\]'); - var regexS = '[\\?&]' + name + '=([^&#]*)'; - var regex = new RegExp(regexS, 'i'); - - var results = regex.exec(url || getWindowLocationSearch()); - if (results == null) { - return ''; - } else { - return decodeURIComponent(results[1].replace(/\+/g, ' ')); - } + showGuide() { + this.show('livetv.html?tab=1'); } - function back() { - page.back(); + goHome() { + this.show('home.html'); } - /** - * Pages of "no return" (when "Go back" should behave differently, probably quitting the application). - */ - var startPages = ['home', 'login', 'selectserver']; - - function canGoBack() { - var curr = current(); - if (!curr) { - return false; - } - - if (!document.querySelector('.dialogContainer') && startPages.indexOf(curr.type) !== -1) { - return false; - } - - return (page.len || 0) > 0; + showSearch() { + this.show('search.html'); } - function showDirect(path) { - return new Promise(function(resolve, reject) { - resolveOnNextShow = resolve; - page.show(baseUrl() + path); - }); + showLiveTV() { + this.show('livetv.html'); } - function show(path, options) { - if (path.indexOf('/') !== 0 && path.indexOf('://') === -1) { - path = '/' + path; + showRecordedTV() { + this.show('livetv.html?tab=3'); + } + + showFavorites() { + this.show('home.html?tab=1'); + } + + setTitle(title) { + LibraryMenu.setTitle(title); + } + + getRouteUrl(item, options) { + if (!item) { + throw new Error('item cannot be null'); } - path = path.replace(baseUrl(), ''); + if (item.url) { + return item.url; + } - if (currentRouteInfo && currentRouteInfo.path === path) { - // can't use this with home right now due to the back menu - if (currentRouteInfo.route.type !== 'home') { - loading.hide(); - return Promise.resolve(); + const context = options ? options.context : null; + const id = item.Id || item.ItemId; + + if (!options) { + options = {}; + } + + let url; + // TODO: options will never be false. Replace condition with lodash's isEmpty() + const itemType = item.Type || (options ? options.itemType : null); + const serverId = item.ServerId || options.serverId; + + if (item === 'settings') { + return 'mypreferencesmenu.html'; + } + + if (item === 'wizard') { + return 'wizardstart.html'; + } + + if (item === 'manageserver') { + return 'dashboard.html'; + } + + if (item === 'recordedtv') { + return 'livetv.html?tab=3&serverId=' + options.serverId; + } + + if (item === 'nextup') { + return 'list.html?type=nextup&serverId=' + options.serverId; + } + + if (item === 'list') { + let url = 'list.html?serverId=' + options.serverId + '&type=' + options.itemTypes; + + if (options.isFavorite) { + url += '&IsFavorite=true'; + } + + return url; + } + + if (item === 'livetv') { + if (options.section === 'programs') { + return 'livetv.html?tab=0&serverId=' + options.serverId; + } + if (options.section === 'guide') { + return 'livetv.html?tab=1&serverId=' + options.serverId; + } + + if (options.section === 'movies') { + return 'list.html?type=Programs&IsMovie=true&serverId=' + options.serverId; + } + + if (options.section === 'shows') { + return 'list.html?type=Programs&IsSeries=true&IsMovie=false&IsNews=false&serverId=' + options.serverId; + } + + if (options.section === 'sports') { + return 'list.html?type=Programs&IsSports=true&serverId=' + options.serverId; + } + + if (options.section === 'kids') { + return 'list.html?type=Programs&IsKids=true&serverId=' + options.serverId; + } + + if (options.section === 'news') { + return 'list.html?type=Programs&IsNews=true&serverId=' + options.serverId; + } + + if (options.section === 'onnow') { + return 'list.html?type=Programs&IsAiring=true&serverId=' + options.serverId; + } + + if (options.section === 'dvrschedule') { + return 'livetv.html?tab=4&serverId=' + options.serverId; + } + + if (options.section === 'seriesrecording') { + return 'livetv.html?tab=5&serverId=' + options.serverId; + } + + return 'livetv.html?serverId=' + options.serverId; + } + + if (itemType == 'SeriesTimer') { + return 'details?seriesTimerId=' + id + '&serverId=' + serverId; + } + + if (item.CollectionType == 'livetv') { + return 'livetv.html'; + } + + if (item.Type === 'Genre') { + url = 'list.html?genreId=' + item.Id + '&serverId=' + serverId; + + if (context === 'livetv') { + url += '&type=Programs'; + } + + if (options.parentId) { + url += '&parentId=' + options.parentId; + } + + return url; + } + + if (item.Type === 'MusicGenre') { + url = 'list.html?musicGenreId=' + item.Id + '&serverId=' + serverId; + + if (options.parentId) { + url += '&parentId=' + options.parentId; + } + + return url; + } + + if (item.Type === 'Studio') { + url = 'list.html?studioId=' + item.Id + '&serverId=' + serverId; + + if (options.parentId) { + url += '&parentId=' + options.parentId; + } + + return url; + } + + if (context !== 'folders' && !itemHelper.isLocalItem(item)) { + if (item.CollectionType == 'movies') { + url = 'movies.html?topParentId=' + item.Id; + + if (options && options.section === 'latest') { + url += '&tab=1'; + } + + return url; + } + + if (item.CollectionType == 'tvshows') { + url = 'tv.html?topParentId=' + item.Id; + + if (options && options.section === 'latest') { + url += '&tab=2'; + } + + return url; + } + + if (item.CollectionType == 'music') { + return 'music.html?topParentId=' + item.Id; } } - return new Promise(function (resolve, reject) { - resolveOnNextShow = resolve; - page.show(path, options); - }); - } + const itemTypes = ['Playlist', 'TvChannel', 'Program', 'BoxSet', 'MusicAlbum', 'MusicGenre', 'Person', 'Recording', 'MusicArtist']; - var resolveOnNextShow; - document.addEventListener('viewshow', function () { - var resolve = resolveOnNextShow; - if (resolve) { - resolveOnNextShow = null; - resolve(); + if (itemTypes.indexOf(itemType) >= 0) { + return 'details?id=' + id + '&serverId=' + serverId; } - }); - var currentRouteInfo; - function current() { - return currentRouteInfo ? currentRouteInfo.route : null; - } + const contextSuffix = context ? '&context=' + context : ''; - function showItem(item, serverId, options) { - // TODO: Refactor this so it only gets items, not strings. - if (typeof (item) === 'string') { - var apiClient = serverId ? connectionManager.getApiClient(serverId) : connectionManager.currentApiClient(); - apiClient.getItem(apiClient.getCurrentUserId(), item).then(function (itemObject) { - appRouter.showItem(itemObject, options); - }); - } else { - if (arguments.length === 2) { - options = arguments[1]; + if (itemType == 'Series' || itemType == 'Season' || itemType == 'Episode') { + return 'details?id=' + id + contextSuffix + '&serverId=' + serverId; + } + + if (item.IsFolder) { + if (id) { + return 'list.html?parentId=' + id + '&serverId=' + serverId; } - var url = appRouter.getRouteUrl(item, options); - appRouter.show(url, { - item: item - }); - } - } - - var allRoutes = []; - - function addRoute(path, newRoute) { - page(path, getHandler(newRoute)); - allRoutes.push(newRoute); - } - - function getRoutes() { - return allRoutes; - } - - var backdropContainer; - var backgroundContainer; - function setTransparency(level) { - if (!backdropContainer) { - backdropContainer = document.querySelector('.backdropContainer'); - } - if (!backgroundContainer) { - backgroundContainer = document.querySelector('.backgroundContainer'); + return '#'; } - if (level === 'full' || level === 2) { - backdrop.clearBackdrop(true); - document.documentElement.classList.add('transparentDocument'); - backgroundContainer.classList.add('backgroundContainer-transparent'); - backdropContainer.classList.add('hide'); - } else if (level === 'backdrop' || level === 1) { - backdrop.externalBackdrop(true); - document.documentElement.classList.add('transparentDocument'); - backgroundContainer.classList.add('backgroundContainer-transparent'); - backdropContainer.classList.add('hide'); - } else { - backdrop.externalBackdrop(false); - document.documentElement.classList.remove('transparentDocument'); - backgroundContainer.classList.remove('backgroundContainer-transparent'); - backdropContainer.classList.remove('hide'); - } + return 'details?id=' + id + '&serverId=' + serverId; } +} - function pushState(state, title, url) { - state.navigate = false; - history.pushState(state, title, url); - } - - function setBaseRoute() { - var baseRoute = self.location.pathname.replace(getRequestFile(), ''); - if (baseRoute.lastIndexOf('/') === baseRoute.length - 1) { - baseRoute = baseRoute.substring(0, baseRoute.length - 1); - } - - console.debug('setting page base to ' + baseRoute); - page.base(baseRoute); - } - - setBaseRoute(); - - function invokeShortcut(id) { - if (id.indexOf('library-') === 0) { - id = id.replace('library-', ''); - id = id.split('_'); - - appRouter.showItem(id[0], id[1]); - } else if (id.indexOf('item-') === 0) { - id = id.replace('item-', ''); - id = id.split('_'); - - appRouter.showItem(id[0], id[1]); - } else { - id = id.split('_'); - appRouter.show(appRouter.getRouteUrl(id[0], { - serverId: id[1] - })); - } - } - - appRouter.addRoute = addRoute; - appRouter.param = param; - appRouter.back = back; - appRouter.show = show; - appRouter.showDirect = showDirect; - appRouter.start = start; - appRouter.baseUrl = baseUrl; - appRouter.canGoBack = canGoBack; - appRouter.current = current; - appRouter.beginConnectionWizard = beginConnectionWizard; - appRouter.invokeShortcut = invokeShortcut; - appRouter.showItem = showItem; - appRouter.setTransparency = setTransparency; - appRouter.getRoutes = getRoutes; - appRouter.pushState = pushState; - appRouter.enableNativeHistory = enableNativeHistory; - appRouter.handleAnchorClick = page.clickHandler; - appRouter.TransparencyLevel = { - None: 0, - Backdrop: 1, - Full: 2 - }; - - return appRouter; -}); +export default new AppRouter(); diff --git a/src/components/cardbuilder/cardBuilder.js b/src/components/cardbuilder/cardBuilder.js index 4a37331ef4..e644365906 100644 --- a/src/components/cardbuilder/cardBuilder.js +++ b/src/components/cardbuilder/cardBuilder.js @@ -362,12 +362,12 @@ import 'programStyles'; let hasOpenRow; let hasOpenSection; - let sectionTitleTagName = options.sectionTitleTagName || 'div'; + const sectionTitleTagName = options.sectionTitleTagName || 'div'; let apiClient; let lastServerId; for (const [i, item] of items.entries()) { - let serverId = item.ServerId || options.serverId; + const serverId = item.ServerId || options.serverId; if (serverId !== lastServerId) { lastServerId = serverId; @@ -621,7 +621,7 @@ import 'programStyles'; }); } - let blurHashes = options.imageBlurhashes || item.ImageBlurHashes || {}; + const blurHashes = options.imageBlurhashes || item.ImageBlurHashes || {}; return { imgUrl: imgUrl, @@ -656,7 +656,7 @@ import 'programStyles'; for (let i = 0; i < character.length; i++) { sum += parseInt(character.charAt(i)); } - let index = String(sum).substr(-1); + const index = String(sum).substr(-1); return (index % numRandomColors) + 1; } else { @@ -682,7 +682,7 @@ import 'programStyles'; for (let i = 0; i < lines.length; i++) { let currentCssClass = cssClass; - let text = lines[i]; + const text = lines[i]; if (valid > 0 && isOuterFooter) { currentCssClass += ' cardText-secondary'; @@ -707,7 +707,7 @@ import 'programStyles'; } if (forceLines) { - let linesLength = maxLines || Math.min(lines.length, maxLines || lines.length); + const linesLength = maxLines || Math.min(lines.length, maxLines || lines.length); while (valid < linesLength) { html += "
     
    "; @@ -1036,7 +1036,7 @@ import 'programStyles'; * @returns {string} HTML markup for the item count indicator. */ function getItemCountsHtml(options, item) { - let counts = []; + const counts = []; let childText; if (item.Type === 'Playlist') { @@ -1318,7 +1318,7 @@ import 'programStyles'; let cardBoxClose = ''; let cardScalableClose = ''; - let cardContentClass = 'cardContent'; + const cardContentClass = 'cardContent'; let blurhashAttrib = ''; if (blurhash && blurhash.length > 0) { @@ -1337,7 +1337,7 @@ import 'programStyles'; cardImageContainerClose = ''; } - let cardScalableClass = 'cardScalable'; + const cardScalableClass = 'cardScalable'; cardImageContainerOpen = '
    ' + cardImageContainerOpen; cardBoxClose = '
    '; @@ -1681,7 +1681,7 @@ import 'programStyles'; const cells = itemsContainer.querySelectorAll('.card[data-id="' + programId + '"]'); for (let i = 0, length = cells.length; i < length; i++) { - let cell = cells[i]; + const cell = cells[i]; const icon = cell.querySelector('.timerIndicator'); if (!icon) { const indicatorsElem = ensureIndicators(cell); @@ -1700,8 +1700,8 @@ import 'programStyles'; const cells = itemsContainer.querySelectorAll('.card[data-timerid="' + timerId + '"]'); for (let i = 0; i < cells.length; i++) { - let cell = cells[i]; - let icon = cell.querySelector('.timerIndicator'); + const cell = cells[i]; + const icon = cell.querySelector('.timerIndicator'); if (icon) { icon.parentNode.removeChild(icon); } @@ -1718,8 +1718,8 @@ import 'programStyles'; const cells = itemsContainer.querySelectorAll('.card[data-seriestimerid="' + cancelledTimerId + '"]'); for (let i = 0; i < cells.length; i++) { - let cell = cells[i]; - let icon = cell.querySelector('.timerIndicator'); + const cell = cells[i]; + const icon = cell.querySelector('.timerIndicator'); if (icon) { icon.parentNode.removeChild(icon); } diff --git a/src/components/dialogHelper/dialogHelper.js b/src/components/dialogHelper/dialogHelper.js index 1f11d8a195..a9ca595c30 100644 --- a/src/components/dialogHelper/dialogHelper.js +++ b/src/components/dialogHelper/dialogHelper.js @@ -375,7 +375,7 @@ import 'scrollStyles'; dlg.setAttribute('data-lockscroll', 'true'); } - if (options.enableHistory !== false && appRouter.enableNativeHistory()) { + if (options.enableHistory !== false) { dlg.setAttribute('data-history', 'true'); } @@ -391,11 +391,8 @@ import 'scrollStyles'; dlg.setAttribute('data-autofocus', 'true'); } - let defaultEntryAnimation; - let defaultExitAnimation; - - defaultEntryAnimation = 'scaleup'; - defaultExitAnimation = 'scaledown'; + const defaultEntryAnimation = 'scaleup'; + const defaultExitAnimation = 'scaledown'; const entryAnimation = options.entryAnimation || defaultEntryAnimation; const exitAnimation = options.exitAnimation || defaultExitAnimation; diff --git a/src/components/filtermenu/filtermenu.js b/src/components/filtermenu/filtermenu.js index b02b5fb9f8..b976ea3f90 100644 --- a/src/components/filtermenu/filtermenu.js +++ b/src/components/filtermenu/filtermenu.js @@ -2,6 +2,8 @@ define(['require', 'dom', 'focusManager', 'dialogHelper', 'loading', 'apphost', 'use strict'; focusManager = focusManager.default || focusManager; + appRouter = appRouter.default || appRouter; + function onSubmit(e) { e.preventDefault(); return false; diff --git a/src/components/images/imageLoader.js b/src/components/images/imageLoader.js index 0effcc7a57..39dc6c2622 100644 --- a/src/components/images/imageLoader.js +++ b/src/components/images/imageLoader.js @@ -17,8 +17,8 @@ import 'css!./style'; // Although the default values recommended by Blurhash developers is 32x32, a size of 18x18 seems to be the sweet spot for us, // improving the performance and reducing the memory usage, while retaining almost full blur quality. // Lower values had more visible pixelation - let width = 18; - let height = 18; + const width = 18; + const height = 18; let pixels; try { pixels = blurhash.decode(blurhashstr, width, height); @@ -27,11 +27,11 @@ import 'css!./style'; target.classList.add('non-blurhashable'); return; } - let canvas = document.createElement('canvas'); + const canvas = document.createElement('canvas'); canvas.width = width; canvas.height = height; - let ctx = canvas.getContext('2d'); - let imgData = ctx.createImageData(width, height); + const ctx = canvas.getContext('2d'); + const imgData = ctx.createImageData(width, height); imgData.data.set(pixels); ctx.putImageData(imgData, 0, 0); @@ -55,7 +55,7 @@ import 'css!./style'; if (!entry) { throw new Error('entry cannot be null'); } - let target = entry.target; + const target = entry.target; var source = undefined; if (target) { @@ -78,7 +78,7 @@ import 'css!./style'; throw new TypeError('url cannot be undefined'); } - let preloaderImg = new Image(); + const preloaderImg = new Image(); preloaderImg.src = url; elem.classList.add('lazy-hidden'); diff --git a/src/components/indicators/indicators.js b/src/components/indicators/indicators.js index 604f480f1d..bbd672ef72 100644 --- a/src/components/indicators/indicators.js +++ b/src/components/indicators/indicators.js @@ -82,7 +82,7 @@ export function enablePlayedIndicator(item) { export function getPlayedIndicatorHtml(item) { if (enablePlayedIndicator(item)) { - let userData = item.UserData || {}; + const userData = item.UserData || {}; if (userData.UnplayedItemCount) { return '
    ' + userData.UnplayedItemCount + '
    '; } diff --git a/src/components/itemContextMenu.js b/src/components/itemContextMenu.js index 173383d064..a42a7537a1 100644 --- a/src/components/itemContextMenu.js +++ b/src/components/itemContextMenu.js @@ -8,7 +8,6 @@ import browser from 'browser'; import actionsheet from 'actionsheet'; /* eslint-disable indent */ - export function getCommands(options) { const item = options.item; const user = options.user; @@ -16,7 +15,7 @@ import actionsheet from 'actionsheet'; const canPlay = playbackManager.canPlay(item); const restrictOptions = (browser.operaTv || browser.web0s) && !user.Policy.IsAdministrator; - let commands = []; + const commands = []; if (canPlay && item.MediaType !== 'Photo') { if (options.play !== false) { @@ -367,7 +366,7 @@ import actionsheet from 'actionsheet'; case 'copy-stream': { const downloadHref = apiClient.getItemDownloadUrl(itemId); const textAreaCopy = function () { - let textArea = document.createElement('textarea'); + const textArea = document.createElement('textarea'); textArea.value = downloadHref; document.body.appendChild(textArea); textArea.focus(); diff --git a/src/components/mediainfo/mediainfo.js b/src/components/mediainfo/mediainfo.js index 53982040b8..4ead1c4dd8 100644 --- a/src/components/mediainfo/mediainfo.js +++ b/src/components/mediainfo/mediainfo.js @@ -9,7 +9,6 @@ import 'programStyles'; import 'emby-button'; /* eslint-disable indent */ - function getTimerIndicator(item) { let status; diff --git a/src/components/metadataEditor/metadataEditor.js b/src/components/metadataEditor/metadataEditor.js index be44e86b44..3dbf5c4264 100644 --- a/src/components/metadataEditor/metadataEditor.js +++ b/src/components/metadataEditor/metadataEditor.js @@ -247,7 +247,7 @@ import 'flexStyles'; reload(context, parentId, item.ServerId); } else { require(['appRouter'], function (appRouter) { - appRouter.goHome(); + appRouter.default.goHome(); }); } } diff --git a/src/components/nowPlayingBar/nowPlayingBar.js b/src/components/nowPlayingBar/nowPlayingBar.js index d411dcc620..7aa8c623b3 100644 --- a/src/components/nowPlayingBar/nowPlayingBar.js +++ b/src/components/nowPlayingBar/nowPlayingBar.js @@ -500,20 +500,20 @@ import 'emby-ratingbutton'; const textLines = nowPlayingItem ? nowPlayingHelper.getNowPlayingNames(nowPlayingItem) : []; nowPlayingTextElement.innerHTML = ''; if (textLines) { - let itemText = document.createElement('div'); - let secondaryText = document.createElement('div'); + const itemText = document.createElement('div'); + const secondaryText = document.createElement('div'); secondaryText.classList.add('nowPlayingBarSecondaryText'); if (textLines.length > 1) { textLines[1].secondary = true; if (textLines[1].text) { - let text = document.createElement('a'); + const text = document.createElement('a'); text.innerHTML = textLines[1].text; secondaryText.appendChild(text); } } if (textLines[0].text) { - let text = document.createElement('a'); + const text = document.createElement('a'); text.innerHTML = textLines[0].text; itemText.appendChild(text); } @@ -555,10 +555,10 @@ import 'emby-ratingbutton'; if (!layoutManager.mobile) { let contextButton = nowPlayingBarElement.querySelector('.btnToggleContextMenu'); // We remove the previous event listener by replacing the item in each update event - let contextButtonClone = contextButton.cloneNode(true); + const contextButtonClone = contextButton.cloneNode(true); contextButton.parentNode.replaceChild(contextButtonClone, contextButton); contextButton = nowPlayingBarElement.querySelector('.btnToggleContextMenu'); - let options = { + const options = { play: false, queue: false, clearQueue: true, @@ -600,10 +600,10 @@ import 'emby-ratingbutton'; return; } - let shuffleMode = playbackManager.getQueueShuffleMode(); - let context = nowPlayingBarElement; + const shuffleMode = playbackManager.getQueueShuffleMode(); + const context = nowPlayingBarElement; const cssClass = 'buttonActive'; - let toggleShuffleButton = context.querySelector('.btnShuffleQueue'); + const toggleShuffleButton = context.querySelector('.btnShuffleQueue'); switch (shuffleMode) { case 'Shuffle': toggleShuffleButton.classList.add(cssClass); diff --git a/src/components/playback/mediasession.js b/src/components/playback/mediasession.js index 0f275c88f7..5c7ddf45dd 100644 --- a/src/components/playback/mediasession.js +++ b/src/components/playback/mediasession.js @@ -127,7 +127,7 @@ import connectionManager from 'connectionManager'; artwork: getImageUrls(item) }); } else { - let itemImageUrl = seriesImageUrl(item, { maxHeight: 3000 }) || imageUrl(item, { maxHeight: 3000 }); + const itemImageUrl = seriesImageUrl(item, { maxHeight: 3000 }) || imageUrl(item, { maxHeight: 3000 }); window.NativeShell.updateMediaSession({ action: eventName, @@ -244,10 +244,10 @@ import connectionManager from 'connectionManager'; /* eslint-disable-next-line compat/compat */ navigator.mediaSession.setActionHandler('seekto', function (object) { - let item = playbackManager.getPlayerState(currentPlayer).NowPlayingItem; + const item = playbackManager.getPlayerState(currentPlayer).NowPlayingItem; // Convert to ms - let duration = parseInt(item.RunTimeTicks ? (item.RunTimeTicks / 10000) : 0); - let wantedTime = object.seekTime * 1000; + const duration = parseInt(item.RunTimeTicks ? (item.RunTimeTicks / 10000) : 0); + const wantedTime = object.seekTime * 1000; playbackManager.seekPercent(wantedTime / duration * 100, currentPlayer); }); } diff --git a/src/components/remotecontrol/remotecontrol.js b/src/components/remotecontrol/remotecontrol.js index b5ac4c9a8b..363eb5ab00 100644 --- a/src/components/remotecontrol/remotecontrol.js +++ b/src/components/remotecontrol/remotecontrol.js @@ -127,8 +127,8 @@ define(['browser', 'datetime', 'backdrop', 'libraryBrowser', 'listView', 'imageL if (item.Artists != null) { if (item.ArtistItems != null) { for (const artist of item.ArtistItems) { - let artistName = artist.Name; - let artistId = artist.Id; + const artistName = artist.Name; + const artistId = artist.Id; artistsSeries += `${artistName}`; if (artist !== item.ArtistItems.slice(-1)[0]) { artistsSeries += ', '; @@ -185,7 +185,7 @@ define(['browser', 'datetime', 'backdrop', 'libraryBrowser', 'listView', 'imageL let contextButton = context.querySelector('.btnToggleContextMenu'); // We remove the previous event listener by replacing the item in each update event const autoFocusContextButton = document.activeElement === contextButton; - let contextButtonClone = contextButton.cloneNode(true); + const contextButtonClone = contextButton.cloneNode(true); contextButton.parentNode.replaceChild(contextButtonClone, contextButton); contextButton = context.querySelector('.btnToggleContextMenu'); if (autoFocusContextButton) { @@ -362,7 +362,7 @@ define(['browser', 'datetime', 'backdrop', 'libraryBrowser', 'listView', 'imageL function updateRepeatModeDisplay(repeatMode) { var context = dlg; - let toggleRepeatButtons = context.querySelectorAll('.repeatToggleButton'); + const toggleRepeatButtons = context.querySelectorAll('.repeatToggleButton'); const cssClass = 'buttonActive'; let innHtml = ''; let repeatOn = true; @@ -529,12 +529,12 @@ define(['browser', 'datetime', 'backdrop', 'libraryBrowser', 'listView', 'imageL } function onShuffleQueueModeChange(updateView = true) { - let shuffleMode = playbackManager.getQueueShuffleMode(this); - let context = dlg; + const shuffleMode = playbackManager.getQueueShuffleMode(this); + const context = dlg; const cssClass = 'buttonActive'; - let shuffleButtons = context.querySelectorAll('.btnShuffleQueue'); + const shuffleButtons = context.querySelectorAll('.btnShuffleQueue'); - for (let shuffleButton of shuffleButtons) { + for (const shuffleButton of shuffleButtons) { switch (shuffleMode) { case 'Shuffle': shuffleButton.classList.add(cssClass); @@ -877,7 +877,7 @@ define(['browser', 'datetime', 'backdrop', 'libraryBrowser', 'listView', 'imageL volumecontrolHtml += ``; volumecontrolHtml += '
    '; volumecontrolHtml += '
    '; - let optionsSection = context.querySelector('.playlistSectionButton'); + const optionsSection = context.querySelector('.playlistSectionButton'); if (!layoutManager.mobile) { context.querySelector('.nowPlayingSecondaryButtons').insertAdjacentHTML('beforeend', volumecontrolHtml); optionsSection.classList.remove('align-items-center', 'justify-content-center'); diff --git a/src/components/scrollManager.js b/src/components/scrollManager.js index 4ee31a6275..549cb9445c 100644 --- a/src/components/scrollManager.js +++ b/src/components/scrollManager.js @@ -251,7 +251,7 @@ import layoutManager from 'layoutManager'; * @return {ScrollerData} Scroller data. */ function getScrollerData(scroller, vertical) { - let data = {}; + const data = {}; if (!vertical) { data.scrollPos = scroller.scrollLeft; diff --git a/src/components/viewSettings/viewSettings.js b/src/components/viewSettings/viewSettings.js index 67abc25a9c..0427618f26 100644 --- a/src/components/viewSettings/viewSettings.js +++ b/src/components/viewSettings/viewSettings.js @@ -1,6 +1,8 @@ define(['require', 'dialogHelper', 'loading', 'apphost', 'layoutManager', 'connectionManager', 'appRouter', 'globalize', 'userSettings', 'emby-checkbox', 'emby-input', 'paper-icon-button-light', 'emby-select', 'material-icons', 'css!./../formdialog', 'emby-button', 'flexStyles'], function (require, dialogHelper, loading, appHost, layoutManager, connectionManager, appRouter, globalize, userSettings) { 'use strict'; + appRouter = appRouter.default || appRouter; + function onSubmit(e) { e.preventDefault(); return false; diff --git a/src/controllers/dashboard/plugins/repositories/index.js b/src/controllers/dashboard/plugins/repositories/index.js index 3087cdd927..25cbbac38a 100644 --- a/src/controllers/dashboard/plugins/repositories/index.js +++ b/src/controllers/dashboard/plugins/repositories/index.js @@ -105,7 +105,7 @@ export default function(view, params) { }); view.querySelector('.btnNewRepository').addEventListener('click', () => { - let dialog = dialogHelper.createDialog({ + const dialog = dialogHelper.createDialog({ scrollY: false, size: 'large', modal: false, diff --git a/src/controllers/playback/video/index.js b/src/controllers/playback/video/index.js index a8bd0e01f3..8f46d24f0e 100644 --- a/src/controllers/playback/video/index.js +++ b/src/controllers/playback/video/index.js @@ -172,9 +172,7 @@ import 'css!assets/css/videoosd'; } setTitle(displayItem, parentName); - let titleElement; - const osdTitle = view.querySelector('.osdTitle'); - titleElement = osdTitle; + const titleElement = view.querySelector('.osdTitle'); let displayName = itemHelper.getDisplayName(displayItem, { includeParentInfo: displayItem.Type !== 'Program', includeIndexNumber: displayItem.Type !== 'Program' @@ -1442,7 +1440,7 @@ import 'css!assets/css/videoosd'; }); } catch (e) { import('appRouter').then(({default: appRouter}) => { - appRouter.goHome(); + appRouter.default.goHome(); }); } }); @@ -1619,7 +1617,7 @@ import 'css!assets/css/videoosd'; const item = currentItem; if (item && item.Chapters && item.Chapters.length && item.Chapters[0].ImageTag) { - let html = getChapterBubbleHtml(connectionManager.getApiClient(item.ServerId), item, item.Chapters, ticks); + const html = getChapterBubbleHtml(connectionManager.getApiClient(item.ServerId), item, item.Chapters, ticks); if (html) { return html; diff --git a/src/plugins/bookPlayer/plugin.js b/src/plugins/bookPlayer/plugin.js index c167046cb9..9563173536 100644 --- a/src/plugins/bookPlayer/plugin.js +++ b/src/plugins/bookPlayer/plugin.js @@ -27,16 +27,16 @@ export class BookPlayer { this._loaded = false; loading.show(); - let elem = this.createMediaElement(); + const elem = this.createMediaElement(); return this.setCurrentSrc(elem, options); } stop() { this.unbindEvents(); - let elem = this._mediaElement; - let tocElement = this._tocElement; - let rendition = this._rendition; + const elem = this._mediaElement; + const tocElement = this._tocElement; + const rendition = this._rendition; if (elem) { dialogHelper.close(elem); @@ -147,7 +147,7 @@ export class BookPlayer { } bindMediaElementEvents() { - let elem = this._mediaElement; + const elem = this._mediaElement; elem.addEventListener('close', this.onDialogClosed, {once: true}); elem.querySelector('.btnBookplayerExit').addEventListener('click', this.onDialogClosed, {once: true}); @@ -166,7 +166,7 @@ export class BookPlayer { } unbindMediaElementEvents() { - let elem = this._mediaElement; + const elem = this._mediaElement; elem.removeEventListener('close', this.onDialogClosed); elem.querySelector('.btnBookplayerExit').removeEventListener('click', this.onDialogClosed); @@ -231,7 +231,7 @@ export class BookPlayer { } setCurrentSrc(elem, options) { - let item = options.items[0]; + const item = options.items[0]; this._currentItem = item; this.streamInfo = { started: true, @@ -241,8 +241,8 @@ export class BookPlayer { } }; - let serverId = item.ServerId; - let apiClient = connectionManager.getApiClient(serverId); + const serverId = item.ServerId; + const apiClient = connectionManager.getApiClient(serverId); return new Promise((resolve, reject) => { import('epubjs').then(({default: epubjs}) => { @@ -252,14 +252,14 @@ export class BookPlayer { this._currentSrc = downloadHref; this._rendition = rendition; - let cancellationToken = { + const cancellationToken = { shouldCancel: false }; this._cancellationToken = cancellationToken; return rendition.display().then(() => { - let epubElem = document.querySelector('.epub-container'); + const epubElem = document.querySelector('.epub-container'); epubElem.style.display = 'none'; this.bindEvents(); diff --git a/src/plugins/bookPlayer/tableOfContents.js b/src/plugins/bookPlayer/tableOfContents.js index 23e288aff5..a1c5d8f220 100644 --- a/src/plugins/bookPlayer/tableOfContents.js +++ b/src/plugins/bookPlayer/tableOfContents.js @@ -11,7 +11,7 @@ export default class TableOfContents { } destroy() { - let elem = this._elem; + const elem = this._elem; if (elem) { this.unbindEvents(); dialogHelper.close(elem); @@ -21,14 +21,14 @@ export default class TableOfContents { } bindEvents() { - let elem = this._elem; + const elem = this._elem; elem.addEventListener('close', this.onDialogClosed, {once: true}); elem.querySelector('.btnBookplayerTocClose').addEventListener('click', this.onDialogClosed, {once: true}); } unbindEvents() { - let elem = this._elem; + const elem = this._elem; elem.removeEventListener('close', this.onDialogClosed); elem.querySelector('.btnBookplayerTocClose').removeEventListener('click', this.onDialogClosed); @@ -39,10 +39,10 @@ export default class TableOfContents { } replaceLinks(contents, f) { - let links = contents.querySelectorAll('a[href]'); + const links = contents.querySelectorAll('a[href]'); links.forEach((link) => { - let href = link.getAttribute('href'); + const href = link.getAttribute('href'); link.onclick = () => { f(href); @@ -52,9 +52,9 @@ export default class TableOfContents { } createMediaElement() { - let rendition = this._rendition; + const rendition = this._rendition; - let elem = dialogHelper.createDialog({ + const elem = dialogHelper.createDialog({ size: 'small', autoFocus: false, removeOnClose: true @@ -69,7 +69,7 @@ export default class TableOfContents { rendition.book.navigation.forEach((chapter) => { tocHtml += '
  • '; // Remove '../' from href - let link = chapter.href.startsWith('../') ? chapter.href.substr(3) : chapter.href; + const link = chapter.href.startsWith('../') ? chapter.href.substr(3) : chapter.href; tocHtml += `${chapter.label}`; tocHtml += '
  • '; }); @@ -78,7 +78,7 @@ export default class TableOfContents { elem.innerHTML = tocHtml; this.replaceLinks(elem, (href) => { - let relative = rendition.book.path.relative(href); + const relative = rendition.book.path.relative(href); rendition.display(relative); this.destroy(); }); diff --git a/src/plugins/htmlVideoPlayer/plugin.js b/src/plugins/htmlVideoPlayer/plugin.js index 525372ac88..40fa98c650 100644 --- a/src/plugins/htmlVideoPlayer/plugin.js +++ b/src/plugins/htmlVideoPlayer/plugin.js @@ -105,7 +105,7 @@ function tryRemoveElement(elem) { } function hidePrePlaybackPage() { - let animatedPage = document.querySelector('.page:not(.hide)'); + const animatedPage = document.querySelector('.page:not(.hide)'); animatedPage.classList.add('hide'); // At this point, we must hide the scrollbar placeholder, so it's not being displayed while the item is being loaded document.body.classList.remove('force-scroll'); @@ -822,8 +822,8 @@ function tryRemoveElement(elem) { } }); - if (this._currentPlayOptions.fullscreen) { - appRouter.showVideoOsd().then(this.onNavigatedToOsd); + if (self._currentPlayOptions.fullscreen) { + appRouter.show('videoosd.html').then(this.onNavigatedToOsd); } else { appRouter.setTransparency('backdrop'); this.#videoDialog.classList.remove('videoPlayerContainer-onTop'); diff --git a/src/plugins/youtubePlayer/plugin.js b/src/plugins/youtubePlayer/plugin.js index eed75a8116..f7b6a04a97 100644 --- a/src/plugins/youtubePlayer/plugin.js +++ b/src/plugins/youtubePlayer/plugin.js @@ -106,7 +106,7 @@ function onPlaying(instance, playOptions, resolve) { instance.timeUpdateInterval = setInterval(onTimeUpdate.bind(instance), 500); if (playOptions.fullscreen) { - appRouter.showVideoOsd().then(function () { + appRouter.show('videoosd.html').then(function () { instance.videoDialog.classList.remove('onTop'); }); } else { diff --git a/src/scripts/deleteHelper.js b/src/scripts/deleteHelper.js index e10a1568c7..44876c75b3 100644 --- a/src/scripts/deleteHelper.js +++ b/src/scripts/deleteHelper.js @@ -15,7 +15,7 @@ export function deleteItem(options) { const item = options.item; const parentId = item.SeasonId || item.SeriesId || item.ParentId; - let apiClient = connectionManager.getApiClient(item.ServerId); + const apiClient = connectionManager.getApiClient(item.ServerId); return confirm({ @@ -34,7 +34,7 @@ export function deleteItem(options) { } } }, function (err) { - let result = function () { + const result = function () { return Promise.reject(err); }; diff --git a/src/scripts/inputManager.js b/src/scripts/inputManager.js index 3432c9e351..077af39bf7 100644 --- a/src/scripts/inputManager.js +++ b/src/scripts/inputManager.js @@ -39,7 +39,7 @@ import appHost from 'apphost'; dom.removeEventListener(scope, 'command', fn, {}); } - let commandTimes = {}; + const commandTimes = {}; function checkCommandTime(command) { const last = commandTimes[command] || 0; diff --git a/src/scripts/libraryMenu.js b/src/scripts/libraryMenu.js index bbe01276ba..55b8e834e4 100644 --- a/src/scripts/libraryMenu.js +++ b/src/scripts/libraryMenu.js @@ -3,6 +3,7 @@ define(['dom', 'layoutManager', 'inputManager', 'connectionManager', 'events', ' playbackManager = playbackManager.default || playbackManager; browser = browser.default || browser; + appRouter = appRouter.default || appRouter; function renderHeader() { var html = ''; diff --git a/src/scripts/serverNotifications.js b/src/scripts/serverNotifications.js index 87db52402d..e432aee805 100644 --- a/src/scripts/serverNotifications.js +++ b/src/scripts/serverNotifications.js @@ -3,6 +3,7 @@ define(['connectionManager', 'playbackManager', 'syncPlayManager', 'events', 'in playbackManager = playbackManager.default || playbackManager; focusManager = focusManager.default || focusManager; + appRouter = appRouter.default || appRouter; var serverNotifications = {}; diff --git a/src/scripts/site.js b/src/scripts/site.js index cd85c35e83..7a9ca00590 100644 --- a/src/scripts/site.js +++ b/src/scripts/site.js @@ -138,14 +138,14 @@ var Dashboard = { return new Promise(function (resolve, reject) { require(['appRouter'], function (appRouter) { - return appRouter.show(url).then(resolve, reject); + return appRouter.default.show(url).then(resolve, reject); }); }); }, navigate_direct: function (path) { return new Promise(function (resolve, reject) { require(['appRouter'], function (appRouter) { - return appRouter.showDirect(path).then(resolve, reject); + return appRouter.default.showDirect(path).then(resolve, reject); }); }); }, @@ -517,6 +517,7 @@ function initClient() { // ensure that appHost is loaded in this point require(['apphost', 'appRouter'], function (appHost, appRouter) { + appRouter = appRouter.default || appRouter; window.Emby = {}; console.debug('onAppReady: loading dependencies'); @@ -614,10 +615,10 @@ function initClient() { init(); } + var promise; var localApiClient; - let promise; - (function () { + function initRequireJs() { var urlArgs = 'v=' + (window.dashboardVersion || new Date().getDate()); var bowerPath = getBowerPath(); @@ -648,7 +649,9 @@ function initClient() { nowPlayingHelper: componentsPath + '/playback/nowplayinghelper', pluginManager: componentsPath + '/pluginManager', packageManager: componentsPath + '/packageManager', - screensaverManager: componentsPath + '/screensavermanager' + screensaverManager: componentsPath + '/screensavermanager', + chromecastHelper: 'plugins/chromecastPlayer/chromecastHelpers', + appRouter: 'components/appRouter' }; requirejs.onError = onRequireJsError; @@ -847,267 +850,9 @@ function initClient() { return window.ApiClient; }; }); - define('appRouter', [componentsPath + '/appRouter', 'itemHelper'], function (appRouter, itemHelper) { - function showItem(item, serverId, options) { - if (typeof item == 'string') { - require(['connectionManager'], function (connectionManager) { - var apiClient = connectionManager.currentApiClient(); - apiClient.getItem(apiClient.getCurrentUserId(), item).then(function (item) { - appRouter.showItem(item, options); - }); - }); - } else { - if (arguments.length == 2) { - options = arguments[1]; - } - - appRouter.show('/' + appRouter.getRouteUrl(item, options), { - item: item - }); - } - } - - appRouter.showLocalLogin = function (serverId, manualLogin) { - Dashboard.navigate('login.html?serverid=' + serverId); - }; - - appRouter.showVideoOsd = function () { - return Dashboard.navigate('video'); - }; - - appRouter.showSelectServer = function () { - Dashboard.navigate(AppInfo.isNativeApp ? 'selectserver.html' : 'login.html'); - }; - - appRouter.showWelcome = function () { - Dashboard.navigate(AppInfo.isNativeApp ? 'selectserver.html' : 'login.html'); - }; - - appRouter.showSettings = function () { - Dashboard.navigate('mypreferencesmenu.html'); - }; - - appRouter.showGuide = function () { - Dashboard.navigate('livetv.html?tab=1'); - }; - - appRouter.goHome = function () { - Dashboard.navigate('home.html'); - }; - - appRouter.showSearch = function () { - Dashboard.navigate('search.html'); - }; - - appRouter.showLiveTV = function () { - Dashboard.navigate('livetv.html'); - }; - - appRouter.showRecordedTV = function () { - Dashboard.navigate('livetv.html?tab=3'); - }; - - appRouter.showFavorites = function () { - Dashboard.navigate('home.html?tab=1'); - }; - - appRouter.showSettings = function () { - Dashboard.navigate('mypreferencesmenu.html'); - }; - - appRouter.setTitle = function (title) { - LibraryMenu.setTitle(title); - }; - - appRouter.getRouteUrl = function (item, options) { - if (!item) { - throw new Error('item cannot be null'); - } - - if (item.url) { - return item.url; - } - - var context = options ? options.context : null; - var id = item.Id || item.ItemId; - - if (!options) { - options = {}; - } - - var url; - var itemType = item.Type || (options ? options.itemType : null); - var serverId = item.ServerId || options.serverId; - - if (item === 'settings') { - return 'mypreferencesmenu.html'; - } - - if (item === 'wizard') { - return 'wizardstart.html'; - } - - if (item === 'manageserver') { - return 'dashboard.html'; - } - - if (item === 'recordedtv') { - return 'livetv.html?tab=3&serverId=' + options.serverId; - } - - if (item === 'nextup') { - return 'list.html?type=nextup&serverId=' + options.serverId; - } - - if (item === 'list') { - var url = 'list.html?serverId=' + options.serverId + '&type=' + options.itemTypes; - - if (options.isFavorite) { - url += '&IsFavorite=true'; - } - - return url; - } - - if (item === 'livetv') { - if (options.section === 'programs') { - return 'livetv.html?tab=0&serverId=' + options.serverId; - } - if (options.section === 'guide') { - return 'livetv.html?tab=1&serverId=' + options.serverId; - } - - if (options.section === 'movies') { - return 'list.html?type=Programs&IsMovie=true&serverId=' + options.serverId; - } - - if (options.section === 'shows') { - return 'list.html?type=Programs&IsSeries=true&IsMovie=false&IsNews=false&serverId=' + options.serverId; - } - - if (options.section === 'sports') { - return 'list.html?type=Programs&IsSports=true&serverId=' + options.serverId; - } - - if (options.section === 'kids') { - return 'list.html?type=Programs&IsKids=true&serverId=' + options.serverId; - } - - if (options.section === 'news') { - return 'list.html?type=Programs&IsNews=true&serverId=' + options.serverId; - } - - if (options.section === 'onnow') { - return 'list.html?type=Programs&IsAiring=true&serverId=' + options.serverId; - } - - if (options.section === 'dvrschedule') { - return 'livetv.html?tab=4&serverId=' + options.serverId; - } - - if (options.section === 'seriesrecording') { - return 'livetv.html?tab=5&serverId=' + options.serverId; - } - - return 'livetv.html?serverId=' + options.serverId; - } - - if (itemType == 'SeriesTimer') { - return 'details?seriesTimerId=' + id + '&serverId=' + serverId; - } - - if (item.CollectionType == 'livetv') { - return 'livetv.html'; - } - - if (item.Type === 'Genre') { - url = 'list.html?genreId=' + item.Id + '&serverId=' + serverId; - - if (context === 'livetv') { - url += '&type=Programs'; - } - - if (options.parentId) { - url += '&parentId=' + options.parentId; - } - - return url; - } - - if (item.Type === 'MusicGenre') { - url = 'list.html?musicGenreId=' + item.Id + '&serverId=' + serverId; - - if (options.parentId) { - url += '&parentId=' + options.parentId; - } - - return url; - } - - if (item.Type === 'Studio') { - url = 'list.html?studioId=' + item.Id + '&serverId=' + serverId; - - if (options.parentId) { - url += '&parentId=' + options.parentId; - } - - return url; - } - - if (context !== 'folders' && !itemHelper.isLocalItem(item)) { - if (item.CollectionType == 'movies') { - url = 'movies.html?topParentId=' + item.Id; - - if (options && options.section === 'latest') { - url += '&tab=1'; - } - - return url; - } - - if (item.CollectionType == 'tvshows') { - url = 'tv.html?topParentId=' + item.Id; - - if (options && options.section === 'latest') { - url += '&tab=2'; - } - - return url; - } - - if (item.CollectionType == 'music') { - return 'music.html?topParentId=' + item.Id; - } - } - - var itemTypes = ['Playlist', 'TvChannel', 'Program', 'BoxSet', 'MusicAlbum', 'MusicGenre', 'Person', 'Recording', 'MusicArtist']; - - if (itemTypes.indexOf(itemType) >= 0) { - return 'details?id=' + id + '&serverId=' + serverId; - } - - var contextSuffix = context ? '&context=' + context : ''; - - if (itemType == 'Series' || itemType == 'Season' || itemType == 'Episode') { - return 'details?id=' + id + contextSuffix + '&serverId=' + serverId; - } - - if (item.IsFolder) { - if (id) { - return 'list.html?parentId=' + id + '&serverId=' + serverId; - } - - return '#'; - } - - return 'details?id=' + id + '&serverId=' + serverId; - }; - - appRouter.showItem = showItem; - return appRouter; - }); - })(); + } + initRequireJs(); promise.then(onWebComponentsReady); } From 4e860a57286b517867b795ef2b0da7e1b538e743 Mon Sep 17 00:00:00 2001 From: "dependabot-preview[bot]" <27856297+dependabot-preview[bot]@users.noreply.github.com> Date: Thu, 6 Aug 2020 21:12:22 +0000 Subject: [PATCH 065/301] Bump css-loader from 4.2.0 to 4.2.1 Bumps [css-loader](https://github.com/webpack-contrib/css-loader) from 4.2.0 to 4.2.1. - [Release notes](https://github.com/webpack-contrib/css-loader/releases) - [Changelog](https://github.com/webpack-contrib/css-loader/blob/master/CHANGELOG.md) - [Commits](https://github.com/webpack-contrib/css-loader/compare/v4.2.0...v4.2.1) Signed-off-by: dependabot-preview[bot] --- package.json | 2 +- yarn.lock | 8 ++++---- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/package.json b/package.json index bf3ac42f97..146ee850d5 100644 --- a/package.json +++ b/package.json @@ -17,7 +17,7 @@ "babel-loader": "^8.0.6", "browser-sync": "^2.26.12", "copy-webpack-plugin": "^5.1.1", - "css-loader": "^4.2.0", + "css-loader": "^4.2.1", "cssnano": "^4.1.10", "del": "^5.1.0", "eslint": "^7.6.0", diff --git a/yarn.lock b/yarn.lock index 3ec7f21487..ad55e16176 100644 --- a/yarn.lock +++ b/yarn.lock @@ -3020,10 +3020,10 @@ css-has-pseudo@^0.10.0: postcss "^7.0.6" postcss-selector-parser "^5.0.0-rc.4" -css-loader@^4.2.0: - version "4.2.0" - resolved "https://registry.yarnpkg.com/css-loader/-/css-loader-4.2.0.tgz#b57efb92ac8f0cd85bf92d89df9634ef1f51b8bf" - integrity sha512-ko7a9b0iFpWtk9eSI/C8IICvZeGtYnjxYjw45rJprokXj/+kBd/siX4vAIBq9Uij8Jubc4jL1EvSnTjCEwaHSw== +css-loader@^4.2.1: + version "4.2.1" + resolved "https://registry.yarnpkg.com/css-loader/-/css-loader-4.2.1.tgz#9f48fd7eae1219d629a3f085ba9a9102ca1141a7" + integrity sha512-MoqmF1if7Z0pZIEXA4ZF9PgtCXxWbfzfJM+3p+OYfhcrwcqhaCRb74DSnfzRl7e024xEiCRn5hCvfUbTf2sgFA== dependencies: camelcase "^6.0.0" cssesc "^3.0.0" From e9b97185b8ba7197d973fe4b61bb24944e43debd Mon Sep 17 00:00:00 2001 From: MrTimscampi Date: Thu, 6 Aug 2020 23:25:18 +0200 Subject: [PATCH 066/301] Fix broken pages --- src/components/appRouter.js | 30 +++++++++++++++------------ src/plugins/htmlVideoPlayer/plugin.js | 4 ++-- src/plugins/youtubePlayer/plugin.js | 2 +- 3 files changed, 20 insertions(+), 16 deletions(-) diff --git a/src/components/appRouter.js b/src/components/appRouter.js index c7495d6460..dc05acc9fd 100644 --- a/src/components/appRouter.js +++ b/src/components/appRouter.js @@ -69,27 +69,31 @@ class AppRouter { } showLocalLogin(serverId) { - this.show('login.html?serverid=' + serverId); + Dashboard.navigate('login.html?serverid=' + serverId); + } + + showVideoOsd() { + return Dashboard.navigate('video'); } showSelectServer() { - this.show(AppInfo.isNativeApp ? 'selectserver.html' : 'login.html'); + Dashboard.navigate(AppInfo.isNativeApp ? 'selectserver.html' : 'login.html'); } showWelcome() { - this.show(AppInfo.isNativeApp ? 'selectserver.html' : 'login.html'); + Dashboard.navigate(AppInfo.isNativeApp ? 'selectserver.html' : 'login.html'); } showSettings() { - this.show('mypreferencesmenu.html'); + Dashboard.navigate('mypreferencesmenu.html'); } showNowPlaying() { - this.show('/nowplaying.html'); + this.show('queue'); } beginConnectionWizard() { - backdrop.clear(); + backdrop.clearBackdrop(); loading.show(); connectionManager.connect({ enableAutoLogin: appSettings.enableAutoLogin() @@ -231,7 +235,7 @@ class AppRouter { } if (level === 'full' || level === 2) { - backdrop.clear(true); + backdrop.clearBackdrop(true); document.documentElement.classList.add('transparentDocument'); this.backgroundContainer.classList.add('backgroundContainer-transparent'); this.backdropContainer.classList.add('hide'); @@ -628,27 +632,27 @@ class AppRouter { } showGuide() { - this.show('livetv.html?tab=1'); + Dashboard.navigate('livetv.html?tab=1'); } goHome() { - this.show('home.html'); + Dashboard.navigate('home.html'); } showSearch() { - this.show('search.html'); + Dashboard.navigate('search.html'); } showLiveTV() { - this.show('livetv.html'); + Dashboard.navigate('livetv.html'); } showRecordedTV() { - this.show('livetv.html?tab=3'); + Dashboard.navigate('livetv.html?tab=3'); } showFavorites() { - this.show('home.html?tab=1'); + Dashboard.navigate('home.html?tab=1'); } setTitle(title) { diff --git a/src/plugins/htmlVideoPlayer/plugin.js b/src/plugins/htmlVideoPlayer/plugin.js index 40fa98c650..dc59604de9 100644 --- a/src/plugins/htmlVideoPlayer/plugin.js +++ b/src/plugins/htmlVideoPlayer/plugin.js @@ -822,8 +822,8 @@ function tryRemoveElement(elem) { } }); - if (self._currentPlayOptions.fullscreen) { - appRouter.show('videoosd.html').then(this.onNavigatedToOsd); + if (this._currentPlayOptions.fullscreen) { + appRouter.showVideoOsd().then(this.onNavigatedToOsd); } else { appRouter.setTransparency('backdrop'); this.#videoDialog.classList.remove('videoPlayerContainer-onTop'); diff --git a/src/plugins/youtubePlayer/plugin.js b/src/plugins/youtubePlayer/plugin.js index f7b6a04a97..eed75a8116 100644 --- a/src/plugins/youtubePlayer/plugin.js +++ b/src/plugins/youtubePlayer/plugin.js @@ -106,7 +106,7 @@ function onPlaying(instance, playOptions, resolve) { instance.timeUpdateInterval = setInterval(onTimeUpdate.bind(instance), 500); if (playOptions.fullscreen) { - appRouter.show('videoosd.html').then(function () { + appRouter.showVideoOsd().then(function () { instance.videoDialog.classList.remove('onTop'); }); } else { From 232ccb6b9fce607adf6bb4319f0bd6abd40ad48f Mon Sep 17 00:00:00 2001 From: Julien Machiels Date: Thu, 6 Aug 2020 23:26:51 +0200 Subject: [PATCH 067/301] Update src/scripts/serverNotifications.js Co-authored-by: Dmitry Lyzo <56478732+dmitrylyzo@users.noreply.github.com> --- src/scripts/serverNotifications.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/scripts/serverNotifications.js b/src/scripts/serverNotifications.js index 2345cf327a..c84377c880 100644 --- a/src/scripts/serverNotifications.js +++ b/src/scripts/serverNotifications.js @@ -15,7 +15,7 @@ function notifyApp() { function displayMessage(cmd) { const args = cmd.Arguments; if (args.TimeoutMs) { - import('toast').then((toast) => { + import('toast').then(({default: toast}) => { toast({ title: args.Header, text: args.Text }); }); } else { From 915a423997914e09b020dc8cd8dfc15614518886 Mon Sep 17 00:00:00 2001 From: Julien Machiels Date: Thu, 6 Aug 2020 23:26:59 +0200 Subject: [PATCH 068/301] Update src/scripts/serverNotifications.js Co-authored-by: Dmitry Lyzo <56478732+dmitrylyzo@users.noreply.github.com> --- src/scripts/serverNotifications.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/scripts/serverNotifications.js b/src/scripts/serverNotifications.js index c84377c880..2566d148f6 100644 --- a/src/scripts/serverNotifications.js +++ b/src/scripts/serverNotifications.js @@ -19,7 +19,7 @@ function displayMessage(cmd) { toast({ title: args.Header, text: args.Text }); }); } else { - import('alert').then((alert) => { + import('alert').then(({default: alert}) => { alert({ title: args.Header, text: args.Text }); }); } From 878ab482cb43545ba7b91670baec1a8ba49a1759 Mon Sep 17 00:00:00 2001 From: Julien Machiels Date: Thu, 6 Aug 2020 23:27:26 +0200 Subject: [PATCH 069/301] Update src/libraries/scroller.js Co-authored-by: Dmitry Lyzo <56478732+dmitrylyzo@users.noreply.github.com> --- src/libraries/scroller.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/libraries/scroller.js b/src/libraries/scroller.js index ada13403bf..c460ec5b2c 100644 --- a/src/libraries/scroller.js +++ b/src/libraries/scroller.js @@ -2,7 +2,7 @@ * and will be replaced soon by a Vue component. */ - import browser from 'browser'; +import browser from 'browser'; import layoutManager from 'layoutManager'; import dom from 'dom'; import focusManager from 'focusManager'; From 85e01537495a73de3dbd8575ad83c34563b0d0e0 Mon Sep 17 00:00:00 2001 From: Julien Machiels Date: Fri, 7 Aug 2020 00:12:27 +0200 Subject: [PATCH 070/301] Update src/components/pluginManager.js Co-authored-by: Dmitry Lyzo <56478732+dmitrylyzo@users.noreply.github.com> --- src/components/pluginManager.js | 2 -- 1 file changed, 2 deletions(-) diff --git a/src/components/pluginManager.js b/src/components/pluginManager.js index 14f4fdecf9..c4418cbff5 100644 --- a/src/components/pluginManager.js +++ b/src/components/pluginManager.js @@ -51,8 +51,6 @@ import globalize from 'globalize'; } loadPlugin(pluginSpec) { - var instance = this; - if (typeof pluginSpec === 'string') { console.debug('Loading plugin (via deprecated requirejs method): ' + pluginSpec); From 2d5db406c8bfac5c7478b1e2e45896b9cd86af01 Mon Sep 17 00:00:00 2001 From: Julien Machiels Date: Fri, 7 Aug 2020 00:13:16 +0200 Subject: [PATCH 071/301] Update src/scripts/site.js Co-authored-by: Dmitry Lyzo <56478732+dmitrylyzo@users.noreply.github.com> --- src/scripts/site.js | 1 - 1 file changed, 1 deletion(-) diff --git a/src/scripts/site.js b/src/scripts/site.js index 7919ed510f..f8e80408ee 100644 --- a/src/scripts/site.js +++ b/src/scripts/site.js @@ -470,7 +470,6 @@ function initClient() { require(['apphost', 'css!assets/css/librarybrowser'], function (appHost) { loadPlugins(appHost, browser).then(function () { - console.groupEnd('loading packages'); onAppReady(browser); }); }); From 7658cd5900ddc2c46c1edb449a72eaf3394fdb19 Mon Sep 17 00:00:00 2001 From: Cameron Date: Fri, 7 Aug 2020 07:41:49 +0100 Subject: [PATCH 072/301] Migration of logoScreenSaver to ES6 module --- package.json | 1 + src/plugins/logoScreensaver/plugin.js | 308 +++++++++++++------------- 2 files changed, 155 insertions(+), 154 deletions(-) diff --git a/package.json b/package.json index 8038de5f90..42e236d670 100644 --- a/package.json +++ b/package.json @@ -159,6 +159,7 @@ "src/components/sanatizefilename.js", "src/components/scrollManager.js", "src/plugins/htmlVideoPlayer/plugin.js", + "src/plugins/logoScreensaver/plugin.js", "src/components/search/searchfields.js", "src/components/search/searchresults.js", "src/components/settingshelper.js", diff --git a/src/plugins/logoScreensaver/plugin.js b/src/plugins/logoScreensaver/plugin.js index bdd1d34e79..61b8f8a6d6 100644 --- a/src/plugins/logoScreensaver/plugin.js +++ b/src/plugins/logoScreensaver/plugin.js @@ -1,165 +1,165 @@ -define(['pluginManager'], function (pluginManager) { - return function () { - var self = this; +import pluginManager from 'pluginManager'; - self.name = 'Logo ScreenSaver'; - self.type = 'screensaver'; - self.id = 'logoscreensaver'; - self.supportsAnonymous = true; +export default function () { + const self = this; - var interval; + self.name = 'Logo ScreenSaver'; + self.type = 'screensaver'; + self.id = 'logoscreensaver'; + self.supportsAnonymous = true; - function animate() { - var animations = [ + let interval; - bounceInLeft, - bounceInRight, - swing, - tada, - wobble, - rotateIn, - rotateOut - ]; + function animate() { + const animations = [ - var elem = document.querySelector('.logoScreenSaverImage'); + bounceInLeft, + bounceInRight, + swing, + tada, + wobble, + rotateIn, + rotateOut + ]; - if (elem && elem.animate) { - var random = getRandomInt(0, animations.length - 1); + const elem = document.querySelector('.logoScreenSaverImage'); - animations[random](elem, 1); + if (elem && elem.animate) { + const random = getRandomInt(0, animations.length - 1); + + animations[random](elem, 1); + } + } + + function getRandomInt(min, max) { + return Math.floor(Math.random() * (max - min + 1)) + min; + } + + function bounceInLeft(elem, iterations) { + const keyframes = [ + { transform: 'translate3d(-3000px, 0, 0)', opacity: '0', offset: 0 }, + { transform: 'translate3d(25px, 0, 0)', opacity: '1', offset: 0.6 }, + { transform: 'translate3d(-100px, 0, 0)', offset: 0.75 }, + { transform: 'translate3d(5px, 0, 0)', offset: 0.9 }, + { transform: 'none', opacity: '1', offset: 1 }]; + const timing = { duration: 900, iterations: iterations, easing: 'cubic-bezier(0.215, 0.610, 0.355, 1.000)' }; + return elem.animate(keyframes, timing); + } + + function bounceInRight(elem, iterations) { + const keyframes = [ + { transform: 'translate3d(3000px, 0, 0)', opacity: '0', offset: 0 }, + { transform: 'translate3d(-25px, 0, 0)', opacity: '1', offset: 0.6 }, + { transform: 'translate3d(100px, 0, 0)', offset: 0.75 }, + { transform: 'translate3d(-5px, 0, 0)', offset: 0.9 }, + { transform: 'none', opacity: '1', offset: 1 }]; + const timing = { duration: 900, iterations: iterations, easing: 'cubic-bezier(0.215, 0.610, 0.355, 1.000)' }; + return elem.animate(keyframes, timing); + } + + function swing(elem, iterations) { + const keyframes = [ + { transform: 'translate(0%)', offset: 0 }, + { transform: 'rotate3d(0, 0, 1, 15deg)', offset: 0.2 }, + { transform: 'rotate3d(0, 0, 1, -10deg)', offset: 0.4 }, + { transform: 'rotate3d(0, 0, 1, 5deg)', offset: 0.6 }, + { transform: 'rotate3d(0, 0, 1, -5deg)', offset: 0.8 }, + { transform: 'rotate3d(0, 0, 1, 0deg)', offset: 1 }]; + const timing = { duration: 900, iterations: iterations }; + return elem.animate(keyframes, timing); + } + + function tada(elem, iterations) { + const keyframes = [ + { transform: 'scale3d(1, 1, 1)', offset: 0 }, + { transform: 'scale3d(.9, .9, .9) rotate3d(0, 0, 1, -3deg)', offset: 0.1 }, + { transform: 'scale3d(.9, .9, .9) rotate3d(0, 0, 1, -3deg)', offset: 0.2 }, + { transform: 'scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 3deg)', offset: 0.3 }, + { transform: 'scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, -3deg)', offset: 0.4 }, + { transform: 'scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 3deg)', offset: 0.5 }, + { transform: 'scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, -3deg)', offset: 0.6 }, + { transform: 'scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 3deg)', offset: 0.7 }, + { transform: 'scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, -3deg)', offset: 0.8 }, + { transform: 'scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 3deg)', offset: 0.9 }, + { transform: 'scale3d(1, 1, 1)', offset: 1 }]; + const timing = { duration: 900, iterations: iterations }; + return elem.animate(keyframes, timing); + } + + function wobble(elem, iterations) { + const keyframes = [ + { transform: 'translate(0%)', offset: 0 }, + { transform: 'translate3d(20%, 0, 0) rotate3d(0, 0, 1, 3deg)', offset: 0.15 }, + { transform: 'translate3d(-15%, 0, 0) rotate3d(0, 0, 1, -3deg)', offset: 0.45 }, + { transform: 'translate3d(10%, 0, 0) rotate3d(0, 0, 1, 2deg)', offset: 0.6 }, + { transform: 'translate3d(-5%, 0, 0) rotate3d(0, 0, 1, -1deg)', offset: 0.75 }, + { transform: 'translateX(0%)', offset: 1 }]; + const timing = { duration: 900, iterations: iterations }; + return elem.animate(keyframes, timing); + } + + function rotateIn(elem, iterations) { + const keyframes = [{ transform: 'rotate3d(0, 0, 1, -200deg)', opacity: '0', transformOrigin: 'center', offset: 0 }, + { transform: 'none', opacity: '1', transformOrigin: 'center', offset: 1 }]; + const timing = { duration: 900, iterations: iterations }; + return elem.animate(keyframes, timing); + } + + function rotateOut(elem, iterations) { + const keyframes = [{ transform: 'none', opacity: '1', transformOrigin: 'center', offset: 0 }, + { transform: 'rotate3d(0, 0, 1, 200deg)', opacity: '0', transformOrigin: 'center', offset: 1 }]; + const timing = { duration: 900, iterations: iterations }; + return elem.animate(keyframes, timing); + } + + function fadeOut(elem, iterations) { + const keyframes = [ + { opacity: '1', offset: 0 }, + { opacity: '0', offset: 1 }]; + const timing = { duration: 400, iterations: iterations }; + return elem.animate(keyframes, timing); + } + + function stopInterval() { + if (interval) { + clearInterval(interval); + interval = null; + } + } + + self.show = function () { + import('css!' + pluginManager.mapPath(self, 'style.css')).then(() => { + let elem = document.querySelector('.logoScreenSaver'); + + if (!elem) { + elem = document.createElement('div'); + elem.classList.add('logoScreenSaver'); + document.body.appendChild(elem); + + elem.innerHTML = ''; } - } - function getRandomInt(min, max) { - return Math.floor(Math.random() * (max - min + 1)) + min; - } - - function bounceInLeft(elem, iterations) { - var keyframes = [ - { transform: 'translate3d(-3000px, 0, 0)', opacity: '0', offset: 0 }, - { transform: 'translate3d(25px, 0, 0)', opacity: '1', offset: 0.6 }, - { transform: 'translate3d(-100px, 0, 0)', offset: 0.75 }, - { transform: 'translate3d(5px, 0, 0)', offset: 0.9 }, - { transform: 'none', opacity: '1', offset: 1 }]; - var timing = { duration: 900, iterations: iterations, easing: 'cubic-bezier(0.215, 0.610, 0.355, 1.000)' }; - return elem.animate(keyframes, timing); - } - - function bounceInRight(elem, iterations) { - var keyframes = [ - { transform: 'translate3d(3000px, 0, 0)', opacity: '0', offset: 0 }, - { transform: 'translate3d(-25px, 0, 0)', opacity: '1', offset: 0.6 }, - { transform: 'translate3d(100px, 0, 0)', offset: 0.75 }, - { transform: 'translate3d(-5px, 0, 0)', offset: 0.9 }, - { transform: 'none', opacity: '1', offset: 1 }]; - var timing = { duration: 900, iterations: iterations, easing: 'cubic-bezier(0.215, 0.610, 0.355, 1.000)' }; - return elem.animate(keyframes, timing); - } - - function swing(elem, iterations) { - var keyframes = [ - { transform: 'translate(0%)', offset: 0 }, - { transform: 'rotate3d(0, 0, 1, 15deg)', offset: 0.2 }, - { transform: 'rotate3d(0, 0, 1, -10deg)', offset: 0.4 }, - { transform: 'rotate3d(0, 0, 1, 5deg)', offset: 0.6 }, - { transform: 'rotate3d(0, 0, 1, -5deg)', offset: 0.8 }, - { transform: 'rotate3d(0, 0, 1, 0deg)', offset: 1 }]; - var timing = { duration: 900, iterations: iterations }; - return elem.animate(keyframes, timing); - } - - function tada(elem, iterations) { - var keyframes = [ - { transform: 'scale3d(1, 1, 1)', offset: 0 }, - { transform: 'scale3d(.9, .9, .9) rotate3d(0, 0, 1, -3deg)', offset: 0.1 }, - { transform: 'scale3d(.9, .9, .9) rotate3d(0, 0, 1, -3deg)', offset: 0.2 }, - { transform: 'scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 3deg)', offset: 0.3 }, - { transform: 'scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, -3deg)', offset: 0.4 }, - { transform: 'scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 3deg)', offset: 0.5 }, - { transform: 'scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, -3deg)', offset: 0.6 }, - { transform: 'scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 3deg)', offset: 0.7 }, - { transform: 'scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, -3deg)', offset: 0.8 }, - { transform: 'scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 3deg)', offset: 0.9 }, - { transform: 'scale3d(1, 1, 1)', offset: 1 }]; - var timing = { duration: 900, iterations: iterations }; - return elem.animate(keyframes, timing); - } - - function wobble(elem, iterations) { - var keyframes = [ - { transform: 'translate(0%)', offset: 0 }, - { transform: 'translate3d(20%, 0, 0) rotate3d(0, 0, 1, 3deg)', offset: 0.15 }, - { transform: 'translate3d(-15%, 0, 0) rotate3d(0, 0, 1, -3deg)', offset: 0.45 }, - { transform: 'translate3d(10%, 0, 0) rotate3d(0, 0, 1, 2deg)', offset: 0.6 }, - { transform: 'translate3d(-5%, 0, 0) rotate3d(0, 0, 1, -1deg)', offset: 0.75 }, - { transform: 'translateX(0%)', offset: 1 }]; - var timing = { duration: 900, iterations: iterations }; - return elem.animate(keyframes, timing); - } - - function rotateIn(elem, iterations) { - var keyframes = [{ transform: 'rotate3d(0, 0, 1, -200deg)', opacity: '0', transformOrigin: 'center', offset: 0 }, - { transform: 'none', opacity: '1', transformOrigin: 'center', offset: 1 }]; - var timing = { duration: 900, iterations: iterations }; - return elem.animate(keyframes, timing); - } - - function rotateOut(elem, iterations) { - var keyframes = [{ transform: 'none', opacity: '1', transformOrigin: 'center', offset: 0 }, - { transform: 'rotate3d(0, 0, 1, 200deg)', opacity: '0', transformOrigin: 'center', offset: 1 }]; - var timing = { duration: 900, iterations: iterations }; - return elem.animate(keyframes, timing); - } - - function fadeOut(elem, iterations) { - var keyframes = [ - { opacity: '1', offset: 0 }, - { opacity: '0', offset: 1 }]; - var timing = { duration: 400, iterations: iterations }; - return elem.animate(keyframes, timing); - } - - function stopInterval() { - if (interval) { - clearInterval(interval); - interval = null; - } - } - - self.show = function () { - require(['css!' + pluginManager.mapPath(self, 'style.css')], function () { - var elem = document.querySelector('.logoScreenSaver'); - - if (!elem) { - elem = document.createElement('div'); - elem.classList.add('logoScreenSaver'); - document.body.appendChild(elem); - - elem.innerHTML = ''; - } - - stopInterval(); - interval = setInterval(animate, 3000); - }); - }; - - self.hide = function () { stopInterval(); - - var elem = document.querySelector('.logoScreenSaver'); - - if (elem) { - var onAnimationFinish = function () { - elem.parentNode.removeChild(elem); - }; - - if (elem.animate) { - var animation = fadeOut(elem, 1); - animation.onfinish = onAnimationFinish; - } else { - onAnimationFinish(); - } - } - }; + interval = setInterval(animate, 3000); + }); }; -}); + + self.hide = function () { + stopInterval(); + + const elem = document.querySelector('.logoScreenSaver'); + + if (elem) { + const onAnimationFinish = function () { + elem.parentNode.removeChild(elem); + }; + + if (elem.animate) { + const animation = fadeOut(elem, 1); + animation.onfinish = onAnimationFinish; + } else { + onAnimationFinish(); + } + } + }; +} From 6eface92394a99b4705d27bcf403cf8f2369443b Mon Sep 17 00:00:00 2001 From: Cameron Date: Fri, 7 Aug 2020 07:42:09 +0100 Subject: [PATCH 073/301] Migration of playAccessValidation to ES6 module --- package.json | 1 + src/plugins/playAccessValidation/plugin.js | 37 +++++++++------------- 2 files changed, 16 insertions(+), 22 deletions(-) diff --git a/package.json b/package.json index 42e236d670..00381203b1 100644 --- a/package.json +++ b/package.json @@ -160,6 +160,7 @@ "src/components/scrollManager.js", "src/plugins/htmlVideoPlayer/plugin.js", "src/plugins/logoScreensaver/plugin.js", + "src/plugins/playAccessValidation/plugin.js", "src/components/search/searchfields.js", "src/components/search/searchresults.js", "src/components/settingshelper.js", diff --git a/src/plugins/playAccessValidation/plugin.js b/src/plugins/playAccessValidation/plugin.js index 5148d2b821..a9fbeda9a9 100644 --- a/src/plugins/playAccessValidation/plugin.js +++ b/src/plugins/playAccessValidation/plugin.js @@ -1,33 +1,26 @@ -define(['connectionManager', 'globalize'], function (connectionManager, globalize) { - 'use strict'; +import connectionManager from 'connectionManager'; +import globalize from 'globalize'; - function getRequirePromise(deps) { - return new Promise(function (resolve, reject) { - require(deps, resolve); - }); - } +function showErrorMessage() { + return import('alert').then(({default: alert}) => { + return alert(globalize.translate('MessagePlayAccessRestricted')); + }); +} - function showErrorMessage() { - return getRequirePromise(['alert']).then(function (alert) { - return alert(globalize.translate('MessagePlayAccessRestricted')).then(function () { - return Promise.reject(); - }); - }); - } - - function PlayAccessValidation() { +class PlayAccessValidation { + constructor() { this.name = 'Playback validation'; this.type = 'preplayintercept'; this.id = 'playaccessvalidation'; this.order = -2; } - PlayAccessValidation.prototype.intercept = function (options) { - var item = options.item; + intercept(options) { + const item = options.item; if (!item) { return Promise.resolve(); } - var serverId = item.ServerId; + const serverId = item.ServerId; if (!serverId) { return Promise.resolve(); } @@ -44,7 +37,7 @@ define(['connectionManager', 'globalize'], function (connectionManager, globaliz return showErrorMessage(); }); - }; + } +} - return PlayAccessValidation; -}); +export default PlayAccessValidation; From 0b786a5205b8f587ad1f9fede76a0bd1855a02fa Mon Sep 17 00:00:00 2001 From: Cameron Date: Fri, 7 Aug 2020 08:13:51 +0100 Subject: [PATCH 074/301] Fix Linting --- src/libraries/screensavermanager.js | 36 +++++++++++++---------------- 1 file changed, 16 insertions(+), 20 deletions(-) diff --git a/src/libraries/screensavermanager.js b/src/libraries/screensavermanager.js index 557b31e0f4..ca35d38a98 100644 --- a/src/libraries/screensavermanager.js +++ b/src/libraries/screensavermanager.js @@ -1,5 +1,5 @@ -define(["events", "playbackManager", "pluginManager", "inputManager", "connectionManager", "userSettings"], function (events, playbackManager, pluginManager, inputManager, connectionManager, userSettings) { - "use strict"; +define(['events', 'playbackManager', 'pluginManager', 'inputManager', 'connectionManager', 'userSettings'], function (events, playbackManager, pluginManager, inputManager, connectionManager, userSettings) { + 'use strict'; playbackManager = playbackManager.default || playbackManager; @@ -15,23 +15,22 @@ define(["events", "playbackManager", "pluginManager", "inputManager", "connectio return new Date().getTime() - lastFunctionalEvent; } - events.on(playbackManager, "playbackstop", function (e, stopInfo) { + events.on(playbackManager, 'playbackstop', function (e, stopInfo) { var state = stopInfo.state; - if (state.NowPlayingItem && state.NowPlayingItem.MediaType == "Video") { + if (state.NowPlayingItem && state.NowPlayingItem.MediaType == 'Video') { lastFunctionalEvent = new Date().getTime(); } }); function getScreensaverPlugin(isLoggedIn) { - var option; try { - option = userSettings.get("screensaver", false); + option = userSettings.get('screensaver', false); } catch (err) { - option = isLoggedIn ? "backdropscreensaver" : "logoscreensaver"; + option = isLoggedIn ? 'backdropscreensaver' : 'logoscreensaver'; } - var plugins = pluginManager.ofType("screensaver"); + var plugins = pluginManager.ofType('screensaver'); for (var i = 0, length = plugins.length; i < length; i++) { var plugin = plugins[i]; @@ -45,42 +44,40 @@ define(["events", "playbackManager", "pluginManager", "inputManager", "connectio } function ScreenSaverManager() { - var self = this; var activeScreenSaver; function showScreenSaver(screensaver) { - if (activeScreenSaver) { - throw new Error("An existing screensaver is already active."); + throw new Error('An existing screensaver is already active.'); } - console.debug("Showing screensaver " + screensaver.name); + console.debug('Showing screensaver ' + screensaver.name); screensaver.show(); activeScreenSaver = screensaver; if (screensaver.hideOnClick !== false) { - window.addEventListener("click", hide, true); + window.addEventListener('click', hide, true); } if (screensaver.hideOnMouse !== false) { - window.addEventListener("mousemove", hide, true); + window.addEventListener('mousemove', hide, true); } if (screensaver.hideOnKey !== false) { - window.addEventListener("keydown", hide, true); + window.addEventListener('keydown', hide, true); } } function hide() { if (activeScreenSaver) { - console.debug("Hiding screensaver"); + console.debug('Hiding screensaver'); activeScreenSaver.hide(); activeScreenSaver = null; } - window.removeEventListener("click", hide, true); - window.removeEventListener("mousemove", hide, true); - window.removeEventListener("keydown", hide, true); + window.removeEventListener('click', hide, true); + window.removeEventListener('mousemove', hide, true); + window.removeEventListener('keydown', hide, true); } self.isShowing = function () { @@ -107,7 +104,6 @@ define(["events", "playbackManager", "pluginManager", "inputManager", "connectio }; function onInterval() { - if (self.isShowing()) { return; } From e55c8958db714479560689f77d2cf0928ee57f29 Mon Sep 17 00:00:00 2001 From: Cameron Date: Fri, 7 Aug 2020 08:16:18 +0100 Subject: [PATCH 075/301] Migration of experimentalWarnings to ES6 modules --- package.json | 1 + src/plugins/experimentalWarnings/plugin.js | 88 +++++++++++----------- 2 files changed, 47 insertions(+), 42 deletions(-) diff --git a/package.json b/package.json index 1d7cf770d3..2d0f044694 100644 --- a/package.json +++ b/package.json @@ -155,6 +155,7 @@ "src/components/refreshdialog/refreshdialog.js", "src/components/sanatizefilename.js", "src/components/scrollManager.js", + "src/plugins/experimentalWarnings/plugin.js", "src/plugins/htmlVideoPlayer/plugin.js", "src/components/search/searchfields.js", "src/components/search/searchresults.js", diff --git a/src/plugins/experimentalWarnings/plugin.js b/src/plugins/experimentalWarnings/plugin.js index c39612d45b..7450040541 100644 --- a/src/plugins/experimentalWarnings/plugin.js +++ b/src/plugins/experimentalWarnings/plugin.js @@ -1,59 +1,63 @@ -define(['connectionManager', 'globalize', 'userSettings', 'apphost'], function (connectionManager, globalize, userSettings, appHost) { - 'use strict'; +import globalize from 'globalize'; +import * as userSettings from 'userSettings'; +import appHost from 'apphost'; - // TODO: Replace with date-fns - // https://stackoverflow.com/questions/6117814/get-week-of-year-in-javascript-like-in-php - function getWeek(date) { - var d = new Date(Date.UTC(date.getFullYear(), date.getMonth(), date.getDate())); - var dayNum = d.getUTCDay() || 7; - d.setUTCDate(d.getUTCDate() + 4 - dayNum); - var yearStart = new Date(Date.UTC(d.getUTCFullYear(), 0, 1)); - return Math.ceil((((d - yearStart) / 86400000) + 1) / 7); +/*eslint prefer-const: "error"*/ + +// TODO: Replace with date-fns +// https://stackoverflow.com/questions/6117814/get-week-of-year-in-javascript-like-in-php +function getWeek(date) { + const d = new Date(Date.UTC(date.getFullYear(), date.getMonth(), date.getDate())); + const dayNum = d.getUTCDay() || 7; + d.setUTCDate(d.getUTCDate() + 4 - dayNum); + const yearStart = new Date(Date.UTC(d.getUTCFullYear(), 0, 1)); + return Math.ceil((((d - yearStart) / 86400000) + 1) / 7); +} + +function showMessage(text, userSettingsKey, appHostFeature) { + if (appHost.supports(appHostFeature)) { + return Promise.resolve(); } - function showMessage(text, userSettingsKey, appHostFeature) { - if (appHost.supports(appHostFeature)) { - return Promise.resolve(); - } + const now = new Date(); - var now = new Date(); + // TODO: Use date-fns + userSettingsKey += now.getFullYear() + '-w' + getWeek(now); - // TODO: Use date-fns - userSettingsKey += now.getFullYear() + '-w' + getWeek(now); + if (userSettings.get(userSettingsKey, false) === '1') { + return Promise.resolve(); + } - if (userSettings.get(userSettingsKey, false) === '1') { - return Promise.resolve(); - } + return new Promise(function (resolve, reject) { + userSettings.set(userSettingsKey, '1', false); - return new Promise(function (resolve, reject) { - userSettings.set(userSettingsKey, '1', false); - - require(['alert'], function (alert) { - return alert(text).then(resolve, resolve); - }); + import('alert').then(({default: alert}) => { + return alert(text).then(resolve, resolve); }); - } + }); +} - function showBlurayMessage() { - return showMessage(globalize.translate('UnsupportedPlayback'), 'blurayexpirementalinfo', 'nativeblurayplayback'); - } +function showBlurayMessage() { + return showMessage(globalize.translate('UnsupportedPlayback'), 'blurayexpirementalinfo', 'nativeblurayplayback'); +} - function showDvdMessage() { - return showMessage(globalize.translate('UnsupportedPlayback'), 'dvdexpirementalinfo', 'nativedvdplayback'); - } +function showDvdMessage() { + return showMessage(globalize.translate('UnsupportedPlayback'), 'dvdexpirementalinfo', 'nativedvdplayback'); +} - function showIsoMessage() { - return showMessage(globalize.translate('UnsupportedPlayback'), 'isoexpirementalinfo', 'nativeisoplayback'); - } +function showIsoMessage() { + return showMessage(globalize.translate('UnsupportedPlayback'), 'isoexpirementalinfo', 'nativeisoplayback'); +} - function ExpirementalPlaybackWarnings() { +class ExpirementalPlaybackWarnings { + constructor() { this.name = 'Experimental playback warnings'; this.type = 'preplayintercept'; this.id = 'expirementalplaybackwarnings'; } - ExpirementalPlaybackWarnings.prototype.intercept = function (options) { - var item = options.item; + intercept(options) { + const item = options.item; if (!item) { return Promise.resolve(); } @@ -71,7 +75,7 @@ define(['connectionManager', 'globalize', 'userSettings', 'apphost'], function ( } return Promise.resolve(); - }; + } +} - return ExpirementalPlaybackWarnings; -}); +export default ExpirementalPlaybackWarnings; From e6ec5bab0287c932897cedcc7720dfa43ec08c0d Mon Sep 17 00:00:00 2001 From: Cameron Date: Fri, 7 Aug 2020 08:16:35 +0100 Subject: [PATCH 076/301] Migration of sessionPlayer to ES6 module --- package.json | 1 + src/plugins/sessionPlayer/plugin.js | 546 +++++++++++++--------------- 2 files changed, 263 insertions(+), 284 deletions(-) diff --git a/package.json b/package.json index 2d0f044694..4fde07544c 100644 --- a/package.json +++ b/package.json @@ -157,6 +157,7 @@ "src/components/scrollManager.js", "src/plugins/experimentalWarnings/plugin.js", "src/plugins/htmlVideoPlayer/plugin.js", + "src/plugins/sessionPlayer/plugin.js", "src/components/search/searchfields.js", "src/components/search/searchresults.js", "src/components/settingshelper.js", diff --git a/src/plugins/sessionPlayer/plugin.js b/src/plugins/sessionPlayer/plugin.js index fb1f745df3..56d904e2fc 100644 --- a/src/plugins/sessionPlayer/plugin.js +++ b/src/plugins/sessionPlayer/plugin.js @@ -1,131 +1,123 @@ -define(['playbackManager', 'events', 'serverNotifications', 'connectionManager'], function (playbackManager, events, serverNotifications, connectionManager) { - 'use strict'; +import playbackManager from 'playbackManager'; +import events from 'events'; +import serverNotifications from 'serverNotifications'; +import connectionManager from 'connectionManager'; - playbackManager = playbackManager.default || playbackManager; +function getActivePlayerId() { + const info = playbackManager.getPlayerInfo(); + return info ? info.id : null; +} - function getActivePlayerId() { - var info = playbackManager.getPlayerInfo(); - return info ? info.id : null; +function sendPlayCommand(apiClient, options, playType) { + const sessionId = getActivePlayerId(); + + const ids = options.ids || options.items.map(function (i) { + return i.Id; + }); + + const remoteOptions = { + ItemIds: ids.join(','), + + PlayCommand: playType + }; + + if (options.startPositionTicks) { + remoteOptions.StartPositionTicks = options.startPositionTicks; } - function sendPlayCommand(apiClient, options, playType) { - var sessionId = getActivePlayerId(); - - var ids = options.ids || options.items.map(function (i) { - return i.Id; - }); - - var remoteOptions = { - ItemIds: ids.join(','), - - PlayCommand: playType - }; - - if (options.startPositionTicks) { - remoteOptions.StartPositionTicks = options.startPositionTicks; - } - - if (options.mediaSourceId) { - remoteOptions.MediaSourceId = options.mediaSourceId; - } - - if (options.audioStreamIndex != null) { - remoteOptions.AudioStreamIndex = options.audioStreamIndex; - } - - if (options.subtitleStreamIndex != null) { - remoteOptions.SubtitleStreamIndex = options.subtitleStreamIndex; - } - - if (options.startIndex != null) { - remoteOptions.StartIndex = options.startIndex; - } - - return apiClient.sendPlayCommand(sessionId, remoteOptions); + if (options.mediaSourceId) { + remoteOptions.MediaSourceId = options.mediaSourceId; } - function sendPlayStateCommand(apiClient, command, options) { - var sessionId = getActivePlayerId(); - - apiClient.sendPlayStateCommand(sessionId, command, options); + if (options.audioStreamIndex != null) { + remoteOptions.AudioStreamIndex = options.audioStreamIndex; } - function getCurrentApiClient(instance) { - var currentServerId = instance.currentServerId; - - if (currentServerId) { - return connectionManager.getApiClient(currentServerId); - } - - return connectionManager.currentApiClient(); + if (options.subtitleStreamIndex != null) { + remoteOptions.SubtitleStreamIndex = options.subtitleStreamIndex; } - function sendCommandByName(instance, name, options) { - var command = { - Name: name - }; - - if (options) { - command.Arguments = options; - } - - instance.sendCommand(command); + if (options.startIndex != null) { + remoteOptions.StartIndex = options.startIndex; } - function unsubscribeFromPlayerUpdates(instance) { - instance.isUpdating = true; + return apiClient.sendPlayCommand(sessionId, remoteOptions); +} - var apiClient = getCurrentApiClient(instance); - apiClient.sendMessage('SessionsStop'); - if (instance.pollInterval) { - clearInterval(instance.pollInterval); - instance.pollInterval = null; - } +function sendPlayStateCommand(apiClient, command, options) { + const sessionId = getActivePlayerId(); + + apiClient.sendPlayStateCommand(sessionId, command, options); +} + +function getCurrentApiClient(instance) { + const currentServerId = instance.currentServerId; + + if (currentServerId) { + return connectionManager.getApiClient(currentServerId); } - function processUpdatedSessions(instance, sessions, apiClient) { - var serverId = apiClient.serverId(); + return connectionManager.currentApiClient(); +} - sessions.map(function (s) { - if (s.NowPlayingItem) { - s.NowPlayingItem.ServerId = serverId; - } - }); +function sendCommandByName(instance, name, options) { + const command = { + Name: name + }; - var currentTargetId = getActivePlayerId(); - - var session = sessions.filter(function (s) { - return s.Id === currentTargetId; - })[0]; - - if (session) { - normalizeImages(session, apiClient); - - var eventNames = getChangedEvents(instance.lastPlayerData, session); - instance.lastPlayerData = session; - - for (var i = 0, length = eventNames.length; i < length; i++) { - events.trigger(instance, eventNames[i], [session]); - } - } else { - instance.lastPlayerData = session; - - playbackManager.setDefaultPlayerActive(); - } + if (options) { + command.Arguments = options; } - function getChangedEvents(state1, state2) { - var names = []; + instance.sendCommand(command); +} - if (!state1) { - names.push('statechange'); - names.push('timeupdate'); - names.push('pause'); +function unsubscribeFromPlayerUpdates(instance) { + instance.isUpdating = true; - return names; + const apiClient = getCurrentApiClient(instance); + apiClient.sendMessage('SessionsStop'); + if (instance.pollInterval) { + clearInterval(instance.pollInterval); + instance.pollInterval = null; + } +} + +function processUpdatedSessions(instance, sessions, apiClient) { + const serverId = apiClient.serverId(); + + sessions.map(function (s) { + if (s.NowPlayingItem) { + s.NowPlayingItem.ServerId = serverId; } + }); - // TODO: Trim these down to prevent the UI from over-refreshing + const currentTargetId = getActivePlayerId(); + + const session = sessions.filter(function (s) { + return s.Id === currentTargetId; + })[0]; + + if (session) { + normalizeImages(session, apiClient); + + const eventNames = getChangedEvents(instance.lastPlayerData, session); + instance.lastPlayerData = session; + + for (let i = 0, length = eventNames.length; i < length; i++) { + events.trigger(instance, eventNames[i], [session]); + } + } else { + instance.lastPlayerData = session; + + playbackManager.setDefaultPlayerActive(); + } +} + +function getChangedEvents(state1, state2) { + const names = []; + + if (!state1) { names.push('statechange'); names.push('timeupdate'); names.push('pause'); @@ -133,53 +125,62 @@ define(['playbackManager', 'events', 'serverNotifications', 'connectionManager'] return names; } - function onPollIntervalFired() { - var instance = this; - var apiClient = getCurrentApiClient(instance); - if (!apiClient.isMessageChannelOpen()) { - apiClient.getSessions().then(function (sessions) { - processUpdatedSessions(instance, sessions, apiClient); - }); - } + // TODO: Trim these down to prevent the UI from over-refreshing + names.push('statechange'); + names.push('timeupdate'); + names.push('pause'); + + return names; +} + +function onPollIntervalFired() { + const instance = this; + const apiClient = getCurrentApiClient(instance); + if (!apiClient.isMessageChannelOpen()) { + apiClient.getSessions().then(function (sessions) { + processUpdatedSessions(instance, sessions, apiClient); + }); } +} - function subscribeToPlayerUpdates(instance) { - instance.isUpdating = true; +function subscribeToPlayerUpdates(instance) { + instance.isUpdating = true; - var apiClient = getCurrentApiClient(instance); - apiClient.sendMessage('SessionsStart', '100,800'); - if (instance.pollInterval) { - clearInterval(instance.pollInterval); - instance.pollInterval = null; - } - instance.pollInterval = setInterval(onPollIntervalFired.bind(instance), 5000); + const apiClient = getCurrentApiClient(instance); + apiClient.sendMessage('SessionsStart', '100,800'); + if (instance.pollInterval) { + clearInterval(instance.pollInterval); + instance.pollInterval = null; } + instance.pollInterval = setInterval(onPollIntervalFired.bind(instance), 5000); +} - function normalizeImages(state, apiClient) { - if (state && state.NowPlayingItem) { - var item = state.NowPlayingItem; +function normalizeImages(state, apiClient) { + if (state && state.NowPlayingItem) { + const item = state.NowPlayingItem; - if (!item.ImageTags || !item.ImageTags.Primary) { - if (item.PrimaryImageTag) { - item.ImageTags = item.ImageTags || {}; - item.ImageTags.Primary = item.PrimaryImageTag; - } - } - if (item.BackdropImageTag && item.BackdropItemId === item.Id) { - item.BackdropImageTags = [item.BackdropImageTag]; - } - if (item.BackdropImageTag && item.BackdropItemId !== item.Id) { - item.ParentBackdropImageTags = [item.BackdropImageTag]; - item.ParentBackdropItemId = item.BackdropItemId; - } - if (!item.ServerId) { - item.ServerId = apiClient.serverId(); + if (!item.ImageTags || !item.ImageTags.Primary) { + if (item.PrimaryImageTag) { + item.ImageTags = item.ImageTags || {}; + item.ImageTags.Primary = item.PrimaryImageTag; } } + if (item.BackdropImageTag && item.BackdropItemId === item.Id) { + item.BackdropImageTags = [item.BackdropImageTag]; + } + if (item.BackdropImageTag && item.BackdropItemId !== item.Id) { + item.ParentBackdropImageTags = [item.BackdropImageTag]; + item.ParentBackdropItemId = item.BackdropItemId; + } + if (!item.ServerId) { + item.ServerId = apiClient.serverId(); + } } +} - function SessionPlayer() { - var self = this; +class SessionPlayer { + constructor() { + const self = this; this.name = 'Remote Control'; this.type = 'mediaplayer'; @@ -191,7 +192,7 @@ define(['playbackManager', 'events', 'serverNotifications', 'connectionManager'] }); } - SessionPlayer.prototype.beginPlayerUpdates = function () { + beginPlayerUpdates() { this.playerListenerCount = this.playerListenerCount || 0; if (this.playerListenerCount <= 0) { @@ -201,9 +202,9 @@ define(['playbackManager', 'events', 'serverNotifications', 'connectionManager'] } this.playerListenerCount++; - }; + } - SessionPlayer.prototype.endPlayerUpdates = function () { + endPlayerUpdates() { this.playerListenerCount = this.playerListenerCount || 0; this.playerListenerCount--; @@ -211,21 +212,21 @@ define(['playbackManager', 'events', 'serverNotifications', 'connectionManager'] unsubscribeFromPlayerUpdates(this); this.playerListenerCount = 0; } - }; + } - SessionPlayer.prototype.getPlayerState = function () { + getPlayerState() { return this.lastPlayerData || {}; - }; + } - SessionPlayer.prototype.getTargets = function () { - var apiClient = getCurrentApiClient(this); + getTargets() { + const apiClient = getCurrentApiClient(this); - var sessionQuery = { + const sessionQuery = { ControllableByUserId: apiClient.getCurrentUserId() }; if (apiClient) { - var name = this.name; + const name = this.name; return apiClient.getSessions(sessionQuery).then(function (sessions) { return sessions.filter(function (s) { @@ -242,11 +243,9 @@ define(['playbackManager', 'events', 'serverNotifications', 'connectionManager'] isLocalPlayer: false, supportedCommands: s.Capabilities.SupportedCommands, user: s.UserId ? { - Id: s.UserId, Name: s.UserName, PrimaryImageTag: s.UserPrimaryImageTag - } : null }; }); @@ -254,16 +253,16 @@ define(['playbackManager', 'events', 'serverNotifications', 'connectionManager'] } else { return Promise.resolve([]); } - }; + } - SessionPlayer.prototype.sendCommand = function (command) { - var sessionId = getActivePlayerId(); + sendCommand(command) { + const sessionId = getActivePlayerId(); - var apiClient = getCurrentApiClient(this); + const apiClient = getCurrentApiClient(this); apiClient.sendCommand(sessionId, command); - }; + } - SessionPlayer.prototype.play = function (options) { + play(options) { options = Object.assign({}, options); if (options.items) { @@ -275,251 +274,230 @@ define(['playbackManager', 'events', 'serverNotifications', 'connectionManager'] } return sendPlayCommand(getCurrentApiClient(this), options, 'PlayNow'); - }; + } - SessionPlayer.prototype.shuffle = function (item) { + shuffle(item) { sendPlayCommand(getCurrentApiClient(this), { ids: [item.Id] }, 'PlayShuffle'); - }; + } - SessionPlayer.prototype.instantMix = function (item) { + instantMix(item) { sendPlayCommand(getCurrentApiClient(this), { ids: [item.Id] }, 'PlayInstantMix'); - }; + } - SessionPlayer.prototype.queue = function (options) { + queue(options) { sendPlayCommand(getCurrentApiClient(this), options, 'PlayNext'); - }; + } - SessionPlayer.prototype.queueNext = function (options) { + queueNext(options) { sendPlayCommand(getCurrentApiClient(this), options, 'PlayLast'); - }; + } - SessionPlayer.prototype.canPlayMediaType = function (mediaType) { + canPlayMediaType(mediaType) { mediaType = (mediaType || '').toLowerCase(); return mediaType === 'audio' || mediaType === 'video'; - }; + } - SessionPlayer.prototype.canQueueMediaType = function (mediaType) { + canQueueMediaType(mediaType) { return this.canPlayMediaType(mediaType); - }; + } - SessionPlayer.prototype.stop = function () { + stop() { sendPlayStateCommand(getCurrentApiClient(this), 'stop'); - }; + } - SessionPlayer.prototype.nextTrack = function () { + nextTrack() { sendPlayStateCommand(getCurrentApiClient(this), 'nextTrack'); - }; + } - SessionPlayer.prototype.previousTrack = function () { + previousTrack() { sendPlayStateCommand(getCurrentApiClient(this), 'previousTrack'); - }; + } - SessionPlayer.prototype.seek = function (positionTicks) { + seek(positionTicks) { sendPlayStateCommand(getCurrentApiClient(this), 'seek', { SeekPositionTicks: positionTicks }); - }; + } - SessionPlayer.prototype.currentTime = function (val) { + currentTime(val) { if (val != null) { return this.seek(val); } - var state = this.lastPlayerData || {}; + let state = this.lastPlayerData || {}; state = state.PlayState || {}; return state.PositionTicks; - }; + } - SessionPlayer.prototype.duration = function () { - var state = this.lastPlayerData || {}; + duration() { + let state = this.lastPlayerData || {}; state = state.NowPlayingItem || {}; return state.RunTimeTicks; - }; + } - SessionPlayer.prototype.paused = function () { - var state = this.lastPlayerData || {}; + paused() { + let state = this.lastPlayerData || {}; state = state.PlayState || {}; return state.IsPaused; - }; + } - SessionPlayer.prototype.getVolume = function () { - var state = this.lastPlayerData || {}; + getVolume() { + let state = this.lastPlayerData || {}; state = state.PlayState || {}; return state.VolumeLevel; - }; + } - SessionPlayer.prototype.isMuted = function () { - var state = this.lastPlayerData || {}; + isMuted() { + let state = this.lastPlayerData || {}; state = state.PlayState || {}; return state.IsMuted; - }; + } - SessionPlayer.prototype.pause = function () { + pause() { sendPlayStateCommand(getCurrentApiClient(this), 'Pause'); - }; + } - SessionPlayer.prototype.unpause = function () { + unpause() { sendPlayStateCommand(getCurrentApiClient(this), 'Unpause'); - }; + } - SessionPlayer.prototype.playPause = function () { + playPause() { sendPlayStateCommand(getCurrentApiClient(this), 'PlayPause'); - }; + } - SessionPlayer.prototype.setMute = function (isMuted) { + setMute(isMuted) { if (isMuted) { sendCommandByName(this, 'Mute'); } else { sendCommandByName(this, 'Unmute'); } - }; + } - SessionPlayer.prototype.toggleMute = function () { + toggleMute() { sendCommandByName(this, 'ToggleMute'); - }; + } - SessionPlayer.prototype.setVolume = function (vol) { + setVolume(vol) { sendCommandByName(this, 'SetVolume', { Volume: vol }); - }; + } - SessionPlayer.prototype.volumeUp = function () { + volumeUp() { sendCommandByName(this, 'VolumeUp'); - }; + } - SessionPlayer.prototype.volumeDown = function () { + volumeDown() { sendCommandByName(this, 'VolumeDown'); - }; + } - SessionPlayer.prototype.toggleFullscreen = function () { + toggleFullscreen() { sendCommandByName(this, 'ToggleFullscreen'); - }; + } - SessionPlayer.prototype.audioTracks = function () { - var state = this.lastPlayerData || {}; + audioTracks() { + let state = this.lastPlayerData || {}; state = state.NowPlayingItem || {}; - var streams = state.MediaStreams || []; + const streams = state.MediaStreams || []; return streams.filter(function (s) { return s.Type === 'Audio'; }); - }; + } - SessionPlayer.prototype.getAudioStreamIndex = function () { - var state = this.lastPlayerData || {}; + getAudioStreamIndex() { + let state = this.lastPlayerData || {}; state = state.PlayState || {}; return state.AudioStreamIndex; - }; + } - SessionPlayer.prototype.playTrailers = function (item) { + playTrailers(item) { sendCommandByName(this, 'PlayTrailers', { ItemId: item.Id }); - }; + } - SessionPlayer.prototype.setAudioStreamIndex = function (index) { + setAudioStreamIndex(index) { sendCommandByName(this, 'SetAudioStreamIndex', { Index: index }); - }; + } - SessionPlayer.prototype.subtitleTracks = function () { - var state = this.lastPlayerData || {}; + subtitleTracks() { + let state = this.lastPlayerData || {}; state = state.NowPlayingItem || {}; - var streams = state.MediaStreams || []; + const streams = state.MediaStreams || []; return streams.filter(function (s) { return s.Type === 'Subtitle'; }); - }; + } - SessionPlayer.prototype.getSubtitleStreamIndex = function () { - var state = this.lastPlayerData || {}; + getSubtitleStreamIndex() { + let state = this.lastPlayerData || {}; state = state.PlayState || {}; return state.SubtitleStreamIndex; - }; + } - SessionPlayer.prototype.setSubtitleStreamIndex = function (index) { + setSubtitleStreamIndex(index) { sendCommandByName(this, 'SetSubtitleStreamIndex', { Index: index }); - }; + } - SessionPlayer.prototype.getMaxStreamingBitrate = function () { + setMaxStreamingBitrate(options) { + } - }; - - SessionPlayer.prototype.setMaxStreamingBitrate = function (options) { - - }; - - SessionPlayer.prototype.isFullscreen = function () { - - }; - - SessionPlayer.prototype.toggleFullscreen = function () { - - }; - - SessionPlayer.prototype.getRepeatMode = function () { - - }; - - SessionPlayer.prototype.setRepeatMode = function (mode) { + setRepeatMode(mode) { sendCommandByName(this, 'SetRepeatMode', { RepeatMode: mode }); - }; + } - SessionPlayer.prototype.setQueueShuffleMode = function (mode) { + setQueueShuffleMode(mode) { sendCommandByName(this, 'SetShuffleQueue', { ShuffleMode: mode }); - }; + } - SessionPlayer.prototype.getQueueShuffleMode = function () { + getQueueShuffleMode() { + } - }; - - SessionPlayer.prototype.displayContent = function (options) { + displayContent(options) { sendCommandByName(this, 'DisplayContent', options); - }; + } - SessionPlayer.prototype.isPlaying = function () { - var state = this.lastPlayerData || {}; + isPlaying() { + const state = this.lastPlayerData || {}; return state.NowPlayingItem != null; - }; + } - SessionPlayer.prototype.isPlayingVideo = function () { - var state = this.lastPlayerData || {}; + isPlayingVideo() { + let state = this.lastPlayerData || {}; state = state.NowPlayingItem || {}; return state.MediaType === 'Video'; - }; + } - SessionPlayer.prototype.isPlayingAudio = function () { - var state = this.lastPlayerData || {}; + isPlayingAudio() { + let state = this.lastPlayerData || {}; state = state.NowPlayingItem || {}; return state.MediaType === 'Audio'; - }; + } - SessionPlayer.prototype.getPlaylist = function () { + getPlaylist() { return Promise.resolve([]); - }; + } - SessionPlayer.prototype.getCurrentPlaylistItemId = function () { - }; - - SessionPlayer.prototype.setCurrentPlaylistItem = function (playlistItemId) { + setCurrentPlaylistItem(playlistItemId) { return Promise.resolve(); - }; + } - SessionPlayer.prototype.removeFromPlaylist = function (playlistItemIds) { + removeFromPlaylist(playlistItemIds) { return Promise.resolve(); - }; + } - SessionPlayer.prototype.tryPair = function (target) { + tryPair(target) { return Promise.resolve(); - }; + } +} - return SessionPlayer; -}); +export default SessionPlayer; From e0b56a2e956d9c598e28e6e434a23f3350335084 Mon Sep 17 00:00:00 2001 From: Cameron Date: Fri, 7 Aug 2020 08:19:47 +0100 Subject: [PATCH 077/301] Migration of tunerPicker to ES6 modules --- package.json | 1 + src/components/tunerPicker.js | 325 +++++++++++++++++----------------- 2 files changed, 168 insertions(+), 158 deletions(-) diff --git a/package.json b/package.json index 6e2480ca05..9d0bbacc68 100644 --- a/package.json +++ b/package.json @@ -172,6 +172,7 @@ "src/components/tvproviders/schedulesdirect.js", "src/components/tvproviders/xmltv.js", "src/components/toast/toast.js", + "src/components/tunerPicker.js", "src/components/upnextdialog/upnextdialog.js", "src/components/viewContainer.js", "src/components/castSenderApi.js", diff --git a/src/components/tunerPicker.js b/src/components/tunerPicker.js index 4e78030a2a..4ad5fd816d 100644 --- a/src/components/tunerPicker.js +++ b/src/components/tunerPicker.js @@ -1,181 +1,190 @@ -define(['dialogHelper', 'dom', 'layoutManager', 'connectionManager', 'globalize', 'loading', 'browser', 'focusManager', 'scrollHelper', 'material-icons', 'formDialogStyle', 'emby-button', 'emby-itemscontainer', 'cardStyle'], function (dialogHelper, dom, layoutManager, connectionManager, globalize, loading, browser, focusManager, scrollHelper) { - 'use strict'; +import dialogHelper from 'dialogHelper'; +import dom from 'dom'; +import layoutManager from 'layoutManager'; +import connectionManager from 'connectionManager'; +import globalize from 'globalize'; +import loading from 'loading'; +import browser from 'browser'; +import focusManager from 'focusManager'; +import scrollHelper from 'scrollHelper'; +import 'material-icons'; +import 'formDialogStyle'; +import 'emby-button'; +import 'emby-itemscontainer'; +import 'cardStyle'; - browser = browser.default || browser; - loading = loading.default || loading; - focusManager = focusManager.default || focusManager; +/*eslint prefer-const: "error"*/ - var enableFocusTransform = !browser.slow && !browser.edge; +const enableFocusTransform = !browser.slow && !browser.edge; - function getEditorHtml() { - var html = ''; - html += '
    '; - html += '
    '; - html += '
    '; - html += '

    ' + globalize.translate('DetectingDevices') + '...

    '; - html += '

    ' + globalize.translate('MessagePleaseWait') + '

    '; - html += '
    '; - html += '

    ' + globalize.translate('HeaderNewDevices') + '

    '; - html += '
    '; - html += '
    '; - html += '
    '; - return html += '
    '; - } +function getEditorHtml() { + let html = ''; + html += '
    '; + html += '
    '; + html += '
    '; + html += '

    ' + globalize.translate('DetectingDevices') + '...

    '; + html += '

    ' + globalize.translate('MessagePleaseWait') + '

    '; + html += '
    '; + html += '

    ' + globalize.translate('HeaderNewDevices') + '

    '; + html += '
    '; + html += '
    '; + html += '
    '; + return html += '
    '; +} - function getDeviceHtml(device) { - var padderClass; - var html = ''; - var cssClass = 'card scalableCard'; - var cardBoxCssClass = 'cardBox visualCardBox'; - cssClass += ' backdropCard backdropCard-scalable'; - padderClass = 'cardPadder-backdrop'; +function getDeviceHtml(device) { + let html = ''; + let cssClass = 'card scalableCard'; + const cardBoxCssClass = 'cardBox visualCardBox'; + cssClass += ' backdropCard backdropCard-scalable'; + const padderClass = 'cardPadder-backdrop'; - // TODO move card creation code to Card component + // TODO move card creation code to Card component - if (layoutManager.tv) { - cssClass += ' show-focus'; + if (layoutManager.tv) { + cssClass += ' show-focus'; - if (enableFocusTransform) { - cssClass += ' show-animation'; - } - } - - html += ''; - } - - function getTunerName(providerId) { - switch (providerId = providerId.toLowerCase()) { - case 'm3u': - return 'M3U'; - - case 'hdhomerun': - return 'HDHomerun'; - - case 'hauppauge': - return 'Hauppauge'; - - case 'satip': - return 'DVB'; - - default: - return 'Unknown'; + if (enableFocusTransform) { + cssClass += ' show-animation'; } } - function renderDevices(view, devices) { - var i; - var length; - var html = ''; + html += ''; +} - for (i = 0, length = devices.length; i < length; i++) { - html += getDeviceHtml(devices[i]); - } +function getTunerName(providerId) { + switch (providerId = providerId.toLowerCase()) { + case 'm3u': + return 'M3U'; - if (devices.length) { - view.querySelector('.devicesHeader').classList.remove('hide'); - } else { - html = '


    ' + globalize.translate('NoNewDevicesFound') + '

    '; - view.querySelector('.devicesHeader').classList.add('hide'); - } + case 'hdhomerun': + return 'HDHomerun'; - var elem = view.querySelector('.results'); - elem.innerHTML = html; + case 'hauppauge': + return 'Hauppauge'; - if (layoutManager.tv) { - focusManager.autoFocus(elem); - } + case 'satip': + return 'DVB'; + + default: + return 'Unknown'; + } +} + +function renderDevices(view, devices) { + let i; + let length; + let html = ''; + + for (i = 0, length = devices.length; i < length; i++) { + html += getDeviceHtml(devices[i]); } - function discoverDevices(view, apiClient) { - loading.show(); - view.querySelector('.loadingContent').classList.remove('hide'); - return ApiClient.getJSON(ApiClient.getUrl('LiveTv/Tuners/Discvover', { - NewDevicesOnly: true - })).then(function (devices) { - currentDevices = devices; - renderDevices(view, devices); - view.querySelector('.loadingContent').classList.add('hide'); - loading.hide(); - }); + if (devices.length) { + view.querySelector('.devicesHeader').classList.remove('hide'); + } else { + html = '


    ' + globalize.translate('NoNewDevicesFound') + '

    '; + view.querySelector('.devicesHeader').classList.add('hide'); } - function tunerPicker() { - this.show = function (options) { - var dialogOptions = { - removeOnClose: true, - scrollY: false - }; + const elem = view.querySelector('.results'); + elem.innerHTML = html; - if (layoutManager.tv) { - dialogOptions.size = 'fullscreen'; - } else { - dialogOptions.size = 'small'; - } + if (layoutManager.tv) { + focusManager.autoFocus(elem); + } +} - var dlg = dialogHelper.createDialog(dialogOptions); - dlg.classList.add('formDialog'); - var html = ''; - html += '
    '; - html += ''; - html += '

    '; - html += globalize.translate('HeaderLiveTvTunerSetup'); - html += '

    '; - html += '
    '; - html += getEditorHtml(); - dlg.innerHTML = html; - dlg.querySelector('.btnCancel').addEventListener('click', function () { - dialogHelper.close(dlg); - }); - var deviceResult; - dlg.querySelector('.results').addEventListener('click', function (e) { - var tunerCard = dom.parentWithClass(e.target, 'card'); +function discoverDevices(view, apiClient) { + loading.show(); + view.querySelector('.loadingContent').classList.remove('hide'); + return ApiClient.getJSON(ApiClient.getUrl('LiveTv/Tuners/Discvover', { + NewDevicesOnly: true + })).then(function (devices) { + currentDevices = devices; + renderDevices(view, devices); + view.querySelector('.loadingContent').classList.add('hide'); + loading.hide(); + }); +} - if (tunerCard) { - var deviceId = tunerCard.getAttribute('data-id'); - deviceResult = currentDevices.filter(function (d) { - return d.DeviceId === deviceId; - })[0]; - dialogHelper.close(dlg); - } - }); - - if (layoutManager.tv) { - scrollHelper.centerFocus.on(dlg.querySelector('.formDialogContent'), false); - } - - var apiClient = connectionManager.getApiClient(options.serverId); - discoverDevices(dlg, apiClient); - - if (layoutManager.tv) { - scrollHelper.centerFocus.off(dlg.querySelector('.formDialogContent'), false); - } - - return dialogHelper.open(dlg).then(function () { - if (deviceResult) { - return Promise.resolve(deviceResult); - } - - return Promise.reject(); - }); +function tunerPicker() { + this.show = function (options) { + const dialogOptions = { + removeOnClose: true, + scrollY: false }; - } - var currentDevices = []; - return tunerPicker; -}); + if (layoutManager.tv) { + dialogOptions.size = 'fullscreen'; + } else { + dialogOptions.size = 'small'; + } + + const dlg = dialogHelper.createDialog(dialogOptions); + dlg.classList.add('formDialog'); + let html = ''; + html += '
    '; + html += ''; + html += '

    '; + html += globalize.translate('HeaderLiveTvTunerSetup'); + html += '

    '; + html += '
    '; + html += getEditorHtml(); + dlg.innerHTML = html; + dlg.querySelector('.btnCancel').addEventListener('click', function () { + dialogHelper.close(dlg); + }); + let deviceResult; + dlg.querySelector('.results').addEventListener('click', function (e) { + const tunerCard = dom.parentWithClass(e.target, 'card'); + + if (tunerCard) { + const deviceId = tunerCard.getAttribute('data-id'); + deviceResult = currentDevices.filter(function (d) { + return d.DeviceId === deviceId; + })[0]; + dialogHelper.close(dlg); + } + }); + + if (layoutManager.tv) { + scrollHelper.centerFocus.on(dlg.querySelector('.formDialogContent'), false); + } + + const apiClient = connectionManager.getApiClient(options.serverId); + discoverDevices(dlg, apiClient); + + if (layoutManager.tv) { + scrollHelper.centerFocus.off(dlg.querySelector('.formDialogContent'), false); + } + + return dialogHelper.open(dlg).then(function () { + if (deviceResult) { + return Promise.resolve(deviceResult); + } + + return Promise.reject(); + }); + }; +} + +let currentDevices = []; + +export default tunerPicker; From 03eff35a3461b93799583d167bd5442fded8bd28 Mon Sep 17 00:00:00 2001 From: Cameron Date: Fri, 7 Aug 2020 08:21:55 +0100 Subject: [PATCH 078/301] Migration of userdatabuttons to ES6 modules --- package.json | 1 + .../userdatabuttons/userdatabuttons.js | 325 +++++++++--------- 2 files changed, 166 insertions(+), 160 deletions(-) diff --git a/package.json b/package.json index 9d0bbacc68..200ade97b7 100644 --- a/package.json +++ b/package.json @@ -174,6 +174,7 @@ "src/components/toast/toast.js", "src/components/tunerPicker.js", "src/components/upnextdialog/upnextdialog.js", + "src/components/userdatabuttons/userdatabuttons.js", "src/components/viewContainer.js", "src/components/castSenderApi.js", "src/controllers/session/addServer/index.js", diff --git a/src/components/userdatabuttons/userdatabuttons.js b/src/components/userdatabuttons/userdatabuttons.js index e3a7b9e06b..2b09095574 100644 --- a/src/components/userdatabuttons/userdatabuttons.js +++ b/src/components/userdatabuttons/userdatabuttons.js @@ -1,214 +1,219 @@ -define(['connectionManager', 'globalize', 'dom', 'itemHelper', 'paper-icon-button-light', 'material-icons', 'emby-button', 'css!./userdatabuttons'], function (connectionManager, globalize, dom, itemHelper) { - 'use strict'; +import connectionManager from 'connectionManager'; +import globalize from 'globalize'; +import dom from 'dom'; +import itemHelper from 'itemHelper'; +import 'paper-icon-button-light'; +import 'material-icons'; +import 'emby-button'; +import 'css!./userdatabuttons'; - var userDataMethods = { - markPlayed: markPlayed, - markDislike: markDislike, - markLike: markLike, - markFavorite: markFavorite - }; +const userDataMethods = { + markPlayed: markPlayed, + markDislike: markDislike, + markLike: markLike, + markFavorite: markFavorite +}; - function getUserDataButtonHtml(method, itemId, serverId, buttonCssClass, iconCssClass, icon, tooltip, style) { - if (style === 'fab-mini') { - style = 'fab'; - buttonCssClass = buttonCssClass ? (buttonCssClass + ' mini') : 'mini'; - } - - var is = style === 'fab' ? 'emby-button' : 'paper-icon-button-light'; - var className = style === 'fab' ? 'autoSize fab' : 'autoSize'; - - if (buttonCssClass) { - className += ' ' + buttonCssClass; - } - - if (iconCssClass) { - iconCssClass += ' '; - } else { - iconCssClass = ''; - } - - iconCssClass += 'material-icons'; - - return ''; +function getUserDataButtonHtml(method, itemId, serverId, buttonCssClass, iconCssClass, icon, tooltip, style) { + if (style === 'fab-mini') { + style = 'fab'; + buttonCssClass = buttonCssClass ? (buttonCssClass + ' mini') : 'mini'; } - function onContainerClick(e) { - var btnUserData = dom.parentWithClass(e.target, 'btnUserData'); + const is = style === 'fab' ? 'emby-button' : 'paper-icon-button-light'; + let className = style === 'fab' ? 'autoSize fab' : 'autoSize'; - if (!btnUserData) { - return; - } - - var method = btnUserData.getAttribute('data-method'); - userDataMethods[method](btnUserData); + if (buttonCssClass) { + className += ' ' + buttonCssClass; } - function fill(options) { - var html = getIconsHtml(options); - - if (options.fillMode === 'insertAdjacent') { - options.element.insertAdjacentHTML(options.insertLocation || 'beforeend', html); - } else { - options.element.innerHTML = html; - } - - dom.removeEventListener(options.element, 'click', onContainerClick, { - passive: true - }); - - dom.addEventListener(options.element, 'click', onContainerClick, { - passive: true - }); + if (iconCssClass) { + iconCssClass += ' '; + } else { + iconCssClass = ''; } - function destroy(options) { - options.element.innerHTML = ''; + iconCssClass += 'material-icons'; - dom.removeEventListener(options.element, 'click', onContainerClick, { - passive: true - }); + return ''; +} + +function onContainerClick(e) { + const btnUserData = dom.parentWithClass(e.target, 'btnUserData'); + + if (!btnUserData) { + return; } - function getIconsHtml(options) { - var item = options.item; - var includePlayed = options.includePlayed; - var cssClass = options.cssClass; - var style = options.style; + const method = btnUserData.getAttribute('data-method'); + userDataMethods[method](btnUserData); +} - var html = ''; +function fill(options) { + const html = getIconsHtml(options); - var userData = item.UserData || {}; + if (options.fillMode === 'insertAdjacent') { + options.element.insertAdjacentHTML(options.insertLocation || 'beforeend', html); + } else { + options.element.innerHTML = html; + } - var itemId = item.Id; + dom.removeEventListener(options.element, 'click', onContainerClick, { + passive: true + }); - if (itemHelper.isLocalItem(item)) { - return html; - } + dom.addEventListener(options.element, 'click', onContainerClick, { + passive: true + }); +} - var btnCssClass = 'btnUserData'; +function destroy(options) { + options.element.innerHTML = ''; - if (cssClass) { - btnCssClass += ' ' + cssClass; - } + dom.removeEventListener(options.element, 'click', onContainerClick, { + passive: true + }); +} - var iconCssClass = options.iconCssClass; +function getIconsHtml(options) { + const item = options.item; + const includePlayed = options.includePlayed; + const cssClass = options.cssClass; + const style = options.style; - var serverId = item.ServerId; + let html = ''; - if (includePlayed !== false) { - var tooltipPlayed = globalize.translate('MarkPlayed'); + const userData = item.UserData || {}; - if (itemHelper.canMarkPlayed(item)) { - if (userData.Played) { - html += getUserDataButtonHtml('markPlayed', itemId, serverId, btnCssClass + ' btnUserDataOn', iconCssClass, 'check', tooltipPlayed, style); - } else { - html += getUserDataButtonHtml('markPlayed', itemId, serverId, btnCssClass, iconCssClass, 'check', tooltipPlayed, style); - } - } - } - - var tooltipFavorite = globalize.translate('Favorite'); - if (userData.IsFavorite) { - html += getUserDataButtonHtml('markFavorite', itemId, serverId, btnCssClass + ' btnUserData btnUserDataOn', iconCssClass, 'favorite', tooltipFavorite, style); - } else { - html += getUserDataButtonHtml('markFavorite', itemId, serverId, btnCssClass + ' btnUserData', iconCssClass, 'favorite', tooltipFavorite, style); - } + const itemId = item.Id; + if (itemHelper.isLocalItem(item)) { return html; } - function markFavorite(link) { - var id = link.getAttribute('data-itemid'); - var serverId = link.getAttribute('data-serverid'); + let btnCssClass = 'btnUserData'; - var markAsFavorite = !link.classList.contains('btnUserDataOn'); + if (cssClass) { + btnCssClass += ' ' + cssClass; + } - favorite(id, serverId, markAsFavorite); + const iconCssClass = options.iconCssClass; - if (markAsFavorite) { - link.classList.add('btnUserDataOn'); - } else { - link.classList.remove('btnUserDataOn'); + const serverId = item.ServerId; + + if (includePlayed !== false) { + const tooltipPlayed = globalize.translate('MarkPlayed'); + + if (itemHelper.canMarkPlayed(item)) { + if (userData.Played) { + html += getUserDataButtonHtml('markPlayed', itemId, serverId, btnCssClass + ' btnUserDataOn', iconCssClass, 'check', tooltipPlayed, style); + } else { + html += getUserDataButtonHtml('markPlayed', itemId, serverId, btnCssClass, iconCssClass, 'check', tooltipPlayed, style); + } } } - function markLike(link) { - var id = link.getAttribute('data-itemid'); - var serverId = link.getAttribute('data-serverid'); - - if (!link.classList.contains('btnUserDataOn')) { - likes(id, serverId, true); - - link.classList.add('btnUserDataOn'); - } else { - clearLike(id, serverId); - - link.classList.remove('btnUserDataOn'); - } - - link.parentNode.querySelector('.btnDislike').classList.remove('btnUserDataOn'); + const tooltipFavorite = globalize.translate('Favorite'); + if (userData.IsFavorite) { + html += getUserDataButtonHtml('markFavorite', itemId, serverId, btnCssClass + ' btnUserData btnUserDataOn', iconCssClass, 'favorite', tooltipFavorite, style); + } else { + html += getUserDataButtonHtml('markFavorite', itemId, serverId, btnCssClass + ' btnUserData', iconCssClass, 'favorite', tooltipFavorite, style); } - function markDislike(link) { - var id = link.getAttribute('data-itemid'); - var serverId = link.getAttribute('data-serverid'); + return html; +} - if (!link.classList.contains('btnUserDataOn')) { - likes(id, serverId, false); +function markFavorite(link) { + const id = link.getAttribute('data-itemid'); + const serverId = link.getAttribute('data-serverid'); - link.classList.add('btnUserDataOn'); - } else { - clearLike(id, serverId); + const markAsFavorite = !link.classList.contains('btnUserDataOn'); - link.classList.remove('btnUserDataOn'); - } + favorite(id, serverId, markAsFavorite); - link.parentNode.querySelector('.btnLike').classList.remove('btnUserDataOn'); + if (markAsFavorite) { + link.classList.add('btnUserDataOn'); + } else { + link.classList.remove('btnUserDataOn'); + } +} + +function markLike(link) { + const id = link.getAttribute('data-itemid'); + const serverId = link.getAttribute('data-serverid'); + + if (!link.classList.contains('btnUserDataOn')) { + likes(id, serverId, true); + + link.classList.add('btnUserDataOn'); + } else { + clearLike(id, serverId); + + link.classList.remove('btnUserDataOn'); } - function markPlayed(link) { - var id = link.getAttribute('data-itemid'); - var serverId = link.getAttribute('data-serverid'); + link.parentNode.querySelector('.btnDislike').classList.remove('btnUserDataOn'); +} - if (!link.classList.contains('btnUserDataOn')) { - played(id, serverId, true); +function markDislike(link) { + const id = link.getAttribute('data-itemid'); + const serverId = link.getAttribute('data-serverid'); - link.classList.add('btnUserDataOn'); - } else { - played(id, serverId, false); + if (!link.classList.contains('btnUserDataOn')) { + likes(id, serverId, false); - link.classList.remove('btnUserDataOn'); - } + link.classList.add('btnUserDataOn'); + } else { + clearLike(id, serverId); + + link.classList.remove('btnUserDataOn'); } - function likes(id, serverId, isLiked) { - var apiClient = connectionManager.getApiClient(serverId); - return apiClient.updateUserItemRating(apiClient.getCurrentUserId(), id, isLiked); + link.parentNode.querySelector('.btnLike').classList.remove('btnUserDataOn'); +} + +function markPlayed(link) { + const id = link.getAttribute('data-itemid'); + const serverId = link.getAttribute('data-serverid'); + + if (!link.classList.contains('btnUserDataOn')) { + played(id, serverId, true); + + link.classList.add('btnUserDataOn'); + } else { + played(id, serverId, false); + + link.classList.remove('btnUserDataOn'); } +} - function played(id, serverId, isPlayed) { - var apiClient = connectionManager.getApiClient(serverId); +function likes(id, serverId, isLiked) { + const apiClient = connectionManager.getApiClient(serverId); + return apiClient.updateUserItemRating(apiClient.getCurrentUserId(), id, isLiked); +} - var method = isPlayed ? 'markPlayed' : 'markUnplayed'; +function played(id, serverId, isPlayed) { + const apiClient = connectionManager.getApiClient(serverId); - return apiClient[method](apiClient.getCurrentUserId(), id, new Date()); - } + const method = isPlayed ? 'markPlayed' : 'markUnplayed'; - function favorite(id, serverId, isFavorite) { - var apiClient = connectionManager.getApiClient(serverId); + return apiClient[method](apiClient.getCurrentUserId(), id, new Date()); +} - return apiClient.updateFavoriteStatus(apiClient.getCurrentUserId(), id, isFavorite); - } +function favorite(id, serverId, isFavorite) { + const apiClient = connectionManager.getApiClient(serverId); - function clearLike(id, serverId) { - var apiClient = connectionManager.getApiClient(serverId); + return apiClient.updateFavoriteStatus(apiClient.getCurrentUserId(), id, isFavorite); +} - return apiClient.clearUserItemRating(apiClient.getCurrentUserId(), id); - } +function clearLike(id, serverId) { + const apiClient = connectionManager.getApiClient(serverId); - return { - fill: fill, - destroy: destroy, - getIconsHtml: getIconsHtml - }; -}); + return apiClient.clearUserItemRating(apiClient.getCurrentUserId(), id); +} + +export default { + fill: fill, + destroy: destroy, + getIconsHtml: getIconsHtml +}; From 06e842be2cc4c3f5d86248bf38a595d5fd480688 Mon Sep 17 00:00:00 2001 From: Cameron Date: Fri, 7 Aug 2020 08:22:39 +0100 Subject: [PATCH 079/301] remove comment --- src/components/tunerPicker.js | 2 -- 1 file changed, 2 deletions(-) diff --git a/src/components/tunerPicker.js b/src/components/tunerPicker.js index 4ad5fd816d..8184b0c62d 100644 --- a/src/components/tunerPicker.js +++ b/src/components/tunerPicker.js @@ -13,8 +13,6 @@ import 'emby-button'; import 'emby-itemscontainer'; import 'cardStyle'; -/*eslint prefer-const: "error"*/ - const enableFocusTransform = !browser.slow && !browser.edge; function getEditorHtml() { From 9f46f21b7f522ca5d6bc9be39c56cc44bbe51227 Mon Sep 17 00:00:00 2001 From: Cameron Date: Fri, 7 Aug 2020 08:29:07 +0100 Subject: [PATCH 080/301] Migration of chromecastPlayer to ES6 module --- package.json | 1 + src/plugins/chromecastPlayer/plugin.js | 761 +++++++++++++------------ 2 files changed, 382 insertions(+), 380 deletions(-) diff --git a/package.json b/package.json index 1d7cf770d3..33be2cac8a 100644 --- a/package.json +++ b/package.json @@ -155,6 +155,7 @@ "src/components/refreshdialog/refreshdialog.js", "src/components/sanatizefilename.js", "src/components/scrollManager.js", + "src/plugins/chromecastPlayer/plugin.js", "src/plugins/htmlVideoPlayer/plugin.js", "src/components/search/searchfields.js", "src/components/search/searchresults.js", diff --git a/src/plugins/chromecastPlayer/plugin.js b/src/plugins/chromecastPlayer/plugin.js index 2741a6f0e3..88c460c444 100644 --- a/src/plugins/chromecastPlayer/plugin.js +++ b/src/plugins/chromecastPlayer/plugin.js @@ -1,66 +1,71 @@ -define(['appSettings', 'userSettings', 'playbackManager', 'connectionManager', 'globalize', 'events', 'require', 'castSenderApiLoader'], function (appSettings, userSettings, playbackManager, connectionManager, globalize, events, require, castSenderApiLoader) { - 'use strict'; +import appSettings from 'appSettings'; +import * as userSettings from 'userSettings'; +import playbackManager from 'playbackManager'; +import connectionManager from 'connectionManager'; +import globalize from 'globalize'; +import events from 'events'; +import castSenderApiLoader from 'castSenderApiLoader'; - playbackManager = playbackManager.default || playbackManager; +// Based on https://github.com/googlecast/CastVideos-chrome/blob/master/CastVideos.js - // Based on https://github.com/googlecast/CastVideos-chrome/blob/master/CastVideos.js - var currentResolve; - var currentReject; +let currentResolve; +let currentReject; - var PlayerName = 'Google Cast'; +const PlayerName = 'Google Cast'; - function sendConnectionResult(isOk) { - var resolve = currentResolve; - var reject = currentReject; +function sendConnectionResult(isOk) { + const resolve = currentResolve; + const reject = currentReject; - currentResolve = null; - currentReject = null; + currentResolve = null; + currentReject = null; - if (isOk) { - if (resolve) { - resolve(); - } + if (isOk) { + if (resolve) { + resolve(); + } + } else { + if (reject) { + reject(); } else { - if (reject) { - reject(); - } else { - playbackManager.removeActivePlayer(PlayerName); - } + playbackManager.removeActivePlayer(PlayerName); } } +} - /** - * Constants of states for Chromecast device - **/ - var DEVICE_STATE = { - 'IDLE': 0, - 'ACTIVE': 1, - 'WARNING': 2, - 'ERROR': 3 - }; +/** + * Constants of states for Chromecast device + **/ +const DEVICE_STATE = { + 'IDLE': 0, + 'ACTIVE': 1, + 'WARNING': 2, + 'ERROR': 3 +}; - /** - * Constants of states for CastPlayer - **/ - var PLAYER_STATE = { - 'IDLE': 'IDLE', - 'LOADING': 'LOADING', - 'LOADED': 'LOADED', - 'PLAYING': 'PLAYING', - 'PAUSED': 'PAUSED', - 'STOPPED': 'STOPPED', - 'SEEKING': 'SEEKING', - 'ERROR': 'ERROR' - }; +/** + * Constants of states for CastPlayer + **/ +const PLAYER_STATE = { + 'IDLE': 'IDLE', + 'LOADING': 'LOADING', + 'LOADED': 'LOADED', + 'PLAYING': 'PLAYING', + 'PAUSED': 'PAUSED', + 'STOPPED': 'STOPPED', + 'SEEKING': 'SEEKING', + 'ERROR': 'ERROR' +}; - // production version registered with google - // replace this value if you want to test changes on another instance - var applicationStable = 'F007D354'; - var applicationUnstable = '6F511C87'; +// production version registered with google +// replace this value if you want to test changes on another instance +const applicationStable = 'F007D354'; +const applicationUnstable = '6F511C87'; - var messageNamespace = 'urn:x-cast:com.connectsdk'; +const messageNamespace = 'urn:x-cast:com.connectsdk'; - var CastPlayer = function () { +class CastPlayer { + constructor() { /* device variables */ // @type {DEVICE_STATE} A state for device this.deviceState = DEVICE_STATE.IDLE; @@ -81,7 +86,7 @@ define(['appSettings', 'userSettings', 'playbackManager', 'connectionManager', ' this.mediaStatusUpdateHandler = this.onMediaStatusUpdate.bind(this); this.initializeCastPlayer(); - }; + } /** * Initialize Cast media player @@ -89,8 +94,8 @@ define(['appSettings', 'userSettings', 'playbackManager', 'connectionManager', ' * invoked once the API has finished initialization. The sessionListener and * receiverListener may be invoked at any time afterwards, and possibly more than once. */ - CastPlayer.prototype.initializeCastPlayer = function () { - var chrome = window.chrome; + initializeCastPlayer() { + const chrome = window.chrome; if (!chrome) { return; } @@ -100,35 +105,35 @@ define(['appSettings', 'userSettings', 'playbackManager', 'connectionManager', ' return; } - var applicationID = applicationStable; + let applicationID = applicationStable; if (userSettings.chromecastVersion() === 'unstable') { applicationID = applicationUnstable; } // request session - var sessionRequest = new chrome.cast.SessionRequest(applicationID); - var apiConfig = new chrome.cast.ApiConfig(sessionRequest, + const sessionRequest = new chrome.cast.SessionRequest(applicationID); + const apiConfig = new chrome.cast.ApiConfig(sessionRequest, this.sessionListener.bind(this), this.receiverListener.bind(this)); console.debug('chromecast.initialize'); chrome.cast.initialize(apiConfig, this.onInitSuccess.bind(this), this.errorHandler); - }; + } /** * Callback function for init success */ - CastPlayer.prototype.onInitSuccess = function () { + onInitSuccess() { this.isInitialized = true; console.debug('chromecast init success'); - }; + } /** * Generic error callback function */ - CastPlayer.prototype.onError = function () { + onError() { console.debug('chromecast error'); - }; + } /** * @param {!Object} e A new session @@ -137,7 +142,7 @@ define(['appSettings', 'userSettings', 'playbackManager', 'connectionManager', ' * join existing session and occur in Cast mode and media * status gets synced up with current media of the session */ - CastPlayer.prototype.sessionListener = function (e) { + sessionListener(e) { this.session = e; if (this.session) { if (this.session.media[0]) { @@ -146,24 +151,15 @@ define(['appSettings', 'userSettings', 'playbackManager', 'connectionManager', ' this.onSessionConnected(e); } - }; - - function alertText(text, title) { - require(['alert'], function (alert) { - alert.default({ - text: text, - title: title - }); - }); } - CastPlayer.prototype.messageListener = function (namespace, message) { + messageListener(namespace, message) { if (typeof (message) === 'string') { message = JSON.parse(message); } if (message.type === 'playbackerror') { - var errorCode = message.data; + const errorCode = message.data; setTimeout(function () { alertText(globalize.translate('MessagePlaybackError' + errorCode), globalize.translate('HeaderPlaybackError')); }, 300); @@ -174,14 +170,14 @@ define(['appSettings', 'userSettings', 'playbackManager', 'connectionManager', ' } else if (message.type) { events.trigger(this, message.type, [message.data]); } - }; + } /** * @param {string} e Receiver availability * This indicates availability of receivers but * does not provide a list of device IDs */ - CastPlayer.prototype.receiverListener = function (e) { + receiverListener(e) { if (e === 'available') { console.debug('chromecast receiver found'); this.hasReceivers = true; @@ -189,12 +185,12 @@ define(['appSettings', 'userSettings', 'playbackManager', 'connectionManager', ' console.debug('chromecast receiver list empty'); this.hasReceivers = false; } - }; + } /** * session update listener */ - CastPlayer.prototype.sessionUpdateListener = function (isAlive) { + sessionUpdateListener(isAlive) { if (isAlive) { console.debug('sessionUpdateListener: already alive'); } else { @@ -209,28 +205,28 @@ define(['appSettings', 'userSettings', 'playbackManager', 'connectionManager', ' sendConnectionResult(false); } - }; + } /** * Requests that a receiver application session be created or joined. By default, the SessionRequest * passed to the API at initialization time is used; this may be overridden by passing a different * session request in opt_sessionRequest. */ - CastPlayer.prototype.launchApp = function () { + launchApp() { console.debug('chromecast launching app...'); chrome.cast.requestSession(this.onRequestSessionSuccess.bind(this), this.onLaunchError.bind(this)); - }; + } /** * Callback function for request session success * @param {Object} e A chrome.cast.Session object */ - CastPlayer.prototype.onRequestSessionSuccess = function (e) { + onRequestSessionSuccess(e) { console.debug('chromecast session success: ' + e.sessionId); this.onSessionConnected(e); - }; + } - CastPlayer.prototype.onSessionConnected = function (session) { + onSessionConnected(session) { this.session = session; this.deviceState = DEVICE_STATE.ACTIVE; @@ -246,46 +242,38 @@ define(['appSettings', 'userSettings', 'playbackManager', 'connectionManager', ' options: {}, command: 'Identify' }); - }; - - function onVolumeUpKeyDown() { - playbackManager.volumeUp(); - } - - function onVolumeDownKeyDown() { - playbackManager.volumeDown(); } /** * session update listener */ - CastPlayer.prototype.sessionMediaListener = function (e) { + sessionMediaListener(e) { this.currentMediaSession = e; this.currentMediaSession.addUpdateListener(this.mediaStatusUpdateHandler); - }; + } /** * Callback function for launch error */ - CastPlayer.prototype.onLaunchError = function () { + onLaunchError() { console.debug('chromecast launch error'); this.deviceState = DEVICE_STATE.ERROR; sendConnectionResult(false); - }; + } /** * Stops the running receiver application associated with the session. */ - CastPlayer.prototype.stopApp = function () { + stopApp() { if (this.session) { this.session.stop(this.onStopAppSuccess.bind(this, 'Session stopped'), this.errorHandler); } - }; + } /** * Callback function for stop app success */ - CastPlayer.prototype.onStopAppSuccess = function (message) { + onStopAppSuccess(message) { console.debug(message); this.deviceState = DEVICE_STATE.IDLE; @@ -294,13 +282,13 @@ define(['appSettings', 'userSettings', 'playbackManager', 'connectionManager', ' document.removeEventListener('volumedownbutton', onVolumeDownKeyDown, false); this.currentMediaSession = null; - }; + } /** * Loads media into a running receiver application * @param {Number} mediaIndex An index number to indicate current media content */ - CastPlayer.prototype.loadMedia = function (options, command) { + loadMedia(options, command) { if (!this.session) { console.debug('no session'); return Promise.reject(); @@ -322,20 +310,20 @@ define(['appSettings', 'userSettings', 'playbackManager', 'connectionManager', ' options: options, command: command }); - }; + } - CastPlayer.prototype.sendMessage = function (message) { - var player = this; + sendMessage(message) { + const player = this; - var receiverName = null; + let receiverName = null; - var session = player.session; + const session = player.session; if (session && session.receiver && session.receiver.friendlyName) { receiverName = session.receiver.friendlyName; } - var apiClient; + let apiClient; if (message.options && message.options.ServerId) { apiClient = connectionManager.getApiClient(message.options.ServerId); } else if (message.options && message.options.items && message.options.items.length) { @@ -354,7 +342,7 @@ define(['appSettings', 'userSettings', 'playbackManager', 'connectionManager', ' receiverName: receiverName }); - var bitrateSetting = appSettings.maxChromecastBitrate(); + const bitrateSetting = appSettings.maxChromecastBitrate(); if (bitrateSetting) { message.maxBitrate = bitrateSetting; } @@ -365,31 +353,31 @@ define(['appSettings', 'userSettings', 'playbackManager', 'connectionManager', ' } return new Promise(function (resolve, reject) { - require(['./chromecastHelper'], function (chromecastHelper) { + import('./chromecastHelper').then(({ default: chromecastHelper }) => { chromecastHelper.getServerAddress(apiClient).then(function (serverAddress) { message.serverAddress = serverAddress; player.sendMessageInternal(message).then(resolve, reject); }, reject); }); }); - }; + } - CastPlayer.prototype.sendMessageInternal = function (message) { + sendMessageInternal(message) { message = JSON.stringify(message); this.session.sendMessage(messageNamespace, message, this.onPlayCommandSuccess.bind(this), this.errorHandler); return Promise.resolve(); - }; + } - CastPlayer.prototype.onPlayCommandSuccess = function () { + onPlayCommandSuccess() { console.debug('Message was sent to receiver ok.'); - }; + } /** * Callback function for loadMedia success * @param {Object} mediaSession A new media object. */ - CastPlayer.prototype.onMediaDiscovered = function (how, mediaSession) { + onMediaDiscovered(how, mediaSession) { console.debug('chromecast new media session ID:' + mediaSession.mediaSessionId + ' (' + how + ')'); this.currentMediaSession = mediaSession; @@ -402,24 +390,24 @@ define(['appSettings', 'userSettings', 'playbackManager', 'connectionManager', ' } this.currentMediaSession.addUpdateListener(this.mediaStatusUpdateHandler); - }; + } /** * Callback function for media status update from receiver * @param {!Boolean} e true/false */ - CastPlayer.prototype.onMediaStatusUpdate = function (e) { + onMediaStatusUpdate(e) { console.debug('chromecast updating media: ' + e); if (e === false) { this.castPlayerState = PLAYER_STATE.IDLE; } - }; + } /** * Set media volume in Cast mode * @param {Boolean} mute A boolean */ - CastPlayer.prototype.setReceiverVolume = function (mute, vol) { + setReceiverVolume(mute, vol) { if (!this.currentMediaSession) { console.debug('this.currentMediaSession is null'); return; @@ -434,142 +422,161 @@ define(['appSettings', 'userSettings', 'playbackManager', 'connectionManager', ' this.mediaCommandSuccessCallback.bind(this), this.errorHandler); } - }; + } /** * Mute CC */ - CastPlayer.prototype.mute = function () { + mute() { this.setReceiverVolume(true); - }; + } /** * Callback function for media command success */ - CastPlayer.prototype.mediaCommandSuccessCallback = function (info, e) { + mediaCommandSuccessCallback(info, e) { console.debug(info); - }; + } +} - function normalizeImages(state) { - if (state && state.NowPlayingItem) { - var item = state.NowPlayingItem; +function alertText(text, title) { + import('alert').then(({default: alert}) => { + alert({ + text: text, + title: title + }); + }); +} - if (!item.ImageTags || !item.ImageTags.Primary) { - if (item.PrimaryImageTag) { - item.ImageTags = item.ImageTags || {}; - item.ImageTags.Primary = item.PrimaryImageTag; - } - } - if (item.BackdropImageTag && item.BackdropItemId === item.Id) { - item.BackdropImageTags = [item.BackdropImageTag]; - } - if (item.BackdropImageTag && item.BackdropItemId !== item.Id) { - item.ParentBackdropImageTags = [item.BackdropImageTag]; - item.ParentBackdropItemId = item.BackdropItemId; +function onVolumeUpKeyDown() { + playbackManager.volumeUp(); +} + +function onVolumeDownKeyDown() { + playbackManager.volumeDown(); +} + +function normalizeImages(state) { + if (state && state.NowPlayingItem) { + const item = state.NowPlayingItem; + + if (!item.ImageTags || !item.ImageTags.Primary) { + if (item.PrimaryImageTag) { + item.ImageTags = item.ImageTags || {}; + item.ImageTags.Primary = item.PrimaryImageTag; } } + if (item.BackdropImageTag && item.BackdropItemId === item.Id) { + item.BackdropImageTags = [item.BackdropImageTag]; + } + if (item.BackdropImageTag && item.BackdropItemId !== item.Id) { + item.ParentBackdropImageTags = [item.BackdropImageTag]; + item.ParentBackdropItemId = item.BackdropItemId; + } } +} - function getItemsForPlayback(apiClient, query) { - var userId = apiClient.getCurrentUserId(); +function getItemsForPlayback(apiClient, query) { + const userId = apiClient.getCurrentUserId(); - if (query.Ids && query.Ids.split(',').length === 1) { - return apiClient.getItem(userId, query.Ids.split(',')).then(function (item) { - return { - Items: [item], - TotalRecordCount: 1 - }; - }); + if (query.Ids && query.Ids.split(',').length === 1) { + return apiClient.getItem(userId, query.Ids.split(',')).then(function (item) { + return { + Items: [item], + TotalRecordCount: 1 + }; + }); + } else { + query.Limit = query.Limit || 100; + query.ExcludeLocationTypes = 'Virtual'; + query.EnableTotalRecordCount = false; + + return apiClient.getItems(userId, query); + } +} + +function bindEventForRelay(instance, eventName) { + events.on(instance._castPlayer, eventName, function (e, data) { + console.debug('cc: ' + eventName); + const state = instance.getPlayerStateInternal(data); + + events.trigger(instance, eventName, [state]); + }); +} + +function initializeChromecast() { + const instance = this; + instance._castPlayer = new CastPlayer(); + + // To allow the native android app to override + document.dispatchEvent(new CustomEvent('chromecastloaded', { + detail: { + player: instance + } + })); + + events.on(instance._castPlayer, 'connect', function (e) { + if (currentResolve) { + sendConnectionResult(true); } else { - query.Limit = query.Limit || 100; - query.ExcludeLocationTypes = 'Virtual'; - query.EnableTotalRecordCount = false; - - return apiClient.getItems(userId, query); + playbackManager.setActivePlayer(PlayerName, instance.getCurrentTargetInfo()); } - } - function bindEventForRelay(instance, eventName) { - events.on(instance._castPlayer, eventName, function (e, data) { - console.debug('cc: ' + eventName); - var state = instance.getPlayerStateInternal(data); + console.debug('cc: connect'); + // Reset this so that statechange will fire + instance.lastPlayerData = null; + }); - events.trigger(instance, eventName, [state]); - }); - } + events.on(instance._castPlayer, 'playbackstart', function (e, data) { + console.debug('cc: playbackstart'); - function initializeChromecast() { - var instance = this; - instance._castPlayer = new CastPlayer(); + instance._castPlayer.initializeCastPlayer(); - // To allow the native android app to override - document.dispatchEvent(new CustomEvent('chromecastloaded', { - detail: { - player: instance - } - })); + const state = instance.getPlayerStateInternal(data); + events.trigger(instance, 'playbackstart', [state]); + }); - events.on(instance._castPlayer, 'connect', function (e) { - if (currentResolve) { - sendConnectionResult(true); - } else { - playbackManager.setActivePlayer(PlayerName, instance.getCurrentTargetInfo()); - } + events.on(instance._castPlayer, 'playbackstop', function (e, data) { + console.debug('cc: playbackstop'); + let state = instance.getPlayerStateInternal(data); - console.debug('cc: connect'); - // Reset this so that statechange will fire - instance.lastPlayerData = null; - }); + events.trigger(instance, 'playbackstop', [state]); - events.on(instance._castPlayer, 'playbackstart', function (e, data) { - console.debug('cc: playbackstart'); + state = instance.lastPlayerData.PlayState || {}; + const volume = state.VolumeLevel || 0.5; + const mute = state.IsMuted || false; - instance._castPlayer.initializeCastPlayer(); + // Reset this so the next query doesn't make it appear like content is playing. + instance.lastPlayerData = {}; + instance.lastPlayerData.PlayState = {}; + instance.lastPlayerData.PlayState.VolumeLevel = volume; + instance.lastPlayerData.PlayState.IsMuted = mute; + }); - var state = instance.getPlayerStateInternal(data); - events.trigger(instance, 'playbackstart', [state]); - }); + events.on(instance._castPlayer, 'playbackprogress', function (e, data) { + console.debug('cc: positionchange'); + const state = instance.getPlayerStateInternal(data); - events.on(instance._castPlayer, 'playbackstop', function (e, data) { - console.debug('cc: playbackstop'); - var state = instance.getPlayerStateInternal(data); + events.trigger(instance, 'timeupdate', [state]); + }); - events.trigger(instance, 'playbackstop', [state]); + bindEventForRelay(instance, 'timeupdate'); + bindEventForRelay(instance, 'pause'); + bindEventForRelay(instance, 'unpause'); + bindEventForRelay(instance, 'volumechange'); + bindEventForRelay(instance, 'repeatmodechange'); + bindEventForRelay(instance, 'shufflequeuemodechange'); - state = instance.lastPlayerData.PlayState || {}; - var volume = state.VolumeLevel || 0.5; - var mute = state.IsMuted || false; + events.on(instance._castPlayer, 'playstatechange', function (e, data) { + console.debug('cc: playstatechange'); + const state = instance.getPlayerStateInternal(data); - // Reset this so the next query doesn't make it appear like content is playing. - instance.lastPlayerData = {}; - instance.lastPlayerData.PlayState = {}; - instance.lastPlayerData.PlayState.VolumeLevel = volume; - instance.lastPlayerData.PlayState.IsMuted = mute; - }); + events.trigger(instance, 'pause', [state]); + }); +} - events.on(instance._castPlayer, 'playbackprogress', function (e, data) { - console.debug('cc: positionchange'); - var state = instance.getPlayerStateInternal(data); - - events.trigger(instance, 'timeupdate', [state]); - }); - - bindEventForRelay(instance, 'timeupdate'); - bindEventForRelay(instance, 'pause'); - bindEventForRelay(instance, 'unpause'); - bindEventForRelay(instance, 'volumechange'); - bindEventForRelay(instance, 'repeatmodechange'); - bindEventForRelay(instance, 'shufflequeuemodechange'); - - events.on(instance._castPlayer, 'playstatechange', function (e, data) { - console.debug('cc: playstatechange'); - var state = instance.getPlayerStateInternal(data); - - events.trigger(instance, 'pause', [state]); - }); - } - - function ChromecastPlayer() { +class ChromecastPlayer { + constructor() { // playbackManager needs this this.name = PlayerName; this.type = 'mediaplayer'; @@ -580,8 +587,8 @@ define(['appSettings', 'userSettings', 'playbackManager', 'connectionManager', ' castSenderApiLoader.load().then(initializeChromecast.bind(this)); } - ChromecastPlayer.prototype.tryPair = function (target) { - var castPlayer = this._castPlayer; + tryPair(target) { + const castPlayer = this._castPlayer; if (castPlayer.deviceState !== DEVICE_STATE.ACTIVE && castPlayer.isInitialized) { return new Promise(function (resolve, reject) { @@ -595,23 +602,23 @@ define(['appSettings', 'userSettings', 'playbackManager', 'connectionManager', ' return Promise.reject(); } - }; + } - ChromecastPlayer.prototype.getTargets = function () { - var targets = []; + getTargets() { + const targets = []; if (this._castPlayer && this._castPlayer.hasReceivers) { targets.push(this.getCurrentTargetInfo()); } return Promise.resolve(targets); - }; + } // This is a privately used method - ChromecastPlayer.prototype.getCurrentTargetInfo = function () { - var appName = null; + getCurrentTargetInfo() { + let appName = null; - var castPlayer = this._castPlayer; + const castPlayer = this._castPlayer; if (castPlayer.session && castPlayer.session.receiver && castPlayer.session.receiver.friendlyName) { appName = castPlayer.session.receiver.friendlyName; @@ -642,10 +649,10 @@ define(['appSettings', 'userSettings', 'playbackManager', 'connectionManager', ' 'PlayTrailers' ] }; - }; + } - ChromecastPlayer.prototype.getPlayerStateInternal = function (data) { - var triggerStateChange = false; + getPlayerStateInternal(data) { + let triggerStateChange = false; if (data && !this.lastPlayerData) { triggerStateChange = true; } @@ -662,12 +669,12 @@ define(['appSettings', 'userSettings', 'playbackManager', 'connectionManager', ' } return data; - }; + } - ChromecastPlayer.prototype.playWithCommand = function (options, command) { + playWithCommand(options, command) { if (!options.items) { - var apiClient = connectionManager.getApiClient(options.serverId); - var instance = this; + const apiClient = connectionManager.getApiClient(options.serverId); + const instance = this; return apiClient.getItem(apiClient.getCurrentUserId(), options.ids[0]).then(function (item) { options.items = [item]; @@ -683,9 +690,9 @@ define(['appSettings', 'userSettings', 'playbackManager', 'connectionManager', ' } return this._castPlayer.loadMedia(options, command); - }; + } - ChromecastPlayer.prototype.seek = function (position) { + seek(position) { position = parseInt(position); position = position / 10000000; @@ -696,55 +703,55 @@ define(['appSettings', 'userSettings', 'playbackManager', 'connectionManager', ' }, command: 'Seek' }); - }; + } - ChromecastPlayer.prototype.setAudioStreamIndex = function (index) { + setAudioStreamIndex(index) { this._castPlayer.sendMessage({ options: { index: index }, command: 'SetAudioStreamIndex' }); - }; + } - ChromecastPlayer.prototype.setSubtitleStreamIndex = function (index) { + setSubtitleStreamIndex(index) { this._castPlayer.sendMessage({ options: { index: index }, command: 'SetSubtitleStreamIndex' }); - }; + } - ChromecastPlayer.prototype.setMaxStreamingBitrate = function (options) { + setMaxStreamingBitrate(options) { this._castPlayer.sendMessage({ options: options, command: 'SetMaxStreamingBitrate' }); - }; + } - ChromecastPlayer.prototype.isFullscreen = function () { - var state = this.lastPlayerData || {}; + isFullscreen() { + let state = this.lastPlayerData || {}; state = state.PlayState || {}; return state.IsFullscreen; - }; + } - ChromecastPlayer.prototype.nextTrack = function () { + nextTrack() { this._castPlayer.sendMessage({ options: {}, command: 'NextTrack' }); - }; + } - ChromecastPlayer.prototype.previousTrack = function () { + previousTrack() { this._castPlayer.sendMessage({ options: {}, command: 'PreviousTrack' }); - }; + } - ChromecastPlayer.prototype.volumeDown = function () { - var vol = this._castPlayer.session.receiver.volume.level; + volumeDown() { + let vol = this._castPlayer.session.receiver.volume.level; if (vol == null) { vol = 0.5; } @@ -752,20 +759,20 @@ define(['appSettings', 'userSettings', 'playbackManager', 'connectionManager', ' vol = Math.max(vol, 0); this._castPlayer.session.setReceiverVolumeLevel(vol); - }; + } - ChromecastPlayer.prototype.endSession = function () { - var instance = this; + endSession() { + const instance = this; this.stop().then(function () { setTimeout(function () { instance._castPlayer.stopApp(); }, 1000); }); - }; + } - ChromecastPlayer.prototype.volumeUp = function () { - var vol = this._castPlayer.session.receiver.volume.level; + volumeUp() { + let vol = this._castPlayer.session.receiver.volume.level; if (vol == null) { vol = 0.5; } @@ -773,53 +780,53 @@ define(['appSettings', 'userSettings', 'playbackManager', 'connectionManager', ' vol = Math.min(vol, 1); this._castPlayer.session.setReceiverVolumeLevel(vol); - }; + } - ChromecastPlayer.prototype.setVolume = function (vol) { + setVolume(vol) { vol = Math.min(vol, 100); vol = Math.max(vol, 0); vol = vol / 100; this._castPlayer.session.setReceiverVolumeLevel(vol); - }; + } - ChromecastPlayer.prototype.unpause = function () { + unpause() { this._castPlayer.sendMessage({ options: {}, command: 'Unpause' }); - }; + } - ChromecastPlayer.prototype.playPause = function () { + playPause() { this._castPlayer.sendMessage({ options: {}, command: 'PlayPause' }); - }; + } - ChromecastPlayer.prototype.pause = function () { + pause() { this._castPlayer.sendMessage({ options: {}, command: 'Pause' }); - }; + } - ChromecastPlayer.prototype.stop = function () { + stop() { return this._castPlayer.sendMessage({ options: {}, command: 'Stop' }); - }; + } - ChromecastPlayer.prototype.displayContent = function (options) { + displayContent(options) { this._castPlayer.sendMessage({ options: options, command: 'DisplayContent' }); - }; + } - ChromecastPlayer.prototype.setMute = function (isMuted) { - var castPlayer = this._castPlayer; + setMute(isMuted) { + const castPlayer = this._castPlayer; if (isMuted) { castPlayer.sendMessage({ @@ -832,21 +839,21 @@ define(['appSettings', 'userSettings', 'playbackManager', 'connectionManager', ' command: 'Unmute' }); } - }; + } - ChromecastPlayer.prototype.getRepeatMode = function () { - var state = this.lastPlayerData || {}; + getRepeatMode() { + let state = this.lastPlayerData || {}; state = state.PlayState || {}; return state.RepeatMode; - }; + } - ChromecastPlayer.prototype.getQueueShuffleMode = function () { - var state = this.lastPlayerData || {}; + getQueueShuffleMode() { + let state = this.lastPlayerData || {}; state = state.PlayState || {}; return state.ShuffleMode; - }; + } - ChromecastPlayer.prototype.playTrailers = function (item) { + playTrailers(item) { this._castPlayer.sendMessage({ options: { ItemId: item.Id, @@ -854,177 +861,173 @@ define(['appSettings', 'userSettings', 'playbackManager', 'connectionManager', ' }, command: 'PlayTrailers' }); - }; + } - ChromecastPlayer.prototype.setRepeatMode = function (mode) { + setRepeatMode(mode) { this._castPlayer.sendMessage({ options: { RepeatMode: mode }, command: 'SetRepeatMode' }); - }; + } - ChromecastPlayer.prototype.setQueueShuffleMode = function (value) { + setQueueShuffleMode(value) { this._castPlayer.sendMessage({ options: { ShuffleMode: value }, command: 'SetShuffleQueue' }); - }; + } - ChromecastPlayer.prototype.toggleMute = function () { + toggleMute() { this._castPlayer.sendMessage({ options: {}, command: 'ToggleMute' }); - }; + } - ChromecastPlayer.prototype.audioTracks = function () { - var state = this.lastPlayerData || {}; + audioTracks() { + let state = this.lastPlayerData || {}; state = state.NowPlayingItem || {}; - var streams = state.MediaStreams || []; + const streams = state.MediaStreams || []; return streams.filter(function (s) { return s.Type === 'Audio'; }); - }; + } - ChromecastPlayer.prototype.getAudioStreamIndex = function () { - var state = this.lastPlayerData || {}; + getAudioStreamIndex() { + let state = this.lastPlayerData || {}; state = state.PlayState || {}; return state.AudioStreamIndex; - }; + } - ChromecastPlayer.prototype.subtitleTracks = function () { - var state = this.lastPlayerData || {}; + subtitleTracks() { + let state = this.lastPlayerData || {}; state = state.NowPlayingItem || {}; - var streams = state.MediaStreams || []; + const streams = state.MediaStreams || []; return streams.filter(function (s) { return s.Type === 'Subtitle'; }); - }; + } - ChromecastPlayer.prototype.getSubtitleStreamIndex = function () { - var state = this.lastPlayerData || {}; + getSubtitleStreamIndex() { + let state = this.lastPlayerData || {}; state = state.PlayState || {}; return state.SubtitleStreamIndex; - }; + } - ChromecastPlayer.prototype.getMaxStreamingBitrate = function () { - var state = this.lastPlayerData || {}; + getMaxStreamingBitrate() { + let state = this.lastPlayerData || {}; state = state.PlayState || {}; return state.MaxStreamingBitrate; - }; + } - ChromecastPlayer.prototype.getVolume = function () { - var state = this.lastPlayerData || {}; + getVolume() { + let state = this.lastPlayerData || {}; state = state.PlayState || {}; return state.VolumeLevel == null ? 100 : state.VolumeLevel; - }; + } - ChromecastPlayer.prototype.isPlaying = function () { - var state = this.lastPlayerData || {}; + isPlaying() { + const state = this.lastPlayerData || {}; return state.NowPlayingItem != null; - }; + } - ChromecastPlayer.prototype.isPlayingVideo = function () { - var state = this.lastPlayerData || {}; + isPlayingVideo() { + let state = this.lastPlayerData || {}; state = state.NowPlayingItem || {}; return state.MediaType === 'Video'; - }; + } - ChromecastPlayer.prototype.isPlayingAudio = function () { - var state = this.lastPlayerData || {}; + isPlayingAudio() { + let state = this.lastPlayerData || {}; state = state.NowPlayingItem || {}; return state.MediaType === 'Audio'; - }; + } - ChromecastPlayer.prototype.currentTime = function (val) { + currentTime(val) { if (val != null) { return this.seek(val); } - var state = this.lastPlayerData || {}; + let state = this.lastPlayerData || {}; state = state.PlayState || {}; return state.PositionTicks; - }; + } - ChromecastPlayer.prototype.duration = function () { - var state = this.lastPlayerData || {}; + duration() { + let state = this.lastPlayerData || {}; state = state.NowPlayingItem || {}; return state.RunTimeTicks; - }; + } - ChromecastPlayer.prototype.getBufferedRanges = function () { - var state = this.lastPlayerData || {}; + getBufferedRanges() { + let state = this.lastPlayerData || {}; state = state.PlayState || {}; return state.BufferedRanges || []; - }; + } - ChromecastPlayer.prototype.paused = function () { - var state = this.lastPlayerData || {}; + paused() { + let state = this.lastPlayerData || {}; state = state.PlayState || {}; return state.IsPaused; - }; + } - ChromecastPlayer.prototype.isMuted = function () { - var state = this.lastPlayerData || {}; + isMuted() { + let state = this.lastPlayerData || {}; state = state.PlayState || {}; return state.IsMuted; - }; + } - ChromecastPlayer.prototype.shuffle = function (item) { - var apiClient = connectionManager.getApiClient(item.ServerId); - var userId = apiClient.getCurrentUserId(); + shuffle(item) { + const apiClient = connectionManager.getApiClient(item.ServerId); + const userId = apiClient.getCurrentUserId(); - var instance = this; + const instance = this; apiClient.getItem(userId, item.Id).then(function (item) { instance.playWithCommand({ - items: [item] - }, 'Shuffle'); }); - }; + } - ChromecastPlayer.prototype.instantMix = function (item) { - var apiClient = connectionManager.getApiClient(item.ServerId); - var userId = apiClient.getCurrentUserId(); + instantMix(item) { + const apiClient = connectionManager.getApiClient(item.ServerId); + const userId = apiClient.getCurrentUserId(); - var instance = this; + const instance = this; apiClient.getItem(userId, item.Id).then(function (item) { instance.playWithCommand({ - items: [item] - }, 'InstantMix'); }); - }; + } - ChromecastPlayer.prototype.canPlayMediaType = function (mediaType) { + canPlayMediaType(mediaType) { mediaType = (mediaType || '').toLowerCase(); return mediaType === 'audio' || mediaType === 'video'; - }; + } - ChromecastPlayer.prototype.canQueueMediaType = function (mediaType) { + canQueueMediaType(mediaType) { return this.canPlayMediaType(mediaType); - }; + } - ChromecastPlayer.prototype.queue = function (options) { + queue(options) { this.playWithCommand(options, 'PlayLast'); - }; + } - ChromecastPlayer.prototype.queueNext = function (options) { + queueNext(options) { this.playWithCommand(options, 'PlayNext'); - }; + } - ChromecastPlayer.prototype.play = function (options) { + play(options) { if (options.items) { return this.playWithCommand(options, 'PlayNow'); } else { @@ -1032,50 +1035,48 @@ define(['appSettings', 'userSettings', 'playbackManager', 'connectionManager', ' throw new Error('serverId required!'); } - var instance = this; - var apiClient = connectionManager.getApiClient(options.serverId); + const instance = this; + const apiClient = connectionManager.getApiClient(options.serverId); return getItemsForPlayback(apiClient, { - Ids: options.ids.join(',') - }).then(function (result) { options.items = result.Items; return instance.playWithCommand(options, 'PlayNow'); }); } - }; + } - ChromecastPlayer.prototype.toggleFullscreen = function () { + toggleFullscreen() { // not supported - }; + } - ChromecastPlayer.prototype.beginPlayerUpdates = function () { + beginPlayerUpdates() { // Setup polling here - }; + } - ChromecastPlayer.prototype.endPlayerUpdates = function () { + endPlayerUpdates() { // Stop polling here - }; + } - ChromecastPlayer.prototype.getPlaylist = function () { + getPlaylist() { return Promise.resolve([]); - }; + } - ChromecastPlayer.prototype.getCurrentPlaylistItemId = function () { - }; + getCurrentPlaylistItemId() { + } - ChromecastPlayer.prototype.setCurrentPlaylistItem = function (playlistItemId) { + setCurrentPlaylistItem(playlistItemId) { return Promise.resolve(); - }; + } - ChromecastPlayer.prototype.removeFromPlaylist = function (playlistItemIds) { + removeFromPlaylist(playlistItemIds) { return Promise.resolve(); - }; + } - ChromecastPlayer.prototype.getPlayerState = function () { + getPlayerState() { return this.getPlayerStateInternal() || {}; - }; + } +} - return ChromecastPlayer; -}); +export default ChromecastPlayer; From 60dd3d009e245eb9318b468c347eef5b310f785b Mon Sep 17 00:00:00 2001 From: Cameron Date: Fri, 7 Aug 2020 08:42:34 +0100 Subject: [PATCH 081/301] remove require --- src/components/imageDownloader/imageDownloader.js | 1 - 1 file changed, 1 deletion(-) diff --git a/src/components/imageDownloader/imageDownloader.js b/src/components/imageDownloader/imageDownloader.js index 3a5f2f56ce..3f78a5ecbb 100644 --- a/src/components/imageDownloader/imageDownloader.js +++ b/src/components/imageDownloader/imageDownloader.js @@ -8,7 +8,6 @@ import browser from 'browser'; import layoutManager from 'layoutManager'; import scrollHelper from 'scrollHelper'; import globalize from 'globalize'; -import require from 'require'; import 'emby-checkbox'; import 'paper-icon-button-light'; import 'emby-button'; From 0872f3f0010263d48a3b546031d215a7f2c3c3b4 Mon Sep 17 00:00:00 2001 From: Cameron Date: Fri, 7 Aug 2020 09:27:11 +0100 Subject: [PATCH 082/301] Apply suggestions --- src/controllers/list.js | 49 +++++++++++++---------------- src/libraries/screensavermanager.js | 4 +-- 2 files changed, 23 insertions(+), 30 deletions(-) diff --git a/src/controllers/list.js b/src/controllers/list.js index 979bb76a20..2c3b966c4b 100644 --- a/src/controllers/list.js +++ b/src/controllers/list.js @@ -184,9 +184,9 @@ import 'emby-scroller'; const values = instance.getSortValues(); const sortBy = values.sortBy; - for (let i = 0, length = options.length; i < length; i++) { - if (sortBy === options[i].value) { - btnSortText.innerHTML = globalize.translate('SortByValue', options[i].name); + for (const option of options) { + if (sortBy === option.value) { + btnSortText.innerHTML = globalize.translate('SortByValue', option.name); break; } } @@ -407,18 +407,18 @@ import 'emby-scroller'; } function hideOrShowAll(elems, hide) { - for (let i = 0, length = elems.length; i < length; i++) { + for (const elem of elems) { if (hide) { - elems[i].classList.add('hide'); + elem.classList.add('hide'); } else { - elems[i].classList.remove('hide'); + elem.classList.remove('hide'); } } } function bindAll(elems, eventName, fn) { - for (let i = 0, length = elems.length; i < length; i++) { - elems[i].addEventListener(eventName, fn); + for (const elem of elems) { + elem.addEventListener(eventName, fn); } } @@ -724,16 +724,15 @@ class ItemsView { const btnViewSettings = view.querySelectorAll('.btnViewSettings'); - for (let i = 0, length = btnViewSettings.length; i < length; i++) { - btnViewSettings[i].addEventListener('click', showViewSettingsMenu.bind(this)); + for (const btnViewSetting of btnViewSettings) { + btnViewSetting.addEventListener('click', showViewSettingsMenu.bind(this)); } const filterButtons = view.querySelectorAll('.btnFilter'); this.filterButtons = filterButtons; const hasVisibleFilters = this.getVisibleFilters().length; - for (let i = 0, length = filterButtons.length; i < length; i++) { - const btnFilter = filterButtons[i]; + for (const btnFilter of filterButtons) { btnFilter.addEventListener('click', showFilterMenu.bind(this)); if (hasVisibleFilters) { @@ -744,10 +743,9 @@ class ItemsView { } const sortButtons = view.querySelectorAll('.btnSort'); - let i; - let length; - for (this.sortButtons = sortButtons, i = 0, length = sortButtons.length; i < length; i++) { - const sortButton = sortButtons[i]; + + this.sortButtons = sortButtons; + for (const sortButton of sortButtons) { sortButton.addEventListener('click', showSortMenu.bind(this)); if (params.type !== 'nextup') { @@ -886,10 +884,9 @@ class ItemsView { } getDefaultSortBy() { - const params = this.params; - const sortNameOption = this.getNameSortOption(params); + const sortNameOption = this.getNameSortOption(this.params); - if (params.type) { + if (this.params.type) { return sortNameOption.value; } @@ -898,16 +895,15 @@ class ItemsView { getSortMenuOptions() { const sortBy = []; - const params = this.params; - if (params.type === 'Programs') { + if (this.params.type === 'Programs') { sortBy.push({ name: globalize.translate('AirDate'), value: 'StartDate,SortName' }); } - let option = this.getNameSortOption(params); + let option = this.getNameSortOption(this.params); if (option) { sortBy.push(option); @@ -925,7 +921,7 @@ class ItemsView { sortBy.push(option); } - if (params.type !== 'Programs') { + if (this.params.type !== 'Programs') { sortBy.push({ name: globalize.translate('DateAdded'), value: 'DateCreated,SortName' @@ -938,8 +934,8 @@ class ItemsView { sortBy.push(option); } - if (!params.type) { - option = this.getNameSortOption(params); + if (!this.params.type) { + option = this.getNameSortOption(this.params); sortBy.push({ name: globalize.translate('Folders'), value: 'IsFolder,' + option.value @@ -1054,8 +1050,7 @@ class ItemsView { const filterButtons = this.filterButtons; if (filterButtons.length) { - for (let i = 0, length = filterButtons.length; i < length; i++) { - const btnFilter = filterButtons[i]; + for (const btnFilter of filterButtons) { let bubble = btnFilter.querySelector('.filterButtonBubble'); if (!bubble) { diff --git a/src/libraries/screensavermanager.js b/src/libraries/screensavermanager.js index 61d128ff14..5c24ec63d0 100644 --- a/src/libraries/screensavermanager.js +++ b/src/libraries/screensavermanager.js @@ -34,9 +34,7 @@ function getScreensaverPlugin(isLoggedIn) { const plugins = pluginManager.ofType('screensaver'); - for (let i = 0, length = plugins.length; i < length; i++) { - const plugin = plugins[i]; - + for (const plugin of plugins) { if (plugin.id === option) { return plugin; } From abd6e02151a5c5d985172da69f053ad40ee49b53 Mon Sep 17 00:00:00 2001 From: Cameron Date: Fri, 7 Aug 2020 09:31:46 +0100 Subject: [PATCH 083/301] lint --- src/components/recordingcreator/recordingeditor.js | 14 ++------------ 1 file changed, 2 insertions(+), 12 deletions(-) diff --git a/src/components/recordingcreator/recordingeditor.js b/src/components/recordingcreator/recordingeditor.js index c08feeeb83..6fe104b57f 100644 --- a/src/components/recordingcreator/recordingeditor.js +++ b/src/components/recordingcreator/recordingeditor.js @@ -15,22 +15,12 @@ import 'css!./recordingcreator'; import 'material-icons'; import 'flexStyles'; -/*eslint prefer-const: "error"*/ - let currentDialog; let recordingDeleted = false; let currentItemId; let currentServerId; let currentResolve; -function deleteTimer(apiClient, timerId) { - return new Promise(function (resolve, reject) { - require(['recordingHelper'], function (recordingHelper) { - recordingHelper.cancelTimerWithConfirmation(timerId, apiClient.serverId()).then(resolve, reject); - }); - }); -} - function renderTimer(context, item, apiClient) { context.querySelector('#txtPrePaddingMinutes').value = item.PrePaddingSeconds / 60; context.querySelector('#txtPostPaddingMinutes').value = item.PostPaddingSeconds / 60; @@ -67,8 +57,8 @@ function init(context) { context.querySelector('.btnCancelRecording').addEventListener('click', function () { const apiClient = connectionManager.getApiClient(currentServerId); - - (apiClient, currentItemId).then(function () { + + (apiClient, currentItemId).then(function () { closeDialog(true); }); }); From 93151b883bb6ce5a34deadbbf3c80a038019df50 Mon Sep 17 00:00:00 2001 From: LapinoLapidus Date: Fri, 7 Aug 2020 09:20:37 +0000 Subject: [PATCH 084/301] Translated using Weblate (Dutch) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/nl/ --- src/strings/nl.json | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/src/strings/nl.json b/src/strings/nl.json index 860783b083..36b947855d 100644 --- a/src/strings/nl.json +++ b/src/strings/nl.json @@ -161,7 +161,7 @@ "DeviceAccessHelp": "Dit geldt alleen voor apparaten die uniek geïdentificeerd kunnen worden en voorkomen niet toegang via een webbrowser. Filteren van apparaat toegang voor gebruikers voorkomt dat zij nieuwe apparaten gebruiken totdat deze hier zijn goedgekeurd.", "DirectPlaying": "Direct afspelen", "DirectStreamHelp1": "De resolutie en codec (bijv. H.264, AC3, etc.) wordt ondersteund door het apparaat, maar het medium is in een niet-ondersteunde bestandscontainer (bijv. mkv, avi, wmv). De video zal tijdens het afspelen opnieuw verpakt worden naar een andere bestandscontainer.", - "DirectStreamHelp2": "Direct streamen van een bestand gebruikt weinig processor kracht zonder verlies van beeldkwaliteit.", + "DirectStreamHelp2": "Direct streamen van een bestand gebruikt weinig processorkracht zonder verlies van beeldkwaliteit.", "DirectStreaming": "Direct streamen", "Director": "Regiseur", "Directors": "Regisseurs", @@ -378,7 +378,7 @@ "HeaderPreferredMetadataLanguage": "Gewenste metadata taal", "HeaderProfile": "Profiel", "HeaderProfileInformation": "Profiel Informatie", - "HeaderProfileServerSettingsHelp": "Deze waarden bepalen hoe Jellyfin Server zich zal presenteren aan het apparaat.", + "HeaderProfileServerSettingsHelp": "Deze waarden bepalen hoe de server zich zal presenteren aan het apparaat.", "HeaderRecentlyPlayed": "Recent afgespeeld", "HeaderRecordingOptions": "Opname instellingen", "HeaderRecordingPostProcessing": "Opname nabewerking", @@ -396,13 +396,13 @@ "HeaderSecondsValue": "{0} Seconden", "HeaderSelectCertificatePath": "Selecteer Certificaat Pad", "HeaderSelectMetadataPath": "Selecteer Metadata Pad", - "HeaderSelectMetadataPathHelp": "Blader of voer het pad in dat u wilt gebruiken om metadata in op te slaan. De map moet beschrijfbaar zijn.", + "HeaderSelectMetadataPathHelp": "Blader of voer het pad in dat u wilt gebruiken om metadata in op te slaan. De map moet schrijfbaar zijn.", "HeaderSelectPath": "Selecteer Pad", "HeaderSelectServer": "Selecteer server", "HeaderSelectServerCachePath": "Selecteer Server Cache Pad", "HeaderSelectServerCachePathHelp": "Bladeren of voer het pad in om te gebruiken voor server cache-bestanden. De map moet beschrijfbaar zijn.", "HeaderSelectTranscodingPath": "Selecteer Tijdelijke Transcodeer Pad", - "HeaderSelectTranscodingPathHelp": "Bladeren of voer het pad in om te gebruiken voor het transcoderen van tijdelijke bestanden. De map moet beschrijfbaar zijn.", + "HeaderSelectTranscodingPathHelp": "Blader of voer het pad in om te gebruiken voor het transcoderen van tijdelijke bestanden. De map moet schrijfbaar zijn.", "HeaderSendMessage": "Stuur bericht", "HeaderSeries": "Series", "HeaderSeriesOptions": "Series Opties", @@ -1255,7 +1255,7 @@ "HeaderGenres": "Genres", "HeaderHttpHeaders": "HTTP Headers", "HeaderStatus": "Status", - "AuthProviderHelp": "Selecteer een Authenticatie Provider om het wachtwoord van deze gebruiker te verifiëren.", + "AuthProviderHelp": "Selecteer een authenticatie provider om het wachtwoord van deze gebruiker te verifiëren.", "HeaderFavoriteMovies": "Favoriete Films", "HeaderFavoriteShows": "Favoriete shows", "HeaderFavoriteEpisodes": "Favoriete afleveringen", From c5f6b5057452d348e473074934498e67d0984d8b Mon Sep 17 00:00:00 2001 From: Tobias Hoos Date: Fri, 7 Aug 2020 13:22:37 +0000 Subject: [PATCH 085/301] Translated using Weblate (German) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/de/ --- src/strings/de.json | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/src/strings/de.json b/src/strings/de.json index 1c87a95a95..0aa4d2172f 100644 --- a/src/strings/de.json +++ b/src/strings/de.json @@ -1542,5 +1542,8 @@ "ViewAlbumArtist": "Zeige Albumkünstler", "PreviousTrack": "Zum Vorherigen springen", "NextTrack": "Zum Nächsten springen", - "LabelUnstable": "Instabil" + "LabelUnstable": "Instabil", + "SubtitleVerticalPositionHelp": "Zeilennummer, in der der Text angezeigt wird. Positive Zahlen geben die Zeile von oben an. Negative Zahlen geben die Zeile von unten an.", + "Preview": "Vorschau", + "LabelSubtitleVerticalPosition": "Vertikale Position:" } From 5efd05617c7b9505302c5c1ab97e7d3339a454f9 Mon Sep 17 00:00:00 2001 From: 4d1m Date: Fri, 7 Aug 2020 15:04:04 +0000 Subject: [PATCH 086/301] Translated using Weblate (Romanian) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/ro/ --- src/strings/ro.json | 58 +++++++++++++++++++++++---------------------- 1 file changed, 30 insertions(+), 28 deletions(-) diff --git a/src/strings/ro.json b/src/strings/ro.json index f8aa986264..5489e92abf 100644 --- a/src/strings/ro.json +++ b/src/strings/ro.json @@ -61,9 +61,9 @@ "HeaderTaskTriggers": "Declanșatori Sarcini", "HeaderUsers": "Utilizatori", "Help": "Ajutor", - "ImportMissingEpisodesHelp": "Dacă este activată, informația despre episoadele lipsă va fi importată in baza de date Jellyfin și va fi afișată în cadrul serialelor. Aceasta poate cauza un timp semnificativ mai îndelungat la scanarea bibliotecilor.", + "ImportMissingEpisodesHelp": "Informația despre episoadele lipsă va fi importată în baza de date și va fi afișată în cadrul serialelor. Aceasta poate cauza un timp semnificativ mai îndelungat la scanarea bibliotecilor.", "LabelArtists": "Artisti:", - "LabelArtistsHelp": "Separare multiplă utilizând ;", + "LabelArtistsHelp": "Separară înșiruirea artiștilor utilizând ;", "LabelAudioLanguagePreference": "Preferințe de limbă pentru audio:", "LabelCachePath": "Cale pentru depozit:", "LabelCachePathHelp": "Specificați o locație specială pentru fișierele de tip depozit, precum imagini etc. Lasați gol pentru a folosi setarea implicită.", @@ -82,7 +82,7 @@ "LabelMetadataPath": "Cale pentru metadata:", "LabelMetadataPathHelp": "Specificați o locație specială pentru a descărca postere și metadata.", "LabelMinBackdropDownloadWidth": "Lățimea maximă pentru fundalurile descărcate:", - "LabelMovieRecordingPath": "Calea pentru înregistrări filme (opțional):", + "LabelMovieRecordingPath": "Calea pentru înregistrări filme:", "LabelName": "Nume:", "LabelNewPassword": "Parola nouă:", "LabelNewPasswordConfirm": "Confirmă parola nouă:", @@ -96,7 +96,7 @@ "LabelSaveLocalMetadata": "Salvează posterele si metadata în dosarele ce conțin fișierele media", "LabelSaveLocalMetadataHelp": "Salvând posterele și metadata direct in dosarele media, acestea vor fi mai accesibile pentru a fi modificate.", "LabelSelectUsers": "Selectare utilizatori:", - "LabelSeriesRecordingPath": "Calea pentru înregistrări seriale (opțional):", + "LabelSeriesRecordingPath": "Calea pentru înregistrări de seriale:", "LabelStopWhenPossible": "Oprește când este posibil:", "LabelTimeLimitHours": "Limită de timp(ore):", "LabelTranscodingTempPathHelp": "Specificați o cale specială pentru fișierele transcodate trimise clienților. Lasați gol pentru a folosi pe cea implicită în directorul de lucru al serverului.", @@ -133,7 +133,7 @@ "OptionDatePlayed": "Dată Rulare", "OptionDescending": "Descrescător", "OptionDisableUser": "Dezactivați acest utilizator", - "OptionDisableUserHelp": "Dacă este dezactivat, serverul nu va permite nicio conexiune de la acest utilizator. Conexiunile existente vor fi terminate brusc.", + "OptionDisableUserHelp": "Serverul nu va permite nici o conexiune de la acest utilizator. Conexiunile existente vor fi terminate brusc.", "OptionDislikes": "Dislike-uri", "OptionDownloadArtImage": "Fundal", "OptionDownloadBackImage": "Înapoi", @@ -419,7 +419,7 @@ "HeaderExternalIds": "ID-uri Externe:", "HeaderFavoriteBooks": "Cărți Favorite", "HeaderBranding": "Marca", - "HeaderApiKeysHelp": "Aplicațiile externe trebuie să aibă o cheie API pentru a comunica cu Jellyfin Server. Cheile sunt emise prin conectarea cu un cont Jellyfin sau prin acordarea manuală a unei chei aplicației.", + "HeaderApiKeysHelp": "Aplicațiile externe trebuie să aibă o cheie API pentru a comunica cu serverul. Cheile sunt emise prin conectarea cu un cont de utilizator sau prin acordarea manuală a unei chei aplicației.", "Sync": "Sincronizare", "ErrorAddingXmlTvFile": "A apărut o eroare la accesarea fișierului XMLTV. Vă rugăm să vă asigurați că fișierul există și încercați din nou.", "HeaderApiKey": "Cheie API", @@ -459,7 +459,7 @@ "HeaderMyMediaSmall": "Fișierele mele Media ( micșorat )", "HeaderNewApiKey": "Nouă cheie API", "HeaderNewDevices": "Dispozitive noi", - "HeaderKodiMetadataHelp": "Pentru a activa sau dezactiva metadatele NFO, editați o bibliotecă, în configurarea bibliotecii Jellyfin, și localizați secțiunea de salvare a metadatelor.", + "HeaderKodiMetadataHelp": "Pentru a activa sau dezactiva metadatele NFO, editați o bibliotecă, și localizați secțiunea de salvare a metadatelor.", "HeaderNextVideoPlayingInValue": "Următorul video se redă în {0}", "HeaderOnNow": "Pornit Acum", "HeaderOtherItems": "Alte Elemente", @@ -475,7 +475,7 @@ "HeaderPlaybackError": "Eroare la redare", "HeaderPluginInstallation": "Instalare Plugin", "HeaderProfileInformation": "Informații Profil", - "HeaderProfileServerSettingsHelp": "Aceste valori controlează modul în care Jellyfin Server va fi reprezentat in dispozitiv.", + "HeaderProfileServerSettingsHelp": "Aceste valori controlează modul în care serverul va fi reprezentat in dispozitivele clientilor.", "HeaderRecordingOptions": "Opțiuni Înregistrare", "HeaderRecordingPostProcessing": "Post procesarea înregistrării", "HeaderRemoveMediaFolder": "Eliminați Dosarul Media", @@ -614,7 +614,7 @@ "HeaderSelectServer": "Selectați Serverul", "HeaderSelectServerCachePath": "Selectați ruta pentru Server Cache", "HeaderSelectTranscodingPath": "Selectați ruta temporară pentru transcodare", - "HeaderSelectTranscodingPathHelp": "Căutați sau introduceți ruta dosarului de utilizat pentru transcodarea fișierelor temporare. Dosarul trebuie permisiuni de scriere.", + "HeaderSelectTranscodingPathHelp": "Căutați sau introduceți ruta dosarului de utilizat pentru transcodarea fișierelor. Dosarul trebuie permisiuni de scriere.", "HeaderSendMessage": "Trimite Mesaj", "HeaderSeriesOptions": "Opțiuni Seriale", "HeaderSeriesStatus": "Starea Serialelor", @@ -675,7 +675,7 @@ "LabelSeasonNumber": "Numărul sezonului:", "LabelScreensaver": "Protector de ecran:", "LabelScheduledTaskLastRan": "Ultima redare{0}, cu durata {1}.", - "LabelRuntimeMinutes": "Timp de redare (minute):", + "LabelRuntimeMinutes": "Timp de redare:", "LabelRemoteClientBitrateLimitHelp": "O limită de biți per-stream opțională pentru toate dispozitivele din rețea. Acest lucru este util pentru a împiedica dispozitivele să solicite un bitrate mai mare decât poate gestiona conexiunea dvs. de internet. Acest lucru poate duce la creșterea încărcării procesorului pe serverul dvs. pentru a transcoda videoclipurile din zbor la un bitrate mai mic.", "LabelRemoteClientBitrateLimit": "Limită de biți pentru streaming pe Internet (Mbps):", "LabelReleaseDate": "Data lansării:", @@ -720,7 +720,7 @@ "LabelOriginalTitle": "Titlu original:", "LabelOriginalAspectRatio": "Raport aspect original:", "LabelOptionalNetworkPathHelp": "Dacă acest folder este partajat în rețeaua dvs., furnizarea căii de partajare a rețelei poate permite aplicațiilor Jellyfin de pe alte dispozitive să acceseze fișiere media direct.", - "LabelOptionalNetworkPath": "(Optional) Dosar partajat în rețea:", + "LabelOptionalNetworkPath": "Dosar partajat în rețea:", "LabelNumber": "Număr:", "LabelNotificationEnabled": "Activează această notificare", "LabelNewsCategories": "Categoriile știrilor:", @@ -741,7 +741,7 @@ "LabelMinResumeDurationHelp": "Cea mai scurtă lungime video în secunde, care va salva locația de redare și vă va permite să reluați.", "LabelMinResumeDuration": "Durata minimă a reluării:", "LabelMethod": "Metoda:", - "LabelMetadataSaversHelp": "Alegeți formatele de fișiere pentru a vă salva metadatele.", + "LabelMetadataSaversHelp": "Alegeți formatele de fișiere pentru salvarea metadatele.", "LabelMetadataSavers": "Salvări de metadate:", "LabelMetadataReadersHelp": "Clasificați sursele preferate de metadate locale în ordinea priorității. Primul fișier găsit va fi citit.", "LabelMetadataReaders": "Cititori de metadate:", @@ -761,7 +761,7 @@ "LabelLoginDisclaimerHelp": "Un mesaj care va fi afișat în partea de jos a paginii de conectare.", "LabelLoginDisclaimer": "Act de renunțare la autentificare:", "LabelLockItemToPreventChanges": "Blocați acest element pentru a preveni modificările viitoare", - "LabelLocalHttpServerPortNumberHelp": "Portul TCP pe care serverul HTTP Jellyfin ar trebui să îl utilizeze.", + "LabelLocalHttpServerPortNumberHelp": "Portul TCP pentru serverul HTTP.", "LabelLocalHttpServerPortNumber": "Portul local HTTP:", "LabelLineup": "Echipa:", "LabelLanNetworks": "Rețele LAN:", @@ -788,7 +788,7 @@ "LabelIconMaxWidth": "Lățimea maximă a pictogramei:", "LabelIconMaxHeightHelp": "Rezoluția maximă a pictogramelor expuse via upnp:icon.", "LabelIconMaxHeight": "Înălțimea maximă a pictogramei:", - "LabelHttpsPortHelp": "Portul TCP pe care serverul HTTPS Jellyfin ar trebui sa îl utilizeze.", + "LabelHttpsPortHelp": "Portul TCP pentru serverul HTTPS.", "LabelHttpsPort": "Portul local HTTPS:", "LabelHomeScreenSectionValue": "Secțiunea ecranului de pornire {0}:", "LabelHomeNetworkQuality": "Calitatea pe rețeaua de domiciliu:", @@ -816,7 +816,7 @@ "LabelEndDate": "Data de încheiere:", "LabelEnableSingleImageInDidlLimitHelp": "Unele dispozitive nu vor reda corect dacă mai multe imagini sunt încorporate în Didl.", "LabelEnableSingleImageInDidlLimit": "Limitați la o singură imagine încorporată", - "LabelEnableRealtimeMonitorHelp": "Modificările la fișiere vor fi procesate imediat, pe sistemele de fișiere acceptate.", + "LabelEnableRealtimeMonitorHelp": "Modificările la fișiere vor fi procesate imediat pe sistemele de fișiere acceptate.", "LabelEnableRealtimeMonitor": "Activați monitorizarea în timp real", "LabelEnableHardwareDecodingFor": "Activați decodarea hardware pentru:", "LabelEnableDlnaServerHelp": "Permite dispozitivelor UPnP din rețeaua dvs. să răsfoiască și să redea conținut.", @@ -826,7 +826,7 @@ "LabelEnableDlnaDebugLoggingHelp": "Creați fișiere de jurnal mari și trebuie utilizate numai în funcție de necesități pentru rezolvarea problemelor.", "LabelEnableDlnaDebugLogging": "Activați jurnalul de depanare DLNA", "LabelEnableDlnaClientDiscoveryIntervalHelp": "Determină durata în secunde între căutările SSDP efectuate de Jellyfin.", - "LabelEnableDlnaClientDiscoveryInterval": "Interval de descoperire a clientului (secunde)", + "LabelEnableDlnaClientDiscoveryInterval": "Interval de descoperire a clientului", "LabelEnableBlastAliveMessagesHelp": "Activați acest lucru dacă serverul nu este detectat în mod fiabil de alte dispozitive UPnP din rețeaua dvs.", "LabelEnableBlastAliveMessages": "Trimitere mesaje de disponibilitate", "LabelEnableAutomaticPortMapHelp": "Încercați să mapați automat portul public către portul local prin UPnP. Este posibil să nu funcționeze cu unele modele de router. Modificările nu se vor aplica decât după repornirea serverului.", @@ -874,11 +874,11 @@ "LabelBurnSubtitles": "Imprimă subtitrările:", "LabelBlockContentWithTags": "Blochează articolele cu etichetele:", "LabelBlastMessageIntervalHelp": "Determină durata în secunde între transmiterea mesajele de viață.", - "LabelBlastMessageInterval": "Interval transmitere mesaj viu (secunde)", + "LabelBlastMessageInterval": "Interval transmitere mesaj viu", "LabelBitrate": "Rată de biți:", "LabelBirthYear": "Anul nașterii:", "LabelBirthDate": "Data nașterii:", - "LabelBindToLocalNetworkAddressHelp": "Opțional. Rescrie adresa IP locală pentru a o utiliza serverul http. Dacă este lăsat gol, serverul se va lega la toate adresele disponibile. Modificarea acestei valori necesită repornirea Jellyfin Server.", + "LabelBindToLocalNetworkAddressHelp": "Rescrie adresa IP locală a serverului http. Dacă este lăsat gol, serverul se va lega la toate adresele disponibile. Modificarea acestei valori necesită repornirea Jellyfin Server.", "LabelBindToLocalNetworkAddress": "Utilizează adresa de rețea locală:", "LabelAutomaticallyRefreshInternetMetadataEvery": "Actualizați automat metadatele de pe internet:", "LabelAuthProvider": "Furnizor de autentificare:", @@ -917,7 +917,7 @@ "ItemCount": "{0} articole", "InstantMix": "Mix instant", "InstallingPackage": "Instalare {0} (versiune {1})", - "ImportFavoriteChannelsHelp": "Dacă este activat, vor fi importate numai canalele marcate ca preferate pe dispozitivul tuner.", + "ImportFavoriteChannelsHelp": "Vor fi importate numai canalele marcate ca preferate pe dispozitivul tuner.", "Images": "Imagini", "Identify": "Identifică", "HttpsRequiresCert": "Pentru a activa conexiunile securizate, va trebui să furnizați un certificat SSL de încredere, cum ar fi Let's Encrypt. Vă rugăm să furnizați un certificat sau să dezactivați conexiunile securizate.", @@ -969,14 +969,14 @@ "OptionBlockChannelContent": "Conținut canal Internet", "OptionBlockBooks": "Cărți", "OptionBanner": "Steag", - "OptionAutomaticallyGroupSeriesHelp": "Dacă este activat, seriile distribuite pe mai multe foldere din această bibliotecă vor fi comasate automat într-o singură serie.", + "OptionAutomaticallyGroupSeriesHelp": "Seriile distribuite pe mai multe foldere din această bibliotecă vor fi comasate automat într-o singură serie.", "OptionAutomaticallyGroupSeries": "Fuzionează automat seriile care sunt răspândite pe mai multe foldere", "OptionAuto": "Auto", "OptionArtist": "Artist", "OptionAllowVideoPlaybackTranscoding": "Permiteți redarea video care necesită transcodare", "OptionAllowVideoPlaybackRemuxing": "Permiteți redarea video care necesită conversie fără re-codificare", "OptionAllowSyncTranscoding": "Permiteți descărcarea și sincronizarea media care necesită transcodare", - "OptionAllowMediaPlaybackTranscodingHelp": "Restrângerea accesului la transcodare poate provoca defecțiuni de redare în aplicațiile Jellyfin din cauza formatelor media neacceptate.", + "OptionAllowMediaPlaybackTranscodingHelp": "Restrângerea accesului la transcodare poate provoca defecțiuni de redare în aplicațiile client din cauza formatelor media neacceptate.", "OptionAllowContentDownloading": "Permiteți descărcarea și sincronizarea media", "OptionAllowAudioPlaybackTranscoding": "Permiteți redarea audio care necesită transcodare", "OptionAllUsers": "Toți utilizatorii", @@ -1113,7 +1113,7 @@ "LatestFromLibrary": "Ultimele {0}", "Large": "Mare", "LanNetworksHelp": "Lista separată de virgule a adreselor IP sau a intrărilor de tip IP/mască de rețea pentru rețelele care vor fi luate în considerare în rețeaua locală atunci când se aplică restricțiile de lățime de bandă. Dacă este setat, toate celelalte adrese IP vor fi considerate a fi în rețeaua externă și vor fi supuse restricțiilor de lățime de bandă externe. Dacă este lăsat necompletat, numai subnetul serverului este considerat a fi în rețeaua locală.", - "LabelffmpegPathHelp": "Calea către executabilul ffmpeg, sau dosarul care conține ffmpeg.", + "LabelffmpegPathHelp": "Calea către executabilul ffmpeg sau dosarul care conține ffmpeg.", "LabelffmpegPath": "Calea către FFmpeg:", "LabelZipCode": "Cod poștal:", "LabelYear": "Anul:", @@ -1300,9 +1300,9 @@ "OptionProfileAudio": "Audio", "OptionPosterCard": "Carte de afiș", "OptionPoster": "Afiș", - "OptionPlainVideoItemsHelp": "Dacă este activat, toate videoclipurile sunt reprezentate în DIDL ca „object.item.videoItem” în loc de un tip mai specific, cum ar fi „object.item.videoItem.movie”.", + "OptionPlainVideoItemsHelp": "Toate videoclipurile sunt reprezentate în DIDL ca „object.item.videoItem” în loc de un tip mai specific, cum ar fi „object.item.videoItem.movie”.", "OptionPlainVideoItems": "Afișați toate videoclipurile ca elemente video simple", - "OptionPlainStorageFoldersHelp": "Dacă este activat, toate folderele sunt reprezentate în DIDL ca „object.container.storageFolder” în loc de un tip mai specific, cum ar fi „object.container.person.musicArtist”.", + "OptionPlainStorageFoldersHelp": "Toate dosarele sunt reprezentate în DIDL ca „object.container.storageFolder” în loc de un tip mai specific, cum ar fi „object.container.person.musicArtist”.", "OptionPlainStorageFolders": "Afișați toate dosarele ca dosare simple de stocare", "OptionOnInterval": "La un interval", "OptionOnAppStartup": "La pornirea aplicației", @@ -1315,7 +1315,7 @@ "OptionList": "Listă", "OptionIsSD": "SD", "OptionIsHD": "HD", - "OptionIgnoreTranscodeByteRangeRequestsHelp": "Dacă sunt activate, aceste solicitări vor fi respectate, dar vor ignora antetul intervalului de octeți.", + "OptionIgnoreTranscodeByteRangeRequestsHelp": "Aceste solicitări vor fi respectate, dar vor ignora antetul intervalului de octeți.", "OptionIgnoreTranscodeByteRangeRequests": "Ignorați solicitările pentru transcodarea intervalului de octeți", "OptionHomeVideos": "Fotografii", "OptionHlsSegmentedSubtitles": "Subtitrare segmentată HLS", @@ -1332,7 +1332,7 @@ "OptionEnableExternalContentInSuggestions": "Activați conținut extern în sugestii", "OptionEmbedSubtitles": "Inclus în container", "OptionDownloadLogoImage": "Siglă", - "OptionDownloadImagesInAdvanceHelp": "În mod implicit, majoritatea imaginilor sunt descărcate numai la cererea unei aplicații din Jellyfin. Activați această opțiune pentru a descărca în prealabil toate imaginile, pe măsură ce fișierele media sunt importate. Acest lucru poate provoca scanări ale bibliotecii semnificativ mai lungi.", + "OptionDownloadImagesInAdvanceHelp": "În mod implicit, majoritatea imaginilor sunt descărcate numai la cererea unei aplicații Jellyfin. Activați această opțiune pentru a descărca în avans toate imaginile, pe măsură ce fișiere media noi sunt importate. Acest lucru poate duce la mărirea semnificativă a timpilor de scanare a bibliotecii.", "OptionDownloadImagesInAdvance": "Descărcați imaginile în avans", "OptionDownloadDiscImage": "Disc", "OptionDisplayFolderViewHelp": "Afișați dosarele alături de celelalte biblioteci media. Acest lucru poate fi util dacă doriți să aveți o vizualizare direct în dosar.", @@ -1476,7 +1476,7 @@ "LabelRequireHttps": "Trebuie HTTPS", "LabelStable": "Stabilă", "LabelChromecastVersion": "Versiunea de Chromecast", - "LabelEnableHttpsHelp": "Activează serverul să asculte pe portul HTTPS configurat. Un certificat valid trebuie de asemenea configurat pentru ca să funcţioneze.", + "LabelEnableHttpsHelp": "Ascultă pe portul HTTPS configurat. Un certificat valid trebuie de asemenea configurat pentru ca să funcţioneze.", "LabelEnableHttps": "Activați HTTPS", "HeaderServerAddressSettings": "Setările adresei serverului", "HeaderRemoteAccessSettings": "Setări pentru aces remote", @@ -1539,5 +1539,7 @@ "LabelRepositoryNameHelp": "Un nume personalizat pentru a distinge acest repertoriu de altele adăugate la serverul dvs.", "ClearQueue": "Golește lista de redare", "StopPlayback": "Oprește redarea", - "ViewAlbumArtist": "Vezi artistul albumului" + "ViewAlbumArtist": "Vezi artistul albumului", + "NextTrack": "Sari la următorul", + "LabelUnstable": "Instabil" } From da7cdda13217ddd47121d5ff59447ad3db0486d7 Mon Sep 17 00:00:00 2001 From: 4d1m Date: Fri, 7 Aug 2020 15:22:47 +0000 Subject: [PATCH 087/301] Translated using Weblate (Romanian) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/ro/ --- src/strings/ro.json | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/src/strings/ro.json b/src/strings/ro.json index 5489e92abf..a0f090676b 100644 --- a/src/strings/ro.json +++ b/src/strings/ro.json @@ -1217,7 +1217,7 @@ "ReleaseDate": "Data lansării", "RefreshQueued": "Actualizare adăugată în coadă.", "RefreshMetadata": "Actualizați metadatele", - "RefreshDialogHelp": "Metadatele sunt actualizate pe baza setărilor și a serviciilor de internet care sunt activate în tabloul de bord Jellyfin Server.", + "RefreshDialogHelp": "Metadatele sunt actualizate pe baza setărilor și a serviciilor de internet care sunt activate în tabloul de bord.", "Refresh": "Reîmprospătează", "Recordings": "Înregistrări", "RecordingScheduled": "Înregistrare programată.", @@ -1263,7 +1263,7 @@ "PerfectMatch": "Potrivire perfectă", "People": "Oameni", "PasswordSaved": "Parolă salvată.", - "PasswordResetProviderHelp": "Alegeți un furnizor de resetare a parolei pentru a fi utilizat atunci când acest utilizator solicită o resetare a parolei", + "PasswordResetProviderHelp": "Alegeți un furnizor de resetare a parolei pentru a fi utilizat atunci când acest utilizator solicită o resetare a parolei.", "HeaderResetPassword": "Resetează parola", "PasswordResetConfirmation": "Sigur doriți să resetați parola?", "PasswordResetComplete": "Parola a fost resetată.", @@ -1541,5 +1541,9 @@ "StopPlayback": "Oprește redarea", "ViewAlbumArtist": "Vezi artistul albumului", "NextTrack": "Sari la următorul", - "LabelUnstable": "Instabil" + "LabelUnstable": "Instabil", + "Preview": "Previzualizare", + "SubtitleVerticalPositionHelp": "Numărul de linie unde apare textul. Numerele pozitive indică de sus în jos. Numerele negative indică de jos în sus.", + "LabelSubtitleVerticalPosition": "Poziție verticală:", + "PreviousTrack": "Sari anterior" } From 406e07154c048c1541bf97521b17445bf5ae7c27 Mon Sep 17 00:00:00 2001 From: Bill Thornton Date: Fri, 7 Aug 2020 13:18:21 -0400 Subject: [PATCH 088/301] Hide download button for books when not supported --- src/controllers/itemDetails/index.js | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/src/controllers/itemDetails/index.js b/src/controllers/itemDetails/index.js index df2855d69a..b2cdc63234 100644 --- a/src/controllers/itemDetails/index.js +++ b/src/controllers/itemDetails/index.js @@ -1,3 +1,4 @@ +import appHost from 'apphost'; import loading from 'loading'; import appRouter from 'appRouter'; import layoutManager from 'layoutManager'; @@ -657,7 +658,7 @@ import 'emby-select'; setPeopleHeader(page, item); loading.hide(); - if (item.Type === 'Book') { + if (item.Type === 'Book' && item.CanDownload && appHost.supports('filedownload')) { hideAll(page, 'btnDownload', true); } From 496fb43cb5ac655b6a0cd4a9de4f2b5e0f760d95 Mon Sep 17 00:00:00 2001 From: Thomas Schwery Date: Fri, 7 Aug 2020 20:29:10 +0000 Subject: [PATCH 089/301] Translated using Weblate (French) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/fr/ --- src/strings/fr.json | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/src/strings/fr.json b/src/strings/fr.json index 6d8fb68ecf..20b96f3a52 100644 --- a/src/strings/fr.json +++ b/src/strings/fr.json @@ -1542,5 +1542,8 @@ "ViewAlbumArtist": "Voir l'album de l'artiste", "PreviousTrack": "Revenir au précédent", "NextTrack": "Passer au prochain", - "LabelUnstable": "Instable" + "LabelUnstable": "Instable", + "Preview": "Aperçu", + "SubtitleVerticalPositionHelp": "Numéro de ligne où le texte apparaît. Un nombre positif compte les lignes de haut en bas. Un nombre négatif, de bas en haut.", + "LabelSubtitleVerticalPosition": "Position verticale :" } From 8319046b26eabfce9ab6638cb25df3b82e4cf8e6 Mon Sep 17 00:00:00 2001 From: Cameron Date: Fri, 7 Aug 2020 22:12:14 +0100 Subject: [PATCH 090/301] Update src/components/tunerPicker.js Co-authored-by: Julien Machiels --- src/components/tunerPicker.js | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/src/components/tunerPicker.js b/src/components/tunerPicker.js index 8184b0c62d..1cb3fdc29a 100644 --- a/src/components/tunerPicker.js +++ b/src/components/tunerPicker.js @@ -32,9 +32,8 @@ function getEditorHtml() { function getDeviceHtml(device) { let html = ''; - let cssClass = 'card scalableCard'; + let cssClass = 'card scalableCard backdropCard backdropCard-scalable'; const cardBoxCssClass = 'cardBox visualCardBox'; - cssClass += ' backdropCard backdropCard-scalable'; const padderClass = 'cardPadder-backdrop'; // TODO move card creation code to Card component From dbb6cd97301cc111ae54f500e683d88759b579c4 Mon Sep 17 00:00:00 2001 From: Cameron Date: Fri, 7 Aug 2020 22:46:12 +0100 Subject: [PATCH 091/301] Lint --- src/libraries/scroller.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/libraries/scroller.js b/src/libraries/scroller.js index 4bfcb7d5b9..c460ec5b2c 100644 --- a/src/libraries/scroller.js +++ b/src/libraries/scroller.js @@ -883,4 +883,4 @@ scrollerFactory.create = function (frame, options) { return Promise.resolve(instance); }; -export default scrollerFactory; \ No newline at end of file +export default scrollerFactory; From b512187129cfb841bc0b1b8556616150ff4fef16 Mon Sep 17 00:00:00 2001 From: SaddFox Date: Fri, 7 Aug 2020 22:09:25 +0000 Subject: [PATCH 092/301] Translated using Weblate (Slovenian) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/sl/ --- src/strings/sl-si.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/src/strings/sl-si.json b/src/strings/sl-si.json index 423ee7797c..bf9ec21379 100644 --- a/src/strings/sl-si.json +++ b/src/strings/sl-si.json @@ -1429,5 +1429,7 @@ "OptionEnableM2tsModeHelp": "Omogoči m2ts način pri kodiranju v mpegts.", "OptionEnableM2tsMode": "Omogoči M2ts način", "OptionDisplayFolderViewHelp": "Prikaže mape poleg ostalih knjižnic predstavnosti. Uporabno za preprost ogled map.", - "OptionDisplayFolderView": "Prikaži pogled mape za prikaz navadnih map predstavnosti" + "OptionDisplayFolderView": "Prikaži pogled mape za prikaz navadnih map predstavnosti", + "Yesterday": "Včeraj", + "Yes": "Da" } From 28d34b1bae8f8b77458fb98c11f134c8fed1ad52 Mon Sep 17 00:00:00 2001 From: Cameron Date: Fri, 7 Aug 2020 23:13:54 +0100 Subject: [PATCH 093/301] Update src/controllers/list.js Co-authored-by: Dmitry Lyzo <56478732+dmitrylyzo@users.noreply.github.com> --- src/controllers/list.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/controllers/list.js b/src/controllers/list.js index 2c3b966c4b..0027c576f1 100644 --- a/src/controllers/list.js +++ b/src/controllers/list.js @@ -399,7 +399,7 @@ import 'emby-scroller'; const instance = this; import('playlistEditor').then(({default: playlistEditor}) => { - new playlistEditor.showEditor({ + new playlistEditor({ items: [], serverId: instance.params.serverId }); From 2d72645aad0ae9dfa94fa9d7e32333d522129499 Mon Sep 17 00:00:00 2001 From: MrTimscampi Date: Sat, 8 Aug 2020 03:15:57 +0200 Subject: [PATCH 094/301] Move HTML files to the proper locations --- package.json | 2 +- src/{ => controllers/dashboard}/apikeys.html | 0 .../dashboard}/dashboard.html | 0 .../dashboard/devices}/device.html | 0 .../dashboard/devices}/devices.html | 0 .../dashboard/dlna/profile.html} | 0 .../dashboard/dlna/profiles.html} | 0 .../dashboard/dlna/settings.html} | 0 .../dashboard}/encodingsettings.html | 0 .../dashboard/general.html} | 0 src/{ => controllers/dashboard}/library.html | 0 .../dashboard/{mediaLibrary.js => library.js} | 0 .../dashboard}/librarydisplay.html | 0 .../dashboard/logs.html} | 0 .../dashboard}/metadataimages.html | 0 .../dashboard}/metadatanfo.html | 0 .../dashboard}/networking.html | 0 .../dashboard/playback.html} | 0 .../scheduledtasks}/scheduledtask.html | 0 .../scheduledtasks}/scheduledtasks.html | 0 .../dashboard}/serveractivity.html | 0 .../dashboard/streaming.html} | 0 .../dashboard/users}/useredit.html | 0 .../dashboard/users}/userlibraryaccess.html | 0 .../dashboard/users}/usernew.html | 0 .../dashboard/users}/userparentalcontrol.html | 0 .../dashboard/users}/userpassword.html | 0 .../dashboard/users}/userprofiles.html | 0 src/{ => controllers}/edititemmetadata.html | 0 src/{ => controllers}/home.html | 0 src/{ => controllers}/list.html | 0 src/{ => controllers}/livetv.html | 0 .../livetvguideprovider.html | 0 src/{ => controllers}/livetvsettings.html | 0 src/{ => controllers}/livetvstatus.html | 0 src/{ => controllers}/livetvtuner.html | 0 src/{ => controllers/movies}/movies.html | 0 src/{ => controllers/music}/music.html | 0 src/{ => controllers}/search.html | 0 .../shows/tvrecommended.html} | 0 .../wizard/library.html} | 0 src/index.html | 3 +- src/scripts/routes.js | 131 ++++++++++++------ 43 files changed, 87 insertions(+), 49 deletions(-) rename src/{ => controllers/dashboard}/apikeys.html (100%) rename src/{ => controllers/dashboard}/dashboard.html (100%) rename src/{ => controllers/dashboard/devices}/device.html (100%) rename src/{ => controllers/dashboard/devices}/devices.html (100%) rename src/{dlnaprofile.html => controllers/dashboard/dlna/profile.html} (100%) rename src/{dlnaprofiles.html => controllers/dashboard/dlna/profiles.html} (100%) rename src/{dlnasettings.html => controllers/dashboard/dlna/settings.html} (100%) rename src/{ => controllers/dashboard}/encodingsettings.html (100%) rename src/{dashboardgeneral.html => controllers/dashboard/general.html} (100%) rename src/{ => controllers/dashboard}/library.html (100%) rename src/controllers/dashboard/{mediaLibrary.js => library.js} (100%) rename src/{ => controllers/dashboard}/librarydisplay.html (100%) rename src/{log.html => controllers/dashboard/logs.html} (100%) rename src/{ => controllers/dashboard}/metadataimages.html (100%) rename src/{ => controllers/dashboard}/metadatanfo.html (100%) rename src/{ => controllers/dashboard}/networking.html (100%) rename src/{playbackconfiguration.html => controllers/dashboard/playback.html} (100%) rename src/{ => controllers/dashboard/scheduledtasks}/scheduledtask.html (100%) rename src/{ => controllers/dashboard/scheduledtasks}/scheduledtasks.html (100%) rename src/{ => controllers/dashboard}/serveractivity.html (100%) rename src/{streamingsettings.html => controllers/dashboard/streaming.html} (100%) rename src/{ => controllers/dashboard/users}/useredit.html (100%) rename src/{ => controllers/dashboard/users}/userlibraryaccess.html (100%) rename src/{ => controllers/dashboard/users}/usernew.html (100%) rename src/{ => controllers/dashboard/users}/userparentalcontrol.html (100%) rename src/{ => controllers/dashboard/users}/userpassword.html (100%) rename src/{ => controllers/dashboard/users}/userprofiles.html (100%) rename src/{ => controllers}/edititemmetadata.html (100%) rename src/{ => controllers}/home.html (100%) rename src/{ => controllers}/list.html (100%) rename src/{ => controllers}/livetv.html (100%) rename src/{ => controllers}/livetvguideprovider.html (100%) rename src/{ => controllers}/livetvsettings.html (100%) rename src/{ => controllers}/livetvstatus.html (100%) rename src/{ => controllers}/livetvtuner.html (100%) rename src/{ => controllers/movies}/movies.html (100%) rename src/{ => controllers/music}/music.html (100%) rename src/{ => controllers}/search.html (100%) rename src/{tv.html => controllers/shows/tvrecommended.html} (100%) rename src/{wizardlibrary.html => controllers/wizard/library.html} (100%) diff --git a/package.json b/package.json index ac2ad86e57..21b8ffbbd8 100644 --- a/package.json +++ b/package.json @@ -198,7 +198,7 @@ "src/controllers/music/musicplaylists.js", "src/controllers/music/musicrecommended.js", "src/controllers/music/songs.js", - "src/controllers/dashboard/mediaLibrary.js", + "src/controllers/dashboard/library.js", "src/controllers/dashboard/metadataImages.js", "src/controllers/dashboard/metadatanfo.js", "src/controllers/dashboard/networking.js", diff --git a/src/apikeys.html b/src/controllers/dashboard/apikeys.html similarity index 100% rename from src/apikeys.html rename to src/controllers/dashboard/apikeys.html diff --git a/src/dashboard.html b/src/controllers/dashboard/dashboard.html similarity index 100% rename from src/dashboard.html rename to src/controllers/dashboard/dashboard.html diff --git a/src/device.html b/src/controllers/dashboard/devices/device.html similarity index 100% rename from src/device.html rename to src/controllers/dashboard/devices/device.html diff --git a/src/devices.html b/src/controllers/dashboard/devices/devices.html similarity index 100% rename from src/devices.html rename to src/controllers/dashboard/devices/devices.html diff --git a/src/dlnaprofile.html b/src/controllers/dashboard/dlna/profile.html similarity index 100% rename from src/dlnaprofile.html rename to src/controllers/dashboard/dlna/profile.html diff --git a/src/dlnaprofiles.html b/src/controllers/dashboard/dlna/profiles.html similarity index 100% rename from src/dlnaprofiles.html rename to src/controllers/dashboard/dlna/profiles.html diff --git a/src/dlnasettings.html b/src/controllers/dashboard/dlna/settings.html similarity index 100% rename from src/dlnasettings.html rename to src/controllers/dashboard/dlna/settings.html diff --git a/src/encodingsettings.html b/src/controllers/dashboard/encodingsettings.html similarity index 100% rename from src/encodingsettings.html rename to src/controllers/dashboard/encodingsettings.html diff --git a/src/dashboardgeneral.html b/src/controllers/dashboard/general.html similarity index 100% rename from src/dashboardgeneral.html rename to src/controllers/dashboard/general.html diff --git a/src/library.html b/src/controllers/dashboard/library.html similarity index 100% rename from src/library.html rename to src/controllers/dashboard/library.html diff --git a/src/controllers/dashboard/mediaLibrary.js b/src/controllers/dashboard/library.js similarity index 100% rename from src/controllers/dashboard/mediaLibrary.js rename to src/controllers/dashboard/library.js diff --git a/src/librarydisplay.html b/src/controllers/dashboard/librarydisplay.html similarity index 100% rename from src/librarydisplay.html rename to src/controllers/dashboard/librarydisplay.html diff --git a/src/log.html b/src/controllers/dashboard/logs.html similarity index 100% rename from src/log.html rename to src/controllers/dashboard/logs.html diff --git a/src/metadataimages.html b/src/controllers/dashboard/metadataimages.html similarity index 100% rename from src/metadataimages.html rename to src/controllers/dashboard/metadataimages.html diff --git a/src/metadatanfo.html b/src/controllers/dashboard/metadatanfo.html similarity index 100% rename from src/metadatanfo.html rename to src/controllers/dashboard/metadatanfo.html diff --git a/src/networking.html b/src/controllers/dashboard/networking.html similarity index 100% rename from src/networking.html rename to src/controllers/dashboard/networking.html diff --git a/src/playbackconfiguration.html b/src/controllers/dashboard/playback.html similarity index 100% rename from src/playbackconfiguration.html rename to src/controllers/dashboard/playback.html diff --git a/src/scheduledtask.html b/src/controllers/dashboard/scheduledtasks/scheduledtask.html similarity index 100% rename from src/scheduledtask.html rename to src/controllers/dashboard/scheduledtasks/scheduledtask.html diff --git a/src/scheduledtasks.html b/src/controllers/dashboard/scheduledtasks/scheduledtasks.html similarity index 100% rename from src/scheduledtasks.html rename to src/controllers/dashboard/scheduledtasks/scheduledtasks.html diff --git a/src/serveractivity.html b/src/controllers/dashboard/serveractivity.html similarity index 100% rename from src/serveractivity.html rename to src/controllers/dashboard/serveractivity.html diff --git a/src/streamingsettings.html b/src/controllers/dashboard/streaming.html similarity index 100% rename from src/streamingsettings.html rename to src/controllers/dashboard/streaming.html diff --git a/src/useredit.html b/src/controllers/dashboard/users/useredit.html similarity index 100% rename from src/useredit.html rename to src/controllers/dashboard/users/useredit.html diff --git a/src/userlibraryaccess.html b/src/controllers/dashboard/users/userlibraryaccess.html similarity index 100% rename from src/userlibraryaccess.html rename to src/controllers/dashboard/users/userlibraryaccess.html diff --git a/src/usernew.html b/src/controllers/dashboard/users/usernew.html similarity index 100% rename from src/usernew.html rename to src/controllers/dashboard/users/usernew.html diff --git a/src/userparentalcontrol.html b/src/controllers/dashboard/users/userparentalcontrol.html similarity index 100% rename from src/userparentalcontrol.html rename to src/controllers/dashboard/users/userparentalcontrol.html diff --git a/src/userpassword.html b/src/controllers/dashboard/users/userpassword.html similarity index 100% rename from src/userpassword.html rename to src/controllers/dashboard/users/userpassword.html diff --git a/src/userprofiles.html b/src/controllers/dashboard/users/userprofiles.html similarity index 100% rename from src/userprofiles.html rename to src/controllers/dashboard/users/userprofiles.html diff --git a/src/edititemmetadata.html b/src/controllers/edititemmetadata.html similarity index 100% rename from src/edititemmetadata.html rename to src/controllers/edititemmetadata.html diff --git a/src/home.html b/src/controllers/home.html similarity index 100% rename from src/home.html rename to src/controllers/home.html diff --git a/src/list.html b/src/controllers/list.html similarity index 100% rename from src/list.html rename to src/controllers/list.html diff --git a/src/livetv.html b/src/controllers/livetv.html similarity index 100% rename from src/livetv.html rename to src/controllers/livetv.html diff --git a/src/livetvguideprovider.html b/src/controllers/livetvguideprovider.html similarity index 100% rename from src/livetvguideprovider.html rename to src/controllers/livetvguideprovider.html diff --git a/src/livetvsettings.html b/src/controllers/livetvsettings.html similarity index 100% rename from src/livetvsettings.html rename to src/controllers/livetvsettings.html diff --git a/src/livetvstatus.html b/src/controllers/livetvstatus.html similarity index 100% rename from src/livetvstatus.html rename to src/controllers/livetvstatus.html diff --git a/src/livetvtuner.html b/src/controllers/livetvtuner.html similarity index 100% rename from src/livetvtuner.html rename to src/controllers/livetvtuner.html diff --git a/src/movies.html b/src/controllers/movies/movies.html similarity index 100% rename from src/movies.html rename to src/controllers/movies/movies.html diff --git a/src/music.html b/src/controllers/music/music.html similarity index 100% rename from src/music.html rename to src/controllers/music/music.html diff --git a/src/search.html b/src/controllers/search.html similarity index 100% rename from src/search.html rename to src/controllers/search.html diff --git a/src/tv.html b/src/controllers/shows/tvrecommended.html similarity index 100% rename from src/tv.html rename to src/controllers/shows/tvrecommended.html diff --git a/src/wizardlibrary.html b/src/controllers/wizard/library.html similarity index 100% rename from src/wizardlibrary.html rename to src/controllers/wizard/library.html diff --git a/src/index.html b/src/index.html index 797fce8a94..c689a42f30 100644 --- a/src/index.html +++ b/src/index.html @@ -137,8 +137,7 @@ } @media screen - and (min-device-width: 992px) - and (-webkit-min-device-pixel-ratio: 1) { + and (min-device-width: 992px) { .splashLogo { background-image: url(assets/img/banner-light.png); } diff --git a/src/scripts/routes.js b/src/scripts/routes.js index 4094a2552f..4bbd5cff34 100644 --- a/src/scripts/routes.js +++ b/src/scripts/routes.js @@ -112,54 +112,69 @@ import 'detailtablecss'; }); defineRoute({ - path: '/dashboard.html', + alias: '/dashboard.html', + path: '/controllers/dashboard/dashboard.html', autoFocus: false, roles: 'admin', controller: 'dashboard/dashboard' }); defineRoute({ - path: '/dashboardgeneral.html', + alias: '/dashboardgeneral.html', + path: '/controllers/dashboard/general.html', controller: 'dashboard/general', autoFocus: false, roles: 'admin' }); defineRoute({ - path: '/networking.html', + alias: '/networking.html', + path: '/controllers/dashboard/networking.html', autoFocus: false, roles: 'admin', controller: 'dashboard/networking' }); defineRoute({ - path: '/devices.html', + alias: '/devices.html', + path: '/controllers/dashboard/devices/devices.html', autoFocus: false, roles: 'admin', controller: 'dashboard/devices/devices' }); defineRoute({ - path: '/device.html', + alias: '/device.html', + path: '/controllers/dashboard/devices/device.html', autoFocus: false, roles: 'admin', controller: 'dashboard/devices/device' }); defineRoute({ - path: '/dlnaprofile.html', + alias: '/dlnaprofile.html', + path: '/controllers/dashboard/dlna/profile.html', autoFocus: false, roles: 'admin', controller: 'dashboard/dlna/profile' }); defineRoute({ - path: '/dlnaprofiles.html', + alias: '/dlnaprofiles.html', + path: '/controllers/dashboard/dlna/profiles.html', autoFocus: false, roles: 'admin', controller: 'dashboard/dlna/profiles' }); + defineRoute({ + alias: '/dlnasettings.html', + path: '/controllers/dashboard/dlna/settings.html', + autoFocus: false, + roles: 'admin', + controller: 'dashboard/dlna/settings' + }); + defineRoute({ alias: '/addplugin.html', path: '/controllers/dashboard/plugins/add/index.html', @@ -169,54 +184,54 @@ import 'detailtablecss'; }); defineRoute({ - path: '/library.html', + alias: '/library.html', + path: '/controllers/dashboard/library.html', autoFocus: false, roles: 'admin', - controller: 'dashboard/mediaLibrary' + controller: 'dashboard/library' }); defineRoute({ - path: '/librarydisplay.html', + alias: '/librarydisplay.html', + path: '/controllers/dashboard/librarydisplay.html', autoFocus: false, roles: 'admin', controller: 'dashboard/librarydisplay' }); defineRoute({ - path: '/dlnasettings.html', - autoFocus: false, - roles: 'admin', - controller: 'dashboard/dlna/settings' - }); - - defineRoute({ - path: '/edititemmetadata.html', + alias: '/edititemmetadata.html', + path: '/controllers/edititemmetadata.html', controller: 'edititemmetadata', autoFocus: false }); defineRoute({ - path: '/encodingsettings.html', + alias: '/encodingsettings.html', + path: '/controllers/dashboard/encodingsettings.html', autoFocus: false, roles: 'admin', controller: 'dashboard/encodingsettings' }); defineRoute({ - path: '/log.html', + alias: '/log.html', + path: '/controllers/dashboard/logs.html', roles: 'admin', controller: 'dashboard/logs' }); defineRoute({ - path: '/metadataimages.html', + alias: '/metadataimages.html', + path: '/controllers/dashboard/metadataimages.html', autoFocus: false, roles: 'admin', controller: 'dashboard/metadataImages' }); defineRoute({ - path: '/metadatanfo.html', + alias: '/metadatanfo.html', + path: '/controllers/dashboard/metadatanfo.html', autoFocus: false, roles: 'admin', controller: 'dashboard/metadatanfo' @@ -240,6 +255,7 @@ import 'detailtablecss'; defineRoute({ path: '/playbackconfiguration.html', + path: '/controllers/dashboard/playback.html', autoFocus: false, roles: 'admin', controller: 'dashboard/playback' @@ -262,19 +278,22 @@ import 'detailtablecss'; }); defineRoute({ - path: '/home.html', + alias: '/home.html', + path: '/controllers/home.html', autoFocus: false, controller: 'home', type: 'home' }); defineRoute({ - path: '/search.html', + alias: '/search.html', + path: '/controllers/search.html', controller: 'searchpage' }); defineRoute({ - path: '/list.html', + alias: '/list.html', + path: '/controllers/list.html', autoFocus: false, controller: 'list' }); @@ -287,46 +306,53 @@ import 'detailtablecss'; }); defineRoute({ - path: '/livetv.html', + alias: '/livetv.html', + path: '/controllers/livetv.html', controller: 'livetv/livetvsuggested', autoFocus: false }); defineRoute({ - path: '/livetvguideprovider.html', + alias: '/livetvguideprovider.html', + path: '/controllers/livetvguideprovider.html', autoFocus: false, roles: 'admin', controller: 'livetvguideprovider' }); defineRoute({ - path: '/livetvsettings.html', + alias: '/livetvsettings.html', + path: '/controllers/livetvsettings.html', autoFocus: false, controller: 'livetvsettings' }); defineRoute({ - path: '/livetvstatus.html', + alias: '/livetvstatus.html', + path: '/controllers/livetvstatus.html', autoFocus: false, roles: 'admin', controller: 'livetvstatus' }); defineRoute({ - path: '/livetvtuner.html', + alias: '/livetvtuner.html', + path: '/controllers/livetvtuner.html', autoFocus: false, roles: 'admin', controller: 'livetvtuner' }); defineRoute({ - path: '/movies.html', + alias: '/movies.html', + path: '/controllers/movies/movies.html', autoFocus: false, controller: 'movies/moviesrecommended' }); defineRoute({ - path: '/music.html', + alias: '/music.html', + path: '/controllers/music/music.html', controller: 'music/musicrecommended', autoFocus: false }); @@ -340,82 +366,94 @@ import 'detailtablecss'; }); defineRoute({ - path: '/scheduledtask.html', + alias: '/scheduledtask.html', + path: '/controllers/dashboard/scheduledtasks/scheduledtask.html', autoFocus: false, roles: 'admin', controller: 'dashboard/scheduledtasks/scheduledtask' }); defineRoute({ - path: '/scheduledtasks.html', + alias: '/scheduledtasks.html', + path: '/controllers/dashboard/scheduledtasks/scheduledtasks.html', autoFocus: false, roles: 'admin', controller: 'dashboard/scheduledtasks/scheduledtasks' }); defineRoute({ - path: '/serveractivity.html', + alias: '/serveractivity.html', + path: '/controllers/dashboard/serveractivity.html', autoFocus: false, roles: 'admin', controller: 'dashboard/serveractivity' }); defineRoute({ - path: '/apikeys.html', + alias: '/apikeys.html', + path: '/controllers/dashboard/apikeys.html', autoFocus: false, roles: 'admin', controller: 'dashboard/apikeys' }); defineRoute({ - path: '/streamingsettings.html', + alias: '/streamingsettings.html', + path: '/controllers/dashboard/streaming.html', autoFocus: false, roles: 'admin', controller: 'dashboard/streaming' }); defineRoute({ - path: '/tv.html', + alias: '/tv.html', + path: '/controllers/shows/tvrecommended.html', autoFocus: false, controller: 'shows/tvrecommended' }); defineRoute({ - path: '/useredit.html', + alias: '/useredit.html', + path: '/controllers/dashboard/users/useredit.html', autoFocus: false, roles: 'admin', controller: 'dashboard/users/useredit' }); defineRoute({ - path: '/userlibraryaccess.html', + alias: '/userlibraryaccess.html', + path: '/controllers/dashboard/users/userlibraryaccess.html', autoFocus: false, roles: 'admin', controller: 'dashboard/users/userlibraryaccess' }); defineRoute({ - path: '/usernew.html', + alias: '/usernew.html', + path: '/controllers/dashboard/users/usernew.html', autoFocus: false, roles: 'admin', controller: 'dashboard/users/usernew' }); defineRoute({ - path: '/userparentalcontrol.html', + alias: '/userparentalcontrol.html', + path: '/controllers/dashboard/users/userparentalcontrol.html', autoFocus: false, roles: 'admin', controller: 'dashboard/users/userparentalcontrol' }); defineRoute({ - path: '/userpassword.html', + alias: '/userpassword.html', + path: '/controllers/dashboard/users/userpassword.html', autoFocus: false, controller: 'dashboard/users/userpasswordpage' }); defineRoute({ - path: '/userprofiles.html', + alias: '/userprofiles.html', + path: '/controllers/dashboard/users/userprofiles.html', autoFocus: false, roles: 'admin', controller: 'dashboard/users/userprofilespage' @@ -438,10 +476,11 @@ import 'detailtablecss'; }); defineRoute({ - path: '/wizardlibrary.html', + alias: '/wizardlibrary.html', + path: '/controllers/wizard/library.html', autoFocus: false, anonymous: true, - controller: 'dashboard/mediaLibrary' + controller: 'dashboard/library' }); defineRoute({ From 6b655e57ac334764f2e9d5aa263dbe851f9414b9 Mon Sep 17 00:00:00 2001 From: MrTimscampi Date: Sat, 8 Aug 2020 05:31:07 +0200 Subject: [PATCH 095/301] Fix lint --- src/scripts/routes.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/scripts/routes.js b/src/scripts/routes.js index 4bbd5cff34..4bb3eb25d9 100644 --- a/src/scripts/routes.js +++ b/src/scripts/routes.js @@ -254,7 +254,7 @@ import 'detailtablecss'; }); defineRoute({ - path: '/playbackconfiguration.html', + alias: '/playbackconfiguration.html', path: '/controllers/dashboard/playback.html', autoFocus: false, roles: 'admin', From b3166dd2c4132d07ec2436d7abc4efa052b016ec Mon Sep 17 00:00:00 2001 From: SaddFox Date: Fri, 7 Aug 2020 22:20:55 +0000 Subject: [PATCH 096/301] Translated using Weblate (Slovenian) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/sl/ --- src/strings/sl-si.json | 18 +++++++++++++++++- 1 file changed, 17 insertions(+), 1 deletion(-) diff --git a/src/strings/sl-si.json b/src/strings/sl-si.json index bf9ec21379..077ea67804 100644 --- a/src/strings/sl-si.json +++ b/src/strings/sl-si.json @@ -1431,5 +1431,21 @@ "OptionDisplayFolderViewHelp": "Prikaže mape poleg ostalih knjižnic predstavnosti. Uporabno za preprost ogled map.", "OptionDisplayFolderView": "Prikaži pogled mape za prikaz navadnih map predstavnosti", "Yesterday": "Včeraj", - "Yes": "Da" + "Yes": "Da", + "RecommendationStarring": "Nastopa {0}", + "Recordings": "Posnetki", + "RemoveFromCollection": "Odstrani iz zbirke", + "ResumeAt": "Nadaljuj od {0}", + "SaveSubtitlesIntoMediaFolders": "Shrani podnapise v mape predstavnosti", + "ScanForNewAndUpdatedFiles": "Poišči nove in spremenjene datoteke", + "Screenshot": "Posnetek zaslona", + "Screenshots": "Posnetki zaslona", + "Search": "Iskanje", + "ShowAdvancedSettings": "Prikaži napredne nastavitve", + "New": "Novo", + "SubtitleOffset": "Zamik podnapisev", + "Subtitles": "Podnapisi", + "Sunday": "Nedelja", + "TabAdvanced": "Napredno", + "TabAlbums": "Albumi" } From f34a64a607c024bea5df3fd8fac00ed68768ab85 Mon Sep 17 00:00:00 2001 From: "dependabot-preview[bot]" <27856297+dependabot-preview[bot]@users.noreply.github.com> Date: Sat, 8 Aug 2020 11:13:21 +0000 Subject: [PATCH 097/301] Bump whatwg-fetch from 3.3.1 to 3.4.0 Bumps [whatwg-fetch](https://github.com/github/fetch) from 3.3.1 to 3.4.0. - [Release notes](https://github.com/github/fetch/releases) - [Commits](https://github.com/github/fetch/compare/v3.3.1...v3.4.0) Signed-off-by: dependabot-preview[bot] --- package.json | 2 +- yarn.lock | 8 ++++---- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/package.json b/package.json index ac2ad86e57..d7cd3b7f31 100644 --- a/package.json +++ b/package.json @@ -80,7 +80,7 @@ "sortablejs": "^1.10.2", "swiper": "^5.4.5", "webcomponents.js": "^0.7.24", - "whatwg-fetch": "^3.3.1" + "whatwg-fetch": "^3.4.0" }, "babel": { "presets": [ diff --git a/yarn.lock b/yarn.lock index ad55e16176..fd02458167 100644 --- a/yarn.lock +++ b/yarn.lock @@ -11994,10 +11994,10 @@ webworkify@^1.5.0: resolved "https://registry.yarnpkg.com/webworkify/-/webworkify-1.5.0.tgz#734ad87a774de6ebdd546e1d3e027da5b8f4a42c" integrity sha512-AMcUeyXAhbACL8S2hqqdqOLqvJ8ylmIbNwUIqQujRSouf4+eUFaXbG6F1Rbu+srlJMmxQWsiU7mOJi0nMBfM1g== -whatwg-fetch@^3.3.1: - version "3.3.1" - resolved "https://registry.yarnpkg.com/whatwg-fetch/-/whatwg-fetch-3.3.1.tgz#6c1acf37dec176b0fd6bc9a74b616bec2f612935" - integrity sha512-faXTmGDcLuEPBpJwb5LQfyxvubKiE+RlbmmweFGKjvIPFj4uHTTfdtTIkdTRhC6OSH9S9eyYbx8kZ0UEaQqYTA== +whatwg-fetch@^3.4.0: + version "3.4.0" + resolved "https://registry.yarnpkg.com/whatwg-fetch/-/whatwg-fetch-3.4.0.tgz#e11de14f4878f773fbebcde8871b2c0699af8b30" + integrity sha512-rsum2ulz2iuZH08mJkT0Yi6JnKhwdw4oeyMjokgxd+mmqYSd9cPpOQf01TIWgjxG/U4+QR+AwKq6lSbXVxkyoQ== which-module@^1.0.0: version "1.0.0" From 93f23c3d32d85899406e699a66b1e40e19968899 Mon Sep 17 00:00:00 2001 From: "dependabot-preview[bot]" <27856297+dependabot-preview[bot]@users.noreply.github.com> Date: Sat, 8 Aug 2020 11:18:26 +0000 Subject: [PATCH 098/301] Bump hls.js from 0.14.7 to 0.14.8 Bumps [hls.js](https://github.com/video-dev/hls.js) from 0.14.7 to 0.14.8. - [Release notes](https://github.com/video-dev/hls.js/releases) - [Changelog](https://github.com/video-dev/hls.js/blob/master/docs/release-process.md) - [Commits](https://github.com/video-dev/hls.js/compare/v0.14.7...v0.14.8) Signed-off-by: dependabot-preview[bot] --- package.json | 2 +- yarn.lock | 8 ++++---- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/package.json b/package.json index ac2ad86e57..9f3b1d9499 100644 --- a/package.json +++ b/package.json @@ -63,7 +63,7 @@ "fast-text-encoding": "^1.0.3", "flv.js": "^1.5.0", "headroom.js": "^0.11.0", - "hls.js": "^0.14.7", + "hls.js": "^0.14.8", "howler": "^2.2.0", "intersection-observer": "^0.11.0", "jellyfin-apiclient": "^1.4.1", diff --git a/yarn.lock b/yarn.lock index ad55e16176..bfe52b7f3e 100644 --- a/yarn.lock +++ b/yarn.lock @@ -5465,10 +5465,10 @@ hex-color-regex@^1.1.0: resolved "https://registry.yarnpkg.com/hex-color-regex/-/hex-color-regex-1.1.0.tgz#4c06fccb4602fe2602b3c93df82d7e7dbf1a8a8e" integrity sha512-l9sfDFsuqtOqKDsQdqrMRk0U85RZc0RtOR9yPI7mRVOa4FsR/BVnZ0shmQRM96Ji99kYZP/7hn1cedc1+ApsTQ== -hls.js@^0.14.7: - version "0.14.7" - resolved "https://registry.yarnpkg.com/hls.js/-/hls.js-0.14.7.tgz#47fbd2662b13121ab17c07aea06b1c07828240cf" - integrity sha512-9JY0D9nwMrfQPRWc8/kEJTKK0TYfDTzIs6Xq+gdCvasRxdvQKQ2T76rdueTkS0AsFV6sQlJN0wxbnI44aRvvUA== +hls.js@^0.14.8: + version "0.14.8" + resolved "https://registry.yarnpkg.com/hls.js/-/hls.js-0.14.8.tgz#c2c6ca7005524c81eece316c2a4a199258bd0590" + integrity sha512-4fh8k/sl1SmYXsT4Om8AY5fKa5tUUtAxup2sffrSMh5MNk4Kt4FOZxbjqTGL5VwkroY1oJ9twSciNQNFbPA/WQ== dependencies: eventemitter3 "^4.0.3" url-toolkit "^2.1.6" From 81c6dc6907f94ab7e438c8c17e8d6a13db481473 Mon Sep 17 00:00:00 2001 From: MrTimscampi Date: Sat, 8 Aug 2020 15:26:03 +0200 Subject: [PATCH 099/301] Move Dashboard to a new module --- package.json | 1 + src/components/appRouter.js | 8 -- src/scripts/clientUtils.js | 228 ++++++++++++++++++++++++++++++++ src/scripts/site.js | 254 ++++++------------------------------ 4 files changed, 266 insertions(+), 225 deletions(-) create mode 100644 src/scripts/clientUtils.js diff --git a/package.json b/package.json index bd2605372c..7326dfa1f4 100644 --- a/package.json +++ b/package.json @@ -288,6 +288,7 @@ "src/scripts/alphanumericshortcuts.js", "src/scripts/autoBackdrops.js", "src/scripts/browser.js", + "src/scripts/clientUtils.js", "src/scripts/datetime.js", "src/scripts/deleteHelper.js", "src/scripts/dfnshelper.js", diff --git a/src/components/appRouter.js b/src/components/appRouter.js index e7b697daf4..9be762fc8f 100644 --- a/src/components/appRouter.js +++ b/src/components/appRouter.js @@ -485,13 +485,6 @@ define(['loading', 'globalize', 'events', 'viewManager', 'skinManager', 'backdro return (page.len || 0) > 0; } - function showDirect(path) { - return new Promise(function(resolve, reject) { - resolveOnNextShow = resolve; - page.show(baseUrl() + path); - }); - } - function show(path, options) { if (path.indexOf('/') !== 0 && path.indexOf('://') === -1) { path = '/' + path; @@ -625,7 +618,6 @@ define(['loading', 'globalize', 'events', 'viewManager', 'skinManager', 'backdro appRouter.param = param; appRouter.back = back; appRouter.show = show; - appRouter.showDirect = showDirect; appRouter.start = start; appRouter.baseUrl = baseUrl; appRouter.canGoBack = canGoBack; diff --git a/src/scripts/clientUtils.js b/src/scripts/clientUtils.js new file mode 100644 index 0000000000..b576f0504e --- /dev/null +++ b/src/scripts/clientUtils.js @@ -0,0 +1,228 @@ +export function getCurrentUser() { + return window.ApiClient.getCurrentUser(false); +} + +//TODO: investigate url prefix support for serverAddress function +export function serverAddress() { + if (AppInfo.isNativeApp) { + var apiClient = window.ApiClient; + + if (apiClient) { + return apiClient.serverAddress(); + } + + return null; + } + + var urlLower = window.location.href.toLowerCase(); + var index = urlLower.lastIndexOf('/web'); + + if (index != -1) { + return urlLower.substring(0, index); + } + + var loc = window.location; + var address = loc.protocol + '//' + loc.hostname; + + if (loc.port) { + address += ':' + loc.port; + } + + return address; +} + +export function getCurrentUserId() { + var apiClient = window.ApiClient; + + if (apiClient) { + return apiClient.getCurrentUserId(); + } + + return null; +} + +export function onServerChanged(userId, accessToken, apiClient) { + apiClient = apiClient || window.ApiClient; + window.ApiClient = apiClient; +} + +export function logout() { + ConnectionManager.logout().then(function () { + var loginPage; + + if (AppInfo.isNativeApp) { + loginPage = 'selectserver.html'; + window.ApiClient = null; + } else { + loginPage = 'login.html'; + } + + navigate(loginPage); + }); +} + +export function getConfigurationPageUrl(name) { + return 'configurationpage?name=' + encodeURIComponent(name); +} + +export function getConfigurationResourceUrl(name) { + if (AppInfo.isNativeApp) { + return ApiClient.getUrl('web/ConfigurationPage', { + name: name + }); + } + + return getConfigurationPageUrl(name); +} + +export function navigate(url, preserveQueryString) { + if (!url) { + throw new Error('url cannot be null or empty'); + } + + var queryString = getWindowLocationSearch(); + + if (preserveQueryString && queryString) { + url += queryString; + } + + return new Promise(function (resolve, reject) { + require(['appRouter'], function (appRouter) { + return appRouter.show(url).then(resolve, reject); + }); + }); +} + +export function processPluginConfigurationUpdateResult() { + require(['loading', 'toast'], function (loading, toast) { + loading.hide(); + toast.default(Globalize.translate('MessageSettingsSaved')); + }); +} + +export function processServerConfigurationUpdateResult(result) { + require(['loading', 'toast'], function (loading, toast) { + loading.hide(); + toast.default(Globalize.translate('MessageSettingsSaved')); + }); +} + +export function processErrorResponse(response) { + require(['loading'], function (loading) { + loading.hide(); + }); + + var status = '' + response.status; + + if (response.statusText) { + status = response.statusText; + } + + alert({ + title: status, + message: response.headers ? response.headers.get('X-Application-Error-Code') : null + }); +} + +export function alert(options) { + if (typeof options == 'string') { + return void require(['toast'], function (toast) { + toast.default({ + text: options + }); + }); + } + + require(['alert'], function (alert) { + alert.default({ + title: options.title || Globalize.translate('HeaderAlert'), + text: options.message + }).then(options.callback || function () {}); + }); +} + +export function capabilities(appHost) { + var capabilities = { + PlayableMediaTypes: ['Audio', 'Video'], + SupportedCommands: ['MoveUp', 'MoveDown', 'MoveLeft', 'MoveRight', 'PageUp', 'PageDown', 'PreviousLetter', 'NextLetter', 'ToggleOsd', 'ToggleContextMenu', 'Select', 'Back', 'SendKey', 'SendString', 'GoHome', 'GoToSettings', 'VolumeUp', 'VolumeDown', 'Mute', 'Unmute', 'ToggleMute', 'SetVolume', 'SetAudioStreamIndex', 'SetSubtitleStreamIndex', 'DisplayContent', 'GoToSearch', 'DisplayMessage', 'SetRepeatMode', 'SetShuffleQueue', 'ChannelUp', 'ChannelDown', 'PlayMediaSource', 'PlayTrailers'], + SupportsPersistentIdentifier: self.appMode === 'cordova' || self.appMode === 'android', + SupportsMediaControl: true + }; + appHost.getPushTokenInfo(); + return capabilities = Object.assign(capabilities, appHost.getPushTokenInfo()); +} + +export function selectServer() { + if (window.NativeShell && typeof window.NativeShell.selectServer === 'function') { + window.NativeShell.selectServer(); + } else { + navigate('selectserver.html'); + } +} + +export function hideLoadingMsg() { + 'use strict'; + require(['loading'], function(loading) { + loading.hide(); + }); +} + +export function showLoadingMsg() { + 'use strict'; + require(['loading'], function(loading) { + loading.show(); + }); +} + +export function confirm(message, title, callback) { + 'use strict'; + require(['confirm'], function(confirm) { + confirm(message, title).then(function() { + callback(!0); + }).catch(function() { + callback(!1); + }); + }); +} + +// This is used in plugins and templates, so keep it defined for now. +// TODO: Remove once plugins don't need it +window.Dashboard = { + alert, + capabilities, + confirm, + getConfigurationPageUrl, + getConfigurationResourceUrl, + getCurrentUser, + getCurrentUserId, + hideLoadingMsg, + logout, + navigate, + onServerChanged, + processErrorResponse, + processPluginConfigurationUpdateResult, + processServerConfigurationUpdateResult, + selectServer, + serverAddress, + showLoadingMsg +}; + +export default { + alert, + capabilities, + confirm, + getConfigurationPageUrl, + getConfigurationResourceUrl, + getCurrentUser, + getCurrentUserId, + hideLoadingMsg, + logout, + navigate, + onServerChanged, + processErrorResponse, + processPluginConfigurationUpdateResult, + processServerConfigurationUpdateResult, + selectServer, + serverAddress, + showLoadingMsg +}; diff --git a/src/scripts/site.js b/src/scripts/site.js index aa74411af4..02e24a8b46 100644 --- a/src/scripts/site.js +++ b/src/scripts/site.js @@ -1,4 +1,4 @@ -function getWindowLocationSearch(win) { +window.getWindowLocationSearch = function(win) { 'use strict'; var search = (win || window).location.search; @@ -12,9 +12,9 @@ function getWindowLocationSearch(win) { } return search || ''; -} +}; -window.getParameterByName = function (name, url) { +window.getParameterByName = function(name, url) { 'use strict'; name = name.replace(/[\[]/, '\\[').replace(/[\]]/, '\\]'); @@ -29,7 +29,7 @@ window.getParameterByName = function (name, url) { return decodeURIComponent(results[1].replace(/\+/g, ' ')); }; -function pageClassOn(eventName, className, fn) { +window.pageClassOn = function(eventName, className, fn) { 'use strict'; document.addEventListener(eventName, function (event) { @@ -39,7 +39,7 @@ function pageClassOn(eventName, className, fn) { fn.call(target, event); } }); -} +}; window.pageIdOn = function(eventName, id, fn) { 'use strict'; @@ -53,187 +53,6 @@ window.pageIdOn = function(eventName, id, fn) { }); }; -var Dashboard = { - getCurrentUser: function () { - return window.ApiClient.getCurrentUser(false); - }, - - //TODO: investigate url prefix support for serverAddress function - serverAddress: function () { - if (AppInfo.isNativeApp) { - var apiClient = window.ApiClient; - - if (apiClient) { - return apiClient.serverAddress(); - } - - return null; - } - - var urlLower = window.location.href.toLowerCase(); - var index = urlLower.lastIndexOf('/web'); - - if (index != -1) { - return urlLower.substring(0, index); - } - - var loc = window.location; - var address = loc.protocol + '//' + loc.hostname; - - if (loc.port) { - address += ':' + loc.port; - } - - return address; - }, - getCurrentUserId: function () { - var apiClient = window.ApiClient; - - if (apiClient) { - return apiClient.getCurrentUserId(); - } - - return null; - }, - onServerChanged: function (userId, accessToken, apiClient) { - apiClient = apiClient || window.ApiClient; - window.ApiClient = apiClient; - }, - logout: function () { - ConnectionManager.logout().then(function () { - var loginPage; - - if (AppInfo.isNativeApp) { - loginPage = 'selectserver.html'; - window.ApiClient = null; - } else { - loginPage = 'login.html'; - } - - Dashboard.navigate(loginPage); - }); - }, - getConfigurationPageUrl: function (name) { - return 'configurationpage?name=' + encodeURIComponent(name); - }, - getConfigurationResourceUrl: function (name) { - if (AppInfo.isNativeApp) { - return ApiClient.getUrl('web/ConfigurationPage', { - name: name - }); - } - - return Dashboard.getConfigurationPageUrl(name); - }, - navigate: function (url, preserveQueryString) { - if (!url) { - throw new Error('url cannot be null or empty'); - } - - var queryString = getWindowLocationSearch(); - - if (preserveQueryString && queryString) { - url += queryString; - } - - return new Promise(function (resolve, reject) { - require(['appRouter'], function (appRouter) { - return appRouter.show(url).then(resolve, reject); - }); - }); - }, - navigate_direct: function (path) { - return new Promise(function (resolve, reject) { - require(['appRouter'], function (appRouter) { - return appRouter.showDirect(path).then(resolve, reject); - }); - }); - }, - processPluginConfigurationUpdateResult: function () { - require(['loading', 'toast'], function (loading, toast) { - loading.hide(); - toast.default(Globalize.translate('MessageSettingsSaved')); - }); - }, - processServerConfigurationUpdateResult: function (result) { - require(['loading', 'toast'], function (loading, toast) { - loading.hide(); - toast.default(Globalize.translate('MessageSettingsSaved')); - }); - }, - processErrorResponse: function (response) { - require(['loading'], function (loading) { - loading.hide(); - }); - - var status = '' + response.status; - - if (response.statusText) { - status = response.statusText; - } - - Dashboard.alert({ - title: status, - message: response.headers ? response.headers.get('X-Application-Error-Code') : null - }); - }, - alert: function (options) { - if (typeof options == 'string') { - return void require(['toast'], function (toast) { - toast.default({ - text: options - }); - }); - } - - require(['alert'], function (alert) { - alert.default({ - title: options.title || Globalize.translate('HeaderAlert'), - text: options.message - }).then(options.callback || function () {}); - }); - }, - capabilities: function (appHost) { - var capabilities = { - PlayableMediaTypes: ['Audio', 'Video'], - SupportedCommands: ['MoveUp', 'MoveDown', 'MoveLeft', 'MoveRight', 'PageUp', 'PageDown', 'PreviousLetter', 'NextLetter', 'ToggleOsd', 'ToggleContextMenu', 'Select', 'Back', 'SendKey', 'SendString', 'GoHome', 'GoToSettings', 'VolumeUp', 'VolumeDown', 'Mute', 'Unmute', 'ToggleMute', 'SetVolume', 'SetAudioStreamIndex', 'SetSubtitleStreamIndex', 'DisplayContent', 'GoToSearch', 'DisplayMessage', 'SetRepeatMode', 'SetShuffleQueue', 'ChannelUp', 'ChannelDown', 'PlayMediaSource', 'PlayTrailers'], - SupportsPersistentIdentifier: self.appMode === 'cordova' || self.appMode === 'android', - SupportsMediaControl: true - }; - appHost.getPushTokenInfo(); - return capabilities = Object.assign(capabilities, appHost.getPushTokenInfo()); - }, - selectServer: function () { - if (window.NativeShell && typeof window.NativeShell.selectServer === 'function') { - window.NativeShell.selectServer(); - } else { - Dashboard.navigate('selectserver.html'); - } - }, - hideLoadingMsg: function() { - 'use strict'; - require(['loading'], function(loading) { - loading.hide(); - }); - }, - showLoadingMsg: function() { - 'use strict'; - require(['loading'], function(loading) { - loading.show(); - }); - }, - confirm: function(message, title, callback) { - 'use strict'; - require(['confirm'], function(confirm) { - confirm(message, title).then(function() { - callback(!0); - }).catch(function() { - callback(!1); - }); - }); - } -}; - var AppInfo = {}; function initClient() { @@ -289,7 +108,7 @@ function initClient() { if (!AppInfo.isNativeApp) { console.debug('loading ApiClient singleton'); - return require(['apiclient'], function (apiClientFactory) { + return require(['apiclient', 'clientUtils'], function (apiClientFactory, clientUtils) { console.debug('creating ApiClient singleton'); var apiClient = new apiClientFactory(Dashboard.serverAddress(), apphost.appName(), apphost.appVersion(), apphost.deviceName(), apphost.deviceId()); @@ -376,36 +195,12 @@ function initClient() { } } - function initRequireWithBrowser() { - var componentsPath = getComponentsPath(); - var scriptsPath = getScriptsPath(); - - define('filesystem', [scriptsPath + '/filesystem'], returnFirstDependency); - - define('lazyLoader', [componentsPath + '/lazyLoader/lazyLoaderIntersectionObserver'], returnFirstDependency); - define('shell', [scriptsPath + '/shell'], returnFirstDependency); - - define('alert', [componentsPath + '/alert'], returnFirstDependency); - - defineResizeObserver(); - - define('dialog', [componentsPath + '/dialog/dialog'], returnFirstDependency); - - define('confirm', [componentsPath + '/confirm/confirm'], returnFirstDependency); - - define('prompt', [componentsPath + '/prompt/prompt'], returnFirstDependency); - - define('loading', [componentsPath + '/loading/loading'], returnFirstDependency); - define('multi-download', [scriptsPath + '/multiDownload'], returnFirstDependency); - define('fileDownloader', [scriptsPath + '/fileDownloader'], returnFirstDependency); - - define('castSenderApiLoader', [componentsPath + '/castSenderApi'], returnFirstDependency); - } - function init() { define('livetvcss', ['css!assets/css/livetv.css'], returnFirstDependency); define('detailtablecss', ['css!assets/css/detailtable.css'], returnFirstDependency); + require(['clientUtils']); + var promises = []; if (!window.fetch) { promises.push(require(['fetch'])); @@ -605,7 +400,29 @@ function initClient() { } function onWebComponentsReady() { - initRequireWithBrowser(); + var componentsPath = getComponentsPath(); + var scriptsPath = getScriptsPath(); + + define('filesystem', [scriptsPath + '/filesystem'], returnFirstDependency); + + define('lazyLoader', [componentsPath + '/lazyLoader/lazyLoaderIntersectionObserver'], returnFirstDependency); + define('shell', [scriptsPath + '/shell'], returnFirstDependency); + + define('alert', [componentsPath + '/alert'], returnFirstDependency); + + defineResizeObserver(); + + define('dialog', [componentsPath + '/dialog/dialog'], returnFirstDependency); + + define('confirm', [componentsPath + '/confirm/confirm'], returnFirstDependency); + + define('prompt', [componentsPath + '/prompt/prompt'], returnFirstDependency); + + define('loading', [componentsPath + '/loading/loading'], returnFirstDependency); + define('multi-download', [scriptsPath + '/multiDownload'], returnFirstDependency); + define('fileDownloader', [scriptsPath + '/fileDownloader'], returnFirstDependency); + + define('castSenderApiLoader', [componentsPath + '/castSenderApi'], returnFirstDependency); if (self.appMode === 'cordova' || self.appMode === 'android' || self.appMode === 'standalone') { AppInfo.isNativeApp = true; @@ -617,7 +434,7 @@ function initClient() { var localApiClient; let promise; - (function () { + function initRequireJs() { var urlArgs = 'v=' + (window.dashboardVersion || new Date().getDate()); var bowerPath = getBowerPath(); @@ -648,7 +465,8 @@ function initClient() { nowPlayingHelper: componentsPath + '/playback/nowplayinghelper', pluginManager: componentsPath + '/pluginManager', packageManager: componentsPath + '/packageManager', - screensaverManager: componentsPath + '/screensavermanager' + screensaverManager: componentsPath + '/screensavermanager', + clientUtils: scriptsPath + '/clientUtils' }; requirejs.onError = onRequireJsError; @@ -1106,7 +924,9 @@ function initClient() { appRouter.showItem = showItem; return appRouter; }); - })(); + } + + initRequireJs(); promise.then(onWebComponentsReady); } From 23be95e450d4873eb5a938cfe3884ec60f083249 Mon Sep 17 00:00:00 2001 From: Cameron Date: Sat, 8 Aug 2020 17:51:10 +0100 Subject: [PATCH 100/301] Update src/components/remotecontrol/remotecontrol.js Co-authored-by: Dmitry Lyzo <56478732+dmitrylyzo@users.noreply.github.com> --- src/components/remotecontrol/remotecontrol.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/components/remotecontrol/remotecontrol.js b/src/components/remotecontrol/remotecontrol.js index b9f33b4e1a..6048c918c7 100644 --- a/src/components/remotecontrol/remotecontrol.js +++ b/src/components/remotecontrol/remotecontrol.js @@ -693,7 +693,7 @@ export default function () { import('playlistEditor').then(({ default: playlistEditor }) => { getSaveablePlaylistItems().then(function (items) { const serverId = items.length ? items[0].ServerId : ApiClient.serverId(); - new playlistEditor.showEditor({ + new playlistEditor({ items: items.map(function (i) { return i.Id; }), From be3dc8c697c2c34d6e8b2c0d046a6a59799eb7b2 Mon Sep 17 00:00:00 2001 From: Cameron Date: Sat, 8 Aug 2020 18:41:23 +0100 Subject: [PATCH 101/301] Update src/controllers/home.js Co-authored-by: Dmitry Lyzo <56478732+dmitrylyzo@users.noreply.github.com> --- src/controllers/home.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/controllers/home.js b/src/controllers/home.js index 1a4b315b09..72e326e46b 100644 --- a/src/controllers/home.js +++ b/src/controllers/home.js @@ -56,7 +56,7 @@ class HomeView extends TabbedView { let controller = instance.tabControllers[index]; if (!controller) { - controller = new controllerFactory.default(instance.view.querySelector(".tabContent[data-index='" + index + "']"), instance.params); + controller = new controllerFactory(instance.view.querySelector(".tabContent[data-index='" + index + "']"), instance.params); instance.tabControllers[index] = controller; } From af2fab85d12f53a16a8e98b30e03ae7166ad7794 Mon Sep 17 00:00:00 2001 From: MrTimscampi Date: Sun, 26 Jul 2020 22:25:54 +0200 Subject: [PATCH 102/301] Migrate add, installed, available plugin pages to ES6 --- package.json | 3 + .../dashboard/plugins/add/index.js | 233 ++++++------ .../dashboard/plugins/available/index.js | 248 ++++++------ .../dashboard/plugins/installed/index.js | 357 +++++++++--------- src/strings/en-us.json | 2 + 5 files changed, 426 insertions(+), 417 deletions(-) diff --git a/package.json b/package.json index 54d5f28189..467dc3b171 100644 --- a/package.json +++ b/package.json @@ -209,6 +209,9 @@ "src/controllers/dashboard/notifications/notification.js", "src/controllers/dashboard/notifications/notifications.js", "src/controllers/dashboard/playback.js", + "src/controllers/dashboard/plugins/add/index.js", + "src/controllers/dashboard/plugins/installed/index.js", + "src/controllers/dashboard/plugins/available/index.js", "src/controllers/dashboard/plugins/repositories/index.js", "src/controllers/dashboard/scheduledtasks/scheduledtask.js", "src/controllers/dashboard/scheduledtasks/scheduledtasks.js", diff --git a/src/controllers/dashboard/plugins/add/index.js b/src/controllers/dashboard/plugins/add/index.js index 6c666b4646..8393970e76 100644 --- a/src/controllers/dashboard/plugins/add/index.js +++ b/src/controllers/dashboard/plugins/add/index.js @@ -1,143 +1,148 @@ -define(['jQuery', 'loading', 'libraryMenu', 'globalize', 'connectionManager', 'emby-button'], function ($, loading, libraryMenu, globalize, connectionManager) { - 'use strict'; +import $ from 'jQuery'; +import loading from 'loading'; +import globalize from 'globalize'; +import 'emby-button'; - loading = loading.default || loading; +function populateHistory(packageInfo, page) { + let html = ''; + const length = Math.min(packageInfo.versions.length, 10); - function populateHistory(packageInfo, page) { - var html = ''; - var length = Math.min(packageInfo.versions.length, 10); - - for (var i = 0; i < length; i++) { - var version = packageInfo.versions[i]; - html += '

    ' + version.version + '

    '; - html += '
    ' + version.changelog + '
    '; - } - - $('#revisionHistory', page).html(html); + for (let i = 0; i < length; i++) { + let version = packageInfo.versions[i]; + html += '

    ' + version.version + '

    '; + html += '
    ' + version.changelog + '
    '; } - function populateVersions(packageInfo, page, installedPlugin) { - var html = ''; + $('#revisionHistory', page).html(html); +} - for (var i = 0; i < packageInfo.versions.length; i++) { - var version = packageInfo.versions[i]; - html += ''; - } +function populateVersions(packageInfo, page, installedPlugin) { + let html = ''; - var selectmenu = $('#selectVersion', page).html(html); - - if (!installedPlugin) { - $('#pCurrentVersion', page).hide().html(''); - } - - var packageVersion = packageInfo.versions[0]; - if (packageVersion) { - selectmenu.val(packageVersion.version); - } + for (let i = 0; i < packageInfo.versions.length; i++) { + const version = packageInfo.versions[i]; + html += ''; } - function renderPackage(pkg, installedPlugins, page) { - var installedPlugin = installedPlugins.filter(function (ip) { - return ip.Name == pkg.name; - })[0]; + const selectmenu = $('#selectVersion', page).html(html); - populateVersions(pkg, page, installedPlugin); - populateHistory(pkg, page); - - $('.pluginName', page).html(pkg.name); - $('#btnInstallDiv', page).removeClass('hide'); - $('#pSelectVersion', page).removeClass('hide'); - - if (pkg.overview) { - $('#overview', page).show().html(pkg.overview); - } else { - $('#overview', page).hide(); - } - - $('#description', page).html(pkg.description); - $('#developer', page).html(pkg.owner); - - if (installedPlugin) { - var currentVersionText = globalize.translate('MessageYouHaveVersionInstalled', '' + installedPlugin.Version + ''); - $('#pCurrentVersion', page).show().html(currentVersionText); - } else { - $('#pCurrentVersion', page).hide().html(''); - } - - loading.hide(); + if (!installedPlugin) { + $('#pCurrentVersion', page).hide().html(''); } - function alertText(options) { - require(['alert'], function ({default: alert}) { - alert(options); - }); + const packageVersion = packageInfo.versions[0]; + if (packageVersion) { + selectmenu.val(packageVersion.version); + } +} + +function renderPackage(pkg, installedPlugins, page) { + const installedPlugin = installedPlugins.filter(function (ip) { + return ip.Name == pkg.name; + })[0]; + + populateVersions(pkg, page, installedPlugin); + populateHistory(pkg, page); + + $('.pluginName', page).html(pkg.name); + $('#btnInstallDiv', page).removeClass('hide'); + $('#pSelectVersion', page).removeClass('hide'); + + if (pkg.overview) { + $('#overview', page).show().html(pkg.overview); + } else { + $('#overview', page).hide(); } - function performInstallation(page, name, guid, version) { - var developer = $('#developer', page).html().toLowerCase(); + $('#description', page).html(pkg.description); + $('#developer', page).html(pkg.owner); - var alertCallback = function () { - loading.show(); - page.querySelector('#btnInstall').disabled = true; - ApiClient.installPlugin(name, guid, version).then(function () { - loading.hide(); - alertText(globalize.translate('MessagePluginInstalled')); - }); - }; + if (installedPlugin) { + const currentVersionText = globalize.translate('MessageYouHaveVersionInstalled', '' + installedPlugin.Version + ''); + $('#pCurrentVersion', page).show().html(currentVersionText); + } else { + $('#pCurrentVersion', page).hide().html(''); + } - if (developer !== 'jellyfin') { + loading.hide(); +} + +function alertText(options) { + import('alert').then(({default: alert}) => { + alert(options); + }); +} + +function performInstallation(page, name, guid, version) { + const developer = $('#developer', page).html().toLowerCase(); + + const alertCallback = function () { + loading.show(); + page.querySelector('#btnInstall').disabled = true; + ApiClient.installPlugin(name, guid, version).then(() => { loading.hide(); - var msg = globalize.translate('MessagePluginInstallDisclaimer'); - msg += '
    '; - msg += '
    '; - msg += globalize.translate('PleaseConfirmPluginInstallation'); + alertText(globalize.translate('MessagePluginInstalled')); + }).catch(() => { + alertText(globalize.translate('MessagePluginIntallError')); + }); + }; - require(['confirm'], function (confirm) { - confirm.default(msg, globalize.translate('HeaderConfirmPluginInstallation')).then(function () { - alertCallback(); - }, function () { - console.debug('plugin not installed'); - }); + if (developer !== 'jellyfin') { + loading.hide(); + let msg = globalize.translate('MessagePluginInstallDisclaimer'); + msg += '
    '; + msg += '
    '; + msg += globalize.translate('PleaseConfirmPluginInstallation'); + + import('confirm').then(({default: confirm}) => { + confirm.default(msg, globalize.translate('HeaderConfirmPluginInstallation')).then(function () { + alertCallback(); + }).catch(() => { + console.debug('plugin not installed'); }); - } else { - alertCallback(); - } + }); + } else { + alertCallback(); } +} - return function (view, params) { - $('.addPluginForm', view).on('submit', function () { - loading.show(); - var page = $(this).parents('#addPluginPage')[0]; - var name = params.name; - var guid = params.guid; - ApiClient.getInstalledPlugins().then(function (plugins) { - var installedPlugin = plugins.filter(function (plugin) { - return plugin.Name == name; - })[0]; +export default function(view, params) { + $('.addPluginForm', view).on('submit', function () { + loading.show(); + const page = $(this).parents('#addPluginPage')[0]; + const name = params.name; + const guid = params.guid; + ApiClient.getInstalledPlugins().then(function (plugins) { + const installedPlugin = plugins.filter(function (plugin) { + return plugin.Name == name; + })[0]; - var version = $('#selectVersion', page).val(); - if (installedPlugin && installedPlugin.Version === version) { + const version = $('#selectVersion', page).val(); + if (installedPlugin) { + if (installedPlugin.Version === version) { loading.hide(); Dashboard.alert({ message: globalize.translate('MessageAlreadyInstalled'), title: globalize.translate('HeaderPluginInstallation') }); - } else { - performInstallation(page, name, guid, version); } - }); - return false; + } else { + performInstallation(page, name, guid, version); + } + }).catch(() => { + alertText(globalize.translate('MessageGetInstalledPluginsError')); }); - view.addEventListener('viewshow', function () { - var page = this; - loading.show(); - var name = params.name; - var guid = params.guid; - var promise1 = ApiClient.getPackageInfo(name, guid); - var promise2 = ApiClient.getInstalledPlugins(); - Promise.all([promise1, promise2]).then(function (responses) { - renderPackage(responses[0], responses[1], page); - }); + return false; + }); + view.addEventListener('viewshow', function () { + const page = this; + loading.show(); + const name = params.name; + const guid = params.guid; + const promise1 = ApiClient.getPackageInfo(name, guid); + const promise2 = ApiClient.getInstalledPlugins(); + Promise.all([promise1, promise2]).then(function (responses) { + renderPackage(responses[0], responses[1], page); }); - }; -}); + }); +} diff --git a/src/controllers/dashboard/plugins/available/index.js b/src/controllers/dashboard/plugins/available/index.js index e38365ef55..aa25320d5c 100644 --- a/src/controllers/dashboard/plugins/available/index.js +++ b/src/controllers/dashboard/plugins/available/index.js @@ -1,143 +1,141 @@ -define(['loading', 'libraryMenu', 'globalize', 'cardStyle', 'emby-button', 'emby-checkbox', 'emby-select'], function (loading, libraryMenu, globalize) { - 'use strict'; +import loading from 'loading'; +import libraryMenu from 'libraryMenu'; +import globalize from 'globalize'; +import 'cardStyle'; +import 'emby-button'; +import 'emby-checkbox'; +import 'emby-select'; - loading = loading.default || loading; - - function reloadList(page) { - loading.show(); - var promise1 = ApiClient.getAvailablePlugins(); - var promise2 = ApiClient.getInstalledPlugins(); - Promise.all([promise1, promise2]).then(function (responses) { - populateList({ - catalogElement: page.querySelector('#pluginTiles'), - noItemsElement: page.querySelector('#noPlugins'), - availablePlugins: responses[0], - installedPlugins: responses[1] - }); +function reloadList(page) { + loading.show(); + const promise1 = ApiClient.getAvailablePlugins(); + const promise2 = ApiClient.getInstalledPlugins(); + Promise.all([promise1, promise2]).then(function (responses) { + populateList({ + catalogElement: page.querySelector('#pluginTiles'), + noItemsElement: page.querySelector('#noPlugins'), + availablePlugins: responses[0], + installedPlugins: responses[1] }); + }); +} + +function getHeaderText(category) { + category = category.replace(' ', ''); + if ('Channel' === category) { + category = 'Channels'; + } else if ('Theme' === category) { + category = 'Themes'; + } else if ('LiveTV' === category) { + category = 'HeaderLiveTV'; + } else if ('ScreenSaver' === category) { + category = 'HeaderScreenSavers'; } - function getHeaderText(category) { - category = category.replace(' ', ''); - if (category === 'Channel') { - category = 'Channels'; - } else if (category === 'Theme') { - category = 'Themes'; - } else if (category === 'LiveTV') { - category = 'HeaderLiveTV'; - } else if (category === 'ScreenSaver') { - category = 'HeaderScreenSavers'; + return globalize.translate(category); +} + +function populateList(options) { + const availablePlugins = options.availablePlugins; + const installedPlugins = options.installedPlugins; + + availablePlugins.forEach(function (plugin, index, array) { + plugin.category = plugin.category || 'General'; + plugin.categoryDisplayName = getHeaderText(plugin.category); + array[index] = plugin; + }); + + availablePlugins.sort(function (a, b) { + if (a.category > b.category) { + return 1; + } else if (b.category > a.category) { + return -1; } + if (a.name > b.name) { + return 1; + } else if (b.name > a.name) { + return -1; + } + return 0; + }); - return globalize.translate(category); - } + let currentCategory = null; + let html = ''; - function populateList(options) { - var availablePlugins = options.availablePlugins; - var installedPlugins = options.installedPlugins; - - availablePlugins.forEach(function (plugin, index, array) { - plugin.category = plugin.category || 'General'; - plugin.categoryDisplayName = getHeaderText(plugin.category); - array[index] = plugin; - }); - - availablePlugins.sort(function (a, b) { - if (a.category > b.category) { - return 1; - } else if (b.category > a.category) { - return -1; + for (let i = 0; i < availablePlugins.length; i++) { + const plugin = availablePlugins[i]; + const category = plugin.categoryDisplayName; + if (category != currentCategory) { + if (currentCategory) { + html += '
    '; + html += '
    '; } - if (a.name > b.name) { - return 1; - } else if (b.name > a.name) { - return -1; - } - return 0; - }); - - var currentCategory = null; - var html = ''; - - for (var i = 0; i < availablePlugins.length; i++) { - var plugin = availablePlugins[i]; - var category = plugin.categoryDisplayName; - if (category != currentCategory) { - if (currentCategory) { - html += '
    '; - html += '
    '; - } - html += '
    '; - html += '

    ' + category + '

    '; - html += '
    '; - currentCategory = category; - } - html += getPluginHtml(plugin, options, installedPlugins); + html += '
    '; + html += '

    ' + category + '

    '; + html += '
    '; + currentCategory = category; } - html += '
    '; - html += '
    '; + html += getPluginHtml(plugin, options, installedPlugins); + } + html += '
    '; + html += '
    '; - if (!availablePlugins.length && options.noItemsElement) { - options.noItemsElement.classList.remove('hide'); - } - - options.catalogElement.innerHTML = html; - loading.hide(); + if (!availablePlugins.length && options.noItemsElement) { + options.noItemsElement.classList.remove('hide'); } - function getPluginHtml(plugin, options, installedPlugins) { - var html = ''; - var href = plugin.externalUrl ? plugin.externalUrl : 'addplugin.html?name=' + encodeURIComponent(plugin.name) + '&guid=' + plugin.guid; + options.catalogElement.innerHTML = html; + loading.hide(); +} - if (options.context) { - href += '&context=' + options.context; - } +function getPluginHtml(plugin, options, installedPlugins) { + let html = ''; + let href = plugin.externalUrl ? plugin.externalUrl : 'addplugin.html?name=' + encodeURIComponent(plugin.name) + '&guid=' + plugin.guid; - var target = plugin.externalUrl ? ' target="_blank"' : ''; - html += "
    "; - html += '
    '; - html += '
    '; - html += '
    '; - html += ''; - html += ''; - html += ''; - html += '
    '; - html += '
    '; - html += "
    "; - html += plugin.name; - html += '
    '; - var installedPlugin = installedPlugins.filter(function (ip) { - return ip.Id == plugin.guid; - })[0]; - html += "
    "; - html += installedPlugin ? globalize.translate('LabelVersionInstalled', installedPlugin.Version) : ' '; - html += '
    '; - html += '
    '; - html += '
    '; - return html += '
    '; + if (options.context) { + href += '&context=' + options.context; } - function getTabs() { - return [{ - href: 'installedplugins.html', - name: globalize.translate('TabMyPlugins') - }, { - href: 'availableplugins.html', - name: globalize.translate('TabCatalog') - }, { - href: 'repositories.html', - name: globalize.translate('TabRepositories') - }]; - } + const target = plugin.externalUrl ? ' target="_blank"' : ''; + html += "
    "; + html += '
    '; + html += '
    '; + html += '
    '; + html += ''; + html += ''; + html += ''; + html += '
    '; + html += '
    '; + html += "
    "; + html += plugin.name; + html += '
    '; + const installedPlugin = installedPlugins.filter(function (ip) { + return ip.Id == plugin.guid; + })[0]; + html += "
    "; + html += installedPlugin ? globalize.translate('LabelVersionInstalled', installedPlugin.Version) : ' '; + html += '
    '; + html += '
    '; + html += '
    '; + return html += '
    '; +} - window.PluginCatalog = { - renderCatalog: populateList - }; +function getTabs() { + return [{ + href: 'installedplugins.html', + name: globalize.translate('TabMyPlugins') + }, { + href: 'availableplugins.html', + name: globalize.translate('TabCatalog') + }, { + href: 'repositories.html', + name: globalize.translate('TabRepositories') + }]; +} - return function (view, params) { - view.addEventListener('viewshow', function () { - libraryMenu.setTabs('plugins', 1, getTabs); - reloadList(this); - }); - }; -}); +export default function (view) { + view.addEventListener('viewshow', function () { + libraryMenu.setTabs('plugins', 1, getTabs); + reloadList(this); + }); +} diff --git a/src/controllers/dashboard/plugins/installed/index.js b/src/controllers/dashboard/plugins/installed/index.js index 80577d227b..20cbe56928 100644 --- a/src/controllers/dashboard/plugins/installed/index.js +++ b/src/controllers/dashboard/plugins/installed/index.js @@ -1,192 +1,193 @@ -define(['loading', 'libraryMenu', 'dom', 'globalize', 'cardStyle', 'emby-button'], function (loading, libraryMenu, dom, globalize) { - 'use strict'; +import loading from 'loading'; +import libraryMenu from 'libraryMenu'; +import dom from 'dom'; +import globalize from 'globalize'; +import 'cardStyle'; +import 'emby-button'; - loading = loading.default || loading; +function deletePlugin(page, uniqueid, name) { + const msg = globalize.translate('UninstallPluginConfirmation', name); - function deletePlugin(page, uniqueid, name) { - var msg = globalize.translate('UninstallPluginConfirmation', name); - - require(['confirm'], function (confirm) { - confirm.default({ - title: globalize.translate('HeaderUninstallPlugin'), - text: msg, - primary: 'delete', - confirmText: globalize.translate('HeaderUninstallPlugin') - }).then(function () { - loading.show(); - ApiClient.uninstallPlugin(uniqueid).then(function () { - reloadList(page); - }); + import('confirm').then(({default: confirm}) => { + confirm.default({ + title: globalize.translate('UninstallPluginHeader'), + text: msg, + primary: 'delete', + confirmText: globalize.translate('UninstallPluginHeader') + }).then(function () { + loading.show(); + ApiClient.uninstallPlugin(uniqueid).then(function () { + reloadList(page); }); }); - } + }); +} - function showNoConfigurationMessage() { - Dashboard.alert({ - message: globalize.translate('MessageNoPluginConfiguration') - }); - } +function showNoConfigurationMessage() { + Dashboard.alert({ + message: globalize.translate('NoPluginConfigurationMessage') + }); +} - function showConnectMessage() { - Dashboard.alert({ - message: globalize.translate('MessagePluginConfigurationRequiresLocalAccess') - }); - } +function showConnectMessage() { + Dashboard.alert({ + message: globalize.translate('MessagePluginConfigurationRequiresLocalAccess') + }); +} - function getPluginCardHtml(plugin, pluginConfigurationPages) { - var configPage = pluginConfigurationPages.filter(function (pluginConfigurationPage) { - return pluginConfigurationPage.PluginId == plugin.Id; - })[0]; - var configPageUrl = configPage ? Dashboard.getConfigurationPageUrl(configPage.Name) : null; - var html = ''; - html += "
    "; - html += '
    '; - html += '
    '; - html += '
    '; - html += configPageUrl ? '' : ''; +function getPluginCardHtml(plugin, pluginConfigurationPages) { + const configPage = pluginConfigurationPages.filter(function (pluginConfigurationPage) { + return pluginConfigurationPage.PluginId == plugin.Id; + })[0]; + const configPageUrl = configPage ? Dashboard.getConfigurationPageUrl(configPage.Name) : null; + let html = ''; + html += "
    "; + html += '
    '; + html += '
    '; + html += '
    '; + html += configPageUrl ? '' : ''; + html += '
    '; + html += '
    '; + + if (configPage || plugin.CanUninstall) { + html += '
    '; + html += ''; html += '
    '; - html += '
    '; + } - if (configPage || plugin.CanUninstall) { - html += '
    '; - html += ''; - html += '
    '; + html += "
    "; + html += configPage && configPage.DisplayName ? configPage.DisplayName : plugin.Name; + html += '
    '; + html += "
    "; + html += plugin.Version; + html += '
    '; + html += '
    '; + html += '
    '; + html += '
    '; + return html; +} + +function renderPlugins(page, plugins) { + ApiClient.getJSON(ApiClient.getUrl('web/configurationpages') + '?pageType=PluginConfiguration').then(function (configPages) { + populateList(page, plugins, configPages); + }); +} + +function populateList(page, plugins, pluginConfigurationPages) { + plugins = plugins.sort(function (plugin1, plugin2) { + if (plugin1.Name > plugin2.Name) { + return 1; } - html += "
    "; - html += configPage && configPage.DisplayName ? configPage.DisplayName : plugin.Name; - html += '
    '; - html += "
    "; - html += plugin.Version; - html += '
    '; - html += '
    '; - html += '
    '; - html += '
    '; - return html; - } - - function renderPlugins(page, plugins) { - ApiClient.getJSON(ApiClient.getUrl('web/configurationpages') + '?pageType=PluginConfiguration').then(function (configPages) { - populateList(page, plugins, configPages); - }); - } - - function populateList(page, plugins, pluginConfigurationPages) { - plugins = plugins.sort(function (plugin1, plugin2) { - if (plugin1.Name > plugin2.Name) { - return 1; - } - - return -1; - }); - - var html = plugins.map(function (p) { - return getPluginCardHtml(p, pluginConfigurationPages); - }).join(''); - - var installedPluginsElement = page.querySelector('.installedPlugins'); - installedPluginsElement.removeEventListener('click', onInstalledPluginsClick); - installedPluginsElement.addEventListener('click', onInstalledPluginsClick); - - if (plugins.length) { - installedPluginsElement.classList.add('itemsContainer'); - installedPluginsElement.classList.add('vertical-wrap'); - } else { - html += '
    '; - html += '

    ' + globalize.translate('MessageNoPluginsInstalled') + '

    '; - html += '

    '; - html += globalize.translate('MessageBrowsePluginCatalog'); - html += '

    '; - html += '
    '; - } - - installedPluginsElement.innerHTML = html; - loading.hide(); - } - - function showPluginMenu(page, elem) { - var card = dom.parentWithClass(elem, 'card'); - var id = card.getAttribute('data-id'); - var name = card.getAttribute('data-name'); - var removable = card.getAttribute('data-removable'); - var configHref = card.querySelector('.cardContent').getAttribute('href'); - var menuItems = []; - - if (configHref) { - menuItems.push({ - name: globalize.translate('ButtonSettings'), - id: 'open', - icon: 'mode_edit' - }); - } - - if (removable === 'true') { - menuItems.push({ - name: globalize.translate('ButtonUninstall'), - id: 'delete', - icon: 'delete' - }); - } - - require(['actionsheet'], function (actionsheet) { - actionsheet.show({ - items: menuItems, - positionTo: elem, - callback: function (resultId) { - switch (resultId) { - case 'open': - Dashboard.navigate(configHref); - break; - case 'delete': - deletePlugin(page, id, name); - break; - } - } - }); - }); - } - - function reloadList(page) { - loading.show(); - ApiClient.getInstalledPlugins().then(function (plugins) { - renderPlugins(page, plugins); - }); - } - - function getTabs() { - return [{ - href: 'installedplugins.html', - name: globalize.translate('TabMyPlugins') - }, { - href: 'availableplugins.html', - name: globalize.translate('TabCatalog') - }, { - href: 'repositories.html', - name: globalize.translate('TabRepositories') - }]; - } - - function onInstalledPluginsClick(e) { - if (dom.parentWithClass(e.target, 'noConfigPluginCard')) { - showNoConfigurationMessage(); - } else if (dom.parentWithClass(e.target, 'connectModePluginCard')) { - showConnectMessage(); - } else { - var btnCardMenu = dom.parentWithClass(e.target, 'btnCardMenu'); - if (btnCardMenu) { - showPluginMenu(dom.parentWithClass(btnCardMenu, 'page'), btnCardMenu); - } - } - } - - pageIdOn('pageshow', 'pluginsPage', function () { - libraryMenu.setTabs('plugins', 0, getTabs); - reloadList(this); + return -1; }); - window.PluginsPage = { - renderPlugins: renderPlugins - }; + let html = plugins.map(function (p) { + return getPluginCardHtml(p, pluginConfigurationPages); + }).join(''); + + const installedPluginsElement = page.querySelector('.installedPlugins'); + installedPluginsElement.removeEventListener('click', onInstalledPluginsClick); + installedPluginsElement.addEventListener('click', onInstalledPluginsClick); + + if (plugins.length) { + installedPluginsElement.classList.add('itemsContainer'); + installedPluginsElement.classList.add('vertical-wrap'); + } else { + html += '
    '; + html += '

    ' + globalize.translate('MessageNoPluginsInstalled') + '

    '; + html += '

    '; + html += globalize.translate('BrowsePluginCatalogMessage'); + html += '

    '; + html += '
    '; + } + + installedPluginsElement.innerHTML = html; + loading.hide(); +} + +function showPluginMenu(page, elem) { + const card = dom.parentWithClass(elem, 'card'); + const id = card.getAttribute('data-id'); + const name = card.getAttribute('data-name'); + const removable = card.getAttribute('data-removable'); + const configHref = card.querySelector('.cardContent').getAttribute('href'); + const menuItems = []; + + if (configHref) { + menuItems.push({ + name: globalize.translate('ButtonSettings'), + id: 'open', + icon: 'mode_edit' + }); + } + + if (removable === 'true') { + menuItems.push({ + name: globalize.translate('ButtonUninstall'), + id: 'delete', + icon: 'delete' + }); + } + + import('actionsheet').then(({default: actionsheet}) => { + actionsheet.show({ + items: menuItems, + positionTo: elem, + callback: function (resultId) { + switch (resultId) { + case 'open': + Dashboard.navigate(configHref); + break; + case 'delete': + deletePlugin(page, id, name); + break; + } + } + }); + }); +} + +function reloadList(page) { + loading.show(); + ApiClient.getInstalledPlugins().then(function (plugins) { + renderPlugins(page, plugins); + }); +} + +function getTabs() { + return [{ + href: 'installedplugins.html', + name: globalize.translate('TabMyPlugins') + }, { + href: 'availableplugins.html', + name: globalize.translate('TabCatalog') + }, { + href: 'repositories.html', + name: globalize.translate('TabRepositories') + }]; +} + +function onInstalledPluginsClick(e) { + if (dom.parentWithClass(e.target, 'noConfigPluginCard')) { + showNoConfigurationMessage(); + } else if (dom.parentWithClass(e.target, 'connectModePluginCard')) { + showConnectMessage(); + } else { + const btnCardMenu = dom.parentWithClass(e.target, 'btnCardMenu'); + if (btnCardMenu) { + showPluginMenu(dom.parentWithClass(btnCardMenu, 'page'), btnCardMenu); + } + } +} + +pageIdOn('pageshow', 'pluginsPage', function () { + libraryMenu.setTabs('plugins', 0, getTabs); + reloadList(this); }); + +window.PluginsPage = { + renderPlugins: renderPlugins +}; diff --git a/src/strings/en-us.json b/src/strings/en-us.json index 4dffc49618..5c7e1e267d 100644 --- a/src/strings/en-us.json +++ b/src/strings/en-us.json @@ -1282,6 +1282,8 @@ "PleaseRestartServerName": "Please restart Jellyfin Server - {0}.", "PleaseSelectTwoItems": "Please select at least two items.", "MessagePluginInstalled": "The plugin has been successfully installed. Jellyfin Server will need to be restarted for changes to take effect.", + "MessagePluginIntallError": "An error occured while installing the plugin.", + "MessageGetInstalledPluginsError": "An error occured while getting the list of currently installed plugins.", "PreferEmbeddedTitlesOverFileNames": "Prefer embedded titles over filenames", "PreferEmbeddedTitlesOverFileNamesHelp": "This determines the default display title when no internet metadata or local metadata is available.", "PreferEmbeddedEpisodeInfosOverFileNamesHelp": "This uses the episode information from the embedded metadata if available.", From 3180a7a177e104106da5dd08b29c5bd9087252c8 Mon Sep 17 00:00:00 2001 From: MrTimscampi Date: Thu, 6 Aug 2020 23:02:00 +0200 Subject: [PATCH 103/301] Fix lint --- src/controllers/dashboard/plugins/available/index.js | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/src/controllers/dashboard/plugins/available/index.js b/src/controllers/dashboard/plugins/available/index.js index aa25320d5c..22b28e0f5a 100644 --- a/src/controllers/dashboard/plugins/available/index.js +++ b/src/controllers/dashboard/plugins/available/index.js @@ -22,13 +22,14 @@ function reloadList(page) { function getHeaderText(category) { category = category.replace(' ', ''); - if ('Channel' === category) { + // TODO: Replace with switch + if (category === 'Channel') { category = 'Channels'; - } else if ('Theme' === category) { + } else if (category === 'Theme') { category = 'Themes'; - } else if ('LiveTV' === category) { + } else if (category === 'LiveTV') { category = 'HeaderLiveTV'; - } else if ('ScreenSaver' === category) { + } else if (category === 'ScreenSaver') { category = 'HeaderScreenSavers'; } From 232ba8182ad28d506727d291a6cefbe42be27427 Mon Sep 17 00:00:00 2001 From: Julien Machiels Date: Fri, 7 Aug 2020 23:58:01 +0200 Subject: [PATCH 104/301] Update src/controllers/dashboard/plugins/installed/index.js Co-authored-by: Cameron --- src/controllers/dashboard/plugins/installed/index.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/controllers/dashboard/plugins/installed/index.js b/src/controllers/dashboard/plugins/installed/index.js index 20cbe56928..793adb70d2 100644 --- a/src/controllers/dashboard/plugins/installed/index.js +++ b/src/controllers/dashboard/plugins/installed/index.js @@ -25,7 +25,7 @@ function deletePlugin(page, uniqueid, name) { function showNoConfigurationMessage() { Dashboard.alert({ - message: globalize.translate('NoPluginConfigurationMessage') + message: globalize.translate('MessageNoPluginConfiguration') }); } From 5ccc24d8f54c8d178451a006190cc94e55dd05aa Mon Sep 17 00:00:00 2001 From: Julien Machiels Date: Fri, 7 Aug 2020 23:58:14 +0200 Subject: [PATCH 105/301] Update src/controllers/dashboard/plugins/installed/index.js Co-authored-by: Cameron --- src/controllers/dashboard/plugins/installed/index.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/controllers/dashboard/plugins/installed/index.js b/src/controllers/dashboard/plugins/installed/index.js index 793adb70d2..ed0bbdaa7b 100644 --- a/src/controllers/dashboard/plugins/installed/index.js +++ b/src/controllers/dashboard/plugins/installed/index.js @@ -99,7 +99,7 @@ function populateList(page, plugins, pluginConfigurationPages) { html += '
    '; html += '

    ' + globalize.translate('MessageNoPluginsInstalled') + '

    '; html += '

    '; - html += globalize.translate('BrowsePluginCatalogMessage'); + html += globalize.translate('MessageBrowsePluginCatalog'); html += '

    '; html += '
    '; } From 9c56306f05d20f03be14a7584a1d84596fbf6c09 Mon Sep 17 00:00:00 2001 From: Julien Machiels Date: Fri, 7 Aug 2020 23:58:21 +0200 Subject: [PATCH 106/301] Update src/controllers/dashboard/plugins/installed/index.js Co-authored-by: Cameron --- src/controllers/dashboard/plugins/installed/index.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/controllers/dashboard/plugins/installed/index.js b/src/controllers/dashboard/plugins/installed/index.js index ed0bbdaa7b..ef36ceb3d3 100644 --- a/src/controllers/dashboard/plugins/installed/index.js +++ b/src/controllers/dashboard/plugins/installed/index.js @@ -10,7 +10,7 @@ function deletePlugin(page, uniqueid, name) { import('confirm').then(({default: confirm}) => { confirm.default({ - title: globalize.translate('UninstallPluginHeader'), + title: globalize.translate('HeaderUninstallPlugin'), text: msg, primary: 'delete', confirmText: globalize.translate('UninstallPluginHeader') From 2cbcddd5daa3d5d55e967c2cb3a354786e24d557 Mon Sep 17 00:00:00 2001 From: Julien Machiels Date: Fri, 7 Aug 2020 23:58:30 +0200 Subject: [PATCH 107/301] Update src/controllers/dashboard/plugins/installed/index.js Co-authored-by: Cameron --- src/controllers/dashboard/plugins/installed/index.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/controllers/dashboard/plugins/installed/index.js b/src/controllers/dashboard/plugins/installed/index.js index ef36ceb3d3..e5f5b92413 100644 --- a/src/controllers/dashboard/plugins/installed/index.js +++ b/src/controllers/dashboard/plugins/installed/index.js @@ -13,7 +13,7 @@ function deletePlugin(page, uniqueid, name) { title: globalize.translate('HeaderUninstallPlugin'), text: msg, primary: 'delete', - confirmText: globalize.translate('UninstallPluginHeader') + confirmText: globalize.translate('HeaderUninstallPlugin') }).then(function () { loading.show(); ApiClient.uninstallPlugin(uniqueid).then(function () { From c14b20727a7832b7c0f3bc2c32d929f2f43b8a5e Mon Sep 17 00:00:00 2001 From: MrTimscampi Date: Sat, 8 Aug 2020 16:48:25 +0200 Subject: [PATCH 108/301] Merge conditions in plugin install --- src/controllers/dashboard/plugins/add/index.js | 14 ++++++-------- 1 file changed, 6 insertions(+), 8 deletions(-) diff --git a/src/controllers/dashboard/plugins/add/index.js b/src/controllers/dashboard/plugins/add/index.js index 8393970e76..875472a278 100644 --- a/src/controllers/dashboard/plugins/add/index.js +++ b/src/controllers/dashboard/plugins/add/index.js @@ -118,14 +118,12 @@ export default function(view, params) { })[0]; const version = $('#selectVersion', page).val(); - if (installedPlugin) { - if (installedPlugin.Version === version) { - loading.hide(); - Dashboard.alert({ - message: globalize.translate('MessageAlreadyInstalled'), - title: globalize.translate('HeaderPluginInstallation') - }); - } + if (installedPlugin && installedPlugin.Version === version) { + loading.hide(); + Dashboard.alert({ + message: globalize.translate('MessageAlreadyInstalled'), + title: globalize.translate('HeaderPluginInstallation') + }); } else { performInstallation(page, name, guid, version); } From faa78ebff14306164157df129cc014984b8e04db Mon Sep 17 00:00:00 2001 From: MrTimscampi Date: Sat, 8 Aug 2020 18:51:27 +0200 Subject: [PATCH 109/301] Fix string --- src/controllers/dashboard/plugins/add/index.js | 4 ++-- src/strings/en-us.json | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/src/controllers/dashboard/plugins/add/index.js b/src/controllers/dashboard/plugins/add/index.js index 875472a278..44c46ce11b 100644 --- a/src/controllers/dashboard/plugins/add/index.js +++ b/src/controllers/dashboard/plugins/add/index.js @@ -83,7 +83,7 @@ function performInstallation(page, name, guid, version) { loading.hide(); alertText(globalize.translate('MessagePluginInstalled')); }).catch(() => { - alertText(globalize.translate('MessagePluginIntallError')); + alertText(globalize.translate('MessagePluginInstallError')); }); }; @@ -95,7 +95,7 @@ function performInstallation(page, name, guid, version) { msg += globalize.translate('PleaseConfirmPluginInstallation'); import('confirm').then(({default: confirm}) => { - confirm.default(msg, globalize.translate('HeaderConfirmPluginInstallation')).then(function () { + confirm(msg, globalize.translate('HeaderConfirmPluginInstallation')).then(function () { alertCallback(); }).catch(() => { console.debug('plugin not installed'); diff --git a/src/strings/en-us.json b/src/strings/en-us.json index 5c7e1e267d..638be2efaf 100644 --- a/src/strings/en-us.json +++ b/src/strings/en-us.json @@ -1282,7 +1282,7 @@ "PleaseRestartServerName": "Please restart Jellyfin Server - {0}.", "PleaseSelectTwoItems": "Please select at least two items.", "MessagePluginInstalled": "The plugin has been successfully installed. Jellyfin Server will need to be restarted for changes to take effect.", - "MessagePluginIntallError": "An error occured while installing the plugin.", + "MessagePluginInstallError": "An error occured while installing the plugin.", "MessageGetInstalledPluginsError": "An error occured while getting the list of currently installed plugins.", "PreferEmbeddedTitlesOverFileNames": "Prefer embedded titles over filenames", "PreferEmbeddedTitlesOverFileNamesHelp": "This determines the default display title when no internet metadata or local metadata is available.", From c1a988f2c7e8a0bc70c3d2ec5af96ca11b1c240c Mon Sep 17 00:00:00 2001 From: Cameron Date: Sat, 8 Aug 2020 19:23:56 +0100 Subject: [PATCH 110/301] add default --- src/controllers/livetv/livetvsuggested.js | 2 ++ 1 file changed, 2 insertions(+) diff --git a/src/controllers/livetv/livetvsuggested.js b/src/controllers/livetv/livetvsuggested.js index 79d9aac6e9..fdc6037850 100644 --- a/src/controllers/livetv/livetvsuggested.js +++ b/src/controllers/livetv/livetvsuggested.js @@ -261,6 +261,8 @@ define(['layoutManager', 'userSettings', 'inputManager', 'loading', 'globalize', } require(depends, function (controllerFactory) { + controllerFactory = controllerFactory.default || controllerFactory; + var tabContent; if (index == 0) { From 0dba3bbb72e519f042495d540960c4393048fcdc Mon Sep 17 00:00:00 2001 From: MrTimscampi Date: Sat, 8 Aug 2020 21:13:20 +0200 Subject: [PATCH 111/301] Keep prefer-const disabled for now --- .eslintrc.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.eslintrc.js b/.eslintrc.js index 426bb73083..a4e972c83e 100644 --- a/.eslintrc.js +++ b/.eslintrc.js @@ -44,7 +44,7 @@ module.exports = { 'no-unused-vars': ['error', { 'vars': 'all', 'args': 'none', 'ignoreRestSiblings': true }], 'one-var': ['error', 'never'], 'padded-blocks': ['error', 'never'], - 'prefer-const': ['error', {'destructuring': 'all'}], + //'prefer-const': ['error', {'destructuring': 'all'}], 'quotes': ['error', 'single', { 'avoidEscape': true, 'allowTemplateLiterals': false }], 'semi': ['error'], 'space-before-blocks': ['error'], From 37abd530eb5b462d8e5493d9d7e48da08d661ecb Mon Sep 17 00:00:00 2001 From: MrTimscampi Date: Sat, 8 Aug 2020 21:19:27 +0200 Subject: [PATCH 112/301] Remove old files --- src/controllers/user/menu.js | 58 ----------------- src/controllers/user/profile.js | 106 -------------------------------- 2 files changed, 164 deletions(-) delete mode 100644 src/controllers/user/menu.js delete mode 100644 src/controllers/user/profile.js diff --git a/src/controllers/user/menu.js b/src/controllers/user/menu.js deleted file mode 100644 index bd6f4de8a2..0000000000 --- a/src/controllers/user/menu.js +++ /dev/null @@ -1,58 +0,0 @@ -define(['apphost', 'connectionManager', 'layoutManager', 'listViewStyle', 'emby-button'], function(appHost, connectionManager, layoutManager) { - 'use strict'; - - return function(view, params) { - view.querySelector('.btnLogout').addEventListener('click', function() { - Dashboard.logout(); - }); - - view.querySelector('.selectServer').addEventListener('click', function () { - Dashboard.selectServer(); - }); - - view.querySelector('.clientSettings').addEventListener('click', function () { - window.NativeShell.openClientSettings(); - }); - - view.addEventListener('viewshow', function() { - // this page can also be used by admins to change user preferences from the user edit page - var userId = params.userId || Dashboard.getCurrentUserId(); - var page = this; - - page.querySelector('.lnkMyProfile').setAttribute('href', 'myprofile.html?userId=' + userId); - page.querySelector('.lnkDisplayPreferences').setAttribute('href', 'mypreferencesdisplay.html?userId=' + userId); - page.querySelector('.lnkHomePreferences').setAttribute('href', 'mypreferenceshome.html?userId=' + userId); - page.querySelector('.lnkPlaybackPreferences').setAttribute('href', 'mypreferencesplayback.html?userId=' + userId); - page.querySelector('.lnkSubtitlePreferences').setAttribute('href', 'mypreferencessubtitles.html?userId=' + userId); - - if (window.NativeShell && window.NativeShell.AppHost.supports('clientsettings')) { - page.querySelector('.clientSettings').classList.remove('hide'); - } else { - page.querySelector('.clientSettings').classList.add('hide'); - } - - if (appHost.default.supports('multiserver')) { - page.querySelector('.selectServer').classList.remove('hide'); - } else { - page.querySelector('.selectServer').classList.add('hide'); - } - - // hide the actions if user preferences are being edited for a different user - if (params.userId && params.userId !== Dashboard.getCurrentUserId) { - page.querySelector('.userSection').classList.add('hide'); - page.querySelector('.adminSection').classList.add('hide'); - } - - ApiClient.getUser(userId).then(function(user) { - page.querySelector('.headerUsername').innerHTML = user.Name; - if (!user.Policy.IsAdministrator) { - page.querySelector('.adminSection').classList.add('hide'); - } - }); - - require(['autoFocuser'], function (autoFocuser) { - autoFocuser.autoFocus(view); - }); - }); - }; -}); diff --git a/src/controllers/user/profile.js b/src/controllers/user/profile.js deleted file mode 100644 index eb912418fd..0000000000 --- a/src/controllers/user/profile.js +++ /dev/null @@ -1,106 +0,0 @@ -define(['controllers/dashboard/users/userpasswordpage', 'loading', 'libraryMenu', 'apphost', 'globalize', 'emby-button'], function (UserPasswordPage, loading, libraryMenu, appHost, globalize) { - 'use strict'; - - function reloadUser(page) { - var userId = getParameterByName('userId'); - loading.show(); - ApiClient.getUser(userId).then(function (user) { - page.querySelector('.username').innerHTML = user.Name; - libraryMenu.setTitle(user.Name); - - var imageUrl = 'assets/img/avatar.png'; - if (user.PrimaryImageTag) { - imageUrl = ApiClient.getUserImageUrl(user.Id, { - tag: user.PrimaryImageTag, - type: 'Primary' - }); - } - - var userImage = page.querySelector('#image'); - userImage.style.backgroundImage = 'url(' + imageUrl + ')'; - - Dashboard.getCurrentUser().then(function (loggedInUser) { - if (user.PrimaryImageTag) { - page.querySelector('#btnAddImage').classList.add('hide'); - page.querySelector('#btnDeleteImage').classList.remove('hide'); - } else if (appHost.default.supports('fileinput') && (loggedInUser.Policy.IsAdministrator || user.Policy.EnableUserPreferenceAccess)) { - page.querySelector('#btnDeleteImage').classList.add('hide'); - page.querySelector('#btnAddImage').classList.remove('hide'); - } - }); - loading.hide(); - }); - } - - function onFileReaderError(evt) { - loading.hide(); - switch (evt.target.error.code) { - case evt.target.error.NOT_FOUND_ERR: - require(['toast'], function (toast) { - toast(globalize.translate('FileNotFound')); - }); - break; - case evt.target.error.ABORT_ERR: - onFileReaderAbort(); - break; - case evt.target.error.NOT_READABLE_ERR: - default: - require(['toast'], function (toast) { - toast(globalize.translate('FileReadError')); - }); - } - } - - function onFileReaderAbort(evt) { - loading.hide(); - require(['toast'], function (toast) { - toast(globalize.translate('FileReadCancelled')); - }); - } - - function setFiles(page, files) { - var userImage = page.querySelector('#image'); - var file = files[0]; - - if (!file || !file.type.match('image.*')) { - return false; - } - - var reader = new FileReader(); - reader.onerror = onFileReaderError; - reader.onabort = onFileReaderAbort; - reader.onload = function (evt) { - userImage.style.backgroundImage = 'url(' + evt.target.result + ')'; - var userId = getParameterByName('userId'); - ApiClient.uploadUserImage(userId, 'Primary', file).then(function () { - loading.hide(); - reloadUser(page); - }); - }; - - reader.readAsDataURL(file); - } - - return function (view, params) { - reloadUser(view); - new UserPasswordPage(view, params); - view.querySelector('#btnDeleteImage').addEventListener('click', function () { - require(['confirm'], function (confirm) { - confirm(globalize.translate('DeleteImageConfirmation'), globalize.translate('DeleteImage')).then(function () { - loading.show(); - var userId = getParameterByName('userId'); - ApiClient.deleteUserImage(userId, 'primary').then(function () { - loading.hide(); - reloadUser(view); - }); - }); - }); - }); - view.querySelector('#btnAddImage').addEventListener('click', function (evt) { - view.querySelector('#uploadImage').click(); - }); - view.querySelector('#uploadImage').addEventListener('change', function (evt) { - setFiles(view, evt.target.files); - }); - }; -}); From 14ee172231d50be81fe3e59314d594b059085c9f Mon Sep 17 00:00:00 2001 From: "dependabot-preview[bot]" <27856297+dependabot-preview[bot]@users.noreply.github.com> Date: Sat, 8 Aug 2020 20:19:03 +0000 Subject: [PATCH 113/301] Bump @babel/eslint-parser from 7.11.0 to 7.11.3 Bumps [@babel/eslint-parser](https://github.com/babel/babel/tree/HEAD/eslint/babel-eslint-parser) from 7.11.0 to 7.11.3. - [Release notes](https://github.com/babel/babel/releases) - [Changelog](https://github.com/babel/babel/blob/main/CHANGELOG.md) - [Commits](https://github.com/babel/babel/commits/v7.11.3/eslint/babel-eslint-parser) Signed-off-by: dependabot-preview[bot] --- package.json | 2 +- yarn.lock | 8 ++++---- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/package.json b/package.json index d8164391cb..252c3e9008 100644 --- a/package.json +++ b/package.json @@ -6,7 +6,7 @@ "license": "GPL-2.0-or-later", "devDependencies": { "@babel/core": "^7.11.1", - "@babel/eslint-parser": "^7.11.0", + "@babel/eslint-parser": "^7.11.3", "@babel/eslint-plugin": "^7.11.0", "@babel/plugin-proposal-class-properties": "^7.10.1", "@babel/plugin-proposal-private-methods": "^7.10.1", diff --git a/yarn.lock b/yarn.lock index 758ded53fc..4518e7af51 100644 --- a/yarn.lock +++ b/yarn.lock @@ -40,10 +40,10 @@ semver "^5.4.1" source-map "^0.5.0" -"@babel/eslint-parser@^7.11.0": - version "7.11.0" - resolved "https://registry.yarnpkg.com/@babel/eslint-parser/-/eslint-parser-7.11.0.tgz#b123924edd44508782c030066c926f1b807151cd" - integrity sha512-dJDM2Pc01D9TwKL3Mmz2xgVF9X953RBHq9H4gywbN1q8MrfvXmNHfsCt06vvByBVQqm+9WxMs+doEH/R09TwWQ== +"@babel/eslint-parser@^7.11.3": + version "7.11.3" + resolved "https://registry.yarnpkg.com/@babel/eslint-parser/-/eslint-parser-7.11.3.tgz#ceb94cb6e2457c4a4d2d87db29925e6b48d20786" + integrity sha512-OdCt/CVXdR/eTNTYDEobf4e55m/AAc04ki+/Oe2/GE8ivh2FxX4yDab48lA6t7ysP4M7luap6Fxx3hUVNTwzFQ== dependencies: eslint-scope "5.1.0" eslint-visitor-keys "^1.3.0" From e1083ec2ea4dfd31fc91a19963a23f55926d18ac Mon Sep 17 00:00:00 2001 From: Steven S O'Connor Date: Sat, 8 Aug 2020 14:20:17 -0700 Subject: [PATCH 114/301] Remove extraneous pageContainer element from videoOSD --- src/controllers/playback/video/index.html | 1 - 1 file changed, 1 deletion(-) diff --git a/src/controllers/playback/video/index.html b/src/controllers/playback/video/index.html index cf3d0beff8..77274230e4 100644 --- a/src/controllers/playback/video/index.html +++ b/src/controllers/playback/video/index.html @@ -1,5 +1,4 @@
    -
    From 4ffded957dbb50a20b20e6a58324da58a9f55399 Mon Sep 17 00:00:00 2001 From: Moritz Date: Sat, 8 Aug 2020 20:57:10 +0000 Subject: [PATCH 115/301] Translated using Weblate (German) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/de/ --- src/strings/de.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/src/strings/de.json b/src/strings/de.json index 0aa4d2172f..b167c31707 100644 --- a/src/strings/de.json +++ b/src/strings/de.json @@ -1545,5 +1545,7 @@ "LabelUnstable": "Instabil", "SubtitleVerticalPositionHelp": "Zeilennummer, in der der Text angezeigt wird. Positive Zahlen geben die Zeile von oben an. Negative Zahlen geben die Zeile von unten an.", "Preview": "Vorschau", - "LabelSubtitleVerticalPosition": "Vertikale Position:" + "LabelSubtitleVerticalPosition": "Vertikale Position:", + "MessageGetInstalledPluginsError": "Beim Abrufen der Liste der derzeit installierten Plugins ist ein Fehler aufgetreten.", + "MessagePluginInstallError": "Bei der Installation des Plugins ist ein Fehler aufgetreten." } From cfb22c0fb91e58c75ec26d21db45e35b33a619d3 Mon Sep 17 00:00:00 2001 From: Cameron Date: Sat, 8 Aug 2020 23:23:53 +0100 Subject: [PATCH 116/301] Apply suggestions from code review Co-authored-by: Dmitry Lyzo <56478732+dmitrylyzo@users.noreply.github.com> --- src/scripts/livetvcomponents.js | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/scripts/livetvcomponents.js b/src/scripts/livetvcomponents.js index f1d0b2d3da..46fb714763 100644 --- a/src/scripts/livetvcomponents.js +++ b/src/scripts/livetvcomponents.js @@ -22,7 +22,7 @@ function getTimersHtml(timers, options) { let currentGroupName = ''; let currentGroup = []; - for (const item in items) { + for (const item of items) { let dateText = ''; if (options.indexByDate !== false && item.StartDate) { @@ -60,7 +60,7 @@ function getTimersHtml(timers, options) { }); } let html = ''; - for (const group in groups) { + for (const group of groups) { if (group.name) { html += '
    '; html += '

    ' + group.name + '

    '; From 1ede5e0d68afa4fc7ebeab1dc0f875eb1e9f5565 Mon Sep 17 00:00:00 2001 From: Cameron Date: Sat, 8 Aug 2020 23:48:24 +0100 Subject: [PATCH 117/301] Update src/scripts/libraryBrowser.js Co-authored-by: Dmitry Lyzo <56478732+dmitrylyzo@users.noreply.github.com> --- src/scripts/libraryBrowser.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/scripts/libraryBrowser.js b/src/scripts/libraryBrowser.js index 4f2a0fdb47..460e1b95ed 100644 --- a/src/scripts/libraryBrowser.js +++ b/src/scripts/libraryBrowser.js @@ -119,7 +119,7 @@ export function getQueryPagingHtml (options) { } export function showSortMenu (options) { - Promise.All([ + Promise.all([ import('dialogHelper'), import('emby-radio') ]).then(({default: dialogHelper}) => { From 10100ce63b818670d36ee0344d6022085821c896 Mon Sep 17 00:00:00 2001 From: Cameron Date: Sat, 8 Aug 2020 23:53:34 +0100 Subject: [PATCH 118/301] Update src/scripts/libraryBrowser.js Co-authored-by: Dmitry Lyzo <56478732+dmitrylyzo@users.noreply.github.com> --- src/scripts/libraryBrowser.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/scripts/libraryBrowser.js b/src/scripts/libraryBrowser.js index 460e1b95ed..83d683a690 100644 --- a/src/scripts/libraryBrowser.js +++ b/src/scripts/libraryBrowser.js @@ -122,7 +122,7 @@ export function showSortMenu (options) { Promise.all([ import('dialogHelper'), import('emby-radio') - ]).then(({default: dialogHelper}) => { + ]).then(([{default: dialogHelper}]) => { function onSortByChange() { var newValue = this.value; From ad7879ad4d481df0f1dac86b0baead1cc88e7707 Mon Sep 17 00:00:00 2001 From: Nicode Jiao Date: Sun, 9 Aug 2020 03:28:41 +0000 Subject: [PATCH 119/301] Translated using Weblate (Chinese (Simplified)) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/zh_Hans/ --- src/strings/zh-cn.json | 76 +++++++++++++++++++++++------------------- 1 file changed, 42 insertions(+), 34 deletions(-) diff --git a/src/strings/zh-cn.json b/src/strings/zh-cn.json index 553445404a..eed9f95599 100644 --- a/src/strings/zh-cn.json +++ b/src/strings/zh-cn.json @@ -159,7 +159,7 @@ "DetectingDevices": "正在侦测设备", "DeviceAccessHelp": "这仅适用于可以唯一标识的设备,而不会阻止浏览器访问。限制用户设备访问会阻止使用未在此被批准的新增设备。", "DirectPlaying": "直接播放", - "DirectStreamHelp2": "直接串流只占用占用很少的CPU并且视频的品质不会有任何损失。", + "DirectStreamHelp2": "直接串流只占用占用很少的CPU并且视频的品质只会有极小程度的损失。", "DirectStreaming": "直接串流", "Director": "导演", "Disabled": "已禁用", @@ -261,7 +261,7 @@ "HeaderAllowMediaDeletionFrom": "允许从中删除媒体", "HeaderApiKey": "API 密钥", "HeaderApiKeys": "API 密钥", - "HeaderApiKeysHelp": "外部应用程序需要 API 密钥才能与 Jellyfin Server 进行通信。使用 Jellyfin 账户进行登录时密钥将会自动生成,您也可以手动为某个应用程序分配一个密钥。", + "HeaderApiKeysHelp": "外部应用程序需要 API 密钥才能与服务器进行通信。密钥会在使用普通账户登录时自动生成,或是手动为应用分配。", "HeaderAudioBooks": "有声读物", "HeaderAudioSettings": "声音设置", "HeaderBlockItemsWithNoRating": "通过没有评级和设置不允许的评级锁定内容:", @@ -327,7 +327,7 @@ "HeaderInstall": "安装", "HeaderInstantMix": "速成合辑", "HeaderItems": "项目", - "HeaderKodiMetadataHelp": "要启用或禁用 NFO 元数据, 请在 Jellyfin 库安装程序中编辑库, 然后找到“元数据储户”部分。", + "HeaderKodiMetadataHelp": "要启用或禁用 NFO 元数据, 请编辑库, 然后找到“元数据储户”部分。", "HeaderLatestEpisodes": "最新剧集", "HeaderLatestMedia": "最新媒体", "HeaderLatestMovies": "最新电影", @@ -372,7 +372,7 @@ "HeaderPreferredMetadataLanguage": "首选元数据语言", "HeaderProfile": "配置", "HeaderProfileInformation": "配置信息", - "HeaderProfileServerSettingsHelp": "这些参数将控制 Jellyfin 媒体服务器如何呈现给设备。", + "HeaderProfileServerSettingsHelp": "这些参数将控制服务器如何将自己呈现给客户端。", "HeaderRecentlyPlayed": "最近播放", "HeaderRecordingOptions": "录制选项", "HeaderRecordingPostProcessing": "记录后处理", @@ -396,7 +396,7 @@ "HeaderSelectServerCachePath": "选择服务器缓存路径", "HeaderSelectServerCachePathHelp": "浏览或输入一个路径用于服务器缓存文件,此文件夹必须可写。", "HeaderSelectTranscodingPath": "选择临时解码路径", - "HeaderSelectTranscodingPathHelp": "浏览或输入一个路径用于临时转码,此文件夹必须可写。", + "HeaderSelectTranscodingPathHelp": "浏览或输入一个路径用于转码文件,此文件夹必须可写。", "HeaderSendMessage": "发送消息", "HeaderSeries": "电视剧", "HeaderSeriesOptions": "系列选项", @@ -445,8 +445,8 @@ "HttpsRequiresCert": "要启用安全连接, 您需要提供一个受信任的 SSL 证书, 例如 Let's Encrypt 。请提供证书或禁用安全连接。", "Identify": "识别", "Images": "图片", - "ImportFavoriteChannelsHelp": "如果启用,只有在协调器设备中被标记为我的最爱的频道才会被导入。", - "ImportMissingEpisodesHelp": "如果启用,会将缺少的剧集信息导入到你的 Jellyfin 数据库并分季分剧显示。可能会大大延长媒体库扫描时间。", + "ImportFavoriteChannelsHelp": "只有在协调器设备中被标记为我的最爱的频道才会被导入。", + "ImportMissingEpisodesHelp": "缺少的剧集信息将被导入到你的数据库并分季分剧显示。可能会大大延长媒体库扫描时间。", "InstallingPackage": "正在安装 {0}(版本 {1})", "InstantMix": "即时混音", "ItemCount": "{0} 项", @@ -476,14 +476,14 @@ "LabelAppName": "APP名称", "LabelAppNameExample": "例如:Sickbeard, Sonarr", "LabelArtists": "艺术家:", - "LabelArtistsHelp": "独立多功能 ;", + "LabelArtistsHelp": "将多个艺术家用分号分隔", "LabelAudioLanguagePreference": "首选音频语言:", "LabelAutomaticallyRefreshInternetMetadataEvery": "自动从互联网获取元数据并刷新:", "LabelBindToLocalNetworkAddress": "监听的本地网络地址:", - "LabelBindToLocalNetworkAddressHelp": "(可选的)覆盖 HTTP 服务器绑定的本地 IP 地址。如果留空,服务器将会监听所有可用的地址。改变这个值需要重启 Jellyfin 服务器。", + "LabelBindToLocalNetworkAddressHelp": "覆盖 HTTP 服务器绑定的本地 IP 地址。如果留空,服务器将会监听所有可用的地址。改变这个值需要重启 Jellyfin 服务器。", "LabelBirthDate": "出生日期:", "LabelBirthYear": "出生年份:", - "LabelBlastMessageInterval": "活动信号的时间间隔(秒)", + "LabelBlastMessageInterval": "活动信号的时间间隔", "LabelBlastMessageIntervalHelp": "确定爆炸活动消息之间的持续时间(以秒为单位)。", "LabelBlockContentWithTags": "通过标签锁定内容:", "LabelBurnSubtitles": "烧录字幕:", @@ -541,7 +541,7 @@ "LabelEnableAutomaticPortMapHelp": "通过UPnP将路由器端口自动转发到服务器端口。这可能不适用于某些型号的路由器和网络配置。需要服务器重新启动后才会应用更改。", "LabelEnableBlastAliveMessages": "爆发活动信号", "LabelEnableBlastAliveMessagesHelp": "如果该服务器不能被网络中的其他UPnP设备检测到,请启用此选项。", - "LabelEnableDlnaClientDiscoveryInterval": "客户端搜寻时间间隔(秒)", + "LabelEnableDlnaClientDiscoveryInterval": "客户端搜寻时间间隔", "LabelEnableDlnaClientDiscoveryIntervalHelp": "确定由 Jellyfin 执行的 SSDP 搜索之间的持续时间 (以秒为单位)。", "LabelEnableDlnaDebugLogging": "启用 DLNA 调试日志", "LabelEnableDlnaDebugLoggingHelp": "创建一个很大的日志文件,仅应在排除故障时使用。", @@ -567,9 +567,9 @@ "LabelForgotPasswordUsernameHelp": "输入你的用户名,如果你还记得。", "LabelFormat": "格式:", "LabelFriendlyName": "好记的名称:", - "LabelServerNameHelp": "此名称将用做服务器名,如果留空,将使用计算机名。", + "LabelServerNameHelp": "此名称将用做服务器名,默认使用服务器的主机名。", "LabelGroupMoviesIntoCollections": "批量添加电影到收藏", - "LabelGroupMoviesIntoCollectionsHelp": "显示电影列表时,属于一个收藏的电影将显示为一个分组。", + "LabelGroupMoviesIntoCollectionsHelp": "显示电影列表时,同一收藏的电影将显示为一个分组。", "LabelH264Crf": "H264 CRF 编码质量等级:", "LabelEncoderPreset": "H264 和 H265 编码预设:", "LabelHardwareAccelerationType": "硬件加速:", @@ -577,7 +577,7 @@ "LabelHomeNetworkQuality": "家庭网络质量:", "LabelHomeScreenSectionValue": "主屏幕模块{0}:", "LabelHttpsPort": "本地 HTTPS 端口号:", - "LabelHttpsPortHelp": "Jellyfin HTTPS 服务器监听端口。", + "LabelHttpsPortHelp": "HTTPS 服务器监听的 TCP 端口号。", "LabelIconMaxHeight": "图标最大高度:", "LabelIconMaxHeightHelp": "通过UPnP显示的图标最大分辨率。", "LabelIconMaxWidth": "图标最大宽度:", @@ -604,7 +604,7 @@ "LabelLanguage": "语言:", "LabelLineup": "排队:", "LabelLocalHttpServerPortNumber": "本地 HTTP 端口号:", - "LabelLocalHttpServerPortNumberHelp": "Jellyfin HTTP 服务器监听的 TCP 端口。", + "LabelLocalHttpServerPortNumberHelp": "HTTP 服务器监听的 TCP 端口号。", "LabelLockItemToPreventChanges": "锁定此项目防止改动", "LabelLoginDisclaimer": "登录声明:", "LabelLoginDisclaimerHelp": "将在登录页面底部显示的信息。", @@ -646,9 +646,9 @@ "LabelMovieCategories": "电影分类:", "LabelMoviePrefix": "电影前缀:", "LabelMoviePrefixHelp": "如果将前缀应用于影片标题, 请在此处输入它, 以便服务器可以正确处理它。", - "LabelMovieRecordingPath": "电影录制路径 (可选的):", + "LabelMovieRecordingPath": "电影录制路径:", "LabelMusicStreamingTranscodingBitrate": "音乐转码的比特率:", - "LabelMusicStreamingTranscodingBitrateHelp": "请指定一个音乐媒体串流时的最大比特率。", + "LabelMusicStreamingTranscodingBitrateHelp": "请指定音乐媒体串流时的最大比特率。", "LabelName": "名字:", "LabelNewName": "新名字:", "LabelNewPassword": "新密码:", @@ -659,7 +659,7 @@ "LabelNumber": "编号:", "LabelNumberOfGuideDays": "下载几天的节目指南:", "LabelNumberOfGuideDaysHelp": "下载更多天的节目指南可以帮你进一步查看节目列表并做出提前安排,但下载过程也将耗时更久。它将基于频道数量自动选择。", - "LabelOptionalNetworkPath": "(可选的)共享的网络文件夹:", + "LabelOptionalNetworkPath": "共享的网络文件夹:", "LabelOptionalNetworkPathHelp": "如果这个文件夹在你的网络上是共享的,提供这个网络共享地址能够允许其他设备上的 Jellyfin 应用程序直接访问媒体文件,例如 {0} 或者 {1}。", "LabelOriginalAspectRatio": "原始长宽比:", "LabelOriginalTitle": "原标题:", @@ -704,7 +704,7 @@ "LabelReleaseDate": "发行日期:", "LabelRemoteClientBitrateLimit": "互联网流媒体传输比特率限制(Mbps):", "LabelRemoteClientBitrateLimitHelp": "所有网络设备都有一个可选的每流比特率限制。这对于防止设备请求比 internet 连接所能处理的更高的比特率非常有用。这可能会导致服务器上的 CPU 负载增加, 以便将视频转码到较低的比特率。", - "LabelRuntimeMinutes": "播放时长(分钟):", + "LabelRuntimeMinutes": "播放时长:", "LabelSaveLocalMetadata": "将媒体图像保存到媒体所在文件夹", "LabelSaveLocalMetadataHelp": "直接将媒体图像保存到媒体所在文件夹以方便编辑。", "LabelScheduledTaskLastRan": "最后运行 {0}, 花费时间 {1}.", @@ -714,7 +714,7 @@ "LabelSelectVersionToInstall": "选择安装版本:", "LabelSendNotificationToUsers": "发送通知至:", "LabelSerialNumber": "序列号", - "LabelSeriesRecordingPath": "电视剧录制路径 (可选的):", + "LabelSeriesRecordingPath": "电视剧录制路径:", "LabelServerHost": "主机:", "LabelServerHostHelp": "192.168.1.100:8096 或 https://myserver.com", "LabelSimultaneousConnectionLimit": "并发流限制:", @@ -786,7 +786,7 @@ "LabelYoureDone": "完成!", "LabelZipCode": "邮编:", "LabelffmpegPath": "FFmpeg 路径:", - "LabelffmpegPathHelp": "FFmpeg 应用程序的文件,或者包含了 FFmpeg 的文件夹的路径。", + "LabelffmpegPathHelp": "FFmpeg 应用文件或包含 FFmpeg 的文件夹的路径。", "LanNetworksHelp": "在强制带宽限制时,认作本地网络上的 IP 地址或 IP/网络掩码条目的逗号分隔列表。如果设置此项,所有其它 IP 地址将被视为在外部网络上,并且将受到外部带宽限制。如果保留为空,则只将服务器的子网视为本地网络。", "Large": "大", "LatestFromLibrary": "最新的{0}", @@ -918,7 +918,7 @@ "OptionAllowLinkSharingHelp": "只有网页包含的媒体信息会被共享。媒体文件不会被公开共享。共享是有时间限制的并且会在 {0} 天后到期。", "OptionAllowManageLiveTv": "允许电视直播录制管理", "OptionAllowMediaPlayback": "允许播放媒体", - "OptionAllowMediaPlaybackTranscodingHelp": "由于不支持的媒体格式, 限制对代码转换的访问可能会导致 Jellyfin 应用程序中的播放失败。", + "OptionAllowMediaPlaybackTranscodingHelp": "限制对转码的访问可能会由于不支持的媒体格式导致客户端中播放失败。", "OptionAllowRemoteControlOthers": "允许其他用户全程控制", "OptionAllowRemoteSharedDevices": "允许远程控制共享的设备", "OptionAllowRemoteSharedDevicesHelp": "DLNA 设备在用户对他们进行控制前都被视为是共享的。", @@ -931,7 +931,7 @@ "OptionAuto": "自动", "OptionAutomatic": "自动", "OptionAutomaticallyGroupSeries": "自动合并分布在不同文件夹的电视剧", - "OptionAutomaticallyGroupSeriesHelp": "如果启用,分布在这个媒体库的多个文件夹中的同一部电视剧将会自动整合成一部电视剧。", + "OptionAutomaticallyGroupSeriesHelp": "在这个媒体库的多个文件夹中的同一部电视剧将会自动整合成一部电视剧。", "OptionBlockBooks": "书籍", "OptionBlockChannelContent": "互联网频道内容", "OptionBlockLiveTvChannels": "电视直播频道", @@ -952,7 +952,7 @@ "OptionDatePlayed": "播放日期", "OptionDescending": "降序", "OptionDisableUser": "禁用此用户", - "OptionDisableUserHelp": "如果禁用该用户,服务器将不允许该用户连接。现有的连接将被终止。", + "OptionDisableUserHelp": "服务器将不允许来自该用户的任何连接。现有的连接将立即被终止。", "OptionDislikes": "不喜欢", "OptionDisplayFolderView": "显示一个“文件夹”类别用于按文件夹分类浏览你的媒体文件夹", "OptionDisplayFolderViewHelp": "在你的媒体库列表中显示文件夹。如果你有按文件夹分类进行浏览的需求,这会非常有用。", @@ -962,7 +962,7 @@ "OptionDownloadBoxImage": "包装", "OptionDownloadDiscImage": "光盘", "OptionDownloadImagesInAdvance": "提前下载图片", - "OptionDownloadImagesInAdvanceHelp": "默认下,大部分图片只有在 Jellyfin 应用程序请求时下载。开启此选项将随着媒体导入时下载所有图片。这可能需要更久媒体库扫描时间。", + "OptionDownloadImagesInAdvanceHelp": "默认大多数图片只在客户端请求时下载。开启此选项将在新媒体导入时预先下载所有图片。这可能大大延长媒体库扫描时间。", "OptionDownloadMenuImage": "菜单", "OptionDownloadPrimaryImage": "封面图", "OptionDownloadThumbImage": "缩略图", @@ -994,7 +994,7 @@ "OptionHlsSegmentedSubtitles": "HLS分段字幕", "OptionHomeVideos": "照片", "OptionIgnoreTranscodeByteRangeRequests": "忽略转码字节范围请求", - "OptionIgnoreTranscodeByteRangeRequestsHelp": "如果启用,这些请求会被兑现,但会忽略的字节范围标头。", + "OptionIgnoreTranscodeByteRangeRequestsHelp": "这些请求会被兑现,但会忽略的字节范围标头。", "OptionImdbRating": "IMDb 评分", "OptionIsHD": "HD高清", "OptionIsSD": "SD标清", @@ -1009,9 +1009,9 @@ "OptionOnInterval": "在一个期间", "OptionParentalRating": "家长分级", "OptionPlainStorageFolders": "显示所有文件夹作为一般存储文件夹", - "OptionPlainStorageFoldersHelp": "如果启用,所有文件夹在DIDL中显示为“ object.container.storageFolder ”,而不是一个更具体的类型,如“ object.container.person.musicArtist ” 。", + "OptionPlainStorageFoldersHelp": "所有文件夹在DIDL中显示为 \"object.container.storageFolder\" ,而不是一个更具体的类型,如 \"object.container.person.musicArtist\" 。", "OptionPlainVideoItems": "显示所有视频为一般视频项目", - "OptionPlainVideoItemsHelp": "如果启用,所有视频在DIDL中显示为“object.item.videoItem”,而不是一个更具体的类型,如“object.item.videoItem.movie ” 。", + "OptionPlainVideoItemsHelp": "所有视频在DIDL中显示为 \"object.item.videoItem\" ,而不是一个更具体的类型,如 \"object.item.videoItem.movie\" 。", "OptionPlayCount": "播放次数", "OptionPlayed": "已播放", "OptionPremiereDate": "首映日期", @@ -1316,7 +1316,7 @@ "ErrorDeletingItem": "从 Jellyfin Server 删除项目时出错。请确认 Jellyfin Server 是否拥有对媒体目录的写权限,然后重试。", "GroupBySeries": "按系列分组", "HeaderApp": "应用程序", - "DirectStreamHelp1": "该媒体文件的分辨率和编码(H.264、AC3 等)与您的设备兼容,但容器格式(.mkv、.avi、.wmv 等)不受支持。因此,视频在串流至您的设备之前将会被即时封装为另一种格式。", + "DirectStreamHelp1": "该媒体文件的分辨率和编码(H.264、AC3 等)与您的设备兼容,但文件格式(.mkv、.avi、.wmv 等)不受支持。因此,视频在串流至您的设备之前将会被即时封装为另一种格式。", "HeaderAppearsOn": "同时出现于", "HeaderCancelSeries": "取消系列", "HeaderFavoriteEpisodes": "最爱的剧集", @@ -1361,14 +1361,14 @@ "OptionDownloadLogoImage": "标志", "OptionLoginAttemptsBeforeLockout": "确定在锁定之前可以进行多少次不正确的登录尝试。", "OptionLoginAttemptsBeforeLockoutHelp": "如果值为0,则表示将允许普通用户尝试三次、管理员尝试五次的默认值。将此设置为-1将禁用此功能。", - "PasswordResetProviderHelp": "选择一个密码重置提供者用于密码重置", + "PasswordResetProviderHelp": "选择一个密码重置提供者用于此用户申请重置密码", "PlaceFavoriteChannelsAtBeginning": "将最喜爱的频道置顶", "PlayNext": "播放下一个", "PlayNextEpisodeAutomatically": "自动播放下一集", "Premieres": "首映", "Raised": "提高", "Recordings": "录音", - "RefreshDialogHelp": "元数据根据设置和Jellyfin服务器中启用的网络服务进行刷新。", + "RefreshDialogHelp": "元数据根据设置和仪表盘中启用的网络服务进行刷新。", "RepeatEpisodes": "重复剧集", "Schedule": "日程", "Screenshot": "屏幕截图", @@ -1421,7 +1421,7 @@ "ButtonAddImage": "添加图片", "LabelPlayer": "播放器:", "LabelBaseUrl": "基础 URL:", - "LabelBaseUrlHelp": "为服务器 URL添加自定义子目录,例如:http://example.com/<baseurl>。", + "LabelBaseUrlHelp": "为服务器 URL添加自定义子目录,例如:http://example.com/<baseurl>", "MusicLibraryHelp": "重播 {0}音乐命名指南{1}。", "HeaderFavoritePeople": "最喜欢的人物", "OptionRandom": "随机", @@ -1480,7 +1480,7 @@ "LabelRequireHttpsHelp": "开启后服务器将自动将所有 HTTP 请求重定向到 HTTPS。如果服务器没有启用 HTTPS 则不生效。", "LabelRequireHttps": "强制 HTTPS", "LabelStable": "稳定版", - "LabelEnableHttpsHelp": "开启服务器对所配置 HTTPS 端口的监听。必须配置有效的证书才会生效。", + "LabelEnableHttpsHelp": "监听已配置的 HTTPS 端口。必须配置有效的证书才会生效。", "LabelEnableHttps": "启用 HTTPS", "LabelChromecastVersion": "Chromecast版本", "HeaderDVR": "DVR", @@ -1539,5 +1539,13 @@ "ClearQueue": "清空队列", "StopPlayback": "停止播放", "Writers": "作者", - "ViewAlbumArtist": "查看专辑艺术家" + "ViewAlbumArtist": "查看专辑艺术家", + "Preview": "预览", + "SubtitleVerticalPositionHelp": "文字出现的行号。正数表示由上到下,负数表示由下到上。", + "LabelSubtitleVerticalPosition": "垂直位置:", + "PreviousTrack": "上一曲", + "MessageGetInstalledPluginsError": "获取已安装插件列表时出现错误。", + "MessagePluginInstallError": "安装插件时出现错误。", + "NextTrack": "下一曲", + "LabelUnstable": "不稳定" } From 754bf98d1645d24b3fdcd9b9c83b6c4c2ab04397 Mon Sep 17 00:00:00 2001 From: Cameron Date: Sun, 9 Aug 2020 10:46:37 +0100 Subject: [PATCH 120/301] Update src/components/recordingcreator/recordingcreator.js Co-authored-by: Dmitry Lyzo <56478732+dmitrylyzo@users.noreply.github.com> --- src/components/recordingcreator/recordingcreator.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/components/recordingcreator/recordingcreator.js b/src/components/recordingcreator/recordingcreator.js index b8001fc35e..f4ae64977d 100644 --- a/src/components/recordingcreator/recordingcreator.js +++ b/src/components/recordingcreator/recordingcreator.js @@ -122,7 +122,7 @@ function executeCloseAction(action, programId, serverId) { const apiClient = connectionManager.getApiClient(serverId); apiClient.getLiveTvProgram(programId, apiClient.getCurrentUserId()).then(function (item) { - playbackManager.default.play({ + playbackManager.play({ ids: [item.ChannelId], serverId: serverId }); From e6159a22d81ff9a4359c613b1fbb32192091a047 Mon Sep 17 00:00:00 2001 From: MrTimscampi Date: Sun, 9 Aug 2020 13:24:16 +0200 Subject: [PATCH 121/301] Fix themes not loading unless signed in --- src/scripts/autoThemes.js | 4 +++ src/scripts/settings/webSettings.js | 39 ++++++++++++++++++++++------- 2 files changed, 34 insertions(+), 9 deletions(-) diff --git a/src/scripts/autoThemes.js b/src/scripts/autoThemes.js index dad8c10322..75309f377b 100644 --- a/src/scripts/autoThemes.js +++ b/src/scripts/autoThemes.js @@ -3,6 +3,10 @@ import skinManager from 'skinManager'; import connectionManager from 'connectionManager'; import events from 'events'; +// Set the default theme when loading +skinManager.setTheme(userSettings.theme()); + +// Set the user's prefered theme when signing in events.on(connectionManager, 'localusersignedin', function (e, user) { skinManager.setTheme(userSettings.theme()); }); diff --git a/src/scripts/settings/webSettings.js b/src/scripts/settings/webSettings.js index 800b56ec7c..7915e7af76 100644 --- a/src/scripts/settings/webSettings.js +++ b/src/scripts/settings/webSettings.js @@ -1,21 +1,41 @@ + let data; -function getConfig() { +async function getConfig() { if (data) return Promise.resolve(data); - return fetch('config.json?nocache=' + new Date().getUTCMilliseconds()).then(response => { - data = response.json(); + try { + const response = await fetch('config.json', { + cache: 'no-cache' + }); + + if (!response.ok) { + throw new Error('network response was not ok'); + } + + data = await response.json(); + return data; - }).catch(error => { - console.warn('web config file is missing so the template will be used'); + } catch (error) { + console.warn('failed to fetch the web config file:', error); return getDefaultConfig(); - }); + } } -function getDefaultConfig() { - return fetch('config.template.json').then(function (response) { +async function getDefaultConfig() { + try { + const response = await fetch('config.template.json', { + cache: 'no-cache' + }); + + if (!response.ok) { + throw new Error('network response was not ok'); + } + data = response.json(); return data; - }); + } catch (error) { + console.error('failed to fetch the default web config file:', error); + } } export function getMultiServer() { @@ -29,6 +49,7 @@ export function getMultiServer() { export function getThemes() { return getConfig().then(config => { + console.warn(config.themes); return config.themes; }).catch(error => { console.log('cannot get web config:', error); From fa9c2757359a4f56a027049d3268b1c49211ec84 Mon Sep 17 00:00:00 2001 From: Cameron Date: Sun, 9 Aug 2020 12:41:16 +0100 Subject: [PATCH 122/301] fix ES6 errors --- src/plugins/chromecastPlayer/plugin.js | 2 +- src/scripts/libraryMenu.js | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/src/plugins/chromecastPlayer/plugin.js b/src/plugins/chromecastPlayer/plugin.js index f38f9b04ff..b7e6d05969 100644 --- a/src/plugins/chromecastPlayer/plugin.js +++ b/src/plugins/chromecastPlayer/plugin.js @@ -584,7 +584,7 @@ class ChromecastPlayer { this.isLocalPlayer = false; this.lastPlayerData = {}; - new castSenderApiLoader.default().load().then(initializeChromecast.bind(this)); + new castSenderApiLoader().load().then(initializeChromecast.bind(this)); } tryPair(target) { diff --git a/src/scripts/libraryMenu.js b/src/scripts/libraryMenu.js index 0780916a7c..ec572752b9 100644 --- a/src/scripts/libraryMenu.js +++ b/src/scripts/libraryMenu.js @@ -850,7 +850,7 @@ import 'flexStyles'; let requiresUserRefresh = true; function setTabs (type, selectedIndex, builder) { - import('mainTabsManager').then(({default: mainTabsManager}) => { + import('mainTabsManager').then((mainTabsManager) => { if (type) { mainTabsManager.setTabs(viewManager.currentView(), selectedIndex, builder, function () { return []; From 862489c73d3b76289bf4e0116f7d5d81b9d76e33 Mon Sep 17 00:00:00 2001 From: MrTimscampi Date: Sun, 9 Aug 2020 14:24:59 +0200 Subject: [PATCH 123/301] Fix forgotten await and warn --- src/scripts/settings/webSettings.js | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/src/scripts/settings/webSettings.js b/src/scripts/settings/webSettings.js index 7915e7af76..edd4d6e1f4 100644 --- a/src/scripts/settings/webSettings.js +++ b/src/scripts/settings/webSettings.js @@ -31,7 +31,7 @@ async function getDefaultConfig() { throw new Error('network response was not ok'); } - data = response.json(); + data = await response.json(); return data; } catch (error) { console.error('failed to fetch the default web config file:', error); @@ -49,7 +49,6 @@ export function getMultiServer() { export function getThemes() { return getConfig().then(config => { - console.warn(config.themes); return config.themes; }).catch(error => { console.log('cannot get web config:', error); From 0643e294040fade2b81de2db3bf5bfc9fac9a6d1 Mon Sep 17 00:00:00 2001 From: MrTimscampi Date: Sun, 9 Aug 2020 15:03:41 +0200 Subject: [PATCH 124/301] Fix suggestions and rebase issues --- src/components/appRouter.js | 5 +++-- src/components/apphost.js | 17 +------------- src/components/multiSelect/multiSelect.js | 2 +- src/components/qualityOptions.js | 1 - src/components/remotecontrol/remotecontrol.js | 3 ++- src/plugins/bookPlayer/plugin.js | 4 +++- src/plugins/experimentalWarnings/plugin.js | 4 +++- src/scripts/gamepadtokey.js | 4 +++- src/scripts/libraryMenu.js | 5 +++-- src/scripts/site.js | 22 ++++++++++++------- 10 files changed, 33 insertions(+), 34 deletions(-) diff --git a/src/components/appRouter.js b/src/components/appRouter.js index d8fe4edb98..e6bd86336b 100644 --- a/src/components/appRouter.js +++ b/src/components/appRouter.js @@ -1,6 +1,7 @@ define(['loading', 'globalize', 'events', 'viewManager', 'skinManager', 'backdrop', 'browser', 'page', 'appSettings', 'apphost', 'connectionManager'], function (loading, globalize, events, viewManager, skinManager, backdrop, browser, page, appSettings, appHost, connectionManager) { 'use strict'; + appHost = appHost.default || appHost; viewManager = viewManager.default || viewManager; browser = browser.default || browser; loading = loading.default || loading; @@ -330,8 +331,8 @@ define(['loading', 'globalize', 'events', 'viewManager', 'skinManager', 'backdro } if (shouldExitApp) { - if (appHost.default.supports('exit')) { - appHost.default.exit(); + if (appHost.supports('exit')) { + appHost.exit(); return; } return; diff --git a/src/components/apphost.js b/src/components/apphost.js index 8563321957..a8e26223a5 100644 --- a/src/components/apphost.js +++ b/src/components/apphost.js @@ -113,14 +113,6 @@ function getDeviceName() { deviceName += ' Android'; } - if (browser.ipad) { - deviceName += ' iPad'; - } else if (browser.iphone) { - deviceName += ' iPhone'; - } else if (browser.android) { - deviceName += ' Android'; - } - return deviceName; } @@ -326,7 +318,7 @@ function askForExit() { let deviceId; let deviceName; const appName = 'Jellyfin Web'; -const appVersion = '10.6.0'; +const appVersion = '10.7.0'; const appHost = { getWindowState: function () { @@ -383,13 +375,6 @@ const appHost = { getPushTokenInfo: function () { return {}; }, - setThemeColor: function (color) { - const metaThemeColor = document.querySelector('meta[name=theme-color]'); - - if (metaThemeColor) { - metaThemeColor.setAttribute('content', color); - } - }, setUserScalable: function (scalable) { if (!browser.tv) { const att = scalable ? 'width=device-width, initial-scale=1, minimum-scale=1, user-scalable=yes' : 'width=device-width, initial-scale=1, minimum-scale=1, maximum-scale=1, user-scalable=no'; diff --git a/src/components/multiSelect/multiSelect.js b/src/components/multiSelect/multiSelect.js index feba0ade5d..d922aee84a 100644 --- a/src/components/multiSelect/multiSelect.js +++ b/src/components/multiSelect/multiSelect.js @@ -196,7 +196,7 @@ import 'css!./multiSelect'; }); } - if (user.Policy.EnableContentDownloading && appHost.default.supports('filedownload')) { + if (user.Policy.EnableContentDownloading && appHost.supports('filedownload')) { menuItems.push({ name: globalize.translate('ButtonDownload'), id: 'download', diff --git a/src/components/qualityOptions.js b/src/components/qualityOptions.js index ff6b04d1f1..63d9557c7b 100644 --- a/src/components/qualityOptions.js +++ b/src/components/qualityOptions.js @@ -12,7 +12,6 @@ export function getVideoQualityOptions(options) { } var maxAllowedWidth = videoWidth || 4096; - //var maxAllowedHeight = videoHeight || 2304; var qualityOptions = []; diff --git a/src/components/remotecontrol/remotecontrol.js b/src/components/remotecontrol/remotecontrol.js index b37656124f..fd42466e91 100644 --- a/src/components/remotecontrol/remotecontrol.js +++ b/src/components/remotecontrol/remotecontrol.js @@ -1,6 +1,7 @@ define(['browser', 'datetime', 'backdrop', 'libraryBrowser', 'listView', 'imageLoader', 'playbackManager', 'nowPlayingHelper', 'events', 'connectionManager', 'apphost', 'globalize', 'layoutManager', 'userSettings', 'cardBuilder', 'itemContextMenu', 'cardStyle', 'emby-itemscontainer', 'css!./remotecontrol.css', 'emby-ratingbutton'], function (browser, datetime, backdrop, libraryBrowser, listView, imageLoader, playbackManager, nowPlayingHelper, events, connectionManager, appHost, globalize, layoutManager, userSettings, cardBuilder, itemContextMenu) { 'use strict'; + appHost = appHost.default || appHost; playbackManager = playbackManager.default || playbackManager; layoutManager = layoutManager.default || layoutManager; @@ -398,7 +399,7 @@ define(['browser', 'datetime', 'backdrop', 'libraryBrowser', 'listView', 'imageL showVolumeSlider = false; } - if (currentPlayer.isLocalPlayer && appHost.default.supports('physicalvolumecontrol')) { + if (currentPlayer.isLocalPlayer && appHost.supports('physicalvolumecontrol')) { showMuteButton = false; showVolumeSlider = false; } diff --git a/src/plugins/bookPlayer/plugin.js b/src/plugins/bookPlayer/plugin.js index d35e248893..415bd7b958 100644 --- a/src/plugins/bookPlayer/plugin.js +++ b/src/plugins/bookPlayer/plugin.js @@ -94,7 +94,9 @@ export class BookPlayer { onWindowKeyUp(e) { const key = keyboardnavigation.getKeyName(e); - const rendition = this._rendition; + + // TODO: depending on the event this can be the document or the rendition itself + const rendition = this._rendition || this; const book = rendition.book; if (this._loaded === false) return; diff --git a/src/plugins/experimentalWarnings/plugin.js b/src/plugins/experimentalWarnings/plugin.js index d97bd9a1a7..76b45fad4e 100644 --- a/src/plugins/experimentalWarnings/plugin.js +++ b/src/plugins/experimentalWarnings/plugin.js @@ -1,6 +1,8 @@ define(['connectionManager', 'globalize', 'userSettings', 'apphost'], function (connectionManager, globalize, userSettings, appHost) { 'use strict'; + appHost = appHost.default || appHost; + // TODO: Replace with date-fns // https://stackoverflow.com/questions/6117814/get-week-of-year-in-javascript-like-in-php function getWeek(date) { @@ -12,7 +14,7 @@ define(['connectionManager', 'globalize', 'userSettings', 'apphost'], function ( } function showMessage(text, userSettingsKey, appHostFeature) { - if (appHost.default.supports(appHostFeature)) { + if (appHost.supports(appHostFeature)) { return Promise.resolve(); } diff --git a/src/scripts/gamepadtokey.js b/src/scripts/gamepadtokey.js index 20c01bdcba..28103bb2db 100644 --- a/src/scripts/gamepadtokey.js +++ b/src/scripts/gamepadtokey.js @@ -22,6 +22,8 @@ require(['apphost'], function (appHost) { 'use strict'; + appHost = appHost.default || appHost; + var _GAMEPAD_A_BUTTON_INDEX = 0; var _GAMEPAD_B_BUTTON_INDEX = 1; var _GAMEPAD_DPAD_UP_BUTTON_INDEX = 12; @@ -187,7 +189,7 @@ require(['apphost'], function (appHost) { return false; } - if (appHost.default.getWindowState() === 'Minimized') { + if (appHost.getWindowState() === 'Minimized') { return false; } diff --git a/src/scripts/libraryMenu.js b/src/scripts/libraryMenu.js index 2bf8c3b3a2..5ebfd632e8 100644 --- a/src/scripts/libraryMenu.js +++ b/src/scripts/libraryMenu.js @@ -1,6 +1,7 @@ define(['dom', 'layoutManager', 'inputManager', 'connectionManager', 'events', 'viewManager', 'libraryBrowser', 'appRouter', 'apphost', 'playbackManager', 'syncPlayManager', 'groupSelectionMenu', 'browser', 'globalize', 'scripts/imagehelper', 'paper-icon-button-light', 'material-icons', 'scrollStyles', 'flexStyles'], function (dom, layoutManager, inputManager, connectionManager, events, viewManager, libraryBrowser, appRouter, appHost, playbackManager, syncPlayManager, groupSelectionMenu, browser, globalize, imageHelper) { 'use strict'; + appHost = appHost.default || appHost; viewManager = viewManager.default || viewManager; playbackManager = playbackManager.default || playbackManager; browser = browser.default || browser; @@ -279,7 +280,7 @@ define(['dom', 'layoutManager', 'inputManager', 'connectionManager', 'events', ' html += globalize.translate('HeaderUser'); html += ''; - if (appHost.default.supports('multiserver')) { + if (appHost.supports('multiserver')) { html += '' + globalize.translate('ButtonSelectServer') + ''; } @@ -591,7 +592,7 @@ define(['dom', 'layoutManager', 'inputManager', 'connectionManager', 'events', ' showBySelector('.lnkSyncToOtherDevices', false); } - if (user.Policy.EnableContentDownloading && appHost.default.supports('sync')) { + if (user.Policy.EnableContentDownloading && appHost.supports('sync')) { showBySelector('.libraryMenuDownloads', true); } else { showBySelector('.libraryMenuDownloads', false); diff --git a/src/scripts/site.js b/src/scripts/site.js index 592bad66c1..8c990077f3 100644 --- a/src/scripts/site.js +++ b/src/scripts/site.js @@ -200,8 +200,8 @@ var Dashboard = { SupportsPersistentIdentifier: self.appMode === 'cordova' || self.appMode === 'android', SupportsMediaControl: true }; - appHost.default.getPushTokenInfo(); - return capabilities = Object.assign(capabilities, appHost.default.getPushTokenInfo()); + appHost.getPushTokenInfo(); + return capabilities = Object.assign(capabilities, appHost.getPushTokenInfo()); }, selectServer: function () { if (window.NativeShell && typeof window.NativeShell.selectServer === 'function') { @@ -272,13 +272,15 @@ function initClient() { function createConnectionManager() { return require(['connectionManagerFactory', 'apphost', 'credentialprovider', 'events', 'userSettings'], function (ConnectionManager, appHost, credentialProvider, events, userSettings) { + appHost = appHost.default || appHost; + var credentialProviderInstance = new credentialProvider(); - var promises = [appHost.default.init()]; + var promises = [appHost.init()]; return Promise.all(promises).then(function (responses) { var capabilities = Dashboard.capabilities(appHost); - var connectionManager = new ConnectionManager(credentialProviderInstance, appHost.default.appName(), appHost.default.appVersion(), appHost.default.deviceName(), appHost.default.deviceId(), capabilities); + var connectionManager = new ConnectionManager(credentialProviderInstance, appHost.appName(), appHost.appVersion(), appHost.deviceName(), appHost.deviceId(), capabilities); defineConnectionManager(connectionManager); bindConnectionManagerEvents(connectionManager, events, userSettings); @@ -289,7 +291,7 @@ function initClient() { return require(['apiclient'], function (apiClientFactory) { console.debug('creating ApiClient singleton'); - var apiClient = new apiClientFactory(Dashboard.serverAddress(), appHost.default.appName(), appHost.default.appVersion(), appHost.default.deviceName(), appHost.default.deviceId()); + var apiClient = new apiClientFactory(Dashboard.serverAddress(), appHost.appName(), appHost.appVersion(), appHost.deviceName(), appHost.deviceId()); apiClient.enableAutomaticNetworking = false; apiClient.manualAddressOnly = true; @@ -468,6 +470,8 @@ function initClient() { } require(['apphost', 'css!assets/css/librarybrowser'], function (appHost) { + appHost = appHost.default || appHost; + loadPlugins(appHost, browser).then(function () { onAppReady(browser); }); @@ -480,7 +484,7 @@ function initClient() { require(['webSettings'], function (webSettings) { webSettings.getPlugins().then(function (list) { // these two plugins are dependent on features - if (!appHost.default.supports('remotecontrol')) { + if (!appHost.supports('remotecontrol')) { list.splice(list.indexOf('sessionPlayer'), 1); if (!browser.chrome && !browser.opera) { @@ -516,6 +520,8 @@ function initClient() { // ensure that appHost is loaded in this point require(['apphost', 'appRouter'], function (appHost, appRouter) { + appHost = appHost.default || appHost; + window.Emby = {}; console.debug('onAppReady: loading dependencies'); @@ -537,13 +543,13 @@ function initClient() { require(['components/nowPlayingBar/nowPlayingBar']); } - if (appHost.default.supports('remotecontrol')) { + if (appHost.supports('remotecontrol')) { require(['playerSelectionMenu', 'components/playback/remotecontrolautoplay']); } require(['libraries/screensavermanager']); - if (!appHost.default.supports('physicalvolumecontrol') || browser.touch) { + if (!appHost.supports('physicalvolumecontrol') || browser.touch) { require(['components/playback/volumeosd']); } From c328d68928e95afd0d37b3dfc0cb47eb9ca14920 Mon Sep 17 00:00:00 2001 From: dkanada Date: Sun, 9 Aug 2020 22:55:32 +0900 Subject: [PATCH 125/301] fix some odd strings --- src/strings/en-us.json | 38 +++++++++++++++++++------------------- 1 file changed, 19 insertions(+), 19 deletions(-) diff --git a/src/strings/en-us.json b/src/strings/en-us.json index 638be2efaf..78c96fcc56 100644 --- a/src/strings/en-us.json +++ b/src/strings/en-us.json @@ -27,7 +27,7 @@ "AllowOnTheFlySubtitleExtractionHelp": "Embedded subtitles can be extracted from videos and delivered to clients in plain text, in order to help prevent video transcoding. On some systems this can take a long time and cause video playback to stall during the extraction process. Disable this to have embedded subtitles burned in with video transcoding when they are not natively supported by the client device.", "AllowFfmpegThrottling": "Throttle Transcodes", "AllowFfmpegThrottlingHelp": "When a transcode or remux gets far enough ahead from the current playback position, pause the process so it will consume less resources. This is most useful when watching without seeking often. Turn this off if you experience playback issues.", - "AllowRemoteAccess": "Allow remote connections to this Jellyfin Server.", + "AllowRemoteAccess": "Allow remote connections to this server.", "AllowRemoteAccessHelp": "If unchecked, all remote connections will be blocked.", "AllowedRemoteAddressesHelp": "Comma separated list of IP addresses or IP/netmask entries for networks that will be allowed to connect remotely. If left blank, all remote addresses will be allowed.", "AlwaysPlaySubtitles": "Always Play", @@ -156,7 +156,7 @@ "ColorTransfer": "Color transfer", "CommunityRating": "Community rating", "Composer": "Composer", - "ConfigureDateAdded": "Configure how date added is determined in the Jellyfin Server dashboard under Library settings", + "ConfigureDateAdded": "Configure how date added is determined in the dashboard under the library settings", "ConfirmDeleteImage": "Delete image?", "ConfirmDeleteItem": "Deleting this item will delete it from both the file system and your media library. Are you sure you wish to continue?", "ConfirmDeleteItems": "Deleting these items will delete them from both the file system and your media library. Are you sure you wish to continue?", @@ -243,10 +243,10 @@ "Episode": "Episode", "Episodes": "Episodes", "ErrorAddingListingsToSchedulesDirect": "There was an error adding the lineup to your Schedules Direct account. Schedules Direct only allows a limited number of lineups per account. You may need to log into the Schedules Direct website and remove others listings from your account before proceeding.", - "ErrorAddingMediaPathToVirtualFolder": "There was an error adding the media path. Please ensure the path is valid and the Jellyfin Server process has access to that location.", + "ErrorAddingMediaPathToVirtualFolder": "There was an error adding the media path. Please ensure the path is valid and Jellyfin has access to that location.", "ErrorAddingTunerDevice": "There was an error adding the tuner device. Please ensure it is accessible and try again.", "ErrorAddingXmlTvFile": "There was an error accessing the XMLTV file. Please ensure the file exists and try again.", - "ErrorDeletingItem": "There was an error deleting the item from Jellyfin Server. Please check that Jellyfin Server has write access to the media folder and try again.", + "ErrorDeletingItem": "There was an error deleting the item from the server. Please check that Jellyfin has write access to the media folder and try again.", "ErrorGettingTvLineups": "There was an error downloading TV lineups. Please ensure your information is correct and try again.", "ErrorStartHourGreaterThanEnd": "End time must be greater than the start time.", "ErrorPleaseSelectLineup": "Please select a lineup and try again. If no lineups are available, then please check that your username, password, and postal code is correct.", @@ -568,7 +568,7 @@ "LabelAuthProvider": "Authentication Provider:", "LabelAutomaticallyRefreshInternetMetadataEvery": "Automatically refresh metadata from the internet:", "LabelBindToLocalNetworkAddress": "Bind to local network address:", - "LabelBindToLocalNetworkAddressHelp": "Override the local IP address for the HTTP server. If left empty, the server will bind to all availabile addresses. Changing this value requires restarting Jellyfin Server.", + "LabelBindToLocalNetworkAddressHelp": "Override the local IP address for the HTTP server. If left empty, the server will bind to all availabile addresses. Changing this value requires a restart.", "LabelBirthDate": "Birth date:", "LabelBirthYear": "Birth year:", "LabelBitrate": "Bitrate:", @@ -632,7 +632,7 @@ "LabelEnableBlastAliveMessages": "Blast alive messages", "LabelEnableBlastAliveMessagesHelp": "Enable this if the server is not detected reliably by other UPnP devices on your network.", "LabelEnableDlnaClientDiscoveryInterval": "Client discovery interval", - "LabelEnableDlnaClientDiscoveryIntervalHelp": "Determines the duration in seconds between SSDP searches performed by Jellyfin.", + "LabelEnableDlnaClientDiscoveryIntervalHelp": "Determines the duration in seconds between SSDP searches.", "LabelEnableDlnaDebugLogging": "Enable DLNA debug logging", "LabelEnableDlnaDebugLoggingHelp": "Create large log files and should only be used as needed for troubleshooting purposes.", "LabelEnableDlnaPlayTo": "Enable DLNA Play To", @@ -761,7 +761,7 @@ "LabelNumberOfGuideDays": "Number of days of guide data to download:", "LabelNumberOfGuideDaysHelp": "Downloading more days worth of guide data provides the ability to schedule out further in advance and view more listings, but it will also take longer to download. Auto will choose based on the number of channels.", "LabelOptionalNetworkPath": "Shared network folder:", - "LabelOptionalNetworkPathHelp": "If this folder is shared on your network, supplying the network share path can allow Jellyfin apps on other devices to access media files directly. For example, {0} or {1}.", + "LabelOptionalNetworkPathHelp": "If this folder is shared on your network, supplying the network share path can allow clients on other devices to access media files directly. For example, {0} or {1}.", "LabelOriginalAspectRatio": "Original aspect ratio:", "LabelOriginalTitle": "Original title:", "LabelOverview": "Overview:", @@ -984,13 +984,13 @@ "MessageConfirmProfileDeletion": "Are you sure you wish to delete this profile?", "MessageConfirmRecordingCancellation": "Cancel recording?", "MessageConfirmRemoveMediaLocation": "Are you sure you wish to remove this location?", - "MessageConfirmRestart": "Are you sure you wish to restart Jellyfin Server?", - "MessageConfirmRevokeApiKey": "Are you sure you wish to revoke this api key? The application's connection to Jellyfin Server will be abruptly terminated.", + "MessageConfirmRestart": "Are you sure you wish to restart Jellyfin?", + "MessageConfirmRevokeApiKey": "Are you sure you wish to revoke this API key? The application's connection to this server will be abruptly terminated.", "MessageConfirmShutdown": "Are you sure you wish to shutdown the server?", "MessageContactAdminToResetPassword": "Please contact your system administrator to reset your password.", "MessageCreateAccountAt": "Create an account at {0}", "MessageDeleteTaskTrigger": "Are you sure you wish to delete this task trigger?", - "MessageDirectoryPickerBSDInstruction": "For BSD, you may need to configure storage within your FreeNAS Jail in order to allow Jellyfin to access it.", + "MessageDirectoryPickerBSDInstruction": "For BSD, you may need to configure storage within your FreeNAS Jail so Jellyfin can access your media.", "MessageDirectoryPickerLinuxInstruction": "For Linux on Arch Linux, CentOS, Debian, Fedora, openSUSE, or Ubuntu, you must grant the service user at least read access to your storage locations.", "MessageDownloadQueued": "Download queued.", "MessageEnablingOptionLongerScans": "Enabling this option may result in significantly longer library scans.", @@ -1024,7 +1024,7 @@ "MessagePleaseEnsureInternetMetadata": "Please ensure downloading of internet metadata is enabled.", "MessagePleaseWait": "Please wait. This may take a minute.", "MessagePluginConfigurationRequiresLocalAccess": "To configure this plugin please sign in to your local server directly.", - "MessagePluginInstallDisclaimer": "Plugins built by Jellyfin community members are a great way to enhance your Jellyfin experience with additional features and benefits. Before installing, please be aware of the effects they may have on your Jellyfin Server, such as longer library scans, additional background processing, and decreased system stability.", + "MessagePluginInstallDisclaimer": "Plugins built by community members are a great way to enhance your experience with additional features and benefits. Before installing, please be aware of the effects they may have on your server, such as longer library scans, additional background processing, and decreased system stability.", "MessageReenableUser": "See below to reenable", "MessageSettingsSaved": "Settings saved.", "MessageTheFollowingLocationWillBeRemovedFromLibrary": "The following media locations will be removed from your library:", @@ -1229,7 +1229,7 @@ "OptionRuntime": "Runtime", "OptionSaturday": "Saturday", "OptionSaveMetadataAsHidden": "Save metadata and images as hidden files", - "OptionSaveMetadataAsHiddenHelp": "Changing this will apply to new metadata saved going forward. Existing metadata files will be updated the next time they are saved by Jellyfin Server.", + "OptionSaveMetadataAsHiddenHelp": "Changing this will apply to new metadata saved going forward. Existing metadata files will be updated the next time they are saved by the server.", "OptionSpecialEpisode": "Specials", "OptionSubstring": "Substring", "OptionSunday": "Sunday", @@ -1279,9 +1279,9 @@ "PleaseAddAtLeastOneFolder": "Please add at least one folder to this library by clicking the Add button.", "PleaseConfirmPluginInstallation": "Please click OK to confirm you've read the above and wish to proceed with the plugin installation.", "PleaseEnterNameOrId": "Please enter a name or an external ID.", - "PleaseRestartServerName": "Please restart Jellyfin Server - {0}.", + "PleaseRestartServerName": "Please restart Jellyfin on {0}.", "PleaseSelectTwoItems": "Please select at least two items.", - "MessagePluginInstalled": "The plugin has been successfully installed. Jellyfin Server will need to be restarted for changes to take effect.", + "MessagePluginInstalled": "The plugin has been successfully installed. The server will need to be restarted for changes to take effect.", "MessagePluginInstallError": "An error occured while installing the plugin.", "MessageGetInstalledPluginsError": "An error occured while getting the list of currently installed plugins.", "PreferEmbeddedTitlesOverFileNames": "Prefer embedded titles over filenames", @@ -1352,10 +1352,10 @@ "SeriesRecordingScheduled": "Series recording scheduled.", "SeriesSettings": "Series settings", "SeriesYearToPresent": "{0} - Present", - "ServerNameIsRestarting": "Jellyfin Server - {0} is restarting.", - "ServerNameIsShuttingDown": "Jellyfin Server - {0} is shutting down.", - "ServerRestartNeededAfterPluginInstall": "Jellyfin Server will need to be restarted after installing a plugin.", - "ServerUpdateNeeded": "This Jellyfin Server needs to be updated. To download the latest version, please visit {0}", + "ServerNameIsRestarting": "The server at {0} is restarting.", + "ServerNameIsShuttingDown": "The server at {0} is shutting down.", + "ServerRestartNeededAfterPluginInstall": "Jellyfin will need to be restarted after installing a plugin.", + "ServerUpdateNeeded": "This server needs to be updated. To download the latest version, please visit {0}", "Settings": "Settings", "SettingsSaved": "Settings saved.", "SettingsWarning": "Changing these values may cause instability or connectivity failures. If you experience any problems, we recommend changing them back to default.", @@ -1526,7 +1526,7 @@ "Yes": "Yes", "Yesterday": "Yesterday", "PathNotFound": "The path could not be found. Please ensure the path is valid and try again.", - "WriteAccessRequired": "Jellyfin Server requires write access to this folder. Please ensure write access and try again.", + "WriteAccessRequired": "Jellyfin requires write access to this folder. Please ensure write access and try again.", "ListPaging": "{0}-{1} of {2}", "PersonRole": "as {0}", "LastSeen": "Last seen {0}", From 23d0f25c7467b441a77ba65a9b24047841702e52 Mon Sep 17 00:00:00 2001 From: dkanada Date: Sun, 9 Aug 2020 23:10:58 +0900 Subject: [PATCH 126/301] remove some duplicate strings from the source --- .../accessSchedule/accessSchedule.template.html | 2 +- .../filterdialog/filterdialog.template.html | 6 +++--- .../mediaLibraryCreator.template.html | 2 +- .../mediaLibraryEditor.template.html | 2 +- .../playbackSettings/playbackSettings.template.html | 2 +- .../tvproviders/schedulesdirect.template.html | 4 ++-- src/components/tvproviders/xmltv.template.html | 2 +- src/controllers/dashboard/apikeys.html | 2 +- src/controllers/dashboard/devices/device.html | 2 +- src/controllers/dashboard/dlna/profile.html | 12 ++++++------ src/controllers/dashboard/dlna/profile.js | 2 +- src/controllers/dashboard/dlna/settings.html | 2 +- src/controllers/dashboard/encodingsettings.html | 4 ++-- src/controllers/dashboard/general.html | 2 +- src/controllers/dashboard/library.js | 4 ++-- src/controllers/dashboard/librarydisplay.html | 2 +- src/controllers/dashboard/librarydisplay.js | 4 ++-- src/controllers/dashboard/metadataImages.js | 4 ++-- src/controllers/dashboard/metadataimages.html | 2 +- src/controllers/dashboard/metadatanfo.html | 2 +- src/controllers/dashboard/metadatanfo.js | 4 ++-- src/controllers/dashboard/networking.html | 2 +- .../dashboard/notifications/notification/index.html | 2 +- src/controllers/dashboard/playback.html | 2 +- .../dashboard/plugins/repositories/index.html | 2 +- .../dashboard/plugins/repositories/index.js | 2 +- .../dashboard/scheduledtasks/scheduledtask.html | 2 +- src/controllers/dashboard/streaming.html | 2 +- src/controllers/dashboard/users/useredit.html | 2 +- .../dashboard/users/userlibraryaccess.html | 2 +- src/controllers/dashboard/users/usernew.html | 2 +- .../dashboard/users/userparentalcontrol.html | 6 +++--- src/controllers/dashboard/users/userpassword.html | 4 ++-- src/controllers/livetvsettings.html | 2 +- src/controllers/livetvstatus.html | 4 ++-- src/controllers/livetvtuner.html | 2 +- src/controllers/movies/moviesrecommended.js | 2 +- src/controllers/music/musicrecommended.js | 4 ++-- src/controllers/playback/queue/index.html | 10 +++++----- src/controllers/search.html | 2 +- src/controllers/shows/tvrecommended.js | 2 +- src/controllers/user/display/index.html | 2 +- src/controllers/user/menu/index.html | 2 +- src/controllers/user/profile/index.html | 4 ++-- src/controllers/wizard/library.html | 2 +- src/scripts/itembynamedetailpage.js | 2 +- src/scripts/libraryMenu.js | 4 ++-- 47 files changed, 71 insertions(+), 71 deletions(-) diff --git a/src/components/accessSchedule/accessSchedule.template.html b/src/components/accessSchedule/accessSchedule.template.html index 493150ae5e..d89b69d9bd 100644 --- a/src/components/accessSchedule/accessSchedule.template.html +++ b/src/components/accessSchedule/accessSchedule.template.html @@ -33,7 +33,7 @@
    diff --git a/src/components/filterdialog/filterdialog.template.html b/src/components/filterdialog/filterdialog.template.html index 20f0f2fc91..f4bbfe7395 100644 --- a/src/components/filterdialog/filterdialog.template.html +++ b/src/components/filterdialog/filterdialog.template.html @@ -1,6 +1,6 @@
    -
    +
    -
    +
    -
    +
    diff --git a/src/components/mediaLibraryCreator/mediaLibraryCreator.template.html b/src/components/mediaLibraryCreator/mediaLibraryCreator.template.html index f92a63e403..2884ce256c 100644 --- a/src/components/mediaLibraryCreator/mediaLibraryCreator.template.html +++ b/src/components/mediaLibraryCreator/mediaLibraryCreator.template.html @@ -25,7 +25,7 @@

    ${HeadersFolders}

    -
    diff --git a/src/components/mediaLibraryEditor/mediaLibraryEditor.template.html b/src/components/mediaLibraryEditor/mediaLibraryEditor.template.html index 6c814cf2dd..ae7d65e1e5 100644 --- a/src/components/mediaLibraryEditor/mediaLibraryEditor.template.html +++ b/src/components/mediaLibraryEditor/mediaLibraryEditor.template.html @@ -19,7 +19,7 @@

    ${HeadersFolders}

    -
    diff --git a/src/components/playbackSettings/playbackSettings.template.html b/src/components/playbackSettings/playbackSettings.template.html index 700215223d..d10b069bb2 100644 --- a/src/components/playbackSettings/playbackSettings.template.html +++ b/src/components/playbackSettings/playbackSettings.template.html @@ -99,6 +99,6 @@
    diff --git a/src/components/tvproviders/schedulesdirect.template.html b/src/components/tvproviders/schedulesdirect.template.html index abe19b50f5..8783987875 100644 --- a/src/components/tvproviders/schedulesdirect.template.html +++ b/src/components/tvproviders/schedulesdirect.template.html @@ -27,7 +27,7 @@
    - +
    @@ -65,7 +65,7 @@

    - +
    diff --git a/src/components/tvproviders/xmltv.template.html b/src/components/tvproviders/xmltv.template.html index 72c29904b3..010e66ea0d 100644 --- a/src/components/tvproviders/xmltv.template.html +++ b/src/components/tvproviders/xmltv.template.html @@ -56,7 +56,7 @@
    - +
    diff --git a/src/controllers/dashboard/apikeys.html b/src/controllers/dashboard/apikeys.html index 3cb7cd6de1..400a3e5f60 100644 --- a/src/controllers/dashboard/apikeys.html +++ b/src/controllers/dashboard/apikeys.html @@ -3,7 +3,7 @@

    ${HeaderApiKeys}

    -
    diff --git a/src/controllers/dashboard/devices/device.html b/src/controllers/dashboard/devices/device.html index 093b311208..4d8fb86537 100644 --- a/src/controllers/dashboard/devices/device.html +++ b/src/controllers/dashboard/devices/device.html @@ -15,7 +15,7 @@
    diff --git a/src/controllers/dashboard/dlna/profile.html b/src/controllers/dashboard/dlna/profile.html index 01636e6019..02a85b4ec7 100644 --- a/src/controllers/dashboard/dlna/profile.html +++ b/src/controllers/dashboard/dlna/profile.html @@ -10,7 +10,7 @@

    ${HeaderHttpHeaders}

    -
    -
    +

    @@ -209,7 +209,7 @@

    ${HeaderSubtitleProfilesHelp}


    @@ -219,7 +219,7 @@

    ${HeaderXmlDocumentAttributes}

    -
    @@ -262,7 +262,7 @@
    diff --git a/src/controllers/dashboard/encodingsettings.html b/src/controllers/dashboard/encodingsettings.html index 858375b145..402532e600 100644 --- a/src/controllers/dashboard/encodingsettings.html +++ b/src/controllers/dashboard/encodingsettings.html @@ -4,7 +4,7 @@
    -

    ${TabTranscoding}

    +

    ${Transcoding}

    ${Help}
    @@ -176,7 +176,7 @@
    diff --git a/src/controllers/dashboard/general.html b/src/controllers/dashboard/general.html index 99e6414dd6..9ac0a90832 100644 --- a/src/controllers/dashboard/general.html +++ b/src/controllers/dashboard/general.html @@ -63,7 +63,7 @@
    diff --git a/src/controllers/dashboard/library.js b/src/controllers/dashboard/library.js index 4fee65e674..0400df7570 100644 --- a/src/controllers/dashboard/library.js +++ b/src/controllers/dashboard/library.js @@ -363,10 +363,10 @@ import 'emby-itemrefreshindicator'; name: globalize.translate('HeaderLibraries') }, { href: 'librarydisplay.html', - name: globalize.translate('TabDisplay') + name: globalize.translate('Display') }, { href: 'metadataimages.html', - name: globalize.translate('TabMetadata') + name: globalize.translate('Metadata') }, { href: 'metadatanfo.html', name: globalize.translate('TabNfoSettings') diff --git a/src/controllers/dashboard/librarydisplay.html b/src/controllers/dashboard/librarydisplay.html index 25dce48223..04a8554823 100644 --- a/src/controllers/dashboard/librarydisplay.html +++ b/src/controllers/dashboard/librarydisplay.html @@ -49,7 +49,7 @@
    diff --git a/src/controllers/dashboard/librarydisplay.js b/src/controllers/dashboard/librarydisplay.js index bbc7e633d1..06e366b988 100644 --- a/src/controllers/dashboard/librarydisplay.js +++ b/src/controllers/dashboard/librarydisplay.js @@ -12,10 +12,10 @@ import 'emby-button'; name: globalize.translate('HeaderLibraries') }, { href: 'librarydisplay.html', - name: globalize.translate('TabDisplay') + name: globalize.translate('Display') }, { href: 'metadataimages.html', - name: globalize.translate('TabMetadata') + name: globalize.translate('Metadata') }, { href: 'metadatanfo.html', name: globalize.translate('TabNfoSettings') diff --git a/src/controllers/dashboard/metadataImages.js b/src/controllers/dashboard/metadataImages.js index 02e01736ea..649ca9ac31 100644 --- a/src/controllers/dashboard/metadataImages.js +++ b/src/controllers/dashboard/metadataImages.js @@ -55,10 +55,10 @@ import 'listViewStyle'; name: globalize.translate('HeaderLibraries') }, { href: 'librarydisplay.html', - name: globalize.translate('TabDisplay') + name: globalize.translate('Display') }, { href: 'metadataimages.html', - name: globalize.translate('TabMetadata') + name: globalize.translate('Metadata') }, { href: 'metadatanfo.html', name: globalize.translate('TabNfoSettings') diff --git a/src/controllers/dashboard/metadataimages.html b/src/controllers/dashboard/metadataimages.html index 8ad129256c..48a9977054 100644 --- a/src/controllers/dashboard/metadataimages.html +++ b/src/controllers/dashboard/metadataimages.html @@ -17,7 +17,7 @@

    -
    +
    diff --git a/src/controllers/dashboard/metadatanfo.html b/src/controllers/dashboard/metadatanfo.html index 4005c74f67..44d1cc06f6 100644 --- a/src/controllers/dashboard/metadatanfo.html +++ b/src/controllers/dashboard/metadatanfo.html @@ -41,7 +41,7 @@
    ${LabelKodiMetadataEnableExtraThumbsHelp}
    -
    +
    diff --git a/src/controllers/dashboard/metadatanfo.js b/src/controllers/dashboard/metadatanfo.js index f1b768d18b..f33971b369 100644 --- a/src/controllers/dashboard/metadatanfo.js +++ b/src/controllers/dashboard/metadatanfo.js @@ -52,10 +52,10 @@ import globalize from 'globalize'; name: globalize.translate('HeaderLibraries') }, { href: 'librarydisplay.html', - name: globalize.translate('TabDisplay') + name: globalize.translate('Display') }, { href: 'metadataimages.html', - name: globalize.translate('TabMetadata') + name: globalize.translate('Metadata') }, { href: 'metadatanfo.html', name: globalize.translate('TabNfoSettings') diff --git a/src/controllers/dashboard/networking.html b/src/controllers/dashboard/networking.html index 74ddefb87b..899d0976b7 100644 --- a/src/controllers/dashboard/networking.html +++ b/src/controllers/dashboard/networking.html @@ -112,7 +112,7 @@
    diff --git a/src/controllers/dashboard/notifications/notification/index.html b/src/controllers/dashboard/notifications/notification/index.html index 67b35981f1..99bed59887 100644 --- a/src/controllers/dashboard/notifications/notification/index.html +++ b/src/controllers/dashboard/notifications/notification/index.html @@ -54,7 +54,7 @@

    -
    +
    diff --git a/src/controllers/dashboard/plugins/repositories/index.html b/src/controllers/dashboard/plugins/repositories/index.html index ff3406fb95..cea20d5a4a 100644 --- a/src/controllers/dashboard/plugins/repositories/index.html +++ b/src/controllers/dashboard/plugins/repositories/index.html @@ -3,7 +3,7 @@

    ${TabRepositories}

    -
    diff --git a/src/controllers/dashboard/plugins/repositories/index.js b/src/controllers/dashboard/plugins/repositories/index.js index 3087cdd927..2fefb0a9e8 100644 --- a/src/controllers/dashboard/plugins/repositories/index.js +++ b/src/controllers/dashboard/plugins/repositories/index.js @@ -127,7 +127,7 @@ export default function(view, params) { html += ``; html += `
    ${globalize.translate('LabelRepositoryUrlHelp')}
    `; html += '
    '; - html += ``; + html += ``; html += '
    '; html += ''; diff --git a/src/controllers/dashboard/scheduledtasks/scheduledtask.html b/src/controllers/dashboard/scheduledtasks/scheduledtask.html index c7e82594ce..4dab484905 100644 --- a/src/controllers/dashboard/scheduledtasks/scheduledtask.html +++ b/src/controllers/dashboard/scheduledtasks/scheduledtask.html @@ -73,7 +73,7 @@
    diff --git a/src/controllers/dashboard/users/useredit.html b/src/controllers/dashboard/users/useredit.html index c3a613bed4..a097144cc3 100644 --- a/src/controllers/dashboard/users/useredit.html +++ b/src/controllers/dashboard/users/useredit.html @@ -192,7 +192,7 @@
    diff --git a/src/controllers/dashboard/users/usernew.html b/src/controllers/dashboard/users/usernew.html index fac036aa8d..26142c9ca2 100644 --- a/src/controllers/dashboard/users/usernew.html +++ b/src/controllers/dashboard/users/usernew.html @@ -49,7 +49,7 @@
    @@ -40,7 +40,7 @@

    ${HeaderAccessSchedule}

    -
    @@ -51,7 +51,7 @@
    diff --git a/src/controllers/dashboard/users/userpassword.html b/src/controllers/dashboard/users/userpassword.html index 119a0212de..51df2e2cb0 100644 --- a/src/controllers/dashboard/users/userpassword.html +++ b/src/controllers/dashboard/users/userpassword.html @@ -29,7 +29,7 @@

    - + @@ -58,7 +58,7 @@

    - +
    diff --git a/src/controllers/livetvstatus.html b/src/controllers/livetvstatus.html index 3aa27637d0..1a894bff94 100644 --- a/src/controllers/livetvstatus.html +++ b/src/controllers/livetvstatus.html @@ -7,7 +7,7 @@

    ${HeaderTunerDevices}

    - ${Help} @@ -20,7 +20,7 @@

    ${HeaderGuideProviders}

    -
    diff --git a/src/controllers/livetvtuner.html b/src/controllers/livetvtuner.html index f45a3a1d04..eab958c1c0 100644 --- a/src/controllers/livetvtuner.html +++ b/src/controllers/livetvtuner.html @@ -67,7 +67,7 @@
    @@ -85,7 +85,7 @@ - @@ -132,7 +132,7 @@ - - -
    diff --git a/src/controllers/search.html b/src/controllers/search.html index acf65e7317..b0277aa7e0 100644 --- a/src/controllers/search.html +++ b/src/controllers/search.html @@ -1,4 +1,4 @@ -
    +
    diff --git a/src/controllers/shows/tvrecommended.js b/src/controllers/shows/tvrecommended.js index 585449d0c0..c519e0ac58 100644 --- a/src/controllers/shows/tvrecommended.js +++ b/src/controllers/shows/tvrecommended.js @@ -19,7 +19,7 @@ import 'emby-button'; return [{ name: globalize.translate('TabShows') }, { - name: globalize.translate('TabSuggestions') + name: globalize.translate('Suggestions') }, { name: globalize.translate('TabLatest') }, { diff --git a/src/controllers/user/display/index.html b/src/controllers/user/display/index.html index bee49754af..5482b62fe8 100644 --- a/src/controllers/user/display/index.html +++ b/src/controllers/user/display/index.html @@ -1,4 +1,4 @@ -
    +
    diff --git a/src/controllers/user/menu/index.html b/src/controllers/user/menu/index.html index 2c3ca0edd9..851a817203 100644 --- a/src/controllers/user/menu/index.html +++ b/src/controllers/user/menu/index.html @@ -16,7 +16,7 @@
    -
    ${HeaderDisplay}
    +
    ${Display}
    diff --git a/src/controllers/user/profile/index.html b/src/controllers/user/profile/index.html index 3765ac5e75..59eb7d416f 100644 --- a/src/controllers/user/profile/index.html +++ b/src/controllers/user/profile/index.html @@ -32,7 +32,7 @@
    +

    diff --git a/src/scripts/itembynamedetailpage.js b/src/scripts/itembynamedetailpage.js index eaeecba275..b4f3c4db96 100644 --- a/src/scripts/itembynamedetailpage.js +++ b/src/scripts/itembynamedetailpage.js @@ -6,7 +6,7 @@ define(['connectionManager', 'listView', 'cardBuilder', 'imageLoader', 'libraryB if (item.ArtistCount) { sections.push({ - name: globalize.translate('TabArtists'), + name: globalize.translate('Artists'), type: 'MusicArtist' }); } diff --git a/src/scripts/libraryMenu.js b/src/scripts/libraryMenu.js index ec572752b9..543aa6f3d0 100644 --- a/src/scripts/libraryMenu.js +++ b/src/scripts/libraryMenu.js @@ -33,7 +33,7 @@ import 'flexStyles'; html += ``; html += ``; html += ``; - html += ``; + html += ``; html += ''; html += '
    '; html += '
    '; @@ -387,7 +387,7 @@ import 'flexStyles'; pageIds: ['mediaLibraryPage', 'librarySettingsPage', 'libraryDisplayPage', 'metadataImagesConfigurationPage', 'metadataNfoPage'], icon: 'folder' }, { - name: globalize.translate('TabPlayback'), + name: globalize.translate('TitlePlayback'), icon: 'play_arrow', href: 'encodingsettings.html', pageIds: ['encodingSettingsPage', 'playbackConfigurationPage', 'streamingSettingsPage'] From 67723291d58af7c8233a1a8d20cc03db9c80208d Mon Sep 17 00:00:00 2001 From: dkanada Date: Sun, 9 Aug 2020 23:11:52 +0900 Subject: [PATCH 127/301] update translation files --- src/strings/af.json | 5 ----- src/strings/ar.json | 17 ----------------- src/strings/bg-bg.json | 17 ----------------- src/strings/ca.json | 15 --------------- src/strings/cs.json | 17 ----------------- src/strings/da.json | 17 ----------------- src/strings/de.json | 17 ----------------- src/strings/el.json | 17 ----------------- src/strings/en-gb.json | 17 ----------------- src/strings/en-us.json | 17 ----------------- src/strings/es-ar.json | 17 ----------------- src/strings/es-mx.json | 17 ----------------- src/strings/es.json | 17 ----------------- src/strings/es_419.json | 17 ----------------- src/strings/fa.json | 17 ----------------- src/strings/fi.json | 17 ----------------- src/strings/fr-ca.json | 6 ------ src/strings/fr.json | 17 ----------------- src/strings/gsw.json | 4 ---- src/strings/he.json | 13 ------------- src/strings/hi-in.json | 2 -- src/strings/hr.json | 17 ----------------- src/strings/hu.json | 17 ----------------- src/strings/id.json | 5 ----- src/strings/is-is.json | 11 ----------- src/strings/it.json | 17 ----------------- src/strings/ja.json | 17 ----------------- src/strings/kk.json | 17 ----------------- src/strings/ko.json | 17 ----------------- src/strings/lt-lt.json | 15 --------------- src/strings/lv.json | 17 ----------------- src/strings/mr.json | 3 --- src/strings/ms.json | 2 -- src/strings/nb.json | 17 ----------------- src/strings/nl.json | 17 ----------------- src/strings/pl.json | 17 ----------------- src/strings/pt-br.json | 17 ----------------- src/strings/pt-pt.json | 17 ----------------- src/strings/pt.json | 17 ----------------- src/strings/ro.json | 17 ----------------- src/strings/ru.json | 17 ----------------- src/strings/sk.json | 17 ----------------- src/strings/sl-si.json | 17 ----------------- src/strings/sr.json | 5 ----- src/strings/sv.json | 17 ----------------- src/strings/tr.json | 13 ------------- src/strings/uk.json | 2 -- src/strings/vi.json | 13 ------------- src/strings/zh-cn.json | 17 ----------------- src/strings/zh-hk.json | 11 ----------- src/strings/zh-tw.json | 17 ----------------- 51 files changed, 720 deletions(-) diff --git a/src/strings/af.json b/src/strings/af.json index 3b82f0363c..8e34e87d60 100644 --- a/src/strings/af.json +++ b/src/strings/af.json @@ -47,7 +47,6 @@ "TabGenres": "Genres", "TabFavorites": "Gunstellinge", "TabEpisodes": "Episodes", - "TabDisplay": "Vertoon", "TabDirectPlay": "Speel Direk", "TabDevices": "Toestelle", "TabDashboard": "Paneelbord", @@ -131,9 +130,7 @@ "TellUsAboutYourself": "Vertel ons van jouself", "TabUsers": "Gebruikers", "TabUpcoming": "Komende", - "TabTranscoding": "Transkodering", "TabTrailers": "Voorprente", - "TabSuggestions": "Voorstelle", "TabStreaming": "Stroom", "TabSongs": "Liedjies", "TabShows": "Programme", @@ -147,7 +144,6 @@ "TabProfiles": "Profiele", "TabProfile": "Profiel", "TabPlaylists": "Speel lyste", - "TabPlayback": "Terugspeel", "TabPassword": "Wagwoord", "TabParentalControl": "Ouer Beheer", "TabOther": "Ander", @@ -158,7 +154,6 @@ "TabMusicVideos": "Musiek Videos", "TabMusic": "Musiek", "TabMovies": "Rolprente", - "TabMetadata": "Meta Inligting", "TabLogs": "Logs", "TabLiveTV": "Lewendige TV" } diff --git a/src/strings/ar.json b/src/strings/ar.json index eb7d6f4249..862c985c85 100644 --- a/src/strings/ar.json +++ b/src/strings/ar.json @@ -11,7 +11,6 @@ "BirthPlaceValue": "مكان الميلاد: {0}", "Browse": "تصفح", "MessageBrowsePluginCatalog": "تصفح قائمتنا للملحق لترى المتوفر من الملاحق.", - "ButtonAdd": "إضافة", "ButtonAddMediaLibrary": "إضافة مكتبة وسائط", "ButtonAddScheduledTaskTrigger": "إضافة زناد", "ButtonAddServer": "إضافة خادم", @@ -36,7 +35,6 @@ "ButtonForgotPassword": "نسيت كلمة السر", "ButtonFullscreen": "ملء الشاشة", "ButtonGuide": "الدليل", - "ButtonHelp": "المساعدة", "ButtonHome": "الرئيسية", "ButtonInfo": "معلومات", "ButtonLibraryAccess": "صلاحيات المكتبة", @@ -58,14 +56,11 @@ "ButtonRefreshGuideData": "إعادة تنشيط بيانات الدليل", "ButtonRemove": "إزالة", "ButtonRename": "إعادة التسمية", - "ButtonRepeat": "كرر", "ButtonResetEasyPassword": "إعادة تهيئة الرمز الشخصي الميسر", "ButtonResetPassword": "إعادة تهيئة كلمة السر", "ButtonRestart": "إعادة التشغيل", "ButtonResume": "استأنف", "ButtonRevoke": "أرفض", - "ButtonSave": "حفظ", - "ButtonSearch": "بحث", "ButtonSelectDirectory": "إختر الدليلة", "ButtonSelectServer": "إختر الخادم", "ButtonSelectView": "إختر طريقة عرض", @@ -176,14 +171,11 @@ "HeaderDevices": "الأجهزة", "HeaderDirectPlayProfile": "عريضة التشغيل المباشر", "HeaderDirectPlayProfileHelp": "أضف مباشرةً عريضة تشغيل للإشارة لأي صيغة يتمكن الجهاز من التعامل معه بتلقائية.", - "HeaderDisplay": "إظهار", "HeaderEasyPinCode": "الرمز الشخصي الميسر", "HeaderEpisodes": "الحلقات", "HeaderError": "حدث خطأ", "HeaderFeatureAccess": "صلاحية الخاصية", - "HeaderFeatures": "المواصقات", "HeaderFetchImages": "إطهار الصور:", - "HeaderFilters": "مرشحات", "HeaderForKids": "للأطفال", "HeaderForgotPassword": "نسيت كلمة السر", "HeaderFrequentlyPlayed": "تم تشغيله مراراً", @@ -270,7 +262,6 @@ "HeaderSubtitleProfiles": "عرائض الترجمة", "HeaderSubtitleProfilesHelp": "عرائض الترجمة تصف صيغ الترجمة المدعومة على الأجهزة المختلفة.", "HeaderSystemDlnaProfiles": "عرائض النظام", - "HeaderTags": "البطاقات", "HeaderTaskTriggers": "زنادات المهام", "HeaderThisUserIsCurrentlyDisabled": "هذا المستخدم موقف حالياً", "HeaderTracks": "المقاطع الصوتية", @@ -307,7 +298,6 @@ "LabelAlbumArtMaxWidthHelp": "الدقة القصوى لرسومات الألبوم المظهّرة عبر سمة upnp:albumArtURI.", "LabelAlbumArtPN": "رسومات الألبوم PN:", "LabelAlbumArtists": "فنانو الألبومات:", - "LabelAll": "الجميع", "LabelAllowHWTranscoding": "السماح بالتشفير البيني بعتاد الحاسب", "LabelAppName": "اسم التطبيق", "LabelAppNameExample": "مثال: Sickbeard، Sonarr", @@ -796,7 +786,6 @@ "TabAdvanced": "متقدم", "TabAlbumArtists": "فنانو الألبومات", "TabAlbums": "الألبومات", - "TabArtists": "الفنانون", "TabCatalog": "الكتالوج", "TabChannels": "القنوات", "TabCodecs": "الكودكات", @@ -805,7 +794,6 @@ "TabDashboard": "لوحة العدادات", "TabDevices": "الأجهزة", "TabDirectPlay": "تشغيل مباشر", - "TabDisplay": "إظهار", "TabEpisodes": "الحلقات", "TabFavorites": "المفضلة", "TabGenres": "أنواع الأفلام", @@ -814,7 +802,6 @@ "TabLatest": "الاخير", "TabLiveTV": "التلفاز المباشر", "TabLogs": "الكشوفات", - "TabMetadata": "واصفات البيانات", "TabMovies": "الفيلم", "TabMusic": "الموسيقى", "TabMusicVideos": "الفيديوهات الموسيقية", @@ -825,7 +812,6 @@ "TabOther": "أخرى", "TabParentalControl": "التحكم الأبوي", "TabPassword": "كلمة السر", - "TabPlayback": "تشغيل", "TabPlaylists": "قوائم التشغيل", "TabPlugins": "الملحقات", "TabProfile": "عريضة", @@ -840,9 +826,7 @@ "TabShows": "المسلسلات", "TabSongs": "الاغانى", "TabStreaming": "التشغيل التدفقي", - "TabSuggestions": "مقترحات", "TabTrailers": "العروض الإعلانية", - "TabTranscoding": "التشفير البيني", "TabUpcoming": "القادم", "TabUsers": "المستخدمون", "TellUsAboutYourself": "اخبرنا عن نفسك", @@ -1057,7 +1041,6 @@ "ClientSettings": "إعدادات التطبيق", "ButtonTogglePlaylist": "قائمة التشغيل", "BoxSet": "طقم", - "ButtonToggleContextMenu": "المزيد", "ButtonSplit": "تقسيم", "AllowFfmpegThrottlingHelp": "عندما يتقدم رمز تحويل أو إعادة تحويل بعيدًا بما فيه الكفاية عن موضع التشغيل الحالي ، أوقف العملية مؤقتًا حتى تستهلك موارد أقل. هذا مفيد للغاية عند المشاهدة دون البحث كثيرًا. أوقف هذا إذا واجهت مشاكل في التشغيل.", "InstallingPackage": "تثبيت {0} (الإصدار {1})", diff --git a/src/strings/bg-bg.json b/src/strings/bg-bg.json index 6eee5e403b..20337a876a 100644 --- a/src/strings/bg-bg.json +++ b/src/strings/bg-bg.json @@ -20,7 +20,6 @@ "BirthPlaceValue": "Родно място: {0}", "Books": "Книги", "Browse": "Разглеждане", - "ButtonAdd": "Добавяне", "ButtonAddMediaLibrary": "Добавяне на библиотека", "ButtonAddScheduledTaskTrigger": "Добавяне на спусък", "ButtonAddServer": "Добавяне на сървър", @@ -41,7 +40,6 @@ "ButtonForgotPassword": "Забравена парола", "ButtonGotIt": "Добре", "ButtonGuide": "Справочник", - "ButtonHelp": "Помощ", "ButtonHome": "Начало", "ButtonInfo": "Сведения", "ButtonLibraryAccess": "Достъп до библиотеката", @@ -65,9 +63,7 @@ "ButtonResetPassword": "Зануляване на паролата", "ButtonRestart": "Повторно пускане", "ButtonResume": "Продължаване", - "ButtonSave": "Запазване", "ButtonScanAllLibraries": "Сканиране на всички библиотеки", - "ButtonSearch": "Търсене", "ButtonSelectDirectory": "Изберете папка", "ButtonSend": "Изпращане", "ButtonSettings": "Настройки", @@ -171,16 +167,13 @@ "HeaderDeviceAccess": "Достъп на устройствата", "HeaderDevices": "Устройства", "HeaderDirectPlayProfile": "Direct Play профил", - "HeaderDisplay": "Показване", "HeaderDownloadSync": "Изтегляне и синхронизиране", "HeaderEasyPinCode": "Лесен ПИН код", "HeaderEditImages": "Редактиране на изображенията", "HeaderEnabledFields": "Включени полета", "HeaderError": "Грешка", "HeaderFeatureAccess": "Достъп до функции", - "HeaderFeatures": "Функции", "HeaderFetchImages": "Свали изображения:", - "HeaderFilters": "Филтри", "HeaderForKids": "Детски", "HeaderForgotPassword": "Забравена парола", "HeaderFrequentlyPlayed": "Често пускани", @@ -253,7 +246,6 @@ "HeaderStatus": "Състояние", "HeaderSubtitleAppearance": "Облик на субтитрите", "HeaderSystemDlnaProfiles": "Системни профили", - "HeaderTags": "Етикети", "HeaderTaskTriggers": "Спусъци на задачи", "HeaderTracks": "Песни", "HeaderTranscodingProfile": "Профил на транскодинг", @@ -677,7 +669,6 @@ "TabAdvanced": "Допълнителни", "TabAlbumArtists": "Изпълнители на албуми", "TabAlbums": "Албуми", - "TabArtists": "Изпълнители", "TabCatalog": "Каталог", "TabChannels": "Канали", "TabCodecs": "Кодеци", @@ -686,7 +677,6 @@ "TabDashboard": "Табло", "TabDevices": "Устройства", "TabDirectPlay": "Директно пускане", - "TabDisplay": "Показване", "TabEpisodes": "Епизоди", "TabFavorites": "Любими", "TabGenres": "Жанрове", @@ -695,7 +685,6 @@ "TabLatest": "Последни", "TabLiveTV": "Телевизия на живо", "TabLogs": "Журнали", - "TabMetadata": "Метаданни", "TabMovies": "Филми", "TabMusic": "Музика", "TabMusicVideos": "Музикални клипове", @@ -706,7 +695,6 @@ "TabOther": "Други", "TabParentalControl": "Родителски контрол", "TabPassword": "Парола", - "TabPlayback": "Възпроизвеждане", "TabPlaylists": "Списъци", "TabPlugins": "Приставки", "TabProfile": "Профил", @@ -721,9 +709,7 @@ "TabShows": "Предавания", "TabSongs": "Песни", "TabStreaming": "Излъчване", - "TabSuggestions": "Предложения", "TabTrailers": "Трейлъри", - "TabTranscoding": "Прекодиране", "TabUpcoming": "Предстоящи", "TabUsers": "Потребители", "Tags": "Етикети", @@ -813,7 +799,6 @@ "ButtonStart": "Пускане", "ButtonSelectView": "Изберете изглед", "ButtonSelectServer": "Изберете сървър", - "ButtonRepeat": "Повтаряне", "ButtonNetwork": "Мрежа", "ButtonFullscreen": "На цял екран", "ButtonDown": "Надолу", @@ -888,7 +873,6 @@ "DeleteImageConfirmation": "Сигурнили сте че искате да премахнете това Изображение?", "DeleteImage": "Премахване на Исображение", "ButtonTogglePlaylist": "Списък с изпълнения", - "ButtonToggleContextMenu": "Повече", "ErrorSavingTvProvider": "Има проблем със запазването на ТВ доставчика.Убедете се ,че е достъпен и опитайте отново.", "ErrorPleaseSelectLineup": "Моля изберете списък и опитайте отново.Ако няма налични списъци се убедете ,че името,паролата и пощенския код са точни.", "ErrorStartHourGreaterThanEnd": "Времето за край трябва да бъде по-голямо от началното време.", @@ -1071,7 +1055,6 @@ "LabelAllowedRemoteAddressesMode": "Режим на филтъра за външни ИП адреси:", "LabelAllowedRemoteAddresses": "Филтър за външни ИП адреси:", "LabelAllowHWTranscoding": "Разреши хардуерно транскодиране", - "LabelAll": "Всички", "LabelAlbumArtMaxWidthHelp": "Максимална резолюция на обложките за албуми показани чрез upnp:albumArtURI.", "LabelAlbumArtMaxHeightHelp": "Максимална резолюция на обложките за албуми показани чрез upnp:albumArtURI.", "LabelAlbumArtMaxHeight": "Максимална височина на обложките за албуми:", diff --git a/src/strings/ca.json b/src/strings/ca.json index 7250a6cb31..e24bde24c4 100644 --- a/src/strings/ca.json +++ b/src/strings/ca.json @@ -15,7 +15,6 @@ "AttributeNew": "Nou", "Audio": "Àudio", "MessageBrowsePluginCatalog": "Consulta el nostre catàleg per veure els complements disponibles.", - "ButtonAdd": "Afegeix", "ButtonAddMediaLibrary": "Afegir Biblioteca Multimèdia", "ButtonAddScheduledTaskTrigger": "Afegir Disparador", "ButtonAddServer": "Afegeix Servidor", @@ -37,7 +36,6 @@ "ButtonForgotPassword": "He oblidat la contrasenya", "ButtonGotIt": "Entesos", "ButtonGuide": "Guia", - "ButtonHelp": "Ajuda", "ButtonHome": "Inici", "ButtonLibraryAccess": "Accés a la biblioteca", "ButtonManualLogin": "Inici de sessió manual", @@ -59,8 +57,6 @@ "ButtonResetPassword": "Reiniciar Contrasenya", "ButtonRestart": "Reiniciar", "ButtonResume": "Reprèn", - "ButtonSave": "Desa", - "ButtonSearch": "Cercar", "ButtonSelectDirectory": "Selecciona Directori", "ButtonSelectServer": "Seleccionar servidor", "ButtonSend": "Envia", @@ -159,15 +155,12 @@ "HeaderDeviceAccess": "Accés de Dispositiu", "HeaderDevices": "Dispositius", "HeaderDirectPlayProfile": "Perfil de Reproducció Directa", - "HeaderDisplay": "Visualització", "HeaderEasyPinCode": "Codi Pin Senzill", "HeaderEditImages": "Edita Imatges", "HeaderEnabledFields": "Camps Habilitats", "HeaderExternalIds": "Identificadors externs:", "HeaderFeatureAccess": "Accés a Funcions", - "HeaderFeatures": "Característiques", "HeaderFetchImages": "Obtingues Imatges:", - "HeaderFilters": "Filtres", "HeaderForgotPassword": "He oblidat la contrasenya", "HeaderFrequentlyPlayed": "Reproduït Freqüentment", "HeaderGenres": "Gèneres", @@ -641,7 +634,6 @@ "TabAccess": "Accés", "TabAdvanced": "Avançat", "TabAlbums": "Àlbums", - "TabArtists": "Artistes:", "TabCatalog": "Catàleg", "TabChannels": "Canals", "TabCodecs": "Còdecs", @@ -650,7 +642,6 @@ "TabDashboard": "Tauler de Control", "TabDevices": "Dispositius", "TabDirectPlay": "Reproducció Directa", - "TabDisplay": "Visualització", "TabEpisodes": "Episodis", "TabFavorites": "Preferits", "TabGenres": "Gèneres", @@ -658,7 +649,6 @@ "TabInfo": "Informació", "TabLatest": "Novetats", "TabLiveTV": "TV en Directe", - "TabMetadata": "Metadades", "TabMovies": "Pel·lícules", "TabMusic": "Música", "TabMusicVideos": "Vídeos musicals", @@ -669,7 +659,6 @@ "TabOther": "Altres", "TabParentalControl": "Control Parental", "TabPassword": "Contrasenya", - "TabPlayback": "Reproducció", "TabPlaylists": "Llistes de reproducció", "TabPlugins": "Complements", "TabProfile": "Perfil", @@ -682,9 +671,7 @@ "TabSettings": "Preferències", "TabShows": "Programes", "TabSongs": "Cançons", - "TabSuggestions": "Suggerències", "TabTrailers": "Tràilers", - "TabTranscoding": "Transcodificació", "TabUpcoming": "Properament", "TabUsers": "Usuaris", "Tags": "Etiquetes", @@ -742,7 +729,6 @@ "ButtonSelectView": "Selecciona la vista", "ButtonScanAllLibraries": "Escanejar totes les biblioteques", "ButtonRevoke": "Revocar", - "ButtonRepeat": "Repetir", "ButtonRename": "Canviar el nom", "ButtonNetwork": "Xarxa", "ButtonInfo": "Informació", @@ -785,7 +771,6 @@ "ChannelNameOnly": "Número de canal", "ChangingMetadataImageSettingsNewContent": "Els canvis als paràmetres de descàrrega de metadades o d'obra d'art només s'apliquen al contingut nou afegit a la biblioteca. Per aplicar els canvis als títols existents, haureu de refrescar les metadades manualment.", "ButtonTogglePlaylist": "Llista de reproducció", - "ButtonToggleContextMenu": "més", "ButtonOff": "Apagar", "BurnSubtitlesHelp": "Determina si el servidor hauria de gravar-se en els subtítols en transcodificar vídeos. Evitar això millorarà molt el rendiment. Seleccioneu Automàtica per gravar formats basats en imatges (VOBSUB, PGS, SUB, IDX) i certs subtítols ASS o SSA.", "Browse": "Navega", diff --git a/src/strings/cs.json b/src/strings/cs.json index 80415c24af..f2cd626199 100644 --- a/src/strings/cs.json +++ b/src/strings/cs.json @@ -34,7 +34,6 @@ "Box": "Pouzdro", "BoxRear": "Zadní část pouzdra", "MessageBrowsePluginCatalog": "Prohlédněte si náš katalog, kde najdete dostupné zásuvné moduly.", - "ButtonAdd": "Přidat", "ButtonAddMediaLibrary": "Přidat knihovnu médií", "ButtonAddScheduledTaskTrigger": "Přidat Spouštěč", "ButtonAddServer": "Přidat server", @@ -60,7 +59,6 @@ "ButtonFullscreen": "Celá obrazovka", "ButtonGotIt": "Mám to", "ButtonGuide": "Programový průvodce", - "ButtonHelp": "Nápověda", "ButtonHome": "Domů", "ButtonLibraryAccess": "Přístup ke knihovně", "ButtonManualLogin": "Manuální přihlášení", @@ -80,13 +78,10 @@ "ButtonRefreshGuideData": "Obnovit data programového průvodce", "ButtonRemove": "Odstranit", "ButtonRename": "Přejmenovat", - "ButtonRepeat": "Opakovat", "ButtonResetEasyPassword": "Obnovit easy pin kód", "ButtonResetPassword": "Obnovit heslo", "ButtonResume": "Pokračovat", "ButtonRevoke": "Odvolat", - "ButtonSave": "Uložit", - "ButtonSearch": "Hledání", "ButtonSelectDirectory": "Vybrat složku", "ButtonSelectServer": "Výběr serveru", "ButtonSelectView": "Výběr zobrazení", @@ -268,7 +263,6 @@ "HeaderDevices": "Zařízení", "HeaderDirectPlayProfile": "Profil Direct Play", "HeaderDirectPlayProfileHelp": "Přidat profil přímého přehrání pro definici formátů, které přístroj zvládne přehrávat nativně.", - "HeaderDisplay": "Zobrazení", "HeaderEasyPinCode": "Jednoduchý pin kód", "HeaderEditImages": "Editovat obrázky", "HeaderEnabledFields": "Povolené pole", @@ -276,9 +270,7 @@ "HeaderEpisodes": "Epizody", "HeaderError": "Chyba", "HeaderFeatureAccess": "Přístup k funkcím", - "HeaderFeatures": "Funkce", "HeaderFetchImages": "Načíst obrázky:", - "HeaderFilters": "Filtry", "HeaderForKids": "Pro děti", "HeaderForgotPassword": "Zapomenuté heslo", "HeaderFrequentlyPlayed": "Nejčastěji přehráváno", @@ -379,7 +371,6 @@ "HeaderSubtitleProfiles": "Profily titulků", "HeaderSubtitleProfilesHelp": "Profily titulků popisují formáty titulků, které daná zařízení podporují.", "HeaderSystemDlnaProfiles": "Systémové profily", - "HeaderTags": "Tagy", "HeaderTaskTriggers": "Spouštěče úloh", "HeaderThisUserIsCurrentlyDisabled": "Tento uživatel je aktuálně zakázán", "HeaderTracks": "Stopy", @@ -430,7 +421,6 @@ "LabelAlbumArtMaxWidthHelp": "Maximální rozlišení alb nabízených prostřednictvím upnp:albumArtURI.", "LabelAlbumArtPN": "Alba PN:", "LabelAlbumArtists": "Alba umělce:", - "LabelAll": "Vše", "LabelAllowHWTranscoding": "Povolit hardwarové překódování", "LabelAppName": "Název aplikace", "LabelAppNameExample": "Příklad: Sickbeard, Sonarr", @@ -1062,7 +1052,6 @@ "TabAdvanced": "Pokročilé", "TabAlbumArtists": "Umělci alba", "TabAlbums": "Alba", - "TabArtists": "Umělec", "TabCatalog": "Katalog", "TabChannels": "Kanály", "TabCodecs": "Kodeky", @@ -1070,7 +1059,6 @@ "TabContainers": "Obaly", "TabDashboard": "Nástěnka", "TabDevices": "Zařízení", - "TabDisplay": "Zobrazení", "TabEpisodes": "Epizody", "TabFavorites": "Oblíbené", "TabGenres": "Žánry", @@ -1087,7 +1075,6 @@ "TabOther": "Další", "TabParentalControl": "Rodičovská kontrola", "TabPassword": "Heslo", - "TabPlayback": "Přehrávání", "TabPlaylists": "Playlisty", "TabPlugins": "Zásuvné moduly", "TabProfile": "Profil", @@ -1101,9 +1088,7 @@ "TabShows": "Seriály", "TabSongs": "Skladby", "TabStreaming": "Streamování", - "TabSuggestions": "Návrhy", "TabTrailers": "Upoutávky", - "TabTranscoding": "Překódování", "TabUpcoming": "Nadcházející", "TabUsers": "Uživatelé", "Tags": "Tagy", @@ -1366,7 +1351,6 @@ "TabDirectPlay": "Přímé přehrávání", "TabInfo": "Info", "TabLiveTV": "Televize", - "TabMetadata": "Metadata", "TabServer": "Server", "TagsValue": "Tagy: {0}", "ThemeSongs": "Tematická hudba", @@ -1470,7 +1454,6 @@ "Filter": "Filtr", "New": "Nové", "ButtonTogglePlaylist": "Playlist", - "ButtonToggleContextMenu": "Více", "LabelStable": "Stabilní", "LabelChromecastVersion": "Verze Chromecastu", "ApiKeysCaption": "Seznam povolených API klíčů", diff --git a/src/strings/da.json b/src/strings/da.json index 89bdd61808..7e4721a42b 100644 --- a/src/strings/da.json +++ b/src/strings/da.json @@ -31,7 +31,6 @@ "BookLibraryHelp": "Lyd- og tekstbøger er understøttet. Se {0}guiden til navngivning af bøger{1}.", "Browse": "Gennemse", "MessageBrowsePluginCatalog": "Gennemse vores plugin-katalog for at se tilgængelige plugins.", - "ButtonAdd": "Tilføj", "ButtonAddMediaLibrary": "Tilføj Mediebibliotek", "ButtonAddScheduledTaskTrigger": "Tilføj udløser", "ButtonAddServer": "Tilføj Server", @@ -55,7 +54,6 @@ "ButtonForgotPassword": "Glemt Adgangskode", "ButtonFullscreen": "Fuld skærm", "ButtonGotIt": "Forstået", - "ButtonHelp": "Hjælp", "ButtonHome": "Hjem", "ButtonLibraryAccess": "Biblioteksadgang", "ButtonManualLogin": "Manuel Login", @@ -74,15 +72,12 @@ "ButtonRefreshGuideData": "Opdater Guide data", "ButtonRemove": "Fjern", "ButtonRename": "Omdøb", - "ButtonRepeat": "Gentag", "ButtonResetEasyPassword": "Nulstil pinkode", "ButtonResetPassword": "Nulstil adgangskode", "ButtonRestart": "Genstart", "ButtonResume": "Genoptag", "ButtonRevoke": "Invalider", - "ButtonSave": "Gem", "ButtonScanAllLibraries": "Skan Alle Biblioteker", - "ButtonSearch": "Søg", "ButtonSelectDirectory": "Vælg mappe", "ButtonSelectServer": "Vælg server", "ButtonSelectView": "Vælg visning", @@ -232,7 +227,6 @@ "HeaderDevices": "Enheder", "HeaderDirectPlayProfile": "Profil for direkte afspilning", "HeaderDirectPlayProfileHelp": "Tilføj profiler for direkte afspilning for at angive hvilke formater enheden selv kan håndtere.", - "HeaderDisplay": "Visning", "HeaderEasyPinCode": "Nem pinkode", "HeaderEditImages": "Rediger billeder", "HeaderEnabledFields": "Aktivér Felter", @@ -241,10 +235,8 @@ "HeaderError": "Fejl", "HeaderExternalIds": "Eksterne ID'er:", "HeaderFeatureAccess": "Adgang til funktioner", - "HeaderFeatures": "Egenskaber", "HeaderFetchImages": "Hent billeder:", "HeaderFetcherSettings": "Henter indstillinger", - "HeaderFilters": "Filtre", "HeaderForKids": "For Børn", "HeaderForgotPassword": "Glemt adgangskode", "HeaderFrequentlyPlayed": "Ofte afspillet", @@ -389,7 +381,6 @@ "LabelAlbumArtMaxWidthHelp": "Maksimumopløsningen på album billede der bliver vist med upnp:albumArtURI.", "LabelAlbumArtPN": "Album billede PN:", "LabelAlbumArtists": "Albumartister:", - "LabelAll": "Alle", "LabelAllowHWTranscoding": "Tillad hardware-omkodning", "LabelAllowedRemoteAddresses": "Fjernadgang IP adresse filter:", "LabelAllowedRemoteAddressesMode": "Fjernadgang IP adresse filter mode:", @@ -974,7 +965,6 @@ "TabAccess": "Adgang", "TabAdvanced": "Avanceret", "TabAlbumArtists": "Album-artister", - "TabArtists": "Kunstnere", "TabCatalog": "Katalog", "TabChannels": "Kanaler", "TabCollections": "Samlinger", @@ -982,7 +972,6 @@ "TabDashboard": "Betjeningspanel", "TabDevices": "Enheder", "TabDirectPlay": "Direkte afspilning", - "TabDisplay": "Visning", "TabEpisodes": "Episoder", "TabFavorites": "Favoritter", "TabGenres": "Genre", @@ -997,7 +986,6 @@ "TabOther": "Andet", "TabParentalControl": "Forældrekontrol", "TabPassword": "Adgangskode", - "TabPlayback": "Afspilning", "TabPlaylists": "Afspilningslister", "TabPlugins": "Tilføjelser", "TabProfile": "Profil", @@ -1010,9 +998,7 @@ "TabSettings": "Indstillinger", "TabShows": "Serier", "TabSongs": "Sange", - "TabSuggestions": "Forslag", "TabTrailers": "Trailere", - "TabTranscoding": "Transkodning", "TabUpcoming": "Kommende", "TabUsers": "Brugere", "TellUsAboutYourself": "Fortæl os lidt om dig selv", @@ -1174,7 +1160,6 @@ "HeaderStatus": "Status", "HeaderStopRecording": "Stop Optagelse", "HeaderSubtitleAppearance": "Undertekst Udseende", - "HeaderTags": "Mærker", "HeaderVideoQuality": "Video Kvalitet", "HeaderVideoType": "Video Type", "Hide": "Skjul", @@ -1331,7 +1316,6 @@ "TabInfo": "Information", "TabLiveTV": "Live TV", "TabLogs": "Log", - "TabMetadata": "Metadata", "TabServer": "Server", "TabStreaming": "Streamer", "Tags": "Mærker", @@ -1470,6 +1454,5 @@ "Filter": "Filtrer", "New": "Nye", "ButtonTogglePlaylist": "Spilleliste", - "ButtonToggleContextMenu": "Mere", "ButtonSyncPlay": "SyncPlay" } diff --git a/src/strings/de.json b/src/strings/de.json index b167c31707..f37a4e13e5 100644 --- a/src/strings/de.json +++ b/src/strings/de.json @@ -46,7 +46,6 @@ "Browse": "Blättern", "MessageBrowsePluginCatalog": "Durchsuche unsere Bibliothek, um alle verfügbaren Plugins anzuzeigen.", "BurnSubtitlesHelp": "Legt fest, ob der Server die Untertitel während der Videotranskodierung einbrennen soll. Deaktivieren verbessert die Serverperformance immens. Wähle Auto, um bildbasierte Formate (z.B. VOBSUB, PGS, SUB, IDX, ...) sowie bestimmte ASS- oder SSA-Untertitel einbrennen zu lassen.", - "ButtonAdd": "Hinzufügen", "ButtonAddMediaLibrary": "Füge Medienbibliothek hinzu", "ButtonAddScheduledTaskTrigger": "Auslöser hinzufügen", "ButtonAddServer": "Server hinzufügen", @@ -70,7 +69,6 @@ "ButtonFullscreen": "Vollbild", "ButtonGotIt": "Verstanden", "ButtonGuide": "TV Guide", - "ButtonHelp": "Hilfe", "ButtonLibraryAccess": "Bibliothekszugang", "ButtonManualLogin": "Manuelle Anmeldung", "ButtonMore": "Mehr", @@ -88,15 +86,12 @@ "ButtonRefreshGuideData": "Aktualisiere TV-Programmdaten", "ButtonRemove": "Entfernen", "ButtonRename": "Umbenennen", - "ButtonRepeat": "Wiederholung", "ButtonResetEasyPassword": "Einfachen PIN zurücksetzen", "ButtonResetPassword": "Passwort zurücksetzten", "ButtonRestart": "Neustart", "ButtonResume": "Fortsetzen", "ButtonRevoke": "Zurücknehmen", - "ButtonSave": "Speichern", "ButtonScanAllLibraries": "Scanne alle Bibliotheken", - "ButtonSearch": "Suche", "ButtonSelectDirectory": "Wähle Verzeichnis", "ButtonSelectServer": "Wähle Server", "ButtonSelectView": "Ansicht wählen", @@ -299,7 +294,6 @@ "HeaderDevices": "Geräte", "HeaderDirectPlayProfile": "Direktwiedergabe Profil", "HeaderDirectPlayProfileHelp": "Füge Direct-Play Profile hinzu um die nativen Abspielmöglichkeiten von Geräten festzulegen.", - "HeaderDisplay": "Anzeige", "HeaderDownloadSync": "Herunterladen & Synchronisieren", "HeaderEasyPinCode": "Einfacher PIN Code", "HeaderEditImages": "Bilder bearbeiten", @@ -309,10 +303,8 @@ "HeaderError": "Fehler", "HeaderExternalIds": "Externe IDs:", "HeaderFeatureAccess": "Funktionszugriff", - "HeaderFeatures": "Funktionen", "HeaderFetchImages": "Bilder abrufen:", "HeaderFetcherSettings": "Fetcher Einstellungen", - "HeaderFilters": "Filter", "HeaderForKids": "Für Kinder", "HeaderForgotPassword": "Passwort vergessen", "HeaderFrequentlyPlayed": "Oft gesehen", @@ -471,7 +463,6 @@ "LabelAlbumArtMaxWidthHelp": "Maximale Auflösung für durch UPnP übermittelte Album Art:albumArtURI.", "LabelAlbumArtPN": "Alben-Cover PN:", "LabelAlbumArtists": "Alben Interpreten:", - "LabelAll": "Alle", "LabelAllowHWTranscoding": "Erlaube Hardware Transkodierung", "LabelAllowedRemoteAddresses": "Remote-IP Adressen Filter:", "LabelAllowedRemoteAddressesMode": "Remote IP Adressen Filtermodus:", @@ -1139,7 +1130,6 @@ "TabAdvanced": "Erweitert", "TabAlbumArtists": "Album-Interpreten", "TabAlbums": "Alben", - "TabArtists": "Interpreten", "TabCatalog": "Katalog", "TabChannels": "Kanäle", "TabCollections": "Sammlungen", @@ -1147,13 +1137,11 @@ "TabDashboard": "Übersicht", "TabDevices": "Geräte", "TabDirectPlay": "Direktwiedergabe", - "TabDisplay": "Anzeige", "TabEpisodes": "Episoden", "TabFavorites": "Favoriten", "TabGuide": "Programm", "TabLatest": "Neueste", "TabLiveTV": "Live-TV", - "TabMetadata": "Metadaten", "TabMovies": "Filme", "TabMusic": "Musik", "TabMusicVideos": "Musikvideos", @@ -1164,7 +1152,6 @@ "TabOther": "Andere", "TabParentalControl": "Kindersicherung", "TabPassword": "Passwort", - "TabPlayback": "Wiedergabe", "TabPlaylists": "Wiedergabelisten", "TabProfile": "Profil", "TabProfiles": "Profile", @@ -1175,9 +1162,7 @@ "TabSeries": "Serie", "TabSettings": "Einstellungen", "TabShows": "Serien", - "TabSuggestions": "Empfehlungen", "TabTrailers": "Trailer", - "TabTranscoding": "Transkodierung", "TabUpcoming": "Bevorstehend", "TabUsers": "Benutzer", "TellUsAboutYourself": "Sagen Sie uns etwas über sich selbst", @@ -1265,7 +1250,6 @@ "HeaderHttpHeaders": "HTTP-Header", "HeaderPluginInstallation": "Plugininstallation", "HeaderStatus": "Status", - "HeaderTags": "Tags", "HeaderVideos": "Videos", "Home": "Startseite", "Horizontal": "Horizontal", @@ -1470,7 +1454,6 @@ "New": "Neu", "HeaderFavoritePlaylists": "Lieblings-Wiedergabeliste", "ButtonTogglePlaylist": "Wiedergabeliste", - "ButtonToggleContextMenu": "Mehr", "ApiKeysCaption": "Liste der aktuell aktivierten API-Schlüssel", "LabelStable": "Stable", "LabelChromecastVersion": "Chromecast Version", diff --git a/src/strings/el.json b/src/strings/el.json index c390f7bde4..d3176ae83c 100644 --- a/src/strings/el.json +++ b/src/strings/el.json @@ -44,7 +44,6 @@ "Browse": "Αναζήτηση", "MessageBrowsePluginCatalog": "Πλοηγηθείτε στον κατάλογο plugin μας για να δείτε τα διαθέσιμα plugins.", "BurnSubtitlesHelp": "Καθορίζει αν ο διακομιστής πρέπει να εγγράψει τους υπότιτλους κατά τη μετατροπή βίντεο ανάλογα με τη μορφή των υπότιτλων. Η αποφυγή της εγγραφής στους υπότιτλους θα βελτιώσει την απόδοση του διακομιστή. Επιλέξτε Αυτόματα για να εγγράψετε μορφές βασισμένες σε εικόνες (VOBSUB, PGS, SUB / IDX κ.λπ.) και ορισμένους υπότιτλους ASS / SSA.", - "ButtonAdd": "Πρόσθεσε", "ButtonAddMediaLibrary": "Προσθήκη βιβλιοθήκης πολυμέσων", "ButtonAddScheduledTaskTrigger": "Προσθήκη διακόπτη", "ButtonAddServer": "Προσθήκη διακομιστή", @@ -69,7 +68,6 @@ "ButtonFullscreen": "Πλήρης οθόνη", "ButtonGotIt": "Το κατάλαβα", "ButtonGuide": "Οδηγός", - "ButtonHelp": "Βοήθεια", "ButtonHome": "Αρχική", "ButtonInfo": "Πληροφορία", "ButtonLibraryAccess": "Πρόσβαση στη βιβλιοθήκη", @@ -88,15 +86,12 @@ "ButtonRefreshGuideData": "Ανανέωση Δεδομένων Οδηγού", "ButtonRemove": "Κατάργηση", "ButtonRename": "Μετονομασία", - "ButtonRepeat": "Επανάληψη", "ButtonResetEasyPassword": "Επαναφορά εύκολου κωδικού PIN", "ButtonResetPassword": "Επαναφορά του κωδικού πρόσβασης", "ButtonRestart": "Επανεκκίνηση", "ButtonResume": "Συνέχιση", "ButtonRevoke": "Ανακαλώ", - "ButtonSave": "Αποθήκευση", "ButtonScanAllLibraries": "Σάρωση όλων των βιβλιοθηκών", - "ButtonSearch": "Αναζήτηση", "ButtonSelectDirectory": "Επιλογή Φακέλου", "ButtonSelectServer": "Επιλογή Διακομιστή", "ButtonSelectView": "Επιλέξτε Προβολή", @@ -285,7 +280,6 @@ "HeaderDevices": "Συσκευές", "HeaderDirectPlayProfile": "Προφίλ Άμεσης Αναπαραγωγής", "HeaderDirectPlayProfileHelp": "Προσθέστε προφίλ άμεσης αναπαραγωγής για να δείξετε ποιες μορφές μπορεί να χειριστεί εγγενώς η συσκευή.", - "HeaderDisplay": "Εμφάνιση", "HeaderEasyPinCode": "Κωδικός PIN", "HeaderEditImages": "Επεξεργασία εικόνων", "HeaderEnabledFields": "Ενεργά Πεδία", @@ -294,9 +288,7 @@ "HeaderError": "Σφάλμα", "HeaderExternalIds": "Εξωτερικά ID:", "HeaderFeatureAccess": "Πρόσβαση χαρακτηριστικών", - "HeaderFeatures": "Χαρακτηριστικά", "HeaderFetchImages": "Λήψη εικόνων:", - "HeaderFilters": "Φίλτρα", "HeaderForKids": "Για τα Παιδιά", "HeaderForgotPassword": "Ξέχασα τον κωδικό", "HeaderFrequentlyPlayed": "Συχνά έπαιξε", @@ -392,7 +384,6 @@ "HeaderSubtitleProfiles": "Προφίλ Υπότιτλων", "HeaderSubtitleProfilesHelp": "Τα προφίλ υποτίτλων περιγράφουν τις μορφές υπότιτλων που υποστηρίζει η συσκευή.", "HeaderSystemDlnaProfiles": "Προφίλ Συστήματος", - "HeaderTags": "Ετικέτες", "HeaderTaskTriggers": "Έναυσμα εργασιών", "HeaderThisUserIsCurrentlyDisabled": "Ο χρήστης είναι απενεργοποιημένος", "HeaderTranscodingProfileHelp": "Προσθέστε προφίλ αποκωδικοποίησης για να δηλώσετε ποιες μορφές θα πρέπει να χρησιμοποιηθούν όταν απαιτείται μετασύνδεση.", @@ -438,7 +429,6 @@ "LabelAlbumArtMaxWidthHelp": "Μέγιστη ανάλυση του άλμπουμ art που εκτίθεται μέσω του upnp: albumArtURI.", "LabelAlbumArtPN": "PN άλμπουμ art:", "LabelAlbumArtists": "Καλλιτέχνες του 'Αλμπουμ:", - "LabelAll": "Όλα", "LabelAppName": "Όνομα App", "LabelAppNameExample": "Παράδειγμα: Sickbeard, NzbDrone", "LabelArtists": "Καλλιτέχνες:", @@ -1029,21 +1019,18 @@ "TabAdvanced": "Για προχωρημένους", "TabAlbumArtists": "Άλμπουμ Καλλιτέχνες", "TabAlbums": "Άλμπουμ", - "TabArtists": "Καλλιτέχνες", "TabCatalog": "Κατάλογος", "TabChannels": "Κανάλια", "TabCollections": "Συλλογές", "TabDashboard": "Πίνακας Ελέγχου", "TabDevices": "Συσκευές", "TabDirectPlay": "Άμεση Αναπαραγωγή", - "TabDisplay": "Εμφάνιση", "TabEpisodes": "Επεισόδια", "TabFavorites": "Αγαπημένα", "TabGenres": "Είδη", "TabGuide": "Οδηγός", "TabInfo": "Πληροφορία", "TabLatest": "Τελευταία", - "TabMetadata": "Μεταδεδομένα", "TabMovies": "Ταινίες", "TabMusic": "Μουσική", "TabMusicVideos": "Μουσικά βίντεο", @@ -1054,7 +1041,6 @@ "TabOther": "Άλλα", "TabParentalControl": "Γονικός έλεγχος", "TabPassword": "Κωδικός", - "TabPlayback": "Αναπαραγωγή", "TabPlaylists": "Λίστες αναπαραγωγής", "TabPlugins": "Πρόσθετα", "TabProfile": "Προφίλ", @@ -1068,9 +1054,7 @@ "TabShows": "Επεισόδια", "TabSongs": "Τραγούδια", "TabStreaming": "Ροή", - "TabSuggestions": "Προτάσεις", "TabTrailers": "Τρέιλερς", - "TabTranscoding": "Κωδικοποίηση", "TabUpcoming": "Επερχόμενα", "TabUsers": "Χρήστες", "Tags": "Ετικέτες", @@ -1212,7 +1196,6 @@ "AllowedRemoteAddressesHelp": "Λίστα διαχωρισμένων διευθύνσεων IP ή καταχωρίσεων IP / netmask για δίκτυα που θα επιτρέπεται η σύνδεση εξ αποστάσεως. Εάν αφεθεί κενό, όλες οι απομακρυσμένες διευθύνσεις θα επιτρέπονται.", "AllowFfmpegThrottlingHelp": "Όταν ένας διακωδικοποιητής ή remux φτάσει αρκετά μπροστά από την τρέχουσα θέση αναπαραγωγής, διακόψτε τη διαδικασία ώστε να καταναλώσει λιγότερους πόρους. Αυτό είναι πιο χρήσιμο όταν παρακολουθείτε χωρίς να αναζητάτε συχνά. Απενεργοποιήστε το εάν αντιμετωπίζετε προβλήματα αναπαραγωγής.", "ButtonTogglePlaylist": "Λίστα αναπαραγωγής", - "ButtonToggleContextMenu": "Περισσότερα", "ButtonSplit": "Διαχωρισμός", "ButtonSyncPlay": "SyncPlay" } diff --git a/src/strings/en-gb.json b/src/strings/en-gb.json index b3ec646101..f2fc6e7764 100644 --- a/src/strings/en-gb.json +++ b/src/strings/en-gb.json @@ -99,7 +99,6 @@ "BoxRear": "Box (rear)", "Browse": "Browse", "BurnSubtitlesHelp": "Determines if the server should burn in subtitles when transcoding videos. Avoiding this will greatly improve performance. Select Auto to burn image based formats (VOBSUB, PGS, SUB, IDX, …) and certain ASS or SSA subtitles.", - "ButtonAdd": "Add", "ButtonAddMediaLibrary": "Add Media Library", "ButtonAddScheduledTaskTrigger": "Add Trigger", "ButtonAddServer": "Add Server", @@ -125,7 +124,6 @@ "ButtonFullscreen": "Fullscreen", "ButtonGotIt": "Got It", "ButtonGuide": "Guide", - "ButtonHelp": "Help", "ButtonHome": "Home", "ButtonInfo": "Info", "ButtonLibraryAccess": "Library access", @@ -147,15 +145,12 @@ "ButtonRefreshGuideData": "Refresh Guide Data", "ButtonRemove": "Remove", "ButtonRename": "Rename", - "ButtonRepeat": "Repeat", "ButtonResetEasyPassword": "Reset easy pin code", "ButtonResetPassword": "Reset Password", "ButtonRestart": "Restart", "ButtonResume": "Resume", "ButtonRevoke": "Revoke", - "ButtonSave": "Save", "ButtonScanAllLibraries": "Scan All Libraries", - "ButtonSearch": "Search", "ButtonSelectDirectory": "Select Directory", "ButtonSelectServer": "Select Server", "ButtonSelectView": "Select view", @@ -357,7 +352,6 @@ "HeaderDevices": "Devices", "HeaderDirectPlayProfile": "Direct Play Profile", "HeaderDirectPlayProfileHelp": "Add direct play profiles to indicate which formats the device can handle natively.", - "HeaderDisplay": "Display", "HeaderDownloadSync": "Download & Sync", "HeaderEasyPinCode": "Easy Pin Code", "HeaderEditImages": "Edit Images", @@ -376,10 +370,8 @@ "HeaderFavoriteVideos": "Favourite Videos", "HeaderFavoritePlaylists": "Favourite Playlists", "HeaderFeatureAccess": "Feature Access", - "HeaderFeatures": "Features", "HeaderFetchImages": "Fetch Images:", "HeaderFetcherSettings": "Fetcher Settings", - "HeaderFilters": "Filters", "HeaderForKids": "For Kids", "HeaderForgotPassword": "Forgot Password", "HeaderFrequentlyPlayed": "Frequently Played", @@ -478,7 +470,6 @@ "TabResumeSettings": "Resume", "TabResponses": "Responses", "TabRecordings": "Recordings", - "TabPlayback": "Playback", "TabOther": "Other", "TabNotifications": "Notifications", "TabNetworks": "Networks", @@ -486,13 +477,10 @@ "TabMusicVideos": "Music Videos", "TabMusic": "Music", "TabMovies": "Movies", - "TabMetadata": "Metadata", "TabLogs": "Logs", - "TabDisplay": "Display", "TabDirectPlay": "Direct Play", "TabDevices": "Devices", "TabChannels": "Channels", - "TabArtists": "Artists", "TabAlbums": "Albums", "TabAlbumArtists": "Album Artists", "TabAdvanced": "Advanced", @@ -924,9 +912,7 @@ "Tags": "Tags", "TabUsers": "Users", "TabUpcoming": "Upcoming", - "TabTranscoding": "Transcoding", "TabTrailers": "Trailers", - "TabSuggestions": "Suggestions", "LabelDisplayMode": "Display mode:", "LabelDisplayLanguageHelp": "Translating Jellyfin is an ongoing project.", "LabelDisplayLanguage": "Display language:", @@ -1148,7 +1134,6 @@ "LabelAllowedRemoteAddressesMode": "Remote IP address filter mode:", "LabelAllowedRemoteAddresses": "Remote IP address filter:", "LabelAllowHWTranscoding": "Allow hardware transcoding", - "LabelAll": "All", "LabelAlbumArtists": "Album artists:", "LabelAlbumArtPN": "Album art PN:", "LabelAlbumArtMaxWidthHelp": "Max resolution of album art exposed via upnp:albumArtURI.", @@ -1192,7 +1177,6 @@ "HeaderTracks": "Tracks", "HeaderThisUserIsCurrentlyDisabled": "This user is currently disabled", "HeaderTaskTriggers": "Task Triggers", - "HeaderTags": "Tags", "HeaderSystemDlnaProfiles": "System Profiles", "HeaderSubtitleProfilesHelp": "Subtitle profiles describe the subtitle formats supported by the device.", "HeaderSubtitleProfiles": "Subtitle Profiles", @@ -1472,7 +1456,6 @@ "Album": "Album", "UnsupportedPlayback": "Jellyfin cannot decrypt content protected by DRM but all content will be attempted regardless, including protected titles. Some files may appear completely black due to encryption or other unsupported features, such as interactive titles.", "ButtonTogglePlaylist": "Playlist", - "ButtonToggleContextMenu": "More", "HeaderDVR": "DVR", "ApiKeysCaption": "List of the currently enabled API keys", "ButtonCast": "Cast", diff --git a/src/strings/en-us.json b/src/strings/en-us.json index 78c96fcc56..2e437b148b 100644 --- a/src/strings/en-us.json +++ b/src/strings/en-us.json @@ -61,7 +61,6 @@ "Browse": "Browse", "MessageBrowsePluginCatalog": "Browse our plugin catalog to view available plugins.", "BurnSubtitlesHelp": "Determines if the server should burn in subtitles when transcoding videos. Avoiding this will greatly improve performance. Select Auto to burn image based formats (VOBSUB, PGS, SUB, IDX, …) and certain ASS or SSA subtitles.", - "ButtonAdd": "Add", "ButtonAddImage": "Add Image", "ButtonAddMediaLibrary": "Add Media Library", "ButtonAddScheduledTaskTrigger": "Add Trigger", @@ -88,7 +87,6 @@ "ButtonFullscreen": "Fullscreen", "ButtonGotIt": "Got It", "ButtonGuide": "Guide", - "ButtonHelp": "Help", "ButtonHome": "Home", "ButtonInfo": "Info", "ButtonLibraryAccess": "Library access", @@ -110,15 +108,12 @@ "ButtonRefreshGuideData": "Refresh Guide Data", "ButtonRemove": "Remove", "ButtonRename": "Rename", - "ButtonRepeat": "Repeat", "ButtonResetEasyPassword": "Reset easy pin code", "ButtonResetPassword": "Reset Password", "ButtonRestart": "Restart", "ButtonResume": "Resume", "ButtonRevoke": "Revoke", - "ButtonSave": "Save", "ButtonScanAllLibraries": "Scan All Libraries", - "ButtonSearch": "Search", "ButtonSelectDirectory": "Select Directory", "ButtonSelectServer": "Select Server", "ButtonSelectView": "Select view", @@ -134,7 +129,6 @@ "ButtonSplit": "Split", "ButtonSubmit": "Submit", "ButtonSubtitles": "Subtitles", - "ButtonToggleContextMenu": "More", "ButtonTogglePlaylist": "Playlist", "ButtonTrailer": "Trailer", "ButtonUninstall": "Uninstall", @@ -350,7 +344,6 @@ "HeaderDevices": "Devices", "HeaderDirectPlayProfile": "Direct Play Profile", "HeaderDirectPlayProfileHelp": "Add direct play profiles to indicate which formats the device can handle natively.", - "HeaderDisplay": "Display", "HeaderDownloadSync": "Download & Sync", "HeaderDVR": "DVR", "HeaderEasyPinCode": "Easy Pin Code", @@ -371,10 +364,8 @@ "HeaderFavoriteVideos": "Favorite Videos", "HeaderFavoritePlaylists": "Favorite Playlists", "HeaderFeatureAccess": "Feature Access", - "HeaderFeatures": "Features", "HeaderFetchImages": "Fetch Images:", "HeaderFetcherSettings": "Fetcher Settings", - "HeaderFilters": "Filters", "HeaderForKids": "For Kids", "HeaderForgotPassword": "Forgot Password", "HeaderFrequentlyPlayed": "Frequently Played", @@ -494,7 +485,6 @@ "HeaderSyncPlaySelectGroup": "Join a group", "HeaderSyncPlayEnabled": "SyncPlay enabled", "HeaderSystemDlnaProfiles": "System Profiles", - "HeaderTags": "Tags", "HeaderTaskTriggers": "Task Triggers", "HeaderThisUserIsCurrentlyDisabled": "This user is currently disabled", "HeaderTracks": "Tracks", @@ -550,7 +540,6 @@ "LabelAlbumArtMaxWidthHelp": "Max resolution of album art exposed via upnp:albumArtURI.", "LabelAlbumArtPN": "Album art PN:", "LabelAlbumArtists": "Album artists:", - "LabelAll": "All", "LabelAllowHWTranscoding": "Allow hardware transcoding", "LabelAllowedRemoteAddresses": "Remote IP address filter:", "LabelAllowedRemoteAddressesMode": "Remote IP address filter mode:", @@ -1401,7 +1390,6 @@ "TabAdvanced": "Advanced", "TabAlbumArtists": "Album Artists", "TabAlbums": "Albums", - "TabArtists": "Artists", "TabCatalog": "Catalog", "TabRepositories": "Repositories", "TabChannels": "Channels", @@ -1411,7 +1399,6 @@ "TabDashboard": "Dashboard", "TabDevices": "Devices", "TabDirectPlay": "Direct Play", - "TabDisplay": "Display", "TabDVR": "DVR", "TabEpisodes": "Episodes", "TabFavorites": "Favorites", @@ -1421,7 +1408,6 @@ "TabLatest": "Latest", "TabLiveTV": "Live TV", "TabLogs": "Logs", - "TabMetadata": "Metadata", "TabMovies": "Movies", "TabMusic": "Music", "TabMusicVideos": "Music Videos", @@ -1433,7 +1419,6 @@ "TabOther": "Other", "TabParentalControl": "Parental Control", "TabPassword": "Password", - "TabPlayback": "Playback", "TabPlaylists": "Playlists", "TabPlugins": "Plugins", "TabProfile": "Profile", @@ -1448,9 +1433,7 @@ "TabShows": "Shows", "TabSongs": "Songs", "TabStreaming": "Streaming", - "TabSuggestions": "Suggestions", "TabTrailers": "Trailers", - "TabTranscoding": "Transcoding", "TabUpcoming": "Upcoming", "TabUsers": "Users", "Tags": "Tags", diff --git a/src/strings/es-ar.json b/src/strings/es-ar.json index c8a1dbb87c..6fb6907284 100644 --- a/src/strings/es-ar.json +++ b/src/strings/es-ar.json @@ -7,7 +7,6 @@ "HeaderLatestEpisodes": "Últimos capítulos", "HeaderLiveTV": "TV en vivo", "HeaderSeries": "Series", - "LabelAll": "Todo", "LabelDisplayMissingEpisodesWithinSeasons": "Mostrar capítulos no disponibles en temporadas", "LabelFinish": "Terminar", "LabelNext": "Siguiente", @@ -96,7 +95,6 @@ "Browse": "Explorar", "MessageBrowsePluginCatalog": "Explore nuestro catálogo de complementos para ver los complementos disponibles.", "BurnSubtitlesHelp": "Determina si el servidor debe grabarse en subtítulos al transcodificar videos. Evitar esto mejorará en gran medida el rendimiento. Seleccione Automático para grabar formatos basados en imágenes (VOBSUB, PGS, SUB, IDX, ...) y ciertos subtítulos ASS o SSA.", - "ButtonAdd": "Agregar", "ButtonAddMediaLibrary": "Agregar biblioteca de medios", "ButtonAddScheduledTaskTrigger": "Agregar desencadenador", "ButtonAddServer": "Agregar servidor", @@ -122,7 +120,6 @@ "ButtonFullscreen": "Pantalla completa", "ButtonGotIt": "Lo entendí", "ButtonGuide": "Guía", - "ButtonHelp": "Ayuda", "ButtonHome": "Inicio", "ButtonInfo": "Información", "ButtonLibraryAccess": "Acceso a la biblioteca", @@ -143,15 +140,12 @@ "ButtonRefreshGuideData": "Actualizar datos de la guía", "ButtonRemove": "Quitar", "ButtonRename": "Renombrar", - "ButtonRepeat": "Repetir", "ButtonResetEasyPassword": "Restablecer código PIN", "ButtonResetPassword": "Restablecer contraseña", "ButtonRestart": "Reiniciar", "ButtonResume": "Resumir", "ButtonRevoke": "Revocar", - "ButtonSave": "Guardar", "ButtonScanAllLibraries": "Escanear todas las bibliotecas", - "ButtonSearch": "Buscar", "ButtonSelectDirectory": "Seleccionar directorio", "ButtonSelectServer": "Seleccionar servidor", "ButtonSelectView": "Seleccionar vista", @@ -380,7 +374,6 @@ "HeaderEditImages": "Editar imágenes", "HeaderEasyPinCode": "Código PIN fácil", "HeaderDownloadSync": "Descargar y sincronizar", - "HeaderDisplay": "Pantalla", "HeaderDirectPlayProfile": "Perfil Direct Play", "HeaderDevices": "Dispositivos", "HeaderDeviceAccess": "Acceso al dispositivo", @@ -425,14 +418,11 @@ "HeaderFrequentlyPlayed": "Reproducido con frecuencia", "HeaderForgotPassword": "Olvidé la contraseña", "HeaderForKids": "Para niños", - "HeaderFilters": "Filtros", "HeaderFetcherSettings": "Configuración del recuperador", "HeaderFetchImages": "Obtener imágenes:", - "HeaderFeatures": "Caracteristicas", "HeaderFeatureAccess": "Acceso a características", "HeaderFavoritePlaylists": "Listas de reproducción favoritas", "ButtonTogglePlaylist": "Lista de reproducción", - "ButtonToggleContextMenu": "Más", "HeaderPlaybackError": "Error de reproducción", "HeaderPlayback": "Reproducción de medios", "HeaderPlayOn": "Reproducir en", @@ -493,7 +483,6 @@ "HeaderTracks": "Pistas", "HeaderThisUserIsCurrentlyDisabled": "Este usuario está actualmente deshabilitado", "HeaderTaskTriggers": "Desencadenantes de tareas", - "HeaderTags": "Etiquetas", "HeaderSystemDlnaProfiles": "Perfiles del sistema", "HeaderSubtitleProfilesHelp": "Los perfiles de subtítulos describen los formatos de subtítulos compatibles con el dispositivo.", "HeaderSubtitleProfiles": "Perfiles de subtítulos", @@ -1409,13 +1398,11 @@ "Tags": "Etiquetas", "TabUsers": "Usuarios", "TabUpcoming": "Próximamente", - "TabTranscoding": "Transcodificación", "MarkUnplayed": "Marcar no reproducido", "MarkPlayed": "Marcar reproducido", "LabelSkipForwardLength": "Saltar hacia adelante longitud:", "Trailers": "Avances", "TabTrailers": "Avances", - "TabSuggestions": "Sugerencias", "TabStreaming": "Transmisión", "TabSongs": "Canciones", "TabShows": "Programas", @@ -1430,7 +1417,6 @@ "TabProfile": "Perfil", "TabPlugins": "Complementos", "TabPlaylists": "Listas de reproducción", - "TabPlayback": "Reproducción", "TabPassword": "Contraseña", "TabParentalControl": "Control parental", "TabOther": "Otro", @@ -1442,7 +1428,6 @@ "TabMusicVideos": "Videos musicales", "TabMusic": "Música", "TabMovies": "Películas", - "TabMetadata": "Metadatos", "TabLogs": "Registros", "TabLiveTV": "TV en vivo", "TabLatest": "Último", @@ -1451,7 +1436,6 @@ "TabGenres": "Géneros", "TabFavorites": "Favoritos", "TabDVR": "DVR", - "TabDisplay": "Pantalla", "TabDirectPlay": "Reproducción directa", "TabDevices": "Dispositivos", "TabDashboard": "Tablero", @@ -1461,7 +1445,6 @@ "TabChannels": "Canales", "TabRepositories": "Repositorios", "TabCatalog": "Catálogo", - "TabArtists": "Artistas", "TabAlbums": "Álbumes", "TabAlbumArtists": "Artistas del álbum", "TabAdvanced": "Avanzado", diff --git a/src/strings/es-mx.json b/src/strings/es-mx.json index b0923c0228..643758b660 100644 --- a/src/strings/es-mx.json +++ b/src/strings/es-mx.json @@ -50,7 +50,6 @@ "Browse": "Explorar", "MessageBrowsePluginCatalog": "Explora nuestro catálogo de complementos para ver los complementos disponibles.", "BurnSubtitlesHelp": "Determina si el servidor debería quemar los subtítulos al transcodificar videos. Evitar esto mejorará altamente el rendimiento del servidor. Seleccione Auto para grabar formatos basados en imágenes (VOBSUB, PGS, SUB, IDX...) y ciertos subtítulos ASS o SSA.", - "ButtonAdd": "Agregar", "ButtonAddMediaLibrary": "Agregar biblioteca de medios", "ButtonAddScheduledTaskTrigger": "Agregar disparador", "ButtonAddServer": "Agregar servidor", @@ -76,7 +75,6 @@ "ButtonFullscreen": "Pantalla completa", "ButtonGotIt": "Hecho", "ButtonGuide": "Guía", - "ButtonHelp": "Ayuda", "ButtonHome": "Inicio", "ButtonLibraryAccess": "Acceso a biblioteca(s)", "ButtonManualLogin": "Inicio de sesión manual", @@ -96,15 +94,12 @@ "ButtonRefreshGuideData": "Actualizar datos de la guía", "ButtonRemove": "Remover", "ButtonRename": "Renombrar", - "ButtonRepeat": "Repetir", "ButtonResetEasyPassword": "Restablecer código PIN sencillo", "ButtonResetPassword": "Restablecer contraseña", "ButtonRestart": "Reiniciar", "ButtonResume": "Continuar", "ButtonRevoke": "Revocar", - "ButtonSave": "Guardar", "ButtonScanAllLibraries": "Escanear todas las bibliotecas", - "ButtonSearch": "Búsqueda", "ButtonSelectDirectory": "Seleccionar directorio", "ButtonSelectServer": "Seleccionar servidor", "ButtonSelectView": "Seleccionar vista", @@ -316,7 +311,6 @@ "HeaderDevices": "Dispositivos", "HeaderDirectPlayProfile": "Perfil de reproducción directa", "HeaderDirectPlayProfileHelp": "Agrega perfiles de reproducción directa para indicar qué formatos puede manejar el dispositivo de forma nativa.", - "HeaderDisplay": "Pantalla", "HeaderDownloadSync": "Descargar y sincronizar", "HeaderEasyPinCode": "Código PIN sencillo", "HeaderEditImages": "Editar imágenes", @@ -325,10 +319,8 @@ "HeaderEpisodes": "Episodios", "HeaderExternalIds": "IDs externos:", "HeaderFeatureAccess": "Acceso a características", - "HeaderFeatures": "Características", "HeaderFetchImages": "Obtener imágenes:", "HeaderFetcherSettings": "Configuración del recolector", - "HeaderFilters": "Filtros", "HeaderForKids": "Para niños", "HeaderForgotPassword": "Olvidé mi contraseña", "HeaderFrequentlyPlayed": "Reproducido frecuentemente", @@ -441,7 +433,6 @@ "HeaderSubtitleProfiles": "Perfiles de subtítulo", "HeaderSubtitleProfilesHelp": "Los perfiles de subtítulo describen los formatos de subtítulo soportados por el dispositivo.", "HeaderSystemDlnaProfiles": "Perfiles del sistema", - "HeaderTags": "Etiquetas", "HeaderTaskTriggers": "Disparadores de tarea", "HeaderThisUserIsCurrentlyDisabled": "Este usuario se encuentra actualmente deshabilitado", "HeaderTracks": "Pistas", @@ -495,7 +486,6 @@ "LabelAlbumArtMaxWidthHelp": "Resolución máxima del arte del álbum expuesta vía upnp:albumArtURI.", "LabelAlbumArtPN": "PN del arte del álbum:", "LabelAlbumArtists": "Artistas del álbum:", - "LabelAll": "Todos", "LabelAllowHWTranscoding": "Permitir transcodificación por hardware", "LabelAllowedRemoteAddresses": "Filtro de direcciones IP remotas:", "LabelAllowedRemoteAddressesMode": "Modo de filtrado de direcciones IP remotas:", @@ -1200,7 +1190,6 @@ "TabAdvanced": "Avanzado", "TabAlbumArtists": "Artistas del álbum", "TabAlbums": "Álbumes", - "TabArtists": "Artistas", "TabCatalog": "Catálogo", "TabChannels": "Canales", "TabCollections": "Colecciones", @@ -1208,7 +1197,6 @@ "TabDashboard": "Panel de control", "TabDevices": "Dispositivos", "TabDirectPlay": "Reproducción directa", - "TabDisplay": "Mostrar", "TabEpisodes": "Episodios", "TabFavorites": "Favoritos", "TabGenres": "Géneros", @@ -1216,7 +1204,6 @@ "TabLatest": "Recientes", "TabLiveTV": "TV en vivo", "TabLogs": "Registros", - "TabMetadata": "Metadatos", "TabMovies": "Películas", "TabMusic": "Música", "TabMusicVideos": "Videos musicales", @@ -1227,7 +1214,6 @@ "TabOther": "Otros", "TabParentalControl": "Control parental", "TabPassword": "Contraseña", - "TabPlayback": "Reproducción", "TabPlaylists": "Listas de reproducción", "TabPlugins": "Complementos", "TabProfile": "Perfil", @@ -1241,9 +1227,7 @@ "TabShows": "Programas", "TabSongs": "Canciones", "TabStreaming": "Transmisión", - "TabSuggestions": "Sugerencias", "TabTrailers": "Trailers", - "TabTranscoding": "Transcodificación", "TabUpcoming": "Próximamente", "TabUsers": "Usuarios", "Tags": "Etiquetas", @@ -1469,7 +1453,6 @@ "LabelLibraryPageSize": "Tamaño de las páginas de las bibliotecas:", "HeaderFavoritePlaylists": "Listas de reproducción favoritas", "ButtonTogglePlaylist": "Lista de reproducción", - "ButtonToggleContextMenu": "Más", "UnsupportedPlayback": "Jellyfin no puede desencriptar contenido protegido por DRM de todas formas todo el contenido será intentado, incluyendo los títulos protegidos. Algunos archivos pueden aparecer completamente en negro debido al encriptado o características no soportadas, como títulos interactivos.", "TabDVR": "DVR", "SaveChanges": "Guardar cambios", diff --git a/src/strings/es.json b/src/strings/es.json index d720b515f4..016bc01656 100644 --- a/src/strings/es.json +++ b/src/strings/es.json @@ -40,7 +40,6 @@ "BoxRear": "Caja (trasera)", "Browse": "Explorar", "MessageBrowsePluginCatalog": "Explore el catálogo de extensiones para ver las extensiones disponibles.", - "ButtonAdd": "Añadir", "ButtonAddMediaLibrary": "Añadir biblioteca de medios", "ButtonAddScheduledTaskTrigger": "Agregar Activador", "ButtonAddServer": "Añadir servidor", @@ -66,7 +65,6 @@ "ButtonFullscreen": "Pantalla completa", "ButtonGotIt": "Entendido", "ButtonGuide": "Guía", - "ButtonHelp": "Ayuda", "ButtonHome": "Inicio", "ButtonLibraryAccess": "Acceso a la biblioteca", "ButtonManualLogin": "Acceder manualmente", @@ -87,15 +85,12 @@ "ButtonRefreshGuideData": "Actualizar datos de la guía", "ButtonRemove": "Quitar", "ButtonRename": "Renombrar", - "ButtonRepeat": "Repetir", "ButtonResetEasyPassword": "Restablecer código PIN", "ButtonResetPassword": "Reiniciar Contraseña", "ButtonRestart": "Reiniciar", "ButtonResume": "Continuar", "ButtonRevoke": "Revocar", - "ButtonSave": "Guardar", "ButtonScanAllLibraries": "Escanear todas las bibliotecas", - "ButtonSearch": "Buscar", "ButtonSelectDirectory": "Seleccionar directorio", "ButtonSelectServer": "Elegir servidor", "ButtonSelectView": "Seleccionar vista", @@ -269,7 +264,6 @@ "HeaderDevices": "Dispositivos", "HeaderDirectPlayProfile": "Perfil de reproducción directa", "HeaderDirectPlayProfileHelp": "Añadir perfiles de reproducción directa para indicar qué formatos puede utilizar el dispositivo de forma nativa.", - "HeaderDisplay": "Mostrar", "HeaderDownloadSync": "Descargar y sincronizar", "HeaderEasyPinCode": "Código PIN", "HeaderEditImages": "Editar imágenes", @@ -278,10 +272,8 @@ "HeaderEpisodes": "Episodios", "HeaderExternalIds": "IDs externos:", "HeaderFeatureAccess": "Permisos de acceso", - "HeaderFeatures": "Características", "HeaderFetchImages": "Buscar imágenes:", "HeaderFetcherSettings": "Ajustes del capturador", - "HeaderFilters": "Filtros", "HeaderForKids": "Para niños", "HeaderForgotPassword": "Contraseña olvidada", "HeaderFrequentlyPlayed": "Reproducido frecuentemente", @@ -390,7 +382,6 @@ "HeaderSubtitleProfiles": "Perfil de los subtítulos", "HeaderSubtitleProfilesHelp": "El perfil de los subtítulos describe el formato soportado por el dispositivo.", "HeaderSystemDlnaProfiles": "Perfiles del sistema", - "HeaderTags": "Etiquetas", "HeaderTaskTriggers": "Tareas de activación", "HeaderThisUserIsCurrentlyDisabled": "Este usuario está desactivado", "HeaderTranscodingProfile": "Parámetros de conversión", @@ -442,7 +433,6 @@ "LabelAlbumArtMaxWidthHelp": "Resolución máxima de la carátula del álbum expuesta a través de upnp: albumArtURI.", "LabelAlbumArtPN": "Carátula del album PN:", "LabelAlbumArtists": "Artistas de los álbumes:", - "LabelAll": "Todo", "LabelAllowHWTranscoding": "Activar la conversión acelerada por hardware", "LabelAllowedRemoteAddresses": "Filtro de dirección IP remota:", "LabelAllowedRemoteAddressesMode": "Modo de filtro de dirección IP remota:", @@ -1101,7 +1091,6 @@ "TabAdvanced": "Avanzado", "TabAlbumArtists": "Artistas de los álbumes", "TabAlbums": "Álbumes", - "TabArtists": "Artistas", "TabCatalog": "Catálogo", "TabChannels": "Canales", "TabCodecs": "Códecs", @@ -1110,14 +1099,12 @@ "TabDashboard": "Panel de control", "TabDevices": "Dispositivos", "TabDirectPlay": "Reproducción directa", - "TabDisplay": "Pantalla", "TabEpisodes": "Episodios", "TabFavorites": "Favoritos", "TabGenres": "Géneros", "TabGuide": "Guía", "TabLatest": "Novedades", "TabLiveTV": "Televisión en directo", - "TabMetadata": "Etiquetas", "TabMovies": "Películas", "TabMusic": "Música", "TabMusicVideos": "Videos musicales", @@ -1128,7 +1115,6 @@ "TabOther": "Otros", "TabParentalControl": "Control parental", "TabPassword": "Contraseña", - "TabPlayback": "Reproducción", "TabPlaylists": "Listas de reproducción", "TabProfile": "Perfil", "TabProfiles": "Perfiles", @@ -1141,8 +1127,6 @@ "TabShows": "Programas", "TabSongs": "Canciones", "TabStreaming": "Transmisión", - "TabSuggestions": "Sugerencias", - "TabTranscoding": "Conversión", "TabUpcoming": "Próximos", "TabUsers": "Usuarios", "Tags": "Etiquetas", @@ -1470,7 +1454,6 @@ "YadifBob": "YADIF Bob", "Yadif": "YADIF", "ButtonTogglePlaylist": "Lista de reproducción", - "ButtonToggleContextMenu": "Más", "Filter": "Filtro", "New": "Nuevo", "HeaderFavoritePlaylists": "Lista reproducción favorita", diff --git a/src/strings/es_419.json b/src/strings/es_419.json index 54dd68e9ed..4ab6f7ae4d 100644 --- a/src/strings/es_419.json +++ b/src/strings/es_419.json @@ -132,8 +132,6 @@ "Tags": "Etiquetas", "TabUsers": "Usuarios", "TabUpcoming": "Próximamente", - "TabTranscoding": "Transcodificación", - "TabSuggestions": "Sugerencias", "TabStreaming": "Transmisión", "TabSongs": "Canciones", "TabShows": "Programas", @@ -148,7 +146,6 @@ "TabProfile": "Perfil", "TabPlugins": "Complementos", "TabPlaylists": "Listas de reproducción", - "TabPlayback": "Reproducción", "TabPassword": "Contraseña", "TabParentalControl": "Control parental", "TabOther": "Otros", @@ -160,7 +157,6 @@ "TabMusicVideos": "Videos musicales", "TabMusic": "Música", "TabMovies": "Películas", - "TabMetadata": "Metadatos", "TabLogs": "Registros", "TabLiveTV": "TV en vivo", "TabInfo": "Información", @@ -169,7 +165,6 @@ "TabFavorites": "Favoritos", "TabEpisodes": "Episodios", "TabDVR": "DVR", - "TabDisplay": "Mostrar", "TabDirectPlay": "Reproducción directa", "TabDevices": "Dispositivos", "TabDashboard": "Panel de control", @@ -870,7 +865,6 @@ "LabelChannels": "Canales:", "LabelCertificatePasswordHelp": "Si tu certificado requiere una contraseña, por favor, introdúcela aquí.", "LabelCertificatePassword": "Contraseña del certificado:", - "TabArtists": "Artistas", "TabAlbums": "Álbumes", "TabAlbumArtists": "Artistas del álbum", "TabAdvanced": "Avanzado", @@ -963,7 +957,6 @@ "LabelAllowedRemoteAddressesMode": "Modo de filtrado de direcciones IP remotas:", "LabelAllowedRemoteAddresses": "Filtro de direcciones IP remotas:", "LabelAllowHWTranscoding": "Permitir transcodificación por hardware", - "LabelAll": "Todos", "LabelAlbumArtists": "Artistas del álbum:", "LabelAlbumArtPN": "PN del arte del álbum:", "LabelAlbumArtMaxWidthHelp": "Resolución máxima del arte del álbum expuesta vía upnp:albumArtURI.", @@ -1017,7 +1010,6 @@ "HeaderTracks": "Pistas", "HeaderThisUserIsCurrentlyDisabled": "Este usuario se encuentra actualmente deshabilitado", "HeaderTaskTriggers": "Disparadores de tarea", - "HeaderTags": "Etiquetas", "HeaderSystemDlnaProfiles": "Perfiles del sistema", "HeaderSyncPlayEnabled": "SyncPlay habilitado", "HeaderSyncPlaySelectGroup": "Unirse a un grupo", @@ -1128,10 +1120,8 @@ "HeaderFrequentlyPlayed": "Reproducido frecuentemente", "HeaderForgotPassword": "Olvidé mi contraseña", "HeaderForKids": "Para niños", - "HeaderFilters": "Filtros", "HeaderFetcherSettings": "Configuración del recolector", "HeaderFetchImages": "Obtener imágenes:", - "HeaderFeatures": "Características", "HeaderFeatureAccess": "Acceso a características", "HeaderFavoritePlaylists": "Listas de reproducción favoritas", "HeaderFavoriteVideos": "Videos favoritos", @@ -1185,7 +1175,6 @@ "HeaderEasyPinCode": "Código PIN sencillo", "HeaderDVR": "DVR", "HeaderDownloadSync": "Descargar y sincronizar", - "HeaderDisplay": "Pantalla", "HeaderDirectPlayProfileHelp": "Agrega perfiles de reproducción directa para indicar qué formatos puede manejar el dispositivo de forma nativa.", "HeaderDirectPlayProfile": "Perfil de reproducción directa", "HeaderDevices": "Dispositivos", @@ -1397,7 +1386,6 @@ "ButtonUninstall": "Desinstalar", "ButtonTrailer": "Trailer", "ButtonTogglePlaylist": "Lista de reproducción", - "ButtonToggleContextMenu": "Más", "ButtonSubtitles": "Subtítulos", "ButtonSubmit": "Enviar", "ButtonSplit": "Dividir", @@ -1413,15 +1401,12 @@ "ButtonSelectView": "Seleccionar vista", "ButtonSelectServer": "Seleccionar servidor", "ButtonSelectDirectory": "Seleccionar directorio", - "ButtonSearch": "Búsqueda", "ButtonScanAllLibraries": "Escanear todas las bibliotecas", - "ButtonSave": "Guardar", "ButtonRevoke": "Revocar", "ButtonResume": "Continuar", "ButtonRestart": "Reiniciar", "ButtonResetPassword": "Restablecer contraseña", "ButtonResetEasyPassword": "Restablecer código PIN sencillo", - "ButtonRepeat": "Repetir", "ButtonRename": "Renombrar", "ButtonRemove": "Remover", "ButtonRefreshGuideData": "Actualizar datos de la guía", @@ -1443,7 +1428,6 @@ "ButtonLibraryAccess": "Acceso a biblioteca(s)", "ButtonInfo": "Info", "ButtonHome": "Inicio", - "ButtonHelp": "Ayuda", "ButtonGuide": "Guía", "ButtonGotIt": "Hecho", "ButtonFullscreen": "Pantalla completa", @@ -1470,7 +1454,6 @@ "ButtonAddScheduledTaskTrigger": "Agregar disparador", "ButtonAddMediaLibrary": "Agregar biblioteca de medios", "ButtonAddImage": "Agregar imagen", - "ButtonAdd": "Agregar", "BurnSubtitlesHelp": "Determina si el servidor debería quemar los subtítulos al transcodificar videos. Evitar esto mejorará altamente el rendimiento del servidor. Seleccione Auto para grabar formatos basados en imágenes (VOBSUB, PGS, SUB, IDX...) y ciertos subtítulos ASS o SSA.", "MessageBrowsePluginCatalog": "Explora nuestro catálogo de complementos para ver los complementos disponibles.", "Browse": "Explorar", diff --git a/src/strings/fa.json b/src/strings/fa.json index 7d27860aaa..5db3a657ca 100644 --- a/src/strings/fa.json +++ b/src/strings/fa.json @@ -14,7 +14,6 @@ "ButtonPlay": "پخش", "ButtonQuickStartGuide": "راهنمای شروع سریع", "ButtonResetPassword": "تنظیم مجدد رمز", - "ButtonSave": "ذخیره", "ButtonSignOut": "Sign out", "ButtonSort": "مرتب سازی", "DeleteMedia": "حذف رسانه", @@ -30,7 +29,6 @@ "HeaderDeviceAccess": "دسترسی دستگاه", "HeaderEasyPinCode": "پین کد آسان", "HeaderFetcherSettings": "تنظیمات ورودی", - "HeaderFilters": "فیلتر ها", "HeaderImageOptions": "گزینه های تصویر", "HeaderInstantMix": "درهم کردن فوری", "HeaderKodiMetadataHelp": "برای فعال یا غیرفعال سازی ابرداده‌های Nfo ، یک کتابخانه را در صفحه تنظیم کتابخانه Jellyfin ویرایش کرده و قسمت سرورهای ابرداده را مسیردهی کنید.", @@ -89,11 +87,9 @@ "TabAdvanced": "پیشرفته", "TabAlbumArtists": "هنرمندان آلبوم", "TabAlbums": "آلبوم ها", - "TabArtists": "هنرمندان", "TabEpisodes": "قسمت ها", "TabGenres": "ژانرها", "TabLatest": "جدیدترین‌ها", - "TabMetadata": "فراداده", "TabMusicVideos": "موزیک ویدیوها", "TabNetworks": "شبکه ها", "TabNotifications": "اعلان ها", @@ -102,7 +98,6 @@ "TabProfiles": "پروفایل ها", "TabShows": "سریال ها", "TabSongs": "آهنگ ها", - "TabSuggestions": "پیشنهادها", "TabUpcoming": "بزودی", "TellUsAboutYourself": "در مورد خودتان به ما بگویید", "ThisWizardWillGuideYou": "این عمل برای انجام تنظیمات به شما کمک می‌کند. برای شروع، لطفا زبان مورد نظر خود را انتخاب کنید.", @@ -144,13 +139,11 @@ "ButtonSend": "ارسال", "ButtonSelectView": "انتخاب نما", "ButtonSelectServer": "انتخاب سرور", - "ButtonSearch": "جستجو", "ButtonScanAllLibraries": "اسکن تمام کتابخانه‌ها", "ButtonRevoke": "ابطال", "ButtonResume": "ادامه", "ButtonRestart": "راه اندازی مجدد", "ButtonResetEasyPassword": "بازنشانی کد پین آسان", - "ButtonRepeat": "تکرار", "ButtonRename": "تغییر نام", "ButtonRemove": "حذف", "ButtonRefreshGuideData": "به‌روز‌رسانی داده‌ی راهنما", @@ -168,7 +161,6 @@ "ButtonLibraryAccess": "دسترسی به کتابخانه", "ButtonInfo": "اطلاعات", "ButtonHome": "خانه", - "ButtonHelp": "کمک", "ButtonGuide": "راهنما", "ButtonGotIt": "متوجه شدم", "ButtonFullscreen": "تمام صفحه", @@ -189,7 +181,6 @@ "ButtonAddScheduledTaskTrigger": "افزودن راه انداز", "ButtonAddMediaLibrary": "افزودن کتابخانه رسانه", "ButtonAddImage": "افزودن تصویر", - "ButtonAdd": "افزودن", "BoxRear": "جعبه (پشت)", "Box": "جعبه", "Blacklist": "لیست سیاه", @@ -370,7 +361,6 @@ "HeaderForgotPassword": "فراموشی گذرواژه", "HeaderForKids": "برای کودکان", "HeaderFetchImages": "دریافت عکس‌ها:", - "HeaderFeatures": "برجسته‌ها", "HeaderFeatureAccess": "دسترسی‌های برجسته", "HeaderFavoriteVideos": "ویدیو‌های مورد علاقه", "HeaderFavoritePeople": "افراد مورد علاقه", @@ -383,7 +373,6 @@ "HeaderEnabledFields": "فیلد‌های فعال شده", "HeaderEditImages": "ویرایش عکس‌ها", "HeaderDownloadSync": "بارگیری و همگام‌سازی", - "HeaderDisplay": "نمایش", "HeaderDirectPlayProfileHelp": "نمایه‌ی پخش مستقیم را اضافه کنید تا مشخص کنید با چه فرمی دستگاه می‌تواند محلی برخورد کند.", "HeaderDirectPlayProfile": "نمایه‌ی پخش مستقیم", "HeaderDevices": "دستگاه‌ها", @@ -630,7 +619,6 @@ "TabInfo": "اطلاعات", "TabGuide": "راهنما", "TabFavorites": "مورد علاقه‌ها", - "TabDisplay": "نمایش", "TabDirectPlay": "پخش مستقیم", "TabDevices": "دستگاه‌ها", "TabDashboard": "داشبورد", @@ -640,7 +628,6 @@ "TabCatalog": "فهرست", "TV": "تلویزیون", "Sunday": "یکشنبه", - "TabTranscoding": "کدگذاری", "TabTrailers": "تریلرها", "Suggestions": "پیشنهادها", "Subtitles": "زیرنویس‌ها", @@ -655,7 +642,6 @@ "Smaller": "کوچکتر", "Small": "کوچک", "ButtonTogglePlaylist": "لیست پخش", - "ButtonToggleContextMenu": "بیشتر", "TheseSettingsAffectSubtitlesOnThisDevice": "این تنظیمات روی زیرنویس‌ها در این دستگاه تأثیر می‌گذارد", "TabStreaming": "در حال پخش", "TabSettings": "تنظیمات", @@ -667,7 +653,6 @@ "TabRecordings": "ضبط‌ها", "TabPlugins": "افزونه‌ها", "TabPlaylists": "لیست‌های پخش", - "TabPlayback": "پخش", "TabParentalControl": "رتبه بندی والدین", "TabOther": "سایر", "TabNfoSettings": "تنظیمات NFO", @@ -1067,7 +1052,6 @@ "HeaderSubtitleProfilesHelp": "Subtitle profiles describe the subtitle formats supported by the device.", "HeaderSyncPlaySelectGroup": "Join a group", "HeaderSyncPlayEnabled": "SyncPlay enabled", - "HeaderTags": "Tags", "HeaderThisUserIsCurrentlyDisabled": "This user is currently disabled", "HeaderTracks": "Tracks", "HeaderTranscodingProfile": "Transcoding Profile", @@ -1120,7 +1104,6 @@ "LabelAlbumArtMaxWidthHelp": "Max resolution of album art exposed via upnp:albumArtURI.", "LabelAlbumArtPN": "Album art PN:", "LabelAlbumArtists": "Album artists:", - "LabelAll": "All", "LabelAllowHWTranscoding": "Allow hardware transcoding", "LabelAllowedRemoteAddresses": "Remote IP address filter:", "LabelAllowedRemoteAddressesMode": "Remote IP address filter mode:", diff --git a/src/strings/fi.json b/src/strings/fi.json index 73f3c608ab..fd514ddb77 100644 --- a/src/strings/fi.json +++ b/src/strings/fi.json @@ -4,7 +4,6 @@ "ButtonCancel": "Peruuta", "ButtonDeleteImage": "Poista Kuva", "ButtonResetPassword": "Nollaa salasana", - "ButtonSave": "Tallenna", "ButtonSignOut": "Sign out", "Delete": "Poista", "DeleteImage": "Poista Kuva", @@ -100,7 +99,6 @@ "Box": "Laatikko", "BoxRear": "Laatikko (takaa)", "Browse": "Selaa", - "ButtonAdd": "Lisää", "ButtonAddMediaLibrary": "Lisää Mediakirjasto", "ButtonAddScheduledTaskTrigger": "Lisää Liipaisin", "ButtonAddServer": "Lisää Palvelin", @@ -123,7 +121,6 @@ "ButtonFullscreen": "Kokonäyttötila", "ButtonGotIt": "Selvä", "ButtonGuide": "Opas", - "ButtonHelp": "Apua", "ButtonHome": "Koti", "ButtonInfo": "Tiedot", "ButtonLibraryAccess": "Kiraston pääsy", @@ -146,13 +143,11 @@ "ButtonRefreshGuideData": "Päivitä oppaan tiedot", "ButtonRemove": "Poista", "ButtonRename": "Nimeä uudelleen", - "ButtonRepeat": "Uudelleentoisto", "ButtonResetEasyPassword": "Nollaa helppo PIN-koodi", "ButtonRestart": "Käynnistä uudelleen", "ButtonResume": "Jatka", "ButtonRevoke": "Peruuta", "ButtonScanAllLibraries": "Skannaa kaikki kirjastot", - "ButtonSearch": "Haku", "ButtonSelectDirectory": "Valitse hakemisto", "ButtonSelectServer": "Valitse palvelin", "ButtonSelectView": "Valitse näkymä", @@ -461,7 +456,6 @@ "HeaderLoginFailure": "Kirjautumisvirhe", "HeaderIdentifyItemHelp": "Anna yksi tai useampi hakukriteeri. Poista kriteerejä lisätäksesi hakutuloksia.", "HeaderIdentificationCriteriaHelp": "Lisää ainakin yksi tunnistuskriteeri.", - "HeaderFeatures": "Ominaisuudet", "HeaderFavoriteVideos": "Suosikkivideot", "HeaderFavoritePeople": "Suosikki-ihmiset", "HeaderFavoriteMovies": "Suosikkielokuvat", @@ -524,7 +518,6 @@ "HeaderFrequentlyPlayed": "Usein toistetut", "HeaderFetcherSettings": "Hakijan asetukset", "HeaderFetchImages": "Hae kuvia:", - "HeaderFilters": "Suodattimet", "OptionBlockBooks": "Kirjat", "Filters": "Suodattimet", "FastForward": "Hyppää eteenpäin", @@ -670,8 +663,6 @@ "Tags": "Tunnisteet", "TabUsers": "Käyttäjät", "TabUpcoming": "Tulevat", - "TabTranscoding": "Transkoodaus", - "TabSuggestions": "Ehdotukset", "TabSongs": "Kappaleet", "TabSettings": "Asetukset", "TabServer": "Palvelin", @@ -682,14 +673,12 @@ "TabRecordings": "Tallennukset", "TabPlugins": "Liitännäiset", "TabPlaylists": "Soittolistat", - "TabPlayback": "Toistaminen", "TabNfoSettings": "NFO-asetukset", "TabNetworks": "Verkot", "TabMyPlugins": "Omat liittännäiseni", "TabMusicVideos": "Musiikkivideot", "TabMusic": "Musiikki", "TabMovies": "Elokuvat", - "TabMetadata": "Metadata", "TabLogs": "Lokit", "TabLiveTV": "Live-TV", "TabLatest": "Uusimmat", @@ -697,14 +686,12 @@ "TabGenres": "Tyylilajit", "TabFavorites": "Suosikit", "TabEpisodes": "Jaksot", - "TabDisplay": "Näyttö", "TabDirectPlay": "Suoratoisto", "TabDevices": "Laitteet", "TabDashboard": "Päänäkymä", "TabCollections": "Kokoelmat", "TabChannels": "Kanavat", "TabCatalog": "Luettelo", - "TabArtists": "Artistit", "TabAlbums": "Albumit", "TabAlbumArtists": "Albumin artistit", "TabAdvanced": "Edistynyt", @@ -889,7 +876,6 @@ "LabelBirthYear": "Syntymävuosi:", "LabelBirthDate": "Syntymäaika:", "LabelArtists": "Artistit:", - "LabelAll": "Kaikki", "LabelAlbum": "Albumi:", "LabelAirTime": "Lähetysaika:", "LabelAccessDay": "Viikonpäivä:", @@ -903,7 +889,6 @@ "HeaderVideoQuality": "Kuvanlaatu", "HeaderUsers": "Käyttäjät", "HeaderUser": "Käyttäjä", - "HeaderTags": "Tunnisteet", "HeaderSubtitleAppearance": "Tekstityksen ulkonäkö", "HeaderStatus": "Tila", "HeaderShutdown": "Sammuta", @@ -928,7 +913,6 @@ "HeaderError": "Virhe", "HeaderEpisodes": "Jaksot", "HeaderEditImages": "Muokkaa kuvia", - "HeaderDisplay": "Näyttö", "HeaderDevices": "Laitteet", "HeaderDeleteItems": "Poista valitut", "HeaderDeleteItem": "Poista valittu", @@ -1011,7 +995,6 @@ "ExitFullscreen": "Poistu kokonäyttötilasta", "Episode": "Jakso", "ButtonTogglePlaylist": "Soittolista", - "ButtonToggleContextMenu": "Lisää", "Artist": "Artisti", "RefreshQueued": "Päivitys odottamassa.", "SeriesCancelled": "Sarja peruttu.", diff --git a/src/strings/fr-ca.json b/src/strings/fr-ca.json index 9229aabf56..d5782ea3fe 100644 --- a/src/strings/fr-ca.json +++ b/src/strings/fr-ca.json @@ -138,7 +138,6 @@ "MessageBrowsePluginCatalog": "Explorer notre catalogue des plugins pour voir les plugins disponibles.", "AllowHWTranscodingHelp": "Permets au syntonisateur de transcoder les flux à la volée. Cela peut aider à réduire le transcodage requis par le serveur.", "BurnSubtitlesHelp": "Détermine si le serveur doit graver les sous-titres lors du transcodage vidéo. Éviter ceci améliorera les performances du serveur. Sélectionnez Auto pour graver les formats basés sur l'image (par exemple, VOBSUB, PGS, SUB/IDX etc) ainsi que certains sous-titres ASS/SSA.", - "ButtonAdd": "Ajouter", "ButtonAddMediaLibrary": "Ajouter une médiathèque", "ButtonAddScheduledTaskTrigger": "Ajouter un déclencheur", "ButtonAddServer": "Ajouter un serveur", @@ -162,7 +161,6 @@ "ButtonForgotPassword": "Mot de passe oublié", "ButtonFullscreen": "Plein écran", "ButtonGuide": "Guide", - "ButtonHelp": "Aide", "ButtonHome": "Accueil", "ButtonInfo": "Informations", "ButtonLibraryAccess": "Accès à la médiathèque", @@ -207,7 +205,6 @@ "ButtonUp": "Vers le haut", "ButtonUninstall": "Désinstaller", "ButtonTogglePlaylist": "Liste de lecture", - "ButtonToggleContextMenu": "Plus", "ButtonSubtitles": "Sous-titres", "ButtonSubmit": "Soumettre", "ButtonStop": "Arrêt", @@ -220,14 +217,11 @@ "ButtonSend": "Envoyer", "ButtonSelectServer": "Sélectionner le serveur", "ButtonSelectDirectory": "Sélectionner le répertoire", - "ButtonSearch": "Rechercher", "ButtonScanAllLibraries": "Analyser toutes les médiathèques", - "ButtonSave": "Sauvegarder", "ButtonRevoke": "Révoquer", "ButtonResume": "Reprendre la lecture", "ButtonResetPassword": "Réinitialiser le mot de passe", "ButtonResetEasyPassword": "Remettre à nouveau le code NIP facile", - "ButtonRepeat": "Répéter", "ButtonRename": "Renommer", "ButtonRemove": "Enlever", "ButtonRefreshGuideData": "Rafraîchir les données de guide", diff --git a/src/strings/fr.json b/src/strings/fr.json index 20b96f3a52..d34b6c9de3 100644 --- a/src/strings/fr.json +++ b/src/strings/fr.json @@ -49,7 +49,6 @@ "Browse": "Parcourir", "MessageBrowsePluginCatalog": "Explorer notre catalogue des plugins pour voir les plugins disponibles.", "BurnSubtitlesHelp": "Détermine si le serveur doit incruster les sous-titres lors du transcodage de la vidéo. Les performances seront grandement améliorées sans incrustation. Sélectionnez Auto pour incruster par image les formats (VOBSUB, PGS, SUB, IDX etc) et certains sous-titres ASS ou SSA.", - "ButtonAdd": "Ajouter", "ButtonAddMediaLibrary": "Ajouter une médiathèque", "ButtonAddScheduledTaskTrigger": "Ajouter un déclencheur", "ButtonAddServer": "Ajouter un serveur", @@ -74,7 +73,6 @@ "ButtonForgotPassword": "Mot de passe oublié", "ButtonFullscreen": "Plein écran", "ButtonGotIt": "Compris", - "ButtonHelp": "Aide", "ButtonHome": "Accueil", "ButtonInfo": "Informations", "ButtonLibraryAccess": "Accès à la médiathèque", @@ -95,15 +93,12 @@ "ButtonRefreshGuideData": "Actualiser les données du guide", "ButtonRemove": "Supprimer", "ButtonRename": "Renommer", - "ButtonRepeat": "Répéter", "ButtonResetEasyPassword": "Réinitialiser le code easy PIN", "ButtonResetPassword": "Réinitialiser le mot de passe", "ButtonRestart": "Redémarrer", "ButtonResume": "Reprendre", "ButtonRevoke": "Révoquer", - "ButtonSave": "Enregistrer", "ButtonScanAllLibraries": "Actualiser toutes les médiathèques", - "ButtonSearch": "Recherche", "ButtonSelectDirectory": "Sélectionner le répertoire", "ButtonSelectServer": "Sélectionner le serveur", "ButtonSelectView": "Sélectionnez une vue", @@ -314,7 +309,6 @@ "HeaderDevices": "Appareils", "HeaderDirectPlayProfile": "Profil de lecture directe :", "HeaderDirectPlayProfileHelp": "Ajoutez des profils de lecture directe pour indiquer quels formats l'appareil peut lire de façon native.", - "HeaderDisplay": "Affichage", "HeaderDownloadSync": "Télécharger et synchroniser", "HeaderEasyPinCode": "Code Easy PIN", "HeaderEditImages": "Modifier les images", @@ -324,10 +318,8 @@ "HeaderError": "Erreur", "HeaderExternalIds": "Identifiants externes :", "HeaderFeatureAccess": "Accès aux fonctionnalités", - "HeaderFeatures": "Fonctionnalités", "HeaderFetchImages": "Télécharger les images :", "HeaderFetcherSettings": "Paramètres du récupérateur", - "HeaderFilters": "Filtres", "HeaderForKids": "Jeunesse", "HeaderForgotPassword": "Mot de passe oublié", "HeaderFrequentlyPlayed": "Fréquemment lus", @@ -438,7 +430,6 @@ "HeaderSubtitleProfiles": "Profils de sous-titre", "HeaderSubtitleProfilesHelp": "Les profils de sous-titre décrivent les formats de sous-titre supportés par l'appareil.", "HeaderSystemDlnaProfiles": "Profils système", - "HeaderTags": "Étiquettes", "HeaderTaskTriggers": "Déclencheurs de tâches", "HeaderThisUserIsCurrentlyDisabled": "Cet utilisateur est actuellement désactivé", "HeaderTracks": "Pistes", @@ -491,7 +482,6 @@ "LabelAlbumArtMaxWidthHelp": "Résolution maximum des images d'album exposée par upnp:albumArtURI.", "LabelAlbumArtPN": "PN d'images d'album :", "LabelAlbumArtists": "Artistes de l'album :", - "LabelAll": "Tout", "LabelAllowHWTranscoding": "Autoriser le transcodage matériel", "LabelAllowedRemoteAddresses": "Filtre d'adresse IP distante :", "LabelAllowedRemoteAddressesMode": "Type de filtre des adresses IP distantes :", @@ -1190,20 +1180,17 @@ "TabAccess": "Accès", "TabAdvanced": "Avancé", "TabAlbumArtists": "Artistes de l'album", - "TabArtists": "Artistes", "TabCatalog": "Catalogue", "TabChannels": "Chaînes", "TabContainers": "Conteneurs", "TabDashboard": "Tableau de bord", "TabDevices": "Appareils", "TabDirectPlay": "Lecture directe", - "TabDisplay": "Affichage", "TabEpisodes": "Épisodes", "TabFavorites": "Favoris", "TabLatest": "Derniers", "TabLiveTV": "TV en direct", "TabLogs": "Journaux", - "TabMetadata": "Métadonnées", "TabMovies": "Films", "TabMusic": "Musique", "TabMusicVideos": "Vidéos musicales", @@ -1213,7 +1200,6 @@ "TabOther": "Autre", "TabParentalControl": "Contrôle Parental", "TabPassword": "Mot de passe", - "TabPlayback": "Lecture", "TabPlaylists": "Listes de lecture", "TabProfile": "Profil", "TabProfiles": "Profils", @@ -1227,7 +1213,6 @@ "TabShows": "Séries", "TabSongs": "Chansons", "TabTrailers": "Bandes-annonces", - "TabTranscoding": "Transcodage", "TabUpcoming": "À venir", "TabUsers": "Utilisateurs", "Tags": "Étiquettes", @@ -1347,7 +1332,6 @@ "TabNotifications": "Notifications", "TabPlugins": "Extensions", "TabStreaming": "Streaming", - "TabSuggestions": "Suggestions", "ValueAlbumCount": "{0} albums", "ValueMinutes": "{0} min", "ValueOneAlbum": "1 album", @@ -1467,7 +1451,6 @@ "LabelLibraryPageSizeHelp": "Définit la quantité d'éléments à afficher sur une page de médiathèque. Définir à 0 afin de désactiver la pagination.", "UnsupportedPlayback": "Jellyfin ne peut pas décoder du contenu protégé par un système de gestion des droits numériques, mais une tentative de lecture sera effectuée sur tout le contenu, y compris les titres protégés. Certains fichiers peuvent apparaître complètement noir, du fait de protections ou de fonctionnalités non supportées, comme les titres interactifs.", "ButtonTogglePlaylist": "Liste de lecture", - "ButtonToggleContextMenu": "Plus", "Filter": "Filtre", "New": "Nouveau", "HeaderFavoritePlaylists": "Listes de lecture favorites", diff --git a/src/strings/gsw.json b/src/strings/gsw.json index bf9852e512..70c773a137 100644 --- a/src/strings/gsw.json +++ b/src/strings/gsw.json @@ -6,7 +6,6 @@ "ButtonOk": "OK", "ButtonQuickStartGuide": "Schnellstart Instruktione", "ButtonResetPassword": "Passwort zrug setze", - "ButtonSave": "Speichere", "ButtonSignOut": "Uslogge", "ButtonSort": "Sortiere", "ChannelAccessHelp": "Wähl en Kanal us, um de mit dem User z'teile. Administratore werded immer d'Möglichkeit ha alli Kanäl mitm Metadate Manager z'bearbeite.", @@ -98,12 +97,10 @@ "TabAdvanced": "Erwiitert", "TabAlbumArtists": "Album-Artist", "TabAlbums": "Albene", - "TabArtists": "Artist", "TabCatalog": "Katalog", "TabEpisodes": "Episode", "TabGenres": "Genre", "TabLatest": "Letschti", - "TabMetadata": "Metadate", "TabMovies": "Film", "TabMusicVideos": "Musigvideos", "TabMyPlugins": "Miini Plugins", @@ -113,7 +110,6 @@ "TabProfile": "Profil", "TabProfiles": "Profil", "TabShows": "Serie", - "TabSuggestions": "Vorschläg", "TabUpcoming": "Usstehend", "TellUsAboutYourself": "Verzell was über dech selber", "ThisWizardWillGuideYou": "De Assistent hilft der dur de Installations Prozess. Zum afange, wähl bitte dini Sproch us.", diff --git a/src/strings/he.json b/src/strings/he.json index c266f587c2..f5084ace4c 100644 --- a/src/strings/he.json +++ b/src/strings/he.json @@ -16,7 +16,6 @@ "Backdrops": "תמונות רקע", "BirthLocation": "מיקום לידה", "MessageBrowsePluginCatalog": "עבור לקטלוג התוספים לראות אילו זמינים.", - "ButtonAdd": "הוסף", "ButtonAddUser": "הוסף משתמש", "ButtonCancel": "בטל", "ButtonDelete": "מחק", @@ -33,8 +32,6 @@ "ButtonRemove": "הסר", "ButtonResetPassword": "איפוס סיסמא", "ButtonRestart": "הפעל מחדש", - "ButtonSave": "שמור", - "ButtonSearch": "חיפוש", "ButtonSelectDirectory": "בחר תיקיות", "ButtonShutdown": "כבה", "ButtonSignIn": "היכנס", @@ -440,7 +437,6 @@ "TabAdvanced": "מתקדם", "TabAlbumArtists": "אמני אלבום", "TabAlbums": "אלבומים", - "TabArtists": "אמנים", "TabCatalog": "קטלוג", "TabChannels": "ערוצים", "TabCodecs": "מקודדים", @@ -467,9 +463,7 @@ "TabSettings": "הגדרות", "TabShows": "תוכניות", "TabSongs": "שירים", - "TabSuggestions": "המלצות", "TabTrailers": "טריילרים", - "TabTranscoding": "קידוד", "TabUpcoming": "בקרוב", "Tags": "מילות מפתח", "TellUsAboutYourself": "ספר לנו על עצמך", @@ -573,7 +567,6 @@ "ButtonMore": "עוד", "ButtonInfo": "מידע", "ButtonHome": "בית", - "ButtonHelp": "עזרה", "ButtonFullscreen": "מסך מלא", "ButtonEditImages": "ערוך תמונות", "ButtonConnect": "התחבר", @@ -588,7 +581,6 @@ "MessageConfirmRestart": "‫האם אתה בטוח שברצונך לאתחל את שרת ה-Jellyfin‏?", "HeaderThisUserIsCurrentlyDisabled": "משתמש זה אינו פעיל כרגע", "HeaderTaskTriggers": "טריגרים של המשימה", - "HeaderTags": "מילות מפתח", "HeaderStopRecording": "עצור הקלטה", "HeaderSortOrder": "סדר מיון", "HeaderSortBy": "מיין לפי", @@ -626,7 +618,6 @@ "HeaderHome": "בית", "HeaderGenres": "ז'אנרים", "HeaderForKids": "עבור ילדים", - "HeaderFilters": "מסננים", "HeaderFavoriteVideos": "סרטונים מועדפים", "HeaderFavoritePeople": "אנשים מועדפים", "HeaderFavoriteMovies": "סרטים מועדפים", @@ -702,7 +693,6 @@ "TabScheduledTasks": "משימות מתוזמנות", "TabResumeSettings": "המשך צפייה", "ButtonResume": "המשך", - "ButtonRepeat": "חזרה", "ButtonRefresh": "רענון", "ButtonProfile": "פרופיל", "ButtonOpen": "פתח", @@ -756,7 +746,6 @@ "LabelSpecialSeasonsDisplayName": "שם תצוגת \"עונה מיוחדת\":", "LabelSource": "מקור:", "ButtonTogglePlaylist": "רשימת ניגון", - "ButtonToggleContextMenu": "עוד", "ButtonSyncPlay": "SyncPlay", "ButtonPlayer": "נגן", "StopPlayback": "הפסק הפעלה", @@ -821,8 +810,6 @@ "MessagePlayAccessRestricted": "התוכן הזה לא ניתן לניגון כרגע. למידע נוסף, נא ליצור קשר עם מנהל המערכת שלך.", "MessageContactAdminToResetPassword": "נא ליצור קשר עם מנהל המערכת שלך על מנת לאפס את הסיסמה שלך.", "HeaderAdmin": "מנהל", - "TabDisplay": "תצוגה", - "HeaderDisplay": "תצוגה", "Suggestions": "המלצות", "MessageSyncPlayNoGroupsAvailable": "אין קבוצות זמינות. התחל לנגן משהו קודם.", "OptionHomeVideos": "תמונות", diff --git a/src/strings/hi-in.json b/src/strings/hi-in.json index e7e45dfa20..e7ac775adf 100644 --- a/src/strings/hi-in.json +++ b/src/strings/hi-in.json @@ -44,7 +44,6 @@ "ButtonLibraryAccess": "पुस्तकालय का उपयोग", "ButtonInfo": "जानकारी", "ButtonHome": "घर", - "ButtonHelp": "मदद", "ButtonGuide": "मार्गदर्शक", "ButtonGotIt": "समझ गया", "ButtonFullscreen": "पूर्ण स्क्रीन", @@ -71,7 +70,6 @@ "ButtonAddScheduledTaskTrigger": "ट्रिगर जोड़ें", "ButtonAddMediaLibrary": "मीडिया लाइब्रेरी जोड़ें", "ButtonAddImage": "छवि जोड़ें", - "ButtonAdd": "जोड़ें", "UnsupportedPlayback": "Jellyfin DRM द्वारा संरक्षित सामग्री को डिक्रिप्ट नहीं कर सकता है, लेकिन सभी सामग्री की परवाह किए बिना, संरक्षित शीर्षकों सहित प्रयास किया जाएगा। एन्क्रिप्शन या अन्य असमर्थित सुविधाओं जैसे इंटरेक्टिव शीर्षक के कारण कुछ फाइलें पूरी तरह से काली दिखाई दे सकती हैं।", "BoxRear": "बॉक्स (पीछे)", "Box": "बॉक्स", diff --git a/src/strings/hr.json b/src/strings/hr.json index 622df7775e..44c151be31 100644 --- a/src/strings/hr.json +++ b/src/strings/hr.json @@ -16,7 +16,6 @@ "BirthLocation": "Lokacija rođenja", "BirthPlaceValue": "Mjesto rođenja: {0}", "MessageBrowsePluginCatalog": "Pregledajte dostupne dodatke u našem katalogu.", - "ButtonAdd": "Dodaj", "ButtonAddMediaLibrary": "Dodaj medijsku bibilioteku", "ButtonAddScheduledTaskTrigger": "Dodaj okidač", "ButtonAddServer": "Dodaj Server", @@ -41,7 +40,6 @@ "ButtonFullscreen": "Puni zaslon", "ButtonGotIt": "Shvaćam", "ButtonGuide": "Vodič", - "ButtonHelp": "Pomoć", "ButtonHome": "Početna", "ButtonLibraryAccess": "Pristup biblioteci", "ButtonManualLogin": "Ručna prijava", @@ -62,14 +60,11 @@ "ButtonRefreshGuideData": "Osvježi TV vodič", "ButtonRemove": "Ukloni", "ButtonRename": "Preimenuj", - "ButtonRepeat": "Ponovi", "ButtonResetEasyPassword": "Poništi jednostavan PIN kod", "ButtonResetPassword": "Resetiraj lozinku", "ButtonRestart": "Ponovo pokreni", "ButtonResume": "Nastavi", "ButtonRevoke": "Opozvati", - "ButtonSave": "Snimi", - "ButtonSearch": "Traži", "ButtonSelectDirectory": "Odaberi mapu", "ButtonSelectServer": "Odaberi Server", "ButtonSelectView": "Odaberi pogled", @@ -202,7 +197,6 @@ "HeaderDevices": "Uređaji", "HeaderDirectPlayProfile": "Profil za direktnu reprodukciju", "HeaderDirectPlayProfileHelp": "Dodaj izravne profile reprodukcije za označavanje kojim formatima uređaj može rukovati prirodno.", - "HeaderDisplay": "Prikaz", "HeaderEasyPinCode": "Lagan PIN", "HeaderEditImages": "Uređivanje slika", "HeaderEnabledFields": "Omogući polja", @@ -210,9 +204,7 @@ "HeaderEpisodes": "Epizode", "HeaderError": "Greška", "HeaderFeatureAccess": "Pristup opcijama", - "HeaderFeatures": "Mogućnosti", "HeaderFetchImages": "Dohvati slike:", - "HeaderFilters": "Filtri", "HeaderForKids": "Za djecu", "HeaderForgotPassword": "Zaboravili ste lozinku", "HeaderFrequentlyPlayed": "Često izvođeno", @@ -297,7 +289,6 @@ "HeaderSubtitleProfiles": "Profili titlova prijevoda", "HeaderSubtitleProfilesHelp": "Profili titlova prijevoda opisuju format titlova koji podržava uređaj.", "HeaderSystemDlnaProfiles": "Sistemski profil", - "HeaderTags": "Oznake", "HeaderTaskTriggers": "Okidači zadataka", "HeaderThisUserIsCurrentlyDisabled": "Ovaj je korisnik trenutno onemogućen", "HeaderTranscodingProfile": "Profil transkodiranja", @@ -340,7 +331,6 @@ "LabelAlbumArtMaxWidthHelp": "Maksimalna rezolucija albuma izloženih putem UPnP:albumArtURI.", "LabelAlbumArtPN": "Grafika albuma PN:", "LabelAlbumArtists": "Izvođači albuma:", - "LabelAll": "Sve", "LabelAllowHWTranscoding": "Dopusti hardversko konvertiranje", "LabelAppName": "Ime aplikacije", "LabelAppNameExample": "Primjer: Sickbeard, Sonarr", @@ -896,7 +886,6 @@ "TabAdvanced": "Napredno", "TabAlbumArtists": "Albumi izvođača", "TabAlbums": "Albumi", - "TabArtists": "Izvođači", "TabCatalog": "Katalog", "TabChannels": "Kanali", "TabCodecs": "Kodek", @@ -905,7 +894,6 @@ "TabDashboard": "Nadzorna ploča", "TabDevices": "Uređaji", "TabDirectPlay": "Direktna reprodukcija", - "TabDisplay": "Prikaz", "TabEpisodes": "Epizode", "TabFavorites": "Omiljeni", "TabGenres": "Žanrovi", @@ -913,7 +901,6 @@ "TabLatest": "Zadnje", "TabLiveTV": "TV uživo", "TabLogs": "Dnevnici", - "TabMetadata": "Meta-podaci", "TabMovies": "Filmovi", "TabMusic": "Glazba", "TabMusicVideos": "Muzički spotovi", @@ -924,7 +911,6 @@ "TabOther": "Ostalo", "TabParentalControl": "Roditeljska kontrola", "TabPassword": "Lozinka", - "TabPlayback": "Reprodukcija", "TabPlaylists": "Popisi", "TabPlugins": "Dodaci", "TabProfile": "Profil", @@ -938,9 +924,7 @@ "TabShows": "Emisije", "TabSongs": "Pjesme", "TabStreaming": "Strujanje", - "TabSuggestions": "Prijedlozi", "TabTrailers": "Kratki filmovi", - "TabTranscoding": "Konvertiranje", "TabUpcoming": "Uskoro", "TabUsers": "Korisnici", "Tags": "Oznake", @@ -1048,7 +1032,6 @@ "Connect": "Spoji", "ClientSettings": "Postavke klijenta", "ButtonTogglePlaylist": "Lista izvođenja", - "ButtonToggleContextMenu": "Više", "ButtonSplit": "Odvoji", "ButtonStop": "Stop", "ButtonScanAllLibraries": "Skeniraj sve biblioteke", diff --git a/src/strings/hu.json b/src/strings/hu.json index a25e02882c..3a88ccf9b3 100644 --- a/src/strings/hu.json +++ b/src/strings/hu.json @@ -16,7 +16,6 @@ "BirthPlaceValue": "Születési hely: {0}", "Books": "Könyvek", "Browse": "Tallózás", - "ButtonAdd": "Hozzáadás", "ButtonAddMediaLibrary": "Médiakönyvtár hozzáadása", "ButtonAddServer": "Szerver Hozzáadása", "ButtonAddUser": "Új felhasználó", @@ -35,7 +34,6 @@ "ButtonFilter": "Szűrő", "ButtonForgotPassword": "Elfelejtett Jelszó", "ButtonGotIt": "Értettem", - "ButtonHelp": "Segítség", "ButtonHome": "Kezdőlap", "ButtonLibraryAccess": "Könyvtár hozzáférés", "ButtonManualLogin": "Manuális belépés", @@ -53,14 +51,11 @@ "ButtonRefresh": "Frissítés", "ButtonRemove": "Eltávolítás", "ButtonRename": "Átnevezés", - "ButtonRepeat": "Ismétlés", "ButtonResetEasyPassword": "Pin kód visszaállítása", "ButtonResetPassword": "Jelszó visszaállítás", "ButtonRestart": "Újraindítás", "ButtonResume": "Folytatás", - "ButtonSave": "Mentés", "ButtonScanAllLibraries": "Minden könyvtár beolvasása", - "ButtonSearch": "Keresés", "ButtonSelectDirectory": "Könyvtár választása", "ButtonSelectServer": "Szerver Kiválasztás", "ButtonSend": "Küldés", @@ -140,15 +135,12 @@ "HeaderDeveloperInfo": "Fejlesztői információk", "HeaderDeviceAccess": "Eszköz Hozzáférések", "HeaderDevices": "Eszközök", - "HeaderDisplay": "Megjelenítés", "HeaderDownloadSync": "Letöltés és szinkronizálás", "HeaderEasyPinCode": "Pin kód", "HeaderEditImages": "Képek szerkesztése", "HeaderEnabledFields": "Engedélyezett mezők", "HeaderEpisodes": "Epizódok", "HeaderExternalIds": "Külső id-k:", - "HeaderFeatures": "Jellemzők", - "HeaderFilters": "Szűrők", "HeaderForgotPassword": "Elfelejtett Jelszó", "HeaderFrequentlyPlayed": "Gyakran játszott", "HeaderGenres": "Műfajok", @@ -208,7 +200,6 @@ "HeaderStatus": "Állapot", "HeaderSubtitleDownloads": "Felirat letöltések", "HeaderSystemDlnaProfiles": "Rendszer profilok", - "HeaderTags": "Címkék", "HeaderTracks": "Sávok", "HeaderUploadImage": "Kép feltöltés", "HeaderUser": "Felhasználó", @@ -225,7 +216,6 @@ "InstallingPackage": "{0} ({1} verzió) telepítése", "Label3DFormat": "3D formátum:", "LabelAlbumArtists": "Album előadók:", - "LabelAll": "Összes", "LabelArtists": "Előadók:", "LabelAudio": "Audió", "LabelAudioLanguagePreference": "Audió nyelvének beállítása:", @@ -495,7 +485,6 @@ "TabAdvanced": "Haladó", "TabAlbumArtists": "Album Előadók", "TabAlbums": "Albumok", - "TabArtists": "Előadók", "TabCatalog": "Katalógus", "TabChannels": "Csatornák", "TabCodecs": "Kódek", @@ -503,7 +492,6 @@ "TabContainers": "Tároló", "TabDashboard": "Vezérlőpult", "TabDevices": "Eszközök", - "TabDisplay": "Megjelenítés", "TabEpisodes": "Epizódok", "TabFavorites": "Kedvencek", "TabGenres": "Műfajok", @@ -511,7 +499,6 @@ "TabInfo": "Infó", "TabLatest": "Legújabb", "TabLogs": "Naplók", - "TabMetadata": "Metaadat", "TabMovies": "Filmek", "TabMusic": "Zene", "TabMusicVideos": "Zenei Videók", @@ -522,7 +509,6 @@ "TabOther": "Egyéb", "TabParentalControl": "Szülői Felügyelet", "TabPassword": "Jelszó", - "TabPlayback": "Lejátszás", "TabPlaylists": "Lejátszási listák", "TabPlugins": "Bővítmények", "TabProfile": "Profil", @@ -534,9 +520,7 @@ "TabSettings": "Beállítások", "TabShows": "Műsorok", "TabSongs": "Dalok", - "TabSuggestions": "Javaslatok", "TabTrailers": "Előzetesek", - "TabTranscoding": "Átkódolás", "TabUpcoming": "Hamarosan érkezik", "TabUsers": "Felhasználók", "Tags": "Címkék", @@ -1467,7 +1451,6 @@ "YadifBob": "YADIF Bob", "Yadif": "YADIF", "ButtonTogglePlaylist": "Lejátszási listák", - "ButtonToggleContextMenu": "Továbbiak", "Filter": "Szűrés", "New": "Új", "HeaderFavoritePlaylists": "Kedvenc lejátszási listák", diff --git a/src/strings/id.json b/src/strings/id.json index cb840a4989..bcb8c6a441 100644 --- a/src/strings/id.json +++ b/src/strings/id.json @@ -93,13 +93,10 @@ "ButtonSelectView": "Pilih tampilan", "ButtonSelectServer": "Pilih Peladen", "ButtonSelectDirectory": "Pilih Direktori", - "ButtonSearch": "Cari", "ButtonScanAllLibraries": "Pindai Semua Pustaka", - "ButtonSave": "Simpan", "ButtonResume": "Lanjutkan", "ButtonResetPassword": "Atur ulang Kata sandi", "ButtonResetEasyPassword": "Atur ulang kode pin mudah", - "ButtonRepeat": "Ulangi", "ButtonRename": "Ubah nama", "ButtonRemove": "Hapus", "ButtonRefreshGuideData": "Muat ulang Data Panduan", @@ -117,7 +114,6 @@ "ButtonLibraryAccess": "Akses pustaka", "ButtonInfo": "Info", "ButtonHome": "Beranda", - "ButtonHelp": "Bantuan", "ButtonGuide": "Panduan", "ButtonGotIt": "Paham", "ButtonFullscreen": "Layar penuh", @@ -144,7 +140,6 @@ "ButtonAddScheduledTaskTrigger": "Tambah Pemicu", "ButtonAddMediaLibrary": "Tambah Pustaka Media", "ButtonAddImage": "Tamba gambar", - "ButtonAdd": "Tambah", "MessageBrowsePluginCatalog": "Jelajahi katalog plugin kamu untuk melihat plugin yang tersedia.", "Browse": "Jelajah", "BoxRear": "Kotak (belakang)", diff --git a/src/strings/is-is.json b/src/strings/is-is.json index 66ea452a64..a820f82921 100644 --- a/src/strings/is-is.json +++ b/src/strings/is-is.json @@ -108,7 +108,6 @@ "Blacklist": "Bannlisti", "Box": "Kassi", "BoxRear": "Box (að aftan)", - "ButtonAdd": "Bæta við", "ButtonAddMediaLibrary": "Bæta við myndasafni", "ButtonAddScheduledTaskTrigger": "Bæta við orsakavald (trigger)", "Books": "Bækur", @@ -220,8 +219,6 @@ "ButtonSend": "Senda", "ButtonSelectServer": "Velja netþjón", "ButtonSelectDirectory": "Velja möppu", - "ButtonSearch": "Leita", - "ButtonSave": "Vista", "ButtonRestart": "Endurræsa", "ButtonResetPassword": "Endurstilla lykilorð", "ButtonOpen": "Opna", @@ -236,7 +233,6 @@ "ButtonRename": "Endurnefna", "Sync": "Samstilla", "ButtonRevoke": "Afturkalla", - "ButtonRepeat": "Endurtaka", "Monday": "Mánudagur", "ButtonRefresh": "Endurhlaða", "ButtonParentalControl": "Foreldraeftirlit", @@ -248,7 +244,6 @@ "ButtonLibraryAccess": "Aðgangur að safni", "ButtonInfo": "Upplýsingar", "ButtonHome": "Heim", - "ButtonHelp": "Hjálp", "ButtonGuide": "Sjónvarpsvísir", "ButtonGotIt": "Skilið", "ButtonFullscreen": "Fylla upp í skjá", @@ -309,7 +304,6 @@ "HeaderDetectMyDevices": "Finna tækin mín", "HeaderFavoritePeople": "Uppáhalds Fólk", "HeaderFavoritePlaylists": "Uppáhalds spilunarlistar", - "HeaderFilters": "Síur", "HeaderForgotPassword": "Gleymt lykilorð", "HeaderForKids": "Fyrir Krakka", "HeaderFrequentlyPlayed": "Oft Spilað", @@ -387,7 +381,6 @@ "Composer": "Tónskáld", "ClientSettings": "Stillingar biðlara", "ButtonTogglePlaylist": "Spilunarlisti", - "ButtonToggleContextMenu": "Meira", "ButtonSplit": "Skipta", "ButtonStop": "Stöðva", "ButtonResetEasyPassword": "Endurstilla Easy PIN númer", @@ -435,9 +428,7 @@ "TellUsAboutYourself": "Segðu okkur frá sjálfum þér", "TabUsers": "Notendur", "TabUpcoming": "Væntanlegt", - "TabTranscoding": "Umkóðun", "TabTrailers": "Sýnishorn", - "TabSuggestions": "Tillögur", "TabSongs": "Lög", "TabResumeSettings": "Halda áfram", "TabProfile": "Prófíll", @@ -482,7 +473,6 @@ "LabelAudio": "Hljóð", "LabelArtists": "Listamenn:", "LabelAppNameExample": "Dæmi: Sickbeard, Sonarr", - "LabelAll": "Allt", "LabelAccessDay": "Vikudagur:", "Kids": "Krakkar", "Hide": "Fela", @@ -493,7 +483,6 @@ "HeaderVideoQuality": "Myndgæði", "HeaderUsers": "Notendur", "HeaderUser": "Notandi", - "TabMetadata": "Lýsigögn", "TabGenres": "Flokkar", "TabFavorites": "Eftirlæti", "TabEpisodes": "Þættir", diff --git a/src/strings/it.json b/src/strings/it.json index 15e32d84bf..2dd958fb49 100644 --- a/src/strings/it.json +++ b/src/strings/it.json @@ -44,7 +44,6 @@ "Browse": "Esplora", "MessageBrowsePluginCatalog": "Sfoglia il catalogo dei Plugins.", "BurnSubtitlesHelp": "Determina se il server deve imprimere i sottotitoli quando i video vengono convertiti. Evitare ciò migliorerà di molto le prestazioni. Selezionare Auto per imprimere formati basati sull'immagine (VOBSUB, PGS, SUB, IDX, ...) e alcuni sottotitoli ASS o SSA.", - "ButtonAdd": "Aggiungi", "ButtonAddMediaLibrary": "Aggiungi raccolta multimediale", "ButtonAddScheduledTaskTrigger": "Aggiungi operazione", "ButtonAddServer": "Aggiungi server", @@ -69,7 +68,6 @@ "ButtonFullscreen": "Schermo Intero", "ButtonGotIt": "Ho capito", "ButtonGuide": "Guida", - "ButtonHelp": "Aiuto", "ButtonLibraryAccess": "Accesso biblioteca", "ButtonManualLogin": "Accesso Manuale", "ButtonMore": "Altro", @@ -88,15 +86,12 @@ "ButtonRefreshGuideData": "Aggiorna la guida", "ButtonRemove": "Rimuovi", "ButtonRename": "Rinomina", - "ButtonRepeat": "Ripeti", "ButtonResetEasyPassword": "Resetta codice PIN", "ButtonResetPassword": "Reset Password", "ButtonRestart": "Riavvia", "ButtonResume": "Riprendi", "ButtonRevoke": "Revocare", - "ButtonSave": "Salva", "ButtonScanAllLibraries": "Scansiona Tutte le Librerie", - "ButtonSearch": "Cerca", "ButtonSelectDirectory": "Seleziona cartella", "ButtonSelectServer": "Scegli Server", "ButtonSelectView": "Seleziona vista", @@ -302,7 +297,6 @@ "HeaderDevices": "Dispositivi", "HeaderDirectPlayProfile": "Profilo Direct Play", "HeaderDirectPlayProfileHelp": "Aggiungere \"profili riproduzione diretta\" per indicare i formati che il dispositivo è in grado di gestire in modo nativo.", - "HeaderDisplay": "Schermo", "HeaderDownloadSync": "Scarica & Sincronizza", "HeaderEasyPinCode": "Codice pin semplificato", "HeaderEditImages": "Modifica Immagini", @@ -312,9 +306,7 @@ "HeaderError": "Errore", "HeaderExternalIds": "ID esterni:", "HeaderFeatureAccess": "Accesso alle funzionalità", - "HeaderFeatures": "Caratteristiche", "HeaderFetchImages": "Identifica Immagini:", - "HeaderFilters": "Filtri", "HeaderForKids": "Per Bambini", "HeaderForgotPassword": "Password dimenticata", "HeaderFrequentlyPlayed": "Visti di frequente", @@ -423,7 +415,6 @@ "HeaderSubtitleProfiles": "Profili sottotitoli", "HeaderSubtitleProfilesHelp": "Profili sottotitoli descrivono i formati di sottotitoli supportati dal dispositivo.", "HeaderSystemDlnaProfiles": "Profili di sistema", - "HeaderTags": "Tag", "HeaderTaskTriggers": "Operazioni Pianificate", "HeaderThisUserIsCurrentlyDisabled": "Questo utente è al momento disabilitato", "HeaderTracks": "Traccia", @@ -476,7 +467,6 @@ "LabelAlbumArtMaxWidthHelp": "Risoluzione massima copertina album inviata tramite upnp:albumArtURI.", "LabelAlbumArtPN": "Copertine Album PN:", "LabelAlbumArtists": "Artisti album:", - "LabelAll": "Tutti", "LabelAllowHWTranscoding": "Consenti transcodifica hardware", "LabelAllowedRemoteAddresses": "Filtro indirizzo IP Remoto:", "LabelAllowedRemoteAddressesMode": "Modalità filtro indirizzo IP remoto:", @@ -1149,7 +1139,6 @@ "TabAdvanced": "Avanzato", "TabAlbumArtists": "Artisti degli Album", "TabAlbums": "Album", - "TabArtists": "Artisti", "TabCatalog": "Catalogo", "TabChannels": "Canali", "TabCodecs": "Codec", @@ -1158,14 +1147,12 @@ "TabDashboard": "Pannello Controllo", "TabDevices": "Dispositivi", "TabDirectPlay": "Riproduzione Diretta", - "TabDisplay": "Schermo", "TabEpisodes": "Episodi", "TabFavorites": "Preferiti", "TabGenres": "Generi", "TabGuide": "Guida", "TabLatest": "Novità", "TabLiveTV": "Tv in Diretta", - "TabMetadata": "Metadati", "TabMovies": "Film", "TabMusic": "Musica", "TabMusicVideos": "Video Musicali", @@ -1175,7 +1162,6 @@ "TabNotifications": "Notifiche", "TabOther": "Altro", "TabParentalControl": "Controllo Genitore", - "TabPlayback": "Riproduzione", "TabPlaylists": "Playlist", "TabProfile": "Profilo", "TabProfiles": "Profili", @@ -1187,9 +1173,7 @@ "TabSettings": "Impostazioni", "TabShows": "Spettacoli", "TabSongs": "Brani", - "TabSuggestions": "Suggerimenti", "TabTrailers": "Trailer", - "TabTranscoding": "Trascodifica", "TabUpcoming": "In Arrivo", "TabUsers": "Utenti", "Tags": "Tag", @@ -1467,7 +1451,6 @@ "AlbumArtist": "Artisti dell'Album", "UnsupportedPlayback": "Jellyfin non è in grado di decriptare i contenuti protetti da DRM ma tutti i contenuti verranno tentati a prescindere, compresi quelli protetti. Alcuni file potrebbero apparire completamente neri a causa della crittografia o di altre funzionalità non supportate, come i titoli interattivi.", "ButtonTogglePlaylist": "Playlist", - "ButtonToggleContextMenu": "Altro", "HeaderFavoritePlaylists": "Playlist Favorite", "Filter": "Filtro", "New": "Nuovo", diff --git a/src/strings/ja.json b/src/strings/ja.json index a6738d9517..f57a1ea672 100644 --- a/src/strings/ja.json +++ b/src/strings/ja.json @@ -53,7 +53,6 @@ "Browse": "ブラウズ", "MessageBrowsePluginCatalog": "利用可能なプラグインを表示するには、プラグインカタログを参照してください。", "BurnSubtitlesHelp": "ビデオのトランスコード時にサーバーが字幕を焼付けるかどうかを決定します。 この字幕焼付けを避けると、サーバーのパフォーマンスが非常に向上します。 画像ベースの形式 (VOBSUB, PGS, SUB, IDX など) と特定の ASS または SSA 字幕でだけ焼付けを行うには、自動を選んでください。", - "ButtonAdd": "追加", "ButtonAddMediaLibrary": "メディアライブラリを追加", "ButtonAddScheduledTaskTrigger": "トリガーを追加", "ButtonAddServer": "サーバーを追加", @@ -79,7 +78,6 @@ "ButtonFullscreen": "フルスクリーン", "ButtonGotIt": "了解", "ButtonGuide": "ガイド", - "ButtonHelp": "ヘルプ", "ButtonHome": "ホーム", "ButtonInfo": "情報", "ButtonLibraryAccess": "ライブラリへアクセス", @@ -99,15 +97,12 @@ "ButtonRefreshGuideData": "ガイドデータの更新", "ButtonRemove": "削除", "ButtonRename": "名前の変更", - "ButtonRepeat": "リピート", "ButtonResetEasyPassword": "easy pin code をリセット", "ButtonResetPassword": "パスワードをリセット", "ButtonRestart": "再起動", "ButtonResume": "レジューム", "ButtonRevoke": "取り消す", - "ButtonSave": "保存", "ButtonScanAllLibraries": "すべてのライブラリをスキャン", - "ButtonSearch": "検索", "ButtonSelectDirectory": "ディレクトリの選択", "ButtonSelectServer": "サーバーの選択", "ButtonSelectView": "ビューを選択", @@ -332,7 +327,6 @@ "HeaderDevices": "デバイス", "HeaderDirectPlayProfile": "ダイレクトプレイ プロファイル", "HeaderDirectPlayProfileHelp": "ダイレクトプレイプロファイルを追加して、デバイスがどのフォーマットをネイティブに処理できるかを示します。", - "HeaderDisplay": "ディスプレイ", "HeaderDownloadSync": "ダウンロード&同期", "HeaderEasyPinCode": "簡単なPINコード", "HeaderEditImages": "イメージの編集", @@ -349,10 +343,8 @@ "HeaderFavoriteSongs": "お気に入りの曲", "HeaderFavoriteVideos": "お気に入りのビデオ", "HeaderFeatureAccess": "機能へのアクセス", - "HeaderFeatures": "機能", "HeaderFetchImages": "画像を取得する:", "HeaderFetcherSettings": "フェッチャー設定", - "HeaderFilters": "フィルタ", "HeaderForKids": "子供向け", "HeaderForgotPassword": "パスワードを忘れました", "HeaderFrequentlyPlayed": "よく再生する", @@ -464,7 +456,6 @@ "HeaderSubtitleProfiles": "字幕のプロファイル", "HeaderSubtitleProfilesHelp": "字幕プロファイルは、デバイスでサポートされている字幕フォーマットを表します。", "HeaderSystemDlnaProfiles": "システムプロファイル", - "HeaderTags": "タグ", "HeaderTaskTriggers": "タスクトリガー", "HeaderThisUserIsCurrentlyDisabled": "このユーザーは現在無効になっています", "HeaderTracks": "トラック", @@ -603,7 +594,6 @@ "Sunday": "日曜日", "CopyStreamURLSuccess": "URLのコピーが成功しました。", "TabDirectPlay": "直接再生", - "TabDisplay": "表示", "TabEpisodes": "エピソード", "TabFavorites": "お気に入り", "TabGenres": "ジャンル", @@ -640,7 +630,6 @@ "SeriesYearToPresent": "{0} - 現在", "SubtitleOffset": "字幕オフセット", "TabPassword": "パスワード", - "TabPlayback": "プレイバック", "ThemeSongs": "テーマ曲", "ThemeVideos": "テーマビデオ", "ValueMusicVideoCount": "{0} ミュージックビデオ", @@ -770,7 +759,6 @@ "TabLatest": "最新", "TabLiveTV": "ライブTV", "TabLogs": "ログ", - "TabMetadata": "メタデータ", "TabMovies": "ムービー", "TabMusic": "ミュージック", "TabMusicVideos": "ミュージックビデオ", @@ -838,7 +826,6 @@ "LabelMusicStreamingTranscodingBitrate": "ミュージックトランスコーディングビットレート:", "LabelName": "名前:", "LabelProtocolInfo": "プロトコル情報:", - "LabelAll": "すべて", "LabelAlbumArtPN": "アルバムアートPN:", "LabelAlbumArtists": "アルバムアーティスト:", "LabelAllowHWTranscoding": "ハードウェアトランスコーディングを許可", @@ -1065,9 +1052,7 @@ "TabShows": "表示", "TabSongs": "曲", "TabStreaming": "ストリーミング", - "TabSuggestions": "おすすめ", "TabTrailers": "トレーラー", - "TabTranscoding": "トランスコーディング", "MessageContactAdminToResetPassword": "パスワードをリセットするためにシステムの管理者に連絡してください。", "TabUsers": "ユーザー", "TagsValue": "タグ: {0}", @@ -1085,7 +1070,6 @@ "SearchForSubtitles": "字幕を検索", "ServerNameIsShuttingDown": "Jellyfinサーバー - {0} は停止中です。", "SettingsSaved": "設定を保存しました。", - "TabArtists": "アーティスト", "ValueSeconds": "{0} 秒", "ValueTimeLimitSingleHour": "タイムリミット: 1 時間", "Wednesday": "水曜日", @@ -1126,7 +1110,6 @@ "ButtonSyncPlay": "SyncPlay", "DeinterlaceMethodHelp": "インターレースコンテンツをトランスコードする際に使用するデインターレース方式を選びます。", "ButtonTogglePlaylist": "プレイリスト", - "ButtonToggleContextMenu": "さらに表示", "BoxSet": "ボックスセット", "AllowFfmpegThrottlingHelp": "トランスコードや remux が現在の再生位置から十分に先に進んだ場合、処理を一時停止してリソースの消費を抑えます。これは、あまり早送り・早戻しをしないで視聴する場合に便利です。再生に問題が発生した場合は、この機能をオフにしてください。", "LabelDisplaySpecialsWithinSeasons": "放送されたシーズン内のスペシャルを表示", diff --git a/src/strings/kk.json b/src/strings/kk.json index 909af11da3..2f0d0c5927 100644 --- a/src/strings/kk.json +++ b/src/strings/kk.json @@ -53,7 +53,6 @@ "Browse": "Sharlaý", "MessageBrowsePluginCatalog": "Qoljetimdi plagındermen tanysý úshin plagın tizimdemesin sholyńyz.", "BurnSubtitlesHelp": "Beıneni qaıta kodtaǵan kezde server sýbtıtrlerdi jazyýyn anyqtaıdy. Onan qashqaqtaý serverdiń ónimdiligin biraz jaqsartady. Sýretke negizdelgen pishimderdi (VOBSUB, PGS, SUB, IDX, j.t.b.) jáne keıbir ASS nemese SSA sýbtıtrlerin jazý úshin Avtomattyny tańdańyz.", - "ButtonAdd": "Ústeý", "ButtonAddMediaLibrary": "Tasyǵyshhana ústeý", "ButtonAddScheduledTaskTrigger": "Trıger ústeý", "ButtonAddServer": "Server ústeý", @@ -79,7 +78,6 @@ "ButtonFullscreen": "Tolyq ekran", "ButtonGotIt": "Túsinikti", "ButtonGuide": "Telegıd", - "ButtonHelp": "Anyqtama", "ButtonHome": "Basqyǵa", "ButtonInfo": "Aqparatqa", "ButtonLibraryAccess": "Tasyǵyshhanǵa qatynaý", @@ -101,15 +99,12 @@ "ButtonRefreshGuideData": "Telegıd derekterin jańǵyrtý", "ButtonRemove": "Alastaý", "ButtonRename": "Qaıta ataý", - "ButtonRepeat": "Qaıtalaý", "ButtonResetEasyPassword": "Ońaıtylǵan PIN-kodty ysyrý", "ButtonResetPassword": "Paróldi ysyrý", "ButtonRestart": "Qaıta iske qosý", "ButtonResume": "Jalǵastyrý", "ButtonRevoke": "Bas tartý", - "ButtonSave": "Saqtaý", "ButtonScanAllLibraries": "Barlyq tasyǵyshhanalardy skanerleý", - "ButtonSearch": "Izdeý", "ButtonSelectDirectory": "Qatalogty tańdaý", "ButtonSelectServer": "Serverdi tańdaý", "ButtonSelectView": "Kórinisti tańdaý", @@ -326,7 +321,6 @@ "HeaderDevices": "Qurylǵylar", "HeaderDirectPlayProfile": "Tikeleı oınatý profaıly", "HeaderDirectPlayProfileHelp": "Qurylǵynyń qandaı pishimderdi ádepki óńdetetin múmkindigin kórsetý ushin tikeleı oınatý profaıldar ústeý.", - "HeaderDisplay": "Beıneleý", "HeaderDownloadSync": "Júkteý men úndestirý", "HeaderEasyPinCode": "Ońaıtylǵan PIN-kod", "HeaderEditImages": "Sýretterdi óńdeý", @@ -336,10 +330,8 @@ "HeaderError": "Qate", "HeaderExternalIds": "Syrtqy sáıkestendirgishter:", "HeaderFeatureAccess": "Erekshelikterge qatynaý", - "HeaderFeatures": "Erekshelikter", "HeaderFetchImages": "Sýretterdi irikteý:", "HeaderFetcherSettings": "Irikteýshi parametrleri", - "HeaderFilters": "Súzgiler", "HeaderForKids": "Balalyq", "HeaderForgotPassword": "Paróldi umytyńyz ba", "HeaderFrequentlyPlayed": "Jıi oınatylǵandar", @@ -452,7 +444,6 @@ "HeaderSubtitleProfiles": "Sýbtıtrler profaıldary", "HeaderSubtitleProfilesHelp": "Sýbtıtrler profaıly osy qurylǵyda qoldaýy bar sýbtıtrler pishimderin sıpattaıdy.", "HeaderSystemDlnaProfiles": "Júıelik profaıldar", - "HeaderTags": "Tegter", "HeaderTaskTriggers": "Tapsyrma trıggerleri", "HeaderThisUserIsCurrentlyDisabled": "Osy paıdalanýshy aǵymda ajyratylǵan", "HeaderTracks": "Jolshyqtar", @@ -508,7 +499,6 @@ "LabelAlbumArtMaxWidthHelp": "upnp:albumArtURI arqyly kórsetetin álbom sýretiniń eń joǵary ajyratylymdyǵy.", "LabelAlbumArtPN": "Álbom sýreti PN:", "LabelAlbumArtists": "Álbom oryndaýshylary:", - "LabelAll": "Barlyq", "LabelAllowHWTranscoding": "Apparattyq qaıta kodtaýǵa ruqsat etý", "LabelAllowedRemoteAddresses": "Qashyqtaǵy IP-mekenjaı súzgisi:", "LabelAllowedRemoteAddressesMode": "Qashyqtaǵy IP-mekenjaı súzgisiniń rejimi:", @@ -1226,7 +1216,6 @@ "TabAdvanced": "Keńeıtilgen", "TabAlbumArtists": "Álbom oryndaýshylary", "TabAlbums": "Álbomdar", - "TabArtists": "Oryndaýshylar", "TabCatalog": "Tizimdeme", "TabChannels": "Arnalar", "TabCodecs": "Kodekter", @@ -1235,7 +1224,6 @@ "TabDashboard": "Taqta", "TabDevices": "Qurylǵylar", "TabDirectPlay": "Tikeleı oınatý", - "TabDisplay": "Beıneleý", "TabEpisodes": "TD-bólimder", "TabFavorites": "Tańdaýlylar", "TabGenres": "Janrlar", @@ -1244,7 +1232,6 @@ "TabLatest": "Eń keıingi", "TabLiveTV": "Efırlik TD", "TabLogs": "Jurnaldar", - "TabMetadata": "Metaderekter", "TabMovies": "Fılmder", "TabMusic": "Mýzyka", "TabMusicVideos": "Mýzykalyq beıneler", @@ -1255,7 +1242,6 @@ "TabOther": "Basqalar", "TabParentalControl": "Mazmundy basqarý", "TabPassword": "Paról", - "TabPlayback": "Oınatý", "TabPlaylists": "Oınatý tizimderi", "TabPlugins": "Plagınder", "TabProfile": "Profaıl", @@ -1270,9 +1256,7 @@ "TabShows": "Kórsetimder", "TabSongs": "Áýender", "TabStreaming": "Tasymaldaný", - "TabSuggestions": "Usynystar", "TabTrailers": "Treılerler", - "TabTranscoding": "Qaıta kodtaý", "TabUpcoming": "Kútilgen", "TabUsers": "Paıdalanýshylar", "Tags": "Tegter", @@ -1458,7 +1442,6 @@ "Episode": "Bólim", "ClientSettings": "Týtynýshy parametrleri", "ButtonTogglePlaylist": "Oýnatý tizimi", - "ButtonToggleContextMenu": "Kúbirek", "BoxSet": "Jıyntyq", "Artist": "Ornatýshy", "AlbumArtist": "Álbom ornatýshysy", diff --git a/src/strings/ko.json b/src/strings/ko.json index e18dc5f537..6a6dadc120 100644 --- a/src/strings/ko.json +++ b/src/strings/ko.json @@ -14,7 +14,6 @@ "BirthDateValue": "출생: {0}", "BirthPlaceValue": "출생지: {0}", "MessageBrowsePluginCatalog": "사용 가능한 플러그인을 보려면 플러그인 카탈로그를 참고하십시오.", - "ButtonAdd": "추가", "ButtonAddScheduledTaskTrigger": "트리거 추가", "ButtonAddServer": "서버 추가", "ButtonAddUser": "사용자 추가", @@ -35,7 +34,6 @@ "ButtonForgotPassword": "비밀번호 분실", "ButtonGotIt": "알겠습니다", "ButtonGuide": "가이드", - "ButtonHelp": "도움말", "ButtonHome": "홈", "ButtonInfo": "정보", "ButtonManualLogin": "수동 로그인", @@ -54,13 +52,10 @@ "ButtonRefreshGuideData": "가이드 데이터 새로 고침", "ButtonRemove": "제거", "ButtonRename": "이름 변경", - "ButtonRepeat": "반복", "ButtonResetEasyPassword": "간편 PIN 코드 재설정", "ButtonResetPassword": "비밀번호 재설정", "ButtonRestart": "다시 시작", "ButtonResume": "이어서 재생", - "ButtonSave": "저장", - "ButtonSearch": "검색", "ButtonSelectDirectory": "디렉터리 선택", "ButtonSelectServer": "서버 선택", "ButtonSelectView": "보기 선택", @@ -155,9 +150,7 @@ "HeaderEasyPinCode": "간편 PIN 코드", "HeaderError": "오류", "HeaderFeatureAccess": "기능 접근", - "HeaderFeatures": "특징", "HeaderFetchImages": "이미지 가져오기:", - "HeaderFilters": "필터", "HeaderForgotPassword": "비밀번호 분실", "HeaderFrequentlyPlayed": "자주 재생함", "HeaderGenres": "장르", @@ -232,7 +225,6 @@ "HeaderSubtitleProfile": "자막 프로필", "HeaderSubtitleProfilesHelp": "자막 프로필은 장치에서 지원하는 자막 형식을 나타냅니다.", "HeaderSystemDlnaProfiles": "시스템 프로필", - "HeaderTags": "태그", "HeaderTaskTriggers": "작업 트리거", "HeaderThisUserIsCurrentlyDisabled": "이 사용자는 현재 비활성화되었습니다", "HeaderTracks": "트랙", @@ -270,7 +262,6 @@ "LabelAlbumArtMaxWidthHelp": "upnp:albumArtURI를 통해 노출된 앨범 아트의 최대 해상도.", "LabelAlbumArtPN": "앨범 아트 PN:", "LabelAlbumArtists": "앨범 아티스트:", - "LabelAll": "모두", "LabelAppName": "앱 이름", "LabelArtists": "아티스트:", "LabelArtistsHelp": "; 를 사용하여 여러 개 분리", @@ -686,7 +677,6 @@ "TabAdvanced": "고급", "TabAlbumArtists": "앨범 아티스트", "TabAlbums": "앨범", - "TabArtists": "아티스트", "TabCatalog": "카탈로그", "TabChannels": "채널", "TabCodecs": "코덱", @@ -695,7 +685,6 @@ "TabDashboard": "대시보드", "TabDevices": "장치", "TabDirectPlay": "다이렉트 재생", - "TabDisplay": "화면", "TabEpisodes": "에피소드", "TabFavorites": "즐겨찾기", "TabGenres": "장르", @@ -704,7 +693,6 @@ "TabLatest": "최근", "TabLiveTV": "실시간 TV", "TabLogs": "로그", - "TabMetadata": "메타데이터", "TabMovies": "영화", "TabMusic": "음악", "TabMusicVideos": "뮤직비디오", @@ -714,7 +702,6 @@ "TabOther": "기타", "TabParentalControl": "자녀 보호", "TabPassword": "비밀번호", - "TabPlayback": "재생", "TabPlaylists": "재생목록", "TabPlugins": "플러그인", "TabProfile": "프로필", @@ -728,9 +715,7 @@ "TabShows": "쇼", "TabSongs": "노래", "TabStreaming": "스트리밍", - "TabSuggestions": "추천", "TabTrailers": "예고편", - "TabTranscoding": "트랜스코딩", "TabUpcoming": "방송 예정", "TabUsers": "사용자", "Tags": "태그", @@ -1183,7 +1168,6 @@ "HeaderKodiMetadataHelp": "NFO 메타데이터를 활성화/비활성화하려면, Jellyfin 라이브러리 설정에서 라이브러리를 편집하고 메타데이터 보호기 섹션을 찾으십시오.", "HeaderKeepRecording": "녹화 유지", "HeaderForKids": "아이들용", - "HeaderDisplay": "디스플레이", "HeaderDetectMyDevices": "내 장치 탐색", "HeaderDeleteItems": "항목 제거", "HeaderConfirmRevokeApiKey": "API 키 해지", @@ -1398,7 +1382,6 @@ "MovieLibraryHelp": "{0}영화 이름 지정 규칙{1}을 확인하십시오.", "HeaderFavoritePlaylists": "즐겨찾는 플레이리스트", "ButtonTogglePlaylist": "플레이리스트", - "ButtonToggleContextMenu": "더보기", "Rate": "평", "PerfectMatch": "정확히 일치", "ButtonSyncPlay": "SyncPlay", diff --git a/src/strings/lt-lt.json b/src/strings/lt-lt.json index 4a259afc8e..e02a183c97 100644 --- a/src/strings/lt-lt.json +++ b/src/strings/lt-lt.json @@ -12,7 +12,6 @@ "AttributeNew": "Naujas", "Backdrops": "Fonai", "BirthLocation": "Gimimo vieta", - "ButtonAdd": "Pridėti", "ButtonAddScheduledTaskTrigger": "Pridėti jungiklį", "ButtonAddUser": "Pridėt vartotoją", "ButtonArrowDown": "Žemyn", @@ -26,7 +25,6 @@ "ButtonEdit": "Redaguoti", "ButtonFilter": "Filtras", "ButtonGotIt": "Supratau", - "ButtonHelp": "Pagalba", "ButtonHome": "Pradinis", "ButtonManualLogin": "Rankinis prisijungimas", "ButtonNew": "Naujas", @@ -41,8 +39,6 @@ "ButtonRemove": "Pašalinti", "ButtonResetPassword": "Atstatyti slaptažodį", "ButtonRestart": "Iš naujo", - "ButtonSave": "Saugoti", - "ButtonSearch": "Paieška", "ButtonSelectDirectory": "Rinktis direktoriją", "ButtonSettings": "Nustatymai", "ButtonSignIn": "Prisijungti", @@ -114,7 +110,6 @@ "HeaderEnabledFieldsHelp": "Nuimkite varnelę nuo lauko kad jį užrakinti ir neleisti keisti jo duomenų.", "HeaderFeatureAccess": "Prieiga prie funkcijų", "HeaderFetchImages": "Gauti vaizdus:", - "HeaderFilters": "Filtrai", "HeaderFrequentlyPlayed": "Dažnai leista", "HeaderIdentificationCriteriaHelp": "Įveskite bent vieną identifikavimo kriterijų.", "HeaderIdentifyItemHelp": "Įveskite vieną ar daugiau paieškos kriterijų. Pašalinkite kriterijų jei norite gauti daugiau paieškos rezultatų.", @@ -466,7 +461,6 @@ "TabAdvanced": "Sudėtingiau", "TabAlbumArtists": "Albumo atlikėjai", "TabAlbums": "Albumai", - "TabArtists": "Atlikėjai", "TabCatalog": "Katalogas", "TabChannels": "Kanalai", "TabCollections": "Kolekcijos", @@ -475,7 +469,6 @@ "TabGenres": "Žanrai", "TabGuide": "Gidas", "TabLatest": "Vėliausi", - "TabMetadata": "Metaduomenys", "TabMovies": "Filmai", "TabMusic": "Muzika", "TabMusicVideos": "Muzikos klipai", @@ -492,9 +485,7 @@ "TabSettings": "Nustatymai", "TabShows": "Laidos", "TabSongs": "Dainos", - "TabSuggestions": "Pasiūlymai", "TabTrailers": "Anonsai", - "TabTranscoding": "Transkodavimas", "TabUpcoming": "Būsimi", "Tags": "Žymės", "TellUsAboutYourself": "Papasakokite apie save", @@ -563,7 +554,6 @@ "ButtonParentalControl": "Tėvų kontrolė", "ButtonProfile": "Profilis", "ButtonRename": "Pervadinti", - "ButtonRepeat": "Kartoti", "ButtonResume": "Tęsti", "ButtonRevoke": "Panaikinti", "ButtonScanAllLibraries": "Nuskaityti Visas Bibliotekas", @@ -732,7 +722,6 @@ "HeaderDateIssued": "Išdavimo data", "HeaderDefaultRecordingSettings": "Numatytieji įrašymo nustatymai", "HeaderDetectMyDevices": "Rasti mano prietaisus", - "HeaderDisplay": "Ekranas", "HeaderFavoriteBooks": "Mėgstamiausios knygos", "HeaderFavoriteMovies": "Mėgstamiausi filmai", "HeaderFavoriteShows": "Mėgstamiausi serialai", @@ -770,7 +759,6 @@ "LabelAllowedRemoteAddressesMode": "Nuotolinio IP adresų filtro režimas:", "HeaderLoginFailure": "Prisijungimo klaida", "Hide": "Paslėpti", - "LabelAll": "Visi", "LabelAudio": "Garsas", "LabelCancelled": "Atšaukta", "LabelCertificatePassword": "Sertifikato slaptažodis:", @@ -782,7 +770,6 @@ "EnableBackdropsHelp": "Rodyti fono dekoracijas naršant bibliotekoje.", "FolderTypeUnset": "Įvairus turinys", "HeaderAddUpdateImage": "Pridėti/Įkelti atvaizdą", - "HeaderTags": "Žymės", "LabelAlbumArtPN": "Albumo iliustracijos PN:", "HeaderSettings": "Nustatymai", "LabelMatchType": "Atitikties tipas:", @@ -821,7 +808,6 @@ "HeaderAccessScheduleHelp": "Sukurkite prieigos tvarkaraštį, kad apribotumėte prieigą tam tikromis valandomis.", "HeaderContainerProfile": "Konteinerio profilis", "ErrorStartHourGreaterThanEnd": "Pabaigos laikas turi būti didesnis nei pradžios laikas.", - "HeaderFeatures": "Medžiagos", "ErrorSavingTvProvider": "Išsaugant TV teikėją įvyko klaida. Įsitikinkite, kad jis prieinamas, ir bandykite dar kartą.", "HeaderKodiMetadataHelp": "Norėdami įjungti arba išjungti NFO metaduomenis, redaguokite biblioteką Jellyfin bibliotekos nustatymuose, metaduomenų išsaugojimo skyriuje.", "EveryNDays": "Kas {0} dienas", @@ -995,7 +981,6 @@ "Episode": "Episodas", "ClientSettings": "Kliento Nustatymai", "ButtonTogglePlaylist": "Grojaraštis", - "ButtonToggleContextMenu": "Daugiau", "ButtonSplit": "Skirstyti", "AskAdminToCreateLibrary": "Prašyti administratoriaus, kad sukurtų mediateka.", "Album": "Albumas", diff --git a/src/strings/lv.json b/src/strings/lv.json index 9346b653f4..094b3a4c74 100644 --- a/src/strings/lv.json +++ b/src/strings/lv.json @@ -224,7 +224,6 @@ "LabelArtists": "Izpildītājs:", "LabelAppNameExample": "Piemēram: Sickbeard, Sonarr", "LabelAppName": "Lietotnes nosaukums", - "LabelAll": "Viss", "LabelAlbumArtists": "Albuma izpildītāji:", "LabelAlbum": "Albums:", "LabelAirTime": "Tiešraides laiks:", @@ -325,7 +324,6 @@ "HeaderFrequentlyPlayed": "Bieži Atskaņots", "HeaderForgotPassword": "Aizmirst PAroli", "HeaderForKids": "Priekš Bērniem", - "HeaderFilters": "Filtri", "HeaderFavoriteVideos": "Video Favorīti", "MediaInfoPath": "Ceļš", "MediaInfoLevel": "Līmenis", @@ -362,7 +360,6 @@ "HeaderEpisodes": "Epizodes", "HeaderEditImages": "Rediģēt Attēlus", "HeaderDownloadSync": "Lejupielādēt & Sinhronizēt", - "HeaderDisplay": "Displejs", "HeaderDevices": "Ierīces", "HeaderDeviceAccess": "Ierīču Piekļuve", "HeaderDeveloperInfo": "Izstrādātāju Info", @@ -498,15 +495,12 @@ "ButtonSelectView": "Izvēlies Skatu", "ButtonSelectServer": "Izvēlies Serveri", "ButtonSelectDirectory": "Izvēlies Mapi", - "ButtonSearch": "Meklēt", "ButtonScanAllLibraries": "Skanēt Visas Bibliotēkas", - "ButtonSave": "Saglabāt", "ButtonRevoke": "Atsaukt", "ButtonResume": "Turpināt", "ButtonRestart": "Restartēt", "ButtonResetPassword": "Nomainīt Paroli", "ButtonResetEasyPassword": "Nomainīt vieglo pin kodu", - "ButtonRepeat": "Atkārtot", "ButtonRename": "Pārsaukt", "ButtonRemove": "Noņemt", "ButtonRefreshGuideData": "Atjaunot Gida Datus", @@ -526,7 +520,6 @@ "ButtonLibraryAccess": "Bibliotēku piekļuve", "ButtonInfo": "Info", "ButtonHome": "Mājas", - "ButtonHelp": "Palīdzība", "ButtonGuide": "Gids", "ButtonGotIt": "Sapratu", "ButtonFullscreen": "Pilnekrāna", @@ -546,7 +539,6 @@ "ButtonAddServer": "Pievienot Serveri", "ButtonAddMediaLibrary": "Pievienot Multimēdiju Bibliotēku", "ButtonAddImage": "Pievienot attēlu", - "ButtonAdd": "Pievienot", "MessageBrowsePluginCatalog": "Pārlūko mūsu paplašinājumu katalogu, lai redzētu pieejamos paplašinājumus.", "Browse": "Pārlūkot", "BoxRear": "Kaste (aizmugure)", @@ -573,7 +565,6 @@ "HeaderTranscodingProfile": "Transkodēšanas Profils", "HeaderTracks": "Celiņi", "HeaderThisUserIsCurrentlyDisabled": "Šis lietotājs pašlaik ir atspējots", - "HeaderTags": "Tagi", "HeaderSystemDlnaProfiles": "Sistēmas Profili", "HeaderSubtitleProfiles": "Subtitru Profili", "HeaderSubtitleProfile": "Subtitru Profils", @@ -697,9 +688,7 @@ "TagsValue": "Tagi: {0}", "Tags": "Tagi", "TabUsers": "Lietotāji", - "TabTranscoding": "Trans-kodēšana", "TabTrailers": "Treileri", - "TabSuggestions": "Ieteikumi", "TabStreaming": "Straumēšana", "TabSongs": "Dziesmas", "TabShows": "Raidījumi", @@ -713,7 +702,6 @@ "TabProfile": "Profils", "TabPlugins": "Paplašinājumi", "TabPlaylists": "Atskaņošanas Saraksti", - "TabPlayback": "Atskaņošana", "TabPassword": "Parole", "TabParentalControl": "Vecāku Pārvaldība", "TabOther": "Cits", @@ -725,7 +713,6 @@ "TabMusicVideos": "Mūzikas Video", "TabMusic": "Mūzika", "TabMovies": "Filmas", - "TabMetadata": "Metadati", "TabLogs": "Logs", "TabLiveTV": "Tiešraides TV", "TabLatest": "Jaunākais", @@ -734,7 +721,6 @@ "TabGenres": "Žanri", "TabFavorites": "Favorīti", "TabEpisodes": "Epizodes", - "TabDisplay": "Displejs", "TabDirectPlay": "Tiešā Atskaņošana", "TabDevices": "Ierīces", "TabContainers": "Konteineri", @@ -742,7 +728,6 @@ "TabCodecs": "Kodeksi", "TabChannels": "Kanāli", "TabCatalog": "Katalogs", - "TabArtists": "Izpildītāji", "TabAlbums": "Albumi", "ValueSpecialEpisodeName": "Speciālais - {0}", "Sync": "Sinhronizācija", @@ -918,7 +903,6 @@ "HeaderKodiMetadataHelp": "Lai iespējotu vai atspējotu NFO metadatus, rediģē bibliotēku Jellyfin bibliotēku iestatījumu metadata glabātāju sadaļā.", "HeaderIdentifyItemHelp": "Ievadi vienu vai vairākus meklēšanas kritērijus. Noņem kritērijus lai palielinātu meklēšanas rezultātus.", "HeaderFetchImages": "Ielādēt Attēlus:", - "HeaderFeatures": "Funkcijas", "HeaderFeatureAccess": "Funkciju Piekļuve", "HeaderEnabledFieldsHelp": "Atķeksē lauku lai to slēgtu un aizliegt tā satura mainīšanu.", "HeaderEnabledFields": "Iespējotie Lauki", @@ -1107,7 +1091,6 @@ "ColorTransfer": "Krāsu pārsūtīšana", "ClientSettings": "Klientu Iestatījumi", "ButtonTogglePlaylist": "Atskaņošanas Saraksts", - "ButtonToggleContextMenu": "Vairāk", "BurnSubtitlesHelp": "Nosaka, vai serverim ir jāiededzina subtitri video trans-kodēšanas laikā. To nedarot tiks stipri palielināta veiktspēja. Izvēlies Auto lai iededzinātu uz attēliem bāzētus formātus (VOBSUB, PGS, SUB, IDX, …) un noteiktus ASS vai SSA subtitrus.", "Artist": "Izpildītājs", "AllowOnTheFlySubtitleExtractionHelp": "Iegultie subtitri var tikt izvilkto no video un nogādāti klientiem kā parasts teksts, lai nevajadzētu veikt lieku video trans kodēšanu. Uz dažām sistēmām tas var aizņemt ilgu laiku un likt video atskaņošanai uzkārties izvilkšanas procesa laikā. Atspējo šo lai iegultos subtitrus iededzinātu video trans kodēšanas veidā, kad tos noklusēti neatbalsta klienta ierīce.", diff --git a/src/strings/mr.json b/src/strings/mr.json index 9ad45d4765..80708c700d 100644 --- a/src/strings/mr.json +++ b/src/strings/mr.json @@ -7,7 +7,6 @@ "ButtonNetwork": "नेटवर्क", "ButtonMore": "अजून", "ButtonInfo": "माहिती", - "ButtonHelp": "मदत", "ButtonGuide": "गाईड", "ButtonGotIt": "समजले", "ButtonForgotPassword": "पासवर्ड विसरलो", @@ -27,7 +26,6 @@ "ButtonArrowDown": "खाली", "ButtonAddUser": "प्रयोक्ता जोडा", "ButtonAddServer": "सर्व्हर जोडा", - "ButtonAdd": "जोडा", "Books": "पुस्तकं", "Blacklist": "ब्लॅकलिस्ट", "BirthPlaceValue": "जन्म ठिकाण: {0}", @@ -89,7 +87,6 @@ "ButtonSelectView": "दृष्य निवडा", "ButtonSelectServer": "सर्व्हर निवडा", "ButtonSelectDirectory": "डिरेक्टरी निवडा", - "ButtonSearch": "शोधा", "ButtonScanAllLibraries": "सर्व संग्रहालय स्कॅन करा", "ButtonRename": "नाव बदला", "ButtonRemove": "काढून टाका", diff --git a/src/strings/ms.json b/src/strings/ms.json index a8a5bba2ee..e7b5be39ee 100644 --- a/src/strings/ms.json +++ b/src/strings/ms.json @@ -57,7 +57,6 @@ "Books": "Buku-buku", "Box": "Kotak", "Browse": "Semak imbas", - "ButtonAdd": "Tambah", "ButtonAddMediaLibrary": "Tambah Pustaka Media", "ButtonAddServer": "Tambah pelayan", "ButtonAddUser": "Tambah pengguna", @@ -73,7 +72,6 @@ "ButtonLibraryAccess": "Akses pustaka", "ButtonInfo": "Info", "ButtonHome": "Mula", - "ButtonHelp": "Pertolongan", "ButtonGuide": "Panduan", "ButtonGotIt": "Terima", "ButtonFullscreen": "Paparan skrin penuh", diff --git a/src/strings/nb.json b/src/strings/nb.json index ee7f9e9ea5..c427b92486 100644 --- a/src/strings/nb.json +++ b/src/strings/nb.json @@ -33,7 +33,6 @@ "BookLibraryHelp": "Lyd- og tekstbøker støttes. Se igjennom {0} navneguiden for bøker {1}.", "Books": "Bøker", "MessageBrowsePluginCatalog": "Bla i tilleggskatalogen vår for å se tilgjengelige applikasjonstillegg.", - "ButtonAdd": "Legg til", "ButtonAddMediaLibrary": "Legg til bibliotek", "ButtonAddScheduledTaskTrigger": "Legg til utløser", "ButtonAddServer": "Legg til server", @@ -57,7 +56,6 @@ "ButtonForgotPassword": "Glemt passord", "ButtonFullscreen": "Fullskjerm", "ButtonGotIt": "Skjønner", - "ButtonHelp": "Hjelp", "ButtonHome": "Hjem", "ButtonLibraryAccess": "Bibliotektilgang", "ButtonManualLogin": "Manuell Login", @@ -77,15 +75,12 @@ "ButtonRefreshGuideData": "Oppdater TV-guidedata", "ButtonRemove": "Fjern", "ButtonRename": "Endre navn", - "ButtonRepeat": "Gjenta", "ButtonResetEasyPassword": "Tilbakestill PIN-kode", "ButtonResetPassword": "Tilbakestill passord", "ButtonRestart": "Omstart", "ButtonResume": "Fortsett", "ButtonRevoke": "Kall tilbake", - "ButtonSave": "Lagre", "ButtonScanAllLibraries": "Skann alle biblioteker", - "ButtonSearch": "Søk", "ButtonSelectDirectory": "Velg katalog", "ButtonSelectServer": "Velg server", "ButtonSelectView": "Velg visning", @@ -241,7 +236,6 @@ "HeaderDevices": "Enheter", "HeaderDirectPlayProfile": "Direkteavspillingsprofil", "HeaderDirectPlayProfileHelp": "Legg direkteavspillingsprofiler for å indikere hvilke formater enheten støtter direkte avspilling av.", - "HeaderDisplay": "Vis", "HeaderDownloadSync": "Last ned og synkroniser", "HeaderEasyPinCode": "Enkel PIN-kode", "HeaderEditImages": "Endre bilder", @@ -250,9 +244,7 @@ "HeaderEpisodes": "Episoder", "HeaderError": "Feil", "HeaderFeatureAccess": "Funksjonstilgang", - "HeaderFeatures": "Funksjoner", "HeaderFetchImages": "Hent bilder:", - "HeaderFilters": "Filtre", "HeaderForKids": "For barn", "HeaderForgotPassword": "Glemt passord", "HeaderFrequentlyPlayed": "Ofte avspilt", @@ -350,7 +342,6 @@ "HeaderSubtitleProfiles": "Undertekstprofiler", "HeaderSubtitleProfilesHelp": "Undertekstprofiler beskriver tekstingsformater som støttes av enheten.", "HeaderSystemDlnaProfiles": "Systemprofiler", - "HeaderTags": "Tagger", "HeaderTaskTriggers": "Oppgaveutløsere", "HeaderThisUserIsCurrentlyDisabled": "Denne brukeren er deaktivert", "HeaderTracks": "Spor", @@ -396,7 +387,6 @@ "LabelAlbumArtMaxWidth": "Maks bredde for albumomslag:", "LabelAlbumArtMaxWidthHelp": "Maksoppløsning av albumomslag er eksponert via upnp:albumArtURI.", "LabelAlbumArtists": "Albumartister:", - "LabelAll": "Alle", "LabelAllowHWTranscoding": "Tillat maskinvare-omkoding", "LabelAppName": "Applikasjonsnavn", "LabelAppNameExample": "Eksempel: Sickbeard, Sonarr", @@ -987,7 +977,6 @@ "TabAdvanced": "Avansert", "TabAlbumArtists": "Albumartister", "TabAlbums": "Album", - "TabArtists": "Artister", "TabCatalog": "Katalog", "TabChannels": "Kanaler", "TabCodecs": "Kodeker", @@ -996,7 +985,6 @@ "TabDashboard": "Dashbord", "TabDevices": "Enheter", "TabDirectPlay": "Direkteavspilling", - "TabDisplay": "Skjerm", "TabEpisodes": "Episoder", "TabFavorites": "Favoritter", "TabGenres": "Sjangre", @@ -1012,7 +1000,6 @@ "TabOther": "Annet", "TabParentalControl": "Foreldrekontroll", "TabPassword": "Passord", - "TabPlayback": "Avspilling", "TabPlaylists": "Spillelister", "TabPlugins": "Programtillegg", "TabProfile": "Profil", @@ -1025,7 +1012,6 @@ "TabSettings": "Innstillinger", "TabShows": "Programmer", "TabSongs": "Sanger", - "TabSuggestions": "Forslag", "TabTrailers": "Trailere", "TabUpcoming": "Kommende", "TabUsers": "Brukere", @@ -1170,7 +1156,6 @@ "HeaderFetcherSettings": "Henteinnstillinger", "TabServer": "Server", "TabStreaming": "Strømming", - "TabTranscoding": "Omkoding", "TagsValue": "Tagger: {0}", "ThemeSongs": "Temamusikk", "ThemeVideos": "Temavideoer", @@ -1399,7 +1384,6 @@ "TV": "TV", "TabInfo": "Informasjon", "TabLiveTV": "Direkte-TV", - "TabMetadata": "Metadata", "TabNetworking": "Nettverk", "Trailers": "Trailere", "Transcoding": "Omkoding", @@ -1447,7 +1431,6 @@ "HeaderFavoritePlaylists": "Favorittspillelister", "DeinterlaceMethodHelp": "Velg deinterlacing metoden som skal bli brukt når man transkoder interlaced innhold.", "ButtonTogglePlaylist": "Spilleliste", - "ButtonToggleContextMenu": "Mer", "EnableBlurHashHelp": "Bilder som fortsatt lastes inn vil vises med en tåkete plassholder", "EnableBlurHash": "Aktiver tåkete plassholdere for bilder", "UnsupportedPlayback": "Jellyfin kan ikke dekryptere innhold beskyttet med DRM, men alt innhold vil bli forsøkt uansett, inkludert beskyttede titler. Noen filer kan fremstå helt svarte grunnet kryptering eller andre ikke støttede funksjoner, som interaktive titler.", diff --git a/src/strings/nl.json b/src/strings/nl.json index 36b947855d..dee7db4292 100644 --- a/src/strings/nl.json +++ b/src/strings/nl.json @@ -48,7 +48,6 @@ "Browse": "Bladeren", "MessageBrowsePluginCatalog": "Bekijk de Plugin catalogus voor beschikbare Plug-ins.", "BurnSubtitlesHelp": "Bepaalt of de server ondertitels moet branden bij het transcoderen van video's. Als u dit vermijd, worden de prestaties aanzienlijk verbeterd. Selecteer Auto om op afbeeldingen gebaseerde formaten (VOBSUB, PGS, SUB/IDX etc.) en bepaalde ASS/SSA ondertitels te branden.", - "ButtonAdd": "Toevoegen", "ButtonAddMediaLibrary": "Voeg Media Bibliotheek toe", "ButtonAddScheduledTaskTrigger": "Trigger Toevoegen", "ButtonAddServer": "Voeg server toe", @@ -73,7 +72,6 @@ "ButtonFullscreen": "Volledig scherm", "ButtonGotIt": "Begrepen", "ButtonGuide": "Gids", - "ButtonHelp": "Hulp", "ButtonHome": "Start", "ButtonLibraryAccess": "Bibliotheek toegang", "ButtonManualLogin": "Handmatige Aanmelding", @@ -93,15 +91,12 @@ "ButtonRefreshGuideData": "Gidsgegevens Vernieuwen", "ButtonRemove": "Verwijderen", "ButtonRename": "Naam wijzigen", - "ButtonRepeat": "Herhaling", "ButtonResetEasyPassword": "Reset eenvoudige pincode", "ButtonResetPassword": "Wachtwoord resetten", "ButtonRestart": "Herstart", "ButtonResume": "Hervatten", "ButtonRevoke": "Herroepen", - "ButtonSave": "Opslaan", "ButtonScanAllLibraries": "Scan alle bibliotheken", - "ButtonSearch": "Zoeken", "ButtonSelectDirectory": "Selecteer map", "ButtonSelectServer": "Server Selecteren", "ButtonSelectView": "Selecteer weergave", @@ -306,7 +301,6 @@ "HeaderDevices": "Apparaten", "HeaderDirectPlayProfile": "Direct Afspelen Profiel", "HeaderDirectPlayProfileHelp": "Voeg direct afspelen profielen toe om aan te geven welke formaten het apparaat standaard aankan.", - "HeaderDisplay": "Weergave", "HeaderDownloadSync": "Download & Synchronisatie", "HeaderEasyPinCode": "Eenvoudige Pincode", "HeaderEditImages": "Afbeeldingen bewerken", @@ -316,7 +310,6 @@ "HeaderError": "Fout", "HeaderExternalIds": "Externe ID's:", "HeaderFeatureAccess": "Functie toegang", - "HeaderFeatures": "Toevoegingen", "HeaderFetchImages": "Afbeeldingen ophalen:", "HeaderFetcherSettings": "Fetcher-instellingen", "HeaderForKids": "Voor Kinderen", @@ -423,7 +416,6 @@ "HeaderSubtitleProfiles": "Ondertitelingsprofielen", "HeaderSubtitleProfilesHelp": "Ondertitelingsprofielen beschrijven de ondertitelings formaten ondersteund door het apparaat.", "HeaderSystemDlnaProfiles": "Systeem Profielen", - "HeaderTags": "Labels", "HeaderTaskTriggers": "Taak Triggers", "HeaderThisUserIsCurrentlyDisabled": "Deze gebruiker is momenteel uitgesloten", "HeaderTranscodingProfile": "Direct Afspelen Profiel", @@ -473,7 +465,6 @@ "LabelAlbumArtMaxWidthHelp": "Max. resolutie van albumhoezen weergegeven via upnp:albumArtURI.", "LabelAlbumArtPN": "Albumhoes PN:", "LabelAlbumArtists": "Album artiesten:", - "LabelAll": "Alles", "LabelAllowHWTranscoding": "Hardware transcoding toestaan", "LabelAllowedRemoteAddresses": "Externe IP-adressen filter:", "LabelAllowedRemoteAddressesMode": "Externe IP-adressen filter modus:", @@ -1134,19 +1125,16 @@ "TabAccess": "Toegang", "TabAdvanced": "Geavanceerd", "TabAlbumArtists": "Albumartiesten", - "TabArtists": "Artiesten", "TabCatalog": "Catalogus", "TabChannels": "Kanalen", "TabCollections": "Collecties", "TabDevices": "Apparaten", "TabDirectPlay": "Direct Afspelen", - "TabDisplay": "Weergave", "TabEpisodes": "Afleveringen", "TabFavorites": "Favorieten", "TabGuide": "Gids", "TabLatest": "Nieuw", "TabLogs": "Logboeken", - "TabMetadata": "Metagegevens", "TabMovies": "Films", "TabMusic": "Muziek", "TabMusicVideos": "Muziek Videos", @@ -1157,7 +1145,6 @@ "TabOther": "Overig", "TabParentalControl": "Ouderlijk toezicht", "TabPassword": "Wachtwoord", - "TabPlayback": "Afspelen", "TabPlaylists": "Afspeellijst", "TabProfile": "Profiel", "TabProfiles": "Profielen", @@ -1169,8 +1156,6 @@ "TabSettings": "Instellingen", "TabShows": "Series", "TabSongs": "Titels", - "TabSuggestions": "Suggesties", - "TabTranscoding": "Transcoderen", "TabUpcoming": "Binnenkort op TV", "TabUsers": "Gebruikers", "Tags": "Labels", @@ -1251,7 +1236,6 @@ "HeaderCastCrew": "Acteurs & medewerkers", "Art": "Afbeeldingen", "HeaderLiveTV": "Live TV", - "HeaderFilters": "Filters", "HeaderGenres": "Genres", "HeaderHttpHeaders": "HTTP Headers", "HeaderStatus": "Status", @@ -1468,7 +1452,6 @@ "SelectAdminUsername": "Selecteer een gebruikersnaam voor het beheerder account.", "HeaderFavoritePlaylists": "Favoriete afspeellijsten", "ButtonTogglePlaylist": "Afspeellijst", - "ButtonToggleContextMenu": "Meer", "LabelRequireHttpsHelp": "Indien aangevinkt, zal de server alle verzoeken via HTTP automatisch omleiden naar HTTPS. Dit heeft geen effect als de server niet luistert op HTTPS.", "EnableDetailsBanner": "Details Banner", "MessageSyncPlayNoGroupsAvailable": "Geen groepen beschikbaar. Begin eerst iets te spelen.", diff --git a/src/strings/pl.json b/src/strings/pl.json index b4612c14af..d97c4d633c 100644 --- a/src/strings/pl.json +++ b/src/strings/pl.json @@ -53,7 +53,6 @@ "Browse": "Przeglądaj", "MessageBrowsePluginCatalog": "Przejrzyj nasz katalog wtyczek żeby zobaczyć dostępne wtyczki.", "BurnSubtitlesHelp": "Określa czy serwer powinien wypalać napisy podczas konwersji wideo, w zależności od formatu napisów. Unikanie wypalania napisów znacząco poprawia wydajność serwera. Wybierz Automatycznie, w celu wypalania zarówno napisów w formatach graficznych (np. VOBSUB, PGS, SUB, IDX, ...), jak i pewnych napisów ASS lub SSA.", - "ButtonAdd": "Dodaj", "ButtonAddMediaLibrary": "Dodaj media do biblioteki", "ButtonAddScheduledTaskTrigger": "Dodaj wyzwalacz", "ButtonAddServer": "Dodaj Serwer", @@ -79,7 +78,6 @@ "ButtonFullscreen": "Pełny ekran", "ButtonGotIt": "Rozumiem", "ButtonGuide": "Przewodnik", - "ButtonHelp": "Pomoc", "ButtonHome": "Start", "ButtonInfo": "Informacje", "ButtonLibraryAccess": "Dostęp do biblioteki", @@ -100,15 +98,12 @@ "ButtonRefreshGuideData": "Odśwież dane przewodnika", "ButtonRemove": "Usuń", "ButtonRename": "Zmień nazwę", - "ButtonRepeat": "Powtórz", "ButtonResetEasyPassword": "Wyczyść kod PIN", "ButtonResetPassword": "Wyczyść hasło", "ButtonRestart": "Uruchom ponownie", "ButtonResume": "Wznów", "ButtonRevoke": "Odwołaj", - "ButtonSave": "Zapisz", "ButtonScanAllLibraries": "Skanuj biblioteki", - "ButtonSearch": "Szukaj", "ButtonSelectDirectory": "Wybierz folder", "ButtonSelectServer": "Serwery", "ButtonSelectView": "Wybierz widok", @@ -324,7 +319,6 @@ "HeaderDevices": "Urządzenia", "HeaderDirectPlayProfile": "Profil Odtwarzania Bezpośredniego", "HeaderDirectPlayProfileHelp": "Dodaj profil odtwarzania bezpośredniego aby wskazać które formaty mogą być obsługiwane natywnie.", - "HeaderDisplay": "Wyświetlanie", "HeaderDownloadSync": "Synchronizacja", "HeaderEasyPinCode": "Kod PIN", "HeaderEditImages": "Edytuj obrazy", @@ -334,10 +328,8 @@ "HeaderError": "Błąd", "HeaderExternalIds": "Identyfikatory zewnętrzne:", "HeaderFeatureAccess": "Dostęp do funkcji", - "HeaderFeatures": "Cechy", "HeaderFetchImages": "Pobieraj obrazy:", "HeaderFetcherSettings": "Ustawienia pobierania", - "HeaderFilters": "Filtry", "HeaderForKids": "Dla dzieci", "HeaderForgotPassword": "Zapomniałem hasła", "HeaderFrequentlyPlayed": "Często odtwarzane", @@ -450,7 +442,6 @@ "HeaderSubtitleProfiles": "Profile napisów", "HeaderSubtitleProfilesHelp": "Profile napisów określają formaty obsługiwane przez urządzenie.", "HeaderSystemDlnaProfiles": "Profile systemowe", - "HeaderTags": "Znaczniki", "HeaderTaskTriggers": "Wyzwalacze", "HeaderThisUserIsCurrentlyDisabled": "Ten użytkownik jest aktualnie zablokowany", "HeaderTracks": "Utwory", @@ -506,7 +497,6 @@ "LabelAlbumArtMaxWidthHelp": "Maksymalna rozdzielczość okładki albumu wystawiana przez upnp:albumArtURI.", "LabelAlbumArtPN": "PN okładki albumu:", "LabelAlbumArtists": "Wykonawcy albumów:", - "LabelAll": "Wszystkie", "LabelAllowHWTranscoding": "Zezwalaj na sprzętowe transkodowanie", "LabelAllowedRemoteAddresses": "Filtr adresów IP:", "LabelAllowedRemoteAddressesMode": "Tryb filtra adresów IP:", @@ -1217,7 +1207,6 @@ "TabAdvanced": "Zaawansowane", "TabAlbumArtists": "Wykonawcy albumów", "TabAlbums": "Albumy", - "TabArtists": "Wykonawcy", "TabCatalog": "Katalog", "TabChannels": "Kanały", "TabCodecs": "Kodeki", @@ -1226,7 +1215,6 @@ "TabDashboard": "Kokpit", "TabDevices": "Urządzenia", "TabDirectPlay": "Odtwarzanie Bezposrednie", - "TabDisplay": "Wyświetlanie", "TabEpisodes": "Odcinki", "TabFavorites": "Ulubione", "TabGenres": "Gatunki", @@ -1235,7 +1223,6 @@ "TabLatest": "Ostatnio dodane", "TabLiveTV": "Telewizja", "TabLogs": "Dziennik zdarzeń", - "TabMetadata": "Metadane", "TabMovies": "Filmy", "TabMusic": "Muzyka", "TabMusicVideos": "Teledyski", @@ -1246,7 +1233,6 @@ "TabOther": "Inne", "TabParentalControl": "Kontrola rodzicielska", "TabPassword": "Hasło", - "TabPlayback": "Odtwarzanie", "TabPlaylists": "Listy odtwarzania", "TabPlugins": "Wtyczki", "TabProfile": "Profil", @@ -1261,9 +1247,7 @@ "TabShows": "Seriale", "TabSongs": "Utwory", "TabStreaming": "Transmitowanie", - "TabSuggestions": "Polecane", "TabTrailers": "Zwiastuny", - "TabTranscoding": "Transkodowanie", "TabUpcoming": "Wkrótce", "TabUsers": "Użytkownicy", "Tags": "Znaczniki", @@ -1448,7 +1432,6 @@ "DeinterlaceMethodHelp": "Wybierz metodę usuwania przeplotu używaną podczas transkodowania.", "ClientSettings": "Ustawienia klienta", "ButtonTogglePlaylist": "Playlista", - "ButtonToggleContextMenu": "Więcej", "ButtonSyncPlay": "SyncPlay", "ClearQueue": "Wyczyść kolejkę", "StopPlayback": "Zatrzymaj odtwarzanie", diff --git a/src/strings/pt-br.json b/src/strings/pt-br.json index e398e47fa2..753b554da6 100644 --- a/src/strings/pt-br.json +++ b/src/strings/pt-br.json @@ -49,7 +49,6 @@ "Browse": "Navegar", "MessageBrowsePluginCatalog": "Navegue pelo nosso catálogo de plugins para ver os plugins disponíveis.", "BurnSubtitlesHelp": "Determina se o servidor deveria gravar as legendas no vídeo ao convertê-lo, dependendo do formato da legenda. Evitar a gravação da legenda irá melhorar a performance do servidor. Selecione Auto para gravar legendas baseados em imagem dos tipos (ex. VOBSUB, PGS, SUB/IDX, etc.) e algumas legendas ASS/SSA.", - "ButtonAdd": "Adicionar", "ButtonAddMediaLibrary": "Adicionar Biblioteca de Mídia", "ButtonAddScheduledTaskTrigger": "Adicionar Disparador", "ButtonAddServer": "Adicionar Servidor", @@ -74,7 +73,6 @@ "ButtonFullscreen": "Tela Cheia", "ButtonGotIt": "Feito", "ButtonGuide": "Guia", - "ButtonHelp": "Ajuda", "ButtonHome": "Início", "ButtonLibraryAccess": "Acesso à biblioteca", "ButtonManualLogin": "Login Manual", @@ -95,15 +93,12 @@ "ButtonRefreshGuideData": "Atualizar Dados do Guia", "ButtonRemove": "Remover", "ButtonRename": "Renomear", - "ButtonRepeat": "Repetir", "ButtonResetEasyPassword": "Redefinir código pin fácil", "ButtonResetPassword": "Redefinir Senha", "ButtonRestart": "Reiniciar", "ButtonResume": "Retomar", "ButtonRevoke": "Revogar", - "ButtonSave": "Salvar", "ButtonScanAllLibraries": "Rastrear Todas as Bibliotecas", - "ButtonSearch": "Busca", "ButtonSelectDirectory": "Selecionar Diretório", "ButtonSelectServer": "Selecionar Servidor", "ButtonSelectView": "Selecionar visualização", @@ -311,7 +306,6 @@ "HeaderDevices": "Dispositivos", "HeaderDirectPlayProfile": "Perfil de Reprodução Direta", "HeaderDirectPlayProfileHelp": "Adiciona perfis de reprodução direta que indiquem quais formatos o dispositivo pode suportar nativamente.", - "HeaderDisplay": "Exibição", "HeaderDownloadSync": "Download e Sincronização", "HeaderEasyPinCode": "Código Pin Fácil", "HeaderEditImages": "Editar Imagens", @@ -321,10 +315,8 @@ "HeaderError": "Erro", "HeaderExternalIds": "IDs Externos:", "HeaderFeatureAccess": "Acesso aos Recursos", - "HeaderFeatures": "Recursos", "HeaderFetchImages": "Buscar Imagens:", "HeaderFetcherSettings": "Configurações do Buscador", - "HeaderFilters": "Filtros", "HeaderForKids": "Para Crianças", "HeaderForgotPassword": "Esqueci a Senha", "HeaderFrequentlyPlayed": "Reproduzidos Frequentemente", @@ -489,7 +481,6 @@ "LabelAlbumArtMaxWidthHelp": "Resolução máxima da arte do álbum exposta via upnp:albumArtURI.", "LabelAlbumArtPN": "PN da arte do álbum:", "LabelAlbumArtists": "Artistas do álbum:", - "LabelAll": "Todos", "LabelAllowHWTranscoding": "Permitir a transcodificação de hardware", "LabelAllowedRemoteAddresses": "Filtro de endereço IP remoto:", "LabelAllowedRemoteAddressesMode": "Modo do filtro de endereço IP remoto:", @@ -1178,21 +1169,18 @@ "TabAdvanced": "Avançado", "TabAlbumArtists": "Artistas do Álbum", "TabAlbums": "Álbuns", - "TabArtists": "Artistas", "TabCatalog": "Catálogo", "TabChannels": "Canais", "TabCollections": "Coletâneas", "TabDashboard": "Painel", "TabDevices": "Dispositivos", "TabDirectPlay": "Reprodução Direta", - "TabDisplay": "Exibição", "TabEpisodes": "Episódios", "TabFavorites": "Favoritos", "TabGenres": "Gêneros", "TabGuide": "Guia", "TabLatest": "Recentes", "TabLiveTV": "TV ao Vivo", - "TabMetadata": "Metadados", "TabMovies": "Filmes", "TabMusic": "Música", "TabMusicVideos": "Videoclipes", @@ -1203,7 +1191,6 @@ "TabOther": "Outros", "TabParentalControl": "Controle dos Pais", "TabPassword": "Senha", - "TabPlayback": "Reprodução", "TabPlaylists": "Listas de Reprodução", "TabProfile": "Perfil", "TabProfiles": "Perfis", @@ -1216,8 +1203,6 @@ "TabSettings": "Configurações", "TabShows": "Séries", "TabSongs": "Músicas", - "TabSuggestions": "Sugestões", - "TabTranscoding": "Transcodificação", "TabUpcoming": "A Seguir", "TabUsers": "Usuários", "TellUsAboutYourself": "Conte-nos sobre você", @@ -1296,7 +1281,6 @@ "HeaderAdmin": "Administrador", "HeaderApp": "Aplicativo", "HeaderStatus": "Status", - "HeaderTags": "Marcadores", "Horizontal": "Horizontal", "LabelAbortedByServerShutdown": "(Abortado devido ao desligamento do servidor)", "LabelCache": "Cache:", @@ -1467,7 +1451,6 @@ "Album": "Album", "UnsupportedPlayback": "O Jellyfin não pode descriptografar conteúdo protegido por DRM, porém mesmo assim fará uma tentativa para todo tipo de conteúdo, incluindo títulos protegidos. A imagem de alguns arquivos pode aparecer completamente preta devido a criptografia ou outros recursos não suportados, como títulos interativos.", "ButtonTogglePlaylist": "Playlist", - "ButtonToggleContextMenu": "Mais", "Filter": "Filtro", "New": "Novo", "HeaderFavoritePlaylists": "Playlists Favoritas", diff --git a/src/strings/pt-pt.json b/src/strings/pt-pt.json index 56712f348a..3d780043aa 100644 --- a/src/strings/pt-pt.json +++ b/src/strings/pt-pt.json @@ -8,7 +8,6 @@ "Audio": "Áudio", "Backdrops": "Imagens de Fundo", "MessageBrowsePluginCatalog": "Procure extensões disponíveis no nosso catálogo.", - "ButtonAdd": "Adicionar", "ButtonAddMediaLibrary": "Adicionar Biblioteca de Multimédia", "ButtonAddScheduledTaskTrigger": "Adicionar tarefa agendada", "ButtonAddServer": "Adicionar Servidor", @@ -28,7 +27,6 @@ "ButtonFilter": "Filtro", "ButtonForgotPassword": "Esqueci-me da palavra-passe", "ButtonFullscreen": "Ecrã inteiro", - "ButtonHelp": "Ajuda", "ButtonHome": "Início", "ButtonInfo": "Informação", "ButtonManualLogin": "Início de Sessão Manual", @@ -45,15 +43,12 @@ "ButtonRefresh": "Atualizar", "ButtonRefreshGuideData": "Atualizar Programação de TV", "ButtonRemove": "Remover", - "ButtonRepeat": "Repetir", "ButtonResetEasyPassword": "Redefinir código PIN", "ButtonResetPassword": "Redefinir palavra-passe", "ButtonRestart": "Reiniciar", "ButtonResume": "Retomar", "ButtonRevoke": "Revogar", - "ButtonSave": "Guardar", "ButtonScanAllLibraries": "Analisar todas as Bibliotecas", - "ButtonSearch": "Procurar", "ButtonSelectDirectory": "Selecione a Pasta", "ButtonSelectView": "Selecionar visualização", "ButtonSend": "Enviar", @@ -144,15 +139,12 @@ "HeaderDevices": "Dispositivos", "HeaderDirectPlayProfile": "Perfil da Reprodução Direta", "HeaderDirectPlayProfileHelp": "Adicionar perfis de reprodução direta que indiquem que formatos o dispositivo pode suportar nativamente.", - "HeaderDisplay": "Visualização", "HeaderEasyPinCode": "Código PIN", "HeaderEnabledFields": "Campos Ativados", "HeaderEnabledFieldsHelp": "Desmarque um campo para bloqueá-lo e evitar que seus dados sejam alterados.", "HeaderError": "Erro", "HeaderFeatureAccess": "Acesso a Características", - "HeaderFeatures": "Recursos", "HeaderFetchImages": "Procurar Imagens:", - "HeaderFilters": "Filtros", "HeaderForgotPassword": "Esqueci-me da palavra-passe", "HeaderFrequentlyPlayed": "Reproduzido Frequentemente", "HeaderGenres": "Géneros", @@ -270,7 +262,6 @@ "LabelAlbumArtMaxWidthHelp": "Resolução máxima da capa do álbum exposta via upnp:albumArtURI.", "LabelAlbumArtPN": "PN da capa do álbum:", "LabelAlbumArtists": "Artistas do Álbum:", - "LabelAll": "Todos", "LabelAppName": "Nome da aplicação", "LabelAppNameExample": "Exemplo: Sickbeard, Sonarr", "LabelArtists": "Artistas:", @@ -677,7 +668,6 @@ "TabAdvanced": "Avançado", "TabAlbumArtists": "Artistas do Álbum", "TabAlbums": "Álbuns", - "TabArtists": "Artistas", "TabCatalog": "Catálogo", "TabChannels": "Canais", "TabCollections": "Coleções", @@ -685,14 +675,12 @@ "TabDashboard": "Painel Principal", "TabDevices": "Dispositivos", "TabDirectPlay": "Reprodução Direta", - "TabDisplay": "Visualização", "TabEpisodes": "Episódios", "TabFavorites": "Favoritos", "TabGenres": "Géneros", "TabGuide": "Programação", "TabLatest": "Mais recente", "TabLiveTV": "TV em Direto", - "TabMetadata": "Metadados", "TabMovies": "Filmes", "TabMusic": "Música", "TabMusicVideos": "Videoclips", @@ -703,7 +691,6 @@ "TabOther": "Outro", "TabParentalControl": "Controlo Parental", "TabPassword": "Palavra-passe", - "TabPlayback": "Reprodução", "TabPlaylists": "Listas de Reprodução", "TabPlugins": "Extensões", "TabProfile": "Perfil", @@ -716,8 +703,6 @@ "TabSettings": "Configurações", "TabShows": "Séries", "TabSongs": "Músicas", - "TabSuggestions": "Sugestões", - "TabTranscoding": "Transcodificação", "TabUpcoming": "Próximos", "TabUsers": "Utilizadores", "TellUsAboutYourself": "Fale-nos sobre si", @@ -1162,7 +1147,6 @@ "CopyStreamURL": "Copiar URL da transmissão", "Disc": "Disco", "EnableBackdrops": "Imagens de Fundo", - "HeaderTags": "Etiquetas", "LabelLogs": "Registos:", "LabelSortTitle": "Título para ordenação:", "HeaderFavoritePeople": "Pessoas Favoritas", @@ -1467,7 +1451,6 @@ "DeinterlaceMethodHelp": "Selecionar um método de desentrelaçamento para converter conteúdo entrelaçado.", "ClientSettings": "Definições do Cliente", "ButtonTogglePlaylist": "Lista de Reprodução", - "ButtonToggleContextMenu": "Mais", "BoxSet": "Coleção", "Artist": "Artista", "AlbumArtist": "Artista do Álbum", diff --git a/src/strings/pt.json b/src/strings/pt.json index 45b8f0c182..9863623dc0 100644 --- a/src/strings/pt.json +++ b/src/strings/pt.json @@ -35,8 +35,6 @@ "TellUsAboutYourself": "Fale-nos sobre si", "TabUsers": "Utilizadores", "TabUpcoming": "Próximos", - "TabTranscoding": "Transcodificação", - "TabSuggestions": "Sugestões", "TabStreaming": "Transmissão", "TabSongs": "Músicas", "TabShows": "Séries", @@ -50,7 +48,6 @@ "TabProfile": "Perfil", "TabPlugins": "Extensões", "TabPlaylists": "Listas de Reprodução", - "TabPlayback": "Reprodução", "TabPassword": "Palavra-passe", "TabParentalControl": "Controlo Parental", "TabOther": "Outro", @@ -61,14 +58,12 @@ "TabMusicVideos": "Videoclips", "TabMusic": "Música", "TabMovies": "Filmes", - "TabMetadata": "Metadados", "TabLiveTV": "TV em Directo", "TabLatest": "Mais recente", "TabGuide": "Programação", "TabGenres": "Géneros", "TabFavorites": "Favoritos", "TabEpisodes": "Episódios", - "TabDisplay": "Visualização", "TabDirectPlay": "Reprodução Directa", "TabDevices": "Dispositivos", "TabDashboard": "Painel Principal", @@ -76,7 +71,6 @@ "TabCollections": "Colecções", "TabChannels": "Canais", "TabCatalog": "Catálogo", - "TabArtists": "Artistas", "TabAlbums": "Álbuns", "TabAlbumArtists": "Artistas do Álbum", "TabAdvanced": "Avançado", @@ -452,7 +446,6 @@ "LabelAllowedRemoteAddressesMode": "Tipo de filtro de IP remoto:", "LabelAllowedRemoteAddresses": "Filtro de IP remoto:", "LabelAllowHWTranscoding": "Permitir transcodificação por hardware", - "LabelAll": "Todos", "LabelAlbumArtists": "Artistas do Álbum:", "LabelAlbumArtPN": "PN da capa do álbum:", "LabelAlbumArtMaxWidthHelp": "Resolução máxima da capa do álbum exposta via upnp:albumArtURI.", @@ -617,9 +610,7 @@ "HeaderFrequentlyPlayed": "Reproduzido Frequentemente", "HeaderForgotPassword": "Esqueci-me da palavra-passe", "HeaderForKids": "Para Crianças", - "HeaderFilters": "Filtros", "HeaderFetchImages": "Procurar Imagens:", - "HeaderFeatures": "Recursos", "OptionDownloadThumbImage": "Miniatura", "OptionDownloadPrimaryImage": "Principal", "OptionDownloadImagesInAdvanceHelp": "Por omissão, a maioria das imagens são transferidas apenas quando uma aplicação do Jellyfin as solicita. Active esta opção para descarregar todas as imagens antecipadamente, assim que novos ficheiros multimédia sejam importados. Isto pode aumentar significativamente a duração da análise da biblioteca.", @@ -820,7 +811,6 @@ "HeaderEditImages": "Editar Imagens", "HeaderEasyPinCode": "Código PIN", "HeaderDownloadSync": "Transferência e Sincronização", - "HeaderDisplay": "Visualização", "HeaderDirectPlayProfileHelp": "Adicionar perfis de reprodução directa que indiquem que formatos o dispositivo pode suportar nativamente.", "HeaderDirectPlayProfile": "Perfil da Reprodução Directa", "HeaderDevices": "Dispositivos", @@ -962,15 +952,12 @@ "ButtonSelectView": "Seleccionar visualização", "ButtonSelectServer": "Seleccionar servidor", "ButtonSelectDirectory": "Seleccione a Pasta", - "ButtonSearch": "Procurar", "ButtonScanAllLibraries": "Analisar todas as Bibliotecas", - "ButtonSave": "Guardar", "ButtonRevoke": "Revogar", "ButtonResume": "Retomar", "ButtonRestart": "Reiniciar", "ButtonResetPassword": "Redefinir palavra-passe", "ButtonResetEasyPassword": "Redefinir código PIN", - "ButtonRepeat": "Repetir", "ButtonRename": "Alterar o nome", "ButtonRemove": "Remover", "ButtonRefreshGuideData": "Actualizar Programação de TV", @@ -992,7 +979,6 @@ "ButtonLibraryAccess": "Acesso à biblioteca", "ButtonInfo": "Informação", "ButtonHome": "Início", - "ButtonHelp": "Ajuda", "ButtonFullscreen": "Ecrã inteiro", "ButtonForgotPassword": "Esqueci-me da palavra-passe", "ButtonFilter": "Filtro", @@ -1056,7 +1042,6 @@ "ButtonAddScheduledTaskTrigger": "Adicionar tarefa agendada", "ButtonAddMediaLibrary": "Adicionar Biblioteca de Multimédia", "ButtonAddImage": "Adicionar Imagem", - "ButtonAdd": "Adicionar", "BurnSubtitlesHelp": "Determina se o servidor deve integrar as legendas durante a conversão de vídeo, dependendo do formato da legenda. Evitar a integração de legendas melhora o desempenho do servidor. Selecione Automático para que legendas baseadas em imagem (VOBSUB, PGS, SUB/IDX) e certos formatos ASS/SSA sejam integrados.", "MessageBrowsePluginCatalog": "Explore as extensões disponíveis no nosso catálogo.", "Browse": "Explorar", @@ -1186,7 +1171,6 @@ "FetchingData": "Buscando Dados Adicionais", "EnableStreamLooping": "Habilitar loop do streaming", "Down": "Baixar", - "HeaderTags": "Tags", "HeaderNavigation": "Navegar", "ButtonSplit": "Dividir", "AskAdminToCreateLibrary": "Peça a um administrador para criar uma biblioteca.", @@ -1388,6 +1372,5 @@ "HeaderDVR": "DVR", "ApiKeysCaption": "Lista das chaves de API ativadas no momento", "ButtonTogglePlaylist": "Lista de leitura", - "ButtonToggleContextMenu": "Mais", "ButtonSyncPlay": "SyncPlay" } diff --git a/src/strings/ro.json b/src/strings/ro.json index a0f090676b..b413f12756 100644 --- a/src/strings/ro.json +++ b/src/strings/ro.json @@ -1,6 +1,5 @@ { "All": "Toate", - "ButtonAdd": "Adaugă", "ButtonAddScheduledTaskTrigger": "Adaugă declanșator", "ButtonAddUser": "Adaugă Utilizator", "ButtonCancel": "Anulează", @@ -8,7 +7,6 @@ "ButtonDeleteImage": "Șterge Imaginea", "ButtonEdit": "Modifică", "ButtonFilter": "Filtru", - "ButtonHelp": "Ajutor", "ButtonManualLogin": "Conectare manuală", "ButtonNew": "Nou", "ButtonPlay": "Redă", @@ -17,7 +15,6 @@ "ButtonRefreshGuideData": "Reîmprospătează Ghidul", "ButtonRemove": "Elimină", "ButtonResetPassword": "Resetează parola", - "ButtonSave": "Salvează", "ButtonSelectDirectory": "Selectați Director", "ButtonSignIn": "Autentificare", "ButtonSignOut": "Delogare", @@ -44,7 +41,6 @@ "HeaderEasyPinCode": "Cod Pin Ușor", "HeaderFeatureAccess": "Acces Facilități", "HeaderFetchImages": "Preia imagini:", - "HeaderFilters": "Filtre", "HeaderFrequentlyPlayed": "Rulate Frecvent", "HeaderImageSettings": "Setari Imagini", "HeaderLatestEpisodes": "Cele Mai Noi Episoade", @@ -182,7 +178,6 @@ "TabAdvanced": "Avansat", "TabAlbumArtists": "Albume Artiști", "TabAlbums": "Albume", - "TabArtists": "Artiști", "TabChannels": "Canale", "TabCollections": "Colecții", "TabEpisodes": "Episoade", @@ -205,9 +200,7 @@ "TabSettings": "Setări", "TabShows": "Seriale", "TabSongs": "Melodii", - "TabSuggestions": "Recomandări", "TabTrailers": "Trailere", - "TabTranscoding": "Conversie", "TabUpcoming": "Urmează să apară", "TellUsAboutYourself": "Spune-ne despre tine", "ThisWizardWillGuideYou": "Acest asistent vă va ghida prin procesul de configurare. Pentru a începe, vă rugăm să selectați limba preferată.", @@ -339,12 +332,10 @@ "ErrorDefault": "A fost o eroare în procesarea cererii. Vă rugam încercați din nou mai târziu.", "DeleteImageConfirmation": "Sigur doriți să ștergeți această imagine?", "ButtonRename": "Redenumește", - "ButtonRepeat": "Repetă", "ButtonResetEasyPassword": "Resetează codul Easy PIN", "ButtonRestart": "Redemarează", "ButtonResume": "Continuă", "ButtonScanAllLibraries": "Scanează Toate Librariile", - "ButtonSearch": "Caută", "ButtonSelectServer": "Selectați Server", "ButtonSelectView": "Selectați perspectivă", "ButtonSend": "Trimite", @@ -409,7 +400,6 @@ "HeaderDeleteTaskTrigger": "Ștergeți Declanșarea Activității", "HeaderDetectMyDevices": "Detectează dispozitivele mele", "HeaderDeveloperInfo": "Informații pentru dezvoltatori", - "HeaderDisplay": "Afișare", "HeaderDownloadSync": "Descărcări și sincronizare", "HeaderEditImages": "Editează imagini", "HeaderEnabledFields": "Câmpuri activate", @@ -425,7 +415,6 @@ "HeaderApiKey": "Cheie API", "HeaderFavoritePeople": "Persoane Favorite", "HeaderFavoriteVideos": "Video Favorite", - "HeaderFeatures": "Caracteristici", "HeaderFetcherSettings": "Setări Fetcher", "HeaderForKids": "Pentru Copii", "HeaderForgotPassword": "Am uitat parola", @@ -893,7 +882,6 @@ "LabelAllowedRemoteAddressesMode": "Modul de filtrare a adresei IP de la distanță:", "LabelAllowedRemoteAddresses": "Filtrul de adrese IP de la distanță:", "LabelAllowHWTranscoding": "Permite transcodare hardware", - "LabelAll": "Tot", "LabelAlbumArtists": "Artiști album:", "LabelAlbumArtPN": "Artă album PN:", "LabelAlbumArtMaxWidthHelp": "Rezoluție maximă a artei albumului expusă via upnp:albumArtURI.", @@ -945,7 +933,6 @@ "HeaderTranscodingProfile": "Profilul transcodării", "HeaderTracks": "Piese", "HeaderThisUserIsCurrentlyDisabled": "Acest utilizator este momentan dezactivat", - "HeaderTags": "Etichete", "HeaderSystemDlnaProfiles": "Profile de sistem", "HeaderSubtitleProfilesHelp": "Profilele subtitrării descriu formatul subtitrării compatibil cu dispozitivul.", "HeaderSubtitleProfiles": "Profilele subtitrării", @@ -1405,15 +1392,12 @@ "TabResponses": "Răspunsuri", "TabPlugins": "Pluginuri", "TabPlaylists": "Liste redare", - "TabPlayback": "Redare", "TabParentalControl": "Control Parental", "TabNfoSettings": "Setări NFO", "TabNetworking": "Rețele", - "TabMetadata": "Metadată", "TabLogs": "Jurnal", "TabLiveTV": "TV în Direct", "TabInfo": "Info", - "TabDisplay": "Afișare", "TabDirectPlay": "Redare directă", "TabDevices": "Dispozitive", "TabDashboard": "Tablou de bord", @@ -1467,7 +1451,6 @@ "LabelLibraryPageSizeHelp": "Setează cantitatea de elemente de afișat pe o pagină a bibliotecii. Setați la 0 pentru a dezactiva paginarea.", "LabelLibraryPageSize": "Mărimea paginii Bibliotecă:", "ButtonTogglePlaylist": "Listă de redare", - "ButtonToggleContextMenu": "Mai mult", "Filter": "Filtru", "New": "Nou", "HeaderFavoritePlaylists": "Listă Favorită", diff --git a/src/strings/ru.json b/src/strings/ru.json index 50ab735286..a35a15642d 100644 --- a/src/strings/ru.json +++ b/src/strings/ru.json @@ -53,7 +53,6 @@ "Browse": "Навигация", "MessageBrowsePluginCatalog": "Просмотрите каталог плагинов, чтобы ознакомиться с имеющимися плагинами.", "BurnSubtitlesHelp": "Определяется, должен ли сервер внедрять субтитры при перекодировании. Избежание этого значительно улучшит производительность. Выберите «Авто» для записи основанных на графике форматов (VOBSUB, PGS, SUB, IDX и др.) и некоторых субтитров ASS или SSA.", - "ButtonAdd": "Добавить", "ButtonAddMediaLibrary": "Добавить медиатеку", "ButtonAddScheduledTaskTrigger": "Добавить триггер", "ButtonAddServer": "Добавить сервер", @@ -79,7 +78,6 @@ "ButtonFullscreen": "Полный экран", "ButtonGotIt": "Понятно", "ButtonGuide": "Телегид", - "ButtonHelp": "Справка", "ButtonHome": "Главное", "ButtonInfo": "Инфо", "ButtonLibraryAccess": "Доступ к медиатеке", @@ -101,15 +99,12 @@ "ButtonRefreshGuideData": "Обновить данные телегида", "ButtonRemove": "Изъять", "ButtonRename": "Переименовать", - "ButtonRepeat": "Повторить", "ButtonResetEasyPassword": "Сбросить простой PIN-код", "ButtonResetPassword": "Сбросить пароль", "ButtonRestart": "Перезапустить", "ButtonResume": "Возобновить", "ButtonRevoke": "Отозвать", - "ButtonSave": "Сохранить", "ButtonScanAllLibraries": "Сканировать все медиатеки", - "ButtonSearch": "Поиск", "ButtonSelectDirectory": "Выбрать каталог", "ButtonSelectServer": "Выбрать сервер", "ButtonSelectView": "Выбрать представление", @@ -124,7 +119,6 @@ "ButtonStop": "Остановить", "ButtonSubmit": "Подтвердить", "ButtonSubtitles": "Субтитры", - "ButtonToggleContextMenu": "Ещё", "ButtonTogglePlaylist": "Плей-лист", "ButtonTrailer": "Трейлер", "ButtonUninstall": "Удалить", @@ -328,7 +322,6 @@ "HeaderDevices": "Устройства", "HeaderDirectPlayProfile": "Профиль прямого воспроизведения", "HeaderDirectPlayProfileHelp": "Добавьте профили прямого воспроизведения, чтобы указать, какие форматы могут обрабатываться устройством изначально.", - "HeaderDisplay": "Отображение", "HeaderDownloadSync": "Загрузка и синхро", "HeaderEasyPinCode": "Простой PIN-код", "HeaderEditImages": "Править изображения", @@ -338,10 +331,8 @@ "HeaderError": "Ошибка", "HeaderExternalIds": "Внешние идентификаторы:", "HeaderFeatureAccess": "Доступ к компонентам", - "HeaderFeatures": "Материалы", "HeaderFetchImages": "Отборка изображений:", "HeaderFetcherSettings": "Параметры отборщика", - "HeaderFilters": "Фильтры", "HeaderForKids": "Детям", "HeaderForgotPassword": "Забыли пароль", "HeaderFrequentlyPlayed": "Воспроизведённые часто", @@ -454,7 +445,6 @@ "HeaderSubtitleProfiles": "Профили субтитров", "HeaderSubtitleProfilesHelp": "В профилях субтитров описываются форматы субтитров поддерживаемых устройством.", "HeaderSystemDlnaProfiles": "Системные профили", - "HeaderTags": "Теги", "HeaderTaskTriggers": "Триггеры задачи", "HeaderThisUserIsCurrentlyDisabled": "В настоящее время этот пользователь заблокирован", "HeaderTracks": "Дор-ки", @@ -510,7 +500,6 @@ "LabelAlbumArtMaxWidthHelp": "Максимальное разрешение альбомных обложек представляемых с помощью upnp:albumArtURI.", "LabelAlbumArtPN": "PN альбомной обложки:", "LabelAlbumArtists": "Исполнители альбома:", - "LabelAll": "Все", "LabelAllowHWTranscoding": "Разрешить аппаратную перекодировку", "LabelAllowedRemoteAddresses": "Фильтр внешних IP-адресов:", "LabelAllowedRemoteAddressesMode": "Режим фильтра внешних IP-адресов:", @@ -1231,7 +1220,6 @@ "TabAdvanced": "Расширенное", "TabAlbumArtists": "Исполнители альбома", "TabAlbums": "Альбомы", - "TabArtists": "Исполнители", "TabCatalog": "Каталог", "TabChannels": "Каналы", "TabCodecs": "Кодеки", @@ -1240,7 +1228,6 @@ "TabDashboard": "Панель", "TabDevices": "Устройства", "TabDirectPlay": "Прямое воспроизведение", - "TabDisplay": "Отображение", "TabEpisodes": "Эпизоды", "TabFavorites": "Избранное", "TabGenres": "Жанры", @@ -1249,7 +1236,6 @@ "TabLatest": "Новейшее", "TabLiveTV": "Эфир", "TabLogs": "Журналы", - "TabMetadata": "Метаданные", "TabMovies": "Фильмы", "TabMusic": "Музыка", "TabMusicVideos": "Муз. видео", @@ -1260,7 +1246,6 @@ "TabOther": "Другое", "TabParentalControl": "Управление содержанием", "TabPassword": "Пароль", - "TabPlayback": "Воспроизведение", "TabPlaylists": "Плей-листы", "TabPlugins": "Плагины", "TabProfile": "Профиль", @@ -1275,9 +1260,7 @@ "TabShows": "Сериалы", "TabSongs": "Треки", "TabStreaming": "Трансляция", - "TabSuggestions": "Рекомендации", "TabTrailers": "Трейлеры", - "TabTranscoding": "Перекодировка", "TabUpcoming": "Ожидаемое", "TabUsers": "Пользователи", "Tags": "Теги", diff --git a/src/strings/sk.json b/src/strings/sk.json index 44c5751175..25d6724907 100644 --- a/src/strings/sk.json +++ b/src/strings/sk.json @@ -26,7 +26,6 @@ "BirthPlaceValue": "Miesto narodenia: {0}", "BookLibraryHelp": "Audioknihy a učebnice sú podporované. Prečítajte si {0} pravidlá pre názvy kníh v Jellyfine {1}.", "Books": "Knihy", - "ButtonAdd": "Pridať", "ButtonAddMediaLibrary": "Pridať knižnicu médií", "ButtonAddScheduledTaskTrigger": "Pridať spúšťač", "ButtonAddServer": "Pridať server", @@ -50,7 +49,6 @@ "ButtonForgotPassword": "Zabudnuté heslo", "ButtonFullscreen": "Celá obrazovka", "ButtonGotIt": "Rozumiem", - "ButtonHelp": "Pomoc", "ButtonHome": "Domov", "ButtonManualLogin": "Manuálne prihlásenie", "ButtonMore": "Viac", @@ -68,14 +66,11 @@ "ButtonRefreshGuideData": "Obnoviť údaje sprievodcu", "ButtonRemove": "Odstrániť", "ButtonRename": "Premenovať", - "ButtonRepeat": "Opakovať", "ButtonResetEasyPassword": "Obnoviť jednoduchý PIN kód", "ButtonResetPassword": "Obnoviť heslo", "ButtonRestart": "Reštartovať", "ButtonResume": "Pokračovať", - "ButtonSave": "Uložiť", "ButtonScanAllLibraries": "Prehľadať všetky knižnice", - "ButtonSearch": "Hľadať", "ButtonSelectDirectory": "Vybrať priečinok", "ButtonSelectServer": "Vybrať server", "ButtonSend": "Odoslať", @@ -204,7 +199,6 @@ "HeaderEpisodes": "Epizódy", "HeaderError": "Chyba", "HeaderFetchImages": "Načítať obrázky:", - "HeaderFilters": "Filtre", "HeaderForKids": "Pre deti", "HeaderForgotPassword": "Zabudnuté heslo", "HeaderFrequentlyPlayed": "Často hrané", @@ -308,7 +302,6 @@ "Label3DFormat": "3D formát:", "LabelAccessDay": "Deň v týždni:", "LabelAirTime": "Čas vysielania:", - "LabelAll": "Všetky", "LabelAllowHWTranscoding": "Povoliť hardvérové transkódovanie", "LabelAllowedRemoteAddresses": "Filter vzdialených IP adries:", "LabelAppName": "Názov aplikácie", @@ -761,7 +754,6 @@ "TabAccess": "Prístup", "TabAdvanced": "Pokročilé", "TabAlbums": "Albumy", - "TabArtists": "Umelci", "TabCatalog": "Katalóg", "TabChannels": "Kanály", "TabCodecs": "Kodeky", @@ -775,7 +767,6 @@ "TabGuide": "Sprievodca", "TabLatest": "Najnovšie", "TabLiveTV": "Živá TV", - "TabMetadata": "Metadáta", "TabMovies": "Filmy", "TabMusic": "Hudba", "TabMusicVideos": "Hudobné videá", @@ -797,9 +788,7 @@ "TabSettings": "Nastavenia", "TabShows": "Seriály", "TabSongs": "Skladby", - "TabSuggestions": "Návrhy", "TabTrailers": "Trailery", - "TabTranscoding": "Transkódovanie", "TabUpcoming": "Nadchádzajúce", "TabUsers": "Užívatelia", "TellUsAboutYourself": "Povedzte nám niečo o sebe", @@ -931,7 +920,6 @@ "HeaderDownloadSync": "Sťahovanie a synchronizácia", "HeaderExternalIds": "Externé ID:", "HeaderFeatureAccess": "Prístup k funkciám", - "HeaderFeatures": "Funkcie", "HeaderHome": "Domov", "HeaderLoginFailure": "Prihlásenie zlyhalo", "HeaderMediaFolders": "Priečinky médií", @@ -941,7 +929,6 @@ "HeaderSpecialEpisodeInfo": "Informácie o špeciálnej epizóde", "HeaderSpecialFeatures": "Bonusové materiály", "HeaderSubtitleDownloads": "Sťahovanie titulkov", - "HeaderTags": "Tagy", "HeaderVideoType": "Typ videa", "HeaderVideoTypes": "Typy videí", "LabelAirsBeforeSeason": "Vysielané pred sériou:", @@ -985,7 +972,6 @@ "SortName": "Zoradiť podľa názvu", "TabDirectPlay": "Priame prehrávanie", "TabLogs": "Záznamy", - "TabPlayback": "Prehrávanie", "TabPlaylists": "Playlisty", "TabServer": "Server", "TabStreaming": "Streamovanie", @@ -1102,7 +1088,6 @@ "HeaderFavoritePeople": "Obľúbené osoby", "HeaderFavoriteBooks": "Obľúbené knihy", "HeaderEnabledFieldsHelp": "Zrušte zaškrtnutie, aby ste zabránili zmenám dát.", - "HeaderDisplay": "Zobrazenie", "HeaderDirectPlayProfile": "Profil Priameho prehrávania", "HeaderDeveloperInfo": "Informácie pre vývojára", "HeaderDeleteTaskTrigger": "Vymazať spúšťač úlohy", @@ -1184,7 +1169,6 @@ "Thumb": "Náhľad", "TheseSettingsAffectSubtitlesOnThisDevice": "Toto nastavenie ovplyvní titulky na tomto zariadení", "TabNetworking": "Sieť", - "TabDisplay": "Zobrazenie", "TabAlbumArtists": "Umelec albumu", "SystemDlnaProfilesHelp": "Systémové profily sú len na čítanie. Zmeny systémových profilov budú uložené do nového vlastné profilu.", "SubtitleOffset": "Odchýlka titulkov", @@ -1470,7 +1454,6 @@ "New": "Nové", "HeaderFavoritePlaylists": "Obľúbené playlisty", "ButtonTogglePlaylist": "Playlist", - "ButtonToggleContextMenu": "Viac", "ApiKeysCaption": "Zoznam v súčasnosti povolených API kľúčov", "LabelStable": "Stabilná", "LabelChromecastVersion": "Chromecast verzia", diff --git a/src/strings/sl-si.json b/src/strings/sl-si.json index 077ea67804..6524841c3e 100644 --- a/src/strings/sl-si.json +++ b/src/strings/sl-si.json @@ -43,7 +43,6 @@ "Settings": "Nastavitve", "TabAccess": "Dostop", "TabAlbumArtists": "Izvajalci Albumov", - "TabArtists": "Izvajalci", "TabCatalog": "Katalog", "TabGenres": "Zvrsti", "TabLatest": "Zadnje", @@ -54,7 +53,6 @@ "TabProfile": "Profil", "TabProfiles": "Profili", "TabShows": "Oddaje", - "TabSuggestions": "Predlogi", "TabUpcoming": "Prihajajoče", "TellUsAboutYourself": "Povej nam nekaj o sebi", "ThisWizardWillGuideYou": "Čarovnik vas bo vodil skozi postopek namestitve. Za začetek, izberite jezik.", @@ -121,7 +119,6 @@ "Browse": "Brskaj", "MessageBrowsePluginCatalog": "Poiščite razpoložljive dodatke v našem katalogu.", "BurnSubtitlesHelp": "Določi ali naj strežnik vžge podnapise pri prekodiranju videa. Izogibanje temu lahko občutno izboljša delovanje strežnika. Izberite Samodejno za vžig slikovnih formatov podnapisov (VOBSUB, PGS, SUB, IDX, ...) in nekaterih ASS oziroma SSA podnapisov.", - "ButtonAdd": "Dodaj", "Photos": "Fotografije", "Playlists": "Seznami predvajanja", "Songs": "Pesmi", @@ -152,7 +149,6 @@ "ButtonFullscreen": "Polni zaslon", "ButtonGotIt": "Razumem", "ButtonGuide": "Vodič", - "ButtonHelp": "Pomoč", "ButtonHome": "Domov", "ButtonInfo": "Info", "ButtonLibraryAccess": "Dostop do knjižnic", @@ -173,14 +169,11 @@ "ButtonRefreshGuideData": "Osveži TV vodič", "ButtonRemove": "Odstrani", "ButtonRename": "Preimenuj", - "ButtonRepeat": "Ponovi", "ButtonResetEasyPassword": "Ponastavi preprosto PIN kodo", "ButtonRestart": "Ponovno zaženi", "ButtonResume": "Nadaljuj", "ButtonRevoke": "Razveljavi", - "ButtonSave": "Shrani", "ButtonScanAllLibraries": "Preišči vse knjižnice", - "ButtonSearch": "Išči", "ButtonSelectDirectory": "Izberi mapo", "ButtonSelectServer": "Izberi strežnik", "ButtonSelectView": "Izberi pogled", @@ -353,7 +346,6 @@ "HeaderGenres": "Žanri", "HeaderForgotPassword": "Pozabljeno geslo", "HeaderForKids": "Za otroke", - "HeaderFilters": "Filtri", "HeaderFetcherSettings": "Nastavitve pridobivanja", "HeaderFetchImages": "Pridobi slike:", "HeaderFavoriteVideos": "Priljubljeni videi", @@ -366,7 +358,6 @@ "HeaderEnabledFields": "Omogočena polja", "HeaderEditImages": "Uredi slike", "HeaderDownloadSync": "Prenos in sinhronizacija", - "HeaderDisplay": "Prikaz", "HeaderDirectPlayProfileHelp": "Dodaj profil za neposredno predvajanje in določi katere formate naprava podpira.", "HeaderDirectPlayProfile": "Profil za neposredno predvajanje", "HeaderDevices": "Naprave", @@ -516,7 +507,6 @@ "HeaderTracks": "Skladbe", "HeaderThisUserIsCurrentlyDisabled": "Ta uporabnik je trenutno onemogočen", "HeaderTaskTriggers": "Sprožilci opravil", - "HeaderTags": "Oznake", "HeaderSystemDlnaProfiles": "Sistemski profili", "HeaderSubtitleProfilesHelp": "Profili podnapisov določajo formate podnapisov, ki je naprava podpira.", "HeaderSubtitleProfiles": "Profili podnapisov", @@ -538,7 +528,6 @@ "HeaderSendMessage": "Pošlji sporočilo", "HeaderSelectTranscodingPath": "Izberi pot začasnih datotek prekodiranja", "HeaderRevisionHistory": "Pregled zgodovine", - "HeaderFeatures": "Funkcije", "HeaderFeatureAccess": "Dostop funkcij", "HeaderDeviceAccess": "Dostop naprav", "HeaderContainerProfile": "Profil kontejnerja", @@ -575,7 +564,6 @@ "LabelAirsAfterSeason": "Predvajanje po sezoni:", "LabelAirsBeforeSeason": "Predvajanje pred sezono:", "LabelAlbumArtists": "Izvajalci albuma:", - "LabelAll": "Vse", "LabelCustomRating": "Prilagojena ocena:", "LabelBirthDate": "Datum rojstva:", "LabelCache": "Predpomnilnik:", @@ -749,7 +737,6 @@ "MessagePluginInstalled": "Dodatek je bil uspešno nameščen. Za uveljavitev sprememb je potreben ponovni zagon Jellyfin strežnika.", "MessageNoMovieSuggestionsAvailable": "Trenutno ni na voljo nobenih predlogov za filme. Začnite gledati in ocenjevati vaše filme, ter se nato vrnite sem in si oglejte predloge.", "LabelSelectFolderGroups": "Samodejno združi vsebine iz spodnjih map v poglede kot so Filmi, Glasba in TV:", - "TabPlayback": "Predvajanje", "TitlePlayback": "Predvajanje", "MessagePasswordResetForUsers": "Gesla naslednjih uporabnikov so bila ponastavljena. Zdaj se lahko prijavijo s PIN kodami, ki so bile uporabljene za ponastavitev.", "OptionHideUserFromLoginHelp": "Koristno za zasebne ali skrite skrbniške račune. Uporabnik se bo moral prijaviti ročno z vpisom svojega uporabniškega imena in gesla.", @@ -1171,7 +1158,6 @@ "TabTrailers": "Napovedniki", "ClientSettings": "Nastavitve odjemalca", "ButtonTogglePlaylist": "Seznam predvajanja", - "ButtonToggleContextMenu": "Več", "Artist": "Izvajalec", "AlbumArtist": "Izvajalec albuma", "Album": "Album", @@ -1344,12 +1330,10 @@ "LabelWeb": "Splet:", "LabelLineup": "Postava:", "BoxSet": "Komplet", - "TabMetadata": "Metapodatki", "TabInfo": "Informacije", "TabGuide": "Vodič", "TabFavorites": "Priljubljeni", "TabEpisodes": "Epizode", - "TabDisplay": "Prikaz", "TabDirectPlay": "Neposredno predvajanje", "TabDevices": "Naprave", "TabCodecs": "Kodeki", @@ -1358,7 +1342,6 @@ "OptionProtocolHls": "HTTP pretakanje v živo", "OptionProfileVideoAudio": "Video zvok", "ThemeSongs": "Glavne pesmi", - "TabTranscoding": "Prekodiranje", "TabStreaming": "Pretakanje", "TabSongs": "Skladbe", "TabSettings": "Nastavitve", diff --git a/src/strings/sr.json b/src/strings/sr.json index 4682f060f1..810fa44141 100644 --- a/src/strings/sr.json +++ b/src/strings/sr.json @@ -43,7 +43,6 @@ "ButtonLibraryAccess": "Приступ библиотеци", "ButtonInfo": "Информације", "ButtonHome": "Почетна страна", - "ButtonHelp": "Помоћ", "ButtonGuide": "Водич", "ButtonGotIt": "У реду", "ButtonFullscreen": "Пун екран", @@ -67,7 +66,6 @@ "ButtonAddScheduledTaskTrigger": "Додај прекидач", "ButtonAddMediaLibrary": "Додај каталог медија", "ButtonAddImage": "Додај слику", - "ButtonAdd": "Додај", "MessageBrowsePluginCatalog": "Претражуј наш каталог доступних додатака", "Browse": "Изабери", "BoxRear": "Омот (позади)", @@ -144,15 +142,12 @@ "ButtonSelectView": "Изаберите приказ", "ButtonSelectServer": "Иѕаберите сервер", "ButtonSelectDirectory": "Изаберите Директоријум", - "ButtonSearch": "Тражи", "ButtonScanAllLibraries": "Скенирај све библиотеке", - "ButtonSave": "Сачувај", "ButtonRevoke": "Опозови", "ButtonResume": "Настави", "ButtonRestart": "Покрени поново", "ButtonResetPassword": "Ресетуј шифру", "ButtonResetEasyPassword": "Ресетујте једноставан ПИН код", - "ButtonRepeat": "Пусти поново", "ButtonRename": "Преименуј", "ButtonRemove": "Уклони", "ButtonRefreshGuideData": "Освежи податке водича", diff --git a/src/strings/sv.json b/src/strings/sv.json index ef4e849e40..23c68d9e84 100644 --- a/src/strings/sv.json +++ b/src/strings/sv.json @@ -45,7 +45,6 @@ "Browse": "Bläddra", "MessageBrowsePluginCatalog": "Besök katalogen för att se tillgängliga tillägg.", "BurnSubtitlesHelp": "Avgör ifall servern ska \"bränna in\" undertexterna under transkodning. Att undvika detta förbättrar prestandan avsevärt. Välj \"Automatisk\" för att bränna bild-baserade format (ex. VOBSUB, PGS, SUB/IDX, ...) och vissa ASS/SSA-undertexter.", - "ButtonAdd": "Lägg till", "ButtonAddMediaLibrary": "Lägg till mediabibliotek", "ButtonAddScheduledTaskTrigger": "Lägg till utlösare", "ButtonAddServer": "Lägg till server", @@ -70,7 +69,6 @@ "ButtonForgotPassword": "Glömt Lösenord", "ButtonFullscreen": "Fullskärm", "ButtonGotIt": "Ok", - "ButtonHelp": "Hjälp", "ButtonHome": "Hem", "ButtonLibraryAccess": "Biblioteksåtkomst", "ButtonManualLogin": "Manuell inloggning", @@ -91,15 +89,12 @@ "ButtonRefreshGuideData": "Uppdatera programguiden", "ButtonRemove": "Ta bort", "ButtonRename": "Ändra namn", - "ButtonRepeat": "Upprepa", "ButtonResetEasyPassword": "Återställ enkel pin-kod", "ButtonResetPassword": "Återställ lösenord", "ButtonRestart": "Starta om", "ButtonResume": "Återuppta", "ButtonRevoke": "Återkalla", - "ButtonSave": "Spara", "ButtonScanAllLibraries": "Scanna alla bibliotek", - "ButtonSearch": "Sök", "ButtonSelectDirectory": "Välj mapp", "ButtonSelectServer": "Välj server", "ButtonSelectView": "Välj vy", @@ -294,7 +289,6 @@ "HeaderDevices": "Enheter", "HeaderDirectPlayProfile": "Profil för direktuppspelning", "HeaderDirectPlayProfileHelp": "Ange direktuppspelningsprofiler för att indikera vilka format enheten kan spela upp utan omkodning.", - "HeaderDisplay": "Visning", "HeaderDownloadSync": "Ladda ner & Synka", "HeaderEasyPinCode": "Lätt pinkod", "HeaderEditImages": "Redigera bilder", @@ -304,9 +298,7 @@ "HeaderError": "Fel", "HeaderExternalIds": "Externa ID:", "HeaderFeatureAccess": "Tillgång till funktioner", - "HeaderFeatures": "Extramaterial", "HeaderFetchImages": "Hämta bilder:", - "HeaderFilters": "Filter", "HeaderForKids": "För barn", "HeaderForgotPassword": "Glömt Lösenord", "HeaderFrequentlyPlayed": "Ofta spelade", @@ -413,7 +405,6 @@ "HeaderSubtitleProfiles": "Undertextprofiler", "HeaderSubtitleProfilesHelp": "Undertextprofiler beskriver de undertextformat som stöds av enheten.", "HeaderSystemDlnaProfiles": "Systemprofiler", - "HeaderTags": "Etiketter", "HeaderTaskTriggers": "Aktivitetsutlösare", "HeaderThisUserIsCurrentlyDisabled": "Den här användaren är inaktiverad", "HeaderTracks": "Spår", @@ -465,7 +456,6 @@ "LabelAlbumArtMaxWidthHelp": "Högsta upplösning hos omslagsbilder presenterade via upnp:albumArtURI.", "LabelAlbumArtPN": "PN för omslagsbilder:", "LabelAlbumArtists": "Albumartist:", - "LabelAll": "Alla", "LabelAllowHWTranscoding": "Tillåt hårdvaruomkodning", "LabelAppName": "Appens namn", "LabelAppNameExample": "Exempel: Sickbeard, Sonarr", @@ -1139,7 +1129,6 @@ "TabAdvanced": "Avancerat", "TabAlbumArtists": "Albumartister", "TabAlbums": "Album", - "TabArtists": "Artister", "TabCatalog": "Katalog", "TabChannels": "Kanaler", "TabCodecs": "Kodningsformat", @@ -1148,7 +1137,6 @@ "TabDashboard": "Kontrollpanel", "TabDevices": "Enheter", "TabDirectPlay": "Direktuppspelning", - "TabDisplay": "Visning", "TabEpisodes": "Avsnitt", "TabFavorites": "Favoriter", "TabGenres": "Genrer", @@ -1166,7 +1154,6 @@ "TabOther": "Övrigt", "TabParentalControl": "Föräldralås", "TabPassword": "Lösenord", - "TabPlayback": "Uppspelning", "TabPlaylists": "Spellistor", "TabPlugins": "Tillägg", "TabProfile": "Profil", @@ -1180,8 +1167,6 @@ "TabShows": "Serier", "TabSongs": "Låtar", "TabStreaming": "Strömning", - "TabSuggestions": "Förslag", - "TabTranscoding": "Omkodning", "TabUpcoming": "Kommande", "TabUsers": "Användare", "Tags": "Etiketter", @@ -1345,7 +1330,6 @@ "TabTrailers": "Trailers", "TabServer": "Server", "TabNetworking": "Nätverk", - "TabMetadata": "Metadata", "TabInfo": "Info", "TabAccess": "Tillgång", "TV": "TV", @@ -1456,7 +1440,6 @@ "BoxSet": "Samlingsbox", "Artist": "Artist", "ButtonTogglePlaylist": "Spellista", - "ButtonToggleContextMenu": "Mer", "AlbumArtist": "Albumartist", "LabelLibraryPageSize": "Bibliotekets sidstorlek:", "LabelDeinterlaceMethod": "Deinterlacing-metod:", diff --git a/src/strings/tr.json b/src/strings/tr.json index 8936fa6463..80098c3222 100644 --- a/src/strings/tr.json +++ b/src/strings/tr.json @@ -6,7 +6,6 @@ "AllowRemoteAccessHelp": "Eğer işaretlenmemişse, bütün uzak bağlantılar bloke edilicek.", "AttributeNew": "Yeni", "MessageBrowsePluginCatalog": "Mevcut eklentileri görebilmek için eklenti katologuna göz atın.", - "ButtonAdd": "Ekle", "ButtonAddUser": "Kullanıcı Ekle", "ButtonArrowRight": "Sağ", "ButtonBack": "Geri", @@ -15,7 +14,6 @@ "ButtonDeleteImage": "Resmi Sil", "ButtonEdit": "Düzenle", "ButtonFilter": "Filtrele", - "ButtonHelp": "Yardım", "ButtonHome": "Anasayfa", "ButtonInfo": "Bilgi", "ButtonManualLogin": "Manuel Giriş", @@ -28,8 +26,6 @@ "ButtonRemove": "Sil", "ButtonResetPassword": "Şifre Sıfırla", "ButtonRestart": "Tekrar Başlat", - "ButtonSave": "Kayıt", - "ButtonSearch": "Arama", "ButtonSelectDirectory": "Dosyayı Seç", "ButtonSend": "Gönder", "ButtonSettings": "Ayarlar", @@ -64,7 +60,6 @@ "HeaderCustomDlnaProfiles": "Özel Profiller", "HeaderDeviceAccess": "Cihaz Erişimi", "HeaderEasyPinCode": "Kolay Pin Kodu", - "HeaderFilters": "Filtreler", "HeaderFrequentlyPlayed": "Sıkça Oynatılan", "HeaderImageSettings": "Resim Ayarları", "HeaderLatestEpisodes": "En yeni bölümler", @@ -207,7 +202,6 @@ "TabAdvanced": "Gelişmiş", "TabAlbumArtists": "Albüm Sanatçıları", "TabAlbums": "Albümler", - "TabArtists": "Sanatçılar", "TabCatalog": "Katalog", "TabChannels": "Kanallar", "TabCodecs": "Codecler", @@ -232,9 +226,7 @@ "TabSettings": "Ayarlar", "TabShows": "Diziler", "TabSongs": "Şarkılar", - "TabSuggestions": "Önerilenler", "TabTrailers": "Fragmanlar", - "TabTranscoding": "Kodlayıcı", "TabUpcoming": "Gelecek", "TellUsAboutYourself": "Kendinizden bahsedin", "ThisWizardWillGuideYou": "Bu sihirbaz kurulum işlemi boyunca size yardımcı olacaktır. Başlamak için, tercih ettiğiniz dili seçiniz.", @@ -291,7 +283,6 @@ "ButtonProfile": "Profil", "ButtonRefresh": "Yenile", "ButtonRename": "Yeniden Adlandır", - "ButtonRepeat": "Tekrar", "ButtonResume": "Devam Et", "ButtonRevoke": "Geri al", "ChannelNumber": "Kanal numarası", @@ -437,7 +428,6 @@ "HeaderForKids": "Çocuklar için", "HeaderFetcherSettings": "Alıcı Ayarları", "HeaderFetchImages": "Görüntüleri Getir:", - "HeaderFeatures": "Özellikleri", "HeaderFeatureAccess": "Özellik Erişimi", "HeaderFavoriteVideos": "Favori Videolar", "HeaderFavoriteMovies": "Favori Filmler", @@ -449,7 +439,6 @@ "HeaderEnabledFields": "Etkin Alanlar", "HeaderEditImages": "Görüntüleri Düzenle", "HeaderDownloadSync": "İndir ve Eşitle", - "HeaderDisplay": "Görüntüle", "HeaderDirectPlayProfileHelp": "Aygıtın yerel olarak hangi biçimlerde kullanılabileceğini göstermek için doğrudan oynatma profilleri ekleyin.", "HeaderDirectPlayProfile": "Doğrudan Oyun Profili", "HeaderDevices": "Cihazlar", @@ -641,7 +630,6 @@ "LabelAudio": "Ses", "LabelAppName": "Uygulama adı", "LabelAllowHWTranscoding": "Donanım kod dönüştürmesine izin ver", - "LabelAll": "Tümü", "LabelAlbumArtMaxWidth": "Albüm resmi maks. genişlik:", "LabelAlbumArtMaxHeight": "Albüm resmi maks. yükseklik:", "LabelAlbum": "Albüm:", @@ -668,7 +656,6 @@ "HeaderTypeText": "Metin Gir", "HeaderTunerDevices": "Alıcı Cihazları", "HeaderThisUserIsCurrentlyDisabled": "Bu kullanıcı şu anda pasif", - "HeaderTags": "Etiketler", "HeaderSubtitleProfiles": "Altyazı Profilleri", "HeaderSubtitleProfile": "Altyazı Profili", "HeaderSubtitleDownloads": "Altyazı İndirmeleri", diff --git a/src/strings/uk.json b/src/strings/uk.json index 95948074ea..c1bec0b050 100644 --- a/src/strings/uk.json +++ b/src/strings/uk.json @@ -7,7 +7,6 @@ "ButtonNew": "Новий", "ButtonRename": "Перейменувати", "ButtonResetPassword": "Скинути пароль", - "ButtonSave": "Зберігти", "ButtonSignOut": "Sign out", "DeathDateValue": "Помер: {0}", "Dislike": "Не подобається", @@ -66,7 +65,6 @@ "TabCollections": "Колекції", "TabEpisodes": "Епізоди", "TabGenres": "Жанри", - "TabMetadata": "Метадані", "TabMovies": "Фільми", "TabNetworks": "Мережі", "TabNotifications": "Повідомлення", diff --git a/src/strings/vi.json b/src/strings/vi.json index b4d79f267b..431644be16 100644 --- a/src/strings/vi.json +++ b/src/strings/vi.json @@ -2,15 +2,12 @@ "Add": "Thêm", "All": "Tất cả", "MessageBrowsePluginCatalog": "Duyệt qua các danh mục plugin của chúng tôi để xem các plugin có sẵn.", - "ButtonAdd": "Thêm", "ButtonAddUser": "Thêm người dùng", "ButtonCancel": "Thoát", "ButtonDeleteImage": "Xóa hình ảnh", "ButtonNew": "Mới", "ButtonRemove": "Gỡ bỏ", "ButtonResetPassword": "Reset mật khẩu", - "ButtonSave": "Lưu", - "ButtonSearch": "Tìm kiếm", "ButtonSelectDirectory": "Lựa chọn trực tiếp", "ButtonSignOut": "Sign out", "ButtonSort": "Phân loại", @@ -93,7 +90,6 @@ "Sunday": "Chủ Nhật", "TabAlbumArtists": "Các Album nghệ sỹ", "TabAlbums": "Các Album", - "TabArtists": "Các nghệ sỹ", "TabCatalog": "Danh mục", "TabEpisodes": "Các tập phim", "TabGenres": "Các thể loại", @@ -107,7 +103,6 @@ "TabProfiles": "Hồ sơ", "TabServer": "Máy chủ", "TabSongs": "Các ca khúc", - "TabTranscoding": "Mã hóa", "TabUpcoming": "Sắp diễn ra", "TellUsAboutYourself": "Nói cho chúng tôi biết đôi điều về Bạn", "ThisWizardWillGuideYou": "Thủ thuật này sẽ hướng dẫn quá trình cài đặt cho bạn. Để bắt đầu, vui lòng lựa chọn ngôn ngữ bạn ưa thích.", @@ -120,7 +115,6 @@ "ButtonResume": "Tiếp tục", "ButtonRestart": "Khởi động lại", "ButtonResetEasyPassword": "Đặt lại mã pin nhanh", - "ButtonRepeat": "Lặp lại", "ButtonRename": "Đổi tên", "ButtonRefreshGuideData": "Làm mới dữ liệu hướng dẫn", "ButtonRefresh": "Làm mới", @@ -139,7 +133,6 @@ "ButtonLibraryAccess": "Truy cập thư viện", "ButtonInfo": "Thông tin", "ButtonHome": "Trang chủ", - "ButtonHelp": "Giúp đỡ", "ButtonGuide": "Hướng dẫn", "ButtonGotIt": "Hiểu rồi", "ButtonFullscreen": "Toàn màn hình", @@ -263,7 +256,6 @@ "ChangingMetadataImageSettingsNewContent": "Thay đổi về thiết lập của việc tải thông tin hoặc hình ảnh sẽ chỉ có tác dụng với những nội dung mới được thêm vào thư viện. Để những thiết lập mới có tác dụng với nội dung đã có sẵn, bạn sẽ phải cập nhật lại thông tin của chúng.", "CancelSeries": "Ngưng series", "ButtonTogglePlaylist": "Danh sách phát", - "ButtonToggleContextMenu": "Thêm", "BoxSet": "Tuyển tập", "Box": "Hộp", "Banner": "Ảnh bìa", @@ -487,10 +479,8 @@ "HeaderGenres": "Thể Loại", "HeaderForgotPassword": "Quên Mật Khẩu", "HeaderForKids": "Dành Cho Trẻ Em", - "HeaderFilters": "Bộ Lọc", "HeaderFetcherSettings": "Cài Đặt Chương Trình Tải Xuống", "HeaderFetchImages": "Tải Hình Ảnh:", - "HeaderFeatures": "Nổi Bật", "HeaderFavoritePeople": "Nhân Vật Yêu Thích", "HeaderFavoriteAlbums": "Album Yêu Thích", "HeaderFavoriteBooks": "Sách Yêu Thích", @@ -508,7 +498,6 @@ "HeaderEditImages": "Chỉnh Sửa Hình Ảnh", "HeaderEasyPinCode": "Mã PIN Đơn Giản", "HeaderDownloadSync": "Tải Xuống Và Đồng Bộ", - "HeaderDisplay": "Hiển Thị", "HeaderDirectPlayProfileHelp": "Thêm thiết lập phát trực tiếp để chỉ ra những định dạng mà thiết bị có thể phát trực tiếp mà không cần chuyển mã.", "HeaderDirectPlayProfile": "Thiết Lập Phát Trực Tiếp", "HeaderDevices": "Thiết Bị", @@ -557,7 +546,6 @@ "HeaderTracks": "Bài Hát", "HeaderThisUserIsCurrentlyDisabled": "Người dùng này hiện tại đang bị khoá", "HeaderTaskTriggers": "Kích Hoạt Tác Vụ", - "HeaderTags": "Nhãn", "HeaderSubtitleProfilesHelp": "Hồ sơ phụ đề chỉ ra những định dạng phụ đề được hỗ trợ bởi thiết bị phát.", "HeaderSubtitleProfiles": "Hồ Sơ Phụ Đề", "HeaderSubtitleProfile": "Hồ Sơ Phụ Đề", @@ -609,7 +597,6 @@ "LabelAllowedRemoteAddressesMode": "Chế độ bộ lọc địa chỉ IP từ xa:", "LabelAllowedRemoteAddresses": "Bộ lọc địa chỉ IP từ xa:", "LabelAllowHWTranscoding": "Cho phép chuyển mã bằng phần cứng", - "LabelAll": "Tất Cả", "LabelAlbumArtists": "Nghệ sĩ album:", "LabelAlbumArtPN": "Bìa album PN:", "LabelAlbumArtMaxWidthHelp": "Độ phân giải cao nhất của bìa album thông qua upnp:albumArtURI.", diff --git a/src/strings/zh-cn.json b/src/strings/zh-cn.json index eed9f95599..e8e43426f0 100644 --- a/src/strings/zh-cn.json +++ b/src/strings/zh-cn.json @@ -47,7 +47,6 @@ "Browse": "浏览", "MessageBrowsePluginCatalog": "浏览我们的插件目录来查看现有插件。", "BurnSubtitlesHelp": "服务器在转换视频时是否应压制字幕。避免压制字幕会提高服务器性能。选择“自动”以压制基于图像的字幕格式(如 VOBSUB, PGS, SUB, IDX 等)和一些复杂的 ASS/SSA 字幕。", - "ButtonAdd": "添加", "ButtonAddMediaLibrary": "添加媒体库", "ButtonAddScheduledTaskTrigger": "添加触发器", "ButtonAddServer": "添加服务器", @@ -73,7 +72,6 @@ "ButtonFullscreen": "全屏", "ButtonGotIt": "知道了", "ButtonGuide": "指南", - "ButtonHelp": "帮助", "ButtonHome": "首页", "ButtonInfo": "详情", "ButtonLibraryAccess": "媒体库访问", @@ -95,15 +93,12 @@ "ButtonRefreshGuideData": "刷新指南数据", "ButtonRemove": "移除", "ButtonRename": "重命名", - "ButtonRepeat": "重播", "ButtonResetEasyPassword": "复位简易PIN码", "ButtonResetPassword": "重置密码", "ButtonRestart": "重启", "ButtonResume": "恢复播放", "ButtonRevoke": "撤销", - "ButtonSave": "保存", "ButtonScanAllLibraries": "扫描所有媒体库", - "ButtonSearch": "搜索", "ButtonSelectDirectory": "选择目录", "ButtonSelectServer": "选择服务器", "ButtonSelectView": "选择视图", @@ -298,7 +293,6 @@ "HeaderDevices": "设备", "HeaderDirectPlayProfile": "直接播放配置", "HeaderDirectPlayProfileHelp": "添加直接播放配置文件标明哪些媒体格式设备可以自己处理。", - "HeaderDisplay": "显示", "HeaderDownloadSync": "下载与同步", "HeaderEasyPinCode": "简单 PIN 码", "HeaderEditImages": "修改图片", @@ -308,10 +302,8 @@ "HeaderError": "错误", "HeaderExternalIds": "外部 ID:", "HeaderFeatureAccess": "可使用的功能", - "HeaderFeatures": "功能", "HeaderFetchImages": "获取图像:", "HeaderFetcherSettings": "读取器设置", - "HeaderFilters": "筛选", "HeaderForKids": "给儿童", "HeaderForgotPassword": "忘记密码", "HeaderFrequentlyPlayed": "多次播放", @@ -416,7 +408,6 @@ "HeaderSubtitleProfiles": "字幕配置", "HeaderSubtitleProfilesHelp": "字幕配置文件描述设备所支持的字幕格式。", "HeaderSystemDlnaProfiles": "系统配置", - "HeaderTags": "标签", "HeaderTaskTriggers": "任务触发条件", "HeaderThisUserIsCurrentlyDisabled": "此用户当前已禁用", "HeaderTracks": "音轨", @@ -469,7 +460,6 @@ "LabelAlbumArtMaxWidthHelp": "通过UPnP显示的专辑封面超链接的最大分辨率。", "LabelAlbumArtPN": "专辑封面PN:", "LabelAlbumArtists": "专辑作家:", - "LabelAll": "所有", "LabelAllowHWTranscoding": "允许硬件转码", "LabelAllowedRemoteAddresses": "远程IP地址过滤器:", "LabelAllowedRemoteAddressesMode": "远程IP地址过滤器模式:", @@ -1167,7 +1157,6 @@ "TabAdvanced": "高级", "TabAlbumArtists": "专辑艺术家", "TabAlbums": "专辑", - "TabArtists": "艺术家", "TabCatalog": "目录", "TabChannels": "频道", "TabCodecs": "编解码器", @@ -1176,7 +1165,6 @@ "TabDashboard": "控制台", "TabDevices": "设备", "TabDirectPlay": "直接播放", - "TabDisplay": "显示", "TabEpisodes": "剧集", "TabFavorites": "我的最爱", "TabGenres": "风格", @@ -1185,7 +1173,6 @@ "TabLatest": "最新", "TabLiveTV": "电视直播", "TabLogs": "日志", - "TabMetadata": "元数据", "TabMovies": "电影", "TabMusic": "音乐", "TabMusicVideos": "音乐视频", @@ -1196,7 +1183,6 @@ "TabOther": "其他", "TabParentalControl": "家长控制", "TabPassword": "密码", - "TabPlayback": "播放", "TabPlaylists": "播放列表", "TabPlugins": "插件", "TabProfile": "个人配置", @@ -1211,9 +1197,7 @@ "TabShows": "节目", "TabSongs": "歌曲", "TabStreaming": "流媒体传输", - "TabSuggestions": "建议", "TabTrailers": "预告片", - "TabTranscoding": "转码", "TabUpcoming": "即将发布", "TabUsers": "用户", "Tags": "标签", @@ -1470,7 +1454,6 @@ "New": "新的", "HeaderFavoritePlaylists": "收藏的播放列表", "ButtonTogglePlaylist": "播放列表", - "ButtonToggleContextMenu": "更多", "HeaderServerAddressSettings": "服务器地址设置", "HeaderRemoteAccessSettings": "远程访问设置", "HeaderHttpsSettings": "HTTPS 设置", diff --git a/src/strings/zh-hk.json b/src/strings/zh-hk.json index 830ab8b400..661195d1d8 100644 --- a/src/strings/zh-hk.json +++ b/src/strings/zh-hk.json @@ -1,6 +1,5 @@ { "Add": "添加", - "ButtonAdd": "增加", "ButtonAddScheduledTaskTrigger": "新增觸發點", "ButtonAddUser": "添加用戶", "ButtonCancel": "取消", @@ -8,7 +7,6 @@ "ButtonDeleteImage": "刪除圖像", "ButtonEdit": "編輯", "ButtonFilter": "過濾", - "ButtonHelp": "幫助", "ButtonManualLogin": "手動登入", "ButtonNew": "新增", "ButtonOk": "確定", @@ -20,7 +18,6 @@ "ButtonRename": "重新命名", "ButtonResetPassword": "重設密碼", "ButtonRestart": "重新啟動", - "ButtonSave": "儲存", "ButtonSelectDirectory": "選擇目錄", "ButtonSignIn": "登入", "ButtonSignOut": "登出", @@ -57,7 +54,6 @@ "HeaderEasyPinCode": "簡易 Pin 碼", "HeaderFeatureAccess": "可以使用的功能", "HeaderFetchImages": "獲取圖像:", - "HeaderFilters": "篩選條件", "HeaderFrequentlyPlayed": "經常播放", "HeaderImageSettings": "圖像設置", "HeaderLatestEpisodes": "最新劇集", @@ -281,7 +277,6 @@ "TabAdvanced": "進階", "TabAlbumArtists": "唱片歌手", "TabAlbums": "專輯", - "TabArtists": "藝人", "TabCatalog": "目錄", "TabChannels": "頻道", "TabCollections": "藏品", @@ -293,7 +288,6 @@ "TabGuide": "指南", "TabInfo": "資訊", "TabLatest": "最新", - "TabMetadata": "媒體資料屬性", "TabMovies": "電影", "TabMusic": "音樂", "TabMusicVideos": "MV", @@ -310,9 +304,7 @@ "TabSettings": "設定", "TabShows": "節目", "TabSongs": "歌曲", - "TabSuggestions": "建議", "TabTrailers": "預告", - "TabTranscoding": "轉碼中", "TabUpcoming": "即將發佈", "TabUsers": "用戶", "TellUsAboutYourself": "介紹一下自己", @@ -432,7 +424,6 @@ "ButtonUninstall": "解除安裝", "ButtonTrailer": "預告", "ButtonTogglePlaylist": "播放清單", - "ButtonToggleContextMenu": "更多", "ButtonSplit": "分開", "ButtonStop": "停止", "ButtonStart": "開始", @@ -440,12 +431,10 @@ "ButtonSettings": "設定", "ButtonSend": "傳送", "ButtonSelectServer": "選擇伺服器", - "ButtonSearch": "搜尋", "ButtonScanAllLibraries": "掃瞄所有媒體櫃", "ButtonRevoke": "撤銷", "ButtonResume": "恢復", "ButtonResetEasyPassword": "重設PIN碼", - "ButtonRepeat": "重複", "ButtonProfile": "檔案", "ButtonPause": "暫停", "ButtonParentalControl": "家長控制", diff --git a/src/strings/zh-tw.json b/src/strings/zh-tw.json index 086d163240..8c8451ea10 100644 --- a/src/strings/zh-tw.json +++ b/src/strings/zh-tw.json @@ -4,7 +4,6 @@ "AllowRemoteAccessHelp": "如果未勾選,所有連線都將被阻擋。", "Browse": "瀏覽", "MessageBrowsePluginCatalog": "瀏覽我們的模組目錄來查看可用的模組。", - "ButtonAdd": "新增", "ButtonAddServer": "新增伺服器", "ButtonAddUser": "新增使用者", "ButtonCancel": "取消", @@ -25,8 +24,6 @@ "ButtonRefreshGuideData": "更新電視節目表", "ButtonRemove": "清除", "ButtonResetPassword": "重設密碼", - "ButtonSave": "保存", - "ButtonSearch": "搜尋", "ButtonSelectDirectory": "選擇目錄", "ButtonSelectServer": "選擇伺服器", "ButtonSignIn": "登入", @@ -252,7 +249,6 @@ "TabAdvanced": "進階", "TabAlbumArtists": "專輯歌手", "TabAlbums": "專輯", - "TabArtists": "歌手", "TabCatalog": "目錄", "TabChannels": "頻道", "TabEpisodes": "單元", @@ -261,7 +257,6 @@ "TabInfo": "資訊", "TabLatest": "最新", "TabLiveTV": "電視", - "TabMetadata": "媒體資料", "TabMovies": "電影", "TabMusic": "音樂", "TabMyPlugins": "我的插件", @@ -275,9 +270,7 @@ "TabSettings": "設定", "TabShows": "節目", "TabSongs": "歌曲", - "TabSuggestions": "建議", "TabTrailers": "預告", - "TabTranscoding": "轉碼中", "TabUpcoming": "接下來", "TellUsAboutYourself": "介紹一下自己", "ThisWizardWillGuideYou": "此精靈將帶你完成安裝過程,開始之前,請選擇您慣用的語言。", @@ -352,7 +345,6 @@ "ButtonDownload": "下載", "ButtonEditOtherUserPreferences": "編輯使用者個人檔案、大頭貼和個人設定。", "ButtonFullscreen": "全螢幕", - "ButtonHelp": "幫助", "ButtonInfo": "詳細資料", "ButtonLibraryAccess": "媒體庫存取", "ButtonManualLogin": "手動登入", @@ -366,7 +358,6 @@ "ButtonPreviousTrack": "上一首", "ButtonProfile": "個人首頁", "ButtonRename": "重新命名", - "ButtonRepeat": "重覆播放", "ButtonResetEasyPassword": "重設簡單 PIN 碼", "ButtonRestart": "重新啟動", "ButtonResume": "繼續播放", @@ -552,7 +543,6 @@ "HeaderDevices": "裝置", "HeaderDirectPlayProfile": "直接播放設定檔", "HeaderDirectPlayProfileHelp": "新增直接播放設定檔,標明哪些媒體格式設備可以自己處理。", - "HeaderDisplay": "顯示", "HeaderDownloadSync": "下載與同步", "HeaderEditImages": "編輯圖片", "HeaderEnabledFields": "已啟用的欄位", @@ -568,9 +558,7 @@ "HeaderFavoriteShows": "最愛節目", "HeaderFavoriteSongs": "最愛歌曲", "HeaderFavoriteVideos": "最愛的影片", - "HeaderFeatures": "功能", "HeaderFetcherSettings": "擷取器設置", - "HeaderFilters": "篩選條件", "HeaderForKids": "給兒童", "HeaderGenres": "類型", "HeaderHttpHeaders": "HTTP 標頭", @@ -645,7 +633,6 @@ "HeaderStopRecording": "停止錄影", "HeaderSubtitleAppearance": "字幕外觀", "HeaderSubtitleDownloads": "字幕下載", - "HeaderTags": "標籤", "HeaderThisUserIsCurrentlyDisabled": "這個使用者目前停用", "HeaderTracks": "軌", "HeaderTunerDevices": "調諧器裝置", @@ -718,7 +705,6 @@ "LabelAlbumArtMaxWidthHelp": "通過 upnp:albumArtURI 顯示的專輯封面超鏈接的最大解析度。", "LabelAlbumArtPN": "專輯封面 PN :", "LabelAlbumArtists": "專輯作家:", - "LabelAll": "所有", "LabelAllowHWTranscoding": "允許硬體轉碼", "LabelAllowedRemoteAddresses": "遠端 IP 過濾:", "LabelAllowedRemoteAddressesMode": "遠端 IP 過濾模式:", @@ -1029,7 +1015,6 @@ "TabCodecs": "編碼", "TabContainers": "影片容器", "TabDashboard": "控制台", - "TabDisplay": "顯示", "TabFavorites": "最愛", "TabLogs": "日誌", "TabNotifications": "通知", @@ -1095,7 +1080,6 @@ "RecommendationStarring": "主演 {0}", "Rewind": "倒帶", "SubtitleOffset": "字幕偏移", - "TabPlayback": "播放", "Unrated": "尚未評等", "Up": "上", "ValueOneSeries": "1 劇集", @@ -1471,7 +1455,6 @@ "New": "新增", "ApiKeysCaption": "目前已啟用的API金鑰列表", "ButtonTogglePlaylist": "播放清單", - "ButtonToggleContextMenu": "更多", "ButtonSyncPlay": "SyncPlay", "LabelRequireHttpsHelp": "開啟後伺服器將自動將所有 HTTP 請求導向 HTTPS。如果伺服器沒有啟用 HTTPS 則不生效。", "EnableFasterAnimationsHelp": "使用更快的動畫與過渡效果", From 7d066a6fcfd8c645b5e9530309b9cb57004279ec Mon Sep 17 00:00:00 2001 From: Thomas Schwery Date: Sun, 9 Aug 2020 10:10:50 +0000 Subject: [PATCH 128/301] Translated using Weblate (French) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/fr/ --- src/strings/fr.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/src/strings/fr.json b/src/strings/fr.json index 20b96f3a52..e66cdc0edc 100644 --- a/src/strings/fr.json +++ b/src/strings/fr.json @@ -1545,5 +1545,7 @@ "LabelUnstable": "Instable", "Preview": "Aperçu", "SubtitleVerticalPositionHelp": "Numéro de ligne où le texte apparaît. Un nombre positif compte les lignes de haut en bas. Un nombre négatif, de bas en haut.", - "LabelSubtitleVerticalPosition": "Position verticale :" + "LabelSubtitleVerticalPosition": "Position verticale :", + "MessageGetInstalledPluginsError": "Une erreur est survenue lors de la récupération de la liste des extensions installées.", + "MessagePluginInstallError": "Une erreur est survenue durant l'installation de l'extension." } From 475cc0e2532183e58466686f02f7e79e4bf1b39b Mon Sep 17 00:00:00 2001 From: "dependabot-preview[bot]" <27856297+dependabot-preview[bot]@users.noreply.github.com> Date: Sun, 9 Aug 2020 14:26:26 +0000 Subject: [PATCH 129/301] Bump @babel/eslint-plugin from 7.11.0 to 7.11.3 Bumps [@babel/eslint-plugin](https://github.com/babel/babel/tree/HEAD/eslint/babel-eslint-plugin) from 7.11.0 to 7.11.3. - [Release notes](https://github.com/babel/babel/releases) - [Changelog](https://github.com/babel/babel/blob/main/CHANGELOG.md) - [Commits](https://github.com/babel/babel/commits/v7.11.3/eslint/babel-eslint-plugin) Signed-off-by: dependabot-preview[bot] --- package.json | 2 +- yarn.lock | 8 ++++---- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/package.json b/package.json index 508fbd1307..fa27f5b951 100644 --- a/package.json +++ b/package.json @@ -7,7 +7,7 @@ "devDependencies": { "@babel/core": "^7.11.1", "@babel/eslint-parser": "^7.11.3", - "@babel/eslint-plugin": "^7.11.0", + "@babel/eslint-plugin": "^7.11.3", "@babel/plugin-proposal-class-properties": "^7.10.1", "@babel/plugin-proposal-private-methods": "^7.10.1", "@babel/plugin-transform-modules-amd": "^7.10.5", diff --git a/yarn.lock b/yarn.lock index 4518e7af51..269b3b93cd 100644 --- a/yarn.lock +++ b/yarn.lock @@ -49,10 +49,10 @@ eslint-visitor-keys "^1.3.0" semver "^6.3.0" -"@babel/eslint-plugin@^7.11.0": - version "7.11.0" - resolved "https://registry.yarnpkg.com/@babel/eslint-plugin/-/eslint-plugin-7.11.0.tgz#55d5b6bd29859cabce152f16d01b3a8150d5b295" - integrity sha512-+gfPM0/T6d25jKBgmxWp38W0jqRs16Vt7DPBxGOcnN/7nS2A/6QoaXOYEaccvWS5a9UpWlMIAylivp6UtH8/sQ== +"@babel/eslint-plugin@^7.11.3": + version "7.11.3" + resolved "https://registry.yarnpkg.com/@babel/eslint-plugin/-/eslint-plugin-7.11.3.tgz#66b531f90592f8f0621d072b59ea2c37c91e8d0d" + integrity sha512-gmi3lgaWlYpNb+h7qPfv5GVz2ZVwzCDyV+kAGj+3il+Mv5uan5Yccvdw7m14UAAY2tdTbB0VgRF6ZLjUbrUm0g== dependencies: eslint-rule-composer "^0.3.0" From 988173fffc5e750e03a8c5b8e7199c787430b877 Mon Sep 17 00:00:00 2001 From: Felipe Date: Mon, 10 Aug 2020 01:25:23 +0000 Subject: [PATCH 130/301] Translated using Weblate (Spanish (Latin America)) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/es_419/ --- src/strings/es_419.json | 50 +++++++++++++++++++++-------------------- 1 file changed, 26 insertions(+), 24 deletions(-) diff --git a/src/strings/es_419.json b/src/strings/es_419.json index 54dd68e9ed..94a4db6aa2 100644 --- a/src/strings/es_419.json +++ b/src/strings/es_419.json @@ -183,7 +183,7 @@ "OptionPlayCount": "Contador de reproducciones", "OptionPlainVideoItemsHelp": "Si se habilita, todos los videos serán representados en DIDL como «object.item.videoItem» en lugar de un tipo más específico, como «object.item.videoItem.movie».", "OptionPlainVideoItems": "Mostrar todos los videos como elementos de video simples", - "OptionPlainStorageFoldersHelp": "Si se habilita, todos las carpetas serán representadas en DIDL como «object.container.storageFolder» en lugar de un tipo más específico, como «object.container.person.musicArtist».", + "OptionPlainStorageFoldersHelp": "Todos las carpetas serán representadas en DIDL como «object.container.storageFolder» en lugar de un tipo más específico, como «object.container.person.musicArtist».", "OptionPlainStorageFolders": "Mostrar todas las carpetas como carpetas de almacenamiento simples", "OptionParentalRating": "Clasificación parental", "OptionOnInterval": "En un intervalo", @@ -201,7 +201,7 @@ "OptionIsSD": "SD", "OptionIsHD": "HD", "OptionImdbRating": "Calificación de IMDb", - "OptionIgnoreTranscodeByteRangeRequestsHelp": "Si se habilita, estas solicitudes serán honradas pero se ignorará el encabezado de rango de bytes.", + "OptionIgnoreTranscodeByteRangeRequestsHelp": "Estas solicitudes serán consideradas pero se ignorará el encabezado de rango de bytes.", "OptionIgnoreTranscodeByteRangeRequests": "Ignorar solicitudes de transcodificación de rango de bytes", "OptionHomeVideos": "Fotos", "OptionHlsSegmentedSubtitles": "Subtítulos segmentados HLS", @@ -234,7 +234,7 @@ "OptionDownloadPrimaryImage": "Principal", "OptionDownloadMenuImage": "Menú", "OptionDownloadLogoImage": "Logo", - "OptionDownloadImagesInAdvanceHelp": "Por defecto, la mayoría de las imágenes solo son descargadas cuando son solicitadas por una aplicación Jellyfin. Habilita esta opción para descargar todas las imágenes por adelantado, a medida que se agreguen nuevos medios. Esto podría causar escaneos de bibliotecas significativamente más largos.", + "OptionDownloadImagesInAdvanceHelp": "Por defecto, la mayoría de las imágenes se descargan cuando son solicitadas por un cliente. Habilita esta opción para descargarlas todas por por adelantado a medida que se agreguen nuevos medios. Esto podría causar que los escaneos de bibliotecas sean significativamente más largos.", "OptionDownloadImagesInAdvance": "Descargar las imágenes con antelación", "OptionDownloadDiscImage": "Disco", "OptionDownloadBoxImage": "Caja", @@ -244,7 +244,7 @@ "OptionDisplayFolderViewHelp": "Muestra las carpetas junto con sus otras bibliotecas de medios. Esto puede ser útil si deseas tener una vista simple de carpeta.", "OptionDisplayFolderView": "Mostrar una vista de carpetas para mostrar las carpetas simples de los medios", "OptionDislikes": "No me gusta", - "OptionDisableUserHelp": "Si se desactiva, el servidor no aceptará conexiones de este usuario. Las conexiones existentes serán finalizadas abruptamente.", + "OptionDisableUserHelp": "El servidor no aceptará conexiones de este usuario. Las conexiones existentes serán finalizadas abruptamente.", "OptionDisableUser": "Desactivar este usuario", "OptionDescending": "Descendente", "OptionDatePlayed": "Fecha de reproducción", @@ -263,7 +263,7 @@ "OptionBlockChannelContent": "Contenido de canales de Internet", "OptionBlockBooks": "Libros", "OptionBanner": "Banner", - "OptionAutomaticallyGroupSeriesHelp": "Si se habilita, las series que se reparten a través de múltiples carpetas dentro de esta biblioteca serán fusionadas en una sola serie.", + "OptionAutomaticallyGroupSeriesHelp": "Series que estén repartidas en múltiples carpetas dentro de esta biblioteca serán fusionadas en una sola serie.", "OptionAutomaticallyGroupSeries": "Fusionar automáticamente series esparcidas a través de múltiples carpetas", "OptionAutomatic": "Automático", "OptionAuto": "Automático", @@ -276,7 +276,7 @@ "OptionAllowRemoteSharedDevicesHelp": "Los dispositivos DLNA se considerarán compartidos hasta que un usuario comience a controlarlos.", "OptionAllowRemoteSharedDevices": "Permitir control remoto de dispositivos compartidos", "OptionAllowRemoteControlOthers": "Permitir control remoto de otros usuarios", - "OptionAllowMediaPlaybackTranscodingHelp": "Restringir el acceso a la transcodificación podría causar fallas en la reproducción en las aplicaciones Jellyfin debido a los formatos de medios no soportados.", + "OptionAllowMediaPlaybackTranscodingHelp": "Restringir el acceso a la transcodificación podría causar fallas en reproducción en las aplicaciones debido a formatos de medios no soportados.", "OptionAllowMediaPlayback": "Permitir reproducción de medios", "OptionAllowManageLiveTv": "Permitir gestión de grabación de TV en vivo", "OptionAllowLinkSharingHelp": "Solo son compartidas páginas web que contienen información sobre los medios. Los archivos de medios nunca son compartidos públicamente. Los compartidos tienen un límite de tiempo y expirarán después de {0} días.", @@ -333,7 +333,7 @@ "Mobile": "Móvil", "MinutesBefore": "minutos antes", "MinutesAfter": "minutos después", - "MetadataSettingChangeHelp": "Cambiar la configuración de los metadatos afectará al nuevo contenido que se añada en el futuro. Para actualizar el contenido existente, abre la pantalla de detalles y haz clic en el botón actualizar, o realiza actualizaciones masivas usando el administrador de metadatos.", + "MetadataSettingChangeHelp": "Cambiar la configuración de los metadatos afectará al nuevo contenido que se añada en el futuro. Para actualizar el contenido existente, abre la pantalla de detalles y haz clic en el botón actualizar, o haz actualizaciones masivas usando el administrador de metadatos.", "MetadataManager": "Administrador de metadatos", "Metadata": "Metadatos", "MessageSyncPlayErrorMedia": "¡Fallo al activar SyncPlay! Error en el archivo de medios.", @@ -392,7 +392,7 @@ "LatestFromLibrary": "Últimas - {0}", "Large": "Grande", "LanNetworksHelp": "Lista separada por comas de direcciones IP o entradas de IP/máscara de red para las redes que se considerarán en la red local al aplicar las restricciones de ancho de banda. Si se establecen, todas las demás direcciones IP se considerarán como parte de la red externa y estarán sujetas a las restricciones de ancho de banda externa. Si se deja en blanco, solo se considera a la subred del servidor estar en la red local.", - "LabelffmpegPathHelp": "La ruta hacia el archivo de la aplicación ffmpeg, o la carpeta que contenga ffmpeg.", + "LabelffmpegPathHelp": "La ruta hacia el archivo ejecutable ffmpeg, o la carpeta que contenga ffmpeg.", "LabelffmpegPath": "Ruta del FFmpeg:", "LabelZipCode": "Código postal:", "LabelYoureDone": "¡Has terminado!", @@ -664,7 +664,7 @@ "LabelServerName": "Nombre del servidor:", "LabelServerHostHelp": "192.168.1.100:8096 o https://miservidor.com", "LabelServerHost": "Servidor:", - "LabelSeriesRecordingPath": "Ruta para las grabaciones de series (opcional):", + "LabelSeriesRecordingPath": "Ruta para las grabaciones de series:", "LabelSerialNumber": "Número de serie", "LabelSendNotificationToUsers": "Enviar la notificación a:", "LabelSelectVersionToInstall": "Seleccionar versión a instalar:", @@ -676,7 +676,7 @@ "LabelScheduledTaskLastRan": "Última ejecución {0}, tomando {1}.", "LabelSaveLocalMetadataHelp": "Guardar ilustraciones en las carpetas de los medios los colocará en un lugar donde se pueden editar fácilmente.", "LabelSaveLocalMetadata": "Guardar las ilustraciones en las carpetas de los medios", - "LabelRuntimeMinutes": "Duración (minutos):", + "LabelRuntimeMinutes": "Duración:", "LabelRequireHttpsHelp": "Si se marca, el servidor redirigirá automáticamente todas las solicitudes a través de HTTP a HTTPS. Esto no tiene efecto si el servidor no está escuchando en HTTPS.", "LabelRequireHttps": "Requerir HTTPS", "LabelRemoteClientBitrateLimitHelp": "Un límite opcional de velocidad de bits por transmisión para todos los dispositivos fuera de la red. Esto es útil para evitar que los dispositivos soliciten una tasa de bits más alta de la que puede manejar tu conexión a Internet. Esto puede provocar un aumento de la carga de la CPU en el servidor para transcodificar los videos sobre la marcha a una velocidad de bits inferior.", @@ -728,7 +728,7 @@ "LabelOriginalTitle": "Título original:", "LabelOriginalAspectRatio": "Relación de aspecto original:", "LabelOptionalNetworkPathHelp": "Si esta carpeta es compartida en su red, proveer la ruta del recurso compartido de red puede permitir a las aplicaciones Jellyfin en otros dispositivos acceder a los archivos de medios directamente. Por ejemplo, {0} o {1}.", - "LabelOptionalNetworkPath": "(Opcional) Carpeta de red compartida:", + "LabelOptionalNetworkPath": "Carpeta de red compartida:", "LabelNumberOfGuideDaysHelp": "Descargar más días de datos de programación permite programar con mayor anticipación y ver más listados, pero tomará más tiempo en descargar. Auto hará la selección basada en el número de canales.", "LabelNumberOfGuideDays": "Número de días de datos de la programación a descargar:", "LabelNumber": "Número:", @@ -741,9 +741,9 @@ "LabelStable": "Estable", "LabelChromecastVersion": "Versión de Chromecast", "LabelName": "Nombre:", - "LabelMusicStreamingTranscodingBitrateHelp": "Especifica la velocidad de bits máxima al transmitir música.", + "LabelMusicStreamingTranscodingBitrateHelp": "Especifica la máxima velocidad de bits al transmitir música.", "LabelMusicStreamingTranscodingBitrate": "Velocidad de bits de transcodificación de música:", - "LabelMovieRecordingPath": "Ruta para las grabaciones de películas (opcional):", + "LabelMovieRecordingPath": "Ruta para las grabaciones de películas:", "LabelMoviePrefixHelp": "Si un prefijo es aplicado al título de las películas, introdúcelo aquí para que el servidor pueda manejarlo correctamente.", "LabelMoviePrefix": "Prefijo de la película:", "LabelMovieCategories": "Categorías de películas:", @@ -941,11 +941,11 @@ "LabelBurnSubtitles": "Quemar subtítulos:", "LabelBlockContentWithTags": "Bloquear elementos con las etiquetas:", "LabelBlastMessageIntervalHelp": "Determina la duración en segundos del intervalo entre mensajes de vida.", - "LabelBlastMessageInterval": "Intervalo de mensajes de vida (segundos)", + "LabelBlastMessageInterval": "Intervalo de mensajes de vida", "LabelBitrate": "Velocidad de bits:", "LabelBirthYear": "Año de nacimiento:", "LabelBirthDate": "Fecha de nacimiento:", - "LabelBindToLocalNetworkAddressHelp": "Opcional. Sobrescribe la dirección IP local a la que se vincula el servidor http. Si se deja vacío, el servidor se vinculará a todas las direcciones disponibles. Cambiar este valor requiere reiniciar el servidor Jellyfin.", + "LabelBindToLocalNetworkAddressHelp": "Sobrescribe la dirección IP local del servidor HTTP. Si se deja vacío, el servidor se vinculará a todas las direcciones disponibles. Para cambiar este valor se necesita reiniciar el servidor.", "LabelBindToLocalNetworkAddress": "Vincular a la dirección de red local:", "LabelAutomaticallyRefreshInternetMetadataEvery": "Actualizar automáticamente los metadatos desde Internet:", "LabelAuthProvider": "Proveedor de autenticación:", @@ -956,7 +956,7 @@ "LabelAudioBitrate": "Velocidad de bits de audio:", "LabelAudioBitDepth": "Profundidad de bits de audio:", "LabelAudio": "Audio", - "LabelArtistsHelp": "Separar múltiples empleando ;", + "LabelArtistsHelp": "Separar múltiples artistas por punto y coma.", "LabelArtists": "Artistas:", "LabelAppNameExample": "Ejemplo: Sickbeard, Sonarr", "LabelAppName": "Nombre de la aplicación", @@ -987,8 +987,8 @@ "ItemCount": "{0} elementos", "InstantMix": "Mix instantáneo", "InstallingPackage": "Instalando {0} (versión {1})", - "ImportMissingEpisodesHelp": "Si se habilita, la información sobre los episodios faltantes se importará a la base de datos de Jellyfin y se mostrarán dentro de las temporadas y series. Esto puede causar escaneos de biblioteca significativamente más largos.", - "ImportFavoriteChannelsHelp": "Si se habilita, solo los canales marcados como favoritos en el dispositivo sintonizador serán importados.", + "ImportMissingEpisodesHelp": "La información sobre los episodios faltantes se importará a la base de datos y se mostrarán dentro de las temporadas y series. Esto puede causar escaneos de biblioteca significativamente más largos.", + "ImportFavoriteChannelsHelp": "Solo los canales marcados como favoritos en el dispositivo sintonizador serán importados.", "Images": "Imágenes", "Identify": "Identificar", "HttpsRequiresCert": "Para habilitar las conexiones seguras, necesitarás proporcionar un certificado SSL de confianza, como el de Let's Encrypt. Por favor, proporciona un certificado o desactiva las conexiones seguras.", @@ -1041,7 +1041,7 @@ "HeaderSelectServerCachePath": "Seleccionar ruta para la caché del servidor", "HeaderSelectServer": "Seleccionar servidor", "HeaderSelectPath": "Seleccionar ruta", - "HeaderSelectMetadataPathHelp": "Explora o introduce la ruta donde deseas almacenar los metadatos. Se debe tener permisos de escritura en dicha carpeta.", + "HeaderSelectMetadataPathHelp": "Explora o escribe la ruta donde deseas guardar los metadatos. Se tienen que tener permisos de escritura en esa carpeta.", "HeaderSelectMetadataPath": "Selecciona la ruta para los metadatos", "HeaderSelectCertificatePath": "Selecciona la ruta del certificado", "HeaderSecondsValue": "{0} segundos", @@ -1060,7 +1060,7 @@ "HeaderRecordingPostProcessing": "Post procesado de las grabaciones", "HeaderRecordingOptions": "Opciones de grabación", "HeaderRecentlyPlayed": "Reproducido recientemente", - "HeaderProfileServerSettingsHelp": "Estos valores controlan como el servidor Jellyfin se presentará al dispositivo.", + "HeaderProfileServerSettingsHelp": "Estos valores controlan cómo el servidor se presentará a los clientes.", "HeaderProfileInformation": "Información del perfil", "HeaderProfile": "Perfil", "HeaderPreferredMetadataLanguage": "Idioma preferido para los metadatos", @@ -1108,7 +1108,7 @@ "HeaderLatestMovies": "Últimas películas", "HeaderLatestMedia": "Últimos medios", "HeaderLatestEpisodes": "Últimos episodios", - "HeaderKodiMetadataHelp": "Para habilitar o deshabilitar los metadatos NFO, edite una biblioteca en la configuración de bibliotecas de Jellyfin y ubica la sección grabadores de metadatos.", + "HeaderKodiMetadataHelp": "Para habilitar o deshabilitar los metadatos NFO, edita una biblioteca y ubica la sección de grabadores de metadatos.", "HeaderKeepSeries": "Conservar serie", "HeaderKeepRecording": "Conservar grabación", "HeaderItems": "Elementos", @@ -1226,7 +1226,7 @@ "HeaderAppearsOn": "Aparece en", "HeaderApp": "Aplicación", "ApiKeysCaption": "Lista de claves API actualmente habilitadas", - "HeaderApiKeysHelp": "Las aplicaciones externas deben tener una clave API para poder comunicarse con el servidor Jellyfin. Las claves se emiten al iniciar sesión con una cuenta Jellyfin, o al otorgar manualmente una clave a la aplicación.", + "HeaderApiKeysHelp": "Las aplicaciones externas deben tener una clave API para poder comunicarse con el servidor. Las claves se emiten al iniciar sesión con una cuenta de usuario, o al otorgar manualmente una clave a la aplicación.", "HeaderApiKeys": "Claves API", "HeaderApiKey": "Clave API", "HeaderAllowMediaDeletionFrom": "Permitir eliminación de medios de", @@ -1372,7 +1372,7 @@ "HeaderSeriesOptions": "Opciones de serie", "HeaderSeries": "Series", "HeaderSendMessage": "Enviar mensaje", - "HeaderSelectTranscodingPathHelp": "Explora o introduce la ruta a utilizar para los archivos temporales de transcodificación. Se debe tener permisos de escritura en dicha carpeta.", + "HeaderSelectTranscodingPathHelp": "Explora o escribe la ruta para los archivos de transcodificación. Se tienen que tener permisos de escritura en esa carpeta.", "HeaderSelectTranscodingPath": "Selecciona la ruta para los archivos temporales de transcodificación", "ConfirmDeleteItems": "Eliminar estos elementos los eliminará tanto del sistema como de tu biblioteca de medios. ¿Estás seguro de querer continuar?", "ConfirmDeleteItem": "Eliminar este elemento lo eliminará tanto del sistema como de tu biblioteca de medios. ¿Estás seguro de querer continuar?", @@ -1539,5 +1539,7 @@ "ButtonCast": "Emitir", "Writers": "Escritores", "ViewAlbumArtist": "Ver Álbum de Artista", - "TabRepositories": "Repositorios" + "TabRepositories": "Repositorios", + "NextTrack": "Saltar al siguiente", + "LabelUnstable": "Inestable" } From 8121cf69b8c71fb7f2eda51b225ad89f0cb87293 Mon Sep 17 00:00:00 2001 From: Felipe Date: Mon, 10 Aug 2020 01:48:27 +0000 Subject: [PATCH 131/301] Translated using Weblate (Spanish (Latin America)) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/es_419/ --- src/strings/es_419.json | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-) diff --git a/src/strings/es_419.json b/src/strings/es_419.json index 94a4db6aa2..b1cc402d38 100644 --- a/src/strings/es_419.json +++ b/src/strings/es_419.json @@ -181,7 +181,7 @@ "OptionPoster": "Póster", "OptionPlayed": "Reproducido", "OptionPlayCount": "Contador de reproducciones", - "OptionPlainVideoItemsHelp": "Si se habilita, todos los videos serán representados en DIDL como «object.item.videoItem» en lugar de un tipo más específico, como «object.item.videoItem.movie».", + "OptionPlainVideoItemsHelp": "Todos los videos serán representados en DIDL como «object.item.videoItem» en vez de un tipo más específico, como «object.item.videoItem.movie».", "OptionPlainVideoItems": "Mostrar todos los videos como elementos de video simples", "OptionPlainStorageFoldersHelp": "Todos las carpetas serán representadas en DIDL como «object.container.storageFolder» en lugar de un tipo más específico, como «object.container.person.musicArtist».", "OptionPlainStorageFolders": "Mostrar todas las carpetas como carpetas de almacenamiento simples", @@ -563,7 +563,7 @@ "ReleaseDate": "Fecha de estreno", "RefreshQueued": "Actualización puesta en la cola.", "RefreshMetadata": "Actualizar metadatos", - "RefreshDialogHelp": "Los metadatos son actualizados basándose en las configuraciones y servicios de Internet que estén activados en el panel de control de tu servidor Jellyfin.", + "RefreshDialogHelp": "Los metadatos se actualizan según las configuraciones y servicios de internet que se habilitan en el panel de control.", "Refresh": "Actualizar", "Recordings": "Grabaciones", "RecordingScheduled": "Grabación programada.", @@ -1541,5 +1541,11 @@ "ViewAlbumArtist": "Ver Álbum de Artista", "TabRepositories": "Repositorios", "NextTrack": "Saltar al siguiente", - "LabelUnstable": "Inestable" + "LabelUnstable": "Inestable", + "Preview": "Vista previa", + "SubtitleVerticalPositionHelp": "Número de línea donde aparece el texto. Números positivos representan de arriba hacia abajo. Números negativos representan de abajo hacia arriba.", + "LabelSubtitleVerticalPosition": "Posición Vertical:", + "PreviousTrack": "Saltar al anterior", + "MessageGetInstalledPluginsError": "Ocurrió un error buscando la lista de plugins instalados.", + "MessagePluginInstallError": "Ocurrió un error instalando el plugin." } From 5d92a37134360c643aa6c7c29fcec4bca3afa519 Mon Sep 17 00:00:00 2001 From: Felipe Date: Mon, 10 Aug 2020 02:07:24 +0000 Subject: [PATCH 132/301] Translated using Weblate (Spanish (Latin America)) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/es_419/ --- src/strings/es_419.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/strings/es_419.json b/src/strings/es_419.json index b1cc402d38..022d2c8635 100644 --- a/src/strings/es_419.json +++ b/src/strings/es_419.json @@ -1485,7 +1485,7 @@ "Backdrops": "Imágenes de fondo", "Backdrop": "Imagen de fondo", "Auto": "Auto", - "AuthProviderHelp": "Selecciona un proveedor de autenticación que se utilizará para autenticar la contraseña de este usuario.", + "AuthProviderHelp": "Selecciona el proveedor de autenticación que se utilizará para autenticar la contraseña de este usuario.", "Audio": "Audio", "AttributeNew": "Nuevo", "AspectRatio": "Relación de aspecto", From c37a59f02b7b002bc46b4991fd1a060e289a2c62 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Juan=20Rodr=C3=ADguez?= Date: Mon, 10 Aug 2020 07:50:49 +0000 Subject: [PATCH 133/301] Translated using Weblate (Spanish) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/es/ --- src/strings/es.json | 24 +++++++++++++++--------- 1 file changed, 15 insertions(+), 9 deletions(-) diff --git a/src/strings/es.json b/src/strings/es.json index d720b515f4..7361015235 100644 --- a/src/strings/es.json +++ b/src/strings/es.json @@ -231,7 +231,7 @@ "HeaderAllowMediaDeletionFrom": "Permitir borrar contenido desde", "HeaderApiKey": "Clave API", "HeaderApiKeys": "Claves API", - "HeaderApiKeysHelp": "Las aplicaciones externas requieren de una clave API para comunicarse con el servidor Jellyfin. Las claves se facilitan iniciando sesión con una cuenta de Jellyfin, u otorgando manualmente una clave a la aplicación.", + "HeaderApiKeysHelp": "Las aplicaciones externas requieren de una clave API para comunicarse con el servidor. Las claves se facilitan iniciando sesión con una cuenta de usuario en Jellyfin, u otorgando manualmente una clave a la aplicación.", "HeaderAudioBooks": "Audiolibros", "HeaderAudioSettings": "Ajustes de audio", "HeaderBlockItemsWithNoRating": "Bloquear artículos sin valoraciones o si son desconocidas:", @@ -346,7 +346,7 @@ "HeaderPreferredMetadataLanguage": "Idioma preferido para las etiquetas", "HeaderProfile": "Perfil", "HeaderProfileInformation": "Información del perfil", - "HeaderProfileServerSettingsHelp": "Estos valores controlan como el servidor Jellyfin se presenta al dispositivo.", + "HeaderProfileServerSettingsHelp": "Estos valores controlan cómo el servidor será presentado a los clientes.", "HeaderRecentlyPlayed": "Reproducido recientemente", "HeaderRecordingOptions": "Ajustes de grabación", "HeaderRecordingPostProcessing": "Grabación post procesamiento", @@ -370,7 +370,7 @@ "HeaderSelectServerCachePath": "Seleccione la ruta para el caché del servidor", "HeaderSelectServerCachePathHelp": "Navega o introduce la ruta para alojar los archivos caché del servidor. Tienes que tener permisos de escritura en esa carpeta.", "HeaderSelectTranscodingPath": "Ruta para los archivos temporales de las conversiones", - "HeaderSelectTranscodingPathHelp": "Busca o escribe la ruta que se utilizará para guardar los archivos temporales que se generarán mientras se convierten los archivos. Jellyfin debe tener permisos de escritura en la carpeta.", + "HeaderSelectTranscodingPathHelp": "Busca o escribe la ruta que se utilizará para guardar los archivos que se generarán mientras se convierten los archivos. Jellyfin debe tener permisos de escritura en la carpeta.", "HeaderSendMessage": "Enviar mensaje", "HeaderSeries": "Series", "HeaderSeriesOptions": "Opciones de series", @@ -417,8 +417,8 @@ "HttpsRequiresCert": "Para activar la conexión segura, necesitas un certificado SSL de confianza, como Let's Encrypt. De lo contrario, desactive las conexiones seguras.", "Identify": "Identificar", "Images": "Imágenes", - "ImportFavoriteChannelsHelp": "Si está activado, sólo los canales guardados como favoritos en el sintonizador se importarán.", - "ImportMissingEpisodesHelp": "Si está activada, la información sobre los episodios que faltan se importará en su base de datos Jellyfin y se mostrará en temporadas y series. Esto puede causar exploraciones de bibliotecas significativamente más largas.", + "ImportFavoriteChannelsHelp": "Sólo los canales guardados como favoritos en el sintonizador se importarán.", + "ImportMissingEpisodesHelp": "La información sobre los episodios que faltan se importará en su base de datos y se mostrará en temporadas y series. Esto puede causar exploraciones de bibliotecas significativamente más largas.", "InstallingPackage": "Instalando {0} (versión {1})", "InstantMix": "Mix instantáneo", "ItemCount": "Elementos {0}", @@ -449,11 +449,11 @@ "LabelAppName": "Nombre de la aplicación", "LabelAppNameExample": "Ejemplo: Sickbeard, Sonarr", "LabelArtists": "Artistas:", - "LabelArtistsHelp": "Separar múltiples artistas usando ;", + "LabelArtistsHelp": "Separar múltiples artistas utilizando punto y coma.", "LabelAudioLanguagePreference": "Idioma de audio preferido:", "LabelAutomaticallyRefreshInternetMetadataEvery": "Actualizar las etiquetas automáticamente desde Internet:", "LabelBindToLocalNetworkAddress": "Vincular a la dirección de red local:", - "LabelBindToLocalNetworkAddressHelp": "Opcional. Anule la dirección IP local para enlazar el servidor HTTP. Si se deja vacío, el servidor se enlazará a todas las direcciones disponibles. Para cambiar este valor, debe reiniciar el servidor Jellyfin.", + "LabelBindToLocalNetworkAddressHelp": "Anule la dirección IP local para enlazar el servidor HTTP. Si se deja vacío, el servidor se enlazará a todas las direcciones disponibles. Para cambiar este valor, debe reiniciar el servidor Jellyfin.", "LabelBirthDate": "Fecha de nacimiento:", "LabelBirthYear": "Año de nacimiento:", "LabelBlastMessageInterval": "Intervalo para mensajes en vivo (segundos)", @@ -1228,7 +1228,7 @@ "DatePlayed": "Reproducido el", "Descending": "Descendiente", "DirectStreamHelp1": "El tipo de archivo (H.264, AC3, etc.) y la resolución son compatibles con el dispositivo, pero no el contenedor (mkv, avi, wmv, etc.). El vídeo será re-empaquetado al vuelo antes de transmitirlo al dispositivo.", - "DirectStreamHelp2": "La transmisión directa del archivo usa muy poco procesamiento sin ninguna pérdida de calidad en el vídeo.", + "DirectStreamHelp2": "La transmisión directa del archivo usa muy poco procesamiento sin mínima pérdida de calidad en el vídeo.", "Director": "Dirección de", "Directors": "Directores", "Display": "Mostrar", @@ -1539,5 +1539,11 @@ "MessageNoRepositories": "Sin repositorios.", "Writers": "Escritores", "StopPlayback": "Detener la reproducción", - "ClearQueue": "Borrar la cola" + "ClearQueue": "Borrar la cola", + "LabelSubtitleVerticalPosition": "Posición vertical:", + "PreviousTrack": "Saltar al anterior", + "MessageGetInstalledPluginsError": "Ha ocurrido un error al recuperar la lista de plugins instalados.", + "MessagePluginInstallError": "Ha ocurrido un error al instalar este plugin.", + "NextTrack": "Saltar al siguiente", + "LabelUnstable": "Inestable" } From e0f1ac833ea98b6b93aa3f3d5bd8f39f224ac848 Mon Sep 17 00:00:00 2001 From: Cameron Date: Mon, 10 Aug 2020 09:53:37 +0100 Subject: [PATCH 134/301] Apply suggestions --- src/plugins/htmlAudioPlayer/plugin.js | 10 ++++------ 1 file changed, 4 insertions(+), 6 deletions(-) diff --git a/src/plugins/htmlAudioPlayer/plugin.js b/src/plugins/htmlAudioPlayer/plugin.js index 86d59aa54d..acce15df88 100644 --- a/src/plugins/htmlAudioPlayer/plugin.js +++ b/src/plugins/htmlAudioPlayer/plugin.js @@ -4,10 +4,8 @@ import appHost from 'apphost'; import * as htmlMediaHelper from 'htmlMediaHelper'; function getDefaultProfile() { - return new Promise(function (resolve, reject) { - import('browserdeviceprofile').then(({default: profileBuilder}) => { - resolve(profileBuilder({})); - }); + return import('browserdeviceprofile').then(({ default: profileBuilder }) => { + return profileBuilder({}); }); } @@ -53,7 +51,7 @@ function supportsFade() { } function requireHlsPlayer(callback) { - import('hlsjs').then(({default: hls}) => { + import('hlsjs').then(({ default: hls }) => { window.Hls = hls; callback(); }); @@ -70,7 +68,7 @@ function enableHlsPlayer(url, item, mediaSource, mediaType) { // issue head request to get content type return new Promise(function (resolve, reject) { - import('fetchHelper').then(({default: fetchHelper}) => { + import('fetchHelper').then((fetchHelper) => { fetchHelper.ajax({ url: url, type: 'HEAD' From 98e666c62dc769337a37f1456882f69e9bbf18df Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Luk=C3=A1=C5=A1=20Kucharczyk?= Date: Mon, 10 Aug 2020 08:49:33 +0000 Subject: [PATCH 135/301] Translated using Weblate (Czech) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/cs/ --- src/strings/cs.json | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/src/strings/cs.json b/src/strings/cs.json index 80415c24af..65a4b0ba3e 100644 --- a/src/strings/cs.json +++ b/src/strings/cs.json @@ -1542,5 +1542,10 @@ "ViewAlbumArtist": "Zobrazit interpreta alba", "PreviousTrack": "Předchozí", "NextTrack": "Další", - "LabelUnstable": "Nestabilní" + "LabelUnstable": "Nestabilní", + "Preview": "Náhled", + "SubtitleVerticalPositionHelp": "Číslo řádku, na kterém se zobrazí text. Kladná čísla znamenají směr shora dolů. Záporná čísla zdola nahoru.", + "LabelSubtitleVerticalPosition": "Svislé umístění:", + "MessageGetInstalledPluginsError": "Při načítání seznamu nainstalovaných zásuvných modulů došlo k chybě.", + "MessagePluginInstallError": "Při instalaci zásuvného modulu došlo k chybě." } From b46ec31afa5289b49d49679915fed5d782dbd7b9 Mon Sep 17 00:00:00 2001 From: Cameron Date: Mon, 10 Aug 2020 09:59:17 +0100 Subject: [PATCH 136/301] Update package.json --- package.json | 1 + 1 file changed, 1 insertion(+) diff --git a/package.json b/package.json index 1d7cf770d3..36f1522538 100644 --- a/package.json +++ b/package.json @@ -277,6 +277,7 @@ "src/scripts/filesystem.js", "src/scripts/globalize.js", "src/scripts/imagehelper.js", + "src/scripts/itembynamedetailpage.js", "src/scripts/inputManager.js", "src/scripts/autoThemes.js", "src/scripts/themeManager.js", From 7133294b8b8296c0b9b66d9f71cbc405b79b89e8 Mon Sep 17 00:00:00 2001 From: Justin van der Krieken Date: Mon, 10 Aug 2020 12:21:30 +0000 Subject: [PATCH 137/301] Translated using Weblate (Dutch) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/nl/ --- src/strings/nl.json | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/strings/nl.json b/src/strings/nl.json index 36b947855d..1e318f92c2 100644 --- a/src/strings/nl.json +++ b/src/strings/nl.json @@ -160,7 +160,7 @@ "DetectingDevices": "Apparaten detecteren", "DeviceAccessHelp": "Dit geldt alleen voor apparaten die uniek geïdentificeerd kunnen worden en voorkomen niet toegang via een webbrowser. Filteren van apparaat toegang voor gebruikers voorkomt dat zij nieuwe apparaten gebruiken totdat deze hier zijn goedgekeurd.", "DirectPlaying": "Direct afspelen", - "DirectStreamHelp1": "De resolutie en codec (bijv. H.264, AC3, etc.) wordt ondersteund door het apparaat, maar het medium is in een niet-ondersteunde bestandscontainer (bijv. mkv, avi, wmv). De video zal tijdens het afspelen opnieuw verpakt worden naar een andere bestandscontainer.", + "DirectStreamHelp1": "De resolutie en codec (H.264, AC3, etc.) wordt ondersteund door het apparaat, maar het medium is in een niet-ondersteunde bestandscontainer (mkv, avi, wmv, etc.). De video zal tijdens het afspelen opnieuw verpakt worden naar een andere bestandscontainer.", "DirectStreamHelp2": "Direct streamen van een bestand gebruikt weinig processorkracht zonder verlies van beeldkwaliteit.", "DirectStreaming": "Direct streamen", "Director": "Regiseur", @@ -267,7 +267,7 @@ "HeaderAllowMediaDeletionFrom": "Wissen van media toestaan van", "HeaderApiKey": "API Sleutel", "HeaderApiKeys": "API Sleutels", - "HeaderApiKeysHelp": "Externe applicaties zijn verplicht om een API sleutel te hebben om te communiceren met Jellyfin Server. Sleutels worden uitgegeven door in te loggen met een Jellyfin account, of door het handmatig verlenen van een sleutel voor de toepassing.", + "HeaderApiKeysHelp": "Externe applicaties zijn verplicht om een API sleutel te hebben om te communiceren met de server. Sleutels kunnen verkregen worden door in te loggen met een Jellyfin account, of door er een handmatig te verlenen.", "HeaderApp": "Applicatie", "HeaderAppearsOn": "Verschijnt op", "HeaderAudioBooks": "Luisterboeken", From d09b6de98842c9cbf0fdeff2fdf712c2aa0e7723 Mon Sep 17 00:00:00 2001 From: Matjaz Zavski Date: Mon, 10 Aug 2020 20:47:44 +0200 Subject: [PATCH 138/301] Update src/controllers/livetv/livetvsuggested.js Co-authored-by: Dmitry Lyzo <56478732+dmitrylyzo@users.noreply.github.com> --- src/controllers/livetv/livetvsuggested.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/controllers/livetv/livetvsuggested.js b/src/controllers/livetv/livetvsuggested.js index 5b75be90c3..34b81deefa 100644 --- a/src/controllers/livetv/livetvsuggested.js +++ b/src/controllers/livetv/livetvsuggested.js @@ -277,7 +277,7 @@ export default function (view, params) { let controller = tabControllers[index]; if (!controller) { - tabContent = view.querySelector('.pageTabContent[data-index="${index}"]'); + tabContent = view.querySelector(`.pageTabContent[data-index="${index}"]`); if (index === 0) { controller = self; From 1f16e0fb9c0a023e71094a3f0a185ecc0f0b400a Mon Sep 17 00:00:00 2001 From: Cameron Date: Mon, 10 Aug 2020 22:13:43 +0100 Subject: [PATCH 139/301] Fix suggestions --- src/components/playback/playbackmanager.js | 4 ++-- src/plugins/sessionPlayer/plugin.js | 3 --- src/scripts/site.js | 2 +- 3 files changed, 3 insertions(+), 6 deletions(-) diff --git a/src/components/playback/playbackmanager.js b/src/components/playback/playbackmanager.js index 437127be18..cf62d647dd 100644 --- a/src/components/playback/playbackmanager.js +++ b/src/components/playback/playbackmanager.js @@ -1416,8 +1416,8 @@ class PlaybackManager { self.toggleFullscreen = function (player) { player = player || self._currentPlayer; - if (!player.isLocalPlayer || player.toggleFulscreen) { - return player.toggleFulscreen(); + if (!player.isLocalPlayer || player.toggleFullscreen) { + return player.toggleFullscreen(); } if (screenfull.isEnabled) { diff --git a/src/plugins/sessionPlayer/plugin.js b/src/plugins/sessionPlayer/plugin.js index 56d904e2fc..d4cbb8345f 100644 --- a/src/plugins/sessionPlayer/plugin.js +++ b/src/plugins/sessionPlayer/plugin.js @@ -444,9 +444,6 @@ class SessionPlayer { }); } - setMaxStreamingBitrate(options) { - } - setRepeatMode(mode) { sendCommandByName(this, 'SetRepeatMode', { RepeatMode: mode diff --git a/src/scripts/site.js b/src/scripts/site.js index aa74411af4..acd38b0970 100644 --- a/src/scripts/site.js +++ b/src/scripts/site.js @@ -341,7 +341,7 @@ function initClient() { function getPlaybackManager(playbackManager) { window.addEventListener('beforeunload', function () { try { - playbackManager.onAppClose(); + playbackManager.default.onAppClose(); } catch (err) { console.error('error in onAppClose: ' + err); } From e8aeaea3eef0687255810a37e176a9b1640c2721 Mon Sep 17 00:00:00 2001 From: Gorrunyo Date: Tue, 11 Aug 2020 02:37:58 +0000 Subject: [PATCH 140/301] Translated using Weblate (Catalan) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/ca/ --- src/strings/ca.json | 18 +++++++++++++++--- 1 file changed, 15 insertions(+), 3 deletions(-) diff --git a/src/strings/ca.json b/src/strings/ca.json index 7250a6cb31..e0aa04ead1 100644 --- a/src/strings/ca.json +++ b/src/strings/ca.json @@ -787,12 +787,12 @@ "ButtonTogglePlaylist": "Llista de reproducció", "ButtonToggleContextMenu": "més", "ButtonOff": "Apagar", - "BurnSubtitlesHelp": "Determina si el servidor hauria de gravar-se en els subtítols en transcodificar vídeos. Evitar això millorarà molt el rendiment. Seleccioneu Automàtica per gravar formats basats en imatges (VOBSUB, PGS, SUB, IDX) i certs subtítols ASS o SSA.", + "BurnSubtitlesHelp": "Determina si el servidor hauria de gravar els subtítols en transcodificar vídeos. Evitar això millorarà molt el rendiment. Seleccioneu Automàtica per gravar formats basats en imatges (VOBSUB, PGS, SUB, IDX) i certs subtítols ASS o SSA.", "Browse": "Navega", "BoxRear": "Caixa (posterior)", "BoxSet": "conjunt de caixes", "Box": "Caixa", - "BookLibraryHelp": "Els àudio i llibres de text són compatibles. Reviseu la {0} guia de denominació de llibres {1}.", + "BookLibraryHelp": "L'àudio i els llibres de text són compatibles. Reviseu la {0} guia de denominació de llibres {1}.", "Backdrops": "Fons", "Backdrop": "Fons", "Artist": "Artista", @@ -802,5 +802,17 @@ "AllowOnTheFlySubtitleExtractionHelp": "Els subtítols incrustats es poden extreure de vídeos i entregar-los a clients en text senzill per tal d'evitar la transcodificació de vídeo. En alguns sistemes, això pot trigar molt i fer que la reproducció de vídeo s’aturi durant el procés d’extracció. Desactiveu-ho per tenir subtítols incrustats incrustats amb la transcodificació de vídeo quan no són compatibles amb el dispositiu client de forma nativa.", "AlbumArtist": "Album artista", "Album": "Album", - "ButtonSyncPlay": "SyncPlay" + "ButtonSyncPlay": "SyncPlay", + "CriticRating": "Ràting de la crítica", + "CopyStreamURLSuccess": "L'URL s'ha copiat correctament.", + "CopyStreamURL": "Copiar l'URL de reproducció", + "ContinueWatching": "Continuar mirant", + "ConfirmEndPlayerSession": "Vols tancar Jellyfin a {0}?", + "ConfirmDeleteItems": "L'esborrat d'aquests elements els eliminarà del sistema de fitxers i de la biblioteca multimèdia. Estàs segur que vols continuar?", + "ConfirmDeleteItem": "L'esborrat d'aquest element l'eliminarà del sistema de fitxers i de la biblioteca multimèdia. Estàs segur que vols continuar?", + "ConfigureDateAdded": "Configura com es determina la data d'afegit en el quadre de comandament dins les Preferències de la biblioteca", + "CommunityRating": "Ràting comunitari", + "ColorTransfer": "Transferència de color", + "ColorSpace": "Espai de color", + "ColorPrimaries": "Colors primaris" } From f0ca919be80e2003d3c1e917e51ce710d8e47268 Mon Sep 17 00:00:00 2001 From: Gorrunyo Date: Tue, 11 Aug 2020 05:56:13 +0000 Subject: [PATCH 141/301] Translated using Weblate (Catalan) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/ca/ --- src/strings/ca.json | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/src/strings/ca.json b/src/strings/ca.json index e0aa04ead1..1e566d657d 100644 --- a/src/strings/ca.json +++ b/src/strings/ca.json @@ -777,7 +777,7 @@ "Aired": "Transmès", "AirDate": "Data d'emissió", "AdditionalNotificationServices": "Examineu el catàleg de complements per instal·lar serveis de notificació addicionals.", - "AddedOnValue": "Afegit {0}", + "AddedOnValue": "Afegit {0}", "Actor": "Actor", "Absolute": "Absolut", "ClientSettings": "Configuració del client", @@ -814,5 +814,10 @@ "CommunityRating": "Ràting comunitari", "ColorTransfer": "Transferència de color", "ColorSpace": "Espai de color", - "ColorPrimaries": "Colors primaris" + "ColorPrimaries": "Colors primaris", + "DefaultMetadataLangaugeDescription": "Aquests són els teus valors per defecte i poden ser personalitats per cada biblioteca.", + "Default": "Per defecte", + "DatePlayed": "Data reproduït", + "DateAdded": "Data d'afegit", + "CustomDlnaProfilesHelp": "Crear un perfil personalitzat per a un nou dispositiu o substitueix un perfil de sistema." } From faf465603d068931b1a43fa0d4761429eb8fc209 Mon Sep 17 00:00:00 2001 From: Ted van den Brink Date: Tue, 11 Aug 2020 07:42:56 +0000 Subject: [PATCH 142/301] Translated using Weblate (Dutch) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/nl/ --- src/strings/nl.json | 25 +++++++++++++++---------- 1 file changed, 15 insertions(+), 10 deletions(-) diff --git a/src/strings/nl.json b/src/strings/nl.json index 1e318f92c2..1e092d3328 100644 --- a/src/strings/nl.json +++ b/src/strings/nl.json @@ -332,7 +332,7 @@ "HeaderInstall": "Installeer", "HeaderKeepRecording": "Bewaar opname", "HeaderKeepSeries": "Series behouden", - "HeaderKodiMetadataHelp": "Om NFO-metadata in of uit te schakelen, gaat u naar de Jellyfin bibliotheekinstellingen en vervolgens naar de metadata-downloaders sectie.", + "HeaderKodiMetadataHelp": "Om NFO-metadata in of uit te schakelen, bewerk een bibliotheek en zoek in de metadata-downloaders sectie.", "HeaderLatestEpisodes": "Nieuwste Afleveringen", "HeaderLatestMedia": "Nieuwste Media", "HeaderLatestMovies": "Nieuwste Films", @@ -452,7 +452,7 @@ "HttpsRequiresCert": "Om beveiligde verbindingen in te schakelen, is een vertrouwd SSL-certificaat vereist (zoals Let's Encrypt). Geef een certificaat op of schakel beveiligde verbindingen uit.", "Identify": "Identificeer", "Images": "Afbeeldingen", - "ImportFavoriteChannelsHelp": "Bij inschakelen zullen alleen kanalen geïmporteerd worden die op de tuner als favoriet aangemerkt zijn.", + "ImportFavoriteChannelsHelp": "Alleen kanalen die als favoriet aangemerkt zijn op de tuner zullen geïmporteerd worden.", "ImportMissingEpisodesHelp": "Indien ingeschakeld, wordt informatie over ontbrekende afleveringen in uw Jellyfin de database geïmporteerd en weergegeven in de seizoenen en series. Dit kan aanzienlijk langere bibliotheekscans veroorzaken.", "InstallingPackage": "Installeren van {0} (versie {1})", "Kids": "Kinderen", @@ -480,14 +480,14 @@ "LabelAppName": "Applicatie Naam", "LabelAppNameExample": "Voorbeeld: Sickbeard, Sonarr", "LabelArtists": "Artiest:", - "LabelArtistsHelp": "Scheidt meerdere met een ;", + "LabelArtistsHelp": "Scheidt artiesten met een ;", "LabelAudioLanguagePreference": "Voorkeurs audiotaal:", "LabelAutomaticallyRefreshInternetMetadataEvery": "Vernieuw metagegevens automatisch van het internet:", "LabelBindToLocalNetworkAddress": "Binden aan het lokale netwerk adres:", "LabelBindToLocalNetworkAddressHelp": "Optioneel. Overrule het lokale IP-adres om aan de http-server te binden. Indien leeg gelaten, zal de server binden aan alle beschikbare adressen. Het veranderen van deze waarde vereist herstarten van Jellyfin Server.", "LabelBirthDate": "Geboortedatum:", "LabelBirthYear": "Geboorte jaar:", - "LabelBlastMessageInterval": "Alive bericht interval (seconden)", + "LabelBlastMessageInterval": "Alive bericht interval", "LabelBlastMessageIntervalHelp": "Bepaalt de duur in seconden tussen Blast Alive berichten.", "LabelBlockContentWithTags": "Blokkeer items met volgende tags:", "LabelBurnSubtitles": "Ondertitels inbranden:", @@ -512,7 +512,7 @@ "LabelCustomRating": "Aangepaste classificatie:", "LabelDateAdded": "Datum toegevoegd:", "LabelDateAddedBehavior": "Datum toegevoegd gedrag voor nieuwe content:", - "LabelDateAddedBehaviorHelp": "Als metadata gegevens aanwezig zijn hebben deze voorrang op deze opties.", + "LabelDateAddedBehaviorHelp": "Als metadata gegevens aanwezig is krijgt deze voorrang op deze opties.", "LabelDateTimeLocale": "Datum en tijd regio:", "LabelDay": "Dag:", "LabelDeathDate": "Overlijdens datum:", @@ -540,12 +540,12 @@ "LabelEnableAutomaticPortMapHelp": "Publieke poort automatisch doorsturen naar een lokale poort via UPnP. Dit werkt niet op alle routers en netwerk configuraties. De wijzigingen worden pas actief na een herstart van de server.", "LabelEnableBlastAliveMessages": "Alive berichten zenden", "LabelEnableBlastAliveMessagesHelp": "Zet dit aan als de server niet betrouwbaar door andere UPnP-apparaten op uw netwerk wordt gedetecteerd.", - "LabelEnableDlnaClientDiscoveryInterval": "Interval voor het zoeken naar clients (seconden)", + "LabelEnableDlnaClientDiscoveryInterval": "Interval voor het zoeken naar clients", "LabelEnableDlnaClientDiscoveryIntervalHelp": "Bepaalt de duur in seconden tussen SSDP zoekopdrachten uitgevoerd door Jellyfin.", "LabelEnableDlnaDebugLogging": "DLNA foutopsporings logboek inschakelen", "LabelEnableDlnaDebugLoggingHelp": "Genereer grote logboekbestanden en is alleen bedoeld voor het troubleshooting doeleinden.", "LabelEnableDlnaPlayTo": "DLNA \"Play To\" inschakelen", - "LabelEnableDlnaPlayToHelp": "Apparaten detecteren binnen uw netwerk en maak het mogelijk om ze op afstand te controleren.", + "LabelEnableDlnaPlayToHelp": "Apparaten detecteren binnen uw netwerk en maak het mogelijk om ze op afstand te gebruiken.", "LabelEnableDlnaServer": "DLNA server inschakelen", "LabelEnableDlnaServerHelp": "Sta UPnP apparaten op uw netwerk toe om door inhoud te bladeren en deze af te spelen.", "LabelEnableHardwareDecodingFor": "Activeer hardwaredecodering voor:", @@ -568,7 +568,7 @@ "LabelFriendlyName": "Gebruiksvriendelijke naam:", "LabelServerNameHelp": "Deze naam wordt gebruikt om de server te identificeren, standaard is deze de server zijn computer naam.", "LabelGroupMoviesIntoCollections": "Groepeer films in collecties", - "LabelGroupMoviesIntoCollectionsHelp": "Bij de weergave van film lijsten, zullen films die tot een collectie behoren worden weergegeven als een gegroepeerd object.", + "LabelGroupMoviesIntoCollectionsHelp": "Bij de weergave van film lijsten, zullen films in een collectie worden weergegeven als een gegroepeerd object.", "LabelEncoderPreset": "H264 codering preset:", "LabelHardwareAccelerationType": "Hardware acceleratie:", "LabelHardwareAccelerationTypeHelp": "Hardwarematige versnelling vereist extra configuratie.", @@ -1507,7 +1507,7 @@ "LabelRequireHttps": "HTTPS verplichten", "LabelStable": "Stabiel", "LabelChromecastVersion": "Chromecast versie", - "LabelEnableHttpsHelp": "Hiermee kan de server luisteren op de geconfigureerde HTTPS-poort. Om dit te laten werken moet ook een geldig certificaat worden geconfigureerd.", + "LabelEnableHttpsHelp": "Luisteren op de geconfigureerde HTTPS-poort. Om dit te laten werken moet ook een geldig certificaat worden ingesteld.", "LabelEnableHttps": "HTTPS inschakelen", "HeaderSyncPlayEnabled": "SyncPlay ingeschakeld", "HeaderSyncPlaySelectGroup": "Word lid van een groep", @@ -1537,5 +1537,10 @@ "LabelRepositoryUrlHelp": "De locatie van het repository manifest dat je wilt gebruiken.", "LabelRepositoryUrl": "Repository URL", "HeaderNewRepository": "Nieuwe repository", - "MessageNoRepositories": "Geen repositories." + "MessageNoRepositories": "Geen repositories.", + "LabelSubtitleVerticalPosition": "Verticale positie:", + "TabRepositories": "Repositories", + "MessageGetInstalledPluginsError": "Er is een fout opgetreden bij het ophalen van de lijst met geïnstalleerde plugins.", + "MessagePluginInstallError": "Er is een fout opgetreden tijdens het installeren van de plugin.", + "LabelUnstable": "Niet stabiel" } From 91dcdafe2302038329dcae199b4e149a54bbf2e2 Mon Sep 17 00:00:00 2001 From: Ted van den Brink Date: Tue, 11 Aug 2020 07:56:13 +0000 Subject: [PATCH 143/301] Translated using Weblate (Dutch) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/nl/ --- src/strings/nl.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/strings/nl.json b/src/strings/nl.json index 1e092d3328..0ea745cc34 100644 --- a/src/strings/nl.json +++ b/src/strings/nl.json @@ -575,7 +575,7 @@ "LabelHomeNetworkQuality": "Thuisnetwerk kwaliteit:", "LabelHomeScreenSectionValue": "Beginscherm sectie {0}:", "LabelHttpsPort": "Lokale HTTPS poort nummer:", - "LabelHttpsPortHelp": "Het TCP poort nummer waar Jellyfin's HTTPS server aan moet verbinden.", + "LabelHttpsPortHelp": "Het TCP poort nummer voor de HTTPS server.", "LabelIconMaxHeight": "Pictogram maximum hoogte:", "LabelIconMaxHeightHelp": "Maximum resolutie van pictogrammen weergegeven via upnp:icon.", "LabelIconMaxWidth": "Pictogram maximum breedte:", From b92c4749b30dba750dd44e61a964f2e38e9610f0 Mon Sep 17 00:00:00 2001 From: Ted van den Brink Date: Tue, 11 Aug 2020 08:12:47 +0000 Subject: [PATCH 144/301] Translated using Weblate (Dutch) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/nl/ --- src/strings/nl.json | 19 ++++++++++--------- 1 file changed, 10 insertions(+), 9 deletions(-) diff --git a/src/strings/nl.json b/src/strings/nl.json index 0ea745cc34..5de7589647 100644 --- a/src/strings/nl.json +++ b/src/strings/nl.json @@ -602,7 +602,7 @@ "LabelLanNetworks": "LAN-netwerken:", "LabelLanguage": "Taal:", "LabelLocalHttpServerPortNumber": "Lokale HTTP poort nummer:", - "LabelLocalHttpServerPortNumberHelp": "Het TCP poort nummer waar Jellyfin's HTTP server aan moet verbinden.", + "LabelLocalHttpServerPortNumberHelp": "Het TCP poort nummer voor de HTTP server.", "LabelLockItemToPreventChanges": "Vergrendel dit item om toekomstige wijzigingen te voorkomen", "LabelLoginDisclaimer": "Aanmeld vrijwaring:", "LabelLoginDisclaimerHelp": "Een bericht dat weergeven zal worden onderaan op de login pagina.", @@ -642,7 +642,7 @@ "LabelMovieCategories": "Film categoriën:", "LabelMoviePrefix": "Film voorvoegsel:", "LabelMoviePrefixHelp": "Als een voorvoegsel wordt toegepast op filmtitels, typ deze dan eventueel hier zodat de server het goed kan verwerken.", - "LabelMovieRecordingPath": "Filmopname pad (optioneel):", + "LabelMovieRecordingPath": "Filmopname pad:", "LabelMusicStreamingTranscodingBitrate": "Muziek transcodering bitrate:", "LabelMusicStreamingTranscodingBitrateHelp": "Geef een maximum bitrate op voor het streamen van muziek.", "LabelName": "Naam:", @@ -655,7 +655,7 @@ "LabelNumber": "Nummer:", "LabelNumberOfGuideDays": "Aantal dagen van de gids om te downloaden:", "LabelNumberOfGuideDaysHelp": "Het downloaden van meer dagen van de gids gegevens biedt de mogelijkheid verder vooruit te plannen en een beter overzicht geven, maar het zal ook langer duren om te downloaden. Auto kiest op basis van het aantal kanalen.", - "LabelOptionalNetworkPath": "(Optioneel) Gedeelde netwerkmap:", + "LabelOptionalNetworkPath": "Gedeelde netwerkmap:", "LabelOptionalNetworkPathHelp": "Als deze map wordt gedeeld op uw netwerk, kunnen middels het netwerkpad Jellyfin apps op andere apparaten rechtstreeks toegang tot mediabestanden krijgen. Bijvoorbeeld {0} or {1}.", "LabelOriginalAspectRatio": "Originele aspect ratio:", "LabelOriginalTitle": "Orginele titel:", @@ -696,7 +696,7 @@ "LabelReleaseDate": "Uitgave datum:", "LabelRemoteClientBitrateLimit": "Internet streaming bitrate limiet (Mbps):", "LabelRemoteClientBitrateLimitHelp": "Een optionele bitrate per stream limiet voor alle apparaten buiten het netwerk. Dit is handig om te voorkomen dat apparaten een hogere bitrate vragen dan je internetverbinding aan kan. Dit kan een verhoogde belasting van de CPU in je server veroorzaken om videos direct te transcoderen naar een lagere bitrate.", - "LabelRuntimeMinutes": "Speelduur (minuten):", + "LabelRuntimeMinutes": "Speelduur:", "LabelSaveLocalMetadata": "Afbeeldingen opslaan in mediamappen", "LabelSaveLocalMetadataHelp": "Door afbeeldingen op te slaan in de mediamappen kunnen ze makkelijker worden aangepast.", "LabelScheduledTaskLastRan": "Laatste keer {0}, duur {1}.", @@ -708,7 +708,7 @@ "LabelSelectVersionToInstall": "Selecteer de versie om te installeren:", "LabelSendNotificationToUsers": "Stuur de melding naar:", "LabelSerialNumber": "Serienummer", - "LabelSeriesRecordingPath": "Serieopname pad (optioneel):", + "LabelSeriesRecordingPath": "Serieopname pad:", "LabelServerHost": "Server:", "LabelServerHostHelp": "192.168.1.100:8096 of https://mijnserver.nl", "LabelSimultaneousConnectionLimit": "Gelijktijdige stream limiet:", @@ -891,7 +891,7 @@ "OptionAllowLinkSharingHelp": "Alleen webpagina's met media-informatie worden gedeeld. Media-bestanden worden nooit publiekelijk gedeeld. Gedeelde items zijn beperkt in tijd en verlopen na {0} dagen.", "OptionAllowManageLiveTv": "Live TV opname beheer toestaan", "OptionAllowMediaPlayback": "Media afspelen toestaan", - "OptionAllowMediaPlaybackTranscodingHelp": "Toegang tot transcodering beperken kan afspeelfouten in Jellyfin apps door niet ondersteunde madiaformaten veroorzaken.", + "OptionAllowMediaPlaybackTranscodingHelp": "Het beperken van toegang tot transcodering kan afspeelfouten in clients veroorzaken door niet ondersteunde madiaformaten.", "OptionAllowRemoteControlOthers": "Op afstand besturen van andere gebruikers toestaan", "OptionAllowRemoteSharedDevices": "Op afstand besturen van gedeelde apparaten toestaan", "OptionAllowRemoteSharedDevicesHelp": "DLNA apparaten worden als gedeeld apparaat gezien totdat een gebruiker deze gaat gebruiken.", @@ -903,7 +903,7 @@ "OptionAscending": "Oplopend", "OptionAutomatic": "Automatisch", "OptionAutomaticallyGroupSeries": "Automatisch samenvoegen serie die zijn verspreid over meerdere mappen", - "OptionAutomaticallyGroupSeriesHelp": "Indien ingeschakeld, zal serie die zijn verspreid over meerdere mappen binnen deze bibliotheek automatisch samengevoegd tot één serie.", + "OptionAutomaticallyGroupSeriesHelp": "Serie die verspreid zijn over meerdere mappen binnen deze bibliotheek worden automatisch samengevoegd tot één serie.", "OptionBlockBooks": "Boeken", "OptionBlockChannelContent": "Internet kanaal Inhoud", "OptionBlockLiveTvChannels": "Live TV Kanalen", @@ -922,7 +922,7 @@ "OptionDatePlayed": "Datum afgespeeld", "OptionDescending": "Aflopend", "OptionDisableUser": "Deze gebruiker uitschakelen", - "OptionDisableUserHelp": "Indien uitgeschakeld zal de server geen verbindingen van deze gebruiker toestaan. Bestaande verbindingen zullen abrupt worden beëindigd.", + "OptionDisableUserHelp": "De server staat geen verbindingen van deze gebruiker toe. Bestaande verbindingen zullen abrupt worden beëindigd.", "OptionDislikes": "Niet leuk", "OptionDisplayFolderView": "Toon een mappenweergave als u gewoon Mediamappen wilt weergeven", "OptionDisplayFolderViewHelp": "Geef folders weer naast uw andere media bibliotheken. Dit kan handig zijn als u een oppervlakkig folder aanzicht wilt hebben.", @@ -1542,5 +1542,6 @@ "TabRepositories": "Repositories", "MessageGetInstalledPluginsError": "Er is een fout opgetreden bij het ophalen van de lijst met geïnstalleerde plugins.", "MessagePluginInstallError": "Er is een fout opgetreden tijdens het installeren van de plugin.", - "LabelUnstable": "Niet stabiel" + "LabelUnstable": "Niet stabiel", + "NextTrack": "Ga naar volgende" } From 7118d4456efaec83e40078ec385aa722b4911b9a Mon Sep 17 00:00:00 2001 From: nextlooper42 Date: Tue, 11 Aug 2020 09:23:17 +0000 Subject: [PATCH 145/301] Translated using Weblate (Slovak) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/sk/ --- src/strings/sk.json | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/src/strings/sk.json b/src/strings/sk.json index 44c5751175..70511a84e5 100644 --- a/src/strings/sk.json +++ b/src/strings/sk.json @@ -916,7 +916,7 @@ "ConfirmDeleteItems": "Zmazaním týchto položiek odstránite súbory zo súborového systému aj z knižnice médií. Ste si istý/á, že chcete pokračovať?", "Continuing": "Pokračujúci", "Default": "Predvolené", - "DirectStreamHelp2": "Priame streamovanie súboru používa veľmi málo procesorového výkonu bez straty kvality videa.", + "DirectStreamHelp2": "Priame streamovanie vyžaduje veľmi málo výkonu takmer bez straty kvality videa.", "DirectStreaming": "Priame streamovanie", "DisplayMissingEpisodesWithinSeasonsHelp": "Toto musí byť povolené pre TV knižnice v nastavení servera.", "DisplayModeHelp": "Vyberte štýl layoutu, ktorý chcete pre rozhranie.", @@ -1086,13 +1086,13 @@ "HeaderResponseProfile": "Profil odozvy", "HeaderRemoveMediaLocation": "Odobrať cestu medií", "HeaderRecordingPostProcessing": "Spracovanie nahratých nahrávok", - "HeaderProfileServerSettingsHelp": "Tieto hodnoty určujú, ako sa bude Jellyfin Server prezentovať v zariadeniach.", + "HeaderProfileServerSettingsHelp": "Tieto hodnoty určujú, ako sa bude server prezentovať klientom.", "HeaderPluginInstallation": "Inštalácia zásuvných modulov", "HeaderPlayback": "Prehrávanie medií", "HeaderPlayOn": "Prehrať na", "HeaderOnNow": "Práve teraz", "HeaderLiveTvTunerSetup": "Nastavenie TV tuneru pre živé vysielanie", - "HeaderKodiMetadataHelp": "Pokiaľ chcete povoliť alebo zakázať NFO metadáta, upravte knižnicu v nastavení Jellyfin knižníc v sekcii ukladania metadát.", + "HeaderKodiMetadataHelp": "Pokiaľ chcete povoliť alebo zakázať NFO metadáta, upravte knižnicu v sekcii ukladania metadát.", "HeaderKeepSeries": "Zachovať seriál", "HeaderKeepRecording": "Zachovať nahrávanie", "HeaderImageOptions": "Možnosti obrázkov", @@ -1118,7 +1118,7 @@ "HeaderBlockItemsWithNoRating": "Blokované položky so žiadnymi alebo nerozpoznanými informáciami o hodnotení:", "HeaderAppearsOn": "Objaví sa", "HeaderApp": "Appka", - "HeaderApiKeysHelp": "Externé aplikácie musia mať vlastný API kľúč, aby mohli komunikovať s Jellyfin Serverom. Kľúče sú vydávané pomocou prihlásenia sa cez Jellyfin účet alebo manuálnym priradením kľúča aplikácií.", + "HeaderApiKeysHelp": "Externé aplikácie musia mať vlastný API kľúč, aby mohli komunikovať so serverom. Kľúče sú vydávané pomocou prihlásenia cez bežný účet alebo manuálnym priradením kľúča aplikácií.", "HeaderAdditionalParts": "Dodatočné časti", "HardwareAccelerationWarning": "Povolenie hardvérovej akcelerácie môže spôsobiť nestabilitu v niektorých podmienkach. Uistite sa, že váš operačný systém a grafické ovládače sú plne aktualizované. Pokiaľ máte po zapnutí problémy s prehrávaním videa, budete musieť zmeniť nastavenie späť na Žiadne.", "EncoderPresetHelp": "Vyberte hodnotu faster pre zlepšenie výkonu alebo hodnotu slower pre zlepšenie kvality.", @@ -1142,7 +1142,7 @@ "EnableExternalVideoPlayersHelp": "Ponuka externého prehrávača sa zobrazí pri spustení prehrávania videa.", "EnableBackdropsHelp": "Zobraziť pozadia na pozadí pre niektoré stránky pri prechádzaní knižnice.", "DisplayInOtherHomeScreenSections": "Zobrazenie v sekciách domovskej obrazovky, ako sú najnovšie médiá a pokračovať v pozeraní", - "DirectStreamHelp1": "Médium je kompatibilné zo zariadením nezávisle na rozlíšení alebo type média (H.264, AC3, atď.), je však v nekompatibilnom kontajneri (mkv, avi, wmv, atď.). Video bude za behu prebalené do kompatibilného kontajnera ešte pred streamovaním do zariadenia.", + "DirectStreamHelp1": "Médium je kompatibilné zo zariadením nezávisle na rozlíšení alebo type média (H.264, AC3, atď.), je však v nekompatibilnom kontajneri (mkv, avi, wmv, atď.). Video bude za behu prebalené do kompatibilného kontajnera ešte pred odoslaním do zariadenia.", "Depressed": "Stlačený", "DefaultSubtitlesHelp": "Titulky sú načítané v závislosti od predvolených a vynútených nastavení v zabudovaných metadátach. Jazykové predvoľby sú zobrané do úvahy až vtedy, keď je k dispozícií viacero možností.", "DefaultMetadataLangaugeDescription": "Toto sú vaše predvolené hodnoty ktoré môžu byť prispôsobené na základe jednotlivých knižníc.", From 3438ddae7711df0475092b1be0163c773d9b317f Mon Sep 17 00:00:00 2001 From: nextlooper42 Date: Tue, 11 Aug 2020 09:28:04 +0000 Subject: [PATCH 146/301] Translated using Weblate (Slovak) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/sk/ --- src/strings/sk.json | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/strings/sk.json b/src/strings/sk.json index 70511a84e5..60c5f2c4d4 100644 --- a/src/strings/sk.json +++ b/src/strings/sk.json @@ -300,7 +300,7 @@ "Horizontal": "Horizontálne", "Identify": "Identifikovať", "Images": "Obrázky", - "ImportMissingEpisodesHelp": "Ak je možnosť povolená, informácie o chýbajúcich epizódach budú importované do Vašej Jellyfin databázy a budú zobrazené v sériách a seriáloch. Toto môže spôsobiť podstatne dlhšie skenovania knižníc.", + "ImportMissingEpisodesHelp": "Informácie o chýbajúcich epizódach budú importované do Vašej databázy a budú zobrazené v sériách a seriáloch. Toto môže spôsobiť podstatne dlhšie skenovania knižníc.", "InstallingPackage": "Inštalujem {0} (verzia{1})", "ItemCount": "{0} položiek", "Items": "Položky", @@ -1067,7 +1067,7 @@ "LabelAllowedRemoteAddressesMode": "Režim filtrácie vzdialenej IP adresy:", "LabelAlbumArtists": "Album umelca:", "InstantMix": "Okamžitý mix", - "ImportFavoriteChannelsHelp": "Pokiaľ je možnosť povolená, tak len kanály označené ako obľúbené budú importované na zariadenie tuneru.", + "ImportFavoriteChannelsHelp": "Len kanály označené ako obľúbené budú importované na zariadenie tuneru.", "HttpsRequiresCert": "Pre povolenie zabezpečeného pripojenia budete musieť dodať dôveryhodný SSL certifikát, ako napríklad Let's Encrypt. Prosím, buď dodajte certifikát alebo zakážte zabezpečené pripojenie.", "HeaderXmlDocumentAttributes": "Atribúty XML dokumentu", "HeaderXmlDocumentAttribute": "Atribúty XML dokumentu", @@ -1076,7 +1076,7 @@ "HeaderTranscodingProfileHelp": "Pridať transkódovacie profily pre určenie, ktoré formáty by mali byť použité, keď je transkódovanie vyžadované.", "HeaderSubtitleProfilesHelp": "Profily titulkov popisujú formáty titulkov, ktoré dané zariadenie podporuje.", "HeaderSeriesStatus": "Stav seriálu", - "HeaderSelectTranscodingPathHelp": "Prechádzať alebo zadať cestu, kde by ste chceli uložiť dočasné transkódované súbory. Priečinok musí mať oprávnenie na zapisovanie.", + "HeaderSelectTranscodingPathHelp": "Prechádzať alebo zadať cestu pre súbory transkódovania. Priečinok musí mať oprávnenie na zapisovanie.", "HeaderSelectTranscodingPath": "Vyberte cestu pre dočasné transkódované súbory", "HeaderSelectServerCachePathHelp": "Prechádzať alebo zadať cestu, kde by ste chceli uložiť cache súbory. Priečinok musí mať oprávnenie na zapisovanie.", "HeaderSelectServerCachePath": "Vyberte cestu pre Server Cache", From f2540fb8dbf5763f40cd208335de37452ed149ad Mon Sep 17 00:00:00 2001 From: nextlooper42 Date: Tue, 11 Aug 2020 09:29:35 +0000 Subject: [PATCH 147/301] Translated using Weblate (Slovak) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/sk/ --- src/strings/sk.json | 60 +++++++++++++++++++++++++-------------------- 1 file changed, 34 insertions(+), 26 deletions(-) diff --git a/src/strings/sk.json b/src/strings/sk.json index 60c5f2c4d4..25b54db853 100644 --- a/src/strings/sk.json +++ b/src/strings/sk.json @@ -314,7 +314,7 @@ "LabelAppName": "Názov aplikácie", "LabelAppNameExample": "Príklad: Sickbeard, Sonarr", "LabelArtists": "Umelci:", - "LabelArtistsHelp": "Oddeľte pomocou ;", + "LabelArtistsHelp": "Viacej umelcov oddeľte pomocou bodkočiarky.", "LabelAudioLanguagePreference": "Uprednostňovaný jazyk zvuku:", "LabelAutomaticallyRefreshInternetMetadataEvery": "Automaticky obnoviť metadáta z internetu:", "LabelBirthDate": "Dátum narodenia:", @@ -367,9 +367,9 @@ "LabelFont": "Písmo:", "LabelForgotPasswordUsernameHelp": "Zadajte svoje používateľské meno, ak si ho pamätáte.", "LabelFormat": "Formát:", - "LabelServerNameHelp": "Tento názov bude použitý na identifikáciu servera. Ak ostane prázdny, bude použitý názov počítača.", + "LabelServerNameHelp": "Tento názov bude použitý na identifikáciu servera. Ak ostane prázdny, bude použitý názov hostiteľa serveru.", "LabelGroupMoviesIntoCollections": "Zoskupiť filmy do kolekcií", - "LabelGroupMoviesIntoCollectionsHelp": "Pri zobrazení zoznamu filmov budú filmy patriace do kolekcie zobrazené ako jedna zoskupená položka.", + "LabelGroupMoviesIntoCollectionsHelp": "Pri zobrazení zoznamu filmov budú filmy v kolekcií zobrazené ako jedna položka.", "LabelHardwareAccelerationType": "Hardvérová akcelerácia:", "LabelHardwareAccelerationTypeHelp": "Hardvérová akcelerácia vyžaduje dodatočnú konfiguráciu.", "LabelHomeScreenSectionValue": "Sekcia domácej obrazovky {0}:", @@ -401,7 +401,7 @@ "LabelMetadata": "Metadáta:", "LabelMetadataDownloadLanguage": "Preferovaný jazyk:", "LabelMetadataPath": "Umiestnenie metadát:", - "LabelMetadataSaversHelp": "Vyberte formát súboru, do ktorého chcete ukladať vaše metadáta.", + "LabelMetadataSaversHelp": "Vyberte formát súboru, ktorý chcete použiť pre ukladanie metadát.", "LabelMinResumeDurationHelp": "Najkratšia dĺžka videa v sekundách, ktorá uloží rozpozeranú polohu a dovolí sa k nej vrátiť.", "LabelMinResumePercentageHelp": "Tituly budú považované za neprehrané ak budú zastavené pred týmto časom.", "LabelModelDescription": "Popis modelu", @@ -409,7 +409,7 @@ "LabelModelNumber": "Číslo modelu", "LabelModelUrl": "Model URL", "LabelMovieCategories": "Kategórie filmov:", - "LabelMovieRecordingPath": "Umiestnenie filmových nahrávok (voliteľné):", + "LabelMovieRecordingPath": "Umiestnenie pre nahrávanie filmov:", "LabelName": "Meno:", "LabelNewName": "Nové meno:", "LabelNewPassword": "Nové heslo:", @@ -418,7 +418,7 @@ "LabelNext": "Ďalej", "LabelNotificationEnabled": "Povoliť toto hlásenie", "LabelNumber": "Číslo:", - "LabelOptionalNetworkPath": "(Voliteľné) Zdieľaný sieťový priečinok:", + "LabelOptionalNetworkPath": "Zdieľaný sieťový priečinok:", "LabelOriginalAspectRatio": "Pôvodný pomer strán:", "LabelOriginalTitle": "Pôvodný názov:", "LabelOverview": "Prehľad:", @@ -445,14 +445,14 @@ "LabelRecordingPath": "Predvolené umiestnenie nahrávok:", "LabelRecordingPathHelp": "Uveďte predvolené umiestnenie pre ukladanie nahrávok. Ak je ponechané prázdne, použije sa priečinok s programovými dátami servera.", "LabelReleaseDate": "Dátum vydania:", - "LabelRuntimeMinutes": "Dĺžka (minúty):", + "LabelRuntimeMinutes": "Dĺžka:", "LabelSaveLocalMetadata": "Uložiť obaly a metadáta do priečinka s médiami", "LabelScreensaver": "Šetrič obrazokvy:", "LabelSeasonNumber": "Číslo série:", "LabelSelectUsers": "Zvoľte užívateľov:", "LabelSelectVersionToInstall": "Vyberte verziu, ktorú chcete nainštalovať:", "LabelSerialNumber": "Sériové číslo", - "LabelSeriesRecordingPath": "Umiestnenie seriálových nahrávok (voliteľné):", + "LabelSeriesRecordingPath": "Umiestnenie pre nahrávanie seriálov:", "LabelServerHostHelp": "192.168.1.100:8096 alebo https://mojserver.sk", "LabelSkipBackLength": "Dĺžka skoku dozadu:", "LabelSkipForwardLength": "Dĺžka skoku dopredu:", @@ -609,7 +609,7 @@ "OptionDatePlayed": "Dátum prehrania", "OptionDescending": "Zostupne", "OptionDisableUser": "Zakázať tohto používateľa", - "OptionDisableUserHelp": "Ak možnosť nie je povolená, server nepovolí žiadne pripojenia od tohto používateľa. Aktívne pripojenia budú ihneď ukončené.", + "OptionDisableUserHelp": "Server nepovolí žiadne pripojenia od tohto používateľa. Aktívne pripojenia budú ihneď ukončené.", "OptionDislikes": "Nepáči sa", "OptionDownloadArtImage": "Obal", "OptionDownloadBackImage": "Späť", @@ -998,7 +998,7 @@ "Absolute": "Absolútne", "LabelDidlMode": "DIDL režim:", "LabelDateTimeLocale": "Lokálne nastavenia dátumu:", - "LabelBlastMessageInterval": "Doba zobrazenie správy (sekundy)", + "LabelBlastMessageInterval": "Doba zobrazenia správy", "LabelAlbumArtMaxWidth": "Maximálna šírka obrázku albumu:", "LabelAlbumArtMaxHeight": "Maximálna výška obrázku albumu:", "LabelAirDays": "Vysielané:", @@ -1199,7 +1199,7 @@ "SeriesCancelled": "Seriál zrušený.", "SelectAdminUsername": "Prosím, vyberte si používateľské meno pre účet administrátora.", "RefreshQueued": "Obnovenie zaradené do fronty.", - "RefreshDialogHelp": "Metadáta sa obnovujú na základe nastavení a internetových služieb, ktoré sú povolené v dashboarde Jellyfin Serveru.", + "RefreshDialogHelp": "Metadáta sa obnovujú na základe nastavení a internetových služieb, ktoré sú povolené v dashboarde.", "MessageChangeRecordingPath": "Zmenou priečinku pre nahrávanie sa existujúce nahrávky automaticky nepresunú zo starej lokácie na na novú. Budete ich musieť presunúť ručne, pokiaľ budete chcieť.", "RecordSeries": "Nahrať sériu", "Raised": "Vystupujúce", @@ -1221,18 +1221,18 @@ "OptionRandom": "Náhodne", "OptionProfileVideoAudio": "Video Zvuk", "OptionPosterCard": "Plagátová karta", - "OptionPlainVideoItemsHelp": "Pokiaľ je povolené, všetky videá sú reprezentované v DIDL ako \"object.item.videoItem\" namiesto viac špecifického typu, ako napríklad \"object.item.videoItem.movie\".", - "OptionPlainStorageFoldersHelp": "Pokiaľ je povolené, všetky priečinky sú reprezentované v DIDL ako \"object.container.storageFolder\" namiesto viac špecifického typu, ako napríklad \"object.container.person.musicArtist\".", + "OptionPlainVideoItemsHelp": "Všetky videá sú reprezentované v DIDL ako \"object.item.videoItem\" namiesto viac špecifického typu, ako napríklad \"object.item.videoItem.movie\".", + "OptionPlainStorageFoldersHelp": "Všetky priečinky sú reprezentované v DIDL ako \"object.container.storageFolder\" namiesto viac špecifického typu, ako napríklad \"object.container.person.musicArtist\".", "OptionPlainStorageFolders": "Zobraziť všetky priečinky ako jednoduché priečinky pre ukladanie", "OptionOnInterval": "V intervale", "OptionLoginAttemptsBeforeLockoutHelp": "Hodnota 0 znamená zdedenie východzej hodnoty troch pokusov pre bežného používateľa a päť pre administrátora. Nastavením na -1 sa táto funkcia zakáže.", "OptionLoginAttemptsBeforeLockout": "Určuje, koľko chybných prihlásení môže byť urobených pred uzamknutím.", - "OptionIgnoreTranscodeByteRangeRequestsHelp": "Pokiaľ je povolené, budú tieto požiadavky aj naďalej plnené, avšak hlavičky bajtových rozsahov budú ignorované.", + "OptionIgnoreTranscodeByteRangeRequestsHelp": "Tieto požiadavky budú aj naďalej plnené, avšak hlavičky bajtových rozsahov budú ignorované.", "OptionIgnoreTranscodeByteRangeRequests": "Ignorovať požiadavky na transkódovanie bajtového rozsahu", "OptionHlsSegmentedSubtitles": "HLS segmentované titulky", "OptionExternallyDownloaded": "Externé sťahovanie", "OptionEnableExternalContentInSuggestionsHelp": "Povoliť zahrnutie internetových trailerov a živých TV programov do navrhovaného obsahu.", - "OptionDownloadImagesInAdvanceHelp": "Vo východzom stave sa väčšina obrázkov sťahuje až po vyžiadaní Jellyfin aplikáciou. Povolením tejto možnosti sa budú všetky obrázky sťahovať popredu, keď sa budú importovať nové médiá. Toto môže spôsobiť výrazne dlhšie skenovanie knižnice.", + "OptionDownloadImagesInAdvanceHelp": "Vo východzom stave sa väčšina obrázkov sťahuje až po vyžiadaní klientom. Povolením tejto možnosti sa budú všetky obrázky sťahovať popredu, keď sa budú importovať nové médiá. Toto môže spôsobiť výrazne dlhšie skenovanie knižnice.", "OptionDownloadBoxImage": "Krabica", "OptionDownloadBannerImage": "Banner", "OptionDisplayFolderViewHelp": "Zobraziť priečinky popri ostatných médiách v knižnici. Toto môže byť užitočné, pokiaľ chcete vidieť jednoduché zobrazenie priečinku.", @@ -1240,10 +1240,10 @@ "OptionBlockTvShows": "Seriál", "OptionBlockLiveTvChannels": "Živé TV kanály", "OptionBanner": "Banner", - "OptionAutomaticallyGroupSeriesHelp": "Pokiaľ je povolené, tak sa série, ktoré sú rozhádzané skrz rôzne priečinky, budú automaticky v tejto knižnici zlučovať do jedného seriálu.", + "OptionAutomaticallyGroupSeriesHelp": "Seriály uložené vo viacerých priečinkoch v tejto knižnici, budú automaticky zlúčené do jedného seriálu.", "OptionAllowVideoPlaybackRemuxing": "Povoliť prehrávanie videa, ktoré vyžaduje konverziu bez opätovného enkódovania", "OptionAllowSyncTranscoding": "Povoliť sťahovanie a synchronizáciu medií, ktoré vyžadujú transkódovanie", - "OptionAllowMediaPlaybackTranscodingHelp": "Obmedzenie prístupu ku transkódovaniu môže spôsobiť zlyhania prehrávania v Jellyfin aplikáciách kvôli nepodporovaným formátom medií.", + "OptionAllowMediaPlaybackTranscodingHelp": "Obmedzenie prístupu ku transkódovaniu môže spôsobiť zlyhania prehrávania v klientoch kvôli nepodporovaným formátom medií.", "MessageNoTrailersFound": "Nainštalujte Trailer kanál pre rozšírenie vášho filmového zážitku pridaním knižnice trailerov z internetu.", "LanNetworksHelp": "Zoznam IP adries alebo IP/netmask záznamov pre všetky siete oddelené čiarkami ktoré budú považované za lokálnu sieť pri vynucovaní obmedzenia šírky pásma. Pokiaľ je toto nastavené, všetky ostatné IP adresy budú považované za vonkajšiu sieť a budú podliehať obmedzeniam šírky pásma vonkajšej siete. Pokiaľ pole ostane prázdne, podsieť serveru bude považovaná za lokálnu sieť.", "LabelUserAgent": "User agent:", @@ -1258,7 +1258,7 @@ "MusicLibraryHelp": "Pozrite si {0}príručku pomenovania hudby{1}.", "MusicAlbum": "Hudobný album", "MoreMediaInfo": "Informácie o médiu", - "MetadataSettingChangeHelp": "Zmena nastavení metadát ovplyvní nový obsah, ktorý bude pridávaný v budúcnosti. Pre obnovenie existujúceho obsahu, otvorte obrazovku s detailom a kliknite na tlačítko obnoviť alebo vykonajte hromadnú obnovu cez metadata manažér.", + "MetadataSettingChangeHelp": "Zmena nastavení metadát ovplyvní nový obsah pridávaný v budúcnosti. Pre obnovenie existujúceho obsahu, otvorte obrazovku s detailom a kliknite na tlačítko obnoviť alebo vykonajte hromadnú obnovu cez metadata manažér.", "MessageUnsetContentHelp": "Obsah bude zobrazený ako jednoduché priečinky. Pre lepšie výsledky použite manažér metadát na nastavenie typu obsahu podpriečinkov.", "MessageUnableToConnectToServer": "Nie sme schopný sa aktuálne pripojiť k vybranému serveru. Prosím, uistite sa že je spustený a skúste to znovu.", "MessageReenableUser": "Pozrite nižšie pre znovu-povolenie", @@ -1291,7 +1291,7 @@ "MediaInfoBitrate": "Dátový tok", "MediaInfoAnamorphic": "Anamorfné", "MapChannels": "Nájdi kanály", - "LabelffmpegPathHelp": "Cesta k aplikačnému súboru ffmpeg alebo k priečinku obsahujúcemu ffmpeg.", + "LabelffmpegPathHelp": "Cesta k súboru aplikácie ffmpeg alebo k priečinku obsahujúcemu ffmpeg.", "LabelXDlnaDocHelp": "Určuje obsah prvku X_DLNADOC v namespace urn:schemas-dlna-org:device-1-0.", "LabelXDlnaDoc": "X-DLNA dokumentácia:", "LabelXDlnaCapHelp": "Určuje obsah prvku X_DLNACAP v namespace urn:schemas-dlna-org:device-1-0.", @@ -1382,7 +1382,7 @@ "LabelLogs": "Logy:", "LabelLoginDisclaimer": "Vyrozumenie prihlásenia:", "LabelLockItemToPreventChanges": "Uzamknúť túto položku pre zabránenie zmien v budúcnosti", - "LabelLocalHttpServerPortNumberHelp": "Číslo TCP portu, na ktoré by sa mal naviazať Jellyfin HTTP server.", + "LabelLocalHttpServerPortNumberHelp": "Číslo portu TCP serveru HTTP.", "LabelKodiMetadataUserHelp": "Uložiť dáta o pozeraní do NFO súboru pre využitie ostatnými aplikáciami.", "LabelKodiMetadataUser": "Ukladá dáta používateľa o pozeraní do NFO súboru pre:", "LabelKodiMetadataEnablePathSubstitutionHelp": "Povoľuje nahradenie ciest k obrázkom pomocou nastavenej cesty serveru pre nahradené cesty.", @@ -1395,14 +1395,14 @@ "LabelIdentificationFieldHelp": "Podreťazec citlivý na veľkosť písmen alebo na regulárne výrazy.", "LabelIconMaxWidthHelp": "Maximálne rozlíšenie ikon pomocou prostredníctvom upnp:icon.", "LabelIconMaxHeightHelp": "Maximálne rozlíšenie ikon pomocou prostredníctvom upnp:icon.", - "LabelHttpsPortHelp": "Číslo TCP portu, na ktoré by sa mal naviazať Jellyfin HTTPS server.", + "LabelHttpsPortHelp": "Číslo portu TCP serveru HTTPS.", "LabelHomeNetworkQuality": "Kvalita na domácej sieti:", "LabelEncoderPreset": "Prednastavené H264 enkódovanie:", "LabelH264Crf": "H264 enkódovanie CRF:", "LabelFriendlyName": "Priateľský názov:", "LabelFolder": "Priečinok:", "LabelExtractChaptersDuringLibraryScanHelp": "Generovať obrázky kapitol počas toho, ako sú videá importované v prvotnom prehľadávaní knižnice. Inak sa budú extrahovať počas naplánovanej úlohy generovania obrázkov kapitol, čo dovoľuje rýchlejšie dokončenie bežného prehľadávania knižnice.", - "LabelBaseUrlHelp": "Pridá vlastný reťazec na URL adresu serveru, napr: http://priklad.sk/<vlastnyretazec>", + "LabelBaseUrlHelp": "Pridá vlastný reťazec na URL adresu serveru, napr: http://priklad.sk/<vlastny-retazec>", "LabelBaseUrl": "Východzia URL:", "LabelEveryXMinutes": "Každý:", "LabelEnableSingleImageInDidlLimitHelp": "Niektoré zariadenia nebudú zobrazovať správne pokiaľ je viacero obrázkov uložených v Didl.", @@ -1410,11 +1410,11 @@ "LabelEnableDlnaDebugLoggingHelp": "Vytvára veľké súbory s logami a mal by sa použiť len v prípade potreby odstraňovania problémov.", "LabelEnableDlnaDebugLogging": "Povoliť loggovanie DLNA debugu", "LabelEnableDlnaClientDiscoveryIntervalHelp": "Určuje dobu trvania v sekundách medzi SSDP vyhľadávaniami vykonanými Jellyfinom.", - "LabelEnableDlnaClientDiscoveryInterval": "Interval pre objavenie klienta (sekundy)", + "LabelEnableDlnaClientDiscoveryInterval": "Interval pre objavenie klienta", "LabelEnableAutomaticPortMapHelp": "Automatické namapovanie vejerného portu na lokálny port serveru cez UPnP. Toto nemusí fungovať so všetkými modelmi routerov alebo sieťových konfigurácií. Zmeny sa vykonajú až po reštarte servera.", "LabelEmbedAlbumArtDidlHelp": "Niektoré zariadenia preferujú túto metódu pre získavanie obrázku albumu. Ostatným môže zlyhať prehrávanie pokiaľ je táto možnosť povolená.", "LabelBlastMessageIntervalHelp": "Určuje dobu v sekundách medzi vysielaniami správ o serveri.", - "LabelBindToLocalNetworkAddressHelp": "Voliteľné. Prepísať lokálnu IP adresu viazanú na http server. Pokiaľ zostane prázdna, server sa naviaže na všetky dostupné adresy. Pri zmene tejto hodnoty sa vyžaduje reštart Jellyfin Servera.", + "LabelBindToLocalNetworkAddressHelp": "Prepísať lokálnu IP adresu http serveru. Pokiaľ zostane prázdna, server sa naviaže na všetky dostupné adresy. Pri zmene tejto hodnoty sa vyžaduje reštart Jellyfin Servera.", "LabelAlbumArtPN": "Obrázok albumu PN:", "LabelAlbumArtMaxWidthHelp": "Maximálne rozlíšenie obrázku albumu prostredníctvom upnp:albumArtURI.", "LabelAlbumArtMaxHeightHelp": "Maximálne rozlíšenie obrázku albumu prostredníctvom upnp:albumArtURI.", @@ -1477,7 +1477,7 @@ "TabDVR": "DVR", "LabelRequireHttpsHelp": "Pokiaľ je zaškrtnutý, server bude automaticky presmerovávať všetky HTTP požiadavky cez HTTPS. Toto nastavenie nemá žiadny efekt, pokiaľ server nepočúva na HTTPS.", "LabelRequireHttps": "Vyžadovať HTTPS", - "LabelEnableHttpsHelp": "Umožní serveru počúvať na nastavenom HTTPS porte. K správnemu fungovaniu je nutné nakonfigurovať aj platný certifikát.", + "LabelEnableHttpsHelp": "Počúvanie na nastavenom HTTPS porte. K správnemu fungovaniu je nutné nakonfigurovať aj platný certifikát.", "LabelEnableHttps": "Povoliť HTTPS", "HeaderServerAddressSettings": "Nastavenie adresy servera", "HeaderRemoteAccessSettings": "Nastavenie vzdialeného prístupu", @@ -1539,5 +1539,13 @@ "Writers": "Scenáristi", "ClearQueue": "Vymazať frontu", "StopPlayback": "Zastaviť prehrávanie", - "ViewAlbumArtist": "Zobraziť interpreta albumu" + "ViewAlbumArtist": "Zobraziť interpreta albumu", + "Preview": "Náhľad", + "SubtitleVerticalPositionHelp": "Číslo riadku, na ktorom sa zobrazí text. Kladné čísla znamenajú smer zhora dole. Záporné čísla zdola hore.", + "LabelSubtitleVerticalPosition": "Vertikálne umiestnenie:", + "PreviousTrack": "Predchádzajúca", + "MessageGetInstalledPluginsError": "Pri načítaní zoznamu nainštalovaných zásuvných modulov došlo k chybe.", + "MessagePluginInstallError": "Pri inštalácií zásuvného modulu došlo k chybe.", + "NextTrack": "Ďalšia", + "LabelUnstable": "Nestabilný" } From 37bd08fef6def998e0ff7715ae8e29733e1ca471 Mon Sep 17 00:00:00 2001 From: Julien Machiels Date: Tue, 11 Aug 2020 15:32:40 +0200 Subject: [PATCH 148/301] Update src/scripts/settings/webSettings.js Co-authored-by: Cameron --- src/scripts/settings/webSettings.js | 1 - 1 file changed, 1 deletion(-) diff --git a/src/scripts/settings/webSettings.js b/src/scripts/settings/webSettings.js index edd4d6e1f4..2ffe290d88 100644 --- a/src/scripts/settings/webSettings.js +++ b/src/scripts/settings/webSettings.js @@ -1,4 +1,3 @@ - let data; async function getConfig() { From 8a67b5e41fa080f728515b72a51adce6c6d88ec1 Mon Sep 17 00:00:00 2001 From: MrTimscampi Date: Tue, 11 Aug 2020 15:37:48 +0200 Subject: [PATCH 149/301] Fix import and Chromecast on Edge Chromium --- src/components/apphost.js | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/components/apphost.js b/src/components/apphost.js index a8e26223a5..c3e9342827 100644 --- a/src/components/apphost.js +++ b/src/components/apphost.js @@ -26,7 +26,7 @@ function getBaseProfileOptions(item) { function getDeviceProfile(item, options = {}) { return new Promise(function (resolve) { - import(['browserdeviceprofile']).then(({default: profileBuilder}) => { + import('browserdeviceprofile').then(({default: profileBuilder}) => { let profile; if (window.NativeShell) { @@ -262,7 +262,7 @@ const supportedFeatures = function () { features.push('fileinput'); } - if (browser.chrome) { + if (browser.chrome || browser.edgeChromium) { features.push('chromecast'); } From 5675b0095616673628ca9f47a5b35506f6fb1ce4 Mon Sep 17 00:00:00 2001 From: Matt Strayer Date: Tue, 11 Aug 2020 13:04:34 -0400 Subject: [PATCH 150/301] Rebased to add in list.js (#1675), updated scope injection --- package.json | 3 +- src/components/filtermenu/filtermenu.js | 123 ++++++++++++------------ 2 files changed, 61 insertions(+), 65 deletions(-) diff --git a/package.json b/package.json index 34252280c9..e1ec7750fd 100644 --- a/package.json +++ b/package.json @@ -110,6 +110,7 @@ "src/components/favoriteitems.js", "src/components/fetchhelper.js", "src/components/filterdialog/filterdialog.js", + "src/components/filtermenu/filtermenu.js", "src/components/focusManager.js", "src/components/groupedcards.js", "src/components/guide/guide.js", @@ -374,4 +375,4 @@ "lint": "eslint \".\"", "stylelint": "stylelint \"src/**/*.css\"" } -} +} \ No newline at end of file diff --git a/src/components/filtermenu/filtermenu.js b/src/components/filtermenu/filtermenu.js index df74dc2a16..4313f31003 100644 --- a/src/components/filtermenu/filtermenu.js +++ b/src/components/filtermenu/filtermenu.js @@ -1,15 +1,26 @@ -define(['require', 'dom', 'focusManager', 'dialogHelper', 'loading', 'apphost', 'inputManager', 'layoutManager', 'connectionManager', 'appRouter', 'globalize', 'userSettings', 'emby-checkbox', 'emby-input', 'paper-icon-button-light', 'emby-select', 'material-icons', 'css!./../formdialog', 'emby-button', 'flexStyles'], function (require, dom, focusManager, dialogHelper, loading, appHost, inputManager, layoutManager, connectionManager, appRouter, globalize, userSettings) { - 'use strict'; - focusManager = focusManager.default || focusManager; +import dom from 'dom'; +import focusManager from 'focusManager'; +import dialogHelper from 'dialogHelper'; +import inputManager from 'inputManager'; +import layoutManager from 'layoutManager'; +import connectionManager from 'connectionManager'; +import globalize from 'globalize'; +import * as userSettings from 'userSettings'; +import 'emby-checkbox'; +import 'emby-input'; +import 'paper-icon-button-light'; +import 'emby-select'; +import 'material-icons'; +import 'css!./../formdialog'; +import 'emby-button'; +import 'flexStyles'; - layoutManager = layoutManager.default || layoutManager; - - function onSubmit(e) { +class FilterMenu { + onSubmit(e) { e.preventDefault(); return false; } - - function renderOptions(context, selector, cssClass, items, isCheckedFn) { + renderOptions(context, selector, cssClass, items, isCheckedFn) { var elem = context.querySelector(selector); if (items.length) { @@ -35,15 +46,14 @@ define(['require', 'dom', 'focusManager', 'dialogHelper', 'loading', 'apphost', elem.querySelector('.filterOptions').innerHTML = html; } - function renderDynamicFilters(context, result, options) { - renderOptions(context, '.genreFilters', 'chkGenreFilter', result.Genres, function (i) { + renderDynamicFilters(context, result, options) { + this.renderOptions(context, '.genreFilters', 'chkGenreFilter', result.Genres, function (i) { // Switching from | to , var delimeter = (options.settings.GenreIds || '').indexOf('|') === -1 ? ',' : '|'; return (delimeter + (options.settings.GenreIds || '') + delimeter).indexOf(delimeter + i.Id + delimeter) !== -1; }); } - - function loadDynamicFilters(context, options) { + loadDynamicFilters(context, options) { var apiClient = connectionManager.getApiClient(options.serverId); var filterMenuOptions = Object.assign(options.filterMenuOptions, { @@ -53,13 +63,13 @@ define(['require', 'dom', 'focusManager', 'dialogHelper', 'loading', 'apphost', IncludeItemTypes: options.itemTypes.join(',') }); - apiClient.getFilters(filterMenuOptions).then(function (result) { - renderDynamicFilters(context, result, options); + apiClient.getFilters(filterMenuOptions).then((result) => { + this.renderDynamicFilters(context, result, options); }); } - function initEditor(context, settings) { - context.querySelector('form').addEventListener('submit', onSubmit); + initEditor(context, settings) { + context.querySelector('form').addEventListener('submit', this.onSubmit); var elems = context.querySelectorAll('.simpleFilter'); var i; @@ -100,15 +110,15 @@ define(['require', 'dom', 'focusManager', 'dialogHelper', 'loading', 'apphost', } } - function saveValues(context, settings, settingsKey) { + saveValues(context, settings, settingsKey) { var elems = context.querySelectorAll('.simpleFilter'); var i; var length; for (i = 0, length = elems.length; i < length; i++) { if (elems[i].tagName === 'INPUT') { - setBasicFilter(context, settingsKey + '-filter-' + elems[i].getAttribute('data-settingname'), elems[i]); + this.setBasicFilter(context, settingsKey + '-filter-' + elems[i].getAttribute('data-settingname'), elems[i]); } else { - setBasicFilter(context, settingsKey + '-filter-' + elems[i].getAttribute('data-settingname'), elems[i].querySelector('input')); + this.setBasicFilter(context, settingsKey + '-filter-' + elems[i].getAttribute('data-settingname'), elems[i].querySelector('input')); } } @@ -144,22 +154,12 @@ define(['require', 'dom', 'focusManager', 'dialogHelper', 'loading', 'apphost', } userSettings.setFilter(settingsKey + '-filter-GenreIds', genres.join(',')); } - - function setBasicFilter(context, key, elem) { + setBasicFilter(context, key, elem) { var value = elem.checked; value = value ? value : null; userSettings.setFilter(key, value); } - - function centerFocus(elem, horiz, on) { - require(['scrollHelper'], function (scrollHelper) { - scrollHelper = scrollHelper.default || scrollHelper; - var fn = on ? 'on' : 'off'; - scrollHelper.centerFocus[fn](elem, horiz); - }); - } - - function moveCheckboxFocus(elem, offset) { + moveCheckboxFocus(elem, offset) { var parent = dom.parentWithClass(elem, 'checkboxList-verticalwrap'); var elems = focusManager.getFocusableElements(parent); @@ -181,45 +181,43 @@ define(['require', 'dom', 'focusManager', 'dialogHelper', 'loading', 'apphost', focusManager.focus(newElem); } } - - function onInputCommand(e) { + centerFocus(elem, horiz, on) { + import('scrollHelper').then(({ default: scrollHelper }) => { + var fn = on ? 'on' : 'off'; + scrollHelper.centerFocus[fn](elem, horiz); + }); + } + onInputCommand(e) { switch (e.detail.command) { case 'left': - moveCheckboxFocus(e.target, -1); + this.moveCheckboxFocus(e.target, -1); e.preventDefault(); break; case 'right': - moveCheckboxFocus(e.target, 1); + this.moveCheckboxFocus(e.target, 1); e.preventDefault(); break; default: break; } } - - function FilterMenu() { - - } - - function bindCheckboxInput(context, on) { + bindCheckboxInput(context, on) { var elems = context.querySelectorAll('.checkboxList-verticalwrap'); for (var i = 0, length = elems.length; i < length; i++) { if (on) { - inputManager.on(elems[i], onInputCommand); + inputManager.on(elems[i], this.onInputCommand); } else { - inputManager.off(elems[i], onInputCommand); + inputManager.off(elems[i], this.onInputCommand); } } } - - FilterMenu.prototype.show = function (options) { - return new Promise(function (resolve, reject) { - require(['text!./filtermenu.template.html'], function (template) { + show(options) { + return new Promise( (resolve, reject) => { + import('text!./filtermenu.template.html').then(({ default: template }) => { var dialogOptions = { removeOnClose: true, scrollY: false }; - if (layoutManager.tv) { dialogOptions.size = 'fullscreen'; } else { @@ -251,17 +249,16 @@ define(['require', 'dom', 'focusManager', 'dialogHelper', 'loading', 'apphost', } } - initEditor(dlg, options.settings); - loadDynamicFilters(dlg, options); - - bindCheckboxInput(dlg, true); + this.initEditor(dlg, options.settings); + this.loadDynamicFilters(dlg, options); + this.bindCheckboxInput(dlg, true); dlg.querySelector('.btnCancel').addEventListener('click', function () { dialogHelper.close(dlg); }); if (layoutManager.tv) { - centerFocus(dlg.querySelector('.formDialogContent'), false, true); + this.centerFocus(dlg.querySelector('.formDialogContent'), false, true); } var submitted; @@ -270,26 +267,24 @@ define(['require', 'dom', 'focusManager', 'dialogHelper', 'loading', 'apphost', submitted = true; }, true); - dialogHelper.open(dlg).then(function () { - bindCheckboxInput(dlg, false); + dialogHelper.open(dlg).then( () => { + this.bindCheckboxInput(dlg, false); if (layoutManager.tv) { - centerFocus(dlg.querySelector('.formDialogContent'), false, false); + this.centerFocus(dlg.querySelector('.formDialogContent'), false, false); } if (submitted) { //if (!options.onChange) { - saveValues(dlg, options.settings, options.settingsKey); - resolve(); + this.saveValues(dlg, options.settings, options.settingsKey); + return resolve(); //} - return; } - - reject(); + return resolve(); }); }); }); - }; + } +} - return FilterMenu; -}); +export default FilterMenu; From e434eebf496a1b4da01fc61715b0c702414e50b6 Mon Sep 17 00:00:00 2001 From: Cameron Date: Tue, 11 Aug 2020 18:27:02 +0100 Subject: [PATCH 151/301] Update package.json Co-authored-by: Dmitry Lyzo <56478732+dmitrylyzo@users.noreply.github.com> --- package.json | 1 - 1 file changed, 1 deletion(-) diff --git a/package.json b/package.json index b7800ebd62..b7595b3804 100644 --- a/package.json +++ b/package.json @@ -166,7 +166,6 @@ "src/components/sanatizefilename.js", "src/components/scrollManager.js", "src/plugins/experimentalWarnings/plugin.js", - "src/plugins/htmlVideoPlayer/plugin.js", "src/plugins/sessionPlayer/plugin.js", "src/plugins/htmlAudioPlayer/plugin.js", "src/plugins/chromecastPlayer/plugin.js", From 0a9632b53170fb5502e905cb24f5ba454451330b Mon Sep 17 00:00:00 2001 From: Cameron Date: Tue, 11 Aug 2020 18:34:28 +0100 Subject: [PATCH 152/301] Update recordingeditor.js --- src/components/recordingcreator/recordingeditor.js | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/src/components/recordingcreator/recordingeditor.js b/src/components/recordingcreator/recordingeditor.js index 6fe104b57f..5bd3d73c67 100644 --- a/src/components/recordingcreator/recordingeditor.js +++ b/src/components/recordingcreator/recordingeditor.js @@ -21,6 +21,12 @@ let currentItemId; let currentServerId; let currentResolve; +function deleteTimer(apiClient, timerId) { + return import('recordingHelper').then(({ default: recordingHelper }) => { + recordingHelper.cancelTimerWithConfirmation(timerId, apiClient.serverId()); + }); +} + function renderTimer(context, item, apiClient) { context.querySelector('#txtPrePaddingMinutes').value = item.PrePaddingSeconds / 60; context.querySelector('#txtPostPaddingMinutes').value = item.PostPaddingSeconds / 60; @@ -58,7 +64,7 @@ function init(context) { context.querySelector('.btnCancelRecording').addEventListener('click', function () { const apiClient = connectionManager.getApiClient(currentServerId); - (apiClient, currentItemId).then(function () { + deleteTimer(apiClient, currentItemId).then(function () { closeDialog(true); }); }); From e7eb567b0fd20a254c92a3adfccc79298beb9667 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Luk=C3=A1=C5=A1=20Kucharczyk?= Date: Tue, 11 Aug 2020 14:55:29 +0000 Subject: [PATCH 153/301] Translated using Weblate (Czech) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/cs/ --- src/strings/cs.json | 38 +++++++++++++++++++------------------- 1 file changed, 19 insertions(+), 19 deletions(-) diff --git a/src/strings/cs.json b/src/strings/cs.json index 160362c7fe..85d4b175f2 100644 --- a/src/strings/cs.json +++ b/src/strings/cs.json @@ -109,7 +109,7 @@ "Collections": "Kolekce", "CommunityRating": "Hodnocení komunity", "Composer": "Skladatel", - "ConfigureDateAdded": "Konfigurace přidání data je definována v nastavení knihovny na nástěnce serveru Jellyfin", + "ConfigureDateAdded": "Konfigurace přidání data je definována v nastavení knihovny na nástěnce", "ConfirmDeleteImage": "Odstranit obrázek?", "ConfirmDeleteItem": "Smazáním položky odstraníte soubor jak z knihovny médií tak ze souborového systému. Jste si jisti, že chcete pokračovat?", "ConfirmDeleteItems": "Odstraněním těchto položek odstraníte vaše média jak z knihovny médií, tak i ze souborového systému. Jste si jisti, že chcete pokračovat?", @@ -172,10 +172,10 @@ "EndsAtValue": "Končí v {0}", "Episodes": "Epizody", "ErrorAddingListingsToSchedulesDirect": "Došlo k chybě při přidání sestavy do účtu vašeho Direct plánovače. Direct plánovač umožňuje pouze omezený počet sestav na účet. Možná se budete muset přihlásit do webových stránek Direct plánovače a před pokračováním odstranit ostatní výpisy ze svého účtu.", - "ErrorAddingMediaPathToVirtualFolder": "Při přidávání cesty k médiím došlo k chybě. Zkontrolujte zda je zadaná složka platná a zda má server Jellyfin k této složce přístup.", + "ErrorAddingMediaPathToVirtualFolder": "Při přidávání cesty k médiím došlo k chybě. Zkontrolujte zda je zadaná složka platná a zda má Jellyfin k této složce přístup.", "ErrorAddingTunerDevice": "Došlo k chybě při přidání zařízení tuneru. Prosím, ujistěte se, že je přístupný a zkuste to znovu.", "ErrorAddingXmlTvFile": "Nastala chyba při přístupu k XMLTV souboru. Ujistěte se, že soubor existuje a zkuste jej znovu otevřít.", - "ErrorDeletingItem": "Při odstranění položky ze serveru Jellyfin došlo k chybě. Zkontrolujte prosím, zda má server Jellyfin oprávnění k zápisu do složky médií, a zkuste to prosím znovu.", + "ErrorDeletingItem": "Při odstranění položky ze serveru došlo k chybě. Zkontrolujte prosím, zda má Jellyfin oprávnění k zápisu do složky médií, a zkuste to prosím znovu.", "ErrorGettingTvLineups": "Došlo k chybě při stahování TV sestav. Ujistěte se prosím, že zadané informace jsou správné a zkuste to znovu.", "ErrorStartHourGreaterThanEnd": "Čas ukončení musí být větší než čas startu.", "ErrorPleaseSelectLineup": "Vyberte prosím sestavu a zkuste to znovu. Pokud nejsou k dispozici žádné sestavy, zkontrolujte, zda je vaše uživatelské jméno, heslo a poštovní směrovací číslo správné.", @@ -429,7 +429,7 @@ "LabelAudio": "Zvuk", "LabelAudioLanguagePreference": "Preferovaný jazyk zvuku:", "LabelBindToLocalNetworkAddress": "Vázat na místní síťovou adresu:", - "LabelBindToLocalNetworkAddressHelp": "Změní místní IP adresu serveru HTTP. Pokud je ponecháno prázdné, server bude svázán se všemi dostupnými adresami. Změna této hodnoty vyžaduje restartování serveru Jellyfin.", + "LabelBindToLocalNetworkAddressHelp": "Změní místní IP adresu serveru HTTP. Pokud je ponecháno prázdné, server bude svázán se všemi dostupnými adresami. Změna této hodnoty vyžaduje restartování.", "LabelBirthDate": "Datum narození:", "LabelBirthYear": "Rok narození:", "LabelBlastMessageInterval": "Doba zobrazení zprávy", @@ -479,7 +479,7 @@ "LabelEnableBlastAliveMessages": "Vytroubit zprávu do světa", "LabelEnableBlastAliveMessagesHelp": "Tuto možnost povolte, pokud není server zjistitelný jinými UPnP zařízeními v síti.", "LabelEnableDlnaClientDiscoveryInterval": "Interval pro vyhledání klienta", - "LabelEnableDlnaClientDiscoveryIntervalHelp": "Určuje interval mezi vyhledáváním SSDP, které Jellyfin provádí.", + "LabelEnableDlnaClientDiscoveryIntervalHelp": "Určuje interval mezi vyhledáváním SSDP.", "LabelEnableDlnaDebugLogging": "Povolit DLNA protokolování (pro ladění)", "LabelEnableDlnaDebugLoggingHelp": "Vytváří velké soubory se záznamy a doporučuje se používat pouze pro potřeby odstraňování problémů.", "LabelEnableDlnaPlayTo": "Povolit DLNA přehrávání", @@ -744,13 +744,13 @@ "MessageConfirmProfileDeletion": "Jste si jisti, že chcete smazat tento profil?", "MessageConfirmRecordingCancellation": "Zrušit nahrávání?", "MessageConfirmRemoveMediaLocation": "Jste si jist, že chcete odstranit toto umístění?", - "MessageConfirmRestart": "Opravdu chcete restartovat server Jellyfin?", - "MessageConfirmRevokeApiKey": "Opravdu chcete zrušit tento klíč k API? Připojení dané aplikace k serveru Jellyfin bude náhle ukončeno.", + "MessageConfirmRestart": "Opravdu chcete restartovat Jellyfin?", + "MessageConfirmRevokeApiKey": "Opravdu chcete zrušit tento klíč k API? Připojení dané aplikace k tomuto serveru bude náhle ukončeno.", "MessageConfirmShutdown": "Jste si jisti, že chcete server vypnout?", "MessageContactAdminToResetPassword": "Kontaktujte, prosím, vašeho systémového administrátora k obnovení vašeho hesla.", "MessageCreateAccountAt": "Vytvořit účet v {0}", "MessageDeleteTaskTrigger": "Opravdu si přejete odebrat spouštění úlohy?", - "MessageDirectoryPickerBSDInstruction": "V operačním systému FreeBSD či FreeNAS může být nutné nakonfigurovat úložiště přímo pomocí izolační funkce jail, aby k němu měl Jellyfin přístup.", + "MessageDirectoryPickerBSDInstruction": "U BSD může být potřeba nakonfigurovat úložiště přímo pomocí izolační funkce jail v FreeNAS, aby měl Jellyfin přístup k vašim médiím.", "MessageDirectoryPickerLinuxInstruction": "Pro systémy Linux jako Arch Linux, CentOS, Debian, Fedora, OpenSUSE nebo Ubuntu musíte udělit uživateli služby oprávnění alespoň pro čtení.", "MessageDownloadQueued": "Stažení zařazeno.", "MessageFileReadError": "Došlo k chybě při čtení souboru. Prosím zkuste to znovu.", @@ -770,7 +770,7 @@ "MessagePlayAccessRestricted": "Přehrávání tohoto obsahu je aktuálně omezeno. Další informace získáte od správce serveru.", "MessagePleaseEnsureInternetMetadata": "Prosím zkontrolujte, zda máte povoleno stahování metadat z internetu.", "MessagePluginConfigurationRequiresLocalAccess": "Pro konfiguraci zásuvného modulu se přihlaste přímo na lokální server.", - "MessagePluginInstallDisclaimer": "Zásuvné moduly vytvořené členy komunity Jellyfin jsou skvělým způsobem, jak si zlepšit prožitek z používání projektu Jellyfin. Před instalací se prosím seznamte se všemi dopady, které mohou doplňky mít na server Jellyfin, např.: pomalejší skenování knihovny, další zpracování na pozadí nebo snížení stability systému.", + "MessagePluginInstallDisclaimer": "Zásuvné moduly vytvořené členy komunity jsou skvělým způsobem, jak si zlepšit prožitek pomocí dalších funkcí. Před instalací se prosím seznamte se všemi dopady, které mohou doplňky na server mít, např.: pomalejší skenování knihovny, delší zpracování na pozadí nebo snížená stabilita systému.", "MessageReenableUser": "Viz níže pro znovuzapnutí", "MessageSettingsSaved": "Nastavení uloženo.", "MessageTheFollowingLocationWillBeRemovedFromLibrary": "Z vaší knihovny budou odstraněny následující zdroje médií:", @@ -920,7 +920,7 @@ "OptionRuntime": "Délka", "OptionSaturday": "Sobota", "OptionSaveMetadataAsHidden": "Ukládat metadata a obrázky jako skryté soubory", - "OptionSaveMetadataAsHiddenHelp": "Změna se projeví u všech nově uložených metadat. Existující soubory metadat se aktualizují při příštím uložení serverem Jellyfin.", + "OptionSaveMetadataAsHiddenHelp": "Změna se projeví u všech nově uložených metadat. Existující soubory metadat se aktualizují při příštím uložení serverem.", "OptionSpecialEpisode": "Speciální", "OptionSubstring": "subřetězec", "OptionSunday": "Neděle", @@ -965,7 +965,7 @@ "PleaseAddAtLeastOneFolder": "Přidejte prosím nejméně jednu složku do této knihovny pomocí tlačítka Přidat.", "PleaseConfirmPluginInstallation": "Pro potvrzení, že jste si přečetli text výše a chcete pokračovat v instalaci zásuvných modulů, klikněte na tlačítko OK.", "PleaseEnterNameOrId": "Prosím, zadejte název nebo externí Id.", - "PleaseRestartServerName": "Prosím restartuje server Jellyfin - {0}.", + "PleaseRestartServerName": "Prosím restartuje Jellyfin na serveru {0}.", "PleaseSelectTwoItems": "Vyberte nejméně dvě položky prosím.", "Premiere": "Premiéra", "Premieres": "Premiéry", @@ -1021,9 +1021,9 @@ "SeriesRecordingScheduled": "Plán nahrávání seriálu.", "SeriesSettings": "Nastavení seriálu", "SeriesYearToPresent": "{0} - Současnost", - "ServerNameIsRestarting": "Server Jellyfin - {0} se restartuje.", - "ServerNameIsShuttingDown": "Server Jellyfin - {0} se vypíná.", - "ServerUpdateNeeded": "Tento server Jellyfin je nutné aktualizovat. Chcete-li stáhnout nejnovější verzi, navštivte prosím {0}", + "ServerNameIsRestarting": "Server {0} se restartuje.", + "ServerNameIsShuttingDown": "Server {0} se vypíná.", + "ServerUpdateNeeded": "Tento server je nutné aktualizovat. Chcete-li stáhnout nejnovější verzi, navštivte prosím {0}", "Settings": "Nastavení", "SettingsSaved": "Nastavení uloženo.", "SettingsWarning": "Změna těchto hodnot může způsobit nestabilitu nebo selhání připojení. Pokud narazíte na nějaké problémy, doporučujeme jej změnit zpět na výchozí hodnotu.", @@ -1154,7 +1154,7 @@ "AllowMediaConversionHelp": "Povolit nebo zakázat přístup k funkci konverze médií.", "AllowOnTheFlySubtitleExtraction": "Povolit extrahování titulků za běhu", "AllowOnTheFlySubtitleExtractionHelp": "Vložené titulky je možné vytáhnout z videa a dodat klientům v textové podobě, aby nebylo nutné video překódovat. Na některých systémech to může trvat dlouho a způsobit zasekávání videa. Pokud tuto funkci vypnete a klientské zařízení vložené titulky nepodporuje, při překódování budou vypáleny přímo do obrazu.", - "AllowRemoteAccess": "Povolit vzdálené připojení k tomuto serveru Jellyfin.", + "AllowRemoteAccess": "Povolit vzdálené připojení k tomuto serveru.", "AllowRemoteAccessHelp": "Pokud není zapnuto, všechna vzdálená připojení budou blokována.", "AllowedRemoteAddressesHelp": "Seznam IP adres nebo síťových masek oddělených čárkou pro sítě, ze kterých se lze vzdáleně připojit. Pokud necháte prázdné, všechny adresy budou povoleny.", "AnyLanguage": "Jakýkoli jazyk", @@ -1247,7 +1247,7 @@ "LabelLanNetworks": "Sítě LAN:", "LabelMaxStreamingBitrate": "Maximální kvalita streamování:", "LabelMetadata": "Metadata:", - "LabelOptionalNetworkPathHelp": "Pokud je tato složka sdílena ve vaší síti, zadání cesty ke sdílené složce umožní aplikacím Jellyfin na jiných zařízeních přímý přístup k souborům s médii. Například {0} nebo {1}.", + "LabelOptionalNetworkPathHelp": "Pokud je tato složka sdílena ve vaší síti, zadání cesty ke sdílené složce umožní klientům na jiných zařízeních přímý přístup k souborům s médii. Například {0} nebo {1}.", "LabelPersonRole": "Úloha:", "LabelPlaylist": "Playlist:", "LabelReasonForTranscoding": "Důvod pro překódování:", @@ -1327,7 +1327,7 @@ "OptionProtocolHttp": "HTTP", "OptionRequirePerfectSubtitleMatchHelp": "Vyžadování dokonalé shody filtruje titulky tak, aby obsahovaly pouze ty, které byly testovány a ověřeny s vaším přesným videosouborem. Zrušení zaškrtnutí tohoto políčka zvýší pravděpodobnost stahování titulků, ale zvýší pravděpodobnost chybného nebo nesprávného textu titulků.", "PasswordResetProviderHelp": "Zvolte poskytovatele resetování hesla, který bude použit při žádosti tohoto uživatele o resetování hesla.", - "MessagePluginInstalled": "Zásuvný modul byl úspěšně nainstalován. Server Jellyfin bude nutné restartovat, aby se změny projevily.", + "MessagePluginInstalled": "Zásuvný modul byl úspěšně nainstalován. Server bude nutné restartovat, aby se změny projevily.", "PreferEmbeddedTitlesOverFileNames": "Preferovat vložené názvy nad názvy souborů", "PreferEmbeddedTitlesOverFileNamesHelp": "Toto určuje výchozí název zobrazení, pokud nejsou k dispozici žádná metadata z internetu nebo místní metadata.", "Raised": "Vystupující", @@ -1336,7 +1336,7 @@ "SaveSubtitlesIntoMediaFoldersHelp": "Ukládání titulků vedle video souborů umožní jejich snadnější správu.", "ScanLibrary": "Skenovat knihovnu", "SeriesDisplayOrderHelp": "Seřadit epizody podle data vysílání, pořadí DVD nebo absolutního číslování.", - "ServerRestartNeededAfterPluginInstall": "Server Jellyfin bude nutné po instalaci zásuvného modulu restartovat.", + "ServerRestartNeededAfterPluginInstall": "Jellyfin bude nutné po instalaci zásuvného modulu restartovat.", "ShowAdvancedSettings": "Zobrazit rozšířená nastavení", "ShowTitle": "Zobrazit název", "ShowYear": "Zobrazit rok", @@ -1440,7 +1440,7 @@ "DailyAt": "Denně v {0}", "PersonRole": "{0}", "ListPaging": "{0}-{1} ze {2}", - "WriteAccessRequired": "Server Jellyfin vyžaduje oprávnění pro zápis do této složky. Zkontrolujte oprávnění a zkuste to znovu.", + "WriteAccessRequired": "Jellyfin vyžaduje oprávnění pro zápis do této složky. Zkontrolujte oprávnění a zkuste to znovu.", "PathNotFound": "Cesta nebyla nalezena. Zkontrolujte, zda je platná a zkuste to znovu.", "WeeklyAt": "V {0} v {1}", "LastSeen": "Naposledy zobrazené {0}", From 3e9106e01b64f905772931bb519046c2b7662712 Mon Sep 17 00:00:00 2001 From: Adam Bokor Date: Tue, 11 Aug 2020 15:40:34 +0000 Subject: [PATCH 154/301] Translated using Weblate (Hungarian) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/hu/ --- src/strings/hu.json | 47 +++++++++++++++++++++++++-------------------- 1 file changed, 26 insertions(+), 21 deletions(-) diff --git a/src/strings/hu.json b/src/strings/hu.json index 3a88ccf9b3..70089ff734 100644 --- a/src/strings/hu.json +++ b/src/strings/hu.json @@ -342,7 +342,7 @@ "MediaInfoResolution": "Felbontás", "MediaInfoSampleRate": "Mintavételi ráta", "MessageAlreadyInstalled": "Ez a verzió már telepítve van.", - "MessageConfirmRestart": "Biztosan újra szeretnéd indítani a Jellyfin Szervert?", + "MessageConfirmRestart": "Biztosan újra szeretnéd indítani a Jellyfint?", "MessageConfirmShutdown": "Biztosan le akarod állítani a Szervert?", "MessageItemsAdded": "Elem hozzáadva.", "MessageNoPluginsInstalled": "Nincs bővítmény telepítve.", @@ -435,7 +435,7 @@ "PlayAllFromHere": "Összes vetítése innen", "PlayCount": "Lejátszások száma", "Played": "Megnézett", - "PleaseRestartServerName": "Kérlek indítsd újra a Jellyfin Szerver-t - {0}.", + "PleaseRestartServerName": "Kérlek indítsd újra a Jellyfint itt: {0}.", "Quality": "Minőség", "RecommendationBecauseYouLike": "Mert tetszett a(z) {0}", "RecommendationBecauseYouWatched": "Amiért megnézted ezt: {0}", @@ -465,9 +465,9 @@ "SearchResults": "A keresés eredménye", "SendMessage": "Üzenet küldés", "SeriesYearToPresent": "{0} - Napjainkig", - "ServerNameIsRestarting": "Jellyfin Szerver - {0} újraindul.", - "ServerNameIsShuttingDown": "Jellyfin Server - {0} leáll.", - "ServerUpdateNeeded": "Ezt a Jellyfin Szervert frissíteni kell. A legújabb verzió letöltéséhez kérjük, látogass el ide {0}", + "ServerNameIsRestarting": "A szerver újraindul itt: {0}.", + "ServerNameIsShuttingDown": "A szerver leáll itt: {0}.", + "ServerUpdateNeeded": "A Jellyfint frissíteni kell. A legújabb verzió letöltéséhez kérjük, látogass el ide {0}", "Settings": "Beállítások", "SettingsSaved": "Beállítások mentve.", "Share": "Megosztás", @@ -563,7 +563,7 @@ "AllComplexFormats": "Minden összetett formátum (ASS, SSA, VOBSUB, PGS, SUB, IDX, ...)", "AllowMediaConversion": "Média konvertálás engedélyezése", "AllowMediaConversionHelp": "Add meg vagy tiltsd le a média konvertálás funkcióhoz való hozzáférést.", - "AllowRemoteAccess": "Engedélyezze a távoli kapcsolatokat a Jellyfin szerverhez.", + "AllowRemoteAccess": "Távoli kapcsolatok engedélyezése ehhez a szerverhez.", "AllowRemoteAccessHelp": "Ha nincs bekapcsolva, minden távoli kapcsolat blokkolva lesz.", "AlwaysPlaySubtitles": "Mindig jelenjen meg", "AnyLanguage": "Bármelyik nyelv", @@ -607,7 +607,7 @@ "ColorSpace": "Színtér", "ColorTransfer": "Színátvitel", "Composer": "Zeneszerző", - "ConfigureDateAdded": "Állítsd be a hozzáadott dátum meghatározását a Jellyfin Szerver Vezérlőpultjában a Könyvtár beállításai alatt", + "ConfigureDateAdded": "Állítsd be a hozzáadott dátum meghatározását a Vezérlőpultban a Könyvtár beállításai alatt", "ConfirmDeleteImage": "Kép törlése?", "ConfirmDeleteItem": "Az elem törlése mind a fájlrendszerből, mind a médiakönyvtárból törlődik. Biztosan folytatni akarod?", "ConfirmDeleteItems": "Az elem törlése mind a fájlrendszerből, mind a médiakönyvtárból törlődik. Biztosan folytatni akarod?", @@ -652,10 +652,10 @@ "EnablePhotos": "Fotók megjelenítése", "EnablePhotosHelp": "A fényképeket a médiafájlok mellett észleli és megjeleníti.", "Ended": "Befejeződött", - "ErrorAddingMediaPathToVirtualFolder": "Hiba történt a média elérésekor. Kérlek győződjön meg róla, hogy az elérési út érvényes és a Jellyfin szerver hozzáfér az adott helyhez.", + "ErrorAddingMediaPathToVirtualFolder": "Hiba történt a média elérésekor. Kérlek győződj meg róla, hogy az elérési út érvényes és a szerver hozzáfér a megadott helyhez.", "ErrorAddingTunerDevice": "Hiba történt a tuner eszköz hozzáadásakor. Kérlek győződj meg róla, hogy az eszköz elérhető és próbáld meg újra.", "ErrorAddingXmlTvFile": "Hiba történt az XMLTV fájl elérésekor. Győződj meg róla, hogy a fájl létezik és próbáld meg újra.", - "ErrorDeletingItem": "Hiba történt az elem törlése során a Jellyfin Szerverről. Ellenőrizd, hogy a Jellyfin Szerver rendelkezik-e írási jogosultsággal a média mappához és próbálja újra.", + "ErrorDeletingItem": "Hiba történt az elem szerverről való törlése során. Ellenőrizd, hogy a szerver rendelkezik-e írási jogosultsággal a média mappához és próbálja újra.", "ErrorStartHourGreaterThanEnd": "A befejezési időnek nagyobbnak kell lennie mint a kezdési idő.", "ErrorSavingTvProvider": "Hiba történt a TV szolgáltató mentésekor. Kérlek győződj meg róla, hogy elérhető és próbálkozz meg újra.", "EveryNDays": "Minden {0} nap", @@ -810,7 +810,7 @@ "LabelAppNameExample": "Például: Sickbeard, Sonarr", "LabelAutomaticallyRefreshInternetMetadataEvery": "A metaadatok automatikus frissítése az internetről:", "LabelBindToLocalNetworkAddress": "Kötés a helyi hálózati címhez:", - "LabelBindToLocalNetworkAddressHelp": "A helyi IP cím felülbírálása a HTTP szerverhez való csatlakozáshoz. Ha üres marad, a szerver minden elérhető címhez kötődik. Az érték megváltoztatásához a Jellyfin Szerver újraindítása szükséges.", + "LabelBindToLocalNetworkAddressHelp": "A helyi IP cím felülbírálása a HTTP szerverhez való csatlakozáshoz. Ha üres marad, a szerver minden elérhető címhez kötődik. Az érték megváltoztatásához a szerver újraindítása szükséges.", "LabelBirthDate": "Születési dátum:", "LabelBlastMessageInterval": "Élő üzenetintervallum", "LabelBlastMessageIntervalHelp": "Meghatározza másodpercben az üzenetek közötti időtartamot.", @@ -838,7 +838,7 @@ "LabelEnableAutomaticPortMapHelp": "A szerver az UPnP segítségével a routeren megpróbálja automatikusan átirányítani a nyilvános portot a helyi portra. Előfordulhat, hogy egyes router modellek, vagy hálózati konfigurációk esetén ez nem működik. A módosítások újraindítás után lépnek életbe.", "LabelEnableBlastAliveMessagesHelp": "Engedélyezd ezt ha a szerver nem észleli megbízhatóan a hálózat más UPnP-eszközeit.", "LabelEnableDlnaClientDiscoveryInterval": "Kliens felderítési intervallum", - "LabelEnableDlnaClientDiscoveryIntervalHelp": "A Jellyfin által végrehajtott SSDP keresések időtartamát határozza meg másodpercben.", + "LabelEnableDlnaClientDiscoveryIntervalHelp": "A szerver által végrehajtott SSDP keresések időtartamát határozza meg másodpercben.", "LabelEnableDlnaDebugLogging": "DLNA hibakeresési naplózás engedélyezése", "LabelEnableDlnaDebugLoggingHelp": "Ez nagy naplófájlokat hoz létre és csak hibaelhárítás céljából használható.", "LabelEnableDlnaPlayTo": "DLNA Play To engedélyezése", @@ -900,7 +900,7 @@ "LabelNewName": "Új név:", "LabelNewsCategories": "Hírek kategóriái:", "LabelNumber": "Szám:", - "LabelOptionalNetworkPathHelp": "Ha ez a mappa meg van osztva a hálózaton, a hálózati megosztási útvonal megadása lehetővé teszi, hogy a Jellyfin alkalmazások más eszközökön közvetlenül hozzáférjenek a médiafájlokhoz. Például: {0{ vagy {1}.", + "LabelOptionalNetworkPathHelp": "Ha ez a mappa meg van osztva a hálózaton, a hálózati megosztási útvonal megadása lehetővé teszi, hogy a kliensek más eszközökön közvetlenül hozzáférjenek a médiafájlokhoz. Például: {0{ vagy {1}.", "LabelPasswordConfirm": "Jelszó (megerősítés):", "LabelPlaceOfBirth": "Születési hely:", "LabelPostProcessor": "A feldolgozás utáni alkalmazás:", @@ -1012,7 +1012,7 @@ "LabelSpecialSeasonsDisplayName": "Speciális évad megjelenítési neve:", "LanNetworksHelp": "Vesszővel elválasztott lista az IP címekről vagy IP / netmask bejegyzésekről a hálózatokban, amelyeket a helyi hálózaton figyelembe kell venni a sávszélesség korlátozások végrehajtása során. Ha be van állítva, az összes többi IP cím külső hálózaton lesz, és a külső sávszélesség korlátozások szabálya alá tartozik. Ha üres marad, csak a szerver alhálózata tekinthető a helyi hálózatnak.", "LiveBroadcasts": "Élő adások", - "MessageConfirmRevokeApiKey": "Biztosan visszavonod ezt az API kulcsot? Az alkalmazás csatlakozása a Jellyfin Szerverhez hirtelen megszűnik.", + "MessageConfirmRevokeApiKey": "Biztosan visszavonod ezt az API kulcsot? Az alkalmazás csatlakozása a szerverhez hirtelen megszűnik.", "MessageDirectoryPickerLinuxInstruction": "Az Arch Linux, CentOS, Debian, Fedora, openSUSE vagy Ubuntu Linux operációs rendszereken a Jellyfin szolgáltatás felhasználójának legalább olvasási hozzáférést kell biztosítania a tárolóhelyekhez.", "MessageForgotPasswordInNetworkRequired": "Kérlek próbáld meg újra a jelszó visszaállítási folyamatot az otthoni hálózatban.", "MessageNoMovieSuggestionsAvailable": "Jelenleg nincsenek filmajánlatok. Kezdj el nézni és értékelni a filmeket, majd térj vissza, hogy megtekinthesd az ajánlásokat.", @@ -1020,7 +1020,7 @@ "MessagePlayAccessRestricted": "A tartalom lejátszása jelenleg korlátozott. További információért fordulj a Szerver üzemeltetőjéhez.", "MessagePleaseWait": "Kérlek várj. Ez eltarthat egy percet.", "MessagePluginConfigurationRequiresLocalAccess": "A bővítmény beállításához jelentkezz be közvetlenül a helyi szerverre.", - "MessagePluginInstallDisclaimer": "A Jellyfin közösség tagjai által készített bővítmények nagyszerű módot adnak a Jellyfin élményének, funkcióinak bővítéséhez. Telepítés előtt kérlek vedd figyelembe a Jellyfin szerverre gyakorolt hatásokat, mint például a hosszabb könyvtárvizsgálatokat, a további háttérfeldolgozást, vagy akár a rendszer stabilitásának csökkenését.", + "MessagePluginInstallDisclaimer": "A közösség tagjai által készített bővítmények nagyszerű módot adnak a felhasználói élmény bővítéséhez. Telepítés előtt kérlek vedd figyelembe a szerverre gyakorolt hatásokat, mint például a hosszabb könyvtárvizsgálatokat, a további háttérfeldolgozást, vagy akár a rendszer stabilitásának csökkenését.", "MessageReenableUser": "Az újra engedélyezéshez lásd lentebb", "MessageTheFollowingLocationWillBeRemovedFromLibrary": "A következő médiahelyek eltávolításra kerülnek a könyvtáradból:", "MessageUnableToConnectToServer": "Jelenleg nem tudunk csatlakozni a kiválasztott szerverhez. Győződj meg róla, hogy fut és próbáld meg újra.", @@ -1115,7 +1115,7 @@ "OptionRequirePerfectSubtitleMatch": "Csak olyan feliratokat töltsön le, amelyek tökéletesen megfelelnek a videó fájljaimnak", "OptionRequirePerfectSubtitleMatchHelp": "A tökéletes egyezés megköveteli a feliratok szűrését, hogy csak azokat tartalmazzák amelyeket teszteltek és hitelesítettek a pontos videofájljával. Az opció kikapcsolása növeli a felirat találat valószínűségét, de növeli a hibás vagy helytelen felirat szövegének esélyeit is.", "OptionSaveMetadataAsHidden": "Mentse a metaadatokat és a képeket rejtett fájlként", - "OptionSaveMetadataAsHiddenHelp": "Ennek megváltoztatása az új metaadatokra vonatkozik, amelyeket ment. A már meglévő metaadatfájlok frissítése a Jellyfin Server következő mentésekor történik.", + "OptionSaveMetadataAsHiddenHelp": "Ennek a beállításnak a módosítása az ezután történő metaadatok mentését érinti. A meglévő metaadatok a szerver általi következő mentéskor lesznek frissítve.", "OptionTvdbRating": "TVDB értékelés", "OptionWakeFromSleep": "Ébredjen alvásból", "OptionWeekdays": "Hétköznapok", @@ -1137,7 +1137,7 @@ "PleaseConfirmPluginInstallation": "Kérlek kattints az OK gombra, hogy megerősítsd, hogy elolvastad a fentieket és folytatni kívánod a bővítmény telepítését.", "PleaseEnterNameOrId": "Kérlek adj meg egy nevet vagy egy külső ID-t.", "PleaseSelectTwoItems": "Kérlek válassz legalább két elemet.", - "MessagePluginInstalled": "A bővítmény sikeresen telepítve lett. A módosítások életbelépéséhez újra kell indítani a Jellyfin Szerver programot.", + "MessagePluginInstalled": "A bővítmény sikeresen telepítve lett. A módosítások életbelépéséhez újra kell indítani a Jellyfint.", "PreferEmbeddedTitlesOverFileNames": "A fájlnevek helyett előnyben részesíti a beépített címeket", "PreferEmbeddedTitlesOverFileNamesHelp": "Ez határozza meg az alapértelmezett megjelenítési címet, ha nem áll rendelkezésre internetes metaadat vagy helyi metaadat.", "Premiere": "Premier", @@ -1170,7 +1170,7 @@ "SeriesCancelled": "Sorozat törölve.", "SeriesRecordingScheduled": "A sorozatfelvétel ütemezett.", "SeriesSettings": "Sorozat beállítások", - "ServerRestartNeededAfterPluginInstall": "A bővítmény telepítése után újra kell indítani a Jellyfin Szerver-t.", + "ServerRestartNeededAfterPluginInstall": "A bővítmény telepítése után újra kell indítani a Jellyfint.", "SettingsWarning": "Ezen értékek módosítása instabilitást vagy csatlakozási hibákat okozhat. Ha bármilyen probléma merül fel javasoljuk, hogy állítsd vissza őket az alapértelmezettre.", "ShowIndicatorsFor": "Indikátor megjelenítése a következőhöz:", "ShowYear": "Év megjelenítése", @@ -1389,7 +1389,7 @@ "LabelXDlnaDoc": "X-DLNA doc:", "LabelXDlnaCap": "X-DLNA cap:", "MapChannels": "Csatornák feltérképezése", - "PasswordResetProviderHelp": "Válassz egy jelszó-visszaállítási szolgáltatót, amelyet akkor kell használni, amikor a felhasználó jelszó-visszaállítást kér", + "PasswordResetProviderHelp": "Válassz egy jelszó-visszaállítási szolgáltatót, amelyet akkor kell használni, amikor a felhasználó jelszó-visszaállítást kér.", "OptionResElement": "res elem", "OptionReportByteRangeSeekingWhenTranscodingHelp": "Erre olyan készülékek esetében van szükség, amelyek időigénye nem nagyon jó.", "OptionPlainVideoItemsHelp": "Az összes videót a DIDL-ben \"object.item.videoItem\" -ként ábrázolja, nem pedig egy specifikusabb típusként, például \"object.item.videoItem.movie\" .", @@ -1398,7 +1398,7 @@ "OptionEquals": "Egyenlő", "OptionForceRemoteSourceTranscoding": "A távoli médiaforrások (például az élő TV) átkódolásának kényszerítése", "NoCreatedLibraries": "Úgy tűnik még nem hoztál létre egy könyvtárat sem. {0}Szeretnél létrehozni egyet most?{1}", - "MessageDirectoryPickerBSDInstruction": "A BSD esetében valószínűleg konfigurálni kell a FreeNAS Jailben lévő tárolót, hogy a Jellyfin hozzáférhest kapjon.", + "MessageDirectoryPickerBSDInstruction": "A BSD esetében valószínűleg konfigurálni kell a FreeNAS Jailben lévő tárolót, hogy a Jellyfin hozzáférhessen a médiádhoz.", "LabelXDlnaDocHelp": "Meghatározza az X_DLNADOC elem tartalmát az urn: schemas-dlna-org: device-1-0 névtérben.", "LabelXDlnaCapHelp": "Meghatározza az X_DLNACAP elem tartalmát az urn: schemas-dlna-org: eszköz-1-0 névtérben.", "LabelVaapiDeviceHelp": "Ez a render csomópont, amelyet a hardveres gyorsításhoz használunk.", @@ -1431,7 +1431,7 @@ "LastSeen": "Utoljára elérhető {0}", "PersonRole": "mint {0}", "ListPaging": "{0}-{1} / {2}", - "WriteAccessRequired": "A Jellyfin Szerver írási jogosultságot igényel ehhez a könyvtárhoz. Kérjük, ellenőrizd, hogy van-e jogod írni ide, majd próbáld újra.", + "WriteAccessRequired": "A Jellyfin írási jogosultságot igényel ehhez a könyvtárhoz. Kérjük, ellenőrizd, hogy van-e jogod írni ide, majd próbáld újra.", "PathNotFound": "Az elérési út nem található. Kérjük, ellenőrizd, hogy az elérési út megfelelő-e, majd próbáld újra.", "Track": "Szám", "Season": "Évad", @@ -1525,5 +1525,10 @@ "ButtonPlayer": "Lejátszó", "PreviousTrack": "Ugrás az előzőhöz", "NextTrack": "Ugrás a következőre", - "LabelUnstable": "Instabil" + "LabelUnstable": "Instabil", + "SubtitleVerticalPositionHelp": "Annak a sornak a száma, ahol a szöveg megjelenik. A pozitív számok fentről lefelé mutatnak. A negatív számok alulról felfelé mutatnak.", + "Preview": "Előnézet", + "LabelSubtitleVerticalPosition": "Függőleges pozíció:", + "MessageGetInstalledPluginsError": "Hiba történt a jelenleg telepített bővítmények lekérdezése során.", + "MessagePluginInstallError": "Hiba történt a bővítmény telepítése során." } From 96963cb8b67850466727159b6035589b08758a28 Mon Sep 17 00:00:00 2001 From: MrTimscampi Date: Tue, 11 Aug 2020 19:53:11 +0200 Subject: [PATCH 155/301] Wrap appLoader in anonymous function --- src/scripts/apploader.js | 92 ++++++++++++++++++++-------------------- 1 file changed, 47 insertions(+), 45 deletions(-) diff --git a/src/scripts/apploader.js b/src/scripts/apploader.js index e5f85e1119..e98c82e693 100644 --- a/src/scripts/apploader.js +++ b/src/scripts/apploader.js @@ -1,48 +1,50 @@ -function injectScriptElement(src, onload) { - if (!src) { - return; - } - - const script = document.createElement('script'); - if (self.dashboardVersion) { - src += `?v=${self.dashboardVersion}`; - } - script.src = src; - script.setAttribute('async', ''); - - if (onload) { - script.onload = onload; - } - - document.head.appendChild(script); -} - -function loadSite() { - injectScriptElement( - './libraries/alameda.js', - function() { - // onload of require library - injectScriptElement('./scripts/site.js'); +(function() { + function injectScriptElement(src, onload) { + if (!src) { + return; } - ); -} -try { - Promise.resolve(); -} catch (ex) { - // this checks for several cases actually, typical is - // Promise() being missing on some legacy browser, and a funky one - // is Promise() present but buggy on WebOS 2 - window.Promise = undefined; - self.Promise = undefined; -} + const script = document.createElement('script'); + if (self.dashboardVersion) { + src += `?v=${self.dashboardVersion}`; + } + script.src = src; + script.setAttribute('async', ''); -if (!self.Promise) { - // Load Promise polyfill if they are not natively supported - injectScriptElement( - './libraries/npo.js', - loadSite - ); -} else { - loadSite(); -} + if (onload) { + script.onload = onload; + } + + document.head.appendChild(script); + } + + function loadSite() { + injectScriptElement( + './libraries/alameda.js', + function() { + // onload of require library + injectScriptElement('./scripts/site.js'); + } + ); + } + + try { + Promise.resolve(); + } catch (ex) { + // this checks for several cases actually, typical is + // Promise() being missing on some legacy browser, and a funky one + // is Promise() present but buggy on WebOS 2 + window.Promise = undefined; + self.Promise = undefined; + } + + if (!self.Promise) { + // Load Promise polyfill if they are not natively supported + injectScriptElement( + './libraries/npo.js', + loadSite + ); + } else { + loadSite(); + } +})(); From fe237698bfa3bf29be3512c63734bd9b4f52c207 Mon Sep 17 00:00:00 2001 From: Matt Strayer Date: Tue, 11 Aug 2020 14:21:19 -0400 Subject: [PATCH 156/301] only export functions previously declared in prototype --- src/components/filtermenu/filtermenu.js | 405 ++++++++++++------------ 1 file changed, 202 insertions(+), 203 deletions(-) diff --git a/src/components/filtermenu/filtermenu.js b/src/components/filtermenu/filtermenu.js index 4313f31003..0ed19f85c9 100644 --- a/src/components/filtermenu/filtermenu.js +++ b/src/components/filtermenu/filtermenu.js @@ -15,202 +15,201 @@ import 'css!./../formdialog'; import 'emby-button'; import 'flexStyles'; +function onSubmit(e) { + e.preventDefault(); + return false; +} +function renderOptions(context, selector, cssClass, items, isCheckedFn) { + var elem = context.querySelector(selector); + + if (items.length) { + elem.classList.remove('hide'); + } else { + elem.classList.add('hide'); + } + + var html = ''; + + html += items.map(function (filter) { + var itemHtml = ''; + + var checkedHtml = isCheckedFn(filter) ? ' checked' : ''; + itemHtml += ''; + + return itemHtml; + }).join(''); + + elem.querySelector('.filterOptions').innerHTML = html; +} + +function renderDynamicFilters(context, result, options) { + renderOptions(context, '.genreFilters', 'chkGenreFilter', result.Genres, function (i) { + // Switching from | to , + var delimeter = (options.settings.GenreIds || '').indexOf('|') === -1 ? ',' : '|'; + return (delimeter + (options.settings.GenreIds || '') + delimeter).indexOf(delimeter + i.Id + delimeter) !== -1; + }); +} + +function setBasicFilter(context, key, elem) { + var value = elem.checked; + value = value ? value : null; + userSettings.setFilter(key, value); +} +function moveCheckboxFocus(elem, offset) { + var parent = dom.parentWithClass(elem, 'checkboxList-verticalwrap'); + var elems = focusManager.getFocusableElements(parent); + + var index = -1; + for (var i = 0, length = elems.length; i < length; i++) { + if (elems[i] === elem) { + index = i; + break; + } + } + + index += offset; + + index = Math.min(elems.length - 1, index); + index = Math.max(0, index); + + var newElem = elems[index]; + if (newElem) { + focusManager.focus(newElem); + } +} +function centerFocus(elem, horiz, on) { + import('scrollHelper').then(({ default: scrollHelper }) => { + var fn = on ? 'on' : 'off'; + scrollHelper.centerFocus[fn](elem, horiz); + }); +} +function onInputCommand(e) { + switch (e.detail.command) { + case 'left': + moveCheckboxFocus(e.target, -1); + e.preventDefault(); + break; + case 'right': + moveCheckboxFocus(e.target, 1); + e.preventDefault(); + break; + default: + break; + } +} +function saveValues(context, settings, settingsKey) { + var elems = context.querySelectorAll('.simpleFilter'); + var i; + var length; + for (i = 0, length = elems.length; i < length; i++) { + if (elems[i].tagName === 'INPUT') { + setBasicFilter(context, settingsKey + '-filter-' + elems[i].getAttribute('data-settingname'), elems[i]); + } else { + setBasicFilter(context, settingsKey + '-filter-' + elems[i].getAttribute('data-settingname'), elems[i].querySelector('input')); + } + } + + // Video type + var videoTypes = []; + elems = context.querySelectorAll('.chkVideoTypeFilter'); + + for (i = 0, length = elems.length; i < length; i++) { + if (elems[i].checked) { + videoTypes.push(elems[i].getAttribute('data-filter')); + } + } + userSettings.setFilter(settingsKey + '-filter-VideoTypes', videoTypes.join(',')); + + // Series status + var seriesStatuses = []; + elems = context.querySelectorAll('.chkSeriesStatus'); + + for (i = 0, length = elems.length; i < length; i++) { + if (elems[i].checked) { + seriesStatuses.push(elems[i].getAttribute('data-filter')); + } + } + + // Genres + var genres = []; + elems = context.querySelectorAll('.chkGenreFilter'); + + for (i = 0, length = elems.length; i < length; i++) { + if (elems[i].checked) { + genres.push(elems[i].getAttribute('data-filter')); + } + } + userSettings.setFilter(settingsKey + '-filter-GenreIds', genres.join(',')); +} +function bindCheckboxInput(context, on) { + var elems = context.querySelectorAll('.checkboxList-verticalwrap'); + for (var i = 0, length = elems.length; i < length; i++) { + if (on) { + inputManager.on(elems[i], onInputCommand); + } else { + inputManager.off(elems[i], onInputCommand); + } + } +} +function initEditor(context, settings) { + context.querySelector('form').addEventListener('submit', onSubmit); + + var elems = context.querySelectorAll('.simpleFilter'); + var i; + var length; + + for (i = 0, length = elems.length; i < length; i++) { + if (elems[i].tagName === 'INPUT') { + elems[i].checked = settings[elems[i].getAttribute('data-settingname')] || false; + } else { + elems[i].querySelector('input').checked = settings[elems[i].getAttribute('data-settingname')] || false; + } + } + + var videoTypes = settings.VideoTypes ? settings.VideoTypes.split(',') : []; + elems = context.querySelectorAll('.chkVideoTypeFilter'); + + for (i = 0, length = elems.length; i < length; i++) { + elems[i].checked = videoTypes.indexOf(elems[i].getAttribute('data-filter')) !== -1; + } + + var seriesStatuses = settings.SeriesStatus ? settings.SeriesStatus.split(',') : []; + elems = context.querySelectorAll('.chkSeriesStatus'); + + for (i = 0, length = elems.length; i < length; i++) { + elems[i].checked = seriesStatuses.indexOf(elems[i].getAttribute('data-filter')) !== -1; + } + + if (context.querySelector('.basicFilterSection .viewSetting:not(.hide)')) { + context.querySelector('.basicFilterSection').classList.remove('hide'); + } else { + context.querySelector('.basicFilterSection').classList.add('hide'); + } + + if (context.querySelector('.featureSection .viewSetting:not(.hide)')) { + context.querySelector('.featureSection').classList.remove('hide'); + } else { + context.querySelector('.featureSection').classList.add('hide'); + } +} +function loadDynamicFilters(context, options) { + var apiClient = connectionManager.getApiClient(options.serverId); + + var filterMenuOptions = Object.assign(options.filterMenuOptions, { + + UserId: apiClient.getCurrentUserId(), + ParentId: options.parentId, + IncludeItemTypes: options.itemTypes.join(',') + }); + + apiClient.getFilters(filterMenuOptions).then((result) => { + renderDynamicFilters(context, result, options); + }); +} class FilterMenu { - onSubmit(e) { - e.preventDefault(); - return false; - } - renderOptions(context, selector, cssClass, items, isCheckedFn) { - var elem = context.querySelector(selector); - - if (items.length) { - elem.classList.remove('hide'); - } else { - elem.classList.add('hide'); - } - - var html = ''; - - html += items.map(function (filter) { - var itemHtml = ''; - - var checkedHtml = isCheckedFn(filter) ? ' checked' : ''; - itemHtml += ''; - - return itemHtml; - }).join(''); - - elem.querySelector('.filterOptions').innerHTML = html; - } - - renderDynamicFilters(context, result, options) { - this.renderOptions(context, '.genreFilters', 'chkGenreFilter', result.Genres, function (i) { - // Switching from | to , - var delimeter = (options.settings.GenreIds || '').indexOf('|') === -1 ? ',' : '|'; - return (delimeter + (options.settings.GenreIds || '') + delimeter).indexOf(delimeter + i.Id + delimeter) !== -1; - }); - } - loadDynamicFilters(context, options) { - var apiClient = connectionManager.getApiClient(options.serverId); - - var filterMenuOptions = Object.assign(options.filterMenuOptions, { - - UserId: apiClient.getCurrentUserId(), - ParentId: options.parentId, - IncludeItemTypes: options.itemTypes.join(',') - }); - - apiClient.getFilters(filterMenuOptions).then((result) => { - this.renderDynamicFilters(context, result, options); - }); - } - - initEditor(context, settings) { - context.querySelector('form').addEventListener('submit', this.onSubmit); - - var elems = context.querySelectorAll('.simpleFilter'); - var i; - var length; - - for (i = 0, length = elems.length; i < length; i++) { - if (elems[i].tagName === 'INPUT') { - elems[i].checked = settings[elems[i].getAttribute('data-settingname')] || false; - } else { - elems[i].querySelector('input').checked = settings[elems[i].getAttribute('data-settingname')] || false; - } - } - - var videoTypes = settings.VideoTypes ? settings.VideoTypes.split(',') : []; - elems = context.querySelectorAll('.chkVideoTypeFilter'); - - for (i = 0, length = elems.length; i < length; i++) { - elems[i].checked = videoTypes.indexOf(elems[i].getAttribute('data-filter')) !== -1; - } - - var seriesStatuses = settings.SeriesStatus ? settings.SeriesStatus.split(',') : []; - elems = context.querySelectorAll('.chkSeriesStatus'); - - for (i = 0, length = elems.length; i < length; i++) { - elems[i].checked = seriesStatuses.indexOf(elems[i].getAttribute('data-filter')) !== -1; - } - - if (context.querySelector('.basicFilterSection .viewSetting:not(.hide)')) { - context.querySelector('.basicFilterSection').classList.remove('hide'); - } else { - context.querySelector('.basicFilterSection').classList.add('hide'); - } - - if (context.querySelector('.featureSection .viewSetting:not(.hide)')) { - context.querySelector('.featureSection').classList.remove('hide'); - } else { - context.querySelector('.featureSection').classList.add('hide'); - } - } - - saveValues(context, settings, settingsKey) { - var elems = context.querySelectorAll('.simpleFilter'); - var i; - var length; - for (i = 0, length = elems.length; i < length; i++) { - if (elems[i].tagName === 'INPUT') { - this.setBasicFilter(context, settingsKey + '-filter-' + elems[i].getAttribute('data-settingname'), elems[i]); - } else { - this.setBasicFilter(context, settingsKey + '-filter-' + elems[i].getAttribute('data-settingname'), elems[i].querySelector('input')); - } - } - - // Video type - var videoTypes = []; - elems = context.querySelectorAll('.chkVideoTypeFilter'); - - for (i = 0, length = elems.length; i < length; i++) { - if (elems[i].checked) { - videoTypes.push(elems[i].getAttribute('data-filter')); - } - } - userSettings.setFilter(settingsKey + '-filter-VideoTypes', videoTypes.join(',')); - - // Series status - var seriesStatuses = []; - elems = context.querySelectorAll('.chkSeriesStatus'); - - for (i = 0, length = elems.length; i < length; i++) { - if (elems[i].checked) { - seriesStatuses.push(elems[i].getAttribute('data-filter')); - } - } - - // Genres - var genres = []; - elems = context.querySelectorAll('.chkGenreFilter'); - - for (i = 0, length = elems.length; i < length; i++) { - if (elems[i].checked) { - genres.push(elems[i].getAttribute('data-filter')); - } - } - userSettings.setFilter(settingsKey + '-filter-GenreIds', genres.join(',')); - } - setBasicFilter(context, key, elem) { - var value = elem.checked; - value = value ? value : null; - userSettings.setFilter(key, value); - } - moveCheckboxFocus(elem, offset) { - var parent = dom.parentWithClass(elem, 'checkboxList-verticalwrap'); - var elems = focusManager.getFocusableElements(parent); - - var index = -1; - for (var i = 0, length = elems.length; i < length; i++) { - if (elems[i] === elem) { - index = i; - break; - } - } - - index += offset; - - index = Math.min(elems.length - 1, index); - index = Math.max(0, index); - - var newElem = elems[index]; - if (newElem) { - focusManager.focus(newElem); - } - } - centerFocus(elem, horiz, on) { - import('scrollHelper').then(({ default: scrollHelper }) => { - var fn = on ? 'on' : 'off'; - scrollHelper.centerFocus[fn](elem, horiz); - }); - } - onInputCommand(e) { - switch (e.detail.command) { - case 'left': - this.moveCheckboxFocus(e.target, -1); - e.preventDefault(); - break; - case 'right': - this.moveCheckboxFocus(e.target, 1); - e.preventDefault(); - break; - default: - break; - } - } - bindCheckboxInput(context, on) { - var elems = context.querySelectorAll('.checkboxList-verticalwrap'); - for (var i = 0, length = elems.length; i < length; i++) { - if (on) { - inputManager.on(elems[i], this.onInputCommand); - } else { - inputManager.off(elems[i], this.onInputCommand); - } - } - } show(options) { return new Promise( (resolve, reject) => { import('text!./filtermenu.template.html').then(({ default: template }) => { @@ -249,16 +248,16 @@ class FilterMenu { } } - this.initEditor(dlg, options.settings); - this.loadDynamicFilters(dlg, options); + initEditor(dlg, options.settings); + loadDynamicFilters(dlg, options); - this.bindCheckboxInput(dlg, true); + bindCheckboxInput(dlg, true); dlg.querySelector('.btnCancel').addEventListener('click', function () { dialogHelper.close(dlg); }); if (layoutManager.tv) { - this.centerFocus(dlg.querySelector('.formDialogContent'), false, true); + centerFocus(dlg.querySelector('.formDialogContent'), false, true); } var submitted; @@ -267,16 +266,16 @@ class FilterMenu { submitted = true; }, true); - dialogHelper.open(dlg).then( () => { - this.bindCheckboxInput(dlg, false); + dialogHelper.open(dlg).then( function() { + bindCheckboxInput(dlg, false); if (layoutManager.tv) { - this.centerFocus(dlg.querySelector('.formDialogContent'), false, false); + centerFocus(dlg.querySelector('.formDialogContent'), false, false); } if (submitted) { //if (!options.onChange) { - this.saveValues(dlg, options.settings, options.settingsKey); + saveValues(dlg, options.settings, options.settingsKey); return resolve(); //} } From efccf4daccd705e8a1fb2d7beadfe8daca557ecd Mon Sep 17 00:00:00 2001 From: Moritz Date: Tue, 11 Aug 2020 18:05:58 +0000 Subject: [PATCH 157/301] Translated using Weblate (German) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/de/ --- src/strings/de.json | 38 +++++++++++++++++++------------------- 1 file changed, 19 insertions(+), 19 deletions(-) diff --git a/src/strings/de.json b/src/strings/de.json index f37a4e13e5..40035d6a45 100644 --- a/src/strings/de.json +++ b/src/strings/de.json @@ -22,7 +22,7 @@ "AllowMediaConversionHelp": "Erlaube oder unterbinde Zugriff auf die Medienkonvertierung.", "AllowOnTheFlySubtitleExtraction": "Erlaube Untertitelextraktion \"on-the-fly\"", "AllowOnTheFlySubtitleExtractionHelp": "Eingebettete Untertitel können aus Videos extrahiert und in Reintext an Clients gesendet werden, um eine Videotranskodierung zu vermeiden. Auf manchen Systemen kann dieser Vorgang eine lange Zeit in Anspruch nehmen und deswegen währenddessen die Videowiedergabe stoppen. Deaktiviere diese Option, um eingebettete Untertitel während des Videotranskodierens einbrennen zu lassen, wenn sie nicht nativ vom Client unterstützt werden.", - "AllowRemoteAccess": "Erlaube externe Verbindungen zu diesem Jellyfin Server.", + "AllowRemoteAccess": "Erlaube externe Verbindungen zu diesem Server.", "AllowRemoteAccessHelp": "Wenn deaktiviert werden alle externen Verbindungen blockiert.", "AllowedRemoteAddressesHelp": "Kommagetrennte Liste von IP Adressen oder IP/Netzmasken für Netzwerke, für die externe Verbindungen erlaubt sind. Wenn leer, sind alle Adressen erlaubt.", "AlwaysPlaySubtitles": "Immer anzeigen", @@ -119,7 +119,7 @@ "ColorSpace": "Farbraum", "CommunityRating": "Community Bewertung", "Composer": "Komponist", - "ConfigureDateAdded": "Bestimme in den Bibliotheks-Einstellungen des Jellyfin Server Dashboards, wie das Feld \"Hinzugefügt am\" interpretiert werden soll", + "ConfigureDateAdded": "Bestimme in den Bibliotheks-Einstellungen des Dashboards, wie das Feld \"Hinzugefügt am\" interpretiert werden soll", "ConfirmDeleteImage": "Bild löschen?", "ConfirmDeleteItem": "Löschen dieses Eintrages bedeutet das Löschen der Datei und das Entfernen aus der Medien-Bibliothek. Möchtest du wirklich fortfahren?", "ConfirmDeleteItems": "Das Löschen dieser Objekte löscht die Dateien vom Laufwerk und in deiner Medienbibliothek. Bist du wirklich sicher?", @@ -196,10 +196,10 @@ "EndsAtValue": "Endet um {0}", "Episodes": "Episoden", "ErrorAddingListingsToSchedulesDirect": "Ein Fehler trat beim Hinzufügen Ihrer Zusammenstellung zu Ihrem Schedules Direct Konto auf. Schedules Direct erlaubt nur eine begrenzte Anzahl von Zusammenstellungen je Account. Sie sollten sich auf der Website in Ihrem Schedules-Direct Konto einloggen und ein paar Zusammenstellungen von Ihrem Konto löschen bevor Sie fortfahren.", - "ErrorAddingMediaPathToVirtualFolder": "Ein Fehler trat beim Hinzufügen eines Medienverzeichnisses auf. Bitte stellen Sie sicher, dass der Pfad gültig ist und der Jellyfin Server Prozess die notwendigen Zugriffsrechte besitzt.", + "ErrorAddingMediaPathToVirtualFolder": "Ein Fehler trat beim Hinzufügen eines Medienverzeichnisses auf. Bitte stellen Sie sicher, dass der Pfad gültig ist und Jellyfin die notwendigen Zugriffsrechte besitzt.", "ErrorAddingTunerDevice": "Es trat ein Fehler beim hinzufügen eines Tuners auf. Bitte stellen Sie sicher das dieser erreichbar ist und versuchen Sie es erneut.", "ErrorAddingXmlTvFile": "Fehler beim Zugriff auf die XMLTV Datei. Stelle bitte sicher, dass die Datei existiert und versuche es nochmal.", - "ErrorDeletingItem": "Fehler beim Löschen des Mediums vom Jellyfin Server. Bitte stelle sicher dass der Jellyfin Server Schreibzugriff auf den Dateiordner hat und versuche es erneut.", + "ErrorDeletingItem": "Fehler beim Löschen des Mediums vom Server. Bitte stelle sicher, dass Jellyfin Schreibzugriff auf den Dateiordner hat und versuche es erneut.", "ErrorGettingTvLineups": "Ein Fehler trat beim Herunterladen des Fernsehprogramms auf. Bitte stellen Sie sicher, dass Ihre Informationen korrekt sind und versuchen Sie es erneut.", "ErrorStartHourGreaterThanEnd": "Die Endzeit muss größer als die Startzeit sein.", "ErrorPleaseSelectLineup": "Bitte wählen Sie ein TV Programm und versuchen Sie es erneut. Wenn keine Programme verfügbar sind prüfen Sie bitte Benutzername, Passwort und Ihre Postleitzahl.", @@ -473,7 +473,7 @@ "LabelAudioLanguagePreference": "Bevorzugte Audiosprache:", "LabelAutomaticallyRefreshInternetMetadataEvery": "Aktualisiere Metadaten automatisch aus dem Internet:", "LabelBindToLocalNetworkAddress": "Binde an lokale Netzwerkadresse:", - "LabelBindToLocalNetworkAddressHelp": "Überschreibt die lokale IP Adresse für den HTTP Server. Wenn leer, wird der Server an alle verfügbaren Adressen gebunden. Änderungen benötigen einen Neustart des Jellyfin Servers.", + "LabelBindToLocalNetworkAddressHelp": "Überschreibt die lokale IP-Adresse für den HTTP Server. Wenn leer, wird der Server an alle verfügbaren Adressen gebunden. Änderungen benötigen einen Neustart.", "LabelBirthDate": "Geburtsdatum:", "LabelBirthYear": "Geburtsjahr:", "LabelBlastMessageInterval": "Alive Meldungsintervall", @@ -531,7 +531,7 @@ "LabelEnableBlastAliveMessages": "Erzeuge Alive Meldungen", "LabelEnableBlastAliveMessagesHelp": "Aktiviere dies, wenn der Server nicht zuverlässig von anderen UPnP Geräten in ihrem Netzwerk erkannt wird.", "LabelEnableDlnaClientDiscoveryInterval": "Client-Entdeckungs Intervall", - "LabelEnableDlnaClientDiscoveryIntervalHelp": "Ermittelt die Zeit in Sekunden zwischen SSDP Suchanfragen die durch Jellyfin ausgeführt wurden.", + "LabelEnableDlnaClientDiscoveryIntervalHelp": "Ermittelt die Zeit in Sekunden zwischen SSDP Suchanfragen.", "LabelEnableDlnaDebugLogging": "Aktiviere DLNA Debug Logging", "LabelEnableDlnaDebugLoggingHelp": "Erzeugt große Logdateien und sollte nur zur Fehlerbehebung benutzt werden.", "LabelEnableDlnaPlayTo": "Aktiviere DLNA Play To", @@ -646,7 +646,7 @@ "LabelNumberOfGuideDays": "Anzahl von Tagen für die Programminformationen geladen werden sollen:", "LabelNumberOfGuideDaysHelp": "Das laden von zusätzlichen Programmdaten bietet einen besseren Überblick und die Möglichkeit weiter in die Zukunft zu planen. Aber es wird länger dauern alles herunterzuladen. Auto wählt auf Grundlage der Kanalanzahl.", "LabelOptionalNetworkPath": "Geteilter Netzwerkordner:", - "LabelOptionalNetworkPathHelp": "Wenn dieser Ordner in deinem Netzwerk geteilt wird, kann die Weitergabe des Netzwerkpfades Jellyfin Apps auf anderen Geräten direkten Zugang zu den Mediendateien ermöglichen. Beispielsweise {0} oder {1}.", + "LabelOptionalNetworkPathHelp": "Wenn dieser Ordner in deinem Netzwerk geteilt wird, kann die Weitergabe des Netzwerkpfades Clients auf anderen Geräten direkten Zugang zu den Mediendateien ermöglichen. Beispielsweise {0} oder {1}.", "LabelOriginalAspectRatio": "Original Seitenverhältnis:", "LabelOriginalTitle": "Original Titel:", "LabelOverview": "Übersicht:", @@ -807,13 +807,13 @@ "MessageConfirmProfileDeletion": "Bist du dir sicher, dass du dieses Profil löschen möchtest?", "MessageConfirmRecordingCancellation": "Aufnahme abbrechen?", "MessageConfirmRemoveMediaLocation": "Bist du dir sicher diese Medienquelle entfernen zu wollen?", - "MessageConfirmRestart": "Möchten Sie Jellyfin Server wirklich neu starten?", - "MessageConfirmRevokeApiKey": "Möchten Sie diesen API Schlüssel wirklich löschen? Die Verbindung der Anwendung zum Jellyfin Server wird sofort unterbrochen.", + "MessageConfirmRestart": "Möchten Sie Jellyfin wirklich neu starten?", + "MessageConfirmRevokeApiKey": "Möchten Sie diesen API Schlüssel wirklich löschen? Die Verbindung der Anwendung zum Server wird sofort unterbrochen.", "MessageConfirmShutdown": "Möchten Sie den Server wirklich herunterfahren?", "MessageContactAdminToResetPassword": "Bitte kontaktiere deinen Systemadministrator, um dein Passwort zurücksetzen zu lassen.", "MessageCreateAccountAt": "Erstellen Sie ein Konto bei {0}", "MessageDeleteTaskTrigger": "Bist du dir sicher, dass du diesen Aufgabenauslöser entfernen möchtest?", - "MessageDirectoryPickerBSDInstruction": "Für BSD müssen Sie ggf. Speicherplatz auf Ihrem FreeNAS Jail für Empby freigeben.", + "MessageDirectoryPickerBSDInstruction": "Für BSD müssen Sie ggf. Speicherplatz in deinem FreeNAS Jail konfigurieren, damit Jellyfin auf deine Medien zugreifen kann.", "MessageDirectoryPickerLinuxInstruction": "Für Linux auf Arch Linux, CentOS, Debian, Fedora, openSUSE oder Ubuntu muss der Service Benutzer mindestens lesenden Zugriff auf die Speicherorte der Medien besitzen.", "MessageDownloadQueued": "Download eingereiht.", "MessageEnablingOptionLongerScans": "Die Aktivierung dieser Option kann erheblich längere Bibliotheks-Scans verursachen.", @@ -835,7 +835,7 @@ "MessagePleaseEnsureInternetMetadata": "Bitte sicherstellen, dass das Herunterladen von Internet Metadaten aktiviert ist.", "MessagePleaseWait": "Bitte warten, dies kann eine Minute dauern.", "MessagePluginConfigurationRequiresLocalAccess": "Melde dich bitte direkt an deinem lokalen Server an, um dieses Plugin konfigurieren zu können.", - "MessagePluginInstallDisclaimer": "Plugins aus der Jellyfin Community sind eine gute Möglichkeit um Jellyfin mit weiteren Funktionen und Vorteilen aufzuwerten. Bevor Sie diese jedoch installieren, seien Sie sich den daraus resultierenden möglichen Umständen für Jellyfin bewusst. Dies können z.B. längere Bibliotheken Scans, weiterführende Verarbeitung von Daten im Hintergrund sowie Systeminstabilität sein.", + "MessagePluginInstallDisclaimer": "Plugins aus der Community sind eine gute Möglichkeit um dein Erlebnis mit weiteren Funktionen und Vorteilen aufzuwerten. Bevor du diese installierst, sei dir den daraus resultierenden möglichen Umständen für deinen Server bewusst. Dies können z.B. längere Bibliotheken Scans, weiterführende Verarbeitung von Daten im Hintergrund sowie Systeminstabilität sein.", "MessageReenableUser": "Für Reaktivierung schauen Sie unten", "MessageSettingsSaved": "Einstellungen gespeichert.", "MessageTheFollowingLocationWillBeRemovedFromLibrary": "Die folgenden Medienverzeichnisse werden aus der Bibliothek entfernt:", @@ -985,7 +985,7 @@ "OptionRuntime": "Dauer", "OptionSaturday": "Samstag", "OptionSaveMetadataAsHidden": "Speichere Metadaten und Bilder als versteckte Dateien", - "OptionSaveMetadataAsHiddenHelp": "Änderungen werden sich auf neue Metadaten angewendet. Bereits existierende Metadaten werden bei der nächsten Speicherung des Jellyfin Servers auf den neusten Stand gebracht.", + "OptionSaveMetadataAsHiddenHelp": "Änderungen werden sich auf neue Metadaten angewendet. Bereits existierende Metadaten werden bei der nächsten Speicherung des Servers auf den neusten Stand gebracht.", "OptionSunday": "Sonntag", "OptionThursday": "Donnerstag", "OptionTuesday": "Dienstag", @@ -1026,9 +1026,9 @@ "PleaseAddAtLeastOneFolder": "Bitte fügen Sie mindestens ein Verzeichniss zur Bibliothek durch Klicken der \"Hinzufügen\"-Schaltfläche hinzu.", "PleaseConfirmPluginInstallation": "Bitte bestätigen Sie mit OK, dass Sie den oben stehenden Text gelesen haben und die Installation des Plugins fortführen möchten.", "PleaseEnterNameOrId": "Bitte gib einen Namen oder eine externe ID an.", - "PleaseRestartServerName": "Bitte starte Jellyfin Server - {0} neu.", + "PleaseRestartServerName": "Bitte starte Jellyfin an {0} neu.", "PleaseSelectTwoItems": "Bitte wähle mindestens zwei Optionen aus.", - "MessagePluginInstalled": "Das Plugin wurde erfolgreich installiert. Der Jellyfin-Server muss neu gestartet werden, um die Änderungen zu übernehmen.", + "MessagePluginInstalled": "Das Plugin wurde erfolgreich installiert. Der Server muss neu gestartet werden, um die Änderungen zu übernehmen.", "PreferEmbeddedTitlesOverFileNames": "Bevorzuge eingebettete Titel vor Dateinamen", "PreferEmbeddedTitlesOverFileNamesHelp": "Das bestimmt den Standard Displaytitel wenn keine lokale oder Internetmetadaten verfügbar sind.", "PreferEmbeddedEpisodeInfosOverFileNames": "Bevorzuge eingebettete Episodeninformationen vor Dateinamen", @@ -1091,10 +1091,10 @@ "SeriesRecordingScheduled": "Serien-Aufnahme geplant.", "SeriesSettings": "Serieneinstellungen", "SeriesYearToPresent": "{0}-Heute", - "ServerNameIsRestarting": "Jellyfin Server - {0} startet neu.", - "ServerNameIsShuttingDown": "Jellyfin Server - {0} fährt herunter.", - "ServerRestartNeededAfterPluginInstall": "Der Jellyfin-Server muss nach der Installation eines Plugins neu gestartet werden.", - "ServerUpdateNeeded": "Dieser Jellyfin Server muss aktualisiert werden. Um die neueste Version herunterzuladen, besuche bitte {0}", + "ServerNameIsRestarting": "Jellyfin Server an {0} startet neu.", + "ServerNameIsShuttingDown": "Der Server an {0} fährt herunter.", + "ServerRestartNeededAfterPluginInstall": "Jellyfin muss nach der Installation eines Plugins neu gestartet werden.", + "ServerUpdateNeeded": "Dieser Server muss aktualisiert werden. Um die neueste Version herunterzuladen, besuche bitte {0}", "Settings": "Einstellungen", "SettingsSaved": "Einstellungen gespeichert.", "SettingsWarning": "Das Verändern dieser Werte kann Instabilität und Verbindungsprobleme hervorrufen. Wenn Probleme auftreten sollten empfehlen wir diese Einstellungen auf die Standardwerte zurück zu stellen.", @@ -1432,7 +1432,7 @@ "LastSeen": "Zuletzt gesehen {0}", "PersonRole": "als {0}", "ListPaging": "{0}-{1} von {2}", - "WriteAccessRequired": "Jellyfin Server benötigt Schreibrechte auf diesem Ordner. Bitte prüfe die Schreibrechte und versuche es erneut.", + "WriteAccessRequired": "Jellyfin benötigt Schreibrechte auf diesem Ordner. Bitte prüfe die Schreibrechte und versuche es erneut.", "PathNotFound": "Der Pfad konnte nicht gefunden werden. Bitte versichere dich dass der Pfad korrekt ist und versuche es erneut.", "Track": "Track", "Season": "Staffel", From 348ad6547346cbcd5441856f60237ffc2af2829f Mon Sep 17 00:00:00 2001 From: 4d1m Date: Tue, 11 Aug 2020 18:08:18 +0000 Subject: [PATCH 158/301] Translated using Weblate (Romanian) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/ro/ --- src/strings/ro.json | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-) diff --git a/src/strings/ro.json b/src/strings/ro.json index b413f12756..47564bdb5f 100644 --- a/src/strings/ro.json +++ b/src/strings/ro.json @@ -236,7 +236,7 @@ "ButtonStop": "Stop", "ButtonSubmit": "Trimite", "Collections": "Colecții", - "AllowRemoteAccess": "Permite conexiuni externe către acest server Jellyfin.", + "AllowRemoteAccess": "Permiteți conexiuni externe către acest server.", "AllowRemoteAccessHelp": "Dacă este neselectat, toate conexiunile externe vor fi blocate.", "AlwaysPlaySubtitles": "Întotdeauna arată", "AnyLanguage": "Orice Limbă", @@ -280,7 +280,7 @@ "ButtonSettings": "Setări", "ChangingMetadataImageSettingsNewContent": "Modificări ale metadatelor sau ale setărilor de descărcare a operelor de artă se va aplica doar conținutului nou adăugat în librăriile tale. Pentru a aplica modificările titlurilor deja existente va trebui reîmprospătată manual metadata lor.", "CinemaModeConfigurationHelp": "Mod cinema aduce experiența cinematografică în sufrageria dumneavoastră prin abilitatea de a rula trailere sau introuri personalizate înaintea titlului principal.", - "ConfigureDateAdded": "Configurează cum este determinată data adaugării în tabloul de bord al serverului Jellyfin în setările librariei", + "ConfigureDateAdded": "Configurează cum este determinată data adaugării în tabloul de bord din setările librariei", "DefaultSubtitlesHelp": "Subtitrările sunt încărcate în funcție de opțiunile implicite și forțate din metadatele încorporate. Preferințele de limbă sunt luate în considerare atunci când sunt disponibile mai multe opțiuni.", "DirectStreamHelp1": "Media este compatibilă cu dispozitivul în ceea ce privește rezoluția și tipul de media(H.264, AC3, etc), dar se află într-un container de fișiere incompatibil (mkv, avi, wmv, etc). Videoclipul va fi re-ambalat în timp real înainte de a-l transmite către dispozitiv.", "CopyStreamURLSuccess": "URL copiat cu succes.", @@ -541,7 +541,7 @@ "ValueSpecialEpisodeName": "Special - {0}", "EnableStreamLoopingHelp": "Activați acestă opțiune dacă fluxurile live conțin doar câteva secunde de date și trebuie solicitate în mod continuu. Activarea acestei opțiuni atunci când nu este necesar poate provoca probleme.", "ErrorAddingListingsToSchedulesDirect": "A apărut o eroare la adăugarea liniei în contul dvs. Schedules Direct. Schedules Direct permite doar un număr limitat de linii pentru fiecare cont. Este posibil să fie nevoie să vă conectați la site-ul web Schedules Direct și să eliminați alte înregistrări din cont înainte de a continua.", - "ErrorAddingMediaPathToVirtualFolder": "A apărut o eroare la adăugarea căii de acces la fișierul media. Vă rugăm să vă asigurați că ruta este validă și procesul Jellyfin Server are acces la locația respectivă.", + "ErrorAddingMediaPathToVirtualFolder": "A apărut o eroare la adăugarea căii de acces la fișierul media. Vă rugăm să vă asigurați că ruta este validă și că Jellyfin are acces la locația respectivă.", "ErrorStartHourGreaterThanEnd": "Timpul de oprire trebuie să fie mai mare decât cel de pornire.", "ErrorPleaseSelectLineup": "Selectați o linie și încercați din nou. Dacă nu sunt disponibile linii, atunci vă rugăm să verificați dacă numele dvs. de utilizator, parola și codul poștal sunt corecte.", "ExitFullscreen": "Ieșiți din modul ecran complet", @@ -586,7 +586,7 @@ "EnableThemeVideos": "Videoclipuri tematice", "EnableThemeVideosHelp": "Redați videoclipuri tematice în fundal în timp ce navigați în bibliotecă.", "ErrorAddingTunerDevice": "A apărut o eroare la adăugarea tuner-ului. Vă rugăm să vă asigurați că este accesibil și încercați din nou.", - "ErrorDeletingItem": "A apărut o eroare la ștergerea elementului din Jellyfin Server. Vă rugăm să verificați dacă Jellyfin Server are acces de scriere la folderul media și încercați din nou.", + "ErrorDeletingItem": "A apărut o eroare la ștergerea elementului din server. Vă rugăm să verificați dacă Jellyfin are acces de scriere la folderul media și încercați din nou.", "ErrorGettingTvLineups": "A apărut o eroare la descărcarea liniilor TV. Vă rugăm să vă asigurați că informațiile dvs. sunt corecte și încercați din nou.", "ErrorSavingTvProvider": "A apărut o eroare la salvarea furnizorului de televiziune. Vă rugăm să vă asigurați că este accesibil și încercați din nou.", "ExtraLarge": "Foarte mare", @@ -708,7 +708,7 @@ "LabelOverview": "Prezentare generală:", "LabelOriginalTitle": "Titlu original:", "LabelOriginalAspectRatio": "Raport aspect original:", - "LabelOptionalNetworkPathHelp": "Dacă acest folder este partajat în rețeaua dvs., furnizarea căii de partajare a rețelei poate permite aplicațiilor Jellyfin de pe alte dispozitive să acceseze fișiere media direct.", + "LabelOptionalNetworkPathHelp": "Dacă acest folder este partajat în rețeaua dvs., furnizarea căii de partajare a rețelei poate permite aplicațiilor client de pe alte dispozitive să acceseze fișiere media direct. De exemplu, {0} sau {1}.", "LabelOptionalNetworkPath": "Dosar partajat în rețea:", "LabelNumber": "Număr:", "LabelNotificationEnabled": "Activează această notificare", @@ -814,7 +814,7 @@ "LabelEnableDlnaPlayTo": "Activează DLNA Play To", "LabelEnableDlnaDebugLoggingHelp": "Creați fișiere de jurnal mari și trebuie utilizate numai în funcție de necesități pentru rezolvarea problemelor.", "LabelEnableDlnaDebugLogging": "Activați jurnalul de depanare DLNA", - "LabelEnableDlnaClientDiscoveryIntervalHelp": "Determină durata în secunde între căutările SSDP efectuate de Jellyfin.", + "LabelEnableDlnaClientDiscoveryIntervalHelp": "Determină durata în secunde între căutările SSDP.", "LabelEnableDlnaClientDiscoveryInterval": "Interval de descoperire a clientului", "LabelEnableBlastAliveMessagesHelp": "Activați acest lucru dacă serverul nu este detectat în mod fiabil de alte dispozitive UPnP din rețeaua dvs.", "LabelEnableBlastAliveMessages": "Trimitere mesaje de disponibilitate", @@ -867,7 +867,7 @@ "LabelBitrate": "Rată de biți:", "LabelBirthYear": "Anul nașterii:", "LabelBirthDate": "Data nașterii:", - "LabelBindToLocalNetworkAddressHelp": "Rescrie adresa IP locală a serverului http. Dacă este lăsat gol, serverul se va lega la toate adresele disponibile. Modificarea acestei valori necesită repornirea Jellyfin Server.", + "LabelBindToLocalNetworkAddressHelp": "Rescrie adresa IP locală a serverului http. Dacă este lăsat gol, serverul se va lega la toate adresele disponibile. Modificarea acestei valori necesită un restart.", "LabelBindToLocalNetworkAddress": "Utilizează adresa de rețea locală:", "LabelAutomaticallyRefreshInternetMetadataEvery": "Actualizați automat metadatele de pe internet:", "LabelAuthProvider": "Furnizor de autentificare:", @@ -1044,7 +1044,7 @@ "MessageContactAdminToResetPassword": "Vă rugăm să contactați administratorul de sistem pentru a vă reseta parola.", "MessageConfirmShutdown": "Sigur doriți să opriți serverul?", "MessageConfirmRevokeApiKey": "Sigur doriți să revocați această cheie API? Conexiunea aplicației la Jellyfin Server va fi terminată brusc.", - "MessageConfirmRestart": "Sigur doriți să redemarați serverul Jellyfin?", + "MessageConfirmRestart": "Sigur doriți să restartați Jellyfin?", "MessageConfirmRemoveMediaLocation": "Sigur doriți să eliminați această locație?", "MessageConfirmRecordingCancellation": "Anulați înregistrarea?", "MessageConfirmProfileDeletion": "Sigur doriți să ștergeți acest profil?", From 5bfaf811d569ccfa84797aff7a3612b74001e7d2 Mon Sep 17 00:00:00 2001 From: Cameron Date: Tue, 11 Aug 2020 20:21:46 +0100 Subject: [PATCH 159/301] relocate let --- src/components/tunerPicker.js | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/src/components/tunerPicker.js b/src/components/tunerPicker.js index 1cb3fdc29a..13625ddb67 100644 --- a/src/components/tunerPicker.js +++ b/src/components/tunerPicker.js @@ -85,11 +85,9 @@ function getTunerName(providerId) { } function renderDevices(view, devices) { - let i; - let length; let html = ''; - for (i = 0, length = devices.length; i < length; i++) { + for (let i = 0, length = devices.length; i < length; i++) { html += getDeviceHtml(devices[i]); } From ad8247cda9cb90a2f44f30437efb053a0402ccde Mon Sep 17 00:00:00 2001 From: Matt Strayer Date: Tue, 11 Aug 2020 15:48:40 -0400 Subject: [PATCH 160/301] Update src/components/filtermenu/filtermenu.js Co-authored-by: Cameron --- src/components/filtermenu/filtermenu.js | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/src/components/filtermenu/filtermenu.js b/src/components/filtermenu/filtermenu.js index 0ed19f85c9..0e229a8044 100644 --- a/src/components/filtermenu/filtermenu.js +++ b/src/components/filtermenu/filtermenu.js @@ -102,9 +102,7 @@ function onInputCommand(e) { } function saveValues(context, settings, settingsKey) { var elems = context.querySelectorAll('.simpleFilter'); - var i; - var length; - for (i = 0, length = elems.length; i < length; i++) { + for (let i = 0, length = elems.length; i < length; i++) { if (elems[i].tagName === 'INPUT') { setBasicFilter(context, settingsKey + '-filter-' + elems[i].getAttribute('data-settingname'), elems[i]); } else { From a6b114ce13a9f46b99d0f97f3a25e10dd35f89bd Mon Sep 17 00:00:00 2001 From: matjaz321 Date: Tue, 11 Aug 2020 22:15:26 +0200 Subject: [PATCH 161/301] Removed code that was changing checked flag for keypress event, because it is already handled by browswer --- src/elements/emby-checkbox/emby-checkbox.js | 2 -- 1 file changed, 2 deletions(-) diff --git a/src/elements/emby-checkbox/emby-checkbox.js b/src/elements/emby-checkbox/emby-checkbox.js index 84961848c6..7b906286ef 100644 --- a/src/elements/emby-checkbox/emby-checkbox.js +++ b/src/elements/emby-checkbox/emby-checkbox.js @@ -13,8 +13,6 @@ import 'webcomponents'; if (e.keyCode === 13 || e.keyCode === 32) { e.preventDefault(); - this.checked = !this.checked; - this.dispatchEvent(new CustomEvent('change', { bubbles: true })); From 492a59db82b73fafdd2dbdbae50be039ee2ae0e9 Mon Sep 17 00:00:00 2001 From: Cameron Date: Tue, 11 Aug 2020 21:22:17 +0100 Subject: [PATCH 162/301] Update src/components/themeMediaPlayer.js Co-authored-by: Dmitry Lyzo <56478732+dmitrylyzo@users.noreply.github.com> --- src/components/themeMediaPlayer.js | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/src/components/themeMediaPlayer.js b/src/components/themeMediaPlayer.js index 4ee9e0c910..8225156bf0 100644 --- a/src/components/themeMediaPlayer.js +++ b/src/components/themeMediaPlayer.js @@ -1,5 +1,5 @@ import playbackManager from 'playbackManager'; -import userSettings from 'userSettings'; +import * as userSettings from 'userSettings'; import connectionManager from 'connectionManager'; let currentOwnerId; @@ -99,4 +99,3 @@ Events.on(playbackManager, 'playbackstart', function (e, player) { currentOwnerId = null; } }); - From 3e8ebe28b96e69be3f3eb3501d6c1ab839523ea1 Mon Sep 17 00:00:00 2001 From: Matt Strayer Date: Tue, 11 Aug 2020 16:51:43 -0400 Subject: [PATCH 163/301] add lets to for loops --- src/components/filtermenu/filtermenu.js | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/src/components/filtermenu/filtermenu.js b/src/components/filtermenu/filtermenu.js index 0e229a8044..637214a878 100644 --- a/src/components/filtermenu/filtermenu.js +++ b/src/components/filtermenu/filtermenu.js @@ -63,7 +63,7 @@ function moveCheckboxFocus(elem, offset) { var elems = focusManager.getFocusableElements(parent); var index = -1; - for (var i = 0, length = elems.length; i < length; i++) { + for (let i = 0, length = elems.length; i < length; i++) { if (elems[i] === elem) { index = i; break; @@ -114,7 +114,7 @@ function saveValues(context, settings, settingsKey) { var videoTypes = []; elems = context.querySelectorAll('.chkVideoTypeFilter'); - for (i = 0, length = elems.length; i < length; i++) { + for (let i = 0, length = elems.length; i < length; i++) { if (elems[i].checked) { videoTypes.push(elems[i].getAttribute('data-filter')); } @@ -125,7 +125,7 @@ function saveValues(context, settings, settingsKey) { var seriesStatuses = []; elems = context.querySelectorAll('.chkSeriesStatus'); - for (i = 0, length = elems.length; i < length; i++) { + for (let i = 0, length = elems.length; i < length; i++) { if (elems[i].checked) { seriesStatuses.push(elems[i].getAttribute('data-filter')); } @@ -135,7 +135,7 @@ function saveValues(context, settings, settingsKey) { var genres = []; elems = context.querySelectorAll('.chkGenreFilter'); - for (i = 0, length = elems.length; i < length; i++) { + for (let i = 0, length = elems.length; i < length; i++) { if (elems[i].checked) { genres.push(elems[i].getAttribute('data-filter')); } @@ -144,7 +144,7 @@ function saveValues(context, settings, settingsKey) { } function bindCheckboxInput(context, on) { var elems = context.querySelectorAll('.checkboxList-verticalwrap'); - for (var i = 0, length = elems.length; i < length; i++) { + for (let i = 0, length = elems.length; i < length; i++) { if (on) { inputManager.on(elems[i], onInputCommand); } else { @@ -238,7 +238,7 @@ class FilterMenu { dlg.innerHTML = globalize.translateHtml(html, 'core'); var settingElements = dlg.querySelectorAll('.viewSetting'); - for (var i = 0, length = settingElements.length; i < length; i++) { + for (let i = 0, length = settingElements.length; i < length; i++) { if (options.visibleSettings.indexOf(settingElements[i].getAttribute('data-settingname')) === -1) { settingElements[i].classList.add('hide'); } else { From c378e59adc122a22453f2fa1a64fcbc82675b3e4 Mon Sep 17 00:00:00 2001 From: 4d1m Date: Tue, 11 Aug 2020 19:05:07 +0000 Subject: [PATCH 164/301] Translated using Weblate (Romanian) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/ro/ --- src/strings/ro.json | 26 ++++++++++++++------------ 1 file changed, 14 insertions(+), 12 deletions(-) diff --git a/src/strings/ro.json b/src/strings/ro.json index 47564bdb5f..a627be87fb 100644 --- a/src/strings/ro.json +++ b/src/strings/ro.json @@ -1015,7 +1015,7 @@ "MessageTheFollowingLocationWillBeRemovedFromLibrary": "Următoarele locații media vor fi eliminate din biblioteca dvs.:", "MessageSettingsSaved": "Setări salvate.", "MessageReenableUser": "Consultați mai jos pentru a reactiva", - "MessagePluginInstallDisclaimer": "Pluginurile create de membrii comunității Jellyfin sunt o modalitate excelentă de a vă îmbunătăți experiența Jellyfin cu funcții și beneficii suplimentare. Înainte de instalare, vă rugăm să fiți conștienți de efectele pe care le pot avea asupra serverului dvs. Jellyfin, cum ar fi scanările de bibliotecă mai lungi, procesarea suplimentară a fundalului și scăderea stabilității sistemului.", + "MessagePluginInstallDisclaimer": "Pluginurile create de membrii comunității sunt o modalitate excelentă de a vă îmbunătăți experiența cu funcții și beneficii suplimentare. Înainte de instalare, vă rugăm să fiți conștienți de efectele pe care le pot avea asupra serverului dvs., cum ar fi scanările de bibliotecă mai îndelungate, procesare suplimentară în fundal și scăderea stabilității sistemului.", "MessagePluginConfigurationRequiresLocalAccess": "Pentru a configura acest plugin, vă rugăm să vă conectați direct la serverul dvs. local.", "MessagePleaseWait": "Te rog așteaptă. Poate dura un minut.", "MessagePlayAccessRestricted": "Redarea acestui conținut este în prezent restricționată. Vă rugăm să contactați administratorul serverului pentru mai multe informații.", @@ -1038,12 +1038,12 @@ "MessageFileReadError": "S-a întâmpinat o eroare în timpul citirii fișierului. Vă rugăm să încercați din nou.", "MessageDownloadQueued": "Descărcare adăugata în coadă.", "MessageDirectoryPickerLinuxInstruction": "Pentru Linux pe Arch Linux, CentOS, Debian, Fedora, openSUSE sau Ubuntu, trebuie să acordați utilizatorului serverului Jellyfin cel puțin permisiunea de citire la locațiile de stocare.", - "MessageDirectoryPickerBSDInstruction": "Pentru BSD, poate fi necesar să configurați stocarea în FreeNAS jail pentru a permite serverului Jellyfin să o acceseze.", + "MessageDirectoryPickerBSDInstruction": "Pentru BSD, poate fi necesar să configurați stocarea în FreeNAS Jail pentru ca Jellyfin să o acceseze.", "MessageDeleteTaskTrigger": "Sigur doriți să ștergeți acest declanșator de activitate?", "MessageCreateAccountAt": "Crează un cont la {0}", "MessageContactAdminToResetPassword": "Vă rugăm să contactați administratorul de sistem pentru a vă reseta parola.", "MessageConfirmShutdown": "Sigur doriți să opriți serverul?", - "MessageConfirmRevokeApiKey": "Sigur doriți să revocați această cheie API? Conexiunea aplicației la Jellyfin Server va fi terminată brusc.", + "MessageConfirmRevokeApiKey": "Sigur doriți să revocați această cheie API? Conexiunea aplicației la acest server va fi terminată brusc.", "MessageConfirmRestart": "Sigur doriți să restartați Jellyfin?", "MessageConfirmRemoveMediaLocation": "Sigur doriți să eliminați această locație?", "MessageConfirmRecordingCancellation": "Anulați înregistrarea?", @@ -1165,10 +1165,10 @@ "SettingsWarning": "Modificarea acestor valori poate provoca instabilități sau eșecuri de conectivitate. Dacă întâmpinați probleme, vă recomandăm să le schimbați înapoi cu cele din modul implicit.", "SettingsSaved": "Setări salvate.", "Settings": "Setări", - "ServerUpdateNeeded": "Acest Jellyfin Server trebuie actualizat. Pentru a descărca cea mai recentă versiune, accesați {0}", - "ServerRestartNeededAfterPluginInstall": "Jellyfin Server va trebui să fie repornit după instalarea unui plugin.", - "ServerNameIsShuttingDown": "Jellyfin Server - {0} se oprește.", - "ServerNameIsRestarting": "Jellyfin Server - {0} se repornește.", + "ServerUpdateNeeded": "Acest server trebuie actualizat. Pentru a descărca cea mai recentă versiune, accesați {0}", + "ServerRestartNeededAfterPluginInstall": "Jellyfin va trebui să fie repornit după instalarea unui plugin.", + "ServerNameIsShuttingDown": "Serverul de pe {0} se oprește.", + "ServerNameIsRestarting": "Serverul de pe {0} se repornește.", "SeriesYearToPresent": "{0} - Prezent", "SeriesSettings": "Setările serialului", "SeriesRecordingScheduled": "Înregistrarea serialului programată.", @@ -1229,9 +1229,9 @@ "Premiere": "Premieră", "PreferEmbeddedTitlesOverFileNamesHelp": "Aceasta determină titlul afișat implicit atunci când nu sunt disponibile metadate din internet sau metadate locale.", "PreferEmbeddedTitlesOverFileNames": "Preferă titlurile incluse decât numele fișierelor", - "MessagePluginInstalled": "Pluginul a fost instalat cu succes. Jellyfin Server va trebui să fie repornit pentru ca modificările să intre în vigoare.", + "MessagePluginInstalled": "Pluginul a fost instalat cu succes. Serverul va trebui să fie repornit pentru ca modificările să intre în vigoare.", "PleaseSelectTwoItems": "Vă rugăm să selectați cel puțin două elemente.", - "PleaseRestartServerName": "Vă rugăm să reporniți Jellyfin Server - {0}.", + "PleaseRestartServerName": "Vă rugăm să reporniți Jellyfin pe {0}.", "PleaseEnterNameOrId": "Vă rugăm să introduceți un nume sau un ID extern.", "PleaseConfirmPluginInstallation": "Faceți clic pe OK pentru a confirma că ați citit mai sus și doriți să continuați cu instalarea pluginului.", "PleaseAddAtLeastOneFolder": "Vă rugăm să adăugați cel puțin un dosar la această bibliotecă făcând clic pe butonul Adăugare.", @@ -1270,7 +1270,7 @@ "OptionThumb": "Miniatură", "OptionSubstring": "Subșir", "OptionSpecialEpisode": "Speciale", - "OptionSaveMetadataAsHiddenHelp": "Modificarea acestui lucru se va aplica la noi metadate salvate de acum înainte. Fișierele de metadate existente vor fi actualizate data viitoare când sunt salvate de Jellyfin Server.", + "OptionSaveMetadataAsHiddenHelp": "Modificarea acestui lucru se va aplica la noi metadate salvate de acum înainte. Fișierele de metadate existente vor fi actualizate data viitoare când sunt salvate de server.", "OptionSaveMetadataAsHidden": "Salvați metadata și imaginile ca fișiere ascunse", "OptionResElement": "element res", "OptionRequirePerfectSubtitleMatchHelp": "Cerând o potrivire perfectă va filtra subtitrările pentru a le include doar pe cele care au fost testate și verificate cu fișierul dvs. video exact. Debifând acest lucru, va crește probabilitatea descărcării subtitrărilor, dar va crește șansele de a avea decalaje sau de a greși textul de subtitrare.", @@ -1441,7 +1441,7 @@ "LastSeen": "Văzut ultima dată {0}", "PersonRole": "ca {0}", "ListPaging": "{0}-{1} din {2}", - "WriteAccessRequired": "Jellyfin Server necesită acces de scriere la acest folder. Vă rugăm să vă asigurați accesul la scriere și încercați din nou.", + "WriteAccessRequired": "Jellyfin necesită acces de scriere la acest folder. Vă rugăm să vă asigurați accesul la scriere și încercați din nou.", "PathNotFound": "Calea nu a fost găsită. Vă rugăm să vă asigurați de validitatea căii și încercați din nou.", "YadifBob": "Gigi Bob", "Yadif": "YADIF", @@ -1528,5 +1528,7 @@ "Preview": "Previzualizare", "SubtitleVerticalPositionHelp": "Numărul de linie unde apare textul. Numerele pozitive indică de sus în jos. Numerele negative indică de jos în sus.", "LabelSubtitleVerticalPosition": "Poziție verticală:", - "PreviousTrack": "Sari anterior" + "PreviousTrack": "Sari anterior", + "MessageGetInstalledPluginsError": "A apărut o eroare la obținerea listei de plugin-uri instalate în prezent.", + "MessagePluginInstallError": "A apărut o eroare la instalarea pluginului." } From bb8a7f87a95936994e518c3026b70172f001cd88 Mon Sep 17 00:00:00 2001 From: Gualdimar Date: Tue, 11 Aug 2020 20:21:54 +0000 Subject: [PATCH 165/301] Translated using Weblate (Ukrainian) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/uk/ --- src/strings/uk.json | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-) diff --git a/src/strings/uk.json b/src/strings/uk.json index c1bec0b050..45b957e0a5 100644 --- a/src/strings/uk.json +++ b/src/strings/uk.json @@ -109,9 +109,9 @@ "HeaderFavoriteEpisodes": "Улюблені серії", "Movies": "Фільми", "Collections": "Колекції", - "Folders": "Директорії", + "Folders": "Каталоги", "HeaderNextUp": "Наступний", - "HeaderAlbumArtists": "Виконавці альбомів", + "HeaderAlbumArtists": "Виконавці альбому", "HeaderFavoriteSongs": "Улюблені пісні", "Favorites": "Улюблені", "HeaderFavoriteAlbums": "Улюблені альбоми", @@ -154,5 +154,11 @@ "AllowOnTheFlySubtitleExtraction": "Дозволити експортування субтитрів «на льоту»", "AllowHWTranscodingHelp": "Дозволити клієнту перекодування на «на льоту». Це дозволить відмикати перекодування, якщо вона вимагається сервером.", "AllComplexFormats": "Усі складні формати (ASS, SSA, VOBSUB, PGS, SUB, IDX, …)", - "ButtonSyncPlay": "SyncPlay" + "ButtonSyncPlay": "SyncPlay", + "ValueSpecialEpisodeName": "Спецепізод - {0}", + "Sync": "Синхронізація", + "Songs": "Пісні", + "Shows": "Шоу", + "Playlists": "Плейлисти", + "Photos": "Фотографії" } From 08dc2efd29414db049323beb165066cec8457007 Mon Sep 17 00:00:00 2001 From: ESJai Date: Wed, 12 Aug 2020 03:25:11 +0000 Subject: [PATCH 166/301] Translated using Weblate (Chinese (Hong Kong)) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/zh_Hant_HK/ --- src/strings/zh-hk.json | 17 ++++++++++++++--- 1 file changed, 14 insertions(+), 3 deletions(-) diff --git a/src/strings/zh-hk.json b/src/strings/zh-hk.json index 661195d1d8..9ddf50b7ee 100644 --- a/src/strings/zh-hk.json +++ b/src/strings/zh-hk.json @@ -367,7 +367,7 @@ "AlwaysPlaySubtitlesHelp": "無論語言是哪種音頻,都將加載與語言首選項匹配的字幕。", "AllowedRemoteAddressesHelp": "IP地址或IP /網絡掩碼條目的逗號分隔列表,用於允許遠程連接的網絡。 如果保留為空白,將允許所有遠程地址。", "AllowRemoteAccessHelp": "如果未選中,則將阻止所有遠程連接。", - "AllowRemoteAccess": "允許與此Jellyfin服務器的遠程連接。", + "AllowRemoteAccess": "允許與此Jellyfin伺服器的遠端連接。", "AllowFfmpegThrottlingHelp": "當轉碼或無損複製進度遠超於當前播放位置,暫停進程可減少資源消耗。 在不經常觀看的情況下,此功能最為有用。 如果遇到播放問題,請關閉此功能。", "AllowOnTheFlySubtitleExtractionHelp": "可以從視頻中提取嵌入式字幕,然後以純文本格式將其交付給客戶端,以幫助防止視頻轉碼。 在某些系統上,這可能需要很長時間,並且會導致提取過程中視頻播放停止。 如果客戶端設備本身不支持嵌入的字幕,則可以禁用此選項以通過視頻轉碼刻錄字幕。", "AllowOnTheFlySubtitleExtraction": "允許即時提取字幕", @@ -413,7 +413,7 @@ "Connect": "連接", "ConfirmEndPlayerSession": "你要關閉 {0} 的Jellyfin嗎?", "ConfirmDeleteImage": "刪除圖片?", - "CommunityRating": "社群分數", + "CommunityRating": "社群評分", "ClientSettings": "客戶端設定", "ChannelNumber": "頻道號碼", "ChannelNameOnly": "只有頻道 {0}", @@ -484,5 +484,16 @@ "Box": "盒裝", "Composer": "作曲家", "ButtonPreviousTrack": "上一曲", - "ButtonNextTrack": "下一曲" + "ButtonNextTrack": "下一曲", + "ColorTransfer": "色彩移動", + "ColorSpace": "色彩空間", + "ColorPrimaries": "主色調", + "CinemaModeConfigurationHelp": "影院模式可在播放主影片前加入預告片及自定引言片段,帶來戲院式體驗。", + "ChangingMetadataImageSettingsNewContent": "任何資料變更只適用於新加入到媒體庫的內容。如要更改舊有媒體的內容,請手動刷新資料。", + "ButtonUp": "上", + "ButtonShuffle": "隨機播放", + "ButtonSelectView": "選擇介面", + "ButtonOff": "關閉", + "ButtonLibraryAccess": "媒體庫存取", + "BookLibraryHelp": "支援文字及有聲書本。請查閱{0} 書本命名教學 {1}。" } From 5cdf726f14b00c38bf9408cadcfb367bc7c64e04 Mon Sep 17 00:00:00 2001 From: ESJai Date: Wed, 12 Aug 2020 03:57:10 +0000 Subject: [PATCH 167/301] Translated using Weblate (Chinese (Hong Kong)) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/zh_Hant_HK/ --- src/strings/zh-hk.json | 17 +++++++++++------ 1 file changed, 11 insertions(+), 6 deletions(-) diff --git a/src/strings/zh-hk.json b/src/strings/zh-hk.json index 9ddf50b7ee..b8f48d474c 100644 --- a/src/strings/zh-hk.json +++ b/src/strings/zh-hk.json @@ -394,7 +394,7 @@ "Disabled": "已停用", "Directors": "導演", "Director": "導演", - "DirectStreaming": "直接直播", + "DirectStreaming": "直接串流", "DirectPlaying": "直接播放", "DetectingDevices": "偵測裝置中", "Desktop": "桌面", @@ -406,12 +406,12 @@ "DeleteImage": "刪除圖片", "ErrorDefault": "處理此請求時發生錯誤,請稍後再嘗試。", "Default": "預設", - "DateAdded": "日期已新增", - "CopyStreamURLSuccess": "成功複製URL。", - "CopyStreamURL": "複製直播URL", + "DateAdded": "新增日期", + "CopyStreamURLSuccess": "成功複製網址。", + "CopyStreamURL": "複製串流網址", "ContinueWatching": "繼續觀看", "Connect": "連接", - "ConfirmEndPlayerSession": "你要關閉 {0} 的Jellyfin嗎?", + "ConfirmEndPlayerSession": "是否關閉 {0} 的Jellyfin?", "ConfirmDeleteImage": "刪除圖片?", "CommunityRating": "社群評分", "ClientSettings": "客戶端設定", @@ -495,5 +495,10 @@ "ButtonSelectView": "選擇介面", "ButtonOff": "關閉", "ButtonLibraryAccess": "媒體庫存取", - "BookLibraryHelp": "支援文字及有聲書本。請查閱{0} 書本命名教學 {1}。" + "BookLibraryHelp": "支援文字及有聲書本。請查閱{0} 書本命名教學 {1}。", + "DatePlayed": "播放日期", + "CriticRating": "評論家評分", + "ConfirmDeletion": "確定刪除", + "ConfirmDeleteItems": "刪除這些物品將會從檔案系統及媒體庫中刪除。請問是否繼續?", + "ConfirmDeleteItem": "刪除此物品將會從檔案系統及媒體庫中刪除。請問是否繼續?" } From 67f32becd4cada1dfb34f681a1a6b60f8e0896c6 Mon Sep 17 00:00:00 2001 From: Cameron Date: Wed, 12 Aug 2020 09:13:46 +0100 Subject: [PATCH 168/301] Update package.json --- package.json | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/package.json b/package.json index e67944ffcf..7bce50c2e1 100644 --- a/package.json +++ b/package.json @@ -223,8 +223,8 @@ "src/controllers/dashboard/metadataImages.js", "src/controllers/dashboard/metadatanfo.js", "src/controllers/dashboard/networking.js", - "src/controllers/dashboard/notifications/notification.js", - "src/controllers/dashboard/notifications/notifications.js", + "src/controllers/dashboard/notifications/notification/index.js", + "src/controllers/dashboard/notifications/notifications/index.js", "src/controllers/dashboard/playback.js", "src/controllers/dashboard/plugins/add/index.js", "src/controllers/dashboard/plugins/installed/index.js", From b396e73ffc88003b39d455ad68f93351d71a824e Mon Sep 17 00:00:00 2001 From: Gualdimar Date: Wed, 12 Aug 2020 11:12:32 +0000 Subject: [PATCH 169/301] Translated using Weblate (Ukrainian) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/uk/ --- src/strings/uk.json | 14 ++++++++------ 1 file changed, 8 insertions(+), 6 deletions(-) diff --git a/src/strings/uk.json b/src/strings/uk.json index 45b957e0a5..859d82ed35 100644 --- a/src/strings/uk.json +++ b/src/strings/uk.json @@ -89,10 +89,10 @@ "ValueSeriesCount": "{0} серій", "ValueSongCount": "{0} пісень", "AddToPlaylist": "Додати до списку відтворення", - "AccessRestrictedTryAgainLater": "На цей момент доступ заборонений. Повторіть спробу пізніше.", - "Actor": "Виконавець", + "AccessRestrictedTryAgainLater": "На даний момент доступ обмежений. Будь ласка, спробуйте пізніше.", + "Actor": "Актор", "AllLanguages": "Усі мови", - "AllLibraries": "Усі бібліотеки", + "AllLibraries": "Усі медіатеки", "AddToCollection": "Додати до колекції", "AddToPlayQueue": "Додати до черги відтворення", "All": "Всі", @@ -103,7 +103,7 @@ "AnyLanguage": "Будь-яка мова", "Anytime": "Завжди", "Add": "Додати", - "AddedOnValue": "Додано", + "AddedOnValue": "Додано {0}", "Albums": "Альбоми", "Absolute": "Абсолютний", "HeaderFavoriteEpisodes": "Улюблені серії", @@ -131,7 +131,7 @@ "Alerts": "Термінові сповіщення", "AlbumArtist": "Виконавець альбому", "Album": "Альбом", - "AdditionalNotificationServices": "Пошук у каталозі плагінів для встановлення додаткових сервісів сповіщень.", + "AdditionalNotificationServices": "Перегляньте каталог плагінів, щоб встановити додаткові служби сповіщення.", "ShowYear": "Відобразити рік", "ShowTitle": "Відобразити назву", "Raised": "Піднятий", @@ -160,5 +160,7 @@ "Songs": "Пісні", "Shows": "Шоу", "Playlists": "Плейлисти", - "Photos": "Фотографії" + "Photos": "Фотографії", + "Aired": "Ефірний", + "AirDate": "Дата ефіру" } From e88139b9a6749cfd0de4750897129f74061055db Mon Sep 17 00:00:00 2001 From: gnehs Date: Wed, 12 Aug 2020 10:35:39 +0000 Subject: [PATCH 170/301] Translated using Weblate (Chinese (Traditional)) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/zh_Hant/ --- src/strings/zh-tw.json | 210 +++++++++++++++++++++-------------------- 1 file changed, 109 insertions(+), 101 deletions(-) diff --git a/src/strings/zh-tw.json b/src/strings/zh-tw.json index 8c8451ea10..37dd333bb6 100644 --- a/src/strings/zh-tw.json +++ b/src/strings/zh-tw.json @@ -3,7 +3,7 @@ "All": "全部", "AllowRemoteAccessHelp": "如果未勾選,所有連線都將被阻擋。", "Browse": "瀏覽", - "MessageBrowsePluginCatalog": "瀏覽我們的模組目錄來查看可用的模組。", + "MessageBrowsePluginCatalog": "瀏覽我們的附加元件目錄來查看可用的附加元件。", "ButtonAddServer": "新增伺服器", "ButtonAddUser": "新增使用者", "ButtonCancel": "取消", @@ -100,16 +100,16 @@ "LabelCurrentPassword": "當前的密碼:", "LabelDay": "日:", "LabelDisplayMissingEpisodesWithinSeasons": "顯示節目季度內缺少的單元", - "LabelEnableDlnaClientDiscoveryInterval": "尋找客戶端時間間隔(秒)", + "LabelEnableDlnaClientDiscoveryInterval": "尋找客戶端時間間隔", "LabelEnableDlnaDebugLogging": "記錄 DLNA 除錯資料到日誌", "LabelEnableDlnaDebugLoggingHelp": "將會建立非常大的日誌檔案,建議在進行故障排除時啟用。", "LabelEnableDlnaPlayTo": "播放到 DLNA 設備", "LabelEnableRealtimeMonitor": "啟用實時監控", - "LabelEnableRealtimeMonitorHelp": "支持的檔案系統上的更改,將會立即處理。", + "LabelEnableRealtimeMonitorHelp": "檔案的更改將在支援的檔案系統上立即處理。", "LabelEvent": "事件:", "LabelEveryXMinutes": "每:", "LabelFinish": "完成", - "LabelServerNameHelp": "名稱將用於辨識服務器,預設是伺服器的電腦名稱。", + "LabelServerNameHelp": "名稱將作為伺服器名稱,預設是伺服器的主機名稱。", "LabelLanguage": "語言:", "LabelMaxBackdropsPerItem": "每個項目背景的最大數目:", "LabelMaxParentalRating": "最大允許的家長評級:", @@ -131,8 +131,8 @@ "LabelPlaylist": "播放清單:", "LabelPrevious": "上一個", "LabelRefreshMode": "更新模式:", - "LabelSaveLocalMetadata": "將媒體圖像及資料檔存到媒體所在的資料夾", - "LabelSaveLocalMetadataHelp": "直接儲存圖片及資料到媒體所在的資料夾能使編輯更容易。", + "LabelSaveLocalMetadata": "將媒體圖像及中繼資料存到媒體所在的資料夾", + "LabelSaveLocalMetadataHelp": "直接儲存圖片及中繼資料到媒體所在的資料夾能使編輯更容易。", "LabelTime": "時間:", "LabelTriggerType": "觸發類型:", "LabelUser": "使用者:", @@ -173,7 +173,7 @@ "OptionDatePlayed": "播放日期", "OptionDescending": "降序", "OptionDisableUser": "停用該使用者", - "OptionDisableUserHelp": "被停用的使用者將被伺服器封鎖,即便正處於連線狀態也將被中斷。", + "OptionDisableUserHelp": "被停用的使用者將被伺服器封鎖,現有的連線也將中斷。", "OptionDislikes": "不喜歡", "OptionDownloadArtImage": "圖像", "OptionDownloadBackImage": "媒體包裝背面", @@ -231,17 +231,17 @@ "RecordingCancelled": "已取消排程錄製。", "RecordingScheduled": "已排程錄製。", "Refresh": "重新整理", - "RefreshDialogHelp": "詳細資料的更新方式會依據 Jellyfin 的設定及已經啟用的網路服務來進行。", + "RefreshDialogHelp": "中繼資料的更新方式會依據伺服器設定及已經啟用的網路服務來進行。", "ReplaceAllMetadata": "取代所有中繼資料", "ReplaceExistingImages": "取代現有圖片", "Saturday": "星期六", "Save": "保存", "Search": "搜尋", - "SearchForCollectionInternetMetadata": "在互聯網上搜索媒體圖像和資料", - "SearchForMissingMetadata": "搜尋遺失的詳細資料", + "SearchForCollectionInternetMetadata": "在網路上搜索媒體圖像和資料", + "SearchForMissingMetadata": "搜尋遺失的中繼資料", "SearchForSubtitles": "搜尋字幕", "SeriesRecordingScheduled": "已排程錄製整個系列。", - "ServerUpdateNeeded": "此Jellyfin伺服器需要更新,請至{0}取得最新版本", + "ServerUpdateNeeded": "伺服器需要更新,請至 {0} 取得最新版本", "SettingsSaved": "設置已保存。", "Share": "分享", "Subtitles": "字幕", @@ -259,7 +259,7 @@ "TabLiveTV": "電視", "TabMovies": "電影", "TabMusic": "音樂", - "TabMyPlugins": "我的插件", + "TabMyPlugins": "我的附加元件", "TabNetworks": "網絡", "TabPassword": "密碼", "TabProfile": "設定", @@ -278,14 +278,14 @@ "TrackCount": "{0} 個曲目", "Tuesday": "星期二", "UninstallPluginConfirmation": "你確定要解除安裝 {0}?", - "HeaderUninstallPlugin": "解除安裝插件", + "HeaderUninstallPlugin": "解除安裝附加元件", "UserProfilesIntro": "Jellyfin 可單獨對使用者進行設定,所有使用者擁有自己的顯示設置,播放狀態和家長控制。", "Wednesday": "星期三", "WelcomeToProject": "歡迎使用 Jellyfin!", "WizardCompleted": "這就是我們所需的全部資訊,Jellyfin 現在正在收集你的媒體櫃的資料,在這段時間內,不妨參考我們推出的應用程式。按一下完成進入控制台。", "Actor": "演員", "AddToPlayQueue": "加入播放清單", - "AddToPlaylist": "加入播放列表", + "AddToPlaylist": "加入播放清單", "Absolute": "絕對", "AccessRestrictedTryAgainLater": "目前存取受限,請稍後再試。", "AddedOnValue": "已加入 {0}", @@ -298,7 +298,7 @@ "AllLibraries": "所有媒體", "AllowMediaConversion": "允許媒體轉檔", "AllowMediaConversionHelp": "授予或拒絕存取媒體轉檔功能。", - "AllowRemoteAccess": "允許遠端存取該 Jellyfin 伺服器。", + "AllowRemoteAccess": "允許遠端存取伺服器。", "AlwaysPlaySubtitles": "總是顯示字幕", "AlwaysPlaySubtitlesHelp": "將會載入符合語音設定的字幕,無論語音是哪一個語言。", "AnyLanguage": "任何語言", @@ -331,10 +331,10 @@ "AirDate": "播出日期", "Aired": "已播於", "AllEpisodes": "所有集數", - "AllowHWTranscodingHelp": "若啟用,將會允許調諧器同步轉檔,這會減少 Jellyfin 伺服器轉檔必要。", + "AllowHWTranscodingHelp": "若啟用,將會允許調諧器同步轉檔,能夠減少伺服器轉檔需求。", "AllowOnTheFlySubtitleExtraction": "允許同步字幕截取", "AllowOnTheFlySubtitleExtractionHelp": "可以從影片中提取內建字幕並以純文字的形式給 Jellyfin 應用程式以避免影片轉檔。某些系統中提取的過程可能會花費較長時間並導致影片播放出現停滯。若停用這個選項,當內建字幕不被播放端設備支援時,字幕將透過轉檔嵌入影片中。", - "AllowedRemoteAddressesHelp": "可以從非本地連線的IP位址,用冒號分隔,留白則允許所有IP。", + "AllowedRemoteAddressesHelp": "可以從非本地連線的 IP 位址或 IP/子網域遮罩清單,用冒號分隔。 留白則允許所有IP。", "BookLibraryHelp": "支援有聲書和電子書。請瀏覽 {0}書籍命名指南{1}。", "Box": "盒子", "BoxRear": "盒子(背面)", @@ -415,7 +415,7 @@ "DeviceAccessHelp": "只適用於用唯一辨識方法的裝置,並不會阻止瀏覽器存取。已過濾的使用者裝置會被拒絕存取,直到他們被批准。", "DirectPlaying": "直接播放", "DirectStreamHelp1": "媒體在畫質和媒體類型(H.264、AC3 等)方面與裝置相容。但是在不相容的檔案格式(.mkv、.avi、.wmv 等)中,在影片傳輸到裝置之前,將會重新轉檔。", - "DirectStreamHelp2": "直接串流檔案會占用非常少的處理效能並且影片的品質不會有任何損失。", + "DirectStreamHelp2": "直接串流檔案會占用較少的 CPU 且影片品質不會有任何損失。", "DirectStreaming": "直接串流", "Director": "導演", "Directors": "導演", @@ -445,7 +445,7 @@ "EnableExternalVideoPlayersHelp": "當你開始播放影片時,將會顯示外部播放器選單。", "EnableHardwareEncoding": "啟用硬體編碼", "EnableNextVideoInfoOverlay": "在播放時顯示下一個影片資訊", - "EnableNextVideoInfoOverlayHelp": "在影片結束前,顯示當前播放列表中下一個影片的資訊。", + "EnableNextVideoInfoOverlayHelp": "在影片結束前,顯示當前播放清單中下一個影片的資訊。", "EnablePhotos": "顯示圖片", "EnablePhotosHelp": "圖片將被偵測到並和其他媒體檔案一起顯示。", "EnableStreamLooping": "自動循環播放直播", @@ -455,21 +455,21 @@ "EnableThemeVideos": "啟用主題影片", "EnableThemeVideosHelp": "瀏覽媒體庫時主題影片將作為背景影片播放。", "Episodes": "劇集", - "ErrorAddingListingsToSchedulesDirect": "在將電視節目時間表新增到您的 Schedules Direct 帳號時出現錯誤。每個 Schedules Direct 帳號只允許有限的時間表。您在繼續前可能需要登入 Schedules Direct 網站並刪除帳號中的其它列表。", - "ErrorAddingMediaPathToVirtualFolder": "新增媒體路徑時發生錯誤,請確認路徑是否有效,且你的 Jellyfin 伺服器有對該位置的存取權。", - "ErrorAddingTunerDevice": "新增調諧器設備時發生錯誤,請確認它是否可被存取後再試一次。", - "ErrorAddingXmlTvFile": "存取 XMLTV 檔案時發生錯誤,請確認該檔案是否存在後再試一次。", - "ErrorDeletingItem": "從 Jellyfin 伺服器刪除項目時發生錯誤,請確認伺服器對該磁碟有寫入權限並再試一次。", + "ErrorAddingListingsToSchedulesDirect": "在將電視節目時間表新增到您的 Schedules Direct 帳號時出現錯誤。每個 Schedules Direct 帳號只允許有限的時間表。您在繼續前可能需要登入 Schedules Direct 網站並刪除帳號中的其它清單。", + "ErrorAddingMediaPathToVirtualFolder": "新增媒體路徑時發生錯誤,請確認路徑是否有效,且 Jellyfin 具該位置的存取權。", + "ErrorAddingTunerDevice": "新增調諧器設備時發生錯誤,請確認它是否可被存取後重試。", + "ErrorAddingXmlTvFile": "存取 XMLTV 檔案時發生錯誤,請確認該檔案是否存在後重試。", + "ErrorDeletingItem": "從伺服器刪除項目時發生錯誤,請確認伺服器對該位址有寫入權限並重試。", "ErrorGettingTvLineups": "下載電視節目表時發生錯誤,請確認你的資訊是否正確並重試。", "ErrorStartHourGreaterThanEnd": "結束時間必須在開始時間後。", - "ErrorPleaseSelectLineup": "請選擇節目表,然後再試一次。如果沒有可用的節目表,請檢查您的使用者名稱、密碼和郵遞區號是否正確。", + "ErrorPleaseSelectLineup": "請選擇節目表,然後重試。若無可用的節目表,請檢查您的使用者名稱、密碼和郵遞區號是否正確。", "ErrorSavingTvProvider": "儲存電視供應商時發生錯誤,請確認是否可存取並重試。", "EveryNDays": "每 {0} 天", "ExitFullscreen": "結束全螢幕", "ExtraLarge": "特大", "ExtractChapterImagesHelp": "擷取章節圖片將允許 Jellyfin 顯示圖片形式的章節選單,過程可能會非常緩慢、佔用大量 CPU 資源,並且可能需要幾 GB 的硬碟空間。\n擷取會在影片被偵測到時啟動,同時也可作為一個夜間計劃任務運行,這個任務可以在「計劃任務」選項中進行設定,不建議在尖峰時刻使用時間進行這個任務。", "Extras": "額外", - "FFmpegSavePathNotFound": "我們無法通過你輸入的路徑找到 FFmpeg。 FFprobe 同樣也是必要且應該被放在同一個資料夾中。他們通常會被打包在一起以供下載。請檢查這個路徑然後再試一次。", + "FFmpegSavePathNotFound": "我們無法通過你輸入的路徑找到 FFmpeg。 FFprobe 同樣也是必要且應該被放在同一個資料夾中。他們通常會被打包在一起以供下載。請檢查這個路徑後重試。", "FastForward": "快轉", "Favorites": "我的最愛", "Features": "功能", @@ -487,7 +487,7 @@ "GroupVersions": "按版本分組", "GuestStar": "客串", "Guide": "指南", - "GuideProviderSelectListings": "選擇列表", + "GuideProviderSelectListings": "選擇清單", "H264CrfHelp": "CRF 是 x264 編碼器的預設畫質設置。此方法允許編碼器自動分配位元速率來試著達到一定輸出品質。讓每個畫格得到它需要的位元數來保持所需的品質等級。CRF 會得到最佳的位元速率分配結果。", "EncoderPresetHelp": "速度越慢則會得到更好的壓縮編碼效率。", "HDPrograms": "HD 節目", @@ -498,7 +498,7 @@ "HeaderActivity": "活動", "HeaderAddScheduledTaskTrigger": "新增觸發", "HeaderAddToCollection": "加到收藏", - "HeaderAddToPlaylist": "加到播放列表", + "HeaderAddToPlaylist": "加到播放清單", "HeaderAddUpdateImage": "新增/更新圖片", "HeaderAlbumArtists": "專輯演出者", "HeaderAlbums": "專輯", @@ -506,7 +506,7 @@ "HeaderAllowMediaDeletionFrom": "允許從中刪除媒體", "HeaderApiKey": "API 金鑰", "HeaderApiKeys": "API 金鑰", - "HeaderApiKeysHelp": "外部應用程式需要有一個 API 金鑰以用於和 Jellyfin 伺服器溝通。金鑰會在 Jellyfin 使用者登入時自動發行,或者你可以手動為應用程式產生一個金鑰。", + "HeaderApiKeysHelp": "外部應用程式需要有一個 API 金鑰以用於和伺服器溝通。金鑰會在使用者登入時自動發行,也可以手動產生一個金鑰。", "HeaderApp": "應用程式", "HeaderAppearsOn": "同時出現於", "HeaderAudioBooks": "有聲書", @@ -520,15 +520,15 @@ "HeaderChannelAccess": "節目存取", "HeaderChapterImages": "章節圖片", "HeaderCodecProfile": "編碼設定檔", - "HeaderCodecProfileHelp": "編碼器的設定檔標明了設備播放特定編碼時的限制;如果在限制之內則媒體將被轉碼,否則編碼器將被設定為直接播放。", + "HeaderCodecProfileHelp": "編碼器的設定檔標明了設備播放特定編碼時的限制;如果在限制之內則媒體將被轉檔,否則編碼器將被設定為直接播放。", "HeaderConfigureRemoteAccess": "設定遠端控制", - "HeaderConfirmPluginInstallation": "確認插件安裝", + "HeaderConfirmPluginInstallation": "確認附加元件安裝", "HeaderConfirmProfileDeletion": "確認刪除個人資料", "HeaderConfirmRevokeApiKey": "重置 API 金鑰", "HeaderConnectToServer": "連結至伺服器", "HeaderConnectionFailure": "連結失敗", "HeaderContainerProfile": "影片載體設定", - "HeaderContainerProfileHelp": "影片容器的設定檔標明了設備播放特定媒體格式時的限制。如果在限制之內則媒體將被轉碼,否則媒體格式將被設定為直接播放。", + "HeaderContainerProfileHelp": "影片容器的設定檔標明了設備播放特定媒體格式時的限制。如果在限制之內則媒體將被轉檔,否則媒體格式將被設定為直接播放。", "HeaderContinueListening": "繼續聆聽", "HeaderContinueWatching": "繼續觀賞", "HeaderDateIssued": "發布日期", @@ -554,7 +554,7 @@ "HeaderFavoriteArtists": "最愛演出者", "HeaderFavoriteEpisodes": "最愛影集", "HeaderFavoriteMovies": "最愛電影", - "HeaderFavoritePlaylists": "最愛播放列表", + "HeaderFavoritePlaylists": "最愛播放清單", "HeaderFavoriteShows": "最愛節目", "HeaderFavoriteSongs": "最愛歌曲", "HeaderFavoriteVideos": "最愛的影片", @@ -571,7 +571,7 @@ "HeaderItems": "項目", "HeaderKeepRecording": "繼續錄製", "HeaderKeepSeries": "保存系列", - "HeaderKodiMetadataHelp": "要啟用或停用 NFO 中繼資料,請在 Jellyfin「建立媒體庫」頁面中編輯該媒體庫「中繼資料儲存」部分。", + "HeaderKodiMetadataHelp": "要啟用或停用 NFO 中繼資料,請在設定裡「建立媒體庫」頁面中編輯「中繼資料儲存」部分。", "HeaderLatestMedia": "最新媒體", "HeaderLatestMusic": "最新音樂", "HeaderLibraries": "媒體庫", @@ -605,7 +605,7 @@ "HeaderPlayOn": "播放在", "HeaderPlayback": "媒體播放", "HeaderPlaybackError": "播放錯誤", - "HeaderPluginInstallation": "插件安裝", + "HeaderPluginInstallation": "附加元件安裝", "HeaderRecordingOptions": "錄影選項", "HeaderRecordingPostProcessing": "錄影後製", "HeaderRemoteControl": "遙控", @@ -618,7 +618,7 @@ "HeaderSecondsValue": "{0} 秒", "HeaderSelectPath": "選擇位址", "HeaderSelectTranscodingPath": "選擇轉碼暫放位址", - "HeaderSelectTranscodingPathHelp": "瀏覽或輸入轉碼用來存暫時資料的位址。資料夾需可讀取。", + "HeaderSelectTranscodingPathHelp": "瀏覽或輸入轉檔用來存暫時資料的位址。資料夾需具寫入權限。", "HeaderSendMessage": "傳送訊息", "HeaderSeriesOptions": "系列選項", "HeaderSeriesStatus": "系列狀態", @@ -647,12 +647,12 @@ "HeaderParentalRatings": "家長評級", "HeaderProfile": "設定檔", "HeaderProfileInformation": "設定檔信息", - "HeaderProfileServerSettingsHelp": "這些數值將控制 Jellyfin 伺服器如何呈現給設備。", + "HeaderProfileServerSettingsHelp": "這些數值將控制伺服器如何呈現給設備。", "HeaderResponseProfile": "回覆設定檔", "HeaderResponseProfileHelp": "當播放某些類型的媒體時,回覆設定檔提供一種方法來發送自定訊息到設備。", "HeaderSchedule": "日程表", "HeaderSelectCertificatePath": "選擇證書路徑", - "HeaderSelectMetadataPath": "選擇數據路徑", + "HeaderSelectMetadataPath": "選擇中繼資料路徑", "HeaderSubtitleProfile": "字幕設定檔", "HeaderSubtitleProfiles": "字幕設定檔", "HeaderSubtitleProfilesHelp": "字幕設定檔描述設備所支援的字幕格式。", @@ -681,8 +681,8 @@ "HttpsRequiresCert": "要啟用安全連線,您需要提供受信任的SSL證書,如 Let's Encrypt。 請提供證書,或停用安全連線。", "Identify": "識別", "Images": "圖片", - "ImportFavoriteChannelsHelp": "若啟用,只有在調諧器設備中被標記為我的最愛的頻道才會被導入。", - "ImportMissingEpisodesHelp": "若啟用,有關缺失劇集的數據導入您的 Jellyfin 媒體庫,並在季節和系列中顯示。 這可能會導致媒體庫掃描延長。", + "ImportFavoriteChannelsHelp": "若啟用,僅於調諧器設備中被標記為我的最愛的頻道才會被導入。", + "ImportMissingEpisodesHelp": "缺失劇集的資料將導入您的媒體庫,並在季度與系列中顯示。 可能導致媒體庫掃描延長。", "InstallingPackage": "正在安装 {0}(版本 {1})", "InstantMix": "即時混音", "Items": "項目", @@ -706,20 +706,20 @@ "LabelAlbumArtPN": "專輯封面 PN :", "LabelAlbumArtists": "專輯作家:", "LabelAllowHWTranscoding": "允許硬體轉碼", - "LabelAllowedRemoteAddresses": "遠端 IP 過濾:", - "LabelAllowedRemoteAddressesMode": "遠端 IP 過濾模式:", + "LabelAllowedRemoteAddresses": "遠端 IP 位址過濾:", + "LabelAllowedRemoteAddressesMode": "遠端 IP 位址過濾模式:", "LabelAppName": "APP 名稱", "LabelAppNameExample": "例如:可愛蹦蹦主機、小安的 Jellyfin", "LabelArtists": "藝人:", - "LabelArtistsHelp": "分開多重使用 ;", + "LabelArtistsHelp": "將多位演出者以「;」分隔。", "LabelAudio": "音頻", "LabelAuthProvider": "認證提供者:", "LabelAutomaticallyRefreshInternetMetadataEvery": "從網路自動抓取中繼資料:", "LabelBindToLocalNetworkAddress": "綁定本地網絡地址:", - "LabelBindToLocalNetworkAddressHelp": "(選用)覆蓋 HTTP 伺服器綁定的本地 IP 地址。如果留空,伺服器將會監聽所有可用的地址。改變此欄位需重啟 Jellyfin 伺服器。", + "LabelBindToLocalNetworkAddressHelp": "(選用)覆蓋 HTTP 伺服器綁定的本地 IP 位址。如果留空,伺服器將會監聽所有可用的地址。改變此欄位需重啟 Jellyfin 伺服器。", "LabelBirthDate": "出生日期:", "LabelBirthYear": "出生年:", - "LabelBlastMessageInterval": "活動信號的時間間隔(秒)", + "LabelBlastMessageInterval": "活動信號的時間間隔", "LabelBlastMessageIntervalHelp": "確定伺服器活動消息之間的持續時間(秒)。", "LabelBlockContentWithTags": "通過標籤鎖定內容:", "LabelBurnSubtitles": "燒錄字幕:", @@ -734,7 +734,7 @@ "LabelCustomCertificatePath": "自訂 SSL 證書路徑:", "LabelCustomCertificatePathHelp": "提供包含證書和金鑰的 PKCS #12 文件的路徑以在自訂域名上啟用 TLS。", "LabelCustomCss": "自訂 CSS:", - "LabelCustomCssHelp": "於 Web 介面套用您的自訂樣式。", + "LabelCustomCssHelp": "於網頁介面套用您的自訂樣式。", "LabelCustomDeviceDisplayName": "顯示名稱:", "Depressed": "凹陷", "HeaderHome": "首頁", @@ -755,7 +755,7 @@ "LabelDisplayLanguageHelp": "翻譯 Jellyfin 是個進行中的專案。", "LabelDisplayMode": "顯示模式:", "LabelDisplayName": "顯示名稱:", - "MessageNoPluginsInstalled": "您尚未安裝任何模組。", + "MessageNoPluginsInstalled": "您尚未安裝任何附加元件。", "Mobile": "手機", "Option3D": "3D", "OptionEveryday": "每天", @@ -763,12 +763,12 @@ "LabelAudioBitDepth": "音訊位元深度:", "LabelBaseUrl": "根路徑:", "LabelIconMaxHeight": "圖示最高高度:", - "LabelHttpsPortHelp": "Jellyfin 的 HTTPS 伺服器應綁定的 TCP 端口。", + "LabelHttpsPortHelp": "HTTPS 伺服器的 TCP 端口。", "LabelIconMaxHeightHelp": "通過 upnp:icon 的圖標最大解析度。", "CopyStreamURL": "複製串流連結", "MediaInfoDefault": "預設", "MediaInfoStreamTypeAudio": "音訊", - "LabelDateAddedBehaviorHelp": "如果原本就有中繼資料,將會優先使用其數據。", + "LabelDateAddedBehaviorHelp": "若原本就有中繼資料,將會優先使用。", "LabelScreensaver": "螢幕保護程式:", "LabelSeasonNumber": "季:", "LabelDropImageHere": "拖移圖片到這裡,或是點擊來選取。", @@ -878,7 +878,7 @@ "MessageConfirmDeleteTunerDevice": "您確定要刪除這部裝置嗎?", "MessageConfirmRecordingCancellation": "取消錄製?", "MessageImageFileTypeAllowed": "僅支援 JPEG 和 PNG。", - "MessageInvalidUser": "錯誤的使用者名稱或密碼,請再試一次。", + "MessageInvalidUser": "錯誤的使用者名稱或密碼,請重試。", "MessageItemSaved": "項目已儲存。", "MessagePleaseWait": "請稍候。", "MinutesBefore": "分前", @@ -912,7 +912,7 @@ "RecommendationBecauseYouLike": "因為您喜歡 {0}", "SearchResults": "搜尋結果", "TabPlaylists": "播放清單", - "TabPlugins": "模組", + "TabPlugins": "附加元件", "Transcoding": "轉檔", "ValueTimeLimitMultiHour": "時間限制:{0} 小時", "ValueVideoCodec": "影片編碼:{0}", @@ -922,10 +922,10 @@ "LabelServerName": "伺服器名稱:", "LabelTag": "標記:", "LabelTranscodingTempPathHelp": "指定轉檔後的儲存路徑,留空將使用預設值。", - "LabelffmpegPathHelp": "路徑指向 FFmpeg,或是包含其的資料夾。", + "LabelffmpegPathHelp": "FFmpeg 的路徑,或是包含其的資料夾。", "ManageRecording": "管理錄影", "MessageAlreadyInstalled": "已安裝此版本。", - "MessageConfirmRestart": "您確定要重新啟動嗎?", + "MessageConfirmRestart": "您確定要重新啟動 Jellyfin 嗎?", "Metadata": "中繼資料", "OptionAllUsers": "所有使用者", "OptionHomeVideos": "圖片", @@ -968,7 +968,7 @@ "MediaInfoStreamTypeVideo": "影片", "Menu": "選單", "MetadataManager": "中繼資料管理器", - "MessageNoPluginConfiguration": "這個模組沒有設定選項可供更改。", + "MessageNoPluginConfiguration": "這個附加元件沒有選項可供更改。", "NoSubtitlesHelp": "字幕不會自動讀取,但可於播放時手動選取。", "Normal": "正常", "OptionAllowContentDownloading": "允許下載及同步媒體", @@ -987,7 +987,7 @@ "LabelGroupMoviesIntoCollections": "將電影分組", "LabelKodiMetadataDateFormat": "釋出日期格式:", "LabelIconMaxWidth": "Icon 最寬寬度:", - "LabelGroupMoviesIntoCollectionsHelp": "顯示電影列表時,屬於相同集合的電影將作為分組項目顯示。", + "LabelGroupMoviesIntoCollectionsHelp": "顯示電影清單時,屬於相同集合的電影將作為分組項目顯示。", "LabelEncoderPreset": "H264 解碼品質:", "LabelHardwareAccelerationType": "硬體加速:", "LabelIconMaxWidthHelp": "通過 upnp:icon 的圖標最大解析度。", @@ -998,7 +998,7 @@ "LabelMaxStreamingBitrateHelp": "指定最大串流比特率。", "LabelMessageText": "訊息文字:", "LabelMessageTitle": "訊息標題:", - "LabelMetadataDownloadLanguage": "首選下載語言:", + "LabelMetadataDownloadLanguage": "偏好下載語言:", "LabelMetadata": "中繼資料:", "LabelMethod": "方法:", "LabelNewName": "新名稱:", @@ -1063,7 +1063,7 @@ "OptionEnableM2tsMode": "啟用 M2ts 模式", "LabelKeepUpTo": "保持:", "LabelKidsCategories": "兒童分類:", - "LabelKodiMetadataEnablePathSubstitution": "啟用路徑替換", + "LabelKodiMetadataEnablePathSubstitution": "啟用路徑取代", "LabelKodiMetadataEnableExtraThumbs": "複製 extrafanart 到 extrathumbs 欄位", "LabelMovieCategories": "電影分類:", "LabelMoviePrefix": "電影前綴:", @@ -1073,7 +1073,7 @@ "LabelTranscodingContainer": "影片容器:", "MovieLibraryHelp": "查看 {0}Jellyfin 電影命名指南{1}。", "None": "無", - "OptionAllowMediaPlaybackTranscodingHelp": "由於不支持的媒體格式,限制轉檔可能會導致 Jellyfin 應用程式播放失敗。", + "OptionAllowMediaPlaybackTranscodingHelp": "限制轉檔可能會導致播放不支援的格式時失敗。", "MediaInfoLevel": "等級", "MessageNoTrailersFound": "安裝 Trailer channel 來新增網路上預告片,以增進你的電影體驗。", "OptionHasSpecialFeatures": "特色", @@ -1089,7 +1089,7 @@ "LabelHardwareAccelerationTypeHelp": "硬件加速需要額外的配置。", "LabelHomeNetworkQuality": "區域網路畫質:", "LabelHomeScreenSectionValue": "主畫面模塊 {0}:", - "LabelMetadataDownloadersHelp": "啟用媒體屬性下載器的優先次序,愈下次序只會用來填補缺少的信息。", + "LabelMetadataDownloadersHelp": "啟用中繼資料下載器的優先次序,愈下次序只會用來填補缺少的信息。", "LabelMetadataReaders": "中繼資料閱讀器:", "LabelMetadataSaversHelp": "選取儲存中繼資料的檔案格式。", "LabelModelNumber": "型號", @@ -1114,10 +1114,10 @@ "SeriesDisplayOrderHelp": "按播出日期、DVD 順序或編號對劇集進行排序。", "SeriesSettings": "系列設定", "SeriesYearToPresent": "{0} - 現在", - "ServerNameIsRestarting": "Jellyfin Server - {0} 重啟中。", - "ServerNameIsShuttingDown": "Jellyfin 伺服器 - {0} 正在關閉。", + "ServerNameIsRestarting": "伺服器將於 {0} 後重新啟動。", + "ServerNameIsShuttingDown": "伺服器將於 {0} 後關閉。", "SimultaneousConnectionLimitHelp": "允許的同時串流的最大數量。輸入 0 表示無限制。", - "SkipEpisodesAlreadyInMyLibrary": "不錄製我的媒體庫裡已存在的劇集", + "SkipEpisodesAlreadyInMyLibrary": "不錄製已存在於媒體庫中的劇集", "SmallCaps": "小型大寫字母", "SortChannelsBy": "頻道排序方式:", "SortName": "排序名稱", @@ -1125,16 +1125,16 @@ "StopRecording": "停止錄影", "LabelDefaultUserHelp": "確定哪些使用者媒體庫將顯示在連接裝置上。這可以為每個裝置提供不同的使用者設定檔。", "LabelEnableBlastAliveMessagesHelp": "若此伺服器無法被其他 UPnP 裝置偵測到,請啟用此選項。", - "LabelEnableDlnaClientDiscoveryIntervalHelp": "由 Jellyfin 決定進行 SSDP 搜尋之間的持續時間(以秒為單位)。", + "LabelEnableDlnaClientDiscoveryIntervalHelp": "決定進行 SSDP 搜尋之間的持續時間(以秒為單位)。", "LabelEnableDlnaPlayToHelp": "偵測您網路裡的設備並遠端控制它們。", "LabelExtractChaptersDuringLibraryScanHelp": "當媒體庫匯入影片並掃描時,將擷取章節圖片。\n否則,章節圖片將在之後的計畫任務中擷取,而媒體庫會更快完成掃描。", "LabelMoviePrefixHelp": "若前綴套用到電影標題,請在此處輸入它來方便伺服器能夠正確處理。", - "LabelMovieRecordingPath": "電影錄製路徑(選用):", + "LabelMovieRecordingPath": "電影錄製路徑:", "LabelNotificationEnabled": "啟用這個通知", "LabelProfileContainersHelp": "以逗號分隔,留空則適用於所有影片容器。", "LabelSelectFolderGroupsHelp": "未選中的資料夾將在其自己的檢視中顯示。", "LabelSerialNumber": "序號", - "LabelSeriesRecordingPath": "電視劇錄影路徑(選用):", + "LabelSeriesRecordingPath": "影集錄影路徑:", "LabelServerHost": "主機:", "LabelSimultaneousConnectionLimit": "同時串流限制:", "LabelSize": "大小:", @@ -1177,7 +1177,7 @@ "MessageConfirmDeleteGuideProvider": "您確定要刪除此指南提供者嗎?", "MessageConfirmProfileDeletion": "您確定要刪除這個設定檔嗎?", "MessageConfirmRemoveMediaLocation": "您確定要移除這個位置嗎?", - "MessageConfirmRevokeApiKey": "您確定要撤銷這個 API 金鑰嗎?這個應用程式與 Jellyfin 伺服器的連接將立即中斷。", + "MessageConfirmRevokeApiKey": "您確定要撤銷這個 API 金鑰嗎?這個應用程式與伺服器的連接將立即中斷。", "MessageCreateAccountAt": "在 {0} 建立使用者", "MessageDeleteTaskTrigger": "您確定要刪除這個任務觸發器嗎?", "MessageDirectoryPickerBSDInstruction": "對於 BSD 系統,您需要設定包含您 FreeNAS Jail 虛擬機的儲存以便 Jellyfin 存取。", @@ -1186,13 +1186,13 @@ "MessageFileReadError": "讀取檔案時發生錯誤。", "MessageForgotPasswordInNetworkRequired": "請檢查您的區域網路後再開始密碼重置流程。", "MessageForgotPasswordFileCreated": "已在伺服器上建立了以下檔案,並包含有關後續步驟說明:", - "MessageNoAvailablePlugins": "沒有可用的模組。", + "MessageNoAvailablePlugins": "沒有可用的附加元件。", "MessageNoServersAvailable": "無法自動偵測伺服器。", "MessageLeaveEmptyToInherit": "保留為空以繼承父項或全域預設值的設定。", "MessageNoCollectionsAvailable": "分組能夠讓您享受個性化的影片、劇集和專輯。點擊+按鈕開始建立分組。", "MessagePlayAccessRestricted": "此內容的播放受到限制,聯繫您的伺服器管理員以獲取更多訊息。", - "MessagePluginConfigurationRequiresLocalAccess": "請直接登入你的本地伺服器以設定這個模組。", - "MessagePluginInstallDisclaimer": "安裝 Jellyfin 社區成員建立的模組來獲取額外的功能可以最佳化您的 Jellyfin。但他們可能會對你的 Jellyfin 伺服器造成的影響,如更長的媒體庫掃描時間、額外的背景資料處理和降低系統穩定性等。", + "MessagePluginConfigurationRequiresLocalAccess": "請直接登入你的本地伺服器以設定這個附加元件。", + "MessagePluginInstallDisclaimer": "安裝 Jellyfin 社區成員建立的附加元件來讓您的 Jellyfin 獲取額外的功能優化您的使用體驗。但可能會對你的 Jellyfin 伺服器效能造成影響,如更長的媒體庫掃描時間、額外的背景資料處理與系統穩定性降低等。", "MessageReenableUser": "請參閱以下以重新啟用", "MessageUnableToConnectToServer": "無法連上所選的伺服器,請確保該伺服器正在運作中。", "MessageYouHaveVersionInstalled": "你目前安裝了 {0} 版本。", @@ -1209,13 +1209,13 @@ "MetadataSettingChangeHelp": "更改中繼資料設定將影響新增的新內容。要重新整理現有內容,請打開詳細訊息視窗並點選「重新整理」按鈕,或使用中繼資料管理器執行批次重新整理。", "MusicLibraryHelp": "查看{0}音樂命名指南{1}。", "OptionAutomaticallyGroupSeries": "自動合併分布在不同資料夾的電視劇", - "OptionAutomaticallyGroupSeriesHelp": "分布在這個媒體庫的多個文件夾中的同一部電視劇將會自動整合成一部電視劇。", + "OptionAutomaticallyGroupSeriesHelp": "媒體庫中同一部電視劇的多個資料夾將會自動整合一起。", "OptionDateAddedImportTime": "使用加入媒體庫時的掃描日期", "OptionDisplayFolderView": "顯示「資料夾」類別來瀏覽你的媒體資料夾", "OptionEmbedSubtitles": "在影片容器中嵌入", "OptionDownloadImagesInAdvance": "提前下載圖片", "OptionEnableAccessFromAllDevices": "允許所有裝置存取", - "OptionDownloadImagesInAdvanceHelp": "預設情況下,大多數圖片僅在Jellyfin應用程式請求時下載。啟用此選項可於匯入新媒體後提前下載所有圖片,可能會延長的媒體庫掃描時間。", + "OptionDownloadImagesInAdvanceHelp": "預設情況下,大多數圖片僅在應用程式請求時下載。啟用此選項可於匯入新媒體時提前下載所有圖片,可能會延長的媒體庫掃描時間。", "OptionEnableExternalContentInSuggestionsHelp": "允許將網際網路預告片和直播電視節目包含在建議的內容中。", "OptionHideUserFromLoginHelp": "對私人或隱藏的管理員帳戶很有用,但需手動輸入使用者名稱和密碼登入。", "OptionPlainStorageFolders": "顯示所有資料夾作為一般存儲資料夾", @@ -1223,16 +1223,16 @@ "OptionPlainVideoItemsHelp": "所有影片在 DIDL 中顯示為「object.item.videoItem」,而不是一個更具體的類型,如「object.item.videoItem.movie」。", "OptionProtocolHls": "HTTP 直播串流", "OptionReportByteRangeSeekingWhenTranscoding": "轉檔時,回報伺服器支持的位元組查詢", - "OptionSaveMetadataAsHidden": "儲存媒體資料和圖片為隱藏文件", + "OptionSaveMetadataAsHidden": "儲存中繼資料和圖片為隱藏文件", "OptionSubstring": "子串", "OptionWeekdays": "工作日", "Overview": "概述", "PackageInstallCancelled": "{0} (版本 {1})安裝被取消。", "PlayAllFromHere": "從這裡開始全部播放", "PleaseAddAtLeastOneFolder": "請點擊新增按鈕,新增至少一個資料夾到這個媒體庫。", - "PleaseConfirmPluginInstallation": "點擊「OK」以確認您已經閱讀了上述內容並希望繼續安裝模組。", + "PleaseConfirmPluginInstallation": "點擊「OK」以確認您已經閱讀了上述內容並希望繼續安裝附加元件。", "PleaseEnterNameOrId": "請輸入一個名稱或一個外部 ID。", - "PleaseRestartServerName": "請重啟 Jellyfin 伺服器 - {0}。", + "PleaseRestartServerName": "請重啟 Jellyfin 於 {0}。", "PleaseSelectTwoItems": "請至少選擇 2 個項目。", "PreferEmbeddedTitlesOverFileNames": "優先使用內建的標題而不是檔案名稱", "PreferEmbeddedTitlesOverFileNamesHelp": "這將在沒有網路上的中繼資料或本地中繼資料可用時顯示預設標題。", @@ -1248,7 +1248,7 @@ "Raised": "提高", "Rate": "評等", "Recordings": "錄影", - "ServerRestartNeededAfterPluginInstall": "安裝模組後,Jellyfin 伺服器需要重啟以使模組生效。", + "ServerRestartNeededAfterPluginInstall": "安裝附加元件後,Jellyfin 伺服器需要重啟使其生效。", "ShowIndicatorsFor": "顯示指標:", "Sort": "排序", "Studios": "工作室", @@ -1262,16 +1262,16 @@ "LabelMonitorUsers": "監控活動:", "LabelPleaseRestart": "改動將在手動重啟用戶端後生效。", "LabelProfileCodecsHelp": "以逗號分隔。留空則適用於所有編解碼器。", - "OptionPlainStorageFoldersHelp": "如果啟用,所有文件夾在DIDL中顯示為「object.container.storageFolder 」,而不是一個更具體的類型,如「object.container.person.musicArtist」。", + "OptionPlainStorageFoldersHelp": "所有資料夾在 DIDL 中顯示為「object.container.storageFolder 」,而不是一個更具體的類型,如「object.container.person.musicArtist」。", "LabelInNetworkSignInWithEasyPasswordHelp": "你可以在你的家庭網路中使用你的簡易 PIN 碼登錄 Jellyfin 應用程式,僅在你使用外部網路時才需要輸入密碼,如果 PIN 碼留空,那麼在你的區域網路中便不需輸入密碼。", "LabelReleaseDate": "釋出日期:", "LabelRemoteClientBitrateLimit": "網際網路串流傳輸位元率限制(Mbps):", - "LanNetworksHelp": "在強制頻寬限制時,認作本地網路上的 IP 地址或 IP/子網域遮罩項目的逗號分隔列表。若設置此項,所有其它 IP 地址將被視作在外部網路上,并且將受到外部頻寬限制。如果保留爲空,則只將服務器的子網域遮罩作本地網路。", + "LanNetworksHelp": "在強制頻寬限制時,認作本地網路上的 IP 位址或 IP/子網域遮罩項目的逗號分隔清單。若設置此項,所有其它 IP 位址將被視作在外部網路上,并且將受到外部頻寬限制。如果保留爲空,則只將伺服器的子網域遮罩作本地網路。", "OptionIgnoreTranscodeByteRangeRequests": "忽略轉檔位元組範圍請求", - "OptionIgnoreTranscodeByteRangeRequestsHelp": "如果啟用,這些請求會被兌現,但會忽略的位元組範圍標頭。", + "OptionIgnoreTranscodeByteRangeRequestsHelp": "這些請求會被接受,但會忽略的位元組範圍標頭。", "OptionLoginAttemptsBeforeLockoutHelp": "若值為 0,則表示將允許普通使用者嘗試三次、管理員嘗試五次的預設值,設定為 -1 來停用此功能。", "OptionRequirePerfectSubtitleMatchHelp": "僅下載經過測試並確認跟此影片檔案完美匹配的字幕。取消勾選這個項目可以增加找到並下載字幕的可能性,但可能會下載時間軸、翻譯不正確的字幕。", - "MessagePluginInstalled": "這個模組安裝成功,但 Jellyfin 伺服器需要重啟以使模組生效。", + "MessagePluginInstalled": "附加元件安裝成功,但需要重新啟動 Jellyfin 伺服器以使附加元件生效。", "MessageChangeRecordingPath": "更改錄製資料夾不會將現有錄製從舊位置遷移到新的,您需要手動移動它們。", "LabelEmbedAlbumArtDidl": "於 Didl 中嵌入專輯封面", "LabelEnableAutomaticPortMapHelp": "透過 UPnP 自動將路由器上的公共埠轉發到伺服器上的本地埠。這可能不適用於某些路由器型號或網路設定。在伺服器重新啟動後才會進行更改。", @@ -1281,7 +1281,7 @@ "SortByValue": "排序方式:{0}", "LabelLineup": "排隊:", "LabelLocalHttpServerPortNumber": "本地 HTTP 端口:", - "LabelLocalHttpServerPortNumberHelp": "Jellyfin HTTP 伺服器監聽的 TCP 端口。", + "LabelLocalHttpServerPortNumberHelp": "HTTP 伺服器的 TCP 端口。", "SubtitleAppearanceSettingsAlsoPassedToCastDevices": "這些設定也會被套用在任何透過此裝置發起的 Chromecast 播放。", "LabelLoginDisclaimer": "登入字句:", "LabelLogs": "日誌:", @@ -1297,11 +1297,11 @@ "LabelRecord": "錄影:", "LabelRecordingPath": "預設錄影路徑:", "LabelRecordingPathHelp": "指定用於存儲轉檔的位置,留空將使用伺服器的程式根目錄。", - "LabelRemoteClientBitrateLimitHelp": "所有網路裝置都有可選的流位元率限制,這對於防止設備請求比網路連接所能處理的更高的位元率非常有用。這可能會導致伺服器上的 CPU 負載增加,以便將影片轉檔到較低的位元率。", + "LabelRemoteClientBitrateLimitHelp": "所有網路裝置都能夠調整流位元率限制,這對於防止設備請求比網路連接所能處理的更高的位元率非常有用。這可能會導致伺服器上的 CPU 負載增加,以便將影片轉檔到較低的位元率。", "SmartSubtitlesHelp": "當音訊為外語時,將載入與語言偏好匹配的字幕。", "SubtitleAppearanceSettingsDisclaimer": "這些設定將不會套用在圖形字幕(如 PGS、DVD 等),或者一些有著自己的內建樣式的字幕(ASS/SSA)。", "UserAgentHelp": "提供自訂的使用者代理 HTTP 標頭。", - "LabelRuntimeMinutes": "播放時長(分鐘):", + "LabelRuntimeMinutes": "播放時間:", "LabelScheduledTaskLastRan": "最後執行 {0},花費時間 {1}。", "LabelSkipForwardLength": "快轉長度:", "LabelSkipIfAudioTrackPresent": "如果預設音軌的語言和下載語言一樣則跳過", @@ -1327,18 +1327,18 @@ "XmlTvNewsCategoriesHelp": "有這些類別的節目會被當作新聞節目,以「|」來分隔多個項目。", "LabelKodiMetadataEnableExtraThumbsHelp": "為了相容 Kodi 主題,下載的圖片將被同時儲存在 extrafanart 和 extrathumbs 資料夾中。", "LabelInternetQuality": "網路畫質:", - "LabelKodiMetadataEnablePathSubstitutionHelp": "允許將圖片的路徑以伺服器路徑來替換。", - "LabelKodiMetadataSaveImagePathsHelp": "如果您的圖片檔案名稱不符合 Kodi 規範,建議啟用。", - "LabelKodiMetadataUser": "儲存這些使用者的觀看資料到 NFO 檔案裏:", + "LabelKodiMetadataEnablePathSubstitutionHelp": "允許將圖片的路徑以伺服器路徑取代。", + "LabelKodiMetadataSaveImagePathsHelp": "若如果您的圖片檔案名稱不符合 Kodi 規範,建議啟用。", + "LabelKodiMetadataUser": "儲存這些使用者的觀看資料到 NFO 檔案中:", "LabelKodiMetadataUserHelp": "儲存觀看資料到 NFO 檔案中以便其他應用程式使用。", - "LabelMetadataReadersHelp": "優先排序您的首選資料屬性來源,首個找到的文件將被讀取。", + "LabelMetadataReadersHelp": "優先排序您的中繼資料屬性來源,首個找到的文件將被讀取。", "LabelMetadataSavers": "中繼資料儲存方式:", "LabelModelDescription": "型號描述", "LabelModelName": "型號名稱", "LabelModelUrl": "型號網址", "LabelMusicStreamingTranscodingBitrate": "音樂轉檔比特率:", "LabelMusicStreamingTranscodingBitrateHelp": "指定音樂串流時的最大比特率。", - "LabelOptionalNetworkPathHelp": "如果這個資料夾在網路上分享,提供網路分享路徑可以供其他 Jellyfin 應用程式直接存取媒體檔案,例如 {0} 或者 {1}。", + "LabelOptionalNetworkPathHelp": "如果這個資料夾在網路上分享,提供網路分享路徑可以供其他應用程式直接存取媒體檔案,例如 {0} 或者 {1}。", "LabelOriginalAspectRatio": "原始長寬比:", "LabelOverview": "內容概述:", "LabelParentalRating": "家長分級:", @@ -1385,27 +1385,27 @@ "ViewPlaybackInfo": "查看播放訊息", "XmlTvSportsCategoriesHelp": "有這些類別的節目會被當作體育節目,以「|」來分隔多個項目。", "XmlTvPathHelp": "XML 電視檔案的路徑,Jellyfin 將讀取該檔案並定期檢查其更新,您負責建立和更新檔案。", - "MessageInvalidForgotPasswordPin": "簡易代碼錯誤或已過期,請再試一次。", + "MessageInvalidForgotPasswordPin": "簡易代碼錯誤或已過期,請重試。", "OptionAllowVideoPlaybackTranscoding": "允許播放需要轉檔的影片", "Small": "小", "Smaller": "更小", "XmlTvKidsCategoriesHelp": "有這些類別的節目會被當作兒童節目,以「|」來分隔多個項目。", "TabResponses": "響應", "LabelDisplaySpecialsWithinSeasons": "顯示劇集季度中的特集", - "LabelNumberOfGuideDaysHelp": "下載更多電視指南資料會提供更好時間表查看能力,但將需要更長的下載時間。自動基於頻道數目來選擇。", - "LabelOptionalNetworkPath": "(選用)分享的網路資料夾:", + "LabelNumberOfGuideDaysHelp": "下載多日的節目指南可以幫你進一步查看節目列表並做出提前安排,但下載過程也將耗時更久。它將基於頻道數量自動選擇。", + "LabelOptionalNetworkPath": "分享的網路資料夾:", "OptionResElement": "res 元素", "PinCodeResetComplete": "PIN 碼已被重設。", "PinCodeResetConfirmation": "你確定要重設 PIN 碼?", - "PasswordResetProviderHelp": "選擇密碼重設提供者以便使用者重設密碼", + "PasswordResetProviderHelp": "選擇重設密碼提供者以便使用者重設密碼。", "PlaceFavoriteChannelsAtBeginning": "將喜愛的頻道置頂", "PlaybackData": "恢復播放資料", "OptionRandom": "隨機", "HeaderFavoritePeople": "最愛人物", - "XmlDocumentAttributeListHelp": "這些屬性會在每一個XML回應的根元素上應用。", + "XmlDocumentAttributeListHelp": "這些屬性會在每一個 XML 回應的根元素上套用。", "SkipEpisodesAlreadyInMyLibraryHelp": "劇集將使用季和劇集編號進行比較。", "SelectAdminUsername": "請為管理員賬戶選擇一個用戶名。", - "OptionSaveMetadataAsHiddenHelp": "更改此項將應用於以後保存的元數據。現有元數據文件將在下一次 Jellyfin 伺服器保存它們時被更新。", + "OptionSaveMetadataAsHiddenHelp": "更改此項將套用至未來保存的中繼資料。現有中繼資料檔案將在下一次伺服器儲存它們時被更新。", "OptionAllowRemoteSharedDevicesHelp": "DLNA裝置將被視為共享中,直至有使用者控制。", "OptionForceRemoteSourceTranscoding": "强制遠端轉碼(像電視直播一樣)", "MessageConfirmAppExit": "您要退出嗎?", @@ -1418,16 +1418,16 @@ "AskAdminToCreateLibrary": "如要建立資料庫,請聯繫管理員。", "NoCreatedLibraries": "看來您還未創任何媒體庫。{0}立刻創一個新的嗎?{1}", "ClientSettings": "客戶端設定", - "AllowFfmpegThrottlingHelp": "當轉檔或重組進度大量超前目前播放進度時,將暫停轉檔節省消耗的資源。在不常跳播的時候最有效。如果遇到播放問題,請關閉此功能。", + "AllowFfmpegThrottlingHelp": "當轉檔或重組進度遠超於目前播放進度時,將暫停轉檔節省消耗的資源。在不常跳播的時候最有效。如果遇到播放問題,請關閉此功能。", "AllowFfmpegThrottling": "限制轉檔", - "PreferEmbeddedEpisodeInfosOverFileNamesHelp": "這將會使用內建劇集資料。", + "PreferEmbeddedEpisodeInfosOverFileNamesHelp": "這將會使用內建中繼資料。", "PlaybackErrorNoCompatibleStream": "用戶端與該媒體不相容,伺服器也未傳送相容的媒體格式。", "PreferEmbeddedEpisodeInfosOverFileNames": "優先使用內建劇集資訊而不是檔案名稱", "Artist": "演出者", "AlbumArtist": "專輯歌手", "Album": "專輯", "YadifBob": "YADIF Bob", - "WriteAccessRequired": "Jellyfin 伺服器需要此資料夾的寫入權限,請確認是否擁有寫入權限並重試。", + "WriteAccessRequired": "伺服器需要此資料夾的寫入權限,請確認是否擁有寫入權限並重試。", "PathNotFound": "無法找到此路徑,請確認路徑可用並重試。", "Track": "音軌", "Yadif": "YADIF", @@ -1453,7 +1453,7 @@ "UnsupportedPlayback": "Jellyfin 無法解密受 DRM 保護的內容,但仍然會嘗試播放所有內容。某些檔案由於被加密或包含如互動標題等不受支援的內容,在播放時可能會沒有畫面。", "Filter": "篩選器", "New": "新增", - "ApiKeysCaption": "目前已啟用的API金鑰列表", + "ApiKeysCaption": "目前已啟用的 API 金鑰清單", "ButtonTogglePlaylist": "播放清單", "ButtonSyncPlay": "SyncPlay", "LabelRequireHttpsHelp": "開啟後伺服器將自動將所有 HTTP 請求導向 HTTPS。如果伺服器沒有啟用 HTTPS 則不生效。", @@ -1462,7 +1462,7 @@ "LabelRequireHttps": "強制 HTTPS", "LabelStable": "穩定版", "LabelChromecastVersion": "Chromecast 版本", - "LabelEnableHttpsHelp": "讓伺服器監聽指定的 HTTPS 端口。須設定有效的證書以便使其生效。", + "LabelEnableHttpsHelp": "監聽指定的 HTTPS 端口。須設定有效的證書使其生效。", "LabelEnableHttps": "啟用HTTPS", "HeaderServerAddressSettings": "伺服器位置設定", "HeaderRemoteAccessSettings": "遠端存取設定", @@ -1484,7 +1484,7 @@ "ShowMore": "顯示更多", "SyncPlayAccessHelp": "選取該使用者對同步播放的存取權。此功能能讓你與其他裝置同步播放進度。", "EnableBlurHash": "啟用模糊的占位圖片", - "EnableBlurHashHelp": "尚未讀取完畢的圖片會先顯示模糊的版本", + "EnableBlurHashHelp": "尚未讀取完畢的圖片會先顯示模糊的版本。", "ClearQueue": "清空佇列", "StopPlayback": "停止播放", "ButtonPlayer": "播放器", @@ -1493,7 +1493,7 @@ "ViewAlbumArtist": "檢視專輯演出者", "TabDVR": "DVR", "TabRepositories": "儲存庫", - "MessageSyncPlayErrorAccessingGroups": "存取群組列表時發生錯誤。", + "MessageSyncPlayErrorAccessingGroups": "存取群組清單時發生錯誤。", "MessageSyncPlayLibraryAccessDenied": "存取受限。", "MessageSyncPlayJoinGroupDenied": "需要同步播放之權限。", "MessageSyncPlayCreateGroupDenied": "需要建立群組之權限。", @@ -1522,5 +1522,13 @@ "MillisecondsUnit": "毫秒", "HeaderSyncPlayEnabled": "已啟用同步播放", "HeaderSyncPlaySelectGroup": "加入群組", - "HeaderDVR": "DVR" + "HeaderDVR": "DVR", + "SubtitleVerticalPositionHelp": "文字出現的行號。正數表示由上到下,負數表示由下到上。", + "MessagePluginInstallError": "安裝附加元件時發生了錯誤。", + "MessageGetInstalledPluginsError": "取得已安裝的附加元件清單時發生了錯誤。", + "Preview": "預覽", + "LabelSubtitleVerticalPosition": "垂直位置:", + "PreviousTrack": "上一首", + "NextTrack": "下一首", + "LabelUnstable": "不穩定" } From 26119dda3cfe7486d884e6ab8db8a7369b6b7cf7 Mon Sep 17 00:00:00 2001 From: Gualdimar Date: Wed, 12 Aug 2020 11:18:29 +0000 Subject: [PATCH 171/301] Translated using Weblate (Ukrainian) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/uk/ --- src/strings/uk.json | 135 +++++++++++++++++++++++++++++++++++++++----- 1 file changed, 120 insertions(+), 15 deletions(-) diff --git a/src/strings/uk.json b/src/strings/uk.json index 859d82ed35..a1100e1e69 100644 --- a/src/strings/uk.json +++ b/src/strings/uk.json @@ -1,13 +1,13 @@ { - "BirthDateValue": "Народився: {0}", + "BirthDateValue": "Дата народження: {0}", "BirthPlaceValue": "Місце народження: {0}", "ButtonAddUser": "Додати користувача", "ButtonCancel": "Скасувати", "ButtonFilter": "Фільтр", - "ButtonNew": "Новий", + "ButtonNew": "Нове", "ButtonRename": "Перейменувати", "ButtonResetPassword": "Скинути пароль", - "ButtonSignOut": "Sign out", + "ButtonSignOut": "Вийти", "DeathDateValue": "Помер: {0}", "Dislike": "Не подобається", "Favorite": "Улюблене", @@ -98,10 +98,10 @@ "All": "Всі", "AllChannels": "Всі канали", "AllEpisodes": "Всі епізоди", - "AllowRemoteAccess": "Дозволити віддалене підключення до цього сервера Jellyfin.", + "AllowRemoteAccess": "Дозволити віддалене підключення до цього сервера.", "AlwaysPlaySubtitles": "Завжди вмикати субтитри", "AnyLanguage": "Будь-яка мова", - "Anytime": "Завжди", + "Anytime": "У будь-який час", "Add": "Додати", "AddedOnValue": "Додано {0}", "Albums": "Альбоми", @@ -123,10 +123,10 @@ "HeaderFavoriteArtists": "Улюблені виконавці", "HeaderFavoriteShows": "Улюблені шоу", "HeaderContinueWatching": "Продовжити перегляд", - "AllowedRemoteAddressesHelp": "Список з комами, в якості розділювачів, визначає IP-адреси та IP/мережеві маски для мереж, яким дозволено підключатись віддалено. Якщо залишити строку пустою, то усі віддалені підключення будуть дозволені.", + "AllowedRemoteAddressesHelp": "Список розділених комами IP-адрес або IP/мережевих масок, яким буде дозволено віддалено підключатися. Якщо залишити порожнім, усі віддалені адреси будуть дозволені.", "AllowRemoteAccessHelp": "Якщо не відмічено прапорцем, усі віддалені підключення будуть заблоковані.", "AllowFfmpegThrottling": "Примусово обмежити перекодування", - "AllowMediaConversionHelp": "Надайте або забороніть доступ для можливості перетворення медіа.", + "AllowMediaConversionHelp": "Надати або заборонити доступ до функції конвертації медіа.", "AllowMediaConversion": "Дозволити перетворення медіа", "Alerts": "Термінові сповіщення", "AlbumArtist": "Виконавець альбому", @@ -139,20 +139,20 @@ "DropShadow": "Тінь", "Blacklist": "Чорний список", "BirthLocation": "Місце народження", - "Banner": "Обкладинка", + "Banner": "Банер", "Auto": "Автоматично", - "AuthProviderHelp": "Оберіть сервіс аутентифікації, який буде використаний з поточним паролем користувача.", + "AuthProviderHelp": "Оберіть сервіс аутентифікації, який буде використаний для автентифікації пароля даного користувача.", "Audio": "Аудіо", "AttributeNew": "Новий", - "AspectRatio": "Відношення сторін", - "AskAdminToCreateLibrary": "Попросіть адміністратора створити бібліотеку.", + "AspectRatio": "Співвідношення сторін", + "AskAdminToCreateLibrary": "Попросіть адміністратора створити медіатеку.", "Ascending": "У порядку зростання", - "AsManyAsPossible": "Настільки багато наскільки можливо", + "AsManyAsPossible": "Якнайбільше", "Artist": "Виконавець", - "Art": "Мистецтво", + "Art": "Обкладинка", "AllowOnTheFlySubtitleExtractionHelp": "Вбудовані субтитри можуть бути експортовані з відео і надіслані, по черзі, клієнтам у вигляді тексту. Це допоможе уникнути перекодування відео. На деяких системах, перекодування може зайняти тривалий час і зупинити відтворення відео, для того щоб забезпечити експортування. Вимкнення цієї функції дозволить вбудованим субтитрам бути інтегрованим у відео, під час перекодування, якщо вбудовані субтитри не підтримуються на стороні клієнта.", "AllowOnTheFlySubtitleExtraction": "Дозволити експортування субтитрів «на льоту»", - "AllowHWTranscodingHelp": "Дозволити клієнту перекодування на «на льоту». Це дозволить відмикати перекодування, якщо вона вимагається сервером.", + "AllowHWTranscodingHelp": "Тюнеру дозволяється перекодувати потоки на льоту. Це може допомогти зменшити перекодування, необхідне серверу.", "AllComplexFormats": "Усі складні формати (ASS, SSA, VOBSUB, PGS, SUB, IDX, …)", "ButtonSyncPlay": "SyncPlay", "ValueSpecialEpisodeName": "Спецепізод - {0}", @@ -162,5 +162,110 @@ "Playlists": "Плейлисти", "Photos": "Фотографії", "Aired": "Ефірний", - "AirDate": "Дата ефіру" + "AirDate": "Дата ефіру", + "CustomDlnaProfilesHelp": "Створіть спеціальний профіль, для нового пристрою або змініть системний профіль.", + "CriticRating": "Рейтинг критиків", + "CopyStreamURLSuccess": "URL-адреса успішно скопійована.", + "CopyStreamURL": "Скопіювати URL-адресу потоку", + "Continuing": "Продовження", + "ContinueWatching": "Продовжити перегляд", + "Connect": "Підключитись", + "ConfirmEndPlayerSession": "Ви хочете вимкнути Jellyfin на {0}?", + "ConfirmDeletion": "Підтвердити видалення", + "ConfirmDeleteItems": "Видалення цих елементів видалить їх як з файлової системи, так і з медіатеки. Ви впевнені, що хочете продовжити?", + "ConfirmDeleteItem": "Видалення цього елемента видалить його як з файлової системи, так і з медіатеки. Ви впевнені, що хочете продовжити?", + "ConfirmDeleteImage": "Видалити зображення?", + "ConfigureDateAdded": "Налаштуйте, як визначається дата додавання на інформаційній панелі в налаштуваннях медіатеки", + "Composer": "Композитор", + "CommunityRating": "Рейтинг спільноти", + "ColorTransfer": "Передача кольору", + "ColorSpace": "Кольоровий простір", + "ColorPrimaries": "Основні кольори", + "ClientSettings": "Налаштування клієнта", + "CinemaModeConfigurationHelp": "Режим кінотеатру забезпечує враження від глядацького залу прямо у вашій вітальні з можливістю відтворювати трейлери та власні відео перед фільмом.", + "ChannelNumber": "Номер каналу", + "ChannelNameOnly": "Тільки канал {0}", + "ChannelAccessHelp": "Виберіть канали, якими поділитись з даним користувачем. Адміністратори зможуть редагувати всі канали за допомогою менеджера метаданих.", + "ChangingMetadataImageSettingsNewContent": "Зміни в налаштуваннях завантаження метаданих або зображень стосуються лише нового вмісту, доданого до вашої бібліотеки. Щоб застосувати зміни до існуючих творів, потрібно оновити їх метадані вручну.", + "Categories": "Категорії", + "CancelSeries": "Скасувати серіал", + "CancelRecording": "Скасувати запис", + "ButtonWebsite": "Веб-сайт", + "ButtonUp": "Вгору", + "ButtonUninstall": "Видалити", + "ButtonTrailer": "Трейлер", + "ButtonTogglePlaylist": "Плейлист", + "ButtonSubtitles": "Субтитри", + "ButtonSubmit": "Підтвердити", + "ButtonSplit": "Розділити", + "ButtonStop": "Зупинити", + "ButtonStart": "Почати", + "ButtonSort": "Сортувати", + "ButtonSignIn": "Вхід", + "ButtonShutdown": "Завершити роботу", + "ButtonShuffle": "Перемішати", + "ButtonSettings": "Налаштування", + "ButtonSend": "Надіслати", + "ButtonSelectView": "Вибрати вигляд", + "ButtonSelectServer": "Вибрати сервер", + "ButtonSelectDirectory": "Вибрати каталог", + "ButtonScanAllLibraries": "Сканувати всі медіатеки", + "ButtonRevoke": "Відмінити", + "ButtonResume": "Відновити", + "ButtonRestart": "Перезапустити", + "ButtonResetEasyPassword": "Скинути простий пін-код", + "ButtonRemove": "Видалити", + "ButtonRefreshGuideData": "Оновити дані телегіда", + "ButtonRefresh": "Оновити", + "ButtonQuickStartGuide": "Посібник по швидкому запуску", + "ButtonProfile": "Профіль", + "ButtonPreviousTrack": "Попередня доріжка", + "ButtonPlay": "Відтворити", + "ButtonPause": "Пауза", + "ButtonParentalControl": "Батьківський контроль", + "ButtonOpen": "Відкрити", + "ButtonOk": "Ок", + "ButtonOff": "Вимкнути", + "ButtonNextTrack": "Наступна доріжка", + "ButtonNetwork": "Мережа", + "ButtonMore": "Більше", + "ButtonManualLogin": "Ввести ім’я користувача вручну", + "ButtonLibraryAccess": "Доступ до медіатеки", + "ButtonInfo": "Інформація", + "ButtonHome": "Головна", + "ButtonGuide": "Телегід", + "ButtonGotIt": "Зрозуміло", + "ButtonFullscreen": "Повноекранний режим", + "ButtonForgotPassword": "Забув(ла) пароль", + "ButtonEditOtherUserPreferences": "Редагувати профіль, зображення та особисті налаштування даного користувача.", + "ButtonEditImages": "Редагувати зображення", + "ButtonEdit": "Редагувати", + "ButtonDownload": "Завантажити", + "ButtonDown": "Вниз", + "ButtonDeleteImage": "Видалити зображення", + "ButtonDelete": "Видалити", + "ButtonConnect": "Підключитись", + "ButtonChangeServer": "Змінити сервер", + "ButtonBack": "Назад", + "ButtonAudioTracks": "Аудіозаписи", + "ButtonArrowUp": "Вниз", + "ButtonArrowRight": "Вправо", + "ButtonArrowLeft": "Вліво", + "ButtonArrowDown": "Вниз", + "ButtonAddServer": "Додати сервер", + "ButtonAddScheduledTaskTrigger": "Додати тригер", + "ButtonAddMediaLibrary": "Додати медіатеку", + "ButtonAddImage": "Додати зображення", + "BurnSubtitlesHelp": "Визначає, чи повинен сервер додавати субтитри під час перекодування відео. Уникнення цього значно покращить продуктивність. Виберіть Автоматично для записування форматів на основі зображень (VOBSUB, PGS, SUB, IDX, ...) та певні субтитри ASS або SSA.", + "MessageBrowsePluginCatalog": "Перегляньте каталог плагінів, щоб ознайомитися з доступними плагінами.", + "Browse": "Огляд", + "BoxRear": "Коробка (задня частина)", + "BoxSet": "Колекція", + "Box": "Коробка", + "BookLibraryHelp": "Підтримуються аудіо та текстові книги. Перегляньте {0} посібник з іменування книг {1}.", + "Backdrops": "Фони", + "Backdrop": "Фон", + "AroundTime": "Приблизно", + "AlwaysPlaySubtitlesHelp": "Субтитри, що відповідають мовним параметрам, завантажуватимуться незалежно від мови звуку.", + "AllowFfmpegThrottlingHelp": "Коли перекодування або перепакування досить далеко випереджає поточну позицію відтворення, процес призупиняється, щоб зекономити ресурси. Це найкорисніше при перегляді, коли рідко міняється позиція відтворення. Вимкніть це, якщо виникнуть проблеми з відтворенням." } From c11dc53e44fb40c0d0c7fb88de636738a60a4109 Mon Sep 17 00:00:00 2001 From: MrTimscampi Date: Wed, 12 Aug 2020 15:12:03 +0200 Subject: [PATCH 172/301] Fix require --- src/components/appRouter.js | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/src/components/appRouter.js b/src/components/appRouter.js index dc05acc9fd..83c93fdaf3 100644 --- a/src/components/appRouter.js +++ b/src/components/appRouter.js @@ -287,7 +287,7 @@ class AppRouter { this.showWelcome(); break; case 'ServerUpdateNeeded': - require(['alert'], (alert) => { + import('alert').then(({default: alert}) =>{ alert({ text: globalize.translate('ServerUpdateNeeded', 'https://github.com/jellyfin/jellyfin'), html: globalize.translate('ServerUpdateNeeded', 'https://github.com/jellyfin/jellyfin') @@ -322,7 +322,8 @@ class AppRouter { url += '?' + ctx.querystring; } - require(['text!' + url], (html) => { + import('text!' + url).then(({default: html}) => { + console.warn(html) this.loadContent(ctx, route, html, request); }); } @@ -339,7 +340,7 @@ class AppRouter { }; if (route.controller) { - require(['controllers/' + route.controller], onInitComplete); + import('controllers/' + route.controller).then(onInitComplete); } else { onInitComplete(); } @@ -406,7 +407,7 @@ class AppRouter { this.forcedLogoutMsg = null; if (msg) { - require(['alert'], (alert) => { + import('alert').then((alert) => { alert(msg); }); } From ed4e733a6499e866915fea54a3c9a014ba760917 Mon Sep 17 00:00:00 2001 From: MrTimscampi Date: Wed, 12 Aug 2020 15:18:13 +0200 Subject: [PATCH 173/301] Remove default --- src/controllers/playback/video/index.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/controllers/playback/video/index.js b/src/controllers/playback/video/index.js index 8f46d24f0e..73540cd636 100644 --- a/src/controllers/playback/video/index.js +++ b/src/controllers/playback/video/index.js @@ -1440,7 +1440,7 @@ import 'css!assets/css/videoosd'; }); } catch (e) { import('appRouter').then(({default: appRouter}) => { - appRouter.default.goHome(); + appRouter.goHome(); }); } }); From e432f3fed2ab4d2881b9f1b3bc80b6deb539b6b2 Mon Sep 17 00:00:00 2001 From: MrTimscampi Date: Wed, 12 Aug 2020 15:21:56 +0200 Subject: [PATCH 174/301] Fix issues --- src/components/packageManager.js | 1 - src/components/pluginManager.js | 6 +++--- 2 files changed, 3 insertions(+), 4 deletions(-) diff --git a/src/components/packageManager.js b/src/components/packageManager.js index 358529ba79..c20f6c5d3e 100644 --- a/src/components/packageManager.js +++ b/src/components/packageManager.js @@ -10,7 +10,6 @@ import pluginManager from 'pluginManager'; console.groupCollapsed('loading packages'); var manifestUrls = JSON.parse(appSettings.get(this.#settingsKey) || '[]'); - var instance = this; return Promise.all(manifestUrls.map((url) => { return this.loadPackage(url); })) diff --git a/src/components/pluginManager.js b/src/components/pluginManager.js index c4418cbff5..b662cca836 100644 --- a/src/components/pluginManager.js +++ b/src/components/pluginManager.js @@ -21,8 +21,8 @@ import globalize from 'globalize'; } #definePluginRoute(route, plugin) { - route.contentPath = this.#mapPath(plugin, route.path); - route.path = this.mapRoute(plugin, route); + route.contentPath = this.mapPath(plugin, route.path); + route.path = this.#mapRoute(plugin, route); Emby.App.defineRoute(route, plugin.id); } @@ -128,7 +128,7 @@ import globalize from 'globalize'; return '/plugins/' + plugin.id + '/' + route; } - #mapPath(plugin, path, addCacheParam) { + mapPath(plugin, path, addCacheParam) { if (typeof plugin === 'string') { plugin = this.pluginsList.filter((p) => { return (p.id || p.packageName) === plugin; From 25b343ac32128968a4d6815f862a7e52e9f40435 Mon Sep 17 00:00:00 2001 From: Matt Strayer Date: Wed, 12 Aug 2020 09:33:15 -0400 Subject: [PATCH 175/301] re-add newline --- package.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/package.json b/package.json index e1ec7750fd..cbfe998015 100644 --- a/package.json +++ b/package.json @@ -375,4 +375,4 @@ "lint": "eslint \".\"", "stylelint": "stylelint \"src/**/*.css\"" } -} \ No newline at end of file +} From 6c3ec3ab97e93f25b231be103fc630a96681f062 Mon Sep 17 00:00:00 2001 From: gnehs Date: Wed, 12 Aug 2020 14:28:28 +0000 Subject: [PATCH 176/301] Translated using Weblate (Chinese (Traditional)) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/zh_Hant/ --- src/strings/zh-tw.json | 138 ++++++++++++++++++++--------------------- 1 file changed, 69 insertions(+), 69 deletions(-) diff --git a/src/strings/zh-tw.json b/src/strings/zh-tw.json index 37dd333bb6..c937cdb161 100644 --- a/src/strings/zh-tw.json +++ b/src/strings/zh-tw.json @@ -92,7 +92,7 @@ "HeaderUsers": "使用者", "Help": "說明", "ItemCount": "{0}個項目", - "LabelAudioLanguagePreference": "音頻語言偏好選項:", + "LabelAudioLanguagePreference": "音訊語言偏好選項:", "LabelCachePath": "快取路徑:", "LabelCollection": "收藏櫃:", "LabelContentType": "內容類型:", @@ -100,11 +100,11 @@ "LabelCurrentPassword": "當前的密碼:", "LabelDay": "日:", "LabelDisplayMissingEpisodesWithinSeasons": "顯示節目季度內缺少的單元", - "LabelEnableDlnaClientDiscoveryInterval": "尋找客戶端時間間隔", + "LabelEnableDlnaClientDiscoveryInterval": "尋找用戶端時間間隔", "LabelEnableDlnaDebugLogging": "記錄 DLNA 除錯資料到日誌", "LabelEnableDlnaDebugLoggingHelp": "將會建立非常大的日誌檔案,建議在進行故障排除時啟用。", "LabelEnableDlnaPlayTo": "播放到 DLNA 設備", - "LabelEnableRealtimeMonitor": "啟用實時監控", + "LabelEnableRealtimeMonitor": "啟用即時監控", "LabelEnableRealtimeMonitorHelp": "檔案的更改將在支援的檔案系統上立即處理。", "LabelEvent": "事件:", "LabelEveryXMinutes": "每:", @@ -145,14 +145,14 @@ "MessageItemsAdded": "已新增項目。", "MessageNoMovieSuggestionsAvailable": "目前並沒有推薦的電影,開始觀看並對您的電影評分後,我們就會為您推薦您可能會喜歡的內容。", "MessageNothingHere": "這裡沒有什麼。", - "MessagePasswordResetForUsers": "下列使用者的密碼已被重新設置。該使用者現在可以使用在密碼重置時所使用之 PIN 代碼進行登入。", - "MessagePleaseEnsureInternetMetadata": "請確保已啟用從互聯網下載媒體資料。", + "MessagePasswordResetForUsers": "下列使用者的密碼已被重新設置。該使用者現在可以使用在密碼重設時所使用之 PIN 代碼進行登入。", + "MessagePleaseEnsureInternetMetadata": "請確保已啟用從網際網路下載媒體資料。", "Monday": "星期一", "MoreUsersCanBeAddedLater": "也可於控制台內新增使用者。", "MySubtitles": "我的字幕", "NewCollection": "新合集", "NewCollectionHelp": "收藏櫃讓您能夠建立個人化的影音及其他媒體的分類。", - "NewCollectionNameExample": "例子:星球大戰合集", + "NewCollectionNameExample": "例子:星際大戰合集", "MessageNoNextUpItems": "沒有找到。開始看你的節目!", "NoSubtitleSearchResultsFound": "無結果。", "OptionAlbum": "專輯", @@ -182,7 +182,7 @@ "OptionDownloadLogoImage": "標誌", "OptionDownloadMenuImage": "菜單", "OptionDownloadPrimaryImage": "主要圖", - "OptionDownloadThumbImage": "縮略圖", + "OptionDownloadThumbImage": "縮圖", "OptionDvd": "DVD", "OptionEnded": "完結", "OptionFavorite": "我的最愛", @@ -192,7 +192,7 @@ "OptionHasThemeVideo": "主題影片", "OptionHideUser": "在登入頁面隱藏此使用者", "OptionImdbRating": "IMDB評分", - "OptionIsHD": "高清", + "OptionIsHD": "高畫質", "OptionIsSD": "標清", "OptionLikes": "喜歡", "OptionMissingEpisode": "缺少了的單元", @@ -237,7 +237,7 @@ "Saturday": "星期六", "Save": "保存", "Search": "搜尋", - "SearchForCollectionInternetMetadata": "在網路上搜索媒體圖像和資料", + "SearchForCollectionInternetMetadata": "在網路上搜尋媒體圖像和資料", "SearchForMissingMetadata": "搜尋遺失的中繼資料", "SearchForSubtitles": "搜尋字幕", "SeriesRecordingScheduled": "已排程錄製整個系列。", @@ -260,7 +260,7 @@ "TabMovies": "電影", "TabMusic": "音樂", "TabMyPlugins": "我的附加元件", - "TabNetworks": "網絡", + "TabNetworks": "網路", "TabPassword": "密碼", "TabProfile": "設定", "TabProfiles": "設定", @@ -332,13 +332,13 @@ "Aired": "已播於", "AllEpisodes": "所有集數", "AllowHWTranscodingHelp": "若啟用,將會允許調諧器同步轉檔,能夠減少伺服器轉檔需求。", - "AllowOnTheFlySubtitleExtraction": "允許同步字幕截取", - "AllowOnTheFlySubtitleExtractionHelp": "可以從影片中提取內建字幕並以純文字的形式給 Jellyfin 應用程式以避免影片轉檔。某些系統中提取的過程可能會花費較長時間並導致影片播放出現停滯。若停用這個選項,當內建字幕不被播放端設備支援時,字幕將透過轉檔嵌入影片中。", + "AllowOnTheFlySubtitleExtraction": "允許即時擷取字幕", + "AllowOnTheFlySubtitleExtractionHelp": "從影片中提取內建字幕並以純文字的形式顯示以避免影片轉檔。某些系統中提取的過程可能花費較長時間並導致影片播放出現停滯。若停用這個選項,當內建字幕不被播放端設備支援時,字幕將透過轉檔嵌入影片中。", "AllowedRemoteAddressesHelp": "可以從非本地連線的 IP 位址或 IP/子網域遮罩清單,用冒號分隔。 留白則允許所有IP。", "BookLibraryHelp": "支援有聲書和電子書。請瀏覽 {0}書籍命名指南{1}。", "Box": "盒子", "BoxRear": "盒子(背面)", - "BurnSubtitlesHelp": "根據字幕格式決定伺服器在影片轉檔時是否燒錄字幕。避免燒錄字幕時消耗過多伺服器資源。選擇「自動」以燒錄基於圖片的字幕格式(如 VOBSUB、PGS 或 SUB/IDX 等)和一些複雜的 ASS/SSA 字幕。", + "BurnSubtitlesHelp": "根據字幕格式決定伺服器在影片轉檔時是否燒錄字幕。避免燒錄字幕時消耗過多伺服器資源。選擇「自動」以燒錄圖片格式的字幕(如 VOBSUB、PGS 或 SUB/IDX 等)與複雜的 ASS/SSA 字幕。", "ButtonArrowDown": "下", "ButtonConnect": "連結", "ButtonDown": "下", @@ -379,7 +379,7 @@ "CancelRecording": "取消錄影", "CancelSeries": "取消系列", "Categories": "類別", - "ChangingMetadataImageSettingsNewContent": "更改影片中繼資料或媒體圖像的下載設定僅對以後添加至媒體庫中的新内容生效,若需更改已存在的資料,請手動更新中繼資料。", + "ChangingMetadataImageSettingsNewContent": "更改影片中繼資料或媒體圖像的下載設定僅對以後添加至媒體庫中的新內容生效,若需更改已存在的資料,請手動更新中繼資料。", "ChannelAccessHelp": "選擇與此使用者共享之頻道。管理員將能夠使用中繼資料管理器編輯所有資料夾。", "ChannelNameOnly": "只在頻道 {0}", "ChannelNumber": "頻道號碼", @@ -432,7 +432,7 @@ "Down": "下", "DownloadsValue": "{0} 個下載", "DrmChannelsNotImported": "受 DMR 保護的頻道將不會被導入。", - "DropShadow": "背景投影", + "DropShadow": "陰影", "EasyPasswordHelp": "你的簡易 PIN 碼將會用於在支援的 Jellyfin 應用上進行離線存取,同時也可被用於區域網路的登入。", "EditMetadata": "編輯中繼資料", "EditSubtitles": "編輯字幕", @@ -524,7 +524,7 @@ "HeaderConfigureRemoteAccess": "設定遠端控制", "HeaderConfirmPluginInstallation": "確認附加元件安裝", "HeaderConfirmProfileDeletion": "確認刪除個人資料", - "HeaderConfirmRevokeApiKey": "重置 API 金鑰", + "HeaderConfirmRevokeApiKey": "重設 API 金鑰", "HeaderConnectToServer": "連結至伺服器", "HeaderConnectionFailure": "連結失敗", "HeaderContainerProfile": "影片載體設定", @@ -617,7 +617,7 @@ "HeaderSeasons": "季數", "HeaderSecondsValue": "{0} 秒", "HeaderSelectPath": "選擇位址", - "HeaderSelectTranscodingPath": "選擇轉碼暫放位址", + "HeaderSelectTranscodingPath": "選擇轉檔暫放位址", "HeaderSelectTranscodingPathHelp": "瀏覽或輸入轉檔用來存暫時資料的位址。資料夾需具寫入權限。", "HeaderSendMessage": "傳送訊息", "HeaderSeriesOptions": "系列選項", @@ -646,7 +646,7 @@ "AuthProviderHelp": "選擇用於驗證使用者密碼的身份驗證提供者。", "HeaderParentalRatings": "家長評級", "HeaderProfile": "設定檔", - "HeaderProfileInformation": "設定檔信息", + "HeaderProfileInformation": "設定檔訊息", "HeaderProfileServerSettingsHelp": "這些數值將控制伺服器如何呈現給設備。", "HeaderResponseProfile": "回覆設定檔", "HeaderResponseProfileHelp": "當播放某些類型的媒體時,回覆設定檔提供一種方法來發送自定訊息到設備。", @@ -657,8 +657,8 @@ "HeaderSubtitleProfiles": "字幕設定檔", "HeaderSubtitleProfilesHelp": "字幕設定檔描述設備所支援的字幕格式。", "HeaderTaskTriggers": "任務觸發", - "HeaderTranscodingProfile": "轉碼設定", - "HeaderTranscodingProfileHelp": "新增轉碼設定檔標明哪些媒體格式需要轉碼處理。", + "HeaderTranscodingProfile": "轉檔設定", + "HeaderTranscodingProfileHelp": "新增轉檔設定檔標明哪些媒體格式需要轉檔處理。", "HeaderTuners": "調諧器", "HeaderTypeImageFetchers": "{0} 圖片獲取程序", "HeaderTypeText": "輸入文字", @@ -683,13 +683,13 @@ "Images": "圖片", "ImportFavoriteChannelsHelp": "若啟用,僅於調諧器設備中被標記為我的最愛的頻道才會被導入。", "ImportMissingEpisodesHelp": "缺失劇集的資料將導入您的媒體庫,並在季度與系列中顯示。 可能導致媒體庫掃描延長。", - "InstallingPackage": "正在安装 {0}(版本 {1})", + "InstallingPackage": "正在安裝 {0}(版本 {1})", "InstantMix": "即時混音", "Items": "項目", "Kids": "兒童", "Label3DFormat": "3D 格式:", "LabelAbortedByServerShutdown": "(因為伺服器關閉被中止)", - "LabelAccessDay": "一周中的何時:", + "LabelAccessDay": "一週中的何時:", "LabelAccessEnd": "結束時間:", "LabelAccessStart": "開始時間:", "LabelAirDays": "播出日期:", @@ -700,22 +700,22 @@ "LabelAlbum": "專輯:", "LabelAlbumArtHelp": "PN 在 upnp:albumArtURI 裡的 dlna:profileID 屬性用於專輯封面。某些設備不管圖像的尺寸大小,都會要求特定的值。", "LabelAlbumArtMaxHeight": "專輯封面最大高度:", - "LabelAlbumArtMaxHeightHelp": "通過 upnp:albumArtURI 顯示的專輯封面超鏈接的最大分辨率。", + "LabelAlbumArtMaxHeightHelp": "通過 upnp:albumArtURI 顯示的專輯封面超連結的最大解析度。", "LabelAlbumArtMaxWidth": "專輯封面最大寬度:", - "LabelAlbumArtMaxWidthHelp": "通過 upnp:albumArtURI 顯示的專輯封面超鏈接的最大解析度。", + "LabelAlbumArtMaxWidthHelp": "通過 upnp:albumArtURI 顯示的專輯封面超連結的最大解析度。", "LabelAlbumArtPN": "專輯封面 PN :", "LabelAlbumArtists": "專輯作家:", - "LabelAllowHWTranscoding": "允許硬體轉碼", + "LabelAllowHWTranscoding": "允許硬體轉檔", "LabelAllowedRemoteAddresses": "遠端 IP 位址過濾:", "LabelAllowedRemoteAddressesMode": "遠端 IP 位址過濾模式:", "LabelAppName": "APP 名稱", "LabelAppNameExample": "例如:可愛蹦蹦主機、小安的 Jellyfin", "LabelArtists": "藝人:", "LabelArtistsHelp": "將多位演出者以「;」分隔。", - "LabelAudio": "音頻", + "LabelAudio": "音訊", "LabelAuthProvider": "認證提供者:", "LabelAutomaticallyRefreshInternetMetadataEvery": "從網路自動抓取中繼資料:", - "LabelBindToLocalNetworkAddress": "綁定本地網絡地址:", + "LabelBindToLocalNetworkAddress": "綁定本地網路地址:", "LabelBindToLocalNetworkAddressHelp": "(選用)覆蓋 HTTP 伺服器綁定的本地 IP 位址。如果留空,伺服器將會監聽所有可用的地址。改變此欄位需重啟 Jellyfin 伺服器。", "LabelBirthDate": "出生日期:", "LabelBirthYear": "出生年:", @@ -743,7 +743,7 @@ "LabelCustomDeviceDisplayNameHelp": "指定自訂的顯示名稱,或者留空以使用設備自己報告的名稱。", "LabelCustomRating": "自訂分級:", "LabelDateAdded": "新增日期:", - "LabelDateAddedBehavior": "新内容加入的日期應使用:", + "LabelDateAddedBehavior": "新內容加入的日期應使用:", "LabelDateTimeLocale": "設定時區:", "LabelDeathDate": "死亡時間:", "LabelDefaultScreen": "預設分頁:", @@ -763,8 +763,8 @@ "LabelAudioBitDepth": "音訊位元深度:", "LabelBaseUrl": "根路徑:", "LabelIconMaxHeight": "圖示最高高度:", - "LabelHttpsPortHelp": "HTTPS 伺服器的 TCP 端口。", - "LabelIconMaxHeightHelp": "通過 upnp:icon 的圖標最大解析度。", + "LabelHttpsPortHelp": "HTTPS 伺服器的 TCP 埠。", + "LabelIconMaxHeightHelp": "通過 upnp:icon 的圖示最大解析度。", "CopyStreamURL": "複製串流連結", "MediaInfoDefault": "預設", "MediaInfoStreamTypeAudio": "音訊", @@ -773,7 +773,7 @@ "LabelSeasonNumber": "季:", "LabelDropImageHere": "拖移圖片到這裡,或是點擊來選取。", "LabelImageType": "圖片格式:", - "LabelIdentificationFieldHelp": "不區分大小寫的子字符串或正則表達式。", + "LabelIdentificationFieldHelp": "不區分大小寫的子字串或正則表達式。", "Large": "大", "LabelTranscodingAudioCodec": "音訊編碼:", "MessageSettingsSaved": "設定已儲存.", @@ -823,9 +823,9 @@ "Shuffle": "隨機播放", "Smart": "智慧", "HeaderFavoriteBooks": "最愛的書籍", - "LabelAudioBitrate": "音訊比特率:", + "LabelAudioBitrate": "音訊位元率:", "LabelAudioCodec": "音訊編碼:", - "LabelBitrate": "比特率:", + "LabelBitrate": "位元率:", "LabelAudioChannels": "音訊聲道:", "LabelAudioSampleRate": "音訊取樣率:", "LabelFont": "字體:", @@ -833,12 +833,12 @@ "LabelDisplayOrder": "顯示順序:", "LabelEnableBlastAliveMessages": "活動訊息", "LabelEnableDlnaServer": "啟用 DLNA 伺服器", - "LabelEnableDlnaServerHelp": "允許網絡上的 UPnP 設備瀏覽和播放內容。", + "LabelEnableDlnaServerHelp": "允許網路上的 UPnP 設備瀏覽和播放內容。", "LabelEnableHardwareDecodingFor": "為以下啟用硬體解碼:", "LabelEpisodeNumber": "集:", "LabelBaseUrlHelp": "您可以在此處自訂伺服器 URL 路徑的子目錄,如:http://example.com/<baseurl>", "LabelExtractChaptersDuringLibraryScan": "於媒體庫掃描時擷取章節圖片", - "LabelHttpsPort": "本地 HTTPS 端口:", + "LabelHttpsPort": "本地 HTTPS 埠:", "LabelFailed": "失敗", "LabelSubtitles": "字幕", "LabelSupportedMediaTypes": "支援的媒體類型:", @@ -864,7 +864,7 @@ "ManageLibrary": "管理媒體庫", "MarkPlayed": "標記為已播放", "MarkUnplayed": "標記為未播放", - "MediaInfoBitrate": "比特率", + "MediaInfoBitrate": "位元率", "MediaInfoChannels": "聲道", "MediaInfoCodec": "編碼", "MediaInfoContainer": "影片容器", @@ -946,7 +946,7 @@ "LabelDownloadLanguages": "下載語言:", "LabelDynamicExternalId": "{0} Id:", "LabelEasyPinCode": "簡易代碼:", - "LabelEnableAutomaticPortMap": "啟用自動端口映射", + "LabelEnableAutomaticPortMap": "啟用自動埠映射", "LabelEnableSingleImageInDidlLimit": "限制單個嵌入式圖片", "LabelEndDate": "結束日期:", "LabelLockItemToPreventChanges": "鎖定此項目來避免被更改", @@ -959,7 +959,7 @@ "LabelSelectVersionToInstall": "選擇要安裝的版本:", "LabelSendNotificationToUsers": "傳送通知給:", "LabelSortBy": "排序按照:", - "LabelVideoBitrate": "影片比特率:", + "LabelVideoBitrate": "影片位元率:", "MediaInfoSize": "大小", "MediaInfoTimestamp": "時間戳", "MediaInfoStreamTypeData": "檔案", @@ -990,12 +990,12 @@ "LabelGroupMoviesIntoCollectionsHelp": "顯示電影清單時,屬於相同集合的電影將作為分組項目顯示。", "LabelEncoderPreset": "H264 解碼品質:", "LabelHardwareAccelerationType": "硬體加速:", - "LabelIconMaxWidthHelp": "通過 upnp:icon 的圖標最大解析度。", + "LabelIconMaxWidthHelp": "通過 upnp:icon 的圖示最大解析度。", "LabelImportOnlyFavoriteChannels": "僅限收藏的頻道", "LabelInNetworkSignInWithEasyPassword": "啟用以簡易密碼進行區域網路登入", "LabelH264Crf": "H264 編碼 CRF:", "LabelMaxStreamingBitrate": "最大串流畫質:", - "LabelMaxStreamingBitrateHelp": "指定最大串流比特率。", + "LabelMaxStreamingBitrateHelp": "指定最大串流位元率。", "LabelMessageText": "訊息文字:", "LabelMessageTitle": "訊息標題:", "LabelMetadataDownloadLanguage": "偏好下載語言:", @@ -1086,10 +1086,10 @@ "Writer": "編劇", "XmlTvMovieCategoriesHelp": "有這些類別的節目會被當作電影,以「|」來分隔多個項目。", "ValueSeriesCount": "{0} 劇集", - "LabelHardwareAccelerationTypeHelp": "硬件加速需要額外的配置。", + "LabelHardwareAccelerationTypeHelp": "硬體加速需要額外的配置。", "LabelHomeNetworkQuality": "區域網路畫質:", - "LabelHomeScreenSectionValue": "主畫面模塊 {0}:", - "LabelMetadataDownloadersHelp": "啟用中繼資料下載器的優先次序,愈下次序只會用來填補缺少的信息。", + "LabelHomeScreenSectionValue": "主畫面模組 {0}:", + "LabelMetadataDownloadersHelp": "啟用中繼資料下載器的優先次序,愈下次序只會用來填補缺少的訊息。", "LabelMetadataReaders": "中繼資料閱讀器:", "LabelMetadataSaversHelp": "選取儲存中繼資料的檔案格式。", "LabelModelNumber": "型號", @@ -1099,7 +1099,7 @@ "OptionDownloadBannerImage": "橫幅", "OptionEnableAccessToAllChannels": "允許存取所有頻道", "OptionEnableAccessToAllLibraries": "允許存取所有媒體庫", - "OptionEnableForAllTuners": "开启所有调谐器", + "OptionEnableForAllTuners": "開啟所有調諧器", "OptionExtractChapterImage": "開啟章節圖片擷取", "OptionEnableM2tsModeHelp": "當編碼為 MPEGTS 時啟用 M2TS 模式。", "OptionEquals": "等於", @@ -1139,13 +1139,13 @@ "LabelSimultaneousConnectionLimit": "同時串流限制:", "LabelSize": "大小:", "LabelSkipBackLength": "跳過長度:", - "LabelSkipIfGraphicalSubsPresentHelp": "保留文字版本的字幕會更有效率傳遞,減低影片轉碼的機會。", + "LabelSkipIfGraphicalSubsPresentHelp": "保留文字版本的字幕會更有效率傳遞,減低影片轉檔的機會。", "LabelStopWhenPossible": "當可能時自動停止:", "LabelStopping": "停止", "LabelTagline": "個性宣言:", "LabelSubtitleDownloaders": "字幕下載器:", - "LabelSubtitleFormatHelp": "例如:SRT", - "LabelSubtitlePlaybackMode": "字幕模式:", + "LabelSubtitleFormatHelp": "如:SRT", + "LabelSubtitlePlaybackMode": "字幕載入:", "LabelTranscodingThreadCount": "轉檔執行緒數:", "LabelTunerIpAddress": "調諧器 IP 位址:", "LabelTunerType": "調諧器類型:", @@ -1184,7 +1184,7 @@ "MessageDirectoryPickerLinuxInstruction": "使用 Linux on Arch Linux、CentOS、Debian、Fedora、openSUSE 或 Ubuntu 作業系統,您必須授權使用者至少讀取權限來存取您的儲存路徑。", "MessageEnablingOptionLongerScans": "啟用這個選項可能會延長媒體庫的掃描時間。", "MessageFileReadError": "讀取檔案時發生錯誤。", - "MessageForgotPasswordInNetworkRequired": "請檢查您的區域網路後再開始密碼重置流程。", + "MessageForgotPasswordInNetworkRequired": "請檢查您的區域網路後再開始密碼重設流程。", "MessageForgotPasswordFileCreated": "已在伺服器上建立了以下檔案,並包含有關後續步驟說明:", "MessageNoAvailablePlugins": "沒有可用的附加元件。", "MessageNoServersAvailable": "無法自動偵測伺服器。", @@ -1192,7 +1192,7 @@ "MessageNoCollectionsAvailable": "分組能夠讓您享受個性化的影片、劇集和專輯。點擊+按鈕開始建立分組。", "MessagePlayAccessRestricted": "此內容的播放受到限制,聯繫您的伺服器管理員以獲取更多訊息。", "MessagePluginConfigurationRequiresLocalAccess": "請直接登入你的本地伺服器以設定這個附加元件。", - "MessagePluginInstallDisclaimer": "安裝 Jellyfin 社區成員建立的附加元件來讓您的 Jellyfin 獲取額外的功能優化您的使用體驗。但可能會對你的 Jellyfin 伺服器效能造成影響,如更長的媒體庫掃描時間、額外的背景資料處理與系統穩定性降低等。", + "MessagePluginInstallDisclaimer": "安裝 Jellyfin 社區成員建立的附加元件來讓您的 Jellyfin 獲取額外的功能最佳化您的使用體驗。但可能會對你的 Jellyfin 伺服器效能造成影響,如更長的媒體庫掃描時間、額外的背景資料處理與系統穩定性降低等。", "MessageReenableUser": "請參閱以下以重新啟用", "MessageUnableToConnectToServer": "無法連上所選的伺服器,請確保該伺服器正在運作中。", "MessageYouHaveVersionInstalled": "你目前安裝了 {0} 版本。", @@ -1201,7 +1201,7 @@ "NoNewDevicesFound": "找不到裝置,要添加新調諧器,請關閉此對話框並手動輸入裝置訊息。", "OnlyForcedSubtitles": "僅顯示強制字幕", "OnlyImageFormats": "圖片格式(VOBSUB、PGS、SUB)", - "OptionAllowLinkSharingHelp": "只有網頁包含的媒體訊息會被共享,媒體檔案本身不會被公開共享,共享的內容會在 {0} 天後到期。", + "OptionAllowLinkSharingHelp": "只有網頁包含的媒體訊息會被共享,媒體檔案本身不會被公開共享,共享的內容會在 {0} 天后到期。", "OptionAllowRemoteSharedDevices": "允許遠端控制共享裝置", "OptionAllowSyncTranscoding": "允許需要轉檔的媒體下載和同步", "OptionAllowVideoPlaybackRemuxing": "允許播放需轉換但無需重新編碼的影片", @@ -1245,7 +1245,7 @@ "Programs": "節目", "Quality": "品質", "PackageInstallFailed": "{0} (版本 {1}) 安裝失敗。", - "Raised": "提高", + "Raised": "浮凹", "Rate": "評等", "Recordings": "錄影", "ServerRestartNeededAfterPluginInstall": "安裝附加元件後,Jellyfin 伺服器需要重啟使其生效。", @@ -1255,7 +1255,7 @@ "TheseSettingsAffectSubtitlesOnThisDevice": "這些設定僅影響該裝置的字幕顯示", "TitleHardwareAcceleration": "硬體加速", "TitleHostingSettings": "主機設定", - "Uniform": "輪廓", + "Uniform": "邊框", "Unmute": "取消靜音", "Unplayed": "尚未播放", "TvLibraryHelp": "查看 {0} 電視命名指南 {1} 。", @@ -1266,7 +1266,7 @@ "LabelInNetworkSignInWithEasyPasswordHelp": "你可以在你的家庭網路中使用你的簡易 PIN 碼登錄 Jellyfin 應用程式,僅在你使用外部網路時才需要輸入密碼,如果 PIN 碼留空,那麼在你的區域網路中便不需輸入密碼。", "LabelReleaseDate": "釋出日期:", "LabelRemoteClientBitrateLimit": "網際網路串流傳輸位元率限制(Mbps):", - "LanNetworksHelp": "在強制頻寬限制時,認作本地網路上的 IP 位址或 IP/子網域遮罩項目的逗號分隔清單。若設置此項,所有其它 IP 位址將被視作在外部網路上,并且將受到外部頻寬限制。如果保留爲空,則只將伺服器的子網域遮罩作本地網路。", + "LanNetworksHelp": "在強制頻寬限制時,認作本地網路上的 IP 位址或 IP/子網域遮罩項目的逗號分隔清單。若設置此項,所有其它 IP 位址將被視作在外部網路上,並且將受到外部頻寬限制。如果保留為空,則只將伺服器的子網域遮罩作本地網路。", "OptionIgnoreTranscodeByteRangeRequests": "忽略轉檔位元組範圍請求", "OptionIgnoreTranscodeByteRangeRequestsHelp": "這些請求會被接受,但會忽略的位元組範圍標頭。", "OptionLoginAttemptsBeforeLockoutHelp": "若值為 0,則表示將允許普通使用者嘗試三次、管理員嘗試五次的預設值,設定為 -1 來停用此功能。", @@ -1280,9 +1280,9 @@ "LabelEnableSingleImageInDidlLimitHelp": "若在 Didl 中嵌入多個圖片,某些裝置可能無法正常顯示。", "SortByValue": "排序方式:{0}", "LabelLineup": "排隊:", - "LabelLocalHttpServerPortNumber": "本地 HTTP 端口:", - "LabelLocalHttpServerPortNumberHelp": "HTTP 伺服器的 TCP 端口。", - "SubtitleAppearanceSettingsAlsoPassedToCastDevices": "這些設定也會被套用在任何透過此裝置發起的 Chromecast 播放。", + "LabelLocalHttpServerPortNumber": "本地 HTTP 埠:", + "LabelLocalHttpServerPortNumberHelp": "HTTP 伺服器的 TCP 埠。", + "SubtitleAppearanceSettingsAlsoPassedToCastDevices": "此設定也會影響透過此裝置投放的 Chromecast。", "LabelLoginDisclaimer": "登入字句:", "LabelLogs": "日誌:", "SubtitleDownloadersHelp": "按優先順序啟用並排列您的首選字幕下載程式。", @@ -1290,7 +1290,7 @@ "SystemDlnaProfilesHelp": "系統設定檔案是唯讀的,更改系統設定檔案將被儲存到自訂的新設定檔案。", "LabelNumber": "編號:", "LabelNumberOfGuideDays": "下載電視指南日數:", - "OnlyForcedSubtitlesHelp": "僅被標記為「強制」的字幕會被載入。", + "OnlyForcedSubtitlesHelp": "僅標記為「強制」的字幕會被載入。", "PackageInstallCompleted": "{0} (版本 {1}) 安裝完成。", "OptionDisplayFolderViewHelp": "在其他媒體庫旁邊顯示資料夾,對想要一個普通的資料夾檢視很有用。", "LabelReasonForTranscoding": "轉檔原因:", @@ -1318,7 +1318,7 @@ "LabelVaapiDevice": "VA API 裝置:", "DashboardArchitecture": "架構:{0}", "MediaInfoSampleRate": "採樣率", - "MessageContactAdminToResetPassword": "請聯繫您的管理員來重置密碼。", + "MessageContactAdminToResetPassword": "請聯絡您的管理員來重設密碼。", "MessageUnsetContentHelp": "內容將顯示為純資料夾,建議使用中繼資料管理器設置子資料夾的內容類型。", "OptionAllowAudioPlaybackTranscoding": "允許播放需要轉檔的音訊", "OptionCustomUsers": "自訂", @@ -1336,8 +1336,8 @@ "LabelModelDescription": "型號描述", "LabelModelName": "型號名稱", "LabelModelUrl": "型號網址", - "LabelMusicStreamingTranscodingBitrate": "音樂轉檔比特率:", - "LabelMusicStreamingTranscodingBitrateHelp": "指定音樂串流時的最大比特率。", + "LabelMusicStreamingTranscodingBitrate": "音樂轉檔位元率:", + "LabelMusicStreamingTranscodingBitrateHelp": "指定音樂串流時的最大位元率。", "LabelOptionalNetworkPathHelp": "如果這個資料夾在網路上分享,提供網路分享路徑可以供其他應用程式直接存取媒體檔案,例如 {0} 或者 {1}。", "LabelOriginalAspectRatio": "原始長寬比:", "LabelOverview": "內容概述:", @@ -1361,8 +1361,8 @@ "LabelPreferredSubtitleLanguage": "字幕語言偏好:", "LabelProtocol": "協議:", "LabelProtocolInfo": "協議資訊:", - "LabelPublicHttpPort": "公開 HTTP 端口:", - "LabelPublicHttpsPort": "公開 HTTPS 端口:", + "LabelPublicHttpPort": "公開 HTTP 埠:", + "LabelPublicHttpsPort": "公開 HTTPS 埠:", "LabelProtocolInfoHelp": "當響應來自裝置的 GetProtocolInfo(獲取協議訊息)請求時,該值將被使用。", "LabelPublicHttpPortHelp": "公開連接埠應映射到本地 HTTP 連接埠。", "LabelPublicHttpsPortHelp": "公開連接埠應映射到本地 HTTPS 連接埠。", @@ -1404,20 +1404,20 @@ "HeaderFavoritePeople": "最愛人物", "XmlDocumentAttributeListHelp": "這些屬性會在每一個 XML 回應的根元素上套用。", "SkipEpisodesAlreadyInMyLibraryHelp": "劇集將使用季和劇集編號進行比較。", - "SelectAdminUsername": "請為管理員賬戶選擇一個用戶名。", + "SelectAdminUsername": "請為管理員帳戶選擇一個使用者名稱。", "OptionSaveMetadataAsHiddenHelp": "更改此項將套用至未來保存的中繼資料。現有中繼資料檔案將在下一次伺服器儲存它們時被更新。", "OptionAllowRemoteSharedDevicesHelp": "DLNA裝置將被視為共享中,直至有使用者控制。", - "OptionForceRemoteSourceTranscoding": "强制遠端轉碼(像電視直播一樣)", + "OptionForceRemoteSourceTranscoding": "強制遠端轉檔(像電視直播一樣)", "MessageConfirmAppExit": "您要退出嗎?", - "LabelVideoResolution": "視頻解析度:", + "LabelVideoResolution": "影片解析度:", "LabelStreamType": "串流類型:", "LabelPlayerDimensions": "播放器尺寸:", "LabelDroppedFrames": "丟棄的幀:", "LabelCorruptedFrames": "損壞的幀:", "ButtonSplit": "分割", - "AskAdminToCreateLibrary": "如要建立資料庫,請聯繫管理員。", + "AskAdminToCreateLibrary": "如要建立資料庫,請聯絡管理員。", "NoCreatedLibraries": "看來您還未創任何媒體庫。{0}立刻創一個新的嗎?{1}", - "ClientSettings": "客戶端設定", + "ClientSettings": "用戶端設定", "AllowFfmpegThrottlingHelp": "當轉檔或重組進度遠超於目前播放進度時,將暫停轉檔節省消耗的資源。在不常跳播的時候最有效。如果遇到播放問題,請關閉此功能。", "AllowFfmpegThrottling": "限制轉檔", "PreferEmbeddedEpisodeInfosOverFileNamesHelp": "這將會使用內建中繼資料。", @@ -1448,7 +1448,7 @@ "LabelLibraryPageSize": "媒體庫分頁大小:", "LabelDeinterlaceMethod": "反交錯方法:", "Episode": "劇集", - "DeinterlaceMethodHelp": "選擇對隔行掃描內容進行轉碼時所用的反交錯方法。", + "DeinterlaceMethodHelp": "選擇對隔行掃描內容進行轉檔時所用的反交錯方法。", "BoxSet": "套裝", "UnsupportedPlayback": "Jellyfin 無法解密受 DRM 保護的內容,但仍然會嘗試播放所有內容。某些檔案由於被加密或包含如互動標題等不受支援的內容,在播放時可能會沒有畫面。", "Filter": "篩選器", @@ -1462,7 +1462,7 @@ "LabelRequireHttps": "強制 HTTPS", "LabelStable": "穩定版", "LabelChromecastVersion": "Chromecast 版本", - "LabelEnableHttpsHelp": "監聽指定的 HTTPS 端口。須設定有效的證書使其生效。", + "LabelEnableHttpsHelp": "監聽指定的 HTTPS 埠。須設定有效的證書使其生效。", "LabelEnableHttps": "啟用HTTPS", "HeaderServerAddressSettings": "伺服器位置設定", "HeaderRemoteAccessSettings": "遠端存取設定", From d7b50b91604e1bd5160be5b6a497fdc0dfefc7aa Mon Sep 17 00:00:00 2001 From: Steven S O'Connor Date: Wed, 12 Aug 2020 10:36:55 -0700 Subject: [PATCH 177/301] Remove extraneous pageContainer styles for videoOSD --- src/assets/css/videoosd.css | 6 ------ 1 file changed, 6 deletions(-) diff --git a/src/assets/css/videoosd.css b/src/assets/css/videoosd.css index 50cb41021b..59a485468d 100644 --- a/src/assets/css/videoosd.css +++ b/src/assets/css/videoosd.css @@ -7,7 +7,6 @@ } .osdPoster img, -.pageContainer, .videoOsdBottom { bottom: 0; left: 0; @@ -248,11 +247,6 @@ animation: spin 4s linear infinite; } -.pageContainer { - top: 0; - position: fixed; -} - @media all and (max-width: 30em) { .btnFastForward, .btnRewind, From ff5833a5f6950456b456845b68870f001b0c72fb Mon Sep 17 00:00:00 2001 From: Thomas Schwery Date: Wed, 12 Aug 2020 17:56:27 +0000 Subject: [PATCH 178/301] Translated using Weblate (French) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/fr/ --- src/strings/fr.json | 38 +++++++++++++++++++------------------- 1 file changed, 19 insertions(+), 19 deletions(-) diff --git a/src/strings/fr.json b/src/strings/fr.json index 17e1061c63..8e13275e39 100644 --- a/src/strings/fr.json +++ b/src/strings/fr.json @@ -22,7 +22,7 @@ "AllowMediaConversionHelp": "Autoriser ou refuser l'accès à la fonctionnalité de conversion des médias.", "AllowOnTheFlySubtitleExtraction": "Autoriser l'extraction des sous-titres à la volée", "AllowOnTheFlySubtitleExtractionHelp": "Les sous-titres intégrés peuvent être extraits des vidéos et envoyés vers les clients au format texte afin d'éviter le transcodage vidéo. Sur certains systèmes, cela peut prendre du temps et arrêter la lecture de la vidéo pendant le processus d'extraction. Désactivez cette option pour conserver les sous-titres pendant le transcodage si l'appareil client ne les prend pas en charge nativement.", - "AllowRemoteAccess": "Autoriser les connexions distantes à ce serveur Jellyfin.", + "AllowRemoteAccess": "Autoriser les connexions distantes à ce serveur.", "AllowRemoteAccessHelp": "Si l'option est désactivée, toutes les connexions distantes seront bloquées.", "AllowedRemoteAddressesHelp": "Liste d'adresses IP ou d'IP/masque de sous-réseau séparées par des virgules qui seront autorisées à se connecter à distance. Si la liste est vide, toutes les adresses distantes seront autorisées.", "AlwaysPlaySubtitles": "Toujours afficher les sous-titres", @@ -131,7 +131,7 @@ "ColorTransfer": "Transfert de couleur", "CommunityRating": "Note de la communauté", "Composer": "Compositeur(trice)", - "ConfigureDateAdded": "Configurez comment la date d'ajout est déterminée dans le tableau de bord du serveur Jellyfin, dans les paramètres de médiathèque", + "ConfigureDateAdded": "Configurez comment la date d'ajout est déterminée dans le tableau de bord sous paramètres de médiathèque", "ConfirmDeleteImage": "Supprimer l'image ?", "ConfirmDeleteItem": "Supprimer cet élément l'effacera à la fois du système de fichiers et de votre médiathèque. Voulez-vous vraiment continuer ?", "ConfirmDeleteItems": "Supprimer ces éléments les effacera à la fois du système de fichiers et de votre médiathèque. Voulez-vous vraiment continuer ?", @@ -210,10 +210,10 @@ "EndsAtValue": "Se termine à {0}", "Episodes": "Épisodes", "ErrorAddingListingsToSchedulesDirect": "Une erreur est survenue pendant l'ajout de la programmation avec votre compte Schedules Direct. Schedules Direct autorise uniquement un nombre limité de programmations par compte. Vous devez vous connecter au site Schedules Direct et supprimer d'autres programmations depuis votre compte avant de pouvoir réessayer.", - "ErrorAddingMediaPathToVirtualFolder": "Une erreur est survenue pendant l'ajout du chemin des médias. Veuillez vérifier que le chemin est valide et que le processus du serveur Jellyfin peut y accéder.", + "ErrorAddingMediaPathToVirtualFolder": "Une erreur est survenue pendant l'ajout du chemin des médias. Veuillez vérifier que le chemin est valide et que Jellyfin peut y accéder.", "ErrorAddingTunerDevice": "Une erreur est survenue lors de l'ajout du tuner. Assurez-vous qu'il est accessible et réessayez.", "ErrorAddingXmlTvFile": "Une erreur est survenue lors de l'accès au fichier XMLTV. Assurez-vous que le fichier existe et réessayez.", - "ErrorDeletingItem": "Une erreur s'est produite lors de la suppression de l'élément du serveur Jellyfin. Vérifiez que le serveur Jellyfin a un accès en écriture au dossier multimédia et réessayez.", + "ErrorDeletingItem": "Une erreur s'est produite lors de la suppression de l'élément du serveur. Vérifiez que Jellyfin a un accès en écriture au dossier multimédia et réessayez.", "ErrorGettingTvLineups": "Une erreur est survenue pendant le téléchargement des programmes TV. Assurez-vous que vos informations sont correctes et réessayez.", "ErrorStartHourGreaterThanEnd": "La date de fin doit être postérieure à la date de début.", "ErrorPleaseSelectLineup": "Veuillez sélectionner une programmation et réessayer. Si aucune programmation n'est disponible, veuillez vérifier que vos identifiant, mot de passe et code postal sont corrects.", @@ -492,7 +492,7 @@ "LabelAudioLanguagePreference": "Langue audio préférée :", "LabelAutomaticallyRefreshInternetMetadataEvery": "Actualiser automatiquement les métadonnées depuis internet :", "LabelBindToLocalNetworkAddress": "Lier à l'adresse de réseau local :", - "LabelBindToLocalNetworkAddressHelp": "Remplace l'adresse IP locale du serveur HTTP. Sans paramètre, le serveur va se lier à toutes les adresses disponibles. La modification de cette valeur nécessite le redémarrage du serveur Jellyfin.", + "LabelBindToLocalNetworkAddressHelp": "Remplace l'adresse IP locale du serveur HTTP. Sans paramètre, le serveur va se lier à toutes les adresses disponibles. La modification de cette valeur nécessite un redémarrage.", "LabelBirthDate": "Date de naissance :", "LabelBirthYear": "Année de naissance :", "LabelBlastMessageInterval": "Intervalle des messages de présence", @@ -552,7 +552,7 @@ "LabelEnableBlastAliveMessages": "Diffuser des message de présence", "LabelEnableBlastAliveMessagesHelp": "Activer cette option si le serveur n'est pas détecté de manière fiable par les autres appareils UPnP sur votre réseau.", "LabelEnableDlnaClientDiscoveryInterval": "Intervalle de découverte des clients", - "LabelEnableDlnaClientDiscoveryIntervalHelp": "Détermine la durée en secondes entre les recherches SSDP exécutées par Jellyfin.", + "LabelEnableDlnaClientDiscoveryIntervalHelp": "Détermine la durée en secondes entre les recherches SSDP.", "LabelEnableDlnaDebugLogging": "Activer le débogage DLNA dans le journal d'événements", "LabelEnableDlnaDebugLoggingHelp": "Génère de gros fichiers de journal d'événements et ne devrait être utilisé que pour des diagnostics d'erreur.", "LabelEnableDlnaPlayTo": "Activer la lecture en DLNA", @@ -671,7 +671,7 @@ "LabelNumberOfGuideDays": "Nombre de jours de données du guide à télécharger :", "LabelNumberOfGuideDaysHelp": "Télécharger plus de journées du guide permet de programmer des enregistrements plus longtemps à l'avance et de visualiser plus de contenus, mais prendra également plus de temps. Automatique permettra une sélection automatique basée sur le nombre de chaînes.", "LabelOptionalNetworkPath": "Dossier réseau partagé :", - "LabelOptionalNetworkPathHelp": "Si le dossier est partagé sur votre réseau, donner le chemin d'accès au dossier réseau peut permettre aux applications Jellyfin sur d'autres appareils d'avoir accès à ses fichiers directement. Par exemple, {0} ou {1}.", + "LabelOptionalNetworkPathHelp": "Si le dossier est partagé sur votre réseau, donner le chemin d'accès au dossier réseau peut permettre aux clients sur d'autres appareils d'avoir accès à ses fichiers directement. Par exemple, {0} ou {1}.", "LabelOriginalAspectRatio": "Ratio d'aspect original :", "LabelOriginalTitle": "Titre original :", "LabelOverview": "Synopsis :", @@ -847,13 +847,13 @@ "MessageConfirmProfileDeletion": "Voulez-vous vraiment supprimer ce profil ?", "MessageConfirmRecordingCancellation": "Annuler l'enregistrement ?", "MessageConfirmRemoveMediaLocation": "Voulez-vous vraiment supprimer cet emplacement ?", - "MessageConfirmRestart": "Voulez-vous vraiment redémarrer le serveur Jellyfin ?", - "MessageConfirmRevokeApiKey": "Voulez-vous vraiment révoquer cette clé API ? La connexion de l'application au serveur Jellyfin sera brutalement interrompue.", + "MessageConfirmRestart": "Voulez-vous vraiment redémarrer Jellyfin ?", + "MessageConfirmRevokeApiKey": "Voulez-vous vraiment révoquer cette clé API ? La connexion de l'application à ce serveur sera brutalement interrompue.", "MessageConfirmShutdown": "Voulez-vous vraiment éteindre le serveur ?", "MessageContactAdminToResetPassword": "Veuillez contacter votre administrateur système pour réinitialiser votre mot de passe.", "MessageCreateAccountAt": "Créer un compte sur {0}", "MessageDeleteTaskTrigger": "Voulez-vous vraiment supprimer ce déclencheur de tâche ?", - "MessageDirectoryPickerBSDInstruction": "Sur BSD, vous devrez peut-être configurer le stockage de votre jail FreeNAS pour autoriser Jellyfin à y accéder.", + "MessageDirectoryPickerBSDInstruction": "Sur BSD, vous devrez peut-être configurer le stockage de votre jail FreeNAS pour autoriser Jellyfin à accéder à vos médias.", "MessageDirectoryPickerLinuxInstruction": "Pour Linux sur Arch Linux, CentOS, Debian, Fedora, openSUSE ou Ubuntu, vous devez au moins autoriser l'accès en lecture à vos répertoires de stockage pour l'utilisateur de service .", "MessageDownloadQueued": "Téléchargement mis en file d'attente.", "MessageEnablingOptionLongerScans": "Activer cette option peut accroître la durée d'actualisation de la médiathèque.", @@ -875,7 +875,7 @@ "MessagePleaseEnsureInternetMetadata": "Veuillez vous assurer que le téléchargement des métadonnées depuis Internet est activé.", "MessagePleaseWait": "Veuillez patienter. Ceci peut prendre quelques minutes.", "MessagePluginConfigurationRequiresLocalAccess": "Pour configurer cette extension, veuillez vous connecter directement à votre serveur local.", - "MessagePluginInstallDisclaimer": "Les extensions développées par les membres de la communauté Jellyfin sont une excellente manière d'améliorer votre expérience Jellyfin avec de nouvelles fonctionnalités. Avant toute installation, veuillez prendre connaissance de l'impact qu'elles peuvent avoir sur le serveur Jellyfin, comme l'augmentation de la durée d'actualisation de la médiathèque, de nouvelles tâches de fond, ou un système moins stable.", + "MessagePluginInstallDisclaimer": "Les extensions développées par les membres de la communauté sont une excellente manière d'améliorer votre expérience avec de nouvelles fonctionnalités. Avant toute installation, veuillez prendre connaissance de l'impact qu'elles peuvent avoir sur le serveur, comme l'augmentation de la durée d'actualisation de la médiathèque, de nouvelles tâches de fond, ou un système moins stable.", "MessageReenableUser": "Voir ci-dessous pour le réactiver", "MessageSettingsSaved": "Paramètres enregistrés.", "MessageTheFollowingLocationWillBeRemovedFromLibrary": "Ces emplacements de média vont être supprimés de votre médiathèque :", @@ -1035,7 +1035,7 @@ "OptionRuntime": "Durée", "OptionSaturday": "Samedi", "OptionSaveMetadataAsHidden": "Enregistrer les métadonnées et les images en tant que fichier cachés", - "OptionSaveMetadataAsHiddenHelp": "La modification s'appliquera aux nouvelles métadonnées enregistrées à l'avenir. Les fichiers de métadonnées existants seront mis à jour la prochaine fois qu'ils seront enregistrés par le serveur Jellyfin.", + "OptionSaveMetadataAsHiddenHelp": "La modification s'appliquera aux nouvelles métadonnées enregistrées à l'avenir. Les fichiers de métadonnées existants seront mis à jour la prochaine fois qu'ils seront enregistrés par le serveur.", "OptionSpecialEpisode": "Spéciaux", "OptionSubstring": "Sous-chaîne", "OptionSunday": "Dimanche", @@ -1078,9 +1078,9 @@ "PleaseAddAtLeastOneFolder": "Veuillez ajouter au moins un dossier à cette médiathèque en cliquant sur le bouton Ajouter.", "PleaseConfirmPluginInstallation": "Merci de cliquer sur OK pour confirmer que vous avez lu ce qui précède et que vous souhaitez poursuivre l'installation de l'extension.", "PleaseEnterNameOrId": "Veuillez saisir un nom ou un identifiant externe.", - "PleaseRestartServerName": "Veuillez redémarrer le serveur Jellyfin - {0}.", + "PleaseRestartServerName": "Veuillez redémarrer le serveur Jellyfin sur {0}.", "PleaseSelectTwoItems": "Veuillez sélectionner au moins deux éléments.", - "MessagePluginInstalled": "Cette extension a été installée avec succès. Le serveur Jellyfin doit être redémarré afin que les modifications soient prises en compte.", + "MessagePluginInstalled": "Cette extension a été installée avec succès. Le serveur doit être redémarré afin que les modifications soient prises en compte.", "PreferEmbeddedTitlesOverFileNames": "Préférer les titres intégrés aux médias aux noms des fichiers", "PreferEmbeddedTitlesOverFileNamesHelp": "Cela détermine le titre affiché par défaut quand il n'y a pas de métadonnées en ligne ou locales disponibles.", "Premieres": "Inédits", @@ -1142,10 +1142,10 @@ "SeriesRecordingScheduled": "Enregistrement de la série planifié.", "SeriesSettings": "Paramètres de la série", "SeriesYearToPresent": "{0} - Présent", - "ServerNameIsRestarting": "Serveur Jellyfin - {0} redémarre.", - "ServerNameIsShuttingDown": "Serveur Jellyfin - {0} s'arrête.", - "ServerRestartNeededAfterPluginInstall": "Le serveur Jellyfin devra être redémarré après l'installation d'une extension.", - "ServerUpdateNeeded": "Le serveur Jellyfin doit être mis à jour. Pour télécharger la dernière version, veuillez visiter {0}", + "ServerNameIsRestarting": "Le serveur sur {0} redémarre.", + "ServerNameIsShuttingDown": "Le serveur sur {0} s'arrête.", + "ServerRestartNeededAfterPluginInstall": "Jellyfin devra être redémarré après l'installation d'une extension.", + "ServerUpdateNeeded": "Ce serveur doit être mis à jour. Pour télécharger la dernière version, veuillez visiter {0}", "Settings": "Paramètres", "SettingsSaved": "Paramètres enregistrés.", "SettingsWarning": "La modification de ces valeurs peut provoquer des défaillances de stabilité ou de connectivité. Si vous rencontrez des problèmes, nous vous recommandons de les remettre aux valeurs par défaut.", @@ -1441,7 +1441,7 @@ "LastSeen": "Vu pour la dernière fois {0}", "PersonRole": "en tant que {0}", "ListPaging": "{0}-{1} de {2}", - "WriteAccessRequired": "Le serveur Jellyfin a besoin d'un accès en écriture à ce dossier. Merci de vérifier l’accès en écriture et réessayez.", + "WriteAccessRequired": "Jellyfin a besoin d'un accès en écriture à ce dossier. Merci de vérifier l’accès en écriture et réessayez.", "PathNotFound": "Le chemin d'accès n'a pas pu être trouvé. Merci de le vérifier et de réessayer.", "YadifBob": "YADIF Bob", "Yadif": "YADIF", From 41f627a07e6084310e2f494ca9a0ff4526088f75 Mon Sep 17 00:00:00 2001 From: matjaz321 Date: Wed, 12 Aug 2020 21:06:10 +0200 Subject: [PATCH 179/301] Added firefox browser condition --- src/elements/emby-checkbox/emby-checkbox.js | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/src/elements/emby-checkbox/emby-checkbox.js b/src/elements/emby-checkbox/emby-checkbox.js index 7b906286ef..74a1696298 100644 --- a/src/elements/emby-checkbox/emby-checkbox.js +++ b/src/elements/emby-checkbox/emby-checkbox.js @@ -10,9 +10,11 @@ import 'webcomponents'; function onKeyDown(e) { // Don't submit form on enter // Real (non-emulator) Tizen does nothing on Space - if (e.keyCode === 13 || e.keyCode === 32) { + if ((e.keyCode === 13 || e.keyCode === 32) && !browser.firefox) { e.preventDefault(); + this.checked = !this.checked; + this.dispatchEvent(new CustomEvent('change', { bubbles: true })); From fdfa4f29b2a603dfa84b03c41efd782ea41651f6 Mon Sep 17 00:00:00 2001 From: matjaz321 Date: Wed, 12 Aug 2020 21:08:10 +0200 Subject: [PATCH 180/301] removed one switch case as was removed --- src/controllers/livetv/livetvsuggested.js | 3 --- 1 file changed, 3 deletions(-) diff --git a/src/controllers/livetv/livetvsuggested.js b/src/controllers/livetv/livetvsuggested.js index 34b81deefa..4a20d02fcf 100644 --- a/src/controllers/livetv/livetvsuggested.js +++ b/src/controllers/livetv/livetvsuggested.js @@ -261,9 +261,6 @@ export default function (view, params) { case 5: depends = 'controllers/livetv/livetvseriestimers'; break; - - case 6: - depends = 'scripts/searchtab'; } import(depends).then(({default: controllerFactory}) => { From 3359fc388b1665b110c01db45e7e47802e3a3334 Mon Sep 17 00:00:00 2001 From: MrTimscampi Date: Wed, 12 Aug 2020 21:17:07 +0200 Subject: [PATCH 181/301] Use JSON when POSTing data --- src/components/channelMapper/channelMapper.js | 4 ++-- src/components/directorybrowser/directorybrowser.js | 4 ++-- src/controllers/dashboard/encodingsettings.js | 4 ++-- src/controllers/session/forgotPassword/index.js | 4 ++-- src/controllers/session/resetPassword/index.js | 4 ++-- src/controllers/wizard/remote/index.js | 2 +- src/controllers/wizard/settings/index.js | 2 +- src/controllers/wizard/start/index.js | 2 +- src/controllers/wizard/user/index.js | 4 ++-- 9 files changed, 15 insertions(+), 15 deletions(-) diff --git a/src/components/channelMapper/channelMapper.js b/src/components/channelMapper/channelMapper.js index 89d085c185..a5e5cc3537 100644 --- a/src/components/channelMapper/channelMapper.js +++ b/src/components/channelMapper/channelMapper.js @@ -19,11 +19,11 @@ export default class channelMapper { connectionManager.getApiClient(options.serverId).ajax({ type: 'POST', url: ApiClient.getUrl('LiveTv/ChannelMappings'), - data: { + data: JSON.stringify({ providerId: providerId, tunerChannelId: channelId, providerChannelId: providerChannelId - }, + }), dataType: 'json' }).then(mapping => { const listItem = dom.parentWithClass(button, 'listItem'); diff --git a/src/components/directorybrowser/directorybrowser.js b/src/components/directorybrowser/directorybrowser.js index 41744bdcbb..5c44db3b15 100644 --- a/src/components/directorybrowser/directorybrowser.js +++ b/src/components/directorybrowser/directorybrowser.js @@ -166,10 +166,10 @@ import 'emby-button'; return apiClient.ajax({ type: 'POST', url: apiClient.getUrl('Environment/ValidatePath'), - data: { + data: JSON.stringify({ ValidateWriteable: validateWriteable, Path: path - } + }) }).catch(response => { if (response) { if (response.status === 404) { diff --git a/src/controllers/dashboard/encodingsettings.js b/src/controllers/dashboard/encodingsettings.js index 3a0ad24430..320a679b37 100644 --- a/src/controllers/dashboard/encodingsettings.js +++ b/src/controllers/dashboard/encodingsettings.js @@ -45,10 +45,10 @@ import libraryMenu from 'libraryMenu'; return ApiClient.ajax({ url: ApiClient.getUrl('System/MediaEncoder/Path'), type: 'POST', - data: { + data: JSON.stringify({ Path: form.querySelector('.txtEncoderPath').value, PathType: 'Custom' - } + }) }).then(Dashboard.processServerConfigurationUpdateResult, onSaveEncodingPathFailure); }); } diff --git a/src/controllers/session/forgotPassword/index.js b/src/controllers/session/forgotPassword/index.js index 368642db35..45e05409da 100644 --- a/src/controllers/session/forgotPassword/index.js +++ b/src/controllers/session/forgotPassword/index.js @@ -41,9 +41,9 @@ import globalize from 'globalize'; type: 'POST', url: ApiClient.getUrl('Users/ForgotPassword'), dataType: 'json', - data: { + data: JSON.stringify({ EnteredUsername: view.querySelector('#txtName').value - } + }) }).then(processForgotPasswordResult); e.preventDefault(); return false; diff --git a/src/controllers/session/resetPassword/index.js b/src/controllers/session/resetPassword/index.js index a88e131eea..3cb8d4a9e2 100644 --- a/src/controllers/session/resetPassword/index.js +++ b/src/controllers/session/resetPassword/index.js @@ -29,9 +29,9 @@ import globalize from 'globalize'; type: 'POST', url: ApiClient.getUrl('Users/ForgotPassword/Pin'), dataType: 'json', - data: { + data: JSON.stringify({ Pin: view.querySelector('#txtPin').value - } + }) }).then(processForgotPasswordResult); e.preventDefault(); return false; diff --git a/src/controllers/wizard/remote/index.js b/src/controllers/wizard/remote/index.js index 3c482607de..74c795658d 100644 --- a/src/controllers/wizard/remote/index.js +++ b/src/controllers/wizard/remote/index.js @@ -11,7 +11,7 @@ function save(page) { config.EnableAutomaticPortMapping = page.querySelector('#chkEnableUpnp').checked; apiClient.ajax({ type: 'POST', - data: config, + data: JSON.stringify(config), url: apiClient.getUrl('Startup/RemoteAccess') }).then(function () { loading.hide(); diff --git a/src/controllers/wizard/settings/index.js b/src/controllers/wizard/settings/index.js index a1c3c11267..2eaef4fab6 100644 --- a/src/controllers/wizard/settings/index.js +++ b/src/controllers/wizard/settings/index.js @@ -11,7 +11,7 @@ function save(page) { config.MetadataCountryCode = page.querySelector('#selectCountry').value; apiClient.ajax({ type: 'POST', - data: config, + data: JSON.stringify(config), url: apiClient.getUrl('Startup/Configuration') }).then(function () { loading.hide(); diff --git a/src/controllers/wizard/start/index.js b/src/controllers/wizard/start/index.js index cec93446db..8c147fc75e 100644 --- a/src/controllers/wizard/start/index.js +++ b/src/controllers/wizard/start/index.js @@ -17,7 +17,7 @@ function save(page) { config.UICulture = $('#selectLocalizationLanguage', page).val(); apiClient.ajax({ type: 'POST', - data: config, + data: JSON.stringify(config), url: apiClient.getUrl('Startup/Configuration') }).then(function () { Dashboard.navigate('wizarduser.html'); diff --git a/src/controllers/wizard/user/index.js b/src/controllers/wizard/user/index.js index 855086a3a4..fc9a27855f 100644 --- a/src/controllers/wizard/user/index.js +++ b/src/controllers/wizard/user/index.js @@ -23,10 +23,10 @@ function submit(form) { const apiClient = getApiClient(); apiClient.ajax({ type: 'POST', - data: { + data: JSON.stringify({ Name: form.querySelector('#txtUsername').value, Password: form.querySelector('#txtManualPassword').value - }, + }), url: apiClient.getUrl('Startup/User') }).then(onUpdateUserComplete); } From 687aa41e2e78d369cf029e9be760b481fe113102 Mon Sep 17 00:00:00 2001 From: WontTell Date: Thu, 13 Aug 2020 06:35:01 +0000 Subject: [PATCH 182/301] Translated using Weblate (Spanish (Latin America)) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/es_419/ --- src/strings/es_419.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/strings/es_419.json b/src/strings/es_419.json index 4be6bdc6c5..7f1702c910 100644 --- a/src/strings/es_419.json +++ b/src/strings/es_419.json @@ -1484,7 +1484,7 @@ "AlwaysPlaySubtitles": "Siempre reproducir", "AllowedRemoteAddressesHelp": "Lista separada por comas de direcciones IP/máscaras de red para las redes a las que se les permitirá conectarse remotamente. Si se deja en blanco, se les permitirá a todas las direcciones remotas.", "AllowRemoteAccessHelp": "Si no se marca, se bloquearán todas las conexiones remotas.", - "AllowRemoteAccess": "Permitir conexiones remotas a este servidor Jellyfin.", + "AllowRemoteAccess": "Permitir conexiones remotas a este servidor.", "AllowFfmpegThrottlingHelp": "Cuando una transcodificación o remuxeado se adelanta lo suficiente de la posición de reproducción actual, se pausa el proceso para que consuma menos recursos. Esto es más útil cuando se mira sin buscar con frecuencia. Apaga esto si experimentas problemas de reproducción.", "AllowFfmpegThrottling": "Regular transcodificaciones", "AllowOnTheFlySubtitleExtractionHelp": "Los subtítulos incrustados pueden extraerse de los videos y entregarse a los clientes en texto plano para ayudar a evitar la transcodificación de video. En algunos sistemas, esto puede tardar mucho tiempo y provocar que la reproducción de video se detenga durante el proceso de extracción. Deshabilite esta opción para que los subtítulos incrustados se graben con transcodificación de video cuando no estén soportados de forma nativa por el dispositivo cliente.", From f3cdedacdf4d71318b597a487d18789d7de9c018 Mon Sep 17 00:00:00 2001 From: Cameron Date: Thu, 13 Aug 2020 09:19:32 +0100 Subject: [PATCH 183/301] Remove unneccessary .default --- .../recordingcreator/recordingcreator.js | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-) diff --git a/src/components/recordingcreator/recordingcreator.js b/src/components/recordingcreator/recordingcreator.js index 412ec6e274..43a91b4992 100644 --- a/src/components/recordingcreator/recordingcreator.js +++ b/src/components/recordingcreator/recordingcreator.js @@ -118,7 +118,7 @@ function reload(context, programId, serverId, refreshRecordingStateOnly) { function executeCloseAction(action, programId, serverId) { if (action === 'play') { - import('playbackManager').then(({default: playbackManager}) => { + import('playbackManager').then(({ default: playbackManager }) => { const apiClient = connectionManager.getApiClient(serverId); apiClient.getLiveTvProgram(programId, apiClient.getCurrentUserId()).then(function (item) { @@ -138,7 +138,7 @@ function showEditor(itemId, serverId) { loading.show(); - import('text!./recordingcreator.template.html').then(({default: template}) => { + import('text!./recordingcreator.template.html').then(({ default: template }) => { const dialogOptions = { removeOnClose: true, scrollY: false @@ -184,13 +184,13 @@ function showEditor(itemId, serverId) { init(dlg); - currentRecordingFields = new recordingFields.default({ - parent: dlg.querySelector('.recordingFields'), - programId: itemId, - serverId: serverId - }); + currentRecordingFields = new recordingFields({ + parent: dlg.querySelector('.recordingFields'), + programId: itemId, + serverId: serverId + }); - events.on(currentRecordingFields, 'recordingchanged', onRecordingChanged); + events.on(currentRecordingFields, 'recordingchanged', onRecordingChanged); currentRecordingFields = new recordingFields({ parent: dlg.querySelector('.recordingFields'), From 71a01f547db3a96c84b878880997d2c66ec589c1 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marcin=20Woli=C5=84ski?= Date: Thu, 13 Aug 2020 09:15:39 +0000 Subject: [PATCH 184/301] Translated using Weblate (Polish) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/pl/ --- src/strings/pl.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/strings/pl.json b/src/strings/pl.json index d97c4d633c..57cb8bc731 100644 --- a/src/strings/pl.json +++ b/src/strings/pl.json @@ -23,7 +23,7 @@ "AllowMediaConversionHelp": "Umożliwia dawanie lub odbieranie dostępu do funkcji konwersji mediów.", "AllowOnTheFlySubtitleExtraction": "Zezwalaj na wydobywanie napisów w locie", "AllowOnTheFlySubtitleExtractionHelp": "Napisy wbudowane mogą zostać wydobyte z plików wideo i dostarczone do klienta w postaci zwykłego tekstu, zapobiegając transkodowaniu wideo. Na niektórych systemach może to zabierać dużo czasu i powodować wstrzymywanie odtwarzania wideo podczas procesu ekstrakcji. Dezaktywuj tę opcję, aby wbudowane napisy były wypalane w transkodowanym wideo, gdy nie są obsługiwane przez urządzenie klienta.", - "AllowRemoteAccess": "Zezwalaj na zdalne połączenia z tym serwerem Jellyfin.", + "AllowRemoteAccess": "Zezwalaj na zdalne połączenia z tym serwerem.", "AllowRemoteAccessHelp": "Jeśli nieaktywne, wszelkie zdalne połączenia będą blokowane.", "AllowedRemoteAddressesHelp": "Lista rozdzielona przecinkiem w postaci adresów IP lub adresów IP z maską sieciową dla całych podsieci. W przypadku pozostawienia pustego pola, dopuszczalne będą połączenia ze wszystkich zdalnych adresów.", "AlwaysPlaySubtitles": "Zawsze wyświetlaj napisy", From d76b95aa5420c2cbd5f0218c784de53f6a782517 Mon Sep 17 00:00:00 2001 From: biAji Date: Thu, 13 Aug 2020 08:47:10 +0000 Subject: [PATCH 185/301] Translated using Weblate (Chinese (Simplified)) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/zh_Hans/ --- src/strings/zh-cn.json | 60 +++++++++++++++++++++--------------------- 1 file changed, 30 insertions(+), 30 deletions(-) diff --git a/src/strings/zh-cn.json b/src/strings/zh-cn.json index e8e43426f0..ec3af3ea13 100644 --- a/src/strings/zh-cn.json +++ b/src/strings/zh-cn.json @@ -22,7 +22,7 @@ "AllowMediaConversionHelp": "授予或拒绝访问媒体转换功能。", "AllowOnTheFlySubtitleExtraction": "允许实时提取字幕", "AllowOnTheFlySubtitleExtractionHelp": "为避免视频转码,可以从视频中提取内置的字幕,并以纯文本的形式发送给客户端。在某些系统中这个提取的进程可能会花费较长时间并导致视频播放出现卡顿。如果禁用这个选项,当内置字幕不能被客户端设备原生支持时,字幕将通过视频转码被烧录进视频中。", - "AllowRemoteAccess": "允许与此 Jellyfin 服务器进行远程连接。", + "AllowRemoteAccess": "允许与此服务器进行远程连接。", "AllowRemoteAccessHelp": "如果取消勾选,所有的远程连接将会被阻止。", "AllowedRemoteAddressesHelp": "允许远程连接的 IP 地址或 IP/子网掩码 的列表,以逗号分隔。如果留空,则允许所有远程地址。", "AlwaysPlaySubtitles": "总是显示", @@ -198,7 +198,7 @@ "EndsAtValue": "结束于 {0}", "Episodes": "剧集", "ErrorAddingListingsToSchedulesDirect": "我们将阵容添加到您的Schedules Direct帐户时出错。 Schedules Direct只允许有限的账号排序。 您可能需要在继续前直接登入Schedules Direct 网站并删除其他列表。", - "ErrorAddingMediaPathToVirtualFolder": "添加媒体路径时发生错误。请确认路径是有效的,并且你的 Jellyfin 服务器进程有对该位置的访问权。", + "ErrorAddingMediaPathToVirtualFolder": "添加媒体路径时发生错误。请确认路径是有效的,并且Jellyfin有对该位置的访问权。", "ErrorAddingTunerDevice": "添加协调器设备时发生错误。请确认它是可访问的然后再试一次。", "ErrorAddingXmlTvFile": "访问 XmlTV 文件时发生错误。请确认该文件是否存在然后再试一次。", "ErrorGettingTvLineups": "下载 TV 节目表 时发生错误。请确认你的信息是否正确,然后再试。", @@ -433,7 +433,7 @@ "Hide": "隐藏", "HideWatchedContentFromLatestMedia": "从最新媒体中隐藏已观看的内容", "Home": "首页", - "HttpsRequiresCert": "要启用安全连接, 您需要提供一个受信任的 SSL 证书, 例如 Let's Encrypt 。请提供证书或禁用安全连接。", + "HttpsRequiresCert": "要启用安全连接, 您需要提供一个受信任的 SSL 证书, 如 \"Let's Encrypt\"。请提供证书或禁用安全连接。", "Identify": "识别", "Images": "图片", "ImportFavoriteChannelsHelp": "只有在协调器设备中被标记为我的最爱的频道才会被导入。", @@ -466,11 +466,11 @@ "LabelAppName": "APP名称", "LabelAppNameExample": "例如:Sickbeard, Sonarr", "LabelArtists": "艺术家:", - "LabelArtistsHelp": "将多个艺术家用分号分隔", + "LabelArtistsHelp": "将多个艺术家用分号分隔。", "LabelAudioLanguagePreference": "首选音频语言:", "LabelAutomaticallyRefreshInternetMetadataEvery": "自动从互联网获取元数据并刷新:", "LabelBindToLocalNetworkAddress": "监听的本地网络地址:", - "LabelBindToLocalNetworkAddressHelp": "覆盖 HTTP 服务器绑定的本地 IP 地址。如果留空,服务器将会监听所有可用的地址。改变这个值需要重启 Jellyfin 服务器。", + "LabelBindToLocalNetworkAddressHelp": "覆盖 HTTP 服务器绑定的本地 IP 地址。如果留空,服务器将会监听所有可用的地址。重启后生效。", "LabelBirthDate": "出生日期:", "LabelBirthYear": "出生年份:", "LabelBlastMessageInterval": "活动信号的时间间隔", @@ -528,11 +528,11 @@ "LabelEmbedAlbumArtDidl": "在DIDL中嵌入专辑封面", "LabelEmbedAlbumArtDidlHelp": "有些设备首选这种方式获取专辑封面。启用该选项可能导致其他设备播放失败。", "LabelEnableAutomaticPortMap": "开启自动端口映射", - "LabelEnableAutomaticPortMapHelp": "通过UPnP将路由器端口自动转发到服务器端口。这可能不适用于某些型号的路由器和网络配置。需要服务器重新启动后才会应用更改。", + "LabelEnableAutomaticPortMapHelp": "勾选以通过 UPnP 自动映射公共端口到本地端口。这个选项在某些不支持的路由器和网络配置上可能不起作用。服务端重启之前设置不会生效。", "LabelEnableBlastAliveMessages": "爆发活动信号", "LabelEnableBlastAliveMessagesHelp": "如果该服务器不能被网络中的其他UPnP设备检测到,请启用此选项。", "LabelEnableDlnaClientDiscoveryInterval": "客户端搜寻时间间隔", - "LabelEnableDlnaClientDiscoveryIntervalHelp": "确定由 Jellyfin 执行的 SSDP 搜索之间的持续时间 (以秒为单位)。", + "LabelEnableDlnaClientDiscoveryIntervalHelp": "确定SSDP 搜索之间的持续时间 (以秒为单位)。", "LabelEnableDlnaDebugLogging": "启用 DLNA 调试日志", "LabelEnableDlnaDebugLoggingHelp": "创建一个很大的日志文件,仅应在排除故障时使用。", "LabelEnableDlnaPlayTo": "启用 DLNA 播放", @@ -541,7 +541,7 @@ "LabelEnableDlnaServerHelp": "允许你网络上的 UPnP 设备浏览并播放内容。", "LabelEnableHardwareDecodingFor": "启用硬件解码:", "LabelEnableRealtimeMonitor": "启用实时监控", - "LabelEnableRealtimeMonitorHelp": "文件更改将立即在支持的文件系统上处理。", + "LabelEnableRealtimeMonitorHelp": "在支持的文件系统中,文件更改将即时处理。", "LabelEnableSingleImageInDidlLimit": "仅限单一的嵌入式图像", "LabelEnableSingleImageInDidlLimitHelp": "如果多个图像嵌入在DIDL,某些设备将无法正确渲染。", "LabelEndDate": "结束日期:", @@ -650,7 +650,7 @@ "LabelNumberOfGuideDays": "下载几天的节目指南:", "LabelNumberOfGuideDaysHelp": "下载更多天的节目指南可以帮你进一步查看节目列表并做出提前安排,但下载过程也将耗时更久。它将基于频道数量自动选择。", "LabelOptionalNetworkPath": "共享的网络文件夹:", - "LabelOptionalNetworkPathHelp": "如果这个文件夹在你的网络上是共享的,提供这个网络共享地址能够允许其他设备上的 Jellyfin 应用程序直接访问媒体文件,例如 {0} 或者 {1}。", + "LabelOptionalNetworkPathHelp": "如果这个文件夹在你的网络上是共享的,提供这个网络共享地址能够允许其他设备上的客户端直接访问媒体文件,例如 {0} 或者 {1}。", "LabelOriginalAspectRatio": "原始长宽比:", "LabelOriginalTitle": "原标题:", "LabelOverview": "内容概述:", @@ -823,13 +823,13 @@ "MessageConfirmProfileDeletion": "你确定希望删除此配置文件?", "MessageConfirmRecordingCancellation": "取消录制?", "MessageConfirmRemoveMediaLocation": "你确定要移除此位置?", - "MessageConfirmRestart": "你确定要重启 Jellyfin 服务端?", - "MessageConfirmRevokeApiKey": "你确定你希望撤销这个 API 秘钥吗?这个应用程序与 Jellyfin 服务器的连接将会被立刻中断。", + "MessageConfirmRestart": "你确定要重启 Jellyfin?", + "MessageConfirmRevokeApiKey": "你确定你希望撤销这个 API 秘钥吗?这个应用程序与本服务器的连接将会被立刻中断。", "MessageConfirmShutdown": "你确定要关闭服务端?", "MessageContactAdminToResetPassword": "请联系你的管理员以重置你的密码。", "MessageCreateAccountAt": "在 {0} 创建帐户", "MessageDeleteTaskTrigger": "你确定删除这个任务触发条件?", - "MessageDirectoryPickerBSDInstruction": "对于 BSD 系统,你需要设置包含你的 FreeNAS Jail 虚拟机的存储以允许 Jellyfin 访问它。", + "MessageDirectoryPickerBSDInstruction": "对于 BSD 系统,您需要配置包含您 FreeNAS Jail 虚拟机的存储以允许 Jellyfin 访问您的媒体文件。", "MessageDirectoryPickerLinuxInstruction": "对于Arch Linux、 CentOS、Debian、Fedora、OpenSuse、Ubuntu上的Linux系统,你必须授权系统服务用户访问你存储位置。", "MessageDownloadQueued": "下载已列队。", "MessageEnablingOptionLongerScans": "启用此选项可能会大大延长媒体库扫描时间。", @@ -850,7 +850,7 @@ "MessagePleaseEnsureInternetMetadata": "请确认已启用从网络上下载媒体资料的选项。", "MessagePleaseWait": "请稍等。这将花费大约1分钟的时间。", "MessagePluginConfigurationRequiresLocalAccess": "请直接登录你的本地服务器以设置这个插件。", - "MessagePluginInstallDisclaimer": "安装 Jellyfin 社区成员构建的插件来获取额外的功能是增强你的 Jellyfin 体验的一种很好的方式。但在安装之前请意识到他们可能会对你的 Jellyfin 服务器造成的影响,如更长的媒体库扫描时间、额外的背景数据加工、降低系统稳定性等。", + "MessagePluginInstallDisclaimer": "安装社区成员构建的插件来获取额外的功能是增强您体验的一种很好的方式。但在安装之前请意识到他们可能会对你的服务器造成影响,如更长的媒体库扫描时间、额外的后台处理、以及系统稳定性的降低等。", "MessageReenableUser": "请参阅以下以重新启用", "MessageSettingsSaved": "设置已保存。", "MessageTheFollowingLocationWillBeRemovedFromLibrary": "以下媒体路径将从你的媒体库移除:", @@ -1022,7 +1022,7 @@ "OptionRuntime": "播放时长", "OptionSaturday": "星期六", "OptionSaveMetadataAsHidden": "保存媒体资料和图像为隐藏文件", - "OptionSaveMetadataAsHiddenHelp": "更改此项将应用于以后保存的元数据。现有元数据文件将在下一次 Jellyfin 服务器保存它们时被更新。", + "OptionSaveMetadataAsHiddenHelp": "更改此项将应用于以后保存的元数据。现有元数据文件将在下一次服务器保存它们时被更新。", "OptionSpecialEpisode": "特集", "OptionSubstring": "子串", "OptionSunday": "星期天", @@ -1063,9 +1063,9 @@ "PleaseAddAtLeastOneFolder": "请点击添加按钮,添加至少一个文件夹到这个媒体库。", "PleaseConfirmPluginInstallation": "请点击“OK”以确认你已经阅读了上述内容并希望继续插件安装进程。", "PleaseEnterNameOrId": "请输入一个名称或一个外部ID。", - "PleaseRestartServerName": "请重启 Jellyfin 服务器 - {0}。", + "PleaseRestartServerName": "请重启 Jellyfin - {0}。", "PleaseSelectTwoItems": "请至少选择2个项目。", - "MessagePluginInstalled": "这个插件已经被成功安装。Jellyfin 服务器需要重启以使该插件生效。", + "MessagePluginInstalled": "此插件已成功安装。服务器需要重启以使该插件生效。", "PreferEmbeddedTitlesOverFileNames": "优先使用内置的标题而不是文件名", "PreferEmbeddedTitlesOverFileNamesHelp": "这将在没有 internet 元数据或本地元数据可用时确定默认显示标题。", "Premiere": "首映", @@ -1120,10 +1120,10 @@ "SeriesRecordingScheduled": "电视剧录制计划。", "SeriesSettings": "系列设定", "SeriesYearToPresent": "{0} - 现在", - "ServerNameIsRestarting": "Jellyfin Server - {0} 重启中。", - "ServerNameIsShuttingDown": "Jellyfin 服务器 - {0} 正在关闭。", - "ServerRestartNeededAfterPluginInstall": "安装插件后,Jellyfin 服务器需要重启以使插件生效。", - "ServerUpdateNeeded": "Jellyfin 服务器需要更新,请访问 {0} 以下载最新的版本", + "ServerNameIsRestarting": "服务器- {0} 重启中。", + "ServerNameIsShuttingDown": "服务器 - {0} 正在关闭。", + "ServerRestartNeededAfterPluginInstall": "安装插件后,Jellyfin需要重启。", + "ServerUpdateNeeded": "服务器需要更新,请访问 {0} 以下载最新的版本", "Settings": "设置", "SettingsSaved": "设置已保存。", "SettingsWarning": "更改这些值可能会导致不稳定或连接故障。如果您遇到任何问题, 我们建议将它们重新更改为默认值。", @@ -1273,7 +1273,7 @@ "ColorSpace": "色彩空间", "Directors": "导演", "ColorTransfer": "色彩转换", - "ConfirmDeleteItem": "这将同时在磁盘和媒体库中删除这个项目。确认删除?", + "ConfirmDeleteItem": "从媒体库中删除此项时,也会同时从文件系统中删除。确定要删除吗?", "ConfirmDeleteItems": "从媒体库中删除这些项目时,也会同时从文件系统中删除。确定要删除吗?", "ConfirmEndPlayerSession": "确认要关闭位于{0}的Jellyfin吗?", "ValueSeconds": "{0}秒", @@ -1293,11 +1293,11 @@ "LabelTranscodePath": "转码路径:", "LabelTranscodes": "转码:", "AuthProviderHelp": "选择用于验证此用户密码的身份验证提供者。", - "ColorPrimaries": "基色", - "ConfigureDateAdded": "在Jellyfin Server仪表板媒体库的设置里确认如何添加日期", + "ColorPrimaries": "原色", + "ConfigureDateAdded": "配置如何确定Jellyfin Server仪表板中媒体库设置下的添加日期", "DisplayModeHelp": "选择您想要的界面布局风格。", "EnableColorCodedBackgrounds": "彩色背景", - "ErrorDeletingItem": "从 Jellyfin Server 删除项目时出错。请确认 Jellyfin Server 是否拥有对媒体目录的写权限,然后重试。", + "ErrorDeletingItem": "从服务器删除项目时出错。请检查Jellyfin是否拥有对媒体目录的写权限,然后重试。", "GroupBySeries": "按系列分组", "HeaderApp": "应用程序", "DirectStreamHelp1": "该媒体文件的分辨率和编码(H.264、AC3 等)与您的设备兼容,但文件格式(.mkv、.avi、.wmv 等)不受支持。因此,视频在串流至您的设备之前将会被即时封装为另一种格式。", @@ -1309,7 +1309,7 @@ "HeaderKeepSeries": "保持系列", "HeaderMusicQuality": "音频质量", "HeaderNextEpisodePlayingInValue": "下一集在 {0} 后播放", - "HeaderNextVideoPlayingInValue": "下一部影片在 {0} 后播放", + "HeaderNextVideoPlayingInValue": "下一个视频将在{0}播放", "HeaderPlayOn": "播放在", "HeaderSeriesStatus": "系列状态", "HeaderStopRecording": "停止录制", @@ -1317,9 +1317,9 @@ "LabelAuthProvider": "认证提供者:", "LabelKeepUpTo": "保持:", "LabelPasswordResetProvider": "密码重置提供者:", - "LabelPersonRoleHelp": "示例:冰淇淋卡车司机", + "LabelPersonRoleHelp": "例如:冰淇淋车司机", "LabelSelectFolderGroups": "自动将来自下列文件夹的内容分组至电影、音乐、电视等视图中:", - "LabelSelectFolderGroupsHelp": "未选中的文件夹将显示在自身的视图中。", + "LabelSelectFolderGroupsHelp": "未勾选的文件夹将在它们自己的视图中显示。", "LabelUserLoginAttemptsBeforeLockout": "用户被封禁前可尝试的次数:", "DashboardVersionNumber": "版本:{0}", "DashboardServerName": "服务器:{0}", @@ -1345,7 +1345,7 @@ "OptionDownloadLogoImage": "标志", "OptionLoginAttemptsBeforeLockout": "确定在锁定之前可以进行多少次不正确的登录尝试。", "OptionLoginAttemptsBeforeLockoutHelp": "如果值为0,则表示将允许普通用户尝试三次、管理员尝试五次的默认值。将此设置为-1将禁用此功能。", - "PasswordResetProviderHelp": "选择一个密码重置提供者用于此用户申请重置密码", + "PasswordResetProviderHelp": "选择一个密码重置提供者用于此用户申请重置密码。", "PlaceFavoriteChannelsAtBeginning": "将最喜爱的频道置顶", "PlayNext": "播放下一个", "PlayNextEpisodeAutomatically": "自动播放下一集", @@ -1441,7 +1441,7 @@ "EveryXHours": "每 {0} 小时", "EveryHour": "每小时", "EveryXMinutes": "每 {0} 分钟", - "WriteAccessRequired": "Jellyfin 服务端需要此文件夹的写入权限。请确认是否拥有写入权限并重试。", + "WriteAccessRequired": "Jellyfin需要此文件夹的写入权限。请确认是否拥有写入权限并重试。", "PathNotFound": "无法找到此路径。请确认路径有效并重试。", "YadifBob": "YADIF Bob", "Yadif": "YADIF", @@ -1491,7 +1491,7 @@ "EnableDetailsBanner": "详细信息页面的横幅", "ButtonCast": "投射", "ButtonSyncPlay": "SyncPlay", - "EnableBlurHashHelp": "仍在加载的图片将显示带有模糊的占位符", + "EnableBlurHashHelp": "仍在加载的图片将以独特的的占位符显示。", "EnableBlurHash": "为图片启用模糊的占位符", "SyncPlayAccessHelp": "为此用户选择对同步播放功能的访问级别。同步播放让你可以和其他设备同步播放进度。", "ShowMore": "显示更多", From 23a55ed0489a99602efa70bc98db9fbf104b0151 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marcin=20Woli=C5=84ski?= Date: Thu, 13 Aug 2020 09:15:57 +0000 Subject: [PATCH 186/301] Translated using Weblate (Polish) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/pl/ --- src/strings/pl.json | 105 +++++++++++++++++++++++--------------------- 1 file changed, 55 insertions(+), 50 deletions(-) diff --git a/src/strings/pl.json b/src/strings/pl.json index 57cb8bc731..781993f4fa 100644 --- a/src/strings/pl.json +++ b/src/strings/pl.json @@ -136,7 +136,7 @@ "ColorTransfer": "Transfer kolorów", "CommunityRating": "Ocena społeczności", "Composer": "Kompozytor", - "ConfigureDateAdded": "Sposób ustalania daty dodania, można skonfigurować w ustawieniach biblioteki w kokpicie serwera Jellyfin", + "ConfigureDateAdded": "Skonfiguruj sposób określania dodanej daty na pulpicie nawigacyjnym w ustawieniach biblioteki.", "ConfirmDeleteImage": "Usunąć obraz?", "ConfirmDeleteItem": "Usunięcie tej pozycji usunie ją zarówno z systemu plików jak i z biblioteki mediów. Czy chcesz kontynuować?", "ConfirmDeleteItems": "Usunięcie tej pozycji usunie ją zarówno z systemu plików jak i z biblioteki mediów. Czy chcesz kontynuować?", @@ -215,10 +215,10 @@ "EndsAtValue": "Koniec o {0}", "Episodes": "Odcinki", "ErrorAddingListingsToSchedulesDirect": "Wystąpił błąd podczas dodawania składu do twojego konta Schedules Direct. Schedules Direct pozwala na limitowaną ilość składów na konto. Może być wymagane zalogowanie się na stronę Schedules Direct i usunięcie innych składów przed kontynuowaniem.", - "ErrorAddingMediaPathToVirtualFolder": "Wystąpił błąd podczas dodawania folderu mediów. Upewnij się, że folder jest prawidłowy a serwer Jellyfin ma dostęp do tej lokalizacji.", + "ErrorAddingMediaPathToVirtualFolder": "Wystąpił błąd podczas dodawania folderu mediów. Upewnij się, że folder jest prawidłowy a Jellyfin ma dostęp do tej lokalizacji.", "ErrorAddingTunerDevice": "Wystąpił błąd podczas dodawania tuner telewizyjnego. Upewnij się, że masz do niego dostęp i spróbuj ponownie.", "ErrorAddingXmlTvFile": "Podczas próby dostępu do pliku XMLTV wystąpił błąd. Upewnij się, że plik istnieje i spróbuj ponownie.", - "ErrorDeletingItem": "Podczas usuwania pozycji z serwera Jellyfin wystąpił błąd. Upewnij się, że serwer ma uprawnienia do zapisu w folderze mediów i spróbuj ponownie.", + "ErrorDeletingItem": "Podczas usuwania pozycji z serwera wystąpił błąd. Upewnij się, że serwer ma uprawnienia do zapisu w folderze mediów i spróbuj ponownie.", "ErrorGettingTvLineups": "Podczas pobierania programu telewizyjnego wystąpił błąd. Upewnij się, że informacje są poprawne i spróbuj ponownie.", "ErrorStartHourGreaterThanEnd": "Czas końcowy musi być większy niż czas początkowy.", "ErrorPleaseSelectLineup": "Wybierz program i spróbuj ponownie, jeśli żadne programy nie są dostępne, sprawdź czy twój login, hasło i kod pocztowy jest poprawny.", @@ -278,7 +278,7 @@ "HeaderAllowMediaDeletionFrom": "Zezwalaj na usuwanie mediów z", "HeaderApiKey": "Klucz API", "HeaderApiKeys": "Klucze API", - "HeaderApiKeysHelp": "Aplikacje zewnętrzne muszą posiadać klucz API, aby móc komunikować się z serwerem Jellyfin. Klucze wydawane są po zalogowaniu się za pomocą konta Jellyfin lub ręcznie nadając aplikacji klucz.", + "HeaderApiKeysHelp": "Aplikacje zewnętrzne muszą posiadać klucz API, aby móc komunikować się z serwerem. Klucze wydawane są po zalogowaniu się za pomocą konta lub ręcznie nadając aplikacji klucz.", "HeaderApp": "Aplikacja", "HeaderAppearsOn": "Występuje", "HeaderAudioBooks": "Książka mówiona", @@ -396,7 +396,7 @@ "HeaderPreferredMetadataLanguage": "Preferowany język metadanych", "HeaderProfile": "Profil", "HeaderProfileInformation": "Informacja o Profilu", - "HeaderProfileServerSettingsHelp": "Te wartości kontrolują jak serwer Jellyfin będzie przedstawiany dla urządzeń.", + "HeaderProfileServerSettingsHelp": "Te wartości kontrolują jak serwer będzie przedstawiany dla urządzeń.", "HeaderRecentlyPlayed": "Ostatnio odtwarzane", "HeaderRecordingOptions": "Opcje nagrywania", "HeaderRecordingPostProcessing": "Przetwarzanie finalne nagrań", @@ -473,7 +473,7 @@ "Identify": "Identyfikuj", "Images": "Obrazy", "ImportFavoriteChannelsHelp": "Jeśli aktywne, tylko kanały oznaczone jako ulubione na tunerze, będą importowane.", - "ImportMissingEpisodesHelp": "W przypadku aktywacji tej opcji, informacje o brakujących odcinkach zostaną zaimportowane do bazy Jellyfin i będą wyświetlane na listach sezonów i seriali. Może to jednak znacznie wydłużyć czas skanowania biblioteki.", + "ImportMissingEpisodesHelp": "Informacje o brakujących odcinkach zostaną zaimportowane do bazy i będą wyświetlane na listach sezonów i seriali. Może to jednak znacznie wydłużyć czas skanowania biblioteki.", "InstallingPackage": "Instalowanie {0} (wersja {1})", "InstantMix": "Szybki remiks", "ItemCount": "{0} pozycje", @@ -503,15 +503,15 @@ "LabelAppName": "Nazwa Aplikacji", "LabelAppNameExample": "Przykład: Sickbeard, Sonarr", "LabelArtists": "Wykonawcy:", - "LabelArtistsHelp": "Oddzielaj używając ;", + "LabelArtistsHelp": "Oddziel wielu artystów średnikiem \";\"", "LabelAudio": "Dźwięk", "LabelAudioLanguagePreference": "Preferowany język ścieżki dźwiękowej:", "LabelAutomaticallyRefreshInternetMetadataEvery": "Odświeżaj automatycznie metadane z Internetu:", "LabelBindToLocalNetworkAddress": "Przypisz do lokalnego adresu sieciowego:", - "LabelBindToLocalNetworkAddressHelp": "Opcjonalne. Zastąpi to lokalny adres IP adresem serwera HTTP Jeśli pozostanie puste, serwer będzie wiązać się z wszystkimi dostępnymi adresami. Zmiana tej wartości wymaga ponownego uruchomienia serwera Jellyfin.", + "LabelBindToLocalNetworkAddressHelp": "Zastąp lokalny adres IP serwera HTTP. Jeśli pozostanie puste, serwer połączy się ze wszystkimi dostępnymi adresami. Zmiana tej wartości wymaga ponownego uruchomienia.", "LabelBirthDate": "Data urodzenia:", "LabelBirthYear": "Rok urodzenia:", - "LabelBlastMessageInterval": "Częstotliwość komunikatów o dostępności (sekundy)", + "LabelBlastMessageInterval": "Częstotliwość komunikatów o dostępności", "LabelBlastMessageIntervalHelp": "Określa częstotliwość, wyrażoną w sekundach, przesyłania komunikatów o dostępności serwera.", "LabelBlockContentWithTags": "Blokuj pozycje ze znacznikami:", "LabelBurnSubtitles": "Wypalaj napisy:", @@ -531,13 +531,13 @@ "LabelCustomCertificatePath": "Folder niestandardowego certyfikatu SSL:", "LabelCustomCertificatePathHelp": "Ścieżka do pliku PKCS #12, zawierającego certyfikat i klucz prywatny, niezbędny do aktywowana obsługi TLS dla własnej domeny.", "LabelCustomCss": "Niestandardowy CSS:", - "LabelCustomCssHelp": "Zastosuj własny niestandardowy arkusz stylów CSS dla interfejsu webowego.", + "LabelCustomCssHelp": "Zastosuj własne niestandardowe arkusze stylów dla interfejsu webowego.", "LabelCustomDeviceDisplayName": "Nazwa wyświetlana:", "LabelCustomDeviceDisplayNameHelp": "Dostarcz własną nazwę wyświetlania lub zostaw puste i użyj nazwy dostarczonej przez urządzenie.", "LabelCustomRating": "Kategoria wiekowa własna:", "LabelDateAdded": "Data dodania:", "LabelDateAddedBehavior": "Data dodania dla nowej zawartości:", - "LabelDateAddedBehaviorHelp": "Jeśli istnieją metadane będą one użyte zawsze przed którąkolwiek z tych opcji.", + "LabelDateAddedBehaviorHelp": "Jeśli istnieją metadane, będą one zawsze użyte przed którąkolwiek z tych opcji.", "LabelDateTimeLocale": "Strefa czasowa:", "LabelDay": "Dzień:", "LabelDeathDate": "Data śmierci:", @@ -566,8 +566,8 @@ "LabelEnableAutomaticPortMapHelp": "Umożliwia automatyczne przekierowanie publicznego portu na twoim ruterze do lokalnego portu na serwerze przy użyciu UPnP. Ta opcja może nie działać z niektórymi modelami ruterów lub w niektórych konfiguracjach sieci. Zmiany zaczną działać po ponownym uruchomieniu serwera.", "LabelEnableBlastAliveMessages": "Przesyłaj komunikaty o dostępności", "LabelEnableBlastAliveMessagesHelp": "Aktywuj tę funkcję, jeśli serwer nie jest odpowiednio wykrywany przez inne urządzenia UPnP w twojej sieci.", - "LabelEnableDlnaClientDiscoveryInterval": "Częstotliwość wykrywania klientów (sekundy)", - "LabelEnableDlnaClientDiscoveryIntervalHelp": "Określa czas w sekundach, pomiędzy wyszukiwaniami SSDP, wykonywanymi przez Jellyfin.", + "LabelEnableDlnaClientDiscoveryInterval": "Częstotliwość wykrywania klientów", + "LabelEnableDlnaClientDiscoveryIntervalHelp": "Określa czas w sekundach, pomiędzy wyszukiwaniami SSDP.", "LabelEnableDlnaDebugLogging": "Rejestruj komunikaty diagnostyczne DLNA", "LabelEnableDlnaDebugLoggingHelp": "Tworzenie ogromnych plików dziennika diagnostycznego powinno być używane tylko w przypadku rozwiązywania problemów.", "LabelEnableDlnaPlayTo": "Aktywuj funkcję DLNA Play To", @@ -576,7 +576,7 @@ "LabelEnableDlnaServerHelp": "Umożliwia urządzeniom UPnP w sieci domowej, na przeglądanie i odtwarzanie zawartości.", "LabelEnableHardwareDecodingFor": "Aktywuj dekodowanie sprzętowe dla:", "LabelEnableRealtimeMonitor": "Monitoruj w czasie rzeczywistym", - "LabelEnableRealtimeMonitorHelp": "Na obsługiwanych systemach plików, zmiany zostaną przetworzone natychmiast.", + "LabelEnableRealtimeMonitorHelp": "Na obsługiwanych systemach plików zmiany zostaną przetworzone natychmiast.", "LabelEnableSingleImageInDidlLimit": "Ograniczaj do jednego wbudowanego obrazu", "LabelEnableSingleImageInDidlLimitHelp": "Niektóre urządzenie nie pokarzą prawidłowo wielu obrazów z Didl.", "LabelEndDate": "Data zakończenia:", @@ -591,9 +591,9 @@ "LabelFont": "Czcionka:", "LabelForgotPasswordUsernameHelp": "Podaj nazwę użytkownika, jeśli pamiętasz.", "LabelFriendlyName": "Przyjazna nazwa:", - "LabelServerNameHelp": "Ta nazwa będzie użyta do identyfikacji serwera, domyślnie użyta będzie nazwa komputera.", + "LabelServerNameHelp": "Ta nazwa będzie użyta do identyfikacji serwera, domyślnie użyta będzie nazwa serwera.", "LabelGroupMoviesIntoCollections": "Grupuj filmy w kolekcje", - "LabelGroupMoviesIntoCollectionsHelp": "Podczas wyświetlania listy filmów, filmy należące do kolekcji będą wyświetlone jako jedna zgrupowana pozycja.", + "LabelGroupMoviesIntoCollectionsHelp": "Podczas wyświetlania list filmów, filmy w kolekcji będą wyświetlane jako jedna zgrupowana pozycja.", "LabelH264Crf": "CRF kodowania H264:", "LabelEncoderPreset": "Szablon kodowania H264:", "LabelHardwareAccelerationType": "Akceleracja sprzętowa:", @@ -601,7 +601,7 @@ "LabelHomeNetworkQuality": "Jakość dla sieci lokalnej:", "LabelHomeScreenSectionValue": "Sekcja ekranu startowego {0}:", "LabelHttpsPort": "Lokalny numer portu HTTPS:", - "LabelHttpsPortHelp": "Numer portu TCP w trybie HTTPS, na którym serwer Jellyfin ma być dostępny.", + "LabelHttpsPortHelp": "Numer portu TCP dla serwera HTTPS.", "LabelIconMaxHeight": "Maksymalna wysokość ikon:", "LabelIconMaxHeightHelp": "Maksymalna rozdzielczość ikon wystawianych przez upnp:icon.", "LabelIconMaxWidth": "Maksymalna szerokość ikony:", @@ -629,7 +629,7 @@ "LabelLanguage": "Język:", "LabelLineup": "Kolejka:", "LabelLocalHttpServerPortNumber": "Lokalny numer portu HTTP:", - "LabelLocalHttpServerPortNumberHelp": "Numer portu TCP w trybie HTTP, na którym serwer Jellyfin ma być dostępny.", + "LabelLocalHttpServerPortNumberHelp": "Numer portu TCP dla serwera HTTP.", "LabelLockItemToPreventChanges": "Zablokuj tę pozycję, aby zapobiec przyszłym zmianom", "LabelLoginDisclaimer": "Zastrzeżenie odpowiedzialności:", "LabelLoginDisclaimerHelp": "Wiadomość będzie wyświetlona na dole strony logowania.", @@ -655,7 +655,7 @@ "LabelMetadataReaders": "Czytnik metadanych:", "LabelMetadataReadersHelp": "Określ swój priorytet dla źródeł metadanych. Pierwszy znaleziony plik będzie odczytany.", "LabelMetadataSavers": "Zapisywanie metadanych:", - "LabelMetadataSaversHelp": "Wybierz formaty plików używane do zapisywania metadanych.", + "LabelMetadataSaversHelp": "Wybierz formaty plików używane do zapisywania Twoich metadanych.", "LabelMethod": "Metoda:", "LabelMinBackdropDownloadWidth": "Minimalna szerokość pobieranych fototapet:", "LabelMinResumeDuration": "Minimalny czas wznowienia:", @@ -671,7 +671,7 @@ "LabelMovieCategories": "Kategorie filmowe:", "LabelMoviePrefix": "Prefiks filmu:", "LabelMoviePrefixHelp": "Jeśli stosujesz prefiksy dla tytułów filmów, wprowadź go tutaj, aby serwer mógł je obsługiwać prawidłowo.", - "LabelMovieRecordingPath": "Folder nagrywania filmów (opcjonalne):", + "LabelMovieRecordingPath": "Folder nagrywania filmów:", "LabelMusicStreamingTranscodingBitrate": "Przepływność transkodowania muzyki:", "LabelMusicStreamingTranscodingBitrateHelp": "Określa maksymalny bitrate podczas strumieniowania muzyki.", "LabelName": "Nazwa:", @@ -684,8 +684,8 @@ "LabelNumber": "Numer:", "LabelNumberOfGuideDays": "Liczba dni pobieranych danych przewodnika:", "LabelNumberOfGuideDaysHelp": "Pobieranie większej liczby dni danych przewodnika, pozwoli na zaplanowanie zadań na dłuższy okres i wyświetlanie większej listy, ale wydłuży także czas na jego pobranie. Automatycznie wybierze na podstawie liczby kanałów.", - "LabelOptionalNetworkPath": "(Opcjonalne) Udostępniony folder sieciowy:", - "LabelOptionalNetworkPathHelp": "Jeśli folder jest udostępniony w sieci domowej, podanie jego ścieżki, umożliwi bezpośrednie odtwarzanie na innych urządzeniach. Na przykład, {0} lub {1}.", + "LabelOptionalNetworkPath": "Udostępniony folder sieciowy:", + "LabelOptionalNetworkPathHelp": "Jeśli ten folder jest udostępniony w sieci, podanie ścieżki udziału sieciowego może umożliwić klientom na innych urządzeniach bezpośredni dostęp do plików multimedialnych. Na przykład {0} lub {1}.", "LabelOriginalAspectRatio": "Oryginalny format obrazu:", "LabelOriginalTitle": "Tytuł oryginalny:", "LabelOverview": "Opis:", @@ -729,7 +729,7 @@ "LabelReleaseDate": "Data wydania:", "LabelRemoteClientBitrateLimit": "Limit przepływności transmisji (Mbps):", "LabelRemoteClientBitrateLimitHelp": "Opcjonalny limit przepływności transmisji dla urządzeń poza siecią domową. Używaj tej opcji, w celu zapobiegania żądaniom o wyższe przepływności, niż Twojej połączenie internetowe może obsłużyć.", - "LabelRuntimeMinutes": "Czas (w minutach):", + "LabelRuntimeMinutes": "Czas trwania:", "LabelSaveLocalMetadata": "Zapisuj grafiki w folderach mediów", "LabelSaveLocalMetadataHelp": "Umożliwia zapisywanie grafik i bezpośrednio w folderach mediów, co umożliwia ich łatwą edycję.", "LabelScheduledTaskLastRan": "Ostatnio uruchomiono {0}, czas trwania {1}.", @@ -741,7 +741,7 @@ "LabelSelectVersionToInstall": "Wybierz wersję do instalacji:", "LabelSendNotificationToUsers": "Wyślij powiadomienie do:", "LabelSerialNumber": "Numer seryjny", - "LabelSeriesRecordingPath": "Folder nagrywania seriali (opcjonalne):", + "LabelSeriesRecordingPath": "Folder nagrywania seriali:", "LabelServerHost": "Serwer:", "LabelServerHostHelp": "192.168.1.100:8096 or https://myserver.com", "LabelSimultaneousConnectionLimit": "Limit jednoczesnych transmisji:", @@ -810,7 +810,7 @@ "LabelYoureDone": "Zakończono!", "LabelZipCode": "Kod pocztowy:", "LabelffmpegPath": "Folder aplikacji FFmpeg:", - "LabelffmpegPathHelp": "Określa folder aplikacji FFmpeg lub folder zawierający FFmpeg.", + "LabelffmpegPathHelp": "Określa folder aplikacji ffmpeg lub folder zawierający ffmpeg.", "LanNetworksHelp": "Lista adresów IP lub adresów IP z maską podsieci dla całych sieci, rozdzielana przecinkami, które będą traktowane jako sieć lokalna w trakcie egzekwowania ograniczeń przepustowości. Jeśli zostanie wypełniona, wszystkie pozostałe adresy będą traktowane jako sieć zewnętrzna i będą podlegać ograniczeniom przepustowości. Jeśli zostanie pusta, tylko podsieć, w której znajduje się serwer, będzie traktowana jako sieć lokalna.", "Large": "Duży", "LatestFromLibrary": "{0} ostatnio dodane", @@ -860,13 +860,13 @@ "MessageConfirmProfileDeletion": "Czy na pewno chcesz usunąć ten profil?", "MessageConfirmRecordingCancellation": "Anulować nagranie?", "MessageConfirmRemoveMediaLocation": "Czy na pewno chcesz usunąć tę lokalizację?", - "MessageConfirmRestart": "Czy na pewno chcesz uruchomić serwer Jellyfin ponownie?", - "MessageConfirmRevokeApiKey": "Czy na pewno chcesz unieważnić klucz api? Połączenia aplikacji z serwerem Jellyfin zostaną natychmiastowo zakończone.", + "MessageConfirmRestart": "Czy na pewno chcesz uruchomić Jellyfin ponownie?", + "MessageConfirmRevokeApiKey": "Czy na pewno chcesz unieważnić kluczAPI? Połączenia aplikacji z serwerem zostaną natychmiastowo zakończone.", "MessageConfirmShutdown": "Czy na pewno chcesz zamknąć serwer?", "MessageContactAdminToResetPassword": "W celu wyczyszczenia hasła. skontaktuj się z administratorem systemu.", "MessageCreateAccountAt": "Utwórz konto na {0}", "MessageDeleteTaskTrigger": "Czy na pewno chcesz usunąć ten wyzwalacz zadania?", - "MessageDirectoryPickerBSDInstruction": "W wypadku BSD, należy skonfigurować oprogramowanie FreeNAS aby umożliwić serwerowi Jellyfin dostęp do danych.", + "MessageDirectoryPickerBSDInstruction": "W wypadku BSD, należy skonfigurować oprogramowanie FreeNAS aby umożliwić Jellyfin dostęp do danych.", "MessageDirectoryPickerLinuxInstruction": "Dla Linuxa dystrybucji Arch Linux, CentOS, Debian, Fedora, openSUSE albo Ubuntu, musisz uzyskać dla użytkownika Jellyfin uprawnienia przynajmniej do odczytu pamięci masowej.", "MessageDownloadQueued": "Dodano do kolejki pobierania.", "MessageEnablingOptionLongerScans": "Aktywowanie tej opcji może spowodować znaczne wydłużenie czasu skanowania biblioteki.", @@ -888,7 +888,7 @@ "MessagePleaseEnsureInternetMetadata": "Upewnij się, że pobieranie metadanych z internetu jest aktywne.", "MessagePleaseWait": "Proszę czekać. To może potrwać chwilę.", "MessagePluginConfigurationRequiresLocalAccess": "Aby skonfigurować ten plugin zaloguj się bezpośrednio do lokalnego serwera.", - "MessagePluginInstallDisclaimer": "Wtyczki tworzone przez członków społeczności Jellyfin są doskonałym sposobem, aby zwiększyć swoje przeżycia z dodatkowymi funkcjami i zaletami Jellyfin. Przed instalacją należy zdawać sobie sprawę jakie efekty mogą mieć na twój serwer Jellyfin, takie jak dłuższy skan biblioteki, dodatkowe przetwarzanie w tle, a także obniżenie stabilności systemu.", + "MessagePluginInstallDisclaimer": "Wtyczki stworzone przez członków społeczności to świetny sposób na ulepszenie Twojego doświadczenia dzięki dodatkowym funkcjom i korzyściom. Przed instalacją zwróć uwagę na skutki, jakie mogą mieć na serwerze, takie jak dłuższe skanowanie bibliotek, dodatkowe przetwarzanie w tle i zmniejszona stabilność systemu.", "MessageReenableUser": "Zobacz poniżej aby aktywować ponownie", "MessageSettingsSaved": "Ustawienia zapisane.", "MessageTheFollowingLocationWillBeRemovedFromLibrary": "Następujące lokalizacje mediów zostaną usunięte z twojej biblioteki:", @@ -897,7 +897,7 @@ "MessageYouHaveVersionInstalled": "Masz aktualnie zainstalowaną wersję {0}.", "Metadata": "Metadane", "MetadataManager": "Menedżer metadanych", - "MetadataSettingChangeHelp": "Zmiana ustawień metadanych wpłynie na nową treść, która będzie dodawana w przyszłości. W celu odświeżenia istniejącej zawartości, otwórz ekran szczegółów, a następnie naciśnij przycisk Odśwież lub wykonaj odświeżanie wsadowe, korzystając z menedżera metadanych.", + "MetadataSettingChangeHelp": "Zmiana ustawień metadanych wpłynie na nowe treści dodane w przyszłości. Aby odświeżyć istniejącą zawartość, otwórz ekran szczegółów i kliknij przycisk odświeżania lub przeprowadź zbiorcze odświeżanie za pomocą menedżera metadanych.", "MinutesAfter": "minut po", "MinutesBefore": "minut przed", "Mobile": "Telefon", @@ -945,7 +945,7 @@ "OptionAllowLinkSharingHelp": "Tylko strony zawierające informacje o mediach są udostępnione. Media nigdy nie są udostępniane publicznie. Udostępnienia są ograniczone czasowo i wygasną po {0} dniach.", "OptionAllowManageLiveTv": "Zezwalaj na zarządzanie nagrywaniem telewizji", "OptionAllowMediaPlayback": "Zezwalaj na odtwarzanie mediów", - "OptionAllowMediaPlaybackTranscodingHelp": "Ograniczenie dostępu do transkodowania może powodować awarie odtwarzania w aplikacji Jellyfin, z powodu nieobsługiwanych formatów mediów.", + "OptionAllowMediaPlaybackTranscodingHelp": "Ograniczenie dostępu do transkodowania może spowodować błędy odtwarzania na klientach z powodu nieobsługiwanych formatów multimediów.", "OptionAllowRemoteControlOthers": "Zezwalaj na zdalne sterowanie innymi użytkownikami", "OptionAllowRemoteSharedDevices": "Zezwalaj na zdalne sterowanie urządzeniami współdzielonymi", "OptionAllowRemoteSharedDevicesHelp": "Urządzenia DLNA są uważane za udostępnione, dopóki użytkownik nie zacznie ich kontrolować.", @@ -958,7 +958,7 @@ "OptionAuto": "Automatycznie", "OptionAutomatic": "Automatycznie", "OptionAutomaticallyGroupSeries": "Scalaj seriale znajdujące się w wielu folderach", - "OptionAutomaticallyGroupSeriesHelp": "Umożliwia automatyczne scalanie seriali, rozproszonych w wielu folderach biblioteki, w pojedyncze seriale.", + "OptionAutomaticallyGroupSeriesHelp": "Serie rozmieszczone w wielu folderach w tej bibliotece zostaną automatycznie połączone w jedną serię.", "OptionBlockBooks": "Książki", "OptionBlockChannelContent": "Kanały internetowe", "OptionBlockLiveTvChannels": "Kanały telewizyjne", @@ -978,7 +978,7 @@ "OptionDatePlayed": "Data odtwarzania", "OptionDescending": "Malejąco", "OptionDisableUser": "Deaktywuj tego użytkownika", - "OptionDisableUserHelp": "Jeśli aktywne, serwer nie pozwoli na żadne połączenia tego użytkownika. Aktywne połączenia zostaną natychmiastowo zerwane.", + "OptionDisableUserHelp": "Serwer nie zezwoli na żadne połączenia od tego użytkownika. Istniejące połączenia zostaną nagle przerwane.", "OptionDislikes": "Nie Lubie", "OptionDisplayFolderView": "Wyświetlaj widok folderów z listą foldery mediów", "OptionDisplayFolderViewHelp": "Wyświetl foldery obok innych bibliotek multimediów. Może to być przydatne, jeśli chcesz mieć prosty widok folderu.", @@ -988,7 +988,7 @@ "OptionDownloadBoxImage": "Pudełko", "OptionDownloadDiscImage": "Dysk", "OptionDownloadImagesInAdvance": "Pobieraj obrazy z wyprzedzeniem", - "OptionDownloadImagesInAdvanceHelp": "Domyślnie, większość obrazów jest pobierana tylko kiedy jest wymagana przez aplikacje Jellyfin. Aktywuj tę opcję, aby pobierać wszystkie obrazy z wyprzedzeniem, podczas importowania multimediów. Może powodować znacząco dłuższe skanowanie biblioteki.", + "OptionDownloadImagesInAdvanceHelp": "Domyślnie większość obrazów jest pobierana tylko na żądanie klienta. Włącz tę opcję, aby pobierać wszystkie obrazy z wyprzedzeniem podczas importowania nowych multimediów. Może to spowodować znacznie dłuższe skanowanie biblioteki.", "OptionDownloadPrimaryImage": "Podstawowy", "OptionDownloadThumbImage": "Miniatura", "OptionDvd": "DVD", @@ -1019,7 +1019,7 @@ "OptionHlsSegmentedSubtitles": "Napisy dostosowane do HLS", "OptionHomeVideos": "Zdjęcia", "OptionIgnoreTranscodeByteRangeRequests": "Ignoruj żądanie zakresu byte transkodowania", - "OptionIgnoreTranscodeByteRangeRequestsHelp": "Jeżeli włączone, te żądania będą uznane ale będzie ignorowany nagłówek zakresu byte.", + "OptionIgnoreTranscodeByteRangeRequestsHelp": "Te żądania będą uznane ale będzie ignorowany nagłówek zakresu byte.", "OptionImdbRating": "Ocena IMDb", "OptionLikes": "Lubie", "OptionMax": "Maksymalny", @@ -1032,9 +1032,9 @@ "OptionOnInterval": "Cyklicznie", "OptionParentalRating": "Kategoria wiekowa", "OptionPlainStorageFolders": "Wyświetlaj wszystkie foldery jako zwyczajne foldery", - "OptionPlainStorageFoldersHelp": "Jeżeli aktywne, wszystkie foldery są reprezentowane w DIDL jako \"object.container.storageFolder\" zamiast bardziej dokładnych typów takich jak \"object.container.person.musicArtist\".", + "OptionPlainStorageFoldersHelp": "Wszystkie foldery są reprezentowane w DIDL jako „object.container.storageFolder” zamiast bardziej konkretnego typu, takiego jak „object.container.person.musicArtist”.", "OptionPlainVideoItems": "Wyświetlaj wszystkie wideo jako zwyczajne pozycje", - "OptionPlainVideoItemsHelp": "Jeżeli aktywne, wszystkie wideo są reprezentowane w DIDL jako \"object.item.videoitem\" zamiast bardziej dokładnych typów takich jak \"object.item.videoitem.movie\".", + "OptionPlainVideoItemsHelp": "Wszystkie wideo są reprezentowane w DIDL jako \"object.item.videoitem\" zamiast bardziej dokładnych typów takich jak \"object.item.videoitem.movie\".", "OptionPlayCount": "Liczba odtworzeń", "OptionPlayed": "Obejrzany", "OptionPremiereDate": "Data premiery", @@ -1055,7 +1055,7 @@ "OptionRuntime": "Długość filmu", "OptionSaturday": "Sobota", "OptionSaveMetadataAsHidden": "Zapisuj metadane i obrazy jako pliki ukryte", - "OptionSaveMetadataAsHiddenHelp": "Zmiana ta będzie miała zastosowanie do nowych metadanych zapisanych w przyszłości. Istniejące pliki metadanych zostaną zaktualizowane przy następnym zapisie przez serwer Jellyfin.", + "OptionSaveMetadataAsHiddenHelp": "Zmiana ta będzie miała zastosowanie do nowych metadanych zapisanych w przyszłości. Istniejące pliki metadanych zostaną zaktualizowane przy następnym zapisie przez serwer.", "OptionSpecialEpisode": "Specjalne", "OptionSubstring": "Podwyrażenie", "OptionSunday": "Niedziela", @@ -1099,9 +1099,9 @@ "PleaseAddAtLeastOneFolder": "Dodaj co najmniej jeden folder do tej biblioteki, klikając przycisk Dodaj.", "PleaseConfirmPluginInstallation": "Kliknij OK aby potwierdzić, iż zapoznałeś się z powyższym i chcesz zainstalować plugin.", "PleaseEnterNameOrId": "Proszę wprowadź nazwę lub zewnętrzne ID.", - "PleaseRestartServerName": "Uruchom ponownie serwer Jellyfin - {0}.", + "PleaseRestartServerName": "Uruchom ponownie Jellyfin na {0}.", "PleaseSelectTwoItems": "Proszę wybierz przynajmniej dwie pozycje.", - "MessagePluginInstalled": "Wtyczka została poprawnie zainstalowana. Serwer Jellyfin będzie wymagała ponownego uruchomienia w celu zastosowania zmian.", + "MessagePluginInstalled": "Wtyczka została poprawnie zainstalowana. Serwer będzie wymagała ponownego uruchomienia w celu zastosowania zmian.", "PreferEmbeddedTitlesOverFileNames": "Preferuj wbudowane tytuły zamiast nazw plików", "PreferEmbeddedTitlesOverFileNamesHelp": "Określa domyślnie wyświetlany tytuł, gdy brak dostępnych metadanych lokalnych i od dostawców internetowych.", "Premiere": "Premiera", @@ -1126,7 +1126,7 @@ "RecordingScheduled": "Zaplanowano nagranie.", "Recordings": "Nagrania", "Refresh": "Odśwież", - "RefreshDialogHelp": "Metadane są odświeżane w oparciu o ustawienia i dostawców internetowych, aktywowanych w kokpicie serwera Jellyfin.", + "RefreshDialogHelp": "Metadane są odświeżane na podstawie ustawień i usług internetowych włączonych na pulpicie nawigacyjnym.", "RefreshMetadata": "Odśwież metadane", "RefreshQueued": "Odświeżanie dodane do kolejki zadań.", "ReleaseDate": "Data wydania", @@ -1164,10 +1164,10 @@ "SeriesRecordingScheduled": "Zaplanowano nagranie seryjne.", "SeriesSettings": "Ustawienia nagrywania serialu", "SeriesYearToPresent": "{0} - Teraz", - "ServerNameIsRestarting": "Jellyfin Server - {0} jest uruchamiany ponownie.", - "ServerNameIsShuttingDown": "Serwer Jellyfin - {0} jest zamykany.", - "ServerRestartNeededAfterPluginInstall": "Serwer Jellyfin będzie wymagał ponownego uruchomienia po zainstalowaniu wtyczki.", - "ServerUpdateNeeded": "Ten serwer Jellyfin wymaga aktualizacji. Aby pobrać najnowszą wersję, odwiedź stronę {0}", + "ServerNameIsRestarting": "Server za {0} zostanie uruchamiony ponownie.", + "ServerNameIsShuttingDown": "Serwer za {0} zostanie wyłączony.", + "ServerRestartNeededAfterPluginInstall": "Jellyfin będzie wymagał ponownego uruchomienia po zainstalowaniu wtyczki.", + "ServerUpdateNeeded": "Ten serwer wymaga aktualizacji. Aby pobrać najnowszą wersję, odwiedź stronę {0}", "Settings": "Ustawienia", "SettingsSaved": "Ustawienia zapisane.", "SettingsWarning": "Zmiana tych wartości może spowodować niestabilność lub awarię połączenia. Jeśli wystąpią jakiekolwiek problemy, zalecamy powrót do ustawień ich na domyślne.", @@ -1330,7 +1330,7 @@ "LabelDynamicExternalId": "{0} Id:", "LabelFormat": "Format:", "LabelServerName": "Nazwa serwera:", - "AuthProviderHelp": "Wybierz dostawcę uwierzytelniania który ma być użyty do uwierzytelnienia hasła tego użytkownika.", + "AuthProviderHelp": "Wybierz dostawcę uwierzytelniania, który ma być użyty do uwierzytelnienia hasła tego użytkownika.", "LabelPasswordResetProvider": "Dostawca resetowania hasła:", "LabelTranscodePath": "Ścieżka Transkodowania:", "LabelTranscodes": "Transkodery:", @@ -1372,7 +1372,7 @@ "OptionPosterCard": "Karta plakatu", "OptionThumb": "Podgląd", "OptionThumbCard": "Karta miniatury", - "PasswordResetProviderHelp": "Wybierz dostawcę resetowania hasła, który będzie używany, gdy ten użytkownik zażąda zresetowania hasła", + "PasswordResetProviderHelp": "Wybierz dostawcę resetowania hasła, który będzie używany, gdy ten użytkownik zażąda resetowania hasła.", "PlaybackData": "Dane Odtwarzania", "SubtitleOffset": "Przesunięcie Napisów", "TabNetworking": "Łączność Sieciowa", @@ -1450,7 +1450,7 @@ "LastSeen": "Ostatnio widziany {0}", "PersonRole": "jako {0}", "ListPaging": "{0}-{1} z {2}", - "WriteAccessRequired": "Serwer Jellyfin wymaga praw zapisu do tego katalogu. Upewnij się, że prawa zapisu zostały przyznane i spróbuj ponownie.", + "WriteAccessRequired": "Jellyfin wymaga praw zapisu do tego katalogu. Upewnij się, że prawa zapisu zostały przyznane i spróbuj ponownie.", "PathNotFound": "Ścieżka nie została znaleziona. Upewnij się, że ścieżka jest poprawna i spróbuj ponownie.", "YadifBob": "YADIF Bob", "Yadif": "YADIF", @@ -1509,7 +1509,7 @@ "LabelRequireHttps": "Wymagaj HTTPS", "LabelStable": "Stabilny", "LabelChromecastVersion": "Wersja Chromecast", - "LabelEnableHttpsHelp": "Pozwala serwerowi na nasłuchiwanie na skonfigurowanym porcie HTTPS. Prawidłowy certyfikat musi być skonfigurowany by ta opcja zadziałała.", + "LabelEnableHttpsHelp": "Nasłuchuj na skonfigurowanym porcie HTTPS. Aby to zadziałało, należy również przedstawić ważny certyfikat.", "LabelEnableHttps": "Włącz HTTPS", "HeaderSyncPlayEnabled": "SyncPlay włączony", "HeaderSyncPlaySelectGroup": "Dołącz do grupy", @@ -1525,5 +1525,10 @@ "BoxSet": "Kolekcja", "PreviousTrack": "Poprzedni", "NextTrack": "Następny", - "LabelUnstable": "Niestabilny" + "LabelUnstable": "Niestabilny", + "Preview": "Zapowiedź", + "SubtitleVerticalPositionHelp": "Numer wiersza, w którym pojawia się tekst. Liczby dodatnie wskazują z góry na dół. Liczby ujemne wskazują od dołu do góry.", + "LabelSubtitleVerticalPosition": "Pozycja pionowa:", + "MessageGetInstalledPluginsError": "Wystąpił błąd podczas pobierania listy aktualnie zainstalowanych wtyczek.", + "MessagePluginInstallError": "Wystąpił błąd podczas instalacji wtyczki." } From 67ce56da9511d9aa1d51eb16339ff50c65163d03 Mon Sep 17 00:00:00 2001 From: dkanada Date: Thu, 13 Aug 2020 21:23:51 +0900 Subject: [PATCH 187/301] remove some duplicate strings --- .../displaySettings/displaySettings.template.html | 2 +- src/components/guide/guide.js | 2 +- .../mediaLibraryEditor/mediaLibraryEditor.js | 2 +- src/components/mediainfo/mediainfo.js | 2 +- src/controllers/dashboard/dashboard.js | 2 +- src/controllers/dashboard/devices/devices.js | 2 +- src/controllers/dashboard/dlna/profile.html | 10 +++++----- src/controllers/dashboard/dlna/profiles.js | 2 +- .../dashboard/plugins/repositories/index.js | 2 +- .../dashboard/scheduledtasks/scheduledtask.js | 2 +- src/controllers/dashboard/users/userprofilespage.js | 4 ++-- src/controllers/itemDetails/index.js | 2 +- src/controllers/livetvstatus.js | 4 ++-- src/controllers/music/musicrecommended.js | 2 +- src/scripts/itembynamedetailpage.js | 2 +- 15 files changed, 21 insertions(+), 21 deletions(-) diff --git a/src/components/displaySettings/displaySettings.template.html b/src/components/displaySettings/displaySettings.template.html index fdaf8d70f1..e751ce56c4 100644 --- a/src/components/displaySettings/displaySettings.template.html +++ b/src/components/displaySettings/displaySettings.template.html @@ -162,7 +162,7 @@
    ${EnableBackdropsHelp}
    diff --git a/src/components/guide/guide.js b/src/components/guide/guide.js index a7b32d887d..b63490a5a5 100644 --- a/src/components/guide/guide.js +++ b/src/components/guide/guide.js @@ -547,7 +547,7 @@ function Guide(options) { } else if (program.IsPremiere && options.showPremiereIndicator) { indicatorHtml = '' + globalize.translate('Premiere') + ''; } else if (program.IsSeries && !program.IsRepeat && options.showNewIndicator) { - indicatorHtml = '' + globalize.translate('AttributeNew') + ''; + indicatorHtml = '' + globalize.translate('New') + ''; } else if (program.IsSeries && program.IsRepeat && options.showRepeatIndicator) { indicatorHtml = '' + globalize.translate('Repeat') + ''; } diff --git a/src/components/mediaLibraryEditor/mediaLibraryEditor.js b/src/components/mediaLibraryEditor/mediaLibraryEditor.js index 0e68c6a289..13d264f4c9 100644 --- a/src/components/mediaLibraryEditor/mediaLibraryEditor.js +++ b/src/components/mediaLibraryEditor/mediaLibraryEditor.js @@ -76,7 +76,7 @@ import 'flexStyles'; confirm({ title: globalize.translate('HeaderRemoveMediaLocation'), text: globalize.translate('MessageConfirmRemoveMediaLocation'), - confirmText: globalize.translate('ButtonDelete'), + confirmText: globalize.translate('Delete'), primary: 'delete' }).then(() => { const refreshAfterChange = currentOptions.refresh; diff --git a/src/components/mediainfo/mediainfo.js b/src/components/mediainfo/mediainfo.js index 53982040b8..8ea165743b 100644 --- a/src/components/mediainfo/mediainfo.js +++ b/src/components/mediainfo/mediainfo.js @@ -208,7 +208,7 @@ import 'emby-button'; }); } else if (item.IsSeries && !item.IsRepeat) { miscInfo.push({ - html: `
    ${globalize.translate('AttributeNew')}
    ` + html: `
    ${globalize.translate('New')}
    ` }); } else if (item.IsSeries && item.IsRepeat) { miscInfo.push({ diff --git a/src/controllers/dashboard/dashboard.js b/src/controllers/dashboard/dashboard.js index a36aa3ce68..a1ce7f489e 100644 --- a/src/controllers/dashboard/dashboard.js +++ b/src/controllers/dashboard/dashboard.js @@ -737,7 +737,7 @@ import 'emby-itemscontainer'; shutdown: function (btn) { import('confirm').then(({default: confirm}) => { confirm({ - title: globalize.translate('HeaderShutdown'), + title: globalize.translate('ButtonShutdown'), text: globalize.translate('MessageConfirmShutdown'), confirmText: globalize.translate('ButtonShutdown'), primary: 'delete' diff --git a/src/controllers/dashboard/devices/devices.js b/src/controllers/dashboard/devices/devices.js index bc9dd19764..1178a0f1bd 100644 --- a/src/controllers/dashboard/devices/devices.js +++ b/src/controllers/dashboard/devices/devices.js @@ -21,7 +21,7 @@ import 'cardStyle'; confirm({ text: msg, title: globalize.translate('HeaderDeleteDevice'), - confirmText: globalize.translate('ButtonDelete'), + confirmText: globalize.translate('Delete'), primary: 'delete' }).then(function () { loading.show(); diff --git a/src/controllers/dashboard/dlna/profile.html b/src/controllers/dashboard/dlna/profile.html index 02a85b4ec7..22c7ce73ef 100644 --- a/src/controllers/dashboard/dlna/profile.html +++ b/src/controllers/dashboard/dlna/profile.html @@ -231,31 +231,31 @@

    ${HeaderDirectPlayProfileHelp}

    - +

    ${HeaderTranscodingProfileHelp}

    - +

    ${HeaderContainerProfileHelp}

    - +

    ${HeaderCodecProfileHelp}

    - +

    ${HeaderResponseProfileHelp}

    - +
    diff --git a/src/controllers/dashboard/dlna/profiles.js b/src/controllers/dashboard/dlna/profiles.js index f1d57eef3c..cdfdcf8212 100644 --- a/src/controllers/dashboard/dlna/profiles.js +++ b/src/controllers/dashboard/dlna/profiles.js @@ -46,7 +46,7 @@ import 'emby-button'; html += '
    '; if (profile.Type == 'User') { - html += ''; + html += ''; } html += '
    '; diff --git a/src/controllers/dashboard/plugins/repositories/index.js b/src/controllers/dashboard/plugins/repositories/index.js index c4c0885375..8d1cbf3164 100644 --- a/src/controllers/dashboard/plugins/repositories/index.js +++ b/src/controllers/dashboard/plugins/repositories/index.js @@ -69,7 +69,7 @@ function getRepositoryHtml(repository) { html += `

    ${repository.Name}

    `; html += `
    ${repository.Url}
    `; html += '
    '; - html += ``; + html += ``; html += '
    '; return html; diff --git a/src/controllers/dashboard/scheduledtasks/scheduledtask.js b/src/controllers/dashboard/scheduledtasks/scheduledtask.js index 0bf0fc5c3c..64c09c6d81 100644 --- a/src/controllers/dashboard/scheduledtasks/scheduledtask.js +++ b/src/controllers/dashboard/scheduledtasks/scheduledtask.js @@ -75,7 +75,7 @@ import 'emby-select'; } html += '
    '; - html += ''; + html += ''; html += '
    '; } diff --git a/src/controllers/dashboard/users/userprofilespage.js b/src/controllers/dashboard/users/userprofilespage.js index add90d0a0b..bfd8d96d92 100644 --- a/src/controllers/dashboard/users/userprofilespage.js +++ b/src/controllers/dashboard/users/userprofilespage.js @@ -18,7 +18,7 @@ import 'flexStyles'; confirm({ title: globalize.translate('DeleteUser'), text: msg, - confirmText: globalize.translate('ButtonDelete'), + confirmText: globalize.translate('Delete'), primary: 'delete' }).then(function () { loading.show(); @@ -50,7 +50,7 @@ import 'flexStyles'; icon: 'person' }); menuItems.push({ - name: globalize.translate('ButtonDelete'), + name: globalize.translate('Delete'), id: 'delete', icon: 'delete' }); diff --git a/src/controllers/itemDetails/index.js b/src/controllers/itemDetails/index.js index b3c6a15dc9..119d265a14 100644 --- a/src/controllers/itemDetails/index.js +++ b/src/controllers/itemDetails/index.js @@ -1435,7 +1435,7 @@ import 'emby-select'; name: globalize.translate('HeaderSeries'), type: 'Series' }, { - name: globalize.translate('HeaderAlbums'), + name: globalize.translate('Albums'), type: 'MusicAlbum' }, { name: globalize.translate('HeaderBooks'), diff --git a/src/controllers/livetvstatus.js b/src/controllers/livetvstatus.js index 7555b04b99..07a6556fb2 100644 --- a/src/controllers/livetvstatus.js +++ b/src/controllers/livetvstatus.js @@ -137,7 +137,7 @@ function renderProviders(page, providers) { function showProviderOptions(page, providerId, button) { const items = []; items.push({ - name: globalize.translate('ButtonDelete'), + name: globalize.translate('Delete'), id: 'delete' }); items.push({ @@ -255,7 +255,7 @@ function addDevice(button) { function showDeviceMenu(button, tunerDeviceId) { const items = []; items.push({ - name: globalize.translate('ButtonDelete'), + name: globalize.translate('Delete'), id: 'delete' }); items.push({ diff --git a/src/controllers/music/musicrecommended.js b/src/controllers/music/musicrecommended.js index 94031cd2c4..e16afa2d59 100644 --- a/src/controllers/music/musicrecommended.js +++ b/src/controllers/music/musicrecommended.js @@ -179,7 +179,7 @@ import 'flexStyles'; return [{ name: globalize.translate('Suggestions') }, { - name: globalize.translate('TabAlbums') + name: globalize.translate('Albums') }, { name: globalize.translate('TabAlbumArtists') }, { diff --git a/src/scripts/itembynamedetailpage.js b/src/scripts/itembynamedetailpage.js index 147dc66ae0..7a56be6781 100644 --- a/src/scripts/itembynamedetailpage.js +++ b/src/scripts/itembynamedetailpage.js @@ -53,7 +53,7 @@ function renderItems(page, item) { if (item.AlbumCount) { sections.push({ - name: globalize.translate('TabAlbums'), + name: globalize.translate('Albums'), type: 'MusicAlbum' }); } From 65776be6aa8eceaeb0c2eb626fd2fb228bc8d173 Mon Sep 17 00:00:00 2001 From: dkanada Date: Thu, 13 Aug 2020 21:31:29 +0900 Subject: [PATCH 188/301] remove more strings from source --- .../accessSchedule.template.html | 2 +- .../guide/guide-settings.template.html | 2 +- src/components/guide/tvguide.template.html | 4 ++-- .../libraryoptionseditor.js | 20 +++++++++---------- .../subtitlesettings.template.html | 2 +- src/controllers/dashboard/general.html | 2 +- src/controllers/itemDetails/index.html | 2 +- src/controllers/itemDetails/index.js | 4 ++-- src/controllers/livetv.html | 2 +- src/controllers/livetv/livetvsuggested.js | 2 +- src/controllers/movies/movies.html | 6 +++--- src/controllers/music/music.html | 6 +++--- src/controllers/music/musicrecommended.js | 2 +- src/controllers/playback/queue/index.html | 8 ++++---- src/controllers/shows/tvrecommended.html | 4 ++-- src/controllers/shows/tvrecommended.js | 6 +++--- src/controllers/wizard/finish/index.html | 2 +- src/controllers/wizard/library.html | 4 ++-- src/controllers/wizard/remote/index.html | 4 ++-- src/controllers/wizard/settings/index.html | 4 ++-- src/controllers/wizard/start/index.html | 2 +- src/controllers/wizard/user/index.html | 4 ++-- src/scripts/itembynamedetailpage.js | 2 +- src/scripts/libraryBrowser.js | 2 +- src/scripts/libraryMenu.js | 2 +- 25 files changed, 50 insertions(+), 50 deletions(-) diff --git a/src/components/accessSchedule/accessSchedule.template.html b/src/components/accessSchedule/accessSchedule.template.html index d89b69d9bd..e209fbc1ff 100644 --- a/src/components/accessSchedule/accessSchedule.template.html +++ b/src/components/accessSchedule/accessSchedule.template.html @@ -1,5 +1,5 @@
    -

    diff --git a/src/components/guide/guide-settings.template.html b/src/components/guide/guide-settings.template.html index edb2ffa8d3..d4bad711b1 100644 --- a/src/components/guide/guide-settings.template.html +++ b/src/components/guide/guide-settings.template.html @@ -1,5 +1,5 @@
    -

    diff --git a/src/components/guide/tvguide.template.html b/src/components/guide/tvguide.template.html index 730de55909..b0f23f4b32 100644 --- a/src/components/guide/tvguide.template.html +++ b/src/components/guide/tvguide.template.html @@ -29,10 +29,10 @@

    - -
    diff --git a/src/components/libraryoptionseditor/libraryoptionseditor.js b/src/components/libraryoptionseditor/libraryoptionseditor.js index ab193c264e..f90643ce07 100644 --- a/src/components/libraryoptionseditor/libraryoptionseditor.js +++ b/src/components/libraryoptionseditor/libraryoptionseditor.js @@ -75,9 +75,9 @@ import 'emby-input'; html += '

    '; html += '
    '; if (i > 0) { - html += ``; + html += ``; } else if (plugins.length > 1) { - html += ``; + html += ``; } html += '
    '; } @@ -131,9 +131,9 @@ import 'emby-input'; html += ''; html += ''; if (index > 0) { - html += ''; + html += ''; } else if (plugins.length > 1) { - html += ''; + html += ''; } html += ''; }); @@ -197,9 +197,9 @@ import 'emby-input'; html += ''; html += ''; if (i > 0) { - html += ``; + html += ``; } else if (plugins.length > 1) { - html += ``; + html += ``; } html += ''; } @@ -236,9 +236,9 @@ import 'emby-input'; html += ''; html += ''; if (i > 0) { - html += ''; + html += ''; } else if (plugins.length > 1) { - html += ''; + html += ''; } html += ''; } @@ -291,13 +291,13 @@ import 'emby-input'; const btnSortable = elem.querySelector('.btnSortable'); const inner = btnSortable.querySelector('.material-icons'); if (elem.previousSibling) { - btnSortable.title = globalize.translate('ButtonUp'); + btnSortable.title = globalize.translate('Up'); btnSortable.classList.add('btnSortableMoveUp'); btnSortable.classList.remove('btnSortableMoveDown'); inner.classList.remove('keyboard_arrow_down'); inner.classList.add('keyboard_arrow_up'); } else { - btnSortable.title = globalize.translate('ButtonDown'); + btnSortable.title = globalize.translate('Down'); btnSortable.classList.remove('btnSortableMoveUp'); btnSortable.classList.add('btnSortableMoveDown'); inner.classList.remove('keyboard_arrow_up'); diff --git a/src/components/subtitlesettings/subtitlesettings.template.html b/src/components/subtitlesettings/subtitlesettings.template.html index af9139188c..2884b26efd 100644 --- a/src/components/subtitlesettings/subtitlesettings.template.html +++ b/src/components/subtitlesettings/subtitlesettings.template.html @@ -14,7 +14,7 @@ - +
    ${DefaultSubtitlesHelp}
    ${SmartSubtitlesHelp}
    diff --git a/src/controllers/dashboard/general.html b/src/controllers/dashboard/general.html index 9ac0a90832..078d9d6055 100644 --- a/src/controllers/dashboard/general.html +++ b/src/controllers/dashboard/general.html @@ -19,7 +19,7 @@
    ${LabelPreferredDisplayLanguageHelp}
    diff --git a/src/controllers/itemDetails/index.html b/src/controllers/itemDetails/index.html index bc6bc5f5a4..9aff1efa14 100644 --- a/src/controllers/itemDetails/index.html +++ b/src/controllers/itemDetails/index.html @@ -42,7 +42,7 @@ - - + @@ -46,7 +46,7 @@
    - +
    @@ -75,7 +75,7 @@
    - +
    diff --git a/src/controllers/music/music.html b/src/controllers/music/music.html index 1e22ae9f3a..6ef1afb89f 100644 --- a/src/controllers/music/music.html +++ b/src/controllers/music/music.html @@ -38,9 +38,9 @@
    - + - +
    @@ -92,7 +92,7 @@
    - +
    diff --git a/src/controllers/music/musicrecommended.js b/src/controllers/music/musicrecommended.js index e16afa2d59..ee182a0427 100644 --- a/src/controllers/music/musicrecommended.js +++ b/src/controllers/music/musicrecommended.js @@ -187,7 +187,7 @@ import 'flexStyles'; }, { name: globalize.translate('TabPlaylists') }, { - name: globalize.translate('TabSongs') + name: globalize.translate('Songs') }, { name: globalize.translate('TabGenres') }]; diff --git a/src/controllers/playback/queue/index.html b/src/controllers/playback/queue/index.html index 2720dfe3f0..8d8476bb1e 100644 --- a/src/controllers/playback/queue/index.html +++ b/src/controllers/playback/queue/index.html @@ -59,7 +59,7 @@ - @@ -81,7 +81,7 @@ - @@ -99,7 +99,7 @@
    -
    @@ -120,7 +120,7 @@ - - +
    @@ -60,7 +60,7 @@
    - +
    diff --git a/src/controllers/shows/tvrecommended.js b/src/controllers/shows/tvrecommended.js index c519e0ac58..3d78997bab 100644 --- a/src/controllers/shows/tvrecommended.js +++ b/src/controllers/shows/tvrecommended.js @@ -17,7 +17,7 @@ import 'emby-button'; function getTabs() { return [{ - name: globalize.translate('TabShows') + name: globalize.translate('Shows') }, { name: globalize.translate('Suggestions') }, { @@ -318,8 +318,8 @@ import 'emby-button'; libraryMenu.setTitle(item.Name); }); } else { - view.setAttribute('data-title', globalize.translate('TabShows')); - libraryMenu.setTitle(globalize.translate('TabShows')); + view.setAttribute('data-title', globalize.translate('Shows')); + libraryMenu.setTitle(globalize.translate('Shows')); } } diff --git a/src/controllers/wizard/finish/index.html b/src/controllers/wizard/finish/index.html index 4d54a10cd4..3447ced02f 100644 --- a/src/controllers/wizard/finish/index.html +++ b/src/controllers/wizard/finish/index.html @@ -6,7 +6,7 @@
    diff --git a/src/controllers/wizard/remote/index.html b/src/controllers/wizard/remote/index.html index 0718c2dc37..0334f584c5 100644 --- a/src/controllers/wizard/remote/index.html +++ b/src/controllers/wizard/remote/index.html @@ -22,10 +22,10 @@
    diff --git a/src/controllers/wizard/settings/index.html b/src/controllers/wizard/settings/index.html index d4f537cf98..d1f557d8f1 100644 --- a/src/controllers/wizard/settings/index.html +++ b/src/controllers/wizard/settings/index.html @@ -17,10 +17,10 @@
    diff --git a/src/controllers/wizard/start/index.html b/src/controllers/wizard/start/index.html index 05e282bee3..5306d2ca73 100644 --- a/src/controllers/wizard/start/index.html +++ b/src/controllers/wizard/start/index.html @@ -19,7 +19,7 @@
    diff --git a/src/controllers/wizard/user/index.html b/src/controllers/wizard/user/index.html index 3ce0b3ba74..24429d043a 100644 --- a/src/controllers/wizard/user/index.html +++ b/src/controllers/wizard/user/index.html @@ -23,10 +23,10 @@
    diff --git a/src/scripts/itembynamedetailpage.js b/src/scripts/itembynamedetailpage.js index 7a56be6781..306282b5fd 100644 --- a/src/scripts/itembynamedetailpage.js +++ b/src/scripts/itembynamedetailpage.js @@ -32,7 +32,7 @@ function renderItems(page, item) { if (item.SeriesCount) { sections.push({ - name: globalize.translate('TabShows'), + name: globalize.translate('Shows'), type: 'Series' }); } diff --git a/src/scripts/libraryBrowser.js b/src/scripts/libraryBrowser.js index 83d683a690..debae200c0 100644 --- a/src/scripts/libraryBrowser.js +++ b/src/scripts/libraryBrowser.js @@ -105,7 +105,7 @@ export function getQueryPagingHtml (options) { } if (options.sortButton) { - html += ''; + html += ''; } if (options.filterButton) { diff --git a/src/scripts/libraryMenu.js b/src/scripts/libraryMenu.js index 543aa6f3d0..29d859740a 100644 --- a/src/scripts/libraryMenu.js +++ b/src/scripts/libraryMenu.js @@ -567,7 +567,7 @@ import 'flexStyles'; view.ImageTags = {}; view.icon = 'live_tv'; const guideView = Object.assign({}, view); - guideView.Name = globalize.translate('ButtonGuide'); + guideView.Name = globalize.translate('Guide'); guideView.ImageTags = {}; guideView.icon = 'dvr'; guideView.url = 'livetv.html?tab=1'; From a9f9444bf7b8750060f230cb52b2a58c4048a27d Mon Sep 17 00:00:00 2001 From: dkanada Date: Thu, 13 Aug 2020 21:38:57 +0900 Subject: [PATCH 189/301] merge most tab and header strings --- src/components/channelMapper/channelMapper.js | 2 +- src/components/filterdialog/filterdialog.template.html | 2 +- .../mediaLibraryCreator.template.html | 2 +- .../mediaLibraryEditor.template.html | 2 +- src/components/multiSelect/multiSelect.js | 2 +- src/controllers/dashboard/devices/devices.html | 2 +- src/controllers/dashboard/users/userlibraryaccess.js | 2 +- src/controllers/dashboard/users/usernew.js | 2 +- src/controllers/itemDetails/index.html | 2 +- src/controllers/livetv.html | 2 +- src/controllers/livetv/livetvsuggested.js | 2 +- src/controllers/movies/moviesrecommended.js | 10 +++++----- src/controllers/music/musicrecommended.js | 2 +- src/controllers/session/addServer/index.html | 2 +- src/controllers/shows/tvrecommended.js | 2 +- src/controllers/user/profile/index.html | 2 +- src/scripts/itembynamedetailpage.js | 2 +- src/scripts/libraryMenu.js | 6 +++--- 18 files changed, 24 insertions(+), 24 deletions(-) diff --git a/src/components/channelMapper/channelMapper.js b/src/components/channelMapper/channelMapper.js index 89d085c185..24f506b9dd 100644 --- a/src/components/channelMapper/channelMapper.js +++ b/src/components/channelMapper/channelMapper.js @@ -93,7 +93,7 @@ export default class channelMapper { html += '
    '; html += '
    '; html += '
    '; - html += `

    ${globalize.translate('HeaderChannels')}

    `; + html += `

    ${globalize.translate('Channels')}

    `; html += '
    '; html += '
    '; html += '
    '; diff --git a/src/components/filterdialog/filterdialog.template.html b/src/components/filterdialog/filterdialog.template.html index f4bbfe7395..1d61f3923e 100644 --- a/src/components/filterdialog/filterdialog.template.html +++ b/src/components/filterdialog/filterdialog.template.html @@ -90,7 +90,7 @@
    -
    +
    diff --git a/src/components/mediaLibraryCreator/mediaLibraryCreator.template.html b/src/components/mediaLibraryCreator/mediaLibraryCreator.template.html index 2884ce256c..4d84544d06 100644 --- a/src/components/mediaLibraryCreator/mediaLibraryCreator.template.html +++ b/src/components/mediaLibraryCreator/mediaLibraryCreator.template.html @@ -24,7 +24,7 @@
    -

    ${HeadersFolders}

    +

    ${Folders}

    diff --git a/src/components/mediaLibraryEditor/mediaLibraryEditor.template.html b/src/components/mediaLibraryEditor/mediaLibraryEditor.template.html index ae7d65e1e5..1f2581612d 100644 --- a/src/components/mediaLibraryEditor/mediaLibraryEditor.template.html +++ b/src/components/mediaLibraryEditor/mediaLibraryEditor.template.html @@ -18,7 +18,7 @@
    -

    ${HeadersFolders}

    +

    ${Folders}

    diff --git a/src/components/multiSelect/multiSelect.js b/src/components/multiSelect/multiSelect.js index d922aee84a..fdce40ab86 100644 --- a/src/components/multiSelect/multiSelect.js +++ b/src/components/multiSelect/multiSelect.js @@ -198,7 +198,7 @@ import 'css!./multiSelect'; if (user.Policy.EnableContentDownloading && appHost.supports('filedownload')) { menuItems.push({ - name: globalize.translate('ButtonDownload'), + name: globalize.translate('Download'), id: 'download', icon: 'file_download' }); diff --git a/src/controllers/dashboard/devices/devices.html b/src/controllers/dashboard/devices/devices.html index 55f51d7e23..63c348c900 100644 --- a/src/controllers/dashboard/devices/devices.html +++ b/src/controllers/dashboard/devices/devices.html @@ -3,7 +3,7 @@
    -

    ${TabDevices}

    +

    ${HeaderDevices}

    ${Help}
    diff --git a/src/controllers/dashboard/users/userlibraryaccess.js b/src/controllers/dashboard/users/userlibraryaccess.js index d32c7312b7..146777a0db 100644 --- a/src/controllers/dashboard/users/userlibraryaccess.js +++ b/src/controllers/dashboard/users/userlibraryaccess.js @@ -32,7 +32,7 @@ import globalize from 'globalize'; function loadChannels(page, user, channels) { let html = ''; - html += '

    ' + globalize.translate('HeaderChannels') + '

    '; + html += '

    ' + globalize.translate('Channels') + '

    '; html += '
    '; for (let i = 0, length = channels.length; i < length; i++) { diff --git a/src/controllers/dashboard/users/usernew.js b/src/controllers/dashboard/users/usernew.js index d3ff449d02..68b6365c02 100644 --- a/src/controllers/dashboard/users/usernew.js +++ b/src/controllers/dashboard/users/usernew.js @@ -22,7 +22,7 @@ import 'emby-checkbox'; function loadChannels(page, channels) { let html = ''; - html += '

    ' + globalize.translate('HeaderChannels') + '

    '; + html += '

    ' + globalize.translate('Channels') + '

    '; html += '
    '; for (let i = 0; i < channels.length; i++) { diff --git a/src/controllers/itemDetails/index.html b/src/controllers/itemDetails/index.html index 9aff1efa14..8c16daba99 100644 --- a/src/controllers/itemDetails/index.html +++ b/src/controllers/itemDetails/index.html @@ -24,7 +24,7 @@
    -
    diff --git a/src/scripts/itembynamedetailpage.js b/src/scripts/itembynamedetailpage.js index 306282b5fd..60be838448 100644 --- a/src/scripts/itembynamedetailpage.js +++ b/src/scripts/itembynamedetailpage.js @@ -25,7 +25,7 @@ function renderItems(page, item) { if (item.MovieCount) { sections.push({ - name: globalize.translate('TabMovies'), + name: globalize.translate('Movies'), type: 'Movie' }); } diff --git a/src/scripts/libraryMenu.js b/src/scripts/libraryMenu.js index 29d859740a..5ee485e815 100644 --- a/src/scripts/libraryMenu.js +++ b/src/scripts/libraryMenu.js @@ -395,10 +395,10 @@ import 'flexStyles'; addPluginPagesToMainMenu(links, pluginItems, 'server'); links.push({ divider: true, - name: globalize.translate('TabDevices') + name: globalize.translate('HeaderDevices') }); links.push({ - name: globalize.translate('TabDevices'), + name: globalize.translate('HeaderDevices'), href: 'devices.html', pageIds: ['devicesPage', 'devicePage'], icon: 'devices' @@ -426,7 +426,7 @@ import 'flexStyles'; icon: 'live_tv' }); links.push({ - name: globalize.translate('TabDVR'), + name: globalize.translate('HeaderDVR'), href: 'livetvsettings.html', pageIds: ['liveTvSettingsPage'], icon: 'dvr' From e21397b38b137921c567d2e9173f8b94d393c67d Mon Sep 17 00:00:00 2001 From: dkanada Date: Thu, 13 Aug 2020 21:43:25 +0900 Subject: [PATCH 190/301] remove unused translations --- src/strings/af.json | 9 --------- src/strings/ar.json | 33 --------------------------------- src/strings/be-by.json | 3 --- src/strings/bg-bg.json | 35 ----------------------------------- src/strings/ca.json | 30 ------------------------------ src/strings/cs.json | 35 ----------------------------------- src/strings/da.json | 34 ---------------------------------- src/strings/de.json | 35 ----------------------------------- src/strings/el.json | 34 ---------------------------------- src/strings/en-gb.json | 35 ----------------------------------- src/strings/en-us.json | 35 ----------------------------------- src/strings/es-ar.json | 35 ----------------------------------- src/strings/es-mx.json | 35 ----------------------------------- src/strings/es.json | 35 ----------------------------------- src/strings/es_419.json | 35 ----------------------------------- src/strings/fa.json | 35 ----------------------------------- src/strings/fi.json | 34 ---------------------------------- src/strings/fr-ca.json | 14 -------------- src/strings/fr.json | 35 ----------------------------------- src/strings/gsw.json | 9 --------- src/strings/he.json | 33 --------------------------------- src/strings/hi-in.json | 11 ----------- src/strings/hr.json | 34 ---------------------------------- src/strings/hu.json | 35 ----------------------------------- src/strings/id.json | 14 -------------- src/strings/is-is.json | 22 ---------------------- src/strings/it.json | 35 ----------------------------------- src/strings/ja.json | 34 ---------------------------------- src/strings/kk.json | 34 ---------------------------------- src/strings/ko.json | 34 ---------------------------------- src/strings/lt-lt.json | 32 -------------------------------- src/strings/lv.json | 33 --------------------------------- src/strings/mr.json | 10 ---------- src/strings/ms.json | 10 ---------- src/strings/nb.json | 35 ----------------------------------- src/strings/nl.json | 35 ----------------------------------- src/strings/pl.json | 35 ----------------------------------- src/strings/pt-br.json | 35 ----------------------------------- src/strings/pt-pt.json | 34 ---------------------------------- src/strings/pt.json | 34 ---------------------------------- src/strings/ro.json | 35 ----------------------------------- src/strings/ru.json | 35 ----------------------------------- src/strings/sk.json | 35 ----------------------------------- src/strings/sl-si.json | 36 +----------------------------------- src/strings/sr.json | 12 ------------ src/strings/sv.json | 35 ----------------------------------- src/strings/tr.json | 30 ------------------------------ src/strings/uk.json | 19 ------------------- src/strings/vi.json | 26 -------------------------- src/strings/zh-cn.json | 35 ----------------------------------- src/strings/zh-hk.json | 27 --------------------------- src/strings/zh-tw.json | 35 ----------------------------------- 52 files changed, 1 insertion(+), 1523 deletions(-) diff --git a/src/strings/af.json b/src/strings/af.json index 8e34e87d60..53b658836e 100644 --- a/src/strings/af.json +++ b/src/strings/af.json @@ -2,7 +2,6 @@ "Auto": "Outo", "AuthProviderHelp": "Kies 'n Authentication Provider vir die egtheid van gebruiker se wagwoord.", "Audio": "Klank", - "AttributeNew": "Nuwe", "AspectRatio": "Aspek verhouding", "Ascending": "Boontoe", "AsManyAsPossible": "So veel moontlik", @@ -43,16 +42,11 @@ "AlbumArtist": "Album Kunstenaar", "TabLatest": "Nuutste", "TabInfo": "Inligting", - "TabGuide": "Gids", - "TabGenres": "Genres", - "TabFavorites": "Gunstellinge", "TabEpisodes": "Episodes", "TabDirectPlay": "Speel Direk", - "TabDevices": "Toestelle", "TabDashboard": "Paneelbord", "TabContainers": "Houers", "Collections": "Versamelings", - "TabCollections": "Versamelings", "UnsupportedPlayback": "Jellyfin kan nie inhoud wat beskerm word deur DRM ontsuifer nie, maar daar sal 'n poging aangwend word inelkgeval, insluitend beskermde titels. Sommige leêrs mag geheel en al swart verksyn weens enkripsie of ander on-ondersteunde funksies, byvoorbeeld interaktiewe titels.", "OnApplicationStartup": "Op applikasie begin", "EveryXHours": "Elke {0} ure", @@ -132,8 +126,6 @@ "TabUpcoming": "Komende", "TabTrailers": "Voorprente", "TabStreaming": "Stroom", - "TabSongs": "Liedjies", - "TabShows": "Programme", "TabSettings": "Instellings", "TabServer": "Bediener", "TabSeries": "Reekse", @@ -153,7 +145,6 @@ "TabNetworks": "Netwerke", "TabMusicVideos": "Musiek Videos", "TabMusic": "Musiek", - "TabMovies": "Rolprente", "TabLogs": "Logs", "TabLiveTV": "Lewendige TV" } diff --git a/src/strings/ar.json b/src/strings/ar.json index 862c985c85..24020ed834 100644 --- a/src/strings/ar.json +++ b/src/strings/ar.json @@ -15,19 +15,12 @@ "ButtonAddScheduledTaskTrigger": "إضافة زناد", "ButtonAddServer": "إضافة خادم", "ButtonAddUser": "اضافة مستخدم", - "ButtonArrowDown": "أسفل", "ButtonArrowLeft": "يسار", "ButtonArrowRight": "يمين", - "ButtonArrowUp": "أعلى", "ButtonAudioTracks": "المقاطع الصوتية", "ButtonBack": "خلف", "ButtonCancel": "الغاء", "ButtonChangeServer": "غير الخادم", - "ButtonConnect": "اتصل", - "ButtonDelete": "حذف", - "ButtonDeleteImage": "حذف الصورة", - "ButtonDown": "أسفل", - "ButtonDownload": "إنزال", "ButtonEdit": "تعديل", "ButtonEditImages": "تعديل الصور", "ButtonEditOtherUserPreferences": "اضبط إعدادات حساب المستخدم هذا، وصورته وتفضيلاته الشخصية.", @@ -41,7 +34,6 @@ "ButtonManualLogin": "الدخول اليدوي", "ButtonMore": "المزيد", "ButtonNetwork": "الشبكة", - "ButtonNew": "جديد", "ButtonNextTrack": "المقطوعة التالية", "ButtonOff": "إيقاف التشغيل", "ButtonOk": "موافق", @@ -66,18 +58,15 @@ "ButtonSelectView": "إختر طريقة عرض", "ButtonSend": "إرسال", "ButtonSettings": "الإعدادات", - "ButtonShuffle": "إخلط", "ButtonShutdown": "إنهاء التشغيل", "ButtonSignIn": "تسجيل الدخول", "ButtonSignOut": "تسجيل الخروج", - "ButtonSort": "ترتيب", "ButtonStart": "إبدأ", "ButtonStop": "إيقاف", "ButtonSubmit": "تسليم", "ButtonSubtitles": "ترجمات", "ButtonTrailer": "العرض الإعلاني", "ButtonUninstall": "إزالة التثبيت", - "ButtonUp": "أعلى", "ButtonWebsite": "موقع إلكتروني", "ChannelAccessHelp": "إختر قناة لمشاركتها مع هذا المستخدم. المدراء سيكونون قادرين على تغيير إعدادات القنوات باستخدام مدير واصفات البيانات.", "Channels": "القنوات", @@ -135,7 +124,6 @@ "HeaderAddUser": "إضافة مستخدم", "HeaderAdditionalParts": "أدوار إضافية", "HeaderAdmin": "المدير", - "HeaderAlbums": "الألبومات", "HeaderAlert": "تنبيه", "HeaderAllowMediaDeletionFrom": "السماح بحذف الوسائط من قبل", "HeaderApiKey": "مفتاح API", @@ -148,7 +136,6 @@ "HeaderCastAndCrew": "الممثلين وطاقم العمل", "HeaderCastCrew": "الممثلين والطاقم", "HeaderChannelAccess": "صلاحيات القنوات", - "HeaderChannels": "القنوات", "HeaderCodecProfile": "عريضة الكودك", "HeaderCodecProfileHelp": "عرائض الكودك تشير إلى محدودية جهاز ما عند تشغيل وسيطة مشفر بكودك معيّن. إن كان هناك أي محدودية مذكورة فستحال الوسيطة إلى التشغير البيني، حتى لو كانت الصيغة مضبوطة للعمل بتلقائية.", "HeaderConfirmPluginInstallation": "أكد عملية تثبيت الملحق", @@ -179,7 +166,6 @@ "HeaderForKids": "للأطفال", "HeaderForgotPassword": "نسيت كلمة السر", "HeaderFrequentlyPlayed": "تم تشغيله مراراً", - "HeaderGenres": "أنواع الأفلام", "HeaderGuideProviders": "مزودو الأدلة", "HeaderHttpHeaders": "رؤوس HTTP", "HeaderIdentification": "التعريفة", @@ -189,7 +175,6 @@ "HeaderImageSettings": "إعدادات الصورة", "HeaderInstall": "تثبيت", "HeaderInstantMix": "مزيج فوري", - "HeaderItems": "العناصر", "HeaderLatestEpisodes": "احدث الحلقات", "HeaderLatestMedia": "آحدث الوسائط", "HeaderLatestMovies": "أحدث الأفلام", @@ -205,7 +190,6 @@ "HeaderMediaFolders": "مجلدات الوسائط", "HeaderMediaInfo": "معلومات الوسيطة", "HeaderMoreLikeThis": "المزيد من الروابط لهذا", - "HeaderMovies": "الأفلام", "HeaderMusicVideos": "الفيديوهات الموسيقية", "HeaderMyMedia": "وسائطي", "HeaderNewApiKey": "مفتاح API جديد", @@ -252,7 +236,6 @@ "HeaderServerSettings": "إعدادات الخادم", "HeaderSettings": "الإعدادات", "HeaderSetupLibrary": "ضبط مكتبة المحتوى الخاصة بك", - "HeaderShutdown": "إنهاء التشغيل", "HeaderSortBy": "ترتيب حسب", "HeaderSortOrder": "تسلسل الترتيب", "HeaderSpecialEpisodeInfo": "معلومات الحلقة الخاصة", @@ -281,7 +264,6 @@ "HeaderXmlDocumentAttributes": "سمات مستند xml", "HeaderXmlSettings": "إعدادات xml", "HeaderYears": "السنوات", - "HeadersFolders": "مجلدات", "ImportFavoriteChannelsHelp": "فقط القنوات التي علّمت في المفضلة على جهاز المولف ستورد.", "ImportMissingEpisodesHelp": "المعلومات الناقصة للحلقات ستورّد إلى قاعدة بياناتك وستعرض داخل المواسم والمسلسلات. قد تتسبب هذه بأوقات أطول بكثير عند تمشيط المكتبات.", "LabelAbortedByServerShutdown": "(تم إهماله بسبب عملية إغلاق الخادم)", @@ -446,7 +428,6 @@ "LabelNewPassword": "كلمة السر الجديدة:", "LabelNewPasswordConfirm": "تأكيد كلمة السر الجديدة:", "LabelNewsCategories": "التصنيفات الأخبارية:", - "LabelNext": "التالي", "LabelNotificationEnabled": "تفعيل هذه الإشعارات", "LabelNumberOfGuideDays": "عدد أيام بيانات الدليل للإنزال:", "LabelNumberOfGuideDaysHelp": "إنزال أيام أكثر من بيانات الدليل ستوفر أمكانية جدولة أيام أبعد وإظهار قوائم أطول للبرامج، لكنها ستأخذ وقتاً أطول للإنزال. االخيار الآلي سوف يتخيّر بناء على عدد القنوات المتاحة.", @@ -462,7 +443,6 @@ "LabelPostProcessorArgumentsHelp": "استخدم المسار: {path} كمسار لملف التسجيل.", "LabelPreferredDisplayLanguage": "لغة الواجهة المفضلة:", "LabelPreferredDisplayLanguageHelp": "إن ترجمة أمبي هو مشروع جاري التنفيذ.", - "LabelPrevious": "السابق", "LabelProfileAudioCodecs": "كودك تشفير الصوت", "LabelProfileCodecs": "الكودكات:", "LabelProfileCodecsHelp": "يجب فصل العناصر بفواصل (,). يمكن أن تترك هذه فارغة إذا أريد تطبيقها على كل الكودكات.", @@ -476,7 +456,6 @@ "LabelPublicHttpPortHelp": "رقم المنفذ العالمي الذي يجب أن يوافق منفذ http المحلي.", "LabelPublicHttpsPort": "رقم منفذ https العالمي:", "LabelPublicHttpsPortHelp": "رقم المنفذ العالمي الذي يجب أن يوافق منفذ https المحلي.", - "LabelReadHowYouCanContribute": "تعرّف على كيفية المساهمة فيه.", "LabelRecordingPath": "المسار الافتراضي للمقاطع المسجلة:", "LabelRecordingPathHelp": "حدد موقع افتراضي لحفظ المقاطع المسجلة، لو تركت هذه الخانة فارغة، فسيستعمل مجلد بيانات البرنامج.", "LabelReleaseDate": "تاريخ الإصدار", @@ -785,24 +764,16 @@ "TabAccess": "الدخول", "TabAdvanced": "متقدم", "TabAlbumArtists": "فنانو الألبومات", - "TabAlbums": "الألبومات", "TabCatalog": "الكتالوج", - "TabChannels": "القنوات", "TabCodecs": "الكودكات", - "TabCollections": "المجاميع", "TabContainers": "الحاويات", "TabDashboard": "لوحة العدادات", - "TabDevices": "الأجهزة", "TabDirectPlay": "تشغيل مباشر", "TabEpisodes": "الحلقات", - "TabFavorites": "المفضلة", - "TabGenres": "أنواع الأفلام", - "TabGuide": "الدليل", "TabInfo": "معلومات", "TabLatest": "الاخير", "TabLiveTV": "التلفاز المباشر", "TabLogs": "الكشوفات", - "TabMovies": "الفيلم", "TabMusic": "الموسيقى", "TabMusicVideos": "الفيديوهات الموسيقية", "TabMyPlugins": "ملحقاتي", @@ -823,8 +794,6 @@ "TabSeries": "المسلسلات", "TabServer": "الخادم", "TabSettings": "الإعدادات", - "TabShows": "المسلسلات", - "TabSongs": "الاغانى", "TabStreaming": "التشغيل التدفقي", "TabTrailers": "العروض الإعلانية", "TabUpcoming": "القادم", @@ -916,7 +885,6 @@ "Auto": "تلقائي", "AuthProviderHelp": "اختار مقدم المصادقة ليتم استخدامه لمصادقة كلمة مرور هذا المستخدم.", "AroundTime": "حول", - "AttributeNew": "جديد", "AspectRatio": "نسبة العرض الى الارتفاع", "Ascending": "تصاعدي", "AsManyAsPossible": "أكبر عدد ممكن", @@ -1108,7 +1076,6 @@ "EnableColorCodedBackgrounds": "تصنيف الخلفيات حسب اللون", "EnableCinemaMode": "وضع السينما", "EnableBackdropsHelp": "اعرض الخلفيات في خلفية بعض الصفحات أثناء تصفح المكتبة.", - "EnableBackdrops": "الخلفيات", "DownloadsValue": "عدد التنزيلات {0}", "Download": "تحميل", "Down": "أسفل", diff --git a/src/strings/be-by.json b/src/strings/be-by.json index e8726bf216..8bd6d2aa31 100644 --- a/src/strings/be-by.json +++ b/src/strings/be-by.json @@ -1,6 +1,5 @@ { "ButtonCancel": "Адмяніць", - "ButtonNew": "Новае", "ButtonOk": "ОК", "ButtonQuickStartGuide": "Кіраўніцтва па запуску", "ButtonSignOut": "Sign out", @@ -9,8 +8,6 @@ "HeaderPaths": "Шляхі", "HeaderTaskTriggers": "Трыгеры задачы", "LabelFinish": "Гатова", - "LabelNext": "Наступнае", - "LabelPrevious": "Папярэдняе", "LabelYoureDone": "Вы скончылі!", "MoreUsersCanBeAddedLater": "Потым можна дадаць яшчэ карыстальнікаў праз «Інфапанэль».", "TellUsAboutYourself": "Раскажыце пра сябе", diff --git a/src/strings/bg-bg.json b/src/strings/bg-bg.json index 20337a876a..4ab46a6eab 100644 --- a/src/strings/bg-bg.json +++ b/src/strings/bg-bg.json @@ -11,7 +11,6 @@ "AllLibraries": "Всички библиотеки", "Art": "Картина", "Artists": "Артисти", - "AttributeNew": "Нови", "Audio": "Звук", "Auto": "Автоматично", "Backdrop": "Фон", @@ -24,16 +23,11 @@ "ButtonAddScheduledTaskTrigger": "Добавяне на спусък", "ButtonAddServer": "Добавяне на сървър", "ButtonAddUser": "Добавяне на потребител", - "ButtonArrowDown": "Надолу", "ButtonArrowLeft": "Наляво", "ButtonArrowRight": "Надясно", - "ButtonArrowUp": "Нагоре", "ButtonAudioTracks": "Звукови пътеки", "ButtonBack": "Назад", "ButtonCancel": "Отмяна", - "ButtonDelete": "Изтриване", - "ButtonDeleteImage": "Изтриване на изобр.", - "ButtonDownload": "Изтегляне", "ButtonEdit": "Редактиране", "ButtonEditImages": "Редактиране на изображенията", "ButtonFilter": "Филтър", @@ -45,7 +39,6 @@ "ButtonLibraryAccess": "Достъп до библиотеката", "ButtonManualLogin": "Вход с име и парола", "ButtonMore": "Още", - "ButtonNew": "Нов", "ButtonNextTrack": "Следваща пътека", "ButtonOff": "Изключено", "ButtonOk": "Добре", @@ -67,11 +60,9 @@ "ButtonSelectDirectory": "Изберете папка", "ButtonSend": "Изпращане", "ButtonSettings": "Настройки", - "ButtonShuffle": "Пускане в разбъркан ред", "ButtonShutdown": "Загасяне", "ButtonSignIn": "Вписване", "ButtonSignOut": "Отписване", - "ButtonSort": "Подреждане", "ButtonStop": "Спиране", "ButtonSubmit": "Подаване", "ButtonSubtitles": "Субтитри", @@ -106,7 +97,6 @@ "EditImages": "Редактиране на изображенията", "EditMetadata": "Редактиране на метаданните", "EditSubtitles": "Редактиране на субтитрите", - "EnableBackdrops": "Фонове", "EnableCinemaMode": "Режим \"Киносалон\"", "EnableThemeSongs": "Тематични песни", "Ended": "Приключило", @@ -148,7 +138,6 @@ "HeaderAdditionalParts": "Допълнителни части", "HeaderAdmin": "Администриране", "HeaderAlbumArtists": "Изпълнители на албуми", - "HeaderAlbums": "Албуми", "HeaderApiKey": "ППИ ключ", "HeaderApiKeys": "ППИ ключове", "HeaderApp": "Програма", @@ -156,7 +145,6 @@ "HeaderBooks": "Книги", "HeaderCastAndCrew": "Артисти и изпълнители", "HeaderCastCrew": "Артисти и изпълнители", - "HeaderChannels": "Канали", "HeaderCodecProfile": "Профил на кодека", "HeaderContainerProfile": "Профил на контейнера", "HeaderContinueListening": "Продължаване на слушането", @@ -177,7 +165,6 @@ "HeaderForKids": "Детски", "HeaderForgotPassword": "Забравена парола", "HeaderFrequentlyPlayed": "Често пускани", - "HeaderGenres": "Жанрове", "HeaderGuideProviders": "Доставчици на справочници", "HeaderIdentification": "Идентификация", "HeaderImageSettings": "Настройки на картината", @@ -200,7 +187,6 @@ "HeaderMediaInfo": "Сведения", "HeaderMetadataSettings": "Настройки на метаданните", "HeaderMoreLikeThis": "Подобни", - "HeaderMovies": "Филми", "HeaderMusicQuality": "Качество на музиката", "HeaderMusicVideos": "Музикални клипове", "HeaderMyDevice": "Моето устройство", @@ -256,7 +242,6 @@ "HeaderVideoQuality": "Качество на видеото", "HeaderVideos": "Видеоклипове", "HeaderYears": "Години", - "HeadersFolders": "Папки", "Help": "Помощ", "Hide": "Скриване", "HideWatchedContentFromLatestMedia": "Скриване на гледаното съдържание от последната медия", @@ -367,7 +352,6 @@ "LabelNewName": "Ново име:", "LabelNewPassword": "Нова парола:", "LabelNewPasswordConfirm": "Нова парола (отново):", - "LabelNext": "Следващ", "LabelNumberOfGuideDays": "Брой дни за които да се свали програма:", "LabelNumberOfGuideDaysHelp": "Изтеглянето на програма заповече дни дава възможност да планирате по-нататъшните записи предварително, но и отнема повече време, за да се изтегли. Автомат ще избере въз основа на броя на каналите.", "LabelOptionalNetworkPath": "Споделена мрежова папка (незадължително):", @@ -385,7 +369,6 @@ "LabelPreferredDisplayLanguage": "Предпочитан език на показване:", "LabelPreferredDisplayLanguageHelp": "Превеждането на Емби е текущ проект.", "LabelPreferredSubtitleLanguage": "Предпочитан език на субтитрите:", - "LabelPrevious": "Предишен", "LabelProfileAudioCodecs": "Звукови кодеци:", "LabelProfileCodecs": "Кодеци:", "LabelProfileCodecsHelp": "Разделени със запетая. Може да бъде оставено празно, за да се отнася за всички кодеци.", @@ -397,7 +380,6 @@ "LabelPublicHttpPortHelp": "Публичният порт, който да бъде съпоставен с локалния HTTP порт.", "LabelPublicHttpsPort": "Публичен HTTPS порт:", "LabelPublicHttpsPortHelp": "Публичният порт, който да бъде съпоставен с локалния HTTPS порт.", - "LabelReadHowYouCanContribute": "Научете как можете да допринесете.", "LabelRecordingPath": "Път за запис по подразбиране:", "LabelReleaseDate": "Дата на издаване:", "LabelRemoteClientBitrateLimit": "Ограничение на интернетното излъчване (мбит/сек):", @@ -494,7 +476,6 @@ "News": "Новини", "MessageNoNextUpItems": "Нищо не е намерено. Започнете да гледате вашите предавания!", "NoSubtitleSearchResultsFound": "Няма намерени резултати.", - "NoSubtitles": "Без", "None": "Нищо", "Normal": "Нормален", "NumLocationsValue": "{0} папки", @@ -668,24 +649,16 @@ "TabAccess": "Достъп", "TabAdvanced": "Допълнителни", "TabAlbumArtists": "Изпълнители на албуми", - "TabAlbums": "Албуми", "TabCatalog": "Каталог", - "TabChannels": "Канали", "TabCodecs": "Кодеци", - "TabCollections": "Колекции", "TabContainers": "Контейнери", "TabDashboard": "Табло", - "TabDevices": "Устройства", "TabDirectPlay": "Директно пускане", "TabEpisodes": "Епизоди", - "TabFavorites": "Любими", - "TabGenres": "Жанрове", - "TabGuide": "Ръководство", "TabInfo": "Информация", "TabLatest": "Последни", "TabLiveTV": "Телевизия на живо", "TabLogs": "Журнали", - "TabMovies": "Филми", "TabMusic": "Музика", "TabMusicVideos": "Музикални клипове", "TabMyPlugins": "Моите приставки", @@ -706,8 +679,6 @@ "TabSeries": "Сериали", "TabServer": "Сървър", "TabSettings": "Настройки", - "TabShows": "Предавания", - "TabSongs": "Песни", "TabStreaming": "Излъчване", "TabTrailers": "Трейлъри", "TabUpcoming": "Предстоящи", @@ -794,15 +765,12 @@ "ReplaceExistingImages": "Заменяне на текущите изображения", "Channels": "Канали", "Categories": "Категории", - "ButtonUp": "Нагоре", "ButtonTrailer": "Предварителен откъс", "ButtonStart": "Пускане", "ButtonSelectView": "Изберете изглед", "ButtonSelectServer": "Изберете сървър", "ButtonNetwork": "Мрежа", "ButtonFullscreen": "На цял екран", - "ButtonDown": "Надолу", - "ButtonConnect": "Свързване", "AllowOnTheFlySubtitleExtraction": "Позволява моментално извличане на поднадписи", "AllowHWTranscodingHelp": "Позволява на тунера да прекодира моментално. Това може да помогне за редуциране на прекодирането от сървъра.", "Absolute": "Aбсолютен", @@ -987,7 +955,6 @@ "HeaderSubtitleDownloads": "Сваляне на субтитри", "HeaderStopRecording": "Спри запис", "HeaderSpecialEpisodeInfo": "Информация за специалните епизоди", - "HeaderShutdown": "Изключване", "HeaderServerAddressSettings": "Настройки за адреса на сървъра", "HeaderSeriesStatus": "Състояние на сериала", "HeaderSeriesOptions": "Настройки на сериала", @@ -1017,7 +984,6 @@ "HeaderKodiMetadataHelp": "За да включиш или изключиш използването на NFO метаданните влез в настройките за библиотеки на сървъра и намери секцията за съхранение.", "HeaderKeepSeries": "Запази сериалите", "HeaderKeepRecording": "Запази записите", - "HeaderItems": "Елементи", "HeaderImageOptions": "Настройки на картини", "HeaderIdentifyItemHelp": "Въведете един или повече критерии за търсене.Премахнете ,ако искате да увеличите резултатите при търсенето.", "HeaderIdentificationHeader": "Идентификационен хедър", @@ -1207,7 +1173,6 @@ "TitleHostingSettings": "Настройки за хостинг", "TitleHardwareAcceleration": "Хардуерно ускорение", "TabNetworking": "Работа в мрежа", - "TabDVR": "ДВР", "SystemDlnaProfilesHelp": "Системните профили са с достъп \"само за четене\".При промяна в системния профил ще бъде създаден нов персонализиран профил.", "SyncPlayAccessHelp": "Избери нивото на достъп ,който този потребител ще има за услугата \"Синхронизирано възпроизвеждане\".С нейна помощ може да синхронизирате възпроизвеждането с други устройства.", "SubtitleOffset": "Изместване на субтитрите", diff --git a/src/strings/ca.json b/src/strings/ca.json index 4033ba56c4..c5f7f2d6de 100644 --- a/src/strings/ca.json +++ b/src/strings/ca.json @@ -12,23 +12,17 @@ "Artists": "Artistes", "AsManyAsPossible": "Tants com sigui possible", "AspectRatio": "Relació d'aspecte", - "AttributeNew": "Nou", "Audio": "Àudio", "MessageBrowsePluginCatalog": "Consulta el nostre catàleg per veure els complements disponibles.", "ButtonAddMediaLibrary": "Afegir Biblioteca Multimèdia", "ButtonAddScheduledTaskTrigger": "Afegir Disparador", "ButtonAddServer": "Afegeix Servidor", "ButtonAddUser": "Afegir Usuari", - "ButtonArrowDown": "Avall", "ButtonArrowLeft": "Esquerra", "ButtonArrowRight": "Dreta", - "ButtonArrowUp": "Amunt", "ButtonBack": "Darrera", "ButtonCancel": "Cancel·la", "ButtonChangeServer": "Canvia Servidor", - "ButtonDelete": "Esborra", - "ButtonDeleteImage": "Esborra Imatge", - "ButtonDownload": "Descarrega", "ButtonEdit": "Edita", "ButtonEditImages": "Edita les imatges", "ButtonEditOtherUserPreferences": "Edita el perfil, la imatge i les preferències d'aquest usuari.", @@ -40,7 +34,6 @@ "ButtonLibraryAccess": "Accés a la biblioteca", "ButtonManualLogin": "Inici de sessió manual", "ButtonMore": "Més", - "ButtonNew": "Nou", "ButtonNextTrack": "Pista següent", "ButtonOk": "D'acord", "ButtonOpen": "Obre", @@ -61,11 +54,9 @@ "ButtonSelectServer": "Seleccionar servidor", "ButtonSend": "Envia", "ButtonSettings": "Preferències", - "ButtonShuffle": "Aleatori", "ButtonShutdown": "Atura", "ButtonSignIn": "Inicia Sessió", "ButtonSignOut": "Tanca sessió", - "ButtonSort": "Ordena", "ButtonStop": "Atura", "ButtonSubmit": "Envia", "ButtonSubtitles": "Subtítols", @@ -138,7 +129,6 @@ "HeaderCancelSeries": "Cancel·lar Sèries", "HeaderCastAndCrew": "Repartiment i Equip", "HeaderCastCrew": "Repartiment i Equip", - "HeaderChannels": "Canals", "HeaderCodecProfile": "Perfil de Còdec", "HeaderConfirmProfileDeletion": "Confirmar Supressió de Perfil", "HeaderConnectToServer": "Connectar al Servidor", @@ -163,7 +153,6 @@ "HeaderFetchImages": "Obtingues Imatges:", "HeaderForgotPassword": "He oblidat la contrasenya", "HeaderFrequentlyPlayed": "Reproduït Freqüentment", - "HeaderGenres": "Gèneres", "HeaderHttpHeaders": "Capçaleres Http", "HeaderIdentification": "Identificació", "HeaderIdentificationCriteriaHelp": "Insereix al menys un criteri d'identificació.", @@ -188,7 +177,6 @@ "HeaderMediaFolders": "Directoris Multimèdia", "HeaderMediaInfo": "Info Multimèdia", "HeaderMetadataSettings": "Preferències de Metadades", - "HeaderMovies": "Pel·lícules", "HeaderMusicVideos": "Vídeos Musicals", "HeaderMyDevice": "El meu dispositiu", "HeaderMyMedia": "Els meus mitjans", @@ -245,7 +233,6 @@ "HeaderXmlDocumentAttributes": "Atributs de Documents XML", "HeaderXmlSettings": "Preferències Xml", "HeaderYears": "Anys", - "HeadersFolders": "Directoris", "Help": "Ajuda", "Hide": "Amaga", "Identify": "Identifica", @@ -358,7 +345,6 @@ "LabelNewName": "Nou nom:", "LabelNewPassword": "Nova contrasenya:", "LabelNewPasswordConfirm": "Confirma la nova contrasenya:", - "LabelNext": "Següent", "LabelNotificationEnabled": "Habilita aquesta notificació", "LabelNumber": "Nombre:", "LabelNumberOfGuideDays": "Nombre de dies de dades de la guia per a descarregar:", @@ -376,7 +362,6 @@ "LabelPreferredDisplayLanguage": "Idioma de visualització preferit:", "LabelPreferredDisplayLanguageHelp": "La traducció d'Jellyfin és un projecte en curs.", "LabelPreferredSubtitleLanguage": "Idioma preferit de subtítols:", - "LabelPrevious": "Anterior", "LabelProfileAudioCodecs": "Còdecs d'àudio:", "LabelProfileCodecs": "Còdecs:", "LabelProfileContainer": "Contenidor:", @@ -384,7 +369,6 @@ "LabelProtocolInfo": "Informació del protocol:", "LabelPublicHttpPort": "Número públic del port http:", "LabelPublicHttpsPort": "Número públic del port https:", - "LabelReadHowYouCanContribute": "Aprèn com pots contribuir.", "LabelRecord": "Enregistra:", "LabelRecordingPath": "Directori de gravació per defecte:", "LabelRefreshMode": "Mode de refresc:", @@ -477,7 +461,6 @@ "MessageNoNextUpItems": "Cap trobat. Comença a mirar els teus programes!", "MessageNoPluginConfiguration": "Aquest complement no té opcions de configuració.", "NoSubtitleSearchResultsFound": "No s'han trobat resultats.", - "NoSubtitles": "Sense subtítols", "None": "Cap", "NumLocationsValue": "{0} directoris", "OnlyForcedSubtitles": "Només subtítols forçats", @@ -633,23 +616,15 @@ "Sync": "Sincronitzar", "TabAccess": "Accés", "TabAdvanced": "Avançat", - "TabAlbums": "Àlbums", "TabCatalog": "Catàleg", - "TabChannels": "Canals", "TabCodecs": "Còdecs", - "TabCollections": "Col·leccions", "TabContainers": "Contenidors", "TabDashboard": "Tauler de Control", - "TabDevices": "Dispositius", "TabDirectPlay": "Reproducció Directa", "TabEpisodes": "Episodis", - "TabFavorites": "Preferits", - "TabGenres": "Gèneres", - "TabGuide": "Guia", "TabInfo": "Informació", "TabLatest": "Novetats", "TabLiveTV": "TV en Directe", - "TabMovies": "Pel·lícules", "TabMusic": "Música", "TabMusicVideos": "Vídeos musicals", "TabMyPlugins": "Els meus complements", @@ -669,8 +644,6 @@ "TabSeries": "Sèries", "TabServer": "Servidor", "TabSettings": "Preferències", - "TabShows": "Programes", - "TabSongs": "Cançons", "TabTrailers": "Tràilers", "TabUpcoming": "Properament", "TabUsers": "Usuaris", @@ -722,7 +695,6 @@ "ChannelNumber": "Número de canal", "Categories": "Categories", "ButtonWebsite": "Lloc web", - "ButtonUp": "Amunt", "ButtonUninstall": "Desinstal·lar", "ButtonSplit": "Dividir", "ButtonStart": "Començar", @@ -733,8 +705,6 @@ "ButtonNetwork": "Xarxa", "ButtonInfo": "Informació", "ButtonFullscreen": "Pantalla completa", - "ButtonDown": "A baix", - "ButtonConnect": "Connectar", "ButtonAudioTracks": "Pistes d'àudio", "ButtonAddImage": "Afegir imatge", "Blacklist": "Llista negra", diff --git a/src/strings/cs.json b/src/strings/cs.json index 85d4b175f2..daa4573874 100644 --- a/src/strings/cs.json +++ b/src/strings/cs.json @@ -21,7 +21,6 @@ "Artists": "Umělci", "AsManyAsPossible": "Tolikrát jak je možné", "AspectRatio": "Poměr stran", - "AttributeNew": "Nové", "Audio": "Zvuk", "Auto": "Automaticky", "Backdrop": "Pozadí", @@ -38,19 +37,12 @@ "ButtonAddScheduledTaskTrigger": "Přidat Spouštěč", "ButtonAddServer": "Přidat server", "ButtonAddUser": "Přidat uživatele", - "ButtonArrowDown": "Dolů", "ButtonArrowLeft": "Vlevo", "ButtonArrowRight": "Vpravo", - "ButtonArrowUp": "Nahoru", "ButtonAudioTracks": "Audio stopy", "ButtonBack": "Zpět", "ButtonCancel": "Zrušit", "ButtonChangeServer": "Změna serveru", - "ButtonConnect": "Připojit", - "ButtonDelete": "Odstranit", - "ButtonDeleteImage": "Odstranit obrázek", - "ButtonDown": "Zeslabit", - "ButtonDownload": "Stáhnout", "ButtonEdit": "Upravit", "ButtonEditImages": "Editovat obrázky", "ButtonEditOtherUserPreferences": "Editace uživatelského profilu, avataru a osobních preferencí.", @@ -64,7 +56,6 @@ "ButtonManualLogin": "Manuální přihlášení", "ButtonMore": "Více", "ButtonNetwork": "Síť", - "ButtonNew": "Nové", "ButtonNextTrack": "Následující stopa", "ButtonOff": "Vypnout", "ButtonOpen": "Otevřít", @@ -87,17 +78,14 @@ "ButtonSelectView": "Výběr zobrazení", "ButtonSend": "Odeslat", "ButtonSettings": "Nastavení", - "ButtonShuffle": "Náhodně", "ButtonShutdown": "Vypnout", "ButtonSignIn": "Přihlásit se", "ButtonSignOut": "Odhlásit se", - "ButtonSort": "Seřadit", "ButtonStop": "Zastavit", "ButtonSubmit": "Potvrdit", "ButtonSubtitles": "Titulky", "ButtonTrailer": "Upoutávka", "ButtonUninstall": "Odinstalovat", - "ButtonUp": "Zesílit", "ButtonWebsite": "Webové stránky", "CancelRecording": "Zrušit nahrávání", "CancelSeries": "Ukončit Seriál", @@ -155,7 +143,6 @@ "Edit": "Upravit", "EditImages": "Editovat obrázky", "EditSubtitles": "Editovat titulky", - "EnableBackdrops": "Povolit pozadí", "EnableBackdropsHelp": "Pokud je povoleno, pozadí je zobrazeno pro některé stránky při procházení vaší knihovny.", "EnableCinemaMode": "Režim Cinema", "EnableColorCodedBackgrounds": "Barevně označené pozadí", @@ -223,7 +210,6 @@ "HeaderAdditionalParts": "Další součásti", "HeaderAdmin": "Administrátor", "HeaderAlbumArtists": "Umělci alba", - "HeaderAlbums": "Alba", "HeaderAlert": "Upozornění", "HeaderApiKey": "Klíč Api", "HeaderApiKeys": "Klíče API", @@ -238,7 +224,6 @@ "HeaderCastAndCrew": "Herci a obsazení", "HeaderCastCrew": "Herci a obsazení", "HeaderChannelAccess": "Přístup ke kanálu", - "HeaderChannels": "Kanály", "HeaderCodecProfile": "Profil kodeků", "HeaderCodecProfileHelp": "Kodek profily označují omezení daného zařízení pro přehrávání pomocí specifických kodeků. Jestliže je omezení aplikováno, média budou překódovany i v případě, že kodek je nakonfigurován pro přímé přehrávání.", "HeaderConfirmPluginInstallation": "Potvrzení instalace zásuvného modulu", @@ -274,7 +259,6 @@ "HeaderForKids": "Pro děti", "HeaderForgotPassword": "Zapomenuté heslo", "HeaderFrequentlyPlayed": "Nejčastěji přehráváno", - "HeaderGenres": "Žánry", "HeaderGuideProviders": "Poskytovatelé programových průvodců", "HeaderHttpHeaders": "Http hlavičky", "HeaderIdentification": "Identifikace", @@ -284,7 +268,6 @@ "HeaderImageSettings": "Nastavení obrázků", "HeaderInstall": "Instalovat", "HeaderInstantMix": "Okamžité míchání", - "HeaderItems": "Položky", "HeaderKeepRecording": "Udržet nahrávání", "HeaderKeepSeries": "Udržet seriál", "HeaderLatestEpisodes": "Nejnovější díly", @@ -303,7 +286,6 @@ "HeaderMediaInfo": "Informace o médiu", "HeaderMetadataSettings": "Nastavení metadat", "HeaderMoreLikeThis": "Podobné položky", - "HeaderMovies": "Filmy", "HeaderMusicQuality": "Kvalita hudby", "HeaderMusicVideos": "Hudební videa", "HeaderMyDevice": "Moje zařízení", @@ -359,7 +341,6 @@ "HeaderServerSettings": "Nastavení serveru", "HeaderSettings": "Nastavení", "HeaderSetupLibrary": "Nastavení Vašich knihoven médií", - "HeaderShutdown": "Vypnout", "HeaderSortBy": "Třídit dle", "HeaderSortOrder": "Pořadí třídění", "HeaderSpecialEpisodeInfo": "Infromace o speciální epizodě", @@ -390,7 +371,6 @@ "HeaderXmlDocumentAttributes": "Atributy XML dokumentu", "HeaderXmlSettings": "Nastavení XML", "HeaderYears": "Roky", - "HeadersFolders": "Složky", "Help": "Nápověda", "Hide": "Skrýt", "HideWatchedContentFromLatestMedia": "Skrýt přehrané položky ze seznamu nejnovějších médií", @@ -583,7 +563,6 @@ "LabelNewPassword": "Nové heslo:", "LabelNewPasswordConfirm": "Potvrzení hesla:", "LabelNewsCategories": "Nové kategorie:", - "LabelNext": "Další", "LabelNotificationEnabled": "Povolit toto oznámení", "LabelNumber": "Číslo:", "LabelNumberOfGuideDays": "Počet dnů programového průvodce ke stažení:", @@ -607,7 +586,6 @@ "LabelPreferredDisplayLanguage": "Preferovaný jazyk zobrazení:", "LabelPreferredDisplayLanguageHelp": "Překlad projektu Jellyfin se neustále vyvíjí.", "LabelPreferredSubtitleLanguage": "Preferovaný jazyk titulků:", - "LabelPrevious": "Předchozí", "LabelProfileAudioCodecs": "Audio kodeky:", "LabelProfileCodecs": "Kodeky:", "LabelProfileCodecsHelp": "Odděl čárkou. Pokud ponecháte prázdné, aplikují se všechny kodeky.", @@ -621,7 +599,6 @@ "LabelPublicHttpPortHelp": "Číslo veřejného portu, které by mělo být mapováno na místní port HTTP.", "LabelPublicHttpsPort": "Veřejný HTTPS port:", "LabelPublicHttpsPortHelp": "Číslo veřejného portu, které by mělo být mapováno na místní port HTTPS.", - "LabelReadHowYouCanContribute": "Zjistěte, jak můžete přispět.", "LabelRecord": "Záznam:", "LabelRecordingPath": "Standardní složka pro nahrávání:", "LabelRecordingPathHelp": "Určete výchozí umístění pro uložení nahrávky. Pokud je ponecháno prázdné, budou použity složky programu na serveru (data).", @@ -802,7 +779,6 @@ "MessageNoNextUpItems": "Nic nenalezeno. Začněte sledovat Vaše oblíbené seriály!", "MessageNoPluginConfiguration": "Tento zásuvný modul nemá žádné nastavení.", "NoSubtitleSearchResultsFound": "Žádné výsledky.", - "NoSubtitles": "Žádné", "NoSubtitlesHelp": "Ve výchozím nastavení nebudou titulky načteny. Během přehrávání však mohou být manuálně zapnuty.", "None": "Žádný", "Normal": "Normální", @@ -1051,21 +1027,13 @@ "TabAccess": "Přístup", "TabAdvanced": "Pokročilé", "TabAlbumArtists": "Umělci alba", - "TabAlbums": "Alba", "TabCatalog": "Katalog", - "TabChannels": "Kanály", "TabCodecs": "Kodeky", - "TabCollections": "Kolekce", "TabContainers": "Obaly", "TabDashboard": "Nástěnka", - "TabDevices": "Zařízení", "TabEpisodes": "Epizody", - "TabFavorites": "Oblíbené", - "TabGenres": "Žánry", - "TabGuide": "Programový průvodce", "TabLatest": "Nejnovější", "TabLogs": "Záznamy", - "TabMovies": "Filmy", "TabMusic": "Hudba", "TabMusicVideos": "Hudební videa", "TabMyPlugins": "Moje zásuvné moduly", @@ -1085,8 +1053,6 @@ "TabScheduledTasks": "Naplánované úlohy", "TabSeries": "Série", "TabSettings": "Nastavení", - "TabShows": "Seriály", - "TabSongs": "Skladby", "TabStreaming": "Streamování", "TabTrailers": "Upoutávky", "TabUpcoming": "Nadcházející", @@ -1464,7 +1430,6 @@ "HeaderHttpsSettings": "Nastavení HTTPS", "LabelRequireHttpsHelp": "Server automaticky přesměruje všechny požadavky z HTTP na HTTPS. Pokud server nenaslouchá na portu HTTPS, tato funkce nemá žádný účinek.", "LabelRequireHttps": "Vyžadovat HTTPS", - "TabDVR": "Nahrávání", "HeaderDVR": "Nahrávání", "SaveChanges": "Uložit změny", "LabelSyncPlayPlaybackDiff": "Rozdíl v době přehrávání:", diff --git a/src/strings/da.json b/src/strings/da.json index 7e4721a42b..e5c8655645 100644 --- a/src/strings/da.json +++ b/src/strings/da.json @@ -23,7 +23,6 @@ "AroundTime": "Omkring {0}", "AsManyAsPossible": "Så mange som muligt", "AspectRatio": "Billedformat", - "AttributeNew": "Ny", "Audio": "Lyd", "BirthDateValue": "Født: {0}", "BirthLocation": "Fødselslokation", @@ -35,19 +34,12 @@ "ButtonAddScheduledTaskTrigger": "Tilføj udløser", "ButtonAddServer": "Tilføj Server", "ButtonAddUser": "Tilføj bruger", - "ButtonArrowDown": "Ned", "ButtonArrowLeft": "Venstre", "ButtonArrowRight": "Højre", - "ButtonArrowUp": "Op", "ButtonAudioTracks": "Lysspor", "ButtonBack": "Tilbage", "ButtonCancel": "Annuller", "ButtonChangeServer": "Skift server", - "ButtonConnect": "Forbind", - "ButtonDelete": "Slet", - "ButtonDeleteImage": "Slet billede", - "ButtonDown": "Ned", - "ButtonDownload": "Hent", "ButtonEdit": "Rediger", "ButtonEditImages": "Rediger billeder", "ButtonEditOtherUserPreferences": "Rediger denne brugers profil, billede og personlige indstillinger.", @@ -59,7 +51,6 @@ "ButtonManualLogin": "Manuel Login", "ButtonMore": "Mere", "ButtonNetwork": "Netværk", - "ButtonNew": "Ny", "ButtonNextTrack": "Næste spor", "ButtonOff": "Fra", "ButtonOpen": "Åben", @@ -82,15 +73,12 @@ "ButtonSelectServer": "Vælg server", "ButtonSelectView": "Vælg visning", "ButtonSettings": "Indstillinger", - "ButtonShuffle": "Bland", "ButtonShutdown": "Luk", "ButtonSignIn": "Log Ind", "ButtonSignOut": "Log ud", - "ButtonSort": "Sortér", "ButtonSubmit": "Indsend", "ButtonSubtitles": "Undertekster", "ButtonUninstall": "Afinstaller", - "ButtonUp": "Op", "ButtonWebsite": "Hjemmeside", "CancelRecording": "Annuller optagelse", "CancelSeries": "Annuller serie", @@ -200,7 +188,6 @@ "HeaderCastAndCrew": "Medvirkende", "HeaderCastCrew": "Medvirkende", "HeaderChannelAccess": "Adgang til kanaler", - "HeaderChannels": "Kanaler", "HeaderChapterImages": "Kapitel Billeder", "HeaderCodecProfile": "Codec profil", "HeaderCodecProfileHelp": "Codec profiler angiver begrænsninger på en enhed for et specifikt codec. Hvis en begrænsning nås, vil indholdet blive transkodet, selv om codec'et er angivet til direkte afspilning.", @@ -240,7 +227,6 @@ "HeaderForKids": "For Børn", "HeaderForgotPassword": "Glemt adgangskode", "HeaderFrequentlyPlayed": "Ofte afspillet", - "HeaderGenres": "Genrer", "HeaderGuideProviders": "Guide Udbydere", "HeaderHttpHeaders": "HTTP Headers", "HeaderIdentification": "Identifikation", @@ -251,7 +237,6 @@ "HeaderImageSettings": "Billedindstillinger", "HeaderInstall": "Installer", "HeaderInstantMix": "Øjeblikkelig Mix", - "HeaderItems": "Element", "HeaderKeepRecording": "Bevar Optagelse", "HeaderKeepSeries": "Bevar Serie", "HeaderKodiMetadataHelp": "For at aktivere eller deaktivere NFO-metadata skal du redigere et bibliotek i Jellyfin-biblioteksopsætningen og finde afsnittet om metadata.", @@ -271,7 +256,6 @@ "HeaderMediaInfo": "Medieinformation", "HeaderMetadataSettings": "Indstillinger for metadata", "HeaderMoreLikeThis": "Mere Som Denne", - "HeaderMovies": "Film", "HeaderMusicVideos": "Musikvideoer", "HeaderMyDevice": "Min Enhed", "HeaderMyMedia": "Mine medier", @@ -324,7 +308,6 @@ "HeaderServerSettings": "Serverindstillinger", "HeaderSettings": "Indstillinger", "HeaderSetupLibrary": "Opsæt dine mediebiblioteker", - "HeaderShutdown": "Luk", "HeaderSortBy": "Sorter Efter", "HeaderSortOrder": "Sorteringsorden", "HeaderSpecialEpisodeInfo": "Information om specialepisoder", @@ -353,7 +336,6 @@ "HeaderXmlDocumentAttributes": "XML dokumentattributter", "HeaderXmlSettings": "XML indstillinger", "HeaderYears": "År", - "HeadersFolders": "Mapper", "Help": "Hjælp", "HttpsRequiresCert": "For at aktivere sikre forbindelser, skal du angive et betroet SSL certifikat, såsom Let's Encrypt. Venligst angiv et certifikat eller deaktiver sikre forbindelser.", "Identify": "Identificer", @@ -541,7 +523,6 @@ "LabelNewPassword": "Ny kode:", "LabelNewPasswordConfirm": "Gentag ny adgangskode:", "LabelNewsCategories": "Nyhedskategorier:", - "LabelNext": "Næste", "LabelNotificationEnabled": "Aktiver denne underretning", "LabelNumber": "Nummer:", "LabelNumberOfGuideDays": "Antal dage af programguide data der skal hentes:", @@ -567,7 +548,6 @@ "LabelPostProcessorArgumentsHelp": "Benyt {path} som stien til optagelsesfilen.", "LabelPreferredDisplayLanguage": "Foretrukket sprog til visning:", "LabelPreferredDisplayLanguageHelp": "Oversættelse af Jellyfin er et løbende projekt.", - "LabelPrevious": "Forrige", "LabelProfileAudioCodecs": "Lyd codecs:", "LabelProfileCodecsHelp": "Adskil med komma. Kan efterlades tom for at gælde for alle codecs.", "LabelProfileContainersHelp": "Adskil med komma. Kan efterlades tom for at gælde for alle containere.", @@ -578,7 +558,6 @@ "LabelPublicHttpPortHelp": "Det offentlige portnummer som bliver knyttet til det lokale HTTP-portnummer.", "LabelPublicHttpsPort": "Offentligt HTTPS portnummer:", "LabelPublicHttpsPortHelp": "Det offentlige portnummer som bliver knyttet til det lokale HTTPS portnummer.", - "LabelReadHowYouCanContribute": "Lær hvordan du kan bidrage.", "LabelRecord": "Optag:", "LabelRecordingPath": "Standard afspilningssti:", "LabelRecordingPathHelp": "Angiv standard-lokationen til at gemme afspilninger. Hvis efterladt blankt, benyttes serverens programdata-mappe.", @@ -966,17 +945,11 @@ "TabAdvanced": "Avanceret", "TabAlbumArtists": "Album-artister", "TabCatalog": "Katalog", - "TabChannels": "Kanaler", - "TabCollections": "Samlinger", "TabContainers": "Containere", "TabDashboard": "Betjeningspanel", - "TabDevices": "Enheder", "TabDirectPlay": "Direkte afspilning", "TabEpisodes": "Episoder", - "TabFavorites": "Favoritter", - "TabGenres": "Genre", "TabLatest": "Seneste", - "TabMovies": "Film", "TabMusic": "Musik", "TabMusicVideos": "Musikvideoer", "TabMyPlugins": "Mine tilføjelser", @@ -996,8 +969,6 @@ "TabScheduledTasks": "Planlagte opgaver", "TabSeries": "Serier", "TabSettings": "Indstillinger", - "TabShows": "Serier", - "TabSongs": "Sange", "TabTrailers": "Trailere", "TabUpcoming": "Kommende", "TabUsers": "Brugere", @@ -1114,7 +1085,6 @@ "DownloadsValue": "{0} hentninger", "DropShadow": "Drop Skygge", "EditMetadata": "Redigér metadata", - "EnableBackdrops": "Baggrundsbilleder", "EnableBackdropsHelp": "Vis baggrundsbilleder i baggrunden af nogle sider mens man gennemser biblioteket.", "EnableDisplayMirroring": "Visning afspejling", "EnableExternalVideoPlayers": "Eksterne video afspillere", @@ -1137,7 +1107,6 @@ "Guide": "Vejledning", "GuideProviderLogin": "Log Ind", "HeaderAdmin": "Admin", - "HeaderAlbums": "Albummer", "HeaderApp": "App", "HeaderAppearsOn": "Forekommer I", "HeaderAudioBooks": "Lydbøger", @@ -1248,7 +1217,6 @@ "Mobile": "Mobil", "Next": "Næste", "No": "Nej", - "NoSubtitles": "Ingen undertekster", "NoSubtitlesHelp": "Undertekster vil ikke blive indlæst som standard. De kan slåes til manuelt under afspilning.", "None": "Ingen", "Normal": "Normalt", @@ -1310,9 +1278,7 @@ "SubtitleAppearanceSettingsDisclaimer": "Disse indstillinger bliver ikke aktiveret på grafiske undertekster (PGS, DVD, etc) eller ASS/SSA undertekster der har deres egen indbyggede stil.", "Suggestions": "Forslag", "TV": "TV", - "TabAlbums": "Albummer", "TabCodecs": "Codeks", - "TabGuide": "Vejledning", "TabInfo": "Information", "TabLiveTV": "Live TV", "TabLogs": "Log", diff --git a/src/strings/de.json b/src/strings/de.json index 40035d6a45..2e28c73d2f 100644 --- a/src/strings/de.json +++ b/src/strings/de.json @@ -34,7 +34,6 @@ "AsManyAsPossible": "So viele wie möglich", "Ascending": "Aufsteigend", "AspectRatio": "Seitenverhältnis", - "AttributeNew": "Neu", "Backdrop": "Hintergrund", "Backdrops": "Hintergründe", "BirthDateValue": "Geboren: {0}", @@ -50,18 +49,12 @@ "ButtonAddScheduledTaskTrigger": "Auslöser hinzufügen", "ButtonAddServer": "Server hinzufügen", "ButtonAddUser": "User hinzufügen", - "ButtonArrowDown": "Ab", "ButtonArrowLeft": "Links", "ButtonArrowRight": "Rechts", - "ButtonArrowUp": "Auf", "ButtonAudioTracks": "Audiospuren", "ButtonBack": "Zurück", "ButtonCancel": "Abbrechen", "ButtonChangeServer": "Wechsel Server", - "ButtonConnect": "Verbinde", - "ButtonDelete": "Löschen", - "ButtonDeleteImage": "Lösche Bild", - "ButtonDown": "Runter", "ButtonEdit": "Bearbeiten", "ButtonEditImages": "Bearbeite Bilder", "ButtonEditOtherUserPreferences": "Bearbeite dieses Benutzerprofil, das Benutzerbild und die persönlichen Einstellungen.", @@ -73,7 +66,6 @@ "ButtonManualLogin": "Manuelle Anmeldung", "ButtonMore": "Mehr", "ButtonNetwork": "Netzwerk", - "ButtonNew": "Neu", "ButtonNextTrack": "Nächstes Stück", "ButtonOff": "Ausschalten", "ButtonOpen": "Öffnen", @@ -97,16 +89,13 @@ "ButtonSelectView": "Ansicht wählen", "ButtonSend": "senden", "ButtonSettings": "Einstellungen", - "ButtonShuffle": "Zufallswiedergabe", "ButtonShutdown": "Herunterfahren", "ButtonSignIn": "Einloggen", "ButtonSignOut": "Abmelden", - "ButtonSort": "Sortieren", "ButtonStop": "Stopp", "ButtonSubmit": "Bestätigen", "ButtonSubtitles": "Untertitel", "ButtonUninstall": "Deinstallieren", - "ButtonUp": "Hoch", "CancelRecording": "Aufnahme abbrechen", "CancelSeries": "Serien abbrechen", "Categories": "Kategorien", @@ -174,7 +163,6 @@ "EditImages": "Bearbeite Bilder", "EditMetadata": "Bearbeite Metadaten", "EditSubtitles": "Untertitel bearbeiten", - "EnableBackdrops": "Hintergründe", "EnableBackdropsHelp": "Zeige während des Browsens durch die Bibliothek auf einigen Seiten passende Hintergründe an.", "EnableCinemaMode": "Kino-Modus", "EnableColorCodedBackgrounds": "Farbige Hintergründe", @@ -249,7 +237,6 @@ "HeaderAddUser": "Benutzer anlegen", "HeaderAdditionalParts": "Zusätzliche Teile", "HeaderAlbumArtists": "Album-Interpreten", - "HeaderAlbums": "Alben", "HeaderAlert": "Alarm", "HeaderAllowMediaDeletionFrom": "Erlaube Medienlöschung von", "HeaderApiKey": "API-Schlüssel", @@ -266,7 +253,6 @@ "HeaderCastAndCrew": "Besetzung & Mitwirkende", "HeaderCastCrew": "Besetzung & Crew", "HeaderChannelAccess": "Channelzugriff", - "HeaderChannels": "Kanäle", "HeaderChapterImages": "Kapitel Bilder", "HeaderCodecProfile": "Codec Profil", "HeaderCodecProfileHelp": "Codec Profile weisen auf Beschränkungen eines Gerätes beim Abspielen bestimmter Codecs hin. Wenn eine Beschränkung zutrifft, dann werden Medien transcodiert, auch wenn der Codec für die Direktwiedergabe konfiguriert ist.", @@ -317,7 +303,6 @@ "HeaderImageSettings": "Bild Einstellungen", "HeaderInstall": "Installieren", "HeaderInstantMix": "Schnellmix", - "HeaderItems": "Inhalte", "HeaderKeepRecording": "Aufnahme behalten", "HeaderKeepSeries": "Serie behalten", "HeaderKodiMetadataHelp": "Um NFO Metadaten zu aktivieren oder deaktivieren, bearbeite eine Bibliothek und mache den Metadaten-Speicherer Abschnitt ausfindig.", @@ -340,7 +325,6 @@ "HeaderMediaInfo": "Medieninformation", "HeaderMetadataSettings": "Metadaten Einstellungen", "HeaderMoreLikeThis": "Mehr wie dieses", - "HeaderMovies": "Filme", "HeaderMusicQuality": "Musikqualität", "HeaderMusicVideos": "Musikvideos", "HeaderMyDevice": "Mein Gerät", @@ -400,7 +384,6 @@ "HeaderServerSettings": "Server Einstellungen", "HeaderSettings": "Einstellungen", "HeaderSetupLibrary": "Medienbibliotheken einrichten", - "HeaderShutdown": "Herunterfahren", "HeaderSortBy": "Sortiert nach", "HeaderSortOrder": "Sortierreihenfolge", "HeaderSpecialEpisodeInfo": "Spezialepisoden Information", @@ -432,7 +415,6 @@ "HeaderXmlDocumentAttributes": "XML-Dokument Eigenschaften", "HeaderXmlSettings": "XML Einstellungen", "HeaderYears": "Jahre", - "HeadersFolders": "Verzeichnisse", "Help": "Hilfe", "Hide": "Verstecke", "HideWatchedContentFromLatestMedia": "Verberge gesehene Inhalte von neuesten Medien", @@ -640,7 +622,6 @@ "LabelNewPassword": "Neues Passwort:", "LabelNewPasswordConfirm": "Neues Passwort wiederholen:", "LabelNewsCategories": "Nachrichtenkategorien:", - "LabelNext": "Nächstes", "LabelNotificationEnabled": "Aktiviere diese Benachrichtigung", "LabelNumber": "Nummer:", "LabelNumberOfGuideDays": "Anzahl von Tagen für die Programminformationen geladen werden sollen:", @@ -667,7 +648,6 @@ "LabelPreferredDisplayLanguage": "Bevorzugte Anzeigesprache:", "LabelPreferredDisplayLanguageHelp": "Die Übersetzung von Jellyfin ist ein laufendes Projekt.", "LabelPreferredSubtitleLanguage": "Bevorzugte Untertitelsprache:", - "LabelPrevious": "Vorheriges", "LabelProfileAudioCodecs": "Audio Codecs:", "LabelProfileCodecsHelp": "Getrennt durch Komma. Leerlassen, um auf alle Codecs anzuwenden.", "LabelProfileContainersHelp": "Getrennt durch Komma. Leerlassen, um auf alle Containerformate anzuwenden.", @@ -679,7 +659,6 @@ "LabelPublicHttpPortHelp": "Die öffentliche Portnummer sollte einem lokalen HTTP Port zugewiesen werden.", "LabelPublicHttpsPort": "Öffentliche HTTPS Portnummer:", "LabelPublicHttpsPortHelp": "Die öffentliche Portnummer sollte einem lokalen HTTPS Port zugewiesen werden.", - "LabelReadHowYouCanContribute": "Erfahren Sie, wie Sie unterstützen können.", "LabelReasonForTranscoding": "Grund für die Transkodierung:", "LabelRecord": "Aufnahme:", "LabelRecordingPath": "Standard Aufnahmepfad:", @@ -871,7 +850,6 @@ "MessageNoNextUpItems": "Es wurde nichts gefunden. Schau dir deine Shows an!", "MessageNoPluginConfiguration": "Dieses Plugin hat keine konfigurierbaren Einstellungen.", "NoSubtitleSearchResultsFound": "Keine Ergebnisse gefunden.", - "NoSubtitles": "Keine", "NoSubtitlesHelp": "Untertitel werden standardmäßig nicht geladen. Sie können aber während der Wiedergabe manuell aktiviert werden.", "None": "Keines", "NumLocationsValue": "{0} Verzeichnisse", @@ -1129,20 +1107,13 @@ "TabAccess": "Zugang", "TabAdvanced": "Erweitert", "TabAlbumArtists": "Album-Interpreten", - "TabAlbums": "Alben", "TabCatalog": "Katalog", - "TabChannels": "Kanäle", - "TabCollections": "Sammlungen", "TabContainers": "Container", "TabDashboard": "Übersicht", - "TabDevices": "Geräte", "TabDirectPlay": "Direktwiedergabe", "TabEpisodes": "Episoden", - "TabFavorites": "Favoriten", - "TabGuide": "Programm", "TabLatest": "Neueste", "TabLiveTV": "Live-TV", - "TabMovies": "Filme", "TabMusic": "Musik", "TabMusicVideos": "Musikvideos", "TabMyPlugins": "Meine Plugins", @@ -1161,7 +1132,6 @@ "TabScheduledTasks": "Geplante Aufgaben", "TabSeries": "Serie", "TabSettings": "Einstellungen", - "TabShows": "Serien", "TabTrailers": "Trailer", "TabUpcoming": "Bevorstehend", "TabUsers": "Benutzer", @@ -1226,7 +1196,6 @@ "Auto": "Auto", "Banner": "Banner", "Blacklist": "Sperrliste", - "ButtonDownload": "Download", "ButtonFilter": "Filter", "ButtonHome": "Startseite", "ButtonOk": "Ok", @@ -1246,7 +1215,6 @@ "Genres": "Genres", "HeaderAdmin": "Admin", "HeaderApp": "App", - "HeaderGenres": "Genres", "HeaderHttpHeaders": "HTTP-Header", "HeaderPluginInstallation": "Plugininstallation", "HeaderStatus": "Status", @@ -1311,12 +1279,10 @@ "Studios": "Studios", "TV": "TV", "TabCodecs": "Codecs", - "TabGenres": "Genres", "TabInfo": "Info", "TabLogs": "Protokoll", "TabPlugins": "Plugins", "TabServer": "Server", - "TabSongs": "Songs", "TabStreaming": "Streaming", "Transcoding": "Transcoding", "ValueAudioCodec": "Audiocodec: {0}", @@ -1458,7 +1424,6 @@ "LabelStable": "Stable", "LabelChromecastVersion": "Chromecast Version", "HeaderDVR": "DVR", - "TabDVR": "DVR", "SaveChanges": "Änderungen speichern", "LabelRequireHttpsHelp": "Wenn dies ausgewählt ist, leitet der Server alle Anfragen über HTTP an HTTPS weiter. Dies hat keinen Effekt, falls der Server nicht auf HTTPS hört.", "LabelRequireHttps": "Erfordere HTTPS", diff --git a/src/strings/el.json b/src/strings/el.json index d3176ae83c..1a15e1b994 100644 --- a/src/strings/el.json +++ b/src/strings/el.json @@ -29,7 +29,6 @@ "AsManyAsPossible": "Οσο το δυνατον περισσοτερα", "Ascending": "Αύξουσα", "AspectRatio": "Αναλογία απεικόνισης", - "AttributeNew": "Νέο", "Audio": "Ήχος", "Auto": "Αυτόματο", "Backdrop": "Φόντο", @@ -48,18 +47,12 @@ "ButtonAddScheduledTaskTrigger": "Προσθήκη διακόπτη", "ButtonAddServer": "Προσθήκη διακομιστή", "ButtonAddUser": "Προσθήκη χρήστη", - "ButtonArrowDown": "Κάτω", "ButtonArrowLeft": "Αριστερά", "ButtonArrowRight": "Δεξιά", - "ButtonArrowUp": "Επάνω", "ButtonAudioTracks": "Ηχητικά κομμάτια", "ButtonBack": "Πίσω", "ButtonCancel": "Ακύρωση", "ButtonChangeServer": "Αλλαγή Διακομιστή", - "ButtonConnect": "Σύνδεση", - "ButtonDelete": "Διαγραφή", - "ButtonDeleteImage": "Διαγραφή εικόνας", - "ButtonDown": "Κάτω", "ButtonEdit": "Επεξεργασία", "ButtonEditImages": "Επεξεργασία εικόνων", "ButtonEditOtherUserPreferences": "Επεξεργαστείτε το προφίλ, την εικόνα και τις προσωπικές προτιμήσεις αυτού του χρήστη.", @@ -73,7 +66,6 @@ "ButtonLibraryAccess": "Πρόσβαση στη βιβλιοθήκη", "ButtonManualLogin": "Χειροκίνητη Είσοδος", "ButtonMore": "Περισσότερα", - "ButtonNew": "Νέο", "ButtonNextTrack": "Επομενο", "ButtonOpen": "Άνοιγμα", "ButtonParentalControl": "Γονικός έλεγχος", @@ -97,18 +89,15 @@ "ButtonSelectView": "Επιλέξτε Προβολή", "ButtonSend": "Αποστολή", "ButtonSettings": "Ρυθμίσεις", - "ButtonShuffle": "Τυχαία Αναπαραγωγή", "ButtonShutdown": "Απενεργοποίηση", "ButtonSignIn": "Είσοδος", "ButtonSignOut": "Έξοδος", - "ButtonSort": "Ταξινόμηση", "ButtonStart": "Έναρξη", "ButtonStop": "Διακοπή", "ButtonSubmit": "υποβολή", "ButtonSubtitles": "Υπότιτλοι", "ButtonTrailer": "Τρέϊλερ", "ButtonUninstall": "Απεγκατάσταση", - "ButtonUp": "Επάνω", "ButtonWebsite": "Ιστοσελίδα", "CancelRecording": "Ακύρωση Εγγραφής", "CancelSeries": "Ακύρωση Σειράς", @@ -179,7 +168,6 @@ "EditImages": "Επεξεργασία εικόνων", "EditMetadata": "Επεξεργασία μεταδεδομένων", "EditSubtitles": "Επεξεργασία υποτίτλων", - "EnableBackdrops": "Ενεργοποίηση Σκηνικών", "EnableBackdropsHelp": "Eμφάνιση φόντων στο παρασκήνιο ορισμένων σελίδων κατά την περιήγηση στη βιβλιοθήκη.", "EnableCinemaMode": "Λειτουργία Κινηματογράφου", "EnableColorCodedBackgrounds": "Ενεργοποιήστε τα έγχρωμα κωδικοποιημένα φόντα", @@ -258,7 +246,6 @@ "HeaderCancelSeries": "Ακύρωση Σειράς", "HeaderCastAndCrew": "Ηθοποιοί και Συνεργείο", "HeaderCastCrew": "Ηθοποιοί και συνεργείο", - "HeaderChannels": "Κανάλια", "HeaderCodecProfileHelp": "Τα προφίλ κωδικοποιητή υποδεικνύουν τους περιορισμούς μιας συσκευής κατά την αναπαραγωγή συγκεκριμένων κωδικοποιητών. Εάν ισχύει περιορισμός, τότε τα μέσα θα κωδικοποιηθούν, ακόμα και αν ο κωδικοποιητής έχει ρυθμιστεί για άμεση αναπαραγωγή.", "HeaderConfigureRemoteAccess": "Ρύθμιση απομακρυσμένης πρόσβασης", "HeaderConfirmPluginInstallation": "Επιβεβαιώστε την εγκατάσταση της προσθήκης", @@ -292,7 +279,6 @@ "HeaderForKids": "Για τα Παιδιά", "HeaderForgotPassword": "Ξέχασα τον κωδικό", "HeaderFrequentlyPlayed": "Συχνά έπαιξε", - "HeaderGenres": "Είδη", "HeaderIdentificationCriteriaHelp": "Καταχωρήστε τουλάχιστον ένα κριτήριο αναγνώρισης.", "HeaderIdentificationHeader": "Αναγνωριστικό Header", "HeaderIdentifyItemHelp": "Πληκτρολογήστε ένα ή περισσότερα κριτήρια αναζήτησης. Κατάργηση κριτηρίων για την αύξηση των αποτελεσμάτων αναζήτησης.", @@ -300,7 +286,6 @@ "HeaderImageSettings": "Ρυθμίσεις Εικόνας", "HeaderInstall": "Εγκατάσταση", "HeaderInstantMix": "Άμεση Mix", - "HeaderItems": "Στοιχεία", "HeaderKeepRecording": "Συνέχισε την Εγγραφή", "HeaderKeepSeries": "Συνέχισε την Σειρά", "HeaderLatestEpisodes": "Τελευταία επεισόδια", @@ -321,7 +306,6 @@ "HeaderMediaInfo": "Πληροφορίες πολυμέσων", "HeaderMetadataSettings": "Ρυθμίσεις μεταδεδομένων", "HeaderMoreLikeThis": "Περισσότερα Σαν Αυτό", - "HeaderMovies": "Ταινίες", "HeaderMusicQuality": "Ποιότητα Μουσικής", "HeaderMusicVideos": "Βίντεο Μουσικής", "HeaderMyDevice": "Η Συσκευή μου", @@ -370,7 +354,6 @@ "HeaderServerSettings": "Ρυθμίσεις διακομιστή", "HeaderSettings": "Ρυθμίσεις", "HeaderSetupLibrary": "Ρυθμίστε τις βιβλιοθήκες πολυμέσων σας", - "HeaderShutdown": "Απενεργοποίηση", "HeaderSortBy": "Ταξινόμηση κατά", "HeaderSortOrder": "Σειρά ταξινόμησης", "HeaderSpecialEpisodeInfo": "Ειδικές πληροφορίες επεισοδίου", @@ -401,7 +384,6 @@ "HeaderXmlDocumentAttributes": "Χαρακτηριστικά εγγράφου Xml", "HeaderXmlSettings": "Ρυθμίσεις xml", "HeaderYears": "Χρονιές", - "HeadersFolders": "Φάκελοι", "Help": "Βοήθεια", "Hide": "Κρύψε", "HideWatchedContentFromLatestMedia": "Απόκρυψη προβληθέντων από τα πρόσφατα μέσα", @@ -577,7 +559,6 @@ "LabelNewPassword": "Νέος κωδικός πρόσβασης:", "LabelNewPasswordConfirm": "Επιβεβαίωση νέου κωδικού πρόσβασης:", "LabelNewsCategories": "Κατηγορίες ειδήσεων:", - "LabelNext": "Επόμενο", "LabelNotificationEnabled": "Ενεργοποίηση αυτής της ειδοποίησης", "LabelNumber": "Αριθμός:", "LabelNumberOfGuideDays": "Αριθμός ημερών οδηγιών για λήψη:", @@ -599,7 +580,6 @@ "LabelPreferredDisplayLanguage": "Προτιμώμενη γλώσσα εμφάνισης:", "LabelPreferredDisplayLanguageHelp": "Η μετάφραση του Jellyfin είναι ένα συνεχιζόμενο έργο.", "LabelPreferredSubtitleLanguage": "Προτεινόμενη Γλώσσα υποτίτλων:", - "LabelPrevious": "Προηγούμενο", "LabelProfileCodecsHelp": "Διαχωρίζονται με κόμμα. Αυτό μπορεί να μείνει κενό για να εφαρμοστεί σε όλα τα codecs.", "LabelProfileContainersHelp": "Διαχωρίζονται με κόμμα. Αυτό μπορεί να μείνει κενό για να εφαρμοστεί σε όλα τα containers.", "LabelProtocol": "Πρωτόκολλο:", @@ -607,7 +587,6 @@ "LabelPublicHttpPortHelp": "Ο αριθμός δημόσιας θύρας που πρέπει να αντιστοιχιστεί στην τοπική θύρα http.", "LabelPublicHttpsPort": "Αριθμός δημόσιας https θύρας:", "LabelPublicHttpsPortHelp": "Ο αριθμός δημόσιας θύρας που πρέπει να αντιστοιχιστεί στην τοπική θύρα https.", - "LabelReadHowYouCanContribute": "Μάθετε πώς μπορείτε να συμβάλλετε.", "LabelReasonForTranscoding": "Λόγος για την Κωδικοποίηση:", "LabelRecord": "Εγγραφή:", "LabelRecordingPath": "Προεπιλεγμένη διαδρομή εγγραφής:", @@ -776,7 +755,6 @@ "MessageNoNextUpItems": "Δεν βρέθηκε κανένα. Ξεκινήστε παρακολουθώντας τις εκπομπές σας!", "MessageNoPluginConfiguration": "Αυτό το plugin δεν απαιτεί ρυθμίσεις.", "NoSubtitleSearchResultsFound": "Δεν βρέθηκαν αποτελέσματα.", - "NoSubtitles": "Χωρίς Υπότιτλους", "NoSubtitlesHelp": "Οι υπότιτλοι δεν θα φορτωθούν από προεπιλογή.Μπορούν ακόμα να ενεργοποιούνται χειροκίνητα κατά την αναπαραγωγή.", "None": "Κανένα", "Normal": "Κανονικός", @@ -1018,20 +996,12 @@ "TabAccess": "Πρόσβαση", "TabAdvanced": "Για προχωρημένους", "TabAlbumArtists": "Άλμπουμ Καλλιτέχνες", - "TabAlbums": "Άλμπουμ", "TabCatalog": "Κατάλογος", - "TabChannels": "Κανάλια", - "TabCollections": "Συλλογές", "TabDashboard": "Πίνακας Ελέγχου", - "TabDevices": "Συσκευές", "TabDirectPlay": "Άμεση Αναπαραγωγή", "TabEpisodes": "Επεισόδια", - "TabFavorites": "Αγαπημένα", - "TabGenres": "Είδη", - "TabGuide": "Οδηγός", "TabInfo": "Πληροφορία", "TabLatest": "Τελευταία", - "TabMovies": "Ταινίες", "TabMusic": "Μουσική", "TabMusicVideos": "Μουσικά βίντεο", "TabMyPlugins": "Τα πρόσθετα μου", @@ -1051,8 +1021,6 @@ "TabSeries": "Σειρές", "TabServer": "Διακομιστής", "TabSettings": "Ρυθμισεις", - "TabShows": "Επεισόδια", - "TabSongs": "Τραγούδια", "TabStreaming": "Ροή", "TabTrailers": "Τρέιλερς", "TabUpcoming": "Επερχόμενα", @@ -1143,7 +1111,6 @@ "HeaderChapterImages": "Εικόνες Κεφαλαίων", "HeaderChannelAccess": "Πρόσβαση σε Κανάλια", "HeaderApp": "Εφαρμογή", - "HeaderAlbums": "Άλμπουμ", "HeaderAccessScheduleHelp": "Δημιουργήστε ένα πρόγραμμα πρόσβασης για να περιορίσετε την πρόσβαση ορισμένες ώρες.", "HeaderAccessSchedule": "Πρόγραμμα Πρόσβασης", "LabelTranscodePath": "Διαδρομή μετατροπών:", @@ -1165,7 +1132,6 @@ "ButtonOk": "Οκ", "ButtonOff": "Απενεργοποίηση", "ButtonNetwork": "Δίκτυο", - "ButtonDownload": "Κατέβασμα", "AllowOnTheFlySubtitleExtractionHelp": "Οι ενσωματωμένοι υπότιτλοι μπορούν να εξαχθούν από βίντεο και να σταλούν στις συσκευές σε απλό κείμενο για να αποφευχθούν μετατροπές βίντεο. Σε μερικά συστήματα αυτό μπορεί να πάρει πολύ ώρα και να κάνει το βίντεο να κολλάει κατά την διάρκεια της εξαγωγής. Απενεργοποιήστε το για να έχετε ενσωματωμένους υπότιτλους πάνω στο βίντεο όταν αυτοί δεν υποστηρίζονται από την συσκευή.", "AllowOnTheFlySubtitleExtraction": "Επίτρεψε την εξαγωγή υποτίτλων σε πραγματικό χρόνο", "AllowMediaConversionHelp": "Παραχώρηση ή στέρηση πρόσβασης στην λειτουργία μετατροπής μέσων.", diff --git a/src/strings/en-gb.json b/src/strings/en-gb.json index f2fc6e7764..2714f21147 100644 --- a/src/strings/en-gb.json +++ b/src/strings/en-gb.json @@ -26,7 +26,6 @@ "PlaceFavoriteChannelsAtBeginning": "Place favourite channels at the beginning", "Programs": "Programs", "TabCatalog": "Catalogue", - "TabFavorites": "Favourites", "XmlTvKidsCategoriesHelp": "Programs with these categories will be displayed as programs for children. Separate multiple with '|'.", "XmlTvMovieCategoriesHelp": "Programs with these categories will be displayed as movies. Separate multiple with '|'.", "XmlTvNewsCategoriesHelp": "Programs with these categories will be displayed as news programs. Separate multiple with '|'.", @@ -83,7 +82,6 @@ "AsManyAsPossible": "As many as possible", "Ascending": "Ascending", "AspectRatio": "Aspect Ratio", - "AttributeNew": "New", "Audio": "Audio", "AuthProviderHelp": "Select an Authentication Provider to be used to authenticate this user's password.", "Auto": "Auto", @@ -103,19 +101,12 @@ "ButtonAddScheduledTaskTrigger": "Add Trigger", "ButtonAddServer": "Add Server", "ButtonAddUser": "Add User", - "ButtonArrowDown": "Down", "ButtonArrowLeft": "Left", "ButtonArrowRight": "Right", - "ButtonArrowUp": "Up", "ButtonAudioTracks": "Audio Tracks", "ButtonBack": "Back", "ButtonCancel": "Cancel", "ButtonChangeServer": "Change Server", - "ButtonConnect": "Connect", - "ButtonDelete": "Delete", - "ButtonDeleteImage": "Delete Image", - "ButtonDown": "Down", - "ButtonDownload": "Download", "ButtonEdit": "Edit", "ButtonEditImages": "Edit images", "ButtonEditOtherUserPreferences": "Edit this user's profile, image and personal preferences.", @@ -130,7 +121,6 @@ "ButtonManualLogin": "Manual Login", "ButtonMore": "More", "ButtonNetwork": "Network", - "ButtonNew": "New", "ButtonNextTrack": "Next track", "ButtonOff": "Off", "ButtonOk": "OK", @@ -156,18 +146,15 @@ "ButtonSelectView": "Select view", "ButtonSend": "Send", "ButtonSettings": "Settings", - "ButtonShuffle": "Shuffle", "ButtonShutdown": "Shutdown", "ButtonSignIn": "Sign In", "ButtonSignOut": "Sign Out", - "ButtonSort": "Sort", "ButtonStart": "Start", "ButtonStop": "Stop", "ButtonSubmit": "Submit", "ButtonSubtitles": "Subtitles", "ButtonTrailer": "Trailer", "ButtonUninstall": "Uninstall", - "ButtonUp": "Up", "ButtonWebsite": "Website", "CancelRecording": "Cancel recording", "CancelSeries": "Cancel series", @@ -234,7 +221,6 @@ "EditImages": "Edit images", "EditMetadata": "Edit metadata", "EditSubtitles": "Edit subtitles", - "EnableBackdrops": "Backdrops", "EnableBackdropsHelp": "Display backdrops in the background of some pages while browsing the library.", "EnableCinemaMode": "Cinema mode", "EnableDisplayMirroring": "Display mirroring", @@ -308,7 +294,6 @@ "HeaderAddUser": "Add User", "HeaderAdditionalParts": "Additional Parts", "HeaderAdmin": "Admin", - "HeaderAlbums": "Albums", "HeaderAlert": "Alert", "HeaderAllowMediaDeletionFrom": "Allow Media Deletion From", "HeaderApiKey": "API Key", @@ -325,7 +310,6 @@ "HeaderCastAndCrew": "Cast & Crew", "HeaderCastCrew": "Cast & Crew", "HeaderChannelAccess": "Channel Access", - "HeaderChannels": "Channels", "HeaderChapterImages": "Chapter Images", "HeaderCodecProfile": "Codec Profile", "HeaderCodecProfileHelp": "Codec profiles indicate the limitations of a device when playing specific codecs. If a limitation applies then the media will be transcoded, even if the codec is configured for direct play.", @@ -375,7 +359,6 @@ "HeaderForKids": "For Kids", "HeaderForgotPassword": "Forgot Password", "HeaderFrequentlyPlayed": "Frequently Played", - "HeaderGenres": "Genres", "HeaderGuideProviders": "TV Guide Data Providers", "HeaderHttpHeaders": "HTTP Headers", "HeaderIdentification": "Identification", @@ -386,7 +369,6 @@ "HeaderImageSettings": "Image Settings", "HeaderInstall": "Install", "HeaderInstantMix": "Instant Mix", - "HeaderItems": "Items", "HeaderKeepRecording": "Keep Recording", "HeaderKeepSeries": "Keep Series", "HeaderKodiMetadataHelp": "To enable or disable NFO metadata, edit a library in Jellyfin library setup and locate the metadata savers section.", @@ -408,7 +390,6 @@ "HeaderMediaInfo": "Media Info", "HeaderMetadataSettings": "Metadata Settings", "HeaderMoreLikeThis": "More Like This", - "HeaderMovies": "Movies", "HeaderMusicQuality": "Music Quality", "HeaderMusicVideos": "Music Videos", "HeaderMyDevice": "My Device", @@ -462,7 +443,6 @@ "Thursday": "Thursday", "ThisWizardWillGuideYou": "This wizard will help guide you through the setup process. To begin, please select your preferred language.", "TheseSettingsAffectSubtitlesOnThisDevice": "These settings affect subtitles on this device", - "TabShows": "Shows", "TabSettings": "Settings", "TabServer": "Server", "TabSeries": "Series", @@ -476,12 +456,8 @@ "TabMyPlugins": "My Plugins", "TabMusicVideos": "Music Videos", "TabMusic": "Music", - "TabMovies": "Movies", "TabLogs": "Logs", "TabDirectPlay": "Direct Play", - "TabDevices": "Devices", - "TabChannels": "Channels", - "TabAlbums": "Albums", "TabAlbumArtists": "Album Artists", "TabAdvanced": "Advanced", "TabAccess": "Access", @@ -665,7 +641,6 @@ "Normal": "Normal", "None": "None", "NoSubtitlesHelp": "Subtitles will not be loaded by default. They can still be turned on manually during playback.", - "NoSubtitles": "None", "MessageNoPluginConfiguration": "This plugin has no settings to configure.", "MessageNoNextUpItems": "None found. Start watching your shows!", "No": "No", @@ -920,7 +895,6 @@ "LabelDeviceDescription": "Device description", "LabelDefaultUserHelp": "Determines which user library should be displayed on connected devices. This can be overridden for each device using profiles.", "TabStreaming": "Streaming", - "TabSongs": "Songs", "TabProfiles": "Profiles", "TabProfile": "Profile", "TabPlugins": "Plugins", @@ -930,12 +904,9 @@ "TabLiveTV": "Live TV", "TabLatest": "Latest", "TabInfo": "Info", - "TabGuide": "Guide", - "TabGenres": "Genres", "TabEpisodes": "Episodes", "TabDashboard": "Dashboard", "TabContainers": "Containers", - "TabCollections": "Collections", "TabCodecs": "Codecs", "Sort": "Sort", "Smaller": "Smaller", @@ -958,7 +929,6 @@ "LabelSeriesRecordingPath": "Series recording path (optional):", "LabelRecordingPathHelp": "Specify the default location to save recordings. If left empty, the server's program data folder will be used.", "LabelRecordingPath": "Default recording path:", - "LabelReadHowYouCanContribute": "Learn how you can contribute.", "LabelAlbumArtMaxWidth": "Album art max width:", "LabelCustomCssHelp": "Apply your own custom styling to the web interface.", "LabelBlastMessageIntervalHelp": "Determines the duration in seconds between blast alive messages.", @@ -1010,7 +980,6 @@ "LabelParentalRating": "Parental rating:", "LabelParentNumber": "Parent number:", "LabelOptionalNetworkPath": "(Optional) Shared network folder:", - "LabelNext": "Next", "LabelNewsCategories": "News categories:", "LabelNewPasswordConfirm": "New password confirm:", "LabelNewPassword": "New password:", @@ -1158,7 +1127,6 @@ "HideWatchedContentFromLatestMedia": "Hide watched content from latest media", "Hide": "Hide", "Help": "Help", - "HeadersFolders": "Folders", "HeaderXmlSettings": "XML Settings", "HeaderXmlDocumentAttributes": "XML Document Attributes", "HeaderXmlDocumentAttribute": "XML Document Attribute", @@ -1289,7 +1257,6 @@ "ValueOneSeries": "1 series", "MediaInfoBitrate": "Bitrate", "LabelVideo": "Video", - "LabelPrevious": "Previous", "LabelPostProcessorArgumentsHelp": "Use {path} as the path to the recording file.", "LabelKodiMetadataEnableExtraThumbs": "Copy extrafanart to extrathumbs field", "LabelInternetQuality": "Internet quality:", @@ -1359,7 +1326,6 @@ "HeaderSpecialEpisodeInfo": "Special Episode Info", "HeaderSortOrder": "Sort Order", "HeaderSortBy": "Sort By", - "HeaderShutdown": "Shutdown", "HeaderSetupLibrary": "Setup your media libraries", "HeaderSettings": "Settings", "HeaderServerSettings": "Server Settings", @@ -1462,7 +1428,6 @@ "ButtonSyncPlay": "SyncPlay", "EnableBlurHashHelp": "Images that are still being loaded will be displayed with a blurred placeholder", "EnableBlurHash": "Enable blurred placeholders for images", - "TabDVR": "DVR", "TabRepositories": "Repositories", "SyncPlayAccessHelp": "Select the level of access this user has to the SyncPlay feature. SyncPlay enables to sync playback with other devices.", "ShowMore": "Show more", diff --git a/src/strings/en-us.json b/src/strings/en-us.json index 2e437b148b..355ef9c96c 100644 --- a/src/strings/en-us.json +++ b/src/strings/en-us.json @@ -42,7 +42,6 @@ "Ascending": "Ascending", "AskAdminToCreateLibrary": "Ask an administrator to create a library.", "AspectRatio": "Aspect Ratio", - "AttributeNew": "New", "Audio": "Audio", "AuthProviderHelp": "Select an authentication provider to be used to authenticate this user's password.", "Auto": "Auto", @@ -66,19 +65,12 @@ "ButtonAddScheduledTaskTrigger": "Add Trigger", "ButtonAddServer": "Add Server", "ButtonAddUser": "Add User", - "ButtonArrowDown": "Down", "ButtonArrowLeft": "Left", "ButtonArrowRight": "Right", - "ButtonArrowUp": "Up", "ButtonAudioTracks": "Audio Tracks", "ButtonBack": "Back", "ButtonCancel": "Cancel", "ButtonChangeServer": "Change Server", - "ButtonConnect": "Connect", - "ButtonDelete": "Delete", - "ButtonDeleteImage": "Delete Image", - "ButtonDown": "Down", - "ButtonDownload": "Download", "ButtonEdit": "Edit", "ButtonEditImages": "Edit images", "ButtonEditOtherUserPreferences": "Edit this user's profile, image and personal preferences.", @@ -93,7 +85,6 @@ "ButtonManualLogin": "Manual Login", "ButtonMore": "More", "ButtonNetwork": "Network", - "ButtonNew": "New", "ButtonNextTrack": "Next track", "ButtonOff": "Off", "ButtonOk": "Ok", @@ -119,11 +110,9 @@ "ButtonSelectView": "Select view", "ButtonSend": "Send", "ButtonSettings": "Settings", - "ButtonShuffle": "Shuffle", "ButtonShutdown": "Shutdown", "ButtonSignIn": "Sign In", "ButtonSignOut": "Sign Out", - "ButtonSort": "Sort", "ButtonStart": "Start", "ButtonStop": "Stop", "ButtonSplit": "Split", @@ -132,7 +121,6 @@ "ButtonTogglePlaylist": "Playlist", "ButtonTrailer": "Trailer", "ButtonUninstall": "Uninstall", - "ButtonUp": "Up", "ButtonWebsite": "Website", "CancelRecording": "Cancel recording", "CancelSeries": "Cancel series", @@ -210,7 +198,6 @@ "EditImages": "Edit images", "EditMetadata": "Edit metadata", "EditSubtitles": "Edit subtitles", - "EnableBackdrops": "Backdrops", "EnableBackdropsHelp": "Display backdrops in the background of some pages while browsing the library.", "EnableCinemaMode": "Cinema mode", "EnableColorCodedBackgrounds": "Color coded backgrounds", @@ -297,7 +284,6 @@ "HeaderAdditionalParts": "Additional Parts", "HeaderAdmin": "Admin", "HeaderAlbumArtists": "Album Artists", - "HeaderAlbums": "Albums", "HeaderAlert": "Alert", "HeaderAllowMediaDeletionFrom": "Allow Media Deletion From", "HeaderApiKey": "API Key", @@ -316,7 +302,6 @@ "HeaderCastAndCrew": "Cast & Crew", "HeaderCastCrew": "Cast & Crew", "HeaderChannelAccess": "Channel Access", - "HeaderChannels": "Channels", "HeaderChapterImages": "Chapter Images", "HeaderCodecProfile": "Codec Profile", "HeaderCodecProfileHelp": "Codec profiles indicate the limitations of a device when playing specific codecs. If a limitation applies then the media will be transcoded, even if the codec is configured for direct play.", @@ -369,7 +354,6 @@ "HeaderForKids": "For Kids", "HeaderForgotPassword": "Forgot Password", "HeaderFrequentlyPlayed": "Frequently Played", - "HeaderGenres": "Genres", "HeaderGuideProviders": "TV Guide Data Providers", "HeaderHome": "Home", "HeaderHttpHeaders": "HTTP Headers", @@ -382,7 +366,6 @@ "HeaderImageSettings": "Image Settings", "HeaderInstall": "Install", "HeaderInstantMix": "Instant Mix", - "HeaderItems": "Items", "HeaderKeepRecording": "Keep Recording", "HeaderKeepSeries": "Keep Series", "HeaderKodiMetadataHelp": "To enable or disable NFO metadata, edit a library and locate the metadata savers section.", @@ -405,7 +388,6 @@ "HeaderMediaInfo": "Media Info", "HeaderMetadataSettings": "Metadata Settings", "HeaderMoreLikeThis": "More Like This", - "HeaderMovies": "Movies", "HeaderMusicQuality": "Music Quality", "HeaderMusicVideos": "Music Videos", "HeaderMyDevice": "My Device", @@ -469,7 +451,6 @@ "HeaderServerSettings": "Server Settings", "HeaderSettings": "Settings", "HeaderSetupLibrary": "Setup your media libraries", - "HeaderShutdown": "Shutdown", "HeaderSortBy": "Sort By", "HeaderSortOrder": "Sort Order", "HeaderSpecialEpisodeInfo": "Special Episode Info", @@ -506,7 +487,6 @@ "HeaderXmlDocumentAttributes": "Xml Document Attributes", "HeaderXmlSettings": "Xml Settings", "HeaderYears": "Years", - "HeadersFolders": "Folders", "Help": "Help", "Hide": "Hide", "HideWatchedContentFromLatestMedia": "Hide watched content from latest media", @@ -744,7 +724,6 @@ "LabelNewPassword": "New password:", "LabelNewPasswordConfirm": "New password confirm:", "LabelNewsCategories": "News categories:", - "LabelNext": "Next", "LabelNotificationEnabled": "Enable this notification", "LabelNumber": "Number:", "LabelNumberOfGuideDays": "Number of days of guide data to download:", @@ -776,7 +755,6 @@ "LabelPreferredDisplayLanguage": "Preferred display language:", "LabelPreferredDisplayLanguageHelp": "Translating Jellyfin is an ongoing project.", "LabelPreferredSubtitleLanguage": "Preferred subtitle language:", - "LabelPrevious": "Previous", "LabelProfileAudioCodecs": "Audio codecs:", "LabelProfileCodecs": "Codecs:", "LabelProfileCodecsHelp": "Separated by comma. This can be left empty to apply to all codecs.", @@ -790,7 +768,6 @@ "LabelPublicHttpPortHelp": "The public port number that should be mapped to the local HTTP port.", "LabelPublicHttpsPort": "Public HTTPS port number:", "LabelPublicHttpsPortHelp": "The public port number that should be mapped to the local HTTPS port.", - "LabelReadHowYouCanContribute": "Learn how you can contribute.", "LabelReasonForTranscoding": "Reason for transcoding:", "LabelRecord": "Record:", "LabelRecordingPath": "Default recording path:", @@ -1073,7 +1050,6 @@ "MessageNoNextUpItems": "None found. Start watching your shows!", "MessageNoPluginConfiguration": "This plugin has no settings to configure.", "NoSubtitleSearchResultsFound": "No results found.", - "NoSubtitles": "None", "NoSubtitlesHelp": "Subtitles will not be loaded by default. They can still be turned on manually during playback.", "None": "None", "Normal": "Normal", @@ -1389,26 +1365,17 @@ "TabAccess": "Access", "TabAdvanced": "Advanced", "TabAlbumArtists": "Album Artists", - "TabAlbums": "Albums", "TabCatalog": "Catalog", "TabRepositories": "Repositories", - "TabChannels": "Channels", "TabCodecs": "Codecs", - "TabCollections": "Collections", "TabContainers": "Containers", "TabDashboard": "Dashboard", - "TabDevices": "Devices", "TabDirectPlay": "Direct Play", - "TabDVR": "DVR", "TabEpisodes": "Episodes", - "TabFavorites": "Favorites", - "TabGenres": "Genres", - "TabGuide": "Guide", "TabInfo": "Info", "TabLatest": "Latest", "TabLiveTV": "Live TV", "TabLogs": "Logs", - "TabMovies": "Movies", "TabMusic": "Music", "TabMusicVideos": "Music Videos", "TabMyPlugins": "My Plugins", @@ -1430,8 +1397,6 @@ "TabSeries": "Series", "TabServer": "Server", "TabSettings": "Settings", - "TabShows": "Shows", - "TabSongs": "Songs", "TabStreaming": "Streaming", "TabTrailers": "Trailers", "TabUpcoming": "Upcoming", diff --git a/src/strings/es-ar.json b/src/strings/es-ar.json index 6fb6907284..0ae3654a9b 100644 --- a/src/strings/es-ar.json +++ b/src/strings/es-ar.json @@ -9,8 +9,6 @@ "HeaderSeries": "Series", "LabelDisplayMissingEpisodesWithinSeasons": "Mostrar capítulos no disponibles en temporadas", "LabelFinish": "Terminar", - "LabelNext": "Siguiente", - "LabelPrevious": "Anterior", "LabelYoureDone": "Ha terminado!", "MoreUsersCanBeAddedLater": "Se pueden agregar más usuarios más tarde desde el tablero.", "NewCollectionNameExample": "Ejemplo: Colección de Star Wars", @@ -72,7 +70,6 @@ "AnyLanguage": "Cualquier idioma", "Anytime": "Cualquier fecha", "Ascending": "Ascendente", - "AttributeNew": "Nuevo", "Audio": "Audio", "Auto": "Auto", "Backdrop": "Fondo", @@ -99,19 +96,12 @@ "ButtonAddScheduledTaskTrigger": "Agregar desencadenador", "ButtonAddServer": "Agregar servidor", "ButtonAddUser": "Agregar usuario", - "ButtonArrowDown": "Abajo", "ButtonArrowLeft": "Izquierda", "ButtonArrowRight": "Derecha", - "ButtonArrowUp": "Arriba", "ButtonAudioTracks": "Pistas de audio", "ButtonBack": "Atrás", "ButtonCancel": "Cancelar", "ButtonChangeServer": "Cambiar servidor", - "ButtonConnect": "Conectar", - "ButtonDelete": "Eliminar", - "ButtonDeleteImage": "Eliminar imagen", - "ButtonDown": "Abajo", - "ButtonDownload": "Descargar", "ButtonEdit": "Editar", "ButtonEditImages": "Editar imágenes", "ButtonEditOtherUserPreferences": "Editar perfil, imagen y preferencias personales del usuario.", @@ -126,7 +116,6 @@ "ButtonManualLogin": "Inicio de sesión manual", "ButtonMore": "Más", "ButtonNetwork": "Red", - "ButtonNew": "Nuevo", "ButtonNextTrack": "Pista siguiente", "ButtonOff": "Desactivado", "ButtonOk": "Aceptar", @@ -151,17 +140,14 @@ "ButtonSelectView": "Seleccionar vista", "ButtonSend": "Enviar", "ButtonSettings": "Configuraciones", - "ButtonShuffle": "Aleatorio", "ButtonShutdown": "Apagar", "ButtonSignIn": "Iniciar sesión", - "ButtonSort": "Ordenar", "ButtonStart": "Iniciar", "ButtonStop": "Detener", "ButtonSubmit": "Enviar", "ButtonSubtitles": "Subtítulos", "ButtonTrailer": "Avance", "ButtonUninstall": "Desinstalar", - "ButtonUp": "Arriba", "ButtonWebsite": "Sitio web", "CancelRecording": "Cancelar grabación", "CancelSeries": "Cancelar serie", @@ -230,7 +216,6 @@ "EditImages": "Editar imagenes", "EditMetadata": "Editar metadata", "EditSubtitles": "Editar subtitulos", - "EnableBackdrops": "Fondos", "EnableBackdropsHelp": "Muestra imágenes de fondo en el fondo de algunas páginas mientras se navega por la biblioteca.", "EnableCinemaMode": "Modo cine", "EnableColorCodedBackgrounds": "Habilitar colores en el fondo del código", @@ -319,7 +304,6 @@ "HeaderApiKey": "Contraseña API", "HeaderAllowMediaDeletionFrom": "Permitir el borrado de medios desde", "HeaderAlert": "Alerta", - "HeaderAlbums": "Albumes", "HeaderAdmin": "Admin", "HeaderAdditionalParts": "Partes adicionales", "HeaderAddUpdateImage": "Agregar/Actualizar imagen", @@ -356,7 +340,6 @@ "HeaderCodecProfileHelp": "Los perfiles de códec indican las limitaciones de un dispositivo cuando se reproducen códecs específicos. Si se aplica una limitación, los medios se transcodificarán, incluso si el códec está configurado para reproducción directa.", "HeaderCodecProfile": "Perfil del códec", "HeaderChapterImages": "Imágenes del capitulo", - "HeaderChannels": "Canales", "HeaderChannelAccess": "Acceso al canal", "HeaderCastCrew": "Reparto", "HeaderCastAndCrew": "Reparto", @@ -402,7 +385,6 @@ "HeaderLatestMedia": "Medios recientes", "HeaderKeepSeries": "Mantener serie", "HeaderKeepRecording": "Mantener grabación", - "HeaderItems": "Artículos", "HeaderInstantMix": "Mezcla instantánea", "HeaderInstall": "Instalar", "HeaderImageSettings": "Configuraciones de imagen", @@ -414,7 +396,6 @@ "HeaderHttpHeaders": "Encabezados HTTP", "HeaderHome": "Inicio", "HeaderGuideProviders": "Proveedores de datos de guías de TV", - "HeaderGenres": "Géneros", "HeaderFrequentlyPlayed": "Reproducido con frecuencia", "HeaderForgotPassword": "Olvidé la contraseña", "HeaderForKids": "Para niños", @@ -444,7 +425,6 @@ "HeaderMyDevice": "Mi dispositivo", "HeaderMusicVideos": "Videos musicales", "HeaderMusicQuality": "Calidad de música", - "HeaderMovies": "Películas", "LabelAccessDay": "Día de la semana:", "LabelAbortedByServerShutdown": "(Abortado por el apagado del servidor)", "Label3DFormat": "Formato 3D:", @@ -462,7 +442,6 @@ "HideWatchedContentFromLatestMedia": "Ocultar contenido visto de los últimos medios", "Hide": "Ocultar", "Help": "Ayuda", - "HeadersFolders": "Carpetas", "HeaderYears": "Años", "HeaderXmlSettings": "Configuraciones Xml", "HeaderXmlDocumentAttributes": "Atributos del documento Xml", @@ -496,7 +475,6 @@ "HeaderSpecialEpisodeInfo": "Información especial del capítulo", "HeaderSortOrder": "Orden de clasificación", "HeaderSortBy": "Ordenar por", - "HeaderShutdown": "Apagar", "HeaderSetupLibrary": "Configura tus bibliotecas de medios", "HeaderSettings": "Configuraciones", "HeaderServerSettings": "Configuración del servidor", @@ -755,7 +733,6 @@ "LabelRecordingPath": "Ruta de grabación predeterminada:", "LabelRecord": "Grabar:", "LabelReasonForTranscoding": "Motivo de la transcodificación:", - "LabelReadHowYouCanContribute": "Aprende cómo puedes contribuir.", "LabelPublicHttpsPortHelp": "El número de puerto público que debe asignarse al puerto HTTPS local.", "LabelPublicHttpsPort": "Número de puerto HTTPS público:", "LabelPublicHttpPortHelp": "El número de puerto público que debe asignarse al puerto HTTP local.", @@ -892,7 +869,6 @@ "Normal": "Normal", "None": "Nunguno", "NoSubtitlesHelp": "Los subtítulos no se cargarán de manera predeterminada. Todavía se pueden activar manualmente durante la reproducción.", - "NoSubtitles": "Ninguno", "NoSubtitleSearchResultsFound": "No se han encontrado resultados.", "MessageNoPluginConfiguration": "Este complemento no tiene opciones para configurar.", "MessageNoNextUpItems": "Nada encontrado. ¡Comienza a ver tus shows!", @@ -1404,8 +1380,6 @@ "Trailers": "Avances", "TabTrailers": "Avances", "TabStreaming": "Transmisión", - "TabSongs": "Canciones", - "TabShows": "Programas", "TabSettings": "Configuraciones", "TabServer": "Servidor", "TabSeries": "Series", @@ -1427,25 +1401,16 @@ "TabMyPlugins": "Mis complementos", "TabMusicVideos": "Videos musicales", "TabMusic": "Música", - "TabMovies": "Películas", "TabLogs": "Registros", "TabLiveTV": "TV en vivo", "TabLatest": "Último", "TabInfo": "Información", - "TabGuide": "Guía", - "TabGenres": "Géneros", - "TabFavorites": "Favoritos", - "TabDVR": "DVR", "TabDirectPlay": "Reproducción directa", - "TabDevices": "Dispositivos", "TabDashboard": "Tablero", "TabContainers": "Contenedores", - "TabCollections": "Colecciones", "TabCodecs": "Códecs", - "TabChannels": "Canales", "TabRepositories": "Repositorios", "TabCatalog": "Catálogo", - "TabAlbums": "Álbumes", "TabAlbumArtists": "Artistas del álbum", "TabAdvanced": "Avanzado", "TabAccess": "Acceso", diff --git a/src/strings/es-mx.json b/src/strings/es-mx.json index 643758b660..e682b2f4cb 100644 --- a/src/strings/es-mx.json +++ b/src/strings/es-mx.json @@ -35,7 +35,6 @@ "AsManyAsPossible": "Tantos como sea posible", "Ascending": "Ascendente", "AspectRatio": "Relación de aspecto", - "AttributeNew": "Nuevo", "Backdrop": "Imagen de fondo", "Backdrops": "Imágenes de fondo", "Banner": "Banner", @@ -54,19 +53,12 @@ "ButtonAddScheduledTaskTrigger": "Agregar disparador", "ButtonAddServer": "Agregar servidor", "ButtonAddUser": "Agregar usuario", - "ButtonArrowDown": "Abajo", "ButtonArrowLeft": "Izquierda", "ButtonArrowRight": "Derecha", - "ButtonArrowUp": "Arriba", "ButtonAudioTracks": "Pistas de audio", "ButtonBack": "Atrás", "ButtonCancel": "Cancelar", "ButtonChangeServer": "Cambiar servidor", - "ButtonConnect": "Conectar", - "ButtonDelete": "Eliminar", - "ButtonDeleteImage": "Eliminar imagen", - "ButtonDown": "Abajo", - "ButtonDownload": "Descargar", "ButtonEdit": "Editar", "ButtonEditImages": "Editar imágenes", "ButtonEditOtherUserPreferences": "Editar el perfil, la imagen y las preferencias personales de este usuario.", @@ -80,7 +72,6 @@ "ButtonManualLogin": "Inicio de sesión manual", "ButtonMore": "Más", "ButtonNetwork": "Red", - "ButtonNew": "Nuevo", "ButtonNextTrack": "Pista siguiente", "ButtonOff": "Apagar", "ButtonOpen": "Abrir", @@ -105,17 +96,14 @@ "ButtonSelectView": "Seleccionar vista", "ButtonSend": "Enviar", "ButtonSettings": "Configuración", - "ButtonShuffle": "Aleatorio", "ButtonShutdown": "Apagar", "ButtonSignIn": "Iniciar sesión", "ButtonSignOut": "Cerrar sesión", - "ButtonSort": "Ordenar", "ButtonStart": "Iniciar", "ButtonStop": "Detener", "ButtonSubmit": "Enviar", "ButtonSubtitles": "Subtítulos", "ButtonUninstall": "Desinstalar", - "ButtonUp": "Arriba", "ButtonWebsite": "Sitio web", "CancelRecording": "Cancelar grabación", "CancelSeries": "Cancelar serie", @@ -188,7 +176,6 @@ "EditImages": "Editar imágenes", "EditMetadata": "Editar metadatos", "EditSubtitles": "Editar subtítulos", - "EnableBackdrops": "Imágenes de fondo", "EnableBackdropsHelp": "Muestra imágenes de fondo en el fondo de algunas páginas mientras se navega por la biblioteca.", "EnableCinemaMode": "Modo cine", "EnableColorCodedBackgrounds": "Fondos de colores codificados", @@ -266,7 +253,6 @@ "HeaderAddUser": "Agregar usuario", "HeaderAdditionalParts": "Partes adicionales", "HeaderAlbumArtists": "Artistas del álbum", - "HeaderAlbums": "Álbumes", "HeaderAlert": "Alerta", "HeaderAllowMediaDeletionFrom": "Permitir eliminación de medios de", "HeaderApiKey": "Clave API", @@ -283,7 +269,6 @@ "HeaderCastAndCrew": "Reparto y equipo", "HeaderCastCrew": "Reparto y equipo", "HeaderChannelAccess": "Acceso a los canales", - "HeaderChannels": "Canales", "HeaderChapterImages": "Imágenes de los capítulos", "HeaderCodecProfile": "Perfil de códec", "HeaderCodecProfileHelp": "Los perfiles de códecs indican las limitaciones de un dispositivo al reproducir códecs específicos. Si una limitación se aplica entonces el medio será transcodificado, incluso si el códec ha sido configurado para reproducción directa.", @@ -324,7 +309,6 @@ "HeaderForKids": "Para niños", "HeaderForgotPassword": "Olvidé mi contraseña", "HeaderFrequentlyPlayed": "Reproducido frecuentemente", - "HeaderGenres": "Géneros", "HeaderGuideProviders": "Proveedores de Guías de TV", "HeaderHttpHeaders": "Encabezados HTTP", "HeaderIdentification": "Identificación", @@ -335,7 +319,6 @@ "HeaderImageSettings": "Configuración de imagen", "HeaderInstall": "Instalar", "HeaderInstantMix": "Mix instantáneo", - "HeaderItems": "Elementos", "HeaderKeepRecording": "Conservar grabación", "HeaderKeepSeries": "Conservar serie", "HeaderKodiMetadataHelp": "Para habilitar o deshabilitar los metadatos NFO, edite una biblioteca en la configuración de bibliotecas de Jellyfin y ubica la sección grabadores de metadatos.", @@ -358,7 +341,6 @@ "HeaderMediaInfo": "Info del medio", "HeaderMetadataSettings": "Configuración de metadatos", "HeaderMoreLikeThis": "Más como esto", - "HeaderMovies": "Películas", "HeaderMusicQuality": "Calidad de la música", "HeaderMusicVideos": "Videos musicales", "HeaderMyDevice": "Mi dispositivo", @@ -419,7 +401,6 @@ "HeaderServerSettings": "Configuración del servidor", "HeaderSettings": "Configuración", "HeaderSetupLibrary": "Configura tus bibliotecas de medios", - "HeaderShutdown": "Apagar", "HeaderSortBy": "Ordenar por", "HeaderSortOrder": "Clasificar ordenado", "HeaderSpecialEpisodeInfo": "Información del episodio especial", @@ -453,7 +434,6 @@ "HeaderXmlDocumentAttributes": "Atributos del documento XML", "HeaderXmlSettings": "Configuración XML", "HeaderYears": "Años", - "HeadersFolders": "Carpetas", "Help": "Ayuda", "Hide": "Ocultar", "HideWatchedContentFromLatestMedia": "Ocultar contenido ya visto de últimos medios", @@ -668,7 +648,6 @@ "LabelNewPassword": "Contraseña nueva:", "LabelNewPasswordConfirm": "Confirmación de contraseña nueva:", "LabelNewsCategories": "Categorías de noticias:", - "LabelNext": "Siguiente", "LabelNotificationEnabled": "Habilitar esta notificación", "LabelNumber": "Número:", "LabelNumberOfGuideDays": "Número de días de datos de la programación a descargar:", @@ -695,7 +674,6 @@ "LabelPreferredDisplayLanguage": "Idioma de pantalla preferido:", "LabelPreferredDisplayLanguageHelp": "La traducción de Jellyfin es un proyecto en curso.", "LabelPreferredSubtitleLanguage": "Idioma preferido para los subtítulos:", - "LabelPrevious": "Anterior", "LabelProfileAudioCodecs": "Códecs de audio:", "LabelProfileCodecsHelp": "Separados por comas. Puede dejarse vacío para aplicarlo a todos los códecs.", "LabelProfileContainer": "Contenedor:", @@ -708,7 +686,6 @@ "LabelPublicHttpPortHelp": "El número de puerto público que debe asignarse al puerto HTTP local.", "LabelPublicHttpsPort": "Número de puerto HTTPS público:", "LabelPublicHttpsPortHelp": "El número de puerto público que debe asignarse al puerto HTTPS local.", - "LabelReadHowYouCanContribute": "Aprende cómo puedes contribuir.", "LabelReasonForTranscoding": "Motivo para transcodificar:", "LabelRecord": "Grabar:", "LabelRecordingPath": "Ruta por defecto para las grabaciones:", @@ -914,7 +891,6 @@ "MessageNoNextUpItems": "No se encontró nada. ¡Comienza a ver tus programas!", "MessageNoPluginConfiguration": "Este complemento no tiene configuraciones disponibles.", "NoSubtitleSearchResultsFound": "No se encontraron resultados.", - "NoSubtitles": "Ninguno", "NoSubtitlesHelp": "Los subtítulos no serán cargados por defecto. Pueden ser activados manualmente durante la reproducción.", "None": "Ninguno", "NumLocationsValue": "{0} carpetas", @@ -1189,22 +1165,14 @@ "TabAccess": "Acceso", "TabAdvanced": "Avanzado", "TabAlbumArtists": "Artistas del álbum", - "TabAlbums": "Álbumes", "TabCatalog": "Catálogo", - "TabChannels": "Canales", - "TabCollections": "Colecciones", "TabContainers": "Contenedores", "TabDashboard": "Panel de control", - "TabDevices": "Dispositivos", "TabDirectPlay": "Reproducción directa", "TabEpisodes": "Episodios", - "TabFavorites": "Favoritos", - "TabGenres": "Géneros", - "TabGuide": "Guía", "TabLatest": "Recientes", "TabLiveTV": "TV en vivo", "TabLogs": "Registros", - "TabMovies": "Películas", "TabMusic": "Música", "TabMusicVideos": "Videos musicales", "TabMyPlugins": "Mis complementos", @@ -1224,8 +1192,6 @@ "TabScheduledTasks": "Tareas programadas", "TabServer": "Servidor", "TabSettings": "Configuración", - "TabShows": "Programas", - "TabSongs": "Canciones", "TabStreaming": "Transmisión", "TabTrailers": "Trailers", "TabUpcoming": "Próximamente", @@ -1454,7 +1420,6 @@ "HeaderFavoritePlaylists": "Listas de reproducción favoritas", "ButtonTogglePlaylist": "Lista de reproducción", "UnsupportedPlayback": "Jellyfin no puede desencriptar contenido protegido por DRM de todas formas todo el contenido será intentado, incluyendo los títulos protegidos. Algunos archivos pueden aparecer completamente en negro debido al encriptado o características no soportadas, como títulos interactivos.", - "TabDVR": "DVR", "SaveChanges": "Guardar cambios", "LabelRequireHttpsHelp": "Si se marca, el servidor redirigirá automáticamente todas las solicitudes a través de HTTP a HTTPS. Esto no tiene efecto si el servidor no está escuchando en HTTPS.", "LabelRequireHttps": "Requerir HTTPS", diff --git a/src/strings/es.json b/src/strings/es.json index 3ee716038c..3bd59126a9 100644 --- a/src/strings/es.json +++ b/src/strings/es.json @@ -27,7 +27,6 @@ "Artists": "Artistas", "AsManyAsPossible": "Tantos como sea posible", "AspectRatio": "Relación de aspecto", - "AttributeNew": "Nuevo", "Backdrop": "Imagen de fondo", "Backdrops": "Imágenes de fondo", "BirthDateValue": "Nacido: {0}", @@ -44,19 +43,12 @@ "ButtonAddScheduledTaskTrigger": "Agregar Activador", "ButtonAddServer": "Añadir servidor", "ButtonAddUser": "Agregar Usuario", - "ButtonArrowDown": "Abajo", "ButtonArrowLeft": "Izquierda", "ButtonArrowRight": "Derecha", - "ButtonArrowUp": "Arriba", "ButtonAudioTracks": "Pistas de audio", "ButtonBack": "Atrás", "ButtonCancel": "Cancelar", "ButtonChangeServer": "Cambiar servidor", - "ButtonConnect": "Conectar", - "ButtonDelete": "Borrar", - "ButtonDeleteImage": "Borrar imagen", - "ButtonDown": "Abajo", - "ButtonDownload": "Descargar", "ButtonEdit": "Editar", "ButtonEditImages": "Editar imágenes", "ButtonEditOtherUserPreferences": "Editar este perfil, la imagen y los ajustes personales.", @@ -70,7 +62,6 @@ "ButtonManualLogin": "Acceder manualmente", "ButtonMore": "Más", "ButtonNetwork": "Red", - "ButtonNew": "Nuevo", "ButtonNextTrack": "Pista siguiente", "ButtonOff": "Apagado", "ButtonOk": "OK", @@ -96,18 +87,15 @@ "ButtonSelectView": "Seleccionar vista", "ButtonSend": "Enviar", "ButtonSettings": "Opciones", - "ButtonShuffle": "Mezclar", "ButtonShutdown": "Apagar", "ButtonSignIn": "Iniciar sesión", "ButtonSignOut": "Desconectarse", - "ButtonSort": "Ordenar", "ButtonStart": "Inicio", "ButtonStop": "Detener", "ButtonSubmit": "Enviar", "ButtonSubtitles": "Subtítulos", "ButtonTrailer": "Tráiler", "ButtonUninstall": "Desinstalar", - "ButtonUp": "Arriba", "ButtonWebsite": "Sitio web", "CancelRecording": "Cancelar grabación", "CancelSeries": "Cancelar series", @@ -236,7 +224,6 @@ "HeaderCastAndCrew": "Reparto y equipo", "HeaderCastCrew": "Reparto y equipo técnico", "HeaderChannelAccess": "Acceso a los canales", - "HeaderChannels": "Canales", "HeaderChapterImages": "Imágenes de capítulos", "HeaderCodecProfile": "Perfil de códec", "HeaderCodecProfileHelp": "Los perfiles de los códecs indican las limitaciones de un dispositivo cuando reproduce un códec en específico. Si lo que se va a reproducir no está dentro de estos límites (por ejemplo, bitrate demasiado alto), el contenido se convertirá, incluso si el códec está configurado para reproducción directa.", @@ -277,7 +264,6 @@ "HeaderForKids": "Para niños", "HeaderForgotPassword": "Contraseña olvidada", "HeaderFrequentlyPlayed": "Reproducido frecuentemente", - "HeaderGenres": "Géneros", "HeaderGuideProviders": "Proveedores de guías", "HeaderHttpHeaders": "Cabeceras HTTP", "HeaderIdentification": "Identificación", @@ -288,7 +274,6 @@ "HeaderImageSettings": "Ajustes de imagen", "HeaderInstall": "Instalar", "HeaderInstantMix": "Mezcla instantánea", - "HeaderItems": "Elementos", "HeaderKeepRecording": "Mantener grabación", "HeaderKeepSeries": "Mantener series", "HeaderKodiMetadataHelp": "Puedes activar o desactivar las etiquetas en formato NFO abriendo la configuración de una biblioteca y revisando los ajustes en la sección de etiquetas.", @@ -311,7 +296,6 @@ "HeaderMediaInfo": "Información multimedia", "HeaderMetadataSettings": "Ajustes de etiquetas", "HeaderMoreLikeThis": "Más como este", - "HeaderMovies": "Películas", "HeaderMusicVideos": "Vídeos musicales", "HeaderMyDevice": "Mi dispositivo", "HeaderMyMedia": "Mis contenidos", @@ -369,7 +353,6 @@ "HeaderServerSettings": "Ajustes del servidor", "HeaderSettings": "Ajustes", "HeaderSetupLibrary": "Configure sus bibliotecas de medios", - "HeaderShutdown": "Apagar", "HeaderSortBy": "Ordenar por", "HeaderSortOrder": "Orden", "HeaderSpecialEpisodeInfo": "Información del episodio especial", @@ -401,7 +384,6 @@ "HeaderXmlDocumentAttributes": "Atributos del documento xml", "HeaderXmlSettings": "Ajustes xml", "HeaderYears": "Años", - "HeadersFolders": "Carpetas", "Help": "Ayuda", "Hide": "Ocultar", "HideWatchedContentFromLatestMedia": "Esconder medios vistos de los medios más recientes", @@ -609,7 +591,6 @@ "LabelNewPassword": "Nueva contraseña:", "LabelNewPasswordConfirm": "Confirmación de la nueva contraseña:", "LabelNewsCategories": "Categorías de noticias:", - "LabelNext": "Siguiente", "LabelNotificationEnabled": "Activar esta notificación", "LabelNumber": "Número:", "LabelNumberOfGuideDays": "Número de días a descargar de la guía:", @@ -634,7 +615,6 @@ "LabelPreferredDisplayLanguage": "Idioma preferido visualizado:", "LabelPreferredDisplayLanguageHelp": "La traducción de Jellyfin es un proyecto en marcha.", "LabelPreferredSubtitleLanguage": "Idioma de subtítulos preferido:", - "LabelPrevious": "Anterior", "LabelProfileAudioCodecs": "Códecs de audio:", "LabelProfileCodecs": "Códecs:", "LabelProfileCodecsHelp": "Separados por comas. Esto se puede dejar vacío para aplicar a todos los códecs.", @@ -648,7 +628,6 @@ "LabelPublicHttpPortHelp": "Número de puerto público que debe ser enlazado al puerto HTTP local.", "LabelPublicHttpsPort": "Puerto público HTTPS:", "LabelPublicHttpsPortHelp": "Puerto público que debe ser enlazado al puerto local HTTPS.", - "LabelReadHowYouCanContribute": "Aprenda cómo contribuir.", "LabelReasonForTranscoding": "Motivo por el que se realiza la conversión:", "LabelRecord": "Grabar:", "LabelRecordingPath": "Ruta de grabaciones por defecto:", @@ -839,7 +818,6 @@ "MessageNoNextUpItems": "Nada encontrado. ¡Comienza a ver tus programas!", "MessageNoPluginConfiguration": "Este complemento no tiene opciones que configurar.", "NoSubtitleSearchResultsFound": "No se han encontrado resultados.", - "NoSubtitles": "Sin subtítulos", "NoSubtitlesHelp": "Los subtítulos no se cargarán de forma predeterminada. Tienen que ser activados manualmente durante la reproducción.", "None": "Nada", "NumLocationsValue": "{0} carpetas", @@ -1090,22 +1068,14 @@ "TabAccess": "Acceso", "TabAdvanced": "Avanzado", "TabAlbumArtists": "Artistas de los álbumes", - "TabAlbums": "Álbumes", "TabCatalog": "Catálogo", - "TabChannels": "Canales", "TabCodecs": "Códecs", - "TabCollections": "Colecciones", "TabContainers": "Contenedores", "TabDashboard": "Panel de control", - "TabDevices": "Dispositivos", "TabDirectPlay": "Reproducción directa", "TabEpisodes": "Episodios", - "TabFavorites": "Favoritos", - "TabGenres": "Géneros", - "TabGuide": "Guía", "TabLatest": "Novedades", "TabLiveTV": "Televisión en directo", - "TabMovies": "Películas", "TabMusic": "Música", "TabMusicVideos": "Videos musicales", "TabMyPlugins": "Mis extensiones", @@ -1124,8 +1094,6 @@ "TabScheduledTasks": "Tareas programadas", "TabServer": "Servidor", "TabSettings": "Opciones", - "TabShows": "Programas", - "TabSongs": "Canciones", "TabStreaming": "Transmisión", "TabUpcoming": "Próximos", "TabUsers": "Usuarios", @@ -1222,7 +1190,6 @@ "DisplayMissingEpisodesWithinSeasonsHelp": "Esto también debe ser habilitado para la biblioteca de TV en la configuración del servidor.", "DropShadow": "Eliminar sombra", "EditMetadata": "Editar etiquetas", - "EnableBackdrops": "Imágenes de fondo", "EnableBackdropsHelp": "Mostrar imágenes de fondo en algunas páginas mientras se explora la biblioteca.", "EnableColorCodedBackgrounds": "Fondos con código de colores", "EnableExternalVideoPlayersHelp": "Se mostrará un menú para reproductor externo cuando comience la reproducción del vídeo.", @@ -1240,7 +1207,6 @@ "GroupBySeries": "Agrupar por series", "GuideProviderLogin": "Credenciales", "HeaderAlbumArtists": "Artistas del álbum", - "HeaderAlbums": "Álbumes", "HeaderApp": "Aplicación", "HeaderAppearsOn": "Aparece en", "HeaderBranding": "Remarcado", @@ -1467,7 +1433,6 @@ "LabelRequireHttps": "Necesita HTTPS", "LabelEnableHttpsHelp": "Permite que el servidor escuche en el puerto HTTPS configurado. También se debe configurar un certificado válido para que esto surta efecto.", "LabelEnableHttps": "Activar HTTPS", - "TabDVR": "DVR", "SaveChanges": "Guardar cambios", "EnableBlurHash": "Mostrar una representación de las imágenes mientras cargan", "EnableBlurHashHelp": "Aparecerá una representación de los colores de las imágenes antes de que terminen de cargar", diff --git a/src/strings/es_419.json b/src/strings/es_419.json index 7f1702c910..815018e9c3 100644 --- a/src/strings/es_419.json +++ b/src/strings/es_419.json @@ -133,8 +133,6 @@ "TabUsers": "Usuarios", "TabUpcoming": "Próximamente", "TabStreaming": "Transmisión", - "TabSongs": "Canciones", - "TabShows": "Programas", "TabSettings": "Configuración", "TabServer": "Servidor", "TabSeries": "Series", @@ -156,22 +154,14 @@ "TabMyPlugins": "Mis complementos", "TabMusicVideos": "Videos musicales", "TabMusic": "Música", - "TabMovies": "Películas", "TabLogs": "Registros", "TabLiveTV": "TV en vivo", "TabInfo": "Información", - "TabGuide": "Guía", - "TabGenres": "Géneros", - "TabFavorites": "Favoritos", "TabEpisodes": "Episodios", - "TabDVR": "DVR", "TabDirectPlay": "Reproducción directa", - "TabDevices": "Dispositivos", "TabDashboard": "Panel de control", "TabContainers": "Contenedores", - "TabCollections": "Colecciones", "TabCodecs": "Códecs", - "TabChannels": "Canales", "TabCatalog": "Catálogo", "OptionPoster": "Póster", "OptionPlayed": "Reproducido", @@ -294,7 +284,6 @@ "Normal": "Normal", "None": "Ninguno", "NoSubtitlesHelp": "Los subtítulos no serán cargados por defecto. Pueden ser activados manualmente durante la reproducción.", - "NoSubtitles": "Ninguno", "NoSubtitleSearchResultsFound": "No se encontraron resultados.", "MessageNoPluginConfiguration": "Este complemento no tiene configuraciones disponibles.", "MessageNoNextUpItems": "No se encontró nada. ¡Comienza a ver tus programas!", @@ -682,7 +671,6 @@ "LabelRecordingPath": "Ruta por defecto para las grabaciones:", "LabelRecord": "Grabar:", "LabelReasonForTranscoding": "Motivo para transcodificar:", - "LabelReadHowYouCanContribute": "Aprende cómo puedes contribuir.", "LabelPublicHttpsPortHelp": "El número de puerto público que debe asignarse al puerto HTTPS local.", "LabelPublicHttpsPort": "Número de puerto HTTPS público:", "LabelPublicHttpPortHelp": "El número de puerto público que debe asignarse al puerto HTTP local.", @@ -696,7 +684,6 @@ "LabelProfileCodecsHelp": "Separados por comas. Puede dejarse vacío para aplicarlo a todos los códecs.", "LabelProfileCodecs": "Códecs:", "LabelProfileAudioCodecs": "Códecs de audio:", - "LabelPrevious": "Anterior", "LabelPreferredSubtitleLanguage": "Idioma preferido para los subtítulos:", "LabelPreferredDisplayLanguageHelp": "La traducción de Jellyfin es un proyecto en curso.", "LabelPreferredDisplayLanguage": "Idioma de pantalla preferido:", @@ -728,7 +715,6 @@ "LabelNumberOfGuideDays": "Número de días de datos de la programación a descargar:", "LabelNumber": "Número:", "LabelNotificationEnabled": "Habilitar esta notificación", - "LabelNext": "Siguiente", "LabelNewsCategories": "Categorías de noticias:", "LabelNewPasswordConfirm": "Confirmación de contraseña nueva:", "LabelNewPassword": "Contraseña nueva:", @@ -865,7 +851,6 @@ "LabelChannels": "Canales:", "LabelCertificatePasswordHelp": "Si tu certificado requiere una contraseña, por favor, introdúcela aquí.", "LabelCertificatePassword": "Contraseña del certificado:", - "TabAlbums": "Álbumes", "TabAlbumArtists": "Artistas del álbum", "TabAdvanced": "Avanzado", "TabAccess": "Acceso", @@ -990,7 +975,6 @@ "HideWatchedContentFromLatestMedia": "Ocultar contenido ya visto de últimos medios", "Hide": "Ocultar", "Help": "Ayuda", - "HeadersFolders": "Carpetas", "HeaderYears": "Años", "HeaderXmlSettings": "Configuración XML", "HeaderXmlDocumentAttributes": "Atributos del documento XML", @@ -1025,7 +1009,6 @@ "HeaderSpecialEpisodeInfo": "Información del episodio especial", "HeaderSortOrder": "Clasificar ordenado", "HeaderSortBy": "Ordenar por", - "HeaderShutdown": "Apagar", "HeaderSetupLibrary": "Configura tus bibliotecas de medios", "HeaderSettings": "Configuración", "HeaderServerSettings": "Configuración del servidor", @@ -1081,7 +1064,6 @@ "HeaderMyDevice": "Mi dispositivo", "HeaderMusicVideos": "Videos musicales", "HeaderMusicQuality": "Calidad de la música", - "HeaderMovies": "Películas", "HeaderMoreLikeThis": "Más como esto", "HeaderMetadataSettings": "Configuración de metadatos", "HeaderMediaInfo": "Info del medio", @@ -1103,7 +1085,6 @@ "HeaderKodiMetadataHelp": "Para habilitar o deshabilitar los metadatos NFO, edita una biblioteca y ubica la sección de grabadores de metadatos.", "HeaderKeepSeries": "Conservar serie", "HeaderKeepRecording": "Conservar grabación", - "HeaderItems": "Elementos", "HeaderInstantMix": "Mix instantáneo", "HeaderInstall": "Instalar", "HeaderImageSettings": "Configuración de imagen", @@ -1116,7 +1097,6 @@ "HeaderHttpHeaders": "Encabezados HTTP", "HeaderHome": "Inicio", "HeaderGuideProviders": "Proveedores de Guías de TV", - "HeaderGenres": "Géneros", "HeaderFrequentlyPlayed": "Reproducido frecuentemente", "HeaderForgotPassword": "Olvidé mi contraseña", "HeaderForKids": "Para niños", @@ -1201,7 +1181,6 @@ "HeaderCodecProfileHelp": "Los perfiles de códecs indican las limitaciones de un dispositivo al reproducir códecs específicos. Si una limitación se aplica entonces el medio será transcodificado, incluso si el códec ha sido configurado para reproducción directa.", "HeaderCodecProfile": "Perfil de códec", "HeaderChapterImages": "Imágenes de los capítulos", - "HeaderChannels": "Canales", "HeaderChannelAccess": "Acceso a los canales", "HeaderCastCrew": "Reparto y equipo", "HeaderCastAndCrew": "Reparto y equipo", @@ -1220,7 +1199,6 @@ "HeaderApiKey": "Clave API", "HeaderAllowMediaDeletionFrom": "Permitir eliminación de medios de", "HeaderAlert": "Alerta", - "HeaderAlbums": "Álbumes", "HeaderAdmin": "Administrador", "HeaderAdditionalParts": "Partes adicionales", "HeaderAddUser": "Agregar usuario", @@ -1301,7 +1279,6 @@ "EnableColorCodedBackgrounds": "Fondos de colores codificados", "EnableCinemaMode": "Modo cine", "EnableBackdropsHelp": "Muestra imágenes de fondo en el fondo de algunas páginas mientras se navega por la biblioteca.", - "EnableBackdrops": "Imágenes de fondo", "EditSubtitles": "Editar subtítulos", "EditMetadata": "Editar metadatos", "EditImages": "Editar imágenes", @@ -1382,7 +1359,6 @@ "CancelSeries": "Cancelar serie", "CancelRecording": "Cancelar grabación", "ButtonWebsite": "Sitio web", - "ButtonUp": "Arriba", "ButtonUninstall": "Desinstalar", "ButtonTrailer": "Trailer", "ButtonTogglePlaylist": "Lista de reproducción", @@ -1391,11 +1367,9 @@ "ButtonSplit": "Dividir", "ButtonStop": "Detener", "ButtonStart": "Iniciar", - "ButtonSort": "Ordenar", "ButtonSignOut": "Cerrar sesión", "ButtonSignIn": "Iniciar sesión", "ButtonShutdown": "Apagar", - "ButtonShuffle": "Aleatorio", "ButtonSettings": "Configuración", "ButtonSend": "Enviar", "ButtonSelectView": "Seleccionar vista", @@ -1421,7 +1395,6 @@ "ButtonOk": "OK", "ButtonOff": "Apagar", "ButtonNextTrack": "Pista siguiente", - "ButtonNew": "Nuevo", "ButtonNetwork": "Red", "ButtonMore": "Más", "ButtonManualLogin": "Inicio de sesión manual", @@ -1436,19 +1409,12 @@ "ButtonEditOtherUserPreferences": "Editar el perfil, la imagen y las preferencias personales de este usuario.", "ButtonEditImages": "Editar imágenes", "ButtonEdit": "Editar", - "ButtonDownload": "Descargar", - "ButtonDown": "Abajo", - "ButtonDeleteImage": "Eliminar imagen", - "ButtonDelete": "Eliminar", - "ButtonConnect": "Conectar", "ButtonChangeServer": "Cambiar servidor", "ButtonCancel": "Cancelar", "ButtonBack": "Atrás", "ButtonAudioTracks": "Pistas de audio", - "ButtonArrowUp": "Arriba", "ButtonArrowRight": "Derecha", "ButtonArrowLeft": "Izquierda", - "ButtonArrowDown": "Abajo", "ButtonAddUser": "Agregar usuario", "ButtonAddServer": "Agregar servidor", "ButtonAddScheduledTaskTrigger": "Agregar disparador", @@ -1470,7 +1436,6 @@ "Auto": "Auto", "AuthProviderHelp": "Selecciona el proveedor de autenticación que se utilizará para autenticar la contraseña de este usuario.", "Audio": "Audio", - "AttributeNew": "Nuevo", "AspectRatio": "Relación de aspecto", "AskAdminToCreateLibrary": "Pide a un administrador crear una biblioteca.", "Ascending": "Ascendente", diff --git a/src/strings/fa.json b/src/strings/fa.json index 5db3a657ca..a764f28998 100644 --- a/src/strings/fa.json +++ b/src/strings/fa.json @@ -7,15 +7,12 @@ "Browse": "مرور کردن", "ButtonAddUser": "افزودن کاربر", "ButtonCancel": "لغو کردن", - "ButtonDeleteImage": "حذف عکس", "ButtonFilter": "فیلتر", - "ButtonNew": "جدید", "ButtonOk": "خوب", "ButtonPlay": "پخش", "ButtonQuickStartGuide": "راهنمای شروع سریع", "ButtonResetPassword": "تنظیم مجدد رمز", "ButtonSignOut": "Sign out", - "ButtonSort": "مرتب سازی", "DeleteMedia": "حذف رسانه", "Disabled": "غیرفعال شده", "FolderTypeBooks": "کتاب‌ها", @@ -54,8 +51,6 @@ "LabelMaxParentalRating": "حداکثر امتیاز سنی مجاز والدین:", "LabelNewPassword": "رمز جدید:", "LabelNewPasswordConfirm": "تایید رمز جدید:", - "LabelNext": "بعدی", - "LabelPrevious": "قبلی", "LabelProfileCodecsHelp": "جدا شده توسط کاما این می تواند برای همه کدک ها اعمال شود.", "LabelSaveLocalMetadata": "پوستر در پوشه مدیا ذخیره گردد", "LabelSaveLocalMetadataHelp": "ذخیره ی پوستر ها داخل پوشه های رسانه، امکان ویرایش آسان آنها را در یک مکان میسر میکند.", @@ -86,9 +81,7 @@ "TabAccess": "دسترسی", "TabAdvanced": "پیشرفته", "TabAlbumArtists": "هنرمندان آلبوم", - "TabAlbums": "آلبوم ها", "TabEpisodes": "قسمت ها", - "TabGenres": "ژانرها", "TabLatest": "جدیدترین‌ها", "TabMusicVideos": "موزیک ویدیوها", "TabNetworks": "شبکه ها", @@ -96,8 +89,6 @@ "TabPassword": "رمز عبور", "TabProfile": "پروفایل", "TabProfiles": "پروفایل ها", - "TabShows": "سریال ها", - "TabSongs": "آهنگ ها", "TabUpcoming": "بزودی", "TellUsAboutYourself": "در مورد خودتان به ما بگویید", "ThisWizardWillGuideYou": "این عمل برای انجام تنظیمات به شما کمک می‌کند. برای شروع، لطفا زبان مورد نظر خود را انتخاب کنید.", @@ -134,7 +125,6 @@ "Add": "افزودن", "Actor": "بازیگر", "AccessRestrictedTryAgainLater": "دسترسی در حال حاضر محدود شده است. لطفا دوباره تلاش کنید.", - "ButtonShuffle": "مخلوط کردن", "ButtonSettings": "تنظیمات", "ButtonSend": "ارسال", "ButtonSelectView": "انتخاب نما", @@ -167,16 +157,10 @@ "ButtonForgotPassword": "فراموشی گذرواژه", "ButtonEditImages": "ویرایش عکس‌ها", "ButtonEdit": "ویرایش", - "ButtonDownload": "بارگیری", - "ButtonDown": "پایین", - "ButtonDelete": "حذف", - "ButtonConnect": "اتصال", "ButtonChangeServer": "تغییر سرور", "ButtonBack": "بازگشت", - "ButtonArrowUp": "بالا", "ButtonArrowRight": "راست", "ButtonArrowLeft": "چپ", - "ButtonArrowDown": "پایین", "ButtonAddServer": "افزودن سرور", "ButtonAddScheduledTaskTrigger": "افزودن راه انداز", "ButtonAddMediaLibrary": "افزودن کتابخانه رسانه", @@ -192,7 +176,6 @@ "Backdrop": "پس زمینه", "Auto": "خودکار", "Audio": "صدا", - "AttributeNew": "جدید", "AspectRatio": "نسبت ابعاد", "AskAdminToCreateLibrary": "از کاربر مدیر بخواهید که یک کتابخانه ایجاد کند.", "Ascending": "بالا رونده", @@ -226,7 +209,6 @@ "EnableExternalVideoPlayers": "پخش کننده ویدیوی خارجی", "EnableDisplayMirroring": "نمایش آینه", "EnableCinemaMode": "حالت سینما", - "EnableBackdrops": "پشت‌زمینه‌ها", "EditSubtitles": "ویرایش زیرنویس‌ها", "EditMetadata": "ویرایش فراداده", "EditImages": "ویرایش عکس‌ها", @@ -285,7 +267,6 @@ "CancelSeries": "لغو سریال‌ها", "CancelRecording": "لغو ضبط", "ButtonWebsite": "وبسایت", - "ButtonUp": "بالا", "ButtonUninstall": "حذف نصب", "ButtonTrailer": "تریلر", "ButtonSubtitles": "زیرنویس‌ها", @@ -326,7 +307,6 @@ "HeaderMyDevice": "دستگاه‌های من", "HeaderMusicVideos": "موزیک ویدیوها", "HeaderMusicQuality": "کیفیت آهنگ", - "HeaderMovies": "فیلم‌ها", "HeaderMoreLikeThis": "موارد مشابه با این", "HeaderMetadataSettings": "تنظیمات ابرداده", "HeaderMediaInfo": "اطلاعات رسانه", @@ -346,7 +326,6 @@ "HeaderLatestMedia": "جدیدترین‌ رسانه‌ها", "HeaderKeepSeries": "سریال ادامه دهید", "HeaderKeepRecording": "ضبط را ادامه دهید", - "HeaderItems": "آیتم‌ها", "HeaderInstall": "نصب", "HeaderImageSettings": "تنظیمات عکس", "HeaderIdentifyItemHelp": "یک یا بیشتر مورد برای جستجو وارد کنید. موارد را حذف کنید تا نتیجه جستجو را افزایش دهید.", @@ -356,7 +335,6 @@ "HeaderHttpHeaders": "سرفصل‌های HTTP", "HeaderHome": "خانه", "HeaderGuideProviders": "ارائه دهنده داده راهنمای تلویزیونی", - "HeaderGenres": "ژانرها", "HeaderFrequentlyPlayed": "اغلب پخش شده", "HeaderForgotPassword": "فراموشی گذرواژه", "HeaderForKids": "برای کودکان", @@ -388,7 +366,6 @@ "HeaderCodecProfileHelp": "نمایه‌های کدک محدودیت‌های یک دستگاه را هنگام پخش کدک‌های خاص نشان می‌دهد. اگر محدودیتی اعمال شود، رسانه‌ها کد گذاری می‌شوند ، حتی اگر کدک برای پخش مستقیم پیکربندی شده باشد.", "HeaderCodecProfile": "نمایه کدک", "HeaderChapterImages": "عکس‌های سکانس", - "HeaderChannels": "کانال‌ها", "HeaderChannelAccess": "دسترسی به کانال", "HeaderCastCrew": "بازیگران و کارکنان", "HeaderCastAndCrew": "بازیگران و کارکنان", @@ -450,7 +427,6 @@ "FolderTypeUnset": "محتواهای مخلوط", "TabMyPlugins": "افزونه‌های من", "TabMusic": "موسیقی‌ها", - "TabMovies": "فیلم‌ها", "TabLogs": "واقعه نگار‌ها", "TabLiveTV": "تلویزیون زنده", "LatestFromLibrary": "جدیدترین‌های {0}", @@ -617,14 +593,9 @@ "OptionOnInterval": "در یک فاصله", "BookLibraryHelp": "کتاب‌های صوتی و متنی پشتیبانی می‌شوند. {0} راهنمای نامگذاری کتاب {1} را مرور کنید.", "TabInfo": "اطلاعات", - "TabGuide": "راهنما", - "TabFavorites": "مورد علاقه‌ها", "TabDirectPlay": "پخش مستقیم", - "TabDevices": "دستگاه‌ها", "TabDashboard": "داشبورد", - "TabCollections": "مجموعه‌ها", "TabCodecs": "کدک‌ها", - "TabChannels": "کانال‌ها", "TabCatalog": "فهرست", "TV": "تلویزیون", "Sunday": "یکشنبه", @@ -765,7 +736,6 @@ "LabelSeasonNumber": "شماره فصل:", "ConfigureDateAdded": "تنظیم کنید که چگونه تاریخ اضافه شده در داشبورد سرور Jellyfin تحت تنظیمات کتابخانه تعیین می‌شود", "CinemaModeConfigurationHelp": "حالت سینما تجربه تئاتر گونه را مستقیم به اتاق نشیمن شما می‌آورد با قابلیت پخش تریلرها و پیش نمایش‌ها قبل از سایر ویژگی‌های اصلی.", - "NoSubtitles": "خالی", "NoSubtitleSearchResultsFound": "نتیجه‌ای یافت نشد.", "MessageNoPluginConfiguration": "این افزونه هیچ تنظیماتی برای پیکربندی ندارد.", "No": "خیر", @@ -919,7 +889,6 @@ "HeaderAddUpdateImage": "Add/Update Image", "HeaderAdditionalParts": "Additional Parts", "HeaderAdmin": "Admin", - "HeaderAlbums": "Albums", "HeaderAlert": "Alert", "HeaderAllowMediaDeletionFrom": "Allow Media Deletion From", "HeaderApiKey": "API Key", @@ -1037,7 +1006,6 @@ "HeaderServerAddressSettings": "Server Address Settings", "HeaderServerSettings": "Server Settings", "HeaderSettings": "Settings", - "HeaderShutdown": "Shutdown", "HeaderSortBy": "Sort By", "HeaderSortOrder": "Sort Order", "HeaderSpecialEpisodeInfo": "Special Episode Info", @@ -1070,7 +1038,6 @@ "HeaderXmlDocumentAttributes": "Xml Document Attributes", "HeaderXmlSettings": "Xml Settings", "HeaderYears": "Years", - "HeadersFolders": "Folders", "Help": "Help", "Hide": "Hide", "HideWatchedContentFromLatestMedia": "Hide watched content from latest media", @@ -1208,7 +1175,6 @@ "LabelPublicHttpPortHelp": "The public port number that should be mapped to the local HTTP port.", "LabelPublicHttpsPort": "Public HTTPS port number:", "LabelPublicHttpsPortHelp": "The public port number that should be mapped to the local HTTPS port.", - "LabelReadHowYouCanContribute": "Learn how you can contribute.", "LabelReasonForTranscoding": "Reason for transcoding:", "LabelRecord": "Record:", "LabelRecordingPath": "Default recording path:", @@ -1497,7 +1463,6 @@ "SyncPlayAccessHelp": "Select the level of access this user has to the SyncPlay feature. SyncPlay enables to sync playback with other devices.", "SystemDlnaProfilesHelp": "System profiles are read-only. Changes to a system profile will be saved to a new custom profile.", "TabContainers": "Containers", - "TabDVR": "DVR", "TvLibraryHelp": "Review the {0}TV naming guide{1}.", "UserAgentHelp": "Supply a custom user-agent HTTP header.", "ValueContainer": "Container: {0}", diff --git a/src/strings/fi.json b/src/strings/fi.json index fd514ddb77..3b17554efc 100644 --- a/src/strings/fi.json +++ b/src/strings/fi.json @@ -2,7 +2,6 @@ "MessageBrowsePluginCatalog": "Selaa lisäosakuvastoamme katsoaksesi saatavilla olevia lisäosia.", "ButtonAddUser": "Lisää Käyttäjä", "ButtonCancel": "Peruuta", - "ButtonDeleteImage": "Poista Kuva", "ButtonResetPassword": "Nollaa salasana", "ButtonSignOut": "Sign out", "Delete": "Poista", @@ -24,8 +23,6 @@ "LabelMaxParentalRating": "Suurin sallittu ikäraja:", "LabelNewPassword": "Uusi salasana:", "LabelNewPasswordConfirm": "Uuden salasanan varmistus:", - "LabelNext": "Seuraava", - "LabelPrevious": "Edellinen", "LabelSaveLocalMetadata": "Tallenna kuvamateriaali mediakansioihin", "LabelSaveLocalMetadataHelp": "Kuvamateriaalin ja metadatan tallentaminen suoraan kansioihin missä niitä on helppo muuttaa.", "LabelYoureDone": "Valmista!", @@ -83,7 +80,6 @@ "AsManyAsPossible": "Niin monta kuin mahdollista", "Ascending": "Nousevassa järjestyksessä", "AspectRatio": "Kuvasuhde", - "AttributeNew": "Uusi", "Audio": "Ääni", "AuthProviderHelp": "Valitse todentamispalvelu, jota käytetään tämän käyttäjän salasanan todentamisessa.", "Auto": "Auto", @@ -102,17 +98,11 @@ "ButtonAddMediaLibrary": "Lisää Mediakirjasto", "ButtonAddScheduledTaskTrigger": "Lisää Liipaisin", "ButtonAddServer": "Lisää Palvelin", - "ButtonArrowDown": "Alas", "ButtonArrowLeft": "Vasen", "ButtonArrowRight": "Oikea", - "ButtonArrowUp": "Ylös", "ButtonAudioTracks": "Ääniraidat", "ButtonBack": "Takaisin", "ButtonChangeServer": "Vaihda Palvelinta", - "ButtonConnect": "Yhdistä", - "ButtonDelete": "Poista", - "ButtonDown": "Alas", - "ButtonDownload": "Lataa", "ButtonEdit": "Muokkaa", "ButtonEditImages": "Muokkaa kuvia", "ButtonEditOtherUserPreferences": "Muokkaa tämän käyttäjän profiilia, kuvaa ja henkilökohtaisia asetuksia.", @@ -127,7 +117,6 @@ "ButtonManualLogin": "Manuaalinen kirjautuminen", "ButtonMore": "Lisää", "ButtonNetwork": "Verkko", - "ButtonNew": "Uusi", "ButtonNextTrack": "Seuraava raita", "ButtonOff": "Pois päältä", "ButtonOk": "Ok", @@ -153,17 +142,14 @@ "ButtonSelectView": "Valitse näkymä", "ButtonSend": "Lähetä", "ButtonSettings": "Asetukset", - "ButtonShuffle": "Satunnaistoisto", "ButtonShutdown": "Sammuta", "ButtonSignIn": "Kirjaudu sisään", - "ButtonSort": "Lajittele", "ButtonStart": "Käynnistä", "ButtonStop": "Pysäytä", "ButtonSubmit": "Lähetä", "ButtonSubtitles": "Tekstitykset", "ButtonTrailer": "Traileri", "ButtonUninstall": "Poista asennus", - "ButtonUp": "Ylös", "ButtonWebsite": "Nettisivusto", "CancelRecording": "Peruuta tallennus", "Categories": "Kategoriat", @@ -253,7 +239,6 @@ "CopyStreamURLSuccess": "Osoite kopioitu onnistuneesti.", "DeathDateValue": "Kuoli: {}", "CustomDlnaProfilesHelp": "Luo uusi profiili kohdistaaksesi uuteen laitteeseen tai ohittaaksesi järjestelmäprofiilin.", - "EnableBackdrops": "Taustat", "ErrorAddingMediaPathToVirtualFolder": "Media-polkua lisätessä ilmeni ongelma. Varmista, että polku on kirjoitettu oikein ja Jellyfin Palvelimella pääsy sijaintiin.", "Episodes": "Jaksot", "EndsAtValue": "Päättyy {0}", @@ -475,7 +460,6 @@ "HeaderConfirmPluginInstallation": "Vahvista liitännäisen asennus", "HeaderConfigureRemoteAccess": "Määritä etäkäyttö", "HeaderChapterImages": "Kappalekuvat", - "HeaderChannels": "Kanavat", "HeaderApp": "Sovellus", "HeaderAllowMediaDeletionFrom": "Salli median poisto", "HeaderAlert": "Hälytys", @@ -499,7 +483,6 @@ "OptionBlockTrailers": "Trailerit", "OptionBlockMusic": "Musiikki", "OptionBlockMovies": "Elokuvat", - "HeaderMovies": "Elokuvat", "HeaderMoreLikeThis": "Lisää tällaista", "HeaderMetadataSettings": "Metadata-asetukset", "MoreMediaInfo": "Mediainfo", @@ -514,7 +497,6 @@ "HeaderLatestMovies": "Uusimmat elokuvat", "HeaderLatestEpisodes": "Uusimmat jaksot", "HeaderInstall": "Asenna", - "HeaderGenres": "Tyylilajit", "HeaderFrequentlyPlayed": "Usein toistetut", "HeaderFetcherSettings": "Hakijan asetukset", "HeaderFetchImages": "Hae kuvia:", @@ -602,7 +584,6 @@ "LabelSeasonNumber": "Kauden numero:", "LabelScreensaver": "Näytönsäästäjä:", "LabelReasonForTranscoding": "Transkoodauksen syy:", - "LabelReadHowYouCanContribute": "Katso, miten voit auttaa.", "LabelPublicHttpsPort": "Julkinen HTTPS-porttinumero:", "LabelPublicHttpPort": "Julkinen HTTP-porttinumero:", "LabelProtocolInfo": "Protokollan info:", @@ -646,7 +627,6 @@ "ExtraLarge": "Suurin", "EveryNDays": "Joka {0} päivä", "Raised": "Korotettu", - "TabShows": "Sarjat", "Yesterday": "Eilen", "Yes": "Kyllä", "Unplayed": "Toistamattomat", @@ -663,7 +643,6 @@ "Tags": "Tunnisteet", "TabUsers": "Käyttäjät", "TabUpcoming": "Tulevat", - "TabSongs": "Kappaleet", "TabSettings": "Asetukset", "TabServer": "Palvelin", "TabSeries": "Sarjat", @@ -678,21 +657,14 @@ "TabMyPlugins": "Omat liittännäiseni", "TabMusicVideos": "Musiikkivideot", "TabMusic": "Musiikki", - "TabMovies": "Elokuvat", "TabLogs": "Lokit", "TabLiveTV": "Live-TV", "TabLatest": "Uusimmat", "TabInfo": "Tiedot", - "TabGenres": "Tyylilajit", - "TabFavorites": "Suosikit", "TabEpisodes": "Jaksot", "TabDirectPlay": "Suoratoisto", - "TabDevices": "Laitteet", "TabDashboard": "Päänäkymä", - "TabCollections": "Kokoelmat", - "TabChannels": "Kanavat", "TabCatalog": "Luettelo", - "TabAlbums": "Albumit", "TabAlbumArtists": "Albumin artistit", "TabAdvanced": "Edistynyt", "TV": "TV", @@ -883,7 +855,6 @@ "Kids": "Lapset", "Images": "Kuvat", "Hide": "Piilota", - "HeadersFolders": "Kansiot", "HeaderYears": "Vuodet", "HeaderVideos": "Videot", "HeaderVideoQuality": "Kuvanlaatu", @@ -891,7 +862,6 @@ "HeaderUser": "Käyttäjä", "HeaderSubtitleAppearance": "Tekstityksen ulkonäkö", "HeaderStatus": "Tila", - "HeaderShutdown": "Sammuta", "HeaderServerSettings": "Palvelimen asetukset", "HeaderSettings": "Asetukset", "HeaderSendMessage": "Lähetä viesti", @@ -928,7 +898,6 @@ "HeaderApiKeys": "API-avaimet", "HeaderApiKey": "API-avain", "HeaderAdmin": "Ylläpitäjä", - "HeaderAlbums": "Albumit", "HeaderAddUser": "Lisää käyttäjä", "HeaderAddUpdateImage": "Lisää/Päivitä kuva", "HeaderAddToPlaylist": "Lisää soittolistaan", @@ -1013,7 +982,6 @@ "TabOther": "Muut", "TabNotifications": "Ilmoitukset", "TabNetworking": "Verkkoasetukset", - "TabGuide": "Opas", "TabContainers": "Säiliöt", "TabCodecs": "Codecit", "Suggestions": "Ehdotukset", @@ -1043,7 +1011,6 @@ "Off": "Poissa päältä", "Normal": "Normaali", "None": "Ei mitään", - "NoSubtitles": "Ei mitään", "MessageTheFollowingLocationWillBeRemovedFromLibrary": "Seuraavat mediasijainnit tullaan poistamaan kirjastostasi:", "MessageItemsAdded": "Kohteet lisätty.", "MessageItemSaved": "Kohde tallennettu.", @@ -1085,7 +1052,6 @@ "HeaderOtherItems": "Muut kohteet", "HeaderLiveTvTunerSetup": "Live-TV virittimen määritys", "HeaderLibrarySettings": "Kirjaston asetukset", - "HeaderItems": "Kohteet", "HeaderGuideProviders": "TV-ohjelmaoppaiden tarjoajat", "HeaderFavoritePlaylists": "Suosikki soittolistat", "HeaderEnabledFields": "Käytössä olevat kentät", diff --git a/src/strings/fr-ca.json b/src/strings/fr-ca.json index d5782ea3fe..e7deac36f9 100644 --- a/src/strings/fr-ca.json +++ b/src/strings/fr-ca.json @@ -2,7 +2,6 @@ "Add": "Ajouter", "AddToCollection": "Ajouter à la collection", "AddToPlaylist": "Ajouter à la liste de lecture", - "AttributeNew": "Nouveau", "ButtonCancel": "Annuler", "ButtonGotIt": "J'ai compris", "ButtonQuickStartGuide": "Guide de démarrage rapide", @@ -32,9 +31,7 @@ "LabelFinish": "Terminer", "LabelLanguage": "Langue :", "LabelName": "Nom :", - "LabelNext": "Suivant", "LabelPlaylist": "Liste de lecture :", - "LabelPrevious": "Précédent", "LabelYear": "Année :", "LabelYoureDone": "Vous avez terminé !", "Live": "En direct", @@ -142,18 +139,11 @@ "ButtonAddScheduledTaskTrigger": "Ajouter un déclencheur", "ButtonAddServer": "Ajouter un serveur", "ButtonAddUser": "Ajouter un utilisateur", - "ButtonArrowDown": "Bas", "ButtonArrowLeft": "Gauche", "ButtonArrowRight": "Droite", - "ButtonArrowUp": "Haut", "ButtonAudioTracks": "Pistes Audio", "ButtonBack": "Retour arrière", "ButtonChangeServer": "Changer de serveur", - "ButtonConnect": "Connexion", - "ButtonDelete": "Supprimer", - "ButtonDeleteImage": "Supprimer l'image", - "ButtonDown": "Bas", - "ButtonDownload": "Téléchargement", "ButtonEdit": "Modifier", "ButtonEditImages": "Modifier les images", "ButtonEditOtherUserPreferences": "Modifier ce profil utilisateur, son avatar et ses préférences personnelles.", @@ -202,17 +192,14 @@ "CancelSeries": "Annuler la série", "CancelRecording": "Annuler l'enregistrement", "ButtonWebsite": "Site web", - "ButtonUp": "Vers le haut", "ButtonUninstall": "Désinstaller", "ButtonTogglePlaylist": "Liste de lecture", "ButtonSubtitles": "Sous-titres", "ButtonSubmit": "Soumettre", "ButtonStop": "Arrêt", "ButtonStart": "Démarrer", - "ButtonSort": "Trier", "ButtonSignIn": "Se connecter", "ButtonShutdown": "Éteindre", - "ButtonShuffle": "Lecture aléatoire", "ButtonSettings": "Paramètres", "ButtonSend": "Envoyer", "ButtonSelectServer": "Sélectionner le serveur", @@ -234,7 +221,6 @@ "ButtonOpen": "Ouvrir", "ButtonOk": "OK", "ButtonNextTrack": "Prochaine piste", - "ButtonNew": "Nouveau", "ButtonAddImage": "Ajouter l'image", "BoxSet": "Coffret" } diff --git a/src/strings/fr.json b/src/strings/fr.json index 8e13275e39..61710fede0 100644 --- a/src/strings/fr.json +++ b/src/strings/fr.json @@ -34,7 +34,6 @@ "AsManyAsPossible": "Autant que possible", "Ascending": "Croissant", "AspectRatio": "Format d'image", - "AttributeNew": "Nouveau", "Backdrop": "Arrière-plan", "Backdrops": "Arrière-plans", "Banner": "Bannière", @@ -53,19 +52,12 @@ "ButtonAddScheduledTaskTrigger": "Ajouter un déclencheur", "ButtonAddServer": "Ajouter un serveur", "ButtonAddUser": "Ajouter un utilisateur", - "ButtonArrowDown": "Bas", "ButtonArrowLeft": "Gauche", "ButtonArrowRight": "Droite", - "ButtonArrowUp": "Haut", "ButtonAudioTracks": "Pistes Audio", "ButtonBack": "Retour arrière", "ButtonCancel": "Annuler", "ButtonChangeServer": "Changer de serveur", - "ButtonConnect": "Connexion", - "ButtonDelete": "Supprimer", - "ButtonDeleteImage": "Supprimer l'image", - "ButtonDown": "Bas", - "ButtonDownload": "Téléchargement", "ButtonEdit": "Modifier", "ButtonEditImages": "Modifier les images", "ButtonEditOtherUserPreferences": "Modifier ce profil utilisateur, son avatar et ses préférences personnelles.", @@ -79,7 +71,6 @@ "ButtonManualLogin": "Connexion manuelle", "ButtonMore": "Plus", "ButtonNetwork": "Réseau", - "ButtonNew": "Nouveau", "ButtonNextTrack": "Piste suivante", "ButtonOff": "Arrêt", "ButtonOk": "OK", @@ -104,18 +95,15 @@ "ButtonSelectView": "Sélectionnez une vue", "ButtonSend": "Envoyer", "ButtonSettings": "Paramètres", - "ButtonShuffle": "Aléatoire", "ButtonShutdown": "Éteindre", "ButtonSignIn": "Se connecter", "ButtonSignOut": "Se déconnecter", - "ButtonSort": "Trier", "ButtonStart": "Commencer", "ButtonStop": "Arrêter", "ButtonSubmit": "Soumettre", "ButtonSubtitles": "Sous-titres", "ButtonTrailer": "Bande-annonce", "ButtonUninstall": "Désinstaller", - "ButtonUp": "Haut", "ButtonWebsite": "Site Web", "CancelRecording": "Annuler l'enregistrement", "CancelSeries": "Annuler la série", @@ -188,7 +176,6 @@ "EditImages": "Modifier les images", "EditMetadata": "Éditer les métadonnées", "EditSubtitles": "Modifier les sous-titres", - "EnableBackdrops": "Images d'arrière-plans", "EnableBackdropsHelp": "Afficher des images d'arrière-plans sur certaines pages pendant la navigation dans la médiathèque.", "EnableCinemaMode": "Mode cinéma", "EnableColorCodedBackgrounds": "Fonds avec code couleur", @@ -281,7 +268,6 @@ "HeaderCastAndCrew": "Distribution & équipe", "HeaderCastCrew": "Distribution & équipe", "HeaderChannelAccess": "Accès aux chaînes", - "HeaderChannels": "Chaînes", "HeaderChapterImages": "Images des chapitres", "HeaderCodecProfile": "Profil de codec", "HeaderCodecProfileHelp": "Les profils de codec indiquent les limites d'un appareil lors de la lecture de codecs spécifiques. Si la limite s'applique au média, ce dernier sera transcodé, même si le codec est configuré pour la lecture directe.", @@ -332,7 +318,6 @@ "HeaderImageSettings": "Paramètres d'image", "HeaderInstall": "Installer", "HeaderInstantMix": "Mix instantané", - "HeaderItems": "Éléments", "HeaderKeepRecording": "Garder l'enregistrement", "HeaderKeepSeries": "Garder la série", "HeaderKodiMetadataHelp": "Pour activer ou désactiver les métadonnées NFO, utilisez l'onglet Métadonnées et configurez les options pour vos types de médias.", @@ -355,7 +340,6 @@ "HeaderMediaInfo": "Informations du média", "HeaderMetadataSettings": "Paramètres des métadonnées", "HeaderMoreLikeThis": "Similaires", - "HeaderMovies": "Films", "HeaderMusicQuality": "Qualité de la musique :", "HeaderMusicVideos": "Vidéos musicales", "HeaderMyDevice": "Cet appareil", @@ -416,7 +400,6 @@ "HeaderServerSettings": "Paramètres du serveur", "HeaderSettings": "Paramètres", "HeaderSetupLibrary": "Configurer vos médiathèques", - "HeaderShutdown": "Éteindre", "HeaderSortBy": "Trier par", "HeaderSortOrder": "Ordre de tri", "HeaderSpecialEpisodeInfo": "Informations de l'épisode spécial", @@ -450,7 +433,6 @@ "HeaderXmlDocumentAttributes": "Attributs des documents XML", "HeaderXmlSettings": "Paramètres XML", "HeaderYears": "Années", - "HeadersFolders": "Dossiers", "Help": "Aide", "Hide": "Cacher", "HideWatchedContentFromLatestMedia": "Masquer le contenu déjà vu dans les derniers médias", @@ -665,7 +647,6 @@ "LabelNewPassword": "Nouveau mot de passe :", "LabelNewPasswordConfirm": "Confirmer le nouveau mot de passe :", "LabelNewsCategories": "Catégories des informations :", - "LabelNext": "Suivant", "LabelNotificationEnabled": "Activer cette notification", "LabelNumber": "Numéro :", "LabelNumberOfGuideDays": "Nombre de jours de données du guide à télécharger :", @@ -692,7 +673,6 @@ "LabelPreferredDisplayLanguage": "Langue d'affichage préférée :", "LabelPreferredDisplayLanguageHelp": "La traduction de Jellyfin est un projet en cours.", "LabelPreferredSubtitleLanguage": "Langue de sous-titrage préférée :", - "LabelPrevious": "Précédent", "LabelProfileAudioCodecs": "Codecs audio :", "LabelProfileCodecs": "Codecs :", "LabelProfileCodecsHelp": "Séparés par des virgules. Peut être laissé vide pour s'appliquer à tous les codecs.", @@ -706,7 +686,6 @@ "LabelPublicHttpPortHelp": "Le numéro de port public à mapper sur le port HTTP local.", "LabelPublicHttpsPort": "Numéro de port HTTPS public :", "LabelPublicHttpsPortHelp": "Le numéro de port public à mapper sur le port HTTPS local.", - "LabelReadHowYouCanContribute": "Voir comment vous pouvez contribuer.", "LabelReasonForTranscoding": "Raison du transcodage :", "LabelRecord": "Enregistrer :", "LabelRecordingPath": "Chemin d'enregistrement par défaut :", @@ -912,7 +891,6 @@ "MessageNoNextUpItems": "Aucun élément trouvé. Commencez à regarder vos émissions !", "MessageNoPluginConfiguration": "Cette extension n'a aucun paramètre à configurer.", "NoSubtitleSearchResultsFound": "Aucun résultat trouvé.", - "NoSubtitles": "Pas de sous-titres", "NoSubtitlesHelp": "Les sous-titres ne seront pas chargés par défaut. Ils peuvent toujours être activés manuellement pendant la lecture.", "None": "Aucun", "NumLocationsValue": "{0} dossiers", @@ -1181,17 +1159,13 @@ "TabAdvanced": "Avancé", "TabAlbumArtists": "Artistes de l'album", "TabCatalog": "Catalogue", - "TabChannels": "Chaînes", "TabContainers": "Conteneurs", "TabDashboard": "Tableau de bord", - "TabDevices": "Appareils", "TabDirectPlay": "Lecture directe", "TabEpisodes": "Épisodes", - "TabFavorites": "Favoris", "TabLatest": "Derniers", "TabLiveTV": "TV en direct", "TabLogs": "Journaux", - "TabMovies": "Films", "TabMusic": "Musique", "TabMusicVideos": "Vidéos musicales", "TabMyPlugins": "Mes extensions", @@ -1210,8 +1184,6 @@ "TabSeries": "Séries", "TabServer": "Serveur", "TabSettings": "Paramètres", - "TabShows": "Séries", - "TabSongs": "Chansons", "TabTrailers": "Bandes-annonces", "TabUpcoming": "À venir", "TabUsers": "Utilisateurs", @@ -1292,8 +1264,6 @@ "Guide": "Guide", "GuestStar": "Guest star", "Photos": "Photos", - "HeaderAlbums": "Albums", - "HeaderGenres": "Genres", "HeaderIdentification": "Identification", "HeaderTuners": "Égaliseur", "Horizontal": "Horizontal", @@ -1323,11 +1293,7 @@ "Studios": "Studios", "Suggestions": "Suggestions", "TV": "Tv", - "TabAlbums": "Albums", "TabCodecs": "Codecs", - "TabCollections": "Collections", - "TabGenres": "Genres", - "TabGuide": "Guide", "TabInfo": "Informations", "TabNotifications": "Notifications", "TabPlugins": "Extensions", @@ -1454,7 +1420,6 @@ "Filter": "Filtre", "New": "Nouveau", "HeaderFavoritePlaylists": "Listes de lecture favorites", - "TabDVR": "DVR", "LabelChromecastVersion": "Version de Chromecast", "LabelEnableHttpsHelp": "Écouter les requêtes HTTPS sur le port configuré. Un certificat valide doit être fourni pour permettre ce mode de fonctionnement.", "LabelEnableHttps": "Activer HTTPS", diff --git a/src/strings/gsw.json b/src/strings/gsw.json index 70c773a137..1b23cb29b1 100644 --- a/src/strings/gsw.json +++ b/src/strings/gsw.json @@ -1,13 +1,10 @@ { "ButtonAddUser": "Erstell en User", "ButtonCancel": "Abbreche", - "ButtonDeleteImage": "Lösch Bild", - "ButtonNew": "Neu", "ButtonOk": "OK", "ButtonQuickStartGuide": "Schnellstart Instruktione", "ButtonResetPassword": "Passwort zrug setze", "ButtonSignOut": "Uslogge", - "ButtonSort": "Sortiere", "ChannelAccessHelp": "Wähl en Kanal us, um de mit dem User z'teile. Administratore werded immer d'Möglichkeit ha alli Kanäl mitm Metadate Manager z'bearbeite.", "Continuing": "Fortlaufend", "DeviceAccessHelp": "Das betrifft nur Grät wo einzigartig indentifiziert werded und tuet ned Browser Zuegriff verhindere. En Filter för Grät Zuegriff verhindered, dass neui Grät dezue gfüegt werded, bovor si ned überprüefd worde sind.", @@ -41,8 +38,6 @@ "LabelMaxParentalRating": "Maximum erlaubti Kindersicherig:", "LabelNewPassword": "Neus Passwort:", "LabelNewPasswordConfirm": "Neus Passwort bestätige:", - "LabelNext": "Nöchst", - "LabelPrevious": "Vorher", "LabelSaveLocalMetadata": "Speicher Bilder und Metadate i d'Medieordner", "LabelSaveLocalMetadataHelp": "Wennd Bilder und Metadate direkt i d'Medieordner speicherisch, chasch sie eifach weder finde und au bearbeite.", "LabelSelectUsers": "Wähl User:", @@ -96,12 +91,9 @@ "TabAccess": "Zuegriff", "TabAdvanced": "Erwiitert", "TabAlbumArtists": "Album-Artist", - "TabAlbums": "Albene", "TabCatalog": "Katalog", "TabEpisodes": "Episode", - "TabGenres": "Genre", "TabLatest": "Letschti", - "TabMovies": "Film", "TabMusicVideos": "Musigvideos", "TabMyPlugins": "Miini Plugins", "TabNetworks": "Studios", @@ -109,7 +101,6 @@ "TabPassword": "Passwort", "TabProfile": "Profil", "TabProfiles": "Profil", - "TabShows": "Serie", "TabUpcoming": "Usstehend", "TellUsAboutYourself": "Verzell was über dech selber", "ThisWizardWillGuideYou": "De Assistent hilft der dur de Installations Prozess. Zum afange, wähl bitte dini Sproch us.", diff --git a/src/strings/he.json b/src/strings/he.json index f5084ace4c..d3a6b1ee19 100644 --- a/src/strings/he.json +++ b/src/strings/he.json @@ -12,19 +12,15 @@ "Anytime": "בכל עת", "AroundTime": "בסביבות", "AsManyAsPossible": "כמה שיותר", - "AttributeNew": "חדש", "Backdrops": "תמונות רקע", "BirthLocation": "מיקום לידה", "MessageBrowsePluginCatalog": "עבור לקטלוג התוספים לראות אילו זמינים.", "ButtonAddUser": "הוסף משתמש", "ButtonCancel": "בטל", - "ButtonDelete": "מחק", - "ButtonDeleteImage": "מחק תמונה", "ButtonEdit": "ערוך", "ButtonFilter": "מסנן", "ButtonGotIt": "הבנתי", "ButtonManualLogin": "התחברות ידנית", - "ButtonNew": "חדש", "ButtonOk": "בסדר", "ButtonPlay": "נגן", "ButtonQuickStartGuide": "מדריך מהיר", @@ -36,7 +32,6 @@ "ButtonShutdown": "כבה", "ButtonSignIn": "היכנס", "ButtonSignOut": "התנתק", - "ButtonSort": "מיין", "CancelRecording": "ביטול הקלטה", "CancelSeries": "בטל סדרה", "Categories": "קטגוריות", @@ -88,7 +83,6 @@ "HeaderCancelRecording": "ביטול הקלטה", "HeaderCancelSeries": "בטל סדרה", "HeaderCastCrew": "שחקנים וצוות", - "HeaderChannels": "ערוצים", "HeaderConfirmPluginInstallation": "אשר התקנת תוסף", "HeaderCustomDlnaProfiles": "פרופילים מותאמים אישית", "HeaderDeleteItem": "מחק פריט", @@ -112,7 +106,6 @@ "HeaderLiveTV": "שידורים חיים", "HeaderMediaFolders": "ספריות מדיה", "HeaderMetadataSettings": "הגדרות מטא-דאטה", - "HeaderMovies": "סרטים", "HeaderMusicVideos": "קליפים", "HeaderMyMedia": "המדיה שלי", "HeaderNextUp": "הבא בתור", @@ -212,7 +205,6 @@ "LabelName": "שם:", "LabelNewPassword": "סיסמא חדשה:", "LabelNewPasswordConfirm": "אימות סיסמא חדשה:", - "LabelNext": "הבא", "LabelNotificationEnabled": "אפשר התראה זו", "LabelNumber": "מספר:", "LabelNumberOfGuideDays": "מספר ימים להורדה מלוח השידורים:", @@ -230,12 +222,10 @@ "LabelPlaylist": "רשימת ניגון:", "LabelPreferredDisplayLanguage": "שפת תצוגה מועדפת:", "LabelPreferredDisplayLanguageHelp": "תרגום Jellyfin הוא תהליך מתמשך.", - "LabelPrevious": "הקודם", "LabelProfileAudioCodecs": "מקודדי שמע:", "LabelProfileCodecs": "מקודדים:", "LabelProfileVideoCodecs": "‮מקודדי וידאו:", "LabelPublicHttpPort": "מספר פורט HTTP פומבי:", - "LabelReadHowYouCanContribute": "למד איך אתה יכול לתרום.", "LabelRecord": "הקלטה:", "LabelRefreshMode": "מצב רענון:", "LabelReleaseDate": "תאריך הוצאה:", @@ -436,19 +426,13 @@ "TabAccess": "גישה", "TabAdvanced": "מתקדם", "TabAlbumArtists": "אמני אלבום", - "TabAlbums": "אלבומים", "TabCatalog": "קטלוג", - "TabChannels": "ערוצים", "TabCodecs": "מקודדים", "TabDashboard": "לוח בקרה", "TabEpisodes": "פרקים", - "TabFavorites": "מועדפים", - "TabGenres": "זאנרים", - "TabGuide": "מדריך", "TabInfo": "מידע", "TabLatest": "אחרון", "TabLiveTV": "שידור ישיר", - "TabMovies": "סרטים", "TabMusic": "מוסיקה", "TabMusicVideos": "קליפים", "TabMyPlugins": "התוספים שלי", @@ -461,8 +445,6 @@ "TabSeries": "סדרות", "TabServer": "שרת", "TabSettings": "הגדרות", - "TabShows": "תוכניות", - "TabSongs": "שירים", "TabTrailers": "טריילרים", "TabUpcoming": "בקרוב", "Tags": "מילות מפתח", @@ -569,14 +551,12 @@ "ButtonHome": "בית", "ButtonFullscreen": "מסך מלא", "ButtonEditImages": "ערוך תמונות", - "ButtonConnect": "התחבר", "ButtonAddServer": "הוסף שרת", "ButtonAddMediaLibrary": "הוסף ספריית מדיה", "ButtonAddImage": "הוסף תמונה", "AskAdminToCreateLibrary": "בקש ממנהל ליצור ספרייה.", "Ascending": "סדר עולה", "Photos": "תמונות", - "TabCollections": "אוספים", "MessageConfirmShutdown": "‫האם אתה בטוח שברצונך לכבות את השרת?", "MessageConfirmRestart": "‫האם אתה בטוח שברצונך לאתחל את שרת ה-Jellyfin‏?", "HeaderThisUserIsCurrentlyDisabled": "משתמש זה אינו פעיל כרגע", @@ -584,7 +564,6 @@ "HeaderStopRecording": "עצור הקלטה", "HeaderSortOrder": "סדר מיון", "HeaderSortBy": "מיין לפי", - "HeaderShutdown": "כיבוי", "HeaderSettings": "הגדרות", "HeaderSendMessage": "שלח הודעה", "HeaderSelectServer": "בחר שרת", @@ -612,11 +591,9 @@ "HeaderLibrarySettings": "הגדרות ספרייה", "HeaderLibraryFolders": "תיקיות הספרייה", "HeaderLibraries": "ספריות", - "HeaderItems": "פריטים", "HeaderInstall": "התקנה", "HeaderImageOptions": "הגדרות תמונה", "HeaderHome": "בית", - "HeaderGenres": "ז'אנרים", "HeaderForKids": "עבור ילדים", "HeaderFavoriteVideos": "סרטונים מועדפים", "HeaderFavoritePeople": "אנשים מועדפים", @@ -625,7 +602,6 @@ "HeaderError": "שגיאה", "HeaderEpisodes": "פרקים", "HeaderDownloadSync": "הורדה וסנכרון", - "TabDevices": "מכשירים", "HeaderDevices": "מכשירים", "HeaderDeveloperInfo": "מידע למפתח", "HeaderDeleteTaskTrigger": "מחק טריגר משימה", @@ -641,7 +617,6 @@ "HeaderAudioBooks": "ספרים מוקלטים", "HeaderApiKeys": "‫מפתחות API", "HeaderApiKey": "‫מפתח API", - "HeaderAlbums": "אלבומים", "HeaderAddUpdateImage": "הוסף/עדכן תמונה", "HeaderAddScheduledTaskTrigger": "הוסף טריגר", "HeaderActivity": "פעילות", @@ -667,7 +642,6 @@ "EnableHardwareEncoding": "הפעל קידוד חומרה", "EnableExternalVideoPlayers": "נגני וידאו חיצוניים", "EnableCinemaMode": "מצב קולנוע", - "EnableBackdrops": "תמונות רקע", "EditMetadata": "ערוך מטא-דאטה", "DrmChannelsNotImported": "‫ערוצים בעלי ניהול זכויות דיגיטלי (DRM) לא ייובאו.", "Down": "למטה", @@ -684,10 +658,8 @@ "ConfirmEndPlayerSession": "‫האם לכבות את Jellyfin על {0}?", "CommunityRating": "דירוג קהילה", "ButtonWebsite": "אתר אינטרנט", - "ButtonUp": "למעלה", "ButtonSubmit": "שלח", "ButtonStart": "התחל", - "ButtonShuffle": "ערבוב", "ButtonScanAllLibraries": "סרוק את כל הספריות", "ButtonRevoke": "בטל", "TabScheduledTasks": "משימות מתוזמנות", @@ -703,14 +675,10 @@ "HeaderForgotPassword": "שחזור סיסמה", "ButtonForgotPassword": "שחזור סיסמה", "ButtonEditOtherUserPreferences": "ערוך את הפרופיל, התמונה וההגדרות האישיות של משתמש זה.", - "ButtonDownload": "הורדה", - "ButtonDown": "למטה", "ButtonChangeServer": "החלף שרת", "ButtonBack": "חזרה", "OptionBanner": "באנר", "ButtonAudioTracks": "רצועות שמע", - "ButtonArrowDown": "למטה", - "ButtonArrowUp": "למעלה", "ButtonArrowRight": "ימינה", "ButtonArrowLeft": "שמאלה", "ButtonAddScheduledTaskTrigger": "הוסף טריגר", @@ -821,7 +789,6 @@ "TabLogs": "יומני רישום", "LabelLogs": "יומני רישום:", "TabNetworking": "תקשורת", - "TabDVR": "ממיר-מקליט", "HeaderDVR": "ממיר-מקליט", "LabelScheduledTaskLastRan": "רץ לאחרונה {0}, במשך {1}.", "LabelTheme": "ערכת נושא:", diff --git a/src/strings/hi-in.json b/src/strings/hi-in.json index e7ac775adf..6a22cb170c 100644 --- a/src/strings/hi-in.json +++ b/src/strings/hi-in.json @@ -3,8 +3,6 @@ "ButtonSignOut": "Sign out", "HeaderAddUser": "उपयोगकर्ता जोडें", "LabelFinish": "समाप्त", - "LabelNext": "अगला", - "LabelPrevious": "पिछला", "LabelYoureDone": "आपने पूरा कर लिया है!", "MoreUsersCanBeAddedLater": "अधिक उपयोगकर्ताओं को बाद में डैशबोर्ड के अंतर्गत जोड़ा जा सकता है।", "TellUsAboutYourself": "हमें अपने बारे में बताएं", @@ -37,7 +35,6 @@ "ButtonOk": "ठीक", "ButtonOff": "बंद", "ButtonNextTrack": "आगे धावन पथ", - "ButtonNew": "नया", "ButtonNetwork": "संजाल", "ButtonMore": "अधिक", "ButtonManualLogin": "मैनुअल लॉगिन", @@ -52,19 +49,12 @@ "ButtonEditOtherUserPreferences": "इस उपयोगकर्ता की प्रोफ़ाइल, छवि और व्यक्तिगत प्राथमिकताएँ संपादित करें।", "ButtonEditImages": "छवियों को संपादित करें", "ButtonEdit": "संपादित करें", - "ButtonDownload": "डाउनलोड", - "ButtonDown": "नीचे", - "ButtonDeleteImage": "छवि हटाएं", - "ButtonDelete": "हटाएं", - "ButtonConnect": "जुडिये", "ButtonChangeServer": "सर्वर बदलें", "ButtonCancel": "रद्द करना", "ButtonBack": "वापस", "ButtonAudioTracks": "ऑडियो ट्रैक्स", - "ButtonArrowUp": "ऊपर", "ButtonArrowRight": "दाएँ", "ButtonArrowLeft": "बाएं", - "ButtonArrowDown": "नीचे", "ButtonAddUser": "उपयोगकर्ता जोड़ें", "ButtonAddServer": "सर्वर जोड़े", "ButtonAddScheduledTaskTrigger": "ट्रिगर जोड़ें", @@ -85,7 +75,6 @@ "Auto": "ऑटो", "AuthProviderHelp": "इस उपयोगकर्ता के पासवर्ड को प्रमाणित करने के लिए एक प्रमाणीकरण प्रदाता का उपयोग करें।", "Audio": "नया", - "AttributeNew": "नया", "AspectRatio": "आस्पेक्ट अनुपात", "AskAdminToCreateLibrary": "लाइब्रेरी बनाने के लिए किसी व्यवस्थापक से पूछें।", "Ascending": "आरोही", diff --git a/src/strings/hr.json b/src/strings/hr.json index 44c151be31..cf4aba1e9d 100644 --- a/src/strings/hr.json +++ b/src/strings/hr.json @@ -10,7 +10,6 @@ "Anytime": "Bilo kada", "AroundTime": "Oko", "AsManyAsPossible": "Što više je moguće", - "AttributeNew": "Novo", "Backdrops": "Pozadine", "BirthDateValue": "Rođen: {0}", "BirthLocation": "Lokacija rođenja", @@ -20,19 +19,12 @@ "ButtonAddScheduledTaskTrigger": "Dodaj okidač", "ButtonAddServer": "Dodaj Server", "ButtonAddUser": "Dodaj korisnika", - "ButtonArrowDown": "Dolje", "ButtonArrowLeft": "Ljevo", "ButtonArrowRight": "Desno", - "ButtonArrowUp": "Gore", "ButtonAudioTracks": "Audio pjesme", "ButtonBack": "Nazad", "ButtonCancel": "Odustani", "ButtonChangeServer": "Promijeni Server", - "ButtonConnect": "Spoji", - "ButtonDelete": "Izbriši", - "ButtonDeleteImage": "Izbriši sliku", - "ButtonDown": "Dolje", - "ButtonDownload": "Preuzimanje", "ButtonEdit": "Izmjeni", "ButtonEditImages": "Uređivanje slika", "ButtonEditOtherUserPreferences": "Uredite ovaj korisnički profil, slike i osobne postavke.", @@ -45,7 +37,6 @@ "ButtonManualLogin": "Ručna prijava", "ButtonMore": "Više", "ButtonNetwork": "Mreža", - "ButtonNew": "Novo", "ButtonNextTrack": "Sljedeća pjesma", "ButtonOff": "Isključi", "ButtonOk": "U redu", @@ -70,17 +61,14 @@ "ButtonSelectView": "Odaberi pogled", "ButtonSend": "Pošalji", "ButtonSettings": "Postavke", - "ButtonShuffle": "Miješaj", "ButtonShutdown": "Ugasi", "ButtonSignIn": "Prijava", "ButtonSignOut": "Odjava", - "ButtonSort": "Složi", "ButtonStart": "Početak", "ButtonSubmit": "Podnesi", "ButtonSubtitles": "Titlovi", "ButtonTrailer": "Kratki video", "ButtonUninstall": "Ukloni", - "ButtonUp": "Gore", "ButtonWebsite": "Web stranica", "CancelRecording": "Prekini snimanje", "CancelSeries": "Odustani od serije", @@ -175,7 +163,6 @@ "HeaderCastAndCrew": "Glumci i ekipa", "HeaderCastCrew": "Glumci i ekipa", "HeaderChannelAccess": "Pristup kanalima", - "HeaderChannels": "Kanali", "HeaderCodecProfile": "Profil kodeka", "HeaderCodecProfileHelp": "Profili kodeka definiraju ograničenja kada uređaji izvode sadržaj u specifičnom kodeku. Ako se ograničenja podudaraju tada će sadržaj biti transkodiran, iako je kodek konfiguriran za direktno izvođenje.", "HeaderConfirmPluginInstallation": "Potvrdi instalaciju dodatka", @@ -216,7 +203,6 @@ "HeaderIdentifyItemHelp": "Unesite jednu ili više kriterija pretraživanja. Uklonite kriterije za povećanje rezultata pretraživanja.", "HeaderImageSettings": "Postavke slike", "HeaderInstall": "Instaliraj", - "HeaderItems": "Stavke", "HeaderKeepRecording": "Zadrži snimanje", "HeaderKeepSeries": "Zadrži serije", "HeaderLatestEpisodes": "Zadnje epizode", @@ -235,7 +221,6 @@ "HeaderMediaInfo": "Info medija", "HeaderMetadataSettings": "Postavke meta-podataka", "HeaderMoreLikeThis": "Više ovakvih", - "HeaderMovies": "Filmovi", "HeaderMusicVideos": "Muzički spotovi", "HeaderMyMedia": "Moji mediji", "HeaderNewApiKey": "Novi API ključ", @@ -280,7 +265,6 @@ "HeaderServerSettings": "Postavke Servera", "HeaderSettings": "Postavke", "HeaderSetupLibrary": "Postavite vaše medijske biblioteke", - "HeaderShutdown": "Ugasi", "HeaderSortBy": "Složi po", "HeaderSortOrder": "Redoslijed", "HeaderSpecialEpisodeInfo": "Posebni podaci o epizodi", @@ -306,7 +290,6 @@ "HeaderXmlDocumentAttributes": "Xml atributi dokumenta", "HeaderXmlSettings": "Xml postavke", "HeaderYears": "Godine", - "HeadersFolders": "Mape", "Help": "Pomoć", "Identify": "Identificiraj", "Images": "Slike", @@ -483,7 +466,6 @@ "LabelNewPassword": "Nova lozinka:", "LabelNewPasswordConfirm": "Potvrda nove lozinke:", "LabelNewsCategories": "Kategorije vijesti:", - "LabelNext": "Sljedeći", "LabelNotificationEnabled": "Omogući ovu obavijest", "LabelNumber": "Broj:", "LabelNumberOfGuideDays": "Broj dana TV vodiča za preuzet:", @@ -505,7 +487,6 @@ "LabelPlaylist": "Popis:", "LabelPreferredDisplayLanguage": "Željeni jezik za prikaz:", "LabelPreferredDisplayLanguageHelp": "Prevađanje Jellyfin-a je projekt u tijeku.", - "LabelPrevious": "Prethodni", "LabelProfileAudioCodecs": "Audio kodek:", "LabelProfileCodecs": "Kodeki:", "LabelProfileCodecsHelp": "Odvojeno sa točka-zrezom. Ovo može ostaviti prazno kao bi bilo postavljeno za sve codecs.", @@ -519,7 +500,6 @@ "LabelPublicHttpPortHelp": "Broj javnog broja porta koji treba biti mapiran na lokalni http port.", "LabelPublicHttpsPort": "Javni broj https porta:", "LabelPublicHttpsPortHelp": "Broj javnog broja porta koji treba biti mapiran na lokalni https port.", - "LabelReadHowYouCanContribute": "Naučite kako možete pridonijeti.", "LabelRecord": "Snimka:", "LabelRecordingPath": "Zadana putanja za snimanje:", "LabelRecordingPathHelp": "Odredite zadano mjesto za spremanje snimaka. Ako se ostavi prazno, koristit će se mapa poslužitelja programskih podaka.", @@ -885,23 +865,15 @@ "TabAccess": "Pristup", "TabAdvanced": "Napredno", "TabAlbumArtists": "Albumi izvođača", - "TabAlbums": "Albumi", "TabCatalog": "Katalog", - "TabChannels": "Kanali", "TabCodecs": "Kodek", - "TabCollections": "Kolekcije", "TabContainers": "Spremnik", "TabDashboard": "Nadzorna ploča", - "TabDevices": "Uređaji", "TabDirectPlay": "Direktna reprodukcija", "TabEpisodes": "Epizode", - "TabFavorites": "Omiljeni", - "TabGenres": "Žanrovi", - "TabGuide": "Vodič", "TabLatest": "Zadnje", "TabLiveTV": "TV uživo", "TabLogs": "Dnevnici", - "TabMovies": "Filmovi", "TabMusic": "Glazba", "TabMusicVideos": "Muzički spotovi", "TabMyPlugins": "Moji dodaci", @@ -921,8 +893,6 @@ "TabScheduledTasks": "Zakazani zadaci", "TabSeries": "Serije", "TabSettings": "Postavke", - "TabShows": "Emisije", - "TabSongs": "Pjesme", "TabStreaming": "Strujanje", "TabTrailers": "Kratki filmovi", "TabUpcoming": "Uskoro", @@ -1058,7 +1028,6 @@ "Off": "Isključi", "Normal": "Normalno", "None": "Ništa", - "NoSubtitles": "Ništa", "No": "Ne", "NextUp": "Slijedi", "Next": "Slijedeće", @@ -1149,7 +1118,6 @@ "HeaderMyDevice": "Moj uređaj", "HeaderLibrarySettings": "Postavke biblioteke", "HeaderHome": "Početna", - "HeaderGenres": "Žanrovi", "HeaderFavoritePeople": "Omiljeni ljudi", "HeaderFavoriteMovies": "Omiljeni filmovi", "HeaderFavoriteBooks": "Omiljene knjige", @@ -1160,7 +1128,6 @@ "HeaderAudioBooks": "Audio knjige", "ApiKeysCaption": "Popis trenutno dostupnih API ključeva", "HeaderAllowMediaDeletionFrom": "Dozvoli brisanje datoteka iz", - "HeaderAlbums": "Albumi", "HeaderAdmin": "Administrator", "Guide": "Vodič", "GroupBySeries": "Grupiraj po serijama", @@ -1181,7 +1148,6 @@ "EnableDecodingColorDepth10Vp9": "Omogući 10-Bitno hardversko dekodiranje za VP9", "EnableDecodingColorDepth10Hevc": "Omogući 10-Bitno hardversko dekodiranje za HEVC", "EnableCinemaMode": "Kino mod", - "EnableBackdrops": "Pozadine", "EditMetadata": "Izmijeni meta podatke", "DisplayMissingEpisodesWithinSeasons": "Prikaži epizode koje nedostaju unutar sezona", "DisplayInMyMedia": "Prikaz na početnom ekranu", diff --git a/src/strings/hu.json b/src/strings/hu.json index 70089ff734..9baf2220b6 100644 --- a/src/strings/hu.json +++ b/src/strings/hu.json @@ -10,7 +10,6 @@ "AllLanguages": "Összes nyelv", "AllLibraries": "Összes könyvtár", "Ascending": "Növekvő", - "AttributeNew": "Új", "Audio": "Audió", "BirthDateValue": "Született: {0}", "BirthPlaceValue": "Születési hely: {0}", @@ -19,16 +18,9 @@ "ButtonAddMediaLibrary": "Médiakönyvtár hozzáadása", "ButtonAddServer": "Szerver Hozzáadása", "ButtonAddUser": "Új felhasználó", - "ButtonArrowDown": "Le", - "ButtonArrowUp": "Fel", "ButtonAudioTracks": "Audió Sávok", "ButtonCancel": "Mégsem", "ButtonChangeServer": "Szerver váltás", - "ButtonConnect": "Kapcsolódás", - "ButtonDelete": "Törlés", - "ButtonDeleteImage": "Kép törlése", - "ButtonDown": "Le", - "ButtonDownload": "Letöltés", "ButtonEdit": "Szerkesztés", "ButtonEditImages": "Képek szerkesztése", "ButtonFilter": "Szűrő", @@ -38,7 +30,6 @@ "ButtonLibraryAccess": "Könyvtár hozzáférés", "ButtonManualLogin": "Manuális belépés", "ButtonMore": "Tovább", - "ButtonNew": "Új", "ButtonNextTrack": "Következő sáv", "ButtonOff": "Ki", "ButtonOpen": "Megnyitás", @@ -60,11 +51,9 @@ "ButtonSelectServer": "Szerver Kiválasztás", "ButtonSend": "Küldés", "ButtonSettings": "Beállítások", - "ButtonShuffle": "Keverés", "ButtonShutdown": "Leállítás", "ButtonSignIn": "Bejelentkezés", "ButtonSignOut": "Kijelentkezés", - "ButtonSort": "Rendezés", "ButtonStop": "Leállít", "ButtonSubmit": "Elküld", "ButtonSubtitles": "Feliratok", @@ -92,7 +81,6 @@ "EditImages": "Képek szerkesztése", "EditMetadata": "Metaadat szerkesztése", "EditSubtitles": "Feliratok szerkesztése", - "EnableBackdrops": "Háttérképek", "EnableBackdropsHelp": "A háttérképek a könyvtár böngészése közben néhány oldal hátterében jelennek meg.", "EnableHardwareEncoding": "Hardveres kódolás engedélyezése", "EnableThemeSongs": "Főcímdalok", @@ -122,12 +110,10 @@ "HeaderAddToPlaylist": "Hozzáadás lejátszási listához", "HeaderAddUpdateImage": "Kép hozzáadása / frissítése", "HeaderAddUser": "Új felhasználó", - "HeaderAlbums": "Albumok", "HeaderAudioBooks": "Hangos könyvek", "HeaderAudioSettings": "Audió Beállítások", "HeaderCastAndCrew": "Szereplők és Stáb", "HeaderCastCrew": "Szereplők és Stáb", - "HeaderChannels": "Csatornák", "HeaderConnectToServer": "Kapcsolódás a Szerverhez", "HeaderContinueWatching": "Megtekintés folytatása", "HeaderCustomDlnaProfiles": "Egyedi profilok", @@ -143,7 +129,6 @@ "HeaderExternalIds": "Külső id-k:", "HeaderForgotPassword": "Elfelejtett Jelszó", "HeaderFrequentlyPlayed": "Gyakran játszott", - "HeaderGenres": "Műfajok", "HeaderIdentifyItemHelp": "Adj meg egy vagy több keresési kritériumot. Távolítsd el a kritériumokat a keresési eredmények növelése érdekében.", "HeaderImageSettings": "Kép beállítások", "HeaderInstall": "Telepítés", @@ -161,7 +146,6 @@ "HeaderMediaInfo": "Média Infó", "HeaderMetadataSettings": "Metaadat Beállítások", "HeaderMoreLikeThis": "Több ehhez hasonló", - "HeaderMovies": "Filmek", "HeaderMusicVideos": "Zenei videók", "HeaderMyDevice": "Jelenlegi eszköz", "HeaderMyMedia": "Médiatáram", @@ -193,7 +177,6 @@ "HeaderSeries": "Sorozatok", "HeaderSettings": "Beállítások", "HeaderSetupLibrary": "Média könyvtárak beállítása", - "HeaderShutdown": "Leállítás", "HeaderSortBy": "Megjelenítés", "HeaderSortOrder": "Sorrend", "HeaderSpecialFeatures": "Speciális lehetőségek", @@ -207,7 +190,6 @@ "HeaderVideoType": "Videó típusa", "HeaderVideos": "Videók", "HeaderYears": "Év", - "HeadersFolders": "Könyvtárak", "Help": "Segítség", "HideWatchedContentFromLatestMedia": "A megtekintett tartalom elrejtése a legújabb médiából", "Home": "Kezdőlap", @@ -267,7 +249,6 @@ "LabelName": "Név:", "LabelNewPassword": "Új jelszó:", "LabelNewPasswordConfirm": "Új jelszó megerősítése:", - "LabelNext": "Következő", "LabelNotificationEnabled": "Értesítés engedélyezése", "LabelOptionalNetworkPath": "Megosztott hálózati mappa:", "LabelOriginalAspectRatio": "Eredeti képarány:", @@ -281,7 +262,6 @@ "LabelPlaylist": "Lejátszási lista:", "LabelPreferredDisplayLanguage": "Elsődleges megjelenítendő nyelv:", "LabelPreferredDisplayLanguageHelp": "A Jellyfin fordítása egy folyamatos projekt.", - "LabelPrevious": "Előző", "LabelProfileAudioCodecs": "Audió kódekek:", "LabelProfileCodecs": "Kódek:", "LabelProfileContainer": "Tároló:", @@ -484,22 +464,14 @@ "TabAccess": "Hozzáférés", "TabAdvanced": "Haladó", "TabAlbumArtists": "Album Előadók", - "TabAlbums": "Albumok", "TabCatalog": "Katalógus", - "TabChannels": "Csatornák", "TabCodecs": "Kódek", - "TabCollections": "Gyűjtemények", "TabContainers": "Tároló", "TabDashboard": "Vezérlőpult", - "TabDevices": "Eszközök", "TabEpisodes": "Epizódok", - "TabFavorites": "Kedvencek", - "TabGenres": "Műfajok", - "TabGuide": "Leírás", "TabInfo": "Infó", "TabLatest": "Legújabb", "TabLogs": "Naplók", - "TabMovies": "Filmek", "TabMusic": "Zene", "TabMusicVideos": "Zenei Videók", "TabMyPlugins": "Telepített bővítmények", @@ -518,8 +490,6 @@ "TabSeries": "Sorozatok", "TabServer": "Szerver", "TabSettings": "Beállítások", - "TabShows": "Műsorok", - "TabSongs": "Dalok", "TabTrailers": "Előzetesek", "TabUpcoming": "Hamarosan érkezik", "TabUsers": "Felhasználók", @@ -595,7 +565,6 @@ "ButtonRevoke": "Visszavon", "ButtonSelectView": "Válassz nézetet", "ButtonStart": "Start", - "ButtonUp": "Fel", "CancelRecording": "Felvétel törlése", "CancelSeries": "Sorozat törlése", "Categories": "Kategóriák", @@ -719,7 +688,6 @@ "HeaderIdentificationHeader": "Azonosító fejléc", "HeaderImageOptions": "Képbeállítások", "HeaderInstantMix": "Azonnali keverés", - "HeaderItems": "Elemek", "HeaderKeepRecording": "Felvétel készítése", "HeaderKodiMetadataHelp": "Az Nfo metaadatok engedélyezéséhez vagy letiltásához szerkeszd a könyvtárat és keresd meg a metaadat letöltő részt.", "HeaderLatestMusic": "Legújabb Zene", @@ -914,7 +882,6 @@ "LabelPublicHttpPortHelp": "A nyilvános port száma, amelyet a helyi HTTP portra kell átirányítani.", "LabelPublicHttpsPort": "Nyilvános HTTPS port száma:", "LabelPublicHttpsPortHelp": "A nyilvános port száma, amelyet a helyi HTTPS portra kell átirányítani.", - "LabelReadHowYouCanContribute": "Ismerd meg, hogyan járulhatsz hozzá.", "LabelReasonForTranscoding": "Az átkódolás oka:", "LabelRemoteClientBitrateLimit": "Internetes streaming bitráta limit (Mbps):", "LabelRemoteClientBitrateLimitHelp": "Ez egy opcionális adatfolyam sebesség korlát a hálózaton kívüli eszközök számára. Ez akkor hasznos, amikor az eszközök magasabb bitrátát kérnek, mint amennyit az internetkapcsolat képes kezelni. Ez megnövelheti a szerver CPU terhelését, hogy átkódolja a videókat egy alacsonyabb bitrátára.", @@ -1041,7 +1008,6 @@ "NoNewDevicesFound": "Nem található új eszköz. Új tuner hozzáadásához zárd be ezt a párbeszédablakot és add meg kézzel az eszköz adatait.", "MessageNoNextUpItems": "Nem található. Kezdj el nézni műsorokat!", "MessageNoPluginConfiguration": "Ez a bővítmény nem rendelkezik konfigurációs beállításokkal.", - "NoSubtitles": "Nincs", "NoSubtitlesHelp": "A feliratok alapértelmezés szerint nem lesznek betöltve. Lejátszás közben kézzel is bekapcsolhatók.", "Off": "Ki", "OneChannel": "Egy csatorna", @@ -1464,7 +1430,6 @@ "HeaderServerAddressSettings": "Kiszolgáló Címének Beállításai", "HeaderRemoteAccessSettings": "Távoli Hozzáférés Beállításai", "HeaderHttpsSettings": "HTTPS Beállítások", - "TabDVR": "DVR", "HeaderDVR": "DVR", "SaveChanges": "Változtatások mentése", "MessageSyncPlayGroupWait": "{0} pufferel…", diff --git a/src/strings/id.json b/src/strings/id.json index bcb8c6a441..a11d411afa 100644 --- a/src/strings/id.json +++ b/src/strings/id.json @@ -10,8 +10,6 @@ "LabelCountry": "Negara:", "LabelFinish": "Selesai", "LabelLanguage": "Bahasa:", - "LabelNext": "Berikutnya", - "LabelPrevious": "Sebelumnya", "LabelSaveLocalMetadata": "Simpan artwork dan metadata ke dalam folder media", "LabelSaveLocalMetadataHelp": "Menyimpan artwork dan metadata langsung ke folder media akan meletakkan mereka di tempat yang mudah diedit.", "LabelTimeLimitHours": "Batas waktu (jam):", @@ -79,15 +77,12 @@ "Categories": "Kategori", "CancelRecording": "Batalkan perekaman", "ButtonWebsite": "Situs web", - "ButtonUp": "Atas", "ButtonTrailer": "Cuplikan", "ButtonSubmit": "Kirim", "ButtonStop": "Berhenti", "ButtonStart": "Mulai", - "ButtonSort": "Urutkan", "ButtonSignIn": "Masuk", "ButtonShutdown": "Matikan", - "ButtonShuffle": "Acak", "ButtonSettings": "Pengaturan", "ButtonSend": "Kirim", "ButtonSelectView": "Pilih tampilan", @@ -108,7 +103,6 @@ "ButtonOpen": "Buka", "ButtonOk": "Baik", "ButtonOff": "Matikan", - "ButtonNew": "Baru", "ButtonNetwork": "Jaringan", "ButtonMore": "Lebih banyak", "ButtonLibraryAccess": "Akses pustaka", @@ -122,19 +116,12 @@ "ButtonEditOtherUserPreferences": "Ubah profil, gambar, dan preferensi pribadi pengguna ini.", "ButtonEditImages": "Ubah gambar", "ButtonEdit": "Ubah", - "ButtonDownload": "Unduh", - "ButtonDown": "Bawah", - "ButtonDeleteImage": "Hapus Gambar", - "ButtonDelete": "Hapus", - "ButtonConnect": "Sambung", "ButtonChangeServer": "Ubah Peladen", "ButtonCancel": "Batalkan", "ButtonBack": "Kembali", "ButtonAudioTracks": "Trek Audio", - "ButtonArrowUp": "Atas", "ButtonArrowRight": "Kanan", "ButtonArrowLeft": "Kiri", - "ButtonArrowDown": "Turun", "ButtonAddUser": "Tambah Pengguna", "ButtonAddServer": "Tambah Peladen", "ButtonAddScheduledTaskTrigger": "Tambah Pemicu", @@ -155,7 +142,6 @@ "Auto": "Auto", "AuthProviderHelp": "Pilih Penyedia Autentikasi yang akan digunakan untuk mengautentikasi kata sandi pengguna ini.", "Audio": "Audio", - "AttributeNew": "Baru", "AspectRatio": "Rasio perbandingan", "Ascending": "Urutan naik", "AsManyAsPossible": "Sebanyak mungkin", diff --git a/src/strings/is-is.json b/src/strings/is-is.json index a820f82921..264b341b62 100644 --- a/src/strings/is-is.json +++ b/src/strings/is-is.json @@ -2,7 +2,6 @@ "All": "Allt", "Browse": "Vafra", "ButtonCancel": "Hætta við", - "ButtonNew": "Nýtt", "ButtonOk": "Í lagi", "ButtonSignOut": "Útskráning", "DeleteMedia": "Eyða margmiðlunarefni", @@ -20,8 +19,6 @@ "LabelCountry": "Land:", "LabelFinish": "Ljúka", "LabelLanguage": "Tungumál:", - "LabelNext": "Næsta", - "LabelPrevious": "Fyrra", "LabelTimeLimitHours": "Tímamörk (í klukkustundum):", "MoreUsersCanBeAddedLater": "Þú getur bætt við fleiri notendum síðar undir stjórnborðinu.", "NextUp": "Næst á dagskrá", @@ -36,10 +33,8 @@ "ButtonAddImage": "Bæta við ljósmynd", "ButtonAddServer": "Bæta við þjón", "ButtonAddUser": "Bæta við notenda", - "ButtonArrowDown": "Niður", "ButtonArrowLeft": "Vinstri", "ButtonArrowRight": "Hægri", - "ButtonArrowUp": "Upp", "OptionBlockBooks": "Bækur", "OptionContinuing": "Heldur áfram", "OptionBlockTvShows": "Sjónvarpsþættir", @@ -98,7 +93,6 @@ "AsManyAsPossible": "Eins margir og mögulegt er", "Ascending": "Í vaxandi röð", "AspectRatio": "Skjáhlutfall", - "AttributeNew": "Nýtt", "Audio": "Hjóð", "Auto": "Sjálfkrafa", "Banner": "Borði", @@ -172,7 +166,6 @@ "HeaderCastCrew": "Leikarar og Áhöfn", "HeaderCastAndCrew": "Leikarar og Áhöfn", "HeaderBooks": "Bækur", - "HeaderAlbums": "Plötur", "HeaderAdmin": "Stjórnandi", "GuideProviderLogin": "Innskrá", "General": "Almennt", @@ -208,13 +201,10 @@ "Categories": "Flokkar", "CancelRecording": "Hætta við upptöku", "ButtonWebsite": "Vefsiða", - "ButtonUp": "Upp", "ButtonUninstall": "Fjarlægja", "ButtonTrailer": "Sýnishorn", "ButtonSubtitles": "Texti", - "ButtonSort": "Flokka", "ButtonSignIn": "Innskráning", - "ButtonShuffle": "Stokka", "ButtonSettings": "Stillingar", "ButtonSend": "Senda", "ButtonSelectServer": "Velja netþjón", @@ -252,11 +242,6 @@ "ButtonEditOtherUserPreferences": "Breyta stillingum notanda, mynd og persónulegum stillingum.", "ButtonEditImages": "Breyta myndum", "ButtonEdit": "Breyta", - "ButtonDownload": "Sækja", - "ButtonDown": "Niður", - "ButtonDeleteImage": "Eyða Mynd", - "ButtonDelete": "Eyða", - "ButtonConnect": "Tengjast", "ButtonChangeServer": "Skipta um þjón", "ButtonBack": "Til baka", "ButtonAudioTracks": "Hljóðspor", @@ -300,14 +285,12 @@ "HeaderAddToPlaylist": "Bæta við á Spilunarlista", "HeaderAlert": "Viðvörun", "HeaderAppearsOn": "Birtist á", - "HeaderChannels": "Rásir", "HeaderDetectMyDevices": "Finna tækin mín", "HeaderFavoritePeople": "Uppáhalds Fólk", "HeaderFavoritePlaylists": "Uppáhalds spilunarlistar", "HeaderForgotPassword": "Gleymt lykilorð", "HeaderForKids": "Fyrir Krakka", "HeaderFrequentlyPlayed": "Oft Spilað", - "HeaderGenres": "Flokkar", "HeaderLatestMusic": "Tónlist, nýlega bætt við", "HeaderMetadataSettings": "Stillingar lýsigagna", "HeaderMedia": "Margmiðlunarsafn", @@ -316,7 +299,6 @@ "HeaderMyDevice": "Tækið mitt", "HeaderMusicVideos": "Tónlistarmyndbönd", "HeaderMusicQuality": "Tónlistargæði", - "HeaderMovies": "Kvikmyndir", "HeaderNewDevices": "Ný tæki", "HeaderPasswordReset": "Endurstilla Lykilorð", "HeaderPhotoAlbums": "Myndaalbúm", @@ -429,7 +411,6 @@ "TabUsers": "Notendur", "TabUpcoming": "Væntanlegt", "TabTrailers": "Sýnishorn", - "TabSongs": "Lög", "TabResumeSettings": "Halda áfram", "TabProfile": "Prófíll", "TabPlugins": "Viðbætur", @@ -438,7 +419,6 @@ "TabMyPlugins": "Mínar viðbætur", "TabMusicVideos": "Tónlistarmyndbönd", "TabMusic": "Tónlist", - "TabMovies": "Kvikmyndir", "PleaseRestartServerName": "Vinsamlegast endurræstu Jellyfin netþjóninn - {0}.", "Previous": "Fyrri", "Premiere": "Frumsýning", @@ -483,8 +463,6 @@ "HeaderVideoQuality": "Myndgæði", "HeaderUsers": "Notendur", "HeaderUser": "Notandi", - "TabGenres": "Flokkar", - "TabFavorites": "Eftirlæti", "TabEpisodes": "Þættir", "TabDirectPlay": "Bein Spilun", "TabAdvanced": "Ítarlegt", diff --git a/src/strings/it.json b/src/strings/it.json index 2dd958fb49..af6de16491 100644 --- a/src/strings/it.json +++ b/src/strings/it.json @@ -32,7 +32,6 @@ "AsManyAsPossible": "Tutto il possibile", "Ascending": "Crescente", "AspectRatio": "Rapporto d'Aspetto", - "AttributeNew": "Nuovo", "Backdrop": "Sfondo", "Backdrops": "Sfondi", "BirthDateValue": "Nato il: {0}", @@ -48,18 +47,12 @@ "ButtonAddScheduledTaskTrigger": "Aggiungi operazione", "ButtonAddServer": "Aggiungi server", "ButtonAddUser": "Aggiungi Utente", - "ButtonArrowDown": "Giù", "ButtonArrowLeft": "Sinistra", "ButtonArrowRight": "Destra", - "ButtonArrowUp": "Su", "ButtonAudioTracks": "Tracce Audio", "ButtonBack": "Indietro", "ButtonCancel": "Annulla", "ButtonChangeServer": "Cambia Server", - "ButtonConnect": "Connetti", - "ButtonDelete": "Elimina", - "ButtonDeleteImage": "Elimina immagine", - "ButtonDown": "Giu", "ButtonEdit": "Modifica", "ButtonEditImages": "Modifica Immagini", "ButtonEditOtherUserPreferences": "Modifica questo utente di profilo, l'immagine e le preferenze personali.", @@ -72,7 +65,6 @@ "ButtonManualLogin": "Accesso Manuale", "ButtonMore": "Altro", "ButtonNetwork": "Rete", - "ButtonNew": "Nuovo", "ButtonNextTrack": "Traccia Successiva", "ButtonOff": "No", "ButtonOpen": "Apri", @@ -97,16 +89,13 @@ "ButtonSelectView": "Seleziona vista", "ButtonSend": "Invia", "ButtonSettings": "Impostazioni", - "ButtonShuffle": "Casuale", "ButtonShutdown": "Arresta Server", "ButtonSignIn": "Accedi", "ButtonSignOut": "Esci", - "ButtonSort": "Ordina", "ButtonStart": "Avvio", "ButtonSubmit": "Invia", "ButtonSubtitles": "Sottotitoli", "ButtonUninstall": "Disinstalla", - "ButtonUp": "Su", "ButtonWebsite": "Web", "CancelRecording": "Annulla la registrazione", "CancelSeries": "Annulla Serie TV", @@ -177,7 +166,6 @@ "EditImages": "Modifica immagini", "EditMetadata": "Modifica metadati", "EditSubtitles": "Modifica i sottotitoli", - "EnableBackdrops": "Abilita gli Sfondi", "EnableBackdropsHelp": "Gli sfondi verranno mostrati sullo sfondo di alcune pagine mentre visualizzi la libreria.", "EnableCinemaMode": "Modalità cinema", "EnableColorCodedBackgrounds": "Sfondi a colori", @@ -255,7 +243,6 @@ "HeaderAdditionalParts": "Parti addizionali", "HeaderAdmin": "Admin", "HeaderAlbumArtists": "Artisti degli Album", - "HeaderAlbums": "Album", "HeaderAlert": "Avviso", "HeaderAllowMediaDeletionFrom": "Abilita Eliminazione Media Da", "HeaderApiKey": "Chiave API", @@ -269,7 +256,6 @@ "HeaderCancelRecording": "Annulla la Registrazione", "HeaderCancelSeries": "Annulla Serie TV", "HeaderChannelAccess": "Accesso canali", - "HeaderChannels": "Canali", "HeaderChapterImages": "Immagini Capitolo", "HeaderCodecProfile": "Profilo Codec", "HeaderCodecProfileHelp": "I Profili Codec indicano i limiti di un dispositivo durante la riproduzione di codec specifici. Se una limitazione corrisponde i media saranno sottoposti a transcodifica, anche se il codec è configurato per la riproduzione diretta.", @@ -310,7 +296,6 @@ "HeaderForKids": "Per Bambini", "HeaderForgotPassword": "Password dimenticata", "HeaderFrequentlyPlayed": "Visti di frequente", - "HeaderGenres": "Generi", "HeaderGuideProviders": "Provider Guida", "HeaderHttpHeaders": "Header HTTP", "HeaderIdentification": "Identificazione", @@ -319,7 +304,6 @@ "HeaderImageSettings": "Impostazioni Immagini", "HeaderInstall": "Installa", "HeaderInstantMix": "Mix Istantaneo", - "HeaderItems": "Elementi", "HeaderKeepRecording": "Mantieni la registrazione", "HeaderKeepSeries": "Mantieni Serie TV", "HeaderKodiMetadataHelp": "Jellyfin include il supporto nativo per i file metadati NFO. Per attivare o disattivare i metadati NFO, utilizzare la scheda Metadati per configurare le opzioni per i tipi di supporto.", @@ -341,7 +325,6 @@ "HeaderMediaInfo": "Informazioni Media", "HeaderMetadataSettings": "Impostazioni Metadati", "HeaderMoreLikeThis": "Simili a questo", - "HeaderMovies": "Film", "HeaderMusicQuality": "Qualità Musica", "HeaderMusicVideos": "Video Musicali", "HeaderMyDevice": "Il Mio Dispositivo", @@ -401,7 +384,6 @@ "HeaderServerSettings": "Impostazioni server", "HeaderSettings": "Impostazioni", "HeaderSetupLibrary": "Imposta le tue librerie multimediali", - "HeaderShutdown": "Spegni", "HeaderSortBy": "Ordina per", "HeaderSortOrder": "Ordinamento", "HeaderSpecialEpisodeInfo": "Informazioni Episodio Speciale", @@ -435,7 +417,6 @@ "HeaderXmlDocumentAttributes": "Attributi Documento Xml", "HeaderXmlSettings": "Impostazioni Xml", "HeaderYears": "Anni", - "HeadersFolders": "Cartella", "Help": "Aiuto", "Hide": "Nascondi", "HideWatchedContentFromLatestMedia": "Nascondi i contenuti già visti dagli Ultimi Media", @@ -645,7 +626,6 @@ "LabelNewPassword": "Nuova password:", "LabelNewPasswordConfirm": "Conferma nuova password:", "LabelNewsCategories": "Categorie notizie:", - "LabelNext": "Prossimo", "LabelNotificationEnabled": "Abilita questa notifica", "LabelNumber": "Numero:", "LabelNumberOfGuideDays": "Numero di giorni per i quali scaricare i dati della guida:", @@ -670,7 +650,6 @@ "LabelPreferredDisplayLanguage": "Lingua preferita visualizzata:", "LabelPreferredDisplayLanguageHelp": "La traduzione di Jellyfin è un progetto attivo.", "LabelPreferredSubtitleLanguage": "Lingua dei sottotitoli preferita:", - "LabelPrevious": "Precedente", "LabelProfileAudioCodecs": "Codec Audio:", "LabelProfileCodecs": "Codec:", "LabelProfileCodecsHelp": "Separati da virgola. Questo può essere lasciato vuoto da applicare a tutti i codec.", @@ -684,7 +663,6 @@ "LabelPublicHttpPortHelp": "Numero di porta pubblica che dovrebbe essere mappato sulla porta HTTP locale.", "LabelPublicHttpsPort": "Numero porta HTTPS pubblica:", "LabelPublicHttpsPortHelp": "Numero della porta pubblica che dovrebbe essere mappato sulla porta HTTPS locale.", - "LabelReadHowYouCanContribute": "Scopri come puoi contribuire.", "LabelReasonForTranscoding": "Motivo per la transcodifica:", "LabelRecord": "Registra:", "LabelRecordingPath": "Percorso di registrazione predefinito:", @@ -875,7 +853,6 @@ "MessageNoNextUpItems": "Trovato niente. Inizia a guardare i tuoi programmi!", "MessageNoPluginConfiguration": "Questo Plugin non ha impostazioni da configurare.", "NoSubtitleSearchResultsFound": "Nessun risultato.", - "NoSubtitles": "Nessuno", "NoSubtitlesHelp": "I sottotitoli non verranno caricati per impostazione predefinita.Possono essere ancora caricati manualmente durante la riproduzione.", "None": "Nessuno", "Normal": "Normale", @@ -1138,22 +1115,14 @@ "TabAccess": "Accesso", "TabAdvanced": "Avanzato", "TabAlbumArtists": "Artisti degli Album", - "TabAlbums": "Album", "TabCatalog": "Catalogo", - "TabChannels": "Canali", "TabCodecs": "Codec", - "TabCollections": "Collezioni", "TabContainers": "Contenitori", "TabDashboard": "Pannello Controllo", - "TabDevices": "Dispositivi", "TabDirectPlay": "Riproduzione Diretta", "TabEpisodes": "Episodi", - "TabFavorites": "Preferiti", - "TabGenres": "Generi", - "TabGuide": "Guida", "TabLatest": "Novità", "TabLiveTV": "Tv in Diretta", - "TabMovies": "Film", "TabMusic": "Musica", "TabMusicVideos": "Video Musicali", "TabMyPlugins": "I miei Plug-in", @@ -1171,8 +1140,6 @@ "TabScheduledTasks": "Operazioni Pianificate", "TabSeries": "Serie TV", "TabSettings": "Impostazioni", - "TabShows": "Spettacoli", - "TabSongs": "Brani", "TabTrailers": "Trailer", "TabUpcoming": "In Arrivo", "TabUsers": "Utenti", @@ -1248,7 +1215,6 @@ "Banner": "Banner", "Blacklist": "Blacklist", "Box": "Scatola", - "ButtonDownload": "Download", "ButtonHome": "Home", "ButtonInfo": "Info", "ButtonOk": "Ok", @@ -1464,7 +1430,6 @@ "HeaderServerAddressSettings": "Configurazione Indirizzo Server", "HeaderRemoteAccessSettings": "Configurazione Access Remoto", "HeaderHttpsSettings": "Configurazione HTTPS", - "TabDVR": "DVR", "SaveChanges": "Salva modifiche", "HeaderDVR": "DVR", "SyncPlayAccessHelp": "Selezionare il livello d'accesso di questo utente a SyncPlay che permetterà di riprodurre contemporaneamente su diversi dispositivi.", diff --git a/src/strings/ja.json b/src/strings/ja.json index f57a1ea672..31f377875d 100644 --- a/src/strings/ja.json +++ b/src/strings/ja.json @@ -57,19 +57,12 @@ "ButtonAddScheduledTaskTrigger": "トリガーを追加", "ButtonAddServer": "サーバーを追加", "ButtonAddUser": "ユーザーを追加", - "ButtonArrowDown": "下", "ButtonArrowLeft": "左", "ButtonArrowRight": "右", - "ButtonArrowUp": "上", "ButtonAudioTracks": "オーディオトラック", "ButtonBack": "戻る", "ButtonCancel": "キャンセル", "ButtonChangeServer": "サーバーを変更", - "ButtonConnect": "接続", - "ButtonDelete": "削除", - "ButtonDeleteImage": "イメージを削除", - "ButtonDown": "下", - "ButtonDownload": "ダウンロード", "ButtonEdit": "編集", "ButtonEditImages": "イメージを編集", "ButtonEditOtherUserPreferences": "ユーザーのアバターイメージやプロフィールなどの個人設定を編集。", @@ -108,18 +101,15 @@ "ButtonSelectView": "ビューを選択", "ButtonSend": "送る", "ButtonSettings": "設定", - "ButtonShuffle": "シャッフル", "ButtonShutdown": "シャットダウン", "ButtonSignIn": "サインイン", "ButtonSignOut": "サインアウト", - "ButtonSort": "ソート", "ButtonStart": "スタート", "ButtonStop": "ストップ", "ButtonSubmit": "提出", "ButtonSubtitles": "字幕", "ButtonTrailer": "予告", "ButtonUninstall": "アンインストール", - "ButtonUp": "上", "ButtonWebsite": "ウェブサイト", "CancelRecording": "レコーディングをキャンセル", "CancelSeries": "中止したシリーズ", @@ -190,7 +180,6 @@ "EditImages": "イメージを編集", "EditMetadata": "メタデータを編集", "EditSubtitles": "字幕を編集", - "EnableBackdrops": "背景", "EnableBackdropsHelp": "ライブラリを閲覧している間、背景がいくつかのページの背景に表示されます。", "EnableCinemaMode": "シネマモード", "EnableColorCodedBackgrounds": "カラーコードによる背景", @@ -215,8 +204,6 @@ "HeaderMoreLikeThis": "これに似たもの", "InstantMix": "インスタントミックス", "MoreFromValue": "もっと詳しく {0}", - "AttributeNew": "新規", - "ButtonNew": "新規", "ButtonOff": "オフ", "ColorTransfer": "Color transfer", "DeathDateValue": "死亡日:{0}", @@ -281,7 +268,6 @@ "HeaderAdditionalParts": "追加のパーツ", "HeaderAdmin": "管理者", "HeaderAlbumArtists": "アルバムアーティスト", - "HeaderAlbums": "アルバム", "HeaderAlert": "アラート", "HeaderAllowMediaDeletionFrom": "メディアの削除を許可", "HeaderApiKey": "API キー", @@ -299,7 +285,6 @@ "HeaderCastAndCrew": "キャスト&クルー", "HeaderCastCrew": "キャスト&クルー", "HeaderChannelAccess": "チャンネルアクセス", - "HeaderChannels": "チャンネル", "HeaderChapterImages": "チャプターイメージ", "HeaderCodecProfile": "コーデックプロファイル", "HeaderCodecProfileHelp": "コーデックプロファイルは、特定のコーデックを再生するときのデバイスの制限を示します。 制限が適用される場合、コーデックが直接再生用に設定されていても、メディアはトランスコードされます。", @@ -348,7 +333,6 @@ "HeaderForKids": "子供向け", "HeaderForgotPassword": "パスワードを忘れました", "HeaderFrequentlyPlayed": "よく再生する", - "HeaderGenres": "ジャンル", "HeaderGuideProviders": "TV番組情報のプロバイダ", "HeaderHome": "ホーム", "HeaderHttpHeaders": "HTTPヘッダー", @@ -359,7 +343,6 @@ "HeaderImageOptions": "イメージオプション", "HeaderImageSettings": "イメージ設定", "HeaderInstall": "インストール", - "HeaderItems": "アイテム", "HeaderKeepRecording": "録画を続ける", "HeaderKeepSeries": "シリーズを続ける", "HeaderKodiMetadataHelp": "NFOメタデータを有効または無効にするには、ライブラリを編集し「メタデータサーバー」の項目にて変更できます。", @@ -381,7 +364,6 @@ "HeaderMediaFolders": "メディアフォルダ", "HeaderMediaInfo": "メディア情報", "HeaderMetadataSettings": "メタデータ設定", - "HeaderMovies": "ムービー", "HeaderMusicQuality": "ミュージックの品質", "HeaderMusicVideos": "ミュージックビデオ", "HeaderMyDevice": "マイデバイス", @@ -442,7 +424,6 @@ "HeaderServerSettings": "サーバー設定", "HeaderSettings": "設定", "HeaderSetupLibrary": "メディアライブラリを設定する", - "HeaderShutdown": "シャットダウン", "HeaderSortBy": "ソート", "HeaderSortOrder": "ソート順", "HeaderSpecialEpisodeInfo": "スペシャルエピソード情報", @@ -475,7 +456,6 @@ "HeaderVideos": "ビデオ", "HeaderXmlSettings": "XML設定", "HeaderYears": "年", - "HeadersFolders": "フォルダ", "Help": "ヘルプ", "Hide": "隠す", "Movies": "ムービー", @@ -488,8 +468,6 @@ "ButtonAddImage": "イメージの追加", "List": "リスト", "MediaInfoTimestamp": "タイムスタンプ", - "NoSubtitles": "無し", - "TabCollections": "コレクション", "Thursday": "木曜日", "TitleHardwareAcceleration": "ハードウェアアクセラレーション", "Tuesday": "火曜日", @@ -535,11 +513,9 @@ "LabelModelUrl": "モデルURL", "LabelNewPassword": "新しいパスワード:", "LabelNewPasswordConfirm": "新しいパスワードを確認:", - "LabelNext": "次へ", "LabelNotificationEnabled": "この通知を有効化", "LabelOptionalNetworkPath": "(任意) 共有ネットワークフォルダー:", "LabelOriginalAspectRatio": "元のアスペクト比:", - "LabelPrevious": "前へ", "LabelServerName": "サーバー名:", "LabelSubtitles": "字幕", "LabelSupportedMediaTypes": "サポートされているメディアタイプ:", @@ -595,8 +571,6 @@ "CopyStreamURLSuccess": "URLのコピーが成功しました。", "TabDirectPlay": "直接再生", "TabEpisodes": "エピソード", - "TabFavorites": "お気に入り", - "TabGenres": "ジャンル", "LabelDefaultUser": "デフォルトユーザー:", "TabSeries": "シリーズ", "Trailers": "トレーラー", @@ -616,7 +590,6 @@ "FetchingData": "追加のデータを取得中", "HeaderFavoriteBooks": "お気に入りのブック", "OneChannel": "1チャンネル", - "TabDevices": "デバイス", "ValueContainer": "コンテナ: {0}", "ImportFavoriteChannelsHelp": "チューナーでのお気に入りのチャンネルのみインポートされます。", "MusicAlbum": "ミュージックアルバム", @@ -743,9 +716,7 @@ "TabAccess": "アクセス", "TabAdvanced": "高度", "TabAlbumArtists": "アルバムアーティスト", - "TabAlbums": "アルバム", "TabCatalog": "カタログ", - "TabChannels": "チャンネル", "TabCodecs": "コーデック", "TabContainers": "コンテナ", "Rewind": "巻き戻す", @@ -754,12 +725,10 @@ "SaveSubtitlesIntoMediaFolders": "字幕をメディアフォルダーに保存", "ScanForNewAndUpdatedFiles": "新しいファイルとアップデートされたファイルをスキャン", "TabDashboard": "ダッシュボード", - "TabGuide": "ガイド", "TabInfo": "情報", "TabLatest": "最新", "TabLiveTV": "ライブTV", "TabLogs": "ログ", - "TabMovies": "ムービー", "TabMusic": "ミュージック", "TabMusicVideos": "ミュージックビデオ", "TheseSettingsAffectSubtitlesOnThisDevice": "これらの設定はこのデバイスの字幕に影響します", @@ -896,7 +865,6 @@ "LabelPublicHttpPort": "公開HTTPポート番号:", "LabelPublicHttpPortHelp": "公開ポート番号はローカルHTTPポートにマッピングしてください。", "LabelPublicHttpsPort": "公開HTTPSポート番号:", - "LabelReadHowYouCanContribute": "コントリビュートする方法を知る。", "LabelReleaseDate": "公開日:", "LabelRemoteClientBitrateLimit": "インターネットストリーミングビットレートリミット (Mbps):", "LabelRuntimeMinutes": "実行時間 (分):", @@ -1049,8 +1017,6 @@ "TabResponses": "レスポンス", "TabServer": "サーバー", "TabSettings": "設定", - "TabShows": "表示", - "TabSongs": "曲", "TabStreaming": "ストリーミング", "TabTrailers": "トレーラー", "MessageContactAdminToResetPassword": "パスワードをリセットするためにシステムの管理者に連絡してください。", diff --git a/src/strings/kk.json b/src/strings/kk.json index 2f0d0c5927..ef542a0705 100644 --- a/src/strings/kk.json +++ b/src/strings/kk.json @@ -36,7 +36,6 @@ "AsManyAsPossible": "Múmkindiginshe kóp", "Ascending": "Artýy boıynsha", "AspectRatio": "Pishimdik araqatynasy", - "AttributeNew": "Jańa", "Audio": "Dybys", "Auto": "Avtomatty", "Backdrop": "Artqy sýret", @@ -57,19 +56,12 @@ "ButtonAddScheduledTaskTrigger": "Trıger ústeý", "ButtonAddServer": "Server ústeý", "ButtonAddUser": "Paıdalanýshy ústeý", - "ButtonArrowDown": "Tómenge", "ButtonArrowLeft": "Sol jaqqa", "ButtonArrowRight": "Oń jaqqa", - "ButtonArrowUp": "Joǵaryǵa", "ButtonAudioTracks": "Dybys jolshyqtaryna", "ButtonBack": "Artqa", "ButtonCancel": "Boldyrmaý", "ButtonChangeServer": "Serverdi aýystyrý", - "ButtonConnect": "Qosylý", - "ButtonDelete": "Joıý", - "ButtonDeleteImage": "Sýretti joıý", - "ButtonDown": "Tómenge", - "ButtonDownload": "Júktep alý", "ButtonEdit": "Óńdeý", "ButtonEditImages": "Sýretterdi óńdeý", "ButtonEditOtherUserPreferences": "Osy paıdalanýshynyń profaılyn, sýretin jáne ózindik teńshelimderin óńdeý.", @@ -84,7 +76,6 @@ "ButtonManualLogin": "Qolmen kirý", "ButtonMore": "Kóbirek", "ButtonNetwork": "Jeli", - "ButtonNew": "Jasaý", "ButtonNextTrack": "Kelesi jolshyqqa", "ButtonOff": "Óshir", "ButtonOk": "Jaraıdy", @@ -110,18 +101,15 @@ "ButtonSelectView": "Kórinisti tańdaý", "ButtonSend": "Jiberý", "ButtonSettings": "Parametrlerge", - "ButtonShuffle": "Aralastyrý", "ButtonShutdown": "Jumysty aıaqtaý", "ButtonSignIn": "Kirý", "ButtonSignOut": "Shyǵý", - "ButtonSort": "Suryptaý", "ButtonStart": "Bastaý", "ButtonStop": "Toqtatý", "ButtonSubmit": "Jiberý", "ButtonSubtitles": "Sýbtıtrlerge", "ButtonTrailer": "Treıler", "ButtonUninstall": "Ornatymdy joıý", - "ButtonUp": "Joǵaryǵa", "ButtonWebsite": "Ýeb-saıty", "CancelRecording": "Jazýdy boldyrmaý", "CancelSeries": "Telehıkaıany boldyrmaý", @@ -194,7 +182,6 @@ "EditImages": "Sýretterdi óńdeý", "EditMetadata": "Metaderekterdi óńdeý", "EditSubtitles": "Sýbtıtrlerdi óńdeý", - "EnableBackdrops": "Artqy sýretter", "EnableBackdropsHelp": "Artqy sýretter tasyǵyshhanany sholý kezinde keıbir betterde óńde beınelenedi.", "EnableCinemaMode": "Kınoteatr rejimi", "EnableColorCodedBackgrounds": "Túspen belgilengen óńder", @@ -275,7 +262,6 @@ "HeaderAdditionalParts": "Jalǵasatyn bólimder", "HeaderAdmin": "Basqarý", "HeaderAlbumArtists": "Álbom oryndaýshylary", - "HeaderAlbums": "Álbomdar", "HeaderAlert": "Eskertý", "HeaderAllowMediaDeletionFrom": "Osydan tasyǵyshderekterdi joıýǵa ruqsat etý", "HeaderApiKey": "API-kilt", @@ -293,7 +279,6 @@ "HeaderCastAndCrew": "Róldegiler men qyzmetkerler", "HeaderCastCrew": "Róldegiler men qyzmetkerler", "HeaderChannelAccess": "Arnaǵa qatynaý", - "HeaderChannels": "Arnalar", "HeaderChapterImages": "Sahna sýretteri", "HeaderCodecProfile": "Kodek profaıly", "HeaderCodecProfileHelp": "Kodek profaıldary naqty kodekter arqyly oınatqanda qurylǵynyń shekteýlerin kórsetedi. Eger shekteý qoldanylsa, sonda kodek tikeleı oınatý úshin teńshelse de tasyǵyshderekter qaıta kodtalynady.", @@ -335,7 +320,6 @@ "HeaderForKids": "Balalyq", "HeaderForgotPassword": "Paróldi umytyńyz ba", "HeaderFrequentlyPlayed": "Jıi oınatylǵandar", - "HeaderGenres": "Janrlar", "HeaderGuideProviders": "Telegıd derekterin jetkizýshileri", "HeaderHttpHeaders": "HTTP ústińgi derektemeleri", "HeaderIdentification": "Anyqtaý", @@ -346,7 +330,6 @@ "HeaderImageSettings": "Sýret parametrleri", "HeaderInstall": "Ornatý", "HeaderInstantMix": "Lezdik qospa", - "HeaderItems": "Tarmaqtar", "HeaderKeepRecording": "Jazýdy saqtap qalý", "HeaderKeepSeries": "Telehıkaıany saqtap qalý", "HeaderKodiMetadataHelp": "NFO metaderekterin qosý nemese óshirý úshin, Jellyfin tasyǵyshhanalar ornatý bóliminde tasyǵyshhana ny óńdeńiz jáne metaderekter saqtaýysh bólimin tabyńyz.", @@ -369,7 +352,6 @@ "HeaderMediaInfo": "Tasyǵyshderekter týraly", "HeaderMetadataSettings": "Metaderekter parametrleri", "HeaderMoreLikeThis": "Osy sıaqty kóbirek", - "HeaderMovies": "Fılmder", "HeaderMusicQuality": "Mýzyka sapasy", "HeaderMusicVideos": "Mýzykalyq beıneler", "HeaderMyDevice": "Meniń qurylǵym", @@ -430,7 +412,6 @@ "HeaderServerSettings": "Server parametrleri", "HeaderSettings": "Parametrler", "HeaderSetupLibrary": "Tasyǵyshhanalardy ornatý jáne teńsheý", - "HeaderShutdown": "Jumysty aıaqtaý", "HeaderSortBy": "Suryptaý tásili", "HeaderSortOrder": "Suryptaý reti", "HeaderSpecialEpisodeInfo": "Arnaıy bólim týraly", @@ -465,7 +446,6 @@ "HeaderXmlDocumentAttributes": "XML-qujat tólsıpattary", "HeaderXmlSettings": "XML parametrleri", "HeaderYears": "Jyldar", - "HeadersFolders": "Qaltalar", "Help": "Internettegi anyqtamaǵa", "Hide": "Jasyrý", "HideWatchedContentFromLatestMedia": "Eń keıingi tasyǵyshderekterden qaralǵan mazmundy jasyrý", @@ -682,7 +662,6 @@ "LabelNewPassword": "Jańa paról:", "LabelNewPasswordConfirm": "Jańa paróldi rastaý:", "LabelNewsCategories": "Jańalyq sanattary:", - "LabelNext": "Kelesi", "LabelNotificationEnabled": "Bul habarlandyrmany qosý", "LabelNumber": "Nómiri:", "LabelNumberOfGuideDays": "Júktep alý úshin Telegıd derekterindegi kún sany:", @@ -709,7 +688,6 @@ "LabelPreferredDisplayLanguage": "Beıneleý tiliniń teńshelimi:", "LabelPreferredDisplayLanguageHelp": "Jellyfin tárjimeleýi aǵymdaǵy joba bolyp tabylady.", "LabelPreferredSubtitleLanguage": "Sýbtıtr tiliniń teńshelimi:", - "LabelPrevious": "Aldyńǵy", "LabelProfileAudioCodecs": "Dybystyq kodekter:", "LabelProfileCodecs": "Kodekter:", "LabelProfileCodecsHelp": "Útir arqyly bólip alynǵan. Barlyq kodekterge qoldaný úshin bul bos qaldyrylý múmkin.", @@ -723,7 +701,6 @@ "LabelPublicHttpPortHelp": "Jergilikti HTTP-portyna salystyrylýy tıis jarıa port nómiri.", "LabelPublicHttpsPort": "Jarıa HTTPS-port nómiri:", "LabelPublicHttpsPortHelp": "Jergilikti HTTPS-portyna salystyrylýy tıis jarıa port nómiri.", - "LabelReadHowYouCanContribute": "Qalaı úles qosý týraly bilý.", "LabelReasonForTranscoding": "Qaıta kodtaý sebebi:", "LabelRecord": "Jazý:", "LabelRecordingPath": "Jazbalardyń ádepki joly:", @@ -932,7 +909,6 @@ "MessageNoNextUpItems": "Eshteńe tabylmady. Kórsetimderińizdi qaraı bastańyz!", "MessageNoPluginConfiguration": "Osy plagınde teńsheletin parametrler joq.", "NoSubtitleSearchResultsFound": "Eshqandaı nátıjeler tabylmady.", - "NoSubtitles": "Eshqandaı", "NoSubtitlesHelp": "Ádepkide sýbtıtrler júktelmeıdi. Olardy oınatý kezinde áli de qolmen qosýǵa bolady.", "None": "Eshqandaı", "Normal": "Kádimgi", @@ -1215,24 +1191,16 @@ "TabAccess": "Qatynaý", "TabAdvanced": "Keńeıtilgen", "TabAlbumArtists": "Álbom oryndaýshylary", - "TabAlbums": "Álbomdar", "TabCatalog": "Tizimdeme", - "TabChannels": "Arnalar", "TabCodecs": "Kodekter", - "TabCollections": "Jıyntyqtar", "TabContainers": "Konteınerler", "TabDashboard": "Taqta", - "TabDevices": "Qurylǵylar", "TabDirectPlay": "Tikeleı oınatý", "TabEpisodes": "TD-bólimder", - "TabFavorites": "Tańdaýlylar", - "TabGenres": "Janrlar", - "TabGuide": "Telegıd", "TabInfo": "Profaıl týraly", "TabLatest": "Eń keıingi", "TabLiveTV": "Efırlik TD", "TabLogs": "Jurnaldar", - "TabMovies": "Fılmder", "TabMusic": "Mýzyka", "TabMusicVideos": "Mýzykalyq beıneler", "TabMyPlugins": "Meniń plagınderim", @@ -1253,8 +1221,6 @@ "TabSeries": "Telehıkaıalar", "TabServer": "Server", "TabSettings": "Parametrler", - "TabShows": "Kórsetimder", - "TabSongs": "Áýender", "TabStreaming": "Tasymaldaný", "TabTrailers": "Treılerler", "TabUpcoming": "Kútilgen", diff --git a/src/strings/ko.json b/src/strings/ko.json index 6a6dadc120..dcdb1f5a8f 100644 --- a/src/strings/ko.json +++ b/src/strings/ko.json @@ -8,7 +8,6 @@ "AllChannels": "모든 채널", "AllEpisodes": "모든 에피소드", "AllLanguages": "모든 언어", - "AttributeNew": "새로운", "Audio": "오디오", "Backdrops": "배경", "BirthDateValue": "출생: {0}", @@ -17,17 +16,11 @@ "ButtonAddScheduledTaskTrigger": "트리거 추가", "ButtonAddServer": "서버 추가", "ButtonAddUser": "사용자 추가", - "ButtonArrowDown": "아래", "ButtonArrowLeft": "왼쪽", "ButtonArrowRight": "오른쪽", - "ButtonArrowUp": "위", "ButtonBack": "뒤로", "ButtonCancel": "취소", "ButtonChangeServer": "서버 변경", - "ButtonConnect": "접속", - "ButtonDelete": "삭제", - "ButtonDeleteImage": "이미지 삭제", - "ButtonDownload": "다운로드", "ButtonEdit": "편집", "ButtonEditOtherUserPreferences": "이 사용자의 프로필, 이미지, 개인 설정을 수정합니다.", "ButtonFilter": "필터", @@ -39,7 +32,6 @@ "ButtonManualLogin": "수동 로그인", "ButtonMore": "더 보기", "ButtonNetwork": "네트워크", - "ButtonNew": "새로운", "ButtonNextTrack": "다음 트랙", "ButtonOk": "OK", "ButtonOpen": "열기", @@ -64,7 +56,6 @@ "ButtonShutdown": "종료", "ButtonSignIn": "로그인", "ButtonSignOut": "로그아웃", - "ButtonSort": "정렬", "ButtonStart": "시작", "ButtonStop": "중지", "ButtonSubmit": "제출", @@ -122,7 +113,6 @@ "HeaderAddUser": "사용자 추가", "HeaderAdditionalParts": "추가 장면", "HeaderAdmin": "관리자", - "HeaderAlbums": "앨범", "HeaderAlert": "알림", "HeaderApiKey": "API 키", "HeaderApiKeys": "API 키", @@ -132,7 +122,6 @@ "HeaderBranding": "브랜딩", "HeaderCastCrew": "배역 및 제작진", "HeaderChannelAccess": "채널 접속", - "HeaderChannels": "채널", "HeaderCodecProfile": "코덱 프로필", "HeaderConfirmProfileDeletion": "프로필 삭제 확인", "HeaderConnectToServer": "서버 접속", @@ -153,13 +142,11 @@ "HeaderFetchImages": "이미지 가져오기:", "HeaderForgotPassword": "비밀번호 분실", "HeaderFrequentlyPlayed": "자주 재생함", - "HeaderGenres": "장르", "HeaderGuideProviders": "가이드 제공자", "HeaderIdentification": "식별자", "HeaderImageSettings": "이미지 설정", "HeaderInstall": "설치", "HeaderInstantMix": "인스턴스 믹스", - "HeaderItems": "항목", "HeaderLatestEpisodes": "최근 에피소드", "HeaderLatestMedia": "최근 미디어", "HeaderLatestMusic": "최근 음악", @@ -175,7 +162,6 @@ "HeaderMediaFolders": "미디어 폴더", "HeaderMediaInfo": "미디어 정보", "HeaderMetadataSettings": "메타데이터 설정", - "HeaderMovies": "영화", "HeaderMusicVideos": "뮤직비디오", "HeaderMyMedia": "내 미디어", "HeaderMyMediaSmall": "내 미디어 (작음)", @@ -218,7 +204,6 @@ "HeaderServerSettings": "서버 설정", "HeaderSettings": "설정", "HeaderSetupLibrary": "미디어 라이브러리 설정", - "HeaderShutdown": "종료", "HeaderSpecialEpisodeInfo": "스페셜 에피소드 정보", "HeaderSpecialFeatures": "특별 배역", "HeaderStatus": "상태", @@ -239,7 +224,6 @@ "HeaderXmlDocumentAttributes": "XML 문서 속성", "HeaderXmlSettings": "XML 설정", "HeaderYears": "연도", - "HeadersFolders": "폴더", "Help": "도움말", "Images": "이미지", "ImportFavoriteChannelsHelp": "활성화 시, 튜너 장치에서 즐겨찾기로 표시된 채널만 불러옵니다.", @@ -381,7 +365,6 @@ "LabelNewName": "새 이름:", "LabelNewPassword": "새 비밀번호:", "LabelNewPasswordConfirm": "새 비밀번호 확인:", - "LabelNext": "다음", "LabelNotificationEnabled": "이 알림 활성화", "LabelNumber": "번호:", "LabelNumberOfGuideDays": "다운로드할 가이드 데이터 일 수:", @@ -398,7 +381,6 @@ "LabelPlaylist": "재생목록:", "LabelPreferredDisplayLanguage": "선호하는 화면 언어:", "LabelPreferredDisplayLanguageHelp": "Jellyfin 번역은 진행중인 프로젝트입니다.", - "LabelPrevious": "이전", "LabelProfileAudioCodecs": "오디오 코덱:", "LabelProfileCodecs": "코덱:", "LabelProfileCodecsHelp": "쉼표로 구분합니다. 모든 코덱에 적용할 수 있도록 빈 칸을 남겨둘 수 있습니다.", @@ -411,7 +393,6 @@ "LabelPublicHttpPortHelp": "로컬 HTTP 포트는 공용 포트 번호에 매핑되어야합니다.", "LabelPublicHttpsPort": "공용 HTTPS 포트 번호:", "LabelPublicHttpsPortHelp": "로컬 HTTPS 포트는 공용 포트 번호에 매핑 되어야합니다.", - "LabelReadHowYouCanContribute": "여러분이 기여할 수 있는 방법을 알려드립니다.", "LabelRecordingPath": "기본 재코딩 위치 :", "LabelRecordingPathHelp": "녹화를 저장할 기본 위치를 지정합니다. 비어 있는 경우 서버의 프로그램 데이터 폴더가 사용됩니다.", "LabelReleaseDate": "개봉일:", @@ -676,24 +657,16 @@ "TabAccess": "접속", "TabAdvanced": "고급", "TabAlbumArtists": "앨범 아티스트", - "TabAlbums": "앨범", "TabCatalog": "카탈로그", - "TabChannels": "채널", "TabCodecs": "코덱", - "TabCollections": "컬렉션", "TabContainers": "컨테이너", "TabDashboard": "대시보드", - "TabDevices": "장치", "TabDirectPlay": "다이렉트 재생", "TabEpisodes": "에피소드", - "TabFavorites": "즐겨찾기", - "TabGenres": "장르", - "TabGuide": "가이드", "TabInfo": "정보", "TabLatest": "최근", "TabLiveTV": "실시간 TV", "TabLogs": "로그", - "TabMovies": "영화", "TabMusic": "음악", "TabMusicVideos": "뮤직비디오", "TabMyPlugins": "내 플러그인", @@ -712,8 +685,6 @@ "TabSeries": "시리즈", "TabServer": "서버", "TabSettings": "설정", - "TabShows": "쇼", - "TabSongs": "노래", "TabStreaming": "스트리밍", "TabTrailers": "예고편", "TabUpcoming": "방송 예정", @@ -818,12 +789,9 @@ "ChannelNumber": "채널 번호", "Categories": "카테고리", "CancelRecording": "녹화 취소", - "ButtonUp": "위", "ButtonTrailer": "트레일러", - "ButtonShuffle": "셔플", "ButtonScanAllLibraries": "모든 라이브러리 스캔", "ButtonOff": "끄기", - "ButtonDown": "아래", "ButtonAudioTracks": "오디오 트랙", "ButtonAddMediaLibrary": "미디어 라이브러리 추가", "ButtonAddImage": "이미지 추가", @@ -952,7 +920,6 @@ "NumLocationsValue": "{0} 폴더", "Normal": "보통", "None": "None", - "NoSubtitles": "자막 없음", "No": "아니오", "Next": "다음", "NextUp": "다음", @@ -1209,7 +1176,6 @@ "ConfirmDeleteItems": "이 항목들을 삭제하면 파일 시스템과 라이브러리 모두에서 삭제됩니다. 계속하겠습니까?", "DeleteDeviceConfirmation": "정말로 이 장치를 제거하시겠습니까? 사용자가 로그인하면 다시 나타날것입니다.", "DisplayMissingEpisodesWithinSeasons": "시즌 내 누락된 에피소드 표시", - "EnableBackdrops": "배경", "EnableBackdropsHelp": "라이브러리를 탐색하는 동안 일부 페이지의 배경을 표시합니다.", "ErrorAddingXmlTvFile": "XMLTV 파일에 액세스하는 동안 오류가 발생했습니다. 파일이 존재하는지 확인 후 다시 시도하십시오.", "ErrorDeletingItem": "Jellyfin 서버에서 항목을 제거하는 중에 오류가 발생했습니다. Jellyfin 서버가 미디어 폴더에 대해 쓰기 권한이 있는지 확인한 후 다시 시도하십시오.", diff --git a/src/strings/lt-lt.json b/src/strings/lt-lt.json index e02a183c97..39277004a2 100644 --- a/src/strings/lt-lt.json +++ b/src/strings/lt-lt.json @@ -9,25 +9,19 @@ "Anytime": "Bet kada", "AroundTime": "Maždaug {0}", "AsManyAsPossible": "Kiek įmanoma", - "AttributeNew": "Naujas", "Backdrops": "Fonai", "BirthLocation": "Gimimo vieta", "ButtonAddScheduledTaskTrigger": "Pridėti jungiklį", "ButtonAddUser": "Pridėt vartotoją", - "ButtonArrowDown": "Žemyn", "ButtonArrowLeft": "Kairėn", "ButtonArrowRight": "Dešinėn", - "ButtonArrowUp": "Aukštyn", "ButtonBack": "Atgal", "ButtonCancel": "Atšaukti", - "ButtonDelete": "Ištrinti", - "ButtonDeleteImage": "Trinti paveikslus", "ButtonEdit": "Redaguoti", "ButtonFilter": "Filtras", "ButtonGotIt": "Supratau", "ButtonHome": "Pradinis", "ButtonManualLogin": "Rankinis prisijungimas", - "ButtonNew": "Naujas", "ButtonNextTrack": "Kitas takelis", "ButtonOk": "OK", "ButtonPause": "Pauzė", @@ -43,7 +37,6 @@ "ButtonSettings": "Nustatymai", "ButtonSignIn": "Prisijungti", "ButtonSignOut": "Atsijungti", - "ButtonSort": "Rūšiuoti", "ButtonStop": "Stabdyti", "ButtonSubmit": "Pateikti", "ButtonSubtitles": "Subtitrai", @@ -98,7 +91,6 @@ "HeaderCancelRecording": "Atšaukti įrašymą", "HeaderCancelSeries": "Atšaukti laidą", "HeaderCastCrew": "Kūrėjai", - "HeaderChannels": "Kanalai", "HeaderContinueWatching": "Žiūrėti toliau", "HeaderCustomDlnaProfiles": "Kiti profiliai", "HeaderDeleteItem": "Ištrinti elementą", @@ -230,7 +222,6 @@ "LabelName": "Pavadinimas:", "LabelNewPassword": "Naujas slaptažodis:", "LabelNewPasswordConfirm": "Naujas slaptažodis (pakartokite):", - "LabelNext": "Kitas", "LabelNumber": "Numeris:", "LabelNumberOfGuideDays": "Kiek dienų gido duomenų atsisiųsti:", "LabelNumberOfGuideDaysHelp": "Atsiuntus daugiau gido duomenų dienų bus galima toliau numatyti tvarkaraštį, tačiau tai užtruks ilgiau. Auto parinks dienų skaičių pagal kanalų kiekį.", @@ -246,14 +237,12 @@ "LabelPlaylist": "Grojaraštis:", "LabelPreferredDisplayLanguage": "Pageidautina rodymo kalba:", "LabelPreferredDisplayLanguageHelp": "Jellyfin vertimas yra besitęsiantis projektas.", - "LabelPrevious": "Ankstesnis", "LabelProfileCodecsHelp": "Atskirta kableliais. Palikus tuščią bus pritaikyta visiems kodekams.", "LabelProfileContainersHelp": "Atskirta kableliais. Palikus tuščią bus pritaikyta visiems konteineriams.", "LabelPublicHttpPort": "Numeris viešo HTTP porto:", "LabelPublicHttpPortHelp": "Numeris viešo porto, kurį reiktų susieti su vietiniu HTTP portu.", "LabelPublicHttpsPort": "Numeris viešo HTTPS porto:", "LabelPublicHttpsPortHelp": "Viešas porto numeris, kurį reiktų susieti su vietiniu HTTPS portu.", - "LabelReadHowYouCanContribute": "Sužinokite, kaip galite prisidėti.", "LabelRecord": "Rašyti:", "LabelRecordingPath": "Įprasta įrašų vieta:", "LabelRecordingPathHelp": "Nurodykite įprastą vietą, kur saugoti įrašus. Palikus tuščia bus saugoma į serverio programos duomenų direktoriją.", @@ -460,16 +449,9 @@ "TabAccess": "Prieiga", "TabAdvanced": "Sudėtingiau", "TabAlbumArtists": "Albumo atlikėjai", - "TabAlbums": "Albumai", "TabCatalog": "Katalogas", - "TabChannels": "Kanalai", - "TabCollections": "Kolekcijos", "TabEpisodes": "Serijos", - "TabFavorites": "Mėgstamiausi", - "TabGenres": "Žanrai", - "TabGuide": "Gidas", "TabLatest": "Vėliausi", - "TabMovies": "Filmai", "TabMusic": "Muzika", "TabMusicVideos": "Muzikos klipai", "TabMyPlugins": "Mano priedai", @@ -483,8 +465,6 @@ "TabSeries": "Laidos", "TabServer": "Serveris", "TabSettings": "Nustatymai", - "TabShows": "Laidos", - "TabSongs": "Dainos", "TabTrailers": "Anonsai", "TabUpcoming": "Būsimi", "Tags": "Žymės", @@ -538,9 +518,6 @@ "ButtonAddServer": "Pridėti Serverį", "ButtonAudioTracks": "Garso takeliai", "ButtonChangeServer": "Keisti serverį", - "ButtonConnect": "Prisijungti", - "ButtonDown": "Žemyn", - "ButtonDownload": "Atsisiųsti", "ButtonEditImages": "Redaguoti vaizdus", "ButtonForgotPassword": "Pamiršau slaptažodį", "ButtonFullscreen": "Per visą ekraną", @@ -563,7 +540,6 @@ "ButtonShutdown": "Išjungti", "ButtonStart": "Pradėti", "ButtonUninstall": "Pašalinti", - "ButtonUp": "Aukštyn", "ButtonWebsite": "Svetainė", "ChangingMetadataImageSettingsNewContent": "Metaduomenų ar iliustracijų pakeitimai bus pritaikyti tik naujai pridėtam turiniui. Norint pritaikyti pakeitimus esančiam turiniui reikės atnaujinti metaduomenis rankiniu būdu.", "Channels": "Kanalai", @@ -598,7 +574,6 @@ "BookLibraryHelp": "Garso ir tekstinės knygos yra palaikomos. Peržiūrėkite {0} knygų vardinimo gidą {1}.", "ButtonEditOtherUserPreferences": "Keisti šio vartotojo profilį, paveikslą ir asmeninius nustatymus.", "ButtonResetEasyPassword": "Atstatyti pin kodą", - "ButtonShuffle": "Sumaišyti", "ColorPrimaries": "Pirminės spalvos", "ConfirmEndPlayerSession": "Ar norite išjungti Jellyfin ant {0}?", "Descending": "Mažėjančia tvarka", @@ -628,7 +603,6 @@ "AllowedRemoteAddressesHelp": "IP adresų atskirtų kableliais sąrašas ar IP/netmask įrašai tinklams, kurie turės teisę prisijungti nuotoliniu būdu. Visi adresai bus leidžiami, jei įrašas tuščias.", "HeaderMyMedia": "Mediateka", "HeaderMyDevice": "Mano įrenginys", - "HeaderMovies": "Filmai", "HeaderMyMediaSmall": "Mediateka", "HeaderNewDevices": "Naujas įrenginys", "AddToPlayQueue": "Pridėti prie grojaraščio", @@ -636,7 +610,6 @@ "Banner": "Juosta", "HeaderDeleteDevice": "Ištrinti prietaisą", "MessageBrowsePluginCatalog": "Peržiūrėti įskiepių katalogą.", - "EnableBackdrops": "Fonai", "EnableCinemaMode": "Kino režimas", "EnableDisplayMirroring": "Ekrano dubliavimas", "CopyStreamURL": "Kopijuoti srauto nuorodą", @@ -708,7 +681,6 @@ "HeaderFavoritePeople": "Mėgstami žmonės", "HeaderForKids": "Vaikams", "HeaderForgotPassword": "Pamiršau slaptažodį", - "HeaderGenres": "Žanrai", "HeaderGuideProviders": "TV gido informacijos teikėjai", "HeaderHome": "Pradinis", "HeaderIdentification": "Identifikacija", @@ -730,7 +702,6 @@ "HeaderFavoriteSongs": "Mėgstamos dainos", "HeaderImageOptions": "Vaizdo parinktys", "HeaderInstall": "Diegti", - "HeaderItems": "Elementai", "HeaderApiKeysHelp": "Išorinėms programoms reikalingas API raktas norint prisijungti prie Jellyfin serverio. Raktai išduodami prisijungus prie Jellyfin paskyros, arba raktas į programą suteikimas rankiniu būdu.", "HeaderSelectTranscodingPath": "Išrinkite kelią į aplanką laikiniems perkodavimo failams", "HeaderSelectTranscodingPathHelp": "Suraskite arba įrašykite kelią serverio į aplanką laikinų perkodavimo failų saugojimui. Aplankalas turi būti su rašymo teise.", @@ -781,7 +752,6 @@ "Genre": "Žanras", "ErrorPleaseSelectLineup": "Pasirinkite TV programą ir bandykite dar kartą. Jei TV programos nerodoma, patikrinkite ar teisingas jūsų vartotojo vardas, slaptažodis ir pašto kodas.", "HeaderRevisionHistory": "Versijų istorija", - "HeaderShutdown": "Išjungti", "HeaderSortBy": "Rūšiuoti pagal", "HeaderTranscodingProfileHelp": "Pridėti perkodavimo profilius, kad nurodyti, kokius formatus reikia naudoti, kai reikia perkoduoti.", "HeaderTunerDevices": "Tiunerio prietaisai", @@ -900,7 +870,6 @@ "GuideProviderLogin": "Prisijungti", "HardwareAccelerationWarning": "Įjungus aparatinės įrangos spartinimą, kai kuriose diegimo aplinkose gali atsirasti nestabilumas. Įsitikinkite, kad jūsų operacinė sistema ir vaizdo tvarkyklės yra visiškai atnaujintos. Jei įjungus šį vaizdo įrašą kyla problemų, turite pakeisti nustatymą į \"Joks\".", "HeaderAdmin": "Administratorius", - "HeaderAlbums": "Albumai", "HeaderAlert": "Perspėjimas", "HeaderAllowMediaDeletionFrom": "Leisti pašalinti medijos failą iš", "HeaderApiKey": "API raktas", @@ -921,7 +890,6 @@ "HeaderVideos": "Video įrašai", "HeaderXmlSettings": "XML nustatymai", "HeaderYears": "Metai", - "HeadersFolders": "Aplankai", "Home": "Pradinis", "Items": "Elementai", "LabelAbortedByServerShutdown": "(Nutraukta išjungus serverį)", diff --git a/src/strings/lv.json b/src/strings/lv.json index 094b3a4c74..e952b25fa9 100644 --- a/src/strings/lv.json +++ b/src/strings/lv.json @@ -143,7 +143,6 @@ "LabelOriginalTitle": "Oriģinālais nosaukums:", "LabelNumber": "Numurs:", "LabelNotificationEnabled": "Iespējot šo paziņojumu", - "LabelNext": "Nākamais", "LabelNewsCategories": "Ziņu kategorijas:", "LabelNewPasswordConfirm": "Jaunās paroles apstiprinājums:", "LabelNewPassword": "Jaunā parole:", @@ -248,7 +247,6 @@ "HeaderSpecialEpisodeInfo": "Speciālās Epizodes Info", "HeaderSortOrder": "Kārtošanas Secība", "HeaderSortBy": "Kārtot Pēc", - "HeaderShutdown": "Izslēgt", "HeaderSetupLibrary": "Uzstādīt multvides bibliotēkas", "HeaderSettings": "Iestatījumi", "HeaderServerSettings": "Servera Iestatījumi", @@ -290,7 +288,6 @@ "HeaderMyDevice": "Mana Ierīce", "HeaderMusicVideos": "Mūzikas Video", "HeaderMusicQuality": "Audio Kvalitāte", - "HeaderMovies": "Filmas", "HeaderMoreLikeThis": "Vairāk Kā Šis", "HeaderMetadataSettings": "Metadatu Iestatījumi", "HeaderMediaInfo": "Multvides informācija", @@ -310,7 +307,6 @@ "HeaderLatestMedia": "Jaunākā Multvide", "HeaderLatestEpisodes": "Jaunākās Epizodes", "HeaderKeepRecording": "Turpināt Ierakstu", - "HeaderItems": "Vienumi", "HeaderInstall": "Uzstādīt", "HeaderImageSettings": "Attēlu Iestatījumi", "HeaderImageOptions": "Attēlu Opcijas", @@ -320,7 +316,6 @@ "HeaderHttpHeaders": "HTTP Headeri", "HeaderHome": "Mājas", "HeaderGuideProviders": "TV Gida Datu Nodrošinātāji", - "HeaderGenres": "Žanri", "HeaderFrequentlyPlayed": "Bieži Atskaņots", "HeaderForgotPassword": "Aizmirst PAroli", "HeaderForKids": "Priekš Bērniem", @@ -375,7 +370,6 @@ "HeaderConfirmPluginInstallation": "Apstiprināt Palašinājumu Uzstādījumu", "HeaderConfigureRemoteAccess": "Konfigurēt Attālināto Piekļuvi", "HeaderCodecProfile": "Kodeksu Profils", - "HeaderChannels": "Kanāli", "HeaderChannelAccess": "Kanālu Piekļuve", "HeaderCancelSeries": "Atcelt Sēriju", "HeaderCancelRecording": "Atcelt Ierakstus", @@ -387,7 +381,6 @@ "HeaderApiKey": "API Atslēga", "HeaderAllowMediaDeletionFrom": "Atļaut Multvides Dzēšanu no", "HeaderAlert": "Paziņojums", - "HeaderAlbums": "Albumi", "HeaderAlbumArtists": "Albumu Izpildītāji", "HeaderAdmin": "Admin", "HeaderAddUser": "Pievienot Lietotāju", @@ -435,7 +428,6 @@ "EnableExternalVideoPlayers": "Ārējie video atskaņotāji", "EnableDisplayMirroring": "Displeju spoguļošana", "EnableCinemaMode": "Teātra režīms", - "EnableBackdrops": "Foni", "EditSubtitles": "Rediģēt subtitrus", "EditMetadata": "Rediģēt metadatus", "EditImages": "Rediģēt attēlus", @@ -489,7 +481,6 @@ "ButtonSignOut": "Iziet", "ButtonSignIn": "Ieiet", "ButtonShutdown": "Izslēgt", - "ButtonShuffle": "Jaukt", "ButtonSettings": "Iestatījumi", "ButtonSend": "Nosūtīt", "ButtonSelectView": "Izvēlies Skatu", @@ -514,7 +505,6 @@ "ButtonOk": "Labi", "ButtonOff": "Izslēgt", "ButtonNextTrack": "Nākamais Celiņš", - "ButtonNew": "Jauns", "ButtonNetwork": "Tīkls", "ButtonMore": "Vairāk", "ButtonLibraryAccess": "Bibliotēku piekļuve", @@ -527,10 +517,6 @@ "ButtonFilter": "Filtrs", "ButtonEditImages": "Rediģēt attēlus", "ButtonEdit": "Rediģēt", - "ButtonDownload": "Lejupielāde", - "ButtonDeleteImage": "Izdzēst Attēlu", - "ButtonDelete": "Izdzēst", - "ButtonConnect": "Pieslēgties", "ButtonChangeServer": "Nomainīt Serveri", "ButtonCancel": "Atcelt", "ButtonBack": "Atpakaļ", @@ -545,7 +531,6 @@ "Box": "Kaste", "Books": "Grāmatas", "Help": "Palīdzība", - "HeadersFolders": "Mapes", "HeaderYears": "Gadi", "HeaderXmlSettings": "Xml Iestatījumi", "HeaderXmlDocumentAttribute": "Xml Dokumenta Atribūts", @@ -578,7 +563,6 @@ "Backdrop": "Fons", "Auto": "Auto", "Audio": "Audio", - "AttributeNew": "Jauns", "AsManyAsPossible": "Cik vien iespējams", "Artists": "Izpildītāji", "Art": "Māksla", @@ -622,7 +606,6 @@ "NumLocationsValue": "{0} mapes", "Normal": "Normāls", "None": "Nakā", - "NoSubtitles": "Nav subtitru", "NoSubtitleSearchResultsFound": "Nav atrasti rezultāti.", "No": "Nr", "Next": "Nākamais", @@ -690,8 +673,6 @@ "TabUsers": "Lietotāji", "TabTrailers": "Treileri", "TabStreaming": "Straumēšana", - "TabSongs": "Dziesmas", - "TabShows": "Raidījumi", "TabSettings": "Iestatījumi", "TabServer": "Serveris", "TabSeries": "Sērijas", @@ -712,23 +693,15 @@ "TabMyPlugins": "Mani Paplašinājumi", "TabMusicVideos": "Mūzikas Video", "TabMusic": "Mūzika", - "TabMovies": "Filmas", "TabLogs": "Logs", "TabLiveTV": "Tiešraides TV", "TabLatest": "Jaunākais", "TabInfo": "Info", - "TabGuide": "Gids", - "TabGenres": "Žanri", - "TabFavorites": "Favorīti", "TabEpisodes": "Epizodes", "TabDirectPlay": "Tiešā Atskaņošana", - "TabDevices": "Ierīces", "TabContainers": "Konteineri", - "TabCollections": "Kolekcijas", "TabCodecs": "Kodeksi", - "TabChannels": "Kanāli", "TabCatalog": "Katalogs", - "TabAlbums": "Albumi", "ValueSpecialEpisodeName": "Speciālais - {0}", "Sync": "Sinhronizācija", "Songs": "Dziesmas", @@ -816,7 +789,6 @@ "LabelServerHostHelp": "192.168.1.100:8096 vai https://myserver.com", "LabelServerHost": "Resursdators:", "LabelReleaseDate": "Izlaiduma datums:", - "LabelPrevious": "Iepriekšējais", "LabelPreferredSubtitleLanguage": "Ieteicamā subtitru valoda:", "LabelPreferredDisplayLanguageHelp": "Jellyfin tulkošana ir notiekošs projekts.", "LabelPlayerDimensions": "Atskaņotāja dimensijas:", @@ -957,15 +929,11 @@ "ChannelAccessHelp": "Izvēlies kanālus, ko koplietot ar šo lietotāju. Administratori spēs rediģēt visus kanālus izmantojot metadatu pārvaldnieku.", "ChangingMetadataImageSettingsNewContent": "Izmaiņas metadatu vai mākslas lejupielādes iestatījumos tiks izmantotas tikai jauniem bibliotēkas vienumiem. Lai pielietotu šīs izmaiņas jau esošiem vienumiem, tev vajadzēs atjaunot šo vienumu metadatus manuāli.", "ButtonSubmit": "Iesniegt", - "ButtonSort": "Kārtot", "ButtonQuickStartGuide": "Pamata Lietošanas Instrukcija", "ButtonManualLogin": "Manuālā Ieiešana", "ButtonEditOtherUserPreferences": "Rediģē šī lietotāja profilu, attēlu un personas iestatījumus.", - "ButtonDown": "Lejup", - "ButtonArrowUp": "Augšup", "ButtonArrowRight": "Labi", "ButtonArrowLeft": "Kreisi", - "ButtonArrowDown": "Lejup", "ButtonAddScheduledTaskTrigger": "Pievienot Trigeru", "BookLibraryHelp": "Audio un teksta grāmatas tiek atbalstītas. Pārskati {0} grāmatu nosaukumu instrukciju {1}.", "Blacklist": "Melnais saraksts", @@ -1036,7 +1004,6 @@ "LabelTranscodes": "Transkodi:", "LabelTitle": "Tituls:", "LabelSaveLocalMetadata": "Saglabāt māksu media mapēs", - "LabelReadHowYouCanContribute": "Uzzini, kā tu vari dot ieguldījumu.", "LabelNumberOfGuideDays": "Dienu daudzumus, kuram lejupielādēt gidu:", "LabelLockItemToPreventChanges": "Aizslēgt šo objektu lai aizliegtu izmaiņas", "LabelLocalHttpServerPortNumber": "Vietējais HTTP porta numurs:", diff --git a/src/strings/mr.json b/src/strings/mr.json index 80708c700d..8a2114bf05 100644 --- a/src/strings/mr.json +++ b/src/strings/mr.json @@ -3,7 +3,6 @@ "ButtonOk": "ऑन", "ButtonOff": "ऑफ", "ButtonNextTrack": "पुढचा ट्रॅक", - "ButtonNew": "नवीन", "ButtonNetwork": "नेटवर्क", "ButtonMore": "अजून", "ButtonInfo": "माहिती", @@ -12,18 +11,12 @@ "ButtonForgotPassword": "पासवर्ड विसरलो", "ButtonEditImages": "चित्र संपादित करा", "ButtonEdit": "संपादित करा", - "ButtonDownload": "डाउनलोड करा", - "ButtonDown": "खाली", - "ButtonDeleteImage": "चित्र काढून टाका", - "ButtonDelete": "काढून टाका", "ButtonChangeServer": "सर्व्हर बदला", "ButtonCancel": "रद्द करा", "ButtonBack": "मागे", "ButtonAudioTracks": "ऑडिओ ट्रॅक", - "ButtonArrowUp": "वर", "ButtonArrowRight": "उजवीकडे", "ButtonArrowLeft": "डावीकडे", - "ButtonArrowDown": "खाली", "ButtonAddUser": "प्रयोक्ता जोडा", "ButtonAddServer": "सर्व्हर जोडा", "Books": "पुस्तकं", @@ -35,7 +28,6 @@ "Backdrop": "पार्श्वभूमी", "Auto": "आपोआप", "Audio": "ऑडिओ", - "AttributeNew": "नवीन", "AspectRatio": "अ‍ॅस्पेक्ट रेशो", "AsManyAsPossible": "जमतील तितके", "Artists": "संगीतकार", @@ -54,7 +46,6 @@ "AddedOnValue": "{0} जोडले", "Add": "जोडा", "Actor": "अभिनेता", - "EnableBackdrops": "पार्श्वभूमी", "EditSubtitles": "सबटायटल संपादित करा", "EditMetadata": "मेटाडेटा संपादित करा", "EditImages": "चित्र संपादित करा", @@ -77,7 +68,6 @@ "Categories": "वर्ग", "CancelRecording": "रेकॉर्डिंग रद्द करा", "ButtonWebsite": "संकेतस्थळ", - "ButtonUp": "वर", "ButtonTrailer": "ट्रेलर", "ButtonSubtitles": "सबटायटल", "ButtonStop": "थांबा", diff --git a/src/strings/ms.json b/src/strings/ms.json index e7b5be39ee..772cb3e043 100644 --- a/src/strings/ms.json +++ b/src/strings/ms.json @@ -4,8 +4,6 @@ "FolderTypeTvShows": "TV", "HeaderSeries": "Series", "LabelFinish": "Habis", - "LabelNext": "Seterusnya", - "LabelPrevious": "Sebelumnya", "LabelYoureDone": "Kamu Selesai!", "ParentalRating": "Parental Rating", "SettingsSaved": "Seting Disimpan", @@ -45,7 +43,6 @@ "AsManyAsPossible": "Sebanyak mungkin", "Ascending": "Susunan menaik", "AspectRatio": "Nisbah aspek", - "AttributeNew": "Terbaru", "Audio": "Audio", "Auto": "Auto", "Backdrop": "Latar belakang", @@ -60,15 +57,12 @@ "ButtonAddMediaLibrary": "Tambah Pustaka Media", "ButtonAddServer": "Tambah pelayan", "ButtonAddUser": "Tambah pengguna", - "ButtonArrowDown": "Turun", "ButtonArrowLeft": "Kiri", "ButtonArrowRight": "Kanan", - "ButtonArrowUp": "Atas", "ButtonAudioTracks": "Trek Audio", "ButtonBack": "Kembali", "ButtonCancel": "Batalkan", "ButtonChangeServer": "Tukar pelayan", - "ButtonConnect": "Sambung", "ButtonLibraryAccess": "Akses pustaka", "ButtonInfo": "Info", "ButtonHome": "Mula", @@ -80,10 +74,6 @@ "ButtonEditOtherUserPreferences": "Edit profil, gambar dan keutamaan peribadi pengguna ini", "ButtonEditImages": "Edit gambar-gambar", "ButtonEdit": "Edit", - "ButtonDownload": "Muat turun", - "ButtonDown": "Bawah", - "ButtonDeleteImage": "Buang gambar", - "ButtonDelete": "Buang", "ButtonAddScheduledTaskTrigger": "Tambah Pencetus", "ButtonAddImage": "Tambah gambar", "BurnSubtitlesHelp": "Menentukan sama ada pelayan perlu membakar subtitle ke skrin apabila menukar video bergantung kepada format sarikata. Menghindari pembakaran sari kata ke skrin akan meningkatkan prestasi pelayan. Pilih Auto untuk membakar format berasaskan imej (VOBSUB, PGS, SUB / IDX, dll) dan subtitle ASS / SSA tertentu.", diff --git a/src/strings/nb.json b/src/strings/nb.json index c427b92486..d9e0b3c8ec 100644 --- a/src/strings/nb.json +++ b/src/strings/nb.json @@ -24,7 +24,6 @@ "Artists": "Artister", "AsManyAsPossible": "Så mange som mulig", "AspectRatio": "Størrelsesforhold", - "AttributeNew": "Ny", "Audio": "Lyd", "Auto": "Automatisk", "BirthDateValue": "Født: {0}", @@ -37,19 +36,12 @@ "ButtonAddScheduledTaskTrigger": "Legg til utløser", "ButtonAddServer": "Legg til server", "ButtonAddUser": "Ny bruker", - "ButtonArrowDown": "Ned", "ButtonArrowLeft": "Venstre", "ButtonArrowRight": "Høyre", - "ButtonArrowUp": "Opp", "ButtonAudioTracks": "Lydspor", "ButtonBack": "Tilbake", "ButtonCancel": "Avbryt", "ButtonChangeServer": "Endre server", - "ButtonConnect": "Koble til", - "ButtonDelete": "Slett", - "ButtonDeleteImage": "Slett bilde", - "ButtonDown": "Ned", - "ButtonDownload": "Last ned", "ButtonEdit": "Rediger", "ButtonEditImages": "Endre bilder", "ButtonEditOtherUserPreferences": "Endre denne brukerens profilbilde og personlige innstillinger.", @@ -61,7 +53,6 @@ "ButtonManualLogin": "Manuell Login", "ButtonMore": "Mer", "ButtonNetwork": "Nettverk", - "ButtonNew": "Ny", "ButtonNextTrack": "Neste Spor", "ButtonOff": "Av", "ButtonOk": "OK", @@ -88,12 +79,10 @@ "ButtonShutdown": "Slå av", "ButtonSignIn": "Logg inn", "ButtonSignOut": "Logg ut", - "ButtonSort": "Sortér", "ButtonStop": "Stopp", "ButtonSubmit": "Send", "ButtonSubtitles": "Undertekster", "ButtonUninstall": "Avinstaller", - "ButtonUp": "Opp", "ButtonWebsite": "Nettsted", "CancelRecording": "Avbryt opptak", "CancelSeries": "Avbryt serie", @@ -195,7 +184,6 @@ "HeaderAddUpdateImage": "Legg Til/Oppdater Bilde", "HeaderAddUser": "Legg til bruker", "HeaderAdditionalParts": "Tilleggsdeler", - "HeaderAlbums": "Albumer", "HeaderAlert": "Varsling", "HeaderAllowMediaDeletionFrom": "Tillat sletting av media fra", "HeaderApiKey": "API-nøkkel", @@ -210,7 +198,6 @@ "HeaderCastAndCrew": "Skuespillere & mannskap", "HeaderCastCrew": "Mannskap", "HeaderChannelAccess": "Kanal-tilgang", - "HeaderChannels": "Kanaler", "HeaderCodecProfile": "Kodekprofil", "HeaderCodecProfileHelp": "Kodekprofiler indikerer begrensningene til en enhet ved avspilling av bestemte kodeker. Hvis en begrensning gjelder, vil media bli omkodet, selv om kodeken er konfigurert for direkteavspilling.", "HeaderConfirmPluginInstallation": "Bekreft installasjon av tillegg", @@ -248,7 +235,6 @@ "HeaderForKids": "For barn", "HeaderForgotPassword": "Glemt passord", "HeaderFrequentlyPlayed": "Ofte avspilt", - "HeaderGenres": "Sjanger", "HeaderGuideProviders": "Leverandører av TV-guide", "HeaderHttpHeaders": "HTTP-hoder", "HeaderIdentification": "Identifisering", @@ -259,7 +245,6 @@ "HeaderImageSettings": "Bildeinnstillinger", "HeaderInstall": "Installer", "HeaderInstantMix": "Miks", - "HeaderItems": "Elementer", "HeaderKeepRecording": "Behold opptak", "HeaderKeepSeries": "Behold serie", "HeaderLatestEpisodes": "Nyeste episoder", @@ -278,7 +263,6 @@ "HeaderMediaInfo": "Mediainformasjon", "HeaderMetadataSettings": "Metadatainnstilinger", "HeaderMoreLikeThis": "Flere som dette", - "HeaderMovies": "Filmer", "HeaderMusicVideos": "Musikkvideoer", "HeaderMyDevice": "Min enhet", "HeaderMyMedia": "Min media", @@ -333,7 +317,6 @@ "HeaderServerSettings": "Serverinnstillinger", "HeaderSettings": "Innstillinger", "HeaderSetupLibrary": "Konfigurer dine mediebibliotek", - "HeaderShutdown": "Skru av", "HeaderSortBy": "Sorter etter", "HeaderSortOrder": "Sorteringsrekkefølge", "HeaderSpecialEpisodeInfo": "Spesialepisodeinfo", @@ -361,7 +344,6 @@ "HeaderXmlDocumentAttributes": "XML-dokumentattributter", "HeaderXmlSettings": "XML-innstillinger", "HeaderYears": "År", - "HeadersFolders": "Mapper", "Help": "Hjelp", "HideWatchedContentFromLatestMedia": "Skjul sett innhold fra nyeste media", "Identify": "Identifiser", @@ -543,7 +525,6 @@ "LabelNewPassword": "Nytt passord:", "LabelNewPasswordConfirm": "Bekreft nytt passord:", "LabelNewsCategories": "Nyhetskategorier:", - "LabelNext": "Neste", "LabelNotificationEnabled": "Aktiver denne varslingen", "LabelNumber": "Nummer:", "LabelNumberOfGuideDays": "Antall dager med TV-guidedata som skal lastes ned:", @@ -568,7 +549,6 @@ "LabelPostProcessorArgumentsHelp": "Bruk {path} som filbanen til opptaksfilen.", "LabelPreferredDisplayLanguage": "Foretrukket visningsspråk:", "LabelPreferredDisplayLanguageHelp": "Oversettelse av Jellyfin er et pågående prosjekt.", - "LabelPrevious": "Forrige", "LabelProfileAudioCodecs": "Lydkodeker:", "LabelProfileCodecs": "Kodeker:", "LabelProfileCodecsHelp": "Separert med komma. Dette feltet kan forbli tomt for å gjelde alle kodeker.", @@ -582,7 +562,6 @@ "LabelPublicHttpPortHelp": "Den eksterne porten som kobles til den lokale HTTP-porten.", "LabelPublicHttpsPort": "Ekstern HTTPS-port:", "LabelPublicHttpsPortHelp": "Den eksterne porten som kobles til den lokale HTTPS-porten.", - "LabelReadHowYouCanContribute": "Lær hvordan du kan bidra.", "LabelRecord": "Opptak:", "LabelRecordingPath": "Standard plassering for opptak:", "LabelRecordingPathHelp": "Angi et egendefinert sted å lagre opptak. Dersom du lar feltet stå tomt vil serverens datamappe bli brukt.", @@ -976,21 +955,14 @@ "TabAccess": "Tilgang", "TabAdvanced": "Avansert", "TabAlbumArtists": "Albumartister", - "TabAlbums": "Album", "TabCatalog": "Katalog", - "TabChannels": "Kanaler", "TabCodecs": "Kodeker", - "TabCollections": "Samlinger", "TabContainers": "Kontainere", "TabDashboard": "Dashbord", - "TabDevices": "Enheter", "TabDirectPlay": "Direkteavspilling", "TabEpisodes": "Episoder", - "TabFavorites": "Favoritter", - "TabGenres": "Sjangre", "TabLatest": "Siste", "TabLogs": "Logger", - "TabMovies": "Filmer", "TabMusic": "Musikk", "TabMusicVideos": "Musikkvideoer", "TabMyPlugins": "Mine programtillegg", @@ -1010,8 +982,6 @@ "TabScheduledTasks": "Planlagte oppgaver", "TabSeries": "Serier", "TabSettings": "Innstillinger", - "TabShows": "Programmer", - "TabSongs": "Sanger", "TabTrailers": "Trailere", "TabUpcoming": "Kommende", "TabUsers": "Brukere", @@ -1076,7 +1046,6 @@ "Channels": "Kanaler", "ButtonTrailer": "Trailer", "ButtonStart": "Start", - "ButtonShuffle": "Tilfeldig rekkefølge", "ButtonSend": "Send", "ButtonPause": "Pause", "ButtonInfo": "Informasjon", @@ -1164,7 +1133,6 @@ "LabelType": "Type:", "Large": "Stor", "DirectStreamHelp1": "Mediet støttes av enheten med tanke på oppløsning og medietype (H.264, AC3, osv), men den støtter ikke filkontaineren (mkv, avi, wmv, osv). Videoen vil ompakkes fortløpende før den sendes til enheten.", - "EnableBackdrops": "Bakgrunner", "EnableThemeVideos": "Temavideoer", "MusicVideo": "Musikkvideo", "Mute": "Demp lyd", @@ -1180,7 +1148,6 @@ "MediaInfoCodecTag": "Kodektagg", "Metadata": "Metadata", "MessageNoPluginConfiguration": "Dette programtillegget har ingen innstillinger å konfigurere.", - "TabGuide": "Guide", "Unmute": "Skru på lyd", "OptionIsHD": "HD", "ButtonAddImage": "Legg til bilde", @@ -1337,7 +1304,6 @@ "MusicAlbum": "Musikkalbum", "MusicArtist": "Musikkartist", "Next": "Neste", - "NoSubtitles": "Ingen", "NoSubtitlesHelp": "Undertekster vil ikke lastes inn som standard. De kan fortsatt aktiveres manuelt under avspilling.", "Normal": "Normal", "OnlyForcedSubtitles": "Kun tvungen", @@ -1449,7 +1415,6 @@ "YadifBob": "YADIF Bob", "Yadif": "YADIF", "Track": "Spor", - "TabDVR": "Opptak", "SyncPlayAccessHelp": "Velg tilgangsnivået denne brukeren skal ha til SyncPlay-funksjonen. SyncPlay muliggjør synkronisert avspilling med andre enheter.", "Filter": "Filter", "New": "Ny", diff --git a/src/strings/nl.json b/src/strings/nl.json index 0401a2f9bf..5dee8dbf47 100644 --- a/src/strings/nl.json +++ b/src/strings/nl.json @@ -34,7 +34,6 @@ "AsManyAsPossible": "Zo veel als mogelijk", "Ascending": "Oplopend", "AspectRatio": "Beeldverhouding", - "AttributeNew": "Nieuw", "Audio": "Geluid", "Auto": "Automatisch", "Backdrop": "Achtergrond", @@ -52,19 +51,12 @@ "ButtonAddScheduledTaskTrigger": "Trigger Toevoegen", "ButtonAddServer": "Voeg server toe", "ButtonAddUser": "Gebruiker toevoegen", - "ButtonArrowDown": "Omlaag", "ButtonArrowLeft": "Links", "ButtonArrowRight": "Rechts", - "ButtonArrowUp": "Omhoog", "ButtonAudioTracks": "Audio track", "ButtonBack": "Terug", "ButtonCancel": "Annuleren", "ButtonChangeServer": "Wijzig server", - "ButtonConnect": "Verbind", - "ButtonDelete": "Verwijderen", - "ButtonDeleteImage": "Verwijder afbeelding", - "ButtonDown": "Omlaag", - "ButtonDownload": "Downloaden", "ButtonEdit": "Bewerken", "ButtonEditImages": "Bewerk afbeeldingen", "ButtonEditOtherUserPreferences": "Wijzig het profiel, afbeelding en persoonlijke voorkeuren van deze gebruiker.", @@ -77,7 +69,6 @@ "ButtonManualLogin": "Handmatige Aanmelding", "ButtonMore": "Meer", "ButtonNetwork": "Netwerk", - "ButtonNew": "Nieuw", "ButtonNextTrack": "Volgende track", "ButtonOff": "Uit", "ButtonOpen": "Openen", @@ -102,14 +93,11 @@ "ButtonSelectView": "Selecteer weergave", "ButtonSend": "Stuur", "ButtonSettings": "Instellingen", - "ButtonShuffle": "Willekeurig", "ButtonShutdown": "Afsluiten", "ButtonSignIn": "Aanmelden", "ButtonSignOut": "Afmelden", - "ButtonSort": "Sorteren", "ButtonSubmit": "Uitvoeren", "ButtonSubtitles": "Ondertiteling", - "ButtonUp": "Omhoog", "CancelRecording": "Opname annuleren", "CancelSeries": "Annuleer series", "Categories": "Categorieën", @@ -180,7 +168,6 @@ "EditImages": "Bewerk afbeeldingen", "EditMetadata": "Metadata wijzigen", "EditSubtitles": "Bewerk ondertiteling", - "EnableBackdrops": "Achtergronden", "EnableBackdropsHelp": "Laat achtergrondafbeeldingen zien tijdens het bladeren door de bibliotheek.", "EnableCinemaMode": "Cinema modus", "EnableColorCodedBackgrounds": "Kleurgecodeerde achtergronden", @@ -273,7 +260,6 @@ "HeaderCancelRecording": "Opname Annuleren", "HeaderCancelSeries": "Annuleren Series", "HeaderChannelAccess": "Kanaal toegang", - "HeaderChannels": "Kanalen", "HeaderChapterImages": "Hoofdstukafbeeldingen", "HeaderCodecProfile": "Codec Profiel", "HeaderCodecProfileHelp": "Codec profielen geven de beperkingen van een apparaat bij het afspelen van bepaalde codecs. Als een beperking geldt dan zal de media getranscodeerd worden, zelfs indien de codec is geconfigureerd voor direct afspelen.", @@ -342,7 +328,6 @@ "HeaderMediaInfo": "Media informatie", "HeaderMetadataSettings": "Metagegevens instellingen", "HeaderMoreLikeThis": "Meer als dit", - "HeaderMovies": "Films", "HeaderMusicQuality": "Muziek Kwaliteit", "HeaderMusicVideos": "Music Video's", "HeaderMyDevice": "Mijn Apparaat", @@ -403,7 +388,6 @@ "HeaderServerSettings": "Server Instellingen", "HeaderSettings": "Instellingen", "HeaderSetupLibrary": "Stel uw mediabibliotheken in", - "HeaderShutdown": "Afsluiten", "HeaderSortBy": "Sorteren op", "HeaderSortOrder": "Sorteer volgorde", "HeaderSpecialEpisodeInfo": "Speciale afleveringsinformatie", @@ -435,7 +419,6 @@ "HeaderXmlDocumentAttributes": "Xml Document Attributen", "HeaderXmlSettings": "Xml Instellingen", "HeaderYears": "Jaren", - "HeadersFolders": "Mappen", "Help": "Hulp", "Hide": "Verbergen", "HideWatchedContentFromLatestMedia": "Verberg gekeken inhoud uit nieuwste media", @@ -641,7 +624,6 @@ "LabelNewPassword": "Nieuw wachtwoord:", "LabelNewPasswordConfirm": "Bevestig nieuw wachtwoord:", "LabelNewsCategories": "Nieuws categorieën:", - "LabelNext": "Volgende", "LabelNotificationEnabled": "Deze melding inschakelen", "LabelNumber": "Nummer:", "LabelNumberOfGuideDays": "Aantal dagen van de gids om te downloaden:", @@ -668,7 +650,6 @@ "LabelPreferredDisplayLanguage": "Voorkeur weergavetaal:", "LabelPreferredDisplayLanguageHelp": "Vertaling van Jellyfin is een voortdurend project.", "LabelPreferredSubtitleLanguage": "Voorkeurstaal ondertiteling:", - "LabelPrevious": "Vorige", "LabelProfileAudioCodecs": "Geluidscodecs:", "LabelProfileCodecsHelp": "Gescheiden door een komma. Dit kan leeg worden gelaten om te laten gelden voor alle codecs.", "LabelProfileContainersHelp": "Gescheiden door een komma. Dit kan leeg worden gelaten om te laten gelden voor alle containers.", @@ -678,7 +659,6 @@ "LabelPublicHttpPortHelp": "Het publieke poortnummer dat moet worden toegewezen aan de lokale HTTP poort.", "LabelPublicHttpsPort": "Publieke HTTPS poort nummer:", "LabelPublicHttpsPortHelp": "Het publieke poortnummer dat moet worden toegewezen aan de lokale HTTPS poort.", - "LabelReadHowYouCanContribute": "Lees meer over hoe u kunt bijdragen.", "LabelReasonForTranscoding": "Reden voor transcoderen:", "LabelRecord": "Opnemen:", "LabelRecordingPath": "Standaard opname pad:", @@ -863,7 +843,6 @@ "MessageNoNextUpItems": "Niets gevonden. Start met kijken!", "MessageNoPluginConfiguration": "Deze plugin heeft geen instellingen te configureren.", "NoSubtitleSearchResultsFound": "Geen resultaten gevonden.", - "NoSubtitles": "Geen ondertiteling", "NoSubtitlesHelp": "Ondertitels worden niet standaard weergegeven. Deze kunnen tijdens het afspelen handmatig worden ingeschakeld.", "None": "Geen", "Normal": "Normaal", @@ -1126,16 +1105,10 @@ "TabAdvanced": "Geavanceerd", "TabAlbumArtists": "Albumartiesten", "TabCatalog": "Catalogus", - "TabChannels": "Kanalen", - "TabCollections": "Collecties", - "TabDevices": "Apparaten", "TabDirectPlay": "Direct Afspelen", "TabEpisodes": "Afleveringen", - "TabFavorites": "Favorieten", - "TabGuide": "Gids", "TabLatest": "Nieuw", "TabLogs": "Logboeken", - "TabMovies": "Films", "TabMusic": "Muziek", "TabMusicVideos": "Muziek Videos", "TabMyPlugins": "Mijn Plugins", @@ -1154,8 +1127,6 @@ "TabScheduledTasks": "Geplande taken", "TabSeries": "Serie", "TabSettings": "Instellingen", - "TabShows": "Series", - "TabSongs": "Titels", "TabUpcoming": "Binnenkort op TV", "TabUsers": "Gebruikers", "Tags": "Labels", @@ -1231,12 +1202,10 @@ "Filters": "Filters", "Genre": "Genre", "Genres": "Genres", - "HeaderAlbums": "Albums", "HeaderCastAndCrew": "Acteurs en medewerkers", "HeaderCastCrew": "Acteurs & medewerkers", "Art": "Afbeeldingen", "HeaderLiveTV": "Live TV", - "HeaderGenres": "Genres", "HeaderHttpHeaders": "HTTP Headers", "HeaderStatus": "Status", "AuthProviderHelp": "Selecteer een authenticatie provider om het wachtwoord van deze gebruiker te verifiëren.", @@ -1248,7 +1217,6 @@ "HeaderFavoriteSongs": "Favoriete nummers", "HeaderFavoriteVideos": "Favoriete Films", "HeaderInstantMix": "Directe Mix", - "HeaderItems": "Items", "HeaderLiveTv": "Live TV", "HeaderMedia": "Media", "HeaderTracks": "Nummers", @@ -1334,8 +1302,6 @@ "PasswordResetProviderHelp": "Kies een wachtwoord reset provider om te gebruiken wanneer deze gebruiker een wachtwoord reset aanvraagt", "Screenshots": "Schermafdruk", "Series": "Series", - "TabAlbums": "Albums", - "TabGenres": "Genres", "TabInfo": "Info", "Trailers": "Trailers", "Uniform": "Uniform", @@ -1456,7 +1422,6 @@ "EnableDetailsBanner": "Details Banner", "MessageSyncPlayNoGroupsAvailable": "Geen groepen beschikbaar. Begin eerst iets te spelen.", "EnableDetailsBannerHelp": "Toon een bannerafbeelding bovenaan de pagina met itemdetails.", - "TabDVR": "DVR", "SyncPlayAccessHelp": "Selecteer het toegangsniveau dat deze gebruiker heeft tot de SyncPlay-functie. SyncPlay maakt het mogelijk om het afspelen met andere gebruikers te synchroniseren.", "Filter": "Filter", "New": "Nieuw", diff --git a/src/strings/pl.json b/src/strings/pl.json index 781993f4fa..d4f88b4b44 100644 --- a/src/strings/pl.json +++ b/src/strings/pl.json @@ -36,7 +36,6 @@ "AsManyAsPossible": "Tak wiele jak to możliwe", "Ascending": "Rosnąco", "AspectRatio": "Proporcje obrazu", - "AttributeNew": "Nowy", "Audio": "Dźwięk", "Auto": "Automatycznie", "Backdrop": "Fototapeta", @@ -57,19 +56,12 @@ "ButtonAddScheduledTaskTrigger": "Dodaj wyzwalacz", "ButtonAddServer": "Dodaj Serwer", "ButtonAddUser": "Dodaj użytkownika", - "ButtonArrowDown": "Dół", "ButtonArrowLeft": "Lewa", "ButtonArrowRight": "Prawa", - "ButtonArrowUp": "Góra", "ButtonAudioTracks": "Ścieżki dźwiękowe", "ButtonBack": "Wstecz", "ButtonCancel": "Anuluj", "ButtonChangeServer": "Zmień Serwer", - "ButtonConnect": "Połacz", - "ButtonDelete": "Usuń", - "ButtonDeleteImage": "Usuń obraz", - "ButtonDown": "Dół", - "ButtonDownload": "Pobierz", "ButtonEdit": "Edytuj", "ButtonEditImages": "Edytuj obrazy", "ButtonEditOtherUserPreferences": "Edytuj profil, obrazy i ustawienia osobiste tego użytkownika.", @@ -84,7 +76,6 @@ "ButtonManualLogin": "Logowanie manualne", "ButtonMore": "Więcej", "ButtonNetwork": "Sieć", - "ButtonNew": "Nowe", "ButtonNextTrack": "Następny utwór", "ButtonOff": "Wyłącz", "ButtonOpen": "Otwórz", @@ -109,17 +100,14 @@ "ButtonSelectView": "Wybierz widok", "ButtonSend": "Wyślij", "ButtonSettings": "Ustawienia", - "ButtonShuffle": "Losowo", "ButtonShutdown": "Zamknij", "ButtonSignIn": "Zaloguj się", "ButtonSignOut": "Wyloguj", - "ButtonSort": "Sortuj", "ButtonStop": "Zatrzymaj", "ButtonSubmit": "Zatwierdź", "ButtonSubtitles": "Napisy", "ButtonTrailer": "Zwiastun", "ButtonUninstall": "Odinstaluj", - "ButtonUp": "Góra", "ButtonWebsite": "Strona WWW", "CancelRecording": "Anuluj nagranie", "CancelSeries": "Anuluj nagrywanie serialu", @@ -193,7 +181,6 @@ "EditImages": "Edytuj obrazy", "EditMetadata": "Edytuj metadane", "EditSubtitles": "Edytuj napisy", - "EnableBackdrops": "Fototapety", "EnableBackdropsHelp": "Wyświetlaj fototapety, w tle niektórych stron, podczas przeglądania biblioteki.", "EnableCinemaMode": "Tryb kinowy", "EnableColorCodedBackgrounds": "Kolorowe tła bazujące na zawartości", @@ -273,7 +260,6 @@ "HeaderAdditionalParts": "Dodatkowe części", "HeaderAdmin": "Administracja", "HeaderAlbumArtists": "Wykonawcy albumów", - "HeaderAlbums": "Albumy", "HeaderAlert": "Alarm", "HeaderAllowMediaDeletionFrom": "Zezwalaj na usuwanie mediów z", "HeaderApiKey": "Klucz API", @@ -291,7 +277,6 @@ "HeaderCastAndCrew": "Obsada i ekipa", "HeaderCastCrew": "Obsada i ekipa", "HeaderChannelAccess": "Dostęp do Kanałów", - "HeaderChannels": "Kanały", "HeaderChapterImages": "Obrazy rozdziałów", "HeaderCodecProfile": "Profil Kodeków", "HeaderCodecProfileHelp": "Profil Kodeków określa ograniczenia urządzenia podczas odtwarzania konkretnych kodeków. Jeśli ograniczenie ma zastosowanie, media będą transkodowane, nawet jeżeli kodek jest skonfigurowany dla odtwarzania bezpośredniego.", @@ -333,7 +318,6 @@ "HeaderForKids": "Dla dzieci", "HeaderForgotPassword": "Zapomniałem hasła", "HeaderFrequentlyPlayed": "Często odtwarzane", - "HeaderGenres": "Gatunki", "HeaderGuideProviders": "Dostawcy danych przewodnika telewizyjnego", "HeaderHttpHeaders": "Nagłówki HTTP", "HeaderIdentification": "Identyfikacja", @@ -344,7 +328,6 @@ "HeaderImageSettings": "Ustawienia obrazów", "HeaderInstall": "Instalacja", "HeaderInstantMix": "Szybki remiks", - "HeaderItems": "Pozycje", "HeaderKeepRecording": "Zachowaj nagranie", "HeaderKeepSeries": "Zachowaj nagranie serialu", "HeaderKodiMetadataHelp": "W celu aktywowania lub dezaktywowania metadanych NFO, należy zmodyfikować ustawienia biblioteki w sekcji menadżerów metadanych.", @@ -367,7 +350,6 @@ "HeaderMediaInfo": "O mediach", "HeaderMetadataSettings": "Ustawienia metadanych", "HeaderMoreLikeThis": "Więcej podobnych", - "HeaderMovies": "Filmy", "HeaderMusicQuality": "Jakość muzyki", "HeaderMusicVideos": "Teledyski", "HeaderMyDevice": "Moje urządzenie", @@ -428,7 +410,6 @@ "HeaderServerSettings": "Ustawienia serwera", "HeaderSettings": "Ustawienia", "HeaderSetupLibrary": "Skonfiguruj swoje biblioteki mediów", - "HeaderShutdown": "Zamknij", "HeaderSortBy": "Sortuj według", "HeaderSortOrder": "Porządek sortowania", "HeaderSpecialEpisodeInfo": "Specjalne informacje o odcinku", @@ -463,7 +444,6 @@ "HeaderXmlDocumentAttributes": "Atrybuty Dokumentu Xml", "HeaderXmlSettings": "Ustawienia Xml", "HeaderYears": "Lata", - "HeadersFolders": "Foldery", "Help": "Pomoc", "Hide": "Ukryj", "HideWatchedContentFromLatestMedia": "Ukrywaj obejrzaną zawartość na listach ostatnio dodanych", @@ -679,7 +659,6 @@ "LabelNewPassword": "Nowe hasło:", "LabelNewPasswordConfirm": "Potwierdź nowe hasło:", "LabelNewsCategories": "Kategorie informacyjne:", - "LabelNext": "Dalej", "LabelNotificationEnabled": "Aktywuj to powiadomienie", "LabelNumber": "Numer:", "LabelNumberOfGuideDays": "Liczba dni pobieranych danych przewodnika:", @@ -706,7 +685,6 @@ "LabelPreferredDisplayLanguage": "Preferowany język interfejsu:", "LabelPreferredDisplayLanguageHelp": "Tłumaczenie Jellyfin to projekt w ciągłym rozwoju.", "LabelPreferredSubtitleLanguage": "Preferowany język napisów:", - "LabelPrevious": "Wstecz", "LabelProfileAudioCodecs": "Kodeki audio:", "LabelProfileCodecs": "Kodeki:", "LabelProfileCodecsHelp": "Oddzielone przecinkiem. Zostaw puste aby zastosować wszystkie kodeki.", @@ -720,7 +698,6 @@ "LabelPublicHttpPortHelp": "Publiczny numer portu na który ma być zmapowany lokalny port HTTP.", "LabelPublicHttpsPort": "Publiczny numer portu HTTPS:", "LabelPublicHttpsPortHelp": "Publiczny numer portu na który ma być zmapowany lokalny port HTTPS.", - "LabelReadHowYouCanContribute": "Dowiedz się jak możesz pomóc.", "LabelReasonForTranscoding": "Powód transkodowania:", "LabelRecord": "Nagraj:", "LabelRecordingPath": "Folder domyślny nagrań:", @@ -925,7 +902,6 @@ "MessageNoNextUpItems": "Nie znaleziono niczego. Zacznij oglądać swoje seriale!", "MessageNoPluginConfiguration": "Ta wtyczka nie ma żadnych ustawień.", "NoSubtitleSearchResultsFound": "Brak wyników wyszukiwania.", - "NoSubtitles": "Brak", "NoSubtitlesHelp": "Domyślnie napisy nie będą wczytywane. Można je ciągle włączyć ręcznie podczas odtwarzania.", "None": "Brak", "Normal": "Normalny", @@ -1206,24 +1182,16 @@ "TabAccess": "Dostęp", "TabAdvanced": "Zaawansowane", "TabAlbumArtists": "Wykonawcy albumów", - "TabAlbums": "Albumy", "TabCatalog": "Katalog", - "TabChannels": "Kanały", "TabCodecs": "Kodeki", - "TabCollections": "Kolekcje", "TabContainers": "Kontenery", "TabDashboard": "Kokpit", - "TabDevices": "Urządzenia", "TabDirectPlay": "Odtwarzanie Bezposrednie", "TabEpisodes": "Odcinki", - "TabFavorites": "Ulubione", - "TabGenres": "Gatunki", - "TabGuide": "Przewodnik", "TabInfo": "Informacje", "TabLatest": "Ostatnio dodane", "TabLiveTV": "Telewizja", "TabLogs": "Dziennik zdarzeń", - "TabMovies": "Filmy", "TabMusic": "Muzyka", "TabMusicVideos": "Teledyski", "TabMyPlugins": "Zainstalowane", @@ -1244,8 +1212,6 @@ "TabSeries": "Seriale", "TabServer": "Serwer", "TabSettings": "Ustawienia", - "TabShows": "Seriale", - "TabSongs": "Utwory", "TabStreaming": "Transmitowanie", "TabTrailers": "Zwiastuny", "TabUpcoming": "Wkrótce", @@ -1457,7 +1423,6 @@ "Writers": "Scenariusz", "ViewAlbumArtist": "Zobacz wykonawcę albumu", "Track": "Utwór", - "TabDVR": "DVR", "TabRepositories": "Repozytoria", "SyncPlayAccessHelp": "Wybierz poziom dostępu do funkcji SyncPlay jaki posiada ten użytkownik. SyncPlay pozwala na synchronizację odtwarzania z innymi urządzeniami.", "Filter": "Filtruj", diff --git a/src/strings/pt-br.json b/src/strings/pt-br.json index 753b554da6..71913399f6 100644 --- a/src/strings/pt-br.json +++ b/src/strings/pt-br.json @@ -35,7 +35,6 @@ "AsManyAsPossible": "Quantos forem possíveis", "Ascending": "Crescente", "AspectRatio": "Proporção da tela", - "AttributeNew": "Novo", "Audio": "Áudio", "Backdrop": "Imagem de Fundo", "Backdrops": "Imagens de Fundo", @@ -53,18 +52,12 @@ "ButtonAddScheduledTaskTrigger": "Adicionar Disparador", "ButtonAddServer": "Adicionar Servidor", "ButtonAddUser": "Adicionar Usuário", - "ButtonArrowDown": "Baixo", "ButtonArrowLeft": "Esquerda", "ButtonArrowRight": "Direita", - "ButtonArrowUp": "Cima", "ButtonAudioTracks": "Faixas de Áudio", "ButtonBack": "Voltar", "ButtonCancel": "Cancelar", "ButtonChangeServer": "Alterar Servidor", - "ButtonConnect": "Conectar", - "ButtonDelete": "Excluir", - "ButtonDeleteImage": "Excluir Imagem", - "ButtonDown": "Baixo", "ButtonEdit": "Editar", "ButtonEditImages": "Editar imagens", "ButtonEditOtherUserPreferences": "Editar este perfil de usuário, imagem e preferências pessoais.", @@ -78,7 +71,6 @@ "ButtonManualLogin": "Login Manual", "ButtonMore": "Mais", "ButtonNetwork": "Rede", - "ButtonNew": "Novo", "ButtonNextTrack": "Próxima faixa", "ButtonOff": "Desligar", "ButtonOk": "OK", @@ -104,17 +96,14 @@ "ButtonSelectView": "Selecionar visualização", "ButtonSend": "Enviar", "ButtonSettings": "Configurações", - "ButtonShuffle": "Aleatório", "ButtonShutdown": "Desligar", "ButtonSignIn": "Entrar", "ButtonSignOut": "Sair", - "ButtonSort": "Ordenar", "ButtonStart": "Iniciar", "ButtonStop": "Parar", "ButtonSubmit": "Enviar", "ButtonSubtitles": "Legendas", "ButtonUninstall": "Desinstalar", - "ButtonUp": "Cima", "CancelRecording": "Cancelar gravação", "CancelSeries": "Cancelar série", "Categories": "Categorias", @@ -183,7 +172,6 @@ "EditImages": "Editar imagens", "EditMetadata": "Editar metadados", "EditSubtitles": "Editar legendas", - "EnableBackdrops": "Imagens de fundo", "EnableBackdropsHelp": "Exibe imagens de fundo de algumas páginas ao navegar pela biblioteca.", "EnableCinemaMode": "Modo cinema", "EnableColorCodedBackgrounds": "Cores de fundo por código", @@ -261,7 +249,6 @@ "HeaderAddUser": "Adicionar Usuário", "HeaderAdditionalParts": "Partes Adicionais", "HeaderAlbumArtists": "Artistas do Álbum", - "HeaderAlbums": "Álbuns", "HeaderAlert": "Alerta", "HeaderAllowMediaDeletionFrom": "Permitir a Exclusão de Mídia de", "HeaderApiKey": "Chave da API", @@ -278,7 +265,6 @@ "HeaderCastAndCrew": "Elenco e Equipe", "HeaderCastCrew": "Elenco e Equipe", "HeaderChannelAccess": "Acesso ao Canal", - "HeaderChannels": "Canais", "HeaderChapterImages": "Imagens do Capítulo", "HeaderCodecProfile": "Perfil do Codec", "HeaderCodecProfileHelp": "Perfis do Codec indicam as limitações de um dispositivo ao reproduzir codecs específicos. Se uma limitação ocorre, a mídia será transcodificada, mesmo se o codec estiver configurado para reprodução direta.", @@ -320,7 +306,6 @@ "HeaderForKids": "Para Crianças", "HeaderForgotPassword": "Esqueci a Senha", "HeaderFrequentlyPlayed": "Reproduzidos Frequentemente", - "HeaderGenres": "Gêneros", "HeaderGuideProviders": "Provedores de Dados do Guia da TV", "HeaderHttpHeaders": "Cabeçalhos de Http", "HeaderIdentification": "Identificação", @@ -331,7 +316,6 @@ "HeaderImageSettings": "Configurações de Imagem", "HeaderInstall": "Instalar", "HeaderInstantMix": "Mix Instantâneo", - "HeaderItems": "Itens", "HeaderKeepRecording": "Continuar Gravando", "HeaderKeepSeries": "Manter Série", "HeaderKodiMetadataHelp": "Para ativar ou desativar metadados NFO, edite uma biblioteca na configuração de Biblioteca do Jellyfin e localize a seção de gravadores de metadados.", @@ -354,7 +338,6 @@ "HeaderMediaInfo": "Informações de Mídia", "HeaderMetadataSettings": "Configurações dos Metadados", "HeaderMoreLikeThis": "Mais Disso", - "HeaderMovies": "Filmes", "HeaderMusicQuality": "Qualidade da Música", "HeaderMusicVideos": "Videoclipes", "HeaderMyDevice": "Meu Dispositivo", @@ -415,7 +398,6 @@ "HeaderServerSettings": "Configurações de Servidor", "HeaderSettings": "Configurações", "HeaderSetupLibrary": "Configurar suas bibliotecas de mídias", - "HeaderShutdown": "Desligar", "HeaderSortBy": "Ordenar Por", "HeaderSortOrder": "Ordem", "HeaderSpecialEpisodeInfo": "Informação do Episódio Especial", @@ -449,7 +431,6 @@ "HeaderXmlDocumentAttributes": "Atributos do Documento Xml", "HeaderXmlSettings": "Configurações Xml", "HeaderYears": "Anos", - "HeadersFolders": "Pastas", "Help": "Ajuda", "Hide": "Ocultar", "HideWatchedContentFromLatestMedia": "Ocultar conteúdo assistido das mídias recentes", @@ -663,7 +644,6 @@ "LabelNewPassword": "Nova senha:", "LabelNewPasswordConfirm": "Confirmar nova senha:", "LabelNewsCategories": "Categorias de notícias:", - "LabelNext": "Próximo", "LabelNotificationEnabled": "Ativar esta notificação", "LabelNumber": "Número:", "LabelNumberOfGuideDays": "Número de dias de dados do guia para baixar:", @@ -690,7 +670,6 @@ "LabelPreferredDisplayLanguage": "Idioma preferido de exibição:", "LabelPreferredDisplayLanguageHelp": "A tradução do Jellyfin é um projeto em andamento.", "LabelPreferredSubtitleLanguage": "Idioma de legendas preferido:", - "LabelPrevious": "Anterior", "LabelProfileAudioCodecs": "Codecs de áudio:", "LabelProfileCodecsHelp": "Separados por vírgula. Deixe em branco para aplicar a todos os codecs.", "LabelProfileContainersHelp": "Separados por vírgula. Deixe em branco para aplicar a todos os formatos.", @@ -702,7 +681,6 @@ "LabelPublicHttpPortHelp": "O número da porta pública que deverá ser mapeada para a porta local de HTTP.", "LabelPublicHttpsPort": "Número da porta pública de HTTPS:", "LabelPublicHttpsPortHelp": "O número da porta pública que deverá ser mapeada para a porta local de HTTPS.", - "LabelReadHowYouCanContribute": "Aprenda como você pode contribuir.", "LabelReasonForTranscoding": "Motivo da transcodificação:", "LabelRecord": "Gravar:", "LabelRecordingPath": "Local de gravação padrão:", @@ -901,7 +879,6 @@ "MessageNoNextUpItems": "Nada encontrado. Comece a assistir suas séries!", "MessageNoPluginConfiguration": "Este plugin não permite alterar configurações.", "NoSubtitleSearchResultsFound": "Nenhum resultado encontrado.", - "NoSubtitles": "Não há legendas", "NoSubtitlesHelp": "Legendas não serão carregadas por padrão. Elas podem ser carregadas manualmente durante a reprodução.", "None": "Nenhum(a)", "NumLocationsValue": "{0} pastas", @@ -1168,20 +1145,12 @@ "TabAccess": "Acesso", "TabAdvanced": "Avançado", "TabAlbumArtists": "Artistas do Álbum", - "TabAlbums": "Álbuns", "TabCatalog": "Catálogo", - "TabChannels": "Canais", - "TabCollections": "Coletâneas", "TabDashboard": "Painel", - "TabDevices": "Dispositivos", "TabDirectPlay": "Reprodução Direta", "TabEpisodes": "Episódios", - "TabFavorites": "Favoritos", - "TabGenres": "Gêneros", - "TabGuide": "Guia", "TabLatest": "Recentes", "TabLiveTV": "TV ao Vivo", - "TabMovies": "Filmes", "TabMusic": "Música", "TabMusicVideos": "Videoclipes", "TabMyPlugins": "Meus Plugins", @@ -1201,8 +1170,6 @@ "TabSeries": "Séries", "TabServer": "Servidor", "TabSettings": "Configurações", - "TabShows": "Séries", - "TabSongs": "Músicas", "TabUpcoming": "A Seguir", "TabUsers": "Usuários", "TellUsAboutYourself": "Conte-nos sobre você", @@ -1268,7 +1235,6 @@ "Auto": "Automático", "Banner": "Cartaz", "Blacklist": "Lista negra", - "ButtonDownload": "Download", "ButtonInfo": "Informações", "ButtonTrailer": "Trailer", "ButtonWebsite": "Site", @@ -1455,7 +1421,6 @@ "New": "Novo", "HeaderFavoritePlaylists": "Playlists Favoritas", "ApiKeysCaption": "Lista de chaves API ativadas no momento", - "TabDVR": "DVR", "SaveChanges": "Salvar mudanças", "LabelRequireHttpsHelp": "Se selecionado, o servidor vai automaticamente redirecionar todas as solicitações HTTP para HTTPS. Isso não terá efeito se o servidor não estiver escutando HTTPS.", "LabelRequireHttps": "Necessita HTTPS", diff --git a/src/strings/pt-pt.json b/src/strings/pt-pt.json index 3d780043aa..2d6890ff6d 100644 --- a/src/strings/pt-pt.json +++ b/src/strings/pt-pt.json @@ -4,7 +4,6 @@ "AddToPlaylist": "Adicionar à lista de reprodução", "AdditionalNotificationServices": "Explore o catálogo de extensões para instalar serviços adicionais de notificação.", "All": "Todos", - "AttributeNew": "Novo", "Audio": "Áudio", "Backdrops": "Imagens de Fundo", "MessageBrowsePluginCatalog": "Procure extensões disponíveis no nosso catálogo.", @@ -12,16 +11,11 @@ "ButtonAddScheduledTaskTrigger": "Adicionar tarefa agendada", "ButtonAddServer": "Adicionar Servidor", "ButtonAddUser": "Adicionar Utilizador", - "ButtonArrowDown": "Baixo", "ButtonArrowLeft": "Esquerda", "ButtonArrowRight": "Direita", - "ButtonArrowUp": "Cima", "ButtonBack": "Voltar", "ButtonCancel": "Cancelar", "ButtonChangeServer": "Alterar Servidor", - "ButtonConnect": "Ligar", - "ButtonDelete": "Remover", - "ButtonDeleteImage": "Apagar imagem", "ButtonEdit": "Editar", "ButtonEditOtherUserPreferences": "Editar este perfil de utilizador, imagem e preferências pessoais.", "ButtonFilter": "Filtro", @@ -32,7 +26,6 @@ "ButtonManualLogin": "Início de Sessão Manual", "ButtonMore": "Mais", "ButtonNetwork": "Rede", - "ButtonNew": "Novo", "ButtonNextTrack": "Faixa seguinte", "ButtonOpen": "Abrir", "ButtonPause": "Pausar", @@ -53,11 +46,9 @@ "ButtonSelectView": "Selecionar visualização", "ButtonSend": "Enviar", "ButtonSettings": "Configurações", - "ButtonShuffle": "Aleatório", "ButtonShutdown": "Encerrar", "ButtonSignIn": "Iniciar Sessão", "ButtonSignOut": "Sair", - "ButtonSort": "Organizar", "ButtonStart": "Iniciar", "ButtonStop": "Parar", "ButtonSubmit": "Enviar", @@ -120,7 +111,6 @@ "HeaderBranding": "Marca", "HeaderCastCrew": "Elenco e Equipa", "HeaderChannelAccess": "Acesso ao Canal", - "HeaderChannels": "Canais", "HeaderCodecProfile": "Perfil do Codec", "HeaderCodecProfileHelp": "Perfis do Codec indicam as limitações de um dispositivo ao reproduzir codecs específicos. Se uma limitação ocorre, o ficheiro multimédia será transcodificado, mesmo se o codec estiver configurado para reprodução direta.", "HeaderConfirmProfileDeletion": "Confirmar Remoção do Perfil", @@ -147,7 +137,6 @@ "HeaderFetchImages": "Procurar Imagens:", "HeaderForgotPassword": "Esqueci-me da palavra-passe", "HeaderFrequentlyPlayed": "Reproduzido Frequentemente", - "HeaderGenres": "Géneros", "HeaderGuideProviders": "Provedores de Programação de TV", "HeaderHttpHeaders": "Cabeçalhos HTTP", "HeaderIdentification": "Identificação", @@ -216,7 +205,6 @@ "HeaderServerSettings": "Configurações do Servidor", "HeaderSettings": "Configurações", "HeaderSetupLibrary": "Configurar Bibliotecas Multimédia", - "HeaderShutdown": "Encerrar", "HeaderSpecialEpisodeInfo": "Informação do Episódio Especial", "HeaderSpecialFeatures": "Extras", "HeaderStatus": "Estado", @@ -238,7 +226,6 @@ "HeaderXmlDocumentAttributes": "Atributos do Documento XML", "HeaderXmlSettings": "Configurações de XML", "HeaderYears": "Anos", - "HeadersFolders": "Pastas", "Help": "Ajuda", "Identify": "Identificar", "Images": "Imagens", @@ -395,7 +382,6 @@ "LabelName": "Nome:", "LabelNewPassword": "Nova palavra-passe:", "LabelNewPasswordConfirm": "Confirmar nova palavra-passe:", - "LabelNext": "Seguinte", "LabelNotificationEnabled": "Ativar esta notificação", "LabelNumberOfGuideDays": "Número de dias de programação de TV para transferir:", "LabelNumberOfGuideDaysHelp": "Transferir mais dias de programação de TV permite agendar com maior antecedência e ver mais listagens, no entanto, irá levar mais tempo a transferir. Se selecionar Automático, será escolhido o período baseado no número de canais.", @@ -411,7 +397,6 @@ "LabelPlayDefaultAudioTrack": "Reproduzir a faixa de áudio padrão independentemente do idioma", "LabelPreferredDisplayLanguage": "Idioma de visualização preferido:", "LabelPreferredDisplayLanguageHelp": "A tradução do Jellyfin é um projeto contínuo.", - "LabelPrevious": "Anterior", "LabelProfileAudioCodecs": "Codecs do áudio:", "LabelProfileCodecsHelp": "Separados por vírgula. Pode ser deixado em branco para usar com todos os codecs.", "LabelProfileContainer": "Contentor:", @@ -424,7 +409,6 @@ "LabelPublicHttpPortHelp": "Número do porto público que deverá ser mapeado para o porto HTTP local.", "LabelPublicHttpsPort": "Número do porto público HTTPS:", "LabelPublicHttpsPortHelp": "Número do porto público que deverá ser mapeado para o porto HTTPS local.", - "LabelReadHowYouCanContribute": "Veja como pode contribuir.", "LabelRecordingPath": "Localização predefinida das gravações:", "LabelReleaseDate": "Data de lançamento:", "LabelRemoteClientBitrateLimit": "Taxa de bits máxima para transmissão para a Internet (Mbps):", @@ -667,21 +651,13 @@ "TabAccess": "Acesso", "TabAdvanced": "Avançado", "TabAlbumArtists": "Artistas do Álbum", - "TabAlbums": "Álbuns", "TabCatalog": "Catálogo", - "TabChannels": "Canais", - "TabCollections": "Coleções", "TabContainers": "Contentores", "TabDashboard": "Painel Principal", - "TabDevices": "Dispositivos", "TabDirectPlay": "Reprodução Direta", "TabEpisodes": "Episódios", - "TabFavorites": "Favoritos", - "TabGenres": "Géneros", - "TabGuide": "Programação", "TabLatest": "Mais recente", "TabLiveTV": "TV em Direto", - "TabMovies": "Filmes", "TabMusic": "Música", "TabMusicVideos": "Videoclips", "TabMyPlugins": "As Minhas Extensões", @@ -701,8 +677,6 @@ "TabSeries": "Séries", "TabServer": "Servidor", "TabSettings": "Configurações", - "TabShows": "Séries", - "TabSongs": "Músicas", "TabUpcoming": "Próximos", "TabUsers": "Utilizadores", "TellUsAboutYourself": "Fale-nos sobre si", @@ -799,7 +773,6 @@ "ButtonGuide": "Programação", "ButtonGotIt": "Entendido", "ButtonEditImages": "Editar imagens", - "ButtonDownload": "Transferir", "ButtonAudioTracks": "Faixas de Áudio", "Browse": "Procurar", "BoxRear": "Caixa (verso)", @@ -812,7 +785,6 @@ "Aired": "Estreou", "HeaderKeepRecording": "Manter Gravação", "HeaderKeepSeries": "Manter Série", - "HeaderItems": "Itens", "HeaderImageOptions": "Opções de Imagem", "HeaderHome": "Início", "HeaderForKids": "Para Crianças", @@ -837,7 +809,6 @@ "HeaderAudioBooks": "Livros de Áudio", "HeaderAllowMediaDeletionFrom": "Permitir remoção de multimédia a partir de", "HeaderAlert": "Alerta", - "HeaderAlbums": "Álbuns", "HeaderAddToPlaylist": "Adicionar à Lista de Reprodução", "HDPrograms": "Programas HD", "EncoderPresetHelp": "Escolha um valor mais rápido para melhorar o desempenho, ou um valor mais lento para melhorar a qualidade.", @@ -951,8 +922,6 @@ "LabelSelectFolderGroups": "Agrupar automaticamente o conteúdo das seguintes pastas em vistas como Filmes, Música e TV:", "HeaderUpcomingOnTV": "A Seguir", "HeaderLiveTvTunerSetup": "Configurar Sintonizador de TV", - "ButtonUp": "Para cima", - "ButtonDown": "Para baixo", "RecordSeries": "Gravar série", "LabelKeepUpTo": "Manter, no máximo:", "AroundTime": "Por volta das {0}", @@ -1042,7 +1011,6 @@ "Sports": "Desporto", "News": "Notícias", "Programs": "Programas", - "HeaderMovies": "Filmes", "Directors": "Realização", "ButtonOff": "Desligado", "ButtonAddImage": "Adicionar Imagem", @@ -1146,7 +1114,6 @@ "DetectingDevices": "A procurar dispositivos", "CopyStreamURL": "Copiar URL da transmissão", "Disc": "Disco", - "EnableBackdrops": "Imagens de Fundo", "LabelLogs": "Registos:", "LabelSortTitle": "Título para ordenação:", "HeaderFavoritePeople": "Pessoas Favoritas", @@ -1287,7 +1254,6 @@ "No": "Não", "OptionRegex": "Expressão Regular", "OptionCaptionInfoExSamsung": "CaptionInfoEx (Samsung)", - "NoSubtitles": "Sem legendas", "NoSubtitleSearchResultsFound": "Sem resultados.", "NoNewDevicesFound": "Não foi encontrado nenhum dispositivo novo. Para adicionar um novo sintonizador, feche este diálogo e introduza manualmente as informações do dispositivo.", "NextUp": "A Seguir", diff --git a/src/strings/pt.json b/src/strings/pt.json index 9863623dc0..324f08a064 100644 --- a/src/strings/pt.json +++ b/src/strings/pt.json @@ -36,8 +36,6 @@ "TabUsers": "Utilizadores", "TabUpcoming": "Próximos", "TabStreaming": "Transmissão", - "TabSongs": "Músicas", - "TabShows": "Séries", "TabSettings": "Configurações", "TabServer": "Servidor", "TabSeries": "Séries", @@ -57,21 +55,13 @@ "TabMyPlugins": "As Minhas Extensões", "TabMusicVideos": "Videoclips", "TabMusic": "Música", - "TabMovies": "Filmes", "TabLiveTV": "TV em Directo", "TabLatest": "Mais recente", - "TabGuide": "Programação", - "TabGenres": "Géneros", - "TabFavorites": "Favoritos", "TabEpisodes": "Episódios", "TabDirectPlay": "Reprodução Directa", - "TabDevices": "Dispositivos", "TabDashboard": "Painel Principal", "TabContainers": "Contentores", - "TabCollections": "Colecções", - "TabChannels": "Canais", "TabCatalog": "Catálogo", - "TabAlbums": "Álbuns", "TabAlbumArtists": "Artistas do Álbum", "TabAdvanced": "Avançado", "TabAccess": "Acesso", @@ -212,7 +202,6 @@ "LabelRecordingPathHelp": "Especifique a localização por omissão para guardar as gravações. Se for deixado em branco, a pasta base do servidor será utilizada.", "LabelRecordingPath": "Localização predefinida das gravações:", "LabelReasonForTranscoding": "Razão para transcodificação:", - "LabelReadHowYouCanContribute": "Veja como pode contribuir.", "LabelPublicHttpsPortHelp": "Número da porta pública que deverá ser transferida para a porta HTTPS local.", "LabelPublicHttpsPort": "Número da porta HTTPS pública:", "LabelPublicHttpPortHelp": "Número da porta pública que deverá ser transferida para a porta HTTP local.", @@ -226,7 +215,6 @@ "LabelProfileCodecsHelp": "Separados por vírgula. Pode ser deixado em branco para usar com todos os codecs.", "LabelProfileCodecs": "Codecs:", "LabelProfileAudioCodecs": "Codecs do áudio:", - "LabelPrevious": "Anterior", "LabelPreferredSubtitleLanguage": "Idioma de legendas preferido:", "LabelPreferredDisplayLanguageHelp": "A tradução do Jellyfin é um projeto contínuo.", "LabelPreferredDisplayLanguage": "Idioma de visualização preferido:", @@ -253,7 +241,6 @@ "LabelNumberOfGuideDays": "Número de dias de programação de TV para transferir:", "LabelNumber": "Número:", "LabelNotificationEnabled": "Activar esta notificação", - "LabelNext": "Seguinte", "LabelNewsCategories": "Categorias para notícias:", "LabelNewPasswordConfirm": "Confirmar nova palavra-passe:", "LabelNewPassword": "Nova palavra-passe:", @@ -478,7 +465,6 @@ "HideWatchedContentFromLatestMedia": "Ocultar os títulos já vistos do conteúdo recente", "Hide": "Esconder", "Help": "Ajuda", - "HeadersFolders": "Pastas", "HeaderYears": "Anos", "HeaderXmlSettings": "Configurações de XML", "HeaderXmlDocumentAttribute": "Atributo do Documento XML", @@ -510,7 +496,6 @@ "HeaderSpecialEpisodeInfo": "Informação do Episódio Especial", "HeaderSortOrder": "Direcção de Ordenação", "HeaderSortBy": "Ordenar Por", - "HeaderShutdown": "Encerrar", "HeaderSetupLibrary": "Configurar Bibliotecas Multimédia", "HeaderSettings": "Configurações", "HeaderServerSettings": "Configurações do Servidor", @@ -571,7 +556,6 @@ "HeaderMyDevice": "O Meu Dispositivo", "HeaderMusicVideos": "Videoclips", "HeaderMusicQuality": "Qualidade da Música", - "HeaderMovies": "Filmes", "HeaderMoreLikeThis": "Mais Como Este", "HeaderMetadataSettings": "Configurações de Metadados", "HeaderMediaInfo": "Informações Multimédia", @@ -592,7 +576,6 @@ "HeaderLatestEpisodes": "Últimos Episódios", "HeaderKeepSeries": "Manter Série", "HeaderKeepRecording": "Manter Gravação", - "HeaderItems": "Itens", "HeaderInstantMix": "Mistura instantânea", "HeaderInstall": "Instalar", "HeaderImageSettings": "Configurações de Imagem", @@ -604,7 +587,6 @@ "HeaderHttpHeaders": "Cabeçalhos HTTP", "HeaderHome": "Início", "HeaderGuideProviders": "Provedores de Programação de TV", - "HeaderGenres": "Géneros", "HeaderDeleteTaskTrigger": "Excluir Tarefa Agendada", "HeaderBranding": "Marca", "HeaderFrequentlyPlayed": "Reproduzido Frequentemente", @@ -861,7 +843,6 @@ "EnableColorCodedBackgrounds": "Código de cores para o fundo", "EnableCinemaMode": "Modo cinema", "EnableBackdropsHelp": "Mostrar imagens de fundo em algumas páginas durante a navegação pela Biblioteca.", - "EnableBackdrops": "Pano de fundo", "EditSubtitles": "Editar legendas", "EditMetadata": "Editar metadados", "EditImages": "Editar imagens", @@ -935,18 +916,15 @@ "CancelSeries": "Cancelar gravação de série", "CancelRecording": "Cancelar gravação", "ButtonWebsite": "Website", - "ButtonUp": "Para cima", "ButtonUninstall": "Desinstalar", "ButtonTrailer": "Trailer", "ButtonSubtitles": "Legendas", "ButtonSubmit": "Enviar", "ButtonStop": "Parar", "ButtonStart": "Iniciar", - "ButtonSort": "Organizar", "ButtonSignOut": "Sair", "ButtonSignIn": "Iniciar Sessão", "ButtonShutdown": "Encerrar", - "ButtonShuffle": "Aleatório", "ButtonSend": "Enviar", "ButtonSettings": "Configurações", "ButtonSelectView": "Seleccionar visualização", @@ -972,7 +950,6 @@ "ButtonOk": "OK", "ButtonOff": "Desligado", "ButtonNextTrack": "Faixa seguinte", - "ButtonNew": "Novo", "ButtonNetwork": "Rede", "ButtonMore": "Mais", "ButtonManualLogin": "Início de Sessão Manual", @@ -985,17 +962,12 @@ "ButtonEditOtherUserPreferences": "Editar este perfil de utilizador, imagem e preferências pessoais.", "ButtonEditImages": "Editar imagens", "ButtonEdit": "Editar", - "ButtonDownload": "Transferir", - "ButtonDown": "Para baixo", "Auto": "Automático", "AlwaysPlaySubtitles": "Mostrar sempre legendas", "AllowMediaConversionHelp": "Permitir ou negar acesso à funcionalidade de conversão multimédia.", "AllowMediaConversion": "Permitir conversão multimédia", "ButtonGuide": "Programação", "ButtonGotIt": "Entendido", - "ButtonDeleteImage": "Remover imagem", - "ButtonDelete": "Remover", - "ButtonConnect": "Ligar", "ButtonChangeServer": "Alterar Servidor", "ButtonCancel": "Cancelar", "ButtonBack": "Voltar", @@ -1033,10 +1005,8 @@ "LabelBitrate": "Taxa de bits:", "LabelBirthYear": "Ano de nascimento:", "ButtonAudioTracks": "Faixas de Áudio", - "ButtonArrowUp": "Cima", "ButtonArrowRight": "Direita", "ButtonArrowLeft": "Esquerda", - "ButtonArrowDown": "Baixo", "ButtonAddUser": "Adicionar Utilizador", "ButtonAddServer": "Adicionar Servidor", "ButtonAddScheduledTaskTrigger": "Adicionar tarefa agendada", @@ -1058,7 +1028,6 @@ "Backdrop": "Imagem de Fundo", "AuthProviderHelp": "Seleccione um mecanismo de autenticação a ser utilizado para validar as credenciais deste utilizador.", "Audio": "Áudio", - "AttributeNew": "Novo", "AspectRatio": "Proporção da tela", "Ascending": "Crescente", "Art": "Capa", @@ -1113,7 +1082,6 @@ "HeaderCodecProfileHelp": "Os perfis do Codec indicam as limitações de um dispositivo ao reproduzir codecs específicos. Se uma limitação ocorrer, o ficheiro multimédia será transcodificado, mesmo se o codec estiver configurado para reprodução direta.", "HeaderCodecProfile": "Perfil do Codec", "HeaderChapterImages": "Imagens do Capítulo", - "HeaderChannels": "Canais", "HeaderChannelAccess": "Acesso ao Canal", "HeaderCastCrew": "Elenco e Equipa", "HeaderCancelSeries": "Cancelar Gravação de Série", @@ -1128,7 +1096,6 @@ "HeaderApiKey": "Chave da API", "HeaderAllowMediaDeletionFrom": "Permitir remoção de multimédia a partir de", "HeaderAlert": "Alerta", - "HeaderAlbums": "Álbuns", "HeaderAlbumArtists": "Artistas do Álbum", "HeaderAdditionalParts": "Partes Adicionais", "HeaderAddUser": "Adicionar Utilizador", @@ -1203,7 +1170,6 @@ "Normal": "Normal", "None": "Nenhum", "NoSubtitlesHelp": "As legendas não serão carregadas por padrão. Eles ainda podem ser ativados manualmente durante a reprodução.", - "NoSubtitles": "Sem legendas", "NoSubtitleSearchResultsFound": "Nenhum resultado encontrado.", "NoNewDevicesFound": "Não foram encontrados novos dispositivos. Para adicionar um novo sintonizador, feche esta caixa de diálogo e insira as informações do dispositivo manualmente.", "NoCreatedLibraries": "Parece que você ainda não criou nenhuma biblioteca. {0} Deseja criar um agora? {1}", diff --git a/src/strings/ro.json b/src/strings/ro.json index a627be87fb..7fcce88aa2 100644 --- a/src/strings/ro.json +++ b/src/strings/ro.json @@ -3,12 +3,9 @@ "ButtonAddScheduledTaskTrigger": "Adaugă declanșator", "ButtonAddUser": "Adaugă Utilizator", "ButtonCancel": "Anulează", - "ButtonDelete": "Șterge", - "ButtonDeleteImage": "Șterge Imaginea", "ButtonEdit": "Modifică", "ButtonFilter": "Filtru", "ButtonManualLogin": "Conectare manuală", - "ButtonNew": "Nou", "ButtonPlay": "Redă", "ButtonQuickStartGuide": "Ghid rapid de Start", "ButtonRefresh": "Reîmprospătează", @@ -18,7 +15,6 @@ "ButtonSelectDirectory": "Selectați Director", "ButtonSignIn": "Autentificare", "ButtonSignOut": "Delogare", - "ButtonSort": "Sortează", "ChannelAccessHelp": "Selectează canalele pe care vrei să le partajezi cu acest utilizator. Administratorii vor avea posibilitatea să modifice canalele folosind managerul de metadate.", "Continuing": "Continuă", "DefaultMetadataLangaugeDescription": "Acestea sunt setările implicite și pot fi personalizate pentru fiecare bibliotecă în parte.", @@ -35,7 +31,6 @@ "HeaderActiveRecordings": "Înregistrări active", "HeaderAddScheduledTaskTrigger": "Adaugă declanșator", "HeaderAddUser": "Adaugă Utilizator", - "HeaderChannels": "Canale", "HeaderContinueWatching": "Vizionează în continuare", "HeaderDeviceAccess": "Accesul Dispozitivelor", "HeaderEasyPinCode": "Cod Pin Ușor", @@ -82,11 +77,9 @@ "LabelName": "Nume:", "LabelNewPassword": "Parola nouă:", "LabelNewPasswordConfirm": "Confirmă parola nouă:", - "LabelNext": "Următorul", "LabelNumberOfGuideDays": "Numărul de zile de ghid de descărcat:", "LabelNumberOfGuideDaysHelp": "Descărcând mai multe zile de ghid va permite să programați mai în avans și să vizualizați listările mai în viitor, dar descărcarea va dura mai mult. \"Automat\" va alege în funcție de numărul de canale.", "LabelPassword": "Parolă:", - "LabelPrevious": "Anteriorul", "LabelRecordingPath": "Calea implicită pentru înregistrări:", "LabelRecordingPathHelp": "Specificați locația implicită pentru a salva înregistrările. Dacă lasați necompletat, va fi utilizat directorul curent în care ruleză programul serverului.", "LabelSaveLocalMetadata": "Salvează posterele si metadata în dosarele ce conțin fișierele media", @@ -177,15 +170,8 @@ "TabAccess": "Acces", "TabAdvanced": "Avansat", "TabAlbumArtists": "Albume Artiști", - "TabAlbums": "Albume", - "TabChannels": "Canale", - "TabCollections": "Colecții", "TabEpisodes": "Episoade", - "TabFavorites": "Favorite", - "TabGenres": "Genuri", - "TabGuide": "Ghid", "TabLatest": "Cele mai recente", - "TabMovies": "Filme", "TabMusic": "Muzică", "TabMusicVideos": "Videoclipuri muzicale", "TabMyPlugins": "Plugin-urile mele", @@ -198,8 +184,6 @@ "TabRecordings": "Înregistrări", "TabSeries": "Seriale", "TabSettings": "Setări", - "TabShows": "Seriale", - "TabSongs": "Melodii", "TabTrailers": "Trailere", "TabUpcoming": "Urmează să apară", "TellUsAboutYourself": "Spune-ne despre tine", @@ -257,14 +241,12 @@ "Blacklist": "Lista neagră", "Books": "Cărți", "Box": "Cutie", - "AttributeNew": "Nou", "Audio": "Audio", "BoxRear": "Cutie (spate)", "Browse": "Răsfoire", "MessageBrowsePluginCatalog": "Răsfoiți catalogul de pluginuri pentru a vedea ce este disponibil.", "ButtonAddMediaLibrary": "Adaugă Librărie Media", "ButtonAddServer": "Adaugă Server", - "ButtonArrowDown": "Jos", "ButtonArrowLeft": "Stânga", "ButtonArrowRight": "Dreapta", "Disc": "Placă", @@ -298,13 +280,9 @@ "Artists": "Artiști", "BookLibraryHelp": "Cărți audio și text sunt suportate. Verifică {0} ghidul numirii cărților{1}.", "ButtonAddImage": "Adaugă Imagine", - "ButtonArrowUp": "Sus", "ButtonAudioTracks": "Cale Audio", "ButtonBack": "Înapoi", "ButtonChangeServer": "Schimbă Server", - "ButtonConnect": "Conectare", - "ButtonDown": "Jos", - "ButtonDownload": "Descarcă", "ButtonEditImages": "Modifică imaginile", "ButtonEditOtherUserPreferences": "Modifică profilul, imaginea și preferințele personale ale acestui utilizator.", "ButtonForgotPassword": "Parolă uitată", @@ -339,13 +317,11 @@ "ButtonSelectServer": "Selectați Server", "ButtonSelectView": "Selectați perspectivă", "ButtonSend": "Trimite", - "ButtonShuffle": "Amestecă", "ButtonShutdown": "Oprește", "ButtonStart": "Start", "ButtonSubtitles": "Subtitrări", "ButtonTrailer": "Trailer", "ButtonUninstall": "Dezinstalează", - "ButtonUp": "Sus", "ButtonWebsite": "Website", "CancelRecording": "Anulează înregistrarea", "CancelSeries": "Anulează serial", @@ -418,7 +394,6 @@ "HeaderFetcherSettings": "Setări Fetcher", "HeaderForKids": "Pentru Copii", "HeaderForgotPassword": "Am uitat parola", - "HeaderGenres": "Genuri", "HeaderGuideProviders": "Furnizori de date ghid TV", "HeaderHome": "Acasă", "HeaderHttpHeaders": "Anteturi HTTP", @@ -439,7 +414,6 @@ "HeaderMediaInfo": "Informații Media", "HeaderMetadataSettings": "Setări metadate", "HeaderMoreLikeThis": "Mai multe ca acesta", - "HeaderMovies": "Filme", "HeaderMusicQuality": "Calitatea muzicii", "HeaderConfirmRevokeApiKey": "Revocați cheia API", "HeaderMusicVideos": "Videoclipuri Muzicale", @@ -497,7 +471,6 @@ "HeaderAddToPlaylist": "Adauga la lista de redare", "HeaderAddUpdateImage": "Adăugați/Actualizați Imaginea", "HeaderAdditionalParts": "Părți Adiționale", - "HeaderAlbums": "Albume", "HeaderAlert": "Alertă", "HeaderAllowMediaDeletionFrom": "Permite ștergerea media din", "HeaderAppearsOn": "Apare în", @@ -511,7 +484,6 @@ "HeaderDevices": "Dispozitive", "HeaderDirectPlayProfile": "Profil de redare directă", "HeaderDirectPlayProfileHelp": "Adăugați profiluri de redare directă pentru a indica ce formate se pot gestiona în mod nativ.", - "HeaderItems": "Elemente", "HeaderKeepSeries": "Păstrează seriile", "HeaderLatestMedia": "Cele mai recente media", "HeaderLibraryOrder": "Ordinea Bibliotecii", @@ -571,7 +543,6 @@ "DropShadow": "Umbra", "EasyPasswordHelp": "Codul dvs. PIN simplu este utilizat pentru accesul offline la clienții suportați și poate fi folosit și pentru conectarea ușoară în rețea.", "EditSubtitles": "Editează subtitrări", - "EnableBackdrops": "Decoruri", "EnableBackdropsHelp": "Afișați decoruri în fundalul unor pagini în timp ce navigați în bibliotecă.", "EnableColorCodedBackgrounds": "Fundaluri codate color", "EnableDisplayMirroring": "Afișează in oglinda", @@ -609,7 +580,6 @@ "HeaderSeriesStatus": "Starea Serialelor", "HeaderServerSettings": "Setările Serverului", "HeaderSettings": "Setări", - "HeaderShutdown": "Opriți Alimentarea", "HeaderSortBy": "Sortează după", "HeaderSortOrder": "Ordinea de sortare", "LabelTranscodingThreadCount": "Numărul de threaduri ale transcodării:", @@ -671,7 +641,6 @@ "LabelRefreshMode": "Mod reîmprospătare:", "LabelRecord": "Înregistrare:", "LabelReasonForTranscoding": "Motiv pentru transcodare:", - "LabelReadHowYouCanContribute": "Aflați cum puteți contribui.", "LabelPublicHttpsPortHelp": "Numărul de port public care ar trebui mapat în portul HTTPS local.", "LabelPublicHttpsPort": "Portul HTTPS public:", "LabelPublicHttpPortHelp": "Numărul de port public care ar trebui mapat în portul HTTP local.", @@ -913,7 +882,6 @@ "Home": "Acasă", "HideWatchedContentFromLatestMedia": "Ascunde conținutul vizionat din cele mai recente media", "Hide": "Ascunde", - "HeadersFolders": "Dosare", "HeaderYears": "Ani", "HeaderXmlSettings": "XML setări", "HeaderXmlDocumentAttributes": "XML Document Atribute", @@ -980,7 +948,6 @@ "Normal": "Normal", "None": "Nici unul", "NoSubtitlesHelp": "Subtitrările nu vor fi încărcate în mod implicit. Acestea pot fi însă activate manual în timpul redării.", - "NoSubtitles": "Fără", "NoSubtitleSearchResultsFound": "Nici un rezultat găsit.", "MessageNoPluginConfiguration": "Acest plugin nu are setări de configurat.", "NoNewDevicesFound": "Nu s-au găsit dispozitive noi. Pentru a adăuga un nou tuner, închideți acest dialog și introduceți informațiile dispozitivului manual.", @@ -1399,7 +1366,6 @@ "TabLiveTV": "TV în Direct", "TabInfo": "Info", "TabDirectPlay": "Redare directă", - "TabDevices": "Dispozitive", "TabDashboard": "Tablou de bord", "TabContainers": "Containere", "TabCodecs": "Codecuri", @@ -1464,7 +1430,6 @@ "HeaderServerAddressSettings": "Setările adresei serverului", "HeaderRemoteAccessSettings": "Setări pentru aces remote", "HeaderHttpsSettings": "Setări https", - "TabDVR": "DVR", "SaveChanges": "Salvează modificările", "HeaderDVR": "DVR", "SyncPlayAccessHelp": "Selectați nivelul de acces pe care îl are acest utilizator la funcția SyncPlay. SyncPlay permite sincronizarea redării cu alte dispozitive.", diff --git a/src/strings/ru.json b/src/strings/ru.json index a35a15642d..f7ec2e0715 100644 --- a/src/strings/ru.json +++ b/src/strings/ru.json @@ -36,7 +36,6 @@ "AsManyAsPossible": "Как можно больше", "Ascending": "По возрастанию", "AspectRatio": "Соотношение сторон", - "AttributeNew": "Новинка", "Audio": "Аудио", "Auto": "Авто", "Backdrop": "Фон", @@ -57,19 +56,12 @@ "ButtonAddScheduledTaskTrigger": "Добавить триггер", "ButtonAddServer": "Добавить сервер", "ButtonAddUser": "Добавить пользователя", - "ButtonArrowDown": "Вниз", "ButtonArrowLeft": "Влево", "ButtonArrowRight": "Вправо", - "ButtonArrowUp": "Вверх", "ButtonAudioTracks": "Аудиодорожки", "ButtonBack": "Назад", "ButtonCancel": "Отменить", "ButtonChangeServer": "Сменить сервер", - "ButtonConnect": "Подсоединиться", - "ButtonDelete": "Удалить", - "ButtonDeleteImage": "Удалить изображение", - "ButtonDown": "Вниз", - "ButtonDownload": "Загрузить", "ButtonEdit": "Править", "ButtonEditImages": "Править изображения", "ButtonEditOtherUserPreferences": "Править профиль, изображение и персональные настройки этого пользователя.", @@ -84,7 +76,6 @@ "ButtonManualLogin": "Войти вручную", "ButtonMore": "Ещё", "ButtonNetwork": "Сеть", - "ButtonNew": "Новое", "ButtonNextTrack": "Следующая дорожка", "ButtonOff": "Откл", "ButtonOk": "Ок", @@ -110,11 +101,9 @@ "ButtonSelectView": "Выбрать представление", "ButtonSend": "Передать", "ButtonSettings": "Параметры", - "ButtonShuffle": "Перемешать", "ButtonShutdown": "Завершить работу", "ButtonSignIn": "Вход", "ButtonSignOut": "Выйти", - "ButtonSort": "Сортировать", "ButtonStart": "Запустить", "ButtonStop": "Остановить", "ButtonSubmit": "Подтвердить", @@ -122,7 +111,6 @@ "ButtonTogglePlaylist": "Плей-лист", "ButtonTrailer": "Трейлер", "ButtonUninstall": "Удалить", - "ButtonUp": "Вверх", "ButtonWebsite": "Веб-сайт", "CancelRecording": "Отменить запись", "CancelSeries": "Отменить сериал", @@ -195,7 +183,6 @@ "EditImages": "Править изображения", "EditMetadata": "Править метаданные", "EditSubtitles": "Править субтитры", - "EnableBackdrops": "Фоны", "EnableBackdropsHelp": "Фоны будут отображаются на заднем плане на некоторых страницах при просмотре медиатеки.", "EnableCinemaMode": "Режим кинозала", "EnableColorCodedBackgrounds": "Обозначеннные цветом фоны", @@ -276,7 +263,6 @@ "HeaderAdditionalParts": "Дополнительные части", "HeaderAdmin": "Администрирование", "HeaderAlbumArtists": "Исполнители альбома", - "HeaderAlbums": "Альбомы", "HeaderAlert": "Предупреждение", "HeaderAllowMediaDeletionFrom": "Разрешить удаление медиаданных из", "HeaderApiKey": "API-ключ", @@ -294,7 +280,6 @@ "HeaderCastAndCrew": "Снимались и снимали", "HeaderCastCrew": "Снимались и снимали", "HeaderChannelAccess": "Доступ ко каналам", - "HeaderChannels": "Каналы", "HeaderChapterImages": "Изображения сцен", "HeaderCodecProfile": "Профиль кодеков", "HeaderCodecProfileHelp": "Профили кодеков обозначают ограничения устройства при воспроизведении с определёнными кодеками. Если применяется ограничение, то медиаданные перекодируются, даже если кодек настроен для прямого воспроизведения.", @@ -336,7 +321,6 @@ "HeaderForKids": "Детям", "HeaderForgotPassword": "Забыли пароль", "HeaderFrequentlyPlayed": "Воспроизведённые часто", - "HeaderGenres": "Жанры", "HeaderGuideProviders": "Поставщики данных телегида", "HeaderHttpHeaders": "HTTP-заголовки", "HeaderIdentification": "Распознание", @@ -347,7 +331,6 @@ "HeaderImageSettings": "Настройки изображения", "HeaderInstall": "Установка", "HeaderInstantMix": "Автомикс", - "HeaderItems": "Элементы", "HeaderKeepRecording": "Хранение записи", "HeaderKeepSeries": "Хранение сериала", "HeaderKodiMetadataHelp": "Для включения или отключения NFO-метаданных, правьте медиатеку и найдите раздел хранителей метаданных.", @@ -370,7 +353,6 @@ "HeaderMediaInfo": "О медиаданных", "HeaderMetadataSettings": "Параметры метаданных", "HeaderMoreLikeThis": "Ещё подобное этому", - "HeaderMovies": "Фильмы", "HeaderMusicQuality": "Качество музыки", "HeaderMusicVideos": "Муз. видео", "HeaderMyDevice": "Моё устройство", @@ -431,7 +413,6 @@ "HeaderServerSettings": "Параметры сервера", "HeaderSettings": "Параметры", "HeaderSetupLibrary": "Установка и настройка медиатеки", - "HeaderShutdown": "Завершение работы", "HeaderSortBy": "Сортировка по", "HeaderSortOrder": "Порядок сортировки", "HeaderSpecialEpisodeInfo": "О спецэпизоде", @@ -466,7 +447,6 @@ "HeaderXmlDocumentAttributes": "Атрибуты XML-документа", "HeaderXmlSettings": "Параметры XML", "HeaderYears": "Годы", - "HeadersFolders": "Папки", "Help": "Справка...", "Hide": "Скрыть", "HideWatchedContentFromLatestMedia": "Скрыть просмотренное содержание из Новейших медиаданных", @@ -683,7 +663,6 @@ "LabelNewPassword": "Новый пароль:", "LabelNewPasswordConfirm": "Подтверждение пароля:", "LabelNewsCategories": "Новостные категории:", - "LabelNext": "Следующее", "LabelNotificationEnabled": "Включить данное уведомление", "LabelNumber": "Номер:", "LabelNumberOfGuideDays": "Число дней для загрузки данных телегида:", @@ -710,7 +689,6 @@ "LabelPreferredDisplayLanguage": "Выбор языка отображения:", "LabelPreferredDisplayLanguageHelp": "Перевод Jellyfin ведётся на постоянной основе.", "LabelPreferredSubtitleLanguage": "Выбор языка субтитров:", - "LabelPrevious": "Предыдущее", "LabelProfileAudioCodecs": "Аудиокодеки:", "LabelProfileCodecs": "Кодеки:", "LabelProfileCodecsHelp": "Разделяются запятой. Поле можно оставить незаполненным, чтобы применять для всех кодеков.", @@ -724,7 +702,6 @@ "LabelPublicHttpPortHelp": "Номер публичного порта, который сопоставляется с локальным HTTP-портом.", "LabelPublicHttpsPort": "Номер публичного HTTPS-порта:", "LabelPublicHttpsPortHelp": "Номер публичного порта, который сопоставляется с локальным HTTPS-портом.", - "LabelReadHowYouCanContribute": "Как вносить свой вклад.", "LabelReasonForTranscoding": "Причина перекодирования:", "LabelRecord": "Запись:", "LabelRecordingPath": "Стандартный путь для записей:", @@ -934,7 +911,6 @@ "MessageNoNextUpItems": "Ничего не найдено. Начните смотреть свои ТВ-передачи!", "MessageNoPluginConfiguration": "В данном плагине нет параметров конфигурирования.", "NoSubtitleSearchResultsFound": "Результатов не найдено.", - "NoSubtitles": "Ничего", "NoSubtitlesHelp": "По умолчанию, субтитры не будут загружаться. Они могут быть все ещё включены вручную во время воспроизведения.", "None": "Ничего", "Normal": "Обычный", @@ -1219,24 +1195,16 @@ "TabAccess": "Доступ", "TabAdvanced": "Расширенное", "TabAlbumArtists": "Исполнители альбома", - "TabAlbums": "Альбомы", "TabCatalog": "Каталог", - "TabChannels": "Каналы", "TabCodecs": "Кодеки", - "TabCollections": "Коллекции", "TabContainers": "Контейнеры", "TabDashboard": "Панель", - "TabDevices": "Устройства", "TabDirectPlay": "Прямое воспроизведение", "TabEpisodes": "Эпизоды", - "TabFavorites": "Избранное", - "TabGenres": "Жанры", - "TabGuide": "Телегид", "TabInfo": "Инфо", "TabLatest": "Новейшее", "TabLiveTV": "Эфир", "TabLogs": "Журналы", - "TabMovies": "Фильмы", "TabMusic": "Музыка", "TabMusicVideos": "Муз. видео", "TabMyPlugins": "Мои плагины", @@ -1257,8 +1225,6 @@ "TabSeries": "Сериалы", "TabServer": "Сервер", "TabSettings": "Параметры", - "TabShows": "Сериалы", - "TabSongs": "Треки", "TabStreaming": "Трансляция", "TabTrailers": "Трейлеры", "TabUpcoming": "Ожидаемое", @@ -1457,7 +1423,6 @@ "LabelRequireHttpsHelp": "Если этот флажок установлен, сервер будет автоматически перенаправлять все запросы через HTTP на HTTPS. Это не имеет никакого эффекта, если сервер не слушает HTTPS.", "LabelEnableHttpsHelp": "Прослушивается указанный HTTPS-порт. Чтобы это вступило в силу, также необходимо предоставить действительный сертификат.", "ApiKeysCaption": "Список действующих текущих API-ключей", - "TabDVR": "DVR", "SaveChanges": "Сохранить изменения", "LabelRequireHttps": "Требуется HTTPS", "LabelStable": "Стабильная", diff --git a/src/strings/sk.json b/src/strings/sk.json index fe95801700..d8572ca1b2 100644 --- a/src/strings/sk.json +++ b/src/strings/sk.json @@ -19,7 +19,6 @@ "AsManyAsPossible": "Najviac ako je možné", "Ascending": "Vzostupne", "AspectRatio": "Pomer strán", - "AttributeNew": "Nové", "Backdrops": "Pozadia", "BirthDateValue": "Narodený/á: {0}", "BirthLocation": "Miesto narodenia", @@ -30,19 +29,12 @@ "ButtonAddScheduledTaskTrigger": "Pridať spúšťač", "ButtonAddServer": "Pridať server", "ButtonAddUser": "Pridať používateľa", - "ButtonArrowDown": "Dole", "ButtonArrowLeft": "Vľavo", "ButtonArrowRight": "Vpravo", - "ButtonArrowUp": "Hore", "ButtonAudioTracks": "Audio stopy", "ButtonBack": "Späť", "ButtonCancel": "Zrušiť", "ButtonChangeServer": "Zmeniť server", - "ButtonConnect": "Pripojiť", - "ButtonDelete": "Zmazať", - "ButtonDeleteImage": "Zmazať obrázok", - "ButtonDown": "Dole", - "ButtonDownload": "Stiahnuť", "ButtonEdit": "Upraviť", "ButtonEditImages": "Upraviť obrázky", "ButtonEditOtherUserPreferences": "Upraviť používateľský profil, obrázok a osobné preferencie.", @@ -53,7 +45,6 @@ "ButtonManualLogin": "Manuálne prihlásenie", "ButtonMore": "Viac", "ButtonNetwork": "Sieť", - "ButtonNew": "Nové", "ButtonNextTrack": "Nasledujúca stopa", "ButtonOpen": "Otvoriť", "ButtonParentalControl": "Rodičovská kontrola", @@ -75,16 +66,13 @@ "ButtonSelectServer": "Vybrať server", "ButtonSend": "Odoslať", "ButtonSettings": "Nastavenia", - "ButtonShuffle": "Zamiešať", "ButtonShutdown": "Vypnúť", "ButtonSignIn": "Prihlásiť sa", "ButtonSignOut": "Odhlásiť sa", - "ButtonSort": "Zoradiť", "ButtonSubmit": "Potvrdiť", "ButtonSubtitles": "Titulky", "ButtonTrailer": "Trailer", "ButtonUninstall": "Odinštalovať", - "ButtonUp": "Hore", "ButtonWebsite": "Webové stránky", "Categories": "Kategórie", "ChannelAccessHelp": "Zvoľte kanály zdieľané s týmto používateľom. Administrátori budú schopní upraviť všetky kanály použitím správcu metadát.", @@ -170,14 +158,12 @@ "HeaderAddToCollection": "Pridať do kolekcie", "HeaderAddUpdateImage": "Pridať/aktualizovať obrázok", "HeaderAddUser": "Pridať používateľa", - "HeaderAlbums": "Albumy", "HeaderApiKey": "Kľúč API", "HeaderApiKeys": "Kľúče API", "HeaderAudioBooks": "Audio knihy", "HeaderAudioSettings": "Nastavenia zvuku", "HeaderBooks": "Knihy", "HeaderCastAndCrew": "Obsadenie a štáb", - "HeaderChannels": "Kanály", "HeaderChapterImages": "Obrázky kapitol", "HeaderConfigureRemoteAccess": "Nastaviť vzdialený prístup", "HeaderConfirmPluginInstallation": "Potvrdiť inštaláciu zásuvných modulov", @@ -202,7 +188,6 @@ "HeaderForKids": "Pre deti", "HeaderForgotPassword": "Zabudnuté heslo", "HeaderFrequentlyPlayed": "Často hrané", - "HeaderGenres": "Žánre", "HeaderHttpHeaders": "HTTP hlavičky", "HeaderIdentification": "Identifikácia", "HeaderIdentificationCriteriaHelp": "Zadajte aspoň jedno identifikačné kritérium.", @@ -210,7 +195,6 @@ "HeaderImageSettings": "Nastavenia obrázkov", "HeaderInstall": "Inštalovať", "HeaderInstantMix": "Okamžitý mix", - "HeaderItems": "Položky", "HeaderLatestEpisodes": "Najnovšie epizódy", "HeaderLatestMedia": "Najnovšie médiá", "HeaderLatestMovies": "Najnovšie filmy", @@ -227,7 +211,6 @@ "HeaderMediaInfo": "Informácie o médiu", "HeaderMetadataSettings": "Nastavenia metadát", "HeaderMoreLikeThis": "Podobné položky", - "HeaderMovies": "Filmy", "HeaderMusicQuality": "Kvalita hudby", "HeaderMusicVideos": "Hudobné videá", "HeaderMyDevice": "Moje zariadenie", @@ -267,7 +250,6 @@ "HeaderServerSettings": "Nastavenia servera", "HeaderSettings": "Nastavenia", "HeaderSetupLibrary": "Nastavte Vaše knižnice médií", - "HeaderShutdown": "Vypnúť", "HeaderSortBy": "Zoradiť podľa", "HeaderStartNow": "Začať teraz", "HeaderStopRecording": "Zastaviť nahrávanie", @@ -287,7 +269,6 @@ "HeaderVideos": "Videá", "HeaderXmlSettings": "Nastavenia XML", "HeaderYears": "Roky", - "HeadersFolders": "Priečinky", "Help": "Pomoc", "Hide": "Skryť", "Home": "Domov", @@ -408,7 +389,6 @@ "LabelNewPassword": "Nové heslo:", "LabelNewPasswordConfirm": "Potvrdenie nového hesla:", "LabelNewsCategories": "Kategórie správ:", - "LabelNext": "Ďalej", "LabelNotificationEnabled": "Povoliť toto hlásenie", "LabelNumber": "Číslo:", "LabelOptionalNetworkPath": "Zdieľaný sieťový priečinok:", @@ -425,7 +405,6 @@ "LabelPlayDefaultAudioTrack": "Prehrať predvolenú zvukovú stopu bez ohľadu na jazyk", "LabelPreferredDisplayLanguage": "Preferovaný jazyk:", "LabelPreferredSubtitleLanguage": "Preferovaný jazyk titulkov:", - "LabelPrevious": "Predchádzajúce", "LabelProfileAudioCodecs": "Audio kodeky:", "LabelProfileCodecs": "Kodeky:", "LabelProfileContainer": "Kontajner:", @@ -434,7 +413,6 @@ "LabelProtocolInfo": "Info o protokole:", "LabelPublicHttpPort": "Verejný HTTP port:", "LabelPublicHttpsPort": "Verejný HTTPS port:", - "LabelReadHowYouCanContribute": "Zistite, ako môžete prispieť.", "LabelRecordingPath": "Predvolené umiestnenie nahrávok:", "LabelRecordingPathHelp": "Uveďte predvolené umiestnenie pre ukladanie nahrávok. Ak je ponechané prázdne, použije sa priečinok s programovými dátami servera.", "LabelReleaseDate": "Dátum vydania:", @@ -561,7 +539,6 @@ "MessageNoNextUpItems": "Nič nenájdené. Začnite pozerať vaše seriály!", "MessageNoPluginConfiguration": "Tento zásuvný modul nemá žiadne nastavenia.", "NoSubtitleSearchResultsFound": "Žiadne výsledky.", - "NoSubtitles": "Žiadne", "None": "Žiadne", "Normal": "Normálne", "NumLocationsValue": "{0} priečinkov", @@ -753,21 +730,13 @@ "Sunday": "Nedeľa", "TabAccess": "Prístup", "TabAdvanced": "Pokročilé", - "TabAlbums": "Albumy", "TabCatalog": "Katalóg", - "TabChannels": "Kanály", "TabCodecs": "Kodeky", - "TabCollections": "Kolekcie", "TabContainers": "Kontajnery", "TabDashboard": "Dashboard", - "TabDevices": "Zariadenia", "TabEpisodes": "Epizódy", - "TabFavorites": "Obľúbené", - "TabGenres": "Žánre", - "TabGuide": "Sprievodca", "TabLatest": "Najnovšie", "TabLiveTV": "Živá TV", - "TabMovies": "Filmy", "TabMusic": "Hudba", "TabMusicVideos": "Hudobné videá", "TabMyPlugins": "Moje zásuvné moduly", @@ -786,8 +755,6 @@ "TabScheduledTasks": "Naplánované úlohy", "TabSeries": "Seriály", "TabSettings": "Nastavenia", - "TabShows": "Seriály", - "TabSongs": "Skladby", "TabTrailers": "Trailery", "TabUpcoming": "Nadchádzajúce", "TabUsers": "Užívatelia", @@ -858,7 +825,6 @@ "DirectPlaying": "Priame prehrávanie", "Disabled": "Vypnuté", "Display": "Zobrazenie", - "EnableBackdrops": "Pozadia", "EnableDisplayMirroring": "Zrkadlenie obrazu", "Ended": "Ukončený", "FileReadCancelled": "Čítanie súboru bolo zrušené.", @@ -1457,7 +1423,6 @@ "ApiKeysCaption": "Zoznam v súčasnosti povolených API kľúčov", "LabelStable": "Stabilná", "LabelChromecastVersion": "Chromecast verzia", - "TabDVR": "DVR", "LabelRequireHttpsHelp": "Pokiaľ je zaškrtnutý, server bude automaticky presmerovávať všetky HTTP požiadavky cez HTTPS. Toto nastavenie nemá žiadny efekt, pokiaľ server nepočúva na HTTPS.", "LabelRequireHttps": "Vyžadovať HTTPS", "LabelEnableHttpsHelp": "Počúvanie na nastavenom HTTPS porte. K správnemu fungovaniu je nutné nakonfigurovať aj platný certifikát.", diff --git a/src/strings/sl-si.json b/src/strings/sl-si.json index 6524841c3e..22d0d60317 100644 --- a/src/strings/sl-si.json +++ b/src/strings/sl-si.json @@ -1,6 +1,5 @@ { "ButtonAddUser": "Dodaj Uporabnika", - "ButtonDeleteImage": "Izbrisi sliko", "ButtonQuickStartGuide": "Vodnik za hiter zacetek", "ButtonResetPassword": "Ponastavitev gesla", "ButtonSignOut": "Odjava", @@ -22,8 +21,6 @@ "LabelLanguage": "Jezik:", "LabelNewPassword": "Novo geslo:", "LabelNewPasswordConfirm": "Potrditev novega gesla:", - "LabelNext": "Naprej", - "LabelPrevious": "Nazaj", "LabelSelectUsers": "Izberi uporabnike:", "LabelTimeLimitHours": "Časovna omejitev (ure):", "LabelYoureDone": "Koncano!", @@ -44,7 +41,6 @@ "TabAccess": "Dostop", "TabAlbumArtists": "Izvajalci Albumov", "TabCatalog": "Katalog", - "TabGenres": "Zvrsti", "TabLatest": "Zadnje", "TabMusic": "Glasba", "TabMyPlugins": "Moji dodatki", @@ -52,7 +48,6 @@ "TabPassword": "Geslo", "TabProfile": "Profil", "TabProfiles": "Profili", - "TabShows": "Oddaje", "TabUpcoming": "Prihajajoče", "TellUsAboutYourself": "Povej nam nekaj o sebi", "ThisWizardWillGuideYou": "Čarovnik vas bo vodil skozi postopek namestitve. Za začetek, izberite jezik.", @@ -105,7 +100,6 @@ "AsManyAsPossible": "Kolikor je mogoče", "Ascending": "Naraščajoče", "AspectRatio": "Razmerje stranic", - "AttributeNew": "Novo", "Audio": "Zvok", "Auto": "Samodejno", "Backdrop": "Ozadje", @@ -129,18 +123,12 @@ "ButtonAddMediaLibrary": "Dodaj knjižnico predstavnosti", "ButtonAddScheduledTaskTrigger": "Dodaj sprožilec", "ButtonAddServer": "Dodaj strežnik", - "ButtonArrowDown": "Dol", "ButtonArrowLeft": "Levo", "ButtonArrowRight": "Desno", - "ButtonArrowUp": "Gor", "ButtonAudioTracks": "Zvočna sled", "ButtonBack": "Nazaj", "ButtonCancel": "Prekliči", "ButtonChangeServer": "Spremeni strežnik", - "ButtonConnect": "Poveži", - "ButtonDelete": "Izbriši", - "ButtonDown": "Dol", - "ButtonDownload": "Prenesi", "ButtonEdit": "Uredi", "ButtonEditImages": "Uredi slike", "ButtonEditOtherUserPreferences": "Uredi profil tega uporabnika, slike in osebne nastavitve.", @@ -155,7 +143,6 @@ "ButtonManualLogin": "Ročna prijava", "ButtonMore": "Več", "ButtonNetwork": "Omrežje", - "ButtonNew": "Novo", "ButtonNextTrack": "Naslednja skladba", "ButtonOff": "Izključi", "ButtonOk": "Ok", @@ -179,16 +166,13 @@ "ButtonSelectView": "Izberi pogled", "ButtonSend": "Pošlji", "ButtonSettings": "Nastavitve", - "ButtonShuffle": "Premešaj", "ButtonShutdown": "Ugasni", "ButtonSignIn": "Prijava", - "ButtonSort": "Razvrsti", "ButtonStart": "Začetek", "ButtonStop": "Stop", "ButtonSubtitles": "Podnapisi", "ButtonTrailer": "Napovednik", "ButtonUninstall": "Odstrani", - "ButtonUp": "Gor", "ButtonWebsite": "Spletna stran", "CancelRecording": "Prekini snemanje", "CancelSeries": "Prekini serijo", @@ -313,7 +297,6 @@ "HeaderMyDevice": "Moja naprava", "HeaderMusicVideos": "Videospoti", "HeaderMusicQuality": "Kvaliteta glasbe", - "HeaderMovies": "Filmi", "HeaderMoreLikeThis": "Podobno", "HeaderMetadataSettings": "Nastavitve metapodatkov", "HeaderMediaInfo": "Informacije o predstavnosti", @@ -343,7 +326,6 @@ "HeaderIdentification": "Identifikacija", "HeaderHome": "Domov", "HeaderGuideProviders": "Ponudniki TV vodiča", - "HeaderGenres": "Žanri", "HeaderForgotPassword": "Pozabljeno geslo", "HeaderForKids": "Za otroke", "HeaderFetcherSettings": "Nastavitve pridobivanja", @@ -381,7 +363,6 @@ "HeaderCodecProfileHelp": "Profili kodeka določajo omejitve naprave pri predvajanju specifičnih kodekov. Če je omejitev dosežena bo predstavnost prekodirana, tudi če je kodek nastavljen za neposredno predvajanje.", "HeaderCodecProfile": "Profil kodeka", "HeaderChapterImages": "Slike poglavij", - "HeaderChannels": "Kanali", "HeaderChannelAccess": "Dostop kanalov", "HeaderCastCrew": "Igralci in ekipa", "HeaderCastAndCrew": "Igralci in ekipa", @@ -397,7 +378,6 @@ "HeaderApiKey": "API ključ", "HeaderAllowMediaDeletionFrom": "Dovoli brisanje predstavnosti iz", "HeaderAlert": "Alarm", - "HeaderAlbums": "Albumi", "HeaderAdmin": "Administrator", "HeaderAdditionalParts": "Dodatni deli", "HeaderAddUpdateImage": "Dodaj/posodobi sliko", @@ -473,7 +453,6 @@ "EnableColorCodedBackgrounds": "Barvno usklajena ozadja", "EnableCinemaMode": "Kino način", "EnableBackdropsHelp": "Prikaži ozadja na nekaterih straneh med brskanjem knjižnice.", - "EnableBackdrops": "Ozadja", "EasyPasswordHelp": "Vaša enostavna PIN koda je uporabna za dostop brez povezave na podprtih napravah in za enostavno prijavo v lokalnem omrežju.", "Images": "Slike", "Identify": "Identificiraj", @@ -483,7 +462,6 @@ "HideWatchedContentFromLatestMedia": "Skrij ogledane vsebine iz razdelka Najnovejša predstavnost", "Hide": "Skrij", "Help": "Pomoč", - "HeadersFolders": "Mape", "HeaderYears": "Leta", "HeaderXmlSettings": "Xml nastavitve", "HeaderXmlDocumentAttributes": "Xml lastnosti dokumenta", @@ -520,7 +498,6 @@ "HeaderSpecialEpisodeInfo": "Informacije o posebni epizodi", "HeaderSortOrder": "Vrstni red", "HeaderSortBy": "Razvrsti po", - "HeaderShutdown": "Ugasni", "HeaderSetupLibrary": "Nastavite vaše knjižnjice predstavnosti", "HeaderServerSettings": "Nastavitve strežnika", "HeaderSeriesStatus": "Status serije", @@ -730,7 +707,6 @@ "LabelMoviePrefixHelp": "Če naslovi filmov vsebujejo predpono, jo vnesite tukaj da jo lahko strežnik pravilno obdela.", "LabelNewName": "Novo ime:", "Raised": "Dvignjeni", - "TabCollections": "Zbirke", "Small": "Majhno", "SmartSubtitlesHelp": "Podnapisi, ki se ujemajo z želenim jezikom, bodo naloženi, ko je zvok v tujem jeziku.", "SubtitleAppearanceSettingsDisclaimer": "Te nastavitve ne vplivajo na grafične podnapise (PGS, DVD, itd.) ali ASS/SSA podnapise, ki imajo vdelan svoj lasten slog.", @@ -745,7 +721,6 @@ "LabelDropShadow": "Senca:", "LabelHomeScreenSectionValue": "Razdelek domačega zaslona {0}:", "LabelPreferredSubtitleLanguage": "Prednostni jezik podnapisov:", - "NoSubtitles": "Nič", "OnlyImageFormats": "Samo slikovni formati (VOBSUB, PGS, SUB)", "OnlyForcedSubtitles": "Samo prisiljeni", "OptionAllowAudioPlaybackTranscoding": "Dovoli predvajanje zvoka, ki zahteva prekodiranje", @@ -1077,7 +1052,6 @@ "LabelRecordingPath": "Privzeta pot posnetkov:", "LabelRecord": "Snemaj:", "LabelReasonForTranscoding": "Razlog za prekodiranje:", - "LabelReadHowYouCanContribute": "Naučite se, kako lahko prispevate.", "LabelPublicHttpsPortHelp": "Številka javnih vrat ki bodo povezana na lokalna HTTPS vrata.", "LabelPublicHttpsPort": "Številka javnih HTTPS vrat:", "LabelPublicHttpPortHelp": "Številka javnih vrat ki bodo povezana na lokalna HTTP vrata.", @@ -1230,7 +1204,6 @@ "HeaderRemoteAccessSettings": "Nastavitve oddaljenega dostopa", "HeaderOtherItems": "Ostale vsebine", "HeaderNavigation": "Navigacija", - "HeaderItems": "Vsebine", "EnableDecodingColorDepth10Vp9": "Omogoči strojno dekodiranje za 10-bit VP9", "EnableDecodingColorDepth10Hevc": "Omogoči strojno dekodiranje za 10-bit HEVC", "LabelEnableHttpsHelp": "Poslušaj na nastavljenih HTTPS vratih. Za uveljavitev te možnosti mora biti nastavljen tudi veljaven certifikat.", @@ -1331,19 +1304,14 @@ "LabelLineup": "Postava:", "BoxSet": "Komplet", "TabInfo": "Informacije", - "TabGuide": "Vodič", - "TabFavorites": "Priljubljeni", "TabEpisodes": "Epizode", "TabDirectPlay": "Neposredno predvajanje", - "TabDevices": "Naprave", "TabCodecs": "Kodeki", - "TabChannels": "Programi", "OptionRegex": "Regex", "OptionProtocolHls": "HTTP pretakanje v živo", "OptionProfileVideoAudio": "Video zvok", "ThemeSongs": "Glavne pesmi", "TabStreaming": "Pretakanje", - "TabSongs": "Skladbe", "TabSettings": "Nastavitve", "TabServer": "Strežnik", "TabSeries": "Serije", @@ -1360,7 +1328,6 @@ "TabNotifications": "Obvestila", "TabNfoSettings": "Nastavitve NFO", "TabMusicVideos": "Videospoti", - "TabMovies": "Filmi", "OptionForceRemoteSourceTranscoding": "Vsili prekodiranje oddaljenih virov predstavnosti (na primer TV v živo)", "Off": "Izključeno", "Normal": "Normalno", @@ -1429,6 +1396,5 @@ "SubtitleOffset": "Zamik podnapisev", "Subtitles": "Podnapisi", "Sunday": "Nedelja", - "TabAdvanced": "Napredno", - "TabAlbums": "Albumi" + "TabAdvanced": "Napredno" } diff --git a/src/strings/sr.json b/src/strings/sr.json index 810fa44141..c302c0a580 100644 --- a/src/strings/sr.json +++ b/src/strings/sr.json @@ -36,7 +36,6 @@ "ButtonOk": "Ок", "ButtonOff": "Искључи", "ButtonNextTrack": "Следећа нумера", - "ButtonNew": "Ново", "ButtonNetwork": "Мрежа", "ButtonMore": "Више", "ButtonManualLogin": "Ручни логин", @@ -48,19 +47,12 @@ "ButtonFullscreen": "Пун екран", "ButtonForgotPassword": "Заборављена шифра", "ButtonFilter": "Филтер", - "ButtonDownload": "Преузми", - "ButtonDown": "Доле", - "ButtonDeleteImage": "Обриши слику", - "ButtonDelete": "Обриши", - "ButtonConnect": "Повежи се", "ButtonChangeServer": "Промени Сервер", "ButtonCancel": "Откажи", "ButtonBack": "Назад", "ButtonAudioTracks": "Избор језика звука", - "ButtonArrowUp": "Горе", "ButtonArrowRight": "Десно", "ButtonArrowLeft": "Лево", - "ButtonArrowDown": "Доле", "ButtonAddUser": "Додај корисника", "ButtonAddServer": "Додај сервер", "ButtonAddScheduledTaskTrigger": "Додај прекидач", @@ -75,7 +67,6 @@ "BirthLocation": "Место рођења", "BirthDateValue": "Рођен", "Audio": "Звук", - "AttributeNew": "Ново", "AroundTime": "Около", "AnyLanguage": "Било који језик", "AlwaysPlaySubtitles": "Увек налепи титлове", @@ -124,7 +115,6 @@ "CancelSeries": "Откажи серију", "CancelRecording": "Откажи снимање", "ButtonWebsite": "Веб сајт", - "ButtonUp": "Горе", "ButtonUninstall": "Деинсталирај", "ButtonTrailer": "Трејлер", "ButtonSubtitles": "Титлови", @@ -132,11 +122,9 @@ "ButtonSplit": "Подели", "ButtonStop": "Заустави", "ButtonStart": "Почни", - "ButtonSort": "Сортирај", "ButtonSignOut": "Одјавите се", "ButtonSignIn": "Пријавите се", "ButtonShutdown": "Искључи", - "ButtonShuffle": "Промешај", "ButtonSettings": "Подешавања", "ButtonSend": "Пошаљи", "ButtonSelectView": "Изаберите приказ", diff --git a/src/strings/sv.json b/src/strings/sv.json index 23c68d9e84..604179f9f6 100644 --- a/src/strings/sv.json +++ b/src/strings/sv.json @@ -30,7 +30,6 @@ "Artists": "Artister", "AsManyAsPossible": "Så många som möjligt", "AspectRatio": "Bildförhållande", - "AttributeNew": "Ny", "Audio": "Ljud", "Backdrop": "Fondbild", "Backdrops": "Fondbilder", @@ -49,19 +48,12 @@ "ButtonAddScheduledTaskTrigger": "Lägg till utlösare", "ButtonAddServer": "Lägg till server", "ButtonAddUser": "Ny användare", - "ButtonArrowDown": "Ned", "ButtonArrowLeft": "Vänster", "ButtonArrowRight": "Höger", - "ButtonArrowUp": "Upp", "ButtonAudioTracks": "Ljudspår", "ButtonBack": "Föregående", "ButtonCancel": "Avbryt", "ButtonChangeServer": "Byt server", - "ButtonConnect": "Anslut", - "ButtonDelete": "Ta bort", - "ButtonDeleteImage": "Ta bort bild", - "ButtonDown": "Ner", - "ButtonDownload": "Ladda ned", "ButtonEdit": "Ändra", "ButtonEditImages": "Ändra bilder", "ButtonEditOtherUserPreferences": "Ändra den här användarens profil, bild och personliga inställningar.", @@ -74,7 +66,6 @@ "ButtonManualLogin": "Manuell inloggning", "ButtonMore": "Mer", "ButtonNetwork": "Nätverk", - "ButtonNew": "Nytillkommet", "ButtonNextTrack": "Nästa spår", "ButtonOff": "Av", "ButtonOk": "OK", @@ -100,16 +91,13 @@ "ButtonSelectView": "Välj vy", "ButtonSend": "Skicka", "ButtonSettings": "Inställningar", - "ButtonShuffle": "Blanda", "ButtonShutdown": "Stäng av", "ButtonSignIn": "Logga in", "ButtonSignOut": "Logga ut", - "ButtonSort": "Sortera", "ButtonStop": "Stopp", "ButtonSubmit": "Bekräfta", "ButtonSubtitles": "Undertexter", "ButtonUninstall": "Avinstallera", - "ButtonUp": "Upp", "ButtonWebsite": "Hemsida", "CancelRecording": "Avbryt inspelning", "CancelSeries": "Avbryt serie", @@ -176,7 +164,6 @@ "EditImages": "Ändra bilder", "EditMetadata": "Redigera metadata", "EditSubtitles": "Ändra undertexter", - "EnableBackdrops": "Fondbilder", "EnableBackdropsHelp": "Visar fondbilder i bakgrunden av vissa sidor vid bläddring i biblioteket.", "EnableCinemaMode": "Bioläge", "EnableColorCodedBackgrounds": "Färgkodade bakgrundsbilder", @@ -246,7 +233,6 @@ "HeaderAddUser": "Lägg till användare", "HeaderAdditionalParts": "Ytterligare delar", "HeaderAlbumArtists": "Albumartister", - "HeaderAlbums": "Album", "HeaderAlert": "Varning", "HeaderAllowMediaDeletionFrom": "Tillåt mediaborttagning från", "HeaderApiKey": "API-nyckel", @@ -261,7 +247,6 @@ "HeaderCastAndCrew": "Medverkande", "HeaderCastCrew": "Rollista & besättning", "HeaderChannelAccess": "Kanalåtkomst", - "HeaderChannels": "Kanaler", "HeaderChapterImages": "Kapitelbilder", "HeaderCodecProfile": "Profil för videokodning", "HeaderCodecProfileHelp": "Avkodarprofiler bestämmer begränsningarna hos en enhet när den spelar upp olika kodningstyper. Om en begränsning är aktuell kommer innehållet att kodas om, även om kodningstypen sig är inställd för direkt avspelning.", @@ -302,7 +287,6 @@ "HeaderForKids": "För barn", "HeaderForgotPassword": "Glömt Lösenord", "HeaderFrequentlyPlayed": "Ofta spelade", - "HeaderGenres": "Genrer", "HeaderGuideProviders": "Källor för programguide", "HeaderHttpHeaders": "HTTP headers", "HeaderIdentification": "Identifiering", @@ -312,7 +296,6 @@ "HeaderImageSettings": "Bildinställningar", "HeaderInstall": "Installera", "HeaderInstantMix": "Direktmix", - "HeaderItems": "Objekt", "HeaderKeepRecording": "Fortsätt spela in", "HeaderKeepSeries": "Behåll serie", "HeaderKodiMetadataHelp": "Jellyfin har stöd för NFO-metadatafiler. För att aktivera eller inaktivera NFO-metadata, använd Metadata-fliken för att konfigurera NFO-stöd för dina mediatyper.", @@ -333,7 +316,6 @@ "HeaderMediaInfo": "Medieinformation", "HeaderMetadataSettings": "Metadatainställningar", "HeaderMoreLikeThis": "Mer som denna", - "HeaderMovies": "Filmer", "HeaderMusicQuality": "Musikkvalitet", "HeaderMusicVideos": "Musikvideor", "HeaderMyDevice": "Min enhet", @@ -393,7 +375,6 @@ "HeaderServerSettings": "Serverinställningar", "HeaderSettings": "Inställningar", "HeaderSetupLibrary": "Sätt upp dina mediabibliotek", - "HeaderShutdown": "Stäng av", "HeaderSortBy": "Sortera efter", "HeaderSortOrder": "Sortering", "HeaderSpecialEpisodeInfo": "Information om specialavsnitt", @@ -424,7 +405,6 @@ "HeaderXmlDocumentAttributes": "XML-dokumentattribut", "HeaderXmlSettings": "XML-inställningar", "HeaderYears": "År", - "HeadersFolders": "Mappar", "Help": "Hjälp", "Hide": "Dölj", "HideWatchedContentFromLatestMedia": "Dölj visat innehåll ifrån senaste media", @@ -635,7 +615,6 @@ "LabelNewPassword": "Nytt lösenord:", "LabelNewPasswordConfirm": "Bekräfta nytt lösenord:", "LabelNewsCategories": "Nyhetskategorier:", - "LabelNext": "Nästa", "LabelNotificationEnabled": "Aktivera denna meddelandetyp", "LabelNumber": "Nr:", "LabelNumberOfGuideDays": "Antal dagars tablå att hämta:", @@ -659,7 +638,6 @@ "LabelPreferredDisplayLanguage": "Föredraget visningsspråk:", "LabelPreferredDisplayLanguageHelp": "Att översätta Jellyfin är ett pågående projekt.", "LabelPreferredSubtitleLanguage": "Önskat språk för undertexter:", - "LabelPrevious": "Föregående", "LabelProfileAudioCodecs": "Kodning av ljud:", "LabelProfileCodecs": "Videokodningar:", "LabelProfileCodecsHelp": "Åtskilda med kommatecken, detta kan lämnas tomt för att gälla för alla kodningsformat.", @@ -673,7 +651,6 @@ "LabelPublicHttpPortHelp": "Det publika portnumret som ska mappas till den lokala porten för HTTP.", "LabelPublicHttpsPort": "Publikt portnummer för HTTPS:", "LabelPublicHttpsPortHelp": "Det publika portnumret som ska mappas till den lokala porten för HTTPS.", - "LabelReadHowYouCanContribute": "Se hur du kan hjälpa till.", "LabelReasonForTranscoding": "Orsak för omkodning:", "LabelRecord": "Spela in:", "LabelRecordingPath": "Standard inspelningssökväg:", @@ -866,7 +843,6 @@ "MessageNoNextUpItems": "Hittade inget. Sätt igång och titta!", "MessageNoPluginConfiguration": "Detta tillägg har inga inställningar att konfigurera.", "NoSubtitleSearchResultsFound": "Inga resultat hittades.", - "NoSubtitles": "Inga", "NoSubtitlesHelp": "Undertexter kommer inte visas per standard. Det kan fortfarande sättas på manuellt under uppspelning.", "None": "Inga", "NumLocationsValue": "{0} mappar", @@ -1128,23 +1104,15 @@ "SystemDlnaProfilesHelp": "Systemprofiler är skrivskyddade. Ändringar av en systemprofil resulterar att en ny anpassad profil skapas.", "TabAdvanced": "Avancerat", "TabAlbumArtists": "Albumartister", - "TabAlbums": "Album", "TabCatalog": "Katalog", - "TabChannels": "Kanaler", "TabCodecs": "Kodningsformat", - "TabCollections": "Samlingar", "TabContainers": "Behållare", "TabDashboard": "Kontrollpanel", - "TabDevices": "Enheter", "TabDirectPlay": "Direktuppspelning", "TabEpisodes": "Avsnitt", - "TabFavorites": "Favoriter", - "TabGenres": "Genrer", - "TabGuide": "TV-guide", "TabLatest": "Nytillkommet", "TabLiveTV": "Live-TV", "TabLogs": "Loggfiler", - "TabMovies": "Filmer", "TabMusic": "Musik", "TabMusicVideos": "Musikvideor", "TabMyPlugins": "Mina tillägg", @@ -1164,8 +1132,6 @@ "TabScheduledTasks": "Schemalagda aktiviteter", "TabSeries": "Serie", "TabSettings": "Inställningar", - "TabShows": "Serier", - "TabSongs": "Låtar", "TabStreaming": "Strömning", "TabUpcoming": "Kommande", "TabUsers": "Användare", @@ -1455,7 +1421,6 @@ "LabelLibraryPageSizeHelp": "Sätter en begränsad sidstorlek i bibliotek. Sätt 0 för att avaktivera begränsad sidstorlek.", "ApiKeysCaption": "Lista av aktiva API-nycklar", "DeinterlaceMethodHelp": "Välj metod för borttagning av inflätning vid konvertering av inflätat inehåll.", - "TabDVR": "PVR", "SaveChanges": "Spara ändringar", "LabelRequireHttps": "Kräv HTTPS", "LabelChromecastVersion": "Chromecast-version", diff --git a/src/strings/tr.json b/src/strings/tr.json index 80098c3222..ba47bd7f6b 100644 --- a/src/strings/tr.json +++ b/src/strings/tr.json @@ -4,20 +4,16 @@ "AllLibraries": "Bütün kütüphaneler", "AllowRemoteAccess": "Bu Jellyfin sunucusuna uzaktan bağlanmaya izin ver.", "AllowRemoteAccessHelp": "Eğer işaretlenmemişse, bütün uzak bağlantılar bloke edilicek.", - "AttributeNew": "Yeni", "MessageBrowsePluginCatalog": "Mevcut eklentileri görebilmek için eklenti katologuna göz atın.", "ButtonAddUser": "Kullanıcı Ekle", "ButtonArrowRight": "Sağ", "ButtonBack": "Geri", "ButtonCancel": "İptal", - "ButtonDelete": "Sil", - "ButtonDeleteImage": "Resmi Sil", "ButtonEdit": "Düzenle", "ButtonFilter": "Filtrele", "ButtonHome": "Anasayfa", "ButtonInfo": "Bilgi", "ButtonManualLogin": "Manuel Giriş", - "ButtonNew": "Yeni", "ButtonOk": "Tamam", "ButtonPause": "Duraklat", "ButtonPlay": "Oynat", @@ -31,7 +27,6 @@ "ButtonSettings": "Ayarlar", "ButtonSignIn": "Giriş Yapın", "ButtonSignOut": "Çıkış Yap", - "ButtonSort": "Sırala", "ButtonStop": "Durdur", "ButtonSubtitles": "Altyazılar", "ChannelAccessHelp": "Bu kullanıcıyla paylaşmak üzere kanalları seç. Yöneticiler bütün kanalları metada yöneticisi ile düzenleyebilecekler.", @@ -54,7 +49,6 @@ "Friday": "Cuma", "HeaderActiveRecordings": "Aktif Kayıtlar", "HeaderAddUser": "Kullanıcı Ekle", - "HeaderChannels": "Kanallar", "HeaderCodecProfile": "Codec Profili", "HeaderContinueWatching": "İzlemeye Devam Et", "HeaderCustomDlnaProfiles": "Özel Profiller", @@ -106,9 +100,7 @@ "LabelName": "İsim:", "LabelNewPassword": "Yeni şifre:", "LabelNewPasswordConfirm": "Yeni şifreyi onayla:", - "LabelNext": "Sonraki", "LabelPassword": "Şifre:", - "LabelPrevious": "Önceki", "LabelProfileAudioCodecs": "Ses Codec:", "LabelProfileCodecs": "Codecler:", "LabelProfileVideoCodecs": "Video Codec:", @@ -201,17 +193,11 @@ "TabAccess": "Erişim", "TabAdvanced": "Gelişmiş", "TabAlbumArtists": "Albüm Sanatçıları", - "TabAlbums": "Albümler", "TabCatalog": "Katalog", - "TabChannels": "Kanallar", "TabCodecs": "Codecler", "TabEpisodes": "Bölümler", - "TabFavorites": "Favoriler", - "TabGenres": "Türler", - "TabGuide": "Kılavuz", "TabInfo": "Bilgi", "TabLatest": "En yeni", - "TabMovies": "Filmler", "TabMusic": "Muzik", "TabMusicVideos": "Klipler", "TabMyPlugins": "Eklentilerim", @@ -224,8 +210,6 @@ "TabSeries": "Seriler", "TabServer": "Sunucu", "TabSettings": "Ayarlar", - "TabShows": "Diziler", - "TabSongs": "Şarkılar", "TabTrailers": "Fragmanlar", "TabUpcoming": "Gelecek", "TellUsAboutYourself": "Kendinizden bahsedin", @@ -277,7 +261,6 @@ "AllowMediaConversion": "Medya dönüşümüne izin ver", "AllowHWTranscodingHelp": "Ayarlayıcının anında akışları dönüştürmesine izin verin. Bu, sunucunun gerektirdiği kodlamanın azaltılmasına yardımcı olabilir.", "ColorSpace": "Renk uzayı", - "ButtonConnect": "Bağlan", "ColorTransfer": "Renk transferi", "ButtonPreviousTrack": "Önceki parça", "ButtonProfile": "Profil", @@ -324,20 +307,15 @@ "ButtonGotIt": "Anlaşıldı", "ButtonMore": "Dahası", "ButtonOpen": "Aç", - "ButtonArrowUp": "Yukarı", "ButtonNetwork": "Ağ", - "ButtonDownload": "İndir", "ButtonNextTrack": "Sonraki parça", "ButtonOff": "Kapalı", "ButtonParentalControl": "Ebeveyn Kontrolü", - "ButtonArrowDown": "Aşağı", "ButtonArrowLeft": "Sol", - "ButtonDown": "Aşağı", "ButtonGuide": "Rehber", "ButtonLibraryAccess": "Kütüphane erişimi", "ButtonScanAllLibraries": "Tüm Kütüphaneleri Tara", "ButtonSelectView": "Görünüm seç", - "ButtonShuffle": "Karıştır", "ButtonShutdown": "Kapat", "ChannelNameOnly": "Yalnızca {0} kanalı", "ConfirmDeleteItems": "Bu öğeleri silmek, onları hem dosya sisteminden hem de medya kitaplığınızdan siler. Devam etmek istediğinize emin misiniz?", @@ -349,7 +327,6 @@ "Display": "Görüntüle", "DisplayInMyMedia": "Ana ekranda görüntüleme", "DisplayInOtherHomeScreenSections": "En son medya gibi ana ekran bölümlerinde görüntüleyin ve izlemeye devam edin", - "EnableBackdrops": "Arka planında", "BurnSubtitlesHelp": "Sunucunun video işlendiği esnada, altyazının görüntüye gömülmesini sağlar. Performansı çok düşürür, zorunda kalmadıkça bu özelliği seçmeyin. Görüntü tabanlı biçimleri (VOBSUB, PGS, SUB / IDX, vb.) Ve bazı ASS / SSA altyazıların görüntüye gömülmesi için Otomatik'i seçin.", "ConfirmDeleteItem": "Bu öğeyi silmek, onu hem dosya sisteminden hem de medya kütüphanenizden siler. Devam etmek istediğinize emin misiniz?", "ValueSpecialEpisodeName": "Özel - {0}", @@ -389,7 +366,6 @@ "CancelRecording": "Kayıttan Vazgeç", "CancelSeries": "Dizileri iptal et", "ButtonUninstall": "Kaldır", - "ButtonUp": "Yukarı", "ButtonWebsite": "Website", "Categories": "Kategoriler", "DrmChannelsNotImported": "DRM'li kanallar içe aktarılmayacak.", @@ -423,7 +399,6 @@ "EnableCinemaMode": "Sinema Modu", "EnableColorCodedBackgrounds": "Renk kodlu arka planlar", "HeaderGuideProviders": "TV Rehberi Veri Sağlayıcıları", - "HeaderGenres": "Türler", "HeaderForgotPassword": "Parolanızı mı unuttunuz", "HeaderForKids": "Çocuklar için", "HeaderFetcherSettings": "Alıcı Ayarları", @@ -479,7 +454,6 @@ "HeaderApiKey": "API Anahtarı", "HeaderAllowMediaDeletionFrom": "Medyadan Silinmeye İzin Ver", "HeaderAlert": "Alarm", - "HeaderAlbums": "Albümler", "HeaderAdmin": "Yönetici", "HeaderAdditionalParts": "İlave parçalar", "HeaderAddUpdateImage": "Resim Ekle / Güncelle", @@ -575,7 +549,6 @@ "HeaderMyMedia": "Benim Medyam", "HeaderMyDevice": "Benim Cihazım", "HeaderMusicQuality": "Müzik Kalitesi", - "HeaderMovies": "Filmler", "HeaderMoreLikeThis": "Buna Benzer Daha Fazla", "HeaderMetadataSettings": "Meta Verisi Ayarları", "HeaderMediaInfo": "Medya Bilgisi", @@ -590,7 +563,6 @@ "HeaderLatestMusic": "Son Müzik", "HeaderKeepSeries": "Seriyi Sakla", "HeaderKeepRecording": "Kaydı Sakla", - "HeaderItems": "Öğeler", "HeaderInstall": "Yükle", "HeaderImageOptions": "Resim Seçenekleri", "HeaderIdentifyItemHelp": "Bir veya daha fazla arama kriteri giriniz. Faha fazla arama sonucu için kriter kaldırın.", @@ -645,7 +617,6 @@ "Identify": "Tanımla", "Horizontal": "Yatay", "Help": "Yardım", - "HeadersFolders": "Klasörler", "HeaderYears": "Yıl", "HeaderXmlSettings": "Xml Ayarları", "HeaderXmlDocumentAttributes": "Xml Döküman Öznitelikleri", @@ -665,7 +636,6 @@ "HeaderSpecialEpisodeInfo": "Özel Bölüm Bilgisi", "HeaderSortOrder": "Sıralama Düzeni", "HeaderSortBy": "Sırala", - "HeaderShutdown": "Kapat", "HeaderSettings": "Ayarlar", "LabelLogs": "Günlük:", "HeaderSelectMetadataPathHelp": "İçinde meta veri depolamak istediğiniz yola göz atın veya bu yolu girin. Klasörün yazılabilir olması gerekir.", diff --git a/src/strings/uk.json b/src/strings/uk.json index a1100e1e69..329f0ca95c 100644 --- a/src/strings/uk.json +++ b/src/strings/uk.json @@ -4,7 +4,6 @@ "ButtonAddUser": "Додати користувача", "ButtonCancel": "Скасувати", "ButtonFilter": "Фільтр", - "ButtonNew": "Нове", "ButtonRename": "Перейменувати", "ButtonResetPassword": "Скинути пароль", "ButtonSignOut": "Вийти", @@ -15,14 +14,12 @@ "FolderTypeMovies": "Фільми", "FolderTypeMusic": "Музика", "FolderTypeTvShows": "ТБ", - "HeaderAlbums": "Альбоми", "HeaderBooks": "Книги", "HeaderDeleteDevice": "Видалить пристрій", "HeaderLatestEpisodes": "Нещодавно переглянуті серії", "HeaderLatestMedia": "Нещодавно переглянуті", "HeaderLatestMovies": "Нещодавні фільми", "HeaderLatestMusic": "Остання музика", - "HeaderMovies": "Фільми", "HeaderSeasons": "Сезони", "HeaderSeries": "Series", "HeaderSettings": "Налаштування", @@ -35,9 +32,7 @@ "LabelDeathDate": "Дата смерті:", "LabelLanguage": "Мова:", "LabelNewPassword": "Новий пароль:", - "LabelNext": "Вперед", "LabelPath": "Шлях:", - "LabelPrevious": "Назад", "Like": "Подобається", "MediaInfoAspectRatio": "Співвідношення сторін", "MediaInfoChannels": "Канали", @@ -62,10 +57,7 @@ "ParentalRating": "Parental Rating", "Save": "Зберігти", "Settings": "Налаштування", - "TabCollections": "Колекції", "TabEpisodes": "Епізоди", - "TabGenres": "Жанри", - "TabMovies": "Фільми", "TabNetworks": "Мережі", "TabNotifications": "Повідомлення", "TabPassword": "Пароль", @@ -143,7 +135,6 @@ "Auto": "Автоматично", "AuthProviderHelp": "Оберіть сервіс аутентифікації, який буде використаний для автентифікації пароля даного користувача.", "Audio": "Аудіо", - "AttributeNew": "Новий", "AspectRatio": "Співвідношення сторін", "AskAdminToCreateLibrary": "Попросіть адміністратора створити медіатеку.", "Ascending": "У порядку зростання", @@ -191,7 +182,6 @@ "CancelSeries": "Скасувати серіал", "CancelRecording": "Скасувати запис", "ButtonWebsite": "Веб-сайт", - "ButtonUp": "Вгору", "ButtonUninstall": "Видалити", "ButtonTrailer": "Трейлер", "ButtonTogglePlaylist": "Плейлист", @@ -200,10 +190,8 @@ "ButtonSplit": "Розділити", "ButtonStop": "Зупинити", "ButtonStart": "Почати", - "ButtonSort": "Сортувати", "ButtonSignIn": "Вхід", "ButtonShutdown": "Завершити роботу", - "ButtonShuffle": "Перемішати", "ButtonSettings": "Налаштування", "ButtonSend": "Надіслати", "ButtonSelectView": "Вибрати вигляд", @@ -240,18 +228,11 @@ "ButtonEditOtherUserPreferences": "Редагувати профіль, зображення та особисті налаштування даного користувача.", "ButtonEditImages": "Редагувати зображення", "ButtonEdit": "Редагувати", - "ButtonDownload": "Завантажити", - "ButtonDown": "Вниз", - "ButtonDeleteImage": "Видалити зображення", - "ButtonDelete": "Видалити", - "ButtonConnect": "Підключитись", "ButtonChangeServer": "Змінити сервер", "ButtonBack": "Назад", "ButtonAudioTracks": "Аудіозаписи", - "ButtonArrowUp": "Вниз", "ButtonArrowRight": "Вправо", "ButtonArrowLeft": "Вліво", - "ButtonArrowDown": "Вниз", "ButtonAddServer": "Додати сервер", "ButtonAddScheduledTaskTrigger": "Додати тригер", "ButtonAddMediaLibrary": "Додати медіатеку", diff --git a/src/strings/vi.json b/src/strings/vi.json index 431644be16..438dfe4632 100644 --- a/src/strings/vi.json +++ b/src/strings/vi.json @@ -4,13 +4,10 @@ "MessageBrowsePluginCatalog": "Duyệt qua các danh mục plugin của chúng tôi để xem các plugin có sẵn.", "ButtonAddUser": "Thêm người dùng", "ButtonCancel": "Thoát", - "ButtonDeleteImage": "Xóa hình ảnh", - "ButtonNew": "Mới", "ButtonRemove": "Gỡ bỏ", "ButtonResetPassword": "Reset mật khẩu", "ButtonSelectDirectory": "Lựa chọn trực tiếp", "ButtonSignOut": "Sign out", - "ButtonSort": "Phân loại", "Delete": "Xóa", "DeleteImage": "Xóa hình ảnh", "DeleteImageConfirmation": "Bạn có chắc muốn xóa hình ảnh này?", @@ -41,8 +38,6 @@ "LabelName": "Tên:", "LabelNewPassword": "Mật khẩu mới:", "LabelNewPasswordConfirm": "Xác nhận mật khẩu mới:", - "LabelNext": "Tiếp theo", - "LabelPrevious": "Trước", "LabelSaveLocalMetadata": "Lưu các ảnh nghệ thuật và metadata vào trong các thư mục media", "LabelSaveLocalMetadataHelp": "Lưu các ảnh nghệ thuật và metadata vào trong các thư mục media, sẽ đưa chúng vào một nơi bạn có thể chỉnh sửa dễ dàng hơn.", "LabelTime": "Thời gian:", @@ -89,12 +84,9 @@ "SettingsSaved": "Lưu các cài đặt.", "Sunday": "Chủ Nhật", "TabAlbumArtists": "Các Album nghệ sỹ", - "TabAlbums": "Các Album", "TabCatalog": "Danh mục", "TabEpisodes": "Các tập phim", - "TabGenres": "Các thể loại", "TabLatest": "Mới nhất", - "TabMovies": "Các phim", "TabMusicVideos": "Các video âm nhạc", "TabMyPlugins": "Các plugin của tôi", "TabNetworks": "Các mạng", @@ -102,7 +94,6 @@ "TabProfile": "Hồ sơ", "TabProfiles": "Hồ sơ", "TabServer": "Máy chủ", - "TabSongs": "Các ca khúc", "TabUpcoming": "Sắp diễn ra", "TellUsAboutYourself": "Nói cho chúng tôi biết đôi điều về Bạn", "ThisWizardWillGuideYou": "Thủ thuật này sẽ hướng dẫn quá trình cài đặt cho bạn. Để bắt đầu, vui lòng lựa chọn ngôn ngữ bạn ưa thích.", @@ -141,17 +132,11 @@ "ButtonEditOtherUserPreferences": "Chỉnh sửa thông tin, hình ảnh và sở thích cá nhân.", "ButtonEditImages": "Sửa hình ảnh", "ButtonEdit": "Sửa", - "ButtonDownload": "Tải", - "ButtonDown": "Xuống", - "ButtonDelete": "Xoá", - "ButtonConnect": "Kết nối", "ButtonChangeServer": "Đổi máy chủ", "ButtonBack": "Lùi", "ButtonAudioTracks": "Track âm thanh", - "ButtonArrowUp": "Lên", "ButtonArrowRight": "Phải", "ButtonArrowLeft": "Trái", - "ButtonArrowDown": "Xuống", "ButtonAddServer": "Thêm máy chủ", "ButtonAddScheduledTaskTrigger": "Thêm kích hoạt", "ButtonAddMediaLibrary": "Thêm thư viện Media", @@ -170,7 +155,6 @@ "Auto": "Tự động", "AuthProviderHelp": "Chọn Nhà cung cấp xác thực sẽ được sử dụng để xác thực mật khẩu người dùng này.", "Audio": "Âm thanh", - "AttributeNew": "Tạo mới", "AspectRatio": "Tỷ lệ khung hình", "AskAdminToCreateLibrary": "Yêu cầu quản trị viên tạo thư viện.", "Ascending": "Tăng dần", @@ -208,11 +192,9 @@ "ButtonSelectServer": "Chọn máy chủ", "ButtonScanAllLibraries": "Quét tất cả các thư viện", "ButtonOk": "Đồng Ý", - "ButtonShuffle": "Xáo trộn", "Categories": "Phân loại", "CancelRecording": "Ngưng ghi hình", "ButtonWebsite": "Trang web", - "ButtonUp": "Lên", "ButtonUninstall": "Gỡ cài đặt", "ButtonTrailer": "Tóm tắt", "ButtonSubtitles": "Phụ đề", @@ -297,7 +279,6 @@ "DoNotRecord": "Không ghi lại", "EnableCinemaMode": "Chế độ rạp phim", "EnableBackdropsHelp": "Hiển thị phông nền phía sau một số trang khi xem thư viện.", - "EnableBackdrops": "Phông nền", "EditSubtitles": "Chỉnh sửa phụ đề", "EditMetadata": "Chỉnh sửa thông tin", "EditImages": "Chỉnh sửa hình ảnh", @@ -321,7 +302,6 @@ "HeaderConfigureRemoteAccess": "Thiết Lập Truy Cập Từ Xa", "HeaderCodecProfile": "Bộ Giải Mã", "HeaderChapterImages": "Hình Ảnh Phân Đoạn", - "HeaderChannels": "Kênh", "HeaderChannelAccess": "Quyền Truy Cập Kênh", "HeaderCastCrew": "Diễn Viên & Ê-kíp", "HeaderCastAndCrew": "Diễn Viên & Ê-kíp", @@ -339,7 +319,6 @@ "HeaderApiKey": "API Key", "HeaderAllowMediaDeletionFrom": "Cho Phép Xoá Nội Dung", "HeaderAlert": "Thông Báo", - "HeaderAlbums": "Albums", "HeaderAlbumArtists": "Nghệ Sĩ Album", "HeaderAdmin": "Quản Trị", "HeaderAdditionalParts": "Phần Bổ Sung", @@ -443,7 +422,6 @@ "HeaderMyDevice": "Thiết Bị Của Tôi", "HeaderMusicVideos": "Video Âm Nhạc", "HeaderMusicQuality": "Chất Lượng Âm Nhạc", - "HeaderMovies": "Phim", "HeaderMoreLikeThis": "Nội Dung Tương Tự", "HeaderMetadataSettings": "Cài Đặt Dữ Liệu Bổ Trợ", "HeaderMediaInfo": "Thông Tin Nội Dung", @@ -464,7 +442,6 @@ "HeaderKodiMetadataHelp": "Để bật hoặc tắt dữ liệu từ NFO, hãy chỉnh sửa thư viện trong phần cài đặt thư viện của Jellyfin và điều chỉnh phần lưu trữ dữ liệu bổ trợ.", "HeaderKeepSeries": "Lưu Series", "HeaderKeepRecording": "Tiếp Tục Ghi Âm/Ghi Hình", - "HeaderItems": "Mục", "HeaderInstantMix": "Trộn Lẫn Nhanh", "HeaderInstall": "Cài Đặt", "HeaderImageSettings": "Thiết Lập Hình Ảnh", @@ -476,7 +453,6 @@ "HeaderHttpHeaders": "HTTP Headers", "HeaderHome": "Trang Chủ", "HeaderGuideProviders": "Nhà Cung Cấp Lịch Phát Sóng TV", - "HeaderGenres": "Thể Loại", "HeaderForgotPassword": "Quên Mật Khẩu", "HeaderForKids": "Dành Cho Trẻ Em", "HeaderFetcherSettings": "Cài Đặt Chương Trình Tải Xuống", @@ -554,7 +530,6 @@ "HeaderStopRecording": "Ngừng Ghi Hình/Ghi Âm", "HeaderSpecialFeatures": "Những Phần Đặc Biệt Nổi Bật", "HeaderSpecialEpisodeInfo": "Thông Tin Tập Đặc Biệt", - "HeaderShutdown": "Tắt Máy Chủ", "LabelCustomDeviceDisplayNameHelp": "Cung cấp một tên hiển thị riêng hoặc bỏ trống để sử dụng tên có sẵn của thiết bị.", "LabelCustomDeviceDisplayName": "Tên hiển thị:", "LabelCustomCssHelp": "Áp dụng tuỳ chỉnh riêng của bạn vào giao diện trang web.", @@ -630,7 +605,6 @@ "HideWatchedContentFromLatestMedia": "Ẩn những nội dung đã xem khỏi phần nội dung mới nhất", "Hide": "Ẩn", "Help": "Trợ Giúp", - "HeadersFolders": "Thư Mục", "HeaderYears": "Năm", "HeaderXmlSettings": "Cài Đặt XML", "HeaderXmlDocumentAttributes": "Những Thuộc Tính Tài Liệu XML", diff --git a/src/strings/zh-cn.json b/src/strings/zh-cn.json index ec3af3ea13..9de331b018 100644 --- a/src/strings/zh-cn.json +++ b/src/strings/zh-cn.json @@ -32,7 +32,6 @@ "Artists": "艺术家", "AsManyAsPossible": "尽可能多", "Ascending": "升序", - "AttributeNew": "新增", "Audio": "音频", "Auto": "自动", "Backdrop": "背景", @@ -51,19 +50,12 @@ "ButtonAddScheduledTaskTrigger": "添加触发器", "ButtonAddServer": "添加服务器", "ButtonAddUser": "添加用户", - "ButtonArrowDown": "下", "ButtonArrowLeft": "左", "ButtonArrowRight": "右", - "ButtonArrowUp": "上", "ButtonAudioTracks": "音轨", "ButtonBack": "返回", "ButtonCancel": "取消", "ButtonChangeServer": "更改服务器", - "ButtonConnect": "连接", - "ButtonDelete": "删除", - "ButtonDeleteImage": "删除图片", - "ButtonDown": "下", - "ButtonDownload": "下载", "ButtonEdit": "编辑", "ButtonEditImages": "修改图片", "ButtonEditOtherUserPreferences": "编辑这个用户的用户配置,图片和个人参数。", @@ -78,7 +70,6 @@ "ButtonManualLogin": "手动登录", "ButtonMore": "更多", "ButtonNetwork": "网络", - "ButtonNew": "新增", "ButtonNextTrack": "下一音轨", "ButtonOff": "关", "ButtonOk": "确定", @@ -104,18 +95,15 @@ "ButtonSelectView": "选择视图", "ButtonSend": "发送", "ButtonSettings": "设置", - "ButtonShuffle": "随机播放", "ButtonShutdown": "关机", "ButtonSignIn": "登录", "ButtonSignOut": "退出", - "ButtonSort": "排序", "ButtonStart": "开始", "ButtonStop": "停止", "ButtonSubmit": "提交", "ButtonSubtitles": "字幕", "ButtonTrailer": "预告片", "ButtonUninstall": "卸载", - "ButtonUp": "上", "ButtonWebsite": "网站", "CancelRecording": "取消录制", "CancelSeries": "取消系列", @@ -177,7 +165,6 @@ "EditImages": "修改图片", "EditMetadata": "编辑元数据", "EditSubtitles": "修改字幕", - "EnableBackdrops": "背景图", "EnableBackdropsHelp": "当浏览媒体库时背景图将作为一些页面的背景显示。", "EnableCinemaMode": "影院模式", "EnableDisplayMirroring": "显示镜像", @@ -251,7 +238,6 @@ "HeaderAdditionalParts": "附加部分", "HeaderAdmin": "管理", "HeaderAlbumArtists": "专辑作家", - "HeaderAlbums": "专辑", "HeaderAlert": "警报", "HeaderAllowMediaDeletionFrom": "允许从中删除媒体", "HeaderApiKey": "API 密钥", @@ -265,7 +251,6 @@ "HeaderCastAndCrew": "演员表", "HeaderCastCrew": "演职人员", "HeaderChannelAccess": "频道访问", - "HeaderChannels": "频道", "HeaderChapterImages": "剧集图片", "HeaderCodecProfile": "编解码器配置", "HeaderCodecProfileHelp": "编解码器的配置文件标明了设备播放特定编码时的限制。如果在限制之内则媒体将被转码,否则编解码器将被配置为直接播放。", @@ -307,7 +292,6 @@ "HeaderForKids": "给儿童", "HeaderForgotPassword": "忘记密码", "HeaderFrequentlyPlayed": "多次播放", - "HeaderGenres": "风格", "HeaderGuideProviders": "电视指南数据提供方", "HeaderHttpHeaders": "HTTP 头部", "HeaderIdentification": "身份识别", @@ -318,7 +302,6 @@ "HeaderImageSettings": "图片设置", "HeaderInstall": "安装", "HeaderInstantMix": "速成合辑", - "HeaderItems": "项目", "HeaderKodiMetadataHelp": "要启用或禁用 NFO 元数据, 请编辑库, 然后找到“元数据储户”部分。", "HeaderLatestEpisodes": "最新剧集", "HeaderLatestMedia": "最新媒体", @@ -339,7 +322,6 @@ "HeaderMediaInfo": "媒体信息", "HeaderMetadataSettings": "元数据设置", "HeaderMoreLikeThis": "更多类似的", - "HeaderMovies": "电影", "HeaderMusicVideos": "音乐视频", "HeaderMyDevice": "我的设备", "HeaderMyMedia": "我的媒体", @@ -395,7 +377,6 @@ "HeaderServerSettings": "服务器设置", "HeaderSettings": "设置", "HeaderSetupLibrary": "设置你的媒体库", - "HeaderShutdown": "关机", "HeaderSortBy": "排序方式", "HeaderSortOrder": "排序顺序", "HeaderSpecialEpisodeInfo": "特别剧集信息", @@ -428,7 +409,6 @@ "HeaderXmlDocumentAttributes": "XML文档属性", "HeaderXmlSettings": "XML设置", "HeaderYears": "年份", - "HeadersFolders": "文件夹", "Help": "帮助", "Hide": "隐藏", "HideWatchedContentFromLatestMedia": "从最新媒体中隐藏已观看的内容", @@ -644,7 +624,6 @@ "LabelNewPassword": "新密码:", "LabelNewPasswordConfirm": "新密码确认:", "LabelNewsCategories": "新分类:", - "LabelNext": "下一个", "LabelNotificationEnabled": "启用此通知", "LabelNumber": "编号:", "LabelNumberOfGuideDays": "下载几天的节目指南:", @@ -671,7 +650,6 @@ "LabelPreferredDisplayLanguage": "首选显示语言:", "LabelPreferredDisplayLanguageHelp": "Jellyfin的翻译工作是一个不断推进的工程项目。", "LabelPreferredSubtitleLanguage": "字幕语言偏好:", - "LabelPrevious": "上一个", "LabelProfileAudioCodecs": "音频编解码器:", "LabelProfileCodecs": "编解码器:", "LabelProfileCodecsHelp": "以逗号分隔。留空则适用于所有编解码器。", @@ -685,7 +663,6 @@ "LabelPublicHttpPortHelp": "映射到本地 HTTP 端口的公开端口号。", "LabelPublicHttpsPort": "公开 HTTPS 端口号:", "LabelPublicHttpsPortHelp": "映射到本地 HTTPS 端口的公开端口号。", - "LabelReadHowYouCanContribute": "了解如何做出贡献。", "LabelReasonForTranscoding": "转码原因:", "LabelRecord": "录制:", "LabelRecordingPath": "默认录制路径:", @@ -888,7 +865,6 @@ "MessageNoNextUpItems": "没有发现。开始看你的节目!", "MessageNoPluginConfiguration": "此插件没有配置选项。", "NoSubtitleSearchResultsFound": "未找到结果。", - "NoSubtitles": "无字幕", "NoSubtitlesHelp": "字幕将默认不被加载,但你仍然可以在播放时手动打开字幕。", "None": "无", "Normal": "普通", @@ -1156,24 +1132,16 @@ "TabAccess": "访问", "TabAdvanced": "高级", "TabAlbumArtists": "专辑艺术家", - "TabAlbums": "专辑", "TabCatalog": "目录", - "TabChannels": "频道", "TabCodecs": "编解码器", - "TabCollections": "收藏", "TabContainers": "媒体载体", "TabDashboard": "控制台", - "TabDevices": "设备", "TabDirectPlay": "直接播放", "TabEpisodes": "剧集", - "TabFavorites": "我的最爱", - "TabGenres": "风格", - "TabGuide": "指南", "TabInfo": "信息", "TabLatest": "最新", "TabLiveTV": "电视直播", "TabLogs": "日志", - "TabMovies": "电影", "TabMusic": "音乐", "TabMusicVideos": "音乐视频", "TabMyPlugins": "我的插件", @@ -1194,8 +1162,6 @@ "TabSeries": "电视剧", "TabServer": "服务器", "TabSettings": "设置", - "TabShows": "节目", - "TabSongs": "歌曲", "TabStreaming": "流媒体传输", "TabTrailers": "预告片", "TabUpcoming": "即将发布", @@ -1458,7 +1424,6 @@ "HeaderRemoteAccessSettings": "远程访问设置", "HeaderHttpsSettings": "HTTPS 设置", "ApiKeysCaption": "当前启用的 API 密钥", - "TabDVR": "DVR", "SaveChanges": "保存更改", "LabelRequireHttpsHelp": "开启后服务器将自动将所有 HTTP 请求重定向到 HTTPS。如果服务器没有启用 HTTPS 则不生效。", "LabelRequireHttps": "强制 HTTPS", diff --git a/src/strings/zh-hk.json b/src/strings/zh-hk.json index b8f48d474c..454bbea0c2 100644 --- a/src/strings/zh-hk.json +++ b/src/strings/zh-hk.json @@ -3,12 +3,9 @@ "ButtonAddScheduledTaskTrigger": "新增觸發點", "ButtonAddUser": "添加用戶", "ButtonCancel": "取消", - "ButtonDelete": "删除", - "ButtonDeleteImage": "刪除圖像", "ButtonEdit": "編輯", "ButtonFilter": "過濾", "ButtonManualLogin": "手動登入", - "ButtonNew": "新增", "ButtonOk": "確定", "ButtonPlay": "播放", "ButtonQuickStartGuide": "快速入門指南", @@ -21,7 +18,6 @@ "ButtonSelectDirectory": "選擇目錄", "ButtonSignIn": "登入", "ButtonSignOut": "登出", - "ButtonSort": "排序", "ButtonSubmit": "提交", "ButtonSubtitles": "字幕", "ChannelAccessHelp": "選擇此用戶共享頻道。管理員將能夠使用資料管理器而編輯所有文件夾。", @@ -47,7 +43,6 @@ "HeaderBooks": "書籍", "HeaderBranding": "界面", "HeaderCastCrew": "演員陣容", - "HeaderChannels": "頻道", "HeaderCustomDlnaProfiles": "自定配置", "HeaderDeviceAccess": "允許裝置通行", "HeaderDevices": "裝置", @@ -141,19 +136,16 @@ "LabelName": "名稱:", "LabelNewPassword": "新密碼:", "LabelNewPasswordConfirm": "新密碼確認:", - "LabelNext": "下一個", "LabelNumberOfGuideDays": "下載電視指南日數", "LabelNumberOfGuideDaysHelp": "下載更多電視指南資料會提供更好時間表查看能力,但將需要更長的下載時間。自動基於頻道數目來選擇。", "LabelPassword": "密碼:", "LabelPath": "路徑:", "LabelPreferredDisplayLanguage": "首選語言:", "LabelPreferredDisplayLanguageHelp": "翻譯 Jellyfin 是一個進行中的項目。", - "LabelPrevious": "前一個", "LabelPublicHttpPort": "公共 http 連接埠號碼:", "LabelPublicHttpPortHelp": "公共連接埠號碼應映射到本地 http 連接埠。", "LabelPublicHttpsPort": "公共 https 連接埠號碼:", "LabelPublicHttpsPortHelp": "公共連接埠號碼應映射到本地 https 連接埠。", - "LabelReadHowYouCanContribute": "了解如何作出貢獻。", "LabelSaveLocalMetadata": "儲存媒體圖片和資料屬性到媒體所屬的文件夾", "LabelSaveLocalMetadataHelp": "直接儲存媒體圖片和資料到媒體文件夾,讓編輯工作更容易。", "LabelSelectUsers": "選擇用戶:", @@ -276,19 +268,11 @@ "TabAccess": "可以通行", "TabAdvanced": "進階", "TabAlbumArtists": "唱片歌手", - "TabAlbums": "專輯", "TabCatalog": "目錄", - "TabChannels": "頻道", - "TabCollections": "藏品", "TabDashboard": "狀態", - "TabDevices": "裝置", "TabEpisodes": "劇集", - "TabFavorites": "我的最受", - "TabGenres": "風格", - "TabGuide": "指南", "TabInfo": "資訊", "TabLatest": "最新", - "TabMovies": "電影", "TabMusic": "音樂", "TabMusicVideos": "MV", "TabMyPlugins": "我的插件", @@ -302,8 +286,6 @@ "TabSeries": "電視劇", "TabServer": "伺服器", "TabSettings": "設定", - "TabShows": "節目", - "TabSongs": "歌曲", "TabTrailers": "預告", "TabUpcoming": "即將發佈", "TabUsers": "用戶", @@ -357,7 +339,6 @@ "Albums": "專輯", "Absolute": "絕對", "AuthProviderHelp": "選擇用於驗證該用戶密碼的身份驗證提供程序。", - "AttributeNew": "新", "AspectRatio": "長寬比", "AskAdminToCreateLibrary": "要求管理員創建一個庫。", "Ascending": "上升", @@ -449,15 +430,11 @@ "ButtonForgotPassword": "忘記密碼", "ButtonEditOtherUserPreferences": "更改用戶個人檔案,圖片及個人偏好。", "ButtonEditImages": "更改圖片", - "ButtonDownload": "下載", - "ButtonConnect": "連接", "ButtonChangeServer": "更換伺服器", "ButtonBack": "返回", "ButtonAudioTracks": "音軌", - "ButtonArrowUp": "箭咀上", "ButtonArrowRight": "箭咀右", "ButtonArrowLeft": "箭咀左", - "ButtonArrowDown": "箭咀下", "ButtonAddServer": "新增伺服器", "ButtonAddMediaLibrary": "新增媒體櫃", "ButtonAddImage": "新增圖片", @@ -470,13 +447,11 @@ "Backdrop": "背景", "AlwaysPlaySubtitles": "經常播放", "Display": "顯示", - "EnableBackdrops": "背景", "EditImages": "更改圖片", "DownloadsValue": "下載數目 {0}", "Download": "下載", "DisplayInMyMedia": "在主頁顯示", "ButtonSyncPlay": "SyncPlay", - "ButtonDown": "向下", "BurnSubtitlesHelp": "確定若服務器對視頻進行轉碼時是否嵌入字幕。 關閉這功能將使用更少時間。 選擇'自動'可嵌入基於圖像的格式字幕(VOBSUB,PGS,SUB,IDX等)和某些ASS或SSA字幕。", "MessageBrowsePluginCatalog": "瀏覽我們的插件目錄以查看可用的插件。", "BoxRear": "盒裝(背面)", @@ -490,8 +465,6 @@ "ColorPrimaries": "主色調", "CinemaModeConfigurationHelp": "影院模式可在播放主影片前加入預告片及自定引言片段,帶來戲院式體驗。", "ChangingMetadataImageSettingsNewContent": "任何資料變更只適用於新加入到媒體庫的內容。如要更改舊有媒體的內容,請手動刷新資料。", - "ButtonUp": "上", - "ButtonShuffle": "隨機播放", "ButtonSelectView": "選擇介面", "ButtonOff": "關閉", "ButtonLibraryAccess": "媒體庫存取", diff --git a/src/strings/zh-tw.json b/src/strings/zh-tw.json index c937cdb161..f9f9bce7a7 100644 --- a/src/strings/zh-tw.json +++ b/src/strings/zh-tw.json @@ -7,8 +7,6 @@ "ButtonAddServer": "新增伺服器", "ButtonAddUser": "新增使用者", "ButtonCancel": "取消", - "ButtonDelete": "刪除", - "ButtonDeleteImage": "刪除圖像", "ButtonEdit": "編輯", "ButtonEditImages": "編輯圖片", "ButtonFilter": "過濾", @@ -16,7 +14,6 @@ "ButtonGotIt": "我知道了", "ButtonGuide": "節目表", "ButtonHome": "首頁", - "ButtonNew": "建立", "ButtonOk": "確定", "ButtonPlay": "播放", "ButtonQuickStartGuide": "快速入門指南", @@ -28,7 +25,6 @@ "ButtonSelectServer": "選擇伺服器", "ButtonSignIn": "登入", "ButtonSignOut": "登出", - "ButtonSort": "排序", "ConfirmDeleteItem": "刪除此項目時,也會一併從檔案系統及媒體櫃中刪除。確定要刪除嗎?", "ConfirmDeletion": "確定刪除", "Continuing": "繼續", @@ -58,7 +54,6 @@ "HeaderAdditionalParts": "附加部份", "HeaderAdmin": "管理", "HeaderCastCrew": "拍攝人員及演員", - "HeaderChannels": "頻道", "HeaderCustomDlnaProfiles": "自訂設定檔", "HeaderDeleteItem": "刪除項目", "HeaderEasyPinCode": "簡易 PIN 碼", @@ -126,10 +121,8 @@ "LabelName": "名字:", "LabelNewPassword": "新密碼:", "LabelNewPasswordConfirm": "確認新密碼:", - "LabelNext": "下一個", "LabelPassword": "密碼:", "LabelPlaylist": "播放清單:", - "LabelPrevious": "上一個", "LabelRefreshMode": "更新模式:", "LabelSaveLocalMetadata": "將媒體圖像及中繼資料存到媒體所在的資料夾", "LabelSaveLocalMetadataHelp": "直接儲存圖片及中繼資料到媒體所在的資料夾能使編輯更容易。", @@ -248,16 +241,11 @@ "Sunday": "星期天", "TabAdvanced": "進階", "TabAlbumArtists": "專輯歌手", - "TabAlbums": "專輯", "TabCatalog": "目錄", - "TabChannels": "頻道", "TabEpisodes": "單元", - "TabGenres": "類型", - "TabGuide": "節目表", "TabInfo": "資訊", "TabLatest": "最新", "TabLiveTV": "電視", - "TabMovies": "電影", "TabMusic": "音樂", "TabMyPlugins": "我的附加元件", "TabNetworks": "網路", @@ -268,8 +256,6 @@ "TabSeries": "電視劇", "TabServer": "伺服器", "TabSettings": "設定", - "TabShows": "節目", - "TabSongs": "歌曲", "TabTrailers": "預告", "TabUpcoming": "接下來", "TellUsAboutYourself": "介紹一下自己", @@ -309,7 +295,6 @@ "AsManyAsPossible": "越多越好", "Ascending": "遞增", "AspectRatio": "長寬比", - "AttributeNew": "新增", "Audio": "音訊", "Auto": "自動", "Backdrop": "背景", @@ -323,7 +308,6 @@ "ButtonAddMediaLibrary": "新增媒體櫃", "ButtonArrowLeft": "左", "ButtonArrowRight": "右", - "ButtonArrowUp": "上", "ButtonAudioTracks": "音軌", "ButtonBack": "返回", "ButtonChangeServer": "更換伺服器", @@ -339,10 +323,6 @@ "Box": "盒子", "BoxRear": "盒子(背面)", "BurnSubtitlesHelp": "根據字幕格式決定伺服器在影片轉檔時是否燒錄字幕。避免燒錄字幕時消耗過多伺服器資源。選擇「自動」以燒錄圖片格式的字幕(如 VOBSUB、PGS 或 SUB/IDX 等)與複雜的 ASS/SSA 字幕。", - "ButtonArrowDown": "下", - "ButtonConnect": "連結", - "ButtonDown": "下", - "ButtonDownload": "下載", "ButtonEditOtherUserPreferences": "編輯使用者個人檔案、大頭貼和個人設定。", "ButtonFullscreen": "全螢幕", "ButtonInfo": "詳細資料", @@ -366,7 +346,6 @@ "ButtonSelectView": "選擇顯示方式", "ButtonSend": "傳送", "ButtonSettings": "設定", - "ButtonShuffle": "隨機播放", "ButtonShutdown": "關機", "ButtonStart": "開始", "ButtonStop": "停止", @@ -374,7 +353,6 @@ "ButtonSubtitles": "字幕", "ButtonTrailer": "預告片", "ButtonUninstall": "解除安裝", - "ButtonUp": "上", "ButtonWebsite": "網站", "CancelRecording": "取消錄影", "CancelSeries": "取消系列", @@ -436,7 +414,6 @@ "EasyPasswordHelp": "你的簡易 PIN 碼將會用於在支援的 Jellyfin 應用上進行離線存取,同時也可被用於區域網路的登入。", "EditMetadata": "編輯中繼資料", "EditSubtitles": "編輯字幕", - "EnableBackdrops": "背景", "EnableBackdropsHelp": "瀏覽媒體庫時背景圖將作為頁面的背景。", "EnableCinemaMode": "影院模式", "EnableColorCodedBackgrounds": "色彩背景", @@ -501,7 +478,6 @@ "HeaderAddToPlaylist": "加到播放清單", "HeaderAddUpdateImage": "新增/更新圖片", "HeaderAlbumArtists": "專輯演出者", - "HeaderAlbums": "專輯", "HeaderAlert": "通知", "HeaderAllowMediaDeletionFrom": "允許從中刪除媒體", "HeaderApiKey": "API 金鑰", @@ -560,7 +536,6 @@ "HeaderFavoriteVideos": "最愛的影片", "HeaderFetcherSettings": "擷取器設置", "HeaderForKids": "給兒童", - "HeaderGenres": "類型", "HeaderHttpHeaders": "HTTP 標頭", "HeaderIdentification": "身份識別", "HeaderIdentificationCriteriaHelp": "至少輸入一個識別標準。", @@ -568,7 +543,6 @@ "HeaderIdentifyItemHelp": "輸入一個或多個搜索條件。刪除條件可得到更多搜索結果。", "HeaderImageOptions": "圖片選項", "HeaderInstall": "安裝", - "HeaderItems": "項目", "HeaderKeepRecording": "繼續錄製", "HeaderKeepSeries": "保存系列", "HeaderKodiMetadataHelp": "要啟用或停用 NFO 中繼資料,請在設定裡「建立媒體庫」頁面中編輯「中繼資料儲存」部分。", @@ -585,7 +559,6 @@ "HeaderMediaInfo": "媒體資訊", "HeaderMetadataSettings": "中繼資料設定", "HeaderMoreLikeThis": "更多類似的", - "HeaderMovies": "電影", "HeaderMusicQuality": "音質", "HeaderMyDevice": "我的裝置", "HeaderMyMedia": "我的媒體", @@ -625,7 +598,6 @@ "HeaderServerSettings": "伺服器設定", "HeaderSettings": "設定", "HeaderSetupLibrary": "設置你的媒體庫", - "HeaderShutdown": "關機", "HeaderSortBy": "分類", "HeaderSortOrder": "分類順序", "HeaderSpecialEpisodeInfo": "特集資訊", @@ -673,7 +645,6 @@ "HeaderXmlDocumentAttributes": "XML 檔案屬性", "HeaderXmlSettings": "XML 設置", "HeaderYears": "年份", - "HeadersFolders": "資料夾", "Hide": "隱藏", "HideWatchedContentFromLatestMedia": "從最新媒體中隱藏已觀看的內容", "Home": "首頁", @@ -784,7 +755,6 @@ "LabelVersionInstalled": "{0} 已安裝", "DashboardVersionNumber": "版本:{0}", "DashboardServerName": "伺服器:{0}", - "NoSubtitles": "無", "List": "清單", "OptionAllowMediaPlayback": "允許播放媒體", "OneChannel": "單聲道", @@ -795,7 +765,6 @@ "ResumeAt": "從 {0} 繼續播放", "Settings": "設定", "TabAccess": "存取", - "TabDevices": "裝置", "TabDirectPlay": "直接播放", "ThemeSongs": "主題曲", "ThemeVideos": "主題曲影片", @@ -1015,7 +984,6 @@ "TabCodecs": "編碼", "TabContainers": "影片容器", "TabDashboard": "控制台", - "TabFavorites": "最愛", "TabLogs": "日誌", "TabNotifications": "通知", "TabOther": "其他", @@ -1366,7 +1334,6 @@ "LabelProtocolInfoHelp": "當響應來自裝置的 GetProtocolInfo(獲取協議訊息)請求時,該值將被使用。", "LabelPublicHttpPortHelp": "公開連接埠應映射到本地 HTTP 連接埠。", "LabelPublicHttpsPortHelp": "公開連接埠應映射到本地 HTTPS 連接埠。", - "LabelReadHowYouCanContribute": "瞭解如何一同貢獻。", "LabelSelectFolderGroups": "自動將以下資料夾中的內容分組到視圖中,例如電影、音樂和電視:", "LabelStatus": "狀態:", "LiveBroadcasts": "直播", @@ -1377,7 +1344,6 @@ "SaveSubtitlesIntoMediaFoldersHelp": "將字幕存儲在影片檔案旁邊可以讓管理更方便。", "ScanForNewAndUpdatedFiles": "掃描新的和有修改的文件", "Schedule": "排程", - "TabCollections": "收藏", "TabNetworking": "網路", "TitlePlayback": "播放", "ValueConditions": "條件:{0}", @@ -1491,7 +1457,6 @@ "ButtonCast": "投放", "Writers": "作者", "ViewAlbumArtist": "檢視專輯演出者", - "TabDVR": "DVR", "TabRepositories": "儲存庫", "MessageSyncPlayErrorAccessingGroups": "存取群組清單時發生錯誤。", "MessageSyncPlayLibraryAccessDenied": "存取受限。", From 369d7b2f5a1092488260b7959c35bf0a1e2d6833 Mon Sep 17 00:00:00 2001 From: dkanada Date: Thu, 13 Aug 2020 21:56:01 +0900 Subject: [PATCH 191/301] merge weekday strings --- .../accessSchedule/accessSchedule.template.html | 14 +++++++------- .../homeScreenSettings.template.html | 14 +++++++------- src/components/homesections/homesections.js | 4 ++-- .../dashboard/plugins/available/index.js | 2 +- .../dashboard/scheduledtasks/scheduledtask.html | 16 ++++++++-------- src/controllers/dashboard/users/useredit.html | 2 +- .../dashboard/users/userlibraryaccess.html | 2 +- .../dashboard/users/userparentalcontrol.html | 2 +- .../dashboard/users/userpassword.html | 2 +- src/controllers/itemDetails/index.html | 4 ++-- src/controllers/itemDetails/index.js | 4 ++-- src/controllers/livetv.html | 2 +- src/controllers/livetv/livetvsuggested.js | 6 +++--- src/controllers/music/musicrecommended.js | 2 +- src/controllers/shows/tvrecommended.html | 2 +- src/scripts/editorsidebar.js | 2 +- src/scripts/libraryMenu.js | 6 +++--- 17 files changed, 43 insertions(+), 43 deletions(-) diff --git a/src/components/accessSchedule/accessSchedule.template.html b/src/components/accessSchedule/accessSchedule.template.html index e209fbc1ff..c0f83ccec6 100644 --- a/src/components/accessSchedule/accessSchedule.template.html +++ b/src/components/accessSchedule/accessSchedule.template.html @@ -12,13 +12,13 @@
    @@ -38,7 +38,7 @@ - + @@ -51,7 +51,7 @@ - + @@ -64,7 +64,7 @@ - + @@ -77,7 +77,7 @@ - + @@ -90,7 +90,7 @@ - + @@ -103,7 +103,7 @@ - + diff --git a/src/components/homesections/homesections.js b/src/components/homesections/homesections.js index 6198894088..e933cf2c3a 100644 --- a/src/components/homesections/homesections.js +++ b/src/components/homesections/homesections.js @@ -696,12 +696,12 @@ import 'css!./homesections'; serverId: apiClient.serverId() }) + '" class="button-flat button-flat-mini sectionTitleTextButton">'; html += '

    '; - html += globalize.translate('HeaderNextUp'); + html += globalize.translate('NextUp'); html += '

    '; html += ''; html += ''; } else { - html += '

    ' + globalize.translate('HeaderNextUp') + '

    '; + html += '

    ' + globalize.translate('NextUp') + '

    '; } html += '
    '; diff --git a/src/controllers/dashboard/plugins/available/index.js b/src/controllers/dashboard/plugins/available/index.js index 22b28e0f5a..b7c3505aa1 100644 --- a/src/controllers/dashboard/plugins/available/index.js +++ b/src/controllers/dashboard/plugins/available/index.js @@ -28,7 +28,7 @@ function getHeaderText(category) { } else if (category === 'Theme') { category = 'Themes'; } else if (category === 'LiveTV') { - category = 'HeaderLiveTV'; + category = 'LiveTV'; } else if (category === 'ScreenSaver') { category = 'HeaderScreenSavers'; } diff --git a/src/controllers/dashboard/scheduledtasks/scheduledtask.html b/src/controllers/dashboard/scheduledtasks/scheduledtask.html index 4dab484905..dc17d9bf07 100644 --- a/src/controllers/dashboard/scheduledtasks/scheduledtask.html +++ b/src/controllers/dashboard/scheduledtasks/scheduledtask.html @@ -31,18 +31,18 @@ - +
    diff --git a/src/controllers/dashboard/users/useredit.html b/src/controllers/dashboard/users/useredit.html index a097144cc3..400c0c35bf 100644 --- a/src/controllers/dashboard/users/useredit.html +++ b/src/controllers/dashboard/users/useredit.html @@ -14,7 +14,7 @@ ${TabProfile} ${TabAccess} ${TabParentalControl} - ${TabPassword} + ${HeaderPassword}

    ${ButtonEditOtherUserPreferences} diff --git a/src/controllers/dashboard/users/userlibraryaccess.html b/src/controllers/dashboard/users/userlibraryaccess.html index f0a239c6a6..363e52a716 100644 --- a/src/controllers/dashboard/users/userlibraryaccess.html +++ b/src/controllers/dashboard/users/userlibraryaccess.html @@ -14,7 +14,7 @@ ${TabProfile} ${TabAccess} ${TabParentalControl} - ${TabPassword} + ${HeaderPassword}

    diff --git a/src/controllers/dashboard/users/userparentalcontrol.html b/src/controllers/dashboard/users/userparentalcontrol.html index fd763ca26d..ffbd183a29 100644 --- a/src/controllers/dashboard/users/userparentalcontrol.html +++ b/src/controllers/dashboard/users/userparentalcontrol.html @@ -12,7 +12,7 @@ ${TabProfile} ${TabAccess} ${TabParentalControl} - ${TabPassword} + ${HeaderPassword}
    diff --git a/src/controllers/dashboard/users/userpassword.html b/src/controllers/dashboard/users/userpassword.html index 51df2e2cb0..0f6ea2d78e 100644 --- a/src/controllers/dashboard/users/userpassword.html +++ b/src/controllers/dashboard/users/userpassword.html @@ -12,7 +12,7 @@ ${TabProfile} ${TabAccess} ${TabParentalControl} - ${TabPassword} + ${HeaderPassword}
    diff --git a/src/controllers/itemDetails/index.html b/src/controllers/itemDetails/index.html index 8c16daba99..bd0821eebe 100644 --- a/src/controllers/itemDetails/index.html +++ b/src/controllers/itemDetails/index.html @@ -147,14 +147,14 @@
    -

    ${HeaderSchedule}

    +

    ${Schedule}

    -

    ${HeaderNextUp}

    +

    ${NextUp}

    diff --git a/src/controllers/itemDetails/index.js b/src/controllers/itemDetails/index.js index 9d4ba09392..c57190139f 100644 --- a/src/controllers/itemDetails/index.js +++ b/src/controllers/itemDetails/index.js @@ -785,7 +785,7 @@ import 'emby-select'; function setPeopleHeader(page, item) { if (item.MediaType == 'Audio' || item.Type == 'MusicAlbum' || item.MediaType == 'Book' || item.MediaType == 'Photo') { - page.querySelector('#peopleHeader').innerHTML = globalize.translate('HeaderPeople'); + page.querySelector('#peopleHeader').innerHTML = globalize.translate('People'); } else { page.querySelector('#peopleHeader').innerHTML = globalize.translate('HeaderCastAndCrew'); } @@ -1432,7 +1432,7 @@ import 'emby-select'; name: globalize.translate('HeaderVideos'), mediaType: 'Video' }, { - name: globalize.translate('HeaderSeries'), + name: globalize.translate('Series'), type: 'Series' }, { name: globalize.translate('Albums'), diff --git a/src/controllers/livetv.html b/src/controllers/livetv.html index 0e02947c12..753521f40b 100644 --- a/src/controllers/livetv.html +++ b/src/controllers/livetv.html @@ -1,4 +1,4 @@ -
    +
    diff --git a/src/controllers/livetv/livetvsuggested.js b/src/controllers/livetv/livetvsuggested.js index 9fec9a2707..346630012a 100644 --- a/src/controllers/livetv/livetvsuggested.js +++ b/src/controllers/livetv/livetvsuggested.js @@ -172,11 +172,11 @@ function getTabs() { }, { name: globalize.translate('Channels') }, { - name: globalize.translate('TabRecordings') + name: globalize.translate('Recordings') }, { - name: globalize.translate('HeaderSchedule') + name: globalize.translate('Schedule') }, { - name: globalize.translate('TabSeries') + name: globalize.translate('Series') }]; } diff --git a/src/controllers/music/musicrecommended.js b/src/controllers/music/musicrecommended.js index 4a04f9e827..65ecd79f65 100644 --- a/src/controllers/music/musicrecommended.js +++ b/src/controllers/music/musicrecommended.js @@ -185,7 +185,7 @@ import 'flexStyles'; }, { name: globalize.translate('Artists') }, { - name: globalize.translate('TabPlaylists') + name: globalize.translate('Playlists') }, { name: globalize.translate('Songs') }, { diff --git a/src/controllers/shows/tvrecommended.html b/src/controllers/shows/tvrecommended.html index bdc21fdc81..2302279ed7 100644 --- a/src/controllers/shows/tvrecommended.html +++ b/src/controllers/shows/tvrecommended.html @@ -26,7 +26,7 @@
    -

    ${HeaderNextUp}

    +

    ${NextUp}

    diff --git a/src/scripts/editorsidebar.js b/src/scripts/editorsidebar.js index 2489335969..7c15eae221 100644 --- a/src/scripts/editorsidebar.js +++ b/src/scripts/editorsidebar.js @@ -86,7 +86,7 @@ import 'material-icons'; if (result.TotalRecordCount) { nodes.push({ id: 'livetv', - text: globalize.translate('HeaderLiveTV'), + text: globalize.translate('LiveTV'), state: { opened: false }, diff --git a/src/scripts/libraryMenu.js b/src/scripts/libraryMenu.js index 5ee485e815..d237eead9d 100644 --- a/src/scripts/libraryMenu.js +++ b/src/scripts/libraryMenu.js @@ -377,7 +377,7 @@ import 'flexStyles'; pageIds: ['dashboardGeneralPage'], icon: 'settings' }, { - name: globalize.translate('TabUsers'), + name: globalize.translate('HeaderUsers'), href: 'userprofiles.html', pageIds: ['userProfilesPage', 'newUserPage', 'editUserPage', 'userLibraryAccessPage', 'userParentalControlPage', 'userPasswordPage'], icon: 'people' @@ -417,10 +417,10 @@ import 'flexStyles'; }); links.push({ divider: true, - name: globalize.translate('TabLiveTV') + name: globalize.translate('LiveTV') }); links.push({ - name: globalize.translate('TabLiveTV'), + name: globalize.translate('LiveTV'), href: 'livetvstatus.html', pageIds: ['liveTvStatusPage', 'liveTvTunerPage'], icon: 'live_tv' From d1858bd03001c6458d4da45cbe9ffea00c93438f Mon Sep 17 00:00:00 2001 From: dkanada Date: Thu, 13 Aug 2020 22:02:55 +0900 Subject: [PATCH 192/301] remove more unused translations --- src/strings/af.json | 8 +------- src/strings/ar.json | 20 -------------------- src/strings/bg-bg.json | 20 -------------------- src/strings/ca.json | 20 -------------------- src/strings/cs.json | 20 -------------------- src/strings/da.json | 20 -------------------- src/strings/de.json | 20 -------------------- src/strings/el.json | 19 ------------------- src/strings/en-gb.json | 20 -------------------- src/strings/en-us.json | 20 -------------------- src/strings/es-ar.json | 20 -------------------- src/strings/es-mx.json | 20 -------------------- src/strings/es.json | 20 -------------------- src/strings/es_419.json | 20 -------------------- src/strings/fa.json | 20 -------------------- src/strings/fi.json | 20 -------------------- src/strings/fr-ca.json | 3 --- src/strings/fr.json | 20 -------------------- src/strings/gsw.json | 11 ----------- src/strings/he.json | 20 +------------------- src/strings/hr.json | 19 ------------------- src/strings/hu.json | 20 -------------------- src/strings/id.json | 3 --- src/strings/is-is.json | 10 ---------- src/strings/it.json | 20 -------------------- src/strings/ja.json | 19 ------------------- src/strings/kk.json | 20 -------------------- src/strings/ko.json | 20 -------------------- src/strings/lt-lt.json | 17 ----------------- src/strings/lv.json | 20 -------------------- src/strings/ms.json | 3 --- src/strings/nb.json | 20 -------------------- src/strings/nl.json | 20 -------------------- src/strings/pl.json | 20 -------------------- src/strings/pt-br.json | 20 -------------------- src/strings/pt-pt.json | 20 -------------------- src/strings/pt.json | 20 -------------------- src/strings/ro.json | 20 -------------------- src/strings/ru.json | 20 -------------------- src/strings/sk.json | 20 -------------------- src/strings/sl-si.json | 20 -------------------- src/strings/sr.json | 2 -- src/strings/sv.json | 20 -------------------- src/strings/tr.json | 16 ---------------- src/strings/uk.json | 5 ----- src/strings/vi.json | 10 ---------- src/strings/zh-cn.json | 20 -------------------- src/strings/zh-hk.json | 16 ---------------- src/strings/zh-tw.json | 20 -------------------- 49 files changed, 2 insertions(+), 839 deletions(-) diff --git a/src/strings/af.json b/src/strings/af.json index 53b658836e..f18b2fc14b 100644 --- a/src/strings/af.json +++ b/src/strings/af.json @@ -122,21 +122,16 @@ "ThemeVideos": "Tema Videos", "ThemeSongs": "Tema Liedjies", "TellUsAboutYourself": "Vertel ons van jouself", - "TabUsers": "Gebruikers", "TabUpcoming": "Komende", "TabTrailers": "Voorprente", "TabStreaming": "Stroom", "TabSettings": "Instellings", "TabServer": "Bediener", - "TabSeries": "Reekse", "TabScheduledTasks": "Geskeduleerde Take", "TabResumeSettings": "Hervat", "TabResponses": "Reaksies", - "TabRecordings": "Opnames", "TabProfiles": "Profiele", "TabProfile": "Profiel", - "TabPlaylists": "Speel lyste", - "TabPassword": "Wagwoord", "TabParentalControl": "Ouer Beheer", "TabOther": "Ander", "TabNotifications": "Kennisgewings", @@ -145,6 +140,5 @@ "TabNetworks": "Netwerke", "TabMusicVideos": "Musiek Videos", "TabMusic": "Musiek", - "TabLogs": "Logs", - "TabLiveTV": "Lewendige TV" + "TabLogs": "Logs" } diff --git a/src/strings/ar.json b/src/strings/ar.json index 24020ed834..23cb2c9cab 100644 --- a/src/strings/ar.json +++ b/src/strings/ar.json @@ -183,8 +183,6 @@ "HeaderLibraries": "المكتبات", "HeaderLibraryAccess": "صلاحيات المكتبة", "HeaderLibraryFolders": "مجلدات الوسائط", - "HeaderLiveTV": "التلفاز المباشر", - "HeaderLiveTv": "التلفاز المباشر", "HeaderLoginFailure": "فشل في تسجيل الدخول", "HeaderMedia": "الوسائط", "HeaderMediaFolders": "مجلدات الوسائط", @@ -193,13 +191,11 @@ "HeaderMusicVideos": "الفيديوهات الموسيقية", "HeaderMyMedia": "وسائطي", "HeaderNewApiKey": "مفتاح API جديد", - "HeaderNextUp": "التالي", "HeaderOtherItems": "عناصر أخرى", "HeaderParentalRatings": "التصنيف الأبوي", "HeaderPassword": "كلمة السر", "HeaderPasswordReset": "إعادة تهيئة كلمة السر", "HeaderPaths": "مسارات", - "HeaderPeople": "الناس", "HeaderPinCodeReset": "أعد تهيئة الرمز الشخصي", "HeaderPlayAll": "تشغيل الكل", "HeaderPlayback": "تشغيل الوسائط", @@ -220,7 +216,6 @@ "HeaderRevisionHistory": "تاريخ المراجعات", "HeaderRunningTasks": "المهام المشغّلة", "HeaderScenes": "المشاهد", - "HeaderSchedule": "الجدول", "HeaderSeasons": "المواسم", "HeaderSelectCertificatePath": "إختر مسار الشهادة", "HeaderSelectMetadataPath": "إختر مسار واصفات البيانات", @@ -232,7 +227,6 @@ "HeaderSelectTranscodingPath": "إختر المسار المؤقت للتشفير البيني", "HeaderSelectTranscodingPathHelp": "تصفح أو أدخل المسار الذي ترغب أن يُستخدم لملفات التشفير البيني. يجب أن يكون هذا المجلد قابل للكتابة فيه.", "HeaderSendMessage": "أرسل رسالة", - "HeaderSeries": "المسلسلات", "HeaderServerSettings": "إعدادات الخادم", "HeaderSettings": "الإعدادات", "HeaderSetupLibrary": "ضبط مكتبة المحتوى الخاصة بك", @@ -669,7 +663,6 @@ "OptionExternallyDownloaded": "الإنزال من الخارج", "OptionExtractChapterImage": "تفعيل استخلاص صور الأبواب", "OptionFavorite": "المفضلات", - "OptionFriday": "الجمعة", "OptionHasSpecialFeatures": "المحتويات الخاصة", "OptionHasSubtitles": "الترجمة", "OptionHasThemeSong": "أغنية الشارة", @@ -687,10 +680,8 @@ "OptionLikes": "المحببات", "OptionMax": "الحد الأقصى", "OptionMissingEpisode": "حلفة مفقودة", - "OptionMonday": "الأثنين", "OptionNameSort": "الاسم", "OptionNone": "لا شيء", - "OptionOnAppStartup": "بناء على تشغيل الخادم", "OptionOnInterval": "بناء على فترة", "OptionParentalRating": "التصنيف الأبوي", "OptionPlainStorageFolders": "غرض جميع المجلدات كمجلدات تخزين بسيطة", @@ -712,19 +703,14 @@ "OptionResElement": "عناصر res", "OptionResumable": "إمكانية التكملة", "OptionRuntime": "زمن التشغيل", - "OptionSaturday": "السبت", "OptionSaveMetadataAsHidden": "حفظ واصفات البيانات والصور كملفات مخفية", "OptionSaveMetadataAsHiddenHelp": "إن تغيير هذه سيطبق على واصفات البيانات الجديدة من الآن. أما واصفات البيانات الموجودة مسبقاً، فهي ستحدث من قبل الخادم في المرة القادمة التي يتم حفظها.", "OptionSpecialEpisode": "حصريات", - "OptionSunday": "الأحد", - "OptionThursday": "الخميس", "OptionTrackName": "اسم المقطوعة", - "OptionTuesday": "الثلاثاء", "OptionTvdbRating": "تقييم Tvdb", "OptionUnairedEpisode": "حلفة لم تبثّ", "OptionUnplayed": "غير معزوف", "OptionWakeFromSleep": "استيقظ من السبات", - "OptionWednesday": "الأربعاء", "OptionWeekdays": "أيام الأسبوع", "OptionWeekends": "أيام العطلة", "OptionWeekly": "أسبوعي", @@ -772,7 +758,6 @@ "TabEpisodes": "الحلقات", "TabInfo": "معلومات", "TabLatest": "الاخير", - "TabLiveTV": "التلفاز المباشر", "TabLogs": "الكشوفات", "TabMusic": "الموسيقى", "TabMusicVideos": "الفيديوهات الموسيقية", @@ -782,22 +767,17 @@ "TabNotifications": "إشعارات", "TabOther": "أخرى", "TabParentalControl": "التحكم الأبوي", - "TabPassword": "كلمة السر", - "TabPlaylists": "قوائم التشغيل", "TabPlugins": "الملحقات", "TabProfile": "عريضة", "TabProfiles": "الحسابات", - "TabRecordings": "المقاطع المسجلة", "TabResponses": "الردود", "TabResumeSettings": "استئناف الإعدادات", "TabScheduledTasks": "المهام المجدولة", - "TabSeries": "المسلسلات", "TabServer": "الخادم", "TabSettings": "الإعدادات", "TabStreaming": "التشغيل التدفقي", "TabTrailers": "العروض الإعلانية", "TabUpcoming": "القادم", - "TabUsers": "المستخدمون", "TellUsAboutYourself": "اخبرنا عن نفسك", "ThisWizardWillGuideYou": "مرشد الاعدادات سيساعدك خلال خطوات عملية الاعدادات. للبدء، الرجاء اختيار لغتك المفضلة.", "Thursday": "الخميس", diff --git a/src/strings/bg-bg.json b/src/strings/bg-bg.json index 4ab46a6eab..1cc469a9fd 100644 --- a/src/strings/bg-bg.json +++ b/src/strings/bg-bg.json @@ -180,8 +180,6 @@ "HeaderLibraryFolders": "Папки на библиотеката", "HeaderLibraryOrder": "Подредба на библиотеката", "HeaderLibrarySettings": "Настройки на библиотеката", - "HeaderLiveTV": "Телевизия на живо", - "HeaderLiveTv": "Телевизия на живо", "HeaderMedia": "Медия", "HeaderMediaFolders": "Медийни папки", "HeaderMediaInfo": "Сведения", @@ -195,12 +193,10 @@ "HeaderNewApiKey": "Нов ППИ ключ", "HeaderNewDevices": "Нови устройства", "HeaderNextEpisodePlayingInValue": "Следващият епизод ще се пусне след {0}", - "HeaderNextUp": "Следва", "HeaderOnNow": "На живо сега", "HeaderParentalRatings": "Родителска оценка", "HeaderPassword": "Парола", "HeaderPaths": "Пътища", - "HeaderPeople": "Хора", "HeaderPlayAll": "Пускане на всичко", "HeaderPlayOn": "Пускане на", "HeaderPleaseSignIn": "Моля, влезте", @@ -216,12 +212,10 @@ "HeaderRevisionHistory": "Списък с промени", "HeaderRunningTasks": "Изпълняващи се задачи", "HeaderScenes": "Сцени", - "HeaderSchedule": "Разписание", "HeaderSeasons": "Сезони", "HeaderSecondsValue": "{0} секунди", "HeaderSelectPath": "Изберете път", "HeaderSendMessage": "Изпращане на съобщение", - "HeaderSeries": "Сериал", "HeaderServerSettings": "Настройки на сървъра", "HeaderSettings": "Настройки", "HeaderSetupLibrary": "Настройте своите медийни библиотеки", @@ -530,7 +524,6 @@ "OptionEveryday": "Всеки ден", "OptionExternallyDownloaded": "Външно сваляне", "OptionFavorite": "Любими", - "OptionFriday": "Петък", "OptionHasSpecialFeatures": "Специални функции", "OptionHasSubtitles": "Субтитри", "OptionHasThemeSong": "Фонова песен", @@ -544,11 +537,9 @@ "OptionIsSD": "СК", "OptionLikes": "Харесвания", "OptionMissingEpisode": "Липсващи епизоди", - "OptionMonday": "Понеделник", "OptionNameSort": "Име", "OptionNew": "Нов…", "OptionNone": "Нищо", - "OptionOnAppStartup": "Като се стартира приложението", "OptionOnInterval": "През интервал", "OptionParentalRating": "Родителска оценка", "OptionPlainStorageFolders": "Показвай всички папки като папки за обикновено съхранение", @@ -564,16 +555,11 @@ "OptionRequirePerfectSubtitleMatch": "Да се изтеглят само субтитри, които пасват идеално на файловете ми", "OptionResumable": "Възобновляемост", "OptionRuntime": "Времетраене", - "OptionSaturday": "Събота", "OptionSpecialEpisode": "Специални", - "OptionSunday": "Неделя", - "OptionThursday": "Четвъртък", "OptionTrackName": "Име на песента", - "OptionTuesday": "Вторник", "OptionUnairedEpisode": "Неизлъчени епизоди", "OptionUnplayed": "Непускано", "OptionWakeFromSleep": "Събуждане от сън", - "OptionWednesday": "Сряда", "OptionWeekly": "Ежеседмично", "OriginalAirDateValue": "Дата на първоначално излъчване: {0}", "Overview": "Обобщение", @@ -657,7 +643,6 @@ "TabEpisodes": "Епизоди", "TabInfo": "Информация", "TabLatest": "Последни", - "TabLiveTV": "Телевизия на живо", "TabLogs": "Журнали", "TabMusic": "Музика", "TabMusicVideos": "Музикални клипове", @@ -667,22 +652,17 @@ "TabNotifications": "Известия", "TabOther": "Други", "TabParentalControl": "Родителски контрол", - "TabPassword": "Парола", - "TabPlaylists": "Списъци", "TabPlugins": "Приставки", "TabProfile": "Профил", "TabProfiles": "Профили", - "TabRecordings": "Записи", "TabResponses": "Отговори", "TabResumeSettings": "Възобнови", "TabScheduledTasks": "Планирани задачи", - "TabSeries": "Сериали", "TabServer": "Сървър", "TabSettings": "Настройки", "TabStreaming": "Излъчване", "TabTrailers": "Трейлъри", "TabUpcoming": "Предстоящи", - "TabUsers": "Потребители", "Tags": "Етикети", "TagsValue": "Етикети: {0}", "TellUsAboutYourself": "Разкажете за себе си", diff --git a/src/strings/ca.json b/src/strings/ca.json index c5f7f2d6de..413fef4792 100644 --- a/src/strings/ca.json +++ b/src/strings/ca.json @@ -172,8 +172,6 @@ "HeaderLibraryFolders": "Directoris de la Llibreria", "HeaderLibraryOrder": "Ordre de la llibreria", "HeaderLibrarySettings": "Preferències de la Biblioteca", - "HeaderLiveTV": "TV en Directe", - "HeaderLiveTv": "TV en Directe", "HeaderMediaFolders": "Directoris Multimèdia", "HeaderMediaInfo": "Info Multimèdia", "HeaderMetadataSettings": "Preferències de Metadades", @@ -183,14 +181,12 @@ "HeaderMyMediaSmall": "Els meus mitjans (petit)", "HeaderNewApiKey": "Nova Clau Api", "HeaderNextEpisodePlayingInValue": "Reproduint proper episodi en {0}", - "HeaderNextUp": "A continuació", "HeaderNextVideoPlayingInValue": "Reproduint proper vídeo en {0}", "HeaderOnNow": "En Directe Ara", "HeaderParentalRatings": "Classificacions Parentals", "HeaderPassword": "Contrasenya", "HeaderPasswordReset": "Reiniciar Contrasenya", "HeaderPaths": "Directoris", - "HeaderPeople": "Gent", "HeaderPlayAll": "Reprodueix Tot", "HeaderPlaybackError": "Error de Reproducció", "HeaderPleaseSignIn": "Si et plau, inicia sessió", @@ -204,12 +200,10 @@ "HeaderRestart": "Reiniciar", "HeaderRunningTasks": "Tasques Corrent", "HeaderScenes": "Escenes", - "HeaderSchedule": "Horari", "HeaderSeasons": "Temporades", "HeaderSecondsValue": "{0} segons", "HeaderSelectServer": "Seleccionar Servidor", "HeaderSendMessage": "Enviar Missatge", - "HeaderSeries": "Sèries:", "HeaderSeriesOptions": "Opcions de Sèries", "HeaderServerSettings": "Preferències del Servidor", "HeaderSettings": "Preferències", @@ -511,7 +505,6 @@ "OptionEveryday": "Cada dia", "OptionExternallyDownloaded": "Descàrrega externa", "OptionFavorite": "Preferits", - "OptionFriday": "Divendres", "OptionHasSpecialFeatures": "Característiques Especials", "OptionHasSubtitles": "Subtítols", "OptionHasThemeSong": "Cançó Temàtica", @@ -523,11 +516,9 @@ "OptionImdbRating": "Qualificació IMDb", "OptionLikes": "M'agrada", "OptionMissingEpisode": "Episodis Perduts", - "OptionMonday": "Dilluns", "OptionNameSort": "Nom", "OptionNew": "Nou...", "OptionNone": "Cap", - "OptionOnAppStartup": "En arrencar l'aplicació", "OptionOnInterval": "En un interval", "OptionParentalRating": "Classificació Parental", "OptionPlayCount": "Nombre de Reproduccions", @@ -538,18 +529,13 @@ "OptionReleaseDate": "Data de Publicació", "OptionResumable": "Continuable", "OptionRuntime": "Temps d'exec.", - "OptionSaturday": "Dissabte", "OptionSaveMetadataAsHidden": "Desa les metadades i les imatges com a fitxers ocults", "OptionSpecialEpisode": "Especials", "OptionSubstring": "Subcadena", - "OptionSunday": "Diumenge", - "OptionThursday": "Dijous", - "OptionTuesday": "Dimarts", "OptionTvdbRating": "Valoració TVDB", "OptionUnairedEpisode": "Episodis No Emesos", "OptionUnplayed": "No reproduït", "OptionWakeFromSleep": "Despertar", - "OptionWednesday": "Dimecres", "OptionWeekdays": "Entre setmana", "OptionWeekends": "Cap de setmana", "OptionWeekly": "Setmanal", @@ -624,7 +610,6 @@ "TabEpisodes": "Episodis", "TabInfo": "Informació", "TabLatest": "Novetats", - "TabLiveTV": "TV en Directe", "TabMusic": "Música", "TabMusicVideos": "Vídeos musicals", "TabMyPlugins": "Els meus complements", @@ -633,20 +618,15 @@ "TabNotifications": "Notificacions", "TabOther": "Altres", "TabParentalControl": "Control Parental", - "TabPassword": "Contrasenya", - "TabPlaylists": "Llistes de reproducció", "TabPlugins": "Complements", "TabProfile": "Perfil", "TabProfiles": "Perfils", - "TabRecordings": "Enregistraments", "TabResponses": "Respostes", "TabScheduledTasks": "Tasques Programades", - "TabSeries": "Sèries", "TabServer": "Servidor", "TabSettings": "Preferències", "TabTrailers": "Tràilers", "TabUpcoming": "Properament", - "TabUsers": "Usuaris", "Tags": "Etiquetes", "TellUsAboutYourself": "Explica'ns sobre tu", "TheseSettingsAffectSubtitlesOnThisDevice": "Aquestes preferències afecten els subtítols d'aquest dispositiu", diff --git a/src/strings/cs.json b/src/strings/cs.json index daa4573874..d796f36a43 100644 --- a/src/strings/cs.json +++ b/src/strings/cs.json @@ -293,7 +293,6 @@ "HeaderMyMediaSmall": "Moje média (malé)", "HeaderNewApiKey": "Nový klíč API", "HeaderNextEpisodePlayingInValue": "Přehrávání další epizody za {0}", - "HeaderNextUp": "Nadcházející", "HeaderNextVideoPlayingInValue": "Přehrávání dalšího videa za {0}", "HeaderOnNow": "Právě teď", "HeaderOtherItems": "Další položky", @@ -301,7 +300,6 @@ "HeaderPassword": "Heslo", "HeaderPasswordReset": "Obnova hesla", "HeaderPaths": "Cesty", - "HeaderPeople": "Lidé", "HeaderPinCodeReset": "Obnovit Pin kód", "HeaderPlayAll": "Přehrát vše", "HeaderPlayback": "Přehrání média", @@ -323,7 +321,6 @@ "HeaderRevisionHistory": "Historie verzí", "HeaderRunningTasks": "Běžící úlohy", "HeaderScenes": "Scény", - "HeaderSchedule": "Naplánování úlohy", "HeaderSeasons": "Sezóny", "HeaderSecondsValue": "{0} sekund", "HeaderSelectCertificatePath": "Vyber cestu k certifikátu", @@ -336,7 +333,6 @@ "HeaderSelectTranscodingPath": "Zvolte dočasnou složku pro překódovávání médií", "HeaderSelectTranscodingPathHelp": "Vyberte nebo zadejte složku pro soubory překódování. Složka musí být zapisovatelná.", "HeaderSendMessage": "Poslat zprávu", - "HeaderSeries": "Seriál", "HeaderSeriesOptions": "Nastavení seriálu", "HeaderServerSettings": "Nastavení serveru", "HeaderSettings": "Nastavení", @@ -856,7 +852,6 @@ "OptionExternallyDownloaded": "Externí stažení", "OptionExtractChapterImage": "Povolit extrakci obrázků z videa", "OptionFavorite": "Oblíbené", - "OptionFriday": "Pátek", "OptionHasSpecialFeatures": "Speciální funkce", "OptionHasSubtitles": "Titulky", "OptionHasThemeSong": "Tematická hudba", @@ -871,11 +866,9 @@ "OptionImdbRating": "Hodnocení IMDb", "OptionLikes": "Líbí se", "OptionMissingEpisode": "Chybějící episody", - "OptionMonday": "Pondělí", "OptionNameSort": "Název", "OptionNew": "Nový…", "OptionNone": "Žádný", - "OptionOnAppStartup": "Při spuštění aplikace", "OptionOnInterval": "V intervalu", "OptionParentalRating": "Rodičovské hodnocení", "OptionPlainStorageFolders": "Zobrazit všechny složky jako obyčejné složky pro ukládání", @@ -894,20 +887,15 @@ "OptionResElement": "Prvek \"res\"", "OptionResumable": "Pozastavavitelný", "OptionRuntime": "Délka", - "OptionSaturday": "Sobota", "OptionSaveMetadataAsHidden": "Ukládat metadata a obrázky jako skryté soubory", "OptionSaveMetadataAsHiddenHelp": "Změna se projeví u všech nově uložených metadat. Existující soubory metadat se aktualizují při příštím uložení serverem.", "OptionSpecialEpisode": "Speciální", "OptionSubstring": "subřetězec", - "OptionSunday": "Neděle", - "OptionThursday": "Čtvrtek", "OptionTrackName": "Název skladby", - "OptionTuesday": "Úterý", "OptionTvdbRating": "Tvdb hodnocení", "OptionUnairedEpisode": "Neodvysílané epizody", "OptionUnplayed": "Neshlédnuto", "OptionWakeFromSleep": "Probuzení ze spánku", - "OptionWednesday": "Středa", "OptionWeekdays": "Pracovní dny", "OptionWeekends": "Víkendy", "OptionWeekly": "Týdenní", @@ -1042,21 +1030,16 @@ "TabNotifications": "Oznámení", "TabOther": "Další", "TabParentalControl": "Rodičovská kontrola", - "TabPassword": "Heslo", - "TabPlaylists": "Playlisty", "TabPlugins": "Zásuvné moduly", "TabProfile": "Profil", "TabProfiles": "Profily", - "TabRecordings": "Nahrané", "TabResponses": "Odpovědi", "TabResumeSettings": "Obnovit", "TabScheduledTasks": "Naplánované úlohy", - "TabSeries": "Série", "TabSettings": "Nastavení", "TabStreaming": "Streamování", "TabTrailers": "Upoutávky", "TabUpcoming": "Nadcházející", - "TabUsers": "Uživatelé", "Tags": "Tagy", "TellUsAboutYourself": "Řekněte nám něco o sobě", "TheseSettingsAffectSubtitlesOnThisDevice": "Tato nastavení ovlivní titulky na tomto zařízení", @@ -1176,8 +1159,6 @@ "HeaderFetcherSettings": "Nastavení načítání", "HeaderImageOptions": "Volby obrázku", "HeaderKodiMetadataHelp": "Chcete-li povolit nebo zakázat metadata v souborech NFO, upravte nastavení knihovny v sekci ukládání metadat.", - "HeaderLiveTV": "Televize", - "HeaderLiveTv": "Televize", "HeaderLiveTvTunerSetup": "Nastavení televizního tuneru", "HeaderNewDevices": "Nové zařízení", "HeaderPhotoAlbums": "Fotoalba", @@ -1316,7 +1297,6 @@ "TV": "TV", "TabDirectPlay": "Přímé přehrávání", "TabInfo": "Info", - "TabLiveTV": "Televize", "TabServer": "Server", "TagsValue": "Tagy: {0}", "ThemeSongs": "Tematická hudba", diff --git a/src/strings/da.json b/src/strings/da.json index e5c8655645..20e237c7fe 100644 --- a/src/strings/da.json +++ b/src/strings/da.json @@ -261,14 +261,12 @@ "HeaderMyMedia": "Mine medier", "HeaderNewApiKey": "Ny API Nøgle", "HeaderNewDevices": "Nye Enheder", - "HeaderNextUp": "Næste", "HeaderOnNow": "Vises Nu", "HeaderOtherItems": "Andre elementer", "HeaderParentalRatings": "Aldersgrænser", "HeaderPassword": "Adgangskode", "HeaderPasswordReset": "Nulstil adgangskode", "HeaderPaths": "Stier", - "HeaderPeople": "Mennesker", "HeaderPinCodeReset": "Nulstil pinkode", "HeaderPlayAll": "Afspil Alle", "HeaderPlayback": "Medieafspilning", @@ -291,7 +289,6 @@ "HeaderRevisionHistory": "Revisionshistorik", "HeaderRunningTasks": "Kørende opgaver", "HeaderScenes": "Scener", - "HeaderSchedule": "Skema", "HeaderSeasons": "Sæsoner", "HeaderSelectCertificatePath": "Vælg certifikatsti", "HeaderSelectMetadataPath": "Vælg Metadata Path", @@ -303,7 +300,6 @@ "HeaderSelectTranscodingPath": "Vælg \"Transcoding Temporary Path\"", "HeaderSelectTranscodingPathHelp": "Vælg eller indtast stien som skal benyttes til midlertidige transkodningsfiler. Mappen må ikke være skrivebeskyttet.", "HeaderSendMessage": "Send besked", - "HeaderSeries": "Series", "HeaderSeriesOptions": "Serieindstillinger", "HeaderServerSettings": "Serverindstillinger", "HeaderSettings": "Indstillinger", @@ -789,7 +785,6 @@ "OptionExternallyDownloaded": "Ekstern hentning", "OptionExtractChapterImage": "Aktiver udvinding af kapitelbillede", "OptionFavorite": "Favoritter", - "OptionFriday": "Fredag", "OptionHasSpecialFeatures": "Specielle egenskaber", "OptionHasSubtitles": "Undertekster", "OptionHasThemeSong": "Temasang", @@ -803,11 +798,9 @@ "OptionImdbRating": "IMDB bedømmelse", "OptionMax": "Maks", "OptionMissingEpisode": "Manglende episoder", - "OptionMonday": "Mandag", "OptionNameSort": "Navn", "OptionNew": "Ny...", "OptionNone": "Ingen", - "OptionOnAppStartup": "Ved opstart", "OptionOnInterval": "Interval", "OptionParentalRating": "Aldersgrænse", "OptionPlainStorageFolders": "Vis alle mapper som standardmapper", @@ -826,20 +819,15 @@ "OptionRequirePerfectSubtitleMatch": "Download kun undertekster der er perfekte matches for mine videofiler", "OptionResumable": "Kan genoptages", "OptionRuntime": "Varighed", - "OptionSaturday": "Lørdag", "OptionSaveMetadataAsHidden": "Gem metadata og billeder som skjulte filer", "OptionSaveMetadataAsHiddenHelp": "Ændring af dette vil blive anvendt på nyt metadata gemt fremadrettet. Allerede eksisterende metadata-filer opdateres næste gang de gemmes af Jellyfin Server.", "OptionSpecialEpisode": "Særudsendelser", "OptionSubstring": "Delstreng", - "OptionSunday": "Søndag", - "OptionThursday": "Torsdag", "OptionTrackName": "Nummerets navn", - "OptionTuesday": "Tirsdag", "OptionTvdbRating": "TVDB bedømmelse", "OptionUnairedEpisode": "Ikke sendte episoder", "OptionUnplayed": "Ikke afspillet", "OptionWakeFromSleep": "Vågner fra dvale", - "OptionWednesday": "Onsdag", "OptionWeekdays": "Hverdage", "OptionWeekends": "Weekender", "OptionWeekly": "Ugentlig", @@ -958,20 +946,15 @@ "TabNotifications": "Underretninger", "TabOther": "Andet", "TabParentalControl": "Forældrekontrol", - "TabPassword": "Adgangskode", - "TabPlaylists": "Afspilningslister", "TabPlugins": "Tilføjelser", "TabProfile": "Profil", "TabProfiles": "Profiler", - "TabRecordings": "Optagelser", "TabResponses": "Svar", "TabResumeSettings": "Genoptag", "TabScheduledTasks": "Planlagte opgaver", - "TabSeries": "Serier", "TabSettings": "Indstillinger", "TabTrailers": "Trailere", "TabUpcoming": "Kommende", - "TabUsers": "Brugere", "TellUsAboutYourself": "Fortæl os lidt om dig selv", "ThisWizardWillGuideYou": "Denne guide vil hjælpe dig igennem opsætningen. For at begynde, vælg venligst dit fortrukne sprog.", "Thursday": "Torsdag", @@ -1031,7 +1014,6 @@ "AllLanguages": "Alle sprog", "AlwaysPlaySubtitles": "Afspil Altid", "AlwaysPlaySubtitlesHelp": "Undertekster, der matcher dine sprogindstillinger, vil altid blive indlæst uanset lydsprog.", - "HeaderLiveTV": "Live-TV", "Shows": "Serier", "Songs": "Sange", "AnyLanguage": "Hvilken som helst sprog", @@ -1115,7 +1097,6 @@ "HeaderDownloadSync": "Hentning Og Sync", "HeaderFavoritePlaylists": "Favorit Afspilningslister", "HeaderLibraryOrder": "Bibliotektsorden", - "HeaderLiveTv": "Live TV", "HeaderMusicQuality": "Musik Kvalitet", "HeaderMyMediaSmall": "Mine Medier (lille)", "HeaderNavigation": "Navigation", @@ -1280,7 +1261,6 @@ "TV": "TV", "TabCodecs": "Codeks", "TabInfo": "Information", - "TabLiveTV": "Live TV", "TabLogs": "Log", "TabServer": "Server", "TabStreaming": "Streamer", diff --git a/src/strings/de.json b/src/strings/de.json index 2e28c73d2f..84a34bc9cf 100644 --- a/src/strings/de.json +++ b/src/strings/de.json @@ -316,8 +316,6 @@ "HeaderLibraryFolders": "Bibliotheksverzeichnisse", "HeaderLibraryOrder": "Bibliotheksreihenfolge", "HeaderLibrarySettings": "Bibliothekseinstellungen", - "HeaderLiveTV": "Live TV", - "HeaderLiveTv": "Live-TV", "HeaderLiveTvTunerSetup": "TV Tuner Setup", "HeaderLoginFailure": "Login Fehler", "HeaderMedia": "Medien", @@ -333,7 +331,6 @@ "HeaderNewApiKey": "Neuer API-Schlüssel", "HeaderNewDevices": "Neue Geräte", "HeaderNextEpisodePlayingInValue": "Nächste Episode wird abgespielt in {0}", - "HeaderNextUp": "Als Nächstes", "HeaderNextVideoPlayingInValue": "Nächstes Video wird abgespielt in {0}", "HeaderOnNow": "Gerade läuft", "HeaderOtherItems": "Andere Inhalte", @@ -341,7 +338,6 @@ "HeaderPassword": "Passwort", "HeaderPasswordReset": "Passwort zurücksetzen", "HeaderPaths": "Pfade", - "HeaderPeople": "Personen", "HeaderPhotoAlbums": "Fotoalben", "HeaderPinCodeReset": "PIN Code zurücksetzen", "HeaderPlayAll": "Alle abspielen", @@ -365,7 +361,6 @@ "HeaderRevisionHistory": "Versionsverlauf", "HeaderRunningTasks": "Laufende Aufgaben", "HeaderScenes": "Szenen", - "HeaderSchedule": "Zeitplan", "HeaderSeasons": "Staffeln", "HeaderSecondsValue": "{0} Sekunden", "HeaderSelectCertificatePath": "Wählen Sie einen Zertifikat Ordner", @@ -378,7 +373,6 @@ "HeaderSelectTranscodingPath": "Wähle Pfad für temporäre Transkodierdateien", "HeaderSelectTranscodingPathHelp": "Suche oder gib den Pfad für die Speicherung Transkodierdateien an. Das Verzeichnis muss beschreibbar sein.", "HeaderSendMessage": "Nachricht senden", - "HeaderSeries": "Serien", "HeaderSeriesOptions": "Serienoptionen", "HeaderSeriesStatus": "Serienstatus", "HeaderServerSettings": "Server Einstellungen", @@ -926,7 +920,6 @@ "OptionExternallyDownloaded": "Externer Download", "OptionExtractChapterImage": "Aktiviere Kapitelbild-Extrahierung", "OptionFavorite": "Favoriten", - "OptionFriday": "Freitag", "OptionHasSpecialFeatures": "Besonderes Merkmal", "OptionHasSubtitles": "Untertitel", "OptionHasThemeSong": "Titellied", @@ -940,10 +933,8 @@ "OptionImdbRating": "IMDb Bewertung", "OptionLikes": "Mag ich", "OptionMissingEpisode": "Fehlende Episoden", - "OptionMonday": "Montag", "OptionNew": "Neu…", "OptionNone": "Keines", - "OptionOnAppStartup": "Bei Anwendungsstart", "OptionOnInterval": "Nach einem Intervall", "OptionParentalRating": "Altersfreigabe", "OptionPlainStorageFolders": "Zeige alle Verzeichnisse als reine Speicherorte an", @@ -961,17 +952,12 @@ "OptionResElement": "Res Element", "OptionResumable": "Fortsetzen", "OptionRuntime": "Dauer", - "OptionSaturday": "Samstag", "OptionSaveMetadataAsHidden": "Speichere Metadaten und Bilder als versteckte Dateien", "OptionSaveMetadataAsHiddenHelp": "Änderungen werden sich auf neue Metadaten angewendet. Bereits existierende Metadaten werden bei der nächsten Speicherung des Servers auf den neusten Stand gebracht.", - "OptionSunday": "Sonntag", - "OptionThursday": "Donnerstag", - "OptionTuesday": "Dienstag", "OptionTvdbRating": "TVDB Bewertung", "OptionUnairedEpisode": "Nicht ausgestrahlte Episoden", "OptionUnplayed": "Ungesehen", "OptionWakeFromSleep": "Aufwachen nach dem Schlafen", - "OptionWednesday": "Mittwoch", "OptionWeekdays": "Wöchentlich", "OptionWeekends": "An Wochenenden", "OptionWeekly": "Wöchentlich", @@ -1113,7 +1099,6 @@ "TabDirectPlay": "Direktwiedergabe", "TabEpisodes": "Episoden", "TabLatest": "Neueste", - "TabLiveTV": "Live-TV", "TabMusic": "Musik", "TabMusicVideos": "Musikvideos", "TabMyPlugins": "Meine Plugins", @@ -1122,19 +1107,14 @@ "TabNotifications": "Benachrichtigungen", "TabOther": "Andere", "TabParentalControl": "Kindersicherung", - "TabPassword": "Passwort", - "TabPlaylists": "Wiedergabelisten", "TabProfile": "Profil", "TabProfiles": "Profile", - "TabRecordings": "Aufnahmen", "TabResponses": "Antworten", "TabResumeSettings": "Fortsetzen", "TabScheduledTasks": "Geplante Aufgaben", - "TabSeries": "Serie", "TabSettings": "Einstellungen", "TabTrailers": "Trailer", "TabUpcoming": "Bevorstehend", - "TabUsers": "Benutzer", "TellUsAboutYourself": "Sagen Sie uns etwas über sich selbst", "ThemeSongs": "Titelsongs", "ThemeVideos": "Titelvideos", diff --git a/src/strings/el.json b/src/strings/el.json index 1a15e1b994..56d19b0c4a 100644 --- a/src/strings/el.json +++ b/src/strings/el.json @@ -298,8 +298,6 @@ "HeaderLibraryFolders": "Φάκελος βιβλιοθηκών", "HeaderLibraryOrder": "Διάταξη Βιβλιοθήκης", "HeaderLibrarySettings": "Ρυθμίσεις Βιβλιοθήκης", - "HeaderLiveTV": "Ζωντανή Τηλεόραση", - "HeaderLiveTv": "ΖΩΝΤΑΝΗ ΤΗΛΕΩΡΑΣΗ", "HeaderLoginFailure": "Αποτυχία εισόδου", "HeaderMedia": "Πολυμέσα", "HeaderMediaFolders": "Φάκελοι Πολυμέσων", @@ -314,7 +312,6 @@ "HeaderNewApiKey": "Νέο κλειδί API", "HeaderNewDevices": "Νέες Συσκευές", "HeaderNextEpisodePlayingInValue": "Επόμενο επεισόδιο που θα παιχτεί σε {0}", - "HeaderNextUp": "Επόμενο", "HeaderNextVideoPlayingInValue": "Επόμενη αναπαραγωγή βίντεο σε {0}", "HeaderOnNow": "Τώρα", "HeaderOtherItems": "Άλλα Στοιχεία", @@ -343,12 +340,10 @@ "HeaderRevisionHistory": "Ιστορικό αναθεωρήσεων", "HeaderRunningTasks": "Προγραμματισμένες Εργασίες", "HeaderScenes": "Σκηνές", - "HeaderSchedule": "Πρόγραμμα", "HeaderSeasons": "Κύκλοι", "HeaderSecondsValue": "{0} δευτερόλεπτα", "HeaderSelectServer": "Επιλογή Διακομιστή", "HeaderSendMessage": "Αποστολή Μηνύματος", - "HeaderSeries": "Σειρές", "HeaderSeriesOptions": "Επιλογές Σειρών", "HeaderSeriesStatus": "Κατάσταση Σειράς", "HeaderServerSettings": "Ρυθμίσεις διακομιστή", @@ -827,7 +822,6 @@ "OptionEveryday": "Κάθε μέρα", "OptionExternallyDownloaded": "Εξωτερική λήψη", "OptionFavorite": "Αγαπημένα", - "OptionFriday": "Παρασκευή", "OptionHasSpecialFeatures": "Ειδικά Χαρακτηριστικά", "OptionHasSubtitles": "Υπότιτλοι", "OptionHasThemeSong": "Θεματικό Τραγούδι", @@ -840,11 +834,9 @@ "OptionLikes": "Συμπαθεί", "OptionMax": "Μέγιστο", "OptionMissingEpisode": "Ελλειπή Επεισόδια", - "OptionMonday": "Δευτέρα", "OptionNameSort": "Όνομα", "OptionNew": "Νέο...", "OptionNone": "Κανένα", - "OptionOnAppStartup": "Κατά την εκκίνηση της εφαρμογής", "OptionOnInterval": "Σε ένα διάστημα", "OptionParentalRating": "Αξιολόγηση γονέων", "OptionPlainStorageFolders": "Εμφάνιση όλων των φακέλων ως φακέλων απλού χώρου αποθήκευσης", @@ -858,18 +850,13 @@ "OptionProfileVideo": "Βίντεο", "OptionReleaseDate": "Ημερομηνία Προβολής", "OptionResumable": "Αναληπτέος", - "OptionSaturday": "Σάββατο", "OptionSaveMetadataAsHidden": "Αποθηκεύστε τα μεταδεδομένα και τις εικόνες ως κρυφά αρχεία", "OptionSubstring": "Υποσύνολο", - "OptionSunday": "Κυρ", - "OptionThursday": "Πέμπτη", "OptionTrackName": "Όνομα Αρχείου", - "OptionTuesday": "Τρίτη", "OptionTvdbRating": "Tvdb Βαθμολογία", "OptionUnairedEpisode": "Επεισόδια που δεν προβλήθηκαν", "OptionUnplayed": "Δεν παίχθηκε", "OptionWakeFromSleep": "Επανεργοποιήση", - "OptionWednesday": "Τετάρτη", "OptionWeekdays": "Καθημερινές", "OptionWeekends": "Σαββατοκύριακα", "OptionWeekly": "Εβδομαδιαία", @@ -1010,21 +997,16 @@ "TabNotifications": "Ειδοποιήσεις", "TabOther": "Άλλα", "TabParentalControl": "Γονικός έλεγχος", - "TabPassword": "Κωδικός", - "TabPlaylists": "Λίστες αναπαραγωγής", "TabPlugins": "Πρόσθετα", "TabProfile": "Προφίλ", "TabProfiles": "Προφίλ", - "TabRecordings": "Εγγραφές", "TabResponses": "Απαντήσεις", "TabScheduledTasks": "Προγραμματισμένες Εργασίες", - "TabSeries": "Σειρές", "TabServer": "Διακομιστής", "TabSettings": "Ρυθμισεις", "TabStreaming": "Ροή", "TabTrailers": "Τρέιλερς", "TabUpcoming": "Επερχόμενα", - "TabUsers": "Χρήστες", "Tags": "Ετικέτες", "TagsValue": "Ετικέτες: {0}", "TellUsAboutYourself": "Πείτε μας για εσάς", @@ -1098,7 +1080,6 @@ "HeaderSelectMetadataPath": "Επιλέξτε Διαδρομή Μεταδεδομένων", "HeaderSelectCertificatePath": "Επιλέξτε Διαδρομή Πιστοποιητικού", "HeaderRemoveMediaFolder": "Αφαίρεση Φακέλου Μέσων", - "HeaderPeople": "Πρόσωπα", "HeaderIdentification": "Ταυτοποίηση", "HeaderHome": "Αρχική", "HeaderGuideProviders": "Πάροχοι Δεδομένων Προγράμματος Τηλεόρασης", diff --git a/src/strings/en-gb.json b/src/strings/en-gb.json index 2714f21147..023475923e 100644 --- a/src/strings/en-gb.json +++ b/src/strings/en-gb.json @@ -39,8 +39,6 @@ "Genres": "Genres", "HeaderAlbumArtists": "Album Artists", "HeaderContinueWatching": "Continue Watching", - "HeaderLiveTV": "Live TV", - "HeaderNextUp": "Next Up", "Movies": "Movies", "Photos": "Photos", "Playlists": "Playlists", @@ -382,7 +380,6 @@ "HeaderLibraryFolders": "Library Folders", "HeaderLibraryOrder": "Library Order", "HeaderLibrarySettings": "Library Settings", - "HeaderLiveTv": "Live TV", "HeaderLiveTvTunerSetup": "Live TV Tuner Setup", "HeaderLoginFailure": "Login Failure", "HeaderMedia": "Media", @@ -445,11 +442,9 @@ "TheseSettingsAffectSubtitlesOnThisDevice": "These settings affect subtitles on this device", "TabSettings": "Settings", "TabServer": "Server", - "TabSeries": "Series", "TabScheduledTasks": "Scheduled Tasks", "TabResumeSettings": "Resume", "TabResponses": "Responses", - "TabRecordings": "Recordings", "TabOther": "Other", "TabNotifications": "Notifications", "TabNetworks": "Networks", @@ -570,20 +565,16 @@ "OptionWeekly": "Weekly", "OptionWeekends": "Weekends", "OptionWeekdays": "Weekdays", - "OptionWednesday": "Wednesday", "OptionWakeFromSleep": "Wake from sleep", "OptionUnplayed": "Unplayed", "OptionUnairedEpisode": "Unaired Episodes", "OptionTrackName": "Track Name", "OptionThumbCard": "Thumb card", "OptionThumb": "Thumb", - "OptionThursday": "Thursday", - "OptionSunday": "Sunday", "OptionSubstring": "Substring", "OptionSpecialEpisode": "Specials", "OptionSaveMetadataAsHiddenHelp": "Changing this will apply to new metadata saved going forward. Existing metadata files will be updated the next time they are saved by Jellyfin Server.", "OptionSaveMetadataAsHidden": "Save metadata and images as hidden files", - "OptionSaturday": "Saturday", "OptionRuntime": "Runtime", "OptionResumable": "Resumable", "OptionResElement": "res element", @@ -601,7 +592,6 @@ "OptionPlainStorageFoldersHelp": "If enabled, all folders are represented in DIDL as \"object.container.storageFolder\" instead of a more specific type, such as \"object.container.person.musicArtist\".", "OptionParentalRating": "Parental Rating", "OptionOnInterval": "On an interval", - "OptionOnAppStartup": "On application startup", "OptionNone": "None", "OptionNew": "New…", "OptionMissingEpisode": "Missing Episodes", @@ -885,7 +875,6 @@ "TellUsAboutYourself": "Tell us about yourself", "TagsValue": "Tags: {0}", "Tags": "Tags", - "TabUsers": "Users", "TabUpcoming": "Upcoming", "TabTrailers": "Trailers", "LabelDisplayMode": "Display mode:", @@ -898,10 +887,8 @@ "TabProfiles": "Profiles", "TabProfile": "Profile", "TabPlugins": "Plugins", - "TabPlaylists": "Playlists", "TabNfoSettings": "NFO Settings", "TabNetworking": "Networking", - "TabLiveTV": "Live TV", "TabLatest": "Latest", "TabInfo": "Info", "TabEpisodes": "Episodes", @@ -1217,7 +1204,6 @@ "OptionHasThemeSong": "Theme Song", "OptionHasSubtitles": "Subtitles", "OptionHasSpecialFeatures": "Special Features", - "OptionFriday": "Friday", "OptionExtractChapterImage": "Enable chapter image extraction", "OptionExternallyDownloaded": "External download", "OptionEquals": "Equals", @@ -1269,13 +1255,11 @@ "ValueOneMovie": "1 movie", "ValueOneEpisode": "1 episode", "ValueEpisodeCount": "{0} episodes", - "TabPassword": "Password", "TabParentalControl": "Parental Control", "SkipEpisodesAlreadyInMyLibraryHelp": "Episodes will be compared using season and episode numbers, when available.", "RefreshQueued": "Refresh queued.", "Play": "Play", "PasswordResetProviderHelp": "Choose a Password Reset Provider to be used when this user requests a password reset", - "OptionTuesday": "Tuesday", "OptionReleaseDate": "Release Date", "OptionDisplayFolderViewHelp": "Display folders alongside your other media libraries. This can be useful if you'd like to have a plain folder view.", "OptionDislikes": "Dislikes", @@ -1315,7 +1299,6 @@ "Save": "Save", "People": "People", "OptionNameSort": "Name", - "OptionMonday": "Monday", "MusicAlbum": "Music Album", "MessageNoCollectionsAvailable": "Collections allow you to enjoy personalized groupings of Movies, Series, and Albums. Click the + button to start creating collections.", "ShowTitle": "Show title", @@ -1331,7 +1314,6 @@ "HeaderServerSettings": "Server Settings", "HeaderSeriesStatus": "Series Status", "HeaderSeriesOptions": "Series Options", - "HeaderSeries": "Series", "HeaderSendMessage": "Send Message", "HeaderSelectTranscodingPathHelp": "Browse or enter the path to use for transcoding temporary files. The folder must be writeable.", "HeaderSubtitleDownloads": "Subtitle Downloads", @@ -1345,7 +1327,6 @@ "HeaderSelectCertificatePath": "Select Certificate Path", "HeaderSecondsValue": "{0} Seconds", "HeaderSeasons": "Seasons", - "HeaderSchedule": "Schedule", "HeaderScenes": "Scenes", "HeaderRunningTasks": "Running Tasks", "HeaderRevisionHistory": "Revision History", @@ -1369,7 +1350,6 @@ "HeaderPlayAll": "Play All", "HeaderPinCodeReset": "Reset Pin Code", "HeaderPhotoAlbums": "Photo Albums", - "HeaderPeople": "People", "HeaderHome": "Home", "HeaderFavoritePeople": "Favourite People", "FetchingData": "Fetching additional data", diff --git a/src/strings/en-us.json b/src/strings/en-us.json index 355ef9c96c..0f37014b76 100644 --- a/src/strings/en-us.json +++ b/src/strings/en-us.json @@ -379,8 +379,6 @@ "HeaderLibraryFolders": "Library Folders", "HeaderLibraryOrder": "Library Order", "HeaderLibrarySettings": "Library Settings", - "HeaderLiveTV": "Live TV", - "HeaderLiveTv": "Live TV", "HeaderLiveTvTunerSetup": "Live TV Tuner Setup", "HeaderLoginFailure": "Login Failure", "HeaderMedia": "Media", @@ -397,7 +395,6 @@ "HeaderNewApiKey": "New API Key", "HeaderNewDevices": "New Devices", "HeaderNextEpisodePlayingInValue": "Next Episode Playing in {0}", - "HeaderNextUp": "Next Up", "HeaderNextVideoPlayingInValue": "Next Video Playing in {0}", "HeaderOnNow": "On Now", "HeaderOtherItems": "Other Items", @@ -405,7 +402,6 @@ "HeaderPassword": "Password", "HeaderPasswordReset": "Password Reset", "HeaderPaths": "Paths", - "HeaderPeople": "People", "HeaderPhotoAlbums": "Photo Albums", "HeaderPinCodeReset": "Reset Pin Code", "HeaderPlayAll": "Play All", @@ -431,7 +427,6 @@ "HeaderRevisionHistory": "Revision History", "HeaderRunningTasks": "Running Tasks", "HeaderScenes": "Scenes", - "HeaderSchedule": "Schedule", "HeaderSeasons": "Seasons", "HeaderSecondsValue": "{0} Seconds", "HeaderSelectCertificatePath": "Select Certificate Path", @@ -444,7 +439,6 @@ "HeaderSelectTranscodingPath": "Select Transcoding Temporary Path", "HeaderSelectTranscodingPathHelp": "Browse or enter the path to use for transcode files. The folder must be writeable.", "HeaderSendMessage": "Send Message", - "HeaderSeries": "Series", "HeaderSeriesOptions": "Series Options", "HeaderSeriesStatus": "Series Status", "HeaderServerAddressSettings": "Server Address Settings", @@ -1139,7 +1133,6 @@ "OptionExternallyDownloaded": "External download", "OptionExtractChapterImage": "Enable chapter image extraction", "OptionFavorite": "Favorites", - "OptionFriday": "Friday", "OptionHasSpecialFeatures": "Special Features", "OptionHasSubtitles": "Subtitles", "OptionHasThemeSong": "Theme Song", @@ -1160,11 +1153,9 @@ "OptionLoginAttemptsBeforeLockoutHelp": "A value of zero means inheriting the default of three attempts for normal users and five for administrators. Setting this to -1 will disable the feature.", "OptionMax": "Max", "OptionMissingEpisode": "Missing Episodes", - "OptionMonday": "Monday", "OptionNameSort": "Name", "OptionNew": "New…", "OptionNone": "None", - "OptionOnAppStartup": "On application startup", "OptionOnInterval": "On an interval", "OptionParentalRating": "Parental Rating", "OptionPlainStorageFolders": "Display all folders as plain storage folders", @@ -1192,22 +1183,17 @@ "OptionResElement": "res element", "OptionResumable": "Resumable", "OptionRuntime": "Runtime", - "OptionSaturday": "Saturday", "OptionSaveMetadataAsHidden": "Save metadata and images as hidden files", "OptionSaveMetadataAsHiddenHelp": "Changing this will apply to new metadata saved going forward. Existing metadata files will be updated the next time they are saved by the server.", "OptionSpecialEpisode": "Specials", "OptionSubstring": "Substring", - "OptionSunday": "Sunday", - "OptionThursday": "Thursday", "OptionThumb": "Thumb", "OptionThumbCard": "Thumb card", "OptionTrackName": "Track Name", - "OptionTuesday": "Tuesday", "OptionTvdbRating": "TVDB Rating", "OptionUnairedEpisode": "Unaired Episodes", "OptionUnplayed": "Unplayed", "OptionWakeFromSleep": "Wake from sleep", - "OptionWednesday": "Wednesday", "OptionWeekdays": "Weekdays", "OptionWeekends": "Weekends", "OptionWeekly": "Weekly", @@ -1374,7 +1360,6 @@ "TabEpisodes": "Episodes", "TabInfo": "Info", "TabLatest": "Latest", - "TabLiveTV": "Live TV", "TabLogs": "Logs", "TabMusic": "Music", "TabMusicVideos": "Music Videos", @@ -1385,22 +1370,17 @@ "TabNotifications": "Notifications", "TabOther": "Other", "TabParentalControl": "Parental Control", - "TabPassword": "Password", - "TabPlaylists": "Playlists", "TabPlugins": "Plugins", "TabProfile": "Profile", "TabProfiles": "Profiles", - "TabRecordings": "Recordings", "TabResponses": "Responses", "TabResumeSettings": "Resume", "TabScheduledTasks": "Scheduled Tasks", - "TabSeries": "Series", "TabServer": "Server", "TabSettings": "Settings", "TabStreaming": "Streaming", "TabTrailers": "Trailers", "TabUpcoming": "Upcoming", - "TabUsers": "Users", "Tags": "Tags", "TagsValue": "Tags: {0}", "TellUsAboutYourself": "Tell us about yourself", diff --git a/src/strings/es-ar.json b/src/strings/es-ar.json index 0ae3654a9b..3ff15ab72b 100644 --- a/src/strings/es-ar.json +++ b/src/strings/es-ar.json @@ -5,8 +5,6 @@ "FolderTypeTvShows": "TV", "HeaderAddUser": "Agregar Usuario", "HeaderLatestEpisodes": "Últimos capítulos", - "HeaderLiveTV": "TV en vivo", - "HeaderSeries": "Series", "LabelDisplayMissingEpisodesWithinSeasons": "Mostrar capítulos no disponibles en temporadas", "LabelFinish": "Terminar", "LabelYoureDone": "Ha terminado!", @@ -35,7 +33,6 @@ "Genres": "Géneros", "HeaderAlbumArtists": "Artistas de álbum", "HeaderContinueWatching": "Seguir viendo", - "HeaderNextUp": "Siguiente", "Movies": "Películas", "Photos": "Fotos", "Playlists": "Listas de reproducción", @@ -373,7 +370,6 @@ "HeaderMedia": "Medios", "HeaderLoginFailure": "Error al iniciar sesión", "HeaderLiveTvTunerSetup": "Configuración del sintonizador de TV en vivo", - "HeaderLiveTv": "TV en vivo", "HeaderLibrarySettings": "Configuraciones de biblioteca", "HeaderLibraryOrder": "Orden de biblioteca", "HeaderLibraryFolders": "Carpetas de biblioteca", @@ -410,7 +406,6 @@ "HeaderPlayAll": "Reproducir todo", "HeaderPinCodeReset": "Restablecer código PIN", "HeaderPhotoAlbums": "Álbumes de fotos", - "HeaderPeople": "Personas", "HeaderPaths": "Rutas", "HeaderPasswordReset": "Restablecer contraseña", "HeaderPassword": "Contraseña", @@ -493,7 +488,6 @@ "HeaderSelectCertificatePath": "Seleccionar ruta del certificado", "HeaderSecondsValue": "{0} segundos", "HeaderSeasons": "Temporadas", - "HeaderSchedule": "Programación", "HeaderScenes": "Escenas", "HeaderRunningTasks": "Ejecución de tareas", "HeaderRevisionHistory": "Revisión histórica", @@ -1213,21 +1207,16 @@ "OptionWeekly": "Semanal", "OptionWeekends": "Fines de semana", "OptionWeekdays": "Días de la semana", - "OptionWednesday": "Miércoles", "OptionWakeFromSleep": "Despertarse del sueño", "OptionUnplayed": "No reproducido", "OptionTvdbRating": "Calificación de TVDB", - "OptionTuesday": "Martes", "OptionTrackName": "Nombre de la pista", "OptionThumbCard": "Tarjeta del pulgar", "OptionThumb": "Pulgar", - "OptionThursday": "Jueves", - "OptionSunday": "Domingo", "OptionSubstring": "Subcadena", "OptionSpecialEpisode": "Especiales", "OptionSaveMetadataAsHiddenHelp": "Cambiar esto se aplicará a los nuevos metadatos guardados en el futuro. Los archivos de metadatos existentes se actualizarán la próxima vez que el servidor Jellyfin los guarde.", "OptionSaveMetadataAsHidden": "Guardar metadatos e imágenes como archivos ocultos", - "OptionSaturday": "Sábado", "OptionRuntime": "Tiempo de ejecución", "OptionResumable": "Reanudable", "OptionResElement": "elemento res", @@ -1255,11 +1244,9 @@ "OptionPlainStorageFolders": "Mostrar todas las carpetas como carpetas de almacenamiento sin formato", "OptionParentalRating": "Calificación parental", "OptionOnInterval": "En un intervalo", - "OptionOnAppStartup": "En el inicio de la aplicación", "OptionNone": "Ninguno", "OptionNew": "Nuevo…", "OptionNameSort": "Nombre", - "OptionMonday": "Lunes", "OptionMax": "Máx.", "OptionLoginAttemptsBeforeLockoutHelp": "Un valor de cero significa heredar el valor predeterminado de tres intentos para usuarios normales y cinco para administradores. Establecer esto en -1 deshabilitará la función.", "OptionLoginAttemptsBeforeLockout": "Determina cuántos intentos de inicio de sesión incorrectos se pueden realizar antes de que ocurra el bloqueo.", @@ -1279,7 +1266,6 @@ "OptionHasThemeSong": "Tema musical", "OptionHasSubtitles": "Subtítulos", "OptionHasSpecialFeatures": "Características especiales", - "OptionFriday": "Viernes", "OptionFavorite": "Favoritos", "OptionExtractChapterImage": "Habilitar la extracción de imágenes de capítulos", "OptionExternallyDownloaded": "Descarga externa", @@ -1372,7 +1358,6 @@ "ThemeSongs": "Canciones temáticas", "TagsValue": "Etiquetas: {0}", "Tags": "Etiquetas", - "TabUsers": "Usuarios", "TabUpcoming": "Próximamente", "MarkUnplayed": "Marcar no reproducido", "MarkPlayed": "Marcar reproducido", @@ -1382,16 +1367,12 @@ "TabStreaming": "Transmisión", "TabSettings": "Configuraciones", "TabServer": "Servidor", - "TabSeries": "Series", "TabScheduledTasks": "Tareas programadas", "TabResumeSettings": "Continuar", "TabResponses": "Respuestas", - "TabRecordings": "Grabaciones", "TabProfiles": "Perfiles", "TabProfile": "Perfil", "TabPlugins": "Complementos", - "TabPlaylists": "Listas de reproducción", - "TabPassword": "Contraseña", "TabParentalControl": "Control parental", "TabOther": "Otro", "TabNotifications": "Notificaciones", @@ -1402,7 +1383,6 @@ "TabMusicVideos": "Videos musicales", "TabMusic": "Música", "TabLogs": "Registros", - "TabLiveTV": "TV en vivo", "TabLatest": "Último", "TabInfo": "Información", "TabDirectPlay": "Reproducción directa", diff --git a/src/strings/es-mx.json b/src/strings/es-mx.json index e682b2f4cb..c7669c4429 100644 --- a/src/strings/es-mx.json +++ b/src/strings/es-mx.json @@ -332,8 +332,6 @@ "HeaderLibraryFolders": "Carpetas de bibliotecas", "HeaderLibraryOrder": "Orden de las bibliotecas", "HeaderLibrarySettings": "Configuraciones de biblioteca", - "HeaderLiveTV": "TV en vivo", - "HeaderLiveTv": "TV en vivo", "HeaderLiveTvTunerSetup": "Configuración del sintonizador de TV", "HeaderLoginFailure": "Falló el inicio de sesión", "HeaderMedia": "Medios", @@ -349,7 +347,6 @@ "HeaderNewApiKey": "Nueva clave API", "HeaderNewDevices": "Nuevos dispositivos", "HeaderNextEpisodePlayingInValue": "El siguiente episodio se reproducirá en {0}", - "HeaderNextUp": "A continuación", "HeaderNextVideoPlayingInValue": "El siguiente video se reproducirá en {0}", "HeaderOnNow": "Transmitiendo ahora", "HeaderOtherItems": "Otros elementos", @@ -357,7 +354,6 @@ "HeaderPassword": "Contraseña", "HeaderPasswordReset": "Restablecer contraseña", "HeaderPaths": "Rutas", - "HeaderPeople": "Personas", "HeaderPhotoAlbums": "Álbumes de fotos", "HeaderPinCodeReset": "Restablecer código PIN", "HeaderPlayAll": "Reproducir todo", @@ -382,7 +378,6 @@ "HeaderRevisionHistory": "Historial de versiones", "HeaderRunningTasks": "Tareas en ejecución", "HeaderScenes": "Escenas", - "HeaderSchedule": "Programación", "HeaderSeasons": "Temporadas", "HeaderSecondsValue": "{0} segundos", "HeaderSelectCertificatePath": "Selecciona la ruta del certificado", @@ -395,7 +390,6 @@ "HeaderSelectTranscodingPath": "Selecciona la ruta para los archivos temporales de transcodificación", "HeaderSelectTranscodingPathHelp": "Explora o introduce la ruta a utilizar para los archivos temporales de transcodificación. Se debe tener permisos de escritura en dicha carpeta.", "HeaderSendMessage": "Enviar mensaje", - "HeaderSeries": "Series", "HeaderSeriesOptions": "Opciones de serie", "HeaderSeriesStatus": "Estado de la serie", "HeaderServerSettings": "Configuración del servidor", @@ -973,7 +967,6 @@ "OptionExternallyDownloaded": "Descarga externa", "OptionExtractChapterImage": "Habilitar la extracción de imágenes de los capítulos", "OptionFavorite": "Favoritos", - "OptionFriday": "Viernes", "OptionHasSpecialFeatures": "Características especiales", "OptionHasSubtitles": "Subtítulos", "OptionHasThemeSong": "Canción temática", @@ -989,11 +982,9 @@ "OptionLikes": "Me gusta", "OptionMax": "Máximo", "OptionMissingEpisode": "Episodios faltantes", - "OptionMonday": "Lunes", "OptionNameSort": "Nombre", "OptionNew": "Nuevo…", "OptionNone": "Ninguno", - "OptionOnAppStartup": "Al iniciar la aplicación", "OptionOnInterval": "En un intervalo", "OptionParentalRating": "Clasificación parental", "OptionPlainStorageFolders": "Mostrar todas las carpetas como carpetas de almacenamiento simples", @@ -1014,20 +1005,15 @@ "OptionResElement": "Elemento res", "OptionResumable": "Reanudable", "OptionRuntime": "Duración", - "OptionSaturday": "Sábado", "OptionSaveMetadataAsHidden": "Guardar metadatos e imágenes como archivos ocultos", "OptionSaveMetadataAsHiddenHelp": "Cambiar esto se aplicará a los nuevos metadatos guardados en el futuro. Los archivos de metadatos existentes serán actualizados la próxima vez que sean guardados por el servidor Jellyfin.", "OptionSpecialEpisode": "Especiales", "OptionSubstring": "Subcadena", - "OptionSunday": "Domingo", - "OptionThursday": "Jueves", "OptionTrackName": "Nombre de la pista", - "OptionTuesday": "Martes", "OptionTvdbRating": "Calificación de TVDB", "OptionUnairedEpisode": "Episodios no emitidos", "OptionUnplayed": "No reproducido", "OptionWakeFromSleep": "Despertar de la suspensión", - "OptionWednesday": "Miércoles", "OptionWeekdays": "Días de semana", "OptionWeekends": "Fines de semana", "OptionWeekly": "Semanal", @@ -1171,7 +1157,6 @@ "TabDirectPlay": "Reproducción directa", "TabEpisodes": "Episodios", "TabLatest": "Recientes", - "TabLiveTV": "TV en vivo", "TabLogs": "Registros", "TabMusic": "Música", "TabMusicVideos": "Videos musicales", @@ -1181,12 +1166,9 @@ "TabNotifications": "Notificaciones", "TabOther": "Otros", "TabParentalControl": "Control parental", - "TabPassword": "Contraseña", - "TabPlaylists": "Listas de reproducción", "TabPlugins": "Complementos", "TabProfile": "Perfil", "TabProfiles": "Perfiles", - "TabRecordings": "Grabaciones", "TabResponses": "Respuestas", "TabResumeSettings": "Reanudar", "TabScheduledTasks": "Tareas programadas", @@ -1195,7 +1177,6 @@ "TabStreaming": "Transmisión", "TabTrailers": "Trailers", "TabUpcoming": "Próximamente", - "TabUsers": "Usuarios", "Tags": "Etiquetas", "TagsValue": "Etiquetas: {0}", "TellUsAboutYourself": "Háblanos de ti", @@ -1337,7 +1318,6 @@ "TV": "TV", "TabCodecs": "Códecs", "TabInfo": "Información", - "TabSeries": "Series", "ValueMinutes": "{0} min", "ValueSeriesCount": "{0} series", "Vertical": "Vertical", diff --git a/src/strings/es.json b/src/strings/es.json index 3bd59126a9..09e5f5fcf4 100644 --- a/src/strings/es.json +++ b/src/strings/es.json @@ -287,8 +287,6 @@ "HeaderLibraryFolders": "Carpetas de la biblioteca", "HeaderLibraryOrder": "Orden de la biblioteca", "HeaderLibrarySettings": "Ajustes de la biblioteca", - "HeaderLiveTV": "Televisión en directo", - "HeaderLiveTv": "Televisión en directo", "HeaderLiveTvTunerSetup": "Ajustes del sintonizador de televisión", "HeaderLoginFailure": "Fallo de inicio de sesión", "HeaderMedia": "Medios", @@ -303,7 +301,6 @@ "HeaderNewApiKey": "Nueva clave API", "HeaderNewDevices": "Nuevos dispositivos", "HeaderNextEpisodePlayingInValue": "Siguiente episodio empezará en {0}", - "HeaderNextUp": "Siguiente", "HeaderNextVideoPlayingInValue": "Siguiente vídeo empezará en {0}", "HeaderOnNow": "Transmitiendo ahora", "HeaderOtherItems": "Otros elementos", @@ -311,7 +308,6 @@ "HeaderPassword": "Contraseña", "HeaderPasswordReset": "Reestablecer contraseña", "HeaderPaths": "Ruta", - "HeaderPeople": "Gente", "HeaderPinCodeReset": "Restablecer código PIN", "HeaderPlayAll": "Reproducir todo", "HeaderPlayOn": "Reproducir en", @@ -335,7 +331,6 @@ "HeaderRevisionHistory": "Histórico de revisiones", "HeaderRunningTasks": "Tareas en ejecución", "HeaderScenes": "Escenas", - "HeaderSchedule": "Horario", "HeaderSeasons": "Temporadas", "HeaderSecondsValue": "{0} segundos", "HeaderSelectCertificatePath": "Elige la ruta del certificado", @@ -348,7 +343,6 @@ "HeaderSelectTranscodingPath": "Ruta para los archivos temporales de las conversiones", "HeaderSelectTranscodingPathHelp": "Busca o escribe la ruta que se utilizará para guardar los archivos que se generarán mientras se convierten los archivos. Jellyfin debe tener permisos de escritura en la carpeta.", "HeaderSendMessage": "Enviar mensaje", - "HeaderSeries": "Series", "HeaderSeriesOptions": "Opciones de series", "HeaderServerSettings": "Ajustes del servidor", "HeaderSettings": "Ajustes", @@ -895,7 +889,6 @@ "OptionExternallyDownloaded": "Descarga externa", "OptionExtractChapterImage": "Habilitar la extracción de imágenes de los capítulos", "OptionFavorite": "Favoritos", - "OptionFriday": "Viernes", "OptionHasSpecialFeatures": "Características especiales", "OptionHasSubtitles": "Subtítulos", "OptionHasThemeSong": "Banda sonora", @@ -910,11 +903,9 @@ "OptionLikes": "Me gusta", "OptionMax": "Máximo", "OptionMissingEpisode": "Episodios que faltan", - "OptionMonday": "Lunes", "OptionNameSort": "Nombre", "OptionNew": "Nuevo…", "OptionNone": "Nada", - "OptionOnAppStartup": "Al iniciar la aplicación", "OptionOnInterval": "En un intervalo", "OptionParentalRating": "Clasificación parental", "OptionPlainStorageFolders": "Ver todas las carpetas como carpetas de almacenamiento sin formato", @@ -935,19 +926,14 @@ "OptionResElement": "Elemento res", "OptionResumable": "Se puede continuar", "OptionRuntime": "Tiempo", - "OptionSaturday": "Sábado", "OptionSaveMetadataAsHidden": "Guardar las etiquetas e imágenes como archivos ocultos", "OptionSaveMetadataAsHiddenHelp": "La configuración se aplicará a las nuevas etiquetas que se creen. Las etiquetas existentes se actualizarán la próxima vez que sean guardadas por Jellyfin.", "OptionSpecialEpisode": "Especiales", - "OptionSunday": "Domingo", - "OptionThursday": "Jueves", "OptionTrackName": "Nombre de pista", - "OptionTuesday": "Martes", "OptionTvdbRating": "Valoración TVDB", "OptionUnairedEpisode": "Episodios no emitidos", "OptionUnplayed": "No reproducido", "OptionWakeFromSleep": "Despertar", - "OptionWednesday": "Miércoles", "OptionWeekdays": "Días de la semana", "OptionWeekends": "Fines de semana", "OptionWeekly": "Semanal", @@ -1075,7 +1061,6 @@ "TabDirectPlay": "Reproducción directa", "TabEpisodes": "Episodios", "TabLatest": "Novedades", - "TabLiveTV": "Televisión en directo", "TabMusic": "Música", "TabMusicVideos": "Videos musicales", "TabMyPlugins": "Mis extensiones", @@ -1084,11 +1069,8 @@ "TabNotifications": "Notificaciones", "TabOther": "Otros", "TabParentalControl": "Control parental", - "TabPassword": "Contraseña", - "TabPlaylists": "Listas de reproducción", "TabProfile": "Perfil", "TabProfiles": "Perfiles", - "TabRecordings": "Grabaciones", "TabResponses": "Respuestas", "TabResumeSettings": "Reanudación", "TabScheduledTasks": "Tareas programadas", @@ -1096,7 +1078,6 @@ "TabSettings": "Opciones", "TabStreaming": "Transmisión", "TabUpcoming": "Próximos", - "TabUsers": "Usuarios", "Tags": "Etiquetas", "TellUsAboutYourself": "Háblenos acerca de usted", "TheseSettingsAffectSubtitlesOnThisDevice": "Estas opciones afectan a los subtítulos en este dispositivo", @@ -1332,7 +1313,6 @@ "TabInfo": "Info", "TabLogs": "Registros", "TabPlugins": "Extensiones", - "TabSeries": "Series", "TabTrailers": "Tráilers", "TagsValue": "Etiquetas: {0}", "ThemeSongs": "Banda sonora", diff --git a/src/strings/es_419.json b/src/strings/es_419.json index 815018e9c3..326ffd5914 100644 --- a/src/strings/es_419.json +++ b/src/strings/es_419.json @@ -6,8 +6,6 @@ "Playlists": "Listas de reproducción", "Photos": "Fotos", "Movies": "Películas", - "HeaderNextUp": "A continuación", - "HeaderLiveTV": "TV en vivo", "HeaderFavoriteSongs": "Canciones favoritas", "HeaderFavoriteShows": "Programas favoritos", "HeaderFavoriteEpisodes": "Episodios favoritos", @@ -130,21 +128,16 @@ "TellUsAboutYourself": "Háblanos de ti", "TagsValue": "Etiquetas: {0}", "Tags": "Etiquetas", - "TabUsers": "Usuarios", "TabUpcoming": "Próximamente", "TabStreaming": "Transmisión", "TabSettings": "Configuración", "TabServer": "Servidor", - "TabSeries": "Series", "TabScheduledTasks": "Tareas programadas", "TabResumeSettings": "Reanudar", "TabResponses": "Respuestas", - "TabRecordings": "Grabaciones", "TabProfiles": "Perfiles", "TabProfile": "Perfil", "TabPlugins": "Complementos", - "TabPlaylists": "Listas de reproducción", - "TabPassword": "Contraseña", "TabParentalControl": "Control parental", "TabOther": "Otros", "TabNotifications": "Notificaciones", @@ -155,7 +148,6 @@ "TabMusicVideos": "Videos musicales", "TabMusic": "Música", "TabLogs": "Registros", - "TabLiveTV": "TV en vivo", "TabInfo": "Información", "TabEpisodes": "Episodios", "TabDirectPlay": "Reproducción directa", @@ -172,11 +164,9 @@ "OptionPlainStorageFolders": "Mostrar todas las carpetas como carpetas de almacenamiento simples", "OptionParentalRating": "Clasificación parental", "OptionOnInterval": "En un intervalo", - "OptionOnAppStartup": "Al iniciar la aplicación", "OptionNone": "Ninguno", "OptionNew": "Nuevo…", "OptionNameSort": "Nombre", - "OptionMonday": "Lunes", "OptionMissingEpisode": "Episodios faltantes", "OptionMax": "Máximo", "OptionLoginAttemptsBeforeLockoutHelp": "Un valor de cero significa heredar el valor predeterminado de tres intentos para los usuarios normales y cinco para los administradores. Ajustar esto a -1 deshabilitará la función.", @@ -197,7 +187,6 @@ "OptionHasThemeSong": "Canción temática", "OptionHasSubtitles": "Subtítulos", "OptionHasSpecialFeatures": "Características especiales", - "OptionFriday": "Viernes", "OptionFavorite": "Favoritos", "OptionExtractChapterImage": "Habilitar la extracción de imágenes de los capítulos", "OptionExternallyDownloaded": "Descarga externa", @@ -611,21 +600,16 @@ "OptionWeekly": "Semanal", "OptionWeekends": "Fines de semana", "OptionWeekdays": "Días de semana", - "OptionWednesday": "Miércoles", "OptionWakeFromSleep": "Despertar de la suspensión", "OptionUnplayed": "No reproducido", "OptionUnairedEpisode": "Episodios no emitidos", "OptionTvdbRating": "Calificación de TVDB", - "OptionTuesday": "Martes", "OptionTrackName": "Nombre de la pista", "OptionThumb": "Miniatura", - "OptionThursday": "Jueves", - "OptionSunday": "Domingo", "OptionSubstring": "Subcadena", "OptionSpecialEpisode": "Especiales", "OptionSaveMetadataAsHiddenHelp": "Cambiar esto se aplicará a los nuevos metadatos guardados en el futuro. Los archivos de metadatos existentes serán actualizados la próxima vez que sean guardados por el servidor Jellyfin.", "OptionSaveMetadataAsHidden": "Guardar metadatos e imágenes como archivos ocultos", - "OptionSaturday": "Sábado", "OptionRuntime": "Duración", "OptionResumable": "Reanudable", "OptionRequirePerfectSubtitleMatchHelp": "Solicitar una coincidencia perfecta filtrará los subtítulos para incluir solo aquellos que han sido probados y verificados exactamente con tu archivo de video. Desmarcar esta opción incrementará las probabilidades de que se descarguen subtítulos, pero incrementará las posibilidades de obtener subtítulos mal sincronizados o con texto incorrecto.", @@ -1021,7 +1005,6 @@ "HeaderSelectCertificatePath": "Selecciona la ruta del certificado", "HeaderSecondsValue": "{0} segundos", "HeaderSeasons": "Temporadas", - "HeaderSchedule": "Programación", "HeaderScenes": "Escenas", "HeaderRunningTasks": "Tareas en ejecución", "HeaderRevisionHistory": "Historial de versiones", @@ -1047,7 +1030,6 @@ "HeaderPlayAll": "Reproducir todo", "HeaderPinCodeReset": "Restablecer código PIN", "HeaderPhotoAlbums": "Álbumes de fotos", - "HeaderPeople": "Personas", "HeaderPaths": "Rutas", "HeaderPasswordReset": "Restablecer contraseña", "HeaderPassword": "Contraseña", @@ -1071,7 +1053,6 @@ "HeaderMedia": "Medios", "HeaderLoginFailure": "Falló el inicio de sesión", "HeaderLiveTvTunerSetup": "Configuración del sintonizador de TV", - "HeaderLiveTv": "TV en vivo", "HeaderLibrarySettings": "Configuraciones de biblioteca", "HeaderLibraryOrder": "Orden de las bibliotecas", "HeaderLibraryFolders": "Carpetas de bibliotecas", @@ -1336,7 +1317,6 @@ "HeaderServerAddressSettings": "Configuración de la dirección del servidor", "HeaderSeriesStatus": "Estado de la serie", "HeaderSeriesOptions": "Opciones de serie", - "HeaderSeries": "Series", "HeaderSendMessage": "Enviar mensaje", "HeaderSelectTranscodingPathHelp": "Explora o escribe la ruta para los archivos de transcodificación. Se tienen que tener permisos de escritura en esa carpeta.", "HeaderSelectTranscodingPath": "Selecciona la ruta para los archivos temporales de transcodificación", diff --git a/src/strings/fa.json b/src/strings/fa.json index a764f28998..61c2f8f26c 100644 --- a/src/strings/fa.json +++ b/src/strings/fa.json @@ -30,7 +30,6 @@ "HeaderInstantMix": "درهم کردن فوری", "HeaderKodiMetadataHelp": "برای فعال یا غیرفعال سازی ابرداده‌های Nfo ، یک کتابخانه را در صفحه تنظیم کتابخانه Jellyfin ویرایش کرده و قسمت سرورهای ابرداده را مسیردهی کنید.", "HeaderLatestEpisodes": "آخرین قسمت ها", - "HeaderNextUp": "قسمت بعدی", "HeaderPaths": "مسیرها", "HeaderPlayAll": "پخش همه", "HeaderPreferredMetadataLanguage": "زبان مدنظر اطلاعات محتوی", @@ -86,7 +85,6 @@ "TabMusicVideos": "موزیک ویدیوها", "TabNetworks": "شبکه ها", "TabNotifications": "اعلان ها", - "TabPassword": "رمز عبور", "TabProfile": "پروفایل", "TabProfiles": "پروفایل ها", "TabUpcoming": "بزودی", @@ -109,7 +107,6 @@ "HeaderFavoriteAlbums": "آلبوم‌های مورد علاقه", "HeaderFavoriteArtists": "هنرمندان مورد علاقه", "HeaderFavoriteSongs": "آهنگ‌های مورد علاقه", - "HeaderLiveTV": "پخش زنده", "Movies": "فیلم‌ها", "Photos": "عکس‌ها", "Playlists": "لیست‌های پخش", @@ -292,7 +289,6 @@ "HeaderPlayOn": "پخش در", "HeaderPinCodeReset": "بازنشانی پین کد", "HeaderPhotoAlbums": "آلبوم‌های عکس", - "HeaderPeople": "افراد", "HeaderPasswordReset": "بازنشانی گذرواژه", "HeaderPassword": "گذرواژه", "HeaderParentalRatings": "رتبه بندی والدین", @@ -314,7 +310,6 @@ "HeaderMedia": "رسانه", "HeaderLoginFailure": "ورود ناموفق", "HeaderLiveTvTunerSetup": "تنظیم تلویزیون زنده", - "HeaderLiveTv": "تلویزیون زنده", "HeaderLibrarySettings": "تنظیمات کتابخانه", "HeaderLibraryOrder": "ترتیت کتابخانه", "HeaderLibraryFolders": "پوشه‌های کتابخانه", @@ -428,7 +423,6 @@ "TabMyPlugins": "افزونه‌های من", "TabMusic": "موسیقی‌ها", "TabLogs": "واقعه نگار‌ها", - "TabLiveTV": "تلویزیون زنده", "LatestFromLibrary": "جدیدترین‌های {0}", "Large": "بزرگ", "LabelffmpegPath": "مسیر FFmpeg:", @@ -495,7 +489,6 @@ "ThemeSongs": "آهنگ‌های تم", "TagsValue": "برچسب‌ها: {0}", "Tags": "برچسب‌ها", - "TabUsers": "کاربران", "Absolute": "کامل", "Writer": "نویسنده", "Whitelist": "لیست سفید", @@ -566,12 +559,9 @@ "AdditionalNotificationServices": "برای نصب سرویس‌های اعلان اضافی، در فروشگاه افزونه‌ها جستجو کنید.", "OptionThumbCard": "کارت بندانگشتی", "OptionThumb": "بندانگشتی", - "OptionThursday": "پنجشنبه", - "OptionSunday": "یکشنبه", "OptionSubstring": "زیررشته", "OptionSpecialEpisode": "ویژه‌ها", "OptionSaveMetadataAsHidden": "ذخیره فراداده‌ها و عکس‌ها به عنوان فایل‌های پنهان", - "OptionSaturday": "شنبه", "OptionRuntime": "زمان اجرا", "OptionResumable": "قابل از سرگیری", "OptionResElement": "عنصر res", @@ -617,13 +607,10 @@ "TabStreaming": "در حال پخش", "TabSettings": "تنظیمات", "TabServer": "سرور", - "TabSeries": "سریال‌ها", "TabScheduledTasks": "وظایف زمان بندی شده", "TabResumeSettings": "ادامه", "TabResponses": "پاسخ‌ها", - "TabRecordings": "ضبط‌ها", "TabPlugins": "افزونه‌ها", - "TabPlaylists": "لیست‌های پخش", "TabParentalControl": "رتبه بندی والدین", "TabOther": "سایر", "TabNfoSettings": "تنظیمات NFO", @@ -654,11 +641,9 @@ "OptionWeekly": "هفتگی", "OptionWeekends": "آخر هفته ها", "OptionWeekdays": "روز های هفته", - "OptionWednesday": "چهارشنبه", "OptionWakeFromSleep": "از خواب بیدار شدن", "OptionUnairedEpisode": "قسمت های پخش نشده", "OptionTvdbRating": "نمره TVDB", - "OptionTuesday": "سه شنبه", "OptionTrackName": "نام ترک", "OptionRequirePerfectSubtitleMatchHelp": "نتیجه کامل زیرنویس ها را به صورتی فیلتر می کند که فقط مواردی را که دقیقا با فایل تصویری شما آزمایش و تأیید شده اند ،شامل شود. حذف این گزینه احتمال بارگیری زیرنویس ها را افزایش می دهد ، اما شانس متن زیرنویس ناهماهنگ یا غلط نیز افزایش می یابد.", "ServerNameIsShuttingDown": "سرور جلی فین - {0} در حال خاموش شدن می باشد.", @@ -991,7 +976,6 @@ "OptionEveryday": "Every day", "OptionExternallyDownloaded": "External download", "OptionExtractChapterImage": "Enable chapter image extraction", - "OptionFriday": "Friday", "OptionHasSpecialFeatures": "Special Features", "OptionHasSubtitles": "Subtitles", "OptionHasThemeSong": "Theme Song", @@ -1000,7 +984,6 @@ "OptionHideUser": "Hide this user from login screens", "OptionHideUserFromLoginHelp": "Useful for private or hidden administrator accounts. The user will need to sign in manually by entering their username and password.", "HeaderSendMessage": "Send Message", - "HeaderSeries": "Series", "HeaderSeriesOptions": "Series Options", "HeaderSeriesStatus": "Series Status", "HeaderServerAddressSettings": "Server Address Settings", @@ -1089,11 +1072,9 @@ "OptionLoginAttemptsBeforeLockoutHelp": "A value of zero means inheriting the default of three attempts for normal users and five for administrators. Setting this to -1 will disable the feature.", "OptionMax": "Max", "OptionMissingEpisode": "Missing Episodes", - "OptionMonday": "Monday", "OptionNameSort": "Name", "OptionNew": "New…", "OptionNone": "None", - "OptionOnAppStartup": "On application startup", "LabelMaxResumePercentageHelp": "Titles are assumed fully played if stopped after this time.", "LabelMaxScreenshotsPerItem": "Maximum number of screenshots per item:", "LabelMaxStreamingBitrate": "Maximum streaming quality:", @@ -1224,7 +1205,6 @@ "HeaderRevisionHistory": "Revision History", "HeaderRunningTasks": "Running Tasks", "HeaderScenes": "Scenes", - "HeaderSchedule": "Schedule", "HeaderSeasons": "Seasons", "HeaderSecondsValue": "{0} Seconds", "HeaderSelectCertificatePath": "Select Certificate Path", diff --git a/src/strings/fi.json b/src/strings/fi.json index 3b17554efc..7eddf8e17f 100644 --- a/src/strings/fi.json +++ b/src/strings/fi.json @@ -13,7 +13,6 @@ "FileReadCancelled": "Tiedoston luku on peruutettu.", "FileReadError": "Virhe tiedoston luvun aikana.", "FolderTypeTvShows": "TV-sarjat", - "HeaderSeries": "Sarjat", "LabelAudioLanguagePreference": "Äänen ensisijainen kieli:", "LabelCountry": "Maa:", "LabelCurrentPassword": "Tämän hetkinen salsana:", @@ -36,7 +35,6 @@ "PasswordSaved": "Salasana tallennettu.", "Save": "Tallenna", "SettingsSaved": "Asetukset tallennettu.", - "TabPassword": "Salasana", "TabProfile": "Profiili", "TabProfiles": "Profiilit", "TellUsAboutYourself": "Kerro meille itsestäsi", @@ -217,8 +215,6 @@ "CopyStreamURL": "Kopioi Toiston Osoite", "ButtonAddImage": "Lisää kuva", "Movies": "Elokuvat", - "HeaderNextUp": "Seuraavaksi", - "HeaderLiveTV": "Live-TV", "HeaderFavoriteSongs": "Lempikappaleet", "HeaderFavoriteShows": "Lempisarjat", "HeaderFavoriteEpisodes": "Lempijaksot", @@ -306,10 +302,8 @@ "OptionPoster": "Juliste", "OptionPlayCount": "Toistokerrat", "OptionPlayed": "Toistettu", - "OptionOnAppStartup": "Käynnistyksen yhteydessä", "OptionNew": "Uusi…", "OptionNameSort": "Nimi", - "OptionMonday": "Maanantai", "OptionMissingEpisode": "Puuttuvat jaksot", "OptionMax": "Maksimi", "OptionList": "Lista", @@ -324,7 +318,6 @@ "OptionHasThemeSong": "Tunnuskappale", "OptionHasSubtitles": "Tekstitykset", "OptionHasSpecialFeatures": "Erikoisominaisuudet", - "OptionFriday": "Perjantai", "OptionFavorite": "Suosikit", "OptionExtractChapterImage": "Ota käyttöön kappalekuvien luonti", "OptionExternallyDownloaded": "Ulkoinen lataus", @@ -419,7 +412,6 @@ "HeaderSeriesStatus": "Sarjan status", "HeaderSeriesOptions": "Sarjan asetukset", "HeaderSelectTranscodingPath": "Valitse transkoodauksen väliaikainen polku", - "HeaderSchedule": "Ajastus", "HeaderScenes": "Kohtaukset", "HeaderResponseProfile": "Vastausprofiili", "HeaderRemoveMediaLocation": "Poista mediasijainti", @@ -489,7 +481,6 @@ "HeaderMediaInfo": "Mediainfo", "HeaderMediaFolders": "Mediakansiot", "HeaderMedia": "Media", - "HeaderLiveTv": "Live-TV", "HeaderLibraryFolders": "Kirjaston kansiot", "HeaderLatestMedia": "Uusin media", "HeaderLatestRecordings": "Uusimmat tallenteet", @@ -641,24 +632,19 @@ "ThemeSongs": "Tunnuslaulut", "TagsValue": "Tunnisteet: {0}", "Tags": "Tunnisteet", - "TabUsers": "Käyttäjät", "TabUpcoming": "Tulevat", "TabSettings": "Asetukset", "TabServer": "Palvelin", - "TabSeries": "Sarjat", "TabScheduledTasks": "Ajastetut tehtävät", "TabResumeSettings": "Jatka", "TabResponses": "Vastaukset", - "TabRecordings": "Tallennukset", "TabPlugins": "Liitännäiset", - "TabPlaylists": "Soittolistat", "TabNfoSettings": "NFO-asetukset", "TabNetworks": "Verkot", "TabMyPlugins": "Omat liittännäiseni", "TabMusicVideos": "Musiikkivideot", "TabMusic": "Musiikki", "TabLogs": "Lokit", - "TabLiveTV": "Live-TV", "TabLatest": "Uusimmat", "TabInfo": "Tiedot", "TabEpisodes": "Jaksot", @@ -870,7 +856,6 @@ "HeaderRestart": "Uudelleenkäynnistys", "HeaderProfile": "Profiili", "HeaderPlayAll": "Toista kaikki", - "HeaderPeople": "Ihmiset", "HeaderPassword": "Salasana", "HeaderNewApiKey": "Uusi API-avain", "HeaderNavigation": "Navigaatio", @@ -946,11 +931,6 @@ "LabelContentType": "Sisältötyyppi:", "LabelChannels": "Kanavat:", "LabelCertificatePasswordHelp": "Jos sertifikaattisi vaatii salasanaa, laita se tähän.", - "OptionWednesday": "Keskiviikko", - "OptionTuesday": "Tiistai", - "OptionThursday": "Torstai", - "OptionSunday": "Sunnuntai", - "OptionSaturday": "Lauantai", "LabelRuntimeMinutes": "Pituus (minuutteja):", "LabelReleaseDate": "Julkaisupäivä:", "Genre": "Tyylilaji", diff --git a/src/strings/fr-ca.json b/src/strings/fr-ca.json index e7deac36f9..15973b5f36 100644 --- a/src/strings/fr-ca.json +++ b/src/strings/fr-ca.json @@ -23,9 +23,7 @@ "HeaderDeleteItem": "Supprimer l'élément", "HeaderMyMedia": "Mes Médias", "HeaderMyMediaSmall": "Mes médias (petit)", - "HeaderNextUp": "À Suivre", "HeaderRemoteControl": "Télécommande", - "HeaderSeries": "Series:", "Help": "Aide", "ItemCount": "{0} articles", "LabelFinish": "Terminer", @@ -103,7 +101,6 @@ "Folders": "Dossiers", "Genres": "Genres", "HeaderAlbumArtists": "Artistes de l'album", - "HeaderLiveTV": "TV en direct", "Movies": "Films", "Photos": "Photos", "Playlists": "Listes de lecture", diff --git a/src/strings/fr.json b/src/strings/fr.json index 61710fede0..4bab5a6179 100644 --- a/src/strings/fr.json +++ b/src/strings/fr.json @@ -331,8 +331,6 @@ "HeaderLibraryFolders": "Dossiers de la médiathèque", "HeaderLibraryOrder": "Ordre de la médiathèque", "HeaderLibrarySettings": "Paramètres de la médiathèque", - "HeaderLiveTV": "TV en direct", - "HeaderLiveTv": "TV en direct", "HeaderLiveTvTunerSetup": "Configuration du Tuner TV en direct", "HeaderLoginFailure": "Échec de la connexion", "HeaderMedia": "Média", @@ -348,7 +346,6 @@ "HeaderNewApiKey": "Nouvelle clé API", "HeaderNewDevices": "Nouveaux appareils", "HeaderNextEpisodePlayingInValue": "Lecture du prochain épisode dans {0}", - "HeaderNextUp": "À suivre", "HeaderNextVideoPlayingInValue": "Lecture de la prochaine vidéo dans {0}", "HeaderOnNow": "En ce moment", "HeaderOtherItems": "Autres éléments", @@ -356,7 +353,6 @@ "HeaderPassword": "Mot de passe", "HeaderPasswordReset": "Mot de passe réinitialisé", "HeaderPaths": "Chemins", - "HeaderPeople": "Personnes", "HeaderPhotoAlbums": "Albums photo", "HeaderPinCodeReset": "Réinitialiser le code PIN", "HeaderPlayAll": "Tout lire", @@ -381,7 +377,6 @@ "HeaderRevisionHistory": "Historique des révisions", "HeaderRunningTasks": "Tâches en cours d'exécution", "HeaderScenes": "Scènes", - "HeaderSchedule": "Planning", "HeaderSeasons": "Saisons", "HeaderSecondsValue": "{0} secondes", "HeaderSelectCertificatePath": "Sélectionnez le chemin du certificat", @@ -394,7 +389,6 @@ "HeaderSelectTranscodingPath": "Sélectionner le chemin d'accès du dossier temporaire de transcodage", "HeaderSelectTranscodingPathHelp": "Parcourir ou saisir le chemin d'accès à utiliser pour les fichiers de transcodage. Le dossier doit être accessible en écriture.", "HeaderSendMessage": "Envoyer un message", - "HeaderSeries": "Séries", "HeaderSeriesOptions": "Options de la série", "HeaderSeriesStatus": "Statut de la série", "HeaderServerSettings": "Paramètres du serveur", @@ -970,7 +964,6 @@ "OptionExternallyDownloaded": "Téléchargement externe", "OptionExtractChapterImage": "Activer l'extraction des images de chapitres", "OptionFavorite": "Favoris", - "OptionFriday": "Vendredi", "OptionHasSpecialFeatures": "Bonus", "OptionHasSubtitles": "Sous-titres", "OptionHasThemeSong": "Chanson thème", @@ -986,11 +979,9 @@ "OptionLikes": "Aimés", "OptionMax": "Maximum", "OptionMissingEpisode": "Épisodes manquantes", - "OptionMonday": "Lundi", "OptionNameSort": "Nom", "OptionNew": "Nouveau…", "OptionNone": "Aucun", - "OptionOnAppStartup": "Au démarrage de l'application", "OptionOnInterval": "Par intervalle", "OptionParentalRating": "Classification parentale", "OptionPlainStorageFolders": "Afficher tous les dossiers en tant que simples dossiers de stockage", @@ -1011,20 +1002,15 @@ "OptionResElement": "Résolution d'élément", "OptionResumable": "Reprise possible", "OptionRuntime": "Durée", - "OptionSaturday": "Samedi", "OptionSaveMetadataAsHidden": "Enregistrer les métadonnées et les images en tant que fichier cachés", "OptionSaveMetadataAsHiddenHelp": "La modification s'appliquera aux nouvelles métadonnées enregistrées à l'avenir. Les fichiers de métadonnées existants seront mis à jour la prochaine fois qu'ils seront enregistrés par le serveur.", "OptionSpecialEpisode": "Spéciaux", "OptionSubstring": "Sous-chaîne", - "OptionSunday": "Dimanche", - "OptionThursday": "Jeudi", "OptionTrackName": "Titre", - "OptionTuesday": "Mardi", "OptionTvdbRating": "Note d'évaluation TVDB", "OptionUnairedEpisode": "Épisodes non diffusés", "OptionUnplayed": "Non lu", "OptionWakeFromSleep": "Sortie de veille", - "OptionWednesday": "Mercredi", "OptionWeekdays": "Jours de la semaine", "OptionWeekends": "Week-ends", "OptionWeekly": "Hebdomadaire", @@ -1164,7 +1150,6 @@ "TabDirectPlay": "Lecture directe", "TabEpisodes": "Épisodes", "TabLatest": "Derniers", - "TabLiveTV": "TV en direct", "TabLogs": "Journaux", "TabMusic": "Musique", "TabMusicVideos": "Vidéos musicales", @@ -1173,20 +1158,15 @@ "TabNfoSettings": "Paramètres NFO", "TabOther": "Autre", "TabParentalControl": "Contrôle Parental", - "TabPassword": "Mot de passe", - "TabPlaylists": "Listes de lecture", "TabProfile": "Profil", "TabProfiles": "Profils", - "TabRecordings": "Enregistrements", "TabResponses": "Réponses", "TabResumeSettings": "Reprise", "TabScheduledTasks": "Tâches planifiées", - "TabSeries": "Séries", "TabServer": "Serveur", "TabSettings": "Paramètres", "TabTrailers": "Bandes-annonces", "TabUpcoming": "À venir", - "TabUsers": "Utilisateurs", "Tags": "Étiquettes", "TagsValue": "Mots clés: {0}", "TellUsAboutYourself": "Parlez-nous de vous", diff --git a/src/strings/gsw.json b/src/strings/gsw.json index 1b23cb29b1..f144e1ca65 100644 --- a/src/strings/gsw.json +++ b/src/strings/gsw.json @@ -21,10 +21,8 @@ "HeaderFrequentlyPlayed": "Vell gspellt", "HeaderLatestEpisodes": "Letschti Episode", "HeaderLatestMovies": "Letschti Film", - "HeaderNextUp": "Als Nächstes", "HeaderPaths": "Pfad", "HeaderRecentlyPlayed": "Erst grad dezue gfüegt", - "HeaderSeries": "Series", "HeaderUsers": "User", "LabelArtists": "Artist:", "LabelArtistsHelp": "Trenn mehreri iisträg dur es ;", @@ -66,10 +64,8 @@ "OptionEnableAccessToAllLibraries": "Aktiviere de Zuegriff zu allne Bibliotheke", "OptionEnded": "Beendent", "OptionFavorite": "Favorite", - "OptionFriday": "Friitig", "OptionHasSubtitles": "Undertitel", "OptionImdbRating": "IMDB Bewertig", - "OptionMonday": "Mäntig", "OptionParentalRating": "Altersfriigab", "OptionPlayCount": "Zähler", "OptionPlayed": "Gspellt", @@ -77,12 +73,7 @@ "OptionReleaseDate": "Release Ziit", "OptionResumable": "Chan fortgsetzt werde", "OptionRuntime": "Laufziit", - "OptionSaturday": "Samstig", - "OptionSunday": "Sonntig", - "OptionThursday": "Donnstig", - "OptionTuesday": "Tsischtig", "OptionUnplayed": "Ungspellt", - "OptionWednesday": "Mittwoch", "ParentalRating": "Parental Rating", "Saturday": "Samstig", "Save": "Speichere", @@ -98,7 +89,6 @@ "TabMyPlugins": "Miini Plugins", "TabNetworks": "Studios", "TabNotifications": "Mitteilige", - "TabPassword": "Passwort", "TabProfile": "Profil", "TabProfiles": "Profil", "TabUpcoming": "Usstehend", @@ -125,7 +115,6 @@ "HeaderFavoriteEpisodes": "Lieblingsepisoden", "HeaderFavoriteShows": "Lieblingsserien", "HeaderFavoriteSongs": "Lieblingslieder", - "HeaderLiveTV": "Live-Fernseh", "Movies": "Film", "Photos": "Fotis", "Playlists": "Wedergabeliste", diff --git a/src/strings/he.json b/src/strings/he.json index d3a6b1ee19..667db59d9e 100644 --- a/src/strings/he.json +++ b/src/strings/he.json @@ -103,12 +103,10 @@ "HeaderLatestMovies": "סרטים אחרונים שהוספו", "HeaderLatestMusic": "מוזיקה אחרונה", "HeaderLatestRecordings": "הקלטות אחרונות", - "HeaderLiveTV": "שידורים חיים", "HeaderMediaFolders": "ספריות מדיה", "HeaderMetadataSettings": "הגדרות מטא-דאטה", "HeaderMusicVideos": "קליפים", "HeaderMyMedia": "המדיה שלי", - "HeaderNextUp": "הבא בתור", "HeaderPaths": "נתיבים", "HeaderPlayAll": "נגן הכל", "HeaderPleaseSignIn": "אנא היכנס", @@ -116,7 +114,6 @@ "HeaderRecordingOptions": "אפשרויות הקלטה", "HeaderRunningTasks": "משימות רצות", "HeaderScenes": "סצנות", - "HeaderSeries": "סדרה", "HeaderSeriesOptions": "אפשרויות סדרה", "HeaderServerSettings": "הגדרות שרת", "HeaderSetupLibrary": "הגדר את ספריית המדיה שלך", @@ -319,7 +316,6 @@ "OptionDvd": "DVD", "OptionEnded": "הסתיים", "OptionFavorite": "מועדפים", - "OptionFriday": "שישי", "OptionHasSpecialFeatures": "מאפיינים מיוחדים", "OptionHasSubtitles": "כתוביות", "OptionHasThemeSong": "שיר נושא", @@ -329,10 +325,8 @@ "OptionImdbRating": "דירוג IMDb", "OptionLikes": "נבחרים", "OptionMissingEpisode": "פרקים חסרים", - "OptionMonday": "שני", "OptionNameSort": "שם", "OptionNew": "חדש…", - "OptionOnAppStartup": "בהפעלת התוכנה", "OptionOnInterval": "כל פרק זמן", "OptionParentalRating": "דירוג בקרת הורים", "OptionPlayCount": "כמות ניגונים", @@ -344,17 +338,12 @@ "OptionProfileVideoAudio": "צליל וידאו", "OptionResumable": "ניתן להמשיך", "OptionRuntime": "זמן ריצה", - "OptionSaturday": "שבת", "OptionSpecialEpisode": "ספיישלים", - "OptionSunday": "ראשון", - "OptionThursday": "חמישי", "OptionTrackName": "שם הרצועה", - "OptionTuesday": "שלישי", "OptionTvdbRating": "דירוג TVDB", "OptionUnairedEpisode": "פרקים שלא שודרו", "OptionUnplayed": "לא נוגן", "OptionWakeFromSleep": "הער ממצב שינה", - "OptionWednesday": "רביעי", "OptionWeekly": "כל שבוע", "OriginalAirDateValue": "תאריך אוויר מקורי: {0}", "Overview": "סקירה כללית", @@ -432,17 +421,13 @@ "TabEpisodes": "פרקים", "TabInfo": "מידע", "TabLatest": "אחרון", - "TabLiveTV": "שידור ישיר", "TabMusic": "מוסיקה", "TabMusicVideos": "קליפים", "TabMyPlugins": "התוספים שלי", "TabNetworks": "רשתות", "TabNotifications": "התראות", - "TabPassword": "סיסמא", "TabProfile": "פרופיל", "TabProfiles": "פרופילים", - "TabRecordings": "הקלטות", - "TabSeries": "סדרות", "TabServer": "שרת", "TabSettings": "הגדרות", "TabTrailers": "טריילרים", @@ -577,7 +562,6 @@ "HeaderPlayOn": "נגן על", "HeaderPinCodeReset": "איפוס קוד סיכה", "HeaderPhotoAlbums": "אלבומי תמונות", - "HeaderPeople": "אנשים", "HeaderPasswordReset": "איפוס סיסמה", "HeaderPassword": "סיסמה", "HeaderOtherItems": "פריטים אחרים", @@ -587,7 +571,6 @@ "HeaderNewApiKey": "‫מפתח API חדש", "HeaderNavigation": "ניווט", "HeaderMyDevice": "המכשיר שלי", - "HeaderLiveTv": "שידורים חיים", "HeaderLibrarySettings": "הגדרות ספרייה", "HeaderLibraryFolders": "תיקיות הספרייה", "HeaderLibraries": "ספריות", @@ -822,6 +805,5 @@ "OptionEnableExternalContentInSuggestions": "הפעל תוכן חיצוני בהמלצות", "OptionEnableAccessToAllLibraries": "אפשר גישה לכל הספריות", "OptionEnableAccessToAllChannels": "אפשר גישה לכל הערוצים", - "HeaderSyncPlaySelectGroup": "הצטרף לקבוצה", - "TabUsers": "משתמשים" + "HeaderSyncPlaySelectGroup": "הצטרף לקבוצה" } diff --git a/src/strings/hr.json b/src/strings/hr.json index cf4aba1e9d..afbdbf2c22 100644 --- a/src/strings/hr.json +++ b/src/strings/hr.json @@ -213,8 +213,6 @@ "HeaderLibraries": "Biblioteke", "HeaderLibraryAccess": "Pristup biblioteci", "HeaderLibraryFolders": "Mape medija", - "HeaderLiveTV": "TV uživo", - "HeaderLiveTv": "TV uživo", "HeaderLoginFailure": "Neuspjela prijava", "HeaderMedia": "Medij", "HeaderMediaFolders": "Medijska mapa", @@ -224,7 +222,6 @@ "HeaderMusicVideos": "Muzički spotovi", "HeaderMyMedia": "Moji mediji", "HeaderNewApiKey": "Novi API ključ", - "HeaderNextUp": "Sljedeće je", "HeaderOtherItems": "Ostale stavke", "HeaderPassword": "Lozinka", "HeaderPasswordReset": "Poništenje lozinke", @@ -248,7 +245,6 @@ "HeaderRevisionHistory": "Povijest revizije", "HeaderRunningTasks": "Zadatci koji se izvode", "HeaderScenes": "Scene", - "HeaderSchedule": "Raspored", "HeaderSeasons": "Sezone", "HeaderSelectCertificatePath": "Odaberi putanju certifikata", "HeaderSelectMetadataPath": "Odaberite putanju meta-podataka", @@ -260,7 +256,6 @@ "HeaderSelectTranscodingPath": "Odaberite privremenu putanju konvertiranja", "HeaderSelectTranscodingPathHelp": "Pregledajte ili unesite putanju za korištenje konvertiranja privremenih datoteka. U mapu se mora moći pisati.", "HeaderSendMessage": "Pošalji poruku", - "HeaderSeries": "Serija", "HeaderSeriesOptions": "Opcije serija", "HeaderServerSettings": "Postavke Servera", "HeaderSettings": "Postavke", @@ -726,7 +721,6 @@ "OptionExternallyDownloaded": "Vanjsko preuzimanje", "OptionExtractChapterImage": "Omogući preuzimanje slika iz poglavlja", "OptionFavorite": "Omiljeni", - "OptionFriday": "Petak", "OptionHasSpecialFeatures": "Specijalne opcije", "OptionHasSubtitles": "Titlovi", "OptionHasThemeSong": "Pjesma teme", @@ -742,11 +736,9 @@ "OptionLikes": "Volim", "OptionMax": "Maksimalno", "OptionMissingEpisode": "Epizode koje nedostaju", - "OptionMonday": "Ponedjeljak", "OptionNameSort": "Nazivu", "OptionNew": "Novo…", "OptionNone": "Ništa", - "OptionOnAppStartup": "Kada se aplikacija pokrene", "OptionOnInterval": "U intervalu", "OptionParentalRating": "Roditeljska ocjena", "OptionPlainStorageFolders": "Prikaži sve mape kako jednostavne mape za skladištenje", @@ -764,20 +756,15 @@ "OptionRequirePerfectSubtitleMatch": "Samo preuzimanje titlova prijevoda koji su savršen izbor za moje video datoteke", "OptionResumable": "Nastavi", "OptionRuntime": "Trajanje", - "OptionSaturday": "Subota", "OptionSaveMetadataAsHidden": "Spremite meta-podatke i slike kao skrivene datoteke", "OptionSaveMetadataAsHiddenHelp": "Promjena ovoga će se primjenjivati na nove meta-podatke spremljene unaprijed. Postojeće datoteke meta-podataka će se ažurirati sljedeći puta kada ih spremi Jellyfin Server.", "OptionSpecialEpisode": "Specijal", "OptionSubstring": "Podniz", - "OptionSunday": "Nedjelja", - "OptionThursday": "Četvrtak", "OptionTrackName": "Nazivu pjesme", - "OptionTuesday": "Utorak", "OptionTvdbRating": "Ocjeni Tvdb", "OptionUnairedEpisode": "Ne emitirane epizode", "OptionUnplayed": "Neizvođeni", "OptionWakeFromSleep": "Pokreni iz stanja mirovanja", - "OptionWednesday": "Srijeda", "OptionWeekdays": "Radni dani", "OptionWeekends": "Vikendi", "OptionWeekly": "Tjedno", @@ -872,7 +859,6 @@ "TabDirectPlay": "Direktna reprodukcija", "TabEpisodes": "Epizode", "TabLatest": "Zadnje", - "TabLiveTV": "TV uživo", "TabLogs": "Dnevnici", "TabMusic": "Glazba", "TabMusicVideos": "Muzički spotovi", @@ -882,21 +868,16 @@ "TabNotifications": "Obavijesti", "TabOther": "Ostalo", "TabParentalControl": "Roditeljska kontrola", - "TabPassword": "Lozinka", - "TabPlaylists": "Popisi", "TabPlugins": "Dodaci", "TabProfile": "Profil", "TabProfiles": "Profili", - "TabRecordings": "Snimke", "TabResponses": "Odazivi", "TabResumeSettings": "Postavke nastavka", "TabScheduledTasks": "Zakazani zadaci", - "TabSeries": "Serije", "TabSettings": "Postavke", "TabStreaming": "Strujanje", "TabTrailers": "Kratki filmovi", "TabUpcoming": "Uskoro", - "TabUsers": "Korisnici", "Tags": "Oznake", "TellUsAboutYourself": "Recite nam nešto o sebi", "ThisWizardWillGuideYou": "Ovaj pomoćnik će Vas voditi kroz proces podešavanja. Za početak, odaberite željeni jezik.", diff --git a/src/strings/hu.json b/src/strings/hu.json index 9baf2220b6..644e7eb746 100644 --- a/src/strings/hu.json +++ b/src/strings/hu.json @@ -150,12 +150,10 @@ "HeaderMyDevice": "Jelenlegi eszköz", "HeaderMyMedia": "Médiatáram", "HeaderMyMediaSmall": "Médiatáram (kicsi)", - "HeaderNextUp": "Következik", "HeaderOnNow": "Most", "HeaderParentalRatings": "Korhatár besorolás", "HeaderPassword": "Jelszó", "HeaderPaths": "Útvonalak", - "HeaderPeople": "Személyek", "HeaderPinCodeReset": "Pin kód visszaállítása", "HeaderPlayAll": "Összes vetítése", "HeaderPlayOn": "Vetítés itt", @@ -174,7 +172,6 @@ "HeaderSelectMetadataPath": "Válaszd ki a metaadat útvonalat", "HeaderSelectServer": "Szerver Kiválasztás", "HeaderSendMessage": "Üzenet küldése", - "HeaderSeries": "Sorozatok", "HeaderSettings": "Beállítások", "HeaderSetupLibrary": "Média könyvtárak beállítása", "HeaderSortBy": "Megjelenítés", @@ -374,7 +371,6 @@ "OptionEnableAccessToAllLibraries": "Hozzáférés engedélyezése minden könyvtárhoz", "OptionExternallyDownloaded": "Külső letöltés", "OptionFavorite": "Kedvencek", - "OptionFriday": "Péntek", "OptionHasSpecialFeatures": "Speciális lehetőségek", "OptionHasSubtitles": "Feliratok", "OptionHasThemeSong": "Főcímdal", @@ -385,7 +381,6 @@ "OptionImdbRating": "IMDb értékelés", "OptionLikes": "Kedveltek", "OptionMissingEpisode": "Hiányzó Epizódok", - "OptionMonday": "Hétfő", "OptionNameSort": "Név", "OptionNew": "Új…", "OptionParentalRating": "Korhatár besorolás", @@ -396,14 +391,9 @@ "OptionReleaseDate": "Megjelenés dátuma", "OptionResumable": "Folytatható", "OptionRuntime": "Játékidő", - "OptionSaturday": "Szombat", - "OptionSunday": "Vasárnap", - "OptionThursday": "Csütörtök", "OptionTrackName": "Sáv Címe", - "OptionTuesday": "Kedd", "OptionUnairedEpisode": "Nem vetített Epizódok", "OptionUnplayed": "Nemjátszott", - "OptionWednesday": "Szerda", "OptionWeekly": "Heti", "OriginalAirDateValue": "Eredeti vetítés dátuma: {0}", "PackageInstallCancelled": "{0} ({1} verzió) telepítése megszakítva.", @@ -480,19 +470,14 @@ "TabNotifications": "Értesítések", "TabOther": "Egyéb", "TabParentalControl": "Szülői Felügyelet", - "TabPassword": "Jelszó", - "TabPlaylists": "Lejátszási listák", "TabPlugins": "Bővítmények", "TabProfile": "Profil", "TabProfiles": "Profilok", - "TabRecordings": "Felvételek", "TabScheduledTasks": "Ütemezett feladatok", - "TabSeries": "Sorozatok", "TabServer": "Szerver", "TabSettings": "Beállítások", "TabTrailers": "Előzetesek", "TabUpcoming": "Hamarosan érkezik", - "TabUsers": "Felhasználók", "Tags": "Címkék", "TellUsAboutYourself": "Mondj valamit magadról", "ThisWizardWillGuideYou": "Ez a varázsló végigvezet a telepítésen. A kezdéshez válasz nyelvet.", @@ -692,8 +677,6 @@ "HeaderKodiMetadataHelp": "Az Nfo metaadatok engedélyezéséhez vagy letiltásához szerkeszd a könyvtárat és keresd meg a metaadat letöltő részt.", "HeaderLatestMusic": "Legújabb Zene", "HeaderLatestRecordings": "Legújabb Felvételek", - "HeaderLiveTV": "Élő TV", - "HeaderLiveTv": "Élő TV", "HeaderLoginFailure": "Bejelentkezési hiba", "HeaderMusicQuality": "Zene minősége", "HeaderNewApiKey": "Új API kulcs", @@ -731,7 +714,6 @@ "EnableThemeVideos": "Videótémák", "EnableThemeVideosHelp": "Videó témájának lejátszása háttérben a könyvtár böngészése közben.", "HeaderBlockItemsWithNoRating": "Blokkolja azokat az elemeket amelyek tiltott, vagy nem felismerhető minősítésűek:", - "HeaderSchedule": "Ütemezés", "HeaderSeriesStatus": "Sorozat állapot", "HeaderSpecialEpisodeInfo": "Speciális epizód információ", "HeaderStartNow": "Indítás most", @@ -1067,7 +1049,6 @@ "OptionIsSD": "SD", "OptionMax": "Max", "OptionNone": "Egyik sem", - "OptionOnAppStartup": "Alkalmazás indításakor", "OptionOnInterval": "Időközönként", "OptionPlainStorageFolders": "Az összes mappa megjelenítése egyszerű tároló mappaként", "OptionPlainVideoItems": "Az összes videó megjelenítése egyszerű videófelvételként", @@ -1156,7 +1137,6 @@ "SystemDlnaProfilesHelp": "A rendszerprofilok csak olvashatóak. A rendszerprofil módosításai egy új egyéni profilba kerülnek.", "TV": "TV", "TabDirectPlay": "Közvetlen lejátszás", - "TabLiveTV": "Élő TV", "TabResponses": "Válaszok", "TabResumeSettings": "Folytatás", "TabStreaming": "Streaming", diff --git a/src/strings/id.json b/src/strings/id.json index a11d411afa..8bf0d7eafd 100644 --- a/src/strings/id.json +++ b/src/strings/id.json @@ -4,7 +4,6 @@ "FolderTypeTvShows": "TV", "HeaderAddUser": "Tambah User", "HeaderEasyPinCode": "Kode Pin Mudah", - "HeaderSeries": "Series", "HeaderSetupLibrary": "Atur pustaka media Anda", "LabelContentType": "Tipe konten:", "LabelCountry": "Negara:", @@ -30,7 +29,6 @@ "WizardCompleted": "Itu semua yang kami butuhkan saat ini. Jellyfin sudah memulai mengkoleksi informasi pustaka media. Lihatlah beberapa aplikasi kami, kemudian klik Selesai untuk menuju ke Dashboard Server", "Collections": "Koleksi", "Folders": "Folder", - "HeaderNextUp": "Selanjutnya", "Albums": "Album", "Books": "Buku", "Favorites": "Favorit", @@ -43,7 +41,6 @@ "HeaderAlbumArtists": "Album Artis", "HeaderContinueWatching": "Masih Melihat", "Artists": "Artis", - "HeaderLiveTV": "TV Live", "AllowMediaConversion": "Izinkan konversi media", "AllEpisodes": "Semua episode", "AllChannels": "Semua saluran", diff --git a/src/strings/is-is.json b/src/strings/is-is.json index 264b341b62..bd1c81c21a 100644 --- a/src/strings/is-is.json +++ b/src/strings/is-is.json @@ -26,7 +26,6 @@ "ShowAdvancedSettings": "Birta ítarlegar stillingar", "TabAccess": "Aðgangur", "TabNotifications": "Tilkynningar", - "TabPassword": "Lykilorð", "WelcomeToProject": "Velkomin/n í Jellyfin!", "Anytime": "Hvenær sem er", "Genres": "Tegundir", @@ -61,12 +60,10 @@ "HeaderFavoriteSongs": "Uppáhalds Lög", "Play": "Spila", "Folders": "Möppur", - "OptionSunday": "Sunnudagur", "OptionSubstring": "Undirstrengur", "OptionSpecialEpisode": "Sérstakt", "OptionTvdbRating": "TVDB einkunn", "OptionWakeFromSleep": "Vekja frá svefni", - "OptionWednesday": "Miðvikudagur", "PackageInstallCancelled": "{0} hætt við uppsetningu.", "AddToPlayQueue": "Bæta í spilunarlista", "AddedOnValue": "Bætti við {0}", @@ -110,8 +107,6 @@ "PerfectMatch": "Passar fullkomlega", "Channels": "Stöðvar", "Collections": "Söfn", - "OptionSaturday": "Laugardagur", - "OptionThursday": "Fimmtudagur", "OptionUnairedEpisode": "Ófrumsýndir þættir", "OptionUnplayed": "Óspilað", "OptionWeekdays": "Vikudagar", @@ -121,8 +116,6 @@ "OptionBluray": "Blu-ray", "Yesterday": "Í gær", "Absolute": "Heildartala", - "HeaderLiveTV": "Sjónvarp í beinni útsendingu", - "HeaderNextUp": "Næst á dagskrá", "OptionCommunityRating": "Einkunn almennings", "OptionCriticRating": "Einkunn gagnrýnenda", "OptionCustomUsers": "Sérsniðið", @@ -152,7 +145,6 @@ "HeaderRestart": "Endurræsa", "HeaderProfileInformation": "Upplýsingar um prófíl", "HeaderProfile": "Prófíll", - "HeaderPeople": "Fólk", "HeaderPassword": "Lykilorð", "HeaderLatestMovies": "Kvikmyndir, nýlega bætt við", "HeaderLatestEpisodes": "Þættir, nýlega bætt við", @@ -294,7 +286,6 @@ "HeaderLatestMusic": "Tónlist, nýlega bætt við", "HeaderMetadataSettings": "Stillingar lýsigagna", "HeaderMedia": "Margmiðlunarsafn", - "HeaderLiveTv": "Sjónvarp í beinni útsendingu", "HeaderLoginFailure": "Innskráning Mistókst", "HeaderMyDevice": "Tækið mitt", "HeaderMusicVideos": "Tónlistarmyndbönd", @@ -408,7 +399,6 @@ "ThemeVideos": "Þemu myndbönd", "ThemeSongs": "Þemu lög", "TellUsAboutYourself": "Segðu okkur frá sjálfum þér", - "TabUsers": "Notendur", "TabUpcoming": "Væntanlegt", "TabTrailers": "Sýnishorn", "TabResumeSettings": "Halda áfram", diff --git a/src/strings/it.json b/src/strings/it.json index af6de16491..758cb25f6e 100644 --- a/src/strings/it.json +++ b/src/strings/it.json @@ -317,8 +317,6 @@ "HeaderLibraryFolders": "Cartelle Libreria", "HeaderLibraryOrder": "Ordine Libreria", "HeaderLibrarySettings": "Impostazioni della Libreria", - "HeaderLiveTV": "Diretta TV", - "HeaderLiveTv": "Diretta TV", "HeaderLiveTvTunerSetup": "Configura Ricevitore TV", "HeaderLoginFailure": "Errore di accesso", "HeaderMediaFolders": "Cartelle dei media", @@ -333,14 +331,12 @@ "HeaderNewApiKey": "Nuova Chiave API", "HeaderNewDevices": "Nuovi Dispositivi", "HeaderNextEpisodePlayingInValue": "Il prossimo Episodio verrà riprodotto in {0}", - "HeaderNextUp": "Prossimo", "HeaderNextVideoPlayingInValue": "Il prossimo Video verrà riprodotto in {0}", "HeaderOnNow": "In onda ora", "HeaderOtherItems": "Altri elmenti", "HeaderParentalRatings": "Valutazioni genitori", "HeaderPasswordReset": "Reset della Password", "HeaderPaths": "Percorsi", - "HeaderPeople": "Persone", "HeaderPhotoAlbums": "Album foto", "HeaderPinCodeReset": "Resetta il codice PIN", "HeaderPlayAll": "Riproduci Tutti", @@ -365,7 +361,6 @@ "HeaderRevisionHistory": "Cronologia delle revisioni", "HeaderRunningTasks": "Operazioni in corso", "HeaderScenes": "Scene", - "HeaderSchedule": "Programmazione", "HeaderSeasons": "Stagioni", "HeaderSecondsValue": "{0} Secondi", "HeaderSelectCertificatePath": "Seleziona il percorso del Certificato", @@ -378,7 +373,6 @@ "HeaderSelectTranscodingPath": "Selezionare Percorso Temporaneo Transcodifica", "HeaderSelectTranscodingPathHelp": "Sfoglia o immettere il percorso da utilizzare per la transcodifica dei file temporanei. La cartella deve essere scrivibile.", "HeaderSendMessage": "Invia un messaggio", - "HeaderSeries": "Serie", "HeaderSeriesOptions": "Impostazioni Serie TV", "HeaderSeriesStatus": "Stato Serie TV", "HeaderServerSettings": "Impostazioni server", @@ -930,7 +924,6 @@ "OptionExternallyDownloaded": "Download Esterno", "OptionExtractChapterImage": "Abilita estrazione dell'immagine dei capitoli", "OptionFavorite": "Preferiti", - "OptionFriday": "Venerdì", "OptionHasSpecialFeatures": "Contenuti speciali", "OptionHasSubtitles": "Sottotitoli", "OptionHasThemeSong": "Sigla", @@ -944,11 +937,9 @@ "OptionImdbRating": "Voto IMDB", "OptionLikes": "Mi piace", "OptionMissingEpisode": "Episodi mancanti", - "OptionMonday": "Lunedì", "OptionNameSort": "Nome", "OptionNew": "Nuovo…", "OptionNone": "Nessuno", - "OptionOnAppStartup": "All'avvio", "OptionOnInterval": "Su intervallo", "OptionParentalRating": "Classificazione per genitori", "OptionPlainStorageFolders": "Visualizzare tutte le cartelle come normali cartelle di archiviazione", @@ -967,20 +958,15 @@ "OptionResElement": "res element", "OptionResumable": "Interrotto", "OptionRuntime": "Durata", - "OptionSaturday": "Sabato", "OptionSaveMetadataAsHidden": "Salvare i metadati e le immagini come file nascosti", "OptionSaveMetadataAsHiddenHelp": "La modifica di questo si applicherà ai nuovi metadati che verranno salvati in avanti. I file di metadati esistenti verranno aggiornati la prossima volta che vengono salvati da Jellyfin Server.", "OptionSpecialEpisode": "Speciali", "OptionSubstring": "Sottostringa", - "OptionSunday": "Domenica", - "OptionThursday": "Giovedì", "OptionTrackName": "Titolo Traccia", - "OptionTuesday": "Martedì", "OptionTvdbRating": "Voto TVDB", "OptionUnairedEpisode": "Episodi mai andati in onda", "OptionUnplayed": "Non visto", "OptionWakeFromSleep": "Risveglio", - "OptionWednesday": "Mercoledì", "OptionWeekdays": "Feriali", "OptionWeekends": "Il Weekend", "OptionWeekly": "Settimanale", @@ -1122,7 +1108,6 @@ "TabDirectPlay": "Riproduzione Diretta", "TabEpisodes": "Episodi", "TabLatest": "Novità", - "TabLiveTV": "Tv in Diretta", "TabMusic": "Musica", "TabMusicVideos": "Video Musicali", "TabMyPlugins": "I miei Plug-in", @@ -1131,18 +1116,14 @@ "TabNotifications": "Notifiche", "TabOther": "Altro", "TabParentalControl": "Controllo Genitore", - "TabPlaylists": "Playlist", "TabProfile": "Profilo", "TabProfiles": "Profili", - "TabRecordings": "Registrazioni", "TabResponses": "Risposte", "TabResumeSettings": "Riprendi", "TabScheduledTasks": "Operazioni Pianificate", - "TabSeries": "Serie TV", "TabSettings": "Impostazioni", "TabTrailers": "Trailer", "TabUpcoming": "In Arrivo", - "TabUsers": "Utenti", "Tags": "Tag", "TellUsAboutYourself": "Parlaci di te", "ThemeSongs": "Temi canzoni", @@ -1362,7 +1343,6 @@ "TabInfo": "Informazioni", "TabLogs": "Log", "TabNetworking": "Rete", - "TabPassword": "Password", "TabPlugins": "Plugin", "TabServer": "Server", "TabStreaming": "Streaming", diff --git a/src/strings/ja.json b/src/strings/ja.json index 31f377875d..b3b97e3c28 100644 --- a/src/strings/ja.json +++ b/src/strings/ja.json @@ -356,8 +356,6 @@ "HeaderLibraryFolders": "ライブラリフォルダ", "HeaderLibraryOrder": "ライブラリの順番", "HeaderLibrarySettings": "ライブラリ設定", - "HeaderLiveTV": "ライブTV", - "HeaderLiveTv": "ライブTV", "HeaderLiveTvTunerSetup": "ライブTV チューナーのセットアップ", "HeaderLoginFailure": "ログイン失敗", "HeaderMedia": "メディア", @@ -372,7 +370,6 @@ "HeaderNewApiKey": "新規のAPIキー", "HeaderNewDevices": "新規のデバイス", "HeaderNextEpisodePlayingInValue": "次のエピソードの再生まで {0}", - "HeaderNextUp": "次", "HeaderNextVideoPlayingInValue": "次のビデオの再生まで{0}", "HeaderOnNow": "今", "HeaderOtherItems": "その他のアイテム", @@ -380,7 +377,6 @@ "HeaderPassword": "パスワード", "HeaderPasswordReset": "パスワードリセット", "HeaderPaths": "パス", - "HeaderPeople": "人", "HeaderPhotoAlbums": "フォトアルバム", "HeaderPinCodeReset": "PINコードのリセット", "HeaderPlayAll": "すべて再生", @@ -405,7 +401,6 @@ "HeaderRevisionHistory": "更新履歴", "HeaderRunningTasks": "実行中のタスク", "HeaderScenes": "シーン", - "HeaderSchedule": "スケジュール", "HeaderSeasons": "シーズン", "HeaderSecondsValue": "{0} 秒", "HeaderSelectCertificatePath": "証明書のパスを選択", @@ -418,7 +413,6 @@ "HeaderSelectTranscodingPath": "トランスコーディング用の一時パスの選択", "HeaderSelectTranscodingPathHelp": "トランスコードファイルの保存先を参照またはパスを入力してください。 フォルダは書き込み可能でなければなりません。", "HeaderSendMessage": "メッセージの送信", - "HeaderSeries": "シリーズ", "HeaderSeriesOptions": "シリーズオプション", "HeaderSeriesStatus": "シリーズの状態", "HeaderServerSettings": "サーバー設定", @@ -552,7 +546,6 @@ "OptionUnplayed": "未再生", "OptionUnairedEpisode": "未放送のエピソード", "OptionWakeFromSleep": "スリープから起動", - "OptionWednesday": "水曜日", "OptionWeekdays": "平日", "ParentalRating": "個人評価", "PasswordResetConfirmation": "本当にパスワードを再設定しますか?", @@ -572,7 +565,6 @@ "TabDirectPlay": "直接再生", "TabEpisodes": "エピソード", "LabelDefaultUser": "デフォルトユーザー:", - "TabSeries": "シリーズ", "Trailers": "トレーラー", "LabelRecord": "レコード:", "MediaInfoAnamorphic": "アナモフィック", @@ -602,7 +594,6 @@ "SeriesSettings": "シリーズ設計", "SeriesYearToPresent": "{0} - 現在", "SubtitleOffset": "字幕オフセット", - "TabPassword": "パスワード", "ThemeSongs": "テーマ曲", "ThemeVideos": "テーマビデオ", "ValueMusicVideoCount": "{0} ミュージックビデオ", @@ -660,12 +651,8 @@ "MessageImageFileTypeAllowed": "JPEGとPNGファイルのみサポートしています。", "NoSubtitleSearchResultsFound": "何も見つかりません。", "OptionRandom": "ランダム", - "OptionSaturday": "土曜日", "OptionSubstring": "字幕", - "OptionSunday": "日曜日", - "OptionThursday": "木曜日", "OptionTrackName": "トラック名", - "OptionTuesday": "火曜日", "OptionTvdbRating": "TVDB評価", "OptionWeekends": "休日", "Overview": "概要", @@ -727,7 +714,6 @@ "TabDashboard": "ダッシュボード", "TabInfo": "情報", "TabLatest": "最新", - "TabLiveTV": "ライブTV", "TabLogs": "ログ", "TabMusic": "ミュージック", "TabMusicVideos": "ミュージックビデオ", @@ -987,7 +973,6 @@ "OptionEnableExternalContentInSuggestions": "おすすめの欄に外部のコンテンツを使う", "OptionEnableM2tsMode": "M2TSモードを有効化", "OptionFavorite": "お気に入り", - "OptionFriday": "金曜日", "OptionHasSpecialFeatures": "特別な機能", "OptionHasSubtitles": "字幕", "OptionHasThemeSong": "テーマ曲", @@ -996,7 +981,6 @@ "OptionHideUser": "ログインスクリーンからこのユーザーを隠す", "OptionHomeVideos": "フォト", "OptionIsHD": "HD", - "OptionMonday": "月曜日", "OptionProtocolHls": "HTTPライブストリーミング", "MediaInfoDefault": "デフォルト", "OptionSpecialEpisode": "スペシャル", @@ -1010,7 +994,6 @@ "TabNotifications": "通知", "TabOther": "その他", "TabParentalControl": "ペアレンタルコントロール", - "TabPlaylists": "プレイリスト", "TabPlugins": "プラグイン", "TabProfile": "プロフィール", "TabProfiles": "プロフィール", @@ -1020,7 +1003,6 @@ "TabStreaming": "ストリーミング", "TabTrailers": "トレーラー", "MessageContactAdminToResetPassword": "パスワードをリセットするためにシステムの管理者に連絡してください。", - "TabUsers": "ユーザー", "TagsValue": "タグ: {0}", "MessageInvalidUser": "ユーザー名かパスワードが無効です。再試行してください。", "MessageYouHaveVersionInstalled": "バージョン {0} がインストールされています。", @@ -1052,7 +1034,6 @@ "LabelCustomDeviceDisplayNameHelp": "任意の表示名を提供するか、空白のままにしてデバイスネームで報告する。", "LabelArtistsHelp": "複数のアーティストは「;」で分ける。", "Identify": "識別する", - "TabRecordings": "録画", "Recordings": "録画", "RecordingScheduled": "録画をスケジュールしました。", "RecordingCancelled": "録画をキャンセルしました。", diff --git a/src/strings/kk.json b/src/strings/kk.json index ef542a0705..3f20e5ca10 100644 --- a/src/strings/kk.json +++ b/src/strings/kk.json @@ -343,8 +343,6 @@ "HeaderLibraryFolders": "Tasyǵyshhanalyq qaltalar", "HeaderLibraryOrder": "Tasyǵyshhana reti", "HeaderLibrarySettings": "Tasyǵyshhana parametrleri", - "HeaderLiveTV": "Efır", - "HeaderLiveTv": "Efırlik TD", "HeaderLiveTvTunerSetup": "Efırlik TD túnerdi ornatý", "HeaderLoginFailure": "Kirý sátsizdigi", "HeaderMedia": "Tasyǵyshderekter", @@ -360,7 +358,6 @@ "HeaderNewApiKey": "Jańa API-kilt", "HeaderNewDevices": "Jańa qurylǵylar", "HeaderNextEpisodePlayingInValue": "Kelesi bólim {0} ishinde oınatylady", - "HeaderNextUp": "Kezekti", "HeaderNextVideoPlayingInValue": "Kelesi beıne {0} ishinde oınatylady", "HeaderOnNow": "Efırde", "HeaderOtherItems": "Basqa tarmaqtar", @@ -368,7 +365,6 @@ "HeaderPassword": "Paról", "HeaderPasswordReset": "Paróldi ysyrý", "HeaderPaths": "Joldar", - "HeaderPeople": "Adamdar", "HeaderPhotoAlbums": "Fotoálbomdar", "HeaderPinCodeReset": "PIN-kodty ysyrý", "HeaderPlayAll": "Bárin oınatý", @@ -393,7 +389,6 @@ "HeaderRevisionHistory": "Ózgerister tarıhy", "HeaderRunningTasks": "Oryndalyp jatqan tapsyrmalar", "HeaderScenes": "Sahnalar", - "HeaderSchedule": "Is kestesi", "HeaderSeasons": "Maýsymdar", "HeaderSecondsValue": "{0} sekónd", "HeaderSelectCertificatePath": "Kýálik jolyn tańdaý", @@ -406,7 +401,6 @@ "HeaderSelectTranscodingPath": "Qaıta kodtaýdyń ýaqytsha faıldaryeyń jolyn tańdaý", "HeaderSelectTranscodingPathHelp": "Qaıta kodtaýdyń ýaqytsha faıldaryn paıdalaný úshin joldy sholyńyz nemese engizińiz. Osy qalta jazý úshin qol jetimdi bolýy qajet.", "HeaderSendMessage": "Habar jiberý", - "HeaderSeries": "Telehıkaıalar", "HeaderSeriesOptions": "Telehıkaıa opsıalary", "HeaderSeriesStatus": "Telehıkaıa kúıi", "HeaderServerSettings": "Server parametrleri", @@ -994,7 +988,6 @@ "OptionExternallyDownloaded": "Syrttan júktelgen", "OptionExtractChapterImage": "Sahna sýretin bólip alýdy qosý", "OptionFavorite": "Tańdaýlylar", - "OptionFriday": "juma", "OptionHasSpecialFeatures": "Arnaıy múmkindikter", "OptionHasSubtitles": "Sýbtıtrler", "OptionHasThemeSong": "Taqyryptyq áýen", @@ -1010,11 +1003,9 @@ "OptionLikes": "Unatýlar", "OptionMax": "Eń joǵary", "OptionMissingEpisode": "Joq bólimder", - "OptionMonday": "dúısenbi", "OptionNameSort": "Aty", "OptionNew": "Jańa…", "OptionNone": "Eshqandaı", - "OptionOnAppStartup": "Qoldanba iske qosylǵanda", "OptionOnInterval": "Aralyqta", "OptionParentalRating": "Jastas sanat", "OptionPlainStorageFolders": "Barlyq qaltalardy kádimgi saqtama qaltalary retinde beıneleý", @@ -1038,20 +1029,15 @@ "OptionRequirePerfectSubtitleMatchHelp": "Keremet sáıkestik talap etilgende tek qana naqty beıne faılyńyzben synaqtaýdan jáne tekserýden ótken sýbtıtrler súziledi. Belgini alastaý sýbtıtrlerdi júkteý yqtımaldyǵyn arttyrady, biraq qate ýaqyty bar nemese burys bolý sýbtıtrler mátininiń múmkindikterin ósiredi.", "OptionResumable": "Jalǵastyralatyn", "OptionRuntime": "Uzaqtyǵy", - "OptionSaturday": "senbi", "OptionSaveMetadataAsHidden": "Metaderekter men sýretterdi jasyryn faıldar retinde saqtaý", "OptionSaveMetadataAsHiddenHelp": "Osy ózgertý bolashaqta saqtalatyn jańa metaderekter úshin qoldanylady. Bar metaderek faıldar olar Jellyfin serveri arqyly saqtalǵanda kelesi joly jańartylady.", "OptionSpecialEpisode": "Arnaıy bólimder", "OptionSubstring": "Ishki jol", - "OptionSunday": "jeksenbi", - "OptionThursday": "beısenbi", "OptionTrackName": "Jolshyq aty", - "OptionTuesday": "seısenbi", "OptionTvdbRating": "TVDB baǵalaýy", "OptionUnairedEpisode": "Kórsetilmegen bólimder", "OptionUnplayed": "Oınatylmaǵan", "OptionWakeFromSleep": "Uıqydan oıatýda", - "OptionWednesday": "sársenbi", "OptionWeekdays": "Jumys kúnderi", "OptionWeekends": "Demalys kúnderi", "OptionWeekly": "Apta saıyn", @@ -1199,7 +1185,6 @@ "TabEpisodes": "TD-bólimder", "TabInfo": "Profaıl týraly", "TabLatest": "Eń keıingi", - "TabLiveTV": "Efırlik TD", "TabLogs": "Jurnaldar", "TabMusic": "Mýzyka", "TabMusicVideos": "Mýzykalyq beıneler", @@ -1209,22 +1194,17 @@ "TabNotifications": "Habarlandyrýlar", "TabOther": "Basqalar", "TabParentalControl": "Mazmundy basqarý", - "TabPassword": "Paról", - "TabPlaylists": "Oınatý tizimderi", "TabPlugins": "Plagınder", "TabProfile": "Profaıl", "TabProfiles": "Profaıldar", - "TabRecordings": "Jazbalar", "TabResponses": "Ún qatýlar", "TabResumeSettings": "Jalǵastyrý", "TabScheduledTasks": "Josparlaýshy", - "TabSeries": "Telehıkaıalar", "TabServer": "Server", "TabSettings": "Parametrler", "TabStreaming": "Tasymaldaný", "TabTrailers": "Treılerler", "TabUpcoming": "Kútilgen", - "TabUsers": "Paıdalanýshylar", "Tags": "Tegter", "TagsValue": "Tegter: {0}", "TellUsAboutYourself": "Ózińiz týraly aıtyńyz", diff --git a/src/strings/ko.json b/src/strings/ko.json index dcdb1f5a8f..62c924e517 100644 --- a/src/strings/ko.json +++ b/src/strings/ko.json @@ -155,8 +155,6 @@ "HeaderLibraryAccess": "라이브러리 접근", "HeaderLibraryFolders": "라이브러리 폴더", "HeaderLibrarySettings": "라이브러리 설정", - "HeaderLiveTV": "실시간 TV", - "HeaderLiveTv": "실시간 TV", "HeaderLoginFailure": "로그인 실패", "HeaderMedia": "미디어", "HeaderMediaFolders": "미디어 폴더", @@ -166,7 +164,6 @@ "HeaderMyMedia": "내 미디어", "HeaderMyMediaSmall": "내 미디어 (작음)", "HeaderNewApiKey": "새 API 키", - "HeaderNextUp": "다음으로", "HeaderParentalRatings": "자녀 보호 등급", "HeaderPassword": "비밀번호", "HeaderPasswordReset": "비밀번호 재설정", @@ -189,7 +186,6 @@ "HeaderRevisionHistory": "리비전 이력", "HeaderRunningTasks": "실행중인 작업", "HeaderScenes": "장면", - "HeaderSchedule": "일정", "HeaderSeasons": "시즌", "HeaderSelectMetadataPath": "메타데이터 경로 선택", "HeaderSelectMetadataPathHelp": "메타데이터를 보관할 경로를 탐색 또는 입력하세요. 쓰기 가능한 폴더여야 합니다.", @@ -200,7 +196,6 @@ "HeaderSelectTranscodingPath": "트랜스코딩 임시 경로 선택", "HeaderSelectTranscodingPathHelp": "트랜스코딩 임시 파일에 사용할 경로를 탐색 또는 입력하세요. 쓰기 가능한 폴더여야 합니다.", "HeaderSendMessage": "메시지 전송", - "HeaderSeries": "시리즈", "HeaderServerSettings": "서버 설정", "HeaderSettings": "설정", "HeaderSetupLibrary": "미디어 라이브러리 설정", @@ -554,7 +549,6 @@ "OptionEveryday": "매일", "OptionExternallyDownloaded": "외부 다운로드", "OptionFavorite": "즐겨찾기", - "OptionFriday": "금요일", "OptionHasSpecialFeatures": "특별한 기능", "OptionHasSubtitles": "자막", "OptionHasThemeSong": "테마송", @@ -569,10 +563,8 @@ "OptionLikes": "좋아함", "OptionMax": "최대", "OptionMissingEpisode": "누락된 에피소드", - "OptionMonday": "월요일", "OptionNameSort": "제목", "OptionNone": "없음", - "OptionOnAppStartup": "애플리케이션 시작할 때", "OptionOnInterval": "기간", "OptionParentalRating": "등급", "OptionPlainStorageFolders": "모든 폴더를 일반 저장소 폴더로 표시", @@ -591,18 +583,13 @@ "OptionResElement": "res 요소", "OptionResumable": "이어보기", "OptionRuntime": "상영 시간", - "OptionSaturday": "토요일", "OptionSaveMetadataAsHidden": "메타데이터와 이미지를 숨김 파일로 저장", "OptionSpecialEpisode": "스페셜", - "OptionSunday": "일요일", - "OptionThursday": "목요일", "OptionTrackName": "트랙 이름", - "OptionTuesday": "화요일", "OptionTvdbRating": "TVDb 평점", "OptionUnairedEpisode": "방송하지 않은 에피소드", "OptionUnplayed": "재생되지 않음", "OptionWakeFromSleep": "슬립모드에서 깨우기", - "OptionWednesday": "수요일", "OptionWeekdays": "주중", "OptionWeekends": "주말", "OptionWeekly": "주", @@ -665,7 +652,6 @@ "TabEpisodes": "에피소드", "TabInfo": "정보", "TabLatest": "최근", - "TabLiveTV": "실시간 TV", "TabLogs": "로그", "TabMusic": "음악", "TabMusicVideos": "뮤직비디오", @@ -674,21 +660,16 @@ "TabNotifications": "알림", "TabOther": "기타", "TabParentalControl": "자녀 보호", - "TabPassword": "비밀번호", - "TabPlaylists": "재생목록", "TabPlugins": "플러그인", "TabProfile": "프로필", "TabProfiles": "프로필", - "TabRecordings": "녹화", "TabResponses": "반응", "TabScheduledTasks": "예약 작업", - "TabSeries": "시리즈", "TabServer": "서버", "TabSettings": "설정", "TabStreaming": "스트리밍", "TabTrailers": "예고편", "TabUpcoming": "방송 예정", - "TabUsers": "사용자", "Tags": "태그", "TellUsAboutYourself": "자신에 대해 알려주세요", "ThisWizardWillGuideYou": "이 마법사는 설정 과정을 안내합니다. 시작하려면 선호하는 언어를 선택하세요.", @@ -1065,7 +1046,6 @@ "HeaderSortOrder": "정렬 순서", "HeaderSortBy": "정렬 기준", "HeaderRecordingPostProcessing": "녹화 후처리 작업", - "HeaderPeople": "사람들", "HeaderOtherItems": "다른 항목", "HeaderLibraryOrder": "라이브러리 순서", "HeaderDefaultRecordingSettings": "기본 녹화 설정", diff --git a/src/strings/lt-lt.json b/src/strings/lt-lt.json index 39277004a2..0d66a6456a 100644 --- a/src/strings/lt-lt.json +++ b/src/strings/lt-lt.json @@ -115,7 +115,6 @@ "HeaderMetadataSettings": "Metaduomenų nustatymai", "HeaderMoreLikeThis": "Daugiau panašių", "HeaderMusicVideos": "Muzikiniai klipai", - "HeaderNextUp": "Toliau eilėje", "HeaderPaths": "Keliai", "HeaderPleaseSignIn": "Prašau prisijungti", "HeaderPreferredMetadataLanguage": "Pageidaujama metaduomenų kalba", @@ -345,7 +344,6 @@ "OptionEnableAccessToAllLibraries": "Leisti prieigą prie visų bibliotekos", "OptionEnded": "Pasibaigė", "OptionFavorite": "Mėgstami", - "OptionFriday": "Penktadienis", "OptionHasSpecialFeatures": "Ypatingos serijos", "OptionHasSubtitles": "Subtitrai", "OptionHasThemeSong": "Teminė daina", @@ -359,10 +357,8 @@ "OptionIsSD": "SH", "OptionLikes": "Patinka", "OptionMissingEpisode": "Trūkstamos serijos", - "OptionMonday": "Pirmadienis", "OptionNameSort": "Vardas", "OptionNew": "Naujas...", - "OptionOnAppStartup": "Paleidus programą", "OptionOnInterval": "Pasikartojantis", "OptionParentalRating": "Tėvų reitingas", "OptionPlayCount": "Rodymų kiekis", @@ -371,17 +367,12 @@ "OptionReleaseDate": "Išleidimo data", "OptionResumable": "Pratęsiamas", "OptionRuntime": "Trukmė", - "OptionSaturday": "Šeštadienis", "OptionSpecialEpisode": "Ypatingos", - "OptionSunday": "Sekmadienis", - "OptionThursday": "Ketvirtadienis", "OptionTrackName": "Dainos pavadinimas", - "OptionTuesday": "Antradienis", "OptionTvdbRating": "Tvdb vertinimas", "OptionUnairedEpisode": "Nerodytos serijos", "OptionUnplayed": "Nerodyta", "OptionWakeFromSleep": "Žadinti iš miego", - "OptionWednesday": "Trečiadienis", "OptionWeekly": "Savaitinis", "OriginalAirDateValue": "Pirmo eterio data: {0}", "Overview": "Apžvalga", @@ -458,11 +449,8 @@ "TabNetworks": "Tinklai", "TabNotifications": "Pranešimai", "TabOther": "Kita", - "TabPassword": "Slaptažodis", "TabProfile": "Profilis", "TabProfiles": "Profiliai", - "TabRecordings": "Įrašai", - "TabSeries": "Laidos", "TabServer": "Serveris", "TabSettings": "Nustatymai", "TabTrailers": "Anonsai", @@ -657,7 +645,6 @@ "HeaderDeveloperInfo": "Kūrėjo informacija", "HeaderDevices": "Įrenginiai", "HeaderDirectPlayProfile": "Tiesioginio leidimo profilis", - "HeaderLiveTV": "TV gyvai", "ButtonTrailer": "Anonsas", "Depressed": "Spaudžiamas", "DirectPlaying": "Tiesioginis leidimas", @@ -706,7 +693,6 @@ "HeaderSelectTranscodingPath": "Išrinkite kelią į aplanką laikiniems perkodavimo failams", "HeaderSelectTranscodingPathHelp": "Suraskite arba įrašykite kelią serverio į aplanką laikinų perkodavimo failų saugojimui. Aplankalas turi būti su rašymo teise.", "HeaderSendMessage": "Siųsti žinutę", - "HeaderSeries": "Serialai", "HeaderSeriesStatus": "Serialo būsena", "HeaderServerSettings": "Serverio nustatymai", "HeaderSubtitleProfile": "Subtitrų profilis", @@ -846,7 +832,6 @@ "LabelPreferredSubtitleLanguage": "Pageidautina titrų kalba:", "HeaderChannelAccess": "Prieiga prie kanalų", "LabelProfileAudioCodecs": "Garso takelio kodekas:", - "HeaderLiveTv": "TV gyvai", "HeaderLiveTvTunerSetup": "Imtuvo nustatymai", "FetchingData": "Gaunami papildomi duomenys", "FileReadError": "Nuskaitant failą įvyko klaida.", @@ -925,7 +910,6 @@ "HeaderOnNow": "Gyvai dabar", "HeaderOtherItems": "Kiti elementai", "HeaderParentalRatings": "Amžiaus kategorijos", - "HeaderPeople": "Žmonės", "HeaderPhotoAlbums": "Nuotraukų albumai", "HeaderPinCodeReset": "Nustatyti PIN kodą iš naujo", "HeaderPlayAll": "Leisti visus", @@ -935,7 +919,6 @@ "HeaderProfile": "Profilis", "HeaderProfileInformation": "Apie profilį", "HeaderResponseProfileHelp": "Atsakymo profiliai suteikia galimybę pritaikyti prie prietaiso siunčiamą informaciją, kai grojama tam tikros rūšies medijos.", - "HeaderSchedule": "Tvarkaraštis", "HeaderSeasons": "Sezonai", "HeaderSecondsValue": "{0} s", "HeaderSelectMetadataPath": "Metaduomenų kelio išrinkimas", diff --git a/src/strings/lv.json b/src/strings/lv.json index e952b25fa9..ee712f615b 100644 --- a/src/strings/lv.json +++ b/src/strings/lv.json @@ -252,13 +252,11 @@ "HeaderServerSettings": "Servera Iestatījumi", "HeaderSeriesStatus": "Sēriju Status", "HeaderSeriesOptions": "Sēriju Opcijas", - "HeaderSeries": "Sērijas", "HeaderSendMessage": "Sūtīt Ziņojumu", "HeaderSelectServerCachePath": "Izvēlies Servera Keša Ceļu", "HeaderSelectServer": "Izvēlies Serveri", "HeaderSecondsValue": "{0} Sekundes", "HeaderSeasons": "Sezonas", - "HeaderSchedule": "Grafiks", "HeaderRevisionHistory": "Revīziju Vēsture", "HeaderRestart": "Restartēt", "HeaderRemoveMediaLocation": "Noņemt Multvides Atrašanās Vietu", @@ -273,12 +271,10 @@ "HeaderPlayAll": "Atskaņot Visu", "HeaderPinCodeReset": "Atiestatīt Pin Kodu", "HeaderPhotoAlbums": "Foto Albūmi", - "HeaderPeople": "Cilvēki", "HeaderPaths": "Ceļi", "HeaderPasswordReset": "Paroles Nomaiņa", "HeaderPassword": "Parole", "HeaderNextVideoPlayingInValue": "Nākamais Video tiks atskaņots pēc {0}", - "HeaderNextUp": "Nākamais", "HeaderNextEpisodePlayingInValue": "Nākamā Epizode tiks atskaņota pēc: {0}", "HeaderNewDevices": "Jaunas Ierīces", "HeaderNewApiKey": "Jauna API Atslēga", @@ -294,8 +290,6 @@ "HeaderMediaFolders": "Multvides Mapes", "HeaderMedia": "Multvide", "HeaderLiveTvTunerSetup": "Tiešraides TV Tūnera Uzstādīšana", - "HeaderLiveTv": "Tiešraides TV", - "HeaderLiveTV": "Tiešraides TV", "HeaderLibrarySettings": "Bibliotēku Iestatījumi", "HeaderLibraryOrder": "Bibliotēku Kārtojums", "HeaderLibraryFolders": "Bibliotēku Mapes", @@ -670,20 +664,15 @@ "TellUsAboutYourself": "Pastāsti mums par sevi", "TagsValue": "Tagi: {0}", "Tags": "Tagi", - "TabUsers": "Lietotāji", "TabTrailers": "Treileri", "TabStreaming": "Straumēšana", "TabSettings": "Iestatījumi", "TabServer": "Serveris", - "TabSeries": "Sērijas", "TabResumeSettings": "Turpināt", "TabResponses": "Atbildes", - "TabRecordings": "Ieraksti", "TabProfiles": "Profili", "TabProfile": "Profils", "TabPlugins": "Paplašinājumi", - "TabPlaylists": "Atskaņošanas Saraksti", - "TabPassword": "Parole", "TabParentalControl": "Vecāku Pārvaldība", "TabOther": "Cits", "TabNotifications": "Paziņojumi", @@ -694,7 +683,6 @@ "TabMusicVideos": "Mūzikas Video", "TabMusic": "Mūzika", "TabLogs": "Logs", - "TabLiveTV": "Tiešraides TV", "TabLatest": "Jaunākais", "TabInfo": "Info", "TabEpisodes": "Epizodes", @@ -748,14 +736,12 @@ "OptionOnInterval": "Pēc intervāla", "OptionNone": "Neviens", "OptionNew": "Jauns...", - "OptionMonday": "Pirmdien", "OptionList": "Saraksts", "OptionLikes": "Patīk", "OptionIsSD": "SD", "OptionIsHD": "HD", "OptionHasTrailer": "Treileris", "OptionHasSubtitles": "Subtitri", - "OptionFriday": "Piektdien", "OptionFavorite": "Favorīti", "OptionEveryday": "Katru dienu", "OptionEnded": "Beidzies", @@ -1083,16 +1069,11 @@ "OptionWeekly": "Iknedēļu", "OptionWeekends": "Nedēļas nogalēs", "OptionWeekdays": "Darba dienās", - "OptionWednesday": "Trešdiena", "OptionWakeFromSleep": "Modināt no miega", "OptionUnplayed": "Neatskaņots", - "OptionTuesday": "Otrdiena", "OptionTrackName": "Celiņa Nosaukums", "OptionThumb": "Sīktēls", - "OptionThursday": "Ceturtdiena", - "OptionSunday": "Svētdiena", "OptionSaveMetadataAsHidden": "Saglabāt metadatus un attēlus kā paslēptas datnes", - "OptionSaturday": "Sestdiena", "OptionRequirePerfectSubtitleMatch": "Lejupielādēt tikai subtitrus, kas perfekti sakrīt ar manām video datnēm", "OptionRegex": "Regex", "OptionProtocolHls": "HTTP Tiešraides Straumes", @@ -1100,7 +1081,6 @@ "OptionPremiereDate": "Pirmizrādes Datums", "OptionPoster": "Plakāts", "OptionPlayCount": "Atskaņošanas Skaits", - "OptionOnAppStartup": "Lietotnes sāknēšanā", "OptionNameSort": "Nosaukums", "OptionMissingEpisode": "Trūkstošās Epizodes", "OptionMax": "Maksimums", diff --git a/src/strings/ms.json b/src/strings/ms.json index 772cb3e043..786d2b7707 100644 --- a/src/strings/ms.json +++ b/src/strings/ms.json @@ -2,7 +2,6 @@ "ButtonSignOut": "Sign out", "Delete": "Padam", "FolderTypeTvShows": "TV", - "HeaderSeries": "Series", "LabelFinish": "Habis", "LabelYoureDone": "Kamu Selesai!", "ParentalRating": "Parental Rating", @@ -90,8 +89,6 @@ "Channels": "Saluran", "ButtonSyncPlay": "SyncPlay", "Movies": "Filem", - "HeaderNextUp": "Seterusnya", - "HeaderLiveTV": "TV Siaran Langsung", "HeaderFavoriteSongs": "Lagu-lagu Kegemaran", "HeaderFavoriteShows": "Rancangan-rancangan Kegemaran", "HeaderFavoriteEpisodes": "Episod-episod Kegemaran", diff --git a/src/strings/nb.json b/src/strings/nb.json index d9e0b3c8ec..66b383b616 100644 --- a/src/strings/nb.json +++ b/src/strings/nb.json @@ -269,14 +269,12 @@ "HeaderMyMediaSmall": "Min media (liten)", "HeaderNewApiKey": "Ny API-nøkkel", "HeaderNewDevices": "Nye enheter", - "HeaderNextUp": "Neste", "HeaderOnNow": "Spiller nå", "HeaderOtherItems": "Andre elementer", "HeaderParentalRatings": "Foreldresensur", "HeaderPassword": "Passord", "HeaderPasswordReset": "Tilbakestill passord", "HeaderPaths": "Filbaner", - "HeaderPeople": "Personer", "HeaderPinCodeReset": "Tilbakestill PIN-kode", "HeaderPlayAll": "Spill alle", "HeaderPlayOn": "Forsett avspilling", @@ -300,7 +298,6 @@ "HeaderRevisionHistory": "Revisjonshistorikk", "HeaderRunningTasks": "Kjørende oppgaver", "HeaderScenes": "Kapitler", - "HeaderSchedule": "Timeplan", "HeaderSeasons": "Sesonger", "HeaderSelectCertificatePath": "Velg sertifikatplassering", "HeaderSelectMetadataPath": "Velg metadataplassering", @@ -312,7 +309,6 @@ "HeaderSelectTranscodingPath": "Velg filbane for midlertidig lagring av omkodede filer", "HeaderSelectTranscodingPathHelp": "Bla eller skriv inn filbanen som skal brukes for midlertidig lagring av omkodede filer. Mappen må være skrivbar.", "HeaderSendMessage": "Send melding", - "HeaderSeries": "Serier", "HeaderSeriesOptions": "Serievalg", "HeaderServerSettings": "Serverinnstillinger", "HeaderSettings": "Innstillinger", @@ -792,7 +788,6 @@ "OptionExternallyDownloaded": "Ekstern nedlasting", "OptionExtractChapterImage": "Aktiver uthenting av kapittelbilder", "OptionFavorite": "Favoritter", - "OptionFriday": "Fredag", "OptionHasSpecialFeatures": "Spesialfunksjoner", "OptionHasSubtitles": "Undertekster", "OptionHasThemeSong": "Temasang", @@ -806,11 +801,9 @@ "OptionLikes": "Liker", "OptionMax": "Maks", "OptionMissingEpisode": "Manglende episoder", - "OptionMonday": "Mandag", "OptionNameSort": "Navn", "OptionNew": "Ny…", "OptionNone": "Ingen", - "OptionOnAppStartup": "Ved applikasjonsoppstart", "OptionOnInterval": "Per intervall", "OptionParentalRating": "Aldersgrense", "OptionPlainStorageFolders": "Vis alle mapper som enkle lagringsmapper", @@ -830,20 +823,15 @@ "OptionRequirePerfectSubtitleMatchHelp": "Å kreve en perfekt match vil filtrere bort undertekster slik at kun de som har blitt testet og verifisert mot nøyaktig samme video-fil gjenstår. Dersom du deaktiverer innstillingen øker sannsynligheten for at undertekster lastes ned, men sjansen øker også for at feilsynkronisert eller feilaktig undertekst lastes ned.", "OptionResumable": "Kan gjenopptas", "OptionRuntime": "Spilletid", - "OptionSaturday": "Lørdag", "OptionSaveMetadataAsHidden": "Lagre metadata og bilder som skjulte filer", "OptionSaveMetadataAsHiddenHelp": "Endring av denne innstillingen vil gjelde ny metadata som lagres fra nå av. Eksisterende metadata vil bli oppdatert neste gang de lagres av Jellyfin-serveren.", "OptionSpecialEpisode": "Spesialepisoder", "OptionSubstring": "Deltekst", - "OptionSunday": "Søndag", - "OptionThursday": "Torsdag", "OptionTrackName": "Låtnavn", - "OptionTuesday": "Tirsdag", "OptionTvdbRating": "TVDB-vurdering", "OptionUnairedEpisode": "Kommende episoder", "OptionUnplayed": "Ikke sett", "OptionWakeFromSleep": "Våkne fra dvale", - "OptionWednesday": "Onsdag", "OptionWeekdays": "Ukedager", "OptionWeekends": "Helger", "OptionWeekly": "Ukentlig", @@ -971,20 +959,15 @@ "TabNotifications": "Varslinger", "TabOther": "Annet", "TabParentalControl": "Foreldrekontroll", - "TabPassword": "Passord", - "TabPlaylists": "Spillelister", "TabPlugins": "Programtillegg", "TabProfile": "Profil", "TabProfiles": "Profiler", - "TabRecordings": "Opptak", "TabResponses": "Svar", "TabResumeSettings": "Fortsettelse", "TabScheduledTasks": "Planlagte oppgaver", - "TabSeries": "Serier", "TabSettings": "Innstillinger", "TabTrailers": "Trailere", "TabUpcoming": "Kommende", - "TabUsers": "Brukere", "Tags": "Tagger", "TellUsAboutYourself": "Fortell oss litt om deg selv", "ThisWizardWillGuideYou": "Denne veiviseren vil hjelpe deg gjennom installasjonsprosessen. Velg ønsket språk for å komme i gang.", @@ -1180,7 +1163,6 @@ "LabelAudioCodec": "Lydkodek:", "LabelAudioSampleRate": "Samplingsfrekvens for lyd:", "OptionRegex": "Regulært uttrykk", - "HeaderLiveTV": "Direkte-TV", "HeaderMedia": "Media", "LabelDropImageHere": "Dra og slipp bildet her, eller klikk for å bla igjennom.", "LabelMetadataSavers": "Lagring av metadata:", @@ -1228,7 +1210,6 @@ "HeaderFavoriteArtists": "Favorittartister", "HeaderFavoriteSongs": "Favorittsanger", "HeaderHome": "Hjem", - "HeaderLiveTv": "Direkte-TV", "HeaderNextEpisodePlayingInValue": "Neste episode starter om {0}", "HeaderNextVideoPlayingInValue": "Neste video starter om {0}", "HeaderSeriesStatus": "Seriestatus", @@ -1349,7 +1330,6 @@ "SubtitleOffset": "Forskyvet underteksting", "TV": "TV", "TabInfo": "Informasjon", - "TabLiveTV": "Direkte-TV", "TabNetworking": "Nettverk", "Trailers": "Trailere", "Transcoding": "Omkoding", diff --git a/src/strings/nl.json b/src/strings/nl.json index 5dee8dbf47..8d5e5c78a4 100644 --- a/src/strings/nl.json +++ b/src/strings/nl.json @@ -336,7 +336,6 @@ "HeaderNewApiKey": "Nieuwe API sleutel", "HeaderNewDevices": "Nieuwe Apparaten", "HeaderNextEpisodePlayingInValue": "Volgende Aflevering over {0}", - "HeaderNextUp": "Volgende", "HeaderNextVideoPlayingInValue": "Volgende Afgespeeld over {0}", "HeaderOnNow": "Aan het spelen", "HeaderOtherItems": "Overige Items", @@ -344,7 +343,6 @@ "HeaderPassword": "Wachtwoord", "HeaderPasswordReset": "Wachtwoord resetten", "HeaderPaths": "Paden", - "HeaderPeople": "Personen", "HeaderPhotoAlbums": "Foto-albums", "HeaderPinCodeReset": "Reset Pincode", "HeaderPlayAll": "Alles afspelen", @@ -369,7 +367,6 @@ "HeaderRevisionHistory": "Versie geschiedenis", "HeaderRunningTasks": "Actieve taken", "HeaderScenes": "Hoofdstukken", - "HeaderSchedule": "Schema", "HeaderSeasons": "Seizoenen", "HeaderSecondsValue": "{0} Seconden", "HeaderSelectCertificatePath": "Selecteer Certificaat Pad", @@ -382,7 +379,6 @@ "HeaderSelectTranscodingPath": "Selecteer Tijdelijke Transcodeer Pad", "HeaderSelectTranscodingPathHelp": "Blader of voer het pad in om te gebruiken voor het transcoderen van tijdelijke bestanden. De map moet schrijfbaar zijn.", "HeaderSendMessage": "Stuur bericht", - "HeaderSeries": "Series", "HeaderSeriesOptions": "Series Opties", "HeaderSeriesStatus": "Seriestatus", "HeaderServerSettings": "Server Instellingen", @@ -918,7 +914,6 @@ "OptionExternallyDownloaded": "Externe download", "OptionExtractChapterImage": "Inschakelen uitpakken van hoofdstuk afbeeldingen", "OptionFavorite": "Favorieten", - "OptionFriday": "Vrijdag", "OptionHasSpecialFeatures": "Extra's", "OptionHasSubtitles": "Ondertiteling", "OptionHasThemeSong": "Thema Lied", @@ -932,11 +927,9 @@ "OptionImdbRating": "IMDb Waardering", "OptionLikes": "Leuk", "OptionMissingEpisode": "Ontbrekende Afleveringen", - "OptionMonday": "Maandag", "OptionNameSort": "Naam", "OptionNew": "Nieuw…", "OptionNone": "Geen", - "OptionOnAppStartup": "Op applicatie start", "OptionOnInterval": "Op interval", "OptionParentalRating": "Kijkwijzer classificatie", "OptionPlainStorageFolders": "Alle mappen weergeven als gewone opslagmappen", @@ -956,19 +949,14 @@ "OptionRequirePerfectSubtitleMatchHelp": "Een perfecte match vereisen zal de ondertitels filteren om alleen ondertitels te downloaden die getest en geverifieerd zijn met je exacte videobestand. Dit uitvinken zal de kans om ondertitels te vinden vergroten, maar ook de kans op een niet gesynchroniseerd of foute ondertitel vergroten.", "OptionResumable": "Hervatbaar", "OptionRuntime": "Speelduur", - "OptionSaturday": "Zaterdag", "OptionSaveMetadataAsHidden": "Metagegevens en afbeeldingen opslaan als verborgen bestanden", "OptionSaveMetadataAsHiddenHelp": "Het veranderen van dit zal gelden voor nieuwe metadata die wordt opgeslagen. Bestaande metadata bestanden zullen de volgende keer dat ze worden opgeslagen door Jellyfin Server worden bijgewerkt.", "OptionSubstring": "Subtekenreeks", - "OptionSunday": "Zondag", - "OptionThursday": "Donderdag", "OptionTrackName": "Naam van Nummer", - "OptionTuesday": "Dinsdag", "OptionTvdbRating": "TVDB Waardering", "OptionUnairedEpisode": "Toekomstige Afleveringen", "OptionUnplayed": "Niet afgespeeld", "OptionWakeFromSleep": "Uit slaapstand halen", - "OptionWednesday": "Woensdag", "OptionWeekdays": "Week dagen", "OptionWeekends": "Weekend", "OptionWeekly": "Wekelijks", @@ -1117,18 +1105,13 @@ "TabNotifications": "Meldingen", "TabOther": "Overig", "TabParentalControl": "Ouderlijk toezicht", - "TabPassword": "Wachtwoord", - "TabPlaylists": "Afspeellijst", "TabProfile": "Profiel", "TabProfiles": "Profielen", - "TabRecordings": "Opnamen", "TabResponses": "Reacties", "TabResumeSettings": "Hervatten", "TabScheduledTasks": "Geplande taken", - "TabSeries": "Serie", "TabSettings": "Instellingen", "TabUpcoming": "Binnenkort op TV", - "TabUsers": "Gebruikers", "Tags": "Labels", "TagsValue": "Labels: {0}", "TellUsAboutYourself": "Vertel ons over uzelf", @@ -1205,7 +1188,6 @@ "HeaderCastAndCrew": "Acteurs en medewerkers", "HeaderCastCrew": "Acteurs & medewerkers", "Art": "Afbeeldingen", - "HeaderLiveTV": "Live TV", "HeaderHttpHeaders": "HTTP Headers", "HeaderStatus": "Status", "AuthProviderHelp": "Selecteer een authenticatie provider om het wachtwoord van deze gebruiker te verifiëren.", @@ -1217,7 +1199,6 @@ "HeaderFavoriteSongs": "Favoriete nummers", "HeaderFavoriteVideos": "Favoriete Films", "HeaderInstantMix": "Directe Mix", - "HeaderLiveTv": "Live TV", "HeaderMedia": "Media", "HeaderTracks": "Nummers", "HeaderTuners": "Stemmers", @@ -1243,7 +1224,6 @@ "LabelSize": "Grootte:", "CopyStreamURLSuccess": "URL succesvol gekopieerd.", "CopyStreamURL": "Kopieer Stream URL", - "TabLiveTV": "Live TV", "ValueAlbumCount": "{0} albums", "FetchingData": "Meer data op aan het halen", "HeaderFavoriteBooks": "Favoriete Boeken", diff --git a/src/strings/pl.json b/src/strings/pl.json index d4f88b4b44..cb23cf40e6 100644 --- a/src/strings/pl.json +++ b/src/strings/pl.json @@ -341,8 +341,6 @@ "HeaderLibraryFolders": "Foldery biblioteki", "HeaderLibraryOrder": "Kolejność biblioteki", "HeaderLibrarySettings": "Ustawienia biblioteki", - "HeaderLiveTV": "Telewizja", - "HeaderLiveTv": "Telewizja", "HeaderLiveTvTunerSetup": "Konfiguracja tunera telewizyjnego", "HeaderLoginFailure": "Niepowodzenie logowania", "HeaderMedia": "Multimedia", @@ -358,7 +356,6 @@ "HeaderNewApiKey": "Nowy Klucz API", "HeaderNewDevices": "Nowe urządzenia", "HeaderNextEpisodePlayingInValue": "Następne odcinek za {0}", - "HeaderNextUp": "Do obejrzenia", "HeaderNextVideoPlayingInValue": "Następne wideo za {0}", "HeaderOnNow": "Teraz", "HeaderOtherItems": "Inne pozycje", @@ -366,7 +363,6 @@ "HeaderPassword": "Hasło", "HeaderPasswordReset": "Czyszczenie hasła", "HeaderPaths": "Foldery", - "HeaderPeople": "Osoby", "HeaderPhotoAlbums": "Albumy fotografii", "HeaderPinCodeReset": "Wyczyść kod PIN", "HeaderPlayAll": "Odtwarzaj wszystko", @@ -391,7 +387,6 @@ "HeaderRevisionHistory": "Historia zmian", "HeaderRunningTasks": "Uruchomione zadania", "HeaderScenes": "Sceny", - "HeaderSchedule": "Harmonogram", "HeaderSeasons": "Sezony", "HeaderSecondsValue": "{0} sekund", "HeaderSelectCertificatePath": "Wybierz folder certyfikatu", @@ -404,7 +399,6 @@ "HeaderSelectTranscodingPath": "Wybierz folder tymczasowy transkodowania", "HeaderSelectTranscodingPathHelp": "Przeglądaj lub wprowadź folder plików tymczasowych transkodowania. Folder musi umożliwiać zapis plików.", "HeaderSendMessage": "Wyślij wiadomość", - "HeaderSeries": "Seriale", "HeaderSeriesOptions": "Opcje nagrywania serialu", "HeaderSeriesStatus": "Stan serialu", "HeaderServerSettings": "Ustawienia serwera", @@ -984,7 +978,6 @@ "OptionExternallyDownloaded": "Pobieranie zewnętrzne", "OptionExtractChapterImage": "Wydobywaj obrazy rozdziałów", "OptionFavorite": "Ulubione", - "OptionFriday": "Piątek", "OptionHasSpecialFeatures": "Funkcje Specjalne", "OptionHasSubtitles": "Napisy", "OptionHasThemeSong": "Piosenka Przewodnia", @@ -1000,11 +993,9 @@ "OptionLikes": "Lubie", "OptionMax": "Maksymalny", "OptionMissingEpisode": "Brakujące Odcinki", - "OptionMonday": "Poniedziałek", "OptionNameSort": "Nazwa", "OptionNew": "Nowa…", "OptionNone": "Brak", - "OptionOnAppStartup": "Podczas uruchomienia aplikacji", "OptionOnInterval": "Cyklicznie", "OptionParentalRating": "Kategoria wiekowa", "OptionPlainStorageFolders": "Wyświetlaj wszystkie foldery jako zwyczajne foldery", @@ -1029,20 +1020,15 @@ "OptionResElement": "Element res", "OptionResumable": "Do wznowienia", "OptionRuntime": "Długość filmu", - "OptionSaturday": "Sobota", "OptionSaveMetadataAsHidden": "Zapisuj metadane i obrazy jako pliki ukryte", "OptionSaveMetadataAsHiddenHelp": "Zmiana ta będzie miała zastosowanie do nowych metadanych zapisanych w przyszłości. Istniejące pliki metadanych zostaną zaktualizowane przy następnym zapisie przez serwer.", "OptionSpecialEpisode": "Specjalne", "OptionSubstring": "Podwyrażenie", - "OptionSunday": "Niedziela", - "OptionThursday": "Czwartek", "OptionTrackName": "Nazwa utworu", - "OptionTuesday": "Wtorek", "OptionTvdbRating": "Ocena TVDB", "OptionUnairedEpisode": "Odcinki o planowanej emisji", "OptionUnplayed": "Nieobejrzany", "OptionWakeFromSleep": "Wybudź z uspienia", - "OptionWednesday": "Środa", "OptionWeekdays": "Dni Tygodnia", "OptionWeekends": "Weekendy", "OptionWeekly": "Cotygodniowo", @@ -1190,7 +1176,6 @@ "TabEpisodes": "Odcinki", "TabInfo": "Informacje", "TabLatest": "Ostatnio dodane", - "TabLiveTV": "Telewizja", "TabLogs": "Dziennik zdarzeń", "TabMusic": "Muzyka", "TabMusicVideos": "Teledyski", @@ -1200,22 +1185,17 @@ "TabNotifications": "Powiadomienia", "TabOther": "Inne", "TabParentalControl": "Kontrola rodzicielska", - "TabPassword": "Hasło", - "TabPlaylists": "Listy odtwarzania", "TabPlugins": "Wtyczki", "TabProfile": "Profil", "TabProfiles": "Profile", - "TabRecordings": "Nagrania", "TabResponses": "Odpowiedzi", "TabResumeSettings": "Wznawianie", "TabScheduledTasks": "Harmonogram zadań", - "TabSeries": "Seriale", "TabServer": "Serwer", "TabSettings": "Ustawienia", "TabStreaming": "Transmitowanie", "TabTrailers": "Zwiastuny", "TabUpcoming": "Wkrótce", - "TabUsers": "Użytkownicy", "Tags": "Znaczniki", "TagsValue": "Znaczniki: {0}", "TellUsAboutYourself": "Opowiedz nam o sobie", diff --git a/src/strings/pt-br.json b/src/strings/pt-br.json index 71913399f6..25f6afd31e 100644 --- a/src/strings/pt-br.json +++ b/src/strings/pt-br.json @@ -329,8 +329,6 @@ "HeaderLibraryFolders": "Pastas da Biblioteca", "HeaderLibraryOrder": "Ordem da Biblioteca", "HeaderLibrarySettings": "Configurações da Biblioteca", - "HeaderLiveTV": "TV ao Vivo", - "HeaderLiveTv": "TV ao Vivo", "HeaderLiveTvTunerSetup": "Configuração do Sintonizador da TV ao Vivo", "HeaderLoginFailure": "Falha no Login", "HeaderMedia": "Mídia", @@ -346,7 +344,6 @@ "HeaderNewApiKey": "Nova Chave de API", "HeaderNewDevices": "Novos Dispositivos", "HeaderNextEpisodePlayingInValue": "Reproduzindo Próximo Episódio em {0}", - "HeaderNextUp": "A Seguir", "HeaderNextVideoPlayingInValue": "Reproduzindo Próximo Vídeo em {0}", "HeaderOnNow": "Em Exibição", "HeaderOtherItems": "Outros Itens", @@ -354,7 +351,6 @@ "HeaderPassword": "Senha", "HeaderPasswordReset": "Redefinição de Senha", "HeaderPaths": "Locais", - "HeaderPeople": "Pessoas", "HeaderPhotoAlbums": "Álbuns de Fotos", "HeaderPinCodeReset": "Redefinir Código Pin", "HeaderPlayAll": "Reproduzir Tudo", @@ -379,7 +375,6 @@ "HeaderRevisionHistory": "Histórico de Versões", "HeaderRunningTasks": "Tarefas em Execução", "HeaderScenes": "Cenas", - "HeaderSchedule": "Programação", "HeaderSeasons": "Temporadas", "HeaderSecondsValue": "{0} Segundos", "HeaderSelectCertificatePath": "Selecionar Local do Certificado", @@ -392,7 +387,6 @@ "HeaderSelectTranscodingPath": "Selecionar Local Temporário da Transcodificação", "HeaderSelectTranscodingPathHelp": "Navegue ou digite o local para usar para arquivos temporários de transcodificação. A pasta deve ter permissão de gravação.", "HeaderSendMessage": "Enviar Mensagem", - "HeaderSeries": "Séries", "HeaderSeriesOptions": "Opções da Série", "HeaderSeriesStatus": "Status da Série", "HeaderServerSettings": "Configurações de Servidor", @@ -956,7 +950,6 @@ "OptionExternallyDownloaded": "Download externo", "OptionExtractChapterImage": "Ativar extração de imagens de capítulos", "OptionFavorite": "Favoritos", - "OptionFriday": "Sexta-feira", "OptionHasSpecialFeatures": "Recursos Especiais", "OptionHasSubtitles": "Legendas", "OptionHasThemeSong": "Música-Tema", @@ -971,11 +964,9 @@ "OptionLikes": "Curtidas", "OptionMax": "Máx", "OptionMissingEpisode": "Episódios em Falta", - "OptionMonday": "Segunda-feira", "OptionNameSort": "Nome", "OptionNew": "Novo…", "OptionNone": "Nenhum", - "OptionOnAppStartup": "Ao iniciar a aplicação", "OptionOnInterval": "Em um intervalo", "OptionParentalRating": "Classificação Etária", "OptionPlainStorageFolders": "Exibir todas as pastas como pastas de armazenamento", @@ -997,19 +988,14 @@ "OptionResElement": "elemento res", "OptionResumable": "Retomável", "OptionRuntime": "Duração", - "OptionSaturday": "Sábado", "OptionSaveMetadataAsHidden": "Salvar metadados e imagens como arquivos ocultos", "OptionSaveMetadataAsHiddenHelp": "Isto será aplicado sobre novos metadados salvos. Os arquivos de metadados existentes serão atualizados na próxima vez que forem salvos no Servidor Jellyfin.", "OptionSpecialEpisode": "Especiais", - "OptionSunday": "Domingo", - "OptionThursday": "Quinta-feira", "OptionTrackName": "Nome da Faixa", - "OptionTuesday": "Terça-feira", "OptionTvdbRating": "Avaliação TVDB", "OptionUnairedEpisode": "Episódios a Estrear", "OptionUnplayed": "Não reproduzido", "OptionWakeFromSleep": "Despertar da hibernação", - "OptionWednesday": "Quarta-feira", "OptionWeekdays": "Dias da semana", "OptionWeekends": "Fins de semana", "OptionWeekly": "Semanal", @@ -1150,7 +1136,6 @@ "TabDirectPlay": "Reprodução Direta", "TabEpisodes": "Episódios", "TabLatest": "Recentes", - "TabLiveTV": "TV ao Vivo", "TabMusic": "Música", "TabMusicVideos": "Videoclipes", "TabMyPlugins": "Meus Plugins", @@ -1159,19 +1144,14 @@ "TabNotifications": "Notificações", "TabOther": "Outros", "TabParentalControl": "Controle dos Pais", - "TabPassword": "Senha", - "TabPlaylists": "Listas de Reprodução", "TabProfile": "Perfil", "TabProfiles": "Perfis", - "TabRecordings": "Gravações", "TabResponses": "Respostas", "TabResumeSettings": "Retomar", "TabScheduledTasks": "Tarefas Agendadas", - "TabSeries": "Séries", "TabServer": "Servidor", "TabSettings": "Configurações", "TabUpcoming": "A Seguir", - "TabUsers": "Usuários", "TellUsAboutYourself": "Conte-nos sobre você", "ThemeSongs": "Músicas-tema", "ThemeVideos": "Vídeos-tema", diff --git a/src/strings/pt-pt.json b/src/strings/pt-pt.json index 2d6890ff6d..02fa88aaf6 100644 --- a/src/strings/pt-pt.json +++ b/src/strings/pt-pt.json @@ -155,8 +155,6 @@ "HeaderLibraryAccess": "Acesso à Biblioteca", "HeaderLibraryFolders": "Pastas Multimédia", "HeaderLibrarySettings": "Configurações da Biblioteca", - "HeaderLiveTV": "TV em Direto", - "HeaderLiveTv": "TV em Direto", "HeaderLoginFailure": "Falha no Login", "HeaderMedia": "Multimédia", "HeaderMediaFolders": "Pastas Multimédia", @@ -165,12 +163,10 @@ "HeaderMusicVideos": "Videoclips", "HeaderMyMedia": "O Meu Conteúdo", "HeaderNewApiKey": "Nova Chave da API", - "HeaderNextUp": "A Seguir", "HeaderParentalRatings": "Classificações Parentais", "HeaderPassword": "Palavra-passe", "HeaderPasswordReset": "Redefinição de Palavra-Passe", "HeaderPaths": "Localizações", - "HeaderPeople": "Pessoas", "HeaderPinCodeReset": "Redefinir Código PIN", "HeaderPlayAll": "Reproduzir Todos", "HeaderPlayback": "Reprodução de Multimédia", @@ -190,7 +186,6 @@ "HeaderRevisionHistory": "Histórico de Versões", "HeaderRunningTasks": "Tarefas em Execução", "HeaderScenes": "Cenas", - "HeaderSchedule": "Agendamentos", "HeaderSelectCertificatePath": "Selecione a Localização do Certificado", "HeaderSelectMetadataPath": "Selecione a Localização dos Metadados", "HeaderSelectMetadataPathHelp": "Procure ou introduza a localização da pasta para guardar os metadados. O Servidor Jellyfin deve ter acesso de escrita a essa pasta.", @@ -201,7 +196,6 @@ "HeaderSelectTranscodingPath": "Selecione o Local Temporário da Transcodificação", "HeaderSelectTranscodingPathHelp": "Procure ou introduza a localização da pasta para guardar os ficheiros temporários de transcodificação. O Servidor Jellyfin deve ter acesso de escrita a essa pasta.", "HeaderSendMessage": "Enviar mensagem", - "HeaderSeries": "Série", "HeaderServerSettings": "Configurações do Servidor", "HeaderSettings": "Configurações", "HeaderSetupLibrary": "Configurar Bibliotecas Multimédia", @@ -555,7 +549,6 @@ "OptionEveryday": "Todos os dias", "OptionExternallyDownloaded": "Download Externo", "OptionFavorite": "Favoritos", - "OptionFriday": "Sexta", "OptionHasSpecialFeatures": "Extras", "OptionHasSubtitles": "Legendas", "OptionHasThemeSong": "Música de Tema", @@ -569,11 +562,9 @@ "OptionLikes": "Gostos", "OptionMax": "Máx", "OptionMissingEpisode": "Episódios em Falta", - "OptionMonday": "Segunda", "OptionNameSort": "Nome", "OptionNew": "Nova…", "OptionNone": "Nenhum", - "OptionOnAppStartup": "Ao iniciar a aplicação", "OptionOnInterval": "Num intervalo", "OptionParentalRating": "Classificação Parental", "OptionPlainStorageFolders": "Mostrar todas as pastas como pastas de armazenamento simples", @@ -593,18 +584,13 @@ "OptionResElement": "elemento res", "OptionResumable": "Retomável", "OptionRuntime": "Duração", - "OptionSaturday": "Sábado", "OptionSaveMetadataAsHidden": "Guardar metadados e imagens como ficheiros ocultos", "OptionSpecialEpisode": "Especiais", - "OptionSunday": "Domingo", - "OptionThursday": "Quinta", "OptionTrackName": "Nome da pista", - "OptionTuesday": "Terça", "OptionTvdbRating": "Classificação no TVDB", "OptionUnairedEpisode": "Episódios por Estrear", "OptionUnplayed": "Por reproduzir", "OptionWakeFromSleep": "Retomar da suspensão", - "OptionWednesday": "Quarta", "OptionWeekdays": "Dias da semana", "OptionWeekends": "Fins-de-semana", "OptionWeekly": "Semanalmente", @@ -657,7 +643,6 @@ "TabDirectPlay": "Reprodução Direta", "TabEpisodes": "Episódios", "TabLatest": "Mais recente", - "TabLiveTV": "TV em Direto", "TabMusic": "Música", "TabMusicVideos": "Videoclips", "TabMyPlugins": "As Minhas Extensões", @@ -666,19 +651,14 @@ "TabNotifications": "Notificações", "TabOther": "Outro", "TabParentalControl": "Controlo Parental", - "TabPassword": "Palavra-passe", - "TabPlaylists": "Listas de Reprodução", "TabPlugins": "Extensões", "TabProfile": "Perfil", "TabProfiles": "Perfis", - "TabRecordings": "Gravações", "TabResponses": "Respostas", "TabScheduledTasks": "Tarefas Agendadas", - "TabSeries": "Séries", "TabServer": "Servidor", "TabSettings": "Configurações", "TabUpcoming": "Próximos", - "TabUsers": "Utilizadores", "TellUsAboutYourself": "Fale-nos sobre si", "ThisWizardWillGuideYou": "Este assistente irá ajudá-lo durante o processo de configuração. Para começar, selecione o idioma.", "Thursday": "Quinta", diff --git a/src/strings/pt.json b/src/strings/pt.json index 324f08a064..95842bb22a 100644 --- a/src/strings/pt.json +++ b/src/strings/pt.json @@ -33,20 +33,15 @@ "Thursday": "Quinta", "ThisWizardWillGuideYou": "Este assistente ajudá-lo-á durante o processo de configuração. Para começar, selecione o idioma.", "TellUsAboutYourself": "Fale-nos sobre si", - "TabUsers": "Utilizadores", "TabUpcoming": "Próximos", "TabStreaming": "Transmissão", "TabSettings": "Configurações", "TabServer": "Servidor", - "TabSeries": "Séries", "TabScheduledTasks": "Tarefas Agendadas", "TabResponses": "Respostas", - "TabRecordings": "Gravações", "TabProfiles": "Perfis", "TabProfile": "Perfil", "TabPlugins": "Extensões", - "TabPlaylists": "Listas de Reprodução", - "TabPassword": "Palavra-passe", "TabParentalControl": "Controlo Parental", "TabOther": "Outro", "TabNotifications": "Notificações", @@ -55,7 +50,6 @@ "TabMyPlugins": "As Minhas Extensões", "TabMusicVideos": "Videoclips", "TabMusic": "Música", - "TabLiveTV": "TV em Directo", "TabLatest": "Mais recente", "TabEpisodes": "Episódios", "TabDirectPlay": "Reprodução Directa", @@ -156,19 +150,14 @@ "OptionWeekly": "Semanalmente", "OptionWeekends": "Fins-de-semana", "OptionWeekdays": "Dias da semana", - "OptionWednesday": "Quarta", "OptionWakeFromSleep": "Retomar da suspensão", "OptionUnplayed": "Por reproduzir", "OptionUnairedEpisode": "Episódios por Estrear", "OptionTvdbRating": "Classificação no TVDB", - "OptionTuesday": "Terça", "OptionTrackName": "Nome da pista", - "OptionThursday": "Quinta", - "OptionSunday": "Domingo", "OptionSubstring": "Subcadeia", "OptionSpecialEpisode": "Especiais", "OptionSaveMetadataAsHidden": "Guardar metadados e imagens como ficheiros ocultos", - "OptionSaturday": "Sábado", "OptionRuntime": "Duração", "OptionResumable": "Retomável", "OptionResElement": "elemento res", @@ -190,7 +179,6 @@ "OptionPlainStorageFolders": "Mostrar todas as pastas como simples pastas de armazenamento", "OptionParentalRating": "Classificação Parental", "OptionOnInterval": "Num intervalo", - "OptionOnAppStartup": "Ao iniciar a aplicação", "OptionNone": "Nenhum", "OptionNew": "Nova...", "OptionNameSort": "Nome", @@ -501,7 +489,6 @@ "HeaderServerSettings": "Configurações do Servidor", "HeaderSeriesStatus": "Estado da Série", "HeaderSeriesOptions": "Opções da Série", - "HeaderSeries": "Série", "HeaderSendMessage": "Enviar mensagem", "HeaderSelectTranscodingPathHelp": "Procure ou introduza a localização da pasta para guardar os ficheiros temporários de transcodificação. O Servidor Jellyfin deve ter acesso de escrita a essa pasta.", "HeaderSelectTranscodingPath": "Seleccione o Local Temporário da Transcodificação", @@ -514,7 +501,6 @@ "HeaderSelectCertificatePath": "Seleccione a Localização do Certificado", "HeaderSecondsValue": "{0} Segundos", "HeaderSeasons": "Temporadas", - "HeaderSchedule": "Agendamentos", "HeaderScenes": "Cenas", "HeaderRunningTasks": "Tarefas em Execução", "HeaderRevisionHistory": "Histórico de Versões", @@ -539,7 +525,6 @@ "HeaderPlayAll": "Reproduzir Todos", "HeaderPinCodeReset": "Redefinir Código PIN", "HeaderPhotoAlbums": "Álbuns de Fotografias", - "HeaderPeople": "Pessoas", "HeaderPaths": "Localizações", "HeaderPasswordReset": "Redefinição de Palavra-Passe", "HeaderPassword": "Palavra-passe", @@ -547,7 +532,6 @@ "HeaderOtherItems": "Outros Itens", "HeaderOnNow": "No Ar", "HeaderNextVideoPlayingInValue": "Reprodução do próximo vídeo começa em {0}", - "HeaderNextUp": "A Seguir", "HeaderNextEpisodePlayingInValue": "Reprodução do próximo episódio começa em {0}", "HeaderNewDevices": "Novos Dispositivos", "HeaderNewApiKey": "Nova Chave da API", @@ -562,8 +546,6 @@ "HeaderMediaFolders": "Pastas Multimédia", "HeaderMedia": "Multimédia", "HeaderLiveTvTunerSetup": "Configurar Sintonizador de TV", - "HeaderLiveTv": "TV ao Vivo", - "HeaderLiveTV": "TV em Directo", "HeaderLibrarySettings": "Configurações da Biblioteca", "HeaderLibraryOrder": "Ordenação da Biblioteca", "HeaderLibraryFolders": "Pastas Multimédia", @@ -971,7 +953,6 @@ "ButtonChangeServer": "Alterar Servidor", "ButtonCancel": "Cancelar", "ButtonBack": "Voltar", - "OptionMonday": "Segunda", "OptionMissingEpisode": "Episódios em Falta", "OptionMax": "Máximo", "OptionLikes": "Gostos", @@ -984,7 +965,6 @@ "OptionHasThemeSong": "Música de Tema", "OptionHasSubtitles": "Legendas", "OptionHasSpecialFeatures": "Extras", - "OptionFriday": "Sexta", "OptionFavorite": "Favoritos", "OptionExternallyDownloaded": "Download Externo", "OptionEveryday": "Todos os dias", diff --git a/src/strings/ro.json b/src/strings/ro.json index 7fcce88aa2..6eeeeba01f 100644 --- a/src/strings/ro.json +++ b/src/strings/ro.json @@ -41,13 +41,11 @@ "HeaderLatestEpisodes": "Cele Mai Noi Episoade", "HeaderLatestMovies": "Cele mai noi Filme", "HeaderLatestRecordings": "Cele mai recente înregistrări", - "HeaderNextUp": "Urmează", "HeaderPaths": "Căi", "HeaderPleaseSignIn": "Vă rugăm, autentificați-vă", "HeaderPreferredMetadataLanguage": "Limba preferata pentru metadata", "HeaderRecentlyPlayed": "Rulate Recent", "HeaderRemoteControl": "Control la distanță", - "HeaderSeries": "Seriale", "HeaderSetupLibrary": "Configurați-vă bibliotecile media", "HeaderTaskTriggers": "Declanșatori Sarcini", "HeaderUsers": "Utilizatori", @@ -137,7 +135,6 @@ "OptionEnableAccessToAllLibraries": "Activează accesul la toate bibliotecile", "OptionEnded": "Anulat", "OptionFavorite": "Favorite", - "OptionFriday": "Vineri", "OptionHasSpecialFeatures": "Caracteristici Speciale", "OptionHasSubtitles": "Subtitrări", "OptionHasThemeSong": "Audio de Fundal", @@ -146,7 +143,6 @@ "OptionHideUserFromLoginHelp": "Folositor pentru conturi private sau de administrator ascunse. Utilizatorul va trebui să se conecteze manual prin introducerea numelui de utilizator și a parolei.", "OptionImdbRating": "Rating IMDb", "OptionLikes": "Like-uri", - "OptionMonday": "Luni", "OptionNameSort": "Nume", "OptionParentalRating": "Limită de vârstă", "OptionPlayCount": "Contorizare rulări", @@ -155,13 +151,8 @@ "OptionReleaseDate": "Dată Lansare", "OptionResumable": "Poate fi continuat", "OptionRuntime": "Timp Rulare", - "OptionSaturday": "Sâmbătă", - "OptionSunday": "Duminică", - "OptionThursday": "Joi", "OptionTrackName": "Nume melodie", - "OptionTuesday": "Marți", "OptionUnplayed": "Nerulat", - "OptionWednesday": "Miercuri", "ParentalRating": "Parental Rating", "Saturday": "Sâmbătă", "Save": "Salveaza", @@ -178,11 +169,8 @@ "TabNetworks": "Rețele TV", "TabNotifications": "Notificări", "TabOther": "Altele", - "TabPassword": "Parolă", "TabProfile": "Profil", "TabProfiles": "Profile", - "TabRecordings": "Înregistrări", - "TabSeries": "Seriale", "TabSettings": "Setări", "TabTrailers": "Trailere", "TabUpcoming": "Urmează să apară", @@ -429,7 +417,6 @@ "HeaderParentalRatings": "Evaluări parentale", "HeaderPassword": "Parolă", "HeaderPasswordReset": "Resetare Parolă", - "HeaderPeople": "Persoane", "HeaderPhotoAlbums": "Albume Fotografii", "HeaderPinCodeReset": "Resetare cod PIN", "HeaderPlayAll": "Redare tot", @@ -448,7 +435,6 @@ "HeaderRevisionHistory": "Istoricul reviziilor", "HeaderRunningTasks": "În desfășurare", "HeaderScenes": "Scene", - "HeaderSchedule": "Planificare", "HeaderSeasons": "Sezoane", "HeaderSecondsValue": "{0} Secunde", "HeaderSelectCertificatePath": "Selectați ruta certificatului", @@ -487,7 +473,6 @@ "HeaderKeepSeries": "Păstrează seriile", "HeaderLatestMedia": "Cele mai recente media", "HeaderLibraryOrder": "Ordinea Bibliotecii", - "HeaderLiveTv": "TV în Direct", "HeaderContinueListening": "Continuați să ascultați", "Down": "In jos", "EveryNDays": "La fiecare {0} zile", @@ -505,7 +490,6 @@ "Folders": "Dosare", "HeaderAlbumArtists": "Album Artiști", "HeaderFavoriteSongs": "Melodii Favorite", - "HeaderLiveTV": "TV în Direct", "Movies": "Filme", "Playlists": "Liste redare", "Shows": "Spectacole", @@ -1259,7 +1243,6 @@ "OptionPlainStorageFoldersHelp": "Toate dosarele sunt reprezentate în DIDL ca „object.container.storageFolder” în loc de un tip mai specific, cum ar fi „object.container.person.musicArtist”.", "OptionPlainStorageFolders": "Afișați toate dosarele ca dosare simple de stocare", "OptionOnInterval": "La un interval", - "OptionOnAppStartup": "La pornirea aplicației", "OptionNone": "Nici unul", "OptionNew": "Nou…", "OptionMissingEpisode": "Episoade lipsă", @@ -1351,19 +1334,16 @@ "ThemeSongs": "Melodiile temei", "TagsValue": "Etichete: {0}", "Tags": "Etichete", - "TabUsers": "Utilizatori", "TabStreaming": "Transmitere", "TabServer": "Server", "TabScheduledTasks": "Task-uri programate", "TabResumeSettings": "Continuă", "TabResponses": "Răspunsuri", "TabPlugins": "Pluginuri", - "TabPlaylists": "Liste redare", "TabParentalControl": "Control Parental", "TabNfoSettings": "Setări NFO", "TabNetworking": "Rețele", "TabLogs": "Jurnal", - "TabLiveTV": "TV în Direct", "TabInfo": "Info", "TabDirectPlay": "Redare directă", "TabDashboard": "Tablou de bord", diff --git a/src/strings/ru.json b/src/strings/ru.json index f7ec2e0715..9989a4c47e 100644 --- a/src/strings/ru.json +++ b/src/strings/ru.json @@ -344,8 +344,6 @@ "HeaderLibraryFolders": "Медиатечные папки", "HeaderLibraryOrder": "Порядок медиатек", "HeaderLibrarySettings": "Параметры медиатеки", - "HeaderLiveTV": "Эфир", - "HeaderLiveTv": "Эфир", "HeaderLiveTvTunerSetup": "Установка и настройка тюнера", "HeaderLoginFailure": "Сбой входа", "HeaderMedia": "Медиаданные", @@ -361,7 +359,6 @@ "HeaderNewApiKey": "Новый API-ключ", "HeaderNewDevices": "Новые устройства", "HeaderNextEpisodePlayingInValue": "Следующий эпизод воспроизводится через {0}", - "HeaderNextUp": "Очередное", "HeaderNextVideoPlayingInValue": "Следующее видео воспроизводится через {0}", "HeaderOnNow": "В эфире", "HeaderOtherItems": "Прочие элементы", @@ -369,7 +366,6 @@ "HeaderPassword": "Пароль", "HeaderPasswordReset": "Сброс пароля", "HeaderPaths": "Пути", - "HeaderPeople": "Люди", "HeaderPhotoAlbums": "Фотоальбомы", "HeaderPinCodeReset": "Сброс PIN-кода", "HeaderPlayAll": "Воспроизвести все", @@ -394,7 +390,6 @@ "HeaderRevisionHistory": "История изменений", "HeaderRunningTasks": "Выполняющиеся задачи", "HeaderScenes": "Сцены", - "HeaderSchedule": "Расписание", "HeaderSeasons": "Сезоны", "HeaderSecondsValue": "{0} с", "HeaderSelectCertificatePath": "Выбор пути к сертификату", @@ -407,7 +402,6 @@ "HeaderSelectTranscodingPath": "Выбор пути для временных файлов перекодировки", "HeaderSelectTranscodingPathHelp": "Найдите или введите путь, чтобы использовать для файлов перекодировки. Папка должна быть доступна для записи.", "HeaderSendMessage": "Передача сообщения", - "HeaderSeries": "Сериалы", "HeaderSeriesOptions": "Опции сериала", "HeaderSeriesStatus": "Статус сериала", "HeaderServerSettings": "Параметры сервера", @@ -996,7 +990,6 @@ "OptionExternallyDownloaded": "Внешние загружаемые", "OptionExtractChapterImage": "Включить извлечение изображений сцен", "OptionFavorite": "Избранное", - "OptionFriday": "пятница", "OptionHasSpecialFeatures": "Доп. материалы", "OptionHasSubtitles": "Субтитры", "OptionHasThemeSong": "Тематическая мелодия", @@ -1012,11 +1005,9 @@ "OptionLikes": "Нравящиеся", "OptionMax": "Макс.", "OptionMissingEpisode": "Отсутствующие эпизоды", - "OptionMonday": "понедельник", "OptionNameSort": "Название", "OptionNew": "Новое…", "OptionNone": "Ничего", - "OptionOnAppStartup": "При запуске приложения", "OptionOnInterval": "В интервале", "OptionParentalRating": "Возрастная категория", "OptionPlainStorageFolders": "Отображать все папки, как обычные папки хранения", @@ -1040,20 +1031,15 @@ "OptionRequirePerfectSubtitleMatchHelp": "Требование полного соответствия, при котором будут отфильтровываться только те субтитры, которые были проверены и подтверждены на соответствие с вашим видеофайлом. Если снять данный флажок, повысится вероятность загрузки субтитров, но увеличатся шансы несовпадения по времени или неверного текста субтитров.", "OptionResumable": "Возможно возобновление", "OptionRuntime": "Длительность", - "OptionSaturday": "суббота", "OptionSaveMetadataAsHidden": "Сохранять метаданные и изображения в виде скрытых файлов", "OptionSaveMetadataAsHiddenHelp": "Это изменение будет применено к новым метаданным сохраняемым в будущем. Существующие файлы метаданных будут обновлены в следующий раз, когда они будут сохраняться на Jellyfin Server.", "OptionSpecialEpisode": "Спецэпизоды", "OptionSubstring": "Подстрока", - "OptionSunday": "воскресенье", - "OptionThursday": "четверг", "OptionTrackName": "Название трека", - "OptionTuesday": "вторник", "OptionTvdbRating": "Оценка TVDB", "OptionUnairedEpisode": "Ожидаемые эпизоды", "OptionUnplayed": "Невоспроизведённое", "OptionWakeFromSleep": "Выход из спящего режима", - "OptionWednesday": "среда", "OptionWeekdays": "В будни", "OptionWeekends": "Выходные", "OptionWeekly": "Еженедельно", @@ -1203,7 +1189,6 @@ "TabEpisodes": "Эпизоды", "TabInfo": "Инфо", "TabLatest": "Новейшее", - "TabLiveTV": "Эфир", "TabLogs": "Журналы", "TabMusic": "Музыка", "TabMusicVideos": "Муз. видео", @@ -1213,22 +1198,17 @@ "TabNotifications": "Уведомления", "TabOther": "Другое", "TabParentalControl": "Управление содержанием", - "TabPassword": "Пароль", - "TabPlaylists": "Плей-листы", "TabPlugins": "Плагины", "TabProfile": "Профиль", "TabProfiles": "Профили", - "TabRecordings": "Записи", "TabResponses": "Отклики", "TabResumeSettings": "Возобновление", "TabScheduledTasks": "Планировщик", - "TabSeries": "Сериалы", "TabServer": "Сервер", "TabSettings": "Параметры", "TabStreaming": "Трансляция", "TabTrailers": "Трейлеры", "TabUpcoming": "Ожидаемое", - "TabUsers": "Пользователи", "Tags": "Теги", "TagsValue": "Теги: {0}", "TellUsAboutYourself": "Расскажите о себе", diff --git a/src/strings/sk.json b/src/strings/sk.json index d8572ca1b2..9968b15c6a 100644 --- a/src/strings/sk.json +++ b/src/strings/sk.json @@ -205,8 +205,6 @@ "HeaderLibraryFolders": "Priečinky knižnice", "HeaderLibraryOrder": "Poradie knižnice", "HeaderLibrarySettings": "Nastavenia knižnice", - "HeaderLiveTV": "Živá TV", - "HeaderLiveTv": "Živá TV", "HeaderMedia": "Médiá", "HeaderMediaInfo": "Informácie o médiu", "HeaderMetadataSettings": "Nastavenia metadát", @@ -219,13 +217,11 @@ "HeaderNewApiKey": "Nový kľúč API", "HeaderNewDevices": "Nové zariadenia", "HeaderNextEpisodePlayingInValue": "Ďalšia epizóda sa spustí o {0}", - "HeaderNextUp": "Nasleduje", "HeaderNextVideoPlayingInValue": "Ďalšie video sa spustí o {0}", "HeaderOtherItems": "Iné položky", "HeaderPassword": "Heslo", "HeaderPasswordReset": "Obnoviť heslo", "HeaderPaths": "Cesty", - "HeaderPeople": "Ľudia", "HeaderPhotoAlbums": "Albumy fotografií", "HeaderPinCodeReset": "Obnoviť PIN kód", "HeaderPlayAll": "Prehrať všetko", @@ -240,13 +236,11 @@ "HeaderRevisionHistory": "História revízií", "HeaderRunningTasks": "Bežiace úlohy", "HeaderScenes": "Scény", - "HeaderSchedule": "Rozvrh", "HeaderSeasons": "Série", "HeaderSecondsValue": "{0} sekúnd", "HeaderSelectPath": "Vybrať priečinok", "HeaderSelectServer": "Vybrať server", "HeaderSendMessage": "Poslať správu", - "HeaderSeries": "Seriál", "HeaderServerSettings": "Nastavenia servera", "HeaderSettings": "Nastavenia", "HeaderSetupLibrary": "Nastavte Vaše knižnice médií", @@ -596,7 +590,6 @@ "OptionEquals": "Sa rovná", "OptionEveryday": "Každý deň", "OptionFavorite": "Obľúbené", - "OptionFriday": "Piatok", "OptionHasSubtitles": "Titulky", "OptionHasThemeSong": "Tématická hudba", "OptionHasThemeVideo": "Tématické video", @@ -606,11 +599,9 @@ "OptionImdbRating": "Hodnotenie IMDb", "OptionLikes": "Páči sa", "OptionMissingEpisode": "Chýbajúce epizódy", - "OptionMonday": "Pondelok", "OptionNameSort": "Názov", "OptionNew": "Nové…", "OptionNone": "Žiadne", - "OptionOnAppStartup": "Pri spustení aplikácie", "OptionParentalRating": "Rodičovské hodnotenie", "OptionPlainVideoItems": "Zobraziť všetky videá ako obyčajné video položky", "OptionPlayCount": "Počet prehraní", @@ -621,17 +612,12 @@ "OptionReleaseDate": "Dátum vydania", "OptionResumable": "Pozastaviteľný", "OptionRuntime": "Dĺžka", - "OptionSaturday": "Sobota", "OptionSaveMetadataAsHidden": "Uložiť metadáta a obrázky ako skryté súbory", - "OptionSunday": "Nedeľa", - "OptionThursday": "Štvrtok", "OptionTrackName": "Názov skladby", - "OptionTuesday": "Utorok", "OptionTvdbRating": "TVDB hodnotenie", "OptionUnairedEpisode": "Nevysielané epizódy", "OptionUnplayed": "Neprehrané", "OptionWakeFromSleep": "Zobudiť zo spánku", - "OptionWednesday": "Streda", "OptionWeekdays": "Pracovné dni", "OptionWeekends": "Víkendy", "OptionWeekly": "Týždenne", @@ -736,7 +722,6 @@ "TabDashboard": "Dashboard", "TabEpisodes": "Epizódy", "TabLatest": "Najnovšie", - "TabLiveTV": "Živá TV", "TabMusic": "Hudba", "TabMusicVideos": "Hudobné videá", "TabMyPlugins": "Moje zásuvné moduly", @@ -745,19 +730,15 @@ "TabNotifications": "Upozornenia", "TabOther": "Iné", "TabParentalControl": "Rodičovská kontrola", - "TabPassword": "Heslo", "TabPlugins": "Zásuvné moduly", "TabProfile": "Profil", "TabProfiles": "Profily", - "TabRecordings": "Nahrávky", "TabResponses": "Odpovede", "TabResumeSettings": "Pokračovať", "TabScheduledTasks": "Naplánované úlohy", - "TabSeries": "Seriály", "TabSettings": "Nastavenia", "TabTrailers": "Trailery", "TabUpcoming": "Nadchádzajúce", - "TabUsers": "Užívatelia", "TellUsAboutYourself": "Povedzte nám niečo o sebe", "ThisWizardWillGuideYou": "Tento sprievodca Vám pomôže prejsť inštalačným procesom. Pre začatie zvoľte preferovaný jazyk.", "Thursday": "Štvrtok", @@ -938,7 +919,6 @@ "SortName": "Zoradiť podľa názvu", "TabDirectPlay": "Priame prehrávanie", "TabLogs": "Záznamy", - "TabPlaylists": "Playlisty", "TabServer": "Server", "TabStreaming": "Streamovanie", "Tags": "Tagy", diff --git a/src/strings/sl-si.json b/src/strings/sl-si.json index 22d0d60317..f9588653ab 100644 --- a/src/strings/sl-si.json +++ b/src/strings/sl-si.json @@ -10,7 +10,6 @@ "HeaderFrequentlyPlayed": "Pogosto Predvajano", "HeaderPaths": "Poti", "HeaderRecentlyPlayed": "Nazadnje Predvajano", - "HeaderSeries": "Serije", "HeaderSettings": "Nastavitve", "HeaderUser": "Uporabnik", "LabelArtists": "Izvajalci:", @@ -45,7 +44,6 @@ "TabMusic": "Glasba", "TabMyPlugins": "Moji dodatki", "TabNetworks": "Omrezja", - "TabPassword": "Geslo", "TabProfile": "Profil", "TabProfiles": "Profili", "TabUpcoming": "Prihajajoče", @@ -87,8 +85,6 @@ "Genres": "Zvrsti", "HeaderAlbumArtists": "Izvajalci albuma", "HeaderContinueWatching": "Nadaljuj gledanje", - "HeaderLiveTV": "TV v živo", - "HeaderNextUp": "Sledi", "Movies": "Filmi", "AllowedRemoteAddressesHelp": "Z vejico ločen seznam IP naslovov ali IP/maska omrežij, ki jim je dovoljen oddaljeni dostop. Če pustite prazno, bodo dovoljeni vsi oddaljeni naslovi.", "AlwaysPlaySubtitles": "Vedno prikaži", @@ -261,7 +257,6 @@ "HeaderSelectCertificatePath": "Izberi pot certifikata", "HeaderSecondsValue": "{0} sekund", "HeaderSeasons": "Sezone", - "HeaderSchedule": "Urnik", "HeaderScenes": "Scene", "HeaderRunningTasks": "Aktivna opravila", "HeaderRestart": "Ponovni zagon", @@ -283,7 +278,6 @@ "HeaderPlayAll": "Predvajaj vse", "HeaderPinCodeReset": "Ponastavi PIN kodo", "HeaderPhotoAlbums": "Foto albumi", - "HeaderPeople": "Osebe", "HeaderPasswordReset": "Ponastavi geslo", "HeaderPassword": "Geslo", "HeaderParentalRatings": "Ocena za starše", @@ -304,7 +298,6 @@ "HeaderMedia": "Predstavnost", "HeaderLoginFailure": "Neuspešna prijava", "HeaderLiveTvTunerSetup": "Nastavitev sprejemnika za TV v živo", - "HeaderLiveTv": "TV v živo", "HeaderLibrarySettings": "Nastavitve knjižnice", "HeaderLibraryOrder": "Vrstni red knjižnic", "HeaderLibraryFolders": "Mape knjižnjice", @@ -762,18 +755,15 @@ "Smart": "Pametno", "SubtitleAppearanceSettingsAlsoPassedToCastDevices": "Te nastavitve veljajo tudi za predvajanja Chromecast, ki jih začne ta naprava.", "TabDashboard": "Nadzorna plošča", - "TabLiveTV": "TV v živo", "PinCodeResetConfirmation": "Ali ste prepričani, da želite ponastaviti PIN kodo?", "PreferEmbeddedTitlesOverFileNames": "Prioritiziraj vdelane naslove pred imeni datotek", "PreferEmbeddedTitlesOverFileNamesHelp": "To vpliva na privzeto prikazan naslov, ko ni na voljo internetnih ali lokalnih metapodatkov.", "Rate": "Oceni", "RecentlyWatched": "Nedavno ogledano", "RecommendationBecauseYouLike": "Ker vam je všeč {0}", - "OptionSunday": "Nedelja", "OptionTvdbRating": "TVDB ocena", "OptionUnairedEpisode": "Nepredvajane epizode", "PleaseEnterNameOrId": "Prosimo vnesite ime ali zunanji ID.", - "OptionWednesday": "Sreda", "OptionWeekends": "Vikendi", "Previous": "Prejšnji", "People": "Ljudje", @@ -802,9 +792,7 @@ "TabNetworking": "Omrežje", "OptionSaveMetadataAsHiddenHelp": "Spreminjanje tega bo veljalo za metapodatke shranjene v prihodnje. Obstoječi metapodatki bodo posodobljeni, ko jih bo strežnik naslednjič spremenil.", "OptionSubstring": "Podniz", - "OptionThursday": "Četrtek", "OptionTrackName": "Ime skladbe", - "OptionTuesday": "Torek", "OptionWakeFromSleep": "Prebudi iz spanja", "OptionWeekdays": "Delovni dnevi", "OptionWeekly": "Tedensko", @@ -833,7 +821,6 @@ "Producer": "Producent", "Premiere": "Premiera", "OptionRuntime": "Trajanje", - "OptionSaturday": "Sobota", "MediaInfoLayout": "Razporeditev", "Like": "Všeč mi je", "LabelPlayDefaultAudioTrack": "Predvajaj privzeti zvočni posnetek ne glede na jezik", @@ -992,9 +979,7 @@ "OptionProfileAudio": "Zvok", "OptionPremiereDate": "Datum premiere", "OptionOnInterval": "V intervalu", - "OptionOnAppStartup": "Ob zagonu aplikacije", "OptionNew": "Novo…", - "OptionMonday": "Ponedeljek", "OptionMissingEpisode": "Manjkajoče epizode", "OptionLoginAttemptsBeforeLockoutHelp": "Vrednost nič (0) pomeni 3 poskuse za običajne uporabnike in 5 za skrbnike. Nastavite na -1 za onemogočanje te funkcije.", "OptionLoginAttemptsBeforeLockout": "Določa število spodletelih poskusov prijave pred zaklenitvijo uporabnika.", @@ -1004,7 +989,6 @@ "OptionHomeVideos": "Slike", "OptionHideUser": "Skrij tega uporabnika z vstopne strani", "OptionHasTrailer": "Napovednik", - "OptionFriday": "Petek", "OptionEveryday": "Vsak dan", "OptionDvd": "DVD", "OptionDownloadMenuImage": "Meni", @@ -1128,7 +1112,6 @@ "Trailers": "Napovedniki", "TitleHardwareAcceleration": "Strojno pospeševanje", "Thursday": "Četrtek", - "TabUsers": "Uporabniki", "TabTrailers": "Napovedniki", "ClientSettings": "Nastavitve odjemalca", "ButtonTogglePlaylist": "Seznam predvajanja", @@ -1314,16 +1297,13 @@ "TabStreaming": "Pretakanje", "TabSettings": "Nastavitve", "TabServer": "Strežnik", - "TabSeries": "Serije", "TabScheduledTasks": "Načrtovana opravila", "TabResumeSettings": "Nadaljuj", "HeaderUninstallPlugin": "Odstrani dodatek", "UninstallPluginConfirmation": "Ali ste prepričan, da želite odstraniti {0}?", "ServerRestartNeededAfterPluginInstall": "Po namestitvi dodatka bo potreben ponoven zagon jellyfin strežnika.", "TabResponses": "Odzivi", - "TabRecordings": "Posnetki", "TabPlugins": "Dodatki", - "TabPlaylists": "Seznami predvajanja", "TabOther": "Ostalo", "TabNotifications": "Obvestila", "TabNfoSettings": "Nastavitve NFO", diff --git a/src/strings/sr.json b/src/strings/sr.json index c302c0a580..22e2343e5e 100644 --- a/src/strings/sr.json +++ b/src/strings/sr.json @@ -6,8 +6,6 @@ "Playlists": "Листе", "Photos": "Фотографије", "Movies": "Филмови", - "HeaderNextUp": "Следеће горе", - "HeaderLiveTV": "ТВ уживо", "HeaderFavoriteSongs": "Омиљене песме", "HeaderFavoriteShows": "Омиљене серије", "HeaderFavoriteEpisodes": "Омиљене епизоде", diff --git a/src/strings/sv.json b/src/strings/sv.json index 604179f9f6..e4a81cfd42 100644 --- a/src/strings/sv.json +++ b/src/strings/sv.json @@ -309,8 +309,6 @@ "HeaderLibraryFolders": "Biblioteksmappar", "HeaderLibraryOrder": "Biblioteksordning", "HeaderLibrarySettings": "Biblioteksinställningar", - "HeaderLiveTV": "Live-TV", - "HeaderLiveTv": "Live-TV", "HeaderLoginFailure": "Misslyckad inloggning", "HeaderMediaFolders": "Mediamappar", "HeaderMediaInfo": "Medieinformation", @@ -324,14 +322,12 @@ "HeaderNewApiKey": "Ny API-nyckel", "HeaderNewDevices": "Nya enheter", "HeaderNextEpisodePlayingInValue": "Nästa avsnitt börjar om {0}", - "HeaderNextUp": "Nästa", "HeaderNextVideoPlayingInValue": "Nästa video börjar om {0}", "HeaderOnNow": "Visas nu", "HeaderOtherItems": "Övriga objekt", "HeaderPassword": "Lösenord", "HeaderPasswordReset": "Återställning av lösenordet", "HeaderPaths": "Sökvägar", - "HeaderPeople": "Personer", "HeaderPhotoAlbums": "Fotoalbum", "HeaderPinCodeReset": "Återställ pinkod", "HeaderPlayAll": "Spela upp alla", @@ -356,7 +352,6 @@ "HeaderRevisionHistory": "Revisionshistorik", "HeaderRunningTasks": "Pågående aktiviteter", "HeaderScenes": "Kapitel", - "HeaderSchedule": "Schema", "HeaderSeasons": "Säsonger", "HeaderSecondsValue": "{0} sekunder", "HeaderSelectCertificatePath": "Välj sökväg för certifikat", @@ -369,7 +364,6 @@ "HeaderSelectTranscodingPath": "Välj plats för mellanlagring vid omkodning", "HeaderSelectTranscodingPathHelp": "Bläddra fram till eller ange plats för omkodarens mellanlagring. Katalogen måste vara tillgänglig för skrivning.", "HeaderSendMessage": "Skicka meddelande", - "HeaderSeries": "Serier", "HeaderSeriesOptions": "Seriealternativ", "HeaderSeriesStatus": "Seriestatus", "HeaderServerSettings": "Serverinställningar", @@ -922,7 +916,6 @@ "OptionExternallyDownloaded": "Extern nerladdning", "OptionExtractChapterImage": "Aktivera extrahering av kapitelbilder", "OptionFavorite": "Favoriter", - "OptionFriday": "Fredag", "OptionHasSpecialFeatures": "Extramaterial", "OptionHasSubtitles": "Undertexter", "OptionHasThemeSong": "Ledmotiv", @@ -936,11 +929,9 @@ "OptionImdbRating": "Betyg på IMDB", "OptionLikes": "Gillar", "OptionMissingEpisode": "Saknade avsnitt", - "OptionMonday": "Måndag", "OptionNameSort": "Namn", "OptionNew": "Ny…", "OptionNone": "Inga", - "OptionOnAppStartup": "När servern startar", "OptionOnInterval": "Med visst intervall", "OptionParentalRating": "Föräldraklassning", "OptionPlainStorageFolders": "Visa alla mappar som vanliga lagringsmappar", @@ -961,19 +952,14 @@ "OptionRequirePerfectSubtitleMatchHelp": "Att kräva en perfekt matchning filtrerar undertexter till att bara inkludera de som testats och verifierats med din exakta videofil. Stänger du av detta ökas chansen att undertexter laddas ned, men ökar chanserna att de är osynkade eller felaktiga.", "OptionResumable": "Kan återupptas", "OptionRuntime": "Speltid", - "OptionSaturday": "Lördag", "OptionSaveMetadataAsHidden": "Spara metadata och bilder som dolda filer", "OptionSpecialEpisode": "Specialavsnitt", "OptionSubstring": "Delsträng", - "OptionSunday": "Söndag", - "OptionThursday": "Torsdag", "OptionTrackName": "Spårnamn", - "OptionTuesday": "Tisdag", "OptionTvdbRating": "TVDB-betyg", "OptionUnairedEpisode": "Ej sända avsnitt", "OptionUnplayed": "Ej visad", "OptionWakeFromSleep": "Vakna ur energisparläge", - "OptionWednesday": "Onsdag", "OptionWeekdays": "Veckodagar", "OptionWeekends": "Helger", "OptionWeekly": "Varje vecka", @@ -1111,7 +1097,6 @@ "TabDirectPlay": "Direktuppspelning", "TabEpisodes": "Avsnitt", "TabLatest": "Nytillkommet", - "TabLiveTV": "Live-TV", "TabLogs": "Loggfiler", "TabMusic": "Musik", "TabMusicVideos": "Musikvideor", @@ -1121,20 +1106,15 @@ "TabNotifications": "Meddelanden", "TabOther": "Övrigt", "TabParentalControl": "Föräldralås", - "TabPassword": "Lösenord", - "TabPlaylists": "Spellistor", "TabPlugins": "Tillägg", "TabProfile": "Profil", "TabProfiles": "Profiler", - "TabRecordings": "Inspelningar", "TabResponses": "Svar", "TabResumeSettings": "Återuppta", "TabScheduledTasks": "Schemalagda aktiviteter", - "TabSeries": "Serie", "TabSettings": "Inställningar", "TabStreaming": "Strömning", "TabUpcoming": "Kommande", - "TabUsers": "Användare", "Tags": "Etiketter", "TagsValue": "Etiketter: {0}", "TellUsAboutYourself": "Berätta om dig själv", diff --git a/src/strings/tr.json b/src/strings/tr.json index ba47bd7f6b..2bae4757f4 100644 --- a/src/strings/tr.json +++ b/src/strings/tr.json @@ -63,7 +63,6 @@ "HeaderLibraryFolders": "Media Klasörleri", "HeaderMediaFolders": "Media Klasörleri", "HeaderMusicVideos": "Müzik vidyoları", - "HeaderNextUp": "Sonraki hafta", "HeaderPlayAll": "Hepsini oynat", "HeaderPleaseSignIn": "Lütfen Giriş Yapın", "HeaderPreferredMetadataLanguage": "Tercih Edilen Meta Dili", @@ -72,7 +71,6 @@ "HeaderResponseProfile": "Profil Görüntüleme", "HeaderScenes": "Sahneler", "HeaderSendMessage": "Mesaj Gönder", - "HeaderSeries": "Series", "HeaderServerSettings": "Sunucu ayarları", "HeaderSetupLibrary": "Medya kütüphanelerini kur", "HeaderStatus": "Durum", @@ -149,7 +147,6 @@ "OptionEnableAccessToAllLibraries": "Bütün kütüphanelere erişim izni ver", "OptionEnded": "Bitmiş", "OptionFavorite": "Favoriler", - "OptionFriday": "Cuma", "OptionHasSubtitles": "Altyazı", "OptionHasThemeSong": "Tema Şarkısı", "OptionHasThemeVideo": "Tema Videosu", @@ -157,7 +154,6 @@ "OptionHideUser": "Bu kullanıcıyı giriş ekranında gösterme", "OptionImdbRating": "İMDb Reyting", "OptionLikes": "Beğenilenler", - "OptionMonday": "Pazartesi", "OptionNameSort": "İsim", "OptionPlayCount": "Oynatma sayacı", "OptionPlayed": "Çalındı", @@ -168,15 +164,10 @@ "OptionReleaseDate": "Yayınlanma Tarihi", "OptionResumable": "Başlatılabilir", "OptionRuntime": "Süresi", - "OptionSaturday": "Cumartesi", "OptionSpecialEpisode": "Özel", - "OptionSunday": "Pazar", - "OptionThursday": "Perşembe", "OptionTrackName": "Parça İsmi", - "OptionTuesday": "Salı", "OptionTvdbRating": "TVDB Puanı", "OptionUnplayed": "Çalınmayan", - "OptionWednesday": "Çarşamba", "OptionWeekly": "Haftalık", "ParentalRating": "Ebeveyn değeri", "PasswordMatchError": "Parola ve Sifre Eslesmelidir.", @@ -203,11 +194,8 @@ "TabMyPlugins": "Eklentilerim", "TabNetworks": "Ağlar", "TabNotifications": "Bildirimler", - "TabPassword": "Şifre", "TabProfile": "Profil", "TabProfiles": "Profiller", - "TabRecordings": "Kayıtlar", - "TabSeries": "Seriler", "TabServer": "Sunucu", "TabSettings": "Ayarlar", "TabTrailers": "Fragmanlar", @@ -247,7 +235,6 @@ "HeaderFavoriteAlbums": "Favori Albümler", "HeaderFavoriteArtists": "Favori Sanatçılar", "HeaderFavoriteSongs": "Favori Şarkılar", - "HeaderLiveTV": "Canlı TV", "Movies": "Filmler", "Photos": "Fotoğraflar", "Playlists": "Çalma listeleri", @@ -520,7 +507,6 @@ "HeaderSelectCertificatePath": "Sertifika Yolunu Seç", "HeaderSecondsValue": "{0} Saniye", "HeaderSeasons": "Sezonlar", - "HeaderSchedule": "Zamanla", "HeaderRunningTasks": "Çalışan Görevler", "HeaderRevisionHistory": "Revizyon Geçmişi", "HeaderRestart": "Yeniden Başlat", @@ -535,7 +521,6 @@ "HeaderPlayback": "Medya Oynatma", "HeaderPinCodeReset": "Pin Kodunu Sıfırla", "HeaderPhotoAlbums": "Fotoğraf Albümleri", - "HeaderPeople": "Kişiler", "HeaderPasswordReset": "Şifre Sıfırlama", "HeaderPassword": "Şifre", "HeaderParentalRatings": "Ebeveyn Derecelendirmeleri", @@ -555,7 +540,6 @@ "HeaderMedia": "Medya", "HeaderLoginFailure": "Giriş Başarısız", "HeaderLiveTvTunerSetup": "Canlı TV istasyon Kurulumu", - "HeaderLiveTv": "Canlı TV", "HeaderLibrarySettings": "Kütüphane Ayarları", "HeaderLibraryOrder": "Kütüphane Sırası", "HeaderLibraryAccess": "Kütüphane Erişimi", diff --git a/src/strings/uk.json b/src/strings/uk.json index 329f0ca95c..ff69296e07 100644 --- a/src/strings/uk.json +++ b/src/strings/uk.json @@ -21,7 +21,6 @@ "HeaderLatestMovies": "Нещодавні фільми", "HeaderLatestMusic": "Остання музика", "HeaderSeasons": "Сезони", - "HeaderSeries": "Series", "HeaderSettings": "Налаштування", "HeaderTracks": "Доріжки", "HeaderUsers": "Користувачі", @@ -60,12 +59,10 @@ "TabEpisodes": "Епізоди", "TabNetworks": "Мережі", "TabNotifications": "Повідомлення", - "TabPassword": "Пароль", "TabPlugins": "Додатки", "TabProfile": "Профіль", "TabProfiles": "Профілі", "TabTrailers": "Трейлери", - "TabUsers": "Користувачі", "ValueAlbumCount": "{0} альбомів", "ValueDiscNumber": "Диск {0}", "ValueEpisodeCount": "{0} епізодів", @@ -102,7 +99,6 @@ "Movies": "Фільми", "Collections": "Колекції", "Folders": "Каталоги", - "HeaderNextUp": "Наступний", "HeaderAlbumArtists": "Виконавці альбому", "HeaderFavoriteSongs": "Улюблені пісні", "Favorites": "Улюблені", @@ -110,7 +106,6 @@ "Genres": "Жанри", "Books": "Книги", "Artists": "Виконавці", - "HeaderLiveTV": "Ефірне ТБ", "Channels": "Канали", "HeaderFavoriteArtists": "Улюблені виконавці", "HeaderFavoriteShows": "Улюблені шоу", diff --git a/src/strings/vi.json b/src/strings/vi.json index 438dfe4632..48e59ca057 100644 --- a/src/strings/vi.json +++ b/src/strings/vi.json @@ -23,7 +23,6 @@ "HeaderLatestEpisodes": "Các tập phim mới nhất", "HeaderLatestMovies": "Phim mới nhất", "HeaderRecentlyPlayed": "Phát gần đây", - "HeaderSeries": "Series", "HeaderStatus": "Trạng thái", "HeaderSystemDlnaProfiles": "Hồ sơ hệ thống", "HeaderUsers": "dùng", @@ -67,12 +66,9 @@ "OptionIsHD": "Độ nét cao", "OptionIsSD": "Độ nét tiêu chuẩn", "OptionLikes": "Thích", - "OptionMonday": "Thứ Hai", "OptionNameSort": "Tên", "OptionPlayCount": "Số lần phát", "OptionRuntime": "Thời gian phát", - "OptionSaturday": "Thứ Bảy", - "OptionSunday": "Chủ Nhật", "OptionTrackName": "Tên bài", "ParentalRating": "Parental Rating", "PasswordMatchError": "Mật khẩu và mật khẩu xác nhận cần phải khớp nhau .", @@ -90,7 +86,6 @@ "TabMusicVideos": "Các video âm nhạc", "TabMyPlugins": "Các plugin của tôi", "TabNetworks": "Các mạng", - "TabPassword": "Mật khẩu", "TabProfile": "Hồ sơ", "TabProfiles": "Hồ sơ", "TabServer": "Máy chủ", @@ -404,7 +399,6 @@ "HeaderPlayAll": "Phát Tất Cả", "HeaderPinCodeReset": "Đặt Lại Mã PIN", "HeaderPhotoAlbums": "Album Ảnh", - "HeaderPeople": "Nhân Vật", "HeaderPaths": "Đường Dẫn", "HeaderPasswordReset": "Đặt Lại Mật Khẩu", "HeaderPassword": "Mật Khẩu", @@ -412,7 +406,6 @@ "HeaderOtherItems": "Những Mục Khác", "HeaderOnNow": "Phát Sóng Hiện Tại", "HeaderNextVideoPlayingInValue": "Video Tiếp Theo Sẽ Phát trong {0}", - "HeaderNextUp": "Tiếp Theo", "HeaderNextEpisodePlayingInValue": "Tập Tiếp Theo Sẽ Được Chạy trong {0}", "HeaderNewDevices": "Thiết Bị Mới", "HeaderNewApiKey": "Mã API Mới", @@ -429,8 +422,6 @@ "HeaderMedia": "Nội Dung", "HeaderLoginFailure": "Đăng Nhập Không Thành Công", "HeaderLiveTvTunerSetup": "Cài Đặt Bộ Bắt Sóng TV", - "HeaderLiveTv": "Truyền Hình Trực Tiếp", - "HeaderLiveTV": "Truyền Hình Trực Tiếp", "HeaderLibrarySettings": "Cài Đặt Thư Viện", "HeaderLibraryOrder": "Thứ Tự Thư Viện", "HeaderLibraryFolders": "Thư Mục Của Thư Viện", @@ -504,7 +495,6 @@ "HeaderSelectCertificatePath": "Chọn Đường Dẫn Đến Chứng Chỉ", "HeaderSecondsValue": "{0} Giây", "HeaderSeasons": "Phần", - "HeaderSchedule": "Lịch Phát Sóng", "HeaderScenes": "Phân Cảnh", "HeaderRunningTasks": "Những Tác Vụ Hoạt Động", "HeaderRevisionHistory": "Lịch Sử Chỉnh Sửa", diff --git a/src/strings/zh-cn.json b/src/strings/zh-cn.json index 9de331b018..b14bec8277 100644 --- a/src/strings/zh-cn.json +++ b/src/strings/zh-cn.json @@ -313,8 +313,6 @@ "HeaderLibraryFolders": "媒体文件夹", "HeaderLibraryOrder": "媒体库顺序", "HeaderLibrarySettings": "媒体库设置", - "HeaderLiveTV": "电视直播", - "HeaderLiveTv": "电视直播", "HeaderLiveTvTunerSetup": "电视直播协调器安装", "HeaderLoginFailure": "登录失败", "HeaderMedia": "媒体", @@ -328,14 +326,12 @@ "HeaderMyMediaSmall": "我的媒体 (小)", "HeaderNewApiKey": "新 API 密钥", "HeaderNewDevices": "新设备", - "HeaderNextUp": "接下来", "HeaderOnNow": "现在", "HeaderOtherItems": "其他项目", "HeaderParentalRatings": "家长分级", "HeaderPassword": "密码", "HeaderPasswordReset": "密码重置", "HeaderPaths": "路径", - "HeaderPeople": "人物", "HeaderPhotoAlbums": "相册", "HeaderPinCodeReset": "重置PIN码", "HeaderPlayAll": "全部播放", @@ -359,7 +355,6 @@ "HeaderRevisionHistory": "修订历史", "HeaderRunningTasks": "运行的任务", "HeaderScenes": "场景", - "HeaderSchedule": "计划", "HeaderSeasons": "季", "HeaderSecondsValue": "{0} 秒", "HeaderSelectCertificatePath": "选择证书路径", @@ -372,7 +367,6 @@ "HeaderSelectTranscodingPath": "选择临时解码路径", "HeaderSelectTranscodingPathHelp": "浏览或输入一个路径用于转码文件,此文件夹必须可写。", "HeaderSendMessage": "发送消息", - "HeaderSeries": "电视剧", "HeaderSeriesOptions": "系列选项", "HeaderServerSettings": "服务器设置", "HeaderSettings": "设置", @@ -949,7 +943,6 @@ "OptionExternallyDownloaded": "外部下载", "OptionExtractChapterImage": "开启剧集图片提取", "OptionFavorite": "我的最爱", - "OptionFriday": "星期五", "OptionHasSpecialFeatures": "特殊功能", "OptionHasSubtitles": "字幕", "OptionHasThemeSong": "主题曲", @@ -967,11 +960,9 @@ "OptionLikes": "喜欢", "OptionMax": "最大", "OptionMissingEpisode": "缺少的剧集", - "OptionMonday": "星期一", "OptionNameSort": "名字", "OptionNew": "新建…", "OptionNone": "没有", - "OptionOnAppStartup": "在程序启动时", "OptionOnInterval": "在一个期间", "OptionParentalRating": "家长分级", "OptionPlainStorageFolders": "显示所有文件夹作为一般存储文件夹", @@ -996,20 +987,15 @@ "OptionResElement": "res 元素", "OptionResumable": "可恢复播放", "OptionRuntime": "播放时长", - "OptionSaturday": "星期六", "OptionSaveMetadataAsHidden": "保存媒体资料和图像为隐藏文件", "OptionSaveMetadataAsHiddenHelp": "更改此项将应用于以后保存的元数据。现有元数据文件将在下一次服务器保存它们时被更新。", "OptionSpecialEpisode": "特集", "OptionSubstring": "子串", - "OptionSunday": "星期天", - "OptionThursday": "星期四", "OptionTrackName": "曲目名称", - "OptionTuesday": "星期二", "OptionTvdbRating": "TVDB 评分", "OptionUnairedEpisode": "尚未发布的剧集", "OptionUnplayed": "未播放", "OptionWakeFromSleep": "从睡眠中唤醒", - "OptionWednesday": "星期三", "OptionWeekdays": "工作日", "OptionWeekends": "周末", "OptionWeekly": "每周", @@ -1140,7 +1126,6 @@ "TabEpisodes": "剧集", "TabInfo": "信息", "TabLatest": "最新", - "TabLiveTV": "电视直播", "TabLogs": "日志", "TabMusic": "音乐", "TabMusicVideos": "音乐视频", @@ -1150,22 +1135,17 @@ "TabNotifications": "通知", "TabOther": "其他", "TabParentalControl": "家长控制", - "TabPassword": "密码", - "TabPlaylists": "播放列表", "TabPlugins": "插件", "TabProfile": "个人配置", "TabProfiles": "配置", - "TabRecordings": "录制", "TabResponses": "响应", "TabResumeSettings": "恢复", "TabScheduledTasks": "计划任务", - "TabSeries": "电视剧", "TabServer": "服务器", "TabSettings": "设置", "TabStreaming": "流媒体传输", "TabTrailers": "预告片", "TabUpcoming": "即将发布", - "TabUsers": "用户", "Tags": "标签", "TellUsAboutYourself": "请介绍一下你自己", "ThemeSongs": "主题曲", diff --git a/src/strings/zh-hk.json b/src/strings/zh-hk.json index 454bbea0c2..6cdb6f13a9 100644 --- a/src/strings/zh-hk.json +++ b/src/strings/zh-hk.json @@ -56,9 +56,7 @@ "HeaderLatestRecordings": "最近錄影的節目", "HeaderMediaFolders": "媒體文件夾", "HeaderMusicVideos": "MV", - "HeaderNextUp": "接下來", "HeaderPaths": "路徑", - "HeaderPeople": "人物", "HeaderPleaseSignIn": "請登入", "HeaderRecentlyPlayed": "最近播放", "HeaderRemoteControl": "遙控器", @@ -66,7 +64,6 @@ "HeaderRunningTasks": "運行任務", "HeaderScenes": "場景", "HeaderSeasons": "季度劇集", - "HeaderSeries": "電視劇:", "HeaderSetupLibrary": "建立你的媒體資料庫", "HeaderSpecialFeatures": "特色", "HeaderStatus": "狀態", @@ -216,7 +213,6 @@ "OptionEnableAccessToAllLibraries": "允許所有媒體庫通行", "OptionEnded": "完成", "OptionFavorite": "我的最愛", - "OptionFriday": "星期五", "OptionHasSpecialFeatures": "特色", "OptionHasSubtitles": "字幕", "OptionHasThemeSong": "主題曲", @@ -230,9 +226,7 @@ "OptionIsSD": "標清", "OptionLikes": "正評", "OptionMissingEpisode": "缺少的劇集", - "OptionMonday": "星期一", "OptionNameSort": "名稱", - "OptionOnAppStartup": "在伺服器啟動", "OptionOnInterval": "每個時段", "OptionParentalRating": "家長評級", "OptionPlayCount": "播放次數", @@ -243,17 +237,12 @@ "OptionReleaseDate": "發佈日期", "OptionResumable": "能夠恢復", "OptionRuntime": "運行時間", - "OptionSaturday": "星期六", "OptionSpecialEpisode": "特集", - "OptionSunday": "星期日", - "OptionThursday": "星期四", "OptionTrackName": "曲目名稱", - "OptionTuesday": "星期二", "OptionTvdbRating": "Tvdb 評分", "OptionUnairedEpisode": "尚未播放的劇集", "OptionUnplayed": "未播放", "OptionWakeFromSleep": "從休眠中恢復", - "OptionWednesday": "星期三", "OptionWeekly": "每週", "ParentalRating": "Parental Rating", "Play": "播放", @@ -279,16 +268,12 @@ "TabNetworks": "網絡", "TabNotifications": "通知", "TabOther": "其它", - "TabPassword": "密碼", "TabProfile": "簡介", "TabProfiles": "簡介", - "TabRecordings": "錄影", - "TabSeries": "電視劇", "TabServer": "伺服器", "TabSettings": "設定", "TabTrailers": "預告", "TabUpcoming": "即將發佈", - "TabUsers": "用戶", "TellUsAboutYourself": "介紹一下自己", "ThisWizardWillGuideYou": "此教學協助您完成安裝過程。首先,請選擇您的語言。", "Thursday": "星期四", @@ -322,7 +307,6 @@ "Playlists": "播放清單", "Photos": "相片", "Movies": "電影", - "HeaderLiveTV": "電視直播", "HeaderFavoriteSongs": "最愛的歌曲", "HeaderFavoriteShows": "最愛的節目", "HeaderFavoriteEpisodes": "最愛的劇集", diff --git a/src/strings/zh-tw.json b/src/strings/zh-tw.json index f9f9bce7a7..6361242d4e 100644 --- a/src/strings/zh-tw.json +++ b/src/strings/zh-tw.json @@ -67,11 +67,8 @@ "HeaderLatestEpisodes": "最新劇集", "HeaderLatestMovies": "最新電影", "HeaderLatestRecordings": "最新錄影的節目", - "HeaderLiveTV": "電視直播", - "HeaderLiveTv": "電視", "HeaderMediaFolders": "媒體資料夾", "HeaderMusicVideos": "MV", - "HeaderNextUp": "接下來", "HeaderPaths": "路徑", "HeaderPlayAll": "全部播放", "HeaderPleaseSignIn": "請登入", @@ -80,7 +77,6 @@ "HeaderScenes": "場景", "HeaderSelectServer": "選擇伺服器", "HeaderSelectServerCachePath": "選擇伺服器快取路徑", - "HeaderSeries": "系列", "HeaderSpecialFeatures": "特色", "HeaderStatus": "狀態", "HeaderSystemDlnaProfiles": "系統設定", @@ -179,7 +175,6 @@ "OptionDvd": "DVD", "OptionEnded": "完結", "OptionFavorite": "我的最愛", - "OptionFriday": "星期五", "OptionHasSubtitles": "字幕", "OptionHasThemeSong": "主題曲", "OptionHasThemeVideo": "主題影片", @@ -189,10 +184,8 @@ "OptionIsSD": "標清", "OptionLikes": "喜歡", "OptionMissingEpisode": "缺少了的單元", - "OptionMonday": "星期一", "OptionNameSort": "名字", "OptionNew": "新增…", - "OptionOnAppStartup": "在伺服器啟動", "OptionOnInterval": "每時段", "OptionParentalRating": "家長評級", "OptionPlayCount": "播放次數", @@ -200,17 +193,12 @@ "OptionPremiereDate": "首映日期", "OptionResumable": "可恢復", "OptionRuntime": "播放長度", - "OptionSaturday": "星期六", "OptionSpecialEpisode": "特集", - "OptionSunday": "星期天", - "OptionThursday": "星期四", "OptionTrackName": "曲目名稱", - "OptionTuesday": "星期二", "OptionTvdbRating": "TVDB 評分", "OptionUnairedEpisode": "還未發佈的單元", "OptionUnplayed": "未播放", "OptionWakeFromSleep": "從休眠中回復", - "OptionWednesday": "星期三", "OptionWeekly": "每週", "OriginalAirDateValue": "原始播出日期:{0}", "ParentalRating": "Parental Rating", @@ -245,15 +233,11 @@ "TabEpisodes": "單元", "TabInfo": "資訊", "TabLatest": "最新", - "TabLiveTV": "電視", "TabMusic": "音樂", "TabMyPlugins": "我的附加元件", "TabNetworks": "網路", - "TabPassword": "密碼", "TabProfile": "設定", "TabProfiles": "設定", - "TabRecordings": "錄影", - "TabSeries": "電視劇", "TabServer": "伺服器", "TabSettings": "設定", "TabTrailers": "預告", @@ -572,7 +556,6 @@ "HeaderOtherItems": "其他項目", "HeaderPassword": "密碼", "HeaderPasswordReset": "重設密碼", - "HeaderPeople": "使用者", "HeaderPhotoAlbums": "相簿", "HeaderPinCodeReset": "重設PIN碼", "HeaderPlayOn": "播放在", @@ -622,7 +605,6 @@ "HeaderProfileServerSettingsHelp": "這些數值將控制伺服器如何呈現給設備。", "HeaderResponseProfile": "回覆設定檔", "HeaderResponseProfileHelp": "當播放某些類型的媒體時,回覆設定檔提供一種方法來發送自定訊息到設備。", - "HeaderSchedule": "日程表", "HeaderSelectCertificatePath": "選擇證書路徑", "HeaderSelectMetadataPath": "選擇中繼資料路徑", "HeaderSubtitleProfile": "字幕設定檔", @@ -880,7 +862,6 @@ "RecentlyWatched": "最近觀賞", "RecommendationBecauseYouLike": "因為您喜歡 {0}", "SearchResults": "搜尋結果", - "TabPlaylists": "播放清單", "TabPlugins": "附加元件", "Transcoding": "轉檔", "ValueTimeLimitMultiHour": "時間限制:{0} 小時", @@ -907,7 +888,6 @@ "RepeatMode": "重複模式", "Runtime": "運行時間", "TV": "電視", - "TabUsers": "使用者", "Trailers": "預告", "LabelImageFetchersHelp": "啟用並按優先順序排序您的首選圖片擷取器。", "LabelDownMixAudioScale": "縮混時的音訊增強:", From ce74cb0602132cfbb4cee40df130257230a47943 Mon Sep 17 00:00:00 2001 From: MrTimscampi Date: Thu, 13 Aug 2020 15:37:09 +0200 Subject: [PATCH 193/301] Fix lint --- src/components/appRouter.js | 1 - 1 file changed, 1 deletion(-) diff --git a/src/components/appRouter.js b/src/components/appRouter.js index 83c93fdaf3..28826c55cc 100644 --- a/src/components/appRouter.js +++ b/src/components/appRouter.js @@ -323,7 +323,6 @@ class AppRouter { } import('text!' + url).then(({default: html}) => { - console.warn(html) this.loadContent(ctx, route, html, request); }); } From b6a5f67d364d799037c840f50b78fb99964118af Mon Sep 17 00:00:00 2001 From: Oatavandi Date: Thu, 13 Aug 2020 15:08:55 +0000 Subject: [PATCH 194/301] Added translation using Weblate (Tamil) --- src/strings/ta.json | 1 + 1 file changed, 1 insertion(+) create mode 100644 src/strings/ta.json diff --git a/src/strings/ta.json b/src/strings/ta.json new file mode 100644 index 0000000000..0967ef424b --- /dev/null +++ b/src/strings/ta.json @@ -0,0 +1 @@ +{} From d7e2cdf3db346751dd33d68f6828fc4e4d776298 Mon Sep 17 00:00:00 2001 From: Oatavandi Date: Thu, 13 Aug 2020 15:10:14 +0000 Subject: [PATCH 195/301] Translated using Weblate (Tamil) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/ta/ --- src/strings/ta.json | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/src/strings/ta.json b/src/strings/ta.json index 0967ef424b..be27ef78bb 100644 --- a/src/strings/ta.json +++ b/src/strings/ta.json @@ -1 +1,8 @@ -{} +{ + "AddToPlayQueue": "வரிசையில் விளையாட சேர்க்கவும்", + "AddToCollection": "சேகரிப்பில் சேர்க்கவும்", + "Add": "சேர்", + "Actor": "நடிகர்", + "AccessRestrictedTryAgainLater": "அணுகல் தற்போது தடைசெய்யப்பட்டுள்ளது. பின்னர் மீண்டும் முயற்சிக்கவும்.", + "Absolute": "அறுதி" +} From d1fadd1419b9a94d0e584f4649416ee7f57531aa Mon Sep 17 00:00:00 2001 From: Oatavandi Date: Thu, 13 Aug 2020 15:13:36 +0000 Subject: [PATCH 196/301] Translated using Weblate (Tamil) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/ta/ --- src/strings/ta.json | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/src/strings/ta.json b/src/strings/ta.json index be27ef78bb..0f527990a1 100644 --- a/src/strings/ta.json +++ b/src/strings/ta.json @@ -4,5 +4,8 @@ "Add": "சேர்", "Actor": "நடிகர்", "AccessRestrictedTryAgainLater": "அணுகல் தற்போது தடைசெய்யப்பட்டுள்ளது. பின்னர் மீண்டும் முயற்சிக்கவும்.", - "Absolute": "அறுதி" + "Absolute": "அறுதி", + "AdditionalNotificationServices": "கூடுதல் அறிவிப்பு சேவைகளை நிறுவ சொருகி பட்டியலை உலாவுக.", + "AddedOnValue": "{0} சேர்க்கப்பட்டது", + "AddToPlaylist": "பட்டியலில் சேர்" } From 61c4d3ac6652dc96feedc2ac493ed7d4d6e49abd Mon Sep 17 00:00:00 2001 From: Oatavandi Date: Thu, 13 Aug 2020 15:15:30 +0000 Subject: [PATCH 197/301] Translated using Weblate (Tamil) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/ta/ --- src/strings/ta.json | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/src/strings/ta.json b/src/strings/ta.json index 0f527990a1..1b4d9bb974 100644 --- a/src/strings/ta.json +++ b/src/strings/ta.json @@ -7,5 +7,6 @@ "Absolute": "அறுதி", "AdditionalNotificationServices": "கூடுதல் அறிவிப்பு சேவைகளை நிறுவ சொருகி பட்டியலை உலாவுக.", "AddedOnValue": "{0} சேர்க்கப்பட்டது", - "AddToPlaylist": "பட்டியலில் சேர்" + "AddToPlaylist": "பட்டியலில் சேர்", + "AirDate": "ஒளிபரப்பப்பட்ட தேதி" } From 702594cc1b65c7ef475b3cd57d6522220388d0ca Mon Sep 17 00:00:00 2001 From: Oatavandi Date: Thu, 13 Aug 2020 15:16:08 +0000 Subject: [PATCH 198/301] Translated using Weblate (Tamil) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/ta/ --- src/strings/ta.json | 31 ++++++++++++++++++++++++++++++- 1 file changed, 30 insertions(+), 1 deletion(-) diff --git a/src/strings/ta.json b/src/strings/ta.json index 1b4d9bb974..9f4302528d 100644 --- a/src/strings/ta.json +++ b/src/strings/ta.json @@ -8,5 +8,34 @@ "AdditionalNotificationServices": "கூடுதல் அறிவிப்பு சேவைகளை நிறுவ சொருகி பட்டியலை உலாவுக.", "AddedOnValue": "{0} சேர்க்கப்பட்டது", "AddToPlaylist": "பட்டியலில் சேர்", - "AirDate": "ஒளிபரப்பப்பட்ட தேதி" + "AirDate": "ஒளிபரப்பப்பட்ட தேதி", + "AsManyAsPossible": "முடிந்தவரை பல", + "Artists": "கலைஞர்", + "Artist": "கலைஞர்", + "Art": "கலை", + "AroundTime": "சுற்றி", + "Anytime": "எப்போது வேண்டுமானாலும்", + "AnyLanguage": "எந்த மொழியும்", + "AlwaysPlaySubtitlesHelp": "ஆடியோ மொழியைப் பொருட்படுத்தாமல் மொழி விருப்பத்துடன் பொருந்தக்கூடிய வசன வரிகள் ஏற்றப்படும்.", + "AlwaysPlaySubtitles": "எப்போதும் ப்ளே", + "AllowedRemoteAddressesHelp": "தொலைதூரத்துடன் இணைக்க அனுமதிக்கப்படும் நெட்வொர்க்குகளுக்கான ஐபி முகவரிகள் அல்லது ஐபி / நெட்மாஸ்க் உள்ளீடுகளின் கமாவால் பிரிக்கப்பட்ட பட்டியல். காலியாக இருந்தால், எல்லா தொலை முகவரிகளும் அனுமதிக்கப்படும்.", + "AllowRemoteAccessHelp": "தேர்வு செய்யப்படாவிட்டால், எல்லா தொலைநிலை இணைப்புகளும் தடுக்கப்படும்.", + "AllowRemoteAccess": "இந்த சேவையகத்திற்கு தொலை இணைப்புகளை அனுமதிக்கவும்.", + "AllowFfmpegThrottlingHelp": "ஒரு டிரான்ஸ்கோட் அல்லது ரீமக்ஸ் தற்போதைய பின்னணி நிலையிலிருந்து வெகு தொலைவில் இருக்கும்போது, செயல்முறையை இடைநிறுத்துங்கள், இதனால் அது குறைந்த ஆதாரங்களை நுகரும். அடிக்கடி தேடாமல் பார்க்கும்போது இது மிகவும் பயனுள்ளதாக இருக்கும். பின்னணி சிக்கல்களை நீங்கள் சந்தித்தால் இதை அணைக்கவும்.", + "AllowFfmpegThrottling": "த்ரோட்டில் டிரான்ஸ்கோட்கள்", + "AllowOnTheFlySubtitleExtractionHelp": "வீடியோ டிரான்ஸ்கோடிங்கைத் தடுக்க உதவும் வகையில் உட்பொதிக்கப்பட்ட வசனங்களை வீடியோக்களிலிருந்து பிரித்தெடுத்து வாடிக்கையாளர்களுக்கு எளிய உரையில் வழங்கலாம். சில கணினிகளில் இது நீண்ட நேரம் எடுக்கும் மற்றும் பிரித்தெடுக்கும் செயல்பாட்டின் போது வீடியோ பிளேபேக் நிறுத்தப்படும். கிளையன்ட் சாதனத்தால் பூர்வீகமாக ஆதரிக்கப்படாதபோது உட்பொதிக்கப்பட்ட வசன வரிகள் வீடியோ டிரான்ஸ்கோடிங்கில் எரிக்கப்படுவதை முடக்கு.", + "AllowOnTheFlySubtitleExtraction": "பறக்கையில் வசன வரிகள் பிரித்தெடுக்க அனுமதிக்கவும்", + "AllowMediaConversionHelp": "மாற்றும் ஊடக அம்சத்திற்கான அணுகலை வழங்கவும் அல்லது மறுக்கவும்.", + "AllowMediaConversion": "ஊடக மாற்றத்தை அனுமதிக்கவும்", + "AllowHWTranscodingHelp": "ட்யூனரை பறக்கும்போது ஸ்ட்ரீம்களை டிரான்ஸ்கோட் செய்ய அனுமதிக்கவும். இது சேவையகத்திற்கு தேவையான டிரான்ஸ்கோடிங்கைக் குறைக்க உதவும்.", + "AllLibraries": "அனைத்து நூலகங்களும்", + "AllLanguages": "அனைத்து மொழிகளையும்", + "AllEpisodes": "எல்லா அத்தியாயங்களும்", + "AllComplexFormats": "அனைத்து சிக்கலான வடிவங்களும் (ASS, SSA, VOBSUB, PGS, SUB, IDX,…)", + "AllChannels": "எல்லா சேனல்களும்", + "All": "அனைத்தும்", + "Alerts": "விழிப்பூட்டல்கள்", + "AlbumArtist": "கலைஞர்", + "Album": "ஆல்பம்", + "Aired": "ஒளிபரப்பானது" } From e309a05507b35ff72bb6767f2f30ff2c11fd6f25 Mon Sep 17 00:00:00 2001 From: Oatavandi Date: Thu, 13 Aug 2020 15:30:22 +0000 Subject: [PATCH 199/301] Translated using Weblate (Tamil) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/ta/ --- src/strings/ta.json | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/src/strings/ta.json b/src/strings/ta.json index 9f4302528d..6832774720 100644 --- a/src/strings/ta.json +++ b/src/strings/ta.json @@ -37,5 +37,11 @@ "Alerts": "விழிப்பூட்டல்கள்", "AlbumArtist": "கலைஞர்", "Album": "ஆல்பம்", - "Aired": "ஒளிபரப்பானது" + "Aired": "ஒளிபரப்பானது", + "AuthProviderHelp": "இந்த பயனரின் கடவுச்சொல்லை அங்கீகரிக்க பயன்படும் அங்கீகார வழங்குநரைத் தேர்ந்தெடுக்கவும்.", + "Audio": "ஒலி", + "AttributeNew": "புதியது", + "AspectRatio": "விகிதம்", + "AskAdminToCreateLibrary": "ஒரு நூலகத்தை உருவாக்க நிர்வாகியிடம் கேளுங்கள்.", + "Ascending": "ஏறுவரிசை" } From fc825eeaa2ba4e75ab4bfc645d0776aa754347e5 Mon Sep 17 00:00:00 2001 From: Oatavandi Date: Thu, 13 Aug 2020 15:32:32 +0000 Subject: [PATCH 200/301] Translated using Weblate (Tamil) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/ta/ --- src/strings/ta.json | 14 +++++++++++++- 1 file changed, 13 insertions(+), 1 deletion(-) diff --git a/src/strings/ta.json b/src/strings/ta.json index 6832774720..3fb9377a50 100644 --- a/src/strings/ta.json +++ b/src/strings/ta.json @@ -43,5 +43,17 @@ "AttributeNew": "புதியது", "AspectRatio": "விகிதம்", "AskAdminToCreateLibrary": "ஒரு நூலகத்தை உருவாக்க நிர்வாகியிடம் கேளுங்கள்.", - "Ascending": "ஏறுவரிசை" + "Ascending": "ஏறுவரிசை", + "BoxSet": "பெட்டி தொகுப்பு", + "Box": "பெட்டி", + "Books": "புத்தகங்கள்", + "BookLibraryHelp": "ஆடியோ மற்றும் உரை புத்தகங்கள் துணைபுரிகின்றன. {0} புத்தக பெயரிடும் வழிகாட்டியை மதிப்பாய்வு செய்யவும் {1}.", + "Blacklist": "தடுப்புப்பட்டியல்", + "BirthPlaceValue": "பிறந்த இடம்: {0}", + "BirthLocation": "பிறந்த இடம்", + "BirthDateValue": "பிறப்பு: {0}", + "Banner": "பதாகை", + "Backdrops": "பின்புலங்கள்", + "Backdrop": "பின்னணி", + "Auto": "தானாக" } From 23a8fc85e5af520ea6e30064666c001574d567f6 Mon Sep 17 00:00:00 2001 From: Oatavandi Date: Thu, 13 Aug 2020 15:39:49 +0000 Subject: [PATCH 201/301] Translated using Weblate (Tamil) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/ta/ --- src/strings/ta.json | 36 +++++++++++++++++++++++++++++++++++- 1 file changed, 35 insertions(+), 1 deletion(-) diff --git a/src/strings/ta.json b/src/strings/ta.json index 3fb9377a50..e6978da08e 100644 --- a/src/strings/ta.json +++ b/src/strings/ta.json @@ -55,5 +55,39 @@ "Banner": "பதாகை", "Backdrops": "பின்புலங்கள்", "Backdrop": "பின்னணி", - "Auto": "தானாக" + "Auto": "தானாக", + "ButtonArrowLeft": "இடப்பக்கம்", + "ButtonArrowDown": "கீழே", + "ButtonAddUser": "பயனரைச் சேர்க்கவும்", + "ButtonAddServer": "சேவையகத்தைச் சேர்க்கவும்", + "ButtonAddScheduledTaskTrigger": "தூண்டுதலைச் சேர்க்கவும்", + "ButtonAddMediaLibrary": "ஊடக நூலகத்தைச் சேர்க்கவும்", + "ButtonAddImage": "படத்தைச் சேர்க்கவும்", + "BurnSubtitlesHelp": "வீடியோக்களை டிரான்ஸ்கோட் செய்யும் போது சேவையகம் வசன வரிகள் எரிக்க வேண்டுமா என்பதை தீர்மானிக்கிறது. இதைத் தவிர்ப்பது செயல்திறனை பெரிதும் மேம்படுத்தும். பட அடிப்படையிலான வடிவங்கள் (VOBSUB, PGS, SUB, IDX,…) மற்றும் சில ASS அல்லது SSA வசன வரிகள் எரிக்க ஆட்டோவைத் தேர்ந்தெடுக்கவும்.", + "MessageBrowsePluginCatalog": "கிடைக்கக்கூடிய செருகுநிரல்களைக் காண எங்கள் சொருகி பட்டியலை உலாவுக.", + "Browse": "உலவ", + "BoxRear": "பெட்டி (பின்புறம்)", + "ValueSpecialEpisodeName": "சிறப்பு - {0}", + "Sync": "ஒத்திசைவு", + "Songs": "பாட்டுகள்", + "Shows": "தொடர்கள்", + "Playlists": "தொடர் பட்டியல்கள்", + "Photos": "புகைப்படங்கள்", + "Movies": "திரைப்படங்கள்", + "HeaderNextUp": "அடுத்ததாக", + "HeaderLiveTV": "நேரடித் தொலைக்காட்சி", + "HeaderFavoriteSongs": "பிடித்த பாட்டுகள்", + "HeaderFavoriteArtists": "பிடித்த கலைஞர்கள்", + "HeaderFavoriteAlbums": "பிடித்த ஆல்பங்கள்", + "HeaderFavoriteEpisodes": "பிடித்த அத்தியாயங்கள்", + "HeaderFavoriteShows": "பிடித்த தொடர்கள்", + "HeaderContinueWatching": "தொடர்ந்து பார்", + "HeaderAlbumArtists": "இசைக் கலைஞர்கள்", + "Genres": "வகைகள்", + "Folders": "கோப்புறைகள்", + "Favorites": "பிடித்தவை", + "Collections": "தொகுப்புகள்", + "Channels": "சேனல்கள்", + "Albums": "ஆல்பங்கள்", + "Preview": "முன்னோட்டம்" } From efe0d70cfc5506e9f2b2e2c217f11590a4a7f681 Mon Sep 17 00:00:00 2001 From: Oatavandi Date: Thu, 13 Aug 2020 15:51:18 +0000 Subject: [PATCH 202/301] Translated using Weblate (Tamil) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/ta/ --- src/strings/ta.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/src/strings/ta.json b/src/strings/ta.json index e6978da08e..7b1eb9c09c 100644 --- a/src/strings/ta.json +++ b/src/strings/ta.json @@ -89,5 +89,7 @@ "Collections": "தொகுப்புகள்", "Channels": "சேனல்கள்", "Albums": "ஆல்பங்கள்", - "Preview": "முன்னோட்டம்" + "Preview": "முன்னோட்டம்", + "ButtonArrowUp": "மேலே", + "ButtonArrowRight": "வலப்பக்க" } From 91b61389b9552962990b3c0cc099f14e2d7e2dad Mon Sep 17 00:00:00 2001 From: Oatavandi Date: Thu, 13 Aug 2020 16:00:18 +0000 Subject: [PATCH 203/301] Translated using Weblate (Tamil) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/ta/ --- src/strings/ta.json | 18 +++++++++++++++++- 1 file changed, 17 insertions(+), 1 deletion(-) diff --git a/src/strings/ta.json b/src/strings/ta.json index 7b1eb9c09c..c88908c2c9 100644 --- a/src/strings/ta.json +++ b/src/strings/ta.json @@ -91,5 +91,21 @@ "Albums": "ஆல்பங்கள்", "Preview": "முன்னோட்டம்", "ButtonArrowUp": "மேலே", - "ButtonArrowRight": "வலப்பக்க" + "ButtonArrowRight": "வலப்பக்க", + "ButtonGotIt": "அறிந்துகொண்டேன்", + "ButtonFullscreen": "முழு திரை", + "ButtonForgotPassword": "கடவுச்சொல்லை மறந்துவிட்டீர்களா", + "ButtonFilter": "வடிகட்டு", + "ButtonEditOtherUserPreferences": "இந்த பயனரின் சுயவிவரம், படம் மற்றும் தனிப்பட்ட விருப்பங்களைத் திருத்தவும்.", + "ButtonEditImages": "படங்களைத் திருத்து", + "ButtonEdit": "தொகு", + "ButtonDownload": "பதிவிறக்க", + "ButtonDown": "கீழே", + "ButtonDeleteImage": "படத்தை நீக்கு", + "ButtonDelete": "அழி", + "ButtonConnect": "இணை", + "ButtonChangeServer": "சேவையகத்தை மாற்று", + "ButtonCancel": "ரத்துசெய்", + "ButtonBack": "பின்னால்", + "ButtonAudioTracks": "ஒலிப்பதிவுகள்" } From e1b28f24f60deaa6c473352d07fcb21a01e9d294 Mon Sep 17 00:00:00 2001 From: Oatavandi Date: Thu, 13 Aug 2020 16:07:33 +0000 Subject: [PATCH 204/301] Translated using Weblate (Tamil) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/ta/ --- src/strings/ta.json | 49 ++++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 48 insertions(+), 1 deletion(-) diff --git a/src/strings/ta.json b/src/strings/ta.json index c88908c2c9..85cfbe8794 100644 --- a/src/strings/ta.json +++ b/src/strings/ta.json @@ -107,5 +107,52 @@ "ButtonChangeServer": "சேவையகத்தை மாற்று", "ButtonCancel": "ரத்துசெய்", "ButtonBack": "பின்னால்", - "ButtonAudioTracks": "ஒலிப்பதிவுகள்" + "ButtonAudioTracks": "ஒலிப்பதிவுகள்", + "ButtonUp": "மேலே", + "ButtonUninstall": "நிறுவல் நீக்கு", + "ButtonTrailer": "டிரெய்லர்", + "ButtonTogglePlaylist": "பிளேலிஸ்ட்", + "ButtonSubtitles": "வசன வரிகள்", + "ButtonSubmit": "சமர்ப்பிக்கவும்", + "ButtonSplit": "பிரிக்கவும்", + "ButtonStop": "நிறுத்து", + "ButtonStart": "தொடங்கு", + "ButtonSort": "வகைபடுத்து", + "ButtonSignOut": "வெளியேறு", + "ButtonSignIn": "உள்நுழைக", + "ButtonShutdown": "பணிநிறுத்தம்", + "ButtonShuffle": "கலக்கு", + "ButtonSettings": "அமைப்புகள்", + "ButtonSend": "அனுப்புக", + "ButtonSelectView": "பார்வையைத் தேர்ந்தெடுக்கவும்", + "ButtonSelectServer": "சேவையகத்தைத் தேர்ந்தெடுக்கவும்", + "ButtonSelectDirectory": "கோப்பகத்தைத் தேர்ந்தெடுக்கவும்", + "ButtonScanAllLibraries": "அனைத்து நூலகங்களையும் ஸ்கேன் செய்யுங்கள்", + "ButtonRevoke": "திரும்பப் பெறு", + "ButtonResume": "மீண்டும் தொடர்", + "ButtonRestart": "மறுதொடக்கம்", + "ButtonResetPassword": "கடவுச்சொல்லை மீட்டமைக்க", + "ButtonResetEasyPassword": "எளிதான முள் குறியீட்டை மீட்டமைக்கவும்", + "ButtonRename": "மறுபெயரிடு", + "ButtonRemove": "அகற்று", + "ButtonRefreshGuideData": "வழிகாட்டி தரவைப் புதுப்பிக்கவும்", + "ButtonRefresh": "புதுப்பிப்பு", + "ButtonQuickStartGuide": "விரைவு தொடக்க வழிகாட்டி", + "ButtonProfile": "சுயவிவரம்", + "ButtonPreviousTrack": "முந்தைய பாடல்", + "ButtonPlay": "வாசிக்கவும்", + "ButtonPause": "இடைநிறுத்தம்", + "ButtonParentalControl": "பெற்றோர் கட்டுப்பாடு", + "ButtonOpen": "திற", + "ButtonOk": "சரி", + "ButtonOff": "முடக்கு", + "ButtonNextTrack": "அடுத்த பாடல்", + "ButtonNew": "புதியது", + "ButtonNetwork": "வலைப்பின்னல்", + "ButtonMore": "மேலும்", + "ButtonManualLogin": "கைமுறை புகுபதிகை", + "ButtonLibraryAccess": "நூலக அணுகல்", + "ButtonInfo": "தகவல்", + "ButtonHome": "முகப்பு", + "ButtonGuide": "வழிகாட்டி" } From a334467ba17853b971c6287100ab68074ff5e22c Mon Sep 17 00:00:00 2001 From: Oatavandi Date: Thu, 13 Aug 2020 16:26:01 +0000 Subject: [PATCH 205/301] Translated using Weblate (Tamil) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/ta/ --- src/strings/ta.json | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/src/strings/ta.json b/src/strings/ta.json index 85cfbe8794..876a6d0cb8 100644 --- a/src/strings/ta.json +++ b/src/strings/ta.json @@ -154,5 +154,9 @@ "ButtonLibraryAccess": "நூலக அணுகல்", "ButtonInfo": "தகவல்", "ButtonHome": "முகப்பு", - "ButtonGuide": "வழிகாட்டி" + "ButtonGuide": "வழிகாட்டி", + "Categories": "பிரிவுகள்", + "CancelSeries": "தொடரை ரத்துசெய்", + "CancelRecording": "பதிவை ரத்துசெய்", + "ButtonWebsite": "இணையதளம்" } From be079275e3d1ae086f75d109d3e4de4b464269f2 Mon Sep 17 00:00:00 2001 From: tokyotexture Date: Thu, 13 Aug 2020 16:59:59 +0000 Subject: [PATCH 206/301] Translated using Weblate (Swedish) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/sv/ --- src/strings/sv.json | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/strings/sv.json b/src/strings/sv.json index 23c68d9e84..a9730d3f4a 100644 --- a/src/strings/sv.json +++ b/src/strings/sv.json @@ -19,7 +19,7 @@ "AllowHWTranscodingHelp": "Tillåt TV-mottagaren att omkoda strömmar. Det kan minska behovet av omkodning på Jellyfin Servern.", "AllowOnTheFlySubtitleExtraction": "Tillåt undertextsextrahering under uppspelning", "AllowOnTheFlySubtitleExtractionHelp": "Inbäddade undertexter kan extraheras ur videor och skickas till klienter i textformat för att förhindra omkodning. I vissa system kan detta ta en lång tid och förhindra videouppspelningen under extraheringsprocessen. Avaktivera detta för att bränna in inbäddade undertexter genom omkodning när de inte stöds av klienten.", - "AllowRemoteAccess": "Tillåt fjärranslutningar till denna Jellyfin-server.", + "AllowRemoteAccess": "Tillåt fjärranslutningar till denna server.", "AllowRemoteAccessHelp": "Om avaktiverat så blockeras alla fjärranslutningar.", "AlwaysPlaySubtitles": "Visa alltid", "AlwaysPlaySubtitlesHelp": "Undertexter på det önskade språket kommer att laddas oavsett ljudspårets språk.", @@ -121,7 +121,7 @@ "Collections": "Samlingar", "CommunityRating": "Användaromdöme", "Composer": "Kompositör", - "ConfigureDateAdded": "Konfigurera hur tillagt datum bestäms i Jellyfin servern under Biblioteksinställningar", + "ConfigureDateAdded": "Konfigurera hur tillagt datum bestäms under Biblioteksinställningar", "ConfirmDeleteImage": "Ta bort bild?", "ConfirmDeleteItem": "Tar du bort det här objeketet så tas det bort från både ditt filsystem och mediabibliotek. Är du säker på att du vill fortsätta?", "ConfirmDeleteItems": "Tar du bort dessa objekt tas dom också bort ifrån både ditt filsystem och mediabibliotek. Är du säker på att du vill fortsätta?", @@ -1255,7 +1255,7 @@ "ButtonGuide": "Guide", "Blacklist": "Svartlista", "Auto": "Automatisk", - "AuthProviderHelp": "Välj en autentiserings leverantör som ska användas för att autentisera denna användarens lösenord.", + "AuthProviderHelp": "Välj en autentiseringsleverantör som ska användas för att autentisera denna användarens lösenord.", "Ascending": "Stigande", "AllowedRemoteAddressesHelp": "Kommaavgränsad lista av IP-adresser eller IP/nätmask poster för nätverk som kommer bli tillåtna att ansluta avlägset. Om fältet lämnas tomt så kommer alla avlägsna adresser tillåtas.", "AllowMediaConversionHelp": "Tillåt eller neka tillgång till media konvertings funktionen.", From 2aa18a8b1db8239c6f60af3805e7bc28adb9a428 Mon Sep 17 00:00:00 2001 From: tokyotexture Date: Thu, 13 Aug 2020 17:05:18 +0000 Subject: [PATCH 207/301] Translated using Weblate (Japanese) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/ja/ --- src/strings/ja.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/strings/ja.json b/src/strings/ja.json index f57a1ea672..2459773a26 100644 --- a/src/strings/ja.json +++ b/src/strings/ja.json @@ -23,7 +23,7 @@ "AllowMediaConversionHelp": "メディア変換機能へのアクセスを許可もしくは、拒否します。", "AllowOnTheFlySubtitleExtraction": "字幕の抽出の許可/拒否", "AllowOnTheFlySubtitleExtractionHelp": "埋め込まれた字幕は、ビデオのトランスコードを防ぐために、ビデオから抽出してプレーンテキストでクライアントに配信できます。 システムによっては、これに時間がかかり、抽出中にビデオの再生が止まることがあります。 これを無効にし、埋め込み字幕がクライアントデバイスでネイティブにサポートされていない場合、ビデオのトランスコードが強制されます。", - "AllowRemoteAccess": "Jellyfin Serverへのリモート接続の許可。", + "AllowRemoteAccess": "サーバへのリモート接続の許可。", "AllowRemoteAccessHelp": "チェックが入っていない場合すべてのリモート接続をブロックします。", "AllowedRemoteAddressesHelp": "リモート接続を許可するネットワークのIPアドレスまたはIPアドレス/マスク長 空白のままにすると、すべてのリモートアドレスが許可されます。", "AlwaysPlaySubtitles": "常に有効", From de2b26bbfcf9aa5b27a3d77a360de06ec0bbafc8 Mon Sep 17 00:00:00 2001 From: WontTell Date: Thu, 13 Aug 2020 17:07:25 +0000 Subject: [PATCH 208/301] Translated using Weblate (Spanish (Latin America)) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/es_419/ --- src/strings/es_419.json | 54 ++++++++++++++++++++--------------------- 1 file changed, 27 insertions(+), 27 deletions(-) diff --git a/src/strings/es_419.json b/src/strings/es_419.json index 7f1702c910..a168eb6c90 100644 --- a/src/strings/es_419.json +++ b/src/strings/es_419.json @@ -61,7 +61,7 @@ "LastSeen": "Ultima vez visto {0}", "PersonRole": "como {0}", "ListPaging": "{0}-{1} de {2}", - "WriteAccessRequired": "El servidor Jellyfin requiere permiso de escritura en esta carpeta. Por favor, asegúrate de tener acceso de escritura e inténtalo de nuevo.", + "WriteAccessRequired": "Jellyfin requiere permiso de escritura en esta carpeta. Por favor, asegúrate de tener acceso de escritura e inténtalo de nuevo.", "PathNotFound": "No se pudo encontrar la ruta. Por favor, asegúrate de que la ruta es válida e inténtalo de nuevo.", "Yesterday": "Ayer", "Yes": "Sí", @@ -352,7 +352,7 @@ "MessageTheFollowingLocationWillBeRemovedFromLibrary": "Las siguientes ubicaciones de medios se removerán de tu biblioteca:", "MessageSettingsSaved": "Configuraciones guardadas.", "MessageReenableUser": "Ver abajo para volver a habilitar", - "MessagePluginInstallDisclaimer": "Los complementos desarrollados por miembros de la comunidad Jellyfin son una gran forma de mejorar tu experiencia con Jellyfin con características y beneficios adicionales. Antes de instalar, por favor, conoce el impacto que pueden ocasionar en tu servidor Jellyfin, tales como escaneo más largo de bibliotecas, procesamiento en segundo plano adicional y reducción de la estabilidad del sistema.", + "MessagePluginInstallDisclaimer": "Los complementos desarrollados por miembros de la comunidad son una gran forma de mejorar tu experiencia con características y beneficios adicionales. Antes de instalar, por favor, conoce el impacto que pueden ocasionar en tu servidor, tales como escaneo más largo de bibliotecas, procesamiento en segundo plano adicional y reducción de la estabilidad del sistema.", "MessagePluginConfigurationRequiresLocalAccess": "Para configurar este complemento por favor, inicia sesión en tu servidor local directamente.", "MessagePleaseWait": "Por favor, espera. Esto podría tomar un minuto.", "MessagePleaseEnsureInternetMetadata": "Por favor, asegúrate de que la descarga de metadatos de Internet está habilitada.", @@ -378,7 +378,7 @@ "MessageEnablingOptionLongerScans": "Habilitar esta opción podría resultar en escaneos de bibliotecas significativamente más largos.", "MessageDownloadQueued": "Descarga puesta en la cola.", "MessageDirectoryPickerLinuxInstruction": "Para Linux en Arch Linux, CentOS, Debian, Fedora, openSUSE o Ubuntu, debes conceder al usuario del servicio al menos permisos de lectura a tus ubicaciones de almacenamiento.", - "MessageDirectoryPickerBSDInstruction": "Para BSD, quizás necesites configurar el almacenamiento dentro de tu «FreeNAS Jail» de manera que permita a Jellyfin accederlo.", + "MessageDirectoryPickerBSDInstruction": "Para BSD, quizás necesites configurar el almacenamiento dentro de tu «jail FreeNAS» de manera que Jellyfin pueda acceder a tus medios.", "List": "Lista", "Like": "Me gusta", "LibraryAccessHelp": "Selecciona las bibliotecas que deseas compartir con este usuario. Los administradores podrán editar todas las carpetas utilizando el gestor de metadatos.", @@ -514,10 +514,10 @@ "SettingsWarning": "Cambiar estos valores podría causar inestabilidad o fallas de conexión. Si experimentas cualquier problema, recomendamos volver a los valores por defecto.", "SettingsSaved": "Configuración guardada.", "Settings": "Configuración", - "ServerUpdateNeeded": "Este servidor Jellyfin necesita ser actualizado. Para descargar la última versión, por favor, visita {0}", - "ServerRestartNeededAfterPluginInstall": "El servidor Jellyfin necesitará reiniciarse después de instalar un complemento.", - "ServerNameIsShuttingDown": "El servidor Jellyfin - {0} se está apagando.", - "ServerNameIsRestarting": "El servidor Jellyfin - {0} se está reiniciando.", + "ServerUpdateNeeded": "Este servidor necesita ser actualizado. Para descargar la última versión, por favor, visita {0}", + "ServerRestartNeededAfterPluginInstall": "Jellyfin necesitará reiniciarse después de instalar un complemento.", + "ServerNameIsShuttingDown": "El servidor en {0} se está apagando.", + "ServerNameIsRestarting": "El servidor en {0} se está reiniciando.", "SeriesYearToPresent": "{0} - Actualidad", "SeriesSettings": "Configuración de la serie", "SeriesRecordingScheduled": "Grabación de series programadas.", @@ -585,9 +585,9 @@ "PreferEmbeddedEpisodeInfosOverFileNamesHelp": "Esto utiliza la información del episodio desde los metadatos incrustados si están disponibles.", "PreferEmbeddedTitlesOverFileNamesHelp": "Esto determina el título mostrado por defecto cuando no hay disponibles metadatos en Internet o localmente.", "PreferEmbeddedTitlesOverFileNames": "Preferir títulos incrustados a los nombres de archivo", - "MessagePluginInstalled": "El complemento ha sido instalado con éxito. El servidor Jellyfin necesitará ser reiniciado para que los cambios surtan efecto.", + "MessagePluginInstalled": "El complemento ha sido instalado con éxito. El servidor necesitará ser reiniciado para que los cambios surtan efecto.", "PleaseSelectTwoItems": "Por favor, selecciona al menos dos elementos.", - "PleaseRestartServerName": "Por favor, reinicia el servidor Jellyfin - {0}.", + "PleaseRestartServerName": "Por favor, reinicia Jellyfin en {0}.", "PleaseEnterNameOrId": "Por favor, introduce un nombre o ID externo.", "PleaseConfirmPluginInstallation": "Por favor, haz clic en OK para confirmar que has leído lo que se encuentra arriba y que deseas proceder con la instalación del complemento.", "PleaseAddAtLeastOneFolder": "Por favor, agrega al menos una carpeta a esta biblioteca dando clic al botón Agregar.", @@ -608,7 +608,7 @@ "PerfectMatch": "Coincidencia perfecta", "People": "Personas", "PasswordSaved": "Contraseña guardada.", - "PasswordResetProviderHelp": "Elige un proveedor de restablecimiento de contraseña para usar cuando este usuario solicite un restablecimiento de contraseña", + "PasswordResetProviderHelp": "Elige un proveedor de restablecimiento de contraseña para usar cuando este usuario solicite un restablecimiento de contraseña.", "HeaderResetPassword": "Restablecer contraseña", "PasswordResetConfirmation": "¿Estás seguro de querer restablecer la contraseña?", "PasswordResetComplete": "La contraseña ha sido restablecida.", @@ -634,7 +634,7 @@ "OptionSunday": "Domingo", "OptionSubstring": "Subcadena", "OptionSpecialEpisode": "Especiales", - "OptionSaveMetadataAsHiddenHelp": "Cambiar esto se aplicará a los nuevos metadatos guardados en el futuro. Los archivos de metadatos existentes serán actualizados la próxima vez que sean guardados por el servidor Jellyfin.", + "OptionSaveMetadataAsHiddenHelp": "Cambiar esto se aplicará a los nuevos metadatos guardados en el futuro. Los archivos de metadatos existentes serán actualizados la próxima vez que sean guardados por el servidor.", "OptionSaveMetadataAsHidden": "Guardar metadatos e imágenes como archivos ocultos", "OptionSaturday": "Sábado", "OptionRuntime": "Duración", @@ -722,7 +722,7 @@ "LabelOverview": "Resumen:", "LabelOriginalTitle": "Título original:", "LabelOriginalAspectRatio": "Relación de aspecto original:", - "LabelOptionalNetworkPathHelp": "Si esta carpeta es compartida en su red, proveer la ruta del recurso compartido de red puede permitir a las aplicaciones Jellyfin en otros dispositivos acceder a los archivos de medios directamente. Por ejemplo, {0} o {1}.", + "LabelOptionalNetworkPathHelp": "Si esta carpeta es compartida en su red, proveer la ruta del recurso compartido de red puede permitir a los clientes en otros dispositivos acceder a los archivos de medios directamente. Por ejemplo, {0} o {1}.", "LabelOptionalNetworkPath": "Carpeta de red compartida:", "LabelNumberOfGuideDaysHelp": "Descargar más días de datos de programación permite programar con mayor anticipación y ver más listados, pero tomará más tiempo en descargar. Auto hará la selección basada en el número de canales.", "LabelNumberOfGuideDays": "Número de días de datos de la programación a descargar:", @@ -754,7 +754,7 @@ "LabelMinResumeDuration": "Duración mínima para la reanudación:", "LabelMinBackdropDownloadWidth": "Anchura mínima de descarga de imágenes de fondo:", "LabelMethod": "Método:", - "LabelMetadataSaversHelp": "Selecciona los formatos de archivo con los que se guardarán tus metadatos.", + "LabelMetadataSaversHelp": "Selecciona los formatos de archivo a usar cuando se guarden tus metadatos.", "LabelMetadataSavers": "Grabadores de metadatos:", "LabelMetadataReadersHelp": "Ordena tus fuentes de metadatos locales por prioridad. El primer archivo encontrado será leído.", "LabelMetadataReaders": "Lectores de metadatos:", @@ -772,7 +772,7 @@ "LabelIconMaxWidth": "Ancho máximo del ícono:", "LabelIconMaxHeightHelp": "Resolución máxima de los íconos expuestos vía upnp:icon.", "LabelIconMaxHeight": "Altura máxima del ícono:", - "LabelHttpsPortHelp": "El número de puerto TCP al que el servidor HTTPS de Jellyfin debería enlazar.", + "LabelHttpsPortHelp": "El número de puerto TCP para el servidor HTTPS.", "LabelHttpsPort": "Número de puerto local HTTPS:", "LabelHomeScreenSectionValue": "Sección {0} de la pantalla de inicio:", "LabelHomeNetworkQuality": "Calidad en red local:", @@ -780,9 +780,9 @@ "LabelHardwareAccelerationType": "Aceleración por hardware:", "LabelEncoderPreset": "Codificación H264 y H265 preestablecida:", "LabelH264Crf": "CRF de codificación H264:", - "LabelGroupMoviesIntoCollectionsHelp": "Cuando se muestran listados de películas, las películas que pertenecen a una colección serán mostradas agrupadas en un solo artículo.", + "LabelGroupMoviesIntoCollectionsHelp": "Cuando se muestran listados de películas, las películas que estén en alguna colección serán mostradas agrupadas en un solo artículo.", "LabelGroupMoviesIntoCollections": "Agrupar películas en colecciones", - "LabelServerNameHelp": "Este nombre se usará para identificar el servidor y se predeterminará al nombre de la computadora del servidor.", + "LabelServerNameHelp": "Este nombre se usará para identificar el servidor y se predeterminará al nombre del servidor.", "LabelFriendlyName": "Nombre amistoso:", "LabelFormat": "Formato:", "LabelForgotPasswordUsernameHelp": "Introduce tu nombre de usuario, si lo recuerdas.", @@ -803,7 +803,7 @@ "LabelEnableSingleImageInDidlLimit": "Limitar a una sola imagen incrustada", "LabelEnableRealtimeMonitorHelp": "Los cambios en los archivos serán procesados inmediatamente, en los sistemas de archivo soportados.", "LabelEnableRealtimeMonitor": "Activar monitoreo en tiempo real", - "LabelEnableHttpsHelp": "Permite que el servidor escuche en el puerto HTTPS configurado. También se debe configurar un certificado válido para que esto surta efecto.", + "LabelEnableHttpsHelp": "Escuchar en el puerto HTTPS configurado. También se debe proporcionar un certificado válido para que esto surta efecto.", "LabelEnableHttps": "Habilitar HTTPS", "LabelEnableHardwareDecodingFor": "Habilitar decodificación por hardware para:", "LabelEnableDlnaServerHelp": "Permite a dispositivos UPnP en tu red explorar y reproducir contenido.", @@ -812,8 +812,8 @@ "LabelEnableDlnaPlayTo": "Habilitar Reproducir En mediante DLNA", "LabelEnableDlnaDebugLoggingHelp": "Crea grandes archivos de registro y solo se debe usar cuando se requiera para solucionar problemas.", "LabelEnableDlnaDebugLogging": "Habilitar el registro de depuración de DLNA", - "LabelEnableDlnaClientDiscoveryIntervalHelp": "Determina la duración en segundos entre búsquedas SSDP realizadas por Jellyfin.", - "LabelEnableDlnaClientDiscoveryInterval": "Intervalo de descubrimiento de clientes (segundos)", + "LabelEnableDlnaClientDiscoveryIntervalHelp": "Determina la duración en segundos entre búsquedas SSDP.", + "LabelEnableDlnaClientDiscoveryInterval": "Intervalo de descubrimiento de clientes", "LabelEnableBlastAliveMessagesHelp": "Habilita esto si el servidor no es detectado de manera confiable por otros dispositivos UPnP en tu red.", "LabelEnableBlastAliveMessages": "Bombardeo de mensajes de vida", "LabelEnableAutomaticPortMapHelp": "Redirecciona automáticamente los puertos públicos de tu router a los puertos locales de tu servidor a través de UPnP. Esto puede no funcionar con algunos modelos de routers o configuraciones de red. Los cambios no se aplicarán hasta después de reiniciar el servidor.", @@ -876,8 +876,8 @@ "MessageCreateAccountAt": "Crear una cuenta en {0}", "MessageContactAdminToResetPassword": "Por favor, contacta a tu administrador para restablecer tu contraseña.", "MessageConfirmShutdown": "¿Estás seguro de que deseas apagar el servidor?", - "MessageConfirmRevokeApiKey": "¿Estás seguro de querer revocar esta clave API? La conexión de la aplicación con el servidor Jellyfin será terminada abruptamente.", - "MessageConfirmRestart": "¿Estás seguro de que deseas reiniciar el servidor Jellyfin?", + "MessageConfirmRevokeApiKey": "¿Estás seguro de querer revocar esta clave API? La conexión de la aplicación a este servidor será terminada abruptamente.", + "MessageConfirmRestart": "¿Estás seguro de que deseas reiniciar Jellyfin?", "MessageConfirmRemoveMediaLocation": "¿Estás seguro de querer remover esta ubicación?", "MessageConfirmRecordingCancellation": "¿Cancelar grabación?", "MessageConfirmProfileDeletion": "¿Estás seguro de querer eliminar este perfil?", @@ -939,7 +939,7 @@ "LabelBitrate": "Velocidad de bits:", "LabelBirthYear": "Año de nacimiento:", "LabelBirthDate": "Fecha de nacimiento:", - "LabelBindToLocalNetworkAddressHelp": "Sobrescribe la dirección IP local del servidor HTTP. Si se deja vacío, el servidor se vinculará a todas las direcciones disponibles. Para cambiar este valor se necesita reiniciar el servidor.", + "LabelBindToLocalNetworkAddressHelp": "Sobrescribe la dirección IP local del servidor HTTP. Si se deja vacío, el servidor se vinculará a todas las direcciones disponibles. Cambiar este valor requiere un reinicio.", "LabelBindToLocalNetworkAddress": "Vincular a la dirección de red local:", "LabelAutomaticallyRefreshInternetMetadataEvery": "Actualizar automáticamente los metadatos desde Internet:", "LabelAuthProvider": "Proveedor de autenticación:", @@ -1146,7 +1146,7 @@ "LabelLoginDisclaimerHelp": "Un mensaje que se mostrará en la parte inferior de la página de inicio de sesión.", "LabelLoginDisclaimer": "Aviso legal:", "LabelLockItemToPreventChanges": "Bloquear este elemento para evitar cambios futuros", - "LabelLocalHttpServerPortNumberHelp": "El número de puerto TCP al que el servidor HTTP de Jellyfin debería enlazar.", + "LabelLocalHttpServerPortNumberHelp": "El número de puerto TCP para el servidor HTTP.", "LabelLocalHttpServerPortNumber": "Número de puerto local HTTP:", "LabelLineup": "Programación:", "LabelLibraryPageSizeHelp": "Establece el número de elementos a mostrar en una página de biblioteca. Establece en 0 para deshabilitar el paginado.", @@ -1273,10 +1273,10 @@ "ErrorPleaseSelectLineup": "Por favor, selecciona una programación e inténtalo de nuevo. Si no hay disponible ninguna, entonces, por favor, verifica que tu nombre de usuario, contraseña, y código postal sean correctos.", "ErrorStartHourGreaterThanEnd": "La hora de finalización debe ser mayor que la hora de inicio.", "ErrorGettingTvLineups": "Hubo un error al descargar la programación de TV. Por favor, asegúrate de que tu información sea correcta e inténtalo de nuevo.", - "ErrorDeletingItem": "Hubo un error eliminando el elemento del servidor Jellyfin. Por favor, verifica que el servidor Jellyfin tiene permisos de escritura en la carpeta del medio e inténtalo de nuevo.", + "ErrorDeletingItem": "Hubo un error eliminando el elemento del servidor. Por favor, verifica que Jellyfin tenga permisos de escritura en la carpeta del medio e inténtalo de nuevo.", "ErrorAddingXmlTvFile": "Hubo un error accediendo al archivo XMLTV. Por favor, asegúrate de que el archivo existe e inténtalo de nuevo.", "ErrorAddingTunerDevice": "Hubo un error al agregar el dispositivo sintonizador. Por favor, asegúrate de que esté disponible e inténtalo de nuevo.", - "ErrorAddingMediaPathToVirtualFolder": "Hubo un error agregando la ruta de medios. Por favor, asegúrate de que la ruta es válida y que el proceso del servidor Jellyfin tiene acceso a ese destino.", + "ErrorAddingMediaPathToVirtualFolder": "Hubo un error agregando la ruta de medios. Por favor, asegúrate de que la ruta es válida y que Jellyfin tiene acceso a ese destino.", "ErrorAddingListingsToSchedulesDirect": "Hubo un error agregando la programación de tu cuenta de Schedules Direct. Schedules Direct solo permite un numero limitado de programaciones por cuenta. Tal vez necesites acceder al sitio web de Schedules Direct y eliminar otras programaciones de tu cuenta antes de continuar.", "Episodes": "Episodios", "Episode": "Episodio", @@ -1326,7 +1326,7 @@ "Directors": "Directores", "DirectStreaming": "Transmisión directa", "DirectStreamHelp2": "Transmitir directamente un archivo usa muy poco poder de procesamiento sin ninguna perdida en la calidad de video.", - "DirectStreamHelp1": "El medio es compatible con el dispositivo en cuanto a la resolución y tipo de medio (H.264, AC3, etc.), pero está en un contenedor de archivo incompatible (mkv, avi, wmv, etc.). El video será reempaquetado sobre la marcha antes de transmitirlo al dispositivo.", + "DirectStreamHelp1": "El medio es compatible con el dispositivo en cuanto a la resolución y tipo de medio (H.264, AC3, etc.), pero está en un contenedor de archivo incompatible (mkv, avi, wmv, etc.). El video será reempaquetado sobre la marcha antes de ser enviado al dispositivo.", "DirectPlaying": "Reproducción directa", "DeviceAccessHelp": "Esto solo se aplica a los dispositivos que pueden ser identificados de manera única y no impedirá el acceso desde navegadores. Filtrar el acceso a los dispositivos de los usuarios les impedirá usar nuevos dispositivos hasta que hayan sido aprobados aquí.", "DetectingDevices": "Detectando dispositivos", @@ -1366,7 +1366,7 @@ "ConfirmDeleteItems": "Eliminar estos elementos los eliminará tanto del sistema como de tu biblioteca de medios. ¿Estás seguro de querer continuar?", "ConfirmDeleteItem": "Eliminar este elemento lo eliminará tanto del sistema como de tu biblioteca de medios. ¿Estás seguro de querer continuar?", "ConfirmDeleteImage": "¿Eliminar imagen?", - "ConfigureDateAdded": "Configura cómo se determina la fecha de adición en el panel de control del servidor Jellyfin en la configuración de la biblioteca", + "ConfigureDateAdded": "Configura cómo se determina la fecha de adición en el panel de control en la configuración de la biblioteca", "Composer": "Compositor", "CommunityRating": "Calificación de la comunidad", "ColorTransfer": "Transferencia de color", From 89d1957c9fe8a855c850093a8633ae8e348d6cdd Mon Sep 17 00:00:00 2001 From: Oatavandi Date: Thu, 13 Aug 2020 16:38:45 +0000 Subject: [PATCH 209/301] Translated using Weblate (Tamil) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/ta/ --- src/strings/ta.json | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) diff --git a/src/strings/ta.json b/src/strings/ta.json index 876a6d0cb8..1e594ffd71 100644 --- a/src/strings/ta.json +++ b/src/strings/ta.json @@ -69,7 +69,7 @@ "BoxRear": "பெட்டி (பின்புறம்)", "ValueSpecialEpisodeName": "சிறப்பு - {0}", "Sync": "ஒத்திசைவு", - "Songs": "பாட்டுகள்", + "Songs": "பாடல்கள்", "Shows": "தொடர்கள்", "Playlists": "தொடர் பட்டியல்கள்", "Photos": "புகைப்படங்கள்", @@ -158,5 +158,11 @@ "Categories": "பிரிவுகள்", "CancelSeries": "தொடரை ரத்துசெய்", "CancelRecording": "பதிவை ரத்துசெய்", - "ButtonWebsite": "இணையதளம்" + "ButtonWebsite": "இணையதளம்", + "ClientSettings": "வாடிக்கையாளர் அமைப்புகள்", + "CinemaModeConfigurationHelp": "சினிமா பயன்முறை தியேட்டர் அனுபவத்தை உங்கள் வாழ்க்கை அறைக்கு நேராக கொண்டு வருகிறது, முக்கிய அம்சத்திற்கு முன் டிரெய்லர்கள் மற்றும் தனிப்பயன் அறிமுகங்களை இயக்கும் திறன் கொண்டது.", + "ChannelNumber": "சேனல் எண்", + "ChannelNameOnly": "சேனல் {0} மட்டுமே", + "ChannelAccessHelp": "இந்த பயனருடன் பகிர சேனல்களைத் தேர்ந்தெடுக்கவும். நிர்வாகிகள் மெட்டாடேட்டா நிர்வாகியைப் பயன்படுத்தி அனைத்து சேனல்களையும் திருத்த முடியும்.", + "ChangingMetadataImageSettingsNewContent": "மெட்டாடேட்டா அல்லது கலைப்படைப்பு பதிவிறக்க அமைப்புகளுக்கான மாற்றங்கள் உங்கள் நூலகத்தில் சேர்க்கப்பட்ட புதிய உள்ளடக்கத்திற்கு மட்டுமே பொருந்தும். இருக்கும் தலைப்புகளில் மாற்றங்களைப் பயன்படுத்த, அவற்றின் மெட்டாடேட்டாவை கைமுறையாக புதுப்பிக்க வேண்டும்." } From 96d1ce9b68221902ca594a6d072f7fd4da212720 Mon Sep 17 00:00:00 2001 From: WontTell Date: Thu, 13 Aug 2020 17:33:23 +0000 Subject: [PATCH 210/301] Translated using Weblate (Spanish (Latin America)) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/es_419/ --- src/strings/es_419.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/strings/es_419.json b/src/strings/es_419.json index a168eb6c90..d495cdca9c 100644 --- a/src/strings/es_419.json +++ b/src/strings/es_419.json @@ -1502,7 +1502,7 @@ "EnableBlurHash": "Habilitar marcadores de posición borrosos para imágenes", "ShowMore": "Mostrar más", "ShowLess": "Mostrar menos", - "EnableBlurHashHelp": "Las imágenes que aún se están cargando se mostrarán con un marcador de posición borroso", + "EnableBlurHashHelp": "Las imágenes que aún se están cargando se mostrarán con uno temporal.", "ButtonSyncPlay": "SyncPlay", "MessageNoGenresAvailable": "Permitir a algunos proveedores de metadatos obtener géneros desde Internet.", "MessageAddRepository": "Si desea agregar un repositorio, haga clic en el botón al lado del encabezado y complete la información solicitada.", From d6ab99b59db6c73878758d4d02ed326e4478e8be Mon Sep 17 00:00:00 2001 From: Matjaz Zavski Date: Thu, 13 Aug 2020 21:22:42 +0200 Subject: [PATCH 211/301] Update src/elements/emby-checkbox/emby-checkbox.js Co-authored-by: Dmitry Lyzo <56478732+dmitrylyzo@users.noreply.github.com> --- src/elements/emby-checkbox/emby-checkbox.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/elements/emby-checkbox/emby-checkbox.js b/src/elements/emby-checkbox/emby-checkbox.js index 74a1696298..d44c58ed48 100644 --- a/src/elements/emby-checkbox/emby-checkbox.js +++ b/src/elements/emby-checkbox/emby-checkbox.js @@ -10,7 +10,7 @@ import 'webcomponents'; function onKeyDown(e) { // Don't submit form on enter // Real (non-emulator) Tizen does nothing on Space - if ((e.keyCode === 13 || e.keyCode === 32) && !browser.firefox) { + if (e.keyCode === 13 || (e.keyCode === 32 && browser.tizen)) { e.preventDefault(); this.checked = !this.checked; From ee54714603fb446e1cb7cc48b7f6ea75beda934c Mon Sep 17 00:00:00 2001 From: matjaz321 Date: Thu, 13 Aug 2020 21:25:38 +0200 Subject: [PATCH 212/301] Applied the same fix to the emby-radio.js --- src/elements/emby-radio/emby-radio.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/elements/emby-radio/emby-radio.js b/src/elements/emby-radio/emby-radio.js index 6fd2529085..8bd4f9fb84 100644 --- a/src/elements/emby-radio/emby-radio.js +++ b/src/elements/emby-radio/emby-radio.js @@ -9,7 +9,7 @@ import 'webcomponents'; function onKeyDown(e) { // Don't submit form on enter // Real (non-emulator) Tizen does nothing on Space - if (e.keyCode === 13 || e.keyCode === 32) { + if (e.keyCode === 13 || (e.keyCode === 32 && browser.tizen)) { e.preventDefault(); if (!this.checked) { From ffcc1181dcbca59438d36744991206b48df7f194 Mon Sep 17 00:00:00 2001 From: matjaz321 Date: Thu, 13 Aug 2020 22:41:49 +0200 Subject: [PATCH 213/301] small cr fix --- src/elements/emby-radio/emby-radio.js | 1 + 1 file changed, 1 insertion(+) diff --git a/src/elements/emby-radio/emby-radio.js b/src/elements/emby-radio/emby-radio.js index 8bd4f9fb84..7c468a84a6 100644 --- a/src/elements/emby-radio/emby-radio.js +++ b/src/elements/emby-radio/emby-radio.js @@ -1,6 +1,7 @@ import layoutManager from 'layoutManager'; import 'css!./emby-radio'; import 'webcomponents'; +import browser from 'browser'; /* eslint-disable indent */ From 5de2498f12cb4370dae14e3d418e3332dbda8835 Mon Sep 17 00:00:00 2001 From: Cameron Date: Thu, 13 Aug 2020 22:30:00 +0100 Subject: [PATCH 214/301] Update recordingcreator.js --- src/components/recordingcreator/recordingcreator.js | 8 +------- 1 file changed, 1 insertion(+), 7 deletions(-) diff --git a/src/components/recordingcreator/recordingcreator.js b/src/components/recordingcreator/recordingcreator.js index 43a91b4992..9cb4e41d2e 100644 --- a/src/components/recordingcreator/recordingcreator.js +++ b/src/components/recordingcreator/recordingcreator.js @@ -184,13 +184,7 @@ function showEditor(itemId, serverId) { init(dlg); - currentRecordingFields = new recordingFields({ - parent: dlg.querySelector('.recordingFields'), - programId: itemId, - serverId: serverId - }); - - events.on(currentRecordingFields, 'recordingchanged', onRecordingChanged); + reload(dlg, itemId, serverId); currentRecordingFields = new recordingFields({ parent: dlg.querySelector('.recordingFields'), From b1c96575f229c62d4b069cc53304f7ad55c6a921 Mon Sep 17 00:00:00 2001 From: Cameron Date: Thu, 13 Aug 2020 22:31:31 +0100 Subject: [PATCH 215/301] remove missed require --- src/components/recordingcreator/recordingeditor.js | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/src/components/recordingcreator/recordingeditor.js b/src/components/recordingcreator/recordingeditor.js index 5bd3d73c67..096ea3b62c 100644 --- a/src/components/recordingcreator/recordingeditor.js +++ b/src/components/recordingcreator/recordingeditor.js @@ -2,7 +2,6 @@ import dialogHelper from 'dialogHelper'; import globalize from 'globalize'; import layoutManager from 'layoutManager'; import connectionManager from 'connectionManager'; -import require from 'require'; import loading from 'loading'; import scrollHelper from 'scrollHelper'; import 'scrollStyles'; @@ -91,7 +90,7 @@ function showEditor(itemId, serverId, options) { options = options || {}; currentResolve = resolve; - require(['text!./recordingeditor.template.html'], function (template) { + import('text!./recordingeditor.template.html').then(({default: template}) => { const dialogOptions = { removeOnClose: true, scrollY: false From f333cc3cb7f25a0f3966e9037baa177f12351bf7 Mon Sep 17 00:00:00 2001 From: Marius Lindvall Date: Thu, 13 Aug 2020 21:46:33 +0000 Subject: [PATCH 216/301] =?UTF-8?q?Translated=20using=20Weblate=20(Norwegi?= =?UTF-8?q?an=20Bokm=C3=A5l)=20Translation:=20Jellyfin/Jellyfin=20Web=20Tr?= =?UTF-8?q?anslate-URL:=20https://translate.jellyfin.org/projects/jellyfin?= =?UTF-8?q?/jellyfin-web/nb=5FNO/?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/strings/nb.json | 90 +++++++++++++++++++++++---------------------- 1 file changed, 46 insertions(+), 44 deletions(-) diff --git a/src/strings/nb.json b/src/strings/nb.json index 66b383b616..814490cabc 100644 --- a/src/strings/nb.json +++ b/src/strings/nb.json @@ -17,7 +17,7 @@ "AllowHWTranscodingHelp": "Tillat at tuneren omkoder strømmer fortløpende. Dette kan bidra til å redusere mendgen omkoding som må utføres av serveren.", "AllowMediaConversion": "Tillat konvertering av media", "AllowMediaConversionHelp": "Tillatt eller forby tilgang til å konvertere media.", - "AllowRemoteAccess": "Tillat eksterne tilkoblinger til denne Jellyfin-serveren.", + "AllowRemoteAccess": "Tillat eksterne tilkoblinger til denne serveren.", "AllowRemoteAccessHelp": "Alle tilkoblinger via nettverk vil blokkeres dersom du ikke aktiverer denne innstillingen.", "Anytime": "Når som helst", "AroundTime": "Rundt", @@ -96,7 +96,7 @@ "ColorSpace": "Fargeutvalg", "ColorTransfer": "Overføring av farger", "Composer": "Komponist", - "ConfigureDateAdded": "Konfigurer hvordan \"Dato lagt til\" bestemmes på Jellyfin-serveren sitt dashbord under instillinger for Bibliotek", + "ConfigureDateAdded": "Konfigurer hvordan \"Dato lagt til\" bestemmes på dashbordet under innstillingene for bibliotek", "ConfirmDeleteImage": "Slett bilde?", "ConfirmDeleteItem": "Sletting av elementet vil slette det fra både filsystemet og biblioteket. Er du sikker på at du vil fortsette?", "ConfirmDeleteItems": "Sletting av disse elementene vil slette dem fra både filsystemet og mediebiblioteket. Er du sikker på at du vil fortsette?", @@ -141,7 +141,7 @@ "EndsAtValue": "Slutter klokken {0}", "Episodes": "Episoder", "ErrorAddingListingsToSchedulesDirect": "Det oppstod en feil når du la oppstillingen til Schedules Direct-kontoen din. Schedules Direct tillater kun et begrenset antall oppstillinger per konto. Det kan hende du må logge inn på Schedules Direct-nettstedet og fjerne andre lister fra kontoen din før du fortsetter.", - "ErrorAddingMediaPathToVirtualFolder": "Det oppstod en feil med å legge inn filbane til media. Vennligst sørg for at filbanen er gyldig og at Jellyfin-serverprosessen har tilgang til filbanen.", + "ErrorAddingMediaPathToVirtualFolder": "Det oppstod en feil med å legge inn filbane til media. Vennligst sørg for at filbanen er gyldig og at Jellyfin har tilgang til filbanen.", "ErrorAddingTunerDevice": "Det oppstod en feil når tuneren skulle legges til. Vennligst sørg for at den er tilgjengelig og prøv på nytt.", "ErrorAddingXmlTvFile": "Det oppstod en feil under lesing av XMLTV-filen. Vennligst sørg for at filen finnes og prøv igjen.", "ErrorGettingTvLineups": "Det oppstod en feil under nedlastning av TV-oversikten. Vennligst sørg for at informasjonen er korrekt og prøv igjen.", @@ -188,7 +188,7 @@ "HeaderAllowMediaDeletionFrom": "Tillat sletting av media fra", "HeaderApiKey": "API-nøkkel", "HeaderApiKeys": "API-nøkler", - "HeaderApiKeysHelp": "Eksterne programmer trenger en API-nøkkel for å kunne kommunisere med Jellyfin-serveren. Nøklene utstedes ved å logge på med en Jellyfin-konto, eller ved å manuelt gi programmet en nøkkel.", + "HeaderApiKeysHelp": "Eksterne programmer trenger en API-nøkkel for å kunne kommunisere med serveren. Nøklene utstedes ved å logge på med en vanlig brukerkonto eller gjennom å manuelt gi programmet en nøkkel.", "HeaderAudioBooks": "Lydbøker", "HeaderAudioSettings": "Lydinnstillinger", "HeaderBooks": "Bøker", @@ -285,7 +285,7 @@ "HeaderPreferredMetadataLanguage": "Foretrukket språk for metadata", "HeaderProfile": "Profil", "HeaderProfileInformation": "Profilinformasjon", - "HeaderProfileServerSettingsHelp": "Disse verdiene styrer hvordan Jellyfin-serveren presenterer seg selv for enheten.", + "HeaderProfileServerSettingsHelp": "Disse verdiene styrer hvordan serveren presenterer seg selv for klienter.", "HeaderRecentlyPlayed": "Nylig avspilt", "HeaderRecordingOptions": "Opptaksvalg", "HeaderRecordingPostProcessing": "Etterbehandling av opptak", @@ -307,7 +307,7 @@ "HeaderSelectServerCachePath": "Velg filbane for mellomlagring", "HeaderSelectServerCachePathHelp": "Bla eller skriv inn filbanen som skal brukes for mellomlagring av serverdata. Mappen må være skrivbar.", "HeaderSelectTranscodingPath": "Velg filbane for midlertidig lagring av omkodede filer", - "HeaderSelectTranscodingPathHelp": "Bla eller skriv inn filbanen som skal brukes for midlertidig lagring av omkodede filer. Mappen må være skrivbar.", + "HeaderSelectTranscodingPathHelp": "Bla eller skriv inn filbanen som skal brukes for omkodede filer. Mappen må være skrivbar.", "HeaderSendMessage": "Send melding", "HeaderSeriesOptions": "Serievalg", "HeaderServerSettings": "Serverinnstillinger", @@ -344,8 +344,8 @@ "HideWatchedContentFromLatestMedia": "Skjul sett innhold fra nyeste media", "Identify": "Identifiser", "Images": "Bilder", - "ImportFavoriteChannelsHelp": "Hvis aktivert, vil kun kanaler som er markert som favoritt på tuneren bli importert.", - "ImportMissingEpisodesHelp": "Hvis aktivert, vil informasjon om manglende episoder importeres til Jellyfin-databasen og de vil vises under sesonger og serier. Dette kan føre til at skanning av biblioteket tar betydelig lengre tid.", + "ImportFavoriteChannelsHelp": "Kun kanaler som er markert som favoritt på tuneren bli importert.", + "ImportMissingEpisodesHelp": "Informasjon om manglende episoder vil bli importet til databasen og bli vist under sesonger og serier. Dette kan føre til at skanning av biblioteket tar betydelig lengre tid.", "InstallingPackage": "Installerer {0} (versjon {1})", "InstantMix": "Direktemiks", "ItemCount": "{0} elementer", @@ -369,14 +369,14 @@ "LabelAppName": "Applikasjonsnavn", "LabelAppNameExample": "Eksempel: Sickbeard, Sonarr", "LabelArtists": "Artister:", - "LabelArtistsHelp": "Separer med semikolon ;", + "LabelArtistsHelp": "Separer flere artister med et semikolon.", "LabelAudioLanguagePreference": "Foretrukket språk på lydspor:", "LabelAutomaticallyRefreshInternetMetadataEvery": "Oppdater metadata automatisk fra Internett:", "LabelBindToLocalNetworkAddress": "Bind til lokal nettverksadresse:", - "LabelBindToLocalNetworkAddressHelp": "Valgfritt. Overstyrer den lokale IP-adressen som HTTP-serveren bindes til. Hvis tomt, vil serveren binde seg til alle tilgjengelige adresser. Endringer av denne verdien krever omstart av Jellyfin-serveren.", + "LabelBindToLocalNetworkAddressHelp": "Overstyr den lokale IP-adressen til HTTP-serveren. Hvis tomt, vil serveren binde seg til alle tilgjengelige adresser. Endringer av denne verdien krever en omstart.", "LabelBirthDate": "Fødselsdato:", "LabelBirthYear": "Fødselsår:", - "LabelBlastMessageInterval": "Intervall mellom keepalive-meldinger (sekunder)", + "LabelBlastMessageInterval": "Intervall mellom keepalive-meldinger", "LabelBlastMessageIntervalHelp": "Bestemmer intervallet i sekunder mellom keepalive-meldinger.", "LabelCachePath": "Filbane for mellomlagring:", "LabelCachePathHelp": "Angi en egendefinert plassering for mellomlagrede filer, som f.eks. bilder. La feltet stå tomt for å bruke standardverdi.", @@ -392,7 +392,7 @@ "LabelCurrentPassword": "Nåværende passord:", "LabelCustomCertificatePath": "Egendefinert filbane for SSL-sertifikat:", "LabelCustomCss": "Tilpasset CSS:", - "LabelCustomCssHelp": "Bruk tilpasset CSS-kode for å endre stil på web-grensesnittet.", + "LabelCustomCssHelp": "Bruk tilpassede stiler på web-grensesnittet.", "LabelCustomDeviceDisplayName": "Visningsnavn:", "LabelCustomDeviceDisplayNameHelp": "Oppgi et egendefinert visningsnavn eller la det være tomt for å bruke navnet som enheten rapporterer.", "LabelCustomRating": "Egen aldersgrense:", @@ -421,8 +421,8 @@ "LabelEnableAutomaticPortMapHelp": "Automatisk koble eksterne porter på ruteren til lokale porter på serveren din via UPnP. Dette fungerer ikke med alle rutere eller nettverkskonfigurasjoner. Endringer trer ikke kraft før serveren startes på nytt.", "LabelEnableBlastAliveMessages": "Kringkast keepalive-meldinger", "LabelEnableBlastAliveMessagesHelp": "Aktiver hvis serveren ikke blir konsekvent oppdaget av andre UPnP-enheter på nettverket ditt.", - "LabelEnableDlnaClientDiscoveryInterval": "Oppdateringsintervall for klient (i sekunder)", - "LabelEnableDlnaClientDiscoveryIntervalHelp": "Bestemmer intervallet i sekunder mellom SSDP-søk utført av Jellyfin.", + "LabelEnableDlnaClientDiscoveryInterval": "Oppdateringsintervall for klient", + "LabelEnableDlnaClientDiscoveryIntervalHelp": "Bestemmer intervallet i sekunder mellom SSDP-søk.", "LabelEnableDlnaDebugLogging": "Aktiver DLNA debug-logging", "LabelEnableDlnaDebugLoggingHelp": "Dette vil lage store loggfiler og burde kun benyttes for feilsøking.", "LabelEnableDlnaPlayTo": "Aktiver DLNA Play To", @@ -444,16 +444,16 @@ "LabelFinish": "Fullfør", "LabelForgotPasswordUsernameHelp": "Skriv inn brukernavnet ditt, dersom du husker det.", "LabelFriendlyName": "Egendefinert navn:", - "LabelServerNameHelp": "Dette navnet vil bli brukt for å identifisere denne serveren. Standardverdien er serverens maskinnavn.", + "LabelServerNameHelp": "Dette navnet vil bli brukt for å identifisere denne serveren. Standardverdien er serverens tjenernavn.", "LabelGroupMoviesIntoCollections": "Gruppér filmer i samlinger", - "LabelGroupMoviesIntoCollectionsHelp": "Ved visning av filmlister vil filmer som tilhører en samling bli vist som ett gruppeelement.", + "LabelGroupMoviesIntoCollectionsHelp": "Ved visning av filmlister, vil filmer i en samling bli vist som ett gruppert element.", "LabelH264Crf": "CRF-verdi for H264-koding:", "LabelEncoderPreset": "Forhåndsinnstilling for H264-koding:", "LabelHardwareAccelerationType": "Maskinvareakselerasjon:", "LabelHardwareAccelerationTypeHelp": "Maskinvareakselerasjon krever ytterligere konfigurasjon.", "LabelHomeScreenSectionValue": "Hjemskjermseksjon {0}:", "LabelHttpsPort": "Lokal HTTPS-port:", - "LabelHttpsPortHelp": "TCP-portnummeret som Jellyfin sin HTTPS-server skal benytte.", + "LabelHttpsPortHelp": "TCP-portnummeret for HTTPS-serveren.", "LabelIconMaxHeight": "Makshøyde for ikon:", "LabelIconMaxHeightHelp": "Maks oppløsning for ikoner eksponert via upnp:icon.", "LabelIconMaxWidth": "Maksbredde for ikon:", @@ -477,7 +477,7 @@ "LabelLanguage": "Språk:", "LabelLineup": "Oppstilling:", "LabelLocalHttpServerPortNumber": "Lokal HTTP-port:", - "LabelLocalHttpServerPortNumberHelp": "TCP-portnummeret som Jellyfin sin HTTP-server skal benytte.", + "LabelLocalHttpServerPortNumberHelp": "TCP-portnummeret for HTTP-serveren.", "LabelLockItemToPreventChanges": "Lås dette elementet for å hindre fremtidige endringer", "LabelLoginDisclaimer": "Ansvarsfraskrivelse ved innlogging:", "LabelLoginDisclaimerHelp": "En melding som vises på bunnen av innloggingssiden.", @@ -498,7 +498,7 @@ "LabelMetadataPathHelp": "Spesifiser en egen plassering for nedlastede omslagsbilder og metadata.", "LabelMetadataReaders": "Metadatalesere:", "LabelMetadataReadersHelp": "Ranger dine foretrukne lokale kilder for metadata i prioritert rekkefølge. Den første filen som blir funnet vil leses inn.", - "LabelMetadataSaversHelp": "Velg filformatene metadataen din skal lagres til.", + "LabelMetadataSaversHelp": "Velg filformatene som skal brukes ved lagring av metadata.", "LabelMethod": "Metode:", "LabelMinBackdropDownloadWidth": "Minimum bredde for nedlastede bakgrunner:", "LabelMinResumeDuration": "Minimum fortsettelsesvarighet:", @@ -513,7 +513,7 @@ "LabelMovieCategories": "Filmkategorier:", "LabelMoviePrefix": "Filmprefiks:", "LabelMoviePrefixHelp": "Hvis et prefiks benyttes i filmtitler, skriv det inn her slik at serveren kan håndtere det på riktig måte.", - "LabelMovieRecordingPath": "Filbane for filmopptak (valgfritt):", + "LabelMovieRecordingPath": "Filbane for filmopptak:", "LabelMusicStreamingTranscodingBitrate": "Bithastighet for omkoding av musikk:", "LabelMusicStreamingTranscodingBitrateHelp": "Spesifiser høyeste tillatte bithastighet ved musikkstrømming.", "LabelName": "Navn:", @@ -525,8 +525,8 @@ "LabelNumber": "Nummer:", "LabelNumberOfGuideDays": "Antall dager med TV-guidedata som skal lastes ned:", "LabelNumberOfGuideDaysHelp": "Nedlasting av TV-guide for flere dager gir muligheten for å planlegge lenger i forveien og for å se flere listinger, men vil også føre til at nedlastningen tar lenger tid. Auto vil velge basert på antall kanaler.", - "LabelOptionalNetworkPath": "(Valgfritt) Delt nettverksmappe:", - "LabelOptionalNetworkPathHelp": "Hvis denne mappen er delt på nettverket, vil Jellyfin-apper på andre enheter kunne få tilgang til mediefilene direkte dersom du spesifiserer nettverksbanen her. For eksempel, {0} eller {1}.", + "LabelOptionalNetworkPath": "Delt nettverksmappe:", + "LabelOptionalNetworkPathHelp": "Hvis denne mappen er delt på nettverket, vil klienter på andre enheter kunne få tilgang til mediefilene direkte dersom du spesifiserer nettverksbanen her. For eksempel, {0} eller {1}.", "LabelOriginalAspectRatio": "Originalt sideforhold:", "LabelOriginalTitle": "Original tittel:", "LabelOverview": "Oversikt:", @@ -564,7 +564,7 @@ "LabelRefreshMode": "Oppdateringsmodus:", "LabelReleaseDate": "Utgivelsesdato:", "LabelRemoteClientBitrateLimit": "Maksimal bithastighet for strømming til Internett (Mbps):", - "LabelRuntimeMinutes": "Spilletid (minutter):", + "LabelRuntimeMinutes": "Spilletid:", "LabelSaveLocalMetadata": "Lagre omslagsbilder og metadata i medie-mappene", "LabelSaveLocalMetadataHelp": "Lagring av omslagsbilder og metadata direkte i mediemapper vil legge dem på et sted hvor de lett kan endres på.", "LabelScheduledTaskLastRan": "Sist kjørt {0}, tok {1}.", @@ -575,7 +575,7 @@ "LabelSelectVersionToInstall": "Velg versjon å installere:", "LabelSendNotificationToUsers": "Send varslingen til:", "LabelSerialNumber": "Serienummer", - "LabelSeriesRecordingPath": "Plassering for serieopptak (valgfritt):", + "LabelSeriesRecordingPath": "Plassering for serieopptak:", "LabelServerHost": "Vertsnavn:", "LabelServerHostHelp": "192.168.1.100:8096 eller https://dinserver.no", "LabelSkipIfAudioTrackPresent": "Hopp over dersom standard lydspor matcher nedlastingsspråket", @@ -624,7 +624,7 @@ "LabelYoureDone": "Du er ferdig!", "LabelZipCode": "Postnummer:", "LabelffmpegPath": "Filbane til FFmpeg:", - "LabelffmpegPathHelp": "Filbanen til applikasjonsfilen for FFmpeg, eller mappen som inneholder FFmpeg.", + "LabelffmpegPathHelp": "Filbanen til applikasjonsfilen for FFmpeg eller mappen som inneholder FFmpeg.", "LatestFromLibrary": "Siste {0}", "LibraryAccessHelp": "Velg bibliotekene som skal deles med denne brukren. Administratorer vil ha mulighet til å gjøre endringer i alle mapper ved å bruke metadatabehandleren.", "Like": "Liker", @@ -662,13 +662,13 @@ "MessageConfirmProfileDeletion": "Er du sikker på at du vil slette denne profilen?", "MessageConfirmRecordingCancellation": "Avbryt opptak?", "MessageConfirmRemoveMediaLocation": "Er du sikker på at du vil slette denne plasseringen?", - "MessageConfirmRestart": "Er du sikker på at du vil starte Jellyfin-serveren på nytt?", - "MessageConfirmRevokeApiKey": "Er du sikker på at du vil tilbakekalle denne API-nøkkelen? Applikasjonens tilkobling til Jellyfin-serveren vil bli avbrutt umiddelbart.", + "MessageConfirmRestart": "Er du sikker på at du vil starte Jellyfin på nytt?", + "MessageConfirmRevokeApiKey": "Er du sikker på at du vil tilbakekalle denne API-nøkkelen? Applikasjonens tilkobling til denne serveren vil bli avbrutt umiddelbart.", "MessageConfirmShutdown": "Er du sikker på at du vil avslutte serveren?", "MessageContactAdminToResetPassword": "Vennligst kontakt systemadministratoren for hjelp til å tilbakestille passordet ditt.", "MessageCreateAccountAt": "Opprett en konto hos {0}", "MessageDeleteTaskTrigger": "Er du sikker på at du vil slette denne oppgaveutløseren?", - "MessageDirectoryPickerBSDInstruction": "På BSD-systemer må du kanskje endre lagringsinnstillinger i FreeNAS Jail slik at Jellyfin har tilgang dit.", + "MessageDirectoryPickerBSDInstruction": "På BSD-systemer må du kanskje endre lagringsinnstillinger i FreeNAS Jail slik at Jellyfin har tilgang til mediene dine.", "MessageDirectoryPickerLinuxInstruction": "På Linux-systemer med Arch Linux, CentOS, Debian, Fedora, openSUSE eller Ubuntu må du minimum gi tjenestebrukeren lesetilgang til lagringsplassene dine.", "MessageDownloadQueued": "Nedlasting lagt i kø.", "MessageEnablingOptionLongerScans": "Aktivering av dette alternativet kan føre til at skanning av biblioteket tar betydelig lenger tid.", @@ -690,7 +690,7 @@ "MessagePleaseEnsureInternetMetadata": "Vennligst sørg for at nedlasting av metadata fra internett er slått på.", "MessagePleaseWait": "Vennligst vent. Dette kan ta noe tid.", "MessagePluginConfigurationRequiresLocalAccess": "Logg inn direkte på din lokale server for å konfigurere dette programtillegget.", - "MessagePluginInstallDisclaimer": "Programtillegg utviklet av Jellyfin-samfunnet er en god måte å forbedre opplevelsen din av Jellyfin gjennom ekstra funksjoner og fordeler. Før installasjon bør du være klar over virkningen de kan ha på Jellyfin-serveren, som lengre skanning av bibliotek, ekstra bakgrunnsbehandling og redusert systemstabilitet.", + "MessagePluginInstallDisclaimer": "Programtillegg utviklet av brukersamfunnet er en god måte å forbedre opplevelsen din gjennom ekstra funksjoner og fordeler. Før installasjon bør du være klar over virkningen de kan ha på serveren din, som lengre skanning av bibliotek, ekstra bakgrunnsbehandling og redusert systemstabilitet.", "MessageReenableUser": "Se under for å reaktivere", "MessageSettingsSaved": "Innstillinger lagret.", "MessageTheFollowingLocationWillBeRemovedFromLibrary": "Følgende medieplassering vil bli fjernet fra biblioteket ditt:", @@ -698,7 +698,7 @@ "MessageUnsetContentHelp": "Innhold vises som enkle mapper. For beste resultat, bruk metadatabehandleren for å sette innholdstypen for undermapper.", "MessageYouHaveVersionInstalled": "Du har for øyeblikket versjon {0} installert.", "MetadataManager": "Metadatabehandler", - "MetadataSettingChangeHelp": "Endring av metadatainnstillinger vil gjelde nytt innhold som legges til fra nå av. For å oppdatere eksisterende innhold, åpne detaljer-menyen og klikk på oppdateringsknappen, eller kjør masseoppdatering ved hjelp av metadatabehandleren.", + "MetadataSettingChangeHelp": "Endring av metadatainnstillinger vil gjelde nytt innhold lagt til fra nå av. For å oppdatere eksisterende innhold, åpne detaljer-menyen og klikk på oppdateringsknappen, eller kjør masseoppdatering ved hjelp av metadatabehandleren.", "MinutesAfter": "minutter etter", "MinutesBefore": "minutter før", "Monday": "Mandag", @@ -742,7 +742,7 @@ "OptionAllowVideoPlaybackTranscoding": "Tillat filmavspilling som krever omkoding", "OptionAscending": "Økende", "OptionAutomaticallyGroupSeries": "Slå sammen serier som er spredt over flere mapper automatisk", - "OptionAutomaticallyGroupSeriesHelp": "Hvis aktivert, vil serier som er spredt over flere mapper innenfor dette biblioteket bli slått sammen automatisk til en enkelt serie.", + "OptionAutomaticallyGroupSeriesHelp": "Serier som er spredt over flere mapper innenfor dette biblioteket bli slått sammen automatisk til en enkelt serie.", "OptionBlockBooks": "Bøker", "OptionBlockChannelContent": "Innhold fra Internettkanal", "OptionBlockLiveTvChannels": "Direkte-TV-kanaler", @@ -761,7 +761,7 @@ "OptionDatePlayed": "Dato avspilt", "OptionDescending": "Fallende", "OptionDisableUser": "Deaktiver denne brukeren", - "OptionDisableUserHelp": "Hvis deaktivert vil ikke serveren godta noen tilkoblinger fra denne brukeren. Eksisterende tilkoblinger vil avsluttes umiddelbart.", + "OptionDisableUserHelp": "Serveren vil ikke godta noen tilkoblinger fra denne brukeren. Eksisterende tilkoblinger vil avsluttes umiddelbart.", "OptionDislikes": "Misliker", "OptionDisplayFolderView": "Vis en mappevisning for å vise enkle mediemapper", "OptionDisplayFolderViewHelp": "Vis mapper ved siden av andre mediebibliotek. Dette kan være nyttig hvis du vil ha en enkel mappevisning.", @@ -796,7 +796,7 @@ "OptionHideUserFromLoginHelp": "Praktisk for private eller skjulte administratorer. Brukeren vil måtte logge inn manuelt ved å skrive inn brukernavn og passord.", "OptionHlsSegmentedSubtitles": "HLS-segmenterte undertekster", "OptionIgnoreTranscodeByteRangeRequests": "Ignorer byte range-forespørsler ved omkoding", - "OptionIgnoreTranscodeByteRangeRequestsHelp": "Hvis aktivert vil disse forespørslene bli besvart, men byte-range-hodet vil ignoreres.", + "OptionIgnoreTranscodeByteRangeRequestsHelp": "Disse forespørslene bli besvart, men byte-range-hodet vil ignoreres.", "OptionImdbRating": "IMDb-vurdering", "OptionLikes": "Liker", "OptionMax": "Maks", @@ -807,9 +807,9 @@ "OptionOnInterval": "Per intervall", "OptionParentalRating": "Aldersgrense", "OptionPlainStorageFolders": "Vis alle mapper som enkle lagringsmapper", - "OptionPlainStorageFoldersHelp": "Hvis aktivert, vil alle mapper bli representert i DIDL som \"object.container.storageFolder\" istedet for en mer spesifikk type, som \"object.container.person.musicArtist\".", + "OptionPlainStorageFoldersHelp": "Alle mapper representeres i DIDL som \"object.container.storageFolder\" istedet for en mer spesifikk type, som \"object.container.person.musicArtist\".", "OptionPlainVideoItems": "Vis alle videoer som enkle videoelementer", - "OptionPlainVideoItemsHelp": "Hvis aktivert, blir alle videoer representert i DIDL som \"object.item.videoItem\" i stedet for en mer bestemt type, for eksempel \"object.item.videoItem.movie\".", + "OptionPlainVideoItemsHelp": "Alle videoer representerer i DIDL som \"object.item.videoItem\" i stedet for en mer bestemt type, for eksempel \"object.item.videoItem.movie\".", "OptionPlayCount": "Antall avspillinger", "OptionPlayed": "Avspilt", "OptionPremiereDate": "Premieredato", @@ -1057,7 +1057,7 @@ "General": "Generelt", "ChangingMetadataImageSettingsNewContent": "Endringer gjort i innstillinger for metadata eller omslagsbilder vil kun gjelde nytt innhold i biblioteket ditt. For å endre eksisterende innhold, må du oppdatere dets metadata manuelt.", "DefaultSubtitlesHelp": "Undertekster lastes inn basert på flaggene \"standard\" og \"tvungen\" i videoens integrerte metadata. Språkpreferanser tas høyde for dersom flere valg er tilgjengelig.", - "DirectStreamHelp2": "Direktestrømming av en fil bruker veldig lite ressurser uten tap av videokvalitet.", + "DirectStreamHelp2": "Direktestrømming bruker veldig lite ressurser med minimalt tap av videokvalitet.", "DisplayInMyMedia": "Vis på hjem-skjermen", "DisplayInOtherHomeScreenSections": "Vis i seksjoner på hjem-skjermen, som f.eks. siste spilte media og fortsett å se", "EnableThemeSongsHelp": "Spill av temamusikk i bakgrunnen mens du blar i biblioteket.", @@ -1139,7 +1139,7 @@ "EnableNextVideoInfoOverlayHelp": "Vis informasjon om den neste videoen i spillelisten ved slutten av en video.", "ExtractChapterImagesHelp": "Uthenting av kapittelbilder vil gjøre det mulig for klienter å vise bilder i menyer for å velge kapitel. Denne prosessen kan være treg, ressurskrevende, og kan kreve flere gigabyte med lagringsplass. Prosessen kjører når videoer oppdages, samt som en daglig planlagt hendelse. Tidsplanen kan endres i innstillinger for planlagte hendelser. Det anbefales ikke at denne prosessen kjøres når det er mange aktive brukere innlogget.", "Extras": "Ekstramateriale", - "HeaderKodiMetadataHelp": "For å aktivere eller deaktivere NFO-metadata, gå til bibliotekoppsettet i Jellyfin og finn valgene for lagring av metadata.", + "HeaderKodiMetadataHelp": "For å aktivere eller deaktivere NFO-metadata, endre biblioteket og finn valgene for lagring av metadata.", "OptionArtist": "Artist", "HeaderPhotoAlbums": "Fotoalbum", "HeaderSecondsValue": "{0} sekunder", @@ -1172,7 +1172,7 @@ "LanNetworksHelp": "Kommaseparert liste over IP-adresser eller IP/nettverksmaske for nettverk som skal regnes som lokalt nettverk når båndbreddebegrensninger skal håndheves. Hvis satt, vil alle andre IP-adresser bli regnet for å være på eksternt nettverk og vil dermed være underlagt båndbreddebegrensningene for eksterne nettverk. Hvis tomt, vil kun serverens subnettverk bli regnet for å være på det lokale nettverket.", "LearnHowYouCanContribute": "Finn ut hvordan du kan bidra.", "SeriesYearToPresent": "{0} - Nå", - "LabelBaseUrlHelp": "Legger til en egendefinert undermappe til serverens nettadresse. For eksempel: http://example.com/<baseurl>", + "LabelBaseUrlHelp": "Legg til en egendefinert undermappe til serverens nettadresse. For eksempel: http://example.com/<baseurl>", "LabelFont": "Skrifttype:", "LabelMatchType": "Matchtype:", "OptionPosterCard": "Plakatkort", @@ -1188,7 +1188,7 @@ "EnableExternalVideoPlayers": "Eksterne videospillere", "EnableExternalVideoPlayersHelp": "En liste over eksterne spillere vil vises når du starter videoavspilling.", "EnableNextVideoInfoOverlay": "Vis informasjon om neste video under avspilling", - "ErrorDeletingItem": "Det oppstod en feil under sletting av elementet fra Jellyfin-serveren. Vennligst sørg for at Jellyfin-serveren har skrivetilgang til mappen og prøv igjen.", + "ErrorDeletingItem": "Det oppstod en feil under sletting av elementet fra serveren. Vennligst sørg for at Jellyfin har skrivetilgang til mappen og prøv igjen.", "ExtraLarge": "Ekstra stor", "FetchingData": "Henter ytterligere data", "Folders": "Mapper", @@ -1290,10 +1290,10 @@ "OnlyForcedSubtitles": "Kun tvungen", "OnlyForcedSubtitlesHelp": "Bare last inn undertekster merket som tvungen.", "OnlyImageFormats": "Bare bildeformater (VOBSUB, PGS, SUB)", - "OptionAllowMediaPlaybackTranscodingHelp": "Begrensning av tilgang til omkoding kan føre til avspillingsfeil i Jellyfin-apper grunnet at medieformater ikke støtes.", + "OptionAllowMediaPlaybackTranscodingHelp": "Begrensning av tilgang til omkoding kan føre til avspillingsfeil hos klienter grunnet at medieformater ikke støttes.", "OptionAllowSyncTranscoding": "Tillat nedlastning og synkronisering av media som krever omkoding", "OptionCaptionInfoExSamsung": "CaptionInfoEx (Samsung)", - "OptionDownloadImagesInAdvanceHelp": "Som standard vil de fleste bilder kun lastes ned når de blir forespurt av en Jellyfin-app. Aktiver denne innstillingen for å laste ned alle bilder på forhånd når ny media oppdages. Dette kan føre til at skanning av biblioteket tar betydelig lenger tid.", + "OptionDownloadImagesInAdvanceHelp": "Som standard vil de fleste bilder kun lastes ned når de blir forespurt av en klient. Aktiver denne innstillingen for å laste ned alle bilder på forhånd når ny media oppdages. Dette kan føre til at skanning av biblioteket tar betydelig lenger tid.", "OptionDownloadLogoImage": "Logo", "OptionDownloadThumbImage": "Miniatyrbilde", "OptionHasTrailer": "Trailer", @@ -1416,7 +1416,7 @@ "MessageSyncPlayGroupDoesNotExist": "Kunne ikke bli med i gruppen fordi den ikke finnes.", "MessageSyncPlayPlaybackPermissionRequired": "Tillatelse for avspilling kreves.", "MessageSyncPlayNoGroupsAvailable": "Ingen grupper tilgjengelige. Begynn å spill noe først.", - "MessageSyncPlayGroupWait": "{0} bufrer...", + "MessageSyncPlayGroupWait": "{0} bufrer…", "MessageSyncPlayUserLeft": "{0} har forlatt gruppen.", "MessageSyncPlayUserJoined": "{0} har blitt med i gruppen.", "MessageSyncPlayDisabled": "SyncPlay deaktivert.", @@ -1437,7 +1437,7 @@ "LabelRequireHttps": "Krev HTTPS", "LabelStable": "Stabil", "LabelChromecastVersion": "Chromecast-versjon", - "LabelEnableHttpsHelp": "Aktiverer at serveren skal lytte på den valgte HTTPS-porten. Et gyldig sertifikat må også være konfigurert for at dette skal tre i kraft.", + "LabelEnableHttpsHelp": "Lytt på den valgte HTTPS-porten. Et gyldig sertifikat må også være angitt for at dette skal tre i kraft.", "LabelEnableHttps": "Aktiver HTTPS", "HeaderSyncPlayEnabled": "SyncPlay aktivert", "HeaderSyncPlaySelectGroup": "Bli med i en gruppe", @@ -1467,5 +1467,7 @@ "LabelRepositoryNameHelp": "Et egendefinert navn for å skille denne kilden fra andre som er lagt til på serveren din.", "ClearQueue": "Tøm køen", "ViewAlbumArtist": "Vis albumartist", - "StopPlayback": "Stopp avspilling" + "StopPlayback": "Stopp avspilling", + "NextTrack": "Hopp til neste", + "LabelUnstable": "Ustabil" } From cfc28c1b58d06393b449701ddd525600f8108991 Mon Sep 17 00:00:00 2001 From: WontTell Date: Thu, 13 Aug 2020 21:57:28 +0000 Subject: [PATCH 217/301] Translated using Weblate (Spanish (Latin America)) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/es_419/ --- src/strings/es_419.json | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/strings/es_419.json b/src/strings/es_419.json index f57a4a17d4..9f0422227a 100644 --- a/src/strings/es_419.json +++ b/src/strings/es_419.json @@ -1414,7 +1414,7 @@ "Backdrops": "Imágenes de fondo", "Backdrop": "Imagen de fondo", "Auto": "Auto", - "AuthProviderHelp": "Selecciona el proveedor de autenticación que se utilizará para autenticar la contraseña de este usuario.", + "AuthProviderHelp": "Selecciona un proveedor de autenticación que se utilizará para autenticar la contraseña de este usuario.", "Audio": "Audio", "AspectRatio": "Relación de aspecto", "AskAdminToCreateLibrary": "Pide a un administrador crear una biblioteca.", @@ -1472,7 +1472,7 @@ "LabelUnstable": "Inestable", "Preview": "Vista previa", "SubtitleVerticalPositionHelp": "Número de línea donde aparece el texto. Números positivos representan de arriba hacia abajo. Números negativos representan de abajo hacia arriba.", - "LabelSubtitleVerticalPosition": "Posición Vertical:", + "LabelSubtitleVerticalPosition": "Posición vertical:", "PreviousTrack": "Saltar al anterior", "MessageGetInstalledPluginsError": "Ocurrió un error buscando la lista de plugins instalados.", "MessagePluginInstallError": "Ocurrió un error instalando el plugin." From 844262e8a00d91bfaf5c6809c5775607a6b257f8 Mon Sep 17 00:00:00 2001 From: Marius Lindvall Date: Thu, 13 Aug 2020 22:00:53 +0000 Subject: [PATCH 218/301] =?UTF-8?q?Translated=20using=20Weblate=20(Norwegi?= =?UTF-8?q?an=20Bokm=C3=A5l)=20Translation:=20Jellyfin/Jellyfin=20Web=20Tr?= =?UTF-8?q?anslate-URL:=20https://translate.jellyfin.org/projects/jellyfin?= =?UTF-8?q?/jellyfin-web/nb=5FNO/?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/strings/nb.json | 28 +++++++++++++++++----------- 1 file changed, 17 insertions(+), 11 deletions(-) diff --git a/src/strings/nb.json b/src/strings/nb.json index 814490cabc..9a31970159 100644 --- a/src/strings/nb.json +++ b/src/strings/nb.json @@ -824,7 +824,7 @@ "OptionResumable": "Kan gjenopptas", "OptionRuntime": "Spilletid", "OptionSaveMetadataAsHidden": "Lagre metadata og bilder som skjulte filer", - "OptionSaveMetadataAsHiddenHelp": "Endring av denne innstillingen vil gjelde ny metadata som lagres fra nå av. Eksisterende metadata vil bli oppdatert neste gang de lagres av Jellyfin-serveren.", + "OptionSaveMetadataAsHiddenHelp": "Endring av denne innstillingen vil gjelde ny metadata som lagres fra nå av. Eksisterende metadata vil bli oppdatert neste gang de lagres av serveren.", "OptionSpecialEpisode": "Spesialepisoder", "OptionSubstring": "Deltekst", "OptionTrackName": "Låtnavn", @@ -860,9 +860,9 @@ "PleaseAddAtLeastOneFolder": "Vennligst legg til minst en mappe til dette biblioteket ved å trykke på Legg til-knappen.", "PleaseConfirmPluginInstallation": "Klikk på OK for å bekrefte at du har lest ovenfor og ønsker å fortsette med installasjon av programtillegget.", "PleaseEnterNameOrId": "Vennligst skriv et navn eller en ekstern ID.", - "PleaseRestartServerName": "Vennligst start Jellyfin-serveren på nytt - {0}.", + "PleaseRestartServerName": "Vennligst start Jellyfin på nytt på {0}.", "PleaseSelectTwoItems": "Vennligst velg minst to elementer.", - "MessagePluginInstalled": "Programtillegget ble installert. Jellyfin-serveren må startes på nytt for at endringene skal tre i kraft.", + "MessagePluginInstalled": "Programtillegget ble installert. Serveren må startes på nytt for at endringene skal tre i kraft.", "PreferEmbeddedTitlesOverFileNames": "Foretrekk integrerte titler fremfor filnavn", "PreferEmbeddedTitlesOverFileNamesHelp": "Dette avgjør standard visningstittel når det ikke er noen metadata eller lokale metadata tilgjengelige.", "Premieres": "Premierer", @@ -883,7 +883,7 @@ "RecordingScheduled": "Opptak planlagt.", "Recordings": "Opptak", "Refresh": "Oppdater", - "RefreshDialogHelp": "Metadata blir oppdatert basert på innstillinger og internett-tjenester som er aktivert i dashbordet for Jellyfin-serveren.", + "RefreshDialogHelp": "Metadata blir oppdatert basert på innstillinger og internett-tjenester som er aktivert i dashbordet.", "RefreshMetadata": "Oppdater metadata", "RefreshQueued": "Oppdatering satt i kø.", "ReleaseDate": "Utgivelsesdato", @@ -917,10 +917,10 @@ "SeriesDisplayOrderHelp": "Sorter episoder etter sendt dato, DVD-rekkefølge eller absolutt nummerering.", "SeriesRecordingScheduled": "Serieopptak planlagt.", "SeriesSettings": "Serieinnstillinger", - "ServerNameIsRestarting": "Jellyfin-server - {0} starter om.", - "ServerNameIsShuttingDown": "Jellyfin-server - {0} avsluttes.", - "ServerRestartNeededAfterPluginInstall": "Jellyfin-serveren trenger en omstart etter installasjon av et programtillegg.", - "ServerUpdateNeeded": "Denne Jellyfin-serveren må oppdateres. For å laste ned siste versjon, vennligst besøk {0}", + "ServerNameIsRestarting": "Serveren på {0} starter om.", + "ServerNameIsShuttingDown": "Serveren på {0} avsluttes.", + "ServerRestartNeededAfterPluginInstall": "Jellyfin trenger en omstart etter installasjon av et programtillegg.", + "ServerUpdateNeeded": "Denne serveren må oppdateres. For å laste ned siste versjon, vennligst besøk {0}", "Settings": "Innstillinger", "SettingsSaved": "Innstillinger lagret.", "SettingsWarning": "Endring av disse verdiene kan føre til ustabilitet eller tilkoblingsfeil. Hvis du opplever problemer anbefaler vi at du endrer dem tilbake til standardverdiene.", @@ -1304,7 +1304,7 @@ "OptionProfileVideo": "Video", "OptionProtocolHls": "HTTP-direktestrømming", "OptionProtocolHttp": "HTTP", - "PasswordResetProviderHelp": "Velg hvilken metode for tilbakestilling av passord som skal benyttes når denne brukeren ber om å tilbakestille passordet", + "PasswordResetProviderHelp": "Velg hvilken metode for tilbakestilling av passord som skal benyttes når denne brukeren ber om å tilbakestille passordet.", "PerfectMatch": "Perfekt match", "PlaybackData": "Avspillingsdata", "PlayCount": "Antall avspillinger", @@ -1390,7 +1390,7 @@ "LastSeen": "Sist sett {0}", "PersonRole": "som {0}", "ListPaging": "{0}-{1} av {2}", - "WriteAccessRequired": "Jellyfin Server krever skrivetilgang til denne mappen. Vennligst påse at skrivetilgang er gitt og prøv igjen.", + "WriteAccessRequired": "Jellyfin krever skrivetilgang til denne mappen. Vennligst påse at skrivetilgang er gitt og prøv igjen.", "PathNotFound": "Banen ble ikke funnet. Påse at banen er gyldig og prøv igjen.", "YadifBob": "YADIF Bob", "Yadif": "YADIF", @@ -1469,5 +1469,11 @@ "ViewAlbumArtist": "Vis albumartist", "StopPlayback": "Stopp avspilling", "NextTrack": "Hopp til neste", - "LabelUnstable": "Ustabil" + "LabelUnstable": "Ustabil", + "Preview": "Forhåndsvis", + "SubtitleVerticalPositionHelp": "Linjenummer hvor teksten dukker opp. Positive tall indikerer ovenfra og ned. Negative tall indikerer nedenfra og opp.", + "LabelSubtitleVerticalPosition": "Vertikal posisjon:", + "PreviousTrack": "Hopp til forrige", + "MessageGetInstalledPluginsError": "En feil oppstod under henting av listen over installerte tillegg.", + "MessagePluginInstallError": "En feil oppstod under installasjon av tillegget." } From 79215f76b66643bc92b226f66fe5ef9d15ec59e4 Mon Sep 17 00:00:00 2001 From: WontTell Date: Thu, 13 Aug 2020 22:06:42 +0000 Subject: [PATCH 219/301] Translated using Weblate (Spanish (Latin America)) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/es_419/ --- src/strings/es_419.json | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/strings/es_419.json b/src/strings/es_419.json index 9f0422227a..c50a878b46 100644 --- a/src/strings/es_419.json +++ b/src/strings/es_419.json @@ -1474,6 +1474,6 @@ "SubtitleVerticalPositionHelp": "Número de línea donde aparece el texto. Números positivos representan de arriba hacia abajo. Números negativos representan de abajo hacia arriba.", "LabelSubtitleVerticalPosition": "Posición vertical:", "PreviousTrack": "Saltar al anterior", - "MessageGetInstalledPluginsError": "Ocurrió un error buscando la lista de plugins instalados.", - "MessagePluginInstallError": "Ocurrió un error instalando el plugin." + "MessageGetInstalledPluginsError": "Ocurrió un error buscando la lista de complementos instalados.", + "MessagePluginInstallError": "Ocurrió un error instalando el complemento." } From c6881e6f311915bc69024f4632bfc18016f67f80 Mon Sep 17 00:00:00 2001 From: WontTell Date: Thu, 13 Aug 2020 22:08:32 +0000 Subject: [PATCH 220/301] Translated using Weblate (Spanish (Latin America)) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/es_419/ --- src/strings/es_419.json | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/src/strings/es_419.json b/src/strings/es_419.json index c50a878b46..34506b0ce7 100644 --- a/src/strings/es_419.json +++ b/src/strings/es_419.json @@ -158,7 +158,7 @@ "OptionPoster": "Póster", "OptionPlayed": "Reproducido", "OptionPlayCount": "Contador de reproducciones", - "OptionPlainVideoItemsHelp": "Todos los videos serán representados en DIDL como «object.item.videoItem» en vez de un tipo más específico, como «object.item.videoItem.movie».", + "OptionPlainVideoItemsHelp": "Todos los videos serán representados en DIDL como «object.item.videoItem» en lugar de un tipo más específico, como «object.item.videoItem.movie».", "OptionPlainVideoItems": "Mostrar todos los videos como elementos de video simples", "OptionPlainStorageFoldersHelp": "Todos las carpetas serán representadas en DIDL como «object.container.storageFolder» en lugar de un tipo más específico, como «object.container.person.musicArtist».", "OptionPlainStorageFolders": "Mostrar todas las carpetas como carpetas de almacenamiento simples", @@ -208,7 +208,7 @@ "OptionDownloadPrimaryImage": "Principal", "OptionDownloadMenuImage": "Menú", "OptionDownloadLogoImage": "Logo", - "OptionDownloadImagesInAdvanceHelp": "Por defecto, la mayoría de las imágenes se descargan cuando son solicitadas por un cliente. Habilita esta opción para descargarlas todas por por adelantado a medida que se agreguen nuevos medios. Esto podría causar que los escaneos de bibliotecas sean significativamente más largos.", + "OptionDownloadImagesInAdvanceHelp": "Por defecto, la mayoría de las imágenes se descargan cuando son solicitadas por un cliente. Habilita esta opción para descargarlas todas por adelantado, a medida que se agreguen nuevos medios. Esto podría causar que los escaneos de bibliotecas sean significativamente más largos.", "OptionDownloadImagesInAdvance": "Descargar las imágenes con antelación", "OptionDownloadDiscImage": "Disco", "OptionDownloadBoxImage": "Caja", @@ -237,7 +237,7 @@ "OptionBlockChannelContent": "Contenido de canales de Internet", "OptionBlockBooks": "Libros", "OptionBanner": "Banner", - "OptionAutomaticallyGroupSeriesHelp": "Series que estén repartidas en múltiples carpetas dentro de esta biblioteca serán fusionadas en una sola serie.", + "OptionAutomaticallyGroupSeriesHelp": "Series que estén repartidas en múltiples carpetas dentro de esta biblioteca serán automáticamente fusionadas en una sola serie.", "OptionAutomaticallyGroupSeries": "Fusionar automáticamente series esparcidas a través de múltiples carpetas", "OptionAutomatic": "Automático", "OptionAuto": "Automático", @@ -250,7 +250,7 @@ "OptionAllowRemoteSharedDevicesHelp": "Los dispositivos DLNA se considerarán compartidos hasta que un usuario comience a controlarlos.", "OptionAllowRemoteSharedDevices": "Permitir control remoto de dispositivos compartidos", "OptionAllowRemoteControlOthers": "Permitir control remoto de otros usuarios", - "OptionAllowMediaPlaybackTranscodingHelp": "Restringir el acceso a la transcodificación podría causar fallas en reproducción en las aplicaciones debido a formatos de medios no soportados.", + "OptionAllowMediaPlaybackTranscodingHelp": "Restringir el acceso a la transcodificación podría causar fallas en la reproducción en los clientes debido a formatos de medios no soportados.", "OptionAllowMediaPlayback": "Permitir reproducción de medios", "OptionAllowManageLiveTv": "Permitir gestión de grabación de TV en vivo", "OptionAllowLinkSharingHelp": "Solo son compartidas páginas web que contienen información sobre los medios. Los archivos de medios nunca son compartidos públicamente. Los compartidos tienen un límite de tiempo y expirarán después de {0} días.", From a15eda7d3f3f94147b7025ce90630c5984fd8eea Mon Sep 17 00:00:00 2001 From: nextlooper42 Date: Thu, 13 Aug 2020 23:29:42 +0000 Subject: [PATCH 221/301] Translated using Weblate (Slovak) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/sk/ --- src/strings/sk.json | 42 +++++++++++++++++++++--------------------- 1 file changed, 21 insertions(+), 21 deletions(-) diff --git a/src/strings/sk.json b/src/strings/sk.json index 9968b15c6a..7aef8eb515 100644 --- a/src/strings/sk.json +++ b/src/strings/sk.json @@ -10,7 +10,7 @@ "AllLanguages": "Všetky jazyky", "AllLibraries": "Všetky knižnice", "AllowMediaConversion": "Povoliť konverziu médií", - "AllowRemoteAccess": "Povoliť vzdialené pripojenia k tomuto Jellyfin serveru.", + "AllowRemoteAccess": "Povoliť vzdialené pripojenia k tomuto serveru.", "AllowRemoteAccessHelp": "Nezaškrtnuté znamená, že všetky vzdialené pripojenia budú blokované.", "AlwaysPlaySubtitles": "Vždy prehrať", "AnyLanguage": "Akýkoľvek jazyk", @@ -491,7 +491,7 @@ "MessageConfirmProfileDeletion": "Ste si istý, že chcete zmazať tento profil?", "MessageConfirmRecordingCancellation": "Zrušiť nahrávanie?", "MessageConfirmRemoveMediaLocation": "Ste si istý, že chcete odobrať toto umiestnenie?", - "MessageConfirmRestart": "Ste si istý, že chcete reštartovať Jellyfin Server?", + "MessageConfirmRestart": "Ste si istý, že chcete reštartovať Jellyfin?", "MessageConfirmShutdown": "Ste si istý, že chcete vypnúť server?", "MessageEnablingOptionLongerScans": "Povolenie tejto možnosti môže mať za následok podstatne dlhšie skenovania knižníc.", "MessageFileReadError": "Pri čítaní súboru nastala chyba.", @@ -647,9 +647,9 @@ "Played": "Prehrané", "PleaseAddAtLeastOneFolder": "Pridajte prosím aspoň jeden priečinok do tejto knižnice kliknutím na tlačidlo Pridať.", "PleaseEnterNameOrId": "Prosím, zadajte meno alebo externé ID.", - "PleaseRestartServerName": "Prosím reštartujte Jellyfin Server - {0}.", + "PleaseRestartServerName": "Prosím reštartujte Jellyfin na {0}.", "PleaseSelectTwoItems": "Vyberte prosím aspoň dve položky.", - "MessagePluginInstalled": "Rozšírenie bolo úspešne nainštalované. Je potrebný reštart Jellyfin Server aby sa prejavili zmeny.", + "MessagePluginInstalled": "Rozšírenie bolo úspešne nainštalované. Je potrebný reštart servera aby sa prejavili zmeny.", "Premiere": "Premiéra", "Premieres": "Premiéry", "Previous": "Predchádzajúce", @@ -691,10 +691,10 @@ "SendMessage": "Poslať správu", "Series": "Seriály", "SeriesSettings": "Nastavenia série", - "ServerNameIsRestarting": "Jellyfin Server - {0} sa reštartuje.", - "ServerNameIsShuttingDown": "Jellyfin Server - {0} sa vypína.", - "ServerRestartNeededAfterPluginInstall": "Po inštalácii zásuvného modulu bude potrebný reštart Jellyfin servera.", - "ServerUpdateNeeded": "Tento Jellyfin server treba aktualizovať. Najnovšiu verziu nájdete na {0}", + "ServerNameIsRestarting": "Server {0} sa reštartuje.", + "ServerNameIsShuttingDown": "Server {0} sa vypína.", + "ServerRestartNeededAfterPluginInstall": "Jellyfin bude nutné po inštalácií zásuvného modulu reštartovať.", + "ServerUpdateNeeded": "Tento server je nutné aktualizovať. Pokiaľ chcete stiahnuť najnovšiu verziu, navštívte prosím {0}", "Settings": "Nastavenia", "SettingsSaved": "Nastavenia uložené.", "Share": "Zdieľať", @@ -859,7 +859,7 @@ "EnableCinemaMode": "Kino režim", "EnableNextVideoInfoOverlay": "Zobraziť informácie o nasledujúcom videu počas prehrávania", "EnableNextVideoInfoOverlayHelp": "Na konci videa sa zobrazia informácie o nasledujúcom videu v aktuálnom playliste.", - "ErrorAddingMediaPathToVirtualFolder": "Pri pridávaní cesty k mediám nastala chyba. Uistite sa prosím, že cesta je platná, a že proces Jellyfin servera má prístup k umiestneniu.", + "ErrorAddingMediaPathToVirtualFolder": "Pri pridávaní cesty k mediám nastala chyba. Uistite sa prosím, že cesta je platná, a že Jellyfin má prístup k umiestneniu.", "HeaderAddScheduledTaskTrigger": "Pridať spúšťač", "HeaderAddToPlaylist": "Pridať do playlistu", "HeaderAlert": "Upozornenie", @@ -1063,7 +1063,7 @@ "ErrorSavingTvProvider": "Nastala chyba pri ukladaní sprostredkovateľa TV vysielania. Prosím, uistite sa, že je prístupný a skúste to znova.", "ErrorPleaseSelectLineup": "Prosím, vyberte lineup a skúste to znova. Pokiaľ nie je k dispozícií žiaden lineup, skontrolujte, či je vaše používateľské meno, heslo a PSČ správne.", "ErrorGettingTvLineups": "Nastala chyba pri sťahovaní rozpisov TV programov. Prosím, uistite sa že vaše informácie sú správne a skúste to znova.", - "ErrorDeletingItem": "Nastala chyba pri vymazávaní položky z Jellyfin Servera. Prosím, overte, či Jellyfin Server má práva pre zapisovanie do priečinku s médiami a skúste to znova.", + "ErrorDeletingItem": "Nastala chyba pri vymazávaní položky zo servera. Prosím, overte, či Jellyfin má práva pre zapisovanie do priečinku s médiami a skúste to znova.", "ErrorAddingXmlTvFile": "Nastala chyba pri prístupe k XMLTV súboru. Prosím, uistite sa že súbor existuje a skúste to znova.", "ErrorAddingTunerDevice": "Nastala chyba pri pridávaní tunera. Prosím, uistite sa že je dostupný a skúste to znova.", "EnableThemeVideosHelp": "Prehrať videá úvodných zvučiek na pozadí počas prechádzania knižnice.", @@ -1080,7 +1080,7 @@ "CustomDlnaProfilesHelp": "Vytvorte si vlastný profil pre nové zariadenie alebo pre prepísanie systémového profilu.", "CopyStreamURLSuccess": "URL úspešne skopírovaná.", "CopyStreamURL": "Kopírovať URL adresu streamu", - "ConfigureDateAdded": "Konfigurácia, ako sa pridáva dátum, je definovaná v dashboarde Jellyfin Servera pod nastavením Knižnice", + "ConfigureDateAdded": "Konfigurácia pridávania dátumu je definovaná v dashboarde pod nastavením knižnice", "ColorTransfer": "Farba prenosu", "ColorPrimaries": "Primárna farba", "CinemaModeConfigurationHelp": "Kino režim prináša zážitok ako z kina priamo do vašej obývačky s možnosťou prehrať trailery a vlastné intrá pred hlavným programom.", @@ -1139,11 +1139,11 @@ "PleaseConfirmPluginInstallation": "Prosím, kliknite na OK pre potvrdenie, že ste prečítali text uvedený vyššie a chcete pokračovať v inštalácií zásuvného modulu.", "PlaybackData": "Podrobnosti prehrávania", "PlayAllFromHere": "Prehrať všetko odtiaľto", - "PasswordResetProviderHelp": "Zvoľte poskytovateľa obnovy hesla, ktorý bude použitý, keď používateľ požiada o obnovu hesla", + "PasswordResetProviderHelp": "Zvoľte poskytovateľa obnovy hesla, ktorý bude použitý, keď používateľ požiada o obnovu hesla.", "OptionThumbCard": "Náhľadové kartičky", "OptionSubstring": "Podreťazec", "OptionSpecialEpisode": "Špeciály", - "OptionSaveMetadataAsHiddenHelp": "Zmena bude platiť pre nové metadáta uložené v budúcnosti. Existujúce metadáta budú aktualizované na ďalší raz, akonáhle budú uložené Jellyfin Serverom.", + "OptionSaveMetadataAsHiddenHelp": "Zmena bude platiť pre nové metadáta uložené v budúcnosti. Existujúce metadáta budú aktualizované na ďalší raz, akonáhle budú uložené serverom.", "OptionResElement": "Zdrojový element", "OptionRequirePerfectSubtitleMatchHelp": "Vyžadovanie dokonalej zhody filtruje titulky tak, aby obsahovali iba tie ktoré boli odskúšané a overené pre váš konkrétny video súbor. Zrušenie zaškrtnutia tohoto zvýši pravdepodobnosť sťahovania tituliek, ale zvýši šancu chybného časovania alebo nesprávneho textu tituliek.", "OptionReportByteRangeSeekingWhenTranscodingHelp": "Toto je vyžadované pre niektoré zariadenia, ktoré nevedia moc dobre časovo pretáčať.", @@ -1192,7 +1192,7 @@ "MessageUnsetContentHelp": "Obsah bude zobrazený ako jednoduché priečinky. Pre lepšie výsledky použite manažér metadát na nastavenie typu obsahu podpriečinkov.", "MessageUnableToConnectToServer": "Nie sme schopný sa aktuálne pripojiť k vybranému serveru. Prosím, uistite sa že je spustený a skúste to znovu.", "MessageReenableUser": "Pozrite nižšie pre znovu-povolenie", - "MessagePluginInstallDisclaimer": "Zásuvné moduly vytvorené členmi Jellyfin komunity sú úžasná cesta ako zlepšiť váš Jellyfin zážitok s dodatočnými funkciami a benefitmi. Pred inštaláciou sa prosím oboznámte s efektmi, ktoré môžu mať vplyv na váš Jellyfin Server, ako dlhšie prehľadávanie knižníc, dodatočné procesy na pozadí a zníženie stability systému.", + "MessagePluginInstallDisclaimer": "Zásuvné moduly vytvorené členmi komunity sú úžasná cesta ako zlepšiť váš zážitok s dodatočnými funkciami a benefitmi. Pred inštaláciou sa prosím oboznámte s efektmi, ktoré môžu mať vplyv na váš server, ako dlhšie prehľadávanie knižníc, dodatočné procesy na pozadí a zníženie stability systému.", "MessagePluginConfigurationRequiresLocalAccess": "Pre konfiguráciu tohoto zásuvného modulu sa prihláste priamo na lokálny server.", "MessagePlayAccessRestricted": "Prehrávanie tohoto obsahuje je aktuálne obmedzené. Prosím, kontaktujte svojho administrátora servera pre viac informácií.", "MessagePasswordResetForUsers": "Nasledujúci používatelia si nechali obnoviť heslo. Teraz sa môžu prihlásiť s PIN kódom, ktorý použijú k vykonaniu obnovy hesla.", @@ -1204,11 +1204,11 @@ "MessageForgotPasswordFileCreated": "Nasledujúci súbor bol vytvorený na vašom serveri a obsahuje inštrukcie, ako postupovať:", "MessageDownloadQueued": "Sťahovanie zaradené do fronty.", "MessageDirectoryPickerLinuxInstruction": "Pre Linuxové distribúcie Arch Linux, CentOS, Debian, Fedora, openSUSE alebo Ubuntu, je potrebné udeliť používateľovi služby oprávnenie aspoň na čítanie.", - "MessageDirectoryPickerBSDInstruction": "Pre BSD možno budete potrebovať nakonfigurovať úložisko priamo vo vašom FreeNAS Jail aby k nim mohol pristupovať Jellyfin.", + "MessageDirectoryPickerBSDInstruction": "Pre BSD možno budete potrebovať nakonfigurovať úložisko priamo vo vašom FreeNAS Jail aby mohol Jellyfin pristupovať k vašim médiám.", "MessageDeleteTaskTrigger": "Naozaj chcete vymazať tento trigger úlohy?", "MessageCreateAccountAt": "Vytvoriť účet v {0}", "MessageContactAdminToResetPassword": "Prosím, kontaktujte vášho systémového administrátora k obnoveniu hesla.", - "MessageConfirmRevokeApiKey": "Ste si istý, že chcete odvolať tento API kľúč? Aplikácie pripojené k Jellyfin Serveru budú rázne ukončené.", + "MessageConfirmRevokeApiKey": "Ste si istý, že chcete odvolať tento API kľúč? Aplikácie pripojené k tomuto serveru budú rázne ukončené.", "Menu": "Menu", "MediaIsBeingConverted": "Médium sa konvertuje do formátu, ktorý je kompatibilný so zariadením, kde sa médium prehráva.", "MediaInfoStreamTypeEmbeddedImage": "Vložený obrázok", @@ -1288,7 +1288,7 @@ "LabelPersonRoleHelp": "Príklad: Vodič nákladiaku so zmrzlinou", "LabelPasswordResetProvider": "Poskytovateľ obnovy hesla:", "LabelParentNumber": "Číslo rodiča:", - "LabelOptionalNetworkPathHelp": "Pokiaľ je tento priečinok zdielaný vo vašej sieti, môže poskytovanie cesty k zdielanému priečinku umožniť Jellyfin aplikáciám priamy prístup k mediálnym súborom. Napríklad, {0} alebo {1}.", + "LabelOptionalNetworkPathHelp": "Pokiaľ je tento priečinok zdielaný vo vašej sieti, môže poskytovanie cesty k zdielanému priečinku umožniť klientom priamy prístup k mediálnym súborom. Napríklad, {0} alebo {1}.", "LabelNumberOfGuideDaysHelp": "Stiahnutím viacerých dní umožní sprievodca naplánovať a zobraziť viac vecí do budúcnosti, sťahovanie však môže trvať dlhšie. Auto vyberie možnosť podľa počtu kanálov.", "LabelNumberOfGuideDays": "Počet dní pre stiahnutie dát sprievodcu:", "LabelMusicStreamingTranscodingBitrateHelp": "Špecifikujte maximálny dátový tok pre streamovanie hudby.", @@ -1339,12 +1339,12 @@ "LabelEnableDlnaPlayTo": "Povoliť DLNA prehrávanie", "LabelEnableDlnaDebugLoggingHelp": "Vytvára veľké súbory s logami a mal by sa použiť len v prípade potreby odstraňovania problémov.", "LabelEnableDlnaDebugLogging": "Povoliť loggovanie DLNA debugu", - "LabelEnableDlnaClientDiscoveryIntervalHelp": "Určuje dobu trvania v sekundách medzi SSDP vyhľadávaniami vykonanými Jellyfinom.", + "LabelEnableDlnaClientDiscoveryIntervalHelp": "Určuje dobu trvania v sekundách medzi SSDP vyhľadávaniami.", "LabelEnableDlnaClientDiscoveryInterval": "Interval pre objavenie klienta", "LabelEnableAutomaticPortMapHelp": "Automatické namapovanie vejerného portu na lokálny port serveru cez UPnP. Toto nemusí fungovať so všetkými modelmi routerov alebo sieťových konfigurácií. Zmeny sa vykonajú až po reštarte servera.", "LabelEmbedAlbumArtDidlHelp": "Niektoré zariadenia preferujú túto metódu pre získavanie obrázku albumu. Ostatným môže zlyhať prehrávanie pokiaľ je táto možnosť povolená.", "LabelBlastMessageIntervalHelp": "Určuje dobu v sekundách medzi vysielaniami správ o serveri.", - "LabelBindToLocalNetworkAddressHelp": "Prepísať lokálnu IP adresu http serveru. Pokiaľ zostane prázdna, server sa naviaže na všetky dostupné adresy. Pri zmene tejto hodnoty sa vyžaduje reštart Jellyfin Servera.", + "LabelBindToLocalNetworkAddressHelp": "Prepísať lokálnu IP adresu http serveru. Pokiaľ zostane prázdna, server sa naviaže na všetky dostupné adresy. Pri zmene tejto hodnoty sa vyžaduje reštart.", "LabelAlbumArtPN": "Obrázok albumu PN:", "LabelAlbumArtMaxWidthHelp": "Maximálne rozlíšenie obrázku albumu prostredníctvom upnp:albumArtURI.", "LabelAlbumArtMaxHeightHelp": "Maximálne rozlíšenie obrázku albumu prostredníctvom upnp:albumArtURI.", @@ -1380,7 +1380,7 @@ "LastSeen": "Naposledy videný {0}", "PersonRole": "ako {0}", "ListPaging": "{0}-{1} z {2}", - "WriteAccessRequired": "Jellyfin Server vyžaduje práva na zapisovanie do tohoto priečinku. Prosím, uistite sa že má práva na zapisovanie a skúste to znova.", + "WriteAccessRequired": "Server vyžaduje práva na zapisovanie do tohoto priečinku. Prosím, uistite sa že má práva na zapisovanie a skúste to znova.", "PathNotFound": "Táto cesta nebola nájdená. Prosím, uistite sa že cesta je správna a skúste to znovu.", "YadifBob": "YADIF Bob", "Yadif": "YADIF", @@ -1444,7 +1444,7 @@ "SyncPlayAccessHelp": "Vyberte úroveň prístupu pre tohto používateľa k funkcií SyncPlay. SyncPlay umožňuje zosynchronizovať prehrávanie s ostatnými zariadeniami.", "EnableDetailsBannerHelp": "Zobrazí banner na vrchnej časti detailu položky.", "EnableDetailsBanner": "Detail banneru", - "EnableBlurHashHelp": "Obrázky, ktoré sa stále načítavajú budú zobrazené ako dočasný obrázok s rozmazaným pozadím", + "EnableBlurHashHelp": "Obrázky, ktoré sa stále načítavajú budú zobrazené ako dočasný obrázok s rozmazaným pozadím.", "EnableBlurHash": "Povoliť obrázok s rozmazaným pozadím pre chýbajúce obrázky", "ShowMore": "Zobraziť viac", "ShowLess": "Zobraziť menej", From d544c7cb37cf47fe65b9fc0ddac3d0e8dd7325c6 Mon Sep 17 00:00:00 2001 From: WontTell Date: Thu, 13 Aug 2020 23:29:37 +0000 Subject: [PATCH 222/301] Translated using Weblate (Spanish (Latin America)) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/es_419/ --- src/strings/es_419.json | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/strings/es_419.json b/src/strings/es_419.json index 34506b0ce7..4014556e9e 100644 --- a/src/strings/es_419.json +++ b/src/strings/es_419.json @@ -1000,7 +1000,7 @@ "HeaderSelectServerCachePath": "Seleccionar ruta para la caché del servidor", "HeaderSelectServer": "Seleccionar servidor", "HeaderSelectPath": "Seleccionar ruta", - "HeaderSelectMetadataPathHelp": "Explora o escribe la ruta donde deseas guardar los metadatos. Se tienen que tener permisos de escritura en esa carpeta.", + "HeaderSelectMetadataPathHelp": "Explora o introduce la ruta que deseas usar para los metadatos. Se debe tener permisos de escritura en esa carpeta.", "HeaderSelectMetadataPath": "Selecciona la ruta para los metadatos", "HeaderSelectCertificatePath": "Selecciona la ruta del certificado", "HeaderSecondsValue": "{0} segundos", @@ -1283,7 +1283,7 @@ "Disabled": "Desactivado", "Directors": "Directores", "DirectStreaming": "Transmisión directa", - "DirectStreamHelp2": "Transmitir directamente un archivo usa muy poco poder de procesamiento sin ninguna perdida en la calidad de video.", + "DirectStreamHelp2": "Transmitir directamente un archivo usa muy poco poder de procesamiento sin pérdida en la calidad de video.", "DirectStreamHelp1": "El medio es compatible con el dispositivo en cuanto a la resolución y tipo de medio (H.264, AC3, etc.), pero está en un contenedor de archivo incompatible (mkv, avi, wmv, etc.). El video será reempaquetado sobre la marcha antes de ser enviado al dispositivo.", "DirectPlaying": "Reproducción directa", "DeviceAccessHelp": "Esto solo se aplica a los dispositivos que pueden ser identificados de manera única y no impedirá el acceso desde navegadores. Filtrar el acceso a los dispositivos de los usuarios les impedirá usar nuevos dispositivos hasta que hayan sido aprobados aquí.", @@ -1318,7 +1318,7 @@ "HeaderSeriesStatus": "Estado de la serie", "HeaderSeriesOptions": "Opciones de serie", "HeaderSendMessage": "Enviar mensaje", - "HeaderSelectTranscodingPathHelp": "Explora o escribe la ruta para los archivos de transcodificación. Se tienen que tener permisos de escritura en esa carpeta.", + "HeaderSelectTranscodingPathHelp": "Explora o introduce la ruta para los archivos de transcodificación. Se debe tener permisos de escritura en esa carpeta.", "HeaderSelectTranscodingPath": "Selecciona la ruta para los archivos temporales de transcodificación", "ConfirmDeleteItems": "Eliminar estos elementos los eliminará tanto del sistema como de tu biblioteca de medios. ¿Estás seguro de querer continuar?", "ConfirmDeleteItem": "Eliminar este elemento lo eliminará tanto del sistema como de tu biblioteca de medios. ¿Estás seguro de querer continuar?", From 195430ceff8125b80def5b94f0d203980e085b4a Mon Sep 17 00:00:00 2001 From: MrTimscampi Date: Fri, 14 Aug 2020 05:48:59 +0200 Subject: [PATCH 223/301] Use ES6 imports for clientUtils --- src/scripts/clientUtils.js | 62 +++++++++++++++++++++----------------- 1 file changed, 34 insertions(+), 28 deletions(-) diff --git a/src/scripts/clientUtils.js b/src/scripts/clientUtils.js index b576f0504e..719d722a2b 100644 --- a/src/scripts/clientUtils.js +++ b/src/scripts/clientUtils.js @@ -1,3 +1,4 @@ + export function getCurrentUser() { return window.ApiClient.getCurrentUser(false); } @@ -5,7 +6,7 @@ export function getCurrentUser() { //TODO: investigate url prefix support for serverAddress function export function serverAddress() { if (AppInfo.isNativeApp) { - var apiClient = window.ApiClient; + const apiClient = window.ApiClient; if (apiClient) { return apiClient.serverAddress(); @@ -14,15 +15,15 @@ export function serverAddress() { return null; } - var urlLower = window.location.href.toLowerCase(); - var index = urlLower.lastIndexOf('/web'); + const urlLower = window.location.href.toLowerCase(); + const index = urlLower.lastIndexOf('/web'); if (index != -1) { return urlLower.substring(0, index); } - var loc = window.location; - var address = loc.protocol + '//' + loc.hostname; + const loc = window.location; + let address = loc.protocol + '//' + loc.hostname; if (loc.port) { address += ':' + loc.port; @@ -32,7 +33,7 @@ export function serverAddress() { } export function getCurrentUserId() { - var apiClient = window.ApiClient; + const apiClient = window.ApiClient; if (apiClient) { return apiClient.getCurrentUserId(); @@ -48,7 +49,7 @@ export function onServerChanged(userId, accessToken, apiClient) { export function logout() { ConnectionManager.logout().then(function () { - var loginPage; + let loginPage; if (AppInfo.isNativeApp) { loginPage = 'selectserver.html'; @@ -80,39 +81,47 @@ export function navigate(url, preserveQueryString) { throw new Error('url cannot be null or empty'); } - var queryString = getWindowLocationSearch(); + const queryString = getWindowLocationSearch(); if (preserveQueryString && queryString) { url += queryString; } return new Promise(function (resolve, reject) { - require(['appRouter'], function (appRouter) { + import('appRouter').then(({default: appRouter}) => { return appRouter.show(url).then(resolve, reject); }); }); } export function processPluginConfigurationUpdateResult() { - require(['loading', 'toast'], function (loading, toast) { - loading.hide(); - toast.default(Globalize.translate('MessageSettingsSaved')); - }); + Promise.all([ + import('loading'), + import('toast') + ]) + .then(([{default: loading}, {default: toast}]) => { + loading.hide(); + toast.default(Globalize.translate('MessageSettingsSaved')); + }); } export function processServerConfigurationUpdateResult(result) { - require(['loading', 'toast'], function (loading, toast) { - loading.hide(); - toast.default(Globalize.translate('MessageSettingsSaved')); - }); + Promise.all([ + import('loading'), + import('toast') + ]) + .then(([{default: loading}, {default: toast}]) => { + loading.hide(); + toast.default(Globalize.translate('MessageSettingsSaved')); + }); } export function processErrorResponse(response) { - require(['loading'], function (loading) { + import('loading').then(({default: loading}) => { loading.hide(); }); - var status = '' + response.status; + let status = '' + response.status; if (response.statusText) { status = response.statusText; @@ -126,14 +135,14 @@ export function processErrorResponse(response) { export function alert(options) { if (typeof options == 'string') { - return void require(['toast'], function (toast) { + return void import('toast').then(({default: toast}) => { toast.default({ text: options }); }); } - require(['alert'], function (alert) { + import('alert').then(({default: alert}) => { alert.default({ title: options.title || Globalize.translate('HeaderAlert'), text: options.message @@ -142,7 +151,7 @@ export function alert(options) { } export function capabilities(appHost) { - var capabilities = { + let capabilities = { PlayableMediaTypes: ['Audio', 'Video'], SupportedCommands: ['MoveUp', 'MoveDown', 'MoveLeft', 'MoveRight', 'PageUp', 'PageDown', 'PreviousLetter', 'NextLetter', 'ToggleOsd', 'ToggleContextMenu', 'Select', 'Back', 'SendKey', 'SendString', 'GoHome', 'GoToSettings', 'VolumeUp', 'VolumeDown', 'Mute', 'Unmute', 'ToggleMute', 'SetVolume', 'SetAudioStreamIndex', 'SetSubtitleStreamIndex', 'DisplayContent', 'GoToSearch', 'DisplayMessage', 'SetRepeatMode', 'SetShuffleQueue', 'ChannelUp', 'ChannelDown', 'PlayMediaSource', 'PlayTrailers'], SupportsPersistentIdentifier: self.appMode === 'cordova' || self.appMode === 'android', @@ -161,22 +170,19 @@ export function selectServer() { } export function hideLoadingMsg() { - 'use strict'; - require(['loading'], function(loading) { + import('loading').then(({default: loading}) => { loading.hide(); }); } export function showLoadingMsg() { - 'use strict'; - require(['loading'], function(loading) { + import('loading').then(({default: loading}) => { loading.show(); }); } export function confirm(message, title, callback) { - 'use strict'; - require(['confirm'], function(confirm) { + import('confirm').then(({default: confirm}) => { confirm(message, title).then(function() { callback(!0); }).catch(function() { From e05efaec4c6491777af4066db38ec638011e85ad Mon Sep 17 00:00:00 2001 From: Oatavandi Date: Fri, 14 Aug 2020 04:45:17 +0000 Subject: [PATCH 224/301] Translated using Weblate (Tamil) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/ta/ --- src/strings/ta.json | 95 +++++++++++++++++++++++++++++++++++++++++++-- 1 file changed, 92 insertions(+), 3 deletions(-) diff --git a/src/strings/ta.json b/src/strings/ta.json index 1e594ffd71..8d4076c491 100644 --- a/src/strings/ta.json +++ b/src/strings/ta.json @@ -1,5 +1,5 @@ { - "AddToPlayQueue": "வரிசையில் விளையாட சேர்க்கவும்", + "AddToPlayQueue": "இசைத்தல் வரிசையில் சேர்", "AddToCollection": "சேகரிப்பில் சேர்க்கவும்", "Add": "சேர்", "Actor": "நடிகர்", @@ -151,7 +151,7 @@ "ButtonNetwork": "வலைப்பின்னல்", "ButtonMore": "மேலும்", "ButtonManualLogin": "கைமுறை புகுபதிகை", - "ButtonLibraryAccess": "நூலக அணுகல்", + "ButtonLibraryAccess": "நூலக அனுமதி", "ButtonInfo": "தகவல்", "ButtonHome": "முகப்பு", "ButtonGuide": "வழிகாட்டி", @@ -164,5 +164,94 @@ "ChannelNumber": "சேனல் எண்", "ChannelNameOnly": "சேனல் {0} மட்டுமே", "ChannelAccessHelp": "இந்த பயனருடன் பகிர சேனல்களைத் தேர்ந்தெடுக்கவும். நிர்வாகிகள் மெட்டாடேட்டா நிர்வாகியைப் பயன்படுத்தி அனைத்து சேனல்களையும் திருத்த முடியும்.", - "ChangingMetadataImageSettingsNewContent": "மெட்டாடேட்டா அல்லது கலைப்படைப்பு பதிவிறக்க அமைப்புகளுக்கான மாற்றங்கள் உங்கள் நூலகத்தில் சேர்க்கப்பட்ட புதிய உள்ளடக்கத்திற்கு மட்டுமே பொருந்தும். இருக்கும் தலைப்புகளில் மாற்றங்களைப் பயன்படுத்த, அவற்றின் மெட்டாடேட்டாவை கைமுறையாக புதுப்பிக்க வேண்டும்." + "ChangingMetadataImageSettingsNewContent": "மெட்டாடேட்டா அல்லது கலைப்படைப்பு பதிவிறக்க அமைப்புகளுக்கான மாற்றங்கள் உங்கள் நூலகத்தில் சேர்க்கப்பட்ட புதிய உள்ளடக்கத்திற்கு மட்டுமே பொருந்தும். இருக்கும் தலைப்புகளில் மாற்றங்களைப் பயன்படுத்த, அவற்றின் மெட்டாடேட்டாவை கைமுறையாக புதுப்பிக்க வேண்டும்.", + "Episode": "அத்தியாயம்", + "EndsAtValue": "{0} இல் முடிகிறது", + "Ended": "முடிந்தது", + "EnableDetailsBannerHelp": "உருப்படி விவரங்கள் பக்கத்தின் மேலே ஒரு பேனர் படத்தைக் காண்பி.", + "EnableDetailsBanner": "விவரங்கள் பேனர்", + "EnableThemeVideosHelp": "நூலகத்தில் உலாவும்போது பின்னணியில் தீம் வீடியோக்களை இயக்குங்கள்.", + "EnableThemeVideos": "தீம் வீடியோக்கள்", + "EnableThemeSongsHelp": "நூலகத்தில் உலாவும்போது பின்னணியில் தீம் பாடல்களை இயக்குங்கள்.", + "EnableThemeSongs": "தீம் பாடல்கள்", + "EnableStreamLoopingHelp": "நேரடி ஸ்ட்ரீம்களில் சில வினாடிகள் மட்டுமே தரவு இருந்தால் தொடர்ந்து இயக்கப்பட வேண்டும். தேவைப்படாதபோது இதை இயக்குவது சிக்கல்களை ஏற்படுத்தக்கூடும்.", + "EnableStreamLooping": "ஆட்டோ-லூப் லைவ் ஸ்ட்ரீம்கள்", + "EnablePhotosHelp": "பிற ஊடக கோப்புகளுடன் படங்கள் கண்டறியப்பட்டு காண்பிக்கப்படும்.", + "EnablePhotos": "புகைப்படங்களைக் காண்பி", + "EnableNextVideoInfoOverlayHelp": "ஒரு வீடியோவின் முடிவில், தற்போதைய பிளேலிஸ்ட்டில் வரும் அடுத்த வீடியோ பற்றிய தகவலைக் காண்பி.", + "EnableNextVideoInfoOverlay": "பிளேபேக்கின் போது அடுத்த வீடியோ தகவலைக் காட்டு", + "EnableHardwareEncoding": "வன்பொருள் குறியாக்கத்தை இயக்கு", + "EnableExternalVideoPlayersHelp": "வீடியோ பிளேபேக்கைத் தொடங்கும்போது வெளிப்புற பிளேயர் மெனு காண்பிக்கப்படும்.", + "EnableExternalVideoPlayers": "வெளிப்புற வீடியோ பிளேயர்கள்", + "EnableDisplayMirroring": "காட்சி பிரதிபலிப்பு", + "EnableDecodingColorDepth10Vp9": "VP9 க்கு 10-பிட் வன்பொருள் டிகோடிங்கை இயக்கவும்", + "EnableDecodingColorDepth10Hevc": "HEVC க்கு 10-பிட் வன்பொருள் டிகோடிங்கை இயக்கவும்", + "EnableColorCodedBackgrounds": "வண்ண குறியிடப்பட்ட பின்னணிகள்", + "EnableCinemaMode": "சினிமா பயன்முறை", + "EnableBackdropsHelp": "நூலகத்தை உலாவும்போது சில பக்கங்களின் பின்னணியில் பின்னணியைக் காண்பி.", + "EditSubtitles": "வசன வரிகள் திருத்து", + "EditMetadata": "மெட்டாடேட்டாவைத் திருத்து", + "EditImages": "படங்களைத் திருத்து", + "Edit": "தொகு", + "EasyPasswordHelp": "உங்கள் எளிதான முள் குறியீடு ஆதரிக்கப்பட்ட கிளையண்ட்களில் ஆஃப்லைன் அணுகலுக்காகப் பயன்படுத்தப்படுகிறது, மேலும் நெட்வொர்க் உள்நுழைவிலும் எளிதாகப் பயன்படுத்தலாம்.", + "DropShadow": "நிழல் விட்டுவிடு", + "DrmChannelsNotImported": "டிஆர்எம் கொண்ட சேனல்கள் இறக்குமதி செய்யப்படாது.", + "DownloadsValue": "{0} பதிவிறக்கங்கள்", + "Download": "பதிவிறக்க", + "Down": "கீழ்", + "DoNotRecord": "பதிவு செய்ய வேண்டாம்", + "DisplayModeHelp": "இடைமுகத்திற்கு நீங்கள் விரும்பும் தளவமைப்பு பாணியைத் தேர்ந்தெடுக்கவும்.", + "DisplayMissingEpisodesWithinSeasonsHelp": "சேவையக உள்ளமைவில் டிவி நூலகங்களுக்கும் இது இயக்கப்பட வேண்டும்.", + "DisplayMissingEpisodesWithinSeasons": "காணாமல் போன அத்தியாயங்களை பருவங்களுக்குள் காண்பி", + "DisplayInOtherHomeScreenSections": "சமீபத்திய மீடியா போன்ற முகப்புத் திரைப் பிரிவுகளில் காண்பிக்கவும், தொடர்ந்து பார்க்கவும்", + "DisplayInMyMedia": "முகப்புத் திரையில் காட்சி", + "Display": "காட்சி", + "Dislike": "விரும்பவில்லை", + "Disconnect": "துண்டிக்கவும்", + "Disc": "வட்டு", + "Disabled": "முடக்கப்பட்டது", + "Directors": "இயக்குநர்கள்", + "Director": "இயக்குனர்", + "DirectStreaming": "நேரடி ஸ்ட்ரீமிங்", + "DirectStreamHelp2": "வீடியோ தரத்தில் குறைந்த இழப்புடன் நேரடி ஸ்ட்ரீம் மிகக் குறைந்த செயலாக்க சக்தியைப் பயன்படுத்துகிறது.", + "DirectStreamHelp1": "தீர்மானம் மற்றும் மீடியா வகை (H.264, AC3, போன்றவை) தொடர்பான சாதனத்துடன் ஊடகங்கள் இணக்கமாக உள்ளன, ஆனால் பொருந்தாத கோப்பு கொள்கலனில் (mkv, avi, wmv, போன்றவை). சாதனத்திற்கு அனுப்பப்படுவதற்கு முன்பு வீடியோ பறக்கையில் மீண்டும் தொகுக்கப்படும்.", + "DirectPlaying": "நேரடி விளையாட்டு", + "DeviceAccessHelp": "இது தனிப்பட்ட முறையில் அடையாளம் காணக்கூடிய சாதனங்களுக்கு மட்டுமே பொருந்தும் மற்றும் உலாவி அணுகலைத் தடுக்காது. பயனர் சாதன அணுகலை வடிகட்டுவது, அவை இங்கு அங்கீகரிக்கப்படும் வரை புதிய சாதனங்களைப் பயன்படுத்துவதைத் தடுக்கும்.", + "DetectingDevices": "சாதனங்களைக் கண்டறிதல்", + "Desktop": "டெஸ்க்டாப்", + "Descending": "இறங்கு வரிசை", + "Depressed": "மனச்சோர்வு", + "DeleteUserConfirmation": "இந்த பயனரை நீக்க விரும்புகிறீர்களா?", + "DeleteUser": "பயனரை நீக்கு", + "DeleteMedia": "மீடியாவை நீக்கு", + "DeleteImageConfirmation": "இந்த படத்தை நீக்க விரும்புகிறீர்களா?", + "DeleteImage": "படத்தை நீக்கு", + "DeleteDeviceConfirmation": "இந்த சாதனத்தை நீக்க விரும்புகிறீர்களா? அடுத்த முறை ஒரு பயனர் உள்நுழையும்போது அது மீண்டும் தோன்றும்.", + "Delete": "அழி", + "DeinterlaceMethodHelp": "ஒன்றோடொன்று உள்ளடக்கத்தை டிரான்ஸ்கோடிங் செய்யும்போது பயன்படுத்த வேண்டிய deinterlacing முறையைத் தேர்ந்தெடுக்கவும்.", + "DefaultSubtitlesHelp": "உட்பொதிக்கப்பட்ட மெட்டாடேட்டாவில் இயல்புநிலை மற்றும் கட்டாயக் கொடிகளின் அடிப்படையில் வசன வரிகள் ஏற்றப்படுகின்றன. பல விருப்பங்கள் கிடைக்கும்போது மொழி விருப்பத்தேர்வுகள் கருதப்படுகின்றன.", + "DefaultMetadataLangaugeDescription": "இவை உங்கள் இயல்புநிலைகள் மற்றும் ஒவ்வொரு நூலக அடிப்படையில் தனிப்பயனாக்கலாம்.", + "ErrorDefault": "கோரிக்கையை செயலாக்குவதில் பிழை ஏற்பட்டது. பின்னர் மீண்டும் முயற்சிக்கவும்.", + "Default": "இயல்புநிலை", + "DeathDateValue": "இறந்தது: {0}", + "DatePlayed": "விளையாடிய தேதி", + "DateAdded": "தேதி சேர்க்கப்பட்டது", + "CustomDlnaProfilesHelp": "புதிய சாதனத்தை குறிவைக்க அல்லது கணினி சுயவிவரத்தை மேலெழுத தனிப்பயன் சுயவிவரத்தை உருவாக்கவும்.", + "CriticRating": "விமர்சன மதிப்பீடு", + "CopyStreamURLSuccess": "URL வெற்றிகரமாக நகலெடுக்கப்பட்டது.", + "CopyStreamURL": "ஸ்ட்ரீம் URL ஐ நகலெடுக்கவும்", + "Continuing": "தொடர்கிறது", + "ContinueWatching": "தொடர்ந்து பார்த்துக் கொள்ளுங்கள்", + "Connect": "இணைக்கவும்", + "ConfirmEndPlayerSession": "ஜெல்லிஃபினை {0} இல் நிறுத்த விரும்புகிறீர்களா?", + "ConfirmDeletion": "நீக்குதலை உறுதிப்படுத்தவும்", + "ConfirmDeleteItems": "இந்த உருப்படிகளை நீக்குவது கோப்பு முறைமை மற்றும் உங்கள் ஊடக நூலகம் இரண்டிலிருந்தும் அவற்றை நீக்கும். நீங்கள் தொடர விரும்புகிறீர்களா?", + "ConfirmDeleteItem": "இந்த உருப்படியை நீக்குவது கோப்பு முறைமை மற்றும் உங்கள் ஊடக நூலகம் இரண்டிலிருந்தும் நீக்கப்படும். நீங்கள் தொடர விரும்புகிறீர்களா?", + "ConfirmDeleteImage": "படத்தை நீக்கவா?", + "ConfigureDateAdded": "நூலக அமைப்புகளின் கீழ் டாஷ்போர்டில் சேர்க்கப்பட்ட தேதி எவ்வாறு தீர்மானிக்கப்படுகிறது என்பதை உள்ளமைக்கவும்", + "Composer": "இசையமைப்பாளர்", + "CommunityRating": "சமூக மதிப்பீடு", + "ColorTransfer": "வண்ண பரிமாற்றம்", + "ColorSpace": "வண்ண இடம்", + "ColorPrimaries": "வண்ண முதன்மைகள்" } From 922623d726d4244a133b3aeb0ccd356dd63a963f Mon Sep 17 00:00:00 2001 From: Oatavandi Date: Fri, 14 Aug 2020 06:37:09 +0000 Subject: [PATCH 225/301] Translated using Weblate (Tamil) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/ta/ --- src/strings/ta.json | 13 ++++++++++++- 1 file changed, 12 insertions(+), 1 deletion(-) diff --git a/src/strings/ta.json b/src/strings/ta.json index 8d4076c491..d8bfbeff95 100644 --- a/src/strings/ta.json +++ b/src/strings/ta.json @@ -253,5 +253,16 @@ "CommunityRating": "சமூக மதிப்பீடு", "ColorTransfer": "வண்ண பரிமாற்றம்", "ColorSpace": "வண்ண இடம்", - "ColorPrimaries": "வண்ண முதன்மைகள்" + "ColorPrimaries": "வண்ண முதன்மைகள்", + "EveryNDays": "ஒவ்வொரு {0} நாட்களும்", + "ErrorSavingTvProvider": "டிவி வழங்குநரைச் சேமிப்பதில் பிழை ஏற்பட்டது. அணுகக்கூடியது என்பதை உறுதிசெய்து மீண்டும் முயற்சிக்கவும்.", + "ErrorPleaseSelectLineup": "தயவுசெய்து ஒரு வரிசையைத் தேர்ந்தெடுத்து மீண்டும் முயற்சிக்கவும். வரிசைகள் எதுவும் கிடைக்கவில்லை என்றால், உங்கள் பயனர்பெயர், கடவுச்சொல் மற்றும் அஞ்சல் குறியீடு சரியானதா என்பதை சரிபார்க்கவும்.", + "ErrorStartHourGreaterThanEnd": "இறுதி நேரம் தொடக்க நேரத்தை விட அதிகமாக இருக்க வேண்டும்.", + "ErrorGettingTvLineups": "டிவி வரிசைகளை பதிவிறக்குவதில் பிழை ஏற்பட்டது. உங்கள் தகவல் சரியானது என்பதை உறுதிசெய்து மீண்டும் முயற்சிக்கவும்.", + "ErrorDeletingItem": "சேவையகத்திலிருந்து உருப்படியை நீக்குவதில் பிழை ஏற்பட்டது. ஜெல்லிஃபின் மீடியா கோப்புறையில் எழுத அணுகல் உள்ளதா என்பதை சரிபார்த்து மீண்டும் முயற்சிக்கவும்.", + "ErrorAddingXmlTvFile": "XMLTV கோப்பை அணுகுவதில் பிழை ஏற்பட்டது. கோப்பு இருப்பதை உறுதிசெய்து மீண்டும் முயற்சிக்கவும்.", + "ErrorAddingTunerDevice": "ட்யூனர் சாதனத்தைச் சேர்ப்பதில் பிழை ஏற்பட்டது. அணுகக்கூடியது என்பதை உறுதிசெய்து மீண்டும் முயற்சிக்கவும்.", + "ErrorAddingMediaPathToVirtualFolder": "ஊடக பாதையைச் சேர்ப்பதில் பிழை ஏற்பட்டது. பாதை செல்லுபடியாகும் என்பதை உறுதிப்படுத்தவும், அந்த இடத்திற்கு ஜெல்லிஃபின் அணுகல் உள்ளது.", + "ErrorAddingListingsToSchedulesDirect": "உங்கள் அட்டவணைகள் நேரடி கணக்கில் வரிசையைச் சேர்ப்பதில் பிழை ஏற்பட்டது. அட்டவணைகள் நேரடி ஒரு கணக்கிற்கு ஒரு குறிப்பிட்ட எண்ணிக்கையிலான வரிசைகளை மட்டுமே அனுமதிக்கிறது. தொடர்வதற்கு முன் நீங்கள் அட்டவணைகள் நேரடி இணையதளத்தில் உள்நுழைந்து மற்றவர்களின் பட்டியலை உங்கள் கணக்கிலிருந்து அகற்ற வேண்டும்.", + "Episodes": "அத்தியாயங்கள்" } From f6517bba29fa910abc84a33ebd7811e57d36efa1 Mon Sep 17 00:00:00 2001 From: Oatavandi Date: Fri, 14 Aug 2020 06:57:43 +0000 Subject: [PATCH 226/301] Translated using Weblate (Tamil) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/ta/ --- src/strings/ta.json | 72 ++++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 71 insertions(+), 1 deletion(-) diff --git a/src/strings/ta.json b/src/strings/ta.json index d8bfbeff95..d7f135ff02 100644 --- a/src/strings/ta.json +++ b/src/strings/ta.json @@ -264,5 +264,75 @@ "ErrorAddingTunerDevice": "ட்யூனர் சாதனத்தைச் சேர்ப்பதில் பிழை ஏற்பட்டது. அணுகக்கூடியது என்பதை உறுதிசெய்து மீண்டும் முயற்சிக்கவும்.", "ErrorAddingMediaPathToVirtualFolder": "ஊடக பாதையைச் சேர்ப்பதில் பிழை ஏற்பட்டது. பாதை செல்லுபடியாகும் என்பதை உறுதிப்படுத்தவும், அந்த இடத்திற்கு ஜெல்லிஃபின் அணுகல் உள்ளது.", "ErrorAddingListingsToSchedulesDirect": "உங்கள் அட்டவணைகள் நேரடி கணக்கில் வரிசையைச் சேர்ப்பதில் பிழை ஏற்பட்டது. அட்டவணைகள் நேரடி ஒரு கணக்கிற்கு ஒரு குறிப்பிட்ட எண்ணிக்கையிலான வரிசைகளை மட்டுமே அனுமதிக்கிறது. தொடர்வதற்கு முன் நீங்கள் அட்டவணைகள் நேரடி இணையதளத்தில் உள்நுழைந்து மற்றவர்களின் பட்டியலை உங்கள் கணக்கிலிருந்து அகற்ற வேண்டும்.", - "Episodes": "அத்தியாயங்கள்" + "Episodes": "அத்தியாயங்கள்", + "HeaderConfirmPluginInstallation": "செருகுநிரல் நிறுவலை உறுதிப்படுத்தவும்", + "HeaderConfigureRemoteAccess": "தொலைநிலை அணுகலை உள்ளமைக்கவும்", + "HeaderCodecProfileHelp": "குறிப்பிட்ட கோடெக்குகளை இயக்கும்போது கோடெக் சுயவிவரங்கள் சாதனத்தின் வரம்புகளைக் குறிக்கின்றன. ஒரு வரம்பு பொருந்தினால், கோடெக் நேரடி விளையாட்டிற்காக கட்டமைக்கப்பட்டிருந்தாலும், மீடியா டிரான்ஸ்கோட் செய்யப்படும்.", + "HeaderCodecProfile": "கோடெக் சுயவிவரம்", + "HeaderChapterImages": "பாடம் படங்கள்", + "HeaderChannelAccess": "சேனல் அணுகல்", + "HeaderCastCrew": "நடிகர்கள் & குழு", + "HeaderCastAndCrew": "நடிகர்கள் & குழு", + "HeaderCancelSeries": "தொடரை ரத்துசெய்", + "HeaderCancelRecording": "பதிவை ரத்துசெய்", + "HeaderBranding": "பிராண்டிங்", + "HeaderBooks": "புத்தகங்கள்", + "HeaderBlockItemsWithNoRating": "இல்லை அல்லது அங்கீகரிக்கப்படாத மதிப்பீட்டு தகவல் இல்லாத உருப்படிகளைத் தடு:", + "HeaderAudioSettings": "ஆடியோ அமைப்புகள்", + "HeaderAudioBooks": "ஆடியோ புத்தகங்கள்", + "HeaderAppearsOn": "தோன்றும்", + "HeaderApp": "செயலி", + "ApiKeysCaption": "தற்போது இயக்கப்பட்ட API விசைகளின் பட்டியல்", + "HeaderApiKeysHelp": "சேவையகத்துடன் தொடர்புகொள்வதற்கு வெளிப்புற பயன்பாடுகள் ஏபிஐ விசையை வைத்திருக்க வேண்டும். விசைகள் ஒரு சாதாரண பயனர் கணக்கில் உள்நுழைந்து அல்லது பயன்பாட்டிற்கு ஒரு விசையை கைமுறையாக வழங்குவதன் மூலம் வழங்கப்படுகின்றன.", + "HeaderApiKeys": "API விசைகள்", + "HeaderApiKey": "API விசை", + "HeaderAllowMediaDeletionFrom": "இருந்து மீடியாவை நீக்க அனுமதிக்கவும்", + "HeaderAlert": "எச்சரிக்கை", + "HeaderAdmin": "நிர்வாகம்", + "HeaderAdditionalParts": "கூடுதல் பாகங்கள்", + "HeaderAddUser": "பயனரைச் சேர்க்கவும்", + "HeaderAddUpdateImage": "படத்தைச் சேர்க்கவும் / புதுப்பிக்கவும்", + "HeaderAddToPlaylist": "பட்டியலில் சேர்", + "HeaderAddToCollection": "சேகரிப்பில் சேர்", + "HeaderAddScheduledTaskTrigger": "தூண்டுதலைச் சேர்க்கவும்", + "HeaderActivity": "செயல்பாடு", + "HeaderActiveRecordings": "செயலில் பதிவுகள்", + "HeaderActiveDevices": "செயலில் உள்ள சாதனங்கள்", + "HeaderAccessScheduleHelp": "சில மணிநேரங்களுக்கான அணுகலைக் கட்டுப்படுத்த அணுகல் அட்டவணையை உருவாக்கவும்.", + "HeaderAccessSchedule": "அணுகல் அட்டவணை", + "HardwareAccelerationWarning": "வன்பொருள் முடுக்கம் இயக்குவது சில சூழல்களில் உறுதியற்ற தன்மையை ஏற்படுத்தக்கூடும். உங்கள் இயக்க முறைமை மற்றும் வீடியோ இயக்கிகள் முழுமையாக புதுப்பித்த நிலையில் இருப்பதை உறுதிசெய்க. இதை இயக்கிய பின் வீடியோவை இயக்குவதில் சிக்கல் இருந்தால், நீங்கள் அமைப்பை எதுவும் இல்லை என மாற்ற வேண்டும்.", + "HDPrograms": "HD நிரல்கள்", + "EncoderPresetHelp": "செயல்திறனை மேம்படுத்த வேகமான மதிப்பை அல்லது தரத்தை மேம்படுத்த மெதுவான மதிப்பைத் தேர்வுசெய்க.", + "H264CrfHelp": "நிலையான விகித காரணி (CRF) என்பது x264 குறியாக்கிக்கான இயல்புநிலை தர அமைப்பாகும். நீங்கள் 0 மற்றும் 51 க்கு இடையில் மதிப்புகளை அமைக்கலாம், அங்கு குறைந்த மதிப்புகள் சிறந்த தரத்தை ஏற்படுத்தும் (அதிக கோப்பு அளவுகளின் இழப்பில்). சேன் மதிப்புகள் 18 முதல் 28 வரை உள்ளன. X264 இன் இயல்புநிலை 23 ஆகும், எனவே இதை நீங்கள் ஒரு தொடக்க புள்ளியாக பயன்படுத்தலாம்.", + "GuideProviderSelectListings": "பட்டியல்களைத் தேர்ந்தெடுக்கவும்", + "GuideProviderLogin": "உள்நுழைய", + "Guide": "வழிகாட்டி", + "GuestStar": "விருந்தினர் நட்சத்திரம்", + "GroupVersions": "குழு பதிப்புகள்", + "GroupBySeries": "தொடர் அடிப்படையில் குழு", + "Genre": "வகை", + "General": "பொது", + "Fullscreen": "முழு திரை", + "Friday": "வெள்ளி", + "FormatValue": "வடிவம்: {0}", + "FolderTypeUnset": "கலப்பு உள்ளடக்கம்", + "FolderTypeTvShows": "தொலைக்காட்சி நிகழ்ச்சிகள்", + "FolderTypeMusicVideos": "இசை கானொளி", + "FolderTypeMusic": "இசை", + "FolderTypeMovies": "திரைப்படங்கள்", + "FolderTypeBooks": "புத்தகங்கள்", + "Filters": "வடிப்பான்கள்", + "FileReadError": "கோப்பைப் படிக்கும்போது பிழை ஏற்பட்டது.", + "FileReadCancelled": "படித்த கோப்பு ரத்து செய்யப்பட்டது.", + "FileNotFound": "கோப்பு கிடைக்கவில்லை.", + "File": "கோப்பு", + "FetchingData": "கூடுதல் தரவைப் பெறுகிறது", + "Features": "அம்சங்கள்", + "Favorite": "பிடித்தது", + "FastForward": "வேகமாக முன்னோக்கி", + "FFmpegSavePathNotFound": "நீங்கள் உள்ளிட்ட பாதையைப் பயன்படுத்தி FFmpeg ஐ எங்களால் கண்டுபிடிக்க முடியவில்லை. FFprobe தேவைப்படுகிறது மற்றும் அதே கோப்புறையில் இருக்க வேண்டும். இந்த கூறுகள் பொதுவாக ஒரே பதிவிறக்கத்தில் ஒன்றாக தொகுக்கப்படுகின்றன. பாதையை சரிபார்த்து மீண்டும் முயற்சிக்கவும்.", + "Extras": "கூடுதல்", + "ExtractChapterImagesHelp": "அத்தியாயப் படங்களை பிரித்தெடுப்பது வாடிக்கையாளர்களுக்கு வரைகலை காட்சி தேர்வு மெனுக்களைக் காண்பிக்கும். செயல்முறை மெதுவாகவும், வள தீவிரமாகவும் இருக்கலாம், மேலும் பல ஜிகாபைட் இடம் தேவைப்படலாம். வீடியோக்கள் கண்டுபிடிக்கப்பட்டதும், இரவு திட்டமிடப்பட்ட பணியாகவும் இது இயங்குகிறது. திட்டமிடப்பட்ட பணிகள் பகுதியில் அட்டவணை கட்டமைக்கப்படுகிறது. அதிகபட்ச பயன்பாட்டு நேரங்களில் இந்த பணியை இயக்க பரிந்துரைக்கப்படவில்லை.", + "ExtraLarge": "கூடுதல் பெரியது", + "ExitFullscreen": "முழு திரையில் இருந்து வெளியேறவும்" } From 429cc400fae7cfac1cd053404ee4d3c8091753d6 Mon Sep 17 00:00:00 2001 From: Oatavandi Date: Fri, 14 Aug 2020 07:51:36 +0000 Subject: [PATCH 227/301] Translated using Weblate (Tamil) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/ta/ --- src/strings/ta.json | 38 +++++++++++++++++++++++++++++++++++++- 1 file changed, 37 insertions(+), 1 deletion(-) diff --git a/src/strings/ta.json b/src/strings/ta.json index d7f135ff02..3e87f8da5f 100644 --- a/src/strings/ta.json +++ b/src/strings/ta.json @@ -334,5 +334,41 @@ "Extras": "கூடுதல்", "ExtractChapterImagesHelp": "அத்தியாயப் படங்களை பிரித்தெடுப்பது வாடிக்கையாளர்களுக்கு வரைகலை காட்சி தேர்வு மெனுக்களைக் காண்பிக்கும். செயல்முறை மெதுவாகவும், வள தீவிரமாகவும் இருக்கலாம், மேலும் பல ஜிகாபைட் இடம் தேவைப்படலாம். வீடியோக்கள் கண்டுபிடிக்கப்பட்டதும், இரவு திட்டமிடப்பட்ட பணியாகவும் இது இயங்குகிறது. திட்டமிடப்பட்ட பணிகள் பகுதியில் அட்டவணை கட்டமைக்கப்படுகிறது. அதிகபட்ச பயன்பாட்டு நேரங்களில் இந்த பணியை இயக்க பரிந்துரைக்கப்படவில்லை.", "ExtraLarge": "கூடுதல் பெரியது", - "ExitFullscreen": "முழு திரையில் இருந்து வெளியேறவும்" + "ExitFullscreen": "முழு திரையில் இருந்து வெளியேறவும்", + "HeaderFeatureAccess": "அம்ச அணுகல்", + "HeaderFavoritePlaylists": "பிடித்த இசைப்பட்டியல்கள்", + "HeaderFavoriteVideos": "பிடித்த வீடியோக்கள்", + "HeaderFavoritePeople": "பிடித்த மக்கள்", + "HeaderFavoriteMovies": "பிடித்த திரைப்படங்கள்", + "HeaderFavoriteBooks": "பிடித்த புத்தகங்கள்", + "HeaderExternalIds": "வெளி ஐடிகள்:", + "HeaderError": "பிழை", + "HeaderEpisodes": "அத்தியாயங்கள்", + "HeaderEnabledFieldsHelp": "ஒரு புலத்தை பூட்டவும், அதன் தரவு மாற்றப்படுவதைத் தடுக்கவும் தேர்வுநீக்கு.", + "HeaderEnabledFields": "இயக்கப்பட்ட புலங்கள்", + "HeaderEditImages": "படங்களைத் திருத்து", + "HeaderEasyPinCode": "எளிதாக பின் குறியீடு", + "HeaderDVR": "டி.வி.ஆர்", + "HeaderDownloadSync": "பதிவிறக்கம் & ஒத்திசை", + "HeaderDirectPlayProfileHelp": "சாதனம் சொந்த முறையில் கையாளக்கூடிய வடிவமைப்புகளைக் குறிக்க நேரடி ப்ளே சுயவிவரங்களைச் சேர்க்கவும்.", + "HeaderDirectPlayProfile": "நேரடி ப்ளே சுயவிவரம்", + "HeaderDevices": "சாதனங்கள்", + "HeaderDeviceAccess": "சாதன அணுகல்", + "HeaderDeveloperInfo": "உருவாக்குனர் தகவல்", + "HeaderDetectMyDevices": "எனது சாதனங்களைக் கண்டறியவும்", + "HeaderDeleteTaskTrigger": "பணி தூண்டுதலை நீக்கு", + "HeaderDeleteProvider": "வழங்குநரை நீக்கு", + "HeaderDeleteItems": "உருப்படிகளை நீக்கு", + "HeaderDeleteItem": "உருப்படியை நீக்கு", + "HeaderDeleteDevice": "சாதனத்தை நீக்கு", + "HeaderDefaultRecordingSettings": "இயல்புநிலை பதிவு அமைப்புகள்", + "HeaderDateIssued": "வழங்கப்பட்ட தேதி", + "HeaderCustomDlnaProfiles": "தனிப்பயன் சுயவிவரங்கள்", + "HeaderContinueListening": "தொடர்ந்து கேளுங்கள்", + "HeaderContainerProfileHelp": "குறிப்பிட்ட வடிவங்களை இயக்கும்போது கொள்கலன் சுயவிவரங்கள் சாதனத்தின் வரம்புகளைக் குறிக்கின்றன. ஒரு வரம்பு பொருந்தினால், நேரடி விளையாட்டுக்காக வடிவமைப்பு கட்டமைக்கப்பட்டிருந்தாலும், மீடியா டிரான்ஸ்கோட் செய்யப்படும்.", + "HeaderContainerProfile": "கொள்கலன் சுயவிவரம்", + "HeaderConnectionFailure": "இணைப்பு தோல்வி", + "HeaderConnectToServer": "சேவையகத்துடன் இணைக்கவும்", + "HeaderConfirmRevokeApiKey": "API விசையைத் திரும்பப்பெறுக", + "HeaderConfirmProfileDeletion": "சுயவிவர நீக்குதலை உறுதிப்படுத்தவும்" } From de798ebb9f8ff10bce3750d67cd6429fbd4a6f6a Mon Sep 17 00:00:00 2001 From: Oatavandi Date: Fri, 14 Aug 2020 08:12:52 +0000 Subject: [PATCH 228/301] Translated using Weblate (Tamil) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/ta/ --- src/strings/ta.json | 101 +++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 99 insertions(+), 2 deletions(-) diff --git a/src/strings/ta.json b/src/strings/ta.json index 3e87f8da5f..30f7ea85ba 100644 --- a/src/strings/ta.json +++ b/src/strings/ta.json @@ -22,7 +22,7 @@ "AllowRemoteAccessHelp": "தேர்வு செய்யப்படாவிட்டால், எல்லா தொலைநிலை இணைப்புகளும் தடுக்கப்படும்.", "AllowRemoteAccess": "இந்த சேவையகத்திற்கு தொலை இணைப்புகளை அனுமதிக்கவும்.", "AllowFfmpegThrottlingHelp": "ஒரு டிரான்ஸ்கோட் அல்லது ரீமக்ஸ் தற்போதைய பின்னணி நிலையிலிருந்து வெகு தொலைவில் இருக்கும்போது, செயல்முறையை இடைநிறுத்துங்கள், இதனால் அது குறைந்த ஆதாரங்களை நுகரும். அடிக்கடி தேடாமல் பார்க்கும்போது இது மிகவும் பயனுள்ளதாக இருக்கும். பின்னணி சிக்கல்களை நீங்கள் சந்தித்தால் இதை அணைக்கவும்.", - "AllowFfmpegThrottling": "த்ரோட்டில் டிரான்ஸ்கோட்கள்", + "AllowFfmpegThrottling": "திராட்டில் ட்ரான்ஸ்கோட்கள்", "AllowOnTheFlySubtitleExtractionHelp": "வீடியோ டிரான்ஸ்கோடிங்கைத் தடுக்க உதவும் வகையில் உட்பொதிக்கப்பட்ட வசனங்களை வீடியோக்களிலிருந்து பிரித்தெடுத்து வாடிக்கையாளர்களுக்கு எளிய உரையில் வழங்கலாம். சில கணினிகளில் இது நீண்ட நேரம் எடுக்கும் மற்றும் பிரித்தெடுக்கும் செயல்பாட்டின் போது வீடியோ பிளேபேக் நிறுத்தப்படும். கிளையன்ட் சாதனத்தால் பூர்வீகமாக ஆதரிக்கப்படாதபோது உட்பொதிக்கப்பட்ட வசன வரிகள் வீடியோ டிரான்ஸ்கோடிங்கில் எரிக்கப்படுவதை முடக்கு.", "AllowOnTheFlySubtitleExtraction": "பறக்கையில் வசன வரிகள் பிரித்தெடுக்க அனுமதிக்கவும்", "AllowMediaConversionHelp": "மாற்றும் ஊடக அம்சத்திற்கான அணுகலை வழங்கவும் அல்லது மறுக்கவும்.", @@ -370,5 +370,102 @@ "HeaderConnectionFailure": "இணைப்பு தோல்வி", "HeaderConnectToServer": "சேவையகத்துடன் இணைக்கவும்", "HeaderConfirmRevokeApiKey": "API விசையைத் திரும்பப்பெறுக", - "HeaderConfirmProfileDeletion": "சுயவிவர நீக்குதலை உறுதிப்படுத்தவும்" + "HeaderConfirmProfileDeletion": "சுயவிவர நீக்குதலை உறுதிப்படுத்தவும்", + "HeaderSortBy": "மூலம் வரிசைப்படுத்து", + "HeaderSetupLibrary": "உங்கள் மீடியா நூலகங்களை அமைக்கவும்", + "HeaderSettings": "அமைப்புகள்", + "HeaderServerSettings": "சேவையக அமைப்புகள்", + "HeaderServerAddressSettings": "சேவையக முகவரி அமைப்புகள்", + "HeaderSeriesStatus": "தொடர் நிலை", + "HeaderSeriesOptions": "தொடர் விருப்பங்கள்", + "HeaderSendMessage": "செய்தியை அனுப்பு", + "HeaderSelectTranscodingPathHelp": "டிரான்ஸ்கோட் கோப்புகளுக்கு பயன்படுத்த பாதையை உலாவவும் அல்லது உள்ளிடவும். கோப்புறை எழுதக்கூடியதாக இருக்க வேண்டும்.", + "HeaderSelectTranscodingPath": "டிரான்ஸ்கோடிங் தற்காலிக பாதையைத் தேர்ந்தெடுக்கவும்", + "HeaderSelectServerCachePathHelp": "சேவையக தேக்கக கோப்புகளுக்கு பயன்படுத்த பாதையை உலாவவும் அல்லது உள்ளிடவும். கோப்புறை எழுதக்கூடியதாக இருக்க வேண்டும்.", + "HeaderSelectServerCachePath": "சேவையக தேக்கக பாதையைத் தேர்ந்தெடுக்கவும்", + "HeaderSelectServer": "சேவையகத்தைத் தேர்ந்தெடுக்கவும்", + "HeaderSelectPath": "பாதையைத் தேர்ந்தெடுக்கவும்", + "HeaderSelectMetadataPathHelp": "மெட்டாடேட்டாவிற்கு நீங்கள் பயன்படுத்த விரும்பும் பாதையை உலாவவும் அல்லது உள்ளிடவும். கோப்புறை எழுதக்கூடியதாக இருக்க வேண்டும்.", + "HeaderSelectMetadataPath": "மெட்டாடேட்டா பாதையைத் தேர்ந்தெடுக்கவும்", + "HeaderSelectCertificatePath": "சான்றிதழ் பாதையைத் தேர்ந்தெடுக்கவும்", + "HeaderSecondsValue": "{0} விநாடிகள்", + "HeaderSeasons": "பருவங்கள்", + "HeaderScenes": "காட்சிகள்", + "HeaderRunningTasks": "இயங்கும் பணிகள்", + "HeaderRevisionHistory": "திருத்த வரலாறு", + "HeaderRestart": "மறுதொடக்கம்", + "HeaderResponseProfileHelp": "சில வகையான மீடியாக்களை இயக்கும்போது சாதனத்திற்கு அனுப்பப்பட்ட தகவல்களைத் தனிப்பயனாக்க பதில் சுயவிவரங்கள் ஒரு வழியை வழங்குகின்றன.", + "HeaderResponseProfile": "பதில் சுயவிவரம்", + "HeaderRemoveMediaLocation": "மீடியா இருப்பிடத்தை அகற்று", + "HeaderRemoveMediaFolder": "மீடியா கோப்புறையை அகற்று", + "HeaderRemoteControl": "தொலையியக்கி", + "HeaderRemoteAccessSettings": "தொலைநிலை அணுகல் அமைப்புகள்", + "HeaderRecordingPostProcessing": "பதிவு செயலாக்கம் பதிவு செய்தல்", + "HeaderRecordingOptions": "பதிவு செய்தல் விருப்பங்கள்", + "HeaderRecentlyPlayed": "சமீபத்தில் இசையப்பட்டுள்ளது", + "HeaderProfileServerSettingsHelp": "இந்த மதிப்புகள் சேவையகம் எவ்வாறு வாடிக்கையாளர்களுக்கு முன்வைக்கும் என்பதைக் கட்டுப்படுத்துகிறது.", + "HeaderProfileInformation": "சுயவிவர தகவல்", + "HeaderProfile": "சுயவிவரம்", + "HeaderPreferredMetadataLanguage": "விருப்பமான மெட்டாடேட்டா மொழி", + "HeaderPluginInstallation": "செருகுநிரல் நிறுவல்", + "HeaderPleaseSignIn": "உள்நுழைக", + "HeaderPlaybackError": "பின்னணி பிழை", + "HeaderPlayback": "மீடியா பிளேபேக்", + "HeaderPlayOn": "இயக்கு", + "HeaderPlayAll": "அனைத்தும் இயக்கு", + "HeaderPinCodeReset": "பின் குறியீட்டை மீட்டமை", + "HeaderPhotoAlbums": "புகைப்பட ஆல்பங்கள்", + "HeaderPaths": "பாதைகள்", + "HeaderPasswordReset": "கடவுச்சொல் மீட்டமைப்பு", + "HeaderPassword": "கடவுச்சொல்", + "HeaderParentalRatings": "பெற்றோர் மதிப்பீடுகள்", + "HeaderOtherItems": "பிற உருப்படிகள்", + "HeaderOnNow": "இப்போது", + "HeaderNextVideoPlayingInValue": "அடுத்த வீடியோ {0} இல் இயங்குகிறது", + "HeaderNextEpisodePlayingInValue": "அடுத்த எபிசோட் {0} இல் விளையாடுகிறது", + "HeaderNewDevices": "புதிய சாதனங்கள்", + "HeaderNewApiKey": "புதிய API விசை", + "HeaderNavigation": "வழிசெலுத்தல்", + "HeaderMyMediaSmall": "எனது மீடியா (சிறியது)", + "HeaderMyMedia": "எனது மீடியா", + "HeaderMyDevice": "என் உபகரணம்", + "HeaderMusicVideos": "இசை கானொளி", + "HeaderMusicQuality": "இசை தரம்", + "HeaderMoreLikeThis": "இது போன்றது", + "HeaderMetadataSettings": "மெட்டாடேட்டா அமைப்புகள்", + "HeaderMediaInfo": "மீடியா தகவல்", + "HeaderMediaFolders": "மீடியா கோப்புறைகள்", + "HeaderMedia": "மீடியா", + "HeaderLoginFailure": "உள்நுழைவு தோல்வி", + "HeaderLiveTvTunerSetup": "லைவ் டிவி ட்யூனர் அமைப்பு", + "HeaderLibrarySettings": "நூலக அமைப்புகள்", + "HeaderLibraryOrder": "நூலக ஆணை", + "HeaderLibraryFolders": "நூலக கோப்புறைகள்", + "HeaderLibraryAccess": "நூலக அணுகல்", + "HeaderLibraries": "நூலகங்கள்", + "HeaderLatestRecordings": "சமீபத்திய பதிவுகள்", + "HeaderLatestMusic": "சமீபத்திய இசை", + "HeaderLatestMovies": "சமீபத்திய திரைப்படங்கள்", + "HeaderLatestMedia": "சமீபத்திய மீடியா", + "HeaderLatestEpisodes": "சமீபத்திய அத்தியாயங்கள்", + "HeaderKodiMetadataHelp": "NFO மெட்டாடேட்டாவை இயக்க அல்லது முடக்க, ஒரு நூலகத்தைத் திருத்தி மெட்டாடேட்டா சேவர்ஸ் பகுதியைக் கண்டறியவும்.", + "HeaderKeepSeries": "தொடரை வைத்திருங்கள்", + "HeaderKeepRecording": "பதிவுசெய்து கொள்ளுங்கள்", + "HeaderInstantMix": "உடனடி கலவை", + "HeaderInstall": "நிறுவு", + "HeaderImageSettings": "பட அமைப்புகள்", + "HeaderImageOptions": "பட விருப்பங்கள்", + "HeaderIdentifyItemHelp": "ஒன்று அல்லது அதற்கு மேற்பட்ட தேடல் அளவுகோல்களை உள்ளிடவும். தேடல் முடிவுகளை அதிகரிக்க அளவுகோல்களை அகற்று.", + "HeaderIdentificationHeader": "அடையாள தலைப்பு", + "HeaderIdentificationCriteriaHelp": "குறைந்தது ஒரு அடையாள அளவுகோல்களை உள்ளிடவும்.", + "HeaderIdentification": "அடையாளம்", + "HeaderHttpsSettings": "HTTPS அமைப்புகள்", + "HeaderHttpHeaders": "HTTP தலைப்புகள்", + "HeaderHome": "முகப்பு", + "HeaderGuideProviders": "டிவி வழிகாட்டி தரவு வழங்குநர்கள்", + "HeaderFrequentlyPlayed": "அடிக்கடி இசைக்கும்", + "HeaderForgotPassword": "கடவுச்சொல்லை மறந்துவிட்டீர்களா", + "HeaderForKids": "குழந்தைகளுக்காக", + "HeaderFetcherSettings": "பெறுதல் அமைப்புகள்", + "HeaderFetchImages": "படங்களை பெறுங்கள்:" } From 06689b91aec063a46ec87ff13bb8c3c4b5057d46 Mon Sep 17 00:00:00 2001 From: Oatavandi Date: Fri, 14 Aug 2020 09:53:35 +0000 Subject: [PATCH 229/301] Translated using Weblate (Tamil) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/ta/ --- src/strings/ta.json | 41 ++++++++++++++++++++++++++++++++++++++++- 1 file changed, 40 insertions(+), 1 deletion(-) diff --git a/src/strings/ta.json b/src/strings/ta.json index 30f7ea85ba..e3bd7a66af 100644 --- a/src/strings/ta.json +++ b/src/strings/ta.json @@ -467,5 +467,44 @@ "HeaderForgotPassword": "கடவுச்சொல்லை மறந்துவிட்டீர்களா", "HeaderForKids": "குழந்தைகளுக்காக", "HeaderFetcherSettings": "பெறுதல் அமைப்புகள்", - "HeaderFetchImages": "படங்களை பெறுங்கள்:" + "HeaderFetchImages": "படங்களை பெறுங்கள்:", + "Home": "முகப்பு", + "HideWatchedContentFromLatestMedia": "சமீபத்திய மீடியாவிலிருந்து பார்த்த உள்ளடக்கத்தை மறை", + "Hide": "மறை", + "Help": "உதவி", + "HeaderYears": "ஆண்டுகள்", + "HeaderXmlSettings": "XML அமைப்புகள்", + "HeaderXmlDocumentAttributes": "XML ஆவண பண்புக்கூறுகள்", + "HeaderXmlDocumentAttribute": "XML ஆவண பண்புக்கூறு", + "HeaderVideos": "வீடியோக்கள்", + "HeaderVideoTypes": "வீடியோ வகைகள்", + "HeaderVideoType": "வீடியோ வகை", + "HeaderVideoQuality": "வீடியோ தரம்", + "HeaderUsers": "பயனர்கள்", + "HeaderUser": "பயனர்", + "HeaderUploadImage": "படத்தை பதிவேற்றம் செய்யவும்", + "HeaderUpcomingOnTV": "தொலைக்காட்சியில் வரவிருக்கும்", + "HeaderTypeText": "உரையை உள்ளிடவும்", + "HeaderTypeImageFetchers": "{0} படத்தை எடுப்பவர்கள்", + "HeaderTuners": "ட்யூனர்கள்", + "HeaderTunerDevices": "ட்யூனர் சாதனங்கள்", + "HeaderTranscodingProfileHelp": "டிரான்ஸ்கோடிங் தேவைப்படும்போது எந்த வடிவங்களைப் பயன்படுத்த வேண்டும் என்பதைக் குறிக்க டிரான்ஸ்கோடிங் சுயவிவரங்களைச் சேர்க்கவும்.", + "HeaderTranscodingProfile": "டிரான்ஸ்கோடிங் சுயவிவரம்", + "HeaderTracks": "தடங்கள்", + "HeaderThisUserIsCurrentlyDisabled": "இந்த பயனர் தற்போது முடக்கப்பட்டுள்ளது", + "HeaderTaskTriggers": "பணி தூண்டுதல்கள்", + "HeaderSystemDlnaProfiles": "கணினி சுயவிவரங்கள்", + "HeaderSyncPlayEnabled": "ஒத்திசைவு இயக்கப்பட்டது", + "HeaderSyncPlaySelectGroup": "ஒரு குழுவில் சேர", + "HeaderSubtitleProfilesHelp": "சாதனம் ஆதரிக்கும் வசன வடிவங்களை வசன சுயவிவரங்கள் விவரிக்கின்றன.", + "HeaderSubtitleProfiles": "வசன சுயவிவரங்கள்", + "HeaderSubtitleProfile": "வசன சுயவிவரம்", + "HeaderSubtitleDownloads": "வசன பதிவிறக்கங்கள்", + "HeaderSubtitleAppearance": "வசனத் தோற்றம்", + "HeaderStopRecording": "பதிவு செய்வதை நிறுத்து", + "HeaderStatus": "நிலை", + "HeaderStartNow": "இப்போதே துவக்கு", + "HeaderSpecialFeatures": "சிறப்பு அம்சங்கள்", + "HeaderSpecialEpisodeInfo": "சிறப்பு எபிசோட் தகவல்", + "HeaderSortOrder": "வரிசைப்படுத்து வரிசை" } From 01c2ec079345f2d1ef7ebd7370cd48e4f93a656c Mon Sep 17 00:00:00 2001 From: Yangjin Cho Date: Fri, 14 Aug 2020 11:53:58 +0000 Subject: [PATCH 230/301] Translated using Weblate (Korean) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/ko/ --- src/strings/ko.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/strings/ko.json b/src/strings/ko.json index 62c924e517..79153c0962 100644 --- a/src/strings/ko.json +++ b/src/strings/ko.json @@ -740,7 +740,7 @@ "AllowMediaConversion": "미디어 변환 허용", "AllowOnTheFlySubtitleExtraction": "실시간 자막 추출 허용", "AllowOnTheFlySubtitleExtractionHelp": "비디오 트랜스코딩을 방지하기 위해 내장된 자막을 비디오에서 추출하여 텍스트로 클라이언트에 전송할 수 있습니다. 다만, 일부 시스템에서 추출 과정은 긴 시간이 걸리고 비디오 재생을 멈출 수 있습니다. 클라이언트에서 트랜스코딩을 사용할 수 없는 경우 이 기능을 비활성화하여 트랜스코딩 시 자막을 영상에 삽입하십시오.", - "AllowRemoteAccess": "이 Jellyfin 서버에 원격 접속을 허용합니다.", + "AllowRemoteAccess": "이 서버에 원격 접속을 허용합니다.", "AllowRemoteAccessHelp": "비 활성화할 시, 모든 외부 접속은 차단됩니다.", "AllowedRemoteAddressesHelp": "외부 접속을 허용할 IP 혹은 IP 넷마스크를 반점(,)으로 구분하여 입력하십시오. 공란일시, 모든 외부 접속이 허용됩니다.", "AlwaysPlaySubtitles": "항상 표시", From 31dd08030123017e461cba5509314b27f101c2db Mon Sep 17 00:00:00 2001 From: nothing nowhere Date: Fri, 14 Aug 2020 14:41:00 +0000 Subject: [PATCH 231/301] Added translation using Weblate (Bengali (Bangladesh)) --- src/strings/bn_BD.json | 1 + 1 file changed, 1 insertion(+) create mode 100644 src/strings/bn_BD.json diff --git a/src/strings/bn_BD.json b/src/strings/bn_BD.json new file mode 100644 index 0000000000..0967ef424b --- /dev/null +++ b/src/strings/bn_BD.json @@ -0,0 +1 @@ +{} From efa11cfe03c449d258ea436cb2570de7f9acc60b Mon Sep 17 00:00:00 2001 From: nothing nowhere Date: Fri, 14 Aug 2020 14:45:48 +0000 Subject: [PATCH 232/301] Translated using Weblate (Bengali (Bangladesh)) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/bn_BD/ --- src/strings/bn_BD.json | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/src/strings/bn_BD.json b/src/strings/bn_BD.json index 0967ef424b..9d0d42982f 100644 --- a/src/strings/bn_BD.json +++ b/src/strings/bn_BD.json @@ -1 +1,4 @@ -{} +{ + "Actor": "অভিনেতা", + "AccessRestrictedTryAgainLater": "অ্যাক্সেস বর্তমানে সীমাবদ্ধ। অনুগ্রহ করে একটু পরে আবার চেষ্টা করুন." +} From 58c49ab85a9eb8c80a9321c7e8949a82f1472087 Mon Sep 17 00:00:00 2001 From: Julien Machiels Date: Fri, 14 Aug 2020 17:10:13 +0200 Subject: [PATCH 233/301] Update src/scripts/clientUtils.js Co-authored-by: Cameron --- src/scripts/clientUtils.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/scripts/clientUtils.js b/src/scripts/clientUtils.js index 719d722a2b..fa9f232439 100644 --- a/src/scripts/clientUtils.js +++ b/src/scripts/clientUtils.js @@ -143,7 +143,7 @@ export function alert(options) { } import('alert').then(({default: alert}) => { - alert.default({ + alert({ title: options.title || Globalize.translate('HeaderAlert'), text: options.message }).then(options.callback || function () {}); From 5b0018850e8689cb9411f45f3724316e560d5351 Mon Sep 17 00:00:00 2001 From: Julien Machiels Date: Fri, 14 Aug 2020 17:10:20 +0200 Subject: [PATCH 234/301] Update src/scripts/clientUtils.js Co-authored-by: Cameron --- src/scripts/clientUtils.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/scripts/clientUtils.js b/src/scripts/clientUtils.js index fa9f232439..d94a08e56e 100644 --- a/src/scripts/clientUtils.js +++ b/src/scripts/clientUtils.js @@ -112,7 +112,7 @@ export function processServerConfigurationUpdateResult(result) { ]) .then(([{default: loading}, {default: toast}]) => { loading.hide(); - toast.default(Globalize.translate('MessageSettingsSaved')); + toast.(Globalize.translate('MessageSettingsSaved')); }); } From 7f9f3cf206950baae1ad2591b4a302546a42d717 Mon Sep 17 00:00:00 2001 From: Julien Machiels Date: Fri, 14 Aug 2020 17:10:27 +0200 Subject: [PATCH 235/301] Update src/scripts/clientUtils.js Co-authored-by: Cameron --- src/scripts/clientUtils.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/scripts/clientUtils.js b/src/scripts/clientUtils.js index d94a08e56e..eb3105a0a2 100644 --- a/src/scripts/clientUtils.js +++ b/src/scripts/clientUtils.js @@ -136,7 +136,7 @@ export function processErrorResponse(response) { export function alert(options) { if (typeof options == 'string') { return void import('toast').then(({default: toast}) => { - toast.default({ + toast({ text: options }); }); From 6cad03ec5346461b916f7bd7f20ccdb3a3362f86 Mon Sep 17 00:00:00 2001 From: DecentM Date: Fri, 14 Aug 2020 15:18:23 +0000 Subject: [PATCH 236/301] Translated using Weblate (Hungarian) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/hu/ --- src/strings/hu.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/strings/hu.json b/src/strings/hu.json index 644e7eb746..9a409e920f 100644 --- a/src/strings/hu.json +++ b/src/strings/hu.json @@ -1471,7 +1471,7 @@ "PreviousTrack": "Ugrás az előzőhöz", "NextTrack": "Ugrás a következőre", "LabelUnstable": "Instabil", - "SubtitleVerticalPositionHelp": "Annak a sornak a száma, ahol a szöveg megjelenik. A pozitív számok fentről lefelé mutatnak. A negatív számok alulról felfelé mutatnak.", + "SubtitleVerticalPositionHelp": "Annak a sornak a száma, ahol a szöveg megjelenik. Pozitív számok fentről lefele számolnak, negatív számok pedig lentről felfelé.", "Preview": "Előnézet", "LabelSubtitleVerticalPosition": "Függőleges pozíció:", "MessageGetInstalledPluginsError": "Hiba történt a jelenleg telepített bővítmények lekérdezése során.", From c88e6a30ae6664606ad254dd51bcfa73d44a6d4a Mon Sep 17 00:00:00 2001 From: nothing nowhere Date: Fri, 14 Aug 2020 14:53:02 +0000 Subject: [PATCH 237/301] Translated using Weblate (Bengali (Bangladesh)) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/bn_BD/ --- src/strings/bn_BD.json | 18 +++++++++++++++++- 1 file changed, 17 insertions(+), 1 deletion(-) diff --git a/src/strings/bn_BD.json b/src/strings/bn_BD.json index 9d0d42982f..7166a05f05 100644 --- a/src/strings/bn_BD.json +++ b/src/strings/bn_BD.json @@ -1,4 +1,20 @@ { "Actor": "অভিনেতা", - "AccessRestrictedTryAgainLater": "অ্যাক্সেস বর্তমানে সীমাবদ্ধ। অনুগ্রহ করে একটু পরে আবার চেষ্টা করুন." + "AccessRestrictedTryAgainLater": "অ্যাক্সেস বর্তমানে সীমাবদ্ধ। অনুগ্রহ করে একটু পরে আবার চেষ্টা করুন.", + "AllLibraries": "সব লাইব্রেরি", + "AllLanguages": "সব ভাষা", + "AllEpisodes": "সব এপিসোড", + "AllComplexFormats": "সমস্ত জটিল ফর্ম্যাট", + "AllChannels": "সব চ্যানেল", + "All": "সবগুলি", + "Alerts": "এলার্টস", + "Albums": "অ্যালবাম সমূহ", + "AlbumArtist": "অ্যালবাম আর্টিস্ট", + "Album": "অ্যালবাম", + "AirDate": "উন্মুক্তের তারিখ", + "AdditionalNotificationServices": "আরো নোটিফিকেশন সার্ভিস ইনস্টল করতে প্লাগিন ক্যাটালগে ব্রাউস করুন।", + "AddedOnValue": "এডেড {০}", + "AddToPlaylist": "প্লেলিস্টে অ্যাড করুন", + "AddToPlayQueue": "প্লে কিউ তে অ্যাড করুন", + "AddToCollection": "কালেকশন এ অ্যাড করুন" } From 395d12e01cb0def13f90db05314dca3b00856002 Mon Sep 17 00:00:00 2001 From: nothing things Date: Fri, 14 Aug 2020 15:58:42 +0000 Subject: [PATCH 238/301] Translated using Weblate (Bengali (Bangladesh)) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/bn_BD/ --- src/strings/bn_BD.json | 67 +++++++++++++++++++++++++++++++++++++++++- 1 file changed, 66 insertions(+), 1 deletion(-) diff --git a/src/strings/bn_BD.json b/src/strings/bn_BD.json index 7166a05f05..e56b7b2723 100644 --- a/src/strings/bn_BD.json +++ b/src/strings/bn_BD.json @@ -16,5 +16,70 @@ "AddedOnValue": "এডেড {০}", "AddToPlaylist": "প্লেলিস্টে অ্যাড করুন", "AddToPlayQueue": "প্লে কিউ তে অ্যাড করুন", - "AddToCollection": "কালেকশন এ অ্যাড করুন" + "AddToCollection": "কালেকশন এ অ্যাড করুন", + "ButtonPlay": "চালান", + "ButtonPause": "বিরতি", + "ButtonParentalControl": "অভিভাবকীয় নিয়ন্ত্রণ", + "ButtonOpen": "খুলুন", + "ButtonOk": "আচ্ছা", + "ButtonOff": "বন্ধ", + "ButtonNextTrack": "পরবর্তী ট্র্যাক", + "ButtonNetwork": "নেটওয়ার্ক", + "ButtonMore": "আরও", + "ButtonLibraryAccess": "লাইব্রেরি অ্যাক্সেস", + "ButtonInfo": "তথ্য", + "ButtonHome": "হোম", + "ButtonGuide": "গাইড", + "ButtonGotIt": "বুঝেছি", + "ButtonFullscreen": "ফুলস্ক্রিন", + "ButtonForgotPassword": "পাসওয়ার্ড ভুলে গেছি", + "ButtonFilter": "ফিলটার", + "ButtonEditOtherUserPreferences": "এই ব্যবহারকারীর প্রোফাইল, ছবি এবং ব্যক্তিগত পছন্দগুলি এডিট করুন।", + "ButtonEditImages": "ছবিগুলি এডিট করুন", + "ButtonEdit": "এডিট করুন", + "ButtonChangeServer": "সার্ভার পরিবর্তন করুন", + "ButtonCancel": "বাতিল", + "ButtonBack": "অনগ্রসর", + "ButtonAudioTracks": "অডিও ট্র্যাকস", + "ButtonArrowRight": "ডান", + "ButtonArrowLeft": "বাম", + "ButtonAddUser": "ব্যবহারকারী যুক্ত করুন", + "ButtonAddServer": "সার্ভার যোগ করুন", + "ButtonAddScheduledTaskTrigger": "ট্রিগার যুক্ত করুন", + "ButtonAddMediaLibrary": "মিডিয়া লাইব্রেরি যুক্ত করুন", + "ButtonAddImage": "ছবি", + "MessageBrowsePluginCatalog": "এভিলেবল প্লাগইনগুলি দেখতে আমাদের প্লাগইন ক্যাটালগ ব্রাউজ করুন।", + "Browse": "ব্রাউজ", + "BoxRear": "বক্স (পিছন)", + "BoxSet": "বক্স সেট", + "Box": "বক্স", + "Books": "বই", + "BookLibraryHelp": "অডিও এবং পাঠ্য বই সমর্থিত। {0} বইয়ের নামকরণ গাইড {1} পর্যালোচনা করুন।", + "Blacklist": "নিষিদ্ধ তালিকা", + "BirthPlaceValue": "জন্ম স্থান: {0}", + "BirthLocation": "জন্মের অবস্থান", + "BirthDateValue": "জন্ম: {0}", + "Banner": "ব্যানার", + "Backdrop": "ব্যাকড্রপ", + "Auto": "অটো", + "Audio": "অডিও", + "AskAdminToCreateLibrary": "একজন প্রশাসককে একটি লাইব্রেরি তৈরি করতে বলুন।", + "Ascending": "ঊর্ধ্বগামী", + "AsManyAsPossible": "যতটা সম্ভব", + "Artists": "শিল্পীবৃন্দ", + "Artist": "শিল্পী", + "Art": "শিল্প", + "AroundTime": "কাছাকাছি", + "Anytime": "যে কোনো সময়", + "AnyLanguage": "যেকোনো ভাষা", + "AlwaysPlaySubtitlesHelp": "ভাষার পছন্দের সাথে মিলিয়ে সাবটাইটেলগুলি লোড করা হবে।", + "AlwaysPlaySubtitles": "সর্বদা চালান", + "AllowRemoteAccessHelp": "যদি টিক না দেয়া হয়, সব রিমোট সংযোগ ব্লক করা হবে।", + "AllowRemoteAccess": "এই সার্ভারে দূরবর্তী সংযোগের অনুমতি দিন।", + "AllowFfmpegThrottling": "থ্রটল ট্রান্সকোড", + "AllowOnTheFlySubtitleExtraction": "অনদাফ্লাই সাবটাইটেল বেরকরার অনুমতি", + "AllowMediaConversion": "মিডিয়া কনভার্টের অনুমতি দিন", + "AllowHWTranscodingHelp": "টিউনার কে স্ট্রিম ট্রান্সকোড করার সুযোগ দিন। এটি সার্ভার ট্রান্সকোডিং কমাতে সাহায্য করতে পারে।", + "Aired": "উন্মুক্ত করন", + "Add": "যোগ" } From 0c84585275e4662781871e8f7a0fbec98bba5dd5 Mon Sep 17 00:00:00 2001 From: nothing things Date: Fri, 14 Aug 2020 16:43:11 +0000 Subject: [PATCH 239/301] Translated using Weblate (Bengali (Bangladesh)) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/bn_BD/ --- src/strings/bn_BD.json | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/src/strings/bn_BD.json b/src/strings/bn_BD.json index e56b7b2723..66f80428cb 100644 --- a/src/strings/bn_BD.json +++ b/src/strings/bn_BD.json @@ -81,5 +81,6 @@ "AllowMediaConversion": "মিডিয়া কনভার্টের অনুমতি দিন", "AllowHWTranscodingHelp": "টিউনার কে স্ট্রিম ট্রান্সকোড করার সুযোগ দিন। এটি সার্ভার ট্রান্সকোডিং কমাতে সাহায্য করতে পারে।", "Aired": "উন্মুক্ত করন", - "Add": "যোগ" + "Add": "যোগ", + "ButtonPreviousTrack": "পূর্ববর্তী ট্র্যাক" } From 4a6492cf11d952fc14625977958b5dbc130ba7c0 Mon Sep 17 00:00:00 2001 From: nothing things Date: Fri, 14 Aug 2020 16:43:21 +0000 Subject: [PATCH 240/301] Translated using Weblate (Bengali (Bangladesh)) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/bn_BD/ --- src/strings/bn_BD.json | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/src/strings/bn_BD.json b/src/strings/bn_BD.json index 66f80428cb..a100ff2890 100644 --- a/src/strings/bn_BD.json +++ b/src/strings/bn_BD.json @@ -82,5 +82,6 @@ "AllowHWTranscodingHelp": "টিউনার কে স্ট্রিম ট্রান্সকোড করার সুযোগ দিন। এটি সার্ভার ট্রান্সকোডিং কমাতে সাহায্য করতে পারে।", "Aired": "উন্মুক্ত করন", "Add": "যোগ", - "ButtonPreviousTrack": "পূর্ববর্তী ট্র্যাক" + "ButtonPreviousTrack": "পূর্ববর্তী ট্র্যাক", + "ButtonProfile": "প্রোফাইল" } From 2710cbe43bd09242d82314b957ae33a0630f0b39 Mon Sep 17 00:00:00 2001 From: nothing things Date: Fri, 14 Aug 2020 16:43:33 +0000 Subject: [PATCH 241/301] Translated using Weblate (Bengali (Bangladesh)) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/bn_BD/ --- src/strings/bn_BD.json | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) diff --git a/src/strings/bn_BD.json b/src/strings/bn_BD.json index a100ff2890..b9d652688c 100644 --- a/src/strings/bn_BD.json +++ b/src/strings/bn_BD.json @@ -83,5 +83,14 @@ "Aired": "উন্মুক্ত করন", "Add": "যোগ", "ButtonPreviousTrack": "পূর্ববর্তী ট্র্যাক", - "ButtonProfile": "প্রোফাইল" + "ButtonProfile": "প্রোফাইল", + "ButtonResume": "রিসিউম", + "ButtonRestart": "রিস্টার্ট", + "ButtonResetPassword": "পাসওয়ার্ড রিসেট করুন", + "ButtonResetEasyPassword": "সহজ পিন কোডটি রিসেট করুন", + "ButtonRename": "নামান্তর", + "ButtonRemove": "সরান", + "ButtonRefreshGuideData": "গাইড ডেটা রিফ্রেশ করুন", + "ButtonRefresh": "রিফ্রেশ", + "ButtonQuickStartGuide": "দ্রুত শুরু করার নির্দেশাবলী" } From 4600d09402ee42257702795addcf5f57e59a8339 Mon Sep 17 00:00:00 2001 From: nothing things Date: Fri, 14 Aug 2020 17:10:47 +0000 Subject: [PATCH 242/301] Translated using Weblate (Bengali (Bangladesh)) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/bn_BD/ --- src/strings/bn_BD.json | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) diff --git a/src/strings/bn_BD.json b/src/strings/bn_BD.json index b9d652688c..f6082e7268 100644 --- a/src/strings/bn_BD.json +++ b/src/strings/bn_BD.json @@ -92,5 +92,14 @@ "ButtonRemove": "সরান", "ButtonRefreshGuideData": "গাইড ডেটা রিফ্রেশ করুন", "ButtonRefresh": "রিফ্রেশ", - "ButtonQuickStartGuide": "দ্রুত শুরু করার নির্দেশাবলী" + "ButtonQuickStartGuide": "দ্রুত শুরু করার নির্দেশাবলী", + "CopyStreamURL": "স্ট্রিম ইউআরএল কপি", + "ContinueWatching": "দেখা অব্যাহত রাখুন", + "Connect": "কানেক্ট", + "ConfirmEndPlayerSession": "আপনি কি জেলিফিনকে {0} এ বন্ধ করতে চান?", + "ConfirmDeletion": "মোছার বিষয়টি নিশ্চিত করুন", + "ConfirmDeleteItems": "এই আইটেমগুলি মোছা ফাইল ফাইল এবং আপনার মিডিয়া লাইব্রেরি উভয় থেকে মুছে ফেলা হবে। আপনি কি তাই চান?", + "ConfirmDeleteItem": "এই আইটেমটি মোছার ফলে এটি ফাইল সিস্টেম এবং আপনার মিডিয়া লাইব্রেরি উভয় থেকে মুছে যাবে। আপনি কি তাই চান?", + "ConfirmDeleteImage": "ছবি মুছবেন?", + "Absolute": "গুণাতীত" } From 4a72b02601207ccc487d83c14a7bb3a0541ea383 Mon Sep 17 00:00:00 2001 From: nothing things Date: Fri, 14 Aug 2020 17:19:42 +0000 Subject: [PATCH 243/301] Translated using Weblate (Bengali (Bangladesh)) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/bn_BD/ --- src/strings/bn_BD.json | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/src/strings/bn_BD.json b/src/strings/bn_BD.json index f6082e7268..8d76889291 100644 --- a/src/strings/bn_BD.json +++ b/src/strings/bn_BD.json @@ -101,5 +101,6 @@ "ConfirmDeleteItems": "এই আইটেমগুলি মোছা ফাইল ফাইল এবং আপনার মিডিয়া লাইব্রেরি উভয় থেকে মুছে ফেলা হবে। আপনি কি তাই চান?", "ConfirmDeleteItem": "এই আইটেমটি মোছার ফলে এটি ফাইল সিস্টেম এবং আপনার মিডিয়া লাইব্রেরি উভয় থেকে মুছে যাবে। আপনি কি তাই চান?", "ConfirmDeleteImage": "ছবি মুছবেন?", - "Absolute": "গুণাতীত" + "Absolute": "গুণাতীত", + "CriticRating": "ক্রিটিক রেটিং" } From 9726ec8079a35b75974c48004191c74f154a1f06 Mon Sep 17 00:00:00 2001 From: nothing things Date: Fri, 14 Aug 2020 17:25:03 +0000 Subject: [PATCH 244/301] Translated using Weblate (Bengali (Bangladesh)) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/bn_BD/ --- src/strings/bn_BD.json | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/src/strings/bn_BD.json b/src/strings/bn_BD.json index 8d76889291..b35c836efd 100644 --- a/src/strings/bn_BD.json +++ b/src/strings/bn_BD.json @@ -102,5 +102,12 @@ "ConfirmDeleteItem": "এই আইটেমটি মোছার ফলে এটি ফাইল সিস্টেম এবং আপনার মিডিয়া লাইব্রেরি উভয় থেকে মুছে যাবে। আপনি কি তাই চান?", "ConfirmDeleteImage": "ছবি মুছবেন?", "Absolute": "গুণাতীত", - "CriticRating": "ক্রিটিক রেটিং" + "CriticRating": "ক্রিটিক রেটিং", + "DefaultMetadataLangaugeDescription": "এগুলি আপনার প্রত্যাশিত এবং প্রতি লাইব্রেরির ভিত্তিতে কাস্টমাইজ করা যায়।", + "ErrorDefault": "অনুরোধটি প্রক্রিয়াতে একটি সমস্যা হয়েছে । অনুগ্রহ করে একটু পরে আবার চেষ্টা করুন।", + "Default": "প্রত্যাশিত", + "DeathDateValue": "মৃত: {0}", + "DatePlayed": "তারিখে চলেছে", + "DateAdded": "তারিখে এসেছে", + "CustomDlnaProfilesHelp": "নতুন ডিভাইসের সিস্টেম প্রোফাইল ওভাররাইড করতে একটি কাস্টম প্রোফাইল তৈরি করুন।" } From 157fa25b1d932c3e8f61cb402daef0c639944cd8 Mon Sep 17 00:00:00 2001 From: nothing things Date: Fri, 14 Aug 2020 17:32:56 +0000 Subject: [PATCH 245/301] Translated using Weblate (Bengali (Bangladesh)) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/bn_BD/ --- src/strings/bn_BD.json | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/src/strings/bn_BD.json b/src/strings/bn_BD.json index b35c836efd..2c32123975 100644 --- a/src/strings/bn_BD.json +++ b/src/strings/bn_BD.json @@ -109,5 +109,11 @@ "DeathDateValue": "মৃত: {0}", "DatePlayed": "তারিখে চলেছে", "DateAdded": "তারিখে এসেছে", - "CustomDlnaProfilesHelp": "নতুন ডিভাইসের সিস্টেম প্রোফাইল ওভাররাইড করতে একটি কাস্টম প্রোফাইল তৈরি করুন।" + "CustomDlnaProfilesHelp": "নতুন ডিভাইসের সিস্টেম প্রোফাইল ওভাররাইড করতে একটি কাস্টম প্রোফাইল তৈরি করুন।", + "DeleteImageConfirmation": "আপনি কি নিশ্চিত যে আপনি এই চিত্রটি মুছতে চান?", + "DeleteImage": "ছবি মুছুন", + "DeleteDeviceConfirmation": "আপনি কি নিশ্চিত যে আপনি এই ডিভাইসটি মুছতে চান? এটি পরবর্তীতে ব্যবহারকারীর সাইন ইন করার পর ব্যবহারকারীর সাথে এটি আবার প্রদর্শিত হবে।", + "Delete": "মুছে ফেলুন", + "DeinterlaceMethodHelp": "ইন্টারলেসড কন্টেন্ট ট্রান্সকোড করার সময় ব্যবহারের জন্য ডিএনটারলেসিং পদ্ধতিটি নির্বাচন করুন।", + "DefaultSubtitlesHelp": "এম্বেড থাকা মেটাডেটাতে ডিফল্ট এবং জোর করে দেওয়া ফ্ল্যাগের উপর ভিত্তি করে সাবটাইটেলগুলি লোড করা হয়। ভাষা পছন্দগুলি বিবেচনা করা হয় যখন একাধিক বিকল্প থাকে।" } From dc682bce172f79badedbdeb97440921ff9eca024 Mon Sep 17 00:00:00 2001 From: nothing things Date: Fri, 14 Aug 2020 17:36:50 +0000 Subject: [PATCH 246/301] Translated using Weblate (Bengali (Bangladesh)) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/bn_BD/ --- src/strings/bn_BD.json | 29 ++++++++++++++++++++++++++++- 1 file changed, 28 insertions(+), 1 deletion(-) diff --git a/src/strings/bn_BD.json b/src/strings/bn_BD.json index 2c32123975..e13514fda4 100644 --- a/src/strings/bn_BD.json +++ b/src/strings/bn_BD.json @@ -115,5 +115,32 @@ "DeleteDeviceConfirmation": "আপনি কি নিশ্চিত যে আপনি এই ডিভাইসটি মুছতে চান? এটি পরবর্তীতে ব্যবহারকারীর সাইন ইন করার পর ব্যবহারকারীর সাথে এটি আবার প্রদর্শিত হবে।", "Delete": "মুছে ফেলুন", "DeinterlaceMethodHelp": "ইন্টারলেসড কন্টেন্ট ট্রান্সকোড করার সময় ব্যবহারের জন্য ডিএনটারলেসিং পদ্ধতিটি নির্বাচন করুন।", - "DefaultSubtitlesHelp": "এম্বেড থাকা মেটাডেটাতে ডিফল্ট এবং জোর করে দেওয়া ফ্ল্যাগের উপর ভিত্তি করে সাবটাইটেলগুলি লোড করা হয়। ভাষা পছন্দগুলি বিবেচনা করা হয় যখন একাধিক বিকল্প থাকে।" + "DefaultSubtitlesHelp": "এম্বেড থাকা মেটাডেটাতে ডিফল্ট এবং জোর করে দেওয়া ফ্ল্যাগের উপর ভিত্তি করে সাবটাইটেলগুলি লোড করা হয়। ভাষা পছন্দগুলি বিবেচনা করা হয় যখন একাধিক বিকল্প থাকে।", + "EditSubtitles": "সাবটাইটেল এডিট করুন", + "EditMetadata": "মেটাডেটা এডিট করুন", + "EditImages": "ছবিগুলি এডিট করুন", + "Edit": "এডিট", + "EasyPasswordHelp": "আপনার সহজ পিন কোড সমর্থিত ক্লায়েন্ট অফলাইন অ্যাকসেসের জন্য ব্যবহার করা হয় এছাড়াও সহজ-নেটওয়ার্কে ব্যবহার করা যেতে পারে।", + "DrmChannelsNotImported": "ডিআরএম সহ চ্যানেলগুলি ইম্পোর্ট করা হবে না।", + "DownloadsValue": "{0} ডাউনলোড সমূহ", + "Download": "ডাউনলোড", + "Down": "নিচে", + "DoNotRecord": "রেকর্ড করবেন না", + "DisplayMissingEpisodesWithinSeasonsHelp": "এটি অবশ্যই সার্ভার কনফিগারেশনে টিভি লাইব্রেরির জন্য ইনেবল করতে হবে।", + "DisplayInOtherHomeScreenSections": "সর্বশেষ মিডিয়া হিসাবে হোম স্ক্রিন বিভাগে প্রদর্শন করুন এবং দেখা চালিয়ে যান", + "DisplayInMyMedia": "হোম স্ক্রিনে প্রদর্শন করুন", + "Display": "ডিসপ্লে", + "Dislike": "ডিসলাইক", + "Disconnect": "ডিসকানেক্ট", + "Disc": "ডিস্ক", + "Directors": "পরিচালকবৃন্দ", + "Director": "পরিচালক", + "DirectPlaying": "ডাইরেক্ট প্লেয়িং", + "DetectingDevices": "ডিভাইস সনাক্ত করা হচ্ছে", + "Desktop": "ডেস্কটপ", + "Descending": "ডিসেন্ডিং", + "Depressed": "অবনমিত", + "DeleteUserConfirmation": "আপনি কি নিশ্চিত যে আপনি এই ব্যবহারকারীকে মুছতে চান?", + "DeleteUser": "ব্যবহারকারী মুছুন", + "DeleteMedia": "মিডিয়া মুছুন" } From c91a6195d75af7e78f9479afc72e9cee816a9551 Mon Sep 17 00:00:00 2001 From: Julien Machiels Date: Fri, 14 Aug 2020 20:00:46 +0200 Subject: [PATCH 247/301] Update src/scripts/clientUtils.js Co-authored-by: Cameron --- src/scripts/clientUtils.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/scripts/clientUtils.js b/src/scripts/clientUtils.js index eb3105a0a2..b8ed8c038b 100644 --- a/src/scripts/clientUtils.js +++ b/src/scripts/clientUtils.js @@ -112,7 +112,7 @@ export function processServerConfigurationUpdateResult(result) { ]) .then(([{default: loading}, {default: toast}]) => { loading.hide(); - toast.(Globalize.translate('MessageSettingsSaved')); + toast(Globalize.translate('MessageSettingsSaved')); }); } From e606681872e86d56c9b06da272f4ca184c956b8b Mon Sep 17 00:00:00 2001 From: Julien Machiels Date: Fri, 14 Aug 2020 20:00:57 +0200 Subject: [PATCH 248/301] Update src/scripts/clientUtils.js Co-authored-by: Cameron --- src/scripts/clientUtils.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/scripts/clientUtils.js b/src/scripts/clientUtils.js index b8ed8c038b..bf61bb1dd3 100644 --- a/src/scripts/clientUtils.js +++ b/src/scripts/clientUtils.js @@ -101,7 +101,7 @@ export function processPluginConfigurationUpdateResult() { ]) .then(([{default: loading}, {default: toast}]) => { loading.hide(); - toast.default(Globalize.translate('MessageSettingsSaved')); + toast(Globalize.translate('MessageSettingsSaved')); }); } From afa56c18af901acf49fccb96db3ad58c7cc82daa Mon Sep 17 00:00:00 2001 From: Jeff Sharkey Date: Fri, 22 May 2020 22:23:18 -0600 Subject: [PATCH 249/301] Support for faster playback rates. The HTML5 video element already has a well-supported "playbackRate" attribute which can be used to increase playback rate. This change wires up that control to be displayed in the Jellyfish web player. The playback rates offered are between 0.5x and 2x in 0.25x increments, which matches the YouTube player. This change also wires up the ">" and "<" key events to increase and decrease the playback rate, which mirrors the keyboard shortcuts supported by YouTube. --- src/components/playback/playbackmanager.js | 49 +++++++++++++++++++ src/components/playback/playersettingsmenu.js | 35 +++++++++++++ src/controllers/playback/video/index.js | 6 +++ src/plugins/htmlVideoPlayer/plugin.js | 25 ++++++++++ src/scripts/inputManager.js | 6 +++ src/strings/en-us.json | 1 + 6 files changed, 122 insertions(+) diff --git a/src/components/playback/playbackmanager.js b/src/components/playback/playbackmanager.js index 8502b551af..96268a51d9 100644 --- a/src/components/playback/playbackmanager.js +++ b/src/components/playback/playbackmanager.js @@ -1112,6 +1112,52 @@ class PlaybackManager { } }; + self.increasePlaybackRate = function (player) { + player = player || self._currentPlayer; + if (player) { + let current = self.getPlaybackRate(player); + let supported = self.getSupportedPlaybackRates(player); + + let index = -1; + for (let i = 0, length = supported.length; i < length; i++) { + if (supported[i].id === current) { + index = i; + break; + } + } + + index = Math.min(index + 1, supported.length - 1); + self.setPlaybackRate(supported[index].id, player); + } + }; + + self.decreasePlaybackRate = function (player) { + player = player || self._currentPlayer; + if (player) { + let current = self.getPlaybackRate(player); + let supported = self.getSupportedPlaybackRates(player); + + let index = -1; + for (let i = 0, length = supported.length; i < length; i++) { + if (supported[i].id === current) { + index = i; + break; + } + } + + index = Math.max(index - 1, 0); + self.setPlaybackRate(supported[index].id, player); + } + }; + + self.getSupportedPlaybackRates = function (player) { + player = player || self._currentPlayer; + if (player && player.getSupportedPlaybackRates) { + return player.getSupportedPlaybackRates(); + } + return []; + }; + let brightnessOsdLoaded; self.setBrightness = function (val, player) { player = player || self._currentPlayer; @@ -3697,6 +3743,9 @@ class PlaybackManager { case 'SetAspectRatio': this.setAspectRatio(cmd.Arguments.AspectRatio, player); break; + case 'PlaybackRate': + this.setPlaybackRate(cmd.Arguments.PlaybackRate, player); + break; case 'SetBrightness': this.setBrightness(cmd.Arguments.Brightness, player); break; diff --git a/src/components/playback/playersettingsmenu.js b/src/components/playback/playersettingsmenu.js index 71dd7a86ff..cd227afcb4 100644 --- a/src/components/playback/playersettingsmenu.js +++ b/src/components/playback/playersettingsmenu.js @@ -149,6 +149,28 @@ function showAspectRatioMenu(player, btn) { }); } +function showPlaybackRateMenu(player, btn) { + // each has a name and id + const currentId = playbackManager.getPlaybackRate(player); + const menuItems = playbackManager.getSupportedPlaybackRates(player).map(i => ({ + id: i.id, + name: i.name, + selected: i.id === currentId + })); + + return actionsheet.show({ + items: menuItems, + positionTo: btn + }).then(function (id) { + if (id) { + playbackManager.setPlaybackRate(id, player); + return Promise.resolve(); + } + + return Promise.reject(); + }); +} + function showWithUser(options, player, user) { var supportedCommands = playbackManager.getSupportedCommands(player); @@ -166,6 +188,17 @@ function showWithUser(options, player, user) { }); } + if (supportedCommands.indexOf('PlaybackRate') !== -1) { + const currentPlaybackRateId = playbackManager.getPlaybackRate(player); + const currentPlaybackRate = playbackManager.getSupportedPlaybackRates(player).filter(i => i.id === currentPlaybackRateId)[0]; + + menuItems.push({ + name: globalize.translate('PlaybackRate'), + id: 'playbackrate', + asideText: currentPlaybackRate ? currentPlaybackRate.name : null + }); + } + if (user && user.Policy.EnableVideoPlaybackTranscoding) { var secondaryQualityText = getQualitySecondaryText(player); @@ -230,6 +263,8 @@ function handleSelectedOption(id, options, player) { return showQualityMenu(player, options.positionTo); case 'aspectratio': return showAspectRatioMenu(player, options.positionTo); + case 'playbackrate': + return showPlaybackRateMenu(player, options.positionTo); case 'repeatmode': return showRepeatModeMenu(player, options.positionTo); case 'stats': diff --git a/src/controllers/playback/video/index.js b/src/controllers/playback/video/index.js index 73540cd636..ea84b9c3f5 100644 --- a/src/controllers/playback/video/index.js +++ b/src/controllers/playback/video/index.js @@ -1243,6 +1243,12 @@ import 'css!assets/css/videoosd'; } break; } + case '>': + playbackManager.increasePlaybackRate(currentPlayer); + break; + case '<': + playbackManager.decreasePlaybackRate(currentPlayer); + break; } } diff --git a/src/plugins/htmlVideoPlayer/plugin.js b/src/plugins/htmlVideoPlayer/plugin.js index ba497729bb..33f15a741f 100644 --- a/src/plugins/htmlVideoPlayer/plugin.js +++ b/src/plugins/htmlVideoPlayer/plugin.js @@ -1634,6 +1634,31 @@ function tryRemoveElement(elem) { return null; } + getSupportedPlaybackRates() { + return [{ + name: '0.5x', + id: 0.5 + }, { + name: '0.75x', + id: 0.75 + }, { + name: '1x', + id: 1.0 + }, { + name: '1.25x', + id: 1.25 + }, { + name: '1.5x', + id: 1.5 + }, { + name: '1.75x', + id: 1.75 + }, { + name: '2x', + id: 2.0 + }]; + } + setVolume(val) { const mediaElement = this.#mediaElement; if (mediaElement) { diff --git a/src/scripts/inputManager.js b/src/scripts/inputManager.js index 077af39bf7..baa3deb0aa 100644 --- a/src/scripts/inputManager.js +++ b/src/scripts/inputManager.js @@ -185,6 +185,12 @@ import appHost from 'apphost'; 'changezoom': () => { playbackManager.toggleAspectRatio(); }, + 'increaseplaybackrate': () => { + playbackManager.increasePlaybackRate(); + }, + 'decreaseplaybackrate': () => { + playbackManager.decreasePlaybackRate(); + }, 'changeaudiotrack': () => { playbackManager.changeAudioStream(); }, diff --git a/src/strings/en-us.json b/src/strings/en-us.json index 0f37014b76..38b79613e2 100644 --- a/src/strings/en-us.json +++ b/src/strings/en-us.json @@ -1220,6 +1220,7 @@ "Play": "Play", "PlayAllFromHere": "Play all from here", "PlaybackData": "Playback Data", + "PlaybackRate": "Playback Rate", "PlayCount": "Play count", "PlayFromBeginning": "Play from beginning", "PlayNext": "Play next", From 7c211e68e63c327439bc759d96d0a0220cd8530f Mon Sep 17 00:00:00 2001 From: "dependabot-preview[bot]" <27856297+dependabot-preview[bot]@users.noreply.github.com> Date: Sat, 15 Aug 2020 01:15:43 +0000 Subject: [PATCH 250/301] Bump eslint from 7.6.0 to 7.7.0 Bumps [eslint](https://github.com/eslint/eslint) from 7.6.0 to 7.7.0. - [Release notes](https://github.com/eslint/eslint/releases) - [Changelog](https://github.com/eslint/eslint/blob/master/CHANGELOG.md) - [Commits](https://github.com/eslint/eslint/compare/v7.6.0...v7.7.0) Signed-off-by: dependabot-preview[bot] --- package.json | 2 +- yarn.lock | 20 +++++--------------- 2 files changed, 6 insertions(+), 16 deletions(-) diff --git a/package.json b/package.json index 27508faa1b..fb3c2dbd30 100644 --- a/package.json +++ b/package.json @@ -20,7 +20,7 @@ "css-loader": "^4.2.1", "cssnano": "^4.1.10", "del": "^5.1.0", - "eslint": "^7.6.0", + "eslint": "^7.7.0", "eslint-plugin-compat": "^3.5.1", "eslint-plugin-eslint-comments": "^3.2.0", "eslint-plugin-import": "^2.21.2", diff --git a/yarn.lock b/yarn.lock index 269b3b93cd..b507238470 100644 --- a/yarn.lock +++ b/yarn.lock @@ -1293,17 +1293,7 @@ ajv-keywords@^3.1.0, ajv-keywords@^3.4.1: resolved "https://registry.yarnpkg.com/ajv-keywords/-/ajv-keywords-3.4.1.tgz#ef916e271c64ac12171fd8384eaae6b2345854da" integrity sha512-RO1ibKvd27e6FEShVFfPALuHI3WjSVNeK5FIsmme/LYRNxjKuNj+Dt7bucLa6NdSv3JcVTyMlm9kGR84z1XpaQ== -ajv@^6.1.0, ajv@^6.12.2, ajv@^6.5.5: - version "6.12.2" - resolved "https://registry.yarnpkg.com/ajv/-/ajv-6.12.2.tgz#c629c5eced17baf314437918d2da88c99d5958cd" - integrity sha512-k+V+hzjm5q/Mr8ef/1Y9goCmlsK4I6Sm74teeyGvFk1XrOsbsKLjEdrvny42CZ+a8sXbk8KWpY/bDwS+FLL2UQ== - dependencies: - fast-deep-equal "^3.1.1" - fast-json-stable-stringify "^2.0.0" - json-schema-traverse "^0.4.1" - uri-js "^4.2.2" - -ajv@^6.10.0, ajv@^6.10.2: +ajv@^6.1.0, ajv@^6.10.0, ajv@^6.10.2, ajv@^6.12.2, ajv@^6.5.5: version "6.12.3" resolved "https://registry.yarnpkg.com/ajv/-/ajv-6.12.3.tgz#18c5af38a111ddeb4f2697bd78d68abc1cabd706" integrity sha512-4K0cK3L1hsqk9xIb2z9vs/XU+PGJZ9PNpJRDS9YLzmNdX6jmVPfamLvTJr0aDAusnHyCHO6MjzlkAsgtqp9teA== @@ -4044,10 +4034,10 @@ eslint-visitor-keys@^1.1.0, eslint-visitor-keys@^1.3.0: resolved "https://registry.yarnpkg.com/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz#30ebd1ef7c2fdff01c3a4f151044af25fab0523e" integrity sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ== -eslint@^7.6.0: - version "7.6.0" - resolved "https://registry.yarnpkg.com/eslint/-/eslint-7.6.0.tgz#522d67cfaea09724d96949c70e7a0550614d64d6" - integrity sha512-QlAManNtqr7sozWm5TF4wIH9gmUm2hE3vNRUvyoYAa4y1l5/jxD/PQStEjBMQtCqZmSep8UxrcecI60hOpe61w== +eslint@^7.7.0: + version "7.7.0" + resolved "https://registry.yarnpkg.com/eslint/-/eslint-7.7.0.tgz#18beba51411927c4b64da0a8ceadefe4030d6073" + integrity sha512-1KUxLzos0ZVsyL81PnRN335nDtQ8/vZUD6uMtWbF+5zDtjKcsklIi78XoE0MVL93QvWTu+E5y44VyyCsOMBrIg== dependencies: "@babel/code-frame" "^7.0.0" ajv "^6.10.0" From de3a1646b0c5e6ceb6a70473ad7ede709fe2f0ee Mon Sep 17 00:00:00 2001 From: Oatavandi Date: Sat, 15 Aug 2020 07:27:09 +0000 Subject: [PATCH 251/301] Translated using Weblate (Tamil) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/ta/ --- src/strings/ta.json | 18 +++++++++++++++++- 1 file changed, 17 insertions(+), 1 deletion(-) diff --git a/src/strings/ta.json b/src/strings/ta.json index e3bd7a66af..c07bf68bbc 100644 --- a/src/strings/ta.json +++ b/src/strings/ta.json @@ -506,5 +506,21 @@ "HeaderStartNow": "இப்போதே துவக்கு", "HeaderSpecialFeatures": "சிறப்பு அம்சங்கள்", "HeaderSpecialEpisodeInfo": "சிறப்பு எபிசோட் தகவல்", - "HeaderSortOrder": "வரிசைப்படுத்து வரிசை" + "HeaderSortOrder": "வரிசைப்படுத்து வரிசை", + "LabelAccessStart": "ஆரம்பிக்கும் நேரம்:", + "LabelAccessEnd": "இறுதி நேரம்:", + "LabelAccessDay": "வாரத்தின் நாள்:", + "LabelAbortedByServerShutdown": "(சேவையக பணிநிறுத்தத்தால் கைவிடப்பட்டது)", + "Label3DFormat": "3D வடிவம்:", + "Kids": "குழந்தைகள்", + "Items": "உருப்படிகள்", + "ItemCount": "{0} உருப்படிகள்", + "InstantMix": "உடனடி கலவை", + "InstallingPackage": "{0} (பதிப்பு {1}) ஐ நிறுவுகிறது", + "ImportMissingEpisodesHelp": "காணாமல் போன அத்தியாயங்கள் பற்றிய தகவல்கள் உங்கள் தரவுத்தளத்தில் இறக்குமதி செய்யப்பட்டு பருவங்கள் மற்றும் தொடர்களில் காண்பிக்கப்படும். இது கணிசமாக நீண்ட நூலக ஸ்கேன்களை ஏற்படுத்தக்கூடும்.", + "ImportFavoriteChannelsHelp": "ட்யூனர் சாதனத்தில் பிடித்ததாகக் குறிக்கப்பட்ட சேனல்கள் மட்டுமே இறக்குமதி செய்யப்படும்.", + "Images": "படங்கள்", + "Identify": "அடையாளம் காணவும்", + "HttpsRequiresCert": "பாதுகாப்பான இணைப்புகளை இயக்க, நீங்கள் மறைகுறியாக்கம் போன்ற நம்பகமான SSL சான்றிதழை வழங்க வேண்டும். தயவுசெய்து ஒரு சான்றிதழை வழங்கவும் அல்லது பாதுகாப்பான இணைப்புகளை முடக்கவும்.", + "Horizontal": "கிடைமட்ட" } From b408ff53314c3084f59b579af25ba678b176e96c Mon Sep 17 00:00:00 2001 From: millallo Date: Sat, 15 Aug 2020 07:49:10 +0000 Subject: [PATCH 252/301] Translated using Weblate (Italian) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/it/ --- src/strings/it.json | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/strings/it.json b/src/strings/it.json index 758cb25f6e..cb73ea2cdb 100644 --- a/src/strings/it.json +++ b/src/strings/it.json @@ -20,7 +20,7 @@ "AllowHWTranscodingHelp": "Abilita il sintonizzatore per codificare i flussi al volo. Ciò potrebbe contribuire a ridurre la transcodifica richiesta dal server.", "AllowOnTheFlySubtitleExtraction": "Consenti l'estrazione sottotitoli al volo", "AllowOnTheFlySubtitleExtractionHelp": "I sottotitoli incorporati possono essere estratti dai video e consegnati ai client in testo semplice per evitare la transcodifica dei video. In alcuni sistemi questo può richiedere molto tempo e causare un rallentamento della riproduzione video durante il processo di estrazione. Disattivare questa opzione per avere i sottotitoli incorporati con la transcodifica video quando non sono supportati nativamente dal dispositivo client.", - "AllowRemoteAccess": "Abilita connessioni remote a questo Server Jellyfin.", + "AllowRemoteAccess": "Abilita connessioni remote a questo server.", "AllowRemoteAccessHelp": "Se deselezionato, tutte le connessioni remote saranno bloccate.", "AllowedRemoteAddressesHelp": "Elenco separato da virgola di indirizzi IP o voci IP / maschera di rete per reti che potranno connettersi da remoto. Se lasciato vuoto, saranno consentiti tutti gli indirizzi remoti.", "AlwaysPlaySubtitles": "Riproduci sempre", @@ -110,7 +110,7 @@ "ColorTransfer": "Trasferimento Colore", "CommunityRating": "Voto del pubblico", "Composer": "Compositore", - "ConfigureDateAdded": "Scegli come determinare la data di aggiunta dal pannello di controllo del Server Jellyfin, nelle impostazioni della Libreria", + "ConfigureDateAdded": "Scegli come determinare la data di aggiunta dal pannello di controllo nelle impostazioni della libreria", "ConfirmDeleteImage": "Elimina immagine?", "ConfirmDeleteItem": "L'eliminazione di questo elemento lo cancellerà sia dal disco che dalla libreria multimediale. Sei sicuro di voler continuare?", "ConfirmDeleteItems": "L'eliminazione di questi elementi li cancellerà sia dal disco che dalla tua libreria multimediale. Sei sicuro di voler continuare?", @@ -187,7 +187,7 @@ "EndsAtValue": "Finirà alle {0}", "Episodes": "Episodi", "ErrorAddingListingsToSchedulesDirect": "C'è stato un errore nell'aggiunta della tua lista all'account Schedules Direct.\nSchedules Direct permette solo un numero limitato di selezioni per account. Potresti aver bisogno di accedere al sito Schedules Direct e rimuoverne alcune prima di procedere.", - "ErrorAddingMediaPathToVirtualFolder": "C'è stato un errore durante l'aggiunta del percorso. Per favore controlla che il percorso sia valido, e che Jellyfin Server abbia l'accesso alla posizione indicata.", + "ErrorAddingMediaPathToVirtualFolder": "C'è stato un errore durante l'aggiunta del percorso. Per favore controlla che il percorso sia valido, e che Jellyfin abbia l'accesso alla posizione indicata.", "ErrorAddingTunerDevice": "Si è verificato un errore durante l'aggiunta del sintonizzatore. Si prega di assicurarsi che sia accessibile e riprovare.", "ErrorAddingXmlTvFile": "Si è verificato un errore durante l'accesso al file XMLTV. Si prega di assicurarsi che il file esista e riprovare.", "ErrorDeletingItem": "Si è verificato un errore durante l'eliminazione dell'elemento da Jellyfin Server. Verifica che Jellyfin Server abbia accesso in scrittura sulla cartella multimediale e riprova.", From 882ede13bd5b3f7f21de168bdf8e32e6e99259f3 Mon Sep 17 00:00:00 2001 From: Oatavandi Date: Sat, 15 Aug 2020 08:05:45 +0000 Subject: [PATCH 253/301] Translated using Weblate (Tamil) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/ta/ --- src/strings/ta.json | 39 ++++++++++++++++++++++++++++++++++++++- 1 file changed, 38 insertions(+), 1 deletion(-) diff --git a/src/strings/ta.json b/src/strings/ta.json index c07bf68bbc..1e490e6969 100644 --- a/src/strings/ta.json +++ b/src/strings/ta.json @@ -522,5 +522,42 @@ "Images": "படங்கள்", "Identify": "அடையாளம் காணவும்", "HttpsRequiresCert": "பாதுகாப்பான இணைப்புகளை இயக்க, நீங்கள் மறைகுறியாக்கம் போன்ற நம்பகமான SSL சான்றிதழை வழங்க வேண்டும். தயவுசெய்து ஒரு சான்றிதழை வழங்கவும் அல்லது பாதுகாப்பான இணைப்புகளை முடக்கவும்.", - "Horizontal": "கிடைமட்ட" + "Horizontal": "கிடைமட்ட", + "LabelBlockContentWithTags": "குறிச்சொற்களைக் கொண்ட உருப்படிகளைத் தடு:", + "LabelBlastMessageIntervalHelp": "உயிருள்ள செய்திகளுக்கு இடையில் வினாடிகளில் கால அளவை தீர்மானிக்கிறது.", + "LabelBlastMessageInterval": "உயிருள்ள செய்தி இடைவெளி", + "LabelBitrate": "பிட்ரேட்:", + "LabelBirthYear": "பிறந்த வருடம்:", + "LabelBirthDate": "பிறந்த தேதி:", + "LabelBindToLocalNetworkAddressHelp": "HTTP சேவையகத்திற்கான உள்ளூர் ஐபி முகவரியை மேலெழுதவும். காலியாக இருந்தால், கிடைக்கக்கூடிய எல்லா முகவரிகளுடனும் சேவையகம் பிணைக்கப்படும். இந்த மதிப்பை மாற்ற மறுதொடக்கம் தேவை.", + "LabelBindToLocalNetworkAddress": "உள்ளூர் பிணைய முகவரியுடன் பிணைக்கவும்:", + "LabelAutomaticallyRefreshInternetMetadataEvery": "இணையத்திலிருந்து மெட்டாடேட்டாவை தானாக புதுப்பிக்கவும்:", + "LabelAuthProvider": "அங்கீகார வழங்குநர்:", + "LabelAudioSampleRate": "ஆடியோ மாதிரி வீதம்:", + "LabelAudioLanguagePreference": "விருப்பமான ஆடியோ மொழி:", + "LabelAudioCodec": "ஆடியோ கோடெக்:", + "LabelAudioChannels": "ஆடியோ சேனல்கள்:", + "LabelAudioBitrate": "ஆடியோ பிட்ரேட்:", + "LabelAudioBitDepth": "ஆடியோ பிட் ஆழம்:", + "LabelAudio": "ஆடியோ", + "LabelArtistsHelp": "அரைக்காற்புள்ளியுடன் பல கலைஞர்களைப் பிரிக்கவும்.", + "LabelArtists": "கலைஞர்கள்:", + "LabelAppNameExample": "எடுத்துக்காட்டு: Sickbeard, Sonarr", + "LabelAppName": "பயன்பாட்டின் பெயர்", + "LabelAllowedRemoteAddressesMode": "தொலை ஐபி முகவரி வடிகட்டி பயன்முறை:", + "LabelAllowedRemoteAddresses": "தொலை ஐபி முகவரி வடிப்பான்:", + "LabelAllowHWTranscoding": "வன்பொருள் டிரான்ஸ்கோடிங்கை அனுமதிக்கவும்", + "LabelAlbumArtists": "ஆல்பம் கலைஞர்கள்:", + "LabelAlbumArtPN": "ஆல்பம் படம் PN:", + "LabelAlbumArtMaxWidthHelp": "ஆல்பம் படத்தின் அதிகபட்ச தெளிவுத்திறன் upnp வழியாக வெளிப்படுத்தப்படுகிறது: albumArtURI.", + "LabelAlbumArtMaxWidth": "ஆல்பம் படம் அதிகபட்ச அகலம்:", + "LabelAlbumArtMaxHeightHelp": "ஆல்பம் படத்தின் அதிகபட்ச தெளிவுத்திறன் upnp வழியாக வெளிப்படுத்தப்படுகிறது: albumArtURI.", + "LabelAlbumArtMaxHeight": "ஆல்பம் படம் அதிகபட்ச உயரம்:", + "LabelAlbumArtHelp": "ஆல்பம் கலைக்கு PN பயன்படுத்தப்படுகிறது, dlna: profileID பண்புக்கூறு upnp: albumArtURI. சில சாதனங்களுக்கு படத்தின் அளவைப் பொருட்படுத்தாமல் ஒரு குறிப்பிட்ட மதிப்பு தேவைப்படுகிறது.", + "LabelAlbum": "ஆல்பம்:", + "LabelAirsBeforeSeason": "பருவத்திற்கு முன் ஒளிபரப்பாகிறது:", + "LabelAirsBeforeEpisode": "அத்தியாயத்திற்கு முன் ஒளிபரப்பாகிறது:", + "LabelAirsAfterSeason": "பருவத்திற்குப் பிறகு ஒளிபரப்பாகிறது:", + "LabelAirTime": "ஒளிபரப்பப்பட்ட நேரம்:", + "LabelAirDays": "ஒளிபரப்பப்பட்ட நாட்கள்:" } From 78e64420fef7e1f1bc28da505acf514ec2028ab1 Mon Sep 17 00:00:00 2001 From: Oatavandi Date: Sat, 15 Aug 2020 08:39:24 +0000 Subject: [PATCH 254/301] Translated using Weblate (Tamil) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/ta/ --- src/strings/ta.json | 57 ++++++++++++++++++++++++++++++++++++++++++--- 1 file changed, 54 insertions(+), 3 deletions(-) diff --git a/src/strings/ta.json b/src/strings/ta.json index 1e490e6969..36eb028372 100644 --- a/src/strings/ta.json +++ b/src/strings/ta.json @@ -24,10 +24,10 @@ "AllowFfmpegThrottlingHelp": "ஒரு டிரான்ஸ்கோட் அல்லது ரீமக்ஸ் தற்போதைய பின்னணி நிலையிலிருந்து வெகு தொலைவில் இருக்கும்போது, செயல்முறையை இடைநிறுத்துங்கள், இதனால் அது குறைந்த ஆதாரங்களை நுகரும். அடிக்கடி தேடாமல் பார்க்கும்போது இது மிகவும் பயனுள்ளதாக இருக்கும். பின்னணி சிக்கல்களை நீங்கள் சந்தித்தால் இதை அணைக்கவும்.", "AllowFfmpegThrottling": "திராட்டில் ட்ரான்ஸ்கோட்கள்", "AllowOnTheFlySubtitleExtractionHelp": "வீடியோ டிரான்ஸ்கோடிங்கைத் தடுக்க உதவும் வகையில் உட்பொதிக்கப்பட்ட வசனங்களை வீடியோக்களிலிருந்து பிரித்தெடுத்து வாடிக்கையாளர்களுக்கு எளிய உரையில் வழங்கலாம். சில கணினிகளில் இது நீண்ட நேரம் எடுக்கும் மற்றும் பிரித்தெடுக்கும் செயல்பாட்டின் போது வீடியோ பிளேபேக் நிறுத்தப்படும். கிளையன்ட் சாதனத்தால் பூர்வீகமாக ஆதரிக்கப்படாதபோது உட்பொதிக்கப்பட்ட வசன வரிகள் வீடியோ டிரான்ஸ்கோடிங்கில் எரிக்கப்படுவதை முடக்கு.", - "AllowOnTheFlySubtitleExtraction": "பறக்கையில் வசன வரிகள் பிரித்தெடுக்க அனுமதிக்கவும்", + "AllowOnTheFlySubtitleExtraction": "வசன வரிகள் பிரித்தெடுக்க அனுமதிக்கவும்", "AllowMediaConversionHelp": "மாற்றும் ஊடக அம்சத்திற்கான அணுகலை வழங்கவும் அல்லது மறுக்கவும்.", "AllowMediaConversion": "ஊடக மாற்றத்தை அனுமதிக்கவும்", - "AllowHWTranscodingHelp": "ட்யூனரை பறக்கும்போது ஸ்ட்ரீம்களை டிரான்ஸ்கோட் செய்ய அனுமதிக்கவும். இது சேவையகத்திற்கு தேவையான டிரான்ஸ்கோடிங்கைக் குறைக்க உதவும்.", + "AllowHWTranscodingHelp": "ட்யூனரை பயன்படுத்தும்போது ஸ்ட்ரீம்களை டிரான்ஸ்கோட் செய்ய அனுமதிக்கவும். இது சேவையகத்திற்கு தேவையான டிரான்ஸ்கோடிங்கைக் குறைக்க உதவும்.", "AllLibraries": "அனைத்து நூலகங்களும்", "AllLanguages": "அனைத்து மொழிகளையும்", "AllEpisodes": "எல்லா அத்தியாயங்களும்", @@ -559,5 +559,56 @@ "LabelAirsBeforeEpisode": "அத்தியாயத்திற்கு முன் ஒளிபரப்பாகிறது:", "LabelAirsAfterSeason": "பருவத்திற்குப் பிறகு ஒளிபரப்பாகிறது:", "LabelAirTime": "ஒளிபரப்பப்பட்ட நேரம்:", - "LabelAirDays": "ஒளிபரப்பப்பட்ட நாட்கள்:" + "LabelAirDays": "ஒளிபரப்பப்பட்ட நாட்கள்:", + "LabelEmbedAlbumArtDidl": "Didlல் ஆல்பம் கலையை உட்பொதிக்கவும்", + "LabelEasyPinCode": "எளிதாக பின் குறியீடு:", + "LabelDynamicExternalId": "{0} ஐடி:", + "LabelDropShadow": "வீழ்நிழல்:", + "LabelDroppedFrames": "கைவிடப்பட்ட பிரேம்கள்:", + "LabelDropImageHere": "படத்தை இங்கே இணைக்கவும் அல்லது உலவ கிளிக் செய்யவும்.", + "LabelDownloadLanguages": "மொழிகளைப் பதிவிறக்குங்கள்:", + "LabelDownMixAudioScaleHelp": "குறைக்கும் போது ஆடியோவை அதிகரிக்கவும். ஒன்றின் மதிப்பு அசல் ஒலி அளவை பாதுகாக்கும்.", + "LabelDownMixAudioScale": "குறைக்கும் போது ஆடியோ ஏற்றம்:", + "LabelDisplaySpecialsWithinSeasons": "அவர்கள் ஒளிபரப்பிய பருவங்களுக்குள் சிறப்புகளைக் காண்பி", + "LabelDisplayOrder": "காட்சி வரிசை:", + "LabelDisplayName": "காட்சி பெயர்:", + "LabelDisplayMode": "காட்சி முறை:", + "LabelDisplayMissingEpisodesWithinSeasons": "காணாமல் போன அத்தியாயங்களை பருவங்களுக்குள் காண்பி", + "LabelDisplayLanguageHelp": "ஜெல்லிஃபின் மொழிபெயர்ப்பது ஒரு தொடர்ச்சியான திட்டம்.", + "LabelDisplayLanguage": "காட்சி மொழி:", + "LabelDiscNumber": "வட்டு எண்:", + "LabelDidlMode": "DIDL பயன்முறை:", + "LabelDeviceDescription": "சாதன விளக்கம்", + "LabelDeinterlaceMethod": "நீக்குதல் முறை:", + "LabelDefaultUserHelp": "இணைக்கப்பட்ட சாதனங்களில் எந்த பயனர் நூலகம் காட்டப்பட வேண்டும் என்பதை தீர்மானிக்கிறது. சுயவிவரங்களைப் பயன்படுத்தி ஒவ்வொரு சாதனத்திற்கும் இது மேலெழுதப்படலாம்.", + "LabelDefaultUser": "இயல்புநிலை பயனர்:", + "LabelDefaultScreen": "இயல்புநிலை திரை:", + "LabelDeathDate": "இறப்பு தேதி:", + "LabelDay": "நாள்:", + "LabelDateTimeLocale": "தேதி நேர இடம்:", + "LabelDateAddedBehaviorHelp": "ஒரு மெட்டாடேட்டா மதிப்பு இருந்தால், இந்த விருப்பங்களில் ஒன்றுக்கு முன்பே இது எப்போதும் பயன்படுத்தப்படும்.", + "LabelDateAddedBehavior": "புதிய உள்ளடக்கத்திற்கான தேதி சேர்க்கப்பட்ட நடத்தை:", + "LabelDateAdded": "சேர்க்கப்பட்ட தேதி:", + "LabelCustomRating": "தனிப்பயன் மதிப்பீடு:", + "LabelCustomDeviceDisplayNameHelp": "தனிப்பயன் காட்சி பெயரை வழங்கவும் அல்லது சாதனத்தால் புகாரளிக்கப்பட்ட பெயரைப் பயன்படுத்த காலியாக விடவும்.", + "LabelCustomDeviceDisplayName": "காட்சி பெயர்:", + "LabelCustomCssHelp": "வலை இடைமுகத்தில் உங்கள் சொந்த தனிப்பயன் பாணிகளைப் பயன்படுத்துங்கள்.", + "LabelCustomCss": "தனிப்பயன் CSS:", + "LabelCustomCertificatePathHelp": "தனிப்பயன் களத்தில் TLS ஆதரவை இயக்க சான்றிதழ் மற்றும் தனிப்பட்ட விசையைக் கொண்ட PKCS # 12 கோப்பிற்கான பாதை.", + "LabelCustomCertificatePath": "தனிப்பயன் SSL சான்றிதழ் பாதை:", + "LabelCurrentPassword": "தற்போதைய கடவுச்சொல்:", + "LabelCriticRating": "விமர்சன மதிப்பீடு:", + "LabelCountry": "நாடு:", + "LabelCorruptedFrames": "சிதைந்த பிரேம்கள்:", + "LabelContentType": "உள்ளடக்க வகை:", + "LabelCommunityRating": "சமூக மதிப்பீடு:", + "LabelCollection": "தொகுப்பு:", + "LabelChannels": "சேனல்கள்:", + "LabelCertificatePasswordHelp": "உங்கள் சான்றிதழுக்கு கடவுச்சொல் தேவைப்பட்டால், அதை இங்கே உள்ளிடவும்.", + "LabelCertificatePassword": "சான்றிதழ் கடவுச்சொல்:", + "LabelCancelled": "ரத்து செய்யப்பட்டது", + "LabelCachePathHelp": "படங்கள் போன்ற சேவையக தற்காலிக சேமிப்பு கோப்புகளுக்கான தனிப்பயன் இருப்பிடத்தைக் குறிப்பிடவும். சேவையக இயல்புநிலையைப் பயன்படுத்த காலியாக விடவும்.", + "LabelCachePath": "தற்காலிக சேமிப்பு பாதை:", + "LabelCache": "தற்காலிக சேமிப்பு:", + "LabelBurnSubtitles": "வசன வரிகள் பதிக்க:" } From 1e35883943b3805727a9c2a7f4a12525d81da8eb Mon Sep 17 00:00:00 2001 From: Oatavandi Date: Sat, 15 Aug 2020 09:02:57 +0000 Subject: [PATCH 255/301] Translated using Weblate (Tamil) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/ta/ --- src/strings/ta.json | 156 +++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 155 insertions(+), 1 deletion(-) diff --git a/src/strings/ta.json b/src/strings/ta.json index 36eb028372..48c82a6eee 100644 --- a/src/strings/ta.json +++ b/src/strings/ta.json @@ -610,5 +610,159 @@ "LabelCachePathHelp": "படங்கள் போன்ற சேவையக தற்காலிக சேமிப்பு கோப்புகளுக்கான தனிப்பயன் இருப்பிடத்தைக் குறிப்பிடவும். சேவையக இயல்புநிலையைப் பயன்படுத்த காலியாக விடவும்.", "LabelCachePath": "தற்காலிக சேமிப்பு பாதை:", "LabelCache": "தற்காலிக சேமிப்பு:", - "LabelBurnSubtitles": "வசன வரிகள் பதிக்க:" + "LabelBurnSubtitles": "வசன வரிகள் பதிக்க:", + "LabelPleaseRestart": "வலை கிளையண்டை கைமுறையாக மீண்டும் ஏற்றிய பிறகு மாற்றங்கள் நடைமுறைக்கு வரும்.", + "LabelPlayMethod": "விளையாட்டு முறை:", + "LabelPlaylist": "பிளேலிஸ்ட்:", + "LabelPlayerDimensions": "பிளேயர் பரிமாணங்கள்:", + "LabelPlayer": "பிளேயர்:", + "LabelPlayDefaultAudioTrack": "மொழியைப் பொருட்படுத்தாமல் இயல்புநிலை ஆடியோ டிராக்கை இயக்கு", + "LabelPlaceOfBirth": "பிறந்த இடம்:", + "LabelPersonRoleHelp": "எடுத்துக்காட்டு: ஐஸ்கிரீம் டிரக் டிரைவர்", + "LabelPersonRole": "பங்கு:", + "LabelPath": "பாதை:", + "LabelPasswordRecoveryPinCode": "அஞ்சல் குறியீடு:", + "LabelPasswordResetProvider": "கடவுச்சொல் மீட்டமை வழங்குநர்:", + "LabelPasswordConfirm": "கடவுச்சொல் (உறுதிப்படுத்து):", + "LabelPassword": "கடவுச்சொல்:", + "LabelParentalRating": "பெற்றோர் மதிப்பீடு:", + "LabelParentNumber": "பெற்றோர் எண்:", + "LabelOverview": "கண்ணோட்டம்:", + "LabelOriginalTitle": "அசல் தலைப்பு:", + "LabelOriginalAspectRatio": "அசல் விகித விகிதம்:", + "LabelOptionalNetworkPathHelp": "இந்த கோப்புறை உங்கள் பிணையத்தில் பகிரப்பட்டால், பிணைய பகிர்வு பாதையை வழங்குவது பிற சாதனங்களில் உள்ள வாடிக்கையாளர்களுக்கு மீடியா கோப்புகளை நேரடியாக அணுக அனுமதிக்கும். எடுத்துக்காட்டாக, {0} அல்லது {1}.", + "LabelOptionalNetworkPath": "பகிரப்பட்ட பிணைய கோப்புறை:", + "LabelNumberOfGuideDaysHelp": "வழிகாட்டி தரவின் அதிக நாட்கள் பதிவிறக்குவது முன்கூட்டியே திட்டமிடவும் மேலும் பட்டியல்களைக் காணவும் திறனை வழங்குகிறது, ஆனால் பதிவிறக்குவதற்கு அதிக நேரம் எடுக்கும். சேனல்களின் எண்ணிக்கையின் அடிப்படையில் ஆட்டோ தேர்வு செய்யும்.", + "LabelNumberOfGuideDays": "பதிவிறக்க வழிகாட்டி தரவின் நாட்களின் எண்ணிக்கை:", + "LabelNumber": "எண்:", + "LabelNotificationEnabled": "இந்த அறிவிப்பை இயக்கவும்", + "LabelNewsCategories": "செய்தி பிரிவுகள்:", + "LabelNewPasswordConfirm": "புதிய கடவு சொல்லை உறுதி செய்:", + "LabelNewPassword": "புதிய கடவுச்சொல்:", + "LabelNewName": "புதிய பெயர்:", + "LabelUnstable": "நிலையற்றது", + "LabelStable": "நிலையானது", + "LabelChromecastVersion": "Chromecast பதிப்பு", + "LabelName": "பெயர்:", + "LabelMusicStreamingTranscodingBitrateHelp": "இசையை ஸ்ட்ரீமிங் செய்யும் போது அதிகபட்ச பிட்ரேட்டைக் குறிப்பிடவும்.", + "LabelMusicStreamingTranscodingBitrate": "இசை டிரான்ஸ்கோடிங் பிட்ரேட்:", + "LabelMovieRecordingPath": "திரைப்பட பதிவு பாதை:", + "LabelMoviePrefixHelp": "திரைப்பட தலைப்புகளுக்கு ஒரு முன்னொட்டு பயன்படுத்தப்பட்டால், அதை இங்கே உள்ளிடவும், இதனால் சேவையகம் அதை சரியாக கையாள முடியும்.", + "LabelMoviePrefix": "திரைப்பட முன்னொட்டு:", + "LabelMovieCategories": "திரைப்பட பிரிவுகள்:", + "LabelMonitorUsers": "இதிலிருந்து செயல்பாட்டைக் கண்காணிக்கவும்:", + "LabelModelUrl": "மாதிரி URL", + "LabelModelNumber": "மாதிரி எண்", + "LabelModelName": "மாதிரி பெயர்", + "LabelModelDescription": "மாதிரி விளக்கம்", + "LabelMinScreenshotDownloadWidth": "குறைந்தபட்ச ஸ்கிரீன்ஷாட் பதிவிறக்க அகலம்:", + "LabelMinResumePercentageHelp": "இந்த நேரத்திற்கு முன் நிறுத்தப்பட்டால் தலைப்புகள் காட்டப்படாது என்று கருதப்படுகிறது.", + "LabelMinResumePercentage": "குறைந்தபட்ச மறுதொடக்கம் சதவீதம்:", + "LabelMinResumeDurationHelp": "பின்னணி இருப்பிடத்தைச் சேமிக்கும் மற்றும் மீண்டும் தொடங்க அனுமதிக்கும் வினாடிகளில் மிகக் குறுகிய வீடியோ நீளம்.", + "LabelMinResumeDuration": "குறைந்தபட்ச மறுதொடக்கம் காலம்:", + "LabelMinBackdropDownloadWidth": "குறைந்தபட்ச பின்னணி பதிவிறக்க அகலம்:", + "LabelMethod": "முறை:", + "LabelMetadataSaversHelp": "உங்கள் மெட்டாடேட்டாவைச் சேமிக்கும்போது பயன்படுத்த கோப்பு வடிவங்களைத் தேர்வுசெய்க.", + "LabelMetadataSavers": "மெட்டாடேட்டா சேமிப்பாளர்கள்:", + "LabelMetadataReadersHelp": "உங்கள் விருப்பமான உள்ளூர் மெட்டாடேட்டா ஆதாரங்களை முன்னுரிமையின் அடிப்படையில் வரிசைப்படுத்தவும். கண்டுபிடிக்கப்பட்ட முதல் கோப்பு படிக்கப்படும்.", + "LabelMetadataReaders": "மெட்டாடேட்டா வாசகர்கள்:", + "LabelMetadataPathHelp": "பதிவிறக்கம் செய்யப்பட்ட கலைப்படைப்பு மற்றும் மெட்டாடேட்டாவிற்கான தனிப்பயன் இருப்பிடத்தைக் குறிப்பிடவும்.", + "LabelMetadataPath": "மெட்டாடேட்டா பாதை:", + "LabelMetadataDownloadersHelp": "முன்னுரிமைக்கு ஏற்ப உங்களுக்கு விருப்பமான மெட்டாடேட்டா பதிவிறக்கிகளை இயக்கவும் தரவரிசைப்படுத்தவும். காணாமல் போன தகவல்களை நிரப்ப மட்டுமே குறைந்த முன்னுரிமை பதிவிறக்கிகள் பயன்படுத்தப்படும்.", + "LabelMetadataDownloadLanguage": "விருப்பமான பதிவிறக்க மொழி:", + "LabelMetadata": "மெட்டாடேட்டா:", + "LabelMessageTitle": "செய்தி தலைப்பு:", + "LabelMessageText": "செய்தி உரை:", + "LabelMaxStreamingBitrateHelp": "ஸ்ட்ரீமிங் செய்யும் போது அதிகபட்ச பிட்ரேட்டைக் குறிப்பிடவும்.", + "LabelMaxStreamingBitrate": "அதிகபட்ச ஸ்ட்ரீமிங் தரம்:", + "LabelMaxScreenshotsPerItem": "ஒரு உருப்படிக்கு அதிகபட்ச ஸ்கிரீன் ஷாட்கள்:", + "LabelMaxResumePercentageHelp": "இந்த நேரத்திற்குப் பிறகு நிறுத்தப்பட்டால் தலைப்புகள் முழுமையாக விளையாடப்படும் என்று கருதப்படுகிறது.", + "LabelMaxResumePercentage": "அதிகபட்ச மறுதொடக்கம் சதவீதம்:", + "LabelMaxParentalRating": "அனுமதிக்கப்பட்ட அதிகபட்ச பெற்றோர் மதிப்பீடு:", + "LabelMaxChromecastBitrate": "Chromecast ஸ்ட்ரீமிங் தரம்:", + "LabelMaxBackdropsPerItem": "ஒரு உருப்படிக்கு அதிகபட்ச பின்னணி எண்ணிக்கை:", + "LabelMatchType": "பொருந்தும் வகை:", + "LabelManufacturerUrl": "உற்பத்தியாளர் URL", + "LabelManufacturer": "உற்பத்தியாளர்:", + "LabelLogs": "பதிவுகள்:", + "LabelLoginDisclaimerHelp": "உள்நுழைவு பக்கத்தின் கீழே காண்பிக்கப்படும் செய்தி.", + "LabelLoginDisclaimer": "உள்நுழைவு மறுப்பு:", + "LabelLockItemToPreventChanges": "எதிர்கால மாற்றங்களைத் தடுக்க இந்த உருப்படியைப் பூட்டவும்", + "LabelLocalHttpServerPortNumberHelp": "HTTP சேவையகத்திற்கான TCP போர்ட் எண்.", + "LabelLocalHttpServerPortNumber": "உள்ளூர் HTTP போர்ட் எண்:", + "LabelLineup": "வரிசை:", + "LabelLibraryPageSizeHelp": "நூலகப் பக்கத்தில் காண்பிக்க வேண்டிய பொருட்களின் அளவை அமைக்கிறது. பேஜிங்கை முடக்க 0 என அமைக்கவும்.", + "LabelLibraryPageSize": "நூலக பக்க அளவு:", + "LabelLanguage": "மொழி:", + "LabelLanNetworks": "LAN நெட்வொர்க்குகள்:", + "LabelKodiMetadataUserHelp": "பிற பயன்பாடுகளைப் பயன்படுத்த வாட்ச் தரவை NFO கோப்புகளில் சேமிக்கவும்.", + "LabelKodiMetadataUser": "இதற்காக பயனர் கண்காணிப்பு தரவை NFO கோப்புகளில் சேமிக்கவும்:", + "LabelKodiMetadataSaveImagePathsHelp": "Kodi வழிகாட்டுதல்களுக்கு இணங்காத படக் கோப்பு பெயர்கள் உங்களிடம் இருந்தால் இது பரிந்துரைக்கப்படுகிறது.", + "LabelKodiMetadataSaveImagePaths": "பட வழிகளை nfo கோப்புகளுக்குள் சேமிக்கவும்", + "LabelKodiMetadataEnablePathSubstitutionHelp": "சேவையகத்தின் பாதை மாற்று அமைப்புகளைப் பயன்படுத்தி பட பாதைகளின் பாதை மாற்றீட்டை இயக்குகிறது.", + "LabelKodiMetadataEnablePathSubstitution": "பாதை மாற்றீட்டை இயக்கு", + "LabelKodiMetadataEnableExtraThumbsHelp": "படங்களை பதிவிறக்கும் போது அவை அதிகபட்ச கோடி தோல் பொருந்தக்கூடிய தன்மைக்காக எக்ஸ்ட்ராஃபனார்ட் மற்றும் எக்ஸ்ட்ராஹம்ப்ஸில் சேமிக்கப்படும்.", + "LabelKodiMetadataEnableExtraThumbs": "extrafanart-ஐ extrathumbs புலத்திற்கு நகலெடுக்கவும்", + "LabelKodiMetadataDateFormatHelp": "NFO கோப்புகளில் உள்ள அனைத்து தேதிகளும் இந்த வடிவமைப்பைப் பயன்படுத்தி பாகுபடுத்தப்படும்.", + "LabelKodiMetadataDateFormat": "வெளியீட்டு தேதி வடிவம்:", + "LabelKidsCategories": "குழந்தைகள் பிரிவுகள்:", + "LabelKeepUpTo": "தொடர்ந்து இருங்கள்:", + "LabelInternetQuality": "இணைய தரம்:", + "LabelInNetworkSignInWithEasyPasswordHelp": "உங்கள் உள்ளூர் நெட்வொர்க்கில் உள்ள வாடிக்கையாளர்களுக்கு உள்நுழைய எளிதான முள் குறியீட்டைப் பயன்படுத்தவும். உங்கள் வழக்கமான கடவுச்சொல் வீட்டிலிருந்து மட்டுமே தேவைப்படும். முள் குறியீடு காலியாக இருந்தால், உங்கள் வீட்டு நெட்வொர்க்கில் கடவுச்சொல் தேவையில்லை.", + "LabelInNetworkSignInWithEasyPassword": "எனது எளிதான முள் குறியீட்டைக் கொண்டு பிணைய உள்நுழைவை இயக்கவும்", + "LabelImportOnlyFavoriteChannels": "பிடித்ததாகக் குறிக்கப்பட்ட சேனல்களுக்கு கட்டுப்படுத்தவும்", + "LabelImageType": "பட வகை:", + "LabelImageFetchersHelp": "முன்னுரிமைக்கு ஏற்ப உங்களுக்கு விருப்பமான பட பெறுபவர்களை இயக்கவும் தரவரிசைப்படுத்தவும்.", + "LabelIdentificationFieldHelp": "ஒரு வழக்கு-உணர்வற்ற அடி மூலக்கூறு அல்லது ரீஜெக்ஸ் வெளிப்பாடு.", + "LabelIconMaxWidthHelp": "Upnp: ஐகான் வழியாக வெளிப்படும் ஐகான்களின் அதிகபட்ச தீர்மானம்.", + "LabelIconMaxWidth": "ஐகான் அதிகபட்ச அகலம்:", + "LabelIconMaxHeightHelp": "Upnp: ஐகான் வழியாக வெளிப்படும் ஐகான்களின் அதிகபட்ச தீர்மானம்.", + "LabelIconMaxHeight": "ஐகான் அதிகபட்ச உயரம்:", + "LabelHttpsPortHelp": "HTTPS சேவையகத்திற்கான TCP போர்ட் எண்.", + "LabelHttpsPort": "உள்ளூர் HTTPS போர்ட் எண்:", + "LabelHomeScreenSectionValue": "முகப்புத் திரை பிரிவு {0}:", + "LabelHomeNetworkQuality": "முகப்பு நெட்வொர்க் தரம்:", + "LabelHardwareAccelerationTypeHelp": "வன்பொருள் முடுக்கம் கூடுதல் உள்ளமைவு தேவை.", + "LabelHardwareAccelerationType": "வன்பொருள் முடுக்கம்:", + "LabelEncoderPreset": "H264 மற்றும் H265 குறியாக்க முன்னமைவு:", + "LabelH264Crf": "H264 குறியாக்கம் CRF:", + "LabelGroupMoviesIntoCollectionsHelp": "மூவி பட்டியல்களைக் காண்பிக்கும் போது, ஒரு தொகுப்பில் உள்ள திரைப்படங்கள் ஒரு குழுவாகக் காட்டப்படும்.", + "LabelGroupMoviesIntoCollections": "திரைப்படங்களை தொகுப்பாக குழு செய்யவும்", + "LabelServerNameHelp": "சேவையகத்தை அடையாளம் காண இந்த பெயர் பயன்படுத்தப்படும் மற்றும் சேவையகத்தின் ஹோஸ்ட்பெயருக்கு இயல்புநிலையாக இருக்கும்.", + "LabelFriendlyName": "நட்பு பெயர்:", + "LabelFormat": "வடிவம்:", + "LabelForgotPasswordUsernameHelp": "உங்கள் பயனர்பெயரை நினைவில் வைத்திருந்தால் உள்ளிடவும்.", + "LabelFont": "எழுத்துரு:", + "LabelFolder": "கோப்புறை:", + "LabelFinish": "முடி", + "LabelFileOrUrl": "கோப்பு அல்லது URL:", + "LabelFailed": "தோல்வி", + "LabelExtractChaptersDuringLibraryScanHelp": "நூலக ஸ்கேன் போது வீடியோக்கள் இறக்குமதி செய்யப்படும்போது அத்தியாய படங்களை உருவாக்கவும். இல்லையெனில், வழக்கமான பட ஸ்கேன் வேகமாக முடிக்க அனுமதிக்கும் அத்தியாயப் படங்கள் திட்டமிடப்பட்ட பணியின் போது அவை பிரித்தெடுக்கப்படும்.", + "LabelExtractChaptersDuringLibraryScan": "நூலக ஸ்கேன் போது அத்தியாய படங்களை பிரித்தெடுக்கவும்", + "LabelBaseUrlHelp": "சேவையக URL இல் தனிப்பயன் துணை அடைவைச் சேர்க்கவும். உதாரணத்திற்கு: http://example.com/<baseurl>", + "LabelBaseUrl": "அடிப்படை URL:", + "LabelEveryXMinutes": "ஒவ்வொரு:", + "LabelEvent": "நிகழ்வு:", + "LabelEpisodeNumber": "அத்தியாயம் எண்:", + "LabelEndDate": "கடைசி தேதி:", + "LabelEnableSingleImageInDidlLimitHelp": "Didlக்குள் பல படங்கள் பதிக்கப்பட்டிருந்தால் சில சாதனங்கள் சரியாக வழங்கப்படாது.", + "LabelEnableSingleImageInDidlLimit": "ஒற்றை உட்பொதிக்கப்பட்ட படத்திற்கு வரம்பு", + "LabelEnableRealtimeMonitorHelp": "கோப்புகளுக்கான மாற்றங்கள் ஆதரிக்கப்பட்ட கோப்பு முறைமைகளில் உடனடியாக செயல்படுத்தப்படும்.", + "LabelEnableRealtimeMonitor": "நிகழ்நேர கண்காணிப்பை இயக்கு", + "LabelEnableHttpsHelp": "கட்டமைக்கப்பட்ட HTTPS போர்ட்டில் கேளுங்கள். இது நடைமுறைக்கு வர செல்லுபடியாகும் சான்றிதழும் வழங்கப்பட வேண்டும்.", + "LabelEnableHttps": "HTTPS ஐ இயக்கு", + "LabelEnableHardwareDecodingFor": "இதற்கான வன்பொருள் டிகோடிங்கை இயக்கவும்:", + "LabelEnableDlnaServerHelp": "உள்ளடக்கத்தை உலவ மற்றும் இயக்க உங்கள் பிணையத்தில் உள்ள UPnP சாதனங்களை அனுமதிக்கிறது.", + "LabelEnableDlnaServer": "DLNA சேவையகத்தை இயக்கு", + "LabelEnableDlnaPlayToHelp": "உங்கள் நெட்வொர்க்கில் உள்ள சாதனங்களைக் கண்டறிந்து அவற்றை தொலைவிலிருந்து கட்டுப்படுத்தும் திறனை வழங்குகின்றன.", + "LabelEnableDlnaPlayTo": "DLNA Play To ஐ இயக்கு", + "LabelEnableDlnaDebugLoggingHelp": "பெரிய பதிவுக் கோப்புகளை உருவாக்கவும், சரிசெய்தல் நோக்கங்களுக்காக மட்டுமே பயன்படுத்தப்பட வேண்டும்.", + "LabelEnableDlnaDebugLogging": "DLNA பிழைத்திருத்த பதிவை இயக்கு", + "LabelEnableDlnaClientDiscoveryIntervalHelp": "SSDP தேடல்களுக்கு இடையில் வினாடிகளில் கால அளவை தீர்மானிக்கிறது.", + "LabelEnableDlnaClientDiscoveryInterval": "கிளையண்ட் கண்டுபிடிப்பு இடைவெளி", + "LabelEnableBlastAliveMessagesHelp": "உங்கள் பிணையத்தில் உள்ள பிற UPnP சாதனங்களால் சேவையகம் நம்பகத்தன்மையுடன் கண்டறியப்படாவிட்டால் இதை இயக்கவும்.", + "LabelEnableBlastAliveMessages": "உயிருள்ள செய்திகளை வழங்கவும்", + "LabelEnableAutomaticPortMapHelp": "உங்கள் திசைவியின் பொது துறைமுகங்களை உங்கள் சேவையகத்தில் உள்ள உள்ளூர் துறைமுகங்களுக்கு UPnP வழியாக தானாக அனுப்பவும். இது சில திசைவி மாதிரிகள் அல்லது பிணைய உள்ளமைவுகளுடன் இயங்காது. சேவையகம் மறுதொடக்கம் செய்யப்படும் வரை மாற்றங்கள் பொருந்தாது.", + "LabelEnableAutomaticPortMap": "தானியங்கி போர்ட் மேப்பிங்கை இயக்கு", + "LabelEmbedAlbumArtDidlHelp": "ஆல்பம் படம் பெறுவதற்கு சில சாதனங்கள் இந்த முறையை விரும்புகின்றன. இயக்கப்பட்ட இந்த விருப்பத்துடன் மற்றவர்கள் விளையாடத் தவறலாம்." } From 18211bec86dceead2725ede379668d84178b7dcd Mon Sep 17 00:00:00 2001 From: Oatavandi Date: Sat, 15 Aug 2020 10:27:15 +0000 Subject: [PATCH 256/301] Translated using Weblate (Tamil) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/ta/ --- src/strings/ta.json | 161 +++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 159 insertions(+), 2 deletions(-) diff --git a/src/strings/ta.json b/src/strings/ta.json index 48c82a6eee..b8d89d701e 100644 --- a/src/strings/ta.json +++ b/src/strings/ta.json @@ -612,7 +612,7 @@ "LabelCache": "தற்காலிக சேமிப்பு:", "LabelBurnSubtitles": "வசன வரிகள் பதிக்க:", "LabelPleaseRestart": "வலை கிளையண்டை கைமுறையாக மீண்டும் ஏற்றிய பிறகு மாற்றங்கள் நடைமுறைக்கு வரும்.", - "LabelPlayMethod": "விளையாட்டு முறை:", + "LabelPlayMethod": "பிளே முறை:", "LabelPlaylist": "பிளேலிஸ்ட்:", "LabelPlayerDimensions": "பிளேயர் பரிமாணங்கள்:", "LabelPlayer": "பிளேயர்:", @@ -764,5 +764,162 @@ "LabelEnableBlastAliveMessages": "உயிருள்ள செய்திகளை வழங்கவும்", "LabelEnableAutomaticPortMapHelp": "உங்கள் திசைவியின் பொது துறைமுகங்களை உங்கள் சேவையகத்தில் உள்ள உள்ளூர் துறைமுகங்களுக்கு UPnP வழியாக தானாக அனுப்பவும். இது சில திசைவி மாதிரிகள் அல்லது பிணைய உள்ளமைவுகளுடன் இயங்காது. சேவையகம் மறுதொடக்கம் செய்யப்படும் வரை மாற்றங்கள் பொருந்தாது.", "LabelEnableAutomaticPortMap": "தானியங்கி போர்ட் மேப்பிங்கை இயக்கு", - "LabelEmbedAlbumArtDidlHelp": "ஆல்பம் படம் பெறுவதற்கு சில சாதனங்கள் இந்த முறையை விரும்புகின்றன. இயக்கப்பட்ட இந்த விருப்பத்துடன் மற்றவர்கள் விளையாடத் தவறலாம்." + "LabelEmbedAlbumArtDidlHelp": "ஆல்பம் படம் பெறுவதற்கு சில சாதனங்கள் இந்த முறையை விரும்புகின்றன. இயக்கப்பட்ட இந்த விருப்பத்துடன் மற்றவர்கள் விளையாடத் தவறலாம்.", + "ManageRecording": "பதிவை நிர்வகிக்கவும்", + "ManageLibrary": "நூலகத்தை நிர்வகிக்கவும்", + "Logo": "லோகோ", + "LiveTV": "நேரடி தொலைக்காட்சி", + "LiveBroadcasts": "நேரடி ஒளிபரப்பு", + "Live": "நேரலை", + "List": "பட்டியல்", + "Like": "விருப்பம்", + "LibraryAccessHelp": "இந்த பயனருடன் பகிர நூலகங்களைத் தேர்ந்தெடுக்கவும். நிர்வாகிகள் மெட்டாடேட்டா நிர்வாகியைப் பயன்படுத்தி அனைத்து கோப்புறைகளையும் திருத்த முடியும்.", + "LeaveBlankToNotSetAPassword": "கடவுச்சொல் எதுவும் அமைக்க இந்த புலத்தை காலியாக விடலாம்.", + "LearnHowYouCanContribute": "நீங்கள் எவ்வாறு பங்களிக்க முடியும் என்பதை அறிக.", + "LatestFromLibrary": "சமீபத்திய {0}", + "Large": "பெரியது", + "LanNetworksHelp": "அலைவரிசை கட்டுப்பாடுகளைச் செயல்படுத்தும்போது உள்ளூர் பிணையத்தில் பரிசீலிக்கப்படும் நெட்வொர்க்குகளுக்கான ஐபி முகவரிகள் அல்லது ஐபி / நெட்மாஸ்க் உள்ளீடுகளின் கமாவால் பிரிக்கப்பட்ட பட்டியல். அமைக்கப்பட்டால், மற்ற அனைத்து ஐபி முகவரிகளும் வெளிப்புற நெட்வொர்க்கில் இருப்பதாகக் கருதப்படும் மற்றும் வெளிப்புற அலைவரிசை கட்டுப்பாடுகளுக்கு உட்பட்டதாக இருக்கும். காலியாக இருந்தால், சேவையகத்தின் சப்நெட் மட்டுமே உள்ளூர் பிணையத்தில் கருதப்படுகிறது.", + "LabelffmpegPathHelp": "Ffmpeg பயன்பாட்டுக் கோப்பு அல்லது ffmpeg கொண்ட கோப்புறையின் பாதை.", + "LabelffmpegPath": "FFmpeg பாதை:", + "LabelZipCode": "அஞ்சல் குறியீடு:", + "LabelYoureDone": "நீங்கள் முடித்துவிட்டீர்கள்!", + "LabelYear": "ஆண்டு:", + "LabelXDlnaDocHelp": "X_DLNADOC உறுப்பின் உள்ளடக்கத்தை urn: schemas-dlna-org: device-1-0 பெயர்வெளியில் தீர்மானிக்கிறது.", + "LabelXDlnaDoc": "X-DLNA ஆவணம்:", + "LabelXDlnaCapHelp": "X_DLNACAP உறுப்பின் உள்ளடக்கத்தை urn: schemas-dlna-org: device-1-0 பெயர்வெளியில் தீர்மானிக்கிறது.", + "LabelXDlnaCap": "X-DLNA திறன்:", + "LabelWeb": "வலை:", + "LabelVideoResolution": "வீடியோ தெளிவுத்திறன்:", + "LabelVideoCodec": "வீடியோ கோடெக்:", + "LabelVideoBitrate": "வீடியோ பிட்ரேட்:", + "LabelVideo": "வீடியோ", + "DashboardArchitecture": "கட்டமைப்பு: {0}", + "DashboardOperatingSystem": "இயக்க முறைமை: {0}", + "DashboardServerName": "சேவையகம்: {0}", + "DashboardVersionNumber": "பதிப்பு: {0}", + "LabelVersionInstalled": "{0} நிறுவப்பட்டது", + "LabelVersion": "பதிப்பு:", + "LabelValue": "மதிப்பு:", + "LabelVaapiDeviceHelp": "வன்பொருள் முடுக்கத்திற்கு பயன்படுத்தப்படும் ரெண்டர் முனை இது.", + "LabelVaapiDevice": "VA API சாதனம்:", + "LabelUsername": "பயனர்பெயர்:", + "LabelUserRemoteClientBitrateLimitHelp": "சேவையக பின்னணி அமைப்புகளில் அமைக்கப்பட்ட இயல்புநிலை உலகளாவிய மதிப்பை மேலெழுதவும்.", + "LabelUserLoginAttemptsBeforeLockout": "பயனர் பூட்டப்படுவதற்கு முன்பு தோல்வியுற்ற உள்நுழைவு முயற்சிகள்:", + "LabelUserLibraryHelp": "சாதனத்தில் காண்பிக்க வேண்டிய பயனர் நூலகத்தைத் தேர்ந்தெடுக்கவும். இயல்புநிலை அமைப்பைப் பெறுவதற்கு காலியாக விடவும்.", + "LabelUserLibrary": "பயனர் நூலகம்:", + "LabelUserAgent": "பயனர் முகவர்:", + "LabelUser": "பயனர்:", + "LabelUseNotificationServices": "பின்வரும் சேவைகளைப் பயன்படுத்தவும்:", + "LabelTypeText": "உரை", + "LabelTypeMetadataDownloaders": "{0} மெட்டாடேட்டா பதிவிறக்கிகள்:", + "LabelType": "வகை:", + "LabelTunerType": "ட்யூனர் வகை:", + "LabelTunerIpAddress": "ட்யூனர் ஐபி முகவரி:", + "LabelTriggerType": "தூண்டுதல் வகை:", + "LabelTranscodingVideoCodec": "வீடியோ கோடெக்:", + "LabelTranscodingThreadCountHelp": "டிரான்ஸ்கோடிங் செய்யும்போது பயன்படுத்த வேண்டிய அதிகபட்ச நூல்களைத் தேர்ந்தெடுக்கவும். நூல் எண்ணிக்கையைக் குறைப்பது CPU பயன்பாட்டைக் குறைக்கும், ஆனால் மென்மையான பின்னணி அனுபவத்திற்கு போதுமானதாக மாற்றாது.", + "LabelTranscodingThreadCount": "டிரான்ஸ்கோடிங் நூல் எண்ணிக்கை:", + "LabelTranscodingProgress": "டிரான்ஸ்கோடிங் முன்னேற்றம்:", + "LabelTranscodingFramerate": "டிரான்ஸ்கோடிங் ஃப்ரேம்ரேட்:", + "LabelTranscodes": "டிரான்ஸ்கோட்கள்:", + "LabelTranscodingTempPathHelp": "வாடிக்கையாளர்களுக்கு வழங்கப்பட்ட டிரான்ஸ்கோட் கோப்புகளுக்கான தனிப்பயன் பாதையை குறிப்பிடவும். சேவையக இயல்புநிலையைப் பயன்படுத்த காலியாக விடவும்.", + "LabelTranscodePath": "டிரான்ஸ்கோட் பாதை:", + "LabelTranscodingContainer": "கொள்கலன்:", + "LabelTranscodingAudioCodec": "ஆடியோ கோடெக்:", + "LabelTrackNumber": "ட்ராக் எண்:", + "LabelTitle": "தலைப்பு:", + "LabelTimeLimitHours": "கால எல்லை (மணிநேரம்):", + "LabelTime": "நேரம்:", + "LabelTheme": "தீம்:", + "LabelTextSize": "உரை அளவு:", + "LabelTextColor": "உரை நிறம்:", + "LabelTextBackgroundColor": "உரை பின்னணி நிறம்:", + "LabelTagline": "கோஷம்:", + "LabelTag": "குறிச்சொல்:", + "LabelTVHomeScreen": "டிவி பயன்முறை முகப்புத் திரை:", + "LabelSyncPlayAccess": "ஒத்திசைவு அணுகல்", + "LabelSyncPlayAccessNone": "இந்த பயனருக்கு முடக்கப்பட்டது", + "LabelSyncPlayAccessJoinGroups": "குழுக்களில் சேர பயனரை அனுமதிக்கவும்", + "LabelSyncPlayAccessCreateAndJoinGroups": "குழுக்களை உருவாக்க மற்றும் சேர பயனரை அனுமதிக்கவும்", + "LabelSyncPlayLeaveGroupDescription": "ஒத்திசைவை முடக்கு", + "LabelSyncPlayLeaveGroup": "குழுவிலிருந்து விலகு", + "LabelSyncPlayNewGroupDescription": "புதிய குழுவை உருவாக்கவும்", + "LabelSyncPlayNewGroup": "புதிய குழு", + "LabelSyncPlaySyncMethod": "ஒத்திசைவு முறை:", + "LabelSyncPlayPlaybackDiff": "பின்னணி நேர வேறுபாடு:", + "MillisecondsUnit": "ms", + "LabelSyncPlayTimeOffset": "சேவையகத்துடன் நேரம் ஈடுசெய்யப்பட்டது:", + "LabelSupportedMediaTypes": "ஆதரிக்கப்படும் ஊடக வகைகள்:", + "LabelSubtitles": "வசன வரிகள்", + "LabelSubtitlePlaybackMode": "வசன முறை:", + "LabelSubtitleFormatHelp": "எடுத்துக்காட்டு: srt", + "LabelSubtitleDownloaders": "வசன பதிவிறக்கிகள்:", + "LabelStreamType": "ஸ்ட்ரீம் வகை:", + "LabelStopping": "நிறுத்துகிறது", + "LabelStopWhenPossible": "சாத்தியமான வகையில் நிறுத்து:", + "LabelStatus": "நிலை:", + "LabelStartWhenPossible": "முடிந்தவரை தொடங்குங்கள்:", + "LabelSportsCategories": "விளையாட்டு பிரிவுகள்:", + "LabelSpecialSeasonsDisplayName": "சிறப்பு பருவ காட்சி பெயர்:", + "LabelSource": "மூலம்:", + "LabelSortTitle": "வரிசை தலைப்பு:", + "LabelSortOrder": "வரிசை வகை:", + "LabelSortBy": "வரிசைப்படுத்து:", + "LabelSonyAggregationFlagsHelp": "திரட்டலில் திரட்டல் ஃப்ளாக்ஸ் உறுப்பு உள்ளடக்கத்தை தீர்மானிக்கிறது: schemas-sonycom: av பெயர்வெளி.", + "LabelSonyAggregationFlags": "Sony திரட்டல் கொடிகள்:", + "LabelSkipIfGraphicalSubsPresentHelp": "வசன வரிகள் உரை பதிப்புகளை வைத்திருப்பது மிகவும் திறமையான விநியோகத்திற்கு வழிவகுக்கும் மற்றும் வீடியோ டிரான்ஸ்கோடிங்கின் சாத்தியத்தை குறைக்கும்.", + "LabelSkipIfGraphicalSubsPresent": "வீடியோவில் ஏற்கனவே உட்பொதிக்கப்பட்ட வசன வரிகள் இருந்தால் தவிர்க்கவும்", + "LabelSkipIfAudioTrackPresentHelp": "ஆடியோ மொழியைப் பொருட்படுத்தாமல் எல்லா வீடியோக்களுக்கும் வசன வரிகள் இருப்பதை உறுதிப்படுத்த இதைத் தேர்வுநீக்கவும்.", + "LabelSkipIfAudioTrackPresent": "இயல்புநிலை ஆடியோ டிராக் பதிவிறக்க மொழியுடன் பொருந்தினால் தவிர்க்கவும்", + "LabelSkipForwardLength": "முன்னோக்கி நீளத்தைத் தவிர்:", + "LabelSkipBackLength": "பின் நீளத்தைத் தவிர்:", + "LabelSize": "அளவு:", + "LabelSimultaneousConnectionLimit": "ஒரே நேரத்தில் ஸ்ட்ரீம் வரம்பு:", + "LabelServerName": "சேவையக பெயர்:", + "LabelServerHostHelp": "192.168.1.100:8096 or https://myserver.com", + "LabelServerHost": "தொகுப்பாளர்:", + "LabelSeriesRecordingPath": "தொடர் பதிவு பாதை:", + "LabelSerialNumber": "வரிசை எண்", + "LabelSendNotificationToUsers": "அறிவிப்பை இதற்கு அனுப்பவும்:", + "LabelSelectVersionToInstall": "நிறுவ பதிப்பைத் தேர்ந்தெடுக்கவும்:", + "LabelSelectUsers": "பயனர்களைத் தேர்ந்தெடுக்கவும்:", + "LabelSelectFolderGroupsHelp": "தேர்வு செய்யப்படாத கோப்புறைகள் தங்களது சொந்த பார்வையில் காண்பிக்கப்படும்.", + "LabelSelectFolderGroups": "திரைப்படங்கள், இசை மற்றும் டிவி போன்ற காட்சிகளில் பின்வரும் கோப்புறைகளிலிருந்து உள்ளடக்கத்தை தானாக தொகுக்கவும்:", + "LabelSeasonNumber": "பருவ எண்:", + "EnableFasterAnimationsHelp": "வேகமான அனிமேஷன்கள் மற்றும் மாற்றங்களைப் பயன்படுத்தவும்", + "EnableFasterAnimations": "வேகமான அனிமேஷன்கள்", + "LabelScreensaver": "ஸ்கிரீன்சேவர்:", + "LabelScheduledTaskLastRan": "கடைசியாக ஓடியது {0}, எடுத்துக் கொண்டது {1}.", + "LabelSaveLocalMetadataHelp": "கலைப்படைப்புகளை மீடியா கோப்புறைகளில் சேமிப்பது அவற்றை எளிதில் திருத்தக்கூடிய இடத்தில் வைக்கும்.", + "LabelSaveLocalMetadata": "கலைப்படைப்புகளை மீடியா கோப்புறைகளில் சேமிக்கவும்", + "LabelRuntimeMinutes": "இயக்க நேரம்:", + "LabelRequireHttpsHelp": "சரிபார்க்கப்பட்டால், சேவையகம் தானாகவே HTTP வழியாக அனைத்து கோரிக்கைகளையும் HTTPS க்கு திருப்பிவிடும். HTTPS இல் சேவையகம் கேட்கவில்லை என்றால் இது எந்த விளைவையும் ஏற்படுத்தாது.", + "LabelRequireHttps": "HTTPS தேவை", + "LabelRemoteClientBitrateLimitHelp": "நெட்வொர்க் சாதனங்களுக்கு வெளியே ஒரு விருப்பமான ஸ்ட்ரீம் பிட்ரேட் வரம்பு. உங்கள் இணைய இணைப்பு கையாளக்கூடியதை விட சாதனங்களை அதிக பிட்ரேட்டைக் கோருவதைத் தடுக்க இது பயனுள்ளதாக இருக்கும். பறக்கும்போது வீடியோக்களை குறைந்த பிட்ரேட்டுக்கு டிரான்ஸ்கோட் செய்வதற்காக இது உங்கள் சேவையகத்தில் CPU சுமை அதிகரிக்கும்.", + "LabelRemoteClientBitrateLimit": "இணைய ஸ்ட்ரீமிங் பிட்ரேட் வரம்பு (Mbps):", + "LabelReleaseDate": "வெளிவரும் தேதி:", + "LabelRefreshMode": "புதுப்பிப்பு பயன்முறை:", + "LabelRecordingPathHelp": "பதிவுகளைச் சேமிக்க இயல்புநிலை இருப்பிடத்தைக் குறிப்பிடவும். காலியாக இருந்தால், சேவையகத்தின் நிரல் தரவு கோப்புறை பயன்படுத்தப்படும்.", + "LabelRecordingPath": "இயல்புநிலை பதிவு பாதை:", + "LabelRecord": "பதிவு:", + "LabelReasonForTranscoding": "டிரான்ஸ்கோடிங்கிற்கான காரணம்:", + "LabelPublicHttpsPortHelp": "உள்ளூர் HTTPS துறைமுகத்துடன் பொருத்தப்பட வேண்டிய பொது துறைமுக எண்.", + "LabelPublicHttpsPort": "பொது HTTPS போர்ட் எண்:", + "LabelPublicHttpPortHelp": "உள்ளூர் HTTP துறைமுகத்துடன் பொருத்தப்பட வேண்டிய பொது போர்ட் எண்.", + "LabelPublicHttpPort": "பொது HTTP போர்ட் எண்:", + "LabelProtocolInfoHelp": "சாதனத்திலிருந்து GetProtocolInfo கோரிக்கைகளுக்கு பதிலளிக்கும் போது பயன்படுத்தப்படும் மதிப்பு.", + "LabelProtocolInfo": "நெறிமுறை தகவல்:", + "LabelProtocol": "நெறிமுறை:", + "LabelProfileVideoCodecs": "வீடியோ கோடெக்குகள்:", + "LabelProfileContainersHelp": "கமாவால் பிரிக்கப்பட்டது. எல்லா கொள்கலன்களுக்கும் விண்ணப்பிக்க இதை காலியாக விடலாம்.", + "LabelProfileContainer": "கொள்கலன்:", + "LabelProfileCodecsHelp": "கமாவால் பிரிக்கப்பட்டது. எல்லா கோடெக்குகளுக்கும் விண்ணப்பிக்க இதை காலியாக விடலாம்.", + "LabelProfileCodecs": "கோடெக்குகள்:", + "LabelProfileAudioCodecs": "ஆடியோ கோடெக்குகள்:", + "LabelPreferredSubtitleLanguage": "விருப்பமான வசன மொழி:", + "LabelPreferredDisplayLanguageHelp": "ஜெல்லிஃபின் மொழிபெயர்ப்பது ஒரு தொடர்ச்சியான திட்டம்.", + "LabelPreferredDisplayLanguage": "விருப்பமான காட்சி மொழி:", + "LabelPostProcessorArgumentsHelp": "பதிவு கோப்புக்கான பாதையாக {path} ஐப் பயன்படுத்தவும்.", + "LabelPostProcessorArguments": "பிந்தைய செயலி கட்டளை வரி வாதங்கள்:", + "LabelPostProcessor": "செயலாக்கத்திற்கு பிந்தைய பயன்பாடு:" } From 4e0a7c33078537b7cc926acfb1c6f178e2d72805 Mon Sep 17 00:00:00 2001 From: Kunio Date: Sat, 15 Aug 2020 12:09:52 +0000 Subject: [PATCH 257/301] Translated using Weblate (Swedish) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/sv/ --- src/strings/sv.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/strings/sv.json b/src/strings/sv.json index b1fb42537a..50ad99be59 100644 --- a/src/strings/sv.json +++ b/src/strings/sv.json @@ -138,7 +138,7 @@ "DetectingDevices": "Söker efter enheter", "DeviceAccessHelp": "Detta tillämpas endast för enheter som kan bli unikt identifierade och som inte förhindrar åtkomst till browsern. Filtering av användarenheter kommer att blockera dom från att använda nya enheter tills dom har blivit godkända här.", "DirectPlaying": "Direktuppspelning", - "DirectStreamHelp1": "Innehållet är kompatibelt med enheten vad gäller upplösning och medietyp (H.264, AC3 osv.) men är i ett inkompatibelt filformat (mkv, avi, wmv osv.). Videofilen kommer att packas om i realtid innan den strömmas till enheten.", + "DirectStreamHelp1": "Innehållet har en kompatibel upplösning och mediatyp (H.264, AC3, osv.) för enheten, men är i en inkompatibel filbehållare (mkv, avi, wmv, osv.). Videofilen kommer att packas om i realtid innan den strömmas till enheten.", "DirectStreamHelp2": "Direktströmning av en fil använder väldigt lite resurser av CPU'n utan att bildkvaliten försämras.", "DirectStreaming": "Direktströmning", "Director": "Regissör", From 134b6b7c3c56541339961766ad6154e258734391 Mon Sep 17 00:00:00 2001 From: Oatavandi Date: Sat, 15 Aug 2020 12:17:38 +0000 Subject: [PATCH 258/301] Translated using Weblate (Tamil) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/ta/ --- src/strings/ta.json | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/src/strings/ta.json b/src/strings/ta.json index b8d89d701e..5914a3bdd5 100644 --- a/src/strings/ta.json +++ b/src/strings/ta.json @@ -921,5 +921,6 @@ "LabelPreferredDisplayLanguage": "விருப்பமான காட்சி மொழி:", "LabelPostProcessorArgumentsHelp": "பதிவு கோப்புக்கான பாதையாக {path} ஐப் பயன்படுத்தவும்.", "LabelPostProcessorArguments": "பிந்தைய செயலி கட்டளை வரி வாதங்கள்:", - "LabelPostProcessor": "செயலாக்கத்திற்கு பிந்தைய பயன்பாடு:" + "LabelPostProcessor": "செயலாக்கத்திற்கு பிந்தைய பயன்பாடு:", + "MapChannels": "சேனல் மேப்பிங்" } From e7578a9b9c63e175f42bc812ee4199860f46351e Mon Sep 17 00:00:00 2001 From: Oatavandi Date: Sat, 15 Aug 2020 12:46:01 +0000 Subject: [PATCH 259/301] Translated using Weblate (Tamil) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/ta/ --- src/strings/ta.json | 118 +++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 117 insertions(+), 1 deletion(-) diff --git a/src/strings/ta.json b/src/strings/ta.json index 5914a3bdd5..b3aaad1a7b 100644 --- a/src/strings/ta.json +++ b/src/strings/ta.json @@ -922,5 +922,121 @@ "LabelPostProcessorArgumentsHelp": "பதிவு கோப்புக்கான பாதையாக {path} ஐப் பயன்படுத்தவும்.", "LabelPostProcessorArguments": "பிந்தைய செயலி கட்டளை வரி வாதங்கள்:", "LabelPostProcessor": "செயலாக்கத்திற்கு பிந்தைய பயன்பாடு:", - "MapChannels": "சேனல் மேப்பிங்" + "MapChannels": "சேனல் மேப்பிங்", + "MoveLeft": "இடதுபுறமாக நகர்த்தவும்", + "MoreMediaInfo": "மீடியா தகவல்", + "MoreUsersCanBeAddedLater": "டாஷ்போர்டுக்குள் இருந்து அதிகமான பயனர்களை பின்னர் சேர்க்கலாம்.", + "MoreFromValue": "{0} இலிருந்து மேலும்", + "Monday": "திங்கட்கிழமை", + "Mobile": "கைபேசி", + "MinutesBefore": "நிமிடங்களுக்கு முன்", + "MinutesAfter": "நிமிடங்கள் கழித்து", + "MetadataSettingChangeHelp": "மெட்டாடேட்டா அமைப்புகளை மாற்றுவது புதிய உள்ளடக்கத்தை முன்னோக்கி செல்லும். இருக்கும் உள்ளடக்கத்தைப் புதுப்பிக்க, விவரம் திரையைத் திறந்து புதுப்பிப்பு பொத்தானைக் கிளிக் செய்க, அல்லது மெட்டாடேட்டா நிர்வாகியைப் பயன்படுத்தி மொத்தமாக புதுப்பிப்புகளைச் செய்யுங்கள்.", + "MetadataManager": "மெட்டாடேட்டா மேலாளர்", + "Metadata": "மெட்டாடேட்டா", + "MessageSyncPlayErrorMedia": "ஒத்திசைவை இயக்குவதில் தோல்வி! மீடியா பிழை.", + "MessageSyncPlayErrorMissingSession": "ஒத்திசைவை இயக்குவதில் தோல்வி! அமர்வு இல்லை.", + "MessageSyncPlayErrorNoActivePlayer": "செயலில் உள்ள எந்த பிளேயரும் கிடைக்கவில்லை. ஒத்திசைவு முடக்கப்பட்டுள்ளது.", + "MessageSyncPlayErrorAccessingGroups": "குழுக்கள் பட்டியலை அணுகும்போது பிழை ஏற்பட்டது.", + "MessageSyncPlayLibraryAccessDenied": "இந்த உள்ளடக்கத்திற்கான அணுகல் தடைசெய்யப்பட்டுள்ளது.", + "MessageSyncPlayJoinGroupDenied": "ஒத்திசைவைப் பயன்படுத்த அனுமதி தேவை.", + "MessageSyncPlayCreateGroupDenied": "ஒரு குழுவை உருவாக்க அனுமதி தேவை.", + "MessageSyncPlayGroupDoesNotExist": "குழு இல்லாததால் குழுவில் சேர முடியவில்லை.", + "MessageSyncPlayPlaybackPermissionRequired": "பின்னணி அனுமதி தேவை.", + "MessageSyncPlayNoGroupsAvailable": "குழுக்கள் எதுவும் கிடைக்கவில்லை. முதலில் ஏதாவது வாசிக்க தொடங்குங்கள்.", + "MessageSyncPlayGroupWait": "{0} இடையகப்படுத்துகிறது…", + "MessageSyncPlayUserLeft": "{0} குழுவிலிருந்து வெளியேறினார்.", + "MessageSyncPlayUserJoined": "{0} குழுவில் சேர்ந்துள்ளார்.", + "MessageSyncPlayDisabled": "ஒத்திசைவு முடக்கப்பட்டது.", + "MessageSyncPlayEnabled": "ஒத்திசைவு இயக்கப்பட்டது.", + "MessageYouHaveVersionInstalled": "நீங்கள் தற்போது {0} பதிப்பை நிறுவியுள்ளீர்கள்.", + "MessageUnsetContentHelp": "உள்ளடக்கம் எளிய கோப்புறைகளாக காண்பிக்கப்படும். சிறந்த முடிவுகளுக்கு துணை கோப்புறைகளின் உள்ளடக்க வகைகளை அமைக்க மெட்டாடேட்டா நிர்வாகியைப் பயன்படுத்தவும்.", + "MessageUnableToConnectToServer": "தேர்ந்தெடுக்கப்பட்ட சேவையகத்துடன் இப்போது எங்களால் இணைக்க முடியவில்லை. இது இயங்குவதை உறுதிசெய்து மீண்டும் முயற்சிக்கவும்.", + "MessageTheFollowingLocationWillBeRemovedFromLibrary": "உங்கள் நூலகத்திலிருந்து பின்வரும் ஊடக இருப்பிடங்கள் அகற்றப்படும்:", + "MessageSettingsSaved": "அமைப்புகள் சேமிக்கப்பட்டன.", + "MessageReenableUser": "மீண்டும் இயக்க கீழே காண்க", + "MessagePluginInstallDisclaimer": "கூடுதல் அம்சங்கள் மற்றும் நன்மைகளுடன் உங்கள் அனுபவத்தை மேம்படுத்த சமூக உறுப்பினர்களால் உருவாக்கப்பட்ட செருகுநிரல்கள் சிறந்த வழியாகும். நிறுவுவதற்கு முன், உங்கள் சேவையகத்தில் அவை நீண்ட நூலக ஸ்கேன், கூடுதல் பின்னணி செயலாக்கம் மற்றும் கணினி நிலைத்தன்மை குறைதல் போன்ற விளைவுகளைப் பற்றி எச்சரிக்கையாக இருங்கள்.", + "MessagePluginConfigurationRequiresLocalAccess": "இந்த சொருகி கட்டமைக்க உங்கள் உள்ளூர் சேவையகத்தில் நேரடியாக உள்நுழைக.", + "MessagePleaseWait": "தயவுசெய்து காத்திருங்கள். இதற்கு ஒரு நிமிடம் ஆகலாம்.", + "MessagePleaseEnsureInternetMetadata": "இணைய மெட்டாடேட்டாவைப் பதிவிறக்குவது இயக்கப்பட்டிருப்பதை உறுதிசெய்க.", + "MessagePlayAccessRestricted": "இந்த உள்ளடக்கத்தின் பின்னணி தற்போது தடைசெய்யப்பட்டுள்ளது. மேலும் தகவலுக்கு உங்கள் சேவையக நிர்வாகியைத் தொடர்பு கொள்ளவும்.", + "MessagePasswordResetForUsers": "பின்வரும் பயனர்கள் தங்கள் கடவுச்சொற்களை மீட்டமைத்துள்ளனர். மீட்டமைப்பைச் செய்யப் பயன்படுத்தப்பட்ட முள் குறியீடுகளுடன் அவர்கள் இப்போது உள்நுழையலாம்.", + "MessageNothingHere": "இங்கு எதுவுமில்லை.", + "MessageNoTrailersFound": "இணைய டிரெய்லர்களின் நூலகத்தைச் சேர்ப்பதன் மூலம் உங்கள் திரைப்பட அனுபவத்தை மேம்படுத்த டிரெய்லர்கள் சேனலை நிறுவவும்.", + "MessageNoServersAvailable": "தானியங்கி சேவையக கண்டுபிடிப்பைப் பயன்படுத்தி சேவையகங்கள் எதுவும் கண்டுபிடிக்கப்படவில்லை.", + "MessageNoPluginsInstalled": "உங்களிடம் செருகுநிரல்கள் எதுவும் நிறுவப்படவில்லை.", + "MessageNoMovieSuggestionsAvailable": "திரைப்பட பரிந்துரைகள் எதுவும் தற்போது கிடைக்கவில்லை. உங்கள் திரைப்படங்களைப் பார்க்கவும் மதிப்பீடு செய்யவும் தொடங்கவும், பின்னர் உங்கள் பரிந்துரைகளைக் காண மீண்டும் வாருங்கள்.", + "MessageNoGenresAvailable": "இணையத்திலிருந்து வகைகளை இழுக்க சில மெட்டாடேட்டா வழங்குநர்களை இயக்கவும்.", + "MessageNoCollectionsAvailable": "திரைப்படங்கள், தொடர் மற்றும் ஆல்பங்களின் தனிப்பயனாக்கப்பட்ட குழுக்களை அனுபவிக்க தொகுப்புகள் உங்களை அனுமதிக்கின்றன. தொகுப்புகளை உருவாக்கத் தொடங்க + பொத்தானைக் கிளிக் செய்க.", + "MessageAddRepository": "நீங்கள் ஒரு களஞ்சியத்தைச் சேர்க்க விரும்பினால், தலைப்புக்கு அடுத்துள்ள பொத்தானைக் கிளிக் செய்து கோரப்பட்ட தகவலை நிரப்பவும்.", + "LabelRepositoryNameHelp": "உங்கள் சேவையகத்தில் சேர்க்கப்பட்ட மற்றவர்களிடமிருந்து இந்த களஞ்சியத்தை வேறுபடுத்துவதற்கான தனிப்பயன் பெயர்.", + "LabelRepositoryName": "களஞ்சிய பெயர்", + "LabelRepositoryUrlHelp": "நீங்கள் சேர்க்க விரும்பும் களஞ்சிய மேனிஃபெஸ்டின் இடம்.", + "LabelRepositoryUrl": "களஞ்சிய URL", + "HeaderNewRepository": "புதிய களஞ்சியம்", + "MessageNoRepositories": "களஞ்சியங்கள் இல்லை.", + "MessageNoAvailablePlugins": "கிடைக்கக்கூடிய செருகுநிரல்கள் இல்லை.", + "MessageLeaveEmptyToInherit": "பெற்றோர் உருப்படி அல்லது உலகளாவிய இயல்புநிலை மதிப்பிலிருந்து அமைப்புகளைப் பெறுவதற்கு காலியாக விடவும்.", + "MessageItemsAdded": "உருப்படிகள் சேர்க்கப்பட்டன.", + "MessageItemSaved": "உருப்படி சேமிக்கப்பட்டது.", + "MessageInvalidUser": "தவறான பயனர்பெயர் அல்லது கடவுச்சொல். தயவுசெய்து மீண்டும் முயற்சி செய்க.", + "MessageInvalidForgotPasswordPin": "தவறான அல்லது காலாவதியான முள் குறியீடு உள்ளிடப்பட்டது. தயவுசெய்து மீண்டும் முயற்சி செய்க.", + "MessageImageTypeNotSelected": "கீழ்தோன்றும் மெனுவிலிருந்து பட வகையைத் தேர்ந்தெடுக்கவும்.", + "MessageImageFileTypeAllowed": "JPEG மற்றும் PNG கோப்புகள் மட்டுமே ஆதரிக்கப்படுகின்றன.", + "MessageForgotPasswordInNetworkRequired": "கடவுச்சொல் மீட்டமைப்பு செயல்முறையைத் தொடங்க உங்கள் வீட்டு நெட்வொர்க்கில் மீண்டும் முயற்சிக்கவும்.", + "MessageForgotPasswordFileCreated": "பின்வரும் கோப்பு உங்கள் சேவையகத்தில் உருவாக்கப்பட்டது மற்றும் எவ்வாறு தொடரலாம் என்பதற்கான வழிமுறைகளைக் கொண்டுள்ளது:", + "MessageFileReadError": "கோப்பைப் படிப்பதில் பிழை ஏற்பட்டது. தயவுசெய்து மீண்டும் முயற்சி செய்க.", + "MessageEnablingOptionLongerScans": "இந்த விருப்பத்தை இயக்குவது கணிசமாக நீண்ட நூலக ஸ்கேன்களுக்கு வழிவகுக்கும்.", + "MessageDownloadQueued": "பதிவிறக்கம் வரிசைப்படுத்தப்பட்டுள்ளது.", + "MessageDirectoryPickerLinuxInstruction": "Arch Linux, CentOS, Debian, Fedora, openSUSE அல்லது Ubuntu ஆகியவற்றில் லினக்ஸைப் பொறுத்தவரை, சேவை பயனருக்கு உங்கள் சேமிப்பிட இருப்பிடங்களுக்கு குறைந்தபட்சம் படிக்க அணுகலை வழங்க வேண்டும்.", + "MessageDirectoryPickerBSDInstruction": "BSD ஐப் பொறுத்தவரை, உங்கள் FreeNAS சிறைக்குள் சேமிப்பிடத்தை உள்ளமைக்க வேண்டியிருக்கலாம், எனவே ஜெல்லிஃபின் உங்கள் மீடியாவை அணுக முடியும்.", + "MessageDeleteTaskTrigger": "இந்த பணி தூண்டுதலை நீக்க விரும்புகிறீர்களா?", + "MessageCreateAccountAt": "{0} இல் ஒரு கணக்கை உருவாக்கவும்", + "MessageContactAdminToResetPassword": "உங்கள் கடவுச்சொல்லை மீட்டமைக்க உங்கள் கணினி நிர்வாகியைத் தொடர்பு கொள்ளவும்.", + "MessageConfirmShutdown": "சேவையகத்தை நிறுத்த விரும்புகிறீர்களா?", + "MessageConfirmRevokeApiKey": "இந்த API விசையை திரும்பப் பெற விரும்புகிறீர்களா? இந்த சேவையகத்திற்கான பயன்பாட்டின் இணைப்பு திடீரென நிறுத்தப்படும்.", + "MessageConfirmRestart": "ஜெல்லிஃபின் மறுதொடக்கம் செய்ய விரும்புகிறீர்களா?", + "MessageConfirmRemoveMediaLocation": "இந்த இருப்பிடத்தை அகற்ற விரும்புகிறீர்களா?", + "MessageConfirmRecordingCancellation": "பதிவை ரத்து செய்யவா?", + "MessageConfirmProfileDeletion": "இந்த சுயவிவரத்தை நீக்க விரும்புகிறீர்களா?", + "MessageConfirmDeleteTunerDevice": "இந்த சாதனத்தை நீக்க விரும்புகிறீர்களா?", + "MessageConfirmDeleteGuideProvider": "இந்த வழிகாட்டி வழங்குநரை நீக்க விரும்புகிறீர்களா?", + "MessageConfirmAppExit": "நீங்கள் வெளியேற விரும்புகிறீர்களா?", + "MessageAreYouSureYouWishToRemoveMediaFolder": "இந்த மீடியா கோப்புறையை அகற்ற விரும்புகிறீர்களா?", + "MessageAreYouSureDeleteSubtitles": "இந்த வசன கோப்பை நீக்க விரும்புகிறீர்களா?", + "MessageAlreadyInstalled": "இந்த பதிப்பு ஏற்கனவே நிறுவப்பட்டுள்ளது.", + "Menu": "பட்டியல்", + "MediaIsBeingConverted": "மீடியா இயங்கும் சாதனத்துடன் பொருந்தக்கூடிய வடிவமாக ஊடகங்கள் மாற்றப்படுகின்றன.", + "MediaInfoStreamTypeVideo": "காணொளி", + "MediaInfoStreamTypeSubtitle": "வசன வரிகள்", + "MediaInfoStreamTypeEmbeddedImage": "உட்பொதிக்கப்பட்ட படம்", + "MediaInfoStreamTypeData": "தகவல்", + "MediaInfoStreamTypeAudio": "ஆடியோ", + "MediaInfoTimestamp": "நேர முத்திரை", + "MediaInfoSize": "அளவு", + "MediaInfoSampleRate": "மாதிரி விகிதம்", + "MediaInfoResolution": "தெளிவுத்திறன்", + "MediaInfoRefFrames": "குறிப்பு கட்டமைப்பு", + "MediaInfoProfile": "சுயவிவரம்", + "MediaInfoPixelFormat": "பிக்சல் வடிவம்", + "MediaInfoPath": "பாதை", + "MediaInfoLevel": "நிலை", + "MediaInfoLayout": "தளவமைப்பு", + "MediaInfoLanguage": "மொழி", + "MediaInfoInterlaced": "ஒன்றோடொன்று", + "MediaInfoFramerate": "ஃப்ரேமரேட்", + "MediaInfoForced": "கட்டாயப்படுத்தப்பட்டது", + "MediaInfoExternal": "வெளிப்புறம்", + "MediaInfoDefault": "இயல்புநிலை", + "MediaInfoContainer": "கொள்கலன்", + "MediaInfoCodecTag": "கோடெக் குறிச்சொல்", + "MediaInfoCodec": "கோடெக்", + "MediaInfoChannels": "சேனல்கள்", + "MediaInfoBitrate": "பிட்ரேட்", + "MediaInfoBitDepth": "பிட் ஆழம்", + "MediaInfoAspectRatio": "விகித விகிதம்", + "MediaInfoAnamorphic": "அனமார்பிக்", + "MaxParentalRatingHelp": "அதிக மதிப்பீட்டைக் கொண்ட உள்ளடக்கம் இந்த பயனரிடமிருந்து மறைக்கப்படும்.", + "MarkUnplayed": "வாசிக்கப்படாதது குறி இடு", + "MarkPlayed": "வாசிக்கப்பட்டது குறி இடு" } From 54ae6b543b651991118a2cb1f8358eebbd4665dc Mon Sep 17 00:00:00 2001 From: Oatavandi Date: Sat, 15 Aug 2020 13:49:57 +0000 Subject: [PATCH 260/301] Translated using Weblate (Tamil) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/ta/ --- src/strings/ta.json | 114 +++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 113 insertions(+), 1 deletion(-) diff --git a/src/strings/ta.json b/src/strings/ta.json index b3aaad1a7b..bd031a66ff 100644 --- a/src/strings/ta.json +++ b/src/strings/ta.json @@ -1038,5 +1038,117 @@ "MediaInfoAnamorphic": "அனமார்பிக்", "MaxParentalRatingHelp": "அதிக மதிப்பீட்டைக் கொண்ட உள்ளடக்கம் இந்த பயனரிடமிருந்து மறைக்கப்படும்.", "MarkUnplayed": "வாசிக்கப்படாதது குறி இடு", - "MarkPlayed": "வாசிக்கப்பட்டது குறி இடு" + "MarkPlayed": "வாசிக்கப்பட்டது குறி இடு", + "OptionEveryday": "தினமும்", + "OptionEstimateContentLength": "டிரான்ஸ்கோடிங் செய்யும் போது உள்ளடக்க நீளத்தை மதிப்பிடுங்கள்", + "OptionEquals": "சமம்", + "OptionEnded": "முடிந்தது", + "OptionEnableM2tsModeHelp": "Mpegts க்கு குறியாக்கம் செய்யும் போது m2ts பயன்முறையை இயக்கவும்.", + "OptionEnableM2tsMode": "M2ts பயன்முறையை இயக்கு", + "OptionEnableForAllTuners": "அனைத்து ட்யூனர் சாதனங்களுக்கும் இயக்கு", + "OptionEnableExternalContentInSuggestionsHelp": "பரிந்துரைக்கப்பட்ட உள்ளடக்கத்தில் இணைய டிரெய்லர்கள் மற்றும் நேரடி தொலைக்காட்சி நிரல்களை சேர்க்க அனுமதிக்கவும்.", + "OptionEnableExternalContentInSuggestions": "பரிந்துரைகளில் வெளிப்புற உள்ளடக்கத்தை இயக்கவும்", + "OptionEnableAccessToAllLibraries": "எல்லா நூலகங்களுக்கும் அணுகலை இயக்கவும்", + "OptionEnableAccessToAllChannels": "எல்லா சேனல்களுக்கும் அணுகலை இயக்கவும்", + "OptionEnableAccessFromAllDevices": "எல்லா சாதனங்களிலிருந்தும் அணுகலை இயக்கவும்", + "OptionEmbedSubtitles": "கொள்கலனுக்குள் உட்பொதிக்கவும்", + "OptionDvd": "டிவிடி", + "OptionDownloadThumbImage": "சிறுபடம்", + "OptionDownloadPrimaryImage": "முதன்மை", + "OptionDownloadMenuImage": "பட்டியல்", + "OptionDownloadLogoImage": "லோகோ", + "OptionDownloadImagesInAdvanceHelp": "இயல்பாக, பெரும்பாலான படங்கள் கிளையன்ட் கோரியபோது மட்டுமே பதிவிறக்கப்படும். புதிய மீடியா இறக்குமதி செய்யப்படுவதால், எல்லா படங்களையும் முன்கூட்டியே பதிவிறக்க இந்த விருப்பத்தை இயக்கவும். இது கணிசமாக நீண்ட நூலக ஸ்கேன்களை ஏற்படுத்தக்கூடும்.", + "OptionDownloadImagesInAdvance": "படங்களை முன்கூட்டியே பதிவிறக்கவும்", + "OptionDownloadDiscImage": "வட்டு", + "OptionDownloadBoxImage": "பெட்டி", + "OptionDownloadBannerImage": "பதாகை", + "OptionDownloadBackImage": "பின்னால்", + "OptionDownloadArtImage": "கலை", + "OptionDisplayFolderViewHelp": "உங்கள் பிற ஊடக நூலகங்களுடன் கோப்புறைகளைக் காண்பி. நீங்கள் ஒரு எளிய கோப்புறை காட்சியைப் பெற விரும்பினால் இது பயனுள்ளதாக இருக்கும்.", + "OptionDisplayFolderView": "எளிய மீடியா கோப்புறைகளைக் காட்ட கோப்புறை காட்சியைக் காண்பி", + "OptionDislikes": "வெறுப்புகள்", + "OptionDisableUserHelp": "இந்த பயனரிடமிருந்து எந்த இணைப்பையும் சேவையகம் அனுமதிக்காது. தற்போதுள்ள இணைப்புகள் திடீரென நிறுத்தப்படும்.", + "OptionDisableUser": "இந்த பயனரை முடக்கு", + "OptionDescending": "இறங்கு", + "OptionDatePlayed": "உடன் தேதி", + "OptionDateAddedImportTime": "நூலகத்தில் ஸ்கேன் செய்யப்பட்ட தேதியைப் பயன்படுத்தவும்", + "OptionDateAddedFileTime": "கோப்பு உருவாக்கும் தேதியைப் பயன்படுத்தவும்", + "OptionDateAdded": "சேர்த்த தேதி", + "OptionDaily": "தினசரி", + "OptionCustomUsers": "தனிப்பயன்", + "OptionCriticRating": "விமர்சன மதிப்பீடு", + "OptionContinuing": "தொடர்கிறது", + "OptionCommunityRating": "சமூக மதிப்பீடு", + "OptionCaptionInfoExSamsung": "CaptionInfoEx (சாம்சங்)", + "OptionBluray": "ப்ளூ-ரே", + "OptionBlockTvShows": "தொலைக்காட்சி நிகழ்ச்சிகள்", + "OptionBlockTrailers": "டிரெய்லர்கள்", + "OptionBlockMusic": "இசை", + "OptionBlockMovies": "திரைப்படங்கள்", + "OptionBlockLiveTvChannels": "நேரடி தொலைக்காட்சி சேனல்கள்", + "OptionBlockChannelContent": "இணைய சேனல் உள்ளடக்கம்", + "OptionBlockBooks": "புத்தகங்கள்", + "OptionBanner": "பதாகை", + "OptionAutomaticallyGroupSeriesHelp": "இந்த நூலகத்திற்குள் பல கோப்புறைகளில் பரவியிருக்கும் தொடர்கள் தானாக ஒரு தொடராக ஒன்றிணைக்கப்படும்.", + "OptionAutomaticallyGroupSeries": "பல கோப்புறைகளில் பரவியிருக்கும் தொடர்களை தானாக இணைக்கவும்", + "OptionAutomatic": "தானாக", + "OptionAuto": "தானாக", + "OptionAscending": "ஏறுதல்", + "OptionArtist": "கலைஞர்", + "OptionAllowVideoPlaybackTranscoding": "டிரான்ஸ்கோடிங் தேவைப்படும் வீடியோ பிளேபேக்கை அனுமதிக்கவும்", + "OptionAllowVideoPlaybackRemuxing": "மறு குறியாக்கம் இல்லாமல் மாற்றம் தேவைப்படும் வீடியோ பிளேபேக்கை அனுமதிக்கவும்", + "OptionAllowUserToManageServer": "சேவையகத்தை நிர்வகிக்க இந்த பயனரை அனுமதிக்கவும்", + "OptionAllowSyncTranscoding": "டிரான்ஸ்கோடிங் தேவைப்படும் மீடியா பதிவிறக்கம் மற்றும் ஒத்திசைவை அனுமதிக்கவும்", + "OptionAllowRemoteSharedDevicesHelp": "ஒரு பயனர் அவற்றைக் கட்டுப்படுத்தத் தொடங்கும் வரை DLNA சாதனங்கள் பகிரப்பட்டதாகக் கருதப்படுகின்றன.", + "OptionAllowRemoteSharedDevices": "பகிரப்பட்ட சாதனங்களின் தொலைநிலைக் கட்டுப்பாட்டை அனுமதிக்கவும்", + "OptionAllowRemoteControlOthers": "பிற பயனர்களின் ரிமோட் கண்ட்ரோலை அனுமதிக்கவும்", + "OptionAllowMediaPlaybackTranscodingHelp": "டிரான்ஸ்கோடிங்கிற்கான அணுகலைக் கட்டுப்படுத்துவது ஆதரிக்கப்படாத ஊடக வடிவங்கள் காரணமாக வாடிக்கையாளர்களுக்கு பின்னணி தோல்விகளை ஏற்படுத்தக்கூடும்.", + "OptionAllowMediaPlayback": "மீடியா பிளேபேக்கை அனுமதிக்கவும்", + "OptionAllowManageLiveTv": "லைவ் டிவி பதிவு நிர்வாகத்தை அனுமதிக்கவும்", + "OptionAllowLinkSharingHelp": "ஊடகத் தகவல்களைக் கொண்ட வலைப்பக்கங்கள் மட்டுமே பகிரப்படுகின்றன. மீடியா கோப்புகள் ஒருபோதும் பகிரங்கமாக பகிரப்படுவதில்லை. பங்குகள் நேர வரம்புக்குட்பட்டவை மற்றும் {0} நாட்களுக்குப் பிறகு காலாவதியாகும்.", + "OptionAllowLinkSharing": "சமூக ஊடக பகிர்வை அனுமதிக்கவும்", + "OptionAllowContentDownloading": "மீடியா பதிவிறக்க மற்றும் ஒத்திசைக்க அனுமதிக்கவும்", + "OptionAllowBrowsingLiveTv": "நேரடி தொலைக்காட்சி அணுகலை அனுமதிக்கவும்", + "OptionForceRemoteSourceTranscoding": "தொலைநிலை ஊடக மூலங்களின் டிரான்ஸ்கோடிங்கை கட்டாயப்படுத்தவும் (லைடிவி போன்றவை)", + "OptionAllowAudioPlaybackTranscoding": "டிரான்ஸ்கோடிங் தேவைப்படும் ஆடியோ பிளேபேக்கை அனுமதிக்கவும்", + "OptionAllUsers": "அனைத்து பயனாளர்கள்", + "OptionAlbumArtist": "ஆல்பம் கலைஞர்", + "OptionAlbum": "ஆல்பம்", + "OptionAdminUsers": "நிர்வாகிகள்", + "OnlyImageFormats": "பட வடிவங்கள் மட்டுமே (VOBSUB, PGS, SUB)", + "Option3D": "3D", + "OnlyForcedSubtitlesHelp": "கட்டாயமாக குறிக்கப்பட்ட வசன வரிகள் மட்டுமே ஏற்றப்படும்.", + "OnlyForcedSubtitles": "கட்டாயப்படுத்தப்பட்டது மட்டுமே", + "OneChannel": "ஒரு சேனல்", + "Off": "முடக்கு", + "NumLocationsValue": "{0} கோப்புறைகள்", + "Normal": "இயல்பானது", + "None": "எதுவுமில்லை", + "NoSubtitlesHelp": "முன்னிருப்பாக வசன வரிகள் ஏற்றப்படாது. பிளேபேக்கின் போது அவற்றை கைமுறையாக இயக்கலாம்.", + "NoSubtitleSearchResultsFound": "முடிவுகள் எதுவும் இல்லை.", + "MessageNoPluginConfiguration": "இந்த சொருகி கட்டமைக்க எந்த அமைப்புகளும் இல்லை.", + "MessageNoNextUpItems": "எதுவும் கிடைக்கவில்லை. உங்கள் நிகழ்ச்சிகளைப் பார்க்கத் தொடங்குங்கள்!", + "NoNewDevicesFound": "புதிய சாதனங்கள் எதுவும் கிடைக்கவில்லை. புதிய ட்யூனரைச் சேர்க்க, இந்த உரையாடலை மூடி சாதனத் தகவலை கைமுறையாக உள்ளிடவும்.", + "NoCreatedLibraries": "நீங்கள் இதுவரை எந்த நூலகங்களையும் உருவாக்கவில்லை என்று தெரிகிறது. {0} இப்போது ஒன்றை உருவாக்க விரும்புகிறீர்களா? {1}", + "No": "இல்லை", + "NextUp": "அடுத்தது", + "NextTrack": "அடுத்ததுக்குச் செல்க", + "Next": "அடுத்தது", + "News": "செய்தி", + "NewEpisodesOnly": "புதிய அத்தியாயங்கள் மட்டுமே", + "NewEpisodes": "புதிய அத்தியாயங்கள்", + "NewCollectionNameExample": "எடுத்துக்காட்டு: Star Wars Collection", + "NewCollectionHelp": "திரைப்படங்கள் மற்றும் பிற நூலக உள்ளடக்கங்களின் தனிப்பயனாக்கப்பட்ட குழுக்களை உருவாக்க தொகுப்புகள் உங்களை அனுமதிக்கின்றன.", + "NewCollection": "புதிய தொகுப்பு", + "Never": "ஒருபோதும்", + "Name": "பெயர்", + "MySubtitles": "எனது வசன வரிகள்", + "Mute": "முடக்கு", + "MusicVideo": "இசை கானொளி", + "MusicLibraryHelp": "{0} இசை பெயரிடும் வழிகாட்டியை {1} மதிப்பாய்வு செய்யவும்.", + "MusicArtist": "இசைக் கலைஞர்", + "MusicAlbum": "இசை ஆல்பம்", + "Movie": "திரைப்படம்", + "MovieLibraryHelp": "{0} மூவி பெயரிடும் வழிகாட்டியை {1} மதிப்பாய்வு செய்யவும்.", + "MoveRight": "வலதுபுறம் நகர்த்தவும்" } From 4095776ab3744930d6313b6e2825745672b5222a Mon Sep 17 00:00:00 2001 From: Ian Walton Date: Sat, 15 Aug 2020 11:41:54 -0400 Subject: [PATCH 261/301] Fix syncplay menu. --- src/scripts/libraryMenu.js | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/scripts/libraryMenu.js b/src/scripts/libraryMenu.js index d237eead9d..d67250d5cb 100644 --- a/src/scripts/libraryMenu.js +++ b/src/scripts/libraryMenu.js @@ -8,7 +8,7 @@ import appRouter from 'appRouter'; import appHost from 'apphost'; import playbackManager from 'playbackManager'; import syncPlayManager from 'syncPlayManager'; -import groupSelectionMenu from 'groupSelectionMenu'; +import { show as showGroupSelectionMenu } from 'groupSelectionMenu'; import browser from 'browser'; import globalize from 'globalize'; import imageHelper from 'scripts/imagehelper'; @@ -208,7 +208,7 @@ import 'flexStyles'; function onSyncButtonClicked() { const btn = this; - groupSelectionMenu.show(btn); + showGroupSelectionMenu(btn); } function onSyncPlayEnabled(event, enabled) { From 8796cd246fffde1b2646a8d40546c9ab5eb6a5f6 Mon Sep 17 00:00:00 2001 From: Oatavandi Date: Sat, 15 Aug 2020 15:19:29 +0000 Subject: [PATCH 262/301] Translated using Weblate (Tamil) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/ta/ --- src/strings/ta.json | 90 ++++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 89 insertions(+), 1 deletion(-) diff --git a/src/strings/ta.json b/src/strings/ta.json index bd031a66ff..7201ea80b4 100644 --- a/src/strings/ta.json +++ b/src/strings/ta.json @@ -1150,5 +1150,93 @@ "MusicAlbum": "இசை ஆல்பம்", "Movie": "திரைப்படம்", "MovieLibraryHelp": "{0} மூவி பெயரிடும் வழிகாட்டியை {1} மதிப்பாய்வு செய்யவும்.", - "MoveRight": "வலதுபுறம் நகர்த்தவும்" + "MoveRight": "வலதுபுறம் நகர்த்தவும்", + "PlayAllFromHere": "அனைத்தையும் இங்கிருந்து வாசிக்கவும்", + "Play": "வாசிக்கவும்", + "PlaceFavoriteChannelsAtBeginning": "பிடித்த சேனல்களை ஆரம்பத்தில் வைக்கவும்", + "PinCodeResetConfirmation": "பின் குறியீட்டை மீட்டமைக்க விரும்புகிறீர்களா?", + "PinCodeResetComplete": "முள் குறியீடு மீட்டமைக்கப்பட்டது.", + "PictureInPicture": "படத்தினுள் படம்", + "Person": "நபர்", + "PerfectMatch": "சரியான பொருத்தம்", + "People": "மக்கள்", + "PasswordSaved": "கடவுச்சொல் சேமிக்கப்பட்டது.", + "PasswordResetProviderHelp": "இந்த பயனர் கடவுச்சொல் மீட்டமைப்பைக் கோரும்போது பயன்படுத்த கடவுச்சொல் மீட்டமைப்பு வழங்குநரைத் தேர்வுசெய்க.", + "HeaderResetPassword": "கடவுச்சொல்லை மீட்டமைக்க", + "PasswordResetConfirmation": "கடவுச்சொல்லை மீட்டமைக்க நிச்சயமாக விரும்புகிறீர்களா?", + "PasswordResetComplete": "கடவுச்சொல் மீட்டமைக்கப்பட்டது.", + "PasswordMatchError": "கடவுச்சொல் மற்றும் கடவுச்சொல் உறுதிப்படுத்தல் பொருந்த வேண்டும்.", + "ParentalRating": "பெற்றோர் மதிப்பீடு", + "PackageInstallFailed": "{0} (பதிப்பு {1}) நிறுவல் தோல்வியடைந்தது.", + "PackageInstallCompleted": "{0} (பதிப்பு {1}) நிறுவல் முடிந்தது.", + "PackageInstallCancelled": "{0} (பதிப்பு {1}) நிறுவல் ரத்து செய்யப்பட்டது.", + "Overview": "கண்ணோட்டம்", + "OriginalAirDateValue": "அசல் ஒளிபரப்பப்பட்ட தேதி: {0}", + "OptionWeekly": "வாராந்திர", + "OptionWeekends": "வார இறுதி நாட்கள்", + "OptionWeekdays": "வார நாட்கள்", + "OptionWakeFromSleep": "தூக்கத்திலிருந்து விழிப்பதற்கு", + "OptionUnplayed": "காட்டப்படாதது", + "OptionUnairedEpisode": "ஒளிபரப்பப்படாத அத்தியாயங்கள்", + "OptionTvdbRating": "TVDB மதிப்பீடு", + "OptionTrackName": "ட்ராக் பெயர்", + "OptionThumbCard": "சிறுபட அட்டை", + "OptionThumb": "சிறுபடம்", + "OptionSubstring": "மூலக்கூறு", + "OptionSpecialEpisode": "சிறப்பு", + "OptionSaveMetadataAsHiddenHelp": "இதை மாற்றுவது முன்னோக்கிச் செல்லும் புதிய மெட்டாடேட்டாவுக்கு பொருந்தும். தற்போதுள்ள மெட்டாடேட்டா கோப்புகள் அடுத்த முறை சேவையகத்தால் சேமிக்கப்படும் போது அவை புதுப்பிக்கப்படும்.", + "OptionSaveMetadataAsHidden": "மெட்டாடேட்டா மற்றும் படங்களை மறைக்கப்பட்ட கோப்புகளாக சேமிக்கவும்", + "OptionRuntime": "இயக்க நேரம்", + "OptionResumable": "மீண்டும் தொடங்கக்கூடியது", + "OptionResElement": "res கூறு", + "OptionRequirePerfectSubtitleMatchHelp": "சரியான பொருத்தம் தேவைப்பட்டால், உங்கள் சரியான வீடியோ கோப்புடன் சோதிக்கப்பட்ட மற்றும் சரிபார்க்கப்பட்டவற்றை மட்டுமே சேர்க்க வசன வரிகள் வடிகட்டப்படும். இதைத் தேர்வுசெய்வது வசன வரிகள் பதிவிறக்கம் செய்யப்படுவதற்கான வாய்ப்பை அதிகரிக்கும், ஆனால் தவறான அல்லது தவறான வசன உரைக்கான வாய்ப்புகளை அதிகரிக்கும்.", + "OptionRequirePerfectSubtitleMatch": "எனது வீடியோ கோப்புகளுக்கு சரியான பொருத்தமாக இருக்கும் வசன வரிகள் மட்டுமே பதிவிறக்கவும்", + "OptionReportByteRangeSeekingWhenTranscodingHelp": "நேரம் நன்றாகத் தேடாத சில சாதனங்களுக்கு இது தேவைப்படுகிறது.", + "OptionReportByteRangeSeekingWhenTranscoding": "டிரான்ஸ்கோடிங் செய்யும் போது பைட் தேடுவதை சேவையகம் ஆதரிக்கிறது என்று புகாரளிக்கவும்", + "OptionReleaseDate": "வெளியீட்டு தேதி", + "OptionRegex": "ரீஜெக்ஸ்", + "OptionRandom": "சீரற்ற", + "OptionProtocolHttp": "HTTP", + "OptionProtocolHls": "HTTP நேரடி ஒளிபரப்பு", + "OptionProfileVideoAudio": "வீடியோ ஆடியோ", + "OptionProfileVideo": "காணொளி", + "OptionProfilePhoto": "புகைப்படம்", + "OptionProfileAudio": "ஆடியோ", + "OptionPremiereDate": "பிரீமியர் தேதி", + "OptionPosterCard": "சுவரொட்டி அட்டை", + "OptionPoster": "சுவரொட்டி", + "OptionPlayed": "வாசிக்கப்பட்டது", + "OptionPlayCount": "ப்ளே கவுண்ட்", + "OptionPlainVideoItemsHelp": "எல்லா வீடியோக்களும் டிஐடிஎல்லில் \"object.item.videoItem\" என குறிப்பிடப்படுகின்றன, அதாவது \"object.item.videoItem.movie\" போன்ற ஒரு குறிப்பிட்ட வகைக்கு பதிலாக.", + "OptionPlainVideoItems": "எல்லா வீடியோக்களையும் எளிய வீடியோ உருப்படிகளாகக் காண்பி", + "OptionPlainStorageFoldersHelp": "அனைத்து கோப்புறைகளும் டிஐடிஎல்லில் \"object.container.storageFolder\" என குறிப்பிடப்படுகின்றன, அதாவது \"object.container.person.musicArtist\" போன்ற ஒரு குறிப்பிட்ட வகைக்கு பதிலாக.", + "OptionPlainStorageFolders": "எல்லா கோப்புறைகளையும் வெற்று சேமிப்பக கோப்புறைகளாகக் காண்பி", + "OptionParentalRating": "பெற்றோர் மதிப்பீடு", + "OptionOnInterval": "ஒரு இடைவெளியில்", + "OptionNone": "எதுவுமில்லை", + "OptionNew": "புதிய…", + "OptionNameSort": "பெயர்", + "OptionMissingEpisode": "தவறிய பாகங்கள்", + "OptionMax": "அதிகபட்சம்", + "OptionLoginAttemptsBeforeLockoutHelp": "பூஜ்ஜியத்தின் மதிப்பு என்பது சாதாரண பயனர்களுக்கான மூன்று முயற்சிகளின் இயல்புநிலையையும், நிர்வாகிகளுக்கு ஐந்து முயற்சிகளையும் பெறுவதாகும். இதை -1 ஆக அமைப்பது அம்சத்தை முடக்கும்.", + "OptionLoginAttemptsBeforeLockout": "கதவடைப்பு ஏற்படுவதற்கு முன்பு எத்தனை தவறான உள்நுழைவு முயற்சிகள் செய்யப்படலாம் என்பதை தீர்மானிக்கிறது.", + "OptionList": "பட்டியல்", + "OptionLikes": "விருப்பங்கள்", + "OptionIsSD": "எஸ்டி", + "OptionIsHD": "எச்டி", + "OptionImdbRating": "IMDb மதிப்பீடு", + "OptionIgnoreTranscodeByteRangeRequestsHelp": "இந்த கோரிக்கைகள் மதிக்கப்படும், ஆனால் பைட் வரம்பு தலைப்பை புறக்கணிக்கும்.", + "OptionIgnoreTranscodeByteRangeRequests": "டிரான்ஸ்கோட் பைட் வரம்பு கோரிக்கைகளை புறக்கணிக்கவும்", + "OptionHomeVideos": "புகைப்படங்கள்", + "OptionHlsSegmentedSubtitles": "HLS பிரிக்கப்பட்ட வசன வரிகள்", + "OptionHideUserFromLoginHelp": "தனிப்பட்ட அல்லது மறைக்கப்பட்ட நிர்வாகி கணக்குகளுக்கு பயனுள்ளதாக இருக்கும். பயனர் தங்கள் பயனர்பெயர் மற்றும் கடவுச்சொல்லை உள்ளிட்டு கைமுறையாக உள்நுழைய வேண்டும்.", + "OptionHideUser": "உள்நுழைவு திரைகளிலிருந்து இந்த பயனரை மறைக்கவும்", + "OptionHasTrailer": "டிரெய்லர்", + "OptionHasThemeVideo": "தீம் வீடியோ", + "OptionHasThemeSong": "தீம் பாடல்", + "OptionHasSubtitles": "வசன வரிகள்", + "OptionHasSpecialFeatures": "சிறப்பு அம்சங்கள்", + "OptionFavorite": "பிடித்தவை", + "OptionExtractChapterImage": "அத்தியாயம் படத்தை பிரித்தெடுப்பதை இயக்கு", + "OptionExternallyDownloaded": "வெளிப்புற பதிவிறக்க" } From 00cb7e0ca835a3d8bf86ef43f4556cc55c979203 Mon Sep 17 00:00:00 2001 From: Oatavandi Date: Sat, 15 Aug 2020 15:47:31 +0000 Subject: [PATCH 263/301] Translated using Weblate (Tamil) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/ta/ --- src/strings/ta.json | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/src/strings/ta.json b/src/strings/ta.json index 7201ea80b4..fddfbfdf1c 100644 --- a/src/strings/ta.json +++ b/src/strings/ta.json @@ -1238,5 +1238,6 @@ "OptionHasSpecialFeatures": "சிறப்பு அம்சங்கள்", "OptionFavorite": "பிடித்தவை", "OptionExtractChapterImage": "அத்தியாயம் படத்தை பிரித்தெடுப்பதை இயக்கு", - "OptionExternallyDownloaded": "வெளிப்புற பதிவிறக்க" + "OptionExternallyDownloaded": "வெளிப்புற பதிவிறக்க", + "PlaybackData": "பின்னணி தரவு" } From 50e4a179ebd88e7d05c58847254c4f9c4544e1fa Mon Sep 17 00:00:00 2001 From: Oatavandi Date: Sat, 15 Aug 2020 15:48:02 +0000 Subject: [PATCH 264/301] Translated using Weblate (Tamil) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/ta/ --- src/strings/ta.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/src/strings/ta.json b/src/strings/ta.json index fddfbfdf1c..90d6c05dbd 100644 --- a/src/strings/ta.json +++ b/src/strings/ta.json @@ -1239,5 +1239,7 @@ "OptionFavorite": "பிடித்தவை", "OptionExtractChapterImage": "அத்தியாயம் படத்தை பிரித்தெடுப்பதை இயக்கு", "OptionExternallyDownloaded": "வெளிப்புற பதிவிறக்க", - "PlaybackData": "பின்னணி தரவு" + "PlaybackData": "பின்னணி தரவு", + "PlayFromBeginning": "ஆரம்பத்தில் இருந்து வாசிக்கவும்", + "PlayCount": "வாசிப்பு எண்ணிக்கை" } From ef4caf2eb4369040b8b09634086cb127ea0d7cde Mon Sep 17 00:00:00 2001 From: Oatavandi Date: Sat, 15 Aug 2020 15:50:00 +0000 Subject: [PATCH 265/301] Translated using Weblate (Tamil) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/ta/ --- src/strings/ta.json | 113 +++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 112 insertions(+), 1 deletion(-) diff --git a/src/strings/ta.json b/src/strings/ta.json index 90d6c05dbd..edb5806508 100644 --- a/src/strings/ta.json +++ b/src/strings/ta.json @@ -1241,5 +1241,116 @@ "OptionExternallyDownloaded": "வெளிப்புற பதிவிறக்க", "PlaybackData": "பின்னணி தரவு", "PlayFromBeginning": "ஆரம்பத்தில் இருந்து வாசிக்கவும்", - "PlayCount": "வாசிப்பு எண்ணிக்கை" + "PlayCount": "வாசிப்பு எண்ணிக்கை", + "StopRecording": "பதிவு செய்வதை நிறுத்துங்கள்", + "Sports": "விளையாட்டு", + "SortName": "பெயரை வரிசைப்படுத்து", + "SortChannelsBy": "சேனல்களை வரிசைப்படுத்து:", + "SortByValue": "{0} மூலம் வரிசைப்படுத்து", + "Sort": "வரிசைப்படுத்து", + "SmartSubtitlesHelp": "ஆடியோ வெளிநாட்டு மொழியில் இருக்கும்போது மொழி விருப்பத்துடன் பொருந்தக்கூடிய வசனங்கள் ஏற்றப்படும்.", + "Smart": "ஸ்மார்ட்", + "Smaller": "மிக சிறிய", + "SmallCaps": "சிறிய எழுத்துக்கள்", + "Small": "சிறிய", + "SkipEpisodesAlreadyInMyLibraryHelp": "எபிசோடுகள் கிடைக்கும்போது, சீசன் மற்றும் எபிசோட் எண்களைப் பயன்படுத்தி ஒப்பிடப்படும்.", + "SkipEpisodesAlreadyInMyLibrary": "எனது நூலகத்தில் ஏற்கனவே இருக்கும் அத்தியாயங்களை பதிவு செய்ய வேண்டாம்", + "SimultaneousConnectionLimitHelp": "அனுமதிக்கப்பட்ட ஒரே நேரத்தில் நீரோடைகளின் அதிகபட்ச எண்ணிக்கை. வரம்பில்லாமல் 0 ஐ உள்ளிடவும்.", + "Filter": "வடிகட்டு", + "New": "புதிய", + "Shuffle": "கலக்கு", + "ShowYear": "ஆண்டு காட்டு", + "ShowTitle": "தலைப்பைக் காட்டு", + "ShowMore": "மேலும் காட்ட", + "ShowLess": "குறைவாகக் காட்டு", + "ShowIndicatorsFor": "இதற்கான குறிகாட்டிகளைக் காட்டு:", + "ShowAdvancedSettings": "மேம்பட்ட அமைப்புகளைக் காட்டு", + "Share": "பகிர்", + "SettingsWarning": "இந்த மதிப்புகளை மாற்றுவது உறுதியற்ற தன்மை அல்லது இணைப்பு தோல்விகளை ஏற்படுத்தக்கூடும். உங்களுக்கு ஏதேனும் சிக்கல்கள் ஏற்பட்டால், அவற்றை இயல்புநிலைக்கு மாற்ற பரிந்துரைக்கிறோம்.", + "SettingsSaved": "அமைப்புகள் சேமிக்கப்பட்டன.", + "Settings": "அமைப்புகள்", + "ServerUpdateNeeded": "இந்த சேவையகத்தை புதுப்பிக்க வேண்டும். சமீபத்திய பதிப்பைப் பதிவிறக்க, தயவுசெய்து {0} ஐ பார்வையிடவும்", + "ServerRestartNeededAfterPluginInstall": "செருகுநிரலை நிறுவிய பின் ஜெல்லிஃபின் மறுதொடக்கம் செய்யப்பட வேண்டும்.", + "ServerNameIsShuttingDown": "{0} இல் உள்ள சேவையகம் மூடப்படும்.", + "ServerNameIsRestarting": "{0} இல் உள்ள சேவையகம் மறுதொடக்கம் செய்யப்படுகிறது.", + "SeriesYearToPresent": "{0} - தற்போது", + "SeriesSettings": "தொடர் அமைப்புகள்", + "SeriesRecordingScheduled": "தொடர் பதிவு திட்டமிடப்பட்டுள்ளது.", + "SeriesDisplayOrderHelp": "எபிசோட்களை ஒளிபரப்பப்பட்ட தேதி, டிவிடி ஆர்டர் அல்லது முழுமையான எண்ணால் வரிசைப்படுத்தவும்.", + "SeriesCancelled": "தொடர் ரத்து செய்யப்பட்டது.", + "Series": "தொடர்", + "SendMessage": "செய்தி அனுப்ப", + "SelectAdminUsername": "நிர்வாகி கணக்கிற்கான பயனர்பெயரைத் தேர்ந்தெடுக்கவும்.", + "Season": "பருவம்", + "SearchResults": "தேடல் முடிவுகள்", + "SearchForSubtitles": "வசன வரிகள் தேடுங்கள்", + "SearchForMissingMetadata": "காணாமல் போன மெட்டாடேட்டாவைத் தேடுங்கள்", + "SearchForCollectionInternetMetadata": "கலைப்படைப்பு மற்றும் மெட்டாடேட்டாவிற்கு இணையத்தில் தேடுங்கள்", + "Search": "தேடு", + "Screenshots": "ஸ்கிரீன்ஷாட்கள்", + "Screenshot": "ஸ்கிரீன்ஷாட்", + "Schedule": "அட்டவணை", + "ScanLibrary": "ஸ்கேன் நூலகம்", + "ScanForNewAndUpdatedFiles": "புதிய மற்றும் புதுப்பிக்கப்பட்ட கோப்புகளை ஸ்கேன் செய்யுங்கள்", + "SaveSubtitlesIntoMediaFoldersHelp": "வீடியோ கோப்புகளுக்கு அடுத்ததாக வசன வரிகள் சேமிப்பது அவற்றை எளிதாக நிர்வகிக்க அனுமதிக்கும்.", + "SaveSubtitlesIntoMediaFolders": "மீடியா கோப்புறைகளில் வசன வரிகளைச் சேமிக்கவும்", + "SaveChanges": "மாற்றங்களை சேமியுங்கள்", + "Save": "சேமியுங்கள்", + "Saturday": "சனிக்கிழமை", + "Runtime": "இயக்க நேரம்", + "Rewind": "முன்னோக்கிச்செலுத்து", + "ResumeAt": "{0} இலிருந்து மீண்டும் தொடங்குங்கள்", + "ReplaceExistingImages": "இருக்கும் படங்களை மாற்றவும்", + "ReplaceAllMetadata": "எல்லா மெட்டாடேட்டாவையும் மாற்றவும்", + "RepeatOne": "மீண்டும் ஒருமுறை", + "RepeatMode": "பயன்முறையை மீண்டும் செய்யவும்", + "RepeatEpisodes": "அத்தியாயங்களை மீண்டும் செய்யவும்", + "RepeatAll": "அனைத்தையும் மீண்டும் செய்யவும்", + "Repeat": "மீண்டும்", + "RemoveFromPlaylist": "பிளேலிஸ்ட்டில் இருந்து அகற்று", + "RemoveFromCollection": "சேகரிப்பிலிருந்து அகற்று", + "RememberMe": "என்னை நினைவிற்கொள்ளவும்", + "ReleaseDate": "வெளியீட்டு தேதி", + "RefreshQueued": "புதுப்பிப்பு வரிசைப்படுத்தப்பட்டுள்ளது.", + "RefreshMetadata": "மெட்டாடேட்டாவைப் புதுப்பிக்கவும்", + "RefreshDialogHelp": "டாஷ்போர்டில் இயக்கப்பட்ட அமைப்புகள் மற்றும் இணைய சேவைகளின் அடிப்படையில் மெட்டாடேட்டா புதுப்பிக்கப்படுகிறது.", + "Refresh": "புதுப்பிப்பு", + "Recordings": "பதிவுகள்", + "RecordingScheduled": "பதிவு திட்டமிடப்பட்டுள்ளது.", + "MessageChangeRecordingPath": "உங்கள் ரெக்கார்டிங் கோப்புறையை மாற்றுவது ஏற்கனவே இருக்கும் பதிவுகளை பழைய இடத்திலிருந்து புதிய இடத்திற்கு மாற்றாது. விரும்பினால் அவற்றை கைமுறையாக நகர்த்த வேண்டும்.", + "RecordingCancelled": "பதிவு ரத்து செய்யப்பட்டது.", + "RecordSeries": "தொடரை பதிவு செய்", + "Record": "பதிவு செய்", + "RecommendationStarring": "{0} நடித்த", + "RecommendationDirectedBy": "{0} ஐ இயக்கியது", + "RecommendationBecauseYouWatched": "நீங்கள் {0} பார்த்ததால்", + "RecommendationBecauseYouLike": "நீங்கள் {0} ஐ விரும்புவதால்", + "RecentlyWatched": "சமீபத்தில் பார்த்தது", + "Rate": "மதிப்பிடுங்கள்", + "Raised": "எழுப்பப்பட்ட", + "Quality": "தரம்", + "Programs": "நிகழ்ச்சிகள்", + "ProductionLocations": "தயாரிப்பு தளம்", + "Producer": "தயாரிப்பாளர்", + "Primary": "முதன்மை", + "PreviousTrack": "முந்தையதைத் தவிர்", + "Previous": "முந்தையது", + "Premieres": "பிரீமியர்ஸ்", + "Premiere": "பிரீமியர்", + "PreferEmbeddedEpisodeInfosOverFileNames": "கோப்பு பெயர்களில் உட்பொதிக்கப்பட்ட எபிசோட் தகவலை விரும்புங்கள்", + "PreferEmbeddedEpisodeInfosOverFileNamesHelp": "இது உட்பொதிக்கப்பட்ட மெட்டாடேட்டாவிலிருந்து எபிசோட் தகவலைப் பெற்றால் பயன்படுத்துகிறது.", + "PreferEmbeddedTitlesOverFileNamesHelp": "இணைய மெட்டாடேட்டா அல்லது உள்ளூர் மெட்டாடேட்டா கிடைக்காதபோது இயல்புநிலை காட்சி தலைப்பை இது தீர்மானிக்கிறது.", + "PreferEmbeddedTitlesOverFileNames": "கோப்பு பெயர்களில் உட்பொதிக்கப்பட்ட தலைப்புகளை விரும்புங்கள்", + "MessageGetInstalledPluginsError": "தற்போது நிறுவப்பட்ட செருகுநிரல்களின் பட்டியலைப் பெறும்போது பிழை ஏற்பட்டது.", + "MessagePluginInstallError": "சொருகி நிறுவும் போது பிழை ஏற்பட்டது.", + "MessagePluginInstalled": "சொருகி வெற்றிகரமாக நிறுவப்பட்டுள்ளது. மாற்றங்கள் நடைமுறைக்கு வர சேவையகத்தை மறுதொடக்கம் செய்ய வேண்டும்.", + "PleaseSelectTwoItems": "குறைந்தது இரண்டு உருப்படிகளைத் தேர்ந்தெடுக்கவும்.", + "PleaseRestartServerName": "ஜெல்லிஃபினை {0} இல் மறுதொடக்கம் செய்யுங்கள்.", + "PleaseEnterNameOrId": "ஒரு பெயர் அல்லது வெளிப்புற ஐடியை உள்ளிடவும்.", + "PleaseConfirmPluginInstallation": "மேலே உள்ளதைப் படித்திருப்பதை உறுதிப்படுத்த சரி என்பதைக் கிளிக் செய்து, சொருகி நிறுவலைத் தொடர விரும்புகிறீர்கள்.", + "PleaseAddAtLeastOneFolder": "சேர் பொத்தானைக் கிளிக் செய்வதன் மூலம் இந்த நூலகத்தில் குறைந்தது ஒரு கோப்புறையாவது சேர்க்கவும்.", + "Played": "வாசிக்கப்பட்டது", + "PlaybackErrorNoCompatibleStream": "இந்த கிளையன்ட் ஊடகத்துடன் பொருந்தாது மற்றும் சேவையகம் இணக்கமான ஊடக வடிவமைப்பை அனுப்பவில்லை.", + "PlayNextEpisodeAutomatically": "அடுத்த அத்தியாயத்தை தானாக இயக்கு", + "PlayNext": "அடுத்ததை வாசிக்கவும்" } From 318ade8bbe0f8fd736ff57e886fdb1a453b35ee7 Mon Sep 17 00:00:00 2001 From: Oatavandi Date: Sat, 15 Aug 2020 16:33:27 +0000 Subject: [PATCH 266/301] Translated using Weblate (Tamil) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/ta/ --- src/strings/ta.json | 117 +++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 116 insertions(+), 1 deletion(-) diff --git a/src/strings/ta.json b/src/strings/ta.json index edb5806508..20d99250fb 100644 --- a/src/strings/ta.json +++ b/src/strings/ta.json @@ -1352,5 +1352,120 @@ "Played": "வாசிக்கப்பட்டது", "PlaybackErrorNoCompatibleStream": "இந்த கிளையன்ட் ஊடகத்துடன் பொருந்தாது மற்றும் சேவையகம் இணக்கமான ஊடக வடிவமைப்பை அனுப்பவில்லை.", "PlayNextEpisodeAutomatically": "அடுத்த அத்தியாயத்தை தானாக இயக்கு", - "PlayNext": "அடுத்ததை வாசிக்கவும்" + "PlayNext": "அடுத்ததை வாசிக்கவும்", + "Yesterday": "நேற்று", + "Yes": "ஆம்", + "YadifBob": "யடிஃப் பாப்", + "Yadif": "யடிஃப்", + "XmlTvSportsCategoriesHelp": "இந்த வகைகளைக் கொண்ட நிகழ்ச்சிகள் விளையாட்டுத் திட்டங்களாகக் காட்டப்படும். '|' உடன் பலவற்றைப் பிரிக்கவும்.", + "XmlTvPathHelp": "XMLTV கோப்புக்கான பாதை. ஜெல்லிஃபின் இந்த கோப்பைப் படித்து புதுப்பிப்புகளுக்கு அவ்வப்போது சரிபார்க்கும். கோப்பை உருவாக்கி புதுப்பிக்க நீங்கள் பொறுப்பு.", + "XmlTvNewsCategoriesHelp": "இந்த வகைகளைக் கொண்ட நிகழ்ச்சிகள் செய்தித் திட்டங்களாகக் காட்டப்படும். '|' உடன் பலவற்றைப் பிரிக்கவும்.", + "XmlTvMovieCategoriesHelp": "இந்த வகைகளைக் கொண்ட நிகழ்ச்சிகள் திரைப்படங்களாக காண்பிக்கப்படும். '|' உடன் பலவற்றைப் பிரிக்கவும்.", + "XmlTvKidsCategoriesHelp": "இந்த வகைகளைக் கொண்ட நிகழ்ச்சிகள் குழந்தைகளுக்கான நிரல்களாக காண்பிக்கப்படும். '|' உடன் பலவற்றைப் பிரிக்கவும்.", + "XmlDocumentAttributeListHelp": "இந்த பண்புக்கூறுகள் ஒவ்வொரு XML பதிலின் மூல உறுப்புக்கும் பயன்படுத்தப்படுகின்றன.", + "Writers": "எழுத்தாளர்கள்", + "Writer": "எழுத்தாளர்", + "WizardCompleted": "இப்போது நமக்குத் தேவை அவ்வளவுதான். ஜெல்லிஃபின் உங்கள் ஊடக நூலகம் பற்றிய தகவல்களை சேகரிக்கத் தொடங்கியுள்ளார். எங்கள் சில பயன்பாடுகளைப் பாருங்கள், பின்னர் டாஷ்போர்டு ஐக் காண பினிஷ் என்பதைக் கிளிக் செய்க.", + "Whitelist": "அனுமதிப்பட்டியல்", + "WelcomeToProject": "ஜெல்லிஃபினுக்கு வருக!", + "Wednesday": "புதன்கிழமை", + "Watched": "ஏற்கனவே பார்த்தேன்", + "ViewPlaybackInfo": "பின்னணி தகவலைக் காண்க", + "ViewAlbumArtist": "ஆல்பம் கலைஞரைக் காண்க", + "ViewAlbum": "ஆல்பத்தைக் காண்க", + "Vertical": "செங்குத்தாக", + "ValueVideoCodec": "வீடியோ கோடெக்: {0}", + "ValueTimeLimitSingleHour": "கால எல்லை: 1 மணி நேரம்", + "ValueTimeLimitMultiHour": "கால எல்லை: {0} மணி", + "ValueSongCount": "{0} பாடல்கள்", + "ValueSeriesCount": "{0} தொடர்", + "ValueSeconds": "{0} விநாடிகள்", + "ValueOneSong": "1 பாடல்", + "ValueOneSeries": "1 தொடர்", + "ValueOneMusicVideo": "1 இசை வீடியோ", + "ValueOneMovie": "1 திரைப்படம்", + "ValueOneEpisode": "1 அத்தியாயம்", + "ValueOneAlbum": "1 ஆல்பம்", + "ValueMusicVideoCount": "{0} இசை வீடியோக்கள்", + "ValueMovieCount": "{0} திரைப்படங்கள்", + "ValueMinutes": "{0} நிமிடம்", + "ValueEpisodeCount": "{0} அத்தியாயங்கள்", + "ValueDiscNumber": "வட்டு {0}", + "ValueContainer": "கொள்கலன்: {0}", + "ValueConditions": "நிபந்தனைகள்: {0}", + "ValueCodec": "கோடெக்: {0}", + "ValueAudioCodec": "ஆடியோ கோடெக்: {0}", + "ValueAlbumCount": "{0} ஆல்பங்கள்", + "UserProfilesIntro": "சிறுமணி காட்சி அமைப்புகள், விளையாட்டு நிலை மற்றும் பெற்றோரின் கட்டுப்பாடுகள் ஆகியவற்றைக் கொண்ட பயனர் சுயவிவரங்களுக்கான ஆதரவை ஜெல்லிஃபின் கொண்டுள்ளது.", + "UserAgentHelp": "தனிப்பயன் பயனர் முகவர் HTTP தலைப்பை வழங்கவும்.", + "Upload": "பதிவேற்றவும்", + "Up": "மேலே", + "Unrated": "மதிப்பிடப்படாதது", + "Unplayed": "காட்டப்படாதது", + "Unmute": "முடக்கு நீக்கம்", + "HeaderUninstallPlugin": "செருகுநிரலை நிறுவல் நீக்கு", + "UninstallPluginConfirmation": "{0} ஐ நிறுவல் நீக்க விரும்புகிறீர்களா?", + "Uniform": "சீராக", + "TvLibraryHelp": "{0} டிவி பெயரிடும் வழிகாட்டியை {1} மதிப்பாய்வு செய்யவும்.", + "Tuesday": "செவ்வாய்", + "Transcoding": "டிரான்ஸ்கோடிங்", + "Trailers": "டிரெய்லர்கள்", + "TrackCount": "{0} தடங்கள்", + "Track": "தடம்", + "TitlePlayback": "பின்னணி", + "TitleHostingSettings": "ஹோஸ்டிங் அமைப்புகள்", + "TitleHardwareAcceleration": "வன்பொருள் முடுக்கம்", + "Thursday": "வியாழக்கிழமை", + "Thumb": "சிறுபடம்", + "ThisWizardWillGuideYou": "இந்த வழிகாட்டி அமைவு செயல்முறை மூலம் உங்களுக்கு வழிகாட்ட உதவும். தொடங்க, நீங்கள் விரும்பும் மொழியைத் தேர்ந்தெடுக்கவும்.", + "TheseSettingsAffectSubtitlesOnThisDevice": "இந்த அமைப்புகள் இந்த சாதனத்தில் வசன வரிகள் பாதிக்கின்றன", + "ThemeVideos": "தீம் வீடியோக்கள்", + "ThemeSongs": "தீம் பாடல்கள்", + "TellUsAboutYourself": "உங்களைப் பற்றி சொல்லுங்கள்", + "TagsValue": "குறிச்சொற்கள்: {0}", + "Tags": "குறிச்சொற்கள்", + "TabUpcoming": "வரவிருக்கும்", + "TabTrailers": "டிரெய்லர்கள்", + "TabStreaming": "ஸ்ட்ரீமிங்", + "TabSettings": "அமைப்புகள்", + "TabServer": "சேவையகம்", + "TabScheduledTasks": "திட்டமிடப்பட்ட பணிகள்", + "TabResumeSettings": "மீண்டும் தொடர்", + "TabResponses": "பதில்கள்", + "TabProfiles": "சுயவிவரங்கள்", + "TabProfile": "சுயவிவரம்", + "TabPlugins": "செருகுநிரல்கள்", + "TabParentalControl": "பெற்றோர் கட்டுப்பாடு", + "TabOther": "மற்றவை", + "TabNotifications": "அறிவிப்புகள்", + "TabNfoSettings": "NFO அமைப்புகள்", + "TabNetworking": "நெட்வொர்க்கிங்", + "TabNetworks": "நெட்வொர்க்குகள்", + "TabMyPlugins": "எனது செருகுநிரல்கள்", + "TabMusicVideos": "இசை கானொளி", + "TabMusic": "இசை", + "TabLogs": "பதிவுகள்", + "TabLatest": "அண்மை", + "TabInfo": "தகவல்", + "TabEpisodes": "அத்தியாயங்கள்", + "TabDirectPlay": "நேரடி நாடகம்", + "TabDashboard": "டாஷ்போர்டு", + "TabContainers": "கொள்கலன்கள்", + "TabCodecs": "கோடெக்குகள்", + "TabRepositories": "களஞ்சியங்கள்", + "TabCatalog": "அட்டவணை", + "TabAlbumArtists": "ஆல்பம் கலைஞர்கள்", + "TabAdvanced": "மேம்படுத்தபட்ட", + "TabAccess": "அணுகல்", + "TV": "தொலைக்காட்சி", + "SystemDlnaProfilesHelp": "கணினி சுயவிவரங்கள் படிக்க மட்டுமே. கணினி சுயவிவரத்திற்கான மாற்றங்கள் புதிய தனிப்பயன் சுயவிவரத்தில் சேமிக்கப்படும்.", + "SyncPlayAccessHelp": "இந்த பயனர் ஒத்திசைவு அம்சத்திற்கு அணுகல் அளவைத் தேர்ந்தெடுக்கவும். ஒத்திசைவு பிளேபேக்கை பிற சாதனங்களுடன் ஒத்திசைக்க உதவுகிறது.", + "Sunday": "ஞாயிற்றுக்கிழமை", + "Suggestions": "பரிந்துரைகள்", + "Subtitles": "வசன வரிகள்", + "SubtitleOffset": "வசன ஆஃப்செட்", + "SubtitleDownloadersHelp": "முன்னுரிமைக்கு ஏற்ப உங்களுக்கு விருப்பமான வசன பதிவிறக்கிகளை இயக்கவும் தரவரிசைப்படுத்தவும்.", + "SubtitleAppearanceSettingsDisclaimer": "இந்த அமைப்புகள் வரைகலை வசன வரிகள் (PGD, DVD போன்றவை) அல்லது அவற்றின் சொந்த பாணியை உட்பொதிக்கும் ASS/SSA வசன வரிகள் பொருந்தாது.", + "SubtitleAppearanceSettingsAlsoPassedToCastDevices": "இந்தச் சாதனத்தால் தொடங்கப்பட்ட எந்த Chromecast இயக்கத்திற்கும் இந்த அமைப்புகள் பொருந்தும்.", + "Studios": "ஸ்டுடியோக்கள்" } From a00aba31d6375ca07574e9b514aedd712a610003 Mon Sep 17 00:00:00 2001 From: Oatavandi Date: Sat, 15 Aug 2020 17:06:51 +0000 Subject: [PATCH 267/301] Translated using Weblate (Tamil) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/ta/ --- src/strings/ta.json | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/src/strings/ta.json b/src/strings/ta.json index 20d99250fb..35c4f265b7 100644 --- a/src/strings/ta.json +++ b/src/strings/ta.json @@ -1467,5 +1467,6 @@ "SubtitleDownloadersHelp": "முன்னுரிமைக்கு ஏற்ப உங்களுக்கு விருப்பமான வசன பதிவிறக்கிகளை இயக்கவும் தரவரிசைப்படுத்தவும்.", "SubtitleAppearanceSettingsDisclaimer": "இந்த அமைப்புகள் வரைகலை வசன வரிகள் (PGD, DVD போன்றவை) அல்லது அவற்றின் சொந்த பாணியை உட்பொதிக்கும் ASS/SSA வசன வரிகள் பொருந்தாது.", "SubtitleAppearanceSettingsAlsoPassedToCastDevices": "இந்தச் சாதனத்தால் தொடங்கப்பட்ட எந்த Chromecast இயக்கத்திற்கும் இந்த அமைப்புகள் பொருந்தும்.", - "Studios": "ஸ்டுடியோக்கள்" + "Studios": "ஸ்டுடியோக்கள்", + "PathNotFound": "பாதை கண்டுபிடிக்க முடியவில்லை. பாதை செல்லுபடியாகும் என்பதை உறுதிசெய்து மீண்டும் முயற்சிக்கவும்." } From bce3f7f408a61a890c7443ad2a05ecdd6453e35b Mon Sep 17 00:00:00 2001 From: Oatavandi Date: Sat, 15 Aug 2020 17:07:03 +0000 Subject: [PATCH 268/301] Translated using Weblate (Tamil) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/ta/ --- src/strings/ta.json | 23 ++++++++++++++++++++++- 1 file changed, 22 insertions(+), 1 deletion(-) diff --git a/src/strings/ta.json b/src/strings/ta.json index 35c4f265b7..d31fb8872e 100644 --- a/src/strings/ta.json +++ b/src/strings/ta.json @@ -1468,5 +1468,26 @@ "SubtitleAppearanceSettingsDisclaimer": "இந்த அமைப்புகள் வரைகலை வசன வரிகள் (PGD, DVD போன்றவை) அல்லது அவற்றின் சொந்த பாணியை உட்பொதிக்கும் ASS/SSA வசன வரிகள் பொருந்தாது.", "SubtitleAppearanceSettingsAlsoPassedToCastDevices": "இந்தச் சாதனத்தால் தொடங்கப்பட்ட எந்த Chromecast இயக்கத்திற்கும் இந்த அமைப்புகள் பொருந்தும்.", "Studios": "ஸ்டுடியோக்கள்", - "PathNotFound": "பாதை கண்டுபிடிக்க முடியவில்லை. பாதை செல்லுபடியாகும் என்பதை உறுதிசெய்து மீண்டும் முயற்சிக்கவும்." + "PathNotFound": "பாதை கண்டுபிடிக்க முடியவில்லை. பாதை செல்லுபடியாகும் என்பதை உறுதிசெய்து மீண்டும் முயற்சிக்கவும்.", + "SubtitleVerticalPositionHelp": "உரை தோன்றும் வரி எண். நேர்மறை எண்கள் மேல் கீழே குறிக்கின்றன. எதிர்மறை எண்கள் கீழே மேலே குறிக்கின்றன.", + "LabelSubtitleVerticalPosition": "செங்குத்து நிலை:", + "ClearQueue": "வரிசையை அழிக்கவும்", + "StopPlayback": "பிளேபேக்கை நிறுத்துங்கள்", + "ButtonPlayer": "பிளேயர்", + "ButtonCast": "நடிகர்கள்", + "ButtonSyncPlay": "ஒத்திசைவு", + "EnableBlurHashHelp": "இன்னும் ஏற்றப்படும் படங்கள் தனித்துவமான ஒதுக்கிடத்துடன் காண்பிக்கப்படும்.", + "EnableBlurHash": "படங்களுக்கு மங்கலான ஒதுக்கிடங்களை இயக்கவும்", + "UnsupportedPlayback": "DRM ஆல் பாதுகாக்கப்பட்ட உள்ளடக்கத்தை ஜெல்லிஃபின் டிக்ரிப்ட் செய்ய முடியாது, ஆனால் பாதுகாக்கப்பட்ட தலைப்புகள் உட்பட எல்லா உள்ளடக்கமும் பொருட்படுத்தாமல் முயற்சிக்கப்படும். குறியாக்கம் அல்லது ஊடாடும் தலைப்புகள் போன்ற பிற ஆதரிக்கப்படாத அம்சங்கள் காரணமாக சில கோப்புகள் முற்றிலும் கருப்பு நிறத்தில் தோன்றக்கூடும்.", + "OnApplicationStartup": "பயன்பாட்டு தொடக்கத்தில்", + "EveryXHours": "ஒவ்வொரு {0} மணி நேரமும்", + "EveryHour": "ஒவ்வொரு மணி நேரமும்", + "EveryXMinutes": "ஒவ்வொரு {0} நிமிடங்களும்", + "OnWakeFromSleep": "தூக்கத்திலிருந்து எழுந்தவுடன்", + "WeeklyAt": "{1} இல் {0}", + "DailyAt": "தினசரி {0}", + "LastSeen": "கடைசியாக பார்த்தது {0}", + "PersonRole": "{0} என", + "ListPaging": "{0} - {2} இன் {1}", + "WriteAccessRequired": "ஜெல்லிஃபினுக்கு இந்த கோப்புறையில் எழுத அணுகல் தேவை. எழுதும் அணுகலை உறுதிசெய்து மீண்டும் முயற்சிக்கவும்." } From 5e87c87c023f3befc0ae19819ef1bd3e31a5f278 Mon Sep 17 00:00:00 2001 From: Cameron Date: Sun, 16 Aug 2020 12:17:37 +0100 Subject: [PATCH 269/301] Update plugin.js --- src/plugins/sessionPlayer/plugin.js | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/src/plugins/sessionPlayer/plugin.js b/src/plugins/sessionPlayer/plugin.js index d4cbb8345f..cbeb6f34b4 100644 --- a/src/plugins/sessionPlayer/plugin.js +++ b/src/plugins/sessionPlayer/plugin.js @@ -450,6 +450,9 @@ class SessionPlayer { }); } + getRepeatMode() { + } + setQueueShuffleMode(mode) { sendCommandByName(this, 'SetShuffleQueue', { ShuffleMode: mode @@ -484,6 +487,9 @@ class SessionPlayer { return Promise.resolve([]); } + getCurrentPlaylistItemId() { + } + setCurrentPlaylistItem(playlistItemId) { return Promise.resolve(); } From f62014a2d4bca871afd8e9c916cb934ec8276933 Mon Sep 17 00:00:00 2001 From: Cameron Date: Sun, 16 Aug 2020 12:19:38 +0100 Subject: [PATCH 270/301] Update plugin.js --- src/plugins/experimentalWarnings/plugin.js | 2 -- 1 file changed, 2 deletions(-) diff --git a/src/plugins/experimentalWarnings/plugin.js b/src/plugins/experimentalWarnings/plugin.js index 7450040541..bc301f01af 100644 --- a/src/plugins/experimentalWarnings/plugin.js +++ b/src/plugins/experimentalWarnings/plugin.js @@ -2,8 +2,6 @@ import globalize from 'globalize'; import * as userSettings from 'userSettings'; import appHost from 'apphost'; -/*eslint prefer-const: "error"*/ - // TODO: Replace with date-fns // https://stackoverflow.com/questions/6117814/get-week-of-year-in-javascript-like-in-php function getWeek(date) { From bc8303aabc2ff6cf6d58e4418bd3c941f54bfc4c Mon Sep 17 00:00:00 2001 From: Dmitry Lyzo Date: Sun, 16 Aug 2020 12:23:07 +0000 Subject: [PATCH 271/301] Translated using Weblate (Russian) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/ru/ --- src/strings/ru.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/strings/ru.json b/src/strings/ru.json index 9989a4c47e..14fb04f16f 100644 --- a/src/strings/ru.json +++ b/src/strings/ru.json @@ -23,7 +23,7 @@ "AllowMediaConversionHelp": "Предоставить или запретить доступ к компоненте преобразования медиаданных.", "AllowOnTheFlySubtitleExtraction": "Разрешить динамическое извлечение субтитров", "AllowOnTheFlySubtitleExtractionHelp": "Встроенные субтитры могут быть извлечены из видео и доставлены клиентам в виде обычного текста, в целях предотвращения перекодировки видео. На некоторых системах это может занять продолжительное время и вызвать задержки воспроизведения видео в процессе извлечения. Отключите этот параметр, чтобы встроенные субтитры записывались при перекодировании видео, если они изначально не поддерживаются клиентским устройством.", - "AllowRemoteAccess": "Разрешить удалённый доступ к данному серверу Jellyfin Server.", + "AllowRemoteAccess": "Разрешить удалённый доступ к данному серверу.", "AllowRemoteAccessHelp": "Если флажок снят, то все удалённые подключения будут заблокированы.", "AllowedRemoteAddressesHelp": "Список разделённых запятыми IP-адресов или записей IP/netmask сетей, которым разрешено удалённое соединение. Если оставить это поле пустым, то будут разрешены все удаленные адреса.", "AlwaysPlaySubtitles": "Воспроизводить всегда", From e7a4cc28c7ff7c51c6cfaf41b71f67ce6e886430 Mon Sep 17 00:00:00 2001 From: MrTimscampi Date: Sun, 16 Aug 2020 15:07:47 +0200 Subject: [PATCH 272/301] Remove chromecastHelper definition --- src/scripts/site.js | 1 - 1 file changed, 1 deletion(-) diff --git a/src/scripts/site.js b/src/scripts/site.js index 14f9851adc..3f97826743 100644 --- a/src/scripts/site.js +++ b/src/scripts/site.js @@ -655,7 +655,6 @@ function initClient() { pluginManager: componentsPath + '/pluginManager', packageManager: componentsPath + '/packageManager', screensaverManager: componentsPath + '/screensavermanager', - chromecastHelper: 'plugins/chromecastPlayer/chromecastHelpers', appRouter: 'components/appRouter' }; From db3773dbc37f79a0e20646d3643b792d150c0a67 Mon Sep 17 00:00:00 2001 From: Dmitry Lyzo Date: Sun, 16 Aug 2020 12:45:23 +0000 Subject: [PATCH 273/301] Translated using Weblate (Russian) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/ru/ --- src/strings/ru.json | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/src/strings/ru.json b/src/strings/ru.json index 14fb04f16f..a3aabd93c3 100644 --- a/src/strings/ru.json +++ b/src/strings/ru.json @@ -204,7 +204,7 @@ "EndsAtValue": "Конец в {0}", "Episodes": "Эпизоды", "ErrorAddingListingsToSchedulesDirect": "Произошла ошибка добавления списка сопоставления в учётную запись Schedules Direct. В Schedules Direct разрешено только ограниченное число таких списков на каждую учётную запись. Вам может понадобится войти на сайт Schedules Direct, и изъять иные перечни из своей учётной записи, прежде чем приступить.", - "ErrorAddingMediaPathToVirtualFolder": "Произошла ошибка при добавлении пути к медиаданным. Убедитесь, что путь является действительным, а процесс Jellyfin Server имеет доступ к этому расположению.", + "ErrorAddingMediaPathToVirtualFolder": "Произошла ошибка при добавлении пути к медиаданным. Убедитесь, что путь действителен и Jellyfin имеет доступ к этому расположению.", "ErrorAddingTunerDevice": "Произошла ошибка при добавлении тюнерного устройства. Убедитесь, что оно доступно и повторите попытку.", "ErrorAddingXmlTvFile": "Произошла ошибка при доступе к XMLTV-файлу. Убедитесь, что файл существует и повторите попытку.", "ErrorDeletingItem": "Произошла ошибка при удалении элемента с Jellyfin Server. Проверьте, что у Jellyfin Server имеется доступ на запись в медиапапку и повторите попытку.", @@ -1473,5 +1473,7 @@ "LabelUnstable": "Нестабильная", "LabelSubtitleVerticalPosition": "Вертикальная позиция:", "SubtitleVerticalPositionHelp": "Номер строки, где появляется текст. Положительные числа означают сверху вниз. Отрицательные числа означают снизу вверх.", - "Preview": "Предварительный просмотр" + "Preview": "Предварительный просмотр", + "MessageGetInstalledPluginsError": "Произошла ошибка при получении списка установленных плагинов.", + "MessagePluginInstallError": "Во время установки плагина произошла ошибка." } From 7756b3164b3808660341ab2021061381ddace931 Mon Sep 17 00:00:00 2001 From: MrTimscampi Date: Sun, 16 Aug 2020 15:46:29 +0200 Subject: [PATCH 274/301] Fix suggestions --- src/components/packageManager.js | 4 ++-- src/components/pluginManager.js | 2 -- 2 files changed, 2 insertions(+), 4 deletions(-) diff --git a/src/components/packageManager.js b/src/components/packageManager.js index c20f6c5d3e..2a15a14f34 100644 --- a/src/components/packageManager.js +++ b/src/components/packageManager.js @@ -73,11 +73,11 @@ import pluginManager from 'pluginManager'; } addPackage(pkg) { - this.packagesList = this.packagesList.filter((p) => { + this.#packagesList = this.#packagesList.filter((p) => { return p.name !== pkg.name; }); - this.packagesList.push(pkg); + this.#packagesList.push(pkg); } removeUrl(url) { diff --git a/src/components/pluginManager.js b/src/components/pluginManager.js index b662cca836..55a5c230ff 100644 --- a/src/components/pluginManager.js +++ b/src/components/pluginManager.js @@ -135,8 +135,6 @@ import globalize from 'globalize'; })[0]; } - console.dir(plugin); - var url = plugin.baseUrl + '/' + path; if (addCacheParam) { From ea41aeaa2bfff1de4dff23cb6104306a68a0ec0d Mon Sep 17 00:00:00 2001 From: Ian Walton Date: Sun, 16 Aug 2020 13:37:25 -0400 Subject: [PATCH 275/301] Fix syncplay menu. (Single line fix.) --- src/scripts/libraryMenu.js | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/scripts/libraryMenu.js b/src/scripts/libraryMenu.js index d67250d5cb..700fb52ad9 100644 --- a/src/scripts/libraryMenu.js +++ b/src/scripts/libraryMenu.js @@ -8,7 +8,7 @@ import appRouter from 'appRouter'; import appHost from 'apphost'; import playbackManager from 'playbackManager'; import syncPlayManager from 'syncPlayManager'; -import { show as showGroupSelectionMenu } from 'groupSelectionMenu'; +import * as groupSelectionMenu from 'groupSelectionMenu'; import browser from 'browser'; import globalize from 'globalize'; import imageHelper from 'scripts/imagehelper'; @@ -208,7 +208,7 @@ import 'flexStyles'; function onSyncButtonClicked() { const btn = this; - showGroupSelectionMenu(btn); + groupSelectionMenu.show(btn); } function onSyncPlayEnabled(event, enabled) { From bc6a1d5734c3b5a688d12d20387b1670c71814cd Mon Sep 17 00:00:00 2001 From: MrTimscampi Date: Sun, 16 Aug 2020 21:14:18 +0200 Subject: [PATCH 276/301] Fix linting issue --- src/components/appRouter.js | 33 --------------------------------- 1 file changed, 33 deletions(-) diff --git a/src/components/appRouter.js b/src/components/appRouter.js index 9734925657..28826c55cc 100644 --- a/src/components/appRouter.js +++ b/src/components/appRouter.js @@ -692,18 +692,12 @@ class AppRouter { return 'dashboard.html'; } -<<<<<<< HEAD - function show(path, options) { - if (path.indexOf('/') !== 0 && path.indexOf('://') === -1) { - path = '/' + path; -======= if (item === 'recordedtv') { return 'livetv.html?tab=3&serverId=' + options.serverId; } if (item === 'nextup') { return 'list.html?type=nextup&serverId=' + options.serverId; ->>>>>>> upstream/master } if (item === 'list') { @@ -851,31 +845,4 @@ class AppRouter { } } -<<<<<<< HEAD - appRouter.addRoute = addRoute; - appRouter.param = param; - appRouter.back = back; - appRouter.show = show; - appRouter.start = start; - appRouter.baseUrl = baseUrl; - appRouter.canGoBack = canGoBack; - appRouter.current = current; - appRouter.beginConnectionWizard = beginConnectionWizard; - appRouter.invokeShortcut = invokeShortcut; - appRouter.showItem = showItem; - appRouter.setTransparency = setTransparency; - appRouter.getRoutes = getRoutes; - appRouter.pushState = pushState; - appRouter.enableNativeHistory = enableNativeHistory; - appRouter.handleAnchorClick = page.clickHandler; - appRouter.TransparencyLevel = { - None: 0, - Backdrop: 1, - Full: 2 - }; - - return appRouter; -}); -======= export default new AppRouter(); ->>>>>>> upstream/master From 92531427df800276b473442793c94294f6ca4d90 Mon Sep 17 00:00:00 2001 From: Professor Vogelbloem Date: Sun, 16 Aug 2020 21:01:29 +0000 Subject: [PATCH 277/301] Translated using Weblate (Dutch) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/nl/ --- src/strings/nl.json | 20 ++++++++++---------- 1 file changed, 10 insertions(+), 10 deletions(-) diff --git a/src/strings/nl.json b/src/strings/nl.json index 8d5e5c78a4..81a74fcb2c 100644 --- a/src/strings/nl.json +++ b/src/strings/nl.json @@ -22,7 +22,7 @@ "AllowMediaConversionHelp": "Toegang verlenen of weigeren tot de mediaconversie functie.", "AllowOnTheFlySubtitleExtraction": "Directe ondertitel extractie toestaan", "AllowOnTheFlySubtitleExtractionHelp": "Ingebakken ondertitels kunnen uit de video's gehaald worden en als tekst bezorgd worden aan de clients om transcodering te helpen voorkomen. Op sommige systemen kan dit een lange tijd duren en dit er voor zorgen dat het afspelen van video stopt tijdens de extractie. Schakel dit uit om ingebakken ondertiteling in de video te laten branden met transcodering als deze niet standaard ondersteund worden door het afspeelapparaat.", - "AllowRemoteAccess": "Externe verbindingen met deze Jellyfin Server toestaan.", + "AllowRemoteAccess": "Externe verbindingen met deze server toestaan.", "AllowRemoteAccessHelp": "Indien niet aangevinkt worden alle externe verbindingen geblokkeerd.", "AllowedRemoteAddressesHelp": "Komma-gescheiden lijst van IP-adressen of IP/netmask adressen voor netwerken die op afstand verbinding mogen maken. Indien blanco, worden alle externe adressen toegestaan.", "AlwaysPlaySubtitles": "Altijd afspelen", @@ -189,10 +189,10 @@ "EndsAtValue": "Eindigt om {0}", "Episodes": "Afleveringen", "ErrorAddingListingsToSchedulesDirect": "Er ging iets mis bij het toevoegen van de lineup aan uw Schedules Direct account. Schedules Direct staat maar een beperkt aantal lineups per account toe. Het kan nodig zijn dat u zich aan moet melden op de Schedules Direct website en andere lineups moet verwijderen voordat u verder kunt.", - "ErrorAddingMediaPathToVirtualFolder": "Er ging iets mis bij het toevoegen van het media pad. Controleer of het pad klopt en of het Jellyfin server process toegang heeft tot het pad.", + "ErrorAddingMediaPathToVirtualFolder": "Er ging iets mis bij het toevoegen van het media pad. Controleer of het pad klopt en of Jellyfin toegang heeft tot de locatie.", "ErrorAddingTunerDevice": "Er was een fout bij het toevoegen van de tuner. Controleer of deze toegankelijk is en probeer het opnieuw.", "ErrorAddingXmlTvFile": "Er is een fout opgetreden met de toegang tot XMLTV bestand. Zorg ervoor dat het bestand bestaat en probeer het opnieuw.", - "ErrorDeletingItem": "Er was een probleem bij het verwijderen van het item in Jellyfin Server. Controleer dat Jellyfin Server schrijfrechten op de map heeft en probeer het opnieuw.", + "ErrorDeletingItem": "Er was een probleem bij het verwijderen van het item in de server. Controleer of Jellyfin schrijfrechten op de map heeft en probeer het opnieuw.", "ErrorGettingTvLineups": "Er was een fout bij het downloaden van de TV lineup. Controleer of uw gegevens correct zijn en probeer het opnieuw.", "ErrorStartHourGreaterThanEnd": "Eind tijd moet na de start tijd liggen.", "ErrorPleaseSelectLineup": "Selecteer een lineup en probeer het opnieuw. Als er geen lineups beschibaar zijn, controleer dan of uw gebruikersnaam, wachtwoord en postcode correct zijn.", @@ -424,7 +424,7 @@ "Identify": "Identificeer", "Images": "Afbeeldingen", "ImportFavoriteChannelsHelp": "Alleen kanalen die als favoriet aangemerkt zijn op de tuner zullen geïmporteerd worden.", - "ImportMissingEpisodesHelp": "Indien ingeschakeld, wordt informatie over ontbrekende afleveringen in uw Jellyfin de database geïmporteerd en weergegeven in de seizoenen en series. Dit kan aanzienlijk langere bibliotheekscans veroorzaken.", + "ImportMissingEpisodesHelp": "Informatie over ontbrekende afleveringen zal in uw database worden geïmporteerd en weergegeven in seizoenen en series. Dit kan aanzienlijk langere bibliotheekscans veroorzaken.", "InstallingPackage": "Installeren van {0} (versie {1})", "Kids": "Kinderen", "Label3DFormat": "3D formaat:", @@ -454,7 +454,7 @@ "LabelAudioLanguagePreference": "Voorkeurs audiotaal:", "LabelAutomaticallyRefreshInternetMetadataEvery": "Vernieuw metagegevens automatisch van het internet:", "LabelBindToLocalNetworkAddress": "Binden aan het lokale netwerk adres:", - "LabelBindToLocalNetworkAddressHelp": "Optioneel. Overrule het lokale IP-adres om aan de http-server te binden. Indien leeg gelaten, zal de server binden aan alle beschikbare adressen. Het veranderen van deze waarde vereist herstarten van Jellyfin Server.", + "LabelBindToLocalNetworkAddressHelp": "Overschrijf het lokale IP-adres voor de HTTP server. Indien leeg gelaten, zal de server binden aan alle beschikbare adressen. Het veranderen van deze waarde vereist een herstart.", "LabelBirthDate": "Geboortedatum:", "LabelBirthYear": "Geboorte jaar:", "LabelBlastMessageInterval": "Alive bericht interval", @@ -511,7 +511,7 @@ "LabelEnableBlastAliveMessages": "Alive berichten zenden", "LabelEnableBlastAliveMessagesHelp": "Zet dit aan als de server niet betrouwbaar door andere UPnP-apparaten op uw netwerk wordt gedetecteerd.", "LabelEnableDlnaClientDiscoveryInterval": "Interval voor het zoeken naar clients", - "LabelEnableDlnaClientDiscoveryIntervalHelp": "Bepaalt de duur in seconden tussen SSDP zoekopdrachten uitgevoerd door Jellyfin.", + "LabelEnableDlnaClientDiscoveryIntervalHelp": "Bepaalt de duur in seconden tussen SSDP zoekopdrachten.", "LabelEnableDlnaDebugLogging": "DLNA foutopsporings logboek inschakelen", "LabelEnableDlnaDebugLoggingHelp": "Genereer grote logboekbestanden en is alleen bedoeld voor het troubleshooting doeleinden.", "LabelEnableDlnaPlayTo": "DLNA \"Play To\" inschakelen", @@ -625,7 +625,7 @@ "LabelNumberOfGuideDays": "Aantal dagen van de gids om te downloaden:", "LabelNumberOfGuideDaysHelp": "Het downloaden van meer dagen van de gids gegevens biedt de mogelijkheid verder vooruit te plannen en een beter overzicht geven, maar het zal ook langer duren om te downloaden. Auto kiest op basis van het aantal kanalen.", "LabelOptionalNetworkPath": "Gedeelde netwerkmap:", - "LabelOptionalNetworkPathHelp": "Als deze map wordt gedeeld op uw netwerk, kunnen middels het netwerkpad Jellyfin apps op andere apparaten rechtstreeks toegang tot mediabestanden krijgen. Bijvoorbeeld {0} or {1}.", + "LabelOptionalNetworkPathHelp": "Als deze map wordt gedeeld op uw netwerk, kunnen middels het netwerkpad clients op andere apparaten rechtstreeks toegang tot mediabestanden krijgen. Bijvoorbeeld {0} of {1}.", "LabelOriginalAspectRatio": "Originele aspect ratio:", "LabelOriginalTitle": "Orginele titel:", "LabelOverview": "Overzicht:", @@ -776,13 +776,13 @@ "MessageConfirmProfileDeletion": "Weet u zeker dat u dit profiel wilt verwijderen?", "MessageConfirmRecordingCancellation": "Opname annuleren?", "MessageConfirmRemoveMediaLocation": "Weet u zeker dat u deze locatie wilt verwijderen?", - "MessageConfirmRestart": "Weet u zeker dat u Jellyfin Server wilt herstarten?", - "MessageConfirmRevokeApiKey": "Weet u zeker dat u deze api sleutel in wilt trekken? De verbinding met Jellyfin Server zal direct verbroken worden.", + "MessageConfirmRestart": "Weet u zeker dat u Jellyfin wilt herstarten?", + "MessageConfirmRevokeApiKey": "Weet u zeker dat u deze API sleutel in wilt trekken? De verbinding van de applicatie met deze server zal plotseling verbroken worden.", "MessageConfirmShutdown": "Weet u zeker dat u de server wilt afsluiten?", "MessageContactAdminToResetPassword": "Neem contact op met de server beheerder om uw wachtwoord te resetten.", "MessageCreateAccountAt": "Maak een account bij {0}", "MessageDeleteTaskTrigger": "Weet u zeker dat u deze signaal taak wilt verwijderen?", - "MessageDirectoryPickerBSDInstruction": "Voor BSD kan het noodzakelijk zijn opslag op uw FreeNAS Jail te configureren voordat Jellyfin het kan benaderen.", + "MessageDirectoryPickerBSDInstruction": "Voor BSD moet u mogelijk de opslag in uw FreeNAS Jail configureren, zodat Jellyfin toegang heeft tot uw media.", "MessageDirectoryPickerLinuxInstruction": "Voor Linux op Arch Linux, CentOS, Debian, Fedora, openSUSE, of Ubuntu, moet u de service-gebruiker ten minste leestoegang tot uw opslaglocaties verlenen.", "MessageDownloadQueued": "Download in de wachtrij geplaatst.", "MessageEnablingOptionLongerScans": "Het inschakelen van deze optie kan leiden tot langere doorlooptijd van bibliotheek scans.", From cb45b4e8ad8ba0c172ac2b5e2e58ebfa8145a487 Mon Sep 17 00:00:00 2001 From: WWWesten Date: Sun, 16 Aug 2020 17:35:22 +0000 Subject: [PATCH 278/301] Translated using Weblate (Russian) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/ru/ --- src/strings/ru.json | 40 ++++++++++++++++++++-------------------- 1 file changed, 20 insertions(+), 20 deletions(-) diff --git a/src/strings/ru.json b/src/strings/ru.json index a3aabd93c3..8982b7f187 100644 --- a/src/strings/ru.json +++ b/src/strings/ru.json @@ -126,7 +126,7 @@ "ColorTransfer": "Цветопередача", "CommunityRating": "Общественная оценка", "Composer": "Композитор", - "ConfigureDateAdded": "Как конфигурировать дату добавления определяется в Панели Jellyfin Server в параметрах Медиатеки", + "ConfigureDateAdded": "Как конфигурировать дату добавления определяется в Панели в параметрах Медиатеки", "ConfirmDeleteImage": "Удалить изображение?", "ConfirmDeleteItem": "При удалении данного элемента, он удалится и из файловой системы, и из медиатеки. Вы действительно хотите продолжить?", "ConfirmDeleteItems": "При удалении данных элементов, он удалится и из файловой системы, и из медиатеки. Вы действительно хотите продолжить?", @@ -207,7 +207,7 @@ "ErrorAddingMediaPathToVirtualFolder": "Произошла ошибка при добавлении пути к медиаданным. Убедитесь, что путь действителен и Jellyfin имеет доступ к этому расположению.", "ErrorAddingTunerDevice": "Произошла ошибка при добавлении тюнерного устройства. Убедитесь, что оно доступно и повторите попытку.", "ErrorAddingXmlTvFile": "Произошла ошибка при доступе к XMLTV-файлу. Убедитесь, что файл существует и повторите попытку.", - "ErrorDeletingItem": "Произошла ошибка при удалении элемента с Jellyfin Server. Проверьте, что у Jellyfin Server имеется доступ на запись в медиапапку и повторите попытку.", + "ErrorDeletingItem": "Произошла ошибка при удалении элемента с сервера. Проверьте, что у Jellyfinr имеется доступ на запись в медиапапку и повторите попытку.", "ErrorGettingTvLineups": "Произошла ошибка при загрузке списков сопоставления. Убедитесь, что ваши данные правильны и повторите попытку.", "ErrorStartHourGreaterThanEnd": "Конечное время должно быть позже, чем начальное время.", "ErrorPleaseSelectLineup": "Выделите список сопоставления и повторите попытку. Если списков сопоставления не имеется, то проверьте, что ваше имя пользователя, пароль и почтовый код являются верными.", @@ -480,12 +480,12 @@ "LabelAppName": "Название приложения", "LabelAppNameExample": "Пример: Sickbeard, Sonarr", "LabelArtists": "Исполнители:", - "LabelArtistsHelp": "Для разделения исполнителей используйте точку с запятой ;", + "LabelArtistsHelp": "Для разделения исполнителей используйте ; (точку с запятой).", "LabelAudio": "Аудио", "LabelAudioLanguagePreference": "Выбор языка аудио:", "LabelAutomaticallyRefreshInternetMetadataEvery": "Автоматически обновлять метаданные из Интернета:", "LabelBindToLocalNetworkAddress": "Привязка к адресу в локальной сети:", - "LabelBindToLocalNetworkAddressHelp": "Переопределяется локальный IP-адрес для HTTP-сервера. Если поле пусто, то привязка сервера будет ко всем доступным адресам. При изменении данного значения потребуется перезапуск Jellyfin Server.", + "LabelBindToLocalNetworkAddressHelp": "Переопределяется локальный IP-адрес для HTTP-сервера. Если поле пусто, то привязка сервера будет ко всем доступным адресам. При изменении данного значения потребуется перезапуск.", "LabelBirthDate": "Дата рождения:", "LabelBirthYear": "Год рождения:", "LabelBlastMessageInterval": "Интервал сообщений проверки активности", @@ -544,7 +544,7 @@ "LabelEnableBlastAliveMessages": "Бомбардировать сообщениями проверки активности", "LabelEnableBlastAliveMessagesHelp": "Включите, если сервер надёжно не обнаруживается иными UPnP устройствами в своей сети.", "LabelEnableDlnaClientDiscoveryInterval": "Интервал обнаружения клиентов", - "LabelEnableDlnaClientDiscoveryIntervalHelp": "Определяется длительность в секундах между SSDP-запросами от Jellyfin.", + "LabelEnableDlnaClientDiscoveryIntervalHelp": "Определяется длительность в секундах между SSDP-запросами.", "LabelEnableDlnaDebugLogging": "Включить журналирование отладки DLNA", "LabelEnableDlnaDebugLoggingHelp": "Создаются большие файлы Журнала, рекомендуется использовать только для поиска неполадок.", "LabelEnableDlnaPlayTo": "Включить DLNA-функцию Воспроизвести На", @@ -662,7 +662,7 @@ "LabelNumberOfGuideDays": "Число дней для загрузки данных телегида:", "LabelNumberOfGuideDaysHelp": "Больше дней загрузки данных телегида обеспечивает возможность заблаговременно назначать расписание и просматривать больше перечней, однако это займёт больше времени для загрузки. При значении «Авто» выбор определяется числом каналов.", "LabelOptionalNetworkPath": "Общедоступная сетевая папка:", - "LabelOptionalNetworkPathHelp": "Если данная папка является общей в сети, указание пути к сетевой папке может позволить Jellyfin-приложениям на других устройствах иметь прямой доступ к медиафайлам. Например, {0} или {1}.", + "LabelOptionalNetworkPathHelp": "Если данная папка является общей в сети, указание пути к сетевой папке может позволить клиентам на других устройствах иметь прямой доступ к медиафайлам. Например, {0} или {1}.", "LabelOriginalAspectRatio": "Исходное соотношение сторон:", "LabelOriginalTitle": "Оригинальное название:", "LabelOverview": "Обзор:", @@ -840,13 +840,13 @@ "MessageConfirmProfileDeletion": "Вы действительно хотите удалить данный профиль?", "MessageConfirmRecordingCancellation": "Отменить запись?", "MessageConfirmRemoveMediaLocation": "Вы действительно хотите изъять это расположение?", - "MessageConfirmRestart": "Вы действительно хотите перезапустить Jellyfin Server?", - "MessageConfirmRevokeApiKey": "Вы действительно хотите отозвать данный API-ключ? Подключение приложения к Jellyfin Server будет резко прекращено.", + "MessageConfirmRestart": "Вы действительно хотите перезапустить Jellyfin?", + "MessageConfirmRevokeApiKey": "Вы действительно хотите отозвать данный API-ключ? Подключение приложения к этому серверу будет резко прекращено.", "MessageConfirmShutdown": "Вы действительно хотите завершить работу сервера?", "MessageContactAdminToResetPassword": "Обратитесь к своему системному администратору, чтобы сбросить ваш пароль.", "MessageCreateAccountAt": "Создайте учётную запись на {0}", "MessageDeleteTaskTrigger": "Вы действительно хотите удалить данный триггер задачи?", - "MessageDirectoryPickerBSDInstruction": "Касаемо BSD, возможно, потребуется конфигурировать хранилище в вашем FreeNAS Jail для того, чтобы разрешить Jellyfin получить к нему доступ.", + "MessageDirectoryPickerBSDInstruction": "Касаемо BSD, возможно, потребуется конфигурировать хранилище в вашем FreeNAS Jail, чтобы Jellyfin мог получить доступ к медиаданным.", "MessageDirectoryPickerLinuxInstruction": "Для Linux на Arch Linux, CentOS, Debian, Fedora, openSUSE или Ubuntu, вы должны предоставить пользователю службы, по крайней мере, доступ для чтения к расположениям хранилища.", "MessageDownloadQueued": "Загрузка в очереди.", "MessageEnablingOptionLongerScans": "Включение этой опции может привести к значительному увеличению времени сканирования медиатеки.", @@ -868,7 +868,7 @@ "MessagePleaseEnsureInternetMetadata": "Убедитесь, что включена загрузка метаданных из Интернета.", "MessagePleaseWait": "Подождите. Это может занять минуту.", "MessagePluginConfigurationRequiresLocalAccess": "Чтобы конфигурировать данный плагин войдите непосредственно в свой локальный сервер.", - "MessagePluginInstallDisclaimer": "Плагины, созданные членами сообщества Jellyfin являются отличным способом повышения эффективности Jellyfin с помощью дополнительных функций и компонентов. Перед установкой примите во внимание влияние, которое они могут оказать на Jellyfin Server, например, длительные сканирования медиатеки, дополнительную фоновую обработку и снижение системной стабильности.", + "MessagePluginInstallDisclaimer": "Плагины, созданные членами сообщества являются отличным способом повышения эффективности с помощью дополнительных функций и компонентов. Перед установкой примите во внимание влияние, которое они могут оказать на сервер, например, длительные сканирования медиатеки, дополнительную фоновую обработку и снижение системной стабильности.", "MessageReenableUser": "См. ниже для разблокировки", "MessageSettingsSaved": "Параметры сохранены.", "MessageTheFollowingLocationWillBeRemovedFromLibrary": "Из вашей медиатеки будут изъяты следующие расположения медиаданных:", @@ -1032,7 +1032,7 @@ "OptionResumable": "Возможно возобновление", "OptionRuntime": "Длительность", "OptionSaveMetadataAsHidden": "Сохранять метаданные и изображения в виде скрытых файлов", - "OptionSaveMetadataAsHiddenHelp": "Это изменение будет применено к новым метаданным сохраняемым в будущем. Существующие файлы метаданных будут обновлены в следующий раз, когда они будут сохраняться на Jellyfin Server.", + "OptionSaveMetadataAsHiddenHelp": "Это изменение будет применено к новым метаданным сохраняемым в будущем. Существующие файлы метаданных будут обновлены в следующий раз, когда они будут сохраняться на сервере.", "OptionSpecialEpisode": "Спецэпизоды", "OptionSubstring": "Подстрока", "OptionTrackName": "Название трека", @@ -1072,9 +1072,9 @@ "PleaseAddAtLeastOneFolder": "Добавьте, по крайней мере, одну папку к данной медиатеке, нажав кнопку Добавить.", "PleaseConfirmPluginInstallation": "Нажмите кнопку ОК, чтобы подтвердить, что вы прочитали вышеизложенное и хотите приступить к установке плагина.", "PleaseEnterNameOrId": "Введите название или внешний ID.", - "PleaseRestartServerName": "Перезапустите Jellyfin Server - {0}.", + "PleaseRestartServerName": "Перезапустите Jellyfin на {0}.", "PleaseSelectTwoItems": "Выберите хотя бы два элемента.", - "MessagePluginInstalled": "Плагин установлен успешно. Чтобы изменения вступили в силу, будет необходимо перезапустить Jellyfin Server.", + "MessagePluginInstalled": "Плагин установлен успешно. Чтобы изменения вступили в силу, будет необходимо перезапустить сервер.", "PreferEmbeddedTitlesOverFileNames": "Предпочитать внедрённые названия, чем имена файлов", "PreferEmbeddedTitlesOverFileNamesHelp": "Этим определяется отображаемое название по умолчанию, когда нет метаданных с интернета или локальные метаданные недоступны.", "Premiere": "Премьера", @@ -1137,10 +1137,10 @@ "SeriesRecordingScheduled": "Запись сериала назначена.", "SeriesSettings": "Параметры сериала", "SeriesYearToPresent": "{0} - Н/В", - "ServerNameIsRestarting": "Jellyfin Server - {0} перезапускается.", - "ServerNameIsShuttingDown": "Jellyfin Server - {0} завершает работу.", - "ServerRestartNeededAfterPluginInstall": "После установки плагина будет необходимо перезапустить Jellyfin Server.", - "ServerUpdateNeeded": "Данный Jellyfin Server нуждается в обновлении. Чтобы загрузить свежую версию, посетите {0}", + "ServerNameIsRestarting": "Сервер перезапускается в {0}.", + "ServerNameIsShuttingDown": "Сервер завершает работу в {0}.", + "ServerRestartNeededAfterPluginInstall": "После установки плагина будет необходимо перезапустить Jellyfin.", + "ServerUpdateNeeded": "Данный сервер нуждается в обновлении. Чтобы загрузить свежую версию, посетите {0}", "Settings": "Параметры", "SettingsSaved": "Параметры сохранены.", "SettingsWarning": "Изменение данных значений может привести к нестабильности или сбоям возможности подключения. Если вы испытываете любые проблемы, мы рекомендуем изменить их обратно к стандартным.", @@ -1324,7 +1324,7 @@ "OptionPosterCard": "Постер-карта", "OptionThumb": "Эскиз", "OptionThumbCard": "Эскиз-карта", - "PasswordResetProviderHelp": "Выберите поставщика сброса пароля, который использовуется при запросе пользователем сброса пароля", + "PasswordResetProviderHelp": "Выберите поставщика сброса пароля, который использовуется при запросе пользователем сброса пароля.", "PlaybackData": "Данные воспроизведения", "SubtitleOffset": "Сдвиг субтитров", "TabNetworking": "Работа в сети", @@ -1391,7 +1391,7 @@ "AlbumArtist": "Исполнитель альбома", "Album": "Альбом", "LastSeen": "Последний раз был {0}", - "WriteAccessRequired": "Jellyfin Server требуются права на запись в эту папку. Обеспечьте доступ для записи и попробуйте снова.", + "WriteAccessRequired": "Jellyfin требуются права на запись в эту папку. Обеспечьте доступ для записи и попробуйте снова.", "PathNotFound": "Путь не может быть найден. Убедитесь, что путь правильный и попробуйте снова.", "PreferEmbeddedEpisodeInfosOverFileNames": "Предпочитать встроенную информацию эпизода вместо имён файлов", "PreferEmbeddedEpisodeInfosOverFileNamesHelp": "Используется информация об эпизоде из встроенных метаданных, если они доступны.", @@ -1446,7 +1446,7 @@ "MessageSyncPlayErrorNoActivePlayer": "Активный проигрыватель не найден. SyncPlay был отключен.", "ShowMore": "Показать больше", "ShowLess": "Показать меньше", - "EnableBlurHashHelp": "Рисунки, которые всё ещё загружаются, будут отображаться с размытым заполнением", + "EnableBlurHashHelp": "Рисунки, которые всё ещё загружаются, будут отображаться с уникальным заполнением.", "EnableBlurHash": "Включить размытые заполнители для изображений", "ButtonSyncPlay": "SyncPlay", "ButtonCast": "Транслировать", From 39b55a4f8d160678efcf401ac69643d059c1c723 Mon Sep 17 00:00:00 2001 From: Konctantin Date: Sun, 16 Aug 2020 21:00:31 +0000 Subject: [PATCH 279/301] Translated using Weblate (Ukrainian) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/uk/ --- src/strings/uk.json | 38 +++++++++++++++++++++++++++++++++++++- 1 file changed, 37 insertions(+), 1 deletion(-) diff --git a/src/strings/uk.json b/src/strings/uk.json index ff69296e07..764f520524 100644 --- a/src/strings/uk.json +++ b/src/strings/uk.json @@ -243,5 +243,41 @@ "Backdrop": "Фон", "AroundTime": "Приблизно", "AlwaysPlaySubtitlesHelp": "Субтитри, що відповідають мовним параметрам, завантажуватимуться незалежно від мови звуку.", - "AllowFfmpegThrottlingHelp": "Коли перекодування або перепакування досить далеко випереджає поточну позицію відтворення, процес призупиняється, щоб зекономити ресурси. Це найкорисніше при перегляді, коли рідко міняється позиція відтворення. Вимкніть це, якщо виникнуть проблеми з відтворенням." + "AllowFfmpegThrottlingHelp": "Коли перекодування або перепакування досить далеко випереджає поточну позицію відтворення, процес призупиняється, щоб зекономити ресурси. Це найкорисніше при перегляді, коли рідко міняється позиція відтворення. Вимкніть це, якщо виникнуть проблеми з відтворенням.", + "ExitFullscreen": "Вийти з повноекранного режиму", + "Episodes": "Серії", + "Episode": "Серія", + "Ended": "Закінчилось", + "EnableThemeVideos": "Тематичні відео", + "EnableThemeSongs": "Тематичні пісні", + "EnablePhotos": "Показувати фото", + "EnableHardwareEncoding": "Ввімкнути апаратне кодування", + "EnableExternalVideoPlayers": "Зовнішні відеоплеєри", + "EnableCinemaMode": "Режим кіно", + "EditSubtitles": "Редагувати субтитри", + "EditMetadata": "Редагувати метадані", + "EditImages": "Редагувати зображення", + "Edit": "Редагувати", + "DownloadsValue": "{0} завантажень", + "Download": "Завантажити", + "Down": "Вниз", + "DoNotRecord": "Не записувати", + "Depressed": "Подавлений", + "ErrorDefault": "Виникла помилка при обробці запиту. Будь-ласка повторіть пізніше.", + "DatePlayed": "Дата програвання", + "DateAdded": "Дата додана", + "Default": "За замовчуванням", + "Delete": "Видалити", + "DeleteImage": "Видалити зображення", + "DeleteMedia": "Видалити медіа", + "DeleteUser": "Видалити користувача", + "Desktop": "Робочий стіл", + "DetectingDevices": "Виявлення пристроїв", + "DirectStreaming": "Пряме мовлення", + "Director": "Режисер", + "Directors": "Режисери", + "Disabled": "Відключено", + "Disc": "Диск", + "Display": "Дисплей", + "Disconnect": "Відключити" } From c2f946d96e79539b343f46ed76566914759e1219 Mon Sep 17 00:00:00 2001 From: Professor Vogelbloem Date: Sun, 16 Aug 2020 21:50:14 +0000 Subject: [PATCH 280/301] Translated using Weblate (Dutch) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/nl/ --- src/strings/nl.json | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/strings/nl.json b/src/strings/nl.json index 81a74fcb2c..963adee2c0 100644 --- a/src/strings/nl.json +++ b/src/strings/nl.json @@ -804,14 +804,14 @@ "MessagePleaseEnsureInternetMetadata": "Zorg ervoor dat het downloaden van internet-metadata is ingeschakeld.", "MessagePleaseWait": "Even geduld. Dit kan even duren.", "MessagePluginConfigurationRequiresLocalAccess": "Om deze plugin te configuren moet u zich aanmelden direct op de lokale server.", - "MessagePluginInstallDisclaimer": "Plugins ontwikkeld door leden van de Jellyfin gemeenschap zijn een geweldige manier om uw Jellyfin ervaring met extra functies en voordelen te verbeteren. Alvorens te installeren, dient u zich bewust te zijn van de gevolgen die zij kunnen hebben op uw Jellyfin Server, zoals langere bibliotheek scans, extra achtergrondinformatie verwerking, en een verminderde stabiliteit van het systeem.", + "MessagePluginInstallDisclaimer": "Plugins ontwikkeld door leden van de gemeenschap zijn een geweldige manier om uw ervaring met extra functies en voordelen te verbeteren. Wees voor het installeren bewust van de effecten die zij op uw server kunnen hebben, zoals langere bibliotheek scans, extra achtergrondinformatie verwerking, en een verminderde stabiliteit van het systeem.", "MessageReenableUser": "Zie hieronder hoe opnieuw in te schakelen", "MessageSettingsSaved": "Instellingen opgeslagen.", "MessageTheFollowingLocationWillBeRemovedFromLibrary": "De volgende media locaties worden verwijderd uit de bibliotheek:", "MessageUnableToConnectToServer": "Het is momenteel niet mogelijk met de geselecteerde server te verbinden. Controleer dat deze draait en probeer het opnieuw.", "MessageUnsetContentHelp": "Inhoud zal als gewone folders worden getoond. Gebruik voor het beste resultaat de Metadata Manager om de inhoud types voor subfolders in te stellen.", "MessageYouHaveVersionInstalled": "Op dit moment is versie {0} geïnstalleerd.", - "MetadataSettingChangeHelp": "Veranderen van metadata instellingen zal nieuwe content die wordt toegevoegd beïnvloeden. Om de bestaande inhoud te vernieuwen, opent u het detail scherm en klik op de knop Vernieuwen, of doe een bulk vernieuwing met behulp van de metadata manager.", + "MetadataSettingChangeHelp": "Het veranderen van metadata instellingen zal nieuwe toegevoegd content beïnvloeden. Om de bestaande content te vernieuwen, opent u het detail scherm en klik op de vernieuw knop, of voer een bulk vernieuwing uit met behulp van de metadata manager.", "MinutesAfter": "minuten na", "MinutesBefore": "minuten voor", "Mobile": "Mobiel", @@ -895,7 +895,7 @@ "OptionDownloadBackImage": "Terug", "OptionDownloadDiscImage": "Schijf", "OptionDownloadImagesInAdvance": "Download afbeeldingen van tevoren", - "OptionDownloadImagesInAdvanceHelp": "Standaard worden de meeste afbeeldingen gedownload wanneer ze opgevraagd worden door een Jellyfin app. Activeer deze optie om alle afbeeldingen op voorhand te downloaden bij het importeren van nieuwe media. Dit kan aanzienlijk langere bibliotheekscans veroorzaken.", + "OptionDownloadImagesInAdvanceHelp": "Standaard worden de meeste afbeeldingen alleen gedownload wanneer ze opgevraagd worden door een client. Activeer deze optie om alle afbeeldingen van tevoren te downloaden bij het importeren van nieuwe media. Dit kan aanzienlijk langere bibliotheekscans veroorzaken.", "OptionDownloadPrimaryImage": "Primair", "OptionDownloadThumbImage": "Miniatuur", "OptionEmbedSubtitles": "Insluiten in container", From 4f87f6807b6e55f662f1a07fb75ccf370d5341e9 Mon Sep 17 00:00:00 2001 From: Franco Castillo Date: Mon, 17 Aug 2020 00:56:49 +0000 Subject: [PATCH 281/301] Translated using Weblate (Spanish (Argentina)) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/es_AR/ --- src/strings/es-ar.json | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/src/strings/es-ar.json b/src/strings/es-ar.json index 3ff15ab72b..74eb87e842 100644 --- a/src/strings/es-ar.json +++ b/src/strings/es-ar.json @@ -1467,5 +1467,13 @@ "Writers": "Escritores", "ClearQueue": "Eliminar cola", "StopPlayback": "Detener reproducción", - "ViewAlbumArtist": "Ver artista del álbum" + "ViewAlbumArtist": "Ver artista del álbum", + "Preview": "Avance", + "SubtitleVerticalPositionHelp": "Número de línea donde aparece el texto. Los números positivos indican de arriba hacia abajo. Los números negativos indican de abajo hacia arriba.", + "LabelSubtitleVerticalPosition": "Posición vertical:", + "PreviousTrack": "Pasar al anterior", + "MessageGetInstalledPluginsError": "Se produjo un error al obtener la lista de complementos instalados actualmente.", + "MessagePluginInstallError": "Ocurrió un error al instalar el complemento.", + "NextTrack": "Pasar al siguiente", + "LabelUnstable": "Inestable" } From 15010b142611aa05e3fe849873c809e1e8907ccd Mon Sep 17 00:00:00 2001 From: Julien Machiels Date: Mon, 17 Aug 2020 04:26:38 +0200 Subject: [PATCH 282/301] Update src/scripts/clientUtils.js Co-authored-by: Dmitry Lyzo <56478732+dmitrylyzo@users.noreply.github.com> --- src/scripts/clientUtils.js | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/src/scripts/clientUtils.js b/src/scripts/clientUtils.js index bf61bb1dd3..564f5784b0 100644 --- a/src/scripts/clientUtils.js +++ b/src/scripts/clientUtils.js @@ -157,8 +157,7 @@ export function capabilities(appHost) { SupportsPersistentIdentifier: self.appMode === 'cordova' || self.appMode === 'android', SupportsMediaControl: true }; - appHost.getPushTokenInfo(); - return capabilities = Object.assign(capabilities, appHost.getPushTokenInfo()); + return Object.assign(capabilities, appHost.getPushTokenInfo()); } export function selectServer() { From 99686db96d65bd21285d8d5804a2a06e4fe9b2ea Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Luk=C3=A1=C5=A1=20Kucharczyk?= Date: Mon, 17 Aug 2020 08:12:34 +0000 Subject: [PATCH 283/301] Translated using Weblate (Czech) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/cs/ --- src/strings/cs.json | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/src/strings/cs.json b/src/strings/cs.json index d796f36a43..3156bf36bc 100644 --- a/src/strings/cs.json +++ b/src/strings/cs.json @@ -1475,5 +1475,6 @@ "SubtitleVerticalPositionHelp": "Číslo řádku, na kterém se zobrazí text. Kladná čísla znamenají směr shora dolů. Záporná čísla zdola nahoru.", "LabelSubtitleVerticalPosition": "Svislé umístění:", "MessageGetInstalledPluginsError": "Při načítání seznamu nainstalovaných zásuvných modulů došlo k chybě.", - "MessagePluginInstallError": "Při instalaci zásuvného modulu došlo k chybě." + "MessagePluginInstallError": "Při instalaci zásuvného modulu došlo k chybě.", + "PlaybackRate": "Rychlost přehrávání" } From 65e4ffe7b07559ac2e43ba7e7f0dd131478cba14 Mon Sep 17 00:00:00 2001 From: dkanada Date: Sun, 16 Aug 2020 20:34:39 +0900 Subject: [PATCH 284/301] remove some duplicate strings --- src/components/directorybrowser/directorybrowser.js | 2 +- .../displaySettings/displaySettings.template.html | 4 ++-- .../homeScreenSettings.template.html | 2 +- .../itemMediaInfo/itemMediaInfo.template.html | 2 +- .../libraryoptionseditor.template.html | 2 +- src/components/remotecontrol/remotecontrol.js | 2 +- src/controllers/dashboard/devices/device.html | 2 +- src/controllers/dashboard/dlna/profile.html | 10 +++++----- src/controllers/dashboard/encodingsettings.js | 2 +- src/controllers/dashboard/general.html | 2 +- src/controllers/dashboard/library.js | 2 +- src/controllers/dashboard/playback.html | 2 +- src/controllers/dashboard/playback.js | 2 +- .../dashboard/scheduledtasks/scheduledtask.html | 2 +- src/controllers/dashboard/streaming.js | 2 +- src/controllers/dashboard/users/usernew.html | 2 +- src/controllers/dashboard/users/userpasswordpage.js | 2 +- src/controllers/itemDetails/index.html | 4 ++-- src/controllers/itemDetails/index.js | 8 ++++---- src/controllers/livetv.html | 2 +- src/controllers/livetvsettings.html | 2 +- src/controllers/livetvstatus.js | 2 +- src/controllers/movies/movies.html | 4 ++-- src/controllers/movies/moviesrecommended.js | 2 +- src/controllers/music/music.html | 8 ++++---- src/controllers/music/musicrecommended.js | 2 +- src/controllers/playback/queue/index.html | 4 ++-- src/controllers/playback/video/index.js | 2 +- src/controllers/session/forgotPassword/index.html | 2 +- src/controllers/session/forgotPassword/index.js | 6 +++--- src/controllers/shows/tvrecommended.html | 4 ++-- src/controllers/shows/tvrecommended.js | 2 +- src/controllers/user/home/index.html | 2 +- src/controllers/user/menu/index.html | 2 +- src/scripts/itembynamedetailpage.js | 6 +++--- src/scripts/libraryBrowser.js | 2 +- src/scripts/libraryMenu.js | 2 +- 37 files changed, 56 insertions(+), 56 deletions(-) diff --git a/src/components/directorybrowser/directorybrowser.js b/src/components/directorybrowser/directorybrowser.js index 5c44db3b15..4205e04a4f 100644 --- a/src/components/directorybrowser/directorybrowser.js +++ b/src/components/directorybrowser/directorybrowser.js @@ -125,7 +125,7 @@ import 'emby-button'; html += ``; html += '
    '; if (!readOnlyAttribute) { - html += ``; + html += ``; } html += '
    '; if (!readOnlyAttribute) { diff --git a/src/components/displaySettings/displaySettings.template.html b/src/components/displaySettings/displaySettings.template.html index e751ce56c4..1b9bf00376 100644 --- a/src/components/displaySettings/displaySettings.template.html +++ b/src/components/displaySettings/displaySettings.template.html @@ -170,7 +170,7 @@
    ${EnableThemeSongsHelp}
    @@ -178,7 +178,7 @@
    ${EnableThemeVideosHelp}
    diff --git a/src/components/homeScreenSettings/homeScreenSettings.template.html b/src/components/homeScreenSettings/homeScreenSettings.template.html index 19f79ea5da..615598a1a6 100644 --- a/src/components/homeScreenSettings/homeScreenSettings.template.html +++ b/src/components/homeScreenSettings/homeScreenSettings.template.html @@ -1,6 +1,6 @@
    -

    ${HeaderHome}

    +

    ${Home}

    - ${LabelDisplayMissingEpisodesWithinSeasons} + ${DisplayMissingEpisodesWithinSeasons}
    ${ImportMissingEpisodesHelp}
    diff --git a/src/components/remotecontrol/remotecontrol.js b/src/components/remotecontrol/remotecontrol.js index 6048c918c7..3216241e7a 100644 --- a/src/components/remotecontrol/remotecontrol.js +++ b/src/components/remotecontrol/remotecontrol.js @@ -66,7 +66,7 @@ function showSubtitleMenu(context, player, button, item) { }); menuItems.unshift({ id: -1, - name: globalize.translate('ButtonOff'), + name: globalize.translate('Off'), selected: currentIndex == null }); diff --git a/src/controllers/dashboard/devices/device.html b/src/controllers/dashboard/devices/device.html index 4d8fb86537..aec73db008 100644 --- a/src/controllers/dashboard/devices/device.html +++ b/src/controllers/dashboard/devices/device.html @@ -9,7 +9,7 @@
    - +
    ${LabelCustomDeviceDisplayNameHelp}
    diff --git a/src/controllers/dashboard/dlna/profile.html b/src/controllers/dashboard/dlna/profile.html index 22c7ce73ef..3ac3a71c6c 100644 --- a/src/controllers/dashboard/dlna/profile.html +++ b/src/controllers/dashboard/dlna/profile.html @@ -8,7 +8,7 @@
    - ${TabInfo} + ${ButtonInfo} ${TabDirectPlay} ${Transcoding} ${TabContainers} @@ -319,7 +319,7 @@
    - +
    @@ -341,16 +341,16 @@
    - +
    - +
    - +
    diff --git a/src/controllers/dashboard/encodingsettings.js b/src/controllers/dashboard/encodingsettings.js index 320a679b37..dfad07618c 100644 --- a/src/controllers/dashboard/encodingsettings.js +++ b/src/controllers/dashboard/encodingsettings.js @@ -128,7 +128,7 @@ import libraryMenu from 'libraryMenu'; name: globalize.translate('Transcoding') }, { href: 'playbackconfiguration.html', - name: globalize.translate('TabResumeSettings') + name: globalize.translate('ButtonResume') }, { href: 'streamingsettings.html', name: globalize.translate('TabStreaming') diff --git a/src/controllers/dashboard/general.html b/src/controllers/dashboard/general.html index 078d9d6055..e3a1769c24 100644 --- a/src/controllers/dashboard/general.html +++ b/src/controllers/dashboard/general.html @@ -17,7 +17,7 @@
    -
    ${LabelPreferredDisplayLanguageHelp}
    +
    ${LabelDisplayLanguageHelp}
    diff --git a/src/controllers/dashboard/library.js b/src/controllers/dashboard/library.js index 0400df7570..85d9a4b1b2 100644 --- a/src/controllers/dashboard/library.js +++ b/src/controllers/dashboard/library.js @@ -93,7 +93,7 @@ import 'emby-itemrefreshindicator'; const virtualFolder = virtualFolders[index]; const menuItems = []; menuItems.push({ - name: globalize.translate('ButtonEditImages'), + name: globalize.translate('EditImages'), id: 'editimages', icon: 'photo' }); diff --git a/src/controllers/dashboard/playback.html b/src/controllers/dashboard/playback.html index 47ae22c21c..e5f392ead4 100644 --- a/src/controllers/dashboard/playback.html +++ b/src/controllers/dashboard/playback.html @@ -3,7 +3,7 @@
    -

    ${TabResumeSettings}

    +

    ${ButtonResume}

    diff --git a/src/controllers/dashboard/playback.js b/src/controllers/dashboard/playback.js index 0406c21926..101c3ac0a2 100644 --- a/src/controllers/dashboard/playback.js +++ b/src/controllers/dashboard/playback.js @@ -32,7 +32,7 @@ import globalize from 'globalize'; name: globalize.translate('Transcoding') }, { href: 'playbackconfiguration.html', - name: globalize.translate('TabResumeSettings') + name: globalize.translate('ButtonResume') }, { href: 'streamingsettings.html', name: globalize.translate('TabStreaming') diff --git a/src/controllers/dashboard/scheduledtasks/scheduledtask.html b/src/controllers/dashboard/scheduledtasks/scheduledtask.html index dc17d9bf07..8d0b2e24e0 100644 --- a/src/controllers/dashboard/scheduledtasks/scheduledtask.html +++ b/src/controllers/dashboard/scheduledtasks/scheduledtask.html @@ -23,7 +23,7 @@
    -

    ${HeaderAddScheduledTaskTrigger}

    +

    ${ButtonAddScheduledTaskTrigger}

    diff --git a/src/controllers/dashboard/streaming.js b/src/controllers/dashboard/streaming.js index c54fbea472..5db888dfc1 100644 --- a/src/controllers/dashboard/streaming.js +++ b/src/controllers/dashboard/streaming.js @@ -27,7 +27,7 @@ import globalize from 'globalize'; name: globalize.translate('Transcoding') }, { href: 'playbackconfiguration.html', - name: globalize.translate('TabResumeSettings') + name: globalize.translate('ButtonResume') }, { href: 'streamingsettings.html', name: globalize.translate('TabStreaming') diff --git a/src/controllers/dashboard/users/usernew.html b/src/controllers/dashboard/users/usernew.html index 26142c9ca2..67f1f61ebc 100644 --- a/src/controllers/dashboard/users/usernew.html +++ b/src/controllers/dashboard/users/usernew.html @@ -4,7 +4,7 @@
    -

    ${HeaderAddUser}

    +

    ${ButtonAddUser}

    ${Help}
    diff --git a/src/controllers/dashboard/users/userpasswordpage.js b/src/controllers/dashboard/users/userpasswordpage.js index d399804d3e..9a3f7dfaac 100644 --- a/src/controllers/dashboard/users/userpasswordpage.js +++ b/src/controllers/dashboard/users/userpasswordpage.js @@ -83,7 +83,7 @@ import 'emby-button'; loading.hide(); import('toast').then(({default: toast}) => { - toast(globalize.translate('MessageSettingsSaved')); + toast(globalize.translate('SettingsSaved')); }); loadUser(view, params); diff --git a/src/controllers/itemDetails/index.html b/src/controllers/itemDetails/index.html index bd0821eebe..a69d917874 100644 --- a/src/controllers/itemDetails/index.html +++ b/src/controllers/itemDetails/index.html @@ -18,7 +18,7 @@
    -
    -

    ${HeaderCastCrew}

    +

    ${HeaderCastAndCrew}

    diff --git a/src/controllers/itemDetails/index.js b/src/controllers/itemDetails/index.js index c57190139f..bd28c68c30 100644 --- a/src/controllers/itemDetails/index.js +++ b/src/controllers/itemDetails/index.js @@ -242,7 +242,7 @@ import 'emby-select'; return m.Type === 'Audio'; }); const select = page.querySelector('.selectAudio'); - select.setLabel(globalize.translate('LabelAudio')); + select.setLabel(globalize.translate('Audio')); const selectedId = mediaSource.DefaultAudioStreamIndex; select.innerHTML = tracks.map(function (v) { const selected = v.Index === selectedId ? ' selected' : ''; @@ -271,7 +271,7 @@ import 'emby-select'; return m.Type === 'Subtitle'; }); const select = page.querySelector('.selectSubtitles'); - select.setLabel(globalize.translate('LabelSubtitles')); + select.setLabel(globalize.translate('Subtitles')); const selectedId = mediaSource.DefaultSubtitleStreamIndex == null ? -1 : mediaSource.DefaultSubtitleStreamIndex; const videoTracks = mediaSource.MediaStreams.filter(function (m) { @@ -1438,7 +1438,7 @@ import 'emby-select'; name: globalize.translate('Albums'), type: 'MusicAlbum' }, { - name: globalize.translate('HeaderBooks'), + name: globalize.translate('Books'), type: 'Book' }]; renderCollectionItems(page, item, collectionItemTypes, result.Items); @@ -1446,7 +1446,7 @@ import 'emby-select'; }); if (item.Type == 'Season') { - page.querySelector('#childrenTitle').innerHTML = globalize.translate('HeaderEpisodes'); + page.querySelector('#childrenTitle').innerHTML = globalize.translate('Episodes'); } else if (item.Type == 'Series') { page.querySelector('#childrenTitle').innerHTML = globalize.translate('HeaderSeasons'); } else if (item.Type == 'MusicAlbum') { diff --git a/src/controllers/livetv.html b/src/controllers/livetv.html index 753521f40b..fa6c3125d5 100644 --- a/src/controllers/livetv.html +++ b/src/controllers/livetv.html @@ -63,7 +63,7 @@
    - +
    diff --git a/src/controllers/livetvsettings.html b/src/controllers/livetvsettings.html index 3f93e0a7fa..ad3a9de7af 100644 --- a/src/controllers/livetvsettings.html +++ b/src/controllers/livetvsettings.html @@ -11,7 +11,7 @@
    diff --git a/src/controllers/session/forgotPassword/index.js b/src/controllers/session/forgotPassword/index.js index 45e05409da..0f2464e2d8 100644 --- a/src/controllers/session/forgotPassword/index.js +++ b/src/controllers/session/forgotPassword/index.js @@ -6,14 +6,14 @@ import globalize from 'globalize'; if (result.Action == 'ContactAdmin') { return void Dashboard.alert({ message: globalize.translate('MessageContactAdminToResetPassword'), - title: globalize.translate('HeaderForgotPassword') + title: globalize.translate('ButtonForgotPassword') }); } if (result.Action == 'InNetworkRequired') { return void Dashboard.alert({ message: globalize.translate('MessageForgotPasswordInNetworkRequired'), - title: globalize.translate('HeaderForgotPassword') + title: globalize.translate('ButtonForgotPassword') }); } @@ -27,7 +27,7 @@ import globalize from 'globalize'; msg += '
    '; return void Dashboard.alert({ message: msg, - title: globalize.translate('HeaderForgotPassword'), + title: globalize.translate('ButtonForgotPassword'), callback: function () { Dashboard.navigate('forgotpasswordpin.html'); } diff --git a/src/controllers/shows/tvrecommended.html b/src/controllers/shows/tvrecommended.html index 2302279ed7..b5b54a5eb5 100644 --- a/src/controllers/shows/tvrecommended.html +++ b/src/controllers/shows/tvrecommended.html @@ -5,7 +5,7 @@
    - +
    @@ -61,7 +61,7 @@
    - +
    diff --git a/src/controllers/shows/tvrecommended.js b/src/controllers/shows/tvrecommended.js index ea95e99386..c58a2faad3 100644 --- a/src/controllers/shows/tvrecommended.js +++ b/src/controllers/shows/tvrecommended.js @@ -29,7 +29,7 @@ import 'emby-button'; }, { name: globalize.translate('TabNetworks') }, { - name: globalize.translate('TabEpisodes') + name: globalize.translate('Episodes') }]; } diff --git a/src/controllers/user/home/index.html b/src/controllers/user/home/index.html index 79c5ccc4bd..f98f373cb0 100644 --- a/src/controllers/user/home/index.html +++ b/src/controllers/user/home/index.html @@ -1,4 +1,4 @@ -
    +
    diff --git a/src/controllers/user/menu/index.html b/src/controllers/user/menu/index.html index 851a817203..4d91f1206f 100644 --- a/src/controllers/user/menu/index.html +++ b/src/controllers/user/menu/index.html @@ -25,7 +25,7 @@
    -
    ${HeaderHome}
    +
    ${Home}
    diff --git a/src/scripts/itembynamedetailpage.js b/src/scripts/itembynamedetailpage.js index 60be838448..f77bb73652 100644 --- a/src/scripts/itembynamedetailpage.js +++ b/src/scripts/itembynamedetailpage.js @@ -39,14 +39,14 @@ function renderItems(page, item) { if (item.EpisodeCount) { sections.push({ - name: globalize.translate('TabEpisodes'), + name: globalize.translate('Episodes'), type: 'Episode' }); } if (item.TrailerCount) { sections.push({ - name: globalize.translate('TabTrailers'), + name: globalize.translate('Trailers'), type: 'Trailer' }); } @@ -60,7 +60,7 @@ function renderItems(page, item) { if (item.MusicVideoCount) { sections.push({ - name: globalize.translate('TabMusicVideos'), + name: globalize.translate('HeaderMusicVideos'), type: 'MusicVideo' }); } diff --git a/src/scripts/libraryBrowser.js b/src/scripts/libraryBrowser.js index debae200c0..5b5a1aad80 100644 --- a/src/scripts/libraryBrowser.js +++ b/src/scripts/libraryBrowser.js @@ -109,7 +109,7 @@ export function getQueryPagingHtml (options) { } if (options.filterButton) { - html += ''; + html += ''; } html += '
    '; diff --git a/src/scripts/libraryMenu.js b/src/scripts/libraryMenu.js index d237eead9d..50061f412e 100644 --- a/src/scripts/libraryMenu.js +++ b/src/scripts/libraryMenu.js @@ -270,7 +270,7 @@ import 'flexStyles'; function refreshLibraryInfoInDrawer(user, drawer) { let html = ''; html += '
    '; - html += '' + globalize.translate('ButtonHome') + ''; + html += '' + globalize.translate('Home') + ''; // libraries are added here html += '
    '; From b5ba7db44129e95cf49f7ea36b654e2dea666c24 Mon Sep 17 00:00:00 2001 From: dkanada Date: Sun, 16 Aug 2020 20:35:48 +0900 Subject: [PATCH 285/301] update translation files --- src/strings/af.json | 5 ----- src/strings/ar.json | 33 --------------------------------- src/strings/be-by.json | 1 - src/strings/bg-bg.json | 34 ---------------------------------- src/strings/bn_BD.json | 7 ------- src/strings/ca.json | 25 ------------------------- src/strings/cs.json | 34 ---------------------------------- src/strings/da.json | 34 ---------------------------------- src/strings/de.json | 34 ---------------------------------- src/strings/el.json | 30 ------------------------------ src/strings/en-gb.json | 34 ---------------------------------- src/strings/en-us.json | 34 ---------------------------------- src/strings/es-ar.json | 34 ---------------------------------- src/strings/es-mx.json | 34 ---------------------------------- src/strings/es.json | 34 ---------------------------------- src/strings/es_419.json | 34 ---------------------------------- src/strings/fa.json | 34 ---------------------------------- src/strings/fi.json | 33 --------------------------------- src/strings/fr-ca.json | 7 ------- src/strings/fr.json | 34 ---------------------------------- src/strings/gsw.json | 5 ----- src/strings/he.json | 27 --------------------------- src/strings/hi-in.json | 6 ------ src/strings/hr.json | 31 ------------------------------- src/strings/hu.json | 34 ---------------------------------- src/strings/id.json | 8 -------- src/strings/is-is.json | 21 --------------------- src/strings/it.json | 34 ---------------------------------- src/strings/ja.json | 31 ------------------------------- src/strings/kk.json | 34 ---------------------------------- src/strings/ko.json | 34 ---------------------------------- src/strings/lt-lt.json | 27 --------------------------- src/strings/lv.json | 33 --------------------------------- src/strings/mr.json | 5 ----- src/strings/ms.json | 4 ---- src/strings/nb.json | 34 ---------------------------------- src/strings/nl.json | 34 ---------------------------------- src/strings/pl.json | 34 ---------------------------------- src/strings/pr.json | 4 ---- src/strings/pt-br.json | 34 ---------------------------------- src/strings/pt-pt.json | 34 ---------------------------------- src/strings/pt.json | 31 ------------------------------- src/strings/ro.json | 34 ---------------------------------- src/strings/ru.json | 36 +----------------------------------- src/strings/sk.json | 34 ---------------------------------- src/strings/sl-si.json | 34 ---------------------------------- src/strings/sr.json | 8 -------- src/strings/sv.json | 34 ---------------------------------- src/strings/ta.json | 34 ---------------------------------- src/strings/tr.json | 27 --------------------------- src/strings/uk.json | 11 ----------- src/strings/vi.json | 25 ------------------------- src/strings/zh-cn.json | 34 ---------------------------------- src/strings/zh-hk.json | 20 -------------------- src/strings/zh-tw.json | 34 ---------------------------------- 55 files changed, 1 insertion(+), 1452 deletions(-) diff --git a/src/strings/af.json b/src/strings/af.json index f18b2fc14b..df3ca17f3f 100644 --- a/src/strings/af.json +++ b/src/strings/af.json @@ -41,8 +41,6 @@ "Absolute": "Absoluut", "AlbumArtist": "Album Kunstenaar", "TabLatest": "Nuutste", - "TabInfo": "Inligting", - "TabEpisodes": "Episodes", "TabDirectPlay": "Speel Direk", "TabDashboard": "Paneelbord", "TabContainers": "Houers", @@ -123,12 +121,10 @@ "ThemeSongs": "Tema Liedjies", "TellUsAboutYourself": "Vertel ons van jouself", "TabUpcoming": "Komende", - "TabTrailers": "Voorprente", "TabStreaming": "Stroom", "TabSettings": "Instellings", "TabServer": "Bediener", "TabScheduledTasks": "Geskeduleerde Take", - "TabResumeSettings": "Hervat", "TabResponses": "Reaksies", "TabProfiles": "Profiele", "TabProfile": "Profiel", @@ -138,7 +134,6 @@ "TabNfoSettings": "NFO Instellings", "TabNetworking": "Netwerking", "TabNetworks": "Netwerke", - "TabMusicVideos": "Musiek Videos", "TabMusic": "Musiek", "TabLogs": "Logs" } diff --git a/src/strings/ar.json b/src/strings/ar.json index 23cb2c9cab..ba172b57ae 100644 --- a/src/strings/ar.json +++ b/src/strings/ar.json @@ -21,30 +21,23 @@ "ButtonBack": "خلف", "ButtonCancel": "الغاء", "ButtonChangeServer": "غير الخادم", - "ButtonEdit": "تعديل", - "ButtonEditImages": "تعديل الصور", "ButtonEditOtherUserPreferences": "اضبط إعدادات حساب المستخدم هذا، وصورته وتفضيلاته الشخصية.", - "ButtonFilter": "مرشِّح", "ButtonForgotPassword": "نسيت كلمة السر", "ButtonFullscreen": "ملء الشاشة", "ButtonGuide": "الدليل", - "ButtonHome": "الرئيسية", "ButtonInfo": "معلومات", "ButtonLibraryAccess": "صلاحيات المكتبة", "ButtonManualLogin": "الدخول اليدوي", "ButtonMore": "المزيد", "ButtonNetwork": "الشبكة", "ButtonNextTrack": "المقطوعة التالية", - "ButtonOff": "إيقاف التشغيل", "ButtonOk": "موافق", "ButtonOpen": "إفتح", "ButtonParentalControl": "التحكم الأبوي", "ButtonPause": "توقف مؤقت", - "ButtonPlay": "تشغيل", "ButtonPreviousTrack": "المقطوعة السابقة", "ButtonProfile": "حساب", "ButtonQuickStartGuide": "دليل بدء الاستخدام السريع", - "ButtonRefresh": "إعادة تنشيط", "ButtonRefreshGuideData": "إعادة تنشيط بيانات الدليل", "ButtonRemove": "إزالة", "ButtonRename": "إعادة التسمية", @@ -64,7 +57,6 @@ "ButtonStart": "إبدأ", "ButtonStop": "إيقاف", "ButtonSubmit": "تسليم", - "ButtonSubtitles": "ترجمات", "ButtonTrailer": "العرض الإعلاني", "ButtonUninstall": "إزالة التثبيت", "ButtonWebsite": "موقع إلكتروني", @@ -119,9 +111,7 @@ "HeaderActiveDevices": "الأجهزة المفعّلة", "HeaderActiveRecordings": "التسجيلات المفعلة", "HeaderActivity": "الأنشطة", - "HeaderAddScheduledTaskTrigger": "إضافة زناد", "HeaderAddUpdateImage": "إضافة/تحديث صورة", - "HeaderAddUser": "إضافة مستخدم", "HeaderAdditionalParts": "أدوار إضافية", "HeaderAdmin": "المدير", "HeaderAlert": "تنبيه", @@ -131,10 +121,8 @@ "HeaderApiKeysHelp": "التطبيقات الخارجية تحتاج أن تمتلك مفتاح api لكي تتصل بالخادم. هذه المفاتيح تُصدر عن طريق تسجيل الدخول بمستخدم عادي، أو عن طريق منح التطبيق مفتاحاً أصدر يدوياً.", "HeaderApp": "التطبيق", "HeaderAudioSettings": "إعدادات الصوت", - "HeaderBooks": "الكتب", "HeaderBranding": "وسومات البرنامج", "HeaderCastAndCrew": "الممثلين وطاقم العمل", - "HeaderCastCrew": "الممثلين والطاقم", "HeaderChannelAccess": "صلاحيات القنوات", "HeaderCodecProfile": "عريضة الكودك", "HeaderCodecProfileHelp": "عرائض الكودك تشير إلى محدودية جهاز ما عند تشغيل وسيطة مشفر بكودك معيّن. إن كان هناك أي محدودية مذكورة فستحال الوسيطة إلى التشغير البيني، حتى لو كانت الصيغة مضبوطة للعمل بتلقائية.", @@ -159,12 +147,10 @@ "HeaderDirectPlayProfile": "عريضة التشغيل المباشر", "HeaderDirectPlayProfileHelp": "أضف مباشرةً عريضة تشغيل للإشارة لأي صيغة يتمكن الجهاز من التعامل معه بتلقائية.", "HeaderEasyPinCode": "الرمز الشخصي الميسر", - "HeaderEpisodes": "الحلقات", "HeaderError": "حدث خطأ", "HeaderFeatureAccess": "صلاحية الخاصية", "HeaderFetchImages": "إطهار الصور:", "HeaderForKids": "للأطفال", - "HeaderForgotPassword": "نسيت كلمة السر", "HeaderFrequentlyPlayed": "تم تشغيله مراراً", "HeaderGuideProviders": "مزودو الأدلة", "HeaderHttpHeaders": "رؤوس HTTP", @@ -186,7 +172,6 @@ "HeaderLoginFailure": "فشل في تسجيل الدخول", "HeaderMedia": "الوسائط", "HeaderMediaFolders": "مجلدات الوسائط", - "HeaderMediaInfo": "معلومات الوسيطة", "HeaderMoreLikeThis": "المزيد من الروابط لهذا", "HeaderMusicVideos": "الفيديوهات الموسيقية", "HeaderMyMedia": "وسائطي", @@ -297,7 +282,6 @@ "LabelCustomCertificatePathHelp": "مسار ملف PKCS # 12 يحتوي على شهادة ومفتاح خاص لتمكين دعم TLS على مجال مخصص.", "LabelCustomCss": "تنيسق CSS مخصص:", "LabelCustomCssHelp": "طبق تنسيقك css المخصص لواجهة الويب.", - "LabelCustomDeviceDisplayName": "اسم العرض:", "LabelCustomDeviceDisplayNameHelp": "أذكر اسم عرض مخصوص أو أتركه فارغاً لاستخدام الاسم المبلغ من الجهاز.", "LabelDateAddedBehavior": "كيف يتصرف المحتوى الجديد نحو \"تاريخ الإضافة\" الخاص به:", "LabelDateAddedBehaviorHelp": "إذا اخذت واصفات البيانات قيمة، فإنها سوف تستخدم قبل أن تستخدم أي من هذه الخيارات.", @@ -307,7 +291,6 @@ "LabelDefaultUserHelp": "لتحديد مكتبة المستخدم التي تظهر على الأجهزة المتصلة. بإمكان الامتطاء على هذه القيمة لكل جهاز عن طريق عرائض الأجهزة.", "LabelDeviceDescription": "وصف الجهاز", "LabelDidlMode": "طور DIDL:", - "LabelDisplayMissingEpisodesWithinSeasons": "أظهر الحلقات المفقودة في مجلدات المواسم", "LabelDisplayName": "الاسم المعروض:", "LabelDisplaySpecialsWithinSeasons": "أظهر الحلقات الخاصة في المواسم التي بثت فيها", "LabelDownMixAudioScale": "تعزيز الصوت عند تقليل توزيع قنوات الصوت:", @@ -436,7 +419,6 @@ "LabelPostProcessorArguments": "معطيات سطر الأوامر لتطبيق ما بعد المعالجة", "LabelPostProcessorArgumentsHelp": "استخدم المسار: {path} كمسار لملف التسجيل.", "LabelPreferredDisplayLanguage": "لغة الواجهة المفضلة:", - "LabelPreferredDisplayLanguageHelp": "إن ترجمة أمبي هو مشروع جاري التنفيذ.", "LabelProfileAudioCodecs": "كودك تشفير الصوت", "LabelProfileCodecs": "الكودكات:", "LabelProfileCodecsHelp": "يجب فصل العناصر بفواصل (,). يمكن أن تترك هذه فارغة إذا أريد تطبيقها على كل الكودكات.", @@ -484,12 +466,9 @@ "LabelTag": "البطاقة:", "LabelTime": "الوقت:", "LabelTimeLimitHours": "الوقت المحدد (بالساعة):", - "LabelTranscodingAudioCodec": "كودك تشفير الصوت:", - "LabelTranscodingContainer": "الحاوية:", "LabelTranscodingTempPathHelp": "هذا المجلد يحتوي على ملفات قيد الاستعمال من قبل المشفر البيني. حدد مساراً مخصوصاً او اتركه فارغاً لاستعمال القيمة الافتراضية في مجلد بيانات الخادم.", "LabelTranscodingThreadCount": "عدد مسارات التشفير البيني", "LabelTranscodingThreadCountHelp": "إختر الحد الأقصى المسموح به من مسارات التشفير البيني. إن تقليل عدد المسارات سيقلل من نسبة استخدام المعالج لكنه قد لا يحوّل الوسيطة بالسرعة المطلوبة لتشغيل سلس.", - "LabelTranscodingVideoCodec": "كودك تشفير الفيديو:", "LabelTriggerType": "نوع الزناد:", "LabelTunerIpAddress": "عنوان آي بي المولف:", "LabelTunerType": "نوع المولف:", @@ -573,7 +552,6 @@ "MessagePluginConfigurationRequiresLocalAccess": "لضبط", "MessagePluginInstallDisclaimer": "إن الملحقات التي بناها أعضاء مجتمع أمبي لهي طريقة رائعة لتحسين متعة استخدام أمبي وذلك بإضافة المزايا والخدمات الجديدة. قبل تثبيت الملحقات، نرجو أخذ العلم بالآثار التي قد تلحقها بخادم أمبي الخاص بك، مثل أوقات أطولة لتمشيط مكتبتك، والعمليات الخلفية الإضافية وتقليل استقرار نظامك.", "MessageReenableUser": "أنظر أدناه لإعادة التفعيل", - "MessageSettingsSaved": "تم حفظ الإعدادات.", "MessageTheFollowingLocationWillBeRemovedFromLibrary": "مكان الوسائط التالي سيزال من مكتبة أمبي الخاصة بك:", "MessageUnableToConnectToServer": "لم نستطع الاتصال إلى الخادم المختار في الوقت الحالي. الرجاء التأكد من أنه يعمل ثم المحاولة مرة أخرى.", "MessageUnsetContentHelp": "المحتوى سيعرض كمجدات اعتيادية. لأفضل النتائج استخدم مدير واصفات البيانات لإعداد نوع محتوى المجلدات الفرعية.", @@ -611,7 +589,6 @@ "OptionArtist": "الفنان", "OptionAscending": "تصاعدي", "OptionAuto": "آلي", - "OptionAutomatic": "الآلي", "OptionAutomaticallyGroupSeries": "إدمج الحلقات الموزعة بين عدة مجلدات إلى مجلد واحد تلقائياً.", "OptionAutomaticallyGroupSeriesHelp": "في حال التفعيل فإن الحلقات الموزعة بين عدة مجلدات ستدمج تلقائياً في مجلد مسلسل واحد.", "OptionBlockBooks": "الكتب", @@ -749,18 +726,14 @@ "SystemDlnaProfilesHelp": "عرائض النظام تكون مقفلة للقراءة-فقط. وأي تغيير على عريضة من عرائض النظام ستحفظ إلى عريضة مخصوصة جديدة.", "TabAccess": "الدخول", "TabAdvanced": "متقدم", - "TabAlbumArtists": "فنانو الألبومات", "TabCatalog": "الكتالوج", "TabCodecs": "الكودكات", "TabContainers": "الحاويات", "TabDashboard": "لوحة العدادات", "TabDirectPlay": "تشغيل مباشر", - "TabEpisodes": "الحلقات", - "TabInfo": "معلومات", "TabLatest": "الاخير", "TabLogs": "الكشوفات", "TabMusic": "الموسيقى", - "TabMusicVideos": "الفيديوهات الموسيقية", "TabMyPlugins": "ملحقاتي", "TabNetworks": "الشبكات", "TabNfoSettings": "أعدادات Nfo", @@ -771,12 +744,10 @@ "TabProfile": "عريضة", "TabProfiles": "الحسابات", "TabResponses": "الردود", - "TabResumeSettings": "استئناف الإعدادات", "TabScheduledTasks": "المهام المجدولة", "TabServer": "الخادم", "TabSettings": "الإعدادات", "TabStreaming": "التشغيل التدفقي", - "TabTrailers": "العروض الإعلانية", "TabUpcoming": "القادم", "TellUsAboutYourself": "اخبرنا عن نفسك", "ThisWizardWillGuideYou": "مرشد الاعدادات سيساعدك خلال خطوات عملية الاعدادات. للبدء، الرجاء اختيار لغتك المفضلة.", @@ -1001,7 +972,6 @@ "HeaderKeepRecording": "استمر في التسجيل", "HeaderIdentifyItemHelp": "أدخل معيار بحث واحد أو أكثر. إزالة المعايير لزيادة نتائج البحث.", "HeaderHttpsSettings": "إعدادات HTTPS", - "HeaderHome": "الصفحة الرئيسية", "HeaderFetcherSettings": "إعدادات الجلب", "HeaderFavoritePlaylists": "قوائم التشغيل المفضلة", "HeaderFavoriteVideos": "مقاطع الفيديو المفضلة", @@ -1044,9 +1014,7 @@ "ErrorDeletingItem": "حدث خطأ في حذف العنصر من سيرفر Jellyfin. يرجى التحقق من أن سيرفر Jellyfin لديه حق الوصول للكتابة إلى مجلد الوسائط وحاول مرة أخرى.", "Episode": "حلقة", "EnableThemeVideosHelp": "قم بتشغيل الفيديوهات الرئيسية في الخلفية أثناء تصفح المكتبة.", - "EnableThemeVideos": "الفيديوهات الرئيسية", "EnableThemeSongsHelp": "قم بتشغيل اللحن الرئيسي في الخلفية أثناء تصفح المكتبة.", - "EnableThemeSongs": "اللحن الرئيسي", "EnableStreamLoopingHelp": "قم بتمكين هذا إذا كانت عمليات البث المباشر تحتوي فقط على بضع ثوان من البيانات وتحتاج إلى إعادة طلب مستمر. قد يؤدي تمكين هذا عندما لا تكون هناك حاجة إلى مشاكل.", "EnableStreamLooping": "تكرار البث المباشر", "EnableHardwareEncoding": "تمكين تشفير الأجهزة", @@ -1099,7 +1067,6 @@ "LabelAudioChannels": "قنوات الصوت:", "LabelAudioBitrate": "معدل بث الصوت:", "LabelAudioBitDepth": "عمق بث الصوت:", - "LabelAudio": "الصوت", "LabelAllowedRemoteAddressesMode": "وضع مرشح عنوان المضيف IP البعيد:", "LabelAllowedRemoteAddresses": "مرشح عنوان المضيف IP البعيد:", "LabelAirsBeforeSeason": "عروض بث قبل الموسم:", diff --git a/src/strings/be-by.json b/src/strings/be-by.json index 8bd6d2aa31..adaa0e43e1 100644 --- a/src/strings/be-by.json +++ b/src/strings/be-by.json @@ -3,7 +3,6 @@ "ButtonOk": "ОК", "ButtonQuickStartGuide": "Кіраўніцтва па запуску", "ButtonSignOut": "Sign out", - "HeaderAddUser": "Даданне карыстальніка", "HeaderEasyPinCode": "Просты PIN-код", "HeaderPaths": "Шляхі", "HeaderTaskTriggers": "Трыгеры задачы", diff --git a/src/strings/bg-bg.json b/src/strings/bg-bg.json index 1cc469a9fd..a79650546c 100644 --- a/src/strings/bg-bg.json +++ b/src/strings/bg-bg.json @@ -28,28 +28,21 @@ "ButtonAudioTracks": "Звукови пътеки", "ButtonBack": "Назад", "ButtonCancel": "Отмяна", - "ButtonEdit": "Редактиране", - "ButtonEditImages": "Редактиране на изображенията", - "ButtonFilter": "Филтър", "ButtonForgotPassword": "Забравена парола", "ButtonGotIt": "Добре", "ButtonGuide": "Справочник", - "ButtonHome": "Начало", "ButtonInfo": "Сведения", "ButtonLibraryAccess": "Достъп до библиотеката", "ButtonManualLogin": "Вход с име и парола", "ButtonMore": "Още", "ButtonNextTrack": "Следваща пътека", - "ButtonOff": "Изключено", "ButtonOk": "Добре", "ButtonOpen": "Отваряне", "ButtonParentalControl": "Родителски контрол", "ButtonPause": "Пауза", - "ButtonPlay": "Пускане", "ButtonPreviousTrack": "Предишна пътека", "ButtonProfile": "Профил", "ButtonQuickStartGuide": "Първи стъпки", - "ButtonRefresh": "Опресняване", "ButtonRefreshGuideData": "Обновяване на данните в справочника", "ButtonRemove": "Премахване", "ButtonRename": "Преименуване", @@ -65,7 +58,6 @@ "ButtonSignOut": "Отписване", "ButtonStop": "Спиране", "ButtonSubmit": "Подаване", - "ButtonSubtitles": "Субтитри", "ButtonUninstall": "Деинсталиране", "ButtonWebsite": "Сайт", "ChannelAccessHelp": "Изберете каналите, които да споделите с потребителя. Администраторите ще могат да редактират всички канали, използвайки управлението на метаданни.", @@ -98,7 +90,6 @@ "EditMetadata": "Редактиране на метаданните", "EditSubtitles": "Редактиране на субтитрите", "EnableCinemaMode": "Режим \"Киносалон\"", - "EnableThemeSongs": "Тематични песни", "Ended": "Приключило", "EndsAtValue": "Свършва на {0}", "Episodes": "Епизоди", @@ -130,11 +121,9 @@ "HeaderActiveDevices": "Активни устройства", "HeaderActiveRecordings": "Активни записи", "HeaderActivity": "Дейност", - "HeaderAddScheduledTaskTrigger": "Добавяне на спусък", "HeaderAddToCollection": "Добавяне към колекция", "HeaderAddToPlaylist": "Добавяне към списък", "HeaderAddUpdateImage": "Добавяне/редактиране на изображение", - "HeaderAddUser": "+ Потребител", "HeaderAdditionalParts": "Допълнителни части", "HeaderAdmin": "Администриране", "HeaderAlbumArtists": "Изпълнители на албуми", @@ -142,9 +131,7 @@ "HeaderApiKeys": "ППИ ключове", "HeaderApp": "Програма", "HeaderAudioSettings": "Настройки на звука", - "HeaderBooks": "Книги", "HeaderCastAndCrew": "Артисти и изпълнители", - "HeaderCastCrew": "Артисти и изпълнители", "HeaderCodecProfile": "Профил на кодека", "HeaderContainerProfile": "Профил на контейнера", "HeaderContinueListening": "Продължаване на слушането", @@ -163,7 +150,6 @@ "HeaderFeatureAccess": "Достъп до функции", "HeaderFetchImages": "Свали изображения:", "HeaderForKids": "Детски", - "HeaderForgotPassword": "Забравена парола", "HeaderFrequentlyPlayed": "Често пускани", "HeaderGuideProviders": "Доставчици на справочници", "HeaderIdentification": "Идентификация", @@ -182,7 +168,6 @@ "HeaderLibrarySettings": "Настройки на библиотеката", "HeaderMedia": "Медия", "HeaderMediaFolders": "Медийни папки", - "HeaderMediaInfo": "Сведения", "HeaderMetadataSettings": "Настройки на метаданните", "HeaderMoreLikeThis": "Подобни", "HeaderMusicQuality": "Качество на музиката", @@ -271,7 +256,6 @@ "LabelCustomCertificatePathHelp": "Път до файл с шифровъчен стандарт №12 (PKCS #12), съдържащ сертификат и частен ключ за поддръжка на протокол TLS на собствен домейн.", "LabelCustomCss": "CSS по избор:", "LabelCustomCssHelp": "Добавете собствен стил към уеб-интерфейса.", - "LabelCustomDeviceDisplayName": "Показвано име:", "LabelCustomRating": "Оценка по избор:", "LabelDateAdded": "Дата на добавяне:", "LabelDateTimeLocale": "Местоположение за дата и час:", @@ -279,7 +263,6 @@ "LabelDeviceDescription": "Описание на устройството", "LabelDisplayLanguage": "Език на показване:", "LabelDisplayLanguageHelp": "Превеждането на Емби е текущ проект.", - "LabelDisplayMissingEpisodesWithinSeasons": "Показване на липсващите епизоди в сезоните", "LabelDisplayMode": "Режим на показване:", "LabelDisplayName": "Показвано име:", "LabelDisplayOrder": "Ред на показване:", @@ -361,7 +344,6 @@ "LabelPlayDefaultAudioTrack": "Да се пуска първоначалната звукова пътечка независимо от езика", "LabelPlaylist": "Списък:", "LabelPreferredDisplayLanguage": "Предпочитан език на показване:", - "LabelPreferredDisplayLanguageHelp": "Превеждането на Емби е текущ проект.", "LabelPreferredSubtitleLanguage": "Предпочитан език на субтитрите:", "LabelProfileAudioCodecs": "Звукови кодеци:", "LabelProfileCodecs": "Кодеци:", @@ -394,7 +376,6 @@ "LabelStatus": "Състояние:", "LabelStopWhenPossible": "Спирай, когато е възможно:", "LabelSubtitlePlaybackMode": "Режим на субтитрите:", - "LabelSubtitles": "Субтитри", "LabelSupportedMediaTypes": "Поддържани типове медия:", "LabelTag": "Етикет:", "LabelTextColor": "Цвят на текста:", @@ -403,9 +384,7 @@ "LabelTime": "Време:", "LabelTimeLimitHours": "Времево ограничение (часове):", "LabelTitle": "Заглавие:", - "LabelTranscodingAudioCodec": "Звуков кодек:", "LabelTranscodingTempPathHelp": "Посочете персонализиран път за файлове,които е необходимо да бъдат транскодирани и доставени на клиентите. Оставете празно ,за да се използва мястото по подразбиране.", - "LabelTranscodingVideoCodec": "Видеокодек:", "LabelTriggerType": "Тип на спусъка:", "LabelType": "Вид:", "LabelTypeText": "Текст", @@ -448,7 +427,6 @@ "MessageNoPluginsInstalled": "Нямате инсталирани приставки.", "MessageNothingHere": "Тук няма нищо.", "MessagePleaseEnsureInternetMetadata": "Моля, уверете се че свалянето на метаданни от интернет е разрешено.", - "MessageSettingsSaved": "Настройките са запазени.", "MessageTheFollowingLocationWillBeRemovedFromLibrary": "Следните местоположения ще бъдат премахнати от библиотеката ви:", "MessageYouHaveVersionInstalled": "В момента имате инсталирана версия {0}.", "MetadataManager": "Управление на метаданните", @@ -490,7 +468,6 @@ "OptionArtist": "Изпълнител", "OptionAscending": "Възходящо", "OptionAuto": "Автоматично", - "OptionAutomatic": "Автоматично", "OptionBlockBooks": "Книги", "OptionBlockMovies": "Филми", "OptionBlockTvShows": "Телевизионни сериали", @@ -634,18 +611,14 @@ "TV": "Телевизор", "TabAccess": "Достъп", "TabAdvanced": "Допълнителни", - "TabAlbumArtists": "Изпълнители на албуми", "TabCatalog": "Каталог", "TabCodecs": "Кодеци", "TabContainers": "Контейнери", "TabDashboard": "Табло", "TabDirectPlay": "Директно пускане", - "TabEpisodes": "Епизоди", - "TabInfo": "Информация", "TabLatest": "Последни", "TabLogs": "Журнали", "TabMusic": "Музика", - "TabMusicVideos": "Музикални клипове", "TabMyPlugins": "Моите приставки", "TabNetworks": "Мрежи", "TabNfoSettings": "Формат за метаданни NFO", @@ -656,12 +629,10 @@ "TabProfile": "Профил", "TabProfiles": "Профили", "TabResponses": "Отговори", - "TabResumeSettings": "Възобнови", "TabScheduledTasks": "Планирани задачи", "TabServer": "Сървър", "TabSettings": "Настройки", "TabStreaming": "Излъчване", - "TabTrailers": "Трейлъри", "TabUpcoming": "Предстоящи", "Tags": "Етикети", "TagsValue": "Етикети: {0}", @@ -833,7 +804,6 @@ "EnableDetailsBannerHelp": "Покажи картинка с банер в горната част на страницата с детайли.", "EnableDetailsBanner": "Банер с подробности", "EnableThemeVideosHelp": "Пускай тематични видеа на заден план ,докато се разглежда библиотеката.", - "EnableThemeVideos": "Тематични видеа", "EnableThemeSongsHelp": "Пускай тематична музика ,докато се разглежда библиотеката.", "EnableStreamLoopingHelp": "Включи това ,ако поточното видео се предава на кратки интервали и е необходимо да се изпращат заявки постоянно.Включването на тази опция без нужда може да породи проблеми.", "EnableStreamLooping": "Автоматично повторение на поточни видеа", @@ -871,7 +841,6 @@ "HeaderFavoriteMovies": "Любими филми", "HeaderFavoriteBooks": "Любими книги", "HeaderExternalIds": "Външни идентификатори:", - "HeaderEpisodes": "Епизоди", "HeaderEnabledFieldsHelp": "Махни отметката ,за да го заключиш и да предотвратиш неговата промяна.", "HeaderDVR": "DVR (Цифрово записващо устройство)", "HeaderDirectPlayProfileHelp": "Добави профили за директно възпроизвеждане ,за да се укаже кои формати може да възпроизвежда устройството.", @@ -970,7 +939,6 @@ "HeaderIdentificationCriteriaHelp": "Въведете пони един критерии.", "HeaderHttpsSettings": "HTTPS настройки", "HeaderHttpHeaders": "HTTP Хедъри", - "HeaderHome": "Главна", "HeaderFetcherSettings": "Настройки на програмата за изтегляне", "HeaderFavoritePlaylists": "Любими списъци", "LabelDeathDate": "Дата на смърт:", @@ -996,7 +964,6 @@ "LabelAudioChannels": "Аудио канали:", "LabelAudioBitrate": "Скорост на предаване на аудиото:", "LabelAudioBitDepth": "Битова дълбочина на аудиото:", - "LabelAudio": "Аудио", "LabelAppNameExample": "Примерно: Sickbeard, Sonarr", "LabelAllowedRemoteAddressesMode": "Режим на филтъра за външни ИП адреси:", "LabelAllowedRemoteAddresses": "Филтър за външни ИП адреси:", @@ -1176,7 +1143,6 @@ "LabelTranscodingFramerate": "Честота на кадрите при транскодиране:", "LabelTranscodes": "Транскодирания:", "LabelTranscodePath": "Път за транскодиране:", - "LabelTranscodingContainer": "Контейнер:", "LabelTrackNumber": "Номер на песен:", "LabelTextBackgroundColor": "Цвят на фона на текста:", "LabelTagline": "Ключова фраза:", diff --git a/src/strings/bn_BD.json b/src/strings/bn_BD.json index e13514fda4..3f11b4f050 100644 --- a/src/strings/bn_BD.json +++ b/src/strings/bn_BD.json @@ -17,26 +17,20 @@ "AddToPlaylist": "প্লেলিস্টে অ্যাড করুন", "AddToPlayQueue": "প্লে কিউ তে অ্যাড করুন", "AddToCollection": "কালেকশন এ অ্যাড করুন", - "ButtonPlay": "চালান", "ButtonPause": "বিরতি", "ButtonParentalControl": "অভিভাবকীয় নিয়ন্ত্রণ", "ButtonOpen": "খুলুন", "ButtonOk": "আচ্ছা", - "ButtonOff": "বন্ধ", "ButtonNextTrack": "পরবর্তী ট্র্যাক", "ButtonNetwork": "নেটওয়ার্ক", "ButtonMore": "আরও", "ButtonLibraryAccess": "লাইব্রেরি অ্যাক্সেস", "ButtonInfo": "তথ্য", - "ButtonHome": "হোম", "ButtonGuide": "গাইড", "ButtonGotIt": "বুঝেছি", "ButtonFullscreen": "ফুলস্ক্রিন", "ButtonForgotPassword": "পাসওয়ার্ড ভুলে গেছি", - "ButtonFilter": "ফিলটার", "ButtonEditOtherUserPreferences": "এই ব্যবহারকারীর প্রোফাইল, ছবি এবং ব্যক্তিগত পছন্দগুলি এডিট করুন।", - "ButtonEditImages": "ছবিগুলি এডিট করুন", - "ButtonEdit": "এডিট করুন", "ButtonChangeServer": "সার্ভার পরিবর্তন করুন", "ButtonCancel": "বাতিল", "ButtonBack": "অনগ্রসর", @@ -91,7 +85,6 @@ "ButtonRename": "নামান্তর", "ButtonRemove": "সরান", "ButtonRefreshGuideData": "গাইড ডেটা রিফ্রেশ করুন", - "ButtonRefresh": "রিফ্রেশ", "ButtonQuickStartGuide": "দ্রুত শুরু করার নির্দেশাবলী", "CopyStreamURL": "স্ট্রিম ইউআরএল কপি", "ContinueWatching": "দেখা অব্যাহত রাখুন", diff --git a/src/strings/ca.json b/src/strings/ca.json index 413fef4792..c199cb2cbe 100644 --- a/src/strings/ca.json +++ b/src/strings/ca.json @@ -23,14 +23,10 @@ "ButtonBack": "Darrera", "ButtonCancel": "Cancel·la", "ButtonChangeServer": "Canvia Servidor", - "ButtonEdit": "Edita", - "ButtonEditImages": "Edita les imatges", "ButtonEditOtherUserPreferences": "Edita el perfil, la imatge i les preferències d'aquest usuari.", - "ButtonFilter": "Filtra", "ButtonForgotPassword": "He oblidat la contrasenya", "ButtonGotIt": "Entesos", "ButtonGuide": "Guia", - "ButtonHome": "Inici", "ButtonLibraryAccess": "Accés a la biblioteca", "ButtonManualLogin": "Inici de sessió manual", "ButtonMore": "Més", @@ -39,11 +35,9 @@ "ButtonOpen": "Obre", "ButtonParentalControl": "Control parental", "ButtonPause": "Pausa", - "ButtonPlay": "Reprodueix", "ButtonPreviousTrack": "Pista anterior", "ButtonProfile": "Perfil", "ButtonQuickStartGuide": "Guia d'inici ràpid", - "ButtonRefresh": "Refresca", "ButtonRefreshGuideData": "Refresca les Dades de la Guia", "ButtonRemove": "Elimina", "ButtonResetEasyPassword": "Reinicia el codi pin senzill", @@ -59,7 +53,6 @@ "ButtonSignOut": "Tanca sessió", "ButtonStop": "Atura", "ButtonSubmit": "Envia", - "ButtonSubtitles": "Subtítols", "ButtonTrailer": "Tràiler", "CancelRecording": "Cancel·la enregistrament", "CancelSeries": "Cancel·la sèrie", @@ -113,22 +106,18 @@ "HeaderActiveDevices": "Dispositius Actius", "HeaderActiveRecordings": "Enregistraments Actius", "HeaderActivity": "Activitat", - "HeaderAddScheduledTaskTrigger": "Afegir Disparador", "HeaderAddToCollection": "Afegir a Col·lecció", "HeaderAddToPlaylist": "Afegir a la llista de reproducció", "HeaderAddUpdateImage": "Afegir/Actualitzar Imatge", - "HeaderAddUser": "Afegir Usuari", "HeaderAdditionalParts": "Parts addicionals", "HeaderApiKey": "Clau Api", "HeaderApiKeys": "Claus Api", "HeaderApiKeysHelp": "Les aplicacions externes requereixen una Api key pere tal de poder-se comunicar amb el Servidor d'Jellyfin. Les claus són emeses iniciant sessió amb un compte d'Jellyfin, o concedint manualment una clau a l'aplicació.", "HeaderAudioSettings": "Preferències d'Àudio", - "HeaderBooks": "Llibres", "HeaderBranding": "Aparença", "HeaderCancelRecording": "Cancel·lar Enregistrament", "HeaderCancelSeries": "Cancel·lar Sèries", "HeaderCastAndCrew": "Repartiment i Equip", - "HeaderCastCrew": "Repartiment i Equip", "HeaderCodecProfile": "Perfil de Còdec", "HeaderConfirmProfileDeletion": "Confirmar Supressió de Perfil", "HeaderConnectToServer": "Connectar al Servidor", @@ -151,7 +140,6 @@ "HeaderExternalIds": "Identificadors externs:", "HeaderFeatureAccess": "Accés a Funcions", "HeaderFetchImages": "Obtingues Imatges:", - "HeaderForgotPassword": "He oblidat la contrasenya", "HeaderFrequentlyPlayed": "Reproduït Freqüentment", "HeaderHttpHeaders": "Capçaleres Http", "HeaderIdentification": "Identificació", @@ -173,7 +161,6 @@ "HeaderLibraryOrder": "Ordre de la llibreria", "HeaderLibrarySettings": "Preferències de la Biblioteca", "HeaderMediaFolders": "Directoris Multimèdia", - "HeaderMediaInfo": "Info Multimèdia", "HeaderMetadataSettings": "Preferències de Metadades", "HeaderMusicVideos": "Vídeos Musicals", "HeaderMyDevice": "El meu dispositiu", @@ -260,7 +247,6 @@ "LabelCurrentPassword": "Contrasenya actual:", "LabelCustomCss": "CSS propi:", "LabelCustomCssHelp": "Aplica el teu propi css a la interfície web.", - "LabelCustomDeviceDisplayName": "Nom a mostrar:", "LabelDateAdded": "Data afegit:", "LabelDay": "Dia:", "LabelDeathDate": "Data de defunció:", @@ -269,7 +255,6 @@ "LabelDeviceDescription": "Descripció del dispositiu", "LabelDiscNumber": "Disc:", "LabelDisplayLanguage": "Idioma de visualització:", - "LabelDisplayMissingEpisodesWithinSeasons": "Mostra els episodis que manquen dins les temporades", "LabelDisplayName": "Nom a mostrar:", "LabelDisplayOrder": "Ordre de visualització:", "LabelDisplaySpecialsWithinSeasons": "Mostra els especials dins les temporades en que van ser emesos", @@ -354,7 +339,6 @@ "LabelPlayDefaultAudioTrack": "Reprodueix la pista d'àudio per defecte independentment de l'idioma", "LabelPlaylist": "Llista de rep.:", "LabelPreferredDisplayLanguage": "Idioma de visualització preferit:", - "LabelPreferredDisplayLanguageHelp": "La traducció d'Jellyfin és un projecte en curs.", "LabelPreferredSubtitleLanguage": "Idioma preferit de subtítols:", "LabelProfileAudioCodecs": "Còdecs d'àudio:", "LabelProfileCodecs": "Còdecs:", @@ -390,10 +374,7 @@ "LabelTimeLimitHours": "Temps límit (en hores):", "LabelTitle": "Títol:", "LabelTrackNumber": "Pista:", - "LabelTranscodingAudioCodec": "Còdec d'àudio", - "LabelTranscodingContainer": "Contenidor:", "LabelTranscodingTempPathHelp": "Aquest directori conté fitxers emprats pel transcodificador. Especifica un directori personalitzat o deixa-ho en blanc per emprar el per defecte dins el directori de dades del servidor.", - "LabelTranscodingVideoCodec": "Còdec de vídeo:", "LabelTriggerType": "Tipus de Disparador:", "LabelType": "Tipus:", "LabelUseNotificationServices": "Empra els següents serveis:", @@ -433,7 +414,6 @@ "MessageNoTrailersFound": "No s'han trobat tràilers. Instal·la el canal Trailer per millorar la teva experiència amb les pel·lícules afegint una llibreria de tràilers d'internet.", "MessageNothingHere": "Res aquí.", "MessagePleaseEnsureInternetMetadata": "Si et plau, assegura't que la descàrrega de metadades d'internet està habilitada.", - "MessageSettingsSaved": "Preferències desades.", "MessageYouHaveVersionInstalled": "Actualment tens la versió {0} instal·lada.", "MetadataManager": "Gestor de Metadades", "MinutesAfter": "minuts després", @@ -607,11 +587,8 @@ "TabContainers": "Contenidors", "TabDashboard": "Tauler de Control", "TabDirectPlay": "Reproducció Directa", - "TabEpisodes": "Episodis", - "TabInfo": "Informació", "TabLatest": "Novetats", "TabMusic": "Música", - "TabMusicVideos": "Vídeos musicals", "TabMyPlugins": "Els meus complements", "TabNetworks": "Cadenes", "TabNfoSettings": "Preferències d'Nfo", @@ -625,7 +602,6 @@ "TabScheduledTasks": "Tasques Programades", "TabServer": "Servidor", "TabSettings": "Preferències", - "TabTrailers": "Tràilers", "TabUpcoming": "Properament", "Tags": "Etiquetes", "TellUsAboutYourself": "Explica'ns sobre tu", @@ -721,7 +697,6 @@ "ChannelNameOnly": "Número de canal", "ChangingMetadataImageSettingsNewContent": "Els canvis als paràmetres de descàrrega de metadades o d'obra d'art només s'apliquen al contingut nou afegit a la biblioteca. Per aplicar els canvis als títols existents, haureu de refrescar les metadades manualment.", "ButtonTogglePlaylist": "Llista de reproducció", - "ButtonOff": "Apagar", "BurnSubtitlesHelp": "Determina si el servidor hauria de gravar els subtítols en transcodificar vídeos. Evitar això millorarà molt el rendiment. Seleccioneu Automàtica per gravar formats basats en imatges (VOBSUB, PGS, SUB, IDX) i certs subtítols ASS o SSA.", "Browse": "Navega", "BoxRear": "Caixa (posterior)", diff --git a/src/strings/cs.json b/src/strings/cs.json index 3156bf36bc..cf7b3cf2e9 100644 --- a/src/strings/cs.json +++ b/src/strings/cs.json @@ -43,29 +43,22 @@ "ButtonBack": "Zpět", "ButtonCancel": "Zrušit", "ButtonChangeServer": "Změna serveru", - "ButtonEdit": "Upravit", - "ButtonEditImages": "Editovat obrázky", "ButtonEditOtherUserPreferences": "Editace uživatelského profilu, avataru a osobních preferencí.", - "ButtonFilter": "Filtr", "ButtonForgotPassword": "Zapomenuté heslo", "ButtonFullscreen": "Celá obrazovka", "ButtonGotIt": "Mám to", "ButtonGuide": "Programový průvodce", - "ButtonHome": "Domů", "ButtonLibraryAccess": "Přístup ke knihovně", "ButtonManualLogin": "Manuální přihlášení", "ButtonMore": "Více", "ButtonNetwork": "Síť", "ButtonNextTrack": "Následující stopa", - "ButtonOff": "Vypnout", "ButtonOpen": "Otevřít", "ButtonParentalControl": "Rodičovská kontrola", "ButtonPause": "Pozastavit", - "ButtonPlay": "Přehrát", "ButtonPreviousTrack": "Předchozí stopa", "ButtonProfile": "Profil", "ButtonQuickStartGuide": "Rychlý průvodce", - "ButtonRefresh": "Obnovit", "ButtonRefreshGuideData": "Obnovit data programového průvodce", "ButtonRemove": "Odstranit", "ButtonRename": "Přejmenovat", @@ -83,7 +76,6 @@ "ButtonSignOut": "Odhlásit se", "ButtonStop": "Zastavit", "ButtonSubmit": "Potvrdit", - "ButtonSubtitles": "Titulky", "ButtonTrailer": "Upoutávka", "ButtonUninstall": "Odinstalovat", "ButtonWebsite": "Webové stránky", @@ -151,9 +143,7 @@ "EnableNextVideoInfoOverlay": "Zobrazit informaci o následujícím videu během přehrávání", "EnablePhotos": "Zobrazit fotky", "EnablePhotosHelp": "Obrázky budou detekovány a zobrazeny spolu s dalšími multimediálními soubory.", - "EnableThemeSongs": "Tématická hudba na pozadí", "EnableThemeSongsHelp": "Přehrát tématickou hudbu na pozadí při procházení knihovny.", - "EnableThemeVideos": "Tématická videa", "EnableThemeVideosHelp": "Přehrát tématické video na pozadí při procházení knihovny.", "Ended": "Ukončeno", "EndsAtValue": "Končí v {0}", @@ -202,11 +192,9 @@ "HeaderActiveDevices": "Aktivní zařízení", "HeaderActiveRecordings": "Aktivní nahrávání", "HeaderActivity": "Aktivita", - "HeaderAddScheduledTaskTrigger": "Přidat Spouštěč", "HeaderAddToCollection": "Přidat do Kolekce", "HeaderAddToPlaylist": "Přidat do playlistu", "HeaderAddUpdateImage": "Přidat/aktualizovat obrázek", - "HeaderAddUser": "Přidat uživatele", "HeaderAdditionalParts": "Další součásti", "HeaderAdmin": "Administrátor", "HeaderAlbumArtists": "Umělci alba", @@ -217,12 +205,10 @@ "HeaderApp": "Aplikace", "HeaderAudioBooks": "Audio knihy", "HeaderAudioSettings": "Nastavení zvuku", - "HeaderBooks": "Knihy", "HeaderBranding": "Branding", "HeaderCancelRecording": "Zrušit nahrávání", "HeaderCancelSeries": "Ukončit Seriál", "HeaderCastAndCrew": "Herci a obsazení", - "HeaderCastCrew": "Herci a obsazení", "HeaderChannelAccess": "Přístup ke kanálu", "HeaderCodecProfile": "Profil kodeků", "HeaderCodecProfileHelp": "Kodek profily označují omezení daného zařízení pro přehrávání pomocí specifických kodeků. Jestliže je omezení aplikováno, média budou překódovany i v případě, že kodek je nakonfigurován pro přímé přehrávání.", @@ -252,12 +238,10 @@ "HeaderEditImages": "Editovat obrázky", "HeaderEnabledFields": "Povolené pole", "HeaderEnabledFieldsHelp": "Zrušte zaškrtnutí, abyste zabránily změnám dat.", - "HeaderEpisodes": "Epizody", "HeaderError": "Chyba", "HeaderFeatureAccess": "Přístup k funkcím", "HeaderFetchImages": "Načíst obrázky:", "HeaderForKids": "Pro děti", - "HeaderForgotPassword": "Zapomenuté heslo", "HeaderFrequentlyPlayed": "Nejčastěji přehráváno", "HeaderGuideProviders": "Poskytovatelé programových průvodců", "HeaderHttpHeaders": "Http hlavičky", @@ -283,7 +267,6 @@ "HeaderLoginFailure": "Přihlášení selhalo", "HeaderMedia": "Média", "HeaderMediaFolders": "Složky médií", - "HeaderMediaInfo": "Informace o médiu", "HeaderMetadataSettings": "Nastavení metadat", "HeaderMoreLikeThis": "Podobné položky", "HeaderMusicQuality": "Kvalita hudby", @@ -402,7 +385,6 @@ "LabelAppNameExample": "Příklad: Sickbeard, Sonarr", "LabelArtists": "Umělci:", "LabelArtistsHelp": "Více interpretů se odděluje pomocí středníku.", - "LabelAudio": "Zvuk", "LabelAudioLanguagePreference": "Preferovaný jazyk zvuku:", "LabelBindToLocalNetworkAddress": "Vázat na místní síťovou adresu:", "LabelBindToLocalNetworkAddressHelp": "Změní místní IP adresu serveru HTTP. Pokud je ponecháno prázdné, server bude svázán se všemi dostupnými adresami. Změna této hodnoty vyžaduje restartování.", @@ -422,7 +404,6 @@ "LabelCurrentPassword": "Aktuální heslo:", "LabelCustomCss": "Vlastní CSS:", "LabelCustomCssHelp": "Aplikovat vaše vlastní styly webového rozhraní.", - "LabelCustomDeviceDisplayName": "Jméno pro zobrazení:", "LabelCustomDeviceDisplayNameHelp": "Nahradit vlastním názvem zobrazení nebo ponechte prázdné, aby název byl určen zařízením.", "LabelCustomRating": "Vlastní hodnocení:", "LabelDateAdded": "Datum přidání:", @@ -437,7 +418,6 @@ "LabelDiscNumber": "Číslo disku:", "LabelDisplayLanguage": "Jazyk rozhraní:", "LabelDisplayLanguageHelp": "Překlad projektu Jellyfin se neustále vyvíjí.", - "LabelDisplayMissingEpisodesWithinSeasons": "Zobrazit chybějící epizody", "LabelDisplayMode": "Režim zobrazení:", "LabelDisplayName": "Zobrazované jméno:", "LabelDisplayOrder": "Pořadí zobrazení:", @@ -580,7 +560,6 @@ "LabelPostProcessorArguments": "Argumenty příkazové řádky pro následné zpracování:", "LabelPostProcessorArgumentsHelp": "Použij {path} jako cestu k nahrávanému souboru.", "LabelPreferredDisplayLanguage": "Preferovaný jazyk zobrazení:", - "LabelPreferredDisplayLanguageHelp": "Překlad projektu Jellyfin se neustále vyvíjí.", "LabelPreferredSubtitleLanguage": "Preferovaný jazyk titulků:", "LabelProfileAudioCodecs": "Audio kodeky:", "LabelProfileCodecs": "Kodeky:", @@ -632,7 +611,6 @@ "LabelStopping": "Zastavování", "LabelSubtitleFormatHelp": "Příklad: srt", "LabelSubtitlePlaybackMode": "Mód titulků:", - "LabelSubtitles": "Titulky", "LabelSupportedMediaTypes": "Podporované typy médií:", "LabelTagline": "Slogan:", "LabelTextBackgroundColor": "Barva pozadí textu:", @@ -643,12 +621,9 @@ "LabelTimeLimitHours": "Časový limit (v hodinách):", "LabelTitle": "Název:", "LabelTrackNumber": "Číslo stopy:", - "LabelTranscodingAudioCodec": "Audio kodek:", - "LabelTranscodingContainer": "Obal:", "LabelTranscodingTempPathHelp": "Určete vlastní cestu pro překódované soubory odesílané klientům. Chcete-li použít výchozí nastavení serveru, ponechte pole prázdné.", "LabelTranscodingThreadCount": "Počet vláken pro překódování:", "LabelTranscodingThreadCountHelp": "Zadejte maximální počet vláken pro překódování. Snížením počtu vláken se sníží využití procesoru, ale převod nemusí být dostatečně rychlý pro plynulé přehrávání.", - "LabelTranscodingVideoCodec": "Video kodek:", "LabelTriggerType": "Typ úkolu:", "LabelTunerIpAddress": "IP adresa tuneru:", "LabelTunerType": "Typ tuneru:", @@ -745,7 +720,6 @@ "MessagePluginConfigurationRequiresLocalAccess": "Pro konfiguraci zásuvného modulu se přihlaste přímo na lokální server.", "MessagePluginInstallDisclaimer": "Zásuvné moduly vytvořené členy komunity jsou skvělým způsobem, jak si zlepšit prožitek pomocí dalších funkcí. Před instalací se prosím seznamte se všemi dopady, které mohou doplňky na server mít, např.: pomalejší skenování knihovny, delší zpracování na pozadí nebo snížená stabilita systému.", "MessageReenableUser": "Viz níže pro znovuzapnutí", - "MessageSettingsSaved": "Nastavení uloženo.", "MessageTheFollowingLocationWillBeRemovedFromLibrary": "Z vaší knihovny budou odstraněny následující zdroje médií:", "MessageUnableToConnectToServer": "Nejsme schopni se připojit k vybranému serveru právě teď. Prosím, ujistěte se, že je spuštěn a zkuste to znovu.", "MessageUnsetContentHelp": "Obsah je zobrazen pomocí prostých složek. Pro dosažení nejlepších výsledků pomocí správce metadat nastavte typy obsahu pod-složek.", @@ -802,7 +776,6 @@ "OptionArtist": "Umělec", "OptionAscending": "Vzestupně", "OptionAuto": "Automaticky", - "OptionAutomatic": "Automaticky", "OptionAutomaticallyGroupSeries": "Automatické sloučení k seriálu, které jsou ve více složkách", "OptionAutomaticallyGroupSeriesHelp": "Seriály uložené ve více složkách v této knihovně budou automaticky sloučeny do jednoho seriálu.", "OptionBlockBooks": "Knihy", @@ -1014,16 +987,13 @@ "SystemDlnaProfilesHelp": "Systémové profily jsou jen pro čtení. Chcete-li přepsat profil systému, vytvořit vlastní profil zaměřený na stejné zařízení.", "TabAccess": "Přístup", "TabAdvanced": "Pokročilé", - "TabAlbumArtists": "Umělci alba", "TabCatalog": "Katalog", "TabCodecs": "Kodeky", "TabContainers": "Obaly", "TabDashboard": "Nástěnka", - "TabEpisodes": "Epizody", "TabLatest": "Nejnovější", "TabLogs": "Záznamy", "TabMusic": "Hudba", - "TabMusicVideos": "Hudební videa", "TabMyPlugins": "Moje zásuvné moduly", "TabNetworks": "Stanice", "TabNfoSettings": "NFO nastavení", @@ -1034,11 +1004,9 @@ "TabProfile": "Profil", "TabProfiles": "Profily", "TabResponses": "Odpovědi", - "TabResumeSettings": "Obnovit", "TabScheduledTasks": "Naplánované úlohy", "TabSettings": "Nastavení", "TabStreaming": "Streamování", - "TabTrailers": "Upoutávky", "TabUpcoming": "Nadcházející", "Tags": "Tagy", "TellUsAboutYourself": "Řekněte nám něco o sobě", @@ -1296,7 +1264,6 @@ "SubtitleDownloadersHelp": "Povolte a zařaďte preferované stahovače titulků v pořadí podle priority.", "TV": "TV", "TabDirectPlay": "Přímé přehrávání", - "TabInfo": "Info", "TabServer": "Server", "TagsValue": "Tagy: {0}", "ThemeSongs": "Tematická hudba", @@ -1312,7 +1279,6 @@ "Vertical": "Svisle", "ViewPlaybackInfo": "Zobrazení informací o přehrávání", "Whitelist": "Povolit vše kromě výjimek", - "HeaderHome": "Domů", "DashboardOperatingSystem": "Operační systém: {0}", "DashboardArchitecture": "Architektura: {0}", "MessageNoServersAvailable": "Pomocí automatického zjišťování nebyly nalezeny žádné servery.", diff --git a/src/strings/da.json b/src/strings/da.json index 20e237c7fe..e097d93dd2 100644 --- a/src/strings/da.json +++ b/src/strings/da.json @@ -40,26 +40,20 @@ "ButtonBack": "Tilbage", "ButtonCancel": "Annuller", "ButtonChangeServer": "Skift server", - "ButtonEdit": "Rediger", - "ButtonEditImages": "Rediger billeder", "ButtonEditOtherUserPreferences": "Rediger denne brugers profil, billede og personlige indstillinger.", "ButtonForgotPassword": "Glemt Adgangskode", "ButtonFullscreen": "Fuld skærm", "ButtonGotIt": "Forstået", - "ButtonHome": "Hjem", "ButtonLibraryAccess": "Biblioteksadgang", "ButtonManualLogin": "Manuel Login", "ButtonMore": "Mere", "ButtonNetwork": "Netværk", "ButtonNextTrack": "Næste spor", - "ButtonOff": "Fra", "ButtonOpen": "Åben", "ButtonParentalControl": "Forældrekontrol", - "ButtonPlay": "Afspil", "ButtonPreviousTrack": "Forrige spor", "ButtonProfile": "Profil", "ButtonQuickStartGuide": "Hurtig-start guide", - "ButtonRefresh": "Opdater", "ButtonRefreshGuideData": "Opdater Guide data", "ButtonRemove": "Fjern", "ButtonRename": "Omdøb", @@ -77,7 +71,6 @@ "ButtonSignIn": "Log Ind", "ButtonSignOut": "Log ud", "ButtonSubmit": "Indsend", - "ButtonSubtitles": "Undertekster", "ButtonUninstall": "Afinstaller", "ButtonWebsite": "Hjemmeside", "CancelRecording": "Annuller optagelse", @@ -169,11 +162,9 @@ "HeaderActiveDevices": "Aktive enheder", "HeaderActiveRecordings": "Aktive optagelser", "HeaderActivity": "Aktivitet", - "HeaderAddScheduledTaskTrigger": "Tilføj udløser", "HeaderAddToCollection": "Tilføj til samling", "HeaderAddToPlaylist": "Tilføj til afspilningsliste", "HeaderAddUpdateImage": "Tilføj/opdater billede", - "HeaderAddUser": "Tilføj bruger", "HeaderAdditionalParts": "Andre stier", "HeaderAlert": "Advarsel", "HeaderAllowMediaDeletionFrom": "Tillad Media Sletning Fra", @@ -182,11 +173,9 @@ "HeaderApiKeysHelp": "Eksterne applikationer skal have en API-nøgle for at kunne kommunikere med Jellyfin. Nøgler udstedes ved at logge ind med en Jellyfin konto, eller ved manuelt at tildele applikationen en nøgle.", "HeaderAudioSettings": "Lydindstillinger", "HeaderBlockItemsWithNoRating": "Klokér titler uden eller med ukendt bedømmelses information:", - "HeaderBooks": "Bøger", "HeaderCancelRecording": "Annuller Optagelse", "HeaderCancelSeries": "Annuller Serie", "HeaderCastAndCrew": "Medvirkende", - "HeaderCastCrew": "Medvirkende", "HeaderChannelAccess": "Adgang til kanaler", "HeaderChapterImages": "Kapitel Billeder", "HeaderCodecProfile": "Codec profil", @@ -218,14 +207,12 @@ "HeaderEditImages": "Rediger billeder", "HeaderEnabledFields": "Aktivér Felter", "HeaderEnabledFieldsHelp": "Fjern fluebenet fra et felt for at låse det og forhindre dets data fra at blive ændret.", - "HeaderEpisodes": "Episoder", "HeaderError": "Fejl", "HeaderExternalIds": "Eksterne ID'er:", "HeaderFeatureAccess": "Adgang til funktioner", "HeaderFetchImages": "Hent billeder:", "HeaderFetcherSettings": "Henter indstillinger", "HeaderForKids": "For Børn", - "HeaderForgotPassword": "Glemt adgangskode", "HeaderFrequentlyPlayed": "Ofte afspillet", "HeaderGuideProviders": "Guide Udbydere", "HeaderHttpHeaders": "HTTP Headers", @@ -253,7 +240,6 @@ "HeaderLoginFailure": "Login fejl", "HeaderMedia": "Medier", "HeaderMediaFolders": "Mediemapper", - "HeaderMediaInfo": "Medieinformation", "HeaderMetadataSettings": "Indstillinger for metadata", "HeaderMoreLikeThis": "Mere Som Denne", "HeaderMusicVideos": "Musikvideoer", @@ -388,7 +374,6 @@ "LabelCustomCertificatePathHelp": "Sti til PKCS #12 fil indeholdende et certifikat og privat nøgle for at aktivere TLS understøttelse på et brugerdefineret domæne.", "LabelCustomCss": "Brugerdefineret CSS:", "LabelCustomCssHelp": "Anvend din egen stil til webinterfacet.", - "LabelCustomDeviceDisplayName": "Visningsnavn:", "LabelCustomDeviceDisplayNameHelp": "Angiv en brugerdefineret navn. hvis der ikke angives et navn, bruges det navn enheden sender.", "LabelCustomRating": "Brugerdefineret bedømmelse:", "LabelDateAdded": "Dato for tilføjelse:", @@ -401,7 +386,6 @@ "LabelDeviceDescription": "Beskrivelse af enhed", "LabelDidlMode": "DIDL tilstand:", "LabelDiscNumber": "Disk-nummer:", - "LabelDisplayMissingEpisodesWithinSeasons": "Vis manglende episoder i sæsoner", "LabelDisplayName": "Visningsnavn:", "LabelDisplayOrder": "Visningsorden:", "LabelDisplaySpecialsWithinSeasons": "Vis specialepisoder sammen med den sæson de blev sent i", @@ -543,7 +527,6 @@ "LabelPostProcessorArguments": "Kommandolinjeargumenter til efterbehandler:", "LabelPostProcessorArgumentsHelp": "Benyt {path} som stien til optagelsesfilen.", "LabelPreferredDisplayLanguage": "Foretrukket sprog til visning:", - "LabelPreferredDisplayLanguageHelp": "Oversættelse af Jellyfin er et løbende projekt.", "LabelProfileAudioCodecs": "Lyd codecs:", "LabelProfileCodecsHelp": "Adskil med komma. Kan efterlades tom for at gælde for alle codecs.", "LabelProfileContainersHelp": "Adskil med komma. Kan efterlades tom for at gælde for alle containere.", @@ -595,7 +578,6 @@ "LabelTimeLimitHours": "Tidsgrænse (timer):", "LabelTitle": "Titel:", "LabelTrackNumber": "Spor nummer:", - "LabelTranscodingAudioCodec": "Lyd codec:", "LabelTranscodingTempPathHelp": "Definér en bugerdefineret sti til transkodede filer til klienter. Lad den stå tom for at bruge standardmappen i serverens datamappe.", "LabelTranscodingThreadCount": "Antal af omkodningstråde:", "LabelTranscodingThreadCountHelp": "Vælg det maksimale antal af tråde der bruges under transcoding. Reduktion af antallet af tråde sænker CPU-forbrug, men resulterer muligvis i at konverteringer ikke foregår hurtigt nok til en jævn afspilning.", @@ -684,7 +666,6 @@ "MessagePluginConfigurationRequiresLocalAccess": "For at konfigurerer dette plugin log da venligst direkte ind på din lokale server.", "MessagePluginInstallDisclaimer": "Plugins fremstillet af medlemmer fra Jellyfin-fællesskabet er en alle tiders måde at forbedre din oplevelse af Jellyfin med yderligere features og fordele. Før installation, bedes du venligst være opmærksom på de effekter de kan have på din Jellyfin Server; så som lange scantider på biblioteker, yderligere baggrundsbehandling og forringet systemstabilitet.", "MessageReenableUser": "Se nedenfor om genaktivering", - "MessageSettingsSaved": "Indstillinger er gemt.", "MessageTheFollowingLocationWillBeRemovedFromLibrary": "Følgende medieplaceringer fjernes fra dit bibliotek:", "MessageUnableToConnectToServer": "Vi kan ikke forbinde til den valgte server på nuværende tidspunkt. Sikrer dig venligst at serveren kører og prøv igen.", "MessageUnsetContentHelp": "Indhold vil blive vist som almindelige mapper. For det bedste resultat benyt metadata manageren til at vælge indholdstypen i undermapper.", @@ -931,15 +912,12 @@ "SystemDlnaProfilesHelp": "Systemprofiler kan ikke overskrives. Ændringer i en systemprofil vil blive gemt i en ny brugerdefineret profil.", "TabAccess": "Adgang", "TabAdvanced": "Avanceret", - "TabAlbumArtists": "Album-artister", "TabCatalog": "Katalog", "TabContainers": "Containere", "TabDashboard": "Betjeningspanel", "TabDirectPlay": "Direkte afspilning", - "TabEpisodes": "Episoder", "TabLatest": "Seneste", "TabMusic": "Musik", - "TabMusicVideos": "Musikvideoer", "TabMyPlugins": "Mine tilføjelser", "TabNetworks": "Netværk", "TabNfoSettings": "NFO Indstillinger", @@ -950,10 +928,8 @@ "TabProfile": "Profil", "TabProfiles": "Profiler", "TabResponses": "Svar", - "TabResumeSettings": "Genoptag", "TabScheduledTasks": "Planlagte opgaver", "TabSettings": "Indstillinger", - "TabTrailers": "Trailere", "TabUpcoming": "Kommende", "TellUsAboutYourself": "Fortæl os lidt om dig selv", "ThisWizardWillGuideYou": "Denne guide vil hjælpe dig igennem opsætningen. For at begynde, vælg venligst dit fortrukne sprog.", @@ -1027,7 +1003,6 @@ "Box": "Boks", "BoxRear": "Boks (bagside)", "BurnSubtitlesHelp": "Bestemmer om serveren skal brænde undertekster, når der afspilles transcoding videoer. Undgå dette vil forbedre ydelsen meget. Vælg Auto for at brænde billedbaserede formater (VOBSUB, PGS, SUB, IDX) og bestemte ASS- eller SSA-undertekster.", - "ButtonFilter": "Filter", "ButtonGuide": "Vejledning", "ButtonInfo": "Information", "ButtonOk": "Ok", @@ -1073,9 +1048,7 @@ "EnableExternalVideoPlayersHelp": "En ekstern afspiller menu vil blive vist når video afspilning starter.", "EnableNextVideoInfoOverlay": "Vis næste video information mens der afspilles", "EnableNextVideoInfoOverlayHelp": "I slutningen af en video, vis information om den næste video i nuværende afspilningsliste.", - "EnableThemeSongs": "Tema sange", "EnableThemeSongsHelp": "Afspil tema sange i baggrunden mens man gennemser biblioteket.", - "EnableThemeVideos": "Tema videoer", "EnableThemeVideosHelp": "Afspil tema videoer i baggrunden mens man gennemser biblioteket.", "Episodes": "Afsnit", "ErrorDeletingItem": "Der skete en fejl ved sletningen af mediet fra Jellyfin Server. Tjek venligst at Jellyfin Server har skrive adgang til mediemappen og prøv igen.", @@ -1118,7 +1091,6 @@ "Horizontal": "Horisontalt", "Label3DFormat": "3D format:", "LabelAlbum": "Album:", - "LabelAudio": "Lyd", "LabelBlockContentWithTags": "Blokér filer med etiketter:", "LabelBurnSubtitles": "Brænd undertekster:", "LabelCache": "Cache:", @@ -1155,15 +1127,12 @@ "LabelSortBy": "Sortér efter:", "LabelSortOrder": "Sorteringsorden:", "LabelStatus": "Status:", - "LabelSubtitles": "Undertekster", "LabelTVHomeScreen": "TV modus hjemmeskærm:", "LabelTag": "Mærke:", "LabelTagline": "Taglinje:", "LabelTextBackgroundColor": "Tekst baggrundsfarve:", "LabelTextColor": "Tekstfarve:", "LabelTextSize": "Tekststørrelse:", - "LabelTranscodingContainer": "Beholder:", - "LabelTranscodingVideoCodec": "Video codec:", "LabelType": "Type:", "LabelVersion": "Version:", "LabelVideo": "Video", @@ -1209,7 +1178,6 @@ "OptionAlbum": "Album", "OptionArtist": "Kunstner", "OptionAuto": "Automatisk", - "OptionAutomatic": "Automatisk", "OptionBanner": "Banner", "OptionBluray": "Blu-Ray", "OptionCaptionInfoExSamsung": "CaptionInfoEx (Samsung)", @@ -1260,7 +1228,6 @@ "Suggestions": "Forslag", "TV": "TV", "TabCodecs": "Codeks", - "TabInfo": "Information", "TabLogs": "Log", "TabServer": "Server", "TabStreaming": "Streamer", @@ -1294,7 +1261,6 @@ "HeaderFavoriteArtists": "Favoritkunstnere", "HeaderFavoriteSongs": "Favoritsange", "HeaderFavoriteVideos": "Favoritvideoer", - "HeaderHome": "Hjem", "LabelServerName": "Server navn:", "LabelUserLoginAttemptsBeforeLockout": "Fejlede loginforsøg før bruger lukkes ude:", "ButtonAddImage": "Tilføj billede", diff --git a/src/strings/de.json b/src/strings/de.json index 84a34bc9cf..896830849c 100644 --- a/src/strings/de.json +++ b/src/strings/de.json @@ -55,8 +55,6 @@ "ButtonBack": "Zurück", "ButtonCancel": "Abbrechen", "ButtonChangeServer": "Wechsel Server", - "ButtonEdit": "Bearbeiten", - "ButtonEditImages": "Bearbeite Bilder", "ButtonEditOtherUserPreferences": "Bearbeite dieses Benutzerprofil, das Benutzerbild und die persönlichen Einstellungen.", "ButtonForgotPassword": "Passwort vergessen", "ButtonFullscreen": "Vollbild", @@ -67,14 +65,11 @@ "ButtonMore": "Mehr", "ButtonNetwork": "Netzwerk", "ButtonNextTrack": "Nächstes Stück", - "ButtonOff": "Ausschalten", "ButtonOpen": "Öffnen", "ButtonParentalControl": "Kindersicherung", - "ButtonPlay": "Abspielen", "ButtonPreviousTrack": "Vorheriges Stück", "ButtonProfile": "Profil", "ButtonQuickStartGuide": "Schnellstart Anleitung", - "ButtonRefresh": "Aktualisieren", "ButtonRefreshGuideData": "Aktualisiere TV-Programmdaten", "ButtonRemove": "Entfernen", "ButtonRename": "Umbenennen", @@ -94,7 +89,6 @@ "ButtonSignOut": "Abmelden", "ButtonStop": "Stopp", "ButtonSubmit": "Bestätigen", - "ButtonSubtitles": "Untertitel", "ButtonUninstall": "Deinstallieren", "CancelRecording": "Aufnahme abbrechen", "CancelSeries": "Serien abbrechen", @@ -176,9 +170,7 @@ "EnablePhotosHelp": "Bilder werden erkannt und neben anderen Mediendateien angezeigt.", "EnableStreamLooping": "Auto-Schleife Live Streams", "EnableStreamLoopingHelp": "Aktivieren, wenn Live Streams nur ein paar Sekunden Daten enthalten und ständig angefragt werden müssen. Kann zu Problemen führen wenn aktiviert, obwohl nicht nötig.", - "EnableThemeSongs": "Titelmelodien", "EnableThemeSongsHelp": "Titelmusik wird während des Blätterns durch die Bibliothek im Hintergrund abgespielt.", - "EnableThemeVideos": "Titelvideos", "EnableThemeVideosHelp": "Titelvideos werden während des Blätterns durch die Bibliothek im Hintergrund abgespielt.", "Ended": "Beendent", "EndsAtValue": "Endet um {0}", @@ -230,11 +222,9 @@ "HeaderActiveDevices": "Aktive Geräte", "HeaderActiveRecordings": "Aktive Aufnahmen", "HeaderActivity": "Aktivitäten", - "HeaderAddScheduledTaskTrigger": "Auslöser hinzufügen", "HeaderAddToCollection": "Zu Sammlung hinzufügen", "HeaderAddToPlaylist": "Zur Wiedergabeliste hinzufügen", "HeaderAddUpdateImage": "Bild hinzufügen/aktualisieren", - "HeaderAddUser": "Benutzer anlegen", "HeaderAdditionalParts": "Zusätzliche Teile", "HeaderAlbumArtists": "Album-Interpreten", "HeaderAlert": "Alarm", @@ -246,12 +236,10 @@ "HeaderAudioBooks": "Hörbücher", "HeaderAudioSettings": "Audioeinstellungen", "HeaderBlockItemsWithNoRating": "Blockiere Inhalte mit keiner oder nicht erkannter Altersfreigabe:", - "HeaderBooks": "Bücher", "HeaderBranding": "Branding / CSS", "HeaderCancelRecording": "Aufnahme abbrechen", "HeaderCancelSeries": "Serie abbrechen", "HeaderCastAndCrew": "Besetzung & Mitwirkende", - "HeaderCastCrew": "Besetzung & Crew", "HeaderChannelAccess": "Channelzugriff", "HeaderChapterImages": "Kapitel Bilder", "HeaderCodecProfile": "Codec Profil", @@ -285,14 +273,12 @@ "HeaderEditImages": "Bilder bearbeiten", "HeaderEnabledFields": "Aktiviere Felder", "HeaderEnabledFieldsHelp": "Wähle Felder ab um das Ändern von Daten zu verhindern.", - "HeaderEpisodes": "Episoden", "HeaderError": "Fehler", "HeaderExternalIds": "Externe IDs:", "HeaderFeatureAccess": "Funktionszugriff", "HeaderFetchImages": "Bilder abrufen:", "HeaderFetcherSettings": "Fetcher Einstellungen", "HeaderForKids": "Für Kinder", - "HeaderForgotPassword": "Passwort vergessen", "HeaderFrequentlyPlayed": "Oft gesehen", "HeaderGuideProviders": "Fernsehprogramm Quellen", "HeaderIdentification": "Identifizierung", @@ -320,7 +306,6 @@ "HeaderLoginFailure": "Login Fehler", "HeaderMedia": "Medien", "HeaderMediaFolders": "Medienverzeichnisse", - "HeaderMediaInfo": "Medieninformation", "HeaderMetadataSettings": "Metadaten Einstellungen", "HeaderMoreLikeThis": "Mehr wie dieses", "HeaderMusicQuality": "Musikqualität", @@ -472,7 +457,6 @@ "LabelCustomCertificatePathHelp": "Pfad zu einer PKCS #12 Datei die ein Zertifikat und einen privaten Schlüssel enthält, um TLS Unterstützung für eine eigene Domain zu aktivieren.", "LabelCustomCss": "Benutzerdefiniertes CSS:", "LabelCustomCssHelp": "Wende deine eigenen benutzerdefinierte Styles auf die Weboberfläche an.", - "LabelCustomDeviceDisplayName": "Angezeigter Name:", "LabelCustomDeviceDisplayNameHelp": "Lege einen individuellen Anzeigenamen fest oder lasse das Feld leer, um den vom gerät übermittelten Namen zu nutzen.", "LabelCustomRating": "Eigene Bewertung:", "LabelDateAdded": "Hinzugefügt am:", @@ -489,7 +473,6 @@ "LabelDiscNumber": "Discnummer:", "LabelDisplayLanguage": "Anzeigesprache:", "LabelDisplayLanguageHelp": "Die Übersetzung von Jellyfin ist ein laufendes Projekt.", - "LabelDisplayMissingEpisodesWithinSeasons": "Zeige fehlende Episoden innerhalb von Staffeln", "LabelDisplayMode": "Bildschirmmodus:", "LabelDisplayName": "Anzeige Name:", "LabelDisplayOrder": "Anzeigereihenfolge:", @@ -640,7 +623,6 @@ "LabelPostProcessorArguments": "Nachbearbeitung Kommandozeilen-Argumente:", "LabelPostProcessorArgumentsHelp": "Verwende {path} als das Verzeichnis für Aufnahmen.", "LabelPreferredDisplayLanguage": "Bevorzugte Anzeigesprache:", - "LabelPreferredDisplayLanguageHelp": "Die Übersetzung von Jellyfin ist ein laufendes Projekt.", "LabelPreferredSubtitleLanguage": "Bevorzugte Untertitelsprache:", "LabelProfileAudioCodecs": "Audio Codecs:", "LabelProfileCodecsHelp": "Getrennt durch Komma. Leerlassen, um auf alle Codecs anzuwenden.", @@ -697,7 +679,6 @@ "LabelSubtitleDownloaders": "Untertitel Downloader:", "LabelSubtitleFormatHelp": "Beispiel: srt", "LabelSubtitlePlaybackMode": "Untertitelmodus:", - "LabelSubtitles": "Untertitel", "LabelSupportedMediaTypes": "Unterstüzte Medientypen:", "LabelTVHomeScreen": "TV-Mode Startseite:", "LabelTextBackgroundColor": "Hintergrundfarbe des Textes:", @@ -708,11 +689,9 @@ "LabelTimeLimitHours": "Zeitlimit (Stunden):", "LabelTitle": "Titel:", "LabelTrackNumber": "Stück Nummer:", - "LabelTranscodingAudioCodec": "Audio Codec:", "LabelTranscodingTempPathHelp": "Wähle einen eigenen Pfad für transkodierte Dateien. Lasse das Feld frei, um den Standardspeicherort zu nutzen.", "LabelTranscodingThreadCount": "Anzahl Transkodierungs-Threads:", "LabelTranscodingThreadCountHelp": "Legen Sie die maximale Anzahl von Transkodierungs-Threads fest. Das Reduzieren der Thread-Anzahl verringert die CPU Auslastung, wird aber möglicherweise die Transkodierung nicht schnell genug für eine störungsfrei Wiedergabe ermöglichen.", - "LabelTranscodingVideoCodec": "Video Codec:", "LabelTriggerType": "Auslöser Typ:", "LabelTunerIpAddress": "Tuner IP Adresse:", "LabelTunerType": "Tuner Typ:", @@ -810,7 +789,6 @@ "MessagePluginConfigurationRequiresLocalAccess": "Melde dich bitte direkt an deinem lokalen Server an, um dieses Plugin konfigurieren zu können.", "MessagePluginInstallDisclaimer": "Plugins aus der Community sind eine gute Möglichkeit um dein Erlebnis mit weiteren Funktionen und Vorteilen aufzuwerten. Bevor du diese installierst, sei dir den daraus resultierenden möglichen Umständen für deinen Server bewusst. Dies können z.B. längere Bibliotheken Scans, weiterführende Verarbeitung von Daten im Hintergrund sowie Systeminstabilität sein.", "MessageReenableUser": "Für Reaktivierung schauen Sie unten", - "MessageSettingsSaved": "Einstellungen gespeichert.", "MessageTheFollowingLocationWillBeRemovedFromLibrary": "Die folgenden Medienverzeichnisse werden aus der Bibliothek entfernt:", "MessageUnableToConnectToServer": "Wir können gerade keine Verbindung zum gewählten Server herstellen. Bitte stellen Sie sicher das dieser läuft und versuchen Sie es erneut.", "MessageUnsetContentHelp": "Inhalte werden als Verzeichnisse dargestellt. Für eine besser Anzeige nutzen Sie nach Möglichkeit den Meta-Data Manager und wählen Sie einen Medien-Typen für Unterverzeichnisse.", @@ -1092,15 +1070,12 @@ "SystemDlnaProfilesHelp": "Systemprofile sind schreibgeschützt. Änderungen an einem Systemprofil werden als neues benutzerdefiniertes Profil gespeichert.", "TabAccess": "Zugang", "TabAdvanced": "Erweitert", - "TabAlbumArtists": "Album-Interpreten", "TabCatalog": "Katalog", "TabContainers": "Container", "TabDashboard": "Übersicht", "TabDirectPlay": "Direktwiedergabe", - "TabEpisodes": "Episoden", "TabLatest": "Neueste", "TabMusic": "Musik", - "TabMusicVideos": "Musikvideos", "TabMyPlugins": "Meine Plugins", "TabNetworks": "Sendergruppen", "TabNfoSettings": "NFO Einstellungen", @@ -1110,10 +1085,8 @@ "TabProfile": "Profil", "TabProfiles": "Profile", "TabResponses": "Antworten", - "TabResumeSettings": "Fortsetzen", "TabScheduledTasks": "Geplante Aufgaben", "TabSettings": "Einstellungen", - "TabTrailers": "Trailer", "TabUpcoming": "Bevorstehend", "TellUsAboutYourself": "Sagen Sie uns etwas über sich selbst", "ThemeSongs": "Titelsongs", @@ -1176,8 +1149,6 @@ "Auto": "Auto", "Banner": "Banner", "Blacklist": "Sperrliste", - "ButtonFilter": "Filter", - "ButtonHome": "Startseite", "ButtonOk": "Ok", "ButtonPause": "Pause", "ButtonStart": "Start", @@ -1202,7 +1173,6 @@ "Home": "Startseite", "Horizontal": "Horizontal", "LabelAlbum": "Album:", - "LabelAudio": "Audio", "LabelCache": "Cache:", "LabelFormat": "Format:", "LabelH264Crf": "H264 Encodierungs-CRF:", @@ -1226,7 +1196,6 @@ "Normal": "Normal", "LabelDynamicExternalId": "{0} Id:", "LabelStatus": "Status:", - "LabelTranscodingContainer": "Container:", "Live": "Live", "LiveTV": "Live-TV", "Logo": "Logo", @@ -1238,7 +1207,6 @@ "Option3D": "3D", "OptionAlbum": "Album", "OptionAuto": "Auto", - "OptionAutomatic": "Auto", "OptionBluray": "Blu-ray", "OptionCaptionInfoExSamsung": "CaptionInfoEx (Samsung)", "OptionDownloadBannerImage": "Banner", @@ -1259,7 +1227,6 @@ "Studios": "Studios", "TV": "TV", "TabCodecs": "Codecs", - "TabInfo": "Info", "TabLogs": "Protokoll", "TabPlugins": "Plugins", "TabServer": "Server", @@ -1311,7 +1278,6 @@ "OptionLoginAttemptsBeforeLockoutHelp": "Null (0) bedeutet den Standardwert von drei Versuchen für normale, sowie fünf für Administrator-Benutzer zu übernehmen. Ein Wert von -1 deaktiviert die Funktion.", "PasswordResetProviderHelp": "Wählen Sie einen Password Reset Provider, der verwendet werden soll, wenn dieser Benutzer ein Passwort zurücksetzen möchte.", "Box": "Box", - "HeaderHome": "Startseite", "LabelAudioCodec": "Audiocodec:", "LabelAudioChannels": "Audiokanäle:", "HeaderTypeImageFetchers": "{0} Bildquellen", diff --git a/src/strings/el.json b/src/strings/el.json index 56d19b0c4a..7ee61d2b62 100644 --- a/src/strings/el.json +++ b/src/strings/el.json @@ -53,15 +53,11 @@ "ButtonBack": "Πίσω", "ButtonCancel": "Ακύρωση", "ButtonChangeServer": "Αλλαγή Διακομιστή", - "ButtonEdit": "Επεξεργασία", - "ButtonEditImages": "Επεξεργασία εικόνων", "ButtonEditOtherUserPreferences": "Επεξεργαστείτε το προφίλ, την εικόνα και τις προσωπικές προτιμήσεις αυτού του χρήστη.", - "ButtonFilter": "Φίλτρο", "ButtonForgotPassword": "Ξέχασα τον κωδικό", "ButtonFullscreen": "Πλήρης οθόνη", "ButtonGotIt": "Το κατάλαβα", "ButtonGuide": "Οδηγός", - "ButtonHome": "Αρχική", "ButtonInfo": "Πληροφορία", "ButtonLibraryAccess": "Πρόσβαση στη βιβλιοθήκη", "ButtonManualLogin": "Χειροκίνητη Είσοδος", @@ -70,11 +66,9 @@ "ButtonOpen": "Άνοιγμα", "ButtonParentalControl": "Γονικός έλεγχος", "ButtonPause": "Παύση", - "ButtonPlay": "Αναπαραγωγή", "ButtonPreviousTrack": "Προηγουμενο", "ButtonProfile": "Προφίλ", "ButtonQuickStartGuide": "Οδηγός Γρήγορης Εκκίνησης", - "ButtonRefresh": "Ανανέωση", "ButtonRefreshGuideData": "Ανανέωση Δεδομένων Οδηγού", "ButtonRemove": "Κατάργηση", "ButtonRename": "Μετονομασία", @@ -95,7 +89,6 @@ "ButtonStart": "Έναρξη", "ButtonStop": "Διακοπή", "ButtonSubmit": "υποβολή", - "ButtonSubtitles": "Υπότιτλοι", "ButtonTrailer": "Τρέϊλερ", "ButtonUninstall": "Απεγκατάσταση", "ButtonWebsite": "Ιστοσελίδα", @@ -177,9 +170,7 @@ "EnableHardwareEncoding": "Ενεργοποίηση αποκωδικοποίησης υλικού", "EnableNextVideoInfoOverlay": "Ενεργοποιήστε τις επόμενες πληροφορίες βίντεο κατά την αναπαραγωγή", "EnableNextVideoInfoOverlayHelp": "Στο τέλος ενός βίντεο, εμφανίστε πληροφορίες σχετικά με το επόμενο βίντεο που εμφανίζεται στην τρέχουσα λίστα αναπαραγωγής.", - "EnableThemeSongs": "Ενεργοποίηση Θεματικών Τραγουδιών", "EnableThemeSongsHelp": "Αν είναι ενεργοποιημένη, τα τραγούδια θεμάτων θα αναπαραχθούν στο παρασκήνιο κατά την περιήγηση στη βιβλιοθήκη.", - "EnableThemeVideos": "Ενεργοποίηση βίντεο θέματος", "EnableThemeVideosHelp": "Αν είναι ενεργοποιημένη, τα βίντεο θεμάτων θα αναπαραχθούν στο παρασκήνιο κατά την περιήγηση στη βιβλιοθήκη.", "Ended": "Τέλος", "EndsAtValue": "Τελειώνει σε {0}", @@ -224,11 +215,9 @@ "HeaderActiveDevices": "Ενεργές Συσκευές", "HeaderActiveRecordings": "Ενεργές εγγραφές", "HeaderActivity": "Δραστηριότητα", - "HeaderAddScheduledTaskTrigger": "Προσθήκη διακόπτη", "HeaderAddToCollection": "Πρόσθεσε στη Συλλογή", "HeaderAddToPlaylist": "Πρόσθεσε σε Λίστα", "HeaderAddUpdateImage": "Προσθήκη / Ενημέρωση εικόνας", - "HeaderAddUser": "Προσθήκη Χρήστη", "HeaderAdditionalParts": "Πρόσθετα Μέρη", "HeaderAdmin": "Διαχειριστής", "HeaderAlbumArtists": "Καλλιτέχνες του Άλμπουμ", @@ -241,11 +230,9 @@ "HeaderAudioBooks": "Μουσικά Βιβλία", "HeaderAudioSettings": "Ρυθμίσεις Ήχου", "HeaderBlockItemsWithNoRating": "Αποκλεισμός στοιχείων χωρίς ή μη αναγνωρισμένων πληροφοριών αξιολόγησης:", - "HeaderBooks": "Βιβλία", "HeaderCancelRecording": "Ακύρωση Εγγραφής", "HeaderCancelSeries": "Ακύρωση Σειράς", "HeaderCastAndCrew": "Ηθοποιοί και Συνεργείο", - "HeaderCastCrew": "Ηθοποιοί και συνεργείο", "HeaderCodecProfileHelp": "Τα προφίλ κωδικοποιητή υποδεικνύουν τους περιορισμούς μιας συσκευής κατά την αναπαραγωγή συγκεκριμένων κωδικοποιητών. Εάν ισχύει περιορισμός, τότε τα μέσα θα κωδικοποιηθούν, ακόμα και αν ο κωδικοποιητής έχει ρυθμιστεί για άμεση αναπαραγωγή.", "HeaderConfigureRemoteAccess": "Ρύθμιση απομακρυσμένης πρόσβασης", "HeaderConfirmPluginInstallation": "Επιβεβαιώστε την εγκατάσταση της προσθήκης", @@ -271,13 +258,11 @@ "HeaderEditImages": "Επεξεργασία εικόνων", "HeaderEnabledFields": "Ενεργά Πεδία", "HeaderEnabledFieldsHelp": "Καταργήστε την επιλογή ενός πεδίου για να το κλειδώσετε και να αποτρέψετε την αλλαγή των δεδομένων του.", - "HeaderEpisodes": "Επεισόδια", "HeaderError": "Σφάλμα", "HeaderExternalIds": "Εξωτερικά ID:", "HeaderFeatureAccess": "Πρόσβαση χαρακτηριστικών", "HeaderFetchImages": "Λήψη εικόνων:", "HeaderForKids": "Για τα Παιδιά", - "HeaderForgotPassword": "Ξέχασα τον κωδικό", "HeaderFrequentlyPlayed": "Συχνά έπαιξε", "HeaderIdentificationCriteriaHelp": "Καταχωρήστε τουλάχιστον ένα κριτήριο αναγνώρισης.", "HeaderIdentificationHeader": "Αναγνωριστικό Header", @@ -301,7 +286,6 @@ "HeaderLoginFailure": "Αποτυχία εισόδου", "HeaderMedia": "Πολυμέσα", "HeaderMediaFolders": "Φάκελοι Πολυμέσων", - "HeaderMediaInfo": "Πληροφορίες πολυμέσων", "HeaderMetadataSettings": "Ρυθμίσεις μεταδεδομένων", "HeaderMoreLikeThis": "Περισσότερα Σαν Αυτό", "HeaderMusicQuality": "Ποιότητα Μουσικής", @@ -410,7 +394,6 @@ "LabelAppNameExample": "Παράδειγμα: Sickbeard, NzbDrone", "LabelArtists": "Καλλιτέχνες:", "LabelArtistsHelp": "Ξεχωρίστε πολλαπλά χρησιμοποιώντας;", - "LabelAudio": "Ήχος", "LabelAudioLanguagePreference": "Προτιμώμενη γλώσσα ήχου:", "LabelAutomaticallyRefreshInternetMetadataEvery": "Αυτόματη ανανέωση μεταδεδομένων από το internet:", "LabelBirthDate": "Ημερομηνία Γενεθλίων:", @@ -433,7 +416,6 @@ "LabelCustomCertificatePathHelp": "Προσθέστε το δικό σας αρχείο .pfx πιστοποιητικού ssl.", "LabelCustomCss": "Προσαρμοσμένο css:", "LabelCustomCssHelp": "Εφαρμόστε το δικό σας προσαρμοσμένο css στην διεπαφή ιστού.", - "LabelCustomDeviceDisplayName": "Εμφάνιση ονόματος:", "LabelCustomRating": "Προσαρμοσμένη αξιολόγηση:", "LabelDateAdded": "Ημερνία προσθήκης:", "LabelDateTimeLocale": "Ημερομηνία τοπική ώρα:", @@ -446,7 +428,6 @@ "LabelDiscNumber": "Αριθμός Δίσκου:", "LabelDisplayLanguage": "Γλώσσα Εμφάνισης:", "LabelDisplayLanguageHelp": "Η μετάφραση του Jellyfin είναι ένα συνεχιζόμενο έργο.", - "LabelDisplayMissingEpisodesWithinSeasons": "Εμφάνιση επεισοδίων που λείπουν από την σαιζόν", "LabelDisplayMode": "Λειτουργία προβολής:", "LabelDisplayName": "Εμφάνιση ονόματος:", "LabelDisplayOrder": "Σειρά εμφάνισης:", @@ -573,7 +554,6 @@ "LabelPlayDefaultAudioTrack": "Αναπαραγωγή προεπιλεγμένου κομματιού ήχου ανεξάρτητα από τη γλώσσα", "LabelPlaylist": "Λίστα:", "LabelPreferredDisplayLanguage": "Προτιμώμενη γλώσσα εμφάνισης:", - "LabelPreferredDisplayLanguageHelp": "Η μετάφραση του Jellyfin είναι ένα συνεχιζόμενο έργο.", "LabelPreferredSubtitleLanguage": "Προτεινόμενη Γλώσσα υποτίτλων:", "LabelProfileCodecsHelp": "Διαχωρίζονται με κόμμα. Αυτό μπορεί να μείνει κενό για να εφαρμοστεί σε όλα τα codecs.", "LabelProfileContainersHelp": "Διαχωρίζονται με κόμμα. Αυτό μπορεί να μείνει κενό για να εφαρμοστεί σε όλα τα containers.", @@ -619,7 +599,6 @@ "LabelStopWhenPossible": "Διακοπή όταν είναι δυνατόν:", "LabelSubtitleFormatHelp": "Παράδειγμα: srt", "LabelSubtitlePlaybackMode": "Λειτουργία υποτίτλων:", - "LabelSubtitles": "Υπότιτλοι", "LabelSupportedMediaTypes": "Υποστηριζόμενοι τύποι μέσων:", "LabelTVHomeScreen": "Αρχική οθόνη λειτουργίας τηλεόρασης:", "LabelTag": "Ετικέτα:", @@ -719,7 +698,6 @@ "MessagePleaseWait": "Παρακαλώ περιμένετε. Αυτό μπορεί να πάρει ένα λεπτό.", "MessagePluginConfigurationRequiresLocalAccess": "Για να ρυθμίσετε αυτό το πρόσθετο παρακαλώ συνδεθείτε στον τοπικό διακομιστή σας άμεσα.", "MessageReenableUser": "Δες παρακάτω για ενεργοποιήση", - "MessageSettingsSaved": "Οι ρυθμίσεις αποθηκεύτηκαν.", "MessageUnableToConnectToServer": "Δεν είναι δυνατή η σύνδεση με τον επιλεγμένο διακομιστή αυτή τη στιγμή. Βεβαιωθείτε ότι εκτελείται και προσπαθήστε ξανά.", "MessageYouHaveVersionInstalled": "Αυτήν τη στιγμή έχετε εγκατεστημένη την έκδοση {0}.", "Metadata": "Μεταδεδομένα", @@ -781,7 +759,6 @@ "OptionArtist": "Καλλιτέχνες", "OptionAscending": "Αύξουσα", "OptionAuto": "Αυτόματο", - "OptionAutomatic": "Αυτόματο", "OptionBlockBooks": "Βιβλία", "OptionBlockChannelContent": "Περιεχόμενο Διαδικτυακών Καναλιών", "OptionBlockLiveTvChannels": "ΚΑΝΑΛΙΑ ΖΩΝΤΑΝΗΣ ΤΗΛΕΟΡΑΣΗΣ", @@ -982,15 +959,11 @@ "TV": "Τηλεόραση", "TabAccess": "Πρόσβαση", "TabAdvanced": "Για προχωρημένους", - "TabAlbumArtists": "Άλμπουμ Καλλιτέχνες", "TabCatalog": "Κατάλογος", "TabDashboard": "Πίνακας Ελέγχου", "TabDirectPlay": "Άμεση Αναπαραγωγή", - "TabEpisodes": "Επεισόδια", - "TabInfo": "Πληροφορία", "TabLatest": "Τελευταία", "TabMusic": "Μουσική", - "TabMusicVideos": "Μουσικά βίντεο", "TabMyPlugins": "Τα πρόσθετα μου", "TabNetworks": "Δίκτυα", "TabNfoSettings": "Ρυθμίσεις NFO", @@ -1005,7 +978,6 @@ "TabServer": "Διακομιστής", "TabSettings": "Ρυθμισεις", "TabStreaming": "Ροή", - "TabTrailers": "Τρέιλερς", "TabUpcoming": "Επερχόμενα", "Tags": "Ετικέτες", "TagsValue": "Ετικέτες: {0}", @@ -1081,7 +1053,6 @@ "HeaderSelectCertificatePath": "Επιλέξτε Διαδρομή Πιστοποιητικού", "HeaderRemoveMediaFolder": "Αφαίρεση Φακέλου Μέσων", "HeaderIdentification": "Ταυτοποίηση", - "HeaderHome": "Αρχική", "HeaderGuideProviders": "Πάροχοι Δεδομένων Προγράμματος Τηλεόρασης", "HeaderFavoriteVideos": "Αγαπημένα Βίντεο", "HeaderFavoriteMovies": "Αγαπημένες Ταινίες", @@ -1111,7 +1082,6 @@ "EnablePhotos": "Εμφάνιση φωτογραφιών", "DrmChannelsNotImported": "Κανάλια με DRM δεν θα εισαχθούν.", "ButtonOk": "Οκ", - "ButtonOff": "Απενεργοποίηση", "ButtonNetwork": "Δίκτυο", "AllowOnTheFlySubtitleExtractionHelp": "Οι ενσωματωμένοι υπότιτλοι μπορούν να εξαχθούν από βίντεο και να σταλούν στις συσκευές σε απλό κείμενο για να αποφευχθούν μετατροπές βίντεο. Σε μερικά συστήματα αυτό μπορεί να πάρει πολύ ώρα και να κάνει το βίντεο να κολλάει κατά την διάρκεια της εξαγωγής. Απενεργοποιήστε το για να έχετε ενσωματωμένους υπότιτλους πάνω στο βίντεο όταν αυτοί δεν υποστηρίζονται από την συσκευή.", "AllowOnTheFlySubtitleExtraction": "Επίτρεψε την εξαγωγή υποτίτλων σε πραγματικό χρόνο", diff --git a/src/strings/en-gb.json b/src/strings/en-gb.json index 023475923e..d44183a4a8 100644 --- a/src/strings/en-gb.json +++ b/src/strings/en-gb.json @@ -105,31 +105,24 @@ "ButtonBack": "Back", "ButtonCancel": "Cancel", "ButtonChangeServer": "Change Server", - "ButtonEdit": "Edit", - "ButtonEditImages": "Edit images", "ButtonEditOtherUserPreferences": "Edit this user's profile, image and personal preferences.", - "ButtonFilter": "Filter", "ButtonForgotPassword": "Forgot Password", "ButtonFullscreen": "Fullscreen", "ButtonGotIt": "Got It", "ButtonGuide": "Guide", - "ButtonHome": "Home", "ButtonInfo": "Info", "ButtonLibraryAccess": "Library access", "ButtonManualLogin": "Manual Login", "ButtonMore": "More", "ButtonNetwork": "Network", "ButtonNextTrack": "Next track", - "ButtonOff": "Off", "ButtonOk": "OK", "ButtonOpen": "Open", "ButtonParentalControl": "Parental control", "ButtonPause": "Pause", - "ButtonPlay": "Play", "ButtonPreviousTrack": "Previous track", "ButtonProfile": "Profile", "ButtonQuickStartGuide": "Quick Start Guide", - "ButtonRefresh": "Refresh", "ButtonRefreshGuideData": "Refresh Guide Data", "ButtonRemove": "Remove", "ButtonRename": "Rename", @@ -150,7 +143,6 @@ "ButtonStart": "Start", "ButtonStop": "Stop", "ButtonSubmit": "Submit", - "ButtonSubtitles": "Subtitles", "ButtonTrailer": "Trailer", "ButtonUninstall": "Uninstall", "ButtonWebsite": "Website", @@ -231,9 +223,7 @@ "EnablePhotosHelp": "Images will be detected and displayed alongside other media files.", "EnableStreamLooping": "Auto-loop live streams", "EnableStreamLoopingHelp": "Enable this if live streams only contain a few seconds of data and need to be continuously requested. Enabling this when not needed may cause problems.", - "EnableThemeSongs": "Theme songs", "EnableThemeSongsHelp": "Play theme songs in the background while browsing the library.", - "EnableThemeVideos": "Theme videos", "EnableThemeVideosHelp": "Play theme videos in the background while browsing the library.", "Ended": "Ended", "EndsAtValue": "Ends at {0}", @@ -285,11 +275,9 @@ "HeaderActiveDevices": "Active Devices", "HeaderActiveRecordings": "Active Recordings", "HeaderActivity": "Activity", - "HeaderAddScheduledTaskTrigger": "Add Trigger", "HeaderAddToCollection": "Add to Collection", "HeaderAddToPlaylist": "Add to Playlist", "HeaderAddUpdateImage": "Add/Update Image", - "HeaderAddUser": "Add User", "HeaderAdditionalParts": "Additional Parts", "HeaderAdmin": "Admin", "HeaderAlert": "Alert", @@ -301,12 +289,10 @@ "HeaderAppearsOn": "Appears On", "HeaderAudioBooks": "Audio Books", "HeaderAudioSettings": "Audio Settings", - "HeaderBooks": "Books", "HeaderBranding": "Branding", "HeaderCancelRecording": "Cancel Recording", "HeaderCancelSeries": "Cancel Series", "HeaderCastAndCrew": "Cast & Crew", - "HeaderCastCrew": "Cast & Crew", "HeaderChannelAccess": "Channel Access", "HeaderChapterImages": "Chapter Images", "HeaderCodecProfile": "Codec Profile", @@ -339,7 +325,6 @@ "HeaderEditImages": "Edit Images", "HeaderEnabledFields": "Enabled Fields", "HeaderEnabledFieldsHelp": "Uncheck a field to lock it and prevent its data from being changed.", - "HeaderEpisodes": "Episodes", "HeaderError": "Error", "HeaderExternalIds": "External IDs:", "HeaderFavoriteBooks": "Favourite Books", @@ -355,7 +340,6 @@ "HeaderFetchImages": "Fetch Images:", "HeaderFetcherSettings": "Fetcher Settings", "HeaderForKids": "For Kids", - "HeaderForgotPassword": "Forgot Password", "HeaderFrequentlyPlayed": "Frequently Played", "HeaderGuideProviders": "TV Guide Data Providers", "HeaderHttpHeaders": "HTTP Headers", @@ -384,7 +368,6 @@ "HeaderLoginFailure": "Login Failure", "HeaderMedia": "Media", "HeaderMediaFolders": "Media Folders", - "HeaderMediaInfo": "Media Info", "HeaderMetadataSettings": "Metadata Settings", "HeaderMoreLikeThis": "More Like This", "HeaderMusicQuality": "Music Quality", @@ -443,17 +426,14 @@ "TabSettings": "Settings", "TabServer": "Server", "TabScheduledTasks": "Scheduled Tasks", - "TabResumeSettings": "Resume", "TabResponses": "Responses", "TabOther": "Other", "TabNotifications": "Notifications", "TabNetworks": "Networks", "TabMyPlugins": "My Plugins", - "TabMusicVideos": "Music Videos", "TabMusic": "Music", "TabLogs": "Logs", "TabDirectPlay": "Direct Play", - "TabAlbumArtists": "Album Artists", "TabAdvanced": "Advanced", "TabAccess": "Access", "TV": "TV", @@ -723,22 +703,18 @@ "LabelTypeText": "Text", "LabelTunerIpAddress": "Tuner IP Address:", "LabelTriggerType": "Trigger Type:", - "LabelTranscodingVideoCodec": "Video codec:", "LabelTranscodingThreadCountHelp": "Select the maximum number of threads to use when transcoding. Reducing the thread count will lower CPU usage but may not convert fast enough for a smooth playback experience.", "LabelTranscodingThreadCount": "Transcoding thread count:", "LabelTranscodingFramerate": "Transcoding framerate:", "LabelTranscodes": "Transcodes:", "LabelTranscodingTempPathHelp": "Specify a custom path for the transcode files served to clients. Leave blank to use the server default.", "LabelTranscodePath": "Transcode path:", - "LabelTranscodingContainer": "Container:", - "LabelTranscodingAudioCodec": "Audio codec:", "LabelTrackNumber": "Track number:", "LabelTitle": "Title:", "LabelTagline": "Tagline:", "LabelTag": "Tag:", "LabelTVHomeScreen": "TV mode home screen:", "LabelSupportedMediaTypes": "Supported Media Types:", - "LabelSubtitles": "Subtitles", "LabelSubtitlePlaybackMode": "Subtitle mode:", "LabelSubtitleFormatHelp": "Example: srt", "LabelSubtitleDownloaders": "Subtitle downloaders:", @@ -778,7 +754,6 @@ "LabelPublicHttpPortHelp": "The public port number that should be mapped to the local HTTP port.", "LabelPublicHttpPort": "Public HTTP port number:", "LabelMetadataDownloadersHelp": "Enable and rank your preferred metadata downloaders in order of priority. Lower priority downloaders will only be used to fill in missing information.", - "LabelDisplayMissingEpisodesWithinSeasons": "Display missing episodes within seasons", "LabelDidlMode": "DIDL mode:", "LabelDefaultUser": "Default user:", "LabelDefaultScreen": "Default screen:", @@ -876,7 +851,6 @@ "TagsValue": "Tags: {0}", "Tags": "Tags", "TabUpcoming": "Upcoming", - "TabTrailers": "Trailers", "LabelDisplayMode": "Display mode:", "LabelDisplayLanguageHelp": "Translating Jellyfin is an ongoing project.", "LabelDisplayLanguage": "Display language:", @@ -890,8 +864,6 @@ "TabNfoSettings": "NFO Settings", "TabNetworking": "Networking", "TabLatest": "Latest", - "TabInfo": "Info", - "TabEpisodes": "Episodes", "TabDashboard": "Dashboard", "TabContainers": "Containers", "TabCodecs": "Codecs", @@ -956,7 +928,6 @@ "LabelProfileCodecsHelp": "Separated by comma. This can be left empty to apply to all codecs.", "LabelProfileAudioCodecs": "Audio codecs:", "LabelPreferredSubtitleLanguage": "Preferred subtitle language:", - "LabelPreferredDisplayLanguageHelp": "Translating Jellyfin is an ongoing project.", "LabelPreferredDisplayLanguage": "Preferred display language:", "LabelPostProcessor": "Post-processing application:", "LabelPlayer": "Player:", @@ -1058,7 +1029,6 @@ "LabelDisplayOrder": "Display order:", "LabelDisplayName": "Display name:", "LabelDateAddedBehaviorHelp": "If a metadata value is present it will always be used before either of these options.", - "LabelCustomDeviceDisplayName": "Display name:", "LabelCustomCss": "Custom CSS:", "LabelCustomCertificatePathHelp": "Path to a PKCS #12 file containing a certificate and private key to enable TLS support on a custom domain.", "LabelCurrentPassword": "Current password:", @@ -1083,7 +1053,6 @@ "LabelAudioChannels": "Audio channels:", "LabelAudioBitrate": "Audio bitrate:", "LabelAudioBitDepth": "Audio bit depth:", - "LabelAudio": "Audio", "LabelArtistsHelp": "Separate multiple using ;", "LabelArtists": "Artists:", "LabelAppName": "App name", @@ -1274,7 +1243,6 @@ "OptionBlockMusic": "Music", "OptionBlockLiveTvChannels": "Live TV Channels", "OptionBlockBooks": "Books", - "OptionAutomatic": "Auto", "OptionAuto": "Auto", "OptionAscending": "Ascending", "OptionAdminUsers": "Administrators", @@ -1286,7 +1254,6 @@ "MessageYouHaveVersionInstalled": "You currently have version {0} installed.", "MessageUnableToConnectToServer": "We're unable to connect to the selected server right now. Please ensure it is running and try again.", "MessageTheFollowingLocationWillBeRemovedFromLibrary": "The following media locations will be removed from your library:", - "MessageSettingsSaved": "Settings saved.", "MessageReenableUser": "See below to reenable", "MessageLeaveEmptyToInherit": "Leave empty to inherit settings from a parent item or the global default value.", "MessageItemsAdded": "Items added.", @@ -1350,7 +1317,6 @@ "HeaderPlayAll": "Play All", "HeaderPinCodeReset": "Reset Pin Code", "HeaderPhotoAlbums": "Photo Albums", - "HeaderHome": "Home", "HeaderFavoritePeople": "Favourite People", "FetchingData": "Fetching additional data", "ButtonAddImage": "Add Image", diff --git a/src/strings/en-us.json b/src/strings/en-us.json index 38b79613e2..f87c1a326e 100644 --- a/src/strings/en-us.json +++ b/src/strings/en-us.json @@ -71,31 +71,24 @@ "ButtonBack": "Back", "ButtonCancel": "Cancel", "ButtonChangeServer": "Change Server", - "ButtonEdit": "Edit", - "ButtonEditImages": "Edit images", "ButtonEditOtherUserPreferences": "Edit this user's profile, image and personal preferences.", - "ButtonFilter": "Filter", "ButtonForgotPassword": "Forgot Password", "ButtonFullscreen": "Fullscreen", "ButtonGotIt": "Got It", "ButtonGuide": "Guide", - "ButtonHome": "Home", "ButtonInfo": "Info", "ButtonLibraryAccess": "Library access", "ButtonManualLogin": "Manual Login", "ButtonMore": "More", "ButtonNetwork": "Network", "ButtonNextTrack": "Next track", - "ButtonOff": "Off", "ButtonOk": "Ok", "ButtonOpen": "Open", "ButtonParentalControl": "Parental control", "ButtonPause": "Pause", - "ButtonPlay": "Play", "ButtonPreviousTrack": "Previous track", "ButtonProfile": "Profile", "ButtonQuickStartGuide": "Quick Start Guide", - "ButtonRefresh": "Refresh", "ButtonRefreshGuideData": "Refresh Guide Data", "ButtonRemove": "Remove", "ButtonRename": "Rename", @@ -117,7 +110,6 @@ "ButtonStop": "Stop", "ButtonSplit": "Split", "ButtonSubmit": "Submit", - "ButtonSubtitles": "Subtitles", "ButtonTogglePlaylist": "Playlist", "ButtonTrailer": "Trailer", "ButtonUninstall": "Uninstall", @@ -213,9 +205,7 @@ "EnablePhotosHelp": "Images will be detected and displayed alongside other media files.", "EnableStreamLooping": "Auto-loop live streams", "EnableStreamLoopingHelp": "Enable this if live streams only contain a few seconds of data and need to be continuously requested. Enabling this when not needed may cause problems.", - "EnableThemeSongs": "Theme songs", "EnableThemeSongsHelp": "Play theme songs in the background while browsing the library.", - "EnableThemeVideos": "Theme videos", "EnableThemeVideosHelp": "Play theme videos in the background while browsing the library.", "EnableDetailsBanner": "Details Banner", "EnableDetailsBannerHelp": "Display a banner image at the top of the item details page.", @@ -276,11 +266,9 @@ "HeaderActiveDevices": "Active Devices", "HeaderActiveRecordings": "Active Recordings", "HeaderActivity": "Activity", - "HeaderAddScheduledTaskTrigger": "Add Trigger", "HeaderAddToCollection": "Add to Collection", "HeaderAddToPlaylist": "Add to Playlist", "HeaderAddUpdateImage": "Add/Update Image", - "HeaderAddUser": "Add User", "HeaderAdditionalParts": "Additional Parts", "HeaderAdmin": "Admin", "HeaderAlbumArtists": "Album Artists", @@ -295,12 +283,10 @@ "HeaderAudioBooks": "Audio Books", "HeaderAudioSettings": "Audio Settings", "HeaderBlockItemsWithNoRating": "Block items with no or unrecognized rating information:", - "HeaderBooks": "Books", "HeaderBranding": "Branding", "HeaderCancelRecording": "Cancel Recording", "HeaderCancelSeries": "Cancel Series", "HeaderCastAndCrew": "Cast & Crew", - "HeaderCastCrew": "Cast & Crew", "HeaderChannelAccess": "Channel Access", "HeaderChapterImages": "Chapter Images", "HeaderCodecProfile": "Codec Profile", @@ -335,7 +321,6 @@ "HeaderEditImages": "Edit Images", "HeaderEnabledFields": "Enabled Fields", "HeaderEnabledFieldsHelp": "Uncheck a field to lock it and prevent its data from being changed.", - "HeaderEpisodes": "Episodes", "HeaderError": "Error", "HeaderExternalIds": "External IDs:", "HeaderFavoriteBooks": "Favorite Books", @@ -352,10 +337,8 @@ "HeaderFetchImages": "Fetch Images:", "HeaderFetcherSettings": "Fetcher Settings", "HeaderForKids": "For Kids", - "HeaderForgotPassword": "Forgot Password", "HeaderFrequentlyPlayed": "Frequently Played", "HeaderGuideProviders": "TV Guide Data Providers", - "HeaderHome": "Home", "HeaderHttpHeaders": "HTTP Headers", "HeaderHttpsSettings": "HTTPS Settings", "HeaderIdentification": "Identification", @@ -383,7 +366,6 @@ "HeaderLoginFailure": "Login Failure", "HeaderMedia": "Media", "HeaderMediaFolders": "Media Folders", - "HeaderMediaInfo": "Media Info", "HeaderMetadataSettings": "Metadata Settings", "HeaderMoreLikeThis": "More Like This", "HeaderMusicQuality": "Music Quality", @@ -521,7 +503,6 @@ "LabelAppNameExample": "Example: Sickbeard, Sonarr", "LabelArtists": "Artists:", "LabelArtistsHelp": "Separate multiple artists with a semicolon.", - "LabelAudio": "Audio", "LabelAudioBitDepth": "Audio bit depth:", "LabelAudioBitrate": "Audio bitrate:", "LabelAudioChannels": "Audio channels:", @@ -557,7 +538,6 @@ "LabelCustomCertificatePathHelp": "Path to a PKCS #12 file containing a certificate and private key to enable TLS support on a custom domain.", "LabelCustomCss": "Custom CSS:", "LabelCustomCssHelp": "Apply your own custom styles on the web interface.", - "LabelCustomDeviceDisplayName": "Display name:", "LabelCustomDeviceDisplayNameHelp": "Supply a custom display name or leave empty to use the name reported by the device.", "LabelCustomRating": "Custom rating:", "LabelDateAdded": "Date added:", @@ -575,7 +555,6 @@ "LabelDiscNumber": "Disc number:", "LabelDisplayLanguage": "Display language:", "LabelDisplayLanguageHelp": "Translating Jellyfin is an ongoing project.", - "LabelDisplayMissingEpisodesWithinSeasons": "Display missing episodes within seasons", "LabelDisplayMode": "Display mode:", "LabelDisplayName": "Display name:", "LabelDisplayOrder": "Display order:", @@ -747,7 +726,6 @@ "LabelPostProcessorArguments": "Post-processor command line arguments:", "LabelPostProcessorArgumentsHelp": "Use {path} as the path to the recording file.", "LabelPreferredDisplayLanguage": "Preferred display language:", - "LabelPreferredDisplayLanguageHelp": "Translating Jellyfin is an ongoing project.", "LabelPreferredSubtitleLanguage": "Preferred subtitle language:", "LabelProfileAudioCodecs": "Audio codecs:", "LabelProfileCodecs": "Codecs:", @@ -814,7 +792,6 @@ "LabelSubtitleDownloaders": "Subtitle downloaders:", "LabelSubtitleFormatHelp": "Example: srt", "LabelSubtitlePlaybackMode": "Subtitle mode:", - "LabelSubtitles": "Subtitles", "LabelSupportedMediaTypes": "Supported Media Types:", "LabelSyncPlayTimeOffset": "Time offset with the server:", "MillisecondsUnit": "ms", @@ -839,8 +816,6 @@ "LabelTimeLimitHours": "Time limit (hours):", "LabelTitle": "Title:", "LabelTrackNumber": "Track number:", - "LabelTranscodingAudioCodec": "Audio codec:", - "LabelTranscodingContainer": "Container:", "LabelTranscodePath": "Transcode path:", "LabelTranscodingTempPathHelp": "Specify a custom path for the transcode files served to clients. Leave blank to use the server default.", "LabelTranscodes": "Transcodes:", @@ -848,7 +823,6 @@ "LabelTranscodingProgress": "Transcoding progress:", "LabelTranscodingThreadCount": "Transcoding thread count:", "LabelTranscodingThreadCountHelp": "Select the maximum number of threads to use when transcoding. Reducing the thread count will lower CPU usage but may not convert fast enough for a smooth playback experience.", - "LabelTranscodingVideoCodec": "Video codec:", "LabelTriggerType": "Trigger Type:", "LabelTunerIpAddress": "Tuner IP Address:", "LabelTunerType": "Tuner type:", @@ -986,7 +960,6 @@ "MessagePluginConfigurationRequiresLocalAccess": "To configure this plugin please sign in to your local server directly.", "MessagePluginInstallDisclaimer": "Plugins built by community members are a great way to enhance your experience with additional features and benefits. Before installing, please be aware of the effects they may have on your server, such as longer library scans, additional background processing, and decreased system stability.", "MessageReenableUser": "See below to reenable", - "MessageSettingsSaved": "Settings saved.", "MessageTheFollowingLocationWillBeRemovedFromLibrary": "The following media locations will be removed from your library:", "MessageUnableToConnectToServer": "We're unable to connect to the selected server right now. Please ensure it is running and try again.", "MessageUnsetContentHelp": "Content will be displayed as plain folders. For best results use the metadata manager to set the content types of sub-folders.", @@ -1077,7 +1050,6 @@ "OptionArtist": "Artist", "OptionAscending": "Ascending", "OptionAuto": "Auto", - "OptionAutomatic": "Auto", "OptionAutomaticallyGroupSeries": "Automatically merge series that are spread across multiple folders", "OptionAutomaticallyGroupSeriesHelp": "Series that are spread across multiple folders within this library will be automatically merged into a single series.", "OptionBanner": "Banner", @@ -1351,19 +1323,15 @@ "TV": "TV", "TabAccess": "Access", "TabAdvanced": "Advanced", - "TabAlbumArtists": "Album Artists", "TabCatalog": "Catalog", "TabRepositories": "Repositories", "TabCodecs": "Codecs", "TabContainers": "Containers", "TabDashboard": "Dashboard", "TabDirectPlay": "Direct Play", - "TabEpisodes": "Episodes", - "TabInfo": "Info", "TabLatest": "Latest", "TabLogs": "Logs", "TabMusic": "Music", - "TabMusicVideos": "Music Videos", "TabMyPlugins": "My Plugins", "TabNetworks": "Networks", "TabNetworking": "Networking", @@ -1375,12 +1343,10 @@ "TabProfile": "Profile", "TabProfiles": "Profiles", "TabResponses": "Responses", - "TabResumeSettings": "Resume", "TabScheduledTasks": "Scheduled Tasks", "TabServer": "Server", "TabSettings": "Settings", "TabStreaming": "Streaming", - "TabTrailers": "Trailers", "TabUpcoming": "Upcoming", "Tags": "Tags", "TagsValue": "Tags: {0}", diff --git a/src/strings/es-ar.json b/src/strings/es-ar.json index 74eb87e842..a031af20ff 100644 --- a/src/strings/es-ar.json +++ b/src/strings/es-ar.json @@ -3,9 +3,7 @@ "ButtonSignOut": "Cerrar sesión", "EnableHardwareEncoding": "Habilitar la codificación de hardware", "FolderTypeTvShows": "TV", - "HeaderAddUser": "Agregar Usuario", "HeaderLatestEpisodes": "Últimos capítulos", - "LabelDisplayMissingEpisodesWithinSeasons": "Mostrar capítulos no disponibles en temporadas", "LabelFinish": "Terminar", "LabelYoureDone": "Ha terminado!", "MoreUsersCanBeAddedLater": "Se pueden agregar más usuarios más tarde desde el tablero.", @@ -13,7 +11,6 @@ "OptionMissingEpisode": "Capítulos faltantes", "OptionUnairedEpisode": "Capítulos no emitidos", "ParentalRating": "Parental Rating", - "TabEpisodes": "Capítulos", "TellUsAboutYourself": "Contanos acerca de vos", "ThisWizardWillGuideYou": "Este asistente le ayudará a guiarlo durante el proceso de configuración. Para comenzar, seleccione su idioma preferido.", "UserProfilesIntro": "Jellyfin incluye soporte para perfiles de usuario con configuraciones de visualización granulares, estado de reproducción y controles parentales.", @@ -99,30 +96,23 @@ "ButtonBack": "Atrás", "ButtonCancel": "Cancelar", "ButtonChangeServer": "Cambiar servidor", - "ButtonEdit": "Editar", - "ButtonEditImages": "Editar imágenes", "ButtonEditOtherUserPreferences": "Editar perfil, imagen y preferencias personales del usuario.", - "ButtonFilter": "Filtrar", "ButtonForgotPassword": "Olvidé mi contraseña", "ButtonFullscreen": "Pantalla completa", "ButtonGotIt": "Lo entendí", "ButtonGuide": "Guía", - "ButtonHome": "Inicio", "ButtonInfo": "Información", "ButtonLibraryAccess": "Acceso a la biblioteca", "ButtonManualLogin": "Inicio de sesión manual", "ButtonMore": "Más", "ButtonNetwork": "Red", "ButtonNextTrack": "Pista siguiente", - "ButtonOff": "Desactivado", "ButtonOk": "Aceptar", "ButtonOpen": "Abrir", "ButtonParentalControl": "Control parental", "ButtonPause": "Pausar", - "ButtonPlay": "Reproducir", "ButtonPreviousTrack": "Pista anterior", "ButtonProfile": "Perfil", - "ButtonRefresh": "Actualizar", "ButtonRefreshGuideData": "Actualizar datos de la guía", "ButtonRemove": "Quitar", "ButtonRename": "Renombrar", @@ -142,7 +132,6 @@ "ButtonStart": "Iniciar", "ButtonStop": "Detener", "ButtonSubmit": "Enviar", - "ButtonSubtitles": "Subtítulos", "ButtonTrailer": "Avance", "ButtonUninstall": "Desinstalar", "ButtonWebsite": "Sitio web", @@ -229,9 +218,7 @@ "EnablePhotosHelp": "Las imágenes serán detectadas y mostradas junto con otros archivos multimedia.", "EnableStreamLooping": "Repetir automáticamente transmisiones en vivo", "EnableStreamLoopingHelp": "Habilita esto sí las transmisiones en vivo sólo contienen unos cuantos segundos y es necesario solicitarlos continuamente. Habilitar esto cuando no es necesario puede causar problemas.", - "EnableThemeSongs": "Canciones temáticas", "EnableThemeSongsHelp": "Reproducir canciones temáticas en el fondo mientras se navega por la biblioteca.", - "EnableThemeVideos": "Videos temáticos", "EnableThemeVideosHelp": "Al habilitarse, los vídeos de tema se reproducirán de fondo mientras navegues por la biblioteca.", "Ended": "Finalizado", "EndsAtValue": "Termina en {0}", @@ -290,7 +277,6 @@ "AllowFfmpegThrottling": "Transcodificación Throttle", "HeaderCancelRecording": "Cancelar Grabación", "HeaderBranding": "Marca", - "HeaderBooks": "Libros", "HeaderBlockItemsWithNoRating": "Bloquear elementos con rating de información vacía o no reconocible:", "HeaderAudioSettings": "Configuraciones de audio", "HeaderAudioBooks": "Audiolibros", @@ -306,7 +292,6 @@ "HeaderAddUpdateImage": "Agregar/Actualizar imagen", "HeaderAddToPlaylist": "Agregar a la lista de reproducción", "HeaderAddToCollection": "Agregar a la Colección", - "HeaderAddScheduledTaskTrigger": "Agregar disparador", "HeaderActivity": "Actividad", "HeaderActiveRecordings": "Grabaciones activas", "HeaderActiveDevices": "Dispositivos activos", @@ -338,7 +323,6 @@ "HeaderCodecProfile": "Perfil del códec", "HeaderChapterImages": "Imágenes del capitulo", "HeaderChannelAccess": "Acceso al canal", - "HeaderCastCrew": "Reparto", "HeaderCastAndCrew": "Reparto", "HeaderCancelSeries": "Cancelar serie", "H264CrfHelp": "El Factor de velocidad constante (CRF) es la configuración de calidad predeterminada para el codificador x264. Puede establecer los valores entre 0 y 51, donde valores más bajos resultarían en una mejor calidad (a expensas de tamaños de archivo más altos). Los valores correctos están entre 18 y 28. El valor predeterminado para x264 es 23, por lo que puede usar esto como punto de partida.", @@ -349,7 +333,6 @@ "HeaderFavoriteBooks": "Libros favoritos", "HeaderExternalIds": "IDs externos:", "HeaderError": "Error", - "HeaderEpisodes": "Capítulos", "HeaderEnabledFields": "Campos habilitados", "HeaderEditImages": "Editar imágenes", "HeaderEasyPinCode": "Código PIN fácil", @@ -390,10 +373,8 @@ "HeaderIdentificationCriteriaHelp": "Ingrese al menos un criterio de identificación.", "HeaderIdentification": "Identificación", "HeaderHttpHeaders": "Encabezados HTTP", - "HeaderHome": "Inicio", "HeaderGuideProviders": "Proveedores de datos de guías de TV", "HeaderFrequentlyPlayed": "Reproducido con frecuencia", - "HeaderForgotPassword": "Olvidé la contraseña", "HeaderForKids": "Para niños", "HeaderFetcherSettings": "Configuración del recuperador", "HeaderFetchImages": "Obtener imágenes:", @@ -510,7 +491,6 @@ "HeaderNextEpisodePlayingInValue": "Reproducción del siguiente capítulo en {0}", "HeaderMoreLikeThis": "Más como esto", "HeaderMetadataSettings": "Configuraciones de metadatos", - "HeaderMediaInfo": "Información de medios", "HeaderHttpsSettings": "Configuraciones HTTPS", "HeaderEnabledFieldsHelp": "Desmarque un campo para bloquearlo y evitar que se modifiquen sus datos.", "HeaderDirectPlayProfileHelp": "Agregue perfiles de reproducción directa para indicar qué formatos puede manejar el dispositivo de forma nativa.", @@ -539,7 +519,6 @@ "LabelAudioCodec": "Códec de audio:", "LabelAudioChannels": "Canales de audio:", "LabelAudioBitrate": "Velocidad de bits de audio:", - "LabelAudio": "Audio", "LabelAllowedRemoteAddresses": "Filtro de dirección IP remota:", "LabelAllowHWTranscoding": "Permitir transcodificación con hardware", "LabelAlbumArtists": "Artistas del álbum:", @@ -639,7 +618,6 @@ "LabelDateAdded": "Fecha agregada:", "LabelCustomRating": "Calificación personalizada:", "LabelCustomDeviceDisplayNameHelp": "Proporcione un nombre personalizado para mostrar o déjelo vacío para usar el nombre informado por el dispositivo.", - "LabelCustomDeviceDisplayName": "Nombre para mostrar:", "LabelCustomCssHelp": "Aplique su propio estilo personalizado a la interfaz web.", "LabelCustomCss": "CSS personalizado:", "LabelCustomCertificatePathHelp": "Ruta a un archivo PKCS #12 que contiene un certificado y una clave privada para habilitar el soporte TLS en un dominio personalizado.", @@ -679,7 +657,6 @@ "MillisecondsUnit": "ms", "LabelSyncPlayTimeOffset": "Compensación horaria con el servidor:", "LabelSupportedMediaTypes": "Tipos de medios soportados:", - "LabelSubtitles": "Subtítulos", "LabelSubtitlePlaybackMode": "Modo de subtítulos:", "LabelSubtitleFormatHelp": "Ejemplo: srt", "LabelSubtitleDownloaders": "Descargadores de subtítulos:", @@ -741,7 +718,6 @@ "LabelProfileCodecs": "Códecs:", "LabelProfileAudioCodecs": "Códecs de audio:", "LabelPreferredSubtitleLanguage": "Idioma de subtítulos preferido:", - "LabelPreferredDisplayLanguageHelp": "La traducción de Jellyfin es un proyecto en curso.", "LabelPreferredDisplayLanguage": "Idioma de visualización preferido:", "LabelPostProcessorArgumentsHelp": "Use {ruta} como la ruta al archivo de grabación.", "LabelPostProcessorArguments": "Argumentos de la línea de comando del post-procesador:", @@ -829,7 +805,6 @@ "OptionBanner": "Pancarta", "OptionAutomaticallyGroupSeriesHelp": "Si está habilitado, las series que se distribuyen en varias carpetas dentro de esta biblioteca se fusionarán automáticamente en una sola serie.", "OptionAutomaticallyGroupSeries": "Combinar automáticamente series que se extienden a través de múltiples carpetas", - "OptionAutomatic": "Auto", "OptionAuto": "Auto", "OptionAscending": "Ascendente", "OptionArtist": "Artista", @@ -914,7 +889,6 @@ "MessageUnsetContentHelp": "El contenido se mostrará como carpetas simples. Para obtener mejores resultados, use el administrador de metadatos para configurar los tipos de contenido de las subcarpetas.", "MessageUnableToConnectToServer": "No podemos conectarnos al servidor seleccionado en este momento. Asegúrese de que se esté ejecutando e intente nuevamente.", "MessageTheFollowingLocationWillBeRemovedFromLibrary": "Las siguientes ubicaciones de medios se eliminarán de su biblioteca:", - "MessageSettingsSaved": "Configuraciones guardadas.", "MessageReenableUser": "Ver abajo para volver a habilitar", "MessagePluginInstallDisclaimer": "Los complementos creados por miembros de la comunidad Jellyfin son una excelente manera de mejorar su experiencia Jellyfin con características y beneficios adicionales. Antes de la instalación, tenga en cuenta los efectos que pueden tener en su servidor Jellyfin, como escaneos de bibliotecas más largos, procesamiento en segundo plano adicional y disminución de la estabilidad del sistema.", "MessagePluginConfigurationRequiresLocalAccess": "Para configurar este complemento, inicie sesión directamente en su servidor local.", @@ -1042,7 +1016,6 @@ "LabelTunerType": "Tipo de sintonizador:", "LabelTunerIpAddress": "Dirección IP del sintonizador:", "LabelTriggerType": "Tipo de disparador:", - "LabelTranscodingVideoCodec": "Códec de vídeo:", "LabelTranscodingThreadCountHelp": "Elija el número máximo de hilos para usar al transcodificar. Reducir el recuento de hilos disminuirá el uso de la CPU, pero es posible que no se convierta lo suficientemente rápido para una experiencia de reproducción fluida.", "LabelTranscodingThreadCount": "Conteo de hilos de transcodificación:", "LabelTranscodingProgress": "Progreso de transcodificación:", @@ -1050,8 +1023,6 @@ "LabelTranscodes": "Transcodificaciones:", "LabelTranscodingTempPathHelp": "Especifique una ruta personalizada para los archivos de transcodificación servidos a los clientes. Déjelo en blanco para usar el servidor predeterminado.", "LabelTranscodePath": "Ruta para las transcodificaciones:", - "LabelTranscodingContainer": "Contenedor:", - "LabelTranscodingAudioCodec": "Códec de audio:", "LabelTrackNumber": "Número de pista:", "LabelTitle": "Título:", "LabelTimeLimitHours": "Límite de tiempo (horas):", @@ -1363,12 +1334,10 @@ "MarkPlayed": "Marcar reproducido", "LabelSkipForwardLength": "Saltar hacia adelante longitud:", "Trailers": "Avances", - "TabTrailers": "Avances", "TabStreaming": "Transmisión", "TabSettings": "Configuraciones", "TabServer": "Servidor", "TabScheduledTasks": "Tareas programadas", - "TabResumeSettings": "Continuar", "TabResponses": "Respuestas", "TabProfiles": "Perfiles", "TabProfile": "Perfil", @@ -1380,18 +1349,15 @@ "TabNetworking": "Redes", "TabNetworks": "Redes", "TabMyPlugins": "Mis complementos", - "TabMusicVideos": "Videos musicales", "TabMusic": "Música", "TabLogs": "Registros", "TabLatest": "Último", - "TabInfo": "Información", "TabDirectPlay": "Reproducción directa", "TabDashboard": "Tablero", "TabContainers": "Contenedores", "TabCodecs": "Códecs", "TabRepositories": "Repositorios", "TabCatalog": "Catálogo", - "TabAlbumArtists": "Artistas del álbum", "TabAdvanced": "Avanzado", "TabAccess": "Acceso", "TV": "TV", diff --git a/src/strings/es-mx.json b/src/strings/es-mx.json index c7669c4429..7c392f04b6 100644 --- a/src/strings/es-mx.json +++ b/src/strings/es-mx.json @@ -59,29 +59,22 @@ "ButtonBack": "Atrás", "ButtonCancel": "Cancelar", "ButtonChangeServer": "Cambiar servidor", - "ButtonEdit": "Editar", - "ButtonEditImages": "Editar imágenes", "ButtonEditOtherUserPreferences": "Editar el perfil, la imagen y las preferencias personales de este usuario.", - "ButtonFilter": "Filtro", "ButtonForgotPassword": "Olvidé mi contraseña", "ButtonFullscreen": "Pantalla completa", "ButtonGotIt": "Hecho", "ButtonGuide": "Guía", - "ButtonHome": "Inicio", "ButtonLibraryAccess": "Acceso a biblioteca(s)", "ButtonManualLogin": "Inicio de sesión manual", "ButtonMore": "Más", "ButtonNetwork": "Red", "ButtonNextTrack": "Pista siguiente", - "ButtonOff": "Apagar", "ButtonOpen": "Abrir", "ButtonParentalControl": "Control parental", "ButtonPause": "Pausar", - "ButtonPlay": "Reproducir", "ButtonPreviousTrack": "Pista anterior", "ButtonProfile": "Perfil", "ButtonQuickStartGuide": "Guía de inicio rápido", - "ButtonRefresh": "Actualizar", "ButtonRefreshGuideData": "Actualizar datos de la guía", "ButtonRemove": "Remover", "ButtonRename": "Renombrar", @@ -102,7 +95,6 @@ "ButtonStart": "Iniciar", "ButtonStop": "Detener", "ButtonSubmit": "Enviar", - "ButtonSubtitles": "Subtítulos", "ButtonUninstall": "Desinstalar", "ButtonWebsite": "Sitio web", "CancelRecording": "Cancelar grabación", @@ -189,9 +181,7 @@ "EnablePhotosHelp": "Las imágenes serán detectadas y mostradas junto con otros archivos multimedia.", "EnableStreamLooping": "Repetir automáticamente las transmisiones en vivo", "EnableStreamLoopingHelp": "Habilita esta opción si las transmisiones en vivo contienen solo unos pocos segundos de datos y necesitan ser solicitadas continuamente. Habilitar esto cuando no es requerido puede causar problemas.", - "EnableThemeSongs": "Canciones temáticas", "EnableThemeSongsHelp": "Reproducir canciones temáticas en el fondo mientras se navega por la biblioteca.", - "EnableThemeVideos": "Videos temáticos", "EnableThemeVideosHelp": "Reproducir videos temáticos en el fondo mientras se navega por la biblioteca.", "Ended": "Finalizado", "EndsAtValue": "Termina a las {0}", @@ -246,11 +236,9 @@ "HeaderActiveDevices": "Dispositivos activos", "HeaderActiveRecordings": "Grabaciones activas", "HeaderActivity": "Actividad", - "HeaderAddScheduledTaskTrigger": "Agregar disparador", "HeaderAddToCollection": "Agregar a colección", "HeaderAddToPlaylist": "Agregar a lista de reproducción", "HeaderAddUpdateImage": "Agregar/Actualizar Imagen", - "HeaderAddUser": "Agregar usuario", "HeaderAdditionalParts": "Partes adicionales", "HeaderAlbumArtists": "Artistas del álbum", "HeaderAlert": "Alerta", @@ -262,12 +250,10 @@ "HeaderAudioBooks": "Audiolibros", "HeaderAudioSettings": "Configuración de audio", "HeaderBlockItemsWithNoRating": "Bloquear elementos sin clasificación o con información de clasificación desconocida:", - "HeaderBooks": "Libros", "HeaderBranding": "Establecer marca", "HeaderCancelRecording": "Cancelar grabación", "HeaderCancelSeries": "Cancelar serie", "HeaderCastAndCrew": "Reparto y equipo", - "HeaderCastCrew": "Reparto y equipo", "HeaderChannelAccess": "Acceso a los canales", "HeaderChapterImages": "Imágenes de los capítulos", "HeaderCodecProfile": "Perfil de códec", @@ -301,13 +287,11 @@ "HeaderEditImages": "Editar imágenes", "HeaderEnabledFields": "Campos habilitados", "HeaderEnabledFieldsHelp": "Desmarca un campo para bloquearlo y prevenir que sus datos sean cambiados.", - "HeaderEpisodes": "Episodios", "HeaderExternalIds": "IDs externos:", "HeaderFeatureAccess": "Acceso a características", "HeaderFetchImages": "Obtener imágenes:", "HeaderFetcherSettings": "Configuración del recolector", "HeaderForKids": "Para niños", - "HeaderForgotPassword": "Olvidé mi contraseña", "HeaderFrequentlyPlayed": "Reproducido frecuentemente", "HeaderGuideProviders": "Proveedores de Guías de TV", "HeaderHttpHeaders": "Encabezados HTTP", @@ -336,7 +320,6 @@ "HeaderLoginFailure": "Falló el inicio de sesión", "HeaderMedia": "Medios", "HeaderMediaFolders": "Carpetas de medios", - "HeaderMediaInfo": "Info del medio", "HeaderMetadataSettings": "Configuración de metadatos", "HeaderMoreLikeThis": "Más como esto", "HeaderMusicQuality": "Calidad de la música", @@ -494,7 +477,6 @@ "LabelCustomCertificatePathHelp": "Ruta a un archivo PKCS #12 que contiene un certificado y una clave privada para habilitar el soporte TLS en un dominio personalizado.", "LabelCustomCss": "CSS personalizado:", "LabelCustomCssHelp": "Aplica tu propio estilo personalizado a la interfaz web.", - "LabelCustomDeviceDisplayName": "Nombre a mostrar:", "LabelCustomDeviceDisplayNameHelp": "Proporcione un nombre personalizado para mostrar o déjalo vacío para usar el nombre reportado por el dispositivo.", "LabelCustomRating": "Calificación personalizada:", "LabelDateAdded": "Fecha de adición:", @@ -511,7 +493,6 @@ "LabelDiscNumber": "Número de disco:", "LabelDisplayLanguage": "Idioma de pantalla:", "LabelDisplayLanguageHelp": "La traducción de Jellyfin es un proyecto en curso.", - "LabelDisplayMissingEpisodesWithinSeasons": "Mostrar episodios faltantes en las temporadas", "LabelDisplayMode": "Modo de pantalla:", "LabelDisplayName": "Nombre a mostrar:", "LabelDisplayOrder": "Orden para mostrar:", @@ -666,7 +647,6 @@ "LabelPostProcessorArguments": "Argumentos de la línea de comandos del post-procesador:", "LabelPostProcessorArgumentsHelp": "Usar {path} como la ruta del archivo grabado.", "LabelPreferredDisplayLanguage": "Idioma de pantalla preferido:", - "LabelPreferredDisplayLanguageHelp": "La traducción de Jellyfin es un proyecto en curso.", "LabelPreferredSubtitleLanguage": "Idioma preferido para los subtítulos:", "LabelProfileAudioCodecs": "Códecs de audio:", "LabelProfileCodecsHelp": "Separados por comas. Puede dejarse vacío para aplicarlo a todos los códecs.", @@ -725,7 +705,6 @@ "LabelSubtitleDownloaders": "Recolectores de subtítulos:", "LabelSubtitleFormatHelp": "Ejemplo: srt", "LabelSubtitlePlaybackMode": "Modo de subtítulo:", - "LabelSubtitles": "Subtítulos", "LabelSupportedMediaTypes": "Tipos de medios soportados:", "LabelTVHomeScreen": "Modo de pantalla de TV:", "LabelTag": "Etiqueta:", @@ -738,12 +717,9 @@ "LabelTimeLimitHours": "Límite de tiempo (horas):", "LabelTitle": "Título:", "LabelTrackNumber": "Número de pista:", - "LabelTranscodingAudioCodec": "Códec de audio:", - "LabelTranscodingContainer": "Contenedor:", "LabelTranscodingTempPathHelp": "Especifica una ruta personalizada para los archivos de transcodificación servidos a los clientes. Deja en blanco para utilizar el predeterminado del servidor.", "LabelTranscodingThreadCount": "Conteo de hilos de la transcodificación:", "LabelTranscodingThreadCountHelp": "Selecciona el número máximo de hilos a utilizar al transcodificar. Reducir el número de hilos reducirá el uso de la CPU, pero es posible que no se convierta lo suficientemente rápido como para que la experiencia de reproducción sea fluida.", - "LabelTranscodingVideoCodec": "Códec de video:", "LabelTriggerType": "Tipo de disparador:", "LabelTunerIpAddress": "Dirección IP del sintonizador:", "LabelTunerType": "Tipo de sintonizador:", @@ -851,7 +827,6 @@ "MessagePluginConfigurationRequiresLocalAccess": "Para configurar este complemento por favor, inicia sesión en tu servidor local directamente.", "MessagePluginInstallDisclaimer": "Los complementos desarrollados por miembros de la comunidad Jellyfin son una gran forma de mejorar tu experiencia con Jellyfin con características y beneficios adicionales. Antes de instalar, por favor, conoce el impacto que pueden ocasionar en tu servidor Jellyfin, tales como escaneo más largo de bibliotecas, procesamiento en segundo plano adicional y reducción de la estabilidad del sistema.", "MessageReenableUser": "Ver abajo para volver a habilitar", - "MessageSettingsSaved": "Configuraciones guardadas.", "MessageTheFollowingLocationWillBeRemovedFromLibrary": "Las siguientes ubicaciones de medios se removerán de tu biblioteca:", "MessageUnableToConnectToServer": "No podemos conectarnos al servidor seleccionado en este momento. Por favor, asegúrate de que está funcionando e inténtalo de nuevo.", "MessageUnsetContentHelp": "El contenido será mostrado como carpetas simples. Para mejores resultados utiliza el administrador de metadatos para establecer los tipos de contenido para las subcarpetas.", @@ -915,7 +890,6 @@ "OptionArtist": "Artista", "OptionAscending": "Ascendente", "OptionAuto": "Automático", - "OptionAutomatic": "Automático", "OptionAutomaticallyGroupSeries": "Fusionar automáticamente series esparcidas a través de múltiples carpetas", "OptionAutomaticallyGroupSeriesHelp": "Si se habilita, las series que se reparten a través de múltiples carpetas dentro de esta biblioteca serán fusionadas en una sola serie.", "OptionBlockBooks": "Libros", @@ -1150,16 +1124,13 @@ "SystemDlnaProfilesHelp": "Los perfiles del sistema son de solo lectura. Los cambios a un perfil del sistema serán guardados en un nuevo perfil personalizado.", "TabAccess": "Acceso", "TabAdvanced": "Avanzado", - "TabAlbumArtists": "Artistas del álbum", "TabCatalog": "Catálogo", "TabContainers": "Contenedores", "TabDashboard": "Panel de control", "TabDirectPlay": "Reproducción directa", - "TabEpisodes": "Episodios", "TabLatest": "Recientes", "TabLogs": "Registros", "TabMusic": "Música", - "TabMusicVideos": "Videos musicales", "TabMyPlugins": "Mis complementos", "TabNetworks": "Cadenas", "TabNfoSettings": "Configuración de NFO", @@ -1170,12 +1141,10 @@ "TabProfile": "Perfil", "TabProfiles": "Perfiles", "TabResponses": "Respuestas", - "TabResumeSettings": "Reanudar", "TabScheduledTasks": "Tareas programadas", "TabServer": "Servidor", "TabSettings": "Configuración", "TabStreaming": "Transmisión", - "TabTrailers": "Trailers", "TabUpcoming": "Próximamente", "Tags": "Etiquetas", "TagsValue": "Etiquetas: {0}", @@ -1261,10 +1230,8 @@ "HeaderFavoriteArtists": "Artistas favoritos", "HeaderFavoriteSongs": "Canciones favoritas", "HeaderFavoriteVideos": "Videos favoritos", - "HeaderHome": "Inicio", "HeaderVideos": "Videos", "Horizontal": "Horizontal", - "LabelAudio": "Audio", "LabelAuthProvider": "Proveedor de autenticación:", "LabelDynamicExternalId": "{0} Id:", "LabelPasswordResetProvider": "Proveedor de restablecimiento de contraseña:", @@ -1317,7 +1284,6 @@ "SubtitleOffset": "Desplazamiento de subtítulos", "TV": "TV", "TabCodecs": "Códecs", - "TabInfo": "Información", "ValueMinutes": "{0} min", "ValueSeriesCount": "{0} series", "Vertical": "Vertical", diff --git a/src/strings/es.json b/src/strings/es.json index 09e5f5fcf4..c56c61e16c 100644 --- a/src/strings/es.json +++ b/src/strings/es.json @@ -49,30 +49,23 @@ "ButtonBack": "Atrás", "ButtonCancel": "Cancelar", "ButtonChangeServer": "Cambiar servidor", - "ButtonEdit": "Editar", - "ButtonEditImages": "Editar imágenes", "ButtonEditOtherUserPreferences": "Editar este perfil, la imagen y los ajustes personales.", - "ButtonFilter": "Filtro", "ButtonForgotPassword": "Contraseña olvidada", "ButtonFullscreen": "Pantalla completa", "ButtonGotIt": "Entendido", "ButtonGuide": "Guía", - "ButtonHome": "Inicio", "ButtonLibraryAccess": "Acceso a la biblioteca", "ButtonManualLogin": "Acceder manualmente", "ButtonMore": "Más", "ButtonNetwork": "Red", "ButtonNextTrack": "Pista siguiente", - "ButtonOff": "Apagado", "ButtonOk": "OK", "ButtonOpen": "Abrir", "ButtonParentalControl": "Control parental", "ButtonPause": "Pausa", - "ButtonPlay": "Reproducir", "ButtonPreviousTrack": "Pista anterior", "ButtonProfile": "Perfil", "ButtonQuickStartGuide": "Guía de inicio rápido", - "ButtonRefresh": "Refrescar", "ButtonRefreshGuideData": "Actualizar datos de la guía", "ButtonRemove": "Quitar", "ButtonRename": "Renombrar", @@ -93,7 +86,6 @@ "ButtonStart": "Inicio", "ButtonStop": "Detener", "ButtonSubmit": "Enviar", - "ButtonSubtitles": "Subtítulos", "ButtonTrailer": "Tráiler", "ButtonUninstall": "Desinstalar", "ButtonWebsite": "Sitio web", @@ -156,7 +148,6 @@ "EnablePhotosHelp": "Las imágenes se detectarán y se mostrarán junto con otros archivos multimedia.", "EnableStreamLooping": "Bucle automático de las emisiones en directo", "EnableStreamLoopingHelp": "Habilite esto si las emisiones en directo sólo contienen unos pocos segundos de datos y necesitan ser solicitados continuamente.", - "EnableThemeVideos": "Vídeos temáticos", "Ended": "Finalizado", "EndsAtValue": "Termina a las {0}", "Episodes": "Episodios", @@ -203,11 +194,9 @@ "HeaderActiveDevices": "Dispositivos activos", "HeaderActiveRecordings": "Grabaciones activas", "HeaderActivity": "Actividad", - "HeaderAddScheduledTaskTrigger": "Agregar Activador", "HeaderAddToCollection": "Agregar a la colección", "HeaderAddToPlaylist": "Añadir a la lista de reproducción", "HeaderAddUpdateImage": "Añadir/Actualizar imagen", - "HeaderAddUser": "Agregar usuario", "HeaderAdditionalParts": "Partes adicionales", "HeaderAdmin": "Administrador", "HeaderAlert": "Alerta", @@ -218,11 +207,9 @@ "HeaderAudioBooks": "Audiolibros", "HeaderAudioSettings": "Ajustes de audio", "HeaderBlockItemsWithNoRating": "Bloquear artículos sin valoraciones o si son desconocidas:", - "HeaderBooks": "Libros", "HeaderCancelRecording": "Cancelar grabación", "HeaderCancelSeries": "Cancelar series", "HeaderCastAndCrew": "Reparto y equipo", - "HeaderCastCrew": "Reparto y equipo técnico", "HeaderChannelAccess": "Acceso a los canales", "HeaderChapterImages": "Imágenes de capítulos", "HeaderCodecProfile": "Perfil de códec", @@ -256,13 +243,11 @@ "HeaderEditImages": "Editar imágenes", "HeaderEnabledFields": "Campos activados", "HeaderEnabledFieldsHelp": "Desmarca un campo para bloquearlo y evitar que se cambie su contenido.", - "HeaderEpisodes": "Episodios", "HeaderExternalIds": "IDs externos:", "HeaderFeatureAccess": "Permisos de acceso", "HeaderFetchImages": "Buscar imágenes:", "HeaderFetcherSettings": "Ajustes del capturador", "HeaderForKids": "Para niños", - "HeaderForgotPassword": "Contraseña olvidada", "HeaderFrequentlyPlayed": "Reproducido frecuentemente", "HeaderGuideProviders": "Proveedores de guías", "HeaderHttpHeaders": "Cabeceras HTTP", @@ -291,7 +276,6 @@ "HeaderLoginFailure": "Fallo de inicio de sesión", "HeaderMedia": "Medios", "HeaderMediaFolders": "Carpetas de medios", - "HeaderMediaInfo": "Información multimedia", "HeaderMetadataSettings": "Ajustes de etiquetas", "HeaderMoreLikeThis": "Más como este", "HeaderMusicVideos": "Vídeos musicales", @@ -442,7 +426,6 @@ "LabelCustomCertificatePathHelp": "Ruta a un archivo PKCS # 12 que contiene un certificado y una clave privada para habilitar el soporte de TLS en un dominio personalizado.", "LabelCustomCss": "CSS personalizado:", "LabelCustomCssHelp": "Aplicar su propio CSS personalizado a la interfaz de la web.", - "LabelCustomDeviceDisplayName": "Nombre para mostrar:", "LabelCustomDeviceDisplayNameHelp": "Proporcione un nombre para mostrar o déjelo vacío para usar el nombre proporcionado por el dispositivo.", "LabelCustomRating": "Valoración pesonalizada:", "LabelDateAdded": "Fecha de añadido:", @@ -455,7 +438,6 @@ "LabelDeviceDescription": "Descripción del dispositivo", "LabelDidlMode": "Modo DIDL:", "LabelDiscNumber": "Número de disco:", - "LabelDisplayMissingEpisodesWithinSeasons": "Mostar episodios no disponibles en temporadas", "LabelDisplayMode": "Modo de visualización:", "LabelDisplayName": "Mostrar nombre:", "LabelDisplayOrder": "Mostrar orden:", @@ -607,7 +589,6 @@ "LabelPostProcessorArguments": "Argumentos de línea de comandos posprocesador:", "LabelPostProcessorArgumentsHelp": "Utilice {path} como ruta del archivo de grabación.", "LabelPreferredDisplayLanguage": "Idioma preferido visualizado:", - "LabelPreferredDisplayLanguageHelp": "La traducción de Jellyfin es un proyecto en marcha.", "LabelPreferredSubtitleLanguage": "Idioma de subtítulos preferido:", "LabelProfileAudioCodecs": "Códecs de audio:", "LabelProfileCodecs": "Códecs:", @@ -673,12 +654,9 @@ "LabelTimeLimitHours": "Límite de tiempo (horas):", "LabelTitle": "Título:", "LabelTrackNumber": "Número de pista:", - "LabelTranscodingAudioCodec": "Códec de audio:", - "LabelTranscodingContainer": "Contenedor:", "LabelTranscodingTempPathHelp": "Establece la carpeta que se usará para almacenar los archivos temporales de las conversiones. Déjalo en blanco para usar la ruta por defecto.", "LabelTranscodingThreadCount": "Núcleos a utilizar durante la conversión:", "LabelTranscodingThreadCountHelp": "Selecciona el número de núcleos a utilizar para la conversión. A menos núcleos, menor será el uso del procesador, pero puede que la conversión no vaya lo suficientemente rápido para una reproducción fluida.", - "LabelTranscodingVideoCodec": "Códec de video:", "LabelTriggerType": "Tipo de evento:", "LabelTunerIpAddress": "IP del sintonizador:", "LabelTunerType": "Tipo de sintonizador:", @@ -779,7 +757,6 @@ "MessagePluginConfigurationRequiresLocalAccess": "Para configurar este complemento inicia sesión en tu servidor local directamente.", "MessagePluginInstallDisclaimer": "Las extensiones creadas por los miembros de la comunidad de Jellyfin son una buena forma de mejorar tu experiencia con características adicionales y otros beneficios. Antes de instalarlos considera los efectos que pueden tener en tu servidor Jellyfin, como escaneos de la biblioteca más largos, procesado en segundo plano adicional y una reducción de la estabilidad del sistema.", "MessageReenableUser": "Mira abajo para reactivarlo", - "MessageSettingsSaved": "Ajustes guardados.", "MessageTheFollowingLocationWillBeRemovedFromLibrary": "Se eliminarán las siguientes ubicaciones de medios de tu biblioteca:", "MessageUnableToConnectToServer": "No podemos conectar con el servidor seleccionado ahora mismo. Por favor, asegúrate de que esta funcionando e inténtalo otra vez.", "MessageUnsetContentHelp": "El contenido se mostrará como carpetas planas. Para tener mejores resultados utiliza el gestor de metadatos para establecer los tipos de contenidos de las sub-carpetas.", @@ -1053,16 +1030,13 @@ "SystemDlnaProfilesHelp": "El perfil del sistema es solo lectura. Cambios al perfil del sistema seran guardados en un perfil nuevo modificado.", "TabAccess": "Acceso", "TabAdvanced": "Avanzado", - "TabAlbumArtists": "Artistas de los álbumes", "TabCatalog": "Catálogo", "TabCodecs": "Códecs", "TabContainers": "Contenedores", "TabDashboard": "Panel de control", "TabDirectPlay": "Reproducción directa", - "TabEpisodes": "Episodios", "TabLatest": "Novedades", "TabMusic": "Música", - "TabMusicVideos": "Videos musicales", "TabMyPlugins": "Mis extensiones", "TabNetworks": "Cadenas", "TabNfoSettings": "Ajustes de NFO", @@ -1072,7 +1046,6 @@ "TabProfile": "Perfil", "TabProfiles": "Perfiles", "TabResponses": "Respuestas", - "TabResumeSettings": "Reanudación", "TabScheduledTasks": "Tareas programadas", "TabServer": "Servidor", "TabSettings": "Opciones", @@ -1175,7 +1148,6 @@ "EnableColorCodedBackgrounds": "Fondos con código de colores", "EnableExternalVideoPlayersHelp": "Se mostrará un menú para reproductor externo cuando comience la reproducción del vídeo.", "EnableNextVideoInfoOverlayHelp": "Al finalizar un vídeo, mostrar información sobre el siguiente de la lista de reproducción actual.", - "EnableThemeSongs": "Canciones temáticas", "EnableThemeSongsHelp": "Reproducir las canciones temáticas de fondo mientras se explora la biblioteca.", "EnableThemeVideosHelp": "Reproducir vídeos temáticos de fondo mientras se explora la biblioteca.", "ErrorDeletingItem": "Se ha producido un error eliminando el elemento del servidor Jellyfin. Por favor, comprueba que el servidor Jellyfin tiene permisos de escritura y prueba de nuevo.", @@ -1200,7 +1172,6 @@ "HeaderVideoType": "Tipo de vídeo", "Home": "Inicio", "Horizontal": "Horizontal", - "LabelAudio": "Audio", "LabelBurnSubtitles": "Incrustar subtítulos:", "LabelDateTimeLocale": "Fecha y hora local:", "LabelDefaultScreen": "Pantalla por defecto:", @@ -1215,7 +1186,6 @@ "LabelSkipForwardLength": "Tiempo de avance:", "LabelSortBy": "Ordenar por:", "LabelSortOrder": "Orden:", - "LabelSubtitles": "Subtítulos", "LabelTVHomeScreen": "Modo televisión en pantalla de inicio:", "LabelVersion": "Versión:", "LabelVideo": "Vídeo", @@ -1238,7 +1208,6 @@ "Off": "Apagado", "Option3D": "3D", "OptionAuto": "Automático", - "OptionAutomatic": "Automático", "OptionBanner": "Cabecera", "OptionBlockTrailers": "Tráilers", "OptionBluray": "Blu-ray", @@ -1255,7 +1224,6 @@ "HeaderFavoriteArtists": "Artistas favoritos", "HeaderFavoriteSongs": "Canciones favoritas", "HeaderFavoriteVideos": "Vídeos favoritos", - "HeaderHome": "Inicio", "LabelAuthProvider": "Proveedor de autenticación:", "LabelPasswordResetProvider": "Proveedor de restablecimiento de contraseña:", "LabelServerName": "Nombre del servidor:", @@ -1310,10 +1278,8 @@ "SubtitleAppearanceSettingsDisclaimer": "Estos ajustes no se aplicarán a los subtítulos gráficos (PGS, DVD, etc.), ni a ASS/SSA que tengan incluidos sus propios estilos.", "SubtitleOffset": "Desplazamiento de subtítulos", "TV": "Televisión", - "TabInfo": "Info", "TabLogs": "Registros", "TabPlugins": "Extensiones", - "TabTrailers": "Tráilers", "TagsValue": "Etiquetas: {0}", "ThemeSongs": "Banda sonora", "Trailers": "Tráilers", diff --git a/src/strings/es_419.json b/src/strings/es_419.json index 4014556e9e..5197f3d813 100644 --- a/src/strings/es_419.json +++ b/src/strings/es_419.json @@ -38,7 +38,6 @@ "Absolute": "Absoluto", "YadifBob": "YADIF Bob", "Trailers": "Trailers", - "TabTrailers": "Trailers", "OptionThumbCard": "Miniatura de imagen", "OptionResElement": "elemento reanudable", "OptionCaptionInfoExSamsung": "CaptionInfoEx (Samsung)", @@ -133,7 +132,6 @@ "TabSettings": "Configuración", "TabServer": "Servidor", "TabScheduledTasks": "Tareas programadas", - "TabResumeSettings": "Reanudar", "TabResponses": "Respuestas", "TabProfiles": "Perfiles", "TabProfile": "Perfil", @@ -145,11 +143,8 @@ "TabNetworking": "Redes", "TabNetworks": "Cadenas", "TabMyPlugins": "Mis complementos", - "TabMusicVideos": "Videos musicales", "TabMusic": "Música", "TabLogs": "Registros", - "TabInfo": "Información", - "TabEpisodes": "Episodios", "TabDirectPlay": "Reproducción directa", "TabDashboard": "Panel de control", "TabContainers": "Contenedores", @@ -239,7 +234,6 @@ "OptionBanner": "Banner", "OptionAutomaticallyGroupSeriesHelp": "Series que estén repartidas en múltiples carpetas dentro de esta biblioteca serán automáticamente fusionadas en una sola serie.", "OptionAutomaticallyGroupSeries": "Fusionar automáticamente series esparcidas a través de múltiples carpetas", - "OptionAutomatic": "Automático", "OptionAuto": "Automático", "OptionAscending": "Ascendente", "OptionArtist": "Artista", @@ -328,7 +322,6 @@ "MessageUnsetContentHelp": "El contenido será mostrado como carpetas simples. Para mejores resultados utiliza el administrador de metadatos para establecer los tipos de contenido para las subcarpetas.", "MessageUnableToConnectToServer": "No podemos conectarnos al servidor seleccionado en este momento. Por favor, asegúrate de que está funcionando e inténtalo de nuevo.", "MessageTheFollowingLocationWillBeRemovedFromLibrary": "Las siguientes ubicaciones de medios se removerán de tu biblioteca:", - "MessageSettingsSaved": "Configuraciones guardadas.", "MessageReenableUser": "Ver abajo para volver a habilitar", "MessagePluginInstallDisclaimer": "Los complementos desarrollados por miembros de la comunidad son una gran forma de mejorar tu experiencia con características y beneficios adicionales. Antes de instalar, por favor, conoce el impacto que pueden ocasionar en tu servidor, tales como escaneo más largo de bibliotecas, procesamiento en segundo plano adicional y reducción de la estabilidad del sistema.", "MessagePluginConfigurationRequiresLocalAccess": "Para configurar este complemento por favor, inicia sesión en tu servidor local directamente.", @@ -402,7 +395,6 @@ "LabelTunerType": "Tipo de sintonizador:", "LabelTunerIpAddress": "Dirección IP del sintonizador:", "LabelTriggerType": "Tipo de disparador:", - "LabelTranscodingVideoCodec": "Códec de video:", "LabelTranscodingThreadCountHelp": "Selecciona el número máximo de hilos a utilizar al transcodificar. Reducir el número de hilos reducirá el uso de la CPU, pero es posible que no se convierta lo suficientemente rápido como para que la experiencia de reproducción sea fluida.", "LabelTranscodingThreadCount": "Conteo de hilos de la transcodificación:", "LabelTranscodingProgress": "Progreso de la transcodificación:", @@ -410,8 +402,6 @@ "LabelTranscodes": "Transcodificaciones:", "LabelTranscodingTempPathHelp": "Especifica una ruta personalizada para los archivos de transcodificación servidos a los clientes. Deja en blanco para utilizar el predeterminado del servidor.", "LabelTranscodePath": "Ruta de transcodificación:", - "LabelTranscodingContainer": "Contenedor:", - "LabelTranscodingAudioCodec": "Códec de audio:", "LabelTrackNumber": "Número de pista:", "LabelTitle": "Título:", "LabelTimeLimitHours": "Límite de tiempo (horas):", @@ -436,7 +426,6 @@ "MillisecondsUnit": "ms", "LabelSyncPlayTimeOffset": "Tiempo compensado respecto al servidor:", "LabelSupportedMediaTypes": "Tipos de medios soportados:", - "LabelSubtitles": "Subtítulos", "LabelSubtitlePlaybackMode": "Modo de subtítulo:", "LabelSubtitleFormatHelp": "Ejemplo: srt", "LabelSubtitleDownloaders": "Recolectores de subtítulos:", @@ -669,7 +658,6 @@ "LabelProfileCodecs": "Códecs:", "LabelProfileAudioCodecs": "Códecs de audio:", "LabelPreferredSubtitleLanguage": "Idioma preferido para los subtítulos:", - "LabelPreferredDisplayLanguageHelp": "La traducción de Jellyfin es un proyecto en curso.", "LabelPreferredDisplayLanguage": "Idioma de pantalla preferido:", "LabelPostProcessorArgumentsHelp": "Usar {path} como la ruta del archivo grabado.", "LabelPostProcessorArguments": "Argumentos de la línea de comandos del post-procesador:", @@ -802,7 +790,6 @@ "LabelDisplayOrder": "Orden para mostrar:", "LabelDisplayName": "Nombre a mostrar:", "LabelDisplayMode": "Modo de pantalla:", - "LabelDisplayMissingEpisodesWithinSeasons": "Mostrar episodios faltantes en las temporadas", "LabelDisplayLanguageHelp": "La traducción de Jellyfin es un proyecto en curso.", "LabelDisplayLanguage": "Idioma de pantalla:", "LabelDiscNumber": "Número de disco:", @@ -820,7 +807,6 @@ "LabelDateAdded": "Fecha de adición:", "LabelCustomRating": "Calificación personalizada:", "LabelCustomDeviceDisplayNameHelp": "Proporcione un nombre personalizado para mostrar o déjalo vacío para usar el nombre reportado por el dispositivo.", - "LabelCustomDeviceDisplayName": "Nombre a mostrar:", "LabelCustomCssHelp": "Aplica tu propio estilo personalizado a la interfaz web.", "LabelCustomCss": "CSS personalizado:", "LabelCustomCertificatePathHelp": "Ruta a un archivo PKCS #12 que contiene un certificado y una clave privada para habilitar el soporte TLS en un dominio personalizado.", @@ -835,7 +821,6 @@ "LabelChannels": "Canales:", "LabelCertificatePasswordHelp": "Si tu certificado requiere una contraseña, por favor, introdúcela aquí.", "LabelCertificatePassword": "Contraseña del certificado:", - "TabAlbumArtists": "Artistas del álbum", "TabAdvanced": "Avanzado", "TabAccess": "Acceso", "TV": "TV", @@ -918,7 +903,6 @@ "LabelAudioChannels": "Canales de audio:", "LabelAudioBitrate": "Velocidad de bits de audio:", "LabelAudioBitDepth": "Profundidad de bits de audio:", - "LabelAudio": "Audio", "LabelArtistsHelp": "Separar múltiples artistas por punto y coma.", "LabelArtists": "Artistas:", "LabelAppNameExample": "Ejemplo: Sickbeard, Sonarr", @@ -1048,7 +1032,6 @@ "HeaderMusicQuality": "Calidad de la música", "HeaderMoreLikeThis": "Más como esto", "HeaderMetadataSettings": "Configuración de metadatos", - "HeaderMediaInfo": "Info del medio", "HeaderMediaFolders": "Carpetas de medios", "HeaderMedia": "Medios", "HeaderLoginFailure": "Falló el inicio de sesión", @@ -1076,10 +1059,8 @@ "HeaderIdentification": "Identificación", "HeaderHttpsSettings": "Opciones HTTPS", "HeaderHttpHeaders": "Encabezados HTTP", - "HeaderHome": "Inicio", "HeaderGuideProviders": "Proveedores de Guías de TV", "HeaderFrequentlyPlayed": "Reproducido frecuentemente", - "HeaderForgotPassword": "Olvidé mi contraseña", "HeaderForKids": "Para niños", "HeaderFetcherSettings": "Configuración del recolector", "HeaderFetchImages": "Obtener imágenes:", @@ -1129,7 +1110,6 @@ "HeaderFavoriteBooks": "Libros favoritos", "HeaderExternalIds": "IDs externos:", "HeaderError": "Error", - "HeaderEpisodes": "Episodios", "HeaderEnabledFieldsHelp": "Desmarca un campo para bloquearlo y prevenir que sus datos sean cambiados.", "HeaderEnabledFields": "Campos habilitados", "HeaderEditImages": "Editar imágenes", @@ -1163,12 +1143,10 @@ "HeaderCodecProfile": "Perfil de códec", "HeaderChapterImages": "Imágenes de los capítulos", "HeaderChannelAccess": "Acceso a los canales", - "HeaderCastCrew": "Reparto y equipo", "HeaderCastAndCrew": "Reparto y equipo", "HeaderCancelSeries": "Cancelar serie", "HeaderCancelRecording": "Cancelar grabación", "HeaderBranding": "Establecer marca", - "HeaderBooks": "Libros", "HeaderBlockItemsWithNoRating": "Bloquear elementos sin clasificación o con información de clasificación desconocida:", "HeaderAudioSettings": "Configuración de audio", "HeaderAudioBooks": "Audiolibros", @@ -1182,11 +1160,9 @@ "HeaderAlert": "Alerta", "HeaderAdmin": "Administrador", "HeaderAdditionalParts": "Partes adicionales", - "HeaderAddUser": "Agregar usuario", "HeaderAddUpdateImage": "Agregar/Actualizar Imagen", "HeaderAddToPlaylist": "Agregar a lista de reproducción", "HeaderAddToCollection": "Agregar a colección", - "HeaderAddScheduledTaskTrigger": "Agregar disparador", "HeaderActivity": "Actividad", "HeaderActiveRecordings": "Grabaciones activas", "HeaderActiveDevices": "Dispositivos activos", @@ -1244,9 +1220,7 @@ "EnableDetailsBannerHelp": "Mostrar una imagen banner en la parte superior de la página de detalles del elemento.", "EnableDetailsBanner": "Banner de detalles", "EnableThemeVideosHelp": "Reproducir videos temáticos en el fondo mientras se navega por la biblioteca.", - "EnableThemeVideos": "Videos temáticos", "EnableThemeSongsHelp": "Reproducir canciones temáticas en el fondo mientras se navega por la biblioteca.", - "EnableThemeSongs": "Canciones temáticas", "EnableStreamLoopingHelp": "Habilita esta opción si las transmisiones en vivo contienen solo unos pocos segundos de datos y necesitan ser solicitadas continuamente. Habilitar esto cuando no es requerido puede causar problemas.", "EnableStreamLooping": "Repetir automáticamente las transmisiones en vivo", "EnablePhotosHelp": "Las imágenes serán detectadas y mostradas junto con otros archivos multimedia.", @@ -1342,7 +1316,6 @@ "ButtonUninstall": "Desinstalar", "ButtonTrailer": "Trailer", "ButtonTogglePlaylist": "Lista de reproducción", - "ButtonSubtitles": "Subtítulos", "ButtonSubmit": "Enviar", "ButtonSplit": "Dividir", "ButtonStop": "Detener", @@ -1364,31 +1337,24 @@ "ButtonRename": "Renombrar", "ButtonRemove": "Remover", "ButtonRefreshGuideData": "Actualizar datos de la guía", - "ButtonRefresh": "Actualizar", "ButtonQuickStartGuide": "Guía de inicio rápido", "ButtonProfile": "Perfil", "ButtonPreviousTrack": "Pista anterior", - "ButtonPlay": "Reproducir", "ButtonPause": "Pausar", "ButtonParentalControl": "Control parental", "ButtonOpen": "Abrir", "ButtonOk": "OK", - "ButtonOff": "Apagar", "ButtonNextTrack": "Pista siguiente", "ButtonNetwork": "Red", "ButtonMore": "Más", "ButtonManualLogin": "Inicio de sesión manual", "ButtonLibraryAccess": "Acceso a biblioteca(s)", "ButtonInfo": "Info", - "ButtonHome": "Inicio", "ButtonGuide": "Guía", "ButtonGotIt": "Hecho", "ButtonFullscreen": "Pantalla completa", "ButtonForgotPassword": "Olvidé mi contraseña", - "ButtonFilter": "Filtro", "ButtonEditOtherUserPreferences": "Editar el perfil, la imagen y las preferencias personales de este usuario.", - "ButtonEditImages": "Editar imágenes", - "ButtonEdit": "Editar", "ButtonChangeServer": "Cambiar servidor", "ButtonCancel": "Cancelar", "ButtonBack": "Atrás", diff --git a/src/strings/fa.json b/src/strings/fa.json index 61c2f8f26c..c68bab1124 100644 --- a/src/strings/fa.json +++ b/src/strings/fa.json @@ -7,9 +7,7 @@ "Browse": "مرور کردن", "ButtonAddUser": "افزودن کاربر", "ButtonCancel": "لغو کردن", - "ButtonFilter": "فیلتر", "ButtonOk": "خوب", - "ButtonPlay": "پخش", "ButtonQuickStartGuide": "راهنمای شروع سریع", "ButtonResetPassword": "تنظیم مجدد رمز", "ButtonSignOut": "Sign out", @@ -20,7 +18,6 @@ "FolderTypeMusic": "موسیقی‌ها", "FolderTypeMusicVideos": "موزیک ویدیوها", "FolderTypeTvShows": "سریال‌های تلویزیونی", - "HeaderAddUser": "اضافه کردن کاربر", "HeaderContinueWatching": "ادامه تماشا", "HeaderCustomDlnaProfiles": "پروفایل های سفارشی", "HeaderDeviceAccess": "دسترسی دستگاه", @@ -44,7 +41,6 @@ "LabelCurrentPassword": "رمز فعلی:", "LabelCustomCertificatePath": "مسیر اختصاصی گواهینامه SSL:", "LabelCustomCertificatePathHelp": "پچ به فایل PKCS #12 حاوی یک گواهینامه و کلید خصوصی است تا پشتیبانی از TLS را در یک دامنه شخصی فعال کند.", - "LabelDisplayMissingEpisodesWithinSeasons": "نمایش قسمت های ناموجود در بین فصل ها", "LabelFinish": "پایان", "LabelLanguage": "زبان:", "LabelMaxParentalRating": "حداکثر امتیاز سنی مجاز والدین:", @@ -79,10 +75,7 @@ "ShowAdvancedSettings": "نمایش تنظیمات پیشرفته", "TabAccess": "دسترسی", "TabAdvanced": "پیشرفته", - "TabAlbumArtists": "هنرمندان آلبوم", - "TabEpisodes": "قسمت ها", "TabLatest": "جدیدترین‌ها", - "TabMusicVideos": "موزیک ویدیوها", "TabNetworks": "شبکه ها", "TabNotifications": "اعلان ها", "TabProfile": "پروفایل", @@ -134,26 +127,21 @@ "ButtonRename": "تغییر نام", "ButtonRemove": "حذف", "ButtonRefreshGuideData": "به‌روز‌رسانی داده‌ی راهنما", - "ButtonRefresh": "به‌روز‌رسانی", "ButtonProfile": "نمایه", "ButtonNextTrack": "ترانه پسین", "ButtonPreviousTrack": "ترانه پیشین", "ButtonPause": "مکث", "ButtonParentalControl": "رتبه بندی والدین", "ButtonOpen": "باز", - "ButtonOff": "خاموش", "ButtonNetwork": "شبکه", "ButtonMore": "بیشتر", "ButtonManualLogin": "ورود دستی", "ButtonLibraryAccess": "دسترسی به کتابخانه", "ButtonInfo": "اطلاعات", - "ButtonHome": "خانه", "ButtonGuide": "راهنما", "ButtonGotIt": "متوجه شدم", "ButtonFullscreen": "تمام صفحه", "ButtonForgotPassword": "فراموشی گذرواژه", - "ButtonEditImages": "ویرایش عکس‌ها", - "ButtonEdit": "ویرایش", "ButtonChangeServer": "تغییر سرور", "ButtonBack": "بازگشت", "ButtonArrowRight": "راست", @@ -196,8 +184,6 @@ "Episodes": "قسمت‌ها", "EndsAtValue": "تمام شده در {0}", "Ended": "تمام شده", - "EnableThemeVideos": "تم فیلم‌ها", - "EnableThemeSongs": "آهنگ‌های تم", "EnableStreamLooping": "چرخش خودکار پخش‌های زنده", "EnablePhotos": "نمایش عکس‌ها", "EnableNextVideoInfoOverlay": "نمایش اطلاعات ودیوی بعدی حین پخش ویدیو", @@ -266,7 +252,6 @@ "ButtonWebsite": "وبسایت", "ButtonUninstall": "حذف نصب", "ButtonTrailer": "تریلر", - "ButtonSubtitles": "زیرنویس‌ها", "ButtonSubmit": "تایید", "ButtonSplit": "جدا کردن", "ButtonStop": "توقف", @@ -305,7 +290,6 @@ "HeaderMusicQuality": "کیفیت آهنگ", "HeaderMoreLikeThis": "موارد مشابه با این", "HeaderMetadataSettings": "تنظیمات ابرداده", - "HeaderMediaInfo": "اطلاعات رسانه", "HeaderMediaFolders": "پوشه‌های رسانه", "HeaderMedia": "رسانه", "HeaderLoginFailure": "ورود ناموفق", @@ -328,10 +312,8 @@ "HeaderIdentificationCriteriaHelp": "حداقل یک مورد تعیین هویت وارد کنید.", "HeaderIdentification": "تعیین هویت", "HeaderHttpHeaders": "سرفصل‌های HTTP", - "HeaderHome": "خانه", "HeaderGuideProviders": "ارائه دهنده داده راهنمای تلویزیونی", "HeaderFrequentlyPlayed": "اغلب پخش شده", - "HeaderForgotPassword": "فراموشی گذرواژه", "HeaderForKids": "برای کودکان", "HeaderFetchImages": "دریافت عکس‌ها:", "HeaderFeatureAccess": "دسترسی‌های برجسته", @@ -341,7 +323,6 @@ "HeaderFavoriteBooks": "کتاب‌های مورد علاقه", "HeaderExternalIds": "ID های خارجی:", "HeaderError": "خطا", - "HeaderEpisodes": "قسمت‌ها", "HeaderEnabledFieldsHelp": "یک فیلد را برای جلوگیری از تغییر در داده‌ی آن علامت بزنید تا قفل بشود.", "HeaderEnabledFields": "فیلد‌های فعال شده", "HeaderEditImages": "ویرایش عکس‌ها", @@ -362,11 +343,9 @@ "HeaderCodecProfile": "نمایه کدک", "HeaderChapterImages": "عکس‌های سکانس", "HeaderChannelAccess": "دسترسی به کانال", - "HeaderCastCrew": "بازیگران و کارکنان", "HeaderCastAndCrew": "بازیگران و کارکنان", "HeaderCancelSeries": "لغو سریال", "HeaderCancelRecording": "لغو ضبط", - "HeaderBooks": "کتاب‌ها", "HeaderBlockItemsWithNoRating": "موارد مسدود شده با نقص یا عدم وجود اطلاعات امتیاز:", "LabelSkipIfAudioTrackPresentHelp": "این گزینه را عدم انتخاب کنید تا اطمینان حاصل کنید که همه ویدیوها فارغ از زبان صوت، زیرنویس دارند.", "LabelSkipIfAudioTrackPresent": "اگر صدای پیش‌فرض با زبان دانلودی یکسان است پرش کن", @@ -387,7 +366,6 @@ "ButtonAudioTracks": "آهنگ‌ها", "AlbumArtist": "هنرمند آلبوم", "Album": "آلبوم", - "HeaderAddScheduledTaskTrigger": "افزودن فعال‌ساز", "HeaderActivity": "فعالیت‌ها", "HeaderActiveRecordings": "ضبط‌های فعال", "HeaderActiveDevices": "دستگاه‌های فعال", @@ -517,7 +495,6 @@ "LabelImportOnlyFavoriteChannels": "محدود کردن کانال‌هایی که به عنوان مورد علاقه انتخاب شده‌اند", "LabelDateAdded": "تاریخ اضافه شده:", "LabelCustomRating": "امتیازدهی سفارشی:", - "LabelCustomDeviceDisplayName": "نام نمایشی:", "LabelCustomCssHelp": "ظاهر سفارشی مورد نظر خود را در رابط وب اعمال کنید.", "LabelCustomCss": "CSS سفارشی:", "LabelCriticRating": "امتیاز منتقدان:", @@ -529,7 +506,6 @@ "LabelHomeNetworkQuality": "کیفیت شبکه خانگی:", "LabelHardwareAccelerationTypeHelp": "تسریع کننده سخت افزاری نیاز به پیکربندی اضافی دارد.", "LabelSupportedMediaTypes": "نوع‌ رسانه‌های پشتیبانی شده:", - "LabelSubtitles": "زیرنویس‌ها", "LabelSubtitlePlaybackMode": "حالت زیرنویس:", "LabelSubtitleFormatHelp": "مثال: srt", "LabelSubtitleDownloaders": "دانلود کننده زیرنویس:", @@ -582,14 +558,12 @@ "OptionParentalRating": "رتبه بندی والدین", "OptionOnInterval": "در یک فاصله", "BookLibraryHelp": "کتاب‌های صوتی و متنی پشتیبانی می‌شوند. {0} راهنمای نامگذاری کتاب {1} را مرور کنید.", - "TabInfo": "اطلاعات", "TabDirectPlay": "پخش مستقیم", "TabDashboard": "داشبورد", "TabCodecs": "کدک‌ها", "TabCatalog": "فهرست", "TV": "تلویزیون", "Sunday": "یکشنبه", - "TabTrailers": "تریلرها", "Suggestions": "پیشنهادها", "Subtitles": "زیرنویس‌ها", "Studios": "استودیو‌ها", @@ -608,7 +582,6 @@ "TabSettings": "تنظیمات", "TabServer": "سرور", "TabScheduledTasks": "وظایف زمان بندی شده", - "TabResumeSettings": "ادامه", "TabResponses": "پاسخ‌ها", "TabPlugins": "افزونه‌ها", "TabParentalControl": "رتبه بندی والدین", @@ -768,7 +741,6 @@ "HeaderSelectTranscodingPath": "Select Transcoding Temporary Path", "HeaderSelectTranscodingPathHelp": "Browse or enter the path to use for transcoding temporary files. The folder must be writeable.", "LabelArtistsHelp": "Separate multiple using ;", - "LabelAudio": "Audio", "LabelAudioBitDepth": "Audio bit depth:", "LabelAudioBitrate": "Audio bitrate:", "LabelAudioChannels": "Audio channels:", @@ -926,7 +898,6 @@ "OptionAllowVideoPlaybackTranscoding": "Allow video playback that requires transcoding", "OptionArtist": "Artist", "OptionAuto": "Auto", - "OptionAutomatic": "Auto", "OptionAutomaticallyGroupSeries": "Automatically merge series that are spread across multiple folders", "OptionAutomaticallyGroupSeriesHelp": "If enabled, series that are spread across multiple folders within this library will be automatically merged into a single series.", "OptionBanner": "Banner", @@ -1142,7 +1113,6 @@ "LabelPostProcessorArguments": "Post-processor command line arguments:", "LabelPostProcessorArgumentsHelp": "Use {path} as the path to the recording file.", "LabelPreferredDisplayLanguage": "Preferred display language:", - "LabelPreferredDisplayLanguageHelp": "Translating Jellyfin is an ongoing project.", "LabelPreferredSubtitleLanguage": "Preferred subtitle language:", "LabelProfileAudioCodecs": "Audio codecs:", "LabelProfileCodecs": "Codecs:", @@ -1227,8 +1197,6 @@ "LabelTime": "Time:", "LabelTitle": "Title:", "LabelTrackNumber": "Track number:", - "LabelTranscodingAudioCodec": "Audio codec:", - "LabelTranscodingContainer": "Container:", "LabelTranscodePath": "Transcode path:", "LabelTranscodingTempPathHelp": "Specify a custom path for the transcode files served to clients. Leave blank to use the server default.", "LabelTranscodes": "Transcodes:", @@ -1236,7 +1204,6 @@ "LabelTranscodingProgress": "Transcoding progress:", "LabelTranscodingThreadCount": "Transcoding thread count:", "LabelTranscodingThreadCountHelp": "Select the maximum number of threads to use when transcoding. Reducing the thread count will lower CPU usage but may not convert fast enough for a smooth playback experience.", - "LabelTranscodingVideoCodec": "Video codec:", "LabelTriggerType": "Trigger Type:", "LabelTunerIpAddress": "Tuner IP Address:", "LabelTunerType": "Tuner type:", @@ -1326,7 +1293,6 @@ "MessagePlayAccessRestricted": "Playback of this content is currently restricted. Please contact your server administrator for more information.", "MessagePluginInstallDisclaimer": "Plugins built by Jellyfin community members are a great way to enhance your Jellyfin experience with additional features and benefits. Before installing, please be aware of the effects they may have on your Jellyfin Server, such as longer library scans, additional background processing, and decreased system stability.", "MessageReenableUser": "See below to reenable", - "MessageSettingsSaved": "Settings saved.", "MessageTheFollowingLocationWillBeRemovedFromLibrary": "The following media locations will be removed from your library:", "MessageUnableToConnectToServer": "We're unable to connect to the selected server right now. Please ensure it is running and try again.", "MessageUnsetContentHelp": "Content will be displayed as plain folders. For best results use the metadata manager to set the content types of sub-folders.", diff --git a/src/strings/fi.json b/src/strings/fi.json index 7eddf8e17f..9481f59b4f 100644 --- a/src/strings/fi.json +++ b/src/strings/fi.json @@ -16,7 +16,6 @@ "LabelAudioLanguagePreference": "Äänen ensisijainen kieli:", "LabelCountry": "Maa:", "LabelCurrentPassword": "Tämän hetkinen salsana:", - "LabelDisplayMissingEpisodesWithinSeasons": "Näytä puuttuvat jaksot kausien sisällä", "LabelFinish": "Valmis", "LabelLanguage": "Kieli:", "LabelMaxParentalRating": "Suurin sallittu ikäraja:", @@ -101,32 +100,25 @@ "ButtonAudioTracks": "Ääniraidat", "ButtonBack": "Takaisin", "ButtonChangeServer": "Vaihda Palvelinta", - "ButtonEdit": "Muokkaa", - "ButtonEditImages": "Muokkaa kuvia", "ButtonEditOtherUserPreferences": "Muokkaa tämän käyttäjän profiilia, kuvaa ja henkilökohtaisia asetuksia.", - "ButtonFilter": "Suodata", "ButtonForgotPassword": "Unohtuiko salasana", "ButtonFullscreen": "Kokonäyttötila", "ButtonGotIt": "Selvä", "ButtonGuide": "Opas", - "ButtonHome": "Koti", "ButtonInfo": "Tiedot", "ButtonLibraryAccess": "Kiraston pääsy", "ButtonManualLogin": "Manuaalinen kirjautuminen", "ButtonMore": "Lisää", "ButtonNetwork": "Verkko", "ButtonNextTrack": "Seuraava raita", - "ButtonOff": "Pois päältä", "ButtonOk": "Ok", "ButtonOpen": "Avaa", "BurnSubtitlesHelp": "Määrittää mikäli palvelimen pitäisi polttaa tekstitykset suoraan videoon muunnoksen aikana riippuen tekstitysten formaatista. Tekstitysten polttamisen välttäminen parantaa palvelimen suorituskykyä. Valitse Automaattinen polttaaksesi sekä kuva- (esim. VOBSUB, PGS, SUB/IDX, jne.) että tekstipohjaiset (ASS/SSA) formaatit.", "ButtonParentalControl": "Lapsilukko", "ButtonPause": "Tauko", - "ButtonPlay": "Toista", "ButtonPreviousTrack": "Edellinen raita", "ButtonProfile": "Profiili", "ButtonQuickStartGuide": "Pikaopas", - "ButtonRefresh": "Päivitä", "ButtonRefreshGuideData": "Päivitä oppaan tiedot", "ButtonRemove": "Poista", "ButtonRename": "Nimeä uudelleen", @@ -145,7 +137,6 @@ "ButtonStart": "Käynnistä", "ButtonStop": "Pysäytä", "ButtonSubmit": "Lähetä", - "ButtonSubtitles": "Tekstitykset", "ButtonTrailer": "Traileri", "ButtonUninstall": "Poista asennus", "ButtonWebsite": "Nettisivusto", @@ -240,7 +231,6 @@ "EndsAtValue": "Päättyy {0}", "Ended": "Päättynyt", "EnableThemeSongsHelp": "Soita tunnussäveliä taustalla selatessasi kirjastoa.", - "EnableThemeSongs": "Tunnuslaulut", "EnableStreamLoopingHelp": "Laita tämä päälle, jos suoratoistot sisältävät vain muutaman sekuntin verran dataa jota tarvitsee pyytää jatkuvasti. Tämän päälle laittaminen ilman toiminnon tarvetta voi aiheuttaa ongelmia.", "EnablePhotosHelp": "Kuvat tunnistetaan ja näytetään muiden media-tiedostojen ohessa.", "EnablePhotos": "Näytä valokuvat", @@ -264,7 +254,6 @@ "ErrorAddingXmlTvFile": "XMLTV-tiedostoa käyttäessä tapahtui virhe. Varmista, että tiedosto on olemassa ja kokeile uudestaan.", "ErrorAddingTunerDevice": "Viritintä lisätessä ilmeni ongelma. Varmista, että se on kytketty oikein ja kokeile uudestaan.", "EnableThemeVideosHelp": "Soita tunnusvideoita taustalla, selatessasi kirjastoa.", - "EnableThemeVideos": "Tunnusvideot", "AlbumArtist": "Albumin Artisti", "Album": "Albumi", "Played": "Toistetut", @@ -382,10 +371,8 @@ "LabelDisplayMode": "Näyttötila:", "LabelDateTimeLocale": "Päivämäärä ja aika:", "LabelCustomRating": "Mukautettu luokitus:", - "LabelCustomDeviceDisplayName": "Näyttönimi:", "LabelCustomCss": "Mukautettu CSS:", "LabelCertificatePassword": "Sertifikaatin salasana:", - "LabelAudio": "Audio", "LabelArtistsHelp": "Erota useita käyttämällä ;", "LabelAppNameExample": "Esimerkiksi: Sickbeard, Sonarr", "LabelAppName": "Sovelluksen nimi", @@ -470,7 +457,6 @@ "OptionDateAdded": "Lisäyspäivä", "OptionDaily": "Päivittäinen", "OptionBluray": "Blu-ray", - "TabTrailers": "Trailerit", "OptionBlockTvShows": "TV-sarjat", "OptionBlockTrailers": "Trailerit", "OptionBlockMusic": "Musiikki", @@ -478,7 +464,6 @@ "HeaderMoreLikeThis": "Lisää tällaista", "HeaderMetadataSettings": "Metadata-asetukset", "MoreMediaInfo": "Mediainfo", - "HeaderMediaInfo": "Mediainfo", "HeaderMediaFolders": "Mediakansiot", "HeaderMedia": "Media", "HeaderLibraryFolders": "Kirjaston kansiot", @@ -564,7 +549,6 @@ "LabelTextBackgroundColor": "Tekstin taustaväri:", "LabelSupportedMediaTypes": "Tuetut mediatyypit:", "LabelTag": "Tunniste:", - "LabelSubtitles": "Tekstitykset", "LabelSubtitleFormatHelp": "Esimerkki: srt", "LabelStatus": "Status:", "LabelSource": "Lähde:", @@ -580,7 +564,6 @@ "LabelProtocolInfo": "Protokollan info:", "LabelProtocol": "Protokolla:", "LabelPreferredSubtitleLanguage": "Ensisijainen tekstityksen kieli:", - "LabelPreferredDisplayLanguageHelp": "Jellyfinin kääntäminen on käynnissä oleva projekti.", "LabelPlayerDimensions": "Soittimen mitat:", "LabelPlayer": "Soitin:", "LabelPlaylist": "Soittolista:", @@ -636,22 +619,17 @@ "TabSettings": "Asetukset", "TabServer": "Palvelin", "TabScheduledTasks": "Ajastetut tehtävät", - "TabResumeSettings": "Jatka", "TabResponses": "Vastaukset", "TabPlugins": "Liitännäiset", "TabNfoSettings": "NFO-asetukset", "TabNetworks": "Verkot", "TabMyPlugins": "Omat liittännäiseni", - "TabMusicVideos": "Musiikkivideot", "TabMusic": "Musiikki", "TabLogs": "Lokit", "TabLatest": "Uusimmat", - "TabInfo": "Tiedot", - "TabEpisodes": "Jaksot", "TabDirectPlay": "Suoratoisto", "TabDashboard": "Päänäkymä", "TabCatalog": "Luettelo", - "TabAlbumArtists": "Albumin artistit", "TabAdvanced": "Edistynyt", "TV": "TV", "Sunday": "Sunnuntai", @@ -703,7 +681,6 @@ "RecordingCancelled": "Tallennus peruttu.", "RecordSeries": "Tallenna sarja", "Record": "Tallenna", - "OptionAutomatic": "Auto", "OptionAuto": "Auto", "OptionAscending": "Nousevassa järjestyksessä", "OptionArtist": "Artisti", @@ -784,7 +761,6 @@ "MetadataManager": "Metadatan hallintatyökalu", "Metadata": "Metadata", "MessageYouHaveVersionInstalled": "Sinulla on versio {0} asennettuna.", - "MessageSettingsSaved": "Asetukset tallennettu.", "MessagePleaseWait": "Ole hyvä ja odota. Tämä voi kestää hetken.", "MessageNothingHere": "Täällä ei ole mitään.", "MessageNoPluginsInstalled": "Sinulla ei ole asennettuna yhtään liitännäistä.", @@ -863,10 +839,8 @@ "HeaderMusicQuality": "Musiikin laatu", "HeaderLibraries": "Kirjastot", "HeaderIdentification": "Tunnistautuminen", - "HeaderForgotPassword": "Unohtuiko salasana", "HeaderForKids": "Lapsille", "HeaderError": "Virhe", - "HeaderEpisodes": "Jaksot", "HeaderEditImages": "Muokkaa kuvia", "HeaderDevices": "Laitteet", "HeaderDeleteItems": "Poista valitut", @@ -878,12 +852,10 @@ "HeaderAudioSettings": "Ääniasetukset", "GroupBySeries": "Ryhmitä sarjan perusteella", "Fullscreen": "Kokonäyttötila", - "HeaderBooks": "Kirjat", "HeaderAudioBooks": "Äänikirjat", "HeaderApiKeys": "API-avaimet", "HeaderApiKey": "API-avain", "HeaderAdmin": "Ylläpitäjä", - "HeaderAddUser": "Lisää käyttäjä", "HeaderAddUpdateImage": "Lisää/Päivitä kuva", "HeaderAddToPlaylist": "Lisää soittolistaan", "HeaderAddToCollection": "Lisää kokoelmaan", @@ -1012,7 +984,6 @@ "LabelVideoBitrate": "Videon bitrate:", "LabelWeb": "Web:", "LabelVideoCodec": "Videon codec:", - "LabelTranscodingVideoCodec": "Video codec:", "LabelSkipIfGraphicalSubsPresent": "Ohita, jos video sisältää upotetut tekstitykset", "LabelInternetQuality": "Verkkoyhteyden laatu:", "LabelEmbedAlbumArtDidl": "Upota albumin kuvamateriaali Didl:iin", @@ -1066,8 +1037,6 @@ "LabelAudioChannels": "Audiokanavia:", "LabelAudioBitrate": "Audion bitrate:", "LabelAudioCodec": "Audio codec:", - "LabelTranscodingContainer": "Säiliö:", - "LabelTranscodingAudioCodec": "Audio codec:", "LabelSubtitleDownloaders": "Tekstitysten lataajat:", "LabelSpecialSeasonsDisplayName": "Erikoiskauden näyttönimi:", "LabelSortTitle": "Lajitteluotsikko:", @@ -1151,7 +1120,6 @@ "ErrorAddingListingsToSchedulesDirect": "Lineuppia Schedules Direct -käyttäjätunnuksellesi lisättäessä ilmeni virhe. Schedules Direct sallii vain rajallisen määrän lineuppeja yhdelle käyttäjätunnukselle. Mikäli haluat jatkaa, voit esimerkiksi kirjautua Schedules Direct -sivustolle ja poistaa muita listauksia käyttäjätunnukseltasi.", "EnableDecodingColorDepth10Vp9": "Salli 10-bittinen hardware dekoodaus (VP9)", "EnableDecodingColorDepth10Hevc": "Salli 10-bittinen hardware dekoodaus (HEVC)", - "HeaderCastCrew": "Näyttelijät ja henkilökunta", "HeaderCastAndCrew": "Näyttelijät ja henkilökunta", "HeaderCancelSeries": "Peruuta sarja", "HeaderCancelRecording": "Peruuta tallennus", @@ -1161,6 +1129,5 @@ "ApiKeysCaption": "Lista aktiivisista API-avaimista", "HeaderApiKeysHelp": "Ulkoiset sovellukset tarvitsevat API-avaimen voidakseen toimia Jellyfin -palvelimen kanssa. Avaimet myönnetään joko kirjautumalla sisään Jellyfin -käyttäjätunnuksella tai myöntämällä sellainen sovellukselle manuaalisesti.", "HeaderAdditionalParts": "Muut osat", - "HeaderAddScheduledTaskTrigger": "Lisää laukaisin", "HeaderActiveRecordings": "Käynnissä olevat nauhoitukset" } diff --git a/src/strings/fr-ca.json b/src/strings/fr-ca.json index 15973b5f36..09585df2bd 100644 --- a/src/strings/fr-ca.json +++ b/src/strings/fr-ca.json @@ -141,14 +141,10 @@ "ButtonAudioTracks": "Pistes Audio", "ButtonBack": "Retour arrière", "ButtonChangeServer": "Changer de serveur", - "ButtonEdit": "Modifier", - "ButtonEditImages": "Modifier les images", "ButtonEditOtherUserPreferences": "Modifier ce profil utilisateur, son avatar et ses préférences personnelles.", - "ButtonFilter": "Filtre", "ButtonForgotPassword": "Mot de passe oublié", "ButtonFullscreen": "Plein écran", "ButtonGuide": "Guide", - "ButtonHome": "Accueil", "ButtonInfo": "Informations", "ButtonLibraryAccess": "Accès à la médiathèque", "ButtonManualLogin": "Connexion manuelle", @@ -191,7 +187,6 @@ "ButtonWebsite": "Site web", "ButtonUninstall": "Désinstaller", "ButtonTogglePlaylist": "Liste de lecture", - "ButtonSubtitles": "Sous-titres", "ButtonSubmit": "Soumettre", "ButtonStop": "Arrêt", "ButtonStart": "Démarrer", @@ -209,10 +204,8 @@ "ButtonRename": "Renommer", "ButtonRemove": "Enlever", "ButtonRefreshGuideData": "Rafraîchir les données de guide", - "ButtonRefresh": "Rafraîchir", "ButtonProfile": "Profil", "ButtonPreviousTrack": "Piste précédente", - "ButtonPlay": "Lecture", "ButtonPause": "Pause", "ButtonParentalControl": "Contrôle parentale", "ButtonOpen": "Ouvrir", diff --git a/src/strings/fr.json b/src/strings/fr.json index 4bab5a6179..84f882d280 100644 --- a/src/strings/fr.json +++ b/src/strings/fr.json @@ -58,29 +58,22 @@ "ButtonBack": "Retour arrière", "ButtonCancel": "Annuler", "ButtonChangeServer": "Changer de serveur", - "ButtonEdit": "Modifier", - "ButtonEditImages": "Modifier les images", "ButtonEditOtherUserPreferences": "Modifier ce profil utilisateur, son avatar et ses préférences personnelles.", - "ButtonFilter": "Filtre", "ButtonForgotPassword": "Mot de passe oublié", "ButtonFullscreen": "Plein écran", "ButtonGotIt": "Compris", - "ButtonHome": "Accueil", "ButtonInfo": "Informations", "ButtonLibraryAccess": "Accès à la médiathèque", "ButtonManualLogin": "Connexion manuelle", "ButtonMore": "Plus", "ButtonNetwork": "Réseau", "ButtonNextTrack": "Piste suivante", - "ButtonOff": "Arrêt", "ButtonOk": "OK", "ButtonOpen": "Ouvrir", "ButtonParentalControl": "Contrôle parental", - "ButtonPlay": "Lire", "ButtonPreviousTrack": "Piste précédente", "ButtonProfile": "Profil", "ButtonQuickStartGuide": "Guide de démarrage rapide", - "ButtonRefresh": "Actualiser", "ButtonRefreshGuideData": "Actualiser les données du guide", "ButtonRemove": "Supprimer", "ButtonRename": "Renommer", @@ -101,7 +94,6 @@ "ButtonStart": "Commencer", "ButtonStop": "Arrêter", "ButtonSubmit": "Soumettre", - "ButtonSubtitles": "Sous-titres", "ButtonTrailer": "Bande-annonce", "ButtonUninstall": "Désinstaller", "ButtonWebsite": "Site Web", @@ -189,9 +181,7 @@ "EnablePhotosHelp": "Les images seront détectées et affichées avec les autres fichiers multimédia.", "EnableStreamLooping": "Reboucler les streaming en direct", "EnableStreamLoopingHelp": "Activez cette option si les streaming en direct ne contiennent que quelques secondes de données et doivent être redemandés continuellement. N'activez pas cette option sans raison car elle peut causer des problèmes.", - "EnableThemeSongs": "Thèmes musicaux", "EnableThemeSongsHelp": "Lire les thèmes musicaux en arrière-plan pendant la navigation dans la médiathèque.", - "EnableThemeVideos": "Thèmes vidéos", "EnableThemeVideosHelp": "Lire les thèmes vidéos en arrière-plan tout en parcourant la médiathèque.", "Ended": "Terminé", "EndsAtValue": "Se termine à {0}", @@ -243,11 +233,9 @@ "HeaderActiveDevices": "Appareils actifs", "HeaderActiveRecordings": "Enregistrements actifs", "HeaderActivity": "Activité", - "HeaderAddScheduledTaskTrigger": "Ajouter un déclencheur", "HeaderAddToCollection": "Ajouter à la collection", "HeaderAddToPlaylist": "Ajouter à la liste de lecture", "HeaderAddUpdateImage": "Ajouter/Mettre à jour une image", - "HeaderAddUser": "Ajouter un utilisateur", "HeaderAdditionalParts": "Parties additionelles", "HeaderAdmin": "Administrateur", "HeaderAlbumArtists": "Artistes", @@ -261,12 +249,10 @@ "HeaderAudioBooks": "Livres audios", "HeaderAudioSettings": "Réglages audio", "HeaderBlockItemsWithNoRating": "Bloquer les éléments avec des informations de classification inconnues ou n'en disposant pas :", - "HeaderBooks": "Livres", "HeaderBranding": "Slogan", "HeaderCancelRecording": "Annuler l'enregistrement", "HeaderCancelSeries": "Annuler la série", "HeaderCastAndCrew": "Distribution & équipe", - "HeaderCastCrew": "Distribution & équipe", "HeaderChannelAccess": "Accès aux chaînes", "HeaderChapterImages": "Images des chapitres", "HeaderCodecProfile": "Profil de codec", @@ -300,14 +286,12 @@ "HeaderEditImages": "Modifier les images", "HeaderEnabledFields": "Activer les champs", "HeaderEnabledFieldsHelp": "Décocher un champ pour le verrouiller et empêcher ses données d'être modifiées.", - "HeaderEpisodes": "Épisodes", "HeaderError": "Erreur", "HeaderExternalIds": "Identifiants externes :", "HeaderFeatureAccess": "Accès aux fonctionnalités", "HeaderFetchImages": "Télécharger les images :", "HeaderFetcherSettings": "Paramètres du récupérateur", "HeaderForKids": "Jeunesse", - "HeaderForgotPassword": "Mot de passe oublié", "HeaderFrequentlyPlayed": "Fréquemment lus", "HeaderGuideProviders": "Fournisseurs de données de guides TV", "HeaderHttpHeaders": "En-têtes HTTP", @@ -335,7 +319,6 @@ "HeaderLoginFailure": "Échec de la connexion", "HeaderMedia": "Média", "HeaderMediaFolders": "Dossiers multimédias", - "HeaderMediaInfo": "Informations du média", "HeaderMetadataSettings": "Paramètres des métadonnées", "HeaderMoreLikeThis": "Similaires", "HeaderMusicQuality": "Qualité de la musique :", @@ -492,7 +475,6 @@ "LabelCustomCertificatePathHelp": "Chemin vers un fichier PKCS #12 contenant un certificat et une clé privée pour activer le support TLS sur un domaine utilisateur.", "LabelCustomCss": "CSS personnalisée :", "LabelCustomCssHelp": "Appliquez votre propre feuille de styles personnalisée à l'interface web.", - "LabelCustomDeviceDisplayName": "Nom d'affichage :", "LabelCustomDeviceDisplayNameHelp": "Entrez un nom d'affichage personnalisé ou laissez vide pour utiliser le nom rapporté par l'appareil.", "LabelCustomRating": "Note personnalisée :", "LabelDateAdded": "Date d'ajout :", @@ -509,7 +491,6 @@ "LabelDiscNumber": "Numéro de disque :", "LabelDisplayLanguage": "Langue d'affichage :", "LabelDisplayLanguageHelp": "La traduction de Jellyfin est un projet en cours.", - "LabelDisplayMissingEpisodesWithinSeasons": "Afficher les épisodes manquants dans les saisons", "LabelDisplayMode": "Mode d'affichage :", "LabelDisplayName": "Nom d'affichage :", "LabelDisplayOrder": "Ordre d'affichage :", @@ -665,7 +646,6 @@ "LabelPostProcessorArguments": "Arguments en ligne de commande du post-processeur :", "LabelPostProcessorArgumentsHelp": "Utiliser {path} comme chemin d'accès au fichier d'enregistrement.", "LabelPreferredDisplayLanguage": "Langue d'affichage préférée :", - "LabelPreferredDisplayLanguageHelp": "La traduction de Jellyfin est un projet en cours.", "LabelPreferredSubtitleLanguage": "Langue de sous-titrage préférée :", "LabelProfileAudioCodecs": "Codecs audio :", "LabelProfileCodecs": "Codecs :", @@ -725,7 +705,6 @@ "LabelSubtitleDownloaders": "Outils de téléchargement de sous-titres :", "LabelSubtitleFormatHelp": "Exemple : srt", "LabelSubtitlePlaybackMode": "Mode des sous-titres :", - "LabelSubtitles": "Sous-titres", "LabelSupportedMediaTypes": "Types de médias supportés :", "LabelTVHomeScreen": "Écran d'accueil du mode TV :", "LabelTag": "Étiquette :", @@ -738,12 +717,9 @@ "LabelTimeLimitHours": "Limite de temps (heures) :", "LabelTitle": "Titre :", "LabelTrackNumber": "Numéro de piste :", - "LabelTranscodingAudioCodec": "Codec audio :", - "LabelTranscodingContainer": "Conteneur :", "LabelTranscodingTempPathHelp": "Spécifiez un chemin personnalisé pour les fichiers transcodés envoyés aux clients. Laissez vide pour utiliser le chemin par défaut du serveur.", "LabelTranscodingThreadCount": "Nombre de threads de transcodage :", "LabelTranscodingThreadCountHelp": "Sélectionnez le nombre maximum de threads à utiliser pour le transcodage. La réduction de cette valeur réduira l'utilisation du processeur mais pourrait ne pas suffire pour maintenir une lecture fluide.", - "LabelTranscodingVideoCodec": "Codec vidéo :", "LabelTriggerType": "Type de déclencheur :", "LabelTunerIpAddress": "Adresse IP du tuner :", "LabelTunerType": "Type de tuner :", @@ -850,7 +826,6 @@ "MessagePluginConfigurationRequiresLocalAccess": "Pour configurer cette extension, veuillez vous connecter directement à votre serveur local.", "MessagePluginInstallDisclaimer": "Les extensions développées par les membres de la communauté sont une excellente manière d'améliorer votre expérience avec de nouvelles fonctionnalités. Avant toute installation, veuillez prendre connaissance de l'impact qu'elles peuvent avoir sur le serveur, comme l'augmentation de la durée d'actualisation de la médiathèque, de nouvelles tâches de fond, ou un système moins stable.", "MessageReenableUser": "Voir ci-dessous pour le réactiver", - "MessageSettingsSaved": "Paramètres enregistrés.", "MessageTheFollowingLocationWillBeRemovedFromLibrary": "Ces emplacements de média vont être supprimés de votre médiathèque :", "MessageUnableToConnectToServer": "Nous sommes dans l'impossibilité de nous connecter au serveur sélectionné. Veuillez vérifier qu'il est opérationnel et réessayez.", "MessageUnsetContentHelp": "Le contenu sera affiché sous forme de dossiers. Pour un résultat optimal, utilisez le gestionnaire de métadonnées pour définir le type de contenu des sous-dossiers.", @@ -914,7 +889,6 @@ "OptionArtist": "Artiste", "OptionAscending": "Croissant", "OptionAuto": "Automatique", - "OptionAutomatic": "Automatique", "OptionAutomaticallyGroupSeries": "Fusionner automatiquement les séries qui sont réparties en plusieurs dossiers", "OptionAutomaticallyGroupSeriesHelp": "Les séries qui sont réparties en plusieurs dossiers dans la médiathèque seront automatiquement fusionnées en une seule série.", "OptionBlockBooks": "Livres", @@ -1143,16 +1117,13 @@ "SystemDlnaProfilesHelp": "Les profils système sont en lecture seule. Les modifications apportées à un profil système seront enregistrées sous un nouveau profil personnalisé.", "TabAccess": "Accès", "TabAdvanced": "Avancé", - "TabAlbumArtists": "Artistes de l'album", "TabCatalog": "Catalogue", "TabContainers": "Conteneurs", "TabDashboard": "Tableau de bord", "TabDirectPlay": "Lecture directe", - "TabEpisodes": "Épisodes", "TabLatest": "Derniers", "TabLogs": "Journaux", "TabMusic": "Musique", - "TabMusicVideos": "Vidéos musicales", "TabMyPlugins": "Mes extensions", "TabNetworks": "Réseaux", "TabNfoSettings": "Paramètres NFO", @@ -1161,11 +1132,9 @@ "TabProfile": "Profil", "TabProfiles": "Profils", "TabResponses": "Réponses", - "TabResumeSettings": "Reprise", "TabScheduledTasks": "Tâches planifiées", "TabServer": "Serveur", "TabSettings": "Paramètres", - "TabTrailers": "Bandes-annonces", "TabUpcoming": "À venir", "Tags": "Étiquettes", "TagsValue": "Mots clés: {0}", @@ -1248,7 +1217,6 @@ "HeaderTuners": "Égaliseur", "Horizontal": "Horizontal", "Images": "Images", - "LabelAudio": "Audio", "LeaveBlankToNotSetAPassword": "Laissez vide pour ne pas définir de mot de passe.", "Logo": "Logo", "MediaInfoCodec": "Codec", @@ -1274,7 +1242,6 @@ "Suggestions": "Suggestions", "TV": "Tv", "TabCodecs": "Codecs", - "TabInfo": "Informations", "TabNotifications": "Notifications", "TabPlugins": "Extensions", "TabStreaming": "Streaming", @@ -1299,7 +1266,6 @@ "MediaInfoStreamTypeVideo": "Video", "AuthProviderHelp": "Sélectionner un fournisseur d'authentification pour authentifier le mot de passe de cet utilisateur.", "PasswordResetProviderHelp": "Choisissez un fournisseur de réinitialisation de mot de passe à utiliser lorsqu'un utilisateur demande la réinitialisation de son mot de passe.", - "HeaderHome": "Accueil", "LabelUserLoginAttemptsBeforeLockout": "Tentatives de connexion échouées avant que l'utilisateur ne soit verrouillé :", "DashboardOperatingSystem": "Système d'Exploitation: {0}", "DashboardArchitecture": "Architecture : {0}", diff --git a/src/strings/gsw.json b/src/strings/gsw.json index f144e1ca65..a16a28910c 100644 --- a/src/strings/gsw.json +++ b/src/strings/gsw.json @@ -15,7 +15,6 @@ "FolderTypeMusicVideos": "Musigvideos", "FolderTypeTvShows": "TV", "Friday": "Friitig", - "HeaderAddUser": "Erstell en User", "HeaderDeviceAccess": "Grät Zuegriff", "HeaderEasyPinCode": "Eifache Pin Code", "HeaderFrequentlyPlayed": "Vell gspellt", @@ -30,7 +29,6 @@ "LabelContentType": "Date Art:", "LabelCountry": "Land:", "LabelCurrentPassword": "Jetzigs Passwort:", - "LabelDisplayMissingEpisodesWithinSeasons": "Zeig fehlendi Episode innerhalb vo de einzelne Staffle", "LabelFinish": "Beende", "LabelLanguage": "Sproch:", "LabelMaxParentalRating": "Maximum erlaubti Kindersicherig:", @@ -81,11 +79,8 @@ "Sunday": "Sonntig", "TabAccess": "Zuegriff", "TabAdvanced": "Erwiitert", - "TabAlbumArtists": "Album-Artist", "TabCatalog": "Katalog", - "TabEpisodes": "Episode", "TabLatest": "Letschti", - "TabMusicVideos": "Musigvideos", "TabMyPlugins": "Miini Plugins", "TabNetworks": "Studios", "TabNotifications": "Mitteilige", diff --git a/src/strings/he.json b/src/strings/he.json index 667db59d9e..828f140465 100644 --- a/src/strings/he.json +++ b/src/strings/he.json @@ -17,12 +17,9 @@ "MessageBrowsePluginCatalog": "עבור לקטלוג התוספים לראות אילו זמינים.", "ButtonAddUser": "הוסף משתמש", "ButtonCancel": "בטל", - "ButtonEdit": "ערוך", - "ButtonFilter": "מסנן", "ButtonGotIt": "הבנתי", "ButtonManualLogin": "התחברות ידנית", "ButtonOk": "בסדר", - "ButtonPlay": "נגן", "ButtonQuickStartGuide": "מדריך מהיר", "ButtonRefreshGuideData": "רענן את מדריך השידור", "ButtonRemove": "הסר", @@ -78,11 +75,9 @@ "HeaderActiveRecordings": "הקלטות פעילות", "HeaderAddToCollection": "להוסיף לאוסף", "HeaderAddToPlaylist": "הוסף לרשימת ניגון", - "HeaderAddUser": "הוסף משתמש", "HeaderAdditionalParts": "חלקים נוספים", "HeaderCancelRecording": "ביטול הקלטה", "HeaderCancelSeries": "בטל סדרה", - "HeaderCastCrew": "שחקנים וצוות", "HeaderConfirmPluginInstallation": "אשר התקנת תוסף", "HeaderCustomDlnaProfiles": "פרופילים מותאמים אישית", "HeaderDeleteItem": "מחק פריט", @@ -160,7 +155,6 @@ "LabelDefaultUser": "משתמש ברירת מחדש:", "LabelDefaultUserHelp": "מגדיר אילו ספריות משתמש יוצגו במכשירים מחוברים. ניתן לעקוף זאת לכל מכשיר על ידי שימוש בפרופילים.", "LabelDiscNumber": "מספר דיסק:", - "LabelDisplayMissingEpisodesWithinSeasons": "הצג פרקים חסרים בתוך העונות", "LabelDisplayOrder": "סדר תצוגה:", "LabelDownMixAudioScaleHelp": "הגבר את עוצמת השמע כאשר הוא ממוזג. ערך השווה ל-1 יישמר את העוצמה המקורית.", "LabelDynamicExternalId": "{0} תעודת זהות:", @@ -218,7 +212,6 @@ "LabelPlaceOfBirth": "מקום לידה:", "LabelPlaylist": "רשימת ניגון:", "LabelPreferredDisplayLanguage": "שפת תצוגה מועדפת:", - "LabelPreferredDisplayLanguageHelp": "תרגום Jellyfin הוא תהליך מתמשך.", "LabelProfileAudioCodecs": "מקודדי שמע:", "LabelProfileCodecs": "מקודדים:", "LabelProfileVideoCodecs": "‮מקודדי וידאו:", @@ -290,7 +283,6 @@ "OptionAllowUserToManageServer": "אפשר למשתמש זה לנהל את השרת", "OptionArtist": "אמן", "OptionAscending": "סדר עולה", - "OptionAutomatic": "אוטומטי", "OptionBlockMovies": "סרטים", "OptionBlockTvShows": "תוכניות טלויזיה", "OptionBluray": "בלו-ריי", @@ -414,15 +406,11 @@ "SystemDlnaProfilesHelp": "פרופלי מערכת הם לקריאה בלבד. שינויים בפרופילי מערכת ישמרו לפרופיל מוצאם אישית חדש.", "TabAccess": "גישה", "TabAdvanced": "מתקדם", - "TabAlbumArtists": "אמני אלבום", "TabCatalog": "קטלוג", "TabCodecs": "מקודדים", "TabDashboard": "לוח בקרה", - "TabEpisodes": "פרקים", - "TabInfo": "מידע", "TabLatest": "אחרון", "TabMusic": "מוסיקה", - "TabMusicVideos": "קליפים", "TabMyPlugins": "התוספים שלי", "TabNetworks": "רשתות", "TabNotifications": "התראות", @@ -430,7 +418,6 @@ "TabProfiles": "פרופילים", "TabServer": "שרת", "TabSettings": "הגדרות", - "TabTrailers": "טריילרים", "TabUpcoming": "בקרוב", "Tags": "מילות מפתח", "TellUsAboutYourself": "ספר לנו על עצמך", @@ -520,7 +507,6 @@ "ContinueWatching": "המשך לצפות", "ButtonUninstall": "הסר התקנה", "ButtonTrailer": "קדימון", - "ButtonSubtitles": "כתוביות", "ButtonSplit": "פיצול", "ButtonStop": "עצור", "ButtonSettings": "הגדרות", @@ -533,9 +519,7 @@ "ButtonNetwork": "רשת", "ButtonMore": "עוד", "ButtonInfo": "מידע", - "ButtonHome": "בית", "ButtonFullscreen": "מסך מלא", - "ButtonEditImages": "ערוך תמונות", "ButtonAddServer": "הוסף שרת", "ButtonAddMediaLibrary": "הוסף ספריית מדיה", "ButtonAddImage": "הוסף תמונה", @@ -576,14 +560,12 @@ "HeaderLibraries": "ספריות", "HeaderInstall": "התקנה", "HeaderImageOptions": "הגדרות תמונה", - "HeaderHome": "בית", "HeaderForKids": "עבור ילדים", "HeaderFavoriteVideos": "סרטונים מועדפים", "HeaderFavoritePeople": "אנשים מועדפים", "HeaderFavoriteMovies": "סרטים מועדפים", "HeaderFavoriteBooks": "ספרים מועדפים", "HeaderError": "שגיאה", - "HeaderEpisodes": "פרקים", "HeaderDownloadSync": "הורדה וסנכרון", "HeaderDevices": "מכשירים", "HeaderDeveloperInfo": "מידע למפתח", @@ -595,13 +577,11 @@ "HeaderConfirmRevokeApiKey": "‫בטל מפתח API", "HeaderCastAndCrew": "שחקנים וצוות", "HeaderBranding": "מיתוג", - "HeaderBooks": "ספרים", "HeaderAudioSettings": "הגדרות שמע", "HeaderAudioBooks": "ספרים מוקלטים", "HeaderApiKeys": "‫מפתחות API", "HeaderApiKey": "‫מפתח API", "HeaderAddUpdateImage": "הוסף/עדכן תמונה", - "HeaderAddScheduledTaskTrigger": "הוסף טריגר", "HeaderActivity": "פעילות", "Guide": "מדריך", "Genre": "ז'אנר", @@ -620,7 +600,6 @@ "Episodes": "פרקים", "EnableThemeSongsHelp": "נגן שירי פתיח ברגע בעת העיון בספרייה.", "ThemeSongs": "שירי פתיח", - "EnableThemeSongs": "שירי פתיח", "EnablePhotos": "הצג תמונות", "EnableHardwareEncoding": "הפעל קידוד חומרה", "EnableExternalVideoPlayers": "נגני וידאו חיצוניים", @@ -646,16 +625,13 @@ "ButtonScanAllLibraries": "סרוק את כל הספריות", "ButtonRevoke": "בטל", "TabScheduledTasks": "משימות מתוזמנות", - "TabResumeSettings": "המשך צפייה", "ButtonResume": "המשך", - "ButtonRefresh": "רענון", "ButtonProfile": "פרופיל", "ButtonOpen": "פתח", "HeaderTracks": "רצועות", "ButtonPreviousTrack": "הרצועה הקודמת", "ButtonNextTrack": "הרצועה הבאה", "ButtonGuide": "מדריך", - "HeaderForgotPassword": "שחזור סיסמה", "ButtonForgotPassword": "שחזור סיסמה", "ButtonEditOtherUserPreferences": "ערוך את הפרופיל, התמונה וההגדרות האישיות של משתמש זה.", "ButtonChangeServer": "החלף שרת", @@ -681,7 +657,6 @@ "CinemaModeConfigurationHelp": "מצב קולנוע מביא את חוויית הקולנוע היישר אל הסלון עם האפשרות להפעיל טריילרים וקדימונים מותאמים אישית לפני הסרט.", "ChannelAccessHelp": "בחר את הערוצים לשיתוף עם משתמש זה. מנהלים יוכלו לערוך את כל הערוצים בעזרת מנהל המטא-דאטה.", "ButtonResetEasyPassword": "אתחל קוד פין פשוט", - "ButtonOff": "כיבוי", "ButtonLibraryAccess": "הרשאות גישה לספרייה", "BurnSubtitlesHelp": "מחליט אם על השרת לצרוב כתוביות בזמן קידוד וידאו. הימנעות מכך תשפר מאוד את הביצועים. בחר \"אוטומטי\" לצריבת כתוביות על בסיס פורמט תמונה (VOBSUB, PGS, SUB, IDX, …) וכתוביות ASS או SSA מסויימות.", "Artist": "אמן", @@ -707,7 +682,6 @@ "DashboardOperatingSystem": "מערכת הפעלה: {0}", "HeaderMyMediaSmall": "המדיה שלי (קטן)", "HeaderMusicQuality": "איכות מוזיקה", - "HeaderMediaInfo": "מידע על המדיה", "HeaderMoreLikeThis": "עוד כמו זה", "HeaderMedia": "מדיה", "LabelMetadata": "מטא-דאטה:", @@ -730,7 +704,6 @@ "LabelDidlMode": "מצב DIDL:", "LabelDeviceDescription": "תיאור מכשיר", "LabelDefaultScreen": "מסך ברירת-מחדל:", - "LabelCustomDeviceDisplayName": "שם תצוגה:", "LabelImageType": "סוג תמונה:", "LabelHttpsPortHelp": "מספר פורט ה-TCP עבור שרת ה-HTTPS.", "LabelHttpsPort": "מספר פורט HTTPS מקומי:", diff --git a/src/strings/hi-in.json b/src/strings/hi-in.json index 6a22cb170c..bacff9aca2 100644 --- a/src/strings/hi-in.json +++ b/src/strings/hi-in.json @@ -1,7 +1,6 @@ { "ButtonQuickStartGuide": "तुरंत आरंभ मार्गदर्शिका", "ButtonSignOut": "Sign out", - "HeaderAddUser": "उपयोगकर्ता जोडें", "LabelFinish": "समाप्त", "LabelYoureDone": "आपने पूरा कर लिया है!", "MoreUsersCanBeAddedLater": "अधिक उपयोगकर्ताओं को बाद में डैशबोर्ड के अंतर्गत जोड़ा जा सकता है।", @@ -33,22 +32,17 @@ "AllowMediaConversionHelp": "मीडिया परिवर्तन के लिये अनुमति दें", "AllowMediaConversion": "मीडिया रूपांतरण की अनुमति दें", "ButtonOk": "ठीक", - "ButtonOff": "बंद", "ButtonNextTrack": "आगे धावन पथ", "ButtonNetwork": "संजाल", "ButtonMore": "अधिक", "ButtonManualLogin": "मैनुअल लॉगिन", "ButtonLibraryAccess": "पुस्तकालय का उपयोग", "ButtonInfo": "जानकारी", - "ButtonHome": "घर", "ButtonGuide": "मार्गदर्शक", "ButtonGotIt": "समझ गया", "ButtonFullscreen": "पूर्ण स्क्रीन", "ButtonForgotPassword": "पासवर्ड भूल गए", - "ButtonFilter": "निस्पंदन", "ButtonEditOtherUserPreferences": "इस उपयोगकर्ता की प्रोफ़ाइल, छवि और व्यक्तिगत प्राथमिकताएँ संपादित करें।", - "ButtonEditImages": "छवियों को संपादित करें", - "ButtonEdit": "संपादित करें", "ButtonChangeServer": "सर्वर बदलें", "ButtonCancel": "रद्द करना", "ButtonBack": "वापस", diff --git a/src/strings/hr.json b/src/strings/hr.json index afbdbf2c22..169d50ad6c 100644 --- a/src/strings/hr.json +++ b/src/strings/hr.json @@ -25,29 +25,23 @@ "ButtonBack": "Nazad", "ButtonCancel": "Odustani", "ButtonChangeServer": "Promijeni Server", - "ButtonEdit": "Izmjeni", - "ButtonEditImages": "Uređivanje slika", "ButtonEditOtherUserPreferences": "Uredite ovaj korisnički profil, slike i osobne postavke.", "ButtonForgotPassword": "Zaboravili ste lozinku", "ButtonFullscreen": "Puni zaslon", "ButtonGotIt": "Shvaćam", "ButtonGuide": "Vodič", - "ButtonHome": "Početna", "ButtonLibraryAccess": "Pristup biblioteci", "ButtonManualLogin": "Ručna prijava", "ButtonMore": "Više", "ButtonNetwork": "Mreža", "ButtonNextTrack": "Sljedeća pjesma", - "ButtonOff": "Isključi", "ButtonOk": "U redu", "ButtonOpen": "Otvori", "ButtonParentalControl": "Roditeljska kontrola", "ButtonPause": "Pauza", - "ButtonPlay": "Pokreni", "ButtonPreviousTrack": "Prethodna pjesma", "ButtonProfile": "Profil", "ButtonQuickStartGuide": "Vodič za brzi početak", - "ButtonRefresh": "Osviježi", "ButtonRefreshGuideData": "Osvježi TV vodič", "ButtonRemove": "Ukloni", "ButtonRename": "Preimenuj", @@ -66,7 +60,6 @@ "ButtonSignOut": "Odjava", "ButtonStart": "Početak", "ButtonSubmit": "Podnesi", - "ButtonSubtitles": "Titlovi", "ButtonTrailer": "Kratki video", "ButtonUninstall": "Ukloni", "ButtonWebsite": "Web stranica", @@ -144,11 +137,9 @@ "HeaderActiveDevices": "Aktivni uređaji", "HeaderActiveRecordings": "Aktivna snimanja", "HeaderActivity": "Aktivnosti", - "HeaderAddScheduledTaskTrigger": "Dodaj okidač", "HeaderAddToCollection": "Dodaj u kolekciju", "HeaderAddToPlaylist": "Dodaj u popis", "HeaderAddUpdateImage": "Dodaj/ažuriraj sliku", - "HeaderAddUser": "Dodaj korisnika", "HeaderAdditionalParts": "Dodatni djelovi", "HeaderAlert": "Uzbuna", "HeaderApiKey": "API ključ", @@ -156,12 +147,10 @@ "HeaderApiKeysHelp": "Vanjske aplikacije moraju imati API ključ kako bi komunicirale s Jellyfin Serverom. Ključevi se izdaju prijavom s Jellyfin računom ili ručnim odobravanjem zahtjeva ključa.", "HeaderApp": "Aplikacija", "HeaderAudioSettings": "Postavke zvuka", - "HeaderBooks": "Knjige", "HeaderBranding": "Brendiranje", "HeaderCancelRecording": "Prekini snimanje", "HeaderCancelSeries": "Otkaži serije", "HeaderCastAndCrew": "Glumci i ekipa", - "HeaderCastCrew": "Glumci i ekipa", "HeaderChannelAccess": "Pristup kanalima", "HeaderCodecProfile": "Profil kodeka", "HeaderCodecProfileHelp": "Profili kodeka definiraju ograničenja kada uređaji izvode sadržaj u specifičnom kodeku. Ako se ograničenja podudaraju tada će sadržaj biti transkodiran, iako je kodek konfiguriran za direktno izvođenje.", @@ -188,12 +177,10 @@ "HeaderEditImages": "Uređivanje slika", "HeaderEnabledFields": "Omogući polja", "HeaderEnabledFieldsHelp": "Poništi polje za zaključavanje i spriječi njihove podatke od toga da budu promijenjeni.", - "HeaderEpisodes": "Epizode", "HeaderError": "Greška", "HeaderFeatureAccess": "Pristup opcijama", "HeaderFetchImages": "Dohvati slike:", "HeaderForKids": "Za djecu", - "HeaderForgotPassword": "Zaboravili ste lozinku", "HeaderFrequentlyPlayed": "Često izvođeno", "HeaderGuideProviders": "Pružatelji vodiča", "HeaderHttpHeaders": "HTTP zaglavlja", @@ -216,7 +203,6 @@ "HeaderLoginFailure": "Neuspjela prijava", "HeaderMedia": "Medij", "HeaderMediaFolders": "Medijska mapa", - "HeaderMediaInfo": "Info medija", "HeaderMetadataSettings": "Postavke meta-podataka", "HeaderMoreLikeThis": "Više ovakvih", "HeaderMusicVideos": "Muzički spotovi", @@ -334,7 +320,6 @@ "LabelCurrentPassword": "Sadašnja lozinka:", "LabelCustomCss": "Prilagođeni CSS:", "LabelCustomCssHelp": "Primijenite svoj vlastiti prilagođeni stil na web sučelje.", - "LabelCustomDeviceDisplayName": "Prikaz naziva:", "LabelCustomDeviceDisplayNameHelp": "Navedite naziv prilagođenog prikaza ili ostaviti prazno za korištenje naziva koji je izvijestio uređaj.", "LabelCustomRating": "Prilagođena ocjena:", "LabelDateAdded": "Datum dodavanja:", @@ -346,7 +331,6 @@ "LabelDefaultUserHelp": "Određuje koja će biblioteka biti prikazana na spojenim uređajima. Ovo se može zaobići za svaki uređaj koristeći profile.", "LabelDeviceDescription": "Opis uređaja", "LabelDidlMode": "DIDL način:", - "LabelDisplayMissingEpisodesWithinSeasons": "Prikaži epizode koje nedostaju unutar sezone", "LabelDisplayName": "Prikaz naziva:", "LabelDisplayOrder": "Poredak prikaza:", "LabelDisplaySpecialsWithinSeasons": "Prikaz specijalnih dodataka unutar sezona u kojima su emitirani", @@ -481,7 +465,6 @@ "LabelPlayDefaultAudioTrack": "Pokreni zadani audio zapis, bez obzira na jezik", "LabelPlaylist": "Popis:", "LabelPreferredDisplayLanguage": "Željeni jezik za prikaz:", - "LabelPreferredDisplayLanguageHelp": "Prevađanje Jellyfin-a je projekt u tijeku.", "LabelProfileAudioCodecs": "Audio kodek:", "LabelProfileCodecs": "Kodeki:", "LabelProfileCodecsHelp": "Odvojeno sa točka-zrezom. Ovo može ostaviti prazno kao bi bilo postavljeno za sve codecs.", @@ -533,12 +516,9 @@ "LabelTimeLimitHours": "Rok (sati):", "LabelTitle": "Naslov:", "LabelTrackNumber": "Broj pjesme:", - "LabelTranscodingAudioCodec": "Audio koder:", - "LabelTranscodingContainer": "Spremnik:", "LabelTranscodingTempPathHelp": "Ova mapa sadrži radne datoteke koje koristi konverter. Navedite prilagođenu putanju ili ostavite prazno za korištenje zadanog unutar mape podataka poslužitelja.", "LabelTranscodingThreadCount": "Broj niti konvertiranja:", "LabelTranscodingThreadCountHelp": "Odaberite maksimalan broj niti koje će se koristiti kada se konvertira. Manji broj niti će smanjiti upotrebu procesora, ali moguće da neće konvertirati dovoljno brzo za glatke reprodukcije.", - "LabelTranscodingVideoCodec": "Video koder:", "LabelTriggerType": "Tip pokretača:", "LabelTunerIpAddress": "IP adresa TV/Radio uređaja:", "LabelTunerType": "Vrsta pretraživača:", @@ -626,7 +606,6 @@ "MessagePluginConfigurationRequiresLocalAccess": "Za podešavanje ovog dodatka prijavite se izravno na lokalni server.", "MessagePluginInstallDisclaimer": "Dodaci izgrađeni od strane članova Jellyfin zajednice su sjajan način kako bi unaprijedili Vaše iskustvo Jellyfin s dodatnim značajkama i prednostima. Prije instaliranja budite svjesni učinaka koje mogu imati na vaš Jellyfin Server, kao što je duže skeniranje biblioteke, dodatna pozadinska obrada, a smanjena stabilnost sustava.", "MessageReenableUser": "Pogledajte dolje za ponovno omogućenje", - "MessageSettingsSaved": "Postavke spremljene.", "MessageTheFollowingLocationWillBeRemovedFromLibrary": "Sljedeće lokacije medija biti će uklonjene iz vaše Jellyfin biblioteke:", "MessageUnableToConnectToServer": "Nismo u mogućnosti spojiti se na odabrani poslužitelj. Provjerite dali je pokrenut i pokušajte ponovno.", "MessageUnsetContentHelp": "Sadržaj će biti prikazan kao obične mape. Za najbolje rezultate upotrijebite upravitelj meta-podataka za postavljanje vrste sadržaja pod-mapa.", @@ -673,7 +652,6 @@ "OptionArtist": "Izvođaču", "OptionAscending": "Uzlazno", "OptionAuto": "Automatski", - "OptionAutomatic": "Automatski", "OptionBlockBooks": "Knjige", "OptionBlockChannelContent": "Sadržaj Internet kanala", "OptionBlockLiveTvChannels": "TV kanali uživo", @@ -851,17 +829,14 @@ "SystemDlnaProfilesHelp": "Sistemski profili su samo za čitanje. Bilo kakve izmjene na sistemskom profilu biti će snimljene kao novi prilagođeni profil.", "TabAccess": "Pristup", "TabAdvanced": "Napredno", - "TabAlbumArtists": "Albumi izvođača", "TabCatalog": "Katalog", "TabCodecs": "Kodek", "TabContainers": "Spremnik", "TabDashboard": "Nadzorna ploča", "TabDirectPlay": "Direktna reprodukcija", - "TabEpisodes": "Epizode", "TabLatest": "Zadnje", "TabLogs": "Dnevnici", "TabMusic": "Glazba", - "TabMusicVideos": "Muzički spotovi", "TabMyPlugins": "Moji dodaci", "TabNetworks": "Mreže", "TabNfoSettings": "Nfo postavke", @@ -872,11 +847,9 @@ "TabProfile": "Profil", "TabProfiles": "Profili", "TabResponses": "Odazivi", - "TabResumeSettings": "Postavke nastavka", "TabScheduledTasks": "Zakazani zadaci", "TabSettings": "Postavke", "TabStreaming": "Strujanje", - "TabTrailers": "Kratki filmovi", "TabUpcoming": "Uskoro", "Tags": "Oznake", "TellUsAboutYourself": "Recite nam nešto o sebi", @@ -987,7 +960,6 @@ "ButtonStop": "Stop", "ButtonScanAllLibraries": "Skeniraj sve biblioteke", "ButtonInfo": "Info", - "ButtonFilter": "Filtriraj", "ButtonAddImage": "Dodaj sliku", "Box": "Kutija", "AskAdminToCreateLibrary": "Traži administratora da kreira biblioteku.", @@ -1051,7 +1023,6 @@ "LabelSyncPlayNewGroupDescription": "Kreiraj novu grupu", "LabelSyncPlayNewGroup": "Nova grupa", "MillisecondsUnit": "ms", - "LabelSubtitles": "Prijevodi", "LabelStatus": "Status:", "LabelSortOrder": "Redoslijed sortiranja:", "LabelSortBy": "Sortiranje po:", @@ -1073,7 +1044,6 @@ "LabelDisplayLanguage": "Jezik prikaza:", "LabelAutomaticallyRefreshInternetMetadataEvery": "Automatski osvježi meta podatke sa interneta:", "LabelAudioChannels": "Audio kanali:", - "LabelAudio": "Audio", "LabelAlbum": "Album:", "Label3DFormat": "3D format:", "Items": "Stavke", @@ -1098,7 +1068,6 @@ "HeaderNavigation": "Navigacija", "HeaderMyDevice": "Moj uređaj", "HeaderLibrarySettings": "Postavke biblioteke", - "HeaderHome": "Početna", "HeaderFavoritePeople": "Omiljeni ljudi", "HeaderFavoriteMovies": "Omiljeni filmovi", "HeaderFavoriteBooks": "Omiljene knjige", diff --git a/src/strings/hu.json b/src/strings/hu.json index 9a409e920f..2217ceb7df 100644 --- a/src/strings/hu.json +++ b/src/strings/hu.json @@ -21,25 +21,18 @@ "ButtonAudioTracks": "Audió Sávok", "ButtonCancel": "Mégsem", "ButtonChangeServer": "Szerver váltás", - "ButtonEdit": "Szerkesztés", - "ButtonEditImages": "Képek szerkesztése", - "ButtonFilter": "Szűrő", "ButtonForgotPassword": "Elfelejtett Jelszó", "ButtonGotIt": "Értettem", - "ButtonHome": "Kezdőlap", "ButtonLibraryAccess": "Könyvtár hozzáférés", "ButtonManualLogin": "Manuális belépés", "ButtonMore": "Tovább", "ButtonNextTrack": "Következő sáv", - "ButtonOff": "Ki", "ButtonOpen": "Megnyitás", "ButtonParentalControl": "Szülői felügyelet", "ButtonPause": "Szünet", - "ButtonPlay": "Lejátszás", "ButtonPreviousTrack": "Előző sáv", "ButtonProfile": "Profil", "ButtonQuickStartGuide": "Gyorsbeállítás varázsló", - "ButtonRefresh": "Frissítés", "ButtonRemove": "Eltávolítás", "ButtonRename": "Átnevezés", "ButtonResetEasyPassword": "Pin kód visszaállítása", @@ -56,7 +49,6 @@ "ButtonSignOut": "Kijelentkezés", "ButtonStop": "Leállít", "ButtonSubmit": "Elküld", - "ButtonSubtitles": "Feliratok", "ButtonTrailer": "Előzetes", "ButtonUninstall": "Eltávolítás", "ButtonWebsite": "Weboldal", @@ -83,7 +75,6 @@ "EditSubtitles": "Feliratok szerkesztése", "EnableBackdropsHelp": "A háttérképek a könyvtár böngészése közben néhány oldal hátterében jelennek meg.", "EnableHardwareEncoding": "Hardveres kódolás engedélyezése", - "EnableThemeSongs": "Főcímdalok", "EnableThemeSongsHelp": "Főcímdalok lejátszása háttérben a könyvtár böngészése közben.", "EndsAtValue": "Várható befejezés {0}", "Episodes": "Epizódok", @@ -109,11 +100,9 @@ "HeaderAddToCollection": "Hozzáadás gyűjteményhez", "HeaderAddToPlaylist": "Hozzáadás lejátszási listához", "HeaderAddUpdateImage": "Kép hozzáadása / frissítése", - "HeaderAddUser": "Új felhasználó", "HeaderAudioBooks": "Hangos könyvek", "HeaderAudioSettings": "Audió Beállítások", "HeaderCastAndCrew": "Szereplők és Stáb", - "HeaderCastCrew": "Szereplők és Stáb", "HeaderConnectToServer": "Kapcsolódás a Szerverhez", "HeaderContinueWatching": "Megtekintés folytatása", "HeaderCustomDlnaProfiles": "Egyedi profilok", @@ -125,9 +114,7 @@ "HeaderEasyPinCode": "Pin kód", "HeaderEditImages": "Képek szerkesztése", "HeaderEnabledFields": "Engedélyezett mezők", - "HeaderEpisodes": "Epizódok", "HeaderExternalIds": "Külső id-k:", - "HeaderForgotPassword": "Elfelejtett Jelszó", "HeaderFrequentlyPlayed": "Gyakran játszott", "HeaderIdentifyItemHelp": "Adj meg egy vagy több keresési kritériumot. Távolítsd el a kritériumokat a keresési eredmények növelése érdekében.", "HeaderImageSettings": "Kép beállítások", @@ -143,7 +130,6 @@ "HeaderLiveTvTunerSetup": "Élő TV tuner beállítása", "HeaderMedia": "Média", "HeaderMediaFolders": "Médiakönyvtárak", - "HeaderMediaInfo": "Média Infó", "HeaderMetadataSettings": "Metaadat Beállítások", "HeaderMoreLikeThis": "Több ehhez hasonló", "HeaderMusicVideos": "Zenei videók", @@ -196,7 +182,6 @@ "Label3DFormat": "3D formátum:", "LabelAlbumArtists": "Album előadók:", "LabelArtists": "Előadók:", - "LabelAudio": "Audió", "LabelAudioLanguagePreference": "Audió nyelvének beállítása:", "LabelBirthYear": "Születési év:", "LabelCachePath": "Gyorsítótár útvonal:", @@ -206,13 +191,11 @@ "LabelCountry": "Ország:", "LabelCriticRating": "Kritikusok értékelése:", "LabelCurrentPassword": "Jelenlegi jelszó:", - "LabelCustomDeviceDisplayName": "Megjelenítendő név:", "LabelCustomDeviceDisplayNameHelp": "Adj meg egy egyedi nevet, vagy hagyd üresen a készülék által elküldött név használatához.", "LabelCustomRating": "Egyéni értékelés:", "LabelDateAdded": "Hozzáadva:", "LabelDateTimeLocale": "Dátum és idő formátum:", "LabelDay": "Nap:", - "LabelDisplayMissingEpisodesWithinSeasons": "Hiányzó évad epizódok megjelenítése", "LabelDisplayName": "Megjelenítendő név:", "LabelDisplayOrder": "Megjelenítési sorrend:", "LabelDownloadLanguages": "Nyelvek letöltése:", @@ -258,7 +241,6 @@ "LabelPlayDefaultAudioTrack": "Az alapértelmezett hangsáv lejátszása a nyelvtől függetlenül", "LabelPlaylist": "Lejátszási lista:", "LabelPreferredDisplayLanguage": "Elsődleges megjelenítendő nyelv:", - "LabelPreferredDisplayLanguageHelp": "A Jellyfin fordítása egy folyamatos projekt.", "LabelProfileAudioCodecs": "Audió kódekek:", "LabelProfileCodecs": "Kódek:", "LabelProfileContainer": "Tároló:", @@ -281,15 +263,11 @@ "LabelStopping": "Megállítás", "LabelSubtitleFormatHelp": "Például: srt", "LabelSubtitlePlaybackMode": "Felirat mód:", - "LabelSubtitles": "Feliratok", "LabelTagline": "Címke:", "LabelTheme": "Kinézet:", "LabelTime": "Idő:", "LabelTimeLimitHours": "Időlimit (óra):", "LabelTitle": "Cím:", - "LabelTranscodingAudioCodec": "Audió kódek:", - "LabelTranscodingContainer": "Tároló:", - "LabelTranscodingVideoCodec": "Videó kódek:", "LabelTunerType": "Tuner típusa:", "LabelType": "Típus:", "LabelTypeMetadataDownloaders": "{0} metaadat letöltő:", @@ -325,7 +303,6 @@ "MessageNoPluginsInstalled": "Nincs bővítmény telepítve.", "MessageNothingHere": "Nincs itt semmi.", "MessagePleaseEnsureInternetMetadata": "Kérlek ellenőrizd hogy az Internetes metaadat letöltés engedélyezve van.", - "MessageSettingsSaved": "Beállítások mentve.", "Metadata": "Metaadat", "MetadataManager": "Metaadat Manager", "Monday": "Hétfő", @@ -453,17 +430,13 @@ "Sync": "Szinkronizál", "TabAccess": "Hozzáférés", "TabAdvanced": "Haladó", - "TabAlbumArtists": "Album Előadók", "TabCatalog": "Katalógus", "TabCodecs": "Kódek", "TabContainers": "Tároló", "TabDashboard": "Vezérlőpult", - "TabEpisodes": "Epizódok", - "TabInfo": "Infó", "TabLatest": "Legújabb", "TabLogs": "Naplók", "TabMusic": "Zene", - "TabMusicVideos": "Zenei Videók", "TabMyPlugins": "Telepített bővítmények", "TabNetworks": "Csatornák", "TabNfoSettings": "NFO Beállítások", @@ -476,7 +449,6 @@ "TabScheduledTasks": "Ütemezett feladatok", "TabServer": "Szerver", "TabSettings": "Beállítások", - "TabTrailers": "Előzetesek", "TabUpcoming": "Hamarosan érkezik", "Tags": "Címkék", "TellUsAboutYourself": "Mondj valamit magadról", @@ -639,7 +611,6 @@ "HeaderApiKey": "API Kulcs", "HeaderApiKeys": "API Kulcsok", "HeaderAppearsOn": "Megjelenik", - "HeaderBooks": "Könyvek", "HeaderCancelRecording": "Felvétel törlése", "HeaderCancelSeries": "Sorozat törlése", "HeaderChannelAccess": "Csatorna hozzáférés", @@ -711,7 +682,6 @@ "Shows": "Sorozatok", "Songs": "Dalok", "ValueSpecialEpisodeName": "Special - {0}", - "EnableThemeVideos": "Videótémák", "EnableThemeVideosHelp": "Videó témájának lejátszása háttérben a könyvtár böngészése közben.", "HeaderBlockItemsWithNoRating": "Blokkolja azokat az elemeket amelyek tiltott, vagy nem felismerhető minősítésűek:", "HeaderSeriesStatus": "Sorozat állapot", @@ -1008,7 +978,6 @@ "OptionAllowVideoPlaybackTranscoding": "Engedélyezze az átkódolást igénylő videó lejátszást", "OptionArtist": "Előadó", "OptionAuto": "Auto", - "OptionAutomatic": "Auto", "OptionAutomaticallyGroupSeries": "A több mappában elosztott sorozat automatikus összevonása", "OptionAutomaticallyGroupSeriesHelp": "A több mappában elosztott sorozat automatikusan egyesül egy sorozatba.", "OptionBlockBooks": "Könyvek", @@ -1138,7 +1107,6 @@ "TV": "TV", "TabDirectPlay": "Közvetlen lejátszás", "TabResponses": "Válaszok", - "TabResumeSettings": "Folytatás", "TabStreaming": "Streaming", "TagsValue": "Címkék: {0}", "ThemeSongs": "Téma dalok", @@ -1210,7 +1178,6 @@ "EnableStreamLoopingHelp": "Kapcsold be, ha az élő stream csak néhány másodpercnyi adatot tartalmaz és folyamatosan újra kell kérni. Ennek szükségtelen bekapcsolása problémát okozhat.", "Guide": "Műsorújság", "H264CrfHelp": "A Constant Rate Factor (CRF) az alapértelmezett minőségi beállítás az x264 enkóderhez. Az értékek 0 és 51 között állíthatók, ahol az alacsonyabb érték jobb minőséget eredményez (nagyobb fájl méret mellett). Az ajánlott érték 18 és 28 között van. Az x264 alapértelmezett beállítása 23, ez lehet kiindulási alap.", - "HeaderAddScheduledTaskTrigger": "Vezérlő Hozzáadása", "HeaderApiKeysHelp": "A külső alkalmazásoknak egy API kulcsra van szükésge, hogy kommunikáljanak a Szerverrel. A kulcsokat egy normális fiókkal történő belépéssel lehet megkapni, vagy kézileg felvenni egy alkalmazáshoz tartozó kulcsot.", "HeaderBranding": "Személyes arculat", "HeaderContinueListening": "Folyamatban lévő zenék", @@ -1222,7 +1189,6 @@ "HeaderFavoriteSongs": "Kedvenc dalok", "HeaderFavoriteVideos": "Kedvenc Videók", "HeaderGuideProviders": "TV műsorújság Szolgáltatók", - "HeaderHome": "Kezdőlap", "HeaderUpcomingOnTV": "Következő TV műsorok", "ImportFavoriteChannelsHelp": "Csak a tuner eszközön kedvencként megjelölt csatornák kerülnek importálásra.", "LabelAlbumArtHelp": "A használandó PN érték az albumborítók esetében, mely a upnp:albumArtURI dlna:profileID tulajdonságában szerepel. Néhány eszköz meghatározott értéket vár el, függetlenül a kép méretétől.", diff --git a/src/strings/id.json b/src/strings/id.json index 8bf0d7eafd..d4a0d9fb55 100644 --- a/src/strings/id.json +++ b/src/strings/id.json @@ -2,7 +2,6 @@ "ButtonQuickStartGuide": "Panduan cepat", "ButtonSignOut": "Sign out", "FolderTypeTvShows": "TV", - "HeaderAddUser": "Tambah User", "HeaderEasyPinCode": "Kode Pin Mudah", "HeaderSetupLibrary": "Atur pustaka media Anda", "LabelContentType": "Tipe konten:", @@ -92,27 +91,20 @@ "ButtonRename": "Ubah nama", "ButtonRemove": "Hapus", "ButtonRefreshGuideData": "Muat ulang Data Panduan", - "ButtonRefresh": "Muat ulang", "ButtonProfile": "Profil", - "ButtonPlay": "Mainkan", "ButtonPause": "Jeda", "ButtonParentalControl": "Kendali orang tua", "ButtonOpen": "Buka", "ButtonOk": "Baik", - "ButtonOff": "Matikan", "ButtonNetwork": "Jaringan", "ButtonMore": "Lebih banyak", "ButtonLibraryAccess": "Akses pustaka", "ButtonInfo": "Info", - "ButtonHome": "Beranda", "ButtonGuide": "Panduan", "ButtonGotIt": "Paham", "ButtonFullscreen": "Layar penuh", "ButtonForgotPassword": "Lupa Kata Sandi", - "ButtonFilter": "Penyaring", "ButtonEditOtherUserPreferences": "Ubah profil, gambar, dan preferensi pribadi pengguna ini.", - "ButtonEditImages": "Ubah gambar", - "ButtonEdit": "Ubah", "ButtonChangeServer": "Ubah Peladen", "ButtonCancel": "Batalkan", "ButtonBack": "Kembali", diff --git a/src/strings/is-is.json b/src/strings/is-is.json index bd1c81c21a..4b48774a2b 100644 --- a/src/strings/is-is.json +++ b/src/strings/is-is.json @@ -10,7 +10,6 @@ "FolderTypeMusic": "Tónlist", "FolderTypeMusicVideos": "Tónlistarmyndbönd", "FolderTypeTvShows": "Sjónvarpsþættir", - "HeaderAddUser": "Bæta við notenda", "HeaderDeviceAccess": "Aðgangur tækja", "HeaderEasyPinCode": "Auðvelt Pin númer", "HeaderPaths": "Slóðir", @@ -141,23 +140,18 @@ "Played": "Spilað", "Photos": "Myndir", "Movies": "Kvikmyndir", - "ButtonPlay": "Spila", "HeaderRestart": "Endurræsa", "HeaderProfileInformation": "Upplýsingar um prófíl", "HeaderProfile": "Prófíll", "HeaderPassword": "Lykilorð", "HeaderLatestMovies": "Kvikmyndir, nýlega bætt við", "HeaderLatestEpisodes": "Þættir, nýlega bætt við", - "HeaderHome": "Heim", "HeaderFavoriteVideos": "Uppáhalds Myndbönd", "HeaderFavoriteMovies": "Uppáhalds Kvikmyndir", - "HeaderEpisodes": "Þættir", "HeaderError": "Villa", "HeaderDownloadSync": "Sækja og Samstilla", "HeaderDeleteDevice": "Eyða Tæki", - "HeaderCastCrew": "Leikarar og Áhöfn", "HeaderCastAndCrew": "Leikarar og Áhöfn", - "HeaderBooks": "Bækur", "HeaderAdmin": "Stjórnandi", "GuideProviderLogin": "Innskrá", "General": "Almennt", @@ -195,7 +189,6 @@ "ButtonWebsite": "Vefsiða", "ButtonUninstall": "Fjarlægja", "ButtonTrailer": "Sýnishorn", - "ButtonSubtitles": "Texti", "ButtonSignIn": "Innskráning", "ButtonSettings": "Stillingar", "ButtonSend": "Senda", @@ -216,24 +209,18 @@ "Sync": "Samstilla", "ButtonRevoke": "Afturkalla", "Monday": "Mánudagur", - "ButtonRefresh": "Endurhlaða", "ButtonParentalControl": "Foreldraeftirlit", - "ButtonOff": "Af", "ButtonNextTrack": "Næsta lag", "ButtonNetwork": "Net", "ButtonMore": "Meira", "ButtonManualLogin": "Handvirkt Auðkenni", "ButtonLibraryAccess": "Aðgangur að safni", "ButtonInfo": "Upplýsingar", - "ButtonHome": "Heim", "ButtonGuide": "Sjónvarpsvísir", "ButtonGotIt": "Skilið", "ButtonFullscreen": "Fylla upp í skjá", "ButtonForgotPassword": "Gleymt Lykilorð", - "ButtonFilter": "Sía", "ButtonEditOtherUserPreferences": "Breyta stillingum notanda, mynd og persónulegum stillingum.", - "ButtonEditImages": "Breyta myndum", - "ButtonEdit": "Breyta", "ButtonChangeServer": "Skipta um þjón", "ButtonBack": "Til baka", "ButtonAudioTracks": "Hljóðspor", @@ -280,7 +267,6 @@ "HeaderDetectMyDevices": "Finna tækin mín", "HeaderFavoritePeople": "Uppáhalds Fólk", "HeaderFavoritePlaylists": "Uppáhalds spilunarlistar", - "HeaderForgotPassword": "Gleymt lykilorð", "HeaderForKids": "Fyrir Krakka", "HeaderFrequentlyPlayed": "Oft Spilað", "HeaderLatestMusic": "Tónlist, nýlega bætt við", @@ -297,8 +283,6 @@ "EveryXHours": "Hverjum {0} klukkustundum", "EveryHour": "Hverja klukkustund", "Episode": "Þáttur", - "EnableThemeVideos": "Þema myndbönd", - "EnableThemeSongs": "Þema lög", "EnablePhotos": "Birta myndir", "EnableHardwareEncoding": "Virkja vélbúnaðarkóðun", "LabelScreensaver": "Skjáhvíla:", @@ -400,14 +384,11 @@ "ThemeSongs": "Þemu lög", "TellUsAboutYourself": "Segðu okkur frá sjálfum þér", "TabUpcoming": "Væntanlegt", - "TabTrailers": "Sýnishorn", - "TabResumeSettings": "Halda áfram", "TabProfile": "Prófíll", "TabPlugins": "Viðbætur", "TabOther": "Annað", "TabNetworks": "Netkerfi", "TabMyPlugins": "Mínar viðbætur", - "TabMusicVideos": "Tónlistarmyndbönd", "TabMusic": "Tónlist", "PleaseRestartServerName": "Vinsamlegast endurræstu Jellyfin netþjóninn - {0}.", "Previous": "Fyrri", @@ -440,7 +421,6 @@ "LabelBitrate": "Bitahraði:", "LabelBirthYear": "Fæðingarár:", "LabelBirthDate": "Fæðingardagur:", - "LabelAudio": "Hljóð", "LabelArtists": "Listamenn:", "LabelAppNameExample": "Dæmi: Sickbeard, Sonarr", "LabelAccessDay": "Vikudagur:", @@ -453,7 +433,6 @@ "HeaderVideoQuality": "Myndgæði", "HeaderUsers": "Notendur", "HeaderUser": "Notandi", - "TabEpisodes": "Þættir", "TabDirectPlay": "Bein Spilun", "TabAdvanced": "Ítarlegt", "Sunday": "Sunnudagur", diff --git a/src/strings/it.json b/src/strings/it.json index cb73ea2cdb..7229f966be 100644 --- a/src/strings/it.json +++ b/src/strings/it.json @@ -53,10 +53,7 @@ "ButtonBack": "Indietro", "ButtonCancel": "Annulla", "ButtonChangeServer": "Cambia Server", - "ButtonEdit": "Modifica", - "ButtonEditImages": "Modifica Immagini", "ButtonEditOtherUserPreferences": "Modifica questo utente di profilo, l'immagine e le preferenze personali.", - "ButtonFilter": "Filtro", "ButtonForgotPassword": "Password Dimenticata", "ButtonFullscreen": "Schermo Intero", "ButtonGotIt": "Ho capito", @@ -66,15 +63,12 @@ "ButtonMore": "Altro", "ButtonNetwork": "Rete", "ButtonNextTrack": "Traccia Successiva", - "ButtonOff": "No", "ButtonOpen": "Apri", "ButtonParentalControl": "Controllo parentale", "ButtonPause": "Pausa", - "ButtonPlay": "Riproduci", "ButtonPreviousTrack": "Traccia Precedente", "ButtonProfile": "Profilo", "ButtonQuickStartGuide": "Guida rapida", - "ButtonRefresh": "Aggiorna", "ButtonRefreshGuideData": "Aggiorna la guida", "ButtonRemove": "Rimuovi", "ButtonRename": "Rinomina", @@ -94,7 +88,6 @@ "ButtonSignOut": "Esci", "ButtonStart": "Avvio", "ButtonSubmit": "Invia", - "ButtonSubtitles": "Sottotitoli", "ButtonUninstall": "Disinstalla", "ButtonWebsite": "Web", "CancelRecording": "Annulla la registrazione", @@ -179,9 +172,7 @@ "EnablePhotosHelp": "Le immagini saranno rilevate e visualizzate accanto ad altri file multimediali.", "EnableStreamLooping": "Auto-loop streaming in diretta", "EnableStreamLoopingHelp": "Abilita questo se gli streaming in diretta contengono solo pochi secondi di dati e devono essere costantemente richiesti. L'abilitazione di questa funzione quando non è servita può causare problemi.", - "EnableThemeSongs": "Canzoni a tema", "EnableThemeSongsHelp": "Le canzoni a tema saranno riprodotte mentre visualizzi la tua libreria.", - "EnableThemeVideos": "Video a tema", "EnableThemeVideosHelp": "Riproduzione dei video a tema sullo sfondo mentre visualizzi la tua libreria.", "Ended": "Finito", "EndsAtValue": "Finirà alle {0}", @@ -235,11 +226,9 @@ "HeaderActiveDevices": "Dispositivi Connessi", "HeaderActiveRecordings": "Registrazioni Attive", "HeaderActivity": "Attività", - "HeaderAddScheduledTaskTrigger": "Aggiungi operazione", "HeaderAddToCollection": "Aggiungi ad una Collezione", "HeaderAddToPlaylist": "Aggiungi alla Playlist", "HeaderAddUpdateImage": "Aggiungi/aggiorna Immagine", - "HeaderAddUser": "Aggiungi utente", "HeaderAdditionalParts": "Parti addizionali", "HeaderAdmin": "Admin", "HeaderAlbumArtists": "Artisti degli Album", @@ -251,7 +240,6 @@ "HeaderAudioBooks": "Audiolibri", "HeaderAudioSettings": "Impostazioni audio", "HeaderBlockItemsWithNoRating": "Blocca elementi sconosciuti o senza informazioni:", - "HeaderBooks": "Libri", "HeaderBranding": "Personalizza", "HeaderCancelRecording": "Annulla la Registrazione", "HeaderCancelSeries": "Annulla Serie TV", @@ -288,13 +276,11 @@ "HeaderEditImages": "Modifica Immagini", "HeaderEnabledFields": "Campi Abilitati", "HeaderEnabledFieldsHelp": "Deseleziona un campo per bloccarlo ed impedire che venga modificato.", - "HeaderEpisodes": "Episodi", "HeaderError": "Errore", "HeaderExternalIds": "ID esterni:", "HeaderFeatureAccess": "Accesso alle funzionalità", "HeaderFetchImages": "Identifica Immagini:", "HeaderForKids": "Per Bambini", - "HeaderForgotPassword": "Password dimenticata", "HeaderFrequentlyPlayed": "Visti di frequente", "HeaderGuideProviders": "Provider Guida", "HeaderHttpHeaders": "Header HTTP", @@ -320,7 +306,6 @@ "HeaderLiveTvTunerSetup": "Configura Ricevitore TV", "HeaderLoginFailure": "Errore di accesso", "HeaderMediaFolders": "Cartelle dei media", - "HeaderMediaInfo": "Informazioni Media", "HeaderMetadataSettings": "Impostazioni Metadati", "HeaderMoreLikeThis": "Simili a questo", "HeaderMusicQuality": "Qualità Musica", @@ -475,7 +460,6 @@ "LabelCustomCertificatePathHelp": "Percorso del file PKCS #12 contenente il certificato e la chiave private per abilitare il supporto TLS in un dominio personalizzato.", "LabelCustomCss": "CSS Personalizzato:", "LabelCustomCssHelp": "Applica il tuo stile personale all'interfaccia web.", - "LabelCustomDeviceDisplayName": "Nome da visualizzare:", "LabelCustomDeviceDisplayNameHelp": "Fornire un nome di visualizzazione personalizzato o lasciare vuoto per utilizzare il nome riportato dal dispositivo.", "LabelCustomRating": "Voto personalizzato:", "LabelDateAdded": "Aggiunto il:", @@ -492,7 +476,6 @@ "LabelDiscNumber": "Numero disco:", "LabelDisplayLanguage": "Lingua di visualizzazione:", "LabelDisplayLanguageHelp": "La traduzione di Jellyfin è un progetto attivo.", - "LabelDisplayMissingEpisodesWithinSeasons": "Visualizza gli episodi mancanti nelle stagioni", "LabelDisplayMode": "Modalità di visualizzazione:", "LabelDisplayName": "Nome visualizzato:", "LabelDisplayOrder": "Ordine di visualizzazione:", @@ -642,7 +625,6 @@ "LabelPostProcessorArguments": "Argomenti linea di comando del Post-processor:", "LabelPostProcessorArgumentsHelp": "Usa {path} come percorso al file di registrazione.", "LabelPreferredDisplayLanguage": "Lingua preferita visualizzata:", - "LabelPreferredDisplayLanguageHelp": "La traduzione di Jellyfin è un progetto attivo.", "LabelPreferredSubtitleLanguage": "Lingua dei sottotitoli preferita:", "LabelProfileAudioCodecs": "Codec Audio:", "LabelProfileCodecs": "Codec:", @@ -699,7 +681,6 @@ "LabelSubtitleDownloaders": "Downloader sottotitoli:", "LabelSubtitleFormatHelp": "Esempio: srt", "LabelSubtitlePlaybackMode": "Modalità Sottotitolo:", - "LabelSubtitles": "Sottotitoli", "LabelSupportedMediaTypes": "Tipi di media supportati:", "LabelTVHomeScreen": "Schermata iniziale della modalità TV:", "LabelTagline": "Slogan:", @@ -711,12 +692,9 @@ "LabelTimeLimitHours": "Tempo limite (ore):", "LabelTitle": "Titolo:", "LabelTrackNumber": "Numero traccia:", - "LabelTranscodingAudioCodec": "Codec Audio:", - "LabelTranscodingContainer": "contenitore:", "LabelTranscodingTempPathHelp": "Specifica un percorso personalizzato per la transcodifica dei files utilizzati dai client. Lasciare vuoto per utilizzare l'impostazione predefinita dal server.", "LabelTranscodingThreadCount": "Transcodifica numero di thread:", "LabelTranscodingThreadCountHelp": "Selezionare il numero massimo di thread da utilizzare durante la transcodifica. Ridurre il numero di thread si abbasserà l'utilizzo della CPU, ma può non convertire abbastanza veloce per un'esperienza di riproduzione fluida.", - "LabelTranscodingVideoCodec": "Codec Video:", "LabelTriggerType": "Tipo Evento:", "LabelTunerIpAddress": "Tuner Indirizzo IP:", "LabelTunerType": "Tipo sintonizzatore:", @@ -816,7 +794,6 @@ "MessagePluginConfigurationRequiresLocalAccess": "Per configurare questo plugin si prega di accedere al proprio server locale direttamente.", "MessagePluginInstallDisclaimer": "I plugin creati dai membri della comunità Jellyfin sono un ottimo modo per migliorare l'esperienza di Jellyfin con funzionalità e vantaggi aggiuntivi. Prima di installare, si prega di notare gli effetti che possono avere sul tuo server Jellyfin, come le scansioni più lunghe della libreria, l'elaborazione di sfondo aggiuntiva e la stabilità del sistema diminuita.", "MessageReenableUser": "Guarda in basso per ri-abilitare", - "MessageSettingsSaved": "Settaggi salvati.", "MessageTheFollowingLocationWillBeRemovedFromLibrary": "I seguenti percorsi ai file multimediali saranno rimossi dalla tua libreria:", "MessageUnableToConnectToServer": "Non siamo in grado di connettersi al server selezionato al momento. Per favore assicurati che sia in esecuzione e riprova.", "MessageUnsetContentHelp": "Il contenuto verrà visualizzato come pianura cartelle. Per ottenere i migliori risultati utilizzare il gestore di metadati per impostare i tipi di contenuto di sottocartelle.", @@ -1100,16 +1077,13 @@ "SystemDlnaProfilesHelp": "I profili di sistema sono in sola lettura. Le modifiche ad un profilo di sistema verranno salvate in un nuovo profilo personalizzato.", "TabAccess": "Accesso", "TabAdvanced": "Avanzato", - "TabAlbumArtists": "Artisti degli Album", "TabCatalog": "Catalogo", "TabCodecs": "Codec", "TabContainers": "Contenitori", "TabDashboard": "Pannello Controllo", "TabDirectPlay": "Riproduzione Diretta", - "TabEpisodes": "Episodi", "TabLatest": "Novità", "TabMusic": "Musica", - "TabMusicVideos": "Video Musicali", "TabMyPlugins": "I miei Plug-in", "TabNetworks": "Reti", "TabNfoSettings": "Impostazioni NFO", @@ -1119,10 +1093,8 @@ "TabProfile": "Profilo", "TabProfiles": "Profili", "TabResponses": "Risposte", - "TabResumeSettings": "Riprendi", "TabScheduledTasks": "Operazioni Pianificate", "TabSettings": "Impostazioni", - "TabTrailers": "Trailer", "TabUpcoming": "In Arrivo", "Tags": "Tag", "TellUsAboutYourself": "Parlaci di te", @@ -1196,7 +1168,6 @@ "Banner": "Banner", "Blacklist": "Blacklist", "Box": "Scatola", - "ButtonHome": "Home", "ButtonInfo": "Info", "ButtonOk": "Ok", "ButtonStop": "Stop", @@ -1209,7 +1180,6 @@ "HeaderApp": "Applicazione", "HeaderAppearsOn": "Appare In", "HeaderCastAndCrew": "Cast", - "HeaderCastCrew": "Cast", "HeaderMedia": "Media", "HeaderPassword": "Password", "AuthProviderHelp": "Selezionare un provider di autenticazione da utilizzare per autenticare la password dell'utente.", @@ -1224,15 +1194,12 @@ "HeaderImageOptions": "Opzioni Immagine", "Home": "Home", "LabelAlbum": "Album:", - "LabelAudio": "Audio", "LabelCache": "Cache:", "ButtonAddImage": "Aggiungi Immagine", "CopyStreamURL": "Copia Indirizzo dello Stream", "CopyStreamURLSuccess": "Indirizzo copiato con successo.", "FetchingData": "Recupero di dati aggiuntivi", "LabelServerHost": "Host:", - "OptionAutomatic": "Automatico", - "HeaderHome": "Home", "LabelServerHostHelp": "192.168.1.100:8096 o https://myserver.com", "HeaderFavoriteBooks": "Libri Preferiti", "HeaderTypeImageFetchers": "{0} Sorgenti Immagini", @@ -1340,7 +1307,6 @@ "Studios": "Studios", "SubtitleOffset": "Sfasamento Sottotitolo", "TV": "TV", - "TabInfo": "Informazioni", "TabLogs": "Log", "TabNetworking": "Rete", "TabPlugins": "Plugin", diff --git a/src/strings/ja.json b/src/strings/ja.json index 1c3d8fe30e..30413c2ad6 100644 --- a/src/strings/ja.json +++ b/src/strings/ja.json @@ -63,15 +63,11 @@ "ButtonBack": "戻る", "ButtonCancel": "キャンセル", "ButtonChangeServer": "サーバーを変更", - "ButtonEdit": "編集", - "ButtonEditImages": "イメージを編集", "ButtonEditOtherUserPreferences": "ユーザーのアバターイメージやプロフィールなどの個人設定を編集。", - "ButtonFilter": "フィルタ", "ButtonForgotPassword": "パスワードを忘れた", "ButtonFullscreen": "フルスクリーン", "ButtonGotIt": "了解", "ButtonGuide": "ガイド", - "ButtonHome": "ホーム", "ButtonInfo": "情報", "ButtonLibraryAccess": "ライブラリへアクセス", "ButtonManualLogin": "マニュアルログイン", @@ -82,11 +78,9 @@ "ButtonOpen": "開く", "ButtonParentalControl": "ペアレンタルコントロール", "ButtonPause": "一時停止", - "ButtonPlay": "再生", "ButtonPreviousTrack": "前のトラック", "ButtonProfile": "プロフィール", "ButtonQuickStartGuide": "クイックスタートガイド", - "ButtonRefresh": "更新", "ButtonRefreshGuideData": "ガイドデータの更新", "ButtonRemove": "削除", "ButtonRename": "名前の変更", @@ -107,7 +101,6 @@ "ButtonStart": "スタート", "ButtonStop": "ストップ", "ButtonSubmit": "提出", - "ButtonSubtitles": "字幕", "ButtonTrailer": "予告", "ButtonUninstall": "アンインストール", "ButtonWebsite": "ウェブサイト", @@ -193,9 +186,7 @@ "EnablePhotosHelp": "写真が検出され、他のメディアファイルと一緒に表示されます。", "EnableStreamLooping": "ライブストリームの自動ループ", "EnableStreamLoopingHelp": "ライブストリームに数秒のデータしか含まれず、継続的に要求する必要がある場合は、これを有効にします。不要なときにこれを有効にすると、問題が発生する可能性があります。", - "EnableThemeSongs": "テーマ曲", "EnableThemeSongsHelp": "ライブラリを閲覧している間バックグラウンドでテーマ曲を再生する。", - "EnableThemeVideos": "テーマ動画", "EnableThemeVideosHelp": "ライブラリを閲覧中にバックグラウンドでテーマ動画を再生します。", "Ended": "終了", "EndsAtValue": "{0}に終了", @@ -204,7 +195,6 @@ "HeaderMoreLikeThis": "これに似たもの", "InstantMix": "インスタントミックス", "MoreFromValue": "もっと詳しく {0}", - "ButtonOff": "オフ", "ColorTransfer": "Color transfer", "DeathDateValue": "死亡日:{0}", "Depressed": "陰鬱", @@ -260,11 +250,9 @@ "HeaderActiveDevices": "アクティブデバイス", "HeaderActiveRecordings": "アクティブな録画", "HeaderActivity": "アクティビティ", - "HeaderAddScheduledTaskTrigger": "トリガーを追加", "HeaderAddToCollection": "コレクションに追加", "HeaderAddToPlaylist": "プレイリストに追加", "HeaderAddUpdateImage": "イメージの追加/更新", - "HeaderAddUser": "ユーザーの追加", "HeaderAdditionalParts": "追加のパーツ", "HeaderAdmin": "管理者", "HeaderAlbumArtists": "アルバムアーティスト", @@ -278,12 +266,10 @@ "HeaderAudioBooks": "オーディオブック", "HeaderAudioSettings": "音声設定", "HeaderBlockItemsWithNoRating": "評価情報がない、または認識できないアイテムをブロックします。", - "HeaderBooks": "ブック", "HeaderBranding": "ブランディング", "HeaderCancelRecording": "録画の停止", "HeaderCancelSeries": "シリーズをキャンセル", "HeaderCastAndCrew": "キャスト&クルー", - "HeaderCastCrew": "キャスト&クルー", "HeaderChannelAccess": "チャンネルアクセス", "HeaderChapterImages": "チャプターイメージ", "HeaderCodecProfile": "コーデックプロファイル", @@ -317,7 +303,6 @@ "HeaderEditImages": "イメージの編集", "HeaderEnabledFields": "有効なフィールド", "HeaderEnabledFieldsHelp": "フィールドをオフにしてロックし、データが変更されないようにします。", - "HeaderEpisodes": "エピソード", "HeaderError": "エラー", "HeaderExternalIds": "外部ID:", "HeaderFavoriteMovies": "お気に入りのムービー", @@ -331,10 +316,8 @@ "HeaderFetchImages": "画像を取得する:", "HeaderFetcherSettings": "フェッチャー設定", "HeaderForKids": "子供向け", - "HeaderForgotPassword": "パスワードを忘れました", "HeaderFrequentlyPlayed": "よく再生する", "HeaderGuideProviders": "TV番組情報のプロバイダ", - "HeaderHome": "ホーム", "HeaderHttpHeaders": "HTTPヘッダー", "HeaderIdentification": "識別", "HeaderIdentificationCriteriaHelp": "少なくとも1つの識別基準を入力してください。", @@ -360,7 +343,6 @@ "HeaderLoginFailure": "ログイン失敗", "HeaderMedia": "メディア", "HeaderMediaFolders": "メディアフォルダ", - "HeaderMediaInfo": "メディア情報", "HeaderMetadataSettings": "メタデータ設定", "HeaderMusicQuality": "ミュージックの品質", "HeaderMusicVideos": "ミュージックビデオ", @@ -511,7 +493,6 @@ "LabelOptionalNetworkPath": "(任意) 共有ネットワークフォルダー:", "LabelOriginalAspectRatio": "元のアスペクト比:", "LabelServerName": "サーバー名:", - "LabelSubtitles": "字幕", "LabelSupportedMediaTypes": "サポートされているメディアタイプ:", "LabelTVHomeScreen": "TVモードホームスクリーン:", "LabelTextColor": "文字色:", @@ -524,11 +505,9 @@ "MessageItemSaved": "アイテムを保存しました。", "MessageItemsAdded": "アイテムを追加しました。", "MessagePleaseWait": "お待ち下さい。この処理には数分かかります。", - "MessageSettingsSaved": "設定を保存しました。", "MessageReenableUser": "最有効するためには以下を参照してください", "Name": "名前", "NewCollection": "新しいコレクション", - "OptionAutomatic": "自動", "OptionAscending": "昇順", "OptionAuto": "自動", "OptionBlockBooks": "ブック", @@ -563,7 +542,6 @@ "Sunday": "日曜日", "CopyStreamURLSuccess": "URLのコピーが成功しました。", "TabDirectPlay": "直接再生", - "TabEpisodes": "エピソード", "LabelDefaultUser": "デフォルトユーザー:", "Trailers": "トレーラー", "LabelRecord": "レコード:", @@ -606,7 +584,6 @@ "LabelCurrentPassword": "現在のパスワード:", "LabelCustomCss": "カスタムCSS:", "LabelCustomCssHelp": "ウェブインターフェースにカスタムスタイルを適応する。", - "LabelCustomDeviceDisplayName": "表示名:", "LabelEnableDlnaClientDiscoveryInterval": "クライアント探索間隔", "LabelParentalRating": "個人評価:", "LabelPassword": "パスワード:", @@ -702,7 +679,6 @@ "TV": "TV", "TabAccess": "アクセス", "TabAdvanced": "高度", - "TabAlbumArtists": "アルバムアーティスト", "TabCatalog": "カタログ", "TabCodecs": "コーデック", "TabContainers": "コンテナ", @@ -712,11 +688,9 @@ "SaveSubtitlesIntoMediaFolders": "字幕をメディアフォルダーに保存", "ScanForNewAndUpdatedFiles": "新しいファイルとアップデートされたファイルをスキャン", "TabDashboard": "ダッシュボード", - "TabInfo": "情報", "TabLatest": "最新", "TabLogs": "ログ", "TabMusic": "ミュージック", - "TabMusicVideos": "ミュージックビデオ", "TheseSettingsAffectSubtitlesOnThisDevice": "これらの設定はこのデバイスの字幕に影響します", "ShowTitle": "タイトルを表示", "TitleHostingSettings": "ホスト設定", @@ -787,7 +761,6 @@ "LabelAllowedRemoteAddresses": "リモートIPアドレスフィルター:", "LabelAppNameExample": "例: スケートボード、ソナー", "LabelArtists": "アーティスト:", - "LabelAudio": "音声", "LabelAudioBitDepth": "音声ビット深度:", "LabelAudioBitrate": "音声ビットレート:", "LabelAudioChannels": "音声チャンネル:", @@ -872,11 +845,9 @@ "LabelTheme": "テーマ:", "LabelTitle": "題:", "LabelTrackNumber": "トラック数:", - "LabelTranscodingAudioCodec": "音声コーデック:", "LabelTranscodes": "トランスコード:", "LabelTranscodingFramerate": "トランスコーディングフレームレート:", "LabelTranscodingProgress": "トランスコーディング進行度:", - "LabelTranscodingVideoCodec": "映像コーデック:", "LabelType": "タイプ:", "LabelTypeText": "文字:", "LabelUser": "ユーザー:", @@ -1001,7 +972,6 @@ "TabServer": "サーバー", "TabSettings": "設定", "TabStreaming": "ストリーミング", - "TabTrailers": "トレーラー", "MessageContactAdminToResetPassword": "パスワードをリセットするためにシステムの管理者に連絡してください。", "TagsValue": "タグ: {0}", "MessageInvalidUser": "ユーザー名かパスワードが無効です。再試行してください。", @@ -1030,7 +1000,6 @@ "LabelEnableDlnaServer": "DLNAサーバーの有効化", "LabelEnableDlnaDebugLogging": "DLNAデバッグログの有効化", "LabelDroppedFrames": "ドロップフレーム:", - "LabelDisplayMissingEpisodesWithinSeasons": "シーズン中の見つからなかったエピソードを表示", "LabelCustomDeviceDisplayNameHelp": "任意の表示名を提供するか、空白のままにしてデバイスネームで報告する。", "LabelArtistsHelp": "複数のアーティストは「;」で分ける。", "Identify": "識別する", diff --git a/src/strings/kk.json b/src/strings/kk.json index 3f20e5ca10..90176b0335 100644 --- a/src/strings/kk.json +++ b/src/strings/kk.json @@ -62,31 +62,24 @@ "ButtonBack": "Artqa", "ButtonCancel": "Boldyrmaý", "ButtonChangeServer": "Serverdi aýystyrý", - "ButtonEdit": "Óńdeý", - "ButtonEditImages": "Sýretterdi óńdeý", "ButtonEditOtherUserPreferences": "Osy paıdalanýshynyń profaılyn, sýretin jáne ózindik teńshelimderin óńdeý.", - "ButtonFilter": "Súzý", "ButtonForgotPassword": "Paróldi eske salý", "ButtonFullscreen": "Tolyq ekran", "ButtonGotIt": "Túsinikti", "ButtonGuide": "Telegıd", - "ButtonHome": "Basqyǵa", "ButtonInfo": "Aqparatqa", "ButtonLibraryAccess": "Tasyǵyshhanǵa qatynaý", "ButtonManualLogin": "Qolmen kirý", "ButtonMore": "Kóbirek", "ButtonNetwork": "Jeli", "ButtonNextTrack": "Kelesi jolshyqqa", - "ButtonOff": "Óshir", "ButtonOk": "Jaraıdy", "ButtonOpen": "Ashý", "ButtonParentalControl": "Mazmundy basqarý", "ButtonPause": "Úzý", - "ButtonPlay": "Oınatý", "ButtonPreviousTrack": "Aldyńǵy jolshyqqa", "ButtonProfile": "Profaıl", "ButtonQuickStartGuide": "Tez bastaý nusqaýlyǵy", - "ButtonRefresh": "Jańǵyrtý", "ButtonRefreshGuideData": "Telegıd derekterin jańǵyrtý", "ButtonRemove": "Alastaý", "ButtonRename": "Qaıta ataý", @@ -107,7 +100,6 @@ "ButtonStart": "Bastaý", "ButtonStop": "Toqtatý", "ButtonSubmit": "Jiberý", - "ButtonSubtitles": "Sýbtıtrlerge", "ButtonTrailer": "Treıler", "ButtonUninstall": "Ornatymdy joıý", "ButtonWebsite": "Ýeb-saıty", @@ -195,9 +187,7 @@ "EnablePhotosHelp": "Sýretter basqa tasyǵysh faıldarymen qatar anyqtalady jáne beınelenedi.", "EnableStreamLooping": "Taratýlardy avtomatty tuıyqtaý", "EnableStreamLoopingHelp": "Eger taratý derekterinde tek qana azyn-aýlaq sekýnd bar bolsa jáne ony úzdiksiz suratyp alý qajet bolsa, ony qosyńyz. Bul qajet bolmaǵan jaǵdaıda qosylsa, qıyndyqtar týdyrýy múmkin.", - "EnableThemeSongs": "Taqyryptyq áýender", "EnableThemeSongsHelp": "Taqyryptyq áýender tasyǵyshhanany sholý kezinde óńde oınatylady.", - "EnableThemeVideos": "Taqyryptyq beıneler", "EnableThemeVideosHelp": "Taqyryptyq beıneler tasyǵyshhanany sholý kezinde óńde oınatylady.", "Ended": "Aıaqtaldy", "EndsAtValue": "Sońy: {0}", @@ -254,11 +244,9 @@ "HeaderActiveDevices": "Belsendi qurylǵylar", "HeaderActiveRecordings": "Belsendi jazbalar", "HeaderActivity": "Áreketter", - "HeaderAddScheduledTaskTrigger": "Trıger ústeý", "HeaderAddToCollection": "Jıyntyqqa ústeý", "HeaderAddToPlaylist": "Oınatý tizimine ústeý", "HeaderAddUpdateImage": "Sýret ústeý/jańartý", - "HeaderAddUser": "Paıdalanýshy ústeý", "HeaderAdditionalParts": "Jalǵasatyn bólimder", "HeaderAdmin": "Basqarý", "HeaderAlbumArtists": "Álbom oryndaýshylary", @@ -272,12 +260,10 @@ "HeaderAudioBooks": "Dybystyq kitaptar", "HeaderAudioSettings": "Dybys parametrleri", "HeaderBlockItemsWithNoRating": "Jastas sanaty týraly aqparaty joq nemese ol tanylmaǵan mazmundy qursaýlaý:", - "HeaderBooks": "Kitaptar", "HeaderBranding": "Bezendirý", "HeaderCancelRecording": "Jazýdy boldyrmaý", "HeaderCancelSeries": "Telehıkaıany boldyrmaý", "HeaderCastAndCrew": "Róldegiler men qyzmetkerler", - "HeaderCastCrew": "Róldegiler men qyzmetkerler", "HeaderChannelAccess": "Arnaǵa qatynaý", "HeaderChapterImages": "Sahna sýretteri", "HeaderCodecProfile": "Kodek profaıly", @@ -311,14 +297,12 @@ "HeaderEditImages": "Sýretterdi óńdeý", "HeaderEnabledFields": "Qosylǵan órister", "HeaderEnabledFieldsHelp": "Qursaýlaý úshin jáne derekter ózgertýine tyıym salý úshin, óristen qusbelgini alyńyz.", - "HeaderEpisodes": "TD-bólimder", "HeaderError": "Qate", "HeaderExternalIds": "Syrtqy sáıkestendirgishter:", "HeaderFeatureAccess": "Erekshelikterge qatynaý", "HeaderFetchImages": "Sýretterdi irikteý:", "HeaderFetcherSettings": "Irikteýshi parametrleri", "HeaderForKids": "Balalyq", - "HeaderForgotPassword": "Paróldi umytyńyz ba", "HeaderFrequentlyPlayed": "Jıi oınatylǵandar", "HeaderGuideProviders": "Telegıd derekterin jetkizýshileri", "HeaderHttpHeaders": "HTTP ústińgi derektemeleri", @@ -347,7 +331,6 @@ "HeaderLoginFailure": "Kirý sátsizdigi", "HeaderMedia": "Tasyǵyshderekter", "HeaderMediaFolders": "Tasyǵysh qaltalary", - "HeaderMediaInfo": "Tasyǵyshderekter týraly", "HeaderMetadataSettings": "Metaderekter parametrleri", "HeaderMoreLikeThis": "Osy sıaqty kóbirek", "HeaderMusicQuality": "Mýzyka sapasy", @@ -480,7 +463,6 @@ "LabelAppNameExample": "Mysaly: Sickbeard, Sonarr", "LabelArtists": "Oryndaýshylar:", "LabelArtistsHelp": "Birneshýin mynaýmen bólińiz ;", - "LabelAudio": "Dybys", "LabelAudioLanguagePreference": "Dybys tiliniń teńshelimi:", "LabelAutomaticallyRefreshInternetMetadataEvery": "Metaderekterdi Internetten avtomatty jańartý:", "LabelBindToLocalNetworkAddress": "Jergilikti jeli mekenjaıyna baılastyrý:", @@ -508,7 +490,6 @@ "LabelCustomCertificatePathHelp": "Teńsheletin domende TLS qoldaýyn qosý úshin sertıfıkaty jáne jeke kilti bar PKCS #12 faılyna jol.", "LabelCustomCss": "Teńsheýli CSS:", "LabelCustomCssHelp": "Ózińizdiń teńsheýli mánerleýdi ýeb-tildesýde qoldanyńyz.", - "LabelCustomDeviceDisplayName": "Beınelený aty:", "LabelCustomDeviceDisplayNameHelp": "Beınelenetin teńshelgen atyn usynyńyz nemese qurylǵy arqyly baıandalǵan atyn paıdalaný úshin bos qaldyryńyz.", "LabelCustomRating": "Teńshelgen sanat:", "LabelDateAdded": "Ústelgen kúni:", @@ -525,7 +506,6 @@ "LabelDiscNumber": "Dıski nómiri:", "LabelDisplayLanguage": "Beıneleý tili:", "LabelDisplayLanguageHelp": "Jellyfin tárjimeleýi aǵymdaǵy joba bolyp tabylady.", - "LabelDisplayMissingEpisodesWithinSeasons": "Joq bólimderdi maýsym ishinde beıneleý", "LabelDisplayMode": "Beıneleý rejimi:", "LabelDisplayName": "Beınelený aty:", "LabelDisplayOrder": "Beıneleý reti:", @@ -680,7 +660,6 @@ "LabelPostProcessorArguments": "Post-prosesor pármen jolynyń argýmentteri:", "LabelPostProcessorArgumentsHelp": "Jazylatyn faıl joly esebinde {path} paıdalanyńyz.", "LabelPreferredDisplayLanguage": "Beıneleý tiliniń teńshelimi:", - "LabelPreferredDisplayLanguageHelp": "Jellyfin tárjimeleýi aǵymdaǵy joba bolyp tabylady.", "LabelPreferredSubtitleLanguage": "Sýbtıtr tiliniń teńshelimi:", "LabelProfileAudioCodecs": "Dybystyq kodekter:", "LabelProfileCodecs": "Kodekter:", @@ -740,7 +719,6 @@ "LabelSubtitleDownloaders": "Sýbtıtrler júkteýshileri:", "LabelSubtitleFormatHelp": "Mysal: srt", "LabelSubtitlePlaybackMode": "Sýbtıtr rejimi:", - "LabelSubtitles": "Sýbtıtrler", "LabelSupportedMediaTypes": "Qoldaýdaǵy tasyǵyshderekter túrleri:", "LabelTVHomeScreen": "TD rejimindegi basqy ekran:", "LabelTag": "Teg:", @@ -753,12 +731,9 @@ "LabelTimeLimitHours": "Ýaqyt shegi (saǵat):", "LabelTitle": "Ataýy:", "LabelTrackNumber": "Jolshyq nómiri:", - "LabelTranscodingAudioCodec": "Dybystyq kodek:", - "LabelTranscodingContainer": "Konteıner:", "LabelTranscodingTempPathHelp": "Klıentterge qyzmet etetin qaıta kodtaý faıldar úshin teńshelgen jolyn kórsetińiz. Server ádepkisin paıdalaný úshin bos qaldyryńyz.", "LabelTranscodingThreadCount": "Qaıta qodtaý tizbekterdiń sany:", "LabelTranscodingThreadCountHelp": "Qaıta kodtaý kezinde paıdalanatyn eń kóp tizbek sanyn tańdańyz. Tizbek sanyn azaıtý OP paıdalanýyn tómendetedi, biraq jatyq oınatý áseri úshin tez túrlendirýge jetkilikti bolmaýy múmkin.", - "LabelTranscodingVideoCodec": "Beınelik kodek:", "LabelTriggerType": "Trıgger túri:", "LabelTunerIpAddress": "Túnerdiń IP-mekenjaıy:", "LabelTunerType": "Túner túri:", @@ -868,7 +843,6 @@ "MessagePluginConfigurationRequiresLocalAccess": "Osy plagındi teńsheý úshin jergilikti serverińizge tikeleı kirińiz.", "MessagePluginInstallDisclaimer": "Jellyfin qaýymdastyǵy múshelerimen qurylǵan plagınder Jellyfin tájirıbeńizdi qosymsha múmkindiktermen jáne jeńildiktermen jaqsartý úshin jaqsy tásili bolyp tabylady. Ornatpas buryn, olar Jellyfin serverińizge tasyǵyshhanany uzaq skanerleý, qosymsha óńdik óńdetý jáne júıeniń turaqtylyǵyn tómendetý sıaqty áserler etýge múmkin bolýyna habardar bolyńyz.", "MessageReenableUser": "Qaıta qosý úshin tómende qarańyz", - "MessageSettingsSaved": "Parametrler saqtaldy.", "MessageTheFollowingLocationWillBeRemovedFromLibrary": "Tasyǵyshhanańyzdan kelesi tasyǵysh ornalasýlary alastalady:", "MessageUnableToConnectToServer": "Tańdalǵan serverge qosylýymyz dál qazir múmkin emes. Bul iske qosylǵanyna kóz jetkizińiz jáne áreketti keıin qaıtalańyz.", "MessageUnsetContentHelp": "Mazmun kádimgi qaltalar retinde beınelenedi. Eń jaqsy nátıjeler alý úshin, ishki qaltalardyń mazmún túrlerin ornatyp Metaderek retteýshini paıdalanyńyz.", @@ -934,7 +908,6 @@ "OptionArtist": "Oryndaýshy", "OptionAscending": "Artýy boıynsha", "OptionAuto": "Avtomatty", - "OptionAutomatic": "Avtomatty", "OptionAutomaticallyGroupSeries": "Birneshe qaltalar arasynda taralǵan telehıkaıany avtomatty bir telehıkaıaǵa biriktirý", "OptionAutomaticallyGroupSeriesHelp": "Qosylǵanda, osy tasyǵyshhana ishindegi birneshe qaltalar arasynda taralǵan telehıkaıasy avtomatty bir telehıkaıaǵa biriktiriletin bolady.", "OptionBlockBooks": "Kitaptar", @@ -1176,18 +1149,14 @@ "TV": "TD", "TabAccess": "Qatynaý", "TabAdvanced": "Keńeıtilgen", - "TabAlbumArtists": "Álbom oryndaýshylary", "TabCatalog": "Tizimdeme", "TabCodecs": "Kodekter", "TabContainers": "Konteınerler", "TabDashboard": "Taqta", "TabDirectPlay": "Tikeleı oınatý", - "TabEpisodes": "TD-bólimder", - "TabInfo": "Profaıl týraly", "TabLatest": "Eń keıingi", "TabLogs": "Jurnaldar", "TabMusic": "Mýzyka", - "TabMusicVideos": "Mýzykalyq beıneler", "TabMyPlugins": "Meniń plagınderim", "TabNetworks": "Jeliler", "TabNfoSettings": "NFO parametrleri", @@ -1198,12 +1167,10 @@ "TabProfile": "Profaıl", "TabProfiles": "Profaıldar", "TabResponses": "Ún qatýlar", - "TabResumeSettings": "Jalǵastyrý", "TabScheduledTasks": "Josparlaýshy", "TabServer": "Server", "TabSettings": "Parametrler", "TabStreaming": "Tasymaldaný", - "TabTrailers": "Treılerler", "TabUpcoming": "Kútilgen", "Tags": "Tegter", "TagsValue": "Tegter: {0}", @@ -1286,7 +1253,6 @@ "HeaderFavoriteArtists": "Tańdaýly oryndaýshylar", "HeaderFavoriteSongs": "Tańdaýly áýender", "HeaderFavoriteVideos": "Tandaýly beıneler", - "HeaderHome": "Basqy", "LabelAuthProvider": "Túpnusqalyq rastamasyn jetkizýshi:", "LabelPasswordResetProvider": "Paróldi ysyrý jetkizýshisi:", "LabelServerName": "Server aty:", diff --git a/src/strings/ko.json b/src/strings/ko.json index 79153c0962..cdb2711a48 100644 --- a/src/strings/ko.json +++ b/src/strings/ko.json @@ -21,13 +21,10 @@ "ButtonBack": "뒤로", "ButtonCancel": "취소", "ButtonChangeServer": "서버 변경", - "ButtonEdit": "편집", "ButtonEditOtherUserPreferences": "이 사용자의 프로필, 이미지, 개인 설정을 수정합니다.", - "ButtonFilter": "필터", "ButtonForgotPassword": "비밀번호 분실", "ButtonGotIt": "알겠습니다", "ButtonGuide": "가이드", - "ButtonHome": "홈", "ButtonInfo": "정보", "ButtonManualLogin": "수동 로그인", "ButtonMore": "더 보기", @@ -36,11 +33,9 @@ "ButtonOk": "OK", "ButtonOpen": "열기", "ButtonPause": "일시 중지", - "ButtonPlay": "재생", "ButtonPreviousTrack": "이전 트랙", "ButtonProfile": "프로필", "ButtonQuickStartGuide": "빠른 시작 가이드", - "ButtonRefresh": "새로 고침", "ButtonRefreshGuideData": "가이드 데이터 새로 고침", "ButtonRemove": "제거", "ButtonRename": "이름 변경", @@ -59,7 +54,6 @@ "ButtonStart": "시작", "ButtonStop": "중지", "ButtonSubmit": "제출", - "ButtonSubtitles": "자막", "ButtonUninstall": "제거", "ButtonWebsite": "웹사이트", "ChannelAccessHelp": "이 사용자와 공유할 채널을 선택합니다. 관리자는 메타데이터 매니저를 사용하여 모든 채널을 수정할 수 있습니다.", @@ -106,11 +100,9 @@ "HeaderActiveDevices": "활성화된 기기", "HeaderActiveRecordings": "활성화된 녹화", "HeaderActivity": "활성화", - "HeaderAddScheduledTaskTrigger": "트리거 추가", "HeaderAddToCollection": "컬렉션에 추가", "HeaderAddToPlaylist": "재생목록에 추가", "HeaderAddUpdateImage": "이미지 추가/업데이트", - "HeaderAddUser": "사용자 추가", "HeaderAdditionalParts": "추가 장면", "HeaderAdmin": "관리자", "HeaderAlert": "알림", @@ -118,9 +110,7 @@ "HeaderApiKeys": "API 키", "HeaderApp": "앱", "HeaderAudioSettings": "오디오 설정", - "HeaderBooks": "도서", "HeaderBranding": "브랜딩", - "HeaderCastCrew": "배역 및 제작진", "HeaderChannelAccess": "채널 접속", "HeaderCodecProfile": "코덱 프로필", "HeaderConfirmProfileDeletion": "프로필 삭제 확인", @@ -140,7 +130,6 @@ "HeaderError": "오류", "HeaderFeatureAccess": "기능 접근", "HeaderFetchImages": "이미지 가져오기:", - "HeaderForgotPassword": "비밀번호 분실", "HeaderFrequentlyPlayed": "자주 재생함", "HeaderGuideProviders": "가이드 제공자", "HeaderIdentification": "식별자", @@ -158,7 +147,6 @@ "HeaderLoginFailure": "로그인 실패", "HeaderMedia": "미디어", "HeaderMediaFolders": "미디어 폴더", - "HeaderMediaInfo": "미디어 정보", "HeaderMetadataSettings": "메타데이터 설정", "HeaderMusicVideos": "뮤직비디오", "HeaderMyMedia": "내 미디어", @@ -262,7 +250,6 @@ "LabelCustomCertificatePathHelp": "커스텀 도메인에서 TLS를 지원할 수 있도록 인증서 및 개인키가 포함 된 PKCS #12 파일의 경로입니다.", "LabelCustomCss": "사용자 지정 CSS:", "LabelCustomCssHelp": "사용자 정의 스타일링을 웹 인터페이스에 적용합니다.", - "LabelCustomDeviceDisplayName": "표시 이름:", "LabelCustomRating": "사용자 평점:", "LabelDateAdded": "추가한 날짜:", "LabelDateAddedBehavior": "새 콘텐츠에 대한 날짜 추가 동작:", @@ -273,7 +260,6 @@ "LabelDefaultUserHelp": "연결된 장치에 어떤 사용자 라이브러리를 표시할 지 결정합니다. 이 설정은 각 장치의 사용중인 프로필을 대체합니다.", "LabelDeviceDescription": "장치 설명", "LabelDidlMode": "DIDL 모드:", - "LabelDisplayMissingEpisodesWithinSeasons": "각 시즌의 누락된 에피소드 표시", "LabelDisplayName": "표시 이름:", "LabelDisplayOrder": "표시 순서:", "LabelDisplaySpecialsWithinSeasons": "방송한 시즌 내에서 스페셜을 표시합니다", @@ -375,7 +361,6 @@ "LabelPlayDefaultAudioTrack": "언어에 상관없이 기본 오디오 트랙 재생", "LabelPlaylist": "재생목록:", "LabelPreferredDisplayLanguage": "선호하는 화면 언어:", - "LabelPreferredDisplayLanguageHelp": "Jellyfin 번역은 진행중인 프로젝트입니다.", "LabelProfileAudioCodecs": "오디오 코덱:", "LabelProfileCodecs": "코덱:", "LabelProfileCodecsHelp": "쉼표로 구분합니다. 모든 코덱에 적용할 수 있도록 빈 칸을 남겨둘 수 있습니다.", @@ -414,10 +399,7 @@ "LabelTime": "시각:", "LabelTimeLimitHours": "시간 제한 (시간):", "LabelTrackNumber": "트랙 번호:", - "LabelTranscodingAudioCodec": "오디오 코덱:", - "LabelTranscodingContainer": "컨테이너:", "LabelTranscodingTempPathHelp": "클라이언트로 제공될 트랜스코딩 파일이 위치한 사용자 경로를 설정합니다. 서버 기본값을 사용하려면 공백으로 두십시오.", - "LabelTranscodingVideoCodec": "비디오 코덱:", "LabelTriggerType": "트리거 종류:", "LabelTunerIpAddress": "튜너 IP 주소:", "LabelTunerType": "튜너 종류:", @@ -477,7 +459,6 @@ "MessageNothingHere": "아무것도 없습니다.", "MessagePasswordResetForUsers": "다음 사용자는 비밀번호를 재설정했습니다. 재설정을 수행하는데 사용된 핀 코드로 로그인 할 수 있습니다.", "MessagePleaseEnsureInternetMetadata": "인터넷 메타데이터 다운로드가 켜져 있는지 확인하세요.", - "MessageSettingsSaved": "설정이 저장되었습니다.", "MessageUnableToConnectToServer": "선택한 서버에 연결할 수 없습니다. 서버가 실행 중인지 확인후 다시 시도하세요.", "MessageUnsetContentHelp": "콘텐트가 일반 폴더로 표시됩니다. 최상의 결과를 위해 메타데이터 관리자를 사용하여 하위 폴더의 콘텐트 종류를 설정하세요.", "MinutesAfter": "몇 분 후에", @@ -506,7 +487,6 @@ "OptionArtist": "아티스트", "OptionAscending": "오름차순", "OptionAuto": "자동", - "OptionAutomatic": "자동", "OptionBlockBooks": "도서", "OptionBlockChannelContent": "인터넷 채널 콘텐츠", "OptionBlockLiveTvChannels": "실시간 TV 방송 채널", @@ -643,18 +623,14 @@ "SystemDlnaProfilesHelp": "시스템 프로필은 읽기 전용입니다. 시스템 프로필에 대한 변경 사항은 새로운 사용자 정의 프로필에 저장됩니다.", "TabAccess": "접속", "TabAdvanced": "고급", - "TabAlbumArtists": "앨범 아티스트", "TabCatalog": "카탈로그", "TabCodecs": "코덱", "TabContainers": "컨테이너", "TabDashboard": "대시보드", "TabDirectPlay": "다이렉트 재생", - "TabEpisodes": "에피소드", - "TabInfo": "정보", "TabLatest": "최근", "TabLogs": "로그", "TabMusic": "음악", - "TabMusicVideos": "뮤직비디오", "TabMyPlugins": "내 플러그인", "TabNetworks": "네트워크", "TabNotifications": "알림", @@ -668,7 +644,6 @@ "TabServer": "서버", "TabSettings": "설정", "TabStreaming": "스트리밍", - "TabTrailers": "예고편", "TabUpcoming": "방송 예정", "Tags": "태그", "TellUsAboutYourself": "자신에 대해 알려주세요", @@ -758,9 +733,7 @@ "BookLibraryHelp": "오디오 혹은 텍스트 도서가 지원됩니다. {0}도서 작명 가이드{1}를 참고하십시오.", "Box": "박스", "Browse": "탐색", - "ButtonEditImages": "이미지 편집", "ButtonFullscreen": "전체 화면", - "HeaderEpisodes": "에피소드", "HeaderExternalIds": "외부 ID:", "HeaderFavoriteMovies": "즐겨찾는 영화", "HeaderFavoriteVideos": "즐겨찾는 동영상", @@ -772,7 +745,6 @@ "CancelRecording": "녹화 취소", "ButtonTrailer": "트레일러", "ButtonScanAllLibraries": "모든 라이브러리 스캔", - "ButtonOff": "끄기", "ButtonAudioTracks": "오디오 트랙", "ButtonAddMediaLibrary": "미디어 라이브러리 추가", "ButtonAddImage": "이미지 추가", @@ -787,7 +759,6 @@ "Filters": "필터", "EveryNDays": "매 {0}일", "EnableThemeVideosHelp": "라이브러리를 탐색하는 동안 테마 비디오를 재생합니다.", - "EnableThemeVideos": "테마 비디오", "EnableThemeSongsHelp": "라이브러리를 탐색하는 동안 테마 곡을 재생합니다.", "EnableStreamLooping": "라이브 스트림 자동 반복", "EnableNextVideoInfoOverlayHelp": "비디오가 끝나면 현재 재생목록의 다음 비디오에 대한 정보를 표시합니다.", @@ -832,7 +803,6 @@ "ThemeVideos": "테마 비디오", "ThemeSongs": "테마 곡", "TagsValue": "태그: {0}", - "TabResumeSettings": "재개", "TabNfoSettings": "NFO 설정", "TabNetworking": "네트워킹", "TV": "TV", @@ -960,7 +930,6 @@ "LabelTheme": "테마:", "LabelTextSize": "글자 크기:", "LabelTextColor": "글자 색:", - "LabelSubtitles": "자막", "LabelSubtitleFormatHelp": "예시: srt", "LabelSubtitleDownloaders": "자막 다운로더:", "LabelStopping": "중지", @@ -998,7 +967,6 @@ "LabelAudioCodec": "오디오 코덱:", "LabelAudioChannels": "오디오 채널:", "LabelAudioBitrate": "오디오 비트레이트:", - "LabelAudio": "오디오", "Items": "항목", "Kids": "어린이", "Home": "홈", @@ -1015,7 +983,6 @@ "HeaderMusicQuality": "음악 퀄리티", "HeaderImageOptions": "이미지 옵션", "HeaderHttpHeaders": "HTTP 헤더", - "HeaderHome": "홈", "HeaderFavoriteBooks": "즐겨찾는 도서", "HeaderEditImages": "이미지 수정", "HeaderDownloadSync": "다운로드 & 동기화", @@ -1126,7 +1093,6 @@ "File": "파일", "Favorite": "즐겨찾기", "Episodes": "에피소드", - "EnableThemeSongs": "테마 곡", "EnablePhotos": "사진 표시", "EnableHardwareEncoding": "하드웨어 인코딩 활성화", "AllowHWTranscodingHelp": "튜너가 방송 스트림을 트랜스코드하도록 허용합니다. 이는 서버가 요구하는 트랜스코딩을 줄이는 데 도움이 될 수 있습니다.", diff --git a/src/strings/lt-lt.json b/src/strings/lt-lt.json index 0d66a6456a..2d890a4fca 100644 --- a/src/strings/lt-lt.json +++ b/src/strings/lt-lt.json @@ -17,18 +17,13 @@ "ButtonArrowRight": "Dešinėn", "ButtonBack": "Atgal", "ButtonCancel": "Atšaukti", - "ButtonEdit": "Redaguoti", - "ButtonFilter": "Filtras", "ButtonGotIt": "Supratau", - "ButtonHome": "Pradinis", "ButtonManualLogin": "Rankinis prisijungimas", "ButtonNextTrack": "Kitas takelis", "ButtonOk": "OK", "ButtonPause": "Pauzė", - "ButtonPlay": "Leisti", "ButtonPreviousTrack": "Ankstesnis takelis", "ButtonQuickStartGuide": "Greitos pradžios gidas", - "ButtonRefresh": "Atnaujinti", "ButtonRefreshGuideData": "Atnaujinti gido duomenis", "ButtonRemove": "Pašalinti", "ButtonResetPassword": "Atstatyti slaptažodį", @@ -39,7 +34,6 @@ "ButtonSignOut": "Atsijungti", "ButtonStop": "Stabdyti", "ButtonSubmit": "Pateikti", - "ButtonSubtitles": "Subtitrai", "CancelRecording": "Atšaukti įrašymą", "CancelSeries": "Atšaukti laidą", "Categories": "Kategorijos", @@ -83,14 +77,11 @@ "HDPrograms": "HD laidos", "HeaderActiveDevices": "Aktyvūs įrenginiai", "HeaderActiveRecordings": "Aktyvūs įrašai", - "HeaderAddScheduledTaskTrigger": "Pridėti jungiklį", "HeaderAddToCollection": "Pridėti į kolekciją", "HeaderAddToPlaylist": "Pridėti į grojaraštį", - "HeaderAddUser": "Pridėti vartotoją", "HeaderAdditionalParts": "Papildomos dalys", "HeaderCancelRecording": "Atšaukti įrašymą", "HeaderCancelSeries": "Atšaukti laidą", - "HeaderCastCrew": "Kūrėjai", "HeaderContinueWatching": "Žiūrėti toliau", "HeaderCustomDlnaProfiles": "Kiti profiliai", "HeaderDeleteItem": "Ištrinti elementą", @@ -167,7 +158,6 @@ "LabelDay": "Diena:", "LabelDeathDate": "Mirties data:", "LabelDeviceDescription": "Įrenginio aprašymas", - "LabelDisplayMissingEpisodesWithinSeasons": "Rodyti sezonuose trūkstamas serijas", "LabelDisplayOrder": "Rodymo tvarka:", "LabelDynamicExternalId": "{0} ID:", "LabelEnableAutomaticPortMap": "Įjungti automatinį portų nukreipimą", @@ -235,7 +225,6 @@ "LabelPlaceOfBirth": "Gimimo vieta:", "LabelPlaylist": "Grojaraštis:", "LabelPreferredDisplayLanguage": "Pageidautina rodymo kalba:", - "LabelPreferredDisplayLanguageHelp": "Jellyfin vertimas yra besitęsiantis projektas.", "LabelProfileCodecsHelp": "Atskirta kableliais. Palikus tuščią bus pritaikyta visiems kodekams.", "LabelProfileContainersHelp": "Atskirta kableliais. Palikus tuščią bus pritaikyta visiems konteineriams.", "LabelPublicHttpPort": "Numeris viešo HTTP porto:", @@ -439,12 +428,9 @@ "SystemDlnaProfilesHelp": "Sistemos profiliai yra tik skaitomi. Pakeitimai sistemos profiliui bus išsaugoti į naują kitą profilį.", "TabAccess": "Prieiga", "TabAdvanced": "Sudėtingiau", - "TabAlbumArtists": "Albumo atlikėjai", "TabCatalog": "Katalogas", - "TabEpisodes": "Serijos", "TabLatest": "Vėliausi", "TabMusic": "Muzika", - "TabMusicVideos": "Muzikos klipai", "TabMyPlugins": "Mano priedai", "TabNetworks": "Tinklai", "TabNotifications": "Pranešimai", @@ -453,7 +439,6 @@ "TabProfiles": "Profiliai", "TabServer": "Serveris", "TabSettings": "Nustatymai", - "TabTrailers": "Anonsai", "TabUpcoming": "Būsimi", "Tags": "Žymės", "TellUsAboutYourself": "Papasakokite apie save", @@ -506,7 +491,6 @@ "ButtonAddServer": "Pridėti Serverį", "ButtonAudioTracks": "Garso takeliai", "ButtonChangeServer": "Keisti serverį", - "ButtonEditImages": "Redaguoti vaizdus", "ButtonForgotPassword": "Pamiršau slaptažodį", "ButtonFullscreen": "Per visą ekraną", "ButtonGuide": "Gidas", @@ -514,7 +498,6 @@ "ButtonLibraryAccess": "Mediatekos prieiga", "ButtonMore": "Daugiau", "ButtonNetwork": "Tinklas", - "ButtonOff": "Išjungti", "ButtonOpen": "Atidaryti", "ButtonParentalControl": "Tėvų kontrolė", "ButtonProfile": "Profilis", @@ -582,7 +565,6 @@ "EnableNextVideoInfoOverlayHelp": "Vaizdo įrašo pabaigoje rodyti informacija apie sekantį vaizdo įrašą, esantį grojaraštyje.", "EnablePhotos": "Rodyti nuotraukas", "EnablePhotosHelp": "Nuotraukos bus rodomos šalia kitų medijos failų.", - "EnableThemeSongs": "Teminės dainos", "AspectRatio": "Vaizdo Santykis", "Ascending": "Didėjančia tvarka", "AllComplexFormats": "Visi Sudėtingi Formatai (ASS, SSA, VOBSUB, PGS, SUB/IDX, t.t.)", @@ -602,7 +584,6 @@ "EnableDisplayMirroring": "Ekrano dubliavimas", "CopyStreamURL": "Kopijuoti srauto nuorodą", "HeaderConfirmPluginInstallation": "Patvirtinti įskiepio diegimą", - "HeaderEpisodes": "Serijos", "HeaderError": "Klaida", "OptionBlockMovies": "Filmai", "Songs": "Kūriniai", @@ -659,22 +640,17 @@ "EnableExternalVideoPlayersHelp": "Paleidus vaizdo įrašą, bus rodomas išorinio grotuvo meniu.", "EnableHardwareEncoding": "Įjungti aparatinės įrangos kodavimą", "EnableThemeSongsHelp": "Naršant bibliotekoje paleisti teminius takelius fone.", - "EnableThemeVideos": "Teminiai vaizdo įrašai", "EnableThemeVideosHelp": "Naršant bibliotekoje paleisti teminius vaizdo įrašus fone.", "Episodes": "Serijos", - "HeaderBooks": "Knygos", "HeaderBranding": "Įforminimas", "HeaderCodecProfile": "Kodeko profilis", "HeaderFavoritePeople": "Mėgstami žmonės", "HeaderForKids": "Vaikams", - "HeaderForgotPassword": "Pamiršau slaptažodį", "HeaderGuideProviders": "TV gido informacijos teikėjai", - "HeaderHome": "Pradinis", "HeaderIdentification": "Identifikacija", "HeaderIdentificationHeader": "Identifikavimo antraštė", "HeaderHttpHeaders": "HTTP-antraštės", "OptionAuto": "Auto", - "OptionAutomatic": "Auto", "OptionAutomaticallyGroupSeriesHelp": "Jei įjungta - serijos skirtinguose bibliotekos aplankaluose bus apjungtos į vieną serialą.", "OptionBanner": "Juosta", "Playlists": "Grojaraštis", @@ -716,12 +692,10 @@ "LabelAllowedRemoteAddressesMode": "Nuotolinio IP adresų filtro režimas:", "HeaderLoginFailure": "Prisijungimo klaida", "Hide": "Paslėpti", - "LabelAudio": "Garsas", "LabelCancelled": "Atšaukta", "LabelCertificatePassword": "Sertifikato slaptažodis:", "LabelCertificatePasswordHelp": "Jei sertifikatui reikalingas slaptažodis, jį įveskite čia.", "LabelCustomCertificatePath": "Pasirinktinis SSL sertifikatas kelias:", - "LabelCustomDeviceDisplayName": "Rodomas vardas:", "LabelDisplayLanguage": "Kalba:", "LabelDisplayName": "Rodomas vardas:", "EnableBackdropsHelp": "Rodyti fono dekoracijas naršant bibliotekoje.", @@ -770,7 +744,6 @@ "HeaderLatestMovies": "Naujausi filmai", "HeaderLatestMusic": "Naujausia muzika", "HeaderLibraryFolders": "Mediatekos aplankai", - "HeaderMediaInfo": "Apie medija", "HeaderNextEpisodePlayingInValue": "Kita serija rodoma už {0}", "HeaderNextVideoPlayingInValue": "Kitas vaizdo įrašas rodomas už {0}", "HeaderPassword": "Slaptažodis", diff --git a/src/strings/lv.json b/src/strings/lv.json index ee712f615b..de3b8475d3 100644 --- a/src/strings/lv.json +++ b/src/strings/lv.json @@ -19,7 +19,6 @@ "MessageYouHaveVersionInstalled": "Jums pašlaik ir uzstādīta versija {0}.", "MessageUnableToConnectToServer": "Mēs pašlaik nevaram sazināties ar izvēlēto serveri. Pārliecinies ka tas strādā, un mēģini vēlreiz.", "MessageTheFollowingLocationWillBeRemovedFromLibrary": "Sekojošie multvides ceļi tiks noņemti no tavas bibliotēkas:", - "MessageSettingsSaved": "Iestatījumi saglabāti.", "MessagePleaseWait": "Lūdzu uzgaidi. Tas var aizņemt pāris minūtes.", "MessageNothingHere": "Šeit nekā nav.", "MessageNoPluginsInstalled": "Tev nav uzstādīti paplašinājumi.", @@ -70,10 +69,7 @@ "LabelTunerIpAddress": "Tūnera IP Addrese:", "LabelTunerType": "Tūnera tips:", "LabelType": "Tips:", - "LabelTranscodingVideoCodec": "Video kodeks:", "LabelTranscodePath": "Trans-kodēšanas ceļš:", - "LabelTranscodingContainer": "Konteineris:", - "LabelTranscodingAudioCodec": "Audio kodeks:", "LabelTrackNumber": "Celiņa numurs:", "LabelTimeLimitHours": "Laika limits (stundas):", "LabelTime": "Laiks:", @@ -84,7 +80,6 @@ "LabelTag": "Tags:", "LabelTVHomeScreen": "TV režīma mājas ekrāns:", "LabelSupportedMediaTypes": "Atbalstītie Multivides Veidi:", - "LabelSubtitles": "Subtitri", "LabelSubtitlePlaybackMode": "Subtitru veids:", "LabelSubtitleFormatHelp": "Piemērs: srt", "LabelSubtitleDownloaders": "Subtitru lejupielādētāji:", @@ -202,7 +197,6 @@ "LabelDefaultUser": "Noklusējuma lietotājs:", "LabelDay": "Diena:", "LabelDateAdded": "Pievienošanas datums:", - "LabelCustomDeviceDisplayName": "Displeja nosaukums:", "LabelCurrentPassword": "Pašreizējā parole:", "LabelCriticRating": "Kritiķu reitings:", "LabelCountry": "Valsts:", @@ -218,7 +212,6 @@ "LabelBirthYear": "Dzimšanas gads:", "LabelBirthDate": "Dzimšanas datums:", "LabelAudioLanguagePreference": "Ieteicamā audio valoda:", - "LabelAudio": "Audio", "LabelArtistsHelp": "Atdali vairākus izmantojot ;", "LabelArtists": "Izpildītājs:", "LabelAppNameExample": "Piemēram: Sickbeard, Sonarr", @@ -286,7 +279,6 @@ "HeaderMusicQuality": "Audio Kvalitāte", "HeaderMoreLikeThis": "Vairāk Kā Šis", "HeaderMetadataSettings": "Metadatu Iestatījumi", - "HeaderMediaInfo": "Multvides informācija", "HeaderMediaFolders": "Multvides Mapes", "HeaderMedia": "Multvide", "HeaderLiveTvTunerSetup": "Tiešraides TV Tūnera Uzstādīšana", @@ -308,10 +300,8 @@ "HeaderIdentificationCriteriaHelp": "Ievadi vismaz vienu identifikācijas kritēriju.", "HeaderIdentification": "Identifikācija", "HeaderHttpHeaders": "HTTP Headeri", - "HeaderHome": "Mājas", "HeaderGuideProviders": "TV Gida Datu Nodrošinātāji", "HeaderFrequentlyPlayed": "Bieži Atskaņots", - "HeaderForgotPassword": "Aizmirst PAroli", "HeaderForKids": "Priekš Bērniem", "HeaderFavoriteVideos": "Video Favorīti", "MediaInfoPath": "Ceļš", @@ -346,7 +336,6 @@ "HeaderFavoriteBooks": "Grāmatu Favorīti", "HeaderExternalIds": "Ārējie ID:", "HeaderError": "Kļūda", - "HeaderEpisodes": "Epizodes", "HeaderEditImages": "Rediģēt Attēlus", "HeaderDownloadSync": "Lejupielādēt & Sinhronizēt", "HeaderDevices": "Ierīces", @@ -367,7 +356,6 @@ "HeaderChannelAccess": "Kanālu Piekļuve", "HeaderCancelSeries": "Atcelt Sēriju", "HeaderCancelRecording": "Atcelt Ierakstus", - "HeaderBooks": "Grāmatas", "HeaderAudioSettings": "Audio Iestatījumi", "HeaderAudioBooks": "Audio Grāmatas", "HeaderApp": "Lietotne", @@ -377,7 +365,6 @@ "HeaderAlert": "Paziņojums", "HeaderAlbumArtists": "Albumu Izpildītāji", "HeaderAdmin": "Admin", - "HeaderAddUser": "Pievienot Lietotāju", "HeaderAddToPlaylist": "Pievienot Atskaņošanas Sarakstam", "HeaderAddToCollection": "Pievienot kolekcijai", "HeaderActivity": "Aktivitāte", @@ -413,8 +400,6 @@ "EndsAtValue": "Beigsies {0}", "EnableThemeVideosHelp": "Atskaņot tēmas video fonā bibliotēkas pārlūkošanas laikā.", "EnableThemeSongsHelp": "Atskaņot tēmas mūziku fonā bibliotēkas pārlūkošanas laikā.", - "EnableThemeVideos": "Tēmas video", - "EnableThemeSongs": "Tēmas mūzika", "EnablePhotos": "Rādīt attēlus", "EnableNextVideoInfoOverlayHelp": "Video beigās rādīt informāciju par nākamo video atskaņošanas sarakstā.", "EnableNextVideoInfoOverlay": "Rādīt nākamā video informāciju atskaņošanas laikā", @@ -468,7 +453,6 @@ "ButtonWebsite": "Web vietne", "ButtonUninstall": "Atinstalēt", "ButtonTrailer": "Treileri", - "ButtonSubtitles": "Subtitri", "ButtonSplit": "Sadalīt", "ButtonStop": "Apturēt", "ButtonStart": "Sākt", @@ -489,28 +473,21 @@ "ButtonRename": "Pārsaukt", "ButtonRemove": "Noņemt", "ButtonRefreshGuideData": "Atjaunot Gida Datus", - "ButtonRefresh": "Atjaunot", "ButtonProfile": "Profils", "ButtonPreviousTrack": "Iepriekšējais celiņš", - "ButtonPlay": "Atskaņot", "ButtonPause": "Pauzēt", "ButtonParentalControl": "Vecāku Pārvaldība", "ButtonOpen": "Atvērt", "ButtonOk": "Labi", - "ButtonOff": "Izslēgt", "ButtonNextTrack": "Nākamais Celiņš", "ButtonNetwork": "Tīkls", "ButtonMore": "Vairāk", "ButtonLibraryAccess": "Bibliotēku piekļuve", "ButtonInfo": "Info", - "ButtonHome": "Mājas", "ButtonGuide": "Gids", "ButtonGotIt": "Sapratu", "ButtonFullscreen": "Pilnekrāna", "ButtonForgotPassword": "Aizmirsu Paroli", - "ButtonFilter": "Filtrs", - "ButtonEditImages": "Rediģēt attēlus", - "ButtonEdit": "Rediģēt", "ButtonChangeServer": "Nomainīt Serveri", "ButtonCancel": "Atcelt", "ButtonBack": "Atpakaļ", @@ -664,11 +641,9 @@ "TellUsAboutYourself": "Pastāsti mums par sevi", "TagsValue": "Tagi: {0}", "Tags": "Tagi", - "TabTrailers": "Treileri", "TabStreaming": "Straumēšana", "TabSettings": "Iestatījumi", "TabServer": "Serveris", - "TabResumeSettings": "Turpināt", "TabResponses": "Atbildes", "TabProfiles": "Profili", "TabProfile": "Profils", @@ -680,12 +655,9 @@ "TabNetworking": "Tīklošana", "TabNetworks": "Tīkli", "TabMyPlugins": "Mani Paplašinājumi", - "TabMusicVideos": "Mūzikas Video", "TabMusic": "Mūzika", "TabLogs": "Logs", "TabLatest": "Jaunākais", - "TabInfo": "Info", - "TabEpisodes": "Epizodes", "TabDirectPlay": "Tiešā Atskaņošana", "TabContainers": "Konteineri", "TabCodecs": "Kodeksi", @@ -759,7 +731,6 @@ "OptionBlockMusic": "Mūzika", "OptionBlockMovies": "Filmas", "OptionBlockBooks": "Grāmatas", - "OptionAutomatic": "Auto", "OptionAuto": "Auto", "OptionArtist": "Izpildītājs", "MessageNoPluginConfiguration": "Šim paplašinājumam nav konfigurējamu iestatījumu.", @@ -776,7 +747,6 @@ "LabelServerHost": "Resursdators:", "LabelReleaseDate": "Izlaiduma datums:", "LabelPreferredSubtitleLanguage": "Ieteicamā subtitru valoda:", - "LabelPreferredDisplayLanguageHelp": "Jellyfin tulkošana ir notiekošs projekts.", "LabelPlayerDimensions": "Atskaņotāja dimensijas:", "LabelParentalRating": "Vecāku reitings:", "LabelMonitorUsers": "Uzraudzīt aktivitāti no:", @@ -875,13 +845,11 @@ "HeaderCustomDlnaProfiles": "Pielāgoti Profili", "HeaderConfirmProfileDeletion": "Apstiprināt Profila Dzēšanu", "HeaderChapterImages": "Nodaļu Attēli", - "HeaderCastCrew": "Lomas & Apkalpe", "HeaderCastAndCrew": "Lomas un Apkalpe", "HeaderAppearsOn": "Redzams", "FFmpegSavePathNotFound": "Mēs nespējām atrast FFmpeg norādītajā ceļā. FFprobe arī ir vajadzīgs, un tam ir jāatrodas tajā pašā mapē. Šīs komponentes parasti tiek apvienotas vienā un tajā pašā lejupielādē. Lūdzu pārbaudiet ceļu un mēģiniet vēlreiz.", "HeaderAdditionalParts": "Papildus Ceļi", "HeaderAddUpdateImage": "Pievienot/Atjaunot Attēlu", - "HeaderAddScheduledTaskTrigger": "Pievienot Trigeri", "GuideProviderLogin": "Ieiet", "Ended": "Beidzies", "EnableStreamLoopingHelp": "Iespējo šo, ja tiešsaistes straume satur tikai pāris sekunžu datus, un ir nepārtraukti jāatjauno. Iespējojot bez vajadzības var radīties problēmas.", @@ -1018,7 +986,6 @@ "LabelDroppedFrames": "Nomestie kadri:", "LabelDownMixAudioScaleHelp": "Pastiprināt audio lejupmiksēšanas laikā. Vērtība viens paturēs oriģinālo skaļumu.", "LabelDownMixAudioScale": "Audio pastiprinājums lejupmiksējot:", - "LabelDisplayMissingEpisodesWithinSeasons": "Rādīt trūkstošās epizodes sezonās", "LabelDateAddedBehaviorHelp": "Ja atrodas metadatu vērtība, tā vienmēr tiks izmantota pirms jebkuras no šīm opcijām.", "LabelCustomDeviceDisplayNameHelp": "Ievadi pielāgotu displeja vārdu vai atstāj tukšu lai izmantotu ierīces noteikto.", "LabelCachePathHelp": "Nosaki pielāgotu atrašanās vietu priekš keša datnēm kā attēliem. Atstāj tukšu lai izmantotu servera noklusējumu.", diff --git a/src/strings/mr.json b/src/strings/mr.json index 8a2114bf05..88a0a9cfe5 100644 --- a/src/strings/mr.json +++ b/src/strings/mr.json @@ -1,7 +1,6 @@ { "ButtonOpen": "उघडा", "ButtonOk": "ऑन", - "ButtonOff": "ऑफ", "ButtonNextTrack": "पुढचा ट्रॅक", "ButtonNetwork": "नेटवर्क", "ButtonMore": "अजून", @@ -9,8 +8,6 @@ "ButtonGuide": "गाईड", "ButtonGotIt": "समजले", "ButtonForgotPassword": "पासवर्ड विसरलो", - "ButtonEditImages": "चित्र संपादित करा", - "ButtonEdit": "संपादित करा", "ButtonChangeServer": "सर्व्हर बदला", "ButtonCancel": "रद्द करा", "ButtonBack": "मागे", @@ -69,7 +66,6 @@ "CancelRecording": "रेकॉर्डिंग रद्द करा", "ButtonWebsite": "संकेतस्थळ", "ButtonTrailer": "ट्रेलर", - "ButtonSubtitles": "सबटायटल", "ButtonStop": "थांबा", "ButtonStart": "सुरू करा", "ButtonSettings": "सेटिंग्झ", @@ -81,7 +77,6 @@ "ButtonRename": "नाव बदला", "ButtonRemove": "काढून टाका", "ButtonPreviousTrack": "मागचा ट्रॅक", - "ButtonPlay": "प्ले", "ButtonPause": "पॉझ", "ButtonSyncPlay": "SyncPlay", "Collections": "संग्रह" diff --git a/src/strings/ms.json b/src/strings/ms.json index 786d2b7707..e9d03a73f0 100644 --- a/src/strings/ms.json +++ b/src/strings/ms.json @@ -64,15 +64,11 @@ "ButtonChangeServer": "Tukar pelayan", "ButtonLibraryAccess": "Akses pustaka", "ButtonInfo": "Info", - "ButtonHome": "Mula", "ButtonGuide": "Panduan", "ButtonGotIt": "Terima", "ButtonFullscreen": "Paparan skrin penuh", "ButtonForgotPassword": "Lupa Kata Laluan", - "ButtonFilter": "Tapisan", "ButtonEditOtherUserPreferences": "Edit profil, gambar dan keutamaan peribadi pengguna ini", - "ButtonEditImages": "Edit gambar-gambar", - "ButtonEdit": "Edit", "ButtonAddScheduledTaskTrigger": "Tambah Pencetus", "ButtonAddImage": "Tambah gambar", "BurnSubtitlesHelp": "Menentukan sama ada pelayan perlu membakar subtitle ke skrin apabila menukar video bergantung kepada format sarikata. Menghindari pembakaran sari kata ke skrin akan meningkatkan prestasi pelayan. Pilih Auto untuk membakar format berasaskan imej (VOBSUB, PGS, SUB / IDX, dll) dan subtitle ASS / SSA tertentu.", diff --git a/src/strings/nb.json b/src/strings/nb.json index 9a31970159..591af23502 100644 --- a/src/strings/nb.json +++ b/src/strings/nb.json @@ -42,27 +42,21 @@ "ButtonBack": "Tilbake", "ButtonCancel": "Avbryt", "ButtonChangeServer": "Endre server", - "ButtonEdit": "Rediger", - "ButtonEditImages": "Endre bilder", "ButtonEditOtherUserPreferences": "Endre denne brukerens profilbilde og personlige innstillinger.", "ButtonForgotPassword": "Glemt passord", "ButtonFullscreen": "Fullskjerm", "ButtonGotIt": "Skjønner", - "ButtonHome": "Hjem", "ButtonLibraryAccess": "Bibliotektilgang", "ButtonManualLogin": "Manuell Login", "ButtonMore": "Mer", "ButtonNetwork": "Nettverk", "ButtonNextTrack": "Neste Spor", - "ButtonOff": "Av", "ButtonOk": "OK", "ButtonOpen": "Åpne", "ButtonParentalControl": "Foreldrekontroll", - "ButtonPlay": "Spill", "ButtonPreviousTrack": "Forrige spor", "ButtonProfile": "Profil", "ButtonQuickStartGuide": "Hurtigveiledning", - "ButtonRefresh": "Oppdater", "ButtonRefreshGuideData": "Oppdater TV-guidedata", "ButtonRemove": "Fjern", "ButtonRename": "Endre navn", @@ -81,7 +75,6 @@ "ButtonSignOut": "Logg ut", "ButtonStop": "Stopp", "ButtonSubmit": "Send", - "ButtonSubtitles": "Undertekster", "ButtonUninstall": "Avinstaller", "ButtonWebsite": "Nettsted", "CancelRecording": "Avbryt opptak", @@ -178,11 +171,9 @@ "HeaderActiveDevices": "Aktive enheter", "HeaderActiveRecordings": "Aktive opptak", "HeaderActivity": "Aktivitet", - "HeaderAddScheduledTaskTrigger": "Legg til utløser", "HeaderAddToCollection": "Legg til i samling", "HeaderAddToPlaylist": "Legg til i Spilleliste", "HeaderAddUpdateImage": "Legg Til/Oppdater Bilde", - "HeaderAddUser": "Legg til bruker", "HeaderAdditionalParts": "Tilleggsdeler", "HeaderAlert": "Varsling", "HeaderAllowMediaDeletionFrom": "Tillat sletting av media fra", @@ -191,12 +182,10 @@ "HeaderApiKeysHelp": "Eksterne programmer trenger en API-nøkkel for å kunne kommunisere med serveren. Nøklene utstedes ved å logge på med en vanlig brukerkonto eller gjennom å manuelt gi programmet en nøkkel.", "HeaderAudioBooks": "Lydbøker", "HeaderAudioSettings": "Lydinnstillinger", - "HeaderBooks": "Bøker", "HeaderBranding": "Merking", "HeaderCancelRecording": "Avbryt opptak", "HeaderCancelSeries": "Avbryt serie", "HeaderCastAndCrew": "Skuespillere & mannskap", - "HeaderCastCrew": "Mannskap", "HeaderChannelAccess": "Kanal-tilgang", "HeaderCodecProfile": "Kodekprofil", "HeaderCodecProfileHelp": "Kodekprofiler indikerer begrensningene til en enhet ved avspilling av bestemte kodeker. Hvis en begrensning gjelder, vil media bli omkodet, selv om kodeken er konfigurert for direkteavspilling.", @@ -228,12 +217,10 @@ "HeaderEditImages": "Endre bilder", "HeaderEnabledFields": "Aktiverte felt", "HeaderEnabledFieldsHelp": "Fjern markeringen av et felt for å låse det og hindre dataene fra å endres.", - "HeaderEpisodes": "Episoder", "HeaderError": "Feil", "HeaderFeatureAccess": "Funksjonstilgang", "HeaderFetchImages": "Hent bilder:", "HeaderForKids": "For barn", - "HeaderForgotPassword": "Glemt passord", "HeaderFrequentlyPlayed": "Ofte avspilt", "HeaderGuideProviders": "Leverandører av TV-guide", "HeaderHttpHeaders": "HTTP-hoder", @@ -260,7 +247,6 @@ "HeaderLiveTvTunerSetup": "Tunerinnstillinger for direkte-TV", "HeaderLoginFailure": "Påloggingsfeil", "HeaderMediaFolders": "Mediemapper", - "HeaderMediaInfo": "Mediainformasjon", "HeaderMetadataSettings": "Metadatainnstilinger", "HeaderMoreLikeThis": "Flere som dette", "HeaderMusicVideos": "Musikkvideoer", @@ -393,7 +379,6 @@ "LabelCustomCertificatePath": "Egendefinert filbane for SSL-sertifikat:", "LabelCustomCss": "Tilpasset CSS:", "LabelCustomCssHelp": "Bruk tilpassede stiler på web-grensesnittet.", - "LabelCustomDeviceDisplayName": "Visningsnavn:", "LabelCustomDeviceDisplayNameHelp": "Oppgi et egendefinert visningsnavn eller la det være tomt for å bruke navnet som enheten rapporterer.", "LabelCustomRating": "Egen aldersgrense:", "LabelDateAdded": "Dato lagt til:", @@ -406,7 +391,6 @@ "LabelDeviceDescription": "Enhetsbeskrivelse", "LabelDidlMode": "DIDL-modus:", "LabelDisplayLanguageHelp": "Oversettelse av Jellyfin er et pågående prosjekt.", - "LabelDisplayMissingEpisodesWithinSeasons": "Vis episoder som mangler fra sesongen", "LabelDisplayMode": "Visningsmodus:", "LabelDisplayName": "Visningsnavn:", "LabelDisplayOrder": "Visningsrekkefølge:", @@ -544,7 +528,6 @@ "LabelPostProcessorArguments": "Kommandolinjeargumenter for etterbehandling:", "LabelPostProcessorArgumentsHelp": "Bruk {path} som filbanen til opptaksfilen.", "LabelPreferredDisplayLanguage": "Foretrukket visningsspråk:", - "LabelPreferredDisplayLanguageHelp": "Oversettelse av Jellyfin er et pågående prosjekt.", "LabelProfileAudioCodecs": "Lydkodeker:", "LabelProfileCodecs": "Kodeker:", "LabelProfileCodecsHelp": "Separert med komma. Dette feltet kan forbli tomt for å gjelde alle kodeker.", @@ -599,12 +582,9 @@ "LabelTimeLimitHours": "Tidsbegrensning (timer):", "LabelTitle": "Tittel:", "LabelTrackNumber": "Spornummer:", - "LabelTranscodingAudioCodec": "Lydkodek:", - "LabelTranscodingContainer": "Kontainer:", "LabelTranscodingTempPathHelp": "Spesifiser en egen filbane for omkodede filer som skal sendes til klienter. La feltet stå tomt for å bruke serverens standardinnstilling.", "LabelTranscodingThreadCount": "Antall tråder for omkoding:", "LabelTranscodingThreadCountHelp": "Velg maksimalt antall tråder som kan brukes under omkoding. Færre tråder vil føre til lavere CPU-bruk, men kan føre til at mediet ikke konverteres fort nok til at avspillingen kan foregå uten avbrudd.", - "LabelTranscodingVideoCodec": "Videokodek:", "LabelTunerIpAddress": "IP-adresse til tuner:", "LabelTunerType": "Tunertype:", "LabelTypeMetadataDownloaders": "{0} - Kilder for metadata:", @@ -692,7 +672,6 @@ "MessagePluginConfigurationRequiresLocalAccess": "Logg inn direkte på din lokale server for å konfigurere dette programtillegget.", "MessagePluginInstallDisclaimer": "Programtillegg utviklet av brukersamfunnet er en god måte å forbedre opplevelsen din gjennom ekstra funksjoner og fordeler. Før installasjon bør du være klar over virkningen de kan ha på serveren din, som lengre skanning av bibliotek, ekstra bakgrunnsbehandling og redusert systemstabilitet.", "MessageReenableUser": "Se under for å reaktivere", - "MessageSettingsSaved": "Innstillinger lagret.", "MessageTheFollowingLocationWillBeRemovedFromLibrary": "Følgende medieplassering vil bli fjernet fra biblioteket ditt:", "MessageUnableToConnectToServer": "Vi klarte ikke å koble til den valgte serveren akkurat nå. Vennligst sørg for at den kjører og prøv på nytt.", "MessageUnsetContentHelp": "Innhold vises som enkle mapper. For beste resultat, bruk metadatabehandleren for å sette innholdstypen for undermapper.", @@ -942,17 +921,14 @@ "SystemDlnaProfilesHelp": "Systemprofiler er skrivebeskyttet. Endinger på en systemprofil vil bli lagret til en ny tilpasset profil.", "TabAccess": "Tilgang", "TabAdvanced": "Avansert", - "TabAlbumArtists": "Albumartister", "TabCatalog": "Katalog", "TabCodecs": "Kodeker", "TabContainers": "Kontainere", "TabDashboard": "Dashbord", "TabDirectPlay": "Direkteavspilling", - "TabEpisodes": "Episoder", "TabLatest": "Siste", "TabLogs": "Logger", "TabMusic": "Musikk", - "TabMusicVideos": "Musikkvideoer", "TabMyPlugins": "Mine programtillegg", "TabNetworks": "Nettverk", "TabNfoSettings": "NFO-innstillinger", @@ -963,10 +939,8 @@ "TabProfile": "Profil", "TabProfiles": "Profiler", "TabResponses": "Svar", - "TabResumeSettings": "Fortsettelse", "TabScheduledTasks": "Planlagte oppgaver", "TabSettings": "Innstillinger", - "TabTrailers": "Trailere", "TabUpcoming": "Kommende", "Tags": "Tagger", "TellUsAboutYourself": "Fortell oss litt om deg selv", @@ -1033,7 +1007,6 @@ "ButtonPause": "Pause", "ButtonInfo": "Informasjon", "ButtonGuide": "Guide", - "ButtonFilter": "Filter", "AirDate": "Sendedato", "Browse": "Bla", "BoxRear": "Eske (bakside)", @@ -1116,12 +1089,10 @@ "LabelType": "Type:", "Large": "Stor", "DirectStreamHelp1": "Mediet støttes av enheten med tanke på oppløsning og medietype (H.264, AC3, osv), men den støtter ikke filkontaineren (mkv, avi, wmv, osv). Videoen vil ompakkes fortløpende før den sendes til enheten.", - "EnableThemeVideos": "Temavideoer", "MusicVideo": "Musikkvideo", "Mute": "Demp lyd", "CopyStreamURL": "Kopier strøm-URL", "DirectStreaming": "Direktestrømming", - "EnableThemeSongs": "Temamusikk", "HeaderMusicQuality": "Musikkvalitet", "Home": "Hjem", "LabelAlbum": "Album:", @@ -1148,7 +1119,6 @@ "LabelDiscNumber": "Platenummer:", "LabelDisplayLanguage": "Visningsspråk:", "OptionAuto": "Automatisk", - "OptionAutomatic": "Automatisk", "OptionHomeVideos": "Fotografier", "Photos": "Bilder", "Thumb": "Miniatyrbilde", @@ -1209,7 +1179,6 @@ "HeaderFavoriteAlbums": "Favorittalbum", "HeaderFavoriteArtists": "Favorittartister", "HeaderFavoriteSongs": "Favorittsanger", - "HeaderHome": "Hjem", "HeaderNextEpisodePlayingInValue": "Neste episode starter om {0}", "HeaderNextVideoPlayingInValue": "Neste video starter om {0}", "HeaderSeriesStatus": "Seriestatus", @@ -1223,7 +1192,6 @@ "Horizontal": "Horisontal", "HttpsRequiresCert": "For å bruke sikker tilkobling må du legge inn et klarert SSL-sertifikat, for eksempel fra Let's Encrypt. Du må enten legge inn et sertifikat, eller deaktivere sikker tilkobling.", "LabelAlbumArtPN": "Albumomslag PN:", - "LabelAudio": "Lyd", "LabelAuthProvider": "Autentiserings-metode:", "LabelBitrate": "Bithastighet:", "LabelBurnSubtitles": "Brenn inn undertekst:", @@ -1249,7 +1217,6 @@ "LabelSpecialSeasonsDisplayName": "Visningsnavn for spesialsesong:", "LabelStatus": "Status:", "LabelSubtitleDownloaders": "Kilder for undertekst:", - "LabelSubtitles": "Undertekster", "LabelTVHomeScreen": "Hjemskjerm for TV-modus:", "LabelTag": "Tagg:", "LabelTextBackgroundColor": "Tekstbagrunnsfarge:", @@ -1329,7 +1296,6 @@ "SubtitleAppearanceSettingsAlsoPassedToCastDevices": "Disse innstillingene gjelder også alle Chromecast-avspillinger startet av denne enheten.", "SubtitleOffset": "Forskyvet underteksting", "TV": "TV", - "TabInfo": "Informasjon", "TabNetworking": "Nettverk", "Trailers": "Trailere", "Transcoding": "Omkoding", diff --git a/src/strings/nl.json b/src/strings/nl.json index 963adee2c0..6258f7c216 100644 --- a/src/strings/nl.json +++ b/src/strings/nl.json @@ -57,28 +57,22 @@ "ButtonBack": "Terug", "ButtonCancel": "Annuleren", "ButtonChangeServer": "Wijzig server", - "ButtonEdit": "Bewerken", - "ButtonEditImages": "Bewerk afbeeldingen", "ButtonEditOtherUserPreferences": "Wijzig het profiel, afbeelding en persoonlijke voorkeuren van deze gebruiker.", "ButtonForgotPassword": "Wachtwoord Vergeten", "ButtonFullscreen": "Volledig scherm", "ButtonGotIt": "Begrepen", "ButtonGuide": "Gids", - "ButtonHome": "Start", "ButtonLibraryAccess": "Bibliotheek toegang", "ButtonManualLogin": "Handmatige Aanmelding", "ButtonMore": "Meer", "ButtonNetwork": "Netwerk", "ButtonNextTrack": "Volgende track", - "ButtonOff": "Uit", "ButtonOpen": "Openen", "ButtonParentalControl": "Ouderlijk toezicht", "ButtonPause": "Pauze", - "ButtonPlay": "Afspelen", "ButtonPreviousTrack": "Vorige track", "ButtonProfile": "Profiel", "ButtonQuickStartGuide": "Snelstart gids", - "ButtonRefresh": "Vernieuwen", "ButtonRefreshGuideData": "Gidsgegevens Vernieuwen", "ButtonRemove": "Verwijderen", "ButtonRename": "Naam wijzigen", @@ -97,7 +91,6 @@ "ButtonSignIn": "Aanmelden", "ButtonSignOut": "Afmelden", "ButtonSubmit": "Uitvoeren", - "ButtonSubtitles": "Ondertiteling", "CancelRecording": "Opname annuleren", "CancelSeries": "Annuleer series", "Categories": "Categorieën", @@ -181,9 +174,7 @@ "EnablePhotosHelp": "Afbeeldingen worden herkend en weergegeven naast andere mediabestanden.", "EnableStreamLooping": "Livestreams automatisch herhalen", "EnableStreamLoopingHelp": "Schakel dit in als de livestreams slechts enkele seconden aan gegevens bevatten en continu moeten worden aangevraagd. Schakel dit niet in indien het niet nodig is.", - "EnableThemeSongs": "Titelmuziek", "EnableThemeSongsHelp": "Speel titelmuziek af tijdens het bladeren door de bibliotheek.", - "EnableThemeVideos": "Titelfilms", "EnableThemeVideosHelp": "Speel titelfilms af op de achtergrond tijdens het bladeren door de bibliotheek.", "Ended": "Gestopt", "EndsAtValue": "Eindigt om {0}", @@ -237,11 +228,9 @@ "HeaderActiveDevices": "Actieve apparaten", "HeaderActiveRecordings": "Actieve Opnames", "HeaderActivity": "Activiteit", - "HeaderAddScheduledTaskTrigger": "Trigger Toevoegen", "HeaderAddToCollection": "Toevoegen aan Collectie", "HeaderAddToPlaylist": "Toevoegen aan Afspeellijst", "HeaderAddUpdateImage": "Afbeelding Toevoegen/Bijwerken", - "HeaderAddUser": "Gebruiker Toevoegen", "HeaderAdditionalParts": "Extra onderdelen", "HeaderAdmin": "Beheerder", "HeaderAlbumArtists": "Albumartiesten", @@ -255,7 +244,6 @@ "HeaderAudioBooks": "Luisterboeken", "HeaderAudioSettings": "Audio Instellingen", "HeaderBlockItemsWithNoRating": "Blokkeer items met geen of niet herkende beoordelingsinformatie:", - "HeaderBooks": "Boeken", "HeaderBranding": "Huisstijl", "HeaderCancelRecording": "Opname Annuleren", "HeaderCancelSeries": "Annuleren Series", @@ -292,14 +280,12 @@ "HeaderEditImages": "Afbeeldingen bewerken", "HeaderEnabledFields": "Schakel velden in", "HeaderEnabledFieldsHelp": "Verwijder een vinkje om het veld te vergrendelen en voorkom dat gegevens gewijzigd kunnen worden.", - "HeaderEpisodes": "Afleveringen", "HeaderError": "Fout", "HeaderExternalIds": "Externe ID's:", "HeaderFeatureAccess": "Functie toegang", "HeaderFetchImages": "Afbeeldingen ophalen:", "HeaderFetcherSettings": "Fetcher-instellingen", "HeaderForKids": "Voor Kinderen", - "HeaderForgotPassword": "Wachtwoord vergeten", "HeaderFrequentlyPlayed": "Vaak afgespeeld", "HeaderGuideProviders": "TV Gids data aanbieders", "HeaderIdentification": "Identificatie", @@ -325,7 +311,6 @@ "HeaderLiveTvTunerSetup": "Live TV Tuner Instellingen", "HeaderLoginFailure": "Aanmeld fout", "HeaderMediaFolders": "Media Mappen", - "HeaderMediaInfo": "Media informatie", "HeaderMetadataSettings": "Metagegevens instellingen", "HeaderMoreLikeThis": "Meer als dit", "HeaderMusicQuality": "Muziek Kwaliteit", @@ -477,7 +462,6 @@ "LabelCustomCertificatePathHelp": "Pad naar een PKCS #12 bestand met een certificaat en privé-sleutel om TLS ondersteuning op een aangepast domein in te schakelen.", "LabelCustomCss": "Aangepaste CSS:", "LabelCustomCssHelp": "Uw eigen aangepaste stijl voor de web-interface toepassen.", - "LabelCustomDeviceDisplayName": "Weergave naam:", "LabelCustomDeviceDisplayNameHelp": "Geef een eigen weergave naam op of laat deze leeg om de naam te gebruiken die het apparaat opgeeft.", "LabelCustomRating": "Aangepaste classificatie:", "LabelDateAdded": "Datum toegevoegd:", @@ -493,7 +477,6 @@ "LabelDiscNumber": "Disk nummer:", "LabelDisplayLanguage": "Schermtaal:", "LabelDisplayLanguageHelp": "Vertaling van Jellyfin is een voortdurend project.", - "LabelDisplayMissingEpisodesWithinSeasons": "Toon ontbrekende afleveringen binnen een seizoen", "LabelDisplayMode": "Weergave mode:", "LabelDisplayName": "Weergave naam:", "LabelDisplayOrder": "Weergave volgorde:", @@ -644,7 +627,6 @@ "LabelPostProcessorArguments": "Nabewerkings command lijn argumenten:", "LabelPostProcessorArgumentsHelp": "Gebruik {path} als het pad naar het opnamebestand.", "LabelPreferredDisplayLanguage": "Voorkeur weergavetaal:", - "LabelPreferredDisplayLanguageHelp": "Vertaling van Jellyfin is een voortdurend project.", "LabelPreferredSubtitleLanguage": "Voorkeurstaal ondertiteling:", "LabelProfileAudioCodecs": "Geluidscodecs:", "LabelProfileCodecsHelp": "Gescheiden door een komma. Dit kan leeg worden gelaten om te laten gelden voor alle codecs.", @@ -699,7 +681,6 @@ "LabelSubtitleDownloaders": "Ondertiteling downloaders:", "LabelSubtitleFormatHelp": "Voorbeeld: srt", "LabelSubtitlePlaybackMode": "Ondertitel modus:", - "LabelSubtitles": "Ondertiteling", "LabelSupportedMediaTypes": "Ondersteunde Media Types:", "LabelTVHomeScreen": "TV mode begin scherm:", "LabelTextBackgroundColor": "Tekst achtergrond kleur:", @@ -710,7 +691,6 @@ "LabelTimeLimitHours": "Tijdslimiet (uren):", "LabelTitle": "Titel:", "LabelTrackNumber": "Tracknummer:", - "LabelTranscodingAudioCodec": "Geluidscodec:", "LabelTranscodingTempPathHelp": "Specificeer een eigen pad voor de transcode bestanden die geleverd worden aan gebruikers. Laat leeg om de server standaard te gebruiken.", "LabelTranscodingThreadCount": "Aantal transcodeer draden:", "LabelTranscodingThreadCountHelp": "Selecteer het maximale aantal draden die gebruikt mogen worden om te kunnen transcoderen. Bij een lager aantal zal het processorgebruik lager zijn, maar kan de afspeelkwaliteit minder zijn voor een vloeiende ervaring.", @@ -806,7 +786,6 @@ "MessagePluginConfigurationRequiresLocalAccess": "Om deze plugin te configuren moet u zich aanmelden direct op de lokale server.", "MessagePluginInstallDisclaimer": "Plugins ontwikkeld door leden van de gemeenschap zijn een geweldige manier om uw ervaring met extra functies en voordelen te verbeteren. Wees voor het installeren bewust van de effecten die zij op uw server kunnen hebben, zoals langere bibliotheek scans, extra achtergrondinformatie verwerking, en een verminderde stabiliteit van het systeem.", "MessageReenableUser": "Zie hieronder hoe opnieuw in te schakelen", - "MessageSettingsSaved": "Instellingen opgeslagen.", "MessageTheFollowingLocationWillBeRemovedFromLibrary": "De volgende media locaties worden verwijderd uit de bibliotheek:", "MessageUnableToConnectToServer": "Het is momenteel niet mogelijk met de geselecteerde server te verbinden. Controleer dat deze draait en probeer het opnieuw.", "MessageUnsetContentHelp": "Inhoud zal als gewone folders worden getoond. Gebruik voor het beste resultaat de Metadata Manager om de inhoud types voor subfolders in te stellen.", @@ -867,7 +846,6 @@ "OptionAllowVideoPlaybackTranscoding": "Afspelen van video die transcoderen vereisen toestaan", "OptionArtist": "Artiest", "OptionAscending": "Oplopend", - "OptionAutomatic": "Automatisch", "OptionAutomaticallyGroupSeries": "Automatisch samenvoegen serie die zijn verspreid over meerdere mappen", "OptionAutomaticallyGroupSeriesHelp": "Serie die verspreid zijn over meerdere mappen binnen deze bibliotheek worden automatisch samengevoegd tot één serie.", "OptionBlockBooks": "Boeken", @@ -1091,14 +1069,11 @@ "SystemDlnaProfilesHelp": "Systeem profielen zijn alleen-lezen. Om een systeem profiel te overschrijven, maakt u een aangepast profiel gericht op hetzelfde apparaat.", "TabAccess": "Toegang", "TabAdvanced": "Geavanceerd", - "TabAlbumArtists": "Albumartiesten", "TabCatalog": "Catalogus", "TabDirectPlay": "Direct Afspelen", - "TabEpisodes": "Afleveringen", "TabLatest": "Nieuw", "TabLogs": "Logboeken", "TabMusic": "Muziek", - "TabMusicVideos": "Muziek Videos", "TabMyPlugins": "Mijn Plugins", "TabNetworks": "TV-Studio's", "TabNfoSettings": "NFO Instellingen", @@ -1108,7 +1083,6 @@ "TabProfile": "Profiel", "TabProfiles": "Profielen", "TabResponses": "Reacties", - "TabResumeSettings": "Hervatten", "TabScheduledTasks": "Geplande taken", "TabSettings": "Instellingen", "TabUpcoming": "Binnenkort op TV", @@ -1172,7 +1146,6 @@ "Banner": "Banner", "Blacklist": "Zwarte lijst", "Box": "Hoes", - "ButtonFilter": "Filter", "ButtonInfo": "Info", "ButtonOk": "Ok", "ButtonStart": "Start", @@ -1186,7 +1159,6 @@ "Genre": "Genre", "Genres": "Genres", "HeaderCastAndCrew": "Acteurs en medewerkers", - "HeaderCastCrew": "Acteurs & medewerkers", "Art": "Afbeeldingen", "HeaderHttpHeaders": "HTTP Headers", "HeaderStatus": "Status", @@ -1206,7 +1178,6 @@ "ItemCount": "{0} items", "Items": "Items", "LabelAlbum": "Album:", - "LabelAudio": "Audio", "LabelAuthProvider": "Authenticatie Aanbieder:", "LabelCache": "Cache:", "LabelDidlMode": "DIDL mode:", @@ -1256,7 +1227,6 @@ "OptionDvd": "DVD", "OptionResElement": "res element", "TV": "TV", - "HeaderHome": "Thuis", "MediaInfoStreamTypeEmbeddedImage": "Ingeladen Afbeelding", "LabelTypeMetadataDownloaders": "{0} metadata downloaders:", "OptionLoginAttemptsBeforeLockout": "Bepaald hoeveel foutieve login pogingen plaats kunnen vinden voor dat de gebruiker buitengesloten wordt.", @@ -1272,7 +1242,6 @@ "ValueDiscNumber": "Schijf {0}", "ValueMinutes": "{0} min", "OptionProtocolHttp": "HTTP", - "LabelTranscodingVideoCodec": "Video codec:", "MusicLibraryHelp": "Bekijk de {0}muziek benaming gids{1}.", "OptionList": "lijst", "LabelAudioBitDepth": "Audio bit diepte:", @@ -1282,7 +1251,6 @@ "PasswordResetProviderHelp": "Kies een wachtwoord reset provider om te gebruiken wanneer deze gebruiker een wachtwoord reset aanvraagt", "Screenshots": "Schermafdruk", "Series": "Series", - "TabInfo": "Info", "Trailers": "Trailers", "Uniform": "Uniform", "ValueCodec": "Codec: {0}", @@ -1307,7 +1275,6 @@ "LabelPleaseRestart": "De wijzigingen zullen worden toegepast na het handmatig herladen van de web cliënt.", "LabelStatus": "Status:", "LabelTagline": "Label tekst:", - "LabelTranscodingContainer": "Container:", "LabelTranscodePath": "Transcodeer pad:", "LabelTranscodes": "Transcoderen:", "DashboardOperatingSystem": "Besturingssysteem: {0}", @@ -1347,7 +1314,6 @@ "OptionRegex": "Regex", "TabServer": "Server", "TabStreaming": "Streamen", - "TabTrailers": "Trailers", "OptionAuto": "Auto", "OptionProfileVideo": "Video", "AlbumArtist": "Album Artiest", diff --git a/src/strings/pl.json b/src/strings/pl.json index cb23cf40e6..44241686b2 100644 --- a/src/strings/pl.json +++ b/src/strings/pl.json @@ -62,30 +62,23 @@ "ButtonBack": "Wstecz", "ButtonCancel": "Anuluj", "ButtonChangeServer": "Zmień Serwer", - "ButtonEdit": "Edytuj", - "ButtonEditImages": "Edytuj obrazy", "ButtonEditOtherUserPreferences": "Edytuj profil, obrazy i ustawienia osobiste tego użytkownika.", - "ButtonFilter": "Filtr", "ButtonForgotPassword": "Zapomniałem hasła", "ButtonFullscreen": "Pełny ekran", "ButtonGotIt": "Rozumiem", "ButtonGuide": "Przewodnik", - "ButtonHome": "Start", "ButtonInfo": "Informacje", "ButtonLibraryAccess": "Dostęp do biblioteki", "ButtonManualLogin": "Logowanie manualne", "ButtonMore": "Więcej", "ButtonNetwork": "Sieć", "ButtonNextTrack": "Następny utwór", - "ButtonOff": "Wyłącz", "ButtonOpen": "Otwórz", "ButtonParentalControl": "Kontrola rodzicielska", "ButtonPause": "Pauza", - "ButtonPlay": "Odtwarzaj", "ButtonPreviousTrack": "Poprzedni utwór", "ButtonProfile": "Profil", "ButtonQuickStartGuide": "Skrócona Instrukcja Obsługi", - "ButtonRefresh": "Odśwież", "ButtonRefreshGuideData": "Odśwież dane przewodnika", "ButtonRemove": "Usuń", "ButtonRename": "Zmień nazwę", @@ -105,7 +98,6 @@ "ButtonSignOut": "Wyloguj", "ButtonStop": "Zatrzymaj", "ButtonSubmit": "Zatwierdź", - "ButtonSubtitles": "Napisy", "ButtonTrailer": "Zwiastun", "ButtonUninstall": "Odinstaluj", "ButtonWebsite": "Strona WWW", @@ -194,9 +186,7 @@ "EnablePhotosHelp": "Obrazy będą wykrywane i wyświetlane obok innych plików multimedialnych.", "EnableStreamLooping": "Zapętlaj żądania transmisji", "EnableStreamLoopingHelp": "Aktywuj tę opcję w przypadku, gdy transmisje na żywo zawierają tylko kilka sekund danych i wymagają ciągłego ponawiania żądań transmisji. Aktywowanie tej funkcji w przypadku braku potrzeby może powodować problemy.", - "EnableThemeSongs": "Motywy muzyczne", "EnableThemeSongsHelp": "Odtwarzaj motywy muzyczne podczas przeglądania biblioteki.", - "EnableThemeVideos": "Motywy wideo", "EnableThemeVideosHelp": "Podczas przeglądania biblioteki odtwarzaj w tle motywy wideo.", "Ended": "Zakończony", "EndsAtValue": "Koniec o {0}", @@ -252,11 +242,9 @@ "HeaderActiveDevices": "Aktywne urządzenia", "HeaderActiveRecordings": "Nagrania aktywne", "HeaderActivity": "Aktywność", - "HeaderAddScheduledTaskTrigger": "Dodawanie wyzwalacza", "HeaderAddToCollection": "Dodaj do kolekcji", "HeaderAddToPlaylist": "Dodaj do listy", "HeaderAddUpdateImage": "Dodaj / Aktualizuj obraz", - "HeaderAddUser": "Dodaj użytkownika", "HeaderAdditionalParts": "Dodatkowe części", "HeaderAdmin": "Administracja", "HeaderAlbumArtists": "Wykonawcy albumów", @@ -270,12 +258,10 @@ "HeaderAudioBooks": "Książka mówiona", "HeaderAudioSettings": "Ustawienia dźwięku", "HeaderBlockItemsWithNoRating": "Blokuj pozycje z brakującą lub nierozpoznaną kategorią wiekową:", - "HeaderBooks": "Książki", "HeaderBranding": "Dostosowywanie", "HeaderCancelRecording": "Anuluj nagranie", "HeaderCancelSeries": "Anuluj nagrywanie serialu", "HeaderCastAndCrew": "Obsada i ekipa", - "HeaderCastCrew": "Obsada i ekipa", "HeaderChannelAccess": "Dostęp do Kanałów", "HeaderChapterImages": "Obrazy rozdziałów", "HeaderCodecProfile": "Profil Kodeków", @@ -309,14 +295,12 @@ "HeaderEditImages": "Edytuj obrazy", "HeaderEnabledFields": "Pola aktywne", "HeaderEnabledFieldsHelp": "Odznacz pole, aby je zablokować i zapobiec zmianom danych w przyszłości.", - "HeaderEpisodes": "Odcinki", "HeaderError": "Błąd", "HeaderExternalIds": "Identyfikatory zewnętrzne:", "HeaderFeatureAccess": "Dostęp do funkcji", "HeaderFetchImages": "Pobieraj obrazy:", "HeaderFetcherSettings": "Ustawienia pobierania", "HeaderForKids": "Dla dzieci", - "HeaderForgotPassword": "Zapomniałem hasła", "HeaderFrequentlyPlayed": "Często odtwarzane", "HeaderGuideProviders": "Dostawcy danych przewodnika telewizyjnego", "HeaderHttpHeaders": "Nagłówki HTTP", @@ -345,7 +329,6 @@ "HeaderLoginFailure": "Niepowodzenie logowania", "HeaderMedia": "Multimedia", "HeaderMediaFolders": "Foldery mediów", - "HeaderMediaInfo": "O mediach", "HeaderMetadataSettings": "Ustawienia metadanych", "HeaderMoreLikeThis": "Więcej podobnych", "HeaderMusicQuality": "Jakość muzyki", @@ -478,7 +461,6 @@ "LabelAppNameExample": "Przykład: Sickbeard, Sonarr", "LabelArtists": "Wykonawcy:", "LabelArtistsHelp": "Oddziel wielu artystów średnikiem \";\"", - "LabelAudio": "Dźwięk", "LabelAudioLanguagePreference": "Preferowany język ścieżki dźwiękowej:", "LabelAutomaticallyRefreshInternetMetadataEvery": "Odświeżaj automatycznie metadane z Internetu:", "LabelBindToLocalNetworkAddress": "Przypisz do lokalnego adresu sieciowego:", @@ -506,7 +488,6 @@ "LabelCustomCertificatePathHelp": "Ścieżka do pliku PKCS #12, zawierającego certyfikat i klucz prywatny, niezbędny do aktywowana obsługi TLS dla własnej domeny.", "LabelCustomCss": "Niestandardowy CSS:", "LabelCustomCssHelp": "Zastosuj własne niestandardowe arkusze stylów dla interfejsu webowego.", - "LabelCustomDeviceDisplayName": "Nazwa wyświetlana:", "LabelCustomDeviceDisplayNameHelp": "Dostarcz własną nazwę wyświetlania lub zostaw puste i użyj nazwy dostarczonej przez urządzenie.", "LabelCustomRating": "Kategoria wiekowa własna:", "LabelDateAdded": "Data dodania:", @@ -523,7 +504,6 @@ "LabelDiscNumber": "Numer dysku:", "LabelDisplayLanguage": "Język interfejsu:", "LabelDisplayLanguageHelp": "Tłumaczenie Jellyfin to projekt, który ciągle trwa.", - "LabelDisplayMissingEpisodesWithinSeasons": "Wyświetlaj w sezonach brakujące odcinki", "LabelDisplayMode": "Tryb wyświetlania:", "LabelDisplayName": "Nazwa wyświetlana:", "LabelDisplayOrder": "Kolejność wyświetlania:", @@ -677,7 +657,6 @@ "LabelPostProcessorArguments": "Argumenty linii poleceń dla aplikacji przetwarzania:", "LabelPostProcessorArgumentsHelp": "Skorzystaj z wypełniacza {path} jako folder pliku nagrania.", "LabelPreferredDisplayLanguage": "Preferowany język interfejsu:", - "LabelPreferredDisplayLanguageHelp": "Tłumaczenie Jellyfin to projekt w ciągłym rozwoju.", "LabelPreferredSubtitleLanguage": "Preferowany język napisów:", "LabelProfileAudioCodecs": "Kodeki audio:", "LabelProfileCodecs": "Kodeki:", @@ -737,7 +716,6 @@ "LabelSubtitleDownloaders": "Dostawcy napisów:", "LabelSubtitleFormatHelp": "Przykład: srt", "LabelSubtitlePlaybackMode": "Tryb napisów:", - "LabelSubtitles": "Napisy", "LabelSupportedMediaTypes": "Obsługiwane typy mediów:", "LabelTVHomeScreen": "Ekran startowy trybu telewizyjnego:", "LabelTag": "Znacznik:", @@ -750,12 +728,9 @@ "LabelTimeLimitHours": "Limit czasu (godziny):", "LabelTitle": "Tytuł:", "LabelTrackNumber": "Numer utworu:", - "LabelTranscodingAudioCodec": "Kodek audio:", - "LabelTranscodingContainer": "Kontener:", "LabelTranscodingTempPathHelp": "Podaj niestandardową ścieżkę dla plików transkodowanych udostępnianych klientom. Pozostaw puste, aby użyć domyślnych ustawień serwera.", "LabelTranscodingThreadCount": "Liczba wątków transkodowania:", "LabelTranscodingThreadCountHelp": "Wybierz maksymalną liczbę wątków dla transkodowania. Ograniczenie ich liczby, obniży poziom użycia procesora, ale może niekorzystnie wpłynąć na płynność odtwarzania.", - "LabelTranscodingVideoCodec": "Kodek wideo:", "LabelTriggerType": "Typ wyzwalacza:", "LabelTunerIpAddress": "Adres IP dekodera:", "LabelTunerType": "Typ tunera:", @@ -861,7 +836,6 @@ "MessagePluginConfigurationRequiresLocalAccess": "Aby skonfigurować ten plugin zaloguj się bezpośrednio do lokalnego serwera.", "MessagePluginInstallDisclaimer": "Wtyczki stworzone przez członków społeczności to świetny sposób na ulepszenie Twojego doświadczenia dzięki dodatkowym funkcjom i korzyściom. Przed instalacją zwróć uwagę na skutki, jakie mogą mieć na serwerze, takie jak dłuższe skanowanie bibliotek, dodatkowe przetwarzanie w tle i zmniejszona stabilność systemu.", "MessageReenableUser": "Zobacz poniżej aby aktywować ponownie", - "MessageSettingsSaved": "Ustawienia zapisane.", "MessageTheFollowingLocationWillBeRemovedFromLibrary": "Następujące lokalizacje mediów zostaną usunięte z twojej biblioteki:", "MessageUnableToConnectToServer": "Połączenie z wybranym serwerem jest teraz niemożliwe. Upewnij się, że jest uruchomiony i spróbuj ponownie.", "MessageUnsetContentHelp": "Zawartość będzie wyświetlana jako proste foldery. W celu uzyskania najlepszych wyników, użyj menadżera metadanych do ustawienia typu zawartości podfolderów.", @@ -926,7 +900,6 @@ "OptionArtist": "Wykonawca", "OptionAscending": "Rosnąco", "OptionAuto": "Automatycznie", - "OptionAutomatic": "Automatycznie", "OptionAutomaticallyGroupSeries": "Scalaj seriale znajdujące się w wielu folderach", "OptionAutomaticallyGroupSeriesHelp": "Serie rozmieszczone w wielu folderach w tej bibliotece zostaną automatycznie połączone w jedną serię.", "OptionBlockBooks": "Książki", @@ -1167,18 +1140,14 @@ "TV": "Telewizor", "TabAccess": "Dostęp", "TabAdvanced": "Zaawansowane", - "TabAlbumArtists": "Wykonawcy albumów", "TabCatalog": "Katalog", "TabCodecs": "Kodeki", "TabContainers": "Kontenery", "TabDashboard": "Kokpit", "TabDirectPlay": "Odtwarzanie Bezposrednie", - "TabEpisodes": "Odcinki", - "TabInfo": "Informacje", "TabLatest": "Ostatnio dodane", "TabLogs": "Dziennik zdarzeń", "TabMusic": "Muzyka", - "TabMusicVideos": "Teledyski", "TabMyPlugins": "Zainstalowane", "TabNetworks": "Sieci", "TabNfoSettings": "Ustawienia NFO", @@ -1189,12 +1158,10 @@ "TabProfile": "Profil", "TabProfiles": "Profile", "TabResponses": "Odpowiedzi", - "TabResumeSettings": "Wznawianie", "TabScheduledTasks": "Harmonogram zadań", "TabServer": "Serwer", "TabSettings": "Ustawienia", "TabStreaming": "Transmitowanie", - "TabTrailers": "Zwiastuny", "TabUpcoming": "Wkrótce", "Tags": "Znaczniki", "TagsValue": "Znaczniki: {0}", @@ -1271,7 +1238,6 @@ "HeaderFavoriteArtists": "Ulubieni wykonawcy", "HeaderFavoriteSongs": "Ulubione utwory", "HeaderFavoriteVideos": "Ulubione Filmy", - "HeaderHome": "Strona główna", "LabelAuthProvider": "Dostawca autentykacji:", "LabelDynamicExternalId": "{0} Id:", "LabelFormat": "Format:", diff --git a/src/strings/pr.json b/src/strings/pr.json index ea27024045..4c99a4556c 100644 --- a/src/strings/pr.json +++ b/src/strings/pr.json @@ -10,16 +10,12 @@ "FolderTypeMusic": "Sea Shanties", "OptionBlockBooks": "Tall Tales", "HeaderFavoriteBooks": "Fav'rit Tales", - "HeaderBooks": "Tall Tales", "HeaderAudioBooks": "Spoken Tales", "FolderTypeBooks": "Tall Tales", "Books": "Tall Tales", "LabelHomeNetworkQuality": "Sail strength:", "Home": "Poop Deck", - "HeaderHome": "Poop Deck", "DisplayInOtherHomeScreenSections": "Show on Poop Deck such as latest booty and continue plundering", - "ButtonHome": "Poop deck", - "HeaderCastCrew": "Mateys", "Add": "Upend", "Actor": "Privateer", "AccessRestrictedTryAgainLater": "Ye arn't appearin' on the list o' the livin'!", diff --git a/src/strings/pt-br.json b/src/strings/pt-br.json index 25f6afd31e..8019cf9eeb 100644 --- a/src/strings/pt-br.json +++ b/src/strings/pt-br.json @@ -58,30 +58,23 @@ "ButtonBack": "Voltar", "ButtonCancel": "Cancelar", "ButtonChangeServer": "Alterar Servidor", - "ButtonEdit": "Editar", - "ButtonEditImages": "Editar imagens", "ButtonEditOtherUserPreferences": "Editar este perfil de usuário, imagem e preferências pessoais.", - "ButtonFilter": "Filtrar", "ButtonForgotPassword": "Esqueci a Senha", "ButtonFullscreen": "Tela Cheia", "ButtonGotIt": "Feito", "ButtonGuide": "Guia", - "ButtonHome": "Início", "ButtonLibraryAccess": "Acesso à biblioteca", "ButtonManualLogin": "Login Manual", "ButtonMore": "Mais", "ButtonNetwork": "Rede", "ButtonNextTrack": "Próxima faixa", - "ButtonOff": "Desligar", "ButtonOk": "OK", "ButtonOpen": "Abrir", "ButtonParentalControl": "Controle dos pais", "ButtonPause": "Pausar", - "ButtonPlay": "Reproduzir", "ButtonPreviousTrack": "Faixa anterior", "ButtonProfile": "Perfil", "ButtonQuickStartGuide": "Guia Rápido", - "ButtonRefresh": "Atualizar", "ButtonRefreshGuideData": "Atualizar Dados do Guia", "ButtonRemove": "Remover", "ButtonRename": "Renomear", @@ -102,7 +95,6 @@ "ButtonStart": "Iniciar", "ButtonStop": "Parar", "ButtonSubmit": "Enviar", - "ButtonSubtitles": "Legendas", "ButtonUninstall": "Desinstalar", "CancelRecording": "Cancelar gravação", "CancelSeries": "Cancelar série", @@ -185,9 +177,7 @@ "EnablePhotosHelp": "Imagens serão detectadas e exibidas junto com outros arquivos de mídia.", "EnableStreamLooping": "Repetir automaticamente transmissões ao vivo", "EnableStreamLoopingHelp": "Ative se as transmissões ao vivo contem poucos segundos de dados e necessitam ser continuamente solicitadas. Ativar esta opção sem necessidade pode causar problemas.", - "EnableThemeSongs": "Músicas-tema", "EnableThemeSongsHelp": "Reproduz músicas-tema em segundo plano ao navegar pela biblioteca.", - "EnableThemeVideos": "Vídeos-tema", "EnableThemeVideosHelp": "Reproduz vídeos-tema em segundo plano ao navegar pela biblioteca.", "Ended": "Finalizada", "EndsAtValue": "Termina às {0}", @@ -242,11 +232,9 @@ "HeaderActiveDevices": "Dispositivos Ativos", "HeaderActiveRecordings": "Gravações Ativas", "HeaderActivity": "Atividade", - "HeaderAddScheduledTaskTrigger": "Adicionar Disparador", "HeaderAddToCollection": "Adicionar à Coletânea", "HeaderAddToPlaylist": "Adicionar à Lista de Reprodução", "HeaderAddUpdateImage": "Adicionar/Atualizar Imagem", - "HeaderAddUser": "Adicionar Usuário", "HeaderAdditionalParts": "Partes Adicionais", "HeaderAlbumArtists": "Artistas do Álbum", "HeaderAlert": "Alerta", @@ -258,12 +246,10 @@ "HeaderAudioBooks": "Livros de Áudio", "HeaderAudioSettings": "Configurações de Áudio", "HeaderBlockItemsWithNoRating": "Bloquear itens com avaliação desconhecida ou sem avaliação:", - "HeaderBooks": "Livros", "HeaderBranding": "Marca", "HeaderCancelRecording": "Cancelar Gravação", "HeaderCancelSeries": "Cancelar Série", "HeaderCastAndCrew": "Elenco e Equipe", - "HeaderCastCrew": "Elenco e Equipe", "HeaderChannelAccess": "Acesso ao Canal", "HeaderChapterImages": "Imagens do Capítulo", "HeaderCodecProfile": "Perfil do Codec", @@ -297,14 +283,12 @@ "HeaderEditImages": "Editar Imagens", "HeaderEnabledFields": "Campos Ativados", "HeaderEnabledFieldsHelp": "Desmarque um campo para bloqueá-lo e evitar que seus dados sejam alterados.", - "HeaderEpisodes": "Episódios", "HeaderError": "Erro", "HeaderExternalIds": "IDs Externos:", "HeaderFeatureAccess": "Acesso aos Recursos", "HeaderFetchImages": "Buscar Imagens:", "HeaderFetcherSettings": "Configurações do Buscador", "HeaderForKids": "Para Crianças", - "HeaderForgotPassword": "Esqueci a Senha", "HeaderFrequentlyPlayed": "Reproduzidos Frequentemente", "HeaderGuideProviders": "Provedores de Dados do Guia da TV", "HeaderHttpHeaders": "Cabeçalhos de Http", @@ -333,7 +317,6 @@ "HeaderLoginFailure": "Falha no Login", "HeaderMedia": "Mídia", "HeaderMediaFolders": "Pastas de Mídia", - "HeaderMediaInfo": "Informações de Mídia", "HeaderMetadataSettings": "Configurações dos Metadados", "HeaderMoreLikeThis": "Mais Disso", "HeaderMusicQuality": "Qualidade da Música", @@ -463,7 +446,6 @@ "LabelAppNameExample": "Exemplo: Sickbeard, Sonarr", "LabelArtists": "Artistas:", "LabelArtistsHelp": "Separe múltiplos artistas usando ponto e vírgula.", - "LabelAudio": "Áudio", "LabelAudioLanguagePreference": "Idioma preferido de áudio:", "LabelAutomaticallyRefreshInternetMetadataEvery": "Atualizar automaticamente os metadados da internet:", "LabelBindToLocalNetworkAddress": "Vincular a um endereço de rede local:", @@ -490,7 +472,6 @@ "LabelCustomCertificatePathHelp": "Local do arquivo PKCS #12 contendo certificado e chave privada para ativar o suporte TLS em um domínio personalizado.", "LabelCustomCss": "CSS personalizado:", "LabelCustomCssHelp": "Aplica o seu estilo personalizado para a interface web.", - "LabelCustomDeviceDisplayName": "Nome para exibição:", "LabelCustomDeviceDisplayNameHelp": "Fornece um nome para exibição ou deixe em branco para usar o nome informado pelo dispositivo.", "LabelCustomRating": "Avaliação personalizada:", "LabelDateAdded": "Data de adição:", @@ -507,7 +488,6 @@ "LabelDiscNumber": "Número do disco:", "LabelDisplayLanguage": "Idioma de exibição:", "LabelDisplayLanguageHelp": "A tradução do Jellyfin é um projeto em andamento.", - "LabelDisplayMissingEpisodesWithinSeasons": "Exibir episódios em falta nas temporadas", "LabelDisplayMode": "Modo de exibição:", "LabelDisplayName": "Nome para exibição:", "LabelDisplayOrder": "Ordem de exibição:", @@ -662,7 +642,6 @@ "LabelPostProcessorArguments": "Argumentos de linha de comando do pós-processador:", "LabelPostProcessorArgumentsHelp": "Usar {path} como o local do arquivo de gravação.", "LabelPreferredDisplayLanguage": "Idioma preferido de exibição:", - "LabelPreferredDisplayLanguageHelp": "A tradução do Jellyfin é um projeto em andamento.", "LabelPreferredSubtitleLanguage": "Idioma de legendas preferido:", "LabelProfileAudioCodecs": "Codecs de áudio:", "LabelProfileCodecsHelp": "Separados por vírgula. Deixe em branco para aplicar a todos os codecs.", @@ -719,7 +698,6 @@ "LabelSubtitleDownloaders": "Downloaders de legendas:", "LabelSubtitleFormatHelp": "Exemplo: srt", "LabelSubtitlePlaybackMode": "Modo de legenda:", - "LabelSubtitles": "Legendas", "LabelSupportedMediaTypes": "Tipos de Mídia Suportados:", "LabelTVHomeScreen": "Tela inicial do modo TV:", "LabelTagline": "Slogan:", @@ -731,11 +709,9 @@ "LabelTimeLimitHours": "Limite de tempo (horas):", "LabelTitle": "Título:", "LabelTrackNumber": "Número da faixa:", - "LabelTranscodingAudioCodec": "Codec de áudio:", "LabelTranscodingTempPathHelp": "Define um local personalizado para os arquivos transcodificados enviados aos clientes. Deixe em branco para usar o local padrão do servidor.", "LabelTranscodingThreadCount": "Contagem de threads da transcodificação:", "LabelTranscodingThreadCountHelp": "Selecione o número máximo de threads a ser usado quando transcodificar. Reduzir o número de threads irá diminuir o uso da CPU, mas pode não converter rápido o suficiente para uma experiência de reprodução suave.", - "LabelTranscodingVideoCodec": "Codec de vídeo:", "LabelTriggerType": "Tipo de Disparador:", "LabelTunerIpAddress": "Endereço IP do Sintonizador:", "LabelTunerType": "Tipo de sintonizador:", @@ -838,7 +814,6 @@ "MessagePluginConfigurationRequiresLocalAccess": "Para configurar este plugin, por favor entre em seu servidor local diretamente.", "MessagePluginInstallDisclaimer": "Plugins feitos por membros da comunidade Jellyfin são uma grande forma de melhorar sua experiência Jellyfin com funcionalidades e benefícios adicionais. Antes de instalar, por favor certifique-se de conhecer os efeitos que podem causar no seu Servidor Jellyfin, tais como rastreamentos de biblioteca mais demorados, processamento adicional e diminuição na estabilidade do sistema.", "MessageReenableUser": "Veja abaixo para reativar", - "MessageSettingsSaved": "Configurações salvas.", "MessageTheFollowingLocationWillBeRemovedFromLibrary": "As seguintes localizações de mídia serão excluídas de sua biblioteca:", "MessageUnableToConnectToServer": "Não foi possível conectar ao servidor selecionado. Por favor, verifique se está sendo executado e tente novamente.", "MessageUnsetContentHelp": "O conteúdo será exibido como pastas simples. Para melhores resultados, use o gerenciador de metadados para definir os tipos de conteúdo das sub-pastas.", @@ -1130,14 +1105,11 @@ "SystemDlnaProfilesHelp": "Os perfis do sistema estão apenas em modo leitura. As alterações feitas no perfil do sistema serão salvas em um novo perfil personalizado.", "TabAccess": "Acesso", "TabAdvanced": "Avançado", - "TabAlbumArtists": "Artistas do Álbum", "TabCatalog": "Catálogo", "TabDashboard": "Painel", "TabDirectPlay": "Reprodução Direta", - "TabEpisodes": "Episódios", "TabLatest": "Recentes", "TabMusic": "Música", - "TabMusicVideos": "Videoclipes", "TabMyPlugins": "Meus Plugins", "TabNetworks": "Emissoras", "TabNfoSettings": "Configurações de NFO", @@ -1147,7 +1119,6 @@ "TabProfile": "Perfil", "TabProfiles": "Perfis", "TabResponses": "Respostas", - "TabResumeSettings": "Retomar", "TabScheduledTasks": "Tarefas Agendadas", "TabServer": "Servidor", "TabSettings": "Configurações", @@ -1253,7 +1224,6 @@ "HeaderFavoriteArtists": "Artistas favoritos", "HeaderFavoriteSongs": "Músicas favoritas", "HeaderFavoriteVideos": "Videos favoritos", - "HeaderHome": "Inicio", "LabelAuthProvider": "Provedor de autenticação:", "LabelServerName": "Nome do servidor:", "LabelTranscodePath": "Pasta de transcodificação:", @@ -1267,7 +1237,6 @@ "LabelWeb": "Web:", "OptionBluray": "Blu-ray", "LabelProfileContainer": "Formato:", - "LabelTranscodingContainer": "Formato:", "LabelXDlnaCap": "X-DLNA cap:", "LabelXDlnaDoc": "X-DLNA doc:", "MediaInfoStreamTypeAudio": "Áudio", @@ -1280,7 +1249,6 @@ "MusicAlbum": "Álbum de Música", "MusicArtist": "Artista da Música", "MusicVideo": "Videoclipe", - "OptionAutomatic": "Automático", "OptionBanner": "Banner", "OptionBlockTrailers": "Trailers", "OptionCaptionInfoExSamsung": "CaptionInfoEx (Samsung)", @@ -1310,12 +1278,10 @@ "TV": "TV", "TabCodecs": "Codecs", "TabContainers": "Formatos", - "TabInfo": "Informações", "TabLogs": "Logs", "TabNetworking": "Rede", "TabPlugins": "Plugins", "TabStreaming": "Streaming", - "TabTrailers": "Trailers", "Tags": "Marcadores", "TagsValue": "Marcadores: {0}", "Trailers": "Trailers", diff --git a/src/strings/pt-pt.json b/src/strings/pt-pt.json index 02fa88aaf6..d421efa30d 100644 --- a/src/strings/pt-pt.json +++ b/src/strings/pt-pt.json @@ -16,12 +16,9 @@ "ButtonBack": "Voltar", "ButtonCancel": "Cancelar", "ButtonChangeServer": "Alterar Servidor", - "ButtonEdit": "Editar", "ButtonEditOtherUserPreferences": "Editar este perfil de utilizador, imagem e preferências pessoais.", - "ButtonFilter": "Filtro", "ButtonForgotPassword": "Esqueci-me da palavra-passe", "ButtonFullscreen": "Ecrã inteiro", - "ButtonHome": "Início", "ButtonInfo": "Informação", "ButtonManualLogin": "Início de Sessão Manual", "ButtonMore": "Mais", @@ -29,11 +26,9 @@ "ButtonNextTrack": "Faixa seguinte", "ButtonOpen": "Abrir", "ButtonPause": "Pausar", - "ButtonPlay": "Reproduzir", "ButtonPreviousTrack": "Faixa anterior", "ButtonProfile": "Perfil", "ButtonQuickStartGuide": "Guia de Início Rápido", - "ButtonRefresh": "Atualizar", "ButtonRefreshGuideData": "Atualizar Programação de TV", "ButtonRemove": "Remover", "ButtonResetEasyPassword": "Redefinir código PIN", @@ -52,7 +47,6 @@ "ButtonStart": "Iniciar", "ButtonStop": "Parar", "ButtonSubmit": "Enviar", - "ButtonSubtitles": "Legendas", "ButtonUninstall": "Desinstalar", "ChannelAccessHelp": "Selecione os canais para partilhar com este utilizador. Os administradores poderão editar todos os canais utilizando o gestor de metadados.", "CinemaModeConfigurationHelp": "O modo cinema traz a experiência do cinema para a sua sala, possibilitando reproduzir trailers e introduções personalizadas antes da longa-metragem.", @@ -97,10 +91,8 @@ "HeaderActiveDevices": "Dispositivos Ativos", "HeaderActiveRecordings": "Gravações Ativas", "HeaderActivity": "Atividade", - "HeaderAddScheduledTaskTrigger": "Adicionar Tarefa Agendada", "HeaderAddToCollection": "Adicionar à Coleção", "HeaderAddUpdateImage": "Adicionar/Atualizar Imagem", - "HeaderAddUser": "Adicionar Utilizador", "HeaderAdditionalParts": "Partes Adicionais", "HeaderApiKey": "Chave da API", "HeaderApiKeys": "Chaves da API", @@ -109,7 +101,6 @@ "HeaderAudioSettings": "Configurações de Áudio", "HeaderBlockItemsWithNoRating": "Bloquear conteúdo sem informação de classificação etária ou com informação desconhecida:", "HeaderBranding": "Marca", - "HeaderCastCrew": "Elenco e Equipa", "HeaderChannelAccess": "Acesso ao Canal", "HeaderCodecProfile": "Perfil do Codec", "HeaderCodecProfileHelp": "Perfis do Codec indicam as limitações de um dispositivo ao reproduzir codecs específicos. Se uma limitação ocorre, o ficheiro multimédia será transcodificado, mesmo se o codec estiver configurado para reprodução direta.", @@ -135,7 +126,6 @@ "HeaderError": "Erro", "HeaderFeatureAccess": "Acesso a Características", "HeaderFetchImages": "Procurar Imagens:", - "HeaderForgotPassword": "Esqueci-me da palavra-passe", "HeaderFrequentlyPlayed": "Reproduzido Frequentemente", "HeaderGuideProviders": "Provedores de Programação de TV", "HeaderHttpHeaders": "Cabeçalhos HTTP", @@ -158,7 +148,6 @@ "HeaderLoginFailure": "Falha no Login", "HeaderMedia": "Multimédia", "HeaderMediaFolders": "Pastas Multimédia", - "HeaderMediaInfo": "Informações Multimédia", "HeaderMetadataSettings": "Configurações de Metadados", "HeaderMusicVideos": "Videoclips", "HeaderMyMedia": "O Meu Conteúdo", @@ -264,7 +253,6 @@ "LabelCustomCertificatePathHelp": "Localização do ficheiro PKCS #12 que contém um certificado e um chave privada, que permite ativar o suporte a ligações TLS em domínios privados.", "LabelCustomCss": "CSS personalizado:", "LabelCustomCssHelp": "Aplica um ficheiro de estilos customizado à interface web.", - "LabelCustomDeviceDisplayName": "Nome a ser mostrado:", "LabelCustomDeviceDisplayNameHelp": "Forneça um nome a ser mostrado, ou deixe em branco para utilizar o nome reportado pelo dispositivo.", "LabelCustomRating": "Classificação personalizada:", "LabelDateAdded": "Adicionado a:", @@ -275,7 +263,6 @@ "LabelDefaultUserHelp": "Determina que biblioteca será apresentada aos dispositivos ligados. Pode ser redefinido para cada dispositivo utilizando perfis.", "LabelDeviceDescription": "Descrição do dispositivo", "LabelDidlMode": "Modo DIDL:", - "LabelDisplayMissingEpisodesWithinSeasons": "Mostrar episódios em falta numa série", "LabelDisplayName": "Nome para apresentação:", "LabelDisplayOrder": "Ordem de apresentação:", "LabelDisplaySpecialsWithinSeasons": "Mostrar epsódios especiais nas temporadas em que estrearam", @@ -390,7 +377,6 @@ "LabelPlaceOfBirth": "Local de nascimento:", "LabelPlayDefaultAudioTrack": "Reproduzir a faixa de áudio padrão independentemente do idioma", "LabelPreferredDisplayLanguage": "Idioma de visualização preferido:", - "LabelPreferredDisplayLanguageHelp": "A tradução do Jellyfin é um projeto contínuo.", "LabelProfileAudioCodecs": "Codecs do áudio:", "LabelProfileCodecsHelp": "Separados por vírgula. Pode ser deixado em branco para usar com todos os codecs.", "LabelProfileContainer": "Contentor:", @@ -434,12 +420,9 @@ "LabelTagline": "Slogan:", "LabelTime": "Tempo:", "LabelTimeLimitHours": "Limite de tempo (horas):", - "LabelTranscodingAudioCodec": "Codec de áudio:", - "LabelTranscodingContainer": "Contentor:", "LabelTranscodingTempPathHelp": "Indique uma localização personalizada para os ficheiros de transcodificação em utilização, ou deixe em branco para utilizar o caminho por defeito.", "LabelTranscodingThreadCount": "Número de threads de transcodificação:", "LabelTranscodingThreadCountHelp": "Indique o número máximo de threads a ser utilizado para transcodificação. Reduzir o número de threads diminuirá a utilização do CPU, mas pode não converter rápido o suficiente para uma experiência de reprodução suave.", - "LabelTranscodingVideoCodec": "Codec do vídeo:", "LabelTriggerType": "Tipo do Acionador:", "LabelTunerIpAddress": "Endereço IP do Sintonizador:", "LabelTunerType": "Tipo do sintonizador:", @@ -509,7 +492,6 @@ "OptionAllowVideoPlaybackTranscoding": "Permitir reprodução de vídeo que necessite de transcodificação", "OptionArtist": "Artista", "OptionAscending": "Ascendente", - "OptionAutomatic": "Automático", "OptionBlockBooks": "Livros", "OptionBlockChannelContent": "Conteúdo do Canal de Internet", "OptionBlockLiveTvChannels": "Canais de TV em Direto", @@ -636,15 +618,12 @@ "SystemDlnaProfilesHelp": "Perfis de sistema são apenas de leitura. Mudanças a um perfil de sistema serão guardadas num novo perfil personalizado.", "TabAccess": "Acesso", "TabAdvanced": "Avançado", - "TabAlbumArtists": "Artistas do Álbum", "TabCatalog": "Catálogo", "TabContainers": "Contentores", "TabDashboard": "Painel Principal", "TabDirectPlay": "Reprodução Direta", - "TabEpisodes": "Episódios", "TabLatest": "Mais recente", "TabMusic": "Música", - "TabMusicVideos": "Videoclips", "TabMyPlugins": "As Minhas Extensões", "TabNetworks": "Redes", "TabNfoSettings": "Definições de Ficheiros NFO", @@ -752,7 +731,6 @@ "ButtonLibraryAccess": "Acesso à biblioteca", "ButtonGuide": "Programação", "ButtonGotIt": "Entendido", - "ButtonEditImages": "Editar imagens", "ButtonAudioTracks": "Faixas de Áudio", "Browse": "Procurar", "BoxRear": "Caixa (verso)", @@ -766,12 +744,10 @@ "HeaderKeepRecording": "Manter Gravação", "HeaderKeepSeries": "Manter Série", "HeaderImageOptions": "Opções de Imagem", - "HeaderHome": "Início", "HeaderForKids": "Para Crianças", "HeaderFavoriteVideos": "Vídeos Favoritos", "HeaderFavoriteMovies": "Filmes Favoritos", "HeaderExternalIds": "IDs Externos:", - "HeaderEpisodes": "Episódios", "HeaderEditImages": "Editar Imagens", "HeaderDownloadSync": "Transferência & Sincronização", "HeaderDetectMyDevices": "Detetar os Meus Dispositivos", @@ -785,7 +761,6 @@ "HeaderChapterImages": "Imagens do Capítulo", "HeaderCancelSeries": "Cancelar Gravação de Série", "HeaderCancelRecording": "Cancelar Gravação", - "HeaderBooks": "Livros", "HeaderAudioBooks": "Livros de Áudio", "HeaderAllowMediaDeletionFrom": "Permitir remoção de multimédia a partir de", "HeaderAlert": "Alerta", @@ -877,7 +852,6 @@ "LabelBindToLocalNetworkAddress": "Endereço local para colocar o servidor à escuta:", "LabelAutomaticallyRefreshInternetMetadataEvery": "Atualizar metadados automaticamente a partir da Internet:", "LabelAuthProvider": "Provedor de autenticação:", - "LabelAudio": "Áudio", "LabelAllowedRemoteAddressesMode": "Tipo de filtro de IP remoto:", "LabelAllowedRemoteAddresses": "Filtro de IP remoto:", "LabelAllowHWTranscoding": "Permitir transcodificação por hardware", @@ -992,7 +966,6 @@ "News": "Notícias", "Programs": "Programas", "Directors": "Realização", - "ButtonOff": "Desligado", "ButtonAddImage": "Adicionar Imagem", "LabelOriginalTitle": "Título original:", "LabelPostProcessorArgumentsHelp": "Utilizar o caminho {path} como caminho para o ficheiro de gravação.", @@ -1000,8 +973,6 @@ "LabelBaseUrl": "URL Base:", "LabelNewName": "Novo nome:", "HeaderUploadImage": "Enviar Imagem", - "EnableThemeSongs": "Músicas do tema", - "EnableThemeVideos": "Vídeos do tema", "HeaderMoreLikeThis": "Mais Como Este", "HeaderRecordingPostProcessing": "Pós-Processamento de Gravações", "Descending": "Descendente", @@ -1190,7 +1161,6 @@ "Metadata": "Metadados", "MessageYouHaveVersionInstalled": "Neste momento está instalada a versão {0}.", "MessageUnsetContentHelp": "O conteúdo será mostrado como pastas simples. Para melhores resultados, utilize o gestor de metadados para definir o tipo de conteúdo das sub-pastas.", - "MessageSettingsSaved": "Definições guardadas.", "MessagePleaseWait": "Por favor, aguarde. Esta operação poderá demorar alguns instantes.", "MessagePlayAccessRestricted": "A reprodução deste conteúdo encontra-se, de momento, restrita. Por favor, contacte o administrador do sistema para mais informação.", "MessageNoServersAvailable": "Não foram encontrados servidores através da pesquisa automática.", @@ -1227,7 +1197,6 @@ "LabelTextColor": "Côr do texto:", "LabelTextBackgroundColor": "Côr de fundo do texto:", "LabelTag": "Etiqueta:", - "LabelSubtitles": "Legendas", "LabelSportsCategories": "Categorias de Desporto:", "FetchingData": "A transferir informação adicional", "List": "lista", @@ -1271,10 +1240,7 @@ "ThemeSongs": "Músicas de tema", "TagsValue": "Etiquetas: {0}", "Tags": "Etiquetas", - "TabTrailers": "Trailers", - "TabResumeSettings": "Retomar", "TabLogs": "Logs", - "TabInfo": "Info", "TabCodecs": "Codecs", "Suggestions": "Sugestões", "SortName": "Ordenar nome", diff --git a/src/strings/pt.json b/src/strings/pt.json index 95842bb22a..733044c2bf 100644 --- a/src/strings/pt.json +++ b/src/strings/pt.json @@ -48,15 +48,12 @@ "TabNfoSettings": "Definições de Ficheiros NFO", "TabNetworks": "Redes", "TabMyPlugins": "As Minhas Extensões", - "TabMusicVideos": "Videoclips", "TabMusic": "Música", "TabLatest": "Mais recente", - "TabEpisodes": "Episódios", "TabDirectPlay": "Reprodução Directa", "TabDashboard": "Painel Principal", "TabContainers": "Contentores", "TabCatalog": "Catálogo", - "TabAlbumArtists": "Artistas do Álbum", "TabAdvanced": "Avançado", "TabAccess": "Acesso", "TV": "TV", @@ -204,7 +201,6 @@ "LabelProfileCodecs": "Codecs:", "LabelProfileAudioCodecs": "Codecs do áudio:", "LabelPreferredSubtitleLanguage": "Idioma de legendas preferido:", - "LabelPreferredDisplayLanguageHelp": "A tradução do Jellyfin é um projeto contínuo.", "LabelPreferredDisplayLanguage": "Idioma de visualização preferido:", "LabelPostProcessorArgumentsHelp": "Utilizar {path} como caminho para o ficheiro de gravação.", "LabelPostProcessorArguments": "Argumentos de linha de comandos para a aplicação de pós-processamento:", @@ -356,7 +352,6 @@ "LabelDisplayOrder": "Ordem de apresentação:", "LabelDisplayName": "Nome para apresentação:", "LabelDisplayMode": "Modo de apresentação:", - "LabelDisplayMissingEpisodesWithinSeasons": "Mostrar episódios em falta dentro das temporadas", "LabelDisplayLanguageHelp": "A tradução do Jellyfin é um projeto em desenvolvimento contínuo.", "LabelDisplayLanguage": "Idioma:", "LabelDiscNumber": "Número do disco:", @@ -385,7 +380,6 @@ "LabelDateAdded": "Adicionado a:", "LabelCustomRating": "Classificação personalizada:", "LabelCustomDeviceDisplayNameHelp": "Forneça um nome a ser mostrado, ou deixe em branco para utilizar o nome reportado pelo dispositivo.", - "LabelCustomDeviceDisplayName": "Nome a ser mostrado:", "LabelCustomCssHelp": "Aplicar um ficheiro de estilos personalizado à interface web.", "LabelCustomCss": "CSS personalizado:", "LabelCustomCertificatePathHelp": "Localização do ficheiro PKCS #12 que contém um certificado e um chave privada que permitem activar o suporte a ligações TLS em domínios privados.", @@ -413,7 +407,6 @@ "LabelAudioCodec": "Codec de áudio:", "LabelAudioChannels": "Canais de áudio:", "LabelAudioBitrate": "Taxa de bits de áudio:", - "LabelAudio": "Áudio", "LabelArtistsHelp": "Separe múltiplos com ;", "LabelArtists": "Artistas:", "LabelAppNameExample": "Exemplo: Sickbeard, NzbDrone", @@ -542,7 +535,6 @@ "HeaderMusicQuality": "Qualidade da Música", "HeaderMoreLikeThis": "Mais Como Este", "HeaderMetadataSettings": "Configurações de Metadados", - "HeaderMediaInfo": "Informações Multimédia", "HeaderMediaFolders": "Pastas Multimédia", "HeaderMedia": "Multimédia", "HeaderLiveTvTunerSetup": "Configurar Sintonizador de TV", @@ -567,12 +559,10 @@ "HeaderIdentificationCriteriaHelp": "Introduza, pelo menos, um critério de identificação.", "HeaderIdentification": "Identificação", "HeaderHttpHeaders": "Cabeçalhos HTTP", - "HeaderHome": "Início", "HeaderGuideProviders": "Provedores de Programação de TV", "HeaderDeleteTaskTrigger": "Excluir Tarefa Agendada", "HeaderBranding": "Marca", "HeaderFrequentlyPlayed": "Reproduzido Frequentemente", - "HeaderForgotPassword": "Esqueci-me da palavra-passe", "HeaderForKids": "Para Crianças", "HeaderFetchImages": "Procurar Imagens:", "OptionDownloadThumbImage": "Miniatura", @@ -601,7 +591,6 @@ "OptionBlockLiveTvChannels": "Canais de TV em Directo", "OptionBlockChannelContent": "Conteúdo do Canal de Internet", "OptionBlockBooks": "Livros", - "OptionAutomatic": "Automático", "OptionAscending": "Ascendente", "OptionArtist": "Artista", "OptionAllowVideoPlaybackTranscoding": "Permitir reprodução de vídeo que necessite de transcodificação", @@ -718,12 +707,9 @@ "LabelTunerType": "Tipo do sintonizador:", "LabelTunerIpAddress": "Endereço IP do Sintonizador:", "LabelTriggerType": "Tipo do Accionador:", - "LabelTranscodingVideoCodec": "Codec do vídeo:", "LabelTranscodingThreadCountHelp": "Indique o número máximo de processors a utilizadar para transcodificação. Reduzir o número de processos diminuirá a utilização do CPU, mas pode não converter suficientemente rápido para uma experiência de reprodução suave.", "LabelTranscodingThreadCount": "Número de processos de transcodificação:", "LabelTranscodingTempPathHelp": "Indique uma localização personalizada para os ficheiros de transcodificação em utilização, ou deixe em branco para utilizar o caminho por omissão.", - "LabelTranscodingContainer": "Contentor:", - "LabelTranscodingAudioCodec": "Codec de áudio:", "LabelTimeLimitHours": "Limite de tempo (horas):", "LabelTime": "Tempo:", "LabelTextSize": "Tamanho do Texto:", @@ -769,7 +755,6 @@ "HeaderFavoriteBooks": "Livros Favoritos", "HeaderExternalIds": "IDs Externos:", "HeaderError": "Erro", - "HeaderEpisodes": "Episódios", "HeaderEnabledFieldsHelp": "Desmarque um campo para bloqueá-lo e evitar que os seus dados sejam alterados.", "HeaderEnabledFields": "Campos Activados", "HeaderEditImages": "Editar Imagens", @@ -810,9 +795,7 @@ "Episodes": "Episódios", "EndsAtValue": "Termina às {0}", "EnableThemeVideosHelp": "Reproduzir vídeos do tema em plano de fundo durante a navegação pela Biblioteca.", - "EnableThemeVideos": "Vídeos do tema", "EnableThemeSongsHelp": "Reproduzir músicas do tema em plano de fundo durante a navegação pela Biblioteca.", - "EnableThemeSongs": "Músicas do tema", "EnableStreamLoopingHelp": "Active esta opção no caso de a transmissão em directo apenas conter alguns segundos de dados e necessitar de ser continuamente requisitada. Activar esta opção quando não é necessário pode causar problemas.", "EnablePhotosHelp": "Imagens serão detectadas e mostradas em conjunto com outros ficheiros multimédia.", "EnablePhotos": "Mostrar fotografias", @@ -900,7 +883,6 @@ "ButtonWebsite": "Website", "ButtonUninstall": "Desinstalar", "ButtonTrailer": "Trailer", - "ButtonSubtitles": "Legendas", "ButtonSubmit": "Enviar", "ButtonStop": "Parar", "ButtonStart": "Iniciar", @@ -921,29 +903,22 @@ "ButtonRename": "Alterar o nome", "ButtonRemove": "Remover", "ButtonRefreshGuideData": "Actualizar Programação de TV", - "ButtonRefresh": "Actualizar", "ButtonQuickStartGuide": "Guia de Início Rápido", "ButtonProfile": "Perfil", "ButtonPreviousTrack": "Faixa anterior", - "ButtonPlay": "Reproduzir", "ButtonPause": "Pausar", "ButtonParentalControl": "Controlo parental", "ButtonOpen": "Abrir", "ButtonOk": "OK", - "ButtonOff": "Desligado", "ButtonNextTrack": "Faixa seguinte", "ButtonNetwork": "Rede", "ButtonMore": "Mais", "ButtonManualLogin": "Início de Sessão Manual", "ButtonLibraryAccess": "Acesso à biblioteca", "ButtonInfo": "Informação", - "ButtonHome": "Início", "ButtonFullscreen": "Ecrã inteiro", "ButtonForgotPassword": "Esqueci-me da palavra-passe", - "ButtonFilter": "Filtro", "ButtonEditOtherUserPreferences": "Editar este perfil de utilizador, imagem e preferências pessoais.", - "ButtonEditImages": "Editar imagens", - "ButtonEdit": "Editar", "Auto": "Automático", "AlwaysPlaySubtitles": "Mostrar sempre legendas", "AllowMediaConversionHelp": "Permitir ou negar acesso à funcionalidade de conversão multimédia.", @@ -1063,10 +1038,8 @@ "HeaderCodecProfile": "Perfil do Codec", "HeaderChapterImages": "Imagens do Capítulo", "HeaderChannelAccess": "Acesso ao Canal", - "HeaderCastCrew": "Elenco e Equipa", "HeaderCancelSeries": "Cancelar Gravação de Série", "HeaderCancelRecording": "Cancelar Gravação", - "HeaderBooks": "Livros", "HeaderBlockItemsWithNoRating": "Bloquear conteúdo sem informação de classificação etária ou com informação desconhecida:", "HeaderAudioSettings": "Configurações de Áudio", "HeaderAudioBooks": "Livros de Áudio", @@ -1078,11 +1051,9 @@ "HeaderAlert": "Alerta", "HeaderAlbumArtists": "Artistas do Álbum", "HeaderAdditionalParts": "Partes Adicionais", - "HeaderAddUser": "Adicionar Utilizador", "HeaderAddUpdateImage": "Adicionar/Actualizar Imagem", "HeaderAddToPlaylist": "Adicionar à Lista de Reprodução", "HeaderAddToCollection": "Adicionar à Colecção", - "HeaderAddScheduledTaskTrigger": "Adicionar Tarefa Agendada", "HeaderActivity": "Actividade", "HeaderActiveRecordings": "Gravações Activas", "HeaderActiveDevices": "Dispositivos Activos", @@ -1160,7 +1131,6 @@ "Metadata": "Metadados", "MessageYouHaveVersionInstalled": "Você possui a versão {0} atualmente instalada.", "MessageUnsetContentHelp": "O conteúdo será exibido como pastas simples. Para obter melhores resultados, use o gerenciador de metadados para definir os tipos de conteúdo das subpastas.", - "MessageSettingsSaved": "Configurações salvas.", "MessagePleaseWait": "Por favor, espere. Isso pode levar um minuto.", "MessagePlayAccessRestricted": "A reprodução deste conteúdo está atualmente restrita. Entre em contato com o administrador do servidor para obter mais informações.", "MessageNoServersAvailable": "Nenhum servidor foi encontrado usando a descoberta automática de servidores.", @@ -1211,7 +1181,6 @@ "LabelTextBackgroundColor": "Cor do plano de fundo do texto:", "LabelTag": "Tag:", "LabelTVHomeScreen": "Tela inicial do modo TV:", - "LabelSubtitles": "Legendas:", "LabelSubtitleDownloaders": "Downloaders de legendas:", "LabelStreamType": "Tipo de fluxo:", "LabelSpecialSeasonsDisplayName": "Nome de exibição da temporada especial:", diff --git a/src/strings/ro.json b/src/strings/ro.json index 6eeeeba01f..962862324d 100644 --- a/src/strings/ro.json +++ b/src/strings/ro.json @@ -3,12 +3,8 @@ "ButtonAddScheduledTaskTrigger": "Adaugă declanșator", "ButtonAddUser": "Adaugă Utilizator", "ButtonCancel": "Anulează", - "ButtonEdit": "Modifică", - "ButtonFilter": "Filtru", "ButtonManualLogin": "Conectare manuală", - "ButtonPlay": "Redă", "ButtonQuickStartGuide": "Ghid rapid de Start", - "ButtonRefresh": "Reîmprospătează", "ButtonRefreshGuideData": "Reîmprospătează Ghidul", "ButtonRemove": "Elimină", "ButtonResetPassword": "Resetează parola", @@ -29,8 +25,6 @@ "FolderTypeTvShows": "Seriale TV", "Friday": "Vineri", "HeaderActiveRecordings": "Înregistrări active", - "HeaderAddScheduledTaskTrigger": "Adaugă declanșator", - "HeaderAddUser": "Adaugă Utilizator", "HeaderContinueWatching": "Vizionează în continuare", "HeaderDeviceAccess": "Accesul Dispozitivelor", "HeaderEasyPinCode": "Cod Pin Ușor", @@ -61,7 +55,6 @@ "LabelCurrentPassword": "Parola curentă:", "LabelCustomCertificatePath": "Calea către certificatul personalizat:", "LabelCustomCertificatePathHelp": "Furnizați propriul fișier care conține un certificat SSL in format .pfx.", - "LabelDisplayMissingEpisodesWithinSeasons": "Afișeaza episoadele lipsă din sezon", "LabelFinish": "Termină", "LabelLanguage": "Limba:", "LabelMaxBackdropsPerItem": "Numărul maxim de fundaluri pentru fiecare element:", @@ -111,7 +104,6 @@ "OptionAllowRemoteSharedDevicesHelp": "Dispozitivele DLNA sunt considerate partajate până ce un utilizator începe să le controleze.", "OptionAllowUserToManageServer": "Permite acestui utilizator să administreze serverul", "OptionAscending": "Ascendent", - "OptionAutomatic": "Auto", "OptionCommunityRating": "Rating Comunitate", "OptionContinuing": "Continuă", "OptionCriticRating": "Rating Critic", @@ -160,11 +152,8 @@ "Sunday": "Duminică", "TabAccess": "Acces", "TabAdvanced": "Avansat", - "TabAlbumArtists": "Albume Artiști", - "TabEpisodes": "Episoade", "TabLatest": "Cele mai recente", "TabMusic": "Muzică", - "TabMusicVideos": "Videoclipuri muzicale", "TabMyPlugins": "Plugin-urile mele", "TabNetworks": "Rețele TV", "TabNotifications": "Notificări", @@ -172,7 +161,6 @@ "TabProfile": "Profil", "TabProfiles": "Profile", "TabSettings": "Setări", - "TabTrailers": "Trailere", "TabUpcoming": "Urmează să apară", "TellUsAboutYourself": "Spune-ne despre tine", "ThisWizardWillGuideYou": "Acest asistent vă va ghida prin procesul de configurare. Pentru a începe, vă rugăm să selectați limba preferată.", @@ -271,19 +259,16 @@ "ButtonAudioTracks": "Cale Audio", "ButtonBack": "Înapoi", "ButtonChangeServer": "Schimbă Server", - "ButtonEditImages": "Modifică imaginile", "ButtonEditOtherUserPreferences": "Modifică profilul, imaginea și preferințele personale ale acestui utilizator.", "ButtonForgotPassword": "Parolă uitată", "ButtonFullscreen": "Umple ecranul", "ButtonGotIt": "Am înțeles", "ButtonGuide": "Ghid", - "ButtonHome": "Acasă", "ButtonInfo": "Info", "ButtonLibraryAccess": "Acces Librarie", "ButtonMore": "Mai mult", "ButtonNetwork": "Rețea", "ButtonNextTrack": "Următoarea cale", - "ButtonOff": "Oprit", "ButtonOk": "Ok", "ButtonOpen": "Deschide", "ButtonParentalControl": "Control parental", @@ -307,7 +292,6 @@ "ButtonSend": "Trimite", "ButtonShutdown": "Oprește", "ButtonStart": "Start", - "ButtonSubtitles": "Subtitrări", "ButtonTrailer": "Trailer", "ButtonUninstall": "Dezinstalează", "ButtonWebsite": "Website", @@ -357,7 +341,6 @@ "HDPrograms": "Programe HD", "HeaderApiKeys": "Chei API", "HeaderApp": "Aplicație", - "HeaderCastCrew": "Distribuție și echipă", "HeaderConfirmPluginInstallation": "Confirmați instalarea plugin-ului", "HeaderDeleteItems": "Ștergeți Elemente", "HeaderDeleteProvider": "Ștergeți Furnizorul", @@ -368,7 +351,6 @@ "HeaderEditImages": "Editează imagini", "HeaderEnabledFields": "Câmpuri activate", "HeaderEnabledFieldsHelp": "Debifează un câmp pentru a-l bloca și pentru a împiedica schimbarea datelor sale.", - "HeaderEpisodes": "Episoade", "HeaderError": "Eroare", "HeaderExternalIds": "ID-uri Externe:", "HeaderFavoriteBooks": "Cărți Favorite", @@ -381,9 +363,7 @@ "HeaderFavoriteVideos": "Video Favorite", "HeaderFetcherSettings": "Setări Fetcher", "HeaderForKids": "Pentru Copii", - "HeaderForgotPassword": "Am uitat parola", "HeaderGuideProviders": "Furnizori de date ghid TV", - "HeaderHome": "Acasă", "HeaderHttpHeaders": "Anteturi HTTP", "HeaderIdentification": "Identificare", "HeaderIdentificationCriteriaHelp": "Introduceți cel puțin un criteriu de identificare.", @@ -399,7 +379,6 @@ "HeaderLoginFailure": "Autentificare eșuată", "HeaderMedia": "Media", "HeaderMediaFolders": "Dosare Media", - "HeaderMediaInfo": "Informații Media", "HeaderMetadataSettings": "Setări metadate", "HeaderMoreLikeThis": "Mai multe ca acesta", "HeaderMusicQuality": "Calitatea muzicii", @@ -462,7 +441,6 @@ "HeaderAppearsOn": "Apare în", "HeaderAudioBooks": "Carți Audio", "HeaderAudioSettings": "Setari audio", - "HeaderBooks": "Cărți", "HeaderChannelAccess": "Accesare canal", "HeaderChapterImages": "Imagini Capitol", "HeaderCodecProfile": "Profilul Codec-ului", @@ -536,9 +514,7 @@ "EnableNextVideoInfoOverlayHelp": "La sfârșitul unui video, afișați informații despre următorul video care urmează în lista de redare curentă.", "EnablePhotosHelp": "Imaginile vor fi detectate și afișate alături de alte fișiere media.", "EnableStreamLooping": "Fluxuri live cu buclă automată", - "EnableThemeSongs": "Melodii tematice", "EnableThemeSongsHelp": "Redați melodii tematice în fundal în timp ce navigați în bibliotecă.", - "EnableThemeVideos": "Videoclipuri tematice", "EnableThemeVideosHelp": "Redați videoclipuri tematice în fundal în timp ce navigați în bibliotecă.", "ErrorAddingTunerDevice": "A apărut o eroare la adăugarea tuner-ului. Vă rugăm să vă asigurați că este accesibil și încercați din nou.", "ErrorDeletingItem": "A apărut o eroare la ștergerea elementului din server. Vă rugăm să verificați dacă Jellyfin are acces de scriere la folderul media și încercați din nou.", @@ -571,8 +547,6 @@ "LabelTranscodingFramerate": "Rata de cadru a transcodării:", "LabelTranscodes": "Transcodează:", "LabelTranscodePath": "Cale transcodare:", - "LabelTranscodingContainer": "Container :", - "LabelTranscodingAudioCodec": "Codec audio:", "LabelTrackNumber": "Număr melodie:", "LabelTitle": "Titlu:", "LabelTime": "Ora:", @@ -584,7 +558,6 @@ "LabelTag": "Etichetă:", "LabelTVHomeScreen": "Ecran de pornire în modul TV:", "LabelSupportedMediaTypes": "Tipuri media suportate:", - "LabelSubtitles": "Subtitrări", "LabelSubtitlePlaybackMode": "Mod subtitrare:", "LabelSubtitleFormatHelp": "Exemplu: srt", "LabelSubtitleDownloaders": "Descărcare subtitrări:", @@ -639,7 +612,6 @@ "LabelProfileCodecs": "Codecuri:", "LabelProfileAudioCodecs": "Codecuri audio:", "LabelPreferredSubtitleLanguage": "Limba subtitrare preferată:", - "LabelPreferredDisplayLanguageHelp": "Traducerea Jellyfin este un proiect în derulare.", "LabelPreferredDisplayLanguage": "Limba de afișare preferată:", "LabelPostProcessorArgumentsHelp": "Utilizați {path} ca și cale către fișierul de înregistrare.", "LabelPostProcessorArguments": "Argumentele liniei de comandă post-procesare:", @@ -802,7 +774,6 @@ "LabelDateAdded": "Data adăugării:", "LabelCustomRating": "Evaluare personalizată:", "LabelCustomDeviceDisplayNameHelp": "Furnizați un nume de afișare personalizat sau lăsați gol pentru a utiliza numele raportat de dispozitiv.", - "LabelCustomDeviceDisplayName": "Numele afisat:", "LabelCustomCssHelp": "Aplicați propriul stil personalizat pe interfața web.", "LabelCustomCss": "CSS personalizat:", "LabelCriticRating": "Evaluare critic:", @@ -829,7 +800,6 @@ "LabelAudioChannels": "Canale audio:", "LabelAudioBitrate": "Rata de biți audio:", "LabelAudioBitDepth": "Adâncimea bitului audio:", - "LabelAudio": "Audio", "LabelAppNameExample": "Exemplu: Sickbeard, Sonarr", "LabelAppName": "Nume app", "LabelAllowedRemoteAddressesMode": "Modul de filtrare a adresei IP de la distanță:", @@ -964,7 +934,6 @@ "MessageUnsetContentHelp": "Conținutul va fi afișat ca foldere simple. Pentru cele mai bune rezultate, utilizați managerul de metadate pentru a seta tipurile de conținut ale sub-foldererelor.", "MessageUnableToConnectToServer": "Nu putem să ne conectăm la serverul selectat în acest moment. Vă rugăm să vă asigurați că funcționează și încercați din nou.", "MessageTheFollowingLocationWillBeRemovedFromLibrary": "Următoarele locații media vor fi eliminate din biblioteca dvs.:", - "MessageSettingsSaved": "Setări salvate.", "MessageReenableUser": "Consultați mai jos pentru a reactiva", "MessagePluginInstallDisclaimer": "Pluginurile create de membrii comunității sunt o modalitate excelentă de a vă îmbunătăți experiența cu funcții și beneficii suplimentare. Înainte de instalare, vă rugăm să fiți conștienți de efectele pe care le pot avea asupra serverului dvs., cum ar fi scanările de bibliotecă mai îndelungate, procesare suplimentară în fundal și scăderea stabilității sistemului.", "MessagePluginConfigurationRequiresLocalAccess": "Pentru a configura acest plugin, vă rugăm să vă conectați direct la serverul dvs. local.", @@ -1084,7 +1053,6 @@ "LabelType": "Tip:", "LabelTunerType": "Tip tuner:", "LabelTunerIpAddress": "Adresă IP Tuner:", - "LabelTranscodingVideoCodec": "Codec video:", "LabelTranscodingThreadCountHelp": "Selectați numărul maxim de fire de execuție de utilizat la transcodare. Reducerea numărului de fire de execuție va scădea utilizarea procesorului, dar este posibil să nu se convertească suficient de repede pentru o experiență de redare lină.", "Suggestions": "Recomandări", "Subtitles": "Subtitrări", @@ -1337,14 +1305,12 @@ "TabStreaming": "Transmitere", "TabServer": "Server", "TabScheduledTasks": "Task-uri programate", - "TabResumeSettings": "Continuă", "TabResponses": "Răspunsuri", "TabPlugins": "Pluginuri", "TabParentalControl": "Control Parental", "TabNfoSettings": "Setări NFO", "TabNetworking": "Rețele", "TabLogs": "Jurnal", - "TabInfo": "Info", "TabDirectPlay": "Redare directă", "TabDashboard": "Tablou de bord", "TabContainers": "Containere", diff --git a/src/strings/ru.json b/src/strings/ru.json index 8982b7f187..28e47b7cc8 100644 --- a/src/strings/ru.json +++ b/src/strings/ru.json @@ -62,31 +62,24 @@ "ButtonBack": "Назад", "ButtonCancel": "Отменить", "ButtonChangeServer": "Сменить сервер", - "ButtonEdit": "Править", - "ButtonEditImages": "Править изображения", "ButtonEditOtherUserPreferences": "Править профиль, изображение и персональные настройки этого пользователя.", - "ButtonFilter": "Фильтр", "ButtonForgotPassword": "Напомнить пароль", "ButtonFullscreen": "Полный экран", "ButtonGotIt": "Понятно", "ButtonGuide": "Телегид", - "ButtonHome": "Главное", "ButtonInfo": "Инфо", "ButtonLibraryAccess": "Доступ к медиатеке", "ButtonManualLogin": "Войти вручную", "ButtonMore": "Ещё", "ButtonNetwork": "Сеть", "ButtonNextTrack": "Следующая дорожка", - "ButtonOff": "Откл", "ButtonOk": "Ок", "ButtonOpen": "Открыть", "ButtonParentalControl": "Родительский контроль", "ButtonPause": "Пауза", - "ButtonPlay": "Воспроизведение", "ButtonPreviousTrack": "Предыдущая дорожка", "ButtonProfile": "Профиль", "ButtonQuickStartGuide": "Руководство по запуску", - "ButtonRefresh": "Обновить", "ButtonRefreshGuideData": "Обновить данные телегида", "ButtonRemove": "Изъять", "ButtonRename": "Переименовать", @@ -107,7 +100,6 @@ "ButtonStart": "Запустить", "ButtonStop": "Остановить", "ButtonSubmit": "Подтвердить", - "ButtonSubtitles": "Субтитры", "ButtonTogglePlaylist": "Плей-лист", "ButtonTrailer": "Трейлер", "ButtonUninstall": "Удалить", @@ -196,9 +188,7 @@ "EnablePhotosHelp": "Изображения будут обнаруживаться и отображаться наряду с другими медиафайлами.", "EnableStreamLooping": "Зацикливание трансляций", "EnableStreamLoopingHelp": "Включайте, если трансляции содержат данные только на несколько секунд и необходимо непрерывно их запрашивать. Включение этого без необходимости может породить проблемы.", - "EnableThemeSongs": "Тематические композиции", "EnableThemeSongsHelp": "Воспроизведение тематических композиций в фоновом режиме при навигации по медиатеке.", - "EnableThemeVideos": "Тематические видео", "EnableThemeVideosHelp": "Воспроизведение тематических видео в фоновом режиме при навигации по медиатеке.", "Ended": "Прекращённое", "EndsAtValue": "Конец в {0}", @@ -255,11 +245,9 @@ "HeaderActiveDevices": "Активные устройства", "HeaderActiveRecordings": "Активные записи", "HeaderActivity": "Действия", - "HeaderAddScheduledTaskTrigger": "Добавление триггера", "HeaderAddToCollection": "Добавить в коллекцию", "HeaderAddToPlaylist": "Добавление в плей-лист", "HeaderAddUpdateImage": "Добавление/Обновление изображения", - "HeaderAddUser": "Добавить пользователя", "HeaderAdditionalParts": "Дополнительные части", "HeaderAdmin": "Администрирование", "HeaderAlbumArtists": "Исполнители альбома", @@ -273,12 +261,10 @@ "HeaderAudioBooks": "Аудиокниги", "HeaderAudioSettings": "Параметры аудио", "HeaderBlockItemsWithNoRating": "Блокирование элементов с отсутствующей или нераспознанной информацией о возрастной категории:", - "HeaderBooks": "Книги", "HeaderBranding": "Оформление", "HeaderCancelRecording": "Отменить запись", "HeaderCancelSeries": "Отмена сериала", "HeaderCastAndCrew": "Снимались и снимали", - "HeaderCastCrew": "Снимались и снимали", "HeaderChannelAccess": "Доступ ко каналам", "HeaderChapterImages": "Изображения сцен", "HeaderCodecProfile": "Профиль кодеков", @@ -312,14 +298,12 @@ "HeaderEditImages": "Править изображения", "HeaderEnabledFields": "Включённые поля", "HeaderEnabledFieldsHelp": "Снимите флажок, чтобы зафиксировать поле и защитить его данные от изменнений.", - "HeaderEpisodes": "Эпизоды", "HeaderError": "Ошибка", "HeaderExternalIds": "Внешние идентификаторы:", "HeaderFeatureAccess": "Доступ к компонентам", "HeaderFetchImages": "Отборка изображений:", "HeaderFetcherSettings": "Параметры отборщика", "HeaderForKids": "Детям", - "HeaderForgotPassword": "Забыли пароль", "HeaderFrequentlyPlayed": "Воспроизведённые часто", "HeaderGuideProviders": "Поставщики данных телегида", "HeaderHttpHeaders": "HTTP-заголовки", @@ -348,7 +332,6 @@ "HeaderLoginFailure": "Сбой входа", "HeaderMedia": "Медиаданные", "HeaderMediaFolders": "Медиапапки", - "HeaderMediaInfo": "О медиаданных", "HeaderMetadataSettings": "Параметры метаданных", "HeaderMoreLikeThis": "Ещё подобное этому", "HeaderMusicQuality": "Качество музыки", @@ -480,8 +463,7 @@ "LabelAppName": "Название приложения", "LabelAppNameExample": "Пример: Sickbeard, Sonarr", "LabelArtists": "Исполнители:", - "LabelArtistsHelp": "Для разделения исполнителей используйте ; (точку с запятой).", - "LabelAudio": "Аудио", + "LabelArtistsHelp": "Для разделения исполнителей используйте точку с запятой ;", "LabelAudioLanguagePreference": "Выбор языка аудио:", "LabelAutomaticallyRefreshInternetMetadataEvery": "Автоматически обновлять метаданные из Интернета:", "LabelBindToLocalNetworkAddress": "Привязка к адресу в локальной сети:", @@ -509,7 +491,6 @@ "LabelCustomCertificatePathHelp": "Путь к файлу PKCS #12, содержащему сертификат и \tзакрытый ключ для включения поддержки TLS на произвольном домене.", "LabelCustomCss": "Настраиваемые CSS:", "LabelCustomCssHelp": "Применяйте свои собственные настраиваемые стили в веб-интерфейсе.", - "LabelCustomDeviceDisplayName": "Отображаемое название:", "LabelCustomDeviceDisplayNameHelp": "Приведите произвольное имя для отображения или не заполняйте, чтобы использовать имя, выданное устройством.", "LabelCustomRating": "Произвольная возрастная категория:", "LabelDateAdded": "Дата добавления:", @@ -526,7 +507,6 @@ "LabelDiscNumber": "Номер диска:", "LabelDisplayLanguage": "Язык отображения:", "LabelDisplayLanguageHelp": "Перевод Jellyfin ведётся на постоянной основе.", - "LabelDisplayMissingEpisodesWithinSeasons": "Отображать отсутствующие эпизоды в пределах сезонов", "LabelDisplayMode": "Режим отображения:", "LabelDisplayName": "Отображаемое название:", "LabelDisplayOrder": "Порядок отображения:", @@ -681,7 +661,6 @@ "LabelPostProcessorArguments": "Аргументы командной строки постобработчика:", "LabelPostProcessorArgumentsHelp": "Используйте {path} как путь к записываемому файлу.", "LabelPreferredDisplayLanguage": "Выбор языка отображения:", - "LabelPreferredDisplayLanguageHelp": "Перевод Jellyfin ведётся на постоянной основе.", "LabelPreferredSubtitleLanguage": "Выбор языка субтитров:", "LabelProfileAudioCodecs": "Аудиокодеки:", "LabelProfileCodecs": "Кодеки:", @@ -741,7 +720,6 @@ "LabelSubtitleDownloaders": "Загрузчики субтитров:", "LabelSubtitleFormatHelp": "Пример: srt", "LabelSubtitlePlaybackMode": "Режим субтитров:", - "LabelSubtitles": "Субтитры", "LabelSupportedMediaTypes": "Поддерживаемые типы медиаданных:", "LabelTVHomeScreen": "Главная страница ТВ-режима:", "LabelTag": "Тег:", @@ -754,12 +732,9 @@ "LabelTimeLimitHours": "Временной лимит (час):", "LabelTitle": "Название:", "LabelTrackNumber": "Номер дорожки:", - "LabelTranscodingAudioCodec": "Аудио профиль:", - "LabelTranscodingContainer": "Контейнер:", "LabelTranscodingTempPathHelp": "Укажите произвольный путь для файлов перекодировки, служащие для клиентов. Оставьте пустым, чтобы использовать умолчания сервера.", "LabelTranscodingThreadCount": "Количество перекодирующих подпотоков:", "LabelTranscodingThreadCountHelp": "Выберите максимальное число подпотоков для использования при перекодировке. Сокращение числа подпотоков понижает нагрузку на ЦП, но преобразование может оказаться недостаточно быстрым для впечатления плавного воспроизведения.", - "LabelTranscodingVideoCodec": "Видео кодек:", "LabelTriggerType": "Тип триггера:", "LabelTunerIpAddress": "IP-адрес тюнера:", "LabelTunerType": "Тип тюнера:", @@ -870,7 +845,6 @@ "MessagePluginConfigurationRequiresLocalAccess": "Чтобы конфигурировать данный плагин войдите непосредственно в свой локальный сервер.", "MessagePluginInstallDisclaimer": "Плагины, созданные членами сообщества являются отличным способом повышения эффективности с помощью дополнительных функций и компонентов. Перед установкой примите во внимание влияние, которое они могут оказать на сервер, например, длительные сканирования медиатеки, дополнительную фоновую обработку и снижение системной стабильности.", "MessageReenableUser": "См. ниже для разблокировки", - "MessageSettingsSaved": "Параметры сохранены.", "MessageTheFollowingLocationWillBeRemovedFromLibrary": "Из вашей медиатеки будут изъяты следующие расположения медиаданных:", "MessageUnableToConnectToServer": "Мы не можем подсоединиться к выбранному серверу в данный момент. Убедитесь, что он запущен и повторите попытку.", "MessageUnsetContentHelp": "Содержание отображается как обычные папки. Для наилучших результатов используйте диспетчер метаданных, чтобы задать тип содержания подпапок.", @@ -936,7 +910,6 @@ "OptionArtist": "Исполнитель", "OptionAscending": "По возрастанию", "OptionAuto": "Авто", - "OptionAutomatic": "Авто", "OptionAutomaticallyGroupSeries": "Автоматически сливать вместе сериалы, которые разбросаны по нескольким папкам", "OptionAutomaticallyGroupSeriesHelp": "Части сериала, которые разбросаны по нескольким папкам данной медиатеки, будут автоматически слиты в единый сериал.", "OptionBlockBooks": "Книги", @@ -1180,18 +1153,14 @@ "TV": "ТВ", "TabAccess": "Доступ", "TabAdvanced": "Расширенное", - "TabAlbumArtists": "Исполнители альбома", "TabCatalog": "Каталог", "TabCodecs": "Кодеки", "TabContainers": "Контейнеры", "TabDashboard": "Панель", "TabDirectPlay": "Прямое воспроизведение", - "TabEpisodes": "Эпизоды", - "TabInfo": "Инфо", "TabLatest": "Новейшее", "TabLogs": "Журналы", "TabMusic": "Музыка", - "TabMusicVideos": "Муз. видео", "TabMyPlugins": "Мои плагины", "TabNetworks": "Телесети", "TabNfoSettings": "Параметры NFO", @@ -1202,12 +1171,10 @@ "TabProfile": "Профиль", "TabProfiles": "Профили", "TabResponses": "Отклики", - "TabResumeSettings": "Возобновление", "TabScheduledTasks": "Планировщик", "TabServer": "Сервер", "TabSettings": "Параметры", "TabStreaming": "Трансляция", - "TabTrailers": "Трейлеры", "TabUpcoming": "Ожидаемое", "Tags": "Теги", "TagsValue": "Теги: {0}", @@ -1290,7 +1257,6 @@ "HeaderFavoriteArtists": "Избранные исполнители", "HeaderFavoriteSongs": "Избранные композиции", "HeaderFavoriteVideos": "Избранные видео", - "HeaderHome": "Главное", "LabelAuthProvider": "Поставщик аутентификации:", "LabelPasswordResetProvider": "Поставщик сброса пароля:", "LabelServerName": "Имя сервера:", diff --git a/src/strings/sk.json b/src/strings/sk.json index 7aef8eb515..91a24fc399 100644 --- a/src/strings/sk.json +++ b/src/strings/sk.json @@ -35,13 +35,10 @@ "ButtonBack": "Späť", "ButtonCancel": "Zrušiť", "ButtonChangeServer": "Zmeniť server", - "ButtonEdit": "Upraviť", - "ButtonEditImages": "Upraviť obrázky", "ButtonEditOtherUserPreferences": "Upraviť používateľský profil, obrázok a osobné preferencie.", "ButtonForgotPassword": "Zabudnuté heslo", "ButtonFullscreen": "Celá obrazovka", "ButtonGotIt": "Rozumiem", - "ButtonHome": "Domov", "ButtonManualLogin": "Manuálne prihlásenie", "ButtonMore": "Viac", "ButtonNetwork": "Sieť", @@ -49,11 +46,9 @@ "ButtonOpen": "Otvoriť", "ButtonParentalControl": "Rodičovská kontrola", "ButtonPause": "Pozastaviť", - "ButtonPlay": "Prehrať", "ButtonPreviousTrack": "Predchádzajúca stopa", "ButtonProfile": "Profil", "ButtonQuickStartGuide": "Príručka rýchleho štartu", - "ButtonRefresh": "Obnoviť", "ButtonRefreshGuideData": "Obnoviť údaje sprievodcu", "ButtonRemove": "Odstrániť", "ButtonRename": "Premenovať", @@ -70,7 +65,6 @@ "ButtonSignIn": "Prihlásiť sa", "ButtonSignOut": "Odhlásiť sa", "ButtonSubmit": "Potvrdiť", - "ButtonSubtitles": "Titulky", "ButtonTrailer": "Trailer", "ButtonUninstall": "Odinštalovať", "ButtonWebsite": "Webové stránky", @@ -157,12 +151,10 @@ "HeaderActivity": "Aktivita", "HeaderAddToCollection": "Pridať do kolekcie", "HeaderAddUpdateImage": "Pridať/aktualizovať obrázok", - "HeaderAddUser": "Pridať používateľa", "HeaderApiKey": "Kľúč API", "HeaderApiKeys": "Kľúče API", "HeaderAudioBooks": "Audio knihy", "HeaderAudioSettings": "Nastavenia zvuku", - "HeaderBooks": "Knihy", "HeaderCastAndCrew": "Obsadenie a štáb", "HeaderChapterImages": "Obrázky kapitol", "HeaderConfigureRemoteAccess": "Nastaviť vzdialený prístup", @@ -182,11 +174,9 @@ "HeaderDevices": "Zariadenia", "HeaderEasyPinCode": "Jednoduchý PIN kód", "HeaderEditImages": "Upraviť obrázky", - "HeaderEpisodes": "Epizódy", "HeaderError": "Chyba", "HeaderFetchImages": "Načítať obrázky:", "HeaderForKids": "Pre deti", - "HeaderForgotPassword": "Zabudnuté heslo", "HeaderFrequentlyPlayed": "Často hrané", "HeaderHttpHeaders": "HTTP hlavičky", "HeaderIdentification": "Identifikácia", @@ -206,7 +196,6 @@ "HeaderLibraryOrder": "Poradie knižnice", "HeaderLibrarySettings": "Nastavenia knižnice", "HeaderMedia": "Médiá", - "HeaderMediaInfo": "Informácie o médiu", "HeaderMetadataSettings": "Nastavenia metadát", "HeaderMoreLikeThis": "Podobné položky", "HeaderMusicQuality": "Kvalita hudby", @@ -312,7 +301,6 @@ "LabelDeviceDescription": "Popis zariadenia", "LabelDiscNumber": "Číslo disku:", "LabelDisplayLanguage": "Jazyk rozhrania:", - "LabelDisplayMissingEpisodesWithinSeasons": "Zobraziť chýbajúce epizódy v sériách", "LabelDisplayOrder": "Poradie zobrazenia:", "LabelDownloadLanguages": "Prebrať jazyky:", "LabelDropImageHere": "Presuňte obrázok sem.", @@ -428,7 +416,6 @@ "LabelStartWhenPossible": "Spustiť akonáhle je možné:", "LabelStatus": "Stav:", "LabelSubtitleFormatHelp": "Príklad: srt", - "LabelSubtitles": "Titulky", "LabelSupportedMediaTypes": "Podporované typy médií:", "LabelTextBackgroundColor": "Farba pozadia textu:", "LabelTextColor": "Farba textu:", @@ -438,9 +425,6 @@ "LabelTimeLimitHours": "Časový limit (v hodinách):", "LabelTitle": "Názov:", "LabelTrackNumber": "Číslo stopy:", - "LabelTranscodingAudioCodec": "Audio kodek:", - "LabelTranscodingContainer": "Obal:", - "LabelTranscodingVideoCodec": "Video kodek:", "LabelTunerIpAddress": "IP adresa tunera:", "LabelTunerType": "Typ tunera:", "LabelType": "Typ:", @@ -504,7 +488,6 @@ "MessageNothingHere": "Nič tu nie je.", "MessagePleaseEnsureInternetMetadata": "Prosím, uistite sa, že sťahovanie internetových metadát je povolené.", "MessagePleaseWait": "Prosím počkajte. Toto môže chvíľu trvať.", - "MessageSettingsSaved": "Nastavenia uložené.", "MessageTheFollowingLocationWillBeRemovedFromLibrary": "Nasledujúce umiestnenia médií budú odobraté z vašej knižnice:", "MessageYouHaveVersionInstalled": "Teraz máte nainštalovanú verziu {0}.", "Metadata": "Metadáta", @@ -556,7 +539,6 @@ "OptionArtist": "Umelec", "OptionAscending": "Vzostupne", "OptionAuto": "Automaticky", - "OptionAutomatic": "Automaticky", "OptionAutomaticallyGroupSeries": "Automaticky zlúčiť série, ktoré sú uložené v rôznych priečinkoch", "OptionBlockBooks": "Knihy", "OptionBlockMovies": "Filmy", @@ -720,10 +702,8 @@ "TabCodecs": "Kodeky", "TabContainers": "Kontajnery", "TabDashboard": "Dashboard", - "TabEpisodes": "Epizódy", "TabLatest": "Najnovšie", "TabMusic": "Hudba", - "TabMusicVideos": "Hudobné videá", "TabMyPlugins": "Moje zásuvné moduly", "TabNetworks": "Siete", "TabNfoSettings": "NFO nastavenia", @@ -734,10 +714,8 @@ "TabProfile": "Profil", "TabProfiles": "Profily", "TabResponses": "Odpovede", - "TabResumeSettings": "Pokračovať", "TabScheduledTasks": "Naplánované úlohy", "TabSettings": "Nastavenia", - "TabTrailers": "Trailery", "TabUpcoming": "Nadchádzajúce", "TellUsAboutYourself": "Povedzte nám niečo o sebe", "ThisWizardWillGuideYou": "Tento sprievodca Vám pomôže prejsť inštalačným procesom. Pre začatie zvoľte preferovaný jazyk.", @@ -795,9 +773,7 @@ "Aired": "Odvysielané", "Alerts": "Upozornenia", "AllowOnTheFlySubtitleExtraction": "Povoliť extrahovanie titulkov za behu", - "ButtonFilter": "Filter", "ButtonInfo": "Info", - "ButtonOff": "Vypnúť", "ButtonOk": "Ok", "ButtonStart": "Štart", "ButtonStop": "Zastaviť", @@ -860,14 +836,11 @@ "EnableNextVideoInfoOverlay": "Zobraziť informácie o nasledujúcom videu počas prehrávania", "EnableNextVideoInfoOverlayHelp": "Na konci videa sa zobrazia informácie o nasledujúcom videu v aktuálnom playliste.", "ErrorAddingMediaPathToVirtualFolder": "Pri pridávaní cesty k mediám nastala chyba. Uistite sa prosím, že cesta je platná, a že Jellyfin má prístup k umiestneniu.", - "HeaderAddScheduledTaskTrigger": "Pridať spúšťač", "HeaderAddToPlaylist": "Pridať do playlistu", "HeaderAlert": "Upozornenie", - "HeaderCastCrew": "Obsadenie a štáb", "HeaderDownloadSync": "Sťahovanie a synchronizácia", "HeaderExternalIds": "Externé ID:", "HeaderFeatureAccess": "Prístup k funkciám", - "HeaderHome": "Domov", "HeaderLoginFailure": "Prihlásenie zlyhalo", "HeaderMediaFolders": "Priečinky médií", "HeaderRemoveMediaFolder": "Odstrániť priečinok médií", @@ -879,7 +852,6 @@ "HeaderVideoType": "Typ videa", "HeaderVideoTypes": "Typy videí", "LabelAirsBeforeSeason": "Vysielané pred sériou:", - "LabelAudio": "Zvuk", "LabelBlockContentWithTags": "Blokovať položky s tagmi:", "LabelDisplayMode": "Režim zobrazenia:", "LabelDisplaySpecialsWithinSeasons": "Zobraziť špeciálne epizódy v sérií, v ktorej boli odvysielané", @@ -939,7 +911,6 @@ "Uniform": "Jednotné", "ThemeVideos": "Tematické videá", "ThemeSongs": "Tématická hudba", - "TabInfo": "Info", "TV": "TV", "SkipEpisodesAlreadyInMyLibraryHelp": "Epizódy budú porovnané na základe čísla série a epizódy, ak sú k dispozícii.", "SimultaneousConnectionLimitHelp": "Maximálny povolený počet súčasných streamov. Zadajte 0 pre vypnutie obmedzenia.", @@ -963,8 +934,6 @@ "HeaderEnabledFields": "Povolené polia", "HeaderAllowMediaDeletionFrom": "Povoliť zmazanie médií z", "HeaderAdmin": "Admin", - "EnableThemeVideos": "Videá úvodných zvučiek", - "EnableThemeSongs": "Úvodné zvučky", "EnablePhotosHelp": "Obrázky budú detekované a zobrazené spolu s ostatnými multimediálnymi súbormi.", "EnableColorCodedBackgrounds": "Farebne označené pozadia", "DropShadow": "Vrhať tieň", @@ -985,7 +954,6 @@ "LabelDefaultUserHelp": "Určuje, ktorá používateľská knižnica by mala byť zobrazená na pripojenom zariadení. Toto nastavenie môže byť prepísané pomocou profilov pre každé zariadenie.", "LabelDateAddedBehaviorHelp": "Pokiaľ majú metadáta hodnotu, bude vždy použitá pred niektorou z týchto možností.", "LabelCustomDeviceDisplayNameHelp": "Nahradte vlastným názvom alebo ponechajte prázdne, aby názov určilo zariadenie.", - "LabelCustomDeviceDisplayName": "Zobrazený názov:", "LabelCache": "Cache:", "LabelBurnSubtitles": "Vypáliť titulky:", "LabelBitrate": "Dátový tok:", @@ -1115,7 +1083,6 @@ "Thumb": "Náhľad", "TheseSettingsAffectSubtitlesOnThisDevice": "Toto nastavenie ovplyvní titulky na tomto zariadení", "TabNetworking": "Sieť", - "TabAlbumArtists": "Umelec albumu", "SystemDlnaProfilesHelp": "Systémové profily sú len na čítanie. Zmeny systémových profilov budú uložené do nového vlastné profilu.", "SubtitleOffset": "Odchýlka titulkov", "SubtitleDownloadersHelp": "Povolí a ohodnotí vaše preferované sťahovače titulkov podľa priority.", @@ -1277,7 +1244,6 @@ "LabelProtocolInfoHelp": "Hodnota, ktorá sa použije pri odpovedi na požiadavky GetProtocolInfo z tohoto zariadenia.", "LabelProfileContainersHelp": "Oddelené čiarkou. Pokiaľ zostane pole prázdne, aplikuje sa na všetky kontajnery.", "LabelProfileCodecsHelp": "Oddelené čiarkou. Pokiaľ zostane pole prázdne, aplikuje sa na všetky kodeky.", - "LabelPreferredDisplayLanguageHelp": "Preklad Jellyfinu je v neustálom vývoji.", "LabelPostProcessorArgumentsHelp": "Použi {path} ako cestu k nahrávanému súboru.", "LabelPostProcessorArguments": "Argumenty príkazového riadku pre následné spracovanie:", "LabelPostProcessor": "Aplikácia pre následné spracovanie:", diff --git a/src/strings/sl-si.json b/src/strings/sl-si.json index f9588653ab..ca1a5d6648 100644 --- a/src/strings/sl-si.json +++ b/src/strings/sl-si.json @@ -5,7 +5,6 @@ "ButtonSignOut": "Odjava", "FolderTypeTvShows": "TV", "HeaderAddToCollection": "Dodaj v Zbirko", - "HeaderAddUser": "Dodaj Uporabnika", "HeaderEasyPinCode": "Enostavna Pin koda", "HeaderFrequentlyPlayed": "Pogosto Predvajano", "HeaderPaths": "Poti", @@ -38,7 +37,6 @@ "ParentalRating": "Ocena za starše", "Settings": "Nastavitve", "TabAccess": "Dostop", - "TabAlbumArtists": "Izvajalci Albumov", "TabCatalog": "Katalog", "TabLatest": "Zadnje", "TabMusic": "Glasba", @@ -125,30 +123,23 @@ "ButtonBack": "Nazaj", "ButtonCancel": "Prekliči", "ButtonChangeServer": "Spremeni strežnik", - "ButtonEdit": "Uredi", - "ButtonEditImages": "Uredi slike", "ButtonEditOtherUserPreferences": "Uredi profil tega uporabnika, slike in osebne nastavitve.", - "ButtonFilter": "Filter", "ButtonForgotPassword": "Pozabljeno geslo", "ButtonFullscreen": "Polni zaslon", "ButtonGotIt": "Razumem", "ButtonGuide": "Vodič", - "ButtonHome": "Domov", "ButtonInfo": "Info", "ButtonLibraryAccess": "Dostop do knjižnic", "ButtonManualLogin": "Ročna prijava", "ButtonMore": "Več", "ButtonNetwork": "Omrežje", "ButtonNextTrack": "Naslednja skladba", - "ButtonOff": "Izključi", "ButtonOk": "Ok", "ButtonOpen": "Odpri", "ButtonParentalControl": "Starševski nadzor", "ButtonPause": "Premor", - "ButtonPlay": "Predvajaj", "ButtonPreviousTrack": "Prejšnja skladba", "ButtonProfile": "Profil", - "ButtonRefresh": "Osveži", "ButtonRefreshGuideData": "Osveži TV vodič", "ButtonRemove": "Odstrani", "ButtonRename": "Preimenuj", @@ -166,7 +157,6 @@ "ButtonSignIn": "Prijava", "ButtonStart": "Začetek", "ButtonStop": "Stop", - "ButtonSubtitles": "Podnapisi", "ButtonTrailer": "Napovednik", "ButtonUninstall": "Odstrani", "ButtonWebsite": "Spletna stran", @@ -293,7 +283,6 @@ "HeaderMusicQuality": "Kvaliteta glasbe", "HeaderMoreLikeThis": "Podobno", "HeaderMetadataSettings": "Nastavitve metapodatkov", - "HeaderMediaInfo": "Informacije o predstavnosti", "HeaderMediaFolders": "Mape predstavnosti", "HeaderMedia": "Predstavnost", "HeaderLoginFailure": "Neuspešna prijava", @@ -317,9 +306,7 @@ "HeaderIdentifyItemHelp": "Vnesite vsaj en kriterij iskanja. Odstranite kriterije za več rezultatov.", "HeaderIdentificationCriteriaHelp": "Vnesite vsaj en kriterij za identifikacijo.", "HeaderIdentification": "Identifikacija", - "HeaderHome": "Domov", "HeaderGuideProviders": "Ponudniki TV vodiča", - "HeaderForgotPassword": "Pozabljeno geslo", "HeaderForKids": "Za otroke", "HeaderFetcherSettings": "Nastavitve pridobivanja", "HeaderFetchImages": "Pridobi slike:", @@ -328,7 +315,6 @@ "HeaderFavoriteBooks": "Priljubljene knjige", "HeaderExternalIds": "Zunanji ID-ji:", "HeaderError": "Napaka", - "HeaderEpisodes": "Epizode", "HeaderEnabledFieldsHelp": "Odznači polja in s tem prepreči njihovo urejanje.", "HeaderEnabledFields": "Omogočena polja", "HeaderEditImages": "Uredi slike", @@ -357,11 +343,9 @@ "HeaderCodecProfile": "Profil kodeka", "HeaderChapterImages": "Slike poglavij", "HeaderChannelAccess": "Dostop kanalov", - "HeaderCastCrew": "Igralci in ekipa", "HeaderCastAndCrew": "Igralci in ekipa", "HeaderCancelSeries": "Prekini serijo", "HeaderCancelRecording": "Prekini snemanje", - "HeaderBooks": "Knjige", "HeaderAudioSettings": "Nastavitve zvoka", "HeaderAudioBooks": "Zvočne knjige", "HeaderAppearsOn": "Pojavi se", @@ -375,7 +359,6 @@ "HeaderAdditionalParts": "Dodatni deli", "HeaderAddUpdateImage": "Dodaj/posodobi sliko", "HeaderAddToPlaylist": "Dodaj na seznam predvajanja", - "HeaderAddScheduledTaskTrigger": "Dodaj sprožilec", "HeaderActivity": "Aktivnost", "HeaderActiveRecordings": "Aktivna snemanja", "HeaderActiveDevices": "Aktivne naprave", @@ -431,9 +414,7 @@ "EndsAtValue": "Konec ob {0}", "Ended": "Končano", "EnableThemeVideosHelp": "Predvajaj tematske videe v ozadju med brskanjem knjižnice.", - "EnableThemeVideos": "Tematski videi", "EnableThemeSongsHelp": "Predvajaj tematske pesmi v ozadju med brskanjem knjižnice.", - "EnableThemeSongs": "Glavne pesmi", "EnableStreamLoopingHelp": "Omogoči za prenose v živo ki vsebujejo zgolj nekaj sekund podatkov in jih je treba neprestano znova zahtevati. Če to ni potrebno lahko omogočanje povzroči težave.", "EnablePhotosHelp": "Fotografije bodo zaznane in prikazane skupaj z drugo predstavnostjo.", "EnablePhotos": "Prikaži fotografije", @@ -516,7 +497,6 @@ "LabelAppName": "Ime aplikacije", "LabelAppNameExample": "Primer: Sickbeard, Sonarr", "LabelArtistsHelp": "Loči več izvajalcev s podpičjem.", - "LabelAudio": "Zvok", "LabelAudioBitrate": "Bitna hitrost zvoka:", "LabelAudioChannels": "Kanali zvoka:", "LabelAudioCodec": "Zvočni kodek:", @@ -547,7 +527,6 @@ "LabelCustomCertificatePathHelp": "Pot do PKCS #12 datoteke, ki vsebuje certifikat in zasebni ključ, za omogočanje TLS povezave na domenah po meri.", "LabelCustomCss": "CSS po meri:", "LabelCustomCssHelp": "Določite vaš lasten slog spletnega vmesnika.", - "LabelCustomDeviceDisplayName": "Prikazano ime:", "LabelCustomDeviceDisplayNameHelp": "Določi prikazano ime naprave. Pusti prazno za uporabo imena kot ga sporoči naprava sama.", "LabelDefaultScreen": "Privzeti zaslon:", "LabelDateAdded": "Datum dodajanja:", @@ -566,7 +545,6 @@ "LabelCollection": "Zbirka:", "LabelCustomCertificatePath": "Lokacija SSL certifikata po meri:", "LabelDidlMode": "DIDL način:", - "LabelDisplayMissingEpisodesWithinSeasons": "Prikaži manjkajoče epizode znotraj sezon", "LabelDay": "Dan:", "LabelDeathDate": "Datum smrti:", "LabelBitrate": "Bitna hitrost:", @@ -848,7 +826,6 @@ "LabelProtocol": "Protokol:", "LabelProfileVideoCodecs": "Video kodeki:", "LabelProfileCodecsHelp": "Ločeno z vejico. Če pustite prazno, velja za vse kodeke.", - "LabelPreferredDisplayLanguageHelp": "Prevajanje Jellyfin je projekt v teku.", "LabelPleaseRestart": "Spremembe bodo začele veljati po ročni osvežitvi spletnega vmesnika.", "LabelPlaylist": "Seznam predvajanja:", "LabelPlaceOfBirth": "Kraj rojstva:", @@ -884,7 +861,6 @@ "OptionArtist": "Izvajalec", "OptionAllowUserToManageServer": "Dovoli temu uporabniku upravljanje strežnika", "MessageTheFollowingLocationWillBeRemovedFromLibrary": "Naslednja mesta predstavnosti bodo odstranjena iz vaše knjižnice:", - "MessageSettingsSaved": "Nastavitve so bile shranjene.", "MessagePluginInstallDisclaimer": "Dodatki ustvarjeni s strani članov Jellyfin skupnosti so odličen način za izboljšanje vaše izkušnje z Jellyfin z dodatnimi funkcijami in prednostmi. Preden namestite dodatke se zavedajte, da imajo lahko ti različne vplive na vaš Jellyfin strežnik, kot na primer počasnejše preiskovanje knjižnic, dodatna obdelava podatkov v ozadju in zmanjšana stabilnost sistema.", "MessagePleaseWait": "Prosimo, počakajte. To lahko traja nekaj minut.", "MessagePleaseEnsureInternetMetadata": "Prosimo poskrbite, da je prenašanje spletnih metapodatkov omogočeno.", @@ -1067,21 +1043,17 @@ "LabelSource": "Vir:", "LabelSkipIfGraphicalSubsPresentHelp": "Ohranjanje besedilnih različic podnapisov omogoča učinkovitejše predvajanje in zmanjša potrebo po prekodiranju.", "LabelTriggerType": "Tip sprožilca:", - "LabelTranscodingVideoCodec": "Video kodek:", "LabelTranscodingProgress": "Napredek prekodiranja:", "LabelTranscodingFramerate": "Hitrost prekodiranja:", "LabelTranscodes": "Prekodiranje:", "LabelTranscodingTempPathHelp": "Določite pot po meri za datoteke prekodiranja. Pustite prazno za uporabo privzete lokacije.", "LabelTranscodePath": "Pot prekodiranja:", - "LabelTranscodingContainer": "Kontejner:", - "LabelTranscodingAudioCodec": "Zvočni kodek:", "LabelTrackNumber": "Številka skladbe:", "LabelTime": "Čas:", "LabelTextColor": "Barva besedila:", "LabelTextBackgroundColor": "Barva ozadja besedila:", "LabelTag": "Oznaka:", "LabelSupportedMediaTypes": "Podprti tipi predstavnosti:", - "LabelSubtitles": "Podnapisi", "LabelSubtitlePlaybackMode": "Način podnapisov:", "LabelSubtitleFormatHelp": "Primer: srt", "LabelSubtitleDownloaders": "Pridobivanje podnapisov:", @@ -1112,7 +1084,6 @@ "Trailers": "Napovedniki", "TitleHardwareAcceleration": "Strojno pospeševanje", "Thursday": "Četrtek", - "TabTrailers": "Napovedniki", "ClientSettings": "Nastavitve odjemalca", "ButtonTogglePlaylist": "Seznam predvajanja", "Artist": "Izvajalec", @@ -1260,7 +1231,6 @@ "OptionDownloadBoxImage": "Ovitek", "OptionDownloadBannerImage": "Pasica", "OptionDownloadBackImage": "Nazaj", - "OptionAutomatic": "Samodejno", "OptionAuto": "Samodejno", "NextUp": "Sledi", "Next": "Naslednji", @@ -1286,8 +1256,6 @@ "LabelWeb": "Splet:", "LabelLineup": "Postava:", "BoxSet": "Komplet", - "TabInfo": "Informacije", - "TabEpisodes": "Epizode", "TabDirectPlay": "Neposredno predvajanje", "TabCodecs": "Kodeki", "OptionRegex": "Regex", @@ -1298,7 +1266,6 @@ "TabSettings": "Nastavitve", "TabServer": "Strežnik", "TabScheduledTasks": "Načrtovana opravila", - "TabResumeSettings": "Nadaljuj", "HeaderUninstallPlugin": "Odstrani dodatek", "UninstallPluginConfirmation": "Ali ste prepričan, da želite odstraniti {0}?", "ServerRestartNeededAfterPluginInstall": "Po namestitvi dodatka bo potreben ponoven zagon jellyfin strežnika.", @@ -1307,7 +1274,6 @@ "TabOther": "Ostalo", "TabNotifications": "Obvestila", "TabNfoSettings": "Nastavitve NFO", - "TabMusicVideos": "Videospoti", "OptionForceRemoteSourceTranscoding": "Vsili prekodiranje oddaljenih virov predstavnosti (na primer TV v živo)", "Off": "Izključeno", "Normal": "Normalno", diff --git a/src/strings/sr.json b/src/strings/sr.json index 22e2343e5e..90cbd0d9df 100644 --- a/src/strings/sr.json +++ b/src/strings/sr.json @@ -32,19 +32,16 @@ "ButtonParentalControl": "Родитељска контрола", "ButtonOpen": "Отвори", "ButtonOk": "Ок", - "ButtonOff": "Искључи", "ButtonNextTrack": "Следећа нумера", "ButtonNetwork": "Мрежа", "ButtonMore": "Више", "ButtonManualLogin": "Ручни логин", "ButtonLibraryAccess": "Приступ библиотеци", "ButtonInfo": "Информације", - "ButtonHome": "Почетна страна", "ButtonGuide": "Водич", "ButtonGotIt": "У реду", "ButtonFullscreen": "Пун екран", "ButtonForgotPassword": "Заборављена шифра", - "ButtonFilter": "Филтер", "ButtonChangeServer": "Промени Сервер", "ButtonCancel": "Откажи", "ButtonBack": "Назад", @@ -115,7 +112,6 @@ "ButtonWebsite": "Веб сајт", "ButtonUninstall": "Деинсталирај", "ButtonTrailer": "Трејлер", - "ButtonSubtitles": "Титлови", "ButtonSubmit": "Пошаљите", "ButtonSplit": "Подели", "ButtonStop": "Заустави", @@ -137,14 +133,10 @@ "ButtonRename": "Преименуј", "ButtonRemove": "Уклони", "ButtonRefreshGuideData": "Освежи податке водича", - "ButtonRefresh": "Освежи", "ButtonQuickStartGuide": "Кратки водич за почетак", "ButtonProfile": "Профил", "ButtonPreviousTrack": "Претходна нумера", - "ButtonPlay": "Пусти", "ButtonEditOtherUserPreferences": "Уредите профил корисника, слику и личне поставке.", - "ButtonEditImages": "Уреди слике", - "ButtonEdit": "Уреди", "BurnSubtitlesHelp": "Одређује да ли сервер треба да кодира титлове приликом транскодирања видео записа. Избегавање тога увелико ће побољшати перформансе. Изаберите Аутоматски да бисте снимили формате засноване на слици (VOBSUB, PGS, SUB, IDX) и одређене ASS или SSA титлове.", "BoxSet": "Бокс сет", "BookLibraryHelp": "Подржани су аудио и текстуалне књиге. Прегледајте {0} водич за именовање књига {1}.", diff --git a/src/strings/sv.json b/src/strings/sv.json index 50ad99be59..c5f82a59d7 100644 --- a/src/strings/sv.json +++ b/src/strings/sv.json @@ -54,29 +54,22 @@ "ButtonBack": "Föregående", "ButtonCancel": "Avbryt", "ButtonChangeServer": "Byt server", - "ButtonEdit": "Ändra", - "ButtonEditImages": "Ändra bilder", "ButtonEditOtherUserPreferences": "Ändra den här användarens profil, bild och personliga inställningar.", - "ButtonFilter": "Filtrera", "ButtonForgotPassword": "Glömt Lösenord", "ButtonFullscreen": "Fullskärm", "ButtonGotIt": "Ok", - "ButtonHome": "Hem", "ButtonLibraryAccess": "Biblioteksåtkomst", "ButtonManualLogin": "Manuell inloggning", "ButtonMore": "Mer", "ButtonNetwork": "Nätverk", "ButtonNextTrack": "Nästa spår", - "ButtonOff": "Av", "ButtonOk": "OK", "ButtonOpen": "Öppna", "ButtonParentalControl": "Föräldralås", "ButtonPause": "Paus", - "ButtonPlay": "Spela upp", "ButtonPreviousTrack": "Föregående spår", "ButtonProfile": "Profil", "ButtonQuickStartGuide": "Snabbstartguide", - "ButtonRefresh": "Uppdatera", "ButtonRefreshGuideData": "Uppdatera programguiden", "ButtonRemove": "Ta bort", "ButtonRename": "Ändra namn", @@ -96,7 +89,6 @@ "ButtonSignOut": "Logga ut", "ButtonStop": "Stopp", "ButtonSubmit": "Bekräfta", - "ButtonSubtitles": "Undertexter", "ButtonUninstall": "Avinstallera", "ButtonWebsite": "Hemsida", "CancelRecording": "Avbryt inspelning", @@ -175,9 +167,7 @@ "EnableNextVideoInfoOverlayHelp": "Vid slutet av en video, visa information om nästföljande video i spellistan.", "EnablePhotos": "Visa foton", "EnablePhotosHelp": "Bilder kommer upptäckas och visas tillsammans med andra mediefiler.", - "EnableThemeSongs": "Signaturmelodi", "EnableThemeSongsHelp": "Spela ledmotiv i bakgrunden vid bläddring i biblioteket.", - "EnableThemeVideos": "Tema-videor", "EnableThemeVideosHelp": "Spela tema-videos i bakgrunden vid bläddring i biblioteket.", "Ended": "Avslutad", "EndsAtValue": "Slutar vid: {0}", @@ -226,11 +216,9 @@ "HeaderActiveDevices": "Aktiva enheter", "HeaderActiveRecordings": "Pågående inspelningar", "HeaderActivity": "Aktivitet", - "HeaderAddScheduledTaskTrigger": "Lägg till utlösare", "HeaderAddToCollection": "Lägg till samling", "HeaderAddToPlaylist": "Lägg till i Spellista", "HeaderAddUpdateImage": "Lägg till/uppdatera bild", - "HeaderAddUser": "Lägg till användare", "HeaderAdditionalParts": "Ytterligare delar", "HeaderAlbumArtists": "Albumartister", "HeaderAlert": "Varning", @@ -241,11 +229,9 @@ "HeaderAudioBooks": "Ljudböcker", "HeaderAudioSettings": "Ljudinställningar", "HeaderBlockItemsWithNoRating": "Blockera innehåll med ingen eller okänd åldersgräns:", - "HeaderBooks": "Böcker", "HeaderCancelRecording": "Avbryt inspelning", "HeaderCancelSeries": "Avbryt serie", "HeaderCastAndCrew": "Medverkande", - "HeaderCastCrew": "Rollista & besättning", "HeaderChannelAccess": "Kanalåtkomst", "HeaderChapterImages": "Kapitelbilder", "HeaderCodecProfile": "Profil för videokodning", @@ -279,13 +265,11 @@ "HeaderEditImages": "Redigera bilder", "HeaderEnabledFields": "Aktiverade fält", "HeaderEnabledFieldsHelp": "Bocka ur ett fält för att låsa det och undvik att dess data ändras.", - "HeaderEpisodes": "Avsnitt", "HeaderError": "Fel", "HeaderExternalIds": "Externa ID:", "HeaderFeatureAccess": "Tillgång till funktioner", "HeaderFetchImages": "Hämta bilder:", "HeaderForKids": "För barn", - "HeaderForgotPassword": "Glömt Lösenord", "HeaderFrequentlyPlayed": "Ofta spelade", "HeaderGuideProviders": "Källor för programguide", "HeaderHttpHeaders": "HTTP headers", @@ -311,7 +295,6 @@ "HeaderLibrarySettings": "Biblioteksinställningar", "HeaderLoginFailure": "Misslyckad inloggning", "HeaderMediaFolders": "Mediamappar", - "HeaderMediaInfo": "Medieinformation", "HeaderMetadataSettings": "Metadatainställningar", "HeaderMoreLikeThis": "Mer som denna", "HeaderMusicQuality": "Musikkvalitet", @@ -435,7 +418,6 @@ "LabelAppNameExample": "Exempel: Sickbeard, Sonarr", "LabelArtists": "Artister:", "LabelArtistsHelp": "Separera med vid flera ;", - "LabelAudio": "Ljud", "LabelAudioLanguagePreference": "Önskat ljudspråk:", "LabelAutomaticallyRefreshInternetMetadataEvery": "Uppdatera metadata automatiskt ifrån internet:", "LabelBindToLocalNetworkAddress": "Knyt till lokal nätverksadress:", @@ -462,7 +444,6 @@ "LabelCustomCertificatePathHelp": "Lägg upp ditt eget SSL-certifkat i .pfx-format.", "LabelCustomCss": "Egen CSS-stil:", "LabelCustomCssHelp": "Använd din egen CSS-stil för webbgränssnittet.", - "LabelCustomDeviceDisplayName": "Visningsnamn:", "LabelCustomDeviceDisplayNameHelp": "Ange ett anpassat enhetsnamn. Lämna blankt för att använda det namn enheten själv rapporterar.", "LabelCustomRating": "Anpassad åldersgräns:", "LabelDateAdded": "Inlagd den:", @@ -479,7 +460,6 @@ "LabelDiscNumber": "Skivnummer:", "LabelDisplayLanguage": "Visningsspråk:", "LabelDisplayLanguageHelp": "Att översätta Jellyfin är ett pågående projekt.", - "LabelDisplayMissingEpisodesWithinSeasons": "Visa saknade avsnitt i säsonger", "LabelDisplayMode": "Visningsläge:", "LabelDisplayName": "Visningsnamn:", "LabelDisplayOrder": "Visningsordning:", @@ -630,7 +610,6 @@ "LabelPlayDefaultAudioTrack": "Använd det förvalda ljudspåret oavsett språk", "LabelPlaylist": "Spellista:", "LabelPreferredDisplayLanguage": "Föredraget visningsspråk:", - "LabelPreferredDisplayLanguageHelp": "Att översätta Jellyfin är ett pågående projekt.", "LabelPreferredSubtitleLanguage": "Önskat språk för undertexter:", "LabelProfileAudioCodecs": "Kodning av ljud:", "LabelProfileCodecs": "Videokodningar:", @@ -689,7 +668,6 @@ "LabelSubtitleDownloaders": "Undertextskällor:", "LabelSubtitleFormatHelp": "Exempel: srt", "LabelSubtitlePlaybackMode": "Undertextläge:", - "LabelSubtitles": "Undertexter", "LabelSupportedMediaTypes": "Mediaformat som stöds:", "LabelTVHomeScreen": "Hemskärm i TV-läge:", "LabelTag": "Etikett:", @@ -702,12 +680,9 @@ "LabelTimeLimitHours": "Tidsbegränsning (timmar):", "LabelTitle": "Titel:", "LabelTrackNumber": "Spår nr:", - "LabelTranscodingAudioCodec": "Ljudkodning:", - "LabelTranscodingContainer": "Behållare:", "LabelTranscodingTempPathHelp": "Ange en egen sökväg där omkodningar skall sparas för klienter. Lämna blankt för att använda förvald plats.", "LabelTranscodingThreadCount": "Trådar för omkodning:", "LabelTranscodingThreadCountHelp": "Välj maximala antalet trådar som ska användas vid omkodning. Att minska antalet trådar sänker cpu-belastningan men ökar även risken att omkodning inte kan ske snabbt nog för felfri uppspelning.", - "LabelTranscodingVideoCodec": "Videokodning:", "LabelTriggerType": "Typ av utlösare:", "LabelTunerIpAddress": "IP-adress till TV-mottagare:", "LabelTunerType": "Typ av TV-mottagare:", @@ -805,7 +780,6 @@ "MessagePluginConfigurationRequiresLocalAccess": "Logga in på din din lokala Jellyfin Server för att konfigurera det här tillägget.", "MessagePluginInstallDisclaimer": "Tillägg skapade av Jellyfin-användare är ett bra sätt att förbättra din Jellyfin-upplevelse med ytterligare funktionalitet. Observera att detta kan påverka din Jellyfin-server så som längre tidsåtgång för biblioteksskanningar, ytterligare bakgrundsprocesser och minskad systemstabilitet.", "MessageReenableUser": "Se nedan för att aktivera igen", - "MessageSettingsSaved": "Inställningarna har sparats.", "MessageTheFollowingLocationWillBeRemovedFromLibrary": "Följande mediaplatser kommer att tas bort från ditt bibliotek:", "MessageUnableToConnectToServer": "Vi kunde inte upprätta anslutning till vald server just nu. Försäkra dig om att den är påslagen och försök igen.", "MessageUnsetContentHelp": "Innehåll kommer visas som enkla mappar. För bästa resultat, använd en metadata-hanterare för att ställa in typ av innehåll för undermapparna.", @@ -1089,17 +1063,14 @@ "Sync": "Synk", "SystemDlnaProfilesHelp": "Systemprofiler är skrivskyddade. Ändringar av en systemprofil resulterar att en ny anpassad profil skapas.", "TabAdvanced": "Avancerat", - "TabAlbumArtists": "Albumartister", "TabCatalog": "Katalog", "TabCodecs": "Kodningsformat", "TabContainers": "Behållare", "TabDashboard": "Kontrollpanel", "TabDirectPlay": "Direktuppspelning", - "TabEpisodes": "Avsnitt", "TabLatest": "Nytillkommet", "TabLogs": "Loggfiler", "TabMusic": "Musik", - "TabMusicVideos": "Musikvideor", "TabMyPlugins": "Mina tillägg", "TabNetworks": "TV-bolag", "TabNfoSettings": "NFO-inställingar", @@ -1110,7 +1081,6 @@ "TabProfile": "Profil", "TabProfiles": "Profiler", "TabResponses": "Svar", - "TabResumeSettings": "Återuppta", "TabScheduledTasks": "Schemalagda aktiviteter", "TabSettings": "Inställningar", "TabStreaming": "Strömning", @@ -1208,7 +1178,6 @@ "AllowMediaConversion": "Tillåt media konvertering", "Alerts": "Alarm", "HeaderMedia": "Media", - "HeaderHome": "Hem", "HeaderFavoriteVideos": "Favoritvideor", "HeaderFavoriteSongs": "Favoritlåtar", "HeaderFavoriteArtists": "Favoritartister", @@ -1273,10 +1242,8 @@ "UserAgentHelp": "Stöd en egen user-agent HTTP rubrik.", "Uniform": "Enhetlig", "Trailers": "Trailers", - "TabTrailers": "Trailers", "TabServer": "Server", "TabNetworking": "Nätverk", - "TabInfo": "Info", "TabAccess": "Tillgång", "TV": "TV", "SubtitleOffset": "Undertext justering", @@ -1310,7 +1277,6 @@ "OptionCaptionInfoExSamsung": "CaptionInfoEx (Samsung)", "OptionBlockTrailers": "Trailers", "OptionBanner": "Banner", - "OptionAutomatic": "Auto", "OptionAuto": "Auto", "OptionArtist": "Artist", "OptionForceRemoteSourceTranscoding": "Tvinga omkodning på fjärr media källor (som LiveTV)", diff --git a/src/strings/ta.json b/src/strings/ta.json index d31fb8872e..585882d415 100644 --- a/src/strings/ta.json +++ b/src/strings/ta.json @@ -95,10 +95,7 @@ "ButtonGotIt": "அறிந்துகொண்டேன்", "ButtonFullscreen": "முழு திரை", "ButtonForgotPassword": "கடவுச்சொல்லை மறந்துவிட்டீர்களா", - "ButtonFilter": "வடிகட்டு", "ButtonEditOtherUserPreferences": "இந்த பயனரின் சுயவிவரம், படம் மற்றும் தனிப்பட்ட விருப்பங்களைத் திருத்தவும்.", - "ButtonEditImages": "படங்களைத் திருத்து", - "ButtonEdit": "தொகு", "ButtonDownload": "பதிவிறக்க", "ButtonDown": "கீழே", "ButtonDeleteImage": "படத்தை நீக்கு", @@ -112,7 +109,6 @@ "ButtonUninstall": "நிறுவல் நீக்கு", "ButtonTrailer": "டிரெய்லர்", "ButtonTogglePlaylist": "பிளேலிஸ்ட்", - "ButtonSubtitles": "வசன வரிகள்", "ButtonSubmit": "சமர்ப்பிக்கவும்", "ButtonSplit": "பிரிக்கவும்", "ButtonStop": "நிறுத்து", @@ -136,16 +132,13 @@ "ButtonRename": "மறுபெயரிடு", "ButtonRemove": "அகற்று", "ButtonRefreshGuideData": "வழிகாட்டி தரவைப் புதுப்பிக்கவும்", - "ButtonRefresh": "புதுப்பிப்பு", "ButtonQuickStartGuide": "விரைவு தொடக்க வழிகாட்டி", "ButtonProfile": "சுயவிவரம்", "ButtonPreviousTrack": "முந்தைய பாடல்", - "ButtonPlay": "வாசிக்கவும்", "ButtonPause": "இடைநிறுத்தம்", "ButtonParentalControl": "பெற்றோர் கட்டுப்பாடு", "ButtonOpen": "திற", "ButtonOk": "சரி", - "ButtonOff": "முடக்கு", "ButtonNextTrack": "அடுத்த பாடல்", "ButtonNew": "புதியது", "ButtonNetwork": "வலைப்பின்னல்", @@ -153,7 +146,6 @@ "ButtonManualLogin": "கைமுறை புகுபதிகை", "ButtonLibraryAccess": "நூலக அனுமதி", "ButtonInfo": "தகவல்", - "ButtonHome": "முகப்பு", "ButtonGuide": "வழிகாட்டி", "Categories": "பிரிவுகள்", "CancelSeries": "தொடரை ரத்துசெய்", @@ -171,9 +163,7 @@ "EnableDetailsBannerHelp": "உருப்படி விவரங்கள் பக்கத்தின் மேலே ஒரு பேனர் படத்தைக் காண்பி.", "EnableDetailsBanner": "விவரங்கள் பேனர்", "EnableThemeVideosHelp": "நூலகத்தில் உலாவும்போது பின்னணியில் தீம் வீடியோக்களை இயக்குங்கள்.", - "EnableThemeVideos": "தீம் வீடியோக்கள்", "EnableThemeSongsHelp": "நூலகத்தில் உலாவும்போது பின்னணியில் தீம் பாடல்களை இயக்குங்கள்.", - "EnableThemeSongs": "தீம் பாடல்கள்", "EnableStreamLoopingHelp": "நேரடி ஸ்ட்ரீம்களில் சில வினாடிகள் மட்டுமே தரவு இருந்தால் தொடர்ந்து இயக்கப்பட வேண்டும். தேவைப்படாதபோது இதை இயக்குவது சிக்கல்களை ஏற்படுத்தக்கூடும்.", "EnableStreamLooping": "ஆட்டோ-லூப் லைவ் ஸ்ட்ரீம்கள்", "EnablePhotosHelp": "பிற ஊடக கோப்புகளுடன் படங்கள் கண்டறியப்பட்டு காண்பிக்கப்படும்.", @@ -271,12 +261,10 @@ "HeaderCodecProfile": "கோடெக் சுயவிவரம்", "HeaderChapterImages": "பாடம் படங்கள்", "HeaderChannelAccess": "சேனல் அணுகல்", - "HeaderCastCrew": "நடிகர்கள் & குழு", "HeaderCastAndCrew": "நடிகர்கள் & குழு", "HeaderCancelSeries": "தொடரை ரத்துசெய்", "HeaderCancelRecording": "பதிவை ரத்துசெய்", "HeaderBranding": "பிராண்டிங்", - "HeaderBooks": "புத்தகங்கள்", "HeaderBlockItemsWithNoRating": "இல்லை அல்லது அங்கீகரிக்கப்படாத மதிப்பீட்டு தகவல் இல்லாத உருப்படிகளைத் தடு:", "HeaderAudioSettings": "ஆடியோ அமைப்புகள்", "HeaderAudioBooks": "ஆடியோ புத்தகங்கள்", @@ -290,11 +278,9 @@ "HeaderAlert": "எச்சரிக்கை", "HeaderAdmin": "நிர்வாகம்", "HeaderAdditionalParts": "கூடுதல் பாகங்கள்", - "HeaderAddUser": "பயனரைச் சேர்க்கவும்", "HeaderAddUpdateImage": "படத்தைச் சேர்க்கவும் / புதுப்பிக்கவும்", "HeaderAddToPlaylist": "பட்டியலில் சேர்", "HeaderAddToCollection": "சேகரிப்பில் சேர்", - "HeaderAddScheduledTaskTrigger": "தூண்டுதலைச் சேர்க்கவும்", "HeaderActivity": "செயல்பாடு", "HeaderActiveRecordings": "செயலில் பதிவுகள்", "HeaderActiveDevices": "செயலில் உள்ள சாதனங்கள்", @@ -343,7 +329,6 @@ "HeaderFavoriteBooks": "பிடித்த புத்தகங்கள்", "HeaderExternalIds": "வெளி ஐடிகள்:", "HeaderError": "பிழை", - "HeaderEpisodes": "அத்தியாயங்கள்", "HeaderEnabledFieldsHelp": "ஒரு புலத்தை பூட்டவும், அதன் தரவு மாற்றப்படுவதைத் தடுக்கவும் தேர்வுநீக்கு.", "HeaderEnabledFields": "இயக்கப்பட்ட புலங்கள்", "HeaderEditImages": "படங்களைத் திருத்து", @@ -433,7 +418,6 @@ "HeaderMusicQuality": "இசை தரம்", "HeaderMoreLikeThis": "இது போன்றது", "HeaderMetadataSettings": "மெட்டாடேட்டா அமைப்புகள்", - "HeaderMediaInfo": "மீடியா தகவல்", "HeaderMediaFolders": "மீடியா கோப்புறைகள்", "HeaderMedia": "மீடியா", "HeaderLoginFailure": "உள்நுழைவு தோல்வி", @@ -461,10 +445,8 @@ "HeaderIdentification": "அடையாளம்", "HeaderHttpsSettings": "HTTPS அமைப்புகள்", "HeaderHttpHeaders": "HTTP தலைப்புகள்", - "HeaderHome": "முகப்பு", "HeaderGuideProviders": "டிவி வழிகாட்டி தரவு வழங்குநர்கள்", "HeaderFrequentlyPlayed": "அடிக்கடி இசைக்கும்", - "HeaderForgotPassword": "கடவுச்சொல்லை மறந்துவிட்டீர்களா", "HeaderForKids": "குழந்தைகளுக்காக", "HeaderFetcherSettings": "பெறுதல் அமைப்புகள்", "HeaderFetchImages": "படங்களை பெறுங்கள்:", @@ -539,7 +521,6 @@ "LabelAudioChannels": "ஆடியோ சேனல்கள்:", "LabelAudioBitrate": "ஆடியோ பிட்ரேட்:", "LabelAudioBitDepth": "ஆடியோ பிட் ஆழம்:", - "LabelAudio": "ஆடியோ", "LabelArtistsHelp": "அரைக்காற்புள்ளியுடன் பல கலைஞர்களைப் பிரிக்கவும்.", "LabelArtists": "கலைஞர்கள்:", "LabelAppNameExample": "எடுத்துக்காட்டு: Sickbeard, Sonarr", @@ -573,7 +554,6 @@ "LabelDisplayOrder": "காட்சி வரிசை:", "LabelDisplayName": "காட்சி பெயர்:", "LabelDisplayMode": "காட்சி முறை:", - "LabelDisplayMissingEpisodesWithinSeasons": "காணாமல் போன அத்தியாயங்களை பருவங்களுக்குள் காண்பி", "LabelDisplayLanguageHelp": "ஜெல்லிஃபின் மொழிபெயர்ப்பது ஒரு தொடர்ச்சியான திட்டம்.", "LabelDisplayLanguage": "காட்சி மொழி:", "LabelDiscNumber": "வட்டு எண்:", @@ -591,7 +571,6 @@ "LabelDateAdded": "சேர்க்கப்பட்ட தேதி:", "LabelCustomRating": "தனிப்பயன் மதிப்பீடு:", "LabelCustomDeviceDisplayNameHelp": "தனிப்பயன் காட்சி பெயரை வழங்கவும் அல்லது சாதனத்தால் புகாரளிக்கப்பட்ட பெயரைப் பயன்படுத்த காலியாக விடவும்.", - "LabelCustomDeviceDisplayName": "காட்சி பெயர்:", "LabelCustomCssHelp": "வலை இடைமுகத்தில் உங்கள் சொந்த தனிப்பயன் பாணிகளைப் பயன்படுத்துங்கள்.", "LabelCustomCss": "தனிப்பயன் CSS:", "LabelCustomCertificatePathHelp": "தனிப்பயன் களத்தில் TLS ஆதரவை இயக்க சான்றிதழ் மற்றும் தனிப்பட்ட விசையைக் கொண்ட PKCS # 12 கோப்பிற்கான பாதை.", @@ -816,7 +795,6 @@ "LabelTunerType": "ட்யூனர் வகை:", "LabelTunerIpAddress": "ட்யூனர் ஐபி முகவரி:", "LabelTriggerType": "தூண்டுதல் வகை:", - "LabelTranscodingVideoCodec": "வீடியோ கோடெக்:", "LabelTranscodingThreadCountHelp": "டிரான்ஸ்கோடிங் செய்யும்போது பயன்படுத்த வேண்டிய அதிகபட்ச நூல்களைத் தேர்ந்தெடுக்கவும். நூல் எண்ணிக்கையைக் குறைப்பது CPU பயன்பாட்டைக் குறைக்கும், ஆனால் மென்மையான பின்னணி அனுபவத்திற்கு போதுமானதாக மாற்றாது.", "LabelTranscodingThreadCount": "டிரான்ஸ்கோடிங் நூல் எண்ணிக்கை:", "LabelTranscodingProgress": "டிரான்ஸ்கோடிங் முன்னேற்றம்:", @@ -824,8 +802,6 @@ "LabelTranscodes": "டிரான்ஸ்கோட்கள்:", "LabelTranscodingTempPathHelp": "வாடிக்கையாளர்களுக்கு வழங்கப்பட்ட டிரான்ஸ்கோட் கோப்புகளுக்கான தனிப்பயன் பாதையை குறிப்பிடவும். சேவையக இயல்புநிலையைப் பயன்படுத்த காலியாக விடவும்.", "LabelTranscodePath": "டிரான்ஸ்கோட் பாதை:", - "LabelTranscodingContainer": "கொள்கலன்:", - "LabelTranscodingAudioCodec": "ஆடியோ கோடெக்:", "LabelTrackNumber": "ட்ராக் எண்:", "LabelTitle": "தலைப்பு:", "LabelTimeLimitHours": "கால எல்லை (மணிநேரம்):", @@ -850,7 +826,6 @@ "MillisecondsUnit": "ms", "LabelSyncPlayTimeOffset": "சேவையகத்துடன் நேரம் ஈடுசெய்யப்பட்டது:", "LabelSupportedMediaTypes": "ஆதரிக்கப்படும் ஊடக வகைகள்:", - "LabelSubtitles": "வசன வரிகள்", "LabelSubtitlePlaybackMode": "வசன முறை:", "LabelSubtitleFormatHelp": "எடுத்துக்காட்டு: srt", "LabelSubtitleDownloaders": "வசன பதிவிறக்கிகள்:", @@ -917,7 +892,6 @@ "LabelProfileCodecs": "கோடெக்குகள்:", "LabelProfileAudioCodecs": "ஆடியோ கோடெக்குகள்:", "LabelPreferredSubtitleLanguage": "விருப்பமான வசன மொழி:", - "LabelPreferredDisplayLanguageHelp": "ஜெல்லிஃபின் மொழிபெயர்ப்பது ஒரு தொடர்ச்சியான திட்டம்.", "LabelPreferredDisplayLanguage": "விருப்பமான காட்சி மொழி:", "LabelPostProcessorArgumentsHelp": "பதிவு கோப்புக்கான பாதையாக {path} ஐப் பயன்படுத்தவும்.", "LabelPostProcessorArguments": "பிந்தைய செயலி கட்டளை வரி வாதங்கள்:", @@ -953,7 +927,6 @@ "MessageUnsetContentHelp": "உள்ளடக்கம் எளிய கோப்புறைகளாக காண்பிக்கப்படும். சிறந்த முடிவுகளுக்கு துணை கோப்புறைகளின் உள்ளடக்க வகைகளை அமைக்க மெட்டாடேட்டா நிர்வாகியைப் பயன்படுத்தவும்.", "MessageUnableToConnectToServer": "தேர்ந்தெடுக்கப்பட்ட சேவையகத்துடன் இப்போது எங்களால் இணைக்க முடியவில்லை. இது இயங்குவதை உறுதிசெய்து மீண்டும் முயற்சிக்கவும்.", "MessageTheFollowingLocationWillBeRemovedFromLibrary": "உங்கள் நூலகத்திலிருந்து பின்வரும் ஊடக இருப்பிடங்கள் அகற்றப்படும்:", - "MessageSettingsSaved": "அமைப்புகள் சேமிக்கப்பட்டன.", "MessageReenableUser": "மீண்டும் இயக்க கீழே காண்க", "MessagePluginInstallDisclaimer": "கூடுதல் அம்சங்கள் மற்றும் நன்மைகளுடன் உங்கள் அனுபவத்தை மேம்படுத்த சமூக உறுப்பினர்களால் உருவாக்கப்பட்ட செருகுநிரல்கள் சிறந்த வழியாகும். நிறுவுவதற்கு முன், உங்கள் சேவையகத்தில் அவை நீண்ட நூலக ஸ்கேன், கூடுதல் பின்னணி செயலாக்கம் மற்றும் கணினி நிலைத்தன்மை குறைதல் போன்ற விளைவுகளைப் பற்றி எச்சரிக்கையாக இருங்கள்.", "MessagePluginConfigurationRequiresLocalAccess": "இந்த சொருகி கட்டமைக்க உங்கள் உள்ளூர் சேவையகத்தில் நேரடியாக உள்நுழைக.", @@ -1091,7 +1064,6 @@ "OptionBanner": "பதாகை", "OptionAutomaticallyGroupSeriesHelp": "இந்த நூலகத்திற்குள் பல கோப்புறைகளில் பரவியிருக்கும் தொடர்கள் தானாக ஒரு தொடராக ஒன்றிணைக்கப்படும்.", "OptionAutomaticallyGroupSeries": "பல கோப்புறைகளில் பரவியிருக்கும் தொடர்களை தானாக இணைக்கவும்", - "OptionAutomatic": "தானாக", "OptionAuto": "தானாக", "OptionAscending": "ஏறுதல்", "OptionArtist": "கலைஞர்", @@ -1425,12 +1397,10 @@ "TagsValue": "குறிச்சொற்கள்: {0}", "Tags": "குறிச்சொற்கள்", "TabUpcoming": "வரவிருக்கும்", - "TabTrailers": "டிரெய்லர்கள்", "TabStreaming": "ஸ்ட்ரீமிங்", "TabSettings": "அமைப்புகள்", "TabServer": "சேவையகம்", "TabScheduledTasks": "திட்டமிடப்பட்ட பணிகள்", - "TabResumeSettings": "மீண்டும் தொடர்", "TabResponses": "பதில்கள்", "TabProfiles": "சுயவிவரங்கள்", "TabProfile": "சுயவிவரம்", @@ -1442,19 +1412,15 @@ "TabNetworking": "நெட்வொர்க்கிங்", "TabNetworks": "நெட்வொர்க்குகள்", "TabMyPlugins": "எனது செருகுநிரல்கள்", - "TabMusicVideos": "இசை கானொளி", "TabMusic": "இசை", "TabLogs": "பதிவுகள்", "TabLatest": "அண்மை", - "TabInfo": "தகவல்", - "TabEpisodes": "அத்தியாயங்கள்", "TabDirectPlay": "நேரடி நாடகம்", "TabDashboard": "டாஷ்போர்டு", "TabContainers": "கொள்கலன்கள்", "TabCodecs": "கோடெக்குகள்", "TabRepositories": "களஞ்சியங்கள்", "TabCatalog": "அட்டவணை", - "TabAlbumArtists": "ஆல்பம் கலைஞர்கள்", "TabAdvanced": "மேம்படுத்தபட்ட", "TabAccess": "அணுகல்", "TV": "தொலைக்காட்சி", diff --git a/src/strings/tr.json b/src/strings/tr.json index 2bae4757f4..053da36a5e 100644 --- a/src/strings/tr.json +++ b/src/strings/tr.json @@ -9,14 +9,10 @@ "ButtonArrowRight": "Sağ", "ButtonBack": "Geri", "ButtonCancel": "İptal", - "ButtonEdit": "Düzenle", - "ButtonFilter": "Filtrele", - "ButtonHome": "Anasayfa", "ButtonInfo": "Bilgi", "ButtonManualLogin": "Manuel Giriş", "ButtonOk": "Tamam", "ButtonPause": "Duraklat", - "ButtonPlay": "Oynat", "ButtonQuickStartGuide": "Hızlı başlangıç rehberi", "ButtonRefreshGuideData": "Kılavuzu Yinele", "ButtonRemove": "Sil", @@ -28,7 +24,6 @@ "ButtonSignIn": "Giriş Yapın", "ButtonSignOut": "Çıkış Yap", "ButtonStop": "Durdur", - "ButtonSubtitles": "Altyazılar", "ChannelAccessHelp": "Bu kullanıcıyla paylaşmak üzere kanalları seç. Yöneticiler bütün kanalları metada yöneticisi ile düzenleyebilecekler.", "Continuing": "Devam ediyor", "Delete": "Sil", @@ -48,7 +43,6 @@ "FolderTypeTvShows": "TV", "Friday": "Cuma", "HeaderActiveRecordings": "Aktif Kayıtlar", - "HeaderAddUser": "Kullanıcı Ekle", "HeaderCodecProfile": "Codec Profili", "HeaderContinueWatching": "İzlemeye Devam Et", "HeaderCustomDlnaProfiles": "Özel Profiller", @@ -86,7 +80,6 @@ "LabelCountry": "Ülke:", "LabelCurrentPassword": "Kullanımdaki şifre:", "LabelDay": "Gün:", - "LabelDisplayMissingEpisodesWithinSeasons": "Sezondaki kayıp bölümleri göster", "LabelEnableDlnaServer": "DLNA Sunucusunu Etkinleştir", "LabelFinish": "Bitir", "LabelIconMaxHeight": "Maksimum simge genişliği:", @@ -126,7 +119,6 @@ "OptionAllowUserToManageServer": "Bu kullanıcıya sunucuyu yönetme izni ver", "OptionArtist": "Sanatçı", "OptionAscending": "Yükselen", - "OptionAutomatic": "Otomatik", "OptionContinuing": "Topluluk", "OptionCriticRating": "Yorumcu Puanı", "OptionDaily": "Günlük", @@ -183,14 +175,10 @@ "Sunday": "Pazar", "TabAccess": "Erişim", "TabAdvanced": "Gelişmiş", - "TabAlbumArtists": "Albüm Sanatçıları", "TabCatalog": "Katalog", "TabCodecs": "Codecler", - "TabEpisodes": "Bölümler", - "TabInfo": "Bilgi", "TabLatest": "En yeni", "TabMusic": "Muzik", - "TabMusicVideos": "Klipler", "TabMyPlugins": "Eklentilerim", "TabNetworks": "Ağlar", "TabNotifications": "Bildirimler", @@ -198,7 +186,6 @@ "TabProfiles": "Profiller", "TabServer": "Sunucu", "TabSettings": "Ayarlar", - "TabTrailers": "Fragmanlar", "TabUpcoming": "Gelecek", "TellUsAboutYourself": "Kendinizden bahsedin", "ThisWizardWillGuideYou": "Bu sihirbaz kurulum işlemi boyunca size yardımcı olacaktır. Başlamak için, tercih ettiğiniz dili seçiniz.", @@ -223,7 +210,6 @@ "AirDate": "Yayın tarihi", "Aired": "Yayınlanma tarihi", "Alerts": "Uyarılar", - "ButtonEditImages": "Resimleri Düzenle", "ButtonEditOtherUserPreferences": "Bu kullanıcının profilini, resmini ve kişisel tercihlerini düzenleyin.", "ButtonForgotPassword": "Şifremi unuttum", "ButtonFullscreen": "Tam Ekran", @@ -251,7 +237,6 @@ "ColorTransfer": "Renk transferi", "ButtonPreviousTrack": "Önceki parça", "ButtonProfile": "Profil", - "ButtonRefresh": "Yenile", "ButtonRename": "Yeniden Adlandır", "ButtonResume": "Devam Et", "ButtonRevoke": "Geri al", @@ -296,7 +281,6 @@ "ButtonOpen": "Aç", "ButtonNetwork": "Ağ", "ButtonNextTrack": "Sonraki parça", - "ButtonOff": "Kapalı", "ButtonParentalControl": "Ebeveyn Kontrolü", "ButtonArrowLeft": "Sol", "ButtonGuide": "Rehber", @@ -386,7 +370,6 @@ "EnableCinemaMode": "Sinema Modu", "EnableColorCodedBackgrounds": "Renk kodlu arka planlar", "HeaderGuideProviders": "TV Rehberi Veri Sağlayıcıları", - "HeaderForgotPassword": "Parolanızı mı unuttunuz", "HeaderForKids": "Çocuklar için", "HeaderFetcherSettings": "Alıcı Ayarları", "HeaderFetchImages": "Görüntüleri Getir:", @@ -396,7 +379,6 @@ "HeaderFavoriteBooks": "favori kitaplar", "HeaderExternalIds": "Dış kimlikler:", "HeaderError": "Hata", - "HeaderEpisodes": "Bölümler", "HeaderEnabledFieldsHelp": "Kilitlemek ve verilerinin değişmesini önlemek için bir alanın işaretini kaldırın.", "HeaderEnabledFields": "Etkin Alanlar", "HeaderEditImages": "Görüntüleri Düzenle", @@ -425,12 +407,10 @@ "HeaderCodecProfileHelp": "Codec profilleri, belirli kodlayıcıları oynatırken cihazın sınırlamalarını gösterir. Eğer bir sınırlama uygulanırsa, kodeğin doğrudan oynaması için yapılandırılmış olsa bile, ortam kodlanır.", "HeaderChapterImages": "Bölüm Görüntüleri", "HeaderChannelAccess": "Kanal erişimi", - "HeaderCastCrew": "Kast ekibi", "HeaderCastAndCrew": "Kast ekibi", "HeaderCancelSeries": "Serileri İptal Et", "HeaderCancelRecording": "Kaydı İptal Et", "HeaderBranding": "dağlama", - "HeaderBooks": "Kitaplar", "HeaderBlockItemsWithNoRating": "Tanınmayan veya bilinmeyen derecelendirme bilgisine sahip öğeleri engelle:", "HeaderAudioSettings": "Ses ayarları", "HeaderAudioBooks": "Sesli Kitaplar", @@ -446,7 +426,6 @@ "HeaderAddUpdateImage": "Resim Ekle / Güncelle", "HeaderAddToPlaylist": "Oynatma listesine ekle", "HeaderAddToCollection": "Koleksiyona ekle", - "HeaderAddScheduledTaskTrigger": "Tetikleyici ekle", "HeaderActivity": "Aktivite", "HeaderActiveDevices": "Aktif Cihazlar", "HeaderAccessScheduleHelp": "Belirli saatlerle erişimi sınırlamak için bir erişim programı oluşturun.", @@ -490,9 +469,7 @@ "Episodes": "Bölümler", "EndsAtValue": "{0} konumundaki biter", "EnableThemeVideosHelp": "Kitaplığa göz atarken tema videoları arka planda oynatın.", - "EnableThemeVideos": "Tema videoları", "EnableThemeSongsHelp": "Kitaplığa göz atarken tema şarkıları arka planda çalın.", - "EnableThemeSongs": "Tema şarkıları", "EnableStreamLoopingHelp": "Canlı akışlar yalnızca birkaç saniye veri içeriyorsa ve sürekli istenmesi gerekiyorsa bunu etkinleştirin. Gerekmediğinde bunu etkinleştirmek sorunlara neden olabilir.", "EnableStreamLooping": "Otomatik döngü canlı akışları", "Hide": "Gizle", @@ -536,7 +513,6 @@ "HeaderMusicQuality": "Müzik Kalitesi", "HeaderMoreLikeThis": "Buna Benzer Daha Fazla", "HeaderMetadataSettings": "Meta Verisi Ayarları", - "HeaderMediaInfo": "Medya Bilgisi", "HeaderMedia": "Medya", "HeaderLoginFailure": "Giriş Başarısız", "HeaderLiveTvTunerSetup": "Canlı TV istasyon Kurulumu", @@ -554,7 +530,6 @@ "HeaderIdentificationCriteriaHelp": "En az bir kimlik kriteri girmelisiniz.", "HeaderIdentification": "Kimlik", "HeaderHttpHeaders": "HTTP Başlıkları", - "HeaderHome": "Ana Sayfa", "HeaderFavoritePeople": "Favori Kişiler", "LabelEnableAutomaticPortMap": "Otomatik port eşleştirmeyi etkinleştir", "LabelEasyPinCode": "Basit pin kodu:", @@ -583,7 +558,6 @@ "LabelAudioSampleRate": "Ses örnekleme hızı:", "LabelAudioCodec": "Ses kodeği:", "LabelAudioChannels": "Ses kanalları:", - "LabelAudio": "Ses", "LabelAppName": "Uygulama adı", "LabelAllowHWTranscoding": "Donanım kod dönüştürmesine izin ver", "LabelAlbumArtMaxWidth": "Albüm resmi maks. genişlik:", @@ -687,7 +661,6 @@ "LabelSupportedMediaTypes": "Desteklenen Ortam Türleri:", "LabelSubtitlePlaybackMode": "Altyazı biçimi:", "LabelSubtitleFormatHelp": "Örnek: srt", - "LabelSubtitles": "Altyazılar", "LabelStreamType": "Akış türü:", "LabelSubtitleDownloaders": "Altyazı indiriciler:", "LabelStopping": "Durduruluyor", diff --git a/src/strings/uk.json b/src/strings/uk.json index 764f520524..893311884c 100644 --- a/src/strings/uk.json +++ b/src/strings/uk.json @@ -3,7 +3,6 @@ "BirthPlaceValue": "Місце народження: {0}", "ButtonAddUser": "Додати користувача", "ButtonCancel": "Скасувати", - "ButtonFilter": "Фільтр", "ButtonRename": "Перейменувати", "ButtonResetPassword": "Скинути пароль", "ButtonSignOut": "Вийти", @@ -14,7 +13,6 @@ "FolderTypeMovies": "Фільми", "FolderTypeMusic": "Музика", "FolderTypeTvShows": "ТБ", - "HeaderBooks": "Книги", "HeaderDeleteDevice": "Видалить пристрій", "HeaderLatestEpisodes": "Нещодавно переглянуті серії", "HeaderLatestMedia": "Нещодавно переглянуті", @@ -56,13 +54,11 @@ "ParentalRating": "Parental Rating", "Save": "Зберігти", "Settings": "Налаштування", - "TabEpisodes": "Епізоди", "TabNetworks": "Мережі", "TabNotifications": "Повідомлення", "TabPlugins": "Додатки", "TabProfile": "Профіль", "TabProfiles": "Профілі", - "TabTrailers": "Трейлери", "ValueAlbumCount": "{0} альбомів", "ValueDiscNumber": "Диск {0}", "ValueEpisodeCount": "{0} епізодів", @@ -180,7 +176,6 @@ "ButtonUninstall": "Видалити", "ButtonTrailer": "Трейлер", "ButtonTogglePlaylist": "Плейлист", - "ButtonSubtitles": "Субтитри", "ButtonSubmit": "Підтвердити", "ButtonSplit": "Розділити", "ButtonStop": "Зупинити", @@ -199,30 +194,24 @@ "ButtonResetEasyPassword": "Скинути простий пін-код", "ButtonRemove": "Видалити", "ButtonRefreshGuideData": "Оновити дані телегіда", - "ButtonRefresh": "Оновити", "ButtonQuickStartGuide": "Посібник по швидкому запуску", "ButtonProfile": "Профіль", "ButtonPreviousTrack": "Попередня доріжка", - "ButtonPlay": "Відтворити", "ButtonPause": "Пауза", "ButtonParentalControl": "Батьківський контроль", "ButtonOpen": "Відкрити", "ButtonOk": "Ок", - "ButtonOff": "Вимкнути", "ButtonNextTrack": "Наступна доріжка", "ButtonNetwork": "Мережа", "ButtonMore": "Більше", "ButtonManualLogin": "Ввести ім’я користувача вручну", "ButtonLibraryAccess": "Доступ до медіатеки", "ButtonInfo": "Інформація", - "ButtonHome": "Головна", "ButtonGuide": "Телегід", "ButtonGotIt": "Зрозуміло", "ButtonFullscreen": "Повноекранний режим", "ButtonForgotPassword": "Забув(ла) пароль", "ButtonEditOtherUserPreferences": "Редагувати профіль, зображення та особисті налаштування даного користувача.", - "ButtonEditImages": "Редагувати зображення", - "ButtonEdit": "Редагувати", "ButtonChangeServer": "Змінити сервер", "ButtonBack": "Назад", "ButtonAudioTracks": "Аудіозаписи", diff --git a/src/strings/vi.json b/src/strings/vi.json index 48e59ca057..68718d4c5d 100644 --- a/src/strings/vi.json +++ b/src/strings/vi.json @@ -16,7 +16,6 @@ "FileReadCancelled": "Tệp tin đọc đã bị hủy.", "FileReadError": "Có một lỗi xảy ra khi đọc tệp tin này.", "FolderTypeTvShows": "TV", - "HeaderAddUser": "Thêm người dùng", "HeaderCustomDlnaProfiles": "Hồ sơ khách hàng", "HeaderFeatureAccess": "Truy cập tính năng", "HeaderFrequentlyPlayed": "Phát thường xuyên", @@ -47,7 +46,6 @@ "OptionAlbumArtist": "Album nghệ sỹ", "OptionAllowUserToManageServer": "Cho phép người dùng này quản lý máy chủ", "OptionArtist": "Nghệ sỹ", - "OptionAutomatic": "Tự động", "OptionCommunityRating": "Đánh giá của cộng đồng", "OptionDateAdded": "Ngày thêm", "OptionDatePlayed": "Ngày phát", @@ -79,11 +77,8 @@ "Save": "Lưu", "SettingsSaved": "Lưu các cài đặt.", "Sunday": "Chủ Nhật", - "TabAlbumArtists": "Các Album nghệ sỹ", "TabCatalog": "Danh mục", - "TabEpisodes": "Các tập phim", "TabLatest": "Mới nhất", - "TabMusicVideos": "Các video âm nhạc", "TabMyPlugins": "Các plugin của tôi", "TabNetworks": "Các mạng", "TabProfile": "Hồ sơ", @@ -103,30 +98,23 @@ "ButtonResetEasyPassword": "Đặt lại mã pin nhanh", "ButtonRename": "Đổi tên", "ButtonRefreshGuideData": "Làm mới dữ liệu hướng dẫn", - "ButtonRefresh": "Làm mới", "ButtonQuickStartGuide": "Hướng dẫn nhanh", "ButtonProfile": "Hồ sơ", "ButtonPreviousTrack": "Bài trước", - "ButtonPlay": "Chơi", "ButtonPause": "Tạm dừng", "ButtonParentalControl": "Kiểm soát của cha mẹ", "ButtonOpen": "Mở", - "ButtonOff": "Tắt", "ButtonNextTrack": "Tiếp theo", "ButtonNetwork": "Mạng", "ButtonMore": "Thêm", "ButtonManualLogin": "Đăng nhập thủ công", "ButtonLibraryAccess": "Truy cập thư viện", "ButtonInfo": "Thông tin", - "ButtonHome": "Trang chủ", "ButtonGuide": "Hướng dẫn", "ButtonGotIt": "Hiểu rồi", "ButtonFullscreen": "Toàn màn hình", "ButtonForgotPassword": "Quên mật khẩu", - "ButtonFilter": "Lọc", "ButtonEditOtherUserPreferences": "Chỉnh sửa thông tin, hình ảnh và sở thích cá nhân.", - "ButtonEditImages": "Sửa hình ảnh", - "ButtonEdit": "Sửa", "ButtonChangeServer": "Đổi máy chủ", "ButtonBack": "Lùi", "ButtonAudioTracks": "Track âm thanh", @@ -192,7 +180,6 @@ "ButtonWebsite": "Trang web", "ButtonUninstall": "Gỡ cài đặt", "ButtonTrailer": "Tóm tắt", - "ButtonSubtitles": "Phụ đề", "ButtonSubmit": "Đăng", "ButtonSplit": "Tách", "ButtonStop": "Ngưng", @@ -298,12 +285,10 @@ "HeaderCodecProfile": "Bộ Giải Mã", "HeaderChapterImages": "Hình Ảnh Phân Đoạn", "HeaderChannelAccess": "Quyền Truy Cập Kênh", - "HeaderCastCrew": "Diễn Viên & Ê-kíp", "HeaderCastAndCrew": "Diễn Viên & Ê-kíp", "HeaderCancelSeries": "Huỷ Series", "HeaderCancelRecording": "Dừng Ghi Âm/Ghi Hình", "HeaderBranding": "Tạo Thương Hiệu", - "HeaderBooks": "Sách", "HeaderBlockItemsWithNoRating": "Khoá những mục không có thông tin đánh giá hoặc thông tin không đáng tin cậy:", "HeaderAudioSettings": "Cài Đặt Âm Thanh", "HeaderAudioBooks": "Sách Nói", @@ -320,7 +305,6 @@ "HeaderAddUpdateImage": "Thêm/Thay Đổi Hình Ảnh", "HeaderAddToPlaylist": "Thêm vào Danh Sách Phát", "HeaderAddToCollection": "Thêm vào Bộ Sưu Tập", - "HeaderAddScheduledTaskTrigger": "Thêm Kích Hoạt Tác Vụ", "HeaderActivity": "Hoạt Động", "HeaderActiveRecordings": "Bản Ghi Hình/Ghi Âm Đang Hoạt Động", "HardwareAccelerationWarning": "Bật tính năng hỗ trợ từ phần cứng có thể gây ra sự bất ổn trong một vài môi trường. Hãy chắc chắn rằng điều hành và driver thiết bị đồ hoạ đã được cập nhật mới nhất. Nếu gặp vấn đề khi phát video sau khi bật tính năng này, bạn nên tắt tính năng này.", @@ -375,9 +359,7 @@ "EndsAtValue": "Kết thúc tại {0}", "Ended": "Đã kết thúc", "EnableThemeVideosHelp": "Phát nền những video chủ đề khi lướt qua thư viện nội dung.", - "EnableThemeVideos": "Video chủ đề", "EnableThemeSongsHelp": "Phát những bài hát chủ đề khi lướt qua thư viện nội dung.", - "EnableThemeSongs": "Nhạc chủ đề", "EnableStreamLoopingHelp": "Cho phép tính năng này nếu live streams chỉ dài một vài giây và cần được lặp lại liên tục. Bật tính năng này khi không cần thiết có thể gây ra nhiều vấn đề khác.", "EnableStreamLooping": "Tự động phát lại live streams", "EnablePhotosHelp": "Hình ảnh sẽ được nhận diện và hiển thị bên cạnh những nội dung media.", @@ -417,7 +399,6 @@ "HeaderMusicQuality": "Chất Lượng Âm Nhạc", "HeaderMoreLikeThis": "Nội Dung Tương Tự", "HeaderMetadataSettings": "Cài Đặt Dữ Liệu Bổ Trợ", - "HeaderMediaInfo": "Thông Tin Nội Dung", "HeaderMediaFolders": "Thư Mục Chứa Nội Dung", "HeaderMedia": "Nội Dung", "HeaderLoginFailure": "Đăng Nhập Không Thành Công", @@ -442,9 +423,7 @@ "HeaderIdentificationCriteriaHelp": "Nhập vào ít nhật một thông tin nhận biết.", "HeaderIdentification": "Thông Tin Nhận Biết", "HeaderHttpHeaders": "HTTP Headers", - "HeaderHome": "Trang Chủ", "HeaderGuideProviders": "Nhà Cung Cấp Lịch Phát Sóng TV", - "HeaderForgotPassword": "Quên Mật Khẩu", "HeaderForKids": "Dành Cho Trẻ Em", "HeaderFetcherSettings": "Cài Đặt Chương Trình Tải Xuống", "HeaderFetchImages": "Tải Hình Ảnh:", @@ -459,7 +438,6 @@ "HeaderFavoriteMovies": "Phim Yêu Thích", "HeaderExternalIds": "Mã Định Danh Từ Bên Ngoài:", "HeaderError": "Lỗi", - "HeaderEpisodes": "Tập", "HeaderEnabledFieldsHelp": "Bỏ chọn một mục để khoá lựa chọn đó và không để nó thay đổi.", "HeaderEnabledFields": "Những Mục Được Kích Hoạt", "HeaderEditImages": "Chỉnh Sửa Hình Ảnh", @@ -521,7 +499,6 @@ "HeaderSpecialFeatures": "Những Phần Đặc Biệt Nổi Bật", "HeaderSpecialEpisodeInfo": "Thông Tin Tập Đặc Biệt", "LabelCustomDeviceDisplayNameHelp": "Cung cấp một tên hiển thị riêng hoặc bỏ trống để sử dụng tên có sẵn của thiết bị.", - "LabelCustomDeviceDisplayName": "Tên hiển thị:", "LabelCustomCssHelp": "Áp dụng tuỳ chỉnh riêng của bạn vào giao diện trang web.", "LabelCustomCss": "CSS tuỳ chọn:", "LabelCustomCertificatePathHelp": "Đường dẫn đến tập tin PKCS #12 chứa chứng chỉ (certificate) và khoá riêng (private key) để bật tính năng TLS trên một tên miền tuỳ chọn.", @@ -554,7 +531,6 @@ "LabelAudioChannels": "Các kênh âm thanh:", "LabelAudioBitrate": "Bitrate của âm thanh:", "LabelAudioBitDepth": "Chiều sâu của âm thanh:", - "LabelAudio": "Âm Thanh", "LabelArtistsHelp": "Sử dụng dấu ; để tách rời nhiều nghệ", "LabelArtists": "Nghệ sĩ:", "LabelAppNameExample": "Ví dụ: Sickbeard, Sonarr", @@ -627,7 +603,6 @@ "LabelDisplayOrder": "Thứ tự hiển thị:", "LabelDisplayName": "Tên hiển thị:", "LabelDisplayMode": "Chế độ hiển thị:", - "LabelDisplayMissingEpisodesWithinSeasons": "Hiển thị những tập bị thiếu", "LabelDisplayLanguageHelp": "Dự án chuyển ngữ Jellyfin là một dự án diễn ra ra liên tục.", "LabelDisplayLanguage": "Ngôn ngữ hiển thị:", "LabelDiscNumber": "Đĩa số:", diff --git a/src/strings/zh-cn.json b/src/strings/zh-cn.json index b14bec8277..3678d168fe 100644 --- a/src/strings/zh-cn.json +++ b/src/strings/zh-cn.json @@ -56,31 +56,24 @@ "ButtonBack": "返回", "ButtonCancel": "取消", "ButtonChangeServer": "更改服务器", - "ButtonEdit": "编辑", - "ButtonEditImages": "修改图片", "ButtonEditOtherUserPreferences": "编辑这个用户的用户配置,图片和个人参数。", - "ButtonFilter": "筛选", "ButtonForgotPassword": "忘记密码", "ButtonFullscreen": "全屏", "ButtonGotIt": "知道了", "ButtonGuide": "指南", - "ButtonHome": "首页", "ButtonInfo": "详情", "ButtonLibraryAccess": "媒体库访问", "ButtonManualLogin": "手动登录", "ButtonMore": "更多", "ButtonNetwork": "网络", "ButtonNextTrack": "下一音轨", - "ButtonOff": "关", "ButtonOk": "确定", "ButtonOpen": "打开", "ButtonParentalControl": "家长控制", "ButtonPause": "暂停", - "ButtonPlay": "播放", "ButtonPreviousTrack": "上一音轨", "ButtonProfile": "配置", "ButtonQuickStartGuide": "快速入门指南", - "ButtonRefresh": "刷新", "ButtonRefreshGuideData": "刷新指南数据", "ButtonRemove": "移除", "ButtonRename": "重命名", @@ -101,7 +94,6 @@ "ButtonStart": "开始", "ButtonStop": "停止", "ButtonSubmit": "提交", - "ButtonSubtitles": "字幕", "ButtonTrailer": "预告片", "ButtonUninstall": "卸载", "ButtonWebsite": "网站", @@ -177,9 +169,7 @@ "EnablePhotosHelp": "图片将被检测到并和其他媒体文件一起显示。", "EnableStreamLooping": "自动循环直播流", "EnableStreamLoopingHelp": "如果直播流仅包含了几秒钟的数据并且需要被不断的请求,请启用此项。如果在没有相关问题的情况下启动此项,可能会导致一些问题。", - "EnableThemeSongs": "主题曲", "EnableThemeSongsHelp": "当浏览媒体库时主题曲将作为背景音乐播放。", - "EnableThemeVideos": "主题视频", "EnableThemeVideosHelp": "当浏览媒体库时主题视频将作为背景视频播放。", "Ended": "结束", "EndsAtValue": "结束于 {0}", @@ -230,11 +220,9 @@ "HeaderActiveDevices": "活动的设备", "HeaderActiveRecordings": "正在录制的节目", "HeaderActivity": "活动", - "HeaderAddScheduledTaskTrigger": "添加触发", "HeaderAddToCollection": "加入收藏", "HeaderAddToPlaylist": "添加到播放列表", "HeaderAddUpdateImage": "添加/更新 图片", - "HeaderAddUser": "添加用户", "HeaderAdditionalParts": "附加部分", "HeaderAdmin": "管理", "HeaderAlbumArtists": "专辑作家", @@ -246,10 +234,8 @@ "HeaderAudioBooks": "有声读物", "HeaderAudioSettings": "声音设置", "HeaderBlockItemsWithNoRating": "通过没有评级和设置不允许的评级锁定内容:", - "HeaderBooks": "书籍", "HeaderBranding": "品牌", "HeaderCastAndCrew": "演员表", - "HeaderCastCrew": "演职人员", "HeaderChannelAccess": "频道访问", "HeaderChapterImages": "剧集图片", "HeaderCodecProfile": "编解码器配置", @@ -283,14 +269,12 @@ "HeaderEditImages": "修改图片", "HeaderEnabledFields": "已启用的栏", "HeaderEnabledFieldsHelp": "反选栏以锁定并不让其数据被更改。", - "HeaderEpisodes": "集数", "HeaderError": "错误", "HeaderExternalIds": "外部 ID:", "HeaderFeatureAccess": "可使用的功能", "HeaderFetchImages": "获取图像:", "HeaderFetcherSettings": "读取器设置", "HeaderForKids": "给儿童", - "HeaderForgotPassword": "忘记密码", "HeaderFrequentlyPlayed": "多次播放", "HeaderGuideProviders": "电视指南数据提供方", "HeaderHttpHeaders": "HTTP 头部", @@ -317,7 +301,6 @@ "HeaderLoginFailure": "登录失败", "HeaderMedia": "媒体", "HeaderMediaFolders": "媒体文件夹", - "HeaderMediaInfo": "媒体信息", "HeaderMetadataSettings": "元数据设置", "HeaderMoreLikeThis": "更多类似的", "HeaderMusicVideos": "音乐视频", @@ -469,7 +452,6 @@ "LabelCustomCertificatePathHelp": "提供一个包含了证书和私钥的 PKCS #12 文件的路径以在一个自定义域名上启动 TLS 支持。", "LabelCustomCss": "自定义CSS:", "LabelCustomCssHelp": "应用你的自定义样式到网页。", - "LabelCustomDeviceDisplayName": "显示名称:", "LabelCustomDeviceDisplayNameHelp": "自定义设备显示名称或留空则使用设备报告名称。", "LabelCustomRating": "自定义分级:", "LabelDateAdded": "加入日期:", @@ -486,7 +468,6 @@ "LabelDiscNumber": "光盘号:", "LabelDisplayLanguage": "显示的语言:", "LabelDisplayLanguageHelp": "Jellyfin的翻译工作是一个不断推进的工程项目。", - "LabelDisplayMissingEpisodesWithinSeasons": "显示每季里缺少的剧集", "LabelDisplayMode": "显示模式:", "LabelDisplayName": "显示名称:", "LabelDisplayOrder": "显示顺序:", @@ -642,7 +623,6 @@ "LabelPostProcessorArguments": "处理器后命令行参数:", "LabelPostProcessorArgumentsHelp": "使用 {path} 作为录制文件的路径。", "LabelPreferredDisplayLanguage": "首选显示语言:", - "LabelPreferredDisplayLanguageHelp": "Jellyfin的翻译工作是一个不断推进的工程项目。", "LabelPreferredSubtitleLanguage": "字幕语言偏好:", "LabelProfileAudioCodecs": "音频编解码器:", "LabelProfileCodecs": "编解码器:", @@ -701,7 +681,6 @@ "LabelSubtitleDownloaders": "字幕下载器:", "LabelSubtitleFormatHelp": "例如:SRT", "LabelSubtitlePlaybackMode": "字幕模式:", - "LabelSubtitles": "字幕", "LabelSupportedMediaTypes": "支持的媒体类型:", "LabelTVHomeScreen": "TV 模式主屏幕:", "LabelTag": "标签:", @@ -714,12 +693,9 @@ "LabelTimeLimitHours": "时间限制(小时):", "LabelTitle": "标题:", "LabelTrackNumber": "音轨号码:", - "LabelTranscodingAudioCodec": "音频编解码器:", - "LabelTranscodingContainer": "容器:", "LabelTranscodingTempPathHelp": "设置转码文件存储目录。留空以使用服务器默认文件夹。", "LabelTranscodingThreadCount": "转码线程数:", "LabelTranscodingThreadCountHelp": "选择转码时使用的最大线程数。\n减少线程数量将会降低CPU使用率,可能无法快速进行转换并流畅的播放。", - "LabelTranscodingVideoCodec": "视频编解码器:", "LabelTriggerType": "触发类型:", "LabelTunerIpAddress": "调谐器 IP 地址:", "LabelTunerType": "调谐器类型:", @@ -823,7 +799,6 @@ "MessagePluginConfigurationRequiresLocalAccess": "请直接登录你的本地服务器以设置这个插件。", "MessagePluginInstallDisclaimer": "安装社区成员构建的插件来获取额外的功能是增强您体验的一种很好的方式。但在安装之前请意识到他们可能会对你的服务器造成影响,如更长的媒体库扫描时间、额外的后台处理、以及系统稳定性的降低等。", "MessageReenableUser": "请参阅以下以重新启用", - "MessageSettingsSaved": "设置已保存。", "MessageTheFollowingLocationWillBeRemovedFromLibrary": "以下媒体路径将从你的媒体库移除:", "MessageUnableToConnectToServer": "现在无法连接所选择的服务器,请确保该服务器目前正在运行。", "MessageUnsetContentHelp": "内容将显示为纯文件夹。为取得最佳效果, 请使用元数据管理器设置子文件夹的内容类型。", @@ -889,7 +864,6 @@ "OptionArtist": "艺术家", "OptionAscending": "升序", "OptionAuto": "自动", - "OptionAutomatic": "自动", "OptionAutomaticallyGroupSeries": "自动合并分布在不同文件夹的电视剧", "OptionAutomaticallyGroupSeriesHelp": "在这个媒体库的多个文件夹中的同一部电视剧将会自动整合成一部电视剧。", "OptionBlockBooks": "书籍", @@ -1117,18 +1091,14 @@ "TV": "电视", "TabAccess": "访问", "TabAdvanced": "高级", - "TabAlbumArtists": "专辑艺术家", "TabCatalog": "目录", "TabCodecs": "编解码器", "TabContainers": "媒体载体", "TabDashboard": "控制台", "TabDirectPlay": "直接播放", - "TabEpisodes": "剧集", - "TabInfo": "信息", "TabLatest": "最新", "TabLogs": "日志", "TabMusic": "音乐", - "TabMusicVideos": "音乐视频", "TabMyPlugins": "我的插件", "TabNetworks": "网络", "TabNfoSettings": "NFO 设定", @@ -1139,12 +1109,10 @@ "TabProfile": "个人配置", "TabProfiles": "配置", "TabResponses": "响应", - "TabResumeSettings": "恢复", "TabScheduledTasks": "计划任务", "TabServer": "服务器", "TabSettings": "设置", "TabStreaming": "流媒体传输", - "TabTrailers": "预告片", "TabUpcoming": "即将发布", "Tags": "标签", "TellUsAboutYourself": "请介绍一下你自己", @@ -1234,7 +1202,6 @@ "HeaderFavoriteVideos": "最爱的视频", "HeaderVideoType": "视频类型", "Items": "项目", - "LabelAudio": "音频", "LabelServerName": "服务器名称:", "LabelTranscodePath": "转码路径:", "LabelTranscodes": "转码:", @@ -1312,7 +1279,6 @@ "Vertical": "垂直", "Depressed": "凹陷", "Uniform": "轮廓", - "HeaderHome": "主页", "DashboardOperatingSystem": "操作系统:{0}", "DashboardArchitecture": "架构:{0}", "GroupVersions": "按版本分组", diff --git a/src/strings/zh-hk.json b/src/strings/zh-hk.json index 6cdb6f13a9..21ac5f304c 100644 --- a/src/strings/zh-hk.json +++ b/src/strings/zh-hk.json @@ -3,13 +3,9 @@ "ButtonAddScheduledTaskTrigger": "新增觸發點", "ButtonAddUser": "添加用戶", "ButtonCancel": "取消", - "ButtonEdit": "編輯", - "ButtonFilter": "過濾", "ButtonManualLogin": "手動登入", "ButtonOk": "確定", - "ButtonPlay": "播放", "ButtonQuickStartGuide": "快速入門指南", - "ButtonRefresh": "重新整理", "ButtonRefreshGuideData": "重新整理指南資料", "ButtonRemove": "清除", "ButtonRename": "重新命名", @@ -19,7 +15,6 @@ "ButtonSignIn": "登入", "ButtonSignOut": "登出", "ButtonSubmit": "提交", - "ButtonSubtitles": "字幕", "ChannelAccessHelp": "選擇此用戶共享頻道。管理員將能夠使用資料管理器而編輯所有文件夾。", "Continuing": "繼續", "CustomDlnaProfilesHelp": "為新的設備建立自定配置或覆蓋原有系統配置。", @@ -36,13 +31,9 @@ "Friday": "星期五", "HeaderActiveDevices": "生效裝置", "HeaderActiveRecordings": "正在錄影的節目", - "HeaderAddScheduledTaskTrigger": "新增觸發", "HeaderAddToCollection": "添加到收藏庫", - "HeaderAddUser": "添加用戶", "HeaderAdditionalParts": "附加部份", - "HeaderBooks": "書籍", "HeaderBranding": "界面", - "HeaderCastCrew": "演員陣容", "HeaderCustomDlnaProfiles": "自定配置", "HeaderDeviceAccess": "允許裝置通行", "HeaderDevices": "裝置", @@ -86,7 +77,6 @@ "LabelCustomCss": "自訂 CSS:", "LabelCustomCssHelp": "應用自訂 CSS Web 界面。", "LabelDay": "日子:", - "LabelDisplayMissingEpisodesWithinSeasons": "顯示每季缺少劇集資料", "LabelDisplaySpecialsWithinSeasons": "顯示劇集季度中的特集", "LabelEnableAutomaticPortMap": "啟用自動連接埠映射", "LabelEnableAutomaticPortMapHelp": "自動嘗試映射公共連接埠到 UPnP 本地連接埠。這可能無法用於某些路由器。", @@ -138,7 +128,6 @@ "LabelPassword": "密碼:", "LabelPath": "路徑:", "LabelPreferredDisplayLanguage": "首選語言:", - "LabelPreferredDisplayLanguageHelp": "翻譯 Jellyfin 是一個進行中的項目。", "LabelPublicHttpPort": "公共 http 連接埠號碼:", "LabelPublicHttpPortHelp": "公共連接埠號碼應映射到本地 http 連接埠。", "LabelPublicHttpsPort": "公共 https 連接埠號碼:", @@ -183,7 +172,6 @@ "OptionArtist": "歌手", "OptionAscending": "遞升", "OptionAuto": "自動", - "OptionAutomatic": "自動", "OptionBlockBooks": "書籍", "OptionBluray": "藍光", "OptionCommunityRating": "討論區評分", @@ -256,14 +244,10 @@ "SystemDlnaProfilesHelp": "系統配置文件是唯讀的。更改系統配置文件將被保存到一個自定新配置文件。", "TabAccess": "可以通行", "TabAdvanced": "進階", - "TabAlbumArtists": "唱片歌手", "TabCatalog": "目錄", "TabDashboard": "狀態", - "TabEpisodes": "劇集", - "TabInfo": "資訊", "TabLatest": "最新", "TabMusic": "音樂", - "TabMusicVideos": "MV", "TabMyPlugins": "我的插件", "TabNetworks": "網絡", "TabNotifications": "通知", @@ -272,7 +256,6 @@ "TabProfiles": "簡介", "TabServer": "伺服器", "TabSettings": "設定", - "TabTrailers": "預告", "TabUpcoming": "即將發佈", "TellUsAboutYourself": "介紹一下自己", "ThisWizardWillGuideYou": "此教學協助您完成安裝過程。首先,請選擇您的語言。", @@ -407,13 +390,11 @@ "ButtonNetwork": "網絡", "ButtonMore": "更多", "ButtonInfo": "資訊", - "ButtonHome": "主頁", "ButtonGuide": "教學", "ButtonGotIt": "了解", "ButtonFullscreen": "全螢幕", "ButtonForgotPassword": "忘記密碼", "ButtonEditOtherUserPreferences": "更改用戶個人檔案,圖片及個人偏好。", - "ButtonEditImages": "更改圖片", "ButtonChangeServer": "更換伺服器", "ButtonBack": "返回", "ButtonAudioTracks": "音軌", @@ -450,7 +431,6 @@ "CinemaModeConfigurationHelp": "影院模式可在播放主影片前加入預告片及自定引言片段,帶來戲院式體驗。", "ChangingMetadataImageSettingsNewContent": "任何資料變更只適用於新加入到媒體庫的內容。如要更改舊有媒體的內容,請手動刷新資料。", "ButtonSelectView": "選擇介面", - "ButtonOff": "關閉", "ButtonLibraryAccess": "媒體庫存取", "BookLibraryHelp": "支援文字及有聲書本。請查閱{0} 書本命名教學 {1}。", "DatePlayed": "播放日期", diff --git a/src/strings/zh-tw.json b/src/strings/zh-tw.json index 6361242d4e..52d960ba5c 100644 --- a/src/strings/zh-tw.json +++ b/src/strings/zh-tw.json @@ -7,17 +7,11 @@ "ButtonAddServer": "新增伺服器", "ButtonAddUser": "新增使用者", "ButtonCancel": "取消", - "ButtonEdit": "編輯", - "ButtonEditImages": "編輯圖片", - "ButtonFilter": "過濾", "ButtonForgotPassword": "忘記密碼", "ButtonGotIt": "我知道了", "ButtonGuide": "節目表", - "ButtonHome": "首頁", "ButtonOk": "確定", - "ButtonPlay": "播放", "ButtonQuickStartGuide": "快速入門指南", - "ButtonRefresh": "重新整理", "ButtonRefreshGuideData": "更新電視節目表", "ButtonRemove": "清除", "ButtonResetPassword": "重設密碼", @@ -50,16 +44,13 @@ "Friday": "星期五", "GuideProviderLogin": "登入", "HeaderActiveRecordings": "正在錄影的節目", - "HeaderAddUser": "增加使用者", "HeaderAdditionalParts": "附加部份", "HeaderAdmin": "管理", - "HeaderCastCrew": "拍攝人員及演員", "HeaderCustomDlnaProfiles": "自訂設定檔", "HeaderDeleteItem": "刪除項目", "HeaderEasyPinCode": "簡易 PIN 碼", "HeaderFeatureAccess": "可以使用的功能", "HeaderFetchImages": "擷取圖像:", - "HeaderForgotPassword": "忘記密碼", "HeaderFrequentlyPlayed": "經常播放", "HeaderGuideProviders": "節目表提供者", "HeaderImageSettings": "圖像設置", @@ -90,7 +81,6 @@ "LabelCountry": "國家:", "LabelCurrentPassword": "當前的密碼:", "LabelDay": "日:", - "LabelDisplayMissingEpisodesWithinSeasons": "顯示節目季度內缺少的單元", "LabelEnableDlnaClientDiscoveryInterval": "尋找用戶端時間間隔", "LabelEnableDlnaDebugLogging": "記錄 DLNA 除錯資料到日誌", "LabelEnableDlnaDebugLoggingHelp": "將會建立非常大的日誌檔案,建議在進行故障排除時啟用。", @@ -151,7 +141,6 @@ "OptionAllowUserToManageServer": "允許該使用者管理伺服器", "OptionArtist": "歌手", "OptionAscending": "升序", - "OptionAutomatic": "自動", "OptionBlockLiveTvChannels": "電視頻道", "OptionBluray": "藍光", "OptionCommunityRating": "社區評分", @@ -228,10 +217,7 @@ "Subtitles": "字幕", "Sunday": "星期天", "TabAdvanced": "進階", - "TabAlbumArtists": "專輯歌手", "TabCatalog": "目錄", - "TabEpisodes": "單元", - "TabInfo": "資訊", "TabLatest": "最新", "TabMusic": "音樂", "TabMyPlugins": "我的附加元件", @@ -240,7 +226,6 @@ "TabProfiles": "設定", "TabServer": "伺服器", "TabSettings": "設定", - "TabTrailers": "預告", "TabUpcoming": "接下來", "TellUsAboutYourself": "介紹一下自己", "ThisWizardWillGuideYou": "此精靈將帶你完成安裝過程,開始之前,請選擇您慣用的語言。", @@ -315,7 +300,6 @@ "ButtonMore": "更多", "ButtonNetwork": "網路", "ButtonNextTrack": "下一首", - "ButtonOff": "關", "ButtonOpen": "開", "ButtonParentalControl": "家長控制", "ButtonPause": "暫停", @@ -334,7 +318,6 @@ "ButtonStart": "開始", "ButtonStop": "停止", "ButtonSubmit": "送出", - "ButtonSubtitles": "字幕", "ButtonTrailer": "預告片", "ButtonUninstall": "解除安裝", "ButtonWebsite": "網站", @@ -411,9 +394,7 @@ "EnablePhotosHelp": "圖片將被偵測到並和其他媒體檔案一起顯示。", "EnableStreamLooping": "自動循環播放直播", "EnableStreamLoopingHelp": "如果直播僅包含了幾秒鐘的數據並且需要被不斷的請求,請啟用此項。如果在沒有相關問題的情況下啟動此項,可能會導致一些問題。", - "EnableThemeSongs": "主題曲", "EnableThemeSongsHelp": "瀏覽媒體庫時主題曲將作為背景音樂播放。", - "EnableThemeVideos": "啟用主題影片", "EnableThemeVideosHelp": "瀏覽媒體庫時主題影片將作為背景影片播放。", "Episodes": "劇集", "ErrorAddingListingsToSchedulesDirect": "在將電視節目時間表新增到您的 Schedules Direct 帳號時出現錯誤。每個 Schedules Direct 帳號只允許有限的時間表。您在繼續前可能需要登入 Schedules Direct 網站並刪除帳號中的其它清單。", @@ -457,7 +438,6 @@ "HeaderAccessScheduleHelp": "建立一個存取時程以限制可存取的時段。", "HeaderActiveDevices": "運行中裝置", "HeaderActivity": "活動", - "HeaderAddScheduledTaskTrigger": "新增觸發", "HeaderAddToCollection": "加到收藏", "HeaderAddToPlaylist": "加到播放清單", "HeaderAddUpdateImage": "新增/更新圖片", @@ -472,7 +452,6 @@ "HeaderAudioBooks": "有聲書", "HeaderAudioSettings": "音訊設定", "HeaderBlockItemsWithNoRating": "封鎖沒有評級或設置不允許的內容:", - "HeaderBooks": "書籍", "HeaderBranding": "品牌", "HeaderCancelRecording": "取消錄製", "HeaderCancelSeries": "取消系列", @@ -507,7 +486,6 @@ "HeaderEditImages": "編輯圖片", "HeaderEnabledFields": "已啟用的欄位", "HeaderEnabledFieldsHelp": "反選欄位以鎖定並不讓其數據被更改。", - "HeaderEpisodes": "集數", "HeaderError": "錯誤", "HeaderExternalIds": "外部 ID:", "HeaderFavoriteAlbums": "最愛專輯", @@ -540,7 +518,6 @@ "HeaderLiveTvTunerSetup": "電視直播調諧器安裝", "HeaderLoginFailure": "登入失敗", "HeaderMedia": "媒體", - "HeaderMediaInfo": "媒體資訊", "HeaderMetadataSettings": "中繼資料設定", "HeaderMoreLikeThis": "更多類似的", "HeaderMusicQuality": "音質", @@ -665,7 +642,6 @@ "LabelAppNameExample": "例如:可愛蹦蹦主機、小安的 Jellyfin", "LabelArtists": "藝人:", "LabelArtistsHelp": "將多位演出者以「;」分隔。", - "LabelAudio": "音訊", "LabelAuthProvider": "認證提供者:", "LabelAutomaticallyRefreshInternetMetadataEvery": "從網路自動抓取中繼資料:", "LabelBindToLocalNetworkAddress": "綁定本地網路地址:", @@ -688,9 +664,7 @@ "LabelCustomCertificatePathHelp": "提供包含證書和金鑰的 PKCS #12 文件的路徑以在自訂域名上啟用 TLS。", "LabelCustomCss": "自訂 CSS:", "LabelCustomCssHelp": "於網頁介面套用您的自訂樣式。", - "LabelCustomDeviceDisplayName": "顯示名稱:", "Depressed": "凹陷", - "HeaderHome": "首頁", "HeaderSelectMetadataPathHelp": "瀏覽或者輸入路徑以用於保存中繼資料,請確保資料夾可以寫入。", "HeaderSelectServerCachePathHelp": "瀏覽或者輸入路徑以用於伺服器快取檔案。請確保該資料夾可以被寫入。", "LabelCustomDeviceDisplayNameHelp": "指定自訂的顯示名稱,或者留空以使用設備自己報告的名稱。", @@ -728,8 +702,6 @@ "LabelImageType": "圖片格式:", "LabelIdentificationFieldHelp": "不區分大小寫的子字串或正則表達式。", "Large": "大", - "LabelTranscodingAudioCodec": "音訊編碼:", - "MessageSettingsSaved": "設定已儲存.", "LabelTranscodePath": "轉檔路徑:", "LabelTranscodes": "轉檔:", "MinutesAfter": "分後", @@ -791,7 +763,6 @@ "LabelExtractChaptersDuringLibraryScan": "於媒體庫掃描時擷取章節圖片", "LabelHttpsPort": "本地 HTTPS 埠:", "LabelFailed": "失敗", - "LabelSubtitles": "字幕", "LabelSupportedMediaTypes": "支援的媒體類型:", "LabelTextBackgroundColor": "文字背景顏色:", "LabelTextColor": "文字顏色:", @@ -926,7 +897,6 @@ "OptionBlockTrailers": "預告", "OptionBlockTvShows": "電視節目", "OptionList": "清單", - "TabMusicVideos": "MV", "Yesterday": "昨天", "Yes": "是", "ButtonAddImage": "新增圖片", @@ -972,7 +942,6 @@ "TabStreaming": "串流", "TagsValue": "標記:{0}", "Thumb": "縮圖", - "TabResumeSettings": "繼續播放", "ValueAlbumCount": "{0} 張專輯", "ValueContainer": "影片容器:{0}", "ValueEpisodeCount": "{0} 集", @@ -993,7 +962,6 @@ "OptionProtocolHttp": "HTTP", "TabNfoSettings": "NFO 設定", "FetchingData": "獲取額外資料", - "LabelTranscodingVideoCodec": "影片編碼:", "MediaInfoBitDepth": "位元深度", "Mute": "靜音", "MessageConfirmShutdown": "你確定要關閉伺服器嗎?", @@ -1018,7 +986,6 @@ "LabelProfileContainer": "影片容器:", "LabelDropShadow": "陰影:", "LabelTVHomeScreen": "電視模式主畫面:", - "LabelTranscodingContainer": "影片容器:", "MovieLibraryHelp": "查看 {0}Jellyfin 電影命名指南{1}。", "None": "無", "OptionAllowMediaPlaybackTranscodingHelp": "限制轉檔可能會導致播放不支援的格式時失敗。", @@ -1305,7 +1272,6 @@ "LabelPostProcessorArguments": "處理器後命令行參數:", "LabelPostProcessorArgumentsHelp": "使用 {path} 作為錄製檔案的路徑。", "LabelPreferredDisplayLanguage": "首選語言:", - "LabelPreferredDisplayLanguageHelp": "歡迎一起翻譯 Jellyfin!", "LabelPreferredSubtitleLanguage": "字幕語言偏好:", "LabelProtocol": "協議:", "LabelProtocolInfo": "協議資訊:", From b45803f969a8ddbda65eacda9c64ddabf386a926 Mon Sep 17 00:00:00 2001 From: dkanada Date: Mon, 17 Aug 2020 20:42:26 +0900 Subject: [PATCH 286/301] fix issue with rebase --- src/scripts/clientUtils.js | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/scripts/clientUtils.js b/src/scripts/clientUtils.js index 564f5784b0..1bad8bc81c 100644 --- a/src/scripts/clientUtils.js +++ b/src/scripts/clientUtils.js @@ -101,7 +101,7 @@ export function processPluginConfigurationUpdateResult() { ]) .then(([{default: loading}, {default: toast}]) => { loading.hide(); - toast(Globalize.translate('MessageSettingsSaved')); + toast(Globalize.translate('SettingsSaved')); }); } @@ -112,7 +112,7 @@ export function processServerConfigurationUpdateResult(result) { ]) .then(([{default: loading}, {default: toast}]) => { loading.hide(); - toast(Globalize.translate('MessageSettingsSaved')); + toast(Globalize.translate('SettingsSaved')); }); } From a43b49bc836e521b93f1c4fbb32f0a2e2eabeec6 Mon Sep 17 00:00:00 2001 From: Nyanmisaka <799610810@qq.com> Date: Mon, 17 Aug 2020 17:56:02 +0000 Subject: [PATCH 287/301] Translated using Weblate (Chinese (Simplified)) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/zh_Hans/ --- src/strings/zh-cn.json | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/src/strings/zh-cn.json b/src/strings/zh-cn.json index b14bec8277..8fe4e14565 100644 --- a/src/strings/zh-cn.json +++ b/src/strings/zh-cn.json @@ -1475,5 +1475,6 @@ "MessageGetInstalledPluginsError": "获取已安装插件列表时出现错误。", "MessagePluginInstallError": "安装插件时出现错误。", "NextTrack": "下一曲", - "LabelUnstable": "不稳定" + "LabelUnstable": "不稳定", + "PlaybackRate": "播放速率" } From 2584b140c9167c41f57783a842a6f747af311dc3 Mon Sep 17 00:00:00 2001 From: adrian gustavo martinez Date: Tue, 18 Aug 2020 03:59:00 +0000 Subject: [PATCH 288/301] Translated using Weblate (Spanish (Argentina)) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/es_AR/ --- src/strings/es-ar.json | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/strings/es-ar.json b/src/strings/es-ar.json index 74eb87e842..2883ac4445 100644 --- a/src/strings/es-ar.json +++ b/src/strings/es-ar.json @@ -61,7 +61,7 @@ "AllowMediaConversionHelp": "Permitir o denegar acceso a la opción de convertir medios.", "AllowOnTheFlySubtitleExtraction": "Permitir extracción de subtítulos al vuelo", "AllowOnTheFlySubtitleExtractionHelp": "Los subtítulos incrustados se pueden extraer de los videos y entregar a los clientes en texto plano, para ayudar a evitar la transcodificación de videos. En algunos sistemas, esto puede llevar mucho tiempo y provocar que la reproducción de video se detenga durante el proceso de extracción. Deshabilite esto para que los subtítulos incrustados se graben con la transcodificación de video cuando el dispositivo cliente no los admite de forma nativa.", - "AllowRemoteAccess": "Permitir conexiones remotas a este servidor Jellyfin.", + "AllowRemoteAccess": "Permitir conexiones remotas a este servidor.", "AllowRemoteAccessHelp": "Si no está tildado, todas las conexiones remotas serán bloqueadas.", "AlwaysPlaySubtitles": "Reproducir siempre", "AnyLanguage": "Cualquier idioma", @@ -159,7 +159,7 @@ "ColorTransfer": "Transferencia de color", "CommunityRating": "Puntuación de la comunidad", "Composer": "Compositor", - "ConfigureDateAdded": "Configura cómo se va a determinar las fechas de adición en la pestaña Bibliotecas del panel del servidor Jellyfin", + "ConfigureDateAdded": "Configure cómo se determina la fecha agregada en el panel en la configuración de la biblioteca", "ConfirmDeleteImage": "¿Eliminar imagen?", "ConfirmDeleteItem": "Eliminar este elemento lo eliminará tanto del sistema de archivos como de la biblioteca de medios. ¿Está seguro que desea continuar?", "ConfirmDeleteItems": "Eliminar estos elementos los eliminará tanto del sistema de archivos como de la biblioteca de medios. ¿Está seguro que desea continuar?", @@ -216,7 +216,7 @@ "EnableBackdropsHelp": "Muestra imágenes de fondo en el fondo de algunas páginas mientras se navega por la biblioteca.", "EnableCinemaMode": "Modo cine", "EnableColorCodedBackgrounds": "Habilitar colores en el fondo del código", - "AuthProviderHelp": "Seleccione un proveedor de autenticación que se utilizará para autenticar la contraseña de este usuario.", + "AuthProviderHelp": "Seleccione un proveedor de autenticación para ser utilizado para autenticar la contraseña de este usuario.", "CriticRating": "Valoración crítica", "DefaultSubtitlesHelp": "Los subtítulos se cargan según los indicadores predeterminados y forzados en los metadatos incrustados. Las preferencias de idioma se consideran cuando hay varias opciones disponibles.", "Dislike": "No me gusta", From adbc5f3885e9d282cb29f2d93b53ed332202edc5 Mon Sep 17 00:00:00 2001 From: millallo Date: Tue, 18 Aug 2020 06:43:56 +0000 Subject: [PATCH 289/301] Translated using Weblate (Italian) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/it/ --- src/strings/it.json | 30 +++++++++++++++--------------- 1 file changed, 15 insertions(+), 15 deletions(-) diff --git a/src/strings/it.json b/src/strings/it.json index cb73ea2cdb..f84fa8e613 100644 --- a/src/strings/it.json +++ b/src/strings/it.json @@ -190,7 +190,7 @@ "ErrorAddingMediaPathToVirtualFolder": "C'è stato un errore durante l'aggiunta del percorso. Per favore controlla che il percorso sia valido, e che Jellyfin abbia l'accesso alla posizione indicata.", "ErrorAddingTunerDevice": "Si è verificato un errore durante l'aggiunta del sintonizzatore. Si prega di assicurarsi che sia accessibile e riprovare.", "ErrorAddingXmlTvFile": "Si è verificato un errore durante l'accesso al file XMLTV. Si prega di assicurarsi che il file esista e riprovare.", - "ErrorDeletingItem": "Si è verificato un errore durante l'eliminazione dell'elemento da Jellyfin Server. Verifica che Jellyfin Server abbia accesso in scrittura sulla cartella multimediale e riprova.", + "ErrorDeletingItem": "Si è verificato un errore durante l'eliminazione dell'elemento dal server. Verifica che Jellyfin abbia accesso in scrittura sulla cartella multimediale e riprova.", "ErrorGettingTvLineups": "Si è verificato un errore durante il download delle formazioni TV. Assicurarsi che le vostre informazioni siano corrette e riprovare.", "ErrorStartHourGreaterThanEnd": "Il tempo della fine deve essere maggiore del tempo di avvio.", "ErrorPleaseSelectLineup": "Si prega di selezionare una scaletta e riprovare. Se non ci sono formazioni disponibili, si prega allora di verificare che il vostro nome utente, password, e il codice postale siano corretti.", @@ -348,7 +348,7 @@ "HeaderPreferredMetadataLanguage": "Lingua Preferita per i Metadati", "HeaderProfile": "Profilo", "HeaderProfileInformation": "Informazioni sul profilo", - "HeaderProfileServerSettingsHelp": "Questi valori controllano come il Server Jellyfin si presenterà ad un dispositivo.", + "HeaderProfileServerSettingsHelp": "Questi valori controllano come il server si presenterà ai client.", "HeaderRecentlyPlayed": "Visti di recente", "HeaderRecordingOptions": "Opzioni di Registrazione", "HeaderRecordingPostProcessing": "Post-processing Registrazione", @@ -365,13 +365,13 @@ "HeaderSecondsValue": "{0} Secondi", "HeaderSelectCertificatePath": "Seleziona il percorso del Certificato", "HeaderSelectMetadataPath": "Selezionare Percorso Metadati", - "HeaderSelectMetadataPathHelp": "Sfoglia o inserire il percorso in cui vuoi archiviare i metadati. La cartella deve essere scrivibile.", + "HeaderSelectMetadataPathHelp": "Sfoglia o inserisci il percorso da usare per archiviare i metadati. La cartella deve essere scrivibile.", "HeaderSelectPath": "Seleziona Percorso", "HeaderSelectServer": "Scegli Server", "HeaderSelectServerCachePath": "Seleziona percorso Cache Server", "HeaderSelectServerCachePathHelp": "Sfoglia o immetti il percorso da utilizzare per i file di cache server. La cartella deve essere scrivibile.", "HeaderSelectTranscodingPath": "Selezionare Percorso Temporaneo Transcodifica", - "HeaderSelectTranscodingPathHelp": "Sfoglia o immettere il percorso da utilizzare per la transcodifica dei file temporanei. La cartella deve essere scrivibile.", + "HeaderSelectTranscodingPathHelp": "Sfoglia o inserisci il percorso da utilizzare per la transcodifica dei file. La cartella deve essere scrivibile.", "HeaderSendMessage": "Invia un messaggio", "HeaderSeriesOptions": "Impostazioni Serie TV", "HeaderSeriesStatus": "Stato Serie TV", @@ -418,8 +418,8 @@ "HttpsRequiresCert": "Per abilitare le connessioni sicure, dovrai fornire un certificato SSL affidabile, come Let's Encrypt. Per favore o fornisci un certificato, o disabilita le connessioni sicure.", "Identify": "Identifica", "Images": "Immagini", - "ImportFavoriteChannelsHelp": "Se abilitata, solo i canali che sono contrassegnati come preferiti sul dispositivo di sintonizzazione verranno importati.", - "ImportMissingEpisodesHelp": "Se abilitato, le informazioni relative agli episodi mancanti saranno importate nel database di Jellyfin e mostrate all'interno di Serie e Stagioni. Questo può causare scansioni della libreria più lente.", + "ImportFavoriteChannelsHelp": "Solo i canali che sono contrassegnati come preferiti sul dispositivo di sintonizzazione verranno importati.", + "ImportMissingEpisodesHelp": "Le informazioni relative agli episodi mancanti saranno importate nel database e mostrate all'interno di Serie e Stagioni. Questo può causare scansioni della libreria più lente.", "InstallingPackage": "Installazione di {0} (versione {1})", "InstantMix": "Mix istantaneo", "ItemCount": "{0} elementi", @@ -448,14 +448,14 @@ "LabelAppName": "Nome app", "LabelAppNameExample": "Esempio: Sickbeart, Sonarr", "LabelArtists": "Artisti:", - "LabelArtistsHelp": "Separa valori multipli usando ;", + "LabelArtistsHelp": "Separa più artisti usando il simbolo ;", "LabelAudioLanguagePreference": "Lingua audio preferita:", "LabelAutomaticallyRefreshInternetMetadataEvery": "Aggiorna automaticamente i metadati da Internet:", "LabelBindToLocalNetworkAddress": "Assegna ad indirizzo di rete locale:", - "LabelBindToLocalNetworkAddressHelp": "Opzionale. Sovrascrivere l'indirizzo IP locale per associare il server http a. Se lasciato vuoto, il server verrà associato a tutti gli indirizzi disponibili. Modificare questo valore richiede di riavviare Jellyfin Server.", + "LabelBindToLocalNetworkAddressHelp": "Sovrascrive l'indirizzo IP locale del server HTTP. Se lasciato vuoto, il server verrà associato a tutti gli indirizzi disponibili. Modificare questo valore richiede il riavvio.", "LabelBirthDate": "Data di nascita:", "LabelBirthYear": "Anno di nascita:", - "LabelBlastMessageInterval": "Intervallo messaggi di presenza (secondi)", + "LabelBlastMessageInterval": "Intervallo messaggi di presenza", "LabelBlastMessageIntervalHelp": "Determina la durata in secondi fra i messaggi \"blast alive\".", "LabelBlockContentWithTags": "Blocco degli elementi con le etichette:", "LabelBurnSubtitles": "Applica sottotitoli:", @@ -474,13 +474,13 @@ "LabelCustomCertificatePath": "Percorso personalizzato certificato SSL:", "LabelCustomCertificatePathHelp": "Percorso del file PKCS #12 contenente il certificato e la chiave private per abilitare il supporto TLS in un dominio personalizzato.", "LabelCustomCss": "CSS Personalizzato:", - "LabelCustomCssHelp": "Applica il tuo stile personale all'interfaccia web.", + "LabelCustomCssHelp": "Applica il tuo stile personalizzato all'interfaccia web.", "LabelCustomDeviceDisplayName": "Nome da visualizzare:", "LabelCustomDeviceDisplayNameHelp": "Fornire un nome di visualizzazione personalizzato o lasciare vuoto per utilizzare il nome riportato dal dispositivo.", "LabelCustomRating": "Voto personalizzato:", "LabelDateAdded": "Aggiunto il:", "LabelDateAddedBehavior": "Data di comportamento per i nuovi contenuti:", - "LabelDateAddedBehaviorHelp": "Se un valore di metadati è presente sarà sempre utilizzato prima una di queste opzioni.", + "LabelDateAddedBehaviorHelp": "Se un valore di metadati è presente sarà sempre utilizzato prima di una di queste opzioni.", "LabelDateTimeLocale": "Data locale:", "LabelDay": "Giorno:", "LabelDeathDate": "Anno di morte:", @@ -509,8 +509,8 @@ "LabelEnableAutomaticPortMapHelp": "Automaticamente inoltra le porte pubbliche del router sul quelle locali del server tramite UPnP. Potrebbe non funzionare con alcuni modelli di router. I cambiamenti non saranno applicati fino ad il riavvio del server.", "LabelEnableBlastAliveMessages": "Invia segnale di presenza", "LabelEnableBlastAliveMessagesHelp": "Attivare questa opzione se il server non viene rilevato in modo affidabile da altri dispositivi UPnP in rete.", - "LabelEnableDlnaClientDiscoveryInterval": "Intervallo di ricerca dispositivi (secondi)", - "LabelEnableDlnaClientDiscoveryIntervalHelp": "Determina la durata in secondi tra le ricerche SSDP effettuate da Jellyfin.", + "LabelEnableDlnaClientDiscoveryInterval": "Intervallo di ricerca dei client", + "LabelEnableDlnaClientDiscoveryIntervalHelp": "Determina la durata in secondi tra le ricerche SSDP.", "LabelEnableDlnaDebugLogging": "Abilita il debug del DLNA", "LabelEnableDlnaDebugLoggingHelp": "Crea file di grandi dimensioni e dovrà essere usato solo quando necessario per risolvere problemi.", "LabelEnableDlnaPlayTo": "Abilita DLNA su", @@ -519,7 +519,7 @@ "LabelEnableDlnaServerHelp": "Consente ai dispositivi UPnP nella tua rete di sfogliare i contenuti e riprodurli.", "LabelEnableHardwareDecodingFor": "Abilita la decodifica hardware per:", "LabelEnableRealtimeMonitor": "Abilita monitoraggio in tempo reale", - "LabelEnableRealtimeMonitorHelp": "Le modifiche saranno applicate immediatamente, sui file system supportati.", + "LabelEnableRealtimeMonitorHelp": "Le modifiche saranno applicate immediatamente sui file system supportati.", "LabelEnableSingleImageInDidlLimit": "Limitato a singola immagine incorporata", "LabelEnableSingleImageInDidlLimitHelp": "Alcuni dispositivi non renderanno correttamente se più immagini sono incorporati all'interno didl.", "LabelEndDate": "Data di fine:", @@ -1405,7 +1405,7 @@ "LabelChromecastVersion": "Versione Chromecast", "LabelRequireHttpsHelp": "Se selezionata, il server reindirizzerà tutte le richieste HTTP a HTTPS. Vale solo se il sever è configurato per l'ascolto in HTTPS.", "LabelRequireHttps": "Richiede HTTPS", - "LabelEnableHttpsHelp": "Abilita il server all'ascolto sulla porta HTTPS configurata. Il certificato deve essere configurato e valido per l'abilitazione.", + "LabelEnableHttpsHelp": "Ascolta sulla porta HTTPS configurata. Deve essere fornito un certificato valido per l'abilitazione.", "LabelEnableHttps": "Abilita HTTPS", "HeaderServerAddressSettings": "Configurazione Indirizzo Server", "HeaderRemoteAccessSettings": "Configurazione Access Remoto", From 89f07432ceee0ce74df4111dfdfc5185298fedb4 Mon Sep 17 00:00:00 2001 From: millallo Date: Tue, 18 Aug 2020 07:02:29 +0000 Subject: [PATCH 290/301] Translated using Weblate (Italian) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/it/ --- src/strings/it.json | 37 +++++++++++++++++++------------------ 1 file changed, 19 insertions(+), 18 deletions(-) diff --git a/src/strings/it.json b/src/strings/it.json index f84fa8e613..85dc28e5b3 100644 --- a/src/strings/it.json +++ b/src/strings/it.json @@ -534,7 +534,7 @@ "LabelForgotPasswordUsernameHelp": "Inserisci il tuo nome utente, se te lo ricordi.", "LabelFormat": "Formato:", "LabelFriendlyName": "Nome Condiviso:", - "LabelServerNameHelp": "Questo nome è usato per identificare il server e avrà come default il nome del pc.", + "LabelServerNameHelp": "Questo nome è usato per identificare il server e avrà come default l'hostname del server.", "LabelGroupMoviesIntoCollections": "Raggruppa i film nelle collezioni", "LabelGroupMoviesIntoCollectionsHelp": "Quando si visualizzano le liste di film, quelli appartenenti ad una collezione saranno visualizzati come un elemento raggruppato.", "LabelH264Crf": "CRF di codifica H264:", @@ -544,7 +544,7 @@ "LabelHomeNetworkQuality": "Qualità della rete domestica:", "LabelHomeScreenSectionValue": "Pagina iniziale Sezione {0}:", "LabelHttpsPort": "Porta HTTPS locale:", - "LabelHttpsPortHelp": "Numero di porta TCP da associare al server HTTPS di Jellyfin.", + "LabelHttpsPortHelp": "Porta TCP da associare al server HTTPS.", "LabelIconMaxHeight": "Altezza icona massima:", "LabelIconMaxHeightHelp": "Risoluzione massima delle icone inviate tramite upnp:icon.", "LabelIconMaxWidth": "Larghezza massima icona:", @@ -572,7 +572,7 @@ "LabelLanguage": "Lingua:", "LabelLineup": "Allineare:", "LabelLocalHttpServerPortNumber": "Porta HTTP locale:", - "LabelLocalHttpServerPortNumberHelp": "Numero di porta TCP da associare al server HTTP di Jellyfin.", + "LabelLocalHttpServerPortNumberHelp": "Porta TCP da associare al server HTTP.", "LabelLockItemToPreventChanges": "Blocca questo elemento per impedire modifiche future", "LabelLoginDisclaimer": "Avviso Login:", "LabelLoginDisclaimerHelp": "Un messaggio che verrà visualizzato nella parte inferiore della pagina di accesso.", @@ -612,7 +612,7 @@ "LabelMovieCategories": "Categorie film:", "LabelMoviePrefix": "Prefisso film:", "LabelMoviePrefixHelp": "Se un prefisso viene applicato ai titoli di film, inseriscilo qui in modo che il server possa gestirlo correttamente.", - "LabelMovieRecordingPath": "Percorso di registrazione film (opzionale):", + "LabelMovieRecordingPath": "Percorso di registrazione film:", "LabelMusicStreamingTranscodingBitrate": "Musica trascodifica bitrate:", "LabelMusicStreamingTranscodingBitrateHelp": "Specifica il massimo bitrate per lo streaming musicale.", "LabelName": "Nome:", @@ -624,8 +624,8 @@ "LabelNumber": "Numero:", "LabelNumberOfGuideDays": "Numero di giorni per i quali scaricare i dati della guida:", "LabelNumberOfGuideDaysHelp": "Scaricando più giorni si avrà la possibilità di pianificare in anticipo più programmi e vedere più liste, ma il tempo di download si allungherà. 'Auto': MB sceglierà automaticamente in base al numero di canali.", - "LabelOptionalNetworkPath": "Cartella condivisa (Opzionale):", - "LabelOptionalNetworkPathHelp": "Se questa cartella è condivisa sulla rete, fornendo il percorso di condivisione di rete si può consentire alle applicazioni Jellyfin su altri dispositivi di accedere direttamente ai file multimediali. Ad esempio {0} oppure {1}.", + "LabelOptionalNetworkPath": "Cartella di rete condivisa:", + "LabelOptionalNetworkPathHelp": "Se questa cartella è condivisa sulla rete, fornendo il percorso di condivisione di rete si può consentire ai client su altri dispositivi di accedere direttamente ai file multimediali. Ad esempio {0} oppure {1}.", "LabelOriginalAspectRatio": "Aspetto originale:", "LabelOriginalTitle": "Titolo originale:", "LabelOverview": "Trama:", @@ -665,7 +665,7 @@ "LabelReleaseDate": "Data di uscita:", "LabelRemoteClientBitrateLimit": "Bitrate limite per lo streaming via internet (Mbps):", "LabelRemoteClientBitrateLimitHelp": "Un limite bitrate per-stream opzionale per tutti i dispositivi di rete. Ciò è utile per impedire ai dispositivi di richiedere un bitrate superiore a quello in grado di gestire la connessione a Internet. Questo può provocare un aumento del carico della CPU sul server per transcodificare i video in volo ad un bitrate inferiore.", - "LabelRuntimeMinutes": "Durata (minuti):", + "LabelRuntimeMinutes": "Durata:", "LabelSaveLocalMetadata": "Salva immagini nelle cartelle multimediali", "LabelSaveLocalMetadataHelp": "Il salvataggio di immagini direttamente nelle cartelle multimediali consentirà di tenerle in un posto dove possono essere facilmente modificati.", "LabelScheduledTaskLastRan": "Ultima esecuzione {0}, taking {1}.", @@ -677,7 +677,7 @@ "LabelSelectVersionToInstall": "Selezionare la versione da installare:", "LabelSendNotificationToUsers": "Invia notifiche a:", "LabelSerialNumber": "Numero di serie", - "LabelSeriesRecordingPath": "Percorso di registrazione serie TV (opzionale):", + "LabelSeriesRecordingPath": "Percorso di registrazione Serie TV:", "LabelSimultaneousConnectionLimit": "Limite stream simultanei:", "LabelSkipBackLength": "Durata salta indietro:", "LabelSkipForwardLength": "Durata salta avanti:", @@ -740,7 +740,7 @@ "LabelYoureDone": "Hai Finito!", "LabelZipCode": "Cap:", "LabelffmpegPath": "Percorso FFmpeg:", - "LabelffmpegPathHelp": "Il percorso all'applicazione ffmpeg, o alla cartella che la contiene.", + "LabelffmpegPathHelp": "Il percorso dell'applicazione ffmpeg o della cartella che la contiene.", "LanNetworksHelp": "Elenco separato da virgola di indirizzi IP o voci IP / maschera di rete per reti che saranno considerate sulla rete locale quando si applicano restrizioni di larghezza di banda. Se impostato, tutti gli altri indirizzi IP verranno considerati nella rete esterna e saranno soggetti alle limitazioni della larghezza di banda esterna. Se lasciato vuoto, solo la sottorete del server viene considerata nella rete locale.", "Large": "Grande", "LatestFromLibrary": "Ultimi {0}", @@ -786,13 +786,13 @@ "MessageConfirmProfileDeletion": "Sei sicuro di voler cancellare questo profilo?", "MessageConfirmRecordingCancellation": "Cancellare la registrazione?", "MessageConfirmRemoveMediaLocation": "Sei sicuro di voler rimuovere questa posizione?", - "MessageConfirmRestart": "Sei sicuro di voler riavviare il Server Jellyfin?", - "MessageConfirmRevokeApiKey": "Sei sicuro di voler revocare questa chiave api? La connessione dell'applicazione al Server Jellyfin terminerà immediatamente.", + "MessageConfirmRestart": "Sei sicuro di voler riavviare Jellyfin?", + "MessageConfirmRevokeApiKey": "Sei sicuro di voler revocare questa chiave API? La connessione dell'applicazione al Server terminerà immediatamente.", "MessageConfirmShutdown": "Sei sicuro di voler spegnere il server?", "MessageContactAdminToResetPassword": "Si prega di contattare l'amministratore di sistema per reimpostare la password.", "MessageCreateAccountAt": "Crea un account a {0}", "MessageDeleteTaskTrigger": "Sei sicuro di voler cancellare questo evento?", - "MessageDirectoryPickerBSDInstruction": "Per BSD, potrebbe essere necessario per configurare le unità all'interno della vostra prigione FreeNAS al fine di permettere ricamato accedervi.", + "MessageDirectoryPickerBSDInstruction": "Per BSD, potrebbe essere necessario configurare le unità all'interno della vostra FreeNAS Jail per permettere A Jellyfin di accedervi.", "MessageDirectoryPickerLinuxInstruction": "Per Linux su Arch Linux, CentOS, Debian, Fedora, openSUSE o Ubuntu, è necessario concedere all'utente del servizio almeno l'accesso alle posizioni di archiviazione.", "MessageDownloadQueued": "Scaricamento programmato.", "MessageEnablingOptionLongerScans": "L'abilitazione di questa opzione può rallentare significativamente le scansioni della libreria.", @@ -814,7 +814,7 @@ "MessagePleaseEnsureInternetMetadata": "Assicurarsi che il download dei metadati Internet sia abilitato.", "MessagePleaseWait": "Per favore attendi. La procedura potrebbe impiegare qualche minuto.", "MessagePluginConfigurationRequiresLocalAccess": "Per configurare questo plugin si prega di accedere al proprio server locale direttamente.", - "MessagePluginInstallDisclaimer": "I plugin creati dai membri della comunità Jellyfin sono un ottimo modo per migliorare l'esperienza di Jellyfin con funzionalità e vantaggi aggiuntivi. Prima di installare, si prega di notare gli effetti che possono avere sul tuo server Jellyfin, come le scansioni più lunghe della libreria, l'elaborazione di sfondo aggiuntiva e la stabilità del sistema diminuita.", + "MessagePluginInstallDisclaimer": "I plugin creati dai membri della comunità sono un ottimo modo per migliorare l'esperienza con funzionalità e vantaggi aggiuntivi. Prima di installarli, si prega di notare gli effetti che possono avere sul tuo Server, come le scansioni più lunghe della libreria, l'elaborazione di sfondo aggiuntiva e la stabilità del sistema diminuita.", "MessageReenableUser": "Guarda in basso per ri-abilitare", "MessageSettingsSaved": "Settaggi salvati.", "MessageTheFollowingLocationWillBeRemovedFromLibrary": "I seguenti percorsi ai file multimediali saranno rimossi dalla tua libreria:", @@ -822,7 +822,7 @@ "MessageUnsetContentHelp": "Il contenuto verrà visualizzato come pianura cartelle. Per ottenere i migliori risultati utilizzare il gestore di metadati per impostare i tipi di contenuto di sottocartelle.", "MessageYouHaveVersionInstalled": "Attualmente hai la versione {0} installato.", "MetadataManager": "Gestisci Metadati", - "MetadataSettingChangeHelp": "Modificare le impostazioni dei metadati influenzerà il nuovo contenuto aggiunto in avanti. Per aggiornare i contenuti esistenti, aprire la schermata dei dettagli e fare click sul pulsante di aggiornamento oppure eseguire aggiornamenti di massa utilizzando il gestore di metadati.", + "MetadataSettingChangeHelp": "Modificare le impostazioni dei metadati influenzerà i futuri contenuti. Per aggiornare i contenuti esistenti, aprire la schermata dei dettagli e fare click sul pulsante di aggiornamento oppure eseguire aggiornamenti di massa utilizzando il gestore di metadati.", "MinutesAfter": "minuti dopo", "MinutesBefore": "minuti prima", "Monday": "Lunedì", @@ -866,7 +866,7 @@ "OptionAllowLinkSharingHelp": "Solo le pagine web contenente informazioni sui media sono condivise. I file media non vengono mai condivisi pubblicamente. Le condivisioni scadono dopo {0} giorni.", "OptionAllowManageLiveTv": "Consenti la gestione delle registrazioni TV", "OptionAllowMediaPlayback": "Consenti la riproduzione dei media", - "OptionAllowMediaPlaybackTranscodingHelp": "Limitare l'accesso alla transcodifica può causare errori di riproduzione nelle applicazioni Jellyfin a causa di formati multimediali non supportati.", + "OptionAllowMediaPlaybackTranscodingHelp": "Limitare l'accesso alla transcodifica può causare errori di riproduzione a causa di formati multimediali non supportati.", "OptionAllowRemoteControlOthers": "Consenti il controllo remoto di altri utenti", "OptionAllowRemoteSharedDevices": "Consenti il controllo remoto dei dispositivi condivisi", "OptionAllowRemoteSharedDevicesHelp": "I dispositivi DLNA sono considerati condivisi fino a quando un utente non inizia a controllarli.", @@ -878,7 +878,7 @@ "OptionAscending": "Crescente", "OptionAuto": "Automatico", "OptionAutomaticallyGroupSeries": "Fondi automaticamente le serie sparse su più cartelle", - "OptionAutomaticallyGroupSeriesHelp": "Se abilitato, le serie distribuite in più cartelle di questa libreria saranno automaticamente combinate in un'unica serie.", + "OptionAutomaticallyGroupSeriesHelp": "Le Serie TV distribuite su più cartelle di questa libreria saranno automaticamente combinate in un'unica Serie TV.", "OptionBlockBooks": "Libri", "OptionBlockChannelContent": "Contenuto di Canali Internet", "OptionBlockLiveTvChannels": "Canali TV in onda", @@ -897,7 +897,7 @@ "OptionDatePlayed": "Visto il", "OptionDescending": "Decrescente", "OptionDisableUser": "Disabilita questo utente", - "OptionDisableUserHelp": "Se disabilitato, il server non sarà disponibile per questo utente. Le connessioni esistenti verranno terminate.", + "OptionDisableUserHelp": "Il server non sarà disponibile per questo utente. Le connessioni esistenti verranno terminate.", "OptionDislikes": "Non mi piace", "OptionDisplayFolderView": "Visualizza cartelle come normali cartelle dei media", "OptionDisplayFolderViewHelp": "Visualizza le cartelle accanto alle librerie multimediali. Questo può essere utile se si desidera avere una vista di cartelle semplici.", @@ -1468,5 +1468,6 @@ "Writers": "Scrittori", "ClearQueue": "Svuota la coda", "StopPlayback": "Interrompi riproduzione", - "LabelUnstable": "Unstable" + "LabelUnstable": "Unstable", + "NextTrack": "Prossima traccia" } From 9bbf0500ee3dd75237a4cb1686395e7fe289d242 Mon Sep 17 00:00:00 2001 From: millallo Date: Tue, 18 Aug 2020 07:51:09 +0000 Subject: [PATCH 291/301] Translated using Weblate (Italian) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/it/ --- src/strings/it.json | 39 ++++++++++++++++++++++----------------- 1 file changed, 22 insertions(+), 17 deletions(-) diff --git a/src/strings/it.json b/src/strings/it.json index 85dc28e5b3..9465c488cb 100644 --- a/src/strings/it.json +++ b/src/strings/it.json @@ -419,7 +419,7 @@ "Identify": "Identifica", "Images": "Immagini", "ImportFavoriteChannelsHelp": "Solo i canali che sono contrassegnati come preferiti sul dispositivo di sintonizzazione verranno importati.", - "ImportMissingEpisodesHelp": "Le informazioni relative agli episodi mancanti saranno importate nel database e mostrate all'interno di Serie e Stagioni. Questo può causare scansioni della libreria più lente.", + "ImportMissingEpisodesHelp": "Le informazioni relative agli episodi mancanti saranno importate nel database e mostrate all'interno di Serie e Stagioni. Questo può causare scansioni della libreria più lente.", "InstallingPackage": "Installazione di {0} (versione {1})", "InstantMix": "Mix istantaneo", "ItemCount": "{0} elementi", @@ -904,7 +904,7 @@ "OptionDownloadBackImage": "Indietro", "OptionDownloadDiscImage": "Disco", "OptionDownloadImagesInAdvance": "Scarica preventivamente le immagini", - "OptionDownloadImagesInAdvanceHelp": "Di default, la maggior parte delle immagini vengono scaricate solo quando richieste da un'applicazione Jellyfin. Abilita questa opzione per scaricare tutte le immagini in anticipo, quando nuovi file multimediali vengono importati. Ciò può causare scansioni delle librerie molto più lunghe.", + "OptionDownloadImagesInAdvanceHelp": "Di default, la maggior parte delle immagini vengono scaricate solo quando richieste dai client. Abilita questa opzione per scaricare tutte le immagini in anticipo, quando nuovi file multimediali vengono importati. Ciò può causare scansioni delle librerie molto più lunghe.", "OptionDownloadMenuImage": "Menù", "OptionDownloadPrimaryImage": "Locandina", "OptionDownloadThumbImage": "Foto", @@ -933,7 +933,7 @@ "OptionHlsSegmentedSubtitles": "HLS sottotitoli segmentati", "OptionHomeVideos": "Foto", "OptionIgnoreTranscodeByteRangeRequests": "Ignorare le richieste di intervallo di byte di trascodifica", - "OptionIgnoreTranscodeByteRangeRequestsHelp": "Se abilitata, queste richieste saranno onorate, ma ignorano l'intervallo di byte.", + "OptionIgnoreTranscodeByteRangeRequestsHelp": "Queste richieste saranno onorate, ma ignoreranno l'intervallo di byte.", "OptionImdbRating": "Voto IMDB", "OptionLikes": "Mi piace", "OptionMissingEpisode": "Episodi mancanti", @@ -943,9 +943,9 @@ "OptionOnInterval": "Su intervallo", "OptionParentalRating": "Classificazione per genitori", "OptionPlainStorageFolders": "Visualizzare tutte le cartelle come normali cartelle di archiviazione", - "OptionPlainStorageFoldersHelp": "Se abilitato, tutte le cartelle sono rappresentate in DIDL come \"object.container.storageFolder\" invece che di tipo più specifico, come \"object.container.person.musicArtist\".", + "OptionPlainStorageFoldersHelp": "Tutte le cartelle sono rappresentate in DIDL come \"object.container.storageFolder\" invece che di tipo più specifico, come \"object.container.person.musicArtist\".", "OptionPlainVideoItems": "Mostra tutti i video come normali file video", - "OptionPlainVideoItemsHelp": "Se attivato, tutti i video sono rappresentati in DIDL come \"object.item.videoItem\" invece che di tipo più specifico, come \"object.item.videoItem.movie\".", + "OptionPlainVideoItemsHelp": "Tutti i video sono rappresentati in DIDL come \"object.item.videoItem\" invece che di tipo più specifico, come \"object.item.videoItem.movie\".", "OptionPlayCount": "Riproduzioni", "OptionPlayed": "Visto", "OptionPremiereDate": "Data della prima", @@ -959,7 +959,7 @@ "OptionResumable": "Interrotto", "OptionRuntime": "Durata", "OptionSaveMetadataAsHidden": "Salvare i metadati e le immagini come file nascosti", - "OptionSaveMetadataAsHiddenHelp": "La modifica di questo si applicherà ai nuovi metadati che verranno salvati in avanti. I file di metadati esistenti verranno aggiornati la prossima volta che vengono salvati da Jellyfin Server.", + "OptionSaveMetadataAsHiddenHelp": "La modifica di questo si applicherà ai nuovi metadati che verranno salvati in avanti. I file di metadati esistenti verranno aggiornati la prossima volta che verranno salvati dal server.", "OptionSpecialEpisode": "Speciali", "OptionSubstring": "Sottostringa", "OptionTrackName": "Titolo Traccia", @@ -998,9 +998,9 @@ "PleaseAddAtLeastOneFolder": "Per favore aggiungi almeno una cartella alla raccolta cliccando sul pulsante Aggiungi.", "PleaseConfirmPluginInstallation": "Per favore premi OK per confermare che hai letto quanto precede e che vuoi procedere all'installazione del plug-in.", "PleaseEnterNameOrId": "Per favore inserisci un nome o un ID esterno.", - "PleaseRestartServerName": "Per favore riavvia Jellyfin Server - {0}.", + "PleaseRestartServerName": "Per favore riavvia Jellyfin su {0}.", "PleaseSelectTwoItems": "Seleziona almeno due elementi.", - "MessagePluginInstalled": "Il plugin è stato installato correttamente. Il server Jellyfin dovrà essere riavviato affinché le modifiche abbiano effetto.", + "MessagePluginInstalled": "Il plugin è stato installato correttamente. Il server dovrà essere riavviato affinché le modifiche abbiano effetto.", "PreferEmbeddedTitlesOverFileNames": "Preferisci titoli integrati ai nomi dei file", "PreferEmbeddedTitlesOverFileNamesHelp": "Determina il titolo predefinito usato quando non sono disponibili metadati locali o da Internet.", "Premiere": "Prima visione", @@ -1025,7 +1025,7 @@ "RecordingScheduled": "Registrazione pianificata.", "Recordings": "Registrazioni", "Refresh": "Aggiorna", - "RefreshDialogHelp": "I Metadati sono aggiornati in base alle impostazioni ed ai servizi Internet abilitati nel Pannello di Controllo del Server Jellyfin.", + "RefreshDialogHelp": "I Metadati sono aggiornati in base alle impostazioni ed ai servizi Internet abilitati nel Pannello di Controllo.", "RefreshMetadata": "Aggiorna metadati", "RefreshQueued": "Aggiornamento programmato.", "ReleaseDate": "Data di uscita", @@ -1063,10 +1063,10 @@ "SeriesRecordingScheduled": "Registrazione serie TV pianificata.", "SeriesSettings": "Impostazioni Serie TV", "SeriesYearToPresent": "{0} - Oggi", - "ServerNameIsRestarting": "Jellyfin Server - {0} si sta riavviando.", - "ServerNameIsShuttingDown": "Jellyfin Server - {0} si sta arrestando.", - "ServerRestartNeededAfterPluginInstall": "Il server Jellyfin dovrà essere riavviato dopo l'installazione di un plugin.", - "ServerUpdateNeeded": "Questo server Jellyfin deve essere aggiornato. Per scaricare l'ultima versione vai su {0}", + "ServerNameIsRestarting": "Il Server su {0} si sta riavviando.", + "ServerNameIsShuttingDown": "Il Server su {0} si sta arrestando.", + "ServerRestartNeededAfterPluginInstall": "Jellyfin dovrà essere riavviato dopo l'installazione di un plugin.", + "ServerUpdateNeeded": "Questo server deve essere aggiornato. Per scaricare l'ultima versione vai su {0}", "Settings": "Impostazioni", "SettingsSaved": "Settaggi salvati.", "SettingsWarning": "La modifica di questi valori può causare problemi di instabilità o di connettività. Se si verificano problemi, si consiglia di modificarli all'impostazione predefinita.", @@ -1262,7 +1262,7 @@ "OptionProtocolHls": "Streaming in Diretta HTTP", "OptionDownloadArtImage": "Art", "OptionMax": "Massimo", - "PasswordResetProviderHelp": "Scegli un Provider Reset Password da utilizzare quando questo utente ne richiede il reset", + "PasswordResetProviderHelp": "Scegli un provider di reset password da utilizzare quando questo utente ne richiederà il reset.", "PlaybackData": "Dati di Riproduzione", "TagsValue": "Tag: {0}", "Whitelist": "Lista bianca", @@ -1383,7 +1383,7 @@ "LastSeen": "Visto l'ultima volta {0}", "PersonRole": "nel ruolo di {0}", "ListPaging": "{0}-{1} di {2}", - "WriteAccessRequired": "Jellyfin Server richiede il permesso di scrittura su questa cartella. Verificare l'autorizzazione e riprovare.", + "WriteAccessRequired": "Jellyfin richiede il permesso di scrittura su questa cartella. Verificare l'autorizzazione e riprovare.", "PathNotFound": "Percorso non trovato. Assicurarsi che sia valido e riprovare.", "YadifBob": "YADIF Bob", "Yadif": "YADIF", @@ -1444,7 +1444,7 @@ "HeaderSyncPlaySelectGroup": "Unisciti a un gruppo", "EnableDetailsBannerHelp": "Mostra il banner nella parte superiore della pagina di dettaglio dell'elemento.", "EnableDetailsBanner": "Banner Dettagli", - "EnableBlurHashHelp": "Le immagini ancora da caricare saranno mostrate inizialmente sfocate", + "EnableBlurHashHelp": "Le immagini ancora da caricare saranno mostrate inizialmente sfocate.", "EnableBlurHash": "Abilita i segnaposto sfocati per le immagini", "ShowMore": "Mostra di più", "ShowLess": "Mostra meno", @@ -1469,5 +1469,10 @@ "ClearQueue": "Svuota la coda", "StopPlayback": "Interrompi riproduzione", "LabelUnstable": "Unstable", - "NextTrack": "Prossima traccia" + "NextTrack": "Prossima traccia", + "Preview": "Anteprima", + "LabelSubtitleVerticalPosition": "Posizione verticale:", + "PreviousTrack": "Traccia precedente", + "MessageGetInstalledPluginsError": "Errore durante la generazione della lista dei plugin installati.", + "MessagePluginInstallError": "Errore durante l'installazione del plugin." } From 5bf7fa6117bbbbc294f93399caf55c39600c113e Mon Sep 17 00:00:00 2001 From: welpher Date: Tue, 18 Aug 2020 18:06:40 +0800 Subject: [PATCH 292/301] Update zh-cn.json MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit collection prefer 集合 --- src/strings/zh-cn.json | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/src/strings/zh-cn.json b/src/strings/zh-cn.json index 8fe4e14565..5ea0a6a4b0 100644 --- a/src/strings/zh-cn.json +++ b/src/strings/zh-cn.json @@ -231,7 +231,7 @@ "HeaderActiveRecordings": "正在录制的节目", "HeaderActivity": "活动", "HeaderAddScheduledTaskTrigger": "添加触发", - "HeaderAddToCollection": "加入收藏", + "HeaderAddToCollection": "加入集合", "HeaderAddToPlaylist": "添加到播放列表", "HeaderAddUpdateImage": "添加/更新 图片", "HeaderAddUser": "添加用户", @@ -458,7 +458,7 @@ "LabelCertificatePassword": "证书密码:", "LabelCertificatePasswordHelp": "如果你的证书需要密码,请在此输入它。", "LabelChannels": "频道:", - "LabelCollection": "收藏:", + "LabelCollection": "集合:", "LabelCommunityRating": "公众评分:", "LabelContentType": "内容类型:", "LabelCorruptedFrames": "损坏的帧:", @@ -532,8 +532,8 @@ "LabelFormat": "格式:", "LabelFriendlyName": "好记的名称:", "LabelServerNameHelp": "此名称将用做服务器名,默认使用服务器的主机名。", - "LabelGroupMoviesIntoCollections": "批量添加电影到收藏", - "LabelGroupMoviesIntoCollectionsHelp": "显示电影列表时,同一收藏的电影将显示为一个分组。", + "LabelGroupMoviesIntoCollections": "批量添加电影到集合", + "LabelGroupMoviesIntoCollectionsHelp": "显示电影列表时,同一集合的电影将显示为一个分组。", "LabelH264Crf": "H264 CRF 编码质量等级:", "LabelEncoderPreset": "H264 和 H265 编码预设:", "LabelHardwareAccelerationType": "硬件加速:", @@ -846,7 +846,7 @@ "MySubtitles": "我的字幕", "Name": "名称", "Never": "从不", - "NewCollection": "新收藏", + "NewCollection": "新集合", "NewCollectionHelp": "“收藏”允许你为电影和其他媒体库内容创建个性化分组。", "NewCollectionNameExample": "例如:星球大战收藏", "NewEpisodes": "新剧集", @@ -1053,7 +1053,7 @@ "RefreshQueued": "列队已刷新。", "ReleaseDate": "发行日期", "RememberMe": "记住我", - "RemoveFromCollection": "从收藏中移除", + "RemoveFromCollection": "从集合中移除", "RemoveFromPlaylist": "从播放列表中移除", "Repeat": "重播", "RepeatAll": "全部循环", From ac9177bd9e3ec85a1e4faa7d515025e463795c92 Mon Sep 17 00:00:00 2001 From: Hilman Maulana Date: Tue, 18 Aug 2020 10:29:21 +0000 Subject: [PATCH 293/301] Translated using Weblate (Indonesian) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/id/ --- src/strings/id.json | 94 ++++++++++++++++++++++++++++++++++++++++----- 1 file changed, 84 insertions(+), 10 deletions(-) diff --git a/src/strings/id.json b/src/strings/id.json index 8bf0d7eafd..006e0cd06e 100644 --- a/src/strings/id.json +++ b/src/strings/id.json @@ -39,7 +39,7 @@ "HeaderFavoriteEpisodes": "Episode Favorit", "HeaderFavoriteShows": "Tayangan Favorit", "HeaderAlbumArtists": "Album Artis", - "HeaderContinueWatching": "Masih Melihat", + "HeaderContinueWatching": "Lanjutkan Menonton", "Artists": "Artis", "AllowMediaConversion": "Izinkan konversi media", "AllEpisodes": "Semua episode", @@ -65,7 +65,7 @@ "ConfirmDeleteItems": "Penghapusan item-item ini akan menghapus baik pada sistem berkas maupun pustaka media Anda. Apakah Anda yakin untuk melanjutkan?", "ConfirmDeleteItem": "Penghapusan item ini akan menghapus baik pada sistem berkas maupun pustaka media Anda. Apakah Anda yakin untuk melanjutkan?", "ConfirmDeleteImage": "Hapus gambar?", - "ConfigureDateAdded": "Atur cara penentuan penambahan tanggal dalam dasbor Peladen Jellyfin lewat pengaturan Pustaka", + "ConfigureDateAdded": "Konfigurasikan bagaimana tanggal ditambahkan ditentukan di dasbor di bawah pengaturan pustaka", "Composer": "Komposer", "CommunityRating": "Peringkat komunitas", "ChannelNumber": "Nomor saluran", @@ -128,7 +128,7 @@ "Browse": "Jelajah", "BoxRear": "Kotak (belakang)", "Box": "Kotak", - "BookLibraryHelp": "Buku audio dan teks didukung. Perhatikan {0}panduan penamaan buku{1}.", + "BookLibraryHelp": "Audio dan buku teks didukung. Tinjau {0} panduan penamaan buku {1}.", "Blacklist": "Daftar hitam", "BirthPlaceValue": "Tempat lahir: {0}", "BirthLocation": "Tempat lahir", @@ -137,25 +137,25 @@ "Backdrops": "Latar belakang", "Backdrop": "Latar belakang", "Auto": "Auto", - "AuthProviderHelp": "Pilih Penyedia Autentikasi yang akan digunakan untuk mengautentikasi kata sandi pengguna ini.", + "AuthProviderHelp": "Pilih penyedia otentikasi yang akan digunakan untuk mengautentikasi kata sandi pengguna ini.", "Audio": "Audio", "AspectRatio": "Rasio perbandingan", "Ascending": "Urutan naik", "AsManyAsPossible": "Sebanyak mungkin", "Art": "Seni", - "AroundTime": "Sekitar {0}", + "AroundTime": "Sekitar", "Anytime": "Kapanpun", "AnyLanguage": "Bahasa apapun", "AlwaysPlaySubtitlesHelp": "Talop yang cocok dengan preferensi bahasa akan dimuat tanpa memperhatikan bahasa suaranya.", - "AlwaysPlaySubtitles": "Selalu putar talop", + "AlwaysPlaySubtitles": "Selalu Mainkan", "AllowedRemoteAddressesHelp": "Daftar yang dipisahkan dengan koma dari alamat IP atau catatan netmask untuk jaringan yang akan diperbolehkan untuk tersambuh dari jarak jauh. Jika dibiarkan kosong, seluruh alamat jarak jauh akan diperbolehkan.", "AllowRemoteAccessHelp": "Jika centang dihapus, semua koneksi jarak jauh akan diblokir.", - "AllowRemoteAccess": "Izinkan koneksi jarak jauh ke Peladen Jellyfin ini.", + "AllowRemoteAccess": "Izinkan koneksi jarak jauh ke server ini.", "AllowOnTheFlySubtitleExtraction": "Izinkan ekstraksi talop dengan cepat", "AllowMediaConversionHelp": "Izinkan atau tolak akses ke fitur konversi media.", "AllLibraries": "Semua pustaka", "AllLanguages": "Semua bahasa", - "AllComplexFormats": "Semua format kompleks (ASS, SSA, VOBSUB, PGS, SUB/IDK, dll.)", + "AllComplexFormats": "Semua Format Kompleks (ASS, SSA, VOBSUB, PGS, SUB, IDX,…)", "Channels": "Saluran", "Aired": "Disiarkan", "AirDate": "Tanggal siaran", @@ -175,6 +175,80 @@ "Alerts": "Peringatan", "AddedOnValue": "Ditambahkan {0}", "AllowFfmpegThrottling": "Transcode Tercekik", - "AllowOnTheFlySubtitleExtractionHelp": "Subtitle yang melekat di video dapat dikeluarkan dan dikirimkan kepada klien dalam bentuk text biasa dengan tujuan untuk menghalau terjadinya transcoding pada video. Pada beberapa system ini membutuhkan waktu yang lama dan dapat menyebabkan video playback menjadi terhenti dikarenakan proses ekstraksi. Non-aktifkan fitur ini untuk membiarkan subtitle langsung dilekatkan kepada video dengan cara transcoding ketika klien tidak mendukung fitur ini.", - "ButtonSyncPlay": "SyncPlay" + "AllowOnTheFlySubtitleExtractionHelp": "Subtitel yang disematkan dapat diekstrak dari video dan dikirim ke klien dalam teks biasa, untuk membantu mencegah transcoding video. Pada beberapa sistem, ini dapat memakan waktu lama dan menyebabkan pemutaran video terhenti selama proses ekstraksi. Nonaktifkan ini untuk menyematkan subtitle yang disematkan dengan transcoding video ketika mereka tidak didukung secara native oleh perangkat klien.", + "ButtonSyncPlay": "SyncPlay", + "EnablePhotosHelp": "Gambar akan terdeteksi dan ditampilkan bersama file media lainnya.", + "EnablePhotos": "Tampilkan foto", + "EnableNextVideoInfoOverlayHelp": "Di akhir video, tampilkan info tentang video berikutnya yang akan muncul di daftar putar saat ini.", + "EnableNextVideoInfoOverlay": "Tampilkan info video berikutnya selama pemutaran", + "EnableHardwareEncoding": "Aktifkan pengkodean perangkat keras", + "EnableExternalVideoPlayersHelp": "Menu pemutar eksternal akan ditampilkan saat memulai pemutaran video.", + "EnableExternalVideoPlayers": "Pemutar video eksternal", + "EnableDisplayMirroring": "Tampilan mirroring", + "EnableDecodingColorDepth10Vp9": "Aktifkan 10-Bit decoding hardware untuk VP9", + "EnableDecodingColorDepth10Hevc": "Aktifkan 10-Bit decoding hardware untuk HEVC", + "EnableColorCodedBackgrounds": "Latar belakang berkode warna", + "EnableCinemaMode": "Mode bioskop", + "EnableBackdropsHelp": "Menampilkan latar belakang di latar belakang beberapa halaman saat menjelajahi pustaka.", + "EditSubtitles": "Edit subtitle", + "EditMetadata": "Edit metadata", + "EditImages": "Edit Gambar", + "Edit": "Edit", + "EasyPasswordHelp": "Kode pin mudah Anda digunakan untuk akses offline di klien yang didukung dan juga dapat digunakan untuk masuk ke jaringan dengan mudah.", + "DropShadow": "Drop Shadow", + "DrmChannelsNotImported": "Saluran dengan DRM tidak akan diimpor.", + "DownloadsValue": "{0} unduhan", + "Download": "Unduh", + "Down": "Turun", + "DoNotRecord": "Jangan merekam", + "DisplayModeHelp": "Pilih gaya tata letak yang Anda inginkan untuk antarmuka.", + "DisplayMissingEpisodesWithinSeasonsHelp": "Ini juga harus diaktifkan untuk pustaka TV di konfigurasi server.", + "DisplayMissingEpisodesWithinSeasons": "Tampilkan episode yang hilang dalam season", + "DisplayInOtherHomeScreenSections": "Tayangkan di bagian layar beranda seperti media terbaru dan lanjutkan menonton", + "Display": "Tampilan", + "DisplayInMyMedia": "Tampilan di layar beranda", + "Dislike": "Benci", + "Disconnect": "Memutuskan", + "Disc": "CD", + "Disabled": "Matikan", + "DirectPlaying": "Bermain langsung", + "DirectStreaming": "Streaming langsung", + "DirectStreamHelp2": "Streaming langsung menggunakan daya pemrosesan yang sangat sedikit dengan penurunan kualitas video yang minimal.", + "DirectStreamHelp1": "Media kompatibel dengan perangkat terkait resolusi dan jenis media (H.264, AC3, dll), tetapi dalam wadah file yang tidak kompatibel (mkv, avi, wmv, dll). Video akan dikemas ulang dengan cepat sebelum dikirim ke perangkat.", + "DeviceAccessHelp": "Ini hanya berlaku untuk perangkat yang dapat diidentifikasi secara unik dan tidak akan mencegah akses browser. Memfilter akses perangkat pengguna akan mencegah mereka menggunakan perangkat baru hingga disetujui di sini.", + "DetectingDevices": "Mendeteksi perangkat", + "Desktop": "Desktop", + "Descending": "Menurun", + "DeleteUserConfirmation": "Apakah Anda yakin ingin menghapus pengguna ini?", + "DeleteUser": "Hapus pengguna", + "DeleteMedia": "Hapus media", + "DeleteImageConfirmation": "Anda yakin ingin menghapus gambar ini?", + "DeleteImage": "Hapus Gambar", + "DeleteDeviceConfirmation": "Anda yakin ingin menghapus perangkat ini? Ini akan muncul kembali saat pengguna login lagi.", + "DeinterlaceMethodHelp": "Pilih metode deinterlacing yang akan digunakan saat melakukan transcoding konten interlace.", + "DefaultSubtitlesHelp": "Subtitel dimuat berdasarkan bendera default dan paksa dalam metadata yang disematkan. Preferensi bahasa dipertimbangkan ketika beberapa opsi tersedia.", + "CustomDlnaProfilesHelp": "Buat profil khusus untuk menargetkan perangkat baru atau mengganti profil sistem.", + "ColorTransfer": "Transfer warna", + "ColorSpace": "Ruang warna", + "ColorPrimaries": "Warna primer", + "ClientSettings": "Pengaturan Klien", + "CinemaModeConfigurationHelp": "Mode bioskop menghadirkan pengalaman teater langsung ke ruang tamu Anda dengan kemampuan untuk memutar trailer dan pengantar khusus sebelum fitur utama.", + "ChangingMetadataImageSettingsNewContent": "Perubahan pada metadata atau setelan pengunduhan karya seni hanya akan berlaku untuk konten baru yang ditambahkan ke perpustakaan Anda. Untuk menerapkan perubahan pada judul yang ada, Anda perlu menyegarkan metadatanya secara manual.", + "CancelSeries": "Batalkan serial", + "ButtonUninstall": "Copot pemasangan", + "ButtonTogglePlaylist": "Daftar Putar", + "ButtonSubtitles": "Subtitle", + "ButtonSplit": "Membagi", + "ButtonRestart": "Muat ulang", + "ButtonPreviousTrack": "Lagu sebelumnya", + "ButtonNextTrack": "Lagu berikutnya", + "ButtonManualLogin": "Login Manual", + "BurnSubtitlesHelp": "Menentukan apakah server harus membakar subtitle saat melakukan transcoding video. Menghindari ini akan sangat meningkatkan kinerja. Pilih Otomatis untuk membakar format berbasis gambar (VOBSUB, PGS, SUB, IDX,…) dan subtitle ASS atau SSA tertentu.", + "BoxSet": "Set Kotak", + "AskAdminToCreateLibrary": "Minta administrator untuk membuat pustaka.", + "Artist": "Artis", + "AllowFfmpegThrottlingHelp": "Saat transcode atau remux cukup jauh dari posisi pemutaran saat ini, jeda prosesnya sehingga akan mengkonsumsi lebih sedikit sumber daya. Ini paling berguna saat menonton tanpa sering mencari. Matikan ini jika Anda mengalami masalah pemutaran.", + "AllowHWTranscodingHelp": "Izinkan tuner untuk mentranskode aliran dengan cepat. Ini dapat membantu mengurangi transcoding yang dibutuhkan oleh server.", + "AlbumArtist": "Album Artis", + "Album": "Album" } From ffe71f31b7ec58bc1cd9c103ec3a0164179f7294 Mon Sep 17 00:00:00 2001 From: Oatavandi Date: Tue, 18 Aug 2020 12:12:26 +0000 Subject: [PATCH 294/301] Translated using Weblate (Tamil) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/ta/ --- src/strings/ta.json | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/src/strings/ta.json b/src/strings/ta.json index d31fb8872e..faeccab647 100644 --- a/src/strings/ta.json +++ b/src/strings/ta.json @@ -1489,5 +1489,6 @@ "LastSeen": "கடைசியாக பார்த்தது {0}", "PersonRole": "{0} என", "ListPaging": "{0} - {2} இன் {1}", - "WriteAccessRequired": "ஜெல்லிஃபினுக்கு இந்த கோப்புறையில் எழுத அணுகல் தேவை. எழுதும் அணுகலை உறுதிசெய்து மீண்டும் முயற்சிக்கவும்." + "WriteAccessRequired": "ஜெல்லிஃபினுக்கு இந்த கோப்புறையில் எழுத அணுகல் தேவை. எழுதும் அணுகலை உறுதிசெய்து மீண்டும் முயற்சிக்கவும்.", + "PlaybackRate": "பின்னணி வீதம்" } From e673a27d912860704f2f759bbcec36961bd6afd3 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marcin=20Woli=C5=84ski?= Date: Tue, 18 Aug 2020 20:12:09 +0000 Subject: [PATCH 295/301] Translated using Weblate (Polish) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/pl/ --- src/strings/pl.json | 11 ++++++----- 1 file changed, 6 insertions(+), 5 deletions(-) diff --git a/src/strings/pl.json b/src/strings/pl.json index cb23cf40e6..3e896ce232 100644 --- a/src/strings/pl.json +++ b/src/strings/pl.json @@ -124,7 +124,7 @@ "ColorTransfer": "Transfer kolorów", "CommunityRating": "Ocena społeczności", "Composer": "Kompozytor", - "ConfigureDateAdded": "Skonfiguruj sposób określania dodanej daty na pulpicie nawigacyjnym w ustawieniach biblioteki.", + "ConfigureDateAdded": "Skonfiguruj sposób określania dodanej daty na pulpicie nawigacyjnym w ustawieniach biblioteki", "ConfirmDeleteImage": "Usunąć obraz?", "ConfirmDeleteItem": "Usunięcie tej pozycji usunie ją zarówno z systemu plików jak i z biblioteki mediów. Czy chcesz kontynuować?", "ConfirmDeleteItems": "Usunięcie tej pozycji usunie ją zarówno z systemu plików jak i z biblioteki mediów. Czy chcesz kontynuować?", @@ -477,7 +477,7 @@ "LabelAppName": "Nazwa Aplikacji", "LabelAppNameExample": "Przykład: Sickbeard, Sonarr", "LabelArtists": "Wykonawcy:", - "LabelArtistsHelp": "Oddziel wielu artystów średnikiem \";\"", + "LabelArtistsHelp": "Oddziel wielu artystów średnikiem \";\".", "LabelAudio": "Dźwięk", "LabelAudioLanguagePreference": "Preferowany język ścieżki dźwiękowej:", "LabelAutomaticallyRefreshInternetMetadataEvery": "Odświeżaj automatycznie metadane z Internetu:", @@ -832,7 +832,7 @@ "MessageConfirmRecordingCancellation": "Anulować nagranie?", "MessageConfirmRemoveMediaLocation": "Czy na pewno chcesz usunąć tę lokalizację?", "MessageConfirmRestart": "Czy na pewno chcesz uruchomić Jellyfin ponownie?", - "MessageConfirmRevokeApiKey": "Czy na pewno chcesz unieważnić kluczAPI? Połączenia aplikacji z serwerem zostaną natychmiastowo zakończone.", + "MessageConfirmRevokeApiKey": "Czy na pewno chcesz unieważnić klucz API? Połączenia aplikacji z serwerem zostaną natychmiastowo zakończone.", "MessageConfirmShutdown": "Czy na pewno chcesz zamknąć serwer?", "MessageContactAdminToResetPassword": "W celu wyczyszczenia hasła. skontaktuj się z administratorem systemu.", "MessageCreateAccountAt": "Utwórz konto na {0}", @@ -1383,7 +1383,7 @@ "StopPlayback": "Zatrzymaj odtwarzanie", "ButtonPlayer": "Odtwarzacz", "ButtonCast": "Obsada", - "EnableBlurHashHelp": "Obrazy które wciąż się ładują zostaną zastąpione rozmazanym symbolem", + "EnableBlurHashHelp": "Obrazy które wciąż się ładują zostaną zastąpione rozmazanym symbolem.", "EnableBlurHash": "Włącz rozmazane zamienniki dla obrazów", "UnsupportedPlayback": "Jellyfin nie może odszyfrować zawartości zabezpieczonej przy pomocy DRM, ale spróbuje pomimo tego. Niektóre pliki mogą pojawiać się jako zupełnie czarne z powodu szyfrowania lub innych nie wspieranych funkcji jak np. interaktywne tytuły.", "OnApplicationStartup": "Przy starcie aplikacji", @@ -1475,5 +1475,6 @@ "SubtitleVerticalPositionHelp": "Numer wiersza, w którym pojawia się tekst. Liczby dodatnie wskazują z góry na dół. Liczby ujemne wskazują od dołu do góry.", "LabelSubtitleVerticalPosition": "Pozycja pionowa:", "MessageGetInstalledPluginsError": "Wystąpił błąd podczas pobierania listy aktualnie zainstalowanych wtyczek.", - "MessagePluginInstallError": "Wystąpił błąd podczas instalacji wtyczki." + "MessagePluginInstallError": "Wystąpił błąd podczas instalacji wtyczki.", + "PlaybackRate": "Szybkość odtwarzania" } From 468f8601b933705c6a19ae1d3ae567e0cc77d849 Mon Sep 17 00:00:00 2001 From: nextlooper42 Date: Tue, 18 Aug 2020 21:13:57 +0000 Subject: [PATCH 296/301] Translated using Weblate (Slovak) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/sk/ --- src/strings/sk.json | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/src/strings/sk.json b/src/strings/sk.json index 7aef8eb515..4df5f1a07d 100644 --- a/src/strings/sk.json +++ b/src/strings/sk.json @@ -1475,5 +1475,6 @@ "MessageGetInstalledPluginsError": "Pri načítaní zoznamu nainštalovaných zásuvných modulov došlo k chybe.", "MessagePluginInstallError": "Pri inštalácií zásuvného modulu došlo k chybe.", "NextTrack": "Ďalšia", - "LabelUnstable": "Nestabilný" + "LabelUnstable": "Nestabilný", + "PlaybackRate": "Rýchlosť prehrávania" } From bfb1ef1673a8e1da7f8e78a1396bb16022d7298c Mon Sep 17 00:00:00 2001 From: NunzioArdi Date: Wed, 19 Aug 2020 10:20:14 +0000 Subject: [PATCH 297/301] Translated using Weblate (French) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/fr/ --- src/strings/fr.json | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/src/strings/fr.json b/src/strings/fr.json index 4bab5a6179..f6037770be 100644 --- a/src/strings/fr.json +++ b/src/strings/fr.json @@ -1475,5 +1475,6 @@ "SubtitleVerticalPositionHelp": "Numéro de ligne où le texte apparaît. Un nombre positif compte les lignes de haut en bas. Un nombre négatif, de bas en haut.", "LabelSubtitleVerticalPosition": "Position verticale :", "MessageGetInstalledPluginsError": "Une erreur est survenue lors de la récupération de la liste des extensions installées.", - "MessagePluginInstallError": "Une erreur est survenue durant l'installation de l'extension." + "MessagePluginInstallError": "Une erreur est survenue durant l'installation de l'extension.", + "PlaybackRate": "Vitesse de lecture" } From 009a6d48c5a6ee7afe29050fb6b385b8747a7174 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Pedro=20Dur=C3=A1n?= Date: Wed, 19 Aug 2020 08:28:39 +0000 Subject: [PATCH 298/301] Translated using Weblate (Spanish) Translation: Jellyfin/Jellyfin Web Translate-URL: https://translate.jellyfin.org/projects/jellyfin/jellyfin-web/es/ --- src/strings/es.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/strings/es.json b/src/strings/es.json index 09e5f5fcf4..69c19d8dce 100644 --- a/src/strings/es.json +++ b/src/strings/es.json @@ -451,7 +451,7 @@ "LabelDay": "Día:", "LabelDeathDate": "Fecha de muerte:", "LabelDefaultUser": "Usuario por defecto:", - "LabelDefaultUserHelp": "Determina de qúe usuario se utilizará su biblioteca de medios para mostrarla por defecto en los dipositivos conectados. Esto puede cambiarse para cada dispositivo mediante el uso de perfiles.", + "LabelDefaultUserHelp": "Determina de qué usuario se utilizará su biblioteca de medios para mostrarla por defecto en los dipositivos conectados. Esto puede cambiarse para cada dispositivo mediante el uso de perfiles.", "LabelDeviceDescription": "Descripción del dispositivo", "LabelDidlMode": "Modo DIDL:", "LabelDiscNumber": "Número de disco:", From 5e1d4edd87cd4c0fbd42af0c1a6bdbcfba7698a5 Mon Sep 17 00:00:00 2001 From: Bill Thornton Date: Wed, 19 Aug 2020 13:02:09 -0400 Subject: [PATCH 299/301] Set background color on blurhash image load --- src/components/images/imageLoader.js | 2 ++ 1 file changed, 2 insertions(+) diff --git a/src/components/images/imageLoader.js b/src/components/images/imageLoader.js index 39dc6c2622..3dc91ffa91 100644 --- a/src/components/images/imageLoader.js +++ b/src/components/images/imageLoader.js @@ -87,6 +87,7 @@ import 'css!./style'; requestAnimationFrame(() => { if (elem.tagName !== 'IMG') { elem.style.backgroundImage = "url('" + url + "')"; + elem.style.backgroundColor = '#fff'; } else { elem.setAttribute('src', url); } @@ -108,6 +109,7 @@ import 'css!./style'; if (elem.tagName !== 'IMG') { url = elem.style.backgroundImage.slice(4, -1).replace(/"/g, ''); elem.style.backgroundImage = 'none'; + elem.style.backgroundColor = null; } else { url = elem.getAttribute('src'); elem.setAttribute('src', ''); From e5198a6328d9880e30776fcb72af3d6a09a8872e Mon Sep 17 00:00:00 2001 From: Bill Thornton Date: Wed, 19 Aug 2020 13:36:29 -0400 Subject: [PATCH 300/301] Skip adding background color for non-blurhashable items --- src/components/images/imageLoader.js | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/src/components/images/imageLoader.js b/src/components/images/imageLoader.js index 3dc91ffa91..17ec55d7ac 100644 --- a/src/components/images/imageLoader.js +++ b/src/components/images/imageLoader.js @@ -87,7 +87,9 @@ import 'css!./style'; requestAnimationFrame(() => { if (elem.tagName !== 'IMG') { elem.style.backgroundImage = "url('" + url + "')"; - elem.style.backgroundColor = '#fff'; + if (!elem.classList.contains('non-blurhashable')) { + elem.style.backgroundColor = '#fff'; + } } else { elem.setAttribute('src', url); } From f4a329433efe9c0cca5bd0b694cc586386620566 Mon Sep 17 00:00:00 2001 From: Bill Thornton Date: Wed, 19 Aug 2020 13:47:16 -0400 Subject: [PATCH 301/301] Only add background color to blurhashed items --- src/components/images/imageLoader.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/components/images/imageLoader.js b/src/components/images/imageLoader.js index 17ec55d7ac..b0ffecd64f 100644 --- a/src/components/images/imageLoader.js +++ b/src/components/images/imageLoader.js @@ -87,7 +87,7 @@ import 'css!./style'; requestAnimationFrame(() => { if (elem.tagName !== 'IMG') { elem.style.backgroundImage = "url('" + url + "')"; - if (!elem.classList.contains('non-blurhashable')) { + if (elem.classList.contains('blurhashed')) { elem.style.backgroundColor = '#fff'; } } else {