fix validation in et2-select had problems with value being an array

eg. mail.compose always displayed "Invalid email"
running validator now for each array element or "" for an empty array
This commit is contained in:
ralf 2022-07-06 10:33:06 +02:00
parent 6c8e85311f
commit 489eb615ac

View File

@ -435,7 +435,7 @@ export class Et2Select extends Et2WithSearchMixin(Et2WidgetWithSelect)
let fieldName = this.id; let fieldName = this.id;
let feedbackData = []; let feedbackData = [];
this.querySelector("lion-validation-feedback")?.remove(); this.querySelector("lion-validation-feedback")?.remove();
const doValidate = async function(validator) const doValidate = async function(validator, value)
{ {
if(validator.config.fieldName) if(validator.config.fieldName)
{ {
@ -443,7 +443,7 @@ export class Et2Select extends Et2WithSearchMixin(Et2WidgetWithSelect)
} }
// @ts-ignore [allow-protected] // @ts-ignore [allow-protected]
const message = await validator._getMessage({ const message = await validator._getMessage({
modelValue: this.value, modelValue: value,
formControl: this, formControl: this,
fieldName, fieldName,
}); });
@ -451,17 +451,22 @@ export class Et2Select extends Et2WithSearchMixin(Et2WidgetWithSelect)
}.bind(this); }.bind(this);
const resultPromises = validators.map(async validator => const resultPromises = validators.map(async validator =>
{ {
const result = validator.execute(this.value, validator.param, {node: this}); let values = this.value;
if (!Array.isArray(values)) values = [values];
if (!values.length) values = ['']; // so required validation works
values.forEach(async value => {
const result = validator.execute(value, validator.param, {node: this});
if(result === true) if(result === true)
{ {
await doValidate(validator); await doValidate(validator, value);
} }
else else if (result !== false && typeof result.then === 'function')
{ {
result.then(doValidate(validator)); result.then(doValidate(validator, value));
return result; return result;
} }
}); });
});
await Promise.all(resultPromises); await Promise.all(resultPromises);
if(feedbackData.length > 0) if(feedbackData.length > 0)