From 2378c09ebe31ab59bccdaa63af73aec42f3fb3e3 Mon Sep 17 00:00:00 2001 From: Thomas David Baker Date: Fri, 8 Nov 2024 15:40:20 -0800 Subject: [PATCH] Handle card hover images in js not css so they can break the bounding box Now that tables have display:block so that they can right-scroll we need to handle hover images differently so they don't get clipped by overflow:hidden. --- gatherling/gatherling.js | 49 +++++++++++++++++++++------- gatherling/styles/css/stylesheet.css | 18 +--------- 2 files changed, 38 insertions(+), 29 deletions(-) diff --git a/gatherling/gatherling.js b/gatherling/gatherling.js index 7e54295d1..b90d6b0e6 100644 --- a/gatherling/gatherling.js +++ b/gatherling/gatherling.js @@ -101,18 +101,43 @@ function formatDate(originalDate, start, timeZone, locale, short) { return `${formattedDate} • ${formattedTime}`; } -export { formatDate }; +function initTime() { + const timeElements = document.querySelectorAll('time[datetime]'); + timeElements.forEach(timeElement => { + const isoDate = timeElement.getAttribute('datetime'); + const originalDate = luxon.DateTime.fromISO(isoDate); + const start = luxon.DateTime.now(); + const timeZone = Intl.DateTimeFormat().resolvedOptions().timeZone; + const locale = navigator.language || navigator.languages[0]; // Fallback to languages array if needed + const short = !timeElement.classList.contains('long'); + const formattedDate = formatDate(originalDate, start, timeZone, locale, short); + timeElement.textContent = formattedDate; + }); +} -if (typeof window !== 'undefined') { - const timeElements = document.querySelectorAll('time[datetime]'); - timeElements.forEach(timeElement => { - const isoDate = timeElement.getAttribute('datetime'); - const originalDate = luxon.DateTime.fromISO(isoDate); - const start = luxon.DateTime.now(); - const timeZone = Intl.DateTimeFormat().resolvedOptions().timeZone; - const locale = navigator.language || navigator.languages[0]; // Fallback to languages array if needed - const short = !timeElement.classList.contains('long'); - const formattedDate = formatDate(originalDate, start, timeZone, locale, short); - timeElement.textContent = formattedDate; +function initHoverImage() { + document.querySelectorAll('.cardHoverImageWrapper').forEach(wrapper => { + wrapper.addEventListener('mouseenter', function() { + const hoverImage = this.querySelector('.linkCardHoverImage'); + const rect = this.getBoundingClientRect(); + + // Adjust the hover image position based on card's position in the viewport, with your offsets + hoverImage.style.position = 'fixed'; + hoverImage.style.left = `${rect.left + 160}px`; // Offset 150px to the right of the card + hoverImage.style.top = `${rect.top - 160}px`; // Offset -155px above the card + hoverImage.style.display = 'block'; + }); + + wrapper.addEventListener('mouseleave', function() { + const hoverImage = this.querySelector('.linkCardHoverImage'); + hoverImage.style.display = 'none'; }); + }); +} + +export { formatDate, initHoverImage }; + +if (typeof window !== 'undefined') { + initTime(); + initHoverImage(); } diff --git a/gatherling/styles/css/stylesheet.css b/gatherling/styles/css/stylesheet.css index bbd1da4ee..580e93984 100644 --- a/gatherling/styles/css/stylesheet.css +++ b/gatherling/styles/css/stylesheet.css @@ -431,25 +431,9 @@ a.create_deck_link { color: var(--link-emphasis-text-color); } -/* autocard */ -.cardHoverImageWrapper { - position: relative; - display: inline-block; -} - -.linkCardHoverImage { - position: absolute; - left: 150px; - top: -155px; - z-index: 20; -} - .cardHoverImageWrapper .linkCardHoverImage { display: none; -} - -.cardHoverImageWrapper:hover .linkCardHoverImage { - display: block; + z-index: 20; } .crop {