cps-ui-kit 0.118.0 → 0.120.0
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.
- package/esm2020/lib/components/cps-table/cps-table.component.mjs +10 -4
- package/esm2020/lib/components/cps-table/table-column-filter/table-column-filter.component.mjs +3 -3
- package/esm2020/lib/components/cps-tree-table/cps-tree-table.component.mjs +11 -5
- package/fesm2015/cps-ui-kit.mjs +21 -9
- package/fesm2015/cps-ui-kit.mjs.map +1 -1
- package/fesm2020/cps-ui-kit.mjs +21 -9
- package/fesm2020/cps-ui-kit.mjs.map +1 -1
- package/lib/components/cps-table/cps-table.component.d.ts +1 -0
- package/lib/components/cps-tree-table/cps-tree-table.component.d.ts +1 -0
- package/package.json +1 -1
|
@@ -182,11 +182,14 @@ export class CpsTreeTableComponent {
|
|
|
182
182
|
this.cdRef.detectChanges();
|
|
183
183
|
}
|
|
184
184
|
ngOnChanges(changes) {
|
|
185
|
-
if (this.loading
|
|
186
|
-
this.
|
|
185
|
+
if (this.loading) {
|
|
186
|
+
this.clearSelection();
|
|
187
|
+
if (this.clearGlobalFilterOnLoading)
|
|
188
|
+
this.clearGlobalFilter();
|
|
189
|
+
}
|
|
187
190
|
const dataChanges = changes?.data;
|
|
188
191
|
if (dataChanges?.previousValue !== dataChanges?.currentValue) {
|
|
189
|
-
this.
|
|
192
|
+
this.clearSelection();
|
|
190
193
|
}
|
|
191
194
|
}
|
|
192
195
|
ngOnDestroy() {
|
|
@@ -281,12 +284,15 @@ export class CpsTreeTableComponent {
|
|
|
281
284
|
this.selectedRows.forEach((row) => this._removeNodeFromData(row, false));
|
|
282
285
|
this.data = [...this.data];
|
|
283
286
|
this.rowsRemoved.emit(this.selectedRows);
|
|
284
|
-
this.
|
|
287
|
+
this.clearSelection();
|
|
285
288
|
setTimeout(() => {
|
|
286
289
|
this._recalcVirtualHeight();
|
|
287
290
|
this.cdRef.markForCheck();
|
|
288
291
|
});
|
|
289
292
|
}
|
|
293
|
+
clearSelection() {
|
|
294
|
+
this.selectedRows = [];
|
|
295
|
+
}
|
|
290
296
|
onEditRowClicked(node) {
|
|
291
297
|
this.editRowBtnClicked.emit(node);
|
|
292
298
|
}
|
|
@@ -637,4 +643,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
|
|
|
637
643
|
type: ViewChild,
|
|
638
644
|
args: ['colToggleMenu']
|
|
639
645
|
}] } });
|
|
640
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cps-tree-table.component.js","sourceRoot":"","sources":["../../../../../../projects/cps-ui-kit/src/lib/components/cps-tree-table/cps-tree-table.component.ts","../../../../../../projects/cps-ui-kit/src/lib/components/cps-tree-table/cps-tree-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewChecked,\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  SimpleChanges,\n  TemplateRef,\n  ViewChild\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FormsModule } from '@angular/forms';\nimport {\n  TreeTable,\n  TreeTableService,\n  TreeTableModule\n} from 'primeng/treetable';\nimport { DomHandler } from 'primeng/dom';\nimport { AngleDoubleLeftIcon } from 'primeng/icons/angledoubleleft';\nimport { AngleLeftIcon } from 'primeng/icons/angleleft';\nimport { AngleRightIcon } from 'primeng/icons/angleright';\nimport { AngleDoubleRightIcon } from 'primeng/icons/angledoubleright';\nimport { SortEvent } from 'primeng/api';\nimport { find, isEqual } from 'lodash-es';\nimport { CpsInputComponent } from '../cps-input/cps-input.component';\nimport { CpsButtonComponent } from '../cps-button/cps-button.component';\nimport { CpsMenuComponent } from '../cps-menu/cps-menu.component';\nimport { CpsIconComponent } from '../cps-icon/cps-icon.component';\nimport { CpsSelectComponent } from '../cps-select/cps-select.component';\nimport { CpsLoaderComponent } from '../cps-loader/cps-loader.component';\nimport { CpsTreeTableColumnSortableDirective } from './directives/cps-tree-table-column-sortable.directive';\nimport { TreeTableUnsortDirective } from './directives/internal/tree-table-unsort.directive';\nimport { TableRowMenuComponent } from '../cps-table/table-row-menu/table-row-menu.component';\nimport { convertSize } from '../../utils/internal/size-utils';\n\nexport function treeTableFactory(tableComponent: CpsTreeTableComponent) {\n  return tableComponent.primengTreeTable;\n}\n\nexport type CpsTreeTableSize = 'small' | 'normal' | 'large';\nexport type CpsTreeTableToolbarSize = 'small' | 'normal';\nexport type CpsTreeTableSortMode = 'single' | 'multiple';\n@Component({\n  selector: 'cps-tree-table',\n  standalone: true,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [\n    FormsModule,\n    CommonModule,\n    TreeTableModule,\n    CpsInputComponent,\n    CpsButtonComponent,\n    CpsMenuComponent,\n    CpsIconComponent,\n    CpsSelectComponent,\n    CpsLoaderComponent,\n    AngleDoubleLeftIcon,\n    AngleLeftIcon,\n    AngleRightIcon,\n    AngleDoubleRightIcon,\n    CpsTreeTableColumnSortableDirective,\n    TreeTableUnsortDirective,\n    TableRowMenuComponent\n  ],\n  templateUrl: './cps-tree-table.component.html',\n  styleUrls: ['./cps-tree-table.component.scss'],\n  providers: [\n    TreeTableService,\n    {\n      provide: TreeTable,\n      useFactory: treeTableFactory,\n      // eslint-disable-next-line no-use-before-define\n      deps: [CpsTreeTableComponent]\n    }\n  ]\n})\nexport class CpsTreeTableComponent\n  implements OnInit, AfterViewInit, OnDestroy, AfterViewChecked, OnChanges\n{\n  @Input() data: any[] = [];\n  @Input() columns: { [key: string]: any }[] = [];\n  @Input() colHeaderName = 'header';\n  @Input() colFieldName = 'field';\n\n  @Input() striped = true;\n  @Input() bordered = true;\n  @Input() size: CpsTreeTableSize = 'normal';\n  @Input() selectable = false;\n  @Input() rowHover = true;\n  @Input() showRowMenu = false;\n  @Input() loading = false;\n\n  @Input() tableStyle = undefined;\n  @Input() tableStyleClass = '';\n\n  @Input() sortable = false; // makes all sortable if columns are provided\n  @Input() sortMode: CpsTreeTableSortMode = 'single';\n  @Input() customSort = false;\n\n  @Input() hasToolbar = true;\n  @Input() toolbarSize: CpsTreeTableToolbarSize = 'normal';\n  @Input() toolbarTitle = '';\n  @Input() toolbarIcon = '';\n  @Input() toolbarIconColor = '';\n\n  @Input() scrollable = true;\n  @Input() scrollHeight = ''; // 'flex' or value+'px'\n  @Input() virtualScroll = false; // works only if scrollable is true\n  @Input() numToleratedItems = 10;\n\n  @Input() paginator = false;\n  @Input() alwaysShowPaginator = true;\n  @Input() rowsPerPageOptions: number[] = [];\n  @Input() first = 0;\n  @Input() rows = 0;\n  @Input() resetPageOnRowsChange = false;\n  @Input() resetPageOnSort = true;\n  @Input() totalRecords = 0;\n\n  @Input() emptyMessage = 'No data';\n  @Input() emptyBodyHeight: number | string = '';\n\n  @Input() lazy = false;\n  @Input() lazyLoadOnInit = true;\n\n  @Input() showGlobalFilter = false;\n  @Input() globalFilterPlaceholder = 'Search';\n  @Input() globalFilterFields: string[] = [];\n  @Input() clearGlobalFilterOnLoading = false;\n\n  @Input() showRemoveBtnOnSelect = true;\n  @Input() removeBtnOnSelectDisabled = false;\n\n  @Input() showAdditionalBtnOnSelect = false;\n  @Input() additionalBtnOnSelectTitle = 'Select action';\n  @Input() additionalBtnOnSelectDisabled = false;\n\n  @Input() showActionBtn = false;\n  @Input() actionBtnTitle = 'Action';\n  @Input() actionBtnDisabled = false;\n\n  @Input() showDataReloadBtn = false;\n  @Input() dataReloadBtnDisabled = false;\n\n  @Input() showColumnsToggleBtn = false; // if external body template is provided, use columnsSelected event emitter\n  @Input() columnsToggleBtnDisabled = false;\n\n  @Output() selectionChanged = new EventEmitter<any[]>();\n  @Output() actionBtnClicked = new EventEmitter<void>();\n  @Output() additionalBtnOnSelectClicked = new EventEmitter<any[]>();\n  @Output() editRowBtnClicked = new EventEmitter<any>();\n  @Output() rowsRemoved = new EventEmitter<any[]>();\n  @Output() pageChanged = new EventEmitter<any>();\n  @Output() sorted = new EventEmitter<any>();\n  @Output() filtered = new EventEmitter<any>();\n  @Output() columnsSelected = new EventEmitter<{ [key: string]: any }[]>();\n  @Output() lazyLoaded = new EventEmitter<any>();\n  @Output() dataReloadBtnClicked = new EventEmitter<any>();\n  @Output() nodeExpanded = new EventEmitter<any>();\n  @Output() nodeCollapsed = new EventEmitter<any>();\n  @Output() nodeSelected = new EventEmitter<any>();\n  @Output() nodeUnselected = new EventEmitter<any>();\n\n  /**\n   * A function to implement custom sorting. customSort must be true.\n   * @param {any} any - sort meta.\n   * @group Emits\n   */\n  @Output() customSortFunction: EventEmitter<any> = new EventEmitter<any>();\n\n  @ContentChild('toolbar', { static: false })\n  public toolbarTemplate!: TemplateRef<any>;\n\n  @ContentChild('header', { static: false })\n  public headerTemplate!: TemplateRef<any>;\n\n  @ContentChild('nestedHeader', { static: false })\n  public nestedHeaderTemplate!: TemplateRef<any>;\n\n  @ContentChild('body', { static: false })\n  public bodyTemplate!: TemplateRef<any>;\n\n  @ViewChild('primengTreeTable', { static: true })\n  primengTreeTable!: TreeTable;\n\n  @ViewChild('globalFilterComp')\n  globalFilterComp!: CpsInputComponent;\n\n  @ViewChild('colToggleMenu')\n  colToggleMenu!: CpsMenuComponent;\n\n  selectedColumns: { [key: string]: any }[] = [];\n\n  rowOptions: { label: string; value: number }[] = [];\n\n  selectedRows: any[] = [];\n\n  virtualScrollItemSize = 0;\n  defScrollHeightPx = 0;\n  defScrollHeight = '';\n\n  resizeObserver: ResizeObserver;\n  headerBox: any;\n  scrollableBody: any;\n  scrollbarWidth = 0;\n\n  // eslint-disable-next-line no-useless-constructor\n  constructor(private cdRef: ChangeDetectorRef) {\n    this.resizeObserver = new ResizeObserver((entries) => {\n      entries.forEach((entry) => {\n        const body = entry.target;\n        const sbarVisible = body.scrollHeight > body.clientHeight;\n\n        let wScroll = sbarVisible ? this.scrollbarWidth : 0;\n        if (wScroll > 0) wScroll -= 1;\n\n        this.headerBox.style.paddingRight = `${wScroll}px`;\n        this.headerBox.style.borderRight =\n          wScroll > 0 ? '1px solid #d7d5d5' : 'unset';\n      });\n    });\n  }\n\n  ngOnInit(): void {\n    this.emptyBodyHeight = convertSize(this.emptyBodyHeight);\n    if (!this.scrollable) this.virtualScroll = false;\n\n    if (this.showAdditionalBtnOnSelect) this.showRemoveBtnOnSelect = false;\n\n    if (this.virtualScroll) {\n      this.defScrollHeight = this.scrollHeight;\n\n      if (this.defScrollHeight === 'flex')\n        window.addEventListener('resize', this._onWindowResize.bind(this));\n\n      if (this.defScrollHeight && this.defScrollHeight !== 'flex') {\n        this.defScrollHeightPx = parseInt(this.scrollHeight, 10);\n      }\n    }\n\n    if (this.paginator) {\n      if (this.rowsPerPageOptions.length < 1)\n        this.rowsPerPageOptions = [5, 10, 25, 50];\n\n      if (!this.rows) this.rows = this.rowsPerPageOptions[0];\n      else {\n        if (!this.rowsPerPageOptions.includes(this.rows)) {\n          throw new Error('rowsPerPageOptions must include rows');\n        }\n      }\n\n      this.rowOptions = this.rowsPerPageOptions.map((v) => ({\n        label: '' + v,\n        value: v\n      }));\n    }\n\n    if (\n      this.showGlobalFilter &&\n      this.globalFilterFields?.length < 1 &&\n      this.data?.length > 0\n    ) {\n      this.globalFilterFields = Object.keys(this.data[0].data);\n    }\n\n    this.selectedColumns = this.columns;\n  }\n\n  ngAfterViewInit(): void {\n    this.scrollableBody = this.primengTreeTable.el.nativeElement.querySelector(\n      '.p-treetable-scrollable-body'\n    );\n    if (this.scrollableBody) {\n      this.headerBox = this.primengTreeTable.el.nativeElement.querySelector(\n        '.p-treetable-scrollable-header-box'\n      );\n      if (this.virtualScroll && this.defScrollHeight === 'flex')\n        this.defScrollHeightPx = this.scrollableBody.clientHeight;\n\n      if (this.headerBox) {\n        this.scrollbarWidth = DomHandler.calculateScrollbarWidth();\n        this.resizeObserver.observe(this.scrollableBody);\n      }\n    }\n  }\n\n  ngAfterViewChecked() {\n    if (!this.virtualScroll || this.virtualScrollItemSize) return;\n    this.virtualScrollItemSize =\n      this.primengTreeTable?.el?.nativeElement\n        ?.querySelector('.p-treetable-tbody')\n        ?.querySelector('tr')?.clientHeight || 0;\n    this.cdRef.detectChanges();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (this.loading && this.clearGlobalFilterOnLoading)\n      this.clearGlobalFilter();\n\n    const dataChanges = changes?.data;\n    if (dataChanges?.previousValue !== dataChanges?.currentValue) {\n      this.selectedRows = [];\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.resizeObserver?.disconnect();\n    if (this.virtualScroll && this.defScrollHeight === 'flex')\n      window.removeEventListener('resize', this._onWindowResize.bind(this));\n  }\n\n  clearGlobalFilter() {\n    this.globalFilterComp?.clear();\n  }\n\n  private _onWindowResize() {\n    this.defScrollHeightPx = this.scrollableBody.clientHeight;\n  }\n\n  get styleClass() {\n    const classesList = [];\n    switch (this.size) {\n      case 'small':\n        classesList.push('p-treetable-sm');\n        break;\n      case 'large':\n        classesList.push('p-treetable-lg');\n        break;\n    }\n    if (this.hasToolbar) {\n      switch (this.toolbarSize) {\n        case 'small':\n          classesList.push('cps-tbar-small');\n          break;\n        case 'normal':\n          classesList.push('cps-tbar-normal');\n          break;\n      }\n    }\n    if (this.striped) {\n      classesList.push('p-treetable-striped');\n    }\n    if (this.bordered) {\n      classesList.push('p-treetable-gridlines');\n    }\n\n    if (this.scrollHeight && !this.loading && this.data.length > 0) {\n      classesList.push('cps-treetable-bottom-bordered');\n    }\n\n    return classesList.join(' ');\n  }\n\n  onSortFunction(event: SortEvent) {\n    this.customSortFunction.emit(event);\n  }\n\n  private _recalcVirtualHeight() {\n    if (this.virtualScroll && this.defScrollHeight) {\n      const itemsLen = this.primengTreeTable.serializedValue.length;\n      if (itemsLen < 1) {\n        this.scrollHeight = this.emptyBodyHeight\n          ? (`calc(${this.emptyBodyHeight} + 1px)` as string)\n          : this.virtualScrollItemSize + 1 + 'px';\n      } else {\n        const curHeight = this.virtualScrollItemSize * itemsLen + 2;\n        if (this.defScrollHeight === 'flex') {\n          if (curHeight >= this.defScrollHeightPx) {\n            this.scrollHeight = 'flex';\n            setTimeout(() => {\n              this.scrollableBody.style.height = '100%';\n              this.cdRef.markForCheck();\n            });\n            return;\n          }\n        }\n        this.scrollHeight = Math.min(this.defScrollHeightPx, curHeight) + 'px';\n      }\n    }\n  }\n\n  onFilterGlobal(value: string) {\n    this.primengTreeTable.filterGlobal(value, 'contains');\n  }\n\n  onClickAdditionalBtnOnSelect() {\n    this.additionalBtnOnSelectClicked.emit(this.selectedRows);\n  }\n\n  onClickActionBtn() {\n    this.actionBtnClicked.emit();\n  }\n\n  onReloadData() {\n    if (this.dataReloadBtnDisabled) return;\n    this.dataReloadBtnClicked.emit();\n  }\n\n  onColumnsToggle(event: any) {\n    if (this.columnsToggleBtnDisabled) return;\n    this.colToggleMenu?.toggle(event);\n  }\n\n  removeSelected() {\n    this.selectedRows.forEach((row) => this._removeNodeFromData(row, false));\n    this.data = [...this.data];\n    this.rowsRemoved.emit(this.selectedRows);\n    this.selectedRows = [];\n    setTimeout(() => {\n      this._recalcVirtualHeight();\n      this.cdRef.markForCheck();\n    });\n  }\n\n  onEditRowClicked(node: any) {\n    this.editRowBtnClicked.emit(node);\n  }\n\n  onRemoveRowClicked(node: any) {\n    this.selectedRows = this.selectedRows.filter((v: any) => v !== node);\n    this._removeNodeFromData(node);\n    this.rowsRemoved.emit([node]);\n    setTimeout(() => {\n      this._recalcVirtualHeight();\n      this.cdRef.markForCheck();\n    });\n  }\n\n  private _removeNodeFromData(nodeToRemove: any, single = true): void {\n    const _findTopSortOrder = (_node: any): any => {\n      if (!_node) return undefined;\n      if (typeof _node._defaultSortOrder === 'number')\n        return _node._defaultSortOrder;\n      return _findTopSortOrder(_node.parent);\n    };\n\n    const _removeFromChildren = (_node: any) => {\n      if (!_node?.children) return false;\n      const idx = _node.children.indexOf(nodeToRemove);\n      if (idx >= 0) {\n        _node.children.splice(idx, 1);\n        if (_node.children.length === 0) {\n          delete _node.children;\n        }\n        return true;\n      } else {\n        for (const child of _node.children) {\n          if (_removeFromChildren(child)) return true;\n        }\n        return false;\n      }\n    };\n\n    // locate top level node\n    const sortOrder = _findTopSortOrder(nodeToRemove);\n    if (sortOrder === undefined) return;\n    const node = this.data.find((n) => n._defaultSortOrder === sortOrder);\n    if (!node) return;\n\n    // remove the node itself or remove its child\n    if (nodeToRemove === node) {\n      this.data = this.data.filter((v: any) => v !== nodeToRemove);\n    } else {\n      if (node.children) {\n        _removeFromChildren(node);\n        if (single) this.data = [...this.data];\n      }\n    }\n  }\n\n  toggleAllColumns() {\n    this.selectedColumns =\n      this.selectedColumns.length < this.columns.length ? this.columns : [];\n    this.columnsSelected.emit(this.selectedColumns);\n  }\n\n  isColumnSelected(col: any) {\n    return !!find(this.selectedColumns, (item) => isEqual(item, col));\n  }\n\n  onRowsPerPageChanged() {\n    if (this.resetPageOnRowsChange) {\n      this.primengTreeTable.first = 0;\n    }\n    this.changePage(this.getPage());\n  }\n\n  getPageCount() {\n    return Math.ceil(this.primengTreeTable.totalRecords / this.rows);\n  }\n\n  getPage(): number {\n    return Math.floor(this.primengTreeTable.first / this.rows);\n  }\n\n  changePage(p: number) {\n    const pc = Math.ceil(this.getPageCount());\n\n    if (p >= 0 && p < pc) {\n      this.first = this.rows * p;\n      this.primengTreeTable.onPageChange({\n        first: this.first,\n        rows: this.rows\n      });\n    }\n  }\n\n  onPageChange(event: any) {\n    this.first = event.first;\n    this.rows = event.rows;\n\n    const state = {\n      page: this.getPage(),\n      first: this.first,\n      rows: this.rows,\n      pageCount: Math.ceil(this.getPageCount())\n    };\n\n    this.pageChanged.emit(state);\n  }\n\n  onLazyLoaded(event: any) {\n    this.lazyLoaded.emit(event);\n  }\n\n  onNodeExpanded(event: any) {\n    this.nodeExpanded.emit(event);\n    setTimeout(() => {\n      this._recalcVirtualHeight();\n      this.cdRef.markForCheck();\n    });\n  }\n\n  onNodeCollapsed(event: any) {\n    this.nodeCollapsed.emit(event);\n    setTimeout(() => {\n      this._recalcVirtualHeight();\n      this.cdRef.markForCheck();\n    });\n  }\n\n  onNodeSelected(event: any) {\n    this.nodeSelected.emit(event);\n  }\n\n  onNodeUnselected(event: any) {\n    this.nodeUnselected.emit(event);\n  }\n\n  onSort(event: any) {\n    this.sorted.emit(event);\n  }\n\n  onFilter(event: any) {\n    this.filtered.emit(event);\n    setTimeout(() => {\n      this._recalcVirtualHeight();\n      this.cdRef.markForCheck();\n    });\n  }\n\n  onSelectColumn(col: any) {\n    let res = [] as any;\n    if (this.isColumnSelected(col)) {\n      res = this.selectedColumns.filter((v: any) => !isEqual(v, col));\n    } else {\n      this.columns.forEach((o) => {\n        if (\n          this.selectedColumns.some((v: any) => isEqual(v, o)) ||\n          isEqual(col, o)\n        ) {\n          res.push(o);\n        }\n      });\n    }\n    this.selectedColumns = res;\n    this.columnsSelected.emit(this.selectedColumns);\n  }\n\n  onSelectionChanged(selection: any[]) {\n    this.selectionChanged.emit(selection);\n  }\n}\n","<p-treeTable\n  #primengTreeTable\n  ttWithUnsort\n  [ngClass]=\"{ 'cps-treetable-loading': loading }\"\n  [value]=\"data\"\n  [scrollable]=\"scrollable\"\n  [scrollHeight]=\"scrollHeight\"\n  [virtualScroll]=\"virtualScroll\"\n  [virtualScrollItemSize]=\"virtualScrollItemSize\"\n  [virtualScrollOptions]=\"{\n    numToleratedItems: numToleratedItems,\n    autoSize: false\n  }\"\n  [columns]=\"selectedColumns\"\n  [loading]=\"loading\"\n  [rowHover]=\"rowHover\"\n  [lazy]=\"lazy\"\n  [(selection)]=\"selectedRows\"\n  (selectionChange)=\"onSelectionChanged($event)\"\n  compareSelectionBy=\"equals\"\n  [lazyLoadOnInit]=\"lazyLoadOnInit\"\n  [styleClass]=\"styleClass\"\n  [tableStyle]=\"tableStyle\"\n  [tableStyleClass]=\"tableStyleClass\"\n  [customSort]=\"customSort\"\n  [sortMode]=\"sortMode\"\n  [globalFilterFields]=\"globalFilterFields\"\n  [paginator]=\"paginator\"\n  [showCurrentPageReport]=\"true\"\n  [alwaysShowPaginator]=\"alwaysShowPaginator\"\n  [rows]=\"rows\"\n  [first]=\"first\"\n  [totalRecords]=\"totalRecords\"\n  [resetPageOnSort]=\"resetPageOnSort\"\n  currentPageReportTemplate=\"{first} - {last} of {totalRecords}\"\n  (onPage)=\"onPageChange($event)\"\n  (onSort)=\"onSort($event)\"\n  (onFilter)=\"onFilter($event)\"\n  (onLazyLoad)=\"onLazyLoaded($event)\"\n  (sortFunction)=\"onSortFunction($event)\"\n  (onNodeExpand)=\"onNodeExpanded($event)\"\n  (onNodeCollapse)=\"onNodeCollapsed($event)\"\n  (onNodeSelect)=\"onNodeSelected($event)\"\n  (onNodeUnselect)=\"onNodeUnselected($event)\">\n  <ng-template pTemplate=\"caption\" *ngIf=\"hasToolbar\">\n    <ng-container *ngIf=\"toolbarTemplate\">\n      <ng-container *ngTemplateOutlet=\"toolbarTemplate\"></ng-container>\n    </ng-container>\n    <ng-container *ngIf=\"!toolbarTemplate\">\n      <div class=\"cps-treetable-tbar-left\">\n        <div *ngIf=\"toolbarIcon\" class=\"cps-treetable-tbar-icon\">\n          <cps-icon [icon]=\"toolbarIcon\" [color]=\"toolbarIconColor\"></cps-icon>\n        </div>\n        <div class=\"cps-treetable-tbar-title\">{{ toolbarTitle }}</div>\n        <div *ngIf=\"showGlobalFilter\" class=\"cps-treetable-tbar-global-filter\">\n          <cps-input\n            #globalFilterComp\n            prefixIcon=\"search\"\n            [placeholder]=\"globalFilterPlaceholder\"\n            (valueChanged)=\"onFilterGlobal($event)\"\n            [clearable]=\"true\"\n            [disabled]=\"loading\"\n            [appearance]=\"toolbarSize === 'small' ? 'underlined' : 'outlined'\"\n            [hideDetails]=\"true\">\n          </cps-input>\n        </div>\n      </div>\n      <div class=\"cps-treetable-tbar-right\">\n        <div\n          *ngIf=\"showRemoveBtnOnSelect && selectedRows.length > 0\"\n          class=\"cps-treetable-tbar-btn-on-select\">\n          <cps-button\n            label=\"Remove\"\n            [disabled]=\"removeBtnOnSelectDisabled\"\n            color=\"prepared\"\n            type=\"borderless\"\n            icon=\"remove\"\n            [size]=\"toolbarSize\"\n            (clicked)=\"removeSelected()\">\n          </cps-button>\n        </div>\n        <div\n          *ngIf=\"showAdditionalBtnOnSelect && selectedRows.length > 0\"\n          class=\"cps-treetable-tbar-btn-on-select\">\n          <cps-button\n            [label]=\"additionalBtnOnSelectTitle\"\n            [disabled]=\"additionalBtnOnSelectDisabled\"\n            color=\"prepared\"\n            type=\"borderless\"\n            [size]=\"toolbarSize\"\n            (clicked)=\"onClickAdditionalBtnOnSelect()\">\n          </cps-button>\n        </div>\n        <div *ngIf=\"showActionBtn\" class=\"cps-treetable-tbar-action-btn\">\n          <cps-button\n            [label]=\"actionBtnTitle\"\n            [disabled]=\"actionBtnDisabled\"\n            color=\"prepared\"\n            type=\"outlined\"\n            [size]=\"toolbarSize\"\n            (clicked)=\"onClickActionBtn()\">\n          </cps-button>\n        </div>\n        <div\n          *ngIf=\"showColumnsToggleBtn && columns.length > 0\"\n          class=\"cps-treetable-tbar-coltoggle-btn\"\n          [ngClass]=\"{ 'btn-disabled': columnsToggleBtnDisabled }\">\n          <cps-icon\n            icon=\"columns\"\n            size=\"normal\"\n            [color]=\"\n              columnsToggleBtnDisabled ? 'text-lightest' : 'prepared-lighten1'\n            \"\n            (click)=\"onColumnsToggle($event)\"></cps-icon>\n          <cps-menu #colToggleMenu [withArrow]=\"false\">\n            <div class=\"cps-treetable-coltoggle-menu\">\n              <div\n                class=\"cps-treetable-coltoggle-menu-item select-all-option\"\n                [class.allselected]=\"selectedColumns.length === columns.length\"\n                (click)=\"toggleAllColumns()\">\n                <span class=\"cps-treetable-coltoggle-menu-item-left\">\n                  <span class=\"cps-treetable-coltoggle-menu-item-check\"> </span>\n                  <span class=\"cps-treetable-coltoggle-menu-item-label\"\n                    >Show all columns</span\n                  >\n                </span>\n              </div>\n              <div\n                *ngFor=\"let col of columns\"\n                class=\"cps-treetable-coltoggle-menu-item\"\n                (click)=\"onSelectColumn(col)\"\n                [class.selected]=\"isColumnSelected(col)\">\n                <span class=\"cps-treetable-coltoggle-menu-item-left\">\n                  <span class=\"cps-treetable-coltoggle-menu-item-check\"></span>\n                  <span class=\"cps-treetable-coltoggle-menu-item-label\">{{\n                    col[colHeaderName]\n                  }}</span>\n                </span>\n              </div>\n            </div>\n          </cps-menu>\n        </div>\n        <div\n          *ngIf=\"showDataReloadBtn\"\n          class=\"cps-treetable-tbar-reload-btn\"\n          [ngClass]=\"{ 'btn-disabled': dataReloadBtnDisabled }\">\n          <cps-icon\n            icon=\"refresh\"\n            size=\"18\"\n            [color]=\"dataReloadBtnDisabled ? 'text-light' : 'prepared-lighten1'\"\n            (click)=\"onReloadData()\">\n          </cps-icon>\n        </div>\n      </div>\n    </ng-container>\n  </ng-template>\n\n  <ng-template pTemplate=\"header\" *ngIf=\"nestedHeaderTemplate\" let-columns>\n    <ng-container\n      *ngTemplateOutlet=\"\n      nestedHeaderTemplate;\n        context: {\n          $implicit: columns,\n        }\n      \"></ng-container>\n  </ng-template>\n\n  <ng-template pTemplate=\"header\" *ngIf=\"!nestedHeaderTemplate\" let-columns>\n    <tr>\n      <!-- <th style=\"width: 3rem\" *ngIf=\"reorderableRows\"></th> -->\n      <th style=\"width: 55px\" *ngIf=\"selectable\">\n        <p-treeTableHeaderCheckbox></p-treeTableHeaderCheckbox>\n      </th>\n      <ng-container *ngIf=\"headerTemplate\">\n        <ng-container\n          *ngTemplateOutlet=\"\n            headerTemplate;\n            context: {\n              $implicit: columns,\n            }\n          \"></ng-container>\n      </ng-container>\n      <ng-container *ngIf=\"!headerTemplate && columns.length > 0\">\n        <ng-container *ngIf=\"sortable\">\n          <th\n            *ngFor=\"let col of columns\"\n            [cpsTTColSortable]=\"col[colFieldName]\">\n            {{ col[colHeaderName] }}\n          </th>\n        </ng-container>\n        <ng-container *ngIf=\"!sortable\">\n          <th *ngFor=\"let col of columns\">\n            {{ col[colHeaderName] }}\n          </th>\n        </ng-container>\n      </ng-container>\n      <th class=\"cps-treetable-row-menu-cell\" *ngIf=\"showRowMenu\"></th>\n    </tr>\n  </ng-template>\n\n  <ng-template\n    pTemplate=\"body\"\n    let-rowData=\"rowData\"\n    let-columns=\"columns\"\n    let-rowNode\n    let-rowIndex=\"rowIndex\">\n    <tr\n      [ttRow]=\"rowNode\"\n      [ngClass]=\"{\n        'cps-treetable-row-selected':\n          selectable && primengTreeTable.isSelected(rowNode.node)\n      }\">\n      <!-- <td *ngIf=\"reorderableRows\" class=\"cps-table-row-drag-handle-cell\">\n        <span class=\"cps-table-row-drag-handle\" pReorderableRowHandle>☰</span>\n      </td> -->\n      <td style=\"width: 55px\" *ngIf=\"selectable\">\n        <p-treeTableCheckbox [value]=\"rowNode\"></p-treeTableCheckbox>\n      </td>\n      <ng-container *ngIf=\"bodyTemplate\">\n        <ng-container\n          *ngTemplateOutlet=\"\n            bodyTemplate;\n            context: {\n              $implicit: rowNode,\n              rowIndex: rowIndex,\n              columns: columns,\n              rowData: rowData\n            }\n          \">\n        </ng-container>\n      </ng-container>\n      <ng-container *ngIf=\"!bodyTemplate\">\n        <ng-container *ngIf=\"columns.length > 0\">\n          <td *ngFor=\"let col of columns; let i = index\">\n            <p-treeTableToggler [rowNode]=\"rowNode\" *ngIf=\"i === 0\">\n            </p-treeTableToggler>\n            {{ rowData[col[colFieldName]] }}\n          </td>\n        </ng-container>\n      </ng-container>\n      <td *ngIf=\"showRowMenu\" class=\"cps-treetable-row-menu-cell\">\n        <table-row-menu\n          (editRowBtnClicked)=\"onEditRowClicked(rowNode.node)\"\n          (removeRowBtnClicked)=\"onRemoveRowClicked(rowNode.node)\">\n        </table-row-menu>\n      </td>\n    </tr>\n  </ng-template>\n  <ng-template pTemplate=\"emptymessage\">\n    <tr>\n      <td\n        colspan=\"100\"\n        class=\"cps-treetable-empty-message-td\"\n        [ngStyle]=\"{ height: emptyBodyHeight }\">\n        {{ emptyMessage }}\n      </td>\n    </tr>\n  </ng-template>\n  <ng-template pTemplate=\"loadingicon\">\n    <cps-loader [fullScreen]=\"false\" opacity=\"0\"></cps-loader>\n  </ng-template>\n  <ng-template pTemplate=\"paginatorleft\">\n    <div class=\"cps-table-paginator-itms-per-page\">\n      <span class=\"cps-table-paginator-items-per-page-title\"\n        >Rows per page:\n      </span>\n      <cps-select\n        [options]=\"rowOptions\"\n        [hideDetails]=\"true\"\n        [(ngModel)]=\"rows\"\n        (valueChanged)=\"onRowsPerPageChanged()\"\n        [returnObject]=\"false\"\n        optionsClass=\"cps-paginator-page-options\">\n      </cps-select>\n    </div>\n  </ng-template>\n\n  <ng-template pTemplate=\"paginatorfirstpagelinkicon\">\n    <AngleDoubleLeftIcon />\n  </ng-template>\n  <ng-template pTemplate=\"paginatorpreviouspagelinkicon\">\n    <AngleLeftIcon />\n  </ng-template>\n  <ng-template pTemplate=\"paginatornextpagelinkicon\">\n    <AngleRightIcon />\n  </ng-template>\n  <ng-template pTemplate=\"paginatorlastpagelinkicon\">\n    <AngleDoubleRightIcon />\n  </ng-template>\n</p-treeTable>\n"]}
|
|
646
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cps-tree-table.component.js","sourceRoot":"","sources":["../../../../../../projects/cps-ui-kit/src/lib/components/cps-tree-table/cps-tree-table.component.ts","../../../../../../projects/cps-ui-kit/src/lib/components/cps-tree-table/cps-tree-table.component.html"],"names":[],"mappings":"AAAA,OAAO,EAGL,uBAAuB,EAEvB,SAAS,EACT,YAAY,EACZ,YAAY,EACZ,KAAK,EAIL,MAAM,EAGN,SAAS,EACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC7C,OAAO,EACL,SAAS,EACT,gBAAgB,EAChB,eAAe,EAChB,MAAM,mBAAmB,CAAC;AAC3B,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AACzC,OAAO,EAAE,mBAAmB,EAAE,MAAM,+BAA+B,CAAC;AACpE,OAAO,EAAE,aAAa,EAAE,MAAM,yBAAyB,CAAC;AACxD,OAAO,EAAE,cAAc,EAAE,MAAM,0BAA0B,CAAC;AAC1D,OAAO,EAAE,oBAAoB,EAAE,MAAM,gCAAgC,CAAC;AAEtE,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAC1C,OAAO,EAAE,iBAAiB,EAAE,MAAM,kCAAkC,CAAC;AACrE,OAAO,EAAE,kBAAkB,EAAE,MAAM,oCAAoC,CAAC;AACxE,OAAO,EAAE,gBAAgB,EAAE,MAAM,gCAAgC,CAAC;AAClE,OAAO,EAAE,gBAAgB,EAAE,MAAM,gCAAgC,CAAC;AAClE,OAAO,EAAE,kBAAkB,EAAE,MAAM,oCAAoC,CAAC;AACxE,OAAO,EAAE,kBAAkB,EAAE,MAAM,oCAAoC,CAAC;AACxE,OAAO,EAAE,mCAAmC,EAAE,MAAM,uDAAuD,CAAC;AAC5G,OAAO,EAAE,wBAAwB,EAAE,MAAM,mDAAmD,CAAC;AAC7F,OAAO,EAAE,qBAAqB,EAAE,MAAM,sDAAsD,CAAC;AAC7F,OAAO,EAAE,WAAW,EAAE,MAAM,iCAAiC,CAAC;;;;;;AAE9D,MAAM,UAAU,gBAAgB,CAAC,cAAqC;IACpE,OAAO,cAAc,CAAC,gBAAgB,CAAC;AACzC,CAAC;AAuCD,MAAM,OAAO,qBAAqB;IAkIhC,kDAAkD;IAClD,YAAoB,KAAwB;QAAxB,UAAK,GAAL,KAAK,CAAmB;QAhInC,SAAI,GAAU,EAAE,CAAC;QACjB,YAAO,GAA6B,EAAE,CAAC;QACvC,kBAAa,GAAG,QAAQ,CAAC;QACzB,iBAAY,GAAG,OAAO,CAAC;QAEvB,YAAO,GAAG,IAAI,CAAC;QACf,aAAQ,GAAG,IAAI,CAAC;QAChB,SAAI,GAAqB,QAAQ,CAAC;QAClC,eAAU,GAAG,KAAK,CAAC;QACnB,aAAQ,GAAG,IAAI,CAAC;QAChB,gBAAW,GAAG,KAAK,CAAC;QACpB,YAAO,GAAG,KAAK,CAAC;QAEhB,eAAU,GAAG,SAAS,CAAC;QACvB,oBAAe,GAAG,EAAE,CAAC;QAErB,aAAQ,GAAG,KAAK,CAAC,CAAC,6CAA6C;QAC/D,aAAQ,GAAyB,QAAQ,CAAC;QAC1C,eAAU,GAAG,KAAK,CAAC;QAEnB,eAAU,GAAG,IAAI,CAAC;QAClB,gBAAW,GAA4B,QAAQ,CAAC;QAChD,iBAAY,GAAG,EAAE,CAAC;QAClB,gBAAW,GAAG,EAAE,CAAC;QACjB,qBAAgB,GAAG,EAAE,CAAC;QAEtB,eAAU,GAAG,IAAI,CAAC;QAClB,iBAAY,GAAG,EAAE,CAAC,CAAC,uBAAuB;QAC1C,kBAAa,GAAG,KAAK,CAAC,CAAC,mCAAmC;QAC1D,sBAAiB,GAAG,EAAE,CAAC;QAEvB,cAAS,GAAG,KAAK,CAAC;QAClB,wBAAmB,GAAG,IAAI,CAAC;QAC3B,uBAAkB,GAAa,EAAE,CAAC;QAClC,UAAK,GAAG,CAAC,CAAC;QACV,SAAI,GAAG,CAAC,CAAC;QACT,0BAAqB,GAAG,KAAK,CAAC;QAC9B,oBAAe,GAAG,IAAI,CAAC;QACvB,iBAAY,GAAG,CAAC,CAAC;QAEjB,iBAAY,GAAG,SAAS,CAAC;QACzB,oBAAe,GAAoB,EAAE,CAAC;QAEtC,SAAI,GAAG,KAAK,CAAC;QACb,mBAAc,GAAG,IAAI,CAAC;QAEtB,qBAAgB,GAAG,KAAK,CAAC;QACzB,4BAAuB,GAAG,QAAQ,CAAC;QACnC,uBAAkB,GAAa,EAAE,CAAC;QAClC,+BAA0B,GAAG,KAAK,CAAC;QAEnC,0BAAqB,GAAG,IAAI,CAAC;QAC7B,8BAAyB,GAAG,KAAK,CAAC;QAElC,8BAAyB,GAAG,KAAK,CAAC;QAClC,+BAA0B,GAAG,eAAe,CAAC;QAC7C,kCAA6B,GAAG,KAAK,CAAC;QAEtC,kBAAa,GAAG,KAAK,CAAC;QACtB,mBAAc,GAAG,QAAQ,CAAC;QAC1B,sBAAiB,GAAG,KAAK,CAAC;QAE1B,sBAAiB,GAAG,KAAK,CAAC;QAC1B,0BAAqB,GAAG,KAAK,CAAC;QAE9B,yBAAoB,GAAG,KAAK,CAAC,CAAC,2EAA2E;QACzG,6BAAwB,GAAG,KAAK,CAAC;QAEhC,qBAAgB,GAAG,IAAI,YAAY,EAAS,CAAC;QAC7C,qBAAgB,GAAG,IAAI,YAAY,EAAQ,CAAC;QAC5C,iCAA4B,GAAG,IAAI,YAAY,EAAS,CAAC;QACzD,sBAAiB,GAAG,IAAI,YAAY,EAAO,CAAC;QAC5C,gBAAW,GAAG,IAAI,YAAY,EAAS,CAAC;QACxC,gBAAW,GAAG,IAAI,YAAY,EAAO,CAAC;QACtC,WAAM,GAAG,IAAI,YAAY,EAAO,CAAC;QACjC,aAAQ,GAAG,IAAI,YAAY,EAAO,CAAC;QACnC,oBAAe,GAAG,IAAI,YAAY,EAA4B,CAAC;QAC/D,eAAU,GAAG,IAAI,YAAY,EAAO,CAAC;QACrC,yBAAoB,GAAG,IAAI,YAAY,EAAO,CAAC;QAC/C,iBAAY,GAAG,IAAI,YAAY,EAAO,CAAC;QACvC,kBAAa,GAAG,IAAI,YAAY,EAAO,CAAC;QACxC,iBAAY,GAAG,IAAI,YAAY,EAAO,CAAC;QACvC,mBAAc,GAAG,IAAI,YAAY,EAAO,CAAC;QAEnD;;;;WAIG;QACO,uBAAkB,GAAsB,IAAI,YAAY,EAAO,CAAC;QAuB1E,oBAAe,GAA6B,EAAE,CAAC;QAE/C,eAAU,GAAuC,EAAE,CAAC;QAEpD,iBAAY,GAAU,EAAE,CAAC;QAEzB,0BAAqB,GAAG,CAAC,CAAC;QAC1B,sBAAiB,GAAG,CAAC,CAAC;QACtB,oBAAe,GAAG,EAAE,CAAC;QAKrB,mBAAc,GAAG,CAAC,CAAC;QAIjB,IAAI,CAAC,cAAc,GAAG,IAAI,cAAc,CAAC,CAAC,OAAO,EAAE,EAAE;YACnD,OAAO,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE;gBACxB,MAAM,IAAI,GAAG,KAAK,CAAC,MAAM,CAAC;gBAC1B,MAAM,WAAW,GAAG,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,YAAY,CAAC;gBAE1D,IAAI,OAAO,GAAG,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,CAAC;gBACpD,IAAI,OAAO,GAAG,CAAC;oBAAE,OAAO,IAAI,CAAC,CAAC;gBAE9B,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,YAAY,GAAG,GAAG,OAAO,IAAI,CAAC;gBACnD,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,WAAW;oBAC9B,OAAO,GAAG,CAAC,CAAC,CAAC,CAAC,mBAAmB,CAAC,CAAC,CAAC,OAAO,CAAC;YAChD,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,eAAe,GAAG,WAAW,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;QACzD,IAAI,CAAC,IAAI,CAAC,UAAU;YAAE,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;QAEjD,IAAI,IAAI,CAAC,yBAAyB;YAAE,IAAI,CAAC,qBAAqB,GAAG,KAAK,CAAC;QAEvE,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,YAAY,CAAC;YAEzC,IAAI,IAAI,CAAC,eAAe,KAAK,MAAM;gBACjC,MAAM,CAAC,gBAAgB,CAAC,QAAQ,EAAE,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;YAErE,IAAI,IAAI,CAAC,eAAe,IAAI,IAAI,CAAC,eAAe,KAAK,MAAM,EAAE;gBAC3D,IAAI,CAAC,iBAAiB,GAAG,QAAQ,CAAC,IAAI,CAAC,YAAY,EAAE,EAAE,CAAC,CAAC;aAC1D;SACF;QAED,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,IAAI,IAAI,CAAC,kBAAkB,CAAC,MAAM,GAAG,CAAC;gBACpC,IAAI,CAAC,kBAAkB,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;YAE5C,IAAI,CAAC,IAAI,CAAC,IAAI;gBAAE,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,kBAAkB,CAAC,CAAC,CAAC,CAAC;iBAClD;gBACH,IAAI,CAAC,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE;oBAChD,MAAM,IAAI,KAAK,CAAC,sCAAsC,CAAC,CAAC;iBACzD;aACF;YAED,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;gBACpD,KAAK,EAAE,EAAE,GAAG,CAAC;gBACb,KAAK,EAAE,CAAC;aACT,CAAC,CAAC,CAAC;SACL;QAED,IACE,IAAI,CAAC,gBAAgB;YACrB,IAAI,CAAC,kBAAkB,EAAE,MAAM,GAAG,CAAC;YACnC,IAAI,CAAC,IAAI,EAAE,MAAM,GAAG,CAAC,EACrB;YACA,IAAI,CAAC,kBAAkB,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;SAC1D;QAED,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,OAAO,CAAC;IACtC,CAAC;IAED,eAAe;QACb,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,gBAAgB,CAAC,EAAE,CAAC,aAAa,CAAC,aAAa,CACxE,8BAA8B,CAC/B,CAAC;QACF,IAAI,IAAI,CAAC,cAAc,EAAE;YACvB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,gBAAgB,CAAC,EAAE,CAAC,aAAa,CAAC,aAAa,CACnE,oCAAoC,CACrC,CAAC;YACF,IAAI,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,eAAe,KAAK,MAAM;gBACvD,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,cAAc,CAAC,YAAY,CAAC;YAE5D,IAAI,IAAI,CAAC,SAAS,EAAE;gBAClB,IAAI,CAAC,cAAc,GAAG,UAAU,CAAC,uBAAuB,EAAE,CAAC;gBAC3D,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;aAClD;SACF;IACH,CAAC;IAED,kBAAkB;QAChB,IAAI,CAAC,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,qBAAqB;YAAE,OAAO;QAC9D,IAAI,CAAC,qBAAqB;YACxB,IAAI,CAAC,gBAAgB,EAAE,EAAE,EAAE,aAAa;gBACtC,EAAE,aAAa,CAAC,oBAAoB,CAAC;gBACrC,EAAE,aAAa,CAAC,IAAI,CAAC,EAAE,YAAY,IAAI,CAAC,CAAC;QAC7C,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC;IAC7B,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,IAAI,IAAI,CAAC,OAAO,EAAE;YAChB,IAAI,CAAC,cAAc,EAAE,CAAC;YACtB,IAAI,IAAI,CAAC,0BAA0B;gBAAE,IAAI,CAAC,iBAAiB,EAAE,CAAC;SAC/D;QAED,MAAM,WAAW,GAAG,OAAO,EAAE,IAAI,CAAC;QAClC,IAAI,WAAW,EAAE,aAAa,KAAK,WAAW,EAAE,YAAY,EAAE;YAC5D,IAAI,CAAC,cAAc,EAAE,CAAC;SACvB;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,cAAc,EAAE,UAAU,EAAE,CAAC;QAClC,IAAI,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,eAAe,KAAK,MAAM;YACvD,MAAM,CAAC,mBAAmB,CAAC,QAAQ,EAAE,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;IAC1E,CAAC;IAED,iBAAiB;QACf,IAAI,CAAC,gBAAgB,EAAE,KAAK,EAAE,CAAC;IACjC,CAAC;IAEO,eAAe;QACrB,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,cAAc,CAAC,YAAY,CAAC;IAC5D,CAAC;IAED,IAAI,UAAU;QACZ,MAAM,WAAW,GAAG,EAAE,CAAC;QACvB,QAAQ,IAAI,CAAC,IAAI,EAAE;YACjB,KAAK,OAAO;gBACV,WAAW,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;gBACnC,MAAM;YACR,KAAK,OAAO;gBACV,WAAW,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;gBACnC,MAAM;SACT;QACD,IAAI,IAAI,CAAC,UAAU,EAAE;YACnB,QAAQ,IAAI,CAAC,WAAW,EAAE;gBACxB,KAAK,OAAO;oBACV,WAAW,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;oBACnC,MAAM;gBACR,KAAK,QAAQ;oBACX,WAAW,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;oBACpC,MAAM;aACT;SACF;QACD,IAAI,IAAI,CAAC,OAAO,EAAE;YAChB,WAAW,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC;SACzC;QACD,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,WAAW,CAAC,IAAI,CAAC,uBAAuB,CAAC,CAAC;SAC3C;QAED,IAAI,IAAI,CAAC,YAAY,IAAI,CAAC,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE;YAC9D,WAAW,CAAC,IAAI,CAAC,+BAA+B,CAAC,CAAC;SACnD;QAED,OAAO,WAAW,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAC/B,CAAC;IAED,cAAc,CAAC,KAAgB;QAC7B,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACtC,CAAC;IAEO,oBAAoB;QAC1B,IAAI,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,eAAe,EAAE;YAC9C,MAAM,QAAQ,GAAG,IAAI,CAAC,gBAAgB,CAAC,eAAe,CAAC,MAAM,CAAC;YAC9D,IAAI,QAAQ,GAAG,CAAC,EAAE;gBAChB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,eAAe;oBACtC,CAAC,CAAE,QAAQ,IAAI,CAAC,eAAe,SAAoB;oBACnD,CAAC,CAAC,IAAI,CAAC,qBAAqB,GAAG,CAAC,GAAG,IAAI,CAAC;aAC3C;iBAAM;gBACL,MAAM,SAAS,GAAG,IAAI,CAAC,qBAAqB,GAAG,QAAQ,GAAG,CAAC,CAAC;gBAC5D,IAAI,IAAI,CAAC,eAAe,KAAK,MAAM,EAAE;oBACnC,IAAI,SAAS,IAAI,IAAI,CAAC,iBAAiB,EAAE;wBACvC,IAAI,CAAC,YAAY,GAAG,MAAM,CAAC;wBAC3B,UAAU,CAAC,GAAG,EAAE;4BACd,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,MAAM,GAAG,MAAM,CAAC;4BAC1C,IAAI,CAAC,KAAK,CAAC,YAAY,EAAE,CAAC;wBAC5B,CAAC,CAAC,CAAC;wBACH,OAAO;qBACR;iBACF;gBACD,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,iBAAiB,EAAE,SAAS,CAAC,GAAG,IAAI,CAAC;aACxE;SACF;IACH,CAAC;IAED,cAAc,CAAC,KAAa;QAC1B,IAAI,CAAC,gBAAgB,CAAC,YAAY,CAAC,KAAK,EAAE,UAAU,CAAC,CAAC;IACxD,CAAC;IAED,4BAA4B;QAC1B,IAAI,CAAC,4BAA4B,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IAC5D,CAAC;IAED,gBAAgB;QACd,IAAI,CAAC,gBAAgB,CAAC,IAAI,EAAE,CAAC;IAC/B,CAAC;IAED,YAAY;QACV,IAAI,IAAI,CAAC,qBAAqB;YAAE,OAAO;QACvC,IAAI,CAAC,oBAAoB,CAAC,IAAI,EAAE,CAAC;IACnC,CAAC;IAED,eAAe,CAAC,KAAU;QACxB,IAAI,IAAI,CAAC,wBAAwB;YAAE,OAAO;QAC1C,IAAI,CAAC,aAAa,EAAE,MAAM,CAAC,KAAK,CAAC,CAAC;IACpC,CAAC;IAED,cAAc;QACZ,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,IAAI,CAAC,mBAAmB,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC,CAAC;QACzE,IAAI,CAAC,IAAI,GAAG,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC;QAC3B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QACzC,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,oBAAoB,EAAE,CAAC;YAC5B,IAAI,CAAC,KAAK,CAAC,YAAY,EAAE,CAAC;QAC5B,CAAC,CAAC,CAAC;IACL,CAAC;IAED,cAAc;QACZ,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;IACzB,CAAC;IAED,gBAAgB,CAAC,IAAS;QACxB,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACpC,CAAC;IAED,kBAAkB,CAAC,IAAS;QAC1B,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,CAAM,EAAE,EAAE,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC;QACrE,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC;QAC/B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;QAC9B,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,oBAAoB,EAAE,CAAC;YAC5B,IAAI,CAAC,KAAK,CAAC,YAAY,EAAE,CAAC;QAC5B,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,mBAAmB,CAAC,YAAiB,EAAE,MAAM,GAAG,IAAI;QAC1D,MAAM,iBAAiB,GAAG,CAAC,KAAU,EAAO,EAAE;YAC5C,IAAI,CAAC,KAAK;gBAAE,OAAO,SAAS,CAAC;YAC7B,IAAI,OAAO,KAAK,CAAC,iBAAiB,KAAK,QAAQ;gBAC7C,OAAO,KAAK,CAAC,iBAAiB,CAAC;YACjC,OAAO,iBAAiB,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;QACzC,CAAC,CAAC;QAEF,MAAM,mBAAmB,GAAG,CAAC,KAAU,EAAE,EAAE;YACzC,IAAI,CAAC,KAAK,EAAE,QAAQ;gBAAE,OAAO,KAAK,CAAC;YACnC,MAAM,GAAG,GAAG,KAAK,CAAC,QAAQ,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;YACjD,IAAI,GAAG,IAAI,CAAC,EAAE;gBACZ,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC;gBAC9B,IAAI,KAAK,CAAC,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE;oBAC/B,OAAO,KAAK,CAAC,QAAQ,CAAC;iBACvB;gBACD,OAAO,IAAI,CAAC;aACb;iBAAM;gBACL,KAAK,MAAM,KAAK,IAAI,KAAK,CAAC,QAAQ,EAAE;oBAClC,IAAI,mBAAmB,CAAC,KAAK,CAAC;wBAAE,OAAO,IAAI,CAAC;iBAC7C;gBACD,OAAO,KAAK,CAAC;aACd;QACH,CAAC,CAAC;QAEF,wBAAwB;QACxB,MAAM,SAAS,GAAG,iBAAiB,CAAC,YAAY,CAAC,CAAC;QAClD,IAAI,SAAS,KAAK,SAAS;YAAE,OAAO;QACpC,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,iBAAiB,KAAK,SAAS,CAAC,CAAC;QACtE,IAAI,CAAC,IAAI;YAAE,OAAO;QAElB,6CAA6C;QAC7C,IAAI,YAAY,KAAK,IAAI,EAAE;YACzB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAM,EAAE,EAAE,CAAC,CAAC,KAAK,YAAY,CAAC,CAAC;SAC9D;aAAM;YACL,IAAI,IAAI,CAAC,QAAQ,EAAE;gBACjB,mBAAmB,CAAC,IAAI,CAAC,CAAC;gBAC1B,IAAI,MAAM;oBAAE,IAAI,CAAC,IAAI,GAAG,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC;aACxC;SACF;IACH,CAAC;IAED,gBAAgB;QACd,IAAI,CAAC,eAAe;YAClB,IAAI,CAAC,eAAe,CAAC,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC;QACxE,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;IAClD,CAAC;IAED,gBAAgB,CAAC,GAAQ;QACvB,OAAO,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC,IAAI,EAAE,EAAE,CAAC,OAAO,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC,CAAC;IACpE,CAAC;IAED,oBAAoB;QAClB,IAAI,IAAI,CAAC,qBAAqB,EAAE;YAC9B,IAAI,CAAC,gBAAgB,CAAC,KAAK,GAAG,CAAC,CAAC;SACjC;QACD,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC;IAClC,CAAC;IAED,YAAY;QACV,OAAO,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,YAAY,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC;IACnE,CAAC;IAED,OAAO;QACL,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,gBAAgB,CAAC,KAAK,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC;IAC7D,CAAC;IAED,UAAU,CAAC,CAAS;QAClB,MAAM,EAAE,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC;QAE1C,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,EAAE;YACpB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC;YAC3B,IAAI,CAAC,gBAAgB,CAAC,YAAY,CAAC;gBACjC,KAAK,EAAE,IAAI,CAAC,KAAK;gBACjB,IAAI,EAAE,IAAI,CAAC,IAAI;aAChB,CAAC,CAAC;SACJ;IACH,CAAC;IAED,YAAY,CAAC,KAAU;QACrB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC;QACzB,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC;QAEvB,MAAM,KAAK,GAAG;YACZ,IAAI,EAAE,IAAI,CAAC,OAAO,EAAE;YACpB,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,IAAI,EAAE,IAAI,CAAC,IAAI;YACf,SAAS,EAAE,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC;SAC1C,CAAC;QAEF,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC/B,CAAC;IAED,YAAY,CAAC,KAAU;QACrB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC9B,CAAC;IAED,cAAc,CAAC,KAAU;QACvB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC9B,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,oBAAoB,EAAE,CAAC;YAC5B,IAAI,CAAC,KAAK,CAAC,YAAY,EAAE,CAAC;QAC5B,CAAC,CAAC,CAAC;IACL,CAAC;IAED,eAAe,CAAC,KAAU;QACxB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC/B,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,oBAAoB,EAAE,CAAC;YAC5B,IAAI,CAAC,KAAK,CAAC,YAAY,EAAE,CAAC;QAC5B,CAAC,CAAC,CAAC;IACL,CAAC;IAED,cAAc,CAAC,KAAU;QACvB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAChC,CAAC;IAED,gBAAgB,CAAC,KAAU;QACzB,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAClC,CAAC;IAED,MAAM,CAAC,KAAU;QACf,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC1B,CAAC;IAED,QAAQ,CAAC,KAAU;QACjB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC1B,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,oBAAoB,EAAE,CAAC;YAC5B,IAAI,CAAC,KAAK,CAAC,YAAY,EAAE,CAAC;QAC5B,CAAC,CAAC,CAAC;IACL,CAAC;IAED,cAAc,CAAC,GAAQ;QACrB,IAAI,GAAG,GAAG,EAAS,CAAC;QACpB,IAAI,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,EAAE;YAC9B,GAAG,GAAG,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC,CAAM,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC;SACjE;aAAM;YACL,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE;gBACzB,IACE,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC,CAAM,EAAE,EAAE,CAAC,OAAO,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;oBACpD,OAAO,CAAC,GAAG,EAAE,CAAC,CAAC,EACf;oBACA,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;iBACb;YACH,CAAC,CAAC,CAAC;SACJ;QACD,IAAI,CAAC,eAAe,GAAG,GAAG,CAAC;QAC3B,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;IAClD,CAAC;IAED,kBAAkB,CAAC,SAAgB;QACjC,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IACxC,CAAC;;kHA/fU,qBAAqB;sGAArB,qBAAqB,43EAVrB;QACT,gBAAgB;QAChB;YACE,OAAO,EAAE,SAAS;YAClB,UAAU,EAAE,gBAAgB;YAC5B,gDAAgD;YAChD,IAAI,EAAE,CAAC,qBAAqB,CAAC;SAC9B;KACF,4vBCjFH,87UAkSA,0vlBD5OI,WAAW,8VACX,YAAY,ylBACZ,eAAe,24DACf,iBAAiB,qgBACjB,kBAAkB,2MAClB,gBAAgB,0RAChB,gBAAgB,wFAChB,kBAAkB,2iBAClB,kBAAkB,qHAClB,mBAAmB,gEACnB,aAAa,0DACb,cAAc,2DACd,oBAAoB,iEACpB,mCAAmC,6FACnC,wBAAwB,2DACxB,qBAAqB;2FAcZ,qBAAqB;kBAlCjC,SAAS;+BACE,gBAAgB,cACd,IAAI,mBACC,uBAAuB,CAAC,MAAM,WACtC;wBACP,WAAW;wBACX,YAAY;wBACZ,eAAe;wBACf,iBAAiB;wBACjB,kBAAkB;wBAClB,gBAAgB;wBAChB,gBAAgB;wBAChB,kBAAkB;wBAClB,kBAAkB;wBAClB,mBAAmB;wBACnB,aAAa;wBACb,cAAc;wBACd,oBAAoB;wBACpB,mCAAmC;wBACnC,wBAAwB;wBACxB,qBAAqB;qBACtB,aAGU;wBACT,gBAAgB;wBAChB;4BACE,OAAO,EAAE,SAAS;4BAClB,UAAU,EAAE,gBAAgB;4BAC5B,gDAAgD;4BAChD,IAAI,EAAE,uBAAuB;yBAC9B;qBACF;wGAKQ,IAAI;sBAAZ,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBAEG,OAAO;sBAAf,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBAEG,UAAU;sBAAlB,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBAEG,QAAQ;sBAAhB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBAEG,UAAU;sBAAlB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBAEG,UAAU;sBAAlB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,iBAAiB;sBAAzB,KAAK;gBAEG,SAAS;sBAAjB,KAAK;gBACG,mBAAmB;sBAA3B,KAAK;gBACG,kBAAkB;sBAA1B,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,qBAAqB;sBAA7B,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBAEG,YAAY;sBAApB,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBAEG,IAAI;sBAAZ,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBAEG,gBAAgB;sBAAxB,KAAK;gBACG,uBAAuB;sBAA/B,KAAK;gBACG,kBAAkB;sBAA1B,KAAK;gBACG,0BAA0B;sBAAlC,KAAK;gBAEG,qBAAqB;sBAA7B,KAAK;gBACG,yBAAyB;sBAAjC,KAAK;gBAEG,yBAAyB;sBAAjC,KAAK;gBACG,0BAA0B;sBAAlC,KAAK;gBACG,6BAA6B;sBAArC,KAAK;gBAEG,aAAa;sBAArB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,iBAAiB;sBAAzB,KAAK;gBAEG,iBAAiB;sBAAzB,KAAK;gBACG,qBAAqB;sBAA7B,KAAK;gBAEG,oBAAoB;sBAA5B,KAAK;gBACG,wBAAwB;sBAAhC,KAAK;gBAEI,gBAAgB;sBAAzB,MAAM;gBACG,gBAAgB;sBAAzB,MAAM;gBACG,4BAA4B;sBAArC,MAAM;gBACG,iBAAiB;sBAA1B,MAAM;gBACG,WAAW;sBAApB,MAAM;gBACG,WAAW;sBAApB,MAAM;gBACG,MAAM;sBAAf,MAAM;gBACG,QAAQ;sBAAjB,MAAM;gBACG,eAAe;sBAAxB,MAAM;gBACG,UAAU;sBAAnB,MAAM;gBACG,oBAAoB;sBAA7B,MAAM;gBACG,YAAY;sBAArB,MAAM;gBACG,aAAa;sBAAtB,MAAM;gBACG,YAAY;sBAArB,MAAM;gBACG,cAAc;sBAAvB,MAAM;gBAOG,kBAAkB;sBAA3B,MAAM;gBAGA,eAAe;sBADrB,YAAY;uBAAC,SAAS,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;gBAInC,cAAc;sBADpB,YAAY;uBAAC,QAAQ,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;gBAIlC,oBAAoB;sBAD1B,YAAY;uBAAC,cAAc,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;gBAIxC,YAAY;sBADlB,YAAY;uBAAC,MAAM,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;gBAIvC,gBAAgB;sBADf,SAAS;uBAAC,kBAAkB,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBAI/C,gBAAgB;sBADf,SAAS;uBAAC,kBAAkB;gBAI7B,aAAa;sBADZ,SAAS;uBAAC,eAAe","sourcesContent":["import {\n  AfterViewChecked,\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  SimpleChanges,\n  TemplateRef,\n  ViewChild\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FormsModule } from '@angular/forms';\nimport {\n  TreeTable,\n  TreeTableService,\n  TreeTableModule\n} from 'primeng/treetable';\nimport { DomHandler } from 'primeng/dom';\nimport { AngleDoubleLeftIcon } from 'primeng/icons/angledoubleleft';\nimport { AngleLeftIcon } from 'primeng/icons/angleleft';\nimport { AngleRightIcon } from 'primeng/icons/angleright';\nimport { AngleDoubleRightIcon } from 'primeng/icons/angledoubleright';\nimport { SortEvent } from 'primeng/api';\nimport { find, isEqual } from 'lodash-es';\nimport { CpsInputComponent } from '../cps-input/cps-input.component';\nimport { CpsButtonComponent } from '../cps-button/cps-button.component';\nimport { CpsMenuComponent } from '../cps-menu/cps-menu.component';\nimport { CpsIconComponent } from '../cps-icon/cps-icon.component';\nimport { CpsSelectComponent } from '../cps-select/cps-select.component';\nimport { CpsLoaderComponent } from '../cps-loader/cps-loader.component';\nimport { CpsTreeTableColumnSortableDirective } from './directives/cps-tree-table-column-sortable.directive';\nimport { TreeTableUnsortDirective } from './directives/internal/tree-table-unsort.directive';\nimport { TableRowMenuComponent } from '../cps-table/table-row-menu/table-row-menu.component';\nimport { convertSize } from '../../utils/internal/size-utils';\n\nexport function treeTableFactory(tableComponent: CpsTreeTableComponent) {\n  return tableComponent.primengTreeTable;\n}\n\nexport type CpsTreeTableSize = 'small' | 'normal' | 'large';\nexport type CpsTreeTableToolbarSize = 'small' | 'normal';\nexport type CpsTreeTableSortMode = 'single' | 'multiple';\n@Component({\n  selector: 'cps-tree-table',\n  standalone: true,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [\n    FormsModule,\n    CommonModule,\n    TreeTableModule,\n    CpsInputComponent,\n    CpsButtonComponent,\n    CpsMenuComponent,\n    CpsIconComponent,\n    CpsSelectComponent,\n    CpsLoaderComponent,\n    AngleDoubleLeftIcon,\n    AngleLeftIcon,\n    AngleRightIcon,\n    AngleDoubleRightIcon,\n    CpsTreeTableColumnSortableDirective,\n    TreeTableUnsortDirective,\n    TableRowMenuComponent\n  ],\n  templateUrl: './cps-tree-table.component.html',\n  styleUrls: ['./cps-tree-table.component.scss'],\n  providers: [\n    TreeTableService,\n    {\n      provide: TreeTable,\n      useFactory: treeTableFactory,\n      // eslint-disable-next-line no-use-before-define\n      deps: [CpsTreeTableComponent]\n    }\n  ]\n})\nexport class CpsTreeTableComponent\n  implements OnInit, AfterViewInit, OnDestroy, AfterViewChecked, OnChanges\n{\n  @Input() data: any[] = [];\n  @Input() columns: { [key: string]: any }[] = [];\n  @Input() colHeaderName = 'header';\n  @Input() colFieldName = 'field';\n\n  @Input() striped = true;\n  @Input() bordered = true;\n  @Input() size: CpsTreeTableSize = 'normal';\n  @Input() selectable = false;\n  @Input() rowHover = true;\n  @Input() showRowMenu = false;\n  @Input() loading = false;\n\n  @Input() tableStyle = undefined;\n  @Input() tableStyleClass = '';\n\n  @Input() sortable = false; // makes all sortable if columns are provided\n  @Input() sortMode: CpsTreeTableSortMode = 'single';\n  @Input() customSort = false;\n\n  @Input() hasToolbar = true;\n  @Input() toolbarSize: CpsTreeTableToolbarSize = 'normal';\n  @Input() toolbarTitle = '';\n  @Input() toolbarIcon = '';\n  @Input() toolbarIconColor = '';\n\n  @Input() scrollable = true;\n  @Input() scrollHeight = ''; // 'flex' or value+'px'\n  @Input() virtualScroll = false; // works only if scrollable is true\n  @Input() numToleratedItems = 10;\n\n  @Input() paginator = false;\n  @Input() alwaysShowPaginator = true;\n  @Input() rowsPerPageOptions: number[] = [];\n  @Input() first = 0;\n  @Input() rows = 0;\n  @Input() resetPageOnRowsChange = false;\n  @Input() resetPageOnSort = true;\n  @Input() totalRecords = 0;\n\n  @Input() emptyMessage = 'No data';\n  @Input() emptyBodyHeight: number | string = '';\n\n  @Input() lazy = false;\n  @Input() lazyLoadOnInit = true;\n\n  @Input() showGlobalFilter = false;\n  @Input() globalFilterPlaceholder = 'Search';\n  @Input() globalFilterFields: string[] = [];\n  @Input() clearGlobalFilterOnLoading = false;\n\n  @Input() showRemoveBtnOnSelect = true;\n  @Input() removeBtnOnSelectDisabled = false;\n\n  @Input() showAdditionalBtnOnSelect = false;\n  @Input() additionalBtnOnSelectTitle = 'Select action';\n  @Input() additionalBtnOnSelectDisabled = false;\n\n  @Input() showActionBtn = false;\n  @Input() actionBtnTitle = 'Action';\n  @Input() actionBtnDisabled = false;\n\n  @Input() showDataReloadBtn = false;\n  @Input() dataReloadBtnDisabled = false;\n\n  @Input() showColumnsToggleBtn = false; // if external body template is provided, use columnsSelected event emitter\n  @Input() columnsToggleBtnDisabled = false;\n\n  @Output() selectionChanged = new EventEmitter<any[]>();\n  @Output() actionBtnClicked = new EventEmitter<void>();\n  @Output() additionalBtnOnSelectClicked = new EventEmitter<any[]>();\n  @Output() editRowBtnClicked = new EventEmitter<any>();\n  @Output() rowsRemoved = new EventEmitter<any[]>();\n  @Output() pageChanged = new EventEmitter<any>();\n  @Output() sorted = new EventEmitter<any>();\n  @Output() filtered = new EventEmitter<any>();\n  @Output() columnsSelected = new EventEmitter<{ [key: string]: any }[]>();\n  @Output() lazyLoaded = new EventEmitter<any>();\n  @Output() dataReloadBtnClicked = new EventEmitter<any>();\n  @Output() nodeExpanded = new EventEmitter<any>();\n  @Output() nodeCollapsed = new EventEmitter<any>();\n  @Output() nodeSelected = new EventEmitter<any>();\n  @Output() nodeUnselected = new EventEmitter<any>();\n\n  /**\n   * A function to implement custom sorting. customSort must be true.\n   * @param {any} any - sort meta.\n   * @group Emits\n   */\n  @Output() customSortFunction: EventEmitter<any> = new EventEmitter<any>();\n\n  @ContentChild('toolbar', { static: false })\n  public toolbarTemplate!: TemplateRef<any>;\n\n  @ContentChild('header', { static: false })\n  public headerTemplate!: TemplateRef<any>;\n\n  @ContentChild('nestedHeader', { static: false })\n  public nestedHeaderTemplate!: TemplateRef<any>;\n\n  @ContentChild('body', { static: false })\n  public bodyTemplate!: TemplateRef<any>;\n\n  @ViewChild('primengTreeTable', { static: true })\n  primengTreeTable!: TreeTable;\n\n  @ViewChild('globalFilterComp')\n  globalFilterComp!: CpsInputComponent;\n\n  @ViewChild('colToggleMenu')\n  colToggleMenu!: CpsMenuComponent;\n\n  selectedColumns: { [key: string]: any }[] = [];\n\n  rowOptions: { label: string; value: number }[] = [];\n\n  selectedRows: any[] = [];\n\n  virtualScrollItemSize = 0;\n  defScrollHeightPx = 0;\n  defScrollHeight = '';\n\n  resizeObserver: ResizeObserver;\n  headerBox: any;\n  scrollableBody: any;\n  scrollbarWidth = 0;\n\n  // eslint-disable-next-line no-useless-constructor\n  constructor(private cdRef: ChangeDetectorRef) {\n    this.resizeObserver = new ResizeObserver((entries) => {\n      entries.forEach((entry) => {\n        const body = entry.target;\n        const sbarVisible = body.scrollHeight > body.clientHeight;\n\n        let wScroll = sbarVisible ? this.scrollbarWidth : 0;\n        if (wScroll > 0) wScroll -= 1;\n\n        this.headerBox.style.paddingRight = `${wScroll}px`;\n        this.headerBox.style.borderRight =\n          wScroll > 0 ? '1px solid #d7d5d5' : 'unset';\n      });\n    });\n  }\n\n  ngOnInit(): void {\n    this.emptyBodyHeight = convertSize(this.emptyBodyHeight);\n    if (!this.scrollable) this.virtualScroll = false;\n\n    if (this.showAdditionalBtnOnSelect) this.showRemoveBtnOnSelect = false;\n\n    if (this.virtualScroll) {\n      this.defScrollHeight = this.scrollHeight;\n\n      if (this.defScrollHeight === 'flex')\n        window.addEventListener('resize', this._onWindowResize.bind(this));\n\n      if (this.defScrollHeight && this.defScrollHeight !== 'flex') {\n        this.defScrollHeightPx = parseInt(this.scrollHeight, 10);\n      }\n    }\n\n    if (this.paginator) {\n      if (this.rowsPerPageOptions.length < 1)\n        this.rowsPerPageOptions = [5, 10, 25, 50];\n\n      if (!this.rows) this.rows = this.rowsPerPageOptions[0];\n      else {\n        if (!this.rowsPerPageOptions.includes(this.rows)) {\n          throw new Error('rowsPerPageOptions must include rows');\n        }\n      }\n\n      this.rowOptions = this.rowsPerPageOptions.map((v) => ({\n        label: '' + v,\n        value: v\n      }));\n    }\n\n    if (\n      this.showGlobalFilter &&\n      this.globalFilterFields?.length < 1 &&\n      this.data?.length > 0\n    ) {\n      this.globalFilterFields = Object.keys(this.data[0].data);\n    }\n\n    this.selectedColumns = this.columns;\n  }\n\n  ngAfterViewInit(): void {\n    this.scrollableBody = this.primengTreeTable.el.nativeElement.querySelector(\n      '.p-treetable-scrollable-body'\n    );\n    if (this.scrollableBody) {\n      this.headerBox = this.primengTreeTable.el.nativeElement.querySelector(\n        '.p-treetable-scrollable-header-box'\n      );\n      if (this.virtualScroll && this.defScrollHeight === 'flex')\n        this.defScrollHeightPx = this.scrollableBody.clientHeight;\n\n      if (this.headerBox) {\n        this.scrollbarWidth = DomHandler.calculateScrollbarWidth();\n        this.resizeObserver.observe(this.scrollableBody);\n      }\n    }\n  }\n\n  ngAfterViewChecked() {\n    if (!this.virtualScroll || this.virtualScrollItemSize) return;\n    this.virtualScrollItemSize =\n      this.primengTreeTable?.el?.nativeElement\n        ?.querySelector('.p-treetable-tbody')\n        ?.querySelector('tr')?.clientHeight || 0;\n    this.cdRef.detectChanges();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (this.loading) {\n      this.clearSelection();\n      if (this.clearGlobalFilterOnLoading) this.clearGlobalFilter();\n    }\n\n    const dataChanges = changes?.data;\n    if (dataChanges?.previousValue !== dataChanges?.currentValue) {\n      this.clearSelection();\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.resizeObserver?.disconnect();\n    if (this.virtualScroll && this.defScrollHeight === 'flex')\n      window.removeEventListener('resize', this._onWindowResize.bind(this));\n  }\n\n  clearGlobalFilter() {\n    this.globalFilterComp?.clear();\n  }\n\n  private _onWindowResize() {\n    this.defScrollHeightPx = this.scrollableBody.clientHeight;\n  }\n\n  get styleClass() {\n    const classesList = [];\n    switch (this.size) {\n      case 'small':\n        classesList.push('p-treetable-sm');\n        break;\n      case 'large':\n        classesList.push('p-treetable-lg');\n        break;\n    }\n    if (this.hasToolbar) {\n      switch (this.toolbarSize) {\n        case 'small':\n          classesList.push('cps-tbar-small');\n          break;\n        case 'normal':\n          classesList.push('cps-tbar-normal');\n          break;\n      }\n    }\n    if (this.striped) {\n      classesList.push('p-treetable-striped');\n    }\n    if (this.bordered) {\n      classesList.push('p-treetable-gridlines');\n    }\n\n    if (this.scrollHeight && !this.loading && this.data.length > 0) {\n      classesList.push('cps-treetable-bottom-bordered');\n    }\n\n    return classesList.join(' ');\n  }\n\n  onSortFunction(event: SortEvent) {\n    this.customSortFunction.emit(event);\n  }\n\n  private _recalcVirtualHeight() {\n    if (this.virtualScroll && this.defScrollHeight) {\n      const itemsLen = this.primengTreeTable.serializedValue.length;\n      if (itemsLen < 1) {\n        this.scrollHeight = this.emptyBodyHeight\n          ? (`calc(${this.emptyBodyHeight} + 1px)` as string)\n          : this.virtualScrollItemSize + 1 + 'px';\n      } else {\n        const curHeight = this.virtualScrollItemSize * itemsLen + 2;\n        if (this.defScrollHeight === 'flex') {\n          if (curHeight >= this.defScrollHeightPx) {\n            this.scrollHeight = 'flex';\n            setTimeout(() => {\n              this.scrollableBody.style.height = '100%';\n              this.cdRef.markForCheck();\n            });\n            return;\n          }\n        }\n        this.scrollHeight = Math.min(this.defScrollHeightPx, curHeight) + 'px';\n      }\n    }\n  }\n\n  onFilterGlobal(value: string) {\n    this.primengTreeTable.filterGlobal(value, 'contains');\n  }\n\n  onClickAdditionalBtnOnSelect() {\n    this.additionalBtnOnSelectClicked.emit(this.selectedRows);\n  }\n\n  onClickActionBtn() {\n    this.actionBtnClicked.emit();\n  }\n\n  onReloadData() {\n    if (this.dataReloadBtnDisabled) return;\n    this.dataReloadBtnClicked.emit();\n  }\n\n  onColumnsToggle(event: any) {\n    if (this.columnsToggleBtnDisabled) return;\n    this.colToggleMenu?.toggle(event);\n  }\n\n  removeSelected() {\n    this.selectedRows.forEach((row) => this._removeNodeFromData(row, false));\n    this.data = [...this.data];\n    this.rowsRemoved.emit(this.selectedRows);\n    this.clearSelection();\n    setTimeout(() => {\n      this._recalcVirtualHeight();\n      this.cdRef.markForCheck();\n    });\n  }\n\n  clearSelection() {\n    this.selectedRows = [];\n  }\n\n  onEditRowClicked(node: any) {\n    this.editRowBtnClicked.emit(node);\n  }\n\n  onRemoveRowClicked(node: any) {\n    this.selectedRows = this.selectedRows.filter((v: any) => v !== node);\n    this._removeNodeFromData(node);\n    this.rowsRemoved.emit([node]);\n    setTimeout(() => {\n      this._recalcVirtualHeight();\n      this.cdRef.markForCheck();\n    });\n  }\n\n  private _removeNodeFromData(nodeToRemove: any, single = true): void {\n    const _findTopSortOrder = (_node: any): any => {\n      if (!_node) return undefined;\n      if (typeof _node._defaultSortOrder === 'number')\n        return _node._defaultSortOrder;\n      return _findTopSortOrder(_node.parent);\n    };\n\n    const _removeFromChildren = (_node: any) => {\n      if (!_node?.children) return false;\n      const idx = _node.children.indexOf(nodeToRemove);\n      if (idx >= 0) {\n        _node.children.splice(idx, 1);\n        if (_node.children.length === 0) {\n          delete _node.children;\n        }\n        return true;\n      } else {\n        for (const child of _node.children) {\n          if (_removeFromChildren(child)) return true;\n        }\n        return false;\n      }\n    };\n\n    // locate top level node\n    const sortOrder = _findTopSortOrder(nodeToRemove);\n    if (sortOrder === undefined) return;\n    const node = this.data.find((n) => n._defaultSortOrder === sortOrder);\n    if (!node) return;\n\n    // remove the node itself or remove its child\n    if (nodeToRemove === node) {\n      this.data = this.data.filter((v: any) => v !== nodeToRemove);\n    } else {\n      if (node.children) {\n        _removeFromChildren(node);\n        if (single) this.data = [...this.data];\n      }\n    }\n  }\n\n  toggleAllColumns() {\n    this.selectedColumns =\n      this.selectedColumns.length < this.columns.length ? this.columns : [];\n    this.columnsSelected.emit(this.selectedColumns);\n  }\n\n  isColumnSelected(col: any) {\n    return !!find(this.selectedColumns, (item) => isEqual(item, col));\n  }\n\n  onRowsPerPageChanged() {\n    if (this.resetPageOnRowsChange) {\n      this.primengTreeTable.first = 0;\n    }\n    this.changePage(this.getPage());\n  }\n\n  getPageCount() {\n    return Math.ceil(this.primengTreeTable.totalRecords / this.rows);\n  }\n\n  getPage(): number {\n    return Math.floor(this.primengTreeTable.first / this.rows);\n  }\n\n  changePage(p: number) {\n    const pc = Math.ceil(this.getPageCount());\n\n    if (p >= 0 && p < pc) {\n      this.first = this.rows * p;\n      this.primengTreeTable.onPageChange({\n        first: this.first,\n        rows: this.rows\n      });\n    }\n  }\n\n  onPageChange(event: any) {\n    this.first = event.first;\n    this.rows = event.rows;\n\n    const state = {\n      page: this.getPage(),\n      first: this.first,\n      rows: this.rows,\n      pageCount: Math.ceil(this.getPageCount())\n    };\n\n    this.pageChanged.emit(state);\n  }\n\n  onLazyLoaded(event: any) {\n    this.lazyLoaded.emit(event);\n  }\n\n  onNodeExpanded(event: any) {\n    this.nodeExpanded.emit(event);\n    setTimeout(() => {\n      this._recalcVirtualHeight();\n      this.cdRef.markForCheck();\n    });\n  }\n\n  onNodeCollapsed(event: any) {\n    this.nodeCollapsed.emit(event);\n    setTimeout(() => {\n      this._recalcVirtualHeight();\n      this.cdRef.markForCheck();\n    });\n  }\n\n  onNodeSelected(event: any) {\n    this.nodeSelected.emit(event);\n  }\n\n  onNodeUnselected(event: any) {\n    this.nodeUnselected.emit(event);\n  }\n\n  onSort(event: any) {\n    this.sorted.emit(event);\n  }\n\n  onFilter(event: any) {\n    this.filtered.emit(event);\n    setTimeout(() => {\n      this._recalcVirtualHeight();\n      this.cdRef.markForCheck();\n    });\n  }\n\n  onSelectColumn(col: any) {\n    let res = [] as any;\n    if (this.isColumnSelected(col)) {\n      res = this.selectedColumns.filter((v: any) => !isEqual(v, col));\n    } else {\n      this.columns.forEach((o) => {\n        if (\n          this.selectedColumns.some((v: any) => isEqual(v, o)) ||\n          isEqual(col, o)\n        ) {\n          res.push(o);\n        }\n      });\n    }\n    this.selectedColumns = res;\n    this.columnsSelected.emit(this.selectedColumns);\n  }\n\n  onSelectionChanged(selection: any[]) {\n    this.selectionChanged.emit(selection);\n  }\n}\n","<p-treeTable\n  #primengTreeTable\n  ttWithUnsort\n  [ngClass]=\"{ 'cps-treetable-loading': loading }\"\n  [value]=\"data\"\n  [scrollable]=\"scrollable\"\n  [scrollHeight]=\"scrollHeight\"\n  [virtualScroll]=\"virtualScroll\"\n  [virtualScrollItemSize]=\"virtualScrollItemSize\"\n  [virtualScrollOptions]=\"{\n    numToleratedItems: numToleratedItems,\n    autoSize: false\n  }\"\n  [columns]=\"selectedColumns\"\n  [loading]=\"loading\"\n  [rowHover]=\"rowHover\"\n  [lazy]=\"lazy\"\n  [(selection)]=\"selectedRows\"\n  (selectionChange)=\"onSelectionChanged($event)\"\n  compareSelectionBy=\"equals\"\n  [lazyLoadOnInit]=\"lazyLoadOnInit\"\n  [styleClass]=\"styleClass\"\n  [tableStyle]=\"tableStyle\"\n  [tableStyleClass]=\"tableStyleClass\"\n  [customSort]=\"customSort\"\n  [sortMode]=\"sortMode\"\n  [globalFilterFields]=\"globalFilterFields\"\n  [paginator]=\"paginator\"\n  [showCurrentPageReport]=\"true\"\n  [alwaysShowPaginator]=\"alwaysShowPaginator\"\n  [rows]=\"rows\"\n  [first]=\"first\"\n  [totalRecords]=\"totalRecords\"\n  [resetPageOnSort]=\"resetPageOnSort\"\n  currentPageReportTemplate=\"{first} - {last} of {totalRecords}\"\n  (onPage)=\"onPageChange($event)\"\n  (onSort)=\"onSort($event)\"\n  (onFilter)=\"onFilter($event)\"\n  (onLazyLoad)=\"onLazyLoaded($event)\"\n  (sortFunction)=\"onSortFunction($event)\"\n  (onNodeExpand)=\"onNodeExpanded($event)\"\n  (onNodeCollapse)=\"onNodeCollapsed($event)\"\n  (onNodeSelect)=\"onNodeSelected($event)\"\n  (onNodeUnselect)=\"onNodeUnselected($event)\">\n  <ng-template pTemplate=\"caption\" *ngIf=\"hasToolbar\">\n    <ng-container *ngIf=\"toolbarTemplate\">\n      <ng-container *ngTemplateOutlet=\"toolbarTemplate\"></ng-container>\n    </ng-container>\n    <ng-container *ngIf=\"!toolbarTemplate\">\n      <div class=\"cps-treetable-tbar-left\">\n        <div *ngIf=\"toolbarIcon\" class=\"cps-treetable-tbar-icon\">\n          <cps-icon [icon]=\"toolbarIcon\" [color]=\"toolbarIconColor\"></cps-icon>\n        </div>\n        <div class=\"cps-treetable-tbar-title\">{{ toolbarTitle }}</div>\n        <div *ngIf=\"showGlobalFilter\" class=\"cps-treetable-tbar-global-filter\">\n          <cps-input\n            #globalFilterComp\n            prefixIcon=\"search\"\n            [placeholder]=\"globalFilterPlaceholder\"\n            (valueChanged)=\"onFilterGlobal($event)\"\n            [clearable]=\"true\"\n            [disabled]=\"loading\"\n            [appearance]=\"toolbarSize === 'small' ? 'underlined' : 'outlined'\"\n            [hideDetails]=\"true\">\n          </cps-input>\n        </div>\n      </div>\n      <div class=\"cps-treetable-tbar-right\">\n        <div\n          *ngIf=\"showRemoveBtnOnSelect && selectedRows.length > 0\"\n          class=\"cps-treetable-tbar-btn-on-select\">\n          <cps-button\n            label=\"Remove\"\n            [disabled]=\"removeBtnOnSelectDisabled\"\n            color=\"prepared\"\n            type=\"borderless\"\n            icon=\"remove\"\n            [size]=\"toolbarSize\"\n            (clicked)=\"removeSelected()\">\n          </cps-button>\n        </div>\n        <div\n          *ngIf=\"showAdditionalBtnOnSelect && selectedRows.length > 0\"\n          class=\"cps-treetable-tbar-btn-on-select\">\n          <cps-button\n            [label]=\"additionalBtnOnSelectTitle\"\n            [disabled]=\"additionalBtnOnSelectDisabled\"\n            color=\"prepared\"\n            type=\"borderless\"\n            [size]=\"toolbarSize\"\n            (clicked)=\"onClickAdditionalBtnOnSelect()\">\n          </cps-button>\n        </div>\n        <div *ngIf=\"showActionBtn\" class=\"cps-treetable-tbar-action-btn\">\n          <cps-button\n            [label]=\"actionBtnTitle\"\n            [disabled]=\"actionBtnDisabled\"\n            color=\"prepared\"\n            type=\"outlined\"\n            [size]=\"toolbarSize\"\n            (clicked)=\"onClickActionBtn()\">\n          </cps-button>\n        </div>\n        <div\n          *ngIf=\"showColumnsToggleBtn && columns.length > 0\"\n          class=\"cps-treetable-tbar-coltoggle-btn\"\n          [ngClass]=\"{ 'btn-disabled': columnsToggleBtnDisabled }\">\n          <cps-icon\n            icon=\"columns\"\n            size=\"normal\"\n            [color]=\"\n              columnsToggleBtnDisabled ? 'text-lightest' : 'prepared-lighten1'\n            \"\n            (click)=\"onColumnsToggle($event)\"></cps-icon>\n          <cps-menu #colToggleMenu [withArrow]=\"false\">\n            <div class=\"cps-treetable-coltoggle-menu\">\n              <div\n                class=\"cps-treetable-coltoggle-menu-item select-all-option\"\n                [class.allselected]=\"selectedColumns.length === columns.length\"\n                (click)=\"toggleAllColumns()\">\n                <span class=\"cps-treetable-coltoggle-menu-item-left\">\n                  <span class=\"cps-treetable-coltoggle-menu-item-check\"> </span>\n                  <span class=\"cps-treetable-coltoggle-menu-item-label\"\n                    >Show all columns</span\n                  >\n                </span>\n              </div>\n              <div\n                *ngFor=\"let col of columns\"\n                class=\"cps-treetable-coltoggle-menu-item\"\n                (click)=\"onSelectColumn(col)\"\n                [class.selected]=\"isColumnSelected(col)\">\n                <span class=\"cps-treetable-coltoggle-menu-item-left\">\n                  <span class=\"cps-treetable-coltoggle-menu-item-check\"></span>\n                  <span class=\"cps-treetable-coltoggle-menu-item-label\">{{\n                    col[colHeaderName]\n                  }}</span>\n                </span>\n              </div>\n            </div>\n          </cps-menu>\n        </div>\n        <div\n          *ngIf=\"showDataReloadBtn\"\n          class=\"cps-treetable-tbar-reload-btn\"\n          [ngClass]=\"{ 'btn-disabled': dataReloadBtnDisabled }\">\n          <cps-icon\n            icon=\"refresh\"\n            size=\"18\"\n            [color]=\"dataReloadBtnDisabled ? 'text-light' : 'prepared-lighten1'\"\n            (click)=\"onReloadData()\">\n          </cps-icon>\n        </div>\n      </div>\n    </ng-container>\n  </ng-template>\n\n  <ng-template pTemplate=\"header\" *ngIf=\"nestedHeaderTemplate\" let-columns>\n    <ng-container\n      *ngTemplateOutlet=\"\n      nestedHeaderTemplate;\n        context: {\n          $implicit: columns,\n        }\n      \"></ng-container>\n  </ng-template>\n\n  <ng-template pTemplate=\"header\" *ngIf=\"!nestedHeaderTemplate\" let-columns>\n    <tr>\n      <!-- <th style=\"width: 3rem\" *ngIf=\"reorderableRows\"></th> -->\n      <th style=\"width: 55px\" *ngIf=\"selectable\">\n        <p-treeTableHeaderCheckbox></p-treeTableHeaderCheckbox>\n      </th>\n      <ng-container *ngIf=\"headerTemplate\">\n        <ng-container\n          *ngTemplateOutlet=\"\n            headerTemplate;\n            context: {\n              $implicit: columns,\n            }\n          \"></ng-container>\n      </ng-container>\n      <ng-container *ngIf=\"!headerTemplate && columns.length > 0\">\n        <ng-container *ngIf=\"sortable\">\n          <th\n            *ngFor=\"let col of columns\"\n            [cpsTTColSortable]=\"col[colFieldName]\">\n            {{ col[colHeaderName] }}\n          </th>\n        </ng-container>\n        <ng-container *ngIf=\"!sortable\">\n          <th *ngFor=\"let col of columns\">\n            {{ col[colHeaderName] }}\n          </th>\n        </ng-container>\n      </ng-container>\n      <th class=\"cps-treetable-row-menu-cell\" *ngIf=\"showRowMenu\"></th>\n    </tr>\n  </ng-template>\n\n  <ng-template\n    pTemplate=\"body\"\n    let-rowData=\"rowData\"\n    let-columns=\"columns\"\n    let-rowNode\n    let-rowIndex=\"rowIndex\">\n    <tr\n      [ttRow]=\"rowNode\"\n      [ngClass]=\"{\n        'cps-treetable-row-selected':\n          selectable && primengTreeTable.isSelected(rowNode.node)\n      }\">\n      <!-- <td *ngIf=\"reorderableRows\" class=\"cps-table-row-drag-handle-cell\">\n        <span class=\"cps-table-row-drag-handle\" pReorderableRowHandle>☰</span>\n      </td> -->\n      <td style=\"width: 55px\" *ngIf=\"selectable\">\n        <p-treeTableCheckbox [value]=\"rowNode\"></p-treeTableCheckbox>\n      </td>\n      <ng-container *ngIf=\"bodyTemplate\">\n        <ng-container\n          *ngTemplateOutlet=\"\n            bodyTemplate;\n            context: {\n              $implicit: rowNode,\n              rowIndex: rowIndex,\n              columns: columns,\n              rowData: rowData\n            }\n          \">\n        </ng-container>\n      </ng-container>\n      <ng-container *ngIf=\"!bodyTemplate\">\n        <ng-container *ngIf=\"columns.length > 0\">\n          <td *ngFor=\"let col of columns; let i = index\">\n            <p-treeTableToggler [rowNode]=\"rowNode\" *ngIf=\"i === 0\">\n            </p-treeTableToggler>\n            {{ rowData[col[colFieldName]] }}\n          </td>\n        </ng-container>\n      </ng-container>\n      <td *ngIf=\"showRowMenu\" class=\"cps-treetable-row-menu-cell\">\n        <table-row-menu\n          (editRowBtnClicked)=\"onEditRowClicked(rowNode.node)\"\n          (removeRowBtnClicked)=\"onRemoveRowClicked(rowNode.node)\">\n        </table-row-menu>\n      </td>\n    </tr>\n  </ng-template>\n  <ng-template pTemplate=\"emptymessage\">\n    <tr>\n      <td\n        colspan=\"100\"\n        class=\"cps-treetable-empty-message-td\"\n        [ngStyle]=\"{ height: emptyBodyHeight }\">\n        {{ emptyMessage }}\n      </td>\n    </tr>\n  </ng-template>\n  <ng-template pTemplate=\"loadingicon\">\n    <cps-loader [fullScreen]=\"false\" opacity=\"0\"></cps-loader>\n  </ng-template>\n  <ng-template pTemplate=\"paginatorleft\">\n    <div class=\"cps-table-paginator-itms-per-page\">\n      <span class=\"cps-table-paginator-items-per-page-title\"\n        >Rows per page:\n      </span>\n      <cps-select\n        [options]=\"rowOptions\"\n        [hideDetails]=\"true\"\n        [(ngModel)]=\"rows\"\n        (valueChanged)=\"onRowsPerPageChanged()\"\n        [returnObject]=\"false\"\n        optionsClass=\"cps-paginator-page-options\">\n      </cps-select>\n    </div>\n  </ng-template>\n\n  <ng-template pTemplate=\"paginatorfirstpagelinkicon\">\n    <AngleDoubleLeftIcon />\n  </ng-template>\n  <ng-template pTemplate=\"paginatorpreviouspagelinkicon\">\n    <AngleLeftIcon />\n  </ng-template>\n  <ng-template pTemplate=\"paginatornextpagelinkicon\">\n    <AngleRightIcon />\n  </ng-template>\n  <ng-template pTemplate=\"paginatorlastpagelinkicon\">\n    <AngleDoubleRightIcon />\n  </ng-template>\n</p-treeTable>\n"]}
|
package/fesm2015/cps-ui-kit.mjs
CHANGED
|
@@ -4008,13 +4008,19 @@ class CpsTableComponent {
|
|
|
4008
4008
|
}
|
|
4009
4009
|
ngOnChanges(changes) {
|
|
4010
4010
|
var _a, _b;
|
|
4011
|
-
if (this.loading
|
|
4012
|
-
this.
|
|
4011
|
+
if (this.loading) {
|
|
4012
|
+
this.clearSelection();
|
|
4013
|
+
if (this.clearGlobalFilterOnLoading)
|
|
4014
|
+
this.clearGlobalFilter();
|
|
4015
|
+
}
|
|
4013
4016
|
const dataChanges = changes === null || changes === void 0 ? void 0 : changes.data;
|
|
4014
4017
|
if (((_a = dataChanges === null || dataChanges === void 0 ? void 0 : dataChanges.previousValue) === null || _a === void 0 ? void 0 : _a.length) !== ((_b = dataChanges === null || dataChanges === void 0 ? void 0 : dataChanges.currentValue) === null || _b === void 0 ? void 0 : _b.length)) {
|
|
4015
4018
|
this.selectedRows = this.selectedRows.filter((sr) => this.data.includes(sr));
|
|
4016
4019
|
}
|
|
4017
4020
|
}
|
|
4021
|
+
clearSelection() {
|
|
4022
|
+
this.selectedRows = [];
|
|
4023
|
+
}
|
|
4018
4024
|
clearGlobalFilter() {
|
|
4019
4025
|
var _a;
|
|
4020
4026
|
(_a = this.globalFilterComp) === null || _a === void 0 ? void 0 : _a.clear();
|
|
@@ -4033,7 +4039,7 @@ class CpsTableComponent {
|
|
|
4033
4039
|
indexes.sort((a, b) => b - a);
|
|
4034
4040
|
this.data = this.data.filter((v) => !indexes.includes(v._defaultSortOrder));
|
|
4035
4041
|
this.rowsRemoved.emit(this.selectedRows);
|
|
4036
|
-
this.
|
|
4042
|
+
this.clearSelection();
|
|
4037
4043
|
}
|
|
4038
4044
|
onClickAdditionalBtnOnSelect() {
|
|
4039
4045
|
this.additionalBtnOnSelectClicked.emit(this.selectedRows);
|
|
@@ -5242,7 +5248,7 @@ class TableColumnFilterComponent {
|
|
|
5242
5248
|
}
|
|
5243
5249
|
}
|
|
5244
5250
|
TableColumnFilterComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TableColumnFilterComponent, deps: [{ token: i0.ElementRef }, { token: i1$2.Table, optional: true }, { token: i1$3.TreeTable, optional: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
5245
|
-
TableColumnFilterComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: TableColumnFilterComponent, isStandalone: true, selector: "table-column-filter", inputs: { field: "field", type: "type", persistent: "persistent", showClearButton: "showClearButton", showApplyButton: "showApplyButton", showCloseButton: "showCloseButton", showMatchModes: "showMatchModes", matchModes: "matchModes", showOperator: "showOperator", maxConstraints: "maxConstraints", headerTitle: "headerTitle", hideOnClear: "hideOnClear", categoryOptions: "categoryOptions", asButtonToggle: "asButtonToggle", singleSelection: "singleSelection", placeholder: "placeholder" }, host: { listeners: { "click": "onClick($event)" } }, viewQueries: [{ propertyName: "columnFilterMenu", first: true, predicate: ["columnFilterMenu"], descendants: true }, { propertyName: "constraintCompList", predicate: ["constraintComponent"], descendants: true }], ngImport: i0, template: "<div class=\"cps-table-col-filter\">\n <cps-menu\n #columnFilterMenu\n [withArrow]=\"false\"\n [persistent]=\"persistent || (showApplyButton && isCategoryDropdownOpened)\"\n (menuShown)=\"onMenuShown()\"\n (menuHidden)=\"onMenuHidden()\"\n (beforeMenuHidden)=\"onBeforeMenuHidden()\">\n <div class=\"cps-table-col-filter-menu-content\">\n <div\n class=\"cps-table-col-filter-menu-content-header\"\n *ngIf=\"showCloseButton || headerTitle\">\n <span class=\"cps-table-col-filter-menu-content-header-title\">\n {{ headerTitle }}\n </span>\n <cps-icon\n *ngIf=\"showCloseButton\"\n icon=\"close-x\"\n (click)=\"onCloseClick()\"></cps-icon>\n </div>\n <div\n class=\"cps-table-col-filter-menu-content-operator\"\n *ngIf=\"isShowOperator\">\n <cps-select\n [hideDetails]=\"true\"\n [disabled]=\"!fieldConstraints || fieldConstraints.length < 2\"\n [returnObject]=\"false\"\n [options]=\"operatorOptions\"\n [ngModel]=\"operator\"\n (valueChanged)=\"onOperatorChange($event)\"></cps-select>\n </div>\n <div class=\"cps-table-col-filter-menu-content-constraints\">\n <div\n *ngFor=\"let fieldConstraint of fieldConstraints; let i = index\"\n class=\"cps-table-col-filter-menu-content-constraint\">\n <cps-select\n *ngIf=\"showMatchModes && currentMatchModes\"\n class=\"cps-table-col-filter-match-mode-select\"\n [hideDetails]=\"true\"\n [returnObject]=\"false\"\n [options]=\"currentMatchModes\"\n [ngModel]=\"fieldConstraint.matchMode\"\n (valueChanged)=\"\n onMenuMatchModeChange($event, fieldConstraint)\n \"></cps-select>\n <table-column-filter-constraint\n #constraintComponent\n [type]=\"type\"\n [field]=\"field\"\n [asButtonToggle]=\"asButtonToggle\"\n [singleSelection]=\"singleSelection\"\n [categoryOptions]=\"categoryOptions\"\n [filterConstraint]=\"fieldConstraint\"\n [hasApplyButton]=\"showApplyButton\"\n [placeholder]=\"placeholder\">\n </table-column-filter-constraint>\n <div\n class=\"cps-table-col-filter-remove-rule-btn\"\n *ngIf=\"showRemoveIcon\">\n <cps-button\n type=\"borderless\"\n width=\"100%\"\n size=\"small\"\n color=\"prepared\"\n icon=\"delete\"\n (clicked)=\"removeConstraint(fieldConstraint)\"\n label=\"Remove condition\">\n </cps-button>\n </div>\n </div>\n </div>\n <div\n class=\"cps-table-col-filter-add-rule-btn\"\n *ngIf=\"isShowAddConstraint\">\n <cps-button\n label=\"Add condition\"\n type=\"borderless\"\n width=\"100%\"\n size=\"small\"\n color=\"surprise\"\n icon=\"add\"\n (clicked)=\"addConstraint()\">\n </cps-button>\n </div>\n <div class=\"cps-table-col-filter-buttonbar\">\n <cps-button\n *ngIf=\"showClearButton\"\n (clicked)=\"clearFilter()\"\n type=\"borderless\"\n color=\"prepared\"\n size=\"small\"\n label=\"Clear\"></cps-button>\n <cps-button\n *ngIf=\"showApplyButton\"\n (clicked)=\"applyFilter()\"\n color=\"prepared\"\n size=\"small\"\n label=\"Apply\"></cps-button>\n </div>\n </div>\n </cps-menu>\n <cps-icon\n [icon]=\"isFilterApplied ? 'filter-funnel-filled' : 'filter-funnel'\"\n size=\"13\"\n (click)=\"columnFilterMenu.toggle($event)\"\n class=\"cps-table-col-filter-menu-button\"\n [ngClass]=\"{\n 'cps-table-col-filter-menu-button-active': isFilterApplied\n }\"\n >>\n </cps-icon>\n</div>\n", styles: [":host .cps-table-col-filter{display:inline-flex}:host .cps-table-col-filter .cps-table-col-filter-menu-button{display:inline-flex;justify-content:center;align-items:center;cursor:pointer;text-decoration:none;overflow:hidden;position:relative;padding-left:12px;padding-right:4px}:host .cps-table-col-filter .cps-table-col-filter-menu-button:not(.cps-table-col-filter-menu-button-active):hover{color:var(--cps-color-text-dark)}:host .cps-table-col-filter .cps-table-col-filter-menu-button-active{color:var(--cps-color-calm-lighten1)}.cps-table-col-filter-menu-content{padding-bottom:12px;min-width:200px;max-height:500px;overflow:auto}.cps-table-col-filter-menu-content .cps-table-col-filter-menu-content-header{min-height:32px;padding:8px;border-bottom:1px solid var(--cps-color-line-mid);background:var(--cps-color-bg-light);display:flex;justify-content:space-between;align-items:center}.cps-table-col-filter-menu-content .cps-table-col-filter-menu-content-header-title{font-family:Source Sans Pro,sans-serif;color:var(--cps-color-text-darkest);max-width:390px}.cps-table-col-filter-menu-content .cps-table-col-filter-menu-content-header cps-icon{margin-left:8px;cursor:pointer}.cps-table-col-filter-menu-content .cps-table-col-filter-menu-content-header cps-icon:hover{color:var(--cps-color-calm)}.cps-table-col-filter-menu-content .cps-table-col-filter-menu-content-operator{padding:12px;border-bottom:1px solid var(--cps-color-line-mid);background:var(--cps-color-bg-light)}.cps-table-col-filter-menu-content .cps-table-col-filter-menu-content-constraints .cps-table-col-filter-menu-content-constraint{border-bottom:1px solid var(--cps-color-line-mid);padding:12px}.cps-table-col-filter-menu-content .cps-table-col-filter-menu-content-constraints .cps-table-col-filter-menu-content-constraint .cps-table-col-filter-match-mode-select{margin-bottom:8px}.cps-table-col-filter-menu-content .cps-table-col-filter-menu-content-constraints .cps-table-col-filter-menu-content-constraint:last-child{border-bottom:none}.cps-table-col-filter-menu-content .cps-table-col-filter-menu-content-constraints .cps-table-col-filter-remove-rule-btn{padding-top:8px}.cps-table-col-filter-menu-content .cps-table-col-filter-add-rule-btn{padding:8px 12px}.cps-table-col-filter-menu-content .cps-table-col-filter-buttonbar{display:flex;align-items:center;justify-content:space-between;padding:12px 12px 0}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: CpsButtonComponent, selector: "cps-button", inputs: ["color", "contentColor", "type", "label", "icon", "iconPosition", "size", "width", "height", "disabled", "loading"], outputs: ["clicked"] }, { kind: "component", type: CpsMenuComponent, selector: "cps-menu", inputs: ["header", "items", "withArrow", "compressed", "focusOnShow", "persistent", "containerClass", "showTransitionOptions", "hideTransitionOptions"], outputs: ["menuShown", "menuHidden", "beforeMenuHidden", "contentClicked"] }, { kind: "component", type: CpsIconComponent, selector: "cps-icon", inputs: ["icon", "size", "color"] }, { kind: "component", type: CpsSelectComponent, selector: "cps-select", inputs: ["label", "placeholder", "hint", "returnObject", "multiple", "disabled", "width", "selectAll", "chips", "closableChips", "clearable", "openOnClear", "options", "optionLabel", "optionValue", "optionInfo", "hideDetails", "persistentClear", "prefixIcon", "prefixIconSize", "loading", "virtualScroll", "numToleratedItems", "infoTooltip", "infoTooltipClass", "infoTooltipMaxWidth", "infoTooltipPersistent", "infoTooltipPosition", "optionsClass", "appearance", "value"], outputs: ["valueChanged"] }, { kind: "component", type: TableColumnFilterConstraintComponent, selector: "table-column-filter-constraint", inputs: ["type", "field", "filterConstraint", "categoryOptions", "asButtonToggle", "singleSelection", "placeholder", "hasApplyButton"] }] });
|
|
5251
|
+
TableColumnFilterComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: TableColumnFilterComponent, isStandalone: true, selector: "table-column-filter", inputs: { field: "field", type: "type", persistent: "persistent", showClearButton: "showClearButton", showApplyButton: "showApplyButton", showCloseButton: "showCloseButton", showMatchModes: "showMatchModes", matchModes: "matchModes", showOperator: "showOperator", maxConstraints: "maxConstraints", headerTitle: "headerTitle", hideOnClear: "hideOnClear", categoryOptions: "categoryOptions", asButtonToggle: "asButtonToggle", singleSelection: "singleSelection", placeholder: "placeholder" }, host: { listeners: { "click": "onClick($event)" } }, viewQueries: [{ propertyName: "columnFilterMenu", first: true, predicate: ["columnFilterMenu"], descendants: true }, { propertyName: "constraintCompList", predicate: ["constraintComponent"], descendants: true }], ngImport: i0, template: "<div class=\"cps-table-col-filter\">\n <cps-menu\n #columnFilterMenu\n [withArrow]=\"false\"\n hideTransitionOptions=\"0s linear\"\n [persistent]=\"persistent || (showApplyButton && isCategoryDropdownOpened)\"\n (menuShown)=\"onMenuShown()\"\n (menuHidden)=\"onMenuHidden()\"\n (beforeMenuHidden)=\"onBeforeMenuHidden()\">\n <div class=\"cps-table-col-filter-menu-content\">\n <div\n class=\"cps-table-col-filter-menu-content-header\"\n *ngIf=\"showCloseButton || headerTitle\">\n <span class=\"cps-table-col-filter-menu-content-header-title\">\n {{ headerTitle }}\n </span>\n <cps-icon\n *ngIf=\"showCloseButton\"\n icon=\"close-x\"\n (click)=\"onCloseClick()\"></cps-icon>\n </div>\n <div\n class=\"cps-table-col-filter-menu-content-operator\"\n *ngIf=\"isShowOperator\">\n <cps-select\n [hideDetails]=\"true\"\n [disabled]=\"!fieldConstraints || fieldConstraints.length < 2\"\n [returnObject]=\"false\"\n [options]=\"operatorOptions\"\n [ngModel]=\"operator\"\n (valueChanged)=\"onOperatorChange($event)\"></cps-select>\n </div>\n <div class=\"cps-table-col-filter-menu-content-constraints\">\n <div\n *ngFor=\"let fieldConstraint of fieldConstraints; let i = index\"\n class=\"cps-table-col-filter-menu-content-constraint\">\n <cps-select\n *ngIf=\"showMatchModes && currentMatchModes\"\n class=\"cps-table-col-filter-match-mode-select\"\n [hideDetails]=\"true\"\n [returnObject]=\"false\"\n [options]=\"currentMatchModes\"\n [ngModel]=\"fieldConstraint.matchMode\"\n (valueChanged)=\"\n onMenuMatchModeChange($event, fieldConstraint)\n \"></cps-select>\n <table-column-filter-constraint\n #constraintComponent\n [type]=\"type\"\n [field]=\"field\"\n [asButtonToggle]=\"asButtonToggle\"\n [singleSelection]=\"singleSelection\"\n [categoryOptions]=\"categoryOptions\"\n [filterConstraint]=\"fieldConstraint\"\n [hasApplyButton]=\"showApplyButton\"\n [placeholder]=\"placeholder\">\n </table-column-filter-constraint>\n <div\n class=\"cps-table-col-filter-remove-rule-btn\"\n *ngIf=\"showRemoveIcon\">\n <cps-button\n type=\"borderless\"\n width=\"100%\"\n size=\"small\"\n color=\"prepared\"\n icon=\"delete\"\n (clicked)=\"removeConstraint(fieldConstraint)\"\n label=\"Remove condition\">\n </cps-button>\n </div>\n </div>\n </div>\n <div\n class=\"cps-table-col-filter-add-rule-btn\"\n *ngIf=\"isShowAddConstraint\">\n <cps-button\n label=\"Add condition\"\n type=\"borderless\"\n width=\"100%\"\n size=\"small\"\n color=\"surprise\"\n icon=\"add\"\n (clicked)=\"addConstraint()\">\n </cps-button>\n </div>\n <div class=\"cps-table-col-filter-buttonbar\">\n <cps-button\n *ngIf=\"showClearButton\"\n (clicked)=\"clearFilter()\"\n type=\"borderless\"\n color=\"prepared\"\n size=\"small\"\n label=\"Clear\"></cps-button>\n <cps-button\n *ngIf=\"showApplyButton\"\n (clicked)=\"applyFilter()\"\n color=\"prepared\"\n size=\"small\"\n label=\"Apply\"></cps-button>\n </div>\n </div>\n </cps-menu>\n <cps-icon\n [icon]=\"isFilterApplied ? 'filter-funnel-filled' : 'filter-funnel'\"\n size=\"13\"\n (click)=\"columnFilterMenu.toggle($event)\"\n class=\"cps-table-col-filter-menu-button\"\n [ngClass]=\"{\n 'cps-table-col-filter-menu-button-active': isFilterApplied\n }\"\n >>\n </cps-icon>\n</div>\n", styles: [":host .cps-table-col-filter{display:inline-flex}:host .cps-table-col-filter .cps-table-col-filter-menu-button{display:inline-flex;justify-content:center;align-items:center;cursor:pointer;text-decoration:none;overflow:hidden;position:relative;padding-left:12px;padding-right:4px}:host .cps-table-col-filter .cps-table-col-filter-menu-button:not(.cps-table-col-filter-menu-button-active):hover{color:var(--cps-color-text-dark)}:host .cps-table-col-filter .cps-table-col-filter-menu-button-active{color:var(--cps-color-calm-lighten1)}.cps-table-col-filter-menu-content{padding-bottom:12px;min-width:200px;max-height:500px;overflow:auto}.cps-table-col-filter-menu-content .cps-table-col-filter-menu-content-header{min-height:32px;padding:8px;border-bottom:1px solid var(--cps-color-line-mid);background:var(--cps-color-bg-light);display:flex;justify-content:space-between;align-items:center}.cps-table-col-filter-menu-content .cps-table-col-filter-menu-content-header-title{font-family:Source Sans Pro,sans-serif;color:var(--cps-color-text-darkest);max-width:390px;cursor:default}.cps-table-col-filter-menu-content .cps-table-col-filter-menu-content-header cps-icon{margin-left:8px;cursor:pointer}.cps-table-col-filter-menu-content .cps-table-col-filter-menu-content-header cps-icon:hover{color:var(--cps-color-calm)}.cps-table-col-filter-menu-content .cps-table-col-filter-menu-content-operator{padding:12px;border-bottom:1px solid var(--cps-color-line-mid);background:var(--cps-color-bg-light)}.cps-table-col-filter-menu-content .cps-table-col-filter-menu-content-constraints .cps-table-col-filter-menu-content-constraint{border-bottom:1px solid var(--cps-color-line-mid);padding:12px}.cps-table-col-filter-menu-content .cps-table-col-filter-menu-content-constraints .cps-table-col-filter-menu-content-constraint .cps-table-col-filter-match-mode-select{margin-bottom:8px}.cps-table-col-filter-menu-content .cps-table-col-filter-menu-content-constraints .cps-table-col-filter-menu-content-constraint:last-child{border-bottom:none}.cps-table-col-filter-menu-content .cps-table-col-filter-menu-content-constraints .cps-table-col-filter-remove-rule-btn{padding-top:8px}.cps-table-col-filter-menu-content .cps-table-col-filter-add-rule-btn{padding:8px 12px}.cps-table-col-filter-menu-content .cps-table-col-filter-buttonbar{display:flex;align-items:center;justify-content:space-between;padding:12px 12px 0}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: CpsButtonComponent, selector: "cps-button", inputs: ["color", "contentColor", "type", "label", "icon", "iconPosition", "size", "width", "height", "disabled", "loading"], outputs: ["clicked"] }, { kind: "component", type: CpsMenuComponent, selector: "cps-menu", inputs: ["header", "items", "withArrow", "compressed", "focusOnShow", "persistent", "containerClass", "showTransitionOptions", "hideTransitionOptions"], outputs: ["menuShown", "menuHidden", "beforeMenuHidden", "contentClicked"] }, { kind: "component", type: CpsIconComponent, selector: "cps-icon", inputs: ["icon", "size", "color"] }, { kind: "component", type: CpsSelectComponent, selector: "cps-select", inputs: ["label", "placeholder", "hint", "returnObject", "multiple", "disabled", "width", "selectAll", "chips", "closableChips", "clearable", "openOnClear", "options", "optionLabel", "optionValue", "optionInfo", "hideDetails", "persistentClear", "prefixIcon", "prefixIconSize", "loading", "virtualScroll", "numToleratedItems", "infoTooltip", "infoTooltipClass", "infoTooltipMaxWidth", "infoTooltipPersistent", "infoTooltipPosition", "optionsClass", "appearance", "value"], outputs: ["valueChanged"] }, { kind: "component", type: TableColumnFilterConstraintComponent, selector: "table-column-filter-constraint", inputs: ["type", "field", "filterConstraint", "categoryOptions", "asButtonToggle", "singleSelection", "placeholder", "hasApplyButton"] }] });
|
|
5246
5252
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TableColumnFilterComponent, decorators: [{
|
|
5247
5253
|
type: Component,
|
|
5248
5254
|
args: [{ selector: 'table-column-filter', standalone: true, imports: [
|
|
@@ -5253,7 +5259,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
|
|
|
5253
5259
|
CpsIconComponent,
|
|
5254
5260
|
CpsSelectComponent,
|
|
5255
5261
|
TableColumnFilterConstraintComponent
|
|
5256
|
-
], template: "<div class=\"cps-table-col-filter\">\n <cps-menu\n #columnFilterMenu\n [withArrow]=\"false\"\n [persistent]=\"persistent || (showApplyButton && isCategoryDropdownOpened)\"\n (menuShown)=\"onMenuShown()\"\n (menuHidden)=\"onMenuHidden()\"\n (beforeMenuHidden)=\"onBeforeMenuHidden()\">\n <div class=\"cps-table-col-filter-menu-content\">\n <div\n class=\"cps-table-col-filter-menu-content-header\"\n *ngIf=\"showCloseButton || headerTitle\">\n <span class=\"cps-table-col-filter-menu-content-header-title\">\n {{ headerTitle }}\n </span>\n <cps-icon\n *ngIf=\"showCloseButton\"\n icon=\"close-x\"\n (click)=\"onCloseClick()\"></cps-icon>\n </div>\n <div\n class=\"cps-table-col-filter-menu-content-operator\"\n *ngIf=\"isShowOperator\">\n <cps-select\n [hideDetails]=\"true\"\n [disabled]=\"!fieldConstraints || fieldConstraints.length < 2\"\n [returnObject]=\"false\"\n [options]=\"operatorOptions\"\n [ngModel]=\"operator\"\n (valueChanged)=\"onOperatorChange($event)\"></cps-select>\n </div>\n <div class=\"cps-table-col-filter-menu-content-constraints\">\n <div\n *ngFor=\"let fieldConstraint of fieldConstraints; let i = index\"\n class=\"cps-table-col-filter-menu-content-constraint\">\n <cps-select\n *ngIf=\"showMatchModes && currentMatchModes\"\n class=\"cps-table-col-filter-match-mode-select\"\n [hideDetails]=\"true\"\n [returnObject]=\"false\"\n [options]=\"currentMatchModes\"\n [ngModel]=\"fieldConstraint.matchMode\"\n (valueChanged)=\"\n onMenuMatchModeChange($event, fieldConstraint)\n \"></cps-select>\n <table-column-filter-constraint\n #constraintComponent\n [type]=\"type\"\n [field]=\"field\"\n [asButtonToggle]=\"asButtonToggle\"\n [singleSelection]=\"singleSelection\"\n [categoryOptions]=\"categoryOptions\"\n [filterConstraint]=\"fieldConstraint\"\n [hasApplyButton]=\"showApplyButton\"\n [placeholder]=\"placeholder\">\n </table-column-filter-constraint>\n <div\n class=\"cps-table-col-filter-remove-rule-btn\"\n *ngIf=\"showRemoveIcon\">\n <cps-button\n type=\"borderless\"\n width=\"100%\"\n size=\"small\"\n color=\"prepared\"\n icon=\"delete\"\n (clicked)=\"removeConstraint(fieldConstraint)\"\n label=\"Remove condition\">\n </cps-button>\n </div>\n </div>\n </div>\n <div\n class=\"cps-table-col-filter-add-rule-btn\"\n *ngIf=\"isShowAddConstraint\">\n <cps-button\n label=\"Add condition\"\n type=\"borderless\"\n width=\"100%\"\n size=\"small\"\n color=\"surprise\"\n icon=\"add\"\n (clicked)=\"addConstraint()\">\n </cps-button>\n </div>\n <div class=\"cps-table-col-filter-buttonbar\">\n <cps-button\n *ngIf=\"showClearButton\"\n (clicked)=\"clearFilter()\"\n type=\"borderless\"\n color=\"prepared\"\n size=\"small\"\n label=\"Clear\"></cps-button>\n <cps-button\n *ngIf=\"showApplyButton\"\n (clicked)=\"applyFilter()\"\n color=\"prepared\"\n size=\"small\"\n label=\"Apply\"></cps-button>\n </div>\n </div>\n </cps-menu>\n <cps-icon\n [icon]=\"isFilterApplied ? 'filter-funnel-filled' : 'filter-funnel'\"\n size=\"13\"\n (click)=\"columnFilterMenu.toggle($event)\"\n class=\"cps-table-col-filter-menu-button\"\n [ngClass]=\"{\n 'cps-table-col-filter-menu-button-active': isFilterApplied\n }\"\n >>\n </cps-icon>\n</div>\n", styles: [":host .cps-table-col-filter{display:inline-flex}:host .cps-table-col-filter .cps-table-col-filter-menu-button{display:inline-flex;justify-content:center;align-items:center;cursor:pointer;text-decoration:none;overflow:hidden;position:relative;padding-left:12px;padding-right:4px}:host .cps-table-col-filter .cps-table-col-filter-menu-button:not(.cps-table-col-filter-menu-button-active):hover{color:var(--cps-color-text-dark)}:host .cps-table-col-filter .cps-table-col-filter-menu-button-active{color:var(--cps-color-calm-lighten1)}.cps-table-col-filter-menu-content{padding-bottom:12px;min-width:200px;max-height:500px;overflow:auto}.cps-table-col-filter-menu-content .cps-table-col-filter-menu-content-header{min-height:32px;padding:8px;border-bottom:1px solid var(--cps-color-line-mid);background:var(--cps-color-bg-light);display:flex;justify-content:space-between;align-items:center}.cps-table-col-filter-menu-content .cps-table-col-filter-menu-content-header-title{font-family:Source Sans Pro,sans-serif;color:var(--cps-color-text-darkest);max-width:390px}.cps-table-col-filter-menu-content .cps-table-col-filter-menu-content-header cps-icon{margin-left:8px;cursor:pointer}.cps-table-col-filter-menu-content .cps-table-col-filter-menu-content-header cps-icon:hover{color:var(--cps-color-calm)}.cps-table-col-filter-menu-content .cps-table-col-filter-menu-content-operator{padding:12px;border-bottom:1px solid var(--cps-color-line-mid);background:var(--cps-color-bg-light)}.cps-table-col-filter-menu-content .cps-table-col-filter-menu-content-constraints .cps-table-col-filter-menu-content-constraint{border-bottom:1px solid var(--cps-color-line-mid);padding:12px}.cps-table-col-filter-menu-content .cps-table-col-filter-menu-content-constraints .cps-table-col-filter-menu-content-constraint .cps-table-col-filter-match-mode-select{margin-bottom:8px}.cps-table-col-filter-menu-content .cps-table-col-filter-menu-content-constraints .cps-table-col-filter-menu-content-constraint:last-child{border-bottom:none}.cps-table-col-filter-menu-content .cps-table-col-filter-menu-content-constraints .cps-table-col-filter-remove-rule-btn{padding-top:8px}.cps-table-col-filter-menu-content .cps-table-col-filter-add-rule-btn{padding:8px 12px}.cps-table-col-filter-menu-content .cps-table-col-filter-buttonbar{display:flex;align-items:center;justify-content:space-between;padding:12px 12px 0}\n"] }]
|
|
5262
|
+
], template: "<div class=\"cps-table-col-filter\">\n <cps-menu\n #columnFilterMenu\n [withArrow]=\"false\"\n hideTransitionOptions=\"0s linear\"\n [persistent]=\"persistent || (showApplyButton && isCategoryDropdownOpened)\"\n (menuShown)=\"onMenuShown()\"\n (menuHidden)=\"onMenuHidden()\"\n (beforeMenuHidden)=\"onBeforeMenuHidden()\">\n <div class=\"cps-table-col-filter-menu-content\">\n <div\n class=\"cps-table-col-filter-menu-content-header\"\n *ngIf=\"showCloseButton || headerTitle\">\n <span class=\"cps-table-col-filter-menu-content-header-title\">\n {{ headerTitle }}\n </span>\n <cps-icon\n *ngIf=\"showCloseButton\"\n icon=\"close-x\"\n (click)=\"onCloseClick()\"></cps-icon>\n </div>\n <div\n class=\"cps-table-col-filter-menu-content-operator\"\n *ngIf=\"isShowOperator\">\n <cps-select\n [hideDetails]=\"true\"\n [disabled]=\"!fieldConstraints || fieldConstraints.length < 2\"\n [returnObject]=\"false\"\n [options]=\"operatorOptions\"\n [ngModel]=\"operator\"\n (valueChanged)=\"onOperatorChange($event)\"></cps-select>\n </div>\n <div class=\"cps-table-col-filter-menu-content-constraints\">\n <div\n *ngFor=\"let fieldConstraint of fieldConstraints; let i = index\"\n class=\"cps-table-col-filter-menu-content-constraint\">\n <cps-select\n *ngIf=\"showMatchModes && currentMatchModes\"\n class=\"cps-table-col-filter-match-mode-select\"\n [hideDetails]=\"true\"\n [returnObject]=\"false\"\n [options]=\"currentMatchModes\"\n [ngModel]=\"fieldConstraint.matchMode\"\n (valueChanged)=\"\n onMenuMatchModeChange($event, fieldConstraint)\n \"></cps-select>\n <table-column-filter-constraint\n #constraintComponent\n [type]=\"type\"\n [field]=\"field\"\n [asButtonToggle]=\"asButtonToggle\"\n [singleSelection]=\"singleSelection\"\n [categoryOptions]=\"categoryOptions\"\n [filterConstraint]=\"fieldConstraint\"\n [hasApplyButton]=\"showApplyButton\"\n [placeholder]=\"placeholder\">\n </table-column-filter-constraint>\n <div\n class=\"cps-table-col-filter-remove-rule-btn\"\n *ngIf=\"showRemoveIcon\">\n <cps-button\n type=\"borderless\"\n width=\"100%\"\n size=\"small\"\n color=\"prepared\"\n icon=\"delete\"\n (clicked)=\"removeConstraint(fieldConstraint)\"\n label=\"Remove condition\">\n </cps-button>\n </div>\n </div>\n </div>\n <div\n class=\"cps-table-col-filter-add-rule-btn\"\n *ngIf=\"isShowAddConstraint\">\n <cps-button\n label=\"Add condition\"\n type=\"borderless\"\n width=\"100%\"\n size=\"small\"\n color=\"surprise\"\n icon=\"add\"\n (clicked)=\"addConstraint()\">\n </cps-button>\n </div>\n <div class=\"cps-table-col-filter-buttonbar\">\n <cps-button\n *ngIf=\"showClearButton\"\n (clicked)=\"clearFilter()\"\n type=\"borderless\"\n color=\"prepared\"\n size=\"small\"\n label=\"Clear\"></cps-button>\n <cps-button\n *ngIf=\"showApplyButton\"\n (clicked)=\"applyFilter()\"\n color=\"prepared\"\n size=\"small\"\n label=\"Apply\"></cps-button>\n </div>\n </div>\n </cps-menu>\n <cps-icon\n [icon]=\"isFilterApplied ? 'filter-funnel-filled' : 'filter-funnel'\"\n size=\"13\"\n (click)=\"columnFilterMenu.toggle($event)\"\n class=\"cps-table-col-filter-menu-button\"\n [ngClass]=\"{\n 'cps-table-col-filter-menu-button-active': isFilterApplied\n }\"\n >>\n </cps-icon>\n</div>\n", styles: [":host .cps-table-col-filter{display:inline-flex}:host .cps-table-col-filter .cps-table-col-filter-menu-button{display:inline-flex;justify-content:center;align-items:center;cursor:pointer;text-decoration:none;overflow:hidden;position:relative;padding-left:12px;padding-right:4px}:host .cps-table-col-filter .cps-table-col-filter-menu-button:not(.cps-table-col-filter-menu-button-active):hover{color:var(--cps-color-text-dark)}:host .cps-table-col-filter .cps-table-col-filter-menu-button-active{color:var(--cps-color-calm-lighten1)}.cps-table-col-filter-menu-content{padding-bottom:12px;min-width:200px;max-height:500px;overflow:auto}.cps-table-col-filter-menu-content .cps-table-col-filter-menu-content-header{min-height:32px;padding:8px;border-bottom:1px solid var(--cps-color-line-mid);background:var(--cps-color-bg-light);display:flex;justify-content:space-between;align-items:center}.cps-table-col-filter-menu-content .cps-table-col-filter-menu-content-header-title{font-family:Source Sans Pro,sans-serif;color:var(--cps-color-text-darkest);max-width:390px;cursor:default}.cps-table-col-filter-menu-content .cps-table-col-filter-menu-content-header cps-icon{margin-left:8px;cursor:pointer}.cps-table-col-filter-menu-content .cps-table-col-filter-menu-content-header cps-icon:hover{color:var(--cps-color-calm)}.cps-table-col-filter-menu-content .cps-table-col-filter-menu-content-operator{padding:12px;border-bottom:1px solid var(--cps-color-line-mid);background:var(--cps-color-bg-light)}.cps-table-col-filter-menu-content .cps-table-col-filter-menu-content-constraints .cps-table-col-filter-menu-content-constraint{border-bottom:1px solid var(--cps-color-line-mid);padding:12px}.cps-table-col-filter-menu-content .cps-table-col-filter-menu-content-constraints .cps-table-col-filter-menu-content-constraint .cps-table-col-filter-match-mode-select{margin-bottom:8px}.cps-table-col-filter-menu-content .cps-table-col-filter-menu-content-constraints .cps-table-col-filter-menu-content-constraint:last-child{border-bottom:none}.cps-table-col-filter-menu-content .cps-table-col-filter-menu-content-constraints .cps-table-col-filter-remove-rule-btn{padding-top:8px}.cps-table-col-filter-menu-content .cps-table-col-filter-add-rule-btn{padding:8px 12px}.cps-table-col-filter-menu-content .cps-table-col-filter-buttonbar{display:flex;align-items:center;justify-content:space-between;padding:12px 12px 0}\n"] }]
|
|
5257
5263
|
}], ctorParameters: function () {
|
|
5258
5264
|
return [{ type: i0.ElementRef }, { type: i1$2.Table, decorators: [{
|
|
5259
5265
|
type: Optional
|
|
@@ -5886,11 +5892,14 @@ class CpsTreeTableComponent {
|
|
|
5886
5892
|
this.cdRef.detectChanges();
|
|
5887
5893
|
}
|
|
5888
5894
|
ngOnChanges(changes) {
|
|
5889
|
-
if (this.loading
|
|
5890
|
-
this.
|
|
5895
|
+
if (this.loading) {
|
|
5896
|
+
this.clearSelection();
|
|
5897
|
+
if (this.clearGlobalFilterOnLoading)
|
|
5898
|
+
this.clearGlobalFilter();
|
|
5899
|
+
}
|
|
5891
5900
|
const dataChanges = changes === null || changes === void 0 ? void 0 : changes.data;
|
|
5892
5901
|
if ((dataChanges === null || dataChanges === void 0 ? void 0 : dataChanges.previousValue) !== (dataChanges === null || dataChanges === void 0 ? void 0 : dataChanges.currentValue)) {
|
|
5893
|
-
this.
|
|
5902
|
+
this.clearSelection();
|
|
5894
5903
|
}
|
|
5895
5904
|
}
|
|
5896
5905
|
ngOnDestroy() {
|
|
@@ -5988,12 +5997,15 @@ class CpsTreeTableComponent {
|
|
|
5988
5997
|
this.selectedRows.forEach((row) => this._removeNodeFromData(row, false));
|
|
5989
5998
|
this.data = [...this.data];
|
|
5990
5999
|
this.rowsRemoved.emit(this.selectedRows);
|
|
5991
|
-
this.
|
|
6000
|
+
this.clearSelection();
|
|
5992
6001
|
setTimeout(() => {
|
|
5993
6002
|
this._recalcVirtualHeight();
|
|
5994
6003
|
this.cdRef.markForCheck();
|
|
5995
6004
|
});
|
|
5996
6005
|
}
|
|
6006
|
+
clearSelection() {
|
|
6007
|
+
this.selectedRows = [];
|
|
6008
|
+
}
|
|
5997
6009
|
onEditRowClicked(node) {
|
|
5998
6010
|
this.editRowBtnClicked.emit(node);
|
|
5999
6011
|
}
|