@tilde-nlp/ngx-translate 2.1.35 → 2.1.36

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.
@@ -28,6 +28,8 @@ export class MtTermV1Service {
28
28
  }));
29
29
  }
30
30
  remove(engineId, collection) {
31
+ engineId;
32
+ collection;
31
33
  throw new Error("not Implemented");
32
34
  }
33
35
  sync(engineId, collection) {
@@ -53,4 +55,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
53
55
  providedIn: 'root'
54
56
  }]
55
57
  }], ctorParameters: function () { return [{ type: i1.HttpClient }, { type: i2.TldTranslateConfigService }]; } });
56
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibXQtdGVybS12MS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdGxkLXRyYW5zbGF0ZS9zcmMvbGliL21vZHVsZXMvdGxkLXRlcm0vc2VydmljZXMvYXBpLXYxL210LXRlcm0tdjEuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzNDLE9BQU8sRUFBRSxHQUFHLEVBQWMsTUFBTSxNQUFNLENBQUM7QUFDdkMsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBRXBELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHFDQUFxQyxDQUFDOzs7O0FBUXpFLE1BQU0sT0FBTyxlQUFlO0lBRTFCLFlBQTZCLElBQWdCLEVBQzFCLE1BQWlDO1FBRHZCLFNBQUksR0FBSixJQUFJLENBQVk7UUFDMUIsV0FBTSxHQUFOLE1BQU0sQ0FBMkI7SUFBSSxDQUFDO0lBR3pELEdBQUcsQ0FBQyxRQUFnQixFQUFFLFVBQThCO1FBQ2xELE1BQU0sR0FBRyxHQUFHLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxVQUFVLENBQUMscUJBQXFCLDBCQUEwQixDQUFDO1FBQ3RGLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQXFCLEdBQUcsRUFBRSxFQUFFLE1BQU0sRUFBRSxFQUFFLFFBQVEsRUFBRSxRQUFRLEVBQUUsb0JBQW9CLEVBQUUsVUFBVSxDQUFDLE1BQU0sRUFBRSxFQUFFLENBQUM7YUFDdkgsSUFBSSxDQUNILEdBQUcsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQywyQkFBMkIsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUNwRCxDQUFDO0lBQ04sQ0FBQztJQUVELE9BQU8sQ0FBQyxRQUFnQjtRQUN0QixNQUFNLE9BQU8sR0FBRyxNQUFNLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUNuRCxNQUFNLEdBQUcsR0FBRyxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsVUFBVSxDQUFDLHFCQUFxQiw4QkFBOEIsQ0FBQztRQUMxRixNQUFNLE1BQU0sR0FBRyxFQUFFLFFBQVEsRUFBRSxRQUFRLEVBQUUsQ0FBQztRQUN0QyxPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUF1QixHQUFHLEVBQUUsRUFBRSxPQUFPLEVBQUUsTUFBTSxFQUFFLENBQUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsSUFBSSxFQUFFLEVBQUU7WUFDckYsTUFBTSxhQUFhLEdBQXlCLEVBQUUsQ0FBQztZQUMvQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUMsVUFBVSxFQUFFLEVBQUU7Z0JBQzFCLGFBQWEsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLDJCQUEyQixDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUM7WUFDbkUsQ0FBQyxDQUFDLENBQUE7WUFDRixPQUFPLGFBQWEsQ0FBQztRQUN2QixDQUFDLENBQUMsQ0FBQyxDQUFBO0lBQ0wsQ0FBQztJQUVELE1BQU0sQ0FBQyxRQUFnQixFQUFFLFVBQThCO1FBQ3JELE1BQU0sSUFBSSxLQUFLLENBQUMsaUJBQWlCLENBQUMsQ0FBQztJQUNyQyxDQUFDO0lBRUQsSUFBSSxDQUFDLFFBQWdCLEVBQUUsVUFBOEI7UUFDbkQsT0FBTyxJQUFJLENBQUMsR0FBRyxDQUFDLFFBQVEsRUFBRSxVQUFVLENBQUMsQ0FBQztJQUN4QyxDQUFDO0lBRU8sMkJBQTJCLENBQUMsVUFBOEI7UUFDaEUsTUFBTSxxQkFBcUIsR0FBaUI7WUFDMUMsRUFBRSxFQUFFLFVBQVUsQ0FBQyxRQUFRO1lBQ3ZCLE1BQU0sRUFBRSxVQUFVLENBQUMsV0FBVztZQUM5QixXQUFXLEVBQUUsSUFBSSxJQUFJLENBQUMsVUFBVSxDQUFDLGtCQUFrQixDQUFDO1lBQ3BELElBQUksRUFBRSxVQUFVLENBQUMsS0FBSztZQUN0QixtQ0FBbUM7WUFDbkMsTUFBTSxFQUFFLFVBQVUsQ0FBQyxNQUFhO1NBQ2pDLENBQUM7UUFFRixPQUFPLElBQUksa0JBQWtCLENBQUMsSUFBSSxFQUFFLHFCQUFxQixDQUFDLENBQUM7SUFDN0QsQ0FBQzs7NEdBOUNVLGVBQWU7Z0hBQWYsZUFBZSxjQUZkLE1BQU07MkZBRVAsZUFBZTtrQkFIM0IsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBIdHRwQ2xpZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uL2h0dHAnO1xyXG5pbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IG1hcCwgT2JzZXJ2YWJsZSB9IGZyb20gJ3J4anMnO1xyXG5pbXBvcnQgeyBDb21tb24gfSBmcm9tICcuLi8uLi8uLi90bGQtY29tbW9uL21vZGVscyc7XHJcbmltcG9ydCB7IFRsZFRyYW5zbGF0ZUNvbmZpZ1NlcnZpY2UgfSBmcm9tICcuLi8uLi8uLi90bGQtY29tbW9uL3NlcnZpY2VzJztcclxuaW1wb3J0IHsgQ29tYmluZWRDb2xsZWN0aW9uIH0gZnJvbSAnLi4vbW9kZWxzL2NvbWJpbmVkLWNvbGxlY3Rpb24ubW9kZWwnO1xyXG5pbXBvcnQgeyBNdENvbGxlY3Rpb24gfSBmcm9tICcuLi9tb2RlbHMvbXQtY29sbGVjdGlvbi5tb2RlbCc7XHJcbmltcG9ydCB7IElNdFRlcm1TZXJ2aWNlIH0gZnJvbSAnLi4vbW9kZWxzL210LXRlcm0tc2VydmljZS5tb2RlbCc7XHJcbmltcG9ydCB7IE10VGVybUNvbGxlY3Rpb25WMSB9IGZyb20gJy4vbW9kZWxzL210LXRlcm0tY29sbGVjdGlvbi12MS5tb2RlbCc7XHJcblxyXG5ASW5qZWN0YWJsZSh7XHJcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBNdFRlcm1WMVNlcnZpY2UgaW1wbGVtZW50cyBJTXRUZXJtU2VydmljZSB7XHJcblxyXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgcmVhZG9ubHkgaHR0cDogSHR0cENsaWVudCxcclxuICAgIHByaXZhdGUgcmVhZG9ubHkgY29uZmlnOiBUbGRUcmFuc2xhdGVDb25maWdTZXJ2aWNlKSB7IH1cclxuXHJcblxyXG4gIGFkZChlbmdpbmVJZDogc3RyaW5nLCBjb2xsZWN0aW9uOiBDb21iaW5lZENvbGxlY3Rpb24pOiBPYnNlcnZhYmxlPENvbWJpbmVkQ29sbGVjdGlvbj4ge1xyXG4gICAgY29uc3QgdXJsID0gYCR7dGhpcy5jb25maWcuY29yZUNvbmZpZy50cmFuc2xhdGlvblNlcnZpY2VVcmx9QXR0YWNoVGVybXNGcm9tVGlsZGVUZXJtYDtcclxuICAgIHJldHVybiB0aGlzLmh0dHAuZ2V0PE10VGVybUNvbGxlY3Rpb25WMT4odXJsLCB7IHBhcmFtczogeyBzeXN0ZW1JRDogZW5naW5lSWQsIHRpbGRlVGVybUNvbGVjdGlvbklEOiBjb2xsZWN0aW9uLnRlcm1JZCB9IH0pXHJcbiAgICAgIC5waXBlKFxyXG4gICAgICAgIG1hcChkYXRhID0+IHRoaXMuY29udmVydFRvQ29tYmluZWRDb2xsZWN0aW9uKGRhdGEpKVxyXG4gICAgICApO1xyXG4gIH1cclxuXHJcbiAgZ2V0TGlzdChlbmdpbmVJZDogc3RyaW5nKTogT2JzZXJ2YWJsZTxDb21iaW5lZENvbGxlY3Rpb25bXT4ge1xyXG4gICAgY29uc3QgaGVhZGVycyA9IENvbW1vbi5nZXRBdXRoSGVhZGVycyh0aGlzLmNvbmZpZyk7XHJcbiAgICBjb25zdCB1cmwgPSBgJHt0aGlzLmNvbmZpZy5jb3JlQ29uZmlnLnRyYW5zbGF0aW9uU2VydmljZVVybH1HZXREZXRhaWxlZFN5c3RlbVRlcm1Db3Jwb3JhYDtcclxuICAgIGNvbnN0IHBhcmFtcyA9IHsgc3lzdGVtSUQ6IGVuZ2luZUlkIH07XHJcbiAgICByZXR1cm4gdGhpcy5odHRwLmdldDxNdFRlcm1Db2xsZWN0aW9uVjFbXT4odXJsLCB7IGhlYWRlcnMsIHBhcmFtcyB9KS5waXBlKG1hcCgoZGF0YSkgPT4ge1xyXG4gICAgICBjb25zdCBtdENvbGxlY3Rpb25zOiBDb21iaW5lZENvbGxlY3Rpb25bXSA9IFtdO1xyXG4gICAgICBkYXRhLmZvckVhY2goKGNvbGxlY3Rpb24pID0+IHtcclxuICAgICAgICBtdENvbGxlY3Rpb25zLnB1c2godGhpcy5jb252ZXJ0VG9Db21iaW5lZENvbGxlY3Rpb24oY29sbGVjdGlvbikpO1xyXG4gICAgICB9KVxyXG4gICAgICByZXR1cm4gbXRDb2xsZWN0aW9ucztcclxuICAgIH0pKVxyXG4gIH1cclxuXHJcbiAgcmVtb3ZlKGVuZ2luZUlkOiBzdHJpbmcsIGNvbGxlY3Rpb246IENvbWJpbmVkQ29sbGVjdGlvbik6IE9ic2VydmFibGU8Q29tYmluZWRDb2xsZWN0aW9uPiB7XHJcbiAgICB0aHJvdyBuZXcgRXJyb3IoXCJub3QgSW1wbGVtZW50ZWRcIik7XHJcbiAgfVxyXG5cclxuICBzeW5jKGVuZ2luZUlkOiBzdHJpbmcsIGNvbGxlY3Rpb246IENvbWJpbmVkQ29sbGVjdGlvbik6IE9ic2VydmFibGU8Q29tYmluZWRDb2xsZWN0aW9uPiB7XHJcbiAgICByZXR1cm4gdGhpcy5hZGQoZW5naW5lSWQsIGNvbGxlY3Rpb24pO1xyXG4gIH1cclxuXHJcbiAgcHJpdmF0ZSBjb252ZXJ0VG9Db21iaW5lZENvbGxlY3Rpb24oY29sbGVjdGlvbjogTXRUZXJtQ29sbGVjdGlvblYxKTogQ29tYmluZWRDb2xsZWN0aW9uIHtcclxuICAgIGNvbnN0IGNvbnZlcnRlZE10Q29sbGVjdGlvbjogTXRDb2xsZWN0aW9uID0ge1xyXG4gICAgICBpZDogY29sbGVjdGlvbi5Db3JwdXNJZCxcclxuICAgICAgdGVybUlkOiBjb2xsZWN0aW9uLlRpbGRlVGVybUlkLFxyXG4gICAgICBsYXN0VXBkYXRlZDogbmV3IERhdGUoY29sbGVjdGlvbi5BdHRhY2htZW50RGF0ZVRpbWUpLFxyXG4gICAgICBuYW1lOiBjb2xsZWN0aW9uLlRpdGxlLFxyXG4gICAgICAvLyBhbnkgYmVjYXVzZSBlbnVtcyBzaG91bGQgb3ZlcmxhcFxyXG4gICAgICBzdGF0dXM6IGNvbGxlY3Rpb24uU3RhdHVzIGFzIGFueVxyXG4gICAgfTtcclxuXHJcbiAgICByZXR1cm4gbmV3IENvbWJpbmVkQ29sbGVjdGlvbihudWxsLCBjb252ZXJ0ZWRNdENvbGxlY3Rpb24pO1xyXG4gIH1cclxufVxyXG4iXX0=
58
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibXQtdGVybS12MS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdGxkLXRyYW5zbGF0ZS9zcmMvbGliL21vZHVsZXMvdGxkLXRlcm0vc2VydmljZXMvYXBpLXYxL210LXRlcm0tdjEuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzNDLE9BQU8sRUFBRSxHQUFHLEVBQWMsTUFBTSxNQUFNLENBQUM7QUFDdkMsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBRXBELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHFDQUFxQyxDQUFDOzs7O0FBUXpFLE1BQU0sT0FBTyxlQUFlO0lBRTFCLFlBQTZCLElBQWdCLEVBQzFCLE1BQWlDO1FBRHZCLFNBQUksR0FBSixJQUFJLENBQVk7UUFDMUIsV0FBTSxHQUFOLE1BQU0sQ0FBMkI7SUFBSSxDQUFDO0lBR3pELEdBQUcsQ0FBQyxRQUFnQixFQUFFLFVBQThCO1FBQ2xELE1BQU0sR0FBRyxHQUFHLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxVQUFVLENBQUMscUJBQXFCLDBCQUEwQixDQUFDO1FBQ3RGLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQXFCLEdBQUcsRUFBRSxFQUFFLE1BQU0sRUFBRSxFQUFFLFFBQVEsRUFBRSxRQUFRLEVBQUUsb0JBQW9CLEVBQUUsVUFBVSxDQUFDLE1BQU0sRUFBRSxFQUFFLENBQUM7YUFDdkgsSUFBSSxDQUNILEdBQUcsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQywyQkFBMkIsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUNwRCxDQUFDO0lBQ04sQ0FBQztJQUVELE9BQU8sQ0FBQyxRQUFnQjtRQUN0QixNQUFNLE9BQU8sR0FBRyxNQUFNLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUNuRCxNQUFNLEdBQUcsR0FBRyxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsVUFBVSxDQUFDLHFCQUFxQiw4QkFBOEIsQ0FBQztRQUMxRixNQUFNLE1BQU0sR0FBRyxFQUFFLFFBQVEsRUFBRSxRQUFRLEVBQUUsQ0FBQztRQUN0QyxPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUF1QixHQUFHLEVBQUUsRUFBRSxPQUFPLEVBQUUsTUFBTSxFQUFFLENBQUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsSUFBSSxFQUFFLEVBQUU7WUFDckYsTUFBTSxhQUFhLEdBQXlCLEVBQUUsQ0FBQztZQUMvQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUMsVUFBVSxFQUFFLEVBQUU7Z0JBQzFCLGFBQWEsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLDJCQUEyQixDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUM7WUFDbkUsQ0FBQyxDQUFDLENBQUE7WUFDRixPQUFPLGFBQWEsQ0FBQztRQUN2QixDQUFDLENBQUMsQ0FBQyxDQUFBO0lBQ0wsQ0FBQztJQUVELE1BQU0sQ0FBQyxRQUFnQixFQUFFLFVBQThCO1FBQ3JELFFBQVEsQ0FBQztRQUFDLFVBQVUsQ0FBQztRQUNyQixNQUFNLElBQUksS0FBSyxDQUFDLGlCQUFpQixDQUFDLENBQUM7SUFDckMsQ0FBQztJQUVELElBQUksQ0FBQyxRQUFnQixFQUFFLFVBQThCO1FBQ25ELE9BQU8sSUFBSSxDQUFDLEdBQUcsQ0FBQyxRQUFRLEVBQUUsVUFBVSxDQUFDLENBQUM7SUFDeEMsQ0FBQztJQUVPLDJCQUEyQixDQUFDLFVBQThCO1FBQ2hFLE1BQU0scUJBQXFCLEdBQWlCO1lBQzFDLEVBQUUsRUFBRSxVQUFVLENBQUMsUUFBUTtZQUN2QixNQUFNLEVBQUUsVUFBVSxDQUFDLFdBQVc7WUFDOUIsV0FBVyxFQUFFLElBQUksSUFBSSxDQUFDLFVBQVUsQ0FBQyxrQkFBa0IsQ0FBQztZQUNwRCxJQUFJLEVBQUUsVUFBVSxDQUFDLEtBQUs7WUFDdEIsbUNBQW1DO1lBQ25DLE1BQU0sRUFBRSxVQUFVLENBQUMsTUFBYTtTQUNqQyxDQUFDO1FBRUYsT0FBTyxJQUFJLGtCQUFrQixDQUFDLElBQUksRUFBRSxxQkFBcUIsQ0FBQyxDQUFDO0lBQzdELENBQUM7OzRHQS9DVSxlQUFlO2dIQUFmLGVBQWUsY0FGZCxNQUFNOzJGQUVQLGVBQWU7a0JBSDNCLFVBQVU7bUJBQUM7b0JBQ1YsVUFBVSxFQUFFLE1BQU07aUJBQ25CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSHR0cENsaWVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbi9odHRwJztcclxuaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBtYXAsIE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcclxuaW1wb3J0IHsgQ29tbW9uIH0gZnJvbSAnLi4vLi4vLi4vdGxkLWNvbW1vbi9tb2RlbHMnO1xyXG5pbXBvcnQgeyBUbGRUcmFuc2xhdGVDb25maWdTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vLi4vdGxkLWNvbW1vbi9zZXJ2aWNlcyc7XHJcbmltcG9ydCB7IENvbWJpbmVkQ29sbGVjdGlvbiB9IGZyb20gJy4uL21vZGVscy9jb21iaW5lZC1jb2xsZWN0aW9uLm1vZGVsJztcclxuaW1wb3J0IHsgTXRDb2xsZWN0aW9uIH0gZnJvbSAnLi4vbW9kZWxzL210LWNvbGxlY3Rpb24ubW9kZWwnO1xyXG5pbXBvcnQgeyBJTXRUZXJtU2VydmljZSB9IGZyb20gJy4uL21vZGVscy9tdC10ZXJtLXNlcnZpY2UubW9kZWwnO1xyXG5pbXBvcnQgeyBNdFRlcm1Db2xsZWN0aW9uVjEgfSBmcm9tICcuL21vZGVscy9tdC10ZXJtLWNvbGxlY3Rpb24tdjEubW9kZWwnO1xyXG5cclxuQEluamVjdGFibGUoe1xyXG4gIHByb3ZpZGVkSW46ICdyb290J1xyXG59KVxyXG5leHBvcnQgY2xhc3MgTXRUZXJtVjFTZXJ2aWNlIGltcGxlbWVudHMgSU10VGVybVNlcnZpY2Uge1xyXG5cclxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHJlYWRvbmx5IGh0dHA6IEh0dHBDbGllbnQsXHJcbiAgICBwcml2YXRlIHJlYWRvbmx5IGNvbmZpZzogVGxkVHJhbnNsYXRlQ29uZmlnU2VydmljZSkgeyB9XHJcblxyXG5cclxuICBhZGQoZW5naW5lSWQ6IHN0cmluZywgY29sbGVjdGlvbjogQ29tYmluZWRDb2xsZWN0aW9uKTogT2JzZXJ2YWJsZTxDb21iaW5lZENvbGxlY3Rpb24+IHtcclxuICAgIGNvbnN0IHVybCA9IGAke3RoaXMuY29uZmlnLmNvcmVDb25maWcudHJhbnNsYXRpb25TZXJ2aWNlVXJsfUF0dGFjaFRlcm1zRnJvbVRpbGRlVGVybWA7XHJcbiAgICByZXR1cm4gdGhpcy5odHRwLmdldDxNdFRlcm1Db2xsZWN0aW9uVjE+KHVybCwgeyBwYXJhbXM6IHsgc3lzdGVtSUQ6IGVuZ2luZUlkLCB0aWxkZVRlcm1Db2xlY3Rpb25JRDogY29sbGVjdGlvbi50ZXJtSWQgfSB9KVxyXG4gICAgICAucGlwZShcclxuICAgICAgICBtYXAoZGF0YSA9PiB0aGlzLmNvbnZlcnRUb0NvbWJpbmVkQ29sbGVjdGlvbihkYXRhKSlcclxuICAgICAgKTtcclxuICB9XHJcblxyXG4gIGdldExpc3QoZW5naW5lSWQ6IHN0cmluZyk6IE9ic2VydmFibGU8Q29tYmluZWRDb2xsZWN0aW9uW10+IHtcclxuICAgIGNvbnN0IGhlYWRlcnMgPSBDb21tb24uZ2V0QXV0aEhlYWRlcnModGhpcy5jb25maWcpO1xyXG4gICAgY29uc3QgdXJsID0gYCR7dGhpcy5jb25maWcuY29yZUNvbmZpZy50cmFuc2xhdGlvblNlcnZpY2VVcmx9R2V0RGV0YWlsZWRTeXN0ZW1UZXJtQ29ycG9yYWA7XHJcbiAgICBjb25zdCBwYXJhbXMgPSB7IHN5c3RlbUlEOiBlbmdpbmVJZCB9O1xyXG4gICAgcmV0dXJuIHRoaXMuaHR0cC5nZXQ8TXRUZXJtQ29sbGVjdGlvblYxW10+KHVybCwgeyBoZWFkZXJzLCBwYXJhbXMgfSkucGlwZShtYXAoKGRhdGEpID0+IHtcclxuICAgICAgY29uc3QgbXRDb2xsZWN0aW9uczogQ29tYmluZWRDb2xsZWN0aW9uW10gPSBbXTtcclxuICAgICAgZGF0YS5mb3JFYWNoKChjb2xsZWN0aW9uKSA9PiB7XHJcbiAgICAgICAgbXRDb2xsZWN0aW9ucy5wdXNoKHRoaXMuY29udmVydFRvQ29tYmluZWRDb2xsZWN0aW9uKGNvbGxlY3Rpb24pKTtcclxuICAgICAgfSlcclxuICAgICAgcmV0dXJuIG10Q29sbGVjdGlvbnM7XHJcbiAgICB9KSlcclxuICB9XHJcblxyXG4gIHJlbW92ZShlbmdpbmVJZDogc3RyaW5nLCBjb2xsZWN0aW9uOiBDb21iaW5lZENvbGxlY3Rpb24pOiBPYnNlcnZhYmxlPENvbWJpbmVkQ29sbGVjdGlvbj4ge1xyXG4gICAgZW5naW5lSWQ7IGNvbGxlY3Rpb247XHJcbiAgICB0aHJvdyBuZXcgRXJyb3IoXCJub3QgSW1wbGVtZW50ZWRcIik7XHJcbiAgfVxyXG5cclxuICBzeW5jKGVuZ2luZUlkOiBzdHJpbmcsIGNvbGxlY3Rpb246IENvbWJpbmVkQ29sbGVjdGlvbik6IE9ic2VydmFibGU8Q29tYmluZWRDb2xsZWN0aW9uPiB7XHJcbiAgICByZXR1cm4gdGhpcy5hZGQoZW5naW5lSWQsIGNvbGxlY3Rpb24pO1xyXG4gIH1cclxuXHJcbiAgcHJpdmF0ZSBjb252ZXJ0VG9Db21iaW5lZENvbGxlY3Rpb24oY29sbGVjdGlvbjogTXRUZXJtQ29sbGVjdGlvblYxKTogQ29tYmluZWRDb2xsZWN0aW9uIHtcclxuICAgIGNvbnN0IGNvbnZlcnRlZE10Q29sbGVjdGlvbjogTXRDb2xsZWN0aW9uID0ge1xyXG4gICAgICBpZDogY29sbGVjdGlvbi5Db3JwdXNJZCxcclxuICAgICAgdGVybUlkOiBjb2xsZWN0aW9uLlRpbGRlVGVybUlkLFxyXG4gICAgICBsYXN0VXBkYXRlZDogbmV3IERhdGUoY29sbGVjdGlvbi5BdHRhY2htZW50RGF0ZVRpbWUpLFxyXG4gICAgICBuYW1lOiBjb2xsZWN0aW9uLlRpdGxlLFxyXG4gICAgICAvLyBhbnkgYmVjYXVzZSBlbnVtcyBzaG91bGQgb3ZlcmxhcFxyXG4gICAgICBzdGF0dXM6IGNvbGxlY3Rpb24uU3RhdHVzIGFzIGFueVxyXG4gICAgfTtcclxuXHJcbiAgICByZXR1cm4gbmV3IENvbWJpbmVkQ29sbGVjdGlvbihudWxsLCBjb252ZXJ0ZWRNdENvbGxlY3Rpb24pO1xyXG4gIH1cclxufVxyXG4iXX0=
@@ -92,9 +92,8 @@ export class CombinedCollection {
92
92
  /**
93
93
  * Updates collection with values from new collection.
94
94
  * @param collection collection from which should be updated.
95
- * @param initialRefresh if set to true, editable fields will also be updated.
96
95
  */
97
- update(collection, initialRefresh = true) {
96
+ update(collection) {
98
97
  if (collection?.termCollection) {
99
98
  this.termCollection = collection.termCollection;
100
99
  }
@@ -108,9 +107,7 @@ export class CombinedCollection {
108
107
  else {
109
108
  this._isTermPortalCollection = (this.termCollection || this.mtCollection.termId) ? true : false;
110
109
  }
111
- if (initialRefresh) {
112
- this.updateEditables(this.mtCollection?.access);
113
- }
110
+ this.updateEditables(this.mtCollection?.access);
114
111
  this._isImporting = this.mtCollection && CombinedCollection.importingStatuses.includes(this.mtCollection?.status);
115
112
  this._default = (this.editables.userDefault || this.editables.groupDefault || this.editables.globalDefault) ?? false;
116
113
  this.updateIsSynchronized();
@@ -137,7 +134,7 @@ export class CombinedCollection {
137
134
  */
138
135
  deleteTerms() {
139
136
  this.termCollection = null;
140
- this.update(null, false);
137
+ this.update(null);
141
138
  }
142
139
  /**
143
140
  * Deletes mt collection and its properties.
@@ -188,4 +185,4 @@ export class CombinedCollection {
188
185
  }
189
186
  //#region Static properties
190
187
  CombinedCollection.importingStatuses = [MtCollectionStatus.IMPORTING, MtCollectionStatus.PROCESSING];
191
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"combined-collection.model.js","sourceRoot":"","sources":["../../../../../../../../projects/tld-translate/src/lib/modules/tld-term/services/models/combined-collection.model.ts"],"names":[],"mappings":"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","sourcesContent":["import { EngineTermCollectionAccess, EngineTermCollectionSource } from \"../engine-term/models\";\r\nimport { ITldTermCollection } from \"../term-api/models/tld-term-collection.model\";\r\nimport { CombinedCollectionTooltipKey } from \"./combined-collection-tooltip-key.enum\";\r\nimport { MtCollectionStatus } from \"./mt-collection-status.enum\";\r\nimport { MtCollection } from \"./mt-collection.model\";\r\n\r\n/**\r\n * Class that joins collection from term api and its imported collection from MT api.\r\n */\r\nexport class CombinedCollection {\r\n  mtCollection: MtCollection;\r\n  termCollection: ITldTermCollection;\r\n  termTooltipKey: CombinedCollectionTooltipKey;\r\n  source: EngineTermCollectionSource;\r\n  /**\r\n   * Modified date from term api or last updated from mt api.\r\n   */\r\n  lastUpdated: Date;\r\n\r\n  //#region Static properties\r\n  static importingStatuses = [MtCollectionStatus.IMPORTING, MtCollectionStatus.PROCESSING];\r\n\r\n  static findExistingCollectionFromList(collections: Iterable<CombinedCollection>, collection: CombinedCollection) {\r\n    for (const col of collections) {\r\n      if ((col.termId && col.termId == collection.termId) ||\r\n        (col.mtCollection?.id && col.mtCollection.id == collection.mtCollection?.id)) {\r\n        return col;\r\n      }\r\n    }\r\n    return null;\r\n  }\r\n\r\n  static findExistingIndexFromList(collections: Iterable<CombinedCollection>, collection: CombinedCollection): number {\r\n    if (!collections) {\r\n      return null;\r\n    }\r\n\r\n    let i = 0;\r\n    for (const col of collections) {\r\n      if ((col.termId && col.termId == collection.termId) ||\r\n        (col.mtCollection?.id && col.mtCollection.id == collection.mtCollection?.id)) {\r\n        return i;\r\n      }\r\n      i += 1;\r\n    }\r\n    return null;\r\n  }\r\n  //#endregion\r\n\r\n  //#region Editable MT (api v2) fields\r\n  editables: {\r\n    globalDefault?: boolean;\r\n    userDefault?: boolean;\r\n    groupDefault?: boolean;\r\n  } = {};\r\n  // #endregion\r\n\r\n  //#region Getters for common fields\r\n  // It is possible to optimize getters, by setting some of the values in update method, but it is left this way, so that data is more consistent.\r\n  // Otherwise it might be easy to miss some property updating and get wrong data in future.\r\n\r\n  private _isSynchronized: boolean = true;\r\n  /**\r\n   * Weather collection is synchronized with term portal collection. If no term collection, value is set to true.\r\n   */\r\n  get isSynchronized() {\r\n    return this._isSynchronized;\r\n  }\r\n\r\n  /**\r\n   * Determines if collections is 'syncable'. Returns true if it is not synced or if synchronization has failed and status is error.\r\n   */\r\n  private _syncButtonVisible: boolean;\r\n  get syncButtonVisible() { return this._syncButtonVisible; }\r\n  /**\r\n   * Term collection id. Returns value from term collection or from mt, if term collection not existing.\r\n   */\r\n  get termId() {\r\n    return this.termCollection?.id ?? this.mtCollection?.termId;\r\n  }\r\n\r\n  get mtStatus() {\r\n    return this.mtCollection?.status;\r\n  }\r\n\r\n  /**\r\n   * Collection name. If has term collection, takes from there. If not, then returns mt collection name.\r\n   */\r\n  get name() {\r\n    return this.termCollection?.name ?? this.mtCollection?.name;\r\n  }\r\n\r\n  /**\r\n   * Entry count from term api.\r\n   */\r\n  get termEntries() {\r\n    return this.termCollection?.entryCount;\r\n  }\r\n\r\n  /** Checks if has set to default in any scope */\r\n  private _default: boolean;\r\n  get default() { return this._default };\r\n\r\n  /**\r\n   * Status from mt api or custom \"NOT_IN_USE\" status if not imported in mt.s\r\n   */\r\n  get status() {\r\n    return this.mtStatus ?? MtCollectionStatus.NOT_IN_USE;\r\n  }\r\n\r\n  /**\r\n   * Scope can be edited only if has mt collcetion or term collection is being prepared for import.\r\n   */\r\n  get canEditScope() {\r\n    return this.mtCollection || this.default;\r\n  }\r\n\r\n  get termCount() {\r\n    return this.mtCollection?.termCount;\r\n  }\r\n\r\n  private _isTermPortalCollection: boolean;\r\n  get isTermPortalCollection() { return this._isTermPortalCollection; }\r\n\r\n  private _isImporting: boolean;\r\n  get isImporting() { return this._isImporting; }\r\n\r\n  //#endregion\r\n\r\n  constructor(termApiCollection: ITldTermCollection, mtCollection: MtCollection) {\r\n    this.mtCollection = mtCollection;\r\n    this.termCollection = termApiCollection;\r\n    this.update(null);\r\n  }\r\n\r\n  /**\r\n   * Updates collection with values from new collection.\r\n   * @param collection collection from which should be updated.\r\n   * @param initialRefresh if set to true, editable fields will also be updated.\r\n   */\r\n  update(collection: CombinedCollection, initialRefresh = true) {\r\n    if (collection?.termCollection) {\r\n      this.termCollection = collection.termCollection;\r\n    }\r\n\r\n    if (collection?.mtCollection) {\r\n      this.mtCollection = collection.mtCollection;\r\n    }\r\n\r\n    // V1 api could not contain collectionSource field value\r\n    if (this.mtCollection?.collectionSource && this.mtCollection.collectionSource !== null) {\r\n      this._isTermPortalCollection = this.mtCollection.collectionSource === EngineTermCollectionSource.TILDE_TERM ? true : false;\r\n    } else {\r\n      this._isTermPortalCollection = (this.termCollection || this.mtCollection.termId) ? true : false;\r\n    }\r\n\r\n    if (initialRefresh) {\r\n      this.updateEditables(this.mtCollection?.access);\r\n    }\r\n\r\n    this._isImporting = this.mtCollection && CombinedCollection.importingStatuses.includes(this.mtCollection?.status);\r\n    this._default = (this.editables.userDefault || this.editables.groupDefault || this.editables.globalDefault) ?? false;\r\n    this.updateIsSynchronized();\r\n    this.updateTooltipKey();\r\n    this.updateSource();\r\n  }\r\n\r\n  /**\r\n   * If some of editables are edited.\r\n   *\r\n   * if collection not imported and enabled not set, method will return true, because you cannot update collection if it is not imported or is not meant to be imported.\r\n   *\r\n   * @returns true if collection is edited, false if not.\r\n   */\r\n  isEdited() {\r\n    if ((this.mtCollection?.access.user?.default !== this.editables.userDefault)\r\n      || (this.mtCollection?.access.group?.default !== this.editables.groupDefault)\r\n      || (this.mtCollection?.access.global?.default !== this.editables.globalDefault)) {\r\n      return true;\r\n    }\r\n    return false;\r\n  }\r\n\r\n  /**\r\n   * Deletes term collection and its properties.\r\n   */\r\n  deleteTerms() {\r\n    this.termCollection = null;\r\n    this.update(null, false);\r\n  }\r\n\r\n\r\n  /**\r\n   * Deletes mt collection and its properties.\r\n   */\r\n  deleteMT() {\r\n    this.mtCollection = null;\r\n    this.update(null);\r\n  }\r\n\r\n  updateEditables(access: EngineTermCollectionAccess | null) {\r\n    if (!access) {\r\n      return;\r\n    }\r\n\r\n    this.editables.globalDefault = access.global?.default;\r\n    this.editables.groupDefault = access.group?.default;\r\n    this.editables.userDefault = access.user?.default;\r\n  }\r\n\r\n  //#region Private methods\r\n  private updateIsSynchronized() {\r\n    let isSynchronized = true;\r\n\r\n    const termModified = this.termCollection?.modifyDate;\r\n    const lastMtUpdated = this.mtCollection?.lastUpdated;\r\n    if (termModified && lastMtUpdated) {\r\n      isSynchronized = termModified <= lastMtUpdated;\r\n    }\r\n\r\n    this._isSynchronized = isSynchronized;\r\n    this.lastUpdated = lastMtUpdated ?? termModified;\r\n    this._syncButtonVisible = !this.isImporting && (!this.isSynchronized || (this.termCollection && this.mtStatus === MtCollectionStatus.ERROR))\r\n  }\r\n\r\n  private updateSource() {\r\n    if (this.termCollection) {\r\n      this.source = EngineTermCollectionSource.TILDE_TERM;\r\n    }\r\n    else if (this.mtCollection) {\r\n      this.source = EngineTermCollectionSource.FILE;\r\n    }\r\n  }\r\n\r\n  private updateTooltipKey() {\r\n    if (this.default) {\r\n      this.termTooltipKey = CombinedCollectionTooltipKey.DEFAULT_COLLECTION;\r\n    }\r\n    else if (this.termCollection?.entryCount === 0) {\r\n      this.termTooltipKey = CombinedCollectionTooltipKey.NO_ENTRIES;\r\n    }\r\n    else {\r\n      this.termTooltipKey = null;\r\n    }\r\n  }\r\n\r\n  //#endregion\r\n}\r\n"]}
188
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"combined-collection.model.js","sourceRoot":"","sources":["../../../../../../../../projects/tld-translate/src/lib/modules/tld-term/services/models/combined-collection.model.ts"],"names":[],"mappings":"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","sourcesContent":["import { EngineTermCollectionAccess, EngineTermCollectionSource } from \"../engine-term/models\";\r\nimport { ITldTermCollection } from \"../term-api/models/tld-term-collection.model\";\r\nimport { CombinedCollectionTooltipKey } from \"./combined-collection-tooltip-key.enum\";\r\nimport { MtCollectionStatus } from \"./mt-collection-status.enum\";\r\nimport { MtCollection } from \"./mt-collection.model\";\r\n\r\n/**\r\n * Class that joins collection from term api and its imported collection from MT api.\r\n */\r\nexport class CombinedCollection {\r\n  mtCollection: MtCollection;\r\n  termCollection: ITldTermCollection;\r\n  termTooltipKey: CombinedCollectionTooltipKey;\r\n  source: EngineTermCollectionSource;\r\n  /**\r\n   * Modified date from term api or last updated from mt api.\r\n   */\r\n  lastUpdated: Date;\r\n\r\n  //#region Static properties\r\n  static importingStatuses = [MtCollectionStatus.IMPORTING, MtCollectionStatus.PROCESSING];\r\n\r\n  static findExistingCollectionFromList(collections: Iterable<CombinedCollection>, collection: CombinedCollection) {\r\n    for (const col of collections) {\r\n      if ((col.termId && col.termId == collection.termId) ||\r\n        (col.mtCollection?.id && col.mtCollection.id == collection.mtCollection?.id)) {\r\n        return col;\r\n      }\r\n    }\r\n    return null;\r\n  }\r\n\r\n  static findExistingIndexFromList(collections: Iterable<CombinedCollection>, collection: CombinedCollection): number {\r\n    if (!collections) {\r\n      return null;\r\n    }\r\n\r\n    let i = 0;\r\n    for (const col of collections) {\r\n      if ((col.termId && col.termId == collection.termId) ||\r\n        (col.mtCollection?.id && col.mtCollection.id == collection.mtCollection?.id)) {\r\n        return i;\r\n      }\r\n      i += 1;\r\n    }\r\n    return null;\r\n  }\r\n  //#endregion\r\n\r\n  //#region Editable MT (api v2) fields\r\n  editables: {\r\n    globalDefault?: boolean;\r\n    userDefault?: boolean;\r\n    groupDefault?: boolean;\r\n  } = {};\r\n  // #endregion\r\n\r\n  //#region Getters for common fields\r\n  // It is possible to optimize getters, by setting some of the values in update method, but it is left this way, so that data is more consistent.\r\n  // Otherwise it might be easy to miss some property updating and get wrong data in future.\r\n\r\n  private _isSynchronized: boolean = true;\r\n  /**\r\n   * Weather collection is synchronized with term portal collection. If no term collection, value is set to true.\r\n   */\r\n  get isSynchronized() {\r\n    return this._isSynchronized;\r\n  }\r\n\r\n  /**\r\n   * Determines if collections is 'syncable'. Returns true if it is not synced or if synchronization has failed and status is error.\r\n   */\r\n  private _syncButtonVisible: boolean;\r\n  get syncButtonVisible() { return this._syncButtonVisible; }\r\n  /**\r\n   * Term collection id. Returns value from term collection or from mt, if term collection not existing.\r\n   */\r\n  get termId() {\r\n    return this.termCollection?.id ?? this.mtCollection?.termId;\r\n  }\r\n\r\n  get mtStatus() {\r\n    return this.mtCollection?.status;\r\n  }\r\n\r\n  /**\r\n   * Collection name. If has term collection, takes from there. If not, then returns mt collection name.\r\n   */\r\n  get name() {\r\n    return this.termCollection?.name ?? this.mtCollection?.name;\r\n  }\r\n\r\n  /**\r\n   * Entry count from term api.\r\n   */\r\n  get termEntries() {\r\n    return this.termCollection?.entryCount;\r\n  }\r\n\r\n  /** Checks if has set to default in any scope */\r\n  private _default: boolean;\r\n  get default() { return this._default };\r\n\r\n  /**\r\n   * Status from mt api or custom \"NOT_IN_USE\" status if not imported in mt.s\r\n   */\r\n  get status() {\r\n    return this.mtStatus ?? MtCollectionStatus.NOT_IN_USE;\r\n  }\r\n\r\n  /**\r\n   * Scope can be edited only if has mt collcetion or term collection is being prepared for import.\r\n   */\r\n  get canEditScope() {\r\n    return this.mtCollection || this.default;\r\n  }\r\n\r\n  get termCount() {\r\n    return this.mtCollection?.termCount;\r\n  }\r\n\r\n  private _isTermPortalCollection: boolean;\r\n  get isTermPortalCollection() { return this._isTermPortalCollection; }\r\n\r\n  private _isImporting: boolean;\r\n  get isImporting() { return this._isImporting; }\r\n\r\n  //#endregion\r\n\r\n  constructor(termApiCollection: ITldTermCollection, mtCollection: MtCollection) {\r\n    this.mtCollection = mtCollection;\r\n    this.termCollection = termApiCollection;\r\n    this.update(null);\r\n  }\r\n\r\n  /**\r\n   * Updates collection with values from new collection.\r\n   * @param collection collection from which should be updated.\r\n   */\r\n  update(collection: CombinedCollection) {\r\n    if (collection?.termCollection) {\r\n      this.termCollection = collection.termCollection;\r\n    }\r\n\r\n    if (collection?.mtCollection) {\r\n      this.mtCollection = collection.mtCollection;\r\n    }\r\n\r\n    // V1 api could not contain collectionSource field value\r\n    if (this.mtCollection?.collectionSource && this.mtCollection.collectionSource !== null) {\r\n      this._isTermPortalCollection = this.mtCollection.collectionSource === EngineTermCollectionSource.TILDE_TERM ? true : false;\r\n    } else {\r\n      this._isTermPortalCollection = (this.termCollection || this.mtCollection.termId) ? true : false;\r\n    }\r\n\r\n    this.updateEditables(this.mtCollection?.access);\r\n\r\n    this._isImporting = this.mtCollection && CombinedCollection.importingStatuses.includes(this.mtCollection?.status);\r\n    this._default = (this.editables.userDefault || this.editables.groupDefault || this.editables.globalDefault) ?? false;\r\n    this.updateIsSynchronized();\r\n    this.updateTooltipKey();\r\n    this.updateSource();\r\n  }\r\n\r\n  /**\r\n   * If some of editables are edited.\r\n   *\r\n   * if collection not imported and enabled not set, method will return true, because you cannot update collection if it is not imported or is not meant to be imported.\r\n   *\r\n   * @returns true if collection is edited, false if not.\r\n   */\r\n  isEdited() {\r\n    if ((this.mtCollection?.access.user?.default !== this.editables.userDefault)\r\n      || (this.mtCollection?.access.group?.default !== this.editables.groupDefault)\r\n      || (this.mtCollection?.access.global?.default !== this.editables.globalDefault)) {\r\n      return true;\r\n    }\r\n    return false;\r\n  }\r\n\r\n  /**\r\n   * Deletes term collection and its properties.\r\n   */\r\n  deleteTerms() {\r\n    this.termCollection = null;\r\n    this.update(null);\r\n  }\r\n\r\n\r\n  /**\r\n   * Deletes mt collection and its properties.\r\n   */\r\n  deleteMT() {\r\n    this.mtCollection = null;\r\n    this.update(null);\r\n  }\r\n\r\n  updateEditables(access: EngineTermCollectionAccess | null) {\r\n    if (!access) {\r\n      return;\r\n    }\r\n\r\n    this.editables.globalDefault = access.global?.default;\r\n    this.editables.groupDefault = access.group?.default;\r\n    this.editables.userDefault = access.user?.default;\r\n  }\r\n\r\n  //#region Private methods\r\n  private updateIsSynchronized() {\r\n    let isSynchronized = true;\r\n\r\n    const termModified = this.termCollection?.modifyDate;\r\n    const lastMtUpdated = this.mtCollection?.lastUpdated;\r\n    if (termModified && lastMtUpdated) {\r\n      isSynchronized = termModified <= lastMtUpdated;\r\n    }\r\n\r\n    this._isSynchronized = isSynchronized;\r\n    this.lastUpdated = lastMtUpdated ?? termModified;\r\n    this._syncButtonVisible = !this.isImporting && (!this.isSynchronized || (this.termCollection && this.mtStatus === MtCollectionStatus.ERROR))\r\n  }\r\n\r\n  private updateSource() {\r\n    if (this.termCollection) {\r\n      this.source = EngineTermCollectionSource.TILDE_TERM;\r\n    }\r\n    else if (this.mtCollection) {\r\n      this.source = EngineTermCollectionSource.FILE;\r\n    }\r\n  }\r\n\r\n  private updateTooltipKey() {\r\n    if (this.default) {\r\n      this.termTooltipKey = CombinedCollectionTooltipKey.DEFAULT_COLLECTION;\r\n    }\r\n    else if (this.termCollection?.entryCount === 0) {\r\n      this.termTooltipKey = CombinedCollectionTooltipKey.NO_ENTRIES;\r\n    }\r\n    else {\r\n      this.termTooltipKey = null;\r\n    }\r\n  }\r\n\r\n  //#endregion\r\n}\r\n"]}
@@ -22,7 +22,7 @@ export class TermApiService {
22
22
  return this.convertToCombinedCollection(collection);
23
23
  }));
24
24
  }
25
- getCollectionList(languages) {
25
+ getCollectionList() {
26
26
  return this.http.get(this.url)
27
27
  .pipe(map((collections) => {
28
28
  const converted = [];
@@ -56,4 +56,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
56
56
  providedIn: 'root'
57
57
  }]
58
58
  }], ctorParameters: function () { return [{ type: i1.TldTranslateConfigService }, { type: i2.HttpClient }]; } });
59
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVybS1hcGkuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3RsZC10cmFuc2xhdGUvc3JjL2xpYi9tb2R1bGVzL3RsZC10ZXJtL3NlcnZpY2VzL3Rlcm0tYXBpL3Rlcm0tYXBpLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzQyxPQUFPLEVBQUUsR0FBRyxFQUFjLE1BQU0sTUFBTSxDQUFDO0FBR3ZDLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHFDQUFxQyxDQUFDOzs7O0FBS3pFLE1BQU0sT0FBTyxjQUFjO0lBS3pCLFlBQTZCLE1BQWlDLEVBQW1CLElBQWdCO1FBQXBFLFdBQU0sR0FBTixNQUFNLENBQTJCO1FBQW1CLFNBQUksR0FBSixJQUFJLENBQVk7SUFBSSxDQUFDO0lBSnRHLElBQUksR0FBRztRQUNMLE9BQU8sR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLFVBQVUsQ0FBQyxvQkFBb0IsNkJBQTZCLENBQUM7SUFDckYsQ0FBQztJQUlELGdCQUFnQixDQUFDLGdCQUEwQixFQUFFLGNBQXNCO1FBQ2pFLE1BQU0sTUFBTSxHQUFHO1lBQ2IsSUFBSSxFQUFFLGNBQWM7WUFDcEIsZ0JBQWdCO1NBQ2pCLENBQUM7UUFDRixPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFxQixJQUFJLENBQUMsR0FBRyxFQUFFLE1BQU0sQ0FBQzthQUN4RCxJQUFJLENBQ0gsR0FBRyxDQUFDLENBQUMsVUFBVSxFQUFFLEVBQUU7WUFDakIsT0FBTyxJQUFJLENBQUMsMkJBQTJCLENBQUMsVUFBVSxDQUFDLENBQUM7UUFDdEQsQ0FBQyxDQUFDLENBQ0gsQ0FBQztJQUNOLENBQUM7SUFFRCxpQkFBaUIsQ0FBQyxTQUFvQjtRQUNwQyxPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUF1QixJQUFJLENBQUMsR0FBRyxDQUFDO2FBQ2pELElBQUksQ0FDSCxHQUFHLENBQUMsQ0FBQyxXQUFXLEVBQUUsRUFBRTtZQUNsQixNQUFNLFNBQVMsR0FBeUIsRUFBRSxDQUFDO1lBQzNDLFdBQVcsQ0FBQyxPQUFPLENBQUMsQ0FBQyxVQUFVLEVBQUUsRUFBRTtnQkFDakMsU0FBUyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsMkJBQTJCLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQztZQUMvRCxDQUFDLENBQUMsQ0FBQTtZQUNGLE9BQU8sU0FBUyxDQUFDO1FBQ25CLENBQUMsQ0FBQyxDQUNILENBQUM7SUFDTixDQUFDO0lBRUQsV0FBVyxDQUFDLE1BQWMsRUFBRSxjQUF1QixFQUFFLGNBQXVCO1FBQzFFLElBQUksSUFBSSxHQUFHLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxVQUFVLENBQUMsb0JBQW9CLGdCQUFnQixNQUFNLEtBQUssQ0FBQztRQUNyRixJQUFJLGNBQWMsRUFBRTtZQUNsQixJQUFJLEdBQUcsR0FBRyxJQUFJLElBQUksY0FBYyxFQUFFLENBQUM7U0FDcEM7UUFDRCxJQUFJLGNBQWMsRUFBRTtZQUNsQixJQUFJLEdBQUcsR0FBRyxJQUFJLElBQUksY0FBYyxFQUFFLENBQUM7U0FDcEM7UUFDRCxPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7SUFFTywyQkFBMkIsQ0FBQyxVQUE4QjtRQUNoRSxtRkFBbUY7UUFDbkYsVUFBVSxDQUFDLFVBQVUsR0FBRyxJQUFJLElBQUksQ0FBQyxVQUFVLENBQUMsVUFBVSxDQUFDLFFBQVEsRUFBRSxHQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQ3ZFLE9BQU8sSUFBSSxrQkFBa0IsQ0FBQyxVQUFVLEVBQUUsSUFBSSxDQUFDLENBQUM7SUFDbEQsQ0FBQzs7MkdBaERVLGNBQWM7K0dBQWQsY0FBYyxjQUZiLE1BQU07MkZBRVAsY0FBYztrQkFIMUIsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBIdHRwQ2xpZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uL2h0dHAnO1xyXG5pbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IG1hcCwgT2JzZXJ2YWJsZSB9IGZyb20gJ3J4anMnO1xyXG5pbXBvcnQgeyBUbGRUcmFuc2xhdGVDb25maWdTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vLi4vdGxkLWNvbW1vbi9zZXJ2aWNlcy90bGQtdHJhbnNsYXRlLWNvbmZpZy5zZXJ2aWNlJztcclxuaW1wb3J0IHsgSVRsZFRlcm1Db2xsZWN0aW9uIH0gZnJvbSAnLi9tb2RlbHMvdGxkLXRlcm0tY29sbGVjdGlvbi5tb2RlbCc7XHJcbmltcG9ydCB7IENvbWJpbmVkQ29sbGVjdGlvbiB9IGZyb20gJy4uL21vZGVscy9jb21iaW5lZC1jb2xsZWN0aW9uLm1vZGVsJztcclxuXHJcbkBJbmplY3RhYmxlKHtcclxuICBwcm92aWRlZEluOiAncm9vdCdcclxufSlcclxuZXhwb3J0IGNsYXNzIFRlcm1BcGlTZXJ2aWNlIHtcclxuICBnZXQgdXJsKCkge1xyXG4gICAgcmV0dXJuIGAke3RoaXMuY29uZmlnLnRlcm1Db25maWcudGVybWlub2xvZ3lQb3J0YWxVcmx9L2FwaS90ZXJtc2VydmljZS9jb2xsZWN0aW9uYDtcclxuICB9XHJcblxyXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgcmVhZG9ubHkgY29uZmlnOiBUbGRUcmFuc2xhdGVDb25maWdTZXJ2aWNlLCBwcml2YXRlIHJlYWRvbmx5IGh0dHA6IEh0dHBDbGllbnQpIHsgfVxyXG5cclxuICBjcmVhdGVDb2xsZWN0aW9uKGRlZmF1bHRMYW5ndWFnZXM6IHN0cmluZ1tdLCBjb2xsZWN0aW9uTmFtZTogc3RyaW5nKTogT2JzZXJ2YWJsZTxDb21iaW5lZENvbGxlY3Rpb24+IHtcclxuICAgIGNvbnN0IHBhcmFtcyA9IHtcclxuICAgICAgbmFtZTogY29sbGVjdGlvbk5hbWUsXHJcbiAgICAgIGRlZmF1bHRMYW5ndWFnZXNcclxuICAgIH07XHJcbiAgICByZXR1cm4gdGhpcy5odHRwLnBvc3Q8SVRsZFRlcm1Db2xsZWN0aW9uPih0aGlzLnVybCwgcGFyYW1zKVxyXG4gICAgICAucGlwZShcclxuICAgICAgICBtYXAoKGNvbGxlY3Rpb24pID0+IHtcclxuICAgICAgICAgIHJldHVybiB0aGlzLmNvbnZlcnRUb0NvbWJpbmVkQ29sbGVjdGlvbihjb2xsZWN0aW9uKTtcclxuICAgICAgICB9KVxyXG4gICAgICApO1xyXG4gIH1cclxuXHJcbiAgZ2V0Q29sbGVjdGlvbkxpc3QobGFuZ3VhZ2VzPzogc3RyaW5nW10pOiBPYnNlcnZhYmxlPENvbWJpbmVkQ29sbGVjdGlvbltdPiB7XHJcbiAgICByZXR1cm4gdGhpcy5odHRwLmdldDxJVGxkVGVybUNvbGxlY3Rpb25bXT4odGhpcy51cmwpXHJcbiAgICAgIC5waXBlKFxyXG4gICAgICAgIG1hcCgoY29sbGVjdGlvbnMpID0+IHtcclxuICAgICAgICAgIGNvbnN0IGNvbnZlcnRlZDogQ29tYmluZWRDb2xsZWN0aW9uW10gPSBbXTtcclxuICAgICAgICAgIGNvbGxlY3Rpb25zLmZvckVhY2goKGNvbGxlY3Rpb24pID0+IHtcclxuICAgICAgICAgICAgY29udmVydGVkLnB1c2godGhpcy5jb252ZXJ0VG9Db21iaW5lZENvbGxlY3Rpb24oY29sbGVjdGlvbikpO1xyXG4gICAgICAgICAgfSlcclxuICAgICAgICAgIHJldHVybiBjb252ZXJ0ZWQ7XHJcbiAgICAgICAgfSlcclxuICAgICAgKTtcclxuICB9XHJcblxyXG4gIGdldEVkaXRMaW5rKHRlcm1JZDogc3RyaW5nLCBzb3VyY2VMYW5ndWFnZT86IHN0cmluZywgdGFyZ2V0TGFuZ3VhZ2U/OiBzdHJpbmcpIHtcclxuICAgIGxldCBsaW5rID0gYCR7dGhpcy5jb25maWcudGVybUNvbmZpZy50ZXJtaW5vbG9neVBvcnRhbFVybH0vY29sbGVjdGlvbnMvJHt0ZXJtSWR9L210YDtcclxuICAgIGlmIChzb3VyY2VMYW5ndWFnZSkge1xyXG4gICAgICBsaW5rID0gYCR7bGlua30vJHtzb3VyY2VMYW5ndWFnZX1gO1xyXG4gICAgfVxyXG4gICAgaWYgKHRhcmdldExhbmd1YWdlKSB7XHJcbiAgICAgIGxpbmsgPSBgJHtsaW5rfS8ke3RhcmdldExhbmd1YWdlfWA7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gbGluaztcclxuICB9XHJcblxyXG4gIHByaXZhdGUgY29udmVydFRvQ29tYmluZWRDb2xsZWN0aW9uKGNvbGxlY3Rpb246IElUbGRUZXJtQ29sbGVjdGlvbikge1xyXG4gICAgLy8gZGlydHkgYXBwcm9hY2gsIGJ1dCB0ZXJtIHBvcnRhbCBub3QgcmV0dXJuaW5nIHRpbWV6b25lLCBidXQgcmV0dXJucyBkYXRlcyBhcyBVVENcclxuICAgIGNvbGxlY3Rpb24ubW9kaWZ5RGF0ZSA9IG5ldyBEYXRlKGNvbGxlY3Rpb24ubW9kaWZ5RGF0ZS50b1N0cmluZygpK1wiWlwiKTtcclxuICAgIHJldHVybiBuZXcgQ29tYmluZWRDb2xsZWN0aW9uKGNvbGxlY3Rpb24sIG51bGwpO1xyXG4gIH1cclxufVxyXG4iXX0=
59
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVybS1hcGkuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3RsZC10cmFuc2xhdGUvc3JjL2xpYi9tb2R1bGVzL3RsZC10ZXJtL3NlcnZpY2VzL3Rlcm0tYXBpL3Rlcm0tYXBpLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzQyxPQUFPLEVBQUUsR0FBRyxFQUFjLE1BQU0sTUFBTSxDQUFDO0FBR3ZDLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHFDQUFxQyxDQUFDOzs7O0FBS3pFLE1BQU0sT0FBTyxjQUFjO0lBS3pCLFlBQTZCLE1BQWlDLEVBQW1CLElBQWdCO1FBQXBFLFdBQU0sR0FBTixNQUFNLENBQTJCO1FBQW1CLFNBQUksR0FBSixJQUFJLENBQVk7SUFBSSxDQUFDO0lBSnRHLElBQUksR0FBRztRQUNMLE9BQU8sR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLFVBQVUsQ0FBQyxvQkFBb0IsNkJBQTZCLENBQUM7SUFDckYsQ0FBQztJQUlELGdCQUFnQixDQUFDLGdCQUEwQixFQUFFLGNBQXNCO1FBQ2pFLE1BQU0sTUFBTSxHQUFHO1lBQ2IsSUFBSSxFQUFFLGNBQWM7WUFDcEIsZ0JBQWdCO1NBQ2pCLENBQUM7UUFDRixPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFxQixJQUFJLENBQUMsR0FBRyxFQUFFLE1BQU0sQ0FBQzthQUN4RCxJQUFJLENBQ0gsR0FBRyxDQUFDLENBQUMsVUFBVSxFQUFFLEVBQUU7WUFDakIsT0FBTyxJQUFJLENBQUMsMkJBQTJCLENBQUMsVUFBVSxDQUFDLENBQUM7UUFDdEQsQ0FBQyxDQUFDLENBQ0gsQ0FBQztJQUNOLENBQUM7SUFFRCxpQkFBaUI7UUFDZixPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUF1QixJQUFJLENBQUMsR0FBRyxDQUFDO2FBQ2pELElBQUksQ0FDSCxHQUFHLENBQUMsQ0FBQyxXQUFXLEVBQUUsRUFBRTtZQUNsQixNQUFNLFNBQVMsR0FBeUIsRUFBRSxDQUFDO1lBQzNDLFdBQVcsQ0FBQyxPQUFPLENBQUMsQ0FBQyxVQUFVLEVBQUUsRUFBRTtnQkFDakMsU0FBUyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsMkJBQTJCLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQztZQUMvRCxDQUFDLENBQUMsQ0FBQTtZQUNGLE9BQU8sU0FBUyxDQUFDO1FBQ25CLENBQUMsQ0FBQyxDQUNILENBQUM7SUFDTixDQUFDO0lBRUQsV0FBVyxDQUFDLE1BQWMsRUFBRSxjQUF1QixFQUFFLGNBQXVCO1FBQzFFLElBQUksSUFBSSxHQUFHLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxVQUFVLENBQUMsb0JBQW9CLGdCQUFnQixNQUFNLEtBQUssQ0FBQztRQUNyRixJQUFJLGNBQWMsRUFBRTtZQUNsQixJQUFJLEdBQUcsR0FBRyxJQUFJLElBQUksY0FBYyxFQUFFLENBQUM7U0FDcEM7UUFDRCxJQUFJLGNBQWMsRUFBRTtZQUNsQixJQUFJLEdBQUcsR0FBRyxJQUFJLElBQUksY0FBYyxFQUFFLENBQUM7U0FDcEM7UUFDRCxPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7SUFFTywyQkFBMkIsQ0FBQyxVQUE4QjtRQUNoRSxtRkFBbUY7UUFDbkYsVUFBVSxDQUFDLFVBQVUsR0FBRyxJQUFJLElBQUksQ0FBQyxVQUFVLENBQUMsVUFBVSxDQUFDLFFBQVEsRUFBRSxHQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQ3ZFLE9BQU8sSUFBSSxrQkFBa0IsQ0FBQyxVQUFVLEVBQUUsSUFBSSxDQUFDLENBQUM7SUFDbEQsQ0FBQzs7MkdBaERVLGNBQWM7K0dBQWQsY0FBYyxjQUZiLE1BQU07MkZBRVAsY0FBYztrQkFIMUIsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBIdHRwQ2xpZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uL2h0dHAnO1xyXG5pbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IG1hcCwgT2JzZXJ2YWJsZSB9IGZyb20gJ3J4anMnO1xyXG5pbXBvcnQgeyBUbGRUcmFuc2xhdGVDb25maWdTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vLi4vdGxkLWNvbW1vbi9zZXJ2aWNlcy90bGQtdHJhbnNsYXRlLWNvbmZpZy5zZXJ2aWNlJztcclxuaW1wb3J0IHsgSVRsZFRlcm1Db2xsZWN0aW9uIH0gZnJvbSAnLi9tb2RlbHMvdGxkLXRlcm0tY29sbGVjdGlvbi5tb2RlbCc7XHJcbmltcG9ydCB7IENvbWJpbmVkQ29sbGVjdGlvbiB9IGZyb20gJy4uL21vZGVscy9jb21iaW5lZC1jb2xsZWN0aW9uLm1vZGVsJztcclxuXHJcbkBJbmplY3RhYmxlKHtcclxuICBwcm92aWRlZEluOiAncm9vdCdcclxufSlcclxuZXhwb3J0IGNsYXNzIFRlcm1BcGlTZXJ2aWNlIHtcclxuICBnZXQgdXJsKCkge1xyXG4gICAgcmV0dXJuIGAke3RoaXMuY29uZmlnLnRlcm1Db25maWcudGVybWlub2xvZ3lQb3J0YWxVcmx9L2FwaS90ZXJtc2VydmljZS9jb2xsZWN0aW9uYDtcclxuICB9XHJcblxyXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgcmVhZG9ubHkgY29uZmlnOiBUbGRUcmFuc2xhdGVDb25maWdTZXJ2aWNlLCBwcml2YXRlIHJlYWRvbmx5IGh0dHA6IEh0dHBDbGllbnQpIHsgfVxyXG5cclxuICBjcmVhdGVDb2xsZWN0aW9uKGRlZmF1bHRMYW5ndWFnZXM6IHN0cmluZ1tdLCBjb2xsZWN0aW9uTmFtZTogc3RyaW5nKTogT2JzZXJ2YWJsZTxDb21iaW5lZENvbGxlY3Rpb24+IHtcclxuICAgIGNvbnN0IHBhcmFtcyA9IHtcclxuICAgICAgbmFtZTogY29sbGVjdGlvbk5hbWUsXHJcbiAgICAgIGRlZmF1bHRMYW5ndWFnZXNcclxuICAgIH07XHJcbiAgICByZXR1cm4gdGhpcy5odHRwLnBvc3Q8SVRsZFRlcm1Db2xsZWN0aW9uPih0aGlzLnVybCwgcGFyYW1zKVxyXG4gICAgICAucGlwZShcclxuICAgICAgICBtYXAoKGNvbGxlY3Rpb24pID0+IHtcclxuICAgICAgICAgIHJldHVybiB0aGlzLmNvbnZlcnRUb0NvbWJpbmVkQ29sbGVjdGlvbihjb2xsZWN0aW9uKTtcclxuICAgICAgICB9KVxyXG4gICAgICApO1xyXG4gIH1cclxuXHJcbiAgZ2V0Q29sbGVjdGlvbkxpc3QoKTogT2JzZXJ2YWJsZTxDb21iaW5lZENvbGxlY3Rpb25bXT4ge1xyXG4gICAgcmV0dXJuIHRoaXMuaHR0cC5nZXQ8SVRsZFRlcm1Db2xsZWN0aW9uW10+KHRoaXMudXJsKVxyXG4gICAgICAucGlwZShcclxuICAgICAgICBtYXAoKGNvbGxlY3Rpb25zKSA9PiB7XHJcbiAgICAgICAgICBjb25zdCBjb252ZXJ0ZWQ6IENvbWJpbmVkQ29sbGVjdGlvbltdID0gW107XHJcbiAgICAgICAgICBjb2xsZWN0aW9ucy5mb3JFYWNoKChjb2xsZWN0aW9uKSA9PiB7XHJcbiAgICAgICAgICAgIGNvbnZlcnRlZC5wdXNoKHRoaXMuY29udmVydFRvQ29tYmluZWRDb2xsZWN0aW9uKGNvbGxlY3Rpb24pKTtcclxuICAgICAgICAgIH0pXHJcbiAgICAgICAgICByZXR1cm4gY29udmVydGVkO1xyXG4gICAgICAgIH0pXHJcbiAgICAgICk7XHJcbiAgfVxyXG5cclxuICBnZXRFZGl0TGluayh0ZXJtSWQ6IHN0cmluZywgc291cmNlTGFuZ3VhZ2U/OiBzdHJpbmcsIHRhcmdldExhbmd1YWdlPzogc3RyaW5nKSB7XHJcbiAgICBsZXQgbGluayA9IGAke3RoaXMuY29uZmlnLnRlcm1Db25maWcudGVybWlub2xvZ3lQb3J0YWxVcmx9L2NvbGxlY3Rpb25zLyR7dGVybUlkfS9tdGA7XHJcbiAgICBpZiAoc291cmNlTGFuZ3VhZ2UpIHtcclxuICAgICAgbGluayA9IGAke2xpbmt9LyR7c291cmNlTGFuZ3VhZ2V9YDtcclxuICAgIH1cclxuICAgIGlmICh0YXJnZXRMYW5ndWFnZSkge1xyXG4gICAgICBsaW5rID0gYCR7bGlua30vJHt0YXJnZXRMYW5ndWFnZX1gO1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIGxpbms7XHJcbiAgfVxyXG5cclxuICBwcml2YXRlIGNvbnZlcnRUb0NvbWJpbmVkQ29sbGVjdGlvbihjb2xsZWN0aW9uOiBJVGxkVGVybUNvbGxlY3Rpb24pIHtcclxuICAgIC8vIGRpcnR5IGFwcHJvYWNoLCBidXQgdGVybSBwb3J0YWwgbm90IHJldHVybmluZyB0aW1lem9uZSwgYnV0IHJldHVybnMgZGF0ZXMgYXMgVVRDXHJcbiAgICBjb2xsZWN0aW9uLm1vZGlmeURhdGUgPSBuZXcgRGF0ZShjb2xsZWN0aW9uLm1vZGlmeURhdGUudG9TdHJpbmcoKStcIlpcIik7XHJcbiAgICByZXR1cm4gbmV3IENvbWJpbmVkQ29sbGVjdGlvbihjb2xsZWN0aW9uLCBudWxsKTtcclxuICB9XHJcbn1cclxuIl19
@@ -63,11 +63,11 @@ export class TerminologyService {
63
63
  this._selected = null;
64
64
  }
65
65
  if (this.engineId) {
66
- this.refreshCollections(setSelectedFromLocalStorage, true);
66
+ this.refreshCollections(setSelectedFromLocalStorage);
67
67
  }
68
68
  return this.dataUpdate();
69
69
  }
