@tilde-nlp/ngx-translate 5.0.15 → 5.0.16

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.
@@ -40,7 +40,7 @@ export class TldTranslateFileDownloadButtonComponent {
40
40
  }
41
41
  onClick(meta) {
42
42
  if (!meta && this.extensions) {
43
- meta = this.extensions[0];
43
+ meta = this.extensions.find((file) => file.category === FileCategory.TRANSLATED) ?? this.extensions[0];
44
44
  }
45
45
  this.tldClick.emit(meta);
46
46
  }
@@ -70,4 +70,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
70
70
  }], sourceDownload: [{
71
71
  type: Input
72
72
  }] } });
73
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"download-button.component.js","sourceRoot":"","sources":["../../../../../../../projects/tld-translate/src/lib/modules/tld-document/download-button/download-button.component.ts","../../../../../../../projects/tld-translate/src/lib/modules/tld-document/download-button/download-button.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAC1F,OAAO,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AAGjD,OAAO,EAAE,mBAAmB,EAAE,MAAM,uCAAuC,CAAC;AAE5E,OAAO,EAAE,YAAY,EAAE,MAAM,4CAA4C,CAAC;;;;;;;;AAO1E,MAAM,OAAO,uCAAuC;IA4B/B;IA1BnB,MAAM,CAAU;IAChB,IAAI,qBAAqB;QACvB,OAAO,IAAI,CAAC,cAAc;YACxB,IAAI,CAAC,IAAI,EAAE,cAAc;YACzB,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,sBAAsB;YAC7C,IAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,mBAAmB,CAAC,GAAG,CAAA;IACjD,CAAC;IACD,IAAI,uBAAuB;QACzB,OAAO,IAAI,CAAC,cAAc;YACxB,IAAI,CAAC,IAAI,EAAE,cAAc;YACzB,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,wBAAwB;YAC/C,IAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,mBAAmB,CAAC,KAAK,CAAA;IACnD,CAAC;IACD,IAAI,UAAU,KAAK,OAAO,IAAI,CAAC,IAAI,EAAE,mBAAmB,IAAI,EAAE,CAAC,CAAC,CAAC;IAExD,kBAAkB,GAAG,YAAY,CAAC,UAAU,CAAC;IAElC,IAAI,CAAU;IAExB,QAAQ,GAA4B,IAAI,YAAY,EAAE,CAAC;IACxD,IAAI,CAAmB;IAChC,mDAAmD;IAC1C,QAAQ,CAAU;IAClB,cAAc,CAAU;IAEjC,YACmB,MAAiC;QAAjC,WAAM,GAAN,MAAM,CAA2B;IACpD,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC;IAC9C,CAAC;IAED,OAAO,CAAC,IAAgB;QACtB,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,UAAU,EAAE;YAC5B,IAAI,GAAG,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;SAC3B;QACD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;IAC1B,CAAC;IAED,aAAa;QACX,MAAM,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,SAAS,CAAC,QAAQ,KAAK,YAAY,CAAC,eAAe,CAAC,CAAC;QAC1G,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;IAC3B,CAAC;IAGD,UAAU;QACR,MAAM,KAAK,GAAG,QAAQ,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACzD,KAAK,CAAC,YAAY,CAAC,cAAc,EAAE,wBAAwB,CAAC,CAAC;IAC/D,CAAC;wGAnDU,uCAAuC;4FAAvC,uCAAuC,qOAmBvC,OAAO,gDChCpB,2xDAsCA;;4FDzBa,uCAAuC;kBALnD,SAAS;+BACE,oCAAoC;gHAuB1B,IAAI;sBAAvB,SAAS;uBAAC,OAAO;gBAER,QAAQ;sBAAjB,MAAM;gBACE,IAAI;sBAAZ,KAAK;gBAEG,QAAQ;sBAAhB,KAAK;gBACG,cAAc;sBAAtB,KAAK","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output, ViewChild } from '@angular/core';\r\nimport { MatMenu } from '@angular/material/menu';\r\nimport { IFileMeta } from '../../tld-common/models';\r\nimport { TldTranslateConfigService } from '../../tld-common/services';\r\nimport { FileConversionTypes } from '../models/file-conversion-types.model';\r\nimport { ITranslationFile } from '../models/translate-file.model';\r\nimport { FileCategory } from '../services/api/models/file-category.model';\r\n\r\n@Component({\r\n  selector: 'tld-translate-file-download-button',\r\n  templateUrl: './download-button.component.html',\r\n  styleUrls: ['./download-button.component.scss']\r\n})\r\nexport class TldTranslateFileDownloadButtonComponent implements OnInit {\r\n\r\n  isAuth: boolean;\r\n  get showSourceDownloadPdf() {\r\n    return this.sourceDownload &&\r\n      this.file?.sourceFileName &&\r\n      this.config.fileConfig.allowPDFSourceDownload &&\r\n      this.file.fileType == FileConversionTypes.PDF\r\n  }\r\n  get showSourceDownloadImage() {\r\n    return this.sourceDownload &&\r\n      this.file?.sourceFileName &&\r\n      this.config.fileConfig.allowImageSourceDownload &&\r\n      this.file.fileType == FileConversionTypes.IMAGE\r\n  }\r\n  get extensions() { return this.file?.availableExtensions || []; }\r\n\r\n  readonly translatedCategory = FileCategory.TRANSLATED;\r\n\r\n  @ViewChild(MatMenu) menu: MatMenu;\r\n\r\n  @Output() tldClick: EventEmitter<IFileMeta> = new EventEmitter();\r\n  @Input() file: ITranslationFile;\r\n  //@Input() extensions: ITranslationExtensionMeta[];\r\n  @Input() disabled: boolean;\r\n  @Input() sourceDownload: boolean;\r\n\r\n  constructor(\r\n    private readonly config: TldTranslateConfigService) {\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.isAuth = this.config.coreConfig.isAuth;\r\n  }\r\n\r\n  onClick(meta?: IFileMeta) {\r\n    if (!meta && this.extensions) {\r\n      meta = this.extensions[0];\r\n    }\r\n    this.tldClick.emit(meta)\r\n  }\r\n\r\n  onSourceClick() {\r\n    const sourceMeta = this.extensions.find(extension => extension.category === FileCategory.SOURCECONVERTED);\r\n    this.onClick(sourceMeta);\r\n  }\r\n\r\n\r\n  onMenuOpen() {\r\n    const panel = document.getElementById(this.menu.panelId);\r\n    panel.setAttribute(\"data-test-id\", 'tld-download-file-list');\r\n  }\r\n}\r\n","<div fxLayout=\"row\">\r\n\r\n  <button mat-stroked-button color=\"accent\" (click)=\"onClick()\" class=\"action-button border-accent download-button\"\r\n    [disabled]=\"disabled\">\r\n    <span class=\"material-icons\">\r\n      file_download\r\n    </span>\r\n    <span class=\"download-btn-text text-m-semi-bold\">\r\n      {{'TLD_TRANSLATE.DOWNLOAD_TRANSLATED' | translate}}\r\n    </span>\r\n  </button>\r\n  <button mat-stroked-button color=\"accent\" class=\"extension-button border-accent\" #menuTrigger=\"matMenuTrigger\"\r\n    data-test-id=\"download-other-formats-button\" (menuOpened)=\"onMenuOpen()\" *ngIf=\"extensions?.length\"\r\n    [matMenuTriggerFor]=\"extensionMenu\" [disabled]=\"disabled\"\r\n    [attr.aria-label]=\"'ARIA_LABELS.SHOW_EXTENSIONS' | translate\" fxLayoutAlign=\"center center\">\r\n    <span class=\"material-icons\">\r\n      arrow_drop_down\r\n    </span>\r\n  </button>\r\n</div>\r\n<mat-menu #extensionMenu=\"matMenu\">\r\n  <div fxLayout=\"column\">\r\n    <ng-container *ngFor=\"let extension of extensions\">\r\n      <button mat-menu-item fxLayoutAlign=\"start center\" class=\"language-title\" *ngIf=\"extension.category === translatedCategory\"\r\n        (click)=\"onClick(extension)\">\r\n        {{extension.extension}}\r\n      </button>\r\n    </ng-container>\r\n    <button mat-menu-item fxLayoutAlign=\"start center\" *ngIf=\"showSourceDownloadPdf\" class=\"language-title\"\r\n      (click)=\"onSourceClick()\">\r\n      {{'TLD_TRANSLATE.FILE_DOWNLOAD_SOURCE'|translate}}\r\n    </button>\r\n    <button mat-menu-item fxLayoutAlign=\"start center\" *ngIf=\"showSourceDownloadImage\" class=\"language-title\"\r\n      (click)=\"onSourceClick()\">\r\n      {{'TLD_TRANSLATE.FILE_DOWNLOAD_SOURCE_IMAGE'|translate}}\r\n    </button>\r\n  </div>\r\n</mat-menu>\r\n"]}
73
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"download-button.component.js","sourceRoot":"","sources":["../../../../../../../projects/tld-translate/src/lib/modules/tld-document/download-button/download-button.component.ts","../../../../../../../projects/tld-translate/src/lib/modules/tld-document/download-button/download-button.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAC1F,OAAO,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AAGjD,OAAO,EAAE,mBAAmB,EAAE,MAAM,uCAAuC,CAAC;AAE5E,OAAO,EAAE,YAAY,EAAE,MAAM,4CAA4C,CAAC;;;;;;;;AAO1E,MAAM,OAAO,uCAAuC;IA4B/B;IA1BnB,MAAM,CAAU;IAChB,IAAI,qBAAqB;QACvB,OAAO,IAAI,CAAC,cAAc;YACxB,IAAI,CAAC,IAAI,EAAE,cAAc;YACzB,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,sBAAsB;YAC7C,IAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,mBAAmB,CAAC,GAAG,CAAA;IACjD,CAAC;IACD,IAAI,uBAAuB;QACzB,OAAO,IAAI,CAAC,cAAc;YACxB,IAAI,CAAC,IAAI,EAAE,cAAc;YACzB,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,wBAAwB;YAC/C,IAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,mBAAmB,CAAC,KAAK,CAAA;IACnD,CAAC;IACD,IAAI,UAAU,KAAK,OAAO,IAAI,CAAC,IAAI,EAAE,mBAAmB,IAAI,EAAE,CAAC,CAAC,CAAC;IAExD,kBAAkB,GAAG,YAAY,CAAC,UAAU,CAAC;IAElC,IAAI,CAAU;IAExB,QAAQ,GAA4B,IAAI,YAAY,EAAE,CAAC;IACxD,IAAI,CAAmB;IAChC,mDAAmD;IAC1C,QAAQ,CAAU;IAClB,cAAc,CAAU;IAEjC,YACmB,MAAiC;QAAjC,WAAM,GAAN,MAAM,CAA2B;IACpD,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC;IAC9C,CAAC;IAED,OAAO,CAAC,IAAgB;QACtB,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,UAAU,EAAE;YAC5B,IAAI,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,QAAQ,KAAK,YAAY,CAAC,UAAU,CAAC,IAAI,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;SACxG;QACD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;IAC1B,CAAC;IAED,aAAa;QACX,MAAM,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,SAAS,CAAC,QAAQ,KAAK,YAAY,CAAC,eAAe,CAAC,CAAC;QAC1G,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;IAC3B,CAAC;IAGD,UAAU;QACR,MAAM,KAAK,GAAG,QAAQ,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACzD,KAAK,CAAC,YAAY,CAAC,cAAc,EAAE,wBAAwB,CAAC,CAAC;IAC/D,CAAC;wGAnDU,uCAAuC;4FAAvC,uCAAuC,qOAmBvC,OAAO,gDChCpB,2xDAsCA;;4FDzBa,uCAAuC;kBALnD,SAAS;+BACE,oCAAoC;gHAuB1B,IAAI;sBAAvB,SAAS;uBAAC,OAAO;gBAER,QAAQ;sBAAjB,MAAM;gBACE,IAAI;sBAAZ,KAAK;gBAEG,QAAQ;sBAAhB,KAAK;gBACG,cAAc;sBAAtB,KAAK","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output, ViewChild } from '@angular/core';\r\nimport { MatMenu } from '@angular/material/menu';\r\nimport { IFileMeta } from '../../tld-common/models';\r\nimport { TldTranslateConfigService } from '../../tld-common/services';\r\nimport { FileConversionTypes } from '../models/file-conversion-types.model';\r\nimport { ITranslationFile } from '../models/translate-file.model';\r\nimport { FileCategory } from '../services/api/models/file-category.model';\r\n\r\n@Component({\r\n  selector: 'tld-translate-file-download-button',\r\n  templateUrl: './download-button.component.html',\r\n  styleUrls: ['./download-button.component.scss']\r\n})\r\nexport class TldTranslateFileDownloadButtonComponent implements OnInit {\r\n\r\n  isAuth: boolean;\r\n  get showSourceDownloadPdf() {\r\n    return this.sourceDownload &&\r\n      this.file?.sourceFileName &&\r\n      this.config.fileConfig.allowPDFSourceDownload &&\r\n      this.file.fileType == FileConversionTypes.PDF\r\n  }\r\n  get showSourceDownloadImage() {\r\n    return this.sourceDownload &&\r\n      this.file?.sourceFileName &&\r\n      this.config.fileConfig.allowImageSourceDownload &&\r\n      this.file.fileType == FileConversionTypes.IMAGE\r\n  }\r\n  get extensions() { return this.file?.availableExtensions || []; }\r\n\r\n  readonly translatedCategory = FileCategory.TRANSLATED;\r\n\r\n  @ViewChild(MatMenu) menu: MatMenu;\r\n\r\n  @Output() tldClick: EventEmitter<IFileMeta> = new EventEmitter();\r\n  @Input() file: ITranslationFile;\r\n  //@Input() extensions: ITranslationExtensionMeta[];\r\n  @Input() disabled: boolean;\r\n  @Input() sourceDownload: boolean;\r\n\r\n  constructor(\r\n    private readonly config: TldTranslateConfigService) {\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.isAuth = this.config.coreConfig.isAuth;\r\n  }\r\n\r\n  onClick(meta?: IFileMeta) {\r\n    if (!meta && this.extensions) {\r\n      meta = this.extensions.find((file) => file.category === FileCategory.TRANSLATED) ?? this.extensions[0];\r\n    }\r\n    this.tldClick.emit(meta)\r\n  }\r\n\r\n  onSourceClick() {\r\n    const sourceMeta = this.extensions.find(extension => extension.category === FileCategory.SOURCECONVERTED);\r\n    this.onClick(sourceMeta);\r\n  }\r\n\r\n\r\n  onMenuOpen() {\r\n    const panel = document.getElementById(this.menu.panelId);\r\n    panel.setAttribute(\"data-test-id\", 'tld-download-file-list');\r\n  }\r\n}\r\n","<div fxLayout=\"row\">\r\n\r\n  <button mat-stroked-button color=\"accent\" (click)=\"onClick()\" class=\"action-button border-accent download-button\"\r\n    [disabled]=\"disabled\">\r\n    <span class=\"material-icons\">\r\n      file_download\r\n    </span>\r\n    <span class=\"download-btn-text text-m-semi-bold\">\r\n      {{'TLD_TRANSLATE.DOWNLOAD_TRANSLATED' | translate}}\r\n    </span>\r\n  </button>\r\n  <button mat-stroked-button color=\"accent\" class=\"extension-button border-accent\" #menuTrigger=\"matMenuTrigger\"\r\n    data-test-id=\"download-other-formats-button\" (menuOpened)=\"onMenuOpen()\" *ngIf=\"extensions?.length\"\r\n    [matMenuTriggerFor]=\"extensionMenu\" [disabled]=\"disabled\"\r\n    [attr.aria-label]=\"'ARIA_LABELS.SHOW_EXTENSIONS' | translate\" fxLayoutAlign=\"center center\">\r\n    <span class=\"material-icons\">\r\n      arrow_drop_down\r\n    </span>\r\n  </button>\r\n</div>\r\n<mat-menu #extensionMenu=\"matMenu\">\r\n  <div fxLayout=\"column\">\r\n    <ng-container *ngFor=\"let extension of extensions\">\r\n      <button mat-menu-item fxLayoutAlign=\"start center\" class=\"language-title\" *ngIf=\"extension.category === translatedCategory\"\r\n        (click)=\"onClick(extension)\">\r\n        {{extension.extension}}\r\n      </button>\r\n    </ng-container>\r\n    <button mat-menu-item fxLayoutAlign=\"start center\" *ngIf=\"showSourceDownloadPdf\" class=\"language-title\"\r\n      (click)=\"onSourceClick()\">\r\n      {{'TLD_TRANSLATE.FILE_DOWNLOAD_SOURCE'|translate}}\r\n    </button>\r\n    <button mat-menu-item fxLayoutAlign=\"start center\" *ngIf=\"showSourceDownloadImage\" class=\"language-title\"\r\n      (click)=\"onSourceClick()\">\r\n      {{'TLD_TRANSLATE.FILE_DOWNLOAD_SOURCE_IMAGE'|translate}}\r\n    </button>\r\n  </div>\r\n</mat-menu>\r\n"]}
@@ -3,6 +3,7 @@ import { NotificationMessageType } from '@tilde-nlp/ngx-common';
3
3
  import { take } from 'rxjs/operators';
