interface.js: add number input

This commit is contained in:
dogeystamp 2023-01-04 14:55:12 -05:00
parent 18a58786ac
commit 6964103c25
Signed by: dogeystamp
GPG Key ID: 7225FE3592EFFA38

View File

@ -143,6 +143,17 @@ class Form extends InterfaceElement {
return this.appendElement(new FormElement(params)); return this.appendElement(new FormElement(params));
} }
createNumberInput(params) {
params.tag = document.createElement("input");
params.tag.setAttribute("type", "number");
dataTypeSupports(params, ["number"]);
if (params.maxValue !== undefined) params.tag.max = params.maxValue;
if (params.minValue !== undefined) params.tag.min = params.minValue;
if (params.step !== undefined) params.tag.step = params.step;
if (params.required !== undefined) params.tag.required = params.required;
return this.appendElement(new FormElement(params));
}
createTextArea(params) { createTextArea(params) {
params.tag = document.createElement("textarea"); params.tag = document.createElement("textarea");
dataTypeSupports(params, ["plaintext", "b64", "json-b64"]); dataTypeSupports(params, ["plaintext", "b64", "json-b64"]);
@ -232,6 +243,12 @@ class FormElement extends InterfaceElement {
get value() { get value() {
this.clearAlerts(); this.clearAlerts();
switch (this.dataType) { switch (this.dataType) {
case "number":
if (this.handle.checkValidity() == false) {
this.alertBox("alert-error", this.handle.validationMessage);
return undefined;
}
return Number(this.handle.value);
case "plaintext": case "plaintext":
return this.handle.value; return this.handle.value;
case "b64": case "b64":
@ -263,6 +280,7 @@ class FormElement extends InterfaceElement {
} }
set value(x) { set value(x) {
switch (this.dataType) { switch (this.dataType) {
case "number":
case "plaintext": case "plaintext":
this.handle.value = x; this.handle.value = x;
break; break;