ontimize-web-ngx 15.4.1 → 15.4.2

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.
@@ -104,6 +104,17 @@ export class OTableExportDialogComponent {
104
104
  }
105
105
  export() {
106
106
  this.dialogRef.close(true);
107
+ const exportFunction = this.getCustomExportButton(this.selectedExportFormat)?.exportFunction;
108
+ if (exportFunction) {
109
+ exportFunction(this.columns, !this.vertical, this.filename);
110
+ return;
111
+ }
112
+ const onClickEvent = this.getCustomExportButton(this.selectedExportFormat)?.onClick;
113
+ if (onClickEvent.observers.length > 0) {
114
+ console.warn('⚠️ [DEPRECATED] The onClick event is deprecated. Use the input export-function instead.');
115
+ this.getCustomExportButton(this.selectedExportFormat)?.onClick.emit();
116
+ return;
117
+ }
107
118
  this.exportService.exportData(this.selectedExportFormat, this.columns, !this.vertical, this.filename).subscribe({
108
119
  next: () => {
109
120
  this.snackBarService.open('MESSAGES.SUCCESS_EXPORT_TABLE_DATA', { icon: 'check_circle' });
@@ -150,6 +161,9 @@ export class OTableExportDialogComponent {
150
161
  event.source.buttonToggleGroup.value = event.value;
151
162
  this.selectedExportFormat = event.value;
152
163
  }
164
+ getCustomExportButton(type) {
165
+ return this.config.options.find(x => x.exportType === type);
166
+ }
153
167
  }
154
168
  OTableExportDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: OTableExportDialogComponent, deps: [{ token: i1.MatDialogRef }, { token: i0.Injector }, { token: MAT_DIALOG_DATA }], target: i0.ɵɵFactoryTarget.Component });
155
169
  OTableExportDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: OTableExportDialogComponent, selector: "o-table-export-dialog", host: { classAttribute: "o-table-export-dialog" }, providers: [
@@ -166,4 +180,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
166
180
  type: Inject,
167
181
  args: [MAT_DIALOG_DATA]
168
182
  }] }]; } });
