forked from extern/egroupware
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:
parent
6c8e85311f
commit
489eb615ac
@ -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)
|
||||||
|
Loading…
Reference in New Issue
Block a user