preact-intlayer 8.5.0 → 8.5.1

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 (105) hide show
  1. package/dist/cjs/client/index.cjs +0 -2
  2. package/dist/cjs/format/index.cjs +20 -0
  3. package/dist/cjs/{client/format → format}/useCompact.cjs +3 -3
  4. package/dist/cjs/format/useCompact.cjs.map +1 -0
  5. package/dist/cjs/{client/format → format}/useCurrency.cjs +3 -3
  6. package/dist/cjs/format/useCurrency.cjs.map +1 -0
  7. package/dist/cjs/{client/format → format}/useDate.cjs +3 -3
  8. package/dist/cjs/format/useDate.cjs.map +1 -0
  9. package/dist/cjs/{client/format → format}/useIntl.cjs +3 -3
  10. package/dist/cjs/format/useIntl.cjs.map +1 -0
  11. package/dist/cjs/{client/format → format}/useList.cjs +3 -3
  12. package/dist/cjs/format/useList.cjs.map +1 -0
  13. package/dist/cjs/{client/format → format}/useNumber.cjs +3 -3
  14. package/dist/cjs/format/useNumber.cjs.map +1 -0
  15. package/dist/cjs/{client/format → format}/usePercentage.cjs +3 -3
  16. package/dist/cjs/format/usePercentage.cjs.map +1 -0
  17. package/dist/cjs/{client/format → format}/useRelativeTime.cjs +3 -3
  18. package/dist/cjs/format/useRelativeTime.cjs.map +1 -0
  19. package/dist/cjs/{client/format → format}/useUnit.cjs +3 -3
  20. package/dist/cjs/format/useUnit.cjs.map +1 -0
  21. package/dist/cjs/index.cjs +0 -2
  22. package/dist/esm/client/index.mjs +1 -2
  23. package/dist/esm/{client/format → format}/index.mjs +2 -1
  24. package/dist/esm/{client/format → format}/useCompact.mjs +2 -2
  25. package/dist/esm/format/useCompact.mjs.map +1 -0
  26. package/dist/esm/{client/format → format}/useCurrency.mjs +2 -2
  27. package/dist/esm/format/useCurrency.mjs.map +1 -0
  28. package/dist/esm/{client/format → format}/useDate.mjs +2 -2
  29. package/dist/esm/format/useDate.mjs.map +1 -0
  30. package/dist/esm/{client/format → format}/useIntl.mjs +2 -2
  31. package/dist/esm/format/useIntl.mjs.map +1 -0
  32. package/dist/esm/{client/format → format}/useList.mjs +2 -2
  33. package/dist/esm/format/useList.mjs.map +1 -0
  34. package/dist/esm/{client/format → format}/useNumber.mjs +2 -2
  35. package/dist/esm/format/useNumber.mjs.map +1 -0
  36. package/dist/esm/{client/format → format}/usePercentage.mjs +2 -2
  37. package/dist/esm/format/usePercentage.mjs.map +1 -0
  38. package/dist/esm/{client/format → format}/useRelativeTime.mjs +2 -2
  39. package/dist/esm/format/useRelativeTime.mjs.map +1 -0
  40. package/dist/esm/{client/format → format}/useUnit.mjs +2 -2
  41. package/dist/esm/format/useUnit.mjs.map +1 -0
  42. package/dist/esm/index.mjs +1 -2
  43. package/dist/types/client/index.d.ts +1 -2
  44. package/dist/types/client/useContent.d.ts +2 -2
  45. package/dist/types/client/useContent.d.ts.map +1 -1
  46. package/dist/types/client/useDictionary.d.ts +2 -2
  47. package/dist/types/client/useDictionary.d.ts.map +1 -1
  48. package/dist/types/client/useDictionaryDynamic.d.ts +2 -2
  49. package/dist/types/client/useDictionaryDynamic.d.ts.map +1 -1
  50. package/dist/types/client/useLocale.d.ts +3 -3
  51. package/dist/types/client/useLocaleBase.d.ts +5 -6
  52. package/dist/types/client/useLocaleBase.d.ts.map +1 -1
  53. package/dist/types/client/useLocaleStorage.d.ts +5 -5
  54. package/dist/types/client/useLocaleStorage.d.ts.map +1 -1
  55. package/dist/types/{client/format → format}/index.d.ts +2 -1
  56. package/dist/types/{client/format → format}/useCompact.d.ts +3 -3
  57. package/dist/types/format/useCompact.d.ts.map +1 -0
  58. package/dist/types/{client/format → format}/useCurrency.d.ts +3 -3
  59. package/dist/types/format/useCurrency.d.ts.map +1 -0
  60. package/dist/types/{client/format → format}/useDate.d.ts +1 -1
  61. package/dist/types/format/useDate.d.ts.map +1 -0
  62. package/dist/types/{client/format → format}/useIntl.d.ts +1 -1
  63. package/dist/types/format/useIntl.d.ts.map +1 -0
  64. package/dist/types/{client/format → format}/useList.d.ts +3 -3
  65. package/dist/types/format/useList.d.ts.map +1 -0
  66. package/dist/types/{client/format → format}/useNumber.d.ts +3 -3
  67. package/dist/types/format/useNumber.d.ts.map +1 -0
  68. package/dist/types/{client/format → format}/usePercentage.d.ts +3 -3
  69. package/dist/types/format/usePercentage.d.ts.map +1 -0
  70. package/dist/types/{client/format → format}/useRelativeTime.d.ts +3 -3
  71. package/dist/types/format/useRelativeTime.d.ts.map +1 -0
  72. package/dist/types/{client/format → format}/useUnit.d.ts +3 -3
  73. package/dist/types/format/useUnit.d.ts.map +1 -0
  74. package/dist/types/index.d.ts +1 -2
  75. package/dist/types/index.d.ts.map +1 -1
  76. package/dist/types/intlayer/dist/types/index.d.ts +4 -0
  77. package/package.json +11 -11
  78. package/dist/cjs/client/format/index.cjs +0 -18
  79. package/dist/cjs/client/format/useCompact.cjs.map +0 -1
  80. package/dist/cjs/client/format/useCurrency.cjs.map +0 -1
  81. package/dist/cjs/client/format/useDate.cjs.map +0 -1
  82. package/dist/cjs/client/format/useIntl.cjs.map +0 -1
  83. package/dist/cjs/client/format/useList.cjs.map +0 -1
  84. package/dist/cjs/client/format/useNumber.cjs.map +0 -1
  85. package/dist/cjs/client/format/usePercentage.cjs.map +0 -1
  86. package/dist/cjs/client/format/useRelativeTime.cjs.map +0 -1
  87. package/dist/cjs/client/format/useUnit.cjs.map +0 -1
  88. package/dist/esm/client/format/useCompact.mjs.map +0 -1
  89. package/dist/esm/client/format/useCurrency.mjs.map +0 -1
  90. package/dist/esm/client/format/useDate.mjs.map +0 -1
  91. package/dist/esm/client/format/useIntl.mjs.map +0 -1
  92. package/dist/esm/client/format/useList.mjs.map +0 -1
  93. package/dist/esm/client/format/useNumber.mjs.map +0 -1
  94. package/dist/esm/client/format/usePercentage.mjs.map +0 -1
  95. package/dist/esm/client/format/useRelativeTime.mjs.map +0 -1
  96. package/dist/esm/client/format/useUnit.mjs.map +0 -1
  97. package/dist/types/client/format/useCompact.d.ts.map +0 -1
  98. package/dist/types/client/format/useCurrency.d.ts.map +0 -1
  99. package/dist/types/client/format/useDate.d.ts.map +0 -1
  100. package/dist/types/client/format/useIntl.d.ts.map +0 -1
  101. package/dist/types/client/format/useList.d.ts.map +0 -1
  102. package/dist/types/client/format/useNumber.d.ts.map +0 -1
  103. package/dist/types/client/format/usePercentage.d.ts.map +0 -1
  104. package/dist/types/client/format/useRelativeTime.d.ts.map +0 -1
  105. package/dist/types/client/format/useUnit.d.ts.map +0 -1
@@ -1,7 +1,6 @@
1
1
  Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
2
2
  const require_client_useLocaleStorage = require('./useLocaleStorage.cjs');
3
3
  const require_client_IntlayerProvider = require('./IntlayerProvider.cjs');
4
- const require_client_format_useIntl = require('./format/useIntl.cjs');
5
4
  const require_client_t = require('./t.cjs');
6
5
  const require_client_useDictionary = require('./useDictionary.cjs');
7
6
  const require_client_useDictionaryAsync = require('./useDictionaryAsync.cjs');
