use-mask-input 3.7.0 → 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.
Files changed (39) hide show
  1. package/CHANGELOG.md +13 -0
  2. package/README.md +1 -1
  3. package/dist/antd.cjs +68 -0
  4. package/dist/antd.cjs.map +1 -0
  5. package/dist/{antd/index.d.ts → antd.d.cts} +2 -2
  6. package/dist/{antd/index.d.cts → antd.d.ts} +2 -2
  7. package/dist/antd.js +65 -0
  8. package/dist/antd.js.map +1 -0
  9. package/dist/{chunk-JGOZSJMW.js → chunk-FDD3PKBM.js} +17 -3
  10. package/dist/chunk-FDD3PKBM.js.map +1 -0
  11. package/dist/{chunk-4Y2DTPBL.cjs → chunk-NIHSNNRR.cjs} +18 -2
  12. package/dist/chunk-NIHSNNRR.cjs.map +1 -0
  13. package/dist/index.cjs +75 -47
  14. package/dist/index.cjs.map +1 -1
  15. package/dist/index.d.cts +2 -2
  16. package/dist/index.d.ts +2 -2
  17. package/dist/index.js +64 -36
  18. package/dist/index.js.map +1 -1
  19. package/package.json +1 -1
  20. package/src/antd/useHookFormMaskAntd.spec.ts +92 -55
  21. package/src/antd/useHookFormMaskAntd.ts +34 -25
  22. package/src/antd/useMaskInputAntd-server.spec.tsx +3 -2
  23. package/src/antd/useMaskInputAntd.spec.tsx +7 -6
  24. package/src/api/useHookFormMask.spec.ts +125 -59
  25. package/src/api/useHookFormMask.ts +38 -32
  26. package/src/api/withHookFormMask.spec.ts +55 -0
  27. package/src/api/withHookFormMask.ts +33 -19
  28. package/src/api/withMask.spec.ts +28 -0
  29. package/src/api/withMask.ts +20 -2
  30. package/src/core/maskConfig.spec.ts +1 -0
  31. package/src/core/maskConfig.ts +1 -0
  32. package/src/utils/index.ts +1 -0
  33. package/src/utils/maskHelpers.ts +22 -0
  34. package/dist/antd/index.cjs +0 -67
  35. package/dist/antd/index.cjs.map +0 -1
  36. package/dist/antd/index.js +0 -64
  37. package/dist/antd/index.js.map +0 -1
  38. package/dist/chunk-4Y2DTPBL.cjs.map +0 -1
  39. package/dist/chunk-JGOZSJMW.js.map +0 -1
package/CHANGELOG.md CHANGED
@@ -1,5 +1,18 @@
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
+
10
+ ## 3.7.1
11
+
12
+ ### Patch Changes
13
+
14
+ - 6ba9e71: adjust entrypoint types in use-mask-input package configuration
15
+
3
16
  ## 3.7.0
4
17
 
5
18
  ### Minor 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 ADDED
@@ -0,0 +1,68 @@
1
+ 'use strict';
2
+
3
+ var chunkNIHSNNRR_cjs = require('./chunk-NIHSNNRR.cjs');
4
+ var react = require('react');
5
+
6
+ function useHookFormMaskAntd(registerFn) {
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;
28
+ };
29
+ }, [registerFn]);
30
+ }
31
+ function useMaskInputAntd(props) {
32
+ const { mask, register, options } = props;
33
+ const ref = react.useRef(null);
34
+ const maskInput = react.useMemo(
35
+ () => chunkNIHSNNRR_cjs.isServer_default ? null : chunkNIHSNNRR_cjs.createMaskInstance(mask, options),
36
+ [mask, options]
37
+ );
38
+ const refCallback = react.useCallback((input) => {
39
+ if (!input) {
40
+ ref.current = null;
41
+ return;
42
+ }
43
+ ref.current = chunkNIHSNNRR_cjs.resolveInputRef(input.input);
44
+ }, []);
45
+ react.useEffect(() => {
46
+ if (chunkNIHSNNRR_cjs.isServer_default || !ref.current) return;
47
+ if (!chunkNIHSNNRR_cjs.isHTMLElement(ref.current)) {
48
+ return;
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) {
59
+ return () => {
60
+ };
61
+ }
62
+ return refCallback;
63
+ }
64
+
65
+ exports.useHookFormMaskAntd = useHookFormMaskAntd;
66
+ exports.useMaskInputAntd = useMaskInputAntd;
67
+ //# sourceMappingURL=antd.cjs.map
68
+ //# sourceMappingURL=antd.cjs.map
@@ -0,0 +1 @@
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"]}
@@ -1,7 +1,7 @@
1
1
  import { InputRef } from 'antd';
2
2
  import { RefCallback } from 'react';
3
3
  import { FieldValues, RegisterOptions, UseFormRegister, Path } from 'react-hook-form';
4
- import { U as UseHookFormMaskReturn, M as Mask, O as Options } from '../index-F3rlTTTe.js';
4
+ import { U as UseHookFormMaskReturn, M as Mask, O as Options } from './index-F3rlTTTe.cjs';
5
5
 
6
6
  type UseHookFormMaskAntdReturn<T extends FieldValues> = Omit<UseHookFormMaskReturn<T>, 'ref'> & {
7
7
  ref: RefCallback<InputRef | null>;
@@ -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;
@@ -1,7 +1,7 @@
1
1
  import { InputRef } from 'antd';
2
2
  import { RefCallback } from 'react';
3
3
  import { FieldValues, RegisterOptions, UseFormRegister, Path } from 'react-hook-form';
4
- import { U as UseHookFormMaskReturn, M as Mask, O as Options } from '../index-F3rlTTTe.cjs';
4
+ import { U as UseHookFormMaskReturn, M as Mask, O as Options } from './index-F3rlTTTe.js';
5
5
 
6
6
  type UseHookFormMaskAntdReturn<T extends FieldValues> = Omit<UseHookFormMaskReturn<T>, 'ref'> & {
7
7
  ref: RefCallback<InputRef | null>;
@@ -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 ADDED
@@ -0,0 +1,65 @@
1
+ import { makeMaskCacheKey, setPrevRef, isServer_default, createMaskInstance, resolveInputRef, isHTMLElement, findInputElement, applyMaskToElement } from './chunk-FDD3PKBM.js';
2
+ import { useMemo, useRef, useCallback, useEffect } from 'react';
3
+
4
+ function useHookFormMaskAntd(registerFn) {
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;
26
+ };
27
+ }, [registerFn]);
28
+ }
29
+ function useMaskInputAntd(props) {
30
+ const { mask, register, options } = props;
31
+ const ref = useRef(null);
32
+ const maskInput = useMemo(
33
+ () => isServer_default ? null : createMaskInstance(mask, options),
34
+ [mask, options]
35
+ );
36
+ const refCallback = useCallback((input) => {
37
+ if (!input) {
38
+ ref.current = null;
39
+ return;
40
+ }
41
+ ref.current = resolveInputRef(input.input);
42
+ }, []);
43
+ useEffect(() => {
44
+ if (isServer_default || !ref.current) return;
45
+ if (!isHTMLElement(ref.current)) {
46
+ return;
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]);
56
+ if (isServer_default) {
57
+ return () => {
58
+ };
59
+ }
60
+ return refCallback;
61
+ }
62
+
63
+ export { useHookFormMaskAntd, useMaskInputAntd };
64
+ //# sourceMappingURL=antd.js.map
65
+ //# sourceMappingURL=antd.js.map
@@ -0,0 +1 @@
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