70
- refreshCollections(setSelectedFromLocalStorage = false, initialRefresh = false) {
70
+ refreshCollections(setSelectedFromLocalStorage = false) {
71
71
  if (!this.engineId || !this.config.termConfig.isCollectionsActivated || this.isRefreshingCollections) {
72
72
  return;
73
73
  }
@@ -78,7 +78,7 @@ export class TerminologyService {
78
78
  let mtApiResponse;
79
79
  const observables = [];
80
80
  if (this.refreshTermCollections) {
81
- observables.push(this.termApi.getCollectionList(this.engineLanguages)
81
+ observables.push(this.termApi.getCollectionList()
82
82
  .pipe(tap((response) => termResponse = response)));
83
83
  }
84
84
  if (this.refreshMtCollections) {
@@ -90,7 +90,7 @@ export class TerminologyService {
90
90
  next: () => {
91
91
  this.isAnyImporting = false;
92
92
  // note that termResponse and mtapiresponse gets changed during remove method
93
- this.removeDeleted(termResponse, mtApiResponse, initialRefresh);
93
+ this.removeDeleted(termResponse, mtApiResponse);
94
94
  const joined = [];
95
95
  if (mtApiResponse) {
96
96
  joined.push(...mtApiResponse);
@@ -98,7 +98,7 @@ export class TerminologyService {
98
98
  if (termResponse) {
99
99
  joined.push(...termResponse);
100
100
  }
101
- this.addCollections(joined, initialRefresh);
101
+ this.addCollections(joined);
102
102
  if (setSelectedFromLocalStorage) {
103
103
  this.setSelectedFromLocalStorage();
104
104
  }
@@ -192,9 +192,8 @@ export class TerminologyService {
192
192
  /**
193
193
  *
194
194
  * @param newCollections
195
- * @param initialRefresh Whether also editable collection fields should be updated. If not initial refresh, editable fields will not be updated.
196
195
  */
197
- addCollections(newCollections, initialRefresh) {
196
+ addCollections(newCollections) {
198
197
  // sets collection list to this value at the end, so deleted collections are not in the list.
199
198
  for (let collection of newCollections) {
200
199
  // User shouldn't see failed collections if he can't retry to import them.
@@ -223,7 +222,7 @@ export class TerminologyService {
223
222
  this._collections.add(collection);
224
223
  }
225
224
  else {
226
- existing.update(collection, initialRefresh);
225
+ existing.update(collection);
227
226
  }
228
227
  }
229
228
  // this._collections = updatedCollections;
@@ -233,7 +232,7 @@ export class TerminologyService {
233
232
  /**
234
233
  * Should be called after refresh to check if there is any collections from api that are deleted.
235
234
  */
236
- removeDeleted(termResponse, mtResponse, initialRefresh) {
235
+ removeDeleted(termResponse, mtResponse) {
237
236
  for (const collection of this.collections) {
238
237
  const termExistingIx = CombinedCollection.findExistingIndexFromList(termResponse, collection);
239
238
  const mtExistingIx = CombinedCollection.findExistingIndexFromList(mtResponse, collection);
@@ -246,7 +245,7 @@ export class TerminologyService {
246
245
  else {
247
246
  if (termExistingIx !== null) {
248
247
  const existing = termResponse[termExistingIx];
249
- collection.update(existing, initialRefresh);
248
+ collection.update(existing);
250
249
  termResponse.splice(termExistingIx, 1);
251
250
  }
252
251
  else {
@@ -254,7 +253,7 @@ export class TerminologyService {
254
253
  }
255
254
  if (mtExistingIx !== null) {
256
255
  const existing = mtResponse[mtExistingIx];
257
- collection.update(existing, initialRefresh);
256
+ collection.update(existing);
258
257
  mtResponse.splice(mtExistingIx, 1);
259
258
  }
260
259
  else {
@@ -314,4 +313,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
314
313
  type: Inject,
315
314
  args: [MT_TERM_API_TOKEN]
316
315
  }] }]; } });
317
- //# 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,EAAE,EAAE,OAAO,EAAE,GAAG,EAAE,MAAM,MAAM,CAAC;AAC9D,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;IA6D7B,YAA6B,MAAiC,EAC3C,OAAuB,EACvB,MAAuB,EACL,KAAqB;QAH7B,WAAM,GAAN,MAAM,CAA2B;QAC3C,YAAO,GAAP,OAAO,CAAgB;QACvB,WAAM,GAAN,MAAM,CAAiB;QACL,UAAK,GAAL,KAAK,CAAgB;QA9DlD,cAAS,GAAuB,IAAI,CAAC;QA6C5B,iBAAY,GAAG,IAAI,OAAO,EAA2B,CAAC;QAEtD,sBAAiB,GAAG,uBAAuB,CAAC;IAeC,CAAC;IA7D/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;QACD,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;IAqBD,UAAU;QACR,OAAO,IAAI,CAAC,YAAY,CAAC,YAAY,EAAE,CAAC;IAC1C,CAAC;IAED,SAAS,CAAC,QAAgB,EAAE,YAAsB,IAAI,EAAE,2BAA2B,GAAG,KAAK,EAAE,eAAe,GAAG,IAAI,EAAE,aAAa,GAAG,IAAI;QACvI,gEAAgE;QAChE,IAAI,QAAQ,KAAK,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,KAAK,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,eAAe,CAAC;eAC/F,IAAI,CAAC,oBAAoB,KAAK,aAAa,IAAI,IAAI,CAAC,sBAAsB,KAAK,eAAe,EAAE;YACnG,IAAI,CAAC,eAAe,GAAG,SAAS,CAAC;YACjC,IAAI,CAAC,oBAAoB,GAAG,aAAa,CAAC;YAC1C,IAAI,CAAC,sBAAsB,GAAG,eAAe,CAAC;YAC9C,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,UAAU,EAAE,CAAC;IAC3B,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,EAAE,CAAC;QAE3D,IAAI,IAAI,CAAC,sBAAsB,EAAE;YAC/B,WAAW,CAAC,IAAI,CACd,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,CACJ,CAAA;SACF;QACD,IAAI,IAAI,CAAC,oBAAoB,EAAE;YAC7B,WAAW,CAAC,IAAI,CACd,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,CACJ,CAAC;SACH;QACD,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;gBAEhE,MAAM,MAAM,GAAG,EAAE,CAAC;gBAClB,IAAI,aAAa,EAAE;oBACjB,MAAM,CAAC,IAAI,CAAC,GAAG,aAAa,CAAC,CAAC;iBAC/B;gBACD,IAAI,YAAY,EAAE;oBAChB,MAAM,CAAC,IAAI,CAAC,GAAG,YAAY,CAAC,CAAC;iBAC9B;gBAED,IAAI,CAAC,cAAc,CAAC,MAAM,EAAE,cAAc,CAAC,CAAC;gBAC5C,IAAI,2BAA2B,EAAE;oBAC/B,IAAI,CAAC,2BAA2B,EAAE,CAAC;iBACpC;gBACD,IAAI,CAAC,wBAAwB,GAAG,KAAK,CAAC;gBACtC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;YAC7B,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,IAAI,CAAC,iBAAiB,CAAC,UAAU,EAAE,IAAI,CAAC,CAAC,SAAS,CAChD;YACE,KAAK,EAAE,CAAC,KAAK,EAAE,EAAE;gBACf,IAAI,CAAC,MAAM,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC;gBACnC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;YACvB,CAAC;SACF,CACF,CAAA;IACH,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,EAAE,QAAQ,GAAG,KAAK;QAChE,8DAA8D;QAC9D,IAAI,UAAU,CAAC,QAAQ,EAAE,IAAI,QAAQ,EAAE;YACrC,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,QAAQ,EAAE,UAAU,CAAC;iBAC7C,IAAI,CACH,GAAG,CAAC,CAAC,iBAAiB,EAAE,EAAE;gBACxB,UAAU,CAAC,MAAM,CAAC,iBAAiB,CAAC,CAAC;YACvC,CAAC,CAAC,CACH,CAAC;SACL;aACI;YACH,OAAO,EAAE,CAAC,UAAU,CAAC,CAAC;SACvB;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,EAAE,eAAe,GAAG,IAAI,EAAE,aAAa,GAAG,IAAI;QAC/I,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,EAAE,eAAe,EAAE,aAAa,CAAC,CAAC;IACnJ,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;IAED,IAAI,CAAC,UAA8B,EAAE,QAAQ,GAAG,IAAI,CAAC,QAAQ;QAC3D,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,QAAQ,EAAE,UAAU,CAAC;YAC1C,IAAI,CAAC,GAAG,CAAC,CAAC,iBAAiB,EAAE,EAAE,GAAG,UAAU,CAAC,MAAM,CAAC,iBAAiB,CAAC,CAAA,CAAC,CAAC,CAAC,CAAC,CAAA;IAC9E,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;gBAEpC,IAAI,IAAI,CAAC,QAAQ,KAAK,UAAU,EAAE;oBAChC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;iBACtB;aACF;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;;+GA1XU,kBAAkB,wHAgEnB,iBAAiB;mHAhEhB,kBAAkB,cAFjB,MAAM;2FAEP,kBAAkB;kBAH9B,UAAU;mBAAC;oBACV,UAAU,EAAE,MAAM;iBACnB;;0BAiEI,MAAM;2BAAC,iBAAiB","sourcesContent":["import { Inject, Injectable } from '@angular/core';\r\nimport { forkJoin, Observable, of, Subject, tap } from 'rxjs';\r\nimport { MT_TERM_API_TOKEN } from '../../../injection-tokens';\r\nimport { TldAlertService, 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    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  private refreshMtCollections: boolean;\r\n  private refreshTermCollections: boolean;\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    private readonly alerts: TldAlertService,\r\n    @Inject(MT_TERM_API_TOKEN) private mtApi: IMtTermService) { }\r\n\r\n  dataUpdate() {\r\n    return this.onDataUpdate.asObservable();\r\n  }\r\n\r\n  setEngine(engineId: string, languages: string[] = null, setSelectedFromLocalStorage = false, termCollections = true, mtCollections = true): 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.refreshMtCollections !== mtCollections || this.refreshTermCollections !== termCollections) {\r\n      this.engineLanguages = languages;\r\n      this.refreshMtCollections = mtCollections;\r\n      this.refreshTermCollections = termCollections;\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.dataUpdate();\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\r\n    if (this.refreshTermCollections) {\r\n      observables.push(\r\n        this.termApi.getCollectionList(this.engineLanguages)\r\n          .pipe(\r\n            tap((response) => termResponse = response)\r\n          )\r\n      )\r\n    }\r\n    if (this.refreshMtCollections) {\r\n      observables.push(\r\n        this.mtApi.getList(this.engineId)\r\n          .pipe(\r\n            tap((response) => mtApiResponse = response)\r\n          )\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\r\n        const joined = [];\r\n        if (mtApiResponse) {\r\n          joined.push(...mtApiResponse);\r\n        }\r\n        if (termResponse) {\r\n          joined.push(...termResponse);\r\n        }\r\n\r\n        this.addCollections(joined, initialRefresh);\r\n        if (setSelectedFromLocalStorage) {\r\n          this.setSelectedFromLocalStorage();\r\n        }\r\n        this._isRefreshingCollections = false;\r\n        this.scheduleRefresh(null);\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    this.updateIfNecessary(collection, true).subscribe(\r\n      {\r\n        error: (error) => {\r\n          this.alerts.unhandeledError(error);\r\n          this.selected = null;\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, isEdited = false): Observable<CombinedCollection> {\r\n    // collection is not imported and should be attached to engine\r\n    if (collection.isEdited() || isEdited) {\r\n      return this.mtApi.add(this.engineId, collection)\r\n        .pipe(\r\n          tap((updatedCollection) => {\r\n            collection.update(updatedCollection);\r\n          })\r\n        );\r\n    }\r\n    else {\r\n      return of(collection);\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, termCollections = true, mtCollections = true) {\r\n    this.hardAutoRefresh = true;\r\n    return this.setEngine(engineId ?? this.engineId, languages ?? this.engineLanguages, setSelectedFromLocalStorage, termCollections, mtCollections);\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  sync(collection: CombinedCollection, engineId = this.engineId): Observable<CombinedCollection> {\r\n    return this.mtApi.sync(engineId, collection).\r\n      pipe(tap((updatedCollection) => { collection.update(updatedCollection) }))\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        if (this.selected === collection) {\r\n          this.selected = null;\r\n        }\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"]}
316
+ //# 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":"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","sourcesContent":["import { Inject, Injectable } from '@angular/core';\r\nimport { forkJoin, Observable, of, Subject, tap } from 'rxjs';\r\nimport { MT_TERM_API_TOKEN } from '../../../injection-tokens';\r\nimport { TldAlertService, 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    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  private refreshMtCollections: boolean;\r\n  private refreshTermCollections: boolean;\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    private readonly alerts: TldAlertService,\r\n    @Inject(MT_TERM_API_TOKEN) private mtApi: IMtTermService) { }\r\n\r\n  dataUpdate() {\r\n    return this.onDataUpdate.asObservable();\r\n  }\r\n\r\n  setEngine(engineId: string, languages: string[] = null, setSelectedFromLocalStorage = false, termCollections = true, mtCollections = true): 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.refreshMtCollections !== mtCollections || this.refreshTermCollections !== termCollections) {\r\n      this.engineLanguages = languages;\r\n      this.refreshMtCollections = mtCollections;\r\n      this.refreshTermCollections = termCollections;\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);\r\n    }\r\n\r\n    return this.dataUpdate();\r\n  }\r\n\r\n  refreshCollections(setSelectedFromLocalStorage = 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\r\n    if (this.refreshTermCollections) {\r\n      observables.push(\r\n        this.termApi.getCollectionList()\r\n          .pipe(\r\n            tap((response) => termResponse = response)\r\n          )\r\n      )\r\n    }\r\n    if (this.refreshMtCollections) {\r\n      observables.push(\r\n        this.mtApi.getList(this.engineId)\r\n          .pipe(\r\n            tap((response) => mtApiResponse = response)\r\n          )\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);\r\n\r\n        const joined = [];\r\n        if (mtApiResponse) {\r\n          joined.push(...mtApiResponse);\r\n        }\r\n        if (termResponse) {\r\n          joined.push(...termResponse);\r\n        }\r\n\r\n        this.addCollections(joined);\r\n        if (setSelectedFromLocalStorage) {\r\n          this.setSelectedFromLocalStorage();\r\n        }\r\n        this._isRefreshingCollections = false;\r\n        this.scheduleRefresh(null);\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    this.updateIfNecessary(collection, true).subscribe(\r\n      {\r\n        error: (error) => {\r\n          this.alerts.unhandeledError(error);\r\n          this.selected = null;\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, isEdited = false): Observable<CombinedCollection> {\r\n    // collection is not imported and should be attached to engine\r\n    if (collection.isEdited() || isEdited) {\r\n      return this.mtApi.add(this.engineId, collection)\r\n        .pipe(\r\n          tap((updatedCollection) => {\r\n            collection.update(updatedCollection);\r\n          })\r\n        );\r\n    }\r\n    else {\r\n      return of(collection);\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, termCollections = true, mtCollections = true) {\r\n    this.hardAutoRefresh = true;\r\n    return this.setEngine(engineId ?? this.engineId, languages ?? this.engineLanguages, setSelectedFromLocalStorage, termCollections, mtCollections);\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  sync(collection: CombinedCollection, engineId = this.engineId): Observable<CombinedCollection> {\r\n    return this.mtApi.sync(engineId, collection).\r\n      pipe(tap((updatedCollection) => { collection.update(updatedCollection) }))\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   */\r\n  private addCollections(newCollections: Iterable<CombinedCollection>) {\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);\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[]) {\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        if (this.selected === collection) {\r\n          this.selected = null;\r\n        }\r\n      }\r\n      else {\r\n        if (termExistingIx !== null) {\r\n          const existing = termResponse[termExistingIx];\r\n          collection.update(existing);\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);\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"]}
@@ -5917,9 +5917,8 @@ class CombinedCollection {
5917
5917
  /**
5918
5918
  * Updates collection with values from new collection.
5919
5919
  * @param collection collection from which should be updated.
5920
- * @param initialRefresh if set to true, editable fields will also be updated.
5921
5920
  */
5922
- update(collection, initialRefresh = true) {
5921
+ update(collection) {
5923
5922
  var _a, _b, _c, _d;
5924
5923
  if (collection === null || collection === void 0 ? void 0 : collection.termCollection) {
5925
5924
  this.termCollection = collection.termCollection;
@@ -5934,9 +5933,7 @@ class CombinedCollection {
5934
5933
  else {
5935
5934
  this._isTermPortalCollection = (this.termCollection || this.mtCollection.termId) ? true : false;
5936
5935
  }
5937
- if (initialRefresh) {
5938
- this.updateEditables((_b = this.mtCollection) === null || _b === void 0 ? void 0 : _b.access);
5939
- }
5936
+ this.updateEditables((_b = this.mtCollection) === null || _b === void 0 ? void 0 : _b.access);
5940
5937
  this._isImporting = this.mtCollection && CombinedCollection.importingStatuses.includes((_c = this.mtCollection) === null || _c === void 0 ? void 0 : _c.status);
5941
5938
  this._default = (_d = (this.editables.userDefault || this.editables.groupDefault || this.editables.globalDefault)) !== null && _d !== void 0 ? _d : false;
5942
5939
  this.updateIsSynchronized();
@@ -5964,7 +5961,7 @@ class CombinedCollection {
5964
5961
  */
5965
5962
  deleteTerms() {
5966
5963
  this.termCollection = null;
5967
- this.update(null, false);
5964
+ this.update(null);
5968
5965
  }
5969
5966
  /**
5970
5967
  * Deletes mt collection and its properties.
@@ -6037,7 +6034,7 @@ class TermApiService {
6037
6034
  return this.convertToCombinedCollection(collection);
6038
6035
  }));
6039
6036
  }
6040
- getCollectionList(languages) {
6037
+ getCollectionList() {
6041
6038
  return this.http.get(this.url)
6042
6039
  .pipe(map((collections) => {
6043
6040
  const converted = [];
@@ -6129,11 +6126,11 @@ class TerminologyService {
6129
6126
  this._selected = null;
6130
6127
  }
6131
6128
  if (this.engineId) {
6132
- this.refreshCollections(setSelectedFromLocalStorage, true);
6129
+ this.refreshCollections(setSelectedFromLocalStorage);
6133
6130
  }
6134
6131
  return this.dataUpdate();
6135
6132
  }
6136
- refreshCollections(setSelectedFromLocalStorage = false, initialRefresh = false) {
6133
+ refreshCollections(setSelectedFromLocalStorage = false) {
6137
6134
  if (!this.engineId || !this.config.termConfig.isCollectionsActivated || this.isRefreshingCollections) {
6138
6135
  return;
6139
6136
  }
@@ -6144,7 +6141,7 @@ class TerminologyService {
6144
6141
  let mtApiResponse;
6145
6142
  const observables = [];
6146
6143
  if (this.refreshTermCollections) {
6147
- observables.push(this.termApi.getCollectionList(this.engineLanguages)
6144
+ observables.push(this.termApi.getCollectionList()
6148
6145
  .pipe(tap((response) => termResponse = response)));
6149
6146
  }
6150
6147
  if (this.refreshMtCollections) {
@@ -6156,7 +6153,7 @@ class TerminologyService {
6156
6153
  next: () => {
6157
6154
  this.isAnyImporting = false;
6158
6155
  // note that termResponse and mtapiresponse gets changed during remove method
6159
- this.removeDeleted(termResponse, mtApiResponse, initialRefresh);
6156
+ this.removeDeleted(termResponse, mtApiResponse);
6160
6157
  const joined = [];
6161
6158
  if (mtApiResponse) {
6162
6159
  joined.push(...mtApiResponse);
@@ -6164,7 +6161,7 @@ class TerminologyService {
6164
6161
  if (termResponse) {
6165
6162
  joined.push(...termResponse);
6166
6163
  }
6167
- this.addCollections(joined, initialRefresh);
6164
+ this.addCollections(joined);
6168
6165
  if (setSelectedFromLocalStorage) {
6169
6166
  this.setSelectedFromLocalStorage();
6170
6167
  }
@@ -6260,9 +6257,8 @@ class TerminologyService {
6260
6257
  /**
6261
6258
  *
6262
6259
  * @param newCollections
6263
- * @param initialRefresh Whether also editable collection fields should be updated. If not initial refresh, editable fields will not be updated.
6264
6260
  */
6265
- addCollections(newCollections, initialRefresh) {
6261
+ addCollections(newCollections) {
6266
6262
  var _a, _b;
6267
6263
  // sets collection list to this value at the end, so deleted collections are not in the list.
6268
6264
  for (let collection of newCollections) {
@@ -6292,7 +6288,7 @@ class TerminologyService {
6292
6288
  this._collections.add(collection);
6293
6289
  }
6294
6290
  else {
6295
- existing.update(collection, initialRefresh);
6291
+ existing.update(collection);
6296
6292
  }
6297
6293
  }
6298
6294
  // this._collections = updatedCollections;
@@ -6302,7 +6298,7 @@ class TerminologyService {
6302
6298
  /**
6303
6299
  * Should be called after refresh to check if there is any collections from api that are deleted.
6304
6300
  */
6305
- removeDeleted(termResponse, mtResponse, initialRefresh) {
6301
+ removeDeleted(termResponse, mtResponse) {
6306
6302
  for (const collection of this.collections) {
6307
6303
  const termExistingIx = CombinedCollection.findExistingIndexFromList(termResponse, collection);
6308
6304
  const mtExistingIx = CombinedCollection.findExistingIndexFromList(mtResponse, collection);
@@ -6315,7 +6311,7 @@ class TerminologyService {
6315
6311
  else {
6316
6312
  if (termExistingIx !== null) {
6317
6313
  const existing = termResponse[termExistingIx];
6318
- collection.update(existing, initialRefresh);
6314
+ collection.update(existing);
6319
6315
  termResponse.splice(termExistingIx, 1);
6320
6316
  }
6321
6317
  else {
@@ -6323,7 +6319,7 @@ class TerminologyService {
6323
6319
  }
6324
6320
  if (mtExistingIx !== null) {
6325
6321
  const existing = mtResponse[mtExistingIx];
6326
- collection.update(existing, initialRefresh);
6322
+ collection.update(existing);
6327
6323
  mtResponse.splice(mtExistingIx, 1);
6328
6324
  }
6329
6325
  else {
@@ -10677,6 +10673,8 @@ class MtTermV1Service {
10677
10673
  }));
10678
10674
  }
10679
10675
  remove(engineId, collection) {
10676
+ engineId;
10677
+ collection;
10680
10678
  throw new Error("not Implemented");
10681
10679
  }
10682
10680
  sync(engineId, collection) {