@@ -22,7 +21,6 @@ exports.t = require_client_t.t;
22
21
  exports.useDictionary = require_client_useDictionary.useDictionary;
23
22
  exports.useDictionaryAsync = require_client_useDictionaryAsync.useDictionaryAsync;
24
23
  exports.useDictionaryDynamic = require_client_useDictionaryDynamic.useDictionaryDynamic;
25
- exports.useIntl = require_client_format_useIntl.useIntl;
26
24
  exports.useIntlayer = require_client_useIntlayer.useIntlayer;
27
25
  exports.useIntlayerContext = require_client_IntlayerProvider.useIntlayerContext;
28
26
  exports.useLoadDynamic = require_client_useLoadDynamic.useLoadDynamic;
@@ -0,0 +1,20 @@
1
+ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
2
+ const require_format_useUnit = require('./useUnit.cjs');
3
+ const require_format_useDate = require('./useDate.cjs');
4
+ const require_format_useNumber = require('./useNumber.cjs');
5
+ const require_format_useRelativeTime = require('./useRelativeTime.cjs');
6
+ const require_format_useCompact = require('./useCompact.cjs');
7
+ const require_format_useIntl = require('./useIntl.cjs');
8
+ const require_format_useList = require('./useList.cjs');
9
+ const require_format_usePercentage = require('./usePercentage.cjs');
10
+ const require_format_useCurrency = require('./useCurrency.cjs');
11
+
12
+ exports.useCompact = require_format_useCompact.useCompact;
13
+ exports.useCurrency = require_format_useCurrency.useCurrency;
14
+ exports.useDate = require_format_useDate.useDate;
15
+ exports.useIntl = require_format_useIntl.useIntl;
16
+ exports.useList = require_format_useList.useList;
17
+ exports.useNumber = require_format_useNumber.useNumber;
18
+ exports.usePercentage = require_format_usePercentage.usePercentage;
19
+ exports.useRelativeTime = require_format_useRelativeTime.useRelativeTime;
20
+ exports.useUnit = require_format_useUnit.useUnit;
@@ -1,10 +1,10 @@
1
1
  Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
2
- const require_runtime = require('../../_virtual/_rolldown/runtime.cjs');
3
- const require_client_IntlayerProvider = require('../IntlayerProvider.cjs');
2
+ const require_runtime = require('../_virtual/_rolldown/runtime.cjs');
3
+ const require_client_IntlayerProvider = require('../client/IntlayerProvider.cjs');
4
4
  let preact_hooks = require("preact/hooks");
5
5
  let _intlayer_core_formatters = require("@intlayer/core/formatters");
6
6
 
7
- //#region src/client/format/useCompact.ts
7
+ //#region src/format/useCompact.ts
8
8
  /**
9
9
  * React client hook that provides a compact number formatter
10
10
  * bound to the current application locale.
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useCompact.cjs","names":["IntlayerClientContext"],"sources":["../../../src/format/useCompact.ts"],"sourcesContent":["import { compact } from '@intlayer/core/formatters';\nimport { useCallback, useContext } from 'preact/hooks';\nimport { IntlayerClientContext } from '../client/IntlayerProvider';\n\n/**\n * React client hook that provides a compact number formatter\n * bound to the current application locale.\n *\n * @example\n * ```tsx\n * const formatCompact = useCompact();\n * formatCompact(1500); // \"1.5K\"\n * ```\n */\nexport const useCompact = () => {\n const { locale } = useContext(IntlayerClientContext);\n\n return useCallback(\n (...args: Parameters<typeof compact>) =>\n compact(args[0], {\n ...args[1],\n locale: args[1]?.locale ?? locale,\n }),\n [locale]\n );\n};\n"],"mappings":";;;;;;;;;;;;;;;;;AAcA,MAAa,mBAAmB;CAC9B,MAAM,EAAE,wCAAsBA,sDAAsB;AAEpD,uCACG,GAAG,gDACM,KAAK,IAAI;EACf,GAAG,KAAK;EACR,QAAQ,KAAK,IAAI,UAAU;EAC5B,CAAC,EACJ,CAAC,OAAO,CACT"}
@@ -1,10 +1,10 @@
1
1
  Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
2
- const require_runtime = require('../../_virtual/_rolldown/runtime.cjs');
3
- const require_client_IntlayerProvider = require('../IntlayerProvider.cjs');
2
+ const require_runtime = require('../_virtual/_rolldown/runtime.cjs');
3
+ const require_client_IntlayerProvider = require('../client/IntlayerProvider.cjs');
4
4
  let preact_hooks = require("preact/hooks");
5
5
  let _intlayer_core_formatters = require("@intlayer/core/formatters");
6
6
 
7
- //#region src/client/format/useCurrency.ts
7
+ //#region src/format/useCurrency.ts
8
8
  /**
9
9
  * React client hook that provides a currency formatter
10
10
  * bound to the current application locale.
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useCurrency.cjs","names":["IntlayerClientContext"],"sources":["../../../src/format/useCurrency.ts"],"sourcesContent":["import { currency } from '@intlayer/core/formatters';\nimport { useCallback, useContext } from 'preact/hooks';\nimport { IntlayerClientContext } from '../client/IntlayerProvider';\n\n/**\n * React client hook that provides a currency formatter\n * bound to the current application locale.\n *\n * @returns {(value: string | number, options?: CurrencyProps) => string}\n * A function to format numbers into localized currency strings.\n *\n * @example\n * ```tsx\n * const formatCurrency = useCurrency();\n *\n * formatCurrency(1500, { currency: \"USD\" });\n * // \"$1,500.00\"\n *\n * formatCurrency(1500, { currency: \"EUR\", locale: \"de-DE\" });\n * // \"1.500,00 €\"\n *\n * formatCurrency(9876543.21, {\n * currency: \"JPY\",\n * fractionDigits: 0,\n * });\n * // \"¥9,876,543\"\n * ```\n */\nexport const useCurrency = () => {\n const { locale } = useContext(IntlayerClientContext);\n\n return useCallback(\n (...args: Parameters<typeof currency>) =>\n currency(args[0], {\n ...args[1],\n locale: args[1]?.locale ?? locale,\n }),\n [locale]\n );\n};\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA4BA,MAAa,oBAAoB;CAC/B,MAAM,EAAE,wCAAsBA,sDAAsB;AAEpD,uCACG,GAAG,iDACO,KAAK,IAAI;EAChB,GAAG,KAAK;EACR,QAAQ,KAAK,IAAI,UAAU;EAC5B,CAAC,EACJ,CAAC,OAAO,CACT"}
@@ -1,10 +1,10 @@
1
1
  Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
2
- const require_runtime = require('../../_virtual/_rolldown/runtime.cjs');
3
- const require_client_IntlayerProvider = require('../IntlayerProvider.cjs');
2
+ const require_runtime = require('../_virtual/_rolldown/runtime.cjs');
3
+ const require_client_IntlayerProvider = require('../client/IntlayerProvider.cjs');
4
4
  let preact_hooks = require("preact/hooks");
5
5
  let _intlayer_core_formatters = require("@intlayer/core/formatters");
6
6
 
7
- //#region src/client/format/useDate.ts
7
+ //#region src/format/useDate.ts
8
8
  /**
9
9
  * React client hook that provides a localized date/time formatter
10
10
  * bound to the current application locale.
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useDate.cjs","names":["IntlayerClientContext"],"sources":["../../../src/format/useDate.ts"],"sourcesContent":["import { date } from '@intlayer/core/formatters';\nimport { useContext } from 'preact/hooks';\nimport { IntlayerClientContext } from '../client/IntlayerProvider';\n\n/**\n * React client hook that provides a localized date/time formatter\n * bound to the current application locale.\n *\n * @returns {(date: Date | string | number, options?: DateProps) => string}\n * A function to format dates or timestamps into localized date/time strings.\n *\n * @example\n * ```tsx\n * const formatDate = useDate();\n *\n * formatDate(new Date(\"2025-01-01\"));\n * // \"Jan 1, 2025\"\n *\n * formatDate(\"2025-01-01T15:30:00Z\", {\n * dateStyle: \"full\",\n * timeStyle: \"short\",\n * });\n * // \"Wednesday, January 1, 2025 at 3:30 PM\"\n *\n * formatDate(1735689600000, { locale: \"fr-FR\", dateStyle: \"long\" });\n * // \"1 janvier 2025\"\n * ```\n *\n * @see createDate\n */\nexport const useDate = () => {\n const { locale } = useContext(IntlayerClientContext);\n\n return (...args: Parameters<typeof date>) =>\n date(args[0], {\n ...args[1],\n locale: args[1]?.locale ?? locale,\n });\n};\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA8BA,MAAa,gBAAgB;CAC3B,MAAM,EAAE,wCAAsBA,sDAAsB;AAEpD,SAAQ,GAAG,6CACJ,KAAK,IAAI;EACZ,GAAG,KAAK;EACR,QAAQ,KAAK,IAAI,UAAU;EAC5B,CAAC"}
@@ -1,10 +1,10 @@
1
1
  Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
