ngx-st-tables 17.0.115 → 17.0.117

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.
@@ -78,6 +78,7 @@ export class MaterialTableRowCellComponent {
78
78
  }
79
79
  else if (this.matSelect) {
80
80
  // Open MatSelect dropdown
81
+ this.matSelect.focus();
81
82
  this.matSelect.open();
82
83
  }
83
84
  }, 150);
@@ -131,4 +132,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
131
132
  }], rowEditing: [{
132
133
  type: Input
133
134
  }] } });
134
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"material-table-row-cell.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-st-tables/src/lib/components/material-table/material-table-row-cell/material-table-row-cell.component.ts","../../../../../../../projects/ngx-st-tables/src/lib/components/material-table/material-table-row-cell/material-table-row-cell.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  Input,\r\n  OnInit,\r\n  input,\r\n  output,\r\n  signal,\r\n  ViewChild,\r\n  AfterViewInit,\r\n} from '@angular/core';\r\nimport { StMaterialTableColumnModel } from '../../../models/st-material-table-column.model';\r\nimport { MatInput } from '@angular/material/input';\r\nimport { MatSelect } from '@angular/material/select';\r\n\r\n@Component({\r\n  selector: 'st-material-table-row-cell',\r\n  templateUrl: './material-table-row-cell.component.html',\r\n  styleUrls: ['./material-table-row-cell.component.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class MaterialTableRowCellComponent implements OnInit, AfterViewInit {\r\n  @ViewChild(MatInput) matInput?: MatInput;\r\n  @ViewChild(MatSelect) matSelect?: MatSelect;\r\n  column = input.required<StMaterialTableColumnModel>();\r\n\r\n  rowData = input.required<{\r\n    [prop: string]: any;\r\n  }>();\r\n\r\n  rowIndex = input.required<number>();\r\n\r\n  rowDataCopy = input<{\r\n    [prop: string]: any;\r\n  }>();\r\n\r\n  canEditRowValidator = input<(row: any) => boolean>(() => true);\r\n\r\n  canDeleteRowValidator = input<(row: any) => boolean>(() => true);\r\n\r\n  selectRowOnlyOne = input<boolean>(false);\r\n\r\n  isFirstEditableColumn = input<boolean>(false);\r\n\r\n  autoSaveOnChange = input<boolean>(false);\r\n\r\n  @Input()\r\n  set rowEditing(data: boolean) {\r\n    const wasNotEditing = !this._rowEditing;\r\n    this._rowEditing = data;\r\n\r\n    if (data) {\r\n      this.getDynamicSelectData();\r\n\r\n      // Focus first editable field when entering edit mode\r\n      if (wasNotEditing && this.isFirstEditableColumn()) {\r\n        this.focusFirstEditableField();\r\n      }\r\n    }\r\n  }\r\n\r\n  get rowEditing(): boolean {\r\n    return this._rowEditing;\r\n  }\r\n\r\n  private _rowEditing: boolean = false;\r\n\r\n  rowIsSelected = input<boolean>(false);\r\n\r\n  rowIsExpanded = input<boolean>(false);\r\n\r\n  saveEditRowEmitter = output<void>();\r\n\r\n  cancelEditRowEmitter = output<void>();\r\n\r\n  editRowEmitter = output<void>();\r\n\r\n  deleteRowEmitter = output<void>();\r\n\r\n  selectRowChange = output<boolean>();\r\n\r\n  fieldValueChanged = output<{ field: string; value: any }>();\r\n\r\n  mobileView = false;\r\n\r\n  actionIconColorDef: {\r\n    [key: string]: 'primary' | 'warn';\r\n  } = {\r\n    edit: 'primary',\r\n    delete: 'warn',\r\n  };\r\n\r\n  dynamicSelectOptions = signal<{ value: any; label: string }[]>([]);\r\n\r\n  constructor(private changeDetectorRef: ChangeDetectorRef) {}\r\n\r\n  ngOnInit() {\r\n    window.addEventListener('resize', event => {\r\n      this.checkWidthSize();\r\n    });\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    // If row is already in edit mode on init (e.g., newly added row), focus the field\r\n    if (this.rowEditing && this.isFirstEditableColumn()) {\r\n      this.focusFirstEditableField();\r\n    }\r\n  }\r\n\r\n  private focusFirstEditableField() {\r\n    // Use setTimeout to ensure the view is fully rendered\r\n    setTimeout(() => {\r\n      if (this.matInput) {\r\n        // Focus MatInput\r\n        this.matInput.focus();\r\n      } else if (this.matSelect) {\r\n        // Open MatSelect dropdown\r\n        this.matSelect.open();\r\n      }\r\n    }, 150);\r\n  }\r\n\r\n  saveRow() {\r\n    this.saveEditRowEmitter.emit();\r\n  }\r\n\r\n  cancelRow() {\r\n    this.cancelEditRowEmitter.emit();\r\n  }\r\n\r\n  editRow() {\r\n    this.editRowEmitter.emit();\r\n  }\r\n\r\n  deleteRow() {\r\n    this.deleteRowEmitter.emit();\r\n  }\r\n\r\n  selectRow(event: { checked: boolean }) {\r\n    if (event) {\r\n      this.selectRowChange.emit(event.checked);\r\n    }\r\n  }\r\n\r\n  onFieldChange(field: string, value: any) {\r\n    if (this.autoSaveOnChange()) {\r\n      this.fieldValueChanged.emit({ field, value });\r\n    }\r\n  }\r\n\r\n  private checkWidthSize() {\r\n    this.mobileView = document.body.clientWidth <= 1100;\r\n    this.changeDetectorRef.markForCheck();\r\n  }\r\n\r\n  private getDynamicSelectData() {\r\n    if (\r\n      this.column() &&\r\n      this.column().allowEditColumn &&\r\n      this.column().rowEditType === 'custom-dynamic-select' &&\r\n      this.column().dynamicRowEditOptions\r\n    ) {\r\n      this.dynamicSelectOptions.set(\r\n        this.column().dynamicRowEditOptions!(this.rowData())\r\n      );\r\n    }\r\n  }\r\n}\r\n","@switch (column().type || 'string') {\r\n  @case ('custom-template') {\r\n    @if (rowEditing && column().allowEditColumn) {\r\n      <ng-container\r\n        *ngTemplateOutlet=\"baseFieldCell; context: { $implicit: column() }\"\r\n      ></ng-container>\r\n    } @else {\r\n      <ng-container\r\n        [ngTemplateOutlet]=\"column().customTemplate!\"\r\n        [ngTemplateOutletContext]=\"{ data: rowData() }\"\r\n      ></ng-container>\r\n    }\r\n  }\r\n\r\n  @case ('actions') {\r\n    @if (column().actions) {\r\n      @if (\r\n        (!column().actionsInMenu && !mobileView) ||\r\n        (mobileView && column().actions!.length <= 1)\r\n      ) {\r\n        <div [ngStyle]=\"{ float: column().flexRight ? 'right' : 'none' }\">\r\n          @for (action of column().actions; track action) {\r\n            @if ((action.show && action.show(rowData())) || !action.show) {\r\n              @if (!action.url && action.action) {\r\n                <button\r\n                  class=\"action-icon-button\"\r\n                  type=\"button\"\r\n                  mat-icon-button\r\n                  [color]=\"\r\n                    actionIconColorDef[action.iconName]\r\n                      ? actionIconColorDef[action.iconName]\r\n                      : action.iconColor\r\n                  \"\r\n                  [matTooltip]=\"action.tooltipName || ''\"\r\n                  [matTooltipDisabled]=\"!action.tooltipName\"\r\n                  (click)=\"\r\n                    $event.stopPropagation();\r\n                    action.action!(rowData(), rowIndex())\r\n                  \"\r\n                >\r\n                  <mat-icon>{{ action.iconName }}</mat-icon>\r\n                </button>\r\n              }\r\n              @if (action.url) {\r\n                <a [routerLink]=\"action.url\">\r\n                  <button\r\n                    class=\"action-icon-button\"\r\n                    type=\"button\"\r\n                    mat-icon-button\r\n                    [color]=\"\r\n                      actionIconColorDef[action.iconName]\r\n                        ? actionIconColorDef[action.iconName]\r\n                        : action.iconColor\r\n                    \"\r\n                    [matTooltip]=\"action.tooltipName || ''\"\r\n                    [matTooltipDisabled]=\"!action.tooltipName\"\r\n                  >\r\n                    <mat-icon>{{ action.iconName }}</mat-icon>\r\n                  </button>\r\n                </a>\r\n              }\r\n            }\r\n          }\r\n        </div>\r\n      }\r\n      @if (\r\n        column().actionsInMenu || (mobileView && column().actions!.length > 1)\r\n      ) {\r\n        <button\r\n          type=\"button\"\r\n          mat-icon-button\r\n          [matMenuTriggerFor]=\"menu\"\r\n          (click)=\"$event.stopPropagation()\"\r\n        >\r\n          <mat-icon>more_vert</mat-icon>\r\n        </button>\r\n        <mat-menu #menu=\"matMenu\">\r\n          @for (action of column().actions; track action) {\r\n            @if ((action.show && action.show(rowData())) || !action.show) {\r\n              @if (!action.url && action.action) {\r\n                <button\r\n                  type=\"button\"\r\n                  mat-menu-item\r\n                  (click)=\"$event.stopPropagation(); action.action!(rowData())\"\r\n                >\r\n                  {{ action.tooltipName }}\r\n                </button>\r\n              }\r\n              @if (action.url) {\r\n                <a [routerLink]=\"action.url\">\r\n                  <button type=\"button\" mat-menu-item>\r\n                    {{ action.tooltipName }}\r\n                  </button>\r\n                </a>\r\n              }\r\n            }\r\n          }\r\n        </mat-menu>\r\n      }\r\n    }\r\n  }\r\n\r\n  @case ('string') {\r\n    <ng-container\r\n      *ngTemplateOutlet=\"baseFieldCell; context: { $implicit: column() }\"\r\n    ></ng-container>\r\n  }\r\n\r\n  @case ('number') {\r\n    <ng-container\r\n      *ngTemplateOutlet=\"baseFieldCell; context: { $implicit: column() }\"\r\n    ></ng-container>\r\n  }\r\n\r\n  @case ('boolean') {\r\n    <ng-container\r\n      *ngTemplateOutlet=\"baseFieldCell; context: { $implicit: column() }\"\r\n    ></ng-container>\r\n  }\r\n\r\n  @case ('date') {\r\n    @if (rowEditing && column().allowEditColumn) {\r\n      <ng-container\r\n        *ngTemplateOutlet=\"baseFieldCell; context: { $implicit: column() }\"\r\n      ></ng-container>\r\n    } @else {\r\n      {{ rowData()[column().field] | stDateTimeFormatPipe }}\r\n    }\r\n  }\r\n\r\n  @case ('actions-row-editing') {\r\n    <div class=\"row justify-content-end\">\r\n      @if (rowEditing) {\r\n        <button\r\n          type=\"button\"\r\n          mat-icon-button\r\n          color=\"accent\"\r\n          (click)=\"saveRow()\"\r\n          [matTooltip]=\"'Save row'\"\r\n        >\r\n          <mat-icon>done</mat-icon>\r\n        </button>\r\n        <button\r\n          type=\"button\"\r\n          mat-icon-button\r\n          color=\"warn\"\r\n          (click)=\"cancelRow()\"\r\n          [matTooltip]=\"'Cancel row'\"\r\n        >\r\n          <mat-icon>close</mat-icon>\r\n        </button>\r\n      } @else {\r\n        <button\r\n          type=\"button\"\r\n          mat-icon-button\r\n          color=\"primary\"\r\n          (click)=\"editRow()\"\r\n          [matTooltip]=\"'Edit row'\"\r\n          [disabled]=\"\r\n            canEditRowValidator() ? !canEditRowValidator()(rowData()) : false\r\n          \"\r\n        >\r\n          <mat-icon>edit</mat-icon>\r\n        </button>\r\n        <button\r\n          type=\"button\"\r\n          mat-icon-button\r\n          color=\"warn\"\r\n          (click)=\"deleteRow()\"\r\n          [matTooltip]=\"'Delete row'\"\r\n          [disabled]=\"\r\n            canDeleteRowValidator()\r\n              ? !canDeleteRowValidator()(rowData())\r\n              : false\r\n          \"\r\n        >\r\n          <mat-icon>delete</mat-icon>\r\n        </button>\r\n      }\r\n    </div>\r\n  }\r\n\r\n  @case ('actions-row-selecting') {\r\n    <!--    @if (selectRowOnlyOne()) {-->\r\n    <!--      <mat-radio-button-->\r\n    <!--        color=\"primary\"-->\r\n    <!--        (click)=\"$event.stopPropagation()\"-->\r\n    <!--        (change)=\"selectRow({ checked: true })\"-->\r\n    <!--        [checked]=\"rowIsSelected()\"-->\r\n    <!--      ></mat-radio-button>-->\r\n    <!--    } @else {-->\r\n    <mat-checkbox\r\n      color=\"primary\"\r\n      (click)=\"$event.stopPropagation()\"\r\n      (change)=\"selectRow($event)\"\r\n      [checked]=\"rowIsSelected()\"\r\n    ></mat-checkbox>\r\n    <!--    }-->\r\n  }\r\n\r\n  @case ('actions-row-extending') {\r\n    @if (rowIsExpanded()) {\r\n      <mat-icon>keyboard_arrow_up</mat-icon>\r\n    } @else {\r\n      <mat-icon>keyboard_arrow_down</mat-icon>\r\n    }\r\n  }\r\n}\r\n\r\n<ng-template #baseFieldCell let-column>\r\n  @if ((rowEditing || autoSaveOnChange()) && column.allowEditColumn) {\r\n    @if (column.rowEditType === 'string' || column.rowEditType === 'number') {\r\n      <mat-form-field\r\n        appearance=\"outline\"\r\n        [ngStyle]=\"{ width: column.width || 'auto' }\"\r\n      >\r\n        <input\r\n          matInput\r\n          [type]=\"column.rowEditType === 'string' ? 'text' : 'number'\"\r\n          [(ngModel)]=\"\r\n            autoSaveOnChange()\r\n              ? rowData()[column.field]\r\n              : rowDataCopy()![column.field]\r\n          \"\r\n          (ngModelChange)=\"\r\n            autoSaveOnChange() && onFieldChange(column.field, $event)\r\n          \"\r\n          (keydown.enter)=\"!autoSaveOnChange() && saveRow()\"\r\n          [required]=\"column.editColumnRequired\"\r\n        />\r\n      </mat-form-field>\r\n    }\r\n    @if (column.rowEditType === 'date') {\r\n      <mat-form-field\r\n        appearance=\"outline\"\r\n        [ngStyle]=\"{ width: column.width || 'auto' }\"\r\n      >\r\n        <input\r\n          matInput\r\n          [matDatepicker]=\"picker1\"\r\n          [(ngModel)]=\"\r\n            autoSaveOnChange()\r\n              ? rowData()[column.field]\r\n              : rowDataCopy()![column.field]\r\n          \"\r\n          (ngModelChange)=\"\r\n            autoSaveOnChange() && onFieldChange(column.field, $event)\r\n          \"\r\n          (keydown.enter)=\"!autoSaveOnChange() && saveRow()\"\r\n          [required]=\"column.editColumnRequired\"\r\n        />\r\n        <mat-datepicker-toggle\r\n          matIconSuffix\r\n          [for]=\"picker1\"\r\n        ></mat-datepicker-toggle>\r\n        <mat-datepicker #picker1></mat-datepicker>\r\n      </mat-form-field>\r\n    }\r\n    @if (column.rowEditType === 'boolean') {\r\n      <mat-checkbox\r\n        [(ngModel)]=\"\r\n          autoSaveOnChange()\r\n            ? rowData()[column.field]\r\n            : rowDataCopy()![column.field]\r\n        \"\r\n        (ngModelChange)=\"\r\n          autoSaveOnChange() && onFieldChange(column.field, $event)\r\n        \"\r\n      ></mat-checkbox>\r\n    }\r\n\r\n    @if (column.rowEditType === 'custom') {\r\n      <mat-form-field\r\n        appearance=\"outline\"\r\n        [ngStyle]=\"{ width: column.width || 'auto' }\"\r\n      >\r\n        <mat-select\r\n          [(ngModel)]=\"\r\n            autoSaveOnChange()\r\n              ? rowData()[column.field]\r\n              : rowDataCopy()![column.field]\r\n          \"\r\n          (ngModelChange)=\"\r\n            autoSaveOnChange() && onFieldChange(column.field, $event)\r\n          \"\r\n          [required]=\"column.editColumnRequired\"\r\n        >\r\n          <mat-option value=\"\"></mat-option>\r\n          @for (option of column.customRowEditOptions; track option) {\r\n            <mat-option [value]=\"option.value\">\r\n              {{ option.label }}\r\n            </mat-option>\r\n          }\r\n        </mat-select>\r\n      </mat-form-field>\r\n    }\r\n\r\n    @if (column.rowEditType === 'custom-dynamic-select') {\r\n      <mat-form-field\r\n        appearance=\"outline\"\r\n        [ngStyle]=\"{ width: column.width || 'auto' }\"\r\n      >\r\n        <mat-select\r\n          [(ngModel)]=\"\r\n            autoSaveOnChange()\r\n              ? rowData()[column.field]\r\n              : rowDataCopy()![column.field]\r\n          \"\r\n          (ngModelChange)=\"\r\n            autoSaveOnChange() && onFieldChange(column.field, $event)\r\n          \"\r\n          [required]=\"column.editColumnRequired\"\r\n        >\r\n          @if (!column.editColumnRequired) {\r\n            <mat-option value=\"\"></mat-option>\r\n          }\r\n\r\n          @for (option of dynamicSelectOptions(); track option) {\r\n            <mat-option [value]=\"option.value\">\r\n              {{ option.label }}\r\n            </mat-option>\r\n          }\r\n        </mat-select>\r\n      </mat-form-field>\r\n    }\r\n  } @else {\r\n    <div>\r\n      @if (column.translateValue) {\r\n        {{ column.translateValue![rowData()[column.field]] || '' }}\r\n      }\r\n      @if (column.customValueDisplay) {\r\n        {{ column.customValueDisplay(rowData()[column.field]) }}\r\n      }\r\n      @if (!column.translateValue && !column.customValueDisplay) {\r\n        {{ rowData()[column.field] }}\r\n      }\r\n    </div>\r\n  }\r\n</ng-template>\r\n"]}
135
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"material-table-row-cell.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-st-tables/src/lib/components/material-table/material-table-row-cell/material-table-row-cell.component.ts","../../../../../../../projects/ngx-st-tables/src/lib/components/material-table/material-table-row-cell/material-table-row-cell.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  Input,\r\n  OnInit,\r\n  input,\r\n  output,\r\n  signal,\r\n  ViewChild,\r\n  AfterViewInit,\r\n} from '@angular/core';\r\nimport { StMaterialTableColumnModel } from '../../../models/st-material-table-column.model';\r\nimport { MatInput } from '@angular/material/input';\r\nimport { MatSelect } from '@angular/material/select';\r\n\r\n@Component({\r\n  selector: 'st-material-table-row-cell',\r\n  templateUrl: './material-table-row-cell.component.html',\r\n  styleUrls: ['./material-table-row-cell.component.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class MaterialTableRowCellComponent implements OnInit, AfterViewInit {\r\n  @ViewChild(MatInput) matInput?: MatInput;\r\n  @ViewChild(MatSelect) matSelect?: MatSelect;\r\n  column = input.required<StMaterialTableColumnModel>();\r\n\r\n  rowData = input.required<{\r\n    [prop: string]: any;\r\n  }>();\r\n\r\n  rowIndex = input.required<number>();\r\n\r\n  rowDataCopy = input<{\r\n    [prop: string]: any;\r\n  }>();\r\n\r\n  canEditRowValidator = input<(row: any) => boolean>(() => true);\r\n\r\n  canDeleteRowValidator = input<(row: any) => boolean>(() => true);\r\n\r\n  selectRowOnlyOne = input<boolean>(false);\r\n\r\n  isFirstEditableColumn = input<boolean>(false);\r\n\r\n  autoSaveOnChange = input<boolean>(false);\r\n\r\n  @Input()\r\n  set rowEditing(data: boolean) {\r\n    const wasNotEditing = !this._rowEditing;\r\n    this._rowEditing = data;\r\n\r\n    if (data) {\r\n      this.getDynamicSelectData();\r\n\r\n      // Focus first editable field when entering edit mode\r\n      if (wasNotEditing && this.isFirstEditableColumn()) {\r\n        this.focusFirstEditableField();\r\n      }\r\n    }\r\n  }\r\n\r\n  get rowEditing(): boolean {\r\n    return this._rowEditing;\r\n  }\r\n\r\n  private _rowEditing: boolean = false;\r\n\r\n  rowIsSelected = input<boolean>(false);\r\n\r\n  rowIsExpanded = input<boolean>(false);\r\n\r\n  saveEditRowEmitter = output<void>();\r\n\r\n  cancelEditRowEmitter = output<void>();\r\n\r\n  editRowEmitter = output<void>();\r\n\r\n  deleteRowEmitter = output<void>();\r\n\r\n  selectRowChange = output<boolean>();\r\n\r\n  fieldValueChanged = output<{ field: string; value: any }>();\r\n\r\n  mobileView = false;\r\n\r\n  actionIconColorDef: {\r\n    [key: string]: 'primary' | 'warn';\r\n  } = {\r\n    edit: 'primary',\r\n    delete: 'warn',\r\n  };\r\n\r\n  dynamicSelectOptions = signal<{ value: any; label: string }[]>([]);\r\n\r\n  constructor(private changeDetectorRef: ChangeDetectorRef) {}\r\n\r\n  ngOnInit() {\r\n    window.addEventListener('resize', event => {\r\n      this.checkWidthSize();\r\n    });\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    // If row is already in edit mode on init (e.g., newly added row), focus the field\r\n    if (this.rowEditing && this.isFirstEditableColumn()) {\r\n      this.focusFirstEditableField();\r\n    }\r\n  }\r\n\r\n  private focusFirstEditableField() {\r\n    // Use setTimeout to ensure the view is fully rendered\r\n    setTimeout(() => {\r\n      if (this.matInput) {\r\n        // Focus MatInput\r\n        this.matInput.focus();\r\n      } else if (this.matSelect) {\r\n        // Open MatSelect dropdown\r\n        this.matSelect.focus();\r\n        this.matSelect.open();\r\n      }\r\n    }, 150);\r\n  }\r\n\r\n  saveRow() {\r\n    this.saveEditRowEmitter.emit();\r\n  }\r\n\r\n  cancelRow() {\r\n    this.cancelEditRowEmitter.emit();\r\n  }\r\n\r\n  editRow() {\r\n    this.editRowEmitter.emit();\r\n  }\r\n\r\n  deleteRow() {\r\n    this.deleteRowEmitter.emit();\r\n  }\r\n\r\n  selectRow(event: { checked: boolean }) {\r\n    if (event) {\r\n      this.selectRowChange.emit(event.checked);\r\n    }\r\n  }\r\n\r\n  onFieldChange(field: string, value: any) {\r\n    if (this.autoSaveOnChange()) {\r\n      this.fieldValueChanged.emit({ field, value });\r\n    }\r\n  }\r\n\r\n  private checkWidthSize() {\r\n    this.mobileView = document.body.clientWidth <= 1100;\r\n    this.changeDetectorRef.markForCheck();\r\n  }\r\n\r\n  private getDynamicSelectData() {\r\n    if (\r\n      this.column() &&\r\n      this.column().allowEditColumn &&\r\n      this.column().rowEditType === 'custom-dynamic-select' &&\r\n      this.column().dynamicRowEditOptions\r\n    ) {\r\n      this.dynamicSelectOptions.set(\r\n        this.column().dynamicRowEditOptions!(this.rowData())\r\n      );\r\n    }\r\n  }\r\n}\r\n","@switch (column().type || 'string') {\r\n  @case ('custom-template') {\r\n    @if (rowEditing && column().allowEditColumn) {\r\n      <ng-container\r\n        *ngTemplateOutlet=\"baseFieldCell; context: { $implicit: column() }\"\r\n      ></ng-container>\r\n    } @else {\r\n      <ng-container\r\n        [ngTemplateOutlet]=\"column().customTemplate!\"\r\n        [ngTemplateOutletContext]=\"{ data: rowData() }\"\r\n      ></ng-container>\r\n    }\r\n  }\r\n\r\n  @case ('actions') {\r\n    @if (column().actions) {\r\n      @if (\r\n        (!column().actionsInMenu && !mobileView) ||\r\n        (mobileView && column().actions!.length <= 1)\r\n      ) {\r\n        <div [ngStyle]=\"{ float: column().flexRight ? 'right' : 'none' }\">\r\n          @for (action of column().actions; track action) {\r\n            @if ((action.show && action.show(rowData())) || !action.show) {\r\n              @if (!action.url && action.action) {\r\n                <button\r\n                  class=\"action-icon-button\"\r\n                  type=\"button\"\r\n                  mat-icon-button\r\n                  [color]=\"\r\n                    actionIconColorDef[action.iconName]\r\n                      ? actionIconColorDef[action.iconName]\r\n                      : action.iconColor\r\n                  \"\r\n                  [matTooltip]=\"action.tooltipName || ''\"\r\n                  [matTooltipDisabled]=\"!action.tooltipName\"\r\n                  (click)=\"\r\n                    $event.stopPropagation();\r\n                    action.action!(rowData(), rowIndex())\r\n                  \"\r\n                >\r\n                  <mat-icon>{{ action.iconName }}</mat-icon>\r\n                </button>\r\n              }\r\n              @if (action.url) {\r\n                <a [routerLink]=\"action.url\">\r\n                  <button\r\n                    class=\"action-icon-button\"\r\n                    type=\"button\"\r\n                    mat-icon-button\r\n                    [color]=\"\r\n                      actionIconColorDef[action.iconName]\r\n                        ? actionIconColorDef[action.iconName]\r\n                        : action.iconColor\r\n                    \"\r\n                    [matTooltip]=\"action.tooltipName || ''\"\r\n                    [matTooltipDisabled]=\"!action.tooltipName\"\r\n                  >\r\n                    <mat-icon>{{ action.iconName }}</mat-icon>\r\n                  </button>\r\n                </a>\r\n              }\r\n            }\r\n          }\r\n        </div>\r\n      }\r\n      @if (\r\n        column().actionsInMenu || (mobileView && column().actions!.length > 1)\r\n      ) {\r\n        <button\r\n          type=\"button\"\r\n          mat-icon-button\r\n          [matMenuTriggerFor]=\"menu\"\r\n          (click)=\"$event.stopPropagation()\"\r\n        >\r\n          <mat-icon>more_vert</mat-icon>\r\n        </button>\r\n        <mat-menu #menu=\"matMenu\">\r\n          @for (action of column().actions; track action) {\r\n            @if ((action.show && action.show(rowData())) || !action.show) {\r\n              @if (!action.url && action.action) {\r\n                <button\r\n                  type=\"button\"\r\n                  mat-menu-item\r\n                  (click)=\"$event.stopPropagation(); action.action!(rowData())\"\r\n                >\r\n                  {{ action.tooltipName }}\r\n                </button>\r\n              }\r\n              @if (action.url) {\r\n                <a [routerLink]=\"action.url\">\r\n                  <button type=\"button\" mat-menu-item>\r\n                    {{ action.tooltipName }}\r\n                  </button>\r\n                </a>\r\n              }\r\n            }\r\n          }\r\n        </mat-menu>\r\n      }\r\n    }\r\n  }\r\n\r\n  @case ('string') {\r\n    <ng-container\r\n      *ngTemplateOutlet=\"baseFieldCell; context: { $implicit: column() }\"\r\n    ></ng-container>\r\n  }\r\n\r\n  @case ('number') {\r\n    <ng-container\r\n      *ngTemplateOutlet=\"baseFieldCell; context: { $implicit: column() }\"\r\n    ></ng-container>\r\n  }\r\n\r\n  @case ('boolean') {\r\n    <ng-container\r\n      *ngTemplateOutlet=\"baseFieldCell; context: { $implicit: column() }\"\r\n    ></ng-container>\r\n  }\r\n\r\n  @case ('date') {\r\n    @if (rowEditing && column().allowEditColumn) {\r\n      <ng-container\r\n        *ngTemplateOutlet=\"baseFieldCell; context: { $implicit: column() }\"\r\n      ></ng-container>\r\n    } @else {\r\n      {{ rowData()[column().field] | stDateTimeFormatPipe }}\r\n    }\r\n  }\r\n\r\n  @case ('actions-row-editing') {\r\n    <div class=\"row justify-content-end\">\r\n      @if (rowEditing) {\r\n        <button\r\n          type=\"button\"\r\n          mat-icon-button\r\n          color=\"accent\"\r\n          (click)=\"saveRow()\"\r\n          [matTooltip]=\"'Save row'\"\r\n        >\r\n          <mat-icon>done</mat-icon>\r\n        </button>\r\n        <button\r\n          type=\"button\"\r\n          mat-icon-button\r\n          color=\"warn\"\r\n          (click)=\"cancelRow()\"\r\n          [matTooltip]=\"'Cancel row'\"\r\n        >\r\n          <mat-icon>close</mat-icon>\r\n        </button>\r\n      } @else {\r\n        <button\r\n          type=\"button\"\r\n          mat-icon-button\r\n          color=\"primary\"\r\n          (click)=\"editRow()\"\r\n          [matTooltip]=\"'Edit row'\"\r\n          [disabled]=\"\r\n            canEditRowValidator() ? !canEditRowValidator()(rowData()) : false\r\n          \"\r\n        >\r\n          <mat-icon>edit</mat-icon>\r\n        </button>\r\n        <button\r\n          type=\"button\"\r\n          mat-icon-button\r\n          color=\"warn\"\r\n          (click)=\"deleteRow()\"\r\n          [matTooltip]=\"'Delete row'\"\r\n          [disabled]=\"\r\n            canDeleteRowValidator()\r\n              ? !canDeleteRowValidator()(rowData())\r\n              : false\r\n          \"\r\n        >\r\n          <mat-icon>delete</mat-icon>\r\n        </button>\r\n      }\r\n    </div>\r\n  }\r\n\r\n  @case ('actions-row-selecting') {\r\n    <!--    @if (selectRowOnlyOne()) {-->\r\n    <!--      <mat-radio-button-->\r\n    <!--        color=\"primary\"-->\r\n    <!--        (click)=\"$event.stopPropagation()\"-->\r\n    <!--        (change)=\"selectRow({ checked: true })\"-->\r\n    <!--        [checked]=\"rowIsSelected()\"-->\r\n    <!--      ></mat-radio-button>-->\r\n    <!--    } @else {-->\r\n    <mat-checkbox\r\n      color=\"primary\"\r\n      (click)=\"$event.stopPropagation()\"\r\n      (change)=\"selectRow($event)\"\r\n      [checked]=\"rowIsSelected()\"\r\n    ></mat-checkbox>\r\n    <!--    }-->\r\n  }\r\n\r\n  @case ('actions-row-extending') {\r\n    @if (rowIsExpanded()) {\r\n      <mat-icon>keyboard_arrow_up</mat-icon>\r\n    } @else {\r\n      <mat-icon>keyboard_arrow_down</mat-icon>\r\n    }\r\n  }\r\n}\r\n\r\n<ng-template #baseFieldCell let-column>\r\n  @if ((rowEditing || autoSaveOnChange()) && column.allowEditColumn) {\r\n    @if (column.rowEditType === 'string' || column.rowEditType === 'number') {\r\n      <mat-form-field\r\n        appearance=\"outline\"\r\n        [ngStyle]=\"{ width: column.width || 'auto' }\"\r\n      >\r\n        <input\r\n          matInput\r\n          [type]=\"column.rowEditType === 'string' ? 'text' : 'number'\"\r\n          [(ngModel)]=\"\r\n            autoSaveOnChange()\r\n              ? rowData()[column.field]\r\n              : rowDataCopy()![column.field]\r\n          \"\r\n          (ngModelChange)=\"\r\n            autoSaveOnChange() && onFieldChange(column.field, $event)\r\n          \"\r\n          (keydown.enter)=\"!autoSaveOnChange() && saveRow()\"\r\n          [required]=\"column.editColumnRequired\"\r\n        />\r\n      </mat-form-field>\r\n    }\r\n    @if (column.rowEditType === 'date') {\r\n      <mat-form-field\r\n        appearance=\"outline\"\r\n        [ngStyle]=\"{ width: column.width || 'auto' }\"\r\n      >\r\n        <input\r\n          matInput\r\n          [matDatepicker]=\"picker1\"\r\n          [(ngModel)]=\"\r\n            autoSaveOnChange()\r\n              ? rowData()[column.field]\r\n              : rowDataCopy()![column.field]\r\n          \"\r\n          (ngModelChange)=\"\r\n            autoSaveOnChange() && onFieldChange(column.field, $event)\r\n          \"\r\n          (keydown.enter)=\"!autoSaveOnChange() && saveRow()\"\r\n          [required]=\"column.editColumnRequired\"\r\n        />\r\n        <mat-datepicker-toggle\r\n          matIconSuffix\r\n          [for]=\"picker1\"\r\n        ></mat-datepicker-toggle>\r\n        <mat-datepicker #picker1></mat-datepicker>\r\n      </mat-form-field>\r\n    }\r\n    @if (column.rowEditType === 'boolean') {\r\n      <mat-checkbox\r\n        [(ngModel)]=\"\r\n          autoSaveOnChange()\r\n            ? rowData()[column.field]\r\n            : rowDataCopy()![column.field]\r\n        \"\r\n        (ngModelChange)=\"\r\n          autoSaveOnChange() && onFieldChange(column.field, $event)\r\n        \"\r\n      ></mat-checkbox>\r\n    }\r\n\r\n    @if (column.rowEditType === 'custom') {\r\n      <mat-form-field\r\n        appearance=\"outline\"\r\n        [ngStyle]=\"{ width: column.width || 'auto' }\"\r\n      >\r\n        <mat-select\r\n          [(ngModel)]=\"\r\n            autoSaveOnChange()\r\n              ? rowData()[column.field]\r\n              : rowDataCopy()![column.field]\r\n          \"\r\n          (ngModelChange)=\"\r\n            autoSaveOnChange() && onFieldChange(column.field, $event)\r\n          \"\r\n          [required]=\"column.editColumnRequired\"\r\n        >\r\n          <mat-option value=\"\"></mat-option>\r\n          @for (option of column.customRowEditOptions; track option) {\r\n            <mat-option [value]=\"option.value\">\r\n              {{ option.label }}\r\n            </mat-option>\r\n          }\r\n        </mat-select>\r\n      </mat-form-field>\r\n    }\r\n\r\n    @if (column.rowEditType === 'custom-dynamic-select') {\r\n      <mat-form-field\r\n        appearance=\"outline\"\r\n        [ngStyle]=\"{ width: column.width || 'auto' }\"\r\n      >\r\n        <mat-select\r\n          [(ngModel)]=\"\r\n            autoSaveOnChange()\r\n              ? rowData()[column.field]\r\n              : rowDataCopy()![column.field]\r\n          \"\r\n          (ngModelChange)=\"\r\n            autoSaveOnChange() && onFieldChange(column.field, $event)\r\n          \"\r\n          [required]=\"column.editColumnRequired\"\r\n        >\r\n          @if (!column.editColumnRequired) {\r\n            <mat-option value=\"\"></mat-option>\r\n          }\r\n\r\n          @for (option of dynamicSelectOptions(); track option) {\r\n            <mat-option [value]=\"option.value\">\r\n              {{ option.label }}\r\n            </mat-option>\r\n          }\r\n        </mat-select>\r\n      </mat-form-field>\r\n    }\r\n  } @else {\r\n    <div>\r\n      @if (column.translateValue) {\r\n        {{ column.translateValue![rowData()[column.field]] || '' }}\r\n      }\r\n      @if (column.customValueDisplay) {\r\n        {{ column.customValueDisplay(rowData()[column.field]) }}\r\n      }\r\n      @if (!column.translateValue && !column.customValueDisplay) {\r\n        {{ rowData()[column.field] }}\r\n      }\r\n    </div>\r\n  }\r\n</ng-template>\r\n"]}