@tolgee/core 4.9.2 → 5.0.0-rc.4aa3be8.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 (273) hide show
  1. package/dist/tolgee.cjs.js +1069 -7029
  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 +1067 -7024
  8. package/dist/tolgee.esm.mjs.map +1 -1
  9. package/dist/tolgee.umd.js +1069 -7029
  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 +23 -0
  14. package/lib/Controller/Cache/helpers.d.ts +4 -0
  15. package/lib/Controller/Controller.d.ts +93 -0
  16. package/lib/Controller/Plugins/Plugins.d.ts +41 -0
  17. package/lib/Controller/State/State.d.ts +22 -0
  18. package/lib/Controller/State/helpers.d.ts +6 -0
  19. package/lib/Controller/State/initState.d.ts +55 -0
  20. package/lib/Controller/ValueObserver.d.ts +5 -0
  21. package/lib/Events/EventEmitter.d.ts +6 -0
  22. package/lib/Events/EventEmitterSelective.d.ts +15 -0
  23. package/lib/Events/Events.d.ts +50 -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 +19 -31
  31. package/src/Controller/Cache/Cache.ts +295 -0
  32. package/src/Controller/Cache/helpers.ts +39 -0
  33. package/src/Controller/Controller.ts +289 -0
  34. package/src/Controller/Plugins/Plugins.ts +305 -0
  35. package/src/Controller/State/State.ts +165 -0
  36. package/src/Controller/State/helpers.ts +41 -0
  37. package/src/Controller/State/initState.ts +90 -0
  38. package/src/Controller/ValueObserver.ts +23 -0
  39. package/src/Events/EventEmitter.ts +27 -0
  40. package/src/Events/EventEmitterSelective.test.ts +108 -0
  41. package/src/Events/EventEmitterSelective.ts +160 -0
  42. package/src/Events/Events.ts +66 -0
  43. package/src/Tolgee.ts +75 -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/client.test.ts +48 -0
  48. package/src/__test/events.test.ts +33 -0
  49. package/src/__test/initialization.test.ts +73 -0
  50. package/src/__test/jest-setup.ts +2 -0
  51. package/src/__test/languageDetection.test.ts +123 -0
  52. package/src/__test/languageStorage.test.ts +145 -0
  53. package/src/__test/languages.test.ts +106 -0
  54. package/src/__test/loading.test.ts +39 -0
  55. package/src/__test/namespaces.test.ts +99 -0
  56. package/src/__test/namespacesFallback.test.ts +73 -0
  57. package/src/__test/plugins.test.ts +98 -0
  58. package/src/__test/testTools.ts +7 -0
  59. package/src/{Constants/Global.ts → constants.ts} +1 -3
  60. package/src/helpers.ts +17 -0
  61. package/src/index.ts +9 -8
  62. package/src/types.ts +324 -90
  63. package/README.md +0 -45
  64. package/dist/Constants/Global.d.ts +0 -6
  65. package/dist/Constants/ModifierKey.d.ts +0 -6
  66. package/dist/Errors/ApiHttpError.d.ts +0 -5
  67. package/dist/Observer.d.ts +0 -14
  68. package/dist/Observer.test.d.ts +0 -2
  69. package/dist/Properties.d.ts +0 -17
  70. package/dist/Properties.test.d.ts +0 -1
  71. package/dist/Tolgee.d.ts +0 -68
  72. package/dist/Tolgee.test.d.ts +0 -1
  73. package/dist/TolgeeConfig.d.ts +0 -69
  74. package/dist/TolgeeConfig.test.d.ts +0 -1
  75. package/dist/__integration/FormatterIcu.test.d.ts +0 -1
  76. package/dist/__integration/FormatterMissing.d.ts +0 -1
  77. package/dist/__integration/Tolgee.test.d.ts +0 -1
  78. package/dist/__integration/TolgeeInvisible.test.d.ts +0 -1
  79. package/dist/__integration/mockTranslations.d.ts +0 -7
  80. package/dist/__integration/testConfig.d.ts +0 -9
  81. package/dist/__testFixtures/classMock.d.ts +0 -3
  82. package/dist/__testFixtures/createElement.d.ts +0 -2
  83. package/dist/__testFixtures/createTestDom.d.ts +0 -9
  84. package/dist/__testFixtures/mocked.d.ts +0 -20
  85. package/dist/__testFixtures/setupAfterEnv.d.ts +0 -8
  86. package/dist/helpers/NodeHelper.d.ts +0 -14
  87. package/dist/helpers/TextHelper.d.ts +0 -5
  88. package/dist/helpers/TextHelper.test.d.ts +0 -1
  89. package/dist/helpers/commonTypes.d.ts +0 -2
  90. package/dist/helpers/encoderPolyfill.d.ts +0 -8
  91. package/dist/helpers/secret.d.ts +0 -6
  92. package/dist/helpers/secret.test.d.ts +0 -1
  93. package/dist/helpers/sleep.d.ts +0 -1
  94. package/dist/highlighter/HighlightFunctionsInitializer.d.ts +0 -10
  95. package/dist/highlighter/HighlightFunctionsInitializer.test.d.ts +0 -1
  96. package/dist/highlighter/MouseEventHandler.d.ts +0 -29
  97. package/dist/highlighter/MouseEventHandler.test.d.ts +0 -1
  98. package/dist/highlighter/TranslationHighlighter.d.ts +0 -14
  99. package/dist/highlighter/TranslationHighlighter.test.d.ts +0 -1
  100. package/dist/index.d.ts +0 -10
  101. package/dist/internal.d.ts +0 -2
  102. package/dist/modules/IcuFormatter.d.ts +0 -2
  103. package/dist/modules/IcuFormatter.test.d.ts +0 -1
  104. package/dist/modules/index.d.ts +0 -1
  105. package/dist/services/ApiHttpService.d.ts +0 -15
  106. package/dist/services/CoreService.d.ts +0 -18
  107. package/dist/services/CoreService.test.d.ts +0 -1
  108. package/dist/services/DependencyService.d.ts +0 -39
  109. package/dist/services/DependencyService.test.d.ts +0 -1
  110. package/dist/services/ElementRegistrar.d.ts +0 -19
  111. package/dist/services/ElementRegistrar.test.d.ts +0 -1
  112. package/dist/services/EventEmitter.d.ts +0 -13
  113. package/dist/services/EventService.d.ts +0 -9
  114. package/dist/services/ModuleService.d.ts +0 -5
  115. package/dist/services/ScreenshotService.d.ts +0 -15
  116. package/dist/services/Subscription.d.ts +0 -5
  117. package/dist/services/TextService.d.ts +0 -14
  118. package/dist/services/TextService.test.d.ts +0 -1
  119. package/dist/services/TranslationService.d.ts +0 -75
  120. package/dist/services/TranslationService.test.d.ts +0 -1
  121. package/dist/services/__mocks__/CoreService.d.ts +0 -2
  122. package/dist/toolsManager/Messages.d.ts +0 -8
  123. package/dist/toolsManager/Messages.test.d.ts +0 -1
  124. package/dist/toolsManager/PluginManager.d.ts +0 -21
  125. package/dist/toolsManager/PluginManager.test.d.ts +0 -1
  126. package/dist/types/DTOs.d.ts +0 -20
  127. package/dist/types/apiSchema.generated.d.ts +0 -6185
  128. package/dist/types.d.ts +0 -123
  129. package/dist/wrappers/AbstractWrapper.d.ts +0 -8
  130. package/dist/wrappers/NodeHandler.d.ts +0 -18
  131. package/dist/wrappers/WrappedHandler.d.ts +0 -8
  132. package/dist/wrappers/invisible/AttributeHandler.d.ts +0 -8
  133. package/dist/wrappers/invisible/Coder.d.ts +0 -7
  134. package/dist/wrappers/invisible/ContentHandler.d.ts +0 -6
  135. package/dist/wrappers/invisible/CoreHandler.d.ts +0 -10
  136. package/dist/wrappers/invisible/InvisibleWrapper.d.ts +0 -18
  137. package/dist/wrappers/invisible/ValueMemory.d.ts +0 -5
  138. package/dist/wrappers/invisible/ValueMemory.test.d.ts +0 -1
  139. package/dist/wrappers/text/AttributeHandler.d.ts +0 -8
  140. package/dist/wrappers/text/AttributeHandler.test.d.ts +0 -1
  141. package/dist/wrappers/text/Coder.d.ts +0 -15
  142. package/dist/wrappers/text/Coder.test.d.ts +0 -1
  143. package/dist/wrappers/text/ContentHandler.d.ts +0 -8
  144. package/dist/wrappers/text/ContentHandler.test.d.ts +0 -1
  145. package/dist/wrappers/text/CoreHandler.d.ts +0 -17
  146. package/dist/wrappers/text/CoreHandler.test.d.ts +0 -1
  147. package/dist/wrappers/text/TextWrapper.d.ts +0 -20
  148. package/index.js +0 -7
  149. package/lib/Constants/ModifierKey.d.ts +0 -6
  150. package/lib/Errors/ApiHttpError.d.ts +0 -5
  151. package/lib/Observer.d.ts +0 -14
  152. package/lib/Properties.d.ts +0 -17
  153. package/lib/TolgeeConfig.d.ts +0 -69
  154. package/lib/helpers/NodeHelper.d.ts +0 -14
  155. package/lib/helpers/TextHelper.d.ts +0 -5
  156. package/lib/helpers/commonTypes.d.ts +0 -2
  157. package/lib/helpers/encoderPolyfill.d.ts +0 -8
  158. package/lib/helpers/secret.d.ts +0 -6
  159. package/lib/helpers/sleep.d.ts +0 -1
  160. package/lib/highlighter/HighlightFunctionsInitializer.d.ts +0 -10
  161. package/lib/highlighter/MouseEventHandler.d.ts +0 -29
  162. package/lib/highlighter/TranslationHighlighter.d.ts +0 -14
  163. package/lib/modules/IcuFormatter.d.ts +0 -2
  164. package/lib/modules/index.d.ts +0 -1
  165. package/lib/services/ApiHttpService.d.ts +0 -15
  166. package/lib/services/CoreService.d.ts +0 -18
  167. package/lib/services/DependencyService.d.ts +0 -39
  168. package/lib/services/ElementRegistrar.d.ts +0 -19
  169. package/lib/services/EventEmitter.d.ts +0 -13
  170. package/lib/services/EventService.d.ts +0 -9
  171. package/lib/services/ModuleService.d.ts +0 -5
  172. package/lib/services/ScreenshotService.d.ts +0 -15
  173. package/lib/services/Subscription.d.ts +0 -5
  174. package/lib/services/TextService.d.ts +0 -14
  175. package/lib/services/TranslationService.d.ts +0 -75
  176. package/lib/toolsManager/Messages.d.ts +0 -8
  177. package/lib/toolsManager/PluginManager.d.ts +0 -21
  178. package/lib/types/DTOs.d.ts +0 -20
  179. package/lib/types/apiSchema.generated.d.ts +0 -6185
  180. package/lib/wrappers/AbstractWrapper.d.ts +0 -8
  181. package/lib/wrappers/NodeHandler.d.ts +0 -18
  182. package/lib/wrappers/WrappedHandler.d.ts +0 -8
  183. package/lib/wrappers/invisible/AttributeHandler.d.ts +0 -8
  184. package/lib/wrappers/invisible/Coder.d.ts +0 -7
  185. package/lib/wrappers/invisible/ContentHandler.d.ts +0 -6
  186. package/lib/wrappers/invisible/CoreHandler.d.ts +0 -10
  187. package/lib/wrappers/invisible/InvisibleWrapper.d.ts +0 -18
  188. package/lib/wrappers/invisible/ValueMemory.d.ts +0 -5
  189. package/lib/wrappers/text/AttributeHandler.d.ts +0 -8
  190. package/lib/wrappers/text/Coder.d.ts +0 -15
  191. package/lib/wrappers/text/ContentHandler.d.ts +0 -8
  192. package/lib/wrappers/text/CoreHandler.d.ts +0 -17
  193. package/lib/wrappers/text/TextWrapper.d.ts +0 -20
  194. package/src/Constants/ModifierKey.ts +0 -6
  195. package/src/Errors/ApiHttpError.ts +0 -8
  196. package/src/Observer.test.ts +0 -119
  197. package/src/Observer.ts +0 -68
  198. package/src/Properties.test.ts +0 -150
  199. package/src/Properties.ts +0 -112
  200. package/src/Tolgee.test.ts +0 -473
  201. package/src/TolgeeConfig.test.ts +0 -21
  202. package/src/TolgeeConfig.ts +0 -134
  203. package/src/__integration/FormatterIcu.test.ts +0 -80
  204. package/src/__integration/FormatterMissing.ts +0 -54
  205. package/src/__integration/Tolgee.test.ts +0 -90
  206. package/src/__integration/TolgeeInvisible.test.ts +0 -145
  207. package/src/__integration/mockTranslations.ts +0 -6
  208. package/src/__integration/testConfig.ts +0 -16
  209. package/src/__testFixtures/classMock.ts +0 -11
  210. package/src/__testFixtures/createElement.ts +0 -43
  211. package/src/__testFixtures/createTestDom.ts +0 -26
  212. package/src/__testFixtures/mocked.ts +0 -25
  213. package/src/__testFixtures/setupAfterEnv.ts +0 -34
  214. package/src/helpers/NodeHelper.ts +0 -90
  215. package/src/helpers/TextHelper.test.ts +0 -62
  216. package/src/helpers/TextHelper.ts +0 -58
  217. package/src/helpers/commonTypes.ts +0 -8
  218. package/src/helpers/encoderPolyfill.ts +0 -96
  219. package/src/helpers/secret.test.ts +0 -61
  220. package/src/helpers/secret.ts +0 -68
  221. package/src/helpers/sleep.ts +0 -2
  222. package/src/highlighter/HighlightFunctionsInitializer.test.ts +0 -40
  223. package/src/highlighter/HighlightFunctionsInitializer.ts +0 -61
  224. package/src/highlighter/MouseEventHandler.test.ts +0 -151
  225. package/src/highlighter/MouseEventHandler.ts +0 -191
  226. package/src/highlighter/TranslationHighlighter.test.ts +0 -177
  227. package/src/highlighter/TranslationHighlighter.ts +0 -113
  228. package/src/internal.ts +0 -2
  229. package/src/modules/IcuFormatter.test.ts +0 -21
  230. package/src/modules/IcuFormatter.ts +0 -39
  231. package/src/modules/index.ts +0 -1
  232. package/src/services/ApiHttpService.ts +0 -85
  233. package/src/services/CoreService.test.ts +0 -141
  234. package/src/services/CoreService.ts +0 -76
  235. package/src/services/DependencyService.test.ts +0 -51
  236. package/src/services/DependencyService.ts +0 -116
  237. package/src/services/ElementRegistrar.test.ts +0 -131
  238. package/src/services/ElementRegistrar.ts +0 -108
  239. package/src/services/EventEmitter.ts +0 -52
  240. package/src/services/EventService.ts +0 -14
  241. package/src/services/ModuleService.ts +0 -14
  242. package/src/services/ScreenshotService.ts +0 -31
  243. package/src/services/Subscription.ts +0 -7
  244. package/src/services/TextService.test.ts +0 -88
  245. package/src/services/TextService.ts +0 -82
  246. package/src/services/TranslationService.test.ts +0 -358
  247. package/src/services/TranslationService.ts +0 -417
  248. package/src/services/__mocks__/CoreService.ts +0 -17
  249. package/src/toolsManager/Messages.test.ts +0 -79
  250. package/src/toolsManager/Messages.ts +0 -60
  251. package/src/toolsManager/PluginManager.test.ts +0 -108
  252. package/src/toolsManager/PluginManager.ts +0 -129
  253. package/src/types/DTOs.ts +0 -25
  254. package/src/types/apiSchema.generated.ts +0 -6208
  255. package/src/wrappers/AbstractWrapper.ts +0 -14
  256. package/src/wrappers/NodeHandler.ts +0 -143
  257. package/src/wrappers/WrappedHandler.ts +0 -28
  258. package/src/wrappers/invisible/AttributeHandler.ts +0 -23
  259. package/src/wrappers/invisible/Coder.ts +0 -65
  260. package/src/wrappers/invisible/ContentHandler.ts +0 -15
  261. package/src/wrappers/invisible/CoreHandler.ts +0 -17
  262. package/src/wrappers/invisible/InvisibleWrapper.ts +0 -59
  263. package/src/wrappers/invisible/ValueMemory.test.ts +0 -25
  264. package/src/wrappers/invisible/ValueMemory.ts +0 -16
  265. package/src/wrappers/text/AttributeHandler.test.ts +0 -118
  266. package/src/wrappers/text/AttributeHandler.ts +0 -25
  267. package/src/wrappers/text/Coder.test.ts +0 -298
  268. package/src/wrappers/text/Coder.ts +0 -202
  269. package/src/wrappers/text/ContentHandler.test.ts +0 -185
  270. package/src/wrappers/text/ContentHandler.ts +0 -21
  271. package/src/wrappers/text/CoreHandler.test.ts +0 -106
  272. package/src/wrappers/text/CoreHandler.ts +0 -45
  273. 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
- });