raqam 0.2.3 → 0.2.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +33 -19
- package/dist/{chunk-IG7CVIA2.js → chunk-4AMLNJEK.js} +3 -3
- package/dist/{chunk-IG7CVIA2.js.map → chunk-4AMLNJEK.js.map} +1 -1
- package/dist/{chunk-NTROGAES.js → chunk-7IEJOMYT.js} +3 -3
- package/dist/{chunk-NTROGAES.js.map → chunk-7IEJOMYT.js.map} +1 -1
- package/dist/{chunk-VOBTYII2.js → chunk-HPUEM7JB.js} +3 -3
- package/dist/{chunk-VOBTYII2.js.map → chunk-HPUEM7JB.js.map} +1 -1
- package/dist/{chunk-WTS5RY7S.js → chunk-OLLREWX6.js} +3 -3
- package/dist/{chunk-WTS5RY7S.js.map → chunk-OLLREWX6.js.map} +1 -1
- package/dist/{chunk-NSFX2EAT.js → chunk-RP3DVBGJ.js} +3 -3
- package/dist/{chunk-NSFX2EAT.js.map → chunk-RP3DVBGJ.js.map} +1 -1
- package/dist/{chunk-NBAZIJ5W.js → chunk-TISOJTKH.js} +2 -2
- package/dist/{chunk-NBAZIJ5W.js.map → chunk-TISOJTKH.js.map} +1 -1
- package/dist/core.cjs +1 -1
- package/dist/core.cjs.map +1 -1
- package/dist/core.d.cts +6 -2
- package/dist/core.d.ts +6 -2
- package/dist/core.js +1 -1
- package/dist/core.js.map +1 -1
- package/dist/{index-B8X3-9h1.d.cts → index-CJrJACqc.d.cts} +6 -2
- package/dist/{index-B8X3-9h1.d.ts → index-CJrJACqc.d.ts} +6 -2
- package/dist/index.cjs +1 -1
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +2 -2
- package/dist/index.d.ts +2 -2
- package/dist/index.js +1 -1
- package/dist/index.js.map +1 -1
- package/dist/locales/ar.cjs.map +1 -1
- package/dist/locales/ar.js +2 -2
- package/dist/locales/bn.cjs.map +1 -1
- package/dist/locales/bn.js +2 -2
- package/dist/locales/fa.cjs.map +1 -1
- package/dist/locales/fa.js +2 -2
- package/dist/locales/hi.cjs.map +1 -1
- package/dist/locales/hi.js +2 -2
- package/dist/locales/index.cjs.map +1 -1
- package/dist/locales/index.js +6 -6
- package/dist/locales/th.cjs.map +1 -1
- package/dist/locales/th.js +2 -2
- package/dist/react.cjs +1 -1
- package/dist/react.cjs.map +1 -1
- package/dist/react.d.cts +1 -1
- package/dist/react.d.ts +1 -1
- package/dist/react.js +1 -1
- package/dist/react.js.map +1 -1
- package/package.json +2 -1
package/dist/react.d.cts
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
export { b as NumberField, d as NumberFieldContext, e as NumberFieldContextValue, u as useControllableState, k as useNumberField, l as useNumberFieldContext, m as useNumberFieldFormat, n as useNumberFieldState } from './index-
|
|
1
|
+
export { b as NumberField, d as NumberFieldContext, e as NumberFieldContextValue, u as useControllableState, k as useNumberField, l as useNumberFieldContext, m as useNumberFieldFormat, n as useNumberFieldState } from './index-CJrJACqc.cjs';
|
|
2
2
|
import 'react/jsx-runtime';
|
|
3
3
|
import 'react';
|
package/dist/react.d.ts
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
export { b as NumberField, d as NumberFieldContext, e as NumberFieldContextValue, u as useControllableState, k as useNumberField, l as useNumberFieldContext, m as useNumberFieldFormat, n as useNumberFieldState } from './index-
|
|
1
|
+
export { b as NumberField, d as NumberFieldContext, e as NumberFieldContextValue, u as useControllableState, k as useNumberField, l as useNumberFieldContext, m as useNumberFieldFormat, n as useNumberFieldState } from './index-CJrJACqc.js';
|
|
2
2
|
import 'react/jsx-runtime';
|
|
3
3
|
import 'react';
|
package/dist/react.js
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
"use client";
|
|
2
|
-
import Rt,{createContext,forwardRef,useRef,useMemo,useCallback,useState,useId,useLayoutEffect,useEffect,useContext}from'react';import {jsx}from'react/jsx-runtime';function De({value:t,defaultValue:e,onChange:n}){let r=t!==void 0,o=useRef(r);typeof window<"u"&&window.__DEV__!==false&&o.current!==r&&console.warn(`[raqam] Component is changing from ${o.current?"controlled":"uncontrolled"} to ${r?"controlled":"uncontrolled"}. Decide between using a controlled or uncontrolled component and don't switch.`);let[i,u]=useState(e),d=useCallback(s=>{let l=typeof s=="function"?s(r?t:i):s;r||u(l),n?.(l);},[r,t,i,n]);return [r?t:i,d]}var Ke=new Map;function ze(t,e){let n=`${t??""}::${JSON.stringify(e??{})}`,r=Ke.get(n);return r||(r=new Intl.NumberFormat(t,e),Ke.set(n,r)),r}function at(t,e){let n=ze(t,e),r=n.formatToParts(12345.6),o=".",i=",",u="-",d="0";for(let b of r)b.type==="decimal"&&(o=b.value),b.type==="group"&&(i=b.value),b.type==="minusSign"&&(u=b.value);let s=n.formatToParts(0);for(let b of s)if(b.type==="integer"){d=b.value;break}let l=/^(ar|he|fa|ur|syc|nqo|ug|yi)/i,a=n.resolvedOptions().locale,m=l.test(a);return {decimalSeparator:o,groupingSeparator:i,minusSign:u,zero:d,isRTL:m}}function Z(t){let e={...t.formatOptions};t.minimumFractionDigits!==void 0&&(e.minimumFractionDigits=t.minimumFractionDigits),t.maximumFractionDigits!==void 0&&(e.maximumFractionDigits=t.maximumFractionDigits),t.fixedDecimalScale&&t.maximumFractionDigits!==void 0&&(e.minimumFractionDigits=t.maximumFractionDigits,e.maximumFractionDigits=t.maximumFractionDigits);let n=ze(t.locale,e),r=null;function o(){return r||(r=at(t.locale,e)),r}function i(s){let l=n.formatToParts(s);if(!t.prefix&&!t.suffix)return l;let a=[];return t.prefix&&a.push({type:"literal",value:t.prefix}),a.push(...l),t.suffix&&a.push({type:"literal",value:t.suffix}),a}function u(s){if(!Number.isFinite(s))return "";let l=n.format(s);return (t.prefix??"")+l+(t.suffix??"")}function d(s){let l=i(s);return {formatted:l.map(m=>m.value).join(""),parts:l}}return {format:u,formatToParts:i,getLocaleInfo:o,formatResult:d}}var ut=[[1632,1641],[1776,1785],[2406,2415],[2534,2543],[3664,3673]],lt=[...ut];function z(t){return /[^\u0020-\u007e]/.test(t)?t.replace(/\p{Nd}/gu,e=>{let n=e.codePointAt(0);for(let[o,i]of lt)if(n>=o&&n<=i)return String(n-o);let r=Number.parseInt(e,10);return Number.isNaN(r)?e:String(r)}):t}function Ye(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function qe(t,e,n,r){let o=Ye(e.decimalSeparator),i=Ye(e.minusSign);return !!(n&&(t==="-"||t===e.minusSign)||r&&new RegExp(`^${i}?\\d+${o}$`).test(t)||r&&new RegExp(`^${i}?\\d+${o}\\d*0+$`).test(t))}function ve(t={}){let e=t.allowNegative??true,n=t.allowDecimal??true,r=Z({locale:t.locale,formatOptions:t.formatOptions,prefix:t.prefix,suffix:t.suffix});function o(){return r.getLocaleInfo()}function i(s){let l=o(),a=z(s),m=a.match(/^\((.+)\)$/);return m&&(a=`-${m[1]}`),t.prefix&&a.startsWith(t.prefix)&&(a=a.slice(t.prefix.length)),t.suffix&&a.endsWith(t.suffix)&&(a=a.slice(0,-t.suffix.length)),l.groupingSeparator&&(a=a.split(l.groupingSeparator).join("")),l.decimalSeparator!=="."&&(a=a.split(l.decimalSeparator).join(".")),l.minusSign!=="-"&&(a=a.split(l.minusSign).join("-")),a=a.replace(/[^\d.\-]/g,"").trim(),a}function u(s){if(!s||s.trim()==="")return {value:null,isValid:false,isIntermediate:false};let l=o();if(qe(s,l,e,n))return {value:null,isValid:false,isIntermediate:true};let a=i(s);if(a==="")return {value:null,isValid:false,isIntermediate:false};if(a==="-")return {value:null,isValid:false,isIntermediate:e};if(!/^-?\d+\.?\d*$/.test(a))return {value:null,isValid:false,isIntermediate:false};if(!e&&a.startsWith("-"))return {value:null,isValid:false,isIntermediate:false};if(!n&&a.includes("."))return {value:null,isValid:false,isIntermediate:false};let m=Number.parseFloat(a);return Number.isFinite(m)?{value:m,isValid:true,isIntermediate:false}:{value:null,isValid:false,isIntermediate:false}}function d(s){let l=o();return qe(s,l,e,n)}return {parse:u,isIntermediate:d,getLocaleInfo:o}}function we(t,e,n){let r=t;return e!==void 0&&(r=Math.max(r,e)),n!==void 0&&(r=Math.min(r,n)),r}function We(t,e){let r=10**Math.max(Ge(t),Ge(e));return Math.round(t*r+e*r)/r}function Ge(t){let e=String(t),n=e.indexOf(".");return n===-1?0:e.length-n-1}function Ae(t){let{locale:e,formatOptions:n,minValue:r,maxValue:o,step:i=1,largeStep:u,smallStep:d,allowNegative:s=true,allowDecimal:l=true,maximumFractionDigits:a,minimumFractionDigits:m,fixedDecimalScale:b,clampBehavior:E="blur",prefix:R,suffix:T,allowOutOfRange:L=false,validate:j,onRawChange:K,formatValue:J}=t,Y=useMemo(()=>Z({locale:e,formatOptions:n,prefix:R,suffix:T,minimumFractionDigits:m,maximumFractionDigits:a,fixedDecimalScale:b}),[e,JSON.stringify(n),R,T,m,a,b]),p=useMemo(()=>ve({locale:e,formatOptions:n,allowNegative:s,allowDecimal:l,prefix:R,suffix:T}),[e,JSON.stringify(n),s,l,R,T]),[I,A]=De({value:t.value,defaultValue:t.defaultValue??null,onChange:t.onChange}),k=useCallback(f=>J?J(f):Y.format(f),[Y,J]),y=useMemo(()=>t.defaultValue!=null?k(t.defaultValue):t.value!=null?k(t.value):"",[]),[C,X]=useState(y),D=useRef(y),[ae,ue]=useState(t.defaultValue!=null?String(t.defaultValue):null),q=useCallback(f=>{if(!j)return {validationState:"valid",validationError:null};let S=j(f);return S===false?{validationState:"invalid",validationError:null}:typeof S=="string"?{validationState:"invalid",validationError:S}:{validationState:"valid",validationError:null}},[j]),re=useMemo(()=>{let f=t.defaultValue??t.value??null;return q(f??null)},[]),[Ie,me]=useState(re.validationState),[F,B]=useState(re.validationError),[N,le]=useState(false),[ye,Se]=useState(false),fe=useRef("input"),Fe=useCallback(f=>{fe.current=f;},[]),Pe=useCallback(()=>fe.current,[]),te=t.value,pe=useRef(te);if(pe.current!==te)if(pe.current=te,te!=null){let f=Y.format(te);f!==D.current&&(D.current=f);}else D.current="";let Q=useCallback(f=>{let{validationState:S,validationError:ne}=q(f);me(S),B(ne);},[q]),he=useCallback(f=>{let S=p.parse(f);E==="strict"&&!L&&S.value!==null&&(r!==void 0&&S.value<r||o!==void 0&&S.value>o)||(X(f),A(S.value),ue(S.value!==null?f:null),K?.(S.value!==null?f:null),Q(S.value));},[p,E,L,r,o,A,K,Q]),_=useCallback(f=>{if(A(f),f!=null){let S=k(f);X(S),D.current=S;let ne=String(f);ue(ne),K?.(ne);}else X(""),D.current="",ue(null),K?.(null);Q(f);},[k,A,K,Q]),Ee=useCallback(()=>{if(I==null){X(""),D.current="";return}let f=I;E==="blur"&&!L&&(f=we(I,r,o));let S=k(f);X(S),D.current=S,f!==I&&A(f),Q(f);},[I,E,L,r,o,Y,A,Q]),Te=u??i*10,be=d??i*.1,Ue=!t.disabled&&!t.readOnly&&(L||o===void 0||(I??Number.NEGATIVE_INFINITY)<o),se=!t.disabled&&!t.readOnly&&(L||r===void 0||(I??Number.POSITIVE_INFINITY)>r),Ne=useCallback(f=>{let ge=we(We(I??0,f??i),r,o);_(ge);},[I,i,r,o,_]),Me=useCallback(f=>{let ge=we(We(I??0,-(f??i)),r,o);_(ge);},[I,i,r,o,_]),Ce=useCallback(()=>{o!==void 0&&_(o);},[o,_]),Ve=useCallback(()=>{r!==void 0&&_(r);},[r,_]);return {inputValue:C,numberValue:I??null,rawValue:ae,canIncrement:Ue,canDecrement:se,isScrubbing:N,setIsScrubbing:le,isFocused:ye,setIsFocused:Se,validationState:Ie,validationError:F,_setLastChangeReason:Fe,_getLastChangeReason:Pe,setInputValue:he,setNumberValue:_,commit:Ee,increment:Ne,decrement:Me,incrementToMax:Ce,decrementToMin:Ve,options:{...t,step:i,largeStep:Te,smallStep:be}}}function Je(t,e){return t>="0"&&t<="9"||t===e.decimalSeparator||t===e.minusSign||t==="-"}function st(t,e,n){let r=z(t),o=0;for(let i=0;i<e&&i<r.length;i++)Je(r[i],n)&&o++;return o}function ct(t,e){let n=t.length,r=new Array(n+1).fill(true);for(let o=0;o<n;o++)t[o]===e.groupingSeparator&&(r[o+1]=false);return r[0]=true,r[n]=true,r}function Oe(t,e,n,r,o){let i=z(t),u=st(i,e,r);o==="deleteContentBackward"&&e>0&&t[e-1]===r.groupingSeparator&&(u=Math.max(0,u-1));let d=ct(n,r),s=z(n),l=0,a=0;for(let m=0;m<s.length;m++){if(l===u){a=m;break}Je(s[m],r)&&l++,a=m+1;}return u>0&&l<u&&(a=n.length),a=dt(a,d),a}function dt(t,e){if(e[t])return t;for(let n=t+1;n<e.length;n++)if(e[n])return n;for(let n=t-1;n>=0;n--)if(e[n])return n;return 0}function ke(t,e={}){let{delay:n=400,interval:r=200,disabled:o=false}=e,i=useRef(t);useEffect(()=>{i.current=t;});let u=useRef(n);useEffect(()=>{u.current=n;});let d=useRef(r);useEffect(()=>{d.current=r;});let s=useRef(null),l=useRef(null),a=useRef(false),m=useCallback(()=>{a.current=false,s.current!==null&&(clearTimeout(s.current),s.current=null),l.current!==null&&(clearTimeout(l.current),l.current=null);},[]),b=useCallback(L=>{if(!a.current)return;i.current();let j=Math.max(50,Math.floor(L/2));l.current=setTimeout(()=>{b(j);},L);},[]),E=useCallback(L=>{o||L.button!==0&&L.pointerType==="mouse"||(i.current(),a.current=true,s.current=setTimeout(()=>{b(d.current);},u.current));},[o,b]),R=useCallback(L=>{L.preventDefault(),m();},[m]),T=useCallback(L=>{m();},[m]);return useEffect(()=>m,[m]),{onPointerDown:E,onPointerUp:R,onPointerLeave:T}}function Qe(t){return t.replace(/[.*+?^${}()|[\]\\\-]/g,"\\$&")}function _e(t,e,n){let{locale:r,formatOptions:o,minValue:i,maxValue:u,allowNegative:d=true,allowDecimal:s=true,allowMouseWheel:l=false,liveFormat:a=true,prefix:m,suffix:b,name:E,disabled:R,readOnly:T,required:L,onFocus:j,onBlur:K,maximumFractionDigits:J,minimumFractionDigits:Y,fixedDecimalScale:p,copyBehavior:I="formatted",stepHoldDelay:A=400,stepHoldInterval:k=200,formatValue:y,parseValue:C}=t,{step:X=1,largeStep:D=X*10,smallStep:ae=X*.1}=e.options,ue=useId(),q=t.id??`raqam-${ue}`,re=`${q}-label`,Ie=`${q}-description`,me=`${q}-error`,F=useMemo(()=>Z({locale:r,formatOptions:o,prefix:m,suffix:b,minimumFractionDigits:Y,maximumFractionDigits:J,fixedDecimalScale:p}),[r,JSON.stringify(o),m,b,Y,J,p]),B=useMemo(()=>ve({locale:r,formatOptions:o,allowNegative:d,allowDecimal:s,prefix:m,suffix:b}),[r,JSON.stringify(o),d,s,m,b]),N=useRef(null);useLayoutEffect(()=>{N.current!==null&&n.current&&document.activeElement===n.current&&(n.current.setSelectionRange(N.current,N.current),N.current=null);},[e.inputValue,n]),useEffect(()=>{let c=n.current;if(!c||!l)return;let g=h=>{R||T||document.activeElement===c&&(h.preventDefault(),e._setLastChangeReason("wheel"),h.deltaY<0?e.increment():e.decrement());};return c.addEventListener("wheel",g,{passive:false}),()=>c.removeEventListener("wheel",g)},[l,R,T,e,n]);let le=useRef(false),ye=useCallback(()=>{le.current=true;},[]),Se=useCallback(c=>{le.current=false;let g=c.currentTarget.value,h=F.getLocaleInfo(),v=z(g),P;if(C){let x=C(v);x.isIntermediate?P=v:x.value!==null&&y?P=y(x.value):x.value!==null?P=F.format(x.value):P=v,N.current=P.length;}else if(a){let x=B.parse(v);x.isIntermediate?P=v:x.value!==null?P=y?y(x.value):F.format(x.value):P=v===""?"":v,N.current=Oe(g,g.length,P,h,"insertCompositionText");}else P=v,N.current=v.length;e._setLastChangeReason("input"),e.setInputValue(P);},[F,B,a,e,y,C]),fe=useCallback(c=>{let g=c.target.value,h=c.target.selectionStart??g.length,v=c.nativeEvent.inputType,P=F.getLocaleInfo();if(le.current){e.setInputValue(g);return}let x=z(g),M;if(C){let V=C(x);V.isIntermediate?M=x:V.value!==null?M=y?y(V.value):F.format(V.value):x===""?M="":M=x,N.current=M.length;}else if(a){let V=B.parse(x);V.isIntermediate?M=x:V.value!==null?M=y?y(V.value):F.format(V.value):x===""?M="":M=x,y?N.current=M.length:N.current=Oe(g,h,M,P,v);}else M=x,N.current=h;e._setLastChangeReason("input"),e.setInputValue(M);},[F,B,a,e,y,C]),Fe=useCallback(c=>{c.preventDefault();let g=c.clipboardData.getData("text/plain");if(!g)return;let h=g.replace(/[€$£¥₹₺₽﷼฿₩¢₦₨₪₫₱]/g,"").trim(),v=z(h);if(e._setLastChangeReason("paste"),C){let $=C(v);if($.value!==null){let je=y?y($.value):F.format($.value);e.setInputValue(je),N.current=je.length;}return}let P=B.parse(v);if(P.value!==null){let $=F.format(P.value);e.setInputValue($),N.current=$.length;return}let x=F.getLocaleInfo(),M=new RegExp(`[^0-9${Qe(x.decimalSeparator)}${Qe(x.minusSign)}-]`,"g"),V=v.replace(M,""),ce=B.parse(V);if(ce.value!==null){let $=F.format(ce.value);e.setInputValue($),N.current=$.length;}},[B,F,e,y,C]),Pe=useCallback(c=>{if(I==="formatted")return;c.preventDefault();let g=String(e.numberValue??"");c.clipboardData.setData("text/plain",g);},[I,e.numberValue]),te=useCallback(c=>{if(I==="formatted")return;c.preventDefault();let g=String(e.numberValue??"");c.clipboardData.setData("text/plain",g),e.setInputValue("");},[I,e]),pe=useCallback(c=>{if(R||T)return;let g=c.key;if(!c.metaKey&&!c.ctrlKey&&!c.altKey&&s){let h=F.getLocaleInfo();if(g===h.decimalSeparator){let v=n.current;if(v){let P=v.value.indexOf(h.decimalSeparator);if(P!==-1){c.preventDefault(),v.setSelectionRange(P+1,P+1);return}}}}if(g==="Backspace"&&!c.shiftKey&&!c.altKey&&!c.metaKey&&!c.ctrlKey){let h=n.current;if(h){let v=h.selectionStart??0,P=h.selectionEnd??v,x=h.value,M=F.getLocaleInfo();if(v===P&&v>=2&&x[v-1]===M.groupingSeparator){c.preventDefault();let V=x.slice(0,v-2)+x.slice(v),ce=B.parse(V);if(e._setLastChangeReason("input"),ce.value!==null){let $=F.format(ce.value);e.setInputValue($);}else e.setInputValue(V);N.current=v-2;return}}}if(g==="ArrowUp"||g==="ArrowDown"){c.preventDefault();let h=g==="ArrowUp"?1:-1;e._setLastChangeReason("keyboard"),c.shiftKey?h>0?e.increment(D):e.decrement(D):c.metaKey||c.ctrlKey?h>0?e.increment(ae):e.decrement(ae):h>0?e.increment():e.decrement();return}if(g==="PageUp"){c.preventDefault(),e._setLastChangeReason("keyboard"),e.increment(D);return}if(g==="PageDown"){c.preventDefault(),e._setLastChangeReason("keyboard"),e.decrement(D);return}if(g==="Home"){i!==void 0&&(c.preventDefault(),e._setLastChangeReason("keyboard"),e.decrementToMin());return}if(g==="End"){u!==void 0&&(c.preventDefault(),e._setLastChangeReason("keyboard"),e.incrementToMax());return}if(g==="Enter"){e._setLastChangeReason("blur"),e.commit();return}},[R,T,e,D,ae,i,u,F,B,n]),Q=useCallback(c=>{e.setIsFocused(false),e._setLastChangeReason("blur"),e.commit(),K?.(c);},[e,K]),he=useCallback(c=>{e.setIsFocused(true),j?.(c);},[e,j]),_=ke(()=>{e._setLastChangeReason("increment"),e.increment();},{delay:A,interval:k,disabled:R||!e.canIncrement}),Ee=ke(()=>{e._setLastChangeReason("decrement"),e.decrement();},{delay:A,interval:k,disabled:R||!e.canDecrement}),Te=useMemo(()=>{if(e.numberValue!=null)return y?y(e.numberValue):F.format(e.numberValue)},[e.numberValue,F,y]),be=F.getLocaleInfo(),se=e.numberValue!==null&&(i!==void 0&&e.numberValue<i||u!==void 0&&e.numberValue>u)||e.validationState==="invalid",Ne={id:re,htmlFor:q},Me={role:"group","aria-labelledby":t["aria-labelledby"]??re},Ce={id:q,type:"text",inputMode:"decimal",role:"spinbutton",autoComplete:"off",autoCorrect:"off",spellCheck:false,"aria-label":t["aria-label"],"aria-labelledby":t["aria-labelledby"]??re,"aria-describedby":t["aria-describedby"],"aria-valuenow":e.numberValue??void 0,"aria-valuemin":i,"aria-valuemax":u,"aria-valuetext":Te,"aria-disabled":R||void 0,"aria-readonly":T||void 0,"aria-required":L||void 0,"aria-invalid":se?true:void 0,"aria-errormessage":se&&e.validationError?me:void 0,disabled:R,readOnly:T,required:L,value:e.inputValue,onChange:fe,onKeyDown:pe,onBlur:Q,onFocus:he,onPaste:Fe,onCopy:I!=="formatted"?Pe:void 0,onCut:I!=="formatted"?te:void 0,onCompositionStart:ye,onCompositionEnd:Se,style:be.isRTL?{direction:"ltr",textAlign:"right",unicodeBidi:"embed"}:void 0,"data-disabled":R?"":void 0,"data-readonly":T?"":void 0,"data-required":L?"":void 0,"data-invalid":se?"":void 0,"data-rtl":be.isRTL?"":void 0},Ve=E?{type:"hidden",name:E,value:e.numberValue??"","aria-hidden":true}:null,f={type:"button",tabIndex:-1,"aria-label":"Increase",disabled:R||!e.canIncrement,..._,"data-disabled":R||!e.canIncrement?"":void 0},S={type:"button",tabIndex:-1,"aria-label":"Decrease",disabled:R||!e.canDecrement,...Ee,"data-disabled":R||!e.canDecrement?"":void 0};return {labelProps:Ne,groupProps:Me,inputProps:Ce,hiddenInputProps:Ve,incrementButtonProps:f,decrementButtonProps:S,descriptionProps:{id:Ie},errorMessageProps:{id:me,role:"alert","aria-live":"polite"}}}function bt(t,e={}){let{locale:n,formatOptions:r,prefix:o,suffix:i,minimumFractionDigits:u,maximumFractionDigits:d,fixedDecimalScale:s}=e,l=useMemo(()=>Z({locale:n,formatOptions:r,prefix:o,suffix:i,minimumFractionDigits:u,maximumFractionDigits:d,fixedDecimalScale:s}),[n,JSON.stringify(r),o,i,u,d,s]);return useMemo(()=>t==null?"":l.format(t),[t,l])}var Le=createContext(null);function H(){let t=useContext(Le);if(!t)throw new Error("[raqam] NumberField sub-components must be used inside <NumberField.Root>.");return t}function nt(t,e={}){let{direction:n="horizontal",pixelSensitivity:r=4}=e,[o,i]=useState(false),u=useRef(t);u.current=t;let d=useRef(n);d.current=n;let s=useRef(r);s.current=r;let l=useRef(false),a=useRef(0),m=useRef(null),b=useRef({x:0,y:0}),[E,R]=useState({x:0,y:0}),T=useRef(p=>{if(!l.current)return;let I=b.current.x+p.movementX,A=b.current.y+p.movementY;b.current={x:I,y:A},R({x:I,y:A});let k=d.current,y=0;k==="horizontal"?y=p.movementX:k==="vertical"?y=-p.movementY:y=Math.abs(p.movementX)>=Math.abs(p.movementY)?p.movementX:-p.movementY,a.current+=y;let C=s.current;for(;a.current>=C;)u.current.increment(),a.current-=C;for(;a.current<=-C;)u.current.decrement(),a.current+=C;}),L=useRef(()=>{document.pointerLockElement===m.current?(l.current=true,a.current=0,i(true),u.current.setIsScrubbing(true),document.addEventListener("mousemove",T.current)):(l.current=false,a.current=0,document.removeEventListener("mousemove",T.current),i(false),u.current.setIsScrubbing(false));});useEffect(()=>{let p=L.current;return document.addEventListener("pointerlockchange",p),()=>{document.removeEventListener("pointerlockchange",p),document.removeEventListener("mousemove",T.current);}},[]);let j=useCallback(p=>{if(u.current.options.disabled||u.current.options.readOnly||p.button!==0)return;let I=p.currentTarget;m.current=I,b.current={x:p.clientX,y:p.clientY},R({x:p.clientX,y:p.clientY}),I.requestPointerLock();},[]),K=useCallback(p=>{u.current.options.disabled||u.current.options.readOnly||(p.key==="ArrowRight"||p.key==="ArrowUp"?(p.preventDefault(),u.current.increment()):(p.key==="ArrowLeft"||p.key==="ArrowDown")&&(p.preventDefault(),u.current.decrement()));},[]),J=n==="horizontal"?"ew-resize":n==="vertical"?"ns-resize":"move",Y={role:"slider",tabIndex:t.options.disabled?-1:0,style:{cursor:t.options.disabled?void 0:J,userSelect:"none",WebkitUserSelect:"none"},"aria-label":"Scrub to change value","data-scrubbing":o?"":void 0,onPointerDown:j,onKeyDown:K};return {isScrubbing:o,scrubAreaProps:Y,virtualCursor:E}}function ee(t,e,n){return e?typeof e=="function"?e(t.props,n):Rt.cloneElement(e,Object.assign({},t.props,e.props)):t}function Lt(t,e){let{options:n}=t;return {"data-disabled":n.disabled?"":void 0,"data-readonly":n.readOnly?"":void 0,"data-required":n.required?"":void 0,"data-scrubbing":t.isScrubbing?"":void 0,"data-focused":t.isFocused?"":void 0,"data-invalid":e?"":void 0}}var It=new Set(["className","style","id","tabIndex","title","role","aria-label","data-testid","onClick","onMouseEnter","onMouseLeave"]);function yt(t){let e={},n={};for(let[r,o]of Object.entries(t))It.has(r)||r.startsWith("data-")||r.startsWith("aria-")?n[r]=o:e[r]=o;return {fieldProps:e,divProps:n}}var St=forwardRef(function({children:e,onValueChange:n,onValueCommitted:r,...o},i){let u=useRef(null),{fieldProps:d,divProps:s}=yt(o),l=d,a=useRef(n);a.current=n;let m=useRef(null),b={...l,onChange:L=>{l.onChange?.(L),a.current&&m.current&&a.current(L,{reason:m.current._getLastChangeReason(),formattedValue:m.current.inputValue});}},E=Ae(b);m.current=E;let R=_e(b,E,u),T=E.validationState==="invalid"||E.numberValue!==null&&(l.minValue!==void 0&&E.numberValue<l.minValue||l.maxValue!==void 0&&E.numberValue>l.maxValue);return jsx(Le.Provider,{value:{state:E,aria:R,inputRef:u,props:b},children:jsx("div",{ref:i,...s,...Lt(E,T),children:e})})}),Ft=forwardRef(function({render:e,children:n,...r},o){let{aria:i,state:u}=H(),d=jsx("label",{ref:o,...i.labelProps,...r,children:n});return ee(d,e,u)}),Pt=forwardRef(function({render:e,children:n,...r},o){let{aria:i,state:u}=H(),d=jsx("div",{ref:o,...i.groupProps,...r,children:n});return ee(d,e,u)}),ht=forwardRef(function({render:e,...n},r){let{aria:o,state:i,inputRef:u}=H(),d=jsx("input",{ref:u,...o.inputProps,...n});return ee(d,e,i)}),Et=forwardRef(function({render:e,children:n,...r},o){let{aria:i,state:u}=H(),d=jsx("button",{ref:o,...i.incrementButtonProps,...r,children:n??"+"});return ee(d,e,u)}),Tt=forwardRef(function({render:e,children:n,...r},o){let{aria:i,state:u}=H(),d=jsx("button",{ref:o,...i.decrementButtonProps,...r,children:n??"\u2212"});return ee(d,e,u)}),Nt=function(){let{aria:e}=H();return e.hiddenInputProps?jsx("input",{...e.hiddenInputProps}):null},Mt=forwardRef(function({render:e,children:n,direction:r="horizontal",pixelSensitivity:o=4,...i},u){let{state:d}=H(),{scrubAreaProps:s}=nt(d,{direction:r,pixelSensitivity:o}),l=jsx("span",{ref:u,...s,...i,children:n});return ee(l,e,d)}),Ct=forwardRef(function({render:e,children:n,style:r,...o},i){let{state:u}=H();if(!u.isScrubbing)return null;let d=jsx("span",{ref:i,style:{position:"fixed",pointerEvents:"none",zIndex:9999,...r},...o,children:n});return ee(d,e,u)}),Vt=forwardRef(function({children:e,...n},r){let{aria:o}=H();return jsx("p",{ref:r,...o.descriptionProps,...n,children:e})}),Dt=forwardRef(function({children:e,...n},r){let{aria:o,state:i}=H(),u=e??i.validationError??null;return u?jsx("p",{ref:r,...o.errorMessageProps,...n,children:u}):null}),Ht=forwardRef(function({render:e,...n},r){let{state:o}=H(),i=jsx("span",{ref:r,"aria-hidden":"true",...n,children:o.inputValue});return ee(i,e,o)}),wt={Root:St,Label:Ft,Group:Pt,Input:ht,Increment:Et,Decrement:Tt,HiddenInput:Nt,ScrubArea:Mt,ScrubAreaCursor:Ct,Description:Vt,ErrorMessage:Dt,Formatted:Ht};export{wt as NumberField,Le as NumberFieldContext,De as useControllableState,_e as useNumberField,H as useNumberFieldContext,bt as useNumberFieldFormat,Ae as useNumberFieldState};//# sourceMappingURL=react.js.map
|
|
2
|
+
import Dt,{createContext,forwardRef,useRef,useMemo,useCallback,useState,useId,useLayoutEffect,useEffect,useContext}from'react';import {jsx}from'react/jsx-runtime';function qe({value:t,defaultValue:e,onChange:r}){let n=t!==void 0,i=useRef(n);typeof window<"u"&&window.__DEV__!==false&&i.current!==n&&console.warn(`[raqam] Component is changing from ${i.current?"controlled":"uncontrolled"} to ${n?"controlled":"uncontrolled"}. Decide between using a controlled or uncontrolled component and don't switch.`);let[a,l]=useState(e),p=useCallback(c=>{let m=typeof c=="function"?c(n?t:a):c;n||l(m),r?.(m);},[n,t,a,r]);return [n?t:a,p]}var nt=new Map;function We(t,e){let r=`${t??""}::${JSON.stringify(e??{})}`,n=nt.get(r);return n||(n=new Intl.NumberFormat(t,e),nt.set(r,n)),n}function bt(t,e){let r=We(t,e),n=We(t,{minimumFractionDigits:1,maximumFractionDigits:1,numberingSystem:e?.numberingSystem}),i=n.formatToParts(-12345.6),a=".",l=",",p="-",c="0";for(let o of i)o.type==="decimal"&&(a=o.value),o.type==="group"&&(l=o.value),o.type==="minusSign"&&(p=o.value);for(let o of n.formatToParts(0))if(o.type==="integer"){c=o.value;break}let m=/^(ar|he|fa|ur|syc|nqo|ug|yi)/i,b=r.resolvedOptions().locale,u=m.test(b);return {decimalSeparator:a,groupingSeparator:l,minusSign:p,zero:c,isRTL:u}}function X(t){let e={...t.formatOptions};t.minimumFractionDigits!==void 0&&(e.minimumFractionDigits=t.minimumFractionDigits),t.maximumFractionDigits!==void 0&&(e.maximumFractionDigits=t.maximumFractionDigits),t.fixedDecimalScale&&t.maximumFractionDigits!==void 0&&(e.minimumFractionDigits=t.maximumFractionDigits,e.maximumFractionDigits=t.maximumFractionDigits);let r=We(t.locale,e),n=null;function i(){return n||(n=bt(t.locale,e)),n}function a(c){let m=r.formatToParts(c);if(!t.prefix&&!t.suffix)return m;let b=[];return t.prefix&&b.push({type:"literal",value:t.prefix}),b.push(...m),t.suffix&&b.push({type:"literal",value:t.suffix}),b}function l(c){if(!Number.isFinite(c))return "";let m=r.format(c);return (t.prefix??"")+m+(t.suffix??"")}function p(c){let m=a(c);return {formatted:m.map(u=>u.value).join(""),parts:m}}return {format:l,formatToParts:a,getLocaleInfo:i,formatResult:p}}var gt=[[1632,1641],[1776,1785],[2406,2415],[2534,2543],[3664,3673]],vt=[...gt];function $(t){return /[^\u0020-\u007e]/.test(t)?t.replace(/\p{Nd}/gu,e=>{let r=e.codePointAt(0);for(let[i,a]of vt)if(r>=i&&r<=a)return String(r-i);let n=Number.parseInt(e,10);return Number.isNaN(n)?e:String(n)}):t}function Je(t,e){if(!e||e==="0")return t;let r=e.codePointAt(0);return r===void 0?t:t.replace(/[0-9]/g,n=>String.fromCodePoint(r+(n.charCodeAt(0)-48)))}function xt(t,e){return e?!!(/^-0+$/.test(t)||/\.$/.test(t)||/\.\d*0$/.test(t)||/^-?\.\d+$/.test(t)):false}function He(t={}){let e=t.allowNegative??true,r=t.allowDecimal??true,n=t.formatOptions?.style==="percent",i=X({locale:t.locale,formatOptions:t.formatOptions,prefix:t.prefix,suffix:t.suffix}),a="";if(t.formatOptions?.style==="currency")try{a=i.formatToParts(1).filter(b=>b.type==="currency").map(b=>b.value).join("");}catch{a="";}function l(){return i.getLocaleInfo()}function p(b){let u=l(),o=$(b);a&&(o=o.split(a).join(""));let L=o.match(/^\((.+)\)$/);if(L&&(o=`-${L[1]}`),t.prefix&&o.startsWith(t.prefix)&&(o=o.slice(t.prefix.length)),t.suffix&&o.endsWith(t.suffix)&&(o=o.slice(0,-t.suffix.length)),u.groupingSeparator&&(o=o.split(u.groupingSeparator).join("")),u.decimalSeparator!=="."&&(o=o.split(u.decimalSeparator).join(".")),u.minusSign!=="-"&&(o=o.split(u.minusSign).join("-")),o.includes("\u2212")&&(o=o.split("\u2212").join("-")),o=o.replace(/[^\d.\-]/g,"").trim(),o.includes("-")){let R=o.startsWith("-");o=o.replace(/-/g,""),R&&(o=`-${o}`);}return o}function c(b){if(!b||b.trim()==="")return {value:null,isValid:false,isIntermediate:false};let u=p(b);if(u==="")return {value:null,isValid:false,isIntermediate:false};if(u==="-")return {value:null,isValid:false,isIntermediate:e};if(u==="."||u==="-.")return {value:null,isValid:false,isIntermediate:r&&(u==="."||e)};if(!e&&u.startsWith("-"))return {value:null,isValid:false,isIntermediate:false};if(!r&&u.includes("."))return {value:null,isValid:false,isIntermediate:false};if(!/^-?(?:\d+\.?\d*|\.\d+)$/.test(u))return {value:null,isValid:false,isIntermediate:false};let o=Number.parseFloat(u);return Number.isFinite(o)?(Object.is(o,-0)&&(o=0),n&&o!==0&&(o=Number((o/100).toPrecision(15))),{value:o,isValid:true,isIntermediate:xt(u,r)}):{value:null,isValid:false,isIntermediate:false}}function m(b){return c(b).isIntermediate}return {parse:c,isIntermediate:m,getLocaleInfo:l}}function Ge(t,e,r){let n=t;return e!==void 0&&(n=Math.max(n,e)),r!==void 0&&(n=Math.min(n,r)),n}function rt(t,e){let n=10**Math.max(it(t),it(e));return Math.round(t*n+e*n)/n}function it(t){if(!Number.isFinite(t))return 0;let e=String(t),r=e.indexOf("e");if(r!==-1){let i=Number(e.slice(r+1)),a=e.indexOf("."),l=a===-1?0:r-a-1;return Math.max(0,l-i)}let n=e.indexOf(".");return n===-1?0:e.length-n-1}function Xe(t){let{locale:e,formatOptions:r,minValue:n,maxValue:i,step:a=1,largeStep:l,smallStep:p,allowNegative:c=true,allowDecimal:m=true,maximumFractionDigits:b,minimumFractionDigits:u,fixedDecimalScale:o,clampBehavior:L="blur",prefix:R,suffix:M,allowOutOfRange:I=false,validate:W,onRawChange:J,formatValue:Z}=t,me=m?u:0,y=m?b:0,O=m?o:false,ie=useMemo(()=>X({locale:e,formatOptions:r,prefix:R,suffix:M,minimumFractionDigits:me,maximumFractionDigits:y,fixedDecimalScale:O}),[e,JSON.stringify(r),R,M,me,y,O]),G=useMemo(()=>He({locale:e,formatOptions:r,allowNegative:c,allowDecimal:m,prefix:R,suffix:M}),[e,JSON.stringify(r),c,m,R,M]),[v,C]=qe({value:t.value,defaultValue:t.defaultValue??null,onChange:t.onChange}),ee=useRef(t.value??t.defaultValue??null),A=useCallback(d=>Z?Z(Object.is(d,-0)?0:d):ie.format(Object.is(d,-0)?0:d),[ie,Z]),xe=useMemo(()=>t.defaultValue!=null?A(t.defaultValue):t.value!=null?A(t.value):"",[]),[oe,U]=useState(xe),ae=useRef(xe),[de,le]=useState(t.defaultValue!=null?String(t.defaultValue):null),Se=useCallback(d=>{if(!W)return {validationState:"valid",validationError:null};let D=W(d);return D===false?{validationState:"invalid",validationError:null}:typeof D=="string"?{validationState:"invalid",validationError:D}:{validationState:"valid",validationError:null}},[W]),Re=useMemo(()=>{let d=t.defaultValue??t.value??null;return Se(d??null)},[]),[Ne,fe]=useState(Re.validationState),[Ee,T]=useState(Re.validationError),[Be,Te]=useState(false),[z,k]=useState(false),ue=useRef("input"),V=useCallback(d=>{ue.current=d;},[]),Fe=useCallback(()=>ue.current,[]),te=t.value,De=useRef(te);if(!Object.is(De.current,te)&&(De.current=te,!Object.is(te,ee.current))){ee.current=te;let d=Object.is(te,-0)?0:te,D=d!=null&&Number.isFinite(d),N=D?A(d):"";ae.current=N,U(N),le(D?String(d):null);}let ye=`${e??""}|${JSON.stringify(r??{})}|${R??""}|${M??""}|${me??""}|${y??""}|${O??""}`,Me=useRef(ye);if(Me.current!==ye&&(Me.current=ye,v!=null&&Number.isFinite(v)&&!z)){let d=A(v);d!==oe&&(U(d),ae.current=d);}let se=useCallback(d=>{let{validationState:D,validationError:N}=Se(d);fe(D),T(N);},[Se]),je=useCallback((d,D)=>{let N=D!==void 0?D:G.parse(d).value;L==="strict"&&!I&&N!==null&&(n!==void 0&&N<n||i!==void 0&&N>i)||(U(d),ee.current=N,C(N),le(N!==null?d:null),J?.(N!==null?d:null),se(N));},[G,L,I,n,i,C,J,se]),Y=useCallback(d=>{if(ee.current=d,C(d),d!=null){let D=A(d);U(D),ae.current=D;let N=String(d);le(N),J?.(N);}else U(""),ae.current="",le(null),J?.(null);se(d);},[A,C,J,se]),_e=useCallback(()=>{if(v==null){U(""),ae.current="";return}let d=v;L==="blur"&&!I&&(d=Ge(v,n,i)),Object.is(d,-0)&&(d=0);let D=A(d);U(D),ae.current=D;let N=d;if(!Z){let _=G.parse(D).value;_!==null&&Number.isFinite(_)&&A(_)===D&&(N=_);}N!==v&&(ee.current=N,C(N)),se(N);},[v,L,I,n,i,G,A,Z,C,se]),ne=v!=null&&Number.isFinite(v)?v:null,$e=l??a*10,Ke=p??a*.1,Ue=!t.disabled&&!t.readOnly&&(I||i===void 0||(ne??Number.NEGATIVE_INFINITY)<i),Ce=!t.disabled&&!t.readOnly&&(I||n===void 0||(ne??Number.POSITIVE_INFINITY)>n),tt=useCallback(d=>{let _=rt(ne??0,d??a),Ve=I?_:Ge(_,n,i);Y(Ve);},[ne,a,n,i,I,Y]),Le=useCallback(d=>{let _=rt(ne??0,-(d??a)),Ve=I?_:Ge(_,n,i);Y(Ve);},[ne,a,n,i,I,Y]),ze=useCallback(()=>{i!==void 0&&Y(i);},[i,Y]),Ye=useCallback(()=>{n!==void 0&&Y(n);},[n,Y]);return {inputValue:oe,numberValue:ne,rawValue:de,canIncrement:Ue,canDecrement:Ce,isScrubbing:Be,setIsScrubbing:Te,isFocused:z,setIsFocused:k,validationState:Ne,validationError:Ee,_setLastChangeReason:V,_getLastChangeReason:Fe,setInputValue:je,setNumberValue:Y,commit:_e,increment:tt,decrement:Le,incrementToMax:ze,decrementToMin:Ye,options:{...t,step:a,largeStep:$e,smallStep:Ke}}}function ot(t,e){return t>="0"&&t<="9"||t===e.decimalSeparator||t===e.minusSign||t==="-"||t==="."&&e.decimalSeparator!=="."&&e.groupingSeparator!=="."}function St(t,e,r){let n=$(t),i=0;for(let a=0;a<e&&a<n.length;a++)ot(n[a],r)&&i++;return i}function Rt(t,e){let r=t.length,n=new Array(r+1).fill(true);for(let i=0;i<r;i++)t[i]===e.groupingSeparator&&(n[i+1]=false);return n[0]=true,n[r]=true,n}function Pe(t,e,r,n,i){let a=$(t),l=St(a,e,n),p=t.slice(0,e),c=p.includes("-")||p.includes(n.minusSign),m=r.includes("-")||r.includes(n.minusSign);c&&!m&&(l=Math.max(0,l-1)),i==="deleteContentBackward"&&e>0&&t[e-1]===n.groupingSeparator&&(l=Math.max(0,l-1));let b=Rt(r,n),u=$(r),o=0,L=0;for(let R=0;R<u.length;R++){if(o===l){L=R;break}ot(u[R],n)&&o++,L=R+1;}return l>0&&o<l&&(L=r.length),L=Ft(L,b),L}function Ft(t,e){if(e[t])return t;for(let r=t+1;r<e.length;r++)if(e[r])return r;for(let r=t-1;r>=0;r--)if(e[r])return r;return 0}function Qe(t,e={}){let{delay:r=400,interval:n=200,disabled:i=false}=e,a=useRef(t);useEffect(()=>{a.current=t;});let l=useRef(r);useEffect(()=>{l.current=r;});let p=useRef(n);useEffect(()=>{p.current=n;});let c=useRef(null),m=useRef(null),b=useRef(false),u=useCallback(()=>{b.current=false,c.current!==null&&(clearTimeout(c.current),c.current=null),m.current!==null&&(clearTimeout(m.current),m.current=null);},[]),o=useCallback(I=>{if(!b.current)return;a.current();let W=Math.max(50,Math.floor(I/2));m.current=setTimeout(()=>{o(W);},I);},[]),L=useCallback(I=>{i||I.button!==0&&I.pointerType==="mouse"||(a.current(),b.current=true,c.current=setTimeout(()=>{o(p.current);},l.current));},[i,o]),R=useCallback(I=>{I.preventDefault(),u();},[u]),M=useCallback(I=>{u();},[u]);return useEffect(()=>u,[u]),{onPointerDown:L,onPointerUp:R,onPointerLeave:M}}function lt(t){return t.replace(/[.*+?^${}()|[\]\\\-]/g,"\\$&")}function Pt(t){let e=t.replace(/\s+/g,"");if(/^[+-]?(?:\d+\.?\d*|\.\d+)[eE][+-]?\d+$/.test(e)){let n=Number(e);return Number.isFinite(n)?n:null}let r=e.match(/^([+-]?(?:\d+\.?\d*|\.\d+))(k|m|b|t|thousand|million|billion|trillion)$/i);if(r){let n={k:1e3,thousand:1e3,m:1e6,million:1e6,b:1e9,billion:1e9,t:1e12,trillion:1e12},i=Number(r[1])*n[r[2].toLowerCase()];return Number.isFinite(i)?i:null}return null}function Ze(t,e,r){let{locale:n,formatOptions:i,minValue:a,maxValue:l,allowNegative:p=true,allowDecimal:c=true,allowMouseWheel:m=false,liveFormat:b=true,prefix:u,suffix:o,name:L,disabled:R,readOnly:M,required:I,onFocus:W,onBlur:J,maximumFractionDigits:Z,minimumFractionDigits:me,fixedDecimalScale:y,copyBehavior:O="formatted",stepHoldDelay:ie=400,stepHoldInterval:G=200,formatValue:v,parseValue:C}=t,ee=i?.notation,A=b&&ee!=="compact"&&ee!=="scientific"&&ee!=="engineering",{step:xe=1,largeStep:oe=xe*10,smallStep:U=xe*.1}=e.options,ae=useId(),de=t.id??`raqam-${ae}`,le=`${de}-label`,Se=`${de}-description`,Re=`${de}-error`,Ne=c?me:0,fe=c?Z:0,Ee=c?y:false,T=useMemo(()=>X({locale:n,formatOptions:i,prefix:u,suffix:o,minimumFractionDigits:Ne,maximumFractionDigits:fe,fixedDecimalScale:Ee}),[n,JSON.stringify(i),u,o,Ne,fe,Ee]),Be=i?.style==="percent",Te=c?Be?20:fe:0,z=useMemo(()=>X({locale:n,formatOptions:i,prefix:u,suffix:o,minimumFractionDigits:0,maximumFractionDigits:Te,fixedDecimalScale:false}),[n,JSON.stringify(i),u,o,Te]),k=useMemo(()=>He({locale:n,formatOptions:i,allowNegative:p,allowDecimal:c,prefix:u,suffix:o}),[n,JSON.stringify(i),p,c,u,o]),ue=useCallback((f,S)=>{let P=T.getLocaleInfo(),g=S.lastIndexOf(P.decimalSeparator);if(g===-1&&P.decimalSeparator!=="."&&P.groupingSeparator!=="."&&(g=S.lastIndexOf(".")),g===-1||!/\d/.test($(S.slice(0,g))))return null;let F=$(S.slice(g+1)).match(/^\d+/);if(!F)return null;let s=Math.min(F[0].length,fe??20,20);return s===0?null:X({locale:n,formatOptions:i,prefix:u,suffix:o,minimumFractionDigits:s,maximumFractionDigits:s}).format(f)},[T,n,JSON.stringify(i),u,o,fe]),V=useRef(null);useLayoutEffect(()=>{V.current!==null&&r.current&&document.activeElement===r.current&&(r.current.setSelectionRange(V.current,V.current),V.current=null);},[e.inputValue,r]),useEffect(()=>{let f=r.current;if(!f||!m)return;let S=P=>{R||M||document.activeElement===f&&(P.preventDefault(),e._setLastChangeReason("wheel"),P.deltaY<0?e.increment():e.decrement());};return f.addEventListener("wheel",S,{passive:false}),()=>f.removeEventListener("wheel",S)},[m,R,M,e,r]);let Fe=useRef(false),te=useCallback(()=>{Fe.current=true;},[]),De=useCallback(f=>{Fe.current=false;let S=f.currentTarget.value,P=T.getLocaleInfo(),g=$(S),F;if(C){let s=C(g);s.isIntermediate?F=g:s.value!==null&&v?F=v(s.value):s.value!==null?F=T.format(s.value):F=g,V.current=F.length;}else if(A){let s=k.parse(g);s.isIntermediate?F=Je(g,P.zero):s.value!==null?F=v?v(s.value):z.format(s.value):F=g===""?"":g,V.current=Pe(S,S.length,F,P,"insertCompositionText");}else F=g,V.current=g.length;e._setLastChangeReason("input"),e.setInputValue(F);},[T,z,k,A,e,v,C]),ye=useCallback(f=>{let S=f.target.value,P=f.target.selectionStart??S.length,g=f.nativeEvent.inputType,F=T.getLocaleInfo();if(Fe.current){e.setInputValue(S);return}let s=$(S);p||(s=s.split("-").join("").split(F.minusSign).join("")),c?F.decimalSeparator!=="."&&F.groupingSeparator!=="."&&(s=s.replace(/\./g,(H,x,h)=>/\d/.test(h[x-1]??"")||/\d/.test(h[x+1]??"")?F.decimalSeparator:".")):s=s.split(".").join("").split(F.decimalSeparator).join("");let E,pe;if(C){let H=C(s);H.isIntermediate?E=s:H.value!==null?E=v?v(H.value):T.format(H.value):s===""?E="":E=s,V.current=E.length;}else if(A){let H=k.parse(s);if(H.isIntermediate)E=(!v&&H.value!==null?ue(H.value,s):null)??Je(s,F.zero);else if(H.value!==null)if(v)E=v(H.value);else {E=z.format(H.value);let x=k.parse(E).value;pe=x!==null&&Number.isFinite(x)&&z.format(x)===E?x:H.value;}else s===""||!/\d/.test(s)?E="":E=s;v?V.current=E.length:V.current=Pe(S,P,E,F,g);}else E=s,V.current=P;e._setLastChangeReason("input"),e.setInputValue(E,pe);},[T,z,k,A,e,v,C,ue]),Me=useCallback(f=>{f.preventDefault();let S=f.clipboardData.getData("text/plain");if(!S)return;let P=S.replace(/[€$£¥₹₺₽﷼฿₩¢₦₨₪₫₱]/g,"").trim(),g=$(P);if(!p){let h=T.getLocaleInfo();g=g.split("-").join("").split(h.minusSign).join("");}if(!c){let h=T.getLocaleInfo();g=g.split(".").join("").split(h.decimalSeparator).join("");}if(e._setLastChangeReason("paste"),C){let h=C(g);if(h.value!==null){let w=v?v(h.value):T.format(h.value);e.setInputValue(w,h.value),V.current=w.length;}return}let F=Pt(g);if(F!==null){let w=i?.style==="percent"?F/100:F,be=v?v(w):T.format(w);e.setInputValue(be,w),V.current=be.length;return}let s=k.parse(g);if(s.value!==null){let h=T.format(s.value);e.setInputValue(h,s.value),V.current=h.length;return}let E=T.getLocaleInfo(),pe=new RegExp(`[^0-9${lt(E.decimalSeparator)}${lt(E.minusSign)}-]`,"g"),H=g.replace(pe,""),x=k.parse(H);if(x.value!==null){let h=T.format(x.value);e.setInputValue(h,x.value),V.current=h.length;}},[k,T,e,v,C]),se=useCallback(f=>{if(O==="formatted")return;f.preventDefault();let S=String(e.numberValue??"");f.clipboardData.setData("text/plain",S);},[O,e.numberValue]),je=useCallback(f=>{if(O==="formatted")return;f.preventDefault();let S=String(e.numberValue??"");f.clipboardData.setData("text/plain",S),e.setInputValue("");},[O,e]),Y=useCallback(f=>{if(R||M)return;let S=f.key;if(!f.metaKey&&!f.ctrlKey&&!f.altKey&&c){let P=T.getLocaleInfo();if(S===P.decimalSeparator||S==="."&&P.decimalSeparator!=="."&&P.groupingSeparator!=="."){let F=r.current;if(F){let s=F.value.indexOf(P.decimalSeparator);if(s!==-1){f.preventDefault(),F.setSelectionRange(s+1,s+1);return}}}}if(S==="Backspace"&&!f.shiftKey&&!f.altKey&&!f.metaKey&&!f.ctrlKey){let P=r.current;if(P){let g=P.selectionStart??0,F=P.selectionEnd??g,s=P.value,E=T.getLocaleInfo();if(g===F&&g>=2&&s[g-1]===E.groupingSeparator){f.preventDefault();let x=s.slice(0,g-2)+s.slice(g),h=k.parse(x);e._setLastChangeReason("input");let w;h.value!==null?(w=ue(h.value,x)??z.format(h.value),e.setInputValue(w,h.value)):(w=x,e.setInputValue(x)),V.current=Pe(x,g-2,w,E,"deleteContentBackward");return}let pe=x=>x!==void 0&&/\p{Nd}/u.test(x),H=x=>x!==void 0&&!pe(x)&&x!==E.decimalSeparator&&x!==E.minusSign&&x!=="-";if(g===F&&g===s.length&&g>=1&&H(s[g-1])){let x=g;for(;x>0&&H(s[x-1]);)x--;if(x>0&&pe(s[x-1])){f.preventDefault();let h=s.slice(0,x-1)+s.slice(x),w=k.parse(h);e._setLastChangeReason("input");let be;w.value!==null&&/\p{Nd}/u.test(h)?(be=ue(w.value,h)??z.format(w.value),e.setInputValue(be,w.value)):(be="",e.setInputValue("")),V.current=Pe(h,x-1,be,E,"deleteContentBackward");return}}}}if(S==="ArrowUp"||S==="ArrowDown"){f.preventDefault();let P=S==="ArrowUp"?1:-1;e._setLastChangeReason("keyboard"),f.shiftKey?P>0?e.increment(oe):e.decrement(oe):f.metaKey||f.ctrlKey?P>0?e.increment(U):e.decrement(U):P>0?e.increment():e.decrement();return}if(S==="PageUp"){f.preventDefault(),e._setLastChangeReason("keyboard"),e.increment(oe);return}if(S==="PageDown"){f.preventDefault(),e._setLastChangeReason("keyboard"),e.decrement(oe);return}if(S==="Home"){a!==void 0&&(f.preventDefault(),e._setLastChangeReason("keyboard"),e.decrementToMin());return}if(S==="End"){l!==void 0&&(f.preventDefault(),e._setLastChangeReason("keyboard"),e.incrementToMax());return}if(S==="Enter"){e._setLastChangeReason("blur"),e.commit();return}},[R,M,e,oe,U,a,l,T,z,k,r,c,ue]),_e=useCallback(f=>{e.setIsFocused(false),e._setLastChangeReason("blur"),e.commit(),J?.(f);},[e,J]),ne=useCallback(f=>{e.setIsFocused(true),W?.(f);},[e,W]),$e=Qe(()=>{e._setLastChangeReason("increment"),e.increment();},{delay:ie,interval:G,disabled:R||!e.canIncrement}),Ke=Qe(()=>{e._setLastChangeReason("decrement"),e.decrement();},{delay:ie,interval:G,disabled:R||!e.canDecrement}),Ue=useMemo(()=>{if(e.numberValue!=null)return v?v(e.numberValue):T.format(e.numberValue)},[e.numberValue,T,v]),Ce=T.getLocaleInfo(),Le=e.numberValue!==null&&(a!==void 0&&e.numberValue<a||l!==void 0&&e.numberValue>l)||e.validationState==="invalid",ze={id:le,htmlFor:de},Ye={role:"group","aria-labelledby":t["aria-labelledby"]??le},d={id:de,type:"text",inputMode:"decimal",role:"spinbutton",autoComplete:"off",autoCorrect:"off",spellCheck:false,"aria-label":t["aria-label"],"aria-labelledby":t["aria-labelledby"]??le,"aria-describedby":t["aria-describedby"],"aria-valuenow":e.numberValue??void 0,"aria-valuemin":a,"aria-valuemax":l,"aria-valuetext":Ue,"aria-disabled":R||void 0,"aria-readonly":M||void 0,"aria-required":I||void 0,"aria-invalid":Le?true:void 0,"aria-errormessage":Le&&e.validationError?Re:void 0,disabled:R,readOnly:M,required:I,value:e.inputValue,onChange:ye,onKeyDown:Y,onBlur:_e,onFocus:ne,onPaste:Me,onCopy:O!=="formatted"?se:void 0,onCut:O!=="formatted"?je:void 0,onCompositionStart:te,onCompositionEnd:De,style:Ce.isRTL?{direction:"ltr",textAlign:"right",unicodeBidi:"embed"}:void 0,"data-disabled":R?"":void 0,"data-readonly":M?"":void 0,"data-required":I?"":void 0,"data-invalid":Le?"":void 0,"data-rtl":Ce.isRTL?"":void 0},D=L?{type:"hidden",name:L,value:e.numberValue??"","aria-hidden":true}:null,N={type:"button",tabIndex:-1,"aria-label":"Increase",disabled:R||!e.canIncrement,...$e,"data-disabled":R||!e.canIncrement?"":void 0},_={type:"button",tabIndex:-1,"aria-label":"Decrease",disabled:R||!e.canDecrement,...Ke,"data-disabled":R||!e.canDecrement?"":void 0};return {labelProps:ze,groupProps:Ye,inputProps:d,hiddenInputProps:D,incrementButtonProps:N,decrementButtonProps:_,descriptionProps:{id:Se},errorMessageProps:{id:Re,role:"alert","aria-live":"polite"}}}function ht(t,e={}){let{locale:r,formatOptions:n,prefix:i,suffix:a,minimumFractionDigits:l,maximumFractionDigits:p,fixedDecimalScale:c}=e,m=useMemo(()=>X({locale:r,formatOptions:n,prefix:i,suffix:a,minimumFractionDigits:l,maximumFractionDigits:p,fixedDecimalScale:c}),[r,JSON.stringify(n),i,a,l,p,c]);return useMemo(()=>t==null?"":m.format(t),[t,m])}var ke=createContext(null);function B(){let t=useContext(ke);if(!t)throw new Error("[raqam] NumberField sub-components must be used inside <NumberField.Root>.");return t}function mt(t,e={}){let{direction:r="horizontal",pixelSensitivity:n=4}=e,[i,a]=useState(false),l=useRef(t);l.current=t;let p=useRef(r);p.current=r;let c=useRef(n);c.current=n;let m=useRef(false),b=useRef(0),u=useRef(null),o=useRef({x:0,y:0}),[L,R]=useState({x:0,y:0}),M=useRef(y=>{if(!m.current)return;let O=o.current.x+y.movementX,ie=o.current.y+y.movementY;o.current={x:O,y:ie},R({x:O,y:ie});let G=p.current,v=0;G==="horizontal"?v=y.movementX:G==="vertical"?v=-y.movementY:v=Math.abs(y.movementX)>=Math.abs(y.movementY)?y.movementX:-y.movementY,b.current+=v;let C=c.current;for(;b.current>=C;)l.current.increment(),b.current-=C;for(;b.current<=-C;)l.current.decrement(),b.current+=C;}),I=useRef(()=>{document.pointerLockElement===u.current?(m.current=true,b.current=0,a(true),l.current.setIsScrubbing(true),document.addEventListener("mousemove",M.current)):(m.current=false,b.current=0,document.removeEventListener("mousemove",M.current),a(false),l.current.setIsScrubbing(false));});useEffect(()=>{let y=I.current;return document.addEventListener("pointerlockchange",y),()=>{document.removeEventListener("pointerlockchange",y),document.removeEventListener("mousemove",M.current);}},[]);let W=useCallback(y=>{if(l.current.options.disabled||l.current.options.readOnly||y.button!==0)return;let O=y.currentTarget;u.current=O,o.current={x:y.clientX,y:y.clientY},R({x:y.clientX,y:y.clientY}),O.requestPointerLock();},[]),J=useCallback(y=>{l.current.options.disabled||l.current.options.readOnly||(y.key==="ArrowRight"||y.key==="ArrowUp"?(y.preventDefault(),l.current.increment()):(y.key==="ArrowLeft"||y.key==="ArrowDown")&&(y.preventDefault(),l.current.decrement()));},[]),Z=r==="horizontal"?"ew-resize":r==="vertical"?"ns-resize":"move",me={role:"slider",tabIndex:t.options.disabled?-1:0,style:{cursor:t.options.disabled?void 0:Z,userSelect:"none",WebkitUserSelect:"none"},"aria-label":"Scrub to change value","data-scrubbing":i?"":void 0,onPointerDown:W,onKeyDown:J};return {isScrubbing:i,scrubAreaProps:me,virtualCursor:L}}function ce(t,e,r){return e?typeof e=="function"?e(t.props,r):Dt.cloneElement(e,Object.assign({},t.props,e.props)):t}function Mt(t,e){let{options:r}=t;return {"data-disabled":r.disabled?"":void 0,"data-readonly":r.readOnly?"":void 0,"data-required":r.required?"":void 0,"data-scrubbing":t.isScrubbing?"":void 0,"data-focused":t.isFocused?"":void 0,"data-invalid":e?"":void 0}}var Ct=new Set(["className","style","id","tabIndex","title","role","aria-label","data-testid","onClick","onMouseEnter","onMouseLeave"]);function Vt(t){let e={},r={};for(let[n,i]of Object.entries(t))Ct.has(n)||n.startsWith("data-")||n.startsWith("aria-")?r[n]=i:e[n]=i;return {fieldProps:e,divProps:r}}var Ht=forwardRef(function({children:e,onValueChange:r,onValueCommitted:n,...i},a){let l=useRef(null),{fieldProps:p,divProps:c}=Vt(i),m=p,b=useRef(r);b.current=r;let u=useRef(null),o={...m,onChange:I=>{m.onChange?.(I),b.current&&u.current&&b.current(I,{reason:u.current._getLastChangeReason(),formattedValue:u.current.inputValue});}},L=Xe(o);u.current=L;let R=Ze(o,L,l),M=L.validationState==="invalid"||L.numberValue!==null&&(m.minValue!==void 0&&L.numberValue<m.minValue||m.maxValue!==void 0&&L.numberValue>m.maxValue);return jsx(ke.Provider,{value:{state:L,aria:R,inputRef:l,props:o},children:jsx("div",{ref:a,...c,...Mt(L,M),children:e})})}),Ot=forwardRef(function({render:e,children:r,...n},i){let{aria:a,state:l}=B(),p=jsx("label",{ref:i,...a.labelProps,...n,children:r});return ce(p,e,l)}),wt=forwardRef(function({render:e,children:r,...n},i){let{aria:a,state:l}=B(),p=jsx("div",{ref:i,...a.groupProps,...n,children:r});return ce(p,e,l)}),At=forwardRef(function({render:e,...r},n){let{aria:i,state:a,inputRef:l}=B(),p=jsx("input",{ref:l,...i.inputProps,...r});return ce(p,e,a)}),kt=forwardRef(function({render:e,children:r,...n},i){let{aria:a,state:l}=B(),p=jsx("button",{ref:i,...a.incrementButtonProps,...n,children:r??"+"});return ce(p,e,l)}),Bt=forwardRef(function({render:e,children:r,...n},i){let{aria:a,state:l}=B(),p=jsx("button",{ref:i,...a.decrementButtonProps,...n,children:r??"\u2212"});return ce(p,e,l)}),jt=function(){let{aria:e}=B();return e.hiddenInputProps?jsx("input",{...e.hiddenInputProps}):null},_t=forwardRef(function({render:e,children:r,direction:n="horizontal",pixelSensitivity:i=4,...a},l){let{state:p}=B(),{scrubAreaProps:c}=mt(p,{direction:n,pixelSensitivity:i}),m=jsx("span",{ref:l,...c,...a,children:r});return ce(m,e,p)}),$t=forwardRef(function({render:e,children:r,style:n,...i},a){let{state:l}=B();if(!l.isScrubbing)return null;let p=jsx("span",{ref:a,style:{position:"fixed",pointerEvents:"none",zIndex:9999,...n},...i,children:r});return ce(p,e,l)}),Kt=forwardRef(function({children:e,...r},n){let{aria:i}=B();return jsx("p",{ref:n,...i.descriptionProps,...r,children:e})}),Ut=forwardRef(function({children:e,...r},n){let{aria:i,state:a}=B(),l=e??a.validationError??null;return l?jsx("p",{ref:n,...i.errorMessageProps,...r,children:l}):null}),zt=forwardRef(function({render:e,...r},n){let{state:i}=B(),a=jsx("span",{ref:n,"aria-hidden":"true",...r,children:i.inputValue});return ce(a,e,i)}),Yt={Root:Ht,Label:Ot,Group:wt,Input:At,Increment:kt,Decrement:Bt,HiddenInput:jt,ScrubArea:_t,ScrubAreaCursor:$t,Description:Kt,ErrorMessage:Ut,Formatted:zt};export{Yt as NumberField,ke as NumberFieldContext,qe as useControllableState,Ze as useNumberField,B as useNumberFieldContext,ht as useNumberFieldFormat,Xe as useNumberFieldState};//# sourceMappingURL=react.js.map
|
|
3
3
|
//# sourceMappingURL=react.js.map
|