Slider-e8b4d094-1720699367816.js 17 KB

12
  1. import{a5 as We,ac as qe,ah as D,af as n,ai as m,ag as U,dM as he,d_ as Ge,d$ as Je,d as Qe,ab as Ze,ao as ge,r as k,dN as eo,U as w,al as oo,ak as ao,A as fe,p as to,ap as ve,dP as no,dO as ee,ad as f,dR as ro,dS as io,dF as lo,dU as so,_ as co,dX as j,aw as O,ax as _,S as Z}from"./index-b48b51d2-1720699367816.js";const uo={railHeight:"4px",railWidthVertical:"4px",handleSize:"18px",dotHeight:"8px",dotWidth:"8px",dotBorderRadius:"4px"},ho=t=>{const i="rgba(0, 0, 0, .85)",y="0 2px 8px 0 rgba(0, 0, 0, 0.12)",{railColor:v,primaryColor:s,baseColor:d,cardColor:z,modalColor:R,popoverColor:L,borderRadius:X,fontSize:M,opacityDisabled:B}=t;return Object.assign(Object.assign({},uo),{fontSize:M,markFontSize:M,railColor:v,railColorHover:v,fillColor:s,fillColorHover:s,opacityDisabled:B,handleColor:"#FFF",dotColor:z,dotColorModal:R,dotColorPopover:L,handleBoxShadow:"0 1px 4px 0 rgba(0, 0, 0, 0.3), inset 0 0 1px 0 rgba(0, 0, 0, 0.05)",handleBoxShadowHover:"0 1px 4px 0 rgba(0, 0, 0, 0.3), inset 0 0 1px 0 rgba(0, 0, 0, 0.05)",handleBoxShadowActive:"0 1px 4px 0 rgba(0, 0, 0, 0.3), inset 0 0 1px 0 rgba(0, 0, 0, 0.05)",handleBoxShadowFocus:"0 1px 4px 0 rgba(0, 0, 0, 0.3), inset 0 0 1px 0 rgba(0, 0, 0, 0.05)",indicatorColor:i,indicatorBoxShadow:y,indicatorTextColor:d,indicatorBorderRadius:X,dotBorder:"2px solid ".concat(v),dotBorderActive:"2px solid ".concat(s),dotBoxShadow:""})},fo={name:"Slider",common:We,self:ho},vo=fo;function me(t){return window.TouchEvent&&t instanceof window.TouchEvent}function be(){const t=new Map,i=y=>v=>{t.set(y,v)};return qe(()=>{t.clear()}),[t,i]}const mo=D([n("slider","\n display: block;\n padding: calc((var(--n-handle-size) - var(--n-rail-height)) / 2) 0;\n position: relative;\n z-index: 0;\n width: 100%;\n cursor: pointer;\n user-select: none;\n -webkit-user-select: none;\n ",[m("reverse",[n("slider-handles",[n("slider-handle-wrapper","\n transform: translate(50%, -50%);\n ")]),n("slider-dots",[n("slider-dot","\n transform: translateX(50%, -50%);\n ")]),m("vertical",[n("slider-handles",[n("slider-handle-wrapper","\n transform: translate(-50%, -50%);\n ")]),n("slider-marks",[n("slider-mark","\n transform: translateY(calc(-50% + var(--n-dot-height) / 2));\n ")]),n("slider-dots",[n("slider-dot","\n transform: translateX(-50%) translateY(0);\n ")])])]),m("vertical","\n padding: 0 calc((var(--n-handle-size) - var(--n-rail-height)) / 2);\n width: var(--n-rail-width-vertical);\n height: 100%;\n ",[n("slider-handles","\n top: calc(var(--n-handle-size) / 2);\n right: 0;\n bottom: calc(var(--n-handle-size) / 2);\n left: 0;\n ",[n("slider-handle-wrapper","\n top: unset;\n left: 50%;\n transform: translate(-50%, 50%);\n ")]),n("slider-rail","\n height: 100%;\n ",[U("fill","\n top: unset;\n right: 0;\n bottom: unset;\n left: 0;\n ")]),m("with-mark","\n width: var(--n-rail-width-vertical);\n margin: 0 32px 0 8px;\n "),n("slider-marks","\n top: calc(var(--n-handle-size) / 2);\n right: unset;\n bottom: calc(var(--n-handle-size) / 2);\n left: 22px;\n font-size: var(--n-mark-font-size);\n ",[n("slider-mark","\n transform: translateY(50%);\n white-space: nowrap;\n ")]),n("slider-dots","\n top: calc(var(--n-handle-size) / 2);\n right: unset;\n bottom: calc(var(--n-handle-size) / 2);\n left: 50%;\n ",[n("slider-dot","\n transform: translateX(-50%) translateY(50%);\n ")])]),m("disabled","\n cursor: not-allowed;\n opacity: var(--n-opacity-disabled);\n ",[n("slider-handle","\n cursor: not-allowed;\n ")]),m("with-mark","\n width: 100%;\n margin: 8px 0 32px 0;\n "),D("&:hover",[n("slider-rail",{backgroundColor:"var(--n-rail-color-hover)"},[U("fill",{backgroundColor:"var(--n-fill-color-hover)"})]),n("slider-handle",{boxShadow:"var(--n-handle-box-shadow-hover)"})]),m("active",[n("slider-rail",{backgroundColor:"var(--n-rail-color-hover)"},[U("fill",{backgroundColor:"var(--n-fill-color-hover)"})]),n("slider-handle",{boxShadow:"var(--n-handle-box-shadow-hover)"})]),n("slider-marks","\n position: absolute;\n top: 18px;\n left: calc(var(--n-handle-size) / 2);\n right: calc(var(--n-handle-size) / 2);\n ",[n("slider-mark","\n position: absolute;\n transform: translateX(-50%);\n white-space: nowrap;\n ")]),n("slider-rail","\n width: 100%;\n position: relative;\n height: var(--n-rail-height);\n background-color: var(--n-rail-color);\n transition: background-color .3s var(--n-bezier);\n border-radius: calc(var(--n-rail-height) / 2);\n ",[U("fill","\n position: absolute;\n top: 0;\n bottom: 0;\n border-radius: calc(var(--n-rail-height) / 2);\n transition: background-color .3s var(--n-bezier);\n background-color: var(--n-fill-color);\n ")]),n("slider-handles","\n position: absolute;\n top: 0;\n right: calc(var(--n-handle-size) / 2);\n bottom: 0;\n left: calc(var(--n-handle-size) / 2);\n ",[n("slider-handle-wrapper","\n outline: none;\n position: absolute;\n top: 50%;\n transform: translate(-50%, -50%);\n cursor: pointer;\n display: flex;\n ",[n("slider-handle","\n height: var(--n-handle-size);\n width: var(--n-handle-size);\n border-radius: 50%;\n overflow: hidden;\n transition: box-shadow .2s var(--n-bezier), background-color .3s var(--n-bezier);\n background-color: var(--n-handle-color);\n box-shadow: var(--n-handle-box-shadow);\n ",[D("&:hover","\n box-shadow: var(--n-handle-box-shadow-hover);\n ")]),D("&:focus",[n("slider-handle","\n box-shadow: var(--n-handle-box-shadow-focus);\n ",[D("&:hover","\n box-shadow: var(--n-handle-box-shadow-active);\n ")])])])]),n("slider-dots","\n position: absolute;\n top: 50%;\n left: calc(var(--n-handle-size) / 2);\n right: calc(var(--n-handle-size) / 2);\n ",[m("transition-disabled",[n("slider-dot","transition: none;")]),n("slider-dot","\n transition:\n border-color .3s var(--n-bezier),\n box-shadow .3s var(--n-bezier),\n background-color .3s var(--n-bezier);\n position: absolute;\n transform: translate(-50%, -50%);\n height: var(--n-dot-height);\n width: var(--n-dot-width);\n border-radius: var(--n-dot-border-radius);\n overflow: hidden;\n box-sizing: border-box;\n border: var(--n-dot-border);\n background-color: var(--n-dot-color);\n ",[m("active","border: var(--n-dot-border-active);")])])]),n("slider-handle-indicator","\n font-size: var(--n-font-size);\n padding: 6px 10px;\n border-radius: var(--n-indicator-border-radius);\n color: var(--n-indicator-text-color);\n background-color: var(--n-indicator-color);\n box-shadow: var(--n-indicator-box-shadow);\n ",[he()]),n("slider-handle-indicator","\n font-size: var(--n-font-size);\n padding: 6px 10px;\n border-radius: var(--n-indicator-border-radius);\n color: var(--n-indicator-text-color);\n background-color: var(--n-indicator-color);\n box-shadow: var(--n-indicator-box-shadow);\n ",[m("top","\n margin-bottom: 12px;\n "),m("right","\n margin-left: 12px;\n "),m("bottom","\n margin-top: 12px;\n "),m("left","\n margin-right: 12px;\n "),he()]),Ge(n("slider",[n("slider-dot","background-color: var(--n-dot-color-modal);")])),Je(n("slider",[n("slider-dot","background-color: var(--n-dot-color-popover);")]))]),bo=0,go=Object.assign(Object.assign({},ge.props),{to:ee.propTo,defaultValue:{type:[Number,Array],default:0},marks:Object,disabled:{type:Boolean,default:void 0},formatTooltip:Function,keyboard:{type:Boolean,default:!0},min:{type:Number,default:0},max:{type:Number,default:100},step:{type:[Number,String],default:1},range:Boolean,value:[Number,Array],placement:String,showTooltip:{type:Boolean,default:void 0},tooltip:{type:Boolean,default:!0},vertical:Boolean,reverse:Boolean,"onUpdate:value":[Function,Array],onUpdateValue:[Function,Array],onDragstart:[Function],onDragend:[Function]}),wo=Qe({name:"Slider",props:go,setup(t){const{mergedClsPrefixRef:i,namespaceRef:y,inlineThemeDisabled:v}=Ze(t),s=ge("Slider","-slider",mo,vo,t,i),d=k(null),[z,R]=be(),[L,X]=be(),M=k(new Set),B=eo(t),{mergedDisabledRef:$}=B,oe=w(()=>{const{step:e}=t;if(Number(e)<=0||e==="mark")return 0;const o=e.toString();let a=0;return o.includes(".")&&(a=o.length-o.indexOf(".")-1),a}),K=k(t.defaultValue),pe=oo(t,"value"),Y=ao(pe,K),b=w(()=>{const{value:e}=Y;return(t.range?e:[e]).map(se)}),ae=w(()=>b.value.length>2),we=w(()=>t.placement===void 0?t.vertical?"right":"top":t.placement),te=w(()=>{const{marks:e}=t;return e?Object.keys(e).map(parseFloat):null}),g=k(-1),ne=k(-1),S=k(-1),C=k(!1),F=k(!1),W=w(()=>{const{vertical:e,reverse:o}=t;return e?o?"top":"bottom":o?"right":"left"}),xe=w(()=>{if(ae.value)return;const e=b.value,o=H(t.range?Math.min(...e):t.min),a=H(t.range?Math.max(...e):e[0]),{value:r}=W;return t.vertical?{[r]:"".concat(o,"%"),height:"".concat(a-o,"%")}:{[r]:"".concat(o,"%"),width:"".concat(a-o,"%")}}),ke=w(()=>{const e=[],{marks:o}=t;if(o){const a=b.value.slice();a.sort((u,h)=>u-h);const{value:r}=W,{value:l}=ae,{range:c}=t,p=l?()=>!1:u=>c?u>=a[0]&&u<=a[a.length-1]:u<=a[0];for(const u of Object.keys(o)){const h=Number(u);e.push({active:p(h),label:o[u],style:{[r]:"".concat(H(h),"%")}})}}return e});function ye(e,o){const a=H(e),{value:r}=W;return{[r]:"".concat(a,"%"),zIndex:o===g.value?1:0}}function re(e){return t.showTooltip||S.value===e||g.value===e&&C.value}function Re(e){return C.value?!(g.value===e&&ne.value===e):!0}function Se(e){var o;~e&&(g.value=e,(o=z.get(e))===null||o===void 0||o.focus())}function Ce(){L.forEach((e,o)=>{re(o)&&e.syncPosition()})}function ie(e){const{"onUpdate:value":o,onUpdateValue:a}=t,{nTriggerFormInput:r,nTriggerFormChange:l}=B;a&&j(a,e),o&&j(o,e),K.value=e,r(),l()}function le(e){const{range:o}=t;if(o){if(Array.isArray(e)){const{value:a}=b;e.join()!==a.join()&&ie(e)}}else Array.isArray(e)||b.value[0]!==e&&ie(e)}function q(e,o){if(t.range){const a=b.value.slice();a.splice(o,1,e),le(a)}else le(e)}function G(e,o,a){const r=a!==void 0;a||(a=e-o>0?1:-1);const l=te.value||[],{step:c}=t;if(c==="mark"){const h=I(e,l.concat(o),r?a:void 0);return h?h.value:o}if(c<=0)return o;const{value:p}=oe;let u;if(r){const h=Number((o/c).toFixed(p)),x=Math.floor(h),J=h>x?x:x-1,Q=h<x?x:x+1;u=I(o,[Number((J*c).toFixed(p)),Number((Q*c).toFixed(p)),...l],a)}else{const h=Te(e);u=I(e,[...l,h])}return u?se(u.value):o}function se(e){return Math.min(t.max,Math.max(t.min,e))}function H(e){const{max:o,min:a}=t;return(e-a)/(o-a)*100}function ze(e){const{max:o,min:a}=t;return a+(o-a)*e}function Te(e){const{step:o,min:a}=t;if(Number(o)<=0||o==="mark")return e;const r=Math.round((e-a)/o)*o+a;return Number(r.toFixed(oe.value))}function I(e,o=te.value,a){if(!(o!=null&&o.length))return null;let r=null,l=-1;for(;++l<o.length;){const c=o[l]-e,p=Math.abs(c);(a===void 0||c*a>0)&&(r===null||p<r.distance)&&(r={index:l,distance:p,value:o[l]})}return r}function de(e){const o=d.value;if(!o)return;const a=me(e)?e.touches[0]:e,r=o.getBoundingClientRect();let l;return t.vertical?l=(r.bottom-a.clientY)/r.height:l=(a.clientX-r.left)/r.width,t.reverse&&(l=1-l),ze(l)}function Ve(e){if($.value||!t.keyboard)return;const{vertical:o,reverse:a}=t;switch(e.key){case"ArrowUp":e.preventDefault(),A(o&&a?-1:1);break;case"ArrowRight":e.preventDefault(),A(!o&&a?-1:1);break;case"ArrowDown":e.preventDefault(),A(o&&a?1:-1);break;case"ArrowLeft":e.preventDefault(),A(!o&&a?1:-1);break}}function A(e){const o=g.value;if(o===-1)return;const{step:a}=t,r=b.value[o],l=Number(a)<=0||a==="mark"?r:r+a*e;q(G(l,r,e>0?1:-1),o)}function De(e){var o,a;if($.value||!me(e)&&e.button!==bo)return;const r=de(e);if(r===void 0)return;const l=b.value.slice(),c=t.range?(a=(o=I(r,l))===null||o===void 0?void 0:o.index)!==null&&a!==void 0?a:-1:0;c!==-1&&(e.preventDefault(),Se(c),Me(),q(G(r,b.value[c]),c))}function Me(){C.value||(C.value=!0,t.onDragstart&&j(t.onDragstart),O("touchend",document,P),O("mouseup",document,P),O("touchmove",document,N),O("mousemove",document,N))}function E(){C.value&&(C.value=!1,t.onDragend&&j(t.onDragend),_("touchend",document,P),_("mouseup",document,P),_("touchmove",document,N),_("mousemove",document,N))}function N(e){const{value:o}=g;if(!C.value||o===-1){E();return}const a=de(e);a!==void 0&&q(G(a,b.value[o]),o)}function P(){E()}function Be(e){g.value=e,$.value||(S.value=e)}function $e(e){g.value===e&&(g.value=-1,E()),S.value===e&&(S.value=-1)}function Fe(e){S.value=e}function He(e){S.value===e&&(S.value=-1)}fe(g,(e,o)=>void Z(()=>ne.value=o)),fe(Y,()=>{if(t.marks){if(F.value)return;F.value=!0,Z(()=>{F.value=!1})}Z(Ce)}),to(()=>{E()});const ce=w(()=>{const{self:{markFontSize:e,railColor:o,railColorHover:a,fillColor:r,fillColorHover:l,handleColor:c,opacityDisabled:p,dotColor:u,dotColorModal:h,handleBoxShadow:x,handleBoxShadowHover:J,handleBoxShadowActive:Q,handleBoxShadowFocus:Ie,dotBorder:Ae,dotBoxShadow:Ee,railHeight:Ne,railWidthVertical:Pe,handleSize:Ue,dotHeight:je,dotWidth:Oe,dotBorderRadius:_e,fontSize:Le,dotBorderActive:Xe,dotColorPopover:Ke},common:{cubicBezierEaseInOut:Ye}}=s.value;return{"--n-bezier":Ye,"--n-dot-border":Ae,"--n-dot-border-active":Xe,"--n-dot-border-radius":_e,"--n-dot-box-shadow":Ee,"--n-dot-color":u,"--n-dot-color-modal":h,"--n-dot-color-popover":Ke,"--n-dot-height":je,"--n-dot-width":Oe,"--n-fill-color":r,"--n-fill-color-hover":l,"--n-font-size":Le,"--n-handle-box-shadow":x,"--n-handle-box-shadow-active":Q,"--n-handle-box-shadow-focus":Ie,"--n-handle-box-shadow-hover":J,"--n-handle-color":c,"--n-handle-size":Ue,"--n-opacity-disabled":p,"--n-rail-color":o,"--n-rail-color-hover":a,"--n-rail-height":Ne,"--n-rail-width-vertical":Pe,"--n-mark-font-size":e}}),T=v?ve("slider",void 0,ce,t):void 0,ue=w(()=>{const{self:{fontSize:e,indicatorColor:o,indicatorBoxShadow:a,indicatorTextColor:r,indicatorBorderRadius:l}}=s.value;return{"--n-font-size":e,"--n-indicator-border-radius":l,"--n-indicator-box-shadow":a,"--n-indicator-color":o,"--n-indicator-text-color":r}}),V=v?ve("slider-indicator",void 0,ue,t):void 0;return{mergedClsPrefix:i,namespace:y,uncontrolledValue:K,mergedValue:Y,mergedDisabled:$,mergedPlacement:we,isMounted:no(),adjustedTo:ee(t),dotTransitionDisabled:F,markInfos:ke,isShowTooltip:re,shouldKeepTooltipTransition:Re,handleRailRef:d,setHandleRefs:R,setFollowerRefs:X,fillStyle:xe,getHandleStyle:ye,activeIndex:g,arrifiedValues:b,followerEnabledIndexSet:M,handleRailMouseDown:De,handleHandleFocus:Be,handleHandleBlur:$e,handleHandleMouseEnter:Fe,handleHandleMouseLeave:He,handleRailKeyDown:Ve,indicatorCssVars:v?void 0:ue,indicatorThemeClass:V==null?void 0:V.themeClass,indicatorOnRender:V==null?void 0:V.onRender,cssVars:v?void 0:ce,themeClass:T==null?void 0:T.themeClass,onRender:T==null?void 0:T.onRender}},render(){var t;const{mergedClsPrefix:i,themeClass:y,formatTooltip:v}=this;return(t=this.onRender)===null||t===void 0||t.call(this),f("div",{class:["".concat(i,"-slider"),y,{["".concat(i,"-slider--disabled")]:this.mergedDisabled,["".concat(i,"-slider--active")]:this.activeIndex!==-1,["".concat(i,"-slider--with-mark")]:this.marks,["".concat(i,"-slider--vertical")]:this.vertical,["".concat(i,"-slider--reverse")]:this.reverse}],style:this.cssVars,onKeydown:this.handleRailKeyDown,onMousedown:this.handleRailMouseDown,onTouchstart:this.handleRailMouseDown},f("div",{class:"".concat(i,"-slider-rail")},f("div",{class:"".concat(i,"-slider-rail__fill"),style:this.fillStyle}),this.marks?f("div",{class:["".concat(i,"-slider-dots"),this.dotTransitionDisabled&&"".concat(i,"-slider-dots--transition-disabled")]},this.markInfos.map(s=>f("div",{key:s.label,class:["".concat(i,"-slider-dot"),{["".concat(i,"-slider-dot--active")]:s.active}],style:s.style}))):null,f("div",{ref:"handleRailRef",class:"".concat(i,"-slider-handles")},this.arrifiedValues.map((s,d)=>{const z=this.isShowTooltip(d);return f(ro,null,{default:()=>[f(io,null,{default:()=>f("div",{ref:this.setHandleRefs(d),class:"".concat(i,"-slider-handle-wrapper"),tabindex:this.mergedDisabled?-1:0,role:"slider","aria-valuenow":s,"aria-valuemin":this.min,"aria-valuemax":this.max,"aria-orientation":this.vertical?"vertical":"horizontal","aria-disabled":this.disabled,style:this.getHandleStyle(s,d),onFocus:()=>{this.handleHandleFocus(d)},onBlur:()=>{this.handleHandleBlur(d)},onMouseenter:()=>{this.handleHandleMouseEnter(d)},onMouseleave:()=>{this.handleHandleMouseLeave(d)}},lo(this.$slots.thumb,()=>[f("div",{class:"".concat(i,"-slider-handle")})]))}),this.tooltip&&f(so,{ref:this.setFollowerRefs(d),show:z,to:this.adjustedTo,enabled:this.showTooltip&&!this.range||this.followerEnabledIndexSet.has(d),teleportDisabled:this.adjustedTo===ee.tdkey,placement:this.mergedPlacement,containerClass:this.namespace},{default:()=>f(co,{name:"fade-in-scale-up-transition",appear:this.isMounted,css:this.shouldKeepTooltipTransition(d),onEnter:()=>{this.followerEnabledIndexSet.add(d)},onAfterLeave:()=>{this.followerEnabledIndexSet.delete(d)}},{default:()=>{var R;return z?((R=this.indicatorOnRender)===null||R===void 0||R.call(this),f("div",{class:["".concat(i,"-slider-handle-indicator"),this.indicatorThemeClass,"".concat(i,"-slider-handle-indicator--").concat(this.mergedPlacement)],style:this.indicatorCssVars},typeof v=="function"?v(s):s)):null}})})]})})),this.marks?f("div",{class:"".concat(i,"-slider-marks")},this.markInfos.map(s=>f("div",{key:s.label,class:"".concat(i,"-slider-mark"),style:s.style},s.label))):null))}});export{wo as N};