react-slideshow-image 4.0.1 → 4.0.4

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,
@@ -68,6 +77,7 @@ var showPreviousArrow = function showPreviousArrow(_ref, currentIndex, moveSlide
68
77
 
69
78
  var className = "nav default-nav " + (isDisabled ? 'disabled' : '');
70
79
  return /*#__PURE__*/React__default.createElement("button", Object.assign({
80
+ type: "button",
71
81
  className: className
72
82
  }, props), /*#__PURE__*/React__default.createElement("svg", {
73
83
  width: "24",
@@ -103,6 +113,7 @@ var showNextArrow = function showNextArrow(properties, currentIndex, moveSlides)
103
113
 
104
114
  var className = "nav default-nav " + (isDisabled ? 'disabled' : '');
105
115
  return /*#__PURE__*/React__default.createElement("button", Object.assign({
116
+ type: "button",
106
117
  className: className
107
118
  }, props), /*#__PURE__*/React__default.createElement("svg", {
108
119
  width: "24",
@@ -117,6 +128,7 @@ var showDefaultIndicator = function showDefaultIndicator(isCurrentPageActive, ke
117
128
  return /*#__PURE__*/React__default.createElement("li", {
118
129
  key: key
119
130
  }, /*#__PURE__*/React__default.createElement("button", Object.assign({
131
+ type: "button",
120
132
  className: "each-slideshow-indicator " + (isCurrentPageActive ? 'active' : '')
121
133
  }, indicatorProps)));
122
134
  };
@@ -128,12 +140,14 @@ var showCustomIndicator = function showCustomIndicator(isCurrentPageActive, key,
128
140
  }, indicatorProps));
129
141
  };
130
142
 
131
- var showIndicators = function showIndicators(props, currentIndex, navigate) {
143
+ var showIndicators = function showIndicators(props, currentIndex, navigate, responsiveSettings) {
132
144
  var children = props.children,
133
145
  indicators = props.indicators;
134
146
  var slidesToScroll = 1;
135
147
 
136
- if ('slidesToScroll' in props) {
148
+ if (responsiveSettings) {
149
+ slidesToScroll = responsiveSettings == null ? void 0 : responsiveSettings.settings.slidesToScroll;
150
+ } else if ('slidesToScroll' in props) {
137
151
  slidesToScroll = props.slidesToScroll || 1;
138
152
  }
139
153
 
@@ -180,7 +194,7 @@ var FadeZoom = /*#__PURE__*/React__default.forwardRef(function (props, ref) {
180
194
 
181
195
  var wrapperRef = React.useRef(null);
182
196
  var innerWrapperRef = React.useRef(null);
183
- var tweenGroup = new TWEEN.Group();
197
+ var tweenGroup = React.useRef(new TWEEN.Group());
184
198
  var timeout = React.useRef();
185
199
  var resizeObserver = React.useRef();
186
200
  var childrenCount = React.useMemo(function () {
@@ -226,7 +240,7 @@ var FadeZoom = /*#__PURE__*/React__default.forwardRef(function (props, ref) {
226
240
  React.useEffect(function () {
227
241
  initResizeObserver();
228
242
  return function () {
229
- tweenGroup.removeAll();
243
+ tweenGroup.current.removeAll();
230
244
  clearTimeout(timeout.current);
231
245
  removeResizeObserver();
232
246
  };
@@ -309,7 +323,7 @@ var FadeZoom = /*#__PURE__*/React__default.forwardRef(function (props, ref) {
309
323
  };
310
324
 
311
325
  var transitionSlide = function transitionSlide(newIndex) {
312
- var existingTweens = tweenGroup.getAll();
326
+ var existingTweens = tweenGroup.current.getAll();
313
327
 
314
328
  if (!existingTweens.length) {
315
329
  var _innerWrapperRef$curr;
@@ -326,11 +340,11 @@ var FadeZoom = /*#__PURE__*/React__default.forwardRef(function (props, ref) {
326
340
 
327
341
  var animate = function animate() {
328
342
  requestAnimationFrame(animate);
329
- tweenGroup.update();
343
+ tweenGroup.current.update();
330
344
  };
331
345
 
332
346
  animate();
333
- var tween = new TWEEN.Tween(value, tweenGroup).to({
347
+ var tween = new TWEEN.Tween(value, tweenGroup.current).to({
334
348
  opacity: 1,
335
349
  scale: props.scale
336
350
  }, props.transitionDuration).onUpdate(function (value) {
@@ -430,13 +444,24 @@ var Slide = /*#__PURE__*/React__default.forwardRef(function (props, ref) {
430
444
 
431
445
  var wrapperRef = React.useRef(null);
432
446
  var innerWrapperRef = React.useRef(null);
433
- var tweenGroup = new TWEEN.Group();
447
+ var tweenGroup = React.useRef(new TWEEN.Group());
448
+ var responsiveSettings = React.useMemo(function () {
449
+ return getResponsiveSettings(wrapperWidth, props.responsive);
450
+ }, [wrapperWidth, props.responsive]);
434
451
  var slidesToScroll = React.useMemo(function () {
452
+ if (responsiveSettings) {
453
+ return responsiveSettings.settings.slidesToScroll;
454
+ }
455
+
435
456
  return props.slidesToScroll || 1;
436
- }, [props.slidesToScroll]);
457
+ }, [responsiveSettings, props.slidesToScroll]);
437
458
  var slidesToShow = React.useMemo(function () {
459
+ if (responsiveSettings) {
460
+ return responsiveSettings.settings.slidesToShow;
461
+ }
462
+
438
463
  return props.slidesToShow || 1;
439
- }, [props.slidesToShow]);
464
+ }, [responsiveSettings, props.slidesToShow]);
440
465
  var childrenCount = React.useMemo(function () {
441
466
  return React__default.Children.count(props.children);
442
467
  }, [props.children]);
@@ -488,7 +513,7 @@ var Slide = /*#__PURE__*/React__default.forwardRef(function (props, ref) {
488
513
  React.useEffect(function () {
489
514
  initResizeObserver();
490
515
  return function () {
491
- tweenGroup.removeAll();
516
+ tweenGroup.current.removeAll();
492
517
  clearTimeout(timeout.current);
493
518
  removeResizeObserver();
494
519
  };
@@ -524,10 +549,16 @@ var Slide = /*#__PURE__*/React__default.forwardRef(function (props, ref) {
524
549
  };
525
550
 
526
551
  var swipe = function swipe(event) {
527
- if (props.canSwipe) {
528
- var clientX = event.nativeEvent instanceof TouchEvent ? event.nativeEvent.touches[0].pageX : event.nativeEvent.clientX;
552
+ if (props.canSwipe && dragging) {
553
+ var clientX;
554
+
555
+ if (window.TouchEvent && event.nativeEvent instanceof TouchEvent) {
556
+ clientX = event.nativeEvent.touches[0].pageX;
557
+ } else if (event.nativeEvent instanceof MouseEvent) {
558
+ clientX = event.nativeEvent.clientX;
559
+ }
529
560
 
530
- if (dragging) {
561
+ if (clientX && startingClientX) {
531
562
  var translateValue = eachChildWidth * (index + getOffset());
532
563
  var distance = clientX - startingClientX;
533
564
 
@@ -652,7 +683,12 @@ var Slide = /*#__PURE__*/React__default.forwardRef(function (props, ref) {
652
683
 
653
684
  var startSwipe = function startSwipe(event) {
654
685
  if (props.canSwipe) {
655
- startingClientX = event.nativeEvent instanceof TouchEvent ? event.nativeEvent.touches[0].pageX : event.nativeEvent.clientX;
686
+ if (window.TouchEvent && event.nativeEvent instanceof TouchEvent) {
687
+ startingClientX = event.nativeEvent.touches[0].pageX;
688
+ } else if (event.nativeEvent instanceof MouseEvent) {
689
+ startingClientX = event.nativeEvent.clientX;
690
+ }
691
+
656
692
  clearTimeout(timeout.current);
657
693
  dragging = true;
658
694
  }
@@ -679,7 +715,7 @@ var Slide = /*#__PURE__*/React__default.forwardRef(function (props, ref) {
679
715
  var transitionSlide = function transitionSlide(toIndex, animationDuration) {
680
716
  var transitionDuration = animationDuration || props.transitionDuration;
681
717
  var currentIndex = index;
682
- var existingTweens = tweenGroup.getAll();
718
+ var existingTweens = tweenGroup.current.getAll();
683
719
 
684
720
  if (!wrapperRef.current) {
685
721
  return;
@@ -692,7 +728,7 @@ var Slide = /*#__PURE__*/React__default.forwardRef(function (props, ref) {
692
728
  var value = {
693
729
  margin: -childWidth * (currentIndex + getOffset()) + distanceSwiped
694
730
  };
695
- var tween = new TWEEN.Tween(value, tweenGroup).to({
731
+ var tween = new TWEEN.Tween(value, tweenGroup.current).to({
696
732
  margin: -childWidth * (toIndex + getOffset())
697
733
  }, transitionDuration).onUpdate(function (value) {
698
734
  if (innerWrapperRef.current) {
@@ -703,7 +739,7 @@ var Slide = /*#__PURE__*/React__default.forwardRef(function (props, ref) {
703
739
 
704
740
  var animate = function animate() {
705
741
  requestAnimationFrame(animate);
706
- tweenGroup.update();
742
+ tweenGroup.current.update();
707
743
  };
708
744
 
709
745
  animate();
@@ -774,7 +810,7 @@ var Slide = /*#__PURE__*/React__default.forwardRef(function (props, ref) {
774
810
  "aria-roledescription": "slide",
775
811
  "aria-hidden": isThisSlideActive ? 'false' : 'true'
776
812
  }, each);
777
- }), renderTrailingSlides())), props.arrows && showNextArrow(props, index, moveSlides)), props.indicators && showIndicators(props, index, goToSlide));
813
+ }), renderTrailingSlides())), props.arrows && showNextArrow(props, index, moveSlides)), props.indicators && showIndicators(props, index, goToSlide, responsiveSettings));
778
814
  });
779
815
  Slide.defaultProps = defaultProps;
780
816
 
@@ -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 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 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 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","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","type","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 = (index: number) => {\n transitionSlide(index);\n };\n\n const navigate: ButtonClick = (event) => {\n const { currentTarget } = event;\n if (!currentTarget.dataset.key) {\n return;\n }\n if (parseInt(currentTarget.dataset.key) !== index) {\n moveTo(parseInt(currentTarget.dataset.key));\n }\n };\n\n return (\n <div dir=\"ltr\" aria-roledescription=\"carousel\">\n <div\n className={`react-slideshow-container ${props.cssClass || ''}`}\n onMouseEnter={pauseSlides}\n onMouseOver={pauseSlides}\n onMouseLeave={startSlides}\n ref={props.ref}\n >\n {props.arrows && showPreviousArrow(props, index, preTransition)}\n <div\n className={`react-slideshow-fadezoom-wrapper ${props.cssClass}`}\n ref={wrapperRef}\n >\n <div className=\"react-slideshow-fadezoom-images-wrap\" ref={innerWrapperRef}>\n {(React.Children.map(props.children, (thisArg) => thisArg) || []).map(\n (each, key) => (\n <div\n style={{\n opacity: key === index ? '1' : '0',\n zIndex: key === index ? '1' : '0',\n }}\n data-index={key}\n key={key}\n aria-roledescription=\"slide\"\n aria-hidden={key === index ? 'false' : 'true'}\n >\n {each}\n </div>\n )\n )}\n </div>\n </div>\n {props.arrows && showNextArrow(props, index, preTransition)}\n </div>\n {props.indicators && showIndicators(props, index, navigate)}\n </div>\n );\n});\n\nFadeZoom.defaultProps = defaultProps;\n","import React from 'react';\nimport { FadeZoom } from './fadezoom';\nimport { defaultProps } from './props';\nimport { FadeProps, SlideshowRef } from './types';\n\nexport const Fade = React.forwardRef<SlideshowRef, FadeProps>((props, ref) => {\n return <FadeZoom {...props} scale={1} ref={ref} />;\n});\n\nFade.defaultProps = defaultProps;\n","import React from 'react';\nimport { FadeZoom } from './fadezoom';\nimport { defaultProps } from './props';\nimport { SlideshowRef, ZoomProps } from './types';\n\nexport const Zoom = React.forwardRef<SlideshowRef, ZoomProps>((props, ref) => {\n return <FadeZoom {...props} ref={ref} />;\n});\n\nZoom.defaultProps = defaultProps;\n","import React, {\n useState,\n useRef,\n useEffect,\n useMemo,\n useImperativeHandle,\n useCallback,\n} from 'react';\nimport ResizeObserver from 'resize-observer-polyfill';\nimport TWEEN from '@tweenjs/tween.js';\nimport {\n getEasing,\n getResponsiveSettings,\n getStartingIndex,\n showIndicators,\n showNextArrow,\n showPreviousArrow,\n} from './helpers';\nimport { ButtonClick, SlideshowRef, SlideProps } from './types';\nimport { defaultProps } from './props';\n\nexport const Slide = React.forwardRef<SlideshowRef, SlideProps>((props, ref) => {\n const [index, setIndex] = useState(getStartingIndex(props.children, props.defaultIndex));\n const [wrapperWidth, setWrapperWidth] = useState<number>(0);\n const wrapperRef = useRef<HTMLDivElement>(null);\n const innerWrapperRef = useRef<any>(null);\n const tweenGroup = useRef(new TWEEN.Group());\n const responsiveSettings = useMemo(\n () => getResponsiveSettings(wrapperWidth, props.responsive),\n [wrapperWidth, props.responsive]\n );\n const slidesToScroll = useMemo(() => {\n if (responsiveSettings) {\n return responsiveSettings.settings.slidesToScroll;\n }\n return props.slidesToScroll || 1;\n }, [responsiveSettings, props.slidesToScroll]);\n const slidesToShow = useMemo(() => {\n if (responsiveSettings) {\n return responsiveSettings.settings.slidesToShow;\n }\n return props.slidesToShow || 1;\n }, [responsiveSettings, props.slidesToShow]);\n const childrenCount = useMemo(() => React.Children.count(props.children), [props.children]);\n const eachChildWidth = useMemo(() => wrapperWidth / slidesToShow, [wrapperWidth, slidesToShow]);\n const timeout = useRef<NodeJS.Timeout>();\n const resizeObserver = useRef<any>();\n let startingClientX: number;\n let dragging: boolean = false;\n let distanceSwiped: number = 0;\n\n const applyStyle = useCallback(() => {\n if (innerWrapperRef.current) {\n const fullwidth = wrapperWidth * innerWrapperRef.current.children.length;\n innerWrapperRef.current.style.width = `${fullwidth}px`;\n for (let index = 0; index < innerWrapperRef.current.children.length; index++) {\n const eachDiv = innerWrapperRef.current.children[index];\n if (eachDiv) {\n eachDiv.style.width = `${eachChildWidth}px`;\n eachDiv.style.display = `block`;\n }\n }\n }\n }, [wrapperWidth, eachChildWidth]);\n\n const initResizeObserver = useCallback(() => {\n if (wrapperRef.current) {\n resizeObserver.current = new ResizeObserver((entries) => {\n if (!entries) return;\n setWidth();\n });\n resizeObserver.current.observe(wrapperRef.current);\n }\n }, [wrapperRef]);\n\n const play = useCallback(() => {\n const { autoplay, infinite, duration } = props;\n if (autoplay && (infinite || index < childrenCount - 1)) {\n timeout.current = setTimeout(moveNext, duration);\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [props, childrenCount, index]);\n\n useEffect(() => {\n applyStyle();\n }, [wrapperWidth, applyStyle]);\n\n useEffect(() => {\n initResizeObserver();\n return () => {\n tweenGroup.current.removeAll();\n clearTimeout(timeout.current);\n removeResizeObserver();\n };\n }, [wrapperRef, initResizeObserver, tweenGroup]);\n\n useEffect(() => {\n clearTimeout(timeout.current);\n play();\n }, [index, wrapperWidth, props.autoplay, play]);\n\n useImperativeHandle(ref, () => ({\n goNext: () => {\n moveNext();\n },\n goBack: () => {\n moveBack();\n },\n goTo: (index: number) => {\n moveTo(index);\n },\n }));\n\n const removeResizeObserver = () => {\n if (resizeObserver && wrapperRef.current) {\n resizeObserver.current.unobserve(wrapperRef.current);\n }\n };\n\n const pauseSlides = () => {\n if (props.pauseOnHover) {\n clearTimeout(timeout.current);\n }\n };\n\n const swipe = (event: React.MouseEvent | React.TouchEvent) => {\n if (props.canSwipe && dragging) {\n let clientX;\n if (window.TouchEvent && event.nativeEvent instanceof TouchEvent) {\n clientX = event.nativeEvent.touches[0].pageX;\n } else if (event.nativeEvent instanceof MouseEvent) {\n clientX = event.nativeEvent.clientX;\n }\n if (clientX && startingClientX) {\n let translateValue = eachChildWidth * (index + getOffset());\n const distance = clientX - startingClientX;\n if (!props.infinite && index === childrenCount - slidesToScroll && distance < 0) {\n // if it is the last and infinite is false and you're swiping left\n // then nothing happens\n return;\n }\n if (!props.infinite && index === 0 && distance > 0) {\n // if it is the first and infinite is false and you're swiping right\n // then nothing happens\n return;\n }\n distanceSwiped = distance;\n translateValue -= distanceSwiped;\n innerWrapperRef.current.style.transform = `translate(-${translateValue}px)`;\n }\n }\n };\n\n const moveNext = () => {\n if (!props.infinite && index === childrenCount - slidesToScroll) {\n return;\n }\n const nextIndex = calculateIndex(index + slidesToScroll);\n transitionSlide(nextIndex);\n };\n\n const moveBack = () => {\n if (!props.infinite && index === 0) {\n return;\n }\n let previousIndex = index - slidesToScroll;\n if (previousIndex % slidesToScroll) {\n previousIndex = Math.ceil(previousIndex / slidesToScroll) * slidesToScroll;\n }\n transitionSlide(previousIndex);\n };\n\n const goToSlide: ButtonClick = ({ currentTarget }) => {\n if (!currentTarget.dataset.key) {\n return;\n }\n const datasetKey = parseInt(currentTarget.dataset.key);\n moveTo(datasetKey * slidesToScroll);\n };\n\n const moveTo = (index: number) => {\n transitionSlide(calculateIndex(index));\n };\n\n const calculateIndex = (nextIndex: number): number => {\n if (nextIndex < childrenCount && nextIndex + slidesToScroll > childrenCount) {\n if ((childrenCount - slidesToScroll) % slidesToScroll) {\n return childrenCount - slidesToScroll;\n }\n return nextIndex;\n }\n return nextIndex;\n };\n\n const startSlides = () => {\n if (dragging) {\n endSwipe();\n } else if (props.pauseOnHover && props.autoplay) {\n timeout.current = setTimeout(moveNext, props.duration);\n }\n };\n\n const moveSlides: ButtonClick = ({ currentTarget: { dataset } }) => {\n if (dataset.type === 'next') {\n moveNext();\n } else {\n moveBack();\n }\n };\n\n const renderPreceedingSlides = () => {\n return React.Children.toArray(props.children)\n .slice(-slidesToShow)\n .map((each, index) => (\n <div\n data-index={index - slidesToShow}\n aria-roledescription=\"slide\"\n aria-hidden=\"true\"\n key={index - slidesToShow}\n >\n {each}\n </div>\n ));\n };\n\n const renderTrailingSlides = () => {\n if (!props.infinite && slidesToShow === slidesToScroll) {\n return;\n }\n return React.Children.toArray(props.children)\n .slice(0, slidesToShow)\n .map((each, index) => (\n <div\n data-index={childrenCount + index}\n aria-roledescription=\"slide\"\n aria-hidden=\"true\"\n key={childrenCount + index}\n >\n {each}\n </div>\n ));\n };\n\n const setWidth = () => {\n if (wrapperRef.current) {\n setWrapperWidth(wrapperRef.current.clientWidth);\n }\n };\n\n const startSwipe = (event: React.MouseEvent | React.TouchEvent) => {\n if (props.canSwipe) {\n if (window.TouchEvent && event.nativeEvent instanceof TouchEvent) {\n startingClientX = event.nativeEvent.touches[0].pageX;\n } else if (event.nativeEvent instanceof MouseEvent) {\n startingClientX = event.nativeEvent.clientX;\n }\n clearTimeout(timeout.current);\n dragging = true;\n }\n };\n\n const endSwipe = () => {\n if (props.canSwipe) {\n dragging = false;\n if (Math.abs(distanceSwiped) / wrapperWidth > 0.2) {\n if (distanceSwiped < 0) {\n moveNext();\n } else {\n moveBack();\n }\n } else {\n if (Math.abs(distanceSwiped) > 0) {\n transitionSlide(index, 300);\n }\n }\n }\n };\n\n const transitionSlide = (toIndex: number, animationDuration?: number) => {\n const transitionDuration = animationDuration || props.transitionDuration;\n const currentIndex = index;\n const existingTweens = tweenGroup.current.getAll();\n if (!wrapperRef.current) {\n return;\n }\n const childWidth = wrapperRef.current.clientWidth / slidesToShow;\n if (!existingTweens.length) {\n clearTimeout(timeout.current);\n const value = {\n margin: -childWidth * (currentIndex + getOffset()) + distanceSwiped,\n };\n const tween = new TWEEN.Tween(value, tweenGroup.current)\n .to({ margin: -childWidth * (toIndex + getOffset()) }, transitionDuration)\n .onUpdate((value) => {\n if (innerWrapperRef.current) {\n innerWrapperRef.current.style.transform = `translate(${value.margin}px)`;\n }\n })\n .start();\n tween.easing(getEasing(props.easing));\n const animate = () => {\n requestAnimationFrame(animate);\n tweenGroup.current.update();\n };\n\n animate();\n\n tween.onComplete(() => {\n distanceSwiped = 0;\n let newIndex = toIndex;\n if (newIndex < 0) {\n newIndex = childrenCount - slidesToScroll;\n } else if (newIndex >= childrenCount) {\n newIndex = 0;\n }\n\n if (typeof props.onChange === 'function') {\n props.onChange(index, newIndex);\n }\n setIndex(newIndex);\n });\n }\n };\n\n const isSlideActive = (key: number) => {\n return key < index + slidesToShow && key >= index;\n };\n\n const getOffset = (): number => {\n if (!props.infinite) {\n return 0;\n }\n return slidesToShow;\n };\n\n const style = {\n transform: `translate(-${(index + getOffset()) * eachChildWidth}px)`,\n };\n return (\n <div dir=\"ltr\" aria-roledescription=\"carousel\">\n <div\n className=\"react-slideshow-container\"\n onMouseEnter={pauseSlides}\n onMouseOver={pauseSlides}\n onMouseLeave={startSlides}\n onMouseDown={startSwipe}\n onMouseUp={endSwipe}\n onMouseMove={swipe}\n onTouchStart={startSwipe}\n onTouchEnd={endSwipe}\n onTouchCancel={endSwipe}\n onTouchMove={swipe}\n >\n {props.arrows && showPreviousArrow(props, index, moveSlides)}\n <div\n className={`react-slideshow-wrapper slide ${props.cssClass || ''}`}\n ref={wrapperRef}\n >\n <div className=\"images-wrap\" style={style} ref={innerWrapperRef}>\n {props.infinite && renderPreceedingSlides()}\n {(React.Children.map(props.children, (thisArg) => thisArg) || []).map(\n (each, key) => {\n const isThisSlideActive = isSlideActive(key);\n return (\n <div\n data-index={key}\n key={key}\n className={isThisSlideActive ? 'active' : ''}\n aria-roledescription=\"slide\"\n aria-hidden={isThisSlideActive ? 'false' : 'true'}\n >\n {each}\n </div>\n );\n }\n )}\n {renderTrailingSlides()}\n </div>\n </div>\n {props.arrows && showNextArrow(props, index, moveSlides)}\n </div>\n {props.indicators && showIndicators(props, index, goToSlide, responsiveSettings)}\n </div>\n );\n});\n\nSlide.defaultProps = defaultProps;\n"],"names":["getStartingIndex","children","defaultIndex","React","Children","count","getResponsiveSettings","wrapperWidth","responsive","window","Array","isArray","find","each","breakpoint","EASING_METHODS","linear","TWEEN","Easing","Linear","None","ease","Quadratic","InOut","In","Out","cubic","Cubic","getEasing","easeMethod","showPreviousArrow","currentIndex","moveSlides","prevArrow","infinite","isDisabled","props","disabled","onClick","cloneElement","className","type","width","height","viewBox","d","showNextArrow","properties","nextArrow","slidesToScroll","showDefaultIndicator","isCurrentPageActive","key","indicatorProps","showCustomIndicator","eachIndicator","showIndicators","navigate","responsiveSettings","indicators","settings","pages","Math","ceil","from","length","_","floor","defaultProps","duration","transitionDuration","autoplay","arrows","pauseOnHover","easing","canSwipe","cssClass","FadeZoom","forwardRef","ref","useState","index","setIndex","wrapperRef","useRef","innerWrapperRef","tweenGroup","Group","timeout","resizeObserver","childrenCount","useMemo","applyStyle","useCallback","current","clientWidth","fullwidth","style","eachDiv","left","display","initResizeObserver","ResizeObserver","entries","observe","play","setTimeout","moveNext","useEffect","removeAll","clearTimeout","removeResizeObserver","useImperativeHandle","goNext","goBack","moveBack","goTo","moveTo","unobserve","pauseSlides","startSlides","transitionSlide","preTransition","event","currentTarget","dataset","newIndex","existingTweens","getAll","value","opacity","scale","animate","requestAnimationFrame","update","tween","Tween","to","onUpdate","transform","start","onComplete","onChange","parseInt","dir","onMouseEnter","onMouseOver","onMouseLeave","map","thisArg","zIndex","Fade","Zoom","Slide","setWrapperWidth","slidesToShow","eachChildWidth","startingClientX","dragging","distanceSwiped","setWidth","swipe","clientX","TouchEvent","nativeEvent","touches","pageX","MouseEvent","translateValue","getOffset","distance","nextIndex","calculateIndex","previousIndex","goToSlide","datasetKey","endSwipe","renderPreceedingSlides","toArray","slice","renderTrailingSlides","startSwipe","abs","toIndex","animationDuration","childWidth","margin","isSlideActive","onMouseDown","onMouseUp","onMouseMove","onTouchStart","onTouchEnd","onTouchCancel","onTouchMove","isThisSlideActive"],"mappings":"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"}
@@ -1,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({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({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({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:[]},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=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]),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 b(),function(){m.removeAll(),clearTimeout(y.current),T()}}),[b,m]),n.useEffect((function(){clearTimeout(y.current),C()}),[d,e.autoplay,C]),n.useEffect((function(){w()}),[E,w]),n.useImperativeHandle(a,(function(){return{goNext:function(){k()},goBack:function(){M()},goTo:function(e){S(e)}}}));var T=function(){g.current&&p.current&&g.current.unobserve(p.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&&(v(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: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&&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))})))}));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=new i.Group,b=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||v<T-1)&&(k.current=setTimeout(P,e.duration))}),[e,T,v]);n.useEffect((function(){S()}),[m,S]),n.useEffect((function(){return I(),function(){w.removeAll(),clearTimeout(k.current),R()}}),[g,I,w]),n.useEffect((function(){clearTimeout(k.current),j()}),[v,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*(v+Q()),i=t-o;if(!e.infinite&&v===T-b&&i<0)return;if(!e.infinite&&0===v&&i>0)return;E.current.style.transform="translate(-"+(r-=O=i)+"px)"}}},P=function(){if(e.infinite||v!==T-b){var n=B(v+b);L(n)}},z=function(){if(e.infinite||0!==v){var n=v-b;n%b&&(n=Math.ceil(n/b)*b),L(n)}},q=function(e){L(B(e))},B=function(e){return e<T&&e+b>T&&(T-b)%b?T-b: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(v,300))},L=function(n,t){var r=t||e.transitionDuration,a=v,c=w.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,w).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),w.update()}(),s.onComplete((function(){O=0;var t=n;t<0?t=T-b:t>=T&&(t=0),"function"==typeof e.onChange&&e.onChange(v,t),p(t)}))}}},Q=function(){return e.infinite?C:0},U={transform:"translate(-"+(v+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,v,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<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!==b)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,v,D)),e.indicators&&f(e,v,(function(e){var n=e.currentTarget;if(n.dataset.key){var t=parseInt(n.dataset.key);q(t*b)}})))}));m.defaultProps=d,exports.Fade=p,exports.Slide=m,exports.Zoom=h;
1
+ "use strict";function e(e){return e&&"object"==typeof e&&"default"in e?e.default:e}Object.defineProperty(exports,"__esModule",{value:!0});var n=require("react"),t=e(n),r=e(require("resize-observer-polyfill")),i=e(require("@tweenjs/tween.js"));function a(){return(a=Object.assign?Object.assign.bind():function(e){for(var n=1;n<arguments.length;n++){var t=arguments[n];for(var r in t)Object.prototype.hasOwnProperty.call(t,r)&&(e[r]=t[r])}return e}).apply(this,arguments)}var c=function(e,n){return n&&n<t.Children.count(e)?n:0},o={linear:i.Easing.Linear.None,ease:i.Easing.Quadratic.InOut,"ease-in":i.Easing.Quadratic.In,"ease-out":i.Easing.Quadratic.Out,cubic:i.Easing.Cubic.InOut,"cubic-in":i.Easing.Cubic.In,"cubic-out":i.Easing.Cubic.Out},u=function(e){return e?o[e]:o.linear},s=function(e,n,r){var i=e.prevArrow,c=n<=0&&!e.infinite,o={"data-type":"prev","aria-label":"Previous Slide",disabled:c,onClick:r};return i?t.cloneElement(i,a({className:(i.props.className||"")+" nav "+(c?"disabled":"")},o)):t.createElement("button",Object.assign({type:"button",className:"nav default-nav "+(c?"disabled":"")},o),t.createElement("svg",{width:"24",height:"24",viewBox:"0 0 24 24"},t.createElement("path",{d:"M16.67 0l2.83 2.829-9.339 9.175 9.339 9.167-2.83 2.829-12.17-11.996z"})))},l=function(e,n,r){var i=e.nextArrow,c=e.infinite,o=1;"slidesToScroll"in e&&(o=e.slidesToScroll||1);var u=n>=t.Children.count(e.children)-o&&!c,s={"data-type":"next","aria-label":"Next Slide",disabled:u,onClick:r};return i?t.cloneElement(i,a({className:(i.props.className||"")+" nav "+(u?"disabled":"")},s)):t.createElement("button",Object.assign({type:"button",className:"nav default-nav "+(u?"disabled":"")},s),t.createElement("svg",{width:"24",height:"24",viewBox:"0 0 24 24"},t.createElement("path",{d:"M5 3l3.057-3 11.943 12-11.943 12-3.057-3 9-9z"})))},f=function(e,n,r,i){var c=e.indicators,o=1;i?o=null==i?void 0:i.settings.slidesToScroll:"slidesToScroll"in e&&(o=e.slidesToScroll||1);var u=Math.ceil(t.Children.count(e.children)/o);return t.createElement("ul",{className:"indicators"},Array.from({length:u},(function(e,i){var u={"data-key":i,"aria-label":"Go to slide "+(i+1),onClick:r},s=Math.floor((n+o-1)/o)===i;return"function"==typeof c?function(e,n,r,i){return t.cloneElement(i,a({className:i.props.className+" "+(e?"active":""),key:n},r))}(s,i,u,c(i)):function(e,n,r){return t.createElement("li",{key:n},t.createElement("button",Object.assign({type:"button",className:"each-slideshow-indicator "+(e?"active":"")},r)))}(s,i,u)})))},d={duration:5e3,transitionDuration:1e3,defaultIndex:0,infinite:!0,autoplay:!0,indicators:!1,arrows:!0,pauseOnHover:!0,easing:"linear",canSwipe:!0,cssClass:"",responsive:[]},v=t.forwardRef((function(e,a){var o=n.useState(c(e.children,e.defaultIndex)),d=o[0],v=o[1],p=n.useRef(null),h=n.useRef(null),m=n.useRef(new i.Group),y=n.useRef(),g=n.useRef(),E=n.useMemo((function(){return t.Children.count(e.children)}),[e.children]),w=n.useCallback((function(){if(h.current&&p.current){var e=p.current.clientWidth;h.current.style.width=e*E+"px";for(var n=0;n<h.current.children.length;n++){var t=h.current.children[n];t&&(t.style.width=e+"px",t.style.left=n*-e+"px",t.style.display="block")}}}),[p,h,E]),b=n.useCallback((function(){p.current&&(g.current=new r((function(e){e&&w()})),g.current.observe(p.current))}),[p,w]),T=n.useCallback((function(){var n=e.children,r=e.duration,i=e.infinite;e.autoplay&&t.Children.count(n)>1&&(i||d<t.Children.count(n)-1)&&(y.current=setTimeout(M,r))}),[e,d]);n.useEffect((function(){return b(),function(){m.current.removeAll(),clearTimeout(y.current),C()}}),[b,m]),n.useEffect((function(){clearTimeout(y.current),T()}),[d,e.autoplay,T]),n.useEffect((function(){w()}),[E,w]),n.useImperativeHandle(a,(function(){return{goNext:function(){M()},goBack:function(){k()},goTo:function(e){O(e)}}}));var C=function(){g.current&&p.current&&g.current.unobserve(p.current)},x=function(){e.pauseOnHover&&clearTimeout(y.current)},M=function(){var n=e.children;(e.infinite||d!==t.Children.count(n)-1)&&N((d+1)%t.Children.count(n))},k=function(){(e.infinite||0!==d)&&N(0===d?t.Children.count(e.children)-1:d-1)},S=function(e){"prev"===e.currentTarget.dataset.type?k():M()},N=function(n){if(!m.current.getAll().length){var t;null!=(t=h.current)&&t.children[n]||(n=0),clearTimeout(y.current),function e(){requestAnimationFrame(e),m.current.update()}();var r=new i.Tween({opacity:0,scale:1},m.current).to({opacity:1,scale:e.scale},e.transitionDuration).onUpdate((function(e){h.current&&(h.current.children[n].style.opacity=e.opacity,h.current.children[d].style.opacity=1-e.opacity,h.current.children[d].style.transform="scale("+e.scale+")")})).start();r.easing(u(e.easing)),r.onComplete((function(){h.current&&(v(n),h.current.children[d].style.transform="scale(1)"),"function"==typeof e.onChange&&e.onChange(d,n)}))}},O=function(e){N(e)};return t.createElement("div",{dir:"ltr","aria-roledescription":"carousel"},t.createElement("div",{className:"react-slideshow-container "+(e.cssClass||""),onMouseEnter:x,onMouseOver:x,onMouseLeave:function(){e.pauseOnHover&&e.autoplay&&(y.current=setTimeout((function(){return M()}),e.duration))},ref:e.ref},e.arrows&&s(e,d,S),t.createElement("div",{className:"react-slideshow-fadezoom-wrapper "+e.cssClass,ref:p},t.createElement("div",{className:"react-slideshow-fadezoom-images-wrap",ref:h},(t.Children.map(e.children,(function(e){return e}))||[]).map((function(e,n){return t.createElement("div",{style:{opacity:n===d?"1":"0",zIndex:n===d?"1":"0"},"data-index":n,key:n,"aria-roledescription":"slide","aria-hidden":n===d?"false":"true"},e)})))),e.arrows&&l(e,d,S)),e.indicators&&f(e,d,(function(e){var n=e.currentTarget;n.dataset.key&&parseInt(n.dataset.key)!==d&&O(parseInt(n.dataset.key))})))}));v.defaultProps=d;var p=t.forwardRef((function(e,n){return t.createElement(v,Object.assign({},e,{scale:1,ref:n}))}));p.defaultProps=d;var h=t.forwardRef((function(e,n){return t.createElement(v,Object.assign({},e,{ref:n}))}));h.defaultProps=d;var m=t.forwardRef((function(e,a){var o,d=n.useState(c(e.children,e.defaultIndex)),v=d[0],p=d[1],h=n.useState(0),m=h[0],y=h[1],g=n.useRef(null),E=n.useRef(null),w=n.useRef(new i.Group),b=n.useMemo((function(){return function(e,n){if("undefined"!=typeof window&&Array.isArray(n))return n.find((function(n){return n.breakpoint<=e}))}(m,e.responsive)}),[m,e.responsive]),T=n.useMemo((function(){return b?b.settings.slidesToScroll:e.slidesToScroll||1}),[b,e.slidesToScroll]),C=n.useMemo((function(){return b?b.settings.slidesToShow:e.slidesToShow||1}),[b,e.slidesToShow]),x=n.useMemo((function(){return t.Children.count(e.children)}),[e.children]),M=n.useMemo((function(){return m/C}),[m,C]),k=n.useRef(),S=n.useRef(),N=!1,O=0,R=n.useCallback((function(){if(E.current){E.current.style.width=m*E.current.children.length+"px";for(var e=0;e<E.current.children.length;e++){var n=E.current.children[e];n&&(n.style.width=M+"px",n.style.display="block")}}}),[m,M]),A=n.useCallback((function(){g.current&&(S.current=new r((function(e){e&&F()})),S.current.observe(g.current))}),[g]),I=n.useCallback((function(){e.autoplay&&(e.infinite||v<x-1)&&(k.current=setTimeout(z,e.duration))}),[e,x,v]);n.useEffect((function(){R()}),[m,R]),n.useEffect((function(){return A(),function(){w.current.removeAll(),clearTimeout(k.current),j()}}),[g,A,w]),n.useEffect((function(){clearTimeout(k.current),I()}),[v,m,e.autoplay,I]),n.useImperativeHandle(a,(function(){return{goNext:function(){z()},goBack:function(){q()},goTo:function(e){B(e)}}}));var j=function(){S&&g.current&&S.current.unobserve(g.current)},H=function(){e.pauseOnHover&&clearTimeout(k.current)},P=function(n){var t;if(e.canSwipe&&N&&(window.TouchEvent&&n.nativeEvent instanceof TouchEvent?t=n.nativeEvent.touches[0].pageX:n.nativeEvent instanceof MouseEvent&&(t=n.nativeEvent.clientX),t&&o)){var r=M*(v+U()),i=t-o;if(!e.infinite&&v===x-T&&i<0)return;if(!e.infinite&&0===v&&i>0)return;E.current.style.transform="translate(-"+(r-=O=i)+"px)"}},z=function(){if(e.infinite||v!==x-T){var n=D(v+T);Q(n)}},q=function(){if(e.infinite||0!==v){var n=v-T;n%T&&(n=Math.ceil(n/T)*T),Q(n)}},B=function(e){Q(D(e))},D=function(e){return e<x&&e+T>x&&(x-T)%T?x-T:e},X=function(e){"next"===e.currentTarget.dataset.type?z():q()},F=function(){g.current&&y(g.current.clientWidth)},G=function(n){e.canSwipe&&(window.TouchEvent&&n.nativeEvent instanceof TouchEvent?o=n.nativeEvent.touches[0].pageX:n.nativeEvent instanceof MouseEvent&&(o=n.nativeEvent.clientX),clearTimeout(k.current),N=!0)},L=function(){e.canSwipe&&(N=!1,Math.abs(O)/m>.2?O<0?z():q():Math.abs(O)>0&&Q(v,300))},Q=function(n,t){var r=t||e.transitionDuration,a=v,c=w.current.getAll();if(g.current){var o=g.current.clientWidth/C;if(!c.length){clearTimeout(k.current);var s={margin:-o*(a+U())+O},l=new i.Tween(s,w.current).to({margin:-o*(n+U())},r).onUpdate((function(e){E.current&&(E.current.style.transform="translate("+e.margin+"px)")})).start();l.easing(u(e.easing)),function e(){requestAnimationFrame(e),w.current.update()}(),l.onComplete((function(){O=0;var t=n;t<0?t=x-T:t>=x&&(t=0),"function"==typeof e.onChange&&e.onChange(v,t),p(t)}))}}},U=function(){return e.infinite?C:0},W={transform:"translate(-"+(v+U())*M+"px)"};return t.createElement("div",{dir:"ltr","aria-roledescription":"carousel"},t.createElement("div",{className:"react-slideshow-container",onMouseEnter:H,onMouseOver:H,onMouseLeave:function(){N?L():e.pauseOnHover&&e.autoplay&&(k.current=setTimeout(z,e.duration))},onMouseDown:G,onMouseUp:L,onMouseMove:P,onTouchStart:G,onTouchEnd:L,onTouchCancel:L,onTouchMove:P},e.arrows&&s(e,v,X),t.createElement("div",{className:"react-slideshow-wrapper slide "+(e.cssClass||""),ref:g},t.createElement("div",{className:"images-wrap",style:W,ref:E},e.infinite&&t.Children.toArray(e.children).slice(-C).map((function(e,n){return t.createElement("div",{"data-index":n-C,"aria-roledescription":"slide","aria-hidden":"true",key:n-C},e)})),(t.Children.map(e.children,(function(e){return e}))||[]).map((function(e,n){var r=function(e){return e<v+C&&e>=v}(n);return t.createElement("div",{"data-index":n,key:n,className:r?"active":"","aria-roledescription":"slide","aria-hidden":r?"false":"true"},e)})),function(){if(e.infinite||C!==T)return t.Children.toArray(e.children).slice(0,C).map((function(e,n){return t.createElement("div",{"data-index":x+n,"aria-roledescription":"slide","aria-hidden":"true",key:x+n},e)}))}())),e.arrows&&l(e,v,X)),e.indicators&&f(e,v,(function(e){var n=e.currentTarget;if(n.dataset.key){var t=parseInt(n.dataset.key);B(t*T)}}),b))}));m.defaultProps=d,exports.Fade=p,exports.Slide=m,exports.Zoom=h;
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 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 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 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","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","type","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":"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"}
1
+ {"version":3,"file":"react-slideshow-image.cjs.production.min.js","sources":["../src/helpers.tsx","../src/props.ts","../src/fadezoom.tsx","../src/fade.tsx","../src/zoom.tsx","../src/slide.tsx"],"sourcesContent":["import React, { ReactNode } from 'react';\nimport {\n ButtonClick,\n FadeProps,\n IndicatorPropsType,\n Responsive,\n SlideProps,\n TweenEasingFn,\n ZoomProps,\n} from './types';\nimport TWEEN from '@tweenjs/tween.js';\n\nexport const getStartingIndex = (children: ReactNode, defaultIndex?: number): number => {\n if (defaultIndex && defaultIndex < React.Children.count(children)) {\n return defaultIndex;\n }\n return 0;\n};\n\nexport const getResponsiveSettings = (\n wrapperWidth: number,\n responsive?: Array<Responsive>\n): Responsive | undefined => {\n if (typeof window !== 'undefined' && Array.isArray(responsive)) {\n return responsive.find((each) => each.breakpoint <= wrapperWidth);\n }\n return;\n};\n\nconst EASING_METHODS: { [key: string]: TweenEasingFn } = {\n linear: TWEEN.Easing.Linear.None,\n ease: TWEEN.Easing.Quadratic.InOut,\n 'ease-in': TWEEN.Easing.Quadratic.In,\n 'ease-out': TWEEN.Easing.Quadratic.Out,\n cubic: TWEEN.Easing.Cubic.InOut,\n 'cubic-in': TWEEN.Easing.Cubic.In,\n 'cubic-out': TWEEN.Easing.Cubic.Out,\n};\n\nexport const getEasing = (easeMethod?: string): TweenEasingFn => {\n if (easeMethod) {\n return EASING_METHODS[easeMethod];\n }\n return EASING_METHODS.linear;\n};\n\nexport const showPreviousArrow = (\n { prevArrow, infinite }: FadeProps | SlideProps | ZoomProps,\n currentIndex: number,\n moveSlides: ButtonClick\n): ReactNode => {\n const isDisabled = currentIndex <= 0 && !infinite;\n const props = {\n 'data-type': 'prev',\n 'aria-label': 'Previous Slide',\n disabled: isDisabled,\n onClick: moveSlides,\n };\n if (prevArrow) {\n return React.cloneElement(prevArrow, {\n className: `${prevArrow.props.className || ''} nav ${isDisabled ? 'disabled' : ''}`,\n ...props,\n });\n }\n const className = `nav default-nav ${isDisabled ? 'disabled' : ''}`;\n return (\n <button type=\"button\" className={className} {...props}>\n <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\">\n <path d=\"M16.67 0l2.83 2.829-9.339 9.175 9.339 9.167-2.83 2.829-12.17-11.996z\" />\n </svg>\n </button>\n );\n};\n\nexport const showNextArrow = (\n properties: FadeProps | SlideProps | ZoomProps,\n currentIndex: number,\n moveSlides: ButtonClick\n) => {\n const { nextArrow, infinite, children } = properties;\n let slidesToScroll = 1;\n if ('slidesToScroll' in properties) {\n slidesToScroll = properties.slidesToScroll || 1;\n }\n const isDisabled = currentIndex >= React.Children.count(children) - slidesToScroll && !infinite;\n const props = {\n 'data-type': 'next',\n 'aria-label': 'Next Slide',\n disabled: isDisabled,\n onClick: moveSlides,\n };\n if (nextArrow) {\n return React.cloneElement(nextArrow, {\n className: `${nextArrow.props.className || ''} nav ${isDisabled ? 'disabled' : ''}`,\n ...props,\n });\n }\n const className = `nav default-nav ${isDisabled ? 'disabled' : ''}`;\n return (\n <button type=\"button\" className={className} {...props}>\n <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\">\n <path d=\"M5 3l3.057-3 11.943 12-11.943 12-3.057-3 9-9z\" />\n </svg>\n </button>\n );\n};\n\nconst showDefaultIndicator = (\n isCurrentPageActive: boolean,\n key: number,\n indicatorProps: IndicatorPropsType\n) => {\n return (\n <li key={key}>\n <button\n type=\"button\"\n className={`each-slideshow-indicator ${isCurrentPageActive ? 'active' : ''}`}\n {...indicatorProps}\n />\n </li>\n );\n};\n\nconst showCustomIndicator = (\n isCurrentPageActive: boolean,\n key: number,\n indicatorProps: any,\n eachIndicator: any\n) => {\n return React.cloneElement(eachIndicator, {\n className: `${eachIndicator.props.className} ${isCurrentPageActive ? 'active' : ''}`,\n key,\n ...indicatorProps,\n });\n};\n\nexport const showIndicators = (\n props: FadeProps | SlideProps | ZoomProps,\n currentIndex: number,\n navigate: ButtonClick,\n responsiveSettings?: Responsive\n): ReactNode => {\n const { children, indicators } = props;\n let slidesToScroll = 1;\n if (responsiveSettings) {\n slidesToScroll = responsiveSettings?.settings.slidesToScroll;\n } else if ('slidesToScroll' in props) {\n slidesToScroll = props.slidesToScroll || 1;\n }\n const pages = Math.ceil(React.Children.count(children) / slidesToScroll);\n return (\n <ul className=\"indicators\">\n {Array.from({ length: pages }, (_, key) => {\n const indicatorProps: IndicatorPropsType = {\n 'data-key': key,\n 'aria-label': `Go to slide ${key + 1}`,\n onClick: navigate,\n };\n const isCurrentPageActive =\n Math.floor((currentIndex + slidesToScroll - 1) / slidesToScroll) === key;\n if (typeof indicators === 'function') {\n return showCustomIndicator(\n isCurrentPageActive,\n key,\n indicatorProps,\n indicators(key)\n );\n }\n return showDefaultIndicator(isCurrentPageActive, key, indicatorProps);\n })}\n </ul>\n );\n};\n","export const defaultProps = {\n duration: 5000,\n transitionDuration: 1000,\n defaultIndex: 0,\n infinite: true,\n autoplay: true,\n indicators: false,\n arrows: true,\n pauseOnHover: true,\n easing: 'linear',\n canSwipe: true,\n cssClass: '',\n responsive: [],\n};\n","import React, {\n useState,\n useRef,\n useEffect,\n useMemo,\n useImperativeHandle,\n useCallback,\n} from 'react';\nimport ResizeObserver from 'resize-observer-polyfill';\nimport TWEEN from '@tweenjs/tween.js';\nimport {\n getEasing,\n getStartingIndex,\n showIndicators,\n showNextArrow,\n showPreviousArrow,\n} from './helpers';\nimport { ButtonClick, SlideshowRef, ZoomProps } from './types';\nimport { defaultProps } from './props';\n\nexport const FadeZoom = React.forwardRef<SlideshowRef, ZoomProps>((props, ref) => {\n const [index, setIndex] = useState<number>(\n getStartingIndex(props.children, props.defaultIndex)\n );\n const wrapperRef = useRef<HTMLDivElement>(null);\n const innerWrapperRef = useRef<any>(null);\n const tweenGroup = useRef(new TWEEN.Group());\n const timeout = useRef<NodeJS.Timeout>();\n const resizeObserver = useRef<any>();\n const childrenCount = useMemo(() => React.Children.count(props.children), [props.children]);\n\n const applyStyle = useCallback(() => {\n if (innerWrapperRef.current && wrapperRef.current) {\n const wrapperWidth = wrapperRef.current.clientWidth;\n const fullwidth = wrapperWidth * childrenCount;\n innerWrapperRef.current.style.width = `${fullwidth}px`;\n for (let index = 0; index < innerWrapperRef.current.children.length; index++) {\n const eachDiv = innerWrapperRef.current.children[index];\n if (eachDiv) {\n eachDiv.style.width = `${wrapperWidth}px`;\n eachDiv.style.left = `${index * -wrapperWidth}px`;\n eachDiv.style.display = `block`;\n }\n }\n }\n }, [wrapperRef, innerWrapperRef, childrenCount]);\n\n const initResizeObserver = useCallback(() => {\n if (wrapperRef.current) {\n resizeObserver.current = new ResizeObserver((entries) => {\n if (!entries) return;\n applyStyle();\n });\n resizeObserver.current.observe(wrapperRef.current);\n }\n }, [wrapperRef, applyStyle]);\n\n const play = useCallback(() => {\n const { autoplay, children, duration, infinite } = props;\n if (\n autoplay &&\n React.Children.count(children) > 1 &&\n (infinite || index < React.Children.count(children) - 1)\n ) {\n timeout.current = setTimeout(moveNext, duration);\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [props, index]);\n\n useEffect(() => {\n initResizeObserver();\n return () => {\n tweenGroup.current.removeAll();\n clearTimeout(timeout.current);\n removeResizeObserver();\n };\n }, [initResizeObserver, tweenGroup]);\n\n useEffect(() => {\n clearTimeout(timeout.current);\n play();\n }, [index, props.autoplay, play]);\n\n useEffect(() => {\n applyStyle();\n }, [childrenCount, applyStyle]);\n\n useImperativeHandle(ref, () => ({\n goNext: () => {\n moveNext();\n },\n goBack: () => {\n moveBack();\n },\n goTo: (index: number) => {\n moveTo(index);\n },\n }));\n\n const removeResizeObserver = () => {\n if (resizeObserver.current && wrapperRef.current) {\n resizeObserver.current.unobserve(wrapperRef.current);\n }\n };\n\n const pauseSlides = () => {\n if (props.pauseOnHover) {\n clearTimeout(timeout.current);\n }\n };\n\n const startSlides = () => {\n const { pauseOnHover, autoplay, duration } = props;\n if (pauseOnHover && autoplay) {\n timeout.current = setTimeout(() => moveNext(), duration);\n }\n };\n\n const moveNext = () => {\n const { children, infinite } = props;\n if (!infinite && index === React.Children.count(children) - 1) {\n return;\n }\n transitionSlide((index + 1) % React.Children.count(children));\n };\n\n const moveBack = () => {\n const { children, infinite } = props;\n if (!infinite && index === 0) {\n return;\n }\n transitionSlide(index === 0 ? React.Children.count(children) - 1 : index - 1);\n };\n\n const preTransition: ButtonClick = (event) => {\n const { currentTarget } = event;\n if (currentTarget.dataset.type === 'prev') {\n moveBack();\n } else {\n moveNext();\n }\n };\n\n const transitionSlide = (newIndex: number) => {\n const existingTweens = tweenGroup.current.getAll();\n if (!existingTweens.length) {\n if (!innerWrapperRef.current?.children[newIndex]) {\n newIndex = 0;\n }\n clearTimeout(timeout.current);\n const value = { opacity: 0, scale: 1 };\n\n const animate = () => {\n requestAnimationFrame(animate);\n tweenGroup.current.update();\n };\n\n animate();\n\n const tween = new TWEEN.Tween(value, tweenGroup.current)\n .to({ opacity: 1, scale: props.scale }, props.transitionDuration)\n .onUpdate((value) => {\n if (!innerWrapperRef.current) {\n return;\n }\n innerWrapperRef.current.children[newIndex].style.opacity = value.opacity;\n innerWrapperRef.current.children[index].style.opacity = 1 - value.opacity;\n innerWrapperRef.current.children[\n index\n ].style.transform = `scale(${value.scale})`;\n })\n .start();\n tween.easing(getEasing(props.easing));\n tween.onComplete(() => {\n if (innerWrapperRef.current) {\n setIndex(newIndex);\n innerWrapperRef.current.children[index].style.transform = `scale(1)`;\n }\n if (typeof props.onChange === 'function') {\n props.onChange(index, newIndex);\n }\n });\n }\n };\n\n const moveTo = (index: number) => {\n transitionSlide(index);\n };\n\n const navigate: ButtonClick = (event) => {\n const { currentTarget } = event;\n if (!currentTarget.dataset.key) {\n return;\n }\n if (parseInt(currentTarget.dataset.key) !== index) {\n moveTo(parseInt(currentTarget.dataset.key));\n }\n };\n\n return (\n <div dir=\"ltr\" aria-roledescription=\"carousel\">\n <div\n className={`react-slideshow-container ${props.cssClass || ''}`}\n onMouseEnter={pauseSlides}\n onMouseOver={pauseSlides}\n onMouseLeave={startSlides}\n ref={props.ref}\n >\n {props.arrows && showPreviousArrow(props, index, preTransition)}\n <div\n className={`react-slideshow-fadezoom-wrapper ${props.cssClass}`}\n ref={wrapperRef}\n >\n <div className=\"react-slideshow-fadezoom-images-wrap\" ref={innerWrapperRef}>\n {(React.Children.map(props.children, (thisArg) => thisArg) || []).map(\n (each, key) => (\n <div\n style={{\n opacity: key === index ? '1' : '0',\n zIndex: key === index ? '1' : '0',\n }}\n data-index={key}\n key={key}\n aria-roledescription=\"slide\"\n aria-hidden={key === index ? 'false' : 'true'}\n >\n {each}\n </div>\n )\n )}\n </div>\n </div>\n {props.arrows && showNextArrow(props, index, preTransition)}\n </div>\n {props.indicators && showIndicators(props, index, navigate)}\n </div>\n );\n});\n\nFadeZoom.defaultProps = defaultProps;\n","import React from 'react';\nimport { FadeZoom } from './fadezoom';\nimport { defaultProps } from './props';\nimport { FadeProps, SlideshowRef } from './types';\n\nexport const Fade = React.forwardRef<SlideshowRef, FadeProps>((props, ref) => {\n return <FadeZoom {...props} scale={1} ref={ref} />;\n});\n\nFade.defaultProps = defaultProps;\n","import React from 'react';\nimport { FadeZoom } from './fadezoom';\nimport { defaultProps } from './props';\nimport { SlideshowRef, ZoomProps } from './types';\n\nexport const Zoom = React.forwardRef<SlideshowRef, ZoomProps>((props, ref) => {\n return <FadeZoom {...props} ref={ref} />;\n});\n\nZoom.defaultProps = defaultProps;\n","import React, {\n useState,\n useRef,\n useEffect,\n useMemo,\n useImperativeHandle,\n useCallback,\n} from 'react';\nimport ResizeObserver from 'resize-observer-polyfill';\nimport TWEEN from '@tweenjs/tween.js';\nimport {\n getEasing,\n getResponsiveSettings,\n getStartingIndex,\n showIndicators,\n showNextArrow,\n showPreviousArrow,\n} from './helpers';\nimport { ButtonClick, SlideshowRef, SlideProps } from './types';\nimport { defaultProps } from './props';\n\nexport const Slide = React.forwardRef<SlideshowRef, SlideProps>((props, ref) => {\n const [index, setIndex] = useState(getStartingIndex(props.children, props.defaultIndex));\n const [wrapperWidth, setWrapperWidth] = useState<number>(0);\n const wrapperRef = useRef<HTMLDivElement>(null);\n const innerWrapperRef = useRef<any>(null);\n const tweenGroup = useRef(new TWEEN.Group());\n const responsiveSettings = useMemo(\n () => getResponsiveSettings(wrapperWidth, props.responsive),\n [wrapperWidth, props.responsive]\n );\n const slidesToScroll = useMemo(() => {\n if (responsiveSettings) {\n return responsiveSettings.settings.slidesToScroll;\n }\n return props.slidesToScroll || 1;\n }, [responsiveSettings, props.slidesToScroll]);\n const slidesToShow = useMemo(() => {\n if (responsiveSettings) {\n return responsiveSettings.settings.slidesToShow;\n }\n return props.slidesToShow || 1;\n }, [responsiveSettings, props.slidesToShow]);\n const childrenCount = useMemo(() => React.Children.count(props.children), [props.children]);\n const eachChildWidth = useMemo(() => wrapperWidth / slidesToShow, [wrapperWidth, slidesToShow]);\n const timeout = useRef<NodeJS.Timeout>();\n const resizeObserver = useRef<any>();\n let startingClientX: number;\n let dragging: boolean = false;\n let distanceSwiped: number = 0;\n\n const applyStyle = useCallback(() => {\n if (innerWrapperRef.current) {\n const fullwidth = wrapperWidth * innerWrapperRef.current.children.length;\n innerWrapperRef.current.style.width = `${fullwidth}px`;\n for (let index = 0; index < innerWrapperRef.current.children.length; index++) {\n const eachDiv = innerWrapperRef.current.children[index];\n if (eachDiv) {\n eachDiv.style.width = `${eachChildWidth}px`;\n eachDiv.style.display = `block`;\n }\n }\n }\n }, [wrapperWidth, eachChildWidth]);\n\n const initResizeObserver = useCallback(() => {\n if (wrapperRef.current) {\n resizeObserver.current = new ResizeObserver((entries) => {\n if (!entries) return;\n setWidth();\n });\n resizeObserver.current.observe(wrapperRef.current);\n }\n }, [wrapperRef]);\n\n const play = useCallback(() => {\n const { autoplay, infinite, duration } = props;\n if (autoplay && (infinite || index < childrenCount - 1)) {\n timeout.current = setTimeout(moveNext, duration);\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [props, childrenCount, index]);\n\n useEffect(() => {\n applyStyle();\n }, [wrapperWidth, applyStyle]);\n\n useEffect(() => {\n initResizeObserver();\n return () => {\n tweenGroup.current.removeAll();\n clearTimeout(timeout.current);\n removeResizeObserver();\n };\n }, [wrapperRef, initResizeObserver, tweenGroup]);\n\n useEffect(() => {\n clearTimeout(timeout.current);\n play();\n }, [index, wrapperWidth, props.autoplay, play]);\n\n useImperativeHandle(ref, () => ({\n goNext: () => {\n moveNext();\n },\n goBack: () => {\n moveBack();\n },\n goTo: (index: number) => {\n moveTo(index);\n },\n }));\n\n const removeResizeObserver = () => {\n if (resizeObserver && wrapperRef.current) {\n resizeObserver.current.unobserve(wrapperRef.current);\n }\n };\n\n const pauseSlides = () => {\n if (props.pauseOnHover) {\n clearTimeout(timeout.current);\n }\n };\n\n const swipe = (event: React.MouseEvent | React.TouchEvent) => {\n if (props.canSwipe && dragging) {\n let clientX;\n if (window.TouchEvent && event.nativeEvent instanceof TouchEvent) {\n clientX = event.nativeEvent.touches[0].pageX;\n } else if (event.nativeEvent instanceof MouseEvent) {\n clientX = event.nativeEvent.clientX;\n }\n if (clientX && startingClientX) {\n let translateValue = eachChildWidth * (index + getOffset());\n const distance = clientX - startingClientX;\n if (!props.infinite && index === childrenCount - slidesToScroll && distance < 0) {\n // if it is the last and infinite is false and you're swiping left\n // then nothing happens\n return;\n }\n if (!props.infinite && index === 0 && distance > 0) {\n // if it is the first and infinite is false and you're swiping right\n // then nothing happens\n return;\n }\n distanceSwiped = distance;\n translateValue -= distanceSwiped;\n innerWrapperRef.current.style.transform = `translate(-${translateValue}px)`;\n }\n }\n };\n\n const moveNext = () => {\n if (!props.infinite && index === childrenCount - slidesToScroll) {\n return;\n }\n const nextIndex = calculateIndex(index + slidesToScroll);\n transitionSlide(nextIndex);\n };\n\n const moveBack = () => {\n if (!props.infinite && index === 0) {\n return;\n }\n let previousIndex = index - slidesToScroll;\n if (previousIndex % slidesToScroll) {\n previousIndex = Math.ceil(previousIndex / slidesToScroll) * slidesToScroll;\n }\n transitionSlide(previousIndex);\n };\n\n const goToSlide: ButtonClick = ({ currentTarget }) => {\n if (!currentTarget.dataset.key) {\n return;\n }\n const datasetKey = parseInt(currentTarget.dataset.key);\n moveTo(datasetKey * slidesToScroll);\n };\n\n const moveTo = (index: number) => {\n transitionSlide(calculateIndex(index));\n };\n\n const calculateIndex = (nextIndex: number): number => {\n if (nextIndex < childrenCount && nextIndex + slidesToScroll > childrenCount) {\n if ((childrenCount - slidesToScroll) % slidesToScroll) {\n return childrenCount - slidesToScroll;\n }\n return nextIndex;\n }\n return nextIndex;\n };\n\n const startSlides = () => {\n if (dragging) {\n endSwipe();\n } else if (props.pauseOnHover && props.autoplay) {\n timeout.current = setTimeout(moveNext, props.duration);\n }\n };\n\n const moveSlides: ButtonClick = ({ currentTarget: { dataset } }) => {\n if (dataset.type === 'next') {\n moveNext();\n } else {\n moveBack();\n }\n };\n\n const renderPreceedingSlides = () => {\n return React.Children.toArray(props.children)\n .slice(-slidesToShow)\n .map((each, index) => (\n <div\n data-index={index - slidesToShow}\n aria-roledescription=\"slide\"\n aria-hidden=\"true\"\n key={index - slidesToShow}\n >\n {each}\n </div>\n ));\n };\n\n const renderTrailingSlides = () => {\n if (!props.infinite && slidesToShow === slidesToScroll) {\n return;\n }\n return React.Children.toArray(props.children)\n .slice(0, slidesToShow)\n .map((each, index) => (\n <div\n data-index={childrenCount + index}\n aria-roledescription=\"slide\"\n aria-hidden=\"true\"\n key={childrenCount + index}\n >\n {each}\n </div>\n ));\n };\n\n const setWidth = () => {\n if (wrapperRef.current) {\n setWrapperWidth(wrapperRef.current.clientWidth);\n }\n };\n\n const startSwipe = (event: React.MouseEvent | React.TouchEvent) => {\n if (props.canSwipe) {\n if (window.TouchEvent && event.nativeEvent instanceof TouchEvent) {\n startingClientX = event.nativeEvent.touches[0].pageX;\n } else if (event.nativeEvent instanceof MouseEvent) {\n startingClientX = event.nativeEvent.clientX;\n }\n clearTimeout(timeout.current);\n dragging = true;\n }\n };\n\n const endSwipe = () => {\n if (props.canSwipe) {\n dragging = false;\n if (Math.abs(distanceSwiped) / wrapperWidth > 0.2) {\n if (distanceSwiped < 0) {\n moveNext();\n } else {\n moveBack();\n }\n } else {\n if (Math.abs(distanceSwiped) > 0) {\n transitionSlide(index, 300);\n }\n }\n }\n };\n\n const transitionSlide = (toIndex: number, animationDuration?: number) => {\n const transitionDuration = animationDuration || props.transitionDuration;\n const currentIndex = index;\n const existingTweens = tweenGroup.current.getAll();\n if (!wrapperRef.current) {\n return;\n }\n const childWidth = wrapperRef.current.clientWidth / slidesToShow;\n if (!existingTweens.length) {\n clearTimeout(timeout.current);\n const value = {\n margin: -childWidth * (currentIndex + getOffset()) + distanceSwiped,\n };\n const tween = new TWEEN.Tween(value, tweenGroup.current)\n .to({ margin: -childWidth * (toIndex + getOffset()) }, transitionDuration)\n .onUpdate((value) => {\n if (innerWrapperRef.current) {\n innerWrapperRef.current.style.transform = `translate(${value.margin}px)`;\n }\n })\n .start();\n tween.easing(getEasing(props.easing));\n const animate = () => {\n requestAnimationFrame(animate);\n tweenGroup.current.update();\n };\n\n animate();\n\n tween.onComplete(() => {\n distanceSwiped = 0;\n let newIndex = toIndex;\n if (newIndex < 0) {\n newIndex = childrenCount - slidesToScroll;\n } else if (newIndex >= childrenCount) {\n newIndex = 0;\n }\n\n if (typeof props.onChange === 'function') {\n props.onChange(index, newIndex);\n }\n setIndex(newIndex);\n });\n }\n };\n\n const isSlideActive = (key: number) => {\n return key < index + slidesToShow && key >= index;\n };\n\n const getOffset = (): number => {\n if (!props.infinite) {\n return 0;\n }\n return slidesToShow;\n };\n\n const style = {\n transform: `translate(-${(index + getOffset()) * eachChildWidth}px)`,\n };\n return (\n <div dir=\"ltr\" aria-roledescription=\"carousel\">\n <div\n className=\"react-slideshow-container\"\n onMouseEnter={pauseSlides}\n onMouseOver={pauseSlides}\n onMouseLeave={startSlides}\n onMouseDown={startSwipe}\n onMouseUp={endSwipe}\n onMouseMove={swipe}\n onTouchStart={startSwipe}\n onTouchEnd={endSwipe}\n onTouchCancel={endSwipe}\n onTouchMove={swipe}\n >\n {props.arrows && showPreviousArrow(props, index, moveSlides)}\n <div\n className={`react-slideshow-wrapper slide ${props.cssClass || ''}`}\n ref={wrapperRef}\n >\n <div className=\"images-wrap\" style={style} ref={innerWrapperRef}>\n {props.infinite && renderPreceedingSlides()}\n {(React.Children.map(props.children, (thisArg) => thisArg) || []).map(\n (each, key) => {\n const isThisSlideActive = isSlideActive(key);\n return (\n <div\n data-index={key}\n key={key}\n className={isThisSlideActive ? 'active' : ''}\n aria-roledescription=\"slide\"\n aria-hidden={isThisSlideActive ? 'false' : 'true'}\n >\n {each}\n </div>\n );\n }\n )}\n {renderTrailingSlides()}\n </div>\n </div>\n {props.arrows && showNextArrow(props, index, moveSlides)}\n </div>\n {props.indicators && showIndicators(props, index, goToSlide, responsiveSettings)}\n </div>\n );\n});\n\nSlide.defaultProps = defaultProps;\n"],"names":["getStartingIndex","children","defaultIndex","React","Children","count","EASING_METHODS","linear","TWEEN","Easing","Linear","None","ease","Quadratic","InOut","ease-in","In","ease-out","Out","cubic","Cubic","cubic-in","cubic-out","getEasing","easeMethod","showPreviousArrow","currentIndex","moveSlides","prevArrow","isDisabled","infinite","props","data-type","aria-label","disabled","onClick","cloneElement","className","type","width","height","viewBox","d","showNextArrow","properties","nextArrow","slidesToScroll","showIndicators","navigate","responsiveSettings","indicators","settings","pages","Math","ceil","Array","from","length","_","key","indicatorProps","data-key","isCurrentPageActive","floor","eachIndicator","showCustomIndicator","showDefaultIndicator","defaultProps","duration","transitionDuration","autoplay","arrows","pauseOnHover","easing","canSwipe","cssClass","responsive","FadeZoom","forwardRef","ref","useState","index","setIndex","wrapperRef","useRef","innerWrapperRef","tweenGroup","Group","timeout","resizeObserver","childrenCount","useMemo","applyStyle","useCallback","current","wrapperWidth","clientWidth","style","eachDiv","left","display","initResizeObserver","ResizeObserver","entries","observe","play","setTimeout","moveNext","useEffect","removeAll","clearTimeout","removeResizeObserver","useImperativeHandle","goNext","goBack","moveBack","goTo","moveTo","unobserve","pauseSlides","transitionSlide","preTransition","event","currentTarget","dataset","newIndex","getAll","_innerWrapperRef$curr","animate","requestAnimationFrame","update","tween","Tween","opacity","scale","to","onUpdate","value","transform","start","onComplete","onChange","dir","onMouseEnter","onMouseOver","onMouseLeave","map","thisArg","each","zIndex","parseInt","Fade","Zoom","Slide","startingClientX","setWrapperWidth","window","isArray","find","breakpoint","getResponsiveSettings","slidesToShow","eachChildWidth","dragging","distanceSwiped","setWidth","swipe","clientX","TouchEvent","nativeEvent","touches","pageX","MouseEvent","translateValue","getOffset","distance","nextIndex","calculateIndex","previousIndex","startSwipe","endSwipe","abs","toIndex","animationDuration","existingTweens","childWidth","margin","onMouseDown","onMouseUp","onMouseMove","onTouchStart","onTouchEnd","onTouchCancel","onTouchMove","toArray","slice","isThisSlideActive","isSlideActive","renderTrailingSlides","datasetKey"],"mappings":"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"}
@@ -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,
@@ -61,6 +70,7 @@ var showPreviousArrow = function showPreviousArrow(_ref, currentIndex, moveSlide
61
70
 
62
71
  var className = "nav default-nav " + (isDisabled ? 'disabled' : '');
63
72
  return /*#__PURE__*/React.createElement("button", Object.assign({
73
+ type: "button",
64
74
  className: className
65
75
  }, props), /*#__PURE__*/React.createElement("svg", {
66
76
  width: "24",
@@ -96,6 +106,7 @@ var showNextArrow = function showNextArrow(properties, currentIndex, moveSlides)
96
106
 
97
107
  var className = "nav default-nav " + (isDisabled ? 'disabled' : '');
98
108
  return /*#__PURE__*/React.createElement("button", Object.assign({
109
+ type: "button",
99
110
  className: className
100
111
  }, props), /*#__PURE__*/React.createElement("svg", {
101
112
  width: "24",
@@ -110,6 +121,7 @@ var showDefaultIndicator = function showDefaultIndicator(isCurrentPageActive, ke
110
121
  return /*#__PURE__*/React.createElement("li", {
111
122
  key: key
112
123
  }, /*#__PURE__*/React.createElement("button", Object.assign({
124
+ type: "button",
113
125
  className: "each-slideshow-indicator " + (isCurrentPageActive ? 'active' : '')
114
126
  }, indicatorProps)));
115
127
  };
@@ -121,12 +133,14 @@ var showCustomIndicator = function showCustomIndicator(isCurrentPageActive, key,
121
133
  }, indicatorProps));
122
134
  };
123
135
 
124
- var showIndicators = function showIndicators(props, currentIndex, navigate) {
136
+ var showIndicators = function showIndicators(props, currentIndex, navigate, responsiveSettings) {
125
137
  var children = props.children,
126
138
  indicators = props.indicators;
127
139
  var slidesToScroll = 1;
128
140
 
129
- if ('slidesToScroll' in props) {
141
+ if (responsiveSettings) {
142
+ slidesToScroll = responsiveSettings == null ? void 0 : responsiveSettings.settings.slidesToScroll;
143
+ } else if ('slidesToScroll' in props) {
130
144
  slidesToScroll = props.slidesToScroll || 1;
131
145
  }
132
146
 
@@ -173,7 +187,7 @@ var FadeZoom = /*#__PURE__*/React.forwardRef(function (props, ref) {
173
187
 
174
188
  var wrapperRef = useRef(null);
175
189
  var innerWrapperRef = useRef(null);
176
- var tweenGroup = new TWEEN.Group();
190
+ var tweenGroup = useRef(new TWEEN.Group());
177
191
  var timeout = useRef();
178
192
  var resizeObserver = useRef();
179
193
  var childrenCount = useMemo(function () {
@@ -219,7 +233,7 @@ var FadeZoom = /*#__PURE__*/React.forwardRef(function (props, ref) {
219
233
  useEffect(function () {
220
234
  initResizeObserver();
221
235
  return function () {
222
- tweenGroup.removeAll();
236
+ tweenGroup.current.removeAll();
223
237
  clearTimeout(timeout.current);
224
238
  removeResizeObserver();
225
239
  };
@@ -302,7 +316,7 @@ var FadeZoom = /*#__PURE__*/React.forwardRef(function (props, ref) {
302
316
  };
303
317
 
304
318
  var transitionSlide = function transitionSlide(newIndex) {
305
- var existingTweens = tweenGroup.getAll();
319
+ var existingTweens = tweenGroup.current.getAll();
306
320
 
307
321
  if (!existingTweens.length) {
308
322
  var _innerWrapperRef$curr;
@@ -319,11 +333,11 @@ var FadeZoom = /*#__PURE__*/React.forwardRef(function (props, ref) {
319
333
 
320
334
  var animate = function animate() {
321
335
  requestAnimationFrame(animate);
322
- tweenGroup.update();
336
+ tweenGroup.current.update();
323
337
  };
324
338
 
325
339
  animate();
326
- var tween = new TWEEN.Tween(value, tweenGroup).to({
340
+ var tween = new TWEEN.Tween(value, tweenGroup.current).to({
327
341
  opacity: 1,
328
342
  scale: props.scale
329
343
  }, props.transitionDuration).onUpdate(function (value) {
@@ -423,13 +437,24 @@ var Slide = /*#__PURE__*/React.forwardRef(function (props, ref) {
423
437
 
424
438
  var wrapperRef = useRef(null);
425
439
  var innerWrapperRef = useRef(null);
426
- var tweenGroup = new TWEEN.Group();
440
+ var tweenGroup = useRef(new TWEEN.Group());
441
+ var responsiveSettings = useMemo(function () {
442
+ return getResponsiveSettings(wrapperWidth, props.responsive);
443
+ }, [wrapperWidth, props.responsive]);
427
444
  var slidesToScroll = useMemo(function () {
445
+ if (responsiveSettings) {
446
+ return responsiveSettings.settings.slidesToScroll;
447
+ }
448
+
428
449
  return props.slidesToScroll || 1;
429
- }, [props.slidesToScroll]);
450
+ }, [responsiveSettings, props.slidesToScroll]);
430
451
  var slidesToShow = useMemo(function () {
452
+ if (responsiveSettings) {
453
+ return responsiveSettings.settings.slidesToShow;
454
+ }
455
+
431
456
  return props.slidesToShow || 1;
432
- }, [props.slidesToShow]);
457
+ }, [responsiveSettings, props.slidesToShow]);
433
458
  var childrenCount = useMemo(function () {
434
459
  return React.Children.count(props.children);
435
460
  }, [props.children]);
@@ -481,7 +506,7 @@ var Slide = /*#__PURE__*/React.forwardRef(function (props, ref) {
481
506
  useEffect(function () {
482
507
  initResizeObserver();
483
508
  return function () {
484
- tweenGroup.removeAll();
509
+ tweenGroup.current.removeAll();
485
510
  clearTimeout(timeout.current);
486
511
  removeResizeObserver();
487
512
  };
@@ -517,10 +542,16 @@ var Slide = /*#__PURE__*/React.forwardRef(function (props, ref) {
517
542
  };
518
543
 
519
544
  var swipe = function swipe(event) {
520
- if (props.canSwipe) {
521
- var clientX = event.nativeEvent instanceof TouchEvent ? event.nativeEvent.touches[0].pageX : event.nativeEvent.clientX;
545
+ if (props.canSwipe && dragging) {
546
+ var clientX;
547
+
548
+ if (window.TouchEvent && event.nativeEvent instanceof TouchEvent) {
549
+ clientX = event.nativeEvent.touches[0].pageX;
550
+ } else if (event.nativeEvent instanceof MouseEvent) {
551
+ clientX = event.nativeEvent.clientX;
552
+ }
522
553
 
523
- if (dragging) {
554
+ if (clientX && startingClientX) {
524
555
  var translateValue = eachChildWidth * (index + getOffset());
525
556
  var distance = clientX - startingClientX;
526
557
 
@@ -645,7 +676,12 @@ var Slide = /*#__PURE__*/React.forwardRef(function (props, ref) {
645
676
 
646
677
  var startSwipe = function startSwipe(event) {
647
678
  if (props.canSwipe) {
648
- startingClientX = event.nativeEvent instanceof TouchEvent ? event.nativeEvent.touches[0].pageX : event.nativeEvent.clientX;
679
+ if (window.TouchEvent && event.nativeEvent instanceof TouchEvent) {
680
+ startingClientX = event.nativeEvent.touches[0].pageX;
681
+ } else if (event.nativeEvent instanceof MouseEvent) {
682
+ startingClientX = event.nativeEvent.clientX;
683
+ }
684
+
649
685
  clearTimeout(timeout.current);
650
686
  dragging = true;
651
687
  }
@@ -672,7 +708,7 @@ var Slide = /*#__PURE__*/React.forwardRef(function (props, ref) {
672
708
  var transitionSlide = function transitionSlide(toIndex, animationDuration) {
673
709
  var transitionDuration = animationDuration || props.transitionDuration;
674
710
  var currentIndex = index;
675
- var existingTweens = tweenGroup.getAll();
711
+ var existingTweens = tweenGroup.current.getAll();
676
712
 
677
713
  if (!wrapperRef.current) {
678
714
  return;
@@ -685,7 +721,7 @@ var Slide = /*#__PURE__*/React.forwardRef(function (props, ref) {
685
721
  var value = {
686
722
  margin: -childWidth * (currentIndex + getOffset()) + distanceSwiped
687
723
  };
688
- var tween = new TWEEN.Tween(value, tweenGroup).to({
724
+ var tween = new TWEEN.Tween(value, tweenGroup.current).to({
689
725
  margin: -childWidth * (toIndex + getOffset())
690
726
  }, transitionDuration).onUpdate(function (value) {
691
727
  if (innerWrapperRef.current) {
@@ -696,7 +732,7 @@ var Slide = /*#__PURE__*/React.forwardRef(function (props, ref) {
696
732
 
697
733
  var animate = function animate() {
698
734
  requestAnimationFrame(animate);
699
- tweenGroup.update();
735
+ tweenGroup.current.update();
700
736
  };
701
737
 
702
738
  animate();
@@ -767,7 +803,7 @@ var Slide = /*#__PURE__*/React.forwardRef(function (props, ref) {
767
803
  "aria-roledescription": "slide",
768
804
  "aria-hidden": isThisSlideActive ? 'false' : 'true'
769
805
  }, each);
770
- }), renderTrailingSlides())), props.arrows && showNextArrow(props, index, moveSlides)), props.indicators && showIndicators(props, index, goToSlide));
806
+ }), renderTrailingSlides())), props.arrows && showNextArrow(props, index, moveSlides)), props.indicators && showIndicators(props, index, goToSlide, responsiveSettings));
771
807
  });
772
808
  Slide.defaultProps = defaultProps;
773
809
 
@@ -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 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 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 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","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","type","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 = (index: number) => {\n transitionSlide(index);\n };\n\n const navigate: ButtonClick = (event) => {\n const { currentTarget } = event;\n if (!currentTarget.dataset.key) {\n return;\n }\n if (parseInt(currentTarget.dataset.key) !== index) {\n moveTo(parseInt(currentTarget.dataset.key));\n }\n };\n\n return (\n <div dir=\"ltr\" aria-roledescription=\"carousel\">\n <div\n className={`react-slideshow-container ${props.cssClass || ''}`}\n onMouseEnter={pauseSlides}\n onMouseOver={pauseSlides}\n onMouseLeave={startSlides}\n ref={props.ref}\n >\n {props.arrows && showPreviousArrow(props, index, preTransition)}\n <div\n className={`react-slideshow-fadezoom-wrapper ${props.cssClass}`}\n ref={wrapperRef}\n >\n <div className=\"react-slideshow-fadezoom-images-wrap\" ref={innerWrapperRef}>\n {(React.Children.map(props.children, (thisArg) => thisArg) || []).map(\n (each, key) => (\n <div\n style={{\n opacity: key === index ? '1' : '0',\n zIndex: key === index ? '1' : '0',\n }}\n data-index={key}\n key={key}\n aria-roledescription=\"slide\"\n aria-hidden={key === index ? 'false' : 'true'}\n >\n {each}\n </div>\n )\n )}\n </div>\n </div>\n {props.arrows && showNextArrow(props, index, preTransition)}\n </div>\n {props.indicators && showIndicators(props, index, navigate)}\n </div>\n );\n});\n\nFadeZoom.defaultProps = defaultProps;\n","import React from 'react';\nimport { FadeZoom } from './fadezoom';\nimport { defaultProps } from './props';\nimport { FadeProps, SlideshowRef } from './types';\n\nexport const Fade = React.forwardRef<SlideshowRef, FadeProps>((props, ref) => {\n return <FadeZoom {...props} scale={1} ref={ref} />;\n});\n\nFade.defaultProps = defaultProps;\n","import React from 'react';\nimport { FadeZoom } from './fadezoom';\nimport { defaultProps } from './props';\nimport { SlideshowRef, ZoomProps } from './types';\n\nexport const Zoom = React.forwardRef<SlideshowRef, ZoomProps>((props, ref) => {\n return <FadeZoom {...props} ref={ref} />;\n});\n\nZoom.defaultProps = defaultProps;\n","import React, {\n useState,\n useRef,\n useEffect,\n useMemo,\n useImperativeHandle,\n useCallback,\n} from 'react';\nimport ResizeObserver from 'resize-observer-polyfill';\nimport TWEEN from '@tweenjs/tween.js';\nimport {\n getEasing,\n getResponsiveSettings,\n getStartingIndex,\n showIndicators,\n showNextArrow,\n showPreviousArrow,\n} from './helpers';\nimport { ButtonClick, SlideshowRef, SlideProps } from './types';\nimport { defaultProps } from './props';\n\nexport const Slide = React.forwardRef<SlideshowRef, SlideProps>((props, ref) => {\n const [index, setIndex] = useState(getStartingIndex(props.children, props.defaultIndex));\n const [wrapperWidth, setWrapperWidth] = useState<number>(0);\n const wrapperRef = useRef<HTMLDivElement>(null);\n const innerWrapperRef = useRef<any>(null);\n const tweenGroup = useRef(new TWEEN.Group());\n const responsiveSettings = useMemo(\n () => getResponsiveSettings(wrapperWidth, props.responsive),\n [wrapperWidth, props.responsive]\n );\n const slidesToScroll = useMemo(() => {\n if (responsiveSettings) {\n return responsiveSettings.settings.slidesToScroll;\n }\n return props.slidesToScroll || 1;\n }, [responsiveSettings, props.slidesToScroll]);\n const slidesToShow = useMemo(() => {\n if (responsiveSettings) {\n return responsiveSettings.settings.slidesToShow;\n }\n return props.slidesToShow || 1;\n }, [responsiveSettings, props.slidesToShow]);\n const childrenCount = useMemo(() => React.Children.count(props.children), [props.children]);\n const eachChildWidth = useMemo(() => wrapperWidth / slidesToShow, [wrapperWidth, slidesToShow]);\n const timeout = useRef<NodeJS.Timeout>();\n const resizeObserver = useRef<any>();\n let startingClientX: number;\n let dragging: boolean = false;\n let distanceSwiped: number = 0;\n\n const applyStyle = useCallback(() => {\n if (innerWrapperRef.current) {\n const fullwidth = wrapperWidth * innerWrapperRef.current.children.length;\n innerWrapperRef.current.style.width = `${fullwidth}px`;\n for (let index = 0; index < innerWrapperRef.current.children.length; index++) {\n const eachDiv = innerWrapperRef.current.children[index];\n if (eachDiv) {\n eachDiv.style.width = `${eachChildWidth}px`;\n eachDiv.style.display = `block`;\n }\n }\n }\n }, [wrapperWidth, eachChildWidth]);\n\n const initResizeObserver = useCallback(() => {\n if (wrapperRef.current) {\n resizeObserver.current = new ResizeObserver((entries) => {\n if (!entries) return;\n setWidth();\n });\n resizeObserver.current.observe(wrapperRef.current);\n }\n }, [wrapperRef]);\n\n const play = useCallback(() => {\n const { autoplay, infinite, duration } = props;\n if (autoplay && (infinite || index < childrenCount - 1)) {\n timeout.current = setTimeout(moveNext, duration);\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [props, childrenCount, index]);\n\n useEffect(() => {\n applyStyle();\n }, [wrapperWidth, applyStyle]);\n\n useEffect(() => {\n initResizeObserver();\n return () => {\n tweenGroup.current.removeAll();\n clearTimeout(timeout.current);\n removeResizeObserver();\n };\n }, [wrapperRef, initResizeObserver, tweenGroup]);\n\n useEffect(() => {\n clearTimeout(timeout.current);\n play();\n }, [index, wrapperWidth, props.autoplay, play]);\n\n useImperativeHandle(ref, () => ({\n goNext: () => {\n moveNext();\n },\n goBack: () => {\n moveBack();\n },\n goTo: (index: number) => {\n moveTo(index);\n },\n }));\n\n const removeResizeObserver = () => {\n if (resizeObserver && wrapperRef.current) {\n resizeObserver.current.unobserve(wrapperRef.current);\n }\n };\n\n const pauseSlides = () => {\n if (props.pauseOnHover) {\n clearTimeout(timeout.current);\n }\n };\n\n const swipe = (event: React.MouseEvent | React.TouchEvent) => {\n if (props.canSwipe && dragging) {\n let clientX;\n if (window.TouchEvent && event.nativeEvent instanceof TouchEvent) {\n clientX = event.nativeEvent.touches[0].pageX;\n } else if (event.nativeEvent instanceof MouseEvent) {\n clientX = event.nativeEvent.clientX;\n }\n if (clientX && startingClientX) {\n let translateValue = eachChildWidth * (index + getOffset());\n const distance = clientX - startingClientX;\n if (!props.infinite && index === childrenCount - slidesToScroll && distance < 0) {\n // if it is the last and infinite is false and you're swiping left\n // then nothing happens\n return;\n }\n if (!props.infinite && index === 0 && distance > 0) {\n // if it is the first and infinite is false and you're swiping right\n // then nothing happens\n return;\n }\n distanceSwiped = distance;\n translateValue -= distanceSwiped;\n innerWrapperRef.current.style.transform = `translate(-${translateValue}px)`;\n }\n }\n };\n\n const moveNext = () => {\n if (!props.infinite && index === childrenCount - slidesToScroll) {\n return;\n }\n const nextIndex = calculateIndex(index + slidesToScroll);\n transitionSlide(nextIndex);\n };\n\n const moveBack = () => {\n if (!props.infinite && index === 0) {\n return;\n }\n let previousIndex = index - slidesToScroll;\n if (previousIndex % slidesToScroll) {\n previousIndex = Math.ceil(previousIndex / slidesToScroll) * slidesToScroll;\n }\n transitionSlide(previousIndex);\n };\n\n const goToSlide: ButtonClick = ({ currentTarget }) => {\n if (!currentTarget.dataset.key) {\n return;\n }\n const datasetKey = parseInt(currentTarget.dataset.key);\n moveTo(datasetKey * slidesToScroll);\n };\n\n const moveTo = (index: number) => {\n transitionSlide(calculateIndex(index));\n };\n\n const calculateIndex = (nextIndex: number): number => {\n if (nextIndex < childrenCount && nextIndex + slidesToScroll > childrenCount) {\n if ((childrenCount - slidesToScroll) % slidesToScroll) {\n return childrenCount - slidesToScroll;\n }\n return nextIndex;\n }\n return nextIndex;\n };\n\n const startSlides = () => {\n if (dragging) {\n endSwipe();\n } else if (props.pauseOnHover && props.autoplay) {\n timeout.current = setTimeout(moveNext, props.duration);\n }\n };\n\n const moveSlides: ButtonClick = ({ currentTarget: { dataset } }) => {\n if (dataset.type === 'next') {\n moveNext();\n } else {\n moveBack();\n }\n };\n\n const renderPreceedingSlides = () => {\n return React.Children.toArray(props.children)\n .slice(-slidesToShow)\n .map((each, index) => (\n <div\n data-index={index - slidesToShow}\n aria-roledescription=\"slide\"\n aria-hidden=\"true\"\n key={index - slidesToShow}\n >\n {each}\n </div>\n ));\n };\n\n const renderTrailingSlides = () => {\n if (!props.infinite && slidesToShow === slidesToScroll) {\n return;\n }\n return React.Children.toArray(props.children)\n .slice(0, slidesToShow)\n .map((each, index) => (\n <div\n data-index={childrenCount + index}\n aria-roledescription=\"slide\"\n aria-hidden=\"true\"\n key={childrenCount + index}\n >\n {each}\n </div>\n ));\n };\n\n const setWidth = () => {\n if (wrapperRef.current) {\n setWrapperWidth(wrapperRef.current.clientWidth);\n }\n };\n\n const startSwipe = (event: React.MouseEvent | React.TouchEvent) => {\n if (props.canSwipe) {\n if (window.TouchEvent && event.nativeEvent instanceof TouchEvent) {\n startingClientX = event.nativeEvent.touches[0].pageX;\n } else if (event.nativeEvent instanceof MouseEvent) {\n startingClientX = event.nativeEvent.clientX;\n }\n clearTimeout(timeout.current);\n dragging = true;\n }\n };\n\n const endSwipe = () => {\n if (props.canSwipe) {\n dragging = false;\n if (Math.abs(distanceSwiped) / wrapperWidth > 0.2) {\n if (distanceSwiped < 0) {\n moveNext();\n } else {\n moveBack();\n }\n } else {\n if (Math.abs(distanceSwiped) > 0) {\n transitionSlide(index, 300);\n }\n }\n }\n };\n\n const transitionSlide = (toIndex: number, animationDuration?: number) => {\n const transitionDuration = animationDuration || props.transitionDuration;\n const currentIndex = index;\n const existingTweens = tweenGroup.current.getAll();\n if (!wrapperRef.current) {\n return;\n }\n const childWidth = wrapperRef.current.clientWidth / slidesToShow;\n if (!existingTweens.length) {\n clearTimeout(timeout.current);\n const value = {\n margin: -childWidth * (currentIndex + getOffset()) + distanceSwiped,\n };\n const tween = new TWEEN.Tween(value, tweenGroup.current)\n .to({ margin: -childWidth * (toIndex + getOffset()) }, transitionDuration)\n .onUpdate((value) => {\n if (innerWrapperRef.current) {\n innerWrapperRef.current.style.transform = `translate(${value.margin}px)`;\n }\n })\n .start();\n tween.easing(getEasing(props.easing));\n const animate = () => {\n requestAnimationFrame(animate);\n tweenGroup.current.update();\n };\n\n animate();\n\n tween.onComplete(() => {\n distanceSwiped = 0;\n let newIndex = toIndex;\n if (newIndex < 0) {\n newIndex = childrenCount - slidesToScroll;\n } else if (newIndex >= childrenCount) {\n newIndex = 0;\n }\n\n if (typeof props.onChange === 'function') {\n props.onChange(index, newIndex);\n }\n setIndex(newIndex);\n });\n }\n };\n\n const isSlideActive = (key: number) => {\n return key < index + slidesToShow && key >= index;\n };\n\n const getOffset = (): number => {\n if (!props.infinite) {\n return 0;\n }\n return slidesToShow;\n };\n\n const style = {\n transform: `translate(-${(index + getOffset()) * eachChildWidth}px)`,\n };\n return (\n <div dir=\"ltr\" aria-roledescription=\"carousel\">\n <div\n className=\"react-slideshow-container\"\n onMouseEnter={pauseSlides}\n onMouseOver={pauseSlides}\n onMouseLeave={startSlides}\n onMouseDown={startSwipe}\n onMouseUp={endSwipe}\n onMouseMove={swipe}\n onTouchStart={startSwipe}\n onTouchEnd={endSwipe}\n onTouchCancel={endSwipe}\n onTouchMove={swipe}\n >\n {props.arrows && showPreviousArrow(props, index, moveSlides)}\n <div\n className={`react-slideshow-wrapper slide ${props.cssClass || ''}`}\n ref={wrapperRef}\n >\n <div className=\"images-wrap\" style={style} ref={innerWrapperRef}>\n {props.infinite && renderPreceedingSlides()}\n {(React.Children.map(props.children, (thisArg) => thisArg) || []).map(\n (each, key) => {\n const isThisSlideActive = isSlideActive(key);\n return (\n <div\n data-index={key}\n key={key}\n className={isThisSlideActive ? 'active' : ''}\n aria-roledescription=\"slide\"\n aria-hidden={isThisSlideActive ? 'false' : 'true'}\n >\n {each}\n </div>\n );\n }\n )}\n {renderTrailingSlides()}\n </div>\n </div>\n {props.arrows && showNextArrow(props, index, moveSlides)}\n </div>\n {props.indicators && showIndicators(props, index, goToSlide, responsiveSettings)}\n </div>\n );\n});\n\nSlide.defaultProps = defaultProps;\n"],"names":["getStartingIndex","children","defaultIndex","React","Children","count","getResponsiveSettings","wrapperWidth","responsive","window","Array","isArray","find","each","breakpoint","EASING_METHODS","linear","TWEEN","Easing","Linear","None","ease","Quadratic","InOut","In","Out","cubic","Cubic","getEasing","easeMethod","showPreviousArrow","currentIndex","moveSlides","prevArrow","infinite","isDisabled","props","disabled","onClick","cloneElement","className","type","width","height","viewBox","d","showNextArrow","properties","nextArrow","slidesToScroll","showDefaultIndicator","isCurrentPageActive","key","indicatorProps","showCustomIndicator","eachIndicator","showIndicators","navigate","responsiveSettings","indicators","settings","pages","Math","ceil","from","length","_","floor","defaultProps","duration","transitionDuration","autoplay","arrows","pauseOnHover","easing","canSwipe","cssClass","FadeZoom","forwardRef","ref","useState","index","setIndex","wrapperRef","useRef","innerWrapperRef","tweenGroup","Group","timeout","resizeObserver","childrenCount","useMemo","applyStyle","useCallback","current","clientWidth","fullwidth","style","eachDiv","left","display","initResizeObserver","ResizeObserver","entries","observe","play","setTimeout","moveNext","useEffect","removeAll","clearTimeout","removeResizeObserver","useImperativeHandle","goNext","goBack","moveBack","goTo","moveTo","unobserve","pauseSlides","startSlides","transitionSlide","preTransition","event","currentTarget","dataset","newIndex","existingTweens","getAll","value","opacity","scale","animate","requestAnimationFrame","update","tween","Tween","to","onUpdate","transform","start","onComplete","onChange","parseInt","dir","onMouseEnter","onMouseOver","onMouseLeave","map","thisArg","zIndex","Fade","Zoom","Slide","setWrapperWidth","slidesToShow","eachChildWidth","startingClientX","dragging","distanceSwiped","setWidth","swipe","clientX","TouchEvent","nativeEvent","touches","pageX","MouseEvent","translateValue","getOffset","distance","nextIndex","calculateIndex","previousIndex","goToSlide","datasetKey","endSwipe","renderPreceedingSlides","toArray","slice","renderTrailingSlides","startSwipe","abs","toIndex","animationDuration","childWidth","margin","isSlideActive","onMouseDown","onMouseUp","onMouseMove","onTouchStart","onTouchEnd","onTouchCancel","onTouchMove","isThisSlideActive"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "react-slideshow-image",
3
- "version": "4.0.1",
3
+ "version": "4.0.4",
4
4
  "description": "An image slideshow with react",
5
5
  "license": "MIT",
6
6
  "main": "dist/index.js",