@tilde-nlp/ngx-translate 2.0.3 → 2.1.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 (130) hide show
  1. package/esm2020/lib/factories/file-api-service.factory.mjs +1 -1
  2. package/esm2020/lib/factories/mt-term-term-api.factory.mjs +12 -0
  3. package/esm2020/lib/factories/text-api-service.factory.mjs +3 -3
  4. package/esm2020/lib/i18n/de.mjs +2 -7
  5. package/esm2020/lib/i18n/en.mjs +2 -6
  6. package/esm2020/lib/i18n/et.mjs +1 -6
  7. package/esm2020/lib/i18n/fi.mjs +1 -6
  8. package/esm2020/lib/i18n/lt.mjs +1 -6
  9. package/esm2020/lib/i18n/lv.mjs +2 -7
  10. package/esm2020/lib/i18n/pl.mjs +1 -6
  11. package/esm2020/lib/i18n/sv.mjs +1 -4
  12. package/esm2020/lib/injection-tokens/index.mjs +2 -1
  13. package/esm2020/lib/injection-tokens/mt-term-api.token.mjs +2 -0
  14. package/esm2020/lib/modules/tld-common/models/configs/tld-term-config.model.mjs +1 -1
  15. package/esm2020/lib/modules/tld-common/services/tld-translate-config.service.mjs +2 -1
  16. package/esm2020/lib/modules/tld-document/services/api/file-api.service.mjs +7 -7
  17. package/esm2020/lib/modules/tld-term/create-collection/create-collection.component.mjs +51 -0
  18. package/esm2020/lib/modules/tld-term/index.mjs +2 -1
  19. package/esm2020/lib/modules/tld-term/services/api-v1/models/mt-term-collection-v1-status.enum.mjs +7 -0
  20. package/esm2020/lib/modules/tld-term/services/api-v1/models/mt-term-collection-v1.model.mjs +2 -0
  21. package/esm2020/lib/modules/tld-term/services/api-v1/mt-term-v1.service.mjs +53 -0
  22. package/esm2020/lib/modules/tld-term/services/api-v2/mt-term-v2.service.mjs +67 -0
  23. package/esm2020/lib/modules/tld-term/services/engine-term/eninge-term-api.service.mjs +32 -0
  24. package/esm2020/lib/modules/tld-term/services/engine-term/models/add-engine-terms-request-params.model.mjs +2 -0
  25. package/esm2020/lib/modules/tld-term/services/engine-term/models/engine-term-collection-list.model.mjs +2 -0
  26. package/esm2020/lib/modules/tld-term/services/engine-term/models/engine-term-collection-scope.enum.mjs +6 -0
  27. package/esm2020/lib/modules/tld-term/services/engine-term/models/engine-term-collection-source.enum.mjs +6 -0
  28. package/esm2020/lib/modules/tld-term/services/engine-term/models/engine-term-collection-status.enum.mjs +11 -0
  29. package/esm2020/lib/modules/tld-term/services/engine-term/models/engine-term-collection.model.mjs +2 -0
  30. package/esm2020/lib/modules/tld-term/services/engine-term/models/index.mjs +8 -0
  31. package/esm2020/lib/modules/tld-term/services/engine-term/models/update-engine-terms-request-params.model.mjs +2 -0
  32. package/esm2020/lib/modules/tld-term/services/index.mjs +4 -4
  33. package/esm2020/lib/modules/tld-term/services/models/combined-collection-tooltip-key.enum.mjs +6 -0
  34. package/esm2020/lib/modules/tld-term/services/models/combined-collection.model.mjs +190 -0
  35. package/esm2020/lib/modules/tld-term/services/models/index.mjs +6 -0
  36. package/esm2020/lib/modules/tld-term/services/models/mt-collection-status.enum.mjs +14 -0
  37. package/esm2020/lib/modules/tld-term/services/models/mt-collection.model.mjs +2 -0
  38. package/esm2020/lib/modules/tld-term/services/models/mt-term-service.model.mjs +2 -0
  39. package/esm2020/lib/modules/tld-term/services/term-api/index.mjs +3 -0
  40. package/esm2020/lib/modules/tld-term/services/term-api/models/index.mjs +3 -0
  41. package/esm2020/lib/modules/tld-term/services/term-api/models/tld-term-collection-languages.model.mjs +2 -0
  42. package/esm2020/lib/modules/tld-term/services/term-api/models/tld-term-collection.model.mjs +2 -0
  43. package/esm2020/lib/modules/tld-term/services/term-api/term-api.service.mjs +58 -0
  44. package/esm2020/lib/modules/tld-term/services/terminology.service.mjs +292 -0
  45. package/esm2020/lib/modules/tld-term/tld-term-collection/tld-term-collection.component.mjs +27 -12
  46. package/esm2020/lib/modules/tld-term/tld-term-collection-list/tld-term-collection-list.component.mjs +24 -51
  47. package/esm2020/lib/modules/tld-term/tld-term-menu/tld-term-menu.component.mjs +19 -12
  48. package/esm2020/lib/modules/tld-term/tld-term.module.mjs +6 -5
  49. package/esm2020/lib/modules/tld-text/services/api/tld-translate-text-api.service.mjs +7 -7
  50. package/esm2020/lib/modules/tld-tooltip/services/api-v2/tld-system-api-v2.service.mjs +4 -2
  51. package/esm2020/lib/modules/tld-web/tld-translate-web/tld-translate-web.component.mjs +8 -8
  52. package/esm2020/lib/tld-translate.module.mjs +17 -4
  53. package/esm2020/public-api.mjs +4 -2
  54. package/fesm2015/tilde-nlp-ngx-translate.mjs +749 -435
  55. package/fesm2015/tilde-nlp-ngx-translate.mjs.map +1 -1
  56. package/fesm2020/tilde-nlp-ngx-translate.mjs +724 -431
  57. package/fesm2020/tilde-nlp-ngx-translate.mjs.map +1 -1
  58. package/lib/factories/file-api-service.factory.d.ts +2 -2
  59. package/lib/factories/mt-term-term-api.factory.d.ts +7 -0
  60. package/lib/factories/text-api-service.factory.d.ts +3 -3
  61. package/lib/i18n/de.d.ts +0 -5
  62. package/lib/i18n/en.d.ts +1 -5
  63. package/lib/i18n/et.d.ts +0 -5
  64. package/lib/i18n/fi.d.ts +0 -5
  65. package/lib/i18n/lt.d.ts +0 -5
  66. package/lib/i18n/lv.d.ts +0 -5
  67. package/lib/i18n/pl.d.ts +0 -5
  68. package/lib/i18n/sv.d.ts +0 -3
  69. package/lib/injection-tokens/index.d.ts +1 -0
  70. package/lib/injection-tokens/mt-term-api.token.d.ts +1 -0
  71. package/lib/modules/tld-common/models/configs/tld-term-config.model.d.ts +1 -0
  72. package/lib/modules/tld-document/services/api/file-api.service.d.ts +3 -3
  73. package/lib/modules/tld-term/create-collection/create-collection.component.d.ts +17 -0
  74. package/lib/modules/tld-term/index.d.ts +1 -0
  75. package/lib/modules/tld-term/{models/mt-collection-status.model.d.ts → services/api-v1/models/mt-term-collection-v1-status.enum.d.ts} +1 -1
  76. package/lib/modules/tld-term/services/api-v1/models/mt-term-collection-v1.model.d.ts +12 -0
  77. package/lib/modules/tld-term/services/api-v1/mt-term-v1.service.d.ts +17 -0
  78. package/lib/modules/tld-term/services/api-v2/mt-term-v2.service.d.ts +18 -0
  79. package/lib/modules/tld-term/services/engine-term/eninge-term-api.service.d.ts +17 -0
  80. package/lib/modules/tld-term/services/engine-term/models/add-engine-terms-request-params.model.d.ts +8 -0
  81. package/lib/modules/tld-term/services/engine-term/models/engine-term-collection-list.model.d.ts +4 -0
  82. package/lib/modules/tld-term/services/engine-term/models/engine-term-collection-scope.enum.d.ts +4 -0
  83. package/lib/modules/tld-term/services/engine-term/models/engine-term-collection-source.enum.d.ts +4 -0
  84. package/lib/modules/tld-term/services/engine-term/models/engine-term-collection-status.enum.d.ts +9 -0
  85. package/lib/modules/tld-term/services/engine-term/models/engine-term-collection.model.d.ts +14 -0
  86. package/lib/modules/tld-term/services/engine-term/models/index.d.ts +7 -0
  87. package/lib/modules/tld-term/services/engine-term/models/update-engine-terms-request-params.model.d.ts +5 -0
  88. package/lib/modules/tld-term/services/index.d.ts +3 -3
  89. package/lib/modules/tld-term/services/models/combined-collection-tooltip-key.enum.d.ts +4 -0
  90. package/lib/modules/tld-term/services/models/combined-collection.model.d.ts +87 -0
  91. package/lib/modules/tld-term/services/models/index.d.ts +5 -0
  92. package/lib/modules/tld-term/services/models/mt-collection-status.enum.d.ts +11 -0
  93. package/lib/modules/tld-term/services/models/mt-collection.model.d.ts +14 -0
  94. package/lib/modules/tld-term/services/models/mt-term-service.model.d.ts +7 -0
  95. package/lib/modules/tld-term/services/term-api/index.d.ts +2 -0
  96. package/lib/modules/tld-term/services/term-api/models/index.d.ts +2 -0
  97. package/lib/modules/tld-term/{models/term-api → services/term-api/models}/tld-term-collection.model.d.ts +2 -2
  98. package/lib/modules/tld-term/services/term-api/term-api.service.d.ts +17 -0
  99. package/lib/modules/tld-term/services/terminology.service.d.ts +63 -0
  100. package/lib/modules/tld-term/tld-term-collection/tld-term-collection.component.d.ts +13 -4
  101. package/lib/modules/tld-term/tld-term-collection-list/tld-term-collection-list.component.d.ts +13 -17
  102. package/lib/modules/tld-term/tld-term-menu/tld-term-menu.component.d.ts +11 -7
  103. package/lib/modules/tld-term/tld-term.module.d.ts +13 -12
  104. package/lib/modules/tld-text/services/api/tld-translate-text-api.service.d.ts +3 -3
  105. package/lib/modules/tld-web/tld-translate-web/tld-translate-web.component.d.ts +3 -3
  106. package/package.json +1 -1
  107. package/public-api.d.ts +3 -1
  108. package/src/assets/webcomponent/tld-translate.js +1 -1
  109. package/tilde-nlp-ngx-translate-2.1.0.tgz +0 -0
  110. package/esm2020/lib/modules/tld-term/models/converted-collection-tooltip-key.model.mjs +0 -7
  111. package/esm2020/lib/modules/tld-term/models/converted-collection-type.model.mjs +0 -9
  112. package/esm2020/lib/modules/tld-term/models/index.mjs +0 -7
  113. package/esm2020/lib/modules/tld-term/models/mt-api/tld-mt-term-collection.model.mjs +0 -2
  114. package/esm2020/lib/modules/tld-term/models/mt-collection-status.model.mjs +0 -7
  115. package/esm2020/lib/modules/tld-term/models/term-api/tld-term-collection-languages.model.mjs +0 -2
  116. package/esm2020/lib/modules/tld-term/models/term-api/tld-term-collection.model.mjs +0 -2
  117. package/esm2020/lib/modules/tld-term/models/tld-converted-collection.model.mjs +0 -114
  118. package/esm2020/lib/modules/tld-term/services/mt-collections-api.service.mjs +0 -33
  119. package/esm2020/lib/modules/tld-term/services/term-api.service.mjs +0 -34
  120. package/esm2020/lib/modules/tld-term/services/tld-term-collections.service.mjs +0 -253
  121. package/lib/modules/tld-term/models/converted-collection-tooltip-key.model.d.ts +0 -5
  122. package/lib/modules/tld-term/models/converted-collection-type.model.d.ts +0 -7
  123. package/lib/modules/tld-term/models/index.d.ts +0 -6
  124. package/lib/modules/tld-term/models/mt-api/tld-mt-term-collection.model.d.ts +0 -15
  125. package/lib/modules/tld-term/models/tld-converted-collection.model.d.ts +0 -43
  126. package/lib/modules/tld-term/services/mt-collections-api.service.d.ts +0 -13
  127. package/lib/modules/tld-term/services/term-api.service.d.ts +0 -15
  128. package/lib/modules/tld-term/services/tld-term-collections.service.d.ts +0 -57
  129. package/tilde-nlp-ngx-translate-2.0.3.tgz +0 -0
  130. /package/lib/modules/tld-term/{models/term-api → services/term-api/models}/tld-term-collection-languages.model.d.ts +0 -0
