2016-07-07 07:11:13 +08:00
|
|
|
import ko from 'ko';
|
|
|
|
|
2019-07-05 03:19:24 +08:00
|
|
|
import { VIEW_MODELS } from 'Common/Globals';
|
2020-08-19 18:34:05 +08:00
|
|
|
import { pString } from 'Common/Utils';
|
2019-07-05 03:19:24 +08:00
|
|
|
import { settings } from 'Common/Links';
|
2016-07-07 07:11:13 +08:00
|
|
|
|
2019-07-05 03:19:24 +08:00
|
|
|
import { setHash } from 'Knoin/Knoin';
|
|
|
|
import { AbstractScreen } from 'Knoin/AbstractScreen';
|
2016-07-07 07:11:13 +08:00
|
|
|
|
2019-07-05 03:19:24 +08:00
|
|
|
class AbstractSettingsScreen extends AbstractScreen {
|
2016-07-07 07:11:13 +08:00
|
|
|
/**
|
|
|
|
* @param {Array} viewModels
|
|
|
|
*/
|
2019-07-05 03:19:24 +08:00
|
|
|
constructor(viewModels) {
|
2016-07-07 07:11:13 +08:00
|
|
|
super('settings', viewModels);
|
|
|
|
|
|
|
|
this.menu = ko.observableArray([]);
|
|
|
|
|
|
|
|
this.oCurrentSubScreen = null;
|
|
|
|
this.oViewModelPlace = null;
|
|
|
|
|
|
|
|
this.setupSettings();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param {Function=} fCallback
|
|
|
|
*/
|
|
|
|
setupSettings(fCallback = null) {
|
2019-07-05 03:19:24 +08:00
|
|
|
if (fCallback) {
|
2016-07-07 07:11:13 +08:00
|
|
|
fCallback();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-08-17 06:01:20 +08:00
|
|
|
onRoute(subName) {
|
2019-07-05 03:19:24 +08:00
|
|
|
let settingsScreen = null,
|
2016-07-07 07:11:13 +08:00
|
|
|
RoutedSettingsViewModel = null,
|
2016-08-17 06:01:20 +08:00
|
|
|
viewModelDom = null;
|
2016-07-07 07:11:13 +08:00
|
|
|
|
2020-07-22 16:43:19 +08:00
|
|
|
RoutedSettingsViewModel = VIEW_MODELS.settings.find(
|
|
|
|
SettingsViewModel =>
|
2019-07-05 03:19:24 +08:00
|
|
|
SettingsViewModel && SettingsViewModel.__rlSettingsData && subName === SettingsViewModel.__rlSettingsData.Route
|
2016-07-07 07:11:13 +08:00
|
|
|
);
|
|
|
|
|
2019-07-05 03:19:24 +08:00
|
|
|
if (RoutedSettingsViewModel) {
|
|
|
|
if (
|
2020-07-22 16:43:19 +08:00
|
|
|
VIEW_MODELS['settings-removed'].find(
|
|
|
|
DisabledSettingsViewModel =>
|
2019-07-05 03:19:24 +08:00
|
|
|
DisabledSettingsViewModel && DisabledSettingsViewModel === RoutedSettingsViewModel
|
|
|
|
)
|
|
|
|
) {
|
2016-07-07 07:11:13 +08:00
|
|
|
RoutedSettingsViewModel = null;
|
|
|
|
}
|
|
|
|
|
2019-07-05 03:19:24 +08:00
|
|
|
if (
|
|
|
|
RoutedSettingsViewModel &&
|
2020-07-22 16:43:19 +08:00
|
|
|
VIEW_MODELS['settings-disabled'].find(
|
|
|
|
DisabledSettingsViewModel =>
|
2019-07-05 03:19:24 +08:00
|
|
|
DisabledSettingsViewModel && DisabledSettingsViewModel === RoutedSettingsViewModel
|
|
|
|
)
|
|
|
|
) {
|
2016-07-07 07:11:13 +08:00
|
|
|
RoutedSettingsViewModel = null;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-07-05 03:19:24 +08:00
|
|
|
if (RoutedSettingsViewModel) {
|
|
|
|
if (RoutedSettingsViewModel.__builded && RoutedSettingsViewModel.__vm) {
|
2016-08-17 06:01:20 +08:00
|
|
|
settingsScreen = RoutedSettingsViewModel.__vm;
|
2019-07-05 03:19:24 +08:00
|
|
|
} else {
|
2020-08-27 21:45:47 +08:00
|
|
|
if (this.oViewModelPlace) {
|
2016-08-17 06:01:20 +08:00
|
|
|
settingsScreen = new RoutedSettingsViewModel();
|
2016-07-07 07:11:13 +08:00
|
|
|
|
2020-08-27 21:45:47 +08:00
|
|
|
viewModelDom = jQuery('<div></div>');
|
|
|
|
viewModelDom[0].classList.add('rl-settings-view-model');
|
|
|
|
viewModelDom[0].hidden = true;
|
|
|
|
this.oViewModelPlace.append(viewModelDom[0]);
|
2016-07-07 07:11:13 +08:00
|
|
|
|
2020-08-27 21:45:47 +08:00
|
|
|
settingsScreen.viewModelDom = viewModelDom[0];
|
2016-07-07 07:11:13 +08:00
|
|
|
|
2016-08-17 06:01:20 +08:00
|
|
|
settingsScreen.__rlSettingsData = RoutedSettingsViewModel.__rlSettingsData;
|
2016-07-07 07:11:13 +08:00
|
|
|
|
2020-08-27 21:45:47 +08:00
|
|
|
RoutedSettingsViewModel.__dom = viewModelDom[0];
|
2016-07-07 07:11:13 +08:00
|
|
|
RoutedSettingsViewModel.__builded = true;
|
2016-08-17 06:01:20 +08:00
|
|
|
RoutedSettingsViewModel.__vm = settingsScreen;
|
2016-07-07 07:11:13 +08:00
|
|
|
|
2019-07-05 03:19:24 +08:00
|
|
|
const tmpl = { name: RoutedSettingsViewModel.__rlSettingsData.Template };
|
|
|
|
ko.applyBindingAccessorsToNode(
|
|
|
|
viewModelDom[0],
|
|
|
|
{
|
2020-08-15 02:35:39 +08:00
|
|
|
i18nInit: true,
|
2019-07-05 03:19:24 +08:00
|
|
|
template: () => tmpl
|
|
|
|
},
|
|
|
|
settingsScreen
|
|
|
|
);
|
2016-07-07 07:11:13 +08:00
|
|
|
|
2020-08-19 02:24:17 +08:00
|
|
|
settingsScreen.onBuild && settingsScreen.onBuild(viewModelDom);
|
2019-07-05 03:19:24 +08:00
|
|
|
} else {
|
2020-08-12 06:25:36 +08:00
|
|
|
console.log('Cannot find sub settings view model position: SettingsSubScreen');
|
2016-07-07 07:11:13 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-07-05 03:19:24 +08:00
|
|
|
if (settingsScreen) {
|
2020-07-30 03:49:41 +08:00
|
|
|
const o = this;
|
|
|
|
setTimeout(() => {
|
2016-07-07 07:11:13 +08:00
|
|
|
// hide
|
2020-07-30 03:49:41 +08:00
|
|
|
if (o.oCurrentSubScreen) {
|
2020-08-19 02:24:17 +08:00
|
|
|
o.oCurrentSubScreen.onHide && o.oCurrentSubScreen.onHide();
|
2020-08-27 21:45:47 +08:00
|
|
|
o.oCurrentSubScreen.viewModelDom.hidden = true;
|
2016-07-07 07:11:13 +08:00
|
|
|
}
|
|
|
|
// --
|
|
|
|
|
2020-07-30 03:49:41 +08:00
|
|
|
o.oCurrentSubScreen = settingsScreen;
|
2016-07-07 07:11:13 +08:00
|
|
|
|
|
|
|
// show
|
2020-07-30 03:49:41 +08:00
|
|
|
if (o.oCurrentSubScreen) {
|
2020-08-19 02:24:17 +08:00
|
|
|
o.oCurrentSubScreen.onBeforeShow && o.oCurrentSubScreen.onBeforeShow();
|
2020-08-27 21:45:47 +08:00
|
|
|
o.oCurrentSubScreen.viewModelDom.hidden = false;
|
2020-08-19 02:24:17 +08:00
|
|
|
o.oCurrentSubScreen.onShow && o.oCurrentSubScreen.onShow();
|
|
|
|
o.oCurrentSubScreen.onShowWithDelay && setTimeout(() => o.oCurrentSubScreen.onShowWithDelay(), 200);
|
2016-07-07 07:11:13 +08:00
|
|
|
|
2020-07-30 03:49:41 +08:00
|
|
|
o.menu().forEach(item => {
|
2019-07-05 03:19:24 +08:00
|
|
|
item.selected(
|
|
|
|
settingsScreen &&
|
|
|
|
settingsScreen.__rlSettingsData &&
|
|
|
|
item.route === settingsScreen.__rlSettingsData.Route
|
|
|
|
);
|
2016-07-07 07:11:13 +08:00
|
|
|
});
|
|
|
|
|
2020-08-27 21:45:47 +08:00
|
|
|
document.querySelector('#rl-content .b-settings .b-content').scrollTop = 0;
|
2016-07-07 07:11:13 +08:00
|
|
|
}
|
|
|
|
// --
|
2020-07-30 03:49:41 +08:00
|
|
|
}, 1);
|
2016-07-07 07:11:13 +08:00
|
|
|
}
|
2019-07-05 03:19:24 +08:00
|
|
|
} else {
|
2016-07-08 07:22:58 +08:00
|
|
|
setHash(settings(), false, true);
|
2016-07-07 07:11:13 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
onHide() {
|
2019-07-05 03:19:24 +08:00
|
|
|
if (this.oCurrentSubScreen && this.oCurrentSubScreen.viewModelDom) {
|
2020-08-19 02:24:17 +08:00
|
|
|
this.oCurrentSubScreen.onHide && this.oCurrentSubScreen.onHide();
|
2020-08-27 21:45:47 +08:00
|
|
|
this.oCurrentSubScreen.viewModelDom.hidden = true;
|
2016-07-07 07:11:13 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
onBuild() {
|
2020-07-22 20:49:18 +08:00
|
|
|
VIEW_MODELS.settings.forEach(SettingsViewModel => {
|
2019-07-05 03:19:24 +08:00
|
|
|
if (
|
|
|
|
SettingsViewModel &&
|
|
|
|
SettingsViewModel.__rlSettingsData &&
|
2020-07-22 16:43:19 +08:00
|
|
|
!VIEW_MODELS['settings-removed'].find(
|
|
|
|
RemoveSettingsViewModel => RemoveSettingsViewModel && RemoveSettingsViewModel === SettingsViewModel
|
2019-07-05 03:19:24 +08:00
|
|
|
)
|
|
|
|
) {
|
2016-07-07 07:11:13 +08:00
|
|
|
this.menu.push({
|
|
|
|
route: SettingsViewModel.__rlSettingsData.Route,
|
|
|
|
label: SettingsViewModel.__rlSettingsData.Label,
|
|
|
|
selected: ko.observable(false),
|
2020-07-22 16:43:19 +08:00
|
|
|
disabled: !!VIEW_MODELS['settings-disabled'].find(
|
|
|
|
DisabledSettingsViewModel => DisabledSettingsViewModel && DisabledSettingsViewModel === SettingsViewModel
|
2019-07-05 03:19:24 +08:00
|
|
|
)
|
2016-07-07 07:11:13 +08:00
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2020-08-27 21:45:47 +08:00
|
|
|
this.oViewModelPlace = document.getElementById('rl-settings-subscreen');
|
2016-07-07 07:11:13 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
routes() {
|
2020-07-22 16:43:19 +08:00
|
|
|
const DefaultViewModel = VIEW_MODELS.settings.find(
|
|
|
|
SettingsViewModel =>
|
2019-07-05 03:19:24 +08:00
|
|
|
SettingsViewModel && SettingsViewModel.__rlSettingsData && SettingsViewModel.__rlSettingsData.IsDefault
|
2017-08-07 23:09:14 +08:00
|
|
|
),
|
2019-07-05 03:19:24 +08:00
|
|
|
defaultRoute =
|
|
|
|
DefaultViewModel && DefaultViewModel.__rlSettingsData ? DefaultViewModel.__rlSettingsData.Route : 'general',
|
2016-08-17 06:01:20 +08:00
|
|
|
rules = {
|
2016-07-07 07:11:13 +08:00
|
|
|
subname: /^(.*)$/,
|
2016-08-17 06:01:20 +08:00
|
|
|
normalize_: (rquest, vals) => {
|
2020-07-30 03:49:41 +08:00
|
|
|
vals.subname = undefined === vals.subname ? defaultRoute : pString(vals.subname);
|
2016-08-17 06:01:20 +08:00
|
|
|
return [vals.subname];
|
2016-07-07 07:11:13 +08:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2019-12-25 03:05:46 +08:00
|
|
|
return [
|
|
|
|
['{subname}/', rules],
|
|
|
|
['{subname}', rules],
|
|
|
|
['', rules]
|
|
|
|
];
|
2016-07-07 07:11:13 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-07-05 03:19:24 +08:00
|
|
|
export { AbstractSettingsScreen, AbstractSettingsScreen as default };
|