| 1 | import{aD as V,ao as ye,aE as we,R as T,aF as Ce,t as D,d as H,z as $,v as E,y as x,c as b,a1 as X,aG as Se,au as U,Z as _,$ as Te,W as G,u as ke,w as O,Q as le,am as Ie,x as Re,r as xe,ay as Be,aH as _e,_ as B,aI as $e,aJ as Pe,aK as Ae,a0 as Ne,as as ze,U as p,G as Oe,I as Le,aL as ee,E as Ee,ak as De,al as te,aM as He,aN as Me,N as We,ae as Ze,O as Fe,C as Ue,aO as Ke,X as Ve,ac as Xe,aP as Ge,D as ie}from"./index.13ca4bcb.js";import{T as Ye}from"./use-tab-status.45bc1956.js";import{S as je,a as qe}from"./index.510ab853.js";import{S as Je}from"./index.13b30705.js";function Qe(e,l,o){let s=0;const a=e.scrollLeft,f=o===0?1:Math.round(o*1e3/16);function d(){e.scrollLeft+=(l-a)/f,++s<f&&V(d)}d()}function pe(e,l,o,s){let a=ye(e);const f=a<l,d=o===0?1:Math.round(o*1e3/16),v=(l-a)/d;function r(){a+=v,(f&&a>l||!f&&a<l)&&(a=l),we(e,a),f&&a<l||!f&&a>l?V(r):s&&V(s)}r()}function et(){const e=T([]),l=[];return Ce(()=>{e.value=[]}),[e,s=>(l[s]||(l[s]=a=>{e.value[s]=a}),l[s])]}const[tt,ne]=D("tab");var nt=H({name:tt,props:{id:String,dot:Boolean,type:String,color:String,title:String,badge:$,shrink:Boolean,isActive:Boolean,disabled:Boolean,controls:String,scrollable:Boolean,activeColor:String,inactiveColor:String,showZeroBadge:E},setup(e,{slots:l}){const o=x(()=>{const a={},{type:f,color:d,disabled:v,isActive:r,activeColor:w,inactiveColor:h}=e;d&&f==="card"&&(a.borderColor=d,v||(r?a.backgroundColor=d:a.color=d));const S=r?w:h;return S&&(a.color=S),a}),s=()=>{const a=b("span",{class:ne("text",{ellipsis:!e.scrollable})},[l.title?l.title():e.title]);return e.dot||X(e.badge)&&e.badge!==""?b(Se,{dot:e.dot,content:e.badge,showZero:e.showZeroBadge},{default:()=>[a]}):a};return()=>b("div",{id:e.id,role:"tab",class:[ne([e.type,{grow:e.scrollable&&!e.shrink,shrink:e.shrink,active:e.isActive,disabled:e.disabled}])],style:o.value,tabindex:e.disabled?void 0:e.isActive?0:-1,"aria-selected":e.isActive,"aria-disabled":e.disabled||void 0,"aria-controls":e.controls},[s()])}});const[at,ae]=D("tabs");var lt=H({name:at,props:{count:U(Number),inited:Boolean,animated:Boolean,duration:U($),swipeable:Boolean,lazyRender:Boolean,currentIndex:U(Number)},emits:["change"],setup(e,{emit:l,slots:o}){const s=T(),a=v=>l("change",v),f=()=>{var v;const r=(v=o.default)==null?void 0:v.call(o);return e.animated||e.swipeable?b(je,{ref:s,loop:!1,class:ae("track"),duration:+e.duration*1e3,touchable:e.swipeable,lazyRender:e.lazyRender,showIndicators:!1,onChange:a},{default:()=>[r]}):r},d=v=>{const r=s.value;r&&r.state.active!==v&&r.swipeTo(v,{immediate:!e.inited})};return _(()=>e.currentIndex,d),Te(()=>{d(e.currentIndex)}),G({swipeRef:s}),()=>b("div",{class:ae("content",{animated:e.animated||e.swipeable})},[f()])}});const[oe,L]=D("tabs"),it={type:ke("line"),color:String,border:Boolean,sticky:Boolean,shrink:Boolean,active:O(0),duration:O(.3),animated:Boolean,ellipsis:E,swipeable:Boolean,scrollspy:Boolean,offsetTop:O(0),background:String,lazyRender:E,lineWidth:$,lineHeight:$,beforeChange:Function,swipeThreshold:O(5),titleActiveColor:String,titleInactiveColor:String},re=Symbol(oe);var ot=H({name:oe,props:it,emits:["change","scroll","rendered","clickTab","update:active"],setup(e,{emit:l,slots:o}){let s,a,f;const d=T(),v=T(),r=T(),w=T(),h=le(),C=Ie(d),[S,M]=et(),{children:u,linkChildren:W}=Re(re),c=xe({inited:!1,position:"",lineStyle:{},currentIndex:-1}),P=x(()=>u.length>e.swipeThreshold||!e.ellipsis||e.shrink),Z=x(()=>({borderColor:e.color,background:e.background})),k=(t,n)=>{var i;return(i=t.name)!=null?i:n},Y=x(()=>{const t=u[c.currentIndex];if(t)return k(t,c.currentIndex)}),F=x(()=>Be(e.offsetTop)),j=x(()=>e.sticky?F.value+s:0),A=t=>{const n=v.value,i=S.value;if(!P.value||!n||!i||!i[c.currentIndex])return;const m=i[c.currentIndex].$el,g=m.offsetLeft-(n.offsetWidth-m.offsetWidth)/2;Qe(n,g,t?0:+e.duration)},I=()=>{const t=c.inited;B(()=>{const n=S.value;if(!n||!n[c.currentIndex]||e.type!=="line"||ze(d.value))return;const i=n[c.currentIndex].$el,{lineWidth:m,lineHeight:g}=e,y=i.offsetLeft+i.offsetWidth/2,R={width:p(m),backgroundColor:e.color,transform:`translateX(${y}px) translateX(-50%)`};if(t&&(R.transitionDuration=`${e.duration}s`),X(g)){const Q=p(g);R.height=Q,R.borderRadius=Q}c.lineStyle=R})},se=t=>{const n=t<c.currentIndex?-1:1;for(;t>=0&&t<u.length;){if(!u[t].disabled)return t;t+=n}},N=(t,n)=>{const i=se(t);if(!X(i))return;const m=u[i],g=k(m,i),y=c.currentIndex!==null;c.currentIndex!==i&&(c.currentIndex=i,n||A(),I()),g!==e.active&&(l("update:active",g),y&&l("change",g,m.title)),f&&!e.scrollspy&&Le(Math.ceil(ee(d.value)-F.value))},z=(t,n)=>{const i=u.find((g,y)=>k(g,y)===t),m=i?u.indexOf(i):0;N(m,n)},q=(t=!1)=>{if(e.scrollspy){const n=u[c.currentIndex].$el;if(n&&C.value){const i=ee(n,C.value)-j.value;a=!0,pe(C.value,i,t?0:+e.duration,()=>{a=!1})}}},ce=(t,n,i)=>{const{title:m,disabled:g}=u[n],y=k(u[n],n);g||(He(e.beforeChange,{args:[y],done:()=>{N(n),q()}}),Me(t)),l("clickTab",{name:y,title:m,event:i,disabled:g})},de=t=>{f=t.isFixed,l("scroll",t)},ue=t=>{B(()=>{z(t),q(!0)})},fe=()=>{for(let t=0;t<u.length;t++){const{top:n}=te(u[t].$el);if(n>j.value)return t===0?0:t-1}return u.length-1},ve=()=>{if(e.scrollspy&&!a){const t=fe();N(t)}},be=()=>u.map((t,n)=>b(nt,Ee({key:t.id,id:`${h}-${n}`,ref:M(n),type:e.type,color:e.color,style:t.titleStyle,class:t.titleClass,shrink:e.shrink,isActive:n===c.currentIndex,controls:t.id,scrollable:P.value,activeColor:e.titleActiveColor,inactiveColor:e.titleInactiveColor,onClick:i=>ce(t,n,i)},De(t,["dot","badge","title","disabled","showZeroBadge"])),{title:t.$slots.title})),he=()=>{if(e.type==="line"&&u.length)return b("div",{class:L("line"),style:c.lineStyle},null)},J=()=>{var t,n,i;const{type:m,border:g,sticky:y}=e,R=[b("div",{ref:y?void 0:r,class:[L("wrap"),{[Oe]:m==="line"&&g}]},[b("div",{ref:v,role:"tablist",class:L("nav",[m,{shrink:e.shrink,complete:P.value}]),style:Z.value,"aria-orientation":"horizontal"},[(t=o["nav-left"])==null?void 0:t.call(o),be(),he(),(n=o["nav-right"])==null?void 0:n.call(o)])]),(i=o["nav-bottom"])==null?void 0:i.call(o)];return y?b("div",{ref:r},[R]):R};_([()=>e.color,_e],I),_(()=>e.active,t=>{t!==Y.value&&z(t)}),_(()=>u.length,()=>{c.inited&&(z(e.active),I(),B(()=>{A(!0)}))});const ge=()=>{z(e.active,!0),B(()=>{c.inited=!0,r.value&&(s=te(r.value).height),A(!0)})},me=(t,n)=>l("rendered",t,n);return G({resize:()=>{I(),B(()=>{var t,n;return(n=(t=w.value)==null?void 0:t.swipeRef.value)==null?void 0:n.resize()})},scrollTo:ue}),$e(I),Pe(I),Ae(ge),Ne("scroll",ve,{target:C,passive:!0}),W({id:h,props:e,setLine:I,onRendered:me,currentName:Y,scrollIntoView:A}),()=>b("div",{ref:d,class:L([e.type])},[e.sticky?b(Je,{container:d.value,offsetTop:F.value,onScroll:de},{default:()=>[J()]}):J(),b(lt,{ref:w,count:u.length,inited:c.inited,animated:e.animated,duration:e.duration,swipeable:e.swipeable,lazyRender:e.lazyRender,currentIndex:c.currentIndex,onChange:N},{default:()=>{var t;return[(t=o.default)==null?void 0:t.call(o)]}})])}});const[rt,K]=D("tab"),st=We({},Ze,{dot:Boolean,name:$,badge:$,title:String,disabled:Boolean,titleClass:Fe,titleStyle:[String,Object],showZeroBadge:E});var ct=H({name:rt,props:st,setup(e,{slots:l}){const o=le(),s=T(!1),{parent:a,index:f}=Ue(re);if(!a)return;const d=()=>{var h;return(h=e.name)!=null?h:f.value},v=()=>{s.value=!0,a.props.lazyRender&&B(()=>{a.onRendered(d(),e.title)})},r=x(()=>{const h=d()===a.currentName.value;return h&&!s.value&&v(),h}),w=T(!r.value);return _(r,h=>{h?w.value=!1:Ke(()=>{w.value=!0})}),_(()=>e.title,()=>{a.setLine(),a.scrollIntoView()}),Ve(Ye,r),()=>{var h;const C=`${a.id}-${f.value}`,{animated:S,swipeable:M,scrollspy:u,lazyRender:W}=a.props;if(!l.default&&!S)return;const c=u||r.value;if(S||M)return b(qe,{id:o,role:"tabpanel",class:K("panel-wrapper",{inactive:w.value}),tabindex:r.value?0:-1,"aria-hidden":!r.value,"aria-labelledby":C},{default:()=>{var k;return[b("div",{class:K("panel")},[(k=l.default)==null?void 0:k.call(l)])]}});const Z=s.value||u||!W?(h=l.default)==null?void 0:h.call(l):null;return G({id:o}),Xe(b("div",{id:o,role:"tabpanel",class:K("panel"),tabindex:c?0:-1,"aria-labelledby":C},[Z]),[[Ge,c]])}}});const ht=ie(ct),gt=ie(ot);export{gt as T,ht as a,et as u};
 |