169
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"o-table-export-dialog.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ontimize-web-ngx/src/lib/components/table/extensions/dialog/export/o-table-export-dialog.component.ts","../../../../../../../../projects/ontimize-web-ngx/src/lib/components/table/extensions/dialog/export/o-table-export-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import { HttpErrorResponse } from '@angular/common/http';\nimport { ChangeDetectionStrategy, Component, Inject, Injector, OnDestroy, OnInit, ViewEncapsulation } from '@angular/core';\nimport { MAT_DIALOG_DATA, MatDialogRef } from '@angular/material/dialog';\nimport { Subscription } from 'rxjs';\nimport { AppConfig } from '../../../../../config/app-config';\n\nimport { CdkDragDrop, moveItemInArray } from '@angular/cdk/drag-drop';\nimport { IExportService } from '../../../../../interfaces/export-service.interface';\nimport { OntimizeExportServiceProvider } from '../../../../../services/factories';\nimport { OntimizeExportService } from '../../../../../services/ontimize/ontimize-export.service';\nimport { SnackBarService } from '../../../../../services/snackbar.service';\nimport { OTranslateService } from '../../../../../services/translate/o-translate.service';\nimport { Codes } from '../../../../../util/codes';\nimport { Util } from '../../../../../util/util';\nimport { OTableExportButtonService } from '../../export-button/o-table-export-button.service';\nimport { OTableExportConfiguration } from '../../header/table-menu/o-table-export-configuration.class';\nimport { MatButtonToggleChange } from '@angular/material/button-toggle';\n\n@Component({\n  selector: 'o-table-export-dialog',\n  templateUrl: 'o-table-export-dialog.component.html',\n  styleUrls: ['o-table-export-dialog.component.scss'],\n  providers: [\n    OntimizeExportServiceProvider\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  host: {\n    class: 'o-table-export-dialog'\n  },\n  encapsulation: ViewEncapsulation.None\n})\nexport class OTableExportDialogComponent implements OnInit, OnDestroy {\n\n  protected snackBarService: SnackBarService;\n  protected exportService: IExportService;\n  protected translateService: OTranslateService;\n  protected oTableExportButtonService: OTableExportButtonService;\n  protected visibleButtons: string[];\n  private subscription: Subscription = new Subscription();\n  private appConfig: AppConfig;\n  columns: string[];\n  columnsData: string[];\n  public orientations = [{ text: \"EXPORT.DIALOG.VERTICAL\", value: true }, { text: \"EXPORT.DIALOG.HORIZONTAL\", value: false }];\n  public exportTypes = [{\n    exportType: 'xlsx',\n    svgIcon: 'ontimize:EXCEL',\n    olabel: 'TABLE.BUTTONS.EXCEL',\n    className: 'excel-button'\n  }, {\n    exportType: 'html',\n    svgIcon: 'ontimize:HTML',\n    olabel: 'TABLE.BUTTONS.HTML',\n    className: 'html-button'\n  }, {\n    exportType: 'pdf',\n    svgIcon: 'ontimize:PDF',\n    olabel: 'TABLE.BUTTONS.PDF',\n    className: 'pdf-button'\n  }, {\n    exportType: 'csv',\n    svgIcon: 'ontimize:CSV',\n    olabel: 'TABLE.BUTTONS.CSV',\n    className: 'csv-button'\n  }];\n  vertical: boolean = true;\n  selectedExportFormat: string;\n  filename: string = '';\n  isExpanded: boolean = false;\n  constructor(\n    public dialogRef: MatDialogRef<OTableExportDialogComponent>,\n    protected injector: Injector,\n    @Inject(MAT_DIALOG_DATA) public config: OTableExportConfiguration\n  ) {\n    this.snackBarService = injector.get(SnackBarService);\n    this.translateService = this.injector.get(OTranslateService);\n    this.oTableExportButtonService = this.injector.get(OTableExportButtonService);\n    this.appConfig = this.injector.get(AppConfig);\n    this.selectedExportFormat = this.getDefaultSelection();\n\n    if (config && Util.isDefined(config.visibleButtons)) {\n      this.visibleButtons = Util.parseArray(config.visibleButtons.toLowerCase(), true);\n    }\n  }\n\n  ngOnInit() {\n    this.initialize();\n  }\n\n  ngOnDestroy() {\n    this.subscription.unsubscribe();\n  }\n\n  initialize(): void {\n    this.columnsData = this.config.columns;\n    this.columns = [...this.columnsData];\n    this.configureService();\n  }\n\n  configureService(): void {\n    let loadingService: any = OntimizeExportService;\n    if (this.config.serviceType) {\n      loadingService = this.config.serviceType;\n    }\n    this.exportService = this.injector.get(loadingService);\n    const serviceCfg = this.exportService.getDefaultServiceConfiguration(this.config.service);\n    this.exportService.configureService(serviceCfg);\n  }\n  updateColumnsSort() {\n    this.columns.sort((a: any, b: any) => {\n      let indexA = this.columnsData.findIndex(x => x === a);\n      let indexB = this.columnsData.findIndex(x => x === b);\n      return indexA - indexB;\n    });\n  }\n  dropColumns(event: CdkDragDrop<string[]>) {\n    moveItemInArray(this.columnsData, event.previousIndex, event.currentIndex);\n    this.updateColumnsSort();\n  }\n  columnsCompareFunction(co1: any, co2: any) {\n    return co1.id === co2.id;\n  }\n\n  export(): void {\n    this.dialogRef.close(true);\n    this.exportService.exportData(this.selectedExportFormat, this.columns, !this.vertical, this.filename).subscribe({\n      next: () => {\n        this.snackBarService.open('MESSAGES.SUCCESS_EXPORT_TABLE_DATA', { icon: 'check_circle' });\n      },\n      error: (err: any) => {\n        this.handleError(err);\n      }\n    }\n    );\n  }\n\n  isButtonVisible(btn: string): boolean {\n\n    const useExportConfiguration3X = this.appConfig.useExportConfiguration();\n    let isVisible = true;\n    if (this.visibleButtons) {\n      isVisible = this.visibleButtons.indexOf(btn) !== -1;\n    } else {\n      if (useExportConfiguration3X) {\n        isVisible = Codes.VISIBLE_EXPORT_BUTTONS3X.indexOf(btn) !== -1;\n      } else {\n        isVisible = Codes.VISIBLE_EXPORT_BUTTONS.indexOf(btn) !== -1\n      }\n    }\n\n    return isVisible;\n  }\n\n  getDefaultSelection() {\n    const useExportConfiguration3X = this.appConfig.useExportConfiguration();\n\n    if (useExportConfiguration3X) {\n      return Codes.VISIBLE_EXPORT_BUTTONS3X[0];\n    } else {\n      return Codes.VISIBLE_EXPORT_BUTTONS[0];\n    }\n\n  }\n\n  protected handleError(err): void {\n    if (err instanceof HttpErrorResponse) {\n      this.snackBarService.open(err.message, { icon: 'error' });\n    } else {\n      this.snackBarService.open('MESSAGES.ERROR_EXPORT_TABLE_DATA', { icon: 'error' });\n    }\n  }\n\n  onChangeMatButtonToggleGroup(event: MatButtonToggleChange) {\n    event.source.buttonToggleGroup.value = event.value;\n    this.selectedExportFormat = event.value;\n  }\n}\n","<span mat-dialog-title>{{ 'TABLE.BUTTONS.EXPORT' | oTranslate }}</span>\n<mat-dialog-content class=\"dialog_content\">\n  <div mat-subheader>{{ 'TABLE.DIALOG.EXPORT.DESCRIPTION' | oTranslate }}</div>\n  <mat-button-toggle-group class=\"type_toggle_group\" #group=\"matButtonToggleGroup\" [(ngModel)]=\"selectedExportFormat\">\n    <ng-container *ngFor=\"let button of exportTypes\">\n      <mat-button-toggle [value]=\"button.exportType\" *ngIf=\"isButtonVisible(button.exportType)\" class=\"button.className\">\n        <ng-container *ngTemplateOutlet=\"buttonTemplate;context:{button:button}\"></ng-container>\n      </mat-button-toggle>\n    </ng-container>\n\n    <ng-container *ngFor=\"let customButton of config.options\">\n      <mat-button-toggle [value]=\"customButton.exportType\">\n        <ng-container *ngTemplateOutlet=\"buttonTemplate;context:{button:customButton}\"></ng-container>\n      </mat-button-toggle>\n    </ng-container>\n  </mat-button-toggle-group>\n  <mat-expansion-panel class=\"acordion\" [expanded]=\"isExpanded\">\n    <mat-expansion-panel-header collapsedHeight=\"32px\" expandedHeight=\"32px\">\n      <mat-panel-title>\n        {{ 'EXPORT.DIALOG.ADVANCED_OPTIONS' | oTranslate }}\n      </mat-panel-title>\n    </mat-expansion-panel-header>\n    <div class=\"inputs_container\">\n      <mat-label class=\"dialog-titles\">{{'EXPORT.DIALOG.FILE_NAME'|oTranslate}}</mat-label>\n      <mat-form-field subscriptSizing=\"dynamic\" class=\"filename_input\">\n        <input matInput [(ngModel)]=\"filename\" placeholder=\"{{ 'EXPORT.DIALOG.FILE_NAME.PLACEHOLDER' | oTranslate }}\" />\n      </mat-form-field>\n      <span class=\"dialog-titles\">{{'EXPORT.DIALOG.ORIENTATION'|oTranslate}}</span>\n      <mat-radio-group name=\"Orientation\" [(ngModel)]=\"vertical\" fxLayout=\"row\" fxLayoutGap=\"12px\" [disabled]=\"selectedExportFormat !== 'pdf'\">\n        <mat-radio-button *ngFor=\"let orientation of orientations\" name=\"Orientation\" [value]=\"orientation.value\"\n          [checked]=\"vertical === orientation.value\">\n          {{ orientation.text | oTranslate}}\n        </mat-radio-button>\n      </mat-radio-group>\n      <span class=\"dialog-titles\">{{'EXPORT.DIALOG.COLUMNS'|oTranslate}}</span>\n      <mat-selection-list dense #columnsList cdkDropList [cdkDropListData]=\"columnsData\" (cdkDropListDropped)=\"dropColumns($event)\" class=\"columns\"\n        [(ngModel)]=\"columns\" [compareWith]=\"columnsCompareFunction\">\n        <mat-list-option checkboxPosition=\"before\" *ngFor=\"let column of columnsData\" [value]=\"column\" cdkDrag>\n          <div fxLayout=\"row\" fxLayoutAlign=\"space-around center\">\n            <span matListItemLine fxFlex>\n              {{column | oTranslate}}\n            </span>\n            <mat-icon mat-list-icon class=\"button-edit\">drag_handle</mat-icon>\n          </div>\n        </mat-list-option>\n      </mat-selection-list>\n\n    </div>\n  </mat-expansion-panel>\n</mat-dialog-content>\n\n<mat-dialog-actions fxLayoutAlign=\"end center\">\n  <button type=\"button\" mat-stroked-button [mat-dialog-close]=\"false\" class=\"o-button-default cancel\">{{ 'CANCEL' | oTranslate }}</button>\n  <button type=\"button\" mat-stroked-button class=\"export_button\" (click)=\"export()\">\n    <mat-icon>ios_share</mat-icon>\n    <span>{{ 'EXPORT.DIALOG.EXPORT_BUTTON' | oTranslate }}</span>\n  </button>\n</mat-dialog-actions>\n\n<ng-template #buttonTemplate let-button=\"button\">\n  <mat-icon class=\"material-icons o-button-icon\" *ngIf=\"button.icon!==undefined\" style=\"vertical-align:middle\">{{ button.icon }}</mat-icon>\n  <mat-icon class=\"material-icons o-button-icon\" *ngIf=\"button.svgIcon!==undefined\" style=\"vertical-align:middle\"\n    [svgIcon]=\"button.svgIcon\"></mat-icon>\n  {{ button.olabel | oTranslate }}\n</ng-template>\n"]}
183
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"o-table-export-dialog.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ontimize-web-ngx/src/lib/components/table/extensions/dialog/export/o-table-export-dialog.component.ts","../../../../../../../../projects/ontimize-web-ngx/src/lib/components/table/extensions/dialog/export/o-table-export-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import { HttpErrorResponse } from '@angular/common/http';\nimport { ChangeDetectionStrategy, Component, Inject, Injector, OnDestroy, OnInit, ViewEncapsulation } from '@angular/core';\nimport { MAT_DIALOG_DATA, MatDialogRef } from '@angular/material/dialog';\nimport { Subscription } from 'rxjs';\nimport { AppConfig } from '../../../../../config/app-config';\n\nimport { CdkDragDrop, moveItemInArray } from '@angular/cdk/drag-drop';\nimport { IExportService } from '../../../../../interfaces/export-service.interface';\nimport { OntimizeExportServiceProvider } from '../../../../../services/factories';\nimport { OntimizeExportService } from '../../../../../services/ontimize/ontimize-export.service';\nimport { SnackBarService } from '../../../../../services/snackbar.service';\nimport { OTranslateService } from '../../../../../services/translate/o-translate.service';\nimport { Codes } from '../../../../../util/codes';\nimport { Util } from '../../../../../util/util';\nimport { OTableExportButtonService } from '../../export-button/o-table-export-button.service';\nimport { OTableExportConfiguration } from '../../header/table-menu/o-table-export-configuration.class';\nimport { MatButtonToggleChange } from '@angular/material/button-toggle';\n\n@Component({\n  selector: 'o-table-export-dialog',\n  templateUrl: 'o-table-export-dialog.component.html',\n  styleUrls: ['o-table-export-dialog.component.scss'],\n  providers: [\n    OntimizeExportServiceProvider\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  host: {\n    class: 'o-table-export-dialog'\n  },\n  encapsulation: ViewEncapsulation.None\n})\nexport class OTableExportDialogComponent implements OnInit, OnDestroy {\n\n  protected snackBarService: SnackBarService;\n  protected exportService: IExportService;\n  protected translateService: OTranslateService;\n  protected oTableExportButtonService: OTableExportButtonService;\n  protected visibleButtons: string[];\n  private subscription: Subscription = new Subscription();\n  private appConfig: AppConfig;\n  columns: string[];\n  columnsData: string[];\n  public orientations = [{ text: \"EXPORT.DIALOG.VERTICAL\", value: true }, { text: \"EXPORT.DIALOG.HORIZONTAL\", value: false }];\n  public exportTypes = [{\n    exportType: 'xlsx',\n    svgIcon: 'ontimize:EXCEL',\n    olabel: 'TABLE.BUTTONS.EXCEL',\n    className: 'excel-button'\n  }, {\n    exportType: 'html',\n    svgIcon: 'ontimize:HTML',\n    olabel: 'TABLE.BUTTONS.HTML',\n    className: 'html-button'\n  }, {\n    exportType: 'pdf',\n    svgIcon: 'ontimize:PDF',\n    olabel: 'TABLE.BUTTONS.PDF',\n    className: 'pdf-button'\n  }, {\n    exportType: 'csv',\n    svgIcon: 'ontimize:CSV',\n    olabel: 'TABLE.BUTTONS.CSV',\n    className: 'csv-button'\n  }];\n  vertical: boolean = true;\n  selectedExportFormat: string;\n  filename: string = '';\n  isExpanded: boolean = false;\n  constructor(\n    public dialogRef: MatDialogRef<OTableExportDialogComponent>,\n    protected injector: Injector,\n    @Inject(MAT_DIALOG_DATA) public config: OTableExportConfiguration\n  ) {\n    this.snackBarService = injector.get(SnackBarService);\n    this.translateService = this.injector.get(OTranslateService);\n    this.oTableExportButtonService = this.injector.get(OTableExportButtonService);\n    this.appConfig = this.injector.get(AppConfig);\n    this.selectedExportFormat = this.getDefaultSelection();\n\n    if (config && Util.isDefined(config.visibleButtons)) {\n      this.visibleButtons = Util.parseArray(config.visibleButtons.toLowerCase(), true);\n    }\n  }\n\n  ngOnInit() {\n    this.initialize();\n  }\n\n  ngOnDestroy() {\n    this.subscription.unsubscribe();\n  }\n\n  initialize(): void {\n    this.columnsData = this.config.columns;\n    this.columns = [...this.columnsData];\n    this.configureService();\n  }\n\n  configureService(): void {\n    let loadingService: any = OntimizeExportService;\n    if (this.config.serviceType) {\n      loadingService = this.config.serviceType;\n    }\n    this.exportService = this.injector.get(loadingService);\n    const serviceCfg = this.exportService.getDefaultServiceConfiguration(this.config.service);\n    this.exportService.configureService(serviceCfg);\n  }\n  updateColumnsSort() {\n    this.columns.sort((a: any, b: any) => {\n      let indexA = this.columnsData.findIndex(x => x === a);\n      let indexB = this.columnsData.findIndex(x => x === b);\n      return indexA - indexB;\n    });\n  }\n\n  dropColumns(event: CdkDragDrop<string[]>) {\n    moveItemInArray(this.columnsData, event.previousIndex, event.currentIndex);\n    this.updateColumnsSort();\n  }\n\n  columnsCompareFunction(co1: any, co2: any) {\n    return co1.id === co2.id;\n  }\n\n  export(): void {\n    this.dialogRef.close(true);\n\n    const exportFunction = this.getCustomExportButton(this.selectedExportFormat)?.exportFunction;\n\n    if (exportFunction) {\n      exportFunction(this.columns, !this.vertical, this.filename);\n      return;\n    }\n\n    const onClickEvent = this.getCustomExportButton(this.selectedExportFormat)?.onClick;\n    if (onClickEvent.observers.length > 0) {\n      console.warn(\n        '⚠️ [DEPRECATED] The onClick event is deprecated. Use the input export-function instead.'\n      );\n      this.getCustomExportButton(this.selectedExportFormat)?.onClick.emit();\n      return;\n    }\n\n\n    this.exportService.exportData(this.selectedExportFormat, this.columns, !this.vertical, this.filename).subscribe({\n      next: () => {\n        this.snackBarService.open('MESSAGES.SUCCESS_EXPORT_TABLE_DATA', { icon: 'check_circle' });\n      },\n      error: (err: any) => {\n        this.handleError(err);\n      }\n    }\n    );\n  }\n\n  isButtonVisible(btn: string): boolean {\n\n    const useExportConfiguration3X = this.appConfig.useExportConfiguration();\n    let isVisible = true;\n    if (this.visibleButtons) {\n      isVisible = this.visibleButtons.indexOf(btn) !== -1;\n    } else {\n      if (useExportConfiguration3X) {\n        isVisible = Codes.VISIBLE_EXPORT_BUTTONS3X.indexOf(btn) !== -1;\n      } else {\n        isVisible = Codes.VISIBLE_EXPORT_BUTTONS.indexOf(btn) !== -1\n      }\n    }\n\n    return isVisible;\n  }\n\n  getDefaultSelection() {\n    const useExportConfiguration3X = this.appConfig.useExportConfiguration();\n\n    if (useExportConfiguration3X) {\n      return Codes.VISIBLE_EXPORT_BUTTONS3X[0];\n    } else {\n      return Codes.VISIBLE_EXPORT_BUTTONS[0];\n    }\n\n  }\n\n  protected handleError(err): void {\n    if (err instanceof HttpErrorResponse) {\n      this.snackBarService.open(err.message, { icon: 'error' });\n    } else {\n      this.snackBarService.open('MESSAGES.ERROR_EXPORT_TABLE_DATA', { icon: 'error' });\n    }\n  }\n\n  onChangeMatButtonToggleGroup(event: MatButtonToggleChange) {\n    event.source.buttonToggleGroup.value = event.value;\n    this.selectedExportFormat = event.value;\n  }\n\n  getCustomExportButton(type: string) {\n    return this.config.options.find(x => x.exportType === type);\n  }\n}\n","<span mat-dialog-title>{{ 'TABLE.BUTTONS.EXPORT' | oTranslate }}</span>\n<mat-dialog-content class=\"dialog_content\">\n  <div mat-subheader>{{ 'TABLE.DIALOG.EXPORT.DESCRIPTION' | oTranslate }}</div>\n  <mat-button-toggle-group class=\"type_toggle_group\" #group=\"matButtonToggleGroup\" [(ngModel)]=\"selectedExportFormat\">\n    <ng-container *ngFor=\"let button of exportTypes\">\n      <mat-button-toggle [value]=\"button.exportType\" *ngIf=\"isButtonVisible(button.exportType)\" class=\"button.className\">\n        <ng-container *ngTemplateOutlet=\"buttonTemplate;context:{button:button}\"></ng-container>\n      </mat-button-toggle>\n    </ng-container>\n\n    <ng-container *ngFor=\"let customButton of config.options\">\n      <mat-button-toggle [value]=\"customButton.exportType\">\n        <ng-container *ngTemplateOutlet=\"buttonTemplate;context:{button:customButton}\"></ng-container>\n      </mat-button-toggle>\n    </ng-container>\n  </mat-button-toggle-group>\n  <mat-expansion-panel class=\"acordion\" [expanded]=\"isExpanded\">\n    <mat-expansion-panel-header collapsedHeight=\"32px\" expandedHeight=\"32px\">\n      <mat-panel-title>\n        {{ 'EXPORT.DIALOG.ADVANCED_OPTIONS' | oTranslate }}\n      </mat-panel-title>\n    </mat-expansion-panel-header>\n    <div class=\"inputs_container\">\n      <mat-label class=\"dialog-titles\">{{'EXPORT.DIALOG.FILE_NAME'|oTranslate}}</mat-label>\n      <mat-form-field subscriptSizing=\"dynamic\" class=\"filename_input\">\n        <input matInput [(ngModel)]=\"filename\" placeholder=\"{{ 'EXPORT.DIALOG.FILE_NAME.PLACEHOLDER' | oTranslate }}\" />\n      </mat-form-field>\n      <span class=\"dialog-titles\">{{'EXPORT.DIALOG.ORIENTATION'|oTranslate}}</span>\n      <mat-radio-group name=\"Orientation\" [(ngModel)]=\"vertical\" fxLayout=\"row\" fxLayoutGap=\"12px\" [disabled]=\"selectedExportFormat !== 'pdf'\">\n        <mat-radio-button *ngFor=\"let orientation of orientations\" name=\"Orientation\" [value]=\"orientation.value\"\n          [checked]=\"vertical === orientation.value\">\n          {{ orientation.text | oTranslate}}\n        </mat-radio-button>\n      </mat-radio-group>\n      <span class=\"dialog-titles\">{{'EXPORT.DIALOG.COLUMNS'|oTranslate}}</span>\n      <mat-selection-list dense #columnsList cdkDropList [cdkDropListData]=\"columnsData\" (cdkDropListDropped)=\"dropColumns($event)\" class=\"columns\"\n        [(ngModel)]=\"columns\" [compareWith]=\"columnsCompareFunction\">\n        <mat-list-option checkboxPosition=\"before\" *ngFor=\"let column of columnsData\" [value]=\"column\" cdkDrag>\n          <div fxLayout=\"row\" fxLayoutAlign=\"space-around center\">\n            <span matListItemLine fxFlex>\n              {{column | oTranslate}}\n            </span>\n            <mat-icon mat-list-icon class=\"button-edit\">drag_handle</mat-icon>\n          </div>\n        </mat-list-option>\n      </mat-selection-list>\n\n    </div>\n  </mat-expansion-panel>\n</mat-dialog-content>\n\n<mat-dialog-actions fxLayoutAlign=\"end center\">\n  <button type=\"button\" mat-stroked-button [mat-dialog-close]=\"false\" class=\"o-button-default cancel\">{{ 'CANCEL' | oTranslate }}</button>\n  <button type=\"button\" mat-stroked-button class=\"export_button\" (click)=\"export()\">\n    <mat-icon>ios_share</mat-icon>\n    <span>{{ 'EXPORT.DIALOG.EXPORT_BUTTON' | oTranslate }}</span>\n  </button>\n</mat-dialog-actions>\n\n<ng-template #buttonTemplate let-button=\"button\">\n  <mat-icon class=\"material-icons o-button-icon\" *ngIf=\"button.icon!==undefined\" style=\"vertical-align:middle\">{{ button.icon }}</mat-icon>\n  <mat-icon class=\"material-icons o-button-icon\" *ngIf=\"button.svgIcon!==undefined\" style=\"vertical-align:middle\"\n    [svgIcon]=\"button.svgIcon\"></mat-icon>\n  {{ button.olabel | oTranslate }}\n</ng-template>\n"]}
@@ -5,7 +5,8 @@ export const DEFAULT_INPUTS_O_TABLE_EXPORT_BUTTON = [
5
5
  'icon',
6
6
  'svgIcon : svg-icon',
7
7
  'olabel: label',
8
- 'exportType: export-type'
8
+ 'exportType: export-type',
9
+ 'exportFunction: export-function'
9
10
  ];
