@evermade/overflow-slider 4.1.0 → 4.2.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,2 +1,2 @@
1
- "use strict";function t(e,o=1){const n=`${e}-${o}`;return document.getElementById(n)?t(e,o+1):n}function e(t){if(0===t.children.length)return 0;const e=t.children[0],o=getComputedStyle(e),n=parseFloat(o.marginLeft),l=t.children[t.children.length-1],i=getComputedStyle(l);return n+parseFloat(i.marginRight)}function o(o,n,l){let i,r={};function a(t=!1){const e=i.details,o=function(t){var e;let o,n=!1,l=0,i=0,r=0,a=0,s=0,c=1;return Math.floor(t.getInclusiveScrollWidth())>Math.floor(t.getInclusiveClientWidth())&&(n=!0),l=null!==(e=t.slides.length)&&void 0!==e?e:0,i=t.container.offsetWidth,r=t.container.offsetHeight,a=t.getInclusiveScrollWidth(),s=Math.ceil(a/i),Math.floor(t.getScrollLeft())>=0&&(c=Math.floor(t.getScrollLeft()/i),Math.floor(t.getScrollLeft()+i)===Math.floor(a)&&(c=s-1)),o={hasOverflow:n,slideCount:l,containerWidth:i,containerHeight:r,scrollableAreaWidth:a,amountOfPages:s,currentPage:c},o}(i);i.details=o,t||function(t,e){const o=Object.keys(t),n=Object.keys(e);if(o.length!==n.length)return!1;for(let n of o)if(!Object.prototype.hasOwnProperty.call(e,n)||t[n]!==e[n])return!1;return!0}(e,o)?t&&i.emit("detailsChanged"):i.emit("detailsChanged")}function s(){i.slides=Array.from(i.container.querySelectorAll(i.options.slidesSelector))}function c(){i.options.cssVariableContainer.style.setProperty("--slider-container-height",`${i.details.containerHeight}px`),i.options.cssVariableContainer.style.setProperty("--slider-container-width",`${i.details.containerWidth}px`),i.options.cssVariableContainer.style.setProperty("--slider-scrollable-width",`${i.details.scrollableAreaWidth}px`),i.options.cssVariableContainer.style.setProperty("--slider-slides-count",`${i.details.slideCount}`),i.options.cssVariableContainer.style.setProperty("--slider-x-offset",`${v()}px`),"function"==typeof i.options.targetWidth&&i.options.cssVariableContainer.style.setProperty("--slider-container-target-width",`${i.options.targetWidth(i)}px`)}function d(){i.container.setAttribute("data-has-overflow",i.details.hasOverflow?"true":"false"),i.options.rtl&&i.container.setAttribute("dir","rtl")}function f(t,e=null){const o=e||i.options.scrollBehavior,n=t.getBoundingClientRect(),l=i.container.getBoundingClientRect(),r=i.container.offsetWidth,a=i.container.scrollLeft,s=n.left-l.left+a,c=s+n.width;let d=null;d=Math.floor(s)<Math.floor(a)?s:Math.floor(c)>Math.floor(a)+Math.floor(r)?c-r:0===Math.floor(s)?0:s,null!==d&&setTimeout(t=>{i.emit("programmaticScrollStart"),i.container.scrollTo({left:t,behavior:o})},50,d)}function h(){const t=i.container.getBoundingClientRect(),e=i.getScrollLeft(),o=i.slides;let n=0,l=!1;if(i.options.rtl){const l=i.getInclusiveScrollWidth()-e-i.getInclusiveClientWidth(),r=[];for(let e=o.length-1;e>=0;e--){const n=o[e].getBoundingClientRect(),i=Math.abs(n.left)-Math.abs(t.left)+l;r.push({slide:o[e],slideEnd:i})}let a=null,s=null;for(let t=0;t<r.length;t++){const e=Math.abs(r[t].slideEnd-l);(null===s||e<s)&&(s=e,a=r[t].slide)}n=a?o.indexOf(a):o.length-1}else for(let i=0;i<o.length;i++){const r=o[i].getBoundingClientRect().left-t.left+e+m();if(Math.floor(r)>=Math.floor(e)){n=i;break}i===o.length-1&&(l=!0)}l&&(n=o.length-1);const r=i.activeSlideIdx;i.activeSlideIdx=n,r!==n&&i.emit("activeSlideChanged")}function u(t){const e=i.slides[t];e&&f(e)}function g(){return i.options.rtl?Math.abs(i.container.scrollLeft):i.container.scrollLeft}function m(){let t=0;if(i.slides.length>1){const e=i.slides[0].getBoundingClientRect(),o=i.slides[1].getBoundingClientRect();t=i.options.rtl?Math.abs(Math.floor(o.right-e.left)):Math.floor(o.left-e.right)}return t}function v(){let t=0;const e=i.container.getAttribute("data-full-width-offset");return e&&(t=parseInt(e)),Math.floor(t)}return i={emit:function(t){var e;r&&r[t]&&r[t].forEach(t=>{t(i)});const o=null===(e=null==i?void 0:i.options)||void 0===e?void 0:e[t];"function"==typeof o&&o(i)},moveToDirection:function(t="prev"){const e=i.options.scrollStrategy,o=i.container.scrollLeft,n=i.container.getBoundingClientRect(),l=i.container.offsetWidth;let r=o;const a=i.options.rtl?"prev"===t?"next":"prev":t;if("prev"===a?r=Math.max(0,o-i.container.offsetWidth):"next"===a&&(r=Math.min(i.getInclusiveScrollWidth(),o+i.container.offsetWidth)),"fullSlide"===e){let t=null;if(t="prev"===a?Math.max(0,r-m()):Math.min(i.getInclusiveScrollWidth(),r+m()),"next"===a){let e=!1;for(let l of i.slides){const i=l.getBoundingClientRect(),a=i.left-n.left+o,s=a+i.width;if(Math.floor(a)<Math.floor(r)&&Math.floor(s)>Math.floor(r)){t=a,e=!0;break}}if(e||(t=Math.min(r,i.getInclusiveScrollWidth()-i.container.offsetWidth)),t)if(Math.floor(t)>Math.floor(o)){const e=Math.floor(i.getInclusiveScrollWidth())-Math.floor(l);r=Math.min(t,e)}else r=Math.min(i.getInclusiveScrollWidth(),o+l)}else{let e=!1;for(let r of i.slides){const i=r.getBoundingClientRect(),a=i.left-n.left+o,s=a+i.width;if(Math.floor(a)<Math.floor(o)&&Math.floor(s)>Math.floor(o)){t=s-l,e=!0;break}}e||(t=Math.max(0,o-l)),t&&Math.floor(t)<Math.floor(o)&&(r=t)}}const s=r-v();Math.floor(s)>=0&&(r=s),i.emit("programmaticScrollStart"),i.container.style.scrollBehavior=i.options.scrollBehavior,i.container.scrollLeft=r,setTimeout(()=>i.container.style.scrollBehavior="",50)},canMoveToSlide:function(t){if(t<0||t>=i.slides.length)return!1;if(t===i.activeSlideIdx)return!1;const e=(i.options.rtl,t<i.activeSlideIdx?"backwards":"forwards"),o=i.container.getBoundingClientRect(),n=i.getScrollLeft(),l=i.details.containerWidth;return i.slides.some((t,r)=>{if(r===i.activeSlideIdx)return!1;const a=t.getBoundingClientRect(),s=a.left-o.left+n,c=s+a.width;return i.options.rtl?!(0!==n||!i.details.hasOverflow)||("forwards"===e&&r>i.activeSlideIdx&&Math.floor(s)<Math.floor(n)||"backwards"===e&&r<i.activeSlideIdx&&Math.floor(c)>Math.floor(n+l)):"forwards"===e&&r>i.activeSlideIdx&&Math.floor(c)>Math.floor(n+l)||"backwards"===e&&r<i.activeSlideIdx&&Math.floor(s)<Math.floor(n)})},moveToSlide:u,moveToSlideInDirection:function(t){const e=i.activeSlideIdx;"prev"===t?e>0&&u(e-1):"next"===t&&e<i.slides.length-1&&u(e+1)},snapToClosestSlide:function(t="prev"){var e,o;const{slides:n,options:l,container:r}=i,{rtl:a,emulateScrollSnapMaxThreshold:s=10,scrollBehavior:c="smooth"}=l,d=a?"prev"===t:"next"===t,f=g(),h=r.getBoundingClientRect(),u=a?-1:1;let m=0;if("function"==typeof l.targetWidth)try{const t=l.targetWidth(i),e=h.width;Number.isFinite(t)&&t>0&&t<e&&(m=(e-t)/2)}catch(t){}const v=[...n].map(t=>{const{width:e}=t.getBoundingClientRect(),o=t.getBoundingClientRect().left-h.left+f,n=o-m,l=Math.min(n+e/2,n+s);return{start:o-m,trigger:l}});let p=null;if(d){const t=v.find(t=>f<=t.trigger);p=null!==(e=null==t?void 0:t.start)&&void 0!==e?e:null}else{const t=[...v].reverse().find(t=>f>=t.trigger);p=null!==(o=null==t?void 0:t.start)&&void 0!==o?o:null}if(null==p)return;const M=Math.max(0,Math.floor(p))*u;r.scrollTo({left:M,behavior:c})},getInclusiveScrollWidth:function(){return i.container.scrollWidth+e(i.container)},getInclusiveClientWidth:function(){return i.container.clientWidth+e(i.container)},getScrollLeft:g,setScrollLeft:function(t){i.container.scrollLeft=i.options.rtl?-t:t},setActiveSlideIdx:h,on:function(t,e){r[t]||(r[t]=[]),r[t].push(e)},options:n},function(){i.container=o;let e=o.getAttribute("id");null===e&&(e=t("overflow-slider"),o.setAttribute("id",e)),s(),i.slides.forEach(t=>{t.style.transition="none"}),a(!0),h(),i.on("contentsChanged",()=>{s(),a(),h()}),i.on("containerSizeChanged",()=>a());let n=0;if(i.on("scroll",()=>{n&&window.cancelAnimationFrame(n),n=window.requestAnimationFrame(()=>{a(),h()})}),function(){new MutationObserver(()=>i.emit("contentsChanged")).observe(i.container,{childList:!0});let t,e,o;new ResizeObserver(()=>i.emit("containerSizeChanged")).observe(i.container);let n=i.container.scrollLeft,l=i.container.scrollLeft,r=i.container.scrollLeft,a=!1,s=!1,c=!1;i.container.addEventListener("scroll",()=>{const e=i.container.scrollLeft;Math.floor(n)!==Math.floor(e)&&(a||(a=!0,i.emit("scrollStart")),n=e,clearTimeout(t),t=setTimeout(()=>{a=!1,i.emit("scrollEnd")},50),i.emit("scroll")),s&&d()});const d=()=>{const t=i.container.scrollLeft;Math.floor(l)===Math.floor(t)||c||(s||(i.emit("nativeScrollStart"),s=!0),i.emit("nativeScroll"),l=t,clearTimeout(e),e=setTimeout(()=>{s=!1,i.emit("nativeScrollEnd"),r=l},50))};i.container.addEventListener("touchmove",d),i.container.addEventListener("mousewheel",d),i.container.addEventListener("wheel",d),i.on("programmaticScrollStart",()=>{c=!0}),i.container.addEventListener("scroll",()=>{const t=i.container.scrollLeft;Math.floor(r)!==Math.floor(t)&&!s&&c&&(r=t,clearTimeout(o),o=setTimeout(()=>{c=!1,i.emit("programmaticScrollEnd"),l=r},50),i.emit("programmaticScroll"))}),i.on("programmaticScrollStart",()=>{i.container.style.scrollSnapType="none"}),i.on("nativeScrollStart",()=>{i.container.style.scrollSnapType=""});let h=!1;i.container.addEventListener("mousedown",()=>{h=!0}),i.container.addEventListener("touchstart",()=>{h=!0},{passive:!0}),i.container.addEventListener("focusin",t=>{if(!h){let e=t.target;for(;e.parentElement!==i.container&&e.parentElement;)e=e.parentElement;f(e,"auto")}h=!1})}(),d(),c(),l){for(const t of l)t(i);a(),h(),c(),i.emit("pluginsLoaded")}i.on("detailsChanged",()=>{d(),c()}),i.emit("created"),i.slides.forEach(t=>{t.style.removeProperty("transition")}),i.container.setAttribute("data-ready","true")}(),i}exports.OverflowSlider=function(t,e,n){try{if(!(t instanceof Element))throw new Error("Container must be HTML element, found "+typeof t);const l={cssVariableContainer:t,scrollBehavior:"smooth",scrollStrategy:"fullSlide",slidesSelector:":scope > *",emulateScrollSnap:!1,emulateScrollSnapMaxThreshold:64,rtl:!1},i=Object.assign(Object.assign({},l),e);return window.matchMedia("(prefers-reduced-motion: reduce)").matches&&(i.scrollBehavior="auto"),o(t,i,n)}catch(t){console.error(t)}};
1
+ "use strict";function t(e,o=1){const n=`${e}-${o}`;return document.getElementById(n)?t(e,o+1):n}function e(t){if(0===t.children.length)return 0;const e=t.children[0],o=getComputedStyle(e),n=parseFloat(o.marginLeft),l=t.children[t.children.length-1],i=getComputedStyle(l);return n+parseFloat(i.marginRight)}function o(o,n,l){let i,r={};function a(t=!1){const e=i.details,o=function(t){var e;let o,n=!1,l=0,i=0,r=0,a=0,s=0,c=0;if(Math.floor(t.getInclusiveScrollWidth())>Math.floor(t.getInclusiveClientWidth())&&(n=!0),l=null!==(e=t.slides.length)&&void 0!==e?e:0,i=t.container.offsetWidth,r=t.container.offsetHeight,a=t.getInclusiveScrollWidth(),s=Math.ceil(a/i),Math.floor(t.getScrollLeft())>=0){c=Math.floor(t.getScrollLeft()/i);const e=a-i-2*t.getLeftOffset();t.getScrollLeft()>=e-1&&(c=s-1)}return o={hasOverflow:n,slideCount:l,containerWidth:i,containerHeight:r,scrollableAreaWidth:a,amountOfPages:s,currentPage:c},o}(i);i.details=o,t||function(t,e){const o=Object.keys(t),n=Object.keys(e);if(o.length!==n.length)return!1;for(let n of o)if(!Object.prototype.hasOwnProperty.call(e,n)||t[n]!==e[n])return!1;return!0}(e,o)?t&&i.emit("detailsChanged"):i.emit("detailsChanged")}function s(){i.slides=Array.from(i.container.querySelectorAll(i.options.slidesSelector))}function c(){i.options.cssVariableContainer.style.setProperty("--slider-container-height",`${i.details.containerHeight}px`),i.options.cssVariableContainer.style.setProperty("--slider-container-width",`${i.details.containerWidth}px`),i.options.cssVariableContainer.style.setProperty("--slider-scrollable-width",`${i.details.scrollableAreaWidth}px`),i.options.cssVariableContainer.style.setProperty("--slider-slides-count",`${i.details.slideCount}`),i.options.cssVariableContainer.style.setProperty("--slider-x-offset",`${v()}px`),"function"==typeof i.options.targetWidth&&i.options.cssVariableContainer.style.setProperty("--slider-container-target-width",`${i.options.targetWidth(i)}px`)}function d(){i.container.setAttribute("data-has-overflow",i.details.hasOverflow?"true":"false"),i.options.rtl&&i.container.setAttribute("dir","rtl")}function f(t,e=null){const o=e||i.options.scrollBehavior,n=t.getBoundingClientRect(),l=i.container.getBoundingClientRect(),r=i.container.offsetWidth,a=i.container.scrollLeft,s=n.left-l.left+a,c=s+n.width;let d=null;d=Math.floor(s)<Math.floor(a)?s:Math.floor(c)>Math.floor(a)+Math.floor(r)?c-r:0===Math.floor(s)?0:s,null!==d&&setTimeout(t=>{i.emit("programmaticScrollStart"),i.container.scrollTo({left:t,behavior:o})},50,d)}function h(){const t=i.container.getBoundingClientRect(),e=i.getScrollLeft(),o=i.slides;let n=0,l=!1;if(i.options.rtl){const l=i.getInclusiveScrollWidth()-e-i.getInclusiveClientWidth(),r=[];for(let e=o.length-1;e>=0;e--){const n=o[e].getBoundingClientRect(),i=Math.abs(n.left)-Math.abs(t.left)+l;r.push({slide:o[e],slideEnd:i})}let a=null,s=null;for(let t=0;t<r.length;t++){const e=Math.abs(r[t].slideEnd-l);(null===s||e<s)&&(s=e,a=r[t].slide)}n=a?o.indexOf(a):o.length-1}else for(let i=0;i<o.length;i++){const r=o[i].getBoundingClientRect().left-t.left+e+m();if(Math.floor(r)>=Math.floor(e)){n=i;break}i===o.length-1&&(l=!0)}l&&(n=o.length-1);const r=i.activeSlideIdx;i.activeSlideIdx=n,r!==n&&i.emit("activeSlideChanged")}function u(t){const e=i.slides[t];e&&f(e)}function g(){return i.options.rtl?Math.abs(i.container.scrollLeft):i.container.scrollLeft}function m(){let t=0;if(i.slides.length>1){const e=i.slides[0].getBoundingClientRect(),o=i.slides[1].getBoundingClientRect();t=i.options.rtl?Math.abs(Math.floor(o.right-e.left)):Math.floor(o.left-e.right)}return t}function v(){let t=0;const e=i.container.getAttribute("data-full-width-offset");return e&&(t=parseInt(e)),Math.floor(t)}return i={emit:function(t){var e;r&&r[t]&&r[t].forEach(t=>{t(i)});const o=null===(e=null==i?void 0:i.options)||void 0===e?void 0:e[t];"function"==typeof o&&o(i)},moveToDirection:function(t="prev"){const e=i.options.scrollStrategy,o=i.container.scrollLeft,n=i.container.getBoundingClientRect(),l=i.container.offsetWidth;let r=o;const a=i.options.rtl?"prev"===t?"next":"prev":t;if("prev"===a?r=Math.max(0,o-i.container.offsetWidth):"next"===a&&(r=Math.min(i.getInclusiveScrollWidth(),o+i.container.offsetWidth)),"fullSlide"===e){let t=null;if(t="prev"===a?Math.max(0,r-m()):Math.min(i.getInclusiveScrollWidth(),r+m()),"next"===a){let e=!1;for(let l of i.slides){const i=l.getBoundingClientRect(),a=i.left-n.left+o,s=a+i.width;if(Math.floor(a)<Math.floor(r)&&Math.floor(s)>Math.floor(r)){t=a,e=!0;break}}if(e||(t=Math.min(r,i.getInclusiveScrollWidth()-i.container.offsetWidth)),t)if(Math.floor(t)>Math.floor(o)){const e=Math.floor(i.getInclusiveScrollWidth())-Math.floor(l);r=Math.min(t,e)}else r=Math.min(i.getInclusiveScrollWidth(),o+l)}else{let e=!1;for(let r of i.slides){const i=r.getBoundingClientRect(),a=i.left-n.left+o,s=a+i.width;if(Math.floor(a)<Math.floor(o)&&Math.floor(s)>Math.floor(o)){t=s-l,e=!0;break}}e||(t=Math.max(0,o-l)),t&&Math.floor(t)<Math.floor(o)&&(r=t)}}const s=r-v();Math.floor(s)>=0&&(r=s),i.emit("programmaticScrollStart"),i.container.style.scrollBehavior=i.options.scrollBehavior,i.container.scrollLeft=r,setTimeout(()=>i.container.style.scrollBehavior="",50)},canMoveToSlide:function(t){if(t<0||t>=i.slides.length)return!1;if(t===i.activeSlideIdx)return!1;const e=(i.options.rtl,t<i.activeSlideIdx?"backwards":"forwards"),o=i.container.getBoundingClientRect(),n=i.getScrollLeft(),l=i.details.containerWidth;return i.slides.some((t,r)=>{if(r===i.activeSlideIdx)return!1;const a=t.getBoundingClientRect(),s=a.left-o.left+n,c=s+a.width;return i.options.rtl?!(0!==n||!i.details.hasOverflow)||("forwards"===e&&r>i.activeSlideIdx&&Math.floor(s)<Math.floor(n)||"backwards"===e&&r<i.activeSlideIdx&&Math.floor(c)>Math.floor(n+l)):"forwards"===e&&r>i.activeSlideIdx&&Math.floor(c)>Math.floor(n+l)||"backwards"===e&&r<i.activeSlideIdx&&Math.floor(s)<Math.floor(n)})},moveToSlide:u,moveToSlideInDirection:function(t){const e=i.activeSlideIdx;"prev"===t?e>0&&u(e-1):"next"===t&&e<i.slides.length-1&&u(e+1)},snapToClosestSlide:function(t="prev"){var e,o;const{slides:n,options:l,container:r}=i,{rtl:a,emulateScrollSnapMaxThreshold:s=10,scrollBehavior:c="smooth"}=l,d=a?"prev"===t:"next"===t,f=g(),h=r.getBoundingClientRect(),u=a?-1:1;let m=0;if("function"==typeof l.targetWidth)try{const t=l.targetWidth(i),e=h.width;Number.isFinite(t)&&t>0&&t<e&&(m=(e-t)/2)}catch(t){}const v=[...n].map(t=>{const{width:e}=t.getBoundingClientRect(),o=t.getBoundingClientRect().left-h.left+f,n=o-m,l=Math.min(n+e/2,n+s);return{start:o-m,trigger:l}});let p=null;if(d){const t=v.find(t=>f<=t.trigger);p=null!==(e=null==t?void 0:t.start)&&void 0!==e?e:null}else{const t=[...v].reverse().find(t=>f>=t.trigger);p=null!==(o=null==t?void 0:t.start)&&void 0!==o?o:null}if(null==p)return;const S=Math.max(0,Math.floor(p))*u;r.scrollTo({left:S,behavior:c})},getInclusiveScrollWidth:function(){return i.container.scrollWidth+e(i.container)},getInclusiveClientWidth:function(){return i.container.clientWidth+e(i.container)},getLeftOffset:v,getGapSize:m,getScrollLeft:g,setScrollLeft:function(t){i.container.scrollLeft=i.options.rtl?-t:t},setActiveSlideIdx:h,on:function(t,e){r[t]||(r[t]=[]),r[t].push(e)},options:n},function(){i.container=o;let e=o.getAttribute("id");null===e&&(e=t("overflow-slider"),o.setAttribute("id",e)),s(),i.slides.forEach(t=>{t.style.transition="none"}),a(!0),h(),i.on("contentsChanged",()=>{s(),a(),h()}),i.on("containerSizeChanged",()=>a());let n=0;if(i.on("scroll",()=>{n&&window.cancelAnimationFrame(n),n=window.requestAnimationFrame(()=>{a(),h()})}),function(){new MutationObserver(()=>i.emit("contentsChanged")).observe(i.container,{childList:!0});let t,e,o;new ResizeObserver(()=>i.emit("containerSizeChanged")).observe(i.container);let n=i.container.scrollLeft,l=i.container.scrollLeft,r=i.container.scrollLeft,a=!1,s=!1,c=!1;i.container.addEventListener("scroll",()=>{const e=i.container.scrollLeft;Math.floor(n)!==Math.floor(e)&&(a||(a=!0,i.emit("scrollStart")),n=e,clearTimeout(t),t=setTimeout(()=>{a=!1,i.emit("scrollEnd")},50),i.emit("scroll")),s&&d()});const d=()=>{const t=i.container.scrollLeft;Math.floor(l)===Math.floor(t)||c||(s||(i.emit("nativeScrollStart"),s=!0),i.emit("nativeScroll"),l=t,clearTimeout(e),e=setTimeout(()=>{s=!1,i.emit("nativeScrollEnd"),r=l},50))};i.container.addEventListener("touchmove",d),i.container.addEventListener("mousewheel",d),i.container.addEventListener("wheel",d),i.on("programmaticScrollStart",()=>{c=!0}),i.container.addEventListener("scroll",()=>{const t=i.container.scrollLeft;Math.floor(r)!==Math.floor(t)&&!s&&c&&(r=t,clearTimeout(o),o=setTimeout(()=>{c=!1,i.emit("programmaticScrollEnd"),l=r},50),i.emit("programmaticScroll"))}),i.on("programmaticScrollStart",()=>{i.container.style.scrollSnapType="none"}),i.on("nativeScrollStart",()=>{i.container.style.scrollSnapType=""});let h=!1;i.container.addEventListener("mousedown",()=>{h=!0}),i.container.addEventListener("touchstart",()=>{h=!0},{passive:!0}),i.container.addEventListener("focusin",t=>{if(!h){let e=t.target;for(;e.parentElement!==i.container&&e.parentElement;)e=e.parentElement;f(e,"auto")}h=!1})}(),d(),c(),l){for(const t of l)t(i);a(),h(),c(),i.emit("pluginsLoaded")}i.on("detailsChanged",()=>{d(),c()}),i.emit("created"),i.slides.forEach(t=>{t.style.removeProperty("transition")}),i.container.setAttribute("data-ready","true")}(),i}exports.OverflowSlider=function(t,e,n){try{if(!(t instanceof Element))throw new Error("Container must be HTML element, found "+typeof t);const l={cssVariableContainer:t,scrollBehavior:"smooth",scrollStrategy:"fullSlide",slidesSelector:":scope > *",emulateScrollSnap:!1,emulateScrollSnapMaxThreshold:64,rtl:!1},i=Object.assign(Object.assign({},l),e);return window.matchMedia("(prefers-reduced-motion: reduce)").matches&&(i.scrollBehavior="auto"),o(t,i,n)}catch(t){console.error(t)}};
2
2
  //# sourceMappingURL=index.min.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.min.js","sources":["../src/core/utils.ts","../src/core/slider.ts","../src/core/details.ts","../src/core/overflow-slider.ts"],"sourcesContent":["function generateId(prefix, i = 1) {\n const id = `${prefix}-${i}`;\n if (document.getElementById(id)) {\n return generateId(prefix, i + 1);\n }\n return id;\n}\nfunction objectsAreEqual(obj1, obj2) {\n const keys1 = Object.keys(obj1);\n const keys2 = Object.keys(obj2);\n if (keys1.length !== keys2.length) {\n return false;\n }\n for (let key of keys1) {\n // Use `Object.prototype.hasOwnProperty.call` for better safety\n if (!Object.prototype.hasOwnProperty.call(obj2, key) || obj1[key] !== obj2[key]) {\n return false;\n }\n }\n return true;\n}\nfunction getOutermostChildrenEdgeMarginSum(el) {\n if (el.children.length === 0) {\n return 0;\n }\n // get the first child and its left margin\n const firstChild = el.children[0];\n const firstChildStyle = getComputedStyle(firstChild);\n const firstChildMarginLeft = parseFloat(firstChildStyle.marginLeft);\n // Get the last child and its right margin\n const lastChild = el.children[el.children.length - 1];\n const lastChildStyle = getComputedStyle(lastChild);\n const lastChildMarginRight = parseFloat(lastChildStyle.marginRight);\n return firstChildMarginLeft + lastChildMarginRight;\n}\nexport { generateId, objectsAreEqual, getOutermostChildrenEdgeMarginSum };\n","import details from './details';\nimport { generateId, objectsAreEqual, getOutermostChildrenEdgeMarginSum } from './utils';\nexport default function Slider(container, options, plugins) {\n let slider;\n let subs = {};\n const overrideTransitions = () => {\n slider.slides.forEach((slide) => {\n slide.style.transition = 'none';\n });\n };\n const restoreTransitions = () => {\n slider.slides.forEach((slide) => {\n slide.style.removeProperty('transition');\n });\n };\n function init() {\n slider.container = container;\n // ensure container has id\n let containerId = container.getAttribute('id');\n if (containerId === null) {\n containerId = generateId('overflow-slider');\n container.setAttribute('id', containerId);\n }\n setSlides();\n // CSS transitions can cause delays for calculations\n overrideTransitions();\n setDetails(true);\n setActiveSlideIdx();\n slider.on('contentsChanged', () => {\n setSlides();\n setDetails();\n setActiveSlideIdx();\n });\n slider.on('containerSizeChanged', () => setDetails());\n let requestId = 0;\n const setDetailsDebounce = () => {\n if (requestId) {\n window.cancelAnimationFrame(requestId);\n }\n requestId = window.requestAnimationFrame(() => {\n setDetails();\n setActiveSlideIdx();\n });\n };\n slider.on('scroll', setDetailsDebounce);\n addEventListeners();\n setDataAttributes();\n setCSSVariables();\n if (plugins) {\n for (const plugin of plugins) {\n plugin(slider);\n }\n // plugins may mutate layout: refresh details and derived data after they run\n // setTimeout( () => {\n setDetails();\n setActiveSlideIdx();\n setCSSVariables();\n slider.emit('pluginsLoaded');\n // }, 250 );\n }\n slider.on('detailsChanged', () => {\n setDataAttributes();\n setCSSVariables();\n });\n slider.emit('created');\n restoreTransitions();\n slider.container.setAttribute('data-ready', 'true');\n }\n ;\n function setDetails(isInit = false) {\n const oldDetails = slider.details;\n const newDetails = details(slider);\n slider.details = newDetails;\n if (!isInit && !objectsAreEqual(oldDetails, newDetails)) {\n slider.emit('detailsChanged');\n }\n else if (isInit) {\n slider.emit('detailsChanged');\n }\n }\n ;\n function setSlides() {\n slider.slides = Array.from(slider.container.querySelectorAll(slider.options.slidesSelector));\n }\n function addEventListeners() {\n // changes to DOM\n const observer = new MutationObserver(() => slider.emit('contentsChanged'));\n observer.observe(slider.container, { childList: true });\n // container size changes\n const resizeObserver = new ResizeObserver(() => slider.emit('containerSizeChanged'));\n resizeObserver.observe(slider.container);\n // scroll event with debouncing\n let scrollTimeout;\n let nativeScrollTimeout;\n let programmaticScrollTimeout;\n let scrollLeft = slider.container.scrollLeft;\n let nativeScrollLeft = slider.container.scrollLeft;\n let programmaticScrollLeft = slider.container.scrollLeft;\n let isScrolling = false;\n let isUserScrolling = false;\n let isProgrammaticScrolling = false;\n // all types of scroll\n slider.container.addEventListener('scroll', () => {\n const newScrollLeft = slider.container.scrollLeft;\n if (Math.floor(scrollLeft) !== Math.floor(newScrollLeft)) {\n if (!isScrolling) {\n isScrolling = true;\n slider.emit('scrollStart');\n }\n scrollLeft = newScrollLeft;\n clearTimeout(scrollTimeout);\n scrollTimeout = setTimeout(() => {\n isScrolling = false;\n slider.emit('scrollEnd');\n }, 50);\n slider.emit('scroll');\n }\n // keep up nativeScrolling to take into account scroll-snap\n if (isUserScrolling) {\n nativeScrollHandler();\n }\n });\n // user initted scroll (touchmove, mouse wheel, etc.)\n const nativeScrollHandler = () => {\n const newScrollLeft = slider.container.scrollLeft;\n if (Math.floor(nativeScrollLeft) !== Math.floor(newScrollLeft) && !isProgrammaticScrolling) {\n if (!isUserScrolling) {\n slider.emit('nativeScrollStart');\n isUserScrolling = true;\n }\n slider.emit('nativeScroll');\n nativeScrollLeft = newScrollLeft;\n clearTimeout(nativeScrollTimeout);\n nativeScrollTimeout = setTimeout(() => {\n isUserScrolling = false;\n slider.emit('nativeScrollEnd');\n // update programmaticScrollLeft to match nativeScrollLeft\n // this prevents programmaticScroll triggering with no real change to scrollLeft\n programmaticScrollLeft = nativeScrollLeft;\n }, 50);\n }\n };\n slider.container.addEventListener('touchmove', nativeScrollHandler);\n slider.container.addEventListener('mousewheel', nativeScrollHandler);\n slider.container.addEventListener('wheel', nativeScrollHandler);\n // programmatic scroll (scrollTo, etc.)\n slider.on('programmaticScrollStart', () => {\n isProgrammaticScrolling = true;\n });\n slider.container.addEventListener('scroll', () => {\n const newScrollLeft = slider.container.scrollLeft;\n if (Math.floor(programmaticScrollLeft) !== Math.floor(newScrollLeft) && !isUserScrolling && isProgrammaticScrolling) {\n programmaticScrollLeft = newScrollLeft;\n clearTimeout(programmaticScrollTimeout);\n programmaticScrollTimeout = setTimeout(() => {\n isProgrammaticScrolling = false;\n slider.emit('programmaticScrollEnd');\n // update nativeScrollLeft to match programmaticScrollLeft\n // this prevents nativeScroll triggering with no real change to scrollLeft\n nativeScrollLeft = programmaticScrollLeft;\n }, 50);\n slider.emit('programmaticScroll');\n }\n });\n // Fix issues on scroll snapping not working on programmatic scroll (it's not smooth)\n // by disabling scroll snap if scrolling is programmatic\n slider.on('programmaticScrollStart', () => {\n slider.container.style.scrollSnapType = 'none';\n });\n // restore scroll snap if user scroll starts\n slider.on('nativeScrollStart', () => {\n slider.container.style.scrollSnapType = '';\n });\n // Listen for mouse down and touch start events on the document\n // This handles both mouse clicks and touch interactions\n let wasInteractedWith = false;\n slider.container.addEventListener('mousedown', () => {\n wasInteractedWith = true;\n });\n slider.container.addEventListener('touchstart', () => {\n wasInteractedWith = true;\n }, { passive: true });\n slider.container.addEventListener('focusin', (e) => {\n // move target parents as long as they are not the container\n // but only if focus didn't start from mouse or touch\n if (!wasInteractedWith) {\n let target = e.target;\n while (target.parentElement !== slider.container) {\n if (target.parentElement) {\n target = target.parentElement;\n }\n else {\n break;\n }\n }\n ensureSlideIsInView(target, 'auto');\n }\n wasInteractedWith = false;\n });\n }\n ;\n function setCSSVariables() {\n slider.options.cssVariableContainer.style.setProperty('--slider-container-height', `${slider.details.containerHeight}px`);\n slider.options.cssVariableContainer.style.setProperty('--slider-container-width', `${slider.details.containerWidth}px`);\n slider.options.cssVariableContainer.style.setProperty('--slider-scrollable-width', `${slider.details.scrollableAreaWidth}px`);\n slider.options.cssVariableContainer.style.setProperty('--slider-slides-count', `${slider.details.slideCount}`);\n slider.options.cssVariableContainer.style.setProperty('--slider-x-offset', `${getLeftOffset()}px`);\n if (typeof slider.options.targetWidth === 'function') {\n slider.options.cssVariableContainer.style.setProperty('--slider-container-target-width', `${slider.options.targetWidth(slider)}px`);\n }\n }\n function setDataAttributes() {\n slider.container.setAttribute('data-has-overflow', slider.details.hasOverflow ? 'true' : 'false');\n if (slider.options.rtl) {\n slider.container.setAttribute('dir', 'rtl');\n }\n }\n function ensureSlideIsInView(slide, scrollBehavior = null) {\n const behavior = scrollBehavior || slider.options.scrollBehavior;\n const slideRect = slide.getBoundingClientRect();\n const sliderRect = slider.container.getBoundingClientRect();\n const containerWidth = slider.container.offsetWidth;\n const scrollLeft = slider.container.scrollLeft;\n const slideStart = slideRect.left - sliderRect.left + scrollLeft;\n const slideEnd = slideStart + slideRect.width;\n let scrollTarget = null;\n if (Math.floor(slideStart) < Math.floor(scrollLeft)) {\n scrollTarget = slideStart;\n }\n else if (Math.floor(slideEnd) > Math.floor(scrollLeft) + Math.floor(containerWidth)) {\n scrollTarget = slideEnd - containerWidth;\n }\n else if (Math.floor(slideStart) === 0) {\n scrollTarget = 0;\n }\n else {\n scrollTarget = slideStart;\n }\n if (scrollTarget !== null) {\n setTimeout((scrollTarget) => {\n slider.emit('programmaticScrollStart');\n slider.container.scrollTo({ left: scrollTarget, behavior: behavior });\n }, 50, scrollTarget);\n }\n }\n ;\n function setActiveSlideIdx() {\n const sliderRect = slider.container.getBoundingClientRect();\n const scrollLeft = slider.getScrollLeft();\n const slides = slider.slides;\n let activeSlideIdx = 0;\n let scrolledPastLastSlide = false;\n if (slider.options.rtl) {\n const scrolledDistance = slider.getInclusiveScrollWidth() - scrollLeft - slider.getInclusiveClientWidth();\n const slidePositions = [];\n for (let i = slides.length - 1; i >= 0; i--) {\n const slideRect = slides[i].getBoundingClientRect();\n const slideEnd = Math.abs(slideRect.left) - Math.abs(sliderRect.left) + scrolledDistance;\n slidePositions.push({\n slide: slides[i],\n slideEnd: slideEnd,\n });\n }\n let closestSlide = null;\n let closestDistance = null;\n for (let i = 0; i < slidePositions.length; i++) {\n const distance = Math.abs(slidePositions[i].slideEnd - scrolledDistance);\n if (closestDistance === null || distance < closestDistance) {\n closestDistance = distance;\n closestSlide = slidePositions[i].slide;\n }\n }\n if (closestSlide) {\n activeSlideIdx = slides.indexOf(closestSlide);\n }\n else {\n activeSlideIdx = slides.length - 1;\n }\n }\n else {\n for (let i = 0; i < slides.length; i++) {\n const slideRect = slides[i].getBoundingClientRect();\n const slideStart = slideRect.left - sliderRect.left + scrollLeft + getGapSize();\n if (Math.floor(slideStart) >= Math.floor(scrollLeft)) {\n activeSlideIdx = i;\n break;\n }\n if (i === slides.length - 1) {\n scrolledPastLastSlide = true;\n }\n }\n }\n if (scrolledPastLastSlide) {\n activeSlideIdx = slides.length - 1;\n }\n const oldActiveSlideIdx = slider.activeSlideIdx;\n slider.activeSlideIdx = activeSlideIdx;\n if (oldActiveSlideIdx !== activeSlideIdx) {\n slider.emit('activeSlideChanged');\n }\n }\n function moveToSlide(idx) {\n const slide = slider.slides[idx];\n if (slide) {\n ensureSlideIsInView(slide);\n }\n }\n ;\n function canMoveToSlide(idx) {\n if (idx < 0 || idx >= slider.slides.length) {\n return false;\n }\n if (idx === slider.activeSlideIdx) {\n return false;\n }\n const direction = slider.options.rtl ? (idx < slider.activeSlideIdx ? 'backwards' : 'forwards') : (idx < slider.activeSlideIdx ? 'backwards' : 'forwards');\n // check if the slide is already in view\n const sliderRect = slider.container.getBoundingClientRect();\n const scrollLeft = slider.getScrollLeft();\n const containerWidth = slider.details.containerWidth;\n const hasUpcomingContent = slider.slides.some((s, i) => {\n if (i === slider.activeSlideIdx) {\n return false; // skip the slide we are checking\n }\n const sRect = s.getBoundingClientRect();\n const sStart = sRect.left - sliderRect.left + scrollLeft;\n const sEnd = sStart + sRect.width;\n if (slider.options.rtl) {\n if (scrollLeft === 0 && slider.details.hasOverflow) {\n return true;\n }\n return (direction === 'forwards' && i > slider.activeSlideIdx && Math.floor(sStart) < Math.floor(scrollLeft)) ||\n (direction === 'backwards' && i < slider.activeSlideIdx && Math.floor(sEnd) > Math.floor(scrollLeft + containerWidth));\n }\n else {\n return (direction === 'forwards' && i > slider.activeSlideIdx && Math.floor(sEnd) > Math.floor(scrollLeft + containerWidth)) ||\n (direction === 'backwards' && i < slider.activeSlideIdx && Math.floor(sStart) < Math.floor(scrollLeft));\n }\n });\n return hasUpcomingContent;\n }\n function moveToSlideInDirection(direction) {\n const activeSlideIdx = slider.activeSlideIdx;\n if (direction === 'prev') {\n if (activeSlideIdx > 0) {\n moveToSlide(activeSlideIdx - 1);\n }\n }\n else if (direction === 'next') {\n if (activeSlideIdx < slider.slides.length - 1) {\n moveToSlide(activeSlideIdx + 1);\n }\n }\n }\n function getInclusiveScrollWidth() {\n return slider.container.scrollWidth + getOutermostChildrenEdgeMarginSum(slider.container);\n }\n ;\n function getInclusiveClientWidth() {\n return slider.container.clientWidth + getOutermostChildrenEdgeMarginSum(slider.container);\n }\n function getScrollLeft() {\n return slider.options.rtl ? Math.abs(slider.container.scrollLeft) : slider.container.scrollLeft;\n }\n ;\n function setScrollLeft(value) {\n slider.container.scrollLeft = slider.options.rtl ? -value : value;\n }\n ;\n function getGapSize() {\n let gapSize = 0;\n if (slider.slides.length > 1) {\n const firstSlideRect = slider.slides[0].getBoundingClientRect();\n const secondSlideRect = slider.slides[1].getBoundingClientRect();\n gapSize = slider.options.rtl ? Math.abs(Math.floor(secondSlideRect.right - firstSlideRect.left)) : Math.floor(secondSlideRect.left - firstSlideRect.right);\n }\n return gapSize;\n }\n ;\n function getLeftOffset() {\n let offset = 0;\n const fullWidthOffset = slider.container.getAttribute('data-full-width-offset');\n if (fullWidthOffset) {\n offset = parseInt(fullWidthOffset);\n }\n return Math.floor(offset);\n }\n ;\n function moveToDirection(direction = \"prev\") {\n const scrollStrategy = slider.options.scrollStrategy;\n const scrollLeft = slider.container.scrollLeft;\n const sliderRect = slider.container.getBoundingClientRect();\n const containerWidth = slider.container.offsetWidth;\n let targetScrollPosition = scrollLeft;\n const realDirection = slider.options.rtl ? (direction === 'prev' ? 'next' : 'prev') : direction;\n if (realDirection === 'prev') {\n targetScrollPosition = Math.max(0, scrollLeft - slider.container.offsetWidth);\n }\n else if (realDirection === 'next') {\n targetScrollPosition = Math.min(slider.getInclusiveScrollWidth(), scrollLeft + slider.container.offsetWidth);\n }\n if (scrollStrategy === 'fullSlide') {\n let fullSlideTargetScrollPosition = null;\n // extend targetScrollPosition to include gap\n if (realDirection === 'prev') {\n fullSlideTargetScrollPosition = Math.max(0, targetScrollPosition - getGapSize());\n }\n else {\n fullSlideTargetScrollPosition = Math.min(slider.getInclusiveScrollWidth(), targetScrollPosition + getGapSize());\n }\n if (realDirection === 'next') {\n let partialSlideFound = false;\n for (let slide of slider.slides) {\n const slideRect = slide.getBoundingClientRect();\n const slideStart = slideRect.left - sliderRect.left + scrollLeft;\n const slideEnd = slideStart + slideRect.width;\n if (Math.floor(slideStart) < Math.floor(targetScrollPosition) && Math.floor(slideEnd) > Math.floor(targetScrollPosition)) {\n fullSlideTargetScrollPosition = slideStart;\n partialSlideFound = true;\n break;\n }\n }\n if (!partialSlideFound) {\n fullSlideTargetScrollPosition = Math.min(targetScrollPosition, slider.getInclusiveScrollWidth() - slider.container.offsetWidth);\n }\n if (fullSlideTargetScrollPosition) {\n if (Math.floor(fullSlideTargetScrollPosition) > Math.floor(scrollLeft)) {\n // make sure fullSlideTargetScrollPosition is possible considering the container width\n const maxScrollPosition = Math.floor(slider.getInclusiveScrollWidth()) - Math.floor(containerWidth);\n targetScrollPosition = Math.min(fullSlideTargetScrollPosition, maxScrollPosition);\n }\n else {\n // cannot snap to slide, move one page worth of distance\n targetScrollPosition = Math.min(slider.getInclusiveScrollWidth(), scrollLeft + containerWidth);\n }\n }\n }\n else {\n let partialSlideFound = false;\n for (let slide of slider.slides) {\n const slideRect = slide.getBoundingClientRect();\n const slideStart = slideRect.left - sliderRect.left + scrollLeft;\n const slideEnd = slideStart + slideRect.width;\n if (Math.floor(slideStart) < Math.floor(scrollLeft) && Math.floor(slideEnd) > Math.floor(scrollLeft)) {\n fullSlideTargetScrollPosition = slideEnd - containerWidth;\n partialSlideFound = true;\n break;\n }\n }\n if (!partialSlideFound) {\n fullSlideTargetScrollPosition = Math.max(0, scrollLeft - containerWidth);\n }\n if (fullSlideTargetScrollPosition && Math.floor(fullSlideTargetScrollPosition) < Math.floor(scrollLeft)) {\n targetScrollPosition = fullSlideTargetScrollPosition;\n }\n }\n }\n // add left offset\n const offsettedTargetScrollPosition = targetScrollPosition - getLeftOffset();\n if (Math.floor(offsettedTargetScrollPosition) >= 0) {\n targetScrollPosition = offsettedTargetScrollPosition;\n }\n slider.emit('programmaticScrollStart');\n slider.container.style.scrollBehavior = slider.options.scrollBehavior;\n slider.container.scrollLeft = targetScrollPosition;\n setTimeout(() => slider.container.style.scrollBehavior = '', 50);\n }\n ;\n function snapToClosestSlide(direction = \"prev\") {\n var _a, _b;\n const { slides, options, container } = slider;\n const { rtl, emulateScrollSnapMaxThreshold = 10, scrollBehavior = 'smooth', } = options;\n const isForward = rtl ? direction === 'prev' : direction === 'next';\n const scrollPos = getScrollLeft();\n // Get container rect once (includes any CSS transforms)\n const containerRect = container.getBoundingClientRect();\n const factor = rtl ? -1 : 1;\n // Calculate target area offset if targetWidth is defined\n let targetAreaOffset = 0;\n if (typeof options.targetWidth === 'function') {\n try {\n const targetWidth = options.targetWidth(slider);\n const containerWidth = containerRect.width;\n if (Number.isFinite(targetWidth) && targetWidth > 0 && targetWidth < containerWidth) {\n targetAreaOffset = (containerWidth - targetWidth) / 2;\n }\n }\n catch (error) {\n // ignore errors, use default offset of 0\n }\n }\n // Build slide metadata\n const slideData = [...slides].map(slide => {\n const { width } = slide.getBoundingClientRect();\n const slideRect = slide.getBoundingClientRect();\n // position relative to container's left edge\n const relativeStart = (slideRect.left - containerRect.left) + scrollPos;\n // Adjust trigger point to align with target area start instead of container edge\n const alignmentPoint = relativeStart - targetAreaOffset;\n const triggerPoint = Math.min(alignmentPoint + width / 2, alignmentPoint + emulateScrollSnapMaxThreshold);\n return { start: relativeStart - targetAreaOffset, trigger: triggerPoint };\n });\n // Pick the target start based on drag direction\n let targetStart = null;\n if (isForward) {\n const found = slideData.find(item => scrollPos <= item.trigger);\n targetStart = (_a = found === null || found === void 0 ? void 0 : found.start) !== null && _a !== void 0 ? _a : null;\n }\n else {\n const found = [...slideData].reverse().find(item => scrollPos >= item.trigger);\n targetStart = (_b = found === null || found === void 0 ? void 0 : found.start) !== null && _b !== void 0 ? _b : null;\n }\n if (targetStart == null)\n return;\n // Clamp to zero and apply RTL factor\n const finalLeft = Math.max(0, Math.floor(targetStart)) * factor;\n container.scrollTo({ left: finalLeft, behavior: scrollBehavior });\n }\n function on(name, cb) {\n if (!subs[name]) {\n subs[name] = [];\n }\n subs[name].push(cb);\n }\n ;\n function emit(name) {\n var _a;\n if (subs && subs[name]) {\n subs[name].forEach(cb => {\n cb(slider);\n });\n }\n const optionCallBack = (_a = slider === null || slider === void 0 ? void 0 : slider.options) === null || _a === void 0 ? void 0 : _a[name];\n // Type guard to check if the option callback is a function\n if (typeof optionCallBack === 'function') {\n optionCallBack(slider); // Type assertion here\n }\n }\n ;\n slider = {\n emit,\n moveToDirection,\n canMoveToSlide,\n moveToSlide,\n moveToSlideInDirection,\n snapToClosestSlide,\n getInclusiveScrollWidth,\n getInclusiveClientWidth,\n getScrollLeft,\n setScrollLeft,\n setActiveSlideIdx,\n on,\n options,\n };\n init();\n return slider;\n}\n","export default function details(slider) {\n var _a;\n let instance;\n let hasOverflow = false;\n let slideCount = 0;\n let containerWidth = 0;\n let containerHeight = 0;\n let scrollableAreaWidth = 0;\n let amountOfPages = 0;\n let currentPage = 1;\n if (Math.floor(slider.getInclusiveScrollWidth()) > Math.floor(slider.getInclusiveClientWidth())) {\n hasOverflow = true;\n }\n slideCount = (_a = slider.slides.length) !== null && _a !== void 0 ? _a : 0;\n containerWidth = slider.container.offsetWidth;\n containerHeight = slider.container.offsetHeight;\n scrollableAreaWidth = slider.getInclusiveScrollWidth();\n amountOfPages = Math.ceil(scrollableAreaWidth / containerWidth);\n if (Math.floor(slider.getScrollLeft()) >= 0) {\n currentPage = Math.floor(slider.getScrollLeft() / containerWidth);\n // consider as last page if the scrollLeft + containerWidth is equal to scrollWidth\n if (Math.floor(slider.getScrollLeft() + containerWidth) === Math.floor(scrollableAreaWidth)) {\n currentPage = amountOfPages - 1;\n }\n }\n instance = {\n hasOverflow,\n slideCount,\n containerWidth,\n containerHeight,\n scrollableAreaWidth,\n amountOfPages,\n currentPage,\n };\n return instance;\n}\n;\n","import Slider from './slider';\nexport default function OverflowSlider(container, options, plugins) {\n try {\n // check that container HTML element\n if (!(container instanceof Element)) {\n throw new Error(`Container must be HTML element, found ${typeof container}`);\n }\n const defaults = {\n cssVariableContainer: container,\n scrollBehavior: \"smooth\",\n scrollStrategy: \"fullSlide\",\n slidesSelector: \":scope > *\",\n emulateScrollSnap: false,\n emulateScrollSnapMaxThreshold: 64,\n rtl: false,\n };\n const sliderOptions = Object.assign(Object.assign({}, defaults), options);\n // disable smooth scrolling if user prefers reduced motion\n if (window.matchMedia('(prefers-reduced-motion: reduce)').matches) {\n sliderOptions.scrollBehavior = \"auto\";\n }\n return Slider(container, sliderOptions, plugins);\n }\n catch (e) {\n console.error(e);\n }\n}\n"],"names":["generateId","prefix","i","id","document","getElementById","getOutermostChildrenEdgeMarginSum","el","children","length","firstChild","firstChildStyle","getComputedStyle","firstChildMarginLeft","parseFloat","marginLeft","lastChild","lastChildStyle","marginRight","Slider","container","options","plugins","slider","subs","setDetails","isInit","oldDetails","details","newDetails","_a","instance","hasOverflow","slideCount","containerWidth","containerHeight","scrollableAreaWidth","amountOfPages","currentPage","Math","floor","getInclusiveScrollWidth","getInclusiveClientWidth","slides","offsetWidth","offsetHeight","ceil","getScrollLeft","obj1","obj2","keys1","Object","keys","keys2","key","prototype","hasOwnProperty","call","objectsAreEqual","emit","setSlides","Array","from","querySelectorAll","slidesSelector","setCSSVariables","cssVariableContainer","style","setProperty","getLeftOffset","targetWidth","setDataAttributes","setAttribute","rtl","ensureSlideIsInView","slide","scrollBehavior","behavior","slideRect","getBoundingClientRect","sliderRect","scrollLeft","slideStart","left","slideEnd","width","scrollTarget","setTimeout","scrollTo","setActiveSlideIdx","activeSlideIdx","scrolledPastLastSlide","scrolledDistance","slidePositions","abs","push","closestSlide","closestDistance","distance","indexOf","getGapSize","oldActiveSlideIdx","moveToSlide","idx","gapSize","firstSlideRect","secondSlideRect","right","offset","fullWidthOffset","getAttribute","parseInt","name","forEach","cb","optionCallBack","moveToDirection","direction","scrollStrategy","targetScrollPosition","realDirection","max","min","fullSlideTargetScrollPosition","partialSlideFound","maxScrollPosition","offsettedTargetScrollPosition","canMoveToSlide","some","s","sRect","sStart","sEnd","moveToSlideInDirection","snapToClosestSlide","_b","emulateScrollSnapMaxThreshold","isForward","scrollPos","containerRect","factor","targetAreaOffset","Number","isFinite","error","slideData","map","relativeStart","alignmentPoint","triggerPoint","start","trigger","targetStart","found","find","item","reverse","finalLeft","scrollWidth","clientWidth","setScrollLeft","value","on","containerId","transition","requestId","window","cancelAnimationFrame","requestAnimationFrame","MutationObserver","observe","childList","scrollTimeout","nativeScrollTimeout","programmaticScrollTimeout","ResizeObserver","nativeScrollLeft","programmaticScrollLeft","isScrolling","isUserScrolling","isProgrammaticScrolling","addEventListener","newScrollLeft","clearTimeout","nativeScrollHandler","scrollSnapType","wasInteractedWith","passive","e","target","parentElement","addEventListeners","plugin","removeProperty","init","Element","Error","defaults","emulateScrollSnap","sliderOptions","assign","matchMedia","matches","console"],"mappings":"aAAA,SAASA,EAAWC,EAAQC,EAAI,GAC5B,MAAMC,EAAK,GAAGF,KAAUC,IACxB,OAAIE,SAASC,eAAeF,GACjBH,EAAWC,EAAQC,EAAI,GAE3BC,CACX,CAeA,SAASG,EAAkCC,GACvC,GAA2B,IAAvBA,EAAGC,SAASC,OACZ,OAAO,EAGX,MAAMC,EAAaH,EAAGC,SAAS,GACzBG,EAAkBC,iBAAiBF,GACnCG,EAAuBC,WAAWH,EAAgBI,YAElDC,EAAYT,EAAGC,SAASD,EAAGC,SAASC,OAAS,GAC7CQ,EAAiBL,iBAAiBI,GAExC,OAAOH,EADsBC,WAAWG,EAAeC,YAE3D,CChCe,SAASC,EAAOC,EAAWC,EAASC,GAC/C,IAAIC,EACAC,EAAO,CAAA,EAiEX,SAASC,EAAWC,GAAS,GACzB,MAAMC,EAAaJ,EAAOK,QACpBC,ECvEC,SAAiBN,GAC5B,IAAIO,EACJ,IAAIC,EACAC,GAAc,EACdC,EAAa,EACbC,EAAiB,EACjBC,EAAkB,EAClBC,EAAsB,EACtBC,EAAgB,EAChBC,EAAc,EAyBlB,OAxBIC,KAAKC,MAAMjB,EAAOkB,2BAA6BF,KAAKC,MAAMjB,EAAOmB,6BACjEV,GAAc,GAElBC,EAA6C,QAA/BH,EAAKP,EAAOoB,OAAOlC,cAA2B,IAAPqB,EAAgBA,EAAK,EAC1EI,EAAiBX,EAAOH,UAAUwB,YAClCT,EAAkBZ,EAAOH,UAAUyB,aACnCT,EAAsBb,EAAOkB,0BAC7BJ,EAAgBE,KAAKO,KAAKV,EAAsBF,GAC5CK,KAAKC,MAAMjB,EAAOwB,kBAAoB,IACtCT,EAAcC,KAAKC,MAAMjB,EAAOwB,gBAAkBb,GAE9CK,KAAKC,MAAMjB,EAAOwB,gBAAkBb,KAAoBK,KAAKC,MAAMJ,KACnEE,EAAcD,EAAgB,IAGtCN,EAAW,CACPC,cACAC,aACAC,iBACAC,kBACAC,sBACAC,gBACAC,eAEGP,CACX,CDoC2BH,CAAQL,GAC3BA,EAAOK,QAAUC,EACZH,GDlEb,SAAyBsB,EAAMC,GAC3B,MAAMC,EAAQC,OAAOC,KAAKJ,GACpBK,EAAQF,OAAOC,KAAKH,GAC1B,GAAIC,EAAMzC,SAAW4C,EAAM5C,OACvB,OAAO,EAEX,IAAK,IAAI6C,KAAOJ,EAEZ,IAAKC,OAAOI,UAAUC,eAAeC,KAAKR,EAAMK,IAAQN,EAAKM,KAASL,EAAKK,GACvE,OAAO,EAGf,OAAO,CACX,CCqDwBI,CAAgB/B,EAAYE,GAGnCH,GACLH,EAAOoC,KAAK,kBAHZpC,EAAOoC,KAAK,iBAKxB,CAEI,SAASC,IACLrC,EAAOoB,OAASkB,MAAMC,KAAKvC,EAAOH,UAAU2C,iBAAiBxC,EAAOF,QAAQ2C,gBACpF,CAsHI,SAASC,IACL1C,EAAOF,QAAQ6C,qBAAqBC,MAAMC,YAAY,4BAA6B,GAAG7C,EAAOK,QAAQO,qBACrGZ,EAAOF,QAAQ6C,qBAAqBC,MAAMC,YAAY,2BAA4B,GAAG7C,EAAOK,QAAQM,oBACpGX,EAAOF,QAAQ6C,qBAAqBC,MAAMC,YAAY,4BAA6B,GAAG7C,EAAOK,QAAQQ,yBACrGb,EAAOF,QAAQ6C,qBAAqBC,MAAMC,YAAY,wBAAyB,GAAG7C,EAAOK,QAAQK,cACjGV,EAAOF,QAAQ6C,qBAAqBC,MAAMC,YAAY,oBAAqB,GAAGC,SACpC,mBAA/B9C,EAAOF,QAAQiD,aACtB/C,EAAOF,QAAQ6C,qBAAqBC,MAAMC,YAAY,kCAAmC,GAAG7C,EAAOF,QAAQiD,YAAY/C,OAEnI,CACI,SAASgD,IACLhD,EAAOH,UAAUoD,aAAa,oBAAqBjD,EAAOK,QAAQI,YAAc,OAAS,SACrFT,EAAOF,QAAQoD,KACflD,EAAOH,UAAUoD,aAAa,MAAO,MAEjD,CACI,SAASE,EAAoBC,EAAOC,EAAiB,MACjD,MAAMC,EAAWD,GAAkBrD,EAAOF,QAAQuD,eAC5CE,EAAYH,EAAMI,wBAClBC,EAAazD,EAAOH,UAAU2D,wBAC9B7C,EAAiBX,EAAOH,UAAUwB,YAClCqC,EAAa1D,EAAOH,UAAU6D,WAC9BC,EAAaJ,EAAUK,KAAOH,EAAWG,KAAOF,EAChDG,EAAWF,EAAaJ,EAAUO,MACxC,IAAIC,EAAe,KAEfA,EADA/C,KAAKC,MAAM0C,GAAc3C,KAAKC,MAAMyC,GACrBC,EAEV3C,KAAKC,MAAM4C,GAAY7C,KAAKC,MAAMyC,GAAc1C,KAAKC,MAAMN,GACjDkD,EAAWlD,EAEM,IAA3BK,KAAKC,MAAM0C,GACD,EAGAA,EAEE,OAAjBI,GACAC,WAAYD,IACR/D,EAAOoC,KAAK,2BACZpC,EAAOH,UAAUoE,SAAS,CAAEL,KAAMG,EAAcT,SAAUA,KAC3D,GAAIS,EAEnB,CAEI,SAASG,IACL,MAAMT,EAAazD,EAAOH,UAAU2D,wBAC9BE,EAAa1D,EAAOwB,gBACpBJ,EAASpB,EAAOoB,OACtB,IAAI+C,EAAiB,EACjBC,GAAwB,EAC5B,GAAIpE,EAAOF,QAAQoD,IAAK,CACpB,MAAMmB,EAAmBrE,EAAOkB,0BAA4BwC,EAAa1D,EAAOmB,0BAC1EmD,EAAiB,GACvB,IAAK,IAAI3F,EAAIyC,EAAOlC,OAAS,EAAGP,GAAK,EAAGA,IAAK,CACzC,MAAM4E,EAAYnC,EAAOzC,GAAG6E,wBACtBK,EAAW7C,KAAKuD,IAAIhB,EAAUK,MAAQ5C,KAAKuD,IAAId,EAAWG,MAAQS,EACxEC,EAAeE,KAAK,CAChBpB,MAAOhC,EAAOzC,GACdkF,SAAUA,GAE9B,CACY,IAAIY,EAAe,KACfC,EAAkB,KACtB,IAAK,IAAI/F,EAAI,EAAGA,EAAI2F,EAAepF,OAAQP,IAAK,CAC5C,MAAMgG,EAAW3D,KAAKuD,IAAID,EAAe3F,GAAGkF,SAAWQ,IAC/B,OAApBK,GAA4BC,EAAWD,KACvCA,EAAkBC,EAClBF,EAAeH,EAAe3F,GAAGyE,MAErD,CAEgBe,EADAM,EACiBrD,EAAOwD,QAAQH,GAGfrD,EAAOlC,OAAS,CAEjD,MAEY,IAAK,IAAIP,EAAI,EAAGA,EAAIyC,EAAOlC,OAAQP,IAAK,CACpC,MACMgF,EADYvC,EAAOzC,GAAG6E,wBACCI,KAAOH,EAAWG,KAAOF,EAAamB,IACnE,GAAI7D,KAAKC,MAAM0C,IAAe3C,KAAKC,MAAMyC,GAAa,CAClDS,EAAiBxF,EACjB,KACpB,CACoBA,IAAMyC,EAAOlC,OAAS,IACtBkF,GAAwB,EAE5C,CAEYA,IACAD,EAAiB/C,EAAOlC,OAAS,GAErC,MAAM4F,EAAoB9E,EAAOmE,eACjCnE,EAAOmE,eAAiBA,EACpBW,IAAsBX,GACtBnE,EAAOoC,KAAK,qBAExB,CACI,SAAS2C,EAAYC,GACjB,MAAM5B,EAAQpD,EAAOoB,OAAO4D,GACxB5B,GACAD,EAAoBC,EAEhC,CAuDI,SAAS5B,IACL,OAAOxB,EAAOF,QAAQoD,IAAMlC,KAAKuD,IAAIvE,EAAOH,UAAU6D,YAAc1D,EAAOH,UAAU6D,UAC7F,CAMI,SAASmB,IACL,IAAII,EAAU,EACd,GAAIjF,EAAOoB,OAAOlC,OAAS,EAAG,CAC1B,MAAMgG,EAAiBlF,EAAOoB,OAAO,GAAGoC,wBAClC2B,EAAkBnF,EAAOoB,OAAO,GAAGoC,wBACzCyB,EAAUjF,EAAOF,QAAQoD,IAAMlC,KAAKuD,IAAIvD,KAAKC,MAAMkE,EAAgBC,MAAQF,EAAetB,OAAS5C,KAAKC,MAAMkE,EAAgBvB,KAAOsB,EAAeE,MAChK,CACQ,OAAOH,CACf,CAEI,SAASnC,IACL,IAAIuC,EAAS,EACb,MAAMC,EAAkBtF,EAAOH,UAAU0F,aAAa,0BAItD,OAHID,IACAD,EAASG,SAASF,IAEftE,KAAKC,MAAMoE,EAC1B,CAyKI,OAhBArF,EAAS,CACLoC,KAfJ,SAAcqD,GACV,IAAIlF,EACAN,GAAQA,EAAKwF,IACbxF,EAAKwF,GAAMC,QAAQC,IACfA,EAAG3F,KAGX,MAAM4F,EAA2F,QAAzErF,EAAKP,aAAuC,EAASA,EAAOF,eAA4B,IAAPS,OAAgB,EAASA,EAAGkF,GAEvG,mBAAnBG,GACPA,EAAe5F,EAE3B,EAIQ6F,gBAzJJ,SAAyBC,EAAY,QACjC,MAAMC,EAAiB/F,EAAOF,QAAQiG,eAChCrC,EAAa1D,EAAOH,UAAU6D,WAC9BD,EAAazD,EAAOH,UAAU2D,wBAC9B7C,EAAiBX,EAAOH,UAAUwB,YACxC,IAAI2E,EAAuBtC,EAC3B,MAAMuC,EAAgBjG,EAAOF,QAAQoD,IAAqB,SAAd4C,EAAuB,OAAS,OAAUA,EAOtF,GANsB,SAAlBG,EACAD,EAAuBhF,KAAKkF,IAAI,EAAGxC,EAAa1D,EAAOH,UAAUwB,aAE1C,SAAlB4E,IACLD,EAAuBhF,KAAKmF,IAAInG,EAAOkB,0BAA2BwC,EAAa1D,EAAOH,UAAUwB,cAE7E,cAAnB0E,EAAgC,CAChC,IAAIK,EAAgC,KAQpC,GALIA,EADkB,SAAlBH,EACgCjF,KAAKkF,IAAI,EAAGF,EAAuBnB,KAGnC7D,KAAKmF,IAAInG,EAAOkB,0BAA2B8E,EAAuBnB,KAEhF,SAAlBoB,EAA0B,CAC1B,IAAII,GAAoB,EACxB,IAAK,IAAIjD,KAASpD,EAAOoB,OAAQ,CAC7B,MAAMmC,EAAYH,EAAMI,wBAClBG,EAAaJ,EAAUK,KAAOH,EAAWG,KAAOF,EAChDG,EAAWF,EAAaJ,EAAUO,MACxC,GAAI9C,KAAKC,MAAM0C,GAAc3C,KAAKC,MAAM+E,IAAyBhF,KAAKC,MAAM4C,GAAY7C,KAAKC,MAAM+E,GAAuB,CACtHI,EAAgCzC,EAChC0C,GAAoB,EACpB,KACxB,CACA,CAIgB,GAHKA,IACDD,EAAgCpF,KAAKmF,IAAIH,EAAsBhG,EAAOkB,0BAA4BlB,EAAOH,UAAUwB,cAEnH+E,EACA,GAAIpF,KAAKC,MAAMmF,GAAiCpF,KAAKC,MAAMyC,GAAa,CAEpE,MAAM4C,EAAoBtF,KAAKC,MAAMjB,EAAOkB,2BAA6BF,KAAKC,MAAMN,GACpFqF,EAAuBhF,KAAKmF,IAAIC,EAA+BE,EACvF,MAGwBN,EAAuBhF,KAAKmF,IAAInG,EAAOkB,0BAA2BwC,EAAa/C,EAGvG,KACiB,CACD,IAAI0F,GAAoB,EACxB,IAAK,IAAIjD,KAASpD,EAAOoB,OAAQ,CAC7B,MAAMmC,EAAYH,EAAMI,wBAClBG,EAAaJ,EAAUK,KAAOH,EAAWG,KAAOF,EAChDG,EAAWF,EAAaJ,EAAUO,MACxC,GAAI9C,KAAKC,MAAM0C,GAAc3C,KAAKC,MAAMyC,IAAe1C,KAAKC,MAAM4C,GAAY7C,KAAKC,MAAMyC,GAAa,CAClG0C,EAAgCvC,EAAWlD,EAC3C0F,GAAoB,EACpB,KACxB,CACA,CACqBA,IACDD,EAAgCpF,KAAKkF,IAAI,EAAGxC,EAAa/C,IAEzDyF,GAAiCpF,KAAKC,MAAMmF,GAAiCpF,KAAKC,MAAMyC,KACxFsC,EAAuBI,EAE3C,CACA,CAEQ,MAAMG,EAAgCP,EAAuBlD,IACzD9B,KAAKC,MAAMsF,IAAkC,IAC7CP,EAAuBO,GAE3BvG,EAAOoC,KAAK,2BACZpC,EAAOH,UAAU+C,MAAMS,eAAiBrD,EAAOF,QAAQuD,eACvDrD,EAAOH,UAAU6D,WAAasC,EAC9BhC,WAAW,IAAMhE,EAAOH,UAAU+C,MAAMS,eAAiB,GAAI,GACrE,EA4EQmD,eA1OJ,SAAwBxB,GACpB,GAAIA,EAAM,GAAKA,GAAOhF,EAAOoB,OAAOlC,OAChC,OAAO,EAEX,GAAI8F,IAAQhF,EAAOmE,eACf,OAAO,EAEX,MAAM2B,GAAY9F,EAAOF,QAAQoD,IAAO8B,EAAMhF,EAAOmE,eAAiB,YAAc,YAE9EV,EAAazD,EAAOH,UAAU2D,wBAC9BE,EAAa1D,EAAOwB,gBACpBb,EAAiBX,EAAOK,QAAQM,eAoBtC,OAnB2BX,EAAOoB,OAAOqF,KAAK,CAACC,EAAG/H,KAC9C,GAAIA,IAAMqB,EAAOmE,eACb,OAAO,EAEX,MAAMwC,EAAQD,EAAElD,wBACVoD,EAASD,EAAM/C,KAAOH,EAAWG,KAAOF,EACxCmD,EAAOD,EAASD,EAAM7C,MAC5B,OAAI9D,EAAOF,QAAQoD,MACI,IAAfQ,IAAoB1D,EAAOK,QAAQI,eAGjB,aAAdqF,GAA4BnH,EAAIqB,EAAOmE,gBAAkBnD,KAAKC,MAAM2F,GAAU5F,KAAKC,MAAMyC,IAC9E,cAAdoC,GAA6BnH,EAAIqB,EAAOmE,gBAAkBnD,KAAKC,MAAM4F,GAAQ7F,KAAKC,MAAMyC,EAAa/C,IAGpF,aAAdmF,GAA4BnH,EAAIqB,EAAOmE,gBAAkBnD,KAAKC,MAAM4F,GAAQ7F,KAAKC,MAAMyC,EAAa/C,IACzF,cAAdmF,GAA6BnH,EAAIqB,EAAOmE,gBAAkBnD,KAAKC,MAAM2F,GAAU5F,KAAKC,MAAMyC,IAI/G,EA2MQqB,cACA+B,uBA3MJ,SAAgChB,GAC5B,MAAM3B,EAAiBnE,EAAOmE,eACZ,SAAd2B,EACI3B,EAAiB,GACjBY,EAAYZ,EAAiB,GAGd,SAAd2B,GACD3B,EAAiBnE,EAAOoB,OAAOlC,OAAS,GACxC6F,EAAYZ,EAAiB,EAG7C,EAgMQ4C,mBA7EJ,SAA4BjB,EAAY,QACpC,IAAIvF,EAAIyG,EACR,MAAM5F,OAAEA,EAAMtB,QAAEA,EAAOD,UAAEA,GAAcG,GACjCkD,IAAEA,EAAG+D,8BAAEA,EAAgC,GAAE5D,eAAEA,EAAiB,UAAcvD,EAC1EoH,EAAYhE,EAAoB,SAAd4C,EAAqC,SAAdA,EACzCqB,EAAY3F,IAEZ4F,EAAgBvH,EAAU2D,wBAC1B6D,EAASnE,GAAM,EAAK,EAE1B,IAAIoE,EAAmB,EACvB,GAAmC,mBAAxBxH,EAAQiD,YACf,IACI,MAAMA,EAAcjD,EAAQiD,YAAY/C,GAClCW,EAAiByG,EAActD,MACjCyD,OAAOC,SAASzE,IAAgBA,EAAc,GAAKA,EAAcpC,IACjE2G,GAAoB3G,EAAiBoC,GAAe,EAExE,CACY,MAAO0E,GAEnB,CAGQ,MAAMC,EAAY,IAAItG,GAAQuG,IAAIvE,IAC9B,MAAMU,MAAEA,GAAUV,EAAMI,wBAGlBoE,EAFYxE,EAAMI,wBAESI,KAAOwD,EAAcxD,KAAQuD,EAExDU,EAAiBD,EAAgBN,EACjCQ,EAAe9G,KAAKmF,IAAI0B,EAAiB/D,EAAQ,EAAG+D,EAAiBZ,GAC3E,MAAO,CAAEc,MAAOH,EAAgBN,EAAkBU,QAASF,KAG/D,IAAIG,EAAc,KAClB,GAAIf,EAAW,CACX,MAAMgB,EAAQR,EAAUS,KAAKC,GAAQjB,GAAaiB,EAAKJ,SACvDC,EAAmF,QAApE1H,EAAK2H,aAAqC,EAASA,EAAMH,aAA0B,IAAPxH,EAAgBA,EAAK,IAC5H,KACa,CACD,MAAM2H,EAAQ,IAAIR,GAAWW,UAAUF,KAAKC,GAAQjB,GAAaiB,EAAKJ,SACtEC,EAAmF,QAApEjB,EAAKkB,aAAqC,EAASA,EAAMH,aAA0B,IAAPf,EAAgBA,EAAK,IAC5H,CACQ,GAAmB,MAAfiB,EACA,OAEJ,MAAMK,EAAYtH,KAAKkF,IAAI,EAAGlF,KAAKC,MAAMgH,IAAgBZ,EACzDxH,EAAUoE,SAAS,CAAEL,KAAM0E,EAAWhF,SAAUD,GACxD,EA6BQnC,wBAhMJ,WACI,OAAOlB,EAAOH,UAAU0I,YAAcxJ,EAAkCiB,EAAOH,UACvF,EA+LQsB,wBA7LJ,WACI,OAAOnB,EAAOH,UAAU2I,YAAczJ,EAAkCiB,EAAOH,UACvF,EA4LQ2B,gBACAiH,cAxLJ,SAAuBC,GACnB1I,EAAOH,UAAU6D,WAAa1D,EAAOF,QAAQoD,KAAOwF,EAAQA,CACpE,EAuLQxE,oBACAyE,GAjCJ,SAAYlD,EAAME,GACT1F,EAAKwF,KACNxF,EAAKwF,GAAQ,IAEjBxF,EAAKwF,GAAMjB,KAAKmB,EACxB,EA6BQ7F,WAzhBJ,WACIE,EAAOH,UAAYA,EAEnB,IAAI+I,EAAc/I,EAAU0F,aAAa,MACrB,OAAhBqD,IACAA,EAAcnK,EAAW,mBACzBoB,EAAUoD,aAAa,KAAM2F,IAEjCvG,IAjBArC,EAAOoB,OAAOsE,QAAStC,IACnBA,EAAMR,MAAMiG,WAAa,SAmB7B3I,GAAW,GACXgE,IACAlE,EAAO2I,GAAG,kBAAmB,KACzBtG,IACAnC,IACAgE,MAEJlE,EAAO2I,GAAG,uBAAwB,IAAMzI,KACxC,IAAI4I,EAAY,EAchB,GAJA9I,EAAO2I,GAAG,SATiB,KACnBG,GACAC,OAAOC,qBAAqBF,GAEhCA,EAAYC,OAAOE,sBAAsB,KACrC/I,IACAgE,QA2CZ,WAEqB,IAAIgF,iBAAiB,IAAMlJ,EAAOoC,KAAK,oBAC/C+G,QAAQnJ,EAAOH,UAAW,CAAEuJ,WAAW,IAKhD,IAAIC,EACAC,EACAC,EALmB,IAAIC,eAAe,IAAMxJ,EAAOoC,KAAK,yBAC7C+G,QAAQnJ,EAAOH,WAK9B,IAAI6D,EAAa1D,EAAOH,UAAU6D,WAC9B+F,EAAmBzJ,EAAOH,UAAU6D,WACpCgG,EAAyB1J,EAAOH,UAAU6D,WAC1CiG,GAAc,EACdC,GAAkB,EAClBC,GAA0B,EAE9B7J,EAAOH,UAAUiK,iBAAiB,SAAU,KACxC,MAAMC,EAAgB/J,EAAOH,UAAU6D,WACnC1C,KAAKC,MAAMyC,KAAgB1C,KAAKC,MAAM8I,KACjCJ,IACDA,GAAc,EACd3J,EAAOoC,KAAK,gBAEhBsB,EAAaqG,EACbC,aAAaX,GACbA,EAAgBrF,WAAW,KACvB2F,GAAc,EACd3J,EAAOoC,KAAK,cACb,IACHpC,EAAOoC,KAAK,WAGZwH,GACAK,MAIR,MAAMA,EAAsB,KACxB,MAAMF,EAAgB/J,EAAOH,UAAU6D,WACnC1C,KAAKC,MAAMwI,KAAsBzI,KAAKC,MAAM8I,IAAmBF,IAC1DD,IACD5J,EAAOoC,KAAK,qBACZwH,GAAkB,GAEtB5J,EAAOoC,KAAK,gBACZqH,EAAmBM,EACnBC,aAAaV,GACbA,EAAsBtF,WAAW,KAC7B4F,GAAkB,EAClB5J,EAAOoC,KAAK,mBAGZsH,EAAyBD,GAC1B,MAGXzJ,EAAOH,UAAUiK,iBAAiB,YAAaG,GAC/CjK,EAAOH,UAAUiK,iBAAiB,aAAcG,GAChDjK,EAAOH,UAAUiK,iBAAiB,QAASG,GAE3CjK,EAAO2I,GAAG,0BAA2B,KACjCkB,GAA0B,IAE9B7J,EAAOH,UAAUiK,iBAAiB,SAAU,KACxC,MAAMC,EAAgB/J,EAAOH,UAAU6D,WACnC1C,KAAKC,MAAMyI,KAA4B1I,KAAKC,MAAM8I,KAAmBH,GAAmBC,IACxFH,EAAyBK,EACzBC,aAAaT,GACbA,EAA4BvF,WAAW,KACnC6F,GAA0B,EAC1B7J,EAAOoC,KAAK,yBAGZqH,EAAmBC,GACpB,IACH1J,EAAOoC,KAAK,yBAKpBpC,EAAO2I,GAAG,0BAA2B,KACjC3I,EAAOH,UAAU+C,MAAMsH,eAAiB,SAG5ClK,EAAO2I,GAAG,oBAAqB,KAC3B3I,EAAOH,UAAU+C,MAAMsH,eAAiB,KAI5C,IAAIC,GAAoB,EACxBnK,EAAOH,UAAUiK,iBAAiB,YAAa,KAC3CK,GAAoB,IAExBnK,EAAOH,UAAUiK,iBAAiB,aAAc,KAC5CK,GAAoB,GACrB,CAAEC,SAAS,IACdpK,EAAOH,UAAUiK,iBAAiB,UAAYO,IAG1C,IAAKF,EAAmB,CACpB,IAAIG,EAASD,EAAEC,OACf,KAAOA,EAAOC,gBAAkBvK,EAAOH,WAC/ByK,EAAOC,eACPD,EAASA,EAAOC,cAMxBpH,EAAoBmH,EAAQ,OAC5C,CACYH,GAAoB,GAEhC,CA1JQK,GACAxH,IACAN,IACI3C,EAAS,CACT,IAAK,MAAM0K,KAAU1K,EACjB0K,EAAOzK,GAIXE,IACAgE,IACAxB,IACA1C,EAAOoC,KAAK,gBAExB,CACQpC,EAAO2I,GAAG,iBAAkB,KACxB3F,IACAN,MAEJ1C,EAAOoC,KAAK,WArDZpC,EAAOoB,OAAOsE,QAAStC,IACnBA,EAAMR,MAAM8H,eAAe,gBAsD/B1K,EAAOH,UAAUoD,aAAa,aAAc,OACpD,CAueI0H,GACO3K,CACX,wBE3iBe,SAAwBH,EAAWC,EAASC,GACvD,IAEI,KAAMF,aAAqB+K,SACvB,MAAM,IAAIC,MAAM,gDAAgDhL,GAEpE,MAAMiL,EAAW,CACbnI,qBAAsB9C,EACtBwD,eAAgB,SAChB0C,eAAgB,YAChBtD,eAAgB,aAChBsI,mBAAmB,EACnB9D,8BAA+B,GAC/B/D,KAAK,GAEH8H,EAAgBpJ,OAAOqJ,OAAOrJ,OAAOqJ,OAAO,CAAA,EAAIH,GAAWhL,GAKjE,OAHIiJ,OAAOmC,WAAW,oCAAoCC,UACtDH,EAAc3H,eAAiB,QAE5BzD,EAAOC,EAAWmL,EAAejL,EAChD,CACI,MAAOsK,GACHe,QAAQ3D,MAAM4C,EACtB,CACA"}
1
+ {"version":3,"file":"index.min.js","sources":["../src/core/utils.ts","../src/core/slider.ts","../src/core/details.ts","../src/core/overflow-slider.ts"],"sourcesContent":["function generateId(prefix, i = 1) {\n const id = `${prefix}-${i}`;\n if (document.getElementById(id)) {\n return generateId(prefix, i + 1);\n }\n return id;\n}\nfunction objectsAreEqual(obj1, obj2) {\n const keys1 = Object.keys(obj1);\n const keys2 = Object.keys(obj2);\n if (keys1.length !== keys2.length) {\n return false;\n }\n for (let key of keys1) {\n // Use `Object.prototype.hasOwnProperty.call` for better safety\n if (!Object.prototype.hasOwnProperty.call(obj2, key) || obj1[key] !== obj2[key]) {\n return false;\n }\n }\n return true;\n}\nfunction getOutermostChildrenEdgeMarginSum(el) {\n if (el.children.length === 0) {\n return 0;\n }\n // get the first child and its left margin\n const firstChild = el.children[0];\n const firstChildStyle = getComputedStyle(firstChild);\n const firstChildMarginLeft = parseFloat(firstChildStyle.marginLeft);\n // Get the last child and its right margin\n const lastChild = el.children[el.children.length - 1];\n const lastChildStyle = getComputedStyle(lastChild);\n const lastChildMarginRight = parseFloat(lastChildStyle.marginRight);\n return firstChildMarginLeft + lastChildMarginRight;\n}\nexport { generateId, objectsAreEqual, getOutermostChildrenEdgeMarginSum };\n","import details from './details';\nimport { generateId, objectsAreEqual, getOutermostChildrenEdgeMarginSum } from './utils';\nexport default function Slider(container, options, plugins) {\n let slider;\n let subs = {};\n const overrideTransitions = () => {\n slider.slides.forEach((slide) => {\n slide.style.transition = 'none';\n });\n };\n const restoreTransitions = () => {\n slider.slides.forEach((slide) => {\n slide.style.removeProperty('transition');\n });\n };\n function init() {\n slider.container = container;\n // ensure container has id\n let containerId = container.getAttribute('id');\n if (containerId === null) {\n containerId = generateId('overflow-slider');\n container.setAttribute('id', containerId);\n }\n setSlides();\n // CSS transitions can cause delays for calculations\n overrideTransitions();\n setDetails(true);\n setActiveSlideIdx();\n slider.on('contentsChanged', () => {\n setSlides();\n setDetails();\n setActiveSlideIdx();\n });\n slider.on('containerSizeChanged', () => setDetails());\n let requestId = 0;\n const setDetailsDebounce = () => {\n if (requestId) {\n window.cancelAnimationFrame(requestId);\n }\n requestId = window.requestAnimationFrame(() => {\n setDetails();\n setActiveSlideIdx();\n });\n };\n slider.on('scroll', setDetailsDebounce);\n addEventListeners();\n setDataAttributes();\n setCSSVariables();\n if (plugins) {\n for (const plugin of plugins) {\n plugin(slider);\n }\n // plugins may mutate layout: refresh details and derived data after they run\n // setTimeout( () => {\n setDetails();\n setActiveSlideIdx();\n setCSSVariables();\n slider.emit('pluginsLoaded');\n // }, 250 );\n }\n slider.on('detailsChanged', () => {\n setDataAttributes();\n setCSSVariables();\n });\n slider.emit('created');\n restoreTransitions();\n slider.container.setAttribute('data-ready', 'true');\n }\n ;\n function setDetails(isInit = false) {\n const oldDetails = slider.details;\n const newDetails = details(slider);\n slider.details = newDetails;\n if (!isInit && !objectsAreEqual(oldDetails, newDetails)) {\n slider.emit('detailsChanged');\n }\n else if (isInit) {\n slider.emit('detailsChanged');\n }\n }\n ;\n function setSlides() {\n slider.slides = Array.from(slider.container.querySelectorAll(slider.options.slidesSelector));\n }\n function addEventListeners() {\n // changes to DOM\n const observer = new MutationObserver(() => slider.emit('contentsChanged'));\n observer.observe(slider.container, { childList: true });\n // container size changes\n const resizeObserver = new ResizeObserver(() => slider.emit('containerSizeChanged'));\n resizeObserver.observe(slider.container);\n // scroll event with debouncing\n let scrollTimeout;\n let nativeScrollTimeout;\n let programmaticScrollTimeout;\n let scrollLeft = slider.container.scrollLeft;\n let nativeScrollLeft = slider.container.scrollLeft;\n let programmaticScrollLeft = slider.container.scrollLeft;\n let isScrolling = false;\n let isUserScrolling = false;\n let isProgrammaticScrolling = false;\n // all types of scroll\n slider.container.addEventListener('scroll', () => {\n const newScrollLeft = slider.container.scrollLeft;\n if (Math.floor(scrollLeft) !== Math.floor(newScrollLeft)) {\n if (!isScrolling) {\n isScrolling = true;\n slider.emit('scrollStart');\n }\n scrollLeft = newScrollLeft;\n clearTimeout(scrollTimeout);\n scrollTimeout = setTimeout(() => {\n isScrolling = false;\n slider.emit('scrollEnd');\n }, 50);\n slider.emit('scroll');\n }\n // keep up nativeScrolling to take into account scroll-snap\n if (isUserScrolling) {\n nativeScrollHandler();\n }\n });\n // user initted scroll (touchmove, mouse wheel, etc.)\n const nativeScrollHandler = () => {\n const newScrollLeft = slider.container.scrollLeft;\n if (Math.floor(nativeScrollLeft) !== Math.floor(newScrollLeft) && !isProgrammaticScrolling) {\n if (!isUserScrolling) {\n slider.emit('nativeScrollStart');\n isUserScrolling = true;\n }\n slider.emit('nativeScroll');\n nativeScrollLeft = newScrollLeft;\n clearTimeout(nativeScrollTimeout);\n nativeScrollTimeout = setTimeout(() => {\n isUserScrolling = false;\n slider.emit('nativeScrollEnd');\n // update programmaticScrollLeft to match nativeScrollLeft\n // this prevents programmaticScroll triggering with no real change to scrollLeft\n programmaticScrollLeft = nativeScrollLeft;\n }, 50);\n }\n };\n slider.container.addEventListener('touchmove', nativeScrollHandler);\n slider.container.addEventListener('mousewheel', nativeScrollHandler);\n slider.container.addEventListener('wheel', nativeScrollHandler);\n // programmatic scroll (scrollTo, etc.)\n slider.on('programmaticScrollStart', () => {\n isProgrammaticScrolling = true;\n });\n slider.container.addEventListener('scroll', () => {\n const newScrollLeft = slider.container.scrollLeft;\n if (Math.floor(programmaticScrollLeft) !== Math.floor(newScrollLeft) && !isUserScrolling && isProgrammaticScrolling) {\n programmaticScrollLeft = newScrollLeft;\n clearTimeout(programmaticScrollTimeout);\n programmaticScrollTimeout = setTimeout(() => {\n isProgrammaticScrolling = false;\n slider.emit('programmaticScrollEnd');\n // update nativeScrollLeft to match programmaticScrollLeft\n // this prevents nativeScroll triggering with no real change to scrollLeft\n nativeScrollLeft = programmaticScrollLeft;\n }, 50);\n slider.emit('programmaticScroll');\n }\n });\n // Fix issues on scroll snapping not working on programmatic scroll (it's not smooth)\n // by disabling scroll snap if scrolling is programmatic\n slider.on('programmaticScrollStart', () => {\n slider.container.style.scrollSnapType = 'none';\n });\n // restore scroll snap if user scroll starts\n slider.on('nativeScrollStart', () => {\n slider.container.style.scrollSnapType = '';\n });\n // Listen for mouse down and touch start events on the document\n // This handles both mouse clicks and touch interactions\n let wasInteractedWith = false;\n slider.container.addEventListener('mousedown', () => {\n wasInteractedWith = true;\n });\n slider.container.addEventListener('touchstart', () => {\n wasInteractedWith = true;\n }, { passive: true });\n slider.container.addEventListener('focusin', (e) => {\n // move target parents as long as they are not the container\n // but only if focus didn't start from mouse or touch\n if (!wasInteractedWith) {\n let target = e.target;\n while (target.parentElement !== slider.container) {\n if (target.parentElement) {\n target = target.parentElement;\n }\n else {\n break;\n }\n }\n ensureSlideIsInView(target, 'auto');\n }\n wasInteractedWith = false;\n });\n }\n ;\n function setCSSVariables() {\n slider.options.cssVariableContainer.style.setProperty('--slider-container-height', `${slider.details.containerHeight}px`);\n slider.options.cssVariableContainer.style.setProperty('--slider-container-width', `${slider.details.containerWidth}px`);\n slider.options.cssVariableContainer.style.setProperty('--slider-scrollable-width', `${slider.details.scrollableAreaWidth}px`);\n slider.options.cssVariableContainer.style.setProperty('--slider-slides-count', `${slider.details.slideCount}`);\n slider.options.cssVariableContainer.style.setProperty('--slider-x-offset', `${getLeftOffset()}px`);\n if (typeof slider.options.targetWidth === 'function') {\n slider.options.cssVariableContainer.style.setProperty('--slider-container-target-width', `${slider.options.targetWidth(slider)}px`);\n }\n }\n function setDataAttributes() {\n slider.container.setAttribute('data-has-overflow', slider.details.hasOverflow ? 'true' : 'false');\n if (slider.options.rtl) {\n slider.container.setAttribute('dir', 'rtl');\n }\n }\n function ensureSlideIsInView(slide, scrollBehavior = null) {\n const behavior = scrollBehavior || slider.options.scrollBehavior;\n const slideRect = slide.getBoundingClientRect();\n const sliderRect = slider.container.getBoundingClientRect();\n const containerWidth = slider.container.offsetWidth;\n const scrollLeft = slider.container.scrollLeft;\n const slideStart = slideRect.left - sliderRect.left + scrollLeft;\n const slideEnd = slideStart + slideRect.width;\n let scrollTarget = null;\n if (Math.floor(slideStart) < Math.floor(scrollLeft)) {\n scrollTarget = slideStart;\n }\n else if (Math.floor(slideEnd) > Math.floor(scrollLeft) + Math.floor(containerWidth)) {\n scrollTarget = slideEnd - containerWidth;\n }\n else if (Math.floor(slideStart) === 0) {\n scrollTarget = 0;\n }\n else {\n scrollTarget = slideStart;\n }\n if (scrollTarget !== null) {\n setTimeout((scrollTarget) => {\n slider.emit('programmaticScrollStart');\n slider.container.scrollTo({ left: scrollTarget, behavior: behavior });\n }, 50, scrollTarget);\n }\n }\n ;\n function setActiveSlideIdx() {\n const sliderRect = slider.container.getBoundingClientRect();\n const scrollLeft = slider.getScrollLeft();\n const slides = slider.slides;\n let activeSlideIdx = 0;\n let scrolledPastLastSlide = false;\n if (slider.options.rtl) {\n const scrolledDistance = slider.getInclusiveScrollWidth() - scrollLeft - slider.getInclusiveClientWidth();\n const slidePositions = [];\n for (let i = slides.length - 1; i >= 0; i--) {\n const slideRect = slides[i].getBoundingClientRect();\n const slideEnd = Math.abs(slideRect.left) - Math.abs(sliderRect.left) + scrolledDistance;\n slidePositions.push({\n slide: slides[i],\n slideEnd: slideEnd,\n });\n }\n let closestSlide = null;\n let closestDistance = null;\n for (let i = 0; i < slidePositions.length; i++) {\n const distance = Math.abs(slidePositions[i].slideEnd - scrolledDistance);\n if (closestDistance === null || distance < closestDistance) {\n closestDistance = distance;\n closestSlide = slidePositions[i].slide;\n }\n }\n if (closestSlide) {\n activeSlideIdx = slides.indexOf(closestSlide);\n }\n else {\n activeSlideIdx = slides.length - 1;\n }\n }\n else {\n for (let i = 0; i < slides.length; i++) {\n const slideRect = slides[i].getBoundingClientRect();\n const slideStart = slideRect.left - sliderRect.left + scrollLeft + getGapSize();\n if (Math.floor(slideStart) >= Math.floor(scrollLeft)) {\n activeSlideIdx = i;\n break;\n }\n if (i === slides.length - 1) {\n scrolledPastLastSlide = true;\n }\n }\n }\n if (scrolledPastLastSlide) {\n activeSlideIdx = slides.length - 1;\n }\n const oldActiveSlideIdx = slider.activeSlideIdx;\n slider.activeSlideIdx = activeSlideIdx;\n if (oldActiveSlideIdx !== activeSlideIdx) {\n slider.emit('activeSlideChanged');\n }\n }\n function moveToSlide(idx) {\n const slide = slider.slides[idx];\n if (slide) {\n ensureSlideIsInView(slide);\n }\n }\n ;\n function canMoveToSlide(idx) {\n if (idx < 0 || idx >= slider.slides.length) {\n return false;\n }\n if (idx === slider.activeSlideIdx) {\n return false;\n }\n const direction = slider.options.rtl ? (idx < slider.activeSlideIdx ? 'backwards' : 'forwards') : (idx < slider.activeSlideIdx ? 'backwards' : 'forwards');\n // check if the slide is already in view\n const sliderRect = slider.container.getBoundingClientRect();\n const scrollLeft = slider.getScrollLeft();\n const containerWidth = slider.details.containerWidth;\n const hasUpcomingContent = slider.slides.some((s, i) => {\n if (i === slider.activeSlideIdx) {\n return false; // skip the slide we are checking\n }\n const sRect = s.getBoundingClientRect();\n const sStart = sRect.left - sliderRect.left + scrollLeft;\n const sEnd = sStart + sRect.width;\n if (slider.options.rtl) {\n if (scrollLeft === 0 && slider.details.hasOverflow) {\n return true;\n }\n return (direction === 'forwards' && i > slider.activeSlideIdx && Math.floor(sStart) < Math.floor(scrollLeft)) ||\n (direction === 'backwards' && i < slider.activeSlideIdx && Math.floor(sEnd) > Math.floor(scrollLeft + containerWidth));\n }\n else {\n return (direction === 'forwards' && i > slider.activeSlideIdx && Math.floor(sEnd) > Math.floor(scrollLeft + containerWidth)) ||\n (direction === 'backwards' && i < slider.activeSlideIdx && Math.floor(sStart) < Math.floor(scrollLeft));\n }\n });\n return hasUpcomingContent;\n }\n function moveToSlideInDirection(direction) {\n const activeSlideIdx = slider.activeSlideIdx;\n if (direction === 'prev') {\n if (activeSlideIdx > 0) {\n moveToSlide(activeSlideIdx - 1);\n }\n }\n else if (direction === 'next') {\n if (activeSlideIdx < slider.slides.length - 1) {\n moveToSlide(activeSlideIdx + 1);\n }\n }\n }\n function getInclusiveScrollWidth() {\n return slider.container.scrollWidth + getOutermostChildrenEdgeMarginSum(slider.container);\n }\n ;\n function getInclusiveClientWidth() {\n return slider.container.clientWidth + getOutermostChildrenEdgeMarginSum(slider.container);\n }\n function getScrollLeft() {\n return slider.options.rtl ? Math.abs(slider.container.scrollLeft) : slider.container.scrollLeft;\n }\n ;\n function setScrollLeft(value) {\n slider.container.scrollLeft = slider.options.rtl ? -value : value;\n }\n ;\n function getGapSize() {\n let gapSize = 0;\n if (slider.slides.length > 1) {\n const firstSlideRect = slider.slides[0].getBoundingClientRect();\n const secondSlideRect = slider.slides[1].getBoundingClientRect();\n gapSize = slider.options.rtl ? Math.abs(Math.floor(secondSlideRect.right - firstSlideRect.left)) : Math.floor(secondSlideRect.left - firstSlideRect.right);\n }\n return gapSize;\n }\n ;\n function getLeftOffset() {\n let offset = 0;\n const fullWidthOffset = slider.container.getAttribute('data-full-width-offset');\n if (fullWidthOffset) {\n offset = parseInt(fullWidthOffset);\n }\n return Math.floor(offset);\n }\n ;\n function moveToDirection(direction = \"prev\") {\n const scrollStrategy = slider.options.scrollStrategy;\n const scrollLeft = slider.container.scrollLeft;\n const sliderRect = slider.container.getBoundingClientRect();\n const containerWidth = slider.container.offsetWidth;\n let targetScrollPosition = scrollLeft;\n const realDirection = slider.options.rtl ? (direction === 'prev' ? 'next' : 'prev') : direction;\n if (realDirection === 'prev') {\n targetScrollPosition = Math.max(0, scrollLeft - slider.container.offsetWidth);\n }\n else if (realDirection === 'next') {\n targetScrollPosition = Math.min(slider.getInclusiveScrollWidth(), scrollLeft + slider.container.offsetWidth);\n }\n if (scrollStrategy === 'fullSlide') {\n let fullSlideTargetScrollPosition = null;\n // extend targetScrollPosition to include gap\n if (realDirection === 'prev') {\n fullSlideTargetScrollPosition = Math.max(0, targetScrollPosition - getGapSize());\n }\n else {\n fullSlideTargetScrollPosition = Math.min(slider.getInclusiveScrollWidth(), targetScrollPosition + getGapSize());\n }\n if (realDirection === 'next') {\n let partialSlideFound = false;\n for (let slide of slider.slides) {\n const slideRect = slide.getBoundingClientRect();\n const slideStart = slideRect.left - sliderRect.left + scrollLeft;\n const slideEnd = slideStart + slideRect.width;\n if (Math.floor(slideStart) < Math.floor(targetScrollPosition) && Math.floor(slideEnd) > Math.floor(targetScrollPosition)) {\n fullSlideTargetScrollPosition = slideStart;\n partialSlideFound = true;\n break;\n }\n }\n if (!partialSlideFound) {\n fullSlideTargetScrollPosition = Math.min(targetScrollPosition, slider.getInclusiveScrollWidth() - slider.container.offsetWidth);\n }\n if (fullSlideTargetScrollPosition) {\n if (Math.floor(fullSlideTargetScrollPosition) > Math.floor(scrollLeft)) {\n // make sure fullSlideTargetScrollPosition is possible considering the container width\n const maxScrollPosition = Math.floor(slider.getInclusiveScrollWidth()) - Math.floor(containerWidth);\n targetScrollPosition = Math.min(fullSlideTargetScrollPosition, maxScrollPosition);\n }\n else {\n // cannot snap to slide, move one page worth of distance\n targetScrollPosition = Math.min(slider.getInclusiveScrollWidth(), scrollLeft + containerWidth);\n }\n }\n }\n else {\n let partialSlideFound = false;\n for (let slide of slider.slides) {\n const slideRect = slide.getBoundingClientRect();\n const slideStart = slideRect.left - sliderRect.left + scrollLeft;\n const slideEnd = slideStart + slideRect.width;\n if (Math.floor(slideStart) < Math.floor(scrollLeft) && Math.floor(slideEnd) > Math.floor(scrollLeft)) {\n fullSlideTargetScrollPosition = slideEnd - containerWidth;\n partialSlideFound = true;\n break;\n }\n }\n if (!partialSlideFound) {\n fullSlideTargetScrollPosition = Math.max(0, scrollLeft - containerWidth);\n }\n if (fullSlideTargetScrollPosition && Math.floor(fullSlideTargetScrollPosition) < Math.floor(scrollLeft)) {\n targetScrollPosition = fullSlideTargetScrollPosition;\n }\n }\n }\n // add left offset\n const offsettedTargetScrollPosition = targetScrollPosition - getLeftOffset();\n if (Math.floor(offsettedTargetScrollPosition) >= 0) {\n targetScrollPosition = offsettedTargetScrollPosition;\n }\n slider.emit('programmaticScrollStart');\n slider.container.style.scrollBehavior = slider.options.scrollBehavior;\n slider.container.scrollLeft = targetScrollPosition;\n setTimeout(() => slider.container.style.scrollBehavior = '', 50);\n }\n ;\n function snapToClosestSlide(direction = \"prev\") {\n var _a, _b;\n const { slides, options, container } = slider;\n const { rtl, emulateScrollSnapMaxThreshold = 10, scrollBehavior = 'smooth', } = options;\n const isForward = rtl ? direction === 'prev' : direction === 'next';\n const scrollPos = getScrollLeft();\n // Get container rect once (includes any CSS transforms)\n const containerRect = container.getBoundingClientRect();\n const factor = rtl ? -1 : 1;\n // Calculate target area offset if targetWidth is defined\n let targetAreaOffset = 0;\n if (typeof options.targetWidth === 'function') {\n try {\n const targetWidth = options.targetWidth(slider);\n const containerWidth = containerRect.width;\n if (Number.isFinite(targetWidth) && targetWidth > 0 && targetWidth < containerWidth) {\n targetAreaOffset = (containerWidth - targetWidth) / 2;\n }\n }\n catch (error) {\n // ignore errors, use default offset of 0\n }\n }\n // Build slide metadata\n const slideData = [...slides].map(slide => {\n const { width } = slide.getBoundingClientRect();\n const slideRect = slide.getBoundingClientRect();\n // position relative to container's left edge\n const relativeStart = (slideRect.left - containerRect.left) + scrollPos;\n // Adjust trigger point to align with target area start instead of container edge\n const alignmentPoint = relativeStart - targetAreaOffset;\n const triggerPoint = Math.min(alignmentPoint + width / 2, alignmentPoint + emulateScrollSnapMaxThreshold);\n return { start: relativeStart - targetAreaOffset, trigger: triggerPoint };\n });\n // Pick the target start based on drag direction\n let targetStart = null;\n if (isForward) {\n const found = slideData.find(item => scrollPos <= item.trigger);\n targetStart = (_a = found === null || found === void 0 ? void 0 : found.start) !== null && _a !== void 0 ? _a : null;\n }\n else {\n const found = [...slideData].reverse().find(item => scrollPos >= item.trigger);\n targetStart = (_b = found === null || found === void 0 ? void 0 : found.start) !== null && _b !== void 0 ? _b : null;\n }\n if (targetStart == null)\n return;\n // Clamp to zero and apply RTL factor\n const finalLeft = Math.max(0, Math.floor(targetStart)) * factor;\n container.scrollTo({ left: finalLeft, behavior: scrollBehavior });\n }\n function on(name, cb) {\n if (!subs[name]) {\n subs[name] = [];\n }\n subs[name].push(cb);\n }\n ;\n function emit(name) {\n var _a;\n if (subs && subs[name]) {\n subs[name].forEach(cb => {\n cb(slider);\n });\n }\n const optionCallBack = (_a = slider === null || slider === void 0 ? void 0 : slider.options) === null || _a === void 0 ? void 0 : _a[name];\n // Type guard to check if the option callback is a function\n if (typeof optionCallBack === 'function') {\n optionCallBack(slider); // Type assertion here\n }\n }\n ;\n slider = {\n emit,\n moveToDirection,\n canMoveToSlide,\n moveToSlide,\n moveToSlideInDirection,\n snapToClosestSlide,\n getInclusiveScrollWidth,\n getInclusiveClientWidth,\n getLeftOffset,\n getGapSize,\n getScrollLeft,\n setScrollLeft,\n setActiveSlideIdx,\n on,\n options,\n };\n init();\n return slider;\n}\n","export default function details(slider) {\n var _a;\n let instance;\n let hasOverflow = false;\n let slideCount = 0;\n let containerWidth = 0;\n let containerHeight = 0;\n let scrollableAreaWidth = 0;\n let amountOfPages = 0;\n let currentPage = 0;\n if (Math.floor(slider.getInclusiveScrollWidth()) > Math.floor(slider.getInclusiveClientWidth())) {\n hasOverflow = true;\n }\n slideCount = (_a = slider.slides.length) !== null && _a !== void 0 ? _a : 0;\n containerWidth = slider.container.offsetWidth;\n containerHeight = slider.container.offsetHeight;\n scrollableAreaWidth = slider.getInclusiveScrollWidth();\n amountOfPages = Math.ceil(scrollableAreaWidth / containerWidth);\n if (Math.floor(slider.getScrollLeft()) >= 0) {\n currentPage = Math.floor(slider.getScrollLeft() / containerWidth);\n // Consider as last page if we're within tolerance of the maximum scroll position\n // When FullWidthPlugin is active, account for the margin offset\n const maxScroll = scrollableAreaWidth - containerWidth - (2 * slider.getLeftOffset());\n const currentScroll = slider.getScrollLeft();\n if (currentScroll >= maxScroll - 1) {\n currentPage = amountOfPages - 1;\n }\n }\n instance = {\n hasOverflow,\n slideCount,\n containerWidth,\n containerHeight,\n scrollableAreaWidth,\n amountOfPages,\n currentPage,\n };\n return instance;\n}\n;\n","import Slider from './slider';\nexport default function OverflowSlider(container, options, plugins) {\n try {\n // check that container HTML element\n if (!(container instanceof Element)) {\n throw new Error(`Container must be HTML element, found ${typeof container}`);\n }\n const defaults = {\n cssVariableContainer: container,\n scrollBehavior: \"smooth\",\n scrollStrategy: \"fullSlide\",\n slidesSelector: \":scope > *\",\n emulateScrollSnap: false,\n emulateScrollSnapMaxThreshold: 64,\n rtl: false,\n };\n const sliderOptions = Object.assign(Object.assign({}, defaults), options);\n // disable smooth scrolling if user prefers reduced motion\n if (window.matchMedia('(prefers-reduced-motion: reduce)').matches) {\n sliderOptions.scrollBehavior = \"auto\";\n }\n return Slider(container, sliderOptions, plugins);\n }\n catch (e) {\n console.error(e);\n }\n}\n"],"names":["generateId","prefix","i","id","document","getElementById","getOutermostChildrenEdgeMarginSum","el","children","length","firstChild","firstChildStyle","getComputedStyle","firstChildMarginLeft","parseFloat","marginLeft","lastChild","lastChildStyle","marginRight","Slider","container","options","plugins","slider","subs","setDetails","isInit","oldDetails","details","newDetails","_a","instance","hasOverflow","slideCount","containerWidth","containerHeight","scrollableAreaWidth","amountOfPages","currentPage","Math","floor","getInclusiveScrollWidth","getInclusiveClientWidth","slides","offsetWidth","offsetHeight","ceil","getScrollLeft","maxScroll","getLeftOffset","obj1","obj2","keys1","Object","keys","keys2","key","prototype","hasOwnProperty","call","objectsAreEqual","emit","setSlides","Array","from","querySelectorAll","slidesSelector","setCSSVariables","cssVariableContainer","style","setProperty","targetWidth","setDataAttributes","setAttribute","rtl","ensureSlideIsInView","slide","scrollBehavior","behavior","slideRect","getBoundingClientRect","sliderRect","scrollLeft","slideStart","left","slideEnd","width","scrollTarget","setTimeout","scrollTo","setActiveSlideIdx","activeSlideIdx","scrolledPastLastSlide","scrolledDistance","slidePositions","abs","push","closestSlide","closestDistance","distance","indexOf","getGapSize","oldActiveSlideIdx","moveToSlide","idx","gapSize","firstSlideRect","secondSlideRect","right","offset","fullWidthOffset","getAttribute","parseInt","name","forEach","cb","optionCallBack","moveToDirection","direction","scrollStrategy","targetScrollPosition","realDirection","max","min","fullSlideTargetScrollPosition","partialSlideFound","maxScrollPosition","offsettedTargetScrollPosition","canMoveToSlide","some","s","sRect","sStart","sEnd","moveToSlideInDirection","snapToClosestSlide","_b","emulateScrollSnapMaxThreshold","isForward","scrollPos","containerRect","factor","targetAreaOffset","Number","isFinite","error","slideData","map","relativeStart","alignmentPoint","triggerPoint","start","trigger","targetStart","found","find","item","reverse","finalLeft","scrollWidth","clientWidth","setScrollLeft","value","on","containerId","transition","requestId","window","cancelAnimationFrame","requestAnimationFrame","MutationObserver","observe","childList","scrollTimeout","nativeScrollTimeout","programmaticScrollTimeout","ResizeObserver","nativeScrollLeft","programmaticScrollLeft","isScrolling","isUserScrolling","isProgrammaticScrolling","addEventListener","newScrollLeft","clearTimeout","nativeScrollHandler","scrollSnapType","wasInteractedWith","passive","e","target","parentElement","addEventListeners","plugin","removeProperty","init","Element","Error","defaults","emulateScrollSnap","sliderOptions","assign","matchMedia","matches","console"],"mappings":"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"}
@@ -1 +1 @@
1
- :root{--overflow-slider-arrows-size:1.5rem;--overflow-slider-arrows-gap:.5rem;--overflow-slider-arrows-inactive-opacity:0.5}.overflow-slider__arrows{display:flex;gap:var(--overflow-slider-arrows-gap)}.overflow-slider__arrows-button{align-items:center;cursor:pointer;display:flex;outline-offset:-2px}.overflow-slider__arrows-button svg{height:var(--overflow-slider-arrows-size);width:var(--overflow-slider-arrows-size)}.overflow-slider__arrows-button[data-has-content=false]{opacity:var(--overflow-slider-arrows-inactive-opacity)}:root{--overflow-slider-autoplay-background:#000}.overflow-slider__autoplay{background:var(--overflow-slider-autoplay-background)}:root{--overflow-slider-dots-gap:0.5rem;--overflow-slider-dot-size:0.75rem;--overflow-slider-dot-inactive-color:rgba(0,0,0,.1);--overflow-slider-dot-active-color:rgba(0,0,0,.8)}.overflow-slider__dots{align-items:center;display:flex;justify-content:center}.overflow-slider__dots ul{display:flex;flex-wrap:wrap;gap:var(--overflow-slider-dots-gap);list-style:none;margin:0;padding:0}.overflow-slider__dots li{line-height:0;margin:0;padding:0}.overflow-slider__dot-item{background:var(--overflow-slider-dot-inactive-color);border-radius:50%;cursor:pointer;height:var(--overflow-slider-dot-size);margin:0;outline-offset:2px;padding:0;position:relative;width:var(--overflow-slider-dot-size)}.overflow-slider__dot-item:after{bottom:calc(var(--overflow-slider-dots-gap)*-1);content:"";display:block;left:calc(var(--overflow-slider-dots-gap)*-1);position:absolute;right:calc(var(--overflow-slider-dots-gap)*-1);top:calc(var(--overflow-slider-dots-gap)*-1)}.overflow-slider__dot-item:focus,.overflow-slider__dot-item:hover,.overflow-slider__dot-item[aria-pressed=true]{background:var(--overflow-slider-dot-active-color)}:root{--overflow-slider-fade-color:#fff;--overflow-slider-fade-width:3rem}.overflow-slider-fade{height:100%;pointer-events:none;position:absolute;top:0;width:var(--overflow-slider-fade-width);z-index:1}.overflow-slider-fade--start{background:linear-gradient(to right,var(--overflow-slider-fade-color) 0,transparent 100%);left:0}[dir=rtl] .overflow-slider-fade--start{left:auto}.overflow-slider-fade--end,[dir=rtl] .overflow-slider-fade--start{background:linear-gradient(to left,var(--overflow-slider-fade-color) 0,transparent 100%);right:0}[dir=rtl] .overflow-slider-fade--end{background:linear-gradient(to right,var(--overflow-slider-fade-color) 0,transparent 100%);left:0;right:auto}[data-has-drag-scrolling][data-has-overflow=true]{cursor:grab;-webkit-user-select:none;-moz-user-select:none;user-select:none}:root{--overflow-slider-scroll-indicator-button-height:4px;--overflow-slider-scroll-indicator-padding:1rem;--overflow-slider-scroll-indicator-button-color:rgba(0,0,0,.75);--overflow-slider-scroll-indicator-bar-color:rgba(0,0,0,.25)}.overflow-slider__scroll-indicator{cursor:pointer;outline:0;padding-block:var(--overflow-slider-scroll-indicator-padding);position:relative;width:100%}.overflow-slider__scroll-indicator[data-has-overflow=false]{display:none}.overflow-slider__scroll-indicator:focus-visible .overflow-slider__scroll-indicator-button{outline:2px solid;outline-offset:2px}.overflow-slider__scroll-indicator-bar{background:var(--overflow-slider-scroll-indicator-bar-color);border-radius:3px;height:2px;left:0;position:absolute;top:50%;transform:translateY(-50%);width:100%}.overflow-slider__scroll-indicator-button{background:var(--overflow-slider-scroll-indicator-button-color);border-radius:3px;cursor:grab;height:var(--overflow-slider-scroll-indicator-button-height);left:0;position:absolute;top:calc(50% - var(--overflow-slider-scroll-indicator-button-height)/2)}.overflow-slider__scroll-indicator-button:hover,.overflow-slider__scroll-indicator-button[data-is-grabbed=true]{--overflow-slider-scroll-indicator-button-height:6px}.overflow-slider__scroll-indicator-button:after{bottom:calc(var(--overflow-slider-scroll-indicator-padding)*-1);content:"";display:block;position:absolute;top:calc(var(--overflow-slider-scroll-indicator-padding)*-1);width:100%}.overflow-slider{-ms-overflow-style:none;display:grid;grid-auto-flow:column;grid-template-columns:max-content;max-width:-moz-max-content;max-width:max-content;overflow:auto;position:relative;scrollbar-width:none;width:100%}.overflow-slider::-webkit-scrollbar{display:none}.overflow-slider>*{outline-offset:-2px;scroll-snap-align:start}
1
+ :root{--overflow-slider-arrows-size:1.5rem;--overflow-slider-arrows-gap:.5rem;--overflow-slider-arrows-inactive-opacity:0.5}.overflow-slider__arrows{display:flex;gap:var(--overflow-slider-arrows-gap)}.overflow-slider__arrows-button{align-items:center;cursor:pointer;display:flex;outline-offset:-2px}.overflow-slider__arrows-button svg{height:var(--overflow-slider-arrows-size);width:var(--overflow-slider-arrows-size)}.overflow-slider__arrows-button[data-has-content=false]{opacity:var(--overflow-slider-arrows-inactive-opacity)}:root{--overflow-slider-autoplay-background:#000}.overflow-slider__autoplay{background:var(--overflow-slider-autoplay-background)}:root{--overflow-slider-dots-gap:0.5rem;--overflow-slider-dot-size:0.75rem;--overflow-slider-dot-inactive-color:rgba(0,0,0,.1);--overflow-slider-dot-active-color:rgba(0,0,0,.8)}.overflow-slider__dots{align-items:center;display:flex;justify-content:center}.overflow-slider__dots ul{display:flex;flex-wrap:wrap;gap:var(--overflow-slider-dots-gap);list-style:none;margin:0;padding:0}.overflow-slider__dots li{line-height:0;margin:0;padding:0}.overflow-slider__dot-item{background:var(--overflow-slider-dot-inactive-color);border-radius:50%;cursor:pointer;height:var(--overflow-slider-dot-size);margin:0;outline-offset:2px;padding:0;position:relative;width:var(--overflow-slider-dot-size)}.overflow-slider__dot-item:after{bottom:calc(var(--overflow-slider-dots-gap)*-1);content:"";display:block;left:calc(var(--overflow-slider-dots-gap)*-1);position:absolute;right:calc(var(--overflow-slider-dots-gap)*-1);top:calc(var(--overflow-slider-dots-gap)*-1)}.overflow-slider__dot-item:hover,.overflow-slider__dot-item[aria-pressed=true]{background:var(--overflow-slider-dot-active-color)}:root{--overflow-slider-fade-color:#fff;--overflow-slider-fade-width:3rem}.overflow-slider-fade{height:100%;pointer-events:none;position:absolute;top:0;width:var(--overflow-slider-fade-width);z-index:1}.overflow-slider-fade--start{background:linear-gradient(to right,var(--overflow-slider-fade-color) 0,transparent 100%);left:0}[dir=rtl] .overflow-slider-fade--start{left:auto}.overflow-slider-fade--end,[dir=rtl] .overflow-slider-fade--start{background:linear-gradient(to left,var(--overflow-slider-fade-color) 0,transparent 100%);right:0}[dir=rtl] .overflow-slider-fade--end{background:linear-gradient(to right,var(--overflow-slider-fade-color) 0,transparent 100%);left:0;right:auto}[data-has-drag-scrolling][data-has-overflow=true]{cursor:grab;-webkit-user-select:none;-moz-user-select:none;user-select:none}:root{--overflow-slider-scroll-indicator-button-height:4px;--overflow-slider-scroll-indicator-padding:1rem;--overflow-slider-scroll-indicator-button-color:rgba(0,0,0,.75);--overflow-slider-scroll-indicator-bar-color:rgba(0,0,0,.25)}.overflow-slider__scroll-indicator{cursor:pointer;outline:0;padding-block:var(--overflow-slider-scroll-indicator-padding);position:relative;width:100%}.overflow-slider__scroll-indicator[data-has-overflow=false]{display:none}.overflow-slider__scroll-indicator:focus-visible .overflow-slider__scroll-indicator-button{outline:2px solid;outline-offset:2px}.overflow-slider__scroll-indicator-bar{background:var(--overflow-slider-scroll-indicator-bar-color);border-radius:3px;height:2px;left:0;position:absolute;top:50%;transform:translateY(-50%);width:100%}.overflow-slider__scroll-indicator-button{background:var(--overflow-slider-scroll-indicator-button-color);border-radius:3px;cursor:grab;height:var(--overflow-slider-scroll-indicator-button-height);left:0;position:absolute;top:calc(50% - var(--overflow-slider-scroll-indicator-button-height)/2)}.overflow-slider__scroll-indicator-button:hover,.overflow-slider__scroll-indicator-button[data-is-grabbed=true]{--overflow-slider-scroll-indicator-button-height:6px}.overflow-slider__scroll-indicator-button:after{bottom:calc(var(--overflow-slider-scroll-indicator-padding)*-1);content:"";display:block;position:absolute;top:calc(var(--overflow-slider-scroll-indicator-padding)*-1);width:100%}.overflow-slider{-ms-overflow-style:none;display:grid;grid-auto-flow:column;grid-template-columns:max-content;max-width:-moz-max-content;max-width:max-content;overflow:auto;position:relative;scrollbar-width:none;width:100%}.overflow-slider::-webkit-scrollbar{display:none}.overflow-slider>*{outline-offset:-2px;scroll-snap-align:start}
@@ -41,7 +41,6 @@ function ClassNamesPlugin(args) {
41
41
  };
42
42
  const update = () => {
43
43
  const { targetStart, targetEnd } = getTargetBounds();
44
- console.log('targetStart:', targetStart, 'targetEnd:', targetEnd);
45
44
  slider.slides.forEach((slide) => {
46
45
  const slideRect = slide.getBoundingClientRect();
47
46
  const slideLeft = slideRect.left;
@@ -1 +1 @@
1
- const t={visible:"is-visible",partlyVisible:"is-partly-visible",hidden:"is-hidden"};function e(e){return n=>{var i,s;const a=null!==(i=null==e?void 0:e.classNames)&&void 0!==i?i:null==e?void 0:e.classnames,l={classNames:Object.assign(Object.assign({},t),null!=a?a:{}),freezeStateOnVisible:null!==(s=null==e?void 0:e.freezeStateOnVisible)&&void 0!==s&&s},r=new WeakMap,o=Array.from(new Set(Object.values(l.classNames).filter(t=>Boolean(t)))),c=()=>{const{targetStart:t,targetEnd:e}=(()=>{const t=n.container.getBoundingClientRect(),e=t.width;if(!e)return{targetStart:t.left,targetEnd:t.right};let i=0;if("function"==typeof n.options.targetWidth)try{i=n.options.targetWidth(n)}catch(t){i=0}(!Number.isFinite(i)||i<=0)&&(i=e);const s=(e-Math.min(i,e))/2,a=Math.max(s,0);return{targetStart:t.left+a,targetEnd:t.right-a}})();console.log("targetStart:",t,"targetEnd:",e),n.slides.forEach(n=>{const i=n.getBoundingClientRect(),s=i.left,a=i.right;let c="hidden";a-2>t&&s+2<e&&(c=s+2>=t&&a-2<=e?"visible":"partlyVisible");const d=r.get(n);if(l.freezeStateOnVisible&&"visible"===d)return;if(d===c)return;const g=l.classNames[c];if(d){const t=l.classNames[d];t!==g&&t&&n.classList.remove(t)}else o.forEach(t=>{t!==g&&n.classList.remove(t)});g&&!n.classList.contains(g)&&n.classList.add(g),r.set(n,c)})};n.on("created",c),n.on("pluginsLoaded",c),n.on("fullWidthPluginUpdate",c),n.on("contentsChanged",c),n.on("containerSizeChanged",c),n.on("detailsChanged",c),n.on("scrollEnd",c),n.on("scrollStart",c),requestAnimationFrame(()=>{requestAnimationFrame(()=>c())});let d=0;n.on("scroll",()=>{d&&window.cancelAnimationFrame(d),d=window.requestAnimationFrame(()=>{c()})})}}export{e as default};
1
+ const t={visible:"is-visible",partlyVisible:"is-partly-visible",hidden:"is-hidden"};function e(e){return n=>{var i,s;const a=null!==(i=null==e?void 0:e.classNames)&&void 0!==i?i:null==e?void 0:e.classnames,l={classNames:Object.assign(Object.assign({},t),null!=a?a:{}),freezeStateOnVisible:null!==(s=null==e?void 0:e.freezeStateOnVisible)&&void 0!==s&&s},r=new WeakMap,o=Array.from(new Set(Object.values(l.classNames).filter(t=>Boolean(t)))),c=()=>{const{targetStart:t,targetEnd:e}=(()=>{const t=n.container.getBoundingClientRect(),e=t.width;if(!e)return{targetStart:t.left,targetEnd:t.right};let i=0;if("function"==typeof n.options.targetWidth)try{i=n.options.targetWidth(n)}catch(t){i=0}(!Number.isFinite(i)||i<=0)&&(i=e);const s=(e-Math.min(i,e))/2,a=Math.max(s,0);return{targetStart:t.left+a,targetEnd:t.right-a}})();n.slides.forEach(n=>{const i=n.getBoundingClientRect(),s=i.left,a=i.right;let c="hidden";a-2>t&&s+2<e&&(c=s+2>=t&&a-2<=e?"visible":"partlyVisible");const d=r.get(n);if(l.freezeStateOnVisible&&"visible"===d)return;if(d===c)return;const u=l.classNames[c];if(d){const t=l.classNames[d];t!==u&&t&&n.classList.remove(t)}else o.forEach(t=>{t!==u&&n.classList.remove(t)});u&&!n.classList.contains(u)&&n.classList.add(u),r.set(n,c)})};n.on("created",c),n.on("pluginsLoaded",c),n.on("fullWidthPluginUpdate",c),n.on("contentsChanged",c),n.on("containerSizeChanged",c),n.on("detailsChanged",c),n.on("scrollEnd",c),n.on("scrollStart",c),requestAnimationFrame(()=>{requestAnimationFrame(()=>c())});let d=0;n.on("scroll",()=>{d&&window.cancelAnimationFrame(d),d=window.requestAnimationFrame(()=>{c()})})}}export{e as default};
@@ -9,6 +9,8 @@ type Slider<O = {}, C = {}, H extends string = string> = {
9
9
  canMoveToSlide: (index: number) => boolean;
10
10
  getInclusiveScrollWidth: () => number;
11
11
  getInclusiveClientWidth: () => number;
12
+ getGapSize: () => number;
13
+ getLeftOffset: () => number;
12
14
  getScrollLeft: () => number;
13
15
  setScrollLeft: (value: number) => void;
14
16
  setActiveSlideIdx: () => void;
@@ -11,6 +11,8 @@ declare function OverflowSlider(container: HTMLElement, options?: SliderOptionAr
11
11
  canMoveToSlide: (index: number) => boolean;
12
12
  getInclusiveScrollWidth: () => number;
13
13
  getInclusiveClientWidth: () => number;
14
+ getGapSize: () => number;
15
+ getLeftOffset: () => number;
14
16
  getScrollLeft: () => number;
15
17
  setScrollLeft: (value: number) => void;
16
18
  setActiveSlideIdx: () => void;
@@ -1,6 +1,7 @@
1
1
  import { DeepPartial, Slider } from '../core/index.js';
2
2
 
3
3
  type DotsOptions = {
4
+ type: 'view' | 'slide';
4
5
  texts: {
5
6
  dotDescription: string;
6
7
  };
@@ -7,11 +7,12 @@ const DEFAULT_CLASS_NAMES = {
7
7
  };
8
8
  function DotsPlugin(args) {
9
9
  return (slider) => {
10
- var _a, _b;
10
+ var _a, _b, _c;
11
11
  const options = {
12
+ type: (_a = args === null || args === void 0 ? void 0 : args.type) !== null && _a !== void 0 ? _a : 'slide',
12
13
  texts: Object.assign(Object.assign({}, DEFAULT_TEXTS), (args === null || args === void 0 ? void 0 : args.texts) || []),
13
14
  classNames: Object.assign(Object.assign({}, DEFAULT_CLASS_NAMES), (args === null || args === void 0 ? void 0 : args.classNames) || []),
14
- container: (_a = args === null || args === void 0 ? void 0 : args.container) !== null && _a !== void 0 ? _a : null,
15
+ container: (_b = args === null || args === void 0 ? void 0 : args.container) !== null && _b !== void 0 ? _b : null,
15
16
  };
16
17
  const dots = document.createElement('div');
17
18
  dots.classList.add(options.classNames.dotsContainer);
@@ -19,19 +20,20 @@ function DotsPlugin(args) {
19
20
  const buildDots = () => {
20
21
  dots.setAttribute('data-has-content', slider.details.hasOverflow.toString());
21
22
  dots.innerHTML = '';
23
+ console.log('buildDots');
22
24
  const dotsList = document.createElement('ul');
23
- const pages = slider.details.slideCount;
24
- const currentItem = slider.activeSlideIdx;
25
- if (pages <= 1) {
25
+ const count = options.type === 'view' ? slider.details.amountOfPages : slider.details.slideCount;
26
+ const currentIndex = options.type === 'view' ? slider.details.currentPage : slider.activeSlideIdx;
27
+ if (count <= 1) {
26
28
  return;
27
29
  }
28
- for (let i = 0; i < pages; i++) {
30
+ for (let i = 0; i < count; i++) {
29
31
  const dotListItem = document.createElement('li');
30
32
  const dot = document.createElement('button');
31
33
  dot.setAttribute('type', 'button');
32
34
  dot.setAttribute('class', options.classNames.dotsItem);
33
- dot.setAttribute('aria-label', options.texts.dotDescription.replace('%d', (i + 1).toString()).replace('%d', pages.toString()));
34
- dot.setAttribute('aria-pressed', (i === currentItem).toString());
35
+ dot.setAttribute('aria-label', options.texts.dotDescription.replace('%d', (i + 1).toString()).replace('%d', count.toString()));
36
+ dot.setAttribute('aria-pressed', (i === currentIndex).toString());
35
37
  dot.setAttribute('data-item', (i + 1).toString());
36
38
  dotListItem.appendChild(dot);
37
39
  dotsList.appendChild(dotListItem);
@@ -45,23 +47,23 @@ function DotsPlugin(args) {
45
47
  }
46
48
  const currentItem = parseInt((_a = currentItemItem.getAttribute('data-item')) !== null && _a !== void 0 ? _a : '1');
47
49
  if (e.key === 'ArrowLeft') {
48
- const previousPage = currentItem - 1;
49
- if (previousPage > 0) {
50
- const matchingDot = dots.querySelector(`[data-item="${previousPage}"]`);
50
+ const previousIndex = currentItem - 1;
51
+ if (previousIndex > 0) {
52
+ const matchingDot = dots.querySelector(`[data-item="${previousIndex}"]`);
51
53
  if (matchingDot) {
52
54
  matchingDot.focus();
53
55
  }
54
- activateDot(previousPage);
56
+ activateDot(previousIndex);
55
57
  }
56
58
  }
57
59
  if (e.key === 'ArrowRight') {
58
- const nextPage = currentItem + 1;
59
- if (nextPage <= pages) {
60
- const matchingDot = dots.querySelector(`[data-item="${nextPage}"]`);
60
+ const nextIndex = currentItem + 1;
61
+ if (nextIndex <= count) {
62
+ const matchingDot = dots.querySelector(`[data-item="${nextIndex}"]`);
61
63
  if (matchingDot) {
62
64
  matchingDot.focus();
63
65
  }
64
- activateDot(nextPage);
66
+ activateDot(nextIndex);
65
67
  }
66
68
  }
67
69
  });
@@ -75,19 +77,37 @@ function DotsPlugin(args) {
75
77
  }
76
78
  }
77
79
  };
78
- const activateDot = (item) => {
79
- slider.moveToSlide(item - 1);
80
+ const activateDot = (index) => {
81
+ console.log('activateDot', index, 'slider.details', slider.details);
82
+ if (options.type === 'view') {
83
+ const count = slider.details.amountOfPages;
84
+ let targetPosition = slider.details.containerWidth * (index - 1);
85
+ // For the last page, scroll to the maximum scroll position to ensure it activates
86
+ if (index === count) {
87
+ const maxScroll = slider.details.scrollableAreaWidth - slider.details.containerWidth;
88
+ targetPosition = maxScroll;
89
+ }
90
+ const scrollLeft = slider.options.rtl ? -targetPosition : targetPosition;
91
+ slider.container.scrollTo({
92
+ left: scrollLeft,
93
+ behavior: slider.options.scrollBehavior
94
+ });
95
+ }
96
+ else {
97
+ slider.moveToSlide(index - 1);
98
+ }
80
99
  };
81
100
  buildDots();
82
101
  if (options.container) {
83
102
  options.container.appendChild(dots);
84
103
  }
85
104
  else {
86
- (_b = slider.container.parentNode) === null || _b === void 0 ? void 0 : _b.insertBefore(dots, slider.container.nextSibling);
105
+ (_c = slider.container.parentNode) === null || _c === void 0 ? void 0 : _c.insertBefore(dots, slider.container.nextSibling);
87
106
  }
88
107
  slider.on('scrollEnd', buildDots);
89
108
  slider.on('contentsChanged', buildDots);
90
109
  slider.on('containerSizeChanged', buildDots);
110
+ slider.on('detailsChanged', buildDots);
91
111
  };
92
112
  }
93
113
 
@@ -1 +1 @@
1
- const t={dotDescription:"Page %d of %d"},e={dotsContainer:"overflow-slider__dots",dotsItem:"overflow-slider__dot-item"};function n(n){return o=>{var i,s;const a={texts:Object.assign(Object.assign({},t),(null==n?void 0:n.texts)||[]),classNames:Object.assign(Object.assign({},e),(null==n?void 0:n.classNames)||[]),container:null!==(i=null==n?void 0:n.container)&&void 0!==i?i:null},r=document.createElement("div");r.classList.add(a.classNames.dotsContainer);let d=null;const l=()=>{r.setAttribute("data-has-content",o.details.hasOverflow.toString()),r.innerHTML="";const t=document.createElement("ul"),e=o.details.slideCount,n=o.activeSlideIdx;if(!(e<=1)){for(let o=0;o<e;o++){const i=document.createElement("li"),s=document.createElement("button");s.setAttribute("type","button"),s.setAttribute("class",a.classNames.dotsItem),s.setAttribute("aria-label",a.texts.dotDescription.replace("%d",(o+1).toString()).replace("%d",e.toString())),s.setAttribute("aria-pressed",(o===n).toString()),s.setAttribute("data-item",(o+1).toString()),i.appendChild(s),t.appendChild(i),s.addEventListener("click",()=>c(o+1)),s.addEventListener("focus",()=>d=o+1),s.addEventListener("keydown",t=>{var n;const o=r.querySelector('[aria-pressed="true"]');if(!o)return;const i=parseInt(null!==(n=o.getAttribute("data-item"))&&void 0!==n?n:"1");if("ArrowLeft"===t.key){const t=i-1;if(t>0){const e=r.querySelector(`[data-item="${t}"]`);e&&e.focus(),c(t)}}if("ArrowRight"===t.key){const t=i+1;if(t<=e){const e=r.querySelector(`[data-item="${t}"]`);e&&e.focus(),c(t)}}})}if(r.appendChild(t),d){const t=r.querySelector(`[data-item="${d}"]`);t&&t.focus()}}},c=t=>{o.moveToSlide(t-1)};l(),a.container?a.container.appendChild(r):null===(s=o.container.parentNode)||void 0===s||s.insertBefore(r,o.container.nextSibling),o.on("scrollEnd",l),o.on("contentsChanged",l),o.on("containerSizeChanged",l)}}export{n as default};
1
+ const t={dotDescription:"Page %d of %d"},e={dotsContainer:"overflow-slider__dots",dotsItem:"overflow-slider__dot-item"};function n(n){return i=>{var o,s,a;const l={type:null!==(o=null==n?void 0:n.type)&&void 0!==o?o:"slide",texts:Object.assign(Object.assign({},t),(null==n?void 0:n.texts)||[]),classNames:Object.assign(Object.assign({},e),(null==n?void 0:n.classNames)||[]),container:null!==(s=null==n?void 0:n.container)&&void 0!==s?s:null},r=document.createElement("div");r.classList.add(l.classNames.dotsContainer);let d=null;const c=()=>{r.setAttribute("data-has-content",i.details.hasOverflow.toString()),r.innerHTML="",console.log("buildDots");const t=document.createElement("ul"),e="view"===l.type?i.details.amountOfPages:i.details.slideCount,n="view"===l.type?i.details.currentPage:i.activeSlideIdx;if(!(e<=1)){for(let i=0;i<e;i++){const o=document.createElement("li"),s=document.createElement("button");s.setAttribute("type","button"),s.setAttribute("class",l.classNames.dotsItem),s.setAttribute("aria-label",l.texts.dotDescription.replace("%d",(i+1).toString()).replace("%d",e.toString())),s.setAttribute("aria-pressed",(i===n).toString()),s.setAttribute("data-item",(i+1).toString()),o.appendChild(s),t.appendChild(o),s.addEventListener("click",()=>u(i+1)),s.addEventListener("focus",()=>d=i+1),s.addEventListener("keydown",t=>{var n;const i=r.querySelector('[aria-pressed="true"]');if(!i)return;const o=parseInt(null!==(n=i.getAttribute("data-item"))&&void 0!==n?n:"1");if("ArrowLeft"===t.key){const t=o-1;if(t>0){const e=r.querySelector(`[data-item="${t}"]`);e&&e.focus(),u(t)}}if("ArrowRight"===t.key){const t=o+1;if(t<=e){const e=r.querySelector(`[data-item="${t}"]`);e&&e.focus(),u(t)}}})}if(r.appendChild(t),d){const t=r.querySelector(`[data-item="${d}"]`);t&&t.focus()}}},u=t=>{if(console.log("activateDot",t,"slider.details",i.details),"view"===l.type){const e=i.details.amountOfPages;let n=i.details.containerWidth*(t-1);if(t===e){n=i.details.scrollableAreaWidth-i.details.containerWidth}const o=i.options.rtl?-n:n;i.container.scrollTo({left:o,behavior:i.options.scrollBehavior})}else i.moveToSlide(t-1)};c(),l.container?l.container.appendChild(r):null===(a=i.container.parentNode)||void 0===a||a.insertBefore(r,i.container.nextSibling),i.on("scrollEnd",c),i.on("contentsChanged",c),i.on("containerSizeChanged",c),i.on("detailsChanged",c)}}export{n as default};
package/docs/index.html CHANGED
@@ -158,7 +158,7 @@
158
158
 
159
159
  <div class="entry__item">
160
160
  <h3>Dots</h3>
161
- <p>Display dots indicator. Uses DotsPlugin.</p>
161
+ <p>Display dots indicator (by slide). Uses DotsPlugin.</p>
162
162
  <div class="overflow-slider example-container example-container-1-dots">
163
163
  <a href="#1" class="example-item example-item--1">1</a>
164
164
  <a href="#2" class="example-item example-item--2">2</a>
@@ -167,6 +167,34 @@
167
167
  <a href="#5" class="example-item example-item--5">5</a>
168
168
  <a href="#6" class="example-item example-item--6">6</a>
169
169
  </div>
170
+ <p style="margin-top:1.5rem;">Display dots indicator (by view).</p>
171
+ <div class="overflow-slider example-container example-container-1-dots-view">
172
+ <a href="#1" class="example-item example-item--1">1</a>
173
+ <a href="#2" class="example-item example-item--2">2</a>
174
+ <a href="#3" class="example-item example-item--3">3</a>
175
+ <a href="#4" class="example-item example-item--4">4</a>
176
+ <a href="#5" class="example-item example-item--5">5</a>
177
+ <a href="#6" class="example-item example-item--6">6</a>
178
+ <a href="#7" class="example-item example-item--7">7</a>
179
+ <a href="#8" class="example-item example-item--8">8</a>
180
+ <a href="#9" class="example-item example-item--9">9</a>
181
+ <a href="#10" class="example-item example-item--10">10</a>
182
+ </div>
183
+ <p style="margin-top:1.5rem;">Display dots indicator (by view) and FullWidthPlugin.</p>
184
+ <div class="example-container-1-full-width-wrapper">
185
+ <div class="overflow-slider example-container example-container-1-dots-view-full">
186
+ <a href="#1" class="example-item example-item--1">1</a>
187
+ <a href="#2" class="example-item example-item--2">2</a>
188
+ <a href="#3" class="example-item example-item--3">3</a>
189
+ <a href="#4" class="example-item example-item--4">4</a>
190
+ <a href="#5" class="example-item example-item--5">5</a>
191
+ <a href="#6" class="example-item example-item--6">6</a>
192
+ <a href="#7" class="example-item example-item--7">7</a>
193
+ <a href="#8" class="example-item example-item--8">8</a>
194
+ <a href="#9" class="example-item example-item--9">9</a>
195
+ <a href="#10" class="example-item example-item--10">10</a>
196
+ </div>
197
+ </div>
170
198
  </div>
171
199
 
172
200
  <div class="entry__item">
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@evermade/overflow-slider",
3
- "version": "4.1.0",
3
+ "version": "4.2.1",
4
4
  "description": "Accessible slider that is powered by overflow: auto.",
5
5
  "type": "module",
6
6
  "main": "dist/index.js",
@@ -10,7 +10,7 @@ export default function details( slider: Slider) {
10
10
  let containerHeight = 0;
11
11
  let scrollableAreaWidth = 0;
12
12
  let amountOfPages = 0;
13
- let currentPage = 1;
13
+ let currentPage = 0;
14
14
 
15
15
  if ( Math.floor( slider.getInclusiveScrollWidth() ) > Math.floor( slider.getInclusiveClientWidth() ) ) {
16
16
  hasOverflow = true;
@@ -28,8 +28,11 @@ export default function details( slider: Slider) {
28
28
 
29
29
  if ( Math.floor( slider.getScrollLeft() ) >= 0) {
30
30
  currentPage = Math.floor(slider.getScrollLeft() / containerWidth);
31
- // consider as last page if the scrollLeft + containerWidth is equal to scrollWidth
32
- if (Math.floor( slider.getScrollLeft() + containerWidth ) === Math.floor( scrollableAreaWidth ) ) {
31
+
32
+ // Consider as last page if we're within tolerance of the maximum scroll position
33
+ // When FullWidthPlugin is active, account for the margin offset
34
+ const maxScroll = scrollableAreaWidth - containerWidth - (2 * slider.getLeftOffset() );
35
+ if ( slider.getScrollLeft() >= maxScroll - 1 ) {
33
36
  currentPage = amountOfPages - 1;
34
37
  }
35
38
  }
@@ -593,6 +593,8 @@ export default function Slider( container: HTMLElement, options : SliderOptionAr
593
593
  snapToClosestSlide,
594
594
  getInclusiveScrollWidth,
595
595
  getInclusiveClientWidth,
596
+ getLeftOffset,
597
+ getGapSize,
596
598
  getScrollLeft,
597
599
  setScrollLeft,
598
600
  setActiveSlideIdx,
package/src/core/types.ts CHANGED
@@ -19,6 +19,8 @@ export type Slider<O = {}, C = {}, H extends string = string> = {
19
19
  ) => boolean
20
20
  getInclusiveScrollWidth: () => number
21
21
  getInclusiveClientWidth: () => number
22
+ getGapSize: () => number
23
+ getLeftOffset: () => number
22
24
  getScrollLeft: () => number
23
25
  setScrollLeft: (value: number) => void
24
26
  setActiveSlideIdx: () => void
@@ -70,8 +70,6 @@ export default function ClassNamesPlugin( args?: DeepPartial<ClassnameOptions> )
70
70
  const update = () => {
71
71
  const { targetStart, targetEnd } = getTargetBounds();
72
72
 
73
- console.log( 'targetStart:', targetStart, 'targetEnd:', targetEnd );
74
-
75
73
  slider.slides.forEach( ( slide ) => {
76
74
  const slideRect = slide.getBoundingClientRect();
77
75
  const slideLeft = slideRect.left;