@trudb/tru-common-lib 0.1.61 → 0.1.63

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.
@@ -1,17 +1,14 @@
1
1
  import { NgClass, NgIf } from '@angular/common';
2
- import { Component } from '@angular/core';
2
+ import { Component, ViewChild } from '@angular/core';
3
3
  import { MatIconModule } from '@angular/material/icon';
4
4
  import * as i0 from "@angular/core";
5
5
  import * as i1 from "@angular/material/icon";
6
6
  export class TruDataGridHeader {
7
- elementRef;
7
+ headerRef;
8
8
  params;
9
9
  ascSort = 'inactive';
10
10
  descSort = 'inactive';
11
11
  noSort = 'inactive';
12
- constructor(elementRef) {
13
- this.elementRef = elementRef;
14
- }
15
12
  agInit(params) {
16
13
  this.params = params;
17
14
  this.params.column.addEventListener('sortChanged', this.onSortChanged.bind(this));
@@ -50,29 +47,20 @@ export class TruDataGridHeader {
50
47
  this.params.api.selectAll();
51
48
  }
52
49
  onCellFocused(event) {
53
- let columnDefs = event.api.getAllGridColumns().filter(gc => { return gc.getColDef(); });
54
50
  var column = event.column;
55
- if (column?.getColDef().pinned) {
56
- columnDefs.forEach((columnDef, index) => {
57
- if (index !== 0)
58
- this.elementRef.nativeElement.classList.add('ag-column-focus');
59
- });
51
+ if (this.params.column.getColId() === column.getColId()) {
52
+ this.headerRef.nativeElement.classList.add('ag-column-focus');
60
53
  }
61
54
  else {
62
- columnDefs.forEach((columnDef, index) => {
63
- if (index !== 0 && column?.getColId() === columnDef.field)
64
- this.elementRef.nativeElement.classList.add('ag-column-focus');
65
- else
66
- this.elementRef.nativeElement.classList.remove('ag-column-focus');
67
- });
55
+ this.headerRef.nativeElement.classList.remove('ag-column-focus');
68
56
  }
69
57
  }
70
58
  ngOnDestroy() {
71
59
  this.params.column.removeEventListener('sortChanged', this.onSortChanged.bind(this));
72
60
  }
73
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: TruDataGridHeader, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
74
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.2", type: TruDataGridHeader, isStandalone: true, selector: "ng-component", ngImport: i0, template: `
75
- <div class="ag-cell-label-container" role="presentation">
61
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: TruDataGridHeader, deps: [], target: i0.ɵɵFactoryTarget.Component });
62
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.2", type: TruDataGridHeader, isStandalone: true, selector: "ng-component", viewQueries: [{ propertyName: "headerRef", first: true, predicate: ["header"], descendants: true }], ngImport: i0, template: `
63
+ <div #header class="ag-cell-label-container" role="presentation">
76
64
  <div ref="eLabel" class="ag-header-cell-label" role="presentation" (click)="onSortRequested($event)">
77
65
  <div class="ag-header-control-container">
78
66
  <div class="ag-header-control-sort-container">
@@ -93,7 +81,7 @@ export class TruDataGridHeader {
93
81
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: TruDataGridHeader, decorators: [{
94
82
  type: Component,
95
83
  args: [{ standalone: true, imports: [NgIf, NgClass, MatIconModule], template: `
96
- <div class="ag-cell-label-container" role="presentation">
84
+ <div #header class="ag-cell-label-container" role="presentation">
97
85
  <div ref="eLabel" class="ag-header-cell-label" role="presentation" (click)="onSortRequested($event)">
98
86
  <div class="ag-header-control-container">
99
87
  <div class="ag-header-control-sort-container">
@@ -110,5 +98,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.2", ngImpor
110
98
  </div>
111
99
  </div>
112
100
  </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"] }]
113
- }], ctorParameters: () => [{ type: i0.ElementRef }] });
114
- //# 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    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"]}
101
+ }], propDecorators: { headerRef: [{
102
+ type: ViewChild,
103
+ args: ['header', { static: false }]
104
+ }] } });
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, ViewChild } 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 #header 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  @ViewChild('header', { static: false }) headerRef!: ElementRef;\r\n\r\n  public params!: IHeaderParams;\r\n  public ascSort = 'inactive';\r\n  public descSort = 'inactive';\r\n  public noSort = 'inactive';\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.headerRef.nativeElement.classList.add('ag-column-focus');\r\n    } else {\r\n      this.headerRef.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"]}
@@ -1,5 +1,5 @@
1
1
  import * as i0 from '@angular/core';
2
- import { Directive, Input, Injectable, Component, Inject, HostListener, InjectionToken, NgModule, EventEmitter, Output, ViewEncapsulation, createComponent, APP_INITIALIZER, ViewChildren, ViewChild } from '@angular/core';
2
+ import { Directive, Input, Injectable, Component, Inject, HostListener, InjectionToken, NgModule, ViewChild, EventEmitter, Output, ViewEncapsulation, createComponent, APP_INITIALIZER, ViewChildren } from '@angular/core';
3
3
  import { EntityAspect, MetadataStore, DataService, EntityManager, EntityQuery, Predicate, FetchStrategy, EntityState, breeze, BinaryPredicate, AndOrPredicate } from 'breeze-client';
4
4
  import { BehaviorSubject, from, defer, of, Subject, Observable, skip, forkJoin, finalize, throwError } from 'rxjs';
5
5
  import * as _ from 'underscore';
@@ -2713,14 +2713,11 @@ var TruDataGridTypes;
2713
2713
  })(TruDataGridTypes || (TruDataGridTypes = {}));
2714
2714
 
2715
2715
  class TruDataGridHeader {
2716
- elementRef;
2716
+ headerRef;
2717
2717
  params;
2718
2718
  ascSort = 'inactive';
2719
2719
  descSort = 'inactive';
2720
2720
  noSort = 'inactive';
2721
- constructor(elementRef) {
2722
- this.elementRef = elementRef;
2723
- }
2724
2721
  agInit(params) {
2725
2722
  this.params = params;
2726
2723
  this.params.column.addEventListener('sortChanged', this.onSortChanged.bind(this));
@@ -2759,29 +2756,20 @@ class TruDataGridHeader {
2759
2756
  this.params.api.selectAll();
2760
2757
  }
2761
2758
  onCellFocused(event) {
2762
- let columnDefs = event.api.getAllGridColumns().filter(gc => { return gc.getColDef(); });
2763
2759
  var column = event.column;
2764
- if (column?.getColDef().pinned) {
2765
- columnDefs.forEach((columnDef, index) => {
2766
- if (index !== 0)
2767
- this.elementRef.nativeElement.classList.add('ag-column-focus');
2768
- });
2760
+ if (this.params.column.getColId() === column.getColId()) {
2761
+ this.headerRef.nativeElement.classList.add('ag-column-focus');
2769
2762
  }
2770
2763
  else {
2771
- columnDefs.forEach((columnDef, index) => {
2772
- if (index !== 0 && column?.getColId() === columnDef.field)
2773
- this.elementRef.nativeElement.classList.add('ag-column-focus');
2774
- else
2775
- this.elementRef.nativeElement.classList.remove('ag-column-focus');
2776
- });
2764
+ this.headerRef.nativeElement.classList.remove('ag-column-focus');
2777
2765
  }
2778
2766
  }
2779
2767
  ngOnDestroy() {
2780
2768
  this.params.column.removeEventListener('sortChanged', this.onSortChanged.bind(this));
2781
2769
  }
2782
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: TruDataGridHeader, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
2783
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.2", type: TruDataGridHeader, isStandalone: true, selector: "ng-component", ngImport: i0, template: `
2784
- <div class="ag-cell-label-container" role="presentation">
2770
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: TruDataGridHeader, deps: [], target: i0.ɵɵFactoryTarget.Component });
2771
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.2", type: TruDataGridHeader, isStandalone: true, selector: "ng-component", viewQueries: [{ propertyName: "headerRef", first: true, predicate: ["header"], descendants: true }], ngImport: i0, template: `
2772
+ <div #header class="ag-cell-label-container" role="presentation">
2785
2773
  <div ref="eLabel" class="ag-header-cell-label" role="presentation" (click)="onSortRequested($event)">
2786
2774
  <div class="ag-header-control-container">
2787
2775
  <div class="ag-header-control-sort-container">
@@ -2802,7 +2790,7 @@ class TruDataGridHeader {
2802
2790
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: TruDataGridHeader, decorators: [{
2803
2791
  type: Component,
2804
2792
  args: [{ standalone: true, imports: [NgIf, NgClass, MatIconModule], template: `
2805
- <div class="ag-cell-label-container" role="presentation">
2793
+ <div #header class="ag-cell-label-container" role="presentation">
2806
2794
  <div ref="eLabel" class="ag-header-cell-label" role="presentation" (click)="onSortRequested($event)">
2807
2795
  <div class="ag-header-control-container">
2808
2796
  <div class="ag-header-control-sort-container">
@@ -2819,7 +2807,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.2", ngImpor
2819
2807
  </div>
2820
2808
  </div>
2821
2809
  </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"] }]
2822
- }], ctorParameters: () => [{ type: i0.ElementRef }] });
2810
+ }], propDecorators: { headerRef: [{
2811
+ type: ViewChild,
2812
+ args: ['header', { static: false }]
2813
+ }] } });
2823
2814
 
2824
2815
  class TruDataGridRefHeader {
2825
2816
  params;