File size: 1,089 Bytes
60a860d |
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 |
// Shared JavaScript functions
document.addEventListener('DOMContentLoaded', function() {
// Smooth scrolling for anchor links
document.querySelectorAll('a[href^="#"]').forEach(anchor => {
anchor.addEventListener('click', function (e) {
e.preventDefault();
document.querySelector(this.getAttribute('href')).scrollIntoView({
behavior: 'smooth'
});
});
});
// Add animation classes to elements
const animateElements = document.querySelectorAll('.fade-in, .slide-up');
animateElements.forEach(el => {
el.style.opacity = '0';
});
const observer = new IntersectionObserver((entries) => {
entries.forEach(entry => {
if (entry.isIntersecting) {
entry.target.classList.add(entry.target.dataset.animation || 'fade-in');
entry.target.style.opacity = '1';
observer.unobserve(entry.target);
}
});
}, { threshold: 0.1 });
animateElements.forEach(el => {
observer.observe(el);
});
}); |