10
11
  export const DEFAULT_OUTPUTS_O_TABLE_EXPORT_BUTTON = [
11
12
  'onClick'
@@ -16,13 +17,9 @@ export class OTableExportButtonComponent {
16
17
  this.onClick = new EventEmitter();
17
18
  this.oTableExportButtonService = this.injector.get(OTableExportButtonService);
18
19
  }
19
- click() {
20
- this.onClick.emit(this.exportType);
21
- this.oTableExportButtonService.export$.next(this.exportType);
22
- }
23
20
  }
24
21
  OTableExportButtonComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: OTableExportButtonComponent, deps: [{ token: i0.Injector }], target: i0.ɵɵFactoryTarget.Directive });
25
- OTableExportButtonComponent.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.10", type: OTableExportButtonComponent, selector: "o-table-export-button", inputs: { icon: "icon", svgIcon: ["svg-icon", "svgIcon"], olabel: ["label", "olabel"], exportType: ["export-type", "exportType"] }, outputs: { onClick: "onClick" }, ngImport: i0 });
22
+ OTableExportButtonComponent.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.10", type: OTableExportButtonComponent, selector: "o-table-export-button", inputs: { icon: "icon", svgIcon: ["svg-icon", "svgIcon"], olabel: ["label", "olabel"], exportType: ["export-type", "exportType"], exportFunction: ["export-function", "exportFunction"] }, outputs: { onClick: "onClick" }, ngImport: i0 });
26
23
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: OTableExportButtonComponent, decorators: [{
27
24
  type: Directive,
28
25
  args: [{
@@ -31,4 +28,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
31
28
  outputs: DEFAULT_OUTPUTS_O_TABLE_EXPORT_BUTTON
32
29
  }]
33
30
  }], ctorParameters: function () { return [{ type: i0.Injector }]; } });
