@trudb/tru-common-lib 0.1.60 → 0.1.62

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.
@@ -15,6 +15,7 @@ export class TruDataGridHeader {
15
15
  agInit(params) {
16
16
  this.params = params;
17
17
  this.params.column.addEventListener('sortChanged', this.onSortChanged.bind(this));
18
+ this.params.api.addEventListener('cellFocused', this.onCellFocused.bind(this));
18
19
  this.onSortChanged();
19
20
  }
20
21
  refresh(params) {
@@ -49,21 +50,12 @@ export class TruDataGridHeader {
49
50
  this.params.api.selectAll();
50
51
  }
51
52
  onCellFocused(event) {
52
- let columnDefs = event.api.getAllGridColumns().filter(gc => { return gc.getColDef(); });
53
53
  var column = event.column;
54
- if (column?.getColDef().pinned) {
55
- columnDefs.forEach((columnDef, index) => {
56
- if (index !== 0)
57
- this.elementRef.nativeElement.classList.add('ag-column-focus');
58
- });
54
+ if (this.params.column.getColId() === column.getColId()) {
55
+ this.elementRef.nativeElement.classList.add('ag-column-focus');
59
56
  }
60
57
  else {
61
- columnDefs.forEach((columnDef, index) => {
62
- if (index !== 0 && column?.getColId() === columnDef.field)
63
- this.elementRef.nativeElement.classList.add('ag-column-focus');
64
- else
65
- this.elementRef.nativeElement.classList.remove('ag-column-focus');
66
- });
58
+ this.elementRef.nativeElement.classList.remove('ag-column-focus');
67
59
  }
68
60
  }
69
61
  ngOnDestroy() {
@@ -110,4 +102,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.2", ngImpor
110
102
  </div>
111
103
  </div>`, styles: [".ag-header-control-container{display:flex}.ag-header-control-sort-container{position:relative;top:1px}.ag-header-cell-text{position:relative;pointer-events:none;vertical-align:middle;vertical-align:-webkit-baseline-middle}.ag-sort-icon{height:100%;width:100%;margin-left:0!important}.tru-data-grid-select-all-icon{width:16px;font-size:28px;color:#ddd;float:right;position:absolute;top:-1px;right:4px}.ag-sort-icon mat-icon{height:16px;width:16px;padding-top:4px}.ag-column-focus .ag-header-cell-text{color:#3f51b5;font-weight:700}.ag-column-focus{background-color:#ddd}::ng-deep .tru-data-grid-select-all-icon path{fill:#d3d3d3;position:relative;z-index:100;pointer-events:all}::ng-deep .ag-sort-icon.ag-sort-ascending-icon svg{transform:rotate(180deg)}\n"] }]
112
104
  }], ctorParameters: () => [{ type: i0.ElementRef }] });
113
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tru-data-grid-header.js","sourceRoot":"","sources":["../../../../../../../projects/tru-common-lib/src/lib/components/data-grid/headers/tru-data-grid-header.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgClass, NgIf } from '@angular/common';\r\nimport { Component, ElementRef } from '@angular/core';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { IHeaderAngularComp } from 'ag-grid-angular';\r\nimport { CellFocusedEvent, Column, IHeaderParams } from 'ag-grid-community';\r\n\r\n@Component({\r\n  standalone: true,\r\n  imports: [NgIf, NgClass, MatIconModule],\r\n  template: `\r\n  <div class=\"ag-cell-label-container\" role=\"presentation\">\r\n    <div ref=\"eLabel\" class=\"ag-header-cell-label\" role=\"presentation\" (click)=\"onSortRequested($event)\">\r\n        <div class=\"ag-header-control-container\">\r\n          <div class=\"ag-header-control-sort-container\">\r\n            <span *ngIf=\"ascSort === 'active'\" ref=\"eSortAsc\" class=\"ag-header-icon ag-header-label-icon ag-sort-icon ag-sort-ascending-icon\">\r\n              <mat-icon [svgIcon]=\"'sort-icon'\"></mat-icon>\r\n            </span>\r\n            <span *ngIf=\"descSort === 'active'\" ref=\"eSortDesc\" class=\"ag-header-icon ag-header-label-icon ag-sort-icon ag-sort-descending-icon\">\r\n              <mat-icon [svgIcon]=\"'sort-icon'\"></mat-icon>\r\n            </span>\r\n          </div>\r\n          <div>\r\n            <span ref=\"eText\" class=\"ag-header-cell-text\">{{params.displayName}}</span>\r\n          </div>\r\n        </div>\r\n    </div>\r\n  </div>`,\r\n  styles: [\r\n   `\r\n   .ag-header-control-container {\r\n     display: flex;\r\n   }\r\n   .ag-header-control-sort-container {\r\n    position: relative;\r\n    top: 1px;\r\n   }\r\n   .ag-header-cell-text {\r\n     position: relative;\r\n     pointer-events: none;\r\n     vertical-align: middle;\r\n     vertical-align: -webkit-baseline-middle;\r\n   }\r\n  .ag-sort-icon {\r\n    height: 100%;\r\n    width: 100%;\r\n    margin-left: 0 !important;\r\n  }\r\n  .tru-data-grid-select-all-icon {\r\n    width: 16px;\r\n    font-size: 28px;\r\n    color: #ddd;\r\n    float: right;\r\n    position: absolute;\r\n    top: -1px;\r\n    right: 4px;\r\n  }\r\n  .ag-sort-icon mat-icon {\r\n    height: 16px;\r\n    width: 16px;\r\n    padding-top: 4px;\r\n  }\r\n  .ag-column-focus .ag-header-cell-text {\r\n    color: #3f51b5;\r\n    font-weight: bold;\r\n  }\r\n  .ag-column-focus {\r\n    background-color: #ddd;\r\n  }\r\n  ::ng-deep .tru-data-grid-select-all-icon path {\r\n    fill: lightgray;\r\n    position: relative;\r\n    z-index: 100;\r\n    pointer-events: all;\r\n  }\r\n  ::ng-deep .ag-sort-icon.ag-sort-ascending-icon svg {\r\n    transform: rotate(180deg);\r\n  }\r\n  `\r\n  ]\r\n})\r\nexport class TruDataGridHeader implements IHeaderAngularComp {\r\n  public params!: IHeaderParams;\r\n  public ascSort = 'inactive';\r\n  public descSort = 'inactive';\r\n  public noSort = 'inactive';\r\n\r\n  constructor(private elementRef: ElementRef) { }\r\n\r\n  agInit(params: IHeaderParams): void {\r\n    this.params = params;\r\n    this.params.column.addEventListener('sortChanged', this.onSortChanged.bind(this));\r\n    this.onSortChanged();\r\n  }\r\n\r\n  refresh(params: IHeaderParams) {\r\n    return false;\r\n  }\r\n\r\n  onSortChanged() {\r\n    this.ascSort = this.descSort = this.noSort = 'inactive';\r\n    if (this.params.column.isSortAscending()) {\r\n      this.ascSort = 'active';\r\n    } else if (this.params.column.isSortDescending()) {\r\n      this.descSort = 'active';\r\n    } else {\r\n      this.noSort = 'active';\r\n    }\r\n  }\r\n\r\n  onSortRequested(event: any) {\r\n    var order: 'asc' | 'desc' | null = null;\r\n    if (this.params.column.isSortAscending()) {\r\n      order = 'desc';\r\n    } else if (this.params.column.isSortDescending()) {\r\n      order = null;\r\n    } else {\r\n      order = 'asc';\r\n    }\r\n    \r\n    this.params.setSort(order, event.shiftKey);\r\n  }\r\n\r\n  onSelectAllIconClicked() {\r\n    this.params.api.selectAll();\r\n  }\r\n\r\n  onCellFocused(event: CellFocusedEvent) {\r\n    let columnDefs = event.api.getAllGridColumns().filter(gc => { return gc.getColDef() });\r\n    var column = event.column as Column;\r\n    if (column?.getColDef().pinned) {\r\n      columnDefs.forEach((columnDef: any, index: number) => {\r\n        if (index !== 0)\r\n          this.elementRef.nativeElement.classList.add('ag-column-focus');\r\n      });\r\n    } else {\r\n      columnDefs.forEach((columnDef: any, index: number) => {\r\n        if (index !== 0 && column?.getColId() === columnDef.field)\r\n          this.elementRef.nativeElement.classList.add('ag-column-focus');\r\n        else\r\n          this.elementRef.nativeElement.classList.remove('ag-column-focus');\r\n      });\r\n    }\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.params.column.removeEventListener('sortChanged', this.onSortChanged.bind(this));\r\n  }\r\n}\r\n"]}
105
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tru-data-grid-header.js","sourceRoot":"","sources":["../../../../../../../projects/tru-common-lib/src/lib/components/data-grid/headers/tru-data-grid-header.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgClass, NgIf } from '@angular/common';\r\nimport { Component, ElementRef } from '@angular/core';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { IHeaderAngularComp } from 'ag-grid-angular';\r\nimport { CellFocusedEvent, Column, IHeaderParams } from 'ag-grid-community';\r\n\r\n@Component({\r\n  standalone: true,\r\n  imports: [NgIf, NgClass, MatIconModule],\r\n  template: `\r\n  <div class=\"ag-cell-label-container\" role=\"presentation\">\r\n    <div ref=\"eLabel\" class=\"ag-header-cell-label\" role=\"presentation\" (click)=\"onSortRequested($event)\">\r\n        <div class=\"ag-header-control-container\">\r\n          <div class=\"ag-header-control-sort-container\">\r\n            <span *ngIf=\"ascSort === 'active'\" ref=\"eSortAsc\" class=\"ag-header-icon ag-header-label-icon ag-sort-icon ag-sort-ascending-icon\">\r\n              <mat-icon [svgIcon]=\"'sort-icon'\"></mat-icon>\r\n            </span>\r\n            <span *ngIf=\"descSort === 'active'\" ref=\"eSortDesc\" class=\"ag-header-icon ag-header-label-icon ag-sort-icon ag-sort-descending-icon\">\r\n              <mat-icon [svgIcon]=\"'sort-icon'\"></mat-icon>\r\n            </span>\r\n          </div>\r\n          <div>\r\n            <span ref=\"eText\" class=\"ag-header-cell-text\">{{params.displayName}}</span>\r\n          </div>\r\n        </div>\r\n    </div>\r\n  </div>`,\r\n  styles: [\r\n   `\r\n   .ag-header-control-container {\r\n     display: flex;\r\n   }\r\n   .ag-header-control-sort-container {\r\n    position: relative;\r\n    top: 1px;\r\n   }\r\n   .ag-header-cell-text {\r\n     position: relative;\r\n     pointer-events: none;\r\n     vertical-align: middle;\r\n     vertical-align: -webkit-baseline-middle;\r\n   }\r\n  .ag-sort-icon {\r\n    height: 100%;\r\n    width: 100%;\r\n    margin-left: 0 !important;\r\n  }\r\n  .tru-data-grid-select-all-icon {\r\n    width: 16px;\r\n    font-size: 28px;\r\n    color: #ddd;\r\n    float: right;\r\n    position: absolute;\r\n    top: -1px;\r\n    right: 4px;\r\n  }\r\n  .ag-sort-icon mat-icon {\r\n    height: 16px;\r\n    width: 16px;\r\n    padding-top: 4px;\r\n  }\r\n  .ag-column-focus .ag-header-cell-text {\r\n    color: #3f51b5;\r\n    font-weight: bold;\r\n  }\r\n  .ag-column-focus {\r\n    background-color: #ddd;\r\n  }\r\n  ::ng-deep .tru-data-grid-select-all-icon path {\r\n    fill: lightgray;\r\n    position: relative;\r\n    z-index: 100;\r\n    pointer-events: all;\r\n  }\r\n  ::ng-deep .ag-sort-icon.ag-sort-ascending-icon svg {\r\n    transform: rotate(180deg);\r\n  }\r\n  `\r\n  ]\r\n})\r\nexport class TruDataGridHeader implements IHeaderAngularComp {\r\n  public params!: IHeaderParams;\r\n  public ascSort = 'inactive';\r\n  public descSort = 'inactive';\r\n  public noSort = 'inactive';\r\n\r\n  constructor(private elementRef: ElementRef) { }\r\n\r\n  agInit(params: IHeaderParams): void {\r\n    this.params = params;\r\n    this.params.column.addEventListener('sortChanged', this.onSortChanged.bind(this));\r\n    this.params.api.addEventListener('cellFocused', this.onCellFocused.bind(this));\r\n    this.onSortChanged();\r\n  }\r\n\r\n  refresh(params: IHeaderParams) {\r\n    return false;\r\n  }\r\n\r\n  onSortChanged() {\r\n    this.ascSort = this.descSort = this.noSort = 'inactive';\r\n    if (this.params.column.isSortAscending()) {\r\n      this.ascSort = 'active';\r\n    } else if (this.params.column.isSortDescending()) {\r\n      this.descSort = 'active';\r\n    } else {\r\n      this.noSort = 'active';\r\n    }\r\n  }\r\n\r\n  onSortRequested(event: any) {\r\n    var order: 'asc' | 'desc' | null = null;\r\n    if (this.params.column.isSortAscending()) {\r\n      order = 'desc';\r\n    } else if (this.params.column.isSortDescending()) {\r\n      order = null;\r\n    } else {\r\n      order = 'asc';\r\n    }\r\n    \r\n    this.params.setSort(order, event.shiftKey);\r\n  }\r\n\r\n  onSelectAllIconClicked() {\r\n    this.params.api.selectAll();\r\n  }\r\n\r\n  onCellFocused(event: CellFocusedEvent) {\r\n    var column = event.column as Column;\r\n    if (this.params.column.getColId() === column.getColId()) {\r\n      this.elementRef.nativeElement.classList.add('ag-column-focus');\r\n    } else {\r\n      this.elementRef.nativeElement.classList.remove('ag-column-focus');\r\n    }\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.params.column.removeEventListener('sortChanged', this.onSortChanged.bind(this));\r\n  }\r\n}\r\n"]}
@@ -2724,6 +2724,7 @@ class TruDataGridHeader {
2724
2724
  agInit(params) {
2725
2725
  this.params = params;
2726
2726
  this.params.column.addEventListener('sortChanged', this.onSortChanged.bind(this));
2727
+ this.params.api.addEventListener('cellFocused', this.onCellFocused.bind(this));
2727
2728
  this.onSortChanged();
2728
2729
  }
2729
2730
  refresh(params) {
@@ -2758,21 +2759,12 @@ class TruDataGridHeader {
2758
2759
  this.params.api.selectAll();
2759
2760
  }
2760
2761
  onCellFocused(event) {
2761
- let columnDefs = event.api.getAllGridColumns().filter(gc => { return gc.getColDef(); });
2762
2762
  var column = event.column;
2763
- if (column?.getColDef().pinned) {
2764
- columnDefs.forEach((columnDef, index) => {
2765
- if (index !== 0)
2766
- this.elementRef.nativeElement.classList.add('ag-column-focus');
2767
- });
2763
+ if (this.params.column.getColId() === column.getColId()) {
2764
+ this.elementRef.nativeElement.classList.add('ag-column-focus');
2768
2765
  }
2769
2766
  else {
2770
- columnDefs.forEach((columnDef, index) => {
2771
- if (index !== 0 && column?.getColId() === columnDef.field)
2772
- this.elementRef.nativeElement.classList.add('ag-column-focus');
2773
- else
2774
- this.elementRef.nativeElement.classList.remove('ag-column-focus');
2775
- });
2767
+ this.elementRef.nativeElement.classList.remove('ag-column-focus');
2776
2768
  }
2777
2769
  }
2778
2770
  ngOnDestroy() {