use-mask-input 3.7.1 → 3.7.2

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/CHANGELOG.md CHANGED
@@ -1,5 +1,12 @@
1
1
  ## [3.6.0](https://github.com/eduardoborges/use-mask-input/compare/3.5.2...3.6.0) (2026-01-13)
2
2
 
3
+ ## 3.7.2
4
+
5
+ ### Patch Changes
6
+
7
+ - e1618a5: optimize masking logic in useHookFormMask and related components with memoization
8
+ - ea0f089: enhance withMask function to support caching of callbacks based on masks and options
9
+
3
10
  ## 3.7.1
4
11
 
5
12
  ### Patch Changes
package/README.md CHANGED
@@ -2,7 +2,7 @@
2
2
  <h1>🥸 use-mask-input</h1>
3
3
  <h4>A React Hook for building elegant and simple input masks.</h4>
4
4
 
5
- ![npm](https://img.shields.io/npm/v/use-mask-input) ![npm package minimized gzipped size (select exports)](https://img.shields.io/bundlejs/size/use-mask-input?color=green-light) ![npm](https://img.shields.io/npm/dw/use-mask-input)
5
+ ![npm](https://img.shields.io/npm/v/use-mask-input) ![npm package minimized gzipped size (select exports)](https://img.shields.io/bundlejs/size/use-mask-input?color=green-light) ![npm](https://img.shields.io/npm/dw/use-mask-input) [![codecov](https://codecov.io/gh/eduardoborges/use-mask-input/branch/main/graph/badge.svg?token=8ORAOAUZTP)](https://codecov.io/gh/eduardoborges/use-mask-input)
6
6
  </div>
7
7
 
8
8
  ## [Full Documentation](http://use-mask-input.eduardoborges.dev) | [Sponsor this project](https://github.com/eduardoborges?tab=sponsors)
package/dist/antd.cjs CHANGED
@@ -1,37 +1,38 @@
1
1
  'use strict';
2
2
 
3
- var chunk4Y2DTPBL_cjs = require('./chunk-4Y2DTPBL.cjs');
3
+ var chunkNIHSNNRR_cjs = require('./chunk-NIHSNNRR.cjs');
4
4
  var react = require('react');
5
5
 
6
- // src/antd/useHookFormMaskAntd.ts
7
6
  function useHookFormMaskAntd(registerFn) {
8
- return (fieldName, mask, options) => {
9
- if (!registerFn) throw new Error("registerFn is required");
10
- const registerReturn = registerFn(fieldName, options);
11
- const { ref } = registerReturn;
12
- const refWithMask = (inputRef) => {
13
- const element = inputRef ? chunk4Y2DTPBL_cjs.resolveInputRef(inputRef.input) : null;
14
- if (element) chunk4Y2DTPBL_cjs.applyMaskToElement(element, mask, options);
15
- if (ref) ref(element);
7
+ return react.useMemo(() => {
8
+ const refCache = /* @__PURE__ */ new Map();
9
+ return (fieldName, mask, options) => {
10
+ if (!registerFn) throw new Error("registerFn is required");
11
+ const registerReturn = registerFn(fieldName, options);
12
+ const { ref } = registerReturn;
13
+ const cacheKey = chunkNIHSNNRR_cjs.makeMaskCacheKey(fieldName, mask);
14
+ if (!refCache.has(cacheKey)) {
15
+ const refWithMask = (inputRef) => {
16
+ const element = inputRef ? chunkNIHSNNRR_cjs.resolveInputRef(inputRef.input) : null;
17
+ if (element) chunkNIHSNNRR_cjs.applyMaskToElement(element, mask, options);
18
+ if (ref) ref(element);
19
+ };
20
+ refCache.set(cacheKey, refWithMask);
21
+ }
22
+ const result = {
23
+ ...registerReturn,
24
+ ref: refCache.get(cacheKey)
25
+ };
26
+ chunkNIHSNNRR_cjs.setPrevRef(result, ref);
27
+ return result;
16
28
  };
17
- const result = {
18
- ...registerReturn,
19
- ref: refWithMask
20
- };
21
- Object.defineProperty(result, "prevRef", {
22
- value: ref,
23
- enumerable: false,
24
- writable: true,
25
- configurable: true
26
- });
27
- return result;
28
- };
29
+ }, [registerFn]);
29
30
  }
30
31
  function useMaskInputAntd(props) {
31
32
  const { mask, register, options } = props;
32
33
  const ref = react.useRef(null);
33
34
  const maskInput = react.useMemo(
34
- () => chunk4Y2DTPBL_cjs.isServer_default ? null : chunk4Y2DTPBL_cjs.createMaskInstance(mask, options),
35
+ () => chunkNIHSNNRR_cjs.isServer_default ? null : chunkNIHSNNRR_cjs.createMaskInstance(mask, options),
35
36
  [mask, options]
36
37
  );
37
38
  const refCallback = react.useCallback((input) => {
@@ -39,22 +40,22 @@ function useMaskInputAntd(props) {
39
40
  ref.current = null;
40
41
  return;
41
42
  }
42
- ref.current = chunk4Y2DTPBL_cjs.resolveInputRef(input.input);
43
+ ref.current = chunkNIHSNNRR_cjs.resolveInputRef(input.input);
43
44
  }, []);
44
45
  react.useEffect(() => {
45
- if (chunk4Y2DTPBL_cjs.isServer_default || !ref.current) return;
46
- if (!chunk4Y2DTPBL_cjs.isHTMLElement(ref.current)) {
46
+ if (chunkNIHSNNRR_cjs.isServer_default || !ref.current) return;
47
+ if (!chunkNIHSNNRR_cjs.isHTMLElement(ref.current)) {
47
48
  return;
48
49
  }
49
- const inputElement = chunk4Y2DTPBL_cjs.findInputElement(ref.current);
50
- if (maskInput && inputElement && chunk4Y2DTPBL_cjs.isHTMLElement(inputElement)) {
50
+ const inputElement = chunkNIHSNNRR_cjs.findInputElement(ref.current);
51
+ if (maskInput && inputElement && chunkNIHSNNRR_cjs.isHTMLElement(inputElement)) {
51
52
  maskInput.mask(inputElement);
52
53
  }
53
- if (register && chunk4Y2DTPBL_cjs.isHTMLElement(ref.current)) {
54
+ if (register && chunkNIHSNNRR_cjs.isHTMLElement(ref.current)) {
54
55
  register(ref.current);
55
56
  }
56
57
  }, [mask, register, options, maskInput]);
57
- if (chunk4Y2DTPBL_cjs.isServer_default) {
58
+ if (chunkNIHSNNRR_cjs.isServer_default) {
58
59
  return () => {
59
60
  };
60
61
  }
package/dist/antd.cjs.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/antd/useHookFormMaskAntd.ts","../src/antd/useMaskInputAntd.ts"],"names":["resolveInputRef","applyMaskToElement","useRef","useMemo","isServer_default","createMaskInstance","useCallback","useEffect","isHTMLElement","findInputElement"],"mappings":";;;;;;AA0Be,SAAR,oBAEL,UAAA,EAAgC;AAChC,EAAA,OAAO,CAAC,SAAA,EAAoB,IAAA,EAAY,OAAA,KACuB;AAC7D,IAAA,IAAI,CAAC,UAAA,EAAY,MAAM,IAAI,MAAM,wBAAwB,CAAA;AAEzD,IAAA,MAAM,cAAA,GAAiB,UAAA,CAAW,SAAA,EAAW,OAAkB,CAAA;AAC/D,IAAA,MAAM,EAAE,KAAI,GAAI,cAAA;AAEhB,IAAA,MAAM,WAAA,GAA4C,CAAC,QAAA,KAAa;AAC9D,MAAA,MAAM,OAAA,GAAU,QAAA,GAAWA,iCAAA,CAAgB,QAAA,CAAS,KAAK,CAAA,GAAI,IAAA;AAC7D,MAAA,IAAI,OAAA,EAASC,oCAAA,CAAmB,OAAA,EAAS,IAAA,EAAM,OAAkB,CAAA;AACjE,MAAA,IAAI,GAAA,MAAS,OAAO,CAAA;AAAA,IACtB,CAAA;AAEA,IAAA,MAAM,MAAA,GAAS;AAAA,MACb,GAAG,cAAA;AAAA,MACH,GAAA,EAAK;AAAA,KACP;AAEA,IAAA,MAAA,CAAO,cAAA,CAAe,QAAQ,SAAA,EAAW;AAAA,MACvC,KAAA,EAAO,GAAA;AAAA,MACP,UAAA,EAAY,KAAA;AAAA,MACZ,QAAA,EAAU,IAAA;AAAA,MACV,YAAA,EAAc;AAAA,KACf,CAAA;AAED,IAAA,OAAO,MAAA;AAAA,EACT,CAAA;AACF;ACxBe,SAAR,iBAAkC,KAAA,EAE/B;AACR,EAAA,MAAM,EAAE,IAAA,EAAM,QAAA,EAAU,OAAA,EAAQ,GAAI,KAAA;AACpC,EAAA,MAAM,GAAA,GAAMC,aAAwB,IAAI,CAAA;AACxC,EAAA,MAAM,SAAA,GAAYC,aAAA;AAAA,IAChB,MAAOC,kCAAA,GAAW,IAAA,GAAOC,oCAAA,CAAmB,MAAM,OAAO,CAAA;AAAA,IACzD,CAAC,MAAM,OAAO;AAAA,GAChB;AAEA,EAAA,MAAM,WAAA,GAAcC,iBAAA,CAAY,CAAC,KAAA,KAA2B;AAC1D,IAAA,IAAI,CAAC,KAAA,EAAO;AACV,MAAA,GAAA,CAAI,OAAA,GAAU,IAAA;AACd,MAAA;AAAA,IACF;AAEA,IAAA,GAAA,CAAI,OAAA,GAAUN,iCAAA,CAAgB,KAAA,CAAM,KAAK,CAAA;AAAA,EAC3C,CAAA,EAAG,EAAE,CAAA;AAEL,EAAAO,eAAA,CAAU,MAAM;AACd,IAAA,IAAIH,kCAAA,IAAY,CAAC,GAAA,CAAI,OAAA,EAAS;AAE9B,IAAA,IAAI,CAACI,+BAAA,CAAc,GAAA,CAAI,OAAO,CAAA,EAAG;AAC/B,MAAA;AAAA,IACF;AAEA,IAAA,MAAM,YAAA,GAAeC,kCAAA,CAAiB,GAAA,CAAI,OAAO,CAAA;AAEjD,IAAA,IAAI,SAAA,IAAa,YAAA,IAAgBD,+BAAA,CAAc,YAAY,CAAA,EAAG;AAC5D,MAAA,SAAA,CAAU,KAAK,YAAY,CAAA;AAAA,IAC7B;AAEA,IAAA,IAAI,QAAA,IAAYA,+BAAA,CAAc,GAAA,CAAI,OAAO,CAAA,EAAG;AAC1C,MAAA,QAAA,CAAS,IAAI,OAAO,CAAA;AAAA,IACtB;AAAA,EACF,GAAG,CAAC,IAAA,EAAM,QAAA,EAAU,OAAA,EAAS,SAAS,CAAC,CAAA;AAEvC,EAAA,IAAIJ,kCAAA,EAAU;AACZ,IAAA,OAAO,MAAY;AAAA,IAEnB,CAAA;AAAA,EACF;AAEA,EAAA,OAAO,WAAA;AACT","file":"antd.cjs","sourcesContent":["import { applyMaskToElement, resolveInputRef } from '../core';\n\nimport type { InputRef } from 'antd';\nimport type { RefCallback } from 'react';\nimport type {\n FieldValues, Path,\n RegisterOptions,\n UseFormRegister,\n} from 'react-hook-form';\n\nimport type { Mask, Options, UseHookFormMaskReturn } from '../types';\n\nexport type UseHookFormMaskAntdReturn<T extends FieldValues> = Omit<\n UseHookFormMaskReturn<T>,\n 'ref'\n> & { ref: RefCallback<InputRef | null> };\n\n/**\n * Ant Design version of useHookFormMask.\n * Creates a masked register that works with Ant Design Input (ref receives InputRef).\n *\n * @template T - The form data type\n * @template D - The register options type\n * @param registerFn - The register function from useForm hook\n * @returns A function that registers a field with mask support for Ant Design Input\n */\nexport default function useHookFormMaskAntd<\n T extends FieldValues, D extends RegisterOptions,\n>(registerFn: UseFormRegister<T>) {\n return (fieldName: Path<T>, mask: Mask, options?: (\n D & Options) | Options | D): UseHookFormMaskAntdReturn<T> => {\n if (!registerFn) throw new Error('registerFn is required');\n\n const registerReturn = registerFn(fieldName, options as Options);\n const { ref } = registerReturn as UseHookFormMaskReturn<T>;\n\n const refWithMask: RefCallback<InputRef | null> = (inputRef) => {\n const element = inputRef ? resolveInputRef(inputRef.input) : null;\n if (element) applyMaskToElement(element, mask, options as Options);\n if (ref) ref(element);\n };\n\n const result = {\n ...registerReturn,\n ref: refWithMask,\n } as UseHookFormMaskAntdReturn<T>;\n\n Object.defineProperty(result, 'prevRef', {\n value: ref,\n enumerable: false,\n writable: true,\n configurable: true,\n });\n\n return result;\n };\n}\n","import {\n useCallback,\n useEffect,\n useMemo,\n useRef,\n} from 'react';\n\nimport {\n createMaskInstance, findInputElement, isHTMLElement, resolveInputRef,\n} from '../core';\nimport isServer from '../utils/isServer';\n\nimport type { InputRef } from 'antd';\n\nimport type { Mask, Options } from '../types';\n\ninterface UseMaskInputOptions {\n mask: Mask;\n register?: (element: HTMLElement) => void;\n options?: Options;\n}\n\n/**\n * React hook for applying input masks to form elements.\n * Works with Ant Design and other wrapped components too.\n *\n * @param props - Configuration object\n * @param props.mask - The mask pattern to apply\n * @param props.register - Optional callback that receives the element\n * @param props.options - Optional mask configuration options\n * @returns A ref callback function to attach to the input element\n */\nexport default function useMaskInputAntd(props: UseMaskInputOptions): (\n input: InputRef | null\n) => void {\n const { mask, register, options } = props;\n const ref = useRef<InputRef | null>(null);\n const maskInput = useMemo(\n () => (isServer ? null : createMaskInstance(mask, options)),\n [mask, options],\n );\n\n const refCallback = useCallback((input: InputRef | null) => {\n if (!input) {\n ref.current = null;\n return;\n }\n\n ref.current = resolveInputRef(input.input) as unknown as InputRef;\n }, []);\n\n useEffect(() => {\n if (isServer || !ref.current) return;\n\n if (!isHTMLElement(ref.current)) {\n return;\n }\n\n const inputElement = findInputElement(ref.current);\n\n if (maskInput && inputElement && isHTMLElement(inputElement)) {\n maskInput.mask(inputElement);\n }\n\n if (register && isHTMLElement(ref.current)) {\n register(ref.current);\n }\n }, [mask, register, options, maskInput]);\n\n if (isServer) {\n return (): void => {\n // server doesn't have dom, so just do nothing\n };\n }\n\n return refCallback;\n}\n"]}
1
+ {"version":3,"sources":["../src/antd/useHookFormMaskAntd.ts","../src/antd/useMaskInputAntd.ts"],"names":["useMemo","makeMaskCacheKey","resolveInputRef","applyMaskToElement","setPrevRef","useRef","isServer_default","createMaskInstance","useCallback","useEffect","isHTMLElement","findInputElement"],"mappings":"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","file":"antd.cjs","sourcesContent":["import { useMemo } from 'react';\n\nimport { applyMaskToElement, resolveInputRef } from '../core';\nimport { makeMaskCacheKey, setPrevRef } from '../utils';\n\nimport type { InputRef } from 'antd';\nimport type { RefCallback } from 'react';\nimport type {\n FieldValues, Path,\n RegisterOptions,\n UseFormRegister,\n} from 'react-hook-form';\n\nimport type { Mask, Options, UseHookFormMaskReturn } from '../types';\n\nexport type UseHookFormMaskAntdReturn<T extends FieldValues> = Omit<\n UseHookFormMaskReturn<T>,\n 'ref'\n> & { ref: RefCallback<InputRef | null> };\n\n/**\n * Ant Design version of useHookFormMask.\n * Creates a masked register that works with Ant Design Input (ref receives InputRef).\n *\n * @template T - The form data type\n * @template D - The register options type\n * @param registerFn - The register function from useForm hook\n * @returns A function that registers a field with mask support for Ant Design Input\n */\nexport default function useHookFormMaskAntd<\n T extends FieldValues, D extends RegisterOptions,\n>(registerFn: UseFormRegister<T>): ((fieldName: Path<T>, mask: Mask, options?: (\n D & Options) | Options | D) => UseHookFormMaskAntdReturn<T>) {\n //\n return useMemo(() => {\n const refCache = new Map<string, RefCallback<InputRef | null>>();\n\n return (fieldName: Path<T>, mask: Mask, options?: (\n D & Options) | Options | D): UseHookFormMaskAntdReturn<T> => {\n if (!registerFn) throw new Error('registerFn is required');\n\n const registerReturn = registerFn(fieldName, options as Options);\n const { ref } = registerReturn as UseHookFormMaskReturn<T>;\n\n const cacheKey = makeMaskCacheKey(fieldName, mask);\n\n if (!refCache.has(cacheKey)) {\n const refWithMask: RefCallback<InputRef | null> = (inputRef) => {\n const element = inputRef ? resolveInputRef(inputRef.input) : null;\n if (element) applyMaskToElement(element, mask, options as Options);\n if (ref) ref(element);\n };\n refCache.set(cacheKey, refWithMask);\n }\n\n const result = {\n ...registerReturn,\n ref: refCache.get(cacheKey),\n } as UseHookFormMaskAntdReturn<T>;\n\n setPrevRef(result, ref);\n\n return result;\n };\n }, [registerFn]);\n}\n","import {\n useCallback,\n useEffect,\n useMemo,\n useRef,\n} from 'react';\n\nimport {\n createMaskInstance, findInputElement, isHTMLElement, resolveInputRef,\n} from '../core';\nimport isServer from '../utils/isServer';\n\nimport type { InputRef } from 'antd';\n\nimport type { Mask, Options } from '../types';\n\ninterface UseMaskInputOptions {\n mask: Mask;\n register?: (element: HTMLElement) => void;\n options?: Options;\n}\n\n/**\n * React hook for applying input masks to form elements.\n * Works with Ant Design and other wrapped components too.\n *\n * @param props - Configuration object\n * @param props.mask - The mask pattern to apply\n * @param props.register - Optional callback that receives the element\n * @param props.options - Optional mask configuration options\n * @returns A ref callback function to attach to the input element\n */\nexport default function useMaskInputAntd(props: UseMaskInputOptions): (\n input: InputRef | null\n) => void {\n const { mask, register, options } = props;\n const ref = useRef<InputRef | null>(null);\n const maskInput = useMemo(\n () => (isServer ? null : createMaskInstance(mask, options)),\n [mask, options],\n );\n\n const refCallback = useCallback((input: InputRef | null) => {\n if (!input) {\n ref.current = null;\n return;\n }\n\n ref.current = resolveInputRef(input.input) as unknown as InputRef;\n }, []);\n\n useEffect(() => {\n if (isServer || !ref.current) return;\n\n if (!isHTMLElement(ref.current)) {\n return;\n }\n\n const inputElement = findInputElement(ref.current);\n\n if (maskInput && inputElement && isHTMLElement(inputElement)) {\n maskInput.mask(inputElement);\n }\n\n if (register && isHTMLElement(ref.current)) {\n register(ref.current);\n }\n }, [mask, register, options, maskInput]);\n\n if (isServer) {\n return (): void => {\n // server doesn't have dom, so just do nothing\n };\n }\n\n return refCallback;\n}\n"]}
package/dist/antd.d.cts CHANGED
@@ -15,7 +15,7 @@ type UseHookFormMaskAntdReturn<T extends FieldValues> = Omit<UseHookFormMaskRetu
15
15
  * @param registerFn - The register function from useForm hook
16
16
  * @returns A function that registers a field with mask support for Ant Design Input
17
17
  */
18
- declare function useHookFormMaskAntd<T extends FieldValues, D extends RegisterOptions>(registerFn: UseFormRegister<T>): (fieldName: Path<T>, mask: Mask, options?: (D & Options) | Options | D) => UseHookFormMaskAntdReturn<T>;
18
+ declare function useHookFormMaskAntd<T extends FieldValues, D extends RegisterOptions>(registerFn: UseFormRegister<T>): ((fieldName: Path<T>, mask: Mask, options?: (D & Options) | Options | D) => UseHookFormMaskAntdReturn<T>);
19
19
 
20
20
  interface UseMaskInputOptions {
21
21
  mask: Mask;
package/dist/antd.d.ts CHANGED
@@ -15,7 +15,7 @@ type UseHookFormMaskAntdReturn<T extends FieldValues> = Omit<UseHookFormMaskRetu
15
15
  * @param registerFn - The register function from useForm hook
16
16
  * @returns A function that registers a field with mask support for Ant Design Input
17
17
  */
18
- declare function useHookFormMaskAntd<T extends FieldValues, D extends RegisterOptions>(registerFn: UseFormRegister<T>): (fieldName: Path<T>, mask: Mask, options?: (D & Options) | Options | D) => UseHookFormMaskAntdReturn<T>;
18
+ declare function useHookFormMaskAntd<T extends FieldValues, D extends RegisterOptions>(registerFn: UseFormRegister<T>): ((fieldName: Path<T>, mask: Mask, options?: (D & Options) | Options | D) => UseHookFormMaskAntdReturn<T>);
19
19
 
20
20
  interface UseMaskInputOptions {
21
21
  mask: Mask;
package/dist/antd.js CHANGED
@@ -1,29 +1,30 @@
1
- import { isServer_default, createMaskInstance, resolveInputRef, isHTMLElement, findInputElement, applyMaskToElement } from './chunk-JGOZSJMW.js';
2
- import { useRef, useMemo, useCallback, useEffect } from 'react';
1
+ import { makeMaskCacheKey, setPrevRef, isServer_default, createMaskInstance, resolveInputRef, isHTMLElement, findInputElement, applyMaskToElement } from './chunk-FDD3PKBM.js';
2
+ import { useMemo, useRef, useCallback, useEffect } from 'react';
3
3
 
4
- // src/antd/useHookFormMaskAntd.ts
5
4
  function useHookFormMaskAntd(registerFn) {
6
- return (fieldName, mask, options) => {
7
- if (!registerFn) throw new Error("registerFn is required");
8
- const registerReturn = registerFn(fieldName, options);
9
- const { ref } = registerReturn;
10
- const refWithMask = (inputRef) => {
11
- const element = inputRef ? resolveInputRef(inputRef.input) : null;
12
- if (element) applyMaskToElement(element, mask, options);
13
- if (ref) ref(element);
5
+ return useMemo(() => {
6
+ const refCache = /* @__PURE__ */ new Map();
7
+ return (fieldName, mask, options) => {
8
+ if (!registerFn) throw new Error("registerFn is required");
9
+ const registerReturn = registerFn(fieldName, options);
10
+ const { ref } = registerReturn;
11
+ const cacheKey = makeMaskCacheKey(fieldName, mask);
12
+ if (!refCache.has(cacheKey)) {
13
+ const refWithMask = (inputRef) => {
14
+ const element = inputRef ? resolveInputRef(inputRef.input) : null;
15
+ if (element) applyMaskToElement(element, mask, options);
16
+ if (ref) ref(element);
17
+ };
18
+ refCache.set(cacheKey, refWithMask);
19
+ }
20
+ const result = {
21
+ ...registerReturn,
22
+ ref: refCache.get(cacheKey)
23
+ };
24
+ setPrevRef(result, ref);
25
+ return result;
14
26
  };
15
- const result = {
16
- ...registerReturn,
17
- ref: refWithMask
18
- };
19
- Object.defineProperty(result, "prevRef", {
20
- value: ref,
21
- enumerable: false,
22
- writable: true,
23
- configurable: true
24
- });
25
- return result;
26
- };
27
+ }, [registerFn]);
27
28
  }
28
29
  function useMaskInputAntd(props) {
29
30
  const { mask, register, options } = props;
package/dist/antd.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/antd/useHookFormMaskAntd.ts","../src/antd/useMaskInputAntd.ts"],"names":[],"mappings":";;;;AA0Be,SAAR,oBAEL,UAAA,EAAgC;AAChC,EAAA,OAAO,CAAC,SAAA,EAAoB,IAAA,EAAY,OAAA,KACuB;AAC7D,IAAA,IAAI,CAAC,UAAA,EAAY,MAAM,IAAI,MAAM,wBAAwB,CAAA;AAEzD,IAAA,MAAM,cAAA,GAAiB,UAAA,CAAW,SAAA,EAAW,OAAkB,CAAA;AAC/D,IAAA,MAAM,EAAE,KAAI,GAAI,cAAA;AAEhB,IAAA,MAAM,WAAA,GAA4C,CAAC,QAAA,KAAa;AAC9D,MAAA,MAAM,OAAA,GAAU,QAAA,GAAW,eAAA,CAAgB,QAAA,CAAS,KAAK,CAAA,GAAI,IAAA;AAC7D,MAAA,IAAI,OAAA,EAAS,kBAAA,CAAmB,OAAA,EAAS,IAAA,EAAM,OAAkB,CAAA;AACjE,MAAA,IAAI,GAAA,MAAS,OAAO,CAAA;AAAA,IACtB,CAAA;AAEA,IAAA,MAAM,MAAA,GAAS;AAAA,MACb,GAAG,cAAA;AAAA,MACH,GAAA,EAAK;AAAA,KACP;AAEA,IAAA,MAAA,CAAO,cAAA,CAAe,QAAQ,SAAA,EAAW;AAAA,MACvC,KAAA,EAAO,GAAA;AAAA,MACP,UAAA,EAAY,KAAA;AAAA,MACZ,QAAA,EAAU,IAAA;AAAA,MACV,YAAA,EAAc;AAAA,KACf,CAAA;AAED,IAAA,OAAO,MAAA;AAAA,EACT,CAAA;AACF;ACxBe,SAAR,iBAAkC,KAAA,EAE/B;AACR,EAAA,MAAM,EAAE,IAAA,EAAM,QAAA,EAAU,OAAA,EAAQ,GAAI,KAAA;AACpC,EAAA,MAAM,GAAA,GAAM,OAAwB,IAAI,CAAA;AACxC,EAAA,MAAM,SAAA,GAAY,OAAA;AAAA,IAChB,MAAO,gBAAA,GAAW,IAAA,GAAO,kBAAA,CAAmB,MAAM,OAAO,CAAA;AAAA,IACzD,CAAC,MAAM,OAAO;AAAA,GAChB;AAEA,EAAA,MAAM,WAAA,GAAc,WAAA,CAAY,CAAC,KAAA,KAA2B;AAC1D,IAAA,IAAI,CAAC,KAAA,EAAO;AACV,MAAA,GAAA,CAAI,OAAA,GAAU,IAAA;AACd,MAAA;AAAA,IACF;AAEA,IAAA,GAAA,CAAI,OAAA,GAAU,eAAA,CAAgB,KAAA,CAAM,KAAK,CAAA;AAAA,EAC3C,CAAA,EAAG,EAAE,CAAA;AAEL,EAAA,SAAA,CAAU,MAAM;AACd,IAAA,IAAI,gBAAA,IAAY,CAAC,GAAA,CAAI,OAAA,EAAS;AAE9B,IAAA,IAAI,CAAC,aAAA,CAAc,GAAA,CAAI,OAAO,CAAA,EAAG;AAC/B,MAAA;AAAA,IACF;AAEA,IAAA,MAAM,YAAA,GAAe,gBAAA,CAAiB,GAAA,CAAI,OAAO,CAAA;AAEjD,IAAA,IAAI,SAAA,IAAa,YAAA,IAAgB,aAAA,CAAc,YAAY,CAAA,EAAG;AAC5D,MAAA,SAAA,CAAU,KAAK,YAAY,CAAA;AAAA,IAC7B;AAEA,IAAA,IAAI,QAAA,IAAY,aAAA,CAAc,GAAA,CAAI,OAAO,CAAA,EAAG;AAC1C,MAAA,QAAA,CAAS,IAAI,OAAO,CAAA;AAAA,IACtB;AAAA,EACF,GAAG,CAAC,IAAA,EAAM,QAAA,EAAU,OAAA,EAAS,SAAS,CAAC,CAAA;AAEvC,EAAA,IAAI,gBAAA,EAAU;AACZ,IAAA,OAAO,MAAY;AAAA,IAEnB,CAAA;AAAA,EACF;AAEA,EAAA,OAAO,WAAA;AACT","file":"antd.js","sourcesContent":["import { applyMaskToElement, resolveInputRef } from '../core';\n\nimport type { InputRef } from 'antd';\nimport type { RefCallback } from 'react';\nimport type {\n FieldValues, Path,\n RegisterOptions,\n UseFormRegister,\n} from 'react-hook-form';\n\nimport type { Mask, Options, UseHookFormMaskReturn } from '../types';\n\nexport type UseHookFormMaskAntdReturn<T extends FieldValues> = Omit<\n UseHookFormMaskReturn<T>,\n 'ref'\n> & { ref: RefCallback<InputRef | null> };\n\n/**\n * Ant Design version of useHookFormMask.\n * Creates a masked register that works with Ant Design Input (ref receives InputRef).\n *\n * @template T - The form data type\n * @template D - The register options type\n * @param registerFn - The register function from useForm hook\n * @returns A function that registers a field with mask support for Ant Design Input\n */\nexport default function useHookFormMaskAntd<\n T extends FieldValues, D extends RegisterOptions,\n>(registerFn: UseFormRegister<T>) {\n return (fieldName: Path<T>, mask: Mask, options?: (\n D & Options) | Options | D): UseHookFormMaskAntdReturn<T> => {\n if (!registerFn) throw new Error('registerFn is required');\n\n const registerReturn = registerFn(fieldName, options as Options);\n const { ref } = registerReturn as UseHookFormMaskReturn<T>;\n\n const refWithMask: RefCallback<InputRef | null> = (inputRef) => {\n const element = inputRef ? resolveInputRef(inputRef.input) : null;\n if (element) applyMaskToElement(element, mask, options as Options);\n if (ref) ref(element);\n };\n\n const result = {\n ...registerReturn,\n ref: refWithMask,\n } as UseHookFormMaskAntdReturn<T>;\n\n Object.defineProperty(result, 'prevRef', {\n value: ref,\n enumerable: false,\n writable: true,\n configurable: true,\n });\n\n return result;\n };\n}\n","import {\n useCallback,\n useEffect,\n useMemo,\n useRef,\n} from 'react';\n\nimport {\n createMaskInstance, findInputElement, isHTMLElement, resolveInputRef,\n} from '../core';\nimport isServer from '../utils/isServer';\n\nimport type { InputRef } from 'antd';\n\nimport type { Mask, Options } from '../types';\n\ninterface UseMaskInputOptions {\n mask: Mask;\n register?: (element: HTMLElement) => void;\n options?: Options;\n}\n\n/**\n * React hook for applying input masks to form elements.\n * Works with Ant Design and other wrapped components too.\n *\n * @param props - Configuration object\n * @param props.mask - The mask pattern to apply\n * @param props.register - Optional callback that receives the element\n * @param props.options - Optional mask configuration options\n * @returns A ref callback function to attach to the input element\n */\nexport default function useMaskInputAntd(props: UseMaskInputOptions): (\n input: InputRef | null\n) => void {\n const { mask, register, options } = props;\n const ref = useRef<InputRef | null>(null);\n const maskInput = useMemo(\n () => (isServer ? null : createMaskInstance(mask, options)),\n [mask, options],\n );\n\n const refCallback = useCallback((input: InputRef | null) => {\n if (!input) {\n ref.current = null;\n return;\n }\n\n ref.current = resolveInputRef(input.input) as unknown as InputRef;\n }, []);\n\n useEffect(() => {\n if (isServer || !ref.current) return;\n\n if (!isHTMLElement(ref.current)) {\n return;\n }\n\n const inputElement = findInputElement(ref.current);\n\n if (maskInput && inputElement && isHTMLElement(inputElement)) {\n maskInput.mask(inputElement);\n }\n\n if (register && isHTMLElement(ref.current)) {\n register(ref.current);\n }\n }, [mask, register, options, maskInput]);\n\n if (isServer) {\n return (): void => {\n // server doesn't have dom, so just do nothing\n };\n }\n\n return refCallback;\n}\n"]}
1
+ {"version":3,"sources":["../src/antd/useHookFormMaskAntd.ts","../src/antd/useMaskInputAntd.ts"],"names":["useMemo"],"mappings":"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","file":"antd.js","sourcesContent":["import { useMemo } from 'react';\n\nimport { applyMaskToElement, resolveInputRef } from '../core';\nimport { makeMaskCacheKey, setPrevRef } from '../utils';\n\nimport type { InputRef } from 'antd';\nimport type { RefCallback } from 'react';\nimport type {\n FieldValues, Path,\n RegisterOptions,\n UseFormRegister,\n} from 'react-hook-form';\n\nimport type { Mask, Options, UseHookFormMaskReturn } from '../types';\n\nexport type UseHookFormMaskAntdReturn<T extends FieldValues> = Omit<\n UseHookFormMaskReturn<T>,\n 'ref'\n> & { ref: RefCallback<InputRef | null> };\n\n/**\n * Ant Design version of useHookFormMask.\n * Creates a masked register that works with Ant Design Input (ref receives InputRef).\n *\n * @template T - The form data type\n * @template D - The register options type\n * @param registerFn - The register function from useForm hook\n * @returns A function that registers a field with mask support for Ant Design Input\n */\nexport default function useHookFormMaskAntd<\n T extends FieldValues, D extends RegisterOptions,\n>(registerFn: UseFormRegister<T>): ((fieldName: Path<T>, mask: Mask, options?: (\n D & Options) | Options | D) => UseHookFormMaskAntdReturn<T>) {\n //\n return useMemo(() => {\n const refCache = new Map<string, RefCallback<InputRef | null>>();\n\n return (fieldName: Path<T>, mask: Mask, options?: (\n D & Options) | Options | D): UseHookFormMaskAntdReturn<T> => {\n if (!registerFn) throw new Error('registerFn is required');\n\n const registerReturn = registerFn(fieldName, options as Options);\n const { ref } = registerReturn as UseHookFormMaskReturn<T>;\n\n const cacheKey = makeMaskCacheKey(fieldName, mask);\n\n if (!refCache.has(cacheKey)) {\n const refWithMask: RefCallback<InputRef | null> = (inputRef) => {\n const element = inputRef ? resolveInputRef(inputRef.input) : null;\n if (element) applyMaskToElement(element, mask, options as Options);\n if (ref) ref(element);\n };\n refCache.set(cacheKey, refWithMask);\n }\n\n const result = {\n ...registerReturn,\n ref: refCache.get(cacheKey),\n } as UseHookFormMaskAntdReturn<T>;\n\n setPrevRef(result, ref);\n\n return result;\n };\n }, [registerFn]);\n}\n","import {\n useCallback,\n useEffect,\n useMemo,\n useRef,\n} from 'react';\n\nimport {\n createMaskInstance, findInputElement, isHTMLElement, resolveInputRef,\n} from '../core';\nimport isServer from '../utils/isServer';\n\nimport type { InputRef } from 'antd';\n\nimport type { Mask, Options } from '../types';\n\ninterface UseMaskInputOptions {\n mask: Mask;\n register?: (element: HTMLElement) => void;\n options?: Options;\n}\n\n/**\n * React hook for applying input masks to form elements.\n * Works with Ant Design and other wrapped components too.\n *\n * @param props - Configuration object\n * @param props.mask - The mask pattern to apply\n * @param props.register - Optional callback that receives the element\n * @param props.options - Optional mask configuration options\n * @returns A ref callback function to attach to the input element\n */\nexport default function useMaskInputAntd(props: UseMaskInputOptions): (\n input: InputRef | null\n) => void {\n const { mask, register, options } = props;\n const ref = useRef<InputRef | null>(null);\n const maskInput = useMemo(\n () => (isServer ? null : createMaskInstance(mask, options)),\n [mask, options],\n );\n\n const refCallback = useCallback((input: InputRef | null) => {\n if (!input) {\n ref.current = null;\n return;\n }\n\n ref.current = resolveInputRef(input.input) as unknown as InputRef;\n }, []);\n\n useEffect(() => {\n if (isServer || !ref.current) return;\n\n if (!isHTMLElement(ref.current)) {\n return;\n }\n\n const inputElement = findInputElement(ref.current);\n\n if (maskInput && inputElement && isHTMLElement(inputElement)) {\n maskInput.mask(inputElement);\n }\n\n if (register && isHTMLElement(ref.current)) {\n register(ref.current);\n }\n }, [mask, register, options, maskInput]);\n\n if (isServer) {\n return (): void => {\n // server doesn't have dom, so just do nothing\n };\n }\n\n return refCallback;\n}\n"]}
@@ -3736,6 +3736,7 @@ var ALIAS_MASKS = {
3736
3736
  placeholder: "0,00",
3737
3737
  displayFormat: "currency",
3738
3738
  radixPoint: ",",
3739
+ groupSeparator: ".",
3739
3740
  autoUnmask: true
3740
3741
  },
3741
3742
  cpf: { mask: "999.999.999-99", placeholder: "___.___.___-__" },
@@ -3795,6 +3796,19 @@ function interopDefaultSync(module) {
3795
3796
  return module;
3796
3797
  }
3797
3798
 
3799
+ // src/utils/maskHelpers.ts
3800
+ function makeMaskCacheKey(fieldName, mask) {
3801
+ return `${fieldName}:${Array.isArray(mask) ? mask.join(",") : String(mask)}`;
3802
+ }
3803
+ function setPrevRef(result, ref) {
3804
+ Object.defineProperty(result, "prevRef", {
3805
+ value: ref,
3806
+ enumerable: false,
3807
+ writable: true,
3808
+ configurable: true
3809
+ });
3810
+ }
3811
+
3798
3812
  // src/core/maskEngine.ts
3799
3813
  var import_inputmask = __toESM(require_inputmask(), 1);
3800
3814
  function createMaskInstance(mask, options) {
@@ -3824,6 +3838,6 @@ inputmask/dist/inputmask.js:
3824
3838
  (*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/babel/babel/blob/main/packages/babel-helpers/LICENSE *)
3825
3839
  */
3826
3840
 
3827
- export { __toESM, applyMaskToElement, createMaskInstance, findInputElement, flow, getMaskOptions, interopDefaultSync, isHTMLElement, isServer_default, require_inputmask, resolveInputRef };
3828
- //# sourceMappingURL=chunk-JGOZSJMW.js.map
3829
- //# sourceMappingURL=chunk-JGOZSJMW.js.map
3841
+ export { __toESM, applyMaskToElement, createMaskInstance, findInputElement, flow, getMaskOptions, interopDefaultSync, isHTMLElement, isServer_default, makeMaskCacheKey, require_inputmask, resolveInputRef, setPrevRef };
3842
+ //# sourceMappingURL=chunk-FDD3PKBM.js.map
3843
+ //# sourceMappingURL=chunk-FDD3PKBM.js.map