@one-paragon/angular-utilities 1.1.3 → 1.1.5

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.
@@ -29,10 +29,12 @@ export class GenericTableComponent {
29
29
  }
30
30
  set trackBy(trackBy) {
31
31
  if (trackBy) {
32
+ this._trackBy = trackBy;
32
33
  this.trackByFunction = (index, item) => item[trackBy];
33
34
  }
34
35
  this.setUpSelections(trackBy);
35
36
  }
37
+ get trackBy() { return this._trackBy; }
36
38
  constructor(state, viewContainer, transformCreator, injector) {
37
39
  this.state = state;
38
40
  this.viewContainer = viewContainer;
@@ -111,7 +113,8 @@ export class GenericTableComponent {
111
113
  });
112
114
  this.state.on(this.state.props().dataSource.viewableData$, (data) => {
113
115
  if (this.selection.selected.length) {
114
- const removed = this.selection.selected.filter(s => !data.includes(s));
116
+ const trackByFunction = this.trackBy ? (s) => data.every(d => d[this.trackBy] !== s[this.trackBy]) : s => !data.includes(s);
117
+ const removed = this.selection.selected.filter(trackByFunction);
115
118
  this.selection.deselect(...removed);
116
119
  }
117
120
  });
@@ -200,4 +203,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImpor
200
203
  }], selection$: [{
201
204
  type: Output
202
205
  }] } });
