mirror of
https://github.com/the-djmaze/snappymail.git
synced 2025-01-07 23:38:14 +08:00
84 lines
2.1 KiB
JavaScript
84 lines
2.1 KiB
JavaScript
import ko from 'ko';
|
|
|
|
import {
|
|
elementById,
|
|
Settings
|
|
} from 'Common/Globals';
|
|
|
|
import { logoutLink } from 'Common/Links';
|
|
import { i18nToNodes, initOnStartOrLangChange } from 'Common/Translator';
|
|
|
|
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';
|
|
|
|
export class AbstractApp {
|
|
/**
|
|
* @param {RemoteStorage|AdminRemoteStorage} Remote
|
|
*/
|
|
constructor(Remote) {
|
|
this.Remote = Remote;
|
|
}
|
|
|
|
logoutReload(close = false) {
|
|
const url = logoutLink();
|
|
|
|
close && window.close && window.close();
|
|
|
|
if (location.href !== url) {
|
|
setTimeout(() => (Settings.app('inIframe') ? parent : window).location.href = url, 100);
|
|
} else {
|
|
rl.route.reload();
|
|
}
|
|
}
|
|
|
|
bootstart() {
|
|
const register = (key, ClassObject, templateID) => ko.components.register(key, {
|
|
template: { element: templateID || (key + 'Component') },
|
|
viewModel: {
|
|
createViewModel: (params, componentInfo) => {
|
|
params = params || {};
|
|
params.element = null;
|
|
|
|
if (componentInfo && componentInfo.element) {
|
|
params.component = componentInfo;
|
|
params.element = componentInfo.element;
|
|
|
|
i18nToNodes(componentInfo.element);
|
|
|
|
if (params.inline && ko.unwrap(params.inline)) {
|
|
params.element.style.display = 'inline-block';
|
|
}
|
|
}
|
|
|
|
return new ClassObject(params);
|
|
}
|
|
}
|
|
});
|
|
|
|
register('Input', InputComponent);
|
|
register('Select', SelectComponent);
|
|
register('TextArea', TextAreaComponent);
|
|
register('Checkbox', CheckboxMaterialDesignComponent, 'CheckboxMaterialDesignComponent');
|
|
register('CheckboxSimple', CheckboxComponent, 'CheckboxComponent');
|
|
|
|
initOnStartOrLangChange();
|
|
|
|
LanguageStore.populate();
|
|
ThemeStore.populate();
|
|
}
|
|
|
|
/**
|
|
* @returns {void}
|
|
*/
|
|
hideLoading() {
|
|
elementById('rl-content').hidden = false;
|
|
elementById('rl-loading').remove();
|
|
}
|
|
|
|
}
|