(function() { 'use strict'; // ====== IMAGE DATA ====== const images = [ "https://carpool.tamu.edu/wp-content/uploads/2023/09/carpool-18.jpg", "https://carpool.tamu.edu/wp-content/uploads/2023/09/carpool-17.jpg", "https://carpool.tamu.edu/wp-content/uploads/2023/09/carpool-14.jpg", "https://carpool.tamu.edu/wp-content/uploads/2023/09/carpool-11.jpg", "https://carpool.tamu.edu/wp-content/uploads/2023/09/carpool-9.jpg", "https://carpool.tamu.edu/wp-content/uploads/2023/09/carpool-8.jpg", "https://carpool.tamu.edu/wp-content/uploads/2023/09/carpool-13.jpg", "https://carpool.tamu.edu/wp-content/uploads/2023/09/carpool-7.jpg", "https://carpool.tamu.edu/wp-content/uploads/2023/09/carpool-6.jpg", "https://carpool.tamu.edu/wp-content/uploads/2023/09/carpool-5.jpg", "https://carpool.tamu.edu/wp-content/uploads/2023/09/carpool-4.jpg", "https://carpool.tamu.edu/wp-content/uploads/2023/09/carpool-2.jpg", "https://carpool.tamu.edu/wp-content/uploads/2023/09/carpool-1.jpg", "https://carpool.tamu.edu/wp-content/uploads/2023/01/FirstOps2023.png", "https://carpool.tamu.edu/wp-content/uploads/2023/01/FirstOps2023F.png", "https://carpool.tamu.edu/wp-content/uploads/2022/12/TexasRoadhouse-scaled.jpg", "https://carpool.tamu.edu/wp-content/uploads/2022/12/AwardsFall2022-scaled.jpg", "https://carpool.tamu.edu/wp-content/uploads/2022/12/CarpoolNov19.jpg", "https://carpool.tamu.edu/wp-content/uploads/2022/12/CarpoolNov18-e1674714221419.jpg", "https://carpool.tamu.edu/wp-content/uploads/2022/11/IMG_8332-scaled.jpg", "https://carpool.tamu.edu/wp-content/uploads/2022/11/IMG_9322.jpeg", "https://carpool.tamu.edu/wp-content/uploads/2022/11/CarpoolOct22.jpg", "https://carpool.tamu.edu/wp-content/uploads/2022/11/CarpoolHalloween.jpg", "https://carpool.tamu.edu/wp-content/uploads/2022/11/Carpool5Nov.jpg", "https://carpool.tamu.edu/wp-content/uploads/2022/11/WYATT.jpg", "https://carpool.tamu.edu/wp-content/uploads/2021/10/242115441_433597971447056_5825105156148892108_n.jpg", "https://carpool.tamu.edu/wp-content/uploads/2021/10/244075086_905994653679760_4175473701291191032_n.jpg", "https://carpool.tamu.edu/wp-content/uploads/2021/10/243609718_450031173036678_5788664855431265157_n.jpg", "https://carpool.tamu.edu/wp-content/uploads/2021/10/243711731_579322229938225_1114406679430999244_n.jpg", "https://carpool.tamu.edu/wp-content/uploads/2018/10/IMG_0910.jpg", "https://carpool.tamu.edu/wp-content/uploads/2018/10/IMG_20180130_122611.jpg", "https://carpool.tamu.edu/wp-content/uploads/2018/10/IMG_0451.jpg", "https://carpool.tamu.edu/wp-content/uploads/2018/10/DSC_0508.jpg", "https://carpool.tamu.edu/wp-content/uploads/2018/10/42868616_10155854350922525_7146265731556966400_n.jpg", "https://carpool.tamu.edu/wp-content/uploads/2018/10/MVIMG_20180324_221117.jpg", "https://carpool.tamu.edu/wp-content/uploads/2018/10/IMG_7491.jpg", "https://carpool.tamu.edu/wp-content/uploads/2018/10/IMG_4095.jpg", "https://carpool.tamu.edu/wp-content/uploads/2018/10/42806428_10155854350917525_5728936694359523328_n.jpg", "https://carpool.tamu.edu/wp-content/uploads/2018/10/DSC_0157.jpg", "https://carpool.tamu.edu/wp-content/uploads/2018/10/CP-Soccer.jpg", "https://carpool.tamu.edu/wp-content/uploads/2018/02/Copy-of-DSC00838.jpg", "https://carpool.tamu.edu/wp-content/uploads/2018/01/youcaring-pic-6.jpg", "https://carpool.tamu.edu/wp-content/uploads/2022/11/carpool20152.jpg", "https://carpool.tamu.edu/wp-content/uploads/2022/11/carpool20132.jpg", "https://carpool.tamu.edu/wp-content/uploads/2022/11/carpool2017.jpg", "https://carpool.tamu.edu/wp-content/uploads/2022/11/Carpool2015.jpg", "https://carpool.tamu.edu/wp-content/uploads/2022/11/Carpool2013.jpg", "https://carpool.tamu.edu/wp-content/uploads/2022/11/Carpool2012.jpg", "https://carpool.tamu.edu/wp-content/uploads/2022/11/Carpool2011ops.jpg", "https://carpool.tamu.edu/wp-content/uploads/2022/11/Carpool2011MADD.jpg", "https://carpool.tamu.edu/wp-content/uploads/2022/11/10645270_10152588119577525_7734777424895653199_n.jpg", "https://carpool.tamu.edu/wp-content/uploads/2022/11/Driven2013d.jpg", "https://carpool.tamu.edu/wp-content/uploads/2022/11/Driven2013.jpg", "https://carpool.tamu.edu/wp-content/uploads/2022/11/Driven2012d.jpg", "https://carpool.tamu.edu/wp-content/uploads/2018/01/youcaring-pic-5.jpg", "https://carpool.tamu.edu/wp-content/uploads/2018/01/youcaring-pic-4.jpg", "https://carpool.tamu.edu/wp-content/uploads/2018/01/youcaring-pic-2.jpg", "https://carpool.tamu.edu/wp-content/uploads/2018/01/youcaring-pic-3.jpg", "https://carpool.tamu.edu/wp-content/uploads/2018/01/youcaring-pic-1.jpg", "https://carpool.tamu.edu/wp-content/uploads/2018/01/24955794_1154858831324772_5743073382205820181_o.jpg", "https://carpool.tamu.edu/wp-content/uploads/2018/01/26173881_1666554330072131_6936993735143468569_o.jpg", "https://carpool.tamu.edu/wp-content/uploads/2017/08/Untitled.jpg", "https://carpool.tamu.edu/wp-content/uploads/2017/08/DJx2BLAUMAAbyYB.jpg", "https://carpool.tamu.edu/wp-content/uploads/2017/08/carpool-birthday.jpg", "https://carpool.tamu.edu/wp-content/uploads/2017/08/21761920_10155008950937525_5025889767885332356_n.jpg", "https://carpool.tamu.edu/wp-content/uploads/2017/08/21616185_10155709263771944_5618501118790763332_n.jpg", "https://carpool.tamu.edu/wp-content/uploads/2016/11/fish-camp.jpg", "https://carpool.tamu.edu/wp-content/uploads/2017/09/carpool-image.jpg", "https://carpool.tamu.edu/wp-content/uploads/2017/08/17629753_1258390960946212_7902836412280047796_n.jpg", "https://carpool.tamu.edu/wp-content/uploads/2017/08/pic-for-website-7.jpg", "https://carpool.tamu.edu/wp-content/uploads/2017/08/pic-for-website-8.jpg", "https://carpool.tamu.edu/wp-content/uploads/2017/08/ccarpool-pic.jpg", "https://carpool.tamu.edu/wp-content/uploads/2016/11/17190685_1612760412070737_6880432442707744504_n.jpg", "https://carpool.tamu.edu/wp-content/uploads/2016/11/16507866_1421570837862253_8886343175990548320_n.jpg", "https://carpool.tamu.edu/wp-content/uploads/2016/11/16473847_1769399716410640_3390018204617373768_n.jpg", "https://carpool.tamu.edu/wp-content/uploads/2016/11/18194844_10209745016406743_3499309372629364197_n-1.jpg", "https://carpool.tamu.edu/wp-content/uploads/2016/11/12933123_1472016546176112_6472897902528997557_n.jpg", "https://carpool.tamu.edu/wp-content/uploads/2016/11/13103356_983548475547_1543734942227155992_n.jpg", "https://carpool.tamu.edu/wp-content/uploads/2016/11/18057037_1421361611220011_5131412449075304108_n.jpg" ]; // ====== ELEMENTS ====== const grid = document.getElementById('gallery-grid'); const photoCount = document.getElementById('photo-count'); const lightbox = document.getElementById('lightbox'); const lightboxImg = document.getElementById('lightbox-img'); const lightboxClose = document.getElementById('lightbox-close'); const lightboxPrev = document.getElementById('lightbox-prev'); const lightboxNext = document.getElementById('lightbox-next'); const lightboxCounter = document.getElementById('lightbox-counter'); let currentIndex = 0; // ====== BUILD GALLERY ====== function buildGallery() { photoCount.textContent = images.length; images.forEach((src, index) => { const item = document.createElement('div'); item.className = 'grid-item loading'; item.setAttribute('role', 'button'); item.setAttribute('tabindex', '0'); item.setAttribute('aria-label', `View image ${index + 1}`); const img = document.createElement('img'); img.src = src; img.alt = `CARPOOL photo ${index + 1}`; img.loading = 'lazy'; img.decoding = 'async'; img.onload = () => item.classList.remove('loading'); img.onerror = () => { item.classList.remove('loading'); item.style.display = 'none'; }; item.addEventListener('click', () => openLightbox(index)); item.addEventListener('keydown', (e) => { if (e.key === 'Enter' || e.key === ' ') { e.preventDefault(); openLightbox(index); } }); item.appendChild(img); grid.appendChild(item); }); } // ====== LIGHTBOX ====== function openLightbox(index) { currentIndex = index; updateLightbox(); lightbox.classList.add('active'); document.body.classList.add('lightbox-open'); lightboxClose.focus(); } function closeLightbox() { lightbox.classList.remove('active'); document.body.classList.remove('lightbox-open'); } function updateLightbox() { lightboxImg.src = images[currentIndex]; lightboxImg.alt = `CARPOOL photo ${currentIndex + 1}`; lightboxCounter.textContent = `${currentIndex + 1} / ${images.length}`; } function prevImage() { currentIndex = (currentIndex - 1 + images.length) % images.length; updateLightbox(); } function nextImage() { currentIndex = (currentIndex + 1) % images.length; updateLightbox(); } // ====== EVENT LISTENERS ====== lightboxClose.addEventListener('click', closeLightbox); lightboxPrev.addEventListener('click', prevImage); lightboxNext.addEventListener('click', nextImage); lightbox.addEventListener('click', (e) => { if (e.target === lightbox) closeLightbox(); }); document.addEventListener('keydown', (e) => { if (!lightbox.classList.contains('active')) return; switch (e.key) { case 'Escape': closeLightbox(); break; case 'ArrowLeft': prevImage(); break; case 'ArrowRight': nextImage(); break; } }); // Touch swipe support let touchStartX = 0; let touchEndX = 0; lightbox.addEventListener('touchstart', (e) => { touchStartX = e.changedTouches[0].screenX; }, { passive: true }); lightbox.addEventListener('touchend', (e) => { touchEndX = e.changedTouches[0].screenX; handleSwipe(); }, { passive: true }); function handleSwipe() { const diff = touchStartX - touchEndX; const threshold = 50; if (Math.abs(diff) > threshold) { if (diff > 0) { nextImage(); } else { prevImage(); } } } // ====== INIT ====== buildGallery(); })();