UNPKG

@c8y/ngx-components

Version:

Angular modules for Cumulocity IoT applications

220 lines 36.5 kB
import { Component, EventEmitter, forwardRef, Input, Output, ViewChild } from '@angular/core'; import { alertOnError, DataGridComponent, FilteringActionType, gettext, PRODUCT_EXPERIENCE_EVENT_SOURCE } from '@c8y/ngx-components'; import { Subject } from 'rxjs'; import { DeviceGridService } from './device-grid.service'; import * as i0 from "@angular/core"; import * as i1 from "./device-grid.service"; import * as i2 from "@c8y/ngx-components"; import * as i3 from "@angular/common"; export class DeviceGridComponent { /** Pagination settings, e.g. allows for setting current page or page size. If not given, defaults to standard settings. */ set _pagination(value) { if (value) { this.pagination = value; } } /** Sets load more mode. */ set _infiniteScroll(infiniteScroll) { this.infiniteScroll = infiniteScroll; if (infiniteScroll) { this.pagination = this.deviceGridService.getInfiniteScrollPagination(); } } /** Sets action controls (actions available for individual items). If not given, it defaults to standard actions. */ set _actionControls(value) { this.actionControls = value; } /** Sets bulk action controls (actions available for items selected by user). If not given, it defaults to standard bulk actions. */ set _bulkActionControls(value) { if (value) { this.bulkActionControls = value; } else { this.bulkActionControls = this.deviceGridService.getDefaultBulkActionControls(); } } /** Sets header action controls (actions available from the grid header). If not given, it defaults to empty list of actions. */ set _headerActionControls(value) { if (value) { this.headerActionControls = value; } else { this.headerActionControls = this.deviceGridService.getDefaultHeaderActionControls(); } } constructor(deviceGridService) { this.deviceGridService = deviceGridService; /** Takes an event emitter. When an event is emitted, the grid will be reloaded. */ this.refresh = new EventEmitter(); /** The title for the data grid, it's displayed in the grid's header. */ this.title = gettext('Devices'); /** The label for load more button. */ this.loadMoreItemsLabel = gettext('Load more devices'); /** The label for loading indicator. */ this.loadingItemsLabel = gettext('Loading devices…'); /** The list of columns to be displayed in the grid. If not given, it defaults to standard columns. */ this.columns = this.deviceGridService.getDefaultColumns(); /** Determines whether items can be selected by clicking a checkbox in the first column. */ this.selectable = false; /** Restricts selection to a single row only. Selection column displays radio button instead of checkboxes */ this.singleSelection = false; /** Sets the base query which is appended to the request for data. */ this.baseQuery = {}; this.childDeviceGrid = false; /** Sets the withChildren query which is appended to the request. */ this.withChildren = false; /** * Enables the search for devices where any device propery is matched agains the search term. * Enabled by default. This input does not take effect if the <code>childDeviceGrid</code> input is set to <code>true</code> */ this.showSearch = true; /** * Sets the class name used for active rows (last clicked). * Set empty string to disable appending active class to grid rows. */ this.activeClassName = 'active'; /** Emits an event when columns configuration changes. */ this.onColumnsChange = new EventEmitter(); this.onFilterChange = new EventEmitter(); this.onDeviceQueryStringChange = new EventEmitter(); /** Emits an event when items selection changes. The array contains ids of selected items. */ this.itemsSelect = new EventEmitter(); this.actionControls = []; this.appliedFilters = []; this.pagination = this.deviceGridService.getDefaultPagination(); this.bulkActionControls = this.deviceGridService.getDefaultBulkActionControls(); this.headerActionControls = this.deviceGridService.getDefaultHeaderActionControls(); this.noResultsMessage = gettext('No matching devices.'); this.noDataMessage = gettext('No devices to display.'); this.noResultsSubtitle = gettext('Refine your search terms'); this.destroyed$ = new Subject(); this.serverSideDataCallback = this.onDataSourceModifier.bind(this); } ngOnDestroy() { this.destroyed$.next(); this.destroyed$.complete(); } trackByName(_index, column) { return column.name; } async onDataSourceModifier(dataSourceModifier) { let serverSideDataResult; let filteredSize; let size; if (this.childDeviceGrid) { const { res, data, paging } = await alertOnError(this.deviceGridService.getChildDeviceData(dataSourceModifier.columns, dataSourceModifier.pagination, this.baseQuery, this.withChildren, this.parentDeviceId)); filteredSize = await alertOnError(this.deviceGridService.getCountChildDevices(dataSourceModifier.columns, dataSourceModifier.pagination, this.baseQuery, this.parentDeviceId)); size = await alertOnError(this.deviceGridService.getTotalChildDevices(this.baseQuery, this.parentDeviceId)); serverSideDataResult = { res, data, paging, filteredSize, size }; } else { const { res, data, paging } = await alertOnError(this.deviceGridService.getData(dataSourceModifier.columns, dataSourceModifier.pagination, this.baseQuery, this.withChildren, dataSourceModifier.searchText)); filteredSize = await alertOnError(this.deviceGridService.getCount(dataSourceModifier.columns, dataSourceModifier.pagination, this.baseQuery, dataSourceModifier.searchText)); size = await alertOnError(this.deviceGridService.getTotal(this.baseQuery)); serverSideDataResult = { res, data, paging, filteredSize, size }; } this.onColumnsChange.emit(dataSourceModifier.columns); this.onDeviceQueryStringChange.emit(this.deviceGridService.getDeviceQueryString(dataSourceModifier.columns, this.baseQuery)); if (this.dataCallback) { serverSideDataResult = this.dataCallback(serverSideDataResult); } return serverSideDataResult; } updateFiltering(columnNames, action) { const { type } = action; if (type === FilteringActionType.ResetFilter) { this.dataGrid.clearFilters(); } else { this.dataGrid.updateFiltering(columnNames, action); } } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DeviceGridComponent, deps: [{ token: i1.DeviceGridService }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DeviceGridComponent, selector: "c8y-device-grid", inputs: { dataCallback: "dataCallback", refresh: "refresh", title: "title", loadMoreItemsLabel: "loadMoreItemsLabel", loadingItemsLabel: "loadingItemsLabel", legacyConfigKey: "legacyConfigKey", legacyFilterKey: "legacyFilterKey", columns: "columns", _pagination: ["pagination", "_pagination"], _infiniteScroll: ["infiniteScroll", "_infiniteScroll"], _actionControls: ["actionControls", "_actionControls"], selectable: "selectable", singleSelection: "singleSelection", baseQuery: "baseQuery", _bulkActionControls: ["bulkActionControls", "_bulkActionControls"], _headerActionControls: ["headerActionControls", "_headerActionControls"], childDeviceGrid: "childDeviceGrid", parentDeviceId: "parentDeviceId", withChildren: "withChildren", showSearch: "showSearch", activeClassName: "activeClassName" }, outputs: { onColumnsChange: "onColumnsChange", onFilterChange: "onFilterChange", onDeviceQueryStringChange: "onDeviceQueryStringChange", itemsSelect: "itemsSelect" }, providers: [ { provide: PRODUCT_EXPERIENCE_EVENT_SOURCE, useExisting: forwardRef(() => DeviceGridComponent) } ], viewQueries: [{ propertyName: "dataGrid", first: true, predicate: DataGridComponent, descendants: true, static: true }], ngImport: i0, template: "<c8y-data-grid\n [title]=\"title\"\n [loadMoreItemsLabel]=\"loadMoreItemsLabel\"\n [loadingItemsLabel]=\"loadingItemsLabel\"\n [columns]=\"columns\"\n [pagination]=\"pagination\"\n [infiniteScroll]=\"infiniteScroll\"\n [actionControls]=\"actionControls\"\n [selectable]=\"selectable\"\n [singleSelection]=\"singleSelection\"\n [bulkActionControls]=\"bulkActionControls\"\n [serverSideDataCallback]=\"serverSideDataCallback\"\n (itemsSelect)=\"itemsSelect.emit($event)\"\n [refresh]=\"refresh\"\n [showSearch]=\"showSearch && !childDeviceGrid\"\n [headerActionControls]=\"headerActionControls\"\n [activeClassName]=\"activeClassName\"\n c8yProductExperience\n inherit\n>\n <c8y-ui-empty-state\n [icon]=\"stats?.size > 0 ? 'search' : 'c8y-device-management'\"\n [title]=\"stats?.size > 0 ? (noResultsMessage | translate) : (noDataMessage | translate)\"\n [subtitle]=\"stats?.size > 0 ? (noResultsSubtitle | translate) : null\"\n *emptyStateContext=\"let stats\"\n [horizontal]=\"stats?.size > 0\"\n ></c8y-ui-empty-state>\n\n <ng-container *ngFor=\"let column of columns; trackBy: trackByName\">\n <c8y-column [name]=\"column.name\"></c8y-column>\n </ng-container>\n</c8y-data-grid>\n", dependencies: [{ kind: "component", type: i2.EmptyStateComponent, selector: "c8y-ui-empty-state", inputs: ["icon", "title", "subtitle", "horizontal"] }, { kind: "directive", type: i2.EmptyStateContextDirective, selector: "[emptyStateContext]" }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.ColumnDirective, selector: "c8y-column", inputs: ["name"] }, { kind: "component", type: i2.DataGridComponent, selector: "c8y-data-grid", inputs: ["title", "loadMoreItemsLabel", "loadingItemsLabel", "showSearch", "refresh", "columns", "rows", "pagination", "infiniteScroll", "serverSideDataCallback", "selectable", "singleSelection", "selectionPrimaryKey", "displayOptions", "actionControls", "bulkActionControls", "headerActionControls", "searchText", "configureColumnsEnabled", "showCounterWarning", "activeClassName", "expandableRows"], outputs: ["rowMouseOver", "rowMouseLeave", "rowClick", "onConfigChange", "onBeforeFilter", "onBeforeSearch", "onFilter", "itemsSelect", "onReload", "onAddCustomColumn", "onRemoveCustomColumn", "onColumnFilterReset", "onSort", "onPageSizeChange", "onColumnReordered", "onColumnVisibilityChange"] }, { kind: "directive", type: i2.ProductExperienceDirective, selector: "[c8yProductExperience]", inputs: ["actionName", "actionData", "inherit", "suppressDataOverriding"] }, { kind: "pipe", type: i2.C8yTranslatePipe, name: "translate" }] }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DeviceGridComponent, decorators: [{ type: Component, args: [{ selector: 'c8y-device-grid', providers: [ { provide: PRODUCT_EXPERIENCE_EVENT_SOURCE, useExisting: forwardRef(() => DeviceGridComponent) } ], template: "<c8y-data-grid\n [title]=\"title\"\n [loadMoreItemsLabel]=\"loadMoreItemsLabel\"\n [loadingItemsLabel]=\"loadingItemsLabel\"\n [columns]=\"columns\"\n [pagination]=\"pagination\"\n [infiniteScroll]=\"infiniteScroll\"\n [actionControls]=\"actionControls\"\n [selectable]=\"selectable\"\n [singleSelection]=\"singleSelection\"\n [bulkActionControls]=\"bulkActionControls\"\n [serverSideDataCallback]=\"serverSideDataCallback\"\n (itemsSelect)=\"itemsSelect.emit($event)\"\n [refresh]=\"refresh\"\n [showSearch]=\"showSearch && !childDeviceGrid\"\n [headerActionControls]=\"headerActionControls\"\n [activeClassName]=\"activeClassName\"\n c8yProductExperience\n inherit\n>\n <c8y-ui-empty-state\n [icon]=\"stats?.size > 0 ? 'search' : 'c8y-device-management'\"\n [title]=\"stats?.size > 0 ? (noResultsMessage | translate) : (noDataMessage | translate)\"\n [subtitle]=\"stats?.size > 0 ? (noResultsSubtitle | translate) : null\"\n *emptyStateContext=\"let stats\"\n [horizontal]=\"stats?.size > 0\"\n ></c8y-ui-empty-state>\n\n <ng-container *ngFor=\"let column of columns; trackBy: trackByName\">\n <c8y-column [name]=\"column.name\"></c8y-column>\n </ng-container>\n</c8y-data-grid>\n" }] }], ctorParameters: () => [{ type: i1.DeviceGridService }], propDecorators: { dataCallback: [{ type: Input }], refresh: [{ type: Input }], title: [{ type: Input }], loadMoreItemsLabel: [{ type: Input }], loadingItemsLabel: [{ type: Input }], legacyConfigKey: [{ type: Input }], legacyFilterKey: [{ type: Input }], columns: [{ type: Input, args: ['columns'] }], _pagination: [{ type: Input, args: ['pagination'] }], _infiniteScroll: [{ type: Input, args: ['infiniteScroll'] }], _actionControls: [{ type: Input, args: ['actionControls'] }], selectable: [{ type: Input }], singleSelection: [{ type: Input }], baseQuery: [{ type: Input }], _bulkActionControls: [{ type: Input, args: ['bulkActionControls'] }], _headerActionControls: [{ type: Input, args: ['headerActionControls'] }], childDeviceGrid: [{ type: Input }], parentDeviceId: [{ type: Input }], withChildren: [{ type: Input }], showSearch: [{ type: Input }], activeClassName: [{ type: Input }], onColumnsChange: [{ type: Output }], onFilterChange: [{ type: Output }], onDeviceQueryStringChange: [{ type: Output }], itemsSelect: [{ type: Output }], dataGrid: [{ type: ViewChild, args: [DataGridComponent, { static: true }] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"device-grid.component.js","sourceRoot":"","sources":["../../../device-grid/device-grid.component.ts","../../../device-grid/device-grid.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  forwardRef,\n  Input,\n  OnDestroy,\n  Output,\n  ViewChild\n} from '@angular/core';\nimport {\n  ActionControl,\n  alertOnError,\n  BulkActionControl,\n  Column,\n  DataGridComponent,\n  DataSourceModifier,\n  FilteringActionType,\n  FilteringModifier,\n  gettext,\n  HeaderActionControl,\n  LoadMoreMode,\n  Pagination,\n  ProductExperienceEvent,\n  ProductExperienceEventSource,\n  PRODUCT_EXPERIENCE_EVENT_SOURCE,\n  ServerSideDataCallback,\n  ServerSideDataResult\n} from '@c8y/ngx-components';\nimport { Subject } from 'rxjs';\nimport { DataCallback, FilterConfig } from './device-grid.model';\nimport { DeviceGridService } from './device-grid.service';\n\n@Component({\n  selector: 'c8y-device-grid',\n  templateUrl: './device-grid.component.html',\n  providers: [\n    {\n      provide: PRODUCT_EXPERIENCE_EVENT_SOURCE,\n      useExisting: forwardRef(() => DeviceGridComponent)\n    }\n  ]\n})\nexport class DeviceGridComponent implements OnDestroy, ProductExperienceEventSource {\n  /** Optional callback function that allows to modify server side data result before it's rendered. */\n  @Input() dataCallback: DataCallback;\n  /** Takes an event emitter. When an event is emitted, the grid will be reloaded. */\n  @Input() refresh: EventEmitter<void> = new EventEmitter();\n  /** The title for the data grid, it's displayed in the grid's header. */\n  @Input() title: string = gettext('Devices');\n  /** The label for load more button. */\n  @Input() loadMoreItemsLabel = gettext('Load more devices');\n  /** The label for loading indicator. */\n  @Input() loadingItemsLabel: string = gettext('Loading devices…');\n  /**\n   * @deprecated\n   *\n   * Internal use only: used to define user preferences key under which 'All devices' column config is stored.\n   */\n  @Input() legacyConfigKey: string;\n  /**\n   * @deprecated\n   *\n   * Internal use only: used to define user preferences key under which 'All devices' filter/sorting config is stored.\n   */\n  @Input() legacyFilterKey: string;\n  /** The list of columns to be displayed in the grid. If not given, it defaults to standard columns. */\n  @Input('columns') columns: Column[] = this.deviceGridService.getDefaultColumns();\n  /** Pagination settings, e.g. allows for setting current page or page size. If not given, defaults to standard settings. */\n  @Input('pagination') set _pagination(value: Pagination) {\n    if (value) {\n      this.pagination = value;\n    }\n  }\n  infiniteScroll: LoadMoreMode;\n  /** Sets load more mode. */\n  @Input('infiniteScroll') set _infiniteScroll(infiniteScroll: LoadMoreMode) {\n    this.infiniteScroll = infiniteScroll;\n    if (infiniteScroll) {\n      this.pagination = this.deviceGridService.getInfiniteScrollPagination();\n    }\n  }\n  /** Sets action controls (actions available for individual items). If not given, it defaults to standard actions. */\n  @Input('actionControls') set _actionControls(value: ActionControl[]) {\n    this.actionControls = value;\n  }\n  /** Determines whether items can be selected by clicking a checkbox in the first column. */\n  @Input() selectable = false;\n  /** Restricts selection to a single row only. Selection column displays radio button instead of checkboxes */\n  @Input() singleSelection = false;\n  /** Sets the base query which is appended to the request for data. */\n  @Input() baseQuery: object = {};\n  /** Sets bulk action controls (actions available for items selected by user). If not given, it defaults to standard bulk actions. */\n  @Input('bulkActionControls') set _bulkActionControls(value: BulkActionControl[]) {\n    if (value) {\n      this.bulkActionControls = value;\n    } else {\n      this.bulkActionControls = this.deviceGridService.getDefaultBulkActionControls();\n    }\n  }\n  /** Sets header action controls (actions available from the grid header). If not given, it defaults to empty list of actions. */\n  @Input('headerActionControls') set _headerActionControls(value: HeaderActionControl[]) {\n    if (value) {\n      this.headerActionControls = value;\n    } else {\n      this.headerActionControls = this.deviceGridService.getDefaultHeaderActionControls();\n    }\n  }\n  @Input() childDeviceGrid = false;\n  @Input() parentDeviceId: string;\n  /** Sets the withChildren query which is appended to the request. */\n  @Input() withChildren = false;\n  /**\n   * Enables the search for devices where any device propery is matched agains the search term.\n   * Enabled by default. This input does not take effect if the <code>childDeviceGrid</code> input is set to <code>true</code>\n   */\n  @Input() showSearch = true;\n  /**\n   * Sets the class name used for active rows (last clicked).\n   * Set empty string to disable appending active class to grid rows.\n   */\n  @Input()\n  activeClassName = 'active';\n  /** Emits an event when columns configuration changes. */\n  @Output() onColumnsChange: EventEmitter<Column[]> = new EventEmitter<Column[]>();\n  @Output() onFilterChange: EventEmitter<FilterConfig[]> = new EventEmitter<FilterConfig[]>();\n  @Output() onDeviceQueryStringChange: EventEmitter<string> = new EventEmitter<string>();\n  /** Emits an event when items selection changes. The array contains ids of selected items. */\n  @Output() itemsSelect = new EventEmitter<string[]>();\n\n  actionControls: ActionControl[] = [];\n  appliedFilters: FilterConfig[] = [];\n  pagination: Pagination = this.deviceGridService.getDefaultPagination();\n  bulkActionControls: BulkActionControl[] = this.deviceGridService.getDefaultBulkActionControls();\n  headerActionControls: HeaderActionControl[] =\n    this.deviceGridService.getDefaultHeaderActionControls();\n  serverSideDataCallback: ServerSideDataCallback;\n\n  @ViewChild(DataGridComponent, { static: true })\n  dataGrid: DataGridComponent;\n  productExperienceEvent: ProductExperienceEvent;\n\n  noResultsMessage = gettext('No matching devices.');\n  noDataMessage = gettext('No devices to display.');\n  noResultsSubtitle = gettext('Refine your search terms');\n\n  private destroyed$: Subject<void> = new Subject();\n\n  constructor(public deviceGridService: DeviceGridService) {\n    this.serverSideDataCallback = this.onDataSourceModifier.bind(this);\n  }\n\n  ngOnDestroy(): void {\n    this.destroyed$.next();\n    this.destroyed$.complete();\n  }\n\n  trackByName(_index, column: Column): string {\n    return column.name;\n  }\n\n  async onDataSourceModifier(\n    dataSourceModifier: DataSourceModifier\n  ): Promise<ServerSideDataResult> {\n    let serverSideDataResult: ServerSideDataResult;\n    let filteredSize: number;\n    let size: number;\n    if (this.childDeviceGrid) {\n      const { res, data, paging } = await alertOnError(\n        this.deviceGridService.getChildDeviceData(\n          dataSourceModifier.columns,\n          dataSourceModifier.pagination,\n          this.baseQuery,\n          this.withChildren,\n          this.parentDeviceId\n        )\n      );\n\n      filteredSize = await alertOnError(\n        this.deviceGridService.getCountChildDevices(\n          dataSourceModifier.columns,\n          dataSourceModifier.pagination,\n          this.baseQuery,\n          this.parentDeviceId\n        )\n      );\n      size = await alertOnError(\n        this.deviceGridService.getTotalChildDevices(this.baseQuery, this.parentDeviceId)\n      );\n\n      serverSideDataResult = {\n        res,\n        data,\n        paging,\n        filteredSize,\n        size\n      };\n    } else {\n      const { res, data, paging } = await alertOnError(\n        this.deviceGridService.getData(\n          dataSourceModifier.columns,\n          dataSourceModifier.pagination,\n          this.baseQuery,\n          this.withChildren,\n          dataSourceModifier.searchText\n        )\n      );\n\n      filteredSize = await alertOnError(\n        this.deviceGridService.getCount(\n          dataSourceModifier.columns,\n          dataSourceModifier.pagination,\n          this.baseQuery,\n          dataSourceModifier.searchText\n        )\n      );\n      size = await alertOnError(this.deviceGridService.getTotal(this.baseQuery));\n\n      serverSideDataResult = {\n        res,\n        data,\n        paging,\n        filteredSize,\n        size\n      };\n    }\n\n    this.onColumnsChange.emit(dataSourceModifier.columns);\n    this.onDeviceQueryStringChange.emit(\n      this.deviceGridService.getDeviceQueryString(dataSourceModifier.columns, this.baseQuery)\n    );\n\n    if (this.dataCallback) {\n      serverSideDataResult = this.dataCallback(serverSideDataResult);\n    }\n\n    return serverSideDataResult;\n  }\n\n  updateFiltering(\n    columnNames: string[],\n    action: {\n      type: FilteringActionType;\n      payload?: { filteringModifier: FilteringModifier };\n    }\n  ) {\n    const { type } = action;\n    if (type === FilteringActionType.ResetFilter) {\n      this.dataGrid.clearFilters();\n    } else {\n      this.dataGrid.updateFiltering(columnNames, action);\n    }\n  }\n}\n","<c8y-data-grid\n  [title]=\"title\"\n  [loadMoreItemsLabel]=\"loadMoreItemsLabel\"\n  [loadingItemsLabel]=\"loadingItemsLabel\"\n  [columns]=\"columns\"\n  [pagination]=\"pagination\"\n  [infiniteScroll]=\"infiniteScroll\"\n  [actionControls]=\"actionControls\"\n  [selectable]=\"selectable\"\n  [singleSelection]=\"singleSelection\"\n  [bulkActionControls]=\"bulkActionControls\"\n  [serverSideDataCallback]=\"serverSideDataCallback\"\n  (itemsSelect)=\"itemsSelect.emit($event)\"\n  [refresh]=\"refresh\"\n  [showSearch]=\"showSearch && !childDeviceGrid\"\n  [headerActionControls]=\"headerActionControls\"\n  [activeClassName]=\"activeClassName\"\n  c8yProductExperience\n  inherit\n>\n  <c8y-ui-empty-state\n    [icon]=\"stats?.size > 0 ? 'search' : 'c8y-device-management'\"\n    [title]=\"stats?.size > 0 ? (noResultsMessage | translate) : (noDataMessage | translate)\"\n    [subtitle]=\"stats?.size > 0 ? (noResultsSubtitle | translate) : null\"\n    *emptyStateContext=\"let stats\"\n    [horizontal]=\"stats?.size > 0\"\n  ></c8y-ui-empty-state>\n\n  <ng-container *ngFor=\"let column of columns; trackBy: trackByName\">\n    <c8y-column [name]=\"column.name\"></c8y-column>\n  </ng-container>\n</c8y-data-grid>\n"]}