4
4
  import { TldFileTranslateBaseComponent } from '../tld-file-translate-base.component';
5
5
  import { AUTO_LANGUAGE_DETECTION_KEY } from '../../tld-common/models/auto-language-detection-key.const';
6
+ import { FileCategory } from '../services/api/models/file-category.model';
6
7
  import * as i0 from "@angular/core";
7
8
  import * as i1 from "../services/tld-translate-file.service";
8
9
  import * as i2 from "../../tld-common/services";
@@ -87,7 +88,7 @@ export class TldTranslateFileMultipleComponent extends TldFileTranslateBaseCompo
87
88
  }
88
89
  download(file, fileMeta) {
89
90
  if (!fileMeta) {
90
- fileMeta = file.availableExtensions?.[0];
91
+ fileMeta = file.availableExtensions?.find((file) => file.category === FileCategory.TRANSLATED) ?? file.availableExtensions?.[0];
91
92
  }
92
93
  this.fileService.download(file, fileMeta);
93
94
  }
@@ -121,4 +122,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
121
122
  }], ctorParameters: function () { return [{ type: i1.TldTranslateFileService }, { type: i2.TldTranslateConfigService }, { type: i3.MatDialog }, { type: i4.TldTranslateButtonService }, { type: i2.TldTranslateSystemManagementService }, { type: i5.AlertService }]; }, propDecorators: { translationFiles: [{
122
123
  type: Input
123
124
  }] } });
