@lingui/react 3.17.0 → 3.17.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.
package/CHANGELOG.md CHANGED
@@ -3,6 +3,17 @@
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
+ ## [3.17.1](https://github.com/lingui/js-lingui/compare/v3.17.0...v3.17.1) (2023-02-07)
7
+
8
+
9
+ ### Bug Fixes
10
+
11
+ * Named components not working in Trans in @lingui/react ([#1402](https://github.com/lingui/js-lingui/issues/1402)) ([bf7f655](https://github.com/lingui/js-lingui/commit/bf7f655ccac3fc22fb7d36662ab0ec96595574e5))
12
+
13
+
14
+
15
+
16
+
6
17
  # [3.17.0](https://github.com/lingui/js-lingui/compare/v3.16.1...v3.17.0) (2023-02-01)
7
18
 
8
19
  **Note:** Version bump only for package @lingui/react
@@ -1,47 +1,42 @@
1
1
  'use strict';
2
2
 
3
- var _slicedToArray = require('@babel/runtime/helpers/slicedToArray');
4
3
  var _extends = require('@babel/runtime/helpers/extends');
5
4
  var React = require('react');
6
- var _defineProperty = require('@babel/runtime/helpers/defineProperty');
7
5
 
8
- var LinguiContext = /*#__PURE__*/React.createContext(null);
6
+ const LinguiContext = /*#__PURE__*/React.createContext(null);
9
7
  function useLingui() {
10
- var context = React.useContext(LinguiContext);
11
-
8
+ const context = React.useContext(LinguiContext);
12
9
  if (process.env.NODE_ENV !== "production") {
13
10
  if (context == null) {
14
11
  throw new Error("useLingui hook was used without I18nProvider.");
15
12
  }
16
13
  }
17
-
18
14
  return context;
19
15
  }
20
16
  function withI18n(o) {
21
- return function (WrappedComponent) {
22
- return function (props) {
17
+ return WrappedComponent => {
18
+ return props => {
23
19
  if (process.env.NODE_ENV !== "production") {
24
20
  if (typeof o === "function" || /*#__PURE__*/React.isValidElement(o)) {
25
21
  throw new Error("withI18n([options]) takes options as a first argument, " + "but received React component itself. Without options, the Component " + "should be wrapped as withI18n()(Component), not withI18n(Component).");
26
22
  }
27
23
  }
28
-
29
- var _useLingui = useLingui(),
30
- i18n = _useLingui.i18n;
31
-
24
+ const {
25
+ i18n
26
+ } = useLingui();
32
27
  return /*#__PURE__*/React.createElement(WrappedComponent, _extends({}, props, {
33
28
  i18n: i18n
34
29
  }));
35
30
  };
36
31
  };
37
32
  }
38
- var I18nProvider = function I18nProvider(_ref) {
39
- var i18n = _ref.i18n,
40
- defaultComponent = _ref.defaultComponent,
41
- _ref$forceRenderOnLoc = _ref.forceRenderOnLocaleChange,
42
- forceRenderOnLocaleChange = _ref$forceRenderOnLoc === void 0 ? true : _ref$forceRenderOnLoc,
43
- children = _ref.children;
44
-
33
+ const I18nProvider = _ref => {
34
+ let {
35
+ i18n,
36
+ defaultComponent,
37
+ forceRenderOnLocaleChange = true,
38
+ children
39
+ } = _ref;
45
40
  /**
46
41
  * We can't pass `i18n` object directly through context, because even when locale
47
42
  * or messages are changed, i18n object is still the same. Context provider compares
@@ -53,25 +48,16 @@ var I18nProvider = function I18nProvider(_ref) {
53
48
  *
54
49
  * We can't use useMemo hook either, because we want to recalculate value manually.
55
50
  */
56
- var makeContext = function makeContext() {
57
- return {
58
- i18n: i18n,
59
- defaultComponent: defaultComponent
60
- };
51
+ const makeContext = () => ({
52
+ i18n,
53
+ defaultComponent
54
+ });
55
+ const getRenderKey = () => {
56
+ return forceRenderOnLocaleChange ? i18n.locale || "default" : "default";
61
57
  };
58
+ const [context, setContext] = React.useState(makeContext()),
59
+ [renderKey, setRenderKey] = React.useState(getRenderKey());
62
60
 
63
- var getRenderKey = function getRenderKey() {
64
- return forceRenderOnLocaleChange ? i18n.locale || 'default' : 'default';
65
- };
66
-
67
- var _React$useState = React.useState(makeContext()),
68
- _React$useState2 = _slicedToArray(_React$useState, 2),
69
- context = _React$useState2[0],
70
- setContext = _React$useState2[1],
71
- _React$useState3 = React.useState(getRenderKey()),
72
- _React$useState4 = _slicedToArray(_React$useState3, 2),
73
- renderKey = _React$useState4[0],
74
- setRenderKey = _React$useState4[1];
75
61
  /**
76
62
  * Subscribe for locale/message changes
77
63
  *
@@ -84,44 +70,33 @@ var I18nProvider = function I18nProvider(_ref) {
84
70
  * `useEffect` hook being called. This can happen if locales are loaded/activated
85
71
  * async.
86
72
  */
87
-
88
-
89
- React.useEffect(function () {
90
- var unsubscribe = i18n.on("change", function () {
73
+ React.useEffect(() => {
74
+ const unsubscribe = i18n.on("change", () => {
91
75
  setContext(makeContext());
92
76
  setRenderKey(getRenderKey());
93
77
  });
94
-
95
- if (renderKey === 'default') {
78
+ if (renderKey === "default") {
96
79
  setRenderKey(getRenderKey());
97
80
  }
98
-
99
- if (forceRenderOnLocaleChange && renderKey === 'default') {
81
+ if (forceRenderOnLocaleChange && renderKey === "default") {
100
82
  console.log("I18nProvider did not render. A call to i18n.activate still needs to happen or forceRenderOnLocaleChange must be set to false.");
101
83
  }
102
-
103
- return function () {
104
- return unsubscribe();
105
- };
84
+ return () => unsubscribe();
106
85
  }, []);
107
- if (forceRenderOnLocaleChange && renderKey === 'default') return null;
86
+ if (forceRenderOnLocaleChange && renderKey === "default") return null;
108
87
  return /*#__PURE__*/React.createElement(LinguiContext.Provider, {
109
88
  value: context,
110
89
  key: renderKey
111
90
  }, children);
112
91
  };
113
92
 
114
- function _createForOfIteratorHelper(o, allowArrayLike) { var it; if (typeof Symbol === "undefined" || o[Symbol.iterator] == null) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = o[Symbol.iterator](); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; }
115
-
116
- function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
117
-
118
- function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
93
+ // match <tag>paired</tag> and <tag/> unpaired tags
94
+ const tagRe = /<([a-zA-Z0-9]+)>(.*?)<\/\1>|<([a-zA-Z0-9]+)\/>/;
95
+ const nlRe = /(?:\r\n|\r|\n)/g;
119
96
 
120
- var tagRe = /<(\d+)>(.*?)<\/\1>|<(\d+)\/>/;
121
- var nlRe = /(?:\r\n|\r|\n)/g; // For HTML, certain tags should omit their close tag. We keep a whitelist for
97
+ // For HTML, certain tags should omit their close tag. We keep a whitelist for
122
98
  // those special-case tags.
123
-
124
- var voidElementTags = {
99
+ const voidElementTags = {
125
100
  area: true,
126
101
  base: true,
127
102
  br: true,
@@ -139,62 +114,47 @@ var voidElementTags = {
139
114
  wbr: true,
140
115
  menuitem: true
141
116
  };
117
+
142
118
  /**
143
119
  * `formatElements` - parse string and return tree of react elements
144
120
  *
145
- * `value` is string to be formatted with <0>Paired<0/> or <0/> (unpaired)
121
+ * `value` is string to be formatted with <tag>Paired<tag/> or <tag/> (unpaired)
146
122
  * placeholders. `elements` is a array of react elements which indexes
147
123
  * correspond to element indexes in formatted string
148
124
  */
149
-
150
125
  function formatElements(value) {
151
- var elements = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
152
- var uniqueId = makeCounter(0, '$lingui$');
153
- var parts = value.replace(nlRe, "").split(tagRe); // no inline elements, return
126
+ let elements = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
127
+ const uniqueId = makeCounter(0, "$lingui$");
128
+ const parts = value.replace(nlRe, "").split(tagRe);
154
129
 
130
+ // no inline elements, return
155
131
  if (parts.length === 1) return value;
156
- var tree = [];
157
- var before = parts.shift();
132
+ const tree = [];
133
+ const before = parts.shift();
158
134
  if (before) tree.push(before);
159
-
160
- var _iterator = _createForOfIteratorHelper(getElements(parts)),
161
- _step;
162
-
163
- try {
164
- for (_iterator.s(); !(_step = _iterator.n()).done;) {
165
- var _step$value = _slicedToArray(_step.value, 3),
166
- index = _step$value[0],
167
- children = _step$value[1],
168
- after = _step$value[2];
169
-
170
- var element = elements[index];
171
-
172
- if (!element || voidElementTags[element.type] && children) {
173
- if (!element) {
174
- console.error("Can use element at index '".concat(index, "' as it is not declared in the original translation"));
175
- } else {
176
- console.error("".concat(element.type, " is a void element tag therefore it must have no children"));
177
- } // ignore problematic element but push its children and elements after it
178
-
179
-
180
- element = /*#__PURE__*/React.createElement(React.Fragment);
135
+ for (const [index, children, after] of getElements(parts)) {
136
+ let element = elements[index];
137
+ if (!element || voidElementTags[element.type] && children) {
138
+ if (!element) {
139
+ console.error(`Can use element at index '${index}' as it is not declared in the original translation`);
140
+ } else {
141
+ console.error(`${element.type} is a void element tag therefore it must have no children`);
181
142
  }
182
143
 
183
- tree.push( /*#__PURE__*/React.cloneElement(element, {
184
- key: uniqueId()
185
- }, // format children for pair tags
186
- // unpaired tags might have children if it's a component passed as a variable
187
- children ? formatElements(children, elements) : element.props.children));
188
- if (after) tree.push(after);
144
+ // ignore problematic element but push its children and elements after it
145
+ element = /*#__PURE__*/React.createElement(React.Fragment);
189
146
  }
190
- } catch (err) {
191
- _iterator.e(err);
192
- } finally {
193
- _iterator.f();
147
+ tree.push( /*#__PURE__*/React.cloneElement(element, {
148
+ key: uniqueId()
149
+ },
150
+ // format children for pair tags
151
+ // unpaired tags might have children if it's a component passed as a variable
152
+ children ? formatElements(children, elements) : element.props.children));
153
+ if (after) tree.push(after);
194
154
  }
195
-
196
155
  return tree;
197
156
  }
157
+
198
158
  /*
199
159
  * `getElements` - return array of element indexes and element childrens
200
160
  *
@@ -209,47 +169,35 @@ function formatElements(value) {
209
169
  *
210
170
  * Returns: Array<[elementIndex, children, after]>
211
171
  */
212
-
213
-
214
172
  function getElements(parts) {
215
173
  if (!parts.length) return [];
216
-
217
- var _parts$slice = parts.slice(0, 4),
218
- _parts$slice2 = _slicedToArray(_parts$slice, 4),
219
- paired = _parts$slice2[0],
220
- children = _parts$slice2[1],
221
- unpaired = _parts$slice2[2],
222
- after = _parts$slice2[3];
223
-
224
- return [[parseInt(paired || unpaired), children || "", after]].concat(getElements(parts.slice(4, parts.length)));
174
+ const [paired, children, unpaired, after] = parts.slice(0, 4);
175
+ return [[paired || unpaired, children || "", after]].concat(getElements(parts.slice(4, parts.length)));
225
176
  }
226
-
227
- var makeCounter = function makeCounter() {
228
- var count = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0;
229
- var prefix = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : "";
230
- return function () {
231
- return "".concat(prefix, "_").concat(count++);
232
- };
177
+ const makeCounter = function () {
178
+ let count = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0;
179
+ let prefix = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : "";
180
+ return () => `${prefix}_${count++}`;
233
181
  };
234
182
 
235
- function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
236
-
237
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
238
183
  function Trans(props) {
239
- var _useLingui = useLingui(),
240
- i18n = _useLingui.i18n,
241
- defaultComponent = _useLingui.defaultComponent;
242
-
243
- var render = props.render,
244
- component = props.component,
245
- id = props.id,
246
- message = props.message,
247
- formats = props.formats;
248
-
249
- var values = _objectSpread({}, props.values);
250
-
251
- var components = _objectSpread({}, props.components);
252
-
184
+ const {
185
+ i18n,
186
+ defaultComponent
187
+ } = useLingui();
188
+ const {
189
+ render,
190
+ component,
191
+ id,
192
+ message,
193
+ formats
194
+ } = props;
195
+ const values = {
196
+ ...props.values
197
+ };
198
+ const components = {
199
+ ...props.components
200
+ };
253
201
  if (values) {
254
202
  /*
255
203
  Related discussion: https://github.com/lingui/js-lingui/issues/183
@@ -260,57 +208,55 @@ function Trans(props) {
260
208
  Values: { name: <strong>Jane</strong> }
261
209
  It'll become "Hello <0 />" with components=[<strong>Jane</strong>]
262
210
  */
263
- Object.keys(values).forEach(function (key) {
264
- var value = values[key];
211
+
212
+ Object.keys(values).forEach(key => {
213
+ const value = values[key];
265
214
  if (! /*#__PURE__*/React.isValidElement(value)) return;
266
- var index = Object.keys(components).length;
215
+ const index = Object.keys(components).length;
267
216
  components[index] = value;
268
- values[key] = "<".concat(index, "/>");
217
+ values[key] = `<${index}/>`;
269
218
  });
270
219
  }
271
-
272
- var _translation = i18n && typeof i18n._ === "function" ? i18n._(id, values, {
273
- message: message,
274
- formats: formats
220
+ const _translation = i18n && typeof i18n._ === "function" ? i18n._(id, values, {
221
+ message,
222
+ formats
275
223
  }) : id; // i18n provider isn't loaded at all
276
224
 
277
-
278
- var translation = _translation ? formatElements(_translation, components) : null;
279
-
225
+ const translation = _translation ? formatElements(_translation, components) : null;
280
226
  if (render === null || component === null) {
281
227
  // Although `string` is a valid react element, types only allow `Element`
282
228
  // Upstream issue: https://github.com/DefinitelyTyped/DefinitelyTyped/issues/20544
283
229
  return translation;
284
230
  }
285
-
286
- var FallbackComponent = defaultComponent || React.Fragment;
287
- var i18nProps = {
288
- id: id,
289
- message: message,
290
- translation: translation,
231
+ const FallbackComponent = defaultComponent || React.Fragment;
232
+ const i18nProps = {
233
+ id,
234
+ message,
235
+ translation,
291
236
  isTranslated: id !== translation && message !== translation
292
- }; // Validation of `render` and `component` props
237
+ };
293
238
 
239
+ // Validation of `render` and `component` props
294
240
  if (render && component) {
295
241
  console.error("You can't use both `component` and `render` prop at the same time. `component` is ignored.");
296
242
  } else if (render && typeof render !== "function") {
297
- console.error("Invalid value supplied to prop `render`. It must be a function, provided ".concat(render));
243
+ console.error(`Invalid value supplied to prop \`render\`. It must be a function, provided ${render}`);
298
244
  } else if (component && typeof component !== "function") {
299
245
  // Apparently, both function components and class components are functions
300
246
  // See https://stackoverflow.com/a/41658173/1535540
301
- console.error("Invalid value supplied to prop `component`. It must be a React component, provided ".concat(component));
247
+ console.error(`Invalid value supplied to prop \`component\`. It must be a React component, provided ${component}`);
302
248
  return /*#__PURE__*/React.createElement(FallbackComponent, i18nProps, translation);
303
- } // Rendering using a render prop
304
-
249
+ }
305
250
 
251
+ // Rendering using a render prop
306
252
  if (typeof render === "function") {
307
253
  // Component: render={(props) => <a title={props.translation}>x</a>}
308
254
  return render(i18nProps);
309
- } // `component` prop has a higher precedence over `defaultComponent`
310
-
255
+ }
311
256
 
312
- var Component = component || FallbackComponent;
313
- var DefaultComponent = defaultComponent;
257
+ // `component` prop has a higher precedence over `defaultComponent`
258
+ const Component = component || FallbackComponent;
259
+ const DefaultComponent = defaultComponent;
314
260
  return DefaultComponent && !component ? /*#__PURE__*/React.createElement(DefaultComponent, i18nProps, translation) : /*#__PURE__*/React.createElement(Component, null, translation);
315
261
  }
316
262
  Trans.defaultProps = {
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../../src/I18nProvider.tsx","../../src/format.ts","../../src/Trans.tsx"],"sourcesContent":["import React, { ComponentType, FunctionComponent } from \"react\"\nimport { I18n } from \"@lingui/core\"\nimport { TransRenderProps } from \"./Trans\"\n\nexport type I18nContext = {\n i18n: I18n\n defaultComponent?: ComponentType<TransRenderProps>\n}\n\nexport type withI18nProps = {\n i18n: I18n\n}\n\nexport type I18nProviderProps = I18nContext & {\n forceRenderOnLocaleChange?: boolean\n children?: React.ReactNode\n}\n\nconst LinguiContext = React.createContext<I18nContext>(null)\n\nexport function useLingui(): I18nContext {\n const context = React.useContext<I18nContext>(LinguiContext)\n\n if (process.env.NODE_ENV !== \"production\") {\n if (context == null) {\n throw new Error(\"useLingui hook was used without I18nProvider.\")\n }\n }\n\n return context\n}\n\nexport function withI18n(\n o?: object\n): <P extends withI18nProps>(\n Component: ComponentType<P>\n) => React.ComponentType<Omit<P, 'i18n'>> {\n return <P extends withI18nProps>(\n WrappedComponent: ComponentType<P>\n ): ComponentType<P> => {\n return (props) => {\n if (process.env.NODE_ENV !== \"production\") {\n if (typeof o === \"function\" || React.isValidElement(o)) {\n throw new Error(\n \"withI18n([options]) takes options as a first argument, \" +\n \"but received React component itself. Without options, the Component \" +\n \"should be wrapped as withI18n()(Component), not withI18n(Component).\"\n )\n }\n }\n\n const { i18n } = useLingui()\n return <WrappedComponent {...props} i18n={i18n} />\n }\n }\n}\n\nexport const I18nProvider: FunctionComponent<I18nProviderProps> = ({\n i18n,\n defaultComponent,\n forceRenderOnLocaleChange = true,\n children,\n}) => {\n /**\n * We can't pass `i18n` object directly through context, because even when locale\n * or messages are changed, i18n object is still the same. Context provider compares\n * reference identity and suggested workaround is create a wrapper object every time\n * we need to trigger re-render. See https://reactjs.org/docs/context.html#caveats.\n *\n * Due to this effect we also pass `defaultComponent` in the same context, instead\n * of creating a separate Provider/Consumer pair.\n *\n * We can't use useMemo hook either, because we want to recalculate value manually.\n */\n const makeContext = () => ({\n i18n,\n defaultComponent,\n })\n const getRenderKey = () => {\n return (forceRenderOnLocaleChange ? (i18n.locale || 'default') : 'default') as string\n }\n\n const [context, setContext] = React.useState<I18nContext>(makeContext()),\n [renderKey, setRenderKey] = React.useState<string>(getRenderKey())\n\n /**\n * Subscribe for locale/message changes\n *\n * I18n object from `@lingui/core` is the single source of truth for all i18n related\n * data (active locale, catalogs). When new messages are loaded or locale is changed\n * we need to trigger re-rendering of LinguiContext.Consumers.\n *\n * We call `setContext(makeContext())` after adding the observer in case the `change`\n * event would already have fired between the inital renderKey calculation and the\n * `useEffect` hook being called. This can happen if locales are loaded/activated\n * async.\n */\n React.useEffect(() => {\n const unsubscribe = i18n.on(\"change\", () => {\n setContext(makeContext())\n setRenderKey(getRenderKey())\n })\n if (renderKey === 'default') {\n setRenderKey(getRenderKey())\n }\n if (forceRenderOnLocaleChange && renderKey === 'default') {\n console.log(\"I18nProvider did not render. A call to i18n.activate still needs to happen or forceRenderOnLocaleChange must be set to false.\")\n }\n return () => unsubscribe()\n }, [])\n\n if (forceRenderOnLocaleChange && renderKey === 'default') return null\n\n return (\n <LinguiContext.Provider value={context} key={renderKey}>\n {children}\n </LinguiContext.Provider>\n )\n}\n","import React from \"react\"\n\n// match <0>paired</0> and <1/> unpaired tags\nconst tagRe = /<(\\d+)>(.*?)<\\/\\1>|<(\\d+)\\/>/\nconst nlRe = /(?:\\r\\n|\\r|\\n)/g\n\n// For HTML, certain tags should omit their close tag. We keep a whitelist for\n// those special-case tags.\nconst voidElementTags = {\n area: true,\n base: true,\n br: true,\n col: true,\n embed: true,\n hr: true,\n img: true,\n input: true,\n keygen: true,\n link: true,\n meta: true,\n param: true,\n source: true,\n track: true,\n wbr: true,\n menuitem: true\n}\n\n/**\n * `formatElements` - parse string and return tree of react elements\n *\n * `value` is string to be formatted with <0>Paired<0/> or <0/> (unpaired)\n * placeholders. `elements` is a array of react elements which indexes\n * correspond to element indexes in formatted string\n */\nfunction formatElements(\n value: string,\n elements: { [key: string]: React.ReactElement<any> } = {}\n): string | Array<any> {\n const uniqueId = makeCounter(0, '$lingui$')\n const parts = value.replace(nlRe, \"\").split(tagRe)\n\n // no inline elements, return\n if (parts.length === 1) return value\n\n const tree = []\n\n const before = parts.shift()\n if (before) tree.push(before)\n\n for (const [index, children, after] of getElements(parts)) {\n let element = elements[index]\n\n if (!element || (voidElementTags[element.type as string] && children)) {\n if (!element) {\n console.error(\n `Can use element at index '${index}' as it is not declared in the original translation`\n )\n } else {\n console.error(\n `${element.type} is a void element tag therefore it must have no children`\n )\n }\n\n // ignore problematic element but push its children and elements after it\n element = React.createElement(React.Fragment)\n }\n\n tree.push(\n React.cloneElement(\n element,\n { key: uniqueId() },\n\n // format children for pair tags\n // unpaired tags might have children if it's a component passed as a variable\n children ? formatElements(children, elements) : element.props.children\n )\n )\n\n if (after) tree.push(after)\n }\n\n return tree\n}\n\n/*\n * `getElements` - return array of element indexes and element childrens\n *\n * `parts` is array of [pairedIndex, children, unpairedIndex, textAfter, ...]\n * where:\n * - `pairedIndex` is index of paired element (undef for unpaired)\n * - `children` are children of paired element (undef for unpaired)\n * - `unpairedIndex` is index of unpaired element (undef for paired)\n * - `textAfter` is string after all elements (empty string, if there's nothing)\n *\n * `parts` length is always multiply of 4\n *\n * Returns: Array<[elementIndex, children, after]>\n */\nfunction getElements(parts) {\n if (!parts.length) return []\n\n const [paired, children, unpaired, after] = parts.slice(0, 4)\n\n return [[parseInt(paired || unpaired), children || \"\", after]].concat(\n getElements(parts.slice(4, parts.length))\n )\n}\n\nconst makeCounter = (count = 0, prefix = \"\") => () => `${prefix}_${count++}`\n\nexport { formatElements }\n","import React from \"react\"\n\nimport { useLingui } from \"./I18nProvider\"\nimport { formatElements } from \"./format\"\n\nexport type TransRenderProps = {\n id?: string\n translation?: React.ReactNode\n children?: React.ReactNode\n message?: string | null\n isTranslated?: boolean\n}\n\nexport type TransProps = {\n id: string\n message?: string\n values: Record<string, unknown>\n context?: string\n components: { [key: string]: React.ElementType | any }\n formats?: Record<string, unknown>\n children?: React.ReactNode\n component?: React.ComponentType<TransRenderProps>\n render?: (props: TransRenderProps) => React.ReactElement<any, any> | null\n}\n\nexport function Trans(props: TransProps): React.ReactElement<any, any> | null {\n const { i18n, defaultComponent } = useLingui()\n const { render, component, id, message, formats } = props\n\n const values = { ...props.values }\n const components = { ...props.components }\n\n if (values) {\n /*\n Related discussion: https://github.com/lingui/js-lingui/issues/183\n\n Values *might* contain React elements with static content.\n They're replaced with <INDEX /> placeholders and added to `components`.\n\n Example:\n Translation: Hello {name}\n Values: { name: <strong>Jane</strong> }\n\n It'll become \"Hello <0 />\" with components=[<strong>Jane</strong>]\n */\n\n Object.keys(values).forEach((key) => {\n const value = values[key]\n if (!React.isValidElement(value)) return\n\n const index = Object.keys(components).length\n\n components[index] = value\n values[key] = `<${index}/>`\n })\n }\n\n const _translation: string =\n i18n && typeof i18n._ === \"function\"\n ? i18n._(id, values, { message, formats })\n : id // i18n provider isn't loaded at all\n\n const translation = _translation\n ? formatElements(_translation, components)\n : null\n\n if (render === null || component === null) {\n // Although `string` is a valid react element, types only allow `Element`\n // Upstream issue: https://github.com/DefinitelyTyped/DefinitelyTyped/issues/20544\n return (translation as unknown) as React.ReactElement<any, any>\n }\n\n const FallbackComponent = (defaultComponent ||\n React.Fragment) as React.ComponentType<any>\n\n const i18nProps = {\n id,\n message,\n translation,\n isTranslated: id !== translation && message !== translation,\n }\n\n // Validation of `render` and `component` props\n if (render && component) {\n console.error(\n \"You can't use both `component` and `render` prop at the same time. `component` is ignored.\"\n )\n } else if (render && typeof render !== \"function\") {\n console.error(\n `Invalid value supplied to prop \\`render\\`. It must be a function, provided ${render}`\n )\n } else if (component && typeof component !== \"function\") {\n // Apparently, both function components and class components are functions\n // See https://stackoverflow.com/a/41658173/1535540\n console.error(\n `Invalid value supplied to prop \\`component\\`. It must be a React component, provided ${component}`\n )\n return <FallbackComponent {...i18nProps}>{translation}</FallbackComponent>\n }\n\n // Rendering using a render prop\n if (typeof render === \"function\") {\n // Component: render={(props) => <a title={props.translation}>x</a>}\n return render(i18nProps)\n }\n\n // `component` prop has a higher precedence over `defaultComponent`\n const Component = (component || FallbackComponent) as React.ComponentType<any>\n const DefaultComponent = defaultComponent\n\n return DefaultComponent && !component ? (\n <DefaultComponent {...i18nProps}>{translation}</DefaultComponent>\n ) : (\n <Component>{translation}</Component>\n )\n}\n\nTrans.defaultProps = {\n values: {},\n components: {},\n}\n"],"names":["LinguiContext","React","createContext","useLingui","context","useContext","process","env","NODE_ENV","Error","withI18n","o","WrappedComponent","props","isValidElement","i18n","I18nProvider","defaultComponent","forceRenderOnLocaleChange","children","makeContext","getRenderKey","locale","useState","setContext","renderKey","setRenderKey","useEffect","unsubscribe","on","console","log","tagRe","nlRe","voidElementTags","area","base","br","col","embed","hr","img","input","keygen","link","meta","param","source","track","wbr","menuitem","formatElements","value","elements","uniqueId","makeCounter","parts","replace","split","length","tree","before","shift","push","getElements","index","after","element","type","error","createElement","Fragment","cloneElement","key","slice","paired","unpaired","parseInt","concat","count","prefix","Trans","render","component","id","message","formats","values","components","Object","keys","forEach","_translation","_","translation","FallbackComponent","i18nProps","isTranslated","Component","DefaultComponent","defaultProps"],"mappings":"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"}
1
+ {"version":3,"file":"index.js","sources":["../../src/I18nProvider.tsx","../../src/format.ts","../../src/Trans.tsx"],"sourcesContent":["import React, { ComponentType, FunctionComponent } from \"react\"\nimport { I18n } from \"@lingui/core\"\nimport { TransRenderProps } from \"./Trans\"\n\nexport type I18nContext = {\n i18n: I18n\n defaultComponent?: ComponentType<TransRenderProps>\n}\n\nexport type withI18nProps = {\n i18n: I18n\n}\n\nexport type I18nProviderProps = I18nContext & {\n forceRenderOnLocaleChange?: boolean\n children?: React.ReactNode\n}\n\nconst LinguiContext = React.createContext<I18nContext>(null)\n\nexport function useLingui(): I18nContext {\n const context = React.useContext<I18nContext>(LinguiContext)\n\n if (process.env.NODE_ENV !== \"production\") {\n if (context == null) {\n throw new Error(\"useLingui hook was used without I18nProvider.\")\n }\n }\n\n return context\n}\n\nexport function withI18n(\n o?: object\n): <P extends withI18nProps>(\n Component: ComponentType<P>\n) => React.ComponentType<Omit<P, \"i18n\">> {\n return <P extends withI18nProps>(\n WrappedComponent: ComponentType<P>\n ): ComponentType<P> => {\n return (props) => {\n if (process.env.NODE_ENV !== \"production\") {\n if (typeof o === \"function\" || React.isValidElement(o)) {\n throw new Error(\n \"withI18n([options]) takes options as a first argument, \" +\n \"but received React component itself. Without options, the Component \" +\n \"should be wrapped as withI18n()(Component), not withI18n(Component).\"\n )\n }\n }\n\n const { i18n } = useLingui()\n return <WrappedComponent {...props} i18n={i18n} />\n }\n }\n}\n\nexport const I18nProvider: FunctionComponent<I18nProviderProps> = ({\n i18n,\n defaultComponent,\n forceRenderOnLocaleChange = true,\n children,\n}) => {\n /**\n * We can't pass `i18n` object directly through context, because even when locale\n * or messages are changed, i18n object is still the same. Context provider compares\n * reference identity and suggested workaround is create a wrapper object every time\n * we need to trigger re-render. See https://reactjs.org/docs/context.html#caveats.\n *\n * Due to this effect we also pass `defaultComponent` in the same context, instead\n * of creating a separate Provider/Consumer pair.\n *\n * We can't use useMemo hook either, because we want to recalculate value manually.\n */\n const makeContext = () => ({\n i18n,\n defaultComponent,\n })\n const getRenderKey = () => {\n return (\n forceRenderOnLocaleChange ? i18n.locale || \"default\" : \"default\"\n ) as string\n }\n\n const [context, setContext] = React.useState<I18nContext>(makeContext()),\n [renderKey, setRenderKey] = React.useState<string>(getRenderKey())\n\n /**\n * Subscribe for locale/message changes\n *\n * I18n object from `@lingui/core` is the single source of truth for all i18n related\n * data (active locale, catalogs). When new messages are loaded or locale is changed\n * we need to trigger re-rendering of LinguiContext.Consumers.\n *\n * We call `setContext(makeContext())` after adding the observer in case the `change`\n * event would already have fired between the inital renderKey calculation and the\n * `useEffect` hook being called. This can happen if locales are loaded/activated\n * async.\n */\n React.useEffect(() => {\n const unsubscribe = i18n.on(\"change\", () => {\n setContext(makeContext())\n setRenderKey(getRenderKey())\n })\n if (renderKey === \"default\") {\n setRenderKey(getRenderKey())\n }\n if (forceRenderOnLocaleChange && renderKey === \"default\") {\n console.log(\n \"I18nProvider did not render. A call to i18n.activate still needs to happen or forceRenderOnLocaleChange must be set to false.\"\n )\n }\n return () => unsubscribe()\n }, [])\n\n if (forceRenderOnLocaleChange && renderKey === \"default\") return null\n\n return (\n <LinguiContext.Provider value={context} key={renderKey}>\n {children}\n </LinguiContext.Provider>\n )\n}\n","import React from \"react\"\n\n// match <tag>paired</tag> and <tag/> unpaired tags\nconst tagRe = /<([a-zA-Z0-9]+)>(.*?)<\\/\\1>|<([a-zA-Z0-9]+)\\/>/\nconst nlRe = /(?:\\r\\n|\\r|\\n)/g\n\n// For HTML, certain tags should omit their close tag. We keep a whitelist for\n// those special-case tags.\nconst voidElementTags = {\n area: true,\n base: true,\n br: true,\n col: true,\n embed: true,\n hr: true,\n img: true,\n input: true,\n keygen: true,\n link: true,\n meta: true,\n param: true,\n source: true,\n track: true,\n wbr: true,\n menuitem: true,\n}\n\n/**\n * `formatElements` - parse string and return tree of react elements\n *\n * `value` is string to be formatted with <tag>Paired<tag/> or <tag/> (unpaired)\n * placeholders. `elements` is a array of react elements which indexes\n * correspond to element indexes in formatted string\n */\nfunction formatElements(\n value: string,\n elements: { [key: string]: React.ReactElement<any> } = {}\n): string | Array<any> {\n const uniqueId = makeCounter(0, \"$lingui$\")\n const parts = value.replace(nlRe, \"\").split(tagRe)\n\n // no inline elements, return\n if (parts.length === 1) return value\n\n const tree = []\n\n const before = parts.shift()\n if (before) tree.push(before)\n\n for (const [index, children, after] of getElements(parts)) {\n let element = elements[index]\n\n if (!element || (voidElementTags[element.type as string] && children)) {\n if (!element) {\n console.error(\n `Can use element at index '${index}' as it is not declared in the original translation`\n )\n } else {\n console.error(\n `${element.type} is a void element tag therefore it must have no children`\n )\n }\n\n // ignore problematic element but push its children and elements after it\n element = React.createElement(React.Fragment)\n }\n\n tree.push(\n React.cloneElement(\n element,\n { key: uniqueId() },\n\n // format children for pair tags\n // unpaired tags might have children if it's a component passed as a variable\n children ? formatElements(children, elements) : element.props.children\n )\n )\n\n if (after) tree.push(after)\n }\n\n return tree\n}\n\n/*\n * `getElements` - return array of element indexes and element childrens\n *\n * `parts` is array of [pairedIndex, children, unpairedIndex, textAfter, ...]\n * where:\n * - `pairedIndex` is index of paired element (undef for unpaired)\n * - `children` are children of paired element (undef for unpaired)\n * - `unpairedIndex` is index of unpaired element (undef for paired)\n * - `textAfter` is string after all elements (empty string, if there's nothing)\n *\n * `parts` length is always multiply of 4\n *\n * Returns: Array<[elementIndex, children, after]>\n */\nfunction getElements(parts) {\n if (!parts.length) return []\n\n const [paired, children, unpaired, after] = parts.slice(0, 4)\n\n return [[paired || unpaired, children || \"\", after]].concat(\n getElements(parts.slice(4, parts.length))\n )\n}\n\nconst makeCounter =\n (count = 0, prefix = \"\") =>\n () =>\n `${prefix}_${count++}`\n\nexport { formatElements }\n","import React from \"react\"\n\nimport { useLingui } from \"./I18nProvider\"\nimport { formatElements } from \"./format\"\n\nexport type TransRenderProps = {\n id?: string\n translation?: React.ReactNode\n children?: React.ReactNode\n message?: string | null\n isTranslated?: boolean\n}\n\nexport type TransProps = {\n id: string\n message?: string\n values: Record<string, unknown>\n context?: string\n components: { [key: string]: React.ElementType | any }\n formats?: Record<string, unknown>\n children?: React.ReactNode\n component?: React.ComponentType<TransRenderProps>\n render?: (props: TransRenderProps) => React.ReactElement<any, any> | null\n}\n\nexport function Trans(props: TransProps): React.ReactElement<any, any> | null {\n const { i18n, defaultComponent } = useLingui()\n const { render, component, id, message, formats } = props\n\n const values = { ...props.values }\n const components = { ...props.components }\n\n if (values) {\n /*\n Related discussion: https://github.com/lingui/js-lingui/issues/183\n\n Values *might* contain React elements with static content.\n They're replaced with <INDEX /> placeholders and added to `components`.\n\n Example:\n Translation: Hello {name}\n Values: { name: <strong>Jane</strong> }\n\n It'll become \"Hello <0 />\" with components=[<strong>Jane</strong>]\n */\n\n Object.keys(values).forEach((key) => {\n const value = values[key]\n if (!React.isValidElement(value)) return\n\n const index = Object.keys(components).length\n\n components[index] = value\n values[key] = `<${index}/>`\n })\n }\n\n const _translation: string =\n i18n && typeof i18n._ === \"function\"\n ? i18n._(id, values, { message, formats })\n : id // i18n provider isn't loaded at all\n\n const translation = _translation\n ? formatElements(_translation, components)\n : null\n\n if (render === null || component === null) {\n // Although `string` is a valid react element, types only allow `Element`\n // Upstream issue: https://github.com/DefinitelyTyped/DefinitelyTyped/issues/20544\n return translation as unknown as React.ReactElement<any, any>\n }\n\n const FallbackComponent = (defaultComponent ||\n React.Fragment) as React.ComponentType<any>\n\n const i18nProps = {\n id,\n message,\n translation,\n isTranslated: id !== translation && message !== translation,\n }\n\n // Validation of `render` and `component` props\n if (render && component) {\n console.error(\n \"You can't use both `component` and `render` prop at the same time. `component` is ignored.\"\n )\n } else if (render && typeof render !== \"function\") {\n console.error(\n `Invalid value supplied to prop \\`render\\`. It must be a function, provided ${render}`\n )\n } else if (component && typeof component !== \"function\") {\n // Apparently, both function components and class components are functions\n // See https://stackoverflow.com/a/41658173/1535540\n console.error(\n `Invalid value supplied to prop \\`component\\`. It must be a React component, provided ${component}`\n )\n return <FallbackComponent {...i18nProps}>{translation}</FallbackComponent>\n }\n\n // Rendering using a render prop\n if (typeof render === \"function\") {\n // Component: render={(props) => <a title={props.translation}>x</a>}\n return render(i18nProps)\n }\n\n // `component` prop has a higher precedence over `defaultComponent`\n const Component = (component || FallbackComponent) as React.ComponentType<any>\n const DefaultComponent = defaultComponent\n\n return DefaultComponent && !component ? (\n <DefaultComponent {...i18nProps}>{translation}</DefaultComponent>\n ) : (\n <Component>{translation}</Component>\n )\n}\n\nTrans.defaultProps = {\n values: {},\n components: {},\n}\n"],"names":["LinguiContext","React","createContext","useLingui","context","useContext","process","env","NODE_ENV","Error","withI18n","o","WrappedComponent","props","isValidElement","i18n","I18nProvider","defaultComponent","forceRenderOnLocaleChange","children","makeContext","getRenderKey","locale","setContext","useState","renderKey","setRenderKey","useEffect","unsubscribe","on","console","log","tagRe","nlRe","voidElementTags","area","base","br","col","embed","hr","img","input","keygen","link","meta","param","source","track","wbr","menuitem","formatElements","value","elements","uniqueId","makeCounter","parts","replace","split","length","tree","before","shift","push","index","after","getElements","element","type","error","createElement","Fragment","cloneElement","key","paired","unpaired","slice","concat","count","prefix","Trans","render","component","id","message","formats","values","components","Object","keys","forEach","_translation","_","translation","FallbackComponent","i18nProps","isTranslated","Component","DefaultComponent","defaultProps"],"mappings":"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"}
@@ -1,45 +1,40 @@
1
- import _slicedToArray from '@babel/runtime/helpers/slicedToArray';
2
1
  import _extends from '@babel/runtime/helpers/extends';
3
2
  import React from 'react';
4
- import _defineProperty from '@babel/runtime/helpers/defineProperty';
5
3
 
6
- var LinguiContext = /*#__PURE__*/React.createContext(null);
4
+ const LinguiContext = /*#__PURE__*/React.createContext(null);
7
5
  function useLingui() {
8
- var context = React.useContext(LinguiContext);
9
-
6
+ const context = React.useContext(LinguiContext);
10
7
  if (process.env.NODE_ENV !== "production") {
11
8
  if (context == null) {
12
9
  throw new Error("useLingui hook was used without I18nProvider.");
13
10
  }
14
11
  }
15
-
16
12
  return context;
17
13
  }
18
14
  function withI18n(o) {
19
- return function (WrappedComponent) {
20
- return function (props) {
15
+ return WrappedComponent => {
16
+ return props => {
21
17
  if (process.env.NODE_ENV !== "production") {
22
18
  if (typeof o === "function" || /*#__PURE__*/React.isValidElement(o)) {
23
19
  throw new Error("withI18n([options]) takes options as a first argument, " + "but received React component itself. Without options, the Component " + "should be wrapped as withI18n()(Component), not withI18n(Component).");
24
20
  }
25
21
  }
26
-
27
- var _useLingui = useLingui(),
28
- i18n = _useLingui.i18n;
29
-
22
+ const {
23
+ i18n
24
+ } = useLingui();
30
25
  return /*#__PURE__*/React.createElement(WrappedComponent, _extends({}, props, {
31
26
  i18n: i18n
32
27
  }));
33
28
  };
34
29
  };
35
30
  }
36
- var I18nProvider = function I18nProvider(_ref) {
37
- var i18n = _ref.i18n,
38
- defaultComponent = _ref.defaultComponent,
39
- _ref$forceRenderOnLoc = _ref.forceRenderOnLocaleChange,
40
- forceRenderOnLocaleChange = _ref$forceRenderOnLoc === void 0 ? true : _ref$forceRenderOnLoc,
41
- children = _ref.children;
42
-
31
+ const I18nProvider = _ref => {
32
+ let {
33
+ i18n,
34
+ defaultComponent,
35
+ forceRenderOnLocaleChange = true,
36
+ children
37
+ } = _ref;
43
38
  /**
44
39
  * We can't pass `i18n` object directly through context, because even when locale
45
40
  * or messages are changed, i18n object is still the same. Context provider compares
@@ -51,25 +46,16 @@ var I18nProvider = function I18nProvider(_ref) {
51
46
  *
52
47
  * We can't use useMemo hook either, because we want to recalculate value manually.
53
48
  */
54
- var makeContext = function makeContext() {
55
- return {
56
- i18n: i18n,
57
- defaultComponent: defaultComponent
58
- };
49
+ const makeContext = () => ({
50
+ i18n,
51
+ defaultComponent
52
+ });
53
+ const getRenderKey = () => {
54
+ return forceRenderOnLocaleChange ? i18n.locale || "default" : "default";
59
55
  };
56
+ const [context, setContext] = React.useState(makeContext()),
57
+ [renderKey, setRenderKey] = React.useState(getRenderKey());
60
58
 
61
- var getRenderKey = function getRenderKey() {
62
- return forceRenderOnLocaleChange ? i18n.locale || 'default' : 'default';
63
- };
64
-
65
- var _React$useState = React.useState(makeContext()),
66
- _React$useState2 = _slicedToArray(_React$useState, 2),
67
- context = _React$useState2[0],
68
- setContext = _React$useState2[1],
69
- _React$useState3 = React.useState(getRenderKey()),
70
- _React$useState4 = _slicedToArray(_React$useState3, 2),
71
- renderKey = _React$useState4[0],
72
- setRenderKey = _React$useState4[1];
73
59
  /**
74
60
  * Subscribe for locale/message changes
75
61
  *
@@ -82,44 +68,33 @@ var I18nProvider = function I18nProvider(_ref) {
82
68
  * `useEffect` hook being called. This can happen if locales are loaded/activated
83
69
  * async.
84
70
  */
85
-
86
-
87
- React.useEffect(function () {
88
- var unsubscribe = i18n.on("change", function () {
71
+ React.useEffect(() => {
72
+ const unsubscribe = i18n.on("change", () => {
89
73
  setContext(makeContext());
90
74
  setRenderKey(getRenderKey());
91
75
  });
92
-
93
- if (renderKey === 'default') {
76
+ if (renderKey === "default") {
94
77
  setRenderKey(getRenderKey());
95
78
  }
96
-
97
- if (forceRenderOnLocaleChange && renderKey === 'default') {
79
+ if (forceRenderOnLocaleChange && renderKey === "default") {
98
80
  console.log("I18nProvider did not render. A call to i18n.activate still needs to happen or forceRenderOnLocaleChange must be set to false.");
99
81
  }
100
-
101
- return function () {
102
- return unsubscribe();
103
- };
82
+ return () => unsubscribe();
104
83
  }, []);
105
- if (forceRenderOnLocaleChange && renderKey === 'default') return null;
84
+ if (forceRenderOnLocaleChange && renderKey === "default") return null;
106
85
  return /*#__PURE__*/React.createElement(LinguiContext.Provider, {
107
86
  value: context,
108
87
  key: renderKey
109
88
  }, children);
110
89
  };
111
90
 
112
- function _createForOfIteratorHelper(o, allowArrayLike) { var it; if (typeof Symbol === "undefined" || o[Symbol.iterator] == null) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = o[Symbol.iterator](); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; }
113
-
114
- function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
115
-
116
- function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
91
+ // match <tag>paired</tag> and <tag/> unpaired tags
92
+ const tagRe = /<([a-zA-Z0-9]+)>(.*?)<\/\1>|<([a-zA-Z0-9]+)\/>/;
93
+ const nlRe = /(?:\r\n|\r|\n)/g;
117
94
 
118
- var tagRe = /<(\d+)>(.*?)<\/\1>|<(\d+)\/>/;
119
- var nlRe = /(?:\r\n|\r|\n)/g; // For HTML, certain tags should omit their close tag. We keep a whitelist for
95
+ // For HTML, certain tags should omit their close tag. We keep a whitelist for
120
96
  // those special-case tags.
121
-
122
- var voidElementTags = {
97
+ const voidElementTags = {
123
98
  area: true,
124
99
  base: true,
125
100
  br: true,
@@ -137,62 +112,47 @@ var voidElementTags = {
137
112
  wbr: true,
138
113
  menuitem: true
139
114
  };
115
+
140
116
  /**
141
117
  * `formatElements` - parse string and return tree of react elements
142
118
  *
143
- * `value` is string to be formatted with <0>Paired<0/> or <0/> (unpaired)
119
+ * `value` is string to be formatted with <tag>Paired<tag/> or <tag/> (unpaired)
144
120
  * placeholders. `elements` is a array of react elements which indexes
145
121
  * correspond to element indexes in formatted string
146
122
  */
147
-
148
123
  function formatElements(value) {
149
- var elements = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
150
- var uniqueId = makeCounter(0, '$lingui$');
151
- var parts = value.replace(nlRe, "").split(tagRe); // no inline elements, return
124
+ let elements = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
125
+ const uniqueId = makeCounter(0, "$lingui$");
126
+ const parts = value.replace(nlRe, "").split(tagRe);
152
127
 
128
+ // no inline elements, return
153
129
  if (parts.length === 1) return value;
154
- var tree = [];
155
- var before = parts.shift();
130
+ const tree = [];
131
+ const before = parts.shift();
156
132
  if (before) tree.push(before);
157
-
158
- var _iterator = _createForOfIteratorHelper(getElements(parts)),
159
- _step;
160
-
161
- try {
162
- for (_iterator.s(); !(_step = _iterator.n()).done;) {
163
- var _step$value = _slicedToArray(_step.value, 3),
164
- index = _step$value[0],
165
- children = _step$value[1],
166
- after = _step$value[2];
167
-
168
- var element = elements[index];
169
-
170
- if (!element || voidElementTags[element.type] && children) {
171
- if (!element) {
172
- console.error("Can use element at index '".concat(index, "' as it is not declared in the original translation"));
173
- } else {
174
- console.error("".concat(element.type, " is a void element tag therefore it must have no children"));
175
- } // ignore problematic element but push its children and elements after it
176
-
177
-
178
- element = /*#__PURE__*/React.createElement(React.Fragment);
133
+ for (const [index, children, after] of getElements(parts)) {
134
+ let element = elements[index];
135
+ if (!element || voidElementTags[element.type] && children) {
136
+ if (!element) {
137
+ console.error(`Can use element at index '${index}' as it is not declared in the original translation`);
138
+ } else {
139
+ console.error(`${element.type} is a void element tag therefore it must have no children`);
179
140
  }
180
141
 
181
- tree.push( /*#__PURE__*/React.cloneElement(element, {
182
- key: uniqueId()
183
- }, // format children for pair tags
184
- // unpaired tags might have children if it's a component passed as a variable
185
- children ? formatElements(children, elements) : element.props.children));
186
- if (after) tree.push(after);
142
+ // ignore problematic element but push its children and elements after it
143
+ element = /*#__PURE__*/React.createElement(React.Fragment);
187
144
  }
188
- } catch (err) {
189
- _iterator.e(err);
190
- } finally {
191
- _iterator.f();
145
+ tree.push( /*#__PURE__*/React.cloneElement(element, {
146
+ key: uniqueId()
147
+ },
148
+ // format children for pair tags
149
+ // unpaired tags might have children if it's a component passed as a variable
150
+ children ? formatElements(children, elements) : element.props.children));
151
+ if (after) tree.push(after);
192
152
  }
193
-
194
153
  return tree;
195
154
  }
155
+
196
156
  /*
197
157
  * `getElements` - return array of element indexes and element childrens
198
158
  *
@@ -207,47 +167,35 @@ function formatElements(value) {
207
167
  *
208
168
  * Returns: Array<[elementIndex, children, after]>
209
169
  */
210
-
211
-
212
170
  function getElements(parts) {
213
171
  if (!parts.length) return [];
214
-
215
- var _parts$slice = parts.slice(0, 4),
216
- _parts$slice2 = _slicedToArray(_parts$slice, 4),
217
- paired = _parts$slice2[0],
218
- children = _parts$slice2[1],
219
- unpaired = _parts$slice2[2],
220
- after = _parts$slice2[3];
221
-
222
- return [[parseInt(paired || unpaired), children || "", after]].concat(getElements(parts.slice(4, parts.length)));
172
+ const [paired, children, unpaired, after] = parts.slice(0, 4);
173
+ return [[paired || unpaired, children || "", after]].concat(getElements(parts.slice(4, parts.length)));
223
174
  }
224
-
225
- var makeCounter = function makeCounter() {
226
- var count = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0;
227
- var prefix = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : "";
228
- return function () {
229
- return "".concat(prefix, "_").concat(count++);
230
- };
175
+ const makeCounter = function () {
176
+ let count = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0;
177
+ let prefix = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : "";
178
+ return () => `${prefix}_${count++}`;
231
179
  };
232
180
 
233
- function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
234
-
235
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
236
181
  function Trans(props) {
237
- var _useLingui = useLingui(),
238
- i18n = _useLingui.i18n,
239
- defaultComponent = _useLingui.defaultComponent;
240
-
241
- var render = props.render,
242
- component = props.component,
243
- id = props.id,
244
- message = props.message,
245
- formats = props.formats;
246
-
247
- var values = _objectSpread({}, props.values);
248
-
249
- var components = _objectSpread({}, props.components);
250
-
182
+ const {
183
+ i18n,
184
+ defaultComponent
185
+ } = useLingui();
186
+ const {
187
+ render,
188
+ component,
189
+ id,
190
+ message,
191
+ formats
192
+ } = props;
193
+ const values = {
194
+ ...props.values
195
+ };
196
+ const components = {
197
+ ...props.components
198
+ };
251
199
  if (values) {
252
200
  /*
253
201
  Related discussion: https://github.com/lingui/js-lingui/issues/183
@@ -258,57 +206,55 @@ function Trans(props) {
258
206
  Values: { name: <strong>Jane</strong> }
259
207
  It'll become "Hello <0 />" with components=[<strong>Jane</strong>]
260
208
  */
261
- Object.keys(values).forEach(function (key) {
262
- var value = values[key];
209
+
210
+ Object.keys(values).forEach(key => {
211
+ const value = values[key];
263
212
  if (! /*#__PURE__*/React.isValidElement(value)) return;
264
- var index = Object.keys(components).length;
213
+ const index = Object.keys(components).length;
265
214
  components[index] = value;
266
- values[key] = "<".concat(index, "/>");
215
+ values[key] = `<${index}/>`;
267
216
  });
268
217
  }
269
-
270
- var _translation = i18n && typeof i18n._ === "function" ? i18n._(id, values, {
271
- message: message,
272
- formats: formats
218
+ const _translation = i18n && typeof i18n._ === "function" ? i18n._(id, values, {
219
+ message,
220
+ formats
273
221
  }) : id; // i18n provider isn't loaded at all
274
222
 
275
-
276
- var translation = _translation ? formatElements(_translation, components) : null;
277
-
223
+ const translation = _translation ? formatElements(_translation, components) : null;
278
224
  if (render === null || component === null) {
279
225
  // Although `string` is a valid react element, types only allow `Element`
280
226
  // Upstream issue: https://github.com/DefinitelyTyped/DefinitelyTyped/issues/20544
281
227
  return translation;
282
228
  }
283
-
284
- var FallbackComponent = defaultComponent || React.Fragment;
285
- var i18nProps = {
286
- id: id,
287
- message: message,
288
- translation: translation,
229
+ const FallbackComponent = defaultComponent || React.Fragment;
230
+ const i18nProps = {
231
+ id,
232
+ message,
233
+ translation,
289
234
  isTranslated: id !== translation && message !== translation
290
- }; // Validation of `render` and `component` props
235
+ };
291
236
 
237
+ // Validation of `render` and `component` props
292
238
  if (render && component) {
293
239
  console.error("You can't use both `component` and `render` prop at the same time. `component` is ignored.");
294
240
  } else if (render && typeof render !== "function") {
295
- console.error("Invalid value supplied to prop `render`. It must be a function, provided ".concat(render));
241
+ console.error(`Invalid value supplied to prop \`render\`. It must be a function, provided ${render}`);
296
242
  } else if (component && typeof component !== "function") {
297
243
  // Apparently, both function components and class components are functions
298
244
  // See https://stackoverflow.com/a/41658173/1535540
299
- console.error("Invalid value supplied to prop `component`. It must be a React component, provided ".concat(component));
245
+ console.error(`Invalid value supplied to prop \`component\`. It must be a React component, provided ${component}`);
300
246
  return /*#__PURE__*/React.createElement(FallbackComponent, i18nProps, translation);
301
- } // Rendering using a render prop
302
-
247
+ }
303
248
 
249
+ // Rendering using a render prop
304
250
  if (typeof render === "function") {
305
251
  // Component: render={(props) => <a title={props.translation}>x</a>}
306
252
  return render(i18nProps);
307
- } // `component` prop has a higher precedence over `defaultComponent`
308
-
253
+ }
309
254
 
310
- var Component = component || FallbackComponent;
311
- var DefaultComponent = defaultComponent;
255
+ // `component` prop has a higher precedence over `defaultComponent`
256
+ const Component = component || FallbackComponent;
257
+ const DefaultComponent = defaultComponent;
312
258
  return DefaultComponent && !component ? /*#__PURE__*/React.createElement(DefaultComponent, i18nProps, translation) : /*#__PURE__*/React.createElement(Component, null, translation);
313
259
  }
314
260
  Trans.defaultProps = {
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../../src/I18nProvider.tsx","../../src/format.ts","../../src/Trans.tsx"],"sourcesContent":["import React, { ComponentType, FunctionComponent } from \"react\"\nimport { I18n } from \"@lingui/core\"\nimport { TransRenderProps } from \"./Trans\"\n\nexport type I18nContext = {\n i18n: I18n\n defaultComponent?: ComponentType<TransRenderProps>\n}\n\nexport type withI18nProps = {\n i18n: I18n\n}\n\nexport type I18nProviderProps = I18nContext & {\n forceRenderOnLocaleChange?: boolean\n children?: React.ReactNode\n}\n\nconst LinguiContext = React.createContext<I18nContext>(null)\n\nexport function useLingui(): I18nContext {\n const context = React.useContext<I18nContext>(LinguiContext)\n\n if (process.env.NODE_ENV !== \"production\") {\n if (context == null) {\n throw new Error(\"useLingui hook was used without I18nProvider.\")\n }\n }\n\n return context\n}\n\nexport function withI18n(\n o?: object\n): <P extends withI18nProps>(\n Component: ComponentType<P>\n) => React.ComponentType<Omit<P, 'i18n'>> {\n return <P extends withI18nProps>(\n WrappedComponent: ComponentType<P>\n ): ComponentType<P> => {\n return (props) => {\n if (process.env.NODE_ENV !== \"production\") {\n if (typeof o === \"function\" || React.isValidElement(o)) {\n throw new Error(\n \"withI18n([options]) takes options as a first argument, \" +\n \"but received React component itself. Without options, the Component \" +\n \"should be wrapped as withI18n()(Component), not withI18n(Component).\"\n )\n }\n }\n\n const { i18n } = useLingui()\n return <WrappedComponent {...props} i18n={i18n} />\n }\n }\n}\n\nexport const I18nProvider: FunctionComponent<I18nProviderProps> = ({\n i18n,\n defaultComponent,\n forceRenderOnLocaleChange = true,\n children,\n}) => {\n /**\n * We can't pass `i18n` object directly through context, because even when locale\n * or messages are changed, i18n object is still the same. Context provider compares\n * reference identity and suggested workaround is create a wrapper object every time\n * we need to trigger re-render. See https://reactjs.org/docs/context.html#caveats.\n *\n * Due to this effect we also pass `defaultComponent` in the same context, instead\n * of creating a separate Provider/Consumer pair.\n *\n * We can't use useMemo hook either, because we want to recalculate value manually.\n */\n const makeContext = () => ({\n i18n,\n defaultComponent,\n })\n const getRenderKey = () => {\n return (forceRenderOnLocaleChange ? (i18n.locale || 'default') : 'default') as string\n }\n\n const [context, setContext] = React.useState<I18nContext>(makeContext()),\n [renderKey, setRenderKey] = React.useState<string>(getRenderKey())\n\n /**\n * Subscribe for locale/message changes\n *\n * I18n object from `@lingui/core` is the single source of truth for all i18n related\n * data (active locale, catalogs). When new messages are loaded or locale is changed\n * we need to trigger re-rendering of LinguiContext.Consumers.\n *\n * We call `setContext(makeContext())` after adding the observer in case the `change`\n * event would already have fired between the inital renderKey calculation and the\n * `useEffect` hook being called. This can happen if locales are loaded/activated\n * async.\n */\n React.useEffect(() => {\n const unsubscribe = i18n.on(\"change\", () => {\n setContext(makeContext())\n setRenderKey(getRenderKey())\n })\n if (renderKey === 'default') {\n setRenderKey(getRenderKey())\n }\n if (forceRenderOnLocaleChange && renderKey === 'default') {\n console.log(\"I18nProvider did not render. A call to i18n.activate still needs to happen or forceRenderOnLocaleChange must be set to false.\")\n }\n return () => unsubscribe()\n }, [])\n\n if (forceRenderOnLocaleChange && renderKey === 'default') return null\n\n return (\n <LinguiContext.Provider value={context} key={renderKey}>\n {children}\n </LinguiContext.Provider>\n )\n}\n","import React from \"react\"\n\n// match <0>paired</0> and <1/> unpaired tags\nconst tagRe = /<(\\d+)>(.*?)<\\/\\1>|<(\\d+)\\/>/\nconst nlRe = /(?:\\r\\n|\\r|\\n)/g\n\n// For HTML, certain tags should omit their close tag. We keep a whitelist for\n// those special-case tags.\nconst voidElementTags = {\n area: true,\n base: true,\n br: true,\n col: true,\n embed: true,\n hr: true,\n img: true,\n input: true,\n keygen: true,\n link: true,\n meta: true,\n param: true,\n source: true,\n track: true,\n wbr: true,\n menuitem: true\n}\n\n/**\n * `formatElements` - parse string and return tree of react elements\n *\n * `value` is string to be formatted with <0>Paired<0/> or <0/> (unpaired)\n * placeholders. `elements` is a array of react elements which indexes\n * correspond to element indexes in formatted string\n */\nfunction formatElements(\n value: string,\n elements: { [key: string]: React.ReactElement<any> } = {}\n): string | Array<any> {\n const uniqueId = makeCounter(0, '$lingui$')\n const parts = value.replace(nlRe, \"\").split(tagRe)\n\n // no inline elements, return\n if (parts.length === 1) return value\n\n const tree = []\n\n const before = parts.shift()\n if (before) tree.push(before)\n\n for (const [index, children, after] of getElements(parts)) {\n let element = elements[index]\n\n if (!element || (voidElementTags[element.type as string] && children)) {\n if (!element) {\n console.error(\n `Can use element at index '${index}' as it is not declared in the original translation`\n )\n } else {\n console.error(\n `${element.type} is a void element tag therefore it must have no children`\n )\n }\n\n // ignore problematic element but push its children and elements after it\n element = React.createElement(React.Fragment)\n }\n\n tree.push(\n React.cloneElement(\n element,\n { key: uniqueId() },\n\n // format children for pair tags\n // unpaired tags might have children if it's a component passed as a variable\n children ? formatElements(children, elements) : element.props.children\n )\n )\n\n if (after) tree.push(after)\n }\n\n return tree\n}\n\n/*\n * `getElements` - return array of element indexes and element childrens\n *\n * `parts` is array of [pairedIndex, children, unpairedIndex, textAfter, ...]\n * where:\n * - `pairedIndex` is index of paired element (undef for unpaired)\n * - `children` are children of paired element (undef for unpaired)\n * - `unpairedIndex` is index of unpaired element (undef for paired)\n * - `textAfter` is string after all elements (empty string, if there's nothing)\n *\n * `parts` length is always multiply of 4\n *\n * Returns: Array<[elementIndex, children, after]>\n */\nfunction getElements(parts) {\n if (!parts.length) return []\n\n const [paired, children, unpaired, after] = parts.slice(0, 4)\n\n return [[parseInt(paired || unpaired), children || \"\", after]].concat(\n getElements(parts.slice(4, parts.length))\n )\n}\n\nconst makeCounter = (count = 0, prefix = \"\") => () => `${prefix}_${count++}`\n\nexport { formatElements }\n","import React from \"react\"\n\nimport { useLingui } from \"./I18nProvider\"\nimport { formatElements } from \"./format\"\n\nexport type TransRenderProps = {\n id?: string\n translation?: React.ReactNode\n children?: React.ReactNode\n message?: string | null\n isTranslated?: boolean\n}\n\nexport type TransProps = {\n id: string\n message?: string\n values: Record<string, unknown>\n context?: string\n components: { [key: string]: React.ElementType | any }\n formats?: Record<string, unknown>\n children?: React.ReactNode\n component?: React.ComponentType<TransRenderProps>\n render?: (props: TransRenderProps) => React.ReactElement<any, any> | null\n}\n\nexport function Trans(props: TransProps): React.ReactElement<any, any> | null {\n const { i18n, defaultComponent } = useLingui()\n const { render, component, id, message, formats } = props\n\n const values = { ...props.values }\n const components = { ...props.components }\n\n if (values) {\n /*\n Related discussion: https://github.com/lingui/js-lingui/issues/183\n\n Values *might* contain React elements with static content.\n They're replaced with <INDEX /> placeholders and added to `components`.\n\n Example:\n Translation: Hello {name}\n Values: { name: <strong>Jane</strong> }\n\n It'll become \"Hello <0 />\" with components=[<strong>Jane</strong>]\n */\n\n Object.keys(values).forEach((key) => {\n const value = values[key]\n if (!React.isValidElement(value)) return\n\n const index = Object.keys(components).length\n\n components[index] = value\n values[key] = `<${index}/>`\n })\n }\n\n const _translation: string =\n i18n && typeof i18n._ === \"function\"\n ? i18n._(id, values, { message, formats })\n : id // i18n provider isn't loaded at all\n\n const translation = _translation\n ? formatElements(_translation, components)\n : null\n\n if (render === null || component === null) {\n // Although `string` is a valid react element, types only allow `Element`\n // Upstream issue: https://github.com/DefinitelyTyped/DefinitelyTyped/issues/20544\n return (translation as unknown) as React.ReactElement<any, any>\n }\n\n const FallbackComponent = (defaultComponent ||\n React.Fragment) as React.ComponentType<any>\n\n const i18nProps = {\n id,\n message,\n translation,\n isTranslated: id !== translation && message !== translation,\n }\n\n // Validation of `render` and `component` props\n if (render && component) {\n console.error(\n \"You can't use both `component` and `render` prop at the same time. `component` is ignored.\"\n )\n } else if (render && typeof render !== \"function\") {\n console.error(\n `Invalid value supplied to prop \\`render\\`. It must be a function, provided ${render}`\n )\n } else if (component && typeof component !== \"function\") {\n // Apparently, both function components and class components are functions\n // See https://stackoverflow.com/a/41658173/1535540\n console.error(\n `Invalid value supplied to prop \\`component\\`. It must be a React component, provided ${component}`\n )\n return <FallbackComponent {...i18nProps}>{translation}</FallbackComponent>\n }\n\n // Rendering using a render prop\n if (typeof render === \"function\") {\n // Component: render={(props) => <a title={props.translation}>x</a>}\n return render(i18nProps)\n }\n\n // `component` prop has a higher precedence over `defaultComponent`\n const Component = (component || FallbackComponent) as React.ComponentType<any>\n const DefaultComponent = defaultComponent\n\n return DefaultComponent && !component ? (\n <DefaultComponent {...i18nProps}>{translation}</DefaultComponent>\n ) : (\n <Component>{translation}</Component>\n )\n}\n\nTrans.defaultProps = {\n values: {},\n components: {},\n}\n"],"names":["LinguiContext","React","createContext","useLingui","context","useContext","process","env","NODE_ENV","Error","withI18n","o","WrappedComponent","props","isValidElement","i18n","I18nProvider","defaultComponent","forceRenderOnLocaleChange","children","makeContext","getRenderKey","locale","useState","setContext","renderKey","setRenderKey","useEffect","unsubscribe","on","console","log","tagRe","nlRe","voidElementTags","area","base","br","col","embed","hr","img","input","keygen","link","meta","param","source","track","wbr","menuitem","formatElements","value","elements","uniqueId","makeCounter","parts","replace","split","length","tree","before","shift","push","getElements","index","after","element","type","error","createElement","Fragment","cloneElement","key","slice","paired","unpaired","parseInt","concat","count","prefix","Trans","render","component","id","message","formats","values","components","Object","keys","forEach","_translation","_","translation","FallbackComponent","i18nProps","isTranslated","Component","DefaultComponent","defaultProps"],"mappings":"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"}
1
+ {"version":3,"file":"index.js","sources":["../../src/I18nProvider.tsx","../../src/format.ts","../../src/Trans.tsx"],"sourcesContent":["import React, { ComponentType, FunctionComponent } from \"react\"\nimport { I18n } from \"@lingui/core\"\nimport { TransRenderProps } from \"./Trans\"\n\nexport type I18nContext = {\n i18n: I18n\n defaultComponent?: ComponentType<TransRenderProps>\n}\n\nexport type withI18nProps = {\n i18n: I18n\n}\n\nexport type I18nProviderProps = I18nContext & {\n forceRenderOnLocaleChange?: boolean\n children?: React.ReactNode\n}\n\nconst LinguiContext = React.createContext<I18nContext>(null)\n\nexport function useLingui(): I18nContext {\n const context = React.useContext<I18nContext>(LinguiContext)\n\n if (process.env.NODE_ENV !== \"production\") {\n if (context == null) {\n throw new Error(\"useLingui hook was used without I18nProvider.\")\n }\n }\n\n return context\n}\n\nexport function withI18n(\n o?: object\n): <P extends withI18nProps>(\n Component: ComponentType<P>\n) => React.ComponentType<Omit<P, \"i18n\">> {\n return <P extends withI18nProps>(\n WrappedComponent: ComponentType<P>\n ): ComponentType<P> => {\n return (props) => {\n if (process.env.NODE_ENV !== \"production\") {\n if (typeof o === \"function\" || React.isValidElement(o)) {\n throw new Error(\n \"withI18n([options]) takes options as a first argument, \" +\n \"but received React component itself. Without options, the Component \" +\n \"should be wrapped as withI18n()(Component), not withI18n(Component).\"\n )\n }\n }\n\n const { i18n } = useLingui()\n return <WrappedComponent {...props} i18n={i18n} />\n }\n }\n}\n\nexport const I18nProvider: FunctionComponent<I18nProviderProps> = ({\n i18n,\n defaultComponent,\n forceRenderOnLocaleChange = true,\n children,\n}) => {\n /**\n * We can't pass `i18n` object directly through context, because even when locale\n * or messages are changed, i18n object is still the same. Context provider compares\n * reference identity and suggested workaround is create a wrapper object every time\n * we need to trigger re-render. See https://reactjs.org/docs/context.html#caveats.\n *\n * Due to this effect we also pass `defaultComponent` in the same context, instead\n * of creating a separate Provider/Consumer pair.\n *\n * We can't use useMemo hook either, because we want to recalculate value manually.\n */\n const makeContext = () => ({\n i18n,\n defaultComponent,\n })\n const getRenderKey = () => {\n return (\n forceRenderOnLocaleChange ? i18n.locale || \"default\" : \"default\"\n ) as string\n }\n\n const [context, setContext] = React.useState<I18nContext>(makeContext()),\n [renderKey, setRenderKey] = React.useState<string>(getRenderKey())\n\n /**\n * Subscribe for locale/message changes\n *\n * I18n object from `@lingui/core` is the single source of truth for all i18n related\n * data (active locale, catalogs). When new messages are loaded or locale is changed\n * we need to trigger re-rendering of LinguiContext.Consumers.\n *\n * We call `setContext(makeContext())` after adding the observer in case the `change`\n * event would already have fired between the inital renderKey calculation and the\n * `useEffect` hook being called. This can happen if locales are loaded/activated\n * async.\n */\n React.useEffect(() => {\n const unsubscribe = i18n.on(\"change\", () => {\n setContext(makeContext())\n setRenderKey(getRenderKey())\n })\n if (renderKey === \"default\") {\n setRenderKey(getRenderKey())\n }\n if (forceRenderOnLocaleChange && renderKey === \"default\") {\n console.log(\n \"I18nProvider did not render. A call to i18n.activate still needs to happen or forceRenderOnLocaleChange must be set to false.\"\n )\n }\n return () => unsubscribe()\n }, [])\n\n if (forceRenderOnLocaleChange && renderKey === \"default\") return null\n\n return (\n <LinguiContext.Provider value={context} key={renderKey}>\n {children}\n </LinguiContext.Provider>\n )\n}\n","import React from \"react\"\n\n// match <tag>paired</tag> and <tag/> unpaired tags\nconst tagRe = /<([a-zA-Z0-9]+)>(.*?)<\\/\\1>|<([a-zA-Z0-9]+)\\/>/\nconst nlRe = /(?:\\r\\n|\\r|\\n)/g\n\n// For HTML, certain tags should omit their close tag. We keep a whitelist for\n// those special-case tags.\nconst voidElementTags = {\n area: true,\n base: true,\n br: true,\n col: true,\n embed: true,\n hr: true,\n img: true,\n input: true,\n keygen: true,\n link: true,\n meta: true,\n param: true,\n source: true,\n track: true,\n wbr: true,\n menuitem: true,\n}\n\n/**\n * `formatElements` - parse string and return tree of react elements\n *\n * `value` is string to be formatted with <tag>Paired<tag/> or <tag/> (unpaired)\n * placeholders. `elements` is a array of react elements which indexes\n * correspond to element indexes in formatted string\n */\nfunction formatElements(\n value: string,\n elements: { [key: string]: React.ReactElement<any> } = {}\n): string | Array<any> {\n const uniqueId = makeCounter(0, \"$lingui$\")\n const parts = value.replace(nlRe, \"\").split(tagRe)\n\n // no inline elements, return\n if (parts.length === 1) return value\n\n const tree = []\n\n const before = parts.shift()\n if (before) tree.push(before)\n\n for (const [index, children, after] of getElements(parts)) {\n let element = elements[index]\n\n if (!element || (voidElementTags[element.type as string] && children)) {\n if (!element) {\n console.error(\n `Can use element at index '${index}' as it is not declared in the original translation`\n )\n } else {\n console.error(\n `${element.type} is a void element tag therefore it must have no children`\n )\n }\n\n // ignore problematic element but push its children and elements after it\n element = React.createElement(React.Fragment)\n }\n\n tree.push(\n React.cloneElement(\n element,\n { key: uniqueId() },\n\n // format children for pair tags\n // unpaired tags might have children if it's a component passed as a variable\n children ? formatElements(children, elements) : element.props.children\n )\n )\n\n if (after) tree.push(after)\n }\n\n return tree\n}\n\n/*\n * `getElements` - return array of element indexes and element childrens\n *\n * `parts` is array of [pairedIndex, children, unpairedIndex, textAfter, ...]\n * where:\n * - `pairedIndex` is index of paired element (undef for unpaired)\n * - `children` are children of paired element (undef for unpaired)\n * - `unpairedIndex` is index of unpaired element (undef for paired)\n * - `textAfter` is string after all elements (empty string, if there's nothing)\n *\n * `parts` length is always multiply of 4\n *\n * Returns: Array<[elementIndex, children, after]>\n */\nfunction getElements(parts) {\n if (!parts.length) return []\n\n const [paired, children, unpaired, after] = parts.slice(0, 4)\n\n return [[paired || unpaired, children || \"\", after]].concat(\n getElements(parts.slice(4, parts.length))\n )\n}\n\nconst makeCounter =\n (count = 0, prefix = \"\") =>\n () =>\n `${prefix}_${count++}`\n\nexport { formatElements }\n","import React from \"react\"\n\nimport { useLingui } from \"./I18nProvider\"\nimport { formatElements } from \"./format\"\n\nexport type TransRenderProps = {\n id?: string\n translation?: React.ReactNode\n children?: React.ReactNode\n message?: string | null\n isTranslated?: boolean\n}\n\nexport type TransProps = {\n id: string\n message?: string\n values: Record<string, unknown>\n context?: string\n components: { [key: string]: React.ElementType | any }\n formats?: Record<string, unknown>\n children?: React.ReactNode\n component?: React.ComponentType<TransRenderProps>\n render?: (props: TransRenderProps) => React.ReactElement<any, any> | null\n}\n\nexport function Trans(props: TransProps): React.ReactElement<any, any> | null {\n const { i18n, defaultComponent } = useLingui()\n const { render, component, id, message, formats } = props\n\n const values = { ...props.values }\n const components = { ...props.components }\n\n if (values) {\n /*\n Related discussion: https://github.com/lingui/js-lingui/issues/183\n\n Values *might* contain React elements with static content.\n They're replaced with <INDEX /> placeholders and added to `components`.\n\n Example:\n Translation: Hello {name}\n Values: { name: <strong>Jane</strong> }\n\n It'll become \"Hello <0 />\" with components=[<strong>Jane</strong>]\n */\n\n Object.keys(values).forEach((key) => {\n const value = values[key]\n if (!React.isValidElement(value)) return\n\n const index = Object.keys(components).length\n\n components[index] = value\n values[key] = `<${index}/>`\n })\n }\n\n const _translation: string =\n i18n && typeof i18n._ === \"function\"\n ? i18n._(id, values, { message, formats })\n : id // i18n provider isn't loaded at all\n\n const translation = _translation\n ? formatElements(_translation, components)\n : null\n\n if (render === null || component === null) {\n // Although `string` is a valid react element, types only allow `Element`\n // Upstream issue: https://github.com/DefinitelyTyped/DefinitelyTyped/issues/20544\n return translation as unknown as React.ReactElement<any, any>\n }\n\n const FallbackComponent = (defaultComponent ||\n React.Fragment) as React.ComponentType<any>\n\n const i18nProps = {\n id,\n message,\n translation,\n isTranslated: id !== translation && message !== translation,\n }\n\n // Validation of `render` and `component` props\n if (render && component) {\n console.error(\n \"You can't use both `component` and `render` prop at the same time. `component` is ignored.\"\n )\n } else if (render && typeof render !== \"function\") {\n console.error(\n `Invalid value supplied to prop \\`render\\`. It must be a function, provided ${render}`\n )\n } else if (component && typeof component !== \"function\") {\n // Apparently, both function components and class components are functions\n // See https://stackoverflow.com/a/41658173/1535540\n console.error(\n `Invalid value supplied to prop \\`component\\`. It must be a React component, provided ${component}`\n )\n return <FallbackComponent {...i18nProps}>{translation}</FallbackComponent>\n }\n\n // Rendering using a render prop\n if (typeof render === \"function\") {\n // Component: render={(props) => <a title={props.translation}>x</a>}\n return render(i18nProps)\n }\n\n // `component` prop has a higher precedence over `defaultComponent`\n const Component = (component || FallbackComponent) as React.ComponentType<any>\n const DefaultComponent = defaultComponent\n\n return DefaultComponent && !component ? (\n <DefaultComponent {...i18nProps}>{translation}</DefaultComponent>\n ) : (\n <Component>{translation}</Component>\n )\n}\n\nTrans.defaultProps = {\n values: {},\n components: {},\n}\n"],"names":["LinguiContext","React","createContext","useLingui","context","useContext","process","env","NODE_ENV","Error","withI18n","o","WrappedComponent","props","isValidElement","i18n","I18nProvider","defaultComponent","forceRenderOnLocaleChange","children","makeContext","getRenderKey","locale","setContext","useState","renderKey","setRenderKey","useEffect","unsubscribe","on","console","log","tagRe","nlRe","voidElementTags","area","base","br","col","embed","hr","img","input","keygen","link","meta","param","source","track","wbr","menuitem","formatElements","value","elements","uniqueId","makeCounter","parts","replace","split","length","tree","before","shift","push","index","after","getElements","element","type","error","createElement","Fragment","cloneElement","key","paired","unpaired","slice","concat","count","prefix","Trans","render","component","id","message","formats","values","components","Object","keys","forEach","_translation","_","translation","FallbackComponent","i18nProps","isTranslated","Component","DefaultComponent","defaultProps"],"mappings":"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"}
package/build/index.d.ts CHANGED
@@ -1,14 +1,14 @@
1
1
  import React, { ComponentType, FunctionComponent } from 'react';
2
2
  import { I18n } from '@lingui/core';
3
3
 
4
- declare type TransRenderProps = {
4
+ type TransRenderProps = {
5
5
  id?: string;
6
6
  translation?: React.ReactNode;
7
7
  children?: React.ReactNode;
8
8
  message?: string | null;
9
9
  isTranslated?: boolean;
10
10
  };
11
- declare type TransProps = {
11
+ type TransProps = {
12
12
  id: string;
13
13
  message?: string;
14
14
  values: Record<string, unknown>;
@@ -29,19 +29,19 @@ declare namespace Trans {
29
29
  };
30
30
  }
31
31
 
32
- declare type I18nContext = {
32
+ type I18nContext = {
33
33
  i18n: I18n;
34
34
  defaultComponent?: ComponentType<TransRenderProps>;
35
35
  };
36
- declare type withI18nProps = {
36
+ type withI18nProps = {
37
37
  i18n: I18n;
38
38
  };
39
- declare type I18nProviderProps = I18nContext & {
39
+ type I18nProviderProps = I18nContext & {
40
40
  forceRenderOnLocaleChange?: boolean;
41
41
  children?: React.ReactNode;
42
42
  };
43
43
  declare function useLingui(): I18nContext;
44
- declare function withI18n(o?: object): <P extends withI18nProps>(Component: ComponentType<P>) => React.ComponentType<Omit<P, 'i18n'>>;
44
+ declare function withI18n(o?: object): <P extends withI18nProps>(Component: ComponentType<P>) => React.ComponentType<Omit<P, "i18n">>;
45
45
  declare const I18nProvider: FunctionComponent<I18nProviderProps>;
46
46
 
47
47
  export { I18nContext, I18nProvider, I18nProviderProps, Trans, TransProps, TransRenderProps, useLingui, withI18n, withI18nProps };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@lingui/react",
3
- "version": "3.17.0",
3
+ "version": "3.17.1",
4
4
  "sideEffects": false,
5
5
  "description": "React components for translations",
6
6
  "main": "./build/cjs/index.js",
@@ -53,11 +53,11 @@
53
53
  "react": "^16.8.0 || ^17.0.0 || ^18.0.0"
54
54
  },
55
55
  "dependencies": {
56
- "@babel/runtime": "^7.11.2",
57
- "@lingui/core": "3.17.0"
56
+ "@babel/runtime": "^7.20.13",
57
+ "@lingui/core": "3.17.1"
58
58
  },
59
59
  "devDependencies": {
60
60
  "react-testing-library": "^8.0.1"
61
61
  },
62
- "gitHead": "1c8bc46213b35b25da8fe7a80ddcf6f6a5d9d539"
62
+ "gitHead": "76ef4e8d1c668578ce2c3829ebf35d22ca5e679c"
63
63
  }