UNPKG

@c8y/ngx-components

Version:

Angular modules for Cumulocity IoT applications

242 lines 36.7 kB
import { Component, EventEmitter, Inject, Input, Optional, Output, ViewChild } from '@angular/core'; import { SmartGroupsService } from '@c8y/client'; import { BuiltInActionType, DATA_GRID_CONFIGURATION_CONTEXT_PROVIDER, DATA_GRID_CONFIGURATION_STRATEGY, DataGridComponent, FilteringActionType, SearchFilters, UserPreferencesConfigurationStrategy, gettext } from '@c8y/ngx-components'; import { AlarmsDeviceGridColumn, ImeiDeviceGridColumn, ModelDeviceGridColumn, NameDeviceGridColumn, RegistrationDateDeviceGridColumn, SerialNumberDeviceGridColumn, SystemIdDeviceGridColumn } from '@c8y/ngx-components/device-grid'; import { DeleteAssetsModalComponent, SubAssetsService } from '@c8y/ngx-components/sub-assets'; import { BsModalService } from 'ngx-bootstrap/modal'; import { AssetTypeSearchGridColumn } from './columns/asset-type-search-grid-column'; import { SEARCH_CONFIG } from './search-config.model'; import { AssetSearchService } from './search.service'; import * as i0 from "@angular/core"; import * as i1 from "./search.service"; import * as i2 from "ngx-bootstrap/modal"; import * as i3 from "@c8y/client"; import * as i4 from "@c8y/ngx-components/sub-assets"; import * as i5 from "@c8y/ngx-components"; import * as i6 from "@angular/common"; export class SearchGridComponent { set _columns(value) { if (value) { this.columns = value; } else { this.columns = this.assetSearchService.getDefaultColumns(); } } set _pagination(value) { if (value) { this.pagination = value; } } set _actionControls(value) { if (value) { this.actionControls = value; } else { this.actionControls = this.assetSearchService.getDefaultActionControls(); } } set _bulkActionControls(value) { if (value) { this.bulkActionControls = value; } else { this.bulkActionControls = this.assetSearchService.getDefaultBulkActionControls(); } } constructor(assetSearchService, bsModalService, smartGroupsService, subAssetsGridService, moduleConfig) { this.assetSearchService = assetSearchService; this.bsModalService = bsModalService; this.smartGroupsService = smartGroupsService; this.subAssetsGridService = subAssetsGridService; this.moduleConfig = moduleConfig; this.title = ''; this.loadingItemsLabel = gettext('Loading results…'); this.selectable = false; this.onColumnsChange = new EventEmitter(); this.searchText = ''; this.pagination = this.assetSearchService.getDefaultPagination(); this.bulkActionControls = this.assetSearchService.getDefaultBulkActionControls(); this.refresh = new EventEmitter(); this.sizeCount = 0; this.showAdvancedFilters = moduleConfig?.showAdvancedFilters ?? false; this.customPlaceholder = moduleConfig?.placeholder ?? undefined; } getGridConfigContext() { return { key: this.columnsConfigKey || this.assetSearchService.GRID_CONFIG_STORAGE_KEY }; } ngOnInit() { if (!this.filteringName) { this.columns = [ new AssetTypeSearchGridColumn(this.showAdvancedFilters, { sortOrder: 'desc' }, this.assetSearchService, this.customPlaceholder), ...this.assetSearchService.getDefaultColumns() ]; } else { this.columns = [ new AssetTypeSearchGridColumn(this.showAdvancedFilters, { sortOrder: 'desc' }, this.assetSearchService), new NameDeviceGridColumn({ sortOrder: 'asc', filter: { externalFilterQuery: { names: [this.filteringName] } } }), new ModelDeviceGridColumn(), new SerialNumberDeviceGridColumn({ visible: false }), new RegistrationDateDeviceGridColumn({ visible: false }), new SystemIdDeviceGridColumn({ visible: false }), new ImeiDeviceGridColumn({ visible: false }), new AlarmsDeviceGridColumn() ]; } this.serverSideDataCallback = this.onDataSourceModifier.bind(this); this.setActionControls(); } ngAfterViewInit() { this.setInitialFilterForTypeColumn(); } trackByName(_index, column) { return column.name; } async onDataSourceModifier(dataSourceModifier) { const response = await this.assetSearchService.getData(dataSourceModifier.columns, dataSourceModifier.pagination, dataSourceModifier.searchText); const { res, data, paging } = response; if (paging.currentPage === 1) { this.sizeCount = 0; } this.sizeCount += data.length; this.onColumnsChange.emit(dataSourceModifier.columns); return { res, data, paging, filteredSize: this.sizeCount, size: undefined }; } setActionControls() { const actionControls = []; const deleteAction = { type: BuiltInActionType.Delete, callback: (asset) => this.onDeleteAsset(asset, this.parentGroup) }; actionControls.push(deleteAction); if (!this.actionControls) { this.actionControls = actionControls; } } updateFiltering(columnNames, action) { const { type } = action; if (type === FilteringActionType.ResetFilter) { this.dataGrid.clearFilters(); } else { /** * TODO: find better solution. After new changes from DM team, we're running into race condition where * this.dataGrid.updateFiltering is executed before this.configurationStrategy.getConfig$() value is emitted. * Columns setter sets columns after this.dataGrid.updateFiltering executes its logic. Value of this.columns in * dataGrid.updateFiltering is just not yet set. */ setTimeout(() => { this.dataGrid.updateFiltering(columnNames, action, false); }, 500); } } onColumnFilterReset(column) { if (column.name === 'type') { this.assetSearchService.resetAppliedFilters(); } } onDeleteAsset(asset, parentRef) { const initialState = { showWithDeviceUserCheckbox: this.subAssetsGridService.shouldShowWithDeviceUserCheckbox(asset), asset, showWithCascadeCheckbox: !this.smartGroupsService.isSmartGroup(asset) }; const modalRef = this.bsModalService.show(DeleteAssetsModalComponent, { initialState }); modalRef.content.closeSubject.subscribe(async (result) => { if (result) { await this.subAssetsGridService.deleteAsset(asset, parentRef, result); this.refresh.emit(); } }); } setInitialFilterForTypeColumn() { const checkboxes = this.assetSearchService.appliedFilters$.value; // Set filter only when all checkboxes are not selected if (checkboxes[SearchFilters.ONLY_DEVICES] !== checkboxes[SearchFilters.ONLY_GROUPS_AND_ASSETS]) { const externalFilterQuery = { [SearchFilters.ONLY_DEVICES]: checkboxes[SearchFilters.ONLY_DEVICES], [SearchFilters.ONLY_GROUPS_AND_ASSETS]: checkboxes[SearchFilters.ONLY_GROUPS_AND_ASSETS] }; this.updateFiltering(['type'], { type: FilteringActionType.ApplyFilter, payload: { filteringModifier: { externalFilterQuery } } }); } } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SearchGridComponent, deps: [{ token: i1.AssetSearchService }, { token: i2.BsModalService }, { token: i3.SmartGroupsService }, { token: i4.SubAssetsService }, { token: SEARCH_CONFIG, optional: true }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: SearchGridComponent, selector: "c8y-search-grid", inputs: { parentGroup: ["parent-group", "parentGroup"], title: "title", loadingItemsLabel: "loadingItemsLabel", _columns: ["columns", "_columns"], _pagination: ["pagination", "_pagination"], _actionControls: ["actionControls", "_actionControls"], selectable: "selectable", _bulkActionControls: ["bulkActionControls", "_bulkActionControls"], searchText: "searchText", filteringName: "filteringName", columnsConfigKey: "columnsConfigKey" }, outputs: { onColumnsChange: "onColumnsChange" }, providers: [ { provide: DATA_GRID_CONFIGURATION_STRATEGY, useClass: UserPreferencesConfigurationStrategy }, { provide: DATA_GRID_CONFIGURATION_CONTEXT_PROVIDER, useExisting: SearchGridComponent } ], viewQueries: [{ propertyName: "dataGrid", first: true, predicate: DataGridComponent, descendants: true, static: true }], ngImport: i0, template: "<div class=\"card--grid--fullpage border-top border-bottom\">\n <c8y-data-grid\n [title]=\"'Search results' | translate\"\n [loadingItemsLabel]=\"loadingItemsLabel\"\n [columns]=\"columns\"\n [pagination]=\"pagination\"\n [actionControls]=\"actionControls\"\n [selectable]=\"selectable\"\n [bulkActionControls]=\"bulkActionControls\"\n [serverSideDataCallback]=\"serverSideDataCallback\"\n [infiniteScroll]=\"'auto'\"\n [showSearch]=\"true\"\n [searchText]=\"searchText\"\n [refresh]=\"refresh\"\n (onColumnFilterReset)=\"onColumnFilterReset($event)\"\n >\n <ng-container *ngFor=\"let column of columns; trackBy: trackByName\">\n <c8y-column [name]=\"column.name\"></c8y-column>\n </ng-container>\n\n <c8y-ui-empty-state\n [icon]=\"'search'\"\n [title]=\"'No results to display.' | translate\"\n [subtitle]=\"'Refine your search terms or check your spelling.' | translate\"\n [horizontal]=\"true\"\n ></c8y-ui-empty-state>\n </c8y-data-grid>\n</div>", dependencies: [{ kind: "component", type: i5.EmptyStateComponent, selector: "c8y-ui-empty-state", inputs: ["icon", "title", "subtitle", "horizontal"] }, { kind: "directive", type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i5.ColumnDirective, selector: "c8y-column", inputs: ["name"] }, { kind: "component", type: i5.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: "pipe", type: i5.C8yTranslatePipe, name: "translate" }] }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SearchGridComponent, decorators: [{ type: Component, args: [{ selector: 'c8y-search-grid', providers: [ { provide: DATA_GRID_CONFIGURATION_STRATEGY, useClass: UserPreferencesConfigurationStrategy }, { provide: DATA_GRID_CONFIGURATION_CONTEXT_PROVIDER, useExisting: SearchGridComponent } ], template: "<div class=\"card--grid--fullpage border-top border-bottom\">\n <c8y-data-grid\n [title]=\"'Search results' | translate\"\n [loadingItemsLabel]=\"loadingItemsLabel\"\n [columns]=\"columns\"\n [pagination]=\"pagination\"\n [actionControls]=\"actionControls\"\n [selectable]=\"selectable\"\n [bulkActionControls]=\"bulkActionControls\"\n [serverSideDataCallback]=\"serverSideDataCallback\"\n [infiniteScroll]=\"'auto'\"\n [showSearch]=\"true\"\n [searchText]=\"searchText\"\n [refresh]=\"refresh\"\n (onColumnFilterReset)=\"onColumnFilterReset($event)\"\n >\n <ng-container *ngFor=\"let column of columns; trackBy: trackByName\">\n <c8y-column [name]=\"column.name\"></c8y-column>\n </ng-container>\n\n <c8y-ui-empty-state\n [icon]=\"'search'\"\n [title]=\"'No results to display.' | translate\"\n [subtitle]=\"'Refine your search terms or check your spelling.' | translate\"\n [horizontal]=\"true\"\n ></c8y-ui-empty-state>\n </c8y-data-grid>\n</div>" }] }], ctorParameters: () => [{ type: i1.AssetSearchService }, { type: i2.BsModalService }, { type: i3.SmartGroupsService }, { type: i4.SubAssetsService }, { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [SEARCH_CONFIG] }] }], propDecorators: { parentGroup: [{ type: Input, args: ['parent-group'] }], title: [{ type: Input }], loadingItemsLabel: [{ type: Input }], _columns: [{ type: Input, args: ['columns'] }], _pagination: [{ type: Input, args: ['pagination'] }], _actionControls: [{ type: Input, args: ['actionControls'] }], selectable: [{ type: Input }], _bulkActionControls: [{ type: Input, args: ['bulkActionControls'] }], onColumnsChange: [{ type: Output }], searchText: [{ type: Input }], filteringName: [{ type: Input }], columnsConfigKey: [{ type: Input }], dataGrid: [{ type: ViewChild, args: [DataGridComponent, { static: true }] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"search-grid.component.js","sourceRoot":"","sources":["../../../search/search-grid.component.ts","../../../search/search-grid.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Inject, Input, Optional, Output, ViewChild } from '@angular/core';\nimport { IManagedObject, SmartGroupsService } from '@c8y/client';\nimport {\n  ActionControl,\n  BuiltInActionType,\n  BulkActionControl,\n  Column,\n  DATA_GRID_CONFIGURATION_CONTEXT_PROVIDER,\n  DATA_GRID_CONFIGURATION_STRATEGY,\n  DataGridComponent,\n  DataSourceModifier,\n  FilteringActionType,\n  FilteringModifier,\n  GridConfigContextProvider,\n  Pagination,\n  Row,\n  SearchFilters,\n  ServerSideDataResult,\n  UserPreferencesConfigurationStrategy,\n  UserPreferencesGridConfigContext,\n  gettext\n} from '@c8y/ngx-components';\nimport {\n  AlarmsDeviceGridColumn,\n  ImeiDeviceGridColumn,\n  ModelDeviceGridColumn,\n  NameDeviceGridColumn,\n  RegistrationDateDeviceGridColumn,\n  SerialNumberDeviceGridColumn,\n  SystemIdDeviceGridColumn\n} from '@c8y/ngx-components/device-grid';\nimport {\n  DeleteAssetsModalComponent,\n  DeleteModalCheckboxes,\n  SubAssetsService\n} from '@c8y/ngx-components/sub-assets';\nimport { BsModalService } from 'ngx-bootstrap/modal';\nimport { AssetTypeSearchGridColumn } from './columns/asset-type-search-grid-column';\nimport { SEARCH_CONFIG, SearchConfig } from './search-config.model';\nimport { AssetSearchService } from './search.service';\n\n@Component({\n  selector: 'c8y-search-grid',\n  templateUrl: './search-grid.component.html',\n  providers: [\n    {\n      provide: DATA_GRID_CONFIGURATION_STRATEGY,\n      useClass: UserPreferencesConfigurationStrategy\n    },\n    {\n      provide: DATA_GRID_CONFIGURATION_CONTEXT_PROVIDER,\n      useExisting: SearchGridComponent\n    }\n  ]\n})\nexport class SearchGridComponent implements GridConfigContextProvider {\n  @Input('parent-group') parentGroup: IManagedObject;\n  @Input() title = '';\n  @Input() loadingItemsLabel: string = gettext('Loading results…');\n  @Input('columns') set _columns(value: Column[]) {\n    if (value) {\n      this.columns = value;\n    } else {\n      this.columns = this.assetSearchService.getDefaultColumns();\n    }\n  }\n  @Input('pagination') set _pagination(value: Pagination) {\n    if (value) {\n      this.pagination = value;\n    }\n  }\n  @Input('actionControls') set _actionControls(value: ActionControl[]) {\n    if (value) {\n      this.actionControls = value;\n    } else {\n      this.actionControls = this.assetSearchService.getDefaultActionControls();\n    }\n  }\n  @Input() selectable = false;\n  @Input('bulkActionControls') set _bulkActionControls(value: BulkActionControl[]) {\n    if (value) {\n      this.bulkActionControls = value;\n    } else {\n      this.bulkActionControls = this.assetSearchService.getDefaultBulkActionControls();\n    }\n  }\n  @Output() onColumnsChange: EventEmitter<Column[]> = new EventEmitter<Column[]>();\n\n  @Input()\n  searchText = '';\n\n  @Input()\n  filteringName: string;\n\n  /** The name of the key where columns configuration will be stored. */\n  @Input() columnsConfigKey: string;\n\n  columns: Column[];\n  pagination: Pagination = this.assetSearchService.getDefaultPagination();\n  actionControls: ActionControl[];\n  bulkActionControls: BulkActionControl[] = this.assetSearchService.getDefaultBulkActionControls();\n  showAdvancedFilters: boolean;\n  customPlaceholder: string;\n  serverSideDataCallback: any;\n  refresh: EventEmitter<any> = new EventEmitter();\n\n  @ViewChild(DataGridComponent, { static: true })\n  dataGrid: DataGridComponent;\n\n  private sizeCount = 0;\n\n  constructor(\n    public assetSearchService: AssetSearchService,\n    private bsModalService: BsModalService,\n    private smartGroupsService: SmartGroupsService,\n    private subAssetsGridService: SubAssetsService,\n    @Optional() @Inject(SEARCH_CONFIG) public moduleConfig: SearchConfig\n  ) {\n    this.showAdvancedFilters = moduleConfig?.showAdvancedFilters ?? false;\n    this.customPlaceholder = moduleConfig?.placeholder ?? undefined;\n  }\n\n  getGridConfigContext(): UserPreferencesGridConfigContext {\n    return { key: this.columnsConfigKey || this.assetSearchService.GRID_CONFIG_STORAGE_KEY };\n  }\n\n  ngOnInit(): void {\n    if (!this.filteringName) {\n      this.columns = [\n        new AssetTypeSearchGridColumn(\n          this.showAdvancedFilters,\n          { sortOrder: 'desc' },\n          this.assetSearchService,\n          this.customPlaceholder\n        ),\n        ...this.assetSearchService.getDefaultColumns()\n      ];\n    } else {\n      this.columns = [\n        new AssetTypeSearchGridColumn(\n          this.showAdvancedFilters,\n          { sortOrder: 'desc' },\n          this.assetSearchService\n        ),\n        new NameDeviceGridColumn({\n          sortOrder: 'asc',\n          filter: { externalFilterQuery: { names: [this.filteringName] } }\n        }),\n        new ModelDeviceGridColumn(),\n        new SerialNumberDeviceGridColumn({ visible: false }),\n        new RegistrationDateDeviceGridColumn({ visible: false }),\n        new SystemIdDeviceGridColumn({ visible: false }),\n        new ImeiDeviceGridColumn({ visible: false }),\n        new AlarmsDeviceGridColumn()\n      ];\n    }\n    this.serverSideDataCallback = this.onDataSourceModifier.bind(this);\n    this.setActionControls();\n  }\n\n  ngAfterViewInit() {\n    this.setInitialFilterForTypeColumn();\n  }\n\n  trackByName(_index, column: Column): string {\n    return column.name;\n  }\n\n  async onDataSourceModifier(\n    dataSourceModifier: DataSourceModifier\n  ): Promise<ServerSideDataResult> {\n    const response = await this.assetSearchService.getData(\n      dataSourceModifier.columns,\n      dataSourceModifier.pagination,\n      dataSourceModifier.searchText\n    );\n    const { res, data, paging } = response;\n\n    if (paging.currentPage === 1) {\n      this.sizeCount = 0;\n    }\n    this.sizeCount += data.length;\n    this.onColumnsChange.emit(dataSourceModifier.columns);\n\n    return {\n      res,\n      data,\n      paging,\n      filteredSize: this.sizeCount,\n      size: undefined\n    };\n  }\n\n  setActionControls() {\n    const actionControls: ActionControl[] = [];\n    const deleteAction: ActionControl = {\n      type: BuiltInActionType.Delete,\n      callback: (asset: Row) => this.onDeleteAsset(asset as IManagedObject, this.parentGroup)\n    };\n    actionControls.push(deleteAction);\n    if (!this.actionControls) {\n      this.actionControls = actionControls;\n    }\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      /**\n       * TODO: find better solution. After new changes from DM team, we're running into race condition where\n       * this.dataGrid.updateFiltering is executed before this.configurationStrategy.getConfig$() value is emitted.\n       * Columns setter sets columns after this.dataGrid.updateFiltering executes its logic. Value of this.columns in\n       * dataGrid.updateFiltering is just not yet set.\n       */\n      setTimeout(() => {\n        this.dataGrid.updateFiltering(columnNames, action, false);\n      }, 500);\n    }\n  }\n\n  onColumnFilterReset(column: Column) {\n    if (column.name === 'type') {\n      this.assetSearchService.resetAppliedFilters();\n    }\n  }\n\n  private onDeleteAsset(asset, parentRef) {\n    const initialState = {\n      showWithDeviceUserCheckbox: this.subAssetsGridService.shouldShowWithDeviceUserCheckbox(asset),\n      asset,\n      showWithCascadeCheckbox: !this.smartGroupsService.isSmartGroup(asset)\n    };\n\n    const modalRef = this.bsModalService.show(DeleteAssetsModalComponent, { initialState });\n\n    modalRef.content.closeSubject.subscribe(async (result: DeleteModalCheckboxes) => {\n      if (result) {\n        await this.subAssetsGridService.deleteAsset(asset, parentRef, result);\n        this.refresh.emit();\n      }\n    });\n  }\n\n  private setInitialFilterForTypeColumn() {\n    const checkboxes = this.assetSearchService.appliedFilters$.value;\n    // Set filter only when all checkboxes are not selected\n    if (\n      checkboxes[SearchFilters.ONLY_DEVICES] !== checkboxes[SearchFilters.ONLY_GROUPS_AND_ASSETS]\n    ) {\n      const externalFilterQuery = {\n        [SearchFilters.ONLY_DEVICES]: checkboxes[SearchFilters.ONLY_DEVICES],\n        [SearchFilters.ONLY_GROUPS_AND_ASSETS]: checkboxes[SearchFilters.ONLY_GROUPS_AND_ASSETS]\n      };\n      this.updateFiltering(['type'], {\n        type: FilteringActionType.ApplyFilter,\n        payload: {\n          filteringModifier: {\n            externalFilterQuery\n          }\n        }\n      });\n    }\n  }\n}\n","<div class=\"card--grid--fullpage border-top border-bottom\">\n  <c8y-data-grid\n    [title]=\"'Search results' | translate\"\n    [loadingItemsLabel]=\"loadingItemsLabel\"\n    [columns]=\"columns\"\n    [pagination]=\"pagination\"\n    [actionControls]=\"actionControls\"\n    [selectable]=\"selectable\"\n    [bulkActionControls]=\"bulkActionControls\"\n    [serverSideDataCallback]=\"serverSideDataCallback\"\n    [infiniteScroll]=\"'auto'\"\n    [showSearch]=\"true\"\n    [searchText]=\"searchText\"\n    [refresh]=\"refresh\"\n    (onColumnFilterReset)=\"onColumnFilterReset($event)\"\n  >\n    <ng-container *ngFor=\"let column of columns; trackBy: trackByName\">\n      <c8y-column [name]=\"column.name\"></c8y-column>\n    </ng-container>\n\n    <c8y-ui-empty-state\n      [icon]=\"'search'\"\n      [title]=\"'No results to display.' | translate\"\n      [subtitle]=\"'Refine your search terms or check your spelling.' | translate\"\n      [horizontal]=\"true\"\n    ></c8y-ui-empty-state>\n  </c8y-data-grid>\n</div>"]}