2
- const require_runtime = require('../../_virtual/_rolldown/runtime.cjs');
3
- const require_client_IntlayerProvider = require('../IntlayerProvider.cjs');
2
+ const require_runtime = require('../_virtual/_rolldown/runtime.cjs');
3
+ const require_client_IntlayerProvider = require('../client/IntlayerProvider.cjs');
4
4
  let preact_hooks = require("preact/hooks");
5
5
  let _intlayer_core_formatters = require("@intlayer/core/formatters");
6
6
 
7
- //#region src/client/format/useIntl.ts
7
+ //#region src/format/useIntl.ts
8
8
  /**
9
9
  * Preact client hook that provides a locale-bound `Intl` object.
10
10
  *
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useIntl.cjs","names":["IntlayerClientContext"],"sources":["../../../src/format/useIntl.ts"],"sourcesContent":["import { bindIntl, type WrappedIntl } from '@intlayer/core/formatters';\nimport type { LocalesValues } from '@intlayer/types/module_augmentation';\nimport { useContext, useMemo } from 'preact/hooks';\nimport { IntlayerClientContext } from '../client/IntlayerProvider';\n\n/**\n * Preact client hook that provides a locale-bound `Intl` object.\n *\n * It acts exactly like the native `Intl` object, but acts as a proxy to:\n * 1. Inject the current locale automatically if none is provided.\n * 2. Use the performance-optimized `CachedIntl` under the hood.\n *\n * @example\n * ```tsx\n * const intl = useIntl(); // uses context locale\n *\n * // Standard API, but no need to pass locale as the first argument\n * const formatted = new intl.NumberFormat({\n * style: 'currency',\n * currency: 'USD'\n * }).format(123.45);\n * ```\n */\nexport const useIntl = (locale?: LocalesValues) => {\n const { locale: contextLocale } = useContext(IntlayerClientContext);\n const currentLocale = locale ?? contextLocale;\n\n return useMemo<WrappedIntl>(() => bindIntl(currentLocale), [currentLocale]);\n};\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;AAuBA,MAAa,WAAW,WAA2B;CACjD,MAAM,EAAE,QAAQ,+CAA6BA,sDAAsB;CACnE,MAAM,gBAAgB,UAAU;AAEhC,gFAA2C,cAAc,EAAE,CAAC,cAAc,CAAC"}
@@ -1,10 +1,10 @@
1
1
  Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
2
- const require_runtime = require('../../_virtual/_rolldown/runtime.cjs');
3
- const require_client_IntlayerProvider = require('../IntlayerProvider.cjs');
2
+ const require_runtime = require('../_virtual/_rolldown/runtime.cjs');
3
+ const require_client_IntlayerProvider = require('../client/IntlayerProvider.cjs');
4
4
  let preact_hooks = require("preact/hooks");
5
5
  let _intlayer_core_formatters = require("@intlayer/core/formatters");
6
6
 
7
- //#region src/client/format/useList.ts
7
+ //#region src/format/useList.ts
8
8
  /**
9
9
  * React client hook that provides a list formatter
10
10
  * bound to the current application locale.
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useList.cjs","names":["IntlayerClientContext"],"sources":["../../../src/format/useList.ts"],"sourcesContent":["import { list } from '@intlayer/core/formatters';\nimport { useCallback, useContext } from 'preact/hooks';\nimport { IntlayerClientContext } from '../client/IntlayerProvider';\n\n/**\n * React client hook that provides a list formatter\n * bound to the current application locale.\n *\n * @returns {(values: (string | number)[], options?: ListProps) => string}\n * A function to format arrays into localized list strings.\n *\n * @example\n * ```tsx\n * const formatList = useList();\n *\n * formatList(['apple', 'banana', 'orange']);\n * // \"apple, banana, and orange\"\n *\n * formatList(['red', 'green', 'blue'], { type: 'disjunction' });\n * // \"red, green, or blue\"\n *\n * formatList([1, 2, 3], { type: 'unit', locale: 'de-DE' });\n * // \"1, 2 und 3\"\n * ```\n */\nexport const useList = () => {\n const { locale } = useContext(IntlayerClientContext);\n\n return useCallback(\n (...args: Parameters<typeof list>) =>\n list(args[0], {\n ...args[1],\n locale: args[1]?.locale ?? locale,\n }),\n [locale]\n );\n};\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAyBA,MAAa,gBAAgB;CAC3B,MAAM,EAAE,wCAAsBA,sDAAsB;AAEpD,uCACG,GAAG,6CACG,KAAK,IAAI;EACZ,GAAG,KAAK;EACR,QAAQ,KAAK,IAAI,UAAU;EAC5B,CAAC,EACJ,CAAC,OAAO,CACT"}
@@ -1,10 +1,10 @@
1
1
  Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
2
- const require_runtime = require('../../_virtual/_rolldown/runtime.cjs');
3
- const require_client_IntlayerProvider = require('../IntlayerProvider.cjs');
2
+ const require_runtime = require('../_virtual/_rolldown/runtime.cjs');
3
+ const require_client_IntlayerProvider = require('../client/IntlayerProvider.cjs');
4
4
  let preact_hooks = require("preact/hooks");
5
5
  let _intlayer_core_formatters = require("@intlayer/core/formatters");
6
6
 
7
- //#region src/client/format/useNumber.ts
7
+ //#region src/format/useNumber.ts
8
8
  /**
9
9
  * React client hook that provides a localized number formatter.
10
10
  *
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useNumber.cjs","names":["IntlayerClientContext"],"sources":["../../../src/format/useNumber.ts"],"sourcesContent":["import { number } from '@intlayer/core/formatters';\nimport { useCallback, useContext } from 'preact/hooks';\nimport { IntlayerClientContext } from '../client/IntlayerProvider';\n\n/**\n * React client hook that provides a localized number formatter.\n *\n * Uses the current locale from {@link useLocaleBase} and returns\n * a function that can be used to format numbers consistently\n * according to the user's locale.\n *\n * @example\n * ```tsx\n * const formatNumber = useNumber();\n *\n * formatNumber(12345);\n * // e.g. \"12,345\" (en-US)\n * // e.g. \"12 345\" (fr-FR)\n *\n * formatNumber(0.75, { style: \"percent\" });\n * // e.g. \"75%\"\n * ```\n *\n * @returns {(value: string | number, options?: import(\"../createNumber\").NumberProps) => string}\n * A number formatting function bound to the active locale.\n */\nexport const useNumber = () => {\n const { locale } = useContext(IntlayerClientContext);\n\n return useCallback(\n (...args: Parameters<typeof number>) =>\n number(args[0], {\n ...args[1],\n locale: args[1]?.locale ?? locale,\n }),\n [locale]\n );\n};\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA0BA,MAAa,kBAAkB;CAC7B,MAAM,EAAE,wCAAsBA,sDAAsB;AAEpD,uCACG,GAAG,+CACK,KAAK,IAAI;EACd,GAAG,KAAK;EACR,QAAQ,KAAK,IAAI,UAAU;EAC5B,CAAC,EACJ,CAAC,OAAO,CACT"}
@@ -1,10 +1,10 @@
1
1
  Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
2
- const require_runtime = require('../../_virtual/_rolldown/runtime.cjs');
3
- const require_client_IntlayerProvider = require('../IntlayerProvider.cjs');
2
+ const require_runtime = require('../_virtual/_rolldown/runtime.cjs');
3
+ const require_client_IntlayerProvider = require('../client/IntlayerProvider.cjs');
4
4
  let preact_hooks = require("preact/hooks");
5
5
  let _intlayer_core_formatters = require("@intlayer/core/formatters");
6
6
 
