import ko from 'ko'; import { SaveSettingsStep, UploadErrorCode, Capa } from 'Common/Enums'; import { changeTheme, convertThemeName } from 'Common/Utils'; import { userBackground, themePreviewLink, serverRequest } from 'Common/Links'; import { i18n } from 'Common/Translator'; import { doc, $htmlCL, Settings } from 'Common/Globals'; import { ThemeStore } from 'Stores/Theme'; import Remote from 'Remote/User/Fetch'; export class ThemesUserSettings { constructor() { this.theme = ThemeStore.theme; this.themes = ThemeStore.themes; this.themesObjects = ko.observableArray(); this.background = {}; this.background.name = ThemeStore.userBackgroundName; this.background.hash = ThemeStore.userBackgroundHash; this.background.uploaderButton = ko.observable(null); this.background.loading = ko.observable(false); this.background.error = ko.observable(''); this.capaUserBackground = ko.observable(Settings.capa(Capa.UserBackground)); this.themeTrigger = ko.observable(SaveSettingsStep.Idle).extend({ debounce: 100 }); this.theme.subscribe((value) => { this.themesObjects.forEach(theme => { theme.selected(value === theme.name); }); changeTheme(value, this.themeTrigger); Remote.saveSettings(null, { Theme: value }); }); this.background.hash.subscribe((value) => { if (!value) { $htmlCL.remove('UserBackground'); doc.body.removeAttribute('style'); } else { $htmlCL.add('UserBackground'); doc.body.style.backgroundImage = "url("+userBackground(value)+")"; } }); } onBuild() { const currentTheme = this.theme(); this.themesObjects( this.themes.map(theme => ({ name: theme, nameDisplay: convertThemeName(theme), selected: ko.observable(theme === currentTheme), themePreviewSrc: themePreviewLink(theme) })) ); this.initUploader(); } onShow() { this.background.error(''); } clearBackground() { if (this.capaUserBackground()) { Remote.clearUserBackground(() => { this.background.name(''); this.background.hash(''); }); } } initUploader() { if (this.background.uploaderButton() && this.capaUserBackground()) { const oJua = new Jua({ action: serverRequest('UploadBackground'), name: 'uploader', queueSize: 1, multipleSizeLimit: 1, disableMultiple: true, clickElement: this.background.uploaderButton() }); oJua .on('onStart', () => { this.background.loading(true); this.background.error(''); return true; }) .on('onComplete', (id, result, data) => { this.background.loading(false); if (result && id && data && data.Result && data.Result.Name && data.Result.Hash) { this.background.name(data.Result.Name); this.background.hash(data.Result.Hash); } else { this.background.name(''); this.background.hash(''); let errorMsg = ''; if (data.ErrorCode) { switch (data.ErrorCode) { case UploadErrorCode.FileIsTooBig: errorMsg = i18n('SETTINGS_THEMES/ERROR_FILE_IS_TOO_BIG'); break; case UploadErrorCode.FileType: errorMsg = i18n('SETTINGS_THEMES/ERROR_FILE_TYPE_ERROR'); break; // no default } } if (!errorMsg && data.ErrorMessage) { errorMsg = data.ErrorMessage; } this.background.error(errorMsg || i18n('SETTINGS_THEMES/ERROR_UNKNOWN')); } return true; }); } } }