style: format static/top_pick_carousel.ts

This commit is contained in:
2026-06-21 02:05:09 +02:00
committed by Milas Holsting
parent 379ade5fd4
commit ebb5e59134

View File

@@ -24,8 +24,9 @@ const getTopPickCarousel = (root: HTMLElement): TopPickCarousel | null => {
return { track, previous, next, previousFade, nextFade }; return { track, previous, next, previousFade, nextFade };
}; };
const topPickCarousels = (root: ParentNode = document): HTMLElement[] => const topPickCarousels = (root: ParentNode = document): HTMLElement[] => [
Array.from(root.querySelectorAll<HTMLElement>("[data-top-pick-carousel]")); ...root.querySelectorAll<HTMLElement>("[data-top-pick-carousel]"),
];
const maxScrollLeft = (track: HTMLElement): number => const maxScrollLeft = (track: HTMLElement): number =>
Math.max(0, track.scrollWidth - track.clientWidth); Math.max(0, track.scrollWidth - track.clientWidth);
@@ -87,18 +88,17 @@ const scrollTopPickCarousel = (root: HTMLElement, direction: -1 | 1): void => {
currentScroll + carouselScrollAmount(carousel.track), currentScroll + carouselScrollAmount(carousel.track),
); );
carousel.track.scrollTo({ carousel.track.scrollTo({ left: targetScroll, behavior: "smooth" });
left: targetScroll,
behavior: "smooth",
});
window.setTimeout(() => updateTopPickCarousel(root), 350); window.setTimeout(() => {
updateTopPickCarousel(root);
}, 350);
}; };
document.addEventListener( document.addEventListener(
"click", "click",
(event: MouseEvent): void => { (event: MouseEvent): void => {
const target = event.target; const { target } = event;
if (!(target instanceof Element)) { if (!(target instanceof Element)) {
return; return;
} }
@@ -132,7 +132,7 @@ document.addEventListener(
document.addEventListener( document.addEventListener(
"scroll", "scroll",
(event: Event): void => { (event: Event): void => {
const target = event.target; const { target } = event;
if (!(target instanceof HTMLElement) || !target.matches("[data-top-pick-track]")) { if (!(target instanceof HTMLElement) || !target.matches("[data-top-pick-track]")) {
return; return;
} }
@@ -145,7 +145,13 @@ document.addEventListener(
true, true,
); );
onReady(() => updateTopPickCarousels()); onReady(() => {
onHtmxLoad((root) => updateTopPickCarousels(root)); updateTopPickCarousels();
window.addEventListener("resize", () => updateTopPickCarousels()); });
onHtmxLoad((root) => {
updateTopPickCarousels(root);
});
window.addEventListener("resize", () => {
updateTopPickCarousels();
});
import { onHtmxLoad, onReady } from "./utils"; import { onHtmxLoad, onReady } from "./utils";