7
- //#region src/client/format/usePercentage.ts
7
+ //#region src/format/usePercentage.ts
8
8
  /**
9
9
  * React hook to provide a percentage formatter function
10
10
  * based on the current application locale.
@@ -0,0 +1 @@
1
+ {"version":3,"file":"usePercentage.cjs","names":["IntlayerClientContext"],"sources":["../../../src/format/usePercentage.ts"],"sourcesContent":["import { percentage } from '@intlayer/core/formatters';\nimport { useCallback, useContext } from 'preact/hooks';\nimport { IntlayerClientContext } from '../client/IntlayerProvider';\n\n/**\n * React hook to provide a percentage formatter function\n * based on the current application locale.\n *\n * This hook retrieves the active locale using {@link useLocaleBase}\n * and memoizes a `createPercentage` instance for that locale.\n *\n * @example\n * ```tsx\n * const formatPercentage = usePercentage();\n *\n * const result = formatPercentage(0.875, { maximumFractionDigits: 1 });\n * // \"87.5%\" (depending on locale)\n * ```\n *\n * @returns {(value: string | number, options?: Omit<PercentageOptions, \"value\">) => string}\n * A function that formats numbers or numeric strings into localized percentages.\n */\nexport const usePercentage = () => {\n const { locale } = useContext(IntlayerClientContext);\n\n return useCallback(\n (...args: Parameters<typeof percentage>) =>\n percentage(args[0], {\n ...args[1],\n locale: args[1]?.locale ?? locale,\n }),\n [locale]\n );\n};\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;AAsBA,MAAa,sBAAsB;CACjC,MAAM,EAAE,wCAAsBA,sDAAsB;AAEpD,uCACG,GAAG,mDACS,KAAK,IAAI;EAClB,GAAG,KAAK;EACR,QAAQ,KAAK,IAAI,UAAU;EAC5B,CAAC,EACJ,CAAC,OAAO,CACT"}
@@ -1,10 +1,10 @@
1
1
  Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
2
- const require_runtime = require('../../_virtual/_rolldown/runtime.cjs');
3
- const require_client_IntlayerProvider = require('../IntlayerProvider.cjs');
2
+ const require_runtime = require('../_virtual/_rolldown/runtime.cjs');
3
+ const require_client_IntlayerProvider = require('../client/IntlayerProvider.cjs');
4
4
  let preact_hooks = require("preact/hooks");
5
5
  let _intlayer_core_formatters = require("@intlayer/core/formatters");
6
6
 
7
- //#region src/client/format/useRelativeTime.ts
7
+ //#region src/format/useRelativeTime.ts
8
8
  /**
9
9
  * Client-side React hook for accessing a localized relative time formatter.
10
10
  *
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useRelativeTime.cjs","names":["IntlayerClientContext"],"sources":["../../../src/format/useRelativeTime.ts"],"sourcesContent":["import { relativeTime } from '@intlayer/core/formatters';\nimport { useCallback, useContext } from 'preact/hooks';\nimport { IntlayerClientContext } from '../client/IntlayerProvider';\n\n/**\n * Client-side React hook for accessing a localized relative time formatter.\n *\n * This hook:\n * - Reads the current locale from {@link useLocaleBase}.\n * - Creates a new relative time formatter with {@link createRelativeTime}.\n * - Returns a function that can format time differences into localized strings.\n *\n * Example:\n * ```tsx\n * const relativeTime = useRelativeTime();\n * const formatted = relativeTime(new Date(\"2024-08-01\"), new Date());\n * // e.g., \"2 weeks ago\"\n * ```\n *\n * @returns {ReturnType<typeof createRelativeTime>} A relative time formatting function\n * bound to the current client locale.\n */\nexport const useRelativeTime = () => {\n const { locale } = useContext(IntlayerClientContext);\n\n return useCallback(\n (...args: Parameters<typeof relativeTime>) =>\n relativeTime(args[0], args[1], {\n ...args[2],\n locale: args[2]?.locale ?? locale,\n }),\n [locale]\n );\n};\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;AAsBA,MAAa,wBAAwB;CACnC,MAAM,EAAE,wCAAsBA,sDAAsB;AAEpD,uCACG,GAAG,qDACW,KAAK,IAAI,KAAK,IAAI;EAC7B,GAAG,KAAK;EACR,QAAQ,KAAK,IAAI,UAAU;EAC5B,CAAC,EACJ,CAAC,OAAO,CACT"}
@@ -1,10 +1,10 @@
1
1
  Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
2
- const require_runtime = require('../../_virtual/_rolldown/runtime.cjs');
3
- const require_client_IntlayerProvider = require('../IntlayerProvider.cjs');
2
+ const require_runtime = require('../_virtual/_rolldown/runtime.cjs');
3
+ const require_client_IntlayerProvider = require('../client/IntlayerProvider.cjs');
4
4
  let preact_hooks = require("preact/hooks");
5
5
  let _intlayer_core_formatters = require("@intlayer/core/formatters");
6
6
 
7
- //#region src/client/format/useUnit.ts
7
+ //#region src/format/useUnit.ts
8
8
  /**
9
9
  * React hook that provides a unit formatting function
10
10
  * based on the current locale from {@link useLocaleBase}.
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useUnit.cjs","names":["IntlayerClientContext"],"sources":["../../../src/format/useUnit.ts"],"sourcesContent":["import { units } from '@intlayer/core/formatters';\nimport { useCallback, useContext } from 'preact/hooks';\nimport { IntlayerClientContext } from '../client/IntlayerProvider';\n\n/**\n * React hook that provides a unit formatting function\n * based on the current locale from {@link useLocaleBase}.\n *\n * This hook wraps {@link createUnit} to return a formatter\n * that can convert values into human-readable localized units\n * (e.g., \"10 km\", \"5 lbs\").\n *\n * @example\n * ```tsx\n * const formatUnit = useUnit();\n * const distance = formatUnit(10, { unit: \"kilometer\" });\n * // \"10 km\" (depending on locale)\n * ```\n *\n * @returns {Function} A unit formatting function that accepts a value and optional formatting options.\n */\nexport const useUnit = () => {\n const { locale } = useContext(IntlayerClientContext);\n\n return useCallback(\n (...args: Parameters<typeof units>) =>\n units(args[0], {\n ...args[1],\n locale: args[1]?.locale ?? locale,\n }),\n [locale]\n );\n};\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;AAqBA,MAAa,gBAAgB;CAC3B,MAAM,EAAE,wCAAsBA,sDAAsB;AAEpD,uCACG,GAAG,8CACI,KAAK,IAAI;EACb,GAAG,KAAK;EACR,QAAQ,KAAK,IAAI,UAAU;EAC5B,CAAC,EACJ,CAAC,OAAO,CACT"}
@@ -3,7 +3,6 @@ const require_getIntlayer = require('./getIntlayer.cjs');
3
3
  const require_getDictionary = require('./getDictionary.cjs');
4
4
  const require_client_useLocaleStorage = require('./client/useLocaleStorage.cjs');
5
5
  const require_client_IntlayerProvider = require('./client/IntlayerProvider.cjs');
6
- const require_client_format_useIntl = require('./client/format/useIntl.cjs');
7
6
  const require_client_t = require('./client/t.cjs');
8
7
  const require_client_useDictionary = require('./client/useDictionary.cjs');
9
8
  const require_client_useDictionaryAsync = require('./client/useDictionaryAsync.cjs');
@@ -25,7 +24,6 @@ exports.t = require_client_t.t;
25
24
  exports.useDictionary = require_client_useDictionary.useDictionary;
26
25
  exports.useDictionaryAsync = require_client_useDictionaryAsync.useDictionaryAsync;
27
26
  exports.useDictionaryDynamic = require_client_useDictionaryDynamic.useDictionaryDynamic;
28
- exports.useIntl = require_client_format_useIntl.useIntl;
29
27
  exports.useIntlayer = require_client_useIntlayer.useIntlayer;
30
28
  exports.useIntlayerContext = require_client_IntlayerProvider.useIntlayerContext;
31
29
  exports.useLoadDynamic = require_client_useLoadDynamic.useLoadDynamic;
@@ -1,6 +1,5 @@
1
1
  import { localeCookie, localeInStorage, setLocaleCookie, setLocaleInStorage, useLocaleCookie, useLocaleStorage } from "./useLocaleStorage.mjs";
2
2
  import { IntlayerClientContext, IntlayerProvider, IntlayerProviderContent, useIntlayerContext } from "./IntlayerProvider.mjs";
3
- import { useIntl } from "./format/useIntl.mjs";
4
3
  import { t } from "./t.mjs";
5
4
  import { useDictionary } from "./useDictionary.mjs";
6
5
  import { useDictionaryAsync } from "./useDictionaryAsync.mjs";
@@ -10,4 +9,4 @@ import { useIntlayer } from "./useIntlayer.mjs";
10
9
  import { useLocale } from "./useLocale.mjs";
11
10
  import { useLocaleBase } from "./useLocaleBase.mjs";
