interface.js: implement checkbox element

This commit is contained in:
dogeystamp 2023-01-02 18:11:47 -05:00
parent 50bb98a109
commit 71d4e3f58d
Signed by: dogeystamp
GPG Key ID: 7225FE3592EFFA38
3 changed files with 52 additions and 16 deletions

View File

@ -1,5 +1,6 @@
let encForm = new Form({id: "encryption", tag: document.getElementById("encryption")}); let encForm = new Form({id: "encryption", tag: document.getElementById("encryption")});
let encAdv = encForm.createCheckBox({label: "Advanced settings"});
let encMsg = encForm.createTextArea({label: "Message"}); let encMsg = encForm.createTextArea({label: "Message"});
let encPass = encForm.createPasswordInput({label: "Password"}); let encPass = encForm.createPasswordInput({label: "Password"});
let encButton = encForm.createButton({label: "Encrypt"}); let encButton = encForm.createButton({label: "Encrypt"});

View File

@ -93,12 +93,27 @@ class Form extends InterfaceElement {
createButton(params) { createButton(params) {
params.tag = document.createElement("button"); params.tag = document.createElement("button");
params.tag.appendChild(document.createTextNode(params.label)); params.labelTag = document.createTextNode(params.label);
params.label = ""; params.tag.appendChild(params.labelTag);
dataTypeSupports(params, ["none"]); dataTypeSupports(params, ["none"]);
return this.appendElement(new FormElement(params)); return this.appendElement(new FormElement(params));
} }
createCheckBox(params) {
params.fragment = new DocumentFragment();
params.tag = document.createElement("input");
params.tag.setAttribute("type", "checkbox");
params.labelTag = document.createElement("label");
params.labelTag.appendChild(document.createTextNode(params.label));
let li = document.createElement("li");
li.classList.add("checkbox-container");
params.fragment.appendChild(li);
li.appendChild(params.tag);
li.appendChild(params.labelTag);
dataTypeSupports(params, ["bool"]);
return this.appendElement(new FormElement(params));
}
createOutput(params) { createOutput(params) {
params.tag = document.createElement("textarea"); params.tag = document.createElement("textarea");
params.tag.setAttribute("readonly", true); params.tag.setAttribute("readonly", true);
@ -119,7 +134,7 @@ function b64ToBuf (b64) {
function bufToB64 (buf) { function bufToB64 (buf) {
let bytes = new Uint8Array(buf); let bytes = new Uint8Array(buf);
let ascii = '' let ascii = '';
for (var i = 0; i < bytes.byteLength; i++) { for (var i = 0; i < bytes.byteLength; i++) {
ascii += String.fromCharCode(bytes[i]); ascii += String.fromCharCode(bytes[i]);
} }
@ -136,29 +151,31 @@ class FormElement extends InterfaceElement {
this.handle.disabled = !this.#enabled; this.handle.disabled = !this.#enabled;
} }
constructor({form, tag, label="", dataType, advanced=false, enabled=true}) { constructor({form, tag, labelTag, label="", fragment, dataType, advanced=false, enabled=true}) {
super({tag}); super({tag});
this.advanced = advanced;
this.clearAlerts = this.clearAlerts.bind(this); this.clearAlerts = this.clearAlerts.bind(this);
if (label !== "") {
this.label = document.createElement("label");
this.label.appendChild(document.createTextNode(label));
}
this.dataType = dataType; this.dataType = dataType;
this.enabled = enabled; this.enabled = enabled;
this.advanced = advanced;
if (this.advanced === true) this.hidden = true; if (this.advanced === true) this.hidden = true;
this.fragment = new DocumentFragment(); this.labelText = label;
if (this.label !== undefined) { if (labelTag === undefined) {
this.fragment.appendChild(this.label); this.labelTag = document.createElement("label");
this.labelTag.appendChild(document.createTextNode(this.labelText));
}
if (fragment === undefined) {
this.fragment = new DocumentFragment();
if (this.labelTag !== undefined) {
this.fragment.appendChild(this.labelTag);
}
this.fragment.appendChild(this.handle);
} else {
this.fragment = fragment;
} }
this.fragment.appendChild(this.handle);
if (this.advanced === true) this.hidden = !form.advanced; if (this.advanced === true) this.hidden = !form.advanced;
} }
@ -189,6 +206,8 @@ class FormElement extends InterfaceElement {
this.alertBox("alert-error", "Invalid JSON encoding."); this.alertBox("alert-error", "Invalid JSON encoding.");
return; return;
} }
case "bool":
return this.handle.checked;
case "none": case "none":
return undefined; return undefined;
} }
@ -204,6 +223,9 @@ class FormElement extends InterfaceElement {
case "json-b64": case "json-b64":
this.handle.value = btoa(JSON.stringify(x)); this.handle.value = btoa(JSON.stringify(x));
break; break;
case "bool":
this.handle.checked = x;
break;
} }
} }

View File

@ -54,6 +54,19 @@ textarea:disabled, input:disabled {
opacity: 40%; opacity: 40%;
} }
.checkbox-container {
list-style: none;
}
.checkbox-container label {
display: inline;
margin-left: 0.5em;
}
.checkbox-container input {
display: inline;
height: 1em;
transform: scale(1.25);
}
.alert { .alert {
border-radius: 3px; border-radius: 3px;
margin-top: 0.5em; margin-top: 0.5em;