@tolgee/core 4.9.2 → 4.9.3-rc.ad9d2a4.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.
Files changed (276) hide show
  1. package/dist/tolgee.cjs.js +1127 -7028
  2. package/dist/tolgee.cjs.js.map +1 -1
  3. package/dist/tolgee.cjs.min.js +1 -1
  4. package/dist/tolgee.cjs.min.js.map +1 -1
  5. package/dist/tolgee.esm.min.mjs +1 -1
  6. package/dist/tolgee.esm.min.mjs.map +1 -1
  7. package/dist/tolgee.esm.mjs +1125 -7023
  8. package/dist/tolgee.esm.mjs.map +1 -1
  9. package/dist/tolgee.umd.js +1127 -7028
  10. package/dist/tolgee.umd.js.map +1 -1
  11. package/dist/tolgee.umd.min.js +1 -1
  12. package/dist/tolgee.umd.min.js.map +1 -1
  13. package/lib/Controller/Cache/Cache.d.ts +22 -0
  14. package/lib/Controller/Cache/helpers.d.ts +4 -0
  15. package/lib/Controller/Controller.d.ts +110 -0
  16. package/lib/Controller/Events/EventEmitter.d.ts +6 -0
  17. package/lib/Controller/Events/EventEmitterSelective.d.ts +7 -0
  18. package/lib/Controller/Events/Events.d.ts +14 -0
  19. package/lib/Controller/Plugins/Plugins.d.ts +36 -0
  20. package/lib/Controller/State/State.d.ts +39 -0
  21. package/lib/Controller/State/helpers.d.ts +6 -0
  22. package/lib/Controller/State/initObserverOptions.d.ts +13 -0
  23. package/lib/Controller/State/initState.d.ts +47 -0
  24. package/lib/Controller/ValueObserver.d.ts +5 -0
  25. package/lib/Tolgee.d.ts +2 -68
  26. package/lib/TranslateParams.d.ts +2 -0
  27. package/lib/{Constants/Global.d.ts → constants.d.ts} +1 -2
  28. package/lib/helpers.d.ts +3 -0
  29. package/lib/index.d.ts +3 -8
  30. package/lib/types.d.ts +244 -84
  31. package/package.json +20 -29
  32. package/src/Controller/Cache/Cache.ts +293 -0
  33. package/src/Controller/Cache/helpers.ts +37 -0
  34. package/src/Controller/Controller.ts +310 -0
  35. package/src/Controller/Events/EventEmitter.ts +30 -0
  36. package/src/Controller/Events/EventEmitterSelective.test.ts +125 -0
  37. package/src/Controller/Events/EventEmitterSelective.ts +188 -0
  38. package/src/Controller/Events/Events.ts +66 -0
  39. package/src/Controller/Plugins/Plugins.ts +315 -0
  40. package/src/Controller/State/State.ts +175 -0
  41. package/src/Controller/State/helpers.ts +41 -0
  42. package/src/Controller/State/initObserverOptions.ts +38 -0
  43. package/src/Controller/State/initState.ts +81 -0
  44. package/src/Controller/ValueObserver.ts +26 -0
  45. package/src/Tolgee.ts +79 -330
  46. package/src/TranslateParams.test.ts +41 -0
  47. package/src/TranslateParams.ts +51 -0
  48. package/src/__test/backend.test.ts +48 -0
  49. package/src/__test/cache.test.ts +148 -0
  50. package/src/__test/client.test.ts +48 -0
  51. package/src/__test/events.test.ts +33 -0
  52. package/src/__test/initialization.test.ts +85 -0
  53. package/src/__test/jest-setup.ts +2 -0
  54. package/src/__test/languageDetection.test.ts +129 -0
  55. package/src/__test/languageStorage.test.ts +145 -0
  56. package/src/__test/languages.test.ts +112 -0
  57. package/src/__test/loading.test.ts +39 -0
  58. package/src/__test/namespaces.test.ts +99 -0
  59. package/src/__test/namespacesFallback.test.ts +74 -0
  60. package/src/__test/plugins.test.ts +136 -0
  61. package/src/__test/testTools.ts +7 -0
  62. package/src/{Constants/Global.ts → constants.ts} +1 -3
  63. package/src/helpers.ts +17 -0
  64. package/src/index.ts +9 -8
  65. package/src/types.ts +338 -90
  66. package/README.md +0 -45
  67. package/dist/Constants/Global.d.ts +0 -6
  68. package/dist/Constants/ModifierKey.d.ts +0 -6
  69. package/dist/Errors/ApiHttpError.d.ts +0 -5
  70. package/dist/Observer.d.ts +0 -14
  71. package/dist/Observer.test.d.ts +0 -2
  72. package/dist/Properties.d.ts +0 -17
  73. package/dist/Properties.test.d.ts +0 -1
  74. package/dist/Tolgee.d.ts +0 -68
  75. package/dist/Tolgee.test.d.ts +0 -1
  76. package/dist/TolgeeConfig.d.ts +0 -69
  77. package/dist/TolgeeConfig.test.d.ts +0 -1
  78. package/dist/__integration/FormatterIcu.test.d.ts +0 -1
  79. package/dist/__integration/FormatterMissing.d.ts +0 -1
  80. package/dist/__integration/Tolgee.test.d.ts +0 -1
  81. package/dist/__integration/TolgeeInvisible.test.d.ts +0 -1
  82. package/dist/__integration/mockTranslations.d.ts +0 -7
  83. package/dist/__integration/testConfig.d.ts +0 -9
  84. package/dist/__testFixtures/classMock.d.ts +0 -3
  85. package/dist/__testFixtures/createElement.d.ts +0 -2
  86. package/dist/__testFixtures/createTestDom.d.ts +0 -9
  87. package/dist/__testFixtures/mocked.d.ts +0 -20
  88. package/dist/__testFixtures/setupAfterEnv.d.ts +0 -8
  89. package/dist/helpers/NodeHelper.d.ts +0 -14
  90. package/dist/helpers/TextHelper.d.ts +0 -5
  91. package/dist/helpers/TextHelper.test.d.ts +0 -1
  92. package/dist/helpers/commonTypes.d.ts +0 -2
  93. package/dist/helpers/encoderPolyfill.d.ts +0 -8
  94. package/dist/helpers/secret.d.ts +0 -6
  95. package/dist/helpers/secret.test.d.ts +0 -1
  96. package/dist/helpers/sleep.d.ts +0 -1
  97. package/dist/highlighter/HighlightFunctionsInitializer.d.ts +0 -10
  98. package/dist/highlighter/HighlightFunctionsInitializer.test.d.ts +0 -1
  99. package/dist/highlighter/MouseEventHandler.d.ts +0 -29
  100. package/dist/highlighter/MouseEventHandler.test.d.ts +0 -1
  101. package/dist/highlighter/TranslationHighlighter.d.ts +0 -14
  102. package/dist/highlighter/TranslationHighlighter.test.d.ts +0 -1
  103. package/dist/index.d.ts +0 -10
  104. package/dist/internal.d.ts +0 -2
  105. package/dist/modules/IcuFormatter.d.ts +0 -2
  106. package/dist/modules/IcuFormatter.test.d.ts +0 -1
  107. package/dist/modules/index.d.ts +0 -1
  108. package/dist/services/ApiHttpService.d.ts +0 -15
  109. package/dist/services/CoreService.d.ts +0 -18
  110. package/dist/services/CoreService.test.d.ts +0 -1
  111. package/dist/services/DependencyService.d.ts +0 -39
  112. package/dist/services/DependencyService.test.d.ts +0 -1
  113. package/dist/services/ElementRegistrar.d.ts +0 -19
  114. package/dist/services/ElementRegistrar.test.d.ts +0 -1
  115. package/dist/services/EventEmitter.d.ts +0 -13
  116. package/dist/services/EventService.d.ts +0 -9
  117. package/dist/services/ModuleService.d.ts +0 -5
  118. package/dist/services/ScreenshotService.d.ts +0 -15
  119. package/dist/services/Subscription.d.ts +0 -5
  120. package/dist/services/TextService.d.ts +0 -14
  121. package/dist/services/TextService.test.d.ts +0 -1
  122. package/dist/services/TranslationService.d.ts +0 -75
  123. package/dist/services/TranslationService.test.d.ts +0 -1
  124. package/dist/services/__mocks__/CoreService.d.ts +0 -2
  125. package/dist/toolsManager/Messages.d.ts +0 -8
  126. package/dist/toolsManager/Messages.test.d.ts +0 -1
  127. package/dist/toolsManager/PluginManager.d.ts +0 -21
  128. package/dist/toolsManager/PluginManager.test.d.ts +0 -1
  129. package/dist/types/DTOs.d.ts +0 -20
  130. package/dist/types/apiSchema.generated.d.ts +0 -6185
  131. package/dist/types.d.ts +0 -123
  132. package/dist/wrappers/AbstractWrapper.d.ts +0 -8
  133. package/dist/wrappers/NodeHandler.d.ts +0 -18
  134. package/dist/wrappers/WrappedHandler.d.ts +0 -8
  135. package/dist/wrappers/invisible/AttributeHandler.d.ts +0 -8
  136. package/dist/wrappers/invisible/Coder.d.ts +0 -7
  137. package/dist/wrappers/invisible/ContentHandler.d.ts +0 -6
  138. package/dist/wrappers/invisible/CoreHandler.d.ts +0 -10
  139. package/dist/wrappers/invisible/InvisibleWrapper.d.ts +0 -18
  140. package/dist/wrappers/invisible/ValueMemory.d.ts +0 -5
  141. package/dist/wrappers/invisible/ValueMemory.test.d.ts +0 -1
  142. package/dist/wrappers/text/AttributeHandler.d.ts +0 -8
  143. package/dist/wrappers/text/AttributeHandler.test.d.ts +0 -1
  144. package/dist/wrappers/text/Coder.d.ts +0 -15
  145. package/dist/wrappers/text/Coder.test.d.ts +0 -1
  146. package/dist/wrappers/text/ContentHandler.d.ts +0 -8
  147. package/dist/wrappers/text/ContentHandler.test.d.ts +0 -1
  148. package/dist/wrappers/text/CoreHandler.d.ts +0 -17
  149. package/dist/wrappers/text/CoreHandler.test.d.ts +0 -1
  150. package/dist/wrappers/text/TextWrapper.d.ts +0 -20
  151. package/index.js +0 -7
  152. package/lib/Constants/ModifierKey.d.ts +0 -6
  153. package/lib/Errors/ApiHttpError.d.ts +0 -5
  154. package/lib/Observer.d.ts +0 -14
  155. package/lib/Properties.d.ts +0 -17
  156. package/lib/TolgeeConfig.d.ts +0 -69
  157. package/lib/helpers/NodeHelper.d.ts +0 -14
  158. package/lib/helpers/TextHelper.d.ts +0 -5
  159. package/lib/helpers/commonTypes.d.ts +0 -2
  160. package/lib/helpers/encoderPolyfill.d.ts +0 -8
  161. package/lib/helpers/secret.d.ts +0 -6
  162. package/lib/helpers/sleep.d.ts +0 -1
  163. package/lib/highlighter/HighlightFunctionsInitializer.d.ts +0 -10
  164. package/lib/highlighter/MouseEventHandler.d.ts +0 -29
  165. package/lib/highlighter/TranslationHighlighter.d.ts +0 -14
  166. package/lib/modules/IcuFormatter.d.ts +0 -2
  167. package/lib/modules/index.d.ts +0 -1
  168. package/lib/services/ApiHttpService.d.ts +0 -15
  169. package/lib/services/CoreService.d.ts +0 -18
  170. package/lib/services/DependencyService.d.ts +0 -39
  171. package/lib/services/ElementRegistrar.d.ts +0 -19
  172. package/lib/services/EventEmitter.d.ts +0 -13
  173. package/lib/services/EventService.d.ts +0 -9
  174. package/lib/services/ModuleService.d.ts +0 -5
  175. package/lib/services/ScreenshotService.d.ts +0 -15
  176. package/lib/services/Subscription.d.ts +0 -5
  177. package/lib/services/TextService.d.ts +0 -14
  178. package/lib/services/TranslationService.d.ts +0 -75
  179. package/lib/toolsManager/Messages.d.ts +0 -8
  180. package/lib/toolsManager/PluginManager.d.ts +0 -21
  181. package/lib/types/DTOs.d.ts +0 -20
  182. package/lib/types/apiSchema.generated.d.ts +0 -6185
  183. package/lib/wrappers/AbstractWrapper.d.ts +0 -8
  184. package/lib/wrappers/NodeHandler.d.ts +0 -18
  185. package/lib/wrappers/WrappedHandler.d.ts +0 -8
  186. package/lib/wrappers/invisible/AttributeHandler.d.ts +0 -8
  187. package/lib/wrappers/invisible/Coder.d.ts +0 -7
  188. package/lib/wrappers/invisible/ContentHandler.d.ts +0 -6
  189. package/lib/wrappers/invisible/CoreHandler.d.ts +0 -10
  190. package/lib/wrappers/invisible/InvisibleWrapper.d.ts +0 -18
  191. package/lib/wrappers/invisible/ValueMemory.d.ts +0 -5
  192. package/lib/wrappers/text/AttributeHandler.d.ts +0 -8
  193. package/lib/wrappers/text/Coder.d.ts +0 -15
  194. package/lib/wrappers/text/ContentHandler.d.ts +0 -8
  195. package/lib/wrappers/text/CoreHandler.d.ts +0 -17
  196. package/lib/wrappers/text/TextWrapper.d.ts +0 -20
  197. package/src/Constants/ModifierKey.ts +0 -6
  198. package/src/Errors/ApiHttpError.ts +0 -8
  199. package/src/Observer.test.ts +0 -119
  200. package/src/Observer.ts +0 -68
  201. package/src/Properties.test.ts +0 -150
  202. package/src/Properties.ts +0 -112
  203. package/src/Tolgee.test.ts +0 -473
  204. package/src/TolgeeConfig.test.ts +0 -21
  205. package/src/TolgeeConfig.ts +0 -134
  206. package/src/__integration/FormatterIcu.test.ts +0 -80
  207. package/src/__integration/FormatterMissing.ts +0 -54
  208. package/src/__integration/Tolgee.test.ts +0 -90
  209. package/src/__integration/TolgeeInvisible.test.ts +0 -145
  210. package/src/__integration/mockTranslations.ts +0 -6
  211. package/src/__integration/testConfig.ts +0 -16
  212. package/src/__testFixtures/classMock.ts +0 -11
  213. package/src/__testFixtures/createElement.ts +0 -43
  214. package/src/__testFixtures/createTestDom.ts +0 -26
  215. package/src/__testFixtures/mocked.ts +0 -25
  216. package/src/__testFixtures/setupAfterEnv.ts +0 -34
  217. package/src/helpers/NodeHelper.ts +0 -90
  218. package/src/helpers/TextHelper.test.ts +0 -62
  219. package/src/helpers/TextHelper.ts +0 -58
  220. package/src/helpers/commonTypes.ts +0 -8
  221. package/src/helpers/encoderPolyfill.ts +0 -96
  222. package/src/helpers/secret.test.ts +0 -61
  223. package/src/helpers/secret.ts +0 -68
  224. package/src/helpers/sleep.ts +0 -2
  225. package/src/highlighter/HighlightFunctionsInitializer.test.ts +0 -40
  226. package/src/highlighter/HighlightFunctionsInitializer.ts +0 -61
  227. package/src/highlighter/MouseEventHandler.test.ts +0 -151
  228. package/src/highlighter/MouseEventHandler.ts +0 -191
  229. package/src/highlighter/TranslationHighlighter.test.ts +0 -177
  230. package/src/highlighter/TranslationHighlighter.ts +0 -113
  231. package/src/internal.ts +0 -2
  232. package/src/modules/IcuFormatter.test.ts +0 -21
  233. package/src/modules/IcuFormatter.ts +0 -39
  234. package/src/modules/index.ts +0 -1
  235. package/src/services/ApiHttpService.ts +0 -85
  236. package/src/services/CoreService.test.ts +0 -141
  237. package/src/services/CoreService.ts +0 -76
  238. package/src/services/DependencyService.test.ts +0 -51
  239. package/src/services/DependencyService.ts +0 -116
  240. package/src/services/ElementRegistrar.test.ts +0 -131
  241. package/src/services/ElementRegistrar.ts +0 -108
  242. package/src/services/EventEmitter.ts +0 -52
  243. package/src/services/EventService.ts +0 -14
  244. package/src/services/ModuleService.ts +0 -14
  245. package/src/services/ScreenshotService.ts +0 -31
  246. package/src/services/Subscription.ts +0 -7
  247. package/src/services/TextService.test.ts +0 -88
  248. package/src/services/TextService.ts +0 -82
  249. package/src/services/TranslationService.test.ts +0 -358
  250. package/src/services/TranslationService.ts +0 -417
  251. package/src/services/__mocks__/CoreService.ts +0 -17
  252. package/src/toolsManager/Messages.test.ts +0 -79
  253. package/src/toolsManager/Messages.ts +0 -60
  254. package/src/toolsManager/PluginManager.test.ts +0 -108
  255. package/src/toolsManager/PluginManager.ts +0 -129
  256. package/src/types/DTOs.ts +0 -25
  257. package/src/types/apiSchema.generated.ts +0 -6208
  258. package/src/wrappers/AbstractWrapper.ts +0 -14
  259. package/src/wrappers/NodeHandler.ts +0 -143
  260. package/src/wrappers/WrappedHandler.ts +0 -28
  261. package/src/wrappers/invisible/AttributeHandler.ts +0 -23
  262. package/src/wrappers/invisible/Coder.ts +0 -65
  263. package/src/wrappers/invisible/ContentHandler.ts +0 -15
  264. package/src/wrappers/invisible/CoreHandler.ts +0 -17
  265. package/src/wrappers/invisible/InvisibleWrapper.ts +0 -59
  266. package/src/wrappers/invisible/ValueMemory.test.ts +0 -25
  267. package/src/wrappers/invisible/ValueMemory.ts +0 -16
  268. package/src/wrappers/text/AttributeHandler.test.ts +0 -118
  269. package/src/wrappers/text/AttributeHandler.ts +0 -25
  270. package/src/wrappers/text/Coder.test.ts +0 -298
  271. package/src/wrappers/text/Coder.ts +0 -202
  272. package/src/wrappers/text/ContentHandler.test.ts +0 -185
  273. package/src/wrappers/text/ContentHandler.ts +0 -21
  274. package/src/wrappers/text/CoreHandler.test.ts +0 -106
  275. package/src/wrappers/text/CoreHandler.ts +0 -45
  276. package/src/wrappers/text/TextWrapper.ts +0 -69