203
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"generic-table.component.js","sourceRoot":"","sources":["../../../../../../projects/angular-utilities/src/table-builder/components/generic-table/generic-table.component.ts","../../../../../../projects/angular-utilities/src/table-builder/components/generic-table/generic-table.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,SAAS,EACT,KAAK,EACL,uBAAuB,EACvB,MAAM,EAKN,QAAQ,EACR,YAAY,GACb,MAAM,eAAe,CAAC;AACvB,OAAO,EAAa,QAAQ,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AAC9E,OAAO,EAAc,aAAa,EAAE,MAAM,MAAM,CAAC;AACjD,OAAO,EAAmB,cAAc,EAAE,MAAM,0BAA0B,CAAC;AAE3E,OAAO,EAAE,GAAG,EAAE,oBAAoB,EAAE,MAAM,gBAAgB,CAAC;AAC3D,OAAO,EAAE,sBAAsB,EAAE,MAAM,4CAA4C,CAAC;AAEpF,OAAO,EAAE,SAAS,EAAE,MAAM,6BAA6B,CAAC;AACxD,OAAO,EAAE,kBAAkB,EAAE,MAAM,8BAA8B,CAAC;AAElE,OAAO,EAAe,WAAW,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AAClF,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,EAAE,iBAAiB,EAAE,MAAM,4BAA4B,CAAC;AAC/D,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAC3D,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,EAAE,SAAS,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AAC9D,OAAO,EAAE,gBAAgB,EAAE,MAAM,2BAA2B,CAAC;AAC7D,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAE/C,OAAO,EAAE,eAAe,EAAE,MAAM,+DAA+D,CAAC;;;;;;;;;AAahG,MAAM,OAAO,qBAAqB;IAEhC,IAAI,CAAC,KAA4B;QAC/B,IAAI,CAAC,KAAK,CAAC,mBAAmB,CAAC,EAAE,QAAQ,EAAC,KAAK,CAAC,YAAY,EAAE,QAAQ,EAAC,KAAK,CAAC,aAAa,EAAE,CAAC,CAAA;IAC/F,CAAC;IACD,IAAa,OAAO,CAAC,OAAe;QAClC,IAAG,OAAO,EAAC,CAAC;YACV,IAAI,CAAC,eAAe,GAAG,CAAC,KAAY,EAAE,IAAS,EAAE,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACpE,CAAC;QACD,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC;IAChC,CAAC;IAqBD,YACS,KAAiB,EAChB,aAA+B,EAC/B,gBAAkC,EAC1C,QAAkB;QAHX,UAAK,GAAL,KAAK,CAAY;QAChB,kBAAa,GAAb,aAAa,CAAkB;QAC/B,qBAAgB,GAAhB,gBAAgB,CAAkB;QAb5C,SAAI,GAAc,EAAE,CAAC;QAErB,cAAS,GAAqB,EAAE,CAAC;QACjC,YAAO,GAAa,EAAE,CAAC;QACvB,cAAS,GAAuC,EAAE,CAAC;QAGnD,gBAAW,GAAG,CAAC,CAAC;QAsBhB,mBAAc,GAAG,CAAC,KAAY,EAAE,IAAS,EAAE,EAAE,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;QACpE,oBAAe,GAAG,IAAI,CAAC,cAAc,CAAC;QAgFtC,sBAAiB,GAAG,CAAC,IAAqB,EAAC,EAAE;YAC3C,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAA,EAAE,CAAA,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC;YACtD,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;YACtB,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;gBACf,CAAC,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,SAAS,KAAK,SAAS,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC;gBAC/I,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;oBACf,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;gBAC1B,CAAC;YACH,CAAC,CAAC,CAAC;QACL,CAAC,CAAA;QAGS,eAAU,GAAG,IAAI,YAAY,EAAwB,CAAC;QAChE,yBAAoB,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,GAAG,CAAC,GAAE,EAAE,CAAA,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC;QACxG,+BAA0B,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,GAAG,CAAC,GAAE,EAAE,CAAA,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC;QAmB/G,eAAU,GAAG,IAAI,CAAC,KAAK,CAAC,wBAAwB,CAAC,IAAI,CACnD,kBAAkB,CAAqB,CAAC,CAAC,EACzC,GAAG,CAAC,CAAC,CAAC,wBAAwB,EAAE,uBAAuB,CAAC,EAAE,EAAE;YAC1D,IAAI,uBAAuB,EAAC,CAAC;gBAC3B,OAAO,CAAC,EAAC,KAAK,EAAC,GAAG,uBAAuB,IAAI,EAAC,CAAC,CAAC;YAClD,CAAC;YAAC,IAAI,QAAQ,EAAE,EAAE,CAAC;gBACjB,OAAO,CAAC,EAAC,KAAK,EAAC,SAAS,EAAC,CAAC,CAAC;YAC7B,CAAC;YACD,OAAO,CAAC,EAAE,CAAC,CAAC;YAEZ,SAAS,QAAQ;gBACf,OAAO,CAAC,wBAAwB,IAAI,CAAC,CAAC,IAAG,CAAC,IAAI,uBAAuB,IAAI,IAAI,CAAC;YAChF,CAAC;QACH,CAAC,CAAC,CACH,CAAC;QAGF,iBAAY,GAAG,CAAC,GAAW,EAAE,GAAW,EAAE,EAAE;YAC1C,IAAG,GAAG,IAAI,SAAS,IAAI,GAAG,KAAK,MAAM;gBAAE,OAAO,EAAE,CAAC;YACjD,IAAI,CAAC;gBACH,OAAO,IAAI,CAAC,gBAAgB,CAAC,iBAAiB,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,GAAG,EAAC,CAAC,CAAC;YACpG,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBACf,OAAO,GAAG,CAAC;YACb,CAAC;QACH,CAAC,CAAA;QAvJC,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC,MAAM,CAAC;YAC9B,SAAS,EAAE;gBACT,EAAC,OAAO,EAAE,QAAQ,EAAE,UAAU,EAAE,GAAE,EAAE,CAAC,IAAI,CAAC,KAAK,EAAE;gBACjD,EAAC,OAAO,EAAE,WAAW,EAAE,UAAU,EAAE,GAAE,EAAE,CAAC,IAAI,CAAC,QAAQ,EAAE;aACxD;YACD,MAAM,EAAE,QAAQ;SACjB,CAAC,CAAC;QAEH,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,mBAAmB,CAAE,CAAC;QAE/D,IAAI,CAAC,eAAe,EAAE,CAAC;IACzB,CAAC;IAID,WAAW,CAAC,OAAsB;QAChC,IAAI,OAAO,CAAC,IAAI,IAAI,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC;YACvD,IAAI,CAAC,iBAAiB,CAAC,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;QACzC,CAAC;IACH,CAAC;IAED,QAAQ;QACN,IAAI,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC,eAAe,EAAE,CAAC;YACvC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC9B,CAAC;QAED,IAAI,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC,WAAW,EAAE,CAAC;YACpC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAC5B,CAAC;QAED,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,WAAW,EAAE,OAAO,CAAC,EAAE;YACxC,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC,CAAA;QAC7C,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,iBAAiB,CAAC,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;QAEvC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,iBAAiB,EAAE,IAAI,CAAC,EAAE;YACjD,IAAI,CAAC,IAAI,GAAG,CAAC,GAAG,IAAI,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC,CAAC;YACvC,IAAI,CAAC,SAAS,EAAE,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,CAAA;QACzD,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC,UAAW,CAAC,aAAa,EAAE,CAAC,IAAI,EAAE,EAAE;YACnE,IAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,MAAM,EAAC,CAAC;gBACjC,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC;gBACvE,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,GAAG,OAAO,CAAC,CAAC;YACtC,CAAC;QACH,CAAC,CAAC,CAAA;QAEF,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC;QAEjG,IAAI,CAAC,cAAc,GAAG,aAAa,CAAC;YAClC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,EAAE,oBAAoB,EAAE,CAAC;YACpE,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,UAAU,EAAE,MAAM,CAAC,CAAC,EAAE,oBAAoB,EAAE,CAAC;YACrH,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,GAAG,CAAC,WAAW,CAAC,EAAE,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,UAAU,EAAE,SAAS,EAAE,UAAU,CAAC,CAAC,EAAE,oBAAoB,EAAE,CAAC;SAClI,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,OAAO,EAAE,YAAY,EAAE,eAAe,CAAC,EAAE,EAAE;YACvD,MAAM,kBAAkB,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC,eAAe,CAAC;YAC9D,OAAO,eAAe,IAAI,CAAC,OAAO,IAAI,CAAC,YAAY,IAAI,kBAAkB,CAAC,CAAC,CAAC,CAAC,CAAC,gBAAgB,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,cAAc,CAAC;QAC1I,CAAC,CAAC,CAAC,CAAC;QAEJ,IAAG,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC,YAAY,IAAI,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC,gBAAgB,EAAE,CAAC;YAC1F,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,KAAK,EAAE,EAAE;gBACzC,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC,YAAY,CAAC;gBACtC,IAAG,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC,YAAY,EAAE,CAAC;oBAC3C,IAAI,CAAC,WAAW,IAAI,CAAC,KAAK,CAAC,QAAQ,GAAG,KAAK,CAAC,WAAW,CAAC,CAAC;gBAC3D,CAAC;YACH,CAAC,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAGD,aAAa,CAAC,CAAS,EAAE,GAA+B;QACtD,OAAO,GAAG,CAAC,aAAa,CAAC;IAC3B,CAAC;IAED,WAAW,CAAC,GAAW,EAAE,QAAgB,EAAE,UAAmB;QAC5D,IAAI,CAAC,KAAK,CAAC,oBAAoB,CAAC,EAAE,GAAG,EAAG,UAAU,EAAE,QAAQ,EAAE,CAAC,CAAC;IAClE,CAAC;IAED,WAAW,CAAC,MAAkB;QAC5B,MAAM,aAAa,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;QAC1D,IAAG,aAAa,EAAE,CAAC;YACjB,aAAa,CAAC,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC;QAC3C,CAAC;aAAM,CAAC;YACN,MAAM,SAAS,GAAG,IAAI,CAAC,aAAa,CAAC,eAAe,CAAC,sBAAsB,EAAE;gBAC3E,KAAK,EAAE,CAAC;gBACR,QAAQ,EAAE,IAAI,CAAC,QAAQ;aACxB,CAAC,CAAC;YACH,SAAS,CAAC,QAAQ,CAAC,UAAU,GAAG,MAAM,CAAC,UAAU,CAAC;YAClD,SAAS,CAAC,QAAQ,CAAC,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC;YAC9C,SAAS,CAAC,QAAQ,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC;YACtC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,QAAQ,CAAC,GAAG,CAAC,GAAG,SAAS,CAAC,QAAQ,CAAC;QAC3D,CAAC;IACH,CAAC;IAiBD,eAAe,CAAC,OAAgB;QAC9B,IAAI,CAAC,SAAS,GAAG,OAAO,CAAC,CAAC,CAAC,IAAI,cAAc,CAAM,IAAI,EAAE,EAAE,EAAE,IAAI,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,cAAc,CAAM,IAAI,EAAE,EAAE,CAAC,CAAC;QAC5I,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;IACtE,CAAC;IAED,aAAa;QACX,MAAM,WAAW,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,MAAM,CAAC;QACnD,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC,UAAU,EAAE,IAAI,CAAC,MAAM,CAAC;QAC3D,OAAO,WAAW,KAAK,OAAO,CAAC;IACjC,CAAC;IAED,gFAAgF;IAChF,YAAY;QACV,IAAI,CAAC,aAAa,EAAE,CAAC,CAAC;YACpB,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC,CAAC;YACxB,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC,UAAW,CAAC,IAAI,CAAC,CAAC;IAClE,CAAC;8GAlKU,qBAAqB;kGAArB,qBAAqB,oTAiBrB,QAAQ,yFACR,WAAW,mFC/DxB,m7FAuEA,ozBD9BI,cAAc,y7CAAE,cAAc,2gBAAE,iBAAiB,6WAAE,eAAe,2IAAE,aAAa,oLAAE,gBAAgB,mJACnG,gBAAgB,0BAAE,SAAS,8CAAE,YAAY,4FAAE,YAAY;;2FAG9C,qBAAqB;kBAXjC,SAAS;+BACE,kBAAkB,mBAGX,uBAAuB,CAAC,MAAM,cACnC,IAAI,WACP;wBACP,cAAc,EAAE,cAAc,EAAE,iBAAiB,EAAE,eAAe,EAAE,aAAa,EAAE,gBAAgB;wBACnG,gBAAgB,EAAE,SAAS,EAAE,YAAY,EAAE,YAAY;qBACxD;oKAOY,OAAO;sBAAnB,KAAK;gBAMG,YAAY;sBAApB,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBAEiC,KAAK;sBAA3C,SAAS;uBAAC,QAAQ,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBACK,QAAQ;sBAAjD,SAAS;uBAAC,WAAW,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBA6H9B,UAAU;sBAAnB,MAAM","sourcesContent":["import {\r\n  Component,\r\n  ViewChild,\r\n  Input,\r\n  ChangeDetectionStrategy,\r\n  Output,\r\n  SimpleChanges,\r\n  OnInit,\r\n  QueryList,\r\n  ViewContainerRef,\r\n  Injector,\r\n  EventEmitter,\r\n} from '@angular/core';\r\nimport { MatRowDef, MatTable, MatTableModule } from '@angular/material/table';\r\nimport { Observable, combineLatest } from 'rxjs';\r\nimport { SelectionChange, SelectionModel } from '@angular/cdk/collections';\r\nimport { TableStore } from '../../classes/table-store';\r\nimport { map, distinctUntilChanged } from 'rxjs/operators';\r\nimport { ColumnBuilderComponent } from '../column-builder/column-builder.component';\r\nimport { Dictionary } from '../../interfaces/dictionary';\r\nimport { FieldType } from '../../interfaces/report-def';\r\nimport { previousAndCurrent } from '../../../rxjs/rxjs-operators';\r\nimport { ColumnInfo } from '../../interfaces/ColumnInfo';\r\nimport { CdkDragDrop, CdkDropList, DragDropModule } from '@angular/cdk/drag-drop';\r\nimport { FunctionPipe } from '../../../utilities';\r\nimport { MatCheckboxModule } from '@angular/material/checkbox';\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { AsyncPipe, NgTemplateOutlet } from '@angular/common';\r\nimport { MatTooltipModule } from '@angular/material/tooltip';\r\nimport { LetDirective } from '@ngrx/component';\r\nimport { TransformCreator } from '../../services/transform-creator';\r\nimport { initIndexSymbol } from '../table-container/table-container.helpers/sort-state.helpers';\r\n\r\n@Component({\r\n  selector: 'tb-generic-table',\r\n  templateUrl: './generic-table.component.html',\r\n  styleUrls: ['./generic-table.component.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  standalone: true,\r\n  imports: [\r\n    MatTableModule, DragDropModule, MatCheckboxModule, MatButtonModule, MatIconModule, NgTemplateOutlet,\r\n    MatTooltipModule, AsyncPipe, LetDirective, FunctionPipe,\r\n  ],\r\n})\r\nexport class GenericTableComponent implements OnInit {\r\n\r\n  drop(event: CdkDragDrop<string[]>) {\r\n    this.state.setUserDefinedOrder({ newOrder:event.currentIndex, oldOrder:event.previousIndex })\r\n  }\r\n  @Input() set trackBy(trackBy: string){\r\n    if(trackBy){\r\n      this.trackByFunction = (index:number, item: any) => item[trackBy];\r\n    }\r\n    this.setUpSelections(trackBy);\r\n  }\r\n  @Input() displayData$!: Observable<any[]>;\r\n  @Input() data$!: Observable<any[]>;\r\n  @Input() rows!: QueryList<MatRowDef<any>>;\r\n  @Input() columnBuilders!: ColumnBuilderComponent[];\r\n  @Input() columnInfos!: Observable<ColumnInfo[]>;\r\n\r\n  @ViewChild(MatTable, { static: true }) table!: MatTable<any>;\r\n  @ViewChild(CdkDropList, { static: true }) dropList!: CdkDropList;\r\n\r\n  currentColumns!: string[];\r\n  keys: string [] = [];\r\n  injector: Injector;\r\n  rowDefArr :MatRowDef<any>[] = [];\r\n  columns:string [] = [];\r\n  myColumns: Dictionary<ColumnBuilderComponent> = {};\r\n  showHeader$!: Observable<boolean>;\r\n  offset$! : Observable<number>;\r\n  offsetIndex = 0;\r\n  dataView!: Observable<any[]>;\r\n\r\n  constructor(\r\n    public state: TableStore,\r\n    private viewContainer: ViewContainerRef,\r\n    private transformCreator: TransformCreator,\r\n    injector: Injector,\r\n    ) {\r\n    this.injector = Injector.create({\r\n      providers: [\r\n        {provide: MatTable, useFactory: ()=> this.table },\r\n        {provide: CdkDropList, useFactory: ()=> this.dropList },\r\n      ],\r\n      parent: injector\r\n    });\r\n\r\n    this.offset$ = this.state.select( s => s.virtualScrollOffset );\r\n\r\n    this.setUpSelections();\r\n  }\r\n\r\n  defaultTrackBy = (index:number, item: any) => item[initIndexSymbol];\r\n  trackByFunction = this.defaultTrackBy;\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    if (changes.rows && this.rows && this.myColumns.length) {\r\n      this.initializeRowDefs([...this.rows]);\r\n    }\r\n  }\r\n\r\n  ngOnInit() {\r\n    if (this.state.props().selectionColumn) {\r\n      this.columns.push('select');\r\n    }\r\n\r\n    if (this.state.props().indexColumn) {\r\n     this.columns.push('index');\r\n    }\r\n\r\n    this.state.on(this.columnInfos, columns => {\r\n      columns.forEach(ci => this.addMetaData(ci))\r\n    });\r\n\r\n    this.initializeRowDefs([...this.rows]);\r\n\r\n    this.state.on(this.state.displayedColumns$, keys => {\r\n      this.keys = [...this.columns, ...keys];\r\n      this.rowDefArr?.forEach(row => row.columns = this.keys)\r\n    });\r\n\r\n    this.state.on(this.state.props().dataSource!.viewableData$, (data) => {\r\n      if(this.selection.selected.length){\r\n        const removed = this.selection.selected.filter(s => !data.includes(s));\r\n        this.selection.deselect(...removed);\r\n      }\r\n    })\r\n\r\n    this.showHeader$ = this.state.tableSettings$.pipe(map(settings => !(settings.hideColumnHeader)));\r\n\r\n    this.showFooterRow$ = combineLatest([\r\n      this.displayData$.pipe(map(d => !!d.length), distinctUntilChanged()),\r\n      this.state.metaDataArray$.pipe(map(metaData => metaData.some(md => !!md.additional?.footer)), distinctUntilChanged()),\r\n      this.columnInfos.pipe(map(columnInfos => columnInfos.some(ci => !!ci.customCell?.columnDef?.footerCell)), distinctUntilChanged()),\r\n    ]).pipe(map(([hasData, hasFooterDef, hasCustomFooter]) => {\r\n      const hasSelectionColumn = this.state.props().selectionColumn;\r\n      return hasCustomFooter || (hasData && (hasFooterDef || hasSelectionColumn)) ? 'regular-footer' : hasData ? 'no-footer' : 'small-footer';\r\n    }));\r\n\r\n    if(this.state.tableSettings().usePaginator || this.state.tableSettings().useVirtualScroll) {\r\n      this.state.on(this.state.state$, (state) => {\r\n        this.offsetIndex = state.virtualStart;\r\n        if(this.state.tableSettings().usePaginator) {\r\n          this.offsetIndex += (state.pageSize * state.currentPage);\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n\r\n  isGroupHeader(_: number, row: { isGroupHeader: boolean }) {\r\n    return row.isGroupHeader;\r\n  }\r\n\r\n  setExpanded(key: string, groupKey: string, isExpanded: boolean): void {\r\n    this.state.updateExpandedGroups({ key , isExpanded, groupKey });\r\n  }\r\n\r\n  addMetaData(column: ColumnInfo) {\r\n    const columnBuilder = this.myColumns[column.metaData.key];\r\n    if(columnBuilder) {\r\n      columnBuilder.metaData = column.metaData;\r\n    } else {\r\n      const component = this.viewContainer.createComponent(ColumnBuilderComponent, {\r\n        index: 0,\r\n        injector: this.injector\r\n      });\r\n      component.instance.customCell = column.customCell;\r\n      component.instance.metaData = column.metaData;\r\n      component.instance.data$ = this.data$;\r\n      this.myColumns[column.metaData.key] = component.instance;\r\n    }\r\n  }\r\n\r\n  initializeRowDefs = (defs:MatRowDef<any>[])=>{\r\n    this.rowDefArr.forEach(r=>this.table.removeRowDef(r));\r\n    this.rowDefArr = defs;\r\n    defs.forEach(r => {\r\n      r.columns = this.columns.concat(Object.values(this.myColumns).filter(c => c.metaData.fieldType !== FieldType.Hidden).map(c => c.metaData.key));\r\n      if (this.table) {\r\n        this.table.addRowDef(r);\r\n      }\r\n    });\r\n  }\r\n\r\n  selection! : SelectionModel<any>;\r\n  @Output() selection$ = new EventEmitter<SelectionChange<any>>();\r\n  masterToggleChecked$ = this.selection$.pipe(map(()=>this.selection.hasValue() && this.isAllSelected()));\r\n  masterToggleIndeterminate$ = this.selection$.pipe(map(()=>this.selection.hasValue() && !this.isAllSelected()));\r\n  setUpSelections(trackBy?: string){\r\n    this.selection = trackBy ? new SelectionModel<any>(true, [], true, (a, b) => a[trackBy] === b[trackBy]) : new SelectionModel<any>(true, []);\r\n    this.state.on(this.selection.changed, c => this.selection$.emit(c));\r\n  }\r\n\r\n  isAllSelected() {\r\n    const numSelected = this.selection.selected.length;\r\n    const numRows = this.state.props().dataSource?.data.length;\r\n    return numSelected === numRows;\r\n  }\r\n\r\n  /** Selects all rows if they are not all selected; otherwise clear selection. */\r\n  masterToggle() {\r\n    this.isAllSelected() ?\r\n      this.selection.clear() :\r\n      this.selection.select(...this.state.props().dataSource!.data);\r\n  }\r\n\r\n  tableWidth = this.state.getUserDefinedTableSize$.pipe(\r\n    previousAndCurrent<number | undefined>(0),\r\n    map(([previousUserDefinedWidth, currentUserDefinedWidth]) => {\r\n      if( currentUserDefinedWidth){\r\n        return ({width:`${currentUserDefinedWidth}px`});\r\n      } if( wasReset() ){\r\n        return ({width:'initial'});\r\n      }\r\n      return ({});\r\n\r\n      function wasReset(){\r\n        return (previousUserDefinedWidth ?? 0) >=0 && currentUserDefinedWidth == null;\r\n      }\r\n    })\r\n  );\r\n\r\n  showFooterRow$!: Observable<'regular-footer' | 'no-footer' | 'small-footer'>;\r\n  getTransform = (key: string, val: string) => {\r\n    if(val == undefined || val === 'null') return '';\r\n    try {\r\n      return this.transformCreator.createTransformer(this.myColumns[key].metaData, true)({ [key]: val});\r\n    } catch (error) {\r\n      return val;\r\n    }\r\n  }\r\n}\r\n","<mat-table\r\n  cdkDropList\r\n  cdkDropListLockAxis='x'\r\n  cdkDropListOrientation=\"horizontal\"\r\n  (cdkDropListDropped)=\"drop($event)\"\r\n  class=\"table-drag-list\"\r\n  [class]=\"(showFooterRow$ | async)\"\r\n  #table\r\n  [dataSource]=\"state.props().dataSource!\"\r\n  [trackBy]=\"trackByFunction\"\r\n  [style]=\"tableWidth | async\"\r\n>\r\n\r\n  <!-- select column -->\r\n  <ng-container matColumnDef=\"select\">\r\n\r\n    <mat-header-cell *matHeaderCellDef class=\"f-mat-header-cell\">\r\n      <mat-checkbox (change)=\"$event ? masterToggle() : null\"\r\n                    [checked]=\"!!(masterToggleChecked$ | async)\"\r\n                    [indeterminate]=\"masterToggleIndeterminate$ | async\">\r\n      </mat-checkbox>\r\n    </mat-header-cell>\r\n\r\n    <mat-cell *matCellDef=\"let row\">\r\n      <mat-checkbox\r\n      (click)=\"$event.stopPropagation()\"\r\n      (change)=\"$event ? selection.toggle(row) : null\"\r\n      [checked]=\"selection.isSelected(row)\"/>\r\n    </mat-cell>\r\n\r\n    <mat-footer-cell *matFooterCellDef>\r\n      {{ selection.selected.length }}\r\n    </mat-footer-cell>\r\n  </ng-container>\r\n\r\n  <!-- index column -->\r\n  <ng-container matColumnDef=\"index\">\r\n      <mat-header-cell *matHeaderCellDef class=\"f-mat-header-cell\" >#</mat-header-cell>\r\n      <mat-cell *matCellDef=\"let i = index;\">\r\n         {{ 1 + i + offsetIndex}}\r\n      </mat-cell>\r\n      <mat-footer-cell *matFooterCellDef></mat-footer-cell>\r\n  </ng-container>\r\n\r\n  <!-- Grouping -->\r\n  <ng-container matColumnDef=\"groupHeader\">\r\n    <mat-cell *matCellDef=\"let row\">\r\n      <div [style.paddingLeft]=\"row.padding + 'px !important'\" *ngrxLet=\"(state.getIsExpanded | func : row.key : row.groupName ) as expanded\">\r\n        <button mat-icon-button (click)=\"setExpanded(row.key, row.groupName, !expanded);\">\r\n          @if(!expanded){\r\n            <mat-icon>chevron_right</mat-icon>\r\n          } @else {\r\n            <mat-icon>expand_more</mat-icon>\r\n          }\r\n        </button>\r\n        {{getTransform | func : row.key :  row.groupHeaderDisplay}} ({{row.length}})\r\n      </div>\r\n      <div style=\"flex-grow: 1\">\r\n        <ng-container *ngTemplateOutlet=\"state.props().groupHeaderTemplate!; context: { element: row }\"></ng-container>\r\n      </div>\r\n    </mat-cell>\r\n  </ng-container>\r\n\r\n  @if(showHeader$ | async){\r\n    <mat-header-row *matHeaderRowDef=\"keys; sticky: state.props().isSticky\" [style.top.px]=\"((offset$ | async)! * -1)\"  />\r\n  }\r\n  <mat-row *matRowDef=\"let row; columns: keys; let i = index\" />\r\n  <mat-row *matRowDef=\"let row; columns: ['groupHeader']; when: isGroupHeader\" style=\"background-color: white;\" />\r\n  <mat-footer-row *matFooterRowDef=\"(showFooterRow$ | async) === 'regular-footer' ? keys : []; sticky: state.props().stickyFooter \"  [style.bottom.px]=\"state.props().stickyFooter ? (offset$ | async) : undefined\"  />\r\n\r\n</mat-table>\r\n"]}
206
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"generic-table.component.js","sourceRoot":"","sources":["../../../../../../projects/angular-utilities/src/table-builder/components/generic-table/generic-table.component.ts","../../../../../../projects/angular-utilities/src/table-builder/components/generic-table/generic-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ViewChild,\r\n  Input,\r\n  ChangeDetectionStrategy,\r\n  Output,\r\n  SimpleChanges,\r\n  OnInit,\r\n  QueryList,\r\n  ViewContainerRef,\r\n  Injector,\r\n  EventEmitter,\r\n} from '@angular/core';\r\nimport { MatRowDef, MatTable, MatTableModule } from '@angular/material/table';\r\nimport { Observable, combineLatest } from 'rxjs';\r\nimport { SelectionChange, SelectionModel } from '@angular/cdk/collections';\r\nimport { TableStore } from '../../classes/table-store';\r\nimport { map, distinctUntilChanged } from 'rxjs/operators';\r\nimport { ColumnBuilderComponent } from '../column-builder/column-builder.component';\r\nimport { Dictionary } from '../../interfaces/dictionary';\r\nimport { FieldType } from '../../interfaces/report-def';\r\nimport { previousAndCurrent } from '../../../rxjs/rxjs-operators';\r\nimport { ColumnInfo } from '../../interfaces/ColumnInfo';\r\nimport { CdkDragDrop, CdkDropList, DragDropModule } from '@angular/cdk/drag-drop';\r\nimport { FunctionPipe } from '../../../utilities';\r\nimport { MatCheckboxModule } from '@angular/material/checkbox';\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { AsyncPipe, NgTemplateOutlet } from '@angular/common';\r\nimport { MatTooltipModule } from '@angular/material/tooltip';\r\nimport { LetDirective } from '@ngrx/component';\r\nimport { TransformCreator } from '../../services/transform-creator';\r\nimport { initIndexSymbol } from '../table-container/table-container.helpers/sort-state.helpers';\r\n\r\n@Component({\r\n  selector: 'tb-generic-table',\r\n  templateUrl: './generic-table.component.html',\r\n  styleUrls: ['./generic-table.component.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  standalone: true,\r\n  imports: [\r\n    MatTableModule, DragDropModule, MatCheckboxModule, MatButtonModule, MatIconModule, NgTemplateOutlet,\r\n    MatTooltipModule, AsyncPipe, LetDirective, FunctionPipe,\r\n  ],\r\n})\r\nexport class GenericTableComponent implements OnInit {\r\n\r\n  drop(event: CdkDragDrop<string[]>) {\r\n    this.state.setUserDefinedOrder({ newOrder:event.currentIndex, oldOrder:event.previousIndex })\r\n  }\r\n  _trackBy?: string;\r\n  @Input() set trackBy(trackBy: string){\r\n    if(trackBy){\r\n      this._trackBy = trackBy;\r\n      this.trackByFunction = (index:number, item: any) => item[trackBy];\r\n    }\r\n    this.setUpSelections(trackBy);\r\n  }\r\n  get trackBy(): string | undefined { return this._trackBy }\r\n  @Input() displayData$!: Observable<any[]>;\r\n  @Input() data$!: Observable<any[]>;\r\n  @Input() rows!: QueryList<MatRowDef<any>>;\r\n  @Input() columnBuilders!: ColumnBuilderComponent[];\r\n  @Input() columnInfos!: Observable<ColumnInfo[]>;\r\n\r\n  @ViewChild(MatTable, { static: true }) table!: MatTable<any>;\r\n  @ViewChild(CdkDropList, { static: true }) dropList!: CdkDropList;\r\n\r\n  currentColumns!: string[];\r\n  keys: string [] = [];\r\n  injector: Injector;\r\n  rowDefArr :MatRowDef<any>[] = [];\r\n  columns:string [] = [];\r\n  myColumns: Dictionary<ColumnBuilderComponent> = {};\r\n  showHeader$!: Observable<boolean>;\r\n  offset$! : Observable<number>;\r\n  offsetIndex = 0;\r\n  dataView!: Observable<any[]>;\r\n\r\n  constructor(\r\n    public state: TableStore,\r\n    private viewContainer: ViewContainerRef,\r\n    private transformCreator: TransformCreator,\r\n    injector: Injector,\r\n    ) {\r\n    this.injector = Injector.create({\r\n      providers: [\r\n        {provide: MatTable, useFactory: ()=> this.table },\r\n        {provide: CdkDropList, useFactory: ()=> this.dropList },\r\n      ],\r\n      parent: injector\r\n    });\r\n\r\n    this.offset$ = this.state.select( s => s.virtualScrollOffset );\r\n\r\n    this.setUpSelections();\r\n  }\r\n\r\n  defaultTrackBy = (index:number, item: any) => item[initIndexSymbol];\r\n  trackByFunction = this.defaultTrackBy;\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    if (changes.rows && this.rows && this.myColumns.length) {\r\n      this.initializeRowDefs([...this.rows]);\r\n    }\r\n  }\r\n\r\n  ngOnInit() {\r\n    if (this.state.props().selectionColumn) {\r\n      this.columns.push('select');\r\n    }\r\n\r\n    if (this.state.props().indexColumn) {\r\n     this.columns.push('index');\r\n    }\r\n\r\n    this.state.on(this.columnInfos, columns => {\r\n      columns.forEach(ci => this.addMetaData(ci))\r\n    });\r\n\r\n    this.initializeRowDefs([...this.rows]);\r\n\r\n    this.state.on(this.state.displayedColumns$, keys => {\r\n      this.keys = [...this.columns, ...keys];\r\n      this.rowDefArr?.forEach(row => row.columns = this.keys)\r\n    });\r\n\r\n    this.state.on(this.state.props().dataSource!.viewableData$, (data) => {\r\n      if(this.selection.selected.length){\r\n        const trackByFunction = this.trackBy ? (s) => data.every(d =>  d[this.trackBy!] !== s[this.trackBy!]) : s => !data.includes(s);\r\n        const removed = this.selection.selected.filter(trackByFunction);\r\n        this.selection.deselect(...removed);\r\n      }\r\n    })\r\n\r\n    this.showHeader$ = this.state.tableSettings$.pipe(map(settings => !(settings.hideColumnHeader)));\r\n\r\n    this.showFooterRow$ = combineLatest([\r\n      this.displayData$.pipe(map(d => !!d.length), distinctUntilChanged()),\r\n      this.state.metaDataArray$.pipe(map(metaData => metaData.some(md => !!md.additional?.footer)), distinctUntilChanged()),\r\n      this.columnInfos.pipe(map(columnInfos => columnInfos.some(ci => !!ci.customCell?.columnDef?.footerCell)), distinctUntilChanged()),\r\n    ]).pipe(map(([hasData, hasFooterDef, hasCustomFooter]) => {\r\n      const hasSelectionColumn = this.state.props().selectionColumn;\r\n      return hasCustomFooter || (hasData && (hasFooterDef || hasSelectionColumn)) ? 'regular-footer' : hasData ? 'no-footer' : 'small-footer';\r\n    }));\r\n\r\n    if(this.state.tableSettings().usePaginator || this.state.tableSettings().useVirtualScroll) {\r\n      this.state.on(this.state.state$, (state) => {\r\n        this.offsetIndex = state.virtualStart;\r\n        if(this.state.tableSettings().usePaginator) {\r\n          this.offsetIndex += (state.pageSize * state.currentPage);\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n\r\n  isGroupHeader(_: number, row: { isGroupHeader: boolean }) {\r\n    return row.isGroupHeader;\r\n  }\r\n\r\n  setExpanded(key: string, groupKey: string, isExpanded: boolean): void {\r\n    this.state.updateExpandedGroups({ key , isExpanded, groupKey });\r\n  }\r\n\r\n  addMetaData(column: ColumnInfo) {\r\n    const columnBuilder = this.myColumns[column.metaData.key];\r\n    if(columnBuilder) {\r\n      columnBuilder.metaData = column.metaData;\r\n    } else {\r\n      const component = this.viewContainer.createComponent(ColumnBuilderComponent, {\r\n        index: 0,\r\n        injector: this.injector\r\n      });\r\n      component.instance.customCell = column.customCell;\r\n      component.instance.metaData = column.metaData;\r\n      component.instance.data$ = this.data$;\r\n      this.myColumns[column.metaData.key] = component.instance;\r\n    }\r\n  }\r\n\r\n  initializeRowDefs = (defs:MatRowDef<any>[])=>{\r\n    this.rowDefArr.forEach(r=>this.table.removeRowDef(r));\r\n    this.rowDefArr = defs;\r\n    defs.forEach(r => {\r\n      r.columns = this.columns.concat(Object.values(this.myColumns).filter(c => c.metaData.fieldType !== FieldType.Hidden).map(c => c.metaData.key));\r\n      if (this.table) {\r\n        this.table.addRowDef(r);\r\n      }\r\n    });\r\n  }\r\n\r\n  selection! : SelectionModel<any>;\r\n  @Output() selection$ = new EventEmitter<SelectionChange<any>>();\r\n  masterToggleChecked$ = this.selection$.pipe(map(()=>this.selection.hasValue() && this.isAllSelected()));\r\n  masterToggleIndeterminate$ = this.selection$.pipe(map(()=>this.selection.hasValue() && !this.isAllSelected()));\r\n  setUpSelections(trackBy?: string){\r\n    this.selection = trackBy ? new SelectionModel<any>(true, [], true, (a, b) => a[trackBy] === b[trackBy]) : new SelectionModel<any>(true, []);\r\n    this.state.on(this.selection.changed, c => this.selection$.emit(c));\r\n  }\r\n\r\n  isAllSelected() {\r\n    const numSelected = this.selection.selected.length;\r\n    const numRows = this.state.props().dataSource?.data.length;\r\n    return numSelected === numRows;\r\n  }\r\n\r\n  /** Selects all rows if they are not all selected; otherwise clear selection. */\r\n  masterToggle() {\r\n    this.isAllSelected() ?\r\n      this.selection.clear() :\r\n      this.selection.select(...this.state.props().dataSource!.data);\r\n  }\r\n\r\n  tableWidth = this.state.getUserDefinedTableSize$.pipe(\r\n    previousAndCurrent<number | undefined>(0),\r\n    map(([previousUserDefinedWidth, currentUserDefinedWidth]) => {\r\n      if( currentUserDefinedWidth){\r\n        return ({width:`${currentUserDefinedWidth}px`});\r\n      } if( wasReset() ){\r\n        return ({width:'initial'});\r\n      }\r\n      return ({});\r\n\r\n      function wasReset(){\r\n        return (previousUserDefinedWidth ?? 0) >=0 && currentUserDefinedWidth == null;\r\n      }\r\n    })\r\n  );\r\n\r\n  showFooterRow$!: Observable<'regular-footer' | 'no-footer' | 'small-footer'>;\r\n  getTransform = (key: string, val: string) => {\r\n    if(val == undefined || val === 'null') return '';\r\n    try {\r\n      return this.transformCreator.createTransformer(this.myColumns[key].metaData, true)({ [key]: val});\r\n    } catch (error) {\r\n      return val;\r\n    }\r\n  }\r\n}\r\n","<mat-table\r\n  cdkDropList\r\n  cdkDropListLockAxis='x'\r\n  cdkDropListOrientation=\"horizontal\"\r\n  (cdkDropListDropped)=\"drop($event)\"\r\n  class=\"table-drag-list\"\r\n  [class]=\"(showFooterRow$ | async)\"\r\n  #table\r\n  [dataSource]=\"state.props().dataSource!\"\r\n  [trackBy]=\"trackByFunction\"\r\n  [style]=\"tableWidth | async\"\r\n>\r\n\r\n  <!-- select column -->\r\n  <ng-container matColumnDef=\"select\">\r\n\r\n    <mat-header-cell *matHeaderCellDef class=\"f-mat-header-cell\">\r\n      <mat-checkbox (change)=\"$event ? masterToggle() : null\"\r\n                    [checked]=\"!!(masterToggleChecked$ | async)\"\r\n                    [indeterminate]=\"masterToggleIndeterminate$ | async\">\r\n      </mat-checkbox>\r\n    </mat-header-cell>\r\n\r\n    <mat-cell *matCellDef=\"let row\">\r\n      <mat-checkbox\r\n      (click)=\"$event.stopPropagation()\"\r\n      (change)=\"$event ? selection.toggle(row) : null\"\r\n      [checked]=\"selection.isSelected(row)\"/>\r\n    </mat-cell>\r\n\r\n    <mat-footer-cell *matFooterCellDef>\r\n      {{ selection.selected.length }}\r\n    </mat-footer-cell>\r\n  </ng-container>\r\n\r\n  <!-- index column -->\r\n  <ng-container matColumnDef=\"index\">\r\n      <mat-header-cell *matHeaderCellDef class=\"f-mat-header-cell\" >#</mat-header-cell>\r\n      <mat-cell *matCellDef=\"let i = index;\">\r\n         {{ 1 + i + offsetIndex}}\r\n      </mat-cell>\r\n      <mat-footer-cell *matFooterCellDef></mat-footer-cell>\r\n  </ng-container>\r\n\r\n  <!-- Grouping -->\r\n  <ng-container matColumnDef=\"groupHeader\">\r\n    <mat-cell *matCellDef=\"let row\">\r\n      <div [style.paddingLeft]=\"row.padding + 'px !important'\" *ngrxLet=\"(state.getIsExpanded | func : row.key : row.groupName ) as expanded\">\r\n        <button mat-icon-button (click)=\"setExpanded(row.key, row.groupName, !expanded);\">\r\n          @if(!expanded){\r\n            <mat-icon>chevron_right</mat-icon>\r\n          } @else {\r\n            <mat-icon>expand_more</mat-icon>\r\n          }\r\n        </button>\r\n        {{getTransform | func : row.key :  row.groupHeaderDisplay}} ({{row.length}})\r\n      </div>\r\n      <div style=\"flex-grow: 1\">\r\n        <ng-container *ngTemplateOutlet=\"state.props().groupHeaderTemplate!; context: { element: row }\"></ng-container>\r\n      </div>\r\n    </mat-cell>\r\n  </ng-container>\r\n\r\n  @if(showHeader$ | async){\r\n    <mat-header-row *matHeaderRowDef=\"keys; sticky: state.props().isSticky\" [style.top.px]=\"((offset$ | async)! * -1)\"  />\r\n  }\r\n  <mat-row *matRowDef=\"let row; columns: keys; let i = index\" />\r\n  <mat-row *matRowDef=\"let row; columns: ['groupHeader']; when: isGroupHeader\" style=\"background-color: white;\" />\r\n  <mat-footer-row *matFooterRowDef=\"(showFooterRow$ | async) === 'regular-footer' ? keys : []; sticky: state.props().stickyFooter \"  [style.bottom.px]=\"state.props().stickyFooter ? (offset$ | async) : undefined\"  />\r\n\r\n</mat-table>\r\n"]}
@@ -1,4 +1,4 @@
1
- import { inject } from "@angular/core";
1
+ import { createComponent, inject } from "@angular/core";
2
2
  import { Injectable } from "@angular/core";
