mirror of
https://github.com/jellyfin/jellyfin-web
synced 2025-03-30 19:56:21 +00:00
147 lines
5.6 KiB
JavaScript
147 lines
5.6 KiB
JavaScript
/**
|
|
* Module that displays an editor for changing SyncPlay settings.
|
|
* @module components/syncPlay/settings/SettingsEditor
|
|
*/
|
|
|
|
import { Events } from 'jellyfin-apiclient';
|
|
import SyncPlay from '../../core';
|
|
import { getSetting, setSetting } from '../../core/Settings';
|
|
import dialogHelper from '../../../dialogHelper/dialogHelper';
|
|
import layoutManager from '../../../layoutManager';
|
|
import loading from '../../../loading/loading';
|
|
import toast from '../../../toast/toast';
|
|
import globalize from '../../../../scripts/globalize';
|
|
import { toBoolean, toFloat } from '../../../../scripts/stringUtils';
|
|
|
|
import 'material-design-icons-iconfont';
|
|
import '../../../../elements/emby-input/emby-input';
|
|
import '../../../../elements/emby-select/emby-select';
|
|
import '../../../../elements/emby-button/emby-button';
|
|
import '../../../../elements/emby-button/paper-icon-button-light';
|
|
import '../../../../elements/emby-checkbox/emby-checkbox';
|
|
import '../../../listview/listview.scss';
|
|
import '../../../formdialog.scss';
|
|
|
|
function centerFocus(elem, horiz, on) {
|
|
import('../../../../scripts/scrollHelper').then((scrollHelper) => {
|
|
const fn = on ? 'on' : 'off';
|
|
scrollHelper.centerFocus[fn](elem, horiz);
|
|
});
|
|
}
|
|
|
|
/**
|
|
* Class that displays an editor for changing SyncPlay settings.
|
|
*/
|
|
class SettingsEditor {
|
|
constructor(apiClient, timeSyncCore, options = {}) {
|
|
this.apiClient = apiClient;
|
|
this.timeSyncCore = timeSyncCore;
|
|
this.options = options;
|
|
}
|
|
|
|
async embed() {
|
|
const dialogOptions = {
|
|
removeOnClose: true,
|
|
scrollY: true
|
|
};
|
|
|
|
if (layoutManager.tv) {
|
|
dialogOptions.size = 'fullscreen';
|
|
} else {
|
|
dialogOptions.size = 'small';
|
|
}
|
|
|
|
this.context = dialogHelper.createDialog(dialogOptions);
|
|
this.context.classList.add('formDialog');
|
|
|
|
const { default: editorTemplate } = await import('./editor.html');
|
|
this.context.innerHTML = globalize.translateHtml(editorTemplate, 'core');
|
|
|
|
// Set callbacks for form submission
|
|
this.context.querySelector('form').addEventListener('submit', (event) => {
|
|
// Disable default form submission
|
|
if (event) {
|
|
event.preventDefault();
|
|
}
|
|
return false;
|
|
});
|
|
|
|
this.context.querySelector('.btnSave').addEventListener('click', () => {
|
|
this.onSubmit();
|
|
});
|
|
|
|
this.context.querySelector('.btnCancel').addEventListener('click', () => {
|
|
dialogHelper.close(this.context);
|
|
});
|
|
|
|
await this.initEditor();
|
|
|
|
if (layoutManager.tv) {
|
|
centerFocus(this.context.querySelector('.formDialogContent'), false, true);
|
|
}
|
|
|
|
return dialogHelper.open(this.context).then(() => {
|
|
if (layoutManager.tv) {
|
|
centerFocus(this.context.querySelector('.formDialogContent'), false, false);
|
|
}
|
|
|
|
if (this.context.submitted) {
|
|
return Promise.resolve();
|
|
}
|
|
|
|
return Promise.reject();
|
|
});
|
|
}
|
|
|
|
async initEditor() {
|
|
const { context } = this;
|
|
|
|
context.querySelector('#txtExtraTimeOffset').value = toFloat(getSetting('extraTimeOffset'), 0.0);
|
|
context.querySelector('#chkSyncCorrection').checked = toBoolean(getSetting('enableSyncCorrection'), true);
|
|
context.querySelector('#txtMinDelaySpeedToSync').value = toFloat(getSetting('minDelaySpeedToSync'), 60.0);
|
|
context.querySelector('#txtMaxDelaySpeedToSync').value = toFloat(getSetting('maxDelaySpeedToSync'), 3000.0);
|
|
context.querySelector('#txtSpeedToSyncDuration').value = toFloat(getSetting('speedToSyncDuration'), 1000.0);
|
|
context.querySelector('#txtMinDelaySkipToSync').value = toFloat(getSetting('minDelaySkipToSync'), 400.0);
|
|
context.querySelector('#chkSpeedToSync').checked = toBoolean(getSetting('useSpeedToSync'), true);
|
|
context.querySelector('#chkSkipToSync').checked = toBoolean(getSetting('useSkipToSync'), true);
|
|
}
|
|
|
|
onSubmit() {
|
|
this.save();
|
|
dialogHelper.close(this.context);
|
|
}
|
|
|
|
async save() {
|
|
loading.show();
|
|
await this.saveToAppSettings();
|
|
loading.hide();
|
|
toast(globalize.translate('SettingsSaved'));
|
|
Events.trigger(this, 'saved');
|
|
}
|
|
|
|
async saveToAppSettings() {
|
|
const { context } = this;
|
|
|
|
const extraTimeOffset = context.querySelector('#txtExtraTimeOffset').value;
|
|
const syncCorrection = context.querySelector('#chkSyncCorrection').checked;
|
|
const minDelaySpeedToSync = context.querySelector('#txtMinDelaySpeedToSync').value;
|
|
const maxDelaySpeedToSync = context.querySelector('#txtMaxDelaySpeedToSync').value;
|
|
const speedToSyncDuration = context.querySelector('#txtSpeedToSyncDuration').value;
|
|
const minDelaySkipToSync = context.querySelector('#txtMinDelaySkipToSync').value;
|
|
const useSpeedToSync = context.querySelector('#chkSpeedToSync').checked;
|
|
const useSkipToSync = context.querySelector('#chkSkipToSync').checked;
|
|
|
|
setSetting('extraTimeOffset', extraTimeOffset);
|
|
setSetting('enableSyncCorrection', syncCorrection);
|
|
setSetting('minDelaySpeedToSync', minDelaySpeedToSync);
|
|
setSetting('maxDelaySpeedToSync', maxDelaySpeedToSync);
|
|
setSetting('speedToSyncDuration', speedToSyncDuration);
|
|
setSetting('minDelaySkipToSync', minDelaySkipToSync);
|
|
setSetting('useSpeedToSync', useSpeedToSync);
|
|
setSetting('useSkipToSync', useSkipToSync);
|
|
|
|
Events.trigger(SyncPlay.Manager, 'settings-update');
|
|
}
|
|
}
|
|
|
|
export default SettingsEditor;
|