forked from gopinav/Angular-Forms-Tutorial
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathscript.js
More file actions
64 lines (54 loc) · 2.11 KB
/
Copy pathscript.js
File metadata and controls
64 lines (54 loc) · 2.11 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
document.addEventListener('DOMContentLoaded', function() {
const form = document.getElementById('radioForm');
const result = document.getElementById('result');
// Handle form submission
form.addEventListener('submit', function(e) {
e.preventDefault();
// Get the selected radio button value
const selectedOption = document.querySelector('input[name="answer"]:checked');
if (selectedOption) {
const answer = selectedOption.value;
showResult(answer);
} else {
showError('Please select an option before submitting.');
}
});
// Add click animation to radio options
const radioOptions = document.querySelectorAll('.radio-option');
radioOptions.forEach(option => {
option.addEventListener('click', function() {
const radio = this.querySelector('input[type="radio"]');
radio.checked = true;
// Add visual feedback
this.style.transform = 'scale(0.98)';
setTimeout(() => {
this.style.transform = 'scale(1)';
}, 150);
});
});
function showResult(answer) {
result.className = 'result success';
result.innerHTML = `
<strong>Thank you for your response!</strong><br>
You selected: <em>${answer.charAt(0).toUpperCase() + answer.slice(1)}</em>
`;
result.style.display = 'block';
// Scroll to result
result.scrollIntoView({ behavior: 'smooth', block: 'nearest' });
}
function showError(message) {
result.className = 'result error';
result.textContent = message;
result.style.display = 'block';
// Hide error after 3 seconds
setTimeout(() => {
result.style.display = 'none';
}, 3000);
}
// Add keyboard navigation support
document.addEventListener('keydown', function(e) {
if (e.key === 'Enter' && document.activeElement.type === 'radio') {
form.dispatchEvent(new Event('submit'));
}
});
});