mirror of
https://gitee.com/vant-contrib/vant.git
synced 2025-04-06 03:57:59 +08:00
2 lines
5.0 KiB
JavaScript
2 lines
5.0 KiB
JavaScript
import{c as F,b as ue,N as re,R as ve,S as fe,n as he,O as L,Q as A,l as de,F as E,u as me}from"./use-translate.d2900b8c.js";import{t as M,n as W,c as R,w as J}from"./with-install.19a35764.js";import{u as ge}from"./use-touch.04ca7093.js";import{u as K}from"./use-expose.c942d5f8.js";import{o as we}from"./on-popup-reopen.138c77eb.js";import{z as Q,C as q,H as U,D as f,u as C,N as j,L as pe,M as ye,J as Se,e as P,q as G}from"./vue-libs.b44bc779.js";const[Z,$]=F("swipe"),be={loop:M,width:W,height:W,vertical:Boolean,autoplay:R(0),duration:R(500),touchable:M,lazyRender:Boolean,initialSwipe:R(0),indicatorColor:String,showIndicators:M,stopPropagation:M},ee=Symbol(Z),Te=Q({name:Z,props:be,emits:["change"],setup(a,{emit:y,slots:d}){const u=q(),h=q(),e=U({rect:null,width:0,height:0,offset:0,active:0,swiping:!1}),r=ge(),{children:m,linkChildren:O}=ue(ee),i=f(()=>m.length),c=f(()=>e[a.vertical?"height":"width"]),s=f(()=>a.vertical?r.deltaY.value:r.deltaX.value),g=f(()=>e.rect?(a.vertical?e.rect.height:e.rect.width)-c.value*i.value:0),k=f(()=>Math.ceil(Math.abs(g.value)/c.value)),S=f(()=>i.value*c.value),I=f(()=>(e.active+i.value)%i.value),B=f(()=>{const t=a.vertical?"vertical":"horizontal";return r.direction.value===t}),te=f(()=>{const t={transitionDuration:`${e.swiping?0:a.duration}ms`,transform:`translate${a.vertical?"Y":"X"}(${e.offset}px)`};if(c.value){const o=a.vertical?"height":"width",n=a.vertical?"width":"height";t[o]=`${S.value}px`,t[n]=a[n]?`${a[n]}px`:""}return t}),ae=t=>{const{active:o}=e;return t?a.loop?E(o+t,-1,i.value):E(o+t,0,k.value):o},N=(t,o=0)=>{let n=t*c.value;a.loop||(n=Math.min(n,-g.value));let v=o-n;return a.loop||(v=E(v,g.value,0)),v},w=({pace:t=0,offset:o=0,emitChange:n})=>{if(i.value<=1)return;const{active:v}=e,l=ae(t),x=N(l,o);if(a.loop){if(m[0]&&x!==g.value){const D=x<g.value;m[0].setOffset(D?S.value:0)}if(m[i.value-1]&&x!==0){const D=x>0;m[i.value-1].setOffset(D?-S.value:0)}}e.active=l,e.offset=x,n&&l!==v&&y("change",I.value)},z=()=>{e.swiping=!0,e.active<=-1?w({pace:i.value}):e.active>=i.value&&w({pace:-i.value})},ie=()=>{z(),r.reset(),A(()=>{e.swiping=!1,w({pace:-1,emitChange:!0})})},V=()=>{z(),r.reset(),A(()=>{e.swiping=!1,w({pace:1,emitChange:!0})})};let Y;const b=()=>clearTimeout(Y),T=()=>{b(),a.autoplay>0&&i.value>1&&(Y=setTimeout(()=>{V(),T()},+a.autoplay))},p=(t=+a.initialSwipe)=>{if(!u.value)return;const o=()=>{var n,v;if(!L(u)){const l={width:u.value.offsetWidth,height:u.value.offsetHeight};e.rect=l,e.width=+((n=a.width)!=null?n:l.width),e.height=+((v=a.height)!=null?v:l.height)}i.value&&(t=Math.min(i.value-1,t)),e.active=t,e.swiping=!0,e.offset=N(t),m.forEach(l=>{l.setOffset(0)}),T()};L(u)?G().then(o):o()},H=()=>p(e.active);let X;const ne=t=>{!a.touchable||(r.start(t),X=Date.now(),b(),z())},oe=t=>{a.touchable&&e.swiping&&(r.move(t),B.value&&(!a.loop&&(e.active===0&&s.value>0||e.active===i.value-1&&s.value<0)||(de(t,a.stopPropagation),w({offset:s.value}))))},_=()=>{if(!a.touchable||!e.swiping)return;const t=Date.now()-X,o=s.value/t;if((Math.abs(o)>.25||Math.abs(s.value)>c.value/2)&&B.value){const v=a.vertical?r.offsetY.value:r.offsetX.value;let l=0;a.loop?l=v>0?s.value>0?-1:1:0:l=-Math[s.value>0?"ceil":"floor"](s.value/c.value),w({pace:l,emitChange:!0})}else s.value&&w({pace:0});e.swiping=!1,T()},se=(t,o={})=>{z(),r.reset(),A(()=>{let n;a.loop&&t===i.value?n=e.active===0?0:t:n=t%i.value,o.immediate?A(()=>{e.swiping=!1}):e.swiping=!1,w({pace:n-e.active,emitChange:!0})})},ce=(t,o)=>{const n=o===I.value,v=n?{backgroundColor:a.indicatorColor}:void 0;return P("i",{style:v,class:$("indicator",{active:n})},null)},le=()=>{if(d.indicator)return d.indicator({active:I.value,total:i.value});if(a.showIndicators&&i.value>1)return P("div",{class:$("indicators",{vertical:a.vertical})},[Array(i.value).fill("").map(ce)])};return K({prev:ie,next:V,state:e,resize:H,swipeTo:se}),O({size:c,props:a,count:i,activeIndicator:I}),C(()=>a.initialSwipe,t=>p(+t)),C(i,()=>p(e.active)),C(()=>a.autoplay,T),C([re,ve],H),C(fe(),t=>{t==="visible"?T():b()}),j(p),pe(()=>p(e.active)),we(()=>p(e.active)),ye(b),Se(b),he("touchmove",oe,{target:h}),()=>{var t;return P("div",{ref:u,class:$()},[P("div",{ref:h,style:te.value,class:$("track",{vertical:a.vertical}),onTouchstartPassive:ne,onTouchend:_,onTouchcancel:_},[(t=d.default)==null?void 0:t.call(d)]),le()])}}}),xe=J(Te),Ee=xe,[Ce,Pe]=F("swipe-item"),Ie=Q({name:Ce,setup(a,{slots:y}){let d;const u=U({offset:0,inited:!1,mounted:!1}),{parent:h,index:e}=me(ee);if(!h)return;const r=f(()=>{const i={},{vertical:c}=h.props;return h.size.value&&(i[c?"height":"width"]=`${h.size.value}px`),u.offset&&(i.transform=`translate${c?"Y":"X"}(${u.offset}px)`),i}),m=f(()=>{const{loop:i,lazyRender:c}=h.props;if(!c||d)return!0;if(!u.mounted)return!1;const s=h.activeIndicator.value,g=h.count.value-1,k=s===0&&i?g:s-1,S=s===g&&i?0:s+1;return d=e.value===s||e.value===k||e.value===S,d}),O=i=>{u.offset=i};return j(()=>{G(()=>{u.mounted=!0})}),K({setOffset:O}),()=>{var i;return P("div",{class:Pe(),style:r.value},[m.value?(i=y.default)==null?void 0:i.call(y):null])}}}),ze=J(Ie),Re=ze;export{xe as S,Ee as V,ze as a,Re as b};
|