@tilde-nlp/ngx-translate 2.0.3-deepl-2 → 2.0.3-deepl-4
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/modules/tld-text/components/highlight-tree/highlight-tree.component.mjs +4 -3
- package/esm2020/lib/modules/tld-text/services/api/tld-translate-text-api.service.mjs +58 -56
- package/fesm2015/tilde-nlp-ngx-translate.mjs +61 -58
- package/fesm2015/tilde-nlp-ngx-translate.mjs.map +1 -1
- package/fesm2020/tilde-nlp-ngx-translate.mjs +60 -57
- package/fesm2020/tilde-nlp-ngx-translate.mjs.map +1 -1
- package/lib/modules/tld-text/components/highlight-tree/highlight-tree.component.d.ts +2 -0
- package/package.json +1 -1
- package/src/assets/webcomponent/tld-translate.js +1 -1
- package/tilde-nlp-ngx-translate-2.0.3-deepl-4.tgz +0 -0
- package/tilde-nlp-ngx-translate-2.0.3-deepl-2.tgz +0 -0
|
@@ -13,6 +13,7 @@ export class HighlightTreeComponent {
|
|
|
13
13
|
this.highlightService = highlightService;
|
|
14
14
|
this.correctionsEnabled = true;
|
|
15
15
|
this.onReplace = new EventEmitter();
|
|
16
|
+
this.wordType = HighlightTreeType.WORD;
|
|
16
17
|
}
|
|
17
18
|
mouseEnter(event) {
|
|
18
19
|
this.onMouseEvent(event, this.isSource, true);
|
|
@@ -87,10 +88,10 @@ export class HighlightTreeComponent {
|
|
|
87
88
|
}
|
|
88
89
|
}
|
|
89
90
|
HighlightTreeComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: HighlightTreeComponent, deps: [{ token: i1.TldHighlightService }], target: i0.ɵɵFactoryTarget.Component });
|
|
90
|
-
HighlightTreeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: HighlightTreeComponent, selector: "tld-highlight-tree", inputs: { tree: "tree", isSource: "isSource", correctionsEnabled: "correctionsEnabled", highlight: "highlight", gramCheck: "gramCheck", selectSentence: "selectSentence" }, outputs: { onReplace: "onReplace" }, ngImport: i0, template: "<ng-template #highlightTree let-tree=\"tree\">\r\n <ng-container *ngIf=\"!tree.children\">\r\n <ng-container *ngIf=\"tree.text\">\r\n <ng-container *ngIf=\"tree.grammarMeta && gramCheck\">\r\n <mat-menu #menu=\"matMenu\" class=\"grammar-check-menu\">\r\n <div class=\"title\">\r\n {{'GRAMMAR_CHECK_MENU.TITLE' | translate}}\r\n </div>\r\n <div *ngFor=\"let replacement of tree.grammarMeta.replacements\">\r\n <button mat-button color=\"accent\" (click)=\"replace(tree, replacement)\">\r\n {{replacement}}\r\n </button>\r\n </div>\r\n </mat-menu>\r\n <span #menuTrigger=\"matMenuTrigger\" [matMenuTriggerFor]=\"menu\" class=\"{{tree.class}}\"\r\n [innerHTML]=\"tree.text\" (mouseenter)=\"mouseEnter($event)\" (click)=\"gramCheckMenu(tree, menuTrigger)\"\r\n (mouseleave)=\"mouseLeave($event)\"></span>\r\n\r\n </ng-container>\r\n <ng-container *ngIf=\"!(tree.grammarMeta && gramCheck)\">\r\n <span class=\"{{tree.class}}\" [innerHTML]=\"tree.text\" (mouseenter)=\"mouseEnter($event)\"\r\n (mouseleave)=\"mouseLeave($event)\"></span>\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngIf=\"!tree.text\">\r\n <br>\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngIf=\"tree.children\">\r\n <span [ngClass]=\"{'selected-sentence': isSelectedSentence(tree)}\" class=\"highlight-tree-child-wrapper {{tree.class}}\"\r\n (mouseenter)=\"mouseEnter($event)\" (mouseleave)=\"mouseLeave($event)\" (click)=\"parentClick(tree)\">\r\n <ng-template ngFor let-child [ngForOf]=\"tree.children\">\r\n <ng-template [ngTemplateOutlet]=\"highlightTree\" [ngTemplateOutletContext]=\"{ tree: child }\">\r\n </ng-template>\r\n </ng-template>\r\n </span>\r\n </ng-container>\r\n</ng-template>\r\n\r\n\r\n\r\n<div *ngIf=\"tree\" class=\"tld-highlight-tree\">\r\n <ng-template [ngTemplateOutlet]=\"highlightTree\" [ngTemplateOutletContext]=\"{ tree: tree }\"></ng-template>\r\n</div
|
|
91
|
+
HighlightTreeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: HighlightTreeComponent, selector: "tld-highlight-tree", inputs: { tree: "tree", isSource: "isSource", correctionsEnabled: "correctionsEnabled", highlight: "highlight", gramCheck: "gramCheck", selectSentence: "selectSentence" }, outputs: { onReplace: "onReplace" }, ngImport: i0, template: "<ng-template #highlightTree let-tree=\"tree\">\r\n <ng-container *ngIf=\"!tree.children\">\r\n <ng-container *ngIf=\"tree.text\">\r\n <ng-container *ngIf=\"tree.grammarMeta && gramCheck\">\r\n <mat-menu #menu=\"matMenu\" class=\"grammar-check-menu\">\r\n <div class=\"title\">\r\n {{'GRAMMAR_CHECK_MENU.TITLE' | translate}}\r\n </div>\r\n <div *ngFor=\"let replacement of tree.grammarMeta.replacements\">\r\n <button mat-button color=\"accent\" (click)=\"replace(tree, replacement)\">\r\n {{replacement}}\r\n </button>\r\n </div>\r\n </mat-menu>\r\n <span #menuTrigger=\"matMenuTrigger\" [matMenuTriggerFor]=\"menu\" class=\"{{tree.class}}\"\r\n [innerHTML]=\"tree.text\" (mouseenter)=\"mouseEnter($event)\" (click)=\"gramCheckMenu(tree, menuTrigger)\"\r\n (mouseleave)=\"mouseLeave($event)\"></span>\r\n\r\n </ng-container>\r\n <ng-container *ngIf=\"!(tree.grammarMeta && gramCheck)\">\r\n <span class=\"{{tree.class}}\" [innerHTML]=\"tree.text\" (mouseenter)=\"mouseEnter($event)\"\r\n (mouseleave)=\"mouseLeave($event)\"></span>\r\n </ng-container>\r\n </ng-container>\r\n <!-- If text is empty and type is 'word', we should not break line. -->\r\n <ng-container *ngIf=\"!tree.text && tree.type !== wordType\">\r\n <br>\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngIf=\"tree.children\">\r\n <span [ngClass]=\"{'selected-sentence': isSelectedSentence(tree)}\" class=\"highlight-tree-child-wrapper {{tree.class}}\"\r\n (mouseenter)=\"mouseEnter($event)\" (mouseleave)=\"mouseLeave($event)\" (click)=\"parentClick(tree)\">\r\n <ng-template ngFor let-child [ngForOf]=\"tree.children\">\r\n <ng-template [ngTemplateOutlet]=\"highlightTree\" [ngTemplateOutletContext]=\"{ tree: child }\">\r\n </ng-template>\r\n </ng-template>\r\n </span>\r\n </ng-container>\r\n</ng-template>\r\n\r\n\r\n\r\n<div *ngIf=\"tree\" class=\"tld-highlight-tree\">\r\n <ng-template [ngTemplateOutlet]=\"highlightTree\" [ngTemplateOutletContext]=\"{ tree: tree }\"></ng-template>\r\n</div>\r\n", styles: ["span{white-space:pre-wrap}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i3.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i4.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { kind: "directive", type: i4.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }, { 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: "pipe", type: i6.TranslatePipe, name: "translate" }] });
|
|
91
92
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: HighlightTreeComponent, decorators: [{
|
|
92
93
|
type: Component,
|
|
93
|
-
args: [{ selector: 'tld-highlight-tree', template: "<ng-template #highlightTree let-tree=\"tree\">\r\n <ng-container *ngIf=\"!tree.children\">\r\n <ng-container *ngIf=\"tree.text\">\r\n <ng-container *ngIf=\"tree.grammarMeta && gramCheck\">\r\n <mat-menu #menu=\"matMenu\" class=\"grammar-check-menu\">\r\n <div class=\"title\">\r\n {{'GRAMMAR_CHECK_MENU.TITLE' | translate}}\r\n </div>\r\n <div *ngFor=\"let replacement of tree.grammarMeta.replacements\">\r\n <button mat-button color=\"accent\" (click)=\"replace(tree, replacement)\">\r\n {{replacement}}\r\n </button>\r\n </div>\r\n </mat-menu>\r\n <span #menuTrigger=\"matMenuTrigger\" [matMenuTriggerFor]=\"menu\" class=\"{{tree.class}}\"\r\n [innerHTML]=\"tree.text\" (mouseenter)=\"mouseEnter($event)\" (click)=\"gramCheckMenu(tree, menuTrigger)\"\r\n (mouseleave)=\"mouseLeave($event)\"></span>\r\n\r\n </ng-container>\r\n <ng-container *ngIf=\"!(tree.grammarMeta && gramCheck)\">\r\n <span class=\"{{tree.class}}\" [innerHTML]=\"tree.text\" (mouseenter)=\"mouseEnter($event)\"\r\n (mouseleave)=\"mouseLeave($event)\"></span>\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngIf=\"!tree.text\">\r\n <br>\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngIf=\"tree.children\">\r\n <span [ngClass]=\"{'selected-sentence': isSelectedSentence(tree)}\" class=\"highlight-tree-child-wrapper {{tree.class}}\"\r\n (mouseenter)=\"mouseEnter($event)\" (mouseleave)=\"mouseLeave($event)\" (click)=\"parentClick(tree)\">\r\n <ng-template ngFor let-child [ngForOf]=\"tree.children\">\r\n <ng-template [ngTemplateOutlet]=\"highlightTree\" [ngTemplateOutletContext]=\"{ tree: child }\">\r\n </ng-template>\r\n </ng-template>\r\n </span>\r\n </ng-container>\r\n</ng-template>\r\n\r\n\r\n\r\n<div *ngIf=\"tree\" class=\"tld-highlight-tree\">\r\n <ng-template [ngTemplateOutlet]=\"highlightTree\" [ngTemplateOutletContext]=\"{ tree: tree }\"></ng-template>\r\n</div
|
|
94
|
+
args: [{ selector: 'tld-highlight-tree', template: "<ng-template #highlightTree let-tree=\"tree\">\r\n <ng-container *ngIf=\"!tree.children\">\r\n <ng-container *ngIf=\"tree.text\">\r\n <ng-container *ngIf=\"tree.grammarMeta && gramCheck\">\r\n <mat-menu #menu=\"matMenu\" class=\"grammar-check-menu\">\r\n <div class=\"title\">\r\n {{'GRAMMAR_CHECK_MENU.TITLE' | translate}}\r\n </div>\r\n <div *ngFor=\"let replacement of tree.grammarMeta.replacements\">\r\n <button mat-button color=\"accent\" (click)=\"replace(tree, replacement)\">\r\n {{replacement}}\r\n </button>\r\n </div>\r\n </mat-menu>\r\n <span #menuTrigger=\"matMenuTrigger\" [matMenuTriggerFor]=\"menu\" class=\"{{tree.class}}\"\r\n [innerHTML]=\"tree.text\" (mouseenter)=\"mouseEnter($event)\" (click)=\"gramCheckMenu(tree, menuTrigger)\"\r\n (mouseleave)=\"mouseLeave($event)\"></span>\r\n\r\n </ng-container>\r\n <ng-container *ngIf=\"!(tree.grammarMeta && gramCheck)\">\r\n <span class=\"{{tree.class}}\" [innerHTML]=\"tree.text\" (mouseenter)=\"mouseEnter($event)\"\r\n (mouseleave)=\"mouseLeave($event)\"></span>\r\n </ng-container>\r\n </ng-container>\r\n <!-- If text is empty and type is 'word', we should not break line. -->\r\n <ng-container *ngIf=\"!tree.text && tree.type !== wordType\">\r\n <br>\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngIf=\"tree.children\">\r\n <span [ngClass]=\"{'selected-sentence': isSelectedSentence(tree)}\" class=\"highlight-tree-child-wrapper {{tree.class}}\"\r\n (mouseenter)=\"mouseEnter($event)\" (mouseleave)=\"mouseLeave($event)\" (click)=\"parentClick(tree)\">\r\n <ng-template ngFor let-child [ngForOf]=\"tree.children\">\r\n <ng-template [ngTemplateOutlet]=\"highlightTree\" [ngTemplateOutletContext]=\"{ tree: child }\">\r\n </ng-template>\r\n </ng-template>\r\n </span>\r\n </ng-container>\r\n</ng-template>\r\n\r\n\r\n\r\n<div *ngIf=\"tree\" class=\"tld-highlight-tree\">\r\n <ng-template [ngTemplateOutlet]=\"highlightTree\" [ngTemplateOutletContext]=\"{ tree: tree }\"></ng-template>\r\n</div>\r\n", styles: ["span{white-space:pre-wrap}\n"] }]
|
|
94
95
|
}], ctorParameters: function () { return [{ type: i1.TldHighlightService }]; }, propDecorators: { tree: [{
|
|
95
96
|
type: Input
|
|
96
97
|
}], isSource: [{
|
|
@@ -106,4 +107,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
106
107
|
}], onReplace: [{
|
|
107
108
|
type: Output
|
|
108
109
|
}] } });
|
|
109
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"highlight-tree.component.js","sourceRoot":"","sources":["../../../../../../../../projects/tld-translate/src/lib/modules/tld-text/components/highlight-tree/highlight-tree.component.ts","../../../../../../../../projects/tld-translate/src/lib/modules/tld-text/components/highlight-tree/highlight-tree.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAIvE,OAAO,EAAE,eAAe,EAAE,MAAM,qCAAqC,CAAC;AACtE,OAAO,EAAE,iBAAiB,EAAE,MAAM,wCAAwC,CAAC;;;;;;;;AAQ3E,MAAM,OAAO,sBAAsB;IAUjC,YAA6B,gBAAqC;QAArC,qBAAgB,GAAhB,gBAAgB,CAAqB;QANzD,uBAAkB,GAAY,IAAI,CAAC;QAIlC,cAAS,GAA2C,IAAI,YAAY,EAAE,CAAC;IAEX,CAAC;IAEvE,UAAU,CAAC,KAAiB;QAC1B,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC;IAChD,CAAC;IAED,UAAU,CAAC,KAAiB;QAC1B,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,IAAI,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;IACjD,CAAC;IAED,aAAa,CAAC,IAAoB,EAAE,WAA4B;QAC9D,IAAI,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,SAAS,EAAE;YACtC,WAAW,CAAC,QAAQ,EAAE,CAAC;SACxB;IACH,CAAC;IAED,OAAO,CAAC,IAAoB,EAAE,WAAmB;QAC/C,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC;YAClB,KAAK,EAAE,IAAI,CAAC,WAAW,CAAC,KAAK;YAC7B,WAAW,EAAE,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,IAAI,EAAE,WAAW;YACvD,WAAW,EAAE,WAAW;YACxB,OAAO,EAAE,IAAI,CAAC,WAAW,CAAC,OAAO;SAClC,CAAC,CAAC;IACL,CAAC;IAED,WAAW,CAAC,IAAoB;QAC9B,IAAI,IAAI,CAAC,cAAc,IAAI,IAAI,CAAC,IAAI,KAAK,iBAAiB,CAAC,QAAQ,EAAE;YACnE,IAAI,CAAC,gBAAgB,CAAC,4BAA4B,CAAC,EAAE,WAAW,EAAE,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,IAAI,EAAE,WAAW,EAAE,UAAU,EAAE,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;SACrJ;IACH,CAAC;IAED,kBAAkB,CAAC,IAAoB;QACrC,OAAO,IAAI,CAAC,cAAc,IAAI,IAAI,CAAC,IAAI,KAAK,iBAAiB,CAAC,QAAQ;eACjE,IAAI,CAAC,gBAAgB,CAAC,sBAAsB,EAAE,WAAW,KAAK,CAAC,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,IAAI,EAAE,WAAW,CAAC;eAC1G,IAAI,CAAC,gBAAgB,CAAC,sBAAsB,CAAC,UAAU,CAAC,QAAQ,EAAE,KAAK,IAAI,CAAC,SAAS,CAAC;IAC7F,CAAC;IAEO,YAAY,CAAC,KAAiB,EAAE,QAAiB,EAAE,YAAqB;QAC9E,MAAM,OAAO,GAAG,KAAK,CAAC,MAAiB,CAAC;QACxC,IAAI,mBAAmB,GAAG,CAAC,OAAO,CAAC,CAAC;QAEpC,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,IAAI,kBAA0B,CAAC;YAC/B,IAAI,QAAQ,EAAE;gBACZ,kBAAkB,GAAG,eAAe,CAAC,oBAAoB,CAAC;aAC3D;iBACI;gBACH,kBAAkB,GAAG,eAAe,CAAC,oBAAoB,CAAC;aAC3D;YACD,OAAO,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,SAAiB,EAAE,EAAE;gBAC9C,IAAI,SAAS,CAAC,QAAQ,CAAC,eAAe,CAAC,YAAY,CAAC,EAAE;oBACpD,MAAM,aAAa,GAAG,IAAI,kBAAkB,KAAK,SAAS,CAAC,OAAO,CAAC,eAAe,CAAC,YAAY,EAAE,eAAe,CAAC,SAAS,CAAC,EAAE,CAAC;oBAC9H,mBAAmB,GAAG,mBAAmB,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,gBAAgB,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC;iBACxG;YACH,CAAC,CAAC,CAAC;SACJ;QAED,mBAAmB,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE;YACtC,kEAAkE;YAClE,IAAI,MAAM,GAAG,IAAI,CAAC,sBAAsB,CAAC,OAAO,CAAC,CAAC;YAElD,IAAI,YAAY,EAAE;gBAChB,OAAO,CAAC,SAAS,CAAC,GAAG,CAAC,eAAe,CAAC,gBAAgB,CAAC,CAAC;gBACxD,MAAM,EAAE,SAAS,CAAC,GAAG,CAAC,eAAe,CAAC,gBAAgB,CAAC,CAAC;aACzD;iBACI;gBACH,OAAO,CAAC,SAAS,CAAC,MAAM,CAAC,eAAe,CAAC,gBAAgB,CAAC,CAAC;gBAC3D,MAAM,EAAE,SAAS,CAAC,MAAM,CAAC,eAAe,CAAC,gBAAgB,CAAC,CAAC;aAC5D;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,sBAAsB,CAAC,OAAY;QACzC,MAAM,mBAAmB,GAAG,CAAC,CAAC;QAC9B,IAAI,MAAM,GAAG,OAAO,CAAC,aAAa,CAAC;QACnC,KAAK,IAAI,KAAK,GAAG,CAAC,EAAE,KAAK,GAAG,mBAAmB,EAAE,KAAK,EAAE,EAAE;YACxD,IAAG,MAAM,CAAC,SAAS,CAAC,QAAQ,CAAC,eAAe,CAAC,aAAa,CAAC,EAAC;gBAC1D,OAAO,MAAM,CAAC;aACf;YACD,MAAM,GAAG,MAAM,CAAC,aAAa,CAAC;SAC/B;QACD,OAAO,IAAI,CAAC;IACd,CAAC;;mHA5FU,sBAAsB;uGAAtB,sBAAsB,2QCbnC,syEA2CM;2FD9BO,sBAAsB;kBALlC,SAAS;+BACE,oBAAoB;0GAMrB,IAAI;sBAAZ,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,kBAAkB;sBAA1B,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACI,SAAS;sBAAlB,MAAM","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\r\nimport { MatMenuTrigger } from '@angular/material/menu';\r\nimport { TldHighlightService } from '../../../tld-common/services';\r\nimport { IGrammarCheckReplacement } from '../../models/grammar-check-replacement.model';\r\nimport { HighlightParams } from '../../models/highlight-params.model';\r\nimport { HighlightTreeType } from '../../models/highlight-tree-type.model';\r\nimport { IHighlightTree } from '../../models/highlight-tree.model';\r\n\r\n@Component({\r\n  selector: 'tld-highlight-tree',\r\n  templateUrl: './highlight-tree.component.html',\r\n  styleUrls: ['./highlight-tree.component.scss']\r\n})\r\nexport class HighlightTreeComponent {\r\n\r\n  @Input() tree: IHighlightTree;\r\n  @Input() isSource: boolean;\r\n  @Input() correctionsEnabled: boolean = true;\r\n  @Input() highlight: boolean;\r\n  @Input() gramCheck: boolean;\r\n  @Input() selectSentence: boolean;\r\n  @Output() onReplace: EventEmitter<IGrammarCheckReplacement> = new EventEmitter();\r\n\r\n  constructor(private readonly highlightService: TldHighlightService) { }\r\n\r\n  mouseEnter(event: MouseEvent) {\r\n    this.onMouseEvent(event, this.isSource, true);\r\n  }\r\n\r\n  mouseLeave(event: MouseEvent) {\r\n    this.onMouseEvent(event, this.isSource, false);\r\n  }\r\n\r\n  gramCheckMenu(tree: IHighlightTree, menuTrigger?: MatMenuTrigger) {\r\n    if (tree.grammarMeta && this.gramCheck) {\r\n      menuTrigger.openMenu();\r\n    }\r\n  }\r\n\r\n  replace(tree: IHighlightTree, replacement: string) {\r\n    this.onReplace.next({\r\n      endIx: tree.grammarMeta.endIx,\r\n      paragraphIx: tree.paragraphIx ?? tree.root?.paragraphIx,\r\n      replacement: replacement,\r\n      startIx: tree.grammarMeta.startIx\r\n    });\r\n  }\r\n\r\n  parentClick(tree: IHighlightTree) {\r\n    if (this.selectSentence && tree.type === HighlightTreeType.SENTENCE) {\r\n      this.highlightService.changeSelectedTargetSentence({ paragraphIx: tree.paragraphIx ?? tree.root?.paragraphIx, sentenceIx: Number(tree.elementId) });\r\n    }\r\n  }\r\n\r\n  isSelectedSentence(tree: IHighlightTree) {\r\n    return this.selectSentence && tree.type === HighlightTreeType.SENTENCE\r\n      && this.highlightService.selectedTargetSentence?.paragraphIx === (tree.paragraphIx ?? tree.root?.paragraphIx)\r\n      && this.highlightService.selectedTargetSentence.sentenceIx.toString() === tree.elementId;\r\n  }\r\n\r\n  private onMouseEvent(event: MouseEvent, isSource: boolean, isMouseEnter: boolean): void {\r\n    const element = event.target as Element;\r\n    let elementWithSiblings = [element];\r\n\r\n    if (this.highlight) {\r\n      let siblingParentClass: string;\r\n      if (isSource) {\r\n        siblingParentClass = HighlightParams.targetHighlightClass;\r\n      }\r\n      else {\r\n        siblingParentClass = HighlightParams.sourceHighlightClass;\r\n      }\r\n      element.classList.forEach((className: string) => {\r\n        if (className.includes(HighlightParams.siblingClass)) {\r\n          const querySelector = `.${siblingParentClass} .${className.replace(HighlightParams.siblingClass, HighlightParams.wordClass)}`;\r\n          elementWithSiblings = elementWithSiblings.concat(Array.from(document.querySelectorAll(querySelector)));\r\n        }\r\n      });\r\n    }\r\n\r\n    elementWithSiblings.forEach((element) => {\r\n      // necessary to highlight also sibling sentence, not only sibling.\r\n      let parent = this.findWordParentSentence(element);\r\n\r\n      if (isMouseEnter) {\r\n        element.classList.add(HighlightParams.hoveredClassName);\r\n        parent?.classList.add(HighlightParams.hoveredClassName);\r\n      }\r\n      else {\r\n        element.classList.remove(HighlightParams.hoveredClassName);\r\n        parent?.classList.remove(HighlightParams.hoveredClassName);\r\n      }\r\n    });\r\n  }\r\n\r\n  private findWordParentSentence(element: any){\r\n    const maxDistanceToParent = 2;\r\n    let parent = element.parentElement;\r\n    for (let index = 0; index < maxDistanceToParent; index++) {\r\n      if(parent.classList.contains(HighlightParams.sentenceClass)){\r\n        return parent;\r\n      }\r\n      parent = parent.parentElement;\r\n    }\r\n    return null;\r\n  }\r\n}\r\n","<ng-template #highlightTree let-tree=\"tree\">\r\n    <ng-container *ngIf=\"!tree.children\">\r\n        <ng-container *ngIf=\"tree.text\">\r\n            <ng-container *ngIf=\"tree.grammarMeta && gramCheck\">\r\n                <mat-menu #menu=\"matMenu\" class=\"grammar-check-menu\">\r\n                    <div class=\"title\">\r\n                        {{'GRAMMAR_CHECK_MENU.TITLE' | translate}}\r\n                    </div>\r\n                    <div *ngFor=\"let replacement of tree.grammarMeta.replacements\">\r\n                        <button mat-button color=\"accent\" (click)=\"replace(tree, replacement)\">\r\n                            {{replacement}}\r\n                        </button>\r\n                    </div>\r\n                </mat-menu>\r\n                <span #menuTrigger=\"matMenuTrigger\" [matMenuTriggerFor]=\"menu\" class=\"{{tree.class}}\"\r\n                    [innerHTML]=\"tree.text\" (mouseenter)=\"mouseEnter($event)\" (click)=\"gramCheckMenu(tree, menuTrigger)\"\r\n                    (mouseleave)=\"mouseLeave($event)\"></span>\r\n\r\n            </ng-container>\r\n            <ng-container *ngIf=\"!(tree.grammarMeta && gramCheck)\">\r\n                <span class=\"{{tree.class}}\" [innerHTML]=\"tree.text\" (mouseenter)=\"mouseEnter($event)\"\r\n                    (mouseleave)=\"mouseLeave($event)\"></span>\r\n            </ng-container>\r\n        </ng-container>\r\n        <ng-container *ngIf=\"!tree.text\">\r\n            <br>\r\n        </ng-container>\r\n    </ng-container>\r\n    <ng-container *ngIf=\"tree.children\">\r\n        <span [ngClass]=\"{'selected-sentence': isSelectedSentence(tree)}\" class=\"highlight-tree-child-wrapper {{tree.class}}\"\r\n            (mouseenter)=\"mouseEnter($event)\" (mouseleave)=\"mouseLeave($event)\" (click)=\"parentClick(tree)\">\r\n            <ng-template ngFor let-child [ngForOf]=\"tree.children\">\r\n                <ng-template [ngTemplateOutlet]=\"highlightTree\" [ngTemplateOutletContext]=\"{ tree: child }\">\r\n                </ng-template>\r\n            </ng-template>\r\n        </span>\r\n    </ng-container>\r\n</ng-template>\r\n\r\n\r\n\r\n<div *ngIf=\"tree\" class=\"tld-highlight-tree\">\r\n    <ng-template [ngTemplateOutlet]=\"highlightTree\" [ngTemplateOutletContext]=\"{ tree: tree }\"></ng-template>\r\n</div>"]}
|
|
110
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"highlight-tree.component.js","sourceRoot":"","sources":["../../../../../../../../projects/tld-translate/src/lib/modules/tld-text/components/highlight-tree/highlight-tree.component.ts","../../../../../../../../projects/tld-translate/src/lib/modules/tld-text/components/highlight-tree/highlight-tree.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\r\nimport { MatMenuTrigger } from '@angular/material/menu';\r\nimport { TldHighlightService } from '../../../tld-common/services';\r\nimport { IGrammarCheckReplacement } from '../../models/grammar-check-replacement.model';\r\nimport { HighlightParams } from '../../models/highlight-params.model';\r\nimport { HighlightTreeType } from '../../models/highlight-tree-type.model';\r\nimport { IHighlightTree } from '../../models/highlight-tree.model';\r\n\r\n@Component({\r\n  selector: 'tld-highlight-tree',\r\n  templateUrl: './highlight-tree.component.html',\r\n  styleUrls: ['./highlight-tree.component.scss']\r\n})\r\nexport class HighlightTreeComponent {\r\n\r\n  @Input() tree: IHighlightTree;\r\n  @Input() isSource: boolean;\r\n  @Input() correctionsEnabled: boolean = true;\r\n  @Input() highlight: boolean;\r\n  @Input() gramCheck: boolean;\r\n  @Input() selectSentence: boolean;\r\n  @Output() onReplace: EventEmitter<IGrammarCheckReplacement> = new EventEmitter();\r\n\r\n  readonly wordType = HighlightTreeType.WORD;\r\n\r\n  constructor(private readonly highlightService: TldHighlightService) { }\r\n\r\n  mouseEnter(event: MouseEvent) {\r\n    this.onMouseEvent(event, this.isSource, true);\r\n  }\r\n\r\n  mouseLeave(event: MouseEvent) {\r\n    this.onMouseEvent(event, this.isSource, false);\r\n  }\r\n\r\n  gramCheckMenu(tree: IHighlightTree, menuTrigger?: MatMenuTrigger) {\r\n    if (tree.grammarMeta && this.gramCheck) {\r\n      menuTrigger.openMenu();\r\n    }\r\n  }\r\n\r\n  replace(tree: IHighlightTree, replacement: string) {\r\n    this.onReplace.next({\r\n      endIx: tree.grammarMeta.endIx,\r\n      paragraphIx: tree.paragraphIx ?? tree.root?.paragraphIx,\r\n      replacement: replacement,\r\n      startIx: tree.grammarMeta.startIx\r\n    });\r\n  }\r\n\r\n  parentClick(tree: IHighlightTree) {\r\n    if (this.selectSentence && tree.type === HighlightTreeType.SENTENCE) {\r\n      this.highlightService.changeSelectedTargetSentence({ paragraphIx: tree.paragraphIx ?? tree.root?.paragraphIx, sentenceIx: Number(tree.elementId) });\r\n    }\r\n  }\r\n\r\n  isSelectedSentence(tree: IHighlightTree) {\r\n    return this.selectSentence && tree.type === HighlightTreeType.SENTENCE\r\n      && this.highlightService.selectedTargetSentence?.paragraphIx === (tree.paragraphIx ?? tree.root?.paragraphIx)\r\n      && this.highlightService.selectedTargetSentence.sentenceIx.toString() === tree.elementId;\r\n  }\r\n\r\n  private onMouseEvent(event: MouseEvent, isSource: boolean, isMouseEnter: boolean): void {\r\n    const element = event.target as Element;\r\n    let elementWithSiblings = [element];\r\n\r\n    if (this.highlight) {\r\n      let siblingParentClass: string;\r\n      if (isSource) {\r\n        siblingParentClass = HighlightParams.targetHighlightClass;\r\n      }\r\n      else {\r\n        siblingParentClass = HighlightParams.sourceHighlightClass;\r\n      }\r\n      element.classList.forEach((className: string) => {\r\n        if (className.includes(HighlightParams.siblingClass)) {\r\n          const querySelector = `.${siblingParentClass} .${className.replace(HighlightParams.siblingClass, HighlightParams.wordClass)}`;\r\n          elementWithSiblings = elementWithSiblings.concat(Array.from(document.querySelectorAll(querySelector)));\r\n        }\r\n      });\r\n    }\r\n\r\n    elementWithSiblings.forEach((element) => {\r\n      // necessary to highlight also sibling sentence, not only sibling.\r\n      let parent = this.findWordParentSentence(element);\r\n\r\n      if (isMouseEnter) {\r\n        element.classList.add(HighlightParams.hoveredClassName);\r\n        parent?.classList.add(HighlightParams.hoveredClassName);\r\n      }\r\n      else {\r\n        element.classList.remove(HighlightParams.hoveredClassName);\r\n        parent?.classList.remove(HighlightParams.hoveredClassName);\r\n      }\r\n    });\r\n  }\r\n\r\n  private findWordParentSentence(element: any){\r\n    const maxDistanceToParent = 2;\r\n    let parent = element.parentElement;\r\n    for (let index = 0; index < maxDistanceToParent; index++) {\r\n      if(parent.classList.contains(HighlightParams.sentenceClass)){\r\n        return parent;\r\n      }\r\n      parent = parent.parentElement;\r\n    }\r\n    return null;\r\n  }\r\n}\r\n","<ng-template #highlightTree let-tree=\"tree\">\r\n    <ng-container *ngIf=\"!tree.children\">\r\n        <ng-container *ngIf=\"tree.text\">\r\n            <ng-container *ngIf=\"tree.grammarMeta && gramCheck\">\r\n                <mat-menu #menu=\"matMenu\" class=\"grammar-check-menu\">\r\n                    <div class=\"title\">\r\n                        {{'GRAMMAR_CHECK_MENU.TITLE' | translate}}\r\n                    </div>\r\n                    <div *ngFor=\"let replacement of tree.grammarMeta.replacements\">\r\n                        <button mat-button color=\"accent\" (click)=\"replace(tree, replacement)\">\r\n                            {{replacement}}\r\n                        </button>\r\n                    </div>\r\n                </mat-menu>\r\n                <span #menuTrigger=\"matMenuTrigger\" [matMenuTriggerFor]=\"menu\" class=\"{{tree.class}}\"\r\n                    [innerHTML]=\"tree.text\" (mouseenter)=\"mouseEnter($event)\" (click)=\"gramCheckMenu(tree, menuTrigger)\"\r\n                    (mouseleave)=\"mouseLeave($event)\"></span>\r\n\r\n            </ng-container>\r\n            <ng-container *ngIf=\"!(tree.grammarMeta && gramCheck)\">\r\n                <span class=\"{{tree.class}}\" [innerHTML]=\"tree.text\" (mouseenter)=\"mouseEnter($event)\"\r\n                    (mouseleave)=\"mouseLeave($event)\"></span>\r\n            </ng-container>\r\n        </ng-container>\r\n        <!-- If text is empty and type is 'word', we should not break line. -->\r\n        <ng-container *ngIf=\"!tree.text && tree.type !== wordType\">\r\n            <br>\r\n        </ng-container>\r\n    </ng-container>\r\n    <ng-container *ngIf=\"tree.children\">\r\n        <span [ngClass]=\"{'selected-sentence': isSelectedSentence(tree)}\" class=\"highlight-tree-child-wrapper {{tree.class}}\"\r\n            (mouseenter)=\"mouseEnter($event)\" (mouseleave)=\"mouseLeave($event)\" (click)=\"parentClick(tree)\">\r\n            <ng-template ngFor let-child [ngForOf]=\"tree.children\">\r\n                <ng-template [ngTemplateOutlet]=\"highlightTree\" [ngTemplateOutletContext]=\"{ tree: child }\">\r\n                </ng-template>\r\n            </ng-template>\r\n        </span>\r\n    </ng-container>\r\n</ng-template>\r\n\r\n\r\n\r\n<div *ngIf=\"tree\" class=\"tld-highlight-tree\">\r\n    <ng-template [ngTemplateOutlet]=\"highlightTree\" [ngTemplateOutletContext]=\"{ tree: tree }\"></ng-template>\r\n</div>\r\n"]}
|
|
@@ -78,8 +78,10 @@ export class TldTranslateTextApiService {
|
|
|
78
78
|
getSentence(text, sentenceRanges, wordRanges, paragraphIx) {
|
|
79
79
|
const tree = { text: text, children: [], paragraphIx, type: HighlightTreeType.PARAGRAPH, root: null, originalText: text };
|
|
80
80
|
const words = [];
|
|
81
|
-
let wordRangeIx = -1;
|
|
82
81
|
let lastProcessedCharIx = 0;
|
|
82
|
+
const wordRangesWithIndex = wordRanges.map((range, ix) => {
|
|
83
|
+
return { range, ix };
|
|
84
|
+
});
|
|
83
85
|
sentenceRanges.forEach((sentenceRange, sentenceIx) => {
|
|
84
86
|
const sentenceString = this.getSentenceFromRange(sentenceRange, text);
|
|
85
87
|
tree.children[sentenceIx] = {
|
|
@@ -92,69 +94,69 @@ export class TldTranslateTextApiService {
|
|
|
92
94
|
};
|
|
93
95
|
const sentenceStartIx = sentenceRange[0];
|
|
94
96
|
const sentenceEndIx = sentenceStartIx + sentenceRange[1];
|
|
97
|
+
const filteredWordRangesWithIndex = wordRangesWithIndex.filter((rangeWithIndex) => {
|
|
98
|
+
const wordStartIx = rangeWithIndex.range[0];
|
|
99
|
+
// on purpose, check only start index, because sometimes end index is not correct and aligned with sentences.
|
|
100
|
+
return wordStartIx >= sentenceStartIx && wordStartIx <= sentenceEndIx;
|
|
101
|
+
});
|
|
95
102
|
let multipleWordWrapper;
|
|
96
|
-
|
|
97
|
-
const
|
|
98
|
-
const
|
|
99
|
-
const
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
// not a word.
|
|
107
|
-
const escaped = Common.escapeHtmlString(originalText);
|
|
108
|
-
tree.children[sentenceIx].children.push({
|
|
109
|
-
text: escaped,
|
|
110
|
-
type: HighlightTreeType.OTHER,
|
|
111
|
-
root: tree,
|
|
112
|
-
originalText
|
|
113
|
-
});
|
|
114
|
-
lastProcessedCharIx = wordStartIx;
|
|
115
|
-
}
|
|
116
|
-
const originalText = text.slice(wordStartIx, wordEndIx);
|
|
103
|
+
filteredWordRangesWithIndex.forEach((rangeWithIndex) => {
|
|
104
|
+
const wordRange = rangeWithIndex.range;
|
|
105
|
+
const wordStartIx = wordRange[0];
|
|
106
|
+
const wordEndIx = wordRange[1];
|
|
107
|
+
const nextWordStartIx = wordRanges[rangeWithIndex.ix + 1]?.[0];
|
|
108
|
+
if (lastProcessedCharIx < wordStartIx) {
|
|
109
|
+
// words are not together anymore.
|
|
110
|
+
multipleWordWrapper = null;
|
|
111
|
+
const originalText = text.slice(lastProcessedCharIx, wordStartIx);
|
|
112
|
+
// not a word.
|
|
117
113
|
const escaped = Common.escapeHtmlString(originalText);
|
|
118
|
-
|
|
119
|
-
const word = {
|
|
114
|
+
tree.children[sentenceIx].children.push({
|
|
120
115
|
text: escaped,
|
|
121
|
-
|
|
122
|
-
elementId: elementId,
|
|
123
|
-
type: originalText === "-" ? HighlightTreeType.HYPEN : HighlightTreeType.WORD,
|
|
116
|
+
type: HighlightTreeType.OTHER,
|
|
124
117
|
root: tree,
|
|
125
118
|
originalText
|
|
126
|
-
};
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
multipleWordWrapper
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
119
|
+
});
|
|
120
|
+
lastProcessedCharIx = wordStartIx;
|
|
121
|
+
}
|
|
122
|
+
const originalText = text.slice(wordStartIx, wordEndIx);
|
|
123
|
+
const escaped = Common.escapeHtmlString(originalText);
|
|
124
|
+
const elementId = `${paragraphIx}-${sentenceIx}-${rangeWithIndex.ix}`;
|
|
125
|
+
const word = {
|
|
126
|
+
text: escaped,
|
|
127
|
+
class: `${HighlightParams.wordClass} ${HighlightParams.wordClass}-${elementId}`,
|
|
128
|
+
elementId: elementId,
|
|
129
|
+
type: originalText === "-" ? HighlightTreeType.HYPEN : HighlightTreeType.WORD,
|
|
130
|
+
root: tree,
|
|
131
|
+
originalText
|
|
132
|
+
};
|
|
133
|
+
if (word.type === HighlightTreeType.HYPEN) {
|
|
134
|
+
multipleWordWrapper = null;
|
|
135
|
+
}
|
|
136
|
+
else if (wordEndIx === nextWordStartIx) {
|
|
137
|
+
if (!multipleWordWrapper) {
|
|
138
|
+
multipleWordWrapper = {
|
|
139
|
+
originalText: "",
|
|
140
|
+
root: tree,
|
|
141
|
+
text: "",
|
|
142
|
+
type: HighlightTreeType.WORD_WRAPPER,
|
|
143
|
+
children: [],
|
|
144
|
+
class: HighlightParams.multipleWordWrapper
|
|
145
|
+
};
|
|
146
|
+
tree.children[sentenceIx].children.push(multipleWordWrapper);
|
|
150
147
|
}
|
|
151
|
-
|
|
152
|
-
|
|
148
|
+
}
|
|
149
|
+
if (multipleWordWrapper) {
|
|
150
|
+
multipleWordWrapper.originalText += originalText;
|
|
151
|
+
multipleWordWrapper.text += escaped;
|
|
152
|
+
multipleWordWrapper.children.push(word);
|
|
153
153
|
}
|
|
154
154
|
else {
|
|
155
|
-
|
|
155
|
+
tree.children[sentenceIx].children.push(word);
|
|
156
156
|
}
|
|
157
|
-
|
|
157
|
+
words.push(word);
|
|
158
|
+
lastProcessedCharIx = wordEndIx;
|
|
159
|
+
});
|
|
158
160
|
});
|
|
159
161
|
return { tree, words };
|
|
160
162
|
}
|
|
@@ -184,4 +186,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
184
186
|
providedIn: 'root'
|
|
185
187
|
}]
|
|
186
188
|
}], ctorParameters: function () { return [{ type: i1.TldTermCollectionsService }, { type: i2.HttpClient }, { type: i3.TldTranslateConfigService }, { type: i3.TldAlertService }]; } });
|
|
187
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tld-translate-text-api.service.js","sourceRoot":"","sources":["../../../../../../../../projects/tld-translate/src/lib/modules/tld-text/services/api/tld-translate-text-api.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from '@angular/common/http';\r\nimport { Injectable } from '@angular/core';\r\nimport { Observable } from 'rxjs';\r\nimport { map } from 'rxjs/operators';\r\nimport { Common, ITldTranslateTextApiService, ITranslateParagraphRequestParams } from '../../../tld-common/models';\r\nimport { TldAlertService, TldTranslateConfigService } from '../../../tld-common/services';\r\nimport { TldTermCollectionsService } from '../../../tld-term/services';\r\nimport { IGetSentenceV1ResponseModel } from '../../models/get-sentence-v1-response.model';\r\nimport { HighlightParams } from '../../models/highlight-params.model';\r\nimport { HighlightTreeType } from '../../models/highlight-tree-type.model';\r\nimport { IHighlightTree } from '../../models/highlight-tree.model';\r\nimport { ITranslateParagraphResponseV1 } from '../../models/translate-paragraph-response-v1.model';\r\nimport { ITranslateParagraphResponse } from '../../models/translate-paragraph-response.model';\r\n\r\n@Injectable({\r\n  providedIn: 'root'\r\n})\r\nexport class TldTranslateTextApiService implements ITldTranslateTextApiService {\r\n\r\n  constructor(private readonly collectionService: TldTermCollectionsService,\r\n    private readonly http: HttpClient,\r\n    private readonly config: TldTranslateConfigService,\r\n    private readonly alerts: TldAlertService) { }\r\n\r\n  updateTranslation(options: string, systemID: string, text: string, translation: string) {\r\n    const url = this.config.textConfig.updateTranslationUrl;\r\n    const headers = Common.getAuthHeaders(this.config);\r\n    const params = {\r\n      appID: this.config.coreConfig.appId,\r\n      options,\r\n      systemID,\r\n      text,\r\n      translation\r\n    }\r\n    return this.http.post(url, params, { headers });\r\n  }\r\n\r\n  dictionaryTranslation(text: string, srcCode: string, trgCode: string) {\r\n    const authHeaders = Common.getAuthHeaders(this.config);\r\n    // TODO. Create type for params.\r\n    const params: any = {\r\n      word: text,\r\n      sourceLanguage: srcCode,\r\n      targetLanguage: trgCode\r\n    };\r\n\r\n    return this.http.get(this.config.textConfig.dictionaryUrl, { headers: authHeaders, params: params })\r\n  }\r\n\r\n  translateParagraph(requestParams: ITranslateParagraphRequestParams): Observable<ITranslateParagraphResponse> {\r\n    const headers = Common.getAuthHeaders(this.config);\r\n    // TODO. Create type for params.\r\n    const params: any = {\r\n      appID: this.config.coreConfig.appId,\r\n      options: \"widget=text,alignment,markSentences\",\r\n      systemID: requestParams.system.id,\r\n      text: requestParams.text,\r\n    };\r\n\r\n    const selectedCollectionId = this.collectionService.selectedIdForTranslation();\r\n    if (selectedCollectionId) {\r\n      params.options += `,termCorpusId=${selectedCollectionId}`;\r\n    }\r\n\r\n    return this.http.get<ITranslateParagraphResponseV1>(this.config?.textConfig?.translationUrl, { headers: headers, params: params }).pipe(\r\n      map((response: ITranslateParagraphResponseV1) => {\r\n        if (response.ErrorMessage) {\r\n          this.alerts.unhandeledError(response.ErrorMessage);\r\n          throw response.ErrorMessage;\r\n        }\r\n        const converted = this.convertParagraphResponse(requestParams, response);\r\n        return converted;\r\n      })\r\n    );\r\n  }\r\n\r\n\r\n  private convertParagraphResponse(request: ITranslateParagraphRequestParams, response: ITranslateParagraphResponseV1): ITranslateParagraphResponse {\r\n    if (this.config.textConfig.highlight) {\r\n      return this.createHighlightTrees(request.text, response, request.paragraphIx);\r\n    }\r\n    else {\r\n      return {\r\n        sourceTree: { text: request.text, paragraphIx: request.paragraphIx, type: HighlightTreeType.PARAGRAPH, root: null, originalText: request.text },\r\n        targetTree: { text: response.translation, paragraphIx: request.paragraphIx, type: HighlightTreeType.PARAGRAPH, root: null, originalText: response.translation }\r\n      };\r\n    }\r\n  }\r\n\r\n  private createHighlightTrees(sourceText: string, response: ITranslateParagraphResponseV1, paragraphIx: number): ITranslateParagraphResponse {\r\n    const targetTree = this.getSentence(response.translation, response.translationSentenceRanges, response.targetWordRanges, paragraphIx);\r\n    const sourceTree = this.getSentence(sourceText, response.originalSentenceRanges, response.sourceWordRanges, paragraphIx);\r\n    this.findSiblings(response.wordAlignment, sourceTree.words, targetTree.words);\r\n    return { sourceTree: sourceTree.tree, targetTree: targetTree.tree };\r\n  }\r\n\r\n  private getSentence(text: string, sentenceRanges: number[][], wordRanges: number[][], paragraphIx: number): IGetSentenceV1ResponseModel {\r\n    const tree: IHighlightTree = { text: text, children: [], paragraphIx, type: HighlightTreeType.PARAGRAPH, root: null, originalText: text };\r\n    const words: IHighlightTree[] = [];\r\n    let wordRangeIx = -1;\r\n    let lastProcessedCharIx = 0;\r\n\r\n    sentenceRanges.forEach((sentenceRange, sentenceIx) => {\r\n      const sentenceString = this.getSentenceFromRange(sentenceRange, text);\r\n      tree.children[sentenceIx] = {\r\n        text: sentenceString, children: [],\r\n        class: `${HighlightParams.sentenceClass} ${HighlightParams.sentenceClass}-${paragraphIx}-${sentenceIx}`,\r\n        elementId: sentenceIx.toString(),\r\n        type: HighlightTreeType.SENTENCE,\r\n        root: tree,\r\n        originalText: sentenceString\r\n      };\r\n\r\n      const sentenceStartIx = sentenceRange[0];\r\n      const sentenceEndIx = sentenceStartIx + sentenceRange[1];\r\n\r\n      let multipleWordWrapper: IHighlightTree;\r\n      for (let wordIx = wordRangeIx + 1; wordIx < wordRanges.length; wordIx++) {\r\n        const wordStartIx = wordRanges[wordIx][0];\r\n        const wordEndIx = wordRanges[wordIx][1];\r\n        const nextWordStartIx = wordRanges[wordIx + 1]?.[0];\r\n\r\n        if (wordStartIx >= sentenceStartIx && wordEndIx <= sentenceEndIx) {\r\n          wordRangeIx = wordIx;\r\n          if (lastProcessedCharIx < wordStartIx) {\r\n            // words are not together anymore.\r\n            multipleWordWrapper = null;\r\n            const originalText = text.slice(lastProcessedCharIx, wordStartIx);\r\n            // not a word.\r\n            const escaped = Common.escapeHtmlString(originalText);\r\n            tree.children[sentenceIx].children.push({\r\n              text: escaped,\r\n              type: HighlightTreeType.OTHER,\r\n              root: tree,\r\n              originalText\r\n            });\r\n            lastProcessedCharIx = wordStartIx;\r\n          }\r\n          const originalText = text.slice(wordStartIx, wordEndIx);\r\n          const escaped = Common.escapeHtmlString(originalText);\r\n          const elementId = `${paragraphIx}-${sentenceIx}-${wordIx}`;\r\n          const word: IHighlightTree = {\r\n            text: escaped,\r\n            class: `${HighlightParams.wordClass} ${HighlightParams.wordClass}-${elementId}`,\r\n            elementId: elementId,\r\n            type: originalText === \"-\" ? HighlightTreeType.HYPEN : HighlightTreeType.WORD,\r\n            root: tree,\r\n            originalText\r\n          };\r\n\r\n          if (word.type === HighlightTreeType.HYPEN) {\r\n            multipleWordWrapper = null;\r\n          }\r\n          else if (wordEndIx === nextWordStartIx) {\r\n            if (!multipleWordWrapper) {\r\n              multipleWordWrapper = {\r\n                originalText: \"\",\r\n                root: tree,\r\n                text: \"\",\r\n                type: HighlightTreeType.WORD_WRAPPER,\r\n                children: [],\r\n                class: HighlightParams.multipleWordWrapper\r\n              }\r\n              tree.children[sentenceIx].children.push(multipleWordWrapper);\r\n            }\r\n          }\r\n          if (multipleWordWrapper) {\r\n            multipleWordWrapper.originalText += originalText;\r\n            multipleWordWrapper.text += escaped;\r\n            multipleWordWrapper.children.push(word);\r\n          }\r\n          else {\r\n            tree.children[sentenceIx].children.push(word);\r\n          }\r\n          words.push(word);\r\n          lastProcessedCharIx = wordEndIx;\r\n        }\r\n        else {\r\n          break;\r\n        }\r\n      }\r\n    })\r\n    return { tree, words };\r\n  }\r\n\r\n  private getSentenceFromRange(range: number[], text: string): string {\r\n    const start = range[0] == 0 ? range[0] : range[0] + 1;\r\n    const end = start + range[1];\r\n    return text.slice(start, end);\r\n  }\r\n\r\n  private findSiblings(wordAlignment: number[][], sourceWords: IHighlightTree[], targetWords: IHighlightTree[]) {\r\n    wordAlignment.forEach((range) => {\r\n      const sourceWordIx = range[0];\r\n      const targetWordIx = range[1];\r\n      const sourceWord = sourceWords[sourceWordIx];\r\n      const targetWord = targetWords[targetWordIx];\r\n\r\n      if (sourceWord && targetWord) {\r\n        sourceWord.class += ` ${HighlightParams.siblingClass}-${targetWord.elementId}`;\r\n        targetWord.class += ` ${HighlightParams.siblingClass}-${sourceWord.elementId}`;\r\n      }\r\n    })\r\n  }\r\n}\r\n"]}
|
|
189
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tld-translate-text-api.service.js","sourceRoot":"","sources":["../../../../../../../../projects/tld-translate/src/lib/modules/tld-text/services/api/tld-translate-text-api.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from '@angular/common/http';\r\nimport { Injectable } from '@angular/core';\r\nimport { Observable } from 'rxjs';\r\nimport { map } from 'rxjs/operators';\r\nimport { Common, ITldTranslateTextApiService, ITranslateParagraphRequestParams } from '../../../tld-common/models';\r\nimport { TldAlertService, TldTranslateConfigService } from '../../../tld-common/services';\r\nimport { TldTermCollectionsService } from '../../../tld-term/services';\r\nimport { IGetSentenceV1ResponseModel } from '../../models/get-sentence-v1-response.model';\r\nimport { HighlightParams } from '../../models/highlight-params.model';\r\nimport { HighlightTreeType } from '../../models/highlight-tree-type.model';\r\nimport { IHighlightTree } from '../../models/highlight-tree.model';\r\nimport { ITranslateParagraphResponseV1 } from '../../models/translate-paragraph-response-v1.model';\r\nimport { ITranslateParagraphResponse } from '../../models/translate-paragraph-response.model';\r\n\r\n@Injectable({\r\n  providedIn: 'root'\r\n})\r\nexport class TldTranslateTextApiService implements ITldTranslateTextApiService {\r\n\r\n  constructor(private readonly collectionService: TldTermCollectionsService,\r\n    private readonly http: HttpClient,\r\n    private readonly config: TldTranslateConfigService,\r\n    private readonly alerts: TldAlertService) { }\r\n\r\n  updateTranslation(options: string, systemID: string, text: string, translation: string) {\r\n    const url = this.config.textConfig.updateTranslationUrl;\r\n    const headers = Common.getAuthHeaders(this.config);\r\n    const params = {\r\n      appID: this.config.coreConfig.appId,\r\n      options,\r\n      systemID,\r\n      text,\r\n      translation\r\n    }\r\n    return this.http.post(url, params, { headers });\r\n  }\r\n\r\n  dictionaryTranslation(text: string, srcCode: string, trgCode: string) {\r\n    const authHeaders = Common.getAuthHeaders(this.config);\r\n    // TODO. Create type for params.\r\n    const params: any = {\r\n      word: text,\r\n      sourceLanguage: srcCode,\r\n      targetLanguage: trgCode\r\n    };\r\n\r\n    return this.http.get(this.config.textConfig.dictionaryUrl, { headers: authHeaders, params: params })\r\n  }\r\n\r\n  translateParagraph(requestParams: ITranslateParagraphRequestParams): Observable<ITranslateParagraphResponse> {\r\n    const headers = Common.getAuthHeaders(this.config);\r\n    // TODO. Create type for params.\r\n    const params: any = {\r\n      appID: this.config.coreConfig.appId,\r\n      options: \"widget=text,alignment,markSentences\",\r\n      systemID: requestParams.system.id,\r\n      text: requestParams.text,\r\n    };\r\n\r\n    const selectedCollectionId = this.collectionService.selectedIdForTranslation();\r\n    if (selectedCollectionId) {\r\n      params.options += `,termCorpusId=${selectedCollectionId}`;\r\n    }\r\n\r\n    return this.http.get<ITranslateParagraphResponseV1>(this.config?.textConfig?.translationUrl, { headers: headers, params: params }).pipe(\r\n      map((response: ITranslateParagraphResponseV1) => {\r\n        if (response.ErrorMessage) {\r\n          this.alerts.unhandeledError(response.ErrorMessage);\r\n          throw response.ErrorMessage;\r\n        }\r\n        const converted = this.convertParagraphResponse(requestParams, response);\r\n        return converted;\r\n      })\r\n    );\r\n  }\r\n\r\n\r\n  private convertParagraphResponse(request: ITranslateParagraphRequestParams, response: ITranslateParagraphResponseV1): ITranslateParagraphResponse {\r\n    if (this.config.textConfig.highlight) {\r\n      return this.createHighlightTrees(request.text, response, request.paragraphIx);\r\n    }\r\n    else {\r\n      return {\r\n        sourceTree: { text: request.text, paragraphIx: request.paragraphIx, type: HighlightTreeType.PARAGRAPH, root: null, originalText: request.text },\r\n        targetTree: { text: response.translation, paragraphIx: request.paragraphIx, type: HighlightTreeType.PARAGRAPH, root: null, originalText: response.translation }\r\n      };\r\n    }\r\n  }\r\n\r\n  private createHighlightTrees(sourceText: string, response: ITranslateParagraphResponseV1, paragraphIx: number): ITranslateParagraphResponse {\r\n    const targetTree = this.getSentence(response.translation, response.translationSentenceRanges, response.targetWordRanges, paragraphIx);\r\n    const sourceTree = this.getSentence(sourceText, response.originalSentenceRanges, response.sourceWordRanges, paragraphIx);\r\n    this.findSiblings(response.wordAlignment, sourceTree.words, targetTree.words);\r\n    return { sourceTree: sourceTree.tree, targetTree: targetTree.tree };\r\n  }\r\n\r\n  private getSentence(text: string, sentenceRanges: number[][], wordRanges: number[][], paragraphIx: number): IGetSentenceV1ResponseModel {\r\n    const tree: IHighlightTree = { text: text, children: [], paragraphIx, type: HighlightTreeType.PARAGRAPH, root: null, originalText: text };\r\n    const words: IHighlightTree[] = [];\r\n    let lastProcessedCharIx = 0;\r\n\r\n    const wordRangesWithIndex = wordRanges.map((range, ix) => {\r\n      return {range, ix};\r\n    });\r\n\r\n    sentenceRanges.forEach((sentenceRange, sentenceIx) => {\r\n      const sentenceString = this.getSentenceFromRange(sentenceRange, text);\r\n      tree.children[sentenceIx] = {\r\n        text: sentenceString, children: [],\r\n        class: `${HighlightParams.sentenceClass} ${HighlightParams.sentenceClass}-${paragraphIx}-${sentenceIx}`,\r\n        elementId: sentenceIx.toString(),\r\n        type: HighlightTreeType.SENTENCE,\r\n        root: tree,\r\n        originalText: sentenceString\r\n      };\r\n\r\n      const sentenceStartIx = sentenceRange[0];\r\n      const sentenceEndIx = sentenceStartIx + sentenceRange[1];\r\n      const filteredWordRangesWithIndex = wordRangesWithIndex.filter((rangeWithIndex) => {\r\n        const wordStartIx = rangeWithIndex.range[0];\r\n        // on purpose, check only start index, because sometimes end index is not correct and aligned with sentences.\r\n        return wordStartIx >= sentenceStartIx && wordStartIx <= sentenceEndIx;\r\n      });\r\n\r\n      let multipleWordWrapper: IHighlightTree;\r\n      filteredWordRangesWithIndex.forEach((rangeWithIndex) => {\r\n        const wordRange = rangeWithIndex.range;\r\n        const wordStartIx = wordRange[0];\r\n        const wordEndIx = wordRange[1];\r\n        const nextWordStartIx = wordRanges[rangeWithIndex.ix + 1]?.[0];\r\n\r\n\r\n        if (lastProcessedCharIx < wordStartIx) {\r\n          // words are not together anymore.\r\n          multipleWordWrapper = null;\r\n          const originalText = text.slice(lastProcessedCharIx, wordStartIx);\r\n          // not a word.\r\n          const escaped = Common.escapeHtmlString(originalText);\r\n          tree.children[sentenceIx].children.push({\r\n            text: escaped,\r\n            type: HighlightTreeType.OTHER,\r\n            root: tree,\r\n            originalText\r\n          });\r\n          lastProcessedCharIx = wordStartIx;\r\n        }\r\n        const originalText = text.slice(wordStartIx, wordEndIx);\r\n        const escaped = Common.escapeHtmlString(originalText);\r\n        const elementId = `${paragraphIx}-${sentenceIx}-${rangeWithIndex.ix}`;\r\n        const word: IHighlightTree = {\r\n          text: escaped,\r\n          class: `${HighlightParams.wordClass} ${HighlightParams.wordClass}-${elementId}`,\r\n          elementId: elementId,\r\n          type: originalText === \"-\" ? HighlightTreeType.HYPEN : HighlightTreeType.WORD,\r\n          root: tree,\r\n          originalText\r\n        };\r\n\r\n        if (word.type === HighlightTreeType.HYPEN) {\r\n          multipleWordWrapper = null;\r\n        }\r\n        else if (wordEndIx === nextWordStartIx) {\r\n          if (!multipleWordWrapper) {\r\n            multipleWordWrapper = {\r\n              originalText: \"\",\r\n              root: tree,\r\n              text: \"\",\r\n              type: HighlightTreeType.WORD_WRAPPER,\r\n              children: [],\r\n              class: HighlightParams.multipleWordWrapper\r\n            }\r\n            tree.children[sentenceIx].children.push(multipleWordWrapper);\r\n          }\r\n        }\r\n        if (multipleWordWrapper) {\r\n          multipleWordWrapper.originalText += originalText;\r\n          multipleWordWrapper.text += escaped;\r\n          multipleWordWrapper.children.push(word);\r\n        }\r\n        else {\r\n          tree.children[sentenceIx].children.push(word);\r\n        }\r\n        words.push(word);\r\n        lastProcessedCharIx = wordEndIx;\r\n      })\r\n    })\r\n    return { tree, words };\r\n  }\r\n\r\n  private getSentenceFromRange(range: number[], text: string): string {\r\n    const start = range[0] == 0 ? range[0] : range[0] + 1;\r\n    const end = start + range[1];\r\n    return text.slice(start, end);\r\n  }\r\n\r\n  private findSiblings(wordAlignment: number[][], sourceWords: IHighlightTree[], targetWords: IHighlightTree[]) {\r\n    wordAlignment.forEach((range) => {\r\n      const sourceWordIx = range[0];\r\n      const targetWordIx = range[1];\r\n      const sourceWord = sourceWords[sourceWordIx];\r\n      const targetWord = targetWords[targetWordIx];\r\n\r\n      if (sourceWord && targetWord) {\r\n        sourceWord.class += ` ${HighlightParams.siblingClass}-${targetWord.elementId}`;\r\n        targetWord.class += ` ${HighlightParams.siblingClass}-${sourceWord.elementId}`;\r\n      }\r\n    })\r\n  }\r\n}\r\n"]}
|
|
@@ -7308,6 +7308,7 @@ class HighlightTreeComponent {
|
|
|
7308
7308
|
this.highlightService = highlightService;
|
|
7309
7309
|
this.correctionsEnabled = true;
|
|
7310
7310
|
this.onReplace = new EventEmitter();
|
|
7311
|
+
this.wordType = HighlightTreeType.WORD;
|
|
7311
7312
|
}
|
|
7312
7313
|
mouseEnter(event) {
|
|
7313
7314
|
this.onMouseEvent(event, this.isSource, true);
|
|
@@ -7385,10 +7386,10 @@ class HighlightTreeComponent {
|
|
|
7385
7386
|
}
|
|
7386
7387
|
}
|
|
7387
7388
|
HighlightTreeComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: HighlightTreeComponent, deps: [{ token: TldHighlightService }], target: i0.ɵɵFactoryTarget.Component });
|
|
7388
|
-
HighlightTreeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: HighlightTreeComponent, selector: "tld-highlight-tree", inputs: { tree: "tree", isSource: "isSource", correctionsEnabled: "correctionsEnabled", highlight: "highlight", gramCheck: "gramCheck", selectSentence: "selectSentence" }, outputs: { onReplace: "onReplace" }, ngImport: i0, template: "<ng-template #highlightTree let-tree=\"tree\">\r\n <ng-container *ngIf=\"!tree.children\">\r\n <ng-container *ngIf=\"tree.text\">\r\n <ng-container *ngIf=\"tree.grammarMeta && gramCheck\">\r\n <mat-menu #menu=\"matMenu\" class=\"grammar-check-menu\">\r\n <div class=\"title\">\r\n {{'GRAMMAR_CHECK_MENU.TITLE' | translate}}\r\n </div>\r\n <div *ngFor=\"let replacement of tree.grammarMeta.replacements\">\r\n <button mat-button color=\"accent\" (click)=\"replace(tree, replacement)\">\r\n {{replacement}}\r\n </button>\r\n </div>\r\n </mat-menu>\r\n <span #menuTrigger=\"matMenuTrigger\" [matMenuTriggerFor]=\"menu\" class=\"{{tree.class}}\"\r\n [innerHTML]=\"tree.text\" (mouseenter)=\"mouseEnter($event)\" (click)=\"gramCheckMenu(tree, menuTrigger)\"\r\n (mouseleave)=\"mouseLeave($event)\"></span>\r\n\r\n </ng-container>\r\n <ng-container *ngIf=\"!(tree.grammarMeta && gramCheck)\">\r\n <span class=\"{{tree.class}}\" [innerHTML]=\"tree.text\" (mouseenter)=\"mouseEnter($event)\"\r\n (mouseleave)=\"mouseLeave($event)\"></span>\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngIf=\"!tree.text\">\r\n <br>\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngIf=\"tree.children\">\r\n <span [ngClass]=\"{'selected-sentence': isSelectedSentence(tree)}\" class=\"highlight-tree-child-wrapper {{tree.class}}\"\r\n (mouseenter)=\"mouseEnter($event)\" (mouseleave)=\"mouseLeave($event)\" (click)=\"parentClick(tree)\">\r\n <ng-template ngFor let-child [ngForOf]=\"tree.children\">\r\n <ng-template [ngTemplateOutlet]=\"highlightTree\" [ngTemplateOutletContext]=\"{ tree: child }\">\r\n </ng-template>\r\n </ng-template>\r\n </span>\r\n </ng-container>\r\n</ng-template>\r\n\r\n\r\n\r\n<div *ngIf=\"tree\" class=\"tld-highlight-tree\">\r\n <ng-template [ngTemplateOutlet]=\"highlightTree\" [ngTemplateOutletContext]=\"{ tree: tree }\"></ng-template>\r\n</div
|
|
7389
|
+
HighlightTreeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: HighlightTreeComponent, selector: "tld-highlight-tree", inputs: { tree: "tree", isSource: "isSource", correctionsEnabled: "correctionsEnabled", highlight: "highlight", gramCheck: "gramCheck", selectSentence: "selectSentence" }, outputs: { onReplace: "onReplace" }, ngImport: i0, template: "<ng-template #highlightTree let-tree=\"tree\">\r\n <ng-container *ngIf=\"!tree.children\">\r\n <ng-container *ngIf=\"tree.text\">\r\n <ng-container *ngIf=\"tree.grammarMeta && gramCheck\">\r\n <mat-menu #menu=\"matMenu\" class=\"grammar-check-menu\">\r\n <div class=\"title\">\r\n {{'GRAMMAR_CHECK_MENU.TITLE' | translate}}\r\n </div>\r\n <div *ngFor=\"let replacement of tree.grammarMeta.replacements\">\r\n <button mat-button color=\"accent\" (click)=\"replace(tree, replacement)\">\r\n {{replacement}}\r\n </button>\r\n </div>\r\n </mat-menu>\r\n <span #menuTrigger=\"matMenuTrigger\" [matMenuTriggerFor]=\"menu\" class=\"{{tree.class}}\"\r\n [innerHTML]=\"tree.text\" (mouseenter)=\"mouseEnter($event)\" (click)=\"gramCheckMenu(tree, menuTrigger)\"\r\n (mouseleave)=\"mouseLeave($event)\"></span>\r\n\r\n </ng-container>\r\n <ng-container *ngIf=\"!(tree.grammarMeta && gramCheck)\">\r\n <span class=\"{{tree.class}}\" [innerHTML]=\"tree.text\" (mouseenter)=\"mouseEnter($event)\"\r\n (mouseleave)=\"mouseLeave($event)\"></span>\r\n </ng-container>\r\n </ng-container>\r\n <!-- If text is empty and type is 'word', we should not break line. -->\r\n <ng-container *ngIf=\"!tree.text && tree.type !== wordType\">\r\n <br>\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngIf=\"tree.children\">\r\n <span [ngClass]=\"{'selected-sentence': isSelectedSentence(tree)}\" class=\"highlight-tree-child-wrapper {{tree.class}}\"\r\n (mouseenter)=\"mouseEnter($event)\" (mouseleave)=\"mouseLeave($event)\" (click)=\"parentClick(tree)\">\r\n <ng-template ngFor let-child [ngForOf]=\"tree.children\">\r\n <ng-template [ngTemplateOutlet]=\"highlightTree\" [ngTemplateOutletContext]=\"{ tree: child }\">\r\n </ng-template>\r\n </ng-template>\r\n </span>\r\n </ng-container>\r\n</ng-template>\r\n\r\n\r\n\r\n<div *ngIf=\"tree\" class=\"tld-highlight-tree\">\r\n <ng-template [ngTemplateOutlet]=\"highlightTree\" [ngTemplateOutletContext]=\"{ tree: tree }\"></ng-template>\r\n</div>\r\n", styles: ["span{white-space:pre-wrap}\n"], dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i5.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i3$1.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { kind: "directive", type: i3$1.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }, { kind: "directive", type: i5$1.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: "pipe", type: i1$1.TranslatePipe, name: "translate" }] });
|
|
7389
7390
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: HighlightTreeComponent, decorators: [{
|
|
7390
7391
|
type: Component,
|
|
7391
|
-
args: [{ selector: 'tld-highlight-tree', template: "<ng-template #highlightTree let-tree=\"tree\">\r\n <ng-container *ngIf=\"!tree.children\">\r\n <ng-container *ngIf=\"tree.text\">\r\n <ng-container *ngIf=\"tree.grammarMeta && gramCheck\">\r\n <mat-menu #menu=\"matMenu\" class=\"grammar-check-menu\">\r\n <div class=\"title\">\r\n {{'GRAMMAR_CHECK_MENU.TITLE' | translate}}\r\n </div>\r\n <div *ngFor=\"let replacement of tree.grammarMeta.replacements\">\r\n <button mat-button color=\"accent\" (click)=\"replace(tree, replacement)\">\r\n {{replacement}}\r\n </button>\r\n </div>\r\n </mat-menu>\r\n <span #menuTrigger=\"matMenuTrigger\" [matMenuTriggerFor]=\"menu\" class=\"{{tree.class}}\"\r\n [innerHTML]=\"tree.text\" (mouseenter)=\"mouseEnter($event)\" (click)=\"gramCheckMenu(tree, menuTrigger)\"\r\n (mouseleave)=\"mouseLeave($event)\"></span>\r\n\r\n </ng-container>\r\n <ng-container *ngIf=\"!(tree.grammarMeta && gramCheck)\">\r\n <span class=\"{{tree.class}}\" [innerHTML]=\"tree.text\" (mouseenter)=\"mouseEnter($event)\"\r\n (mouseleave)=\"mouseLeave($event)\"></span>\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngIf=\"!tree.text\">\r\n <br>\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngIf=\"tree.children\">\r\n <span [ngClass]=\"{'selected-sentence': isSelectedSentence(tree)}\" class=\"highlight-tree-child-wrapper {{tree.class}}\"\r\n (mouseenter)=\"mouseEnter($event)\" (mouseleave)=\"mouseLeave($event)\" (click)=\"parentClick(tree)\">\r\n <ng-template ngFor let-child [ngForOf]=\"tree.children\">\r\n <ng-template [ngTemplateOutlet]=\"highlightTree\" [ngTemplateOutletContext]=\"{ tree: child }\">\r\n </ng-template>\r\n </ng-template>\r\n </span>\r\n </ng-container>\r\n</ng-template>\r\n\r\n\r\n\r\n<div *ngIf=\"tree\" class=\"tld-highlight-tree\">\r\n <ng-template [ngTemplateOutlet]=\"highlightTree\" [ngTemplateOutletContext]=\"{ tree: tree }\"></ng-template>\r\n</div
|
|
7392
|
+
args: [{ selector: 'tld-highlight-tree', template: "<ng-template #highlightTree let-tree=\"tree\">\r\n <ng-container *ngIf=\"!tree.children\">\r\n <ng-container *ngIf=\"tree.text\">\r\n <ng-container *ngIf=\"tree.grammarMeta && gramCheck\">\r\n <mat-menu #menu=\"matMenu\" class=\"grammar-check-menu\">\r\n <div class=\"title\">\r\n {{'GRAMMAR_CHECK_MENU.TITLE' | translate}}\r\n </div>\r\n <div *ngFor=\"let replacement of tree.grammarMeta.replacements\">\r\n <button mat-button color=\"accent\" (click)=\"replace(tree, replacement)\">\r\n {{replacement}}\r\n </button>\r\n </div>\r\n </mat-menu>\r\n <span #menuTrigger=\"matMenuTrigger\" [matMenuTriggerFor]=\"menu\" class=\"{{tree.class}}\"\r\n [innerHTML]=\"tree.text\" (mouseenter)=\"mouseEnter($event)\" (click)=\"gramCheckMenu(tree, menuTrigger)\"\r\n (mouseleave)=\"mouseLeave($event)\"></span>\r\n\r\n </ng-container>\r\n <ng-container *ngIf=\"!(tree.grammarMeta && gramCheck)\">\r\n <span class=\"{{tree.class}}\" [innerHTML]=\"tree.text\" (mouseenter)=\"mouseEnter($event)\"\r\n (mouseleave)=\"mouseLeave($event)\"></span>\r\n </ng-container>\r\n </ng-container>\r\n <!-- If text is empty and type is 'word', we should not break line. -->\r\n <ng-container *ngIf=\"!tree.text && tree.type !== wordType\">\r\n <br>\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngIf=\"tree.children\">\r\n <span [ngClass]=\"{'selected-sentence': isSelectedSentence(tree)}\" class=\"highlight-tree-child-wrapper {{tree.class}}\"\r\n (mouseenter)=\"mouseEnter($event)\" (mouseleave)=\"mouseLeave($event)\" (click)=\"parentClick(tree)\">\r\n <ng-template ngFor let-child [ngForOf]=\"tree.children\">\r\n <ng-template [ngTemplateOutlet]=\"highlightTree\" [ngTemplateOutletContext]=\"{ tree: child }\">\r\n </ng-template>\r\n </ng-template>\r\n </span>\r\n </ng-container>\r\n</ng-template>\r\n\r\n\r\n\r\n<div *ngIf=\"tree\" class=\"tld-highlight-tree\">\r\n <ng-template [ngTemplateOutlet]=\"highlightTree\" [ngTemplateOutletContext]=\"{ tree: tree }\"></ng-template>\r\n</div>\r\n", styles: ["span{white-space:pre-wrap}\n"] }]
|
|
7392
7393
|
}], ctorParameters: function () { return [{ type: TldHighlightService }]; }, propDecorators: { tree: [{
|
|
7393
7394
|
type: Input
|
|
7394
7395
|
}], isSource: [{
|
|
@@ -10741,10 +10742,11 @@ class TldTranslateTextApiService {
|
|
|
10741
10742
|
getSentence(text, sentenceRanges, wordRanges, paragraphIx) {
|
|
10742
10743
|
const tree = { text: text, children: [], paragraphIx, type: HighlightTreeType.PARAGRAPH, root: null, originalText: text };
|
|
10743
10744
|
const words = [];
|
|
10744
|
-
let wordRangeIx = -1;
|
|
10745
10745
|
let lastProcessedCharIx = 0;
|
|
10746
|
+
const wordRangesWithIndex = wordRanges.map((range, ix) => {
|
|
10747
|
+
return { range, ix };
|
|
10748
|
+
});
|
|
10746
10749
|
sentenceRanges.forEach((sentenceRange, sentenceIx) => {
|
|
10747
|
-
var _a;
|
|
10748
10750
|
const sentenceString = this.getSentenceFromRange(sentenceRange, text);
|
|
10749
10751
|
tree.children[sentenceIx] = {
|
|
10750
10752
|
text: sentenceString, children: [],
|
|
@@ -10756,69 +10758,70 @@ class TldTranslateTextApiService {
|
|
|
10756
10758
|
};
|
|
10757
10759
|
const sentenceStartIx = sentenceRange[0];
|
|
10758
10760
|
const sentenceEndIx = sentenceStartIx + sentenceRange[1];
|
|
10761
|
+
const filteredWordRangesWithIndex = wordRangesWithIndex.filter((rangeWithIndex) => {
|
|
10762
|
+
const wordStartIx = rangeWithIndex.range[0];
|
|
10763
|
+
// on purpose, check only start index, because sometimes end index is not correct and aligned with sentences.
|
|
10764
|
+
return wordStartIx >= sentenceStartIx && wordStartIx <= sentenceEndIx;
|
|
10765
|
+
});
|
|
10759
10766
|
let multipleWordWrapper;
|
|
10760
|
-
|
|
10761
|
-
|
|
10762
|
-
const
|
|
10763
|
-
const
|
|
10764
|
-
|
|
10765
|
-
|
|
10766
|
-
|
|
10767
|
-
|
|
10768
|
-
|
|
10769
|
-
|
|
10770
|
-
|
|
10771
|
-
const escaped = Common.escapeHtmlString(originalText);
|
|
10772
|
-
tree.children[sentenceIx].children.push({
|
|
10773
|
-
text: escaped,
|
|
10774
|
-
type: HighlightTreeType.OTHER,
|
|
10775
|
-
root: tree,
|
|
10776
|
-
originalText
|
|
10777
|
-
});
|
|
10778
|
-
lastProcessedCharIx = wordStartIx;
|
|
10779
|
-
}
|
|
10780
|
-
const originalText = text.slice(wordStartIx, wordEndIx);
|
|
10767
|
+
filteredWordRangesWithIndex.forEach((rangeWithIndex) => {
|
|
10768
|
+
var _a;
|
|
10769
|
+
const wordRange = rangeWithIndex.range;
|
|
10770
|
+
const wordStartIx = wordRange[0];
|
|
10771
|
+
const wordEndIx = wordRange[1];
|
|
10772
|
+
const nextWordStartIx = (_a = wordRanges[rangeWithIndex.ix + 1]) === null || _a === void 0 ? void 0 : _a[0];
|
|
10773
|
+
if (lastProcessedCharIx < wordStartIx) {
|
|
10774
|
+
// words are not together anymore.
|
|
10775
|
+
multipleWordWrapper = null;
|
|
10776
|
+
const originalText = text.slice(lastProcessedCharIx, wordStartIx);
|
|
10777
|
+
// not a word.
|
|
10781
10778
|
const escaped = Common.escapeHtmlString(originalText);
|
|
10782
|
-
|
|
10783
|
-
const word = {
|
|
10779
|
+
tree.children[sentenceIx].children.push({
|
|
10784
10780
|
text: escaped,
|
|
10785
|
-
|
|
10786
|
-
elementId: elementId,
|
|
10787
|
-
type: originalText === "-" ? HighlightTreeType.HYPEN : HighlightTreeType.WORD,
|
|
10781
|
+
type: HighlightTreeType.OTHER,
|
|
10788
10782
|
root: tree,
|
|
10789
10783
|
originalText
|
|
10790
|
-
};
|
|
10791
|
-
|
|
10792
|
-
|
|
10793
|
-
|
|
10794
|
-
|
|
10795
|
-
|
|
10796
|
-
|
|
10797
|
-
|
|
10798
|
-
|
|
10799
|
-
|
|
10800
|
-
|
|
10801
|
-
|
|
10802
|
-
|
|
10803
|
-
|
|
10804
|
-
|
|
10805
|
-
|
|
10806
|
-
|
|
10807
|
-
|
|
10808
|
-
|
|
10809
|
-
multipleWordWrapper
|
|
10810
|
-
|
|
10811
|
-
|
|
10812
|
-
|
|
10813
|
-
|
|
10784
|
+
});
|
|
10785
|
+
lastProcessedCharIx = wordStartIx;
|
|
10786
|
+
}
|
|
10787
|
+
const originalText = text.slice(wordStartIx, wordEndIx);
|
|
10788
|
+
const escaped = Common.escapeHtmlString(originalText);
|
|
10789
|
+
const elementId = `${paragraphIx}-${sentenceIx}-${rangeWithIndex.ix}`;
|
|
10790
|
+
const word = {
|
|
10791
|
+
text: escaped,
|
|
10792
|
+
class: `${HighlightParams.wordClass} ${HighlightParams.wordClass}-${elementId}`,
|
|
10793
|
+
elementId: elementId,
|
|
10794
|
+
type: originalText === "-" ? HighlightTreeType.HYPEN : HighlightTreeType.WORD,
|
|
10795
|
+
root: tree,
|
|
10796
|
+
originalText
|
|
10797
|
+
};
|
|
10798
|
+
if (word.type === HighlightTreeType.HYPEN) {
|
|
10799
|
+
multipleWordWrapper = null;
|
|
10800
|
+
}
|
|
10801
|
+
else if (wordEndIx === nextWordStartIx) {
|
|
10802
|
+
if (!multipleWordWrapper) {
|
|
10803
|
+
multipleWordWrapper = {
|
|
10804
|
+
originalText: "",
|
|
10805
|
+
root: tree,
|
|
10806
|
+
text: "",
|
|
10807
|
+
type: HighlightTreeType.WORD_WRAPPER,
|
|
10808
|
+
children: [],
|
|
10809
|
+
class: HighlightParams.multipleWordWrapper
|
|
10810
|
+
};
|
|
10811
|
+
tree.children[sentenceIx].children.push(multipleWordWrapper);
|
|
10814
10812
|
}
|
|
10815
|
-
|
|
10816
|
-
|
|
10813
|
+
}
|
|
10814
|
+
if (multipleWordWrapper) {
|
|
10815
|
+
multipleWordWrapper.originalText += originalText;
|
|
10816
|
+
multipleWordWrapper.text += escaped;
|
|
10817
|
+
multipleWordWrapper.children.push(word);
|
|
10817
10818
|
}
|
|
10818
10819
|
else {
|
|
10819
|
-
|
|
10820
|
+
tree.children[sentenceIx].children.push(word);
|
|
10820
10821
|
}
|
|
10821
|
-
|
|
10822
|
+
words.push(word);
|
|
10823
|
+
lastProcessedCharIx = wordEndIx;
|
|
10824
|
+
});
|
|
10822
10825
|
});
|
|
10823
10826
|
return { tree, words };
|
|
10824
10827
|
}
|