3
3
  import { ArrayStyle, FieldType } from "../interfaces/report-def";
4
4
  import { InitializationComponent } from "../components/initialization-component/initialization-component";
@@ -39,18 +39,19 @@ export class TableTemplateService {
39
39
  }
40
40
  return tmp;
41
41
  }
42
- constructor(resolver, i) {
42
+ constructor(ei) {
43
43
  this.tableConfig = inject(TableBuilderConfigToken);
44
- const factory = resolver.resolveComponentFactory(InitializationComponent);
45
- const c = factory.create(i);
44
+ const c = createComponent(InitializationComponent, {
45
+ environmentInjector: ei,
46
+ });
46
47
  this.instance = c.instance;
47
48
  this.initTemplates();
48
49
  }
49
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: TableTemplateService, deps: [{ token: i0.ComponentFactoryResolver }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Injectable }); }
50
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: TableTemplateService, deps: [{ token: i0.EnvironmentInjector }], target: i0.ɵɵFactoryTarget.Injectable }); }
50
51
  static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: TableTemplateService, providedIn: 'root' }); }
51
52
  }
52
53
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: TableTemplateService, decorators: [{
53
54
  type: Injectable,
54
55
  args: [{ providedIn: 'root' }]
55
- }], ctorParameters: () => [{ type: i0.ComponentFactoryResolver }, { type: i0.Injector }] });
56
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtdGVtcGxhdGUtc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItdXRpbGl0aWVzL3NyYy90YWJsZS1idWlsZGVyL3NlcnZpY2VzL3RhYmxlLXRlbXBsYXRlLXNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFzQyxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDM0UsT0FBTyxFQUFFLFVBQVUsRUFBZSxNQUFNLGVBQWUsQ0FBQztBQUN4RCxPQUFPLEVBQW1CLFVBQVUsRUFBRSxTQUFTLEVBQVksTUFBTSwwQkFBMEIsQ0FBQztBQUM1RixPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxpRUFBaUUsQ0FBQztBQUMxRyxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQzs7QUFHeEUsTUFBTSxPQUFPLG9CQUFvQjtJQUkvQixhQUFhO1FBQ1gsSUFBSSxDQUFDLFNBQVMsR0FBRyxFQUFHLENBQUM7UUFDckIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQyxvQkFBb0IsQ0FBQztRQUNyRSxJQUFJLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBQyxLQUFLLEdBQUcsRUFBRSxDQUFDLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQyxrQkFBa0IsQ0FBQztRQUN4RSxJQUFJLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBQyxPQUFPLENBQUMsR0FBRyxJQUFJLENBQUMsUUFBUSxDQUFDLGVBQWUsQ0FBQztRQUNsRSxJQUFJLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUMsR0FBRyxJQUFJLENBQUMsUUFBUSxDQUFDLGVBQWUsQ0FBQztRQUNuRSxJQUFJLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsR0FBRyxJQUFJLENBQUMsUUFBUSxDQUFD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Q0FBQyxRQUFRLEdBQUcsQ0FBQyxDQUFDLFFBQVEsQ0FBQztRQUMzQixJQUFJLENBQUMsYUFBYSxFQUFFLENBQUM7SUFDM0IsQ0FBQzs4R0E3Q1Usb0JBQW9CO2tIQUFwQixvQkFBb0IsY0FEUixNQUFNOzsyRkFDbEIsb0JBQW9CO2tCQURoQyxVQUFVO21CQUFDLEVBQUMsVUFBVSxFQUFFLE1BQU0sRUFBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudEZhY3RvcnlSZXNvbHZlciwgSW5qZWN0b3IsIGluamVjdCB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7IEluamVjdGFibGUsIFRlbXBsYXRlUmVmIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHsgQXJyYXlBZGRpdGlvbmFsLCBBcnJheVN0eWxlLCBGaWVsZFR5cGUsIE1ldGFEYXRhIH0gZnJvbSBcIi4uL2ludGVyZmFjZXMvcmVwb3J0LWRlZlwiO1xyXG5pbXBvcnQgeyBJbml0aWFsaXphdGlvbkNvbXBvbmVudCB9IGZyb20gXCIuLi9jb21wb25lbnRzL2luaXRpYWxpemF0aW9uLWNvbXBvbmVudC9pbml0aWFsaXphdGlvbi1jb21wb25lbnRcIjtcclxuaW1wb3J0IHsgVGFibGVCdWlsZGVyQ29uZmlnVG9rZW4gfSBmcm9tIFwiLi4vY2xhc3Nlcy9UYWJsZUJ1aWxkZXJDb25maWdcIjtcclxuXHJcbkBJbmplY3RhYmxlKHtwcm92aWRlZEluOiAncm9vdCd9KVxyXG5leHBvcnQgY2xhc3MgVGFibGVUZW1wbGF0ZVNlcnZpY2Uge1xyXG4gIGluc3RhbmNlITogSW5pdGlhbGl6YXRpb25Db21wb25lbnQ7XHJcbiAgdGVtcGxhdGVzO1xyXG5cclxuICBpbml0VGVtcGxhdGVzKCkge1xyXG4gICAgdGhpcy50ZW1wbGF0ZXMgPSB7IH07XHJcbiAgICB0aGlzLnRlbXBsYXRlc1tGaWVsZFR5cGUuQXJyYXldID0gdGhpcy5pbnN0YW5jZS5hcnJheU5ld0xpbmVUZW1wbGF0ZTtcclxuICAgIHRoaXMudGVtcGxhdGVzW0ZpZWxkVHlwZS5BcnJheSArIC41XSA9IHRoaXMuaW5zdGFuY2UuYXJyYXlDb21tYVRlbXBsYXRlO1xyXG4gICAgdGhpcy50ZW1wbGF0ZXNbRmllbGRUeXBlLkJvb2xlYW5dID0gdGhpcy5pbnN0YW5jZS5kZWZhdWx0V2l0aEljb247XHJcbiAgICB0aGlzLnRlbXBsYXRlc1tGaWVsZFR5cGUuQ3VycmVuY3ldID0gdGhpcy5pbnN0YW5jZS5kZWZhdWx0VGVtcGxhdGU7XHJcbiAgICB0aGlzLnRlbXBsYXRlc1tGaWVsZFR5cGUuRGF0ZV0gPSB0aGlzLmluc3RhbmNlLmRlZmF1bHRUZW1wbGF0ZTtcclxuICAgIHRoaXMudGVtcGxhdGVzW0ZpZWxkVHlwZS5EYXRlVGltZV0gPSB0aGlzLmluc3RhbmNlLmRlZmF1bHRUZW1wbGF0ZTtcclxuICAgIHRoaXMudGVtcGxhdGVzW0ZpZWxkVHlwZS5FeHByZXNzaW9uXSA9IHRoaXMuaW5zdGFuY2UuZGVmYXVsdFRlbXBsYXRlO1xyXG4gICAgdGhpcy50ZW1wbGF0ZXNbRmllbGRUeXBlLk5vdE1hcHBlZF0gPSB0aGlzLmluc3RhbmNlLmRlZmF1bHRUZW1wbGF0ZTtcclxuICAgIHRoaXMudGVtcGxhdGVzW0ZpZWxkVHlwZS5JbWFnZVVybF0gPSB0aGlzLmluc3RhbmNlLmltYWdlVXJsVGVtcGxhdGU7XHJcbiAgICB0aGlzLnRlbXBsYXRlc1tGaWVsZFR5cGUuTGlua10gPSB0aGlzLmluc3RhbmNlLmxpbmtUZW1wbGF0ZTtcclxuICAgIHRoaXMudGVtcGxhdGVzW0ZpZWxkVHlwZS5MaW5rICsgLjVdID0gdGhpcy5pbnN0YW5jZS5yb3V0ZXJMaW5rVGVtcGxhdGU7XHJcbiAgICB0aGlzLnRlbXBsYXRlc1tGaWVsZFR5cGUuTnVtYmVyXSA9IHRoaXMuaW5zdGFuY2UuZGVmYXVsdFRlbXBsYXRlO1xyXG4gICAgdGhpcy50ZW1wbGF0ZXNbRmllbGRUeXBlLlBob25lTnVtYmVyXSA9IHRoaXMuaW5zdGFuY2UuZGVmYXVsdFRlbXBsYXRlO1xyXG4gICAgdGhpcy50ZW1wbGF0ZXNbRmllbGRUeXBlLlN0cmluZ10gPSB0aGlzLmluc3RhbmNlLmRlZmF1bHRUZW1wbGF0ZTtcclxuICAgIHRoaXMudGVtcGxhdGVzW0ZpZWxkVHlwZS5Vbmtub3duXSA9IHRoaXMuaW5zdGFuY2UuZGVmYXVsdFRlbXBsYXRlO1xyXG4gICAgdGhpcy50ZW1wbGF0ZXNbRmllbGRUeXBlLkVudW1dID0gdGhpcy5pbnN0YW5jZS5kZWZhdWx0VGVtcGxhdGU7XHJcbiAgfVxyXG4gIGdldFRlbXBsYXRlKG1ldGFEYXRhOiBNZXRhRGF0YSkgOiBUZW1wbGF0ZVJlZjxhbnk+IHtcclxuXHJcbiAgICBsZXQgdG1wID0gbWV0YURhdGEuZmllbGRUeXBlID09PSBGaWVsZFR5cGUuTGluayAmJiBtZXRhRGF0YS5hZGRpdGlvbmFsPy5saW5rPy51c2VSb3V0ZXJMaW5rXHJcbiAgICAgID8gdGhpcy50ZW1wbGF0ZXNbRmllbGRUeXBlLkxpbmsgKyAuNV0gXHJcbiAgICAgIDogXHJcbiAgICAgIG1ldGFEYXRhLmZpZWxkVHlwZSA9PT0gRmllbGRUeXBlLkFycmF5ICYmICgobWV0YURhdGEuYWRkaXRpb25hbCBhcyBBcnJheUFkZGl0aW9uYWwpPy5hcnJheVN0eWxlID09PSBBcnJheVN0eWxlLkNvbW1hRGVsaW1pdGVkIHx8IHRoaXMudGFibGVDb25maWc/LmFycmF5SW5mbz8uYXJyYXlTdHlsZSA9PT0gQXJyYXlTdHlsZS5Db21tYURlbGltaXRlZClcclxuICAgICAgPyB0aGlzLnRlbXBsYXRlc1tGaWVsZFR5cGUuQXJyYXkgKyAuNV0gXHJcbiAgICAgIDpcclxuICAgICAgdGhpcy50ZW1wbGF0ZXNbbWV0YURhdGEuZmllbGRUeXBlXTtcclxuICAgIGlmKG1ldGFEYXRhLnVzZUljb24pIHtcclxuICAgICAgaWYodG1wID09PSB0aGlzLmluc3RhbmNlLmRlZmF1bHRUZW1wbGF0ZSkge1xyXG4gICAgICAgIHRtcCA9IHRoaXMuaW5zdGFuY2UuZGVmYXVsdFdpdGhJY29uO1xyXG4gICAgICB9XHJcbiAgICB9XHJcbiAgICByZXR1cm4gdG1wO1xyXG4gIH1cclxuXHJcbiAgY29uc3RydWN0b3IocmVzb2x2ZXI6IENvbXBvbmVudEZhY3RvcnlSZXNvbHZlciwgaTogSW5qZWN0b3IsICApIHtcclxuICAgICAgICBjb25zdCBmYWN0b3J5ID0gcmVzb2x2ZXIucmVzb2x2ZUNvbXBvbmVudEZhY3RvcnkoSW5pdGlhbGl6YXRpb25Db21wb25lbnQpO1xyXG4gICAgICAgIGNvbnN0IGMgPSBmYWN0b3J5LmNyZWF0ZShpKTtcclxuICAgICAgICB0aGlzLmluc3RhbmNlID0gYy5pbnN0YW5jZTtcclxuICAgICAgICB0aGlzLmluaXRUZW1wbGF0ZXMoKTtcclxuICB9XHJcblxyXG4gIHRhYmxlQ29uZmlnID0gaW5qZWN0KFRhYmxlQnVpbGRlckNvbmZpZ1Rva2VuKTtcclxufVxyXG4iXX0=
56
+ }], ctorParameters: () => [{ type: i0.EnvironmentInjector }] });
57
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtdGVtcGxhdGUtc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItdXRpbGl0aWVzL3NyYy90YWJsZS1idWlsZGVyL3NlcnZpY2VzL3RhYmxlLXRlbXBsYXRlLXNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFpQyxlQUFlLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3ZGLE9BQU8sRUFBRSxVQUFVLEVBQWUsTUFBTSxlQUFlLENBQUM7QUFDeEQsT0FBTyxFQUFtQixVQUFVLEVBQUUsU0FBUyxFQUFZLE1BQU0sMEJBQTBCLENBQUM7QUFDNUYsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0saUVBQWlFLENBQUM7QUFDMUcsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sK0JBQStCLENBQUM7O0FBR3hFLE1BQU0sT0FBTyxvQkFBb0I7SUFJL0IsYUFBYTtRQUNYLElBQUksQ0FBQyxTQUFTLEdBQUcsRUFBRyxDQUFDO1FBQ3JCLElBQUksQ0FBQyxTQUFTLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsb0JBQW9CLENBQUM7UUFDckUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxTQUFTLENBQUMsS0FBSyxHQUFHLEVBQUUsQ0FBQyxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsa0JBQWtCLENBQUM7UUFDeEUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQyxlQUFlLENBQUM7UUFDbEUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxTQUFTLENBQUMsUUFBUSxDQUFDLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQyxlQUFlLENBQUM7UUFDbkUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLEdBQUcsSUFBSSxDQUFD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UUFDM0IsSUFBSSxDQUFDLGFBQWEsRUFBRSxDQUFDO0lBQ3ZCLENBQUM7OEdBOUNVLG9CQUFvQjtrSEFBcEIsb0JBQW9CLGNBRFIsTUFBTTs7MkZBQ2xCLG9CQUFvQjtrQkFEaEMsVUFBVTttQkFBQyxFQUFDLFVBQVUsRUFBRSxNQUFNLEVBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBFbnZpcm9ubWVudEluamVjdG9yLCBJbmplY3RvciwgY3JlYXRlQ29tcG9uZW50LCBpbmplY3QgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQgeyBJbmplY3RhYmxlLCBUZW1wbGF0ZVJlZiB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7IEFycmF5QWRkaXRpb25hbCwgQXJyYXlTdHlsZSwgRmllbGRUeXBlLCBNZXRhRGF0YSB9IGZyb20gXCIuLi9pbnRlcmZhY2VzL3JlcG9ydC1kZWZcIjtcclxuaW1wb3J0IHsgSW5pdGlhbGl6YXRpb25Db21wb25lbnQgfSBmcm9tIFwiLi4vY29tcG9uZW50cy9pbml0aWFsaXphdGlvbi1jb21wb25lbnQvaW5pdGlhbGl6YXRpb24tY29tcG9uZW50XCI7XHJcbmltcG9ydCB7IFRhYmxlQnVpbGRlckNvbmZpZ1Rva2VuIH0gZnJvbSBcIi4uL2NsYXNzZXMvVGFibGVCdWlsZGVyQ29uZmlnXCI7XHJcblxyXG5ASW5qZWN0YWJsZSh7cHJvdmlkZWRJbjogJ3Jvb3QnfSlcclxuZXhwb3J0IGNsYXNzIFRhYmxlVGVtcGxhdGVTZXJ2aWNlIHtcclxuICBpbnN0YW5jZSE6IEluaXRpYWxpemF0aW9uQ29tcG9uZW50O1xyXG4gIHRlbXBsYXRlcztcclxuXHJcbiAgaW5pdFRlbXBsYXRlcygpIHtcclxuICAgIHRoaXMudGVtcGxhdGVzID0geyB9O1xyXG4gICAgdGhpcy50ZW1wbGF0ZXNbRmllbGRUeXBlLkFycmF5XSA9IHRoaXMuaW5zdGFuY2UuYXJyYXlOZXdMaW5lVGVtcGxhdGU7XHJcbiAgICB0aGlzLnRlbXBsYXRlc1tGaWVsZFR5cGUuQXJyYXkgKyAuNV0gPSB0aGlzLmluc3RhbmNlLmFycmF5Q29tbWFUZW1wbGF0ZTtcclxuICAgIHRoaXMudGVtcGxhdGVzW0ZpZWxkVHlwZS5Cb29sZWFuXSA9IHRoaXMuaW5zdGFuY2UuZGVmYXVsdFdpdGhJY29uO1xyXG4gICAgdGhpcy50ZW1wbGF0ZXNbRmllbGRUeXBlLkN1cnJlbmN5XSA9IHRoaXMuaW5zdGFuY2UuZGVmYXVsdFRlbXBsYXRlO1xyXG4gICAgdGhpcy50ZW1wbGF0ZXNbRmllbGRUeXBlLkRhdGVdID0gdGhpcy5pbnN0YW5jZS5kZWZhdWx0VGVtcGxhdGU7XHJcbiAgICB0aGlzLnRlbXBsYXRlc1tGaWVsZFR5cGUuRGF0ZVRpbWVdID0gdGhpcy5pbnN0YW5jZS5kZWZhdWx0VGVtcGxhdGU7XHJcbiAgICB0aGlzLnRlbXBsYXRlc1tGaWVsZFR5cGUuRXhwcmVzc2lvbl0gPSB0aGlzLmluc3RhbmNlLmRlZmF1bHRUZW1wbGF0ZTtcclxuICAgIHRoaXMudGVtcGxhdGVzW0ZpZWxkVHlwZS5Ob3RNYXBwZWRdID0gdGhpcy5pbnN0YW5jZS5kZWZhdWx0VGVtcGxhdGU7XHJcbiAgICB0aGlzLnRlbXBsYXRlc1tGaWVsZFR5cGUuSW1hZ2VVcmxdID0gdGhpcy5pbnN0YW5jZS5pbWFnZVVybFRlbXBsYXRlO1xyXG4gICAgdGhpcy50ZW1wbGF0ZXNbRmllbGRUeXBlLkxpbmtdID0gdGhpcy5pbnN0YW5jZS5saW5rVGVtcGxhdGU7XHJcbiAgICB0aGlzLnRlbXBsYXRlc1tGaWVsZFR5cGUuTGluayArIC41XSA9IHRoaXMuaW5zdGFuY2Uucm91dGVyTGlua1RlbXBsYXRlO1xyXG4gICAgdGhpcy50ZW1wbGF0ZXNbRmllbGRUeXBlLk51bWJlcl0gPSB0aGlzLmluc3RhbmNlLmRlZmF1bHRUZW1wbGF0ZTtcclxuICAgIHRoaXMudGVtcGxhdGVzW0ZpZWxkVHlwZS5QaG9uZU51bWJlcl0gPSB0aGlzLmluc3RhbmNlLmRlZmF1bHRUZW1wbGF0ZTtcclxuICAgIHRoaXMudGVtcGxhdGVzW0ZpZWxkVHlwZS5TdHJpbmddID0gdGhpcy5pbnN0YW5jZS5kZWZhdWx0VGVtcGxhdGU7XHJcbiAgICB0aGlzLnRlbXBsYXRlc1tGaWVsZFR5cGUuVW5rbm93bl0gPSB0aGlzLmluc3RhbmNlLmRlZmF1bHRUZW1wbGF0ZTtcclxuICAgIHRoaXMudGVtcGxhdGVzW0ZpZWxkVHlwZS5FbnVtXSA9IHRoaXMuaW5zdGFuY2UuZGVmYXVsdFRlbXBsYXRlO1xyXG4gIH1cclxuICBnZXRUZW1wbGF0ZShtZXRhRGF0YTogTWV0YURhdGEpIDogVGVtcGxhdGVSZWY8YW55PiB7XHJcblxyXG4gICAgbGV0IHRtcCA9IG1ldGFEYXRhLmZpZWxkVHlwZSA9PT0gRmllbGRUeXBlLkxpbmsgJiYgbWV0YURhdGEuYWRkaXRpb25hbD8ubGluaz8udXNlUm91dGVyTGlua1xyXG4gICAgICA/IHRoaXMudGVtcGxhdGVzW0ZpZWxkVHlwZS5MaW5rICsgLjVdIFxyXG4gICAgICA6IFxyXG4gICAgICBtZXRhRGF0YS5maWVsZFR5cGUgPT09IEZpZWxkVHlwZS5BcnJheSAmJiAoKG1ldGFEYXRhLmFkZGl0aW9uYWwgYXMgQXJyYXlBZGRpdGlvbmFsKT8uYXJyYXlTdHlsZSA9PT0gQXJyYXlTdHlsZS5Db21tYURlbGltaXRlZCB8fCB0aGlzLnRhYmxlQ29uZmlnPy5hcnJheUluZm8/LmFycmF5U3R5bGUgPT09IEFycmF5U3R5bGUuQ29tbWFEZWxpbWl0ZWQpXHJcbiAgICAgID8gdGhpcy50ZW1wbGF0ZXNbRmllbGRUeXBlLkFycmF5ICsgLjVdIFxyXG4gICAgICA6XHJcbiAgICAgIHRoaXMudGVtcGxhdGVzW21ldGFEYXRhLmZpZWxkVHlwZV07XHJcbiAgICBpZihtZXRhRGF0YS51c2VJY29uKSB7XHJcbiAgICAgIGlmKHRtcCA9PT0gdGhpcy5pbnN0YW5jZS5kZWZhdWx0VGVtcGxhdGUpIHtcclxuICAgICAgICB0bXAgPSB0aGlzLmluc3RhbmNlLmRlZmF1bHRXaXRoSWNvbjtcclxuICAgICAgfVxyXG4gICAgfVxyXG4gICAgcmV0dXJuIHRtcDtcclxuICB9XHJcblxyXG4gIGNvbnN0cnVjdG9yKGVpOiBFbnZpcm9ubWVudEluamVjdG9yICApIHtcclxuICAgIGNvbnN0IGMgPSBjcmVhdGVDb21wb25lbnQoSW5pdGlhbGl6YXRpb25Db21wb25lbnQsIHtcclxuICAgICAgZW52aXJvbm1lbnRJbmplY3RvcjogZWksXHJcbiAgICB9KTtcclxuICAgIHRoaXMuaW5zdGFuY2UgPSBjLmluc3RhbmNlO1xyXG4gICAgdGhpcy5pbml0VGVtcGxhdGVzKCk7XHJcbiAgfVxyXG5cclxuICB0YWJsZUNvbmZpZyA9IGluamVjdChUYWJsZUJ1aWxkZXJDb25maWdUb2tlbik7XHJcbn1cclxuIl19
@@ -1,5 +1,5 @@
1
1
  import * as i0 from '@angular/core';