12
11
 
13
- export { IntlayerClientContext, IntlayerProvider, IntlayerProviderContent, localeCookie, localeInStorage, setLocaleCookie, setLocaleInStorage, t, useDictionary, useDictionaryAsync, useDictionaryDynamic, useIntl, useIntlayer, useIntlayerContext, useLoadDynamic, useLocale, useLocaleBase, useLocaleCookie, useLocaleStorage };
12
+ export { IntlayerClientContext, IntlayerProvider, IntlayerProviderContent, localeCookie, localeInStorage, setLocaleCookie, setLocaleInStorage, t, useDictionary, useDictionaryAsync, useDictionaryDynamic, useIntlayer, useIntlayerContext, useLoadDynamic, useLocale, useLocaleBase, useLocaleCookie, useLocaleStorage };
@@ -3,8 +3,9 @@ import { useDate } from "./useDate.mjs";
3
3
  import { useNumber } from "./useNumber.mjs";
4
4
  import { useRelativeTime } from "./useRelativeTime.mjs";
5
5
  import { useCompact } from "./useCompact.mjs";
6
+ import { useIntl } from "./useIntl.mjs";
6
7
  import { useList } from "./useList.mjs";
7
8
  import { usePercentage } from "./usePercentage.mjs";
8
9
  import { useCurrency } from "./useCurrency.mjs";
9
10
 
10
- export { useCompact, useCurrency, useDate, useList, useNumber, usePercentage, useRelativeTime, useUnit };
11
+ export { useCompact, useCurrency, useDate, useIntl, useList, useNumber, usePercentage, useRelativeTime, useUnit };
@@ -1,8 +1,8 @@
1
- import { IntlayerClientContext } from "../IntlayerProvider.mjs";
1
+ import { IntlayerClientContext } from "../client/IntlayerProvider.mjs";
2
2
  import { useCallback, useContext } from "preact/hooks";
3
3
  import { compact } from "@intlayer/core/formatters";
4
4
 
5
- //#region src/client/format/useCompact.ts
5
+ //#region src/format/useCompact.ts
6
6
  /**
7
7
  * React client hook that provides a compact number formatter
8
8
  * bound to the current application locale.
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useCompact.mjs","names":[],"sources":["../../../src/format/useCompact.ts"],"sourcesContent":["import { compact } from '@intlayer/core/formatters';\nimport { useCallback, useContext } from 'preact/hooks';\nimport { IntlayerClientContext } from '../client/IntlayerProvider';\n\n/**\n * React client hook that provides a compact number formatter\n * bound to the current application locale.\n *\n * @example\n * ```tsx\n * const formatCompact = useCompact();\n * formatCompact(1500); // \"1.5K\"\n * ```\n */\nexport const useCompact = () => {\n const { locale } = useContext(IntlayerClientContext);\n\n return useCallback(\n (...args: Parameters<typeof compact>) =>\n compact(args[0], {\n ...args[1],\n locale: args[1]?.locale ?? locale,\n }),\n [locale]\n );\n};\n"],"mappings":";;;;;;;;;;;;;;;AAcA,MAAa,mBAAmB;CAC9B,MAAM,EAAE,WAAW,WAAW,sBAAsB;AAEpD,QAAO,aACJ,GAAG,SACF,QAAQ,KAAK,IAAI;EACf,GAAG,KAAK;EACR,QAAQ,KAAK,IAAI,UAAU;EAC5B,CAAC,EACJ,CAAC,OAAO,CACT"}
@@ -1,8 +1,8 @@
1
- import { IntlayerClientContext } from "../IntlayerProvider.mjs";
1
+ import { IntlayerClientContext } from "../client/IntlayerProvider.mjs";
2
2
  import { useCallback, useContext } from "preact/hooks";
3
3
  import { currency } from "@intlayer/core/formatters";
4
4
 
5
- //#region src/client/format/useCurrency.ts
5
+ //#region src/format/useCurrency.ts
6
6
  /**
7
7
  * React client hook that provides a currency formatter
8
8
  * bound to the current application locale.
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useCurrency.mjs","names":[],"sources":["../../../src/format/useCurrency.ts"],"sourcesContent":["import { currency } from '@intlayer/core/formatters';\nimport { useCallback, useContext } from 'preact/hooks';\nimport { IntlayerClientContext } from '../client/IntlayerProvider';\n\n/**\n * React client hook that provides a currency formatter\n * bound to the current application locale.\n *\n * @returns {(value: string | number, options?: CurrencyProps) => string}\n * A function to format numbers into localized currency strings.\n *\n * @example\n * ```tsx\n * const formatCurrency = useCurrency();\n *\n * formatCurrency(1500, { currency: \"USD\" });\n * // \"$1,500.00\"\n *\n * formatCurrency(1500, { currency: \"EUR\", locale: \"de-DE\" });\n * // \"1.500,00 €\"\n *\n * formatCurrency(9876543.21, {\n * currency: \"JPY\",\n * fractionDigits: 0,\n * });\n * // \"¥9,876,543\"\n * ```\n */\nexport const useCurrency = () => {\n const { locale } = useContext(IntlayerClientContext);\n\n return useCallback(\n (...args: Parameters<typeof currency>) =>\n currency(args[0], {\n ...args[1],\n locale: args[1]?.locale ?? locale,\n }),\n [locale]\n );\n};\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA4BA,MAAa,oBAAoB;CAC/B,MAAM,EAAE,WAAW,WAAW,sBAAsB;AAEpD,QAAO,aACJ,GAAG,SACF,SAAS,KAAK,IAAI;EAChB,GAAG,KAAK;EACR,QAAQ,KAAK,IAAI,UAAU;EAC5B,CAAC,EACJ,CAAC,OAAO,CACT"}
@@ -1,8 +1,8 @@
1
- import { IntlayerClientContext } from "../IntlayerProvider.mjs";
1
+ import { IntlayerClientContext } from "../client/IntlayerProvider.mjs";
2
2
  import { useContext } from "preact/hooks";
3
3
  import { date } from "@intlayer/core/formatters";
4
4
 
5
- //#region src/client/format/useDate.ts
5
+ //#region src/format/useDate.ts
6
6
  /**
7
7
  * React client hook that provides a localized date/time formatter
8
8
  * bound to the current application locale.
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useDate.mjs","names":[],"sources":["../../../src/format/useDate.ts"],"sourcesContent":["import { date } from '@intlayer/core/formatters';\nimport { useContext } from 'preact/hooks';\nimport { IntlayerClientContext } from '../client/IntlayerProvider';\n\n/**\n * React client hook that provides a localized date/time formatter\n * bound to the current application locale.\n *\n * @returns {(date: Date | string | number, options?: DateProps) => string}\n * A function to format dates or timestamps into localized date/time strings.\n *\n * @example\n * ```tsx\n * const formatDate = useDate();\n *\n * formatDate(new Date(\"2025-01-01\"));\n * // \"Jan 1, 2025\"\n *\n * formatDate(\"2025-01-01T15:30:00Z\", {\n * dateStyle: \"full\",\n * timeStyle: \"short\",\n * });\n * // \"Wednesday, January 1, 2025 at 3:30 PM\"\n *\n * formatDate(1735689600000, { locale: \"fr-FR\", dateStyle: \"long\" });\n * // \"1 janvier 2025\"\n * ```\n *\n * @see createDate\n */\nexport const useDate = () => {\n const { locale } = useContext(IntlayerClientContext);\n\n return (...args: Parameters<typeof date>) =>\n date(args[0], {\n ...args[1],\n locale: args[1]?.locale ?? locale,\n });\n};\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA8BA,MAAa,gBAAgB;CAC3B,MAAM,EAAE,WAAW,WAAW,sBAAsB;AAEpD,SAAQ,GAAG,SACT,KAAK,KAAK,IAAI;EACZ,GAAG,KAAK;EACR,QAAQ,KAAK,IAAI,UAAU;EAC5B,CAAC"}
@@ -1,8 +1,8 @@
1
- import { IntlayerClientContext } from "../IntlayerProvider.mjs";
1
+ import { IntlayerClientContext } from "../client/IntlayerProvider.mjs";
2
2
  import { useContext, useMemo } from "preact/hooks";
3
3
  import { bindIntl } from "@intlayer/core/formatters";
4
4
 
