index.cd21c278.js 5.0 KB

1
  1. import{E as N,d as S,J as j,ab as w,U as b,W as P,V as q,X as f,a3 as g,ak as p,i as B,a8 as J,aB as Q,aQ as h,as as K,a0 as te,b6 as E,O as ae}from"./index.6b776f4b.js";import{s as z,t as G,p as L,a as R,g as X,b as ne}from"./utils.98263d8b.js";import{P as A}from"./index.e13f12a0.js";const[ue]=N("time-picker");var U=S({name:ue,props:j({},z,{minHour:w(0),maxHour:w(23),minMinute:w(0),maxMinute:w(59),modelValue:String}),emits:["confirm","cancel","change","update:modelValue"],setup(t,{emit:c,slots:$}){const d=u=>{const{minHour:e,maxHour:a,maxMinute:n,minMinute:r}=t;u||(u=`${h(e)}:${h(r)}`);let[i,m]=u.split(":");return i=h(K(+i,+e,+a)),m=h(K(+m,+r,+n)),`${i}:${m}`},l=b(),o=b(d(t.modelValue)),M=P(()=>[{type:"hour",range:[+t.minHour,+t.maxHour]},{type:"minute",range:[+t.minMinute,+t.maxMinute]}]),O=P(()=>M.value.map(({type:u,range:e})=>{let a=G(e[1]-e[0]+1,n=>h(e[0]+n));return t.filter&&(a=t.filter(u,a)),{type:u,values:a}})),x=P(()=>O.value.map(u=>({values:u.values.map(e=>t.formatter(u.type,e))}))),k=()=>{const u=o.value.split(":"),e=[t.formatter("hour",u[0]),t.formatter("minute",u[1])];f(()=>{var a;(a=l.value)==null||a.setValues(e)})},D=()=>{const[u,e]=l.value.getIndexes(),[a,n]=O.value,r=a.values[u]||a.values[0],i=n.values[e]||n.values[0];o.value=d(`${r}:${i}`),k()},V=()=>c("confirm",o.value),I=()=>c("cancel"),_=()=>{D(),f(()=>{f(()=>c("change",o.value))})};return q(()=>{k(),f(D)}),g(x,k),g(()=>[t.filter,t.maxHour,t.minMinute,t.maxMinute],D),g(()=>t.minHour,()=>{f(D)}),g(o,u=>c("update:modelValue",u)),g(()=>t.modelValue,u=>{u=d(u),u!==o.value&&(o.value=u,k())}),p({getPicker:()=>l.value&&L(l.value,D)}),()=>B(A,J({ref:l,columns:x.value,onChange:_,onCancel:I,onConfirm:V},Q(t,R)),$)}});const Z=new Date().getFullYear(),[oe]=N("date-picker");var W=S({name:oe,props:j({},z,{type:te("datetime"),modelValue:Date,minDate:{type:Date,default:()=>new Date(Z-10,0,1),validator:E},maxDate:{type:Date,default:()=>new Date(Z+10,11,31),validator:E}}),emits:["confirm","cancel","change","update:modelValue"],setup(t,{emit:c,slots:$}){const d=e=>{if(E(e)){const a=K(e.getTime(),t.minDate.getTime(),t.maxDate.getTime());return new Date(a)}},l=b(),o=b(d(t.modelValue)),M=(e,a)=>{const n=t[`${e}Date`],r=n.getFullYear();let i=1,m=1,v=0,y=0;return e==="max"&&(i=12,m=X(a.getFullYear(),a.getMonth()+1),v=23,y=59),a.getFullYear()===r&&(i=n.getMonth()+1,a.getMonth()+1===i&&(m=n.getDate(),a.getDate()===m&&(v=n.getHours(),a.getHours()===v&&(y=n.getMinutes())))),{[`${e}Year`]:r,[`${e}Month`]:i,[`${e}Date`]:m,[`${e}Hour`]:v,[`${e}Minute`]:y}},O=P(()=>{const{maxYear:e,maxDate:a,maxMonth:n,maxHour:r,maxMinute:i}=M("max",o.value||t.minDate),{minYear:m,minDate:v,minMonth:y,minHour:Y,minMinute:F}=M("min",o.value||t.minDate);let s=[{type:"year",range:[m,e]},{type:"month",range:[y,n]},{type:"day",range:[v,a]},{type:"hour",range:[Y,r]},{type:"minute",range:[F,i]}];switch(t.type){case"date":s=s.slice(0,3);break;case"year-month":s=s.slice(0,2);break;case"month-day":s=s.slice(1,3);break;case"datehour":s=s.slice(0,4);break}if(t.columnsOrder){const C=t.columnsOrder.concat(s.map(H=>H.type));s.sort((H,T)=>C.indexOf(H.type)-C.indexOf(T.type))}return s}),x=P(()=>O.value.map(({type:e,range:a})=>{let n=G(a[1]-a[0]+1,r=>h(a[0]+r));return t.filter&&(n=t.filter(e,n)),{type:e,values:n}})),k=P(()=>x.value.map(e=>({values:e.values.map(a=>t.formatter(e.type,a))}))),D=()=>{const e=o.value||t.minDate,{formatter:a}=t,n=x.value.map(r=>{switch(r.type){case"year":return a("year",`${e.getFullYear()}`);case"month":return a("month",h(e.getMonth()+1));case"day":return a("day",h(e.getDate()));case"hour":return a("hour",h(e.getHours()));case"minute":return a("minute",h(e.getMinutes()));default:return""}});f(()=>{var r;(r=l.value)==null||r.setValues(n)})},V=()=>{const{type:e}=t,a=l.value.getIndexes(),n=s=>{let C=0;x.value.forEach((T,ee)=>{s===T.type&&(C=ee)});const{values:H}=x.value[C];return ne(H[a[C]])};let r,i,m;e==="month-day"?(r=(o.value||t.minDate).getFullYear(),i=n("month"),m=n("day")):(r=n("year"),i=n("month"),m=e==="year-month"?1:n("day"));const v=X(r,i);m=m>v?v:m;let y=0,Y=0;e==="datehour"&&(y=n("hour")),e==="datetime"&&(y=n("hour"),Y=n("minute"));const F=new Date(r,i-1,m,y,Y);o.value=d(F)},I=()=>{c("update:modelValue",o.value),c("confirm",o.value)},_=()=>c("cancel"),u=()=>{V(),f(()=>{f(()=>c("change",o.value))})};return q(()=>{D(),f(V)}),g(k,D),g(o,(e,a)=>c("update:modelValue",a?e:null)),g(()=>[t.filter,t.maxDate],V),g(()=>t.minDate,()=>{f(V)}),g(()=>t.modelValue,e=>{var a;e=d(e),e&&e.valueOf()!==((a=o.value)==null?void 0:a.valueOf())&&(o.value=e)}),p({getPicker:()=>l.value&&L(l.value,V)}),()=>B(A,J({ref:l,columns:k.value,onChange:u,onCancel:_,onConfirm:I},Q(t,R)),$)}});const[re,le]=N("datetime-picker"),ie=Object.keys(U.props),me=Object.keys(W.props),se=j({},U.props,W.props,{modelValue:[String,Date]});var ce=S({name:re,props:se,setup(t,{attrs:c,slots:$}){const d=b();return p({getPicker:()=>{var l;return(l=d.value)==null?void 0:l.getPicker()}}),()=>{const l=t.type==="time",o=l?U:W,M=Q(t,l?ie:me);return B(o,J({ref:d,class:le()},M,c),$)}}});const he=ae(ce);export{he as D};