react-slideshow-image 4.0.2 → 4.0.5

Sign up to get free protection for your applications and to get access to all the features.
package/dist/helpers.d.ts CHANGED
@@ -1,7 +1,8 @@
1
1
  import { ReactNode } from 'react';
2
- import { ButtonClick, FadeProps, SlideProps, TweenEasingFn, ZoomProps } from './types';
2
+ import { ButtonClick, FadeProps, Responsive, SlideProps, TweenEasingFn, ZoomProps } from './types';
3
3
  export declare const getStartingIndex: (children: ReactNode, defaultIndex?: number | undefined) => number;
4
+ export declare const getResponsiveSettings: (wrapperWidth: number, responsive?: Responsive[] | undefined) => Responsive | undefined;
4
5
  export declare const getEasing: (easeMethod?: string | undefined) => TweenEasingFn;
5
6
  export declare const showPreviousArrow: ({ prevArrow, infinite }: FadeProps | SlideProps | ZoomProps, currentIndex: number, moveSlides: ButtonClick) => ReactNode;
6
7
  export declare const showNextArrow: (properties: FadeProps | SlideProps | ZoomProps, currentIndex: number, moveSlides: ButtonClick) => JSX.Element;
7
- export declare const showIndicators: (props: FadeProps | SlideProps | ZoomProps, currentIndex: number, navigate: ButtonClick) => ReactNode;
8
+ export declare const showIndicators: (props: FadeProps | SlideProps | ZoomProps, currentIndex: number, navigate: ButtonClick, responsiveSettings?: Responsive | undefined) => ReactNode;
@@ -33,6 +33,15 @@ var getStartingIndex = function getStartingIndex(children, defaultIndex) {
33
33
 
34
34
  return 0;
35
35
  };
36
+ var getResponsiveSettings = function getResponsiveSettings(wrapperWidth, responsive) {
37
+ if (typeof window !== 'undefined' && Array.isArray(responsive)) {
38
+ return responsive.find(function (each) {
39
+ return each.breakpoint <= wrapperWidth;
40
+ });
41
+ }
42
+
43
+ return;
44
+ };
36
45
  var EASING_METHODS = {
37
46
  linear: TWEEN.Easing.Linear.None,
38
47
  ease: TWEEN.Easing.Quadratic.InOut,
@@ -131,12 +140,14 @@ var showCustomIndicator = function showCustomIndicator(isCurrentPageActive, key,
131
140
  }, indicatorProps));
132
141
  };
133
142
 
