@tolgee/core 4.9.2 → 4.9.3-rc.d287ae9.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 +146 -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 +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 +27 -0
  36. package/src/Controller/Events/EventEmitterSelective.test.ts +125 -0
  37. package/src/Controller/Events/EventEmitterSelective.ts +179 -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 +23 -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
@@ -1,51 +0,0 @@
1
- jest.dontMock('./DependencyService');
2
- jest.dontMock('../TolgeeConfig');
3
-
4
- import { getMockedInstance } from '@testFixtures/mocked';
5
- import { mocked } from 'jest-mock';
6
- import { InvisibleWrapper } from '../wrappers/invisible/InvisibleWrapper';
7
- import { TextWrapper } from '../wrappers/text/TextWrapper';
8
- import { DependencyService } from './DependencyService';
9
-
10
- describe('DependecyStore', () => {
11
- let dependecyService: DependencyService;
12
-
13
- const config = {
14
- apiKey: 'yep',
15
- };
16
-
17
- beforeEach(async () => {
18
- dependecyService = new DependencyService();
19
- });
20
-
21
- afterEach(async () => {
22
- jest.clearAllMocks();
23
- });
24
-
25
- it('inits translation service', () => {
26
- dependecyService.init(config);
27
- dependecyService.run();
28
- expect(
29
- mocked(dependecyService.translationService).initStatic
30
- ).toBeCalledTimes(1);
31
- });
32
-
33
- it('sets config to properties', () => {
34
- dependecyService.init(config);
35
- expect(dependecyService.properties.config.apiKey).toEqual(config.apiKey);
36
- });
37
-
38
- it('inits text wrapper', () => {
39
- dependecyService.init(config);
40
- dependecyService.run();
41
- expect(dependecyService.wrapper).toEqual(getMockedInstance(TextWrapper));
42
- });
43
-
44
- it('inits invisible wrapper', () => {
45
- dependecyService.init({ ...config, wrapperMode: 'invisible' });
46
- dependecyService.run();
47
- expect(dependecyService.wrapper).toEqual(
48
- getMockedInstance(InvisibleWrapper)
49
- );
50
- });
51
- });
@@ -1,116 +0,0 @@
1
- import { Properties } from '../Properties';
2
- import { EventService } from './EventService';
3
- import { ApiHttpService } from './ApiHttpService';
4
- import { TranslationService } from './TranslationService';
5
- import { TextService } from './TextService';
6
- import { MouseEventHandler } from '../highlighter/MouseEventHandler';
7
- import { TranslationHighlighter } from '../highlighter/TranslationHighlighter';
8
- import { ElementRegistrar } from './ElementRegistrar';
9
- import { Observer } from '../Observer';
10
- import { CoreService } from './CoreService';
11
- import { TolgeeConfig } from '../TolgeeConfig';
12
- import { PluginManager } from '../toolsManager/PluginManager';
13
- import { Messages } from '../toolsManager/Messages';
14
- import { HighlightFunctionsInitializer } from '../highlighter/HighlightFunctionsInitializer';
15
- import { ScreenshotService } from './ScreenshotService';
16
- import { ModuleService } from './ModuleService';
17
- import { TextWrapper } from '../wrappers/text/TextWrapper';
18
- import { NodeHelper } from '../helpers/NodeHelper';
19
- import { AbstractWrapper } from '../wrappers/AbstractWrapper';
20
- import { InvisibleWrapper } from '../wrappers/invisible/InvisibleWrapper';
21
-
22
- export class DependencyService {
23
- public properties: Properties = new Properties();
24
- public eventService: EventService = new EventService();
25
- public apiHttpService: ApiHttpService = new ApiHttpService(this.properties);
26
- public mouseEventHandler = new MouseEventHandler(this);
27
- public moduleService = new ModuleService();
28
- public coreService: CoreService = new CoreService(
29
- this.properties,
30
- this.apiHttpService
31
- );
32
- public screenshotService = new ScreenshotService(
33
- this.coreService,
34
- this.apiHttpService
35
- );
36
- public translationService: TranslationService = new TranslationService(
37
- this.properties,
38
- this.coreService,
39
- this.apiHttpService,
40
- this.eventService
41
- );
42
- public textService: TextService = new TextService(
43
- this.properties,
44
- this.translationService,
45
- this.moduleService
46
- );
47
-
48
- public highlightFunctionInitializer = new HighlightFunctionsInitializer(
49
- this.properties
50
- );
51
-
52
- public translationHighlighter = new TranslationHighlighter(this);
53
-
54
- public elementRegistrar: ElementRegistrar = new ElementRegistrar(
55
- this.properties,
56
- this.translationHighlighter,
57
- this.eventService
58
- );
59
-
60
- public messages: Messages = new Messages();
61
-
62
- public pluginManager: PluginManager = new PluginManager(
63
- this.messages,
64
- this.properties,
65
- this.eventService,
66
- this.elementRegistrar,
67
- this.translationService
68
- );
69
-
70
- constructor() {
71
- this.translationHighlighter.pluginManager = this.pluginManager;
72
- }
73
-
74
- public wrapper: AbstractWrapper;
75
- public observer: Observer;
76
-
77
- init(config: TolgeeConfig) {
78
- if (this.properties.config) {
79
- throw new Error('Duplicate initialization of config');
80
- }
81
- this.properties.config = new TolgeeConfig(config);
82
- if (this.properties.config.wrapperMode === 'invisible') {
83
- this.wrapper = new InvisibleWrapper(
84
- this.properties,
85
- this.elementRegistrar
86
- );
87
- } else {
88
- this.wrapper = new TextWrapper(
89
- this.eventService,
90
- this.properties,
91
- this.textService,
92
- this.elementRegistrar
93
- );
94
- }
95
-
96
- this.observer = new Observer(
97
- this.properties,
98
- this.wrapper,
99
- this.elementRegistrar
100
- );
101
- this.translationService.initStatic();
102
- }
103
-
104
- run = () => {
105
- this.mouseEventHandler.run();
106
- };
107
-
108
- stop = () => {
109
- this.observer.stopObserving();
110
- this.elementRegistrar.cleanAll();
111
- this.mouseEventHandler.stop();
112
- NodeHelper.unmarkElementAsTargetElement(
113
- this.properties.config.targetElement
114
- );
115
- };
116
- }
@@ -1,131 +0,0 @@
1
- jest.dontMock('./ElementRegistrar');
2
- jest.dontMock('./DependencyService');
3
-
4
- import '@testing-library/jest-dom/extend-expect';
5
- import { ElementRegistrar } from './ElementRegistrar';
6
- import { ElementWithMeta } from '../types';
7
- import { getMockedInstance } from '@testFixtures/mocked';
8
- import { TranslationHighlighter } from '../highlighter/TranslationHighlighter';
9
- import { createElement } from '@testFixtures/createElement';
10
- import { Properties } from '../Properties';
11
- import { TOLGEE_ATTRIBUTE_NAME } from '../Constants/Global';
12
- import { DependencyService } from './DependencyService';
13
- import { EventEmitterImpl } from './EventEmitter';
14
- import { EventService } from './EventService';
15
-
16
- describe('ElementRegistrar', () => {
17
- let elementRegistrar: ElementRegistrar;
18
- const mockElementRegisteredEmit = jest.fn();
19
-
20
- beforeEach(async () => {
21
- const dependencyStore = new DependencyService();
22
- dependencyStore.init({});
23
- elementRegistrar = dependencyStore.elementRegistrar;
24
- (getMockedInstance(EventService).ELEMENT_REGISTERED as any) = {
25
- emit: mockElementRegisteredEmit,
26
- } as any as EventEmitterImpl<ElementWithMeta>;
27
- getMockedInstance(Properties).config.targetElement = document.body;
28
- });
29
-
30
- afterEach(async () => {
31
- jest.clearAllMocks();
32
- });
33
-
34
- describe('In development mode', () => {
35
- const element = createElement(1, 1);
36
-
37
- beforeEach(async () => {
38
- getMockedInstance(Properties).mode = 'development';
39
- document.body.append(element);
40
- await elementRegistrar.register(element);
41
- });
42
-
43
- test('will be registered for highlighting in development mode', () => {
44
- expect(getMockedInstance(TranslationHighlighter).listen).toBeCalledWith(
45
- element
46
- );
47
- expect(getMockedInstance(TranslationHighlighter).listen).toBeCalledTimes(
48
- 1
49
- );
50
- });
51
-
52
- test('will emit element registered event', () => {
53
- expect(mockElementRegisteredEmit).toBeCalledTimes(1);
54
- expect(mockElementRegisteredEmit).toBeCalledWith(element);
55
- });
56
- });
57
-
58
- test('throws error on register element without any node', async () => {
59
- const element = createElement(0, 0);
60
- getMockedInstance(Properties).mode = 'development';
61
- document.body.append(element);
62
- elementRegistrar.register(element);
63
- expect((elementRegistrar as any).registeredElements).toBeInstanceOf(Set);
64
- expect((elementRegistrar as any).registeredElements).not.toContain(element);
65
- });
66
-
67
- describe('register, clean & refresh methods', () => {
68
- let mockedElements: ElementWithMeta[];
69
- beforeEach(() => {
70
- mockedElements = [
71
- createElement(5, 0),
72
- createElement(1, 0),
73
- createElement(3, 0),
74
- ];
75
- document.body.append(...mockedElements);
76
- mockedElements.forEach((e) => elementRegistrar.register(e));
77
- });
78
-
79
- test('refresh all will remove inactive elements', () => {
80
- const node = mockedElements[1]._tolgee.nodes.values().next().value;
81
- node.parentElement.removeChild(node);
82
- elementRegistrar.refreshAll();
83
- expect(mockedElements[1]._tolgee).not.toBeDefined();
84
- expect(mockedElements[1]).not.toHaveAttribute(TOLGEE_ATTRIBUTE_NAME);
85
- });
86
-
87
- test('refresh all will remove inactive nodes', () => {
88
- const node = mockedElements[2]._tolgee.nodes.values().next().value;
89
- node.parentElement.removeChild(node);
90
- elementRegistrar.refreshAll();
91
- expect(mockedElements[2]._tolgee.nodes.size).toEqual(2);
92
- });
93
-
94
- test('clean all will clean all elements', () => {
95
- elementRegistrar.cleanAll();
96
- for (const mockedElement of mockedElements) {
97
- expect(mockedElement._tolgee).not.toBeDefined();
98
- }
99
- });
100
-
101
- test("clean all doesn't clean elements with preventClean", () => {
102
- mockedElements[1]._tolgee.preventClean = true;
103
- const node = mockedElements[1]._tolgee.nodes.values().next().value;
104
- node.parentElement.removeChild(node);
105
- elementRegistrar.refreshAll();
106
- expect(mockedElements[1]._tolgee).toBeDefined();
107
- expect(mockedElements[1]).toHaveAttribute(TOLGEE_ATTRIBUTE_NAME);
108
- });
109
-
110
- test("refresh all doesn't delete nodes on elements wih preventClean", () => {
111
- mockedElements[1]._tolgee.preventClean = true;
112
- const node = mockedElements[1]._tolgee.nodes.values().next().value;
113
- node.parentElement.removeChild(node);
114
- elementRegistrar.refreshAll();
115
- expect(mockedElements[1]._tolgee).toBeDefined();
116
- });
117
- });
118
-
119
- test('will register attribute node', () => {
120
- const inputElement = document.createElement(
121
- 'input'
122
- ) as any as ElementWithMeta;
123
- document.body.append(inputElement);
124
- inputElement.setAttribute('_tolgee', '');
125
- inputElement.setAttribute('placeholder', 'Text');
126
- inputElement._tolgee = {
127
- nodes: new Set([inputElement.attributes['placeholder']]),
128
- };
129
- elementRegistrar.register(inputElement);
130
- });
131
- });
@@ -1,108 +0,0 @@
1
- import { ElementWithMeta } from '../types';
2
- import { Properties } from '../Properties';
3
- import { TOLGEE_ATTRIBUTE_NAME } from '../Constants/Global';
4
- import { TranslationHighlighter } from '../highlighter/TranslationHighlighter';
5
- import { NodeHelper } from '../helpers/NodeHelper';
6
- import { EventService } from './EventService';
7
- import { EventEmitterImpl } from './EventEmitter';
8
-
9
- export class ElementRegistrar {
10
- private registeredElements: Set<ElementWithMeta> = new Set();
11
-
12
- constructor(
13
- private properties: Properties,
14
- private translationHighlighter: TranslationHighlighter,
15
- private eventService: EventService
16
- ) {}
17
-
18
- register(element: ElementWithMeta) {
19
- //ignore element with no active nodes
20
- if (
21
- this.getActiveNodes(element).next().value === undefined &&
22
- !element._tolgee.wrappedWithElementOnlyKey
23
- ) {
24
- return;
25
- }
26
- if (
27
- this.properties.mode === 'development' &&
28
- !this.registeredElements.has(element)
29
- ) {
30
- this.translationHighlighter.listen(element);
31
- }
32
- this.registeredElements.add(element);
33
- (
34
- this.eventService.ELEMENT_REGISTERED as EventEmitterImpl<ElementWithMeta>
35
- ).emit(element);
36
- }
37
-
38
- refreshAll() {
39
- for (const element of this.registeredElements) {
40
- if (!element._tolgee.preventClean) {
41
- this.cleanElementInactiveNodes(element);
42
- if (
43
- element._tolgee.nodes.size === 0 &&
44
- !element._tolgee.wrappedWithElementOnlyKey
45
- ) {
46
- this.cleanElement(element);
47
- }
48
- }
49
- }
50
- }
51
-
52
- cleanAll() {
53
- for (const registeredElement of this.registeredElements) {
54
- this.cleanElement(registeredElement);
55
- }
56
- }
57
-
58
- findAllByKey(key: string) {
59
- const result: ElementWithMeta[] = [];
60
- for (const registeredElement of this.registeredElements) {
61
- if (registeredElement._tolgee.wrappedWithElementOnlyKey === key) {
62
- result.push(registeredElement);
63
- continue;
64
- }
65
- for (const node of registeredElement._tolgee.nodes) {
66
- if (
67
- node._tolgee.keys.findIndex(
68
- (keyWithParams) => keyWithParams.key === key
69
- ) > -1
70
- ) {
71
- result.push(registeredElement);
72
- break;
73
- }
74
- }
75
- }
76
- return result;
77
- }
78
-
79
- private cleanElementInactiveNodes(element: ElementWithMeta) {
80
- if (this.isElementActive(element)) {
81
- element._tolgee.nodes = new Set(this.getActiveNodes(element));
82
- return;
83
- }
84
- }
85
-
86
- private cleanElement(element: ElementWithMeta) {
87
- if (!element._tolgee.preventClean) {
88
- if (element._tolgee.highlightEl) {
89
- element._tolgee.unhighlight();
90
- }
91
- element.removeAttribute(TOLGEE_ATTRIBUTE_NAME);
92
- delete element._tolgee;
93
- this.registeredElements.delete(element);
94
- }
95
- }
96
-
97
- private *getActiveNodes(element: ElementWithMeta) {
98
- for (const node of element._tolgee.nodes) {
99
- if (NodeHelper.nodeContains(this.properties.config.targetElement, node)) {
100
- yield node;
101
- }
102
- }
103
- }
104
-
105
- private isElementActive(element: ElementWithMeta) {
106
- return this.properties.config.targetElement.contains(element);
107
- }
108
- }
@@ -1,52 +0,0 @@
1
- import { Subscription } from './Subscription';
2
-
3
- export type CallbackType<T> = (data: T) => Promise<void> | void;
4
-
5
- export interface EventEmitter<T> {
6
- subscribe(callback: CallbackType<T>): Subscription;
7
- }
8
-
9
- export class EventEmitterImpl<T> {
10
- private idCounter = 0;
11
- private _subscriptions: Map<number, CallbackType<T>> = new Map<
12
- number,
13
- CallbackType<T>
14
- >();
15
-
16
- private get subscriptions() {
17
- return this._subscriptions;
18
- }
19
-
20
- public emit(data?: T): Promise<void> | void {
21
- const promiseReturns = [];
22
- for (const callback of this.subscriptions.values()) {
23
- const returned = callback(data);
24
- if (typeof returned?.['then'] === 'function') {
25
- promiseReturns.push(returned);
26
- }
27
- }
28
-
29
- if (promiseReturns.length === 0) {
30
- return;
31
- }
32
-
33
- return new Promise((resolve) =>
34
- Promise.all(promiseReturns).then(() => resolve())
35
- );
36
- }
37
-
38
- public subscribe(callback: CallbackType<T>) {
39
- const newId = this.idCounter++;
40
- const subscription = new Subscription(() => this.unsubscribe(newId));
41
- this.subscriptions.set(newId, callback);
42
- return subscription;
43
- }
44
-
45
- private unsubscribe(id: number) {
46
- const wasPresent = this._subscriptions.delete(id);
47
- if (!wasPresent) {
48
- // eslint-disable-next-line no-console
49
- console.warn('Event to unsubscribe was not found');
50
- }
51
- }
52
- }
@@ -1,14 +0,0 @@
1
- import { EventEmitter, EventEmitterImpl } from './EventEmitter';
2
- import { TranslationData } from '../types/DTOs';
3
- import { ElementWithMeta } from '../types';
4
-
5
- export class EventService {
6
- public readonly TRANSLATION_CHANGED: EventEmitter<TranslationData> =
7
- new EventEmitterImpl<TranslationData>();
8
- public readonly LANGUAGE_CHANGED: EventEmitter<string> =
9
- new EventEmitterImpl<string>();
10
- public readonly LANGUAGE_LOADED: EventEmitter<string> =
11
- new EventEmitterImpl<string>();
12
- public readonly ELEMENT_REGISTERED: EventEmitter<ElementWithMeta> =
13
- new EventEmitterImpl<ElementWithMeta>();
14
- }
@@ -1,14 +0,0 @@
1
- import { Formatter, TolgeeModule } from '../types';
2
-
3
- export class ModuleService {
4
- formatter: Formatter | null = null;
5
-
6
- addModule = (module: TolgeeModule) => {
7
- if (module.type === 'formatter') {
8
- const instance = new module();
9
- this.formatter = instance;
10
- } else {
11
- throw new Error('Module with unknown type');
12
- }
13
- };
14
- }
@@ -1,31 +0,0 @@
1
- import { UploadedImageModel } from '..';
2
- import { ApiHttpService } from './ApiHttpService';
3
- import { CoreService } from './CoreService';
4
-
5
- export class ScreenshotService {
6
- constructor(
7
- private coreService: CoreService,
8
- private apiHttpService: ApiHttpService
9
- ) {}
10
-
11
- async uploadImage(blob: Blob) {
12
- const formData = new FormData();
13
-
14
- formData.append('image', blob);
15
-
16
- return this.apiHttpService.postJson('v2/image-upload', undefined, {
17
- headers: {},
18
- body: formData,
19
- }) as Promise<UploadedImageModel>;
20
- }
21
-
22
- async deleteImages(ids: number[]) {
23
- return this.apiHttpService.post(
24
- `v2/image-upload/${ids.join(',')}`,
25
- undefined,
26
- {
27
- method: 'delete',
28
- }
29
- ) as Promise<Response>;
30
- }
31
- }
@@ -1,7 +0,0 @@
1
- export class Subscription {
2
- constructor(private onUnsubscribe: () => void) {}
3
-
4
- unsubscribe() {
5
- this.onUnsubscribe();
6
- }
7
- }
@@ -1,88 +0,0 @@
1
- jest.dontMock('./TextService');
2
- jest.dontMock('../helpers/TextHelper');
3
- jest.dontMock('./DependencyService');
4
- jest.dontMock('./ModuleService');
5
- jest.dontMock('../modules/IcuFormatter');
6
-
7
- import { Properties } from '../Properties';
8
- import { TextService } from './TextService';
9
- import { getMockedInstance } from '@testFixtures/mocked';
10
- import { TranslationService } from './TranslationService';
11
- import { DependencyService } from './DependencyService';
12
- import { IcuFormatter } from '../modules/IcuFormatter';
13
-
14
- describe('TextService', () => {
15
- let mockedTranslationReturn = '';
16
- const params = { param1: 'Dummy param 1', param2: 'Dummy param 2' };
17
- let expectedTranslated = '';
18
- let textService: TextService;
19
-
20
- const getTranslationMock = jest.fn(async () => {
21
- return mockedTranslationReturn;
22
- });
23
-
24
- const getFromCacheOrCallbackMock = jest.fn(() => {
25
- return mockedTranslationReturn;
26
- });
27
-
28
- beforeEach(async () => {
29
- const depStore = new DependencyService();
30
- depStore.moduleService.addModule(IcuFormatter);
31
- textService = depStore.textService;
32
- mockedTranslationReturn = 'Dummy translated text {param1} {param2}';
33
- expectedTranslated = mockedTranslationReturn
34
- .replace('{param1}', params.param1)
35
- .replace('{param2}', params.param2);
36
-
37
- getMockedInstance(Properties).config = {
38
- inputPrefix: '{{',
39
- inputSuffix: '}}',
40
- restrictedElements: [],
41
- tagAttributes: {
42
- '*': ['aria-label'],
43
- },
44
- };
45
- getMockedInstance(TranslationService).getTranslation = getTranslationMock;
46
-
47
- getMockedInstance(TranslationService).getFromCacheOrFallback =
48
- getFromCacheOrCallbackMock;
49
- });
50
-
51
- afterEach(async () => {
52
- jest.clearAllMocks();
53
- });
54
-
55
- describe('translation functions', () => {
56
- test('it will translate asynchronously correctly', async () => {
57
- const translated = await textService.translate(
58
- mockedTranslationReturn,
59
- params,
60
- `en`,
61
- true,
62
- 'Default'
63
- );
64
- expect(translated).toEqual(expectedTranslated);
65
- expect(getTranslationMock).toBeCalledWith(
66
- 'Dummy translated text {param1} {param2}',
67
- 'en',
68
- 'Default'
69
- );
70
- });
71
-
72
- test('it will translate synchronously correctly', () => {
73
- const translated = textService.instant(
74
- mockedTranslationReturn,
75
- params,
76
- 'en',
77
- true,
78
- 'Default'
79
- );
80
- expect(translated).toEqual(expectedTranslated);
81
- expect(getFromCacheOrCallbackMock).toBeCalledWith(
82
- 'Dummy translated text {param1} {param2}',
83
- 'en',
84
- 'Default'
85
- );
86
- });
87
- });
88
- });