Handle changes better

This commit is contained in:
Samuel Elliott 2018-03-04 22:54:37 +00:00
parent 47637eca75
commit 9617890ab6
No known key found for this signature in database
GPG Key ID: 8420C7CDE43DC4D6
2 changed files with 41 additions and 63 deletions

View File

@ -24,12 +24,11 @@ export default class ArraySetting extends Setting {
this.args.schemes = this.schemes.map(scheme => new SettingsScheme(scheme)); this.args.schemes = this.schemes.map(scheme => new SettingsScheme(scheme));
this.args.items = this.value ? this.value.map(item => this.createItem(item.args || item)) : []; this.args.items = this.value ? this.value.map(item => this.createItem(item.args || item)) : [];
this.args.value = this.items.map(item => { this._setValue(this.items.map(item => {
if (!item) return; if (!item) return;
item.setSaved(); item.setSaved();
return item.strip(); return item.strip();
}); }));
this.changed = !Utils.compare(this.args.value, this.args.saved_value);
} }
/** /**
@ -147,24 +146,6 @@ export default class ArraySetting extends Setting {
return set; return set;
} }
/**
* Merges a setting into this setting without emitting events (and therefore synchronously).
* This only exists for use by the constructor and SettingsCategory.
*/
_merge(newSetting) {
const value = newSetting.args ? newSetting.args.value : newSetting.value;
const old_value = this.args.value;
if (Utils.compare(value, old_value)) return [];
this.args.value = value;
this.args.items = this.value ? this.value.map(item => this.createItem(item.args || item)) : [];
this.changed = !Utils.compare(this.args.value, this.args.saved_value);
return [{
setting: this, setting_id: this.id,
value, old_value
}];
}
/** /**
* Sets the value of this setting. * Sets the value of this setting.
* This is only intended for use by settings. * This is only intended for use by settings.
@ -173,20 +154,17 @@ export default class ArraySetting extends Setting {
* @param {Boolean} emit Whether to emit a SettingUpdatedEvent * @param {Boolean} emit Whether to emit a SettingUpdatedEvent
* @return {Promise} * @return {Promise}
*/ */
setValue(value, emit_multi = true, emit = true) { setValueHook(updatedSetting) {
this.args.items = value ? value.map(item => this.createItem(item)) : []; this.args.items = updatedSetting.value ? updatedSetting.value.map(item => this.createItem(item)) : [];
this.updateValue(emit_multi, emit);
} }
/** /**
* Updates the value of this array setting. * Updates the value of this array setting.
* This only exists for use by array settings. * This only exists for use by array settings.
* @param {Boolean} emit_multi Whether to emit a SettingsUpdatedEvent
* @param {Boolean} emit Whether to emit a SettingUpdatedEvent
* @return {Promise} * @return {Promise}
*/ */
updateValue(emit_multi = true, emit = true) { updateValue(emit_multi = true, emit = true) {
return this.__proto__.__proto__.setValue.call(this, this.items.map(item => { return this.setValue.call(this, this.items.map(item => {
if (!item) return; if (!item) return;
item.setSaved(); item.setSaved();
return item.strip(); return item.strip();

View File

@ -107,75 +107,75 @@ export default class Setting {
*/ */
_merge(newSetting) { _merge(newSetting) {
const value = newSetting.args ? newSetting.args.value : newSetting.value; const value = newSetting.args ? newSetting.args.value : newSetting.value;
const old_value = this.args.value; return this._setValue(value);
if (Utils.compare(value, old_value)) return [];
this.args.value = value;
this.changed = !Utils.compare(this.args.value, this.args.saved_value);
return [{
setting: this, setting_id: this.id,
value, old_value
}];
} }
/** /**
* Merges another setting into this setting. * Merges another setting into this setting.
* @param {SettingsSetting} newSetting The setting to merge into this setting * @param {SettingsSetting} newSetting The setting to merge into this setting
* @param {Boolean} emit_multi Whether to emit a SettingsUpdatedEvent
* @param {Boolean} emit Whether to emit a SettingUpdatedEvent
* @return {Promise} * @return {Promise}
*/ */
async merge(newSetting, emit_multi = true, emit = true) { async merge(newSetting, emit_multi = true, emit = true) {
const value = newSetting.args ? newSetting.args.value : newSetting.value; const updatedSettings = this._merge(newSetting);
if (!updatedSettings.length) return [];
const updatedSetting = updatedSettings[0];
if (emit)
await this.emit('setting-updated', updatedSetting);
if (emit_multi)
await this.emit('settings-updated', new SettingsUpdatedEvent({
updatedSettings
}));
return updatedSettings;
}
/**
* Sets the value of this setting.
* This only exists for use by the constructor and SettingsCategory.
*/
_setValue(value) {
const old_value = this.args.value; const old_value = this.args.value;
if (Utils.compare(value, old_value)) return []; if (Utils.compare(value, old_value)) return [];
this.args.value = value; this.args.value = value;
this.changed = !Utils.compare(this.args.value, this.args.saved_value); this.changed = !Utils.compare(this.args.value, this.args.saved_value);
const updatedSetting = { const updatedSetting = new SettingUpdatedEvent({
setting: this, setting_id: this.id, setting: this, setting_id: this.id,
value, old_value value, old_value
}; });
if (emit) this.setValueHook(updatedSetting);
await this.emit('setting-updated', new SettingUpdatedEvent(updatedSetting));
if (emit_multi)
await this.emit('settings-updated', new SettingsUpdatedEvent({
updatedSettings: [updatedSetting]
}));
return [updatedSetting]; return [updatedSetting];
} }
/**
* Function to be called after the value changes.
* This can be overridden by other settings types.
* @param {SettingUpdatedEvent} updatedSetting
*/
setValueHook(updatedSetting) {}
/** /**
* Sets the value of this setting. * Sets the value of this setting.
* This is only intended for use by settings.
* @param {Any} value The new value of this setting * @param {Any} value The new value of this setting
* @param {Boolean} emit_multi Whether to emit a SettingsUpdatedEvent
* @param {Boolean} emit Whether to emit a SettingUpdatedEvent
* @return {Promise} * @return {Promise}
*/ */
async setValue(value, emit_multi = true, emit = true) { async setValue(value, emit_multi = true, emit = true) {
const old_value = this.args.value; const updatedSettings = this._setValue(value);
if (Utils.compare(value, old_value)) return []; if (!updatedSettings.length) return [];
this.args.value = value;
this.changed = !Utils.compare(this.args.value, this.args.saved_value);
const updatedSetting = {
setting: this, setting_id: this.id,
value, old_value
};
if (emit) if (emit)
await this.emit('setting-updated', new SettingUpdatedEvent(updatedSetting)); await this.emit('setting-updated', updatedSettings[0]);
if (emit_multi) if (emit_multi)
await this.emit('settings-updated', new SettingsUpdatedEvent({ await this.emit('settings-updated', new SettingsUpdatedEvent({
updatedSettings: [updatedSetting] updatedSettings
})); }));
return [updatedSetting]; return updatedSettings;
} }
/** /**