@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,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
- });