ontimize-web-ngx 15.4.3 → 15.4.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.
@@ -110,7 +110,7 @@ export class OTableExportDialogComponent {
110
110
  return;
111
111
  }
112
112
  const onClickEvent = this.getCustomExportButton(this.selectedExportFormat)?.onClick;
113
- if (onClickEvent.observers.length > 0) {
113
+ if (onClickEvent?.observers?.length > 0) {
114
114
  console.warn('⚠️ [DEPRECATED] The onClick event is deprecated. Use the input export-function instead.');
115
115
  this.getCustomExportButton(this.selectedExportFormat)?.onClick.emit();
116
116
  return;
@@ -180,4 +180,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
180
180
  type: Inject,
181
181
  args: [MAT_DIALOG_DATA]
182
182
  }] }]; } });
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"]}
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"]}