mirror of
https://github.com/the-djmaze/snappymail.git
synced 2025-01-18 12:48:50 +08:00
143 lines
3.6 KiB
JavaScript
143 lines
3.6 KiB
JavaScript
import ko from 'ko';
|
|
|
|
import { pString } from 'Common/Utils';
|
|
import { settings } from 'Common/Links';
|
|
import { elementById } from 'Common/Globals';
|
|
|
|
import { AbstractScreen } from 'Knoin/AbstractScreen';
|
|
|
|
const VIEW_MODELS = [];
|
|
|
|
export class AbstractSettingsScreen extends AbstractScreen {
|
|
/**
|
|
* @param {Array} viewModels
|
|
*/
|
|
constructor(viewModels) {
|
|
super('settings', viewModels);
|
|
|
|
this.menu = ko.observableArray();
|
|
|
|
this.oCurrentSubScreen = null;
|
|
}
|
|
|
|
onRoute(subName) {
|
|
let settingsScreen = null,
|
|
viewModelDom = null,
|
|
RoutedSettingsViewModel = VIEW_MODELS.find(
|
|
SettingsViewModel => subName === SettingsViewModel.__rlSettingsData.route
|
|
);
|
|
|
|
if (RoutedSettingsViewModel) {
|
|
if (RoutedSettingsViewModel.__builded && RoutedSettingsViewModel.__vm) {
|
|
settingsScreen = RoutedSettingsViewModel.__vm;
|
|
} else {
|
|
const vmPlace = elementById('rl-settings-subscreen');
|
|
if (vmPlace) {
|
|
viewModelDom = Element.fromHTML('<div id="V-Settings-'
|
|
+ (RoutedSettingsViewModel.name.replace(/(User|Admin)Settings/,''))
|
|
+ '" class="g-ui-user-select-none" hidden=""></div>');
|
|
vmPlace.append(viewModelDom);
|
|
|
|
settingsScreen = new RoutedSettingsViewModel();
|
|
settingsScreen.viewModelDom = viewModelDom;
|
|
|
|
RoutedSettingsViewModel.__dom = viewModelDom;
|
|
RoutedSettingsViewModel.__builded = true;
|
|
RoutedSettingsViewModel.__vm = settingsScreen;
|
|
|
|
ko.applyBindingAccessorsToNode(
|
|
viewModelDom,
|
|
{
|
|
i18nInit: true,
|
|
template: () => ({ name: RoutedSettingsViewModel.__rlSettingsData.template })
|
|
},
|
|
settingsScreen
|
|
);
|
|
|
|
settingsScreen.onBuild && settingsScreen.onBuild(viewModelDom);
|
|
} else {
|
|
console.log('Cannot find sub settings view model position: SettingsSubScreen');
|
|
}
|
|
}
|
|
|
|
if (settingsScreen) {
|
|
setTimeout(() => {
|
|
// hide
|
|
this.onHide();
|
|
// --
|
|
|
|
this.oCurrentSubScreen = settingsScreen;
|
|
|
|
// show
|
|
settingsScreen.onBeforeShow && settingsScreen.onBeforeShow();
|
|
settingsScreen.viewModelDom.hidden = false;
|
|
settingsScreen.onShow && settingsScreen.onShow();
|
|
|
|
this.menu.forEach(item => {
|
|
item.selected(
|
|
item.route === RoutedSettingsViewModel.__rlSettingsData.route
|
|
);
|
|
});
|
|
|
|
elementById('rl-settings-subscreen').scrollTop = 0;
|
|
// --
|
|
}, 1);
|
|
}
|
|
} else {
|
|
rl.route.setHash(settings(), false, true);
|
|
}
|
|
}
|
|
|
|
onHide() {
|
|
let subScreen = this.oCurrentSubScreen;
|
|
if (subScreen) {
|
|
subScreen.onHide && subScreen.onHide();
|
|
subScreen.viewModelDom.hidden = true;
|
|
}
|
|
}
|
|
|
|
onBuild() {
|
|
VIEW_MODELS.forEach(SettingsViewModel => this.menu.push(SettingsViewModel.__rlSettingsData));
|
|
}
|
|
|
|
routes() {
|
|
const DefaultViewModel = VIEW_MODELS.find(
|
|
SettingsViewModel => SettingsViewModel.__rlSettingsData.isDefault
|
|
),
|
|
defaultRoute =
|
|
DefaultViewModel ? DefaultViewModel.__rlSettingsData.route : 'general',
|
|
rules = {
|
|
subname: /^(.*)$/,
|
|
normalize_: (rquest, vals) => {
|
|
vals.subname = null == vals.subname ? defaultRoute : pString(vals.subname);
|
|
return [vals.subname];
|
|
}
|
|
};
|
|
|
|
return [
|
|
['{subname}/', rules],
|
|
['{subname}', rules],
|
|
['', rules]
|
|
];
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @param {Function} SettingsViewModelClass
|
|
* @param {string} template
|
|
* @param {string} labelName
|
|
* @param {string} route
|
|
* @param {boolean=} isDefault = false
|
|
* @returns {void}
|
|
*/
|
|
export function settingsAddViewModel(SettingsViewModelClass, template, labelName, route, isDefault = false) {
|
|
SettingsViewModelClass.__rlSettingsData = {
|
|
label: labelName,
|
|
route: route,
|
|
selected: ko.observable(false),
|
|
template: template,
|
|
isDefault: !!isDefault
|
|
};
|
|
|
|
VIEW_MODELS.push(SettingsViewModelClass);
|
|
}
|