TeaWeb/shared/js/ui/modal/global-settings-editor/Controller.tsx

81 lines
3.1 KiB
TypeScript
Raw Normal View History

2020-09-17 23:06:02 +02:00
import {spawnReactModal} from "tc-shared/ui/react-elements/Modal";
import {ModalGlobalSettingsEditor} from "tc-shared/ui/modal/global-settings-editor/Renderer";
import {Registry} from "tc-shared/events";
import {ModalGlobalSettingsEditorEvents, Setting} from "tc-shared/ui/modal/global-settings-editor/Definitions";
2020-09-17 23:41:47 +02:00
import {ConfigValueTypes, settings, Settings, SettingsKey} from "tc-shared/settings";
2020-09-24 11:24:31 +02:00
import {key} from "tc-shared/KeyControl";
2020-09-17 23:06:02 +02:00
export function spawnGlobalSettingsEditor() {
const events = new Registry<ModalGlobalSettingsEditorEvents>();
initializeController(events);
const modal = spawnReactModal(ModalGlobalSettingsEditor, events);
modal.show();
modal.events.on("destroy", () => {
events.fire("notify_destroy");
events.destroy();
});
}
function initializeController(events: Registry<ModalGlobalSettingsEditorEvents>) {
events.on("query_settings", () => {
const settingsList: Setting[] = [];
for(const key of Settings.KEYS) {
const setting = Settings[key] as SettingsKey<ConfigValueTypes>;
settingsList.push({
key: setting.key,
description: setting.description,
type: setting.valueType,
defaultValue: setting.defaultValue
});
}
events.fire_async("notify_settings", { settings: settingsList });
});
events.on("action_select_setting", event => {
events.fire("notify_selected_setting", { setting: event.setting });
});
events.on("query_setting", event => {
const setting = Settings.KEYS.map(setting => Settings[setting] as SettingsKey<ConfigValueTypes>).find(e => e.key === event.setting);
if(typeof setting === "undefined") {
events.fire("notify_setting", {
2020-09-17 23:41:47 +02:00
setting: event.setting,
2020-09-17 23:06:02 +02:00
status: "not-found"
});
return;
}
events.fire("notify_setting", {
setting: event.setting,
status: "success",
info: {
key: setting.key,
description: setting.description,
type: setting.valueType,
defaultValue: setting.defaultValue
},
2020-09-17 23:41:47 +02:00
value: settings.global(setting, undefined)
2020-09-17 23:06:02 +02:00
});
});
events.on("action_set_value", event => {
const setting = Settings.KEYS.map(setting => Settings[setting] as SettingsKey<ConfigValueTypes>).find(e => e.key === event.setting);
if(typeof setting === "undefined") {
return;
}
/* the change will may already trigger a notify_setting_value, but just to ensure we're fiering it later as well */
settings.changeGlobal(setting, event.value);
events.fire_async("notify_setting_value", { setting: event.setting, value: event.value });
});
events.on("notify_destroy", settings.events.on("notify_setting_changed", event => {
if(event.mode === "global") {
events.fire_async("notify_setting_value", { setting: event.setting, value: event.newValue });
}
}));
}