- Deprecate "needed" attribute in favour of standard "required"

- Fix some required CSS
This commit is contained in:
nathan 2022-02-25 10:21:16 -07:00
parent cdcb85f4f3
commit e048b26235
4 changed files with 22 additions and 11 deletions

View File

@ -1,6 +1,6 @@
import {et2_IInput, et2_IInputNode, et2_ISubmitListener} from "../et2_core_interfaces"; import {et2_IInput, et2_IInputNode, et2_ISubmitListener} from "../et2_core_interfaces";
import {Et2Widget} from "../Et2Widget/Et2Widget"; import {Et2Widget} from "../Et2Widget/Et2Widget";
import {dedupeMixin, PropertyValues} from "@lion/core"; import {css, dedupeMixin, PropertyValues} from "@lion/core";
import {ManualMessage} from "../Validators/ManualMessage"; import {ManualMessage} from "../Validators/ManualMessage";
import {Required} from "../Validators/Required"; import {Required} from "../Validators/Required";
@ -47,7 +47,12 @@ const Et2InputWidgetMixin = (superclass) =>
static get styles() static get styles()
{ {
return [ return [
...super.styles super.styles,
css`
/* Needed so required can show through */
::slotted(input), input {
background-color: transparent;
}`
]; ];
} }
@ -67,11 +72,10 @@ const Et2InputWidgetMixin = (superclass) =>
type: Boolean type: Boolean
}, },
needed: { required: {
type: Boolean, type: Boolean,
reflect: true reflect: true
}, },
onchange: { onchange: {
type: Function type: Function
}, },
@ -100,14 +104,13 @@ const Et2InputWidgetMixin = (superclass) =>
super.updated(changedProperties); super.updated(changedProperties);
// Needed changed, add / remove validator // Needed changed, add / remove validator
if(changedProperties.has('needed')) if(changedProperties.has('required'))
{ {
// Remove class // Remove class
this.classList.remove("et2_required") this.classList.remove("et2_required")
// Remove all existing Required validators (avoids duplicates) // Remove all existing Required validators (avoids duplicates)
this.validators = (this.validators || []).filter((validator) => validator instanceof Required) this.validators = (this.validators || []).filter((validator) => validator instanceof Required)
this.setAttribute("required", this.needed); if(this.required)
if(this.needed)
{ {
this.validators.push(new Required()); this.validators.push(new Required());
this.classList.add("et2_required"); this.classList.add("et2_required");
@ -231,6 +234,7 @@ const Et2InputWidgetMixin = (superclass) =>
transformAttributes(attrs) transformAttributes(attrs)
{ {
super.transformAttributes(attrs); super.transformAttributes(attrs);
// Check whether an validation error entry exists // Check whether an validation error entry exists
if(this.id && this.getArrayMgr("validation_errors")) if(this.id && this.getArrayMgr("validation_errors"))
{ {

View File

@ -19,7 +19,7 @@ export class Et2Textbox extends Et2InputWidget(LionInput)
static get styles() static get styles()
{ {
return [ return [
...super.styles, super.styles,
css` css`
:host([type="hidden"]) { :host([type="hidden"]) {
display: none; display: none;

View File

@ -1180,8 +1180,15 @@ function transformAttributes(widget, mgr : et2_arrayMgr, attributes)
// If there is not attribute set, ignore it. Widget sets its own default. // If there is not attribute set, ignore it. Widget sets its own default.
if(typeof attrValue === "undefined") if(typeof attrValue === "undefined")
{ {
return; continue;
} }
// "needed" is deprecated, use "required"
if(attribute == "needed")
{
attribute = "required";
}
const property = widget_class.getPropertyOptions(attribute); const property = widget_class.getPropertyOptions(attribute);
switch(typeof property === "object" ? property.type : property) switch(typeof property === "object" ? property.type : property)

View File

@ -930,9 +930,9 @@ export class etemplate2
} }
else if(submit instanceof Promise) else if(submit instanceof Promise)
{ {
invalid.push(submit.then(function(sub) invalid.push(submit.then(function(ok)
{ {
return sub ? false : this; return ok ? false : this;
}.bind(_widget))); }.bind(_widget)));
} }
}, this, et2_ISubmitListener); }, this, et2_ISubmitListener);