@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
@@ -1,7 +0,0 @@
1
- export var ConvertedCollectionTooltipKey;
2
- (function (ConvertedCollectionTooltipKey) {
3
- ConvertedCollectionTooltipKey["NO_ENTRIES"] = "NO_ENTRIES";
4
- ConvertedCollectionTooltipKey["IMPORTING"] = "IMPORTING";
5
- ConvertedCollectionTooltipKey["SYNCING"] = "SYNCING";
6
- })(ConvertedCollectionTooltipKey || (ConvertedCollectionTooltipKey = {}));
7
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udmVydGVkLWNvbGxlY3Rpb24tdG9vbHRpcC1rZXkubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90bGQtdHJhbnNsYXRlL3NyYy9saWIvbW9kdWxlcy90bGQtdGVybS9tb2RlbHMvY29udmVydGVkLWNvbGxlY3Rpb24tdG9vbHRpcC1rZXkubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFOLElBQVksNkJBSVg7QUFKRCxXQUFZLDZCQUE2QjtJQUNyQywwREFBeUIsQ0FBQTtJQUN6Qix3REFBdUIsQ0FBQTtJQUN2QixvREFBbUIsQ0FBQTtBQUN2QixDQUFDLEVBSlcsNkJBQTZCLEtBQTdCLDZCQUE2QixRQUl4QyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBlbnVtIENvbnZlcnRlZENvbGxlY3Rpb25Ub29sdGlwS2V5e1xyXG4gICAgTk9fRU5UUklFUyA9IFwiTk9fRU5UUklFU1wiLFxyXG4gICAgSU1QT1JUSU5HID0gXCJJTVBPUlRJTkdcIixcclxuICAgIFNZTkNJTkcgPSBcIlNZTkNJTkdcIlxyXG59Il19
@@ -1,9 +0,0 @@
1
- /**
2
- * Enumerator to determine if collection imported from term api or mt
3
- */
4
- export var ConvertedCollectionType;
5
- (function (ConvertedCollectionType) {
6
- ConvertedCollectionType[ConvertedCollectionType["Term"] = 0] = "Term";
7
- ConvertedCollectionType[ConvertedCollectionType["MT"] = 1] = "MT";
8
- })(ConvertedCollectionType || (ConvertedCollectionType = {}));
9
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udmVydGVkLWNvbGxlY3Rpb24tdHlwZS5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3RsZC10cmFuc2xhdGUvc3JjL2xpYi9tb2R1bGVzL3RsZC10ZXJtL21vZGVscy9jb252ZXJ0ZWQtY29sbGVjdGlvbi10eXBlLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBQ0gsTUFBTSxDQUFOLElBQVksdUJBR1g7QUFIRCxXQUFZLHVCQUF1QjtJQUMvQixxRUFBSSxDQUFBO0lBQ0osaUVBQUUsQ0FBQTtBQUNOLENBQUMsRUFIVyx1QkFBdUIsS0FBdkIsdUJBQXVCLFFBR2xDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXHJcbiAqIEVudW1lcmF0b3IgdG8gZGV0ZXJtaW5lIGlmIGNvbGxlY3Rpb24gaW1wb3J0ZWQgZnJvbSB0ZXJtIGFwaSBvciBtdFxyXG4gKi9cclxuZXhwb3J0IGVudW0gQ29udmVydGVkQ29sbGVjdGlvblR5cGV7XHJcbiAgICBUZXJtLFxyXG4gICAgTVRcclxufSJdfQ==
@@ -1,7 +0,0 @@
1
- export * from './mt-api/tld-mt-term-collection.model';
2
- export * from './term-api/tld-term-collection.model';
3
- export * from './term-api/tld-term-collection-languages.model';
4
- export * from './tld-converted-collection.model';
5
- export * from './converted-collection-tooltip-key.model';
6
- export * from './converted-collection-type.model';
7
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90bGQtdHJhbnNsYXRlL3NyYy9saWIvbW9kdWxlcy90bGQtdGVybS9tb2RlbHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLHNDQUFzQyxDQUFDO0FBQ3JELGNBQWMsZ0RBQWdELENBQUM7QUFDL0QsY0FBYyxrQ0FBa0MsQ0FBQztBQUNqRCxjQUFjLDBDQUEwQyxDQUFDO0FBQ3pELGNBQWMsbUNBQW1DLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL210LWFwaS90bGQtbXQtdGVybS1jb2xsZWN0aW9uLm1vZGVsJztcclxuZXhwb3J0ICogZnJvbSAnLi90ZXJtLWFwaS90bGQtdGVybS1jb2xsZWN0aW9uLm1vZGVsJztcclxuZXhwb3J0ICogZnJvbSAnLi90ZXJtLWFwaS90bGQtdGVybS1jb2xsZWN0aW9uLWxhbmd1YWdlcy5tb2RlbCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vdGxkLWNvbnZlcnRlZC1jb2xsZWN0aW9uLm1vZGVsJztcclxuZXhwb3J0ICogZnJvbSAnLi9jb252ZXJ0ZWQtY29sbGVjdGlvbi10b29sdGlwLWtleS5tb2RlbCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vY29udmVydGVkLWNvbGxlY3Rpb24tdHlwZS5tb2RlbCc7XHJcbiJdfQ==
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGxkLW10LXRlcm0tY29sbGVjdGlvbi5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3RsZC10cmFuc2xhdGUvc3JjL2xpYi9tb2R1bGVzL3RsZC10ZXJtL21vZGVscy9tdC1hcGkvdGxkLW10LXRlcm0tY29sbGVjdGlvbi5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTXRDb2xsZWN0aW9uU3RhdHVzIH0gZnJvbSBcIi4uL210LWNvbGxlY3Rpb24tc3RhdHVzLm1vZGVsXCI7XHJcblxyXG4vKipcclxuICogSW50ZXJmYWNlIHRoYXQgZGVzY3JpYmVzIHN0cnVjdHVyZSByZXR1cm5lZCBmcm9tIEdldERldGFpbGVkVGVybUNvcnBvcmFcclxuICovXHJcbmV4cG9ydCBpbnRlcmZhY2UgSVRsZE1UVGVybUNvbGxlY3Rpb24ge1xyXG4gIENvcnB1c0lkOiBzdHJpbmc7XHJcbiAgTWVzc2FnZTogc3RyaW5nO1xyXG4gIFN0YXR1czogTXRDb2xsZWN0aW9uU3RhdHVzO1xyXG4gIFRpbGRlVGVybUlkOiBzdHJpbmc7XHJcbiAgVGl0bGU6IHN0cmluZztcclxuICBUeXBlOiBzdHJpbmc7XHJcbiAgQXR0YWNobWVudERhdGVUaW1lOiBzdHJpbmc7XHJcbiAgQ291bnQ6IG51bWJlcjtcclxuICBQcmVwYXJlZERhdGVUaW1lOiBzdHJpbmc7XHJcbn1cclxuIl19
@@ -1,7 +0,0 @@
1
- export var MtCollectionStatus;
2
- (function (MtCollectionStatus) {
3
- MtCollectionStatus["READY"] = "Ready";
4
- MtCollectionStatus["PROCESSING"] = "Processing";
5
- MtCollectionStatus["ERROR"] = "Error";
6
- })(MtCollectionStatus || (MtCollectionStatus = {}));
7
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibXQtY29sbGVjdGlvbi1zdGF0dXMubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90bGQtdHJhbnNsYXRlL3NyYy9saWIvbW9kdWxlcy90bGQtdGVybS9tb2RlbHMvbXQtY29sbGVjdGlvbi1zdGF0dXMubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFOLElBQVksa0JBSVg7QUFKRCxXQUFZLGtCQUFrQjtJQUMxQixxQ0FBZSxDQUFBO0lBQ2YsK0NBQXlCLENBQUE7SUFDekIscUNBQWUsQ0FBQTtBQUNuQixDQUFDLEVBSlcsa0JBQWtCLEtBQWxCLGtCQUFrQixRQUk3QiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBlbnVtIE10Q29sbGVjdGlvblN0YXR1c3tcclxuICAgIFJFQURZID0gXCJSZWFkeVwiLFxyXG4gICAgUFJPQ0VTU0lORyA9IFwiUHJvY2Vzc2luZ1wiLFxyXG4gICAgRVJST1IgPSBcIkVycm9yXCIgXHJcbn0iXX0=
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGxkLXRlcm0tY29sbGVjdGlvbi1sYW5ndWFnZXMubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90bGQtdHJhbnNsYXRlL3NyYy9saWIvbW9kdWxlcy90bGQtdGVybS9tb2RlbHMvdGVybS1hcGkvdGxkLXRlcm0tY29sbGVjdGlvbi1sYW5ndWFnZXMubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxyXG4gKiBUZXJtIGNvbGxlY3Rpb24gZnJvbSB0ZXJtIHBvcnRhbCBsYW5ndWFnZXMgcHJvcGVydHkgaW50ZXJmYWNlLlxyXG4gKi9cclxuZXhwb3J0IGludGVyZmFjZSBJVGxkVGVybUNvbGxlY3Rpb25MYW5ndWFnZXN7XHJcbiAgICAvKipcclxuICAgICAqIExhbmd1YWdlIGNvZGVcclxuICAgICAqL1xyXG4gICAgaWQ6IHN0cmluZztcclxuICAgIGNvdW50OiBudW1iZXI7XHJcbiAgICBuYW1lOiBzdHJpbmc7XHJcbn0iXX0=
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGxkLXRlcm0tY29sbGVjdGlvbi5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3RsZC10cmFuc2xhdGUvc3JjL2xpYi9tb2R1bGVzL3RsZC10ZXJtL21vZGVscy90ZXJtLWFwaS90bGQtdGVybS1jb2xsZWN0aW9uLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJVGxkVGVybUNvbGxlY3Rpb25MYW5ndWFnZXMgfSBmcm9tIFwiLi90bGQtdGVybS1jb2xsZWN0aW9uLWxhbmd1YWdlcy5tb2RlbFwiO1xyXG5cclxuZXhwb3J0IGludGVyZmFjZSBJVGxkVGVybUNvbGxlY3Rpb24ge1xyXG4gICAgYWxsb3dzVXNlc0Jlc2lkZXNER1Q6IGJvb2xlYW47XHJcbiAgICBhcHByb3ByaWF0bmVzc0ZvckRTSTogYm9vbGVhbjtcclxuICAgIGF0dHJpYnV0aW9uVGV4dDogc3RyaW5nO1xyXG4gICAgYmVsb25naW5nOiBhbnk7XHJcbiAgICBjYW5Eb3dubG9hZFB1YmxpYzogYm9vbGVhbjtcclxuICAgIGNsb3NlZDogYm9vbGVhbjtcclxuICAgIGNvbGxlY3Rpb25HdWlkOiBzdHJpbmc7XHJcbiAgICBjb2xsZWN0aW9uVGFnczogYW55W107XHJcbiAgICBjcEVtYWlsOiBzdHJpbmc7XHJcbiAgICBjcE5hbWU6IHN0cmluZztcclxuICAgIGNwT3JnYW5pemF0aW9uOiBzdHJpbmc7XHJcbiAgICBjcFN1cm5hbWU6IHN0cmluZztcclxuICAgIGNyZWF0ZURhdGU6IERhdGU7XHJcbiAgICBkZWZhdWx0RG9tYWluOiBhbnk7XHJcbiAgICBkZWZhdWx0TGFuZ3VhZ2VzOiBhbnk7XHJcbiAgICBkZXNjcmlwdGlvbjogc3RyaW5nO1xyXG4gICAgZG9tYWluSUQ6IGFueTtcclxuICAgIGRvbWFpbnM6IGFueTtcclxuICAgIGVscmNTaGFyZUlkOiBhbnk7XHJcbiAgICBlbnRyeUNvdW50OiBudW1iZXI7XHJcbiAgICBldXJvdm9jRG9tYWluSWQ6IGFueTtcclxuICAgIGV4dGVybmFsVXJpOiBzdHJpbmc7XHJcbiAgICBpZDogbnVtYmVyO1xyXG4gICAgaXByRW1haWw6IHN0cmluZztcclxuICAgIGlwck5hbWU6IHN0cmluZztcclxuICAgIGlwck9yZ2FuaXphdGlvbjogc3RyaW5nO1xyXG4gICAgaXByU3VybmFtZTogc3RyaW5nO1xyXG4gICAgaXNJbXBvcnRpbmc6IGJvb2xlYW47XHJcbiAgICBpc1BTSTogYm9vbGVhbjtcclxuICAgIGxhbmd1YWdlczogSVRsZFRlcm1Db2xsZWN0aW9uTGFuZ3VhZ2VzW107XHJcbiAgICBsaWNlbmNlOiBhbnk7XHJcbiAgICBtZXRhTm9yZElkOiBhbnk7XHJcbiAgICBtb2RpZnlEYXRlOiBzdHJpbmc7XHJcbiAgICBuYW1lOiBzdHJpbmc7XHJcbiAgICBvcmlnaW5hbE5hbWU6IHN0cmluZztcclxuICAgIG9yaWdpbmFsTmFtZUxhbmc6IHN0cmluZztcclxuICAgIG93bmVyR3JvdXBHdWlkOiBzdHJpbmc7XHJcbiAgICBwZXJtaXNzaW9uczogc3RyaW5nW107XHJcbiAgICBwdWJsaWM6IGJvb2xlYW47XHJcbiAgICByZXN0cmljdGlvbnNPZlVzZTogYW55O1xyXG4gICAgc291cmNlVVJMOiBzdHJpbmc7XHJcbiAgICB0YXJnZXRDb2xsZWN0aW9uSWQ6IGFueTtcclxuICAgIHR5cGU6IHN0cmluZztcclxufSJdfQ==
@@ -1,114 +0,0 @@
1
- import { ConvertedCollectionTooltipKey } from "./converted-collection-tooltip-key.model";
2
- import { ConvertedCollectionType } from "./converted-collection-type.model";
3
- import { MtCollectionStatus } from "./mt-collection-status.model";
4
- /**
5
- * Used to combine term collection interfaces from term api and MT api.
6
- */
7
- export class TldConvertedCollection {
8
- constructor(obj, sourceLanguageCode, targetLanguageCode) {
9
- this.sourceLanguageCode = sourceLanguageCode;
10
- this.targetLanguageCode = targetLanguageCode;
11
- this.isSynchronized = true;
12
- if (this.isTldCorpus(obj)) {
13
- this.fromTldMTCollection(obj);
14
- }
15
- else {
16
- this.fromTermApi(obj);
17
- }
18
- }
19
- get syncButtonVissible() {
20
- return !this.isSynchronized || (this.termModifiedDate && this.mtStatus === MtCollectionStatus.ERROR);
21
- }
22
- get isImporting() {
23
- return this.mtStatus === MtCollectionStatus.PROCESSING;
24
- }
25
- ;
26
- static findExistingCollectionFromList(termCollections, collection) {
27
- for (const col of termCollections) {
28
- if ((col.id && col.id === collection.id)
29
- || (collection.termId && col.termId === collection.termId)) {
30
- return col;
31
- }
32
- }
33
- return null;
34
- }
35
- update(obj) {
36
- if (obj.importedFrom === ConvertedCollectionType.MT) {
37
- if (obj.mtStatus !== MtCollectionStatus.ERROR) {
38
- this.errorKey = null;
39
- }
40
- this.id = obj.id;
41
- this.mtStatus = obj.mtStatus;
42
- this.mtAttachmentDateTime = obj.mtAttachmentDateTime;
43
- this.mtEntryCount = obj.mtEntryCount;
44
- }
45
- else if (obj.importedFrom === ConvertedCollectionType.Term) {
46
- this.termId = obj.termId;
47
- this.languagesString = obj.languagesString;
48
- this.termModifiedDate = obj.termModifiedDate;
49
- this.entryCount = obj.entryCount;
50
- this.title = obj.title;
51
- }
52
- this.isSynchronized = this.isTermSynchronizedWithMT();
53
- if (this.entryCount === 0 && this.termId !== null) {
54
- this.tooltipKey = ConvertedCollectionTooltipKey.NO_ENTRIES;
55
- }
56
- else if (this.isImporting && this.mtEntryCount === 0) {
57
- this.tooltipKey = ConvertedCollectionTooltipKey.IMPORTING;
58
- }
59
- else if (this.isImporting) {
60
- this.tooltipKey = ConvertedCollectionTooltipKey.SYNCING;
61
- }
62
- else {
63
- this.tooltipKey = null;
64
- }
65
- }
66
- deletedFromTermApi() {
67
- this.termId = null;
68
- this.languagesString = null;
69
- this.termModifiedDate = null;
70
- this.entryCount = null;
71
- }
72
- static convertCollections(collections, sourceLanguage, targetLanguage) {
73
- const converted = [];
74
- collections.forEach((collection) => {
75
- converted.push(new TldConvertedCollection(collection, sourceLanguage, targetLanguage));
76
- });
77
- return converted;
78
- }
79
- fromTermApi(obj) {
80
- this.termId = obj.id.toString();
81
- this.title = obj.name;
82
- this.importedFrom = ConvertedCollectionType.Term;
83
- this.termModifiedDate = new Date(obj.modifyDate);
84
- const language = obj.languages?.find(lang => lang.id.toLowerCase() === this.sourceLanguageCode.toLowerCase());
85
- this.entryCount = language?.count ?? 0;
86
- this.languagesString = obj.languages.filter(lang => lang.id !== this.sourceLanguageCode && lang.count > 0)
87
- .map(lang => lang.id.toUpperCase()).join(", ");
88
- }
89
- fromTldMTCollection(obj) {
90
- this.id = obj.CorpusId;
91
- this.title = obj.Title;
92
- this.importedFrom = ConvertedCollectionType.MT;
93
- this.mtAttachmentDateTime = new Date(obj.AttachmentDateTime);
94
- this.termId = obj.TildeTermId;
95
- this.mtStatus = obj.Status;
96
- this.mtPreparedDateTime = obj.PreparedDateTime;
97
- this.mtEntryCount = obj.Count;
98
- }
99
- isTldCorpus(obj) {
100
- return obj.TildeTermId !== undefined;
101
- }
102
- /**
103
- * Check if the newest version of the term collection is synchronized from Term portal.
104
- * Note. Term collections that are not linked from Term portal are considered as synchronized.
105
- */
106
- isTermSynchronizedWithMT() {
107
- let isSynchronized = true;
108
- if (this.termModifiedDate && this.mtAttachmentDateTime) {
109
- isSynchronized = this.termModifiedDate < this.mtAttachmentDateTime;
110
- }
111
- return isSynchronized;
112
- }
113
- }
114
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tld-converted-collection.model.js","sourceRoot":"","sources":["../../../../../../../projects/tld-translate/src/lib/modules/tld-term/models/tld-converted-collection.model.ts"],"names":[],"mappings":"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","sourcesContent":["import { ITldMTTermCollection, ITldTermCollection } from \".\";\r\nimport { ErrorCode } from \"../../tld-common/models/errors/error-codes.enum\";\r\nimport { ConvertedCollectionTooltipKey } from \"./converted-collection-tooltip-key.model\";\r\nimport { ConvertedCollectionType } from \"./converted-collection-type.model\";\r\nimport { MtCollectionStatus } from \"./mt-collection-status.model\";\r\n/**\r\n * Used to combine term collection interfaces from term api and MT api.\r\n */\r\nexport class TldConvertedCollection {\r\n    title: string;\r\n    id: string;\r\n    termId: string;\r\n    /** Entry count for source language from term api */\r\n    entryCount: number;\r\n    /** Entry count from MT api */\r\n    mtEntryCount: number;\r\n    sourceLanguageCode: string;\r\n    targetLanguageCode: string;\r\n    importedFrom: ConvertedCollectionType;\r\n    mtAttachmentDateTime: Date;\r\n    termModifiedDate: Date;\r\n    isSynchronized: boolean;\r\n    languagesString: string;\r\n    tooltipKey: ConvertedCollectionTooltipKey;\r\n    mtStatus: MtCollectionStatus;\r\n    errorKey: ErrorCode;\r\n    mtPreparedDateTime: string;\r\n\r\n\r\n    get syncButtonVissible() {\r\n        return !this.isSynchronized || (this.termModifiedDate && this.mtStatus === MtCollectionStatus.ERROR);\r\n    }\r\n\r\n    get isImporting(): boolean {\r\n        return this.mtStatus === MtCollectionStatus.PROCESSING;\r\n    };\r\n\r\n    constructor(obj: ITldTermCollection | ITldMTTermCollection, sourceLanguageCode: string, targetLanguageCode: string) {\r\n        this.sourceLanguageCode = sourceLanguageCode;\r\n        this.targetLanguageCode = targetLanguageCode;\r\n        this.isSynchronized = true;\r\n\r\n        if (this.isTldCorpus(obj)) {\r\n            this.fromTldMTCollection(obj);\r\n        }\r\n        else {\r\n            this.fromTermApi(obj);\r\n        }\r\n    }\r\n\r\n    static findExistingCollectionFromList(termCollections: Set<TldConvertedCollection>, collection: TldConvertedCollection) {\r\n        for (const col of termCollections) {\r\n            if ((col.id && col.id === collection.id)\r\n                || (collection.termId && col.termId === collection.termId)) {\r\n                return col;\r\n            }\r\n        }\r\n        return null;\r\n    }\r\n\r\n    update(obj: TldConvertedCollection) {\r\n        if (obj.importedFrom === ConvertedCollectionType.MT) {\r\n            if (obj.mtStatus !== MtCollectionStatus.ERROR) {\r\n                this.errorKey = null;\r\n            }\r\n            this.id = obj.id;\r\n            this.mtStatus = obj.mtStatus;\r\n            this.mtAttachmentDateTime = obj.mtAttachmentDateTime;\r\n            this.mtEntryCount = obj.mtEntryCount;\r\n        }\r\n        else if (obj.importedFrom === ConvertedCollectionType.Term) {\r\n            this.termId = obj.termId;\r\n            this.languagesString = obj.languagesString;\r\n            this.termModifiedDate = obj.termModifiedDate;\r\n            this.entryCount = obj.entryCount;\r\n            this.title = obj.title;\r\n        }\r\n        this.isSynchronized = this.isTermSynchronizedWithMT();\r\n\r\n        if (this.entryCount === 0 && this.termId !== null) {\r\n            this.tooltipKey = ConvertedCollectionTooltipKey.NO_ENTRIES;\r\n        }\r\n        else if (this.isImporting && this.mtEntryCount === 0) {\r\n            this.tooltipKey = ConvertedCollectionTooltipKey.IMPORTING;\r\n        }\r\n        else if (this.isImporting) {\r\n            this.tooltipKey = ConvertedCollectionTooltipKey.SYNCING;\r\n        }\r\n        else {\r\n            this.tooltipKey = null;\r\n        }\r\n\r\n    }\r\n\r\n    deletedFromTermApi() {\r\n        this.termId = null;\r\n        this.languagesString = null;\r\n        this.termModifiedDate = null;\r\n        this.entryCount = null;\r\n    }\r\n\r\n    static convertCollections(collections: ITldMTTermCollection[] | ITldTermCollection[], sourceLanguage: string, targetLanguage: string) {\r\n        const converted: TldConvertedCollection[] = [];\r\n        collections.forEach((collection) => {\r\n            converted.push(new TldConvertedCollection(collection, sourceLanguage, targetLanguage));\r\n        });\r\n        return converted;\r\n    }\r\n\r\n    private fromTermApi(obj: ITldTermCollection) {\r\n        this.termId = obj.id.toString();\r\n        this.title = obj.name;\r\n        this.importedFrom = ConvertedCollectionType.Term;\r\n        this.termModifiedDate = new Date(obj.modifyDate);\r\n        const language = obj.languages?.find(lang => lang.id.toLowerCase() === this.sourceLanguageCode.toLowerCase());\r\n        this.entryCount = language?.count ?? 0;\r\n        this.languagesString = obj.languages.filter(lang => lang.id !== this.sourceLanguageCode && lang.count > 0)\r\n            .map(lang => lang.id.toUpperCase()).join(\", \");\r\n    }\r\n\r\n    private fromTldMTCollection(obj: ITldMTTermCollection) {\r\n        this.id = obj.CorpusId;\r\n        this.title = obj.Title;\r\n        this.importedFrom = ConvertedCollectionType.MT;\r\n        this.mtAttachmentDateTime = new Date(obj.AttachmentDateTime);\r\n        this.termId = obj.TildeTermId;\r\n        this.mtStatus = obj.Status;\r\n        this.mtPreparedDateTime = obj.PreparedDateTime;\r\n        this.mtEntryCount = obj.Count;\r\n    }\r\n\r\n    private isTldCorpus(obj: ITldTermCollection | ITldMTTermCollection): obj is ITldMTTermCollection {\r\n        return (obj as ITldMTTermCollection).TildeTermId !== undefined;\r\n    }\r\n\r\n    /**\r\n     * Check if the newest version of the term collection is synchronized from Term portal. \r\n     * Note. Term collections that are not linked from Term portal are considered as synchronized.\r\n    */\r\n    private isTermSynchronizedWithMT() {\r\n        let isSynchronized = true;\r\n        if (this.termModifiedDate && this.mtAttachmentDateTime) {\r\n            isSynchronized = this.termModifiedDate < this.mtAttachmentDateTime;\r\n        }\r\n        return isSynchronized;\r\n    }\r\n}"]}
@@ -1,33 +0,0 @@
1
- import { Injectable } from '@angular/core';
2
- import { map } from 'rxjs/operators';
3
- import { Common } from '../../tld-common/models';
4
- import { TldConvertedCollection } from '../models';
5
- import * as i0 from "@angular/core";
6
- import * as i1 from "@angular/common/http";
7
- import * as i2 from "../../tld-common/services";
8
- export class MtCollectionsApiService {
9
- constructor(http, config) {
10
- this.http = http;
11
- this.config = config;
12
- }
13
- attachTermsFromTildeTerm(systemId, tildeTermCollectionId) {
14
- const params = { systemID: systemId, tildeTermColectionID: tildeTermCollectionId };
15
- const url = `${this.config.coreConfig.translationServiceUrl}AttachTermsFromTildeTerm`;
16
- return this.http.get(url, { params });
17
- }
18
- loadMTCollections(systemId, sourceLanguage, targetLanguage) {
19
- const headers = Common.getAuthHeaders(this.config);
20
- const url = `${this.config.coreConfig.translationServiceUrl}GetDetailedSystemTermCorpora`;
21
- const params = { systemID: systemId };
22
- return this.http.get(url, { headers, params }).pipe(map((collections) => { return TldConvertedCollection.convertCollections(collections, sourceLanguage, targetLanguage); }));
23
- }
24
- }
25
- MtCollectionsApiService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: MtCollectionsApiService, deps: [{ token: i1.HttpClient }, { token: i2.TldTranslateConfigService }], target: i0.ɵɵFactoryTarget.Injectable });
26
- MtCollectionsApiService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: MtCollectionsApiService, providedIn: 'root' });
27
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: MtCollectionsApiService, decorators: [{
28
- type: Injectable,
29
- args: [{
30
- providedIn: 'root'
31
- }]
32
- }], ctorParameters: function () { return [{ type: i1.HttpClient }, { type: i2.TldTranslateConfigService }]; } });
33
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibXQtY29sbGVjdGlvbnMtYXBpLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90bGQtdHJhbnNsYXRlL3NyYy9saWIvbW9kdWxlcy90bGQtdGVybS9zZXJ2aWNlcy9tdC1jb2xsZWN0aW9ucy1hcGkuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzNDLE9BQU8sRUFBRSxHQUFHLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNyQyxPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFFakQsT0FBTyxFQUF3QixzQkFBc0IsRUFBRSxNQUFNLFdBQVcsQ0FBQzs7OztBQUt6RSxNQUFNLE9BQU8sdUJBQXVCO0lBRWxDLFlBQTZCLElBQWdCLEVBQzFCLE1BQWlDO1FBRHZCLFNBQUksR0FBSixJQUFJLENBQVk7UUFDMUIsV0FBTSxHQUFOLE1BQU0sQ0FBMkI7SUFBSSxDQUFDO0lBRXpELHdCQUF3QixDQUFDLFFBQWdCLEVBQUUscUJBQTZCO1FBQ3RFLE1BQU0sTUFBTSxHQUFHLEVBQUUsUUFBUSxFQUFFLFFBQVEsRUFBRSxvQkFBb0IsRUFBRSxxQkFBcUIsRUFBRSxDQUFDO1FBQ25GLE1BQU0sR0FBRyxHQUFHLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxVQUFVLENBQUMscUJBQXFCLDBCQUEwQixDQUFDO1FBQ3RGLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsR0FBRyxFQUFFLEVBQUUsTUFBTSxFQUFFLENBQUMsQ0FBQztJQUN4QyxDQUFDO0lBRUQsaUJBQWlCLENBQUMsUUFBZ0IsRUFBRSxjQUFxQixFQUFFLGNBQXNCO1FBQy9FLE1BQU0sT0FBTyxHQUFHLE1BQU0sQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQ25ELE1BQU0sR0FBRyxHQUFHLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxVQUFVLENBQUMscUJBQXFCLDhCQUE4QixDQUFDO1FBQzFGLE1BQU0sTUFBTSxHQUFHLEVBQUUsUUFBUSxFQUFFLFFBQVEsRUFBRSxDQUFDO1FBQ3RDLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQXlCLEdBQUcsRUFBRSxFQUFFLE9BQU8sRUFBRSxNQUFNLEVBQUUsQ0FBQyxDQUFDLElBQUksQ0FDekUsR0FBRyxDQUFDLENBQUMsV0FBVyxFQUFFLEVBQUUsR0FBRyxPQUFPLHNCQUFzQixDQUFDLGtCQUFrQixDQUFDLFdBQVcsRUFBRSxjQUFjLEVBQUUsY0FBYyxDQUFDLENBQUEsQ0FBQyxDQUFDLENBQUMsQ0FDeEgsQ0FBQztJQUNKLENBQUM7O29IQWxCVSx1QkFBdUI7d0hBQXZCLHVCQUF1QixjQUZ0QixNQUFNOzJGQUVQLHVCQUF1QjtrQkFIbkMsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBIdHRwQ2xpZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uL2h0dHAnO1xyXG5pbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IG1hcCB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcclxuaW1wb3J0IHsgQ29tbW9uIH0gZnJvbSAnLi4vLi4vdGxkLWNvbW1vbi9tb2RlbHMnO1xyXG5pbXBvcnQgeyBUbGRUcmFuc2xhdGVDb25maWdTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vdGxkLWNvbW1vbi9zZXJ2aWNlcyc7XHJcbmltcG9ydCB7IElUbGRNVFRlcm1Db2xsZWN0aW9uLCBUbGRDb252ZXJ0ZWRDb2xsZWN0aW9uIH0gZnJvbSAnLi4vbW9kZWxzJztcclxuXHJcbkBJbmplY3RhYmxlKHtcclxuICBwcm92aWRlZEluOiAncm9vdCdcclxufSlcclxuZXhwb3J0IGNsYXNzIE10Q29sbGVjdGlvbnNBcGlTZXJ2aWNlIHtcclxuXHJcbiAgY29uc3RydWN0b3IocHJpdmF0ZSByZWFkb25seSBodHRwOiBIdHRwQ2xpZW50LFxyXG4gICAgcHJpdmF0ZSByZWFkb25seSBjb25maWc6IFRsZFRyYW5zbGF0ZUNvbmZpZ1NlcnZpY2UpIHsgfVxyXG5cclxuICBhdHRhY2hUZXJtc0Zyb21UaWxkZVRlcm0oc3lzdGVtSWQ6IHN0cmluZywgdGlsZGVUZXJtQ29sbGVjdGlvbklkOiBzdHJpbmcpIHtcclxuICAgIGNvbnN0IHBhcmFtcyA9IHsgc3lzdGVtSUQ6IHN5c3RlbUlkLCB0aWxkZVRlcm1Db2xlY3Rpb25JRDogdGlsZGVUZXJtQ29sbGVjdGlvbklkIH07XHJcbiAgICBjb25zdCB1cmwgPSBgJHt0aGlzLmNvbmZpZy5jb3JlQ29uZmlnLnRyYW5zbGF0aW9uU2VydmljZVVybH1BdHRhY2hUZXJtc0Zyb21UaWxkZVRlcm1gO1xyXG4gICAgcmV0dXJuIHRoaXMuaHR0cC5nZXQodXJsLCB7IHBhcmFtcyB9KTtcclxuICB9XHJcblxyXG4gIGxvYWRNVENvbGxlY3Rpb25zKHN5c3RlbUlkOiBzdHJpbmcsIHNvdXJjZUxhbmd1YWdlOnN0cmluZywgdGFyZ2V0TGFuZ3VhZ2U6IHN0cmluZykge1xyXG4gICAgY29uc3QgaGVhZGVycyA9IENvbW1vbi5nZXRBdXRoSGVhZGVycyh0aGlzLmNvbmZpZyk7XHJcbiAgICBjb25zdCB1cmwgPSBgJHt0aGlzLmNvbmZpZy5jb3JlQ29uZmlnLnRyYW5zbGF0aW9uU2VydmljZVVybH1HZXREZXRhaWxlZFN5c3RlbVRlcm1Db3Jwb3JhYDtcclxuICAgIGNvbnN0IHBhcmFtcyA9IHsgc3lzdGVtSUQ6IHN5c3RlbUlkIH07XHJcbiAgICByZXR1cm4gdGhpcy5odHRwLmdldDxJVGxkTVRUZXJtQ29sbGVjdGlvbltdPih1cmwsIHsgaGVhZGVycywgcGFyYW1zIH0pLnBpcGUoXHJcbiAgICAgIG1hcCgoY29sbGVjdGlvbnMpID0+IHsgcmV0dXJuIFRsZENvbnZlcnRlZENvbGxlY3Rpb24uY29udmVydENvbGxlY3Rpb25zKGNvbGxlY3Rpb25zLCBzb3VyY2VMYW5ndWFnZSwgdGFyZ2V0TGFuZ3VhZ2UpIH0pXHJcbiAgICApO1xyXG4gIH1cclxufVxyXG4iXX0=
@@ -1,34 +0,0 @@
1
- import { Injectable } from '@angular/core';
2
- import { map } from 'rxjs/operators';
3
- import { TldConvertedCollection } from '../models/tld-converted-collection.model';
4
- import * as i0 from "@angular/core";
5
- import * as i1 from "../../tld-common/services";
6
- import * as i2 from "@angular/common/http";
7
- export class TermApiService {
8
- constructor(config, http) {
9
- this.config = config;
10
- this.http = http;
11
- }
12
- get url() {
13
- return `${this.config.termConfig.apiUrl}/api/termservice/collection`;
14
- }
15
- createCollection(defaultLanguages, collectionName) {
16
- const params = {
17
- name: collectionName,
18
- defaultLanguages
19
- };
20
- return this.http.post(this.url, params);
21
- }
22
- getCollectionList(sourceLanguageCode, targetLanguageCode) {
23
- return this.http.get(this.url).pipe(map((collections) => { return TldConvertedCollection.convertCollections(collections, sourceLanguageCode, targetLanguageCode); }));
24
- }
25
- }
26
- TermApiService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TermApiService, deps: [{ token: i1.TldTranslateConfigService }, { token: i2.HttpClient }], target: i0.ɵɵFactoryTarget.Injectable });
27
- TermApiService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TermApiService, providedIn: 'root' });
28
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TermApiService, decorators: [{
29
- type: Injectable,
30
- args: [{
31
- providedIn: 'root'
32
- }]
33
- }], ctorParameters: function () { return [{ type: i1.TldTranslateConfigService }, { type: i2.HttpClient }]; } });
34
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVybS1hcGkuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3RsZC10cmFuc2xhdGUvc3JjL2xpYi9tb2R1bGVzL3RsZC10ZXJtL3NlcnZpY2VzL3Rlcm0tYXBpLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzQyxPQUFPLEVBQUUsR0FBRyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFHckMsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sMENBQTBDLENBQUM7Ozs7QUFLbEYsTUFBTSxPQUFPLGNBQWM7SUFLekIsWUFBNkIsTUFBaUMsRUFDM0MsSUFBZ0I7UUFETixXQUFNLEdBQU4sTUFBTSxDQUEyQjtRQUMzQyxTQUFJLEdBQUosSUFBSSxDQUFZO0lBQ25DLENBQUM7SUFORCxJQUFJLEdBQUc7UUFDTCxPQUFPLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxVQUFVLENBQUMsTUFBTSw2QkFBNkIsQ0FBQztJQUN2RSxDQUFDO0lBTUQsZ0JBQWdCLENBQUMsZ0JBQTBCLEVBQUUsY0FBc0I7UUFDakUsTUFBTSxNQUFNLEdBQUc7WUFDYixJQUFJLEVBQUUsY0FBYztZQUNwQixnQkFBZ0I7U0FDakIsQ0FBQztRQUNGLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQXFCLElBQUksQ0FBQyxHQUFHLEVBQUUsTUFBTSxDQUFDLENBQUE7SUFDN0QsQ0FBQztJQUVELGlCQUFpQixDQUFDLGtCQUEwQixFQUFFLGtCQUEwQjtRQUN0RSxPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUF1QixJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsSUFBSSxDQUN2RCxHQUFHLENBQUMsQ0FBQyxXQUFXLEVBQUUsRUFBRSxHQUFHLE9BQU8sc0JBQXNCLENBQUMsa0JBQWtCLENBQUMsV0FBVyxFQUFFLGtCQUFrQixFQUFFLGtCQUFrQixDQUFDLENBQUEsQ0FBQyxDQUFDLENBQUMsQ0FDaEksQ0FBQztJQUNKLENBQUM7OzJHQXJCVSxjQUFjOytHQUFkLGNBQWMsY0FGYixNQUFNOzJGQUVQLGNBQWM7a0JBSDFCLFVBQVU7bUJBQUM7b0JBQ1YsVUFBVSxFQUFFLE1BQU07aUJBQ25CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSHR0cENsaWVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbi9odHRwJztcclxuaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBtYXAgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XHJcbmltcG9ydCB7IFRsZFRyYW5zbGF0ZUNvbmZpZ1NlcnZpY2UgfSBmcm9tICcuLi8uLi90bGQtY29tbW9uL3NlcnZpY2VzJztcclxuaW1wb3J0IHsgSVRsZFRlcm1Db2xsZWN0aW9uIH0gZnJvbSAnLi4vbW9kZWxzL3Rlcm0tYXBpL3RsZC10ZXJtLWNvbGxlY3Rpb24ubW9kZWwnO1xyXG5pbXBvcnQgeyBUbGRDb252ZXJ0ZWRDb2xsZWN0aW9uIH0gZnJvbSAnLi4vbW9kZWxzL3RsZC1jb252ZXJ0ZWQtY29sbGVjdGlvbi5tb2RlbCc7XHJcblxyXG5ASW5qZWN0YWJsZSh7XHJcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBUZXJtQXBpU2VydmljZSB7XHJcbiAgZ2V0IHVybCgpIHtcclxuICAgIHJldHVybiBgJHt0aGlzLmNvbmZpZy50ZXJtQ29uZmlnLmFwaVVybH0vYXBpL3Rlcm1zZXJ2aWNlL2NvbGxlY3Rpb25gO1xyXG4gIH1cclxuXHJcbiAgY29uc3RydWN0b3IocHJpdmF0ZSByZWFkb25seSBjb25maWc6IFRsZFRyYW5zbGF0ZUNvbmZpZ1NlcnZpY2UsXHJcbiAgICBwcml2YXRlIHJlYWRvbmx5IGh0dHA6IEh0dHBDbGllbnQpIHtcclxuICB9XHJcbiAgXHJcbiAgY3JlYXRlQ29sbGVjdGlvbihkZWZhdWx0TGFuZ3VhZ2VzOiBzdHJpbmdbXSwgY29sbGVjdGlvbk5hbWU6IHN0cmluZykge1xyXG4gICAgY29uc3QgcGFyYW1zID0ge1xyXG4gICAgICBuYW1lOiBjb2xsZWN0aW9uTmFtZSxcclxuICAgICAgZGVmYXVsdExhbmd1YWdlc1xyXG4gICAgfTtcclxuICAgIHJldHVybiB0aGlzLmh0dHAucG9zdDxJVGxkVGVybUNvbGxlY3Rpb24+KHRoaXMudXJsLCBwYXJhbXMpXHJcbiAgfVxyXG5cclxuICBnZXRDb2xsZWN0aW9uTGlzdChzb3VyY2VMYW5ndWFnZUNvZGU6IHN0cmluZywgdGFyZ2V0TGFuZ3VhZ2VDb2RlOiBzdHJpbmcpIHtcclxuICAgIHJldHVybiB0aGlzLmh0dHAuZ2V0PElUbGRUZXJtQ29sbGVjdGlvbltdPih0aGlzLnVybCkucGlwZShcclxuICAgICAgbWFwKChjb2xsZWN0aW9ucykgPT4geyByZXR1cm4gVGxkQ29udmVydGVkQ29sbGVjdGlvbi5jb252ZXJ0Q29sbGVjdGlvbnMoY29sbGVjdGlvbnMsIHNvdXJjZUxhbmd1YWdlQ29kZSwgdGFyZ2V0TGFuZ3VhZ2VDb2RlKSB9KVxyXG4gICAgKTtcclxuICB9XHJcbn1cclxuIl19
@@ -1,253 +0,0 @@
1
- import { Injectable } from '@angular/core';
2
- import { forkJoin } from 'rxjs';
3
- import { map, tap } from 'rxjs/operators';
4
- import { ErrorCode } from '../../tld-common/models/errors/error-codes.enum';
5
- import { ConvertedCollectionType } from '../models/converted-collection-type.model';
6
- import { MtCollectionStatus } from '../models/mt-collection-status.model';
7
- import { TldConvertedCollection } from '../models/tld-converted-collection.model';
8
- import * as i0 from "@angular/core";
9
- import * as i1 from "../../tld-common/services";
10
- import * as i2 from "../../tld-tooltip/services";
11
- import * as i3 from "./term-api.service";
12
- import * as i4 from "./mt-collections-api.service";
13
- export class TldTermCollectionsService {
14
- constructor(config, tldSystem, termApi, mtApi) {
15
- this.config = config;
16
- this.tldSystem = tldSystem;
17
- this.termApi = termApi;
18
- this.mtApi = mtApi;
19
- this._selected = null;
20
- this.LOCAL_STORAGE_KEY = "systemLastCollections";
21
- this.tldSystem.getActiveData()
22
- .subscribe((active) => {
23
- this.sourceLanguageCode = active?.sourceLang.lang;
24
- this.targetLanguageCode = active?.targetLang.lang;
25
- this.activeSystemId = active?.systemId || null;
26
- this._collections = new Set();
27
- // avoiding setter, so the null value is not storeed in location since it is not by user action
28
- this._selected = null;
29
- if (active && this.tldSystem.isTerminologySupported(active?.system)) {
30
- this.refreshCollections(true);
31
- }
32
- });
33
- }
34
- get selected() { return this._selected; }
35
- set selected(val) {
36
- this._selected = val;
37
- this.storeSelectedInLocalStorage();
38
- if (!this._selected) {
39
- return;
40
- }
41
- if (!this._selected.id) {
42
- this.addCollectionToSystem(this._selected);
43
- }
44
- }
45
- get collections() {
46
- return this._collections;
47
- }
48
- get isRefreshingCollections() {
49
- return this._isRefreshingCollections;
50
- }
51
- get canCreateCollections() {
52
- return this.config.termConfig.canCreateCollection;
53
- }
54
- get hasEditPermissions() {
55
- return this.config?.coreConfig.isAuth && this.canCreateCollections && this.config.termConfig.isTermPortalSupported;
56
- }
57
- get hasAnyCollections() {
58
- return this._hasAnyCollections;
59
- }
60
- get shouldShowPromotion() {
61
- return !this.hasAnyCollections && !this.hasEditPermissions;
62
- }
63
- onMenuOpen() {
64
- this.menuOpened = true;
65
- if (!this.shouldShowPromotion) {
66
- this.startAutoRefresh();
67
- }
68
- }
69
- onMenuClose() {
70
- this.menuOpened = false;
71
- // if menu is closed, but selected collection still syncing, auto refresh should be kept opened.
72
- if (this.selected?.mtStatus !== MtCollectionStatus.PROCESSING) {
73
- this.stopAutoRefresh();
74
- }
75
- }
76
- addCollectionToSystem(collection) {
77
- if (!collection || !collection.termId) {
78
- console.error("Trying to attach collection that has no tilde term id.");
79
- return;
80
- }
81
- collection.mtStatus = MtCollectionStatus.PROCESSING;
82
- collection.isSynchronized = true;
83
- this.mtApi.attachTermsFromTildeTerm(this.activeSystemId, collection.termId)
84
- .subscribe(() => { }, () => {
85
- collection.mtStatus = MtCollectionStatus.ERROR;
86
- collection.errorKey = ErrorCode.COLLECTION_IMPORT;
87
- });
88
- }
89
- create(defaultLanguages, collectionName) {
90
- return this.termApi.createCollection(defaultLanguages, collectionName).pipe(map(collection => new TldConvertedCollection(collection, this.sourceLanguageCode, this.targetLanguageCode)), tap((collection) => {
91
- this._collections.add(collection);
92
- this._hasAnyCollections = true;
93
- }));
94
- }
95
- refreshCollections(setSelectedFromLocalStorage = false) {
96
- if (!this.activeSystemId
97
- || !this.config.termConfig.isCollectionsActivated) {
98
- return;
99
- }
100
- this._isRefreshingCollections = true;
101
- const observables = [
102
- this.termApi.getCollectionList(this.sourceLanguageCode, this.targetLanguageCode),
103
- this.mtApi.loadMTCollections(this.activeSystemId, this.sourceLanguageCode, this.targetLanguageCode)
104
- ];
105
- forkJoin(observables).subscribe((response) => {
106
- this.isAnyImporting = false;
107
- // TO DO. Doesn't seem to be clean approach with syncing collections. Maybe some cleaner solution possible?
108
- this.removeDeletedFromTerms(response[0]);
109
- this.updateCollections([...response[0], ...response[1]]);
110
- if (setSelectedFromLocalStorage) {
111
- this.setSelectedFromLocalStorage();
112
- }
113
- this._isRefreshingCollections = false;
114
- this.scheduleRefresh();
115
- }, (error) => {
116
- this._isRefreshingCollections = false;
117
- // it is enough to show error only in console. No special thing is necessary.
118
- console.error(error);
119
- });
120
- }
121
- /**
122
- *
123
- * @returns selected collection id if it is allowed to use collection for translations
124
- */
125
- selectedIdForTranslation() {
126
- if (this.selected && (this.selected.mtPreparedDateTime || this.selected.mtStatus === MtCollectionStatus.READY)) {
127
- return this.selected.id;
128
- }
129
- return null;
130
- }
131
- startAutoRefresh() {
132
- this.isAutoRefreshingOn = true;
133
- this.scheduleRefresh(0);
134
- }
135
- stopAutoRefresh() {
136
- if (this.refreshTimeout) {
137
- clearTimeout(this.refreshTimeout);
138
- this.refreshTimeout = null;
139
- }
140
- this.isAutoRefreshingOn = false;
141
- }
142
- scheduleRefresh(timeout) {
143
- // if menu is closed and selected collection is not importing anymore - auto refreshing should be cancelled.
144
- if (!this.menuOpened && !this.selected?.isImporting && this.isAutoRefreshingOn) {
145
- this.stopAutoRefresh();
146
- return;
147
- }
148
- // if menu is opened, auto refresh should be on. If menu is closed, refresh needs to be done only if selected is importing.
149
- if (!this.refreshTimeout && (this.isAutoRefreshingOn || this.selected?.isImporting)) {
150
- const timeoutMs = timeout ?? (this.isAnyImporting ? this.config.termConfig.refreshTimeoutMsWhenImporting : this.config.termConfig.refreshTimeoutMs);
151
- this.refreshTimeout = setTimeout(() => {
152
- this.refreshTimeout = null;
153
- this.refreshCollections();
154
- }, timeoutMs);
155
- }
156
- }
157
- /**
158
- * Should be called after refresh to check if there is any collections from term api that are deleted.
159
- */
160
- removeDeletedFromTerms(refreshedList) {
161
- for (const collection of this.collections) {
162
- if (!collection.termId) {
163
- continue;
164
- }
165
- const exists = refreshedList.find(refreshedCollection => refreshedCollection.importedFrom === ConvertedCollectionType.Term && refreshedCollection.termId === collection.termId);
166
- if (!exists) {
167
- // Removes collection if it hasn't been imported.
168
- if (!collection.id) {
169
- this.collections.delete(collection);
170
- }
171
- else {
172
- collection.deletedFromTermApi();
173
- }
174
- }
175
- }
176
- }
177
- updateCollections(refreshedCollections) {
178
- // sets collection list to this value at the end, so deleted collections are not in the list.
179
- const updatedCollections = new Set();
180
- for (let collection of refreshedCollections) {
181
- // User shouldn't see failed collections if he can't retry to import them.
182
- if (!this.hasEditPermissions
183
- && collection.importedFrom === ConvertedCollectionType.MT
184
- && collection.mtStatus === MtCollectionStatus.ERROR) {
185
- continue;
186
- }
187
- if (collection.isImporting) {
188
- this.isAnyImporting = true;
189
- }
190
- let existing = TldConvertedCollection.findExistingCollectionFromList(this.collections, collection);
191
- // Term Id should be set only for entities coming from term API, because collection can be deleted, but key would still be in MT api.
192
- // But term id is necessary to do the previous check to sync collections - it can be set to null only after update.
193
- if (collection.importedFrom === ConvertedCollectionType.MT) {
194
- // Collections from MT should be only visible when Ready or collection is being processed, but it has already been created before and it can be used.
195
- if (!(collection.mtStatus === MtCollectionStatus.READY
196
- || (collection.mtStatus === MtCollectionStatus.PROCESSING && collection.mtPreparedDateTime)
197
- || existing)) {
198
- continue;
199
- }
200
- collection.termId = null;
201
- }
202
- if (existing) {
203
- existing.update(collection);
204
- }
205
- else {
206
- this.collections.add(collection);
207
- }
208
- const editedCollection = existing ?? collection;
209
- updatedCollections.add(editedCollection);
210
- }
211
- this._collections = updatedCollections;
212
- this._hasAnyCollections = updatedCollections.size > 0;
213
- }
214
- setSelectedFromLocalStorage() {
215
- // If no collections or selected is already set, it should not be changed from localstorage value. (Usually, localstorage should have the same value).
216
- if (this.collections?.size === 0 || this.selected) {
217
- return;
218
- }
219
- const storedId = this.readLocalStorage()?.[this.activeSystemId];
220
- if (!storedId) {
221
- return;
222
- }
223
- const existing = Array.from(this.collections).find(item => item.id === storedId || item.termId === storedId);
224
- this.selected = existing;
225
- }
226
- storeSelectedInLocalStorage() {
227
- let localStorageObject = this.readLocalStorage();
228
- if (!localStorageObject) {
229
- localStorageObject = {};
230
- }
231
- localStorageObject[this.activeSystemId] = this.selected ? (this.selected.termId ?? this.selected.id) : null;
232
- // store term id if it exists
233
- localStorage.setItem(this.LOCAL_STORAGE_KEY, JSON.stringify(localStorageObject));
234
- }
235
- readLocalStorage() {
236
- const data = localStorage.getItem(this.LOCAL_STORAGE_KEY);
237
- try {
238
- return JSON.parse(data);
239
- }
240
- catch {
241
- return null;
242
- }
243
- }
244
- }
245
- TldTermCollectionsService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TldTermCollectionsService, deps: [{ token: i1.TldTranslateConfigService }, { token: i2.TldSystemService }, { token: i3.TermApiService }, { token: i4.MtCollectionsApiService }], target: i0.ɵɵFactoryTarget.Injectable });
246
- TldTermCollectionsService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TldTermCollectionsService, providedIn: 'root' });
247
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TldTermCollectionsService, decorators: [{
248
- type: Injectable,
249
- args: [{
250
- providedIn: 'root'
251
- }]
252
- }], ctorParameters: function () { return [{ type: i1.TldTranslateConfigService }, { type: i2.TldSystemService }, { type: i3.TermApiService }, { type: i4.MtCollectionsApiService }]; } });
253
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tld-term-collections.service.js","sourceRoot":"","sources":["../../../../../../../projects/tld-translate/src/lib/modules/tld-term/services/tld-term-collections.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\r\nimport { forkJoin, Observable } from 'rxjs';\r\nimport { map, tap } from 'rxjs/operators';\r\nimport { ErrorCode } from '../../tld-common/models/errors/error-codes.enum';\r\nimport { TldTranslateConfigService } from '../../tld-common/services';\r\nimport { TldSystemService } from '../../tld-tooltip/services';\r\nimport { ConvertedCollectionType } from '../models/converted-collection-type.model';\r\nimport { MtCollectionStatus } from '../models/mt-collection-status.model';\r\nimport { TldConvertedCollection } from '../models/tld-converted-collection.model';\r\nimport { MtCollectionsApiService } from './mt-collections-api.service';\r\nimport { TermApiService } from './term-api.service';\r\n\r\n@Injectable({\r\n  providedIn: 'root'\r\n})\r\nexport class TldTermCollectionsService {\r\n\r\n  private _selected: TldConvertedCollection = null;\r\n  get selected() { return this._selected; }\r\n  set selected(val: TldConvertedCollection) {\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.id) {\r\n      this.addCollectionToSystem(this._selected);\r\n    }\r\n\r\n  }\r\n\r\n  // set instead of array because only distinct values should be in list and with set no manual checks are necessary.\r\n  private _collections: Set<TldConvertedCollection>;\r\n  get collections() {\r\n    return this._collections;\r\n  }\r\n\r\n  private _isRefreshingCollections: boolean;\r\n  get isRefreshingCollections() {\r\n    return this._isRefreshingCollections;\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 _hasAnyCollections: boolean;\r\n  get hasAnyCollections() {\r\n    return this._hasAnyCollections;\r\n  }\r\n\r\n  get shouldShowPromotion() {\r\n    return !this.hasAnyCollections && !this.hasEditPermissions;\r\n  }\r\n\r\n  private isAutoRefreshingOn: boolean;\r\n  private sourceLanguageCode: string;\r\n  private targetLanguageCode: string;\r\n  private activeSystemId: string;\r\n  private refreshTimeout: any;\r\n  private isAnyImporting: boolean;\r\n  private menuOpened: boolean;\r\n\r\n  private readonly LOCAL_STORAGE_KEY = \"systemLastCollections\";\r\n\r\n  constructor(private readonly config: TldTranslateConfigService,\r\n    private readonly tldSystem: TldSystemService,\r\n    private readonly termApi: TermApiService,\r\n    private readonly mtApi: MtCollectionsApiService) {\r\n    this.tldSystem.getActiveData()\r\n      .subscribe((active) => {\r\n        this.sourceLanguageCode = active?.sourceLang.lang;\r\n        this.targetLanguageCode = active?.targetLang.lang;\r\n        this.activeSystemId = active?.systemId || null;\r\n        this._collections = new Set();\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        if (active && this.tldSystem.isTerminologySupported(active?.system)) {\r\n          this.refreshCollections(true);\r\n        }\r\n      });\r\n  }\r\n\r\n  onMenuOpen() {\r\n    this.menuOpened = true;\r\n    if (!this.shouldShowPromotion) {\r\n      this.startAutoRefresh();\r\n    }\r\n  }\r\n\r\n  onMenuClose() {\r\n    this.menuOpened = false;\r\n    // if menu is closed, but selected collection still syncing, auto refresh should be kept opened.\r\n    if (this.selected?.mtStatus !== MtCollectionStatus.PROCESSING) {\r\n      this.stopAutoRefresh();\r\n    }\r\n  }\r\n\r\n  addCollectionToSystem(collection: TldConvertedCollection) {\r\n    if (!collection || !collection.termId) {\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.attachTermsFromTildeTerm(this.activeSystemId, collection.termId)\r\n      .subscribe(() => { },\r\n        () => {\r\n          collection.mtStatus = MtCollectionStatus.ERROR;\r\n          collection.errorKey = ErrorCode.COLLECTION_IMPORT;\r\n        });\r\n  }\r\n\r\n  create(defaultLanguages: string[], collectionName: string) {\r\n    return this.termApi.createCollection(defaultLanguages, collectionName).pipe(\r\n      map(collection => new TldConvertedCollection(collection, this.sourceLanguageCode, this.targetLanguageCode)),\r\n      tap((collection) => {\r\n        this._collections.add(collection);\r\n        this._hasAnyCollections = true;\r\n      })\r\n    );\r\n  }\r\n\r\n  refreshCollections(setSelectedFromLocalStorage = false) {\r\n    if (!this.activeSystemId\r\n      || !this.config.termConfig.isCollectionsActivated) {\r\n      return;\r\n    }\r\n    this._isRefreshingCollections = true;\r\n    const observables: Observable<TldConvertedCollection[]>[] = [\r\n      this.termApi.getCollectionList(this.sourceLanguageCode, this.targetLanguageCode),\r\n      this.mtApi.loadMTCollections(this.activeSystemId, this.sourceLanguageCode, this.targetLanguageCode)\r\n    ];\r\n\r\n    forkJoin(observables).subscribe(\r\n      (response) => {\r\n        this.isAnyImporting = false;\r\n        // TO DO. Doesn't seem to be clean approach with syncing collections. Maybe some cleaner solution possible?\r\n        this.removeDeletedFromTerms(response[0]);\r\n        this.updateCollections([...response[0], ...response[1]]);\r\n        if (setSelectedFromLocalStorage) {\r\n          this.setSelectedFromLocalStorage();\r\n        }\r\n        this._isRefreshingCollections = false;\r\n        this.scheduleRefresh();\r\n      }, (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   *\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 && (this.selected.mtPreparedDateTime || this.selected.mtStatus === MtCollectionStatus.READY)) {\r\n      return this.selected.id;\r\n    }\r\n    return null;\r\n  }\r\n\r\n  private startAutoRefresh() {\r\n    this.isAutoRefreshingOn = true;\r\n    this.scheduleRefresh(0);\r\n  }\r\n\r\n  private stopAutoRefresh() {\r\n    if (this.refreshTimeout) {\r\n      clearTimeout(this.refreshTimeout);\r\n      this.refreshTimeout = null;\r\n    }\r\n\r\n    this.isAutoRefreshingOn = false;\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.menuOpened && !this.selected?.isImporting && this.isAutoRefreshingOn) {\r\n      this.stopAutoRefresh();\r\n      return;\r\n    }\r\n\r\n    // if menu is opened, auto refresh should be on. If menu is closed, refresh needs to be done only if selected is importing.\r\n    if (!this.refreshTimeout && (this.isAutoRefreshingOn || 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   * Should be called after refresh to check if there is any collections from term api that are deleted.\r\n   */\r\n  private removeDeletedFromTerms(refreshedList: TldConvertedCollection[]) {\r\n    for (const collection of this.collections) {\r\n      if (!collection.termId) {\r\n        continue;\r\n      }\r\n      const exists = refreshedList.find(refreshedCollection => refreshedCollection.importedFrom === ConvertedCollectionType.Term && refreshedCollection.termId === collection.termId);\r\n      if (!exists) {\r\n        // Removes collection if it hasn't been imported.\r\n        if (!collection.id) {\r\n          this.collections.delete(collection);\r\n        }\r\n        else {\r\n          collection.deletedFromTermApi();\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  private updateCollections(refreshedCollections: TldConvertedCollection[]) {\r\n    // sets collection list to this value at the end, so deleted collections are not in the list.\r\n    const updatedCollections = new Set<TldConvertedCollection>();\r\n    for (let collection of refreshedCollections) {\r\n      // User shouldn't see failed collections if he can't retry to import them.\r\n      if (!this.hasEditPermissions\r\n        && collection.importedFrom === ConvertedCollectionType.MT\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\r\n      let existing: TldConvertedCollection = TldConvertedCollection.findExistingCollectionFromList(this.collections, collection);\r\n\r\n      // Term Id should be set only for entities coming from term API, because collection can be deleted, but key would still be in MT api.\r\n      // But term id is necessary to do the previous check to sync collections - it can be set to null only after update.\r\n      if (collection.importedFrom === ConvertedCollectionType.MT) {\r\n        // Collections from MT should be only visible when Ready or collection is being processed, but it has already been created before and it can be used.\r\n        if (!(collection.mtStatus === MtCollectionStatus.READY\r\n          || (collection.mtStatus === MtCollectionStatus.PROCESSING && collection.mtPreparedDateTime)\r\n          || existing)) {\r\n          continue;\r\n        }\r\n        collection.termId = null;\r\n      }\r\n\r\n      if (existing) {\r\n        existing.update(collection);\r\n      }\r\n      else {\r\n        this.collections.add(collection);\r\n      }\r\n\r\n      const editedCollection = existing ?? collection;\r\n      updatedCollections.add(editedCollection);\r\n    }\r\n    this._collections = updatedCollections;\r\n    this._hasAnyCollections = updatedCollections.size > 0;\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.activeSystemId];\r\n    if (!storedId) {\r\n      return;\r\n    }\r\n\r\n    const existing = Array.from(this.collections).find(item => item.id === storedId || item.termId === 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.activeSystemId] = this.selected ? (this.selected.termId ?? this.selected.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"]}
@@ -1,5 +0,0 @@
1
- export declare enum ConvertedCollectionTooltipKey {
2
- NO_ENTRIES = "NO_ENTRIES",
3
- IMPORTING = "IMPORTING",
4
- SYNCING = "SYNCING"
5
- }
@@ -1,7 +0,0 @@
1
- /**
2
- * Enumerator to determine if collection imported from term api or mt
3
- */
4
- export declare enum ConvertedCollectionType {
5
- Term = 0,
6
- MT = 1
7
- }
@@ -1,6 +0,0 @@
1
- export * from './mt-api/tld-mt-term-collection.model';
2
- export * from './term-api/tld-term-collection.model';
3
- export * from './term-api/tld-term-collection-languages.model';
4
- export * from './tld-converted-collection.model';
5
- export * from './converted-collection-tooltip-key.model';
6
- export * from './converted-collection-type.model';
@@ -1,15 +0,0 @@
1
- import { MtCollectionStatus } from "../mt-collection-status.model";
2
- /**
3
- * Interface that describes structure returned from GetDetailedTermCorpora
4
- */
5
- export interface ITldMTTermCollection {
6
- CorpusId: string;
7
- Message: string;
8
- Status: MtCollectionStatus;
9
- TildeTermId: string;
10
- Title: string;
11
- Type: string;
12
- AttachmentDateTime: string;
13
- Count: number;
14
- PreparedDateTime: string;
15
- }