package/src/Tolgee.ts CHANGED
@@ -1,335 +1,84 @@
1
- import { TolgeeConfig } from './TolgeeConfig';
1
+ import { Controller } from './Controller/Controller';
2
2
  import {
3
- InstantProps,
4
- InstantPropsTags,
5
- TolgeeModule,
6
- TranslateProps,
7
- TranslatePropsTags,
8
- TranslationTags,
9
- TranslationParams,
10
- TranslationParamsTags,
3
+ Options,
4
+ TolgeeInstance,
5
+ TolgeePlugin,
6
+ ObserverOptions,
11
7
  } from './types';
12
8
 
13
- import { EventEmitterImpl } from './services/EventEmitter';
14
- import { DependencyService } from './services/DependencyService';
15
-
16
- export class Tolgee {
17
- private dependencyService: DependencyService;
18
-
19
- private constructor() {
20
- this.dependencyService = new DependencyService();
21
- }
22
-
23
- get properties() {
24
- return this.dependencyService.properties;
25
- }
26
-
27
- public get lang() {
28
- return this.properties.currentLanguage;
29
- }
30
-
31
- /**
32
- * This sets a new language.
33
- *
34
- * Using this setter can behave buggy when you change languages
35
- * too fast, since it changes the language property before
36
- * translations are actually loaded.
37
- * @deprecated use asynchronous changeLanguage method.
38
- */
39
- public set lang(newLanguage) {
40
- this.properties.currentLanguage = newLanguage;
41
-
42
- this.dependencyService.translationService
43
- .loadTranslations(newLanguage)
44
- .then(() => {
45
- this.emitLangChangeEvent(newLanguage);
46
- });
47
- }
48
-
49
- public get defaultLanguage() {
50
- return this.properties.config.defaultLanguage;
51
- }
52
-
53
- public get onLangChange() {
54
- return this.dependencyService.eventService.LANGUAGE_CHANGED;
55
- }
56
-
57
- public get onTranslationChange() {
58
- return this.dependencyService.eventService.TRANSLATION_CHANGED;
59
- }
60
-
61
- /**
62
- * Is emitted when language is loaded for the first time
63
- */
64
- public get onLangLoaded() {
65
- return this.dependencyService.eventService.LANGUAGE_LOADED;
66
- }
67
-
68
- /**
69
- * True if loading is needed to wait for Tolgee init.
70
- * When translation data are provided statically (using import
71
- * as staticData config property) then there is no need for translation
72
- * fetching so initial loading is not needed at all.
73
- */
74
- get initialLoading(): boolean {
75
- const currentLang = this.properties.currentLanguage;
76
- const fallbackLang = this.properties.config.fallbackLanguage;
77
- const fallbackPreloading = this.properties.config.preloadFallback;
78
- const isStaticDataProvided = (data?: any) => {
79
- return data !== undefined && typeof data !== 'function';
80
- };
81
-
82
- return (
83
- !isStaticDataProvided(this.properties.config.staticData?.[currentLang]) ||
84
- (!!fallbackPreloading &&
85
- !isStaticDataProvided(
86
- this.properties.config.staticData?.[fallbackLang]
87
- ))
88
- );
89
- }
90
-
91
- private get coreService() {
92
- return this.dependencyService.coreService;
93
- }
94
-
95
- static use(module: TolgeeModule) {
96
- return new Tolgee().use(module);
97
- }
98
-
99
- static init(config: TolgeeConfig) {
100
- return new Tolgee().init(config);
101
- }
102
-
103
- /**
104
- * Sets the new language.
105
- *
106
- * Emits the onLangChange and onLangChangeAndLoad events after
107
- * the translations are loaded.
108
- *
109
- * @return Promise<void> Resolves when translations are loaded
110
- */
111
- public async changeLanguage(newLanguage: string): Promise<void> {
112
- await this.dependencyService.translationService.loadTranslations(
113
- newLanguage
114
- );
115
- this.properties.currentLanguage = newLanguage;
116
- this.emitLangChangeEvent(newLanguage);
117
- }
118
-
119
- use(module: TolgeeModule) {
120
- this.dependencyService.moduleService.addModule(module);
121
- return this;
122
- }
123
-
124
- init(config: TolgeeConfig) {
125
- this.dependencyService.init(config);
126
- const { apiKey, apiUrl } = this.dependencyService.properties.config;
127
- this.dependencyService.properties.mode =
128
- apiKey && apiUrl ? 'development' : 'production';
129
-
130
- return this;
131
- }
132
-
133
- public async run(): Promise<void> {
134
- this.dependencyService.run();
135
- if (this.properties.mode === 'development') {
136
- try {
137
- await this.coreService.loadApiKeyDetails();
138
- } catch (e) {
139
- // eslint-disable-next-line no-console
140
- console.error("Couldn't connect to Tolgee");
141
- // eslint-disable-next-line no-console
142
- console.error(e);
143
- this.properties.mode = 'production';
144
- }
145
- }
146
-
147
- await this.dependencyService.translationService.loadTranslations();
148
- await this.dependencyService.pluginManager.run();
149
-
150
- if (this.properties.config.preloadFallback) {
151
- await this.dependencyService.translationService.loadTranslations(
152
- this.properties.config.fallbackLanguage
153
- );
154
- }
155
-
156
- await this.refresh();
157
-
158
- if (this.properties.config.watch) {
159
- this.dependencyService.observer.observe();
160
- }
161
- }
162
-
163
- public async refresh() {
164
- return this.dependencyService.wrapper.handleSubtree(
165
- this.properties.config.targetElement
166
- );
167
- }
168
-
169
- async translate(props: TranslateProps): Promise<string>;
170
- async translate<T>(props: TranslatePropsTags<T>): Promise<TranslationTags<T>>;
171
-
172
- async translate(
173
- key: string,
174
- params?: TranslationParams,
175
- noWrap?: boolean,
176
- defaultValue?: string
177
- ): Promise<string>;
178
- async translate<T>(
179
- key: string,
180
- params?: TranslationParamsTags<T>,
181
- noWrap?: boolean,
182
- defaultValue?: string
183
- ): Promise<TranslationTags<T>>;
184
-
185
- async translate(
186
- keyOrProps: string | TranslatePropsTags<any>,
187
- params: TranslationParamsTags<any> = {},
188
- noWrap = false,
189
- defaultValue: string | undefined = undefined
190
- ): Promise<TranslationTags<any>> {
191
- const key = typeof keyOrProps === 'string' ? keyOrProps : keyOrProps.key;
192
- let orEmpty = undefined;
193
- if (typeof keyOrProps === 'object') {
194
- const props = keyOrProps as TranslateProps;
195
- // if values are not provided in props object, get them from function
196
- // params defaults
197
- params = props.params !== undefined ? props.params : params;
198
- noWrap = props.noWrap !== undefined ? props.noWrap : noWrap;
199
- defaultValue =
200
- props.defaultValue !== undefined ? props.defaultValue : defaultValue;
201
- orEmpty = props.orEmpty;
202
- }
203
-
204
- const translation = await this.dependencyService.textService.translate(
205
- key,
206
- params,
207
- undefined,
208
- orEmpty,
209
- defaultValue
210
- );
211
-
212
- if (this.properties.mode === 'development' && !noWrap) {
213
- await this.coreService.loadApiKeyDetails();
214
- return this.dependencyService.wrapper.wrap(
215
- key,
216
- params,
217
- defaultValue,
218
- translation
219
- );
220
- }
221
-
222
- return translation;
223
- }
224
-
225
- wrap(
226
- key: string,
227
- params?: TranslationParams,
228
- defaultValue?: string | undefined,
229
- translation?: string
230
- ): string;
231
- wrap<T>(
232
- key: string,
233
- params?: TranslationTags<T>,
234
- defaultValue?: string | undefined,
235
- translation?: TranslationTags<T>
236
- ): TranslationTags<T>;
237
-
238
- wrap(
239
- key: string,
240
- params?: any,
241
- defaultValue?: string | undefined,
242
- translation?: TranslationTags<any>
243
- ): TranslationTags<any> {
244
- if (this.properties.mode === 'development') {
245
- return this.dependencyService.wrapper.wrap(
246
- key,
247
- params,
248
- defaultValue,
249
- translation
250
- );
251
- } else {
252
- return translation || defaultValue;
253
- }
254
- }
255
-
256
- instant(
257
- key: string,
258
- params?: TranslationParams,
259
- noWrap?: boolean,
260
- orEmpty?: boolean,
261
- defaultValue?: string
262
- ): string;
263
- instant<T>(
264
- key: string,
265
- params?: TranslationParamsTags<T>,
266
- noWrap?: boolean,
267
- orEmpty?: boolean,
268
- defaultValue?: string
269
- ): TranslationTags<T>;
270
-
271
- instant(props: InstantProps): string;
272
- instant<T>(props: InstantPropsTags<T>): TranslationTags<T>;
273
-
274
- instant(
275
- keyOrProps: string | InstantPropsTags<any>,
276
- params: TranslationParams = {},
277
- noWrap = false,
278
- orEmpty?: boolean,
279
- defaultValue?: string
280
- ) {
281
- const key = typeof keyOrProps === 'string' ? keyOrProps : keyOrProps.key;
282
- if (typeof keyOrProps === 'object') {
283
- const props = keyOrProps as InstantProps;
284
- // if values are not provided in props object, get them from function
285
- // params defaults
286
- params = props.params !== undefined ? props.params : params;
287
- noWrap = props.noWrap !== undefined ? props.noWrap : noWrap;
288
- defaultValue =
289
- props.defaultValue !== undefined ? props.defaultValue : defaultValue;
290
- orEmpty = props.orEmpty !== undefined ? props.orEmpty : orEmpty;
291
- }
292
-
293
- const translation = this.dependencyService.textService.instant(
294
- key,
295
- params,
296
- undefined,
297
- orEmpty,
298
- defaultValue
299
- );
300
-
301
- if (this.properties.mode === 'development' && !noWrap) {
302
- return this.dependencyService.wrapper.wrap(
303
- key,
304
- params,
305
- defaultValue,
306
- translation
307
- );
308
- }
309
- return translation;
310
- }
311
-
312
- /**
313
- * Get currently cached translations for all languages
314
- */
315
- public getCachedTranslations() {
316
- return this.dependencyService.translationService.getCachedTranslations();
317
- }
318
-
319
- /**
320
- * Loads translations for given language or returns them from cache
321
- * @returns Loaded translations
322
- */
323
- public loadTranslations(lang: string) {
324
- return this.dependencyService.translationService.loadTranslations(lang);
325
- }
326
-
327
- public stop = () => {
328
- this.dependencyService.stop();
9
+ export const Tolgee = (options?: Partial<Options>): TolgeeInstance => {
10
+ const controller = Controller({
11
+ options,
12
+ });
13
+
14
+ const pluginTools = Object.freeze({
15
+ setFinalFormatter: controller.setFinalFormatter,
16
+ addFormatter: controller.addFormatter,
17
+ setObserver: controller.setObserver,
18
+ hasObserver: controller.hasObserver,
19
+ setUi: controller.setUi,
20
+ hasUi: controller.hasUi,
21
+ setDevBackend: controller.setDevBackend,
22
+ addBackend: controller.addBackend,
23
+ setLanguageDetector: controller.setLanguageDetector,
24
+ setLanguageStorage: controller.setLanguageStorage,
25
+ overrideCredentials: controller.overrideCredentials,
26
+ });
27
+
28
+ const withRestart = (callback: () => void) => {
29
+ const wasRunning = controller.isRunning();
30
+ wasRunning && controller.stop();
31
+ callback();
32
+ wasRunning && controller.run();
329
33
  };
330
34
 
331
- private emitLangChangeEvent(value: string) {
332
- const langChangedEmitter = this.onLangChange as EventEmitterImpl<any>;
333
- langChangedEmitter.emit(value);
334
- }
335
- }
35
+ const tolgee: TolgeeInstance = Object.freeze({
36
+ // event listeners
37
+ on: controller.on,
38
+ onKeyUpdate: controller.onKeyUpdate.listenSome,
39
+
40
+ // state
41
+ getLanguage: controller.getLanguage,
42
+ getPendingLanguage: controller.getPendingLanguage,
43
+ changeLanguage: controller.changeLanguage,
44
+ changeTranslation: controller.changeTranslation,
45
+ addActiveNs: controller.addActiveNs,
46
+ removeActiveNs: controller.removeActiveNs,
47
+ loadRecords: controller.loadRecords,
48
+ loadRecord: controller.loadRecord,
49
+ addStaticData: controller.addStaticData,
50
+ getRecord: controller.getRecord,
51
+ getAllRecords: controller.getAllRecords,
52
+ isLoaded: controller.isLoaded,
53
+ isInitialLoading: controller.isInitialLoading,
54
+ isLoading: controller.isLoading,
55
+ isFetching: controller.isFetching,
56
+ isRunning: controller.isRunning,
57
+ run: controller.run,
58
+ stop: controller.stop,
59
+ t: controller.t,
60
+ highlight: controller.highlight,
61
+ getInitialOptions: controller.getInitialOptions,
62
+ isDev: controller.isDev,
63
+ wrap: controller.wrap,
64
+ unwrap: controller.unwrap,
65
+
66
+ // plugins
67
+ setObserverOptions: (options: Partial<ObserverOptions>) => {
68
+ controller.setObserverOptions(options);
69
+ return tolgee;
70
+ },
71
+ use: (plugin: TolgeePlugin | undefined) => {
72
+ if (plugin) {
73
+ withRestart(() => plugin(tolgee, pluginTools));
74
+ }
75
+ return tolgee;
76
+ },
77
+ init: (options: Partial<Options>) => {
78
+ withRestart(() => controller.init(options));
79
+ return tolgee;
80
+ },
81
+ });
82
+
83
+ return tolgee;
84
+ };
@@ -0,0 +1,41 @@
1
+ import { getTranslateParams } from './TranslateParams';
2
+ import { TranslateProps } from './types';
3
+
4
+ const testParams: TranslateProps = {
5
+ key: 'test',
6
+ defaultValue: 'Test',
7
+ noWrap: true,
8
+ ns: [],
9
+ orEmpty: true,
10
+ params: { yo: 'yo', ns: '(this is param not namespace)' },
11
+ };
12
+
13
+ describe('getTranslateParams', () => {
14
+ it('manages regular params', () => {
15
+ const result = getTranslateParams(testParams);
16
+ expect(result).toEqual(testParams);
17
+ });
18
+
19
+ it('manages key with default value', () => {
20
+ const result = getTranslateParams('test', 'Test');
21
+ expect(result).toEqual({ key: 'test', defaultValue: 'Test' });
22
+ });
23
+
24
+ it('manages key with options', () => {
25
+ const result = getTranslateParams('test', { noWrap: true, yo: 'yo' });
26
+ expect(result).toEqual({ key: 'test', noWrap: true, params: { yo: 'yo' } });
27
+ });
28
+
29
+ it('manages key default and options', () => {
30
+ const result = getTranslateParams('test', 'Test', {
31
+ noWrap: true,
32
+ ns: [],
33
+ orEmpty: true,
34
+ yo: 'yo',
35
+ params: {
36
+ ns: '(this is param not namespace)',
37
+ },
38
+ });
39
+ expect(result).toEqual(testParams);
40
+ });
41
+ });
@@ -0,0 +1,51 @@
1
+ import {
2
+ CombinedOptions,
3
+ TFnType,
4
+ TranslateOptions,
5
+ TranslateProps,
6
+ } from './types';
7
+
8
+ function parseCombinedOptions({
9
+ ns,
10
+ noWrap,
11
+ orEmpty,
12
+ params,
13
+ ...rest
14
+ }: CombinedOptions<any>): Partial<TranslateProps> {
15
+ const options: Required<TranslateOptions<any>> = {
16
+ ns: ns!,
17
+ noWrap: noWrap!,
18
+ orEmpty: orEmpty!,
19
+ params: {
20
+ ...rest,
21
+ ...params,
22
+ },
23
+ };
24
+ return options;
25
+ }
26
+
27
+ export const getTranslateParams: TFnType<any, TranslateProps<any>> = (
28
+ keyOrProps,
29
+ ...params
30
+ ) => {
31
+ let result = {} as TranslateProps<any>;
32
+ let options: CombinedOptions<any> | undefined;
33
+ if (typeof keyOrProps === 'object') {
34
+ result = keyOrProps;
35
+ } else {
36
+ result.key = keyOrProps;
37
+ if (typeof params[0] === 'string') {
38
+ result.defaultValue = params[0];
39
+ options = params[1] as CombinedOptions<any>;
40
+ } else if (typeof params[0] === 'object') {
41
+ options = params[0] as CombinedOptions<any>;
42
+ }
43
+ }
44
+ if (options) {
45
+ result = {
46
+ ...parseCombinedOptions(options),
47
+ ...result,
48
+ };
49
+ }
50
+ return result;
51
+ };
@@ -0,0 +1,48 @@
1
+ import { Tolgee } from '../Tolgee';
2
+ import { BackendInterface, TolgeePlugin } from '../types';
3
+
4
+ const data = {
5
+ en: {
6
+ common: { cancel: 'Cancel' },
7
+ test: { test: 'Test' },
8
+ },
9
+ es: {
10
+ common: { cancel: 'Cancellar' },
11
+ test: { test: 'Testar' },
12
+ },
13
+ } as any;
14
+
15
+ const backendNormal: BackendInterface = {
16
+ getRecord({ language, namespace = '' }) {
17
+ return data[language]?.[namespace];
18
+ },
19
+ };
20
+
21
+ const backendDev: BackendInterface = {
22
+ getRecord() {
23
+ return Promise.resolve({ cancel: 'Dev' });
24
+ },
25
+ };
26
+
27
+ const backendPlugin: TolgeePlugin = (tolgee, tools) => {
28
+ tools.addBackend(backendNormal);
29
+ tools.setDevBackend(backendDev);
30
+ return tolgee;
31
+ };
32
+
33
+ describe('backend plugins', () => {
34
+ it('uses plugin to fetch', async () => {
35
+ const tolgee = Tolgee()
36
+ .use(backendPlugin)
37
+ .init({
38
+ ns: ['common', 'test'],
39
+ language: 'en',
40
+ });
41
+ await tolgee.run();
42
+ expect(tolgee.t({ key: 'cancel', ns: 'common' })).toEqual('Cancel');
43
+ tolgee.stop();
44
+ tolgee.init({ apiUrl: 'asdfasdf', apiKey: 'test' });
45
+ await tolgee.run();
46
+ expect(tolgee.t({ key: 'cancel', ns: 'common' })).toEqual('Dev');
47
+ });
48
+ });
@@ -0,0 +1,148 @@
1
+ import { Tolgee } from '../Tolgee';
2
+ import { TolgeeInstance, TolgeePlugin, TreeTranslationsData } from '../types';
3
+ import { resolvablePromise } from './testTools';
4
+
5
+ const waitForInitialLoad = (tolgee: TolgeeInstance) =>
6
+ new Promise<void>((resolve) => {
7
+ const { unsubscribe } = tolgee.on('initialLoad', () => {
8
+ unsubscribe();
9
+ resolve();
10
+ });
11
+ });
12
+
13
+ const DevToolsPlugin =
14
+ (postfix = ''): TolgeePlugin =>
15
+ (tolgee, tools) => {
16
+ tolgee.init({ apiKey: 'test', apiUrl: 'test' });
17
+ tools.setDevBackend({
18
+ getRecord({ language, namespace }) {
19
+ return Promise.resolve({
20
+ test: { sub: `${language}.${namespace || 'default'}${postfix}` },
21
+ });
22
+ },
23
+ });
24
+ return tolgee;
25
+ };
26
+
27
+ describe('cache', () => {
28
+ let tolgee: TolgeeInstance;
29
+
30
+ beforeEach(async () => {
31
+ tolgee = Tolgee({
32
+ language: 'en',
33
+ staticData: {
34
+ en: { test: { sub: 'subtestEn' } },
35
+ cs: { 'test.sub': 'subtestCs' },
36
+ },
37
+ });
38
+ });
39
+
40
+ afterEach(() => {
41
+ tolgee.stop();
42
+ });
43
+
44
+ it('stores initial data correctly', async () => {
45
+ expect(tolgee.t('test.sub')).toEqual('subtestEn');
46
+ await tolgee.changeLanguage('cs');
47
+ expect(tolgee.t('test.sub')).toEqual('subtestCs');
48
+ });
49
+
50
+ it('ignores empty values', async () => {
51
+ tolgee.addStaticData({
52
+ en: { sub: { test: 'Test', null: null, undefined: undefined } },
53
+ });
54
+ expect(tolgee.t('sub.test')).toEqual('Test');
55
+ expect(tolgee.t('sub.null')).toEqual('sub.null');
56
+ expect(tolgee.t('sub.undefined')).toEqual('sub.undefined');
57
+ });
58
+
59
+ it('returns correct data when in dev mode', async () => {
60
+ expect(tolgee.t('test.sub')).toEqual('subtestEn');
61
+ tolgee.use(DevToolsPlugin());
62
+ await tolgee.run();
63
+ expect(tolgee.t('test.sub')).toEqual('en.default');
64
+ const changeLangPromise = tolgee.changeLanguage('cs');
65
+ expect(tolgee.t('test.sub')).toEqual('en.default');
66
+ await changeLangPromise;
67
+ expect(tolgee.t('test.sub')).toEqual('cs.default');
68
+ });
69
+
70
+ it('invalidates the cache when switching to dev', async () => {
71
+ await tolgee.run();
72
+ expect(tolgee.t('test.sub')).toEqual('subtestEn');
73
+ tolgee.use(DevToolsPlugin());
74
+ expect(tolgee.t('test.sub')).toEqual('subtestEn');
75
+
76
+ await new Promise<void>((resolve) => {
77
+ const { unsubscribe } = tolgee.on('initialLoad', async () => {
78
+ expect(tolgee.t('test.sub')).toEqual('en.default');
79
+ unsubscribe();
80
+ resolve();
81
+ });
82
+ });
83
+ });
84
+
85
+ it('works with switching to different dev backend', async () => {
86
+ tolgee.use(DevToolsPlugin());
87
+ await tolgee.run();
88
+ expect(tolgee.t('test.sub')).toEqual('en.default');
89
+ tolgee.use(DevToolsPlugin('.new'));
90
+ expect(tolgee.t('test.sub')).toEqual('en.default');
91
+
92
+ await waitForInitialLoad(tolgee);
93
+ expect(tolgee.t('test.sub')).toEqual('en.default.new');
94
+ });
95
+
96
+ it('updates initial data correctly', async () => {
97
+ await tolgee.run();
98
+ expect(tolgee.t('test.sub')).toEqual('subtestEn');
99
+ tolgee.addStaticData({ en: { test: { sub: 'newSubtestEn' } } });
100
+ expect(tolgee.t('test.sub')).toEqual('newSubtestEn');
101
+ });
102
+
103
+ it('ignores new initial data when already in dev mode', async () => {
104
+ tolgee.use(DevToolsPlugin());
105
+ await tolgee.run();
106
+ expect(tolgee.t('test.sub')).toEqual('en.default');
107
+ tolgee.addStaticData({ en: { test: { sub: 'newSubtestEn' } } });
108
+ expect(tolgee.t('test.sub')).toEqual('en.default');
109
+ });
110
+
111
+ it('gets all records', async () => {
112
+ await tolgee.run();
113
+ expect(tolgee.getAllRecords().length).toEqual(2);
114
+ });
115
+
116
+ it('fetching works with namespaces', async () => {
117
+ tolgee.use(DevToolsPlugin());
118
+ const runPromise = tolgee.run();
119
+ expect(tolgee.isFetching()).toBeTruthy();
120
+ await runPromise;
121
+ expect(tolgee.t('test.sub', { ns: 'common' })).toEqual('test.sub');
122
+ const nsPromise = tolgee.addActiveNs('common');
123
+ expect(tolgee.isFetching()).toBeTruthy();
124
+ expect(tolgee.isFetching('common')).toBeTruthy();
125
+ expect(tolgee.isFetching('nonexistant')).toBeFalsy();
126
+ await nsPromise;
127
+ expect(tolgee.t('test.sub', { ns: 'common' })).toEqual('en.common');
128
+ expect(tolgee.isFetching()).toBeFalsy();
129
+ });
130
+
131
+ it("pending requests won't rewrite cache when reinitialized", async () => {
132
+ const [promiseEn, resolveEn] = resolvablePromise<TreeTranslationsData>();
133
+ tolgee = Tolgee({
134
+ language: 'en',
135
+ staticData: {
136
+ en: () => promiseEn,
137
+ },
138
+ });
139
+ tolgee.run();
140
+ await Promise.resolve();
141
+ tolgee.use(DevToolsPlugin());
142
+ await waitForInitialLoad(tolgee);
143
+ expect(tolgee.t('test.sub')).toEqual('en.default');
144
+ resolveEn({ test: { sub: 'Invalid' } });
145
+ await Promise.resolve();
146
+ expect(tolgee.t('test.sub')).toEqual('en.default');
147
+ });
148
+ });