improve interface scripts
- dynamically hide/unhide advanced options - add base64 handlers for raw data inputs
This commit is contained in:
parent
30bce07f67
commit
2bcfefbd2a
@ -1,5 +1,5 @@
|
|||||||
class Form {
|
class Form {
|
||||||
constructor(id, formTag) {
|
constructor({id, formTag}) {
|
||||||
this.id = id;
|
this.id = id;
|
||||||
|
|
||||||
if (formTag !== undefined) {
|
if (formTag !== undefined) {
|
||||||
@ -8,8 +8,44 @@ class Form {
|
|||||||
this.handle = document.createElement("div");
|
this.handle = document.createElement("div");
|
||||||
}
|
}
|
||||||
|
|
||||||
this.inputs = new Map();
|
this.elements = new Map();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#advanced = false;
|
||||||
|
get advanced() {
|
||||||
|
return this.#advanced;
|
||||||
|
}
|
||||||
|
set advanced(x) {
|
||||||
|
this.#advanced = x;
|
||||||
|
for (const [id, element] of this.elements.entries()) {
|
||||||
|
if (element.advanced === true) {
|
||||||
|
if (this.advanced === true) {
|
||||||
|
element.hidden = false;
|
||||||
|
} else {
|
||||||
|
element.hidden = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function b64ToBuf (b64) {
|
||||||
|
let ascii = atob(b64);
|
||||||
|
let buf = new ArrayBuffer(ascii.length);
|
||||||
|
let bytes = new Uint8Array(buf);
|
||||||
|
for (var i = 0; i < ascii.length; i++) {
|
||||||
|
bytes[i] = ascii.charCodeAt(i);
|
||||||
|
}
|
||||||
|
return buf;
|
||||||
|
}
|
||||||
|
|
||||||
|
function bufToB64 (buf) {
|
||||||
|
let bytes = new Uint8Array(buf);
|
||||||
|
let ascii = ''
|
||||||
|
for (var i = 0; i < bytes.byteLength; i++) {
|
||||||
|
ascii += String.fromCharCode(bytes[i]);
|
||||||
|
}
|
||||||
|
return btoa(ascii);
|
||||||
}
|
}
|
||||||
|
|
||||||
class FormElement {
|
class FormElement {
|
||||||
@ -22,9 +58,22 @@ class FormElement {
|
|||||||
this.handle.disabled = !this.#enabled;
|
this.handle.disabled = !this.#enabled;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#hidden = true;
|
||||||
|
get hidden() {
|
||||||
|
return this.#hidden;
|
||||||
|
}
|
||||||
|
set hidden(x) {
|
||||||
|
this.#hidden = x;
|
||||||
|
|
||||||
|
this.handle.hidden = this.hidden;
|
||||||
|
if (this.label !== undefined) {
|
||||||
|
this.label.hidden = this.hidden;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
constructor({id, type, form, label="", dataType="plaintext", advanced=false, enabled=true}) {
|
constructor({id, type, form, label="", dataType="plaintext", advanced=false, enabled=true}) {
|
||||||
this.id = id;
|
this.id = id;
|
||||||
this.dataType = dataType;
|
|
||||||
this.advanced = advanced;
|
this.advanced = advanced;
|
||||||
|
|
||||||
if (label !== "") {
|
if (label !== "") {
|
||||||
@ -33,6 +82,7 @@ class FormElement {
|
|||||||
}
|
}
|
||||||
|
|
||||||
this.type = type;
|
this.type = type;
|
||||||
|
|
||||||
switch (type) {
|
switch (type) {
|
||||||
case "textbox":
|
case "textbox":
|
||||||
this.handle = document.createElement("input");
|
this.handle = document.createElement("input");
|
||||||
@ -46,24 +96,82 @@ class FormElement {
|
|||||||
break;
|
break;
|
||||||
case "button":
|
case "button":
|
||||||
this.handle = document.createElement("button");
|
this.handle = document.createElement("button");
|
||||||
|
dataType = "none"
|
||||||
break;
|
break;
|
||||||
case "output":
|
case "output":
|
||||||
this.handle = document.createElement("textarea");
|
this.handle = document.createElement("textarea");
|
||||||
this.handle.setAttribute("readonly", true);
|
this.handle.setAttribute("readonly", true);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
console.error(`Unknown input type: ${type}`)
|
throw `Unknown input type: ${type}`;
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
this.dataType = dataType;
|
||||||
|
|
||||||
this.enabled = enabled;
|
this.enabled = enabled;
|
||||||
|
this.handle.id = this.id;
|
||||||
|
|
||||||
|
if (this.advanced === true) this.hidden = true;
|
||||||
|
|
||||||
if (form !== undefined) {
|
if (form !== undefined) {
|
||||||
|
this.form = form;
|
||||||
if (this.label !== undefined) {
|
if (this.label !== undefined) {
|
||||||
this.label.setAttribute("for", form.id);
|
this.label.setAttribute("for", this.id);
|
||||||
form.handle.appendChild(this.label);
|
form.handle.appendChild(this.label);
|
||||||
}
|
}
|
||||||
form.handle.appendChild(this.handle);
|
form.handle.appendChild(this.handle);
|
||||||
|
form.elements.set(id, this);
|
||||||
|
|
||||||
|
if (this.advanced === true) this.hidden = !form.advanced;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// plaintext is string data
|
||||||
|
// b64 is raw ArrayBuffer data
|
||||||
|
// or none, which gives undefined
|
||||||
|
#dataType = "none";
|
||||||
|
get dataType() {
|
||||||
|
return this.#dataType;
|
||||||
|
}
|
||||||
|
set dataType(x) {
|
||||||
|
function err(type, x) {
|
||||||
|
throw `'${type}' element can not support '${x}' data type`;
|
||||||
|
}
|
||||||
|
|
||||||
|
switch (x) {
|
||||||
|
case "plaintext":
|
||||||
|
case "b64":
|
||||||
|
let valid = ["textbox", "password", "textarea", "output"];
|
||||||
|
if (!valid.includes(this.type)) err(this.type, x);
|
||||||
|
break;
|
||||||
|
case "none":
|
||||||
|
if (this.type !== "button") err(this.type, x);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
throw `Unknown data type: ${x}`;
|
||||||
|
}
|
||||||
|
|
||||||
|
this.#dataType = x;
|
||||||
|
}
|
||||||
|
|
||||||
|
#value;
|
||||||
|
get value() {
|
||||||
|
switch (this.dataType) {
|
||||||
|
case "plaintext":
|
||||||
|
return this.handle.value;
|
||||||
|
case "b64":
|
||||||
|
// TODO: error handling
|
||||||
|
return b64ToBuf(this.handle.value);
|
||||||
|
case "none":
|
||||||
|
return undefined;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
set value(x) {
|
||||||
|
switch (this.dataType) {
|
||||||
|
case "plaintext":
|
||||||
|
this.handle.value = x;
|
||||||
|
case "b64":
|
||||||
|
this.handle.value = bufToB64(x);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -20,6 +20,7 @@ let inp3 = new FormElement({
|
|||||||
type: "textarea",
|
type: "textarea",
|
||||||
label: "Large text box",
|
label: "Large text box",
|
||||||
enabled: true,
|
enabled: true,
|
||||||
|
dataType: "b64",
|
||||||
form: form
|
form: form
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -35,5 +36,14 @@ let out = new FormElement({
|
|||||||
id: "output",
|
id: "output",
|
||||||
type: "output",
|
type: "output",
|
||||||
label: "Output box",
|
label: "Output box",
|
||||||
|
dataType: "b64",
|
||||||
|
form: form
|
||||||
|
});
|
||||||
|
|
||||||
|
let outAdvanced = new FormElement({
|
||||||
|
id: "output-advanced",
|
||||||
|
type: "output",
|
||||||
|
label: "Output box (advanced setting)",
|
||||||
|
advanced: true,
|
||||||
form: form
|
form: form
|
||||||
});
|
});
|
@ -51,6 +51,11 @@ textarea:disabled, input:disabled {
|
|||||||
opacity: 40%;
|
opacity: 40%;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
[hidden] {
|
||||||
|
height: 0;
|
||||||
|
opacity: 0;
|
||||||
|
}
|
||||||
|
|
||||||
p {
|
p {
|
||||||
text-align: justify;
|
text-align: justify;
|
||||||
}
|
}
|
||||||
|
@ -4,12 +4,12 @@
|
|||||||
<meta charset="UTF-8">
|
<meta charset="UTF-8">
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||||
<meta http-equiv="X-UA-Compatible" content="ie=edge">
|
<meta http-equiv="X-UA-Compatible" content="ie=edge">
|
||||||
<title>encryptme: AES encryption and decryption</title>
|
<title>encryptme: interface logic testing page</title>
|
||||||
<link rel="stylesheet" href="style.css">
|
<link rel="stylesheet" href="style.css">
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<h1>encryptme</h1>
|
<h1>encryptme</h1>
|
||||||
<script src="scripts/interface.js"></script>
|
<script src="scripts/interface.js"></script>
|
||||||
<script src="scripts/aes.js"></script>
|
<script src="scripts/testpage.js"></script>
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
Loading…
Reference in New Issue
Block a user