124
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tld-translate-file-multiple.component.js","sourceRoot":"","sources":["../../../../../../../projects/tld-translate/src/lib/modules/tld-document/tld-translate-file-multiple/tld-translate-file-multiple.component.ts","../../../../../../../projects/tld-translate/src/lib/modules/tld-document/tld-translate-file-multiple/tld-translate-file-multiple.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit } from '@angular/core';\r\nimport { MatDialog } from '@angular/material/dialog';\r\nimport { AlertService, FileUploadError, NotificationMessageType } from '@tilde-nlp/ngx-common';\r\nimport { take } from 'rxjs/operators';\r\nimport { TldTranslateButtonService } from '../../tld-common/components/translate-button/tld-translate-button.service';\r\nimport { IFileMeta } from '../../tld-common/models';\r\nimport { TldTranslateSystemManagementService, TldTranslateConfigService } from '../../tld-common/services';\r\nimport { ITranslationFile } from '../models/translate-file.model';\r\nimport { TldTranslateFileService } from '../services/tld-translate-file.service';\r\nimport { TldFileTranslateBaseComponent } from '../tld-file-translate-base.component';\r\nimport { AUTO_LANGUAGE_DETECTION_KEY } from '../../tld-common/models/auto-language-detection-key.const';\r\n\r\n@Component({\r\n  selector: 'tld-translate-file-multiple',\r\n  templateUrl: './tld-translate-file-multiple.component.html',\r\n  styleUrls: ['./tld-translate-file-multiple.component.scss']\r\n})\r\nexport class TldTranslateFileMultipleComponent extends TldFileTranslateBaseComponent implements OnInit {\r\n\r\n  constructor(\r\n    protected readonly fileService: TldTranslateFileService,\r\n    protected readonly config: TldTranslateConfigService,\r\n    protected readonly dialog: MatDialog,\r\n    protected readonly translateButtonService: TldTranslateButtonService,\r\n    private readonly systemManagementService: TldTranslateSystemManagementService,\r\n    private readonly alertService: AlertService\r\n  ) {\r\n    super(dialog, config, fileService);\r\n  }\r\n  @Input() translationFiles: ITranslationFile[];\r\n\r\n  allowedFileTypes: string[];\r\n  allowedFileTypesAuthUser: string[];\r\n  maxFileUploadSize: number;\r\n  multipleFiles: boolean;\r\n  extendedFileTypes: string[];\r\n  showVendorNotification: boolean;\r\n\r\n  private isSelectLanguageWarningAdded = false;\r\n\r\n  get isAutoSourceLangEnabled() {\r\n    const isSourceLangAuto = this.systemManagementService.getActiveSystemObj().sourceLanguage === AUTO_LANGUAGE_DETECTION_KEY;\r\n\r\n    if (isSourceLangAuto) {\r\n      if (this.isSelectLanguageWarningAdded) {\r\n        return true;\r\n      }\r\n\r\n      this.isSelectLanguageWarningAdded = true;\r\n      this.alertService.warning('FILE_UPLOAD.SELECT_LANGUAGE_WARNING', null, true);\r\n    } else {\r\n      this.isSelectLanguageWarningAdded = false;\r\n      this.alertService.deleteMessage(NotificationMessageType.WARNING, 'FILE_UPLOAD.SELECT_LANGUAGE_WARNING', null, true)\r\n    }\r\n\r\n    return isSourceLangAuto;\r\n  }\r\n\r\n  get translationStarted() {\r\n    return this.fileService.translationStarted;\r\n  }\r\n\r\n  get disableAppendFiles() {\r\n    return this.fileService?.translationStarted || this.fileService.translationFiles?.length >= this.config.fileConfig.numberOfFilesAllowed;\r\n  }\r\n\r\n  get isAuth() {\r\n    return this.config?.coreConfig?.isAuth;\r\n  }\r\n\r\n  get translatedFilesCount() {\r\n    return this.fileService?.translatedCount || 0;\r\n  }\r\n\r\n  get maxFileCount() {\r\n    return this.config.fileConfig.numberOfFilesAllowed;\r\n  }\r\n\r\n  get fileCount() {\r\n    return this.translationFiles?.length || 0;\r\n  }\r\n\r\n  get disableTranslateButton() {\r\n    return this.fileService.disableTranslateButton || this.isAutoSourceLangEnabled;\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.allowedFileTypes = this.config.fileConfig.allowedFileTypes;\r\n    this.extendedFileTypes = this.config.fileConfig.extendedFileTypes;\r\n    this.maxFileUploadSize = this.config.fileConfig.maxSize;\r\n    this.multipleFiles = this.config.fileConfig.numberOfFilesAllowed > 1;\r\n\r\n    this.fileService.onFilesUploaded().pipe(take(1)).subscribe(() => { this.translateButtonService.pulseButton(); })\r\n\r\n  }\r\n\r\n  download(file: ITranslationFile, fileMeta?: IFileMeta) {\r\n    if (!fileMeta) {\r\n      fileMeta = file.availableExtensions?.[0];\r\n    }\r\n    this.fileService.download(file, fileMeta);\r\n  }\r\n\r\n  fileChange(files: File[]) {\r\n    for (var i = 0; i < files.length; i++) {\r\n      this.fileService.loadFilePreview(files[i]);\r\n    }\r\n  }\r\n\r\n\r\n  remove(file: ITranslationFile) {\r\n    if (this.translationFiles.length === 1) {\r\n      this.clearAll();\r\n    }\r\n    else {\r\n      this.fileService.remove(file);\r\n    }\r\n  }\r\n\r\n  fileUploadError(error: any) {\r\n    this.fileService.fileUploadError(error as FileUploadError);\r\n  }\r\n\r\n  // no need to handle translation, since it is happening in translate button component, but this method is for custom action\r\n  translateButtonClick() {\r\n    const vendor = this.systemManagementService.activeVendor;\r\n    this.showVendorNotification = this.config.fileConfig.progressIndicatorTitleVisibleForVendors.includes(vendor);\r\n  }\r\n}\r\n","<div class=\"tld-translate-file-container\" [ngClass.xs]=\"'tld-multiple-mobile'\" fxLayout=\"column\" fxFlex\r\n  fxLayoutAlign=\"start center\">\r\n  <div class=\"cdk-visually-hidden\" aria-live=\"polite\">\r\n    {{'MULTIPLE_FILES.SCREEN_READER_ANNOUNCEMENT' | translate: {translated:translatedFilesCount , total: fileCount} }}\r\n  </div>\r\n  <div fxLayout=\"column\" fxLayoutGap=\"0.5rem\" fxFlex class=\"multiple-files-body\">\r\n    <div *ngFor=\"let file of translationFiles\" class=\"file-row\" [ngClass.gt-sm]=\"'extra-width'\" fxLayout=\"row\"\r\n      fxLayoutAlign=\"center center\" fxLayoutAlign.xs=\"flex-start center\">\r\n      <div fxLayout=\"column\" fxFlex>\r\n        <div fxLayout=\"row\" fxLayoutAlign.xs=\"space-between center\" fxLayoutAlign=\"space-between center\">\r\n          <div class=\"file-name\">\r\n            {{file.originalFileName}}\r\n          </div>\r\n          <div fxLayout=\"row\" class=\"file-actions\">\r\n            <tld-translate-file-download-button (tldClick)=\"download(file, $event)\" *ngIf=\"file.downloadAvailable\"\r\n              [sourceDownload]=\"true\" [disabled]=\"file.isDownloading\" [file]=\"file\">\r\n            </tld-translate-file-download-button>\r\n            <tld-close-button [tooltip]=\"'FILE_UPLOAD.CLEAR'\" (tldClick)=\"remove(file)\"></tld-close-button>\r\n          </div>\r\n        </div>\r\n        <mat-progress-bar *ngIf=\"file.translationStatuss===translatingStatuss\" color=\"accent\" mode=\"determinate\"\r\n          [value]=\"file.progress\"></mat-progress-bar>\r\n        <div class=\"progress-message text-s\"\r\n          *ngIf=\"(file.translationStatuss !== errorTranslatingStatuss) && (file.translationStatuss !== completedTranslatingStatuss) && (file.translationStatuss !== uploadedTranslatingStatuss)\">\r\n          {{'MULTIPLE_FILES.STATUSS_' + file.translationStatuss | translate: {percent: file.progress} }}\r\n        </div>\r\n        <ng-container *ngIf=\"file.messages.length>0\">\r\n          <lib-inline-message *ngFor=\"let message of file.messages\" [message]=\"message\"></lib-inline-message>\r\n        </ng-container>\r\n      </div>\r\n    </div>\r\n\r\n    <tld-file-upload *ngIf=\"!translationStarted\" fxFlex class=\"tld-append-files\" (fileChange)=\"fileChange($event)\"\r\n      [accept]=\"allowedFileTypes\" [maxSize]=\"maxFileUploadSize\" [multiple]=\"multipleFiles\"\r\n      [disabled]=\"disableAppendFiles\" (errorEvent)=\"fileUploadError($event)\" [extendedAcceptList]=\"extendedFileTypes\">\r\n      {{'MULTIPLE_FILES.APPEND' | translate}} ({{fileCount}}/{{maxFileCount}})\r\n    </tld-file-upload>\r\n  </div>\r\n  <ng-container *ngIf=\"sourceDownloadPDF\">\r\n    <ng-container\r\n      *ngTemplateOutlet=\"conversionMessage; context: { messageKey:'MULTIPLE_FILES.PDF_DISCLAIMER', dialogParams: pdfConversion, buttonText: 'MULTIPLE_FILES.PDF_DISCLAIMER_LINK'}\">\r\n    </ng-container>\r\n  </ng-container>\r\n\r\n  <ng-container *ngIf=\"sourceDownloadImage\">\r\n    <ng-container\r\n      *ngTemplateOutlet=\"conversionMessage; context: { messageKey:'MULTIPLE_FILES.IMAGE_DISCLAIMER', dialogParams: imageConversion, buttonText: 'MULTIPLE_FILES.IMAGE_DISCLAIMER_LINK'}\">\r\n    </ng-container>\r\n  </ng-container>\r\n\r\n  <ng-container *ngIf=\"showVendorNotification\">\r\n    <vendor-disclaimer></vendor-disclaimer>\r\n  </ng-container>\r\n  <div fxLayout=\"row\" fxLayoutAlign=\"center center\" fxLayout.xs=\"column\" fxLayuotGap.xs=\"1rem\" class=\"button-container\">\r\n    <tld-translate-button [disabled]=\"disableTranslateButton\" (clicked)=\"translateButtonClick()\"\r\n      *ngIf=\"!translationStarted\"></tld-translate-button>\r\n    <button (click)=\"clearAll()\" mat-stroked-button color=\"accent\"\r\n      class=\"cancel-button border-accent\">{{'MULTIPLE_FILES.CLEAR_ALL' | translate}}</button>\r\n  </div>\r\n</div>\r\n\r\n<ng-template #conversionMessage let-messageKey=\"messageKey\" let-dialogParams=\"dialogParams\" let-buttonText=\"buttonText\">\r\n\r\n  <p class=\"conversion-disclaimer text-m\" [ngClass.gt-sm]=\"'conversion-info-margins-gt-sm'\">\r\n    <span class=\"material-icons\">\r\n      info\r\n    </span>\r\n    <span>\r\n      {{messageKey | translate }}\r\n    </span>\r\n    <button class=\"conversion-message-action text-m-semi-bold\" (click)=\"conversionDialog(dialogParams)\">{{buttonText |\r\n      translate}}</button>\r\n</ng-template>\r\n"]}
125
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tld-translate-file-multiple.component.js","sourceRoot":"","sources":["../../../../../../../projects/tld-translate/src/lib/modules/tld-document/tld-translate-file-multiple/tld-translate-file-multiple.component.ts","../../../../../../../projects/tld-translate/src/lib/modules/tld-document/tld-translate-file-multiple/tld-translate-file-multiple.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit } from '@angular/core';\r\nimport { MatDialog } from '@angular/material/dialog';\r\nimport { AlertService, FileUploadError, NotificationMessageType } from '@tilde-nlp/ngx-common';\r\nimport { take } from 'rxjs/operators';\r\nimport { TldTranslateButtonService } from '../../tld-common/components/translate-button/tld-translate-button.service';\r\nimport { IFileMeta } from '../../tld-common/models';\r\nimport { TldTranslateSystemManagementService, TldTranslateConfigService } from '../../tld-common/services';\r\nimport { ITranslationFile } from '../models/translate-file.model';\r\nimport { TldTranslateFileService } from '../services/tld-translate-file.service';\r\nimport { TldFileTranslateBaseComponent } from '../tld-file-translate-base.component';\r\nimport { AUTO_LANGUAGE_DETECTION_KEY } from '../../tld-common/models/auto-language-detection-key.const';\r\nimport { FileCategory } from '../services/api/models/file-category.model';\r\n\r\n@Component({\r\n  selector: 'tld-translate-file-multiple',\r\n  templateUrl: './tld-translate-file-multiple.component.html',\r\n  styleUrls: ['./tld-translate-file-multiple.component.scss']\r\n})\r\nexport class TldTranslateFileMultipleComponent extends TldFileTranslateBaseComponent implements OnInit {\r\n\r\n  constructor(\r\n    protected readonly fileService: TldTranslateFileService,\r\n    protected readonly config: TldTranslateConfigService,\r\n    protected readonly dialog: MatDialog,\r\n    protected readonly translateButtonService: TldTranslateButtonService,\r\n    private readonly systemManagementService: TldTranslateSystemManagementService,\r\n    private readonly alertService: AlertService\r\n  ) {\r\n    super(dialog, config, fileService);\r\n  }\r\n  @Input() translationFiles: ITranslationFile[];\r\n\r\n  allowedFileTypes: string[];\r\n  allowedFileTypesAuthUser: string[];\r\n  maxFileUploadSize: number;\r\n  multipleFiles: boolean;\r\n  extendedFileTypes: string[];\r\n  showVendorNotification: boolean;\r\n\r\n  private isSelectLanguageWarningAdded = false;\r\n\r\n  get isAutoSourceLangEnabled() {\r\n    const isSourceLangAuto = this.systemManagementService.getActiveSystemObj().sourceLanguage === AUTO_LANGUAGE_DETECTION_KEY;\r\n\r\n    if (isSourceLangAuto) {\r\n      if (this.isSelectLanguageWarningAdded) {\r\n        return true;\r\n      }\r\n\r\n      this.isSelectLanguageWarningAdded = true;\r\n      this.alertService.warning('FILE_UPLOAD.SELECT_LANGUAGE_WARNING', null, true);\r\n    } else {\r\n      this.isSelectLanguageWarningAdded = false;\r\n      this.alertService.deleteMessage(NotificationMessageType.WARNING, 'FILE_UPLOAD.SELECT_LANGUAGE_WARNING', null, true)\r\n    }\r\n\r\n    return isSourceLangAuto;\r\n  }\r\n\r\n  get translationStarted() {\r\n    return this.fileService.translationStarted;\r\n  }\r\n\r\n  get disableAppendFiles() {\r\n    return this.fileService?.translationStarted || this.fileService.translationFiles?.length >= this.config.fileConfig.numberOfFilesAllowed;\r\n  }\r\n\r\n  get isAuth() {\r\n    return this.config?.coreConfig?.isAuth;\r\n  }\r\n\r\n  get translatedFilesCount() {\r\n    return this.fileService?.translatedCount || 0;\r\n  }\r\n\r\n  get maxFileCount() {\r\n    return this.config.fileConfig.numberOfFilesAllowed;\r\n  }\r\n\r\n  get fileCount() {\r\n    return this.translationFiles?.length || 0;\r\n  }\r\n\r\n  get disableTranslateButton() {\r\n    return this.fileService.disableTranslateButton || this.isAutoSourceLangEnabled;\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.allowedFileTypes = this.config.fileConfig.allowedFileTypes;\r\n    this.extendedFileTypes = this.config.fileConfig.extendedFileTypes;\r\n    this.maxFileUploadSize = this.config.fileConfig.maxSize;\r\n    this.multipleFiles = this.config.fileConfig.numberOfFilesAllowed > 1;\r\n\r\n    this.fileService.onFilesUploaded().pipe(take(1)).subscribe(() => { this.translateButtonService.pulseButton(); })\r\n\r\n  }\r\n\r\n  download(file: ITranslationFile, fileMeta?: IFileMeta) {\r\n    if (!fileMeta) {\r\n      fileMeta = file.availableExtensions?.find((file) => file.category === FileCategory.TRANSLATED) ?? file.availableExtensions?.[0];\r\n    }\r\n    this.fileService.download(file, fileMeta);\r\n  }\r\n\r\n  fileChange(files: File[]) {\r\n    for (var i = 0; i < files.length; i++) {\r\n      this.fileService.loadFilePreview(files[i]);\r\n    }\r\n  }\r\n\r\n\r\n  remove(file: ITranslationFile) {\r\n    if (this.translationFiles.length === 1) {\r\n      this.clearAll();\r\n    }\r\n    else {\r\n      this.fileService.remove(file);\r\n    }\r\n  }\r\n\r\n  fileUploadError(error: any) {\r\n    this.fileService.fileUploadError(error as FileUploadError);\r\n  }\r\n\r\n  // no need to handle translation, since it is happening in translate button component, but this method is for custom action\r\n  translateButtonClick() {\r\n    const vendor = this.systemManagementService.activeVendor;\r\n    this.showVendorNotification = this.config.fileConfig.progressIndicatorTitleVisibleForVendors.includes(vendor);\r\n  }\r\n}\r\n","<div class=\"tld-translate-file-container\" [ngClass.xs]=\"'tld-multiple-mobile'\" fxLayout=\"column\" fxFlex\r\n  fxLayoutAlign=\"start center\">\r\n  <div class=\"cdk-visually-hidden\" aria-live=\"polite\">\r\n    {{'MULTIPLE_FILES.SCREEN_READER_ANNOUNCEMENT' | translate: {translated:translatedFilesCount , total: fileCount} }}\r\n  </div>\r\n  <div fxLayout=\"column\" fxLayoutGap=\"0.5rem\" fxFlex class=\"multiple-files-body\">\r\n    <div *ngFor=\"let file of translationFiles\" class=\"file-row\" [ngClass.gt-sm]=\"'extra-width'\" fxLayout=\"row\"\r\n      fxLayoutAlign=\"center center\" fxLayoutAlign.xs=\"flex-start center\">\r\n      <div fxLayout=\"column\" fxFlex>\r\n        <div fxLayout=\"row\" fxLayoutAlign.xs=\"space-between center\" fxLayoutAlign=\"space-between center\">\r\n          <div class=\"file-name\">\r\n            {{file.originalFileName}}\r\n          </div>\r\n          <div fxLayout=\"row\" class=\"file-actions\">\r\n            <tld-translate-file-download-button (tldClick)=\"download(file, $event)\" *ngIf=\"file.downloadAvailable\"\r\n              [sourceDownload]=\"true\" [disabled]=\"file.isDownloading\" [file]=\"file\">\r\n            </tld-translate-file-download-button>\r\n            <tld-close-button [tooltip]=\"'FILE_UPLOAD.CLEAR'\" (tldClick)=\"remove(file)\"></tld-close-button>\r\n          </div>\r\n        </div>\r\n        <mat-progress-bar *ngIf=\"file.translationStatuss===translatingStatuss\" color=\"accent\" mode=\"determinate\"\r\n          [value]=\"file.progress\"></mat-progress-bar>\r\n        <div class=\"progress-message text-s\"\r\n          *ngIf=\"(file.translationStatuss !== errorTranslatingStatuss) && (file.translationStatuss !== completedTranslatingStatuss) && (file.translationStatuss !== uploadedTranslatingStatuss)\">\r\n          {{'MULTIPLE_FILES.STATUSS_' + file.translationStatuss | translate: {percent: file.progress} }}\r\n        </div>\r\n        <ng-container *ngIf=\"file.messages.length>0\">\r\n          <lib-inline-message *ngFor=\"let message of file.messages\" [message]=\"message\"></lib-inline-message>\r\n        </ng-container>\r\n      </div>\r\n    </div>\r\n\r\n    <tld-file-upload *ngIf=\"!translationStarted\" fxFlex class=\"tld-append-files\" (fileChange)=\"fileChange($event)\"\r\n      [accept]=\"allowedFileTypes\" [maxSize]=\"maxFileUploadSize\" [multiple]=\"multipleFiles\"\r\n      [disabled]=\"disableAppendFiles\" (errorEvent)=\"fileUploadError($event)\" [extendedAcceptList]=\"extendedFileTypes\">\r\n      {{'MULTIPLE_FILES.APPEND' | translate}} ({{fileCount}}/{{maxFileCount}})\r\n    </tld-file-upload>\r\n  </div>\r\n  <ng-container *ngIf=\"sourceDownloadPDF\">\r\n    <ng-container\r\n      *ngTemplateOutlet=\"conversionMessage; context: { messageKey:'MULTIPLE_FILES.PDF_DISCLAIMER', dialogParams: pdfConversion, buttonText: 'MULTIPLE_FILES.PDF_DISCLAIMER_LINK'}\">\r\n    </ng-container>\r\n  </ng-container>\r\n\r\n  <ng-container *ngIf=\"sourceDownloadImage\">\r\n    <ng-container\r\n      *ngTemplateOutlet=\"conversionMessage; context: { messageKey:'MULTIPLE_FILES.IMAGE_DISCLAIMER', dialogParams: imageConversion, buttonText: 'MULTIPLE_FILES.IMAGE_DISCLAIMER_LINK'}\">\r\n    </ng-container>\r\n  </ng-container>\r\n\r\n  <ng-container *ngIf=\"showVendorNotification\">\r\n    <vendor-disclaimer></vendor-disclaimer>\r\n  </ng-container>\r\n  <div fxLayout=\"row\" fxLayoutAlign=\"center center\" fxLayout.xs=\"column\" fxLayuotGap.xs=\"1rem\" class=\"button-container\">\r\n    <tld-translate-button [disabled]=\"disableTranslateButton\" (clicked)=\"translateButtonClick()\"\r\n      *ngIf=\"!translationStarted\"></tld-translate-button>\r\n    <button (click)=\"clearAll()\" mat-stroked-button color=\"accent\"\r\n      class=\"cancel-button border-accent\">{{'MULTIPLE_FILES.CLEAR_ALL' | translate}}</button>\r\n  </div>\r\n</div>\r\n\r\n<ng-template #conversionMessage let-messageKey=\"messageKey\" let-dialogParams=\"dialogParams\" let-buttonText=\"buttonText\">\r\n\r\n  <p class=\"conversion-disclaimer text-m\" [ngClass.gt-sm]=\"'conversion-info-margins-gt-sm'\">\r\n    <span class=\"material-icons\">\r\n      info\r\n    </span>\r\n    <span>\r\n      {{messageKey | translate }}\r\n    </span>\r\n    <button class=\"conversion-message-action text-m-semi-bold\" (click)=\"conversionDialog(dialogParams)\">{{buttonText |\r\n      translate}}</button>\r\n</ng-template>\r\n"]}
@@ -5042,7 +5042,7 @@ class TldTranslateFileDownloadButtonComponent {
5042
5042
  }
5043
5043
  onClick(meta) {
5044
5044
  if (!meta && this.extensions) {
5045
- meta = this.extensions[0];
5045
+ meta = this.extensions.find((file) => file.category === FileCategory.TRANSLATED) ?? this.extensions[0];
5046
5046
  }
5047
5047
  this.tldClick.emit(meta);
5048
5048
  }
@@ -5197,7 +5197,7 @@ class TldTranslateFileMultipleComponent extends TldFileTranslateBaseComponent {
5197
5197
  }
5198
5198
  download(file, fileMeta) {
5199
5199
  if (!fileMeta) {
5200
- fileMeta = file.availableExtensions?.[0];
5200
+ fileMeta = file.availableExtensions?.find((file) => file.category === FileCategory.TRANSLATED) ?? file.availableExtensions?.[0];
5201
5201
  }
5202
5202
  this.fileService.download(file, fileMeta);
5203
5203
  }