use-intl 2.11.0-alpha.1 → 2.11.0-useFormatter-alpha.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 (106) hide show
  1. package/CHANGELOG.md +30 -0
  2. package/README.md +32 -20
  3. package/dist/core/createFormatter.d.ts +17 -0
  4. package/dist/core/createIntl.d.ts +5 -15
  5. package/dist/core/index.d.ts +1 -0
  6. package/dist/core/use-intl.esm.js +38 -41
  7. package/dist/core/use-intl.esm.js.map +1 -1
  8. package/dist/core/use-intl.esm10.js +34 -0
  9. package/dist/core/use-intl.esm10.js.map +1 -0
  10. package/dist/core/use-intl.esm2.js +151 -35
  11. package/dist/core/use-intl.esm2.js.map +1 -1
  12. package/dist/core/use-intl.esm3.js +27 -140
  13. package/dist/core/use-intl.esm3.js.map +1 -1
  14. package/dist/core/use-intl.esm4.js +12 -12
  15. package/dist/core/use-intl.esm4.js.map +1 -1
  16. package/dist/core/use-intl.esm5.js +23 -50
  17. package/dist/core/use-intl.esm5.js.map +1 -1
  18. package/dist/core/use-intl.esm6.js +11 -28
  19. package/dist/core/use-intl.esm6.js.map +1 -1
  20. package/dist/core/use-intl.esm7.js +44 -198
  21. package/dist/core/use-intl.esm7.js.map +1 -1
  22. package/dist/core/use-intl.esm8.js +210 -7
  23. package/dist/core/use-intl.esm8.js.map +1 -1
  24. package/dist/core/use-intl.esm9.js +5 -29
  25. package/dist/core/use-intl.esm9.js.map +1 -1
  26. package/dist/react/IntlContext.d.ts +19 -2
  27. package/dist/react/IntlProvider.d.ts +16 -2
  28. package/dist/react/index.d.ts +2 -1
  29. package/dist/react/use-intl.esm.js +26 -7
  30. package/dist/react/use-intl.esm.js.map +1 -1
  31. package/dist/react/use-intl.esm10.js +2 -2
  32. package/dist/react/use-intl.esm2.js +3 -3
  33. package/dist/react/use-intl.esm2.js.map +1 -1
  34. package/dist/react/use-intl.esm3.js +43 -18
  35. package/dist/react/use-intl.esm3.js.map +1 -1
  36. package/dist/react/use-intl.esm4.js +16 -40
  37. package/dist/react/use-intl.esm4.js.map +1 -1
  38. package/dist/react/use-intl.esm5.js +19 -20
  39. package/dist/react/use-intl.esm5.js.map +1 -1
  40. package/dist/react/use-intl.esm6.js +28 -3
  41. package/dist/react/use-intl.esm6.js.map +1 -1
  42. package/dist/react/use-intl.esm7.js +5 -3
  43. package/dist/react/use-intl.esm7.js.map +1 -1
  44. package/dist/react/use-intl.esm8.js +3 -30
  45. package/dist/react/use-intl.esm8.js.map +1 -1
  46. package/dist/react/use-intl.esm9.js +1 -1
  47. package/dist/react/useFormatter.d.ts +5 -0
  48. package/dist/react/useIntl.d.ts +1 -0
  49. package/dist/react/useIntlContext.d.ts +1 -1
  50. package/dist/src/core/createBaseTranslator.js +10 -8
  51. package/dist/src/core/createBaseTranslator.js.map +1 -1
  52. package/dist/src/core/createFormatter.d.ts +17 -0
  53. package/dist/src/core/createFormatter.js +126 -0
  54. package/dist/src/core/createFormatter.js.map +1 -0
  55. package/dist/src/core/createIntl.d.ts +5 -15
  56. package/dist/src/core/createIntl.js +9 -124
  57. package/dist/src/core/createIntl.js.map +1 -1
  58. package/dist/src/core/index.d.ts +1 -0
  59. package/dist/src/core/index.js +2 -0
  60. package/dist/src/core/index.js.map +1 -1
  61. package/dist/src/react/IntlContext.d.ts +19 -2
  62. package/dist/src/react/IntlContext.js.map +1 -1
  63. package/dist/src/react/IntlProvider.d.ts +16 -2
  64. package/dist/src/react/IntlProvider.js +13 -4
  65. package/dist/src/react/IntlProvider.js.map +1 -1
  66. package/dist/src/react/index.d.ts +2 -1
  67. package/dist/src/react/index.js +3 -1
  68. package/dist/src/react/index.js.map +1 -1
  69. package/dist/src/react/useFormatter.d.ts +5 -0
  70. package/dist/src/react/useFormatter.js +14 -0
  71. package/dist/src/react/useFormatter.js.map +1 -0
  72. package/dist/src/react/useIntl.d.ts +1 -0
  73. package/dist/src/react/useIntl.js +6 -0
  74. package/dist/src/react/useIntl.js.map +1 -1
  75. package/dist/src/react/useIntlContext.d.ts +1 -1
  76. package/dist/use-intl.cjs.development.js +99 -68
  77. package/dist/use-intl.cjs.development.js.map +1 -1
  78. package/dist/use-intl.cjs.production.min.js +1 -1
  79. package/dist/use-intl.cjs.production.min.js.map +1 -1
  80. package/dist/use-intl.esm.js +10 -8
  81. package/dist/use-intl.esm.js.map +1 -1
  82. package/package.json +1 -1
  83. package/src/core/createBaseTranslator.tsx +14 -12
  84. package/src/core/createFormatter.tsx +181 -0
  85. package/src/core/createIntl.tsx +12 -180
  86. package/src/core/index.tsx +3 -0
  87. package/src/react/IntlContext.tsx +20 -2
  88. package/src/react/IntlProvider.tsx +36 -5
  89. package/src/react/index.tsx +4 -1
  90. package/src/react/useFormatter.tsx +19 -0
  91. package/src/react/useIntl.tsx +10 -0
  92. package/dist/react/IntlContextValue.d.ts +0 -19
  93. package/dist/react/IntlProviderProps.d.ts +0 -15
  94. package/dist/react/getIntlContextValue.d.ts +0 -18
  95. package/dist/src/react/IntlContextValue.d.ts +0 -19
  96. package/dist/src/react/IntlContextValue.js +0 -2
  97. package/dist/src/react/IntlContextValue.js.map +0 -1
  98. package/dist/src/react/IntlProviderProps.d.ts +0 -15
  99. package/dist/src/react/IntlProviderProps.js +0 -2
  100. package/dist/src/react/IntlProviderProps.js.map +0 -1
  101. package/dist/src/react/getIntlContextValue.d.ts +0 -18
  102. package/dist/src/react/getIntlContextValue.js +0 -21
  103. package/dist/src/react/getIntlContextValue.js.map +0 -1
  104. package/src/react/IntlContextValue.tsx +0 -21
  105. package/src/react/IntlProviderProps.tsx +0 -17
  106. package/src/react/getIntlContextValue.tsx +0 -30
