snappymail/dev/App/Abstract.js

76 lines
2 KiB
JavaScript
Raw Normal View History

import ko from 'ko';
2016-06-07 05:57:52 +08:00
import { Settings, SettingsGet } from 'Common/Globals';
2021-11-03 09:28:19 +08:00
import { changeTheme } from 'Common/Utils';
2016-06-07 05:57:52 +08:00
2021-01-27 19:02:37 +08:00
import { logoutLink } from 'Common/Links';
import { i18nToNodes, initOnStartOrLangChange } from 'Common/Translator';
2015-11-19 01:32:29 +08:00
import { LanguageStore } from 'Stores/Language';
import { ThemeStore } from 'Stores/Theme';
import { InputComponent } from 'Component/Input';
import { SelectComponent } from 'Component/Select';
import { TextAreaComponent } from 'Component/TextArea';
import { CheckboxMaterialDesignComponent } from 'Component/MaterialDesign/Checkbox';
import { CheckboxComponent } from 'Component/Checkbox';
2021-01-22 23:32:08 +08:00
export class AbstractApp {
2014-08-20 23:03:12 +08:00
/**
* @param {RemoteStorage|AdminRemoteStorage} Remote
2014-08-20 23:03:12 +08:00
*/
constructor(Remote) {
this.Remote = Remote;
}
logoutReload() {
2021-01-27 19:02:37 +08:00
const url = logoutLink();
2021-01-27 19:02:37 +08:00
if (location.href !== url) {
setTimeout(() => (Settings.app('inIframe') ? parent : window).location.href = url, 100);
2019-07-05 03:19:24 +08:00
} else {
rl.route.reload();
2014-08-20 23:03:12 +08:00
}
2015-11-19 01:32:29 +08:00
}
refresh() {
// rl.adminArea() || !translatorReload(false, );
2021-11-03 09:28:19 +08:00
rl.adminArea() || (
LanguageStore.language(SettingsGet('Language'))
& ThemeStore.populate()
& changeTheme(SettingsGet('Theme'))
);
this.start();
}
2015-11-19 01:32:29 +08:00
bootstart() {
const register = (key, ClassObject, templateID) => ko.components.register(key, {
template: { element: templateID || (key + 'Component') },
viewModel: {
createViewModel: (params, componentInfo) => {
params = params || {};
2022-02-17 16:36:29 +08:00
i18nToNodes(componentInfo.element);
if (params.inline) {
componentInfo.element.style.display = 'inline-block';
}
return new ClassObject(params);
}
}
});
register('Input', InputComponent);
register('Select', SelectComponent);
register('TextArea', TextAreaComponent);
2021-03-25 17:54:40 +08:00
register('Checkbox', CheckboxMaterialDesignComponent, 'CheckboxMaterialDesignComponent');
register('CheckboxSimple', CheckboxComponent, 'CheckboxComponent');
2014-08-20 23:03:12 +08:00
initOnStartOrLangChange();
LanguageStore.populate();
ThemeStore.populate();
2020-09-17 05:19:34 +08:00
this.start();
2020-09-17 05:19:34 +08:00
}
2015-11-19 01:32:29 +08:00
}