react-slideshow-image 4.0.4 → 4.1.0

Sign up to get free protection for your applications and to get access to all the features.
@@ -260,8 +260,12 @@ var FadeZoom = /*#__PURE__*/React__default.forwardRef(function (props, ref) {
260
260
  goBack: function goBack() {
261
261
  moveBack();
262
262
  },
263
- goTo: function goTo(index) {
264
- moveTo(index);
263
+ goTo: function goTo(index, options) {
264
+ if (options != null && options.skipTransition) {
265
+ setIndex(index);
266
+ } else {
267
+ moveTo(index);
268
+ }
265
269
  }
266
270
  };
267
271
  });
@@ -370,8 +374,10 @@ var FadeZoom = /*#__PURE__*/React__default.forwardRef(function (props, ref) {
370
374
  }
371
375
  };
372
376
 
373
- var moveTo = function moveTo(index) {
374
- transitionSlide(index);
377
+ var moveTo = function moveTo(gotoIndex) {
378
+ if (gotoIndex !== index) {
379
+ transitionSlide(gotoIndex);
380
+ }
375
381
  };
376
382
 
377
383
  var navigate = function navigate(event) {
@@ -393,8 +399,7 @@ var FadeZoom = /*#__PURE__*/React__default.forwardRef(function (props, ref) {
393
399
  className: "react-slideshow-container " + (props.cssClass || ''),
394
400
  onMouseEnter: pauseSlides,
395
401
  onMouseOver: pauseSlides,
396
- onMouseLeave: startSlides,
397
- ref: props.ref
402
+ onMouseLeave: startSlides
398
403
  }, props.arrows && showPreviousArrow(props, index, preTransition), /*#__PURE__*/React__default.createElement("div", {
399
404
  className: "react-slideshow-fadezoom-wrapper " + props.cssClass,
400
405
  ref: wrapperRef
@@ -530,8 +535,12 @@ var Slide = /*#__PURE__*/React__default.forwardRef(function (props, ref) {
530
535
  goBack: function goBack() {
531
536
  moveBack();
532
537
  },
533
- goTo: function goTo(index) {
534
- moveTo(index);
538
+ goTo: function goTo(index, options) {
539
+ if (options != null && options.skipTransition) {
540
+ setIndex(index);
541
+ } else {
542
+ moveTo(index);
543
+ }
535
544
  }
536
545
  };
537
546
  });
@@ -1 +1 @@
1
- {"version":3,"file":"react-slideshow-image.cjs.development.js","sources":["../src/helpers.tsx","../src/props.ts","../src/fadezoom.tsx","../src/fade.tsx","../src/zoom.tsx","../src/slide.tsx"],"sourcesContent":["import React, { ReactNode } from 'react';\nimport {\n ButtonClick,\n FadeProps,\n IndicatorPropsType,\n Responsive,\n SlideProps,\n TweenEasingFn,\n ZoomProps,\n} from './types';\nimport TWEEN from '@tweenjs/tween.js';\n\nexport const getStartingIndex = (children: ReactNode, defaultIndex?: number): number => {\n if (defaultIndex && defaultIndex < React.Children.count(children)) {\n return defaultIndex;\n }\n return 0;\n};\n\nexport const getResponsiveSettings = (\n wrapperWidth: number,\n responsive?: Array<Responsive>\n): Responsive | undefined => {\n if (typeof window !== 'undefined' && Array.isArray(responsive)) {\n return responsive.find((each) => each.breakpoint <= wrapperWidth);\n }\n return;\n};\n\nconst EASING_METHODS: { [key: string]: TweenEasingFn } = {\n linear: TWEEN.Easing.Linear.None,\n ease: TWEEN.Easing.Quadratic.InOut,\n 'ease-in': TWEEN.Easing.Quadratic.In,\n 'ease-out': TWEEN.Easing.Quadratic.Out,\n cubic: TWEEN.Easing.Cubic.InOut,\n 'cubic-in': TWEEN.Easing.Cubic.In,\n 'cubic-out': TWEEN.Easing.Cubic.Out,\n};\n\nexport const getEasing = (easeMethod?: string): TweenEasingFn => {\n if (easeMethod) {\n return EASING_METHODS[easeMethod];\n }\n return EASING_METHODS.linear;\n};\n\nexport const showPreviousArrow = (\n { prevArrow, infinite }: FadeProps | SlideProps | ZoomProps,\n currentIndex: number,\n moveSlides: ButtonClick\n): ReactNode => {\n const isDisabled = currentIndex <= 0 && !infinite;\n const props = {\n 'data-type': 'prev',\n 'aria-label': 'Previous Slide',\n disabled: isDisabled,\n onClick: moveSlides,\n };\n if (prevArrow) {\n return React.cloneElement(prevArrow, {\n className: `${prevArrow.props.className || ''} nav ${isDisabled ? 'disabled' : ''}`,\n ...props,\n });\n }\n const className = `nav default-nav ${isDisabled ? 'disabled' : ''}`;\n return (\n <button type=\"button\" className={className} {...props}>\n <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\">\n <path d=\"M16.67 0l2.83 2.829-9.339 9.175 9.339 9.167-2.83 2.829-12.17-11.996z\" />\n </svg>\n </button>\n );\n};\n\nexport const showNextArrow = (\n properties: FadeProps | SlideProps | ZoomProps,\n currentIndex: number,\n moveSlides: ButtonClick\n) => {\n const { nextArrow, infinite, children } = properties;\n let slidesToScroll = 1;\n if ('slidesToScroll' in properties) {\n slidesToScroll = properties.slidesToScroll || 1;\n }\n const isDisabled = currentIndex >= React.Children.count(children) - slidesToScroll && !infinite;\n const props = {\n 'data-type': 'next',\n 'aria-label': 'Next Slide',\n disabled: isDisabled,\n onClick: moveSlides,\n };\n if (nextArrow) {\n return React.cloneElement(nextArrow, {\n className: `${nextArrow.props.className || ''} nav ${isDisabled ? 'disabled' : ''}`,\n ...props,\n });\n }\n const className = `nav default-nav ${isDisabled ? 'disabled' : ''}`;\n return (\n <button type=\"button\" className={className} {...props}>\n <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\">\n <path d=\"M5 3l3.057-3 11.943 12-11.943 12-3.057-3 9-9z\" />\n </svg>\n </button>\n );\n};\n\nconst showDefaultIndicator = (\n isCurrentPageActive: boolean,\n key: number,\n indicatorProps: IndicatorPropsType\n) => {\n return (\n <li key={key}>\n <button\n type=\"button\"\n className={`each-slideshow-indicator ${isCurrentPageActive ? 'active' : ''}`}\n {...indicatorProps}\n />\n </li>\n );\n};\n\nconst showCustomIndicator = (\n isCurrentPageActive: boolean,\n key: number,\n indicatorProps: any,\n eachIndicator: any\n) => {\n return React.cloneElement(eachIndicator, {\n className: `${eachIndicator.props.className} ${isCurrentPageActive ? 'active' : ''}`,\n key,\n ...indicatorProps,\n });\n};\n\nexport const showIndicators = (\n props: FadeProps | SlideProps | ZoomProps,\n currentIndex: number,\n navigate: ButtonClick,\n responsiveSettings?: Responsive\n): ReactNode => {\n const { children, indicators } = props;\n let slidesToScroll = 1;\n if (responsiveSettings) {\n slidesToScroll = responsiveSettings?.settings.slidesToScroll;\n } else if ('slidesToScroll' in props) {\n slidesToScroll = props.slidesToScroll || 1;\n }\n const pages = Math.ceil(React.Children.count(children) / slidesToScroll);\n return (\n <ul className=\"indicators\">\n {Array.from({ length: pages }, (_, key) => {\n const indicatorProps: IndicatorPropsType = {\n 'data-key': key,\n 'aria-label': `Go to slide ${key + 1}`,\n onClick: navigate,\n };\n const isCurrentPageActive =\n Math.floor((currentIndex + slidesToScroll - 1) / slidesToScroll) === key;\n if (typeof indicators === 'function') {\n return showCustomIndicator(\n isCurrentPageActive,\n key,\n indicatorProps,\n indicators(key)\n );\n }\n return showDefaultIndicator(isCurrentPageActive, key, indicatorProps);\n })}\n </ul>\n );\n};\n","export const defaultProps = {\n duration: 5000,\n transitionDuration: 1000,\n defaultIndex: 0,\n infinite: true,\n autoplay: true,\n indicators: false,\n arrows: true,\n pauseOnHover: true,\n easing: 'linear',\n canSwipe: true,\n cssClass: '',\n responsive: [],\n};\n","import React, {\n useState,\n useRef,\n useEffect,\n useMemo,\n useImperativeHandle,\n useCallback,\n} from 'react';\nimport ResizeObserver from 'resize-observer-polyfill';\nimport TWEEN from '@tweenjs/tween.js';\nimport {\n getEasing,\n getStartingIndex,\n showIndicators,\n showNextArrow,\n showPreviousArrow,\n} from './helpers';\nimport { ButtonClick, SlideshowRef, ZoomProps } from './types';\nimport { defaultProps } from './props';\n\nexport const FadeZoom = React.forwardRef<SlideshowRef, ZoomProps>((props, ref) => {\n const [index, setIndex] = useState<number>(\n getStartingIndex(props.children, props.defaultIndex)\n );\n const wrapperRef = useRef<HTMLDivElement>(null);\n const innerWrapperRef = useRef<any>(null);\n const tweenGroup = useRef(new TWEEN.Group());\n const timeout = useRef<NodeJS.Timeout>();\n const resizeObserver = useRef<any>();\n const childrenCount = useMemo(() => React.Children.count(props.children), [props.children]);\n\n const applyStyle = useCallback(() => {\n if (innerWrapperRef.current && wrapperRef.current) {\n const wrapperWidth = wrapperRef.current.clientWidth;\n const fullwidth = wrapperWidth * childrenCount;\n innerWrapperRef.current.style.width = `${fullwidth}px`;\n for (let index = 0; index < innerWrapperRef.current.children.length; index++) {\n const eachDiv = innerWrapperRef.current.children[index];\n if (eachDiv) {\n eachDiv.style.width = `${wrapperWidth}px`;\n eachDiv.style.left = `${index * -wrapperWidth}px`;\n eachDiv.style.display = `block`;\n }\n }\n }\n }, [wrapperRef, innerWrapperRef, childrenCount]);\n\n const initResizeObserver = useCallback(() => {\n if (wrapperRef.current) {\n resizeObserver.current = new ResizeObserver((entries) => {\n if (!entries) return;\n applyStyle();\n });\n resizeObserver.current.observe(wrapperRef.current);\n }\n }, [wrapperRef, applyStyle]);\n\n const play = useCallback(() => {\n const { autoplay, children, duration, infinite } = props;\n if (\n autoplay &&\n React.Children.count(children) > 1 &&\n (infinite || index < React.Children.count(children) - 1)\n ) {\n timeout.current = setTimeout(moveNext, duration);\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [props, index]);\n\n useEffect(() => {\n initResizeObserver();\n return () => {\n tweenGroup.current.removeAll();\n clearTimeout(timeout.current);\n removeResizeObserver();\n };\n }, [initResizeObserver, tweenGroup]);\n\n useEffect(() => {\n clearTimeout(timeout.current);\n play();\n }, [index, props.autoplay, play]);\n\n useEffect(() => {\n applyStyle();\n }, [childrenCount, applyStyle]);\n\n useImperativeHandle(ref, () => ({\n goNext: () => {\n moveNext();\n },\n goBack: () => {\n moveBack();\n },\n goTo: (index: number) => {\n moveTo(index);\n },\n }));\n\n const removeResizeObserver = () => {\n if (resizeObserver.current && wrapperRef.current) {\n resizeObserver.current.unobserve(wrapperRef.current);\n }\n };\n\n const pauseSlides = () => {\n if (props.pauseOnHover) {\n clearTimeout(timeout.current);\n }\n };\n\n const startSlides = () => {\n const { pauseOnHover, autoplay, duration } = props;\n if (pauseOnHover && autoplay) {\n timeout.current = setTimeout(() => moveNext(), duration);\n }\n };\n\n const moveNext = () => {\n const { children, infinite } = props;\n if (!infinite && index === React.Children.count(children) - 1) {\n return;\n }\n transitionSlide((index + 1) % React.Children.count(children));\n };\n\n const moveBack = () => {\n const { children, infinite } = props;\n if (!infinite && index === 0) {\n return;\n }\n transitionSlide(index === 0 ? React.Children.count(children) - 1 : index - 1);\n };\n\n const preTransition: ButtonClick = (event) => {\n const { currentTarget } = event;\n if (currentTarget.dataset.type === 'prev') {\n moveBack();\n } else {\n moveNext();\n }\n };\n\n const transitionSlide = (newIndex: number) => {\n const existingTweens = tweenGroup.current.getAll();\n if (!existingTweens.length) {\n if (!innerWrapperRef.current?.children[newIndex]) {\n newIndex = 0;\n }\n clearTimeout(timeout.current);\n const value = { opacity: 0, scale: 1 };\n\n const animate = () => {\n requestAnimationFrame(animate);\n tweenGroup.current.update();\n };\n\n animate();\n\n const tween = new TWEEN.Tween(value, tweenGroup.current)\n .to({ opacity: 1, scale: props.scale }, props.transitionDuration)\n .onUpdate((value) => {\n if (!innerWrapperRef.current) {\n return;\n }\n innerWrapperRef.current.children[newIndex].style.opacity = value.opacity;\n innerWrapperRef.current.children[index].style.opacity = 1 - value.opacity;\n innerWrapperRef.current.children[\n index\n ].style.transform = `scale(${value.scale})`;\n })\n .start();\n tween.easing(getEasing(props.easing));\n tween.onComplete(() => {\n if (innerWrapperRef.current) {\n setIndex(newIndex);\n innerWrapperRef.current.children[index].style.transform = `scale(1)`;\n }\n if (typeof props.onChange === 'function') {\n props.onChange(index, newIndex);\n }\n });\n }\n };\n\n const moveTo = (index: number) => {\n transitionSlide(index);\n };\n\n const navigate: ButtonClick = (event) => {\n const { currentTarget } = event;\n if (!currentTarget.dataset.key) {\n return;\n }\n if (parseInt(currentTarget.dataset.key) !== index) {\n moveTo(parseInt(currentTarget.dataset.key));\n }\n };\n\n return (\n <div dir=\"ltr\" aria-roledescription=\"carousel\">\n <div\n className={`react-slideshow-container ${props.cssClass || ''}`}\n onMouseEnter={pauseSlides}\n onMouseOver={pauseSlides}\n onMouseLeave={startSlides}\n ref={props.ref}\n >\n {props.arrows && showPreviousArrow(props, index, preTransition)}\n <div\n className={`react-slideshow-fadezoom-wrapper ${props.cssClass}`}\n ref={wrapperRef}\n >\n <div className=\"react-slideshow-fadezoom-images-wrap\" ref={innerWrapperRef}>\n {(React.Children.map(props.children, (thisArg) => thisArg) || []).map(\n (each, key) => (\n <div\n style={{\n opacity: key === index ? '1' : '0',\n zIndex: key === index ? '1' : '0',\n }}\n data-index={key}\n key={key}\n aria-roledescription=\"slide\"\n aria-hidden={key === index ? 'false' : 'true'}\n >\n {each}\n </div>\n )\n )}\n </div>\n </div>\n {props.arrows && showNextArrow(props, index, preTransition)}\n </div>\n {props.indicators && showIndicators(props, index, navigate)}\n </div>\n );\n});\n\nFadeZoom.defaultProps = defaultProps;\n","import React from 'react';\nimport { FadeZoom } from './fadezoom';\nimport { defaultProps } from './props';\nimport { FadeProps, SlideshowRef } from './types';\n\nexport const Fade = React.forwardRef<SlideshowRef, FadeProps>((props, ref) => {\n return <FadeZoom {...props} scale={1} ref={ref} />;\n});\n\nFade.defaultProps = defaultProps;\n","import React from 'react';\nimport { FadeZoom } from './fadezoom';\nimport { defaultProps } from './props';\nimport { SlideshowRef, ZoomProps } from './types';\n\nexport const Zoom = React.forwardRef<SlideshowRef, ZoomProps>((props, ref) => {\n return <FadeZoom {...props} ref={ref} />;\n});\n\nZoom.defaultProps = defaultProps;\n","import React, {\n useState,\n useRef,\n useEffect,\n useMemo,\n useImperativeHandle,\n useCallback,\n} from 'react';\nimport ResizeObserver from 'resize-observer-polyfill';\nimport TWEEN from '@tweenjs/tween.js';\nimport {\n getEasing,\n getResponsiveSettings,\n getStartingIndex,\n showIndicators,\n showNextArrow,\n showPreviousArrow,\n} from './helpers';\nimport { ButtonClick, SlideshowRef, SlideProps } from './types';\nimport { defaultProps } from './props';\n\nexport const Slide = React.forwardRef<SlideshowRef, SlideProps>((props, ref) => {\n const [index, setIndex] = useState(getStartingIndex(props.children, props.defaultIndex));\n const [wrapperWidth, setWrapperWidth] = useState<number>(0);\n const wrapperRef = useRef<HTMLDivElement>(null);\n const innerWrapperRef = useRef<any>(null);\n const tweenGroup = useRef(new TWEEN.Group());\n const responsiveSettings = useMemo(\n () => getResponsiveSettings(wrapperWidth, props.responsive),\n [wrapperWidth, props.responsive]\n );\n const slidesToScroll = useMemo(() => {\n if (responsiveSettings) {\n return responsiveSettings.settings.slidesToScroll;\n }\n return props.slidesToScroll || 1;\n }, [responsiveSettings, props.slidesToScroll]);\n const slidesToShow = useMemo(() => {\n if (responsiveSettings) {\n return responsiveSettings.settings.slidesToShow;\n }\n return props.slidesToShow || 1;\n }, [responsiveSettings, props.slidesToShow]);\n const childrenCount = useMemo(() => React.Children.count(props.children), [props.children]);\n const eachChildWidth = useMemo(() => wrapperWidth / slidesToShow, [wrapperWidth, slidesToShow]);\n const timeout = useRef<NodeJS.Timeout>();\n const resizeObserver = useRef<any>();\n let startingClientX: number;\n let dragging: boolean = false;\n let distanceSwiped: number = 0;\n\n const applyStyle = useCallback(() => {\n if (innerWrapperRef.current) {\n const fullwidth = wrapperWidth * innerWrapperRef.current.children.length;\n innerWrapperRef.current.style.width = `${fullwidth}px`;\n for (let index = 0; index < innerWrapperRef.current.children.length; index++) {\n const eachDiv = innerWrapperRef.current.children[index];\n if (eachDiv) {\n eachDiv.style.width = `${eachChildWidth}px`;\n eachDiv.style.display = `block`;\n }\n }\n }\n }, [wrapperWidth, eachChildWidth]);\n\n const initResizeObserver = useCallback(() => {\n if (wrapperRef.current) {\n resizeObserver.current = new ResizeObserver((entries) => {\n if (!entries) return;\n setWidth();\n });\n resizeObserver.current.observe(wrapperRef.current);\n }\n }, [wrapperRef]);\n\n const play = useCallback(() => {\n const { autoplay, infinite, duration } = props;\n if (autoplay && (infinite || index < childrenCount - 1)) {\n timeout.current = setTimeout(moveNext, duration);\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [props, childrenCount, index]);\n\n useEffect(() => {\n applyStyle();\n }, [wrapperWidth, applyStyle]);\n\n useEffect(() => {\n initResizeObserver();\n return () => {\n tweenGroup.current.removeAll();\n clearTimeout(timeout.current);\n removeResizeObserver();\n };\n }, [wrapperRef, initResizeObserver, tweenGroup]);\n\n useEffect(() => {\n clearTimeout(timeout.current);\n play();\n }, [index, wrapperWidth, props.autoplay, play]);\n\n useImperativeHandle(ref, () => ({\n goNext: () => {\n moveNext();\n },\n goBack: () => {\n moveBack();\n },\n goTo: (index: number) => {\n moveTo(index);\n },\n }));\n\n const removeResizeObserver = () => {\n if (resizeObserver && wrapperRef.current) {\n resizeObserver.current.unobserve(wrapperRef.current);\n }\n };\n\n const pauseSlides = () => {\n if (props.pauseOnHover) {\n clearTimeout(timeout.current);\n }\n };\n\n const swipe = (event: React.MouseEvent | React.TouchEvent) => {\n if (props.canSwipe && dragging) {\n let clientX;\n if (window.TouchEvent && event.nativeEvent instanceof TouchEvent) {\n clientX = event.nativeEvent.touches[0].pageX;\n } else if (event.nativeEvent instanceof MouseEvent) {\n clientX = event.nativeEvent.clientX;\n }\n if (clientX && startingClientX) {\n let translateValue = eachChildWidth * (index + getOffset());\n const distance = clientX - startingClientX;\n if (!props.infinite && index === childrenCount - slidesToScroll && distance < 0) {\n // if it is the last and infinite is false and you're swiping left\n // then nothing happens\n return;\n }\n if (!props.infinite && index === 0 && distance > 0) {\n // if it is the first and infinite is false and you're swiping right\n // then nothing happens\n return;\n }\n distanceSwiped = distance;\n translateValue -= distanceSwiped;\n innerWrapperRef.current.style.transform = `translate(-${translateValue}px)`;\n }\n }\n };\n\n const moveNext = () => {\n if (!props.infinite && index === childrenCount - slidesToScroll) {\n return;\n }\n const nextIndex = calculateIndex(index + slidesToScroll);\n transitionSlide(nextIndex);\n };\n\n const moveBack = () => {\n if (!props.infinite && index === 0) {\n return;\n }\n let previousIndex = index - slidesToScroll;\n if (previousIndex % slidesToScroll) {\n previousIndex = Math.ceil(previousIndex / slidesToScroll) * slidesToScroll;\n }\n transitionSlide(previousIndex);\n };\n\n const goToSlide: ButtonClick = ({ currentTarget }) => {\n if (!currentTarget.dataset.key) {\n return;\n }\n const datasetKey = parseInt(currentTarget.dataset.key);\n moveTo(datasetKey * slidesToScroll);\n };\n\n const moveTo = (index: number) => {\n transitionSlide(calculateIndex(index));\n };\n\n const calculateIndex = (nextIndex: number): number => {\n if (nextIndex < childrenCount && nextIndex + slidesToScroll > childrenCount) {\n if ((childrenCount - slidesToScroll) % slidesToScroll) {\n return childrenCount - slidesToScroll;\n }\n return nextIndex;\n }\n return nextIndex;\n };\n\n const startSlides = () => {\n if (dragging) {\n endSwipe();\n } else if (props.pauseOnHover && props.autoplay) {\n timeout.current = setTimeout(moveNext, props.duration);\n }\n };\n\n const moveSlides: ButtonClick = ({ currentTarget: { dataset } }) => {\n if (dataset.type === 'next') {\n moveNext();\n } else {\n moveBack();\n }\n };\n\n const renderPreceedingSlides = () => {\n return React.Children.toArray(props.children)\n .slice(-slidesToShow)\n .map((each, index) => (\n <div\n data-index={index - slidesToShow}\n aria-roledescription=\"slide\"\n aria-hidden=\"true\"\n key={index - slidesToShow}\n >\n {each}\n </div>\n ));\n };\n\n const renderTrailingSlides = () => {\n if (!props.infinite && slidesToShow === slidesToScroll) {\n return;\n }\n return React.Children.toArray(props.children)\n .slice(0, slidesToShow)\n .map((each, index) => (\n <div\n data-index={childrenCount + index}\n aria-roledescription=\"slide\"\n aria-hidden=\"true\"\n key={childrenCount + index}\n >\n {each}\n </div>\n ));\n };\n\n const setWidth = () => {\n if (wrapperRef.current) {\n setWrapperWidth(wrapperRef.current.clientWidth);\n }\n };\n\n const startSwipe = (event: React.MouseEvent | React.TouchEvent) => {\n if (props.canSwipe) {\n if (window.TouchEvent && event.nativeEvent instanceof TouchEvent) {\n startingClientX = event.nativeEvent.touches[0].pageX;\n } else if (event.nativeEvent instanceof MouseEvent) {\n startingClientX = event.nativeEvent.clientX;\n }\n clearTimeout(timeout.current);\n dragging = true;\n }\n };\n\n const endSwipe = () => {\n if (props.canSwipe) {\n dragging = false;\n if (Math.abs(distanceSwiped) / wrapperWidth > 0.2) {\n if (distanceSwiped < 0) {\n moveNext();\n } else {\n moveBack();\n }\n } else {\n if (Math.abs(distanceSwiped) > 0) {\n transitionSlide(index, 300);\n }\n }\n }\n };\n\n const transitionSlide = (toIndex: number, animationDuration?: number) => {\n const transitionDuration = animationDuration || props.transitionDuration;\n const currentIndex = index;\n const existingTweens = tweenGroup.current.getAll();\n if (!wrapperRef.current) {\n return;\n }\n const childWidth = wrapperRef.current.clientWidth / slidesToShow;\n if (!existingTweens.length) {\n clearTimeout(timeout.current);\n const value = {\n margin: -childWidth * (currentIndex + getOffset()) + distanceSwiped,\n };\n const tween = new TWEEN.Tween(value, tweenGroup.current)\n .to({ margin: -childWidth * (toIndex + getOffset()) }, transitionDuration)\n .onUpdate((value) => {\n if (innerWrapperRef.current) {\n innerWrapperRef.current.style.transform = `translate(${value.margin}px)`;\n }\n })\n .start();\n tween.easing(getEasing(props.easing));\n const animate = () => {\n requestAnimationFrame(animate);\n tweenGroup.current.update();\n };\n\n animate();\n\n tween.onComplete(() => {\n distanceSwiped = 0;\n let newIndex = toIndex;\n if (newIndex < 0) {\n newIndex = childrenCount - slidesToScroll;\n } else if (newIndex >= childrenCount) {\n newIndex = 0;\n }\n\n if (typeof props.onChange === 'function') {\n props.onChange(index, newIndex);\n }\n setIndex(newIndex);\n });\n }\n };\n\n const isSlideActive = (key: number) => {\n return key < index + slidesToShow && key >= index;\n };\n\n const getOffset = (): number => {\n if (!props.infinite) {\n return 0;\n }\n return slidesToShow;\n };\n\n const style = {\n transform: `translate(-${(index + getOffset()) * eachChildWidth}px)`,\n };\n return (\n <div dir=\"ltr\" aria-roledescription=\"carousel\">\n <div\n className=\"react-slideshow-container\"\n onMouseEnter={pauseSlides}\n onMouseOver={pauseSlides}\n onMouseLeave={startSlides}\n onMouseDown={startSwipe}\n onMouseUp={endSwipe}\n onMouseMove={swipe}\n onTouchStart={startSwipe}\n onTouchEnd={endSwipe}\n onTouchCancel={endSwipe}\n onTouchMove={swipe}\n >\n {props.arrows && showPreviousArrow(props, index, moveSlides)}\n <div\n className={`react-slideshow-wrapper slide ${props.cssClass || ''}`}\n ref={wrapperRef}\n >\n <div className=\"images-wrap\" style={style} ref={innerWrapperRef}>\n {props.infinite && renderPreceedingSlides()}\n {(React.Children.map(props.children, (thisArg) => thisArg) || []).map(\n (each, key) => {\n const isThisSlideActive = isSlideActive(key);\n return (\n <div\n data-index={key}\n key={key}\n className={isThisSlideActive ? 'active' : ''}\n aria-roledescription=\"slide\"\n aria-hidden={isThisSlideActive ? 'false' : 'true'}\n >\n {each}\n </div>\n );\n }\n )}\n {renderTrailingSlides()}\n </div>\n </div>\n {props.arrows && showNextArrow(props, index, moveSlides)}\n </div>\n {props.indicators && showIndicators(props, index, goToSlide, responsiveSettings)}\n </div>\n );\n});\n\nSlide.defaultProps = defaultProps;\n"],"names":["getStartingIndex","children","defaultIndex","React","Children","count","getResponsiveSettings","wrapperWidth","responsive","window","Array","isArray","find","each","breakpoint","EASING_METHODS","linear","TWEEN","Easing","Linear","None","ease","Quadratic","InOut","In","Out","cubic","Cubic","getEasing","easeMethod","showPreviousArrow","currentIndex","moveSlides","prevArrow","infinite","isDisabled","props","disabled","onClick","cloneElement","className","type","width","height","viewBox","d","showNextArrow","properties","nextArrow","slidesToScroll","showDefaultIndicator","isCurrentPageActive","key","indicatorProps","showCustomIndicator","eachIndicator","showIndicators","navigate","responsiveSettings","indicators","settings","pages","Math","ceil","from","length","_","floor","defaultProps","duration","transitionDuration","autoplay","arrows","pauseOnHover","easing","canSwipe","cssClass","FadeZoom","forwardRef","ref","useState","index","setIndex","wrapperRef","useRef","innerWrapperRef","tweenGroup","Group","timeout","resizeObserver","childrenCount","useMemo","applyStyle","useCallback","current","clientWidth","fullwidth","style","eachDiv","left","display","initResizeObserver","ResizeObserver","entries","observe","play","setTimeout","moveNext","useEffect","removeAll","clearTimeout","removeResizeObserver","useImperativeHandle","goNext","goBack","moveBack","goTo","moveTo","unobserve","pauseSlides","startSlides","transitionSlide","preTransition","event","currentTarget","dataset","newIndex","existingTweens","getAll","value","opacity","scale","animate","requestAnimationFrame","update","tween","Tween","to","onUpdate","transform","start","onComplete","onChange","parseInt","dir","onMouseEnter","onMouseOver","onMouseLeave","map","thisArg","zIndex","Fade","Zoom","Slide","setWrapperWidth","slidesToShow","eachChildWidth","startingClientX","dragging","distanceSwiped","setWidth","swipe","clientX","TouchEvent","nativeEvent","touches","pageX","MouseEvent","translateValue","getOffset","distance","nextIndex","calculateIndex","previousIndex","goToSlide","datasetKey","endSwipe","renderPreceedingSlides","toArray","slice","renderTrailingSlides","startSwipe","abs","toIndex","animationDuration","childWidth","margin","isSlideActive","onMouseDown","onMouseUp","onMouseMove","onTouchStart","onTouchEnd","onTouchCancel","onTouchMove","isThisSlideActive"],"mappings":"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"}
1
+ {"version":3,"file":"react-slideshow-image.cjs.development.js","sources":["../src/helpers.tsx","../src/props.ts","../src/fadezoom.tsx","../src/fade.tsx","../src/zoom.tsx","../src/slide.tsx"],"sourcesContent":["import React, { ReactNode } from 'react';\nimport {\n ButtonClick,\n FadeProps,\n IndicatorPropsType,\n Responsive,\n SlideProps,\n TweenEasingFn,\n ZoomProps,\n} from './types';\nimport TWEEN from '@tweenjs/tween.js';\n\nexport const getStartingIndex = (children: ReactNode, defaultIndex?: number): number => {\n if (defaultIndex && defaultIndex < React.Children.count(children)) {\n return defaultIndex;\n }\n return 0;\n};\n\nexport const getResponsiveSettings = (\n wrapperWidth: number,\n responsive?: Array<Responsive>\n): Responsive | undefined => {\n if (typeof window !== 'undefined' && Array.isArray(responsive)) {\n return responsive.find((each) => each.breakpoint <= wrapperWidth);\n }\n return;\n};\n\nconst EASING_METHODS: { [key: string]: TweenEasingFn } = {\n linear: TWEEN.Easing.Linear.None,\n ease: TWEEN.Easing.Quadratic.InOut,\n 'ease-in': TWEEN.Easing.Quadratic.In,\n 'ease-out': TWEEN.Easing.Quadratic.Out,\n cubic: TWEEN.Easing.Cubic.InOut,\n 'cubic-in': TWEEN.Easing.Cubic.In,\n 'cubic-out': TWEEN.Easing.Cubic.Out,\n};\n\nexport const getEasing = (easeMethod?: string): TweenEasingFn => {\n if (easeMethod) {\n return EASING_METHODS[easeMethod];\n }\n return EASING_METHODS.linear;\n};\n\nexport const showPreviousArrow = (\n { prevArrow, infinite }: FadeProps | SlideProps | ZoomProps,\n currentIndex: number,\n moveSlides: ButtonClick\n): ReactNode => {\n const isDisabled = currentIndex <= 0 && !infinite;\n const props = {\n 'data-type': 'prev',\n 'aria-label': 'Previous Slide',\n disabled: isDisabled,\n onClick: moveSlides,\n };\n if (prevArrow) {\n return React.cloneElement(prevArrow, {\n className: `${prevArrow.props.className || ''} nav ${isDisabled ? 'disabled' : ''}`,\n ...props,\n });\n }\n const className = `nav default-nav ${isDisabled ? 'disabled' : ''}`;\n return (\n <button type=\"button\" className={className} {...props}>\n <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\">\n <path d=\"M16.67 0l2.83 2.829-9.339 9.175 9.339 9.167-2.83 2.829-12.17-11.996z\" />\n </svg>\n </button>\n );\n};\n\nexport const showNextArrow = (\n properties: FadeProps | SlideProps | ZoomProps,\n currentIndex: number,\n moveSlides: ButtonClick\n) => {\n const { nextArrow, infinite, children } = properties;\n let slidesToScroll = 1;\n if ('slidesToScroll' in properties) {\n slidesToScroll = properties.slidesToScroll || 1;\n }\n const isDisabled = currentIndex >= React.Children.count(children) - slidesToScroll && !infinite;\n const props = {\n 'data-type': 'next',\n 'aria-label': 'Next Slide',\n disabled: isDisabled,\n onClick: moveSlides,\n };\n if (nextArrow) {\n return React.cloneElement(nextArrow, {\n className: `${nextArrow.props.className || ''} nav ${isDisabled ? 'disabled' : ''}`,\n ...props,\n });\n }\n const className = `nav default-nav ${isDisabled ? 'disabled' : ''}`;\n return (\n <button type=\"button\" className={className} {...props}>\n <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\">\n <path d=\"M5 3l3.057-3 11.943 12-11.943 12-3.057-3 9-9z\" />\n </svg>\n </button>\n );\n};\n\nconst showDefaultIndicator = (\n isCurrentPageActive: boolean,\n key: number,\n indicatorProps: IndicatorPropsType\n) => {\n return (\n <li key={key}>\n <button\n type=\"button\"\n className={`each-slideshow-indicator ${isCurrentPageActive ? 'active' : ''}`}\n {...indicatorProps}\n />\n </li>\n );\n};\n\nconst showCustomIndicator = (\n isCurrentPageActive: boolean,\n key: number,\n indicatorProps: any,\n eachIndicator: any\n) => {\n return React.cloneElement(eachIndicator, {\n className: `${eachIndicator.props.className} ${isCurrentPageActive ? 'active' : ''}`,\n key,\n ...indicatorProps,\n });\n};\n\nexport const showIndicators = (\n props: FadeProps | SlideProps | ZoomProps,\n currentIndex: number,\n navigate: ButtonClick,\n responsiveSettings?: Responsive\n): ReactNode => {\n const { children, indicators } = props;\n let slidesToScroll = 1;\n if (responsiveSettings) {\n slidesToScroll = responsiveSettings?.settings.slidesToScroll;\n } else if ('slidesToScroll' in props) {\n slidesToScroll = props.slidesToScroll || 1;\n }\n const pages = Math.ceil(React.Children.count(children) / slidesToScroll);\n return (\n <ul className=\"indicators\">\n {Array.from({ length: pages }, (_, key) => {\n const indicatorProps: IndicatorPropsType = {\n 'data-key': key,\n 'aria-label': `Go to slide ${key + 1}`,\n onClick: navigate,\n };\n const isCurrentPageActive =\n Math.floor((currentIndex + slidesToScroll - 1) / slidesToScroll) === key;\n if (typeof indicators === 'function') {\n return showCustomIndicator(\n isCurrentPageActive,\n key,\n indicatorProps,\n indicators(key)\n );\n }\n return showDefaultIndicator(isCurrentPageActive, key, indicatorProps);\n })}\n </ul>\n );\n};\n","export const defaultProps = {\n duration: 5000,\n transitionDuration: 1000,\n defaultIndex: 0,\n infinite: true,\n autoplay: true,\n indicators: false,\n arrows: true,\n pauseOnHover: true,\n easing: 'linear',\n canSwipe: true,\n cssClass: '',\n responsive: [],\n};\n","import React, {\n useState,\n useRef,\n useEffect,\n useMemo,\n useImperativeHandle,\n useCallback,\n} from 'react';\nimport ResizeObserver from 'resize-observer-polyfill';\nimport TWEEN from '@tweenjs/tween.js';\nimport {\n getEasing,\n getStartingIndex,\n showIndicators,\n showNextArrow,\n showPreviousArrow,\n} from './helpers';\nimport { ButtonClick, SlideshowRef, ZoomProps } from './types';\nimport { defaultProps } from './props';\n\nexport const FadeZoom = React.forwardRef<SlideshowRef, ZoomProps>((props, ref) => {\n const [index, setIndex] = useState<number>(\n getStartingIndex(props.children, props.defaultIndex)\n );\n const wrapperRef = useRef<HTMLDivElement>(null);\n const innerWrapperRef = useRef<any>(null);\n const tweenGroup = useRef(new TWEEN.Group());\n const timeout = useRef<NodeJS.Timeout>();\n const resizeObserver = useRef<any>();\n const childrenCount = useMemo(() => React.Children.count(props.children), [props.children]);\n\n const applyStyle = useCallback(() => {\n if (innerWrapperRef.current && wrapperRef.current) {\n const wrapperWidth = wrapperRef.current.clientWidth;\n const fullwidth = wrapperWidth * childrenCount;\n innerWrapperRef.current.style.width = `${fullwidth}px`;\n for (let index = 0; index < innerWrapperRef.current.children.length; index++) {\n const eachDiv = innerWrapperRef.current.children[index];\n if (eachDiv) {\n eachDiv.style.width = `${wrapperWidth}px`;\n eachDiv.style.left = `${index * -wrapperWidth}px`;\n eachDiv.style.display = `block`;\n }\n }\n }\n }, [wrapperRef, innerWrapperRef, childrenCount]);\n\n const initResizeObserver = useCallback(() => {\n if (wrapperRef.current) {\n resizeObserver.current = new ResizeObserver((entries) => {\n if (!entries) return;\n applyStyle();\n });\n resizeObserver.current.observe(wrapperRef.current);\n }\n }, [wrapperRef, applyStyle]);\n\n const play = useCallback(() => {\n const { autoplay, children, duration, infinite } = props;\n if (\n autoplay &&\n React.Children.count(children) > 1 &&\n (infinite || index < React.Children.count(children) - 1)\n ) {\n timeout.current = setTimeout(moveNext, duration);\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [props, index]);\n\n useEffect(() => {\n initResizeObserver();\n return () => {\n tweenGroup.current.removeAll();\n clearTimeout(timeout.current);\n removeResizeObserver();\n };\n }, [initResizeObserver, tweenGroup]);\n\n useEffect(() => {\n clearTimeout(timeout.current);\n play();\n }, [index, props.autoplay, play]);\n\n useEffect(() => {\n applyStyle();\n }, [childrenCount, applyStyle]);\n\n useImperativeHandle(ref, () => ({\n goNext: () => {\n moveNext();\n },\n goBack: () => {\n moveBack();\n },\n goTo: (index: number, options?: { skipTransition?: boolean }) => {\n if (options?.skipTransition) {\n setIndex(index);\n } else {\n moveTo(index);\n }\n },\n }));\n\n const removeResizeObserver = () => {\n if (resizeObserver.current && wrapperRef.current) {\n resizeObserver.current.unobserve(wrapperRef.current);\n }\n };\n\n const pauseSlides = () => {\n if (props.pauseOnHover) {\n clearTimeout(timeout.current);\n }\n };\n\n const startSlides = () => {\n const { pauseOnHover, autoplay, duration } = props;\n if (pauseOnHover && autoplay) {\n timeout.current = setTimeout(() => moveNext(), duration);\n }\n };\n\n const moveNext = () => {\n const { children, infinite } = props;\n if (!infinite && index === React.Children.count(children) - 1) {\n return;\n }\n transitionSlide((index + 1) % React.Children.count(children));\n };\n\n const moveBack = () => {\n const { children, infinite } = props;\n if (!infinite && index === 0) {\n return;\n }\n transitionSlide(index === 0 ? React.Children.count(children) - 1 : index - 1);\n };\n\n const preTransition: ButtonClick = (event) => {\n const { currentTarget } = event;\n if (currentTarget.dataset.type === 'prev') {\n moveBack();\n } else {\n moveNext();\n }\n };\n\n const transitionSlide = (newIndex: number) => {\n const existingTweens = tweenGroup.current.getAll();\n if (!existingTweens.length) {\n if (!innerWrapperRef.current?.children[newIndex]) {\n newIndex = 0;\n }\n clearTimeout(timeout.current);\n const value = { opacity: 0, scale: 1 };\n\n const animate = () => {\n requestAnimationFrame(animate);\n tweenGroup.current.update();\n };\n\n animate();\n\n const tween = new TWEEN.Tween(value, tweenGroup.current)\n .to({ opacity: 1, scale: props.scale }, props.transitionDuration)\n .onUpdate((value) => {\n if (!innerWrapperRef.current) {\n return;\n }\n innerWrapperRef.current.children[newIndex].style.opacity = value.opacity;\n innerWrapperRef.current.children[index].style.opacity = 1 - value.opacity;\n innerWrapperRef.current.children[\n index\n ].style.transform = `scale(${value.scale})`;\n })\n .start();\n tween.easing(getEasing(props.easing));\n tween.onComplete(() => {\n if (innerWrapperRef.current) {\n setIndex(newIndex);\n innerWrapperRef.current.children[index].style.transform = `scale(1)`;\n }\n if (typeof props.onChange === 'function') {\n props.onChange(index, newIndex);\n }\n });\n }\n };\n\n const moveTo = (gotoIndex: number) => {\n if (gotoIndex !== index) {\n transitionSlide(gotoIndex);\n }\n };\n\n const navigate: ButtonClick = (event) => {\n const { currentTarget } = event;\n if (!currentTarget.dataset.key) {\n return;\n }\n if (parseInt(currentTarget.dataset.key) !== index) {\n moveTo(parseInt(currentTarget.dataset.key));\n }\n };\n\n return (\n <div dir=\"ltr\" aria-roledescription=\"carousel\">\n <div\n className={`react-slideshow-container ${props.cssClass || ''}`}\n onMouseEnter={pauseSlides}\n onMouseOver={pauseSlides}\n onMouseLeave={startSlides}\n >\n {props.arrows && showPreviousArrow(props, index, preTransition)}\n <div\n className={`react-slideshow-fadezoom-wrapper ${props.cssClass}`}\n ref={wrapperRef}\n >\n <div className=\"react-slideshow-fadezoom-images-wrap\" ref={innerWrapperRef}>\n {(React.Children.map(props.children, (thisArg) => thisArg) || []).map(\n (each, key) => (\n <div\n style={{\n opacity: key === index ? '1' : '0',\n zIndex: key === index ? '1' : '0',\n }}\n data-index={key}\n key={key}\n aria-roledescription=\"slide\"\n aria-hidden={key === index ? 'false' : 'true'}\n >\n {each}\n </div>\n )\n )}\n </div>\n </div>\n {props.arrows && showNextArrow(props, index, preTransition)}\n </div>\n {props.indicators && showIndicators(props, index, navigate)}\n </div>\n );\n});\n\nFadeZoom.defaultProps = defaultProps;\n","import React from 'react';\nimport { FadeZoom } from './fadezoom';\nimport { defaultProps } from './props';\nimport { FadeProps, SlideshowRef } from './types';\n\nexport const Fade = React.forwardRef<SlideshowRef, FadeProps>((props, ref) => {\n return <FadeZoom {...props} scale={1} ref={ref} />;\n});\n\nFade.defaultProps = defaultProps;\n","import React from 'react';\nimport { FadeZoom } from './fadezoom';\nimport { defaultProps } from './props';\nimport { SlideshowRef, ZoomProps } from './types';\n\nexport const Zoom = React.forwardRef<SlideshowRef, ZoomProps>((props, ref) => {\n return <FadeZoom {...props} ref={ref} />;\n});\n\nZoom.defaultProps = defaultProps;\n","import React, {\n useState,\n useRef,\n useEffect,\n useMemo,\n useImperativeHandle,\n useCallback,\n} from 'react';\nimport ResizeObserver from 'resize-observer-polyfill';\nimport TWEEN from '@tweenjs/tween.js';\nimport {\n getEasing,\n getResponsiveSettings,\n getStartingIndex,\n showIndicators,\n showNextArrow,\n showPreviousArrow,\n} from './helpers';\nimport { ButtonClick, SlideshowRef, SlideProps } from './types';\nimport { defaultProps } from './props';\n\nexport const Slide = React.forwardRef<SlideshowRef, SlideProps>((props, ref) => {\n const [index, setIndex] = useState(getStartingIndex(props.children, props.defaultIndex));\n const [wrapperWidth, setWrapperWidth] = useState<number>(0);\n const wrapperRef = useRef<HTMLDivElement>(null);\n const innerWrapperRef = useRef<any>(null);\n const tweenGroup = useRef(new TWEEN.Group());\n const responsiveSettings = useMemo(\n () => getResponsiveSettings(wrapperWidth, props.responsive),\n [wrapperWidth, props.responsive]\n );\n const slidesToScroll = useMemo(() => {\n if (responsiveSettings) {\n return responsiveSettings.settings.slidesToScroll;\n }\n return props.slidesToScroll || 1;\n }, [responsiveSettings, props.slidesToScroll]);\n const slidesToShow = useMemo(() => {\n if (responsiveSettings) {\n return responsiveSettings.settings.slidesToShow;\n }\n return props.slidesToShow || 1;\n }, [responsiveSettings, props.slidesToShow]);\n const childrenCount = useMemo(() => React.Children.count(props.children), [props.children]);\n const eachChildWidth = useMemo(() => wrapperWidth / slidesToShow, [wrapperWidth, slidesToShow]);\n const timeout = useRef<NodeJS.Timeout>();\n const resizeObserver = useRef<any>();\n let startingClientX: number;\n let dragging: boolean = false;\n let distanceSwiped: number = 0;\n\n const applyStyle = useCallback(() => {\n if (innerWrapperRef.current) {\n const fullwidth = wrapperWidth * innerWrapperRef.current.children.length;\n innerWrapperRef.current.style.width = `${fullwidth}px`;\n for (let index = 0; index < innerWrapperRef.current.children.length; index++) {\n const eachDiv = innerWrapperRef.current.children[index];\n if (eachDiv) {\n eachDiv.style.width = `${eachChildWidth}px`;\n eachDiv.style.display = `block`;\n }\n }\n }\n }, [wrapperWidth, eachChildWidth]);\n\n const initResizeObserver = useCallback(() => {\n if (wrapperRef.current) {\n resizeObserver.current = new ResizeObserver((entries) => {\n if (!entries) return;\n setWidth();\n });\n resizeObserver.current.observe(wrapperRef.current);\n }\n }, [wrapperRef]);\n\n const play = useCallback(() => {\n const { autoplay, infinite, duration } = props;\n if (autoplay && (infinite || index < childrenCount - 1)) {\n timeout.current = setTimeout(moveNext, duration);\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [props, childrenCount, index]);\n\n useEffect(() => {\n applyStyle();\n }, [wrapperWidth, applyStyle]);\n\n useEffect(() => {\n initResizeObserver();\n return () => {\n tweenGroup.current.removeAll();\n clearTimeout(timeout.current);\n removeResizeObserver();\n };\n }, [wrapperRef, initResizeObserver, tweenGroup]);\n\n useEffect(() => {\n clearTimeout(timeout.current);\n play();\n }, [index, wrapperWidth, props.autoplay, play]);\n\n useImperativeHandle(ref, () => ({\n goNext: () => {\n moveNext();\n },\n goBack: () => {\n moveBack();\n },\n goTo: (index: number, options?: { skipTransition?: boolean }) => {\n if (options?.skipTransition) {\n setIndex(index);\n } else {\n moveTo(index);\n }\n },\n }));\n\n const removeResizeObserver = () => {\n if (resizeObserver && wrapperRef.current) {\n resizeObserver.current.unobserve(wrapperRef.current);\n }\n };\n\n const pauseSlides = () => {\n if (props.pauseOnHover) {\n clearTimeout(timeout.current);\n }\n };\n\n const swipe = (event: React.MouseEvent | React.TouchEvent) => {\n if (props.canSwipe && dragging) {\n let clientX;\n if (window.TouchEvent && event.nativeEvent instanceof TouchEvent) {\n clientX = event.nativeEvent.touches[0].pageX;\n } else if (event.nativeEvent instanceof MouseEvent) {\n clientX = event.nativeEvent.clientX;\n }\n if (clientX && startingClientX) {\n let translateValue = eachChildWidth * (index + getOffset());\n const distance = clientX - startingClientX;\n if (!props.infinite && index === childrenCount - slidesToScroll && distance < 0) {\n // if it is the last and infinite is false and you're swiping left\n // then nothing happens\n return;\n }\n if (!props.infinite && index === 0 && distance > 0) {\n // if it is the first and infinite is false and you're swiping right\n // then nothing happens\n return;\n }\n distanceSwiped = distance;\n translateValue -= distanceSwiped;\n innerWrapperRef.current.style.transform = `translate(-${translateValue}px)`;\n }\n }\n };\n\n const moveNext = () => {\n if (!props.infinite && index === childrenCount - slidesToScroll) {\n return;\n }\n const nextIndex = calculateIndex(index + slidesToScroll);\n transitionSlide(nextIndex);\n };\n\n const moveBack = () => {\n if (!props.infinite && index === 0) {\n return;\n }\n let previousIndex = index - slidesToScroll;\n if (previousIndex % slidesToScroll) {\n previousIndex = Math.ceil(previousIndex / slidesToScroll) * slidesToScroll;\n }\n transitionSlide(previousIndex);\n };\n\n const goToSlide: ButtonClick = ({ currentTarget }) => {\n if (!currentTarget.dataset.key) {\n return;\n }\n const datasetKey = parseInt(currentTarget.dataset.key);\n moveTo(datasetKey * slidesToScroll);\n };\n\n const moveTo = (index: number) => {\n transitionSlide(calculateIndex(index));\n };\n\n const calculateIndex = (nextIndex: number): number => {\n if (nextIndex < childrenCount && nextIndex + slidesToScroll > childrenCount) {\n if ((childrenCount - slidesToScroll) % slidesToScroll) {\n return childrenCount - slidesToScroll;\n }\n return nextIndex;\n }\n return nextIndex;\n };\n\n const startSlides = () => {\n if (dragging) {\n endSwipe();\n } else if (props.pauseOnHover && props.autoplay) {\n timeout.current = setTimeout(moveNext, props.duration);\n }\n };\n\n const moveSlides: ButtonClick = ({ currentTarget: { dataset } }) => {\n if (dataset.type === 'next') {\n moveNext();\n } else {\n moveBack();\n }\n };\n\n const renderPreceedingSlides = () => {\n return React.Children.toArray(props.children)\n .slice(-slidesToShow)\n .map((each, index) => (\n <div\n data-index={index - slidesToShow}\n aria-roledescription=\"slide\"\n aria-hidden=\"true\"\n key={index - slidesToShow}\n >\n {each}\n </div>\n ));\n };\n\n const renderTrailingSlides = () => {\n if (!props.infinite && slidesToShow === slidesToScroll) {\n return;\n }\n return React.Children.toArray(props.children)\n .slice(0, slidesToShow)\n .map((each, index) => (\n <div\n data-index={childrenCount + index}\n aria-roledescription=\"slide\"\n aria-hidden=\"true\"\n key={childrenCount + index}\n >\n {each}\n </div>\n ));\n };\n\n const setWidth = () => {\n if (wrapperRef.current) {\n setWrapperWidth(wrapperRef.current.clientWidth);\n }\n };\n\n const startSwipe = (event: React.MouseEvent | React.TouchEvent) => {\n if (props.canSwipe) {\n if (window.TouchEvent && event.nativeEvent instanceof TouchEvent) {\n startingClientX = event.nativeEvent.touches[0].pageX;\n } else if (event.nativeEvent instanceof MouseEvent) {\n startingClientX = event.nativeEvent.clientX;\n }\n clearTimeout(timeout.current);\n dragging = true;\n }\n };\n\n const endSwipe = () => {\n if (props.canSwipe) {\n dragging = false;\n if (Math.abs(distanceSwiped) / wrapperWidth > 0.2) {\n if (distanceSwiped < 0) {\n moveNext();\n } else {\n moveBack();\n }\n } else {\n if (Math.abs(distanceSwiped) > 0) {\n transitionSlide(index, 300);\n }\n }\n }\n };\n\n const transitionSlide = (toIndex: number, animationDuration?: number) => {\n const transitionDuration = animationDuration || props.transitionDuration;\n const currentIndex = index;\n const existingTweens = tweenGroup.current.getAll();\n if (!wrapperRef.current) {\n return;\n }\n const childWidth = wrapperRef.current.clientWidth / slidesToShow;\n if (!existingTweens.length) {\n clearTimeout(timeout.current);\n const value = {\n margin: -childWidth * (currentIndex + getOffset()) + distanceSwiped,\n };\n const tween = new TWEEN.Tween(value, tweenGroup.current)\n .to({ margin: -childWidth * (toIndex + getOffset()) }, transitionDuration)\n .onUpdate((value) => {\n if (innerWrapperRef.current) {\n innerWrapperRef.current.style.transform = `translate(${value.margin}px)`;\n }\n })\n .start();\n tween.easing(getEasing(props.easing));\n const animate = () => {\n requestAnimationFrame(animate);\n tweenGroup.current.update();\n };\n\n animate();\n\n tween.onComplete(() => {\n distanceSwiped = 0;\n let newIndex = toIndex;\n if (newIndex < 0) {\n newIndex = childrenCount - slidesToScroll;\n } else if (newIndex >= childrenCount) {\n newIndex = 0;\n }\n\n if (typeof props.onChange === 'function') {\n props.onChange(index, newIndex);\n }\n setIndex(newIndex);\n });\n }\n };\n\n const isSlideActive = (key: number) => {\n return key < index + slidesToShow && key >= index;\n };\n\n const getOffset = (): number => {\n if (!props.infinite) {\n return 0;\n }\n return slidesToShow;\n };\n\n const style = {\n transform: `translate(-${(index + getOffset()) * eachChildWidth}px)`,\n };\n return (\n <div dir=\"ltr\" aria-roledescription=\"carousel\">\n <div\n className=\"react-slideshow-container\"\n onMouseEnter={pauseSlides}\n onMouseOver={pauseSlides}\n onMouseLeave={startSlides}\n onMouseDown={startSwipe}\n onMouseUp={endSwipe}\n onMouseMove={swipe}\n onTouchStart={startSwipe}\n onTouchEnd={endSwipe}\n onTouchCancel={endSwipe}\n onTouchMove={swipe}\n >\n {props.arrows && showPreviousArrow(props, index, moveSlides)}\n <div\n className={`react-slideshow-wrapper slide ${props.cssClass || ''}`}\n ref={wrapperRef}\n >\n <div className=\"images-wrap\" style={style} ref={innerWrapperRef}>\n {props.infinite && renderPreceedingSlides()}\n {(React.Children.map(props.children, (thisArg) => thisArg) || []).map(\n (each, key) => {\n const isThisSlideActive = isSlideActive(key);\n return (\n <div\n data-index={key}\n key={key}\n className={isThisSlideActive ? 'active' : ''}\n aria-roledescription=\"slide\"\n aria-hidden={isThisSlideActive ? 'false' : 'true'}\n >\n {each}\n </div>\n );\n }\n )}\n {renderTrailingSlides()}\n </div>\n </div>\n {props.arrows && showNextArrow(props, index, moveSlides)}\n </div>\n {props.indicators && showIndicators(props, index, goToSlide, responsiveSettings)}\n </div>\n );\n});\n\nSlide.defaultProps = defaultProps;\n"],"names":["getStartingIndex","children","defaultIndex","React","Children","count","getResponsiveSettings","wrapperWidth","responsive","window","Array","isArray","find","each","breakpoint","EASING_METHODS","linear","TWEEN","Easing","Linear","None","ease","Quadratic","InOut","In","Out","cubic","Cubic","getEasing","easeMethod","showPreviousArrow","currentIndex","moveSlides","prevArrow","infinite","isDisabled","props","disabled","onClick","cloneElement","className","type","width","height","viewBox","d","showNextArrow","properties","nextArrow","slidesToScroll","showDefaultIndicator","isCurrentPageActive","key","indicatorProps","showCustomIndicator","eachIndicator","showIndicators","navigate","responsiveSettings","indicators","settings","pages","Math","ceil","from","length","_","floor","defaultProps","duration","transitionDuration","autoplay","arrows","pauseOnHover","easing","canSwipe","cssClass","FadeZoom","forwardRef","ref","useState","index","setIndex","wrapperRef","useRef","innerWrapperRef","tweenGroup","Group","timeout","resizeObserver","childrenCount","useMemo","applyStyle","useCallback","current","clientWidth","fullwidth","style","eachDiv","left","display","initResizeObserver","ResizeObserver","entries","observe","play","setTimeout","moveNext","useEffect","removeAll","clearTimeout","removeResizeObserver","useImperativeHandle","goNext","goBack","moveBack","goTo","options","skipTransition","moveTo","unobserve","pauseSlides","startSlides","transitionSlide","preTransition","event","currentTarget","dataset","newIndex","existingTweens","getAll","value","opacity","scale","animate","requestAnimationFrame","update","tween","Tween","to","onUpdate","transform","start","onComplete","onChange","gotoIndex","parseInt","dir","onMouseEnter","onMouseOver","onMouseLeave","map","thisArg","zIndex","Fade","Zoom","Slide","setWrapperWidth","slidesToShow","eachChildWidth","startingClientX","dragging","distanceSwiped","setWidth","swipe","clientX","TouchEvent","nativeEvent","touches","pageX","MouseEvent","translateValue","getOffset","distance","nextIndex","calculateIndex","previousIndex","goToSlide","datasetKey","endSwipe","renderPreceedingSlides","toArray","slice","renderTrailingSlides","startSwipe","abs","toIndex","animationDuration","childWidth","margin","isSlideActive","onMouseDown","onMouseUp","onMouseMove","onTouchStart","onTouchEnd","onTouchCancel","onTouchMove","isThisSlideActive"],"mappings":"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"}
@@ -1,2 +1,2 @@
1
- "use strict";function e(e){return e&&"object"==typeof e&&"default"in e?e.default:e}Object.defineProperty(exports,"__esModule",{value:!0});var n=require("react"),t=e(n),r=e(require("resize-observer-polyfill")),i=e(require("@tweenjs/tween.js"));function a(){return(a=Object.assign?Object.assign.bind():function(e){for(var n=1;n<arguments.length;n++){var t=arguments[n];for(var r in t)Object.prototype.hasOwnProperty.call(t,r)&&(e[r]=t[r])}return e}).apply(this,arguments)}var c=function(e,n){return n&&n<t.Children.count(e)?n:0},o={linear:i.Easing.Linear.None,ease:i.Easing.Quadratic.InOut,"ease-in":i.Easing.Quadratic.In,"ease-out":i.Easing.Quadratic.Out,cubic:i.Easing.Cubic.InOut,"cubic-in":i.Easing.Cubic.In,"cubic-out":i.Easing.Cubic.Out},u=function(e){return e?o[e]:o.linear},s=function(e,n,r){var i=e.prevArrow,c=n<=0&&!e.infinite,o={"data-type":"prev","aria-label":"Previous Slide",disabled:c,onClick:r};return i?t.cloneElement(i,a({className:(i.props.className||"")+" nav "+(c?"disabled":"")},o)):t.createElement("button",Object.assign({type:"button",className:"nav default-nav "+(c?"disabled":"")},o),t.createElement("svg",{width:"24",height:"24",viewBox:"0 0 24 24"},t.createElement("path",{d:"M16.67 0l2.83 2.829-9.339 9.175 9.339 9.167-2.83 2.829-12.17-11.996z"})))},l=function(e,n,r){var i=e.nextArrow,c=e.infinite,o=1;"slidesToScroll"in e&&(o=e.slidesToScroll||1);var u=n>=t.Children.count(e.children)-o&&!c,s={"data-type":"next","aria-label":"Next Slide",disabled:u,onClick:r};return i?t.cloneElement(i,a({className:(i.props.className||"")+" nav "+(u?"disabled":"")},s)):t.createElement("button",Object.assign({type:"button",className:"nav default-nav "+(u?"disabled":"")},s),t.createElement("svg",{width:"24",height:"24",viewBox:"0 0 24 24"},t.createElement("path",{d:"M5 3l3.057-3 11.943 12-11.943 12-3.057-3 9-9z"})))},f=function(e,n,r,i){var c=e.indicators,o=1;i?o=null==i?void 0:i.settings.slidesToScroll:"slidesToScroll"in e&&(o=e.slidesToScroll||1);var u=Math.ceil(t.Children.count(e.children)/o);return t.createElement("ul",{className:"indicators"},Array.from({length:u},(function(e,i){var u={"data-key":i,"aria-label":"Go to slide "+(i+1),onClick:r},s=Math.floor((n+o-1)/o)===i;return"function"==typeof c?function(e,n,r,i){return t.cloneElement(i,a({className:i.props.className+" "+(e?"active":""),key:n},r))}(s,i,u,c(i)):function(e,n,r){return t.createElement("li",{key:n},t.createElement("button",Object.assign({type:"button",className:"each-slideshow-indicator "+(e?"active":"")},r)))}(s,i,u)})))},d={duration:5e3,transitionDuration:1e3,defaultIndex:0,infinite:!0,autoplay:!0,indicators:!1,arrows:!0,pauseOnHover:!0,easing:"linear",canSwipe:!0,cssClass:"",responsive:[]},v=t.forwardRef((function(e,a){var o=n.useState(c(e.children,e.defaultIndex)),d=o[0],v=o[1],p=n.useRef(null),h=n.useRef(null),m=n.useRef(new i.Group),y=n.useRef(),g=n.useRef(),E=n.useMemo((function(){return t.Children.count(e.children)}),[e.children]),w=n.useCallback((function(){if(h.current&&p.current){var e=p.current.clientWidth;h.current.style.width=e*E+"px";for(var n=0;n<h.current.children.length;n++){var t=h.current.children[n];t&&(t.style.width=e+"px",t.style.left=n*-e+"px",t.style.display="block")}}}),[p,h,E]),b=n.useCallback((function(){p.current&&(g.current=new r((function(e){e&&w()})),g.current.observe(p.current))}),[p,w]),T=n.useCallback((function(){var n=e.children,r=e.duration,i=e.infinite;e.autoplay&&t.Children.count(n)>1&&(i||d<t.Children.count(n)-1)&&(y.current=setTimeout(M,r))}),[e,d]);n.useEffect((function(){return b(),function(){m.current.removeAll(),clearTimeout(y.current),C()}}),[b,m]),n.useEffect((function(){clearTimeout(y.current),T()}),[d,e.autoplay,T]),n.useEffect((function(){w()}),[E,w]),n.useImperativeHandle(a,(function(){return{goNext:function(){M()},goBack:function(){k()},goTo:function(e){O(e)}}}));var C=function(){g.current&&p.current&&g.current.unobserve(p.current)},x=function(){e.pauseOnHover&&clearTimeout(y.current)},M=function(){var n=e.children;(e.infinite||d!==t.Children.count(n)-1)&&N((d+1)%t.Children.count(n))},k=function(){(e.infinite||0!==d)&&N(0===d?t.Children.count(e.children)-1:d-1)},S=function(e){"prev"===e.currentTarget.dataset.type?k():M()},N=function(n){if(!m.current.getAll().length){var t;null!=(t=h.current)&&t.children[n]||(n=0),clearTimeout(y.current),function e(){requestAnimationFrame(e),m.current.update()}();var r=new i.Tween({opacity:0,scale:1},m.current).to({opacity:1,scale:e.scale},e.transitionDuration).onUpdate((function(e){h.current&&(h.current.children[n].style.opacity=e.opacity,h.current.children[d].style.opacity=1-e.opacity,h.current.children[d].style.transform="scale("+e.scale+")")})).start();r.easing(u(e.easing)),r.onComplete((function(){h.current&&(v(n),h.current.children[d].style.transform="scale(1)"),"function"==typeof e.onChange&&e.onChange(d,n)}))}},O=function(e){N(e)};return t.createElement("div",{dir:"ltr","aria-roledescription":"carousel"},t.createElement("div",{className:"react-slideshow-container "+(e.cssClass||""),onMouseEnter:x,onMouseOver:x,onMouseLeave:function(){e.pauseOnHover&&e.autoplay&&(y.current=setTimeout((function(){return M()}),e.duration))},ref:e.ref},e.arrows&&s(e,d,S),t.createElement("div",{className:"react-slideshow-fadezoom-wrapper "+e.cssClass,ref:p},t.createElement("div",{className:"react-slideshow-fadezoom-images-wrap",ref:h},(t.Children.map(e.children,(function(e){return e}))||[]).map((function(e,n){return t.createElement("div",{style:{opacity:n===d?"1":"0",zIndex:n===d?"1":"0"},"data-index":n,key:n,"aria-roledescription":"slide","aria-hidden":n===d?"false":"true"},e)})))),e.arrows&&l(e,d,S)),e.indicators&&f(e,d,(function(e){var n=e.currentTarget;n.dataset.key&&parseInt(n.dataset.key)!==d&&O(parseInt(n.dataset.key))})))}));v.defaultProps=d;var p=t.forwardRef((function(e,n){return t.createElement(v,Object.assign({},e,{scale:1,ref:n}))}));p.defaultProps=d;var h=t.forwardRef((function(e,n){return t.createElement(v,Object.assign({},e,{ref:n}))}));h.defaultProps=d;var m=t.forwardRef((function(e,a){var o,d=n.useState(c(e.children,e.defaultIndex)),v=d[0],p=d[1],h=n.useState(0),m=h[0],y=h[1],g=n.useRef(null),E=n.useRef(null),w=n.useRef(new i.Group),b=n.useMemo((function(){return function(e,n){if("undefined"!=typeof window&&Array.isArray(n))return n.find((function(n){return n.breakpoint<=e}))}(m,e.responsive)}),[m,e.responsive]),T=n.useMemo((function(){return b?b.settings.slidesToScroll:e.slidesToScroll||1}),[b,e.slidesToScroll]),C=n.useMemo((function(){return b?b.settings.slidesToShow:e.slidesToShow||1}),[b,e.slidesToShow]),x=n.useMemo((function(){return t.Children.count(e.children)}),[e.children]),M=n.useMemo((function(){return m/C}),[m,C]),k=n.useRef(),S=n.useRef(),N=!1,O=0,R=n.useCallback((function(){if(E.current){E.current.style.width=m*E.current.children.length+"px";for(var e=0;e<E.current.children.length;e++){var n=E.current.children[e];n&&(n.style.width=M+"px",n.style.display="block")}}}),[m,M]),A=n.useCallback((function(){g.current&&(S.current=new r((function(e){e&&F()})),S.current.observe(g.current))}),[g]),I=n.useCallback((function(){e.autoplay&&(e.infinite||v<x-1)&&(k.current=setTimeout(z,e.duration))}),[e,x,v]);n.useEffect((function(){R()}),[m,R]),n.useEffect((function(){return A(),function(){w.current.removeAll(),clearTimeout(k.current),j()}}),[g,A,w]),n.useEffect((function(){clearTimeout(k.current),I()}),[v,m,e.autoplay,I]),n.useImperativeHandle(a,(function(){return{goNext:function(){z()},goBack:function(){q()},goTo:function(e){B(e)}}}));var j=function(){S&&g.current&&S.current.unobserve(g.current)},H=function(){e.pauseOnHover&&clearTimeout(k.current)},P=function(n){var t;if(e.canSwipe&&N&&(window.TouchEvent&&n.nativeEvent instanceof TouchEvent?t=n.nativeEvent.touches[0].pageX:n.nativeEvent instanceof MouseEvent&&(t=n.nativeEvent.clientX),t&&o)){var r=M*(v+U()),i=t-o;if(!e.infinite&&v===x-T&&i<0)return;if(!e.infinite&&0===v&&i>0)return;E.current.style.transform="translate(-"+(r-=O=i)+"px)"}},z=function(){if(e.infinite||v!==x-T){var n=D(v+T);Q(n)}},q=function(){if(e.infinite||0!==v){var n=v-T;n%T&&(n=Math.ceil(n/T)*T),Q(n)}},B=function(e){Q(D(e))},D=function(e){return e<x&&e+T>x&&(x-T)%T?x-T:e},X=function(e){"next"===e.currentTarget.dataset.type?z():q()},F=function(){g.current&&y(g.current.clientWidth)},G=function(n){e.canSwipe&&(window.TouchEvent&&n.nativeEvent instanceof TouchEvent?o=n.nativeEvent.touches[0].pageX:n.nativeEvent instanceof MouseEvent&&(o=n.nativeEvent.clientX),clearTimeout(k.current),N=!0)},L=function(){e.canSwipe&&(N=!1,Math.abs(O)/m>.2?O<0?z():q():Math.abs(O)>0&&Q(v,300))},Q=function(n,t){var r=t||e.transitionDuration,a=v,c=w.current.getAll();if(g.current){var o=g.current.clientWidth/C;if(!c.length){clearTimeout(k.current);var s={margin:-o*(a+U())+O},l=new i.Tween(s,w.current).to({margin:-o*(n+U())},r).onUpdate((function(e){E.current&&(E.current.style.transform="translate("+e.margin+"px)")})).start();l.easing(u(e.easing)),function e(){requestAnimationFrame(e),w.current.update()}(),l.onComplete((function(){O=0;var t=n;t<0?t=x-T:t>=x&&(t=0),"function"==typeof e.onChange&&e.onChange(v,t),p(t)}))}}},U=function(){return e.infinite?C:0},W={transform:"translate(-"+(v+U())*M+"px)"};return t.createElement("div",{dir:"ltr","aria-roledescription":"carousel"},t.createElement("div",{className:"react-slideshow-container",onMouseEnter:H,onMouseOver:H,onMouseLeave:function(){N?L():e.pauseOnHover&&e.autoplay&&(k.current=setTimeout(z,e.duration))},onMouseDown:G,onMouseUp:L,onMouseMove:P,onTouchStart:G,onTouchEnd:L,onTouchCancel:L,onTouchMove:P},e.arrows&&s(e,v,X),t.createElement("div",{className:"react-slideshow-wrapper slide "+(e.cssClass||""),ref:g},t.createElement("div",{className:"images-wrap",style:W,ref:E},e.infinite&&t.Children.toArray(e.children).slice(-C).map((function(e,n){return t.createElement("div",{"data-index":n-C,"aria-roledescription":"slide","aria-hidden":"true",key:n-C},e)})),(t.Children.map(e.children,(function(e){return e}))||[]).map((function(e,n){var r=function(e){return e<v+C&&e>=v}(n);return t.createElement("div",{"data-index":n,key:n,className:r?"active":"","aria-roledescription":"slide","aria-hidden":r?"false":"true"},e)})),function(){if(e.infinite||C!==T)return t.Children.toArray(e.children).slice(0,C).map((function(e,n){return t.createElement("div",{"data-index":x+n,"aria-roledescription":"slide","aria-hidden":"true",key:x+n},e)}))}())),e.arrows&&l(e,v,X)),e.indicators&&f(e,v,(function(e){var n=e.currentTarget;if(n.dataset.key){var t=parseInt(n.dataset.key);B(t*T)}}),b))}));m.defaultProps=d,exports.Fade=p,exports.Slide=m,exports.Zoom=h;
1
+ "use strict";function e(e){return e&&"object"==typeof e&&"default"in e?e.default:e}Object.defineProperty(exports,"__esModule",{value:!0});var n=require("react"),t=e(n),r=e(require("resize-observer-polyfill")),i=e(require("@tweenjs/tween.js"));function a(){return(a=Object.assign?Object.assign.bind():function(e){for(var n=1;n<arguments.length;n++){var t=arguments[n];for(var r in t)Object.prototype.hasOwnProperty.call(t,r)&&(e[r]=t[r])}return e}).apply(this,arguments)}var c=function(e,n){return n&&n<t.Children.count(e)?n:0},o={linear:i.Easing.Linear.None,ease:i.Easing.Quadratic.InOut,"ease-in":i.Easing.Quadratic.In,"ease-out":i.Easing.Quadratic.Out,cubic:i.Easing.Cubic.InOut,"cubic-in":i.Easing.Cubic.In,"cubic-out":i.Easing.Cubic.Out},u=function(e){return e?o[e]:o.linear},s=function(e,n,r){var i=e.prevArrow,c=n<=0&&!e.infinite,o={"data-type":"prev","aria-label":"Previous Slide",disabled:c,onClick:r};return i?t.cloneElement(i,a({className:(i.props.className||"")+" nav "+(c?"disabled":"")},o)):t.createElement("button",Object.assign({type:"button",className:"nav default-nav "+(c?"disabled":"")},o),t.createElement("svg",{width:"24",height:"24",viewBox:"0 0 24 24"},t.createElement("path",{d:"M16.67 0l2.83 2.829-9.339 9.175 9.339 9.167-2.83 2.829-12.17-11.996z"})))},l=function(e,n,r){var i=e.nextArrow,c=e.infinite,o=1;"slidesToScroll"in e&&(o=e.slidesToScroll||1);var u=n>=t.Children.count(e.children)-o&&!c,s={"data-type":"next","aria-label":"Next Slide",disabled:u,onClick:r};return i?t.cloneElement(i,a({className:(i.props.className||"")+" nav "+(u?"disabled":"")},s)):t.createElement("button",Object.assign({type:"button",className:"nav default-nav "+(u?"disabled":"")},s),t.createElement("svg",{width:"24",height:"24",viewBox:"0 0 24 24"},t.createElement("path",{d:"M5 3l3.057-3 11.943 12-11.943 12-3.057-3 9-9z"})))},f=function(e,n,r,i){var c=e.indicators,o=1;i?o=null==i?void 0:i.settings.slidesToScroll:"slidesToScroll"in e&&(o=e.slidesToScroll||1);var u=Math.ceil(t.Children.count(e.children)/o);return t.createElement("ul",{className:"indicators"},Array.from({length:u},(function(e,i){var u={"data-key":i,"aria-label":"Go to slide "+(i+1),onClick:r},s=Math.floor((n+o-1)/o)===i;return"function"==typeof c?function(e,n,r,i){return t.cloneElement(i,a({className:i.props.className+" "+(e?"active":""),key:n},r))}(s,i,u,c(i)):function(e,n,r){return t.createElement("li",{key:n},t.createElement("button",Object.assign({type:"button",className:"each-slideshow-indicator "+(e?"active":"")},r)))}(s,i,u)})))},d={duration:5e3,transitionDuration:1e3,defaultIndex:0,infinite:!0,autoplay:!0,indicators:!1,arrows:!0,pauseOnHover:!0,easing:"linear",canSwipe:!0,cssClass:"",responsive:[]},v=t.forwardRef((function(e,a){var o=n.useState(c(e.children,e.defaultIndex)),d=o[0],v=o[1],p=n.useRef(null),h=n.useRef(null),m=n.useRef(new i.Group),y=n.useRef(),g=n.useRef(),E=n.useMemo((function(){return t.Children.count(e.children)}),[e.children]),w=n.useCallback((function(){if(h.current&&p.current){var e=p.current.clientWidth;h.current.style.width=e*E+"px";for(var n=0;n<h.current.children.length;n++){var t=h.current.children[n];t&&(t.style.width=e+"px",t.style.left=n*-e+"px",t.style.display="block")}}}),[p,h,E]),b=n.useCallback((function(){p.current&&(g.current=new r((function(e){e&&w()})),g.current.observe(p.current))}),[p,w]),T=n.useCallback((function(){var n=e.children,r=e.duration,i=e.infinite;e.autoplay&&t.Children.count(n)>1&&(i||d<t.Children.count(n)-1)&&(y.current=setTimeout(x,r))}),[e,d]);n.useEffect((function(){return b(),function(){m.current.removeAll(),clearTimeout(y.current),C()}}),[b,m]),n.useEffect((function(){clearTimeout(y.current),T()}),[d,e.autoplay,T]),n.useEffect((function(){w()}),[E,w]),n.useImperativeHandle(a,(function(){return{goNext:function(){x()},goBack:function(){M()},goTo:function(e,n){null!=n&&n.skipTransition?v(e):O(e)}}}));var C=function(){g.current&&p.current&&g.current.unobserve(p.current)},k=function(){e.pauseOnHover&&clearTimeout(y.current)},x=function(){var n=e.children;(e.infinite||d!==t.Children.count(n)-1)&&N((d+1)%t.Children.count(n))},M=function(){(e.infinite||0!==d)&&N(0===d?t.Children.count(e.children)-1:d-1)},S=function(e){"prev"===e.currentTarget.dataset.type?M():x()},N=function(n){if(!m.current.getAll().length){var t;null!=(t=h.current)&&t.children[n]||(n=0),clearTimeout(y.current),function e(){requestAnimationFrame(e),m.current.update()}();var r=new i.Tween({opacity:0,scale:1},m.current).to({opacity:1,scale:e.scale},e.transitionDuration).onUpdate((function(e){h.current&&(h.current.children[n].style.opacity=e.opacity,h.current.children[d].style.opacity=1-e.opacity,h.current.children[d].style.transform="scale("+e.scale+")")})).start();r.easing(u(e.easing)),r.onComplete((function(){h.current&&(v(n),h.current.children[d].style.transform="scale(1)"),"function"==typeof e.onChange&&e.onChange(d,n)}))}},O=function(e){e!==d&&N(e)};return t.createElement("div",{dir:"ltr","aria-roledescription":"carousel"},t.createElement("div",{className:"react-slideshow-container "+(e.cssClass||""),onMouseEnter:k,onMouseOver:k,onMouseLeave:function(){e.pauseOnHover&&e.autoplay&&(y.current=setTimeout((function(){return x()}),e.duration))}},e.arrows&&s(e,d,S),t.createElement("div",{className:"react-slideshow-fadezoom-wrapper "+e.cssClass,ref:p},t.createElement("div",{className:"react-slideshow-fadezoom-images-wrap",ref:h},(t.Children.map(e.children,(function(e){return e}))||[]).map((function(e,n){return t.createElement("div",{style:{opacity:n===d?"1":"0",zIndex:n===d?"1":"0"},"data-index":n,key:n,"aria-roledescription":"slide","aria-hidden":n===d?"false":"true"},e)})))),e.arrows&&l(e,d,S)),e.indicators&&f(e,d,(function(e){var n=e.currentTarget;n.dataset.key&&parseInt(n.dataset.key)!==d&&O(parseInt(n.dataset.key))})))}));v.defaultProps=d;var p=t.forwardRef((function(e,n){return t.createElement(v,Object.assign({},e,{scale:1,ref:n}))}));p.defaultProps=d;var h=t.forwardRef((function(e,n){return t.createElement(v,Object.assign({},e,{ref:n}))}));h.defaultProps=d;var m=t.forwardRef((function(e,a){var o,d=n.useState(c(e.children,e.defaultIndex)),v=d[0],p=d[1],h=n.useState(0),m=h[0],y=h[1],g=n.useRef(null),E=n.useRef(null),w=n.useRef(new i.Group),b=n.useMemo((function(){return function(e,n){if("undefined"!=typeof window&&Array.isArray(n))return n.find((function(n){return n.breakpoint<=e}))}(m,e.responsive)}),[m,e.responsive]),T=n.useMemo((function(){return b?b.settings.slidesToScroll:e.slidesToScroll||1}),[b,e.slidesToScroll]),C=n.useMemo((function(){return b?b.settings.slidesToShow:e.slidesToShow||1}),[b,e.slidesToShow]),k=n.useMemo((function(){return t.Children.count(e.children)}),[e.children]),x=n.useMemo((function(){return m/C}),[m,C]),M=n.useRef(),S=n.useRef(),N=!1,O=0,R=n.useCallback((function(){if(E.current){E.current.style.width=m*E.current.children.length+"px";for(var e=0;e<E.current.children.length;e++){var n=E.current.children[e];n&&(n.style.width=x+"px",n.style.display="block")}}}),[m,x]),A=n.useCallback((function(){g.current&&(S.current=new r((function(e){e&&F()})),S.current.observe(g.current))}),[g]),I=n.useCallback((function(){e.autoplay&&(e.infinite||v<k-1)&&(M.current=setTimeout(z,e.duration))}),[e,k,v]);n.useEffect((function(){R()}),[m,R]),n.useEffect((function(){return A(),function(){w.current.removeAll(),clearTimeout(M.current),j()}}),[g,A,w]),n.useEffect((function(){clearTimeout(M.current),I()}),[v,m,e.autoplay,I]),n.useImperativeHandle(a,(function(){return{goNext:function(){z()},goBack:function(){q()},goTo:function(e,n){null!=n&&n.skipTransition?p(e):B(e)}}}));var j=function(){S&&g.current&&S.current.unobserve(g.current)},H=function(){e.pauseOnHover&&clearTimeout(M.current)},P=function(n){var t;if(e.canSwipe&&N&&(window.TouchEvent&&n.nativeEvent instanceof TouchEvent?t=n.nativeEvent.touches[0].pageX:n.nativeEvent instanceof MouseEvent&&(t=n.nativeEvent.clientX),t&&o)){var r=x*(v+U()),i=t-o;if(!e.infinite&&v===k-T&&i<0)return;if(!e.infinite&&0===v&&i>0)return;E.current.style.transform="translate(-"+(r-=O=i)+"px)"}},z=function(){if(e.infinite||v!==k-T){var n=D(v+T);Q(n)}},q=function(){if(e.infinite||0!==v){var n=v-T;n%T&&(n=Math.ceil(n/T)*T),Q(n)}},B=function(e){Q(D(e))},D=function(e){return e<k&&e+T>k&&(k-T)%T?k-T:e},X=function(e){"next"===e.currentTarget.dataset.type?z():q()},F=function(){g.current&&y(g.current.clientWidth)},G=function(n){e.canSwipe&&(window.TouchEvent&&n.nativeEvent instanceof TouchEvent?o=n.nativeEvent.touches[0].pageX:n.nativeEvent instanceof MouseEvent&&(o=n.nativeEvent.clientX),clearTimeout(M.current),N=!0)},L=function(){e.canSwipe&&(N=!1,Math.abs(O)/m>.2?O<0?z():q():Math.abs(O)>0&&Q(v,300))},Q=function(n,t){var r=t||e.transitionDuration,a=v,c=w.current.getAll();if(g.current){var o=g.current.clientWidth/C;if(!c.length){clearTimeout(M.current);var s={margin:-o*(a+U())+O},l=new i.Tween(s,w.current).to({margin:-o*(n+U())},r).onUpdate((function(e){E.current&&(E.current.style.transform="translate("+e.margin+"px)")})).start();l.easing(u(e.easing)),function e(){requestAnimationFrame(e),w.current.update()}(),l.onComplete((function(){O=0;var t=n;t<0?t=k-T:t>=k&&(t=0),"function"==typeof e.onChange&&e.onChange(v,t),p(t)}))}}},U=function(){return e.infinite?C:0},W={transform:"translate(-"+(v+U())*x+"px)"};return t.createElement("div",{dir:"ltr","aria-roledescription":"carousel"},t.createElement("div",{className:"react-slideshow-container",onMouseEnter:H,onMouseOver:H,onMouseLeave:function(){N?L():e.pauseOnHover&&e.autoplay&&(M.current=setTimeout(z,e.duration))},onMouseDown:G,onMouseUp:L,onMouseMove:P,onTouchStart:G,onTouchEnd:L,onTouchCancel:L,onTouchMove:P},e.arrows&&s(e,v,X),t.createElement("div",{className:"react-slideshow-wrapper slide "+(e.cssClass||""),ref:g},t.createElement("div",{className:"images-wrap",style:W,ref:E},e.infinite&&t.Children.toArray(e.children).slice(-C).map((function(e,n){return t.createElement("div",{"data-index":n-C,"aria-roledescription":"slide","aria-hidden":"true",key:n-C},e)})),(t.Children.map(e.children,(function(e){return e}))||[]).map((function(e,n){var r=function(e){return e<v+C&&e>=v}(n);return t.createElement("div",{"data-index":n,key:n,className:r?"active":"","aria-roledescription":"slide","aria-hidden":r?"false":"true"},e)})),function(){if(e.infinite||C!==T)return t.Children.toArray(e.children).slice(0,C).map((function(e,n){return t.createElement("div",{"data-index":k+n,"aria-roledescription":"slide","aria-hidden":"true",key:k+n},e)}))}())),e.arrows&&l(e,v,X)),e.indicators&&f(e,v,(function(e){var n=e.currentTarget;if(n.dataset.key){var t=parseInt(n.dataset.key);B(t*T)}}),b))}));m.defaultProps=d,exports.Fade=p,exports.Slide=m,exports.Zoom=h;
2
2
  //# sourceMappingURL=react-slideshow-image.cjs.production.min.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"react-slideshow-image.cjs.production.min.js","sources":["../src/helpers.tsx","../src/props.ts","../src/fadezoom.tsx","../src/fade.tsx","../src/zoom.tsx","../src/slide.tsx"],"sourcesContent":["import React, { ReactNode } from 'react';\nimport {\n ButtonClick,\n FadeProps,\n IndicatorPropsType,\n Responsive,\n SlideProps,\n TweenEasingFn,\n ZoomProps,\n} from './types';\nimport TWEEN from '@tweenjs/tween.js';\n\nexport const getStartingIndex = (children: ReactNode, defaultIndex?: number): number => {\n if (defaultIndex && defaultIndex < React.Children.count(children)) {\n return defaultIndex;\n }\n return 0;\n};\n\nexport const getResponsiveSettings = (\n wrapperWidth: number,\n responsive?: Array<Responsive>\n): Responsive | undefined => {\n if (typeof window !== 'undefined' && Array.isArray(responsive)) {\n return responsive.find((each) => each.breakpoint <= wrapperWidth);\n }\n return;\n};\n\nconst EASING_METHODS: { [key: string]: TweenEasingFn } = {\n linear: TWEEN.Easing.Linear.None,\n ease: TWEEN.Easing.Quadratic.InOut,\n 'ease-in': TWEEN.Easing.Quadratic.In,\n 'ease-out': TWEEN.Easing.Quadratic.Out,\n cubic: TWEEN.Easing.Cubic.InOut,\n 'cubic-in': TWEEN.Easing.Cubic.In,\n 'cubic-out': TWEEN.Easing.Cubic.Out,\n};\n\nexport const getEasing = (easeMethod?: string): TweenEasingFn => {\n if (easeMethod) {\n return EASING_METHODS[easeMethod];\n }\n return EASING_METHODS.linear;\n};\n\nexport const showPreviousArrow = (\n { prevArrow, infinite }: FadeProps | SlideProps | ZoomProps,\n currentIndex: number,\n moveSlides: ButtonClick\n): ReactNode => {\n const isDisabled = currentIndex <= 0 && !infinite;\n const props = {\n 'data-type': 'prev',\n 'aria-label': 'Previous Slide',\n disabled: isDisabled,\n onClick: moveSlides,\n };\n if (prevArrow) {\n return React.cloneElement(prevArrow, {\n className: `${prevArrow.props.className || ''} nav ${isDisabled ? 'disabled' : ''}`,\n ...props,\n });\n }\n const className = `nav default-nav ${isDisabled ? 'disabled' : ''}`;\n return (\n <button type=\"button\" className={className} {...props}>\n <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\">\n <path d=\"M16.67 0l2.83 2.829-9.339 9.175 9.339 9.167-2.83 2.829-12.17-11.996z\" />\n </svg>\n </button>\n );\n};\n\nexport const showNextArrow = (\n properties: FadeProps | SlideProps | ZoomProps,\n currentIndex: number,\n moveSlides: ButtonClick\n) => {\n const { nextArrow, infinite, children } = properties;\n let slidesToScroll = 1;\n if ('slidesToScroll' in properties) {\n slidesToScroll = properties.slidesToScroll || 1;\n }\n const isDisabled = currentIndex >= React.Children.count(children) - slidesToScroll && !infinite;\n const props = {\n 'data-type': 'next',\n 'aria-label': 'Next Slide',\n disabled: isDisabled,\n onClick: moveSlides,\n };\n if (nextArrow) {\n return React.cloneElement(nextArrow, {\n className: `${nextArrow.props.className || ''} nav ${isDisabled ? 'disabled' : ''}`,\n ...props,\n });\n }\n const className = `nav default-nav ${isDisabled ? 'disabled' : ''}`;\n return (\n <button type=\"button\" className={className} {...props}>\n <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\">\n <path d=\"M5 3l3.057-3 11.943 12-11.943 12-3.057-3 9-9z\" />\n </svg>\n </button>\n );\n};\n\nconst showDefaultIndicator = (\n isCurrentPageActive: boolean,\n key: number,\n indicatorProps: IndicatorPropsType\n) => {\n return (\n <li key={key}>\n <button\n type=\"button\"\n className={`each-slideshow-indicator ${isCurrentPageActive ? 'active' : ''}`}\n {...indicatorProps}\n />\n </li>\n );\n};\n\nconst showCustomIndicator = (\n isCurrentPageActive: boolean,\n key: number,\n indicatorProps: any,\n eachIndicator: any\n) => {\n return React.cloneElement(eachIndicator, {\n className: `${eachIndicator.props.className} ${isCurrentPageActive ? 'active' : ''}`,\n key,\n ...indicatorProps,\n });\n};\n\nexport const showIndicators = (\n props: FadeProps | SlideProps | ZoomProps,\n currentIndex: number,\n navigate: ButtonClick,\n responsiveSettings?: Responsive\n): ReactNode => {\n const { children, indicators } = props;\n let slidesToScroll = 1;\n if (responsiveSettings) {\n slidesToScroll = responsiveSettings?.settings.slidesToScroll;\n } else if ('slidesToScroll' in props) {\n slidesToScroll = props.slidesToScroll || 1;\n }\n const pages = Math.ceil(React.Children.count(children) / slidesToScroll);\n return (\n <ul className=\"indicators\">\n {Array.from({ length: pages }, (_, key) => {\n const indicatorProps: IndicatorPropsType = {\n 'data-key': key,\n 'aria-label': `Go to slide ${key + 1}`,\n onClick: navigate,\n };\n const isCurrentPageActive =\n Math.floor((currentIndex + slidesToScroll - 1) / slidesToScroll) === key;\n if (typeof indicators === 'function') {\n return showCustomIndicator(\n isCurrentPageActive,\n key,\n indicatorProps,\n indicators(key)\n );\n }\n return showDefaultIndicator(isCurrentPageActive, key, indicatorProps);\n })}\n </ul>\n );\n};\n","export const defaultProps = {\n duration: 5000,\n transitionDuration: 1000,\n defaultIndex: 0,\n infinite: true,\n autoplay: true,\n indicators: false,\n arrows: true,\n pauseOnHover: true,\n easing: 'linear',\n canSwipe: true,\n cssClass: '',\n responsive: [],\n};\n","import React, {\n useState,\n useRef,\n useEffect,\n useMemo,\n useImperativeHandle,\n useCallback,\n} from 'react';\nimport ResizeObserver from 'resize-observer-polyfill';\nimport TWEEN from '@tweenjs/tween.js';\nimport {\n getEasing,\n getStartingIndex,\n showIndicators,\n showNextArrow,\n showPreviousArrow,\n} from './helpers';\nimport { ButtonClick, SlideshowRef, ZoomProps } from './types';\nimport { defaultProps } from './props';\n\nexport const FadeZoom = React.forwardRef<SlideshowRef, ZoomProps>((props, ref) => {\n const [index, setIndex] = useState<number>(\n getStartingIndex(props.children, props.defaultIndex)\n );\n const wrapperRef = useRef<HTMLDivElement>(null);\n const innerWrapperRef = useRef<any>(null);\n const tweenGroup = useRef(new TWEEN.Group());\n const timeout = useRef<NodeJS.Timeout>();\n const resizeObserver = useRef<any>();\n const childrenCount = useMemo(() => React.Children.count(props.children), [props.children]);\n\n const applyStyle = useCallback(() => {\n if (innerWrapperRef.current && wrapperRef.current) {\n const wrapperWidth = wrapperRef.current.clientWidth;\n const fullwidth = wrapperWidth * childrenCount;\n innerWrapperRef.current.style.width = `${fullwidth}px`;\n for (let index = 0; index < innerWrapperRef.current.children.length; index++) {\n const eachDiv = innerWrapperRef.current.children[index];\n if (eachDiv) {\n eachDiv.style.width = `${wrapperWidth}px`;\n eachDiv.style.left = `${index * -wrapperWidth}px`;\n eachDiv.style.display = `block`;\n }\n }\n }\n }, [wrapperRef, innerWrapperRef, childrenCount]);\n\n const initResizeObserver = useCallback(() => {\n if (wrapperRef.current) {\n resizeObserver.current = new ResizeObserver((entries) => {\n if (!entries) return;\n applyStyle();\n });\n resizeObserver.current.observe(wrapperRef.current);\n }\n }, [wrapperRef, applyStyle]);\n\n const play = useCallback(() => {\n const { autoplay, children, duration, infinite } = props;\n if (\n autoplay &&\n React.Children.count(children) > 1 &&\n (infinite || index < React.Children.count(children) - 1)\n ) {\n timeout.current = setTimeout(moveNext, duration);\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [props, index]);\n\n useEffect(() => {\n initResizeObserver();\n return () => {\n tweenGroup.current.removeAll();\n clearTimeout(timeout.current);\n removeResizeObserver();\n };\n }, [initResizeObserver, tweenGroup]);\n\n useEffect(() => {\n clearTimeout(timeout.current);\n play();\n }, [index, props.autoplay, play]);\n\n useEffect(() => {\n applyStyle();\n }, [childrenCount, applyStyle]);\n\n useImperativeHandle(ref, () => ({\n goNext: () => {\n moveNext();\n },\n goBack: () => {\n moveBack();\n },\n goTo: (index: number) => {\n moveTo(index);\n },\n }));\n\n const removeResizeObserver = () => {\n if (resizeObserver.current && wrapperRef.current) {\n resizeObserver.current.unobserve(wrapperRef.current);\n }\n };\n\n const pauseSlides = () => {\n if (props.pauseOnHover) {\n clearTimeout(timeout.current);\n }\n };\n\n const startSlides = () => {\n const { pauseOnHover, autoplay, duration } = props;\n if (pauseOnHover && autoplay) {\n timeout.current = setTimeout(() => moveNext(), duration);\n }\n };\n\n const moveNext = () => {\n const { children, infinite } = props;\n if (!infinite && index === React.Children.count(children) - 1) {\n return;\n }\n transitionSlide((index + 1) % React.Children.count(children));\n };\n\n const moveBack = () => {\n const { children, infinite } = props;\n if (!infinite && index === 0) {\n return;\n }\n transitionSlide(index === 0 ? React.Children.count(children) - 1 : index - 1);\n };\n\n const preTransition: ButtonClick = (event) => {\n const { currentTarget } = event;\n if (currentTarget.dataset.type === 'prev') {\n moveBack();\n } else {\n moveNext();\n }\n };\n\n const transitionSlide = (newIndex: number) => {\n const existingTweens = tweenGroup.current.getAll();\n if (!existingTweens.length) {\n if (!innerWrapperRef.current?.children[newIndex]) {\n newIndex = 0;\n }\n clearTimeout(timeout.current);\n const value = { opacity: 0, scale: 1 };\n\n const animate = () => {\n requestAnimationFrame(animate);\n tweenGroup.current.update();\n };\n\n animate();\n\n const tween = new TWEEN.Tween(value, tweenGroup.current)\n .to({ opacity: 1, scale: props.scale }, props.transitionDuration)\n .onUpdate((value) => {\n if (!innerWrapperRef.current) {\n return;\n }\n innerWrapperRef.current.children[newIndex].style.opacity = value.opacity;\n innerWrapperRef.current.children[index].style.opacity = 1 - value.opacity;\n innerWrapperRef.current.children[\n index\n ].style.transform = `scale(${value.scale})`;\n })\n .start();\n tween.easing(getEasing(props.easing));\n tween.onComplete(() => {\n if (innerWrapperRef.current) {\n setIndex(newIndex);\n innerWrapperRef.current.children[index].style.transform = `scale(1)`;\n }\n if (typeof props.onChange === 'function') {\n props.onChange(index, newIndex);\n }\n });\n }\n };\n\n const moveTo = (index: number) => {\n transitionSlide(index);\n };\n\n const navigate: ButtonClick = (event) => {\n const { currentTarget } = event;\n if (!currentTarget.dataset.key) {\n return;\n }\n if (parseInt(currentTarget.dataset.key) !== index) {\n moveTo(parseInt(currentTarget.dataset.key));\n }\n };\n\n return (\n <div dir=\"ltr\" aria-roledescription=\"carousel\">\n <div\n className={`react-slideshow-container ${props.cssClass || ''}`}\n onMouseEnter={pauseSlides}\n onMouseOver={pauseSlides}\n onMouseLeave={startSlides}\n ref={props.ref}\n >\n {props.arrows && showPreviousArrow(props, index, preTransition)}\n <div\n className={`react-slideshow-fadezoom-wrapper ${props.cssClass}`}\n ref={wrapperRef}\n >\n <div className=\"react-slideshow-fadezoom-images-wrap\" ref={innerWrapperRef}>\n {(React.Children.map(props.children, (thisArg) => thisArg) || []).map(\n (each, key) => (\n <div\n style={{\n opacity: key === index ? '1' : '0',\n zIndex: key === index ? '1' : '0',\n }}\n data-index={key}\n key={key}\n aria-roledescription=\"slide\"\n aria-hidden={key === index ? 'false' : 'true'}\n >\n {each}\n </div>\n )\n )}\n </div>\n </div>\n {props.arrows && showNextArrow(props, index, preTransition)}\n </div>\n {props.indicators && showIndicators(props, index, navigate)}\n </div>\n );\n});\n\nFadeZoom.defaultProps = defaultProps;\n","import React from 'react';\nimport { FadeZoom } from './fadezoom';\nimport { defaultProps } from './props';\nimport { FadeProps, SlideshowRef } from './types';\n\nexport const Fade = React.forwardRef<SlideshowRef, FadeProps>((props, ref) => {\n return <FadeZoom {...props} scale={1} ref={ref} />;\n});\n\nFade.defaultProps = defaultProps;\n","import React from 'react';\nimport { FadeZoom } from './fadezoom';\nimport { defaultProps } from './props';\nimport { SlideshowRef, ZoomProps } from './types';\n\nexport const Zoom = React.forwardRef<SlideshowRef, ZoomProps>((props, ref) => {\n return <FadeZoom {...props} ref={ref} />;\n});\n\nZoom.defaultProps = defaultProps;\n","import React, {\n useState,\n useRef,\n useEffect,\n useMemo,\n useImperativeHandle,\n useCallback,\n} from 'react';\nimport ResizeObserver from 'resize-observer-polyfill';\nimport TWEEN from '@tweenjs/tween.js';\nimport {\n getEasing,\n getResponsiveSettings,\n getStartingIndex,\n showIndicators,\n showNextArrow,\n showPreviousArrow,\n} from './helpers';\nimport { ButtonClick, SlideshowRef, SlideProps } from './types';\nimport { defaultProps } from './props';\n\nexport const Slide = React.forwardRef<SlideshowRef, SlideProps>((props, ref) => {\n const [index, setIndex] = useState(getStartingIndex(props.children, props.defaultIndex));\n const [wrapperWidth, setWrapperWidth] = useState<number>(0);\n const wrapperRef = useRef<HTMLDivElement>(null);\n const innerWrapperRef = useRef<any>(null);\n const tweenGroup = useRef(new TWEEN.Group());\n const responsiveSettings = useMemo(\n () => getResponsiveSettings(wrapperWidth, props.responsive),\n [wrapperWidth, props.responsive]\n );\n const slidesToScroll = useMemo(() => {\n if (responsiveSettings) {\n return responsiveSettings.settings.slidesToScroll;\n }\n return props.slidesToScroll || 1;\n }, [responsiveSettings, props.slidesToScroll]);\n const slidesToShow = useMemo(() => {\n if (responsiveSettings) {\n return responsiveSettings.settings.slidesToShow;\n }\n return props.slidesToShow || 1;\n }, [responsiveSettings, props.slidesToShow]);\n const childrenCount = useMemo(() => React.Children.count(props.children), [props.children]);\n const eachChildWidth = useMemo(() => wrapperWidth / slidesToShow, [wrapperWidth, slidesToShow]);\n const timeout = useRef<NodeJS.Timeout>();\n const resizeObserver = useRef<any>();\n let startingClientX: number;\n let dragging: boolean = false;\n let distanceSwiped: number = 0;\n\n const applyStyle = useCallback(() => {\n if (innerWrapperRef.current) {\n const fullwidth = wrapperWidth * innerWrapperRef.current.children.length;\n innerWrapperRef.current.style.width = `${fullwidth}px`;\n for (let index = 0; index < innerWrapperRef.current.children.length; index++) {\n const eachDiv = innerWrapperRef.current.children[index];\n if (eachDiv) {\n eachDiv.style.width = `${eachChildWidth}px`;\n eachDiv.style.display = `block`;\n }\n }\n }\n }, [wrapperWidth, eachChildWidth]);\n\n const initResizeObserver = useCallback(() => {\n if (wrapperRef.current) {\n resizeObserver.current = new ResizeObserver((entries) => {\n if (!entries) return;\n setWidth();\n });\n resizeObserver.current.observe(wrapperRef.current);\n }\n }, [wrapperRef]);\n\n const play = useCallback(() => {\n const { autoplay, infinite, duration } = props;\n if (autoplay && (infinite || index < childrenCount - 1)) {\n timeout.current = setTimeout(moveNext, duration);\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [props, childrenCount, index]);\n\n useEffect(() => {\n applyStyle();\n }, [wrapperWidth, applyStyle]);\n\n useEffect(() => {\n initResizeObserver();\n return () => {\n tweenGroup.current.removeAll();\n clearTimeout(timeout.current);\n removeResizeObserver();\n };\n }, [wrapperRef, initResizeObserver, tweenGroup]);\n\n useEffect(() => {\n clearTimeout(timeout.current);\n play();\n }, [index, wrapperWidth, props.autoplay, play]);\n\n useImperativeHandle(ref, () => ({\n goNext: () => {\n moveNext();\n },\n goBack: () => {\n moveBack();\n },\n goTo: (index: number) => {\n moveTo(index);\n },\n }));\n\n const removeResizeObserver = () => {\n if (resizeObserver && wrapperRef.current) {\n resizeObserver.current.unobserve(wrapperRef.current);\n }\n };\n\n const pauseSlides = () => {\n if (props.pauseOnHover) {\n clearTimeout(timeout.current);\n }\n };\n\n const swipe = (event: React.MouseEvent | React.TouchEvent) => {\n if (props.canSwipe && dragging) {\n let clientX;\n if (window.TouchEvent && event.nativeEvent instanceof TouchEvent) {\n clientX = event.nativeEvent.touches[0].pageX;\n } else if (event.nativeEvent instanceof MouseEvent) {\n clientX = event.nativeEvent.clientX;\n }\n if (clientX && startingClientX) {\n let translateValue = eachChildWidth * (index + getOffset());\n const distance = clientX - startingClientX;\n if (!props.infinite && index === childrenCount - slidesToScroll && distance < 0) {\n // if it is the last and infinite is false and you're swiping left\n // then nothing happens\n return;\n }\n if (!props.infinite && index === 0 && distance > 0) {\n // if it is the first and infinite is false and you're swiping right\n // then nothing happens\n return;\n }\n distanceSwiped = distance;\n translateValue -= distanceSwiped;\n innerWrapperRef.current.style.transform = `translate(-${translateValue}px)`;\n }\n }\n };\n\n const moveNext = () => {\n if (!props.infinite && index === childrenCount - slidesToScroll) {\n return;\n }\n const nextIndex = calculateIndex(index + slidesToScroll);\n transitionSlide(nextIndex);\n };\n\n const moveBack = () => {\n if (!props.infinite && index === 0) {\n return;\n }\n let previousIndex = index - slidesToScroll;\n if (previousIndex % slidesToScroll) {\n previousIndex = Math.ceil(previousIndex / slidesToScroll) * slidesToScroll;\n }\n transitionSlide(previousIndex);\n };\n\n const goToSlide: ButtonClick = ({ currentTarget }) => {\n if (!currentTarget.dataset.key) {\n return;\n }\n const datasetKey = parseInt(currentTarget.dataset.key);\n moveTo(datasetKey * slidesToScroll);\n };\n\n const moveTo = (index: number) => {\n transitionSlide(calculateIndex(index));\n };\n\n const calculateIndex = (nextIndex: number): number => {\n if (nextIndex < childrenCount && nextIndex + slidesToScroll > childrenCount) {\n if ((childrenCount - slidesToScroll) % slidesToScroll) {\n return childrenCount - slidesToScroll;\n }\n return nextIndex;\n }\n return nextIndex;\n };\n\n const startSlides = () => {\n if (dragging) {\n endSwipe();\n } else if (props.pauseOnHover && props.autoplay) {\n timeout.current = setTimeout(moveNext, props.duration);\n }\n };\n\n const moveSlides: ButtonClick = ({ currentTarget: { dataset } }) => {\n if (dataset.type === 'next') {\n moveNext();\n } else {\n moveBack();\n }\n };\n\n const renderPreceedingSlides = () => {\n return React.Children.toArray(props.children)\n .slice(-slidesToShow)\n .map((each, index) => (\n <div\n data-index={index - slidesToShow}\n aria-roledescription=\"slide\"\n aria-hidden=\"true\"\n key={index - slidesToShow}\n >\n {each}\n </div>\n ));\n };\n\n const renderTrailingSlides = () => {\n if (!props.infinite && slidesToShow === slidesToScroll) {\n return;\n }\n return React.Children.toArray(props.children)\n .slice(0, slidesToShow)\n .map((each, index) => (\n <div\n data-index={childrenCount + index}\n aria-roledescription=\"slide\"\n aria-hidden=\"true\"\n key={childrenCount + index}\n >\n {each}\n </div>\n ));\n };\n\n const setWidth = () => {\n if (wrapperRef.current) {\n setWrapperWidth(wrapperRef.current.clientWidth);\n }\n };\n\n const startSwipe = (event: React.MouseEvent | React.TouchEvent) => {\n if (props.canSwipe) {\n if (window.TouchEvent && event.nativeEvent instanceof TouchEvent) {\n startingClientX = event.nativeEvent.touches[0].pageX;\n } else if (event.nativeEvent instanceof MouseEvent) {\n startingClientX = event.nativeEvent.clientX;\n }\n clearTimeout(timeout.current);\n dragging = true;\n }\n };\n\n const endSwipe = () => {\n if (props.canSwipe) {\n dragging = false;\n if (Math.abs(distanceSwiped) / wrapperWidth > 0.2) {\n if (distanceSwiped < 0) {\n moveNext();\n } else {\n moveBack();\n }\n } else {\n if (Math.abs(distanceSwiped) > 0) {\n transitionSlide(index, 300);\n }\n }\n }\n };\n\n const transitionSlide = (toIndex: number, animationDuration?: number) => {\n const transitionDuration = animationDuration || props.transitionDuration;\n const currentIndex = index;\n const existingTweens = tweenGroup.current.getAll();\n if (!wrapperRef.current) {\n return;\n }\n const childWidth = wrapperRef.current.clientWidth / slidesToShow;\n if (!existingTweens.length) {\n clearTimeout(timeout.current);\n const value = {\n margin: -childWidth * (currentIndex + getOffset()) + distanceSwiped,\n };\n const tween = new TWEEN.Tween(value, tweenGroup.current)\n .to({ margin: -childWidth * (toIndex + getOffset()) }, transitionDuration)\n .onUpdate((value) => {\n if (innerWrapperRef.current) {\n innerWrapperRef.current.style.transform = `translate(${value.margin}px)`;\n }\n })\n .start();\n tween.easing(getEasing(props.easing));\n const animate = () => {\n requestAnimationFrame(animate);\n tweenGroup.current.update();\n };\n\n animate();\n\n tween.onComplete(() => {\n distanceSwiped = 0;\n let newIndex = toIndex;\n if (newIndex < 0) {\n newIndex = childrenCount - slidesToScroll;\n } else if (newIndex >= childrenCount) {\n newIndex = 0;\n }\n\n if (typeof props.onChange === 'function') {\n props.onChange(index, newIndex);\n }\n setIndex(newIndex);\n });\n }\n };\n\n const isSlideActive = (key: number) => {\n return key < index + slidesToShow && key >= index;\n };\n\n const getOffset = (): number => {\n if (!props.infinite) {\n return 0;\n }\n return slidesToShow;\n };\n\n const style = {\n transform: `translate(-${(index + getOffset()) * eachChildWidth}px)`,\n };\n return (\n <div dir=\"ltr\" aria-roledescription=\"carousel\">\n <div\n className=\"react-slideshow-container\"\n onMouseEnter={pauseSlides}\n onMouseOver={pauseSlides}\n onMouseLeave={startSlides}\n onMouseDown={startSwipe}\n onMouseUp={endSwipe}\n onMouseMove={swipe}\n onTouchStart={startSwipe}\n onTouchEnd={endSwipe}\n onTouchCancel={endSwipe}\n onTouchMove={swipe}\n >\n {props.arrows && showPreviousArrow(props, index, moveSlides)}\n <div\n className={`react-slideshow-wrapper slide ${props.cssClass || ''}`}\n ref={wrapperRef}\n >\n <div className=\"images-wrap\" style={style} ref={innerWrapperRef}>\n {props.infinite && renderPreceedingSlides()}\n {(React.Children.map(props.children, (thisArg) => thisArg) || []).map(\n (each, key) => {\n const isThisSlideActive = isSlideActive(key);\n return (\n <div\n data-index={key}\n key={key}\n className={isThisSlideActive ? 'active' : ''}\n aria-roledescription=\"slide\"\n aria-hidden={isThisSlideActive ? 'false' : 'true'}\n >\n {each}\n </div>\n );\n }\n )}\n {renderTrailingSlides()}\n </div>\n </div>\n {props.arrows && showNextArrow(props, index, moveSlides)}\n </div>\n {props.indicators && showIndicators(props, index, goToSlide, responsiveSettings)}\n </div>\n );\n});\n\nSlide.defaultProps = defaultProps;\n"],"names":["getStartingIndex","children","defaultIndex","React","Children","count","EASING_METHODS","linear","TWEEN","Easing","Linear","None","ease","Quadratic","InOut","ease-in","In","ease-out","Out","cubic","Cubic","cubic-in","cubic-out","getEasing","easeMethod","showPreviousArrow","currentIndex","moveSlides","prevArrow","isDisabled","infinite","props","data-type","aria-label","disabled","onClick","cloneElement","className","type","width","height","viewBox","d","showNextArrow","properties","nextArrow","slidesToScroll","showIndicators","navigate","responsiveSettings","indicators","settings","pages","Math","ceil","Array","from","length","_","key","indicatorProps","data-key","isCurrentPageActive","floor","eachIndicator","showCustomIndicator","showDefaultIndicator","defaultProps","duration","transitionDuration","autoplay","arrows","pauseOnHover","easing","canSwipe","cssClass","responsive","FadeZoom","forwardRef","ref","useState","index","setIndex","wrapperRef","useRef","innerWrapperRef","tweenGroup","Group","timeout","resizeObserver","childrenCount","useMemo","applyStyle","useCallback","current","wrapperWidth","clientWidth","style","eachDiv","left","display","initResizeObserver","ResizeObserver","entries","observe","play","setTimeout","moveNext","useEffect","removeAll","clearTimeout","removeResizeObserver","useImperativeHandle","goNext","goBack","moveBack","goTo","moveTo","unobserve","pauseSlides","transitionSlide","preTransition","event","currentTarget","dataset","newIndex","getAll","_innerWrapperRef$curr","animate","requestAnimationFrame","update","tween","Tween","opacity","scale","to","onUpdate","value","transform","start","onComplete","onChange","dir","onMouseEnter","onMouseOver","onMouseLeave","map","thisArg","each","zIndex","parseInt","Fade","Zoom","Slide","startingClientX","setWrapperWidth","window","isArray","find","breakpoint","getResponsiveSettings","slidesToShow","eachChildWidth","dragging","distanceSwiped","setWidth","swipe","clientX","TouchEvent","nativeEvent","touches","pageX","MouseEvent","translateValue","getOffset","distance","nextIndex","calculateIndex","previousIndex","startSwipe","endSwipe","abs","toIndex","animationDuration","existingTweens","childWidth","margin","onMouseDown","onMouseUp","onMouseMove","onTouchStart","onTouchEnd","onTouchCancel","onTouchMove","toArray","slice","isThisSlideActive","isSlideActive","renderTrailingSlides","datasetKey"],"mappings":"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"}
1
+ {"version":3,"file":"react-slideshow-image.cjs.production.min.js","sources":["../src/helpers.tsx","../src/props.ts","../src/fadezoom.tsx","../src/fade.tsx","../src/zoom.tsx","../src/slide.tsx"],"sourcesContent":["import React, { ReactNode } from 'react';\nimport {\n ButtonClick,\n FadeProps,\n IndicatorPropsType,\n Responsive,\n SlideProps,\n TweenEasingFn,\n ZoomProps,\n} from './types';\nimport TWEEN from '@tweenjs/tween.js';\n\nexport const getStartingIndex = (children: ReactNode, defaultIndex?: number): number => {\n if (defaultIndex && defaultIndex < React.Children.count(children)) {\n return defaultIndex;\n }\n return 0;\n};\n\nexport const getResponsiveSettings = (\n wrapperWidth: number,\n responsive?: Array<Responsive>\n): Responsive | undefined => {\n if (typeof window !== 'undefined' && Array.isArray(responsive)) {\n return responsive.find((each) => each.breakpoint <= wrapperWidth);\n }\n return;\n};\n\nconst EASING_METHODS: { [key: string]: TweenEasingFn } = {\n linear: TWEEN.Easing.Linear.None,\n ease: TWEEN.Easing.Quadratic.InOut,\n 'ease-in': TWEEN.Easing.Quadratic.In,\n 'ease-out': TWEEN.Easing.Quadratic.Out,\n cubic: TWEEN.Easing.Cubic.InOut,\n 'cubic-in': TWEEN.Easing.Cubic.In,\n 'cubic-out': TWEEN.Easing.Cubic.Out,\n};\n\nexport const getEasing = (easeMethod?: string): TweenEasingFn => {\n if (easeMethod) {\n return EASING_METHODS[easeMethod];\n }\n return EASING_METHODS.linear;\n};\n\nexport const showPreviousArrow = (\n { prevArrow, infinite }: FadeProps | SlideProps | ZoomProps,\n currentIndex: number,\n moveSlides: ButtonClick\n): ReactNode => {\n const isDisabled = currentIndex <= 0 && !infinite;\n const props = {\n 'data-type': 'prev',\n 'aria-label': 'Previous Slide',\n disabled: isDisabled,\n onClick: moveSlides,\n };\n if (prevArrow) {\n return React.cloneElement(prevArrow, {\n className: `${prevArrow.props.className || ''} nav ${isDisabled ? 'disabled' : ''}`,\n ...props,\n });\n }\n const className = `nav default-nav ${isDisabled ? 'disabled' : ''}`;\n return (\n <button type=\"button\" className={className} {...props}>\n <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\">\n <path d=\"M16.67 0l2.83 2.829-9.339 9.175 9.339 9.167-2.83 2.829-12.17-11.996z\" />\n </svg>\n </button>\n );\n};\n\nexport const showNextArrow = (\n properties: FadeProps | SlideProps | ZoomProps,\n currentIndex: number,\n moveSlides: ButtonClick\n) => {\n const { nextArrow, infinite, children } = properties;\n let slidesToScroll = 1;\n if ('slidesToScroll' in properties) {\n slidesToScroll = properties.slidesToScroll || 1;\n }\n const isDisabled = currentIndex >= React.Children.count(children) - slidesToScroll && !infinite;\n const props = {\n 'data-type': 'next',\n 'aria-label': 'Next Slide',\n disabled: isDisabled,\n onClick: moveSlides,\n };\n if (nextArrow) {\n return React.cloneElement(nextArrow, {\n className: `${nextArrow.props.className || ''} nav ${isDisabled ? 'disabled' : ''}`,\n ...props,\n });\n }\n const className = `nav default-nav ${isDisabled ? 'disabled' : ''}`;\n return (\n <button type=\"button\" className={className} {...props}>\n <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\">\n <path d=\"M5 3l3.057-3 11.943 12-11.943 12-3.057-3 9-9z\" />\n </svg>\n </button>\n );\n};\n\nconst showDefaultIndicator = (\n isCurrentPageActive: boolean,\n key: number,\n indicatorProps: IndicatorPropsType\n) => {\n return (\n <li key={key}>\n <button\n type=\"button\"\n className={`each-slideshow-indicator ${isCurrentPageActive ? 'active' : ''}`}\n {...indicatorProps}\n />\n </li>\n );\n};\n\nconst showCustomIndicator = (\n isCurrentPageActive: boolean,\n key: number,\n indicatorProps: any,\n eachIndicator: any\n) => {\n return React.cloneElement(eachIndicator, {\n className: `${eachIndicator.props.className} ${isCurrentPageActive ? 'active' : ''}`,\n key,\n ...indicatorProps,\n });\n};\n\nexport const showIndicators = (\n props: FadeProps | SlideProps | ZoomProps,\n currentIndex: number,\n navigate: ButtonClick,\n responsiveSettings?: Responsive\n): ReactNode => {\n const { children, indicators } = props;\n let slidesToScroll = 1;\n if (responsiveSettings) {\n slidesToScroll = responsiveSettings?.settings.slidesToScroll;\n } else if ('slidesToScroll' in props) {\n slidesToScroll = props.slidesToScroll || 1;\n }\n const pages = Math.ceil(React.Children.count(children) / slidesToScroll);\n return (\n <ul className=\"indicators\">\n {Array.from({ length: pages }, (_, key) => {\n const indicatorProps: IndicatorPropsType = {\n 'data-key': key,\n 'aria-label': `Go to slide ${key + 1}`,\n onClick: navigate,\n };\n const isCurrentPageActive =\n Math.floor((currentIndex + slidesToScroll - 1) / slidesToScroll) === key;\n if (typeof indicators === 'function') {\n return showCustomIndicator(\n isCurrentPageActive,\n key,\n indicatorProps,\n indicators(key)\n );\n }\n return showDefaultIndicator(isCurrentPageActive, key, indicatorProps);\n })}\n </ul>\n );\n};\n","export const defaultProps = {\n duration: 5000,\n transitionDuration: 1000,\n defaultIndex: 0,\n infinite: true,\n autoplay: true,\n indicators: false,\n arrows: true,\n pauseOnHover: true,\n easing: 'linear',\n canSwipe: true,\n cssClass: '',\n responsive: [],\n};\n","import React, {\n useState,\n useRef,\n useEffect,\n useMemo,\n useImperativeHandle,\n useCallback,\n} from 'react';\nimport ResizeObserver from 'resize-observer-polyfill';\nimport TWEEN from '@tweenjs/tween.js';\nimport {\n getEasing,\n getStartingIndex,\n showIndicators,\n showNextArrow,\n showPreviousArrow,\n} from './helpers';\nimport { ButtonClick, SlideshowRef, ZoomProps } from './types';\nimport { defaultProps } from './props';\n\nexport const FadeZoom = React.forwardRef<SlideshowRef, ZoomProps>((props, ref) => {\n const [index, setIndex] = useState<number>(\n getStartingIndex(props.children, props.defaultIndex)\n );\n const wrapperRef = useRef<HTMLDivElement>(null);\n const innerWrapperRef = useRef<any>(null);\n const tweenGroup = useRef(new TWEEN.Group());\n const timeout = useRef<NodeJS.Timeout>();\n const resizeObserver = useRef<any>();\n const childrenCount = useMemo(() => React.Children.count(props.children), [props.children]);\n\n const applyStyle = useCallback(() => {\n if (innerWrapperRef.current && wrapperRef.current) {\n const wrapperWidth = wrapperRef.current.clientWidth;\n const fullwidth = wrapperWidth * childrenCount;\n innerWrapperRef.current.style.width = `${fullwidth}px`;\n for (let index = 0; index < innerWrapperRef.current.children.length; index++) {\n const eachDiv = innerWrapperRef.current.children[index];\n if (eachDiv) {\n eachDiv.style.width = `${wrapperWidth}px`;\n eachDiv.style.left = `${index * -wrapperWidth}px`;\n eachDiv.style.display = `block`;\n }\n }\n }\n }, [wrapperRef, innerWrapperRef, childrenCount]);\n\n const initResizeObserver = useCallback(() => {\n if (wrapperRef.current) {\n resizeObserver.current = new ResizeObserver((entries) => {\n if (!entries) return;\n applyStyle();\n });\n resizeObserver.current.observe(wrapperRef.current);\n }\n }, [wrapperRef, applyStyle]);\n\n const play = useCallback(() => {\n const { autoplay, children, duration, infinite } = props;\n if (\n autoplay &&\n React.Children.count(children) > 1 &&\n (infinite || index < React.Children.count(children) - 1)\n ) {\n timeout.current = setTimeout(moveNext, duration);\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [props, index]);\n\n useEffect(() => {\n initResizeObserver();\n return () => {\n tweenGroup.current.removeAll();\n clearTimeout(timeout.current);\n removeResizeObserver();\n };\n }, [initResizeObserver, tweenGroup]);\n\n useEffect(() => {\n clearTimeout(timeout.current);\n play();\n }, [index, props.autoplay, play]);\n\n useEffect(() => {\n applyStyle();\n }, [childrenCount, applyStyle]);\n\n useImperativeHandle(ref, () => ({\n goNext: () => {\n moveNext();\n },\n goBack: () => {\n moveBack();\n },\n goTo: (index: number, options?: { skipTransition?: boolean }) => {\n if (options?.skipTransition) {\n setIndex(index);\n } else {\n moveTo(index);\n }\n },\n }));\n\n const removeResizeObserver = () => {\n if (resizeObserver.current && wrapperRef.current) {\n resizeObserver.current.unobserve(wrapperRef.current);\n }\n };\n\n const pauseSlides = () => {\n if (props.pauseOnHover) {\n clearTimeout(timeout.current);\n }\n };\n\n const startSlides = () => {\n const { pauseOnHover, autoplay, duration } = props;\n if (pauseOnHover && autoplay) {\n timeout.current = setTimeout(() => moveNext(), duration);\n }\n };\n\n const moveNext = () => {\n const { children, infinite } = props;\n if (!infinite && index === React.Children.count(children) - 1) {\n return;\n }\n transitionSlide((index + 1) % React.Children.count(children));\n };\n\n const moveBack = () => {\n const { children, infinite } = props;\n if (!infinite && index === 0) {\n return;\n }\n transitionSlide(index === 0 ? React.Children.count(children) - 1 : index - 1);\n };\n\n const preTransition: ButtonClick = (event) => {\n const { currentTarget } = event;\n if (currentTarget.dataset.type === 'prev') {\n moveBack();\n } else {\n moveNext();\n }\n };\n\n const transitionSlide = (newIndex: number) => {\n const existingTweens = tweenGroup.current.getAll();\n if (!existingTweens.length) {\n if (!innerWrapperRef.current?.children[newIndex]) {\n newIndex = 0;\n }\n clearTimeout(timeout.current);\n const value = { opacity: 0, scale: 1 };\n\n const animate = () => {\n requestAnimationFrame(animate);\n tweenGroup.current.update();\n };\n\n animate();\n\n const tween = new TWEEN.Tween(value, tweenGroup.current)\n .to({ opacity: 1, scale: props.scale }, props.transitionDuration)\n .onUpdate((value) => {\n if (!innerWrapperRef.current) {\n return;\n }\n innerWrapperRef.current.children[newIndex].style.opacity = value.opacity;\n innerWrapperRef.current.children[index].style.opacity = 1 - value.opacity;\n innerWrapperRef.current.children[\n index\n ].style.transform = `scale(${value.scale})`;\n })\n .start();\n tween.easing(getEasing(props.easing));\n tween.onComplete(() => {\n if (innerWrapperRef.current) {\n setIndex(newIndex);\n innerWrapperRef.current.children[index].style.transform = `scale(1)`;\n }\n if (typeof props.onChange === 'function') {\n props.onChange(index, newIndex);\n }\n });\n }\n };\n\n const moveTo = (gotoIndex: number) => {\n if (gotoIndex !== index) {\n transitionSlide(gotoIndex);\n }\n };\n\n const navigate: ButtonClick = (event) => {\n const { currentTarget } = event;\n if (!currentTarget.dataset.key) {\n return;\n }\n if (parseInt(currentTarget.dataset.key) !== index) {\n moveTo(parseInt(currentTarget.dataset.key));\n }\n };\n\n return (\n <div dir=\"ltr\" aria-roledescription=\"carousel\">\n <div\n className={`react-slideshow-container ${props.cssClass || ''}`}\n onMouseEnter={pauseSlides}\n onMouseOver={pauseSlides}\n onMouseLeave={startSlides}\n >\n {props.arrows && showPreviousArrow(props, index, preTransition)}\n <div\n className={`react-slideshow-fadezoom-wrapper ${props.cssClass}`}\n ref={wrapperRef}\n >\n <div className=\"react-slideshow-fadezoom-images-wrap\" ref={innerWrapperRef}>\n {(React.Children.map(props.children, (thisArg) => thisArg) || []).map(\n (each, key) => (\n <div\n style={{\n opacity: key === index ? '1' : '0',\n zIndex: key === index ? '1' : '0',\n }}\n data-index={key}\n key={key}\n aria-roledescription=\"slide\"\n aria-hidden={key === index ? 'false' : 'true'}\n >\n {each}\n </div>\n )\n )}\n </div>\n </div>\n {props.arrows && showNextArrow(props, index, preTransition)}\n </div>\n {props.indicators && showIndicators(props, index, navigate)}\n </div>\n );\n});\n\nFadeZoom.defaultProps = defaultProps;\n","import React from 'react';\nimport { FadeZoom } from './fadezoom';\nimport { defaultProps } from './props';\nimport { FadeProps, SlideshowRef } from './types';\n\nexport const Fade = React.forwardRef<SlideshowRef, FadeProps>((props, ref) => {\n return <FadeZoom {...props} scale={1} ref={ref} />;\n});\n\nFade.defaultProps = defaultProps;\n","import React from 'react';\nimport { FadeZoom } from './fadezoom';\nimport { defaultProps } from './props';\nimport { SlideshowRef, ZoomProps } from './types';\n\nexport const Zoom = React.forwardRef<SlideshowRef, ZoomProps>((props, ref) => {\n return <FadeZoom {...props} ref={ref} />;\n});\n\nZoom.defaultProps = defaultProps;\n","import React, {\n useState,\n useRef,\n useEffect,\n useMemo,\n useImperativeHandle,\n useCallback,\n} from 'react';\nimport ResizeObserver from 'resize-observer-polyfill';\nimport TWEEN from '@tweenjs/tween.js';\nimport {\n getEasing,\n getResponsiveSettings,\n getStartingIndex,\n showIndicators,\n showNextArrow,\n showPreviousArrow,\n} from './helpers';\nimport { ButtonClick, SlideshowRef, SlideProps } from './types';\nimport { defaultProps } from './props';\n\nexport const Slide = React.forwardRef<SlideshowRef, SlideProps>((props, ref) => {\n const [index, setIndex] = useState(getStartingIndex(props.children, props.defaultIndex));\n const [wrapperWidth, setWrapperWidth] = useState<number>(0);\n const wrapperRef = useRef<HTMLDivElement>(null);\n const innerWrapperRef = useRef<any>(null);\n const tweenGroup = useRef(new TWEEN.Group());\n const responsiveSettings = useMemo(\n () => getResponsiveSettings(wrapperWidth, props.responsive),\n [wrapperWidth, props.responsive]\n );\n const slidesToScroll = useMemo(() => {\n if (responsiveSettings) {\n return responsiveSettings.settings.slidesToScroll;\n }\n return props.slidesToScroll || 1;\n }, [responsiveSettings, props.slidesToScroll]);\n const slidesToShow = useMemo(() => {\n if (responsiveSettings) {\n return responsiveSettings.settings.slidesToShow;\n }\n return props.slidesToShow || 1;\n }, [responsiveSettings, props.slidesToShow]);\n const childrenCount = useMemo(() => React.Children.count(props.children), [props.children]);\n const eachChildWidth = useMemo(() => wrapperWidth / slidesToShow, [wrapperWidth, slidesToShow]);\n const timeout = useRef<NodeJS.Timeout>();\n const resizeObserver = useRef<any>();\n let startingClientX: number;\n let dragging: boolean = false;\n let distanceSwiped: number = 0;\n\n const applyStyle = useCallback(() => {\n if (innerWrapperRef.current) {\n const fullwidth = wrapperWidth * innerWrapperRef.current.children.length;\n innerWrapperRef.current.style.width = `${fullwidth}px`;\n for (let index = 0; index < innerWrapperRef.current.children.length; index++) {\n const eachDiv = innerWrapperRef.current.children[index];\n if (eachDiv) {\n eachDiv.style.width = `${eachChildWidth}px`;\n eachDiv.style.display = `block`;\n }\n }\n }\n }, [wrapperWidth, eachChildWidth]);\n\n const initResizeObserver = useCallback(() => {\n if (wrapperRef.current) {\n resizeObserver.current = new ResizeObserver((entries) => {\n if (!entries) return;\n setWidth();\n });\n resizeObserver.current.observe(wrapperRef.current);\n }\n }, [wrapperRef]);\n\n const play = useCallback(() => {\n const { autoplay, infinite, duration } = props;\n if (autoplay && (infinite || index < childrenCount - 1)) {\n timeout.current = setTimeout(moveNext, duration);\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [props, childrenCount, index]);\n\n useEffect(() => {\n applyStyle();\n }, [wrapperWidth, applyStyle]);\n\n useEffect(() => {\n initResizeObserver();\n return () => {\n tweenGroup.current.removeAll();\n clearTimeout(timeout.current);\n removeResizeObserver();\n };\n }, [wrapperRef, initResizeObserver, tweenGroup]);\n\n useEffect(() => {\n clearTimeout(timeout.current);\n play();\n }, [index, wrapperWidth, props.autoplay, play]);\n\n useImperativeHandle(ref, () => ({\n goNext: () => {\n moveNext();\n },\n goBack: () => {\n moveBack();\n },\n goTo: (index: number, options?: { skipTransition?: boolean }) => {\n if (options?.skipTransition) {\n setIndex(index);\n } else {\n moveTo(index);\n }\n },\n }));\n\n const removeResizeObserver = () => {\n if (resizeObserver && wrapperRef.current) {\n resizeObserver.current.unobserve(wrapperRef.current);\n }\n };\n\n const pauseSlides = () => {\n if (props.pauseOnHover) {\n clearTimeout(timeout.current);\n }\n };\n\n const swipe = (event: React.MouseEvent | React.TouchEvent) => {\n if (props.canSwipe && dragging) {\n let clientX;\n if (window.TouchEvent && event.nativeEvent instanceof TouchEvent) {\n clientX = event.nativeEvent.touches[0].pageX;\n } else if (event.nativeEvent instanceof MouseEvent) {\n clientX = event.nativeEvent.clientX;\n }\n if (clientX && startingClientX) {\n let translateValue = eachChildWidth * (index + getOffset());\n const distance = clientX - startingClientX;\n if (!props.infinite && index === childrenCount - slidesToScroll && distance < 0) {\n // if it is the last and infinite is false and you're swiping left\n // then nothing happens\n return;\n }\n if (!props.infinite && index === 0 && distance > 0) {\n // if it is the first and infinite is false and you're swiping right\n // then nothing happens\n return;\n }\n distanceSwiped = distance;\n translateValue -= distanceSwiped;\n innerWrapperRef.current.style.transform = `translate(-${translateValue}px)`;\n }\n }\n };\n\n const moveNext = () => {\n if (!props.infinite && index === childrenCount - slidesToScroll) {\n return;\n }\n const nextIndex = calculateIndex(index + slidesToScroll);\n transitionSlide(nextIndex);\n };\n\n const moveBack = () => {\n if (!props.infinite && index === 0) {\n return;\n }\n let previousIndex = index - slidesToScroll;\n if (previousIndex % slidesToScroll) {\n previousIndex = Math.ceil(previousIndex / slidesToScroll) * slidesToScroll;\n }\n transitionSlide(previousIndex);\n };\n\n const goToSlide: ButtonClick = ({ currentTarget }) => {\n if (!currentTarget.dataset.key) {\n return;\n }\n const datasetKey = parseInt(currentTarget.dataset.key);\n moveTo(datasetKey * slidesToScroll);\n };\n\n const moveTo = (index: number) => {\n transitionSlide(calculateIndex(index));\n };\n\n const calculateIndex = (nextIndex: number): number => {\n if (nextIndex < childrenCount && nextIndex + slidesToScroll > childrenCount) {\n if ((childrenCount - slidesToScroll) % slidesToScroll) {\n return childrenCount - slidesToScroll;\n }\n return nextIndex;\n }\n return nextIndex;\n };\n\n const startSlides = () => {\n if (dragging) {\n endSwipe();\n } else if (props.pauseOnHover && props.autoplay) {\n timeout.current = setTimeout(moveNext, props.duration);\n }\n };\n\n const moveSlides: ButtonClick = ({ currentTarget: { dataset } }) => {\n if (dataset.type === 'next') {\n moveNext();\n } else {\n moveBack();\n }\n };\n\n const renderPreceedingSlides = () => {\n return React.Children.toArray(props.children)\n .slice(-slidesToShow)\n .map((each, index) => (\n <div\n data-index={index - slidesToShow}\n aria-roledescription=\"slide\"\n aria-hidden=\"true\"\n key={index - slidesToShow}\n >\n {each}\n </div>\n ));\n };\n\n const renderTrailingSlides = () => {\n if (!props.infinite && slidesToShow === slidesToScroll) {\n return;\n }\n return React.Children.toArray(props.children)\n .slice(0, slidesToShow)\n .map((each, index) => (\n <div\n data-index={childrenCount + index}\n aria-roledescription=\"slide\"\n aria-hidden=\"true\"\n key={childrenCount + index}\n >\n {each}\n </div>\n ));\n };\n\n const setWidth = () => {\n if (wrapperRef.current) {\n setWrapperWidth(wrapperRef.current.clientWidth);\n }\n };\n\n const startSwipe = (event: React.MouseEvent | React.TouchEvent) => {\n if (props.canSwipe) {\n if (window.TouchEvent && event.nativeEvent instanceof TouchEvent) {\n startingClientX = event.nativeEvent.touches[0].pageX;\n } else if (event.nativeEvent instanceof MouseEvent) {\n startingClientX = event.nativeEvent.clientX;\n }\n clearTimeout(timeout.current);\n dragging = true;\n }\n };\n\n const endSwipe = () => {\n if (props.canSwipe) {\n dragging = false;\n if (Math.abs(distanceSwiped) / wrapperWidth > 0.2) {\n if (distanceSwiped < 0) {\n moveNext();\n } else {\n moveBack();\n }\n } else {\n if (Math.abs(distanceSwiped) > 0) {\n transitionSlide(index, 300);\n }\n }\n }\n };\n\n const transitionSlide = (toIndex: number, animationDuration?: number) => {\n const transitionDuration = animationDuration || props.transitionDuration;\n const currentIndex = index;\n const existingTweens = tweenGroup.current.getAll();\n if (!wrapperRef.current) {\n return;\n }\n const childWidth = wrapperRef.current.clientWidth / slidesToShow;\n if (!existingTweens.length) {\n clearTimeout(timeout.current);\n const value = {\n margin: -childWidth * (currentIndex + getOffset()) + distanceSwiped,\n };\n const tween = new TWEEN.Tween(value, tweenGroup.current)\n .to({ margin: -childWidth * (toIndex + getOffset()) }, transitionDuration)\n .onUpdate((value) => {\n if (innerWrapperRef.current) {\n innerWrapperRef.current.style.transform = `translate(${value.margin}px)`;\n }\n })\n .start();\n tween.easing(getEasing(props.easing));\n const animate = () => {\n requestAnimationFrame(animate);\n tweenGroup.current.update();\n };\n\n animate();\n\n tween.onComplete(() => {\n distanceSwiped = 0;\n let newIndex = toIndex;\n if (newIndex < 0) {\n newIndex = childrenCount - slidesToScroll;\n } else if (newIndex >= childrenCount) {\n newIndex = 0;\n }\n\n if (typeof props.onChange === 'function') {\n props.onChange(index, newIndex);\n }\n setIndex(newIndex);\n });\n }\n };\n\n const isSlideActive = (key: number) => {\n return key < index + slidesToShow && key >= index;\n };\n\n const getOffset = (): number => {\n if (!props.infinite) {\n return 0;\n }\n return slidesToShow;\n };\n\n const style = {\n transform: `translate(-${(index + getOffset()) * eachChildWidth}px)`,\n };\n return (\n <div dir=\"ltr\" aria-roledescription=\"carousel\">\n <div\n className=\"react-slideshow-container\"\n onMouseEnter={pauseSlides}\n onMouseOver={pauseSlides}\n onMouseLeave={startSlides}\n onMouseDown={startSwipe}\n onMouseUp={endSwipe}\n onMouseMove={swipe}\n onTouchStart={startSwipe}\n onTouchEnd={endSwipe}\n onTouchCancel={endSwipe}\n onTouchMove={swipe}\n >\n {props.arrows && showPreviousArrow(props, index, moveSlides)}\n <div\n className={`react-slideshow-wrapper slide ${props.cssClass || ''}`}\n ref={wrapperRef}\n >\n <div className=\"images-wrap\" style={style} ref={innerWrapperRef}>\n {props.infinite && renderPreceedingSlides()}\n {(React.Children.map(props.children, (thisArg) => thisArg) || []).map(\n (each, key) => {\n const isThisSlideActive = isSlideActive(key);\n return (\n <div\n data-index={key}\n key={key}\n className={isThisSlideActive ? 'active' : ''}\n aria-roledescription=\"slide\"\n aria-hidden={isThisSlideActive ? 'false' : 'true'}\n >\n {each}\n </div>\n );\n }\n )}\n {renderTrailingSlides()}\n </div>\n </div>\n {props.arrows && showNextArrow(props, index, moveSlides)}\n </div>\n {props.indicators && showIndicators(props, index, goToSlide, responsiveSettings)}\n </div>\n );\n});\n\nSlide.defaultProps = defaultProps;\n"],"names":["getStartingIndex","children","defaultIndex","React","Children","count","EASING_METHODS","linear","TWEEN","Easing","Linear","None","ease","Quadratic","InOut","ease-in","In","ease-out","Out","cubic","Cubic","cubic-in","cubic-out","getEasing","easeMethod","showPreviousArrow","currentIndex","moveSlides","prevArrow","isDisabled","infinite","props","data-type","aria-label","disabled","onClick","cloneElement","className","type","width","height","viewBox","d","showNextArrow","properties","nextArrow","slidesToScroll","showIndicators","navigate","responsiveSettings","indicators","settings","pages","Math","ceil","Array","from","length","_","key","indicatorProps","data-key","isCurrentPageActive","floor","eachIndicator","showCustomIndicator","showDefaultIndicator","defaultProps","duration","transitionDuration","autoplay","arrows","pauseOnHover","easing","canSwipe","cssClass","responsive","FadeZoom","forwardRef","ref","useState","index","setIndex","wrapperRef","useRef","innerWrapperRef","tweenGroup","Group","timeout","resizeObserver","childrenCount","useMemo","applyStyle","useCallback","current","wrapperWidth","clientWidth","style","eachDiv","left","display","initResizeObserver","ResizeObserver","entries","observe","play","setTimeout","moveNext","useEffect","removeAll","clearTimeout","removeResizeObserver","useImperativeHandle","goNext","goBack","moveBack","goTo","options","skipTransition","moveTo","unobserve","pauseSlides","transitionSlide","preTransition","event","currentTarget","dataset","newIndex","getAll","_innerWrapperRef$curr","animate","requestAnimationFrame","update","tween","Tween","opacity","scale","to","onUpdate","value","transform","start","onComplete","onChange","gotoIndex","dir","onMouseEnter","onMouseOver","onMouseLeave","map","thisArg","each","zIndex","parseInt","Fade","Zoom","Slide","startingClientX","setWrapperWidth","window","isArray","find","breakpoint","getResponsiveSettings","slidesToShow","eachChildWidth","dragging","distanceSwiped","setWidth","swipe","clientX","TouchEvent","nativeEvent","touches","pageX","MouseEvent","translateValue","getOffset","distance","nextIndex","calculateIndex","previousIndex","startSwipe","endSwipe","abs","toIndex","animationDuration","existingTweens","childWidth","margin","onMouseDown","onMouseUp","onMouseMove","onTouchStart","onTouchEnd","onTouchCancel","onTouchMove","toArray","slice","isThisSlideActive","isSlideActive","renderTrailingSlides","datasetKey"],"mappings":"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"}
@@ -253,8 +253,12 @@ var FadeZoom = /*#__PURE__*/React.forwardRef(function (props, ref) {
253
253
  goBack: function goBack() {
254
254
  moveBack();
255
255
  },
256
- goTo: function goTo(index) {
257
- moveTo(index);
256
+ goTo: function goTo(index, options) {
257
+ if (options != null && options.skipTransition) {
258
+ setIndex(index);
259
+ } else {
260
+ moveTo(index);
261
+ }
258
262
  }
259
263
  };
260
264
  });
@@ -363,8 +367,10 @@ var FadeZoom = /*#__PURE__*/React.forwardRef(function (props, ref) {
363
367
  }
364
368
  };
365
369
 
366
- var moveTo = function moveTo(index) {
367
- transitionSlide(index);
370
+ var moveTo = function moveTo(gotoIndex) {
371
+ if (gotoIndex !== index) {
372
+ transitionSlide(gotoIndex);
373
+ }
368
374
  };
369
375
 
370
376
  var navigate = function navigate(event) {
@@ -386,8 +392,7 @@ var FadeZoom = /*#__PURE__*/React.forwardRef(function (props, ref) {
386
392
  className: "react-slideshow-container " + (props.cssClass || ''),
387
393
  onMouseEnter: pauseSlides,
388
394
  onMouseOver: pauseSlides,
389
- onMouseLeave: startSlides,
390
- ref: props.ref
395
+ onMouseLeave: startSlides
391
396
  }, props.arrows && showPreviousArrow(props, index, preTransition), /*#__PURE__*/React.createElement("div", {
392
397
  className: "react-slideshow-fadezoom-wrapper " + props.cssClass,
393
398
  ref: wrapperRef
@@ -523,8 +528,12 @@ var Slide = /*#__PURE__*/React.forwardRef(function (props, ref) {
523
528
  goBack: function goBack() {
524
529
  moveBack();
525
530
  },
526
- goTo: function goTo(index) {
527
- moveTo(index);
531
+ goTo: function goTo(index, options) {
532
+ if (options != null && options.skipTransition) {
533
+ setIndex(index);
534
+ } else {
535
+ moveTo(index);
536
+ }
528
537
  }
529
538
  };
530
539
  });
@@ -1 +1 @@
1
- {"version":3,"file":"react-slideshow-image.esm.js","sources":["../src/helpers.tsx","../src/props.ts","../src/fadezoom.tsx","../src/fade.tsx","../src/zoom.tsx","../src/slide.tsx"],"sourcesContent":["import React, { ReactNode } from 'react';\nimport {\n ButtonClick,\n FadeProps,\n IndicatorPropsType,\n Responsive,\n SlideProps,\n TweenEasingFn,\n ZoomProps,\n} from './types';\nimport TWEEN from '@tweenjs/tween.js';\n\nexport const getStartingIndex = (children: ReactNode, defaultIndex?: number): number => {\n if (defaultIndex && defaultIndex < React.Children.count(children)) {\n return defaultIndex;\n }\n return 0;\n};\n\nexport const getResponsiveSettings = (\n wrapperWidth: number,\n responsive?: Array<Responsive>\n): Responsive | undefined => {\n if (typeof window !== 'undefined' && Array.isArray(responsive)) {\n return responsive.find((each) => each.breakpoint <= wrapperWidth);\n }\n return;\n};\n\nconst EASING_METHODS: { [key: string]: TweenEasingFn } = {\n linear: TWEEN.Easing.Linear.None,\n ease: TWEEN.Easing.Quadratic.InOut,\n 'ease-in': TWEEN.Easing.Quadratic.In,\n 'ease-out': TWEEN.Easing.Quadratic.Out,\n cubic: TWEEN.Easing.Cubic.InOut,\n 'cubic-in': TWEEN.Easing.Cubic.In,\n 'cubic-out': TWEEN.Easing.Cubic.Out,\n};\n\nexport const getEasing = (easeMethod?: string): TweenEasingFn => {\n if (easeMethod) {\n return EASING_METHODS[easeMethod];\n }\n return EASING_METHODS.linear;\n};\n\nexport const showPreviousArrow = (\n { prevArrow, infinite }: FadeProps | SlideProps | ZoomProps,\n currentIndex: number,\n moveSlides: ButtonClick\n): ReactNode => {\n const isDisabled = currentIndex <= 0 && !infinite;\n const props = {\n 'data-type': 'prev',\n 'aria-label': 'Previous Slide',\n disabled: isDisabled,\n onClick: moveSlides,\n };\n if (prevArrow) {\n return React.cloneElement(prevArrow, {\n className: `${prevArrow.props.className || ''} nav ${isDisabled ? 'disabled' : ''}`,\n ...props,\n });\n }\n const className = `nav default-nav ${isDisabled ? 'disabled' : ''}`;\n return (\n <button type=\"button\" className={className} {...props}>\n <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\">\n <path d=\"M16.67 0l2.83 2.829-9.339 9.175 9.339 9.167-2.83 2.829-12.17-11.996z\" />\n </svg>\n </button>\n );\n};\n\nexport const showNextArrow = (\n properties: FadeProps | SlideProps | ZoomProps,\n currentIndex: number,\n moveSlides: ButtonClick\n) => {\n const { nextArrow, infinite, children } = properties;\n let slidesToScroll = 1;\n if ('slidesToScroll' in properties) {\n slidesToScroll = properties.slidesToScroll || 1;\n }\n const isDisabled = currentIndex >= React.Children.count(children) - slidesToScroll && !infinite;\n const props = {\n 'data-type': 'next',\n 'aria-label': 'Next Slide',\n disabled: isDisabled,\n onClick: moveSlides,\n };\n if (nextArrow) {\n return React.cloneElement(nextArrow, {\n className: `${nextArrow.props.className || ''} nav ${isDisabled ? 'disabled' : ''}`,\n ...props,\n });\n }\n const className = `nav default-nav ${isDisabled ? 'disabled' : ''}`;\n return (\n <button type=\"button\" className={className} {...props}>\n <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\">\n <path d=\"M5 3l3.057-3 11.943 12-11.943 12-3.057-3 9-9z\" />\n </svg>\n </button>\n );\n};\n\nconst showDefaultIndicator = (\n isCurrentPageActive: boolean,\n key: number,\n indicatorProps: IndicatorPropsType\n) => {\n return (\n <li key={key}>\n <button\n type=\"button\"\n className={`each-slideshow-indicator ${isCurrentPageActive ? 'active' : ''}`}\n {...indicatorProps}\n />\n </li>\n );\n};\n\nconst showCustomIndicator = (\n isCurrentPageActive: boolean,\n key: number,\n indicatorProps: any,\n eachIndicator: any\n) => {\n return React.cloneElement(eachIndicator, {\n className: `${eachIndicator.props.className} ${isCurrentPageActive ? 'active' : ''}`,\n key,\n ...indicatorProps,\n });\n};\n\nexport const showIndicators = (\n props: FadeProps | SlideProps | ZoomProps,\n currentIndex: number,\n navigate: ButtonClick,\n responsiveSettings?: Responsive\n): ReactNode => {\n const { children, indicators } = props;\n let slidesToScroll = 1;\n if (responsiveSettings) {\n slidesToScroll = responsiveSettings?.settings.slidesToScroll;\n } else if ('slidesToScroll' in props) {\n slidesToScroll = props.slidesToScroll || 1;\n }\n const pages = Math.ceil(React.Children.count(children) / slidesToScroll);\n return (\n <ul className=\"indicators\">\n {Array.from({ length: pages }, (_, key) => {\n const indicatorProps: IndicatorPropsType = {\n 'data-key': key,\n 'aria-label': `Go to slide ${key + 1}`,\n onClick: navigate,\n };\n const isCurrentPageActive =\n Math.floor((currentIndex + slidesToScroll - 1) / slidesToScroll) === key;\n if (typeof indicators === 'function') {\n return showCustomIndicator(\n isCurrentPageActive,\n key,\n indicatorProps,\n indicators(key)\n );\n }\n return showDefaultIndicator(isCurrentPageActive, key, indicatorProps);\n })}\n </ul>\n );\n};\n","export const defaultProps = {\n duration: 5000,\n transitionDuration: 1000,\n defaultIndex: 0,\n infinite: true,\n autoplay: true,\n indicators: false,\n arrows: true,\n pauseOnHover: true,\n easing: 'linear',\n canSwipe: true,\n cssClass: '',\n responsive: [],\n};\n","import React, {\n useState,\n useRef,\n useEffect,\n useMemo,\n useImperativeHandle,\n useCallback,\n} from 'react';\nimport ResizeObserver from 'resize-observer-polyfill';\nimport TWEEN from '@tweenjs/tween.js';\nimport {\n getEasing,\n getStartingIndex,\n showIndicators,\n showNextArrow,\n showPreviousArrow,\n} from './helpers';\nimport { ButtonClick, SlideshowRef, ZoomProps } from './types';\nimport { defaultProps } from './props';\n\nexport const FadeZoom = React.forwardRef<SlideshowRef, ZoomProps>((props, ref) => {\n const [index, setIndex] = useState<number>(\n getStartingIndex(props.children, props.defaultIndex)\n );\n const wrapperRef = useRef<HTMLDivElement>(null);\n const innerWrapperRef = useRef<any>(null);\n const tweenGroup = useRef(new TWEEN.Group());\n const timeout = useRef<NodeJS.Timeout>();\n const resizeObserver = useRef<any>();\n const childrenCount = useMemo(() => React.Children.count(props.children), [props.children]);\n\n const applyStyle = useCallback(() => {\n if (innerWrapperRef.current && wrapperRef.current) {\n const wrapperWidth = wrapperRef.current.clientWidth;\n const fullwidth = wrapperWidth * childrenCount;\n innerWrapperRef.current.style.width = `${fullwidth}px`;\n for (let index = 0; index < innerWrapperRef.current.children.length; index++) {\n const eachDiv = innerWrapperRef.current.children[index];\n if (eachDiv) {\n eachDiv.style.width = `${wrapperWidth}px`;\n eachDiv.style.left = `${index * -wrapperWidth}px`;\n eachDiv.style.display = `block`;\n }\n }\n }\n }, [wrapperRef, innerWrapperRef, childrenCount]);\n\n const initResizeObserver = useCallback(() => {\n if (wrapperRef.current) {\n resizeObserver.current = new ResizeObserver((entries) => {\n if (!entries) return;\n applyStyle();\n });\n resizeObserver.current.observe(wrapperRef.current);\n }\n }, [wrapperRef, applyStyle]);\n\n const play = useCallback(() => {\n const { autoplay, children, duration, infinite } = props;\n if (\n autoplay &&\n React.Children.count(children) > 1 &&\n (infinite || index < React.Children.count(children) - 1)\n ) {\n timeout.current = setTimeout(moveNext, duration);\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [props, index]);\n\n useEffect(() => {\n initResizeObserver();\n return () => {\n tweenGroup.current.removeAll();\n clearTimeout(timeout.current);\n removeResizeObserver();\n };\n }, [initResizeObserver, tweenGroup]);\n\n useEffect(() => {\n clearTimeout(timeout.current);\n play();\n }, [index, props.autoplay, play]);\n\n useEffect(() => {\n applyStyle();\n }, [childrenCount, applyStyle]);\n\n useImperativeHandle(ref, () => ({\n goNext: () => {\n moveNext();\n },\n goBack: () => {\n moveBack();\n },\n goTo: (index: number) => {\n moveTo(index);\n },\n }));\n\n const removeResizeObserver = () => {\n if (resizeObserver.current && wrapperRef.current) {\n resizeObserver.current.unobserve(wrapperRef.current);\n }\n };\n\n const pauseSlides = () => {\n if (props.pauseOnHover) {\n clearTimeout(timeout.current);\n }\n };\n\n const startSlides = () => {\n const { pauseOnHover, autoplay, duration } = props;\n if (pauseOnHover && autoplay) {\n timeout.current = setTimeout(() => moveNext(), duration);\n }\n };\n\n const moveNext = () => {\n const { children, infinite } = props;\n if (!infinite && index === React.Children.count(children) - 1) {\n return;\n }\n transitionSlide((index + 1) % React.Children.count(children));\n };\n\n const moveBack = () => {\n const { children, infinite } = props;\n if (!infinite && index === 0) {\n return;\n }\n transitionSlide(index === 0 ? React.Children.count(children) - 1 : index - 1);\n };\n\n const preTransition: ButtonClick = (event) => {\n const { currentTarget } = event;\n if (currentTarget.dataset.type === 'prev') {\n moveBack();\n } else {\n moveNext();\n }\n };\n\n const transitionSlide = (newIndex: number) => {\n const existingTweens = tweenGroup.current.getAll();\n if (!existingTweens.length) {\n if (!innerWrapperRef.current?.children[newIndex]) {\n newIndex = 0;\n }\n clearTimeout(timeout.current);\n const value = { opacity: 0, scale: 1 };\n\n const animate = () => {\n requestAnimationFrame(animate);\n tweenGroup.current.update();\n };\n\n animate();\n\n const tween = new TWEEN.Tween(value, tweenGroup.current)\n .to({ opacity: 1, scale: props.scale }, props.transitionDuration)\n .onUpdate((value) => {\n if (!innerWrapperRef.current) {\n return;\n }\n innerWrapperRef.current.children[newIndex].style.opacity = value.opacity;\n innerWrapperRef.current.children[index].style.opacity = 1 - value.opacity;\n innerWrapperRef.current.children[\n index\n ].style.transform = `scale(${value.scale})`;\n })\n .start();\n tween.easing(getEasing(props.easing));\n tween.onComplete(() => {\n if (innerWrapperRef.current) {\n setIndex(newIndex);\n innerWrapperRef.current.children[index].style.transform = `scale(1)`;\n }\n if (typeof props.onChange === 'function') {\n props.onChange(index, newIndex);\n }\n });\n }\n };\n\n const moveTo = (index: number) => {\n transitionSlide(index);\n };\n\n const navigate: ButtonClick = (event) => {\n const { currentTarget } = event;\n if (!currentTarget.dataset.key) {\n return;\n }\n if (parseInt(currentTarget.dataset.key) !== index) {\n moveTo(parseInt(currentTarget.dataset.key));\n }\n };\n\n return (\n <div dir=\"ltr\" aria-roledescription=\"carousel\">\n <div\n className={`react-slideshow-container ${props.cssClass || ''}`}\n onMouseEnter={pauseSlides}\n onMouseOver={pauseSlides}\n onMouseLeave={startSlides}\n ref={props.ref}\n >\n {props.arrows && showPreviousArrow(props, index, preTransition)}\n <div\n className={`react-slideshow-fadezoom-wrapper ${props.cssClass}`}\n ref={wrapperRef}\n >\n <div className=\"react-slideshow-fadezoom-images-wrap\" ref={innerWrapperRef}>\n {(React.Children.map(props.children, (thisArg) => thisArg) || []).map(\n (each, key) => (\n <div\n style={{\n opacity: key === index ? '1' : '0',\n zIndex: key === index ? '1' : '0',\n }}\n data-index={key}\n key={key}\n aria-roledescription=\"slide\"\n aria-hidden={key === index ? 'false' : 'true'}\n >\n {each}\n </div>\n )\n )}\n </div>\n </div>\n {props.arrows && showNextArrow(props, index, preTransition)}\n </div>\n {props.indicators && showIndicators(props, index, navigate)}\n </div>\n );\n});\n\nFadeZoom.defaultProps = defaultProps;\n","import React from 'react';\nimport { FadeZoom } from './fadezoom';\nimport { defaultProps } from './props';\nimport { FadeProps, SlideshowRef } from './types';\n\nexport const Fade = React.forwardRef<SlideshowRef, FadeProps>((props, ref) => {\n return <FadeZoom {...props} scale={1} ref={ref} />;\n});\n\nFade.defaultProps = defaultProps;\n","import React from 'react';\nimport { FadeZoom } from './fadezoom';\nimport { defaultProps } from './props';\nimport { SlideshowRef, ZoomProps } from './types';\n\nexport const Zoom = React.forwardRef<SlideshowRef, ZoomProps>((props, ref) => {\n return <FadeZoom {...props} ref={ref} />;\n});\n\nZoom.defaultProps = defaultProps;\n","import React, {\n useState,\n useRef,\n useEffect,\n useMemo,\n useImperativeHandle,\n useCallback,\n} from 'react';\nimport ResizeObserver from 'resize-observer-polyfill';\nimport TWEEN from '@tweenjs/tween.js';\nimport {\n getEasing,\n getResponsiveSettings,\n getStartingIndex,\n showIndicators,\n showNextArrow,\n showPreviousArrow,\n} from './helpers';\nimport { ButtonClick, SlideshowRef, SlideProps } from './types';\nimport { defaultProps } from './props';\n\nexport const Slide = React.forwardRef<SlideshowRef, SlideProps>((props, ref) => {\n const [index, setIndex] = useState(getStartingIndex(props.children, props.defaultIndex));\n const [wrapperWidth, setWrapperWidth] = useState<number>(0);\n const wrapperRef = useRef<HTMLDivElement>(null);\n const innerWrapperRef = useRef<any>(null);\n const tweenGroup = useRef(new TWEEN.Group());\n const responsiveSettings = useMemo(\n () => getResponsiveSettings(wrapperWidth, props.responsive),\n [wrapperWidth, props.responsive]\n );\n const slidesToScroll = useMemo(() => {\n if (responsiveSettings) {\n return responsiveSettings.settings.slidesToScroll;\n }\n return props.slidesToScroll || 1;\n }, [responsiveSettings, props.slidesToScroll]);\n const slidesToShow = useMemo(() => {\n if (responsiveSettings) {\n return responsiveSettings.settings.slidesToShow;\n }\n return props.slidesToShow || 1;\n }, [responsiveSettings, props.slidesToShow]);\n const childrenCount = useMemo(() => React.Children.count(props.children), [props.children]);\n const eachChildWidth = useMemo(() => wrapperWidth / slidesToShow, [wrapperWidth, slidesToShow]);\n const timeout = useRef<NodeJS.Timeout>();\n const resizeObserver = useRef<any>();\n let startingClientX: number;\n let dragging: boolean = false;\n let distanceSwiped: number = 0;\n\n const applyStyle = useCallback(() => {\n if (innerWrapperRef.current) {\n const fullwidth = wrapperWidth * innerWrapperRef.current.children.length;\n innerWrapperRef.current.style.width = `${fullwidth}px`;\n for (let index = 0; index < innerWrapperRef.current.children.length; index++) {\n const eachDiv = innerWrapperRef.current.children[index];\n if (eachDiv) {\n eachDiv.style.width = `${eachChildWidth}px`;\n eachDiv.style.display = `block`;\n }\n }\n }\n }, [wrapperWidth, eachChildWidth]);\n\n const initResizeObserver = useCallback(() => {\n if (wrapperRef.current) {\n resizeObserver.current = new ResizeObserver((entries) => {\n if (!entries) return;\n setWidth();\n });\n resizeObserver.current.observe(wrapperRef.current);\n }\n }, [wrapperRef]);\n\n const play = useCallback(() => {\n const { autoplay, infinite, duration } = props;\n if (autoplay && (infinite || index < childrenCount - 1)) {\n timeout.current = setTimeout(moveNext, duration);\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [props, childrenCount, index]);\n\n useEffect(() => {\n applyStyle();\n }, [wrapperWidth, applyStyle]);\n\n useEffect(() => {\n initResizeObserver();\n return () => {\n tweenGroup.current.removeAll();\n clearTimeout(timeout.current);\n removeResizeObserver();\n };\n }, [wrapperRef, initResizeObserver, tweenGroup]);\n\n useEffect(() => {\n clearTimeout(timeout.current);\n play();\n }, [index, wrapperWidth, props.autoplay, play]);\n\n useImperativeHandle(ref, () => ({\n goNext: () => {\n moveNext();\n },\n goBack: () => {\n moveBack();\n },\n goTo: (index: number) => {\n moveTo(index);\n },\n }));\n\n const removeResizeObserver = () => {\n if (resizeObserver && wrapperRef.current) {\n resizeObserver.current.unobserve(wrapperRef.current);\n }\n };\n\n const pauseSlides = () => {\n if (props.pauseOnHover) {\n clearTimeout(timeout.current);\n }\n };\n\n const swipe = (event: React.MouseEvent | React.TouchEvent) => {\n if (props.canSwipe && dragging) {\n let clientX;\n if (window.TouchEvent && event.nativeEvent instanceof TouchEvent) {\n clientX = event.nativeEvent.touches[0].pageX;\n } else if (event.nativeEvent instanceof MouseEvent) {\n clientX = event.nativeEvent.clientX;\n }\n if (clientX && startingClientX) {\n let translateValue = eachChildWidth * (index + getOffset());\n const distance = clientX - startingClientX;\n if (!props.infinite && index === childrenCount - slidesToScroll && distance < 0) {\n // if it is the last and infinite is false and you're swiping left\n // then nothing happens\n return;\n }\n if (!props.infinite && index === 0 && distance > 0) {\n // if it is the first and infinite is false and you're swiping right\n // then nothing happens\n return;\n }\n distanceSwiped = distance;\n translateValue -= distanceSwiped;\n innerWrapperRef.current.style.transform = `translate(-${translateValue}px)`;\n }\n }\n };\n\n const moveNext = () => {\n if (!props.infinite && index === childrenCount - slidesToScroll) {\n return;\n }\n const nextIndex = calculateIndex(index + slidesToScroll);\n transitionSlide(nextIndex);\n };\n\n const moveBack = () => {\n if (!props.infinite && index === 0) {\n return;\n }\n let previousIndex = index - slidesToScroll;\n if (previousIndex % slidesToScroll) {\n previousIndex = Math.ceil(previousIndex / slidesToScroll) * slidesToScroll;\n }\n transitionSlide(previousIndex);\n };\n\n const goToSlide: ButtonClick = ({ currentTarget }) => {\n if (!currentTarget.dataset.key) {\n return;\n }\n const datasetKey = parseInt(currentTarget.dataset.key);\n moveTo(datasetKey * slidesToScroll);\n };\n\n const moveTo = (index: number) => {\n transitionSlide(calculateIndex(index));\n };\n\n const calculateIndex = (nextIndex: number): number => {\n if (nextIndex < childrenCount && nextIndex + slidesToScroll > childrenCount) {\n if ((childrenCount - slidesToScroll) % slidesToScroll) {\n return childrenCount - slidesToScroll;\n }\n return nextIndex;\n }\n return nextIndex;\n };\n\n const startSlides = () => {\n if (dragging) {\n endSwipe();\n } else if (props.pauseOnHover && props.autoplay) {\n timeout.current = setTimeout(moveNext, props.duration);\n }\n };\n\n const moveSlides: ButtonClick = ({ currentTarget: { dataset } }) => {\n if (dataset.type === 'next') {\n moveNext();\n } else {\n moveBack();\n }\n };\n\n const renderPreceedingSlides = () => {\n return React.Children.toArray(props.children)\n .slice(-slidesToShow)\n .map((each, index) => (\n <div\n data-index={index - slidesToShow}\n aria-roledescription=\"slide\"\n aria-hidden=\"true\"\n key={index - slidesToShow}\n >\n {each}\n </div>\n ));\n };\n\n const renderTrailingSlides = () => {\n if (!props.infinite && slidesToShow === slidesToScroll) {\n return;\n }\n return React.Children.toArray(props.children)\n .slice(0, slidesToShow)\n .map((each, index) => (\n <div\n data-index={childrenCount + index}\n aria-roledescription=\"slide\"\n aria-hidden=\"true\"\n key={childrenCount + index}\n >\n {each}\n </div>\n ));\n };\n\n const setWidth = () => {\n if (wrapperRef.current) {\n setWrapperWidth(wrapperRef.current.clientWidth);\n }\n };\n\n const startSwipe = (event: React.MouseEvent | React.TouchEvent) => {\n if (props.canSwipe) {\n if (window.TouchEvent && event.nativeEvent instanceof TouchEvent) {\n startingClientX = event.nativeEvent.touches[0].pageX;\n } else if (event.nativeEvent instanceof MouseEvent) {\n startingClientX = event.nativeEvent.clientX;\n }\n clearTimeout(timeout.current);\n dragging = true;\n }\n };\n\n const endSwipe = () => {\n if (props.canSwipe) {\n dragging = false;\n if (Math.abs(distanceSwiped) / wrapperWidth > 0.2) {\n if (distanceSwiped < 0) {\n moveNext();\n } else {\n moveBack();\n }\n } else {\n if (Math.abs(distanceSwiped) > 0) {\n transitionSlide(index, 300);\n }\n }\n }\n };\n\n const transitionSlide = (toIndex: number, animationDuration?: number) => {\n const transitionDuration = animationDuration || props.transitionDuration;\n const currentIndex = index;\n const existingTweens = tweenGroup.current.getAll();\n if (!wrapperRef.current) {\n return;\n }\n const childWidth = wrapperRef.current.clientWidth / slidesToShow;\n if (!existingTweens.length) {\n clearTimeout(timeout.current);\n const value = {\n margin: -childWidth * (currentIndex + getOffset()) + distanceSwiped,\n };\n const tween = new TWEEN.Tween(value, tweenGroup.current)\n .to({ margin: -childWidth * (toIndex + getOffset()) }, transitionDuration)\n .onUpdate((value) => {\n if (innerWrapperRef.current) {\n innerWrapperRef.current.style.transform = `translate(${value.margin}px)`;\n }\n })\n .start();\n tween.easing(getEasing(props.easing));\n const animate = () => {\n requestAnimationFrame(animate);\n tweenGroup.current.update();\n };\n\n animate();\n\n tween.onComplete(() => {\n distanceSwiped = 0;\n let newIndex = toIndex;\n if (newIndex < 0) {\n newIndex = childrenCount - slidesToScroll;\n } else if (newIndex >= childrenCount) {\n newIndex = 0;\n }\n\n if (typeof props.onChange === 'function') {\n props.onChange(index, newIndex);\n }\n setIndex(newIndex);\n });\n }\n };\n\n const isSlideActive = (key: number) => {\n return key < index + slidesToShow && key >= index;\n };\n\n const getOffset = (): number => {\n if (!props.infinite) {\n return 0;\n }\n return slidesToShow;\n };\n\n const style = {\n transform: `translate(-${(index + getOffset()) * eachChildWidth}px)`,\n };\n return (\n <div dir=\"ltr\" aria-roledescription=\"carousel\">\n <div\n className=\"react-slideshow-container\"\n onMouseEnter={pauseSlides}\n onMouseOver={pauseSlides}\n onMouseLeave={startSlides}\n onMouseDown={startSwipe}\n onMouseUp={endSwipe}\n onMouseMove={swipe}\n onTouchStart={startSwipe}\n onTouchEnd={endSwipe}\n onTouchCancel={endSwipe}\n onTouchMove={swipe}\n >\n {props.arrows && showPreviousArrow(props, index, moveSlides)}\n <div\n className={`react-slideshow-wrapper slide ${props.cssClass || ''}`}\n ref={wrapperRef}\n >\n <div className=\"images-wrap\" style={style} ref={innerWrapperRef}>\n {props.infinite && renderPreceedingSlides()}\n {(React.Children.map(props.children, (thisArg) => thisArg) || []).map(\n (each, key) => {\n const isThisSlideActive = isSlideActive(key);\n return (\n <div\n data-index={key}\n key={key}\n className={isThisSlideActive ? 'active' : ''}\n aria-roledescription=\"slide\"\n aria-hidden={isThisSlideActive ? 'false' : 'true'}\n >\n {each}\n </div>\n );\n }\n )}\n {renderTrailingSlides()}\n </div>\n </div>\n {props.arrows && showNextArrow(props, index, moveSlides)}\n </div>\n {props.indicators && showIndicators(props, index, goToSlide, responsiveSettings)}\n </div>\n );\n});\n\nSlide.defaultProps = defaultProps;\n"],"names":["getStartingIndex","children","defaultIndex","React","Children","count","getResponsiveSettings","wrapperWidth","responsive","window","Array","isArray","find","each","breakpoint","EASING_METHODS","linear","TWEEN","Easing","Linear","None","ease","Quadratic","InOut","In","Out","cubic","Cubic","getEasing","easeMethod","showPreviousArrow","currentIndex","moveSlides","prevArrow","infinite","isDisabled","props","disabled","onClick","cloneElement","className","type","width","height","viewBox","d","showNextArrow","properties","nextArrow","slidesToScroll","showDefaultIndicator","isCurrentPageActive","key","indicatorProps","showCustomIndicator","eachIndicator","showIndicators","navigate","responsiveSettings","indicators","settings","pages","Math","ceil","from","length","_","floor","defaultProps","duration","transitionDuration","autoplay","arrows","pauseOnHover","easing","canSwipe","cssClass","FadeZoom","forwardRef","ref","useState","index","setIndex","wrapperRef","useRef","innerWrapperRef","tweenGroup","Group","timeout","resizeObserver","childrenCount","useMemo","applyStyle","useCallback","current","clientWidth","fullwidth","style","eachDiv","left","display","initResizeObserver","ResizeObserver","entries","observe","play","setTimeout","moveNext","useEffect","removeAll","clearTimeout","removeResizeObserver","useImperativeHandle","goNext","goBack","moveBack","goTo","moveTo","unobserve","pauseSlides","startSlides","transitionSlide","preTransition","event","currentTarget","dataset","newIndex","existingTweens","getAll","value","opacity","scale","animate","requestAnimationFrame","update","tween","Tween","to","onUpdate","transform","start","onComplete","onChange","parseInt","dir","onMouseEnter","onMouseOver","onMouseLeave","map","thisArg","zIndex","Fade","Zoom","Slide","setWrapperWidth","slidesToShow","eachChildWidth","startingClientX","dragging","distanceSwiped","setWidth","swipe","clientX","TouchEvent","nativeEvent","touches","pageX","MouseEvent","translateValue","getOffset","distance","nextIndex","calculateIndex","previousIndex","goToSlide","datasetKey","endSwipe","renderPreceedingSlides","toArray","slice","renderTrailingSlides","startSwipe","abs","toIndex","animationDuration","childWidth","margin","isSlideActive","onMouseDown","onMouseUp","onMouseMove","onTouchStart","onTouchEnd","onTouchCancel","onTouchMove","isThisSlideActive"],"mappings":"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"}
1
+ {"version":3,"file":"react-slideshow-image.esm.js","sources":["../src/helpers.tsx","../src/props.ts","../src/fadezoom.tsx","../src/fade.tsx","../src/zoom.tsx","../src/slide.tsx"],"sourcesContent":["import React, { ReactNode } from 'react';\nimport {\n ButtonClick,\n FadeProps,\n IndicatorPropsType,\n Responsive,\n SlideProps,\n TweenEasingFn,\n ZoomProps,\n} from './types';\nimport TWEEN from '@tweenjs/tween.js';\n\nexport const getStartingIndex = (children: ReactNode, defaultIndex?: number): number => {\n if (defaultIndex && defaultIndex < React.Children.count(children)) {\n return defaultIndex;\n }\n return 0;\n};\n\nexport const getResponsiveSettings = (\n wrapperWidth: number,\n responsive?: Array<Responsive>\n): Responsive | undefined => {\n if (typeof window !== 'undefined' && Array.isArray(responsive)) {\n return responsive.find((each) => each.breakpoint <= wrapperWidth);\n }\n return;\n};\n\nconst EASING_METHODS: { [key: string]: TweenEasingFn } = {\n linear: TWEEN.Easing.Linear.None,\n ease: TWEEN.Easing.Quadratic.InOut,\n 'ease-in': TWEEN.Easing.Quadratic.In,\n 'ease-out': TWEEN.Easing.Quadratic.Out,\n cubic: TWEEN.Easing.Cubic.InOut,\n 'cubic-in': TWEEN.Easing.Cubic.In,\n 'cubic-out': TWEEN.Easing.Cubic.Out,\n};\n\nexport const getEasing = (easeMethod?: string): TweenEasingFn => {\n if (easeMethod) {\n return EASING_METHODS[easeMethod];\n }\n return EASING_METHODS.linear;\n};\n\nexport const showPreviousArrow = (\n { prevArrow, infinite }: FadeProps | SlideProps | ZoomProps,\n currentIndex: number,\n moveSlides: ButtonClick\n): ReactNode => {\n const isDisabled = currentIndex <= 0 && !infinite;\n const props = {\n 'data-type': 'prev',\n 'aria-label': 'Previous Slide',\n disabled: isDisabled,\n onClick: moveSlides,\n };\n if (prevArrow) {\n return React.cloneElement(prevArrow, {\n className: `${prevArrow.props.className || ''} nav ${isDisabled ? 'disabled' : ''}`,\n ...props,\n });\n }\n const className = `nav default-nav ${isDisabled ? 'disabled' : ''}`;\n return (\n <button type=\"button\" className={className} {...props}>\n <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\">\n <path d=\"M16.67 0l2.83 2.829-9.339 9.175 9.339 9.167-2.83 2.829-12.17-11.996z\" />\n </svg>\n </button>\n );\n};\n\nexport const showNextArrow = (\n properties: FadeProps | SlideProps | ZoomProps,\n currentIndex: number,\n moveSlides: ButtonClick\n) => {\n const { nextArrow, infinite, children } = properties;\n let slidesToScroll = 1;\n if ('slidesToScroll' in properties) {\n slidesToScroll = properties.slidesToScroll || 1;\n }\n const isDisabled = currentIndex >= React.Children.count(children) - slidesToScroll && !infinite;\n const props = {\n 'data-type': 'next',\n 'aria-label': 'Next Slide',\n disabled: isDisabled,\n onClick: moveSlides,\n };\n if (nextArrow) {\n return React.cloneElement(nextArrow, {\n className: `${nextArrow.props.className || ''} nav ${isDisabled ? 'disabled' : ''}`,\n ...props,\n });\n }\n const className = `nav default-nav ${isDisabled ? 'disabled' : ''}`;\n return (\n <button type=\"button\" className={className} {...props}>\n <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\">\n <path d=\"M5 3l3.057-3 11.943 12-11.943 12-3.057-3 9-9z\" />\n </svg>\n </button>\n );\n};\n\nconst showDefaultIndicator = (\n isCurrentPageActive: boolean,\n key: number,\n indicatorProps: IndicatorPropsType\n) => {\n return (\n <li key={key}>\n <button\n type=\"button\"\n className={`each-slideshow-indicator ${isCurrentPageActive ? 'active' : ''}`}\n {...indicatorProps}\n />\n </li>\n );\n};\n\nconst showCustomIndicator = (\n isCurrentPageActive: boolean,\n key: number,\n indicatorProps: any,\n eachIndicator: any\n) => {\n return React.cloneElement(eachIndicator, {\n className: `${eachIndicator.props.className} ${isCurrentPageActive ? 'active' : ''}`,\n key,\n ...indicatorProps,\n });\n};\n\nexport const showIndicators = (\n props: FadeProps | SlideProps | ZoomProps,\n currentIndex: number,\n navigate: ButtonClick,\n responsiveSettings?: Responsive\n): ReactNode => {\n const { children, indicators } = props;\n let slidesToScroll = 1;\n if (responsiveSettings) {\n slidesToScroll = responsiveSettings?.settings.slidesToScroll;\n } else if ('slidesToScroll' in props) {\n slidesToScroll = props.slidesToScroll || 1;\n }\n const pages = Math.ceil(React.Children.count(children) / slidesToScroll);\n return (\n <ul className=\"indicators\">\n {Array.from({ length: pages }, (_, key) => {\n const indicatorProps: IndicatorPropsType = {\n 'data-key': key,\n 'aria-label': `Go to slide ${key + 1}`,\n onClick: navigate,\n };\n const isCurrentPageActive =\n Math.floor((currentIndex + slidesToScroll - 1) / slidesToScroll) === key;\n if (typeof indicators === 'function') {\n return showCustomIndicator(\n isCurrentPageActive,\n key,\n indicatorProps,\n indicators(key)\n );\n }\n return showDefaultIndicator(isCurrentPageActive, key, indicatorProps);\n })}\n </ul>\n );\n};\n","export const defaultProps = {\n duration: 5000,\n transitionDuration: 1000,\n defaultIndex: 0,\n infinite: true,\n autoplay: true,\n indicators: false,\n arrows: true,\n pauseOnHover: true,\n easing: 'linear',\n canSwipe: true,\n cssClass: '',\n responsive: [],\n};\n","import React, {\n useState,\n useRef,\n useEffect,\n useMemo,\n useImperativeHandle,\n useCallback,\n} from 'react';\nimport ResizeObserver from 'resize-observer-polyfill';\nimport TWEEN from '@tweenjs/tween.js';\nimport {\n getEasing,\n getStartingIndex,\n showIndicators,\n showNextArrow,\n showPreviousArrow,\n} from './helpers';\nimport { ButtonClick, SlideshowRef, ZoomProps } from './types';\nimport { defaultProps } from './props';\n\nexport const FadeZoom = React.forwardRef<SlideshowRef, ZoomProps>((props, ref) => {\n const [index, setIndex] = useState<number>(\n getStartingIndex(props.children, props.defaultIndex)\n );\n const wrapperRef = useRef<HTMLDivElement>(null);\n const innerWrapperRef = useRef<any>(null);\n const tweenGroup = useRef(new TWEEN.Group());\n const timeout = useRef<NodeJS.Timeout>();\n const resizeObserver = useRef<any>();\n const childrenCount = useMemo(() => React.Children.count(props.children), [props.children]);\n\n const applyStyle = useCallback(() => {\n if (innerWrapperRef.current && wrapperRef.current) {\n const wrapperWidth = wrapperRef.current.clientWidth;\n const fullwidth = wrapperWidth * childrenCount;\n innerWrapperRef.current.style.width = `${fullwidth}px`;\n for (let index = 0; index < innerWrapperRef.current.children.length; index++) {\n const eachDiv = innerWrapperRef.current.children[index];\n if (eachDiv) {\n eachDiv.style.width = `${wrapperWidth}px`;\n eachDiv.style.left = `${index * -wrapperWidth}px`;\n eachDiv.style.display = `block`;\n }\n }\n }\n }, [wrapperRef, innerWrapperRef, childrenCount]);\n\n const initResizeObserver = useCallback(() => {\n if (wrapperRef.current) {\n resizeObserver.current = new ResizeObserver((entries) => {\n if (!entries) return;\n applyStyle();\n });\n resizeObserver.current.observe(wrapperRef.current);\n }\n }, [wrapperRef, applyStyle]);\n\n const play = useCallback(() => {\n const { autoplay, children, duration, infinite } = props;\n if (\n autoplay &&\n React.Children.count(children) > 1 &&\n (infinite || index < React.Children.count(children) - 1)\n ) {\n timeout.current = setTimeout(moveNext, duration);\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [props, index]);\n\n useEffect(() => {\n initResizeObserver();\n return () => {\n tweenGroup.current.removeAll();\n clearTimeout(timeout.current);\n removeResizeObserver();\n };\n }, [initResizeObserver, tweenGroup]);\n\n useEffect(() => {\n clearTimeout(timeout.current);\n play();\n }, [index, props.autoplay, play]);\n\n useEffect(() => {\n applyStyle();\n }, [childrenCount, applyStyle]);\n\n useImperativeHandle(ref, () => ({\n goNext: () => {\n moveNext();\n },\n goBack: () => {\n moveBack();\n },\n goTo: (index: number, options?: { skipTransition?: boolean }) => {\n if (options?.skipTransition) {\n setIndex(index);\n } else {\n moveTo(index);\n }\n },\n }));\n\n const removeResizeObserver = () => {\n if (resizeObserver.current && wrapperRef.current) {\n resizeObserver.current.unobserve(wrapperRef.current);\n }\n };\n\n const pauseSlides = () => {\n if (props.pauseOnHover) {\n clearTimeout(timeout.current);\n }\n };\n\n const startSlides = () => {\n const { pauseOnHover, autoplay, duration } = props;\n if (pauseOnHover && autoplay) {\n timeout.current = setTimeout(() => moveNext(), duration);\n }\n };\n\n const moveNext = () => {\n const { children, infinite } = props;\n if (!infinite && index === React.Children.count(children) - 1) {\n return;\n }\n transitionSlide((index + 1) % React.Children.count(children));\n };\n\n const moveBack = () => {\n const { children, infinite } = props;\n if (!infinite && index === 0) {\n return;\n }\n transitionSlide(index === 0 ? React.Children.count(children) - 1 : index - 1);\n };\n\n const preTransition: ButtonClick = (event) => {\n const { currentTarget } = event;\n if (currentTarget.dataset.type === 'prev') {\n moveBack();\n } else {\n moveNext();\n }\n };\n\n const transitionSlide = (newIndex: number) => {\n const existingTweens = tweenGroup.current.getAll();\n if (!existingTweens.length) {\n if (!innerWrapperRef.current?.children[newIndex]) {\n newIndex = 0;\n }\n clearTimeout(timeout.current);\n const value = { opacity: 0, scale: 1 };\n\n const animate = () => {\n requestAnimationFrame(animate);\n tweenGroup.current.update();\n };\n\n animate();\n\n const tween = new TWEEN.Tween(value, tweenGroup.current)\n .to({ opacity: 1, scale: props.scale }, props.transitionDuration)\n .onUpdate((value) => {\n if (!innerWrapperRef.current) {\n return;\n }\n innerWrapperRef.current.children[newIndex].style.opacity = value.opacity;\n innerWrapperRef.current.children[index].style.opacity = 1 - value.opacity;\n innerWrapperRef.current.children[\n index\n ].style.transform = `scale(${value.scale})`;\n })\n .start();\n tween.easing(getEasing(props.easing));\n tween.onComplete(() => {\n if (innerWrapperRef.current) {\n setIndex(newIndex);\n innerWrapperRef.current.children[index].style.transform = `scale(1)`;\n }\n if (typeof props.onChange === 'function') {\n props.onChange(index, newIndex);\n }\n });\n }\n };\n\n const moveTo = (gotoIndex: number) => {\n if (gotoIndex !== index) {\n transitionSlide(gotoIndex);\n }\n };\n\n const navigate: ButtonClick = (event) => {\n const { currentTarget } = event;\n if (!currentTarget.dataset.key) {\n return;\n }\n if (parseInt(currentTarget.dataset.key) !== index) {\n moveTo(parseInt(currentTarget.dataset.key));\n }\n };\n\n return (\n <div dir=\"ltr\" aria-roledescription=\"carousel\">\n <div\n className={`react-slideshow-container ${props.cssClass || ''}`}\n onMouseEnter={pauseSlides}\n onMouseOver={pauseSlides}\n onMouseLeave={startSlides}\n >\n {props.arrows && showPreviousArrow(props, index, preTransition)}\n <div\n className={`react-slideshow-fadezoom-wrapper ${props.cssClass}`}\n ref={wrapperRef}\n >\n <div className=\"react-slideshow-fadezoom-images-wrap\" ref={innerWrapperRef}>\n {(React.Children.map(props.children, (thisArg) => thisArg) || []).map(\n (each, key) => (\n <div\n style={{\n opacity: key === index ? '1' : '0',\n zIndex: key === index ? '1' : '0',\n }}\n data-index={key}\n key={key}\n aria-roledescription=\"slide\"\n aria-hidden={key === index ? 'false' : 'true'}\n >\n {each}\n </div>\n )\n )}\n </div>\n </div>\n {props.arrows && showNextArrow(props, index, preTransition)}\n </div>\n {props.indicators && showIndicators(props, index, navigate)}\n </div>\n );\n});\n\nFadeZoom.defaultProps = defaultProps;\n","import React from 'react';\nimport { FadeZoom } from './fadezoom';\nimport { defaultProps } from './props';\nimport { FadeProps, SlideshowRef } from './types';\n\nexport const Fade = React.forwardRef<SlideshowRef, FadeProps>((props, ref) => {\n return <FadeZoom {...props} scale={1} ref={ref} />;\n});\n\nFade.defaultProps = defaultProps;\n","import React from 'react';\nimport { FadeZoom } from './fadezoom';\nimport { defaultProps } from './props';\nimport { SlideshowRef, ZoomProps } from './types';\n\nexport const Zoom = React.forwardRef<SlideshowRef, ZoomProps>((props, ref) => {\n return <FadeZoom {...props} ref={ref} />;\n});\n\nZoom.defaultProps = defaultProps;\n","import React, {\n useState,\n useRef,\n useEffect,\n useMemo,\n useImperativeHandle,\n useCallback,\n} from 'react';\nimport ResizeObserver from 'resize-observer-polyfill';\nimport TWEEN from '@tweenjs/tween.js';\nimport {\n getEasing,\n getResponsiveSettings,\n getStartingIndex,\n showIndicators,\n showNextArrow,\n showPreviousArrow,\n} from './helpers';\nimport { ButtonClick, SlideshowRef, SlideProps } from './types';\nimport { defaultProps } from './props';\n\nexport const Slide = React.forwardRef<SlideshowRef, SlideProps>((props, ref) => {\n const [index, setIndex] = useState(getStartingIndex(props.children, props.defaultIndex));\n const [wrapperWidth, setWrapperWidth] = useState<number>(0);\n const wrapperRef = useRef<HTMLDivElement>(null);\n const innerWrapperRef = useRef<any>(null);\n const tweenGroup = useRef(new TWEEN.Group());\n const responsiveSettings = useMemo(\n () => getResponsiveSettings(wrapperWidth, props.responsive),\n [wrapperWidth, props.responsive]\n );\n const slidesToScroll = useMemo(() => {\n if (responsiveSettings) {\n return responsiveSettings.settings.slidesToScroll;\n }\n return props.slidesToScroll || 1;\n }, [responsiveSettings, props.slidesToScroll]);\n const slidesToShow = useMemo(() => {\n if (responsiveSettings) {\n return responsiveSettings.settings.slidesToShow;\n }\n return props.slidesToShow || 1;\n }, [responsiveSettings, props.slidesToShow]);\n const childrenCount = useMemo(() => React.Children.count(props.children), [props.children]);\n const eachChildWidth = useMemo(() => wrapperWidth / slidesToShow, [wrapperWidth, slidesToShow]);\n const timeout = useRef<NodeJS.Timeout>();\n const resizeObserver = useRef<any>();\n let startingClientX: number;\n let dragging: boolean = false;\n let distanceSwiped: number = 0;\n\n const applyStyle = useCallback(() => {\n if (innerWrapperRef.current) {\n const fullwidth = wrapperWidth * innerWrapperRef.current.children.length;\n innerWrapperRef.current.style.width = `${fullwidth}px`;\n for (let index = 0; index < innerWrapperRef.current.children.length; index++) {\n const eachDiv = innerWrapperRef.current.children[index];\n if (eachDiv) {\n eachDiv.style.width = `${eachChildWidth}px`;\n eachDiv.style.display = `block`;\n }\n }\n }\n }, [wrapperWidth, eachChildWidth]);\n\n const initResizeObserver = useCallback(() => {\n if (wrapperRef.current) {\n resizeObserver.current = new ResizeObserver((entries) => {\n if (!entries) return;\n setWidth();\n });\n resizeObserver.current.observe(wrapperRef.current);\n }\n }, [wrapperRef]);\n\n const play = useCallback(() => {\n const { autoplay, infinite, duration } = props;\n if (autoplay && (infinite || index < childrenCount - 1)) {\n timeout.current = setTimeout(moveNext, duration);\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [props, childrenCount, index]);\n\n useEffect(() => {\n applyStyle();\n }, [wrapperWidth, applyStyle]);\n\n useEffect(() => {\n initResizeObserver();\n return () => {\n tweenGroup.current.removeAll();\n clearTimeout(timeout.current);\n removeResizeObserver();\n };\n }, [wrapperRef, initResizeObserver, tweenGroup]);\n\n useEffect(() => {\n clearTimeout(timeout.current);\n play();\n }, [index, wrapperWidth, props.autoplay, play]);\n\n useImperativeHandle(ref, () => ({\n goNext: () => {\n moveNext();\n },\n goBack: () => {\n moveBack();\n },\n goTo: (index: number, options?: { skipTransition?: boolean }) => {\n if (options?.skipTransition) {\n setIndex(index);\n } else {\n moveTo(index);\n }\n },\n }));\n\n const removeResizeObserver = () => {\n if (resizeObserver && wrapperRef.current) {\n resizeObserver.current.unobserve(wrapperRef.current);\n }\n };\n\n const pauseSlides = () => {\n if (props.pauseOnHover) {\n clearTimeout(timeout.current);\n }\n };\n\n const swipe = (event: React.MouseEvent | React.TouchEvent) => {\n if (props.canSwipe && dragging) {\n let clientX;\n if (window.TouchEvent && event.nativeEvent instanceof TouchEvent) {\n clientX = event.nativeEvent.touches[0].pageX;\n } else if (event.nativeEvent instanceof MouseEvent) {\n clientX = event.nativeEvent.clientX;\n }\n if (clientX && startingClientX) {\n let translateValue = eachChildWidth * (index + getOffset());\n const distance = clientX - startingClientX;\n if (!props.infinite && index === childrenCount - slidesToScroll && distance < 0) {\n // if it is the last and infinite is false and you're swiping left\n // then nothing happens\n return;\n }\n if (!props.infinite && index === 0 && distance > 0) {\n // if it is the first and infinite is false and you're swiping right\n // then nothing happens\n return;\n }\n distanceSwiped = distance;\n translateValue -= distanceSwiped;\n innerWrapperRef.current.style.transform = `translate(-${translateValue}px)`;\n }\n }\n };\n\n const moveNext = () => {\n if (!props.infinite && index === childrenCount - slidesToScroll) {\n return;\n }\n const nextIndex = calculateIndex(index + slidesToScroll);\n transitionSlide(nextIndex);\n };\n\n const moveBack = () => {\n if (!props.infinite && index === 0) {\n return;\n }\n let previousIndex = index - slidesToScroll;\n if (previousIndex % slidesToScroll) {\n previousIndex = Math.ceil(previousIndex / slidesToScroll) * slidesToScroll;\n }\n transitionSlide(previousIndex);\n };\n\n const goToSlide: ButtonClick = ({ currentTarget }) => {\n if (!currentTarget.dataset.key) {\n return;\n }\n const datasetKey = parseInt(currentTarget.dataset.key);\n moveTo(datasetKey * slidesToScroll);\n };\n\n const moveTo = (index: number) => {\n transitionSlide(calculateIndex(index));\n };\n\n const calculateIndex = (nextIndex: number): number => {\n if (nextIndex < childrenCount && nextIndex + slidesToScroll > childrenCount) {\n if ((childrenCount - slidesToScroll) % slidesToScroll) {\n return childrenCount - slidesToScroll;\n }\n return nextIndex;\n }\n return nextIndex;\n };\n\n const startSlides = () => {\n if (dragging) {\n endSwipe();\n } else if (props.pauseOnHover && props.autoplay) {\n timeout.current = setTimeout(moveNext, props.duration);\n }\n };\n\n const moveSlides: ButtonClick = ({ currentTarget: { dataset } }) => {\n if (dataset.type === 'next') {\n moveNext();\n } else {\n moveBack();\n }\n };\n\n const renderPreceedingSlides = () => {\n return React.Children.toArray(props.children)\n .slice(-slidesToShow)\n .map((each, index) => (\n <div\n data-index={index - slidesToShow}\n aria-roledescription=\"slide\"\n aria-hidden=\"true\"\n key={index - slidesToShow}\n >\n {each}\n </div>\n ));\n };\n\n const renderTrailingSlides = () => {\n if (!props.infinite && slidesToShow === slidesToScroll) {\n return;\n }\n return React.Children.toArray(props.children)\n .slice(0, slidesToShow)\n .map((each, index) => (\n <div\n data-index={childrenCount + index}\n aria-roledescription=\"slide\"\n aria-hidden=\"true\"\n key={childrenCount + index}\n >\n {each}\n </div>\n ));\n };\n\n const setWidth = () => {\n if (wrapperRef.current) {\n setWrapperWidth(wrapperRef.current.clientWidth);\n }\n };\n\n const startSwipe = (event: React.MouseEvent | React.TouchEvent) => {\n if (props.canSwipe) {\n if (window.TouchEvent && event.nativeEvent instanceof TouchEvent) {\n startingClientX = event.nativeEvent.touches[0].pageX;\n } else if (event.nativeEvent instanceof MouseEvent) {\n startingClientX = event.nativeEvent.clientX;\n }\n clearTimeout(timeout.current);\n dragging = true;\n }\n };\n\n const endSwipe = () => {\n if (props.canSwipe) {\n dragging = false;\n if (Math.abs(distanceSwiped) / wrapperWidth > 0.2) {\n if (distanceSwiped < 0) {\n moveNext();\n } else {\n moveBack();\n }\n } else {\n if (Math.abs(distanceSwiped) > 0) {\n transitionSlide(index, 300);\n }\n }\n }\n };\n\n const transitionSlide = (toIndex: number, animationDuration?: number) => {\n const transitionDuration = animationDuration || props.transitionDuration;\n const currentIndex = index;\n const existingTweens = tweenGroup.current.getAll();\n if (!wrapperRef.current) {\n return;\n }\n const childWidth = wrapperRef.current.clientWidth / slidesToShow;\n if (!existingTweens.length) {\n clearTimeout(timeout.current);\n const value = {\n margin: -childWidth * (currentIndex + getOffset()) + distanceSwiped,\n };\n const tween = new TWEEN.Tween(value, tweenGroup.current)\n .to({ margin: -childWidth * (toIndex + getOffset()) }, transitionDuration)\n .onUpdate((value) => {\n if (innerWrapperRef.current) {\n innerWrapperRef.current.style.transform = `translate(${value.margin}px)`;\n }\n })\n .start();\n tween.easing(getEasing(props.easing));\n const animate = () => {\n requestAnimationFrame(animate);\n tweenGroup.current.update();\n };\n\n animate();\n\n tween.onComplete(() => {\n distanceSwiped = 0;\n let newIndex = toIndex;\n if (newIndex < 0) {\n newIndex = childrenCount - slidesToScroll;\n } else if (newIndex >= childrenCount) {\n newIndex = 0;\n }\n\n if (typeof props.onChange === 'function') {\n props.onChange(index, newIndex);\n }\n setIndex(newIndex);\n });\n }\n };\n\n const isSlideActive = (key: number) => {\n return key < index + slidesToShow && key >= index;\n };\n\n const getOffset = (): number => {\n if (!props.infinite) {\n return 0;\n }\n return slidesToShow;\n };\n\n const style = {\n transform: `translate(-${(index + getOffset()) * eachChildWidth}px)`,\n };\n return (\n <div dir=\"ltr\" aria-roledescription=\"carousel\">\n <div\n className=\"react-slideshow-container\"\n onMouseEnter={pauseSlides}\n onMouseOver={pauseSlides}\n onMouseLeave={startSlides}\n onMouseDown={startSwipe}\n onMouseUp={endSwipe}\n onMouseMove={swipe}\n onTouchStart={startSwipe}\n onTouchEnd={endSwipe}\n onTouchCancel={endSwipe}\n onTouchMove={swipe}\n >\n {props.arrows && showPreviousArrow(props, index, moveSlides)}\n <div\n className={`react-slideshow-wrapper slide ${props.cssClass || ''}`}\n ref={wrapperRef}\n >\n <div className=\"images-wrap\" style={style} ref={innerWrapperRef}>\n {props.infinite && renderPreceedingSlides()}\n {(React.Children.map(props.children, (thisArg) => thisArg) || []).map(\n (each, key) => {\n const isThisSlideActive = isSlideActive(key);\n return (\n <div\n data-index={key}\n key={key}\n className={isThisSlideActive ? 'active' : ''}\n aria-roledescription=\"slide\"\n aria-hidden={isThisSlideActive ? 'false' : 'true'}\n >\n {each}\n </div>\n );\n }\n )}\n {renderTrailingSlides()}\n </div>\n </div>\n {props.arrows && showNextArrow(props, index, moveSlides)}\n </div>\n {props.indicators && showIndicators(props, index, goToSlide, responsiveSettings)}\n </div>\n );\n});\n\nSlide.defaultProps = defaultProps;\n"],"names":["getStartingIndex","children","defaultIndex","React","Children","count","getResponsiveSettings","wrapperWidth","responsive","window","Array","isArray","find","each","breakpoint","EASING_METHODS","linear","TWEEN","Easing","Linear","None","ease","Quadratic","InOut","In","Out","cubic","Cubic","getEasing","easeMethod","showPreviousArrow","currentIndex","moveSlides","prevArrow","infinite","isDisabled","props","disabled","onClick","cloneElement","className","type","width","height","viewBox","d","showNextArrow","properties","nextArrow","slidesToScroll","showDefaultIndicator","isCurrentPageActive","key","indicatorProps","showCustomIndicator","eachIndicator","showIndicators","navigate","responsiveSettings","indicators","settings","pages","Math","ceil","from","length","_","floor","defaultProps","duration","transitionDuration","autoplay","arrows","pauseOnHover","easing","canSwipe","cssClass","FadeZoom","forwardRef","ref","useState","index","setIndex","wrapperRef","useRef","innerWrapperRef","tweenGroup","Group","timeout","resizeObserver","childrenCount","useMemo","applyStyle","useCallback","current","clientWidth","fullwidth","style","eachDiv","left","display","initResizeObserver","ResizeObserver","entries","observe","play","setTimeout","moveNext","useEffect","removeAll","clearTimeout","removeResizeObserver","useImperativeHandle","goNext","goBack","moveBack","goTo","options","skipTransition","moveTo","unobserve","pauseSlides","startSlides","transitionSlide","preTransition","event","currentTarget","dataset","newIndex","existingTweens","getAll","value","opacity","scale","animate","requestAnimationFrame","update","tween","Tween","to","onUpdate","transform","start","onComplete","onChange","gotoIndex","parseInt","dir","onMouseEnter","onMouseOver","onMouseLeave","map","thisArg","zIndex","Fade","Zoom","Slide","setWrapperWidth","slidesToShow","eachChildWidth","startingClientX","dragging","distanceSwiped","setWidth","swipe","clientX","TouchEvent","nativeEvent","touches","pageX","MouseEvent","translateValue","getOffset","distance","nextIndex","calculateIndex","previousIndex","goToSlide","datasetKey","endSwipe","renderPreceedingSlides","toArray","slice","renderTrailingSlides","startSwipe","abs","toIndex","animationDuration","childWidth","margin","isSlideActive","onMouseDown","onMouseUp","onMouseMove","onTouchStart","onTouchEnd","onTouchCancel","onTouchMove","isThisSlideActive"],"mappings":"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"}
package/dist/types.d.ts CHANGED
@@ -64,5 +64,7 @@ export declare type TweenEasingFn = (amount: number) => number;
64
64
  export declare type SlideshowRef = {
65
65
  goNext: () => void;
66
66
  goBack: () => void;
67
- goTo: (index: number) => void;
67
+ goTo: (index: number, options?: {
68
+ skipTransition?: boolean;
69
+ }) => void;
68
70
  };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "react-slideshow-image",
3
- "version": "4.0.4",
3
+ "version": "4.1.0",
4
4
  "description": "An image slideshow with react",
5
5
  "license": "MIT",
6
6
  "main": "dist/index.js",