134
- var showIndicators = function showIndicators(props, currentIndex, navigate) {
143
+ var showIndicators = function showIndicators(props, currentIndex, navigate, responsiveSettings) {
135
144
  var children = props.children,
136
145
  indicators = props.indicators;
137
146
  var slidesToScroll = 1;
138
147
 
139
- if ('slidesToScroll' in props) {
148
+ if (responsiveSettings) {
149
+ slidesToScroll = responsiveSettings == null ? void 0 : responsiveSettings.settings.slidesToScroll;
150
+ } else if ('slidesToScroll' in props) {
140
151
  slidesToScroll = props.slidesToScroll || 1;
141
152
  }
142
153
 
@@ -183,7 +194,7 @@ var FadeZoom = /*#__PURE__*/React__default.forwardRef(function (props, ref) {
183
194
 
184
195
  var wrapperRef = React.useRef(null);
185
196
  var innerWrapperRef = React.useRef(null);
186
- var tweenGroup = new TWEEN.Group();
197
+ var tweenGroup = React.useRef(new TWEEN.Group());
187
198
  var timeout = React.useRef();
188
199
  var resizeObserver = React.useRef();
189
200
  var childrenCount = React.useMemo(function () {
@@ -229,7 +240,7 @@ var FadeZoom = /*#__PURE__*/React__default.forwardRef(function (props, ref) {
229
240
  React.useEffect(function () {
230
241
  initResizeObserver();
231
242
  return function () {
232
- tweenGroup.removeAll();
243
+ tweenGroup.current.removeAll();
233
244
  clearTimeout(timeout.current);
234
245
  removeResizeObserver();
235
246
  };
@@ -312,7 +323,7 @@ var FadeZoom = /*#__PURE__*/React__default.forwardRef(function (props, ref) {
312
323
  };
313
324
 
314
325
  var transitionSlide = function transitionSlide(newIndex) {
315
- var existingTweens = tweenGroup.getAll();
326
+ var existingTweens = tweenGroup.current.getAll();
316
327
 
317
328
  if (!existingTweens.length) {
318
329
  var _innerWrapperRef$curr;
@@ -329,11 +340,11 @@ var FadeZoom = /*#__PURE__*/React__default.forwardRef(function (props, ref) {
329
340
 
330
341
  var animate = function animate() {
331
342
  requestAnimationFrame(animate);
332
- tweenGroup.update();
343
+ tweenGroup.current.update();
333
344
  };
334
345
 
335
346
  animate();
336
- var tween = new TWEEN.Tween(value, tweenGroup).to({
347
+ var tween = new TWEEN.Tween(value, tweenGroup.current).to({
337
348
  opacity: 1,
338
349
  scale: props.scale
339
350
  }, props.transitionDuration).onUpdate(function (value) {
@@ -359,8 +370,10 @@ var FadeZoom = /*#__PURE__*/React__default.forwardRef(function (props, ref) {
359
370
  }
360
371
  };
361
372
 
362
- var moveTo = function moveTo(index) {
363
- transitionSlide(index);
373
+ var moveTo = function moveTo(gotoIndex) {
374
+ if (gotoIndex !== index) {
375
+ transitionSlide(gotoIndex);
376
+ }
364
377
  };
365
378
 
366
379
  var navigate = function navigate(event) {
@@ -382,8 +395,7 @@ var FadeZoom = /*#__PURE__*/React__default.forwardRef(function (props, ref) {
382
395
  className: "react-slideshow-container " + (props.cssClass || ''),
383
396
  onMouseEnter: pauseSlides,
384
397
  onMouseOver: pauseSlides,
385
- onMouseLeave: startSlides,
386
- ref: props.ref
398
+ onMouseLeave: startSlides
387
399
  }, props.arrows && showPreviousArrow(props, index, preTransition), /*#__PURE__*/React__default.createElement("div", {
388
400
  className: "react-slideshow-fadezoom-wrapper " + props.cssClass,
389
401
  ref: wrapperRef
@@ -433,13 +445,24 @@ var Slide = /*#__PURE__*/React__default.forwardRef(function (props, ref) {
433
445
 
434
446
  var wrapperRef = React.useRef(null);
435
447
  var innerWrapperRef = React.useRef(null);
436
- var tweenGroup = new TWEEN.Group();
448
+ var tweenGroup = React.useRef(new TWEEN.Group());
449
+ var responsiveSettings = React.useMemo(function () {
450
+ return getResponsiveSettings(wrapperWidth, props.responsive);
451
+ }, [wrapperWidth, props.responsive]);
437
452
  var slidesToScroll = React.useMemo(function () {
453
+ if (responsiveSettings) {
454
+ return responsiveSettings.settings.slidesToScroll;
455
+ }
456
+
438
457
  return props.slidesToScroll || 1;
439
- }, [props.slidesToScroll]);
458
+ }, [responsiveSettings, props.slidesToScroll]);
440
459
  var slidesToShow = React.useMemo(function () {
460
+ if (responsiveSettings) {
461
+ return responsiveSettings.settings.slidesToShow;
462
+ }
463
+
441
464
  return props.slidesToShow || 1;
442
- }, [props.slidesToShow]);
465
+ }, [responsiveSettings, props.slidesToShow]);
443
466
  var childrenCount = React.useMemo(function () {
444
467
  return React__default.Children.count(props.children);
445
468
  }, [props.children]);
@@ -491,7 +514,7 @@ var Slide = /*#__PURE__*/React__default.forwardRef(function (props, ref) {
491
514
  React.useEffect(function () {
492
515
  initResizeObserver();
493
516
  return function () {
494
- tweenGroup.removeAll();
517
+ tweenGroup.current.removeAll();
495
518
  clearTimeout(timeout.current);
496
519
  removeResizeObserver();
497
520
  };
@@ -527,10 +550,16 @@ var Slide = /*#__PURE__*/React__default.forwardRef(function (props, ref) {
527
550
  };
528
551
 
529
552
  var swipe = function swipe(event) {
530
- if (props.canSwipe) {
531
- var clientX = event.nativeEvent instanceof TouchEvent ? event.nativeEvent.touches[0].pageX : event.nativeEvent.clientX;
553
+ if (props.canSwipe && dragging) {
554
+ var clientX;
532
555
 
533
- if (dragging) {
556
+ if (window.TouchEvent && event.nativeEvent instanceof TouchEvent) {
557
+ clientX = event.nativeEvent.touches[0].pageX;
558
+ } else if (event.nativeEvent instanceof MouseEvent) {
559
+ clientX = event.nativeEvent.clientX;
560
+ }
561
+
562
+ if (clientX && startingClientX) {
534
563
  var translateValue = eachChildWidth * (index + getOffset());
535
564
  var distance = clientX - startingClientX;
536
565
 
@@ -655,7 +684,12 @@ var Slide = /*#__PURE__*/React__default.forwardRef(function (props, ref) {
655
684
 
656
685
  var startSwipe = function startSwipe(event) {
657
686
  if (props.canSwipe) {
658
- startingClientX = event.nativeEvent instanceof TouchEvent ? event.nativeEvent.touches[0].pageX : event.nativeEvent.clientX;
687
+ if (window.TouchEvent && event.nativeEvent instanceof TouchEvent) {
688
+ startingClientX = event.nativeEvent.touches[0].pageX;
689
+ } else if (event.nativeEvent instanceof MouseEvent) {
690
+ startingClientX = event.nativeEvent.clientX;
691
+ }
692
+
659
693
  clearTimeout(timeout.current);
660
694
  dragging = true;
661
695
  }
@@ -682,7 +716,7 @@ var Slide = /*#__PURE__*/React__default.forwardRef(function (props, ref) {
682
716
  var transitionSlide = function transitionSlide(toIndex, animationDuration) {
683
717
  var transitionDuration = animationDuration || props.transitionDuration;
684
718
  var currentIndex = index;
685
- var existingTweens = tweenGroup.getAll();
719
+ var existingTweens = tweenGroup.current.getAll();
686
720
 
687
721
  if (!wrapperRef.current) {
688
722
  return;
@@ -695,7 +729,7 @@ var Slide = /*#__PURE__*/React__default.forwardRef(function (props, ref) {
695
729
  var value = {
696
730
  margin: -childWidth * (currentIndex + getOffset()) + distanceSwiped
697
731
  };
698
- var tween = new TWEEN.Tween(value, tweenGroup).to({
732
+ var tween = new TWEEN.Tween(value, tweenGroup.current).to({
699
733
  margin: -childWidth * (toIndex + getOffset())
700
734
  }, transitionDuration).onUpdate(function (value) {
701
735
  if (innerWrapperRef.current) {
@@ -706,7 +740,7 @@ var Slide = /*#__PURE__*/React__default.forwardRef(function (props, ref) {
706
740
 
707
741
  var animate = function animate() {
708
742
  requestAnimationFrame(animate);
709
- tweenGroup.update();
743
+ tweenGroup.current.update();
710
744
  };
711
745
 
712
746
  animate();
@@ -777,7 +811,7 @@ var Slide = /*#__PURE__*/React__default.forwardRef(function (props, ref) {
777
811
  "aria-roledescription": "slide",
778
812
  "aria-hidden": isThisSlideActive ? 'false' : 'true'
779
813
  }, each);
780
- }), renderTrailingSlides())), props.arrows && showNextArrow(props, index, moveSlides)), props.indicators && showIndicators(props, index, goToSlide));
814
+ }), renderTrailingSlides())), props.arrows && showNextArrow(props, index, moveSlides)), props.indicators && showIndicators(props, index, goToSlide, responsiveSettings));
781
815
  });
782
816
  Slide.defaultProps = defaultProps;
783
817
 
@@ -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 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\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): ReactNode => {\n const { children, indicators } = props;\n let slidesToScroll = 1;\n 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 = 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.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.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.update();\n };\n\n animate();\n\n const tween = new TWEEN.Tween(value, tweenGroup)\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 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 = new TWEEN.Group();\n const slidesToScroll = useMemo(() => props.slidesToScroll || 1, [props.slidesToScroll]);\n const slidesToShow = useMemo(() => props.slidesToShow || 1, [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.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) {\n const clientX =\n event.nativeEvent instanceof TouchEvent\n ? event.nativeEvent.touches[0].pageX\n : event.nativeEvent.clientX;\n if (dragging) {\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 startingClientX =\n event.nativeEvent instanceof TouchEvent\n ? event.nativeEvent.touches[0].pageX\n : event.nativeEvent.clientX;\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.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)\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.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)}\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","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","indicators","pages","Math","ceil","Array","from","length","_","floor","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","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","each","zIndex","Fade","Zoom","Slide","setWrapperWidth","slidesToShow","eachChildWidth","startingClientX","dragging","distanceSwiped","setWidth","swipe","clientX","nativeEvent","TouchEvent","touches","pageX","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) => {\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 = (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) => {\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","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},l=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"})))},s=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,l={"data-type":"next","aria-label":"Next Slide",disabled:u,onClick:r};return i?t.cloneElement(i,a({className:(i.props.className||"")+" nav "+(u?"disabled":"")},l)):t.createElement("button",Object.assign({type:"button",className:"nav default-nav "+(u?"disabled":"")},l),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){var i=e.indicators,c=1;"slidesToScroll"in e&&(c=e.slidesToScroll||1);var o=Math.ceil(t.Children.count(e.children)/c);return t.createElement("ul",{className:"indicators"},Array.from({length:o},(function(e,o){var u={"data-key":o,"aria-label":"Go to slide "+(o+1),onClick:r},l=Math.floor((n+c-1)/c)===o;return"function"==typeof i?function(e,n,r,i){return t.cloneElement(i,a({className:i.props.className+" "+(e?"active":""),key:n},r))}(l,o,u,i(o)):function(e,n,r){return t.createElement("li",{key:n},t.createElement("button",Object.assign({type:"button",className:"each-slideshow-indicator "+(e?"active":"")},r)))}(l,o,u)})))},d={duration:5e3,transitionDuration:1e3,defaultIndex:0,infinite:!0,autoplay:!0,indicators:!1,arrows:!0,pauseOnHover:!0,easing:"linear",canSwipe:!0,cssClass:"",responsive:[]},p=t.forwardRef((function(e,a){var o=n.useState(c(e.children,e.defaultIndex)),d=o[0],p=o[1],v=n.useRef(null),h=n.useRef(null),m=new i.Group,y=n.useRef(),g=n.useRef(),E=n.useMemo((function(){return t.Children.count(e.children)}),[e.children]),b=n.useCallback((function(){if(h.current&&v.current){var e=v.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")}}}),[v,h,E]),w=n.useCallback((function(){v.current&&(g.current=new r((function(e){e&&b()})),g.current.observe(v.current))}),[v,b]),C=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(k,r))}),[e,d]);n.useEffect((function(){return w(),function(){m.removeAll(),clearTimeout(y.current),T()}}),[w,m]),n.useEffect((function(){clearTimeout(y.current),C()}),[d,e.autoplay,C]),n.useEffect((function(){b()}),[E,b]),n.useImperativeHandle(a,(function(){return{goNext:function(){k()},goBack:function(){M()},goTo:function(e){S(e)}}}));var T=function(){g.current&&v.current&&g.current.unobserve(v.current)},x=function(){e.pauseOnHover&&clearTimeout(y.current)},k=function(){var n=e.children;(e.infinite||d!==t.Children.count(n)-1)&&O((d+1)%t.Children.count(n))},M=function(){(e.infinite||0!==d)&&O(0===d?t.Children.count(e.children)-1:d-1)},N=function(e){"prev"===e.currentTarget.dataset.type?M():k()},O=function(n){if(!m.getAll().length){var t;null!=(t=h.current)&&t.children[n]||(n=0),clearTimeout(y.current),function e(){requestAnimationFrame(e),m.update()}();var r=new i.Tween({opacity:0,scale:1},m).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&&(p(n),h.current.children[d].style.transform="scale(1)"),"function"==typeof e.onChange&&e.onChange(d,n)}))}},S=function(e){O(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 k()}),e.duration))},ref:e.ref},e.arrows&&l(e,d,N),t.createElement("div",{className:"react-slideshow-fadezoom-wrapper "+e.cssClass,ref:v},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&&s(e,d,N)),e.indicators&&f(e,d,(function(e){var n=e.currentTarget;n.dataset.key&&parseInt(n.dataset.key)!==d&&S(parseInt(n.dataset.key))})))}));p.defaultProps=d;var v=t.forwardRef((function(e,n){return t.createElement(p,Object.assign({},e,{scale:1,ref:n}))}));v.defaultProps=d;var h=t.forwardRef((function(e,n){return t.createElement(p,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)),p=d[0],v=d[1],h=n.useState(0),m=h[0],y=h[1],g=n.useRef(null),E=n.useRef(null),b=new i.Group,w=n.useMemo((function(){return e.slidesToScroll||1}),[e.slidesToScroll]),C=n.useMemo((function(){return e.slidesToShow||1}),[e.slidesToShow]),T=n.useMemo((function(){return t.Children.count(e.children)}),[e.children]),x=n.useMemo((function(){return m/C}),[m,C]),k=n.useRef(),M=n.useRef(),N=!1,O=0,S=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]),I=n.useCallback((function(){g.current&&(M.current=new r((function(e){e&&X()})),M.current.observe(g.current))}),[g]),j=n.useCallback((function(){e.autoplay&&(e.infinite||p<T-1)&&(k.current=setTimeout(P,e.duration))}),[e,T,p]);n.useEffect((function(){S()}),[m,S]),n.useEffect((function(){return I(),function(){b.removeAll(),clearTimeout(k.current),R()}}),[g,I,b]),n.useEffect((function(){clearTimeout(k.current),j()}),[p,m,e.autoplay,j]),n.useImperativeHandle(a,(function(){return{goNext:function(){P()},goBack:function(){z()},goTo:function(e){q(e)}}}));var R=function(){M&&g.current&&M.current.unobserve(g.current)},A=function(){e.pauseOnHover&&clearTimeout(k.current)},H=function(n){if(e.canSwipe){var t=n.nativeEvent instanceof TouchEvent?n.nativeEvent.touches[0].pageX:n.nativeEvent.clientX;if(N){var r=x*(p+Q()),i=t-o;if(!e.infinite&&p===T-w&&i<0)return;if(!e.infinite&&0===p&&i>0)return;E.current.style.transform="translate(-"+(r-=O=i)+"px)"}}},P=function(){if(e.infinite||p!==T-w){var n=B(p+w);L(n)}},z=function(){if(e.infinite||0!==p){var n=p-w;n%w&&(n=Math.ceil(n/w)*w),L(n)}},q=function(e){L(B(e))},B=function(e){return e<T&&e+w>T&&(T-w)%w?T-w:e},D=function(e){"next"===e.currentTarget.dataset.type?P():z()},X=function(){g.current&&y(g.current.clientWidth)},F=function(n){e.canSwipe&&(o=n.nativeEvent instanceof TouchEvent?n.nativeEvent.touches[0].pageX:n.nativeEvent.clientX,clearTimeout(k.current),N=!0)},G=function(){e.canSwipe&&(N=!1,Math.abs(O)/m>.2?O<0?P():z():Math.abs(O)>0&&L(p,300))},L=function(n,t){var r=t||e.transitionDuration,a=p,c=b.getAll();if(g.current){var o=g.current.clientWidth/C;if(!c.length){clearTimeout(k.current);var l={margin:-o*(a+Q())+O},s=new i.Tween(l,b).to({margin:-o*(n+Q())},r).onUpdate((function(e){E.current&&(E.current.style.transform="translate("+e.margin+"px)")})).start();s.easing(u(e.easing)),function e(){requestAnimationFrame(e),b.update()}(),s.onComplete((function(){O=0;var t=n;t<0?t=T-w:t>=T&&(t=0),"function"==typeof e.onChange&&e.onChange(p,t),v(t)}))}}},Q=function(){return e.infinite?C:0},U={transform:"translate(-"+(p+Q())*x+"px)"};return t.createElement("div",{dir:"ltr","aria-roledescription":"carousel"},t.createElement("div",{className:"react-slideshow-container",onMouseEnter:A,onMouseOver:A,onMouseLeave:function(){N?G():e.pauseOnHover&&e.autoplay&&(k.current=setTimeout(P,e.duration))},onMouseDown:F,onMouseUp:G,onMouseMove:H,onTouchStart:F,onTouchEnd:G,onTouchCancel:G,onTouchMove:H},e.arrows&&l(e,p,D),t.createElement("div",{className:"react-slideshow-wrapper slide "+(e.cssClass||""),ref:g},t.createElement("div",{className:"images-wrap",style:U,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<p+C&&e>=p}(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!==w)return t.Children.toArray(e.children).slice(0,C).map((function(e,n){return t.createElement("div",{"data-index":T+n,"aria-roledescription":"slide","aria-hidden":"true",key:T+n},e)}))}())),e.arrows&&s(e,p,D)),e.indicators&&f(e,p,(function(e){var n=e.currentTarget;if(n.dataset.key){var t=parseInt(n.dataset.key);q(t*w)}})))}));m.defaultProps=d,exports.Fade=v,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(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){e!==d&&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))}},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;
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 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\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): ReactNode => {\n const { children, indicators } = props;\n let slidesToScroll = 1;\n 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 = 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.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.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.update();\n };\n\n animate();\n\n const tween = new TWEEN.Tween(value, tweenGroup)\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 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 = new TWEEN.Group();\n const slidesToScroll = useMemo(() => props.slidesToScroll || 1, [props.slidesToScroll]);\n const slidesToShow = useMemo(() => props.slidesToShow || 1, [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.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) {\n const clientX =\n event.nativeEvent instanceof TouchEvent\n ? event.nativeEvent.touches[0].pageX\n : event.nativeEvent.clientX;\n if (dragging) {\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 startingClientX =\n event.nativeEvent instanceof TouchEvent\n ? event.nativeEvent.touches[0].pageX\n : event.nativeEvent.clientX;\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.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)\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.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)}\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","indicators","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","slidesToShow","eachChildWidth","dragging","distanceSwiped","setWidth","swipe","clientX","nativeEvent","TouchEvent","touches","pageX","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":"sdAWO,IAAMA,EAAmB,SAACC,EAAqBC,GAClD,OAAIA,GAAgBA,EAAeC,EAAMC,SAASC,MAAMJ,GAC7CC,EAEJ,GAGLI,EAAmD,CACrDC,OAAQC,EAAMC,OAAOC,OAAOC,KAC5BC,KAAMJ,EAAMC,OAAOI,UAAUC,MAC7BC,UAAWP,EAAMC,OAAOI,UAAUG,GAClCC,WAAYT,EAAMC,OAAOI,UAAUK,IACnCC,MAAOX,EAAMC,OAAOW,MAAMN,MAC1BO,WAAYb,EAAMC,OAAOW,MAAMJ,GAC/BM,YAAad,EAAMC,OAAOW,MAAMF,KAGvBK,EAAY,SAACC,GACtB,OAAIA,EACOlB,EAAekB,GAEnBlB,EAAeC,QAGbkB,EAAoB,WAE7BC,EACAC,OAFEC,IAAAA,UAIIC,EAAaH,GAAgB,MAJtBI,SAKPC,EAAQ,CACVC,YAAa,OACbC,aAAc,iBACdC,SAAUL,EACVM,QAASR,GAEb,OAAIC,EACOzB,EAAMiC,aAAaR,KACtBS,WAAcT,EAAUG,MAAMM,WAAa,aAAUR,EAAa,WAAa,KAC5EE,IAKP5B,wCAAQmC,KAAK,SAASD,8BAFWR,EAAa,WAAa,KAEXE,GAC5C5B,uBAAKoC,MAAM,KAAKC,OAAO,KAAKC,QAAQ,aAChCtC,wBAAMuC,EAAE,4EAMXC,EAAgB,SACzBC,EACAlB,EACAC,GAEA,IAAQkB,EAAkCD,EAAlCC,UAAWf,EAAuBc,EAAvBd,SACfgB,EAAiB,EACjB,mBAAoBF,IACpBE,EAAiBF,EAAWE,gBAAkB,GAElD,IAAMjB,EAAaH,GAAgBvB,EAAMC,SAASC,MALRuC,EAAb3C,UAKuC6C,IAAmBhB,EACjFC,EAAQ,CACVC,YAAa,OACbC,aAAc,aACdC,SAAUL,EACVM,QAASR,GAEb,OAAIkB,EACO1C,EAAMiC,aAAaS,KACtBR,WAAcQ,EAAUd,MAAMM,WAAa,aAAUR,EAAa,WAAa,KAC5EE,IAKP5B,wCAAQmC,KAAK,SAASD,8BAFWR,EAAa,WAAa,KAEXE,GAC5C5B,uBAAKoC,MAAM,KAAKC,OAAO,KAAKC,QAAQ,aAChCtC,wBAAMuC,EAAE,qDAmCXK,EAAiB,SAC1BhB,EACAL,EACAsB,GAEA,IAAkBC,EAAelB,EAAfkB,WACdH,EAAiB,EACjB,mBAAoBf,IACpBe,EAAiBf,EAAMe,gBAAkB,GAE7C,IAAMI,EAAQC,KAAKC,KAAKjD,EAAMC,SAASC,MALN0B,EAAzB9B,UAKiD6C,GACzD,OACI3C,sBAAIkC,UAAU,cACTgB,MAAMC,KAAK,CAAEC,OAAQL,IAAS,SAACM,EAAGC,GAC/B,IAAMC,EAAqC,CACvCC,WAAYF,EACZxB,6BAA6BwB,EAAM,GACnCtB,QAASa,GAEPY,EACFT,KAAKU,OAAOnC,EAAeoB,EAAiB,GAAKA,KAAoBW,EACzE,MAA0B,mBAAfR,EAlCC,SACxBW,EACAH,EACAC,EACAI,GAEA,OAAO3D,EAAMiC,aAAa0B,KACtBzB,UAAcyB,EAAc/B,MAAMM,eAAauB,EAAsB,SAAW,IAChFH,IAAAA,GACGC,IA0BgBK,CACHH,EACAH,EACAC,EACAT,EAAWQ,IAvDN,SACzBG,EACAH,EACAC,GAEA,OACIvD,sBAAIsD,IAAKA,GACLtD,wCACImC,KAAK,SACLD,uCAAuCuB,EAAsB,SAAW,KACpEF,KAgDGM,CAAqBJ,EAAqBH,EAAKC,QC1JzDO,EAAe,CAC1BC,SAAU,IACVC,mBAAoB,IACpBjE,aAAc,EACd4B,UAAU,EACVsC,UAAU,EACVnB,YAAY,EACZoB,QAAQ,EACRC,cAAc,EACdC,OAAQ,SACRC,UAAU,EACVC,SAAU,GACVC,WAAY,ICQDC,EAAWxE,EAAMyE,YAAoC,SAAC7C,EAAO8C,GACtE,MAA0BC,WACtB9E,EAAiB+B,EAAM9B,SAAU8B,EAAM7B,eADpC6E,OAAOC,OAGRC,EAAaC,SAAuB,MACpCC,EAAkBD,SAAY,MAC9BE,EAAa,IAAI5E,EAAM6E,MACvBC,EAAUJ,WACVK,EAAiBL,WACjBM,EAAgBC,WAAQ,WAAA,OAAMtF,EAAMC,SAASC,MAAM0B,EAAM9B,YAAW,CAAC8B,EAAM9B,WAE3EyF,EAAaC,eAAY,WAC3B,GAAIR,EAAgBS,SAAWX,EAAWW,QAAS,CAC/C,IAAMC,EAAeZ,EAAWW,QAAQE,YAExCX,EAAgBS,QAAQG,MAAMxD,MADZsD,EAAeL,OAEjC,IAAK,IAAIT,EAAQ,EAAGA,EAAQI,EAAgBS,QAAQ3F,SAASsD,OAAQwB,IAAS,CAC1E,IAAMiB,EAAUb,EAAgBS,QAAQ3F,SAAS8E,GAC7CiB,IACAA,EAAQD,MAAMxD,MAAWsD,OACzBG,EAAQD,MAAME,KAAUlB,GAASc,OACjCG,EAAQD,MAAMG,qBAI3B,CAACjB,EAAYE,EAAiBK,IAE3BW,EAAqBR,eAAY,WAC/BV,EAAWW,UACXL,EAAeK,QAAU,IAAIQ,GAAe,SAACC,GACpCA,GACLX,OAEJH,EAAeK,QAAQU,QAAQrB,EAAWW,YAE/C,CAACX,EAAYS,IAEVa,EAAOZ,eAAY,WACrB,IAAkB1F,EAAiC8B,EAAjC9B,SAAUiE,EAAuBnC,EAAvBmC,SAAUpC,EAAaC,EAAbD,SAAaC,EAA3CqC,UAGJjE,EAAMC,SAASC,MAAMJ,GAAY,IAChC6B,GAAYiD,EAAQ5E,EAAMC,SAASC,MAAMJ,GAAY,KAEtDqF,EAAQM,QAAUY,WAAWC,EAAUvC,MAG5C,CAACnC,EAAOgD,IAEX2B,aAAU,WAEN,OADAP,IACO,WACHf,EAAWuB,YACXC,aAAatB,EAAQM,SACrBiB,OAEL,CAACV,EAAoBf,IAExBsB,aAAU,WACNE,aAAatB,EAAQM,SACrBW,MACD,CAACxB,EAAOhD,EAAMqC,SAAUmC,IAE3BG,aAAU,WACNhB,MACD,CAACF,EAAeE,IAEnBoB,sBAAoBjC,GAAK,WAAA,MAAO,CAC5BkC,OAAQ,WACJN,KAEJO,OAAQ,WACJC,KAEJC,KAAM,SAACnC,GACHoC,EAAOpC,QAIf,IAAM8B,EAAuB,WACrBtB,EAAeK,SAAWX,EAAWW,SACrCL,EAAeK,QAAQwB,UAAUnC,EAAWW,UAI9CyB,EAAc,WACZtF,EAAMuC,cACNsC,aAAatB,EAAQM,UAWvBa,EAAW,WACb,IAAQxG,EAAuB8B,EAAvB9B,UAAuB8B,EAAbD,UACDiD,IAAU5E,EAAMC,SAASC,MAAMJ,GAAY,IAG5DqH,GAAiBvC,EAAQ,GAAK5E,EAAMC,SAASC,MAAMJ,KAGjDgH,EAAW,YACkBlF,EAAbD,UACS,IAAViD,IAGjBuC,EAA0B,IAAVvC,EAAc5E,EAAMC,SAASC,MAJd0B,EAAvB9B,UAIuD,EAAI8E,EAAQ,IAGzEwC,EAA6B,SAACC,GAEG,SADTA,EAAlBC,cACUC,QAAQpF,KACtB2E,IAEAR,KAIFa,EAAkB,SAACK,GAErB,IADuBvC,EAAWwC,SACdrE,OAAQ,CAAA,eACnB4B,EAAgBS,UAAhBiC,EAAyB5H,SAAS0H,KACnCA,EAAW,GAEff,aAAatB,EAAQM,SAGL,SAAVkC,IACFC,sBAAsBD,GACtB1C,EAAW4C,SAGfF,GAEA,IAAMG,EAAQ,IAAIzH,EAAM0H,MATV,CAAEC,QAAS,EAAGC,MAAO,GASEhD,GAChCiD,GAAG,CAAEF,QAAS,EAAGC,MAAOrG,EAAMqG,OAASrG,EAAMoC,oBAC7CmE,UAAS,SAACC,GACFpD,EAAgBS,UAGrBT,EAAgBS,QAAQ3F,SAAS0H,GAAU5B,MAAMoC,QAAUI,EAAMJ,QACjEhD,EAAgBS,QAAQ3F,SAAS8E,GAAOgB,MAAMoC,QAAU,EAAII,EAAMJ,QAClEhD,EAAgBS,QAAQ3F,SACpB8E,GACFgB,MAAMyC,mBAAqBD,EAAMH,cAEtCK,QACLR,EAAM1D,OAAOhD,EAAUQ,EAAMwC,SAC7B0D,EAAMS,YAAW,WACTvD,EAAgBS,UAChBZ,EAAS2C,GACTxC,EAAgBS,QAAQ3F,SAAS8E,GAAOgB,MAAMyC,sBAEpB,mBAAnBzG,EAAM4G,UACb5G,EAAM4G,SAAS5D,EAAO4C,QAMhCR,EAAS,SAACpC,GACZuC,EAAgBvC,IAapB,OACI5E,uBAAKyI,IAAI,6BAA2B,YAChCzI,uBACIkC,wCAAwCN,EAAM0C,UAAY,IAC1DoE,aAAcxB,EACdyB,YAAazB,EACb0B,aA9FQ,WAC6BhH,EAArCuC,cAAqCvC,EAAvBqC,WAElBkB,EAAQM,QAAUY,YAAW,WAAA,OAAMC,MAFM1E,EAAbmC,YA8FxBW,IAAK9C,EAAM8C,KAEV9C,EAAMsC,QAAU5C,EAAkBM,EAAOgD,EAAOwC,GACjDpH,uBACIkC,8CAA+CN,EAAM0C,SACrDI,IAAKI,GAEL9E,uBAAKkC,UAAU,uCAAuCwC,IAAKM,IACrDhF,EAAMC,SAAS4I,IAAIjH,EAAM9B,UAAU,SAACgJ,GAAD,OAAaA,MAAY,IAAID,KAC9D,SAACE,EAAMzF,GAAP,OACItD,uBACI4F,MAAO,CACHoC,QAAS1E,IAAQsB,EAAQ,IAAM,IAC/BoE,OAAQ1F,IAAQsB,EAAQ,IAAM,kBAEtBtB,EACZA,IAAKA,yBACgB,sBACRA,IAAQsB,EAAQ,QAAU,QAEtCmE,QAMpBnH,EAAMsC,QAAU1B,EAAcZ,EAAOgD,EAAOwC,IAEhDxF,EAAMkB,YAAcF,EAAehB,EAAOgD,GA7CrB,SAACyC,GAC3B,IAAQC,EAAkBD,EAAlBC,cACHA,EAAcC,QAAQjE,KAGvB2F,SAAS3B,EAAcC,QAAQjE,OAASsB,GACxCoC,EAAOiC,SAAS3B,EAAcC,QAAQjE,aA4ClDkB,EAASV,aAAeA,MC1OXoF,EAAOlJ,EAAMyE,YAAoC,SAAC7C,EAAO8C,GAClE,OAAO1E,gBAACwE,mBAAa5C,GAAOqG,MAAO,EAAGvD,IAAKA,QAG/CwE,EAAKpF,aAAeA,MCJPqF,EAAOnJ,EAAMyE,YAAoC,SAAC7C,EAAO8C,GAClE,OAAO1E,gBAACwE,mBAAa5C,GAAO8C,IAAKA,QAGrCyE,EAAKrF,aAAeA,MCWPsF,EAAQpJ,EAAMyE,YAAqC,SAAC7C,EAAO8C,GACpE,IAWI2E,IAXsB1E,WAAS9E,EAAiB+B,EAAM9B,SAAU8B,EAAM7B,eAAnE6E,OAAOC,SAC0BF,WAAiB,GAAlDe,OAAc4D,OACfxE,EAAaC,SAAuB,MACpCC,EAAkBD,SAAY,MAC9BE,EAAa,IAAI5E,EAAM6E,MACvBvC,EAAiB2C,WAAQ,WAAA,OAAM1D,EAAMe,gBAAkB,IAAG,CAACf,EAAMe,iBACjE4G,EAAejE,WAAQ,WAAA,OAAM1D,EAAM2H,cAAgB,IAAG,CAAC3H,EAAM2H,eAC7DlE,EAAgBC,WAAQ,WAAA,OAAMtF,EAAMC,SAASC,MAAM0B,EAAM9B,YAAW,CAAC8B,EAAM9B,WAC3E0J,EAAiBlE,WAAQ,WAAA,OAAMI,EAAe6D,IAAc,CAAC7D,EAAc6D,IAC3EpE,EAAUJ,WACVK,EAAiBL,WAEnB0E,GAAoB,EACpBC,EAAyB,EAEvBnE,EAAaC,eAAY,WAC3B,GAAIR,EAAgBS,QAAS,CAEzBT,EAAgBS,QAAQG,MAAMxD,MADZsD,EAAeV,EAAgBS,QAAQ3F,SAASsD,YAElE,IAAK,IAAIwB,EAAQ,EAAGA,EAAQI,EAAgBS,QAAQ3F,SAASsD,OAAQwB,IAAS,CAC1E,IAAMiB,EAAUb,EAAgBS,QAAQ3F,SAAS8E,GAC7CiB,IACAA,EAAQD,MAAMxD,MAAWoH,OACzB3D,EAAQD,MAAMG,qBAI3B,CAACL,EAAc8D,IAEZxD,EAAqBR,eAAY,WAC/BV,EAAWW,UACXL,EAAeK,QAAU,IAAIQ,GAAe,SAACC,GACpCA,GACLyD,OAEJvE,EAAeK,QAAQU,QAAQrB,EAAWW,YAE/C,CAACX,IAEEsB,EAAOZ,eAAY,WACoB5D,EAAjCqC,WAAiCrC,EAAvBD,UACWiD,EAAQS,EAAgB,KACjDF,EAAQM,QAAUY,WAAWC,EAFQ1E,EAAbmC,aAK7B,CAACnC,EAAOyD,EAAeT,IAE1B2B,aAAU,WACNhB,MACD,CAACG,EAAcH,IAElBgB,aAAU,WAEN,OADAP,IACO,WACHf,EAAWuB,YACXC,aAAatB,EAAQM,SACrBiB,OAEL,CAAC5B,EAAYkB,EAAoBf,IAEpCsB,aAAU,WACNE,aAAatB,EAAQM,SACrBW,MACD,CAACxB,EAAOc,EAAc9D,EAAMqC,SAAUmC,IAEzCO,sBAAoBjC,GAAK,WAAA,MAAO,CAC5BkC,OAAQ,WACJN,KAEJO,OAAQ,WACJC,KAEJC,KAAM,SAACnC,GACHoC,EAAOpC,QAIf,IAAM8B,EAAuB,WACrBtB,GAAkBN,EAAWW,SAC7BL,EAAeK,QAAQwB,UAAUnC,EAAWW,UAI9CyB,EAAc,WACZtF,EAAMuC,cACNsC,aAAatB,EAAQM,UAIvBmE,EAAQ,SAACvC,GACX,GAAIzF,EAAMyC,SAAU,CAChB,IAAMwF,EACFxC,EAAMyC,uBAAuBC,WACvB1C,EAAMyC,YAAYE,QAAQ,GAAGC,MAC7B5C,EAAMyC,YAAYD,QAC5B,GAAIJ,EAAU,CACV,IAAIS,EAAiBV,GAAkB5E,EAAQuF,KACzCC,EAAWP,EAAUR,EAC3B,IAAKzH,EAAMD,UAAYiD,IAAUS,EAAgB1C,GAAkByH,EAAW,EAG1E,OAEJ,IAAKxI,EAAMD,UAAsB,IAAViD,GAAewF,EAAW,EAG7C,OAIJpF,EAAgBS,QAAQG,MAAMyC,yBAD9B6B,GADAR,EAAiBU,YAOvB9D,EAAW,WACb,GAAK1E,EAAMD,UAAYiD,IAAUS,EAAgB1C,EAAjD,CAGA,IAAM0H,EAAYC,EAAe1F,EAAQjC,GACzCwE,EAAgBkD,KAGdvD,EAAW,WACb,GAAKlF,EAAMD,UAAsB,IAAViD,EAAvB,CAGA,IAAI2F,EAAgB3F,EAAQjC,EACxB4H,EAAgB5H,IAChB4H,EAAgBvH,KAAKC,KAAKsH,EAAgB5H,GAAkBA,GAEhEwE,EAAgBoD,KAWdvD,EAAS,SAACpC,GACZuC,EAAgBmD,EAAe1F,KAG7B0F,EAAiB,SAACD,GACpB,OAAIA,EAAYhF,GAAiBgF,EAAY1H,EAAiB0C,IACrDA,EAAgB1C,GAAkBA,EAC5B0C,EAAgB1C,EAIxB0H,GAWL7I,EAA0B,YACP,WADU8F,cAAiBC,QACpCpF,KACRmE,IAEAQ,KAqCF6C,EAAW,WACT7E,EAAWW,SACX6D,EAAgBxE,EAAWW,QAAQE,cAIrC6E,EAAa,SAACnD,GACZzF,EAAMyC,WACNgF,EACIhC,EAAMyC,uBAAuBC,WACvB1C,EAAMyC,YAAYE,QAAQ,GAAGC,MAC7B5C,EAAMyC,YAAYD,QAC5BpD,aAAatB,EAAQM,SACrBgE,GAAW,IAIbgB,EAAW,WACT7I,EAAMyC,WACNoF,GAAW,EACPzG,KAAK0H,IAAIhB,GAAkBhE,EAAe,GACtCgE,EAAiB,EACjBpD,IAEAQ,IAGA9D,KAAK0H,IAAIhB,GAAkB,GAC3BvC,EAAgBvC,EAAO,OAMjCuC,EAAkB,SAACwD,EAAiBC,GACtC,IAAM5G,EAAqB4G,GAAqBhJ,EAAMoC,mBAChDzC,EAAeqD,EACfiG,EAAiB5F,EAAWwC,SAClC,GAAK3C,EAAWW,QAAhB,CAGA,IAAMqF,EAAahG,EAAWW,QAAQE,YAAc4D,EACpD,IAAKsB,EAAezH,OAAQ,CACxBqD,aAAatB,EAAQM,SACrB,IAAM2C,EAAQ,CACV2C,QAASD,GAAcvJ,EAAe4I,KAAeT,GAEnD5B,EAAQ,IAAIzH,EAAM0H,MAAMK,EAAOnD,GAChCiD,GAAG,CAAE6C,QAASD,GAAcH,EAAUR,MAAgBnG,GACtDmE,UAAS,SAACC,GACHpD,EAAgBS,UAChBT,EAAgBS,QAAQG,MAAMyC,uBAAyBD,EAAM2C,iBAGpEzC,QACLR,EAAM1D,OAAOhD,EAAUQ,EAAMwC,SACb,SAAVuD,IACFC,sBAAsBD,GACtB1C,EAAW4C,SAGfF,GAEAG,EAAMS,YAAW,WACbmB,EAAiB,EACjB,IAAIlC,EAAWmD,EACXnD,EAAW,EACXA,EAAWnC,EAAgB1C,EACpB6E,GAAYnC,IACnBmC,EAAW,GAGe,mBAAnB5F,EAAM4G,UACb5G,EAAM4G,SAAS5D,EAAO4C,GAE1B3C,EAAS2C,SASf2C,EAAY,WACd,OAAKvI,EAAMD,SAGJ4H,EAFI,GAKT3D,EAAQ,CACVyC,yBAA0BzD,EAAQuF,KAAeX,SAErD,OACIxJ,uBAAKyI,IAAI,6BAA2B,YAChCzI,uBACIkC,UAAU,4BACVwG,aAAcxB,EACdyB,YAAazB,EACb0B,aArJQ,WACZa,EACAgB,IACO7I,EAAMuC,cAAgBvC,EAAMqC,WACnCkB,EAAQM,QAAUY,WAAWC,EAAU1E,EAAMmC,YAkJzCiH,YAAaR,EACbS,UAAWR,EACXS,YAAatB,EACbuB,aAAcX,EACdY,WAAYX,EACZY,cAAeZ,EACfa,YAAa1B,GAEZhI,EAAMsC,QAAU5C,EAAkBM,EAAOgD,EAAOpD,GACjDxB,uBACIkC,4CAA4CN,EAAM0C,UAAY,IAC9DI,IAAKI,GAEL9E,uBAAKkC,UAAU,cAAc0D,MAAOA,EAAOlB,IAAKM,GAC3CpD,EAAMD,UAnJhB3B,EAAMC,SAASsL,QAAQ3J,EAAM9B,UAC/B0L,OAAOjC,GACPV,KAAI,SAACE,EAAMnE,GAAP,OACD5E,oCACgB4E,EAAQ2E,yBACC,sBACT,OACZjG,IAAKsB,EAAQ2E,GAEZR,OA2IK/I,EAAMC,SAAS4I,IAAIjH,EAAM9B,UAAU,SAACgJ,GAAD,OAAaA,MAAY,IAAID,KAC9D,SAACE,EAAMzF,GACH,IAAMmI,EAtCZ,SAACnI,GACnB,OAAOA,EAAMsB,EAAQ2E,GAAgBjG,GAAOsB,EAqCM8G,CAAcpI,GACxC,OACItD,oCACgBsD,EACZA,IAAKA,EACLpB,UAAWuJ,EAAoB,SAAW,0BACrB,sBACRA,EAAoB,QAAU,QAE1C1C,MAjJR,WACzB,GAAKnH,EAAMD,UAAY4H,IAAiB5G,EAGxC,OAAO3C,EAAMC,SAASsL,QAAQ3J,EAAM9B,UAC/B0L,MAAM,EAAGjC,GACTV,KAAI,SAACE,EAAMnE,GAAP,OACD5E,oCACgBqF,EAAgBT,yBACP,sBACT,OACZtB,IAAK+B,EAAgBT,GAEpBmE,MAyII4C,KAGR/J,EAAMsC,QAAU1B,EAAcZ,EAAOgD,EAAOpD,IAEhDI,EAAMkB,YAAcF,EAAehB,EAAOgD,GAhNpB,gBAAG0C,IAAAA,cAC9B,GAAKA,EAAcC,QAAQjE,IAA3B,CAGA,IAAMsI,EAAa3C,SAAS3B,EAAcC,QAAQjE,KAClD0D,EAAO4E,EAAajJ,WAgN5ByG,EAAMtF,aAAeA"}
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 = (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) => {\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","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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"}
@@ -26,6 +26,15 @@ var getStartingIndex = function getStartingIndex(children, defaultIndex) {
26
26
 
27
27
  return 0;
28
28
  };
29
+ var getResponsiveSettings = function getResponsiveSettings(wrapperWidth, responsive) {
30
+ if (typeof window !== 'undefined' && Array.isArray(responsive)) {
31
+ return responsive.find(function (each) {
32
+ return each.breakpoint <= wrapperWidth;
33
+ });
34
+ }
35
+
36
+ return;
37
+ };
29
38
  var EASING_METHODS = {
30
39
  linear: TWEEN.Easing.Linear.None,
31
40
  ease: TWEEN.Easing.Quadratic.InOut,
@@ -124,12 +133,14 @@ var showCustomIndicator = function showCustomIndicator(isCurrentPageActive, key,
124
133
  }, indicatorProps));
125
134
  };
126
135
 
127
- var showIndicators = function showIndicators(props, currentIndex, navigate) {
136
+ var showIndicators = function showIndicators(props, currentIndex, navigate, responsiveSettings) {
128
137
  var children = props.children,
129
138
  indicators = props.indicators;
130
139
  var slidesToScroll = 1;
131
140
 
132
- if ('slidesToScroll' in props) {
141
+ if (responsiveSettings) {
142
+ slidesToScroll = responsiveSettings == null ? void 0 : responsiveSettings.settings.slidesToScroll;
143
+ } else if ('slidesToScroll' in props) {
133
144
  slidesToScroll = props.slidesToScroll || 1;
134
145
  }
135
146
 
@@ -176,7 +187,7 @@ var FadeZoom = /*#__PURE__*/React.forwardRef(function (props, ref) {
176
187
 
177
188
  var wrapperRef = useRef(null);
178
189
  var innerWrapperRef = useRef(null);
179
- var tweenGroup = new TWEEN.Group();
190
+ var tweenGroup = useRef(new TWEEN.Group());
180
191
  var timeout = useRef();
181
192
  var resizeObserver = useRef();
182
193
  var childrenCount = useMemo(function () {
@@ -222,7 +233,7 @@ var FadeZoom = /*#__PURE__*/React.forwardRef(function (props, ref) {
222
233
  useEffect(function () {
223
234
  initResizeObserver();
224
235
  return function () {
225
- tweenGroup.removeAll();
236
+ tweenGroup.current.removeAll();
226
237
  clearTimeout(timeout.current);
227
238
  removeResizeObserver();
228
239
  };
@@ -305,7 +316,7 @@ var FadeZoom = /*#__PURE__*/React.forwardRef(function (props, ref) {
305
316
  };
306
317
 
307
318
  var transitionSlide = function transitionSlide(newIndex) {
308
- var existingTweens = tweenGroup.getAll();
319
+ var existingTweens = tweenGroup.current.getAll();
309
320
 
310
321
  if (!existingTweens.length) {
311
322
  var _innerWrapperRef$curr;
@@ -322,11 +333,11 @@ var FadeZoom = /*#__PURE__*/React.forwardRef(function (props, ref) {
322
333
 
323
334
  var animate = function animate() {
324
335
  requestAnimationFrame(animate);
325
- tweenGroup.update();
336
+ tweenGroup.current.update();
326
337
  };
327
338
 
328
339
  animate();
329
- var tween = new TWEEN.Tween(value, tweenGroup).to({
340
+ var tween = new TWEEN.Tween(value, tweenGroup.current).to({
330
341
  opacity: 1,
331
342
  scale: props.scale
332
343
  }, props.transitionDuration).onUpdate(function (value) {
@@ -352,8 +363,10 @@ var FadeZoom = /*#__PURE__*/React.forwardRef(function (props, ref) {
352
363
  }
353
364
  };
354
365
 
355
- var moveTo = function moveTo(index) {
356
- transitionSlide(index);
366
+ var moveTo = function moveTo(gotoIndex) {
367
+ if (gotoIndex !== index) {
368
+ transitionSlide(gotoIndex);
369
+ }
357
370
  };
358
371
 
359
372
  var navigate = function navigate(event) {
@@ -375,8 +388,7 @@ var FadeZoom = /*#__PURE__*/React.forwardRef(function (props, ref) {
375
388
  className: "react-slideshow-container " + (props.cssClass || ''),
376
389
  onMouseEnter: pauseSlides,
377
390
  onMouseOver: pauseSlides,
378
- onMouseLeave: startSlides,
379
- ref: props.ref
391
+ onMouseLeave: startSlides
380
392
  }, props.arrows && showPreviousArrow(props, index, preTransition), /*#__PURE__*/React.createElement("div", {
381
393
  className: "react-slideshow-fadezoom-wrapper " + props.cssClass,
382
394
  ref: wrapperRef
@@ -426,13 +438,24 @@ var Slide = /*#__PURE__*/React.forwardRef(function (props, ref) {
426
438
 
427
439
  var wrapperRef = useRef(null);
428
440
  var innerWrapperRef = useRef(null);
429
- var tweenGroup = new TWEEN.Group();
441
+ var tweenGroup = useRef(new TWEEN.Group());
442
+ var responsiveSettings = useMemo(function () {
443
+ return getResponsiveSettings(wrapperWidth, props.responsive);
444
+ }, [wrapperWidth, props.responsive]);
430
445
  var slidesToScroll = useMemo(function () {
446
+ if (responsiveSettings) {
447
+ return responsiveSettings.settings.slidesToScroll;
448
+ }
449
+
431
450
  return props.slidesToScroll || 1;
432
- }, [props.slidesToScroll]);
451
+ }, [responsiveSettings, props.slidesToScroll]);
433
452
  var slidesToShow = useMemo(function () {
453
+ if (responsiveSettings) {
454
+ return responsiveSettings.settings.slidesToShow;
455
+ }
456
+
434
457
  return props.slidesToShow || 1;
435
- }, [props.slidesToShow]);
458
+ }, [responsiveSettings, props.slidesToShow]);
436
459
  var childrenCount = useMemo(function () {
437
460
  return React.Children.count(props.children);
438
461
  }, [props.children]);
@@ -484,7 +507,7 @@ var Slide = /*#__PURE__*/React.forwardRef(function (props, ref) {
484
507
  useEffect(function () {
485
508
  initResizeObserver();
486
509
  return function () {
487
- tweenGroup.removeAll();
510
+ tweenGroup.current.removeAll();
488
511
  clearTimeout(timeout.current);
489
512
  removeResizeObserver();
490
513
  };
@@ -520,10 +543,16 @@ var Slide = /*#__PURE__*/React.forwardRef(function (props, ref) {
520
543
  };
521
544
 
522
545
  var swipe = function swipe(event) {
523
- if (props.canSwipe) {
524
- var clientX = event.nativeEvent instanceof TouchEvent ? event.nativeEvent.touches[0].pageX : event.nativeEvent.clientX;
546
+ if (props.canSwipe && dragging) {
547
+ var clientX;
525
548
 
526
- if (dragging) {
549
+ if (window.TouchEvent && event.nativeEvent instanceof TouchEvent) {
550
+ clientX = event.nativeEvent.touches[0].pageX;
551
+ } else if (event.nativeEvent instanceof MouseEvent) {
552
+ clientX = event.nativeEvent.clientX;
553
+ }
554
+
555
+ if (clientX && startingClientX) {
527
556
  var translateValue = eachChildWidth * (index + getOffset());
528
557
  var distance = clientX - startingClientX;
529
558
 
@@ -648,7 +677,12 @@ var Slide = /*#__PURE__*/React.forwardRef(function (props, ref) {
648
677
 
649
678
  var startSwipe = function startSwipe(event) {
650
679
  if (props.canSwipe) {
651
- startingClientX = event.nativeEvent instanceof TouchEvent ? event.nativeEvent.touches[0].pageX : event.nativeEvent.clientX;
680
+ if (window.TouchEvent && event.nativeEvent instanceof TouchEvent) {
681
+ startingClientX = event.nativeEvent.touches[0].pageX;
682
+ } else if (event.nativeEvent instanceof MouseEvent) {
683
+ startingClientX = event.nativeEvent.clientX;
684
+ }
685
+
652
686
  clearTimeout(timeout.current);
653
687
  dragging = true;
654
688
  }
@@ -675,7 +709,7 @@ var Slide = /*#__PURE__*/React.forwardRef(function (props, ref) {
675
709
  var transitionSlide = function transitionSlide(toIndex, animationDuration) {
676
710
  var transitionDuration = animationDuration || props.transitionDuration;
677
711
  var currentIndex = index;
678
- var existingTweens = tweenGroup.getAll();
712
+ var existingTweens = tweenGroup.current.getAll();
679
713
 
680
714
  if (!wrapperRef.current) {
681
715
  return;
@@ -688,7 +722,7 @@ var Slide = /*#__PURE__*/React.forwardRef(function (props, ref) {
688
722
  var value = {
689
723
  margin: -childWidth * (currentIndex + getOffset()) + distanceSwiped
690
724
  };
691
- var tween = new TWEEN.Tween(value, tweenGroup).to({
725
+ var tween = new TWEEN.Tween(value, tweenGroup.current).to({
692
726
  margin: -childWidth * (toIndex + getOffset())
693
727
  }, transitionDuration).onUpdate(function (value) {
694
728
  if (innerWrapperRef.current) {
@@ -699,7 +733,7 @@ var Slide = /*#__PURE__*/React.forwardRef(function (props, ref) {
699
733
 
700
734
  var animate = function animate() {
701
735
  requestAnimationFrame(animate);
702
- tweenGroup.update();
736
+ tweenGroup.current.update();
703
737
  };
704
738
 
705
739
  animate();
@@ -770,7 +804,7 @@ var Slide = /*#__PURE__*/React.forwardRef(function (props, ref) {
770
804
  "aria-roledescription": "slide",
771
805
  "aria-hidden": isThisSlideActive ? 'false' : 'true'
772
806
  }, each);
773
- }), renderTrailingSlides())), props.arrows && showNextArrow(props, index, moveSlides)), props.indicators && showIndicators(props, index, goToSlide));
807
+ }), renderTrailingSlides())), props.arrows && showNextArrow(props, index, moveSlides)), props.indicators && showIndicators(props, index, goToSlide, responsiveSettings));
774
808
  });
775
809
  Slide.defaultProps = defaultProps;
776
810
 
@@ -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 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\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): ReactNode => {\n const { children, indicators } = props;\n let slidesToScroll = 1;\n 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 = 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.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.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.update();\n };\n\n animate();\n\n const tween = new TWEEN.Tween(value, tweenGroup)\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 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 = new TWEEN.Group();\n const slidesToScroll = useMemo(() => props.slidesToScroll || 1, [props.slidesToScroll]);\n const slidesToShow = useMemo(() => props.slidesToShow || 1, [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.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) {\n const clientX =\n event.nativeEvent instanceof TouchEvent\n ? event.nativeEvent.touches[0].pageX\n : event.nativeEvent.clientX;\n if (dragging) {\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 startingClientX =\n event.nativeEvent instanceof TouchEvent\n ? event.nativeEvent.touches[0].pageX\n : event.nativeEvent.clientX;\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.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)\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.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)}\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","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","indicators","pages","Math","ceil","Array","from","length","_","floor","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","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","each","zIndex","Fade","Zoom","Slide","setWrapperWidth","slidesToShow","eachChildWidth","startingClientX","dragging","distanceSwiped","setWidth","swipe","clientX","nativeEvent","TouchEvent","touches","pageX","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) => {\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 = (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) => {\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","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/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "react-slideshow-image",
3
- "version": "4.0.2",
3
+ "version": "4.0.5",
4
4
  "description": "An image slideshow with react",
5
5
  "license": "MIT",
6
6
  "main": "dist/index.js",