mirror of
https://github.com/the-djmaze/snappymail.git
synced 2025-01-20 13:47:50 +08:00
120 lines
3.9 KiB
JavaScript
120 lines
3.9 KiB
JavaScript
import ko from 'ko';
|
|
|
|
import {
|
|
isArray
|
|
} from 'Common/Utils';
|
|
|
|
import { addObservablesTo, addSubscribablesTo, addComputablesTo } from 'External/ko';
|
|
|
|
import { SaveSettingStatus } from 'Common/Enums';
|
|
import { Settings, SettingsGet, SettingsCapa } from 'Common/Globals';
|
|
import { translatorReload, convertLangName } from 'Common/Translator';
|
|
|
|
import { AbstractViewSettings } from 'Knoin/AbstractViews';
|
|
import { showScreenPopup } from 'Knoin/Knoin';
|
|
|
|
import Remote from 'Remote/Admin/Fetch';
|
|
|
|
import { ThemeStore, convertThemeName, changeTheme } from 'Stores/Theme';
|
|
import { LanguageStore } from 'Stores/Language';
|
|
import { LanguagesPopupView } from 'View/Popup/Languages';
|
|
|
|
export class AdminSettingsGeneral extends AbstractViewSettings {
|
|
constructor() {
|
|
super();
|
|
|
|
this.language = LanguageStore.language;
|
|
this.languages = LanguageStore.languages;
|
|
|
|
const aLanguagesAdmin = Settings.app('languagesAdmin');
|
|
this.languagesAdmin = ko.observableArray(isArray(aLanguagesAdmin) ? aLanguagesAdmin : []);
|
|
this.languageAdmin = ko.observable(SettingsGet('languageAdmin'));
|
|
|
|
this.theme = ThemeStore.theme;
|
|
this.themes = ThemeStore.themes;
|
|
|
|
this.addSettings(['allowLanguagesOnSettings']);
|
|
|
|
addObservablesTo(this, {
|
|
capaThemes: SettingsCapa('Themes'),
|
|
capaUserBackground: SettingsCapa('UserBackground'),
|
|
capaAdditionalAccounts: SettingsCapa('AdditionalAccounts'),
|
|
capaIdentities: SettingsCapa('Identities'),
|
|
capaAttachmentThumbnails: SettingsCapa('AttachmentThumbnails'),
|
|
dataFolderAccess: false
|
|
});
|
|
|
|
this.weakPassword = rl.app.weakPassword;
|
|
|
|
/** https://github.com/RainLoop/rainloop-webmail/issues/1924
|
|
if (this.weakPassword) {
|
|
fetch('./data/VERSION?' + Math.random()).then(response => this.dataFolderAccess(response.ok));
|
|
}
|
|
*/
|
|
|
|
this.attachmentLimit = ko
|
|
.observable(SettingsGet('attachmentLimit') / (1024 * 1024))
|
|
.extend({ debounce: 500 });
|
|
|
|
this.addSetting('language');
|
|
this.addSetting('attachmentLimit');
|
|
this.addSetting('Theme', value => changeTheme(value, this.themeTrigger));
|
|
|
|
this.uploadData = SettingsGet('phpUploadSizes');
|
|
this.uploadDataDesc =
|
|
(this.uploadData?.upload_max_filesize || this.uploadData?.post_max_size)
|
|
? [
|
|
this.uploadData.upload_max_filesize
|
|
? 'upload_max_filesize = ' + this.uploadData.upload_max_filesize + '; '
|
|
: '',
|
|
this.uploadData.post_max_size ? 'post_max_size = ' + this.uploadData.post_max_size : ''
|
|
].join('')
|
|
: '';
|
|
|
|
addComputablesTo(this, {
|
|
themesOptions: () => this.themes.map(theme => ({ optValue: theme, optText: convertThemeName(theme) })),
|
|
|
|
languageFullName: () => convertLangName(this.language()),
|
|
languageAdminFullName: () => convertLangName(this.languageAdmin())
|
|
});
|
|
|
|
this.languageAdminTrigger = ko.observable(SaveSettingStatus.Idle).extend({ debounce: 100 });
|
|
|
|
const fReloadLanguageHelper = (saveSettingsStep) => () => {
|
|
this.languageAdminTrigger(saveSettingsStep);
|
|
setTimeout(() => this.languageAdminTrigger(SaveSettingStatus.Idle), 1000);
|
|
},
|
|
fSaveHelper = key => value => Remote.saveSetting(key, value);
|
|
|
|
addSubscribablesTo(this, {
|
|
languageAdmin: value => {
|
|
this.languageAdminTrigger(SaveSettingStatus.Saving);
|
|
translatorReload(value, 1)
|
|
.then(fReloadLanguageHelper(SaveSettingStatus.Success), fReloadLanguageHelper(SaveSettingStatus.Failed))
|
|
.then(() => Remote.saveSetting('languageAdmin', value));
|
|
},
|
|
|
|
capaAdditionalAccounts: fSaveHelper('CapaAdditionalAccounts'),
|
|
|
|
capaIdentities: fSaveHelper('CapaIdentities'),
|
|
|
|
capaAttachmentThumbnails: fSaveHelper('CapaAttachmentThumbnails'),
|
|
|
|
capaThemes: fSaveHelper('CapaThemes'),
|
|
|
|
capaUserBackground: fSaveHelper('CapaUserBackground')
|
|
});
|
|
}
|
|
|
|
selectLanguage() {
|
|
showScreenPopup(LanguagesPopupView, [this.language, this.languages(), LanguageStore.userLanguage()]);
|
|
}
|
|
|
|
selectLanguageAdmin() {
|
|
showScreenPopup(LanguagesPopupView, [
|
|
this.languageAdmin,
|
|
this.languagesAdmin(),
|
|
SettingsGet('languageUsers')
|
|
]);
|
|
}
|
|
}
|