فهرست منبع

+js/10(Form)/index.html (without 'Power Of The Form')

ilya_shyian 3 سال پیش
والد
کامیت
29a3609342
1فایلهای تغییر یافته به همراه637 افزوده شده و 0 حذف شده
  1. 637 0
      js/10(Form)/index.html

+ 637 - 0
js/10(Form)/index.html

@@ -0,0 +1,637 @@
+<!DOCTYPE html>
+<html lang="en">
+    <head>
+        <meta charset="UTF-8" />
+        <meta http-equiv="X-UA-Compatible" content="IE=edge" />
+        <meta name="viewport" content="width=device-width, initial-scale=1.0" />
+        <title>Document</title>
+    </head>
+    <body>
+        <div id="formContainer"></div>
+        <script>
+            //PASSWORD
+            // function Password(parent, open) {
+            //     let formBody = document.createElement("div");
+            //     let passwordInput = document.createElement("input");
+            //     let isOpenInput = document.createElement("input");
+            //     parent.append(formBody);
+
+            //     passwordInput.type = open ? "text" : "password";
+            //     passwordInput.oninput = () => {
+            //         this.value = passwordInput.value;
+            //         if (typeof this.onChange === "function") {
+            //             this.onChange(this.value);
+            //         }
+            //     };
+
+            //     isOpenInput.type = "checkbox";
+            //     isOpenInput.checked = open;
+            //     isOpenInput.onchange = () => {
+            //         this.open = isOpenInput.checked;
+            //         passwordInput.type = this.open ? "text" : "password";
+            //         if (typeof this.onOpenChange === "function") {
+            //             this.onOpenChange(this.open);
+            //         }
+            //     };
+
+            //     const setValue = (value) => {
+            //         this.value = value;
+            //         passwordInput.value = this.value;
+            //     };
+            //     const getValue = () => {
+            //         return this.value;
+            //     };
+
+            //     const setOpen = (value) => {
+            //         this.open = value;
+            //         isOpenInput.checked = value;
+            //         passwordInput.type = this.open ? "text" : "password";
+            //     };
+
+            //     const getOpen = () => {
+            //         return this.open;
+            //     };
+
+            //     formBody.append(passwordInput);
+            //     formBody.append(isOpenInput);
+
+            //     this.open = open;
+
+            //     this.setValue = setValue;
+            //     this.getValue = getValue;
+
+            //     this.setOpen = setOpen;
+            //     this.getOpen = getOpen;
+
+            //     this.value = passwordInput.value;
+            // }
+
+            // let p = new Password(document.body, true);
+
+            // p.onChange = (data) => console.log(data);
+            // p.onOpenChange = (open) => console.log(open);
+
+            // p.setValue("qwerty");
+            // console.log(p.getValue());
+
+            // p.setOpen(false);
+            // console.log(p.getOpen());
+
+            //LoginForm
+
+            // function LoginForm(parent, open) {
+            //     let formBody = document.createElement("div");
+            //     let passwordInput = document.createElement("input");
+            //     let loginInput = document.createElement("input");
+            //     let isOpenInput = document.createElement("input");
+            //     let loginButton = document.createElement("button");
+            //     parent.append(formBody);
+
+            //     passwordInput.type = open ? "text" : "password";
+            //     passwordInput.oninput = () => {
+            //         this.passwordValue = passwordInput.value;
+            //         loginButton.disabled = checkIfBlank();
+            //         if (typeof this.onPasswordChange === "function") {
+            //             this.onPasswordChange(this.passwordValue);
+            //         }
+            //     };
+
+            //     loginInput.type = "text";
+            //     loginInput.oninput = () => {
+            //         this.loginValue = loginInput.value;
+            //         loginButton.disabled = checkIfBlank();
+            //         if (typeof this.onLoginChange === "function") {
+            //             this.onLoginChange(this.loginValue);
+            //         }
+            //     };
+
+            //     isOpenInput.type = "checkbox";
+            //     isOpenInput.checked = open;
+            //     isOpenInput.onchange = () => {
+            //         this.open = isOpenInput.checked;
+            //         passwordInput.type = this.open ? "text" : "password";
+            //         if (typeof this.onOpenChange === "function") {
+            //             this.onOpenChange(this.open);
+            //         }
+            //     };
+
+            //     loginButton.innerText = "Login";
+
+            //     const setPasswordValue = (value) => {
+            //         this.passwordValue = value;
+            //         passwordInput.value = this.passwordValue;
+            //     };
+            //     const getPasswordValue = () => {
+            //         return this.passwordValue;
+            //     };
+
+            //     const setLoginValue = (value) => {
+            //         this.loginValue = value;
+            //         loginInput.value = this.loginValue;
+            //     };
+            //     const getLoginValue = () => {
+            //         return this.loginValue;
+            //     };
+
+            //     const setOpen = (value) => {
+            //         this.open = value;
+            //         isOpenInput.checked = value;
+            //         passwordInput.type = this.open ? "text" : "password";
+            //     };
+
+            //     const getOpen = () => {
+            //         return this.open;
+            //     };
+
+            //     const checkIfBlank = () => {
+            //         if (this.loginValue.trim().length === 0 || this.passwordValue.trim().length === 0) {
+            //             return true;
+            //         }
+            //         return false;
+            //     };
+
+            //     formBody.append(loginInput);
+            //     formBody.append(passwordInput);
+            //     formBody.append(isOpenInput);
+            //     formBody.append(loginButton);
+
+            //     this.open = open;
+
+            //     this.setPasswordValue = setPasswordValue;
+            //     this.getPasswordValue = getPasswordValue;
+
+            //     this.setLoginValue = setLoginValue;
+            //     this.getLoginValue = getLoginValue;
+
+            //     this.setOpen = setOpen;
+            //     this.getOpen = getOpen;
+
+            //     this.passwordValue = passwordInput.value;
+            //     this.loginValue = loginInput.value;
+
+            //     loginButton.disabled = checkIfBlank();
+            // }
+
+            // let p = new LoginForm(document.body, true);
+
+            // p.onPasswordChange = (data) => console.log(data);
+            // p.onOpenChange = (open) => console.log(open);
+            // p.onLoginChange = (data) => console.log(data);
+
+            // p.setPasswordValue("qwerty");
+            // console.log(p.getPasswordValue());
+
+            // p.setLoginValue("qwerty");
+            // console.log(p.getLoginValue());
+
+            // p.setOpen(false);
+            // console.log(p.getOpen());
+
+            //PASSWORD VERIFY
+
+            // function Password(parent, open) {
+            //     let formBody = document.createElement("div");
+            //     let passwordInput1 = document.createElement("input");
+            //     let passwordInput2 = document.createElement("input");
+            //     let isOpenInput = document.createElement("input");
+            //     let checkButton = document.createElement("button");
+            //     parent.append(formBody);
+
+            //     checkButton.innerText = "checkButton";
+
+            //     passwordInput1.type = open ? "text" : "password";
+            //     passwordInput1.oninput = () => {
+            //         this.value1 = passwordInput1.value;
+            //         checkButton.disabled = !isValid();
+            //         if (typeof this.onPassword1Change === "function") {
+            //             this.onPassword1Change(this.value1);
+            //         }
+            //     };
+
+            //     passwordInput2.type = "password";
+            //     passwordInput2.style.display = !open ? "inline" : "none";
+            //     passwordInput2.oninput = () => {
+            //         this.value2 = passwordInput2.value;
+            //         checkButton.disabled = !isValid();
+            //         console.log(isValid());
+            //         if (typeof this.onPassword2Change === "function") {
+            //             this.onPassword2Change(this.value2);
+            //         }
+            //     };
+
+            //     isOpenInput.type = "checkbox";
+            //     isOpenInput.checked = open;
+            //     isOpenInput.onchange = () => {
+            //         this.open = isOpenInput.checked;
+            //         checkButton.disabled = !isValid();
+            //         passwordInput1.type = this.open ? "text" : "password";
+            //         passwordInput2.style.display = !this.open ? "inline" : "none";
+            //         if (typeof this.onOpenChange === "function") {
+            //             this.onOpenChange(this.open);
+            //         }
+            //     };
+
+            //     const setValue1 = (newValue) => {
+            //         this.value1 = newValue;
+            //         passwordInput1.value = newValue;
+            //         checkButton.disabled = !isValid();
+            //     };
+            //     const setValue2 = (newValue) => {
+            //         this.value2 = newValue;
+            //         passwordInput2.value = newValue;
+            //         checkButton.disabled = !isValid();
+            //     };
+            //     const getValue1 = () => {
+            //         return this.value1;
+            //     };
+
+            //     const getValue2 = () => {
+            //         return this.value2;
+            //     };
+
+            //     const setOpen = (value) => {
+            //         this.open = value;
+            //         isOpenInput.checked = value;
+            //         passwordInput1.type = this.open ? "text" : "password";
+            //         passwordInput2.style.display = !this.open ? "inline" : "none";
+            //         checkButton.disabled = !isValid();
+            //     };
+
+            //     const getOpen = () => {
+            //         return this.open;
+            //     };
+
+            //     const isValid = () => {
+            //         if (this.open === true) {
+            //             return false;
+            //         }
+
+            //         if (this.value1 === this.value2 && this.value1.trim() !== "" && this.value2.trim()) {
+            //             return true;
+            //         }
+
+            //         return false;
+            //     };
+
+            //     formBody.append(passwordInput1);
+            //     formBody.append(passwordInput2);
+            //     formBody.append(isOpenInput);
+            //     formBody.append(checkButton);
+
+            //     this.open = open;
+            //     this.value1 = passwordInput1.value;
+            //     this.value2 = passwordInput2.value;
+
+            //     this.setOpen = setOpen;
+            //     this.getOpen = getOpen;
+
+            //     this.setValue1 = setValue1;
+            //     this.getValue1 = getValue1;
+            //     this.setValue2 = setValue2;
+            //     this.getValue2 = getValue2;
+
+            //     checkButton.disabled = !isValid();
+            // }
+
+            // let p = new Password(document.body, true);
+
+            // p.onPassword1Change = (data) => console.log(data);
+            // p.onPassword2Change = (data) => console.log(data);
+            // p.onOpenChange = (open) => console.log(open);
+
+            // p.setValue1("qwerty");
+            // console.log(p.getValue1());
+            // p.setValue2("qwer");
+            // console.log(p.getValue2());
+
+            // p.setOpen(false);
+            // console.log(p.getOpen());
+
+            //FORM
+            // function Form(el, data, okCallback, cancelCallback) {
+            //     let formBody = document.createElement("div");
+            //     let inputBox = document.createElement("div");
+            //     let okButton = document.createElement("button");
+            //     let validatorErrors = new Set();
+            //     let requiredErrors = new Set();
+            //     let cancelButton = document.createElement("button");
+            //     let initData = { ...data };
+
+            //     okButton.innerHTML = "OK";
+            //     cancelButton.innerHTML = "Cancel";
+            //     el.appendChild(formBody);
+            //     formBody.append(inputBox);
+
+            //     let inputCreators = {
+            //         String(key, value, oninput) {
+            //             if (value.length > 20) {
+            //                 let textarea = document.createElement("textarea");
+            //                 textarea.value = value;
+            //                 textarea.oninput = () => oninput(textarea.value);
+            //                 return textarea;
+            //             } else {
+            //                 let input = document.createElement("input");
+            //                 input.type = "text";
+            //                 if ([...value].every((el) => el === "*")) {
+            //                     input.type = "password";
+            //                 }
+
+            //                 input.placeholder = key;
+            //                 input.value = value;
+            //                 input.oninput = () => oninput(input.value);
+
+            //                 return input;
+            //             }
+            //         },
+            //         Boolean(key, value, oninput) {
+            //             let input = document.createElement("input");
+            //             input.type = "checkbox";
+            //             input.checked = value;
+            //             input.oninput = () => oninput(Boolean(input.checked));
+            //             return input;
+            //         },
+            //         Date(key, value, oninput) {
+            //             let input = document.createElement("input");
+            //             let timeOffset = new Date().getTimezoneOffset();
+            //             let dateInMillSec =
+            //                 new Date(value.toISOString()).getTime() - new Date().getTimezoneOffset() * 1000 * 60;
+
+            //             input.type = "datetime-local";
+            //             input.value = new Date(dateInMillSec).toISOString().slice(0, 16);
+            //             input.oninput = () => oninput(new Date(input.value));
+            //             return input;
+            //         },
+            //     };
+
+            //     let createInputs = (data) => {
+            //         inputBox.innerHTML = "";
+            //         for (let [key, value] of Object.entries(data)) {
+            //             let inputWrapper = document.createElement("div");
+            //             let inputType = value.constructor.name;
+            //             let th = document.createElement("th");
+            //             let inputLabel = document.createElement("label");
+            //             let isRequired = key.trim()[0] === "*";
+            //             let isRequiredChar = document.createElement("span");
+
+            //             inputLabel.style.marginLeft = "5px";
+            //             isRequiredChar.innerText = "* ";
+            //             isRequiredChar.style.color = "red";
+
+            //             if (isRequired) {
+            //                 th.prepend(isRequiredChar);
+            //             }
+            //             th.innerHTML += isRequired ? key.slice(1, key.length) : key;
+
+            //             let input = inputCreators[inputType](key, value, (value) => {
+            //                 let validator;
+            //                 if (isRequired && value.trim().length === 0) {
+            //                     input.style.border = "1px solid red";
+            //                     requiredErrors.add(key);
+            //                 } else {
+            //                     requiredErrors.delete(key);
+            //                 }
+            //                 if (this.validators && typeof this.validators[key] === "function") {
+            //                     validator = this.validators[key];
+            //                 }
+            //                 if (validator) {
+            //                     let validResult = validator(value, key, data, input);
+            //                     if (validResult !== true && validResult.trim() !== "") {
+            //                         inputLabel.innerText = validResult;
+            //                         inputLabel.style.border = "1px solid red";
+            //                         validatorErrors.add(key);
+            //                     } else {
+            //                         inputLabel.innerText = "";
+            //                         inputLabel.style.border = "none";
+            //                         validatorErrors.delete(key);
+            //                     }
+            //                 }
+
+            //                 inputWrapper.append(inputLabel);
+
+            //                 !validatorErrors.has(key) && (this.data[key] = value);
+            //                 okButton.disabled = checkErrors();
+            //             });
+
+            //             inputWrapper.appendChild(th);
+            //             inputWrapper.appendChild(input);
+            //             inputBox.append(inputWrapper);
+            //         }
+            //     };
+
+            //     createInputs(data);
+            //     okButton.disabled = checkErrors();
+
+            //     function checkErrors() {
+            //         if (requiredErrors.size === 0 && validatorErrors.size === 0) {
+            //             return false;
+            //         }
+            //         return true;
+            //     }
+
+            //     if (typeof okCallback === "function") {
+            //         formBody.appendChild(okButton);
+            //         okButton.onclick = (e) => {
+            //             this.okCallback(data);
+            //         };
+            //     }
+
+            //     if (typeof cancelCallback === "function") {
+            //         formBody.appendChild(cancelButton);
+
+            //         cancelButton.onclick = () => {
+            //             this.data = { ...initData };
+            //             console.log(initData);
+            //             createInputs(this.data);
+            //             cancelCallback();
+            //         };
+            //     }
+            //     this.okCallback = okCallback;
+            //     this.cancelCallback = cancelCallback;
+
+            //     this.data = data;
+            //     this.validators = {};
+            // }
+
+            // let form = new Form(
+            //     formContainer,
+            //     {
+            //         "*name": "Anakin",
+            //         "*surname": "SkywalkerSkywalkerSkywalkerSkywalkerSkywalkerSkywalkerSkywalkerSkywalker",
+            //         married: true,
+            //         birthday: new Date(new Date().getTime() - 86400000 * 30 * 365),
+            //     },
+            //     () => console.log("ok"),
+            //     () => console.log("cancel")
+            // );
+            // form.okCallback = () => console.log("ok2");
+
+            // form.validators.surname = (value, key, data, input) =>
+            //     value.length > 2 && value[0].toUpperCase() == value[0] && !value.includes(" ") ? true : "Wrong surname";
+            // form.validators["*name"] = (value, key, data, input) =>
+            //     value.length > 3 && value[0].toUpperCase() == value[0] && !value.includes(" ") ? true : "Wrong name";
+            // form.validators["birthday"] = (value, key, data, input) => {
+            //     if (new Date(value.toISOString().slice(0, 16)) <= new Date("1900-01-01")) {
+            //         return "Wrong date";
+            //     }
+
+            //     if (
+            //         new Date(value.toISOString().slice(0, 16)).getTime() >=
+            //         new Date().getTime() - new Date().getTimezoneOffset() * 1000 * 60 - 3 * 365 * 86400000
+            //     ) {
+            //         return "Wrong date";
+            //     }
+            //     return true;
+            // };
+
+            // console.log(form);
+
+            //POWER OF THE FORM
+
+            // function Password(parent, open) {
+            //     let formBody = document.createElement("div");
+            //     let passwordInput1 = document.createElement("input");
+            //     let passwordInput2 = document.createElement("input");
+            //     let isOpenInput = document.createElement("input");
+            //     let checkButton = document.createElement("button");
+            //     let errorDiv = document.createElement("div");
+            //     let errors = {
+            //         blankFields: "Password fields cannot be empty",
+            //         notMatch: "Password confirmation does not match",
+            //     };
+            //     let errorSet = new Set();
+            //     parent.append(formBody);
+            //     errorDiv.style.color = "red";
+
+            //     checkButton.innerText = "Submit";
+
+            //     passwordInput1.type = open ? "text" : "password";
+            //     passwordInput1.oninput = () => {
+            //         this.value1 = passwordInput1.value;
+            //         checkButton.disabled = !isValid();
+            //         if (typeof this.onPassword1Change === "function") {
+            //             this.onPassword1Change(this.value1);
+            //         }
+            //     };
+
+            //     passwordInput2.type = "password";
+            //     passwordInput2.style.display = !open ? "inline" : "none";
+            //     passwordInput2.oninput = () => {
+            //         this.value2 = passwordInput2.value;
+            //         checkButton.disabled = !isValid();
+            //         console.log(isValid());
+            //         if (typeof this.onPassword2Change === "function") {
+            //             this.onPassword2Change(this.value2);
+            //         }
+            //     };
+
+            //     isOpenInput.type = "checkbox";
+            //     isOpenInput.checked = open;
+            //     isOpenInput.onchange = () => {
+            //         this.open = isOpenInput.checked;
+            //         checkButton.disabled = !isValid();
+            //         passwordInput1.type = this.open ? "text" : "password";
+            //         passwordInput2.style.display = !this.open ? "inline" : "none";
+            //         if (typeof this.onOpenChange === "function") {
+            //             this.onOpenChange(this.open);
+            //         }
+            //     };
+
+            //     const setValue1 = (newValue) => {
+            //         this.value1 = newValue;
+            //         passwordInput1.value = newValue;
+            //         checkButton.disabled = !isValid();
+            //     };
+            //     const setValue2 = (newValue) => {
+            //         this.value2 = newValue;
+            //         passwordInput2.value = newValue;
+            //         checkButton.disabled = !isValid();
+            //     };
+            //     const getValue1 = () => {
+            //         return this.value1;
+            //     };
+
+            //     const getValue2 = () => {
+            //         return this.value2;
+            //     };
+
+            //     const setOpen = (value) => {
+            //         this.open = value;
+            //         isOpenInput.checked = value;
+            //         passwordInput1.type = this.open ? "text" : "password";
+            //         passwordInput2.style.display = !this.open ? "inline" : "none";
+            //         checkButton.disabled = !isValid();
+            //     };
+
+            //     const getOpen = () => {
+            //         return this.open;
+            //     };
+
+            //     const isValid = () => {
+            //         if (this.open === true) {
+            //             return false;
+            //         }
+
+            //         if (this.value1.trim() === "" || this.value2.trim() === "") {
+            //             errorSet.add(errors.blankFields);
+            //             showErrors();
+            //             return false;
+            //         } else {
+            //             errorSet.delete(errors.blankFields);
+            //         }
+
+            //         if (this.value1 !== this.value2) {
+            //             errorSet.add(errors.notMatch);
+            //             showErrors();
+            //             return false;
+            //         } else {
+            //             errorSet.delete(errors.notMatch);
+            //         }
+            //         showErrors();
+            //         return true;
+            //     };
+
+            //     const showErrors = () => {
+            //         let str = "";
+            //         for (let er of errorSet) {
+            //             str += er + "<br>";
+            //         }
+            //         errorDiv.innerHTML = str;
+            //     };
+
+            //     formBody.append(passwordInput1);
+            //     formBody.append(passwordInput2);
+            //     formBody.append(isOpenInput);
+            //     formBody.append(checkButton);
+            //     formBody.append(errorDiv);
+
+            //     this.open = open;
+            //     this.value1 = passwordInput1.value;
+            //     this.value2 = passwordInput2.value;
+
+            //     this.setOpen = setOpen;
+            //     this.getOpen = getOpen;
+
+            //     this.setValue1 = setValue1;
+            //     this.getValue1 = getValue1;
+            //     this.setValue2 = setValue2;
+            //     this.getValue2 = getValue2;
+
+            //     checkButton.disabled = !isValid();
+            // }
+
+            // let p = new Password(document.body, true);
+
+            // p.onPassword1Change = (data) => console.log(data);
+            // p.onPassword2Change = (data) => console.log(data);
+            // p.onOpenChange = (open) => console.log(open);
+
+            // p.setValue1("qwerty");
+            // console.log(p.getValue1());
+            // p.setValue2("qwer");
+            // console.log(p.getValue2());
+
+            // p.setOpen(false);
+            // console.log(p.getOpen());
+        </script>
+    </body>
+</html>