|
1 | 1 | const VISA_REG_EX = /^(4[0-9]{15})$/; |
2 | 2 |
|
3 | 3 | function onChangeEmailField(e) { |
4 | | - const field = e.target; |
5 | | - const parent = field.parentElement; |
6 | | - const errorSpan = parent.querySelector('.error'); |
7 | | - const value = field.value; |
| 4 | + const $field = e.target; |
| 5 | + const $parent = $field.parentElement; |
| 6 | + const $error = $parent.querySelector('.error'); |
| 7 | + const value = $field.value; |
8 | 8 | const isValid = value.includes('@'); |
9 | 9 | if (isValid) { |
10 | | - parent.classList.remove('invalid'); |
11 | | - errorSpan.innerHTML = ''; |
| 10 | + $parent.classList.remove('invalid'); |
| 11 | + $error.innerHTML = ''; |
12 | 12 | } else { |
13 | | - parent.classList.add('invalid'); |
14 | | - errorSpan.innerHTML = 'Email address is not valid.'; |
| 13 | + $parent.classList.add('invalid'); |
| 14 | + $error.innerHTML = 'Email address is not valid.'; |
15 | 15 | } |
16 | 16 | } |
17 | 17 |
|
18 | 18 | function onChangeCardField(e) { |
19 | | - const field = e.target; |
20 | | - const parent = field.parentElement; |
21 | | - const errorSpan = parent.querySelector('.error'); |
22 | | - let value = field.value; |
| 19 | + const $field = e.target; |
| 20 | + const $parent = $field.parentElement; |
| 21 | + const $error = $parent.querySelector('.error'); |
| 22 | + let value = $field.value; |
23 | 23 | value = value.replace(/\s/g, ''); |
24 | 24 | const isValid = VISA_REG_EX.test(value); |
25 | 25 | if (isValid) { |
26 | | - parent.classList.remove('invalid'); |
27 | | - errorSpan.innerHTML = ''; |
| 26 | + $parent.classList.remove('invalid'); |
| 27 | + $error.innerHTML = ''; |
28 | 28 | } else { |
29 | | - parent.classList.add('invalid'); |
30 | | - errorSpan.innerHTML = 'Your card number is invalid.'; |
| 29 | + $parent.classList.add('invalid'); |
| 30 | + $error.innerHTML = 'Your card number is invalid.'; |
31 | 31 | } |
32 | 32 | } |
33 | 33 |
|
34 | 34 | function onInputCardField(e) { |
35 | | - const field = e.target; |
36 | | - let value = field.value; |
| 35 | + const $field = e.target; |
| 36 | + let value = $field.value; |
37 | 37 | value = value.replace(/[^0-9]+/g, ''); |
38 | 38 | value = value.replace(/(.{4})/g, '$1 '); |
39 | 39 | value = value.trim(); |
40 | | - e.target.value = value; |
| 40 | + $field.value = value; |
41 | 41 | } |
42 | 42 |
|
43 | 43 | document.querySelector('#email-field').addEventListener('change', onChangeEmailField); |
|
0 commit comments