From a6593709b0e1e99e241b6c163fe66623685b6efc Mon Sep 17 00:00:00 2001 From: Soopyboo32 <49228220+Soopyboo32@users.noreply.github.com> Date: Sun, 29 May 2022 12:04:52 +0800 Subject: first part of supporting java side rendering --- features/settings/settingThings/toggle.js | 24 ++++++++++++++---------- 1 file changed, 14 insertions(+), 10 deletions(-) (limited to 'features/settings/settingThings/toggle.js') diff --git a/features/settings/settingThings/toggle.js b/features/settings/settingThings/toggle.js index d839b8f..200ac87 100644 --- a/features/settings/settingThings/toggle.js +++ b/features/settings/settingThings/toggle.js @@ -4,47 +4,51 @@ import Toggle from "../../../../guimanager/GuiElement/Toggle"; import SettingBase from "./settingBase"; class ToggleSetting extends SettingBase { - constructor(name, description, defaultVal, settingId, module){ + constructor(name, description, defaultVal, settingId, module) { super(name, description, defaultVal, settingId, module) + this.onChange = undefined + this.toggleObject = new Toggle().setLocation(0, 0.3, 0.8, 0.4).setValue(this.getValue()) this.settingObject.addChild(this.toggleObject) - this.toggleObject.addEvent(new SoopyContentChangeEvent().setHandler((newVal, oldVal, resetFun)=>{ + this.toggleObject.addEvent(new SoopyContentChangeEvent().setHandler((newVal, oldVal, resetFun) => { this.setValue(newVal) })) } - setValue(newVal){ + setValue(newVal) { super.setValue(newVal) this.toggleObject.setValue(newVal) + if (this.onChange) this.onChange() + return this } - requires(toggleSetting){ + requires(toggleSetting) { this.requiresO = toggleSetting - toggleSetting.toggleObject.addEvent(new SoopyContentChangeEvent().setHandler((newVal, oldVal, resetFun)=>{ - if(newVal){ + toggleSetting.toggleObject.addEvent(new SoopyContentChangeEvent().setHandler((newVal, oldVal, resetFun) => { + if (newVal) { this.setValue(this.temp_val) - this.toggleObject.triggerEvent(Enum.EVENT.CONTENT_CHANGE, [this.temp_val, false, ()=>{}]) + this.toggleObject.triggerEvent(Enum.EVENT.CONTENT_CHANGE, [this.temp_val, false, () => { }]) this.guiObject.location.size.y.set(0.2, 500) - }else{ + } else { this.temp_val = this.getValue() this.setValue(false) - this.toggleObject.triggerEvent(Enum.EVENT.CONTENT_CHANGE, [false, this.temp_val, ()=>{}]) + this.toggleObject.triggerEvent(Enum.EVENT.CONTENT_CHANGE, [false, this.temp_val, () => { }]) this.guiObject.location.size.y.set(0, 500) } })) let newVal = this.requiresO.getValue() - if(!newVal){ + if (!newVal) { let temp_val = this.temp_val this.setValue(false) this.temp_val = temp_val -- cgit