@tolgee/core 4.9.2 → 4.10.0-rc.14ca700.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 (274) hide show
  1. package/dist/tolgee.cjs.js +1075 -7022
  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 +1073 -7017
  8. package/dist/tolgee.esm.mjs.map +1 -1
  9. package/dist/tolgee.umd.js +1075 -7022
  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 +137 -0
  16. package/lib/Controller/Events/EventEmitter.d.ts +6 -0
  17. package/lib/Controller/Events/EventEmitterSelective.d.ts +15 -0
  18. package/lib/Controller/Events/Events.d.ts +50 -0
  19. package/lib/Controller/Plugins/Plugins.d.ts +43 -0
  20. package/lib/Controller/State/State.d.ts +21 -0
  21. package/lib/Controller/State/helpers.d.ts +6 -0
  22. package/lib/Controller/State/initState.d.ts +55 -0
  23. package/lib/Controller/ValueObserver.d.ts +5 -0
  24. package/lib/Tolgee.d.ts +2 -68
  25. package/lib/TranslateParams.d.ts +2 -0
  26. package/lib/{Constants/Global.d.ts → constants.d.ts} +1 -2
  27. package/lib/helpers.d.ts +3 -0
  28. package/lib/index.d.ts +3 -8
  29. package/lib/types.d.ts +235 -84
  30. package/package.json +20 -29
  31. package/src/Controller/Cache/Cache.ts +293 -0
  32. package/src/Controller/Cache/helpers.ts +37 -0
  33. package/src/Controller/Controller.ts +307 -0
  34. package/src/Controller/Events/EventEmitter.ts +27 -0
  35. package/src/Controller/Events/EventEmitterSelective.test.ts +125 -0
  36. package/src/Controller/Events/EventEmitterSelective.ts +179 -0
  37. package/src/Controller/Events/Events.ts +66 -0
  38. package/src/Controller/Plugins/Plugins.ts +305 -0
  39. package/src/Controller/State/State.ts +156 -0
  40. package/src/Controller/State/helpers.ts +41 -0
  41. package/src/Controller/State/initState.ts +90 -0
  42. package/src/Controller/ValueObserver.ts +23 -0
  43. package/src/Tolgee.ts +72 -333
  44. package/src/TranslateParams.test.ts +41 -0
  45. package/src/TranslateParams.ts +51 -0
  46. package/src/__test/backend.test.ts +48 -0
  47. package/src/__test/cache.test.ts +148 -0
  48. package/src/__test/client.test.ts +48 -0
  49. package/src/__test/events.test.ts +33 -0
  50. package/src/__test/initialization.test.ts +73 -0
  51. package/src/__test/jest-setup.ts +2 -0
  52. package/src/__test/languageDetection.test.ts +129 -0
  53. package/src/__test/languageStorage.test.ts +145 -0
  54. package/src/__test/languages.test.ts +112 -0
  55. package/src/__test/loading.test.ts +39 -0
  56. package/src/__test/namespaces.test.ts +99 -0
  57. package/src/__test/namespacesFallback.test.ts +74 -0
  58. package/src/__test/plugins.test.ts +98 -0
  59. package/src/__test/testTools.ts +7 -0
  60. package/src/{Constants/Global.ts → constants.ts} +1 -3
  61. package/src/helpers.ts +17 -0
  62. package/src/index.ts +9 -8
  63. package/src/types.ts +322 -90
  64. package/README.md +0 -45
  65. package/dist/Constants/Global.d.ts +0 -6
  66. package/dist/Constants/ModifierKey.d.ts +0 -6
  67. package/dist/Errors/ApiHttpError.d.ts +0 -5
  68. package/dist/Observer.d.ts +0 -14
  69. package/dist/Observer.test.d.ts +0 -2
  70. package/dist/Properties.d.ts +0 -17
  71. package/dist/Properties.test.d.ts +0 -1
  72. package/dist/Tolgee.d.ts +0 -68
  73. package/dist/Tolgee.test.d.ts +0 -1
  74. package/dist/TolgeeConfig.d.ts +0 -69
  75. package/dist/TolgeeConfig.test.d.ts +0 -1
  76. package/dist/__integration/FormatterIcu.test.d.ts +0 -1
  77. package/dist/__integration/FormatterMissing.d.ts +0 -1
  78. package/dist/__integration/Tolgee.test.d.ts +0 -1
  79. package/dist/__integration/TolgeeInvisible.test.d.ts +0 -1
  80. package/dist/__integration/mockTranslations.d.ts +0 -7
  81. package/dist/__integration/testConfig.d.ts +0 -9
  82. package/dist/__testFixtures/classMock.d.ts +0 -3
  83. package/dist/__testFixtures/createElement.d.ts +0 -2
  84. package/dist/__testFixtures/createTestDom.d.ts +0 -9
  85. package/dist/__testFixtures/mocked.d.ts +0 -20
  86. package/dist/__testFixtures/setupAfterEnv.d.ts +0 -8
  87. package/dist/helpers/NodeHelper.d.ts +0 -14
  88. package/dist/helpers/TextHelper.d.ts +0 -5
  89. package/dist/helpers/TextHelper.test.d.ts +0 -1
  90. package/dist/helpers/commonTypes.d.ts +0 -2
  91. package/dist/helpers/encoderPolyfill.d.ts +0 -8
  92. package/dist/helpers/secret.d.ts +0 -6
  93. package/dist/helpers/secret.test.d.ts +0 -1
  94. package/dist/helpers/sleep.d.ts +0 -1
  95. package/dist/highlighter/HighlightFunctionsInitializer.d.ts +0 -10
  96. package/dist/highlighter/HighlightFunctionsInitializer.test.d.ts +0 -1
  97. package/dist/highlighter/MouseEventHandler.d.ts +0 -29
  98. package/dist/highlighter/MouseEventHandler.test.d.ts +0 -1
  99. package/dist/highlighter/TranslationHighlighter.d.ts +0 -14
  100. package/dist/highlighter/TranslationHighlighter.test.d.ts +0 -1
  101. package/dist/index.d.ts +0 -10
  102. package/dist/internal.d.ts +0 -2
  103. package/dist/modules/IcuFormatter.d.ts +0 -2
  104. package/dist/modules/IcuFormatter.test.d.ts +0 -1
  105. package/dist/modules/index.d.ts +0 -1
  106. package/dist/services/ApiHttpService.d.ts +0 -15
  107. package/dist/services/CoreService.d.ts +0 -18
  108. package/dist/services/CoreService.test.d.ts +0 -1
  109. package/dist/services/DependencyService.d.ts +0 -39
  110. package/dist/services/DependencyService.test.d.ts +0 -1
  111. package/dist/services/ElementRegistrar.d.ts +0 -19
  112. package/dist/services/ElementRegistrar.test.d.ts +0 -1
  113. package/dist/services/EventEmitter.d.ts +0 -13
  114. package/dist/services/EventService.d.ts +0 -9
  115. package/dist/services/ModuleService.d.ts +0 -5
  116. package/dist/services/ScreenshotService.d.ts +0 -15
  117. package/dist/services/Subscription.d.ts +0 -5
  118. package/dist/services/TextService.d.ts +0 -14
  119. package/dist/services/TextService.test.d.ts +0 -1
  120. package/dist/services/TranslationService.d.ts +0 -75
  121. package/dist/services/TranslationService.test.d.ts +0 -1
  122. package/dist/services/__mocks__/CoreService.d.ts +0 -2
  123. package/dist/toolsManager/Messages.d.ts +0 -8
  124. package/dist/toolsManager/Messages.test.d.ts +0 -1
  125. package/dist/toolsManager/PluginManager.d.ts +0 -21
  126. package/dist/toolsManager/PluginManager.test.d.ts +0 -1
  127. package/dist/types/DTOs.d.ts +0 -20
  128. package/dist/types/apiSchema.generated.d.ts +0 -6185
  129. package/dist/types.d.ts +0 -123
  130. package/dist/wrappers/AbstractWrapper.d.ts +0 -8
  131. package/dist/wrappers/NodeHandler.d.ts +0 -18
  132. package/dist/wrappers/WrappedHandler.d.ts +0 -8
  133. package/dist/wrappers/invisible/AttributeHandler.d.ts +0 -8
  134. package/dist/wrappers/invisible/Coder.d.ts +0 -7
  135. package/dist/wrappers/invisible/ContentHandler.d.ts +0 -6
  136. package/dist/wrappers/invisible/CoreHandler.d.ts +0 -10
  137. package/dist/wrappers/invisible/InvisibleWrapper.d.ts +0 -18
  138. package/dist/wrappers/invisible/ValueMemory.d.ts +0 -5
  139. package/dist/wrappers/invisible/ValueMemory.test.d.ts +0 -1
  140. package/dist/wrappers/text/AttributeHandler.d.ts +0 -8
  141. package/dist/wrappers/text/AttributeHandler.test.d.ts +0 -1
  142. package/dist/wrappers/text/Coder.d.ts +0 -15
  143. package/dist/wrappers/text/Coder.test.d.ts +0 -1
  144. package/dist/wrappers/text/ContentHandler.d.ts +0 -8
  145. package/dist/wrappers/text/ContentHandler.test.d.ts +0 -1
  146. package/dist/wrappers/text/CoreHandler.d.ts +0 -17
  147. package/dist/wrappers/text/CoreHandler.test.d.ts +0 -1
  148. package/dist/wrappers/text/TextWrapper.d.ts +0 -20
  149. package/index.js +0 -7
  150. package/lib/Constants/ModifierKey.d.ts +0 -6
  151. package/lib/Errors/ApiHttpError.d.ts +0 -5
  152. package/lib/Observer.d.ts +0 -14
  153. package/lib/Properties.d.ts +0 -17
  154. package/lib/TolgeeConfig.d.ts +0 -69
  155. package/lib/helpers/NodeHelper.d.ts +0 -14
  156. package/lib/helpers/TextHelper.d.ts +0 -5
  157. package/lib/helpers/commonTypes.d.ts +0 -2
  158. package/lib/helpers/encoderPolyfill.d.ts +0 -8
  159. package/lib/helpers/secret.d.ts +0 -6
  160. package/lib/helpers/sleep.d.ts +0 -1
  161. package/lib/highlighter/HighlightFunctionsInitializer.d.ts +0 -10
  162. package/lib/highlighter/MouseEventHandler.d.ts +0 -29
  163. package/lib/highlighter/TranslationHighlighter.d.ts +0 -14
  164. package/lib/modules/IcuFormatter.d.ts +0 -2
  165. package/lib/modules/index.d.ts +0 -1
  166. package/lib/services/ApiHttpService.d.ts +0 -15
  167. package/lib/services/CoreService.d.ts +0 -18
  168. package/lib/services/DependencyService.d.ts +0 -39
  169. package/lib/services/ElementRegistrar.d.ts +0 -19
  170. package/lib/services/EventEmitter.d.ts +0 -13
  171. package/lib/services/EventService.d.ts +0 -9
  172. package/lib/services/ModuleService.d.ts +0 -5
  173. package/lib/services/ScreenshotService.d.ts +0 -15
  174. package/lib/services/Subscription.d.ts +0 -5
  175. package/lib/services/TextService.d.ts +0 -14
  176. package/lib/services/TranslationService.d.ts +0 -75
  177. package/lib/toolsManager/Messages.d.ts +0 -8
  178. package/lib/toolsManager/PluginManager.d.ts +0 -21
  179. package/lib/types/DTOs.d.ts +0 -20
  180. package/lib/types/apiSchema.generated.d.ts +0 -6185
  181. package/lib/wrappers/AbstractWrapper.d.ts +0 -8
  182. package/lib/wrappers/NodeHandler.d.ts +0 -18
  183. package/lib/wrappers/WrappedHandler.d.ts +0 -8
  184. package/lib/wrappers/invisible/AttributeHandler.d.ts +0 -8
  185. package/lib/wrappers/invisible/Coder.d.ts +0 -7
  186. package/lib/wrappers/invisible/ContentHandler.d.ts +0 -6
  187. package/lib/wrappers/invisible/CoreHandler.d.ts +0 -10
  188. package/lib/wrappers/invisible/InvisibleWrapper.d.ts +0 -18
  189. package/lib/wrappers/invisible/ValueMemory.d.ts +0 -5
  190. package/lib/wrappers/text/AttributeHandler.d.ts +0 -8
  191. package/lib/wrappers/text/Coder.d.ts +0 -15
  192. package/lib/wrappers/text/ContentHandler.d.ts +0 -8
  193. package/lib/wrappers/text/CoreHandler.d.ts +0 -17
  194. package/lib/wrappers/text/TextWrapper.d.ts +0 -20
  195. package/src/Constants/ModifierKey.ts +0 -6
  196. package/src/Errors/ApiHttpError.ts +0 -8
  197. package/src/Observer.test.ts +0 -119
  198. package/src/Observer.ts +0 -68
  199. package/src/Properties.test.ts +0 -150
  200. package/src/Properties.ts +0 -112
  201. package/src/Tolgee.test.ts +0 -473
  202. package/src/TolgeeConfig.test.ts +0 -21
  203. package/src/TolgeeConfig.ts +0 -134
  204. package/src/__integration/FormatterIcu.test.ts +0 -80
  205. package/src/__integration/FormatterMissing.ts +0 -54
  206. package/src/__integration/Tolgee.test.ts +0 -90
  207. package/src/__integration/TolgeeInvisible.test.ts +0 -145
  208. package/src/__integration/mockTranslations.ts +0 -6
  209. package/src/__integration/testConfig.ts +0 -16
  210. package/src/__testFixtures/classMock.ts +0 -11
  211. package/src/__testFixtures/createElement.ts +0 -43
  212. package/src/__testFixtures/createTestDom.ts +0 -26
  213. package/src/__testFixtures/mocked.ts +0 -25
  214. package/src/__testFixtures/setupAfterEnv.ts +0 -34
  215. package/src/helpers/NodeHelper.ts +0 -90
  216. package/src/helpers/TextHelper.test.ts +0 -62
  217. package/src/helpers/TextHelper.ts +0 -58
  218. package/src/helpers/commonTypes.ts +0 -8
  219. package/src/helpers/encoderPolyfill.ts +0 -96
  220. package/src/helpers/secret.test.ts +0 -61
  221. package/src/helpers/secret.ts +0 -68
  222. package/src/helpers/sleep.ts +0 -2
  223. package/src/highlighter/HighlightFunctionsInitializer.test.ts +0 -40
  224. package/src/highlighter/HighlightFunctionsInitializer.ts +0 -61
  225. package/src/highlighter/MouseEventHandler.test.ts +0 -151
  226. package/src/highlighter/MouseEventHandler.ts +0 -191
  227. package/src/highlighter/TranslationHighlighter.test.ts +0 -177
  228. package/src/highlighter/TranslationHighlighter.ts +0 -113
  229. package/src/internal.ts +0 -2
  230. package/src/modules/IcuFormatter.test.ts +0 -21
  231. package/src/modules/IcuFormatter.ts +0 -39
  232. package/src/modules/index.ts +0 -1
  233. package/src/services/ApiHttpService.ts +0 -85
  234. package/src/services/CoreService.test.ts +0 -141
  235. package/src/services/CoreService.ts +0 -76
  236. package/src/services/DependencyService.test.ts +0 -51
  237. package/src/services/DependencyService.ts +0 -116
  238. package/src/services/ElementRegistrar.test.ts +0 -131
  239. package/src/services/ElementRegistrar.ts +0 -108
  240. package/src/services/EventEmitter.ts +0 -52
  241. package/src/services/EventService.ts +0 -14
  242. package/src/services/ModuleService.ts +0 -14
  243. package/src/services/ScreenshotService.ts +0 -31
  244. package/src/services/Subscription.ts +0 -7
  245. package/src/services/TextService.test.ts +0 -88
  246. package/src/services/TextService.ts +0 -82
  247. package/src/services/TranslationService.test.ts +0 -358
  248. package/src/services/TranslationService.ts +0 -417
  249. package/src/services/__mocks__/CoreService.ts +0 -17
  250. package/src/toolsManager/Messages.test.ts +0 -79
  251. package/src/toolsManager/Messages.ts +0 -60
  252. package/src/toolsManager/PluginManager.test.ts +0 -108
  253. package/src/toolsManager/PluginManager.ts +0 -129
  254. package/src/types/DTOs.ts +0 -25
  255. package/src/types/apiSchema.generated.ts +0 -6208
  256. package/src/wrappers/AbstractWrapper.ts +0 -14
  257. package/src/wrappers/NodeHandler.ts +0 -143
  258. package/src/wrappers/WrappedHandler.ts +0 -28
  259. package/src/wrappers/invisible/AttributeHandler.ts +0 -23
  260. package/src/wrappers/invisible/Coder.ts +0 -65
  261. package/src/wrappers/invisible/ContentHandler.ts +0 -15
  262. package/src/wrappers/invisible/CoreHandler.ts +0 -17
  263. package/src/wrappers/invisible/InvisibleWrapper.ts +0 -59
  264. package/src/wrappers/invisible/ValueMemory.test.ts +0 -25
  265. package/src/wrappers/invisible/ValueMemory.ts +0 -16
  266. package/src/wrappers/text/AttributeHandler.test.ts +0 -118
  267. package/src/wrappers/text/AttributeHandler.ts +0 -25
  268. package/src/wrappers/text/Coder.test.ts +0 -298
  269. package/src/wrappers/text/Coder.ts +0 -202
  270. package/src/wrappers/text/ContentHandler.test.ts +0 -185
  271. package/src/wrappers/text/ContentHandler.ts +0 -21
  272. package/src/wrappers/text/CoreHandler.test.ts +0 -106
  273. package/src/wrappers/text/CoreHandler.ts +0 -45
  274. package/src/wrappers/text/TextWrapper.ts +0 -69