@@ -0,0 +1,292 @@
1
+ import { Inject, Injectable } from '@angular/core';
2
+ import { forkJoin, Subject, tap } from 'rxjs';
3
+ import { MT_TERM_API_TOKEN } from '../../../injection-tokens';
4
+ import { EngineTermCollectionSource } from './engine-term/models';
5
+ import { CombinedCollection } from './models/combined-collection.model';
6
+ import { MtCollectionStatus } from './models/mt-collection-status.enum';
7
+ import * as i0 from "@angular/core";
8
+ import * as i1 from "../../tld-common/services";
9
+ import * as i2 from "./term-api/term-api.service";
10
+ export class TerminologyService {
11
+ constructor(config, termApi, mtApi) {
12
+ this.config = config;
13
+ this.termApi = termApi;
14
+ this.mtApi = mtApi;
15
+ this._selected = null;
16
+ this.onDataUpdate = new Subject();
17
+ this.LOCAL_STORAGE_KEY = "systemLastCollections";
18
+ }
19
+ get selected() { return this._selected; }
20
+ set selected(val) {
21
+ this._selected = val;
22
+ this.storeSelectedInLocalStorage();
23
+ if (!this._selected) {
24
+ return;
25
+ }
26
+ if (!this._selected.mtCollection) {
27
+ this.addToEngine(this._selected);
28
+ }
29
+ }
30
+ get hasAnyCollections() {
31
+ return this._hasAnyCollections;
32
+ }
33
+ get shouldShowPromotion() {
34
+ return !this.hasAnyCollections && !this.hasEditPermissions;
35
+ }
36
+ get canCreateCollections() {
37
+ return this.config.termConfig.canCreateCollection;
38
+ }
39
+ get hasEditPermissions() {
40
+ return this.config?.coreConfig.isAuth && this.canCreateCollections && this.config.termConfig.isTermPortalSupported;
41
+ }
42
+ get isRefreshingCollections() {
43
+ return this._isRefreshingCollections;
44
+ }
45
+ get collections() {
46
+ return this._collections;
47
+ }
48
+ setEngine(engineId, languages = null, setSelectedFromLocalStorage = false) {
49
+ // engine is already set with that ID and no need to refresh it.
50
+ if (engineId !== this.engineId || JSON.stringify(languages) !== JSON.stringify(this.engineLanguages)) {
51
+ this.engineLanguages = languages;
52
+ this.engineId = engineId;
53
+ this._collections = new Set();
54
+ this.emitDataUpdateEvent();
55
+ // avoiding setter, so the null value is not storeed in location since it is not by user action
56
+ this._selected = null;
57
+ }
58
+ if (this.engineId) {
59
+ this.refreshCollections(setSelectedFromLocalStorage, true);
60
+ }
61
+ return this.onDataUpdate.asObservable();
62
+ }
63
+ refreshCollections(setSelectedFromLocalStorage = false, initialRefresh = false) {
64
+ if (!this.engineId || !this.config.termConfig.isCollectionsActivated || this.isRefreshingCollections) {
65
+ return;
66
+ }
67
+ // clear timeout since this refresh replaces scheduled
68
+ this.clearTimeout();
69
+ this._isRefreshingCollections = true;
70
+ let termResponse;
71
+ let mtApiResponse;
72
+ const observables = [
73
+ this.termApi.getCollectionList(this.engineLanguages)
74
+ .pipe(tap((response) => termResponse = response)),
75
+ this.mtApi.getList(this.engineId)
76
+ .pipe(tap((response) => mtApiResponse = response)),
77
+ ];
78
+ forkJoin(observables).subscribe({
79
+ // do not need response becaue responses are saved in pipe methods
80
+ next: () => {
81
+ this.isAnyImporting = false;
82
+ // note that termResponse and mtapiresponse gets changed during remove method
83
+ this.removeDeleted(termResponse, mtApiResponse, initialRefresh);
84
+ this.addCollections([...mtApiResponse, ...termResponse], initialRefresh);
85
+ if (setSelectedFromLocalStorage) {
86
+ this.setSelectedFromLocalStorage();
87
+ }
88
+ this._isRefreshingCollections = false;
89
+ this.scheduleRefresh();
90
+ },
91
+ error: (error) => {
92
+ this._isRefreshingCollections = false;
93
+ // it is enough to show error only in console. No special thing is necessary.
94
+ console.error(error);
95
+ },
96
+ });
97
+ }
98
+ addToEngine(collection) {
99
+ if (!collection || !collection.termCollection) {
100
+ console.error("Trying to attach collection that has no tilde term id.");
101
+ return;
102
+ }
103
+ // collection.mtStatus = MtCollectionStatus.PROCESSING;
104
+ // collection.isSynchronized = true;
105
+ this.mtApi.add(this.engineId, collection)
106
+ .subscribe({
107
+ error: () => {
108
+ // collection.mtStatus = MtCollectionStatus.ERROR;
109
+ // collection.errorKey = ErrorCode.COLLECTION_IMPORT;
110
+ }
111
+ });
112
+ }
113
+ create(sourceLanguage, targetLanguage, collectionName, redirectToEdit = true) {
114
+ return this.termApi.createCollection([sourceLanguage, targetLanguage], collectionName).pipe(tap((collection) => {
115
+ if (redirectToEdit) {
116
+ window.open(this.termApi.getEditLink(collection.termCollection.id, sourceLanguage, targetLanguage), "_blank");
117
+ }
118
+ this._collections.add(collection);
119
+ this.emitDataUpdateEvent();
120
+ this._hasAnyCollections = true;
121
+ }));
122
+ }
123
+ updateIfNecessary(collection) {
124
+ // collection is not imported and should be attached to engine
125
+ if (collection.isEdited()) {
126
+ this.mtApi.add(this.engineId, collection).subscribe((updatedCollection) => {
127
+ collection.update(updatedCollection);
128
+ });
129
+ }
130
+ }
131
+ /**
132
+ *
133
+ * @returns selected collection id if it is allowed to use collection for translations
134
+ */
135
+ selectedIdForTranslation() {
136
+ if (this.selected?.mtCollection && (this.selected.mtCollection.lastUpdated || this.selected.mtCollection?.status === MtCollectionStatus.READY)) {
137
+ return this.selected.mtCollection?.id;
138
+ }
139
+ return null;
140
+ }
141
+ startAutoRefresh(engineId, languages = null, setSelectedFromLocalStorage = false) {
142
+ this.hardAutoRefresh = true;
143
+ return this.setEngine(engineId ?? this.engineId, languages ?? this.engineLanguages, setSelectedFromLocalStorage);
144
+ }
145
+ stopAutoRefresh() {
146
+ this.clearTimeout();
147
+ this.isSoftAutoRefreshOn = false;
148
+ this.hardAutoRefresh = false;
149
+ }
150
+ removeMtCollection(collection, engineId = this.engineId) {
151
+ return this.mtApi.remove(engineId, collection).pipe(tap((response) => {
152
+ collection.update(response);
153
+ }));
154
+ }
155
+ scheduleRefresh(timeout) {
156
+ // if menu is closed and selected collection is not importing anymore - auto refreshing should be cancelled.
157
+ if (!this.hardAutoRefresh && !this.selected?.isImporting && this.isSoftAutoRefreshOn) {
158
+ this.stopAutoRefresh();
159
+ return;
160
+ }
161
+ // if hard auto refresho on, auto refresh should be on. If hard autoreferesh is off , refresh needs to be done only if selected is importing.
162
+ if (this.hardAutoRefresh || (!this.refreshTimeout && (this.isSoftAutoRefreshOn || this.selected?.isImporting))) {
163
+ const timeoutMs = timeout ?? (this.isAnyImporting ? this.config.termConfig.refreshTimeoutMsWhenImporting : this.config.termConfig.refreshTimeoutMs);
164
+ this.refreshTimeout = setTimeout(() => {
165
+ this.refreshTimeout = null;
166
+ this.refreshCollections();
167
+ }, timeoutMs);
168
+ }
169
+ }
170
+ /**
171
+ *
172
+ * @param newCollections
173
+ * @param initialRefresh Whether also editable collection fields should be updated. If not initial refresh, editable fields will not be updated.
174
+ */
175
+ addCollections(newCollections, initialRefresh) {
176
+ // sets collection list to this value at the end, so deleted collections are not in the list.
177
+ for (let collection of newCollections) {
178
+ // User shouldn't see failed collections if he can't retry to import them.
179
+ if (!this.hasEditPermissions
180
+ && collection.mtStatus === MtCollectionStatus.ERROR) {
181
+ continue;
182
+ }
183
+ if (collection.isImporting) {
184
+ this.isAnyImporting = true;
185
+ }
186
+ let existing = CombinedCollection.findExistingCollectionFromList(this.collections, collection);
187
+ // If term api doesn't have engine languages, collection should not be shown (if it is not already imported somehow);
188
+ if (!existing && collection.source === EngineTermCollectionSource.TILDE_TERM) {
189
+ let hasLanguages = true;
190
+ for (let i = 0; i < this.engineLanguages?.length; i++) {
191
+ if (!collection.termCollection.languages?.find(lang => lang.id === this.engineLanguages[i])) {
192
+ hasLanguages = false;
193
+ break;
194
+ }
195
+ }
196
+ if (!hasLanguages) {
197
+ continue;
198
+ }
199
+ }
200
+ if (!existing) {
201
+ this._collections.add(collection);
202
+ }
203
+ else {
204
+ existing.update(collection, initialRefresh);
205
+ }
206
+ }
207
+ // this._collections = updatedCollections;
208
+ this.emitDataUpdateEvent();
209
+ this._hasAnyCollections = this._collections.size > 0;
210
+ }
211
+ /**
212
+ * Should be called after refresh to check if there is any collections from api that are deleted.
213
+ */
214
+ removeDeleted(termResponse, mtResponse, initialRefresh) {
215
+ for (const collection of this.collections) {
216
+ const termExistingIx = CombinedCollection.findExistingIndexFromList(termResponse, collection);
217
+ const mtExistingIx = CombinedCollection.findExistingIndexFromList(mtResponse, collection);
218
+ if (termExistingIx === null && mtExistingIx === null) {
219
+ this.collections.delete(collection);
220
+ }
221
+ else {
222
+ if (termExistingIx !== null) {
223
+ const existing = termResponse[termExistingIx];
224
+ collection.update(existing, initialRefresh);
225
+ termResponse.splice(termExistingIx, 1);
226
+ }
227
+ else {
228
+ collection.deleteTerms();
229
+ }
230
+ if (mtExistingIx !== null) {
231
+ const existing = mtResponse[mtExistingIx];
232
+ collection.update(existing, initialRefresh);
233
+ mtResponse.splice(mtExistingIx, 1);
234
+ }
235
+ else {
236
+ collection.deleteMT();
237
+ }
238
+ }
239
+ }
240
+ }
241
+ clearTimeout() {
242
+ if (this.refreshTimeout) {
243
+ clearTimeout(this.refreshTimeout);
244
+ this.refreshTimeout = null;
245
+ }
246
+ }
247
+ setSelectedFromLocalStorage() {
248
+ // If no collections or selected is already set, it should not be changed from localstorage value. (Usually, localstorage should have the same value).
249
+ if (this.collections?.size === 0 || this.selected) {
250
+ return;
251
+ }
252
+ const storedId = this.readLocalStorage()?.[this.engineId];
253
+ if (!storedId) {
254
+ return;
255
+ }
256
+ const existing = Array.from(this.collections).find(item => item.termCollection?.id === storedId || item.mtCollection?.id === storedId);
257
+ this.selected = existing;
258
+ }
259
+ storeSelectedInLocalStorage() {
260
+ let localStorageObject = this.readLocalStorage();
261
+ if (!localStorageObject) {
262
+ localStorageObject = {};
263
+ }
264
+ localStorageObject[this.engineId] = this.selected ? (this.selected.termCollection?.id ?? this.selected.mtCollection?.id) : null;
265
+ // store term id if it exists
266
+ localStorage.setItem(this.LOCAL_STORAGE_KEY, JSON.stringify(localStorageObject));
267
+ }
268
+ readLocalStorage() {
269
+ const data = localStorage.getItem(this.LOCAL_STORAGE_KEY);
270
+ try {
271
+ return JSON.parse(data);
272
+ }
273
+ catch {
274
+ return null;
275
+ }
276
+ }
277
+ emitDataUpdateEvent() {
278
+ this.onDataUpdate.next(this.collections);
279
+ }
280
+ }
281
+ TerminologyService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TerminologyService, deps: [{ token: i1.TldTranslateConfigService }, { token: i2.TermApiService }, { token: MT_TERM_API_TOKEN }], target: i0.ɵɵFactoryTarget.Injectable });
282
+ TerminologyService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TerminologyService, providedIn: 'root' });
283
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TerminologyService, decorators: [{
284
+ type: Injectable,
285
+ args: [{
286
+ providedIn: 'root'
287
+ }]
288
+ }], ctorParameters: function () { return [{ type: i1.TldTranslateConfigService }, { type: i2.TermApiService }, { type: undefined, decorators: [{
289
+ type: Inject,
290
+ args: [MT_TERM_API_TOKEN]
291
+ }] }]; } });
292
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"terminology.service.js","sourceRoot":"","sources":["../../../../../../../projects/tld-translate/src/lib/modules/tld-term/services/terminology.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AACnD,OAAO,EAAE,QAAQ,EAAc,OAAO,EAAE,GAAG,EAAE,MAAM,MAAM,CAAC;AAC1D,OAAO,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAC;AAE9D,OAAO,EAAE,0BAA0B,EAAE,MAAM,sBAAsB,CAAC;AAClE,OAAO,EAAE,kBAAkB,EAAE,MAAM,oCAAoC,CAAC;AACxE,OAAO,EAAE,kBAAkB,EAAE,MAAM,oCAAoC,CAAC;;;;AAOxE,MAAM,OAAO,kBAAkB;IA4D7B,YAA6B,MAAiC,EAC3C,OAAuB,EACL,KAAqB;QAF7B,WAAM,GAAN,MAAM,CAA2B;QAC3C,YAAO,GAAP,OAAO,CAAgB;QACL,UAAK,GAAL,KAAK,CAAgB;QA5DlD,cAAS,GAAuB,IAAI,CAAC;QA8C5B,iBAAY,GAAG,IAAI,OAAO,EAA2B,CAAC;QAEtD,sBAAiB,GAAG,uBAAuB,CAAC;IAYC,CAAC;IA3D/D,IAAI,QAAQ,KAAK,OAAO,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC;IACzC,IAAI,QAAQ,CAAC,GAAuB;QAClC,IAAI,CAAC,SAAS,GAAG,GAAG,CAAC;QACrB,IAAI,CAAC,2BAA2B,EAAE,CAAC;QACnC,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE;YACnB,OAAO;SACR;QAED,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,YAAY,EAAE;YAChC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;SAClC;IAEH,CAAC;IAMD,IAAI,iBAAiB;QACnB,OAAO,IAAI,CAAC,kBAAkB,CAAC;IACjC,CAAC;IAGD,IAAI,mBAAmB;QACrB,OAAO,CAAC,IAAI,CAAC,iBAAiB,IAAI,CAAC,IAAI,CAAC,kBAAkB,CAAC;IAC7D,CAAC;IAED,IAAI,oBAAoB;QACtB,OAAO,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,mBAAmB,CAAC;IACpD,CAAC;IAED,IAAI,kBAAkB;QACpB,OAAO,IAAI,CAAC,MAAM,EAAE,UAAU,CAAC,MAAM,IAAI,IAAI,CAAC,oBAAoB,IAAI,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,qBAAqB,CAAC;IACrH,CAAC;IAGD,IAAI,uBAAuB;QACzB,OAAO,IAAI,CAAC,wBAAwB,CAAC;IACvC,CAAC;IAGD,IAAI,WAAW;QACb,OAAO,IAAI,CAAC,YAAY,CAAC;IAC3B,CAAC;IAkBD,SAAS,CAAC,QAAgB,EAAE,YAAsB,IAAI,EAAE,2BAA2B,GAAG,KAAK;QACzF,gEAAgE;QAChE,IAAI,QAAQ,KAAK,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,KAAK,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,eAAe,CAAC,EAAE;YACpG,IAAI,CAAC,eAAe,GAAG,SAAS,CAAC;YACjC,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;YACzB,IAAI,CAAC,YAAY,GAAG,IAAI,GAAG,EAAE,CAAC;YAC9B,IAAI,CAAC,mBAAmB,EAAE,CAAC;YAC3B,+FAA+F;YAC/F,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;SACvB;QAED,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,IAAI,CAAC,kBAAkB,CAAC,2BAA2B,EAAE,IAAI,CAAC,CAAC;SAC5D;QAED,OAAO,IAAI,CAAC,YAAY,CAAC,YAAY,EAAE,CAAC;IAC1C,CAAC;IAED,kBAAkB,CAAC,2BAA2B,GAAG,KAAK,EAAE,cAAc,GAAG,KAAK;QAC5E,IAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,sBAAsB,IAAI,IAAI,CAAC,uBAAuB,EAAE;YACpG,OAAO;SACR;QAED,sDAAsD;QACtD,IAAI,CAAC,YAAY,EAAE,CAAC;QAEpB,IAAI,CAAC,wBAAwB,GAAG,IAAI,CAAC;QAErC,IAAI,YAAkC,CAAC;QACvC,IAAI,aAAmC,CAAC;QAExC,MAAM,WAAW,GAAuC;YACtD,IAAI,CAAC,OAAO,CAAC,iBAAiB,CAAC,IAAI,CAAC,eAAe,CAAC;iBACjD,IAAI,CACH,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,YAAY,GAAG,QAAQ,CAAC,CAC3C;YACH,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC;iBAC9B,IAAI,CACH,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,aAAa,GAAG,QAAQ,CAAC,CAC5C;SACJ,CAAC;QACF,QAAQ,CAAC,WAAW,CAAC,CAAC,SAAS,CAAC;YAC9B,kEAAkE;YAClE,IAAI,EAAE,GAAG,EAAE;gBACT,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;gBAC5B,6EAA6E;gBAC7E,IAAI,CAAC,aAAa,CAAC,YAAY,EAAE,aAAa,EAAE,cAAc,CAAC,CAAC;gBAChE,IAAI,CAAC,cAAc,CAAC,CAAC,GAAG,aAAa,EAAE,GAAG,YAAY,CAAC,EAAE,cAAc,CAAC,CAAC;gBACzE,IAAI,2BAA2B,EAAE;oBAC/B,IAAI,CAAC,2BAA2B,EAAE,CAAC;iBACpC;gBACD,IAAI,CAAC,wBAAwB,GAAG,KAAK,CAAC;gBACtC,IAAI,CAAC,eAAe,EAAE,CAAC;YACzB,CAAC;YACD,KAAK,EAAE,CAAC,KAAK,EAAE,EAAE;gBACf,IAAI,CAAC,wBAAwB,GAAG,KAAK,CAAC;gBACtC,6EAA6E;gBAC7E,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;YACvB,CAAC;SACF,CAAC,CAAC;IACL,CAAC;IAED,WAAW,CAAC,UAA8B;QACxC,IAAI,CAAC,UAAU,IAAI,CAAC,UAAU,CAAC,cAAc,EAAE;YAC7C,OAAO,CAAC,KAAK,CAAC,wDAAwD,CAAC,CAAC;YACxE,OAAO;SACR;QACD,uDAAuD;QACvD,oCAAoC;QACpC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,QAAQ,EAAE,UAAU,CAAC;aACtC,SAAS,CAAC;YACT,KAAK,EAAE,GAAG,EAAE;gBACV,kDAAkD;gBAClD,qDAAqD;YACvD,CAAC;SACF,CAAC,CAAA;IAEN,CAAC;IAED,MAAM,CAAC,cAAsB,EAAE,cAAsB,EAAE,cAAsB,EAAE,cAAc,GAAG,IAAI;QAClG,OAAO,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC,CAAC,cAAc,EAAE,cAAc,CAAC,EAAE,cAAc,CAAC,CAAC,IAAI,CACzF,GAAG,CAAC,CAAC,UAAU,EAAE,EAAE;YACjB,IAAI,cAAc,EAAE;gBAClB,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,UAAU,CAAC,cAAc,CAAC,EAAE,EAAE,cAAc,EAAE,cAAc,CAAC,EAAE,QAAQ,CAAC,CAAC;aAC/G;YACD,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;YAClC,IAAI,CAAC,mBAAmB,EAAE,CAAC;YAC3B,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC;QACjC,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAED,iBAAiB,CAAC,UAA8B;QAC9C,8DAA8D;QAC9D,IAAI,UAAU,CAAC,QAAQ,EAAE,EAAE;YACzB,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,QAAQ,EAAE,UAAU,CAAC,CAAC,SAAS,CAAC,CAAC,iBAAiB,EAAE,EAAE;gBACxE,UAAU,CAAC,MAAM,CAAC,iBAAiB,CAAC,CAAC;YACvC,CAAC,CAAC,CAAC;SACJ;IACH,CAAC;IAED;;;KAGC;IACD,wBAAwB;QACtB,IAAI,IAAI,CAAC,QAAQ,EAAE,YAAY,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,WAAW,IAAI,IAAI,CAAC,QAAQ,CAAC,YAAY,EAAE,MAAM,KAAK,kBAAkB,CAAC,KAAK,CAAC,EAAE;YAC9I,OAAO,IAAI,CAAC,QAAQ,CAAC,YAAY,EAAE,EAAE,CAAC;SACvC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IAED,gBAAgB,CAAC,QAAiB,EAAE,YAAsB,IAAI,EAAE,2BAA2B,GAAG,KAAK;QACjG,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;QAC5B,OAAO,IAAI,CAAC,SAAS,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,EAAE,SAAS,IAAI,IAAI,CAAC,eAAe,EAAE,2BAA2B,CAAC,CAAC;IACnH,CAAC;IAED,eAAe;QACb,IAAI,CAAC,YAAY,EAAE,CAAC;QAEpB,IAAI,CAAC,mBAAmB,GAAG,KAAK,CAAC;QACjC,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;IAC/B,CAAC;IAED,kBAAkB,CAAC,UAA8B,EAAE,QAAQ,GAAG,IAAI,CAAC,QAAQ;QACzE,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,QAAQ,EAAE,UAAU,CAAC,CAAC,IAAI,CACjD,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE;YACf,UAAU,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;QAC9B,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAEO,eAAe,CAAC,OAAgB;QACtC,4GAA4G;QAC5G,IAAI,CAAC,IAAI,CAAC,eAAe,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,WAAW,IAAI,IAAI,CAAC,mBAAmB,EAAE;YACpF,IAAI,CAAC,eAAe,EAAE,CAAC;YACvB,OAAO;SACR;QAED,6IAA6I;QAC7I,IAAI,IAAI,CAAC,eAAe,IAAI,CAAC,CAAC,IAAI,CAAC,cAAc,IAAI,CAAC,IAAI,CAAC,mBAAmB,IAAI,IAAI,CAAC,QAAQ,EAAE,WAAW,CAAC,CAAC,EAAE;YAC9G,MAAM,SAAS,GAAG,OAAO,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,6BAA6B,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,gBAAgB,CAAC,CAAC;YACpJ,IAAI,CAAC,cAAc,GAAG,UAAU,CAAC,GAAG,EAAE;gBACpC,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;gBAC3B,IAAI,CAAC,kBAAkB,EAAE,CAAA;YAC3B,CAAC,EAAE,SAAS,CAAC,CAAC;SACf;IACH,CAAC;IAED;;;;OAIG;IACK,cAAc,CAAC,cAA4C,EAAE,cAAuB;QAC1F,6FAA6F;QAC7F,KAAK,IAAI,UAAU,IAAI,cAAc,EAAE;YACrC,0EAA0E;YAC1E,IAAI,CAAC,IAAI,CAAC,kBAAkB;mBACvB,UAAU,CAAC,QAAQ,KAAK,kBAAkB,CAAC,KAAK,EAAE;gBACrD,SAAS;aACV;YAED,IAAI,UAAU,CAAC,WAAW,EAAE;gBAC1B,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;aAC5B;YACD,IAAI,QAAQ,GAAuB,kBAAkB,CAAC,8BAA8B,CAAC,IAAI,CAAC,WAAW,EAAE,UAAU,CAAC,CAAC;YAEnH,qHAAqH;YACrH,IAAI,CAAC,QAAQ,IAAI,UAAU,CAAC,MAAM,KAAK,0BAA0B,CAAC,UAAU,EAAE;gBAC5E,IAAI,YAAY,GAAG,IAAI,CAAC;gBACxB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,eAAe,EAAE,MAAM,EAAE,CAAC,EAAE,EAAE;oBACrD,IAAI,CAAC,UAAU,CAAC,cAAc,CAAC,SAAS,EAAE,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,KAAK,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,EAAE;wBAC3F,YAAY,GAAG,KAAK,CAAC;wBACrB,MAAM;qBACP;iBACF;gBAED,IAAI,CAAC,YAAY,EAAE;oBACjB,SAAS;iBACV;aACF;YAED,IAAI,CAAC,QAAQ,EAAE;gBACb,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;aACnC;iBACI;gBACH,QAAQ,CAAC,MAAM,CAAC,UAAU,EAAE,cAAc,CAAC,CAAC;aAC7C;SACF;QAED,0CAA0C;QAC1C,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAC3B,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,GAAG,CAAC,CAAC;IACvD,CAAC;IAED;;OAEG;IACK,aAAa,CAAC,YAAkC,EAAE,UAAgC,EAAE,cAAuB;QAEjH,KAAK,MAAM,UAAU,IAAI,IAAI,CAAC,WAAW,EAAE;YACzC,MAAM,cAAc,GAAG,kBAAkB,CAAC,yBAAyB,CAAC,YAAY,EAAE,UAAU,CAAC,CAAC;YAC9F,MAAM,YAAY,GAAG,kBAAkB,CAAC,yBAAyB,CAAC,UAAU,EAAE,UAAU,CAAC,CAAC;YAC1F,IAAI,cAAc,KAAK,IAAI,IAAI,YAAY,KAAK,IAAI,EAAE;gBACpD,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;aACrC;iBACI;gBACH,IAAI,cAAc,KAAK,IAAI,EAAE;oBAC3B,MAAM,QAAQ,GAAG,YAAY,CAAC,cAAc,CAAC,CAAC;oBAC9C,UAAU,CAAC,MAAM,CAAC,QAAQ,EAAE,cAAc,CAAC,CAAC;oBAC5C,YAAY,CAAC,MAAM,CAAC,cAAc,EAAE,CAAC,CAAC,CAAC;iBACxC;qBACI;oBACH,UAAU,CAAC,WAAW,EAAE,CAAC;iBAC1B;gBAED,IAAI,YAAY,KAAK,IAAI,EAAE;oBACzB,MAAM,QAAQ,GAAG,UAAU,CAAC,YAAY,CAAC,CAAC;oBAC1C,UAAU,CAAC,MAAM,CAAC,QAAQ,EAAE,cAAc,CAAC,CAAC;oBAC5C,UAAU,CAAC,MAAM,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC;iBACpC;qBACI;oBACH,UAAU,CAAC,QAAQ,EAAE,CAAC;iBACvB;aACF;SACF;IACH,CAAC;IAEO,YAAY;QAClB,IAAI,IAAI,CAAC,cAAc,EAAE;YACvB,YAAY,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;YAClC,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;SAC5B;IACH,CAAC;IAEO,2BAA2B;QACjC,sJAAsJ;QACtJ,IAAI,IAAI,CAAC,WAAW,EAAE,IAAI,KAAK,CAAC,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjD,OAAM;SACP;QAED,MAAM,QAAQ,GAAG,IAAI,CAAC,gBAAgB,EAAE,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC1D,IAAI,CAAC,QAAQ,EAAE;YACb,OAAO;SACR;QAED,MAAM,QAAQ,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,cAAc,EAAE,EAAE,KAAK,QAAQ,IAAI,IAAI,CAAC,YAAY,EAAE,EAAE,KAAK,QAAQ,CAAC,CAAC;QACvI,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;IAC3B,CAAC;IAGO,2BAA2B;QACjC,IAAI,kBAAkB,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACjD,IAAI,CAAC,kBAAkB,EAAE;YACvB,kBAAkB,GAAG,EAAE,CAAC;SACzB;QAED,kBAAkB,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,cAAc,EAAE,EAAE,IAAI,IAAI,CAAC,QAAQ,CAAC,YAAY,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;QAChI,6BAA6B;QAC7B,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC,iBAAiB,EAAE,IAAI,CAAC,SAAS,CAAC,kBAAkB,CAAC,CAAC,CAAC;IACnF,CAAC;IAEO,gBAAgB;QACtB,MAAM,IAAI,GAAG,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;QAC1D,IAAI;YACF,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;SACzB;QACD,MAAM;YACJ,OAAO,IAAI,CAAC;SACb;IACH,CAAC;IAEO,mBAAmB;QACzB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;IAC3C,CAAC;;+GAnVU,kBAAkB,yFA8DnB,iBAAiB;mHA9DhB,kBAAkB,cAFjB,MAAM;2FAEP,kBAAkB;kBAH9B,UAAU;mBAAC;oBACV,UAAU,EAAE,MAAM;iBACnB;;0BA+DI,MAAM;2BAAC,iBAAiB","sourcesContent":["import { Inject, Injectable } from '@angular/core';\r\nimport { forkJoin, Observable, Subject, tap } from 'rxjs';\r\nimport { MT_TERM_API_TOKEN } from '../../../injection-tokens';\r\nimport { TldTranslateConfigService } from '../../tld-common/services';\r\nimport { EngineTermCollectionSource } from './engine-term/models';\r\nimport { CombinedCollection } from './models/combined-collection.model';\r\nimport { MtCollectionStatus } from './models/mt-collection-status.enum';\r\nimport { IMtTermService } from './models/mt-term-service.model';\r\nimport { TermApiService } from './term-api/term-api.service';\r\n\r\n@Injectable({\r\n  providedIn: 'root'\r\n})\r\nexport class TerminologyService {\r\n\r\n  private _selected: CombinedCollection = null;\r\n  get selected() { return this._selected; }\r\n  set selected(val: CombinedCollection) {\r\n    this._selected = val;\r\n    this.storeSelectedInLocalStorage();\r\n    if (!this._selected) {\r\n      return;\r\n    }\r\n\r\n    if (!this._selected.mtCollection) {\r\n      this.addToEngine(this._selected);\r\n    }\r\n\r\n  }\r\n\r\n  private isAnyImporting: boolean;\r\n\r\n\r\n  private _hasAnyCollections: boolean;\r\n  get hasAnyCollections() {\r\n    return this._hasAnyCollections;\r\n  }\r\n\r\n\r\n  get shouldShowPromotion() {\r\n    return !this.hasAnyCollections && !this.hasEditPermissions;\r\n  }\r\n\r\n  get canCreateCollections() {\r\n    return this.config.termConfig.canCreateCollection;\r\n  }\r\n\r\n  get hasEditPermissions() {\r\n    return this.config?.coreConfig.isAuth && this.canCreateCollections && this.config.termConfig.isTermPortalSupported;\r\n  }\r\n\r\n  private _isRefreshingCollections: boolean;\r\n  get isRefreshingCollections() {\r\n    return this._isRefreshingCollections;\r\n  }\r\n\r\n  private _collections: Set<CombinedCollection>;\r\n  get collections() {\r\n    return this._collections;\r\n  }\r\n\r\n  private readonly onDataUpdate = new Subject<Set<CombinedCollection>>();\r\n\r\n  private readonly LOCAL_STORAGE_KEY = \"systemLastCollections\";\r\n  private engineId: string;\r\n  // stores language codes which are used to filter visble collections from term api.\r\n  private engineLanguages: string[];\r\n  private refreshTimeout: any;\r\n  // soft refresh takes in account other params as well.\r\n  private isSoftAutoRefreshOn: boolean;\r\n  // should do autorefresh by ignoring any other params.\r\n  private hardAutoRefresh: boolean;\r\n\r\n  constructor(private readonly config: TldTranslateConfigService,\r\n    private readonly termApi: TermApiService,\r\n    @Inject(MT_TERM_API_TOKEN) private mtApi: IMtTermService) { }\r\n\r\n  setEngine(engineId: string, languages: string[] = null, setSelectedFromLocalStorage = false): Observable<Set<CombinedCollection>> {\r\n    // engine is already set with that ID and no need to refresh it.\r\n    if (engineId !== this.engineId || JSON.stringify(languages) !== JSON.stringify(this.engineLanguages)) {\r\n      this.engineLanguages = languages;\r\n      this.engineId = engineId;\r\n      this._collections = new Set();\r\n      this.emitDataUpdateEvent();\r\n      // avoiding setter, so the null value is not storeed in location since it is not by user action\r\n      this._selected = null;\r\n    }\r\n\r\n    if (this.engineId) {\r\n      this.refreshCollections(setSelectedFromLocalStorage, true);\r\n    }\r\n\r\n    return this.onDataUpdate.asObservable();\r\n  }\r\n\r\n  refreshCollections(setSelectedFromLocalStorage = false, initialRefresh = false) {\r\n    if (!this.engineId || !this.config.termConfig.isCollectionsActivated || this.isRefreshingCollections) {\r\n      return;\r\n    }\r\n\r\n    // clear timeout since this refresh replaces scheduled\r\n    this.clearTimeout();\r\n\r\n    this._isRefreshingCollections = true;\r\n\r\n    let termResponse: CombinedCollection[];\r\n    let mtApiResponse: CombinedCollection[];\r\n\r\n    const observables: Observable<CombinedCollection[]>[] = [\r\n      this.termApi.getCollectionList(this.engineLanguages)\r\n        .pipe(\r\n          tap((response) => termResponse = response)\r\n        ),\r\n      this.mtApi.getList(this.engineId)\r\n        .pipe(\r\n          tap((response) => mtApiResponse = response)\r\n        ),\r\n    ];\r\n    forkJoin(observables).subscribe({\r\n      // do not need response becaue responses are saved in pipe methods\r\n      next: () => {\r\n        this.isAnyImporting = false;\r\n        // note that termResponse and mtapiresponse gets changed during remove method\r\n        this.removeDeleted(termResponse, mtApiResponse, initialRefresh);\r\n        this.addCollections([...mtApiResponse, ...termResponse], initialRefresh);\r\n        if (setSelectedFromLocalStorage) {\r\n          this.setSelectedFromLocalStorage();\r\n        }\r\n        this._isRefreshingCollections = false;\r\n        this.scheduleRefresh();\r\n      },\r\n      error: (error) => {\r\n        this._isRefreshingCollections = false;\r\n        // it is enough to show error only in console. No special thing is necessary.\r\n        console.error(error);\r\n      },\r\n    });\r\n  }\r\n\r\n  addToEngine(collection: CombinedCollection) {\r\n    if (!collection || !collection.termCollection) {\r\n      console.error(\"Trying to attach collection that has no tilde term id.\");\r\n      return;\r\n    }\r\n    // collection.mtStatus = MtCollectionStatus.PROCESSING;\r\n    // collection.isSynchronized = true;\r\n    this.mtApi.add(this.engineId, collection)\r\n      .subscribe({\r\n        error: () => {\r\n          // collection.mtStatus = MtCollectionStatus.ERROR;\r\n          // collection.errorKey = ErrorCode.COLLECTION_IMPORT;\r\n        }\r\n      })\r\n\r\n  }\r\n\r\n  create(sourceLanguage: string, targetLanguage: string, collectionName: string, redirectToEdit = true) {\r\n    return this.termApi.createCollection([sourceLanguage, targetLanguage], collectionName).pipe(\r\n      tap((collection) => {\r\n        if (redirectToEdit) {\r\n          window.open(this.termApi.getEditLink(collection.termCollection.id, sourceLanguage, targetLanguage), \"_blank\");\r\n        }\r\n        this._collections.add(collection);\r\n        this.emitDataUpdateEvent();\r\n        this._hasAnyCollections = true;\r\n      })\r\n    );\r\n  }\r\n\r\n  updateIfNecessary(collection: CombinedCollection) {\r\n    // collection is not imported and should be attached to engine\r\n    if (collection.isEdited()) {\r\n      this.mtApi.add(this.engineId, collection).subscribe((updatedCollection) => {\r\n        collection.update(updatedCollection);\r\n      });\r\n    }\r\n  }\r\n\r\n  /**\r\n *\r\n * @returns selected collection id if it is allowed to use collection for translations\r\n */\r\n  selectedIdForTranslation(): string {\r\n    if (this.selected?.mtCollection && (this.selected.mtCollection.lastUpdated || this.selected.mtCollection?.status === MtCollectionStatus.READY)) {\r\n      return this.selected.mtCollection?.id;\r\n    }\r\n    return null;\r\n  }\r\n\r\n  startAutoRefresh(engineId?: string, languages: string[] = null, setSelectedFromLocalStorage = false) {\r\n    this.hardAutoRefresh = true;\r\n    return this.setEngine(engineId ?? this.engineId, languages ?? this.engineLanguages, setSelectedFromLocalStorage);\r\n  }\r\n\r\n  stopAutoRefresh() {\r\n    this.clearTimeout();\r\n\r\n    this.isSoftAutoRefreshOn = false;\r\n    this.hardAutoRefresh = false;\r\n  }\r\n\r\n  removeMtCollection(collection: CombinedCollection, engineId = this.engineId) {\r\n    return this.mtApi.remove(engineId, collection).pipe(\r\n      tap((response) => {\r\n        collection.update(response);\r\n      })\r\n    );\r\n  }\r\n\r\n  private scheduleRefresh(timeout?: number) {\r\n    // if menu is closed and selected collection is not importing anymore - auto refreshing should be cancelled.\r\n    if (!this.hardAutoRefresh && !this.selected?.isImporting && this.isSoftAutoRefreshOn) {\r\n      this.stopAutoRefresh();\r\n      return;\r\n    }\r\n\r\n    // if hard auto refresho on, auto refresh should be on. If hard autoreferesh is off , refresh needs to be done only if selected is importing.\r\n    if (this.hardAutoRefresh || (!this.refreshTimeout && (this.isSoftAutoRefreshOn || this.selected?.isImporting))) {\r\n      const timeoutMs = timeout ?? (this.isAnyImporting ? this.config.termConfig.refreshTimeoutMsWhenImporting : this.config.termConfig.refreshTimeoutMs);\r\n      this.refreshTimeout = setTimeout(() => {\r\n        this.refreshTimeout = null;\r\n        this.refreshCollections()\r\n      }, timeoutMs);\r\n    }\r\n  }\r\n\r\n  /**\r\n   *\r\n   * @param newCollections\r\n   * @param initialRefresh Whether also editable collection fields should be updated. If not initial refresh, editable fields will not be updated.\r\n   */\r\n  private addCollections(newCollections: Iterable<CombinedCollection>, initialRefresh: boolean) {\r\n    // sets collection list to this value at the end, so deleted collections are not in the list.\r\n    for (let collection of newCollections) {\r\n      // User shouldn't see failed collections if he can't retry to import them.\r\n      if (!this.hasEditPermissions\r\n        && collection.mtStatus === MtCollectionStatus.ERROR) {\r\n        continue;\r\n      }\r\n\r\n      if (collection.isImporting) {\r\n        this.isAnyImporting = true;\r\n      }\r\n      let existing: CombinedCollection = CombinedCollection.findExistingCollectionFromList(this.collections, collection);\r\n\r\n      // If term api doesn't have engine languages, collection should not be shown (if it is not already imported somehow);\r\n      if (!existing && collection.source === EngineTermCollectionSource.TILDE_TERM) {\r\n        let hasLanguages = true;\r\n        for (let i = 0; i < this.engineLanguages?.length; i++) {\r\n          if (!collection.termCollection.languages?.find(lang => lang.id === this.engineLanguages[i])) {\r\n            hasLanguages = false;\r\n            break;\r\n          }\r\n        }\r\n\r\n        if (!hasLanguages) {\r\n          continue;\r\n        }\r\n      }\r\n\r\n      if (!existing) {\r\n        this._collections.add(collection);\r\n      }\r\n      else {\r\n        existing.update(collection, initialRefresh);\r\n      }\r\n    }\r\n\r\n    // this._collections = updatedCollections;\r\n    this.emitDataUpdateEvent();\r\n    this._hasAnyCollections = this._collections.size > 0;\r\n  }\r\n\r\n  /**\r\n   * Should be called after refresh to check if there is any collections from api that are deleted.\r\n   */\r\n  private removeDeleted(termResponse: CombinedCollection[], mtResponse: CombinedCollection[], initialRefresh: boolean) {\r\n\r\n    for (const collection of this.collections) {\r\n      const termExistingIx = CombinedCollection.findExistingIndexFromList(termResponse, collection);\r\n      const mtExistingIx = CombinedCollection.findExistingIndexFromList(mtResponse, collection);\r\n      if (termExistingIx === null && mtExistingIx === null) {\r\n        this.collections.delete(collection);\r\n      }\r\n      else {\r\n        if (termExistingIx !== null) {\r\n          const existing = termResponse[termExistingIx];\r\n          collection.update(existing, initialRefresh);\r\n          termResponse.splice(termExistingIx, 1);\r\n        }\r\n        else {\r\n          collection.deleteTerms();\r\n        }\r\n\r\n        if (mtExistingIx !== null) {\r\n          const existing = mtResponse[mtExistingIx];\r\n          collection.update(existing, initialRefresh);\r\n          mtResponse.splice(mtExistingIx, 1);\r\n        }\r\n        else {\r\n          collection.deleteMT();\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  private clearTimeout() {\r\n    if (this.refreshTimeout) {\r\n      clearTimeout(this.refreshTimeout);\r\n      this.refreshTimeout = null;\r\n    }\r\n  }\r\n\r\n  private setSelectedFromLocalStorage() {\r\n    // If no collections or selected is already set, it should not be changed from localstorage value. (Usually, localstorage should have the same value).\r\n    if (this.collections?.size === 0 || this.selected) {\r\n      return\r\n    }\r\n\r\n    const storedId = this.readLocalStorage()?.[this.engineId];\r\n    if (!storedId) {\r\n      return;\r\n    }\r\n\r\n    const existing = Array.from(this.collections).find(item => item.termCollection?.id === storedId || item.mtCollection?.id === storedId);\r\n    this.selected = existing;\r\n  }\r\n\r\n\r\n  private storeSelectedInLocalStorage() {\r\n    let localStorageObject = this.readLocalStorage();\r\n    if (!localStorageObject) {\r\n      localStorageObject = {};\r\n    }\r\n\r\n    localStorageObject[this.engineId] = this.selected ? (this.selected.termCollection?.id ?? this.selected.mtCollection?.id) : null;\r\n    // store term id if it exists\r\n    localStorage.setItem(this.LOCAL_STORAGE_KEY, JSON.stringify(localStorageObject));\r\n  }\r\n\r\n  private readLocalStorage(): any {\r\n    const data = localStorage.getItem(this.LOCAL_STORAGE_KEY);\r\n    try {\r\n      return JSON.parse(data);\r\n    }\r\n    catch {\r\n      return null;\r\n    }\r\n  }\r\n\r\n  private emitDataUpdateEvent() {\r\n    this.onDataUpdate.next(this.collections);\r\n  }\r\n}\r\n"]}
@@ -1,19 +1,34 @@
1
1
  import { Component } from '@angular/core';