34
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiby10YWJsZS1leHBvcnQtYnV0dG9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL29udGltaXplLXdlYi1uZ3gvc3JjL2xpYi9jb21wb25lbnRzL3RhYmxlL2V4dGVuc2lvbnMvZXhwb3J0LWJ1dHRvbi9vLXRhYmxlLWV4cG9ydC1idXR0b24uY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUVsRSxPQUFPLEVBQUUseUJBQXlCLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQzs7QUFFNUUsTUFBTSxDQUFDLE1BQU0sb0NBQW9DLEdBQUc7SUFDbEQsTUFBTTtJQUNOLG9CQUFvQjtJQUNwQixlQUFlO0lBQ2YseUJBQXlCO0NBQzFCLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxxQ0FBcUMsR0FBRztJQUNuRCxTQUFTO0NBQ1YsQ0FBQztBQU9GLE1BQU0sT0FBTywyQkFBMkI7SUFTdEMsWUFDbUIsUUFBa0I7UUFBbEIsYUFBUSxHQUFSLFFBQVEsQ0FBVTtRQUw5QixZQUFPLEdBQXNCLElBQUksWUFBWSxFQUFFLENBQUM7UUFPckQsSUFBSSxDQUFDLHlCQUF5QixHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLHlCQUF5QixDQUFDLENBQUM7SUFDaEYsQ0FBQztJQUVELEtBQUs7UUFDSCxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUM7UUFDbkMsSUFBSSxDQUFDLHlCQUF5QixDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDO0lBQy9ELENBQUM7O3lIQWxCVSwyQkFBMkI7NkdBQTNCLDJCQUEyQjs0RkFBM0IsMkJBQTJCO2tCQUx2QyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSx1QkFBdUI7b0JBQ2pDLE1BQU0sRUFBRSxvQ0FBb0M7b0JBQzVDLE9BQU8sRUFBRSxxQ0FBcUM7aUJBQy9DIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBFdmVudEVtaXR0ZXIsIEluamVjdG9yIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IE9UYWJsZUV4cG9ydEJ1dHRvblNlcnZpY2UgfSBmcm9tICcuL28tdGFibGUtZXhwb3J0LWJ1dHRvbi5zZXJ2aWNlJztcblxuZXhwb3J0IGNvbnN0IERFRkFVTFRfSU5QVVRTX09fVEFCTEVfRVhQT1JUX0JVVFRPTiA9IFtcbiAgJ2ljb24nLFxuICAnc3ZnSWNvbiA6IHN2Zy1pY29uJyxcbiAgJ29sYWJlbDogbGFiZWwnLFxuICAnZXhwb3J0VHlwZTogZXhwb3J0LXR5cGUnXG5dO1xuXG5leHBvcnQgY29uc3QgREVGQVVMVF9PVVRQVVRTX09fVEFCTEVfRVhQT1JUX0JVVFRPTiA9IFtcbiAgJ29uQ2xpY2snXG5dO1xuXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdvLXRhYmxlLWV4cG9ydC1idXR0b24nLFxuICBpbnB1dHM6IERFRkFVTFRfSU5QVVRTX09fVEFCTEVfRVhQT1JUX0JVVFRPTixcbiAgb3V0cHV0czogREVGQVVMVF9PVVRQVVRTX09fVEFCTEVfRVhQT1JUX0JVVFRPTlxufSlcbmV4cG9ydCBjbGFzcyBPVGFibGVFeHBvcnRCdXR0b25Db21wb25lbnQge1xuXG4gIHB1YmxpYyBpY29uOiBzdHJpbmc7XG4gIHB1YmxpYyBzdmdJY29uOiBzdHJpbmc7XG4gIHB1YmxpYyBvbGFiZWw6IHN0cmluZztcbiAgcHVibGljIG9uQ2xpY2s6IEV2ZW50RW1pdHRlcjxhbnk+ID0gbmV3IEV2ZW50RW1pdHRlcigpO1xuICBwcm90ZWN0ZWQgZXhwb3J0VHlwZTogc3RyaW5nO1xuICBwcm90ZWN0ZWQgb1RhYmxlRXhwb3J0QnV0dG9uU2VydmljZTogT1RhYmxlRXhwb3J0QnV0dG9uU2VydmljZTtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIHJlYWRvbmx5IGluamVjdG9yOiBJbmplY3RvclxuICApIHtcbiAgICB0aGlzLm9UYWJsZUV4cG9ydEJ1dHRvblNlcnZpY2UgPSB0aGlzLmluamVjdG9yLmdldChPVGFibGVFeHBvcnRCdXR0b25TZXJ2aWNlKTtcbiAgfVxuXG4gIGNsaWNrKCkge1xuICAgIHRoaXMub25DbGljay5lbWl0KHRoaXMuZXhwb3J0VHlwZSk7XG4gICAgdGhpcy5vVGFibGVFeHBvcnRCdXR0b25TZXJ2aWNlLmV4cG9ydCQubmV4dCh0aGlzLmV4cG9ydFR5cGUpO1xuICB9XG5cbn1cbiJdfQ==
31
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiby10YWJsZS1leHBvcnQtYnV0dG9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL29udGltaXplLXdlYi1uZ3gvc3JjL2xpYi9jb21wb25lbnRzL3RhYmxlL2V4dGVuc2lvbnMvZXhwb3J0LWJ1dHRvbi9vLXRhYmxlLWV4cG9ydC1idXR0b24uY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUVsRSxPQUFPLEVBQUUseUJBQXlCLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQzs7QUFFNUUsTUFBTSxDQUFDLE1BQU0sb0NBQW9DLEdBQUc7SUFDbEQsTUFBTTtJQUNOLG9CQUFvQjtJQUNwQixlQUFlO0lBQ2YseUJBQXlCO0lBQ3pCLGlDQUFpQztDQUNsQyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0scUNBQXFDLEdBQUc7SUFDbkQsU0FBUztDQUNWLENBQUM7QUFPRixNQUFNLE9BQU8sMkJBQTJCO0lBZ0J0QyxZQUNtQixRQUFrQjtRQUFsQixhQUFRLEdBQVIsUUFBUSxDQUFVO1FBTjlCLFlBQU8sR0FBc0IsSUFBSSxZQUFZLEVBQUUsQ0FBQztRQVFyRCxJQUFJLENBQUMseUJBQXlCLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMseUJBQXlCLENBQUMsQ0FBQztJQUNoRixDQUFDOzt5SEFwQlUsMkJBQTJCOzZHQUEzQiwyQkFBMkI7NEZBQTNCLDJCQUEyQjtrQkFMdkMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsdUJBQXVCO29CQUNqQyxNQUFNLEVBQUUsb0NBQW9DO29CQUM1QyxPQUFPLEVBQUUscUNBQXFDO2lCQUMvQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgRXZlbnRFbWl0dGVyLCBJbmplY3RvciB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBPVGFibGVFeHBvcnRCdXR0b25TZXJ2aWNlIH0gZnJvbSAnLi9vLXRhYmxlLWV4cG9ydC1idXR0b24uc2VydmljZSc7XG5cbmV4cG9ydCBjb25zdCBERUZBVUxUX0lOUFVUU19PX1RBQkxFX0VYUE9SVF9CVVRUT04gPSBbXG4gICdpY29uJyxcbiAgJ3N2Z0ljb24gOiBzdmctaWNvbicsXG4gICdvbGFiZWw6IGxhYmVsJyxcbiAgJ2V4cG9ydFR5cGU6IGV4cG9ydC10eXBlJyxcbiAgJ2V4cG9ydEZ1bmN0aW9uOiBleHBvcnQtZnVuY3Rpb24nXG5dO1xuXG5leHBvcnQgY29uc3QgREVGQVVMVF9PVVRQVVRTX09fVEFCTEVfRVhQT1JUX0JVVFRPTiA9IFtcbiAgJ29uQ2xpY2snXG5dO1xuXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdvLXRhYmxlLWV4cG9ydC1idXR0b24nLFxuICBpbnB1dHM6IERFRkFVTFRfSU5QVVRTX09fVEFCTEVfRVhQT1JUX0JVVFRPTixcbiAgb3V0cHV0czogREVGQVVMVF9PVVRQVVRTX09fVEFCTEVfRVhQT1JUX0JVVFRPTlxufSlcbmV4cG9ydCBjbGFzcyBPVGFibGVFeHBvcnRCdXR0b25Db21wb25lbnQge1xuXG4gIHB1YmxpYyBpY29uOiBzdHJpbmc7XG4gIHB1YmxpYyBzdmdJY29uOiBzdHJpbmc7XG4gIHB1YmxpYyBvbGFiZWw6IHN0cmluZztcblxuICAvKipcbiAgICogQGRlcHJlY2F0ZWQgVGhpcyBldmVudCBpcyBkZXByZWNhdGVkIGFuZCB3aWxsIGJlIHJlbW92ZWQgaW4gZnV0dXJlIHZlcnNpb25zLlxuICAgKiBQbGVhc2UgdXNlIGBleHBvcnQtZnVuY3Rpb25gIGluc3RlYWQuXG4gICAqL1xuXG4gIHB1YmxpYyBvbkNsaWNrOiBFdmVudEVtaXR0ZXI8YW55PiA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcbiAgcHVibGljIGV4cG9ydEZ1bmN0aW9uOiAoKSA9PiB2b2lkO1xuICBwcm90ZWN0ZWQgZXhwb3J0VHlwZTogc3RyaW5nO1xuICBwcm90ZWN0ZWQgb1RhYmxlRXhwb3J0QnV0dG9uU2VydmljZTogT1RhYmxlRXhwb3J0QnV0dG9uU2VydmljZTtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIHJlYWRvbmx5IGluamVjdG9yOiBJbmplY3RvclxuICApIHtcbiAgICB0aGlzLm9UYWJsZUV4cG9ydEJ1dHRvblNlcnZpY2UgPSB0aGlzLmluamVjdG9yLmdldChPVGFibGVFeHBvcnRCdXR0b25TZXJ2aWNlKTtcbiAgfVxuXG5cbn1cbiJdfQ==