From 3d3443dc02cc75a2b29edebc5a2b48c2205956f4 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=D0=98=D0=B3=D0=BE=D1=80=D1=8C=20=D0=A9=D0=B5=D1=80=D0=B1?= =?UTF-8?q?=D0=B0=D0=BA=D0=BE=D0=B2?= Date: Mon, 2 Sep 2024 12:45:50 +0300 Subject: [PATCH] focus --- source/js/main.js | 3 +- source/js/modules/form-valid.js | 78 +++++++++++++++++++++++++++++++++ source/sass/blocks/form.scss | 14 ++++-- 3 files changed, 89 insertions(+), 6 deletions(-) diff --git a/source/js/main.js b/source/js/main.js index e69b186a1..1236561e7 100644 --- a/source/js/main.js +++ b/source/js/main.js @@ -7,7 +7,7 @@ import { activateAdvSlider } from './modules/swiper-adv'; import { toggleSwiper } from './modules/toggle-swiper'; import { activateGallerySlider } from './modules/swiper-gallery'; import { toggleMenu } from './modules/menu'; -import { formValid } from './modules/form-valid'; + closePressing(); activateHeroSlider(); @@ -27,4 +27,3 @@ window.onresize = function() { toggleSwiper(); }; -formValid(); diff --git a/source/js/modules/form-valid.js b/source/js/modules/form-valid.js index 8b1378917..c38e6963c 100644 --- a/source/js/modules/form-valid.js +++ b/source/js/modules/form-valid.js @@ -1 +1,79 @@ +const validateForm = () => { + const form = document.querySelector('form'); + const phoneInput = document.querySelector('input[type="tel"]'); + const emailInput = document.querySelector('input[type="email"]'); + + if (form && phoneInput && emailInput) { + const inputs = form.querySelectorAll('input'); + const digitsOnlyRegex = /^\d+$/; + const emailRegex = /^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}$|^[a-zA-Z0-9._%+-]+@[а-яА-ЯёЁ0-9.-]+\.[рф]{2,3}$/; + + const toggleError = (input, show) => { + const parent = input.parentElement; + parent.classList.toggle('error', show); + input.classList.toggle('error', show); + }; + + const validateInput = (input, regex) => { + const value = input.value.trim(); + toggleError(input, value === '' || !regex.test(value)); + }; + + form.addEventListener('submit', (event) => { + let isValid = true; + + inputs.forEach((input) => { + if (input.value.trim() === '') { + isValid = false; + toggleError(input, true); + } else { + if (input.name === 'phone') { + validateInput(input, digitsOnlyRegex); + } + if (input.name === 'email') { + validateInput(input, emailRegex); + } + if (input.classList.contains('error')) { + isValid = false; + } + } + }); + + if (!isValid) { + event.preventDefault(); + } + }); + + inputs.forEach((input) => { + const label = input.previousElementSibling; + + input.addEventListener('focus', () => { + if (label && label.tagName.toLowerCase() === 'label') { + label.style.display = 'none'; + } + input.classList.add('show-placeholder'); + toggleError(input, false); + }); + + input.addEventListener('blur', () => { + if (label && label.tagName.toLowerCase() === 'label' && input.value.trim() === '') { + label.style.display = 'block'; + } + input.classList.remove('show-placeholder'); + }); + + input.addEventListener('input', () => { + if (label && label.tagName.toLowerCase() === 'label') { + label.style.display = input.value.trim() === '' && document.activeElement !== input ? 'block' : 'none'; + } + }); + + if (label && label.tagName.toLowerCase() === 'label' && input.value.trim() !== '') { + label.style.display = 'none'; + } + }); + } +}; + +export { validateForm }; diff --git a/source/sass/blocks/form.scss b/source/sass/blocks/form.scss index 694652d21..02832e080 100644 --- a/source/sass/blocks/form.scss +++ b/source/sass/blocks/form.scss @@ -153,14 +153,20 @@ } } -.form__input:focus + .form__label { +input:focus + label, +input:not(:placeholder-shown) + label { display: none; - color: transparent; } -.form__input:active + .form__label { + +.form__input:focus + label, +.form__input:required:valid + label { + display: none; +} + +.form__label:focus + label, +.form__label:required:valid + label { display: none; - color: transparent; }