2
2
  import * as i0 from "@angular/core";
3
- import * as i1 from "../services/tld-term-collections.service";
4
- import * as i2 from "@angular/common";
5
- import * as i3 from "../tld-term-collection-list/tld-term-collection-list.component";
6
- import * as i4 from "../tld-term-promotion/tld-term-promotion.component";
3
+ import * as i1 from "../services/terminology.service";
4
+ import * as i2 from "../../tld-tooltip/services/tld-system.service";
5
+ import * as i3 from "@angular/common";
6
+ import * as i4 from "@angular/flex-layout/flex";
7
+ import * as i5 from "../tld-term-collection-list/tld-term-collection-list.component";
8
+ import * as i6 from "../tld-term-promotion/tld-term-promotion.component";
9
+ import * as i7 from "../create-collection/create-collection.component";
7
10
  export class TldTermCollectionComponent {
8
- constructor(terms) {
9
- this.terms = terms;
11
+ constructor(terminologyService, systemService) {
12
+ this.terminologyService = terminologyService;
13
+ this.systemService = systemService;
14
+ }
15
+ get promotion() { return this.terminologyService.shouldShowPromotion; }
16
+ get hasEditPermissions() { return this.terminologyService.hasEditPermissions; }
17
+ ngOnInit() {
18
+ this.subscription = this.systemService.getActiveData().subscribe((data) => {
19
+ this.sourceLanguageCode = data.sourceLang.lang;
20
+ this.targetLanguageCode = data.targetLang.lang;
21
+ this.terminologyService.setEngine(data.systemId, [this.sourceLanguageCode, this.targetLanguageCode]);
22
+ });
23
+ }
24
+ ngOnDestroy() {
25
+ this.subscription.unsubscribe();
10
26
  }
11
- get promotion() { return this.terms.shouldShowPromotion; }
12
27
  }
13
- TldTermCollectionComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TldTermCollectionComponent, deps: [{ token: i1.TldTermCollectionsService }], target: i0.ɵɵFactoryTarget.Component });
14
- TldTermCollectionComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: TldTermCollectionComponent, selector: "tld-term-collection", ngImport: i0, template: "<section class=\"tld-collection-list-wrapper\">\r\n <ng-container *ngIf=\"!promotion\">\r\n <tld-term-collection-list></tld-term-collection-list>\r\n </ng-container>\r\n <ng-container *ngIf=\"promotion\">\r\n <tld-term-promotion></tld-term-promotion>\r\n </ng-container>\r\n</section>", styles: [""], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.TldTermCollectionListComponent, selector: "tld-term-collection-list" }, { kind: "component", type: i4.TldTermPromotionComponent, selector: "tld-term-promotion" }] });
28
+ TldTermCollectionComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TldTermCollectionComponent, deps: [{ token: i1.TerminologyService }, { token: i2.TldSystemService }], target: i0.ɵɵFactoryTarget.Component });
29
+ TldTermCollectionComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: TldTermCollectionComponent, selector: "tld-term-collection", ngImport: i0, template: "<section class=\"tld-collection-list-wrapper\">\r\n <ng-container *ngIf=\"!promotion\">\r\n <tld-term-collection-list></tld-term-collection-list>\r\n <footer class=\"tld-collection-list-footer\" fxLayout=\"row\" *ngIf=\"hasEditPermissions\">\r\n <tld-create-collection [sourceLanguageCode]=\"sourceLanguageCode\" [targetLanguageCode]=\"targetLanguageCode\">\r\n </tld-create-collection>\r\n </footer>\r\n </ng-container>\r\n <ng-container *ngIf=\"promotion\">\r\n <tld-term-promotion></tld-term-promotion>\r\n </ng-container>\r\n</section>\r\n", styles: [".tld-collection-list-footer{padding:1em .75em}\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.DefaultLayoutDirective, selector: " [fxLayout], [fxLayout.xs], [fxLayout.sm], [fxLayout.md], [fxLayout.lg], [fxLayout.xl], [fxLayout.lt-sm], [fxLayout.lt-md], [fxLayout.lt-lg], [fxLayout.lt-xl], [fxLayout.gt-xs], [fxLayout.gt-sm], [fxLayout.gt-md], [fxLayout.gt-lg]", inputs: ["fxLayout", "fxLayout.xs", "fxLayout.sm", "fxLayout.md", "fxLayout.lg", "fxLayout.xl", "fxLayout.lt-sm", "fxLayout.lt-md", "fxLayout.lt-lg", "fxLayout.lt-xl", "fxLayout.gt-xs", "fxLayout.gt-sm", "fxLayout.gt-md", "fxLayout.gt-lg"] }, { kind: "component", type: i5.TldTermCollectionListComponent, selector: "tld-term-collection-list" }, { kind: "component", type: i6.TldTermPromotionComponent, selector: "tld-term-promotion" }, { kind: "component", type: i7.CreateCollectionComponent, selector: "tld-create-collection", inputs: ["sourceLanguageCode", "targetLanguageCode"] }] });
15
30
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TldTermCollectionComponent, decorators: [{
16
31
  type: Component,
17
- args: [{ selector: 'tld-term-collection', template: "<section class=\"tld-collection-list-wrapper\">\r\n <ng-container *ngIf=\"!promotion\">\r\n <tld-term-collection-list></tld-term-collection-list>\r\n </ng-container>\r\n <ng-container *ngIf=\"promotion\">\r\n <tld-term-promotion></tld-term-promotion>\r\n </ng-container>\r\n</section>" }]
18
- }], ctorParameters: function () { return [{ type: i1.TldTermCollectionsService }]; } });
19
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGxkLXRlcm0tY29sbGVjdGlvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90bGQtdHJhbnNsYXRlL3NyYy9saWIvbW9kdWxlcy90bGQtdGVybS90bGQtdGVybS1jb2xsZWN0aW9uL3RsZC10ZXJtLWNvbGxlY3Rpb24uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdGxkLXRyYW5zbGF0ZS9zcmMvbGliL21vZHVsZXMvdGxkLXRlcm0vdGxkLXRlcm0tY29sbGVjdGlvbi90bGQtdGVybS1jb2xsZWN0aW9uLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7Ozs7OztBQVExQyxNQUFNLE9BQU8sMEJBQTBCO0lBR3JDLFlBQTZCLEtBQWdDO1FBQWhDLFVBQUssR0FBTCxLQUFLLENBQTJCO0lBQUksQ0FBQztJQUZsRSxJQUFJLFNBQVMsS0FBSyxPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsbUJBQW1CLENBQUMsQ0FBQyxDQUFDOzt1SEFEL0MsMEJBQTBCOzJHQUExQiwwQkFBMEIsMkRDUnZDLHdTQU9VOzJGRENHLDBCQUEwQjtrQkFMdEMsU0FBUzsrQkFDRSxxQkFBcUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgVGxkVGVybUNvbGxlY3Rpb25zU2VydmljZSB9IGZyb20gJy4uL3NlcnZpY2VzL3RsZC10ZXJtLWNvbGxlY3Rpb25zLnNlcnZpY2UnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICd0bGQtdGVybS1jb2xsZWN0aW9uJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vdGxkLXRlcm0tY29sbGVjdGlvbi5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vdGxkLXRlcm0tY29sbGVjdGlvbi5jb21wb25lbnQuc2NzcyddXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBUbGRUZXJtQ29sbGVjdGlvbkNvbXBvbmVudCB7XHJcbiAgZ2V0IHByb21vdGlvbigpIHsgcmV0dXJuIHRoaXMudGVybXMuc2hvdWxkU2hvd1Byb21vdGlvbjsgfVxyXG5cclxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHJlYWRvbmx5IHRlcm1zOiBUbGRUZXJtQ29sbGVjdGlvbnNTZXJ2aWNlKSB7IH1cclxufVxyXG4iLCI8c2VjdGlvbiBjbGFzcz1cInRsZC1jb2xsZWN0aW9uLWxpc3Qtd3JhcHBlclwiPlxyXG4gIDxuZy1jb250YWluZXIgKm5nSWY9XCIhcHJvbW90aW9uXCI+XHJcbiAgICA8dGxkLXRlcm0tY29sbGVjdGlvbi1saXN0PjwvdGxkLXRlcm0tY29sbGVjdGlvbi1saXN0PlxyXG4gIDwvbmctY29udGFpbmVyPlxyXG4gIDxuZy1jb250YWluZXIgKm5nSWY9XCJwcm9tb3Rpb25cIj5cclxuICAgIDx0bGQtdGVybS1wcm9tb3Rpb24+PC90bGQtdGVybS1wcm9tb3Rpb24+XHJcbiAgPC9uZy1jb250YWluZXI+XHJcbjwvc2VjdGlvbj4iXX0=
32
+ args: [{ selector: 'tld-term-collection', template: "<section class=\"tld-collection-list-wrapper\">\r\n <ng-container *ngIf=\"!promotion\">\r\n <tld-term-collection-list></tld-term-collection-list>\r\n <footer class=\"tld-collection-list-footer\" fxLayout=\"row\" *ngIf=\"hasEditPermissions\">\r\n <tld-create-collection [sourceLanguageCode]=\"sourceLanguageCode\" [targetLanguageCode]=\"targetLanguageCode\">\r\n </tld-create-collection>\r\n </footer>\r\n </ng-container>\r\n <ng-container *ngIf=\"promotion\">\r\n <tld-term-promotion></tld-term-promotion>\r\n </ng-container>\r\n</section>\r\n", styles: [".tld-collection-list-footer{padding:1em .75em}\n"] }]
33
+ }], ctorParameters: function () { return [{ type: i1.TerminologyService }, { type: i2.TldSystemService }]; } });
34
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGxkLXRlcm0tY29sbGVjdGlvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90bGQtdHJhbnNsYXRlL3NyYy9saWIvbW9kdWxlcy90bGQtdGVybS90bGQtdGVybS1jb2xsZWN0aW9uL3RsZC10ZXJtLWNvbGxlY3Rpb24uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdGxkLXRyYW5zbGF0ZS9zcmMvbGliL21vZHVsZXMvdGxkLXRlcm0vdGxkLXRlcm0tY29sbGVjdGlvbi90bGQtdGVybS1jb2xsZWN0aW9uLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQXFCLE1BQU0sZUFBZSxDQUFDOzs7Ozs7Ozs7QUFVN0QsTUFBTSxPQUFPLDBCQUEwQjtJQVFyQyxZQUE2QixrQkFBc0MsRUFDaEQsYUFBK0I7UUFEckIsdUJBQWtCLEdBQWxCLGtCQUFrQixDQUFvQjtRQUNoRCxrQkFBYSxHQUFiLGFBQWEsQ0FBa0I7SUFBSSxDQUFDO0lBUnZELElBQUksU0FBUyxLQUFLLE9BQU8sSUFBSSxDQUFDLGtCQUFrQixDQUFDLG1CQUFtQixDQUFDLENBQUMsQ0FBQztJQUN2RSxJQUFJLGtCQUFrQixLQUFLLE9BQU8sSUFBSSxDQUFDLGtCQUFrQixDQUFDLGtCQUFrQixDQUFDLENBQUMsQ0FBQztJQVMvRSxRQUFRO1FBQ04sSUFBSSxDQUFDLFlBQVksR0FBRyxJQUFJLENBQUMsYUFBYSxDQUFDLGFBQWEsRUFBRSxDQUFDLFNBQVMsQ0FBQyxDQUFDLElBQUksRUFBRSxFQUFFO1lBQ3hFLElBQUksQ0FBQyxrQkFBa0IsR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQztZQUMvQyxJQUFJLENBQUMsa0JBQWtCLEdBQUcsSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUM7WUFDL0MsSUFBSSxDQUFDLGtCQUFrQixDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUMsSUFBSSxDQUFDLGtCQUFrQixFQUFFLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDLENBQUM7UUFDdkcsQ0FBQyxDQUFDLENBQUE7SUFDSixDQUFDO0lBRUQsV0FBVztRQUNULElBQUksQ0FBQyxZQUFZLENBQUMsV0FBVyxFQUFFLENBQUM7SUFDbEMsQ0FBQzs7dUhBckJVLDBCQUEwQjsyR0FBMUIsMEJBQTBCLDJEQ1Z2QywyakJBWUE7MkZERmEsMEJBQTBCO2tCQUx0QyxTQUFTOytCQUNFLHFCQUFxQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgT25EZXN0cm95LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgU3Vic2NyaXB0aW9uIH0gZnJvbSAncnhqcyc7XHJcbmltcG9ydCB7IFRsZFN5c3RlbVNlcnZpY2UgfSBmcm9tICcuLi8uLi90bGQtdG9vbHRpcC9zZXJ2aWNlcy90bGQtc3lzdGVtLnNlcnZpY2UnO1xyXG5pbXBvcnQgeyBUZXJtaW5vbG9neVNlcnZpY2UgfSBmcm9tICcuLi9zZXJ2aWNlcy90ZXJtaW5vbG9neS5zZXJ2aWNlJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAndGxkLXRlcm0tY29sbGVjdGlvbicsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL3RsZC10ZXJtLWNvbGxlY3Rpb24uY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL3RsZC10ZXJtLWNvbGxlY3Rpb24uY29tcG9uZW50LnNjc3MnXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgVGxkVGVybUNvbGxlY3Rpb25Db21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQsIE9uRGVzdHJveSB7XHJcbiAgZ2V0IHByb21vdGlvbigpIHsgcmV0dXJuIHRoaXMudGVybWlub2xvZ3lTZXJ2aWNlLnNob3VsZFNob3dQcm9tb3Rpb247IH1cclxuICBnZXQgaGFzRWRpdFBlcm1pc3Npb25zKCkgeyByZXR1cm4gdGhpcy50ZXJtaW5vbG9neVNlcnZpY2UuaGFzRWRpdFBlcm1pc3Npb25zOyB9XHJcblxyXG4gIHByaXZhdGUgc3Vic2NyaXB0aW9uOiBTdWJzY3JpcHRpb247XHJcbiAgc291cmNlTGFuZ3VhZ2VDb2RlOiBzdHJpbmc7XHJcbiAgdGFyZ2V0TGFuZ3VhZ2VDb2RlOiBzdHJpbmc7XHJcblxyXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgcmVhZG9ubHkgdGVybWlub2xvZ3lTZXJ2aWNlOiBUZXJtaW5vbG9neVNlcnZpY2UsXHJcbiAgICBwcml2YXRlIHJlYWRvbmx5IHN5c3RlbVNlcnZpY2U6IFRsZFN5c3RlbVNlcnZpY2UpIHsgfVxyXG5cclxuICBuZ09uSW5pdCgpOiB2b2lkIHtcclxuICAgIHRoaXMuc3Vic2NyaXB0aW9uID0gdGhpcy5zeXN0ZW1TZXJ2aWNlLmdldEFjdGl2ZURhdGEoKS5zdWJzY3JpYmUoKGRhdGEpID0+IHtcclxuICAgICAgdGhpcy5zb3VyY2VMYW5ndWFnZUNvZGUgPSBkYXRhLnNvdXJjZUxhbmcubGFuZztcclxuICAgICAgdGhpcy50YXJnZXRMYW5ndWFnZUNvZGUgPSBkYXRhLnRhcmdldExhbmcubGFuZztcclxuICAgICAgdGhpcy50ZXJtaW5vbG9neVNlcnZpY2Uuc2V0RW5naW5lKGRhdGEuc3lzdGVtSWQsIFt0aGlzLnNvdXJjZUxhbmd1YWdlQ29kZSwgdGhpcy50YXJnZXRMYW5ndWFnZUNvZGVdKTtcclxuICAgIH0pXHJcbiAgfVxyXG5cclxuICBuZ09uRGVzdHJveSgpOiB2b2lkIHtcclxuICAgIHRoaXMuc3Vic2NyaXB0aW9uLnVuc3Vic2NyaWJlKCk7XHJcbiAgfVxyXG59XHJcbiIsIjxzZWN0aW9uIGNsYXNzPVwidGxkLWNvbGxlY3Rpb24tbGlzdC13cmFwcGVyXCI+XHJcbiAgPG5nLWNvbnRhaW5lciAqbmdJZj1cIiFwcm9tb3Rpb25cIj5cclxuICAgIDx0bGQtdGVybS1jb2xsZWN0aW9uLWxpc3Q+PC90bGQtdGVybS1jb2xsZWN0aW9uLWxpc3Q+XHJcbiAgICA8Zm9vdGVyIGNsYXNzPVwidGxkLWNvbGxlY3Rpb24tbGlzdC1mb290ZXJcIiBmeExheW91dD1cInJvd1wiICpuZ0lmPVwiaGFzRWRpdFBlcm1pc3Npb25zXCI+XHJcbiAgICAgIDx0bGQtY3JlYXRlLWNvbGxlY3Rpb24gW3NvdXJjZUxhbmd1YWdlQ29kZV09XCJzb3VyY2VMYW5ndWFnZUNvZGVcIiBbdGFyZ2V0TGFuZ3VhZ2VDb2RlXT1cInRhcmdldExhbmd1YWdlQ29kZVwiPlxyXG4gICAgICA8L3RsZC1jcmVhdGUtY29sbGVjdGlvbj5cclxuICAgIDwvZm9vdGVyPlxyXG4gIDwvbmctY29udGFpbmVyPlxyXG4gIDxuZy1jb250YWluZXIgKm5nSWY9XCJwcm9tb3Rpb25cIj5cclxuICAgIDx0bGQtdGVybS1wcm9tb3Rpb24+PC90bGQtdGVybS1wcm9tb3Rpb24+XHJcbiAgPC9uZy1jb250YWluZXI+XHJcbjwvc2VjdGlvbj5cclxuIl19