5
- //#region src/client/format/useIntl.ts
5
+ //#region src/format/useIntl.ts
6
6
  /**
7
7
  * Preact client hook that provides a locale-bound `Intl` object.
8
8
  *
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useIntl.mjs","names":[],"sources":["../../../src/format/useIntl.ts"],"sourcesContent":["import { bindIntl, type WrappedIntl } from '@intlayer/core/formatters';\nimport type { LocalesValues } from '@intlayer/types/module_augmentation';\nimport { useContext, useMemo } from 'preact/hooks';\nimport { IntlayerClientContext } from '../client/IntlayerProvider';\n\n/**\n * Preact client hook that provides a locale-bound `Intl` object.\n *\n * It acts exactly like the native `Intl` object, but acts as a proxy to:\n * 1. Inject the current locale automatically if none is provided.\n * 2. Use the performance-optimized `CachedIntl` under the hood.\n *\n * @example\n * ```tsx\n * const intl = useIntl(); // uses context locale\n *\n * // Standard API, but no need to pass locale as the first argument\n * const formatted = new intl.NumberFormat({\n * style: 'currency',\n * currency: 'USD'\n * }).format(123.45);\n * ```\n */\nexport const useIntl = (locale?: LocalesValues) => {\n const { locale: contextLocale } = useContext(IntlayerClientContext);\n const currentLocale = locale ?? contextLocale;\n\n return useMemo<WrappedIntl>(() => bindIntl(currentLocale), [currentLocale]);\n};\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;AAuBA,MAAa,WAAW,WAA2B;CACjD,MAAM,EAAE,QAAQ,kBAAkB,WAAW,sBAAsB;CACnE,MAAM,gBAAgB,UAAU;AAEhC,QAAO,cAA2B,SAAS,cAAc,EAAE,CAAC,cAAc,CAAC"}
@@ -1,8 +1,8 @@
1
- import { IntlayerClientContext } from "../IntlayerProvider.mjs";
1
+ import { IntlayerClientContext } from "../client/IntlayerProvider.mjs";
2
2
  import { useCallback, useContext } from "preact/hooks";
3
3
  import { list } from "@intlayer/core/formatters";
4
4
 
5
- //#region src/client/format/useList.ts
5
+ //#region src/format/useList.ts
6
6
  /**
7
7
  * React client hook that provides a list formatter
8
8
  * bound to the current application locale.
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useList.mjs","names":[],"sources":["../../../src/format/useList.ts"],"sourcesContent":["import { list } from '@intlayer/core/formatters';\nimport { useCallback, useContext } from 'preact/hooks';\nimport { IntlayerClientContext } from '../client/IntlayerProvider';\n\n/**\n * React client hook that provides a list formatter\n * bound to the current application locale.\n *\n * @returns {(values: (string | number)[], options?: ListProps) => string}\n * A function to format arrays into localized list strings.\n *\n * @example\n * ```tsx\n * const formatList = useList();\n *\n * formatList(['apple', 'banana', 'orange']);\n * // \"apple, banana, and orange\"\n *\n * formatList(['red', 'green', 'blue'], { type: 'disjunction' });\n * // \"red, green, or blue\"\n *\n * formatList([1, 2, 3], { type: 'unit', locale: 'de-DE' });\n * // \"1, 2 und 3\"\n * ```\n */\nexport const useList = () => {\n const { locale } = useContext(IntlayerClientContext);\n\n return useCallback(\n (...args: Parameters<typeof list>) =>\n list(args[0], {\n ...args[1],\n locale: args[1]?.locale ?? locale,\n }),\n [locale]\n );\n};\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAyBA,MAAa,gBAAgB;CAC3B,MAAM,EAAE,WAAW,WAAW,sBAAsB;AAEpD,QAAO,aACJ,GAAG,SACF,KAAK,KAAK,IAAI;EACZ,GAAG,KAAK;EACR,QAAQ,KAAK,IAAI,UAAU;EAC5B,CAAC,EACJ,CAAC,OAAO,CACT"}
@@ -1,8 +1,8 @@
1
- import { IntlayerClientContext } from "../IntlayerProvider.mjs";
1
+ import { IntlayerClientContext } from "../client/IntlayerProvider.mjs";
2
2
  import { useCallback, useContext } from "preact/hooks";
3
3
  import { number } from "@intlayer/core/formatters";
4
4
 
5
- //#region src/client/format/useNumber.ts
5
+ //#region src/format/useNumber.ts
6
6
  /**
7
7
  * React client hook that provides a localized number formatter.
8
8
  *
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useNumber.mjs","names":[],"sources":["../../../src/format/useNumber.ts"],"sourcesContent":["import { number } from '@intlayer/core/formatters';\nimport { useCallback, useContext } from 'preact/hooks';\nimport { IntlayerClientContext } from '../client/IntlayerProvider';\n\n/**\n * React client hook that provides a localized number formatter.\n *\n * Uses the current locale from {@link useLocaleBase} and returns\n * a function that can be used to format numbers consistently\n * according to the user's locale.\n *\n * @example\n * ```tsx\n * const formatNumber = useNumber();\n *\n * formatNumber(12345);\n * // e.g. \"12,345\" (en-US)\n * // e.g. \"12 345\" (fr-FR)\n *\n * formatNumber(0.75, { style: \"percent\" });\n * // e.g. \"75%\"\n * ```\n *\n * @returns {(value: string | number, options?: import(\"../createNumber\").NumberProps) => string}\n * A number formatting function bound to the active locale.\n */\nexport const useNumber = () => {\n const { locale } = useContext(IntlayerClientContext);\n\n return useCallback(\n (...args: Parameters<typeof number>) =>\n number(args[0], {\n ...args[1],\n locale: args[1]?.locale ?? locale,\n }),\n [locale]\n );\n};\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;AA0BA,MAAa,kBAAkB;CAC7B,MAAM,EAAE,WAAW,WAAW,sBAAsB;AAEpD,QAAO,aACJ,GAAG,SACF,OAAO,KAAK,IAAI;EACd,GAAG,KAAK;EACR,QAAQ,KAAK,IAAI,UAAU;EAC5B,CAAC,EACJ,CAAC,OAAO,CACT"}
@@ -1,8 +1,8 @@
1
- import { IntlayerClientContext } from "../IntlayerProvider.mjs";
1
+ import { IntlayerClientContext } from "../client/IntlayerProvider.mjs";
2
2
  import { useCallback, useContext } from "preact/hooks";
3
3
  import { percentage } from "@intlayer/core/formatters";
4
4
 
5
- //#region src/client/format/usePercentage.ts
5
+ //#region src/format/usePercentage.ts
6
6
  /**
7
7
  * React hook to provide a percentage formatter function
8
8
  * based on the current application locale.
@@ -0,0 +1 @@
1
+ {"version":3,"file":"usePercentage.mjs","names":[],"sources":["../../../src/format/usePercentage.ts"],"sourcesContent":["import { percentage } from '@intlayer/core/formatters';\nimport { useCallback, useContext } from 'preact/hooks';\nimport { IntlayerClientContext } from '../client/IntlayerProvider';\n\n/**\n * React hook to provide a percentage formatter function\n * based on the current application locale.\n *\n * This hook retrieves the active locale using {@link useLocaleBase}\n * and memoizes a `createPercentage` instance for that locale.\n *\n * @example\n * ```tsx\n * const formatPercentage = usePercentage();\n *\n * const result = formatPercentage(0.875, { maximumFractionDigits: 1 });\n * // \"87.5%\" (depending on locale)\n * ```\n *\n * @returns {(value: string | number, options?: Omit<PercentageOptions, \"value\">) => string}\n * A function that formats numbers or numeric strings into localized percentages.\n */\nexport const usePercentage = () => {\n const { locale } = useContext(IntlayerClientContext);\n\n return useCallback(\n (...args: Parameters<typeof percentage>) =>\n percentage(args[0], {\n ...args[1],\n locale: args[1]?.locale ?? locale,\n }),\n [locale]\n );\n};\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;AAsBA,MAAa,sBAAsB;CACjC,MAAM,EAAE,WAAW,WAAW,sBAAsB;AAEpD,QAAO,aACJ,GAAG,SACF,WAAW,KAAK,IAAI;EAClB,GAAG,KAAK;EACR,QAAQ,KAAK,IAAI,UAAU;EAC5B,CAAC,EACJ,CAAC,OAAO,CACT"}
@@ -1,8 +1,8 @@
1
- import { IntlayerClientContext } from "../IntlayerProvider.mjs";
1
+ import { IntlayerClientContext } from "../client/IntlayerProvider.mjs";
2
2
  import { useCallback, useContext } from "preact/hooks";
3
3
  import { relativeTime } from "@intlayer/core/formatters";
4
4
 
