@webiny/i18n-react 5.24.0 → 5.25.0-beta.0

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/index.d.ts CHANGED
@@ -7,11 +7,11 @@ declare global {
7
7
  children?: React.ReactNode;
8
8
  };
9
9
  "i18n-text-part": {
10
- key?: any;
10
+ key?: string;
11
11
  children?: React.ReactNode;
12
12
  };
13
13
  }
14
14
  }
15
15
  }
16
- declare const _default: Processor;
17
- export default _default;
16
+ declare const processor: Processor;
17
+ export default processor;
package/index.js CHANGED
@@ -1,22 +1,20 @@
1
1
  import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
2
- import _has from "lodash/has";
3
- import _trim from "lodash/trim";
4
- import _startsWith from "lodash/startsWith";
5
2
  import React from "react";
3
+ import lodashTrim from "lodash/trim";
6
4
 
7
5
  var processTextPart = function processTextPart(part, values, modifiers) {
8
- if (!_startsWith(part, "{")) {
6
+ if (part.startsWith("{") === false) {
9
7
  return part;
10
8
  }
11
9
 
12
- part = _trim(part, "{}");
10
+ part = lodashTrim(part, "{}");
13
11
  var parts = part.split("|");
14
12
 
15
13
  var _parts = _slicedToArray(parts, 2),
16
14
  variable = _parts[0],
17
15
  modifier = _parts[1];
18
16
 
19
- if (!_has(values, variable)) {
17
+ if (!values[variable]) {
20
18
  return variable;
21
19
  }
22
20
 
@@ -26,6 +24,10 @@ var processTextPart = function processTextPart(part, values, modifiers) {
26
24
  var parameters = modifier.split(":");
27
25
  var name = parameters.shift();
28
26
 
27
+ if (!name) {
28
+ return value;
29
+ }
30
+
29
31
  if (modifiers[name]) {
30
32
  var _modifier = modifiers[name];
31
33
  value = _modifier.execute(value, parameters);
@@ -35,7 +37,7 @@ var processTextPart = function processTextPart(part, values, modifiers) {
35
37
  return value;
36
38
  };
37
39
 
38
- export default {
40
+ var processor = {
39
41
  name: "react",
40
42
  canExecute: function canExecute(data) {
41
43
  for (var key in data.values) {
@@ -49,12 +51,12 @@ export default {
49
51
  return false;
50
52
  },
51
53
  execute: function execute(data) {
52
- var parts = data.translation.split(/({.*?})/); // @ts-ignore
53
-
54
+ var parts = data.translation.split(/({.*?})/);
54
55
  return /*#__PURE__*/React.createElement("i18n-text", null, parts.map(function (part, index) {
55
56
  return /*#__PURE__*/React.createElement("i18n-text-part", {
56
- key: index
57
+ key: String(index)
57
58
  }, processTextPart(part, data.values, data.i18n.modifiers));
58
59
  }));
59
60
  }
60
- };
61
+ };
62
+ export default processor;
package/index.js.map ADDED
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["index.tsx"],"names":["React","lodashTrim","processTextPart","part","values","modifiers","startsWith","parts","split","variable","modifier","value","parameters","name","shift","execute","processor","canExecute","data","key","isValidElement","translation","map","index","String","i18n"],"mappings":";AAAA,OAAOA,KAAP,MAAkB,OAAlB;AACA,OAAOC,UAAP,MAAuB,aAAvB;;AAmBA,IAAMC,eAAe,GAAG,SAAlBA,eAAkB,CACpBC,IADoB,EAEpBC,MAFoB,EAGpBC,SAHoB,EAIX;AACT,MAAIF,IAAI,CAACG,UAAL,CAAgB,GAAhB,MAAyB,KAA7B,EAAoC;AAChC,WAAOH,IAAP;AACH;;AAEDA,EAAAA,IAAI,GAAGF,UAAU,CAACE,IAAD,EAAO,IAAP,CAAjB;AAEA,MAAMI,KAAe,GAAGJ,IAAI,CAACK,KAAL,CAAW,GAAX,CAAxB;;AAEA,8BAA6BD,KAA7B;AAAA,MAAOE,QAAP;AAAA,MAAiBC,QAAjB;;AAEA,MAAI,CAACN,MAAM,CAACK,QAAD,CAAX,EAAuB;AACnB,WAAOA,QAAP;AACH;;AAED,MAAIE,KAAK,GAAGP,MAAM,CAACK,QAAD,CAAlB;;AACA,MAAIC,QAAJ,EAAc;AACV,QAAME,UAAU,GAAGF,QAAQ,CAACF,KAAT,CAAe,GAAf,CAAnB;AACA,QAAMK,IAAI,GAAGD,UAAU,CAACE,KAAX,EAAb;;AACA,QAAI,CAACD,IAAL,EAAW;AACP,aAAOF,KAAP;AACH;;AACD,QAAIN,SAAS,CAACQ,IAAD,CAAb,EAAqB;AACjB,UAAMH,SAAQ,GAAGL,SAAS,CAACQ,IAAD,CAA1B;AACAF,MAAAA,KAAK,GAAGD,SAAQ,CAACK,OAAT,CAAiBJ,KAAjB,EAAwBC,UAAxB,CAAR;AACH;AACJ;;AAED,SAAOD,KAAP;AACH,CAjCD;;AAmCA,IAAMK,SAAoB,GAAG;AACzBH,EAAAA,IAAI,EAAE,OADmB;AAEzBI,EAAAA,UAFyB,sBAEdC,IAFc,EAER;AACb,SAAK,IAAMC,GAAX,IAAkBD,IAAI,CAACd,MAAvB,EAA+B;AAC3B,UAAMO,KAAK,GAAGO,IAAI,CAACd,MAAL,CAAYe,GAAZ,CAAd;;AACA,wBAAInB,KAAK,CAACoB,cAAN,CAAqBT,KAArB,CAAJ,EAAiC;AAC7B,eAAO,IAAP;AACH;AACJ;;AAED,WAAO,KAAP;AACH,GAXwB;AAYzBI,EAAAA,OAZyB,mBAYjBG,IAZiB,EAYX;AACV,QAAMX,KAAK,GAAGW,IAAI,CAACG,WAAL,CAAiBb,KAAjB,CAAuB,SAAvB,CAAd;AACA,wBACI,uCACKD,KAAK,CAACe,GAAN,CAAU,UAACnB,IAAD,EAAOoB,KAAP;AAAA,0BACP;AAAgB,QAAA,GAAG,EAAEC,MAAM,CAACD,KAAD;AAA3B,SACKrB,eAAe,CAACC,IAAD,EAAOe,IAAI,CAACd,MAAZ,EAAoBc,IAAI,CAACO,IAAL,CAAUpB,SAA9B,CADpB,CADO;AAAA,KAAV,CADL,CADJ;AASH;AAvBwB,CAA7B;AAyBA,eAAeW,SAAf","sourcesContent":["import React from \"react\";\nimport lodashTrim from \"lodash/trim\";\nimport { I18NDataValues, Modifier, Processor } from \"@webiny/i18n/types\";\n\ndeclare global {\n // eslint-disable-next-line\n namespace JSX {\n interface IntrinsicElements {\n \"i18n-text\": {\n children?: React.ReactNode;\n };\n\n \"i18n-text-part\": {\n key?: string;\n children?: React.ReactNode;\n };\n }\n }\n}\n\nconst processTextPart = (\n part: string,\n values: I18NDataValues,\n modifiers: Record<string, Modifier>\n): string => {\n if (part.startsWith(\"{\") === false) {\n return part;\n }\n\n part = lodashTrim(part, \"{}\");\n\n const parts: string[] = part.split(\"|\");\n\n const [variable, modifier] = parts;\n\n if (!values[variable]) {\n return variable;\n }\n\n let value = values[variable];\n if (modifier) {\n const parameters = modifier.split(\":\");\n const name = parameters.shift();\n if (!name) {\n return value;\n }\n if (modifiers[name]) {\n const modifier = modifiers[name];\n value = modifier.execute(value, parameters);\n }\n }\n\n return value;\n};\n\nconst processor: Processor = {\n name: \"react\",\n canExecute(data) {\n for (const key in data.values) {\n const value = data.values[key];\n if (React.isValidElement(value)) {\n return true;\n }\n }\n\n return false;\n },\n execute(data) {\n const parts = data.translation.split(/({.*?})/);\n return (\n <i18n-text>\n {parts.map((part, index) => (\n <i18n-text-part key={String(index)}>\n {processTextPart(part, data.values, data.i18n.modifiers)}\n </i18n-text-part>\n ))}\n </i18n-text>\n );\n }\n};\nexport default processor;\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@webiny/i18n-react",
3
- "version": "5.24.0",
3
+ "version": "5.25.0-beta.0",
4
4
  "main": "index.js",
5
5
  "repository": {
6
6
  "type": "git",
@@ -14,8 +14,8 @@
14
14
  ],
15
15
  "license": "MIT",
16
16
  "dependencies": {
17
- "@babel/runtime": "7.16.7",
18
- "@webiny/i18n": "5.24.0",
17
+ "@babel/runtime": "7.17.2",
18
+ "@webiny/i18n": "5.25.0-beta.0",
19
19
  "lodash": "4.17.21"
20
20
  },
21
21
  "devDependencies": {
@@ -24,11 +24,11 @@
24
24
  "@babel/preset-env": "^7.16.4",
25
25
  "@babel/preset-react": "^7.16.0",
26
26
  "@babel/preset-typescript": "^7.16.0",
27
- "@webiny/cli": "^5.24.0",
28
- "@webiny/project-utils": "^5.24.0",
27
+ "@webiny/cli": "^5.25.0-beta.0",
28
+ "@webiny/project-utils": "^5.25.0-beta.0",
29
29
  "babel-plugin-lodash": "^3.3.4",
30
30
  "rimraf": "^3.0.2",
31
- "typescript": "^4.1.3"
31
+ "typescript": "4.5.5"
32
32
  },
33
33
  "peerDependencies": {
34
34
  "react": "^16.14.0"
@@ -41,5 +41,5 @@
41
41
  "build": "yarn webiny run build",
42
42
  "watch": "yarn webiny run watch"
43
43
  },
44
- "gitHead": "be0cbfcaa9247c658c44179af7943cc5d6d71bc7"
44
+ "gitHead": "2d3e7833575e88fde77d84e5490e746933a5ec28"
45
45
  }