2
- import { Directive, Input, NgModule, Injectable, assertInInjectionContext, DestroyRef, inject, Pipe, Optional, Injector, booleanAttribute, InjectionToken, makeEnvironmentProviders, Inject, HostListener, Component, ChangeDetectionStrategy, EventEmitter, Output, ContentChildren, ViewChild, input, computed, forwardRef, ElementRef, ContentChild, APP_INITIALIZER } from '@angular/core';
2
+ import { Directive, Input, NgModule, Injectable, assertInInjectionContext, DestroyRef, inject, Pipe, Optional, Injector, booleanAttribute, InjectionToken, makeEnvironmentProviders, Inject, HostListener, Component, ChangeDetectionStrategy, EventEmitter, Output, ContentChildren, ViewChild, input, computed, createComponent, forwardRef, ElementRef, ContentChild, APP_INITIALIZER } from '@angular/core';
3
3
  import { shareReplay, map, switchAll, filter, tap, catchError, startWith, switchMap, mergeMap, concatMap, takeUntil, distinctUntilChanged, last, first as first$1, distinctUntilKeyChanged, delay as delay$1, mergeAll as mergeAll$1, scan as scan$1, timestamp as timestamp$1, withLatestFrom } from 'rxjs/operators';
4
4
  import * as i3$1 from 'rxjs';
