import{t as B,a1 as be,N as E,at as q,d as I,z as K,au as M,av as _,R as x,an as ge,C as ne,W as ae,aw as Te,a0 as oe,c as r,a4 as le,ax as Z,x as ie,E as ce,w as U,v as pe,u as Oe,y,ay as Ce,Z as Y,aq as L,L as ke,ak as J,_ as ye,az as xe,D as Ee}from"./index.13ca4bcb.js";import{T as Pe,a as we}from"./index.4cd47248.js";const[Se,g,Q]=B("picker"),se=e=>e.find(a=>!a.disabled)||e[0];function Ne(e,a){const n=e[0];if(n){if(Array.isArray(n))return"multiple";if(a.children in n)return"cascade"}return"default"}function G(e,a){a=q(a,0,e.length);for(let n=a;n=0;n--)if(!e[n].disabled)return n;return 0}const X=(e,a,n)=>a!==void 0&&!!e.find(s=>s[n.value]===a);function W(e,a,n){const s=e.findIndex(f=>f[n.value]===a),l=G(e,s);return e[l]}function De(e,a,n){const s=[];let l={[a.children]:e},f=0;for(;l&&l[a.children];){const v=l[a.children],d=n.value[f];if(l=be(d)?W(v,d,a):void 0,!l&&v.length){const u=se(v)[a.value];l=W(v,u,a)}f++,s.push(v)}return s}function He(e){const{transform:a}=window.getComputedStyle(e),n=a.slice(7,a.length-1).split(", ")[5];return Number(n)}function Me(e){return E({text:"text",value:"value",children:"children"},e)}const ee=200,te=300,_e=15,[ue,j]=B("picker-column"),re=Symbol(ue);var Be=I({name:ue,props:{value:K,fields:M(Object),options:_(),readonly:Boolean,allowHtml:Boolean,optionHeight:M(Number),swipeDuration:M(K),visibleOptionNum:M(K)},emits:["change","clickOption"],setup(e,{emit:a,slots:n}){let s,l,f,v,d;const u=x(),b=x(),m=x(0),h=x(0),O=ge(),P=()=>e.options.length,C=()=>e.optionHeight*(+e.visibleOptionNum-1)/2,T=i=>{const t=G(e.options,i),o=-t*e.optionHeight,c=()=>{const p=e.options[t][e.fields.value];p!==e.value&&a("change",p)};s&&o!==m.value?d=c:c(),m.value=o},k=()=>e.readonly||!e.options.length,$=i=>{s||k()||(d=null,h.value=ee,T(i),a("clickOption",e.options[i]))},w=i=>q(Math.round(-i/e.optionHeight),0,P()-1),R=(i,t)=>{const o=Math.abs(i/t);i=m.value+o/.003*(i<0?-1:1);const c=w(i);h.value=+e.swipeDuration,T(c)},H=()=>{s=!1,h.value=0,d&&(d(),d=null)},A=i=>{if(!k()){if(O.start(i),s){const t=He(b.value);m.value=Math.min(0,t-C())}h.value=0,l=m.value,f=Date.now(),v=l,d=null}},F=i=>{if(k())return;O.move(i),O.isVertical()&&(s=!0,le(i,!0)),m.value=q(l+O.deltaY.value,-(P()*e.optionHeight),e.optionHeight);const t=Date.now();t-f>te&&(f=t,v=m.value)},S=()=>{if(k())return;const i=m.value-v,t=Date.now()-f;if(t_e){R(i,t);return}const c=w(m.value);h.value=ee,T(c),setTimeout(()=>{s=!1},0)},N=()=>{const i={height:`${e.optionHeight}px`};return e.options.map((t,o)=>{const c=t[e.fields.text],{disabled:p}=t,D=t[e.fields.value],ve={role:"button",style:i,tabindex:p?-1:0,class:[j("item",{disabled:p,selected:D===e.value}),t.className],onClick:()=>$(o)},he={class:"van-ellipsis",[e.allowHtml?"innerHTML":"textContent"]:c};return r("li",ve,[n.option?n.option(t):r("div",he,null)])})};return ne(re),ae({stopMomentum:H}),Te(()=>{const i=e.options.findIndex(c=>c[e.fields.value]===e.value),o=-G(e.options,i)*e.optionHeight;m.value=o}),oe("touchmove",F,{target:u}),()=>r("div",{ref:u,class:j(),onTouchstartPassive:A,onTouchend:S,onTouchcancel:S},[r("ul",{ref:b,style:{transform:`translate3d(0, ${m.value+C()}px, 0)`,transitionDuration:`${h.value}ms`,transitionProperty:h.value?"all":"none"},class:j("wrapper"),onTransitionend:H},[N()])])}});const[Ie]=B("picker-toolbar"),V={title:String,cancelButtonText:String,confirmButtonText:String},Ve=["cancel","confirm","title","toolbar"],$e=Object.keys(V);var de=I({name:Ie,props:V,emits:["confirm","cancel"],setup(e,{emit:a,slots:n}){const s=()=>{if(n.title)return n.title();if(e.title)return r("div",{class:[g("title"),"van-ellipsis"]},[e.title])},l=()=>a("cancel"),f=()=>a("confirm"),v=()=>{const u=e.cancelButtonText||Q("cancel");return r("button",{type:"button",class:[g("cancel"),Z],onClick:l},[n.cancel?n.cancel():u])},d=()=>{const u=e.confirmButtonText||Q("confirm");return r("button",{type:"button",class:[g("confirm"),Z],onClick:f},[n.confirm?n.confirm():u])};return()=>r("div",{class:g("toolbar")},[n.toolbar?n.toolbar():[v(),s(),d()]])}});const[me,z]=B("picker-group"),fe=Symbol(me),Re=E({tabs:_()},V);var Le=I({name:me,props:Re,emits:["confirm","cancel"],setup(e,{emit:a,slots:n}){const{children:s,linkChildren:l}=ie(fe);l();const f=()=>{a("confirm",s.map(d=>d.confirm()))},v=()=>a("cancel");return()=>{var d;const u=(d=n.default)==null?void 0:d.call(n);return r("div",{class:z()},[r(de,ce(e,{onConfirm:f,onCancel:v}),null),r(Pe,{shrink:!0,class:z("tabs"),animated:!0},{default:()=>[e.tabs.map((b,m)=>r(we,{title:b,titleClass:z("tab-title")},{default:()=>[u==null?void 0:u[m]]}))]})])}}});const Ae=E({loading:Boolean,readonly:Boolean,allowHtml:Boolean,optionHeight:U(44),showToolbar:pe,swipeDuration:U(1e3),visibleOptionNum:U(6)},V),Fe=E({},Ae,{columns:_(),modelValue:_(),toolbarPosition:Oe("top"),columnsFieldNames:Object});var Ke=I({name:Se,props:Fe,emits:["confirm","cancel","change","clickOption","update:modelValue"],setup(e,{emit:a,slots:n}){const s=x(),l=x(e.modelValue.slice(0)),{parent:f}=ne(fe),{children:v,linkChildren:d}=ie(re);d();const u=y(()=>Me(e.columnsFieldNames)),b=y(()=>Ce(e.optionHeight)),m=y(()=>Ne(e.columns,u.value)),h=y(()=>{const{columns:t}=e;switch(m.value){case"multiple":return t;case"cascade":return De(t,u.value,l);default:return[t]}}),O=y(()=>h.value.some(t=>t.length)),P=y(()=>h.value.map((t,o)=>W(t,l.value[o],u.value))),C=(t,o)=>{if(l.value[t]!==o){const c=l.value.slice(0);c[t]=o,l.value=c}},T=()=>({selectedValues:l.value.slice(0),selectedOptions:P.value}),k=(t,o)=>{C(o,t),m.value==="cascade"&&l.value.forEach((c,p)=>{const D=h.value[p];X(D,c,u.value)||C(p,D.length?D[0][u.value.value]:void 0)}),a("change",E({columnIndex:o},T()))},$=(t,o)=>a("clickOption",E({columnIndex:o,currentOption:t},T())),w=()=>{v.forEach(o=>o.stopMomentum());const t=T();return ye(()=>{a("confirm",t)}),t},R=()=>a("cancel",T()),H=()=>h.value.map((t,o)=>r(Be,{value:l.value[o],fields:u.value,options:t,readonly:e.readonly,allowHtml:e.allowHtml,optionHeight:b.value,swipeDuration:e.swipeDuration,visibleOptionNum:e.visibleOptionNum,onChange:c=>k(c,o),onClickOption:c=>$(c,o)},{option:n.option})),A=t=>{if(O.value){const o={height:`${b.value}px`},c={backgroundSize:`100% ${(t-b.value)/2}px`};return[r("div",{class:g("mask"),style:c},null),r("div",{class:[xe,g("frame")],style:o},null)]}},F=()=>{const t=b.value*+e.visibleOptionNum,o={height:`${t}px`};return r("div",{ref:s,class:g("columns"),style:o},[H(),A(t)])},S=()=>{if(e.showToolbar&&!f)return r(de,ce(J(e,$e),{onConfirm:w,onCancel:R}),J(n,Ve))};Y(h,t=>{t.forEach((o,c)=>{o.length&&!X(o,l.value[c],u.value)&&C(c,se(o)[u.value.value])})},{immediate:!0});let N;return Y(()=>e.modelValue,t=>{!L(t,l.value)&&!L(t,N)&&(l.value=t.slice(0))},{deep:!0}),Y(l,t=>{L(t,e.modelValue)||(N=t.slice(0),a("update:modelValue",N))},{immediate:!0}),oe("touchmove",le,{target:s}),ae({confirm:w,getSelectedOptions:()=>P.value}),()=>{var t,o;return r("div",{class:g()},[e.toolbarPosition==="top"?S():null,e.loading?r(ke,{class:g("loading")},null):null,(t=n["columns-top"])==null?void 0:t.call(n),F(),(o=n["columns-bottom"])==null?void 0:o.call(n),e.toolbarPosition==="bottom"?S():null])}}});const je=Ee(Ke);export{je as P,Ae as p,Le as s};