@cleartrip/ct-design-peek-carousel 1.2.0-SNAPSHOT-testpeekCarousel.0 → 1.2.0-SNAPSHOT-test-peekCarousel.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/PeekCarousel.d.ts +2 -1
- package/dist/PeekCarousel.d.ts.map +1 -1
- package/dist/constants.d.ts +0 -8
- package/dist/constants.d.ts.map +1 -1
- package/dist/ct-design-peek-carousel.browser.cjs.js +1 -1
- package/dist/ct-design-peek-carousel.browser.cjs.js.map +1 -1
- package/dist/ct-design-peek-carousel.browser.esm.js +1 -1
- package/dist/ct-design-peek-carousel.browser.esm.js.map +1 -1
- package/dist/ct-design-peek-carousel.cjs.js +87 -182
- package/dist/ct-design-peek-carousel.cjs.js.map +1 -1
- package/dist/ct-design-peek-carousel.esm.js +87 -183
- package/dist/ct-design-peek-carousel.esm.js.map +1 -1
- package/dist/ct-design-peek-carousel.umd.js +90 -186
- package/dist/ct-design-peek-carousel.umd.js.map +1 -1
- package/dist/index.d.ts +1 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/style.d.ts +0 -1
- package/dist/style.d.ts.map +1 -1
- package/dist/type.d.ts +6 -9
- package/dist/type.d.ts.map +1 -1
- package/package.json +9 -8
package/dist/PeekCarousel.d.ts
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
2
|
import { IPeekCarouselProps, IPeekCarouselRef } from './type';
|
|
3
|
-
|
|
3
|
+
declare const PeekCarousel: React.ForwardRefExoticComponent<IPeekCarouselProps & React.RefAttributes<IPeekCarouselRef>>;
|
|
4
|
+
export default PeekCarousel;
|
|
4
5
|
//# sourceMappingURL=PeekCarousel.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PeekCarousel.d.ts","sourceRoot":"","sources":["../packages/components/PeekCarousel/src/PeekCarousel.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,OAAO,CAAC;
|
|
1
|
+
{"version":3,"file":"PeekCarousel.d.ts","sourceRoot":"","sources":["../packages/components/PeekCarousel/src/PeekCarousel.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,OAAO,CAAC;AAM1B,OAAO,EAAE,kBAAkB,EAAE,gBAAgB,EAAE,MAAM,QAAQ,CAAC;AAI9D,QAAA,MAAM,YAAY,6FAoNhB,CAAC;AAEH,eAAe,YAAY,CAAC"}
|
package/dist/constants.d.ts
CHANGED
|
@@ -1,11 +1,3 @@
|
|
|
1
|
-
export declare const PEEK_CAROUSEL_IDS: {
|
|
2
|
-
ROOT_CONTAINER: string;
|
|
3
|
-
SLIDER_ROOT_CONTAINER: string;
|
|
4
|
-
SLIDER_CARD_CONTAINER: string;
|
|
5
|
-
ICONS_CONTAINER: string;
|
|
6
|
-
LEFT_ICON_CONTAINER: string;
|
|
7
|
-
RIGHT_ICON_CONTAINER: string;
|
|
8
|
-
};
|
|
9
1
|
export declare enum SLIDER_DIRECTION {
|
|
10
2
|
NEXT = "LEFT",
|
|
11
3
|
PREV = "RIGHT"
|
package/dist/constants.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"constants.d.ts","sourceRoot":"","sources":["../packages/components/PeekCarousel/src/constants.ts"],"names":[],"mappings":"AAAA,
|
|
1
|
+
{"version":3,"file":"constants.d.ts","sourceRoot":"","sources":["../packages/components/PeekCarousel/src/constants.ts"],"names":[],"mappings":"AAAA,oBAAY,gBAAgB;IAC1B,IAAI,SAAS;IACb,IAAI,UAAU;CACf;AACD,eAAO,MAAM,wBAAwB,MAAM,CAAC;AAC5C,eAAO,MAAM,qBAAqB,KAAK,CAAC"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";var n=require("tslib"),e=require("react/jsx-runtime"),t=require("react"),r=require("react-swipeable"),i=require("@cleartrip/ct-design-container");function
|
|
1
|
+
"use strict";var n=require("tslib"),e=require("react/jsx-runtime"),t=require("react"),r=require("react-swipeable"),i=require("@cleartrip/ct-design-use-isomorphic-effect"),a=require("@cleartrip/ct-design-container");function s(n){return n&&n.__esModule?n:{default:n}}var o,l=s(t),c=s(i);!function(n){n.NEXT="LEFT",n.PREV="RIGHT"}(o||(o={}));var u=t.forwardRef(function(i,s){var u,d=i.children,f=i.onSlide,h=i.startIndex,m=void 0===h?0:h,v=i.height,p=i.animationDelay,g=void 0===p?480:p,x=i.cardWidth,C=i.slideMargin,_=void 0===C?4:C,w=i.currentIndex,N=i.thresholdVelocity,b=void 0===N?.2:N,y=i.thresholdDelta,R=void 0===y?50:y,S=i.styleConfig,M=i.virtualized,k=void 0!==M&&M,T=i.overscan,I=void 0===T?2:T,P=S||{},X=P.relativeBaseContainerProps,j=P.rootContainerProps,q=P.sliderCardContainerProps,E=P.sliderRootContainerProps,F=P.sliderCardRootContainerProps,A=null!==(u=null==d?void 0:d.length)&&void 0!==u?u:0,V=t.useState(null!=w?w:m),D=V[0],L=V[1],O=t.useState(0),z=O[0],B=O[1],H=t.useState(!1),G=H[0],W=H[1],J=t.useRef(null),K=t.useRef(null);c.default(function(){void 0!==w&&L(w)},[w]);var Q=parseFloat(x)||0,U=Q+_,Y="calc(50% - ".concat(Q/2,"px)"),Z=t.useMemo(function(){return k?{start:Math.max(0,D-I),end:Math.min(A-1,D+I)}:null},[k,D,I,A]),$=t.useCallback(function(n){var e=Math.max(0,Math.min(n,A-1));void 0===w&&L(e),null==f||f(e)},[A,w,f]),nn=t.useCallback(function(n){if(d){var e=d.findIndex(function(e){return l.default.isValidElement(e)&&e.props.id===n});-1!==e&&$(e)}},[d,$]);t.useImperativeHandle(s,function(){return{goToIndex:$,goToItemById:nn}},[$,nn]);var en=t.useCallback(function(n){var e=n===o.NEXT?D+1:D-1;$(e)},[D,$]),tn=t.useCallback(function(n,e){K.current&&cancelAnimationFrame(K.current),W(!1),B(0),J.current&&(J.current.style.transition=""),(Math.abs(n.deltaX)>R||n.velocity>b)&&en(e)},[R,b,en]),rn=r.useSwipeable({onSwiping:function(n){W(!0);var e=-D*U,t=-(A-1)*U,r=e+n.deltaX,i=r<t?t-e:r>0?0-e:n.deltaX;J.current&&(J.current.style.transform="translateX(".concat(e+i,"px)"),J.current.style.transition="none"),K.current&&cancelAnimationFrame(K.current),K.current=requestAnimationFrame(function(){B(i),K.current=null})},onSwipedLeft:function(n){return tn(n,o.NEXT)},onSwipedRight:function(n){return tn(n,o.PREV)},onTouchStartOrOnMouseDown:function(){W(!0),J.current&&(J.current.style.transition="none")},trackMouse:!0,trackTouch:!0,preventScrollOnSwipe:!0}),an=-D*U,sn=G?z:0,on="translateX(".concat(an+sn,"px)"),ln=-(an+sn)/U;return e.jsx(a.Container,n.__assign({className:"flex flex-middle flex-center o-hidden ".concat((null==j?void 0:j.className)||""),css:n.__assign({width:"100%"},null==j?void 0:j.css)},{children:e.jsx(a.Container,n.__assign({},rn,{className:"position-relative o-hidden ".concat((null==X?void 0:X.className)||""),css:n.__assign({width:"100%",height:v},null==X?void 0:X.css)},{children:e.jsx(a.Container,n.__assign({ref:J,className:"flex h-100p ".concat((null==E?void 0:E.className)||""),css:null==E?void 0:E.css,style:{paddingLeft:Y,paddingRight:Y,transform:on,transition:G?"none":"transform ".concat(g,"ms cubic-bezier(0.4, 0, 0.2, 1)")}},{children:Array.from({length:A},function(t,r){var i=function(n,e){var t=n-e,r=Math.abs(t);return{transform:"scale(".concat(r<1?1-.15*r:.85,")")}}(r,ln).transform;return!k||Z&&r>=Z.start&&r<=Z.end?e.jsx(a.Container,n.__assign({className:"flex-no-shrink h-100p flex-middle flex-center ".concat((null==F?void 0:F.className)||""),css:n.__assign({width:x,transition:G?"none":"transform 150ms linear",transform:i,marginRight:r===A-1?0:_},null==F?void 0:F.css)},{children:e.jsx(a.Container,n.__assign({className:"slider-single-content w-100p h-100p flex-middle flex-center o-hidden br-16 ".concat((null==q?void 0:q.className)||""),css:null==q?void 0:q.css},{children:null==d?void 0:d[r]}))}),"slider-".concat(r)):e.jsx(a.Container,{style:{width:x,height:"100%",flexShrink:0,marginRight:r===A-1?0:_}},"placeholder-".concat(r))})}))}))}))});exports.PeekCarousel=u;
|
|
2
2
|
//# sourceMappingURL=ct-design-peek-carousel.browser.cjs.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ct-design-peek-carousel.browser.cjs.js","sources":["../packages/components/PeekCarousel/src/constants.ts","../packages/components/PeekCarousel/src/PeekCarousel.tsx","../packages/components/PeekCarousel/src/style.ts"],"sourcesContent":[null,null,null],"names":["SLIDER_DIRECTION","
|
|
1
|
+
{"version":3,"file":"ct-design-peek-carousel.browser.cjs.js","sources":["../packages/components/PeekCarousel/src/constants.ts","../packages/components/PeekCarousel/src/PeekCarousel.tsx","../packages/components/PeekCarousel/src/style.ts"],"sourcesContent":[null,null,null],"names":["SLIDER_DIRECTION","PeekCarousel","forwardRef","props","ref","children","onSlide","_b","startIndex","height","_c","animationDelay","cardWidth","_d","slideMargin","currentIndex","_e","thresholdVelocity","_f","thresholdDelta","styleConfig","_g","virtualized","_h","overscan","_j","relativeBaseContainerProps","rootContainerProps","sliderCardContainerProps","sliderRootContainerProps","sliderCardRootContainerProps","totalCount","_a","length","_k","useState","activeIndex","setActiveIndex","_l","dragOffset","setDragOffset","_m","isDragging","setIsDragging","sliderRef","useRef","rafRef","useIsomorphicEffect","undefined","cardWidthPx","parseFloat","stepSize","centerPadding","concat","visibleRange","useMemo","start","Math","max","end","min","goToIndex","useCallback","index","clampedIndex","goToItemById","id","findIndex","child","React","default","isValidElement","useImperativeHandle","onNavigateClick","direction","nextIndex","NEXT","handleSwiped","e","current","cancelAnimationFrame","style","transition","abs","deltaX","velocity","handlers","useSwipeable","onSwiping","currentBaseX","maxLeft","proposedX","clampedOffset","transform","requestAnimationFrame","onSwipedLeft","onSwipedRight","PREV","onTouchStartOrOnMouseDown","trackMouse","trackTouch","preventScrollOnSwipe","baseX","currentOffset","finalTransform","effectiveIndex","_jsx","Container","__assign","className","css","width","paddingLeft","paddingRight","Array","from","_","distance","absDistance","getStyles","marginRight","jsx","flexShrink"],"mappings":"8QAAYA,iBAAZ,SAAYA,GACVA,EAAA,KAAA,OACAA,EAAA,KAAA,OACD,CAHD,CAAYA,IAAAA,EAGX,CAAA,IACM,ICODC,EAAeC,EAAUA,WAAuC,SAACC,EAAOC,SAE1EC,EAaEF,EAAKE,SAZPC,EAYEH,EAZKG,QACPC,EAWEJ,EAAKK,WAXPA,OAAU,IAAAD,EAAG,EAACA,EACdE,EAUEN,SATFO,EASEP,EATkBQ,eAApBA,OAAiB,IAAAD,EAAA,MACjBE,EAQET,EAAKS,UAPPC,EAOEV,cAPFW,aAAc,EAACD,EACfE,EAMEZ,EANUY,aACZC,EAKEb,EAAKc,kBALPA,OAAiB,IAAAD,EDjBmB,GCiBQA,EAC5CE,EAIEf,EAAKgB,eAJPA,OAAc,IAAAD,EDjBmB,GCiBKA,EACtCE,EAGEjB,cAFFkB,EAEElB,EAFiBmB,YAAnBA,OAAc,IAAAD,KACdE,EACEpB,EADUqB,SAAZA,OAAW,IAAAD,EAAA,IAGPE,EAMFL,GAAe,GALjBM,+BACAC,uBACAC,6BACAC,6BACAC,iCAGIC,EAAiC,QAApBC,EAAA3B,aAAA,EAAAA,EAAU4B,cAAU,IAAAD,EAAAA,EAAA,EAEjCE,EAAgCC,EAAAA,SAASpB,QAAAA,EAAgBP,GAAxD4B,OAAaC,OACdC,EAA8BH,EAAAA,SAAS,GAAtCI,EAAUD,EAAA,GAAEE,EAAaF,EAAA,GAC1BG,EAA8BN,EAAAA,UAAS,GAAtCO,EAAUD,EAAA,GAAEE,EAAaF,EAAA,GAE1BG,EAAYC,SAAuB,MACnCC,EAASD,SAAsB,MAGrCE,EAAAA,QAAoB,gBACGC,IAAjBjC,GAA4BsB,EAAetB,EACjD,EAAG,CAACA,IAEJ,IAAMkC,EAAcC,WAAWtC,IAAc,EACvCuC,EAAWF,EAAcnC,EAEzBsC,EAAgB,cAAAC,OAAcJ,EAAc,SAE5CK,EAAeC,EAAAA,QAAQ,WAC3B,OAAKjC,EACE,CACLkC,MAAOC,KAAKC,IAAI,EAAGtB,EAAcZ,GACjCmC,IAAKF,KAAKG,IAAI7B,EAAa,EAAGK,EAAcZ,IAHrB,IAK1B,EAAE,CAACF,EAAac,EAAaZ,EAAUO,IAElC8B,EAAYC,cAChB,SAACC,GACC,IAAMC,EAAeP,KAAKC,IAAI,EAAGD,KAAKG,IAAIG,EAAOhC,EAAa,SACzCiB,IAAjBjC,GAA4BsB,EAAe2B,GAC/C1D,SAAAA,EAAU0D,EACX,EACD,CAACjC,EAAYhB,EAAcT,IAGvB2D,GAAeH,cACnB,SAACI,GACC,GAAK7D,EAAL,CACA,IAAM0D,EAAQ1D,EAAS8D,UACrB,SAACC,GAAU,OAAAC,EAAKC,QAACC,eAAeH,IAAWA,EAAMjE,MAA0B+D,KAAOA,CAAE,IAEvE,IAAXH,GAAcF,EAAUE,EAJN,CAKxB,EACA,CAAC1D,EAAUwD,IAGbW,EAAAA,oBAAoBpE,EAAK,WAAM,MAAC,CAAEyD,UAASA,EAAEI,gBAAe,EAAE,CAACJ,EAAWI,KAE1E,IAAMQ,GAAkBX,cACtB,SAACY,GACC,IAAMC,EAAYD,IAAc1E,EAAiB4E,KAAOxC,EAAc,EAAIA,EAAc,EACxFyB,EAAUc,EACZ,EACA,CAACvC,EAAayB,IAGVgB,GAAef,EAAAA,YACnB,SAACgB,EAAmBJ,GACd5B,EAAOiC,SAASC,qBAAqBlC,EAAOiC,SAChDpC,GAAc,GACdH,EAAc,GACVI,EAAUmC,UAASnC,EAAUmC,QAAQE,MAAMC,WAAa,KAExDzB,KAAK0B,IAAIL,EAAEM,QAAUjE,GAAkB2D,EAAEO,SAAWpE,IACtDwD,GAAgBC,EAEnB,EACD,CAACvD,EAAgBF,EAAmBwD,KAGhCa,GAAWC,EAAAA,aAAa,CAC5BC,UAAW,SAACV,GACVnC,GAAc,GAGd,IAAM8C,GAAgBrD,EAAce,EAC9BuC,IAAY3D,EAAa,GAAKoB,EAE9BwC,EAAYF,EAAeX,EAAEM,OAE7BQ,EACJD,EAAYD,EAAUA,EAAUD,EAAeE,EAJhC,IAIkEF,EAAeX,EAAEM,OAGhGxC,EAAUmC,UACZnC,EAAUmC,QAAQE,MAAMY,UAAY,cAAAxC,OAAcoC,EAAeG,EAAa,OAC9EhD,EAAUmC,QAAQE,MAAMC,WAAa,QAInCpC,EAAOiC,SAASC,qBAAqBlC,EAAOiC,SAChDjC,EAAOiC,QAAUe,sBAAsB,WACrCtD,EAAcoD,GACd9C,EAAOiC,QAAU,IACnB,EACD,EACDgB,aAAc,SAACjB,GAAsB,OAAAD,GAAaC,EAAG9E,EAAiB4E,KAAK,EAC3EoB,cAAe,SAAClB,GAAsB,OAAAD,GAAaC,EAAG9E,EAAiBiG,KAAK,EAC5EC,0BAA2B,WACzBvD,GAAc,GACVC,EAAUmC,UAASnC,EAAUmC,QAAQE,MAAMC,WAAa,OAC7D,EACDiB,YAAY,EACZC,YAAY,EACZC,sBAAsB,IAIlBC,IAASlE,EAAce,EACvBoD,GAAgB7D,EAAaH,EAAa,EAC1CiE,GAAiB,cAAAnD,OAAciD,GAAQC,UACvCE,KAAmBH,GAAQC,IAAiBpD,EAElD,OACEuD,MAACC,EAAAA,UAASC,EAAAA,SAAA,CACRC,UAAW,yCAAAxD,QAAyC1B,eAAAA,EAAoBkF,YAAa,IACrFC,IAAOF,EAAAA,SAAA,CAAAG,MAAO,QAAWpF,aAAA,EAAAA,EAAoBmF,MAAG,CAAAzG,SAEhDqG,MAACC,EAAAA,UACKC,EAAAA,SAAA,GAAAtB,IACJuB,UAAW,8BAA8BxD,QAAA3B,aAAA,EAAAA,EAA4BmF,YAAa,IAClFC,gBACEC,MAAO,OACPtG,OAAMA,GACHiB,aAAA,EAAAA,EAA4BoF,MAGjC,CAAAzG,SAAAqG,EAAAA,IAACC,EAASA,UACRC,EAAAA,SAAA,CAAAxG,IAAKwC,EACLiE,UAAW,eAAexD,QAAAxB,eAAAA,EAA0BgF,YAAa,IACjEC,IAAKjF,aAAwB,EAAxBA,EAA0BiF,IAC/B7B,MAAO,CACL+B,YAAa5D,EACb6D,aAAc7D,EACdyC,UAAWW,GACXtB,WAAYxC,EAAa,OAAS,aAAaW,OAAA1C,EAA+C,qCAC/F,CAAAN,SAEA6G,MAAMC,KAAK,CAAElF,OAAQF,GAAc,SAACqF,EAAGrD,GAC9B,IAAA8B,EChLK,SAAC9B,EAAe0C,GACvC,IAAMY,EAAWtD,EAAQ0C,EACnBa,EAAc7D,KAAK0B,IAAIkC,GAU7B,MAAO,CACLxB,UAAW,SAASxC,OARlBiE,EAAc,EAER,EAAoB,IAAdA,EAEN,IAIoB,KAEhC,CDiKkCC,CAAUxD,EAAO0C,IAAeZ,UAItD,OAFGvE,GAAgBgC,GAAgBS,GAAST,EAAaE,OAASO,GAAST,EAAaK,IAiBtF+C,MAACC,YAASC,EAAAA,SAAA,CAERC,UAAW,iDAAAxD,QACTvB,eAAAA,EAA8B+E,YAAa,IAE7CC,IAAGF,WAAA,CACDG,MAAOnG,EACPsE,WAAYxC,EAAa,OAAS,yBAClCmD,UAASA,EACT2B,YAAazD,IAAUhC,EAAa,EAAI,EAAIjB,GACzCgB,aAA4B,EAA5BA,EAA8BgF,MAGnC,CAAAzG,SAAAqG,EAAAe,IAACd,YAASC,EAAAA,SAAA,CACRC,UAAW,8EAAAxD,QACTzB,eAAAA,EAA0BiF,YAAa,IAEzCC,IAAKlF,aAAwB,EAAxBA,EAA0BkF,KAE9B,CAAAzG,SAAAA,eAAAA,EAAW0D,QAlBT,iBAAUA,IAdf2C,EAAAe,IAACd,YAAS,CAER1B,MAAO,CACL8B,MAAOnG,EACPH,OAAQ,OACRiH,WAAY,EACZF,YAAazD,IAAUhC,EAAa,EAAI,EAAIjB,IALzC,eAAeuC,OAAAU,GAmC3B,WAKX"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import{__assign as n}from"tslib";import{jsx as t}from"react/jsx-runtime";import
|
|
1
|
+
import{__assign as n}from"tslib";import{jsx as t}from"react/jsx-runtime";import r,{forwardRef as e,useState as i,useRef as o,useMemo as a,useCallback as c,useImperativeHandle as l}from"react";import{useSwipeable as s}from"react-swipeable";import d from"@cleartrip/ct-design-use-isomorphic-effect";import{Container as u}from"@cleartrip/ct-design-container";var m;!function(n){n.NEXT="LEFT",n.PREV="RIGHT"}(m||(m={}));var f=e(function(e,f){var h,v=e.children,p=e.onSlide,g=e.startIndex,x=void 0===g?0:g,N=e.height,y=e.animationDelay,w=void 0===y?480:y,M=e.cardWidth,R=e.slideMargin,T=void 0===R?4:R,C=e.currentIndex,S=e.thresholdVelocity,X=void 0===S?.2:S,b=e.thresholdDelta,E=void 0===b?50:b,I=e.styleConfig,P=e.virtualized,F=void 0!==P&&P,k=e.overscan,A=void 0===k?2:k,V=I||{},D=V.relativeBaseContainerProps,L=V.rootContainerProps,O=V.sliderCardContainerProps,z=V.sliderRootContainerProps,B=V.sliderCardRootContainerProps,j=null!==(h=null==v?void 0:v.length)&&void 0!==h?h:0,q=i(null!=C?C:x),G=q[0],H=q[1],W=i(0),J=W[0],K=W[1],Q=i(!1),U=Q[0],Y=Q[1],Z=o(null),$=o(null);d(function(){void 0!==C&&H(C)},[C]);var _=parseFloat(M)||0,nn=_+T,tn="calc(50% - ".concat(_/2,"px)"),rn=a(function(){return F?{start:Math.max(0,G-A),end:Math.min(j-1,G+A)}:null},[F,G,A,j]),en=c(function(n){var t=Math.max(0,Math.min(n,j-1));void 0===C&&H(t),null==p||p(t)},[j,C,p]),on=c(function(n){if(v){var t=v.findIndex(function(t){return r.isValidElement(t)&&t.props.id===n});-1!==t&&en(t)}},[v,en]);l(f,function(){return{goToIndex:en,goToItemById:on}},[en,on]);var an=c(function(n){var t=n===m.NEXT?G+1:G-1;en(t)},[G,en]),cn=c(function(n,t){$.current&&cancelAnimationFrame($.current),Y(!1),K(0),Z.current&&(Z.current.style.transition=""),(Math.abs(n.deltaX)>E||n.velocity>X)&&an(t)},[E,X,an]),ln=s({onSwiping:function(n){Y(!0);var t=-G*nn,r=-(j-1)*nn,e=t+n.deltaX,i=e<r?r-t:e>0?0-t:n.deltaX;Z.current&&(Z.current.style.transform="translateX(".concat(t+i,"px)"),Z.current.style.transition="none"),$.current&&cancelAnimationFrame($.current),$.current=requestAnimationFrame(function(){K(i),$.current=null})},onSwipedLeft:function(n){return cn(n,m.NEXT)},onSwipedRight:function(n){return cn(n,m.PREV)},onTouchStartOrOnMouseDown:function(){Y(!0),Z.current&&(Z.current.style.transition="none")},trackMouse:!0,trackTouch:!0,preventScrollOnSwipe:!0}),sn=-G*nn,dn=U?J:0,un="translateX(".concat(sn+dn,"px)"),mn=-(sn+dn)/nn;return t(u,n({className:"flex flex-middle flex-center o-hidden ".concat((null==L?void 0:L.className)||""),css:n({width:"100%"},null==L?void 0:L.css)},{children:t(u,n({},ln,{className:"position-relative o-hidden ".concat((null==D?void 0:D.className)||""),css:n({width:"100%",height:N},null==D?void 0:D.css)},{children:t(u,n({ref:Z,className:"flex h-100p ".concat((null==z?void 0:z.className)||""),css:null==z?void 0:z.css,style:{paddingLeft:tn,paddingRight:tn,transform:un,transition:U?"none":"transform ".concat(w,"ms cubic-bezier(0.4, 0, 0.2, 1)")}},{children:Array.from({length:j},function(r,e){var i=function(n,t){var r=n-t,e=Math.abs(r);return{transform:"scale(".concat(e<1?1-.15*e:.85,")")}}(e,mn).transform;return!F||rn&&e>=rn.start&&e<=rn.end?t(u,n({className:"flex-no-shrink h-100p flex-middle flex-center ".concat((null==B?void 0:B.className)||""),css:n({width:M,transition:U?"none":"transform 150ms linear",transform:i,marginRight:e===j-1?0:T},null==B?void 0:B.css)},{children:t(u,n({className:"slider-single-content w-100p h-100p flex-middle flex-center o-hidden br-16 ".concat((null==O?void 0:O.className)||""),css:null==O?void 0:O.css},{children:null==v?void 0:v[e]}))}),"slider-".concat(e)):t(u,{style:{width:M,height:"100%",flexShrink:0,marginRight:e===j-1?0:T}},"placeholder-".concat(e))})}))}))}))});export{f as PeekCarousel};
|
|
2
2
|
//# sourceMappingURL=ct-design-peek-carousel.browser.esm.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ct-design-peek-carousel.browser.esm.js","sources":["../packages/components/PeekCarousel/src/constants.ts","../packages/components/PeekCarousel/src/PeekCarousel.tsx","../packages/components/PeekCarousel/src/style.ts"],"sourcesContent":[null,null,null],"names":["SLIDER_DIRECTION","
|
|
1
|
+
{"version":3,"file":"ct-design-peek-carousel.browser.esm.js","sources":["../packages/components/PeekCarousel/src/constants.ts","../packages/components/PeekCarousel/src/PeekCarousel.tsx","../packages/components/PeekCarousel/src/style.ts"],"sourcesContent":[null,null,null],"names":["SLIDER_DIRECTION","PeekCarousel","forwardRef","props","ref","children","onSlide","_b","startIndex","height","_c","animationDelay","cardWidth","_d","slideMargin","currentIndex","_e","thresholdVelocity","_f","thresholdDelta","styleConfig","_g","virtualized","_h","overscan","_j","relativeBaseContainerProps","rootContainerProps","sliderCardContainerProps","sliderRootContainerProps","sliderCardRootContainerProps","totalCount","_a","length","_k","useState","activeIndex","setActiveIndex","_l","dragOffset","setDragOffset","_m","isDragging","setIsDragging","sliderRef","useRef","rafRef","useIsomorphicEffect","undefined","cardWidthPx","parseFloat","stepSize","centerPadding","concat","visibleRange","useMemo","start","Math","max","end","min","goToIndex","useCallback","index","clampedIndex","goToItemById","id","findIndex","child","React","isValidElement","useImperativeHandle","onNavigateClick","direction","nextIndex","NEXT","handleSwiped","e","current","cancelAnimationFrame","style","transition","abs","deltaX","velocity","handlers","useSwipeable","onSwiping","currentBaseX","maxLeft","proposedX","clampedOffset","transform","requestAnimationFrame","onSwipedLeft","onSwipedRight","PREV","onTouchStartOrOnMouseDown","trackMouse","trackTouch","preventScrollOnSwipe","baseX","currentOffset","finalTransform","effectiveIndex","_jsx","Container","__assign","className","css","width","paddingLeft","paddingRight","Array","from","_","distance","absDistance","getStyles","marginRight","flexShrink"],"mappings":"oWAAA,IAAYA,GAAZ,SAAYA,GACVA,EAAA,KAAA,OACAA,EAAA,KAAA,OACD,CAHD,CAAYA,IAAAA,EAGX,CAAA,IACM,ICODC,EAAeC,EAAiD,SAACC,EAAOC,SAE1EC,EAaEF,EAAKE,SAZPC,EAYEH,EAZKG,QACPC,EAWEJ,EAAKK,WAXPA,OAAU,IAAAD,EAAG,EAACA,EACdE,EAUEN,SATFO,EASEP,EATkBQ,eAApBA,OAAiB,IAAAD,EAAA,MACjBE,EAQET,EAAKS,UAPPC,EAOEV,cAPFW,aAAc,EAACD,EACfE,EAMEZ,EANUY,aACZC,EAKEb,EAAKc,kBALPA,OAAiB,IAAAD,EDjBmB,GCiBQA,EAC5CE,EAIEf,EAAKgB,eAJPA,OAAc,IAAAD,EDjBmB,GCiBKA,EACtCE,EAGEjB,cAFFkB,EAEElB,EAFiBmB,YAAnBA,OAAc,IAAAD,KACdE,EACEpB,EADUqB,SAAZA,OAAW,IAAAD,EAAA,IAGPE,EAMFL,GAAe,GALjBM,+BACAC,uBACAC,6BACAC,6BACAC,iCAGIC,EAAiC,QAApBC,EAAA3B,aAAA,EAAAA,EAAU4B,cAAU,IAAAD,EAAAA,EAAA,EAEjCE,EAAgCC,EAASpB,QAAAA,EAAgBP,GAAxD4B,OAAaC,OACdC,EAA8BH,EAAS,GAAtCI,EAAUD,EAAA,GAAEE,EAAaF,EAAA,GAC1BG,EAA8BN,GAAS,GAAtCO,EAAUD,EAAA,GAAEE,EAAaF,EAAA,GAE1BG,EAAYC,EAAuB,MACnCC,EAASD,EAAsB,MAGrCE,EAAoB,gBACGC,IAAjBjC,GAA4BsB,EAAetB,EACjD,EAAG,CAACA,IAEJ,IAAMkC,EAAcC,WAAWtC,IAAc,EACvCuC,GAAWF,EAAcnC,EAEzBsC,GAAgB,cAAAC,OAAcJ,EAAc,SAE5CK,GAAeC,EAAQ,WAC3B,OAAKjC,EACE,CACLkC,MAAOC,KAAKC,IAAI,EAAGtB,EAAcZ,GACjCmC,IAAKF,KAAKG,IAAI7B,EAAa,EAAGK,EAAcZ,IAHrB,IAK1B,EAAE,CAACF,EAAac,EAAaZ,EAAUO,IAElC8B,GAAYC,EAChB,SAACC,GACC,IAAMC,EAAeP,KAAKC,IAAI,EAAGD,KAAKG,IAAIG,EAAOhC,EAAa,SACzCiB,IAAjBjC,GAA4BsB,EAAe2B,GAC/C1D,SAAAA,EAAU0D,EACX,EACD,CAACjC,EAAYhB,EAAcT,IAGvB2D,GAAeH,EACnB,SAACI,GACC,GAAK7D,EAAL,CACA,IAAM0D,EAAQ1D,EAAS8D,UACrB,SAACC,GAAU,OAAAC,EAAMC,eAAeF,IAAWA,EAAMjE,MAA0B+D,KAAOA,CAAE,IAEvE,IAAXH,GAAcF,GAAUE,EAJN,CAKxB,EACA,CAAC1D,EAAUwD,KAGbU,EAAoBnE,EAAK,WAAM,MAAC,CAAEyD,UAASA,GAAEI,gBAAe,EAAE,CAACJ,GAAWI,KAE1E,IAAMO,GAAkBV,EACtB,SAACW,GACC,IAAMC,EAAYD,IAAczE,EAAiB2E,KAAOvC,EAAc,EAAIA,EAAc,EACxFyB,GAAUa,EACZ,EACA,CAACtC,EAAayB,KAGVe,GAAed,EACnB,SAACe,EAAmBJ,GACd3B,EAAOgC,SAASC,qBAAqBjC,EAAOgC,SAChDnC,GAAc,GACdH,EAAc,GACVI,EAAUkC,UAASlC,EAAUkC,QAAQE,MAAMC,WAAa,KAExDxB,KAAKyB,IAAIL,EAAEM,QAAUhE,GAAkB0D,EAAEO,SAAWnE,IACtDuD,GAAgBC,EAEnB,EACD,CAACtD,EAAgBF,EAAmBuD,KAGhCa,GAAWC,EAAa,CAC5BC,UAAW,SAACV,GACVlC,GAAc,GAGd,IAAM6C,GAAgBpD,EAAce,GAC9BsC,IAAY1D,EAAa,GAAKoB,GAE9BuC,EAAYF,EAAeX,EAAEM,OAE7BQ,EACJD,EAAYD,EAAUA,EAAUD,EAAeE,EAJhC,IAIkEF,EAAeX,EAAEM,OAGhGvC,EAAUkC,UACZlC,EAAUkC,QAAQE,MAAMY,UAAY,cAAAvC,OAAcmC,EAAeG,EAAa,OAC9E/C,EAAUkC,QAAQE,MAAMC,WAAa,QAInCnC,EAAOgC,SAASC,qBAAqBjC,EAAOgC,SAChDhC,EAAOgC,QAAUe,sBAAsB,WACrCrD,EAAcmD,GACd7C,EAAOgC,QAAU,IACnB,EACD,EACDgB,aAAc,SAACjB,GAAsB,OAAAD,GAAaC,EAAG7E,EAAiB2E,KAAK,EAC3EoB,cAAe,SAAClB,GAAsB,OAAAD,GAAaC,EAAG7E,EAAiBgG,KAAK,EAC5EC,0BAA2B,WACzBtD,GAAc,GACVC,EAAUkC,UAASlC,EAAUkC,QAAQE,MAAMC,WAAa,OAC7D,EACDiB,YAAY,EACZC,YAAY,EACZC,sBAAsB,IAIlBC,IAASjE,EAAce,GACvBmD,GAAgB5D,EAAaH,EAAa,EAC1CgE,GAAiB,cAAAlD,OAAcgD,GAAQC,UACvCE,KAAmBH,GAAQC,IAAiBnD,GAElD,OACEsD,EAACC,EAASC,EAAA,CACRC,UAAW,yCAAAvD,QAAyC1B,eAAAA,EAAoBiF,YAAa,IACrFC,IAAOF,EAAA,CAAAG,MAAO,QAAWnF,aAAA,EAAAA,EAAoBkF,MAAG,CAAAxG,SAEhDoG,EAACC,EACKC,EAAA,GAAAtB,IACJuB,UAAW,8BAA8BvD,QAAA3B,aAAA,EAAAA,EAA4BkF,YAAa,IAClFC,OACEC,MAAO,OACPrG,OAAMA,GACHiB,aAAA,EAAAA,EAA4BmF,MAGjC,CAAAxG,SAAAoG,EAACC,EACCC,EAAA,CAAAvG,IAAKwC,EACLgE,UAAW,eAAevD,QAAAxB,eAAAA,EAA0B+E,YAAa,IACjEC,IAAKhF,aAAwB,EAAxBA,EAA0BgF,IAC/B7B,MAAO,CACL+B,YAAa3D,GACb4D,aAAc5D,GACdwC,UAAWW,GACXtB,WAAYvC,EAAa,OAAS,aAAaW,OAAA1C,EAA+C,qCAC/F,CAAAN,SAEA4G,MAAMC,KAAK,CAAEjF,OAAQF,GAAc,SAACoF,EAAGpD,GAC9B,IAAA6B,EChLK,SAAC7B,EAAeyC,GACvC,IAAMY,EAAWrD,EAAQyC,EACnBa,EAAc5D,KAAKyB,IAAIkC,GAU7B,MAAO,CACLxB,UAAW,SAASvC,OARlBgE,EAAc,EAER,EAAoB,IAAdA,EAEN,IAIoB,KAEhC,CDiKkCC,CAAUvD,EAAOyC,IAAeZ,UAItD,OAFGtE,GAAgBgC,IAAgBS,GAAST,GAAaE,OAASO,GAAST,GAAaK,IAiBtF8C,EAACC,EAASC,EAAA,CAERC,UAAW,iDAAAvD,QACTvB,eAAAA,EAA8B8E,YAAa,IAE7CC,IAAGF,EAAA,CACDG,MAAOlG,EACPqE,WAAYvC,EAAa,OAAS,yBAClCkD,UAASA,EACT2B,YAAaxD,IAAUhC,EAAa,EAAI,EAAIjB,GACzCgB,aAA4B,EAA5BA,EAA8B+E,MAGnC,CAAAxG,SAAAoG,EAACC,EAASC,EAAA,CACRC,UAAW,8EAAAvD,QACTzB,eAAAA,EAA0BgF,YAAa,IAEzCC,IAAKjF,aAAwB,EAAxBA,EAA0BiF,KAE9B,CAAAxG,SAAAA,eAAAA,EAAW0D,QAlBT,iBAAUA,IAdf0C,EAACC,EAAS,CAER1B,MAAO,CACL8B,MAAOlG,EACPH,OAAQ,OACR+G,WAAY,EACZD,YAAaxD,IAAUhC,EAAa,EAAI,EAAIjB,IALzC,eAAeuC,OAAAU,GAmC3B,WAKX"}
|
|
@@ -4,20 +4,14 @@ var tslib = require('tslib');
|
|
|
4
4
|
var jsxRuntime = require('react/jsx-runtime');
|
|
5
5
|
var React = require('react');
|
|
6
6
|
var reactSwipeable = require('react-swipeable');
|
|
7
|
+
var useIsomorphicEffect = require('@cleartrip/ct-design-use-isomorphic-effect');
|
|
7
8
|
var ctDesignContainer = require('@cleartrip/ct-design-container');
|
|
8
9
|
|
|
9
10
|
function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
|
|
10
11
|
|
|
11
12
|
var React__default = /*#__PURE__*/_interopDefault(React);
|
|
13
|
+
var useIsomorphicEffect__default = /*#__PURE__*/_interopDefault(useIsomorphicEffect);
|
|
12
14
|
|
|
13
|
-
var PEEK_CAROUSEL_IDS = {
|
|
14
|
-
ROOT_CONTAINER: 'peekRootContainer',
|
|
15
|
-
SLIDER_ROOT_CONTAINER: 'peekSliderRootContainer',
|
|
16
|
-
SLIDER_CARD_CONTAINER: 'peekSliderCardContainer',
|
|
17
|
-
ICONS_CONTAINER: 'peekIconsContainer',
|
|
18
|
-
LEFT_ICON_CONTAINER: 'peekLeftIconContainer',
|
|
19
|
-
RIGHT_ICON_CONTAINER: 'peekRightIconContainer',
|
|
20
|
-
};
|
|
21
15
|
var SLIDER_DIRECTION;
|
|
22
16
|
(function (SLIDER_DIRECTION) {
|
|
23
17
|
SLIDER_DIRECTION["NEXT"] = "LEFT";
|
|
@@ -30,211 +24,122 @@ var getStyles = function (index, effectiveIndex) {
|
|
|
30
24
|
var distance = index - effectiveIndex;
|
|
31
25
|
var absDistance = Math.abs(distance);
|
|
32
26
|
var scale;
|
|
33
|
-
if (absDistance
|
|
34
|
-
scale =
|
|
27
|
+
if (absDistance < 1) {
|
|
28
|
+
scale = 1.0 - absDistance * 0.15;
|
|
35
29
|
}
|
|
36
30
|
else {
|
|
37
|
-
|
|
38
|
-
scale = 1.0 - absDistance * maxScaleDrop;
|
|
31
|
+
scale = 0.85;
|
|
39
32
|
}
|
|
40
|
-
scale = Math.min(1.0, Math.max(0.7, scale));
|
|
41
|
-
var zIndex = 10 - Math.floor(absDistance * 5);
|
|
42
33
|
return {
|
|
43
34
|
transform: "scale(".concat(scale, ")"),
|
|
44
|
-
zIndex: zIndex,
|
|
45
35
|
};
|
|
46
36
|
};
|
|
47
37
|
|
|
48
38
|
var PeekCarousel = React.forwardRef(function (props, ref) {
|
|
49
|
-
var
|
|
50
|
-
var
|
|
51
|
-
var
|
|
52
|
-
var
|
|
53
|
-
var _k = React.useState(0),
|
|
54
|
-
var _l = React.useState(
|
|
55
|
-
var
|
|
56
|
-
var
|
|
57
|
-
var
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
React.useEffect(function () {
|
|
62
|
-
currentIndexRef.current = currentIndex;
|
|
39
|
+
var _a;
|
|
40
|
+
var children = props.children, onSlide = props.onSlide, _b = props.startIndex, startIndex = _b === void 0 ? 0 : _b, height = props.height, _c = props.animationDelay, animationDelay = _c === void 0 ? 480 : _c, cardWidth = props.cardWidth, _d = props.slideMargin, slideMargin = _d === void 0 ? 4 : _d, currentIndex = props.currentIndex, _e = props.thresholdVelocity, thresholdVelocity = _e === void 0 ? SWIPE_THRESHOLD_VELOCITY : _e, _f = props.thresholdDelta, thresholdDelta = _f === void 0 ? SWIPE_THRESHOLD_DELTA : _f, styleConfig = props.styleConfig, _g = props.virtualized, virtualized = _g === void 0 ? false : _g, _h = props.overscan, overscan = _h === void 0 ? 2 : _h;
|
|
41
|
+
var _j = styleConfig || {}, relativeBaseContainerProps = _j.relativeBaseContainerProps, rootContainerProps = _j.rootContainerProps, sliderCardContainerProps = _j.sliderCardContainerProps, sliderRootContainerProps = _j.sliderRootContainerProps, sliderCardRootContainerProps = _j.sliderCardRootContainerProps;
|
|
42
|
+
var totalCount = (_a = children === null || children === void 0 ? void 0 : children.length) !== null && _a !== void 0 ? _a : 0;
|
|
43
|
+
var _k = React.useState(currentIndex !== null && currentIndex !== void 0 ? currentIndex : startIndex), activeIndex = _k[0], setActiveIndex = _k[1];
|
|
44
|
+
var _l = React.useState(0), dragOffset = _l[0], setDragOffset = _l[1];
|
|
45
|
+
var _m = React.useState(false), isDragging = _m[0], setIsDragging = _m[1];
|
|
46
|
+
var sliderRef = React.useRef(null);
|
|
47
|
+
var rafRef = React.useRef(null);
|
|
48
|
+
useIsomorphicEffect__default.default(function () {
|
|
49
|
+
if (currentIndex !== undefined)
|
|
50
|
+
setActiveIndex(currentIndex);
|
|
63
51
|
}, [currentIndex]);
|
|
64
|
-
var
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
var _a;
|
|
71
|
-
if (typeof cardWidth === 'string' && cardWidth.includes('px')) {
|
|
72
|
-
return parseInt(cardWidth, 10);
|
|
73
|
-
}
|
|
74
|
-
else if (typeof cardWidth === 'string' && cardWidth.includes('%')) {
|
|
75
|
-
var containerWidthPx = ((_a = containerRef.current) === null || _a === void 0 ? void 0 : _a.offsetWidth) || window.innerWidth;
|
|
76
|
-
var percentage = parseFloat(cardWidth);
|
|
77
|
-
return (percentage / 100) * containerWidthPx;
|
|
78
|
-
}
|
|
79
|
-
else if (typeof cardWidth === 'number') {
|
|
80
|
-
return cardWidth;
|
|
81
|
-
}
|
|
82
|
-
return 400;
|
|
83
|
-
};
|
|
84
|
-
var itemWidthPx = getCardWidthValue();
|
|
85
|
-
var cardGapPx = slideMargin;
|
|
86
|
-
var peekStepPx = itemWidthPx + cardGapPx;
|
|
87
|
-
var getContainerWidth = function () {
|
|
88
|
-
if (typeof cardWidth === 'string' && cardWidth.includes('px')) {
|
|
89
|
-
var widthValue = parseInt(cardWidth, 10);
|
|
90
|
-
var peekWidth = (widthValue * peekPercentage) / 100;
|
|
91
|
-
var totalWidth = widthValue + peekWidth * 2 + slideMargin * 4;
|
|
92
|
-
return "".concat(totalWidth, "px");
|
|
93
|
-
}
|
|
94
|
-
return cardWidth;
|
|
95
|
-
};
|
|
96
|
-
var containerWidthValue = getContainerWidth();
|
|
97
|
-
var containerWidthPxValue = typeof containerWidthValue === 'string' && containerWidthValue.includes('px')
|
|
98
|
-
? parseInt(containerWidthValue, 10)
|
|
99
|
-
: typeof cardWidth === 'string' && cardWidth.includes('px')
|
|
100
|
-
? parseInt(cardWidth, 10) + 200
|
|
101
|
-
: 600;
|
|
102
|
-
var centerOffsetPx = containerWidthPxValue / 2;
|
|
103
|
-
var paddingCenteringPx = centerOffsetPx - itemWidthPx / 2;
|
|
52
|
+
var cardWidthPx = parseFloat(cardWidth) || 0;
|
|
53
|
+
var stepSize = cardWidthPx + slideMargin;
|
|
54
|
+
var centerPadding = "calc(50% - ".concat(cardWidthPx / 2, "px)");
|
|
55
|
+
var visibleRange = React.useMemo(function () {
|
|
56
|
+
if (!virtualized)
|
|
57
|
+
return null;
|
|
104
58
|
return {
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
PEEK_STEP_PX: peekStepPx,
|
|
108
|
-
containerWidth: containerWidthValue,
|
|
109
|
-
containerWidthPx: containerWidthPxValue,
|
|
110
|
-
CENTER_OFFSET_PX: centerOffsetPx,
|
|
111
|
-
PADDING_CENTERING_PX: paddingCenteringPx,
|
|
59
|
+
start: Math.max(0, activeIndex - overscan),
|
|
60
|
+
end: Math.min(totalCount - 1, activeIndex + overscan),
|
|
112
61
|
};
|
|
113
|
-
}, [
|
|
114
|
-
var findIndexById = React.useCallback(function (id) {
|
|
115
|
-
return sliderChildren.findIndex(function (child) {
|
|
116
|
-
if (React__default.default.isValidElement(child) && child.props) {
|
|
117
|
-
var props_1 = child.props;
|
|
118
|
-
return props_1.id === id;
|
|
119
|
-
}
|
|
120
|
-
return false;
|
|
121
|
-
});
|
|
122
|
-
}, [sliderChildren]);
|
|
62
|
+
}, [virtualized, activeIndex, overscan, totalCount]);
|
|
123
63
|
var goToIndex = React.useCallback(function (index) {
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
React.useEffect(function () {
|
|
140
|
-
if (currentIndex !== undefined && currentIndex !== slideCurrent) {
|
|
141
|
-
setSlideCurrent(currentIndex);
|
|
142
|
-
}
|
|
143
|
-
}, [currentIndex, slideCurrent]);
|
|
144
|
-
var onNavigateClick = React.useCallback(function (dir) {
|
|
145
|
-
var delta = dir === SLIDER_DIRECTION.NEXT ? -1 : 1;
|
|
146
|
-
var nextIndex = activeIndexRef.current + delta;
|
|
64
|
+
var clampedIndex = Math.max(0, Math.min(index, totalCount - 1));
|
|
65
|
+
if (currentIndex === undefined)
|
|
66
|
+
setActiveIndex(clampedIndex);
|
|
67
|
+
onSlide === null || onSlide === void 0 ? void 0 : onSlide(clampedIndex);
|
|
68
|
+
}, [totalCount, currentIndex, onSlide]);
|
|
69
|
+
var goToItemById = React.useCallback(function (id) {
|
|
70
|
+
if (!children)
|
|
71
|
+
return;
|
|
72
|
+
var index = children.findIndex(function (child) { return React__default.default.isValidElement(child) && child.props.id === id; });
|
|
73
|
+
if (index !== -1)
|
|
74
|
+
goToIndex(index);
|
|
75
|
+
}, [children, goToIndex]);
|
|
76
|
+
React.useImperativeHandle(ref, function () { return ({ goToIndex: goToIndex, goToItemById: goToItemById }); }, [goToIndex, goToItemById]);
|
|
77
|
+
var onNavigateClick = React.useCallback(function (direction) {
|
|
78
|
+
var nextIndex = direction === SLIDER_DIRECTION.NEXT ? activeIndex + 1 : activeIndex - 1;
|
|
147
79
|
goToIndex(nextIndex);
|
|
148
|
-
}, [goToIndex]);
|
|
149
|
-
var handleSwiped = React.useCallback(function (e,
|
|
150
|
-
if (
|
|
151
|
-
cancelAnimationFrame(
|
|
152
|
-
rafIdRef.current = null;
|
|
153
|
-
}
|
|
80
|
+
}, [activeIndex, goToIndex]);
|
|
81
|
+
var handleSwiped = React.useCallback(function (e, direction) {
|
|
82
|
+
if (rafRef.current)
|
|
83
|
+
cancelAnimationFrame(rafRef.current);
|
|
154
84
|
setIsDragging(false);
|
|
155
|
-
|
|
156
|
-
if (
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
if (shouldMove) {
|
|
161
|
-
onNavigateClick(dir);
|
|
85
|
+
setDragOffset(0);
|
|
86
|
+
if (sliderRef.current)
|
|
87
|
+
sliderRef.current.style.transition = '';
|
|
88
|
+
if (Math.abs(e.deltaX) > thresholdDelta || e.velocity > thresholdVelocity) {
|
|
89
|
+
onNavigateClick(direction);
|
|
162
90
|
}
|
|
163
|
-
|
|
164
|
-
goToIndex(activeIndexRef.current);
|
|
165
|
-
}
|
|
166
|
-
setTranslateOffset(0);
|
|
167
|
-
}, [onNavigateClick, goToIndex, thresholdDelta, thresholdVelocity]);
|
|
91
|
+
}, [thresholdDelta, thresholdVelocity, onNavigateClick]);
|
|
168
92
|
var handlers = reactSwipeable.useSwipeable({
|
|
169
93
|
onSwiping: function (e) {
|
|
170
94
|
setIsDragging(true);
|
|
171
|
-
var currentBaseX = -
|
|
172
|
-
var
|
|
173
|
-
var
|
|
95
|
+
var currentBaseX = -activeIndex * stepSize;
|
|
96
|
+
var maxLeft = -(totalCount - 1) * stepSize;
|
|
97
|
+
var maxRight = 0;
|
|
174
98
|
var proposedX = currentBaseX + e.deltaX;
|
|
175
|
-
var
|
|
176
|
-
if (
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
else if (proposedX > maxDragRight) {
|
|
180
|
-
clampedDiffX = maxDragRight - currentBaseX;
|
|
181
|
-
}
|
|
182
|
-
translateOffsetRef.current = clampedDiffX;
|
|
183
|
-
if (sliderContainerRef.current) {
|
|
184
|
-
var finalTransform_1 = "translateX(".concat(currentBaseX + clampedDiffX, "px)");
|
|
185
|
-
sliderContainerRef.current.style.transform = finalTransform_1;
|
|
186
|
-
sliderContainerRef.current.style.transition = 'none';
|
|
99
|
+
var clampedOffset = proposedX < maxLeft ? maxLeft - currentBaseX : proposedX > maxRight ? maxRight - currentBaseX : e.deltaX;
|
|
100
|
+
if (sliderRef.current) {
|
|
101
|
+
sliderRef.current.style.transform = "translateX(".concat(currentBaseX + clampedOffset, "px)");
|
|
102
|
+
sliderRef.current.style.transition = 'none';
|
|
187
103
|
}
|
|
188
|
-
if (
|
|
189
|
-
cancelAnimationFrame(
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
rafIdRef.current = null;
|
|
104
|
+
if (rafRef.current)
|
|
105
|
+
cancelAnimationFrame(rafRef.current);
|
|
106
|
+
rafRef.current = requestAnimationFrame(function () {
|
|
107
|
+
setDragOffset(clampedOffset);
|
|
108
|
+
rafRef.current = null;
|
|
194
109
|
});
|
|
195
110
|
},
|
|
196
|
-
onSwipedLeft: function (e) {
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
onSwipedRight: function (e) {
|
|
200
|
-
handleSwiped(e, SLIDER_DIRECTION.NEXT);
|
|
201
|
-
},
|
|
202
|
-
onTouchStartOrOnMouseDown: function (e) {
|
|
203
|
-
e.event.preventDefault();
|
|
111
|
+
onSwipedLeft: function (e) { return handleSwiped(e, SLIDER_DIRECTION.NEXT); },
|
|
112
|
+
onSwipedRight: function (e) { return handleSwiped(e, SLIDER_DIRECTION.PREV); },
|
|
113
|
+
onTouchStartOrOnMouseDown: function () {
|
|
204
114
|
setIsDragging(true);
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
sliderContainerRef.current.style.transition = 'none';
|
|
208
|
-
}
|
|
115
|
+
if (sliderRef.current)
|
|
116
|
+
sliderRef.current.style.transition = 'none';
|
|
209
117
|
},
|
|
210
118
|
trackMouse: true,
|
|
211
119
|
trackTouch: true,
|
|
212
120
|
preventScrollOnSwipe: true,
|
|
213
|
-
delta: 0,
|
|
214
121
|
});
|
|
215
|
-
var
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
effectiveIndex: effIndex,
|
|
223
|
-
};
|
|
224
|
-
}, [activeIndex, PEEK_STEP_PX, isDragging, translateOffset]), finalTransform = _o.finalTransform, effectiveIndex = _o.effectiveIndex;
|
|
225
|
-
return (jsxRuntime.jsx(ctDesignContainer.Container, tslib.__assign({ id: PEEK_CAROUSEL_IDS.ROOT_CONTAINER, css: tslib.__assign({ display: 'flex', justifyContent: 'center', alignItems: 'center', overflow: 'hidden' }, rootContainerProps === null || rootContainerProps === void 0 ? void 0 : rootContainerProps.css), className: rootContainerProps === null || rootContainerProps === void 0 ? void 0 : rootContainerProps.className }, { children: jsxRuntime.jsx(ctDesignContainer.Container, tslib.__assign({}, handlers, { ref: function (node) {
|
|
226
|
-
containerRef.current = node;
|
|
227
|
-
if (handlers.ref && typeof handlers.ref === 'function') {
|
|
228
|
-
handlers.ref(node);
|
|
229
|
-
}
|
|
230
|
-
}, css: tslib.__assign({ position: 'relative', minHeight: height, width: containerWidth, marginLeft: 'auto', marginRight: 'auto', overflow: 'hidden' }, relativeBaseContainerProps === null || relativeBaseContainerProps === void 0 ? void 0 : relativeBaseContainerProps.css), className: relativeBaseContainerProps === null || relativeBaseContainerProps === void 0 ? void 0 : relativeBaseContainerProps.className }, { children: jsxRuntime.jsx(ctDesignContainer.Container, tslib.__assign({ ref: sliderContainerRef, id: PEEK_CAROUSEL_IDS.SLIDER_ROOT_CONTAINER, css: tslib.__assign({ display: 'flex', width: 'max-content' }, sliderRootContainerProps === null || sliderRootContainerProps === void 0 ? void 0 : sliderRootContainerProps.css), className: sliderRootContainerProps === null || sliderRootContainerProps === void 0 ? void 0 : sliderRootContainerProps.className, style: {
|
|
122
|
+
var baseX = -activeIndex * stepSize;
|
|
123
|
+
var currentOffset = isDragging ? dragOffset : 0;
|
|
124
|
+
var finalTransform = "translateX(".concat(baseX + currentOffset, "px)");
|
|
125
|
+
var effectiveIndex = -(baseX + currentOffset) / stepSize;
|
|
126
|
+
return (jsxRuntime.jsx(ctDesignContainer.Container, tslib.__assign({ className: "flex flex-middle flex-center o-hidden ".concat((rootContainerProps === null || rootContainerProps === void 0 ? void 0 : rootContainerProps.className) || ''), css: tslib.__assign({ width: '100%' }, rootContainerProps === null || rootContainerProps === void 0 ? void 0 : rootContainerProps.css) }, { children: jsxRuntime.jsx(ctDesignContainer.Container, tslib.__assign({}, handlers, { className: "position-relative o-hidden ".concat((relativeBaseContainerProps === null || relativeBaseContainerProps === void 0 ? void 0 : relativeBaseContainerProps.className) || ''), css: tslib.__assign({ width: '100%', height: height }, relativeBaseContainerProps === null || relativeBaseContainerProps === void 0 ? void 0 : relativeBaseContainerProps.css) }, { children: jsxRuntime.jsx(ctDesignContainer.Container, tslib.__assign({ ref: sliderRef, className: "flex h-100p ".concat((sliderRootContainerProps === null || sliderRootContainerProps === void 0 ? void 0 : sliderRootContainerProps.className) || ''), css: sliderRootContainerProps === null || sliderRootContainerProps === void 0 ? void 0 : sliderRootContainerProps.css, style: {
|
|
127
|
+
paddingLeft: centerPadding,
|
|
128
|
+
paddingRight: centerPadding,
|
|
231
129
|
transform: finalTransform,
|
|
232
130
|
transition: isDragging ? 'none' : "transform ".concat(animationDelay, "ms cubic-bezier(0.4, 0, 0.2, 1)"),
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
131
|
+
} }, { children: Array.from({ length: totalCount }, function (_, index) {
|
|
132
|
+
var transform = getStyles(index, effectiveIndex).transform;
|
|
133
|
+
var isVisible = !virtualized || (visibleRange && index >= visibleRange.start && index <= visibleRange.end);
|
|
134
|
+
if (!isVisible) {
|
|
135
|
+
return (jsxRuntime.jsx(ctDesignContainer.Container, { style: {
|
|
136
|
+
width: cardWidth,
|
|
137
|
+
height: '100%',
|
|
138
|
+
flexShrink: 0,
|
|
139
|
+
marginRight: index === totalCount - 1 ? 0 : slideMargin,
|
|
140
|
+
} }, "placeholder-".concat(index)));
|
|
141
|
+
}
|
|
142
|
+
return (jsxRuntime.jsx(ctDesignContainer.Container, tslib.__assign({ className: "flex-no-shrink h-100p flex-middle flex-center ".concat((sliderCardRootContainerProps === null || sliderCardRootContainerProps === void 0 ? void 0 : sliderCardRootContainerProps.className) || ''), css: tslib.__assign({ width: cardWidth, transition: isDragging ? 'none' : 'transform 150ms linear', transform: transform, marginRight: index === totalCount - 1 ? 0 : slideMargin }, sliderCardRootContainerProps === null || sliderCardRootContainerProps === void 0 ? void 0 : sliderCardRootContainerProps.css) }, { children: jsxRuntime.jsx(ctDesignContainer.Container, tslib.__assign({ className: "slider-single-content w-100p h-100p flex-middle flex-center o-hidden br-16 ".concat((sliderCardContainerProps === null || sliderCardContainerProps === void 0 ? void 0 : sliderCardContainerProps.className) || ''), css: sliderCardContainerProps === null || sliderCardContainerProps === void 0 ? void 0 : sliderCardContainerProps.css }, { children: children === null || children === void 0 ? void 0 : children[index] })) }), "slider-".concat(index)));
|
|
238
143
|
}) })) })) })));
|
|
239
144
|
});
|
|
240
145
|
|