mirror of
https://gitee.com/vant-contrib/vant.git
synced 2025-04-06 03:57:59 +08:00
2 lines
2.8 KiB
JavaScript
2 lines
2.8 KiB
JavaScript
import{c as j,E as q,n as J,h as K,r as _,l as O}from"./use-translate.d2900b8c.js";import{n as A,m as B,c as Q,t as W,a as Z,w as $}from"./with-install.19a35764.js";import{u as x}from"./use-refs.b3168e03.js";import{u as ee}from"./use-touch.04ca7093.js";import{I as F}from"./index.b70c9b40.js";import{z as te,C as oe,D as ae,e as f}from"./vue-libs.b44bc779.js";const[le,m]=j("rate");function se(t,s,n,r){return t>=s?{status:"full",value:1}:t+.5>=s&&n&&!r?{status:"half",value:.5}:t+1>=s&&n&&r?{status:"half",value:Math.round((t-s+1)*1e10)/1e10}:{status:"void",value:0}}const ne={size:A,icon:B("star"),color:String,count:Q(5),gutter:A,readonly:Boolean,disabled:Boolean,voidIcon:B("star-o"),allowHalf:Boolean,voidColor:String,touchable:W,iconPrefix:String,modelValue:Z(0),disabledColor:String},ie=te({name:le,props:ne,emits:["change","update:modelValue"],setup(t,{emit:s}){const n=ee(),[r,p]=x(),h=oe(),P=()=>t.readonly||t.disabled||!t.touchable,X=ae(()=>Array(+t.count).fill("").map((o,e)=>se(t.modelValue,e+1,t.allowHalf,t.readonly)));let l,c,g=Number.MAX_SAFE_INTEGER,b=Number.MIN_SAFE_INTEGER;const S=()=>{c=_(h);const o=r.value.map(_);l=[],o.forEach((e,a)=>{g=Math.min(e.top,g),b=Math.max(e.top,b),t.allowHalf?l.push({score:a+.5,left:e.left,top:e.top,height:e.height},{score:a+1,left:e.left+e.width/2,top:e.top,height:e.height}):l.push({score:a+1,left:e.left,top:e.top,height:e.height})})},V=(o,e)=>{for(let a=l.length-1;a>0;a--)if(e>=c.top&&e<=c.bottom){if(o>l[a].left&&e>=l[a].top&&e<=l[a].top+l[a].height)return l[a].score}else{const u=e<c.top?g:b;if(o>l[a].left&&l[a].top===u)return l[a].score}return t.allowHalf?.5:1},I=o=>{!t.disabled&&!t.readonly&&o!==t.modelValue&&(s("update:modelValue",o),s("change",o))},D=o=>{P()||(n.start(o),S())},G=o=>{if(!P()&&(n.move(o),n.isHorizontal())){const{clientX:e,clientY:a}=o.touches[0];O(o),I(V(e,a))}},Y=(o,e)=>{const{icon:a,size:u,color:y,count:C,gutter:E,voidIcon:N,disabled:i,voidColor:T,allowHalf:w,iconPrefix:k,disabledColor:z}=t,v=e+1,R=o.status==="full",d=o.status==="void",L=w&&o.value>0&&o.value<1;let H;E&&v!==+C&&(H={paddingRight:K(E)});const U=M=>{S(),I(w?V(M.clientX,M.clientY):v)};return f("div",{key:e,ref:p(e),role:"radio",style:H,class:m("item"),tabindex:i?void 0:0,"aria-setsize":C,"aria-posinset":v,"aria-checked":!d,onClick:U},[f(F,{size:u,name:R?a:N,class:m("icon",{disabled:i,full:R}),color:i?z:R?y:T,classPrefix:k},null),L&&f(F,{size:u,style:{width:o.value+"em"},name:d?N:a,class:m("icon",["half",{disabled:i,full:!d}]),color:i?z:d?T:y,classPrefix:k},null)])};return q(()=>t.modelValue),J("touchmove",G,{target:h}),()=>f("div",{ref:h,role:"radiogroup",class:m({readonly:t.readonly,disabled:t.disabled}),tabindex:t.disabled?void 0:0,"aria-disabled":t.disabled,"aria-readonly":t.readonly,onTouchstartPassive:D},[X.value.map(Y)])}}),re=$(ie),ge=re;export{ge as V};
|