(function(d,e){typeof exports=="object"&&typeof module<"u"?e(exports,require("vue")):typeof define=="function"&&define.amd?define(["exports","vue"],e):(d=typeof globalThis<"u"?globalThis:d||self,e(d.VueRollingNumberInput={},d.Vue))})(this,function(d,e){"use strict";const g={class:"rolling-number-input-grid"},N=["value","onKeydown","onInput","onWheel"],I=["name","value"],b=e.defineComponent({__name:"RollingNumberInput",props:{allowNegative:{type:Boolean,default:!1},centerClass:{default:"rolling-number-input-center"},digitClass:{default:"rolling-number-input-digit"},leftClass:{default:"rolling-number-input-left"},rightClass:{default:"rolling-number-input-right"},name:{default:""},modelValue:{default:0},precision:{default:0},width:{},max:{default:void 0},min:{default:void 0}},emits:["input","change","update:modelValue"],setup(m,{emit:i}){const l=m,a=e.reactive({internalValue:l.modelValue}),s=e.ref(null),c=e.computed(()=>{if(l.precision<0||l.width<1)return[];const t=Math.abs(a.internalValue).toFixed(l.precision),n=new Array(l.width).fill("0"),o=l.width-t.length;for(let r=t.length-1;r>=0;r--)n[r+o]=t.charAt(r);return l.allowNegative&&(a.internalValue>=0?n[0]="+":n[0]="-"),n}),V=e.computed(()=>l.max?l.max:Math.pow(10,L.value)-Math.pow(10,-l.precision)),X=e.computed(()=>l.min?l.allowNegative?l.min:Math.max(l.min,0):l.allowNegative?-V.value:0),L=e.computed(()=>l.width-l.precision-(l.allowNegative?1:0)-(l.precision>0?1:0));e.watch(()=>l.modelValue,(t,n)=>{t!==n&&(isNaN(t)?a.internalValue=0:a.internalValue=t)}),e.watch(()=>a.internalValue,(t,n)=>{t!==n&&(i("input",t),i("change",t),i("update:modelValue",t))});const j=async(t,n)=>{if(n<0||n>=c.value.length||parseInt(c.value[n])===t)return!1;const o=c.value.map((r,u)=>u===n?t:r).join("");return a.internalValue=parseFloat(o),!0},f=async(t,n)=>{let o=n+(t?-1:1);return o=(l.allowNegative?1:0)?(s.value[o].focus(),!0):!1},H=async(t,n)=>{const o=c.value[n],r=parseInt(t.key);if(t.key==="-"&&l.allowNegative||(t.key==="ArrowUp"||t.key==="ArrowDown")&&o==="+"){a.internalValue=-Math.abs(a.internalValue),l.min&&(a.internalValue=Math.max(l.min,a.internalValue)),t.preventDefault();return}else if(t.key==="+"||(t.key==="ArrowUp"||t.key==="ArrowDown")&&o==="-"){a.internalValue=Math.abs(a.internalValue),l.max&&(a.internalValue=Math.min(l.max,a.internalValue)),t.preventDefault();return}if((o==="."||o==="+"||o==="-"||n<0||n>=c.value.length||parseInt(o)===r)&&t.preventDefault(),parseInt(o)===r){await f(!1,n);return}if(t.key==="ArrowUp"){await p(!0,n),t.preventDefault();return}if(t.key==="ArrowDown"){await p(!1,n),t.preventDefault();return}if(r>=0&&r<=9)return;if(t.key!=="ArrowLeft"&&t.key!=="ArrowRight"&&t.key!=="Tab"){isNaN(r)&&t.preventDefault();return}const u=t.key==="ArrowLeft"||t.shiftKey&&t.key==="Tab";await f(u,n)&&t.preventDefault()},F=t=>{if(t===0){let n=`${l.digitClass} ${l.leftClass}`;return l.width===1&&(n+=" rolling-number-input-single"),l.width===2&&(n+=" rolling-number-input-left-two-digits"),n}else return t===l.width-1?`${l.digitClass} ${l.rightClass}`:`${l.digitClass} ${l.centerClass}`},v=async t=>{t.currentTarget instanceof HTMLInputElement&&t.currentTarget.select()},q=async(t,n)=>{t.data&&(await j(parseInt(t.data),n)?await f(!1,n):t.preventDefault())},_=async(t,n)=>{if(l.allowNegative&&n===0||l.precision>0&&n===l.width-l.precision-1){t.preventDefault();return}t.deltaY<0?await p(!0,n):t.deltaY>0&&await p(!1,n)},p=async(t,n)=>{const o=l.width-l.precision,r=Math.pow(10,o-n-(n>=o?1:2)-(l.precision===0?-1:0));t?a.internalValue+=r:a.internalValue-=r,a.internalValue=await $(Math.max(X.value,Math.min(a.internalValue,V.value)),l.precision)},$=async(t,n)=>+(Math.round(+(t+"e"+n))+"e-"+n);return(t,n)=>(e.openBlock(),e.createElementBlock("span",g,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(c.value,(o,r)=>(e.openBlock(),e.createElementBlock("input",{ref_for:!0,ref_key:"inputs",ref:s,key:r,value:o,class:e.normalizeClass(F(r)),onKeydown:u=>H(u,r),onInput:u=>q(u,r),onWheel:u=>_(u,r),onClick:n[0]||(n[0]=u=>v(u))},null,42,N))),128)),e.createElementVNode("span",null,[e.createElementVNode("input",{type:"hidden",name:t.name,value:""+a.internalValue},null,8,I)])]))}}),ee="",h=((m,i)=>{const l=m.__vccOpts||m;for(const[a,s]of i)l[a]=s;return l})(b,[["__scopeId","data-v-fc4e4e4f"]]),y="",w={id:"app"},E=e.createElementVNode("img",{alt:"Vue logo",src:y},null,-1),k=e.createElementVNode("h1",null,"Rolling Number Input Example",-1),C=e.createElementVNode("p",null,"Spin your mouse wheel over individual digits to change them!",-1),R={style:{display:"flex","flex-direction":"column","align-items":"center"}},x={style:{padding:"1em",border:"1px solid black",display:"flex","flex-direction":"column"}},W={style:{padding:"1em",display:"flex","flex-direction":"row"}},B={style:{"margin-right":"20px","text-align":"right"}},U=e.createElementVNode("label",null,"Allow Negative",-1),Z=e.createElementVNode("br",null,null,-1),M=e.createElementVNode("label",null,"Minimum: ",-1),Q=e.createElementVNode("br",null,null,-1),A=e.createElementVNode("label",null,"Maximum: ",-1),G=e.createElementVNode("br",null,null,-1),z=e.createElementVNode("label",null,"Precision: ",-1),D=e.createElementVNode("br",null,null,-1),Y=e.createElementVNode("label",null,"Width: ",-1),S=e.createElementVNode("label",null,"Form Input: ",-1),P=e.createElementVNode("br",null,null,-1),J=e.createElementVNode("br",null,null,-1),O=e.createElementVNode("br",null,null,-1),T=e.createElementVNode("input",{type:"submit"},null,-1),K=e.defineComponent({__name:"Demo",setup(m){const i=e.reactive({value:50,submittedValue:"",allowNegative:!1,precision:"3",width:"8",min:"10",max:"1000"}),l=a=>{if(a.preventDefault(),a.target&&a.target instanceof HTMLFormElement){const s=new FormData(a.target);s.has("example")&&(i.submittedValue=String(s.get("example")))}};return(a,s)=>(e.openBlock(),e.createElementBlock("div",w,[E,k,C,e.createElementVNode("div",R,[e.createElementVNode("div",x,[e.createElementVNode("p",null,"Current Value: "+e.toDisplayString(i.value),1),e.createElementVNode("div",W,[e.createElementVNode("div",B,[e.createElementVNode("form",null,[U,e.withDirectives(e.createElementVNode("input",{"onUpdate:modelValue":s[0]||(s[0]=c=>i.allowNegative=c),type:"checkbox"},null,512),[[e.vModelCheckbox,i.allowNegative]]),Z,M,e.withDirectives(e.createElementVNode("input",{"onUpdate:modelValue":s[1]||(s[1]=c=>i.min=c),type:"number"},null,512),[[e.vModelText,i.min]]),Q,A,e.withDirectives(e.createElementVNode("input",{"onUpdate:modelValue":s[2]||(s[2]=c=>i.max=c),type:"number"},null,512),[[e.vModelText,i.max]]),G,z,e.withDirectives(e.createElementVNode("input",{"onUpdate:modelValue":s[3]||(s[3]=c=>i.precision=c),type:"number"},null,512),[[e.vModelText,i.precision]]),D,Y,e.withDirectives(e.createElementVNode("input",{"onUpdate:modelValue":s[4]||(s[4]=c=>i.width=c),type:"number"},null,512),[[e.vModelText,i.width]])])]),e.createElementVNode("div",null,[e.createElementVNode("form",{onSubmit:l},[S,P,e.createVNode(h,{modelValue:i.value,"onUpdate:modelValue":s[5]||(s[5]=c=>i.value=c),"allow-negative":i.allowNegative,width:parseInt(i.width),precision:parseInt(i.precision),min:parseInt(i.min),max:parseInt(i.max),name:"example"},null,8,["modelValue","allow-negative","width","precision","min","max"]),J,O,T],32),e.createElementVNode("p",null,"Submitted value: "+e.toDisplayString(i.submittedValue),1)])])])])]))}}),le="";d.Demo=K,d.RollingNumberInput=h,Object.defineProperty(d,Symbol.toStringTag,{value:"Module"})});