jellyfish-web/src/components/subtitlesettings/subtitlesettings.js

207 lines
7.7 KiB
JavaScript
Raw Normal View History

import globalize from 'globalize';
import appHost from 'apphost';
import appSettings from 'appSettings';
import focusManager from 'focusManager';
import loading from 'loading';
import connectionManager from 'connectionManager';
import subtitleAppearanceHelper from 'subtitleAppearanceHelper';
import settingsHelper from 'settingsHelper';
import dom from 'dom';
import events from 'events';
import 'listViewStyle';
import 'emby-select';
import 'emby-input';
import 'emby-checkbox';
import 'flexStyles';
/**
2020-06-28 16:36:00 +09:00
* Subtitle settings.
* @module components/subtitleSettings/subtitleSettings
*/
function getSubtitleAppearanceObject(context) {
2020-07-17 10:33:31 +02:00
const appearanceSettings = {};
appearanceSettings.textSize = context.querySelector('#selectTextSize').value;
appearanceSettings.dropShadow = context.querySelector('#selectDropShadow').value;
appearanceSettings.font = context.querySelector('#selectFont').value;
appearanceSettings.textBackground = context.querySelector('#inputTextBackground').value;
appearanceSettings.textColor = context.querySelector('#inputTextColor').value;
return appearanceSettings;
}
function loadForm(context, user, userSettings, appearanceSettings, apiClient) {
apiClient.getCultures().then(function (allCultures) {
if (appHost.supports('subtitleburnsettings') && user.Policy.EnableVideoPlaybackTranscoding) {
context.querySelector('.fldBurnIn').classList.remove('hide');
2018-10-23 01:05:09 +03:00
}
2020-07-17 10:33:31 +02:00
const selectSubtitleLanguage = context.querySelector('#selectSubtitleLanguage');
settingsHelper.populateLanguages(selectSubtitleLanguage, allCultures);
selectSubtitleLanguage.value = user.Configuration.SubtitleLanguagePreference || '';
context.querySelector('#selectSubtitlePlaybackMode').value = user.Configuration.SubtitleMode || '';
context.querySelector('#selectSubtitlePlaybackMode').dispatchEvent(new CustomEvent('change', {}));
context.querySelector('#selectTextSize').value = appearanceSettings.textSize || '';
context.querySelector('#selectDropShadow').value = appearanceSettings.dropShadow || '';
context.querySelector('#inputTextBackground').value = appearanceSettings.textBackground || 'transparent';
context.querySelector('#inputTextColor').value = appearanceSettings.textColor || '#ffffff';
context.querySelector('#selectFont').value = appearanceSettings.font || '';
context.querySelector('#selectSubtitleBurnIn').value = appSettings.get('subtitleburnin') || '';
onAppearanceFieldChange({
target: context.querySelector('#selectTextSize')
});
2018-10-23 01:05:09 +03:00
loading.hide();
});
}
function saveUser(context, user, userSettingsInstance, appearanceKey, apiClient) {
2020-06-28 16:36:00 +09:00
let appearanceSettings = userSettingsInstance.getSubtitleAppearanceSettings(appearanceKey);
appearanceSettings = Object.assign(appearanceSettings, getSubtitleAppearanceObject(context));
userSettingsInstance.setSubtitleAppearanceSettings(appearanceSettings, appearanceKey);
user.Configuration.SubtitleLanguagePreference = context.querySelector('#selectSubtitleLanguage').value;
user.Configuration.SubtitleMode = context.querySelector('#selectSubtitlePlaybackMode').value;
return apiClient.updateUserConfiguration(user.Id, user.Configuration);
}
function save(instance, context, userId, userSettings, apiClient, enableSaveConfirmation) {
loading.show();
appSettings.set('subtitleburnin', context.querySelector('#selectSubtitleBurnIn').value);
apiClient.getUser(userId).then(function (user) {
saveUser(context, user, userSettings, instance.appearanceKey, apiClient).then(function () {
loading.hide();
if (enableSaveConfirmation) {
2020-07-21 13:25:50 +01:00
import('toast').then(({default: toast}) => {
toast(globalize.translate('SettingsSaved'));
});
}
2018-10-23 01:05:09 +03:00
events.trigger(instance, 'saved');
}, function () {
loading.hide();
});
});
}
function onSubtitleModeChange(e) {
2020-07-17 10:33:31 +02:00
const view = dom.parentWithClass(e.target, 'subtitlesettings');
2020-07-17 10:33:31 +02:00
const subtitlesHelp = view.querySelectorAll('.subtitlesHelp');
for (let i = 0, length = subtitlesHelp.length; i < length; i++) {
subtitlesHelp[i].classList.add('hide');
2018-10-23 01:05:09 +03:00
}
view.querySelector('.subtitles' + this.value + 'Help').classList.remove('hide');
}
2018-10-23 01:05:09 +03:00
function onAppearanceFieldChange(e) {
2020-07-17 10:33:31 +02:00
const view = dom.parentWithClass(e.target, 'subtitlesettings');
2020-07-17 10:33:31 +02:00
const appearanceSettings = getSubtitleAppearanceObject(view);
2020-07-17 10:33:31 +02:00
const elements = {
2020-06-28 16:36:00 +09:00
window: view.querySelector('.subtitleappearance-preview-window'),
text: view.querySelector('.subtitleappearance-preview-text')
};
subtitleAppearanceHelper.applyStyles(elements, appearanceSettings);
}
2018-10-23 01:05:09 +03:00
function embed(options, self) {
2020-07-21 13:25:50 +01:00
import('text!./subtitlesettings.template.html').then(({default: template}) => {
options.element.classList.add('subtitlesettings');
2020-07-18 09:21:15 +01:00
options.element.innerHTML = globalize.translateHtml(template, 'core');
2020-06-12 16:37:11 +03:00
options.element.querySelector('form').addEventListener('submit', self.onSubmit.bind(self));
options.element.querySelector('#selectSubtitlePlaybackMode').addEventListener('change', onSubtitleModeChange);
options.element.querySelector('#selectTextSize').addEventListener('change', onAppearanceFieldChange);
options.element.querySelector('#selectDropShadow').addEventListener('change', onAppearanceFieldChange);
options.element.querySelector('#selectFont').addEventListener('change', onAppearanceFieldChange);
options.element.querySelector('#inputTextColor').addEventListener('change', onAppearanceFieldChange);
options.element.querySelector('#inputTextBackground').addEventListener('change', onAppearanceFieldChange);
if (options.enableSaveButton) {
options.element.querySelector('.btnSave').classList.remove('hide');
}
2020-07-19 17:38:42 +02:00
if (appHost.default.supports('subtitleappearancesettings')) {
options.element.querySelector('.subtitleAppearanceSection').classList.remove('hide');
}
self.loadData();
if (options.autoFocus) {
focusManager.autoFocus(options.element);
}
});
}
2018-10-23 01:05:09 +03:00
export class SubtitleSettings {
constructor(options) {
this.options = options;
embed(options, this);
}
loadData() {
2020-07-17 10:33:31 +02:00
const self = this;
const context = self.options.element;
loading.show();
2020-07-17 10:33:31 +02:00
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;
2020-07-17 10:33:31 +02:00
const appearanceSettings = userSettings.getSubtitleAppearanceSettings(self.options.appearanceKey);
loadForm(context, user, userSettings, appearanceSettings, apiClient);
});
});
}
submit() {
2020-06-28 16:36:00 +09:00
this.onSubmit(null);
}
destroy() {
this.options = null;
}
2020-06-28 16:36:00 +09:00
onSubmit(e) {
const self = this;
2020-07-17 10:33:31 +02:00
const apiClient = connectionManager.getApiClient(self.options.serverId);
const userId = self.options.userId;
const userSettings = self.options.userSettings;
userSettings.setUserInfo(userId, apiClient).then(function () {
2020-07-17 10:33:31 +02:00
const enableSaveConfirmation = self.options.enableSaveConfirmation;
save(self, self.options.element, userId, userSettings, apiClient, enableSaveConfirmation);
});
// Disable default form submission
if (e) {
e.preventDefault();
}
return false;
}
}
export default SubtitleSettings;