5
- //#region src/client/format/useRelativeTime.ts
5
+ //#region src/format/useRelativeTime.ts
6
6
  /**
7
7
  * Client-side React hook for accessing a localized relative time formatter.
8
8
  *
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useRelativeTime.mjs","names":[],"sources":["../../../src/format/useRelativeTime.ts"],"sourcesContent":["import { relativeTime } from '@intlayer/core/formatters';\nimport { useCallback, useContext } from 'preact/hooks';\nimport { IntlayerClientContext } from '../client/IntlayerProvider';\n\n/**\n * Client-side React hook for accessing a localized relative time formatter.\n *\n * This hook:\n * - Reads the current locale from {@link useLocaleBase}.\n * - Creates a new relative time formatter with {@link createRelativeTime}.\n * - Returns a function that can format time differences into localized strings.\n *\n * Example:\n * ```tsx\n * const relativeTime = useRelativeTime();\n * const formatted = relativeTime(new Date(\"2024-08-01\"), new Date());\n * // e.g., \"2 weeks ago\"\n * ```\n *\n * @returns {ReturnType<typeof createRelativeTime>} A relative time formatting function\n * bound to the current client locale.\n */\nexport const useRelativeTime = () => {\n const { locale } = useContext(IntlayerClientContext);\n\n return useCallback(\n (...args: Parameters<typeof relativeTime>) =>\n relativeTime(args[0], args[1], {\n ...args[2],\n locale: args[2]?.locale ?? locale,\n }),\n [locale]\n );\n};\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;AAsBA,MAAa,wBAAwB;CACnC,MAAM,EAAE,WAAW,WAAW,sBAAsB;AAEpD,QAAO,aACJ,GAAG,SACF,aAAa,KAAK,IAAI,KAAK,IAAI;EAC7B,GAAG,KAAK;EACR,QAAQ,KAAK,IAAI,UAAU;EAC5B,CAAC,EACJ,CAAC,OAAO,CACT"}
@@ -1,8 +1,8 @@
1
- import { IntlayerClientContext } from "../IntlayerProvider.mjs";
1
+ import { IntlayerClientContext } from "../client/IntlayerProvider.mjs";
2
2
  import { useCallback, useContext } from "preact/hooks";
3
3
  import { units } from "@intlayer/core/formatters";
4
4
 
5
- //#region src/client/format/useUnit.ts
5
+ //#region src/format/useUnit.ts
6
6
  /**
7
7
  * React hook that provides a unit formatting function
8
8
  * based on the current locale from {@link useLocaleBase}.
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useUnit.mjs","names":[],"sources":["../../../src/format/useUnit.ts"],"sourcesContent":["import { units } from '@intlayer/core/formatters';\nimport { useCallback, useContext } from 'preact/hooks';\nimport { IntlayerClientContext } from '../client/IntlayerProvider';\n\n/**\n * React hook that provides a unit formatting function\n * based on the current locale from {@link useLocaleBase}.\n *\n * This hook wraps {@link createUnit} to return a formatter\n * that can convert values into human-readable localized units\n * (e.g., \"10 km\", \"5 lbs\").\n *\n * @example\n * ```tsx\n * const formatUnit = useUnit();\n * const distance = formatUnit(10, { unit: \"kilometer\" });\n * // \"10 km\" (depending on locale)\n * ```\n *\n * @returns {Function} A unit formatting function that accepts a value and optional formatting options.\n */\nexport const useUnit = () => {\n const { locale } = useContext(IntlayerClientContext);\n\n return useCallback(\n (...args: Parameters<typeof units>) =>\n units(args[0], {\n ...args[1],\n locale: args[1]?.locale ?? locale,\n }),\n [locale]\n );\n};\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;AAqBA,MAAa,gBAAgB;CAC3B,MAAM,EAAE,WAAW,WAAW,sBAAsB;AAEpD,QAAO,aACJ,GAAG,SACF,MAAM,KAAK,IAAI;EACb,GAAG,KAAK;EACR,QAAQ,KAAK,IAAI,UAAU;EAC5B,CAAC,EACJ,CAAC,OAAO,CACT"}
@@ -2,7 +2,6 @@ import { getIntlayer } from "./getIntlayer.mjs";
2
2
  import { getDictionary } from "./getDictionary.mjs";
3
3
  import { localeCookie, setLocaleCookie, setLocaleInStorage, useLocaleCookie, useLocaleStorage } from "./client/useLocaleStorage.mjs";
4
4
  import { IntlayerClientContext, IntlayerProvider, IntlayerProviderContent, useIntlayerContext } from "./client/IntlayerProvider.mjs";
5
- import { useIntl } from "./client/format/useIntl.mjs";
6
5
  import { t } from "./client/t.mjs";
7
6
  import { useDictionary } from "./client/useDictionary.mjs";
8
7
  import { useDictionaryAsync } from "./client/useDictionaryAsync.mjs";
@@ -12,4 +11,4 @@ import { useIntlayer } from "./client/useIntlayer.mjs";
12
11
  import { useLocale } from "./client/useLocale.mjs";
13
12
  import { useLocaleBase } from "./client/useLocaleBase.mjs";
14
13
 
15
- export { IntlayerClientContext, IntlayerProvider, IntlayerProviderContent, getDictionary, getIntlayer, localeCookie, setLocaleCookie, setLocaleInStorage, t, useDictionary, useDictionaryAsync, useDictionaryDynamic, useIntl, useIntlayer, useIntlayerContext, useLoadDynamic, useLocale, useLocaleBase, useLocaleCookie, useLocaleStorage };
14
+ export { IntlayerClientContext, IntlayerProvider, IntlayerProviderContent, getDictionary, getIntlayer, localeCookie, setLocaleCookie, setLocaleInStorage, t, useDictionary, useDictionaryAsync, useDictionaryDynamic, useIntlayer, useIntlayerContext, useLoadDynamic, useLocale, useLocaleBase, useLocaleCookie, useLocaleStorage };
@@ -1,5 +1,4 @@
1
1
  import { IntlayerClientContext, IntlayerProvider, IntlayerProviderContent, IntlayerProviderProps, useIntlayerContext } from "./IntlayerProvider.js";
2
- import { useIntl } from "./format/useIntl.js";
3
2
  import { t } from "./t.js";
4
3
  import { useDictionary } from "./useDictionary.js";
5
4
  import { useDictionaryAsync } from "./useDictionaryAsync.js";
@@ -9,4 +8,4 @@ import { useLoadDynamic } from "./useLoadDynamic.js";
9
8
  import { useLocale } from "./useLocale.js";
10
9
  import { useLocaleBase } from "./useLocaleBase.js";
11
10
  import { localeCookie, localeInStorage, setLocaleCookie, setLocaleInStorage, useLocaleCookie, useLocaleStorage } from "./useLocaleStorage.js";
12
- export { IntlayerClientContext, IntlayerProvider, IntlayerProviderContent, type IntlayerProviderProps, localeCookie, localeInStorage, setLocaleCookie, setLocaleInStorage, t, useDictionary, useDictionaryAsync, useDictionaryDynamic, useIntl, useIntlayer, useIntlayerContext, useLoadDynamic, useLocale, useLocaleBase, useLocaleCookie, useLocaleStorage };
11
+ export { IntlayerClientContext, IntlayerProvider, IntlayerProviderContent, type IntlayerProviderProps, localeCookie, localeInStorage, setLocaleCookie, setLocaleInStorage, t, useDictionary, useDictionaryAsync, useDictionaryDynamic, useIntlayer, useIntlayerContext, useLoadDynamic, useLocale, useLocaleBase, useLocaleCookie, useLocaleStorage };
@@ -1,4 +1,4 @@
1
- import * as _intlayer_types_module_augmentation0 from "@intlayer/types/module_augmentation";
1
+ import { LocalesValues as LocalesValues$1 } from "../intlayer/dist/types/index.js";
2
2
  import { StrictModeLocaleMap } from "@intlayer/types/module_augmentation";
3
3
 
4
4
  //#region src/client/useContent.d.ts
@@ -6,7 +6,7 @@ import { StrictModeLocaleMap } from "@intlayer/types/module_augmentation";
6
6
  * On the client side, hook to get the translation content based on the locale
7
7
  */
8
8
  declare const useContent: <Content>(languageContent: StrictModeLocaleMap<Content>) => {
9
- locale: _intlayer_types_module_augmentation0.LocalesValues;
9
+ locale: LocalesValues$1;
10
10
  content: Content;
11
11
  t: <Content_1 = string>(languageContent: StrictModeLocaleMap<Content_1>) => Content_1;
12
12
  };