package/CHANGELOG.md CHANGED
@@ -3,6 +3,36 @@
3
3
  All notable changes to this project will be documented in this file.
4
4
  See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
5
5
 
6
+ ## 2.10.4 (2023-02-20)
7
+
8
+
9
+ ### Bug Fixes
10
+
11
+ * Return up-to-date translations when messages change ([#199](https://github.com/amannn/next-intl/tree/main/packages/use-intl/issues/199)) ([78f39b4](https://github.com/amannn/next-intl/tree/main/packages/use-intl/commit/78f39b408933d6fcbb38d085704bfbe14065dc0a))
12
+
13
+
14
+
15
+
16
+
17
+ ## 2.10.3 (2023-02-19)
18
+
19
+ **Note:** Version bump only for package use-intl
20
+
21
+
22
+
23
+
24
+
25
+ ## 2.10.2 (2022-12-09)
26
+
27
+
28
+ ### Bug Fixes
29
+
30
+ * Remove magic `__DEV__` global ([#151](https://github.com/amannn/next-intl/tree/main/packages/use-intl/issues/151)) ([7d5aa6a](https://github.com/amannn/next-intl/tree/main/packages/use-intl/commit/7d5aa6a8fda0189adc6440214270e07a5593d98f))
31
+
32
+
33
+
34
+
35
+
6
36
  ## 2.10.1 (2022-12-09)
7
37
 
8
38
  **Note:** Version bump only for package use-intl
package/README.md CHANGED
@@ -1,33 +1,38 @@
1
1
  # 🌐 use-intl
2
2
 
3
- ![Gzipped size](https://badgen.net/bundlephobia/minzip/use-intl) ![Tree shaking supported](https://badgen.net/bundlephobia/tree-shaking/use-intl) ![Build passing](https://img.shields.io/github/workflow/status/amannn/next-intl/main)
3
+ ![Gzipped size](https://badgen.net/bundlephobia/minzip/use-intl) ![Tree shaking supported](https://badgen.net/bundlephobia/tree-shaking/use-intl) [<img src="https://img.shields.io/npm/dw/use-intl.svg" />](https://www.npmjs.com/package/use-intl)
4
4
 
5
- > A minimal, but complete solution for managing translations, date, time and number formatting in React apps.
5
+ > Internationalization for React that gets out of your way.
6
6
 
7
7
  ## Features
8
8
 
9
- - 🌟 **Proven [ICU syntax](https://formatjs.io/docs/core-concepts/icu-syntax)**: This covers interpolation, plurals, ordinal pluralization, label selection based on enums and rich text. I18n is an essential part of the user experience, therefore this library doesn't compromise on flexibility and never leaves you behind when you need to fine tune a translation.
10
- - 📅 **Built-in date, time and number formatting**: You can use global formats for a consistent look & feel of your app and integrate them with translations.
11
- - 💡 **Hooks-only API**: This ensures that you can use the same API for `children` as well as for attributes which expect strings.
12
- - **Type-safe**: If you're using TypeScript, you'll benefit from autocompletion for available message keys and compile-time errors for typos.
13
- - ⚔️ **Battle-tested building blocks**: This library is a minimal wrapper around built-in browser APIs and supplemental lower-level APIs from [Format.JS](https://formatjs.io/) (used by `react-intl`).
9
+ Internationalization is an essential part of the user experience. use-intl gives you everything you need to get language subtleties right and has always got your back whenever you need to fine-tune a translation.
10
+
11
+ - 🌟 **ICU message syntax**: Localize your messages with interpolation, plurals, ordinal pluralization, enum-based label selection, and rich text.
12
+ - 📅 **Dates, times & numbers**: Use global formats for a consistent look & feel of your app and apply fine-tuning as necessary.
13
+ - **Type-safe**: Speed up development with autocompletion for message keys and catch typos early with compile-time checks.
14
+ - 💡 **Hooks-only API**: Learn a single API that can be used across your code base to turn translations into plain strings or rich text.
15
+ - ⚔️ **Standards-based**: Use the best parts of built-in JavaScript APIs and supplemental lower-level APIs from Format.JS.
14
16
 
15
17
  ## What does it look like?
16
18
 
17
19
  This library is based on the premise that messages can be grouped by namespaces (typically a component name).
18
20
 
19
21
  ```jsx
20
- // LatestFollower.js
21
- import {useTranslations} from 'use-intl';
22
-
23
- function LatestFollower({user}) {
24
- const t = useTranslations('LatestFollower');
25
-
22
+ // UserDetails.tsx
23
+ import {useTranslations, useFormatter} from 'next-intl';
24
+
25
+ function UserDetails({user}) {
26
+ const t = useTranslations('UserDetails');
27
+ const format = useFormatter();
28
+
26
29
  return (
27
- <>
28
- <Text>{t('latestFollower', {username: user.name})}</Text>
29
- <IconButton aria-label={t('followBack')} icon={<FollowIcon />} />
30
- </>
30
+ <section>
31
+ <h2>{t('title')}</h2>
32
+ <p>{t('followers', {count: user.followers.length})}</p>
33
+ <p>{t('lastSeen', {time: format.relativeTime(user.lastSeen)})</p>
34
+ <Image alt={t('portrait', {username: user.name})} src={user.portrait} />
35
+ </section>
31
36
  );
32
37
  }
33
38
  ```
@@ -35,9 +40,15 @@ function LatestFollower({user}) {
35
40
  ```js
36
41
  // en.json
37
42
  {
38
- "LatestFollower": {
39
- "latestFollower": "{username} started following you",
40
- "followBack": "Follow back"
43
+ "UserDetails": {
44
+ "title": "User details",
45
+ "followers": "{count, plural, ↵
46
+ =0 {No followers yet} ↵
47
+ =1 {One follower} ↵
48
+ other {# followers} ↵
49
+ }",
50
+ "lastSeen": "Last seen {time}",
51
+ "portrait": "Portrait of {username}"
41
52
  }
42
53
  }
43
54
  ```
@@ -46,6 +57,7 @@ function LatestFollower({user}) {
46
57
 
47
58
  1. `npm install use-intl`
48
59
  2. Add the provider
60
+
49
61
  ```jsx
50
62
  import {IntlProvider} from 'use-intl';
51
63
 
@@ -0,0 +1,17 @@
1
+ import DateTimeFormatOptions from './DateTimeFormatOptions';
2
+ import Formats from './Formats';
3
+ import IntlError from './IntlError';
4
+ import NumberFormatOptions from './NumberFormatOptions';
5
+ declare type Props = {
6
+ locale: string;
7
+ timeZone?: string;
8
+ onError?(error: IntlError): void;
9
+ formats?: Partial<Formats>;
10
+ now?: Date;
11
+ };
12
+ export default function createFormatter({ formats, locale, now: globalNow, onError, timeZone }: Props): {
13
+ dateTime: (value: Date | number, formatOrOptions?: string | DateTimeFormatOptions | undefined) => string;
14
+ number: (value: number, formatOrOptions?: string | NumberFormatOptions | undefined) => string;
15
+ relativeTime: (date: number | Date, now?: number | Date | undefined) => string;
16
+ };
17
+ export {};
@@ -1,17 +1,7 @@
1
- import DateTimeFormatOptions from './DateTimeFormatOptions';
2
- import Formats from './Formats';
3
- import IntlError from './IntlError';
4
- import NumberFormatOptions from './NumberFormatOptions';
5
- declare type Props = {
6
- locale: string;
7
- timeZone?: string;
8
- onError?(error: IntlError): void;
9
- formats?: Partial<Formats>;
10
- now?: Date;
11
- };
12
- export default function createIntl({ formats, locale, now: globalNow, onError, timeZone }: Props): {
13
- formatDateTime: (value: Date | number, formatOrOptions?: string | DateTimeFormatOptions | undefined) => string;
14
- formatNumber: (value: number, formatOrOptions?: string | NumberFormatOptions | undefined) => string;
1
+ import createFormatter from './createFormatter';
2
+ /** @deprecated Switch to `createFormatter` */
3
+ export default function createIntl(...args: Parameters<typeof createFormatter>): {
4
+ formatDateTime: (value: number | Date, formatOrOptions?: string | import("./DateTimeFormatOptions").default | undefined) => string;
5
+ formatNumber: (value: number, formatOrOptions?: string | import("@formatjs/ecma402-abstract").NumberFormatOptions | undefined) => string;
15
6
  formatRelativeTime: (date: number | Date, now?: number | Date | undefined) => string;
16
7
  };
17
- export {};
@@ -5,4 +5,5 @@ export { default as DateTimeFormatOptions } from './DateTimeFormatOptions';
5
5
  export { default as NumberFormatOptions } from './NumberFormatOptions';
6
6
  export { default as IntlError, IntlErrorCode } from './IntlError';
7
7
  export { default as createTranslator } from './createTranslator';
8
+ export { default as createFormatter } from './createFormatter';
8
9
  export { default as createIntl } from './createIntl';
@@ -1,42 +1,39 @@
1
- import { inheritsLoose as _inheritsLoose, wrapNativeSuper as _wrapNativeSuper } from '../_virtual/use-intl.esm.js';
2
-
3
- var IntlErrorCode;
4
-
5
- (function (IntlErrorCode) {
6
- IntlErrorCode["MISSING_MESSAGE"] = "MISSING_MESSAGE";
7
- IntlErrorCode["MISSING_FORMAT"] = "MISSING_FORMAT";
8
- IntlErrorCode["INSUFFICIENT_PATH"] = "INSUFFICIENT_PATH";
9
- IntlErrorCode["INVALID_MESSAGE"] = "INVALID_MESSAGE";
10
- IntlErrorCode["INVALID_KEY"] = "INVALID_KEY";
11
- IntlErrorCode["FORMATTING_ERROR"] = "FORMATTING_ERROR";
12
- })(IntlErrorCode || (IntlErrorCode = {}));
13
-
14
- var IntlError = /*#__PURE__*/function (_Error) {
15
- _inheritsLoose(IntlError, _Error);
16
-
17
- function IntlError(code, originalMessage) {
18
- var _this;
19
-
20
- var message = code;
21
-
22
- if (originalMessage) {
23
- message += ': ' + originalMessage;
24
- }
25
-
26
- _this = _Error.call(this, message) || this;
27
- _this.code = void 0;
28
- _this.originalMessage = void 0;
29
- _this.code = code;
30
-
31
- if (originalMessage) {
32
- _this.originalMessage = originalMessage;
33
- }
34
-
35
- return _this;
36
- }
37
-
38
- return IntlError;
39
- }( /*#__PURE__*/_wrapNativeSuper(Error));
40
-
41
- export { IntlErrorCode, IntlError as default };
1
+ import { objectWithoutPropertiesLoose as _objectWithoutPropertiesLoose, extends as _extends } from '../_virtual/use-intl.esm.js';
2
+ import createTranslatorImpl from './use-intl.esm7.js';
3
+ import { defaultOnError, defaultGetMessageFallback } from './use-intl.esm6.js';
4
+
5
+ var _excluded = ["onError", "getMessageFallback", "messages", "namespace"];
6
+ /**
7
+ * Translates messages from the given namespace by using the ICU syntax.
8
+ * See https://formatjs.io/docs/core-concepts/icu-syntax.
9
+ *
10
+ * If no namespace is provided, all available messages are returned.
11
+ * The namespace can also indicate nesting by using a dot
12
+ * (e.g. `namespace.Component`).
13
+ */
14
+
15
+ function createTranslator(_ref) {
16
+ var _ref$onError = _ref.onError,
17
+ onError = _ref$onError === void 0 ? defaultOnError : _ref$onError,
18
+ _ref$getMessageFallba = _ref.getMessageFallback,
19
+ getMessageFallback = _ref$getMessageFallba === void 0 ? defaultGetMessageFallback : _ref$getMessageFallba,
20
+ messages = _ref.messages,
21
+ namespace = _ref.namespace,
22
+ rest = _objectWithoutPropertiesLoose(_ref, _excluded);
23
+
24
+ // We have to wrap the actual function so the type inference for the optional
25
+ // namespace works correctly. See https://stackoverflow.com/a/71529575/343045
26
+ // The prefix ("!") is arbitrary.
27
+ return createTranslatorImpl(_extends({}, rest, {
28
+ onError: onError,
29
+ getMessageFallback: getMessageFallback,
30
+ messages: {
31
+ '!': messages
32
+ },
33
+ // @ts-ignore
34
+ namespace: namespace ? "!." + namespace : '!'
35
+ }), '!');
36
+ }
37
+
38
+ export { createTranslator as default };
42
39
  //# sourceMappingURL=use-intl.esm.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"use-intl.esm.js","sources":["../../src/core/IntlError.tsx"],"sourcesContent":["export enum IntlErrorCode {\n MISSING_MESSAGE = 'MISSING_MESSAGE',\n MISSING_FORMAT = 'MISSING_FORMAT',\n INSUFFICIENT_PATH = 'INSUFFICIENT_PATH',\n INVALID_MESSAGE = 'INVALID_MESSAGE',\n INVALID_KEY = 'INVALID_KEY',\n FORMATTING_ERROR = 'FORMATTING_ERROR'\n}\n\nexport default class IntlError extends Error {\n public readonly code: IntlErrorCode;\n public readonly originalMessage: string | undefined;\n\n constructor(code: IntlErrorCode, originalMessage?: string) {\n let message: string = code;\n if (originalMessage) {\n message += ': ' + originalMessage;\n }\n super(message);\n\n this.code = code;\n if (originalMessage) {\n this.originalMessage = originalMessage;\n }\n }\n}\n"],"names":["IntlErrorCode","IntlError","code","originalMessage","message","Error"],"mappings":";;IAAYA,cAAZ;;AAAA,CAAA,UAAYA,aAAZ,EAAyB;AACvBA,EAAAA,aAAA,CAAA,iBAAA,CAAA,GAAA,iBAAA,CAAA;AACAA,EAAAA,aAAA,CAAA,gBAAA,CAAA,GAAA,gBAAA,CAAA;AACAA,EAAAA,aAAA,CAAA,mBAAA,CAAA,GAAA,mBAAA,CAAA;AACAA,EAAAA,aAAA,CAAA,iBAAA,CAAA,GAAA,iBAAA,CAAA;AACAA,EAAAA,aAAA,CAAA,aAAA,CAAA,GAAA,aAAA,CAAA;AACAA,EAAAA,aAAA,CAAA,kBAAA,CAAA,GAAA,kBAAA,CAAA;AACD,CAPD,EAAYA,aAAa,KAAbA,aAAa,GAOxB,EAPwB,CAAzB,CAAA,CAAA;;IASqBC;;;AAInB,EAAYC,SAAAA,SAAAA,CAAAA,IAAZ,EAAiCC,eAAjC,EAAyD;AAAA,IAAA,IAAA,KAAA,CAAA;;AACvD,IAAIC,IAAAA,OAAO,GAAWF,IAAtB,CAAA;;AACA,IAAA,IAAIC,eAAJ,EAAqB;AACnBC,MAAAA,OAAO,IAAI,IAAA,GAAOD,eAAlB,CAAA;AACD,KAAA;;AACD,IAAA,KAAA,GAAA,MAAA,CAAA,IAAA,CAAA,IAAA,EAAMC,OAAN,CAAA,IAAA,IAAA,CAAA;AALuD,IAAA,KAAA,CAHzCF,IAGyC,GAAA,KAAA,CAAA,CAAA;AAAA,IAAA,KAAA,CAFzCC,eAEyC,GAAA,KAAA,CAAA,CAAA;AAOvD,IAAKD,KAAAA,CAAAA,IAAL,GAAYA,IAAZ,CAAA;;AACA,IAAA,IAAIC,eAAJ,EAAqB;AACnB,MAAKA,KAAAA,CAAAA,eAAL,GAAuBA,eAAvB,CAAA;AACD,KAAA;;AAVsD,IAAA,OAAA,KAAA,CAAA;AAWxD,GAAA;;;iCAfoCE;;;;"}
1
+ {"version":3,"file":"use-intl.esm.js","sources":["../../src/core/createTranslator.tsx"],"sourcesContent":["import Formats from './Formats';\nimport IntlConfiguration from './IntlConfiguration';\nimport TranslationValues from './TranslationValues';\nimport createTranslatorImpl, {\n CoreRichTranslationValues\n} from './createTranslatorImpl';\nimport {defaultGetMessageFallback, defaultOnError} from './defaults';\nimport MessageKeys from './utils/MessageKeys';\nimport NamespaceKeys from './utils/NamespaceKeys';\nimport NestedKeyOf from './utils/NestedKeyOf';\nimport NestedValueOf from './utils/NestedValueOf';\n\n/**\n * Translates messages from the given namespace by using the ICU syntax.\n * See https://formatjs.io/docs/core-concepts/icu-syntax.\n *\n * If no namespace is provided, all available messages are returned.\n * The namespace can also indicate nesting by using a dot\n * (e.g. `namespace.Component`).\n */\nexport default function createTranslator<\n NestedKey extends NamespaceKeys<\n IntlMessages,\n NestedKeyOf<IntlMessages>\n > = never\n>({\n onError = defaultOnError,\n getMessageFallback = defaultGetMessageFallback,\n messages,\n namespace,\n ...rest\n}: IntlConfiguration & {\n messages: IntlMessages;\n namespace?: NestedKey;\n}): // Explicitly defining the return type is necessary as TypeScript would get it wrong\n{\n // Default invocation\n <\n TargetKey extends MessageKeys<\n NestedValueOf<\n {'!': IntlMessages},\n [NestedKey] extends [never] ? '!' : `!.${NestedKey}`\n >,\n NestedKeyOf<\n NestedValueOf<\n {'!': IntlMessages},\n [NestedKey] extends [never] ? '!' : `!.${NestedKey}`\n >\n >\n >\n >(\n key: TargetKey,\n values?: TranslationValues,\n formats?: Partial<Formats>\n ): string;\n\n // `rich`\n rich<\n TargetKey extends MessageKeys<\n NestedValueOf<\n {'!': IntlMessages},\n [NestedKey] extends [never] ? '!' : `!.${NestedKey}`\n >,\n NestedKeyOf<\n NestedValueOf<\n {'!': IntlMessages},\n [NestedKey] extends [never] ? '!' : `!.${NestedKey}`\n >\n >\n >\n >(\n key: TargetKey,\n values?: CoreRichTranslationValues,\n formats?: Partial<Formats>\n ): string;\n\n // `raw`\n raw<\n TargetKey extends MessageKeys<\n NestedValueOf<\n {'!': IntlMessages},\n [NestedKey] extends [never] ? '!' : `!.${NestedKey}`\n >,\n NestedKeyOf<\n NestedValueOf<\n {'!': IntlMessages},\n [NestedKey] extends [never] ? '!' : `!.${NestedKey}`\n >\n >\n >\n >(\n key: TargetKey\n ): any;\n} {\n // We have to wrap the actual function so the type inference for the optional\n // namespace works correctly. See https://stackoverflow.com/a/71529575/343045\n // The prefix (\"!\") is arbitrary.\n return createTranslatorImpl<\n {'!': IntlMessages},\n [NestedKey] extends [never] ? '!' : `!.${NestedKey}`\n >(\n {\n ...rest,\n onError,\n getMessageFallback,\n messages: {'!': messages},\n // @ts-ignore\n namespace: namespace ? `!.${namespace}` : '!'\n },\n '!'\n );\n}\n"],"names":["createTranslator","onError","defaultOnError","getMessageFallback","defaultGetMessageFallback","messages","namespace","rest","createTranslatorImpl"],"mappings":";;;;;AAYA;;;;;;;AAOG;;AACqB,SAAAA,gBAAA,CAcvB,IAAA,EAAA;AAAA,EAAA,IAAA,YAAA,GAAA,IAAA,CARCC,OAQD;AAAA,MARCA,OAQD,6BARWC,cAQX,GAAA,YAAA;AAAA,MAAA,qBAAA,GAAA,IAAA,CAPCC,kBAOD;AAAA,MAPCA,kBAOD,sCAPsBC,yBAOtB,GAAA,qBAAA;AAAA,MANCC,QAMD,QANCA,QAMD;AAAA,MALCC,SAKD,QALCA,SAKD;AAAA,MAJIC,IAIJ,GAAA,6BAAA,CAAA,IAAA,EAAA,SAAA,CAAA,CAAA;;AA4DC;AACA;AACA;AACA,EAAOC,OAAAA,oBAAoB,cAKpBD,IALoB,EAAA;AAMvBN,IAAAA,OAAO,EAAPA,OANuB;AAOvBE,IAAAA,kBAAkB,EAAlBA,kBAPuB;AAQvBE,IAAAA,QAAQ,EAAE;AAAC,MAAKA,GAAAA,EAAAA,QAAAA;AAAN,KARa;AASvB;AACAC,IAAAA,SAAS,EAAEA,SAAS,GAAA,IAAA,GAAQA,SAAR,GAAsB,GAAA;AAVnB,GAAA,CAAA,EAYzB,GAZyB,CAA3B,CAAA;AAcD;;;;"}
@@ -0,0 +1,34 @@
1
+ import { extends as _extends } from '../_virtual/use-intl.esm.js';
2
+
3
+ function setTimeZoneInFormats(formats, timeZone) {
4
+ if (!formats) return formats; // The only way to set a time zone with `intl-messageformat` is to merge it into the formats
5
+ // https://github.com/formatjs/formatjs/blob/8256c5271505cf2606e48e3c97ecdd16ede4f1b5/packages/intl/src/message.ts#L15
6
+
7
+ return Object.keys(formats).reduce(function (acc, key) {
8
+ acc[key] = _extends({
9
+ timeZone: timeZone
10
+ }, formats[key]);
11
+ return acc;
12
+ }, {});
13
+ }
14
+ /**
15
+ * `intl-messageformat` uses separate keys for `date` and `time`, but there's
16
+ * only one native API: `Intl.DateTimeFormat`. Additionally you might want to
17
+ * include both a time and a date in a value, therefore the separation doesn't
18
+ * seem so useful. We offer a single `dateTime` namespace instead, but we have
19
+ * to convert the format before `intl-messageformat` can be used.
20
+ */
21
+
22
+
23
+ function convertFormatsToIntlMessageFormat(formats, timeZone) {
24
+ var formatsWithTimeZone = timeZone ? _extends({}, formats, {
25
+ dateTime: setTimeZoneInFormats(formats.dateTime, timeZone)
26
+ }) : formats;
27
+ return _extends({}, formatsWithTimeZone, {
28
+ date: formatsWithTimeZone == null ? void 0 : formatsWithTimeZone.dateTime,
29
+ time: formatsWithTimeZone == null ? void 0 : formatsWithTimeZone.dateTime
30
+ });
31
+ }
32
+
33
+ export { convertFormatsToIntlMessageFormat as default };
34
+ //# sourceMappingURL=use-intl.esm10.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-intl.esm10.js","sources":["../../src/core/convertFormatsToIntlMessageFormat.tsx"],"sourcesContent":["import {Formats as IntlFormats} from 'intl-messageformat';\nimport DateTimeFormatOptions from './DateTimeFormatOptions';\nimport Formats from './Formats';\n\nfunction setTimeZoneInFormats(\n formats: Record<string, DateTimeFormatOptions> | undefined,\n timeZone: string\n) {\n if (!formats) return formats;\n\n // The only way to set a time zone with `intl-messageformat` is to merge it into the formats\n // https://github.com/formatjs/formatjs/blob/8256c5271505cf2606e48e3c97ecdd16ede4f1b5/packages/intl/src/message.ts#L15\n return Object.keys(formats).reduce(\n (acc: Record<string, DateTimeFormatOptions>, key) => {\n acc[key] = {\n timeZone,\n ...formats[key]\n };\n return acc;\n },\n {}\n );\n}\n\n/**\n * `intl-messageformat` uses separate keys for `date` and `time`, but there's\n * only one native API: `Intl.DateTimeFormat`. Additionally you might want to\n * include both a time and a date in a value, therefore the separation doesn't\n * seem so useful. We offer a single `dateTime` namespace instead, but we have\n * to convert the format before `intl-messageformat` can be used.\n */\nexport default function convertFormatsToIntlMessageFormat(\n formats: Partial<Formats>,\n timeZone?: string\n): Partial<IntlFormats> {\n const formatsWithTimeZone = timeZone\n ? {...formats, dateTime: setTimeZoneInFormats(formats.dateTime, timeZone)}\n : formats;\n\n return {\n ...formatsWithTimeZone,\n date: formatsWithTimeZone?.dateTime,\n time: formatsWithTimeZone?.dateTime\n };\n}\n"],"names":["setTimeZoneInFormats","formats","timeZone","Object","keys","reduce","acc","key","convertFormatsToIntlMessageFormat","formatsWithTimeZone","dateTime","date","time"],"mappings":";;AAIA,SAASA,oBAAT,CACEC,OADF,EAEEC,QAFF,EAEkB;AAEhB,EAAA,IAAI,CAACD,OAAL,EAAc,OAAOA,OAAP,CAFE;AAKhB;;AACA,EAAA,OAAOE,MAAM,CAACC,IAAP,CAAYH,OAAZ,CAAA,CAAqBI,MAArB,CACL,UAACC,GAAD,EAA6CC,GAA7C,EAAoD;AAClDD,IAAAA,GAAG,CAACC,GAAD,CAAH,GAAA,QAAA,CAAA;AACEL,MAAAA,QAAQ,EAARA,QAAAA;AADF,KAEKD,EAAAA,OAAO,CAACM,GAAD,CAFZ,CAAA,CAAA;AAIA,IAAA,OAAOD,GAAP,CAAA;AACD,GAPI,EAQL,EARK,CAAP,CAAA;AAUD,CAAA;AAED;;;;;;AAMG;;;AACW,SAAUE,iCAAV,CACZP,OADY,EAEZC,QAFY,EAEK;AAEjB,EAAA,IAAMO,mBAAmB,GAAGP,QAAQ,GAAA,QAAA,CAAA,EAAA,EAC5BD,OAD4B,EAAA;AACnBS,IAAAA,QAAQ,EAAEV,oBAAoB,CAACC,OAAO,CAACS,QAAT,EAAmBR,QAAnB,CAAA;AADX,GAAA,CAAA,GAEhCD,OAFJ,CAAA;AAIA,EAAA,OAAA,QAAA,CAAA,EAAA,EACKQ,mBADL,EAAA;AAEEE,IAAAA,IAAI,EAAEF,mBAAF,IAAEA,IAAAA,GAAAA,KAAAA,CAAAA,GAAAA,mBAAmB,CAAEC,QAF7B;AAGEE,IAAAA,IAAI,EAAEH,mBAAF,IAAA,IAAA,GAAA,KAAA,CAAA,GAAEA,mBAAmB,CAAEC,QAAAA;AAH7B,GAAA,CAAA,CAAA;AAKD;;;;"}
@@ -1,39 +1,155 @@
1
- import { objectWithoutPropertiesLoose as _objectWithoutPropertiesLoose, extends as _extends } from '../_virtual/use-intl.esm.js';
2
- import createTranslatorImpl from './use-intl.esm5.js';
3
- import { defaultOnError, defaultGetMessageFallback } from './use-intl.esm4.js';
4
-
5
- var _excluded = ["onError", "getMessageFallback", "messages", "namespace"];
6
- /**
7
- * Translates messages from the given namespace by using the ICU syntax.
8
- * See https://formatjs.io/docs/core-concepts/icu-syntax.
9
- *
10
- * If no namespace is provided, all available messages are returned.
11
- * The namespace can also indicate nesting by using a dot
12
- * (e.g. `namespace.Component`).
13
- */
14
-
15
- function createTranslator(_ref) {
16
- var _ref$onError = _ref.onError,
1
+ import { extends as _extends } from '../_virtual/use-intl.esm.js';
2
+ import IntlError, { IntlErrorCode } from './use-intl.esm3.js';
3
+ import { defaultOnError } from './use-intl.esm6.js';
4
+
5
+ var MINUTE = 60;
6
+ var HOUR = MINUTE * 60;
7
+ var DAY = HOUR * 24;
8
+ var WEEK = DAY * 7;
9
+ var MONTH = DAY * (365 / 12); // Approximation
10
+
11
+ var YEAR = DAY * 365;
12
+
13
+ function getRelativeTimeFormatConfig(seconds) {
14
+ var absValue = Math.abs(seconds);
15
+ var value, unit; // We have to round the resulting values, as `Intl.RelativeTimeFormat`
16
+ // will include fractions like '2.1 hours ago'.
17
+
18
+ if (absValue < MINUTE) {
19
+ unit = 'second';
20
+ value = Math.round(seconds);
21
+ } else if (absValue < HOUR) {
22
+ unit = 'minute';
23
+ value = Math.round(seconds / MINUTE);
24
+ } else if (absValue < DAY) {
25
+ unit = 'hour';
26
+ value = Math.round(seconds / HOUR);
27
+ } else if (absValue < WEEK) {
28
+ unit = 'day';
29
+ value = Math.round(seconds / DAY);
30
+ } else if (absValue < MONTH) {
31
+ unit = 'week';
32
+ value = Math.round(seconds / WEEK);
33
+ } else if (absValue < YEAR) {
34
+ unit = 'month';
35
+ value = Math.round(seconds / MONTH);
36
+ } else {
37
+ unit = 'year';
38
+ value = Math.round(seconds / YEAR);
39
+ }
40
+
41
+ return {
42
+ value: value,
43
+ unit: unit
44
+ };
45
+ }
46
+
47
+ function createFormatter(_ref) {
48
+ var formats = _ref.formats,
49
+ locale = _ref.locale,
50
+ globalNow = _ref.now,
51
+ _ref$onError = _ref.onError,
17
52
  onError = _ref$onError === void 0 ? defaultOnError : _ref$onError,
18
- _ref$getMessageFallba = _ref.getMessageFallback,
19
- getMessageFallback = _ref$getMessageFallba === void 0 ? defaultGetMessageFallback : _ref$getMessageFallba,
20
- messages = _ref.messages,
21
- namespace = _ref.namespace,
22
- rest = _objectWithoutPropertiesLoose(_ref, _excluded);
23
-
24
- // We have to wrap the actual function so the type inference for the optional
25
- // namespace works correctly. See https://stackoverflow.com/a/71529575/343045
26
- // The prefix ("!") is arbitrary.
27
- return createTranslatorImpl(_extends({}, rest, {
28
- onError: onError,
29
- getMessageFallback: getMessageFallback,
30
- messages: {
31
- '!': messages
32
- },
33
- // @ts-ignore
34
- namespace: namespace ? "!." + namespace : '!'
35
- }), '!');
53
+ timeZone = _ref.timeZone;
54
+
55
+ function resolveFormatOrOptions(typeFormats, formatOrOptions) {
56
+ var options;
57
+
58
+ if (typeof formatOrOptions === 'string') {
59
+ var formatName = formatOrOptions;
60
+ options = typeFormats == null ? void 0 : typeFormats[formatName];
61
+
62
+ if (!options) {
63
+ var error = new IntlError(IntlErrorCode.MISSING_FORMAT, process.env.NODE_ENV !== 'production' ? "Format `" + formatName + "` is not available. You can configure it on the provider or provide custom options." : undefined);
64
+ onError(error);
65
+ throw error;
66
+ }
67
+ } else {
68
+ options = formatOrOptions;
69
+ }
70
+
71
+ return options;
72
+ }
73
+
74
+ function getFormattedValue(value, formatOrOptions, typeFormats, formatter) {
75
+ var options;
76
+
77
+ try {
78
+ options = resolveFormatOrOptions(typeFormats, formatOrOptions);
79
+ } catch (error) {
80
+ return String(value);
81
+ }
82
+
83
+ try {
84
+ return formatter(options);
85
+ } catch (error) {
86
+ onError(new IntlError(IntlErrorCode.FORMATTING_ERROR, error.message));
87
+ return String(value);
88
+ }
89
+ }
90
+
91
+ function dateTime(
92
+ /** If a number is supplied, this is interpreted as a UTC timestamp. */
93
+ value,
94
+ /** If a time zone is supplied, the `value` is converted to that time zone.
95
+ * Otherwise the user time zone will be used. */
96
+ formatOrOptions) {
97
+ return getFormattedValue(value, formatOrOptions, formats == null ? void 0 : formats.dateTime, function (options) {
98
+ var _options;
99
+
100
+ if (timeZone && !((_options = options) != null && _options.timeZone)) {
101
+ options = _extends({}, options, {
102
+ timeZone: timeZone
103
+ });
104
+ }
105
+
106
+ return new Intl.DateTimeFormat(locale, options).format(value);
107
+ });
108
+ }
109
+
110
+ function number(value, formatOrOptions) {
111
+ return getFormattedValue(value, formatOrOptions, formats == null ? void 0 : formats.number, function (options) {
112
+ return new Intl.NumberFormat(locale, options).format(value);
113
+ });
114
+ }
115
+
116
+ function relativeTime(
117
+ /** The date time that needs to be formatted. */
118
+ date,
119
+ /** The reference point in time to which `date` will be formatted in relation to. */
120
+ now) {
121
+ try {
122
+ if (!now) {
123
+ if (globalNow) {
124
+ now = globalNow;
125
+ } else {
126
+ throw new Error(process.env.NODE_ENV !== 'production' ? "The `now` parameter wasn't provided and there was no global fallback configured on the provider." : undefined);
127
+ }
128
+ }
129
+
130
+ var dateDate = date instanceof Date ? date : new Date(date);
131
+ var nowDate = now instanceof Date ? now : new Date(now);
132
+ var seconds = (dateDate.getTime() - nowDate.getTime()) / 1000;
133
+
134
+ var _getRelativeTimeForma = getRelativeTimeFormatConfig(seconds),
135
+ unit = _getRelativeTimeForma.unit,
136
+ value = _getRelativeTimeForma.value;
137
+
138
+ return new Intl.RelativeTimeFormat(locale, {
139
+ numeric: 'auto'
140
+ }).format(value, unit);
141
+ } catch (error) {
142
+ onError(new IntlError(IntlErrorCode.FORMATTING_ERROR, error.message));
143
+ return String(date);
144
+ }
145
+ }
146
+
147
+ return {
148
+ dateTime: dateTime,
149
+ number: number,
150
+ relativeTime: relativeTime
151
+ };
36
152
  }
37
153
 
38
- export { createTranslator as default };
154
+ export { createFormatter as default };
39
155
  //# sourceMappingURL=use-intl.esm2.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"use-intl.esm2.js","sources":["../../src/core/createTranslator.tsx"],"sourcesContent":["import Formats from './Formats';\nimport IntlConfiguration from './IntlConfiguration';\nimport TranslationValues from './TranslationValues';\nimport createTranslatorImpl, {\n CoreRichTranslationValues\n} from './createTranslatorImpl';\nimport {defaultGetMessageFallback, defaultOnError} from './defaults';\nimport MessageKeys from './utils/MessageKeys';\nimport NamespaceKeys from './utils/NamespaceKeys';\nimport NestedKeyOf from './utils/NestedKeyOf';\nimport NestedValueOf from './utils/NestedValueOf';\n\n/**\n * Translates messages from the given namespace by using the ICU syntax.\n * See https://formatjs.io/docs/core-concepts/icu-syntax.\n *\n * If no namespace is provided, all available messages are returned.\n * The namespace can also indicate nesting by using a dot\n * (e.g. `namespace.Component`).\n */\nexport default function createTranslator<\n NestedKey extends NamespaceKeys<\n IntlMessages,\n NestedKeyOf<IntlMessages>\n > = never\n>({\n onError = defaultOnError,\n getMessageFallback = defaultGetMessageFallback,\n messages,\n namespace,\n ...rest\n}: IntlConfiguration & {\n messages: IntlMessages;\n namespace?: NestedKey;\n}): // Explicitly defining the return type is necessary as TypeScript would get it wrong\n{\n // Default invocation\n <\n TargetKey extends MessageKeys<\n NestedValueOf<\n {'!': IntlMessages},\n [NestedKey] extends [never] ? '!' : `!.${NestedKey}`\n >,\n NestedKeyOf<\n NestedValueOf<\n {'!': IntlMessages},\n [NestedKey] extends [never] ? '!' : `!.${NestedKey}`\n >\n >\n >\n >(\n key: TargetKey,\n values?: TranslationValues,\n formats?: Partial<Formats>\n ): string;\n\n // `rich`\n rich<\n TargetKey extends MessageKeys<\n NestedValueOf<\n {'!': IntlMessages},\n [NestedKey] extends [never] ? '!' : `!.${NestedKey}`\n >,\n NestedKeyOf<\n NestedValueOf<\n {'!': IntlMessages},\n [NestedKey] extends [never] ? '!' : `!.${NestedKey}`\n >\n >\n >\n >(\n key: TargetKey,\n values?: CoreRichTranslationValues,\n formats?: Partial<Formats>\n ): string;\n\n // `raw`\n raw<\n TargetKey extends MessageKeys<\n NestedValueOf<\n {'!': IntlMessages},\n [NestedKey] extends [never] ? '!' : `!.${NestedKey}`\n >,\n NestedKeyOf<\n NestedValueOf<\n {'!': IntlMessages},\n [NestedKey] extends [never] ? '!' : `!.${NestedKey}`\n >\n >\n >\n >(\n key: TargetKey\n ): any;\n} {\n // We have to wrap the actual function so the type inference for the optional\n // namespace works correctly. See https://stackoverflow.com/a/71529575/343045\n // The prefix (\"!\") is arbitrary.\n return createTranslatorImpl<\n {'!': IntlMessages},\n [NestedKey] extends [never] ? '!' : `!.${NestedKey}`\n >(\n {\n ...rest,\n onError,\n getMessageFallback,\n messages: {'!': messages},\n // @ts-ignore\n namespace: namespace ? `!.${namespace}` : '!'\n },\n '!'\n );\n}\n"],"names":["createTranslator","onError","defaultOnError","getMessageFallback","defaultGetMessageFallback","messages","namespace","rest","createTranslatorImpl"],"mappings":";;;;;AAYA;;;;;;;AAOG;;AACqB,SAAAA,gBAAA,CAcvB,IAAA,EAAA;AAAA,EAAA,IAAA,YAAA,GAAA,IAAA,CARCC,OAQD;AAAA,MARCA,OAQD,6BARWC,cAQX,GAAA,YAAA;AAAA,MAAA,qBAAA,GAAA,IAAA,CAPCC,kBAOD;AAAA,MAPCA,kBAOD,sCAPsBC,yBAOtB,GAAA,qBAAA;AAAA,MANCC,QAMD,QANCA,QAMD;AAAA,MALCC,SAKD,QALCA,SAKD;AAAA,MAJIC,IAIJ,GAAA,6BAAA,CAAA,IAAA,EAAA,SAAA,CAAA,CAAA;;AA4DC;AACA;AACA;AACA,EAAOC,OAAAA,oBAAoB,cAKpBD,IALoB,EAAA;AAMvBN,IAAAA,OAAO,EAAPA,OANuB;AAOvBE,IAAAA,kBAAkB,EAAlBA,kBAPuB;AAQvBE,IAAAA,QAAQ,EAAE;AAAC,MAAKA,GAAAA,EAAAA,QAAAA;AAAN,KARa;AASvB;AACAC,IAAAA,SAAS,EAAEA,SAAS,GAAA,IAAA,GAAQA,SAAR,GAAsB,GAAA;AAVnB,GAAA,CAAA,EAYzB,GAZyB,CAA3B,CAAA;AAcD;;;;"}
1
+ {"version":3,"file":"use-intl.esm2.js","sources":["../../src/core/createFormatter.tsx"],"sourcesContent":["import DateTimeFormatOptions from './DateTimeFormatOptions';\nimport Formats from './Formats';\nimport IntlError, {IntlErrorCode} from './IntlError';\nimport NumberFormatOptions from './NumberFormatOptions';\nimport {defaultOnError} from './defaults';\n\nconst MINUTE = 60;\nconst HOUR = MINUTE * 60;\nconst DAY = HOUR * 24;\nconst WEEK = DAY * 7;\nconst MONTH = DAY * (365 / 12); // Approximation\nconst YEAR = DAY * 365;\n\nfunction getRelativeTimeFormatConfig(seconds: number) {\n const absValue = Math.abs(seconds);\n let value, unit: Intl.RelativeTimeFormatUnit;\n\n // We have to round the resulting values, as `Intl.RelativeTimeFormat`\n // will include fractions like '2.1 hours ago'.\n\n if (absValue < MINUTE) {\n unit = 'second';\n value = Math.round(seconds);\n } else if (absValue < HOUR) {\n unit = 'minute';\n value = Math.round(seconds / MINUTE);\n } else if (absValue < DAY) {\n unit = 'hour';\n value = Math.round(seconds / HOUR);\n } else if (absValue < WEEK) {\n unit = 'day';\n value = Math.round(seconds / DAY);\n } else if (absValue < MONTH) {\n unit = 'week';\n value = Math.round(seconds / WEEK);\n } else if (absValue < YEAR) {\n unit = 'month';\n value = Math.round(seconds / MONTH);\n } else {\n unit = 'year';\n value = Math.round(seconds / YEAR);\n }\n\n return {value, unit};\n}\n\ntype Props = {\n locale: string;\n timeZone?: string;\n onError?(error: IntlError): void;\n formats?: Partial<Formats>;\n now?: Date;\n};\n\nexport default function createFormatter({\n formats,\n locale,\n now: globalNow,\n onError = defaultOnError,\n timeZone\n}: Props) {\n function resolveFormatOrOptions<Options>(\n typeFormats: Record<string, Options> | undefined,\n formatOrOptions?: string | Options\n ) {\n let options;\n if (typeof formatOrOptions === 'string') {\n const formatName = formatOrOptions;\n options = typeFormats?.[formatName];\n\n if (!options) {\n const error = new IntlError(\n IntlErrorCode.MISSING_FORMAT,\n process.env.NODE_ENV !== 'production'\n ? `Format \\`${formatName}\\` is not available. You can configure it on the provider or provide custom options.`\n : undefined\n );\n onError(error);\n throw error;\n }\n } else {\n options = formatOrOptions;\n }\n\n return options;\n }\n\n function getFormattedValue<Value, Options>(\n value: Value,\n formatOrOptions: string | Options | undefined,\n typeFormats: Record<string, Options> | undefined,\n formatter: (options?: Options) => string\n ) {\n let options;\n try {\n options = resolveFormatOrOptions(typeFormats, formatOrOptions);\n } catch (error) {\n return String(value);\n }\n\n try {\n return formatter(options);\n } catch (error) {\n onError(\n new IntlError(IntlErrorCode.FORMATTING_ERROR, (error as Error).message)\n );\n return String(value);\n }\n }\n\n function dateTime(\n /** If a number is supplied, this is interpreted as a UTC timestamp. */\n value: Date | number,\n /** If a time zone is supplied, the `value` is converted to that time zone.\n * Otherwise the user time zone will be used. */\n formatOrOptions?: string | DateTimeFormatOptions\n ) {\n return getFormattedValue(\n value,\n formatOrOptions,\n formats?.dateTime,\n (options) => {\n if (timeZone && !options?.timeZone) {\n options = {...options, timeZone};\n }\n\n return new Intl.DateTimeFormat(locale, options).format(value);\n }\n );\n }\n\n function number(\n value: number,\n formatOrOptions?: string | NumberFormatOptions\n ) {\n return getFormattedValue(\n value,\n formatOrOptions,\n formats?.number,\n (options) => new Intl.NumberFormat(locale, options).format(value)\n );\n }\n\n function relativeTime(\n /** The date time that needs to be formatted. */\n date: number | Date,\n /** The reference point in time to which `date` will be formatted in relation to. */\n now?: number | Date\n ) {\n try {\n if (!now) {\n if (globalNow) {\n now = globalNow;\n } else {\n throw new Error(\n process.env.NODE_ENV !== 'production'\n ? `The \\`now\\` parameter wasn't provided and there was no global fallback configured on the provider.`\n : undefined\n );\n }\n }\n\n const dateDate = date instanceof Date ? date : new Date(date);\n const nowDate = now instanceof Date ? now : new Date(now);\n\n const seconds = (dateDate.getTime() - nowDate.getTime()) / 1000;\n const {unit, value} = getRelativeTimeFormatConfig(seconds);\n\n return new Intl.RelativeTimeFormat(locale, {\n numeric: 'auto'\n }).format(value, unit);\n } catch (error) {\n onError(\n new IntlError(IntlErrorCode.FORMATTING_ERROR, (error as Error).message)\n );\n return String(date);\n }\n }\n\n return {dateTime, number, relativeTime};\n}\n"],"names":["MINUTE","HOUR","DAY","WEEK","MONTH","YEAR","getRelativeTimeFormatConfig","seconds","absValue","Math","abs","value","unit","round","createFormatter","formats","locale","globalNow","now","onError","defaultOnError","timeZone","resolveFormatOrOptions","typeFormats","formatOrOptions","options","formatName","error","IntlError","IntlErrorCode","MISSING_FORMAT","process","env","NODE_ENV","undefined","getFormattedValue","formatter","String","FORMATTING_ERROR","message","dateTime","Intl","DateTimeFormat","format","number","NumberFormat","relativeTime","date","Error","dateDate","Date","nowDate","getTime","RelativeTimeFormat","numeric"],"mappings":"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"}