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 +7 -0
- package/README.md +1 -1
- package/dist/antd.cjs +31 -30
- package/dist/antd.cjs.map +1 -1
- package/dist/antd.d.cts +1 -1
- package/dist/antd.d.ts +1 -1
- package/dist/antd.js +24 -23
- package/dist/antd.js.map +1 -1
- package/dist/{chunk-JGOZSJMW.js → chunk-FDD3PKBM.js} +17 -3
- package/dist/chunk-FDD3PKBM.js.map +1 -0
- package/dist/{chunk-4Y2DTPBL.cjs → chunk-NIHSNNRR.cjs} +18 -2
- package/dist/chunk-NIHSNNRR.cjs.map +1 -0
- package/dist/index.cjs +75 -47
- 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 +64 -36
- package/dist/index.js.map +1 -1
- package/package.json +1 -1
- package/src/antd/useHookFormMaskAntd.spec.ts +86 -49
- package/src/antd/useHookFormMaskAntd.ts +34 -25
- package/src/api/useHookFormMask.spec.ts +125 -59
- package/src/api/useHookFormMask.ts +38 -32
- package/src/api/withHookFormMask.spec.ts +55 -0
- package/src/api/withHookFormMask.ts +33 -19
- package/src/api/withMask.spec.ts +28 -0
- package/src/api/withMask.ts +20 -2
- package/src/core/maskConfig.spec.ts +1 -0
- package/src/core/maskConfig.ts +1 -0
- package/src/utils/index.ts +1 -0
- package/src/utils/maskHelpers.ts +22 -0
- package/dist/chunk-4Y2DTPBL.cjs.map +0 -1
- package/dist/chunk-JGOZSJMW.js.map +0 -1
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
|
-
  
|
|
5
|
+
   [](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
|
|
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 (
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
const
|
|
14
|
-
|
|
15
|
-
if (
|
|
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
|
-
|
|
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
|
-
() =>
|
|
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 =
|
|
43
|
+
ref.current = chunkNIHSNNRR_cjs.resolveInputRef(input.input);
|
|
43
44
|
}, []);
|
|
44
45
|
react.useEffect(() => {
|
|
45
|
-
if (
|
|
46
|
-
if (!
|
|
46
|
+
if (chunkNIHSNNRR_cjs.isServer_default || !ref.current) return;
|
|
47
|
+
if (!chunkNIHSNNRR_cjs.isHTMLElement(ref.current)) {
|
|
47
48
|
return;
|
|
48
49
|
}
|
|
49
|
-
const inputElement =
|
|
50
|
-
if (maskInput && 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 &&
|
|
54
|
+
if (register && chunkNIHSNNRR_cjs.isHTMLElement(ref.current)) {
|
|
54
55
|
register(ref.current);
|
|
55
56
|
}
|
|
56
57
|
}, [mask, register, options, maskInput]);
|
|
57
|
-
if (
|
|
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","
|
|
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-
|
|
2
|
-
import {
|
|
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 (
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
const
|
|
12
|
-
|
|
13
|
-
if (
|
|
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
|
-
|
|
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":"
|
|
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-
|
|
3829
|
-
//# sourceMappingURL=chunk-
|
|
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
|