@@ -1,473 +0,0 @@
1
- jest.dontMock('./Tolgee');
2
- jest.dontMock('./services/DependencyService');
3
-
4
- import '@testing-library/jest-dom/extend-expect';
5
- import { mocked } from 'jest-mock';
6
- import { Tolgee } from './Tolgee';
7
- import {
8
- configMock,
9
- coreServiceMock,
10
- eventServiceMock,
11
- getMockedInstance,
12
- observerMock,
13
- propertiesMock,
14
- textServiceMock,
15
- translationServiceMock,
16
- } from '@testFixtures/mocked';
17
- import { EventEmitterImpl } from './services/EventEmitter';
18
- import { TextService } from './services/TextService';
19
- import { TextWrapper } from './wrappers/text/TextWrapper';
20
- import { ElementRegistrar } from './services/ElementRegistrar';
21
- import { NodeHelper } from './helpers/NodeHelper';
22
- import { TOLGEE_TARGET_ATTRIBUTE } from './Constants/Global';
23
- import { Properties } from './Properties';
24
- import { waitFor } from '@testing-library/dom';
25
- import { Translations } from './types';
26
-
27
- describe('Tolgee', () => {
28
- let tolgee: Tolgee;
29
-
30
- beforeEach(() => {
31
- jest.clearAllMocks();
32
- tolgee = Tolgee.init({});
33
- });
34
-
35
- test('can be created', () => {
36
- expect(tolgee).not.toBeNull();
37
- });
38
-
39
- test('returns proper default language', () => {
40
- configMock.mock.instances[0].defaultLanguage = 'testDefaultLanguage';
41
- expect(configMock).toBeCalledTimes(1);
42
- expect(tolgee.defaultLanguage).toEqual('testDefaultLanguage');
43
- });
44
-
45
- test('returns proper language', () => {
46
- propertiesMock.mock.instances[0].currentLanguage = 'currentLang';
47
- expect(tolgee.lang).toEqual('currentLang');
48
- });
49
-
50
- test('will load api key details', async () => {
51
- propertiesMock.mock.instances[0].mode = 'development';
52
- await tolgee.run();
53
- expect(
54
- coreServiceMock.mock.instances[0].loadApiKeyDetails
55
- ).toHaveBeenCalledTimes(1);
56
- expect(
57
- coreServiceMock.mock.instances[0].loadApiKeyDetails
58
- ).toHaveBeenCalledWith();
59
- });
60
-
61
- test('will not set properties.scopes on run in production mode', async () => {
62
- propertiesMock.mock.instances[0].mode = 'production';
63
- await tolgee.run();
64
- expect(coreServiceMock.mock.instances[0].getApiKeyDetails).toBeCalledTimes(
65
- 0
66
- );
67
- expect(propertiesMock.mock.instances[0].scopes).toBeUndefined();
68
- });
69
-
70
- test('will run the observer when watch is on', async () => {
71
- propertiesMock.mock.instances[0].config.watch = true;
72
- await tolgee.run();
73
- expect(observerMock.mock.instances[0].observe).toBeCalledTimes(1);
74
- });
75
-
76
- test('will not the observer when watch is off', async () => {
77
- propertiesMock.mock.instances[0].config.watch = false;
78
- await tolgee.run();
79
- expect(observerMock.mock.instances[0].observe).toBeCalledTimes(0);
80
- });
81
-
82
- test('will try to get translations with current language from properties', async () => {
83
- propertiesMock.mock.instances[0].currentLanguage = 'dummyLang';
84
- await tolgee.run();
85
- expect(
86
- translationServiceMock.mock.instances[0].loadTranslations
87
- ).toBeCalledWith();
88
- });
89
-
90
- test('will try to get translations with current language from properties', async () => {
91
- propertiesMock.mock.instances[0].currentLanguage = 'dummyLang';
92
- propertiesMock.mock.instances[0].config.preloadFallback = true;
93
- propertiesMock.mock.instances[0].config.fallbackLanguage = 'fallbackLang';
94
- await tolgee.run();
95
- expect(
96
- translationServiceMock.mock.instances[0].loadTranslations
97
- ).toBeCalledWith();
98
- expect(
99
- translationServiceMock.mock.instances[0].loadTranslations
100
- ).toBeCalledWith('fallbackLang');
101
- });
102
-
103
- test('will refresh translations using observer on run', async () => {
104
- const htmlElement = document.createElement('dummyElement');
105
- propertiesMock.mock.instances[0].config.targetElement = htmlElement;
106
- await tolgee.run();
107
- expect(getMockedInstance(TextWrapper).handleSubtree).toBeCalledWith(
108
- htmlElement
109
- );
110
- });
111
-
112
- test('will refresh translations using observer on refresh', async () => {
113
- const htmlElement = document.createElement('dummyElement');
114
- propertiesMock.mock.instances[0].config.targetElement = htmlElement;
115
- await tolgee.run();
116
- await tolgee.refresh();
117
- expect(getMockedInstance(TextWrapper).handleSubtree).toBeCalledWith(
118
- htmlElement
119
- );
120
- });
121
-
122
- test('will get defaultLanguage from config', async () => {
123
- propertiesMock.mock.instances[0].config.defaultLanguage = 'dummyLang';
124
- expect(tolgee.defaultLanguage).toEqual('dummyLang');
125
- });
126
-
127
- describe('translation functions', () => {
128
- const translatedDummyText = 'translatedDummyText';
129
- const wrappedDummyText = 'wrappedDummyText';
130
- const dummyKey = 'dummyText';
131
- let mockedTranslate;
132
- let mockedInstant;
133
- let mockedWrap;
134
- let mockedLoadTranslations;
135
- const dummyParams = {};
136
-
137
- beforeEach(() => {
138
- tolgee.run();
139
- mockedTranslate = mocked(textServiceMock.mock.instances[0].translate);
140
- mockedInstant = mocked(textServiceMock.mock.instances[0].instant);
141
- mockedWrap = getMockedInstance(TextWrapper).wrap;
142
- mockedLoadTranslations = mocked(
143
- translationServiceMock.mock.instances[0].loadTranslations
144
- );
145
- mockedTranslate.mockImplementation(async () => translatedDummyText);
146
- mockedInstant.mockImplementation(() => translatedDummyText);
147
- mockedWrap.mockImplementation(() => wrappedDummyText);
148
- });
149
-
150
- describe('async translate', () => {
151
- test('will return wrapped string from text service in development mode', async () => {
152
- propertiesMock.mock.instances[0].mode = 'development';
153
- const translated = await tolgee.translate(dummyKey, dummyParams);
154
-
155
- expect(mockedWrap).toBeCalledWith(
156
- dummyKey,
157
- dummyParams,
158
- undefined,
159
- 'translatedDummyText'
160
- );
161
- expect(translated).toEqual(wrappedDummyText);
162
- });
163
-
164
- test('will return translated string from text service in production mode', async () => {
165
- propertiesMock.mock.instances[0].mode = 'production';
166
- const translated = await tolgee.translate(dummyKey, dummyParams);
167
-
168
- expect(translated).toEqual(translatedDummyText);
169
- expect(mockedWrap).not.toBeCalled();
170
- expect(mockedTranslate).toBeCalledWith(
171
- dummyKey,
172
- dummyParams,
173
- undefined,
174
- undefined,
175
- undefined
176
- );
177
- });
178
-
179
- test('will not wrap when development is on, but noWrap is true', async () => {
180
- propertiesMock.mock.instances[0].mode = 'development';
181
- const translated = await tolgee.translate(dummyKey, dummyParams, true);
182
-
183
- expect(mockedWrap).not.toBeCalled();
184
- expect(translated).toEqual(translatedDummyText);
185
- });
186
-
187
- test('will wait for translations load before wrapping', async () => {
188
- propertiesMock.mock.instances[0].mode = 'development';
189
- await tolgee.translate(dummyKey, dummyParams);
190
- expect(mockedLoadTranslations).toBeCalled();
191
- });
192
-
193
- test('passes default value to wrap fn', async () => {
194
- propertiesMock.mock.instances[0].mode = 'development';
195
- await tolgee.translate(dummyKey, dummyParams, false, 'Default');
196
- expect(mockedWrap).toBeCalledWith(
197
- 'dummyText',
198
- {},
199
- 'Default',
200
- 'translatedDummyText'
201
- );
202
- });
203
-
204
- test('passes default value to translate fn', async () => {
205
- propertiesMock.mock.instances[0].mode = 'development';
206
- await tolgee.translate(dummyKey, dummyParams, true, 'Default');
207
- expect(mockedTranslate).toBeCalledWith(
208
- 'dummyText',
209
- {},
210
- undefined,
211
- undefined,
212
- 'Default'
213
- );
214
- });
215
-
216
- test('props object works correctly', async () => {
217
- propertiesMock.mock.instances[0].mode = 'development';
218
- await tolgee.translate({
219
- key: dummyKey,
220
- params: dummyParams,
221
- noWrap: true,
222
- defaultValue: 'Default',
223
- });
224
- expect(mockedTranslate).toBeCalledWith(
225
- dummyKey,
226
- dummyParams,
227
- undefined,
228
- undefined,
229
- 'Default'
230
- );
231
- });
232
-
233
- test('passes orEmpty correctly', async () => {
234
- propertiesMock.mock.instances[0].mode = 'development';
235
- await tolgee.translate({
236
- key: dummyKey,
237
- params: dummyParams,
238
- noWrap: true,
239
- orEmpty: true,
240
- });
241
- expect(mockedTranslate).toBeCalledWith(
242
- dummyKey,
243
- dummyParams,
244
- undefined,
245
- true,
246
- undefined
247
- );
248
- });
249
- });
250
-
251
- describe('sync instant', () => {
252
- test('will return wrapped string from text service in development mode', async () => {
253
- propertiesMock.mock.instances[0].mode = 'development';
254
- const dummyParams = {};
255
- const translated = tolgee.instant(dummyKey, dummyParams);
256
-
257
- expect(mockedWrap).toBeCalledWith(
258
- dummyKey,
259
- dummyParams,
260
- undefined,
261
- 'translatedDummyText'
262
- );
263
- expect(translated).toEqual(wrappedDummyText);
264
- });
265
-
266
- test('will return translated string from text service in production mode', async () => {
267
- propertiesMock.mock.instances[0].mode = 'production';
268
- const translated = tolgee.instant(dummyKey, dummyParams);
269
-
270
- expect(translated).toEqual(translatedDummyText);
271
- expect(mockedWrap).not.toBeCalled();
272
- expect(mockedInstant).toBeCalledWith(
273
- dummyKey,
274
- dummyParams,
275
- undefined,
276
- undefined,
277
- undefined
278
- );
279
- });
280
-
281
- test('will pass noEmpty parameter', () => {
282
- tolgee.instant(dummyKey, dummyParams, undefined, true);
283
- expect(mockedInstant).toBeCalledWith(
284
- dummyKey,
285
- dummyParams,
286
- undefined,
287
- true,
288
- undefined
289
- );
290
- });
291
-
292
- test('will not wrap when development is on, but noWrap is true', async () => {
293
- propertiesMock.mock.instances[0].mode = 'development';
294
- const translated = tolgee.instant(dummyKey, dummyParams, true);
295
-
296
- expect(mockedWrap).not.toBeCalled();
297
- expect(translated).toEqual(translatedDummyText);
298
- });
299
-
300
- test('will call instant with orEmpty true', async () => {
301
- tolgee.instant(dummyKey, dummyParams, true, true);
302
- expect(getMockedInstance(TextService).instant).toBeCalledWith(
303
- dummyKey,
304
- dummyParams,
305
- undefined,
306
- true,
307
- undefined
308
- );
309
- });
310
-
311
- test('passes default value to wrap fn', async () => {
312
- propertiesMock.mock.instances[0].mode = 'development';
313
- const dummyParams = {};
314
- tolgee.instant(dummyKey, dummyParams, false, false, 'Default');
315
-
316
- expect(mockedWrap).toBeCalledWith(
317
- dummyKey,
318
- dummyParams,
319
- 'Default',
320
- 'translatedDummyText'
321
- );
322
- });
323
-
324
- test('props object works correctly', async () => {
325
- propertiesMock.mock.instances[0].mode = 'development';
326
- await tolgee.instant({
327
- key: dummyKey,
328
- params: dummyParams,
329
- orEmpty: false,
330
- noWrap: true,
331
- defaultValue: 'Default',
332
- });
333
- expect(mockedInstant).toBeCalledWith(
334
- dummyKey,
335
- dummyParams,
336
- undefined,
337
- false,
338
- 'Default'
339
- );
340
- });
341
- });
342
-
343
- test('passes default value to instant fn', async () => {
344
- propertiesMock.mock.instances[0].mode = 'development';
345
- const dummyParams = {};
346
- tolgee.instant(dummyKey, dummyParams, true, false, 'Default');
347
-
348
- expect(mockedInstant).toBeCalledWith(
349
- dummyKey,
350
- dummyParams,
351
- undefined,
352
- false,
353
- 'Default'
354
- );
355
- });
356
- });
357
-
358
- test('will stop on stop function', () => {
359
- getMockedInstance(Properties).config.targetElement = document.body;
360
- NodeHelper.markElementAsTargetElement(document.body);
361
- tolgee.run();
362
- tolgee.stop();
363
- expect(getMockedInstance(ElementRegistrar).cleanAll).toBeCalledTimes(1);
364
- expect(observerMock.mock.instances[0].stopObserving).toBeCalledTimes(1);
365
- expect(document.body).not.toHaveAttribute(TOLGEE_TARGET_ATTRIBUTE);
366
- });
367
-
368
- test('will return proper onLangChange emitter', () => {
369
- const eventEmitter = new EventEmitterImpl();
370
- (eventServiceMock.mock.instances[0] as any).LANGUAGE_CHANGED = eventEmitter;
371
- expect(tolgee.onLangChange).toEqual(eventEmitter);
372
- });
373
-
374
- test('will return proper initialLoading', () => {
375
- tolgee.properties.mode = 'production';
376
- tolgee.properties.config.preloadFallback = true;
377
- tolgee.properties.currentLanguage = 'cs';
378
- tolgee.properties.config.staticData = {
379
- cs: {},
380
- };
381
- expect(tolgee.initialLoading).toEqual(true);
382
- tolgee.properties.config.fallbackLanguage = 'en';
383
- tolgee.properties.config.preloadFallback = false;
384
- expect(tolgee.initialLoading).toEqual(false);
385
- tolgee.properties.config.preloadFallback = true;
386
- tolgee.properties.config.staticData.en = {};
387
- expect(tolgee.initialLoading).toEqual(false);
388
- tolgee.properties.mode = 'development';
389
- expect(tolgee.initialLoading).toEqual(false);
390
- });
391
-
392
- describe('lang setter', () => {
393
- const dummyLang = 'dummyLang';
394
- let loadTranslationsResolve: (value: Translations) => void;
395
- let languageChangedEmitter;
396
-
397
- beforeEach(() => {
398
- languageChangedEmitter = (
399
- eventServiceMock.mock.instances[0] as any
400
- ).LANGUAGE_CHANGED = {
401
- emit: jest.fn(),
402
- };
403
-
404
- translationServiceMock.mock.instances[0].loadTranslations = jest.fn(
405
- async () =>
406
- new Promise((resolve) => {
407
- loadTranslationsResolve = resolve;
408
- })
409
- );
410
- tolgee.lang = dummyLang;
411
- });
412
-
413
- test('will change the language', () => {
414
- expect(propertiesMock.mock.instances[0].currentLanguage).toEqual(
415
- dummyLang
416
- );
417
- });
418
-
419
- test('emits the changed event', async () => {
420
- expect(languageChangedEmitter.emit).toBeCalledTimes(0);
421
- loadTranslationsResolve({});
422
- await waitFor(() => {
423
- expect(languageChangedEmitter.emit).toBeCalledTimes(1);
424
- expect(languageChangedEmitter.emit).toBeCalledWith(dummyLang);
425
- });
426
- });
427
- });
428
-
429
- describe('changeLanguage method', () => {
430
- const dummyLang = 'dummyLang';
431
- let loadTranslationsResolve: (value: Translations) => void;
432
- let languageChanged;
433
- let changeLanguagePromise: Promise<void>;
434
-
435
- beforeEach(() => {
436
- languageChanged = (
437
- eventServiceMock.mock.instances[0] as any
438
- ).LANGUAGE_CHANGED = {
439
- emit: jest.fn(),
440
- };
441
-
442
- translationServiceMock.mock.instances[0].loadTranslations = jest.fn(
443
- async () =>
444
- new Promise((resolve) => {
445
- loadTranslationsResolve = resolve;
446
- })
447
- );
448
- changeLanguagePromise = tolgee.changeLanguage(dummyLang);
449
- });
450
-
451
- test('will change the language', (done) => {
452
- expect(propertiesMock.mock.instances[0].currentLanguage).not.toEqual(
453
- dummyLang
454
- );
455
- changeLanguagePromise.then(() => {
456
- expect(propertiesMock.mock.instances[0].currentLanguage).toEqual(
457
- dummyLang
458
- );
459
- done();
460
- });
461
- loadTranslationsResolve({});
462
- });
463
-
464
- test('emits the change and loaded event', (done) => {
465
- expect(languageChanged.emit).toBeCalledTimes(0);
466
- changeLanguagePromise.then(() => {
467
- expect(languageChanged.emit).toBeCalledTimes(1);
468
- done();
469
- });
470
- loadTranslationsResolve({});
471
- });
472
- });
473
- });
@@ -1,21 +0,0 @@
1
- jest.dontMock('./TolgeeConfig');
2
-
3
- import { TolgeeConfig } from './TolgeeConfig';
4
-
5
- describe('TolgeeConfig', () => {
6
- test('will be created with default targetElement', () => {
7
- const tolgeeConfig = new TolgeeConfig();
8
- expect(tolgeeConfig.targetElement).toEqual(document.body);
9
- });
10
-
11
- test('will be created with provided targetElement', () => {
12
- const div = document.createElement('div');
13
- const tolgeeConfig = new TolgeeConfig({ targetElement: div });
14
- expect(tolgeeConfig.targetElement).toEqual(div);
15
- });
16
-
17
- test('will be created with default when empty object', () => {
18
- const tolgeeConfig = new TolgeeConfig({});
19
- expect(tolgeeConfig.targetElement).toEqual(document.body);
20
- });
21
- });
@@ -1,134 +0,0 @@
1
- import { TreeTranslationsData } from './types';
2
- import { NodeHelper } from './helpers/NodeHelper';
3
- import { ModifierKey } from './Constants/ModifierKey';
4
- import { Mode } from 'fs';
5
-
6
- const API_KEY_LOCAL_STORAGE = '__tolgee_apiKey';
7
- const API_URL_LOCAL_STORAGE = '__tolgee_apiUrl';
8
-
9
- const DEFAULT_TARGET_ELEMENT_SUPPLIER = () => {
10
- if (typeof document !== 'undefined') {
11
- return document.body;
12
- }
13
- };
14
-
15
- type UiConstructor = new (...args) => any;
16
-
17
- interface UiLibInterface {
18
- UI: UiConstructor;
19
- }
20
-
21
- type UiType =
22
- | UiConstructor
23
- | UiLibInterface
24
- | Promise<UiConstructor>
25
- | Promise<UiLibInterface>;
26
-
27
- export class TolgeeConfig {
28
- /**
29
- * @deprecated This option won't have any effect,
30
- * because mode is now automatically detected when apiKey + apiUrl are set
31
- */
32
- mode?: Mode;
33
- apiUrl?: string;
34
- apiKey?: string;
35
- inputPrefix?: string = '%-%tolgee:';
36
- inputSuffix?: string = '%-%';
37
- /**
38
- * Overrides all language settings
39
- */
40
- forceLanguage?: string;
41
- /**
42
- * Used when auto detection is not available or is turned off
43
- */
44
- defaultLanguage?: string = 'en';
45
- /**
46
- * Languages which can be used for language detection
47
- * and also limits which values can be stored
48
- */
49
- availableLanguages?: string[];
50
- /**
51
- * Language which is used when no translation is available for current one
52
- */
53
- fallbackLanguage?: string;
54
- /**
55
- * Store user language in localStorage (default: true)
56
- */
57
- enableLanguageStore?: boolean = true;
58
- /**
59
- * Use auto language detection by browser locale (default: true)
60
- */
61
- enableLanguageDetection?: boolean = true;
62
- filesUrlPrefix?: string = 'i18n/';
63
- watch?: boolean;
64
- ui?: UiType;
65
- targetElement?: Element;
66
- tagAttributes?: { [key: string]: string[] } = {
67
- textarea: ['placeholder'],
68
- input: ['value', 'placeholder'],
69
- img: ['alt'],
70
- '*': ['aria-label', 'title'],
71
- };
72
- highlightKeys?: ModifierKey[] = [ModifierKey.Alt];
73
- passToParent?:
74
- | (keyof HTMLElementTagNameMap)[]
75
- | ((node: Element) => boolean) = ['option', 'optgroup'];
76
- restrictedElements?: string[] = ['script', 'style'];
77
- highlightColor?: string = 'rgb(255, 0, 0)';
78
- highlightWidth?: number = 5;
79
- /** localization data to use in production mode */
80
- staticData?: {
81
- [key: string]: TreeTranslationsData | (() => Promise<TreeTranslationsData>);
82
- };
83
- wrapperMode?: 'text' | 'invisible' = 'text';
84
-
85
- /**
86
- * When true, fallback language will be preloaded on Tolgee.run
87
- */
88
- preloadFallback?: boolean = false;
89
- private _targetElement?: Element;
90
-
91
- constructor(config?: TolgeeConfig) {
92
- //workaround for: https://stackoverflow.com/questions/48725916/typescript-optional-property-with-a-getter
93
- Object.defineProperty(this, 'targetElement', {
94
- set(targetElement: Element) {
95
- if (this.targetElement !== undefined) {
96
- throw new Error('Target element is already defined!');
97
- }
98
- if (targetElement === undefined) {
99
- this._targetElement = DEFAULT_TARGET_ELEMENT_SUPPLIER();
100
- }
101
- if (NodeHelper.isElementTargetElement(targetElement)) {
102
- // eslint-disable-next-line no-console
103
- console.error('Target element: ', this._targetElement);
104
- throw new Error(
105
- 'An tolgee instance is inited with provided target element'
106
- );
107
- }
108
- this._targetElement = targetElement;
109
- NodeHelper.markElementAsTargetElement(this._targetElement);
110
- },
111
- get() {
112
- return this._targetElement;
113
- },
114
- });
115
-
116
- Object.assign(this, config || {});
117
- if (typeof sessionStorage !== 'undefined') {
118
- this.apiUrl =
119
- sessionStorage.getItem(API_URL_LOCAL_STORAGE) || this.apiUrl;
120
- this.apiKey =
121
- sessionStorage.getItem(API_KEY_LOCAL_STORAGE) || this.apiKey;
122
- }
123
- if (this._targetElement === undefined) {
124
- this._targetElement = DEFAULT_TARGET_ELEMENT_SUPPLIER();
125
- }
126
- this.fallbackLanguage = this.fallbackLanguage || this.defaultLanguage;
127
- if (this.watch === undefined) {
128
- this.watch = Boolean(this.apiKey && this.apiUrl);
129
- }
130
- if (this.availableLanguages === undefined && this.staticData) {
131
- this.availableLanguages = Object.keys(this.staticData);
132
- }
133
- }
134
- }
@@ -1,80 +0,0 @@
1
- jest.autoMockOff();
2
-
3
- import '@testing-library/jest-dom/extend-expect';
4
- import { IcuFormatter, Tolgee } from '../index';
5
- import mockTranslations from './mockTranslations';
6
- import fetchMock from 'jest-fetch-mock';
7
- import { testConfig } from './testConfig';
8
-
9
- const API_URL = 'http://localhost';
10
- const API_KEY = 'dummyApiKey';
11
-
12
- const fetch = fetchMock.mockResponse(async (req) => {
13
- if (req.url.includes('/v2/api-keys/current')) {
14
- return JSON.stringify(testConfig);
15
- } else if (req.url.includes('/v2/projects/translations/en')) {
16
- return JSON.stringify(mockTranslations);
17
- }
18
- throw new Error('Invalid request');
19
- });
20
-
21
- describe('Tolgee with icu formatter', () => {
22
- let tolgee: Tolgee;
23
- beforeEach(async () => {
24
- fetch.enableMocks();
25
- tolgee = Tolgee.use(IcuFormatter).init({
26
- targetElement: document.body,
27
- apiKey: API_KEY,
28
- apiUrl: API_URL,
29
- inputPrefix: '{{',
30
- inputSuffix: '}}',
31
- watch: false,
32
- });
33
- document.body.innerHTML = '';
34
- await tolgee.run();
35
- });
36
-
37
- afterEach(() => {
38
- tolgee.stop();
39
- });
40
-
41
- it('Formats variable', async () => {
42
- const translation = await tolgee.translate(
43
- 'peter_dogs',
44
- { dogsCount: '10' },
45
- true
46
- );
47
- expect(translation).toEqual('Peter has 10 dogs.');
48
-
49
- const instantTranslation = tolgee.instant(
50
- 'peter_dogs',
51
- { dogsCount: '10' },
52
- true
53
- );
54
- expect(instantTranslation).toEqual('Peter has 10 dogs.');
55
- });
56
-
57
- it('Wont format key', async () => {
58
- const translation = await tolgee.translate(
59
- 'weird {key}',
60
- { key: '10' },
61
- true
62
- );
63
- expect(translation).toEqual('weird {key}');
64
-
65
- const instantTranslation = tolgee.instant(
66
- 'weird {key}',
67
- { key: '10' },
68
- true
69
- );
70
- expect(instantTranslation).toEqual('weird {key}');
71
- });
72
-
73
- it('Returns key if missing', async () => {
74
- const translation = await tolgee.translate('nonexistant', undefined, true);
75
- expect(translation).toEqual('nonexistant');
76
-
77
- const instantTranslation = tolgee.instant('nonexistant', undefined, true);
78
- expect(instantTranslation).toEqual('nonexistant');
79
- });
80
- });