@@ -1 +1 @@
1
- {"version":3,"file":"useContent.d.ts","names":[],"sources":["../../../src/client/useContent.ts"],"mappings":";;;;;;;cAOa,UAAA,YACX,eAAA,EAAiB,mBAAA,CAAoB,OAAA;UAAD,oCAAA,CAAA,aAAA"}
1
+ {"version":3,"file":"useContent.d.ts","names":[],"sources":["../../../src/client/useContent.ts"],"mappings":";;;;;;;cAOa,UAAA,YACX,eAAA,EAAiB,mBAAA,CAAoB,OAAA;UAAD,eAAA"}
@@ -1,7 +1,7 @@
1
1
  import { IInterpreterPluginState as IInterpreterPluginState$1 } from "../plugins.js";
2
+ import { Locale } from "../intlayer/dist/types/index.js";
2
3
  import * as _intlayer_core_interpreter0 from "@intlayer/core/interpreter";
3
4
  import { DeclaredLocales, LocalesValues } from "@intlayer/types/module_augmentation";
4
- import * as _intlayer_types_allLocales0 from "@intlayer/types/allLocales";
5
5
  import { Dictionary } from "@intlayer/types/dictionary";
6
6
 
7
7
  //#region src/client/useDictionary.d.ts
@@ -10,7 +10,7 @@ import { Dictionary } from "@intlayer/types/dictionary";
10
10
  *
11
11
  * If the locale is not provided, it will use the locale from the client context
12
12
  */
13
- declare const useDictionary: <T extends Dictionary, L extends LocalesValues = DeclaredLocales>(dictionary: T, locale?: L) => _intlayer_core_interpreter0.DeepTransformContent<T["content"], IInterpreterPluginState$1, _intlayer_types_allLocales0.Locale>;
13
+ declare const useDictionary: <T extends Dictionary, L extends LocalesValues = DeclaredLocales>(dictionary: T, locale?: L) => _intlayer_core_interpreter0.DeepTransformContent<T["content"], IInterpreterPluginState$1, Locale>;
14
14
  //#endregion
15
15
  export { useDictionary };
16
16
  //# sourceMappingURL=useDictionary.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"useDictionary.d.ts","names":[],"sources":["../../../src/client/useDictionary.ts"],"mappings":";;;;;;;;;;;;cAca,aAAA,aACD,UAAA,YACA,aAAA,GAAgB,eAAA,EAE1B,UAAA,EAAY,CAAA,EACZ,MAAA,GAAS,CAAA,KAAC,2BAAA,CAAA,oBAAA,CAAA,CAAA,aAAA,yBAAA,EAAA,2BAAA,CAAA,MAAA"}
1
+ {"version":3,"file":"useDictionary.d.ts","names":[],"sources":["../../../src/client/useDictionary.ts"],"mappings":";;;;;;;;;;;;cAca,aAAA,aACD,UAAA,YACA,aAAA,GAAgB,eAAA,EAE1B,UAAA,EAAY,CAAA,EACZ,MAAA,GAAS,CAAA,KAAC,2BAAA,CAAA,oBAAA,CAAA,CAAA,aAAA,yBAAA,EAAA,MAAA"}
@@ -1,7 +1,7 @@
1
1
  import { IInterpreterPluginState as IInterpreterPluginState$1 } from "../plugins.js";
2
+ import { Locale } from "../intlayer/dist/types/index.js";
2
3
  import * as _intlayer_core_interpreter0 from "@intlayer/core/interpreter";
3
4
  import { DictionaryKeys, LocalesValues, StrictModeLocaleMap } from "@intlayer/types/module_augmentation";
4
- import * as _intlayer_types_allLocales0 from "@intlayer/types/allLocales";
5
5
  import { Dictionary } from "@intlayer/types/dictionary";
6
6
 
7
7
  //#region src/client/useDictionaryDynamic.d.ts
@@ -10,7 +10,7 @@ import { Dictionary } from "@intlayer/types/dictionary";
10
10
  *
11
11
  * If the locale is not provided, it will use the locale from the client context
12
12
  */
13
- declare const useDictionaryDynamic: <T extends Dictionary, K extends DictionaryKeys>(dictionaryPromise: StrictModeLocaleMap<() => Promise<T>>, key: K, locale?: LocalesValues) => _intlayer_core_interpreter0.DeepTransformContent<T["content"], IInterpreterPluginState$1, _intlayer_types_allLocales0.Locale>;
13
+ declare const useDictionaryDynamic: <T extends Dictionary, K extends DictionaryKeys>(dictionaryPromise: StrictModeLocaleMap<() => Promise<T>>, key: K, locale?: LocalesValues) => _intlayer_core_interpreter0.DeepTransformContent<T["content"], IInterpreterPluginState$1, Locale>;
14
14
  //#endregion
15
15
  export { useDictionaryDynamic };
16
16
  //# sourceMappingURL=useDictionaryDynamic.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"useDictionaryDynamic.d.ts","names":[],"sources":["../../../src/client/useDictionaryDynamic.ts"],"mappings":";;;;;;;;;;;;cAgBa,oBAAA,aACD,UAAA,YACA,cAAA,EAEV,iBAAA,EAAmB,mBAAA,OAA0B,OAAA,CAAQ,CAAA,IACrD,GAAA,EAAK,CAAA,EACL,MAAA,GAAS,aAAA,KAAa,2BAAA,CAAA,oBAAA,CAAA,CAAA,aAAA,yBAAA,EAAA,2BAAA,CAAA,MAAA"}
1
+ {"version":3,"file":"useDictionaryDynamic.d.ts","names":[],"sources":["../../../src/client/useDictionaryDynamic.ts"],"mappings":";;;;;;;;;;;;cAgBa,oBAAA,aACD,UAAA,YACA,cAAA,EAEV,iBAAA,EAAmB,mBAAA,OAA0B,OAAA,CAAQ,CAAA,IACrD,GAAA,EAAK,CAAA,EACL,MAAA,GAAS,aAAA,KAAa,2BAAA,CAAA,oBAAA,CAAA,CAAA,aAAA,yBAAA,EAAA,MAAA"}
@@ -1,5 +1,5 @@
1
+ import { Locale } from "../intlayer/dist/types/index.js";
1
2
  import { LocalesValues } from "@intlayer/types/module_augmentation";
2
- import * as _intlayer_types_allLocales0 from "@intlayer/types/allLocales";
3
3
 
4
4
  //#region src/client/useLocale.d.ts
5
5
  type useLocaleProps = {
@@ -34,8 +34,8 @@ declare const useLocale: ({
34
34
  onLocaleChange
35
35
  }?: useLocaleProps) => {
36
36
  locale: LocalesValues;
37
- defaultLocale: _intlayer_types_allLocales0.Locale;
38
- availableLocales: _intlayer_types_allLocales0.Locale[];
37
+ defaultLocale: Locale;
38
+ availableLocales: Locale[];
39
39
  setLocale: (locale: LocalesValues) => void;
40
40
  };
41
41
  //#endregion
@@ -1,15 +1,14 @@
1
- import * as _intlayer_types_module_augmentation0 from "@intlayer/types/module_augmentation";
2
- import * as _intlayer_types_allLocales0 from "@intlayer/types/allLocales";
1
+ import { Locale, LocalesValues } from "../intlayer/dist/types/index.js";
3
2
 
4
3
  //#region src/client/useLocaleBase.d.ts
5
4
  /**
6
5
  * On the client side, hook to get the current locale and all related fields
7
6
  */
8
7
  declare const useLocaleBase: () => {
9
- locale: _intlayer_types_module_augmentation0.LocalesValues;
10
- defaultLocale: _intlayer_types_allLocales0.Locale;
11
- availableLocales: _intlayer_types_allLocales0.Locale[];
12
- setLocale: (newLocale: _intlayer_types_module_augmentation0.LocalesValues) => void;
8
+ locale: LocalesValues;
9
+ defaultLocale: Locale;
10
+ availableLocales: Locale[];
11
+ setLocale: (newLocale: LocalesValues) => void;
13
12
  };
14
13
  //#endregion
15
14
  export { useLocaleBase };
@@ -1 +1 @@
1
- {"version":3,"file":"useLocaleBase.d.ts","names":[],"sources":["../../../src/client/useLocaleBase.ts"],"mappings":";;;;;;;cAUa,aAAA;UASZ,oCAAA,CAAA,aAAA"}
1
+ {"version":3,"file":"useLocaleBase.d.ts","names":[],"sources":["../../../src/client/useLocaleBase.ts"],"mappings":";;;;;;cAUa,aAAA;UASZ,aAAA"}