From 94d534d8973e29b8a758bfc309087bb3e97abfc4 Mon Sep 17 00:00:00 2001 From: nathan Date: Mon, 6 Jun 2022 16:41:29 -0600 Subject: [PATCH] Et2Select bugs: - multiple always had the first option selected - removing multiple options did not trigger change event --- api/js/etemplate/Et2Select/Et2Select.ts | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/api/js/etemplate/Et2Select/Et2Select.ts b/api/js/etemplate/Et2Select/Et2Select.ts index a9bf19d9cd..9e7189ae6e 100644 --- a/api/js/etemplate/Et2Select/Et2Select.ts +++ b/api/js/etemplate/Et2Select/Et2Select.ts @@ -116,6 +116,7 @@ export class Et2Select extends Et2WithSearchMixin(Et2InvokerMixin(Et2WidgetWithS { this.addEventListener("sl-clear", this._triggerChange) this.addEventListener("sl-select", this._triggerChange); + this.addEventListener("sl-change", this._triggerChange); }); } @@ -135,7 +136,7 @@ export class Et2Select extends Et2WithSearchMixin(Et2InvokerMixin(Et2WidgetWithS // Only do this on firstUpdated() otherwise it is impossible to clear the field const valueArray = Array.isArray(this.value) ? this.value : (!this.value ? [] : this.value.toString().split(',')); // value not in options AND NOT (having an empty label and value) - if(this.select_options.length > 0 && this.select_options.filter((option) => valueArray.find(val => val == option.value)).length === 0 && + if(!this.multiple && this.select_options.length > 0 && this.select_options.filter((option) => valueArray.find(val => val == option.value)).length === 0 && !(typeof this.empty_label !== 'undefined' && (this.value || "") === "")) { // --> use first option @@ -168,9 +169,9 @@ export class Et2Select extends Et2WithSearchMixin(Et2InvokerMixin(Et2WidgetWithS this.multiple = multi; } - set_value(val) + set_value(val : string | string[]) { - this.value = ""+val; + this.value = val; } /**