5
5
  import { isObservable, Subject, of, ReplaySubject, filter as filter$1, first, map as map$1, Observable, combineLatest, Subscription, startWith as startWith$1, pairwise, concatMap as concatMap$1, merge as merge$1, delay, fromEvent, tap as tap$1, BehaviorSubject, takeUntil as takeUntil$1, switchMap as switchMap$1, scan, asyncScheduler, distinctUntilChanged as distinctUntilChanged$1, timestamp, mergeAll, from } from 'rxjs';
@@ -3497,20 +3497,21 @@ class TableTemplateService {
3497
3497
  }
3498
3498
  return tmp;
3499
3499
  }
3500
- constructor(resolver, i) {
3500
+ constructor(ei) {
3501
3501
  this.tableConfig = inject(TableBuilderConfigToken);
3502
- const factory = resolver.resolveComponentFactory(InitializationComponent);
3503
- const c = factory.create(i);
3502
+ const c = createComponent(InitializationComponent, {
3503
+ environmentInjector: ei,
3504
+ });
3504
3505
  this.instance = c.instance;
3505
3506
  this.initTemplates();
3506
3507
  }
3507
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: TableTemplateService, deps: [{ token: i0.ComponentFactoryResolver }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Injectable }); }
3508
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: TableTemplateService, deps: [{ token: i0.EnvironmentInjector }], target: i0.ɵɵFactoryTarget.Injectable }); }
3508
3509
  static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: TableTemplateService, providedIn: 'root' }); }
3509
3510
  }
3510
3511
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: TableTemplateService, decorators: [{
3511
3512
  type: Injectable,
3512
3513
  args: [{ providedIn: 'root' }]
3513
- }], ctorParameters: () => [{ type: i0.ComponentFactoryResolver }, { type: i0.Injector }] });
3514
+ }], ctorParameters: () => [{ type: i0.EnvironmentInjector }] });
3514
3515
 
3515
3516
  class ColumnBuilderComponent {
3516
3517
  get metaData() {
@@ -3654,10 +3655,12 @@ class GenericTableComponent {
3654
3655
  }
3655
3656
  set trackBy(trackBy) {
3656
3657
  if (trackBy) {
3658
+ this._trackBy = trackBy;
3657
3659
  this.trackByFunction = (index, item) => item[trackBy];
3658
3660
  }
3659
3661
  this.setUpSelections(trackBy);
3660
3662
  }
3663
+ get trackBy() { return this._trackBy; }
3661
3664
  constructor(state, viewContainer, transformCreator, injector) {
3662
3665
  this.state = state;
3663
3666
  this.viewContainer = viewContainer;
@@ -3736,7 +3739,8 @@ class GenericTableComponent {
3736
3739
  });
3737
3740
  this.state.on(this.state.props().dataSource.viewableData$, (data) => {
3738
3741
  if (this.selection.selected.length) {
3739
- const removed = this.selection.selected.filter(s => !data.includes(s));
3742
+ const trackByFunction = this.trackBy ? (s) => data.every(d => d[this.trackBy] !== s[this.trackBy]) : s => !data.includes(s);
3743
+ const removed = this.selection.selected.filter(trackByFunction);
3740
3744
  this.selection.deselect(...removed);
3741
3745
  }
3742
3746
  });