@tilde-nlp/ngx-translate 2.0.2 → 2.0.3-deepl
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.
- package/esm2020/lib/i18n/en.mjs +4 -2
- package/esm2020/lib/i18n/lv.mjs +4 -2
- package/esm2020/lib/modules/tld-common/components/tld-list-menu/tld-list-menu.component.mjs +4 -3
- package/esm2020/lib/modules/tld-common/index.mjs +1 -1
- package/esm2020/lib/modules/tld-common/models/configs/tld-translate-text-config.model.mjs +1 -1
- package/esm2020/lib/modules/tld-common/pipes/capitalize.pipe.mjs +16 -0
- package/esm2020/lib/modules/tld-common/pipes/index.mjs +2 -1
- package/esm2020/lib/modules/tld-common/services/tld-translate-config.service.mjs +2 -1
- package/esm2020/lib/modules/tld-common/tld-common.module.mjs +9 -4
- package/esm2020/lib/modules/tld-document/services/tld-translate-file.service.mjs +6 -2
- package/esm2020/lib/modules/tld-text/components/textarea-with-background/textarea-with-background.component.mjs +2 -2
- package/esm2020/lib/modules/tld-tooltip/tld-domain-list/tld-domain-list.component.mjs +6 -5
- package/esm2020/lib/modules/tld-tooltip/tld-translate-switcher/tld-translate-switcher.component.mjs +5 -4
- package/esm2020/lib/tld-translate.component.mjs +6 -2
- package/fesm2015/tilde-nlp-ngx-translate.mjs +148 -117
- package/fesm2015/tilde-nlp-ngx-translate.mjs.map +1 -1
- package/fesm2020/tilde-nlp-ngx-translate.mjs +119 -88
- package/fesm2020/tilde-nlp-ngx-translate.mjs.map +1 -1
- package/lib/i18n/en.d.ts +2 -0
- package/lib/i18n/lv.d.ts +2 -0
- package/lib/modules/tld-common/models/configs/tld-translate-text-config.model.d.ts +2 -0
- package/lib/modules/tld-common/pipes/capitalize.pipe.d.ts +7 -0
- package/lib/modules/tld-common/pipes/index.d.ts +1 -0
- package/lib/modules/tld-common/tld-common.module.d.ts +8 -7
- package/lib/modules/tld-tooltip/tld-domain-list/tld-domain-list.component.d.ts +1 -1
- package/lib/modules/tld-tooltip/tld-translate-switcher/tld-translate-switcher.component.d.ts +1 -1
- package/lib/tld-translate.component.d.ts +2 -1
- package/package.json +1 -1
- package/src/assets/webcomponent/tld-translate.js +1 -1
- package/tilde-nlp-ngx-translate-2.0.3-deepl.tgz +0 -0
- package/tilde-nlp-ngx-translate-2.0.2.tgz +0 -0
|
@@ -7,7 +7,8 @@ import * as i3 from "../../tld-common/pipes/translate-domain.pipe";
|
|
|
7
7
|
import * as i4 from "@angular/common";
|
|
8
8
|
import * as i5 from "@angular/flex-layout/extended";
|
|
9
9
|
import * as i6 from "../../tld-common/components/tld-list-menu/tld-list-menu.component";
|
|
10
|
-
import * as i7 from "
|
|
10
|
+
import * as i7 from "../../tld-common/pipes/capitalize.pipe";
|
|
11
|
+
import * as i8 from "@tilde-nlp/ngx-common";
|
|
11
12
|
export class TldDomainListComponent {
|
|
12
13
|
constructor(translate, config, translateDomainPipe) {
|
|
13
14
|
this.translate = translate;
|
|
@@ -16,6 +17,7 @@ export class TldDomainListComponent {
|
|
|
16
17
|
this.selectionChange = new EventEmitter();
|
|
17
18
|
this.titleKey = "title";
|
|
18
19
|
this.valueKey = "domain";
|
|
20
|
+
this.showTitle = this.config.coreConfig.showDomainTitle;
|
|
19
21
|
}
|
|
20
22
|
get list() { return this._list; }
|
|
21
23
|
set list(value) {
|
|
@@ -29,7 +31,6 @@ export class TldDomainListComponent {
|
|
|
29
31
|
this.selectedDomainName = this.translateDomainName(value?.title);
|
|
30
32
|
}
|
|
31
33
|
;
|
|
32
|
-
get showTitle() { return this.config.coreConfig.showDomainTitle; }
|
|
33
34
|
ngOnInit() {
|
|
34
35
|
this.translate.stream("DOMAINS").subscribe((translations) => {
|
|
35
36
|
this.translations = translations;
|
|
@@ -53,10 +54,10 @@ export class TldDomainListComponent {
|
|
|
53
54
|
}
|
|
54
55
|
}
|
|
55
56
|
TldDomainListComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TldDomainListComponent, deps: [{ token: i1.TranslateService }, { token: i2.TldTranslateConfigService }, { token: i3.TranslateDomainPipe }], target: i0.ɵɵFactoryTarget.Component });
|
|
56
|
-
TldDomainListComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: TldDomainListComponent, selector: "tld-domain-list", inputs: { list: "list", selected: "selected", disabled: "disabled" }, outputs: { selectionChange: "selectionChange" }, providers: [TranslateDomainPipe], ngImport: i0, template: "<span fxHide.lt-md class=\"domain-title\" *ngIf=\"showTitle\">{{'DOMAINS.TITLE' | translate}}</span>\r\n<tld-list-menu (selectionChange)=\"select($event)\" [list]=\"translatedList | sortTranslations: null: 'title': currentLanguage | async\" [titleKey]=\"titleKey\" \r\n[valueKey]=\"valueKey\" testId=\"tld-domain-list\" [disabled]=\"disabled\" [ariaLabel]=\"'DOMAINS.OPEN_LIST_ARIA_LABEL' | translate\">\r\n {{selectedDomainName |
|
|
57
|
+
TldDomainListComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: TldDomainListComponent, selector: "tld-domain-list", inputs: { list: "list", selected: "selected", disabled: "disabled" }, outputs: { selectionChange: "selectionChange" }, providers: [TranslateDomainPipe], ngImport: i0, template: "<span fxHide.lt-md class=\"domain-title\" *ngIf=\"showTitle\">{{'DOMAINS.TITLE' | translate}}</span>\r\n<tld-list-menu (selectionChange)=\"select($event)\" [list]=\"translatedList | sortTranslations: null: 'title': currentLanguage | async\" [titleKey]=\"titleKey\" \r\n[valueKey]=\"valueKey\" testId=\"tld-domain-list\" [disabled]=\"disabled\" [ariaLabel]=\"'DOMAINS.OPEN_LIST_ARIA_LABEL' | translate\">\r\n <span [ngClass.lt-sm]=\"'selected-domain'\">{{ selectedDomainName | capitalize }}</span> \r\n</tld-list-menu>", styles: [".selected-domain{max-width:60px;overflow:hidden;text-overflow:ellipsis}\n"], dependencies: [{ kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.DefaultShowHideDirective, selector: " [fxShow], [fxShow.print], [fxShow.xs], [fxShow.sm], [fxShow.md], [fxShow.lg], [fxShow.xl], [fxShow.lt-sm], [fxShow.lt-md], [fxShow.lt-lg], [fxShow.lt-xl], [fxShow.gt-xs], [fxShow.gt-sm], [fxShow.gt-md], [fxShow.gt-lg], [fxHide], [fxHide.print], [fxHide.xs], [fxHide.sm], [fxHide.md], [fxHide.lg], [fxHide.xl], [fxHide.lt-sm], [fxHide.lt-md], [fxHide.lt-lg], [fxHide.lt-xl], [fxHide.gt-xs], [fxHide.gt-sm], [fxHide.gt-md], [fxHide.gt-lg]", inputs: ["fxShow", "fxShow.print", "fxShow.xs", "fxShow.sm", "fxShow.md", "fxShow.lg", "fxShow.xl", "fxShow.lt-sm", "fxShow.lt-md", "fxShow.lt-lg", "fxShow.lt-xl", "fxShow.gt-xs", "fxShow.gt-sm", "fxShow.gt-md", "fxShow.gt-lg", "fxHide", "fxHide.print", "fxHide.xs", "fxHide.sm", "fxHide.md", "fxHide.lg", "fxHide.xl", "fxHide.lt-sm", "fxHide.lt-md", "fxHide.lt-lg", "fxHide.lt-xl", "fxHide.gt-xs", "fxHide.gt-sm", "fxHide.gt-md", "fxHide.gt-lg"] }, { kind: "directive", type: i5.DefaultClassDirective, selector: " [ngClass], [ngClass.xs], [ngClass.sm], [ngClass.md], [ngClass.lg], [ngClass.xl], [ngClass.lt-sm], [ngClass.lt-md], [ngClass.lt-lg], [ngClass.lt-xl], [ngClass.gt-xs], [ngClass.gt-sm], [ngClass.gt-md], [ngClass.gt-lg]", inputs: ["ngClass", "ngClass.xs", "ngClass.sm", "ngClass.md", "ngClass.lg", "ngClass.xl", "ngClass.lt-sm", "ngClass.lt-md", "ngClass.lt-lg", "ngClass.lt-xl", "ngClass.gt-xs", "ngClass.gt-sm", "ngClass.gt-md", "ngClass.gt-lg"] }, { kind: "component", type: i6.TldListMenuComponent, selector: "tld-list-menu", inputs: ["titleKey", "list", "showContent", "selectedValue", "disabled", "ariaLabel", "valueKey", "testId"], outputs: ["selectionChange"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }, { kind: "pipe", type: i7.CapitalizePipe, name: "capitalize" }, { kind: "pipe", type: i8.SortTranslationsPipe, name: "sortTranslations" }] });
|
|
57
58
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TldDomainListComponent, decorators: [{
|
|
58
59
|
type: Component,
|
|
59
|
-
args: [{ selector: 'tld-domain-list', providers: [TranslateDomainPipe], template: "<span fxHide.lt-md class=\"domain-title\" *ngIf=\"showTitle\">{{'DOMAINS.TITLE' | translate}}</span>\r\n<tld-list-menu (selectionChange)=\"select($event)\" [list]=\"translatedList | sortTranslations: null: 'title': currentLanguage | async\" [titleKey]=\"titleKey\" \r\n[valueKey]=\"valueKey\" testId=\"tld-domain-list\" [disabled]=\"disabled\" [ariaLabel]=\"'DOMAINS.OPEN_LIST_ARIA_LABEL' | translate\">\r\n {{selectedDomainName |
|
|
60
|
+
args: [{ selector: 'tld-domain-list', providers: [TranslateDomainPipe], template: "<span fxHide.lt-md class=\"domain-title\" *ngIf=\"showTitle\">{{'DOMAINS.TITLE' | translate}}</span>\r\n<tld-list-menu (selectionChange)=\"select($event)\" [list]=\"translatedList | sortTranslations: null: 'title': currentLanguage | async\" [titleKey]=\"titleKey\" \r\n[valueKey]=\"valueKey\" testId=\"tld-domain-list\" [disabled]=\"disabled\" [ariaLabel]=\"'DOMAINS.OPEN_LIST_ARIA_LABEL' | translate\">\r\n <span [ngClass.lt-sm]=\"'selected-domain'\">{{ selectedDomainName | capitalize }}</span> \r\n</tld-list-menu>", styles: [".selected-domain{max-width:60px;overflow:hidden;text-overflow:ellipsis}\n"] }]
|
|
60
61
|
}], ctorParameters: function () { return [{ type: i1.TranslateService }, { type: i2.TldTranslateConfigService }, { type: i3.TranslateDomainPipe }]; }, propDecorators: { list: [{
|
|
61
62
|
type: Input
|
|
62
63
|
}], selected: [{
|
|
@@ -66,4 +67,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
66
67
|
}], selectionChange: [{
|
|
67
68
|
type: Output
|
|
68
69
|
}] } });
|
|
69
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
70
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGxkLWRvbWFpbi1saXN0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3RsZC10cmFuc2xhdGUvc3JjL2xpYi9tb2R1bGVzL3RsZC10b29sdGlwL3RsZC1kb21haW4tbGlzdC90bGQtZG9tYWluLWxpc3QuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdGxkLXRyYW5zbGF0ZS9zcmMvbGliL21vZHVsZXMvdGxkLXRvb2x0aXAvdGxkLWRvbWFpbi1saXN0L3RsZC1kb21haW4tbGlzdC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQVUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRS9FLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLDhDQUE4QyxDQUFDOzs7Ozs7Ozs7O0FBVW5GLE1BQU0sT0FBTyxzQkFBc0I7SUE4QmpDLFlBQ21CLFNBQTJCLEVBQzNCLE1BQWlDLEVBQ2pDLG1CQUF3QztRQUZ4QyxjQUFTLEdBQVQsU0FBUyxDQUFrQjtRQUMzQixXQUFNLEdBQU4sTUFBTSxDQUEyQjtRQUNqQyx3QkFBbUIsR0FBbkIsbUJBQW1CLENBQXFCO1FBZmpELG9CQUFlLEdBQXNCLElBQUksWUFBWSxFQUFFLENBQUM7UUFTekQsYUFBUSxHQUFXLE9BQU8sQ0FBQztRQUMzQixhQUFRLEdBQUcsUUFBUSxDQUFDO1FBTzNCLElBQUksQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxVQUFVLENBQUMsZUFBZSxDQUFDO0lBQzFELENBQUM7SUFqQ0QsSUFBSSxJQUFJLEtBQUssT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQztJQUNqQyxJQUFhLElBQUksQ0FBQyxLQUFnQjtRQUNoQyxJQUFJLENBQUMsS0FBSyxHQUFHLEtBQUssQ0FBQztRQUNuQixJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7SUFDckIsQ0FBQztJQUFBLENBQUM7SUFHRixJQUFJLFFBQVEsS0FBSyxPQUFPLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDO0lBQ3pDLElBQWEsUUFBUSxDQUFDLEtBQWM7UUFDbEMsSUFBSSxDQUFDLFNBQVMsR0FBRyxLQUFLLENBQUM7UUFDdkIsSUFBSSxDQUFDLGtCQUFrQixHQUFHLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxLQUFLLEVBQUUsS0FBSyxDQUFDLENBQUM7SUFDbkUsQ0FBQztJQUFBLENBQUM7SUF3QkYsUUFBUTtRQUNOLElBQUksQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDLFNBQVMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxDQUFDLFlBQVksRUFBRSxFQUFFO1lBQzFELElBQUksQ0FBQyxZQUFZLEdBQUcsWUFBWSxDQUFDO1lBQ2pDLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQztZQUNuQixJQUFJLENBQUMsZUFBZSxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsV0FBVyxDQUFDO1FBQ3BELENBQUMsQ0FBQyxDQUFBO0lBQ0osQ0FBQztJQUVELE1BQU0sQ0FBQyxPQUFZO1FBQ2pCLElBQUksQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQ3JDLENBQUM7SUFFTyxXQUFXO1FBQ2pCLElBQUksQ0FBQyxrQkFBa0IsR0FBRyxJQUFJLENBQUMsbUJBQW1CLENBQUMsSUFBSSxDQUFDLFFBQVEsRUFBRSxLQUFLLENBQUMsQ0FBQztRQUV6RSxNQUFNLGNBQWMsR0FBYyxFQUFFLENBQUM7UUFDckMsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQyxNQUFNLEVBQUUsRUFBRTtZQUMzQixjQUFjLENBQUMsSUFBSSxDQUFDLEVBQUUsS0FBSyxFQUFFLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLEVBQUUsTUFBTSxFQUFFLE1BQU0sQ0FBQyxNQUFNLEVBQUUsQ0FBQyxDQUFBO1FBQy9GLENBQUMsQ0FBQyxDQUFBO1FBQ0YsSUFBSSxDQUFDLGNBQWMsR0FBRyxjQUFjLENBQUM7SUFDdkMsQ0FBQztJQUVPLG1CQUFtQixDQUFDLFVBQWtCO1FBQzVDLE9BQU8sSUFBSSxDQUFDLG1CQUFtQixDQUFDLFNBQVMsQ0FBQyxVQUFVLENBQUMsQ0FBQztJQUN4RCxDQUFDOzttSEE5RFUsc0JBQXNCO3VHQUF0QixzQkFBc0IsaUtBRnRCLENBQUMsbUJBQW1CLENBQUMsMEJDVmxDLDZnQkFJZ0I7MkZEUUgsc0JBQXNCO2tCQU5sQyxTQUFTOytCQUNFLGlCQUFpQixhQUdoQixDQUFDLG1CQUFtQixDQUFDO2lMQU1uQixJQUFJO3NCQUFoQixLQUFLO2dCQU9PLFFBQVE7c0JBQXBCLEtBQUs7Z0JBS0csUUFBUTtzQkFBaEIsS0FBSztnQkFFSSxlQUFlO3NCQUF4QixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPbkluaXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBUcmFuc2xhdGVTZXJ2aWNlIH0gZnJvbSAnQG5neC10cmFuc2xhdGUvY29yZSc7XHJcbmltcG9ydCB7IFRyYW5zbGF0ZURvbWFpblBpcGUgfSBmcm9tICcuLi8uLi90bGQtY29tbW9uL3BpcGVzL3RyYW5zbGF0ZS1kb21haW4ucGlwZSc7XHJcbmltcG9ydCB7IFRsZFRyYW5zbGF0ZUNvbmZpZ1NlcnZpY2UgfSBmcm9tICcuLi8uLi90bGQtY29tbW9uL3NlcnZpY2VzL3RsZC10cmFuc2xhdGUtY29uZmlnLnNlcnZpY2UnO1xyXG5pbXBvcnQgeyBJRG9tYWluIH0gZnJvbSAnLi4vbW9kZWxzL2RvbWFpbi5tb2RlbCc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ3RsZC1kb21haW4tbGlzdCcsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL3RsZC1kb21haW4tbGlzdC5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vdGxkLWRvbWFpbi1saXN0LmNvbXBvbmVudC5zY3NzJ10sXHJcbiAgcHJvdmlkZXJzOiBbVHJhbnNsYXRlRG9tYWluUGlwZV1cclxufSlcclxuZXhwb3J0IGNsYXNzIFRsZERvbWFpbkxpc3RDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xyXG5cclxuICBwcml2YXRlIF9saXN0OiBJRG9tYWluW107XHJcbiAgZ2V0IGxpc3QoKSB7IHJldHVybiB0aGlzLl9saXN0OyB9XHJcbiAgQElucHV0KCkgc2V0IGxpc3QodmFsdWU6IElEb21haW5bXSkge1xyXG4gICAgdGhpcy5fbGlzdCA9IHZhbHVlO1xyXG4gICAgdGhpcy5yZXRyYW5zbGF0ZSgpO1xyXG4gIH07XHJcblxyXG4gIHByaXZhdGUgX3NlbGVjdGVkOiBJRG9tYWluO1xyXG4gIGdldCBzZWxlY3RlZCgpIHsgcmV0dXJuIHRoaXMuX3NlbGVjdGVkOyB9XHJcbiAgQElucHV0KCkgc2V0IHNlbGVjdGVkKHZhbHVlOiBJRG9tYWluKSB7XHJcbiAgICB0aGlzLl9zZWxlY3RlZCA9IHZhbHVlO1xyXG4gICAgdGhpcy5zZWxlY3RlZERvbWFpbk5hbWUgPSB0aGlzLnRyYW5zbGF0ZURvbWFpbk5hbWUodmFsdWU/LnRpdGxlKTtcclxuICB9O1xyXG5cclxuICBASW5wdXQoKSBkaXNhYmxlZDogYm9vbGVhbjtcclxuXHJcbiAgQE91dHB1dCgpIHNlbGVjdGlvbkNoYW5nZTogRXZlbnRFbWl0dGVyPGFueT4gPSBuZXcgRXZlbnRFbWl0dGVyKCk7XHJcblxyXG4gIHRyYW5zbGF0aW9uczogYW55O1xyXG4gIHRyYW5zbGF0ZWRMaXN0OiBJRG9tYWluW107XHJcbiAgc2VsZWN0ZWREb21haW5OYW1lOiBzdHJpbmc7XHJcbiAgY3VycmVudExhbmd1YWdlOiBzdHJpbmc7XHJcblxyXG4gIHNob3dUaXRsZTogYm9vbGVhbjtcclxuXHJcbiAgcmVhZG9ubHkgdGl0bGVLZXk6IHN0cmluZyA9IFwidGl0bGVcIjtcclxuICByZWFkb25seSB2YWx1ZUtleSA9IFwiZG9tYWluXCI7XHJcblxyXG4gIGNvbnN0cnVjdG9yIChcclxuICAgIHByaXZhdGUgcmVhZG9ubHkgdHJhbnNsYXRlOiBUcmFuc2xhdGVTZXJ2aWNlLFxyXG4gICAgcHJpdmF0ZSByZWFkb25seSBjb25maWc6IFRsZFRyYW5zbGF0ZUNvbmZpZ1NlcnZpY2UsXHJcbiAgICBwcml2YXRlIHJlYWRvbmx5IHRyYW5zbGF0ZURvbWFpblBpcGU6IFRyYW5zbGF0ZURvbWFpblBpcGVcclxuICApIHtcclxuICAgIHRoaXMuc2hvd1RpdGxlID0gdGhpcy5jb25maWcuY29yZUNvbmZpZy5zaG93RG9tYWluVGl0bGU7XHJcbiAgfVxyXG5cclxuICBuZ09uSW5pdCgpIHtcclxuICAgIHRoaXMudHJhbnNsYXRlLnN0cmVhbShcIkRPTUFJTlNcIikuc3Vic2NyaWJlKCh0cmFuc2xhdGlvbnMpID0+IHtcclxuICAgICAgdGhpcy50cmFuc2xhdGlvbnMgPSB0cmFuc2xhdGlvbnM7XHJcbiAgICAgIHRoaXMucmV0cmFuc2xhdGUoKTtcclxuICAgICAgdGhpcy5jdXJyZW50TGFuZ3VhZ2UgPSB0aGlzLnRyYW5zbGF0ZS5jdXJyZW50TGFuZztcclxuICAgIH0pXHJcbiAgfVxyXG5cclxuICBzZWxlY3QoZWxlbWVudDogYW55KSB7XHJcbiAgICB0aGlzLnNlbGVjdGlvbkNoYW5nZS5uZXh0KGVsZW1lbnQpO1xyXG4gIH1cclxuXHJcbiAgcHJpdmF0ZSByZXRyYW5zbGF0ZSgpIHtcclxuICAgIHRoaXMuc2VsZWN0ZWREb21haW5OYW1lID0gdGhpcy50cmFuc2xhdGVEb21haW5OYW1lKHRoaXMuc2VsZWN0ZWQ/LnRpdGxlKTtcclxuXHJcbiAgICBjb25zdCB0cmFuc2xhdGVkTGlzdDogSURvbWFpbltdID0gW107XHJcbiAgICB0aGlzLmxpc3QuZm9yRWFjaCgoZG9tYWluKSA9PiB7XHJcbiAgICAgIHRyYW5zbGF0ZWRMaXN0LnB1c2goeyB0aXRsZTogdGhpcy50cmFuc2xhdGVEb21haW5OYW1lKGRvbWFpbi50aXRsZSksIGRvbWFpbjogZG9tYWluLmRvbWFpbiB9KVxyXG4gICAgfSlcclxuICAgIHRoaXMudHJhbnNsYXRlZExpc3QgPSB0cmFuc2xhdGVkTGlzdDtcclxuICB9XHJcblxyXG4gIHByaXZhdGUgdHJhbnNsYXRlRG9tYWluTmFtZShkb21haW5OYW1lOiBzdHJpbmcpOiBzdHJpbmcge1xyXG4gICAgcmV0dXJuIHRoaXMudHJhbnNsYXRlRG9tYWluUGlwZS50cmFuc2Zvcm0oZG9tYWluTmFtZSk7XHJcbiAgfVxyXG5cclxufVxyXG4iLCI8c3BhbiBmeEhpZGUubHQtbWQgY2xhc3M9XCJkb21haW4tdGl0bGVcIiAqbmdJZj1cInNob3dUaXRsZVwiPnt7J0RPTUFJTlMuVElUTEUnIHwgdHJhbnNsYXRlfX08L3NwYW4+XHJcbjx0bGQtbGlzdC1tZW51IChzZWxlY3Rpb25DaGFuZ2UpPVwic2VsZWN0KCRldmVudClcIiBbbGlzdF09XCJ0cmFuc2xhdGVkTGlzdCB8IHNvcnRUcmFuc2xhdGlvbnM6IG51bGw6ICd0aXRsZSc6IGN1cnJlbnRMYW5ndWFnZSB8IGFzeW5jXCIgW3RpdGxlS2V5XT1cInRpdGxlS2V5XCIgXHJcblt2YWx1ZUtleV09XCJ2YWx1ZUtleVwiIHRlc3RJZD1cInRsZC1kb21haW4tbGlzdFwiIFtkaXNhYmxlZF09XCJkaXNhYmxlZFwiIFthcmlhTGFiZWxdPVwiJ0RPTUFJTlMuT1BFTl9MSVNUX0FSSUFfTEFCRUwnIHwgdHJhbnNsYXRlXCI+XHJcbiAgICA8c3BhbiBbbmdDbGFzcy5sdC1zbV09XCInc2VsZWN0ZWQtZG9tYWluJ1wiPnt7IHNlbGVjdGVkRG9tYWluTmFtZSB8IGNhcGl0YWxpemUgfX08L3NwYW4+ICAgIFxyXG48L3RsZC1saXN0LW1lbnU+Il19
|
package/esm2020/lib/modules/tld-tooltip/tld-translate-switcher/tld-translate-switcher.component.mjs
CHANGED
|
@@ -66,10 +66,11 @@ export class TldTranslateSwitcherComponent {
|
|
|
66
66
|
return this.config?.coreConfig.showVendors && this.settings.vendors?.length > 0;
|
|
67
67
|
}
|
|
68
68
|
get showDomains() {
|
|
69
|
-
|
|
69
|
+
const singleDomainAvailable = this.config?.textConfig.displaySingleAvailableDomain && this.settings?.domains?.domains?.length >= 1;
|
|
70
|
+
return (this.config?.coreConfig.showDomains &&
|
|
70
71
|
!this.showDomainsWithLanguageName &&
|
|
71
|
-
this.settings?.domains?.domains?.length > 1 &&
|
|
72
|
-
|
|
72
|
+
((this.settings?.domains?.domains?.length > 1 && this.settings?.source) ||
|
|
73
|
+
singleDomainAvailable));
|
|
73
74
|
}
|
|
74
75
|
get isSwapLanguagesDisabled() {
|
|
75
76
|
return this.disabled || !this.settings.swapActive;
|
|
@@ -185,4 +186,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
185
186
|
}], onVendorChange: [{
|
|
186
187
|
type: Output
|
|
187
188
|
}] } });
|
|
188
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tld-translate-switcher.component.js","sourceRoot":"","sources":["../../../../../../../projects/tld-translate/src/lib/modules/tld-tooltip/tld-translate-switcher/tld-translate-switcher.component.ts","../../../../../../../projects/tld-translate/src/lib/modules/tld-tooltip/tld-translate-switcher/tld-translate-switcher.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, ElementRef, EventEmitter, HostListener, Input, OnDestroy, OnInit, Output, ViewChild } from '@angular/core';\r\nimport { Subject } from 'rxjs';\r\nimport { takeUntil } from 'rxjs/operators';\r\nimport { TldTranslateConfigService } from '../../tld-common/services';\r\nimport { ISwitcherTranslationOptions } from '../models/switcher-options.model';\r\nimport { TldSystemService } from '../services/tld-system.service';\r\n\r\n@Component({\r\n  selector: 'tld-translate-switcher',\r\n  templateUrl: './tld-translate-switcher.component.html',\r\n  styleUrls: ['./tld-translate-switcher.component.scss']\r\n})\r\nexport class TldTranslateSwitcherComponent implements OnInit, AfterViewInit, OnDestroy {\r\n\r\n  @ViewChild(\"wrapper\") wrapper: ElementRef;\r\n  @ViewChild(\"fromLabel\") fromLabel: ElementRef;\r\n  @ViewChild(\"sourceAside\") sourceAside: ElementRef;\r\n  @ViewChild(\"toLabel\") toLabel: ElementRef;\r\n  @ViewChild(\"domainWrapper\") domainWrapper: ElementRef;\r\n  @ViewChild(\"vendorWrapper\") vendorWrapper: ElementRef;\r\n  @ViewChild(\"collectionWrapper\") collectionWrapper: ElementRef;\r\n\r\n  @HostListener('window:resize')\r\n  onResize() {\r\n    const pxPerLanguage = 110;\r\n    const componentWidth = this.getElementRefWidth(this.wrapper);\r\n    const parentWidth = this.elRef?.nativeElement?.parentElement.offsetWidth || 0;\r\n    const wrapperWidth = this.useParentWidth ? parentWidth : componentWidth;\r\n    const fromWidth = this.getElementRefWidth(this.fromLabel);\r\n    const sourceAsideWidth = this.getElementRefWidth(this.sourceAside);\r\n    const toWidth = this.getElementRefWidth(this.toLabel);\r\n    const domainsWidth = this.getElementRefWidth(this.domainWrapper);\r\n    const vendorsWidth = this.getElementRefWidth(this.vendorWrapper);\r\n    const collectionsWidth = this.getElementRefWidth(this.collectionWrapper);\r\n    // additional px to distract because swap lang button and dropdown icons.\r\n    const extra = 100;\r\n    const freeWidth = wrapperWidth - fromWidth - sourceAsideWidth - toWidth - domainsWidth - vendorsWidth - collectionsWidth - extra;\r\n    const languageCount = Math.floor(freeWidth / 2 / pxPerLanguage);\r\n    this.languageCountByScreenSize = languageCount > 0 ? languageCount : 1;\r\n  }\r\n\r\n  @Input() buttonDisabled = false;\r\n  @Input() showTranslateButton = true;\r\n  @Input() hideOnSmallScreens = true;\r\n  @Input() disabled: boolean;\r\n  @Input() hideLangMenuLabels = false;\r\n  @Input() maxDisplayedLanguages: number;\r\n  @Input() collections: any[];\r\n  @Input() showDomainsWithLanguageName: boolean;\r\n  @Input() isCollectionsActivated: boolean;\r\n  /** If this is set to true, component parent is checked for displayed language count. */\r\n  @Input() useParentWidth: boolean;\r\n  /** Show loader instead of translate button */\r\n  @Input() loader: boolean;\r\n\r\n  @Input() settings: ISwitcherTranslationOptions;\r\n\r\n  @Output() onDomainChange: EventEmitter<string> = new EventEmitter();\r\n  @Output() onActionClick: EventEmitter<any> = new EventEmitter();\r\n  @Output() onSourceLanguageChange: EventEmitter<any> = new EventEmitter();\r\n  @Output() onTargetLanguageChange: EventEmitter<any> = new EventEmitter();\r\n  @Output() onLanguageSwap: EventEmitter<string> = new EventEmitter();\r\n  @Output() onVendorChange: EventEmitter<string> = new EventEmitter();\r\n\r\n  languageCountByScreenSize: number;\r\n\r\n  get visibleLanguageCount() {\r\n    if (this.languageCountByScreenSize && this.languageCountByScreenSize < this.maxDisplayedLanguages) {\r\n      return this.languageCountByScreenSize;\r\n    }\r\n    return this.maxDisplayedLanguages;\r\n  }\r\n\r\n  get collectionsVisible() {\r\n    return this.isCollectionsActivated\r\n      && this.isTerminologySupported\r\n  }\r\n\r\n  get showVendors() {\r\n    return this.config?.coreConfig.showVendors && this.settings.vendors?.length > 0;\r\n  }\r\n\r\n  get showDomains() {\r\n    return this.config?.coreConfig.showDomains &&\r\n      !this.showDomainsWithLanguageName &&\r\n      this.settings?.domains?.domains?.length > 1 &&\r\n      this.settings?.source;\r\n  }\r\n\r\n  get isSwapLanguagesDisabled() {\r\n    return this.disabled || !this.settings.swapActive;\r\n  }\r\n\r\n  get domainSide() { return this.config.coreConfig.domainSide; }\r\n  get swapIconPosition() { return this.config.coreConfig.swapIconPosition; }\r\n\r\n  private readonly destroy$ = new Subject();\r\n\r\n  readonly srcLangTestId = \"src-lang-menu\";\r\n  readonly trgLangTestId = \"trg-lang-menu\";\r\n\r\n  private isTerminologySupported: boolean;\r\n\r\n  constructor(\r\n    private readonly config: TldTranslateConfigService,\r\n    private readonly tldSystem: TldSystemService,\r\n    private elRef: ElementRef) {\r\n  }\r\n\r\n\r\n  ngOnInit() {\r\n    this.subscribeToActiveData();\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.onResize();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.destroy$.next(null)\r\n    this.destroy$.complete();\r\n  }\r\n\r\n  actionClick() {\r\n    this.onActionClick.emit();\r\n  }\r\n\r\n  domainChange(systemId: string) {\r\n    this.onDomainChange.emit(systemId);\r\n  }\r\n\r\n  sourceLangChange(language: string) {\r\n    this.onSourceLanguageChange.emit(language);\r\n  }\r\n\r\n  swapSourceAndTarget() {\r\n    this.onLanguageSwap.emit();\r\n  }\r\n\r\n  targetLangChange(language: string) {\r\n    this.onTargetLanguageChange.emit(language);\r\n  }\r\n\r\n  vendorChange(systemId: string) {\r\n    this.onVendorChange.emit(systemId);\r\n  }\r\n\r\n  private getElementRefWidth(element: ElementRef) {\r\n    return element?.nativeElement.offsetWidth || 0;\r\n  }\r\n\r\n  private subscribeToActiveData(){\r\n    this.tldSystem.getActiveData()\r\n    .pipe(takeUntil(this.destroy$))\r\n    .subscribe((active) => {\r\n      if (!active) {\r\n        this.isTerminologySupported = false;\r\n        return;\r\n      }\r\n\r\n      this.isTerminologySupported = this.tldSystem.isTerminologySupported(active.system);\r\n    });\r\n  }\r\n}\r\n","<div fxLayout=\"row\" fxLayoutAlign=\"center center\" class=\"tld-translate-switcher-container\" #wrapper\r\n  [ngClass.lt-md]=\"'tld-translate-switcher-container-tablet'\"\r\n  [ngClass.lt-sm]=\"'tld-translate-switcher-container-mobile'\"\r\n  [class.tld-switcher-with-collections]='collectionsVisible'>\r\n\r\n  <div fxFlex fxLayout=\"row\" fxLayoutAlign=\"start center\">\r\n    <div fxHide.lt-md *ngIf=\"!hideLangMenuLabels\" #fromLabel>{{'TLD_TRANSLATE.FROM' | translate}}</div>\r\n    <div fxFlex fxLayout=\"row\" fxLayoutAlign=\"start center\">\r\n      <tld-lang-list id=\"tld-source-language-list\" [disabled]=\"disabled\" [testId]=\"srcLangTestId\"\r\n        [languages]=\"settings.sourceLanguageList\" (onLanguageChange)=\"sourceLangChange($event)\"\r\n        [selected]=\"settings.source\" [maxDisplayedLanguages]=\"visibleLanguageCount\"></tld-lang-list>\r\n      <ng-container *ngIf=\"domainSide==='src'\">\r\n        <ng-container *ngTemplateOutlet=\"domainTemplate;\">\r\n        </ng-container>\r\n      </ng-container>\r\n    </div>\r\n    <div #sourceAside *ngIf=\"swapIconPosition==='src'\">\r\n      <ng-container *ngTemplateOutlet=\"swapButtonTemplate;\"></ng-container>\r\n    </div>\r\n  </div>\r\n  <div *ngIf=\"swapIconPosition==='center'\">\r\n    <ng-container *ngTemplateOutlet=\"swapButtonTemplate;\"></ng-container>\r\n  </div>\r\n  <div fxFlex fxLayout=\"row\" fxLayoutAlign=\"start center\" fxLayoutAlign.lt-sm=\"end center\">\r\n    <div fxHide.lt-md *ngIf=\"!hideLangMenuLabels\" #toLabel>{{'TLD_TRANSLATE.TO' | translate}}</div>\r\n    <div fxFlex fxLayout=\"row\" fxLayoutAlign=\"start center\">\r\n      <tld-lang-list [disabled]=\"disabled\" id=\"tld-target-language-list\" [languages]=\"settings.targetLanguageList\"\r\n        (onLanguageChange)=\"targetLangChange($event)\" [selected]=\"settings.target\"\r\n        [maxDisplayedLanguages]=\"visibleLanguageCount\" [testId]=\"trgLangTestId\" (onDomainChange)=\"domainChange($event)\"\r\n        [showDomainsWithLanguageName]=\"showDomainsWithLanguageName\">\r\n        <ng-container *ngIf=\"domainSide==='trg'\">\r\n          <ng-container *ngTemplateOutlet=\"domainTemplate;\">\r\n          </ng-container>\r\n        </ng-container>\r\n        <div class=\"tld-translate-vendor-selection\" fxLayoutAlign=\"center center\" *ngIf=\"showVendors\" #vendorWrapper>\r\n          <tld-list-menu (selectionChange)=\"domainChange($event)\" [list]=\"settings.vendors\" [titleKey]=\"'title'\"\r\n            [valueKey]=\"'systemId'\" testId=\"tld-vendor-list\" [disabled]=\"disabled\" [showContent]=\"false\"\r\n            [ariaLabel]=\"'TLD_TRANSLATE.VENDORS_ARIA_LABEL' | translate\" [selectedValue]=\"settings.systemId\">\r\n          </tld-list-menu>\r\n        </div>\r\n      </tld-lang-list>\r\n    </div>\r\n    <div fxLayout=\"row\" fxLayoutGap.gt-xs=\"16px\">\r\n      <div *ngIf=\"collectionsVisible\" #collectionWrapper>\r\n        <tld-term-menu></tld-term-menu>\r\n      </div>\r\n      <tld-loader *ngIf=\"loader\" fxHide.lt-sm></tld-loader>\r\n      <tld-translate-button [enablePulseAnimation]=\"true\" *ngIf=\"showTranslateButton && !loader\" class=\"switcher-translate-button\"\r\n        [fxHide.lt-sm]=\"hideOnSmallScreens\" [disabled]=\"buttonDisabled\"></tld-translate-button>\r\n    </div>\r\n  </div>\r\n</div>\r\n\r\n<ng-template #swapButtonTemplate>\r\n  <button [disabled]=\"isSwapLanguagesDisabled\" class=\"swap-languages-button\" mat-icon-button\r\n    (click)=\"swapSourceAndTarget()\" aria-label=\"swap languages\" color=\"primary\"\r\n    matTooltip=\"{{'TOOLTIPS.SWAP_LANGUAGES' | translate}}\">\r\n    <span class=\"material-icons\" aria-hidden=\"false\"\r\n      [attr.aria-label]=\"'ARIA_LABELS.SWAP_LANGUAGES' | translate\">swap_horiz</span>\r\n  </button>\r\n</ng-template>\r\n\r\n<ng-template #domainTemplate>\r\n  <div class=\"tld-translate-domain-selection\" fxLayoutAlign=\"center center\" *ngIf=\"showDomains\" #domainWrapper>\r\n    <tld-domain-list fxLayoutAlign=\"center center\" (selectionChange)=\"domainChange($event)\"\r\n      [list]=\"settings.domains.domains\" [selected]=\"settings.domains.active\" [selected]=\"settings.domains.active\"\r\n      [disabled]=\"disabled\"></tld-domain-list>\r\n  </div>\r\n</ng-template>\r\n"]}
|
|
189
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tld-translate-switcher.component.js","sourceRoot":"","sources":["../../../../../../../projects/tld-translate/src/lib/modules/tld-tooltip/tld-translate-switcher/tld-translate-switcher.component.ts","../../../../../../../projects/tld-translate/src/lib/modules/tld-tooltip/tld-translate-switcher/tld-translate-switcher.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, ElementRef, EventEmitter, HostListener, Input, OnDestroy, OnInit, Output, ViewChild } from '@angular/core';\r\nimport { Subject } from 'rxjs';\r\nimport { takeUntil } from 'rxjs/operators';\r\nimport { TldTranslateConfigService } from '../../tld-common/services';\r\nimport { ISwitcherTranslationOptions } from '../models/switcher-options.model';\r\nimport { TldSystemService } from '../services/tld-system.service';\r\n\r\n@Component({\r\n  selector: 'tld-translate-switcher',\r\n  templateUrl: './tld-translate-switcher.component.html',\r\n  styleUrls: ['./tld-translate-switcher.component.scss']\r\n})\r\nexport class TldTranslateSwitcherComponent implements OnInit, AfterViewInit, OnDestroy {\r\n\r\n  @ViewChild(\"wrapper\") wrapper: ElementRef;\r\n  @ViewChild(\"fromLabel\") fromLabel: ElementRef;\r\n  @ViewChild(\"sourceAside\") sourceAside: ElementRef;\r\n  @ViewChild(\"toLabel\") toLabel: ElementRef;\r\n  @ViewChild(\"domainWrapper\") domainWrapper: ElementRef;\r\n  @ViewChild(\"vendorWrapper\") vendorWrapper: ElementRef;\r\n  @ViewChild(\"collectionWrapper\") collectionWrapper: ElementRef;\r\n\r\n  @HostListener('window:resize')\r\n  onResize() {\r\n    const pxPerLanguage = 110;\r\n    const componentWidth = this.getElementRefWidth(this.wrapper);\r\n    const parentWidth = this.elRef?.nativeElement?.parentElement.offsetWidth || 0;\r\n    const wrapperWidth = this.useParentWidth ? parentWidth : componentWidth;\r\n    const fromWidth = this.getElementRefWidth(this.fromLabel);\r\n    const sourceAsideWidth = this.getElementRefWidth(this.sourceAside);\r\n    const toWidth = this.getElementRefWidth(this.toLabel);\r\n    const domainsWidth = this.getElementRefWidth(this.domainWrapper);\r\n    const vendorsWidth = this.getElementRefWidth(this.vendorWrapper);\r\n    const collectionsWidth = this.getElementRefWidth(this.collectionWrapper);\r\n    // additional px to distract because swap lang button and dropdown icons.\r\n    const extra = 100;\r\n    const freeWidth = wrapperWidth - fromWidth - sourceAsideWidth - toWidth - domainsWidth - vendorsWidth - collectionsWidth - extra;\r\n    const languageCount = Math.floor(freeWidth / 2 / pxPerLanguage);\r\n    this.languageCountByScreenSize = languageCount > 0 ? languageCount : 1;\r\n  }\r\n\r\n  @Input() buttonDisabled = false;\r\n  @Input() showTranslateButton = true;\r\n  @Input() hideOnSmallScreens = true;\r\n  @Input() disabled: boolean;\r\n  @Input() hideLangMenuLabels = false;\r\n  @Input() maxDisplayedLanguages: number;\r\n  @Input() collections: any[];\r\n  @Input() showDomainsWithLanguageName: boolean;\r\n  @Input() isCollectionsActivated: boolean;\r\n  /** If this is set to true, component parent is checked for displayed language count. */\r\n  @Input() useParentWidth: boolean;\r\n  /** Show loader instead of translate button */\r\n  @Input() loader: boolean;\r\n\r\n  @Input() settings: ISwitcherTranslationOptions;\r\n\r\n  @Output() onDomainChange: EventEmitter<string> = new EventEmitter();\r\n  @Output() onActionClick: EventEmitter<any> = new EventEmitter();\r\n  @Output() onSourceLanguageChange: EventEmitter<any> = new EventEmitter();\r\n  @Output() onTargetLanguageChange: EventEmitter<any> = new EventEmitter();\r\n  @Output() onLanguageSwap: EventEmitter<string> = new EventEmitter();\r\n  @Output() onVendorChange: EventEmitter<string> = new EventEmitter();\r\n\r\n  languageCountByScreenSize: number;\r\n\r\n  get visibleLanguageCount() {\r\n    if (this.languageCountByScreenSize && this.languageCountByScreenSize < this.maxDisplayedLanguages) {\r\n      return this.languageCountByScreenSize;\r\n    }\r\n    return this.maxDisplayedLanguages;\r\n  }\r\n\r\n  get collectionsVisible() {\r\n    return this.isCollectionsActivated\r\n      && this.isTerminologySupported\r\n  }\r\n\r\n  get showVendors() {\r\n    return this.config?.coreConfig.showVendors && this.settings.vendors?.length > 0;\r\n  }\r\n\r\n  get showDomains() {\r\n    const singleDomainAvailable = this.config?.textConfig.displaySingleAvailableDomain && this.settings?.domains?.domains?.length >= 1;\r\n  \r\n    return (\r\n      this.config?.coreConfig.showDomains &&\r\n      !this.showDomainsWithLanguageName &&\r\n      (\r\n        (this.settings?.domains?.domains?.length > 1 && this.settings?.source) ||\r\n        singleDomainAvailable\r\n      )\r\n    );\r\n  }\r\n\r\n  get isSwapLanguagesDisabled() {\r\n    return this.disabled || !this.settings.swapActive;\r\n  }\r\n\r\n  get domainSide() { return this.config.coreConfig.domainSide; }\r\n  get swapIconPosition() { return this.config.coreConfig.swapIconPosition; }\r\n\r\n  private readonly destroy$ = new Subject();\r\n\r\n  readonly srcLangTestId = \"src-lang-menu\";\r\n  readonly trgLangTestId = \"trg-lang-menu\";\r\n\r\n  private isTerminologySupported: boolean;\r\n\r\n  constructor(\r\n    private readonly config: TldTranslateConfigService,\r\n    private readonly tldSystem: TldSystemService,\r\n    private elRef: ElementRef) {\r\n  }\r\n\r\n\r\n  ngOnInit() {\r\n    this.subscribeToActiveData();\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.onResize();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.destroy$.next(null)\r\n    this.destroy$.complete();\r\n  }\r\n\r\n  actionClick() {\r\n    this.onActionClick.emit();\r\n  }\r\n\r\n  domainChange(systemId: string) {\r\n    this.onDomainChange.emit(systemId);\r\n  }\r\n\r\n  sourceLangChange(language: string) {\r\n    this.onSourceLanguageChange.emit(language);\r\n  }\r\n\r\n  swapSourceAndTarget() {\r\n    this.onLanguageSwap.emit();\r\n  }\r\n\r\n  targetLangChange(language: string) {\r\n    this.onTargetLanguageChange.emit(language);\r\n  }\r\n\r\n  vendorChange(systemId: string) {\r\n    this.onVendorChange.emit(systemId);\r\n  }\r\n\r\n  private getElementRefWidth(element: ElementRef) {\r\n    return element?.nativeElement.offsetWidth || 0;\r\n  }\r\n\r\n  private subscribeToActiveData(){\r\n    this.tldSystem.getActiveData()\r\n    .pipe(takeUntil(this.destroy$))\r\n    .subscribe((active) => {\r\n      if (!active) {\r\n        this.isTerminologySupported = false;\r\n        return;\r\n      }\r\n\r\n      this.isTerminologySupported = this.tldSystem.isTerminologySupported(active.system);\r\n    });\r\n  }\r\n}\r\n","<div fxLayout=\"row\" fxLayoutAlign=\"center center\" class=\"tld-translate-switcher-container\" #wrapper\r\n  [ngClass.lt-md]=\"'tld-translate-switcher-container-tablet'\"\r\n  [ngClass.lt-sm]=\"'tld-translate-switcher-container-mobile'\"\r\n  [class.tld-switcher-with-collections]='collectionsVisible'>\r\n\r\n  <div fxFlex fxLayout=\"row\" fxLayoutAlign=\"start center\">\r\n    <div fxHide.lt-md *ngIf=\"!hideLangMenuLabels\" #fromLabel>{{'TLD_TRANSLATE.FROM' | translate}}</div>\r\n    <div fxFlex fxLayout=\"row\" fxLayoutAlign=\"start center\">\r\n      <tld-lang-list id=\"tld-source-language-list\" [disabled]=\"disabled\" [testId]=\"srcLangTestId\"\r\n        [languages]=\"settings.sourceLanguageList\" (onLanguageChange)=\"sourceLangChange($event)\"\r\n        [selected]=\"settings.source\" [maxDisplayedLanguages]=\"visibleLanguageCount\"></tld-lang-list>\r\n      <ng-container *ngIf=\"domainSide==='src'\">\r\n        <ng-container *ngTemplateOutlet=\"domainTemplate;\">\r\n        </ng-container>\r\n      </ng-container>\r\n    </div>\r\n    <div #sourceAside *ngIf=\"swapIconPosition==='src'\">\r\n      <ng-container *ngTemplateOutlet=\"swapButtonTemplate;\"></ng-container>\r\n    </div>\r\n  </div>\r\n  <div *ngIf=\"swapIconPosition==='center'\">\r\n    <ng-container *ngTemplateOutlet=\"swapButtonTemplate;\"></ng-container>\r\n  </div>\r\n  <div fxFlex fxLayout=\"row\" fxLayoutAlign=\"start center\" fxLayoutAlign.lt-sm=\"end center\">\r\n    <div fxHide.lt-md *ngIf=\"!hideLangMenuLabels\" #toLabel>{{'TLD_TRANSLATE.TO' | translate}}</div>\r\n    <div fxFlex fxLayout=\"row\" fxLayoutAlign=\"start center\">\r\n      <tld-lang-list [disabled]=\"disabled\" id=\"tld-target-language-list\" [languages]=\"settings.targetLanguageList\"\r\n        (onLanguageChange)=\"targetLangChange($event)\" [selected]=\"settings.target\"\r\n        [maxDisplayedLanguages]=\"visibleLanguageCount\" [testId]=\"trgLangTestId\" (onDomainChange)=\"domainChange($event)\"\r\n        [showDomainsWithLanguageName]=\"showDomainsWithLanguageName\">\r\n        <ng-container *ngIf=\"domainSide==='trg'\">\r\n          <ng-container *ngTemplateOutlet=\"domainTemplate;\">\r\n          </ng-container>\r\n        </ng-container>\r\n        <div class=\"tld-translate-vendor-selection\" fxLayoutAlign=\"center center\" *ngIf=\"showVendors\" #vendorWrapper>\r\n          <tld-list-menu (selectionChange)=\"domainChange($event)\" [list]=\"settings.vendors\" [titleKey]=\"'title'\"\r\n            [valueKey]=\"'systemId'\" testId=\"tld-vendor-list\" [disabled]=\"disabled\" [showContent]=\"false\"\r\n            [ariaLabel]=\"'TLD_TRANSLATE.VENDORS_ARIA_LABEL' | translate\" [selectedValue]=\"settings.systemId\">\r\n          </tld-list-menu>\r\n        </div>\r\n      </tld-lang-list>\r\n    </div>\r\n    <div fxLayout=\"row\" fxLayoutGap.gt-xs=\"16px\">\r\n      <div *ngIf=\"collectionsVisible\" #collectionWrapper>\r\n        <tld-term-menu></tld-term-menu>\r\n      </div>\r\n      <tld-loader *ngIf=\"loader\" fxHide.lt-sm></tld-loader>\r\n      <tld-translate-button [enablePulseAnimation]=\"true\" *ngIf=\"showTranslateButton && !loader\" class=\"switcher-translate-button\"\r\n        [fxHide.lt-sm]=\"hideOnSmallScreens\" [disabled]=\"buttonDisabled\"></tld-translate-button>\r\n    </div>\r\n  </div>\r\n</div>\r\n\r\n<ng-template #swapButtonTemplate>\r\n  <button [disabled]=\"isSwapLanguagesDisabled\" class=\"swap-languages-button\" mat-icon-button\r\n    (click)=\"swapSourceAndTarget()\" aria-label=\"swap languages\" color=\"primary\"\r\n    matTooltip=\"{{'TOOLTIPS.SWAP_LANGUAGES' | translate}}\">\r\n    <span class=\"material-icons\" aria-hidden=\"false\"\r\n      [attr.aria-label]=\"'ARIA_LABELS.SWAP_LANGUAGES' | translate\">swap_horiz</span>\r\n  </button>\r\n</ng-template>\r\n\r\n<ng-template #domainTemplate>\r\n  <div class=\"tld-translate-domain-selection\" fxLayoutAlign=\"center center\" *ngIf=\"showDomains\" #domainWrapper>\r\n    <tld-domain-list fxLayoutAlign=\"center center\" (selectionChange)=\"domainChange($event)\"\r\n      [list]=\"settings.domains.domains\" [selected]=\"settings.domains.active\" [selected]=\"settings.domains.active\"\r\n      [disabled]=\"disabled\"></tld-domain-list>\r\n  </div>\r\n</ng-template>\r\n"]}
|
|
@@ -39,6 +39,7 @@ export class TldTranslateComponent {
|
|
|
39
39
|
this.wtwQueryService = wtwQueryService;
|
|
40
40
|
this.systemPickerService = systemPickerService;
|
|
41
41
|
this.onError = new EventEmitter();
|
|
42
|
+
this.onSystemChange = new EventEmitter();
|
|
42
43
|
this.messages = [];
|
|
43
44
|
this.noSystemsError = { body: "TLD_TRANSLATE.ERROR_NO_SYSTEMS_LOADED", type: NotificationMessageType.ERROR, hideClose: true };
|
|
44
45
|
this.languageMenuV1 = languageMenuVersion.V1;
|
|
@@ -110,6 +111,7 @@ export class TldTranslateComponent {
|
|
|
110
111
|
if (!val) {
|
|
111
112
|
return;
|
|
112
113
|
}
|
|
114
|
+
this.onSystemChange.emit(val);
|
|
113
115
|
this.switcherOptions = {
|
|
114
116
|
domains: val.domains,
|
|
115
117
|
source: { code: val.sourceLang.lang, systemId: val.systemId },
|
|
@@ -200,7 +202,7 @@ export class TldTranslateComponent {
|
|
|
200
202
|
}
|
|
201
203
|
}
|
|
202
204
|
TldTranslateComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TldTranslateComponent, deps: [{ token: i1.TranslateService }, { token: i2.TldTranslateFileService }, { token: i3.TldTranslateTextService }, { token: i4.TldTranslateConfigService }, { token: i4.TldAlertService }, { token: i5.TldTranslateButtonService }, { token: i6.TldSystemService }, { token: i7.AudioRecordService }, { token: i7.TldVoiceInputService }, { token: i8.WtwLinkParamsService }, { token: i9.TranslationSystemPickerService }, { token: i4.IconService }], target: i0.ɵɵFactoryTarget.Component });
|
|
203
|
-
TldTranslateComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: TldTranslateComponent, selector: "tld-translate", outputs: { onError: "onError" }, viewQueries: [{ propertyName: "tldTranslateBody", first: true, predicate: TldTranslateBodyComponent, descendants: true }], ngImport: i0, template: "<div fxLayout=\"column\" class=\"h-100 tld-translate\" *ngIf=\"!showNoSystemsError\"\r\n [ngClass.lt-md]=\"'tld-translate-tablet tld-default-border-bottom'\"\r\n [ngClass.lt-sm]=\"'tld-translate-mobile tld-default-border-bottom'\"\r\n [class.tld-translate-multiple-files-active]=\"isMultipleFilesActive\">\r\n <div class=\"tld-translate-wrapper tld-default-border\" fxLayout=\"column\" fxFlex>\r\n <div class=\"tld-translate-switcher-wrapper tld-default-border-bottom\">\r\n <tld-translate-switcher *ngIf=\"switcherOptions && languageMenuVersion === languageMenuV1\"\r\n [disabled]=\"actionButtonDisabled\" [isCollectionsActivated]=\"isCollectionsActivated\" [settings]=\"switcherOptions\"\r\n [maxDisplayedLanguages]=\"maxDisplayedLanguages\" [showDomainsWithLanguageName]=\"showDomainsWithLanguageName\"\r\n [buttonDisabled]=\"actionButtonDisabled\" [hideLangMenuLabels]=\"hideLangMenuLabels\"\r\n (onDomainChange)=\"systemChange($event)\" (onActionClick)=\"translateButtonClick()\"\r\n (onLanguageSwap)=\"swapLanguages()\" (onSourceLanguageChange)=\"sourceLanguageChange($event)\"\r\n (onTargetLanguageChange)=\"targetLanguageChange($event)\" [loader]=\"actionButtonLoader\" [showTranslateButton]=\"showTranslateButton\">\r\n </tld-translate-switcher>\r\n <tld-translation-system-picker *ngIf=\"languageMenuVersion===languageMenuV2\"\r\n [isCollectionsActivated]=\"isCollectionsActivated\"></tld-translation-system-picker>\r\n </div>\r\n <lib-tld-notification-message [inline]=\"true\" *ngFor=\"let message of messages; let ix = index\" [message]=\"message\"\r\n (closeClicked)=\"removeMessage(ix)\">\r\n </lib-tld-notification-message>\r\n <div fxFlex style=\"position: relative;\">\r\n <tld-translate-body fxFlex fxLayoutAlign=\"column\" [attr.source-language]=\"sourceLanguage\"\r\n [attr.target-language]=\"targetLanguage\"></tld-translate-body>\r\n <tld-translation-system-picker-dropdown [ngClass.xs]=\"'mobile'\" *ngIf=\"systemPickerDropdownVisible\">\r\n </tld-translation-system-picker-dropdown>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<lib-tld-notification-message *ngIf=\"showNoSystemsError\" [message]=\"noSystemsError\">\r\n</lib-tld-notification-message>\r\n", styles: [".tld-translate-wrapper{overflow:hidden;background:#ffffff;box-shadow:0 3.2px 7.2px #00000021}.tld-translate-switcher-wrapper{padding:.5em 1em}.h-100{height:100%}tld-translation-system-picker-dropdown{z-index:2}tld-translation-system-picker-dropdown:not(.mobile){position:absolute;width:100%;height:100%}tld-translation-system-picker-dropdown.mobile{position:fixed;top:0;left:0;width:100vw;height:100vh}\n"], dependencies: [{ kind: "directive", type: i10.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i10.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i11.DefaultLayoutDirective, selector: " [fxLayout], [fxLayout.xs], [fxLayout.sm], [fxLayout.md], [fxLayout.lg], [fxLayout.xl], [fxLayout.lt-sm], [fxLayout.lt-md], [fxLayout.lt-lg], [fxLayout.lt-xl], [fxLayout.gt-xs], [fxLayout.gt-sm], [fxLayout.gt-md], [fxLayout.gt-lg]", inputs: ["fxLayout", "fxLayout.xs", "fxLayout.sm", "fxLayout.md", "fxLayout.lg", "fxLayout.xl", "fxLayout.lt-sm", "fxLayout.lt-md", "fxLayout.lt-lg", "fxLayout.lt-xl", "fxLayout.gt-xs", "fxLayout.gt-sm", "fxLayout.gt-md", "fxLayout.gt-lg"] }, { kind: "directive", type: i11.DefaultLayoutAlignDirective, selector: " [fxLayoutAlign], [fxLayoutAlign.xs], [fxLayoutAlign.sm], [fxLayoutAlign.md], [fxLayoutAlign.lg], [fxLayoutAlign.xl], [fxLayoutAlign.lt-sm], [fxLayoutAlign.lt-md], [fxLayoutAlign.lt-lg], [fxLayoutAlign.lt-xl], [fxLayoutAlign.gt-xs], [fxLayoutAlign.gt-sm], [fxLayoutAlign.gt-md], [fxLayoutAlign.gt-lg]", inputs: ["fxLayoutAlign", "fxLayoutAlign.xs", "fxLayoutAlign.sm", "fxLayoutAlign.md", "fxLayoutAlign.lg", "fxLayoutAlign.xl", "fxLayoutAlign.lt-sm", "fxLayoutAlign.lt-md", "fxLayoutAlign.lt-lg", "fxLayoutAlign.lt-xl", "fxLayoutAlign.gt-xs", "fxLayoutAlign.gt-sm", "fxLayoutAlign.gt-md", "fxLayoutAlign.gt-lg"] }, { kind: "directive", type: i11.DefaultFlexDirective, selector: " [fxFlex], [fxFlex.xs], [fxFlex.sm], [fxFlex.md], [fxFlex.lg], [fxFlex.xl], [fxFlex.lt-sm], [fxFlex.lt-md], [fxFlex.lt-lg], [fxFlex.lt-xl], [fxFlex.gt-xs], [fxFlex.gt-sm], [fxFlex.gt-md], [fxFlex.gt-lg]", inputs: ["fxFlex", "fxFlex.xs", "fxFlex.sm", "fxFlex.md", "fxFlex.lg", "fxFlex.xl", "fxFlex.lt-sm", "fxFlex.lt-md", "fxFlex.lt-lg", "fxFlex.lt-xl", "fxFlex.gt-xs", "fxFlex.gt-sm", "fxFlex.gt-md", "fxFlex.gt-lg"] }, { kind: "directive", type: i12.DefaultClassDirective, selector: " [ngClass], [ngClass.xs], [ngClass.sm], [ngClass.md], [ngClass.lg], [ngClass.xl], [ngClass.lt-sm], [ngClass.lt-md], [ngClass.lt-lg], [ngClass.lt-xl], [ngClass.gt-xs], [ngClass.gt-sm], [ngClass.gt-md], [ngClass.gt-lg]", inputs: ["ngClass", "ngClass.xs", "ngClass.sm", "ngClass.md", "ngClass.lg", "ngClass.xl", "ngClass.lt-sm", "ngClass.lt-md", "ngClass.lt-lg", "ngClass.lt-xl", "ngClass.gt-xs", "ngClass.gt-sm", "ngClass.gt-md", "ngClass.gt-lg"] }, { kind: "component", type: i13.TldTranslateSwitcherComponent, selector: "tld-translate-switcher", inputs: ["buttonDisabled", "showTranslateButton", "hideOnSmallScreens", "disabled", "hideLangMenuLabels", "maxDisplayedLanguages", "collections", "showDomainsWithLanguageName", "isCollectionsActivated", "useParentWidth", "loader", "settings"], outputs: ["onDomainChange", "onActionClick", "onSourceLanguageChange", "onTargetLanguageChange", "onLanguageSwap", "onVendorChange"] }, { kind: "component", type: i14.TranslationSystemPickerComponent, selector: "tld-translation-system-picker", inputs: ["isCollectionsActivated"] }, { kind: "component", type: i15.TranslationSystemPickerDropdownComponent, selector: "tld-translation-system-picker-dropdown" }, { kind: "component", type: i16.NotificationMessageComponent, selector: "lib-tld-notification-message", inputs: ["message", "inline"], outputs: ["buttonClicked", "closeClicked", "linkClicked"] }, { kind: "component", type: i17.TldTranslateBodyComponent, selector: "tld-translate-body" }], animations: [
|
|
205
|
+
TldTranslateComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: TldTranslateComponent, selector: "tld-translate", outputs: { onError: "onError", onSystemChange: "onSystemChange" }, viewQueries: [{ propertyName: "tldTranslateBody", first: true, predicate: TldTranslateBodyComponent, descendants: true }], ngImport: i0, template: "<div fxLayout=\"column\" class=\"h-100 tld-translate\" *ngIf=\"!showNoSystemsError\"\r\n [ngClass.lt-md]=\"'tld-translate-tablet tld-default-border-bottom'\"\r\n [ngClass.lt-sm]=\"'tld-translate-mobile tld-default-border-bottom'\"\r\n [class.tld-translate-multiple-files-active]=\"isMultipleFilesActive\">\r\n <div class=\"tld-translate-wrapper tld-default-border\" fxLayout=\"column\" fxFlex>\r\n <div class=\"tld-translate-switcher-wrapper tld-default-border-bottom\">\r\n <tld-translate-switcher *ngIf=\"switcherOptions && languageMenuVersion === languageMenuV1\"\r\n [disabled]=\"actionButtonDisabled\" [isCollectionsActivated]=\"isCollectionsActivated\" [settings]=\"switcherOptions\"\r\n [maxDisplayedLanguages]=\"maxDisplayedLanguages\" [showDomainsWithLanguageName]=\"showDomainsWithLanguageName\"\r\n [buttonDisabled]=\"actionButtonDisabled\" [hideLangMenuLabels]=\"hideLangMenuLabels\"\r\n (onDomainChange)=\"systemChange($event)\" (onActionClick)=\"translateButtonClick()\"\r\n (onLanguageSwap)=\"swapLanguages()\" (onSourceLanguageChange)=\"sourceLanguageChange($event)\"\r\n (onTargetLanguageChange)=\"targetLanguageChange($event)\" [loader]=\"actionButtonLoader\" [showTranslateButton]=\"showTranslateButton\">\r\n </tld-translate-switcher>\r\n <tld-translation-system-picker *ngIf=\"languageMenuVersion===languageMenuV2\"\r\n [isCollectionsActivated]=\"isCollectionsActivated\"></tld-translation-system-picker>\r\n </div>\r\n <lib-tld-notification-message [inline]=\"true\" *ngFor=\"let message of messages; let ix = index\" [message]=\"message\"\r\n (closeClicked)=\"removeMessage(ix)\">\r\n </lib-tld-notification-message>\r\n <div fxFlex style=\"position: relative;\">\r\n <tld-translate-body fxFlex fxLayoutAlign=\"column\" [attr.source-language]=\"sourceLanguage\"\r\n [attr.target-language]=\"targetLanguage\"></tld-translate-body>\r\n <tld-translation-system-picker-dropdown [ngClass.xs]=\"'mobile'\" *ngIf=\"systemPickerDropdownVisible\">\r\n </tld-translation-system-picker-dropdown>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<lib-tld-notification-message *ngIf=\"showNoSystemsError\" [message]=\"noSystemsError\">\r\n</lib-tld-notification-message>\r\n", styles: [".tld-translate-wrapper{overflow:hidden;background:#ffffff;box-shadow:0 3.2px 7.2px #00000021}.tld-translate-switcher-wrapper{padding:.5em 1em}.h-100{height:100%}tld-translation-system-picker-dropdown{z-index:2}tld-translation-system-picker-dropdown:not(.mobile){position:absolute;width:100%;height:100%}tld-translation-system-picker-dropdown.mobile{position:fixed;top:0;left:0;width:100vw;height:100vh}\n"], dependencies: [{ kind: "directive", type: i10.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i10.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i11.DefaultLayoutDirective, selector: " [fxLayout], [fxLayout.xs], [fxLayout.sm], [fxLayout.md], [fxLayout.lg], [fxLayout.xl], [fxLayout.lt-sm], [fxLayout.lt-md], [fxLayout.lt-lg], [fxLayout.lt-xl], [fxLayout.gt-xs], [fxLayout.gt-sm], [fxLayout.gt-md], [fxLayout.gt-lg]", inputs: ["fxLayout", "fxLayout.xs", "fxLayout.sm", "fxLayout.md", "fxLayout.lg", "fxLayout.xl", "fxLayout.lt-sm", "fxLayout.lt-md", "fxLayout.lt-lg", "fxLayout.lt-xl", "fxLayout.gt-xs", "fxLayout.gt-sm", "fxLayout.gt-md", "fxLayout.gt-lg"] }, { kind: "directive", type: i11.DefaultLayoutAlignDirective, selector: " [fxLayoutAlign], [fxLayoutAlign.xs], [fxLayoutAlign.sm], [fxLayoutAlign.md], [fxLayoutAlign.lg], [fxLayoutAlign.xl], [fxLayoutAlign.lt-sm], [fxLayoutAlign.lt-md], [fxLayoutAlign.lt-lg], [fxLayoutAlign.lt-xl], [fxLayoutAlign.gt-xs], [fxLayoutAlign.gt-sm], [fxLayoutAlign.gt-md], [fxLayoutAlign.gt-lg]", inputs: ["fxLayoutAlign", "fxLayoutAlign.xs", "fxLayoutAlign.sm", "fxLayoutAlign.md", "fxLayoutAlign.lg", "fxLayoutAlign.xl", "fxLayoutAlign.lt-sm", "fxLayoutAlign.lt-md", "fxLayoutAlign.lt-lg", "fxLayoutAlign.lt-xl", "fxLayoutAlign.gt-xs", "fxLayoutAlign.gt-sm", "fxLayoutAlign.gt-md", "fxLayoutAlign.gt-lg"] }, { kind: "directive", type: i11.DefaultFlexDirective, selector: " [fxFlex], [fxFlex.xs], [fxFlex.sm], [fxFlex.md], [fxFlex.lg], [fxFlex.xl], [fxFlex.lt-sm], [fxFlex.lt-md], [fxFlex.lt-lg], [fxFlex.lt-xl], [fxFlex.gt-xs], [fxFlex.gt-sm], [fxFlex.gt-md], [fxFlex.gt-lg]", inputs: ["fxFlex", "fxFlex.xs", "fxFlex.sm", "fxFlex.md", "fxFlex.lg", "fxFlex.xl", "fxFlex.lt-sm", "fxFlex.lt-md", "fxFlex.lt-lg", "fxFlex.lt-xl", "fxFlex.gt-xs", "fxFlex.gt-sm", "fxFlex.gt-md", "fxFlex.gt-lg"] }, { kind: "directive", type: i12.DefaultClassDirective, selector: " [ngClass], [ngClass.xs], [ngClass.sm], [ngClass.md], [ngClass.lg], [ngClass.xl], [ngClass.lt-sm], [ngClass.lt-md], [ngClass.lt-lg], [ngClass.lt-xl], [ngClass.gt-xs], [ngClass.gt-sm], [ngClass.gt-md], [ngClass.gt-lg]", inputs: ["ngClass", "ngClass.xs", "ngClass.sm", "ngClass.md", "ngClass.lg", "ngClass.xl", "ngClass.lt-sm", "ngClass.lt-md", "ngClass.lt-lg", "ngClass.lt-xl", "ngClass.gt-xs", "ngClass.gt-sm", "ngClass.gt-md", "ngClass.gt-lg"] }, { kind: "component", type: i13.TldTranslateSwitcherComponent, selector: "tld-translate-switcher", inputs: ["buttonDisabled", "showTranslateButton", "hideOnSmallScreens", "disabled", "hideLangMenuLabels", "maxDisplayedLanguages", "collections", "showDomainsWithLanguageName", "isCollectionsActivated", "useParentWidth", "loader", "settings"], outputs: ["onDomainChange", "onActionClick", "onSourceLanguageChange", "onTargetLanguageChange", "onLanguageSwap", "onVendorChange"] }, { kind: "component", type: i14.TranslationSystemPickerComponent, selector: "tld-translation-system-picker", inputs: ["isCollectionsActivated"] }, { kind: "component", type: i15.TranslationSystemPickerDropdownComponent, selector: "tld-translation-system-picker-dropdown" }, { kind: "component", type: i16.NotificationMessageComponent, selector: "lib-tld-notification-message", inputs: ["message", "inline"], outputs: ["buttonClicked", "closeClicked", "linkClicked"] }, { kind: "component", type: i17.TldTranslateBodyComponent, selector: "tld-translate-body" }], animations: [
|
|
204
206
|
trigger('openCloseAnimation', [
|
|
205
207
|
transition(':enter', [
|
|
206
208
|
style({ height: 0 }),
|
|
@@ -222,8 +224,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
222
224
|
], template: "<div fxLayout=\"column\" class=\"h-100 tld-translate\" *ngIf=\"!showNoSystemsError\"\r\n [ngClass.lt-md]=\"'tld-translate-tablet tld-default-border-bottom'\"\r\n [ngClass.lt-sm]=\"'tld-translate-mobile tld-default-border-bottom'\"\r\n [class.tld-translate-multiple-files-active]=\"isMultipleFilesActive\">\r\n <div class=\"tld-translate-wrapper tld-default-border\" fxLayout=\"column\" fxFlex>\r\n <div class=\"tld-translate-switcher-wrapper tld-default-border-bottom\">\r\n <tld-translate-switcher *ngIf=\"switcherOptions && languageMenuVersion === languageMenuV1\"\r\n [disabled]=\"actionButtonDisabled\" [isCollectionsActivated]=\"isCollectionsActivated\" [settings]=\"switcherOptions\"\r\n [maxDisplayedLanguages]=\"maxDisplayedLanguages\" [showDomainsWithLanguageName]=\"showDomainsWithLanguageName\"\r\n [buttonDisabled]=\"actionButtonDisabled\" [hideLangMenuLabels]=\"hideLangMenuLabels\"\r\n (onDomainChange)=\"systemChange($event)\" (onActionClick)=\"translateButtonClick()\"\r\n (onLanguageSwap)=\"swapLanguages()\" (onSourceLanguageChange)=\"sourceLanguageChange($event)\"\r\n (onTargetLanguageChange)=\"targetLanguageChange($event)\" [loader]=\"actionButtonLoader\" [showTranslateButton]=\"showTranslateButton\">\r\n </tld-translate-switcher>\r\n <tld-translation-system-picker *ngIf=\"languageMenuVersion===languageMenuV2\"\r\n [isCollectionsActivated]=\"isCollectionsActivated\"></tld-translation-system-picker>\r\n </div>\r\n <lib-tld-notification-message [inline]=\"true\" *ngFor=\"let message of messages; let ix = index\" [message]=\"message\"\r\n (closeClicked)=\"removeMessage(ix)\">\r\n </lib-tld-notification-message>\r\n <div fxFlex style=\"position: relative;\">\r\n <tld-translate-body fxFlex fxLayoutAlign=\"column\" [attr.source-language]=\"sourceLanguage\"\r\n [attr.target-language]=\"targetLanguage\"></tld-translate-body>\r\n <tld-translation-system-picker-dropdown [ngClass.xs]=\"'mobile'\" *ngIf=\"systemPickerDropdownVisible\">\r\n </tld-translation-system-picker-dropdown>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<lib-tld-notification-message *ngIf=\"showNoSystemsError\" [message]=\"noSystemsError\">\r\n</lib-tld-notification-message>\r\n", styles: [".tld-translate-wrapper{overflow:hidden;background:#ffffff;box-shadow:0 3.2px 7.2px #00000021}.tld-translate-switcher-wrapper{padding:.5em 1em}.h-100{height:100%}tld-translation-system-picker-dropdown{z-index:2}tld-translation-system-picker-dropdown:not(.mobile){position:absolute;width:100%;height:100%}tld-translation-system-picker-dropdown.mobile{position:fixed;top:0;left:0;width:100vw;height:100vh}\n"] }]
|
|
223
225
|
}], ctorParameters: function () { return [{ type: i1.TranslateService }, { type: i2.TldTranslateFileService }, { type: i3.TldTranslateTextService }, { type: i4.TldTranslateConfigService }, { type: i4.TldAlertService }, { type: i5.TldTranslateButtonService }, { type: i6.TldSystemService }, { type: i7.AudioRecordService }, { type: i7.TldVoiceInputService }, { type: i8.WtwLinkParamsService }, { type: i9.TranslationSystemPickerService }, { type: i4.IconService }]; }, propDecorators: { onError: [{
|
|
224
226
|
type: Output
|
|
227
|
+
}], onSystemChange: [{
|
|
228
|
+
type: Output
|
|
225
229
|
}], tldTranslateBody: [{
|
|
226
230
|
type: ViewChild,
|
|
227
231
|
args: [TldTranslateBodyComponent]
|
|
228
232
|
}] } });
|
|
229
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tld-translate.component.js","sourceRoot":"","sources":["../../../../projects/tld-translate/src/lib/tld-translate.component.ts","../../../../projects/tld-translate/src/lib/tld-translate.component.html"],"names":[],"mappings":"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","sourcesContent":["import { animate, style, transition, trigger } from '@angular/animations';\r\nimport { Component, EventEmitter, OnDestroy, OnInit, Output, ViewChild } from '@angular/core';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { NotificationMessage, NotificationMessageType } from '@tilde-nlp/ngx-common';\r\nimport { Subject } from 'rxjs';\r\nimport { distinctUntilChanged, takeUntil } from 'rxjs/operators';\r\nimport { availableLanguages } from './i18n/available-languages';\r\nimport { AudioRecordService, TldVoiceInputService } from './modules/tld-audio/services';\r\nimport { TldTranslateButtonService } from './modules/tld-common/components/translate-button/tld-translate-button.service';\r\nimport { IAuthOptions, languageMenuVersion } from './modules/tld-common/models';\r\nimport { IconService, TldAlertService, TldTranslateConfigService } from './modules/tld-common/services';\r\nimport { WtwLinkParamsService } from './modules/tld-common/services/wtw-link-params.service';\r\nimport { TldTranslateFileService } from './modules/tld-document/services/tld-translate-file.service';\r\nimport { TldTranslateTextService } from './modules/tld-text/services/tld-translate-text.service';\r\nimport { IActiveData } from './modules/tld-tooltip/models/active-data.model';\r\nimport { ISwitcherTranslationOptions } from './modules/tld-tooltip/models/switcher-options.model';\r\nimport { TldSystemService } from './modules/tld-tooltip/services/tld-system.service';\r\nimport { OpenedMenu } from './modules/tld-tooltip/translation-system-picker/models/opened-menu';\r\nimport { TranslationSystemPickerService } from './modules/tld-tooltip/translation-system-picker/services/translation-system-picker.service';\r\nimport { TldTranslateBodyComponent } from './tld-translate-body/tld-translate-body.component';\r\n\r\n@Component({\r\n  selector: 'tld-translate',\r\n  templateUrl: './tld-translate.component.html',\r\n  styleUrls: ['./tld-translate.component.scss'],\r\n  animations: [\r\n    trigger('openCloseAnimation', [\r\n\r\n      transition(':enter', [\r\n        style({ height: 0 }),\r\n        animate(500)\r\n      ]),\r\n\r\n      transition(':leave',\r\n        animate(500, style({ height: 0 })))\r\n    ])\r\n  ]\r\n})\r\nexport class TldTranslateComponent implements OnInit, OnDestroy {\r\n  @Output() onError: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  @ViewChild(TldTranslateBodyComponent) tldTranslateBody: TldTranslateBodyComponent;\r\n\r\n  activeSystemObj: IActiveData;\r\n  messages: NotificationMessage[] = [];\r\n\r\n  switcherOptions: ISwitcherTranslationOptions;\r\n\r\n  get actionButtonLoader() { return this.translateTextService.isTranslating; }\r\n\r\n  get showDomainsWithLanguageName(): boolean {\r\n    return this.configService.coreConfig.showDomainsWithLanguageName;\r\n  }\r\n\r\n  get maxDisplayedLanguages(): number {\r\n    return this.configService.coreConfig.maxDisplayedLanguages;\r\n  }\r\n\r\n  get showNoSystemsError() {\r\n    return this.tldSystem.noSystemsError;\r\n  }\r\n  readonly noSystemsError: NotificationMessage = { body: \"TLD_TRANSLATE.ERROR_NO_SYSTEMS_LOADED\", type: NotificationMessageType.ERROR, hideClose: true };\r\n  get actionButtonDisabled() {\r\n    return this.translateFileService.disableTranslateButton\r\n      || this.audioService.isRecording\r\n      || this.voiceProcessingService.isProcessing\r\n      || this.translateTextService.isDictating\r\n  }\r\n\r\n  get showTranslateButton() {\r\n    return !this.translateFileService.multipleFileUploadActive;\r\n  }\r\n\r\n  // this param is necessary to remove max height if multiple file component is active, since there shouldn't be max height in that case.\r\n  get isMultipleFilesActive() {\r\n    return this.tldTranslateBody?.multipleFilesUploaded;\r\n  }\r\n\r\n  get hideLangMenuLabels() {\r\n    return this.configService?.coreConfig.hideLangMenuLabels;\r\n  }\r\n\r\n  get isCollectionsActivated() {\r\n    return this.configService?.termConfig?.isCollectionsActivated;\r\n  }\r\n\r\n  get sourceLanguage() {\r\n    return this.activeSystemObj?.sourceLang.lang;\r\n  }\r\n\r\n  get targetLanguage() {\r\n    return this.activeSystemObj?.targetLang.lang;\r\n  }\r\n\r\n  get systemPickerDropdownVisible() {\r\n    return this.systemPickerService.openedMenu !== OpenedMenu.NONE;\r\n  }\r\n\r\n  get languageMenuVersion() {\r\n    return this.configService.coreConfig?.languageMenuVersion;\r\n  }\r\n\r\n  readonly languageMenuV1 = languageMenuVersion.V1;\r\n  readonly languageMenuV2 = languageMenuVersion.V2;\r\n\r\n  private readonly destroy$ = new Subject();\r\n\r\n  constructor(private readonly translate: TranslateService,\r\n    private readonly translateFileService: TldTranslateFileService,\r\n    private readonly translateTextService: TldTranslateTextService,\r\n    private readonly configService: TldTranslateConfigService,\r\n    private readonly alerts: TldAlertService,\r\n    private readonly translateButtonService: TldTranslateButtonService,\r\n    private readonly tldSystem: TldSystemService,\r\n    private readonly audioService: AudioRecordService,\r\n    private readonly voiceProcessingService: TldVoiceInputService,\r\n    private readonly wtwQueryService: WtwLinkParamsService,\r\n    private readonly systemPickerService: TranslationSystemPickerService,\r\n    iconService: IconService\r\n  ) {\r\n    iconService.registerIcons();\r\n  }\r\n\r\n  changeAuth(authOptions: IAuthOptions) {\r\n    this.configService.coreConfig.isAuth = authOptions.isAuth;\r\n    this.configService.termConfig.canCreateCollection = authOptions.canCreateTermCollection;\r\n    this.translateFileService.clear();\r\n    this.initializeWidget();\r\n  }\r\n\r\n  initializeWidget(): void {\r\n    this.tldSystem.init(this.tldSystem.getLastUsedSystem() ?? this.configService.coreConfig.defaultSystemId);\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.removeMessagesOnClear();\r\n\r\n    if (this.configService.coreConfig.debug) {\r\n      for (const key in availableLanguages) {\r\n        this.translate.setTranslation(key, availableLanguages[key], true);\r\n      }\r\n    }\r\n\r\n    this.initializeWidget();\r\n\r\n    this.tldSystem.getActiveData().pipe(\r\n      distinctUntilChanged(),\r\n      takeUntil(this.destroy$))\r\n      .subscribe((val: IActiveData) => {\r\n        this.activeSystemObj = val;\r\n        if (!val) {\r\n          return;\r\n        }\r\n        this.switcherOptions = {\r\n          domains: val.domains,\r\n          source: { code: val.sourceLang.lang, systemId: val.systemId },\r\n          sourceLanguageList: val.sourceLangList,\r\n          systemId: val.systemId,\r\n          swapActive: val.swapLangActive,\r\n          target: { code: val.targetLang.lang, systemId: val.systemId },\r\n          targetLanguageList: val.targetLangList,\r\n          vendors: val.vendors\r\n        };\r\n      });\r\n\r\n    this.translateTextService.sourceChange.pipe(\r\n      takeUntil(this.destroy$))\r\n      .subscribe((event) => {\r\n        if (event.swapSystems) {\r\n          this.swapLanguages();\r\n        }\r\n      });\r\n\r\n    this.translateButtonService.getActionClick().pipe(\r\n      takeUntil(this.destroy$))\r\n      .subscribe(() => {\r\n        this.translateButtonClick();\r\n      });\r\n\r\n    this.wtwQueryService.query().pipe(\r\n      takeUntil(this.destroy$))\r\n      .subscribe((query: string) => {\r\n        this.messages.forEach(msg => {\r\n          msg.localizationParams.queryString = query\r\n        });\r\n      });\r\n\r\n    this.alerts.getMessages().pipe(\r\n      takeUntil(this.destroy$))\r\n      .subscribe((message: NotificationMessage) => {\r\n        message.localizationParams.queryString = this.wtwQueryService.defaultQueryString;\r\n        if (message.type === NotificationMessageType.ERROR) {\r\n          this.onError.emit(message.error);\r\n        }\r\n        // pushing only \"one of\" message in array, so screen is not spammed with messages\r\n        const existingMessage = this.messages.find(msg => msg.title === message.title\r\n          && msg.type === message.type\r\n          && message.body === msg.body\r\n          && JSON.stringify(msg.localizationParams) === JSON.stringify(message.localizationParams));\r\n        if (!existingMessage) {\r\n          this.messages.push(message);\r\n        }\r\n      });\r\n\r\n    if (this.configService.coreConfig.translateAppName) {\r\n      this.translate.get(\"APP_NAME\").pipe(\r\n        takeUntil(this.destroy$))\r\n        .subscribe((text: string) => {\r\n          this.configService.coreConfig.appName = text;\r\n        });\r\n    }\r\n  }\r\n\r\n  removeMessage(ix: number) {\r\n    this.messages.splice(ix, 1);\r\n  }\r\n\r\n  swapLanguages() {\r\n    this.tldSystem.swapSystemLanguages();\r\n  }\r\n\r\n  sourceLanguageChange(language: string) {\r\n    this.tldSystem.changeLanguage(language, this.switcherOptions.target.code);\r\n  }\r\n\r\n  systemChange(systemId: string) {\r\n    this.tldSystem.changeSystem(systemId);\r\n  }\r\n\r\n  targetLanguageChange(language: string) {\r\n    this.tldSystem.changeLanguage(this.switcherOptions.source.code, language);\r\n  }\r\n\r\n  translateButtonClick() {\r\n    if (this.translateFileService.translationFiles?.length > 0) {\r\n      this.translateFileService.translateButtonClick(this.activeSystemObj);\r\n    }\r\n    else {\r\n      this.translateTextService.onTranslateButtonClick();\r\n    }\r\n  }\r\n\r\n  removeMessagesOnClear() {\r\n    this.translateFileService.onClear()\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe(() => {\r\n        this.messages = [];\r\n      })\r\n\r\n    this.translateTextService.onClear()\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe(() => {\r\n        this.messages = [];\r\n      })\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.destroy$.next(null)\r\n    this.destroy$.complete();\r\n  }\r\n\r\n}\r\n","<div fxLayout=\"column\" class=\"h-100 tld-translate\" *ngIf=\"!showNoSystemsError\"\r\n  [ngClass.lt-md]=\"'tld-translate-tablet tld-default-border-bottom'\"\r\n  [ngClass.lt-sm]=\"'tld-translate-mobile tld-default-border-bottom'\"\r\n  [class.tld-translate-multiple-files-active]=\"isMultipleFilesActive\">\r\n  <div class=\"tld-translate-wrapper tld-default-border\" fxLayout=\"column\" fxFlex>\r\n    <div class=\"tld-translate-switcher-wrapper tld-default-border-bottom\">\r\n      <tld-translate-switcher *ngIf=\"switcherOptions && languageMenuVersion === languageMenuV1\"\r\n        [disabled]=\"actionButtonDisabled\" [isCollectionsActivated]=\"isCollectionsActivated\" [settings]=\"switcherOptions\"\r\n        [maxDisplayedLanguages]=\"maxDisplayedLanguages\" [showDomainsWithLanguageName]=\"showDomainsWithLanguageName\"\r\n        [buttonDisabled]=\"actionButtonDisabled\" [hideLangMenuLabels]=\"hideLangMenuLabels\"\r\n        (onDomainChange)=\"systemChange($event)\" (onActionClick)=\"translateButtonClick()\"\r\n        (onLanguageSwap)=\"swapLanguages()\" (onSourceLanguageChange)=\"sourceLanguageChange($event)\"\r\n        (onTargetLanguageChange)=\"targetLanguageChange($event)\" [loader]=\"actionButtonLoader\" [showTranslateButton]=\"showTranslateButton\">\r\n      </tld-translate-switcher>\r\n      <tld-translation-system-picker *ngIf=\"languageMenuVersion===languageMenuV2\"\r\n        [isCollectionsActivated]=\"isCollectionsActivated\"></tld-translation-system-picker>\r\n    </div>\r\n    <lib-tld-notification-message [inline]=\"true\" *ngFor=\"let message of messages; let ix = index\" [message]=\"message\"\r\n      (closeClicked)=\"removeMessage(ix)\">\r\n    </lib-tld-notification-message>\r\n    <div fxFlex style=\"position: relative;\">\r\n      <tld-translate-body fxFlex fxLayoutAlign=\"column\" [attr.source-language]=\"sourceLanguage\"\r\n        [attr.target-language]=\"targetLanguage\"></tld-translate-body>\r\n      <tld-translation-system-picker-dropdown [ngClass.xs]=\"'mobile'\" *ngIf=\"systemPickerDropdownVisible\">\r\n      </tld-translation-system-picker-dropdown>\r\n    </div>\r\n  </div>\r\n</div>\r\n\r\n<lib-tld-notification-message *ngIf=\"showNoSystemsError\" [message]=\"noSystemsError\">\r\n</lib-tld-notification-message>\r\n"]}
|
|
233
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tld-translate.component.js","sourceRoot":"","sources":["../../../../projects/tld-translate/src/lib/tld-translate.component.ts","../../../../projects/tld-translate/src/lib/tld-translate.component.html"],"names":[],"mappings":"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","sourcesContent":["import { animate, style, transition, trigger } from '@angular/animations';\r\nimport { Component, EventEmitter, OnDestroy, OnInit, Output, ViewChild } from '@angular/core';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { NotificationMessage, NotificationMessageType } from '@tilde-nlp/ngx-common';\r\nimport { Subject } from 'rxjs';\r\nimport { distinctUntilChanged, takeUntil } from 'rxjs/operators';\r\nimport { availableLanguages } from './i18n/available-languages';\r\nimport { AudioRecordService, TldVoiceInputService } from './modules/tld-audio/services';\r\nimport { TldTranslateButtonService } from './modules/tld-common/components/translate-button/tld-translate-button.service';\r\nimport { IAuthOptions, languageMenuVersion } from './modules/tld-common/models';\r\nimport { IconService, TldAlertService, TldTranslateConfigService } from './modules/tld-common/services';\r\nimport { WtwLinkParamsService } from './modules/tld-common/services/wtw-link-params.service';\r\nimport { TldTranslateFileService } from './modules/tld-document/services/tld-translate-file.service';\r\nimport { TldTranslateTextService } from './modules/tld-text/services/tld-translate-text.service';\r\nimport { IActiveData } from './modules/tld-tooltip/models/active-data.model';\r\nimport { ISwitcherTranslationOptions } from './modules/tld-tooltip/models/switcher-options.model';\r\nimport { TldSystemService } from './modules/tld-tooltip/services/tld-system.service';\r\nimport { OpenedMenu } from './modules/tld-tooltip/translation-system-picker/models/opened-menu';\r\nimport { TranslationSystemPickerService } from './modules/tld-tooltip/translation-system-picker/services/translation-system-picker.service';\r\nimport { TldTranslateBodyComponent } from './tld-translate-body/tld-translate-body.component';\r\n\r\n@Component({\r\n  selector: 'tld-translate',\r\n  templateUrl: './tld-translate.component.html',\r\n  styleUrls: ['./tld-translate.component.scss'],\r\n  animations: [\r\n    trigger('openCloseAnimation', [\r\n\r\n      transition(':enter', [\r\n        style({ height: 0 }),\r\n        animate(500)\r\n      ]),\r\n\r\n      transition(':leave',\r\n        animate(500, style({ height: 0 })))\r\n    ])\r\n  ]\r\n})\r\nexport class TldTranslateComponent implements OnInit, OnDestroy {\r\n  @Output() onError: EventEmitter<any> = new EventEmitter<any>();\r\n  @Output() onSystemChange: EventEmitter<IActiveData> = new EventEmitter<IActiveData>();\r\n\r\n  @ViewChild(TldTranslateBodyComponent) tldTranslateBody: TldTranslateBodyComponent;\r\n\r\n  activeSystemObj: IActiveData;\r\n  messages: NotificationMessage[] = [];\r\n\r\n  switcherOptions: ISwitcherTranslationOptions;\r\n\r\n  get actionButtonLoader() { return this.translateTextService.isTranslating; }\r\n\r\n  get showDomainsWithLanguageName(): boolean {\r\n    return this.configService.coreConfig.showDomainsWithLanguageName;\r\n  }\r\n\r\n  get maxDisplayedLanguages(): number {\r\n    return this.configService.coreConfig.maxDisplayedLanguages;\r\n  }\r\n\r\n  get showNoSystemsError() {\r\n    return this.tldSystem.noSystemsError;\r\n  }\r\n  readonly noSystemsError: NotificationMessage = { body: \"TLD_TRANSLATE.ERROR_NO_SYSTEMS_LOADED\", type: NotificationMessageType.ERROR, hideClose: true };\r\n  get actionButtonDisabled() {\r\n    return this.translateFileService.disableTranslateButton\r\n      || this.audioService.isRecording\r\n      || this.voiceProcessingService.isProcessing\r\n      || this.translateTextService.isDictating\r\n  }\r\n\r\n  get showTranslateButton() {\r\n    return !this.translateFileService.multipleFileUploadActive;\r\n  }\r\n\r\n  // this param is necessary to remove max height if multiple file component is active, since there shouldn't be max height in that case.\r\n  get isMultipleFilesActive() {\r\n    return this.tldTranslateBody?.multipleFilesUploaded;\r\n  }\r\n\r\n  get hideLangMenuLabels() {\r\n    return this.configService?.coreConfig.hideLangMenuLabels;\r\n  }\r\n\r\n  get isCollectionsActivated() {\r\n    return this.configService?.termConfig?.isCollectionsActivated;\r\n  }\r\n\r\n  get sourceLanguage() {\r\n    return this.activeSystemObj?.sourceLang.lang;\r\n  }\r\n\r\n  get targetLanguage() {\r\n    return this.activeSystemObj?.targetLang.lang;\r\n  }\r\n\r\n  get systemPickerDropdownVisible() {\r\n    return this.systemPickerService.openedMenu !== OpenedMenu.NONE;\r\n  }\r\n\r\n  get languageMenuVersion() {\r\n    return this.configService.coreConfig?.languageMenuVersion;\r\n  }\r\n\r\n  readonly languageMenuV1 = languageMenuVersion.V1;\r\n  readonly languageMenuV2 = languageMenuVersion.V2;\r\n\r\n  private readonly destroy$ = new Subject();\r\n\r\n  constructor(private readonly translate: TranslateService,\r\n    private readonly translateFileService: TldTranslateFileService,\r\n    private readonly translateTextService: TldTranslateTextService,\r\n    private readonly configService: TldTranslateConfigService,\r\n    private readonly alerts: TldAlertService,\r\n    private readonly translateButtonService: TldTranslateButtonService,\r\n    private readonly tldSystem: TldSystemService,\r\n    private readonly audioService: AudioRecordService,\r\n    private readonly voiceProcessingService: TldVoiceInputService,\r\n    private readonly wtwQueryService: WtwLinkParamsService,\r\n    private readonly systemPickerService: TranslationSystemPickerService,\r\n    iconService: IconService\r\n  ) {\r\n    iconService.registerIcons();\r\n  }\r\n\r\n  changeAuth(authOptions: IAuthOptions) {\r\n    this.configService.coreConfig.isAuth = authOptions.isAuth;\r\n    this.configService.termConfig.canCreateCollection = authOptions.canCreateTermCollection;\r\n    this.translateFileService.clear();\r\n    this.initializeWidget();\r\n  }\r\n\r\n  initializeWidget(): void {\r\n    this.tldSystem.init(this.tldSystem.getLastUsedSystem() ?? this.configService.coreConfig.defaultSystemId);\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.removeMessagesOnClear();\r\n\r\n    if (this.configService.coreConfig.debug) {\r\n      for (const key in availableLanguages) {\r\n        this.translate.setTranslation(key, availableLanguages[key], true);\r\n      }\r\n    }\r\n\r\n    this.initializeWidget();\r\n\r\n    this.tldSystem.getActiveData().pipe(\r\n      distinctUntilChanged(),\r\n      takeUntil(this.destroy$))\r\n      .subscribe((val: IActiveData) => {\r\n        this.activeSystemObj = val;\r\n        if (!val) {\r\n          return;\r\n        }\r\n\r\n        this.onSystemChange.emit(val);\r\n\r\n        this.switcherOptions = {\r\n          domains: val.domains,\r\n          source: { code: val.sourceLang.lang, systemId: val.systemId },\r\n          sourceLanguageList: val.sourceLangList,\r\n          systemId: val.systemId,\r\n          swapActive: val.swapLangActive,\r\n          target: { code: val.targetLang.lang, systemId: val.systemId },\r\n          targetLanguageList: val.targetLangList,\r\n          vendors: val.vendors\r\n        };\r\n      });\r\n\r\n    this.translateTextService.sourceChange.pipe(\r\n      takeUntil(this.destroy$))\r\n      .subscribe((event) => {\r\n        if (event.swapSystems) {\r\n          this.swapLanguages();\r\n        }\r\n      });\r\n\r\n    this.translateButtonService.getActionClick().pipe(\r\n      takeUntil(this.destroy$))\r\n      .subscribe(() => {\r\n        this.translateButtonClick();\r\n      });\r\n\r\n    this.wtwQueryService.query().pipe(\r\n      takeUntil(this.destroy$))\r\n      .subscribe((query: string) => {\r\n        this.messages.forEach(msg => {\r\n          msg.localizationParams.queryString = query\r\n        });\r\n      });\r\n\r\n    this.alerts.getMessages().pipe(\r\n      takeUntil(this.destroy$))\r\n      .subscribe((message: NotificationMessage) => {\r\n        message.localizationParams.queryString = this.wtwQueryService.defaultQueryString;\r\n        if (message.type === NotificationMessageType.ERROR) {\r\n          this.onError.emit(message.error);\r\n        }\r\n        // pushing only \"one of\" message in array, so screen is not spammed with messages\r\n        const existingMessage = this.messages.find(msg => msg.title === message.title\r\n          && msg.type === message.type\r\n          && message.body === msg.body\r\n          && JSON.stringify(msg.localizationParams) === JSON.stringify(message.localizationParams));\r\n        if (!existingMessage) {\r\n          this.messages.push(message);\r\n        }\r\n      });\r\n\r\n    if (this.configService.coreConfig.translateAppName) {\r\n      this.translate.get(\"APP_NAME\").pipe(\r\n        takeUntil(this.destroy$))\r\n        .subscribe((text: string) => {\r\n          this.configService.coreConfig.appName = text;\r\n        });\r\n    }\r\n  }\r\n\r\n  removeMessage(ix: number) {\r\n    this.messages.splice(ix, 1);\r\n  }\r\n\r\n  swapLanguages() {\r\n    this.tldSystem.swapSystemLanguages();\r\n  }\r\n\r\n  sourceLanguageChange(language: string) {\r\n    this.tldSystem.changeLanguage(language, this.switcherOptions.target.code);\r\n  }\r\n\r\n  systemChange(systemId: string) {\r\n    this.tldSystem.changeSystem(systemId);\r\n  }\r\n\r\n  targetLanguageChange(language: string) {\r\n    this.tldSystem.changeLanguage(this.switcherOptions.source.code, language);\r\n  }\r\n\r\n  translateButtonClick() {\r\n    if (this.translateFileService.translationFiles?.length > 0) {\r\n      this.translateFileService.translateButtonClick(this.activeSystemObj);\r\n    }\r\n    else {\r\n      this.translateTextService.onTranslateButtonClick();\r\n    }\r\n  }\r\n\r\n  removeMessagesOnClear() {\r\n    this.translateFileService.onClear()\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe(() => {\r\n        this.messages = [];\r\n      })\r\n\r\n    this.translateTextService.onClear()\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe(() => {\r\n        this.messages = [];\r\n      })\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.destroy$.next(null)\r\n    this.destroy$.complete();\r\n  }\r\n\r\n}\r\n","<div fxLayout=\"column\" class=\"h-100 tld-translate\" *ngIf=\"!showNoSystemsError\"\r\n  [ngClass.lt-md]=\"'tld-translate-tablet tld-default-border-bottom'\"\r\n  [ngClass.lt-sm]=\"'tld-translate-mobile tld-default-border-bottom'\"\r\n  [class.tld-translate-multiple-files-active]=\"isMultipleFilesActive\">\r\n  <div class=\"tld-translate-wrapper tld-default-border\" fxLayout=\"column\" fxFlex>\r\n    <div class=\"tld-translate-switcher-wrapper tld-default-border-bottom\">\r\n      <tld-translate-switcher *ngIf=\"switcherOptions && languageMenuVersion === languageMenuV1\"\r\n        [disabled]=\"actionButtonDisabled\" [isCollectionsActivated]=\"isCollectionsActivated\" [settings]=\"switcherOptions\"\r\n        [maxDisplayedLanguages]=\"maxDisplayedLanguages\" [showDomainsWithLanguageName]=\"showDomainsWithLanguageName\"\r\n        [buttonDisabled]=\"actionButtonDisabled\" [hideLangMenuLabels]=\"hideLangMenuLabels\"\r\n        (onDomainChange)=\"systemChange($event)\" (onActionClick)=\"translateButtonClick()\"\r\n        (onLanguageSwap)=\"swapLanguages()\" (onSourceLanguageChange)=\"sourceLanguageChange($event)\"\r\n        (onTargetLanguageChange)=\"targetLanguageChange($event)\" [loader]=\"actionButtonLoader\" [showTranslateButton]=\"showTranslateButton\">\r\n      </tld-translate-switcher>\r\n      <tld-translation-system-picker *ngIf=\"languageMenuVersion===languageMenuV2\"\r\n        [isCollectionsActivated]=\"isCollectionsActivated\"></tld-translation-system-picker>\r\n    </div>\r\n    <lib-tld-notification-message [inline]=\"true\" *ngFor=\"let message of messages; let ix = index\" [message]=\"message\"\r\n      (closeClicked)=\"removeMessage(ix)\">\r\n    </lib-tld-notification-message>\r\n    <div fxFlex style=\"position: relative;\">\r\n      <tld-translate-body fxFlex fxLayoutAlign=\"column\" [attr.source-language]=\"sourceLanguage\"\r\n        [attr.target-language]=\"targetLanguage\"></tld-translate-body>\r\n      <tld-translation-system-picker-dropdown [ngClass.xs]=\"'mobile'\" *ngIf=\"systemPickerDropdownVisible\">\r\n      </tld-translation-system-picker-dropdown>\r\n    </div>\r\n  </div>\r\n</div>\r\n\r\n<lib-tld-notification-message *ngIf=\"showNoSystemsError\" [message]=\"noSystemsError\">\r\n</lib-tld-notification-message>\r\n"]}
|