@evermade/overflow-slider 4.0.0 → 4.1.0
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.
- package/README.md +44 -5
- package/dist/index.esm.js +39 -3
- package/dist/index.esm.js.map +1 -1
- package/dist/index.min.js +1 -1
- package/dist/index.min.js.map +1 -1
- package/dist/plugins/classnames/index.d.ts +14 -0
- package/dist/plugins/classnames/index.esm.js +108 -0
- package/dist/plugins/classnames/index.min.js +1 -0
- package/dist/plugins/core/index.d.ts +1 -0
- package/dist/plugins/full-width/index.d.ts +1 -1
- package/dist/plugins/full-width/index.esm.js +36 -19
- package/dist/plugins/full-width/index.min.js +1 -1
- package/docs/assets/demo.css +41 -0
- package/docs/assets/demo.js +44 -28
- package/docs/dist/index.d.ts +1 -1
- package/docs/dist/index.esm.js +39 -3
- package/docs/dist/index.esm.js.map +1 -1
- package/docs/dist/index.min.js +1 -1
- package/docs/dist/index.min.js.map +1 -1
- package/docs/dist/plugins/arrows/index.d.ts +1 -1
- package/docs/dist/plugins/autoplay/index.d.ts +1 -1
- package/docs/dist/plugins/classnames/index.d.ts +14 -0
- package/docs/dist/plugins/classnames/index.esm.js +108 -0
- package/docs/dist/plugins/classnames/index.min.js +1 -0
- package/docs/dist/plugins/core/index.d.ts +63 -10
- package/docs/dist/plugins/core/index.d2.ts +10 -62
- package/docs/dist/plugins/dots/index.d.ts +1 -1
- package/docs/dist/plugins/drag-scrolling/index.d.ts +1 -1
- package/docs/dist/plugins/fade/index.d.ts +1 -1
- package/docs/dist/plugins/full-width/index.d.ts +2 -2
- package/docs/dist/plugins/full-width/index.esm.js +36 -19
- package/docs/dist/plugins/full-width/index.min.js +1 -1
- package/docs/dist/plugins/infinite-scroll/index.d.ts +1 -1
- package/docs/dist/plugins/scroll-indicator/index.d.ts +1 -1
- package/docs/dist/plugins/skip-links/index.d.ts +1 -1
- package/docs/dist/plugins/thumbnails/index.d.ts +1 -1
- package/docs/index.html +25 -16
- package/package.json +6 -6
- package/src/core/slider.ts +42 -4
- package/src/core/types.ts +1 -0
- package/src/plugins/classnames/index.ts +147 -0
- package/src/plugins/full-width/index.ts +41 -21
- package/src/plugins/infinite-scroll/index.ts +0 -109
package/dist/index.min.js.map
CHANGED
|
@@ -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 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 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 }\n slider.on('detailsChanged', () => {\n setDataAttributes();\n setCSSVariables();\n });\n slider.emit('created');\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 // 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 const triggerPoint = Math.min(relativeStart + width / 2, relativeStart + emulateScrollSnapMaxThreshold);\n return { start: relativeStart, 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","slideData","map","relativeStart","start","trigger","targetStart","found","find","item","reverse","finalLeft","scrollWidth","clientWidth","setScrollLeft","value","on","containerId","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","init","Element","Error","defaults","emulateScrollSnap","sliderOptions","assign","matchMedia","matches","console","error"],"mappings":"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"}
|
|
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":"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"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { DeepPartial, Slider } from '../core/index.js';
|
|
2
|
+
|
|
3
|
+
type ClassnameOptions = {
|
|
4
|
+
classNames: {
|
|
5
|
+
visible: string;
|
|
6
|
+
partlyVisible: string;
|
|
7
|
+
hidden: string;
|
|
8
|
+
};
|
|
9
|
+
freezeStateOnVisible: boolean;
|
|
10
|
+
};
|
|
11
|
+
declare function ClassNamesPlugin(args?: DeepPartial<ClassnameOptions>): (slider: Slider) => void;
|
|
12
|
+
|
|
13
|
+
export { ClassNamesPlugin as default };
|
|
14
|
+
export type { ClassnameOptions };
|
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
const DEFAULT_CLASS_NAMES = {
|
|
2
|
+
visible: 'is-visible',
|
|
3
|
+
partlyVisible: 'is-partly-visible',
|
|
4
|
+
hidden: 'is-hidden',
|
|
5
|
+
};
|
|
6
|
+
function ClassNamesPlugin(args) {
|
|
7
|
+
return (slider) => {
|
|
8
|
+
var _a, _b;
|
|
9
|
+
const providedClassNames = (_a = args === null || args === void 0 ? void 0 : args.classNames) !== null && _a !== void 0 ? _a : args === null || args === void 0 ? void 0 : args.classnames;
|
|
10
|
+
const options = {
|
|
11
|
+
classNames: Object.assign(Object.assign({}, DEFAULT_CLASS_NAMES), providedClassNames !== null && providedClassNames !== void 0 ? providedClassNames : {}),
|
|
12
|
+
freezeStateOnVisible: (_b = args === null || args === void 0 ? void 0 : args.freezeStateOnVisible) !== null && _b !== void 0 ? _b : false,
|
|
13
|
+
};
|
|
14
|
+
const slideStates = new WeakMap();
|
|
15
|
+
const uniqueClassNames = Array.from(new Set(Object.values(options.classNames).filter((className) => Boolean(className))));
|
|
16
|
+
const getTargetBounds = () => {
|
|
17
|
+
const sliderRect = slider.container.getBoundingClientRect();
|
|
18
|
+
const sliderWidth = sliderRect.width;
|
|
19
|
+
if (!sliderWidth) {
|
|
20
|
+
return { targetStart: sliderRect.left, targetEnd: sliderRect.right };
|
|
21
|
+
}
|
|
22
|
+
let targetWidth = 0;
|
|
23
|
+
if (typeof slider.options.targetWidth === 'function') {
|
|
24
|
+
try {
|
|
25
|
+
targetWidth = slider.options.targetWidth(slider);
|
|
26
|
+
}
|
|
27
|
+
catch (error) {
|
|
28
|
+
targetWidth = 0;
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
if (!Number.isFinite(targetWidth) || targetWidth <= 0) {
|
|
32
|
+
targetWidth = sliderWidth;
|
|
33
|
+
}
|
|
34
|
+
const effectiveTargetWidth = Math.min(targetWidth, sliderWidth);
|
|
35
|
+
const offset = (sliderWidth - effectiveTargetWidth) / 2;
|
|
36
|
+
const clampedOffset = Math.max(offset, 0);
|
|
37
|
+
return {
|
|
38
|
+
targetStart: sliderRect.left + clampedOffset,
|
|
39
|
+
targetEnd: sliderRect.right - clampedOffset,
|
|
40
|
+
};
|
|
41
|
+
};
|
|
42
|
+
const update = () => {
|
|
43
|
+
const { targetStart, targetEnd } = getTargetBounds();
|
|
44
|
+
console.log('targetStart:', targetStart, 'targetEnd:', targetEnd);
|
|
45
|
+
slider.slides.forEach((slide) => {
|
|
46
|
+
const slideRect = slide.getBoundingClientRect();
|
|
47
|
+
const slideLeft = slideRect.left;
|
|
48
|
+
const slideRight = slideRect.right;
|
|
49
|
+
const tolerance = 2;
|
|
50
|
+
const overlapsTarget = (slideRight - tolerance) > targetStart && (slideLeft + tolerance) < targetEnd;
|
|
51
|
+
const fullyInsideTarget = (slideLeft + tolerance) >= targetStart && (slideRight - tolerance) <= targetEnd;
|
|
52
|
+
let nextState = 'hidden';
|
|
53
|
+
if (overlapsTarget) {
|
|
54
|
+
nextState = fullyInsideTarget ? 'visible' : 'partlyVisible';
|
|
55
|
+
}
|
|
56
|
+
const prevState = slideStates.get(slide);
|
|
57
|
+
// If freezeStateOnVisible is enabled and slide was previously visible, keep it frozen
|
|
58
|
+
if (options.freezeStateOnVisible && prevState === 'visible') {
|
|
59
|
+
return;
|
|
60
|
+
}
|
|
61
|
+
if (prevState === nextState) {
|
|
62
|
+
return;
|
|
63
|
+
}
|
|
64
|
+
const nextClass = options.classNames[nextState];
|
|
65
|
+
if (prevState) {
|
|
66
|
+
const prevClass = options.classNames[prevState];
|
|
67
|
+
if (prevClass !== nextClass && prevClass) {
|
|
68
|
+
slide.classList.remove(prevClass);
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
else {
|
|
72
|
+
uniqueClassNames.forEach((className) => {
|
|
73
|
+
if (className !== nextClass) {
|
|
74
|
+
slide.classList.remove(className);
|
|
75
|
+
}
|
|
76
|
+
});
|
|
77
|
+
}
|
|
78
|
+
if (nextClass && !slide.classList.contains(nextClass)) {
|
|
79
|
+
slide.classList.add(nextClass);
|
|
80
|
+
}
|
|
81
|
+
slideStates.set(slide, nextState);
|
|
82
|
+
});
|
|
83
|
+
};
|
|
84
|
+
slider.on('created', update);
|
|
85
|
+
slider.on('pluginsLoaded', update);
|
|
86
|
+
slider.on('fullWidthPluginUpdate', update);
|
|
87
|
+
slider.on('contentsChanged', update);
|
|
88
|
+
slider.on('containerSizeChanged', update);
|
|
89
|
+
slider.on('detailsChanged', update);
|
|
90
|
+
slider.on('scrollEnd', update);
|
|
91
|
+
slider.on('scrollStart', update);
|
|
92
|
+
requestAnimationFrame(() => {
|
|
93
|
+
requestAnimationFrame(() => update());
|
|
94
|
+
});
|
|
95
|
+
let requestId = 0;
|
|
96
|
+
const debouncedUpdate = () => {
|
|
97
|
+
if (requestId) {
|
|
98
|
+
window.cancelAnimationFrame(requestId);
|
|
99
|
+
}
|
|
100
|
+
requestId = window.requestAnimationFrame(() => {
|
|
101
|
+
update();
|
|
102
|
+
});
|
|
103
|
+
};
|
|
104
|
+
slider.on('scroll', debouncedUpdate);
|
|
105
|
+
};
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
export { ClassNamesPlugin as default };
|
|
@@ -0,0 +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,42 +1,59 @@
|
|
|
1
1
|
const DEFAULT_TARGET_WIDTH = (slider) => { var _a, _b; return (_b = (_a = slider.container.parentElement) === null || _a === void 0 ? void 0 : _a.offsetWidth) !== null && _b !== void 0 ? _b : window.innerWidth; };
|
|
2
2
|
function FullWidthPlugin(args) {
|
|
3
3
|
return (slider) => {
|
|
4
|
-
var _a, _b, _c;
|
|
4
|
+
var _a, _b, _c, _d;
|
|
5
5
|
const options = {
|
|
6
|
-
targetWidth: (_a = args === null || args === void 0 ? void 0 : args.targetWidth) !== null && _a !== void 0 ? _a :
|
|
6
|
+
targetWidth: (_a = args === null || args === void 0 ? void 0 : args.targetWidth) !== null && _a !== void 0 ? _a : undefined,
|
|
7
7
|
addMarginBefore: (_b = args === null || args === void 0 ? void 0 : args.addMarginBefore) !== null && _b !== void 0 ? _b : true,
|
|
8
8
|
addMarginAfter: (_c = args === null || args === void 0 ? void 0 : args.addMarginAfter) !== null && _c !== void 0 ? _c : true,
|
|
9
9
|
};
|
|
10
|
+
if (typeof slider.options.targetWidth !== 'function') {
|
|
11
|
+
slider.options.targetWidth = (_d = options.targetWidth) !== null && _d !== void 0 ? _d : DEFAULT_TARGET_WIDTH;
|
|
12
|
+
}
|
|
13
|
+
const resolveTargetWidth = () => {
|
|
14
|
+
var _a;
|
|
15
|
+
if (typeof slider.options.targetWidth === 'function') {
|
|
16
|
+
return slider.options.targetWidth;
|
|
17
|
+
}
|
|
18
|
+
return (_a = options.targetWidth) !== null && _a !== void 0 ? _a : DEFAULT_TARGET_WIDTH;
|
|
19
|
+
};
|
|
10
20
|
const update = () => {
|
|
11
21
|
const slides = slider.container.querySelectorAll(slider.options.slidesSelector);
|
|
12
22
|
if (!slides.length) {
|
|
13
23
|
return;
|
|
14
24
|
}
|
|
25
|
+
const targetWidthFn = resolveTargetWidth();
|
|
26
|
+
const rawMargin = (window.innerWidth - targetWidthFn(slider)) / 2;
|
|
27
|
+
const marginAmount = Math.max(0, Math.floor(rawMargin));
|
|
28
|
+
const marginValue = marginAmount ? `${marginAmount}px` : '';
|
|
29
|
+
slides.forEach((slide) => {
|
|
30
|
+
const element = slide;
|
|
31
|
+
element.style.marginInlineStart = '';
|
|
32
|
+
element.style.marginInlineEnd = '';
|
|
33
|
+
});
|
|
15
34
|
const firstSlide = slides[0];
|
|
16
35
|
const lastSlide = slides[slides.length - 1];
|
|
17
|
-
const marginAmount = Math.floor((window.innerWidth - getTargetWidth()) / 2);
|
|
18
36
|
if (options.addMarginBefore) {
|
|
19
|
-
firstSlide.style.marginInlineStart =
|
|
37
|
+
firstSlide.style.marginInlineStart = marginValue;
|
|
38
|
+
slider.container.style.setProperty('scroll-padding-inline-start', marginValue || '0px');
|
|
20
39
|
}
|
|
21
|
-
|
|
22
|
-
|
|
40
|
+
else {
|
|
41
|
+
slider.container.style.removeProperty('scroll-padding-inline-start');
|
|
23
42
|
}
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
const getTargetWidth = () => {
|
|
28
|
-
if (typeof options.targetWidth === 'function') {
|
|
29
|
-
return options.targetWidth(slider);
|
|
43
|
+
if (options.addMarginAfter) {
|
|
44
|
+
lastSlide.style.marginInlineEnd = marginValue;
|
|
45
|
+
slider.container.style.setProperty('scroll-padding-inline-end', marginValue || '0px');
|
|
30
46
|
}
|
|
31
|
-
|
|
32
|
-
|
|
47
|
+
else {
|
|
48
|
+
slider.container.style.removeProperty('scroll-padding-inline-end');
|
|
33
49
|
}
|
|
34
|
-
|
|
50
|
+
slider.container.setAttribute('data-full-width-offset', `${marginAmount}`);
|
|
51
|
+
setCSS(targetWidthFn);
|
|
52
|
+
slider.emit('fullWidthPluginUpdate');
|
|
35
53
|
};
|
|
36
|
-
const setCSS = () => {
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
}
|
|
54
|
+
const setCSS = (targetWidthFn) => {
|
|
55
|
+
const width = targetWidthFn(slider);
|
|
56
|
+
slider.options.cssVariableContainer.style.setProperty('--slider-container-target-width', `${width}px`);
|
|
40
57
|
};
|
|
41
58
|
update();
|
|
42
59
|
slider.on('contentsChanged', update);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
|
|
1
|
+
const t=t=>{var n,e;return null!==(e=null===(n=t.container.parentElement)||void 0===n?void 0:n.offsetWidth)&&void 0!==e?e:window.innerWidth};function n(n){return e=>{var i,r,o,d;const l={targetWidth:null!==(i=null==n?void 0:n.targetWidth)&&void 0!==i?i:void 0,addMarginBefore:null===(r=null==n?void 0:n.addMarginBefore)||void 0===r||r,addMarginAfter:null===(o=null==n?void 0:n.addMarginAfter)||void 0===o||o};"function"!=typeof e.options.targetWidth&&(e.options.targetWidth=null!==(d=l.targetWidth)&&void 0!==d?d:t);const a=()=>{const n=e.container.querySelectorAll(e.options.slidesSelector);if(!n.length)return;const i=(()=>{var n;return"function"==typeof e.options.targetWidth?e.options.targetWidth:null!==(n=l.targetWidth)&&void 0!==n?n:t})(),r=(window.innerWidth-i(e))/2,o=Math.max(0,Math.floor(r)),d=o?`${o}px`:"";n.forEach(t=>{const n=t;n.style.marginInlineStart="",n.style.marginInlineEnd=""});const a=n[0],c=n[n.length-1];l.addMarginBefore?(a.style.marginInlineStart=d,e.container.style.setProperty("scroll-padding-inline-start",d||"0px")):e.container.style.removeProperty("scroll-padding-inline-start"),l.addMarginAfter?(c.style.marginInlineEnd=d,e.container.style.setProperty("scroll-padding-inline-end",d||"0px")):e.container.style.removeProperty("scroll-padding-inline-end"),e.container.setAttribute("data-full-width-offset",`${o}`),s(i),e.emit("fullWidthPluginUpdate")},s=t=>{const n=t(e);e.options.cssVariableContainer.style.setProperty("--slider-container-target-width",`${n}px`)};a(),e.on("contentsChanged",a),e.on("containerSizeChanged",a),window.addEventListener("resize",a)}}export{n as default};
|
package/docs/assets/demo.css
CHANGED
|
@@ -625,6 +625,46 @@ h3:before {
|
|
|
625
625
|
height: 1.625rem !important;
|
|
626
626
|
}
|
|
627
627
|
|
|
628
|
+
.example-container-1-classname-opacity .example-item {
|
|
629
|
+
transition: .5s ease-in-out;
|
|
630
|
+
}
|
|
631
|
+
|
|
632
|
+
.example-container-1-classname-opacity .is-visible {
|
|
633
|
+
opacity: 1;
|
|
634
|
+
}
|
|
635
|
+
.example-container-1-classname-opacity .is-hidden {
|
|
636
|
+
opacity: 0;
|
|
637
|
+
}
|
|
638
|
+
|
|
639
|
+
.example-container-1-classname-partly {
|
|
640
|
+
width: 100vw;
|
|
641
|
+
margin-inline-start: calc(-50vw + 50%);
|
|
642
|
+
scroll-snap-type: x mandatory;
|
|
643
|
+
}
|
|
644
|
+
|
|
645
|
+
@media (min-width: 768px) {
|
|
646
|
+
.example-container-1-classname-partly .example-item {
|
|
647
|
+
width: calc( ( var( --slider-container-target-width ) / 4 ) - ( 3 / 4 * var( --slide-gap ) ) );
|
|
648
|
+
}
|
|
649
|
+
|
|
650
|
+
.example-container-1-classname-partly .example-item {
|
|
651
|
+
transition: .2s ease-in-out;
|
|
652
|
+
}
|
|
653
|
+
|
|
654
|
+
.example-container-1-classname-partly .is-visible {
|
|
655
|
+
opacity: 1;
|
|
656
|
+
/* transform: scale(1); */
|
|
657
|
+
}
|
|
658
|
+
|
|
659
|
+
.example-container-1-classname-partly .is-partly-visible {
|
|
660
|
+
opacity: .5;
|
|
661
|
+
/* transform: scale(0.85); */
|
|
662
|
+
}
|
|
663
|
+
.example-container-1-classname-partly .is-hidden {
|
|
664
|
+
opacity: .2;
|
|
665
|
+
/* transform: scale(0); */
|
|
666
|
+
}
|
|
667
|
+
|
|
628
668
|
/* ===========================================================================
|
|
629
669
|
Example 4: Filters
|
|
630
670
|
=========================================================================== */
|
|
@@ -722,6 +762,7 @@ h3:before {
|
|
|
722
762
|
.example-container-4-full-width {
|
|
723
763
|
width: 100vw;
|
|
724
764
|
margin-inline-start: calc(-50vw + 50%);
|
|
765
|
+
scroll-snap-type: x mandatory;
|
|
725
766
|
}
|
|
726
767
|
|
|
727
768
|
/* ===========================================================================
|
package/docs/assets/demo.js
CHANGED
|
@@ -20,7 +20,8 @@ import DotsPlugin from '../dist/plugins/dots/index.esm.js';
|
|
|
20
20
|
import FullWidthPlugin from '../dist/plugins/full-width/index.esm.js';
|
|
21
21
|
import ThumbnailsPlugin from '../dist/plugins/thumbnails/index.esm.js';
|
|
22
22
|
import FadePlugin from '../dist/plugins/fade/index.esm.js';
|
|
23
|
-
|
|
23
|
+
import ClassNamesPlugin from '../dist/plugins/classnames/index.esm.js';
|
|
24
|
+
|
|
24
25
|
|
|
25
26
|
(function () {
|
|
26
27
|
const init = () => {
|
|
@@ -135,6 +136,43 @@ import FadePlugin from '../dist/plugins/fade/index.esm.js';
|
|
|
135
136
|
);
|
|
136
137
|
console.log( '1-fade', example1Fade );
|
|
137
138
|
|
|
139
|
+
const example1ClassNames = new OverflowSlider(
|
|
140
|
+
document.querySelector( '.example-container-1-classname-opacity' ),
|
|
141
|
+
{
|
|
142
|
+
emulateScrollSnap: true,
|
|
143
|
+
rtl: document.documentElement.dir === 'rtl',
|
|
144
|
+
},
|
|
145
|
+
[
|
|
146
|
+
DragScrollingPlugin(),
|
|
147
|
+
ClassNamesPlugin(),
|
|
148
|
+
]
|
|
149
|
+
);
|
|
150
|
+
console.log( '1-classname-opacity', example1ClassNames );
|
|
151
|
+
|
|
152
|
+
const example1ClassNamesPartly = new OverflowSlider(
|
|
153
|
+
document.querySelector( '.example-container-1-classname-partly' ),
|
|
154
|
+
{
|
|
155
|
+
emulateScrollSnap: true,
|
|
156
|
+
rtl: document.documentElement.dir === 'rtl',
|
|
157
|
+
targetWidth: (slider) => {
|
|
158
|
+
return slider.container.parentElement.clientWidth;
|
|
159
|
+
}
|
|
160
|
+
},
|
|
161
|
+
[
|
|
162
|
+
DragScrollingPlugin(),
|
|
163
|
+
FullWidthPlugin(),
|
|
164
|
+
ClassNamesPlugin(
|
|
165
|
+
{
|
|
166
|
+
classnames: {
|
|
167
|
+
partlyVisible: 'is-partly-visible',
|
|
168
|
+
},
|
|
169
|
+
freezeStateOnVisible: true,
|
|
170
|
+
}
|
|
171
|
+
),
|
|
172
|
+
]
|
|
173
|
+
);
|
|
174
|
+
console.log( '1-classname-partly', example1ClassNamesPartly );
|
|
175
|
+
|
|
138
176
|
const example1AutoplaySlide = new OverflowSlider(
|
|
139
177
|
document.querySelector( '.example-container-1-autoplay-slide' ),
|
|
140
178
|
{
|
|
@@ -163,25 +201,6 @@ import FadePlugin from '../dist/plugins/fade/index.esm.js';
|
|
|
163
201
|
);
|
|
164
202
|
console.log( '1-autoplay-view', example1AutoplayView );
|
|
165
203
|
|
|
166
|
-
// const example1Infinite = new OverflowSlider(
|
|
167
|
-
// document.querySelector( '.example-container-1-infinite' ),
|
|
168
|
-
// {
|
|
169
|
-
// emulateScrollSnap: true,
|
|
170
|
-
// rtl: document.documentElement.dir === 'rtl',
|
|
171
|
-
// },
|
|
172
|
-
// [
|
|
173
|
-
// DragScrollingPlugin(),
|
|
174
|
-
// AutoplayPlugin({
|
|
175
|
-
// movementType: 'slide',
|
|
176
|
-
// delayInMs: 1000,
|
|
177
|
-
// // loop: false, // infinite should loop it
|
|
178
|
-
// }),
|
|
179
|
-
// ScrollIndicatorPlugin(),
|
|
180
|
-
// InfiniteScrollPlugin(),
|
|
181
|
-
// ]
|
|
182
|
-
// );
|
|
183
|
-
// console.log( '1-infinite', example1Infinite );
|
|
184
|
-
|
|
185
204
|
const example2PerfectFit = new OverflowSlider(
|
|
186
205
|
document.querySelector( '.example-container-2-perfect-fit' ),
|
|
187
206
|
{
|
|
@@ -288,17 +307,14 @@ import FadePlugin from '../dist/plugins/fade/index.esm.js';
|
|
|
288
307
|
document.querySelector( '.example-container-4-full-width' ),
|
|
289
308
|
{
|
|
290
309
|
rtl: document.documentElement.dir === 'rtl',
|
|
310
|
+
emulateScrollSnap: true,
|
|
311
|
+
targetWidth: (slider) => {
|
|
312
|
+
return slider.container.parentElement.clientWidth;
|
|
313
|
+
}
|
|
291
314
|
},
|
|
292
315
|
[
|
|
293
316
|
DragScrollingPlugin(),
|
|
294
|
-
FullWidthPlugin(
|
|
295
|
-
{
|
|
296
|
-
targetWidth: (slider) => {
|
|
297
|
-
// copy the width of the parent element
|
|
298
|
-
return slider.container.parentElement.clientWidth;
|
|
299
|
-
}
|
|
300
|
-
}
|
|
301
|
-
),
|
|
317
|
+
FullWidthPlugin(),
|
|
302
318
|
ScrollIndicatorPlugin(),
|
|
303
319
|
]
|
|
304
320
|
);
|
package/docs/dist/index.d.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
export { default as OverflowSlider } from './plugins/core/index.
|
|
1
|
+
export { default as OverflowSlider } from './plugins/core/index.d2.ts';
|