@c8y/ngx-components 1018.0.102 → 1018.0.104

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.
@@ -182,7 +182,7 @@ export class DataGridComponent {
182
182
  this.reloadConfiguration$
183
183
  .pipe(switchMap(() => this.configurationStrategy?.getConfig$() ?? of(null)), tap(config => {
184
184
  this.setColumns(config);
185
- this.setPagination(config);
185
+ this.setPageSize(config);
186
186
  this.triggerLoadData.emit(!!this.infiniteScroll);
187
187
  }), switchMap(() => this.dataSource.stats$), tap(stats => {
188
188
  this.createLoadMoreComponent(stats);
@@ -195,6 +195,10 @@ export class DataGridComponent {
195
195
  set _rows(rows) {
196
196
  this.rows = rows || [];
197
197
  }
198
+ /** Pagination settings, e.g. allows for setting current page or page size. */
199
+ set _pagination(pagination) {
200
+ this.pagination = pagination;
201
+ }
198
202
  /** Sets load more mode. */
199
203
  set _infiniteScroll(infiniteScroll) {
200
204
  this.infiniteScroll = infiniteScroll;
@@ -296,11 +300,13 @@ export class DataGridComponent {
296
300
  this.defaultColumns = this.columns || [];
297
301
  this.updateColumns();
298
302
  }
299
- setPagination(config) {
303
+ setPageSize(config) {
300
304
  if (!!config?.pagination) {
301
- this.pagination = config.pagination;
305
+ this.pagination = {
306
+ ...this.pagination,
307
+ pageSize: config.pagination.pageSize
308
+ };
302
309
  }
303
- this.pagination = this.pagination ?? this._pagination;
304
310
  const pageSize = get(this.pagination, 'pageSize');
305
311
  if (this.pagination &&
306
312
  !this.possiblePageSizes.find(possiblePageSize => possiblePageSize === pageSize)) {
@@ -441,9 +447,12 @@ export class DataGridComponent {
441
447
  return !!(filterable && (filterPredicate || externalFilterQuery));
442
448
  }
443
449
  updatePagination({ itemsPerPage, page }) {
450
+ const configChanged = this.pagination?.pageSize !== itemsPerPage;
444
451
  this.pagination = { ...this.pagination, pageSize: itemsPerPage, currentPage: page };
445
452
  this.loadData();
446
- this.emitConfigChange('pagination');
453
+ if (configChanged) {
454
+ this.emitConfigChange('pagination');
455
+ }
447
456
  this.triggerEvent({ action: PX_ACTIONS.CHANGE_PAGINATION, itemsPerPage, page });
448
457
  }
449
458
  clickReload() {
@@ -835,7 +844,7 @@ export class DataGridComponent {
835
844
  }))))
836
845
  .pipe(map((columns) => ({
837
846
  columns,
838
- pagination: this.pagination
847
+ pagination: { pageSize: this.pagination.pageSize }
839
848
  })), filter(() => !!this.configurationStrategy), this.trimFilterConfigPipe(), this.trimSortConfigPipe(), this.trimCustomColumnConfigPipe(), this.ignoreColumnOrderPipe(), this.ignoreColumnVisibilityPipe(), concatMap((config) => this.configurationStrategy.saveConfig$(config)), takeUntil(this.unsubscribe$))
840
849
  .subscribe();
841
850
  }
@@ -1023,4 +1032,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.6", ngImpor
1023
1032
  type: ViewChildren,
1024
1033
  args: [CdkHeaderCell, { read: ElementRef }]
1025
1034
  }] } });
1026
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-grid.component.js","sourceRoot":"","sources":["../../../../core/data-grid/data-grid.component.ts","../../../../core/data-grid/data-grid.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CdkHeaderCell } from '@angular/cdk/table';\nimport {\n  AfterViewInit,\n  Component,\n  ComponentFactory,\n  ComponentFactoryResolver,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  Inject,\n  Input,\n  OnChanges,\n  Optional,\n  Output,\n  QueryList,\n  ViewChild,\n  ViewChildren,\n  ViewContainerRef\n} from '@angular/core';\nimport { DomSanitizer } from '@angular/platform-browser';\nimport { IResultList, Paging } from '@c8y/client';\nimport {\n  flow,\n  get,\n  indexOf,\n  isEmpty,\n  isNil,\n  parseInt as _parseInt,\n  union,\n  uniqBy,\n  without\n} from 'lodash-es';\nimport { BsDropdownDirective } from 'ngx-bootstrap/dropdown';\nimport { BsModalService } from 'ngx-bootstrap/modal';\nimport {\n  BehaviorSubject,\n  combineLatest,\n  isObservable,\n  merge,\n  Observable,\n  of,\n  pipe,\n  Subject,\n  UnaryFunction\n} from 'rxjs';\nimport {\n  concatMap,\n  debounceTime,\n  delay,\n  distinctUntilChanged,\n  filter,\n  first,\n  map,\n  mergeMap,\n  switchMap,\n  take,\n  takeUntil,\n  tap\n} from 'rxjs/operators';\nimport { AlertService } from '../alert/alert.service';\nimport { toObservable } from '../common/extension-hooks';\nimport { LoadMoreComponent } from '../common/load-more.component';\nimport { LoadMoreMode } from '../common/load-more.model';\nimport { gettext } from '../i18n/gettext';\nimport { PopoverConfirmButtons, PopoverConfirmComponent } from '../modal/popover-confirm.component';\nimport { GainsightService } from '../product-experience/gainsight.service';\nimport {\n  ProductExperienceEvent,\n  ProductExperienceEventSource,\n  PRODUCT_EXPERIENCE_EVENT_SOURCE\n} from '../product-experience/product-experience.model';\nimport { CellRendererSpec } from './column/cell-renderer';\nimport { ColumnDirective } from './column/column.directive';\nimport { CustomColumn } from './column/custom.column';\nimport { FilteringFormRendererSpec, FilteringModifier } from './column/filtering-form-renderer';\nimport { ConfigureCustomColumnComponent } from './configure-custom-column';\nimport {\n  DataGridConfigurationStrategy,\n  DATA_GRID_CONFIGURATION_STRATEGY,\n  GridConfigPart,\n  GridEventType\n} from './data-grid-configuration.model';\nimport {\n  ActionControl,\n  BuiltInActionType,\n  BulkActionControl,\n  Column,\n  ColumnConfig,\n  ColumnDataType,\n  CustomColumnConfig,\n  DataGrid,\n  DataSourceStats,\n  DisplayOptions,\n  FilteringActionType,\n  GridConfig,\n  HeaderActionControl,\n  minColumnGridTrackSize,\n  Pagination,\n  ratiosByColumnTypes,\n  Row,\n  ServerSideDataCallback,\n  SortOrder,\n  SpecialColumnName\n} from './data-grid.model';\nimport { DataGridService } from './data-grid.service';\nimport { GridDataSource } from './grid-data-source';\nimport { PX_ACTIONS, PX_EVENT_NAME } from './product-experience.constants';\n\nenum SortingOrder {\n  ASC = 'asc',\n  DESC = 'desc'\n}\n\n@Component({\n  selector: 'c8y-data-grid',\n  templateUrl: './data-grid.component.html',\n  host: { class: 'd-contents' },\n  providers: [\n    {\n      provide: PRODUCT_EXPERIENCE_EVENT_SOURCE,\n      useExisting: forwardRef(() => DataGridComponent)\n    }\n  ]\n})\nexport class DataGridComponent\n  implements DataGrid, OnChanges, AfterViewInit, ProductExperienceEventSource\n{\n  /** The title for the data grid, it's displayed in the grid's header. */\n  @Input() title: string = gettext('Items');\n  /** The label for load more button. */\n  @Input() loadMoreItemsLabel: string = gettext('Load more items');\n  /** The label for loading indicator. */\n  @Input() loadingItemsLabel: string = gettext('Loading items…');\n  /** Determines whether text search input is shown in the grid's header. */\n  @Input() showSearch = false;\n  /** Takes an event emitter. When an event is emitted, the grid will be reloaded. */\n  @Input() refresh: EventEmitter<any>;\n\n  columns: Column[] = [];\n  /** The list of columns to be displayed in the grid. */\n  @Input('columns')\n  private _columns: Column[];\n\n  dataSource = new GridDataSource();\n  rows: Row[];\n  /** The list of rows to be displayed in the grid (used for client side data). */\n  @Input('rows')\n  set _rows(rows: Row[]) {\n    this.rows = rows || [];\n  }\n\n  filteringLabelsParams = {\n    filteredItemsCount: 0,\n    allItemsCount: 0\n  };\n\n  pagination: Pagination;\n  paginationLabelParams = {\n    pageFirstItemIdx: 0,\n    pageLastItemIdx: 0,\n    itemsTotal: 0\n  };\n  readonly possiblePageSizes: number[] = [25, 50, 100];\n  readonly minPossiblePageSize = Math.min(...this.possiblePageSizes);\n  /** Pagination settings, e.g. allows for setting current page or page size. */\n  @Input('pagination')\n  private _pagination: Pagination;\n\n  infiniteScroll: LoadMoreMode;\n  /** Sets load more mode. */\n  @Input('infiniteScroll')\n  set _infiniteScroll(infiniteScroll: LoadMoreMode) {\n    this.infiniteScroll = infiniteScroll;\n  }\n\n  serverSideDataCallback: ServerSideDataCallback;\n  /**\n   * Sets a callback function which will be invoked whenever data needs to be loaded from server.\n   * The function should take [[DataSourceModifier]] and return [[ServerSideDataResult]].\n   */\n  @Input('serverSideDataCallback')\n  set _serverSideDataCallback(serverSideDataCallback: ServerSideDataCallback) {\n    this.serverSideDataCallback = serverSideDataCallback;\n  }\n\n  selectable = false;\n  /** Determines whether items can be selected by clicking a checkbox in the first column. */\n  @Input('selectable')\n  set _selectable(selectable: boolean) {\n    this.selectable = selectable;\n  }\n\n  selectionPrimaryKey = 'id';\n  /** Determines which item's property will be used to distinguish selection status. */\n  @Input('selectionPrimaryKey')\n  set _selectionPrimaryKey(selectionPrimaryKey: string) {\n    this.selectionPrimaryKey = selectionPrimaryKey;\n  }\n\n  displayOptions: DisplayOptions = {\n    striped: true,\n    bordered: false,\n    gridHeader: true,\n    filter: true\n  };\n  /** Sets display options. */\n  @Input('displayOptions')\n  set _displayOptions(displayOptions: DisplayOptions) {\n    this.displayOptions = { ...this.displayOptions, ...displayOptions };\n  }\n\n  actionControls: ActionControl[];\n  /** Sets action controls (actions available for individual items). */\n  @Input('actionControls')\n  set _actionControls(actionControls: ActionControl[]) {\n    this.actionControls = actionControls || [];\n  }\n\n  bulkActionControls: BulkActionControl[];\n  /** Sets bulk action controls (actions available for items selected by user). */\n  @Input('bulkActionControls')\n  set _bulkActionControls(bulkActionControls: BulkActionControl[]) {\n    this.bulkActionControls = bulkActionControls || [];\n  }\n\n  headerActionControls: HeaderActionControl[];\n  /** Sets header action controls (actions available from data grid header). */\n  @Input('headerActionControls')\n  set _headerActionControls(headerActionControls: HeaderActionControl[]) {\n    this.headerActionControls = headerActionControls || [];\n  }\n\n  /** Sets initial search text. */\n  @Input()\n  searchText = '';\n\n  /** Determines if custom columns button will be enabled. */\n  @Input()\n  configureColumnsEnabled = true;\n\n  /** Shows the warning for the sub-assets counter */\n  @Input()\n  showCounterWarning = false;\n\n  /** Emits an event when mouse is over a row. */\n  @Output() rowMouseOver = new EventEmitter<object>();\n  /** Emits an event when mouse leaves a row. */\n  @Output() rowMouseLeave = new EventEmitter<object>();\n  /** Emits an event when a row is clicked. */\n  @Output() rowClick = new EventEmitter<object>();\n  /** Emits an event when grid's configuration is changed. */\n  @Output() onConfigChange = new EventEmitter<GridConfig>();\n  /** Emits an event before the filter is applied. */\n  @Output() onBeforeFilter = new EventEmitter<object>();\n  /** Emits an event before the search is performed. */\n  @Output() onBeforeSearch = new EventEmitter<string>();\n  /** Emits an event when a filter is applied in a column. */\n  @Output() onFilter = new EventEmitter<{\n    columnName?: string;\n    dropdown?: any;\n    filteringModifier?: any;\n  }>();\n  /** Emits an event when items selection changes. The array contains keys of selected items (key property is defined by `selectionPrimaryKey`). */\n  @Output() itemsSelect = new EventEmitter<string[]>();\n  /** Emits an event when reload button is clicked. */\n  @Output() onReload = new EventEmitter();\n  /** Emits an event when a custom column is added */\n  @Output() onAddCustomColumn = new EventEmitter<CustomColumnConfig>();\n  /** Emits an event when a custom column is removed */\n  @Output() onRemoveCustomColumn = new EventEmitter<Column>();\n  /** Emits an event after the column filter has been reset */\n  @Output() onColumnFilterReset = new EventEmitter<Column>();\n  /** Emits an event when column sorting has been changed */\n  @Output() onSort = new EventEmitter<GridConfig>();\n  /** Emits an event when page size has been changed */\n  @Output() onPageSizeChange = new EventEmitter<GridConfig>();\n  /** Emits an event when column order has been changed */\n  @Output() onColumnReordered = new EventEmitter<GridConfig>();\n  /** Emits an event when column order has been changed */\n  @Output() onColumnVisibilityChange = new EventEmitter<GridConfig>();\n\n  @ContentChildren(ColumnDirective) columnRenderers: QueryList<ColumnDirective>;\n\n  @ViewChild('scroll', { static: true }) scrollContainer: ElementRef;\n\n  @ViewChild('infiniteScrollContainer', { static: false, read: ViewContainerRef })\n  infiniteScrollContainer: ViewContainerRef;\n\n  loadMoreComponent: LoadMoreComponent;\n\n  columnNames = [];\n\n  styles = {\n    tableCursor: 'auto',\n    gridTemplateColumns: undefined,\n    gridInfiniteScrollColumn: undefined\n  };\n\n  searchText$ = new EventEmitter<string>();\n  filteringApplied = false;\n\n  totalPagesCount$ = new BehaviorSubject<number>(Infinity);\n  hidePagination$ = this.totalPagesCount$.pipe(\n    map(totalPagesCount => totalPagesCount <= 1),\n    delay(0) // prevents ExpressionChangedAfterItHasBeenCheckedError\n  );\n\n  selectedItemIds: string[] = [];\n  currentPageSelectionState = {\n    allSelected: false,\n    allDeselected: true\n  };\n\n  builtInActionType = {\n    Edit: BuiltInActionType.Edit,\n    Delete: BuiltInActionType.Delete,\n    Export: BuiltInActionType.Export\n  };\n\n  confirmRemoveColumnButtons: PopoverConfirmButtons[] = [\n    {\n      label: gettext('Cancel'),\n      action: () => Promise.resolve(false)\n    },\n    {\n      label: gettext('Remove`column,verb`'),\n      status: 'danger',\n      action: () => Promise.resolve(true)\n    }\n  ];\n\n  isConfigContextKnown = false;\n\n  /** Product experience constants declarations */\n  productExperienceEvent: ProductExperienceEvent = { eventName: PX_EVENT_NAME };\n  PX_ACTIONS = PX_ACTIONS;\n\n  readonly sortColumnTitle = gettext('Sort column \"{{ name }}\"');\n\n  resizeHandleMouseDown$ = new EventEmitter<any>();\n  resizeHandleContainerMouseMove$ = new EventEmitter<any>();\n  resizeHandleContainerMouseUp$ = new EventEmitter<any>();\n  private headerBeingResized: {\n    columnName: string;\n    el: HTMLElement;\n  };\n  @ViewChildren(CdkHeaderCell, { read: ElementRef }) private thRefs: QueryList<ElementRef>;\n  private thEls: HTMLElement[];\n\n  private recreateLoadMoreComponent: boolean;\n\n  private columnsInitialized = false;\n\n  private defaultColumns: Column[] = [];\n\n  private reloadConfiguration$: Subject<void> = new Subject();\n\n  private unsubscribe$ = new Subject<any>();\n\n  private readonly SEARCH_DEBOUNCE_TIME = 500;\n\n  /**\n   * Event emitter, taking boolean values used for loading data grid data with debounce.\n   * Default value is set to false. Set to true if data grid is using infinite scroll and page should be reloaded.\n   * This is used to avoid having multiple this.loadData() function calls.\n   */\n  private triggerLoadData = new EventEmitter<boolean>();\n\n  constructor(\n    @Optional()\n    @Inject(DATA_GRID_CONFIGURATION_STRATEGY)\n    public configurationStrategy: DataGridConfigurationStrategy,\n    private dataGridService: DataGridService,\n    private sanitizer: DomSanitizer,\n    private cfr: ComponentFactoryResolver,\n    private gainsightService: GainsightService,\n    private bsModalService: BsModalService,\n    private alertService: AlertService\n  ) {\n    this.triggerLoadData.pipe(debounceTime(1), takeUntil(this.unsubscribe$)).subscribe(reload => {\n      this.loadData(reload);\n    });\n\n    this.reloadConfiguration$\n      .pipe(\n        switchMap(() => this.configurationStrategy?.getConfig$() ?? of(null)),\n        tap(config => {\n          this.setColumns(config);\n          this.setPagination(config);\n          this.triggerLoadData.emit(!!this.infiniteScroll);\n        }),\n        switchMap(() => this.dataSource.stats$),\n        tap(stats => {\n          this.createLoadMoreComponent(stats);\n          this.updateFilteringLabelsParams(stats);\n          this.updatePaginationLabelParams(stats);\n        }),\n        takeUntil(this.unsubscribe$)\n      )\n      .subscribe();\n  }\n\n  ngOnInit() {\n    this.isConfigContextKnown = !!this.configurationStrategy?.isContextKnown();\n\n    this.searchText$\n      .pipe(\n        takeUntil(this.unsubscribe$),\n        debounceTime(this.SEARCH_DEBOUNCE_TIME),\n        distinctUntilChanged(),\n        tap(searchText => {\n          this.searchText = searchText;\n          this.onBeforeSearch.emit(this.searchText);\n          this.triggerEvent({\n            action: PX_ACTIONS.SEARCH,\n            searchInput: searchText\n          });\n        })\n      )\n      .subscribe(() => {\n        this.reload();\n      });\n\n    if (this.selectable) {\n      combineLatest(this.dataSource.data$, this.itemsSelect.asObservable())\n        .pipe(takeUntil(this.unsubscribe$))\n        .subscribe(([data]) => {\n          const currentPageEmpty = data.length === 0;\n\n          this.currentPageSelectionState = {\n            allSelected: currentPageEmpty ? false : data.every(item => this.isItemSelected(item)),\n            allDeselected: currentPageEmpty ? true : data.every(item => !this.isItemSelected(item))\n          };\n        });\n    }\n\n    this.reloadConfiguration$.next();\n\n    if (this.refresh) {\n      this.refresh.pipe(takeUntil(this.unsubscribe$)).subscribe(() => {\n        this.cancel();\n        this.reload();\n      });\n    }\n\n    this.processAndPersistConfigChange();\n  }\n\n  ngOnChanges(event) {\n    if (\n      ((!event._actionControls && !event.searchText) || event._actionControls?.firstChange) &&\n      this.columnsInitialized\n    ) {\n      const reload = !!event._infiniteScroll?.currentValue && !event._infiniteScroll?.firstChange;\n      this.triggerLoadData.emit(reload);\n    }\n    if (!!event._columns && !event._columns.firstChange) {\n      this.reloadConfiguration$.next();\n    }\n    this.updateColumns();\n  }\n\n  ngAfterViewInit() {\n    this.updateGridColumnsSize();\n    this.updateThEls();\n    this.setupResizeHandle();\n  }\n\n  ngOnDestroy() {\n    this.unsubscribe$.next();\n    this.unsubscribe$.complete();\n  }\n\n  setColumns(config: GridConfig) {\n    if (!!this.configurationStrategy && !isEmpty(this._columns)) {\n      this.columns = this.dataGridService.applyConfigToColumns(config, this._columns);\n      this.columnsInitialized = true;\n    } else {\n      this.columns = this._columns || [];\n      this.columnsInitialized = this.columnsInitialized || !!this._columns;\n    }\n\n    this.defaultColumns = this.columns || [];\n    this.updateColumns();\n  }\n\n  setPagination(config: GridConfig) {\n    if (!!config?.pagination) {\n      this.pagination = config.pagination;\n    }\n\n    this.pagination = this.pagination ?? this._pagination;\n    const pageSize = get(this.pagination, 'pageSize');\n    if (\n      this.pagination &&\n      !this.possiblePageSizes.find(possiblePageSize => possiblePageSize === pageSize)\n    ) {\n      this.pagination = { ...this.pagination, pageSize: this.minPossiblePageSize };\n    }\n  }\n\n  openCustomColumnModal(): void {\n    const modalRef = this.bsModalService.show(ConfigureCustomColumnComponent, {\n      class: 'modal-sm',\n      ariaDescribedby: 'modal-body',\n      ariaLabelledBy: 'modal-title',\n      ignoreBackdropClick: true,\n      initialState: {\n        columns: this.columns\n      }\n    });\n\n    modalRef.content.onAddCustomColumn\n      .pipe(\n        tap((customColumnConfig: CustomColumnConfig) => {\n          const firstFixedColumPosition = this.columns.indexOf(\n            this.columns.find(column => column.positionFixed)\n          );\n          this.columns.splice(\n            firstFixedColumPosition > -1 ? firstFixedColumPosition : this.columns.length,\n            0,\n            new CustomColumn(customColumnConfig)\n          );\n          this.updateColumns();\n          this.triggerEvent({\n            action: PX_ACTIONS.ADD_CUSTOM_COLUMN,\n            column: customColumnConfig.header || customColumnConfig.name\n          });\n        }),\n        takeUntil(modalRef.onHidden)\n      )\n      .subscribe(event => this.onAddCustomColumn.emit(event));\n  }\n\n  async removeCustomColumn(\n    poConfirm: PopoverConfirmComponent,\n    column: Column,\n    ddConfigureColumns: BsDropdownDirective\n  ) {\n    ddConfigureColumns.autoClose = false;\n    poConfirm.message = gettext('Do you want to remove this column?');\n    try {\n      const remove: boolean = await poConfirm.show(this.confirmRemoveColumnButtons);\n      if (remove) {\n        this.columns = this.columns.filter(col => col?.name !== column?.name);\n        this.updateColumns();\n        this.onRemoveCustomColumn.emit(column);\n        this.triggerEvent({\n          action: PX_ACTIONS.REMOVE_CUSTOM_COLUMN,\n          column: column.header || column.name\n        });\n      }\n    } catch (e) {\n      this.alertService.addServerFailure(e);\n    }\n\n    setTimeout(() => (ddConfigureColumns.autoClose = true), 0);\n  }\n\n  trackByName(index, item) {\n    return item.name;\n  }\n\n  resolveCellValue(row, path) {\n    return flow([\n      x => this.dataSource.resolveValue(x, path),\n      this.dataSource.resolveFunction,\n      this.dataSource.normalizeNil\n    ])(row);\n  }\n\n  changeSortOrder(columnName) {\n    const column = this.columns.find(({ name }) => name === columnName);\n\n    if (column) {\n      const { sortOrder } = column;\n\n      if (!sortOrder) {\n        this.updateSorting([columnName], SortingOrder.ASC);\n      } else if (sortOrder === SortingOrder.ASC) {\n        this.updateSorting([columnName], SortingOrder.DESC);\n      } else {\n        this.updateSorting([columnName], '');\n      }\n    }\n  }\n\n  updateSorting(columnNames: string[], sortOrder: SortOrder) {\n    this.triggerEvent({\n      action: PX_ACTIONS.CHANGE_SORTING_ORDER,\n      columns: columnNames,\n      sortOrder: sortOrder === '' ? 'none' : sortOrder\n    });\n\n    this.columns = this.columns.map((column): Column => {\n      if (columnNames.includes(column.name)) {\n        return { ...column, sortOrder };\n      }\n\n      return column;\n    });\n    this.emitConfigChange('sort');\n    this.reload();\n  }\n\n  applyFilter(columnName, dropdown, filteringModifier) {\n    this.triggerEvent({\n      action: PX_ACTIONS.APPLY_FILTER,\n      column: columnName,\n      filteringModifier\n    });\n    this.onBeforeFilter.emit({ columnName, dropdown, filteringModifier });\n    this.updateFiltering([columnName], {\n      type: FilteringActionType.ApplyFilter,\n      payload: { filteringModifier }\n    });\n    dropdown.hide();\n    this.onFilter.emit({ columnName, dropdown, filteringModifier });\n  }\n\n  resetFilter(columnName, dropdown) {\n    this.triggerEvent({ action: PX_ACTIONS.RESET_FILTER, column: columnName });\n    this.updateFiltering([columnName], { type: FilteringActionType.ResetFilter });\n    dropdown.hide();\n    this.onFilter.emit({ columnName, dropdown });\n  }\n\n  clearFilters(reload = true) {\n    this.updateFiltering(\n      this.columns.map(({ name }) => name),\n      {\n        type: FilteringActionType.ResetFilter\n      },\n      reload\n    );\n    this.onFilter.emit({});\n    this.triggerEvent({ action: PX_ACTIONS.CLEAR_FILTER });\n  }\n\n  updateFiltering(\n    columnNames: string[],\n    action: {\n      type: FilteringActionType;\n      payload?: { filteringModifier: FilteringModifier };\n    },\n    reload = true\n  ) {\n    this.columns = this.columns.map(column => {\n      if (columnNames.includes(column.name)) {\n        return {\n          ...column,\n          ...(action.type === FilteringActionType.ApplyFilter\n            ? action.payload.filteringModifier\n            : this.onResetFilterAction(column))\n        };\n      }\n      return column;\n    });\n\n    this.updateFilteringApplied();\n    if (reload) {\n      this.reload();\n    }\n  }\n\n  updateFilteringApplied() {\n    this.filteringApplied = this.columns.some(this.isColumnFilteringApplied);\n  }\n\n  isColumnFilteringApplied(column: Column): boolean {\n    const { filterable, filterPredicate, externalFilterQuery } = column;\n\n    return !!(filterable && (filterPredicate || externalFilterQuery));\n  }\n\n  updatePagination({ itemsPerPage, page }) {\n    this.pagination = { ...this.pagination, pageSize: itemsPerPage, currentPage: page };\n    this.loadData();\n    this.emitConfigChange('pagination');\n    this.triggerEvent({ action: PX_ACTIONS.CHANGE_PAGINATION, itemsPerPage, page });\n  }\n\n  clickReload() {\n    this.searchText = '';\n    this.reload();\n    this.onReload.next();\n    this.triggerEvent({ action: PX_ACTIONS.RELOAD });\n  }\n\n  reload() {\n    this.pagination = { ...this.pagination, currentPage: 1 };\n    this.recreateLoadMoreComponent = true;\n    this.loadData(true);\n    this.scrollToTop();\n  }\n\n  loadNextPage(): Promise<IResultList<object>> {\n    this.pagination = { ...this.pagination, currentPage: this.pagination.nextPage };\n\n    this.loadData();\n\n    return this.dataSource.resultList$\n      .pipe(take(1)) // in order for `toPromise` to work, the observable needs to complete\n      .toPromise()\n      .then(result => {\n        return {\n          ...result,\n          paging: {\n            ...result.paging,\n            next: this.loadNextPage.bind(this)\n          }\n        } as IResultList<object>;\n      });\n  }\n\n  getCellRendererSpec({ value, row, columnName }): CellRendererSpec {\n    return this._getCellRendererSpec({ type: 'CELL', value, row, columnName });\n  }\n\n  getHeaderCellRendererSpec({ value, columnName }): CellRendererSpec {\n    return this._getCellRendererSpec({ type: 'HEADER', value, row: undefined, columnName });\n  }\n\n  getFilteringFormRendererSpec({ column, dropdown }): FilteringFormRendererSpec {\n    return {\n      renderer:\n        get(this.getColumnRenderer(column), 'filteringFormRendererDef.template') ||\n        column.filteringFormRendererComponent,\n      context: {\n        property: column,\n        applyFilter: this.applyFilter.bind(this, column.name, dropdown),\n        resetFilter: this.resetFilter.bind(this, column.name, dropdown)\n      }\n    };\n  }\n\n  setAllItemsSelected(selected) {\n    this.dataSource.selection$\n      .pipe(first())\n      .subscribe(({ filteredDataIds }) => this.setItemsSelected(filteredDataIds, selected));\n  }\n\n  setAllItemsInCurrentPageSelected(selected) {\n    this.dataSource.data$.pipe(first()).subscribe(data => this.setItemsSelected(data, selected));\n  }\n\n  setItemsSelected(items: any[], selected) {\n    const itemIds = items.map((item: object | string) =>\n      typeof item === 'object' ? item[this.selectionPrimaryKey] : item\n    );\n\n    this.selectedItemIds = selected\n      ? union(this.selectedItemIds, itemIds)\n      : without(this.selectedItemIds, ...itemIds);\n    this.itemsSelect.emit(this.selectedItemIds);\n  }\n\n  cancel() {\n    this.selectedItemIds = [];\n    this.itemsSelect.emit(this.selectedItemIds);\n  }\n\n  isItemSelected(item) {\n    return this.selectedItemIds.includes(item[this.selectionPrimaryKey]);\n  }\n\n  onColumnDrop({ previousIndex, currentIndex }) {\n    const differentIndex = previousIndex !== currentIndex;\n\n    if (differentIndex) {\n      this.triggerEvent({\n        action: PX_ACTIONS.REORDER_COLUMNS,\n        column: this.columnNames[previousIndex]\n      });\n      const column = this.columns.splice(previousIndex, 1);\n      this.columns.splice(currentIndex, 0, column[0]);\n      this.emitConfigChange('reorderColumn');\n    }\n\n    this.updateColumnNames();\n    this.updateGridColumnsSize();\n  }\n\n  updateGridColumnsSize() {\n    this.styles = {\n      ...this.styles,\n      gridTemplateColumns: this.sanitizer.bypassSecurityTrustStyle(\n        this.columns\n          .filter(column => column.visible)\n          .map(({ gridTrackSize }) => gridTrackSize)\n          .join(' ')\n      ),\n      gridInfiniteScrollColumn: this.sanitizer.bypassSecurityTrustStyle(\n        `1 / span ${this.columns.filter(column => column.visible).length}`\n      )\n    };\n  }\n\n  updateThEls() {\n    setTimeout(() => {\n      this.thEls = this.thRefs\n        ? this.thRefs.toArray().map(({ nativeElement }) => nativeElement)\n        : [];\n    }, 0);\n  }\n\n  // To be removed when columns are transformed to observables.\n  isDropDownPlacedRight(column: Column) {\n    return (\n      indexOf(\n        this.columns.filter(c => c.visible),\n        column\n      ) >\n      this.columns.filter(c => c.visible).length / 2\n    );\n  }\n\n  emitConfigChange(eventType?: GridEventType) {\n    if (this.columnsInitialized) {\n      const columns = this.columns.map(this.mapColumnToConfig.bind(this));\n      const config = { columns, pagination: this.pagination };\n      this.onConfigChange.emit(config);\n      switch (eventType) {\n        case 'sort':\n          this.onSort.emit(config);\n          break;\n        case 'pagination':\n          this.onPageSizeChange.emit(config);\n          break;\n        case 'reorderColumn':\n          this.onColumnReordered.emit(config);\n          break;\n        case 'changeColumnVisibility':\n          this.onColumnVisibilityChange.emit(config);\n      }\n    }\n  }\n\n  triggerEvent(eventData) {\n    this.gainsightService.triggerEvent(this.productExperienceEvent?.eventName || PX_EVENT_NAME, {\n      ...this.productExperienceEvent?.data,\n      ...eventData\n    });\n  }\n\n  private onResetFilterAction(column: Column) {\n    this.onColumnFilterReset.emit(column);\n    return {\n      filterPredicate: undefined,\n      externalFilterQuery: undefined\n    };\n  }\n\n  private mapColumnToConfig(column: Column): ColumnConfig | CustomColumnConfig {\n    let config;\n    if (column.custom) {\n      const { visible, sortOrder, name, externalFilterQuery, header, path } = column;\n      config = {\n        visible,\n        sortOrder,\n        name,\n        filter: { externalFilterQuery },\n        header,\n        path,\n        custom: true\n      };\n    } else {\n      const { visible, sortOrder, name, externalFilterQuery } = column;\n      config = { visible, sortOrder, name, filter: { externalFilterQuery } };\n    }\n\n    if (isEmpty(config?.filter?.externalFilterQuery)) {\n      delete config.filter;\n    }\n\n    return config;\n  }\n\n  private loadData(reload = false) {\n    const {\n      rows,\n      columns,\n      pagination,\n      searchText,\n      serverSideDataCallback,\n      selectable,\n      selectionPrimaryKey,\n      infiniteScroll\n    } = this;\n\n    this.dataSource.loadData({\n      rows,\n      columns,\n      pagination,\n      searchText,\n      serverSideDataCallback,\n      selectable,\n      selectionPrimaryKey,\n      infiniteScroll,\n      reload\n    });\n  }\n\n  private updateColumns() {\n    const specialColumn = {\n      sortable: false,\n      positionFixed: true\n    };\n    const checkboxColumn = this.selectable\n      ? {\n          ...specialColumn,\n          name: SpecialColumnName.Checkbox,\n          gridTrackSize: '32px'\n        }\n      : undefined;\n    const actionsColumn =\n      this.actionControls?.length > 0\n        ? {\n            ...specialColumn,\n            name: SpecialColumnName.Actions,\n            gridTrackSize: this.actionControls.length > 2 ? '56px' : 'minmax(40px, auto)'\n          }\n        : undefined;\n\n    const columns = [checkboxColumn, ...this.columns, actionsColumn]\n      .filter(Boolean)\n      .map(this.withColumnDefaults);\n\n    this.columns = uniqBy(columns, 'name');\n    this.updateColumnNames();\n    this.updateGridColumnsSize();\n    this.updateThEls();\n    this.updateFilteringApplied();\n  }\n\n  private withColumnDefaults(column): Column {\n    const dataType = column.dataType || ColumnDataType.TextShort;\n    const { headerCSSClassName, cellCSSClassName } = column;\n\n    return {\n      visible: true,\n      positionFixed: false,\n      resizable: true,\n      sortable: true,\n      sortOrder: '',\n      filterable: false,\n      ...column,\n      dataType,\n      gridTrackSize:\n        column.gridTrackSize ||\n        `minmax(${minColumnGridTrackSize}px, ${ratiosByColumnTypes[dataType]}fr)`,\n      headerCSSClassName:\n        (typeof headerCSSClassName === 'string'\n          ? headerCSSClassName.split(' ')\n          : headerCSSClassName) || [],\n      cellCSSClassName:\n        (typeof cellCSSClassName === 'string' ? cellCSSClassName.split(' ') : cellCSSClassName) ||\n        []\n    };\n  }\n\n  private updateColumnNames() {\n    this.columnNames = this.columns.map(({ name }) => name);\n  }\n\n  private setupResizeHandle() {\n    const resizeHandleDrag$ = this.resizeHandleMouseDown$.pipe(\n      takeUntil(this.unsubscribe$),\n      tap(() => this.clearMouseHighlights()),\n      mergeMap(({ event, targetColumnName }) => {\n        this.columns = this.columns.map(column => {\n          if (column.name === targetColumnName) {\n            return {\n              ...column,\n              headerCSSClassName: union(column.headerCSSClassName, ['header--being-resized'])\n            };\n          }\n\n          return column;\n        });\n\n        this.headerBeingResized = {\n          columnName: targetColumnName,\n          el: event.target?.parentNode\n        };\n\n        this.styles = {\n          ...this.styles,\n          tableCursor: 'col-resize'\n        };\n\n        return this.resizeHandleContainerMouseMove$.pipe(\n          tap(() => this.clearMouseHighlights()),\n          takeUntil(this.resizeHandleContainerMouseUp$)\n        );\n      })\n    );\n\n    resizeHandleDrag$.subscribe((event: MouseEvent) => {\n      requestAnimationFrame(() => {\n        this.columns = this.columns.map((column, i) => {\n          if (this.headerBeingResized && column.name === this.headerBeingResized.columnName) {\n            const scrollContainerDiv: HTMLDivElement = this.scrollContainer.nativeElement;\n\n            // Read scrollContainerEl's offset left relative to the document.\n            const horizontalOffset = scrollContainerDiv.getBoundingClientRect().left;\n\n            // Adjust with the scrollContainerEl horizontal scroll position.\n            const horizontalScrollOffset = scrollContainerDiv.scrollLeft - horizontalOffset;\n\n            // Read left offset of the resized header.\n            const headerOffsetLeft = this.headerBeingResized.el.offsetLeft || 0;\n\n            // Calculate the desired width.\n            const width = horizontalScrollOffset + event.clientX - headerOffsetLeft;\n\n            return {\n              ...column,\n              // Update the column object with the new size value, enforce our minimum size.\n              gridTrackSize: `${Math.max(minColumnGridTrackSize, width)}px`\n            };\n          }\n\n          // For the other headers which don't have a set width, fix it to their computed width.\n          if (column.gridTrackSize.startsWith('minmax')) {\n            return {\n              ...column,\n              // isn't fixed yet (it would be a px value)\n              gridTrackSize: `${_parseInt(this.thEls[i].clientWidth)}px`\n            };\n          }\n\n          return column;\n        });\n\n        /*\n         * Update the column sizes.\n         * Note: grid-template-columns sets the width for all columns in one value.\n         */\n        this.updateGridColumnsSize();\n      });\n    });\n\n    this.resizeHandleContainerMouseUp$.pipe(takeUntil(this.unsubscribe$)).subscribe(() => {\n      if (this.headerBeingResized) {\n        this.columns = this.columns.map(column => {\n          if (column.name === this.headerBeingResized.columnName) {\n            return {\n              ...column,\n              headerCSSClassName: without(column.headerCSSClassName, 'header--being-resized')\n            };\n          }\n\n          return column;\n        });\n        this.headerBeingResized = undefined;\n\n        this.styles = {\n          ...this.styles,\n          tableCursor: 'auto'\n        };\n      }\n    });\n  }\n\n  private clearMouseHighlights() {\n    if (window.getSelection) {\n      window.getSelection().removeAllRanges();\n    }\n  }\n\n  private _getCellRendererSpec({ type, value, row, columnName }): CellRendererSpec {\n    const column = this.columns.find(({ name }) => name === columnName);\n    const columnRenderer = this.getColumnRenderer(column);\n    const rendererTemplate = get(\n      columnRenderer,\n      `${type === 'HEADER' ? 'headerCellRendererDef' : 'cellRendererDef'}.template`\n    );\n\n    const { cellRendererComponent, headerCellRendererComponent } = column;\n    const rendererComponent =\n      type === 'HEADER' ? headerCellRendererComponent : cellRendererComponent;\n\n    return {\n      renderer: rendererTemplate || rendererComponent,\n      context: {\n        value,\n        item: row,\n        property: column\n      }\n    };\n  }\n\n  private getColumnRenderer(column): ColumnDirective {\n    return this.columnRenderers.toArray().find(({ name }) => name === column.name);\n  }\n\n  private updateFilteringLabelsParams(stats: DataSourceStats) {\n    this.filteringLabelsParams = {\n      filteredItemsCount: stats.filteredSize,\n      allItemsCount: stats.size\n    };\n  }\n\n  private updatePaginationLabelParams(stats: DataSourceStats) {\n    if (stats.nextPage) {\n      this.pagination = { ...this.pagination, nextPage: stats.nextPage };\n    }\n\n    const pageFirstItemIdx = (stats.currentPage - 1) * stats.firstPageSize + 1;\n    this.paginationLabelParams = {\n      pageFirstItemIdx,\n      pageLastItemIdx: pageFirstItemIdx + (stats.currentPageSize - 1),\n      itemsTotal: stats.filteredSize\n    };\n  }\n\n  private createLoadMoreComponent(stats: DataSourceStats) {\n    if (\n      this.infiniteScroll &&\n      stats &&\n      stats.nextPage &&\n      (!this.loadMoreComponent || this.recreateLoadMoreComponent)\n    ) {\n      this.recreateLoadMoreComponent = false;\n      this.infiniteScrollContainer.clear();\n      const componentFactory: ComponentFactory<any> =\n        this.cfr.resolveComponentFactory(LoadMoreComponent);\n      const componentRef = this.infiniteScrollContainer.createComponent(componentFactory);\n      const instance = componentRef.instance as LoadMoreComponent;\n      instance.useIntersection = this.infiniteScroll === 'auto' || this.infiniteScroll === 'hidden';\n      instance.hidden = this.infiniteScroll === 'hidden';\n      instance.paging = {\n        nextPage: stats.nextPage,\n        next: this.loadNextPage.bind(this)\n      } as Paging<any>;\n      instance.loadNextLabel = this.loadMoreItemsLabel;\n      instance.loadingLabel = this.loadingItemsLabel;\n      this.loadMoreComponent = instance;\n    } else if (this.loadMoreComponent && !stats.nextPage) {\n      this.loadMoreComponent.paging = {\n        nextPage: null\n      } as Paging<any>;\n    }\n  }\n\n  private scrollToTop() {\n    if (this.infiniteScroll) {\n      this.scrollContainer.nativeElement.scrollTop = 0;\n    }\n  }\n\n  private processAndPersistConfigChange() {\n    merge(\n      merge(\n        this.onSort,\n        this.onPageSizeChange,\n        this.onColumnReordered,\n        this.onColumnVisibilityChange\n      ).pipe(map(config => config.columns)),\n      merge(this.onAddCustomColumn, this.onRemoveCustomColumn).pipe(\n        map(() => (this.columns || []).map(this.mapColumnToConfig.bind(this)))\n      ),\n      this.onFilter.pipe(\n        map(({ columnName, filteringModifier }) =>\n          this.columns.map(this.mapColumnToConfig.bind(this)).map((column: ColumnConfig) => {\n            if (isNil(columnName)) {\n              delete column.filter;\n            } else if (column.name === columnName) {\n              if (isEmpty(filteringModifier)) {\n                delete column.filter;\n              } else {\n                column.filter = filteringModifier;\n              }\n            }\n\n            return column;\n          })\n        )\n      )\n    )\n      .pipe(\n        map((columns: Array<ColumnConfig | CustomColumnConfig>) => ({\n          columns,\n          pagination: this.pagination\n        })),\n        filter(() => !!this.configurationStrategy),\n        this.trimFilterConfigPipe(),\n        this.trimSortConfigPipe(),\n        this.trimCustomColumnConfigPipe(),\n        this.ignoreColumnOrderPipe(),\n        this.ignoreColumnVisibilityPipe(),\n        concatMap((config: GridConfig) => this.configurationStrategy.saveConfig$(config)),\n        takeUntil(this.unsubscribe$)\n      )\n      .subscribe();\n  }\n\n  private trimFilterConfigPipe(): UnaryFunction<Observable<GridConfig>, Observable<GridConfig>> {\n    return pipe(\n      this.checkEventPipe('filter', config => {\n        config.columns = (config.columns || []).map(col => {\n          delete col.filter;\n          return col;\n        });\n\n        return config;\n      })\n    );\n  }\n\n  private trimSortConfigPipe(): UnaryFunction<Observable<GridConfig>, Observable<GridConfig>> {\n    return pipe(\n      this.checkEventPipe('sort', config => {\n        config.columns = (config.columns || []).map(col => {\n          col.sortOrder = '';\n          return col;\n        });\n\n        return config;\n      })\n    );\n  }\n\n  private trimCustomColumnConfigPipe(): UnaryFunction<\n    Observable<GridConfig>,\n    Observable<GridConfig>\n  > {\n    return pipe(\n      this.checkEventPipe('customColumns', config => {\n        config.columns = (config.columns || []).filter((col: CustomColumnConfig) => !col.custom);\n\n        return config;\n      })\n    );\n  }\n\n  private ignoreColumnOrderPipe(): UnaryFunction<Observable<GridConfig>, Observable<GridConfig>> {\n    return pipe(\n      this.checkEventPipe('order', config => {\n        return this.configurationStrategy.getConfig$().pipe(\n          map(oldConfig => {\n            const oldColumns: ColumnConfig[] =\n              oldConfig?.columns || (this.defaultColumns as ColumnConfig[]);\n            // check if custom columns have been added\n            const columnsAdded = (config.columns || []).filter(\n              col => !oldColumns.find(old => old.name === col.name)\n            );\n\n            config.columns = [\n              ...oldColumns.map(oldCol =>\n                (config.columns || []).find(newCol => newCol.name === oldCol.name)\n              ),\n              ...columnsAdded\n            ];\n\n            return config;\n          })\n        );\n      })\n    );\n  }\n\n  private ignoreColumnVisibilityPipe(): UnaryFunction<\n    Observable<GridConfig>,\n    Observable<GridConfig>\n  > {\n    return pipe(\n      this.checkEventPipe('visibility', config => {\n        return this.configurationStrategy.getConfig$().pipe(\n          map(oldConfig => {\n            config.columns = (config.columns || []).map(newCol => {\n              const columns: ColumnConfig[] =\n                oldConfig?.columns || (this.defaultColumns as ColumnConfig[]);\n              const oldCol = columns.find((col: any) => newCol.name === col.name);\n              newCol.visible = oldCol?.visible ?? true;\n              return newCol;\n            });\n\n            return config;\n          })\n        );\n      })\n    );\n  }\n\n  private checkEventPipe(\n    configPart: GridConfigPart,\n    trimEventDataFn: (config: GridConfig) => GridConfig | Observable<GridConfig>\n  ): UnaryFunction<Observable<GridConfig>, Observable<GridConfig>> {\n    return pipe(\n      concatMap((config: GridConfig) => {\n        return this.resolveConfigFilter\n          .call(this, configPart)\n          .pipe(map(keepEventData => ({ config, keepEventData })));\n      }),\n      map(({ config, keepEventData }) =>\n        keepEventData ? config : trimEventDataFn.call(this, config)\n      ),\n      concatMap(config => (isObservable(config) ? config : of(config)) as Observable<GridConfig>)\n    );\n  }\n\n  private resolveConfigFilter(configPart: GridConfigPart): Observable<boolean> {\n    let result: boolean | Observable<boolean> | Promise<boolean>;\n    const valueOrFn = this.configurationStrategy.getContext()?.configFilter?.[configPart];\n    if (typeof valueOrFn === 'function') {\n      result = valueOrFn();\n    } else {\n      result = valueOrFn;\n    }\n    return toObservable(result ?? true);\n  }\n}\n","<div\n  #scroll\n  class=\"table-data-grid-scroll\"\n  [ngClass]=\"{ 'table-data-grid__overlay': (dataSource.loading$ | async) && !loadMoreComponent }\"\n  data-cy=\"c8y-data-grid--table-data-grid-scroll\"\n>\n  <div\n    class=\"table-data-grid__loading--wrapper\"\n    *ngIf=\"(dataSource.loading$ | async) && !loadMoreComponent\"\n  >\n    <div class=\"table-data-grid__loading--loader\">\n      <c8y-progress-bar [message]=\"loadingItemsLabel\"></c8y-progress-bar>\n    </div>\n  </div>\n\n  <div *ngIf=\"displayOptions.gridHeader\" class=\"table-data-grid-header separator large-padding\">\n    <div class=\"h4\" [ngClass]=\"{ 'm-r-16': !!title }\">{{ title | translate }}</div>\n\n    <ng-container *ngIf=\"displayOptions.filter\">\n      <span *ngIf=\"!filteringApplied\">\n        <span class=\"label label-default m-r-4\" translate>No filters</span>\n        <small\n          *ngIf=\"!!filteringLabelsParams.allItemsCount\"\n          class=\"m-r-4\"\n          ngNonBindable\n          translate\n          [translateParams]=\"filteringLabelsParams\"\n        >\n          {{ filteredItemsCount }} of {{ allItemsCount }} items\n        </small>\n      </span>\n      <span *ngIf=\"filteringApplied\">\n        <ng-container *ngIf=\"!!filteringLabelsParams.allItemsCount\">\n          <span class=\"badge badge-info m-r-4\">\n            {{ (dataSource.stats$ | async).filteredSize }}\n          </span>\n          <small ngNonBindable translate [translateParams]=\"filteringLabelsParams\">\n            of {{ allItemsCount }} items\n          </small>\n        </ng-container>\n        <button\n          class=\"btn btn-sm btn-default m-l-8 m-r-4\"\n          type=\"button\"\n          title=\"{{ 'Clear filters' | translate }}\"\n          (click)=\"clearFilters()\"\n        >\n          {{ 'Clear filters' | translate }}\n        </button>\n      </span>\n\n      <button\n        class=\"btn-help btn-help--sm hidden-xs hidden-sm\"\n        *ngIf=\"displayOptions.filter\"\n        type=\"button\"\n        [attr.aria-label]=\"'Help' | translate\"\n        popover=\"{{ 'Click the column headers to apply filters.' | translate }}\"\n        placement=\"right\"\n        triggers=\"focus\"\n        [attr.aria-label]=\"'Click the column headers to apply filters.' | translate\"\n        data-cy=\"data-grid--help-filters\"\n      >\n        <i c8yIcon=\"question-circle-o\"></i>\n      </button>\n\n      <button\n        class=\"btn-clean text-primary hidden-xs hidden-sm\"\n        *ngIf=\"showCounterWarning\"\n        type=\"button\"\n        [attr.aria-label]=\"'Help' | translate\"\n        popover=\"{{ 'The counter for the total number of items might be inaccurate.' | translate }}\"\n        placement=\"right\"\n        triggers=\"focus\"\n      >\n        <i c8yIcon=\"warning\"></i>\n      </button>\n    </ng-container>\n\n    <div class=\"m-l-auto\">\n      <div class=\"btnbar d-flex a-i-center\">\n        <ng-container *ngFor=\"let headerActionControl of headerActionControls\">\n          <ng-container *ngIf=\"headerActionControl | isControlVisible\">\n            <ng-container *ngIf=\"!headerActionControl.template; else customTemplate\">\n              <button\n                class=\"btnbar-btn btn-link\"\n                type=\"button\"\n                title=\"{{ headerActionControl.text | translate }}\"\n                (click)=\"headerActionControl.callback()\"\n                c8yProductExperience\n                inherit\n                [actionData]=\"{\n                  action: PX_ACTIONS.CUSTOM_ACTION,\n                  customActionName: headerActionControl.text,\n                  type: headerActionControl.type\n                }\"\n              >\n                <i [c8yIcon]=\"headerActionControl.icon\" class=\"m-r-4\"></i>\n                <span>{{ headerActionControl.text | translate }}</span>\n              </button>\n            </ng-container>\n            <ng-template #customTemplate>\n              <ng-container\n                *ngTemplateOutlet=\"\n                  headerActionControl.template;\n                  context: { headerActionControl: headerActionControl }\n                \"\n              ></ng-container>\n            </ng-template>\n          </ng-container>\n        </ng-container>\n\n        <div\n          *ngIf=\"configureColumnsEnabled\"\n          class=\"dropdown\"\n          dropdown\n          #ddConfigureColumns=\"bs-dropdown\"\n          [cdkTrapFocus]=\"ddConfigureColumns.isOpen\"\n          [insideClick]=\"true\"\n          placement=\"bottom left\"\n        >\n          <button\n            title=\"{{ 'Configure columns' | translate }}\"\n            data-cy=\"data-grid--custom-column-btn\"\n            class=\"btnbar-btn\"\n            type=\"button\"\n            dropdownToggle\n          >\n            <i c8yIcon=\"columns\" class=\"m-r-4\"></i>\n            <span>{{ 'Configure columns' | translate }}</span>\n          </button>\n\n          <ul *dropdownMenu class=\"dropdown-menu data-grid__dropdown\" (click)=\"$event.stopPropagation()\">\n            <li class=\"bg-level-0\">\n              <div cdkDropList (cdkDropListDropped)=\"onColumnDrop($event)\" class=\"list-group m-0\">\n                <div *ngFor=\"let column of columns\" cdkDrag cdkDragLockAxis=\"y\">\n                  <ng-container *ngIf=\"!column.positionFixed\">\n                    <div class=\"list-group-item draggable-after p-0 a-i-center\">\n                      <label\n                        title=\"{{ (column.header | translate) || column.name }}\"\n                        [attr.data-cy]=\"'data-grid--custom-column-header-' + column.header\"\n                        class=\"c8y-checkbox p-l-16\"\n                      >\n                        <input\n                          type=\"checkbox\"\n                          [(ngModel)]=\"column.visible\"\n                          (change)=\"\n                            updateGridColumnsSize(); emitConfigChange('changeColumnVisibility')\n                          \"\n                          c8yProductExperience\n                          inherit\n                          [actionData]=\"{\n                            action: PX_ACTIONS.CHANGE_VISIBILITY,\n                            column: column.name,\n                            visible: !column.visible\n                          }\"\n                        />\n                        <span></span>\n                        <span>{{ (column.header | translate) || column.name }}</span>\n                      </label>\n                      <button\n                        class=\"btn btn-dot showOnHover max-width-fit a-i-center\"\n                        type=\"button\"\n                        [attr.aria-label]=\"'Remove`column,verb`' | translate\"\n                        tooltip=\"{{ 'Remove`column,verb`' | translate }}\"\n                        placement=\"left\"\n                        container=\"body\"\n                        (click)=\"removeCustomColumn(poConfirm, column, ddConfigureColumns)\"\n                        *ngIf=\"column.custom\"\n                      >\n                        <c8y-popover-confirm\n                          [placement]=\"'left'\"\n                          [title]=\"'Confirm removal' | translate\"\n                          triggers=\"focus\"\n                          #poConfirm\n                        ></c8y-popover-confirm>\n                        <i c8yIcon=\"minus-circle\" data-cy=\"data-grid--custom-column-remove-btn\"></i>\n                      </button>\n                    </div>\n                  </ng-container>\n                </div>\n              </div>\n            </li>\n            <li *ngIf=\"isConfigContextKnown\" class=\"p-8 sticky-bottom separator-top\">\n              <button\n                class=\"btn btn-default btn-block\"\n                type=\"button\"\n                title=\"{{ 'Add custom column' | translate }}\"\n                data-cy=\"data-grid--add-custom-column\"\n                (click)=\"openCustomColumnModal(); ddConfigureColumns.hide()\"\n              >\n                <i c8yIcon=\"plus-circle\" class=\"m-r-4\"></i>\n                <span>{{ 'Add custom column' | translate }}</span>\n              </button>\n            </li>\n          </ul>\n        </div>\n\n        <button\n          title=\"{{ 'Reload' | translate }}\"\n          data-cy=\"data-grid--reload-btn\"\n          class=\"btnbar-btn btn-link\"\n          type=\"button\"\n          [disabled]=\"dataSource.loading$ | async\"\n          (click)=\"clickReload()\"\n        >\n          <i c8yIcon=\"refresh\" class=\"m-r-4\"></i>\n          <span>{{ 'Reload' | translate }}</span>\n        </button>\n\n        <div\n          *ngIf=\"!serverSideDataCallback || showSearch\"\n          class=\"input-group input-group-search m-l-sm-16 data-grid__search-input\"\n        >\n          <input\n            type=\"search\"\n            class=\"form-control\"\n            placeholder=\"{{ 'Search…' | translate }}\"\n            [ngModel]=\"searchText\"\n            (input)=\"searchText$.emit($event.target.value)\"\n          />\n          <div class=\"input-group-addon\">\n            <i c8yIcon=\"search\" *ngIf=\"searchText.length === 0\"></i>\n            <i\n              c8yIcon=\"times\"\n              class=\"pointer\"\n              *ngIf=\"searchText.length > 0\"\n              (click)=\"searchText = ''; searchText$.emit('')\"\n              c8yProductExperience\n              inherit\n              [actionData]=\"{ action: PX_ACTIONS.CLEAR_SEARCH }\"\n            ></i>\n          </div>\n        </div>\n      </div>\n    </div>\n    <div\n      class=\"table-data-grid-header-bulk-actions animated slideInDown fast\"\n      *ngIf=\"selectedItemIds.length !== 0\"\n    >\n      <h4>\n        <span ngNonBindable translate [translateParams]=\"{ count: selectedItemIds.length }\">\n          {{ count }} selected item(s).\n        </span>\n        <br class=\"visible-xs\" />\n        <small *ngIf=\"!serverSideDataCallback && selectedItemIds.length >= pagination.pageSize\">\n          <a\n            (click)=\"setAllItemsSelected(true)\"\n            class=\"interact\"\n            c8yProductExperience\n            inherit\n            [actionData]=\"{ action: PX_ACTIONS.SELECT_ALL_ITEMS }\"\n          >\n            <span\n              ngNonBindable\n              translate\n              [translateParams]=\"{ count: (dataSource.stats$ | async).filteredSize }\"\n            >\n              Select all {{ count }} items\n            </span>\n          </a>\n        </small>\n      </h4>\n      <div class=\"m-l-auto\">\n        <div class=\"btnbar d-flex\">\n          <ng-container *ngFor=\"let bulkActionControl of bulkActionControls\">\n            <ng-container\n              *ngIf=\"bulkActionControl | isControlVisible: selectedItemIds\"\n              [ngSwitch]=\"bulkActionControl.type\"\n            >\n              <button\n                class=\"btnbar-btn\"\n                type=\"button\"\n                title=\"{{ 'Export' | translate }}\"\n                (click)=\"bulkActionControl.callback(selectedItemIds, reload.bind(this))\"\n                *ngSwitchCase=\"builtInActionType.Export\"\n                [actionData]=\"{ action: PX_ACTIONS.BULK_EXPORT }\"\n                c8yProductExperience\n                inherit\n              >\n                <i c8yIcon=\"sign-out\"></i>\n                <span>{{ 'Export' | translate }}</span>\n              </button>\n\n              <button\n                class=\"btnbar-btn\"\n                type=\"button\"\n                title=\"{{ 'Delete' | translate }}\"\n                (click)=\"bulkActionControl.callback(selectedItemIds, reload.bind(this))\"\n                *ngSwitchCase=\"builtInActionType.Delete\"\n                [actionData]=\"{ action: PX_ACTIONS.BULK_DELETE }\"\n                c8yProductExperience\n                inherit\n              >\n                <i c8yIcon=\"delete\"></i>\n                <span>{{ 'Delete' | translate }}</span>\n              </button>\n\n              <button\n                class=\"btnbar-btn\"\n                type=\"button\"\n                title=\"{{ bulkActionControl.text | translate }}\"\n                (click)=\"bulkActionControl.callback(selectedItemIds, reload.bind(this))\"\n                *ngSwitchDefault\n                [actionData]=\"{\n                  action: PX_ACTIONS.BULK_CUSTOM_ACTION,\n                  customActionName: bulkActionControl.text\n                }\"\n                c8yProductExperience\n                inherit\n              >\n                <i c8yIcon=\"{{ bulkActionControl.icon }}\"></i>\n                <span>{{ bulkActionControl.text | translate }}</span>\n              </button>\n            </ng-container>\n          </ng-container>\n\n          <button\n            class=\"btnbar-btn\"\n            type=\"button\"\n            title=\"{{ 'Cancel' | translate }}\"\n            (click)=\"cancel()\"\n            [actionData]=\"{\n              action: PX_ACTIONS.BULK_CANCEL\n            }\"\n            c8yProductExperience\n            inherit\n          >\n            <i c8yIcon=\"times\"></i>\n            <span>{{ 'Cancel' | translate }}</span>\n          </button>\n        </div>\n      </div>\n    </div>\n  </div>\n\n  <table\n    class=\"table table-hover table-filtered-sorted table-data-grid large-padding\"\n    cdk-table\n    [dataSource]=\"dataSource\"\n    [trackBy]=\"trackByName\"\n    [class.table-striped]=\"displayOptions.striped\"\n    [class.table-bordered]=\"displayOptions.bordered\"\n    [class.table-data-grid-with-checkboxes]=\"selectable\"\n    [class.table-data-grid-with-actions]=\"actionControls.length > 0\"\n    [style.grid-template-columns]=\"styles.gridTemplateColumns\"\n    (mousemove)=\"resizeHandleContainerMouseMove$.emit($event)\"\n    (mouseup)=\"resizeHandleContainerMouseUp$.emit($event)\"\n    data-cy=\"c8y-data-grid--table\"\n  >\n    <ng-container\n      *ngFor=\"let column of columns; let i = index; trackBy: trackByName\"\n      [cdkColumnDef]=\"column.name\"\n    >\n      <ng-container [ngSwitch]=\"column.name\">\n        <ng-container *ngSwitchCase=\"'checkbox'\">\n          <th cdk-header-cell *cdkHeaderCellDef data-type=\"icon\">\n            <div>\n              <label class=\"c8y-checkbox\">\n                <input\n                  [attr.aria-label]=\"'Selected' | translate\"\n                  type=\"checkbox\"\n                  [checked]=\"currentPageSelectionState.allSelected\"\n                  [indeterminate]=\"\n                    !(\n                      currentPageSelectionState.allSelected ||\n                      currentPageSelectionState.allDeselected\n                    )\n                  \"\n                  (change)=\"setAllItemsInCurrentPageSelected($event.target.checked)\"\n                  c8yProductExperience\n                  inherit\n                  [actionData]=\"{ action: PX_ACTIONS.SELECT_ALL_ITEMS }\"\n                />\n                <span></span>\n              </label>\n            </div>\n          </th>\n\n          <td cdk-cell *cdkCellDef=\"let row\" data-type=\"icon\">\n            <label class=\"c8y-checkbox\">\n              <input\n                [attr.aria-label]=\"'Selected' | translate\"\n                type=\"checkbox\"\n                [checked]=\"isItemSelected(row)\"\n                (change)=\"setItemsSelected([row], $event.target.checked)\"\n                c8yProductExperience\n                inherit\n                [actionData]=\"{\n                  action: PX_ACTIONS.SELECT_ITEM,\n                  id: row.id\n                }\"\n                data-cy=\"c8y-data-grid--checkbox\"\n              />\n              <span></span>\n            </label>\n          </td>\n        </ng-container>\n\n        <ng-container *ngSwitchCase=\"'actions'\">\n          <th cdk-header-cell *cdkHeaderCellDef data-type=\"icon\">\n            <p class=\"text-medium sr-only\">{{ 'Actions' | translate }}</p>\n          </th>\n\n          <td cdk-cell *cdkCellDef=\"let row\" data-type=\"icon\">\n            <ng-container *ngIf=\"actionControls.length <= 2\">\n              <ng-container *ngFor=\"let actionControl of actionControls\">\n                <ng-container\n                  *ngIf=\"actionControl | isControlVisible: row\"\n                  [ngSwitch]=\"actionControl.type\"\n                >\n                  <button\n                    *ngSwitchCase=\"builtInActionType.Edit\"\n                    class=\"btn btn-dot\"\n                    type=\"button\"\n                    [attr.aria-label]=\"'Edit' | translate\"\n                    tooltip=\"{{ 'Edit' | translate }}\"\n                    [delay]=\"500\"\n                    container=\"body\"\n                    (click)=\"actionControl.callback(row, reload.bind(this))\"\n                    c8yProductExperience\n                    inherit\n                    [actionData]=\"{\n                      action: PX_ACTIONS.EDIT_ITEM,\n                      id: row.id\n                    }\"\n                  >\n                    <i c8yIcon=\"pencil\"></i>\n                  </button>\n\n                  <button\n                    class=\"btn btn-dot btn-dot--danger showOnHover\"\n                    type=\"button\"\n                    [attr.aria-label]=\"'Delete' | translate\"\n                    tooltip=\"{{ 'Delete' | translate }}\"\n                    [delay]=\"500\"\n                    container=\"body\"\n                    (click)=\"actionControl.callback(row, reload.bind(this))\"\n                    *ngSwitchCase=\"builtInActionType.Delete\"\n                    [actionData]=\"{\n                      action: PX_ACTIONS.DELETE_ITEM,\n                      id: row.id\n                    }\"\n                    c8yProductExperience\n                    inherit\n                    data-cy=\"c8y-data-grid--remove-button-in-row\"\n                  >\n                    <i c8yIcon=\"delete\"></i>\n                  </button>\n\n                  <button\n                    class=\"btn btn-dot\"\n                    type=\"button\"\n                    [attr.aria-label]=\"(actionControl.icon ? actionControl.text : '') | translate\"\n                    tooltip=\"{{ (actionControl.icon ? actionControl.text : '') | translate }}\"\n                    [delay]=\"500\"\n                    container=\"body\"\n                    *ngSwitchDefault\n                    (click)=\"actionControl.callback(row, reload.bind(this))\"\n                    [actionData]=\"{\n                      action: PX_ACTIONS.CUSTOM_ACTION_ITEM,\n                      customActionName: actionControl.text,\n                      id: row.id\n                    }\"\n                    c8yProductExperience\n                    inherit\n                  >\n                    <i *ngIf=\"actionControl.icon\" c8yIcon=\"{{ actionControl.icon }}\"></i>\n                    <span *ngIf=\"!actionControl.icon\">{{ actionControl.text | translate }}</span>\n                  </button>\n                </ng-container>\n              </ng-container>\n            </ng-container>\n\n            <div [ngClass]=\"{ 'm-l-auto overflow-visible': actionControls.length > 2 }\">\n              <div\n                class=\"dropdown\"\n                dropdown\n                container=\"body\"\n                placement=\"bottom right\"\n                *ngIf=\"actionControls.length > 2\"\n              >\n                <button\n                  class=\"dropdown-toggle c8y-dropdown\"\n                  type=\"button\"\n                  title=\"{{ 'Actions' | translate }}\"\n                  dropdownToggle\n                  aria-haspopup=\"true\"\n                >\n                  <i c8yIcon=\"ellipsis-v\"></i>\n                </button>\n                <ul class=\"dropdown-menu dropdown-menu-right\" *dropdownMenu>\n                  <li *ngFor=\"let actionControl of actionControls\">\n                    <ng-container\n                      *ngIf=\"actionControl | isControlVisible: row\"\n                      [ngSwitch]=\"actionControl.type\"\n                    >\n                      <button\n                        type=\"button\"\n                        title=\"{{ 'Edit' | translate }}\"\n                        *ngSwitchCase=\"builtInActionType.Edit\"\n                        (click)=\"actionControl.callback(row, reload.bind(this))\"\n                        [actionData]=\"{\n                          action: PX_ACTIONS.EDIT_ITEM,\n                          id: row.id\n                        }\"\n                        c8yProductExperience\n                        inherit\n                      >\n                        <i c8yIcon=\"pencil\"></i>\n                        {{ 'Edit' | translate }}\n                      </button>\n                      <button\n                        type=\"button\"\n                        title=\"{{ 'Delete' | translate }}\"\n                        *ngSwitchCase=\"builtInActionType.Delete\"\n                        (click)=\"actionControl.callback(row, reload.bind(this))\"\n                        [actionData]=\"{\n                          action: PX_ACTIONS.DELETE_ITEM,\n                          id: row.id\n                        }\"\n                        c8yProductExperience\n                        inherit\n                      >\n                        <i c8yIcon=\"delete\"></i>\n                        {{ 'Delete' | translate }}\n                      </button>\n                      <button\n                        type=\"button\"\n                        title=\"{{ 'Export' | translate }}\"\n                        *ngSwitchCase=\"builtInActionType.Export\"\n                        (click)=\"actionControl.callback(row, reload.bind(this))\"\n                        [actionData]=\"{\n                          action: PX_ACTIONS.EXPORT_ITEM,\n                          id: row.id\n                        }\"\n                        c8yProductExperience\n                        inherit\n                      >\n                        <i c8yIcon=\"download\"></i>\n                        {{ 'Export' | translate }}\n                      </button>\n                      <button\n                        type=\"button\"\n                        title=\"{{ actionControl.text | translate }}\"\n                        *ngSwitchDefault\n                        (click)=\"actionControl.callback(row, reload.bind(this))\"\n                        c8yProductExperience\n                        inherit\n                        [actionData]=\"{\n                          action: PX_ACTIONS.CUSTOM_ACTION_ITEM,\n                          customActionName: actionControl.text,\n                          id: row.id\n                        }\"\n                      >\n                        <i c8yIcon=\"{{ actionControl.icon }}\"></i>\n                        {{ actionControl.text | translate }}\n                      </button>\n                    </ng-container>\n                  </li>\n                </ul>\n              </div>\n            </div>\n          </td>\n        </ng-container>\n\n        <ng-container *ngSwitchDefault>\n          <th\n            cdk-header-cell\n            *cdkHeaderCellDef\n            [ngClass]=\"column.headerCSSClassName\"\n            [attr.data-type]=\"column.dataType\"\n            [class.sorted]=\"column.sortOrder\"\n            [class.filtered]=\"column | map: isColumnFilteringApplied\"\n            [class.hidden]=\"!column.visible\"\n          >\n            <div *ngIf=\"!column.filterable\" [title]=\"(column.header | translate) || column.name\">\n              <ng-container\n                *ngIf=\"\n                  [\n                    {\n                      columnName: column.name,\n                      value: (column.header | translate) || column.name\n                    }\n                  ] | map: getHeaderCellRendererSpec:this as cellRendererSpec\n                \"\n              >\n                <c8y-cell-renderer [spec]=\"cellRendererSpec\"></c8y-cell-renderer>\n              </ng-container>\n            </div>\n\n            <!-- isDropDownPlacedRight to be removed when columns are transformed to observables. -->\n            <div\n              *ngIf=\"column.filterable\"\n              class=\"dropdown\"\n              dropdown\n              #gridHeaderDropdown=\"bs-dropdown\"\n              [cdkTrapFocus]=\"gridHeaderDropdown.isOpen\"\n              placement=\"bottom {{ isDropDownPlacedRight(column) ? 'right' : 'left' }}\"\n              [insideClick]=\"true\"\n            >\n              <button\n                class=\"btn-header\"\n                type=\"button\"\n                [title]=\"(column.header | translate) || column.name\"\n                [attr.data-cy]=\"'data-grid--header-btn--' + column.header\"\n                dropdownToggle\n              >\n                <ng-container\n                  *ngIf=\"\n                    [\n                      {\n                        columnName: column.name,\n                        value: (column.header | translate) || column.name\n                      }\n                    ] | map: getHeaderCellRendererSpec:this as cellRendererSpec\n                  \"\n                >\n                  <c8y-cell-renderer\n                    data-cy=\"c8y-data-grid--c8y-cell-renderer\"\n                    [spec]=\"cellRendererSpec\"\n                  ></c8y-cell-renderer>\n                </ng-container>\n                <i c8yIcon=\"filter\" title=\"{{ 'Filter' | translate }}\"></i>\n              </button>\n\n              <!-- isDropDownPlacedRight to be removed when columns are transformed to observables. -->\n              <ul\n                *dropdownMenu\n                class=\"dropdown-menu\"\n                [ngClass]=\"{ 'dropdown-menu-right-grid': isDropDownPlacedRight(column) }\"\n                (click)=\"$event.stopPropagation()\"\n              >\n                <li class=\"data-grid__dropdown\">\n                  <ng-container\n                    *ngIf=\"\n                      [\n                        {\n                          column: column,\n                          dropdown: gridHeaderDropdown\n                        }\n                      ] | map: getFilteringFormRendererSpec:this as filteringFormRendererSpec\n                    \"\n                  >\n                    <c8y-filtering-form-renderer\n                      [spec]=\"filteringFormRendererSpec\"\n                      data-cy=\"c8y-data-grid--c8y-filtering-form-renderer\"\n                    ></c8y-filtering-form-renderer>\n                  </ng-container>\n                </li>\n              </ul>\n            </div>\n\n            <button\n              class=\"btn-sort\"\n              type=\"button\"\n              [title]=\"sortColumnTitle | translate: { name: column.header | translate }\"\n              *ngIf=\"column.sortable\"\n              (click)=\"changeSortOrder(column.name)\"\n              data-cy=\"change-sort-order\"\n            >\n              <ng-container [ngSwitch]=\"column.sortOrder\">\n                <i *ngSwitchCase=\"'asc'\" c8yIcon=\"long-arrow-up\"></i>\n                <i *ngSwitchCase=\"'desc'\" c8yIcon=\"long-arrow-down\"></i>\n                <i *ngSwitchDefault c8yIcon=\"exchange\"></i>\n              </ng-container>\n            </button>\n\n            <span\n              *ngIf=\"column.resizable\"\n              class=\"resize-handle\"\n              (mousedown)=\"\n                resizeHandleMouseDown$.emit({ event: $event, targetColumnName: column.name })\n              \"\n            ></span>\n          </th>\n\n          <td\n            cdk-cell\n            *cdkCellDef=\"let row\"\n            [ngClass]=\"column.cellCSSClassName\"\n            [attr.data-cell-title]=\"column.header | translate\"\n            [attr.data-cy]=\"'data-grid--' + column.header\"\n            [attr.data-type]=\"column.dataType\"\n            [class.hidden]=\"!column.visible\"\n          >\n            <ng-container\n              *ngIf=\"\n                [\n                  {\n                    value: resolveCellValue(row, column.path),\n                    row: row,\n                    columnName: column.name\n                  }\n                ] | map: getCellRendererSpec:this as cellRendererSpec\n              \"\n            >\n              <c8y-cell-renderer [spec]=\"cellRendererSpec\"></c8y-cell-renderer>\n            </ng-container>\n          </td>\n        </ng-container>\n      </ng-container>\n    </ng-container>\n\n    <ng-container cdkColumnDef=\"infiniteScrollFooter\">\n      <td cdk-footer-cell *cdkFooterCellDef [style.grid-column]=\"styles.gridInfiniteScrollColumn\">\n        <template #infiniteScrollContainer></template>\n      </td>\n    </ng-container>\n\n    <tr cdk-header-row *cdkHeaderRowDef=\"columnNames\"></tr>\n\n    <tr\n      data-cy=\"c8y-data-grid--row-in-data-grid\"\n      cdk-row\n      *cdkRowDef=\"let row; columns: columnNames\"\n      (mouseover)=\"rowMouseOver.emit(row)\"\n      (mouseleave)=\"rowMouseLeave.emit(row)\"\n      (click)=\"rowClick.emit(row)\"\n    ></tr>\n\n    <ng-container>\n      <tr\n        [ngClass]=\"{ hidden: !infiniteScroll }\"\n        cdk-footer-row\n        *cdkFooterRowDef=\"['infiniteScrollFooter']\"\n      ></tr>\n    </ng-container>\n  </table>\n\n  <div\n    class=\"d-flex m-0 p-t-40 p-b-40\"\n    *ngIf=\"!(dataSource.loading$ | async) && (dataSource.stats$ | async).filteredSize === 0\"\n  >\n    <div class=\"col-lg-3 col-sm-4 m-l-auto m-r-auto\">\n      <ng-content select=\"c8y-ui-empty-state, .c8y-empty-state\"></ng-content>\n    </div>\n  </div>\n\n  <div *ngIf=\"pagination && !infiniteScroll\" class=\"table-data-grid-footer separator large-padding\">\n    <div class=\"col-sm-4 no-gutter\">\n      <div\n        *ngIf=\"(dataSource.stats$ | async).currentPageSize > 0\"\n        class=\"counter p-t-8 p-b-8\"\n        data-cy=\"data-grid--counter\"\n      >\n        <span class=\"text-muted\" ngNonBindable translate [translateParams]=\"paginationLabelParams\">\n          {{ pageFirstItemIdx }} - {{ pageLastItemIdx }} of {{ itemsTotal }}\n        </span>\n      </div>\n    </div>\n\n    <div class=\"col-sm-4 no-gutter text-center\">\n      <div\n        *ngIf=\"(dataSource.stats$ | async).filteredSize > minPossiblePageSize\"\n        class=\"form-group form-inline p-t-8 p-b-8\"\n      >\n        <label class=\"m-r-4\" for=\"filteredSize\">{{ 'Items per page' | translate }}</label>\n        <div class=\"c8y-select-wrapper\">\n          <select\n            class=\"form-control\"\n            id=\"filteredSize\"\n            data-cy=\"data-grid--pagesize-options\"\n            [ngModel]=\"pagination.pageSize\"\n            (ngModelChange)=\"\n              updatePagination({ itemsPerPage: $event, page: pagination.currentPage })\n            \"\n          >\n            <option *ngFor=\"let pageSize of possiblePageSizes\" [ngValue]=\"pageSize\">\n              {{ pageSize }}\n            </option>\n          </select>\n        </div>\n      </div>\n    </div>\n\n    <div class=\"col-sm-4 no-gutter text-right\">\n      <pagination\n        *ngIf=\"(dataSource.stats$ | async).filteredSize > 0\"\n        [class.hidden]=\"hidePagination$ | async\"\n        [ngModel]=\"pagination.currentPage\"\n        (pageChanged)=\"updatePagination($event)\"\n        [totalItems]=\"(dataSource.stats$ | async).filteredSize\"\n        [itemsPerPage]=\"pagination.pageSize\"\n        (numPages)=\"totalPagesCount$.next($event)\"\n        [maxSize]=\"5\"\n        [boundaryLinks]=\"false\"\n        previousText=\"Previous\"\n        nextText=\"Next\"\n        class=\"p-t-8 p-b-8\"\n      ></pagination>\n    </div>\n  </div>\n</div>\n"]}
1035
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-grid.component.js","sourceRoot":"","sources":["../../../../core/data-grid/data-grid.component.ts","../../../../core/data-grid/data-grid.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAEL,SAAS,EAET,wBAAwB,EACxB,eAAe,EACf,UAAU,EACV,YAAY,EACZ,UAAU,EACV,MAAM,EACN,KAAK,EAEL,QAAQ,EACR,MAAM,EACN,SAAS,EACT,SAAS,EACT,YAAY,EACZ,gBAAgB,EACjB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AAEzD,OAAO,EACL,IAAI,EACJ,GAAG,EACH,OAAO,EACP,OAAO,EACP,KAAK,EACL,QAAQ,IAAI,SAAS,EACrB,KAAK,EACL,MAAM,EACN,OAAO,EACR,MAAM,WAAW,CAAC;AAEnB,OAAO,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AACrD,OAAO,EACL,eAAe,EACf,aAAa,EACb,YAAY,EACZ,KAAK,EAEL,EAAE,EACF,IAAI,EACJ,OAAO,EAER,MAAM,MAAM,CAAC;AACd,OAAO,EACL,SAAS,EACT,YAAY,EACZ,KAAK,EACL,oBAAoB,EACpB,MAAM,EACN,KAAK,EACL,GAAG,EACH,QAAQ,EACR,SAAS,EACT,IAAI,EACJ,SAAS,EACT,GAAG,EACJ,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AACtD,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AACzD,OAAO,EAAE,iBAAiB,EAAE,MAAM,+BAA+B,CAAC;AAElE,OAAO,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AAE1C,OAAO,EAAE,gBAAgB,EAAE,MAAM,yCAAyC,CAAC;AAC3E,OAAO,EAGL,+BAA+B,EAChC,MAAM,gDAAgD,CAAC;AAExD,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAC;AAC5D,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AAEtD,OAAO,EAAE,8BAA8B,EAAE,MAAM,2BAA2B,CAAC;AAC3E,OAAO,EAEL,gCAAgC,EAGjC,MAAM,iCAAiC,CAAC;AACzC,OAAO,EAWL,mBAAmB,EAGnB,sBAAsB,EAEtB,mBAAmB,EAKpB,MAAM,mBAAmB,CAAC;AAC3B,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AACtD,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AACpD,OAAO,EAAE,UAAU,EAAE,aAAa,EAAE,MAAM,gCAAgC,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;AAE3E,IAAK,YAGJ;AAHD,WAAK,YAAY;IACf,2BAAW,CAAA;IACX,6BAAa,CAAA;AACf,CAAC,EAHI,YAAY,KAAZ,YAAY,QAGhB;AAaD,MAAM,OAAO,iBAAiB;IAsP5B,YAGS,qBAAoD,EACnD,eAAgC,EAChC,SAAuB,EACvB,GAA6B,EAC7B,gBAAkC,EAClC,cAA8B,EAC9B,YAA0B;QAN3B,0BAAqB,GAArB,qBAAqB,CAA+B;QACnD,oBAAe,GAAf,eAAe,CAAiB;QAChC,cAAS,GAAT,SAAS,CAAc;QACvB,QAAG,GAAH,GAAG,CAA0B;QAC7B,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,mBAAc,GAAd,cAAc,CAAgB;QAC9B,iBAAY,GAAZ,YAAY,CAAc;QA5PpC,wEAAwE;QAC/D,UAAK,GAAW,OAAO,CAAC,OAAO,CAAC,CAAC;QAC1C,sCAAsC;QAC7B,uBAAkB,GAAW,OAAO,CAAC,iBAAiB,CAAC,CAAC;QACjE,uCAAuC;QAC9B,sBAAiB,GAAW,OAAO,CAAC,gBAAgB,CAAC,CAAC;QAC/D,0EAA0E;QACjE,eAAU,GAAG,KAAK,CAAC;QAI5B,YAAO,GAAa,EAAE,CAAC;QAKvB,eAAU,GAAG,IAAI,cAAc,EAAE,CAAC;QAQlC,0BAAqB,GAAG;YACtB,kBAAkB,EAAE,CAAC;YACrB,aAAa,EAAE,CAAC;SACjB,CAAC;QAGF,0BAAqB,GAAG;YACtB,gBAAgB,EAAE,CAAC;YACnB,eAAe,EAAE,CAAC;YAClB,UAAU,EAAE,CAAC;SACd,CAAC;QACO,sBAAiB,GAAa,CAAC,EAAE,EAAE,EAAE,EAAE,GAAG,CAAC,CAAC;QAC5C,wBAAmB,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,iBAAiB,CAAC,CAAC;QAwBnE,eAAU,GAAG,KAAK,CAAC;QAOnB,wBAAmB,GAAG,IAAI,CAAC;QAO3B,mBAAc,GAAmB;YAC/B,OAAO,EAAE,IAAI;YACb,QAAQ,EAAE,KAAK;YACf,UAAU,EAAE,IAAI;YAChB,MAAM,EAAE,IAAI;SACb,CAAC;QA4BF,gCAAgC;QAEhC,eAAU,GAAG,EAAE,CAAC;QAEhB,2DAA2D;QAE3D,4BAAuB,GAAG,IAAI,CAAC;QAE/B,mDAAmD;QAEnD,uBAAkB,GAAG,KAAK,CAAC;QAE3B,+CAA+C;QACrC,iBAAY,GAAG,IAAI,YAAY,EAAU,CAAC;QACpD,8CAA8C;QACpC,kBAAa,GAAG,IAAI,YAAY,EAAU,CAAC;QACrD,4CAA4C;QAClC,aAAQ,GAAG,IAAI,YAAY,EAAU,CAAC;QAChD,2DAA2D;QACjD,mBAAc,GAAG,IAAI,YAAY,EAAc,CAAC;QAC1D,mDAAmD;QACzC,mBAAc,GAAG,IAAI,YAAY,EAAU,CAAC;QACtD,qDAAqD;QAC3C,mBAAc,GAAG,IAAI,YAAY,EAAU,CAAC;QACtD,2DAA2D;QACjD,aAAQ,GAAG,IAAI,YAAY,EAIjC,CAAC;QACL,iJAAiJ;QACvI,gBAAW,GAAG,IAAI,YAAY,EAAY,CAAC;QACrD,oDAAoD;QAC1C,aAAQ,GAAG,IAAI,YAAY,EAAE,CAAC;QACxC,mDAAmD;QACzC,sBAAiB,GAAG,IAAI,YAAY,EAAsB,CAAC;QACrE,qDAAqD;QAC3C,yBAAoB,GAAG,IAAI,YAAY,EAAU,CAAC;QAC5D,4DAA4D;QAClD,wBAAmB,GAAG,IAAI,YAAY,EAAU,CAAC;QAC3D,0DAA0D;QAChD,WAAM,GAAG,IAAI,YAAY,EAAc,CAAC;QAClD,qDAAqD;QAC3C,qBAAgB,GAAG,IAAI,YAAY,EAAc,CAAC;QAC5D,wDAAwD;QAC9C,sBAAiB,GAAG,IAAI,YAAY,EAAc,CAAC;QAC7D,wDAAwD;QAC9C,6BAAwB,GAAG,IAAI,YAAY,EAAc,CAAC;QAWpE,gBAAW,GAAG,EAAE,CAAC;QAEjB,WAAM,GAAG;YACP,WAAW,EAAE,MAAM;YACnB,mBAAmB,EAAE,SAAS;YAC9B,wBAAwB,EAAE,SAAS;SACpC,CAAC;QAEF,gBAAW,GAAG,IAAI,YAAY,EAAU,CAAC;QACzC,qBAAgB,GAAG,KAAK,CAAC;QAEzB,qBAAgB,GAAG,IAAI,eAAe,CAAS,QAAQ,CAAC,CAAC;QACzD,oBAAe,GAAG,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAC1C,GAAG,CAAC,eAAe,CAAC,EAAE,CAAC,eAAe,IAAI,CAAC,CAAC,EAC5C,KAAK,CAAC,CAAC,CAAC,CAAC,uDAAuD;SACjE,CAAC;QAEF,oBAAe,GAAa,EAAE,CAAC;QAC/B,8BAAyB,GAAG;YAC1B,WAAW,EAAE,KAAK;YAClB,aAAa,EAAE,IAAI;SACpB,CAAC;QAEF,sBAAiB,GAAG;YAClB,IAAI,qCAAwB;YAC5B,MAAM,yCAA0B;YAChC,MAAM,yCAA0B;SACjC,CAAC;QAEF,+BAA0B,GAA4B;YACpD;gBACE,KAAK,EAAE,OAAO,CAAC,QAAQ,CAAC;gBACxB,MAAM,EAAE,GAAG,EAAE,CAAC,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC;aACrC;YACD;gBACE,KAAK,EAAE,OAAO,CAAC,qBAAqB,CAAC;gBACrC,MAAM,EAAE,QAAQ;gBAChB,MAAM,EAAE,GAAG,EAAE,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC;aACpC;SACF,CAAC;QAEF,yBAAoB,GAAG,KAAK,CAAC;QAE7B,gDAAgD;QAChD,2BAAsB,GAA2B,EAAE,SAAS,EAAE,aAAa,EAAE,CAAC;QAC9E,eAAU,GAAG,UAAU,CAAC;QAEf,oBAAe,GAAG,OAAO,CAAC,0BAA0B,CAAC,CAAC;QAE/D,2BAAsB,GAAG,IAAI,YAAY,EAAO,CAAC;QACjD,oCAA+B,GAAG,IAAI,YAAY,EAAO,CAAC;QAC1D,kCAA6B,GAAG,IAAI,YAAY,EAAO,CAAC;QAUhD,uBAAkB,GAAG,KAAK,CAAC;QAE3B,mBAAc,GAAa,EAAE,CAAC;QAE9B,yBAAoB,GAAkB,IAAI,OAAO,EAAE,CAAC;QAEpD,iBAAY,GAAG,IAAI,OAAO,EAAO,CAAC;QAEzB,yBAAoB,GAAG,GAAG,CAAC;QAE5C;;;;WAIG;QACK,oBAAe,GAAG,IAAI,YAAY,EAAW,CAAC;QAapD,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,EAAE,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE;YAC1F,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;QACxB,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,oBAAoB;aACtB,IAAI,CACH,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,qBAAqB,EAAE,UAAU,EAAE,IAAI,EAAE,CAAC,IAAI,CAAC,CAAC,EACrE,GAAG,CAAC,MAAM,CAAC,EAAE;YACX,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;YACxB,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;YACzB,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;QACnD,CAAC,CAAC,EACF,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,EACvC,GAAG,CAAC,KAAK,CAAC,EAAE;YACV,IAAI,CAAC,uBAAuB,CAAC,KAAK,CAAC,CAAC;YACpC,IAAI,CAAC,2BAA2B,CAAC,KAAK,CAAC,CAAC;YACxC,IAAI,CAAC,2BAA2B,CAAC,KAAK,CAAC,CAAC;QAC1C,CAAC,CAAC,EACF,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,CAC7B;aACA,SAAS,EAAE,CAAC;IACjB,CAAC;IAjQD,gFAAgF;IAChF,IACI,KAAK,CAAC,IAAW;QACnB,IAAI,CAAC,IAAI,GAAG,IAAI,IAAI,EAAE,CAAC;IACzB,CAAC;IAeD,8EAA8E;IAC9E,IACI,WAAW,CAAC,UAAsB;QACpC,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;IAC/B,CAAC;IAGD,2BAA2B;IAC3B,IACI,eAAe,CAAC,cAA4B;QAC9C,IAAI,CAAC,cAAc,GAAG,cAAc,CAAC;IACvC,CAAC;IAGD;;;OAGG;IACH,IACI,uBAAuB,CAAC,sBAA8C;QACxE,IAAI,CAAC,sBAAsB,GAAG,sBAAsB,CAAC;IACvD,CAAC;IAGD,2FAA2F;IAC3F,IACI,WAAW,CAAC,UAAmB;QACjC,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;IAC/B,CAAC;IAGD,qFAAqF;IACrF,IACI,oBAAoB,CAAC,mBAA2B;QAClD,IAAI,CAAC,mBAAmB,GAAG,mBAAmB,CAAC;IACjD,CAAC;IAQD,4BAA4B;IAC5B,IACI,eAAe,CAAC,cAA8B;QAChD,IAAI,CAAC,cAAc,GAAG,EAAE,GAAG,IAAI,CAAC,cAAc,EAAE,GAAG,cAAc,EAAE,CAAC;IACtE,CAAC;IAGD,qEAAqE;IACrE,IACI,eAAe,CAAC,cAA+B;QACjD,IAAI,CAAC,cAAc,GAAG,cAAc,IAAI,EAAE,CAAC;IAC7C,CAAC;IAGD,gFAAgF;IAChF,IACI,mBAAmB,CAAC,kBAAuC;QAC7D,IAAI,CAAC,kBAAkB,GAAG,kBAAkB,IAAI,EAAE,CAAC;IACrD,CAAC;IAGD,6EAA6E;IAC7E,IACI,qBAAqB,CAAC,oBAA2C;QACnE,IAAI,CAAC,oBAAoB,GAAG,oBAAoB,IAAI,EAAE,CAAC;IACzD,CAAC;IA4KD,QAAQ;QACN,IAAI,CAAC,oBAAoB,GAAG,CAAC,CAAC,IAAI,CAAC,qBAAqB,EAAE,cAAc,EAAE,CAAC;QAE3E,IAAI,CAAC,WAAW;aACb,IAAI,CACH,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,EAC5B,YAAY,CAAC,IAAI,CAAC,oBAAoB,CAAC,EACvC,oBAAoB,EAAE,EACtB,GAAG,CAAC,UAAU,CAAC,EAAE;YACf,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;YAC7B,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YAC1C,IAAI,CAAC,YAAY,CAAC;gBAChB,MAAM,EAAE,UAAU,CAAC,MAAM;gBACzB,WAAW,EAAE,UAAU;aACxB,CAAC,CAAC;QACL,CAAC,CAAC,CACH;aACA,SAAS,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,MAAM,EAAE,CAAC;QAChB,CAAC,CAAC,CAAC;QAEL,IAAI,IAAI,CAAC,UAAU,EAAE;YACnB,aAAa,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,IAAI,CAAC,WAAW,CAAC,YAAY,EAAE,CAAC;iBAClE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;iBAClC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,EAAE;gBACpB,MAAM,gBAAgB,GAAG,IAAI,CAAC,MAAM,KAAK,CAAC,CAAC;gBAE3C,IAAI,CAAC,yBAAyB,GAAG;oBAC/B,WAAW,EAAE,gBAAgB,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;oBACrF,aAAa,EAAE,gBAAgB,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;iBACxF,CAAC;YACJ,CAAC,CAAC,CAAC;SACN;QAED,IAAI,CAAC,oBAAoB,CAAC,IAAI,EAAE,CAAC;QAEjC,IAAI,IAAI,CAAC,OAAO,EAAE;YAChB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;gBAC7D,IAAI,CAAC,MAAM,EAAE,CAAC;gBACd,IAAI,CAAC,MAAM,EAAE,CAAC;YAChB,CAAC,CAAC,CAAC;SACJ;QAED,IAAI,CAAC,6BAA6B,EAAE,CAAC;IACvC,CAAC;IAED,WAAW,CAAC,KAAK;QACf,IACE,CAAC,CAAC,CAAC,KAAK,CAAC,eAAe,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,IAAI,KAAK,CAAC,eAAe,EAAE,WAAW,CAAC;YACrF,IAAI,CAAC,kBAAkB,EACvB;YACA,MAAM,MAAM,GAAG,CAAC,CAAC,KAAK,CAAC,eAAe,EAAE,YAAY,IAAI,CAAC,KAAK,CAAC,eAAe,EAAE,WAAW,CAAC;YAC5F,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;SACnC;QACD,IAAI,CAAC,CAAC,KAAK,CAAC,QAAQ,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,WAAW,EAAE;YACnD,IAAI,CAAC,oBAAoB,CAAC,IAAI,EAAE,CAAC;SAClC;QACD,IAAI,CAAC,aAAa,EAAE,CAAC;IACvB,CAAC;IAED,eAAe;QACb,IAAI,CAAC,qBAAqB,EAAE,CAAC;QAC7B,IAAI,CAAC,WAAW,EAAE,CAAC;QACnB,IAAI,CAAC,iBAAiB,EAAE,CAAC;IAC3B,CAAC;IAED,WAAW;QACT,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;QACzB,IAAI,CAAC,YAAY,CAAC,QAAQ,EAAE,CAAC;IAC/B,CAAC;IAED,UAAU,CAAC,MAAkB;QAC3B,IAAI,CAAC,CAAC,IAAI,CAAC,qBAAqB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE;YAC3D,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,eAAe,CAAC,oBAAoB,CAAC,MAAM,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;YAChF,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC;SAChC;aAAM;YACL,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,QAAQ,IAAI,EAAE,CAAC;YACnC,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,kBAAkB,IAAI,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC;SACtE;QAED,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,OAAO,IAAI,EAAE,CAAC;QACzC,IAAI,CAAC,aAAa,EAAE,CAAC;IACvB,CAAC;IAED,WAAW,CAAC,MAAkB;QAC5B,IAAI,CAAC,CAAC,MAAM,EAAE,UAAU,EAAE;YACxB,IAAI,CAAC,UAAU,GAAG;gBAChB,GAAG,IAAI,CAAC,UAAU;gBAClB,QAAQ,EAAE,MAAM,CAAC,UAAU,CAAC,QAAQ;aACrC,CAAC;SACH;QAED,MAAM,QAAQ,GAAG,GAAG,CAAC,IAAI,CAAC,UAAU,EAAE,UAAU,CAAC,CAAC;QAClD,IACE,IAAI,CAAC,UAAU;YACf,CAAC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,gBAAgB,CAAC,EAAE,CAAC,gBAAgB,KAAK,QAAQ,CAAC,EAC/E;YACA,IAAI,CAAC,UAAU,GAAG,EAAE,GAAG,IAAI,CAAC,UAAU,EAAE,QAAQ,EAAE,IAAI,CAAC,mBAAmB,EAAE,CAAC;SAC9E;IACH,CAAC;IAED,qBAAqB;QACnB,MAAM,QAAQ,GAAG,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,8BAA8B,EAAE;YACxE,KAAK,EAAE,UAAU;YACjB,eAAe,EAAE,YAAY;YAC7B,cAAc,EAAE,aAAa;YAC7B,mBAAmB,EAAE,IAAI;YACzB,YAAY,EAAE;gBACZ,OAAO,EAAE,IAAI,CAAC,OAAO;aACtB;SACF,CAAC,CAAC;QAEH,QAAQ,CAAC,OAAO,CAAC,iBAAiB;aAC/B,IAAI,CACH,GAAG,CAAC,CAAC,kBAAsC,EAAE,EAAE;YAC7C,MAAM,uBAAuB,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAClD,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,aAAa,CAAC,CAClD,CAAC;YACF,IAAI,CAAC,OAAO,CAAC,MAAM,CACjB,uBAAuB,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,uBAAuB,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,EAC5E,CAAC,EACD,IAAI,YAAY,CAAC,kBAAkB,CAAC,CACrC,CAAC;YACF,IAAI,CAAC,aAAa,EAAE,CAAC;YACrB,IAAI,CAAC,YAAY,CAAC;gBAChB,MAAM,EAAE,UAAU,CAAC,iBAAiB;gBACpC,MAAM,EAAE,kBAAkB,CAAC,MAAM,IAAI,kBAAkB,CAAC,IAAI;aAC7D,CAAC,CAAC;QACL,CAAC,CAAC,EACF,SAAS,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAC7B;aACA,SAAS,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;IAC5D,CAAC;IAED,KAAK,CAAC,kBAAkB,CACtB,SAAkC,EAClC,MAAc,EACd,kBAAuC;QAEvC,kBAAkB,CAAC,SAAS,GAAG,KAAK,CAAC;QACrC,SAAS,CAAC,OAAO,GAAG,OAAO,CAAC,oCAAoC,CAAC,CAAC;QAClE,IAAI;YACF,MAAM,MAAM,GAAY,MAAM,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,0BAA0B,CAAC,CAAC;YAC9E,IAAI,MAAM,EAAE;gBACV,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,IAAI,KAAK,MAAM,EAAE,IAAI,CAAC,CAAC;gBACtE,IAAI,CAAC,aAAa,EAAE,CAAC;gBACrB,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;gBACvC,IAAI,CAAC,YAAY,CAAC;oBAChB,MAAM,EAAE,UAAU,CAAC,oBAAoB;oBACvC,MAAM,EAAE,MAAM,CAAC,MAAM,IAAI,MAAM,CAAC,IAAI;iBACrC,CAAC,CAAC;aACJ;SACF;QAAC,OAAO,CAAC,EAAE;YACV,IAAI,CAAC,YAAY,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC;SACvC;QAED,UAAU,CAAC,GAAG,EAAE,CAAC,CAAC,kBAAkB,CAAC,SAAS,GAAG,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC;IAC7D,CAAC;IAED,WAAW,CAAC,KAAK,EAAE,IAAI;QACrB,OAAO,IAAI,CAAC,IAAI,CAAC;IACnB,CAAC;IAED,gBAAgB,CAAC,GAAG,EAAE,IAAI;QACxB,OAAO,IAAI,CAAC;YACV,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,YAAY,CAAC,CAAC,EAAE,IAAI,CAAC;YAC1C,IAAI,CAAC,UAAU,CAAC,eAAe;YAC/B,IAAI,CAAC,UAAU,CAAC,YAAY;SAC7B,CAAC,CAAC,GAAG,CAAC,CAAC;IACV,CAAC;IAED,eAAe,CAAC,UAAU;QACxB,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,KAAK,UAAU,CAAC,CAAC;QAEpE,IAAI,MAAM,EAAE;YACV,MAAM,EAAE,SAAS,EAAE,GAAG,MAAM,CAAC;YAE7B,IAAI,CAAC,SAAS,EAAE;gBACd,IAAI,CAAC,aAAa,CAAC,CAAC,UAAU,CAAC,EAAE,YAAY,CAAC,GAAG,CAAC,CAAC;aACpD;iBAAM,IAAI,SAAS,KAAK,YAAY,CAAC,GAAG,EAAE;gBACzC,IAAI,CAAC,aAAa,CAAC,CAAC,UAAU,CAAC,EAAE,YAAY,CAAC,IAAI,CAAC,CAAC;aACrD;iBAAM;gBACL,IAAI,CAAC,aAAa,CAAC,CAAC,UAAU,CAAC,EAAE,EAAE,CAAC,CAAC;aACtC;SACF;IACH,CAAC;IAED,aAAa,CAAC,WAAqB,EAAE,SAAoB;QACvD,IAAI,CAAC,YAAY,CAAC;YAChB,MAAM,EAAE,UAAU,CAAC,oBAAoB;YACvC,OAAO,EAAE,WAAW;YACpB,SAAS,EAAE,SAAS,KAAK,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS;SACjD,CAAC,CAAC;QAEH,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAU,EAAE;YACjD,IAAI,WAAW,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE;gBACrC,OAAO,EAAE,GAAG,MAAM,EAAE,SAAS,EAAE,CAAC;aACjC;YAED,OAAO,MAAM,CAAC;QAChB,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC;QAC9B,IAAI,CAAC,MAAM,EAAE,CAAC;IAChB,CAAC;IAED,WAAW,CAAC,UAAU,EAAE,QAAQ,EAAE,iBAAiB;QACjD,IAAI,CAAC,YAAY,CAAC;YAChB,MAAM,EAAE,UAAU,CAAC,YAAY;YAC/B,MAAM,EAAE,UAAU;YAClB,iBAAiB;SAClB,CAAC,CAAC;QACH,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,EAAE,UAAU,EAAE,QAAQ,EAAE,iBAAiB,EAAE,CAAC,CAAC;QACtE,IAAI,CAAC,eAAe,CAAC,CAAC,UAAU,CAAC,EAAE;YACjC,IAAI,EAAE,mBAAmB,CAAC,WAAW;YACrC,OAAO,EAAE,EAAE,iBAAiB,EAAE;SAC/B,CAAC,CAAC;QACH,QAAQ,CAAC,IAAI,EAAE,CAAC;QAChB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,UAAU,EAAE,QAAQ,EAAE,iBAAiB,EAAE,CAAC,CAAC;IAClE,CAAC;IAED,WAAW,CAAC,UAAU,EAAE,QAAQ;QAC9B,IAAI,CAAC,YAAY,CAAC,EAAE,MAAM,EAAE,UAAU,CAAC,YAAY,EAAE,MAAM,EAAE,UAAU,EAAE,CAAC,CAAC;QAC3E,IAAI,CAAC,eAAe,CAAC,CAAC,UAAU,CAAC,EAAE,EAAE,IAAI,EAAE,mBAAmB,CAAC,WAAW,EAAE,CAAC,CAAC;QAC9E,QAAQ,CAAC,IAAI,EAAE,CAAC;QAChB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,UAAU,EAAE,QAAQ,EAAE,CAAC,CAAC;IAC/C,CAAC;IAED,YAAY,CAAC,MAAM,GAAG,IAAI;QACxB,IAAI,CAAC,eAAe,CAClB,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC,EACpC;YACE,IAAI,EAAE,mBAAmB,CAAC,WAAW;SACtC,EACD,MAAM,CACP,CAAC;QACF,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACvB,IAAI,CAAC,YAAY,CAAC,EAAE,MAAM,EAAE,UAAU,CAAC,YAAY,EAAE,CAAC,CAAC;IACzD,CAAC;IAED,eAAe,CACb,WAAqB,EACrB,MAGC,EACD,MAAM,GAAG,IAAI;QAEb,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE;YACvC,IAAI,WAAW,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE;gBACrC,OAAO;oBACL,GAAG,MAAM;oBACT,GAAG,CAAC,MAAM,CAAC,IAAI,KAAK,mBAAmB,CAAC,WAAW;wBACjD,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,iBAAiB;wBAClC,CAAC,CAAC,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,CAAC;iBACtC,CAAC;aACH;YACD,OAAO,MAAM,CAAC;QAChB,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,sBAAsB,EAAE,CAAC;QAC9B,IAAI,MAAM,EAAE;YACV,IAAI,CAAC,MAAM,EAAE,CAAC;SACf;IACH,CAAC;IAED,sBAAsB;QACpB,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,wBAAwB,CAAC,CAAC;IAC3E,CAAC;IAED,wBAAwB,CAAC,MAAc;QACrC,MAAM,EAAE,UAAU,EAAE,eAAe,EAAE,mBAAmB,EAAE,GAAG,MAAM,CAAC;QAEpE,OAAO,CAAC,CAAC,CAAC,UAAU,IAAI,CAAC,eAAe,IAAI,mBAAmB,CAAC,CAAC,CAAC;IACpE,CAAC;IAED,gBAAgB,CAAC,EAAE,YAAY,EAAE,IAAI,EAAE;QACrC,MAAM,aAAa,GAAG,IAAI,CAAC,UAAU,EAAE,QAAQ,KAAK,YAAY,CAAC;QACjE,IAAI,CAAC,UAAU,GAAG,EAAE,GAAG,IAAI,CAAC,UAAU,EAAE,QAAQ,EAAE,YAAY,EAAE,WAAW,EAAE,IAAI,EAAE,CAAC;QACpF,IAAI,CAAC,QAAQ,EAAE,CAAC;QAChB,IAAI,aAAa,EAAE;YACjB,IAAI,CAAC,gBAAgB,CAAC,YAAY,CAAC,CAAC;SACrC;QACD,IAAI,CAAC,YAAY,CAAC,EAAE,MAAM,EAAE,UAAU,CAAC,iBAAiB,EAAE,YAAY,EAAE,IAAI,EAAE,CAAC,CAAC;IAClF,CAAC;IAED,WAAW;QACT,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;QACrB,IAAI,CAAC,MAAM,EAAE,CAAC;QACd,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QACrB,IAAI,CAAC,YAAY,CAAC,EAAE,MAAM,EAAE,UAAU,CAAC,MAAM,EAAE,CAAC,CAAC;IACnD,CAAC;IAED,MAAM;QACJ,IAAI,CAAC,UAAU,GAAG,EAAE,GAAG,IAAI,CAAC,UAAU,EAAE,WAAW,EAAE,CAAC,EAAE,CAAC;QACzD,IAAI,CAAC,yBAAyB,GAAG,IAAI,CAAC;QACtC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QACpB,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;IAED,YAAY;QACV,IAAI,CAAC,UAAU,GAAG,EAAE,GAAG,IAAI,CAAC,UAAU,EAAE,WAAW,EAAE,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE,CAAC;QAEhF,IAAI,CAAC,QAAQ,EAAE,CAAC;QAEhB,OAAO,IAAI,CAAC,UAAU,CAAC,WAAW;aAC/B,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,qEAAqE;aACnF,SAAS,EAAE;aACX,IAAI,CAAC,MAAM,CAAC,EAAE;YACb,OAAO;gBACL,GAAG,MAAM;gBACT,MAAM,EAAE;oBACN,GAAG,MAAM,CAAC,MAAM;oBAChB,IAAI,EAAE,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC;iBACnC;aACqB,CAAC;QAC3B,CAAC,CAAC,CAAC;IACP,CAAC;IAED,mBAAmB,CAAC,EAAE,KAAK,EAAE,GAAG,EAAE,UAAU,EAAE;QAC5C,OAAO,IAAI,CAAC,oBAAoB,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,EAAE,UAAU,EAAE,CAAC,CAAC;IAC7E,CAAC;IAED,yBAAyB,CAAC,EAAE,KAAK,EAAE,UAAU,EAAE;QAC7C,OAAO,IAAI,CAAC,oBAAoB,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,GAAG,EAAE,SAAS,EAAE,UAAU,EAAE,CAAC,CAAC;IAC1F,CAAC;IAED,4BAA4B,CAAC,EAAE,MAAM,EAAE,QAAQ,EAAE;QAC/C,OAAO;YACL,QAAQ,EACN,GAAG,CAAC,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,EAAE,mCAAmC,CAAC;gBACxE,MAAM,CAAC,8BAA8B;YACvC,OAAO,EAAE;gBACP,QAAQ,EAAE,MAAM;gBAChB,WAAW,EAAE,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,EAAE,MAAM,CAAC,IAAI,EAAE,QAAQ,CAAC;gBAC/D,WAAW,EAAE,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,EAAE,MAAM,CAAC,IAAI,EAAE,QAAQ,CAAC;aAChE;SACF,CAAC;IACJ,CAAC;IAED,mBAAmB,CAAC,QAAQ;QAC1B,IAAI,CAAC,UAAU,CAAC,UAAU;aACvB,IAAI,CAAC,KAAK,EAAE,CAAC;aACb,SAAS,CAAC,CAAC,EAAE,eAAe,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC,gBAAgB,CAAC,eAAe,EAAE,QAAQ,CAAC,CAAC,CAAC;IAC1F,CAAC;IAED,gCAAgC,CAAC,QAAQ;QACvC,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,gBAAgB,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC,CAAC;IAC/F,CAAC;IAED,gBAAgB,CAAC,KAAY,EAAE,QAAQ;QACrC,MAAM,OAAO,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC,IAAqB,EAAE,EAAE,CAClD,OAAO,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC,CAAC,CAAC,IAAI,CACjE,CAAC;QAEF,IAAI,CAAC,eAAe,GAAG,QAAQ;YAC7B,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,eAAe,EAAE,OAAO,CAAC;YACtC,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,eAAe,EAAE,GAAG,OAAO,CAAC,CAAC;QAC9C,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;IAC9C,CAAC;IAED,MAAM;QACJ,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC;QAC1B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;IAC9C,CAAC;IAED,cAAc,CAAC,IAAI;QACjB,OAAO,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC,CAAC;IACvE,CAAC;IAED,YAAY,CAAC,EAAE,aAAa,EAAE,YAAY,EAAE;QAC1C,MAAM,cAAc,GAAG,aAAa,KAAK,YAAY,CAAC;QAEtD,IAAI,cAAc,EAAE;YAClB,IAAI,CAAC,YAAY,CAAC;gBAChB,MAAM,EAAE,UAAU,CAAC,eAAe;gBAClC,MAAM,EAAE,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC;aACxC,CAAC,CAAC;YACH,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC;YACrD,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,YAAY,EAAE,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;YAChD,IAAI,CAAC,gBAAgB,CAAC,eAAe,CAAC,CAAC;SACxC;QAED,IAAI,CAAC,iBAAiB,EAAE,CAAC;QACzB,IAAI,CAAC,qBAAqB,EAAE,CAAC;IAC/B,CAAC;IAED,qBAAqB;QACnB,IAAI,CAAC,MAAM,GAAG;YACZ,GAAG,IAAI,CAAC,MAAM;YACd,mBAAmB,EAAE,IAAI,CAAC,SAAS,CAAC,wBAAwB,CAC1D,IAAI,CAAC,OAAO;iBACT,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC;iBAChC,GAAG,CAAC,CAAC,EAAE,aAAa,EAAE,EAAE,EAAE,CAAC,aAAa,CAAC;iBACzC,IAAI,CAAC,GAAG,CAAC,CACb;YACD,wBAAwB,EAAE,IAAI,CAAC,SAAS,CAAC,wBAAwB,CAC/D,YAAY,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,CACnE;SACF,CAAC;IACJ,CAAC;IAED,WAAW;QACT,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM;gBACtB,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC,GAAG,CAAC,CAAC,EAAE,aAAa,EAAE,EAAE,EAAE,CAAC,aAAa,CAAC;gBACjE,CAAC,CAAC,EAAE,CAAC;QACT,CAAC,EAAE,CAAC,CAAC,CAAC;IACR,CAAC;IAED,6DAA6D;IAC7D,qBAAqB,CAAC,MAAc;QAClC,OAAO,CACL,OAAO,CACL,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,EACnC,MAAM,CACP;YACD,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,MAAM,GAAG,CAAC,CAC/C,CAAC;IACJ,CAAC;IAED,gBAAgB,CAAC,SAAyB;QACxC,IAAI,IAAI,CAAC,kBAAkB,EAAE;YAC3B,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;YACpE,MAAM,MAAM,GAAG,EAAE,OAAO,EAAE,UAAU,EAAE,IAAI,CAAC,UAAU,EAAE,CAAC;YACxD,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YACjC,QAAQ,SAAS,EAAE;gBACjB,KAAK,MAAM;oBACT,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;oBACzB,MAAM;gBACR,KAAK,YAAY;oBACf,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;oBACnC,MAAM;gBACR,KAAK,eAAe;oBAClB,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;oBACpC,MAAM;gBACR,KAAK,wBAAwB;oBAC3B,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;aAC9C;SACF;IACH,CAAC;IAED,YAAY,CAAC,SAAS;QACpB,IAAI,CAAC,gBAAgB,CAAC,YAAY,CAAC,IAAI,CAAC,sBAAsB,EAAE,SAAS,IAAI,aAAa,EAAE;YAC1F,GAAG,IAAI,CAAC,sBAAsB,EAAE,IAAI;YACpC,GAAG,SAAS;SACb,CAAC,CAAC;IACL,CAAC;IAEO,mBAAmB,CAAC,MAAc;QACxC,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACtC,OAAO;YACL,eAAe,EAAE,SAAS;YAC1B,mBAAmB,EAAE,SAAS;SAC/B,CAAC;IACJ,CAAC;IAEO,iBAAiB,CAAC,MAAc;QACtC,IAAI,MAAM,CAAC;QACX,IAAI,MAAM,CAAC,MAAM,EAAE;YACjB,MAAM,EAAE,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,mBAAmB,EAAE,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,CAAC;YAC/E,MAAM,GAAG;gBACP,OAAO;gBACP,SAAS;gBACT,IAAI;gBACJ,MAAM,EAAE,EAAE,mBAAmB,EAAE;gBAC/B,MAAM;gBACN,IAAI;gBACJ,MAAM,EAAE,IAAI;aACb,CAAC;SACH;aAAM;YACL,MAAM,EAAE,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,mBAAmB,EAAE,GAAG,MAAM,CAAC;YACjE,MAAM,GAAG,EAAE,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,MAAM,EAAE,EAAE,mBAAmB,EAAE,EAAE,CAAC;SACxE;QAED,IAAI,OAAO,CAAC,MAAM,EAAE,MAAM,EAAE,mBAAmB,CAAC,EAAE;YAChD,OAAO,MAAM,CAAC,MAAM,CAAC;SACtB;QAED,OAAO,MAAM,CAAC;IAChB,CAAC;IAEO,QAAQ,CAAC,MAAM,GAAG,KAAK;QAC7B,MAAM,EACJ,IAAI,EACJ,OAAO,EACP,UAAU,EACV,UAAU,EACV,sBAAsB,EACtB,UAAU,EACV,mBAAmB,EACnB,cAAc,EACf,GAAG,IAAI,CAAC;QAET,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC;YACvB,IAAI;YACJ,OAAO;YACP,UAAU;YACV,UAAU;YACV,sBAAsB;YACtB,UAAU;YACV,mBAAmB;YACnB,cAAc;YACd,MAAM;SACP,CAAC,CAAC;IACL,CAAC;IAEO,aAAa;QACnB,MAAM,aAAa,GAAG;YACpB,QAAQ,EAAE,KAAK;YACf,aAAa,EAAE,IAAI;SACpB,CAAC;QACF,MAAM,cAAc,GAAG,IAAI,CAAC,UAAU;YACpC,CAAC,CAAC;gBACE,GAAG,aAAa;gBAChB,IAAI,6CAA4B;gBAChC,aAAa,EAAE,MAAM;aACtB;YACH,CAAC,CAAC,SAAS,CAAC;QACd,MAAM,aAAa,GACjB,IAAI,CAAC,cAAc,EAAE,MAAM,GAAG,CAAC;YAC7B,CAAC,CAAC;gBACE,GAAG,aAAa;gBAChB,IAAI,2CAA2B;gBAC/B,aAAa,EAAE,IAAI,CAAC,cAAc,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,oBAAoB;aAC9E;YACH,CAAC,CAAC,SAAS,CAAC;QAEhB,MAAM,OAAO,GAAG,CAAC,cAAc,EAAE,GAAG,IAAI,CAAC,OAAO,EAAE,aAAa,CAAC;aAC7D,MAAM,CAAC,OAAO,CAAC;aACf,GAAG,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;QAEhC,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;QACvC,IAAI,CAAC,iBAAiB,EAAE,CAAC;QACzB,IAAI,CAAC,qBAAqB,EAAE,CAAC;QAC7B,IAAI,CAAC,WAAW,EAAE,CAAC;QACnB,IAAI,CAAC,sBAAsB,EAAE,CAAC;IAChC,CAAC;IAEO,kBAAkB,CAAC,MAAM;QAC/B,MAAM,QAAQ,GAAG,MAAM,CAAC,QAAQ,+CAA4B,CAAC;QAC7D,MAAM,EAAE,kBAAkB,EAAE,gBAAgB,EAAE,GAAG,MAAM,CAAC;QAExD,OAAO;YACL,OAAO,EAAE,IAAI;YACb,aAAa,EAAE,KAAK;YACpB,SAAS,EAAE,IAAI;YACf,QAAQ,EAAE,IAAI;YACd,SAAS,EAAE,EAAE;YACb,UAAU,EAAE,KAAK;YACjB,GAAG,MAAM;YACT,QAAQ;YACR,aAAa,EACX,MAAM,CAAC,aAAa;gBACpB,UAAU,sBAAsB,OAAO,mBAAmB,CAAC,QAAQ,CAAC,KAAK;YAC3E,kBAAkB,EAChB,CAAC,OAAO,kBAAkB,KAAK,QAAQ;gBACrC,CAAC,CAAC,kBAAkB,CAAC,KAAK,CAAC,GAAG,CAAC;gBAC/B,CAAC,CAAC,kBAAkB,CAAC,IAAI,EAAE;YAC/B,gBAAgB,EACd,CAAC,OAAO,gBAAgB,KAAK,QAAQ,CAAC,CAAC,CAAC,gBAAgB,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,gBAAgB,CAAC;gBACvF,EAAE;SACL,CAAC;IACJ,CAAC;IAEO,iBAAiB;QACvB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC;IAC1D,CAAC;IAEO,iBAAiB;QACvB,MAAM,iBAAiB,GAAG,IAAI,CAAC,sBAAsB,CAAC,IAAI,CACxD,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,EAC5B,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,oBAAoB,EAAE,CAAC,EACtC,QAAQ,CAAC,CAAC,EAAE,KAAK,EAAE,gBAAgB,EAAE,EAAE,EAAE;YACvC,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE;gBACvC,IAAI,MAAM,CAAC,IAAI,KAAK,gBAAgB,EAAE;oBACpC,OAAO;wBACL,GAAG,MAAM;wBACT,kBAAkB,EAAE,KAAK,CAAC,MAAM,CAAC,kBAAkB,EAAE,CAAC,uBAAuB,CAAC,CAAC;qBAChF,CAAC;iBACH;gBAED,OAAO,MAAM,CAAC;YAChB,CAAC,CAAC,CAAC;YAEH,IAAI,CAAC,kBAAkB,GAAG;gBACxB,UAAU,EAAE,gBAAgB;gBAC5B,EAAE,EAAE,KAAK,CAAC,MAAM,EAAE,UAAU;aAC7B,CAAC;YAEF,IAAI,CAAC,MAAM,GAAG;gBACZ,GAAG,IAAI,CAAC,MAAM;gBACd,WAAW,EAAE,YAAY;aAC1B,CAAC;YAEF,OAAO,IAAI,CAAC,+BAA+B,CAAC,IAAI,CAC9C,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,oBAAoB,EAAE,CAAC,EACtC,SAAS,CAAC,IAAI,CAAC,6BAA6B,CAAC,CAC9C,CAAC;QACJ,CAAC,CAAC,CACH,CAAC;QAEF,iBAAiB,CAAC,SAAS,CAAC,CAAC,KAAiB,EAAE,EAAE;YAChD,qBAAqB,CAAC,GAAG,EAAE;gBACzB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;oBAC5C,IAAI,IAAI,CAAC,kBAAkB,IAAI,MAAM,CAAC,IAAI,KAAK,IAAI,CAAC,kBAAkB,CAAC,UAAU,EAAE;wBACjF,MAAM,kBAAkB,GAAmB,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC;wBAE9E,iEAAiE;wBACjE,MAAM,gBAAgB,GAAG,kBAAkB,CAAC,qBAAqB,EAAE,CAAC,IAAI,CAAC;wBAEzE,gEAAgE;wBAChE,MAAM,sBAAsB,GAAG,kBAAkB,CAAC,UAAU,GAAG,gBAAgB,CAAC;wBAEhF,0CAA0C;wBAC1C,MAAM,gBAAgB,GAAG,IAAI,CAAC,kBAAkB,CAAC,EAAE,CAAC,UAAU,IAAI,CAAC,CAAC;wBAEpE,+BAA+B;wBAC/B,MAAM,KAAK,GAAG,sBAAsB,GAAG,KAAK,CAAC,OAAO,GAAG,gBAAgB,CAAC;wBAExE,OAAO;4BACL,GAAG,MAAM;4BACT,8EAA8E;4BAC9E,aAAa,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,sBAAsB,EAAE,KAAK,CAAC,IAAI;yBAC9D,CAAC;qBACH;oBAED,sFAAsF;oBACtF,IAAI,MAAM,CAAC,aAAa,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE;wBAC7C,OAAO;4BACL,GAAG,MAAM;4BACT,2CAA2C;4BAC3C,aAAa,EAAE,GAAG,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,IAAI;yBAC3D,CAAC;qBACH;oBAED,OAAO,MAAM,CAAC;gBAChB,CAAC,CAAC,CAAC;gBAEH;;;mBAGG;gBACH,IAAI,CAAC,qBAAqB,EAAE,CAAC;YAC/B,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,6BAA6B,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;YACnF,IAAI,IAAI,CAAC,kBAAkB,EAAE;gBAC3B,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE;oBACvC,IAAI,MAAM,CAAC,IAAI,KAAK,IAAI,CAAC,kBAAkB,CAAC,UAAU,EAAE;wBACtD,OAAO;4BACL,GAAG,MAAM;4BACT,kBAAkB,EAAE,OAAO,CAAC,MAAM,CAAC,kBAAkB,EAAE,uBAAuB,CAAC;yBAChF,CAAC;qBACH;oBAED,OAAO,MAAM,CAAC;gBAChB,CAAC,CAAC,CAAC;gBACH,IAAI,CAAC,kBAAkB,GAAG,SAAS,CAAC;gBAEpC,IAAI,CAAC,MAAM,GAAG;oBACZ,GAAG,IAAI,CAAC,MAAM;oBACd,WAAW,EAAE,MAAM;iBACpB,CAAC;aACH;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,oBAAoB;QAC1B,IAAI,MAAM,CAAC,YAAY,EAAE;YACvB,MAAM,CAAC,YAAY,EAAE,CAAC,eAAe,EAAE,CAAC;SACzC;IACH,CAAC;IAEO,oBAAoB,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,EAAE,UAAU,EAAE;QAC3D,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,KAAK,UAAU,CAAC,CAAC;QACpE,MAAM,cAAc,GAAG,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC;QACtD,MAAM,gBAAgB,GAAG,GAAG,CAC1B,cAAc,EACd,GAAG,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,uBAAuB,CAAC,CAAC,CAAC,iBAAiB,WAAW,CAC9E,CAAC;QAEF,MAAM,EAAE,qBAAqB,EAAE,2BAA2B,EAAE,GAAG,MAAM,CAAC;QACtE,MAAM,iBAAiB,GACrB,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,2BAA2B,CAAC,CAAC,CAAC,qBAAqB,CAAC;QAE1E,OAAO;YACL,QAAQ,EAAE,gBAAgB,IAAI,iBAAiB;YAC/C,OAAO,EAAE;gBACP,KAAK;gBACL,IAAI,EAAE,GAAG;gBACT,QAAQ,EAAE,MAAM;aACjB;SACF,CAAC;IACJ,CAAC;IAEO,iBAAiB,CAAC,MAAM;QAC9B,OAAO,IAAI,CAAC,eAAe,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,KAAK,MAAM,CAAC,IAAI,CAAC,CAAC;IACjF,CAAC;IAEO,2BAA2B,CAAC,KAAsB;QACxD,IAAI,CAAC,qBAAqB,GAAG;YAC3B,kBAAkB,EAAE,KAAK,CAAC,YAAY;YACtC,aAAa,EAAE,KAAK,CAAC,IAAI;SAC1B,CAAC;IACJ,CAAC;IAEO,2BAA2B,CAAC,KAAsB;QACxD,IAAI,KAAK,CAAC,QAAQ,EAAE;YAClB,IAAI,CAAC,UAAU,GAAG,EAAE,GAAG,IAAI,CAAC,UAAU,EAAE,QAAQ,EAAE,KAAK,CAAC,QAAQ,EAAE,CAAC;SACpE;QAED,MAAM,gBAAgB,GAAG,CAAC,KAAK,CAAC,WAAW,GAAG,CAAC,CAAC,GAAG,KAAK,CAAC,aAAa,GAAG,CAAC,CAAC;QAC3E,IAAI,CAAC,qBAAqB,GAAG;YAC3B,gBAAgB;YAChB,eAAe,EAAE,gBAAgB,GAAG,CAAC,KAAK,CAAC,eAAe,GAAG,CAAC,CAAC;YAC/D,UAAU,EAAE,KAAK,CAAC,YAAY;SAC/B,CAAC;IACJ,CAAC;IAEO,uBAAuB,CAAC,KAAsB;QACpD,IACE,IAAI,CAAC,cAAc;YACnB,KAAK;YACL,KAAK,CAAC,QAAQ;YACd,CAAC,CAAC,IAAI,CAAC,iBAAiB,IAAI,IAAI,CAAC,yBAAyB,CAAC,EAC3D;YACA,IAAI,CAAC,yBAAyB,GAAG,KAAK,CAAC;YACvC,IAAI,CAAC,uBAAuB,CAAC,KAAK,EAAE,CAAC;YACrC,MAAM,gBAAgB,GACpB,IAAI,CAAC,GAAG,CAAC,uBAAuB,CAAC,iBAAiB,CAAC,CAAC;YACtD,MAAM,YAAY,GAAG,IAAI,CAAC,uBAAuB,CAAC,eAAe,CAAC,gBAAgB,CAAC,CAAC;YACpF,MAAM,QAAQ,GAAG,YAAY,CAAC,QAA6B,CAAC;YAC5D,QAAQ,CAAC,eAAe,GAAG,IAAI,CAAC,cAAc,KAAK,MAAM,IAAI,IAAI,CAAC,cAAc,KAAK,QAAQ,CAAC;YAC9F,QAAQ,CAAC,MAAM,GAAG,IAAI,CAAC,cAAc,KAAK,QAAQ,CAAC;YACnD,QAAQ,CAAC,MAAM,GAAG;gBAChB,QAAQ,EAAE,KAAK,CAAC,QAAQ;gBACxB,IAAI,EAAE,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC;aACpB,CAAC;YACjB,QAAQ,CAAC,aAAa,GAAG,IAAI,CAAC,kBAAkB,CAAC;YACjD,QAAQ,CAAC,YAAY,GAAG,IAAI,CAAC,iBAAiB,CAAC;YAC/C,IAAI,CAAC,iBAAiB,GAAG,QAAQ,CAAC;SACnC;aAAM,IAAI,IAAI,CAAC,iBAAiB,IAAI,CAAC,KAAK,CAAC,QAAQ,EAAE;YACpD,IAAI,CAAC,iBAAiB,CAAC,MAAM,GAAG;gBAC9B,QAAQ,EAAE,IAAI;aACA,CAAC;SAClB;IACH,CAAC;IAEO,WAAW;QACjB,IAAI,IAAI,CAAC,cAAc,EAAE;YACvB,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,SAAS,GAAG,CAAC,CAAC;SAClD;IACH,CAAC;IAEO,6BAA6B;QACnC,KAAK,CACH,KAAK,CACH,IAAI,CAAC,MAAM,EACX,IAAI,CAAC,gBAAgB,EACrB,IAAI,CAAC,iBAAiB,EACtB,IAAI,CAAC,wBAAwB,CAC9B,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,EACrC,KAAK,CAAC,IAAI,CAAC,iBAAiB,EAAE,IAAI,CAAC,oBAAoB,CAAC,CAAC,IAAI,CAC3D,GAAG,CAAC,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,OAAO,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CACvE,EACD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAChB,GAAG,CAAC,CAAC,EAAE,UAAU,EAAE,iBAAiB,EAAE,EAAE,EAAE,CACxC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,MAAoB,EAAE,EAAE;YAC/E,IAAI,KAAK,CAAC,UAAU,CAAC,EAAE;gBACrB,OAAO,MAAM,CAAC,MAAM,CAAC;aACtB;iBAAM,IAAI,MAAM,CAAC,IAAI,KAAK,UAAU,EAAE;gBACrC,IAAI,OAAO,CAAC,iBAAiB,CAAC,EAAE;oBAC9B,OAAO,MAAM,CAAC,MAAM,CAAC;iBACtB;qBAAM;oBACL,MAAM,CAAC,MAAM,GAAG,iBAAiB,CAAC;iBACnC;aACF;YAED,OAAO,MAAM,CAAC;QAChB,CAAC,CAAC,CACH,CACF,CACF;aACE,IAAI,CACH,GAAG,CAAC,CAAC,OAAiD,EAAE,EAAE,CAAC,CAAC;YAC1D,OAAO;YACP,UAAU,EAAE,EAAE,QAAQ,EAAE,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE;SACnD,CAAC,CAAC,EACH,MAAM,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,qBAAqB,CAAC,EAC1C,IAAI,CAAC,oBAAoB,EAAE,EAC3B,IAAI,CAAC,kBAAkB,EAAE,EACzB,IAAI,CAAC,0BAA0B,EAAE,EACjC,IAAI,CAAC,qBAAqB,EAAE,EAC5B,IAAI,CAAC,0BAA0B,EAAE,EACjC,SAAS,CAAC,CAAC,MAAkB,EAAE,EAAE,CAAC,IAAI,CAAC,qBAAqB,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,EACjF,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,CAC7B;aACA,SAAS,EAAE,CAAC;IACjB,CAAC;IAEO,oBAAoB;QAC1B,OAAO,IAAI,CACT,IAAI,CAAC,cAAc,CAAC,QAAQ,EAAE,MAAM,CAAC,EAAE;YACrC,MAAM,CAAC,OAAO,GAAG,CAAC,MAAM,CAAC,OAAO,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE;gBAChD,OAAO,GAAG,CAAC,MAAM,CAAC;gBAClB,OAAO,GAAG,CAAC;YACb,CAAC,CAAC,CAAC;YAEH,OAAO,MAAM,CAAC;QAChB,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAEO,kBAAkB;QACxB,OAAO,IAAI,CACT,IAAI,CAAC,cAAc,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE;YACnC,MAAM,CAAC,OAAO,GAAG,CAAC,MAAM,CAAC,OAAO,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE;gBAChD,GAAG,CAAC,SAAS,GAAG,EAAE,CAAC;gBACnB,OAAO,GAAG,CAAC;YACb,CAAC,CAAC,CAAC;YAEH,OAAO,MAAM,CAAC;QAChB,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAEO,0BAA0B;QAIhC,OAAO,IAAI,CACT,IAAI,CAAC,cAAc,CAAC,eAAe,EAAE,MAAM,CAAC,EAAE;YAC5C,MAAM,CAAC,OAAO,GAAG,CAAC,MAAM,CAAC,OAAO,IAAI,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,GAAuB,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;YAEzF,OAAO,MAAM,CAAC;QAChB,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAEO,qBAAqB;QAC3B,OAAO,IAAI,CACT,IAAI,CAAC,cAAc,CAAC,OAAO,EAAE,MAAM,CAAC,EAAE;YACpC,OAAO,IAAI,CAAC,qBAAqB,CAAC,UAAU,EAAE,CAAC,IAAI,CACjD,GAAG,CAAC,SAAS,CAAC,EAAE;gBACd,MAAM,UAAU,GACd,SAAS,EAAE,OAAO,IAAK,IAAI,CAAC,cAAiC,CAAC;gBAChE,0CAA0C;gBAC1C,MAAM,YAAY,GAAG,CAAC,MAAM,CAAC,OAAO,IAAI,EAAE,CAAC,CAAC,MAAM,CAChD,GAAG,CAAC,EAAE,CAAC,CAAC,UAAU,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,IAAI,KAAK,GAAG,CAAC,IAAI,CAAC,CACtD,CAAC;gBAEF,MAAM,CAAC,OAAO,GAAG;oBACf,GAAG,UAAU,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CACzB,CAAC,MAAM,CAAC,OAAO,IAAI,EAAE,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,IAAI,KAAK,MAAM,CAAC,IAAI,CAAC,CACnE;oBACD,GAAG,YAAY;iBAChB,CAAC;gBAEF,OAAO,MAAM,CAAC;YAChB,CAAC,CAAC,CACH,CAAC;QACJ,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAEO,0BAA0B;QAIhC,OAAO,IAAI,CACT,IAAI,CAAC,cAAc,CAAC,YAAY,EAAE,MAAM,CAAC,EAAE;YACzC,OAAO,IAAI,CAAC,qBAAqB,CAAC,UAAU,EAAE,CAAC,IAAI,CACjD,GAAG,CAAC,SAAS,CAAC,EAAE;gBACd,MAAM,CAAC,OAAO,GAAG,CAAC,MAAM,CAAC,OAAO,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE;oBACnD,MAAM,OAAO,GACX,SAAS,EAAE,OAAO,IAAK,IAAI,CAAC,cAAiC,CAAC;oBAChE,MAAM,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC,GAAQ,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,KAAK,GAAG,CAAC,IAAI,CAAC,CAAC;oBACpE,MAAM,CAAC,OAAO,GAAG,MAAM,EAAE,OAAO,IAAI,IAAI,CAAC;oBACzC,OAAO,MAAM,CAAC;gBAChB,CAAC,CAAC,CAAC;gBAEH,OAAO,MAAM,CAAC;YAChB,CAAC,CAAC,CACH,CAAC;QACJ,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAEO,cAAc,CACpB,UAA0B,EAC1B,eAA4E;QAE5E,OAAO,IAAI,CACT,SAAS,CAAC,CAAC,MAAkB,EAAE,EAAE;YAC/B,OAAO,IAAI,CAAC,mBAAmB;iBAC5B,IAAI,CAAC,IAAI,EAAE,UAAU,CAAC;iBACtB,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC,EAAE,CAAC,CAAC,EAAE,MAAM,EAAE,aAAa,EAAE,CAAC,CAAC,CAAC,CAAC;QAC7D,CAAC,CAAC,EACF,GAAG,CAAC,CAAC,EAAE,MAAM,EAAE,aAAa,EAAE,EAAE,EAAE,CAChC,aAAa,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,EAAE,MAAM,CAAC,CAC5D,EACD,SAAS,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,MAAM,CAAC,CAA2B,CAAC,CAC5F,CAAC;IACJ,CAAC;IAEO,mBAAmB,CAAC,UAA0B;QACpD,IAAI,MAAwD,CAAC;QAC7D,MAAM,SAAS,GAAG,IAAI,CAAC,qBAAqB,CAAC,UAAU,EAAE,EAAE,YAAY,EAAE,CAAC,UAAU,CAAC,CAAC;QACtF,IAAI,OAAO,SAAS,KAAK,UAAU,EAAE;YACnC,MAAM,GAAG,SAAS,EAAE,CAAC;SACtB;aAAM;YACL,MAAM,GAAG,SAAS,CAAC;SACpB;QACD,OAAO,YAAY,CAAC,MAAM,IAAI,IAAI,CAAC,CAAC;IACtC,CAAC;;8GA3qCU,iBAAiB,kBAwPlB,gCAAgC;kGAxP/B,iBAAiB,6+CAPjB;QACT;YACE,OAAO,EAAE,+BAA+B;YACxC,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,iBAAiB,CAAC;SACjD;KACF,0DAiKgB,eAAe,sPAI6B,gBAAgB,yCA6D/D,aAAa,2BAAU,UAAU,kDC7VjD,sx+BAwxBA;2FD3pBa,iBAAiB;kBAX7B,SAAS;+BACE,eAAe,QAEnB,EAAE,KAAK,EAAE,YAAY,EAAE,aAClB;wBACT;4BACE,OAAO,EAAE,+BAA+B;4BACxC,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,kBAAkB,CAAC;yBACjD;qBACF;;0BAyPE,QAAQ;;0BACR,MAAM;2BAAC,gCAAgC;mOApPjC,KAAK;sBAAb,KAAK;gBAEG,kBAAkB;sBAA1B,KAAK;gBAEG,iBAAiB;sBAAzB,KAAK;gBAEG,UAAU;sBAAlB,KAAK;gBAEG,OAAO;sBAAf,KAAK;gBAKE,QAAQ;sBADf,KAAK;uBAAC,SAAS;gBAOZ,KAAK;sBADR,KAAK;uBAAC,MAAM;gBAoBT,WAAW;sBADd,KAAK;uBAAC,YAAY;gBAQf,eAAe;sBADlB,KAAK;uBAAC,gBAAgB;gBAWnB,uBAAuB;sBAD1B,KAAK;uBAAC,wBAAwB;gBAQ3B,WAAW;sBADd,KAAK;uBAAC,YAAY;gBAQf,oBAAoB;sBADvB,KAAK;uBAAC,qBAAqB;gBAaxB,eAAe;sBADlB,KAAK;uBAAC,gBAAgB;gBAQnB,eAAe;sBADlB,KAAK;uBAAC,gBAAgB;gBAQnB,mBAAmB;sBADtB,KAAK;uBAAC,oBAAoB;gBAQvB,qBAAqB;sBADxB,KAAK;uBAAC,sBAAsB;gBAO7B,UAAU;sBADT,KAAK;gBAKN,uBAAuB;sBADtB,KAAK;gBAKN,kBAAkB;sBADjB,KAAK;gBAII,YAAY;sBAArB,MAAM;gBAEG,aAAa;sBAAtB,MAAM;gBAEG,QAAQ;sBAAjB,MAAM;gBAEG,cAAc;sBAAvB,MAAM;gBAEG,cAAc;sBAAvB,MAAM;gBAEG,cAAc;sBAAvB,MAAM;gBAEG,QAAQ;sBAAjB,MAAM;gBAMG,WAAW;sBAApB,MAAM;gBAEG,QAAQ;sBAAjB,MAAM;gBAEG,iBAAiB;sBAA1B,MAAM;gBAEG,oBAAoB;sBAA7B,MAAM;gBAEG,mBAAmB;sBAA5B,MAAM;gBAEG,MAAM;sBAAf,MAAM;gBAEG,gBAAgB;sBAAzB,MAAM;gBAEG,iBAAiB;sBAA1B,MAAM;gBAEG,wBAAwB;sBAAjC,MAAM;gBAE2B,eAAe;sBAAhD,eAAe;uBAAC,eAAe;gBAEO,eAAe;sBAArD,SAAS;uBAAC,QAAQ,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBAGrC,uBAAuB;sBADtB,SAAS;uBAAC,yBAAyB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,gBAAgB,EAAE;gBA6DpB,MAAM;sBAAhE,YAAY;uBAAC,aAAa,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE","sourcesContent":["import { CdkHeaderCell } from '@angular/cdk/table';\nimport {\n  AfterViewInit,\n  Component,\n  ComponentFactory,\n  ComponentFactoryResolver,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  Inject,\n  Input,\n  OnChanges,\n  Optional,\n  Output,\n  QueryList,\n  ViewChild,\n  ViewChildren,\n  ViewContainerRef\n} from '@angular/core';\nimport { DomSanitizer } from '@angular/platform-browser';\nimport { IResultList, Paging } from '@c8y/client';\nimport {\n  flow,\n  get,\n  indexOf,\n  isEmpty,\n  isNil,\n  parseInt as _parseInt,\n  union,\n  uniqBy,\n  without\n} from 'lodash-es';\nimport { BsDropdownDirective } from 'ngx-bootstrap/dropdown';\nimport { BsModalService } from 'ngx-bootstrap/modal';\nimport {\n  BehaviorSubject,\n  combineLatest,\n  isObservable,\n  merge,\n  Observable,\n  of,\n  pipe,\n  Subject,\n  UnaryFunction\n} from 'rxjs';\nimport {\n  concatMap,\n  debounceTime,\n  delay,\n  distinctUntilChanged,\n  filter,\n  first,\n  map,\n  mergeMap,\n  switchMap,\n  take,\n  takeUntil,\n  tap\n} from 'rxjs/operators';\nimport { AlertService } from '../alert/alert.service';\nimport { toObservable } from '../common/extension-hooks';\nimport { LoadMoreComponent } from '../common/load-more.component';\nimport { LoadMoreMode } from '../common/load-more.model';\nimport { gettext } from '../i18n/gettext';\nimport { PopoverConfirmButtons, PopoverConfirmComponent } from '../modal/popover-confirm.component';\nimport { GainsightService } from '../product-experience/gainsight.service';\nimport {\n  ProductExperienceEvent,\n  ProductExperienceEventSource,\n  PRODUCT_EXPERIENCE_EVENT_SOURCE\n} from '../product-experience/product-experience.model';\nimport { CellRendererSpec } from './column/cell-renderer';\nimport { ColumnDirective } from './column/column.directive';\nimport { CustomColumn } from './column/custom.column';\nimport { FilteringFormRendererSpec, FilteringModifier } from './column/filtering-form-renderer';\nimport { ConfigureCustomColumnComponent } from './configure-custom-column';\nimport {\n  DataGridConfigurationStrategy,\n  DATA_GRID_CONFIGURATION_STRATEGY,\n  GridConfigPart,\n  GridEventType\n} from './data-grid-configuration.model';\nimport {\n  ActionControl,\n  BuiltInActionType,\n  BulkActionControl,\n  Column,\n  ColumnConfig,\n  ColumnDataType,\n  CustomColumnConfig,\n  DataGrid,\n  DataSourceStats,\n  DisplayOptions,\n  FilteringActionType,\n  GridConfig,\n  HeaderActionControl,\n  minColumnGridTrackSize,\n  Pagination,\n  ratiosByColumnTypes,\n  Row,\n  ServerSideDataCallback,\n  SortOrder,\n  SpecialColumnName\n} from './data-grid.model';\nimport { DataGridService } from './data-grid.service';\nimport { GridDataSource } from './grid-data-source';\nimport { PX_ACTIONS, PX_EVENT_NAME } from './product-experience.constants';\n\nenum SortingOrder {\n  ASC = 'asc',\n  DESC = 'desc'\n}\n\n@Component({\n  selector: 'c8y-data-grid',\n  templateUrl: './data-grid.component.html',\n  host: { class: 'd-contents' },\n  providers: [\n    {\n      provide: PRODUCT_EXPERIENCE_EVENT_SOURCE,\n      useExisting: forwardRef(() => DataGridComponent)\n    }\n  ]\n})\nexport class DataGridComponent\n  implements DataGrid, OnChanges, AfterViewInit, ProductExperienceEventSource\n{\n  /** The title for the data grid, it's displayed in the grid's header. */\n  @Input() title: string = gettext('Items');\n  /** The label for load more button. */\n  @Input() loadMoreItemsLabel: string = gettext('Load more items');\n  /** The label for loading indicator. */\n  @Input() loadingItemsLabel: string = gettext('Loading items…');\n  /** Determines whether text search input is shown in the grid's header. */\n  @Input() showSearch = false;\n  /** Takes an event emitter. When an event is emitted, the grid will be reloaded. */\n  @Input() refresh: EventEmitter<any>;\n\n  columns: Column[] = [];\n  /** The list of columns to be displayed in the grid. */\n  @Input('columns')\n  private _columns: Column[];\n\n  dataSource = new GridDataSource();\n  rows: Row[];\n  /** The list of rows to be displayed in the grid (used for client side data). */\n  @Input('rows')\n  set _rows(rows: Row[]) {\n    this.rows = rows || [];\n  }\n\n  filteringLabelsParams = {\n    filteredItemsCount: 0,\n    allItemsCount: 0\n  };\n\n  pagination: Pagination;\n  paginationLabelParams = {\n    pageFirstItemIdx: 0,\n    pageLastItemIdx: 0,\n    itemsTotal: 0\n  };\n  readonly possiblePageSizes: number[] = [25, 50, 100];\n  readonly minPossiblePageSize = Math.min(...this.possiblePageSizes);\n  /** Pagination settings, e.g. allows for setting current page or page size. */\n  @Input('pagination')\n  set _pagination(pagination: Pagination) {\n    this.pagination = pagination;\n  }\n\n  infiniteScroll: LoadMoreMode;\n  /** Sets load more mode. */\n  @Input('infiniteScroll')\n  set _infiniteScroll(infiniteScroll: LoadMoreMode) {\n    this.infiniteScroll = infiniteScroll;\n  }\n\n  serverSideDataCallback: ServerSideDataCallback;\n  /**\n   * Sets a callback function which will be invoked whenever data needs to be loaded from server.\n   * The function should take [[DataSourceModifier]] and return [[ServerSideDataResult]].\n   */\n  @Input('serverSideDataCallback')\n  set _serverSideDataCallback(serverSideDataCallback: ServerSideDataCallback) {\n    this.serverSideDataCallback = serverSideDataCallback;\n  }\n\n  selectable = false;\n  /** Determines whether items can be selected by clicking a checkbox in the first column. */\n  @Input('selectable')\n  set _selectable(selectable: boolean) {\n    this.selectable = selectable;\n  }\n\n  selectionPrimaryKey = 'id';\n  /** Determines which item's property will be used to distinguish selection status. */\n  @Input('selectionPrimaryKey')\n  set _selectionPrimaryKey(selectionPrimaryKey: string) {\n    this.selectionPrimaryKey = selectionPrimaryKey;\n  }\n\n  displayOptions: DisplayOptions = {\n    striped: true,\n    bordered: false,\n    gridHeader: true,\n    filter: true\n  };\n  /** Sets display options. */\n  @Input('displayOptions')\n  set _displayOptions(displayOptions: DisplayOptions) {\n    this.displayOptions = { ...this.displayOptions, ...displayOptions };\n  }\n\n  actionControls: ActionControl[];\n  /** Sets action controls (actions available for individual items). */\n  @Input('actionControls')\n  set _actionControls(actionControls: ActionControl[]) {\n    this.actionControls = actionControls || [];\n  }\n\n  bulkActionControls: BulkActionControl[];\n  /** Sets bulk action controls (actions available for items selected by user). */\n  @Input('bulkActionControls')\n  set _bulkActionControls(bulkActionControls: BulkActionControl[]) {\n    this.bulkActionControls = bulkActionControls || [];\n  }\n\n  headerActionControls: HeaderActionControl[];\n  /** Sets header action controls (actions available from data grid header). */\n  @Input('headerActionControls')\n  set _headerActionControls(headerActionControls: HeaderActionControl[]) {\n    this.headerActionControls = headerActionControls || [];\n  }\n\n  /** Sets initial search text. */\n  @Input()\n  searchText = '';\n\n  /** Determines if custom columns button will be enabled. */\n  @Input()\n  configureColumnsEnabled = true;\n\n  /** Shows the warning for the sub-assets counter */\n  @Input()\n  showCounterWarning = false;\n\n  /** Emits an event when mouse is over a row. */\n  @Output() rowMouseOver = new EventEmitter<object>();\n  /** Emits an event when mouse leaves a row. */\n  @Output() rowMouseLeave = new EventEmitter<object>();\n  /** Emits an event when a row is clicked. */\n  @Output() rowClick = new EventEmitter<object>();\n  /** Emits an event when grid's configuration is changed. */\n  @Output() onConfigChange = new EventEmitter<GridConfig>();\n  /** Emits an event before the filter is applied. */\n  @Output() onBeforeFilter = new EventEmitter<object>();\n  /** Emits an event before the search is performed. */\n  @Output() onBeforeSearch = new EventEmitter<string>();\n  /** Emits an event when a filter is applied in a column. */\n  @Output() onFilter = new EventEmitter<{\n    columnName?: string;\n    dropdown?: any;\n    filteringModifier?: any;\n  }>();\n  /** Emits an event when items selection changes. The array contains keys of selected items (key property is defined by `selectionPrimaryKey`). */\n  @Output() itemsSelect = new EventEmitter<string[]>();\n  /** Emits an event when reload button is clicked. */\n  @Output() onReload = new EventEmitter();\n  /** Emits an event when a custom column is added */\n  @Output() onAddCustomColumn = new EventEmitter<CustomColumnConfig>();\n  /** Emits an event when a custom column is removed */\n  @Output() onRemoveCustomColumn = new EventEmitter<Column>();\n  /** Emits an event after the column filter has been reset */\n  @Output() onColumnFilterReset = new EventEmitter<Column>();\n  /** Emits an event when column sorting has been changed */\n  @Output() onSort = new EventEmitter<GridConfig>();\n  /** Emits an event when page size has been changed */\n  @Output() onPageSizeChange = new EventEmitter<GridConfig>();\n  /** Emits an event when column order has been changed */\n  @Output() onColumnReordered = new EventEmitter<GridConfig>();\n  /** Emits an event when column order has been changed */\n  @Output() onColumnVisibilityChange = new EventEmitter<GridConfig>();\n\n  @ContentChildren(ColumnDirective) columnRenderers: QueryList<ColumnDirective>;\n\n  @ViewChild('scroll', { static: true }) scrollContainer: ElementRef;\n\n  @ViewChild('infiniteScrollContainer', { static: false, read: ViewContainerRef })\n  infiniteScrollContainer: ViewContainerRef;\n\n  loadMoreComponent: LoadMoreComponent;\n\n  columnNames = [];\n\n  styles = {\n    tableCursor: 'auto',\n    gridTemplateColumns: undefined,\n    gridInfiniteScrollColumn: undefined\n  };\n\n  searchText$ = new EventEmitter<string>();\n  filteringApplied = false;\n\n  totalPagesCount$ = new BehaviorSubject<number>(Infinity);\n  hidePagination$ = this.totalPagesCount$.pipe(\n    map(totalPagesCount => totalPagesCount <= 1),\n    delay(0) // prevents ExpressionChangedAfterItHasBeenCheckedError\n  );\n\n  selectedItemIds: string[] = [];\n  currentPageSelectionState = {\n    allSelected: false,\n    allDeselected: true\n  };\n\n  builtInActionType = {\n    Edit: BuiltInActionType.Edit,\n    Delete: BuiltInActionType.Delete,\n    Export: BuiltInActionType.Export\n  };\n\n  confirmRemoveColumnButtons: PopoverConfirmButtons[] = [\n    {\n      label: gettext('Cancel'),\n      action: () => Promise.resolve(false)\n    },\n    {\n      label: gettext('Remove`column,verb`'),\n      status: 'danger',\n      action: () => Promise.resolve(true)\n    }\n  ];\n\n  isConfigContextKnown = false;\n\n  /** Product experience constants declarations */\n  productExperienceEvent: ProductExperienceEvent = { eventName: PX_EVENT_NAME };\n  PX_ACTIONS = PX_ACTIONS;\n\n  readonly sortColumnTitle = gettext('Sort column \"{{ name }}\"');\n\n  resizeHandleMouseDown$ = new EventEmitter<any>();\n  resizeHandleContainerMouseMove$ = new EventEmitter<any>();\n  resizeHandleContainerMouseUp$ = new EventEmitter<any>();\n  private headerBeingResized: {\n    columnName: string;\n    el: HTMLElement;\n  };\n  @ViewChildren(CdkHeaderCell, { read: ElementRef }) private thRefs: QueryList<ElementRef>;\n  private thEls: HTMLElement[];\n\n  private recreateLoadMoreComponent: boolean;\n\n  private columnsInitialized = false;\n\n  private defaultColumns: Column[] = [];\n\n  private reloadConfiguration$: Subject<void> = new Subject();\n\n  private unsubscribe$ = new Subject<any>();\n\n  private readonly SEARCH_DEBOUNCE_TIME = 500;\n\n  /**\n   * Event emitter, taking boolean values used for loading data grid data with debounce.\n   * Default value is set to false. Set to true if data grid is using infinite scroll and page should be reloaded.\n   * This is used to avoid having multiple this.loadData() function calls.\n   */\n  private triggerLoadData = new EventEmitter<boolean>();\n\n  constructor(\n    @Optional()\n    @Inject(DATA_GRID_CONFIGURATION_STRATEGY)\n    public configurationStrategy: DataGridConfigurationStrategy,\n    private dataGridService: DataGridService,\n    private sanitizer: DomSanitizer,\n    private cfr: ComponentFactoryResolver,\n    private gainsightService: GainsightService,\n    private bsModalService: BsModalService,\n    private alertService: AlertService\n  ) {\n    this.triggerLoadData.pipe(debounceTime(1), takeUntil(this.unsubscribe$)).subscribe(reload => {\n      this.loadData(reload);\n    });\n\n    this.reloadConfiguration$\n      .pipe(\n        switchMap(() => this.configurationStrategy?.getConfig$() ?? of(null)),\n        tap(config => {\n          this.setColumns(config);\n          this.setPageSize(config);\n          this.triggerLoadData.emit(!!this.infiniteScroll);\n        }),\n        switchMap(() => this.dataSource.stats$),\n        tap(stats => {\n          this.createLoadMoreComponent(stats);\n          this.updateFilteringLabelsParams(stats);\n          this.updatePaginationLabelParams(stats);\n        }),\n        takeUntil(this.unsubscribe$)\n      )\n      .subscribe();\n  }\n\n  ngOnInit() {\n    this.isConfigContextKnown = !!this.configurationStrategy?.isContextKnown();\n\n    this.searchText$\n      .pipe(\n        takeUntil(this.unsubscribe$),\n        debounceTime(this.SEARCH_DEBOUNCE_TIME),\n        distinctUntilChanged(),\n        tap(searchText => {\n          this.searchText = searchText;\n          this.onBeforeSearch.emit(this.searchText);\n          this.triggerEvent({\n            action: PX_ACTIONS.SEARCH,\n            searchInput: searchText\n          });\n        })\n      )\n      .subscribe(() => {\n        this.reload();\n      });\n\n    if (this.selectable) {\n      combineLatest(this.dataSource.data$, this.itemsSelect.asObservable())\n        .pipe(takeUntil(this.unsubscribe$))\n        .subscribe(([data]) => {\n          const currentPageEmpty = data.length === 0;\n\n          this.currentPageSelectionState = {\n            allSelected: currentPageEmpty ? false : data.every(item => this.isItemSelected(item)),\n            allDeselected: currentPageEmpty ? true : data.every(item => !this.isItemSelected(item))\n          };\n        });\n    }\n\n    this.reloadConfiguration$.next();\n\n    if (this.refresh) {\n      this.refresh.pipe(takeUntil(this.unsubscribe$)).subscribe(() => {\n        this.cancel();\n        this.reload();\n      });\n    }\n\n    this.processAndPersistConfigChange();\n  }\n\n  ngOnChanges(event) {\n    if (\n      ((!event._actionControls && !event.searchText) || event._actionControls?.firstChange) &&\n      this.columnsInitialized\n    ) {\n      const reload = !!event._infiniteScroll?.currentValue && !event._infiniteScroll?.firstChange;\n      this.triggerLoadData.emit(reload);\n    }\n    if (!!event._columns && !event._columns.firstChange) {\n      this.reloadConfiguration$.next();\n    }\n    this.updateColumns();\n  }\n\n  ngAfterViewInit() {\n    this.updateGridColumnsSize();\n    this.updateThEls();\n    this.setupResizeHandle();\n  }\n\n  ngOnDestroy() {\n    this.unsubscribe$.next();\n    this.unsubscribe$.complete();\n  }\n\n  setColumns(config: GridConfig) {\n    if (!!this.configurationStrategy && !isEmpty(this._columns)) {\n      this.columns = this.dataGridService.applyConfigToColumns(config, this._columns);\n      this.columnsInitialized = true;\n    } else {\n      this.columns = this._columns || [];\n      this.columnsInitialized = this.columnsInitialized || !!this._columns;\n    }\n\n    this.defaultColumns = this.columns || [];\n    this.updateColumns();\n  }\n\n  setPageSize(config: GridConfig) {\n    if (!!config?.pagination) {\n      this.pagination = {\n        ...this.pagination,\n        pageSize: config.pagination.pageSize\n      };\n    }\n\n    const pageSize = get(this.pagination, 'pageSize');\n    if (\n      this.pagination &&\n      !this.possiblePageSizes.find(possiblePageSize => possiblePageSize === pageSize)\n    ) {\n      this.pagination = { ...this.pagination, pageSize: this.minPossiblePageSize };\n    }\n  }\n\n  openCustomColumnModal(): void {\n    const modalRef = this.bsModalService.show(ConfigureCustomColumnComponent, {\n      class: 'modal-sm',\n      ariaDescribedby: 'modal-body',\n      ariaLabelledBy: 'modal-title',\n      ignoreBackdropClick: true,\n      initialState: {\n        columns: this.columns\n      }\n    });\n\n    modalRef.content.onAddCustomColumn\n      .pipe(\n        tap((customColumnConfig: CustomColumnConfig) => {\n          const firstFixedColumPosition = this.columns.indexOf(\n            this.columns.find(column => column.positionFixed)\n          );\n          this.columns.splice(\n            firstFixedColumPosition > -1 ? firstFixedColumPosition : this.columns.length,\n            0,\n            new CustomColumn(customColumnConfig)\n          );\n          this.updateColumns();\n          this.triggerEvent({\n            action: PX_ACTIONS.ADD_CUSTOM_COLUMN,\n            column: customColumnConfig.header || customColumnConfig.name\n          });\n        }),\n        takeUntil(modalRef.onHidden)\n      )\n      .subscribe(event => this.onAddCustomColumn.emit(event));\n  }\n\n  async removeCustomColumn(\n    poConfirm: PopoverConfirmComponent,\n    column: Column,\n    ddConfigureColumns: BsDropdownDirective\n  ) {\n    ddConfigureColumns.autoClose = false;\n    poConfirm.message = gettext('Do you want to remove this column?');\n    try {\n      const remove: boolean = await poConfirm.show(this.confirmRemoveColumnButtons);\n      if (remove) {\n        this.columns = this.columns.filter(col => col?.name !== column?.name);\n        this.updateColumns();\n        this.onRemoveCustomColumn.emit(column);\n        this.triggerEvent({\n          action: PX_ACTIONS.REMOVE_CUSTOM_COLUMN,\n          column: column.header || column.name\n        });\n      }\n    } catch (e) {\n      this.alertService.addServerFailure(e);\n    }\n\n    setTimeout(() => (ddConfigureColumns.autoClose = true), 0);\n  }\n\n  trackByName(index, item) {\n    return item.name;\n  }\n\n  resolveCellValue(row, path) {\n    return flow([\n      x => this.dataSource.resolveValue(x, path),\n      this.dataSource.resolveFunction,\n      this.dataSource.normalizeNil\n    ])(row);\n  }\n\n  changeSortOrder(columnName) {\n    const column = this.columns.find(({ name }) => name === columnName);\n\n    if (column) {\n      const { sortOrder } = column;\n\n      if (!sortOrder) {\n        this.updateSorting([columnName], SortingOrder.ASC);\n      } else if (sortOrder === SortingOrder.ASC) {\n        this.updateSorting([columnName], SortingOrder.DESC);\n      } else {\n        this.updateSorting([columnName], '');\n      }\n    }\n  }\n\n  updateSorting(columnNames: string[], sortOrder: SortOrder) {\n    this.triggerEvent({\n      action: PX_ACTIONS.CHANGE_SORTING_ORDER,\n      columns: columnNames,\n      sortOrder: sortOrder === '' ? 'none' : sortOrder\n    });\n\n    this.columns = this.columns.map((column): Column => {\n      if (columnNames.includes(column.name)) {\n        return { ...column, sortOrder };\n      }\n\n      return column;\n    });\n    this.emitConfigChange('sort');\n    this.reload();\n  }\n\n  applyFilter(columnName, dropdown, filteringModifier) {\n    this.triggerEvent({\n      action: PX_ACTIONS.APPLY_FILTER,\n      column: columnName,\n      filteringModifier\n    });\n    this.onBeforeFilter.emit({ columnName, dropdown, filteringModifier });\n    this.updateFiltering([columnName], {\n      type: FilteringActionType.ApplyFilter,\n      payload: { filteringModifier }\n    });\n    dropdown.hide();\n    this.onFilter.emit({ columnName, dropdown, filteringModifier });\n  }\n\n  resetFilter(columnName, dropdown) {\n    this.triggerEvent({ action: PX_ACTIONS.RESET_FILTER, column: columnName });\n    this.updateFiltering([columnName], { type: FilteringActionType.ResetFilter });\n    dropdown.hide();\n    this.onFilter.emit({ columnName, dropdown });\n  }\n\n  clearFilters(reload = true) {\n    this.updateFiltering(\n      this.columns.map(({ name }) => name),\n      {\n        type: FilteringActionType.ResetFilter\n      },\n      reload\n    );\n    this.onFilter.emit({});\n    this.triggerEvent({ action: PX_ACTIONS.CLEAR_FILTER });\n  }\n\n  updateFiltering(\n    columnNames: string[],\n    action: {\n      type: FilteringActionType;\n      payload?: { filteringModifier: FilteringModifier };\n    },\n    reload = true\n  ) {\n    this.columns = this.columns.map(column => {\n      if (columnNames.includes(column.name)) {\n        return {\n          ...column,\n          ...(action.type === FilteringActionType.ApplyFilter\n            ? action.payload.filteringModifier\n            : this.onResetFilterAction(column))\n        };\n      }\n      return column;\n    });\n\n    this.updateFilteringApplied();\n    if (reload) {\n      this.reload();\n    }\n  }\n\n  updateFilteringApplied() {\n    this.filteringApplied = this.columns.some(this.isColumnFilteringApplied);\n  }\n\n  isColumnFilteringApplied(column: Column): boolean {\n    const { filterable, filterPredicate, externalFilterQuery } = column;\n\n    return !!(filterable && (filterPredicate || externalFilterQuery));\n  }\n\n  updatePagination({ itemsPerPage, page }) {\n    const configChanged = this.pagination?.pageSize !== itemsPerPage;\n    this.pagination = { ...this.pagination, pageSize: itemsPerPage, currentPage: page };\n    this.loadData();\n    if (configChanged) {\n      this.emitConfigChange('pagination');\n    }\n    this.triggerEvent({ action: PX_ACTIONS.CHANGE_PAGINATION, itemsPerPage, page });\n  }\n\n  clickReload() {\n    this.searchText = '';\n    this.reload();\n    this.onReload.next();\n    this.triggerEvent({ action: PX_ACTIONS.RELOAD });\n  }\n\n  reload() {\n    this.pagination = { ...this.pagination, currentPage: 1 };\n    this.recreateLoadMoreComponent = true;\n    this.loadData(true);\n    this.scrollToTop();\n  }\n\n  loadNextPage(): Promise<IResultList<object>> {\n    this.pagination = { ...this.pagination, currentPage: this.pagination.nextPage };\n\n    this.loadData();\n\n    return this.dataSource.resultList$\n      .pipe(take(1)) // in order for `toPromise` to work, the observable needs to complete\n      .toPromise()\n      .then(result => {\n        return {\n          ...result,\n          paging: {\n            ...result.paging,\n            next: this.loadNextPage.bind(this)\n          }\n        } as IResultList<object>;\n      });\n  }\n\n  getCellRendererSpec({ value, row, columnName }): CellRendererSpec {\n    return this._getCellRendererSpec({ type: 'CELL', value, row, columnName });\n  }\n\n  getHeaderCellRendererSpec({ value, columnName }): CellRendererSpec {\n    return this._getCellRendererSpec({ type: 'HEADER', value, row: undefined, columnName });\n  }\n\n  getFilteringFormRendererSpec({ column, dropdown }): FilteringFormRendererSpec {\n    return {\n      renderer:\n        get(this.getColumnRenderer(column), 'filteringFormRendererDef.template') ||\n        column.filteringFormRendererComponent,\n      context: {\n        property: column,\n        applyFilter: this.applyFilter.bind(this, column.name, dropdown),\n        resetFilter: this.resetFilter.bind(this, column.name, dropdown)\n      }\n    };\n  }\n\n  setAllItemsSelected(selected) {\n    this.dataSource.selection$\n      .pipe(first())\n      .subscribe(({ filteredDataIds }) => this.setItemsSelected(filteredDataIds, selected));\n  }\n\n  setAllItemsInCurrentPageSelected(selected) {\n    this.dataSource.data$.pipe(first()).subscribe(data => this.setItemsSelected(data, selected));\n  }\n\n  setItemsSelected(items: any[], selected) {\n    const itemIds = items.map((item: object | string) =>\n      typeof item === 'object' ? item[this.selectionPrimaryKey] : item\n    );\n\n    this.selectedItemIds = selected\n      ? union(this.selectedItemIds, itemIds)\n      : without(this.selectedItemIds, ...itemIds);\n    this.itemsSelect.emit(this.selectedItemIds);\n  }\n\n  cancel() {\n    this.selectedItemIds = [];\n    this.itemsSelect.emit(this.selectedItemIds);\n  }\n\n  isItemSelected(item) {\n    return this.selectedItemIds.includes(item[this.selectionPrimaryKey]);\n  }\n\n  onColumnDrop({ previousIndex, currentIndex }) {\n    const differentIndex = previousIndex !== currentIndex;\n\n    if (differentIndex) {\n      this.triggerEvent({\n        action: PX_ACTIONS.REORDER_COLUMNS,\n        column: this.columnNames[previousIndex]\n      });\n      const column = this.columns.splice(previousIndex, 1);\n      this.columns.splice(currentIndex, 0, column[0]);\n      this.emitConfigChange('reorderColumn');\n    }\n\n    this.updateColumnNames();\n    this.updateGridColumnsSize();\n  }\n\n  updateGridColumnsSize() {\n    this.styles = {\n      ...this.styles,\n      gridTemplateColumns: this.sanitizer.bypassSecurityTrustStyle(\n        this.columns\n          .filter(column => column.visible)\n          .map(({ gridTrackSize }) => gridTrackSize)\n          .join(' ')\n      ),\n      gridInfiniteScrollColumn: this.sanitizer.bypassSecurityTrustStyle(\n        `1 / span ${this.columns.filter(column => column.visible).length}`\n      )\n    };\n  }\n\n  updateThEls() {\n    setTimeout(() => {\n      this.thEls = this.thRefs\n        ? this.thRefs.toArray().map(({ nativeElement }) => nativeElement)\n        : [];\n    }, 0);\n  }\n\n  // To be removed when columns are transformed to observables.\n  isDropDownPlacedRight(column: Column) {\n    return (\n      indexOf(\n        this.columns.filter(c => c.visible),\n        column\n      ) >\n      this.columns.filter(c => c.visible).length / 2\n    );\n  }\n\n  emitConfigChange(eventType?: GridEventType) {\n    if (this.columnsInitialized) {\n      const columns = this.columns.map(this.mapColumnToConfig.bind(this));\n      const config = { columns, pagination: this.pagination };\n      this.onConfigChange.emit(config);\n      switch (eventType) {\n        case 'sort':\n          this.onSort.emit(config);\n          break;\n        case 'pagination':\n          this.onPageSizeChange.emit(config);\n          break;\n        case 'reorderColumn':\n          this.onColumnReordered.emit(config);\n          break;\n        case 'changeColumnVisibility':\n          this.onColumnVisibilityChange.emit(config);\n      }\n    }\n  }\n\n  triggerEvent(eventData) {\n    this.gainsightService.triggerEvent(this.productExperienceEvent?.eventName || PX_EVENT_NAME, {\n      ...this.productExperienceEvent?.data,\n      ...eventData\n    });\n  }\n\n  private onResetFilterAction(column: Column) {\n    this.onColumnFilterReset.emit(column);\n    return {\n      filterPredicate: undefined,\n      externalFilterQuery: undefined\n    };\n  }\n\n  private mapColumnToConfig(column: Column): ColumnConfig | CustomColumnConfig {\n    let config;\n    if (column.custom) {\n      const { visible, sortOrder, name, externalFilterQuery, header, path } = column;\n      config = {\n        visible,\n        sortOrder,\n        name,\n        filter: { externalFilterQuery },\n        header,\n        path,\n        custom: true\n      };\n    } else {\n      const { visible, sortOrder, name, externalFilterQuery } = column;\n      config = { visible, sortOrder, name, filter: { externalFilterQuery } };\n    }\n\n    if (isEmpty(config?.filter?.externalFilterQuery)) {\n      delete config.filter;\n    }\n\n    return config;\n  }\n\n  private loadData(reload = false) {\n    const {\n      rows,\n      columns,\n      pagination,\n      searchText,\n      serverSideDataCallback,\n      selectable,\n      selectionPrimaryKey,\n      infiniteScroll\n    } = this;\n\n    this.dataSource.loadData({\n      rows,\n      columns,\n      pagination,\n      searchText,\n      serverSideDataCallback,\n      selectable,\n      selectionPrimaryKey,\n      infiniteScroll,\n      reload\n    });\n  }\n\n  private updateColumns() {\n    const specialColumn = {\n      sortable: false,\n      positionFixed: true\n    };\n    const checkboxColumn = this.selectable\n      ? {\n          ...specialColumn,\n          name: SpecialColumnName.Checkbox,\n          gridTrackSize: '32px'\n        }\n      : undefined;\n    const actionsColumn =\n      this.actionControls?.length > 0\n        ? {\n            ...specialColumn,\n            name: SpecialColumnName.Actions,\n            gridTrackSize: this.actionControls.length > 2 ? '56px' : 'minmax(40px, auto)'\n          }\n        : undefined;\n\n    const columns = [checkboxColumn, ...this.columns, actionsColumn]\n      .filter(Boolean)\n      .map(this.withColumnDefaults);\n\n    this.columns = uniqBy(columns, 'name');\n    this.updateColumnNames();\n    this.updateGridColumnsSize();\n    this.updateThEls();\n    this.updateFilteringApplied();\n  }\n\n  private withColumnDefaults(column): Column {\n    const dataType = column.dataType || ColumnDataType.TextShort;\n    const { headerCSSClassName, cellCSSClassName } = column;\n\n    return {\n      visible: true,\n      positionFixed: false,\n      resizable: true,\n      sortable: true,\n      sortOrder: '',\n      filterable: false,\n      ...column,\n      dataType,\n      gridTrackSize:\n        column.gridTrackSize ||\n        `minmax(${minColumnGridTrackSize}px, ${ratiosByColumnTypes[dataType]}fr)`,\n      headerCSSClassName:\n        (typeof headerCSSClassName === 'string'\n          ? headerCSSClassName.split(' ')\n          : headerCSSClassName) || [],\n      cellCSSClassName:\n        (typeof cellCSSClassName === 'string' ? cellCSSClassName.split(' ') : cellCSSClassName) ||\n        []\n    };\n  }\n\n  private updateColumnNames() {\n    this.columnNames = this.columns.map(({ name }) => name);\n  }\n\n  private setupResizeHandle() {\n    const resizeHandleDrag$ = this.resizeHandleMouseDown$.pipe(\n      takeUntil(this.unsubscribe$),\n      tap(() => this.clearMouseHighlights()),\n      mergeMap(({ event, targetColumnName }) => {\n        this.columns = this.columns.map(column => {\n          if (column.name === targetColumnName) {\n            return {\n              ...column,\n              headerCSSClassName: union(column.headerCSSClassName, ['header--being-resized'])\n            };\n          }\n\n          return column;\n        });\n\n        this.headerBeingResized = {\n          columnName: targetColumnName,\n          el: event.target?.parentNode\n        };\n\n        this.styles = {\n          ...this.styles,\n          tableCursor: 'col-resize'\n        };\n\n        return this.resizeHandleContainerMouseMove$.pipe(\n          tap(() => this.clearMouseHighlights()),\n          takeUntil(this.resizeHandleContainerMouseUp$)\n        );\n      })\n    );\n\n    resizeHandleDrag$.subscribe((event: MouseEvent) => {\n      requestAnimationFrame(() => {\n        this.columns = this.columns.map((column, i) => {\n          if (this.headerBeingResized && column.name === this.headerBeingResized.columnName) {\n            const scrollContainerDiv: HTMLDivElement = this.scrollContainer.nativeElement;\n\n            // Read scrollContainerEl's offset left relative to the document.\n            const horizontalOffset = scrollContainerDiv.getBoundingClientRect().left;\n\n            // Adjust with the scrollContainerEl horizontal scroll position.\n            const horizontalScrollOffset = scrollContainerDiv.scrollLeft - horizontalOffset;\n\n            // Read left offset of the resized header.\n            const headerOffsetLeft = this.headerBeingResized.el.offsetLeft || 0;\n\n            // Calculate the desired width.\n            const width = horizontalScrollOffset + event.clientX - headerOffsetLeft;\n\n            return {\n              ...column,\n              // Update the column object with the new size value, enforce our minimum size.\n              gridTrackSize: `${Math.max(minColumnGridTrackSize, width)}px`\n            };\n          }\n\n          // For the other headers which don't have a set width, fix it to their computed width.\n          if (column.gridTrackSize.startsWith('minmax')) {\n            return {\n              ...column,\n              // isn't fixed yet (it would be a px value)\n              gridTrackSize: `${_parseInt(this.thEls[i].clientWidth)}px`\n            };\n          }\n\n          return column;\n        });\n\n        /*\n         * Update the column sizes.\n         * Note: grid-template-columns sets the width for all columns in one value.\n         */\n        this.updateGridColumnsSize();\n      });\n    });\n\n    this.resizeHandleContainerMouseUp$.pipe(takeUntil(this.unsubscribe$)).subscribe(() => {\n      if (this.headerBeingResized) {\n        this.columns = this.columns.map(column => {\n          if (column.name === this.headerBeingResized.columnName) {\n            return {\n              ...column,\n              headerCSSClassName: without(column.headerCSSClassName, 'header--being-resized')\n            };\n          }\n\n          return column;\n        });\n        this.headerBeingResized = undefined;\n\n        this.styles = {\n          ...this.styles,\n          tableCursor: 'auto'\n        };\n      }\n    });\n  }\n\n  private clearMouseHighlights() {\n    if (window.getSelection) {\n      window.getSelection().removeAllRanges();\n    }\n  }\n\n  private _getCellRendererSpec({ type, value, row, columnName }): CellRendererSpec {\n    const column = this.columns.find(({ name }) => name === columnName);\n    const columnRenderer = this.getColumnRenderer(column);\n    const rendererTemplate = get(\n      columnRenderer,\n      `${type === 'HEADER' ? 'headerCellRendererDef' : 'cellRendererDef'}.template`\n    );\n\n    const { cellRendererComponent, headerCellRendererComponent } = column;\n    const rendererComponent =\n      type === 'HEADER' ? headerCellRendererComponent : cellRendererComponent;\n\n    return {\n      renderer: rendererTemplate || rendererComponent,\n      context: {\n        value,\n        item: row,\n        property: column\n      }\n    };\n  }\n\n  private getColumnRenderer(column): ColumnDirective {\n    return this.columnRenderers.toArray().find(({ name }) => name === column.name);\n  }\n\n  private updateFilteringLabelsParams(stats: DataSourceStats) {\n    this.filteringLabelsParams = {\n      filteredItemsCount: stats.filteredSize,\n      allItemsCount: stats.size\n    };\n  }\n\n  private updatePaginationLabelParams(stats: DataSourceStats) {\n    if (stats.nextPage) {\n      this.pagination = { ...this.pagination, nextPage: stats.nextPage };\n    }\n\n    const pageFirstItemIdx = (stats.currentPage - 1) * stats.firstPageSize + 1;\n    this.paginationLabelParams = {\n      pageFirstItemIdx,\n      pageLastItemIdx: pageFirstItemIdx + (stats.currentPageSize - 1),\n      itemsTotal: stats.filteredSize\n    };\n  }\n\n  private createLoadMoreComponent(stats: DataSourceStats) {\n    if (\n      this.infiniteScroll &&\n      stats &&\n      stats.nextPage &&\n      (!this.loadMoreComponent || this.recreateLoadMoreComponent)\n    ) {\n      this.recreateLoadMoreComponent = false;\n      this.infiniteScrollContainer.clear();\n      const componentFactory: ComponentFactory<any> =\n        this.cfr.resolveComponentFactory(LoadMoreComponent);\n      const componentRef = this.infiniteScrollContainer.createComponent(componentFactory);\n      const instance = componentRef.instance as LoadMoreComponent;\n      instance.useIntersection = this.infiniteScroll === 'auto' || this.infiniteScroll === 'hidden';\n      instance.hidden = this.infiniteScroll === 'hidden';\n      instance.paging = {\n        nextPage: stats.nextPage,\n        next: this.loadNextPage.bind(this)\n      } as Paging<any>;\n      instance.loadNextLabel = this.loadMoreItemsLabel;\n      instance.loadingLabel = this.loadingItemsLabel;\n      this.loadMoreComponent = instance;\n    } else if (this.loadMoreComponent && !stats.nextPage) {\n      this.loadMoreComponent.paging = {\n        nextPage: null\n      } as Paging<any>;\n    }\n  }\n\n  private scrollToTop() {\n    if (this.infiniteScroll) {\n      this.scrollContainer.nativeElement.scrollTop = 0;\n    }\n  }\n\n  private processAndPersistConfigChange() {\n    merge(\n      merge(\n        this.onSort,\n        this.onPageSizeChange,\n        this.onColumnReordered,\n        this.onColumnVisibilityChange\n      ).pipe(map(config => config.columns)),\n      merge(this.onAddCustomColumn, this.onRemoveCustomColumn).pipe(\n        map(() => (this.columns || []).map(this.mapColumnToConfig.bind(this)))\n      ),\n      this.onFilter.pipe(\n        map(({ columnName, filteringModifier }) =>\n          this.columns.map(this.mapColumnToConfig.bind(this)).map((column: ColumnConfig) => {\n            if (isNil(columnName)) {\n              delete column.filter;\n            } else if (column.name === columnName) {\n              if (isEmpty(filteringModifier)) {\n                delete column.filter;\n              } else {\n                column.filter = filteringModifier;\n              }\n            }\n\n            return column;\n          })\n        )\n      )\n    )\n      .pipe(\n        map((columns: Array<ColumnConfig | CustomColumnConfig>) => ({\n          columns,\n          pagination: { pageSize: this.pagination.pageSize }\n        })),\n        filter(() => !!this.configurationStrategy),\n        this.trimFilterConfigPipe(),\n        this.trimSortConfigPipe(),\n        this.trimCustomColumnConfigPipe(),\n        this.ignoreColumnOrderPipe(),\n        this.ignoreColumnVisibilityPipe(),\n        concatMap((config: GridConfig) => this.configurationStrategy.saveConfig$(config)),\n        takeUntil(this.unsubscribe$)\n      )\n      .subscribe();\n  }\n\n  private trimFilterConfigPipe(): UnaryFunction<Observable<GridConfig>, Observable<GridConfig>> {\n    return pipe(\n      this.checkEventPipe('filter', config => {\n        config.columns = (config.columns || []).map(col => {\n          delete col.filter;\n          return col;\n        });\n\n        return config;\n      })\n    );\n  }\n\n  private trimSortConfigPipe(): UnaryFunction<Observable<GridConfig>, Observable<GridConfig>> {\n    return pipe(\n      this.checkEventPipe('sort', config => {\n        config.columns = (config.columns || []).map(col => {\n          col.sortOrder = '';\n          return col;\n        });\n\n        return config;\n      })\n    );\n  }\n\n  private trimCustomColumnConfigPipe(): UnaryFunction<\n    Observable<GridConfig>,\n    Observable<GridConfig>\n  > {\n    return pipe(\n      this.checkEventPipe('customColumns', config => {\n        config.columns = (config.columns || []).filter((col: CustomColumnConfig) => !col.custom);\n\n        return config;\n      })\n    );\n  }\n\n  private ignoreColumnOrderPipe(): UnaryFunction<Observable<GridConfig>, Observable<GridConfig>> {\n    return pipe(\n      this.checkEventPipe('order', config => {\n        return this.configurationStrategy.getConfig$().pipe(\n          map(oldConfig => {\n            const oldColumns: ColumnConfig[] =\n              oldConfig?.columns || (this.defaultColumns as ColumnConfig[]);\n            // check if custom columns have been added\n            const columnsAdded = (config.columns || []).filter(\n              col => !oldColumns.find(old => old.name === col.name)\n            );\n\n            config.columns = [\n              ...oldColumns.map(oldCol =>\n                (config.columns || []).find(newCol => newCol.name === oldCol.name)\n              ),\n              ...columnsAdded\n            ];\n\n            return config;\n          })\n        );\n      })\n    );\n  }\n\n  private ignoreColumnVisibilityPipe(): UnaryFunction<\n    Observable<GridConfig>,\n    Observable<GridConfig>\n  > {\n    return pipe(\n      this.checkEventPipe('visibility', config => {\n        return this.configurationStrategy.getConfig$().pipe(\n          map(oldConfig => {\n            config.columns = (config.columns || []).map(newCol => {\n              const columns: ColumnConfig[] =\n                oldConfig?.columns || (this.defaultColumns as ColumnConfig[]);\n              const oldCol = columns.find((col: any) => newCol.name === col.name);\n              newCol.visible = oldCol?.visible ?? true;\n              return newCol;\n            });\n\n            return config;\n          })\n        );\n      })\n    );\n  }\n\n  private checkEventPipe(\n    configPart: GridConfigPart,\n    trimEventDataFn: (config: GridConfig) => GridConfig | Observable<GridConfig>\n  ): UnaryFunction<Observable<GridConfig>, Observable<GridConfig>> {\n    return pipe(\n      concatMap((config: GridConfig) => {\n        return this.resolveConfigFilter\n          .call(this, configPart)\n          .pipe(map(keepEventData => ({ config, keepEventData })));\n      }),\n      map(({ config, keepEventData }) =>\n        keepEventData ? config : trimEventDataFn.call(this, config)\n      ),\n      concatMap(config => (isObservable(config) ? config : of(config)) as Observable<GridConfig>)\n    );\n  }\n\n  private resolveConfigFilter(configPart: GridConfigPart): Observable<boolean> {\n    let result: boolean | Observable<boolean> | Promise<boolean>;\n    const valueOrFn = this.configurationStrategy.getContext()?.configFilter?.[configPart];\n    if (typeof valueOrFn === 'function') {\n      result = valueOrFn();\n    } else {\n      result = valueOrFn;\n    }\n    return toObservable(result ?? true);\n  }\n}\n","<div\n  #scroll\n  class=\"table-data-grid-scroll\"\n  [ngClass]=\"{ 'table-data-grid__overlay': (dataSource.loading$ | async) && !loadMoreComponent }\"\n  data-cy=\"c8y-data-grid--table-data-grid-scroll\"\n>\n  <div\n    class=\"table-data-grid__loading--wrapper\"\n    *ngIf=\"(dataSource.loading$ | async) && !loadMoreComponent\"\n  >\n    <div class=\"table-data-grid__loading--loader\">\n      <c8y-progress-bar [message]=\"loadingItemsLabel\"></c8y-progress-bar>\n    </div>\n  </div>\n\n  <div *ngIf=\"displayOptions.gridHeader\" class=\"table-data-grid-header separator large-padding\">\n    <div class=\"h4\" [ngClass]=\"{ 'm-r-16': !!title }\">{{ title | translate }}</div>\n\n    <ng-container *ngIf=\"displayOptions.filter\">\n      <span *ngIf=\"!filteringApplied\">\n        <span class=\"label label-default m-r-4\" translate>No filters</span>\n        <small\n          *ngIf=\"!!filteringLabelsParams.allItemsCount\"\n          class=\"m-r-4\"\n          ngNonBindable\n          translate\n          [translateParams]=\"filteringLabelsParams\"\n        >\n          {{ filteredItemsCount }} of {{ allItemsCount }} items\n        </small>\n      </span>\n      <span *ngIf=\"filteringApplied\">\n        <ng-container *ngIf=\"!!filteringLabelsParams.allItemsCount\">\n          <span class=\"badge badge-info m-r-4\">\n            {{ (dataSource.stats$ | async).filteredSize }}\n          </span>\n          <small ngNonBindable translate [translateParams]=\"filteringLabelsParams\">\n            of {{ allItemsCount }} items\n          </small>\n        </ng-container>\n        <button\n          class=\"btn btn-sm btn-default m-l-8 m-r-4\"\n          type=\"button\"\n          title=\"{{ 'Clear filters' | translate }}\"\n          (click)=\"clearFilters()\"\n        >\n          {{ 'Clear filters' | translate }}\n        </button>\n      </span>\n\n      <button\n        class=\"btn-help btn-help--sm hidden-xs hidden-sm\"\n        *ngIf=\"displayOptions.filter\"\n        type=\"button\"\n        [attr.aria-label]=\"'Help' | translate\"\n        popover=\"{{ 'Click the column headers to apply filters.' | translate }}\"\n        placement=\"right\"\n        triggers=\"focus\"\n        [attr.aria-label]=\"'Click the column headers to apply filters.' | translate\"\n        data-cy=\"data-grid--help-filters\"\n      >\n        <i c8yIcon=\"question-circle-o\"></i>\n      </button>\n\n      <button\n        class=\"btn-clean text-primary hidden-xs hidden-sm\"\n        *ngIf=\"showCounterWarning\"\n        type=\"button\"\n        [attr.aria-label]=\"'Help' | translate\"\n        popover=\"{{ 'The counter for the total number of items might be inaccurate.' | translate }}\"\n        placement=\"right\"\n        triggers=\"focus\"\n      >\n        <i c8yIcon=\"warning\"></i>\n      </button>\n    </ng-container>\n\n    <div class=\"m-l-auto\">\n      <div class=\"btnbar d-flex a-i-center\">\n        <ng-container *ngFor=\"let headerActionControl of headerActionControls\">\n          <ng-container *ngIf=\"headerActionControl | isControlVisible\">\n            <ng-container *ngIf=\"!headerActionControl.template; else customTemplate\">\n              <button\n                class=\"btnbar-btn btn-link\"\n                type=\"button\"\n                title=\"{{ headerActionControl.text | translate }}\"\n                (click)=\"headerActionControl.callback()\"\n                c8yProductExperience\n                inherit\n                [actionData]=\"{\n                  action: PX_ACTIONS.CUSTOM_ACTION,\n                  customActionName: headerActionControl.text,\n                  type: headerActionControl.type\n                }\"\n              >\n                <i [c8yIcon]=\"headerActionControl.icon\" class=\"m-r-4\"></i>\n                <span>{{ headerActionControl.text | translate }}</span>\n              </button>\n            </ng-container>\n            <ng-template #customTemplate>\n              <ng-container\n                *ngTemplateOutlet=\"\n                  headerActionControl.template;\n                  context: { headerActionControl: headerActionControl }\n                \"\n              ></ng-container>\n            </ng-template>\n          </ng-container>\n        </ng-container>\n\n        <div\n          *ngIf=\"configureColumnsEnabled\"\n          class=\"dropdown\"\n          dropdown\n          #ddConfigureColumns=\"bs-dropdown\"\n          [cdkTrapFocus]=\"ddConfigureColumns.isOpen\"\n          [insideClick]=\"true\"\n          placement=\"bottom left\"\n        >\n          <button\n            title=\"{{ 'Configure columns' | translate }}\"\n            data-cy=\"data-grid--custom-column-btn\"\n            class=\"btnbar-btn\"\n            type=\"button\"\n            dropdownToggle\n          >\n            <i c8yIcon=\"columns\" class=\"m-r-4\"></i>\n            <span>{{ 'Configure columns' | translate }}</span>\n          </button>\n\n          <ul *dropdownMenu class=\"dropdown-menu data-grid__dropdown\" (click)=\"$event.stopPropagation()\">\n            <li class=\"bg-level-0\">\n              <div cdkDropList (cdkDropListDropped)=\"onColumnDrop($event)\" class=\"list-group m-0\">\n                <div *ngFor=\"let column of columns\" cdkDrag cdkDragLockAxis=\"y\">\n                  <ng-container *ngIf=\"!column.positionFixed\">\n                    <div class=\"list-group-item draggable-after p-0 a-i-center\">\n                      <label\n                        title=\"{{ (column.header | translate) || column.name }}\"\n                        [attr.data-cy]=\"'data-grid--custom-column-header-' + column.header\"\n                        class=\"c8y-checkbox p-l-16\"\n                      >\n                        <input\n                          type=\"checkbox\"\n                          [(ngModel)]=\"column.visible\"\n                          (change)=\"\n                            updateGridColumnsSize(); emitConfigChange('changeColumnVisibility')\n                          \"\n                          c8yProductExperience\n                          inherit\n                          [actionData]=\"{\n                            action: PX_ACTIONS.CHANGE_VISIBILITY,\n                            column: column.name,\n                            visible: !column.visible\n                          }\"\n                        />\n                        <span></span>\n                        <span>{{ (column.header | translate) || column.name }}</span>\n                      </label>\n                      <button\n                        class=\"btn btn-dot showOnHover max-width-fit a-i-center\"\n                        type=\"button\"\n                        [attr.aria-label]=\"'Remove`column,verb`' | translate\"\n                        tooltip=\"{{ 'Remove`column,verb`' | translate }}\"\n                        placement=\"left\"\n                        container=\"body\"\n                        (click)=\"removeCustomColumn(poConfirm, column, ddConfigureColumns)\"\n                        *ngIf=\"column.custom\"\n                      >\n                        <c8y-popover-confirm\n                          [placement]=\"'left'\"\n                          [title]=\"'Confirm removal' | translate\"\n                          triggers=\"focus\"\n                          #poConfirm\n                        ></c8y-popover-confirm>\n                        <i c8yIcon=\"minus-circle\" data-cy=\"data-grid--custom-column-remove-btn\"></i>\n                      </button>\n                    </div>\n                  </ng-container>\n                </div>\n              </div>\n            </li>\n            <li *ngIf=\"isConfigContextKnown\" class=\"p-8 sticky-bottom separator-top\">\n              <button\n                class=\"btn btn-default btn-block\"\n                type=\"button\"\n                title=\"{{ 'Add custom column' | translate }}\"\n                data-cy=\"data-grid--add-custom-column\"\n                (click)=\"openCustomColumnModal(); ddConfigureColumns.hide()\"\n              >\n                <i c8yIcon=\"plus-circle\" class=\"m-r-4\"></i>\n                <span>{{ 'Add custom column' | translate }}</span>\n              </button>\n            </li>\n          </ul>\n        </div>\n\n        <button\n          title=\"{{ 'Reload' | translate }}\"\n          data-cy=\"data-grid--reload-btn\"\n          class=\"btnbar-btn btn-link\"\n          type=\"button\"\n          [disabled]=\"dataSource.loading$ | async\"\n          (click)=\"clickReload()\"\n        >\n          <i c8yIcon=\"refresh\" class=\"m-r-4\"></i>\n          <span>{{ 'Reload' | translate }}</span>\n        </button>\n\n        <div\n          *ngIf=\"!serverSideDataCallback || showSearch\"\n          class=\"input-group input-group-search m-l-sm-16 data-grid__search-input\"\n        >\n          <input\n            type=\"search\"\n            class=\"form-control\"\n            placeholder=\"{{ 'Search…' | translate }}\"\n            [ngModel]=\"searchText\"\n            (input)=\"searchText$.emit($event.target.value)\"\n          />\n          <div class=\"input-group-addon\">\n            <i c8yIcon=\"search\" *ngIf=\"searchText.length === 0\"></i>\n            <i\n              c8yIcon=\"times\"\n              class=\"pointer\"\n              *ngIf=\"searchText.length > 0\"\n              (click)=\"searchText = ''; searchText$.emit('')\"\n              c8yProductExperience\n              inherit\n              [actionData]=\"{ action: PX_ACTIONS.CLEAR_SEARCH }\"\n            ></i>\n          </div>\n        </div>\n      </div>\n    </div>\n    <div\n      class=\"table-data-grid-header-bulk-actions animated slideInDown fast\"\n      *ngIf=\"selectedItemIds.length !== 0\"\n    >\n      <h4>\n        <span ngNonBindable translate [translateParams]=\"{ count: selectedItemIds.length }\">\n          {{ count }} selected item(s).\n        </span>\n        <br class=\"visible-xs\" />\n        <small *ngIf=\"!serverSideDataCallback && selectedItemIds.length >= pagination.pageSize\">\n          <a\n            (click)=\"setAllItemsSelected(true)\"\n            class=\"interact\"\n            c8yProductExperience\n            inherit\n            [actionData]=\"{ action: PX_ACTIONS.SELECT_ALL_ITEMS }\"\n          >\n            <span\n              ngNonBindable\n              translate\n              [translateParams]=\"{ count: (dataSource.stats$ | async).filteredSize }\"\n            >\n              Select all {{ count }} items\n            </span>\n          </a>\n        </small>\n      </h4>\n      <div class=\"m-l-auto\">\n        <div class=\"btnbar d-flex\">\n          <ng-container *ngFor=\"let bulkActionControl of bulkActionControls\">\n            <ng-container\n              *ngIf=\"bulkActionControl | isControlVisible: selectedItemIds\"\n              [ngSwitch]=\"bulkActionControl.type\"\n            >\n              <button\n                class=\"btnbar-btn\"\n                type=\"button\"\n                title=\"{{ 'Export' | translate }}\"\n                (click)=\"bulkActionControl.callback(selectedItemIds, reload.bind(this))\"\n                *ngSwitchCase=\"builtInActionType.Export\"\n                [actionData]=\"{ action: PX_ACTIONS.BULK_EXPORT }\"\n                c8yProductExperience\n                inherit\n              >\n                <i c8yIcon=\"sign-out\"></i>\n                <span>{{ 'Export' | translate }}</span>\n              </button>\n\n              <button\n                class=\"btnbar-btn\"\n                type=\"button\"\n                title=\"{{ 'Delete' | translate }}\"\n                (click)=\"bulkActionControl.callback(selectedItemIds, reload.bind(this))\"\n                *ngSwitchCase=\"builtInActionType.Delete\"\n                [actionData]=\"{ action: PX_ACTIONS.BULK_DELETE }\"\n                c8yProductExperience\n                inherit\n              >\n                <i c8yIcon=\"delete\"></i>\n                <span>{{ 'Delete' | translate }}</span>\n              </button>\n\n              <button\n                class=\"btnbar-btn\"\n                type=\"button\"\n                title=\"{{ bulkActionControl.text | translate }}\"\n                (click)=\"bulkActionControl.callback(selectedItemIds, reload.bind(this))\"\n                *ngSwitchDefault\n                [actionData]=\"{\n                  action: PX_ACTIONS.BULK_CUSTOM_ACTION,\n                  customActionName: bulkActionControl.text\n                }\"\n                c8yProductExperience\n                inherit\n              >\n                <i c8yIcon=\"{{ bulkActionControl.icon }}\"></i>\n                <span>{{ bulkActionControl.text | translate }}</span>\n              </button>\n            </ng-container>\n          </ng-container>\n\n          <button\n            class=\"btnbar-btn\"\n            type=\"button\"\n            title=\"{{ 'Cancel' | translate }}\"\n            (click)=\"cancel()\"\n            [actionData]=\"{\n              action: PX_ACTIONS.BULK_CANCEL\n            }\"\n            c8yProductExperience\n            inherit\n          >\n            <i c8yIcon=\"times\"></i>\n            <span>{{ 'Cancel' | translate }}</span>\n          </button>\n        </div>\n      </div>\n    </div>\n  </div>\n\n  <table\n    class=\"table table-hover table-filtered-sorted table-data-grid large-padding\"\n    cdk-table\n    [dataSource]=\"dataSource\"\n    [trackBy]=\"trackByName\"\n    [class.table-striped]=\"displayOptions.striped\"\n    [class.table-bordered]=\"displayOptions.bordered\"\n    [class.table-data-grid-with-checkboxes]=\"selectable\"\n    [class.table-data-grid-with-actions]=\"actionControls.length > 0\"\n    [style.grid-template-columns]=\"styles.gridTemplateColumns\"\n    (mousemove)=\"resizeHandleContainerMouseMove$.emit($event)\"\n    (mouseup)=\"resizeHandleContainerMouseUp$.emit($event)\"\n    data-cy=\"c8y-data-grid--table\"\n  >\n    <ng-container\n      *ngFor=\"let column of columns; let i = index; trackBy: trackByName\"\n      [cdkColumnDef]=\"column.name\"\n    >\n      <ng-container [ngSwitch]=\"column.name\">\n        <ng-container *ngSwitchCase=\"'checkbox'\">\n          <th cdk-header-cell *cdkHeaderCellDef data-type=\"icon\">\n            <div>\n              <label class=\"c8y-checkbox\">\n                <input\n                  [attr.aria-label]=\"'Selected' | translate\"\n                  type=\"checkbox\"\n                  [checked]=\"currentPageSelectionState.allSelected\"\n                  [indeterminate]=\"\n                    !(\n                      currentPageSelectionState.allSelected ||\n                      currentPageSelectionState.allDeselected\n                    )\n                  \"\n                  (change)=\"setAllItemsInCurrentPageSelected($event.target.checked)\"\n                  c8yProductExperience\n                  inherit\n                  [actionData]=\"{ action: PX_ACTIONS.SELECT_ALL_ITEMS }\"\n                />\n                <span></span>\n              </label>\n            </div>\n          </th>\n\n          <td cdk-cell *cdkCellDef=\"let row\" data-type=\"icon\">\n            <label class=\"c8y-checkbox\">\n              <input\n                [attr.aria-label]=\"'Selected' | translate\"\n                type=\"checkbox\"\n                [checked]=\"isItemSelected(row)\"\n                (change)=\"setItemsSelected([row], $event.target.checked)\"\n                c8yProductExperience\n                inherit\n                [actionData]=\"{\n                  action: PX_ACTIONS.SELECT_ITEM,\n                  id: row.id\n                }\"\n                data-cy=\"c8y-data-grid--checkbox\"\n              />\n              <span></span>\n            </label>\n          </td>\n        </ng-container>\n\n        <ng-container *ngSwitchCase=\"'actions'\">\n          <th cdk-header-cell *cdkHeaderCellDef data-type=\"icon\">\n            <p class=\"text-medium sr-only\">{{ 'Actions' | translate }}</p>\n          </th>\n\n          <td cdk-cell *cdkCellDef=\"let row\" data-type=\"icon\">\n            <ng-container *ngIf=\"actionControls.length <= 2\">\n              <ng-container *ngFor=\"let actionControl of actionControls\">\n                <ng-container\n                  *ngIf=\"actionControl | isControlVisible: row\"\n                  [ngSwitch]=\"actionControl.type\"\n                >\n                  <button\n                    *ngSwitchCase=\"builtInActionType.Edit\"\n                    class=\"btn btn-dot\"\n                    type=\"button\"\n                    [attr.aria-label]=\"'Edit' | translate\"\n                    tooltip=\"{{ 'Edit' | translate }}\"\n                    [delay]=\"500\"\n                    container=\"body\"\n                    (click)=\"actionControl.callback(row, reload.bind(this))\"\n                    c8yProductExperience\n                    inherit\n                    [actionData]=\"{\n                      action: PX_ACTIONS.EDIT_ITEM,\n                      id: row.id\n                    }\"\n                  >\n                    <i c8yIcon=\"pencil\"></i>\n                  </button>\n\n                  <button\n                    class=\"btn btn-dot btn-dot--danger showOnHover\"\n                    type=\"button\"\n                    [attr.aria-label]=\"'Delete' | translate\"\n                    tooltip=\"{{ 'Delete' | translate }}\"\n                    [delay]=\"500\"\n                    container=\"body\"\n                    (click)=\"actionControl.callback(row, reload.bind(this))\"\n                    *ngSwitchCase=\"builtInActionType.Delete\"\n                    [actionData]=\"{\n                      action: PX_ACTIONS.DELETE_ITEM,\n                      id: row.id\n                    }\"\n                    c8yProductExperience\n                    inherit\n                    data-cy=\"c8y-data-grid--remove-button-in-row\"\n                  >\n                    <i c8yIcon=\"delete\"></i>\n                  </button>\n\n                  <button\n                    class=\"btn btn-dot\"\n                    type=\"button\"\n                    [attr.aria-label]=\"(actionControl.icon ? actionControl.text : '') | translate\"\n                    tooltip=\"{{ (actionControl.icon ? actionControl.text : '') | translate }}\"\n                    [delay]=\"500\"\n                    container=\"body\"\n                    *ngSwitchDefault\n                    (click)=\"actionControl.callback(row, reload.bind(this))\"\n                    [actionData]=\"{\n                      action: PX_ACTIONS.CUSTOM_ACTION_ITEM,\n                      customActionName: actionControl.text,\n                      id: row.id\n                    }\"\n                    c8yProductExperience\n                    inherit\n                  >\n                    <i *ngIf=\"actionControl.icon\" c8yIcon=\"{{ actionControl.icon }}\"></i>\n                    <span *ngIf=\"!actionControl.icon\">{{ actionControl.text | translate }}</span>\n                  </button>\n                </ng-container>\n              </ng-container>\n            </ng-container>\n\n            <div [ngClass]=\"{ 'm-l-auto overflow-visible': actionControls.length > 2 }\">\n              <div\n                class=\"dropdown\"\n                dropdown\n                container=\"body\"\n                placement=\"bottom right\"\n                *ngIf=\"actionControls.length > 2\"\n              >\n                <button\n                  class=\"dropdown-toggle c8y-dropdown\"\n                  type=\"button\"\n                  title=\"{{ 'Actions' | translate }}\"\n                  dropdownToggle\n                  aria-haspopup=\"true\"\n                >\n                  <i c8yIcon=\"ellipsis-v\"></i>\n                </button>\n                <ul class=\"dropdown-menu dropdown-menu-right\" *dropdownMenu>\n                  <li *ngFor=\"let actionControl of actionControls\">\n                    <ng-container\n                      *ngIf=\"actionControl | isControlVisible: row\"\n                      [ngSwitch]=\"actionControl.type\"\n                    >\n                      <button\n                        type=\"button\"\n                        title=\"{{ 'Edit' | translate }}\"\n                        *ngSwitchCase=\"builtInActionType.Edit\"\n                        (click)=\"actionControl.callback(row, reload.bind(this))\"\n                        [actionData]=\"{\n                          action: PX_ACTIONS.EDIT_ITEM,\n                          id: row.id\n                        }\"\n                        c8yProductExperience\n                        inherit\n                      >\n                        <i c8yIcon=\"pencil\"></i>\n                        {{ 'Edit' | translate }}\n                      </button>\n                      <button\n                        type=\"button\"\n                        title=\"{{ 'Delete' | translate }}\"\n                        *ngSwitchCase=\"builtInActionType.Delete\"\n                        (click)=\"actionControl.callback(row, reload.bind(this))\"\n                        [actionData]=\"{\n                          action: PX_ACTIONS.DELETE_ITEM,\n                          id: row.id\n                        }\"\n                        c8yProductExperience\n                        inherit\n                      >\n                        <i c8yIcon=\"delete\"></i>\n                        {{ 'Delete' | translate }}\n                      </button>\n                      <button\n                        type=\"button\"\n                        title=\"{{ 'Export' | translate }}\"\n                        *ngSwitchCase=\"builtInActionType.Export\"\n                        (click)=\"actionControl.callback(row, reload.bind(this))\"\n                        [actionData]=\"{\n                          action: PX_ACTIONS.EXPORT_ITEM,\n                          id: row.id\n                        }\"\n                        c8yProductExperience\n                        inherit\n                      >\n                        <i c8yIcon=\"download\"></i>\n                        {{ 'Export' | translate }}\n                      </button>\n                      <button\n                        type=\"button\"\n                        title=\"{{ actionControl.text | translate }}\"\n                        *ngSwitchDefault\n                        (click)=\"actionControl.callback(row, reload.bind(this))\"\n                        c8yProductExperience\n                        inherit\n                        [actionData]=\"{\n                          action: PX_ACTIONS.CUSTOM_ACTION_ITEM,\n                          customActionName: actionControl.text,\n                          id: row.id\n                        }\"\n                      >\n                        <i c8yIcon=\"{{ actionControl.icon }}\"></i>\n                        {{ actionControl.text | translate }}\n                      </button>\n                    </ng-container>\n                  </li>\n                </ul>\n              </div>\n            </div>\n          </td>\n        </ng-container>\n\n        <ng-container *ngSwitchDefault>\n          <th\n            cdk-header-cell\n            *cdkHeaderCellDef\n            [ngClass]=\"column.headerCSSClassName\"\n            [attr.data-type]=\"column.dataType\"\n            [class.sorted]=\"column.sortOrder\"\n            [class.filtered]=\"column | map: isColumnFilteringApplied\"\n            [class.hidden]=\"!column.visible\"\n          >\n            <div *ngIf=\"!column.filterable\" [title]=\"(column.header | translate) || column.name\">\n              <ng-container\n                *ngIf=\"\n                  [\n                    {\n                      columnName: column.name,\n                      value: (column.header | translate) || column.name\n                    }\n                  ] | map: getHeaderCellRendererSpec:this as cellRendererSpec\n                \"\n              >\n                <c8y-cell-renderer [spec]=\"cellRendererSpec\"></c8y-cell-renderer>\n              </ng-container>\n            </div>\n\n            <!-- isDropDownPlacedRight to be removed when columns are transformed to observables. -->\n            <div\n              *ngIf=\"column.filterable\"\n              class=\"dropdown\"\n              dropdown\n              #gridHeaderDropdown=\"bs-dropdown\"\n              [cdkTrapFocus]=\"gridHeaderDropdown.isOpen\"\n              placement=\"bottom {{ isDropDownPlacedRight(column) ? 'right' : 'left' }}\"\n              [insideClick]=\"true\"\n            >\n              <button\n                class=\"btn-header\"\n                type=\"button\"\n                [title]=\"(column.header | translate) || column.name\"\n                [attr.data-cy]=\"'data-grid--header-btn--' + column.header\"\n                dropdownToggle\n              >\n                <ng-container\n                  *ngIf=\"\n                    [\n                      {\n                        columnName: column.name,\n                        value: (column.header | translate) || column.name\n                      }\n                    ] | map: getHeaderCellRendererSpec:this as cellRendererSpec\n                  \"\n                >\n                  <c8y-cell-renderer\n                    data-cy=\"c8y-data-grid--c8y-cell-renderer\"\n                    [spec]=\"cellRendererSpec\"\n                  ></c8y-cell-renderer>\n                </ng-container>\n                <i c8yIcon=\"filter\" title=\"{{ 'Filter' | translate }}\"></i>\n              </button>\n\n              <!-- isDropDownPlacedRight to be removed when columns are transformed to observables. -->\n              <ul\n                *dropdownMenu\n                class=\"dropdown-menu\"\n                [ngClass]=\"{ 'dropdown-menu-right-grid': isDropDownPlacedRight(column) }\"\n                (click)=\"$event.stopPropagation()\"\n              >\n                <li class=\"data-grid__dropdown\">\n                  <ng-container\n                    *ngIf=\"\n                      [\n                        {\n                          column: column,\n                          dropdown: gridHeaderDropdown\n                        }\n                      ] | map: getFilteringFormRendererSpec:this as filteringFormRendererSpec\n                    \"\n                  >\n                    <c8y-filtering-form-renderer\n                      [spec]=\"filteringFormRendererSpec\"\n                      data-cy=\"c8y-data-grid--c8y-filtering-form-renderer\"\n                    ></c8y-filtering-form-renderer>\n                  </ng-container>\n                </li>\n              </ul>\n            </div>\n\n            <button\n              class=\"btn-sort\"\n              type=\"button\"\n              [title]=\"sortColumnTitle | translate: { name: column.header | translate }\"\n              *ngIf=\"column.sortable\"\n              (click)=\"changeSortOrder(column.name)\"\n              data-cy=\"change-sort-order\"\n            >\n              <ng-container [ngSwitch]=\"column.sortOrder\">\n                <i *ngSwitchCase=\"'asc'\" c8yIcon=\"long-arrow-up\"></i>\n                <i *ngSwitchCase=\"'desc'\" c8yIcon=\"long-arrow-down\"></i>\n                <i *ngSwitchDefault c8yIcon=\"exchange\"></i>\n              </ng-container>\n            </button>\n\n            <span\n              *ngIf=\"column.resizable\"\n              class=\"resize-handle\"\n              (mousedown)=\"\n                resizeHandleMouseDown$.emit({ event: $event, targetColumnName: column.name })\n              \"\n            ></span>\n          </th>\n\n          <td\n            cdk-cell\n            *cdkCellDef=\"let row\"\n            [ngClass]=\"column.cellCSSClassName\"\n            [attr.data-cell-title]=\"column.header | translate\"\n            [attr.data-cy]=\"'data-grid--' + column.header\"\n            [attr.data-type]=\"column.dataType\"\n            [class.hidden]=\"!column.visible\"\n          >\n            <ng-container\n              *ngIf=\"\n                [\n                  {\n                    value: resolveCellValue(row, column.path),\n                    row: row,\n                    columnName: column.name\n                  }\n                ] | map: getCellRendererSpec:this as cellRendererSpec\n              \"\n            >\n              <c8y-cell-renderer [spec]=\"cellRendererSpec\"></c8y-cell-renderer>\n            </ng-container>\n          </td>\n        </ng-container>\n      </ng-container>\n    </ng-container>\n\n    <ng-container cdkColumnDef=\"infiniteScrollFooter\">\n      <td cdk-footer-cell *cdkFooterCellDef [style.grid-column]=\"styles.gridInfiniteScrollColumn\">\n        <template #infiniteScrollContainer></template>\n      </td>\n    </ng-container>\n\n    <tr cdk-header-row *cdkHeaderRowDef=\"columnNames\"></tr>\n\n    <tr\n      data-cy=\"c8y-data-grid--row-in-data-grid\"\n      cdk-row\n      *cdkRowDef=\"let row; columns: columnNames\"\n      (mouseover)=\"rowMouseOver.emit(row)\"\n      (mouseleave)=\"rowMouseLeave.emit(row)\"\n      (click)=\"rowClick.emit(row)\"\n    ></tr>\n\n    <ng-container>\n      <tr\n        [ngClass]=\"{ hidden: !infiniteScroll }\"\n        cdk-footer-row\n        *cdkFooterRowDef=\"['infiniteScrollFooter']\"\n      ></tr>\n    </ng-container>\n  </table>\n\n  <div\n    class=\"d-flex m-0 p-t-40 p-b-40\"\n    *ngIf=\"!(dataSource.loading$ | async) && (dataSource.stats$ | async).filteredSize === 0\"\n  >\n    <div class=\"col-lg-3 col-sm-4 m-l-auto m-r-auto\">\n      <ng-content select=\"c8y-ui-empty-state, .c8y-empty-state\"></ng-content>\n    </div>\n  </div>\n\n  <div *ngIf=\"pagination && !infiniteScroll\" class=\"table-data-grid-footer separator large-padding\">\n    <div class=\"col-sm-4 no-gutter\">\n      <div\n        *ngIf=\"(dataSource.stats$ | async).currentPageSize > 0\"\n        class=\"counter p-t-8 p-b-8\"\n        data-cy=\"data-grid--counter\"\n      >\n        <span class=\"text-muted\" ngNonBindable translate [translateParams]=\"paginationLabelParams\">\n          {{ pageFirstItemIdx }} - {{ pageLastItemIdx }} of {{ itemsTotal }}\n        </span>\n      </div>\n    </div>\n\n    <div class=\"col-sm-4 no-gutter text-center\">\n      <div\n        *ngIf=\"(dataSource.stats$ | async).filteredSize > minPossiblePageSize\"\n        class=\"form-group form-inline p-t-8 p-b-8\"\n      >\n        <label class=\"m-r-4\" for=\"filteredSize\">{{ 'Items per page' | translate }}</label>\n        <div class=\"c8y-select-wrapper\">\n          <select\n            class=\"form-control\"\n            id=\"filteredSize\"\n            data-cy=\"data-grid--pagesize-options\"\n            [ngModel]=\"pagination.pageSize\"\n            (ngModelChange)=\"\n              updatePagination({ itemsPerPage: $event, page: pagination.currentPage })\n            \"\n          >\n            <option *ngFor=\"let pageSize of possiblePageSizes\" [ngValue]=\"pageSize\">\n              {{ pageSize }}\n            </option>\n          </select>\n        </div>\n      </div>\n    </div>\n\n    <div class=\"col-sm-4 no-gutter text-right\">\n      <pagination\n        *ngIf=\"(dataSource.stats$ | async).filteredSize > 0\"\n        [class.hidden]=\"hidePagination$ | async\"\n        [ngModel]=\"pagination.currentPage\"\n        (pageChanged)=\"updatePagination($event)\"\n        [totalItems]=\"(dataSource.stats$ | async).filteredSize\"\n        [itemsPerPage]=\"pagination.pageSize\"\n        (numPages)=\"totalPagesCount$.next($event)\"\n        [maxSize]=\"5\"\n        [boundaryLinks]=\"false\"\n        previousText=\"Previous\"\n        nextText=\"Next\"\n        class=\"p-t-8 p-b-8\"\n      ></pagination>\n    </div>\n  </div>\n</div>\n"]}