use-mask-input 3.7.2 → 3.7.3
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 +6 -0
- package/README.md +4 -1
- package/dist/antd.cjs +13 -23
- package/dist/antd.cjs.map +1 -1
- package/dist/antd.d.cts +2 -3
- package/dist/antd.d.ts +2 -3
- package/dist/antd.js +7 -17
- package/dist/antd.js.map +1 -1
- package/dist/{chunk-FDD3PKBM.js → chunk-QCWLMMDI.js} +50 -47
- package/dist/chunk-QCWLMMDI.js.map +1 -0
- package/dist/{chunk-NIHSNNRR.cjs → chunk-VK6LQ75W.cjs} +50 -53
- package/dist/chunk-VK6LQ75W.cjs.map +1 -0
- package/dist/index.cjs +22 -51
- package/dist/index.cjs.map +1 -1
- package/dist/index.js +10 -41
- package/dist/index.js.map +1 -1
- package/package.json +1 -1
- package/src/antd/useMaskInputAntd.ts +13 -34
- package/src/api/useMaskInput.ts +9 -27
- package/dist/chunk-FDD3PKBM.js.map +0 -1
- package/dist/chunk-NIHSNNRR.cjs.map +0 -1
package/CHANGELOG.md
CHANGED
package/README.md
CHANGED
|
@@ -2,7 +2,10 @@
|
|
|
2
2
|
<h1>🥸 use-mask-input</h1>
|
|
3
3
|
<h4>A React Hook for building elegant and simple input masks.</h4>
|
|
4
4
|
|
|
5
|
-

|
|
5
|
+
[](https://www.npmjs.com/package/use-mask-input)
|
|
6
|
+
[](https://www.npmjs.com/package/use-mask-input)
|
|
7
|
+
[](https://bundlejs.com/?q=use-mask-input)
|
|
8
|
+
[](https://codecov.io/gh/eduardoborges/use-mask-input)
|
|
6
9
|
</div>
|
|
7
10
|
|
|
8
11
|
## [Full Documentation](http://use-mask-input.eduardoborges.dev) | [Sponsor this project](https://github.com/eduardoborges?tab=sponsors)
|
package/dist/antd.cjs
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
-
var
|
|
3
|
+
var chunkVK6LQ75W_cjs = require('./chunk-VK6LQ75W.cjs');
|
|
4
4
|
var react = require('react');
|
|
5
5
|
|
|
6
6
|
function useHookFormMaskAntd(registerFn) {
|
|
@@ -10,11 +10,11 @@ function useHookFormMaskAntd(registerFn) {
|
|
|
10
10
|
if (!registerFn) throw new Error("registerFn is required");
|
|
11
11
|
const registerReturn = registerFn(fieldName, options);
|
|
12
12
|
const { ref } = registerReturn;
|
|
13
|
-
const cacheKey =
|
|
13
|
+
const cacheKey = chunkVK6LQ75W_cjs.makeMaskCacheKey(fieldName, mask);
|
|
14
14
|
if (!refCache.has(cacheKey)) {
|
|
15
15
|
const refWithMask = (inputRef) => {
|
|
16
|
-
const element = inputRef ?
|
|
17
|
-
if (element)
|
|
16
|
+
const element = inputRef ? chunkVK6LQ75W_cjs.resolveInputRef(inputRef.input) : null;
|
|
17
|
+
if (element) chunkVK6LQ75W_cjs.applyMaskToElement(element, mask, options);
|
|
18
18
|
if (ref) ref(element);
|
|
19
19
|
};
|
|
20
20
|
refCache.set(cacheKey, refWithMask);
|
|
@@ -23,7 +23,7 @@ function useHookFormMaskAntd(registerFn) {
|
|
|
23
23
|
...registerReturn,
|
|
24
24
|
ref: refCache.get(cacheKey)
|
|
25
25
|
};
|
|
26
|
-
|
|
26
|
+
chunkVK6LQ75W_cjs.setPrevRef(result, ref);
|
|
27
27
|
return result;
|
|
28
28
|
};
|
|
29
29
|
}, [registerFn]);
|
|
@@ -31,31 +31,21 @@ function useHookFormMaskAntd(registerFn) {
|
|
|
31
31
|
function useMaskInputAntd(props) {
|
|
32
32
|
const { mask, register, options } = props;
|
|
33
33
|
const ref = react.useRef(null);
|
|
34
|
-
const
|
|
35
|
-
|
|
36
|
-
[mask, options]
|
|
37
|
-
);
|
|
34
|
+
const maskRef = react.useRef(mask);
|
|
35
|
+
const optionsRef = react.useRef(options);
|
|
38
36
|
const refCallback = react.useCallback((input) => {
|
|
39
37
|
if (!input) {
|
|
40
38
|
ref.current = null;
|
|
41
39
|
return;
|
|
42
40
|
}
|
|
43
|
-
ref.current =
|
|
41
|
+
ref.current = chunkVK6LQ75W_cjs.resolveInputRef(input.input);
|
|
42
|
+
chunkVK6LQ75W_cjs.withMask(maskRef.current, optionsRef.current)(ref.current);
|
|
44
43
|
}, []);
|
|
45
44
|
react.useEffect(() => {
|
|
46
|
-
if (
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
const inputElement = chunkNIHSNNRR_cjs.findInputElement(ref.current);
|
|
51
|
-
if (maskInput && inputElement && chunkNIHSNNRR_cjs.isHTMLElement(inputElement)) {
|
|
52
|
-
maskInput.mask(inputElement);
|
|
53
|
-
}
|
|
54
|
-
if (register && chunkNIHSNNRR_cjs.isHTMLElement(ref.current)) {
|
|
55
|
-
register(ref.current);
|
|
56
|
-
}
|
|
57
|
-
}, [mask, register, options, maskInput]);
|
|
58
|
-
if (chunkNIHSNNRR_cjs.isServer_default) {
|
|
45
|
+
if (chunkVK6LQ75W_cjs.isServer_default || !ref.current || !register) return;
|
|
46
|
+
register(ref.current);
|
|
47
|
+
}, [register]);
|
|
48
|
+
if (chunkVK6LQ75W_cjs.isServer_default) {
|
|
59
49
|
return () => {
|
|
60
50
|
};
|
|
61
51
|
}
|
package/dist/antd.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/antd/useHookFormMaskAntd.ts","../src/antd/useMaskInputAntd.ts"],"names":["useMemo","makeMaskCacheKey","resolveInputRef","applyMaskToElement","setPrevRef","useRef","
|
|
1
|
+
{"version":3,"sources":["../src/antd/useHookFormMaskAntd.ts","../src/antd/useMaskInputAntd.ts"],"names":["useMemo","makeMaskCacheKey","resolveInputRef","applyMaskToElement","setPrevRef","useRef","useCallback","withMask","useEffect","isServer_default"],"mappings":";;;;;AA6Be,SAAR,oBAEL,UAAA,EAC6D;AAE7D,EAAA,OAAOA,cAAQ,MAAM;AACnB,IAAA,MAAM,QAAA,uBAAe,GAAA,EAA0C;AAE/D,IAAA,OAAO,CAAC,SAAA,EAAoB,IAAA,EAAY,OAAA,KACuB;AAC7D,MAAA,IAAI,CAAC,UAAA,EAAY,MAAM,IAAI,MAAM,wBAAwB,CAAA;AAEzD,MAAA,MAAM,cAAA,GAAiB,UAAA,CAAW,SAAA,EAAW,OAAkB,CAAA;AAC/D,MAAA,MAAM,EAAE,KAAI,GAAI,cAAA;AAEhB,MAAA,MAAM,QAAA,GAAWC,kCAAA,CAAiB,SAAA,EAAW,IAAI,CAAA;AAEjD,MAAA,IAAI,CAAC,QAAA,CAAS,GAAA,CAAI,QAAQ,CAAA,EAAG;AAC3B,QAAA,MAAM,WAAA,GAA4C,CAAC,QAAA,KAAa;AAC9D,UAAA,MAAM,OAAA,GAAU,QAAA,GAAWC,iCAAA,CAAgB,QAAA,CAAS,KAAK,CAAA,GAAI,IAAA;AAC7D,UAAA,IAAI,OAAA,EAASC,oCAAA,CAAmB,OAAA,EAAS,IAAA,EAAM,OAAkB,CAAA;AACjE,UAAA,IAAI,GAAA,MAAS,OAAO,CAAA;AAAA,QACtB,CAAA;AACA,QAAA,QAAA,CAAS,GAAA,CAAI,UAAU,WAAW,CAAA;AAAA,MACpC;AAEA,MAAA,MAAM,MAAA,GAAS;AAAA,QACb,GAAG,cAAA;AAAA,QACH,GAAA,EAAK,QAAA,CAAS,GAAA,CAAI,QAAQ;AAAA,OAC5B;AAEA,MAAAC,4BAAA,CAAW,QAAQ,GAAG,CAAA;AAEtB,MAAA,OAAO,MAAA;AAAA,IACT,CAAA;AAAA,EACF,CAAA,EAAG,CAAC,UAAU,CAAC,CAAA;AACjB;ACxCe,SAAR,iBAAkC,KAAA,EAE/B;AACR,EAAA,MAAM,EAAE,IAAA,EAAM,QAAA,EAAU,OAAA,EAAQ,GAAI,KAAA;AACpC,EAAA,MAAM,GAAA,GAAMC,aAAgC,IAAI,CAAA;AAChD,EAAA,MAAM,OAAA,GAAUA,aAAO,IAAI,CAAA;AAC3B,EAAA,MAAM,UAAA,GAAaA,aAAO,OAAO,CAAA;AAEjC,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,GAAUJ,iCAAA,CAAgB,KAAA,CAAM,KAAK,CAAA;AACzC,IAAAK,0BAAA,CAAS,QAAQ,OAAA,EAAS,UAAA,CAAW,OAAO,CAAA,CAAE,IAAI,OAAO,CAAA;AAAA,EAC3D,CAAA,EAAG,EAAE,CAAA;AAEL,EAAAC,eAAA,CAAU,MAAM;AACd,IAAA,IAAIC,kCAAA,IAAY,CAAC,GAAA,CAAI,OAAA,IAAW,CAAC,QAAA,EAAU;AAC3C,IAAA,QAAA,CAAS,IAAI,OAAO,CAAA;AAAA,EACtB,CAAA,EAAG,CAAC,QAAQ,CAAC,CAAA;AAEb,EAAA,IAAIA,kCAAA,EAAU;AACZ,IAAA,OAAO,MAAY;AAAA,IAEnB,CAAA;AAAA,EACF;AAEA,EAAA,OAAO,WAAA;AACT","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 { useCallback, useEffect, useRef } from 'react';\n\nimport withMask from '../api/withMask';\nimport { resolveInputRef } 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 Ant Design form elements.\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 Ant Design 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<HTMLInputElement | null>(null);\n const maskRef = useRef(mask);\n const optionsRef = useRef(options);\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);\n withMask(maskRef.current, optionsRef.current)(ref.current);\n }, []);\n\n useEffect(() => {\n if (isServer || !ref.current || !register) return;\n register(ref.current);\n }, [register]);\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
|
@@ -23,14 +23,13 @@ interface UseMaskInputOptions {
|
|
|
23
23
|
options?: Options;
|
|
24
24
|
}
|
|
25
25
|
/**
|
|
26
|
-
* React hook for applying input masks to form elements.
|
|
27
|
-
* Works with Ant Design and other wrapped components too.
|
|
26
|
+
* React hook for applying input masks to Ant Design form elements.
|
|
28
27
|
*
|
|
29
28
|
* @param props - Configuration object
|
|
30
29
|
* @param props.mask - The mask pattern to apply
|
|
31
30
|
* @param props.register - Optional callback that receives the element
|
|
32
31
|
* @param props.options - Optional mask configuration options
|
|
33
|
-
* @returns A ref callback function to attach to the
|
|
32
|
+
* @returns A ref callback function to attach to the Ant Design Input element
|
|
34
33
|
*/
|
|
35
34
|
declare function useMaskInputAntd(props: UseMaskInputOptions): (input: InputRef | null) => void;
|
|
36
35
|
|
package/dist/antd.d.ts
CHANGED
|
@@ -23,14 +23,13 @@ interface UseMaskInputOptions {
|
|
|
23
23
|
options?: Options;
|
|
24
24
|
}
|
|
25
25
|
/**
|
|
26
|
-
* React hook for applying input masks to form elements.
|
|
27
|
-
* Works with Ant Design and other wrapped components too.
|
|
26
|
+
* React hook for applying input masks to Ant Design form elements.
|
|
28
27
|
*
|
|
29
28
|
* @param props - Configuration object
|
|
30
29
|
* @param props.mask - The mask pattern to apply
|
|
31
30
|
* @param props.register - Optional callback that receives the element
|
|
32
31
|
* @param props.options - Optional mask configuration options
|
|
33
|
-
* @returns A ref callback function to attach to the
|
|
32
|
+
* @returns A ref callback function to attach to the Ant Design Input element
|
|
34
33
|
*/
|
|
35
34
|
declare function useMaskInputAntd(props: UseMaskInputOptions): (input: InputRef | null) => void;
|
|
36
35
|
|
package/dist/antd.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { makeMaskCacheKey, setPrevRef,
|
|
1
|
+
import { makeMaskCacheKey, setPrevRef, resolveInputRef, withMask, isServer_default, applyMaskToElement } from './chunk-QCWLMMDI.js';
|
|
2
2
|
import { useMemo, useRef, useCallback, useEffect } from 'react';
|
|
3
3
|
|
|
4
4
|
function useHookFormMaskAntd(registerFn) {
|
|
@@ -29,30 +29,20 @@ function useHookFormMaskAntd(registerFn) {
|
|
|
29
29
|
function useMaskInputAntd(props) {
|
|
30
30
|
const { mask, register, options } = props;
|
|
31
31
|
const ref = useRef(null);
|
|
32
|
-
const
|
|
33
|
-
|
|
34
|
-
[mask, options]
|
|
35
|
-
);
|
|
32
|
+
const maskRef = useRef(mask);
|
|
33
|
+
const optionsRef = useRef(options);
|
|
36
34
|
const refCallback = useCallback((input) => {
|
|
37
35
|
if (!input) {
|
|
38
36
|
ref.current = null;
|
|
39
37
|
return;
|
|
40
38
|
}
|
|
41
39
|
ref.current = resolveInputRef(input.input);
|
|
40
|
+
withMask(maskRef.current, optionsRef.current)(ref.current);
|
|
42
41
|
}, []);
|
|
43
42
|
useEffect(() => {
|
|
44
|
-
if (isServer_default || !ref.current) return;
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
}
|
|
48
|
-
const inputElement = findInputElement(ref.current);
|
|
49
|
-
if (maskInput && inputElement && isHTMLElement(inputElement)) {
|
|
50
|
-
maskInput.mask(inputElement);
|
|
51
|
-
}
|
|
52
|
-
if (register && isHTMLElement(ref.current)) {
|
|
53
|
-
register(ref.current);
|
|
54
|
-
}
|
|
55
|
-
}, [mask, register, options, maskInput]);
|
|
43
|
+
if (isServer_default || !ref.current || !register) return;
|
|
44
|
+
register(ref.current);
|
|
45
|
+
}, [register]);
|
|
56
46
|
if (isServer_default) {
|
|
57
47
|
return () => {
|
|
58
48
|
};
|
package/dist/antd.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/antd/useHookFormMaskAntd.ts","../src/antd/useMaskInputAntd.ts"],"names":[
|
|
1
|
+
{"version":3,"sources":["../src/antd/useHookFormMaskAntd.ts","../src/antd/useMaskInputAntd.ts"],"names":[],"mappings":";;;AA6Be,SAAR,oBAEL,UAAA,EAC6D;AAE7D,EAAA,OAAO,QAAQ,MAAM;AACnB,IAAA,MAAM,QAAA,uBAAe,GAAA,EAA0C;AAE/D,IAAA,OAAO,CAAC,SAAA,EAAoB,IAAA,EAAY,OAAA,KACuB;AAC7D,MAAA,IAAI,CAAC,UAAA,EAAY,MAAM,IAAI,MAAM,wBAAwB,CAAA;AAEzD,MAAA,MAAM,cAAA,GAAiB,UAAA,CAAW,SAAA,EAAW,OAAkB,CAAA;AAC/D,MAAA,MAAM,EAAE,KAAI,GAAI,cAAA;AAEhB,MAAA,MAAM,QAAA,GAAW,gBAAA,CAAiB,SAAA,EAAW,IAAI,CAAA;AAEjD,MAAA,IAAI,CAAC,QAAA,CAAS,GAAA,CAAI,QAAQ,CAAA,EAAG;AAC3B,QAAA,MAAM,WAAA,GAA4C,CAAC,QAAA,KAAa;AAC9D,UAAA,MAAM,OAAA,GAAU,QAAA,GAAW,eAAA,CAAgB,QAAA,CAAS,KAAK,CAAA,GAAI,IAAA;AAC7D,UAAA,IAAI,OAAA,EAAS,kBAAA,CAAmB,OAAA,EAAS,IAAA,EAAM,OAAkB,CAAA;AACjE,UAAA,IAAI,GAAA,MAAS,OAAO,CAAA;AAAA,QACtB,CAAA;AACA,QAAA,QAAA,CAAS,GAAA,CAAI,UAAU,WAAW,CAAA;AAAA,MACpC;AAEA,MAAA,MAAM,MAAA,GAAS;AAAA,QACb,GAAG,cAAA;AAAA,QACH,GAAA,EAAK,QAAA,CAAS,GAAA,CAAI,QAAQ;AAAA,OAC5B;AAEA,MAAA,UAAA,CAAW,QAAQ,GAAG,CAAA;AAEtB,MAAA,OAAO,MAAA;AAAA,IACT,CAAA;AAAA,EACF,CAAA,EAAG,CAAC,UAAU,CAAC,CAAA;AACjB;ACxCe,SAAR,iBAAkC,KAAA,EAE/B;AACR,EAAA,MAAM,EAAE,IAAA,EAAM,QAAA,EAAU,OAAA,EAAQ,GAAI,KAAA;AACpC,EAAA,MAAM,GAAA,GAAM,OAAgC,IAAI,CAAA;AAChD,EAAA,MAAM,OAAA,GAAU,OAAO,IAAI,CAAA;AAC3B,EAAA,MAAM,UAAA,GAAa,OAAO,OAAO,CAAA;AAEjC,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;AACzC,IAAA,QAAA,CAAS,QAAQ,OAAA,EAAS,UAAA,CAAW,OAAO,CAAA,CAAE,IAAI,OAAO,CAAA;AAAA,EAC3D,CAAA,EAAG,EAAE,CAAA;AAEL,EAAA,SAAA,CAAU,MAAM;AACd,IAAA,IAAI,gBAAA,IAAY,CAAC,GAAA,CAAI,OAAA,IAAW,CAAC,QAAA,EAAU;AAC3C,IAAA,QAAA,CAAS,IAAI,OAAO,CAAA;AAAA,EACtB,CAAA,EAAG,CAAC,QAAQ,CAAC,CAAA;AAEb,EAAA,IAAI,gBAAA,EAAU;AACZ,IAAA,OAAO,MAAY;AAAA,IAEnB,CAAA;AAAA,EACF;AAEA,EAAA,OAAO,WAAA;AACT","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 { useCallback, useEffect, useRef } from 'react';\n\nimport withMask from '../api/withMask';\nimport { resolveInputRef } 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 Ant Design form elements.\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 Ant Design 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<HTMLInputElement | null>(null);\n const maskRef = useRef(mask);\n const optionsRef = useRef(options);\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);\n withMask(maskRef.current, optionsRef.current)(ref.current);\n }, []);\n\n useEffect(() => {\n if (isServer || !ref.current || !register) return;\n register(ref.current);\n }, [register]);\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"]}
|
|
@@ -20,7 +20,7 @@ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__ge
|
|
|
20
20
|
// file that has been converted to a CommonJS file using a Babel-
|
|
21
21
|
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
22
22
|
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
23
|
-
|
|
23
|
+
__defProp(target, "default", { value: mod, enumerable: true }) ,
|
|
24
24
|
mod
|
|
25
25
|
));
|
|
26
26
|
|
|
@@ -3675,47 +3675,8 @@ var require_inputmask = __commonJS({
|
|
|
3675
3675
|
}
|
|
3676
3676
|
});
|
|
3677
3677
|
|
|
3678
|
-
// src/
|
|
3679
|
-
|
|
3680
|
-
return element !== null && typeof element === "object" && "nodeType" in element && "querySelector" in element && typeof element.querySelector === "function";
|
|
3681
|
-
}
|
|
3682
|
-
function findInputElement(element) {
|
|
3683
|
-
if (!element) return null;
|
|
3684
|
-
if (!isHTMLElement(element)) {
|
|
3685
|
-
return null;
|
|
3686
|
-
}
|
|
3687
|
-
if (element.nodeName === "INPUT" || element.nodeName === "TEXTAREA") {
|
|
3688
|
-
return element;
|
|
3689
|
-
}
|
|
3690
|
-
if (!("querySelector" in element) || typeof element.querySelector !== "function") {
|
|
3691
|
-
return null;
|
|
3692
|
-
}
|
|
3693
|
-
try {
|
|
3694
|
-
const inputElement = element.querySelector("input, textarea");
|
|
3695
|
-
if (inputElement && isHTMLElement(inputElement)) {
|
|
3696
|
-
return inputElement;
|
|
3697
|
-
}
|
|
3698
|
-
} catch {
|
|
3699
|
-
return null;
|
|
3700
|
-
}
|
|
3701
|
-
return null;
|
|
3702
|
-
}
|
|
3703
|
-
function resolveInputRef(input) {
|
|
3704
|
-
if (!input) {
|
|
3705
|
-
return null;
|
|
3706
|
-
}
|
|
3707
|
-
if (typeof input === "object" && "current" in input) {
|
|
3708
|
-
const refValue = input.current;
|
|
3709
|
-
if (isHTMLElement(refValue)) {
|
|
3710
|
-
return refValue;
|
|
3711
|
-
}
|
|
3712
|
-
return null;
|
|
3713
|
-
}
|
|
3714
|
-
if (isHTMLElement(input)) {
|
|
3715
|
-
return input;
|
|
3716
|
-
}
|
|
3717
|
-
return null;
|
|
3718
|
-
}
|
|
3678
|
+
// src/api/withMask.ts
|
|
3679
|
+
var import_inputmask = __toESM(require_inputmask());
|
|
3719
3680
|
|
|
3720
3681
|
// src/core/maskConfig.ts
|
|
3721
3682
|
var ALIAS_MASKS = {
|
|
@@ -3809,10 +3770,52 @@ function setPrevRef(result, ref) {
|
|
|
3809
3770
|
});
|
|
3810
3771
|
}
|
|
3811
3772
|
|
|
3773
|
+
// src/api/withMask.ts
|
|
3774
|
+
var callbackCache = /* @__PURE__ */ new Map();
|
|
3775
|
+
function withMask(mask, options) {
|
|
3776
|
+
if (!options) {
|
|
3777
|
+
const cacheKey = makeMaskCacheKey("", mask);
|
|
3778
|
+
if (callbackCache.has(cacheKey)) {
|
|
3779
|
+
return callbackCache.get(cacheKey);
|
|
3780
|
+
}
|
|
3781
|
+
}
|
|
3782
|
+
const callback = (input) => {
|
|
3783
|
+
if (isServer_default || mask === null || !input) return;
|
|
3784
|
+
const maskInput = interopDefaultSync(import_inputmask.default)(getMaskOptions(mask, options));
|
|
3785
|
+
maskInput.mask(input);
|
|
3786
|
+
};
|
|
3787
|
+
if (!options) {
|
|
3788
|
+
const cacheKey = makeMaskCacheKey("", mask);
|
|
3789
|
+
callbackCache.set(cacheKey, callback);
|
|
3790
|
+
}
|
|
3791
|
+
return callback;
|
|
3792
|
+
}
|
|
3793
|
+
|
|
3794
|
+
// src/core/elementResolver.ts
|
|
3795
|
+
function isHTMLElement(element) {
|
|
3796
|
+
return element !== null && typeof element === "object" && "nodeType" in element && "querySelector" in element && typeof element.querySelector === "function";
|
|
3797
|
+
}
|
|
3798
|
+
function resolveInputRef(input) {
|
|
3799
|
+
if (!input) {
|
|
3800
|
+
return null;
|
|
3801
|
+
}
|
|
3802
|
+
if (typeof input === "object" && "current" in input) {
|
|
3803
|
+
const refValue = input.current;
|
|
3804
|
+
if (isHTMLElement(refValue)) {
|
|
3805
|
+
return refValue;
|
|
3806
|
+
}
|
|
3807
|
+
return null;
|
|
3808
|
+
}
|
|
3809
|
+
if (isHTMLElement(input)) {
|
|
3810
|
+
return input;
|
|
3811
|
+
}
|
|
3812
|
+
return null;
|
|
3813
|
+
}
|
|
3814
|
+
|
|
3812
3815
|
// src/core/maskEngine.ts
|
|
3813
|
-
var
|
|
3816
|
+
var import_inputmask2 = __toESM(require_inputmask());
|
|
3814
3817
|
function createMaskInstance(mask, options) {
|
|
3815
|
-
const inputmaskInstance = interopDefaultSync(
|
|
3818
|
+
const inputmaskInstance = interopDefaultSync(import_inputmask2.default);
|
|
3816
3819
|
return inputmaskInstance(getMaskOptions(mask, options));
|
|
3817
3820
|
}
|
|
3818
3821
|
function applyMaskToElement(element, mask, options) {
|
|
@@ -3838,6 +3841,6 @@ inputmask/dist/inputmask.js:
|
|
|
3838
3841
|
(*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/babel/babel/blob/main/packages/babel-helpers/LICENSE *)
|
|
3839
3842
|
*/
|
|
3840
3843
|
|
|
3841
|
-
export {
|
|
3842
|
-
//# sourceMappingURL=chunk-
|
|
3843
|
-
//# sourceMappingURL=chunk-
|
|
3844
|
+
export { applyMaskToElement, flow, isServer_default, makeMaskCacheKey, resolveInputRef, setPrevRef, withMask };
|
|
3845
|
+
//# sourceMappingURL=chunk-QCWLMMDI.js.map
|
|
3846
|
+
//# sourceMappingURL=chunk-QCWLMMDI.js.map
|