@one-paragon/angular-utilities 1.2.9 → 1.2.10-beta-1

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.
Files changed (46) hide show
  1. package/action-state/ngrx.d.ts +1 -1
  2. package/esm2022/http-request-state/HttpRequestStateStore.mjs +19 -3
  3. package/esm2022/http-request-state/types.mjs +1 -1
  4. package/esm2022/public-api.mjs +2 -1
  5. package/esm2022/table-builder/classes/TableBuilderDataSource.mjs +18 -12
  6. package/esm2022/table-builder/classes/TableState.mjs +5 -3
  7. package/esm2022/table-builder/classes/data-store.mjs +15 -0
  8. package/esm2022/table-builder/classes/table-builder-general-settings.mjs +14 -1
  9. package/esm2022/table-builder/classes/table-builder.mjs +3 -3
  10. package/esm2022/table-builder/classes/table-store.mjs +71 -46
  11. package/esm2022/table-builder/components/column-builder/column-builder.component.mjs +2 -2
  12. package/esm2022/table-builder/components/generic-table/generic-table.component.mjs +100 -55
  13. package/esm2022/table-builder/components/generic-table/paginator.component.mjs +6 -4
  14. package/esm2022/table-builder/components/sort-menu/sort-menu.component-store.mjs +4 -2
  15. package/esm2022/table-builder/components/table-container/table-container.mjs +90 -65
  16. package/esm2022/table-builder/components/table-container/tableProps.mjs +2 -1
  17. package/esm2022/table-builder/components/table-container/virtual-scroll-container.mjs +36 -10
  18. package/esm2022/table-builder/components/table-container-filter/filter-list/filter-list.component.mjs +5 -6
  19. package/esm2022/table-builder/components/table-container-filter/gen-filter-displayer/gen-filter-displayer.component.mjs +9 -11
  20. package/esm2022/table-builder/directives/custom-cell-directive.mjs +12 -13
  21. package/esm2022/table-builder/directives/table-wrapper.directive.mjs +4 -4
  22. package/esm2022/table-builder/interfaces/ColumnInfo.mjs +1 -1
  23. package/esm2022/table-builder/services/export-to-csv.service.mjs +3 -3
  24. package/fesm2022/one-paragon-angular-utilities.mjs +537 -374
  25. package/fesm2022/one-paragon-angular-utilities.mjs.map +1 -1
  26. package/http-request-state/HttpRequestStateStore.d.ts +5 -0
  27. package/http-request-state/types.d.ts +1 -1
  28. package/package.json +1 -1
  29. package/public-api.d.ts +1 -2
  30. package/table-builder/classes/TableBuilderDataSource.d.ts +2 -3
  31. package/table-builder/classes/TableState.d.ts +14 -4
  32. package/table-builder/classes/data-store.d.ts +8 -0
  33. package/table-builder/classes/table-builder-general-settings.d.ts +6 -0
  34. package/table-builder/classes/table-store.d.ts +16 -28
  35. package/table-builder/components/generic-table/generic-table.component.d.ts +20 -10
  36. package/table-builder/components/generic-table/paginator.component.d.ts +1 -0
  37. package/table-builder/components/sort-menu/sort-menu.component-store.d.ts +1 -0
  38. package/table-builder/components/table-container/table-container-imports.d.ts +1 -1
  39. package/table-builder/components/table-container/table-container.d.ts +15 -8
  40. package/table-builder/components/table-container/tableProps.d.ts +1 -0
  41. package/table-builder/components/table-container/virtual-scroll-container.d.ts +9 -3
  42. package/table-builder/components/table-container-filter/filter-list/filter-list.component.d.ts +2 -3
  43. package/table-builder/components/table-container-filter/gen-filter-displayer/gen-filter-displayer.component.d.ts +1 -3
  44. package/table-builder/directives/custom-cell-directive.d.ts +6 -4
  45. package/table-builder/directives/table-wrapper.directive.d.ts +1 -1
  46. package/table-builder/interfaces/ColumnInfo.d.ts +1 -1
@@ -1,22 +1,28 @@
1
- import { ChangeDetectionStrategy, Component, effect, forwardRef, untracked, viewChild, inject } from '@angular/core';
1
+ import { ChangeDetectionStrategy, Component, effect, forwardRef, untracked, viewChild, inject, contentChild } from '@angular/core';
2
2
  import { CdkVirtualScrollViewport, ScrollingModule, VIRTUAL_SCROLL_STRATEGY, } from '@angular/cdk/scrolling';
3
- import { distinctUntilChanged, map } from 'rxjs';
3
+ import { combineLatest, distinctUntilChanged, map } from 'rxjs';
4
4
  import { defaultShareReplay, subscriber } from '../../../rxjs';
5
5
  import { TableStore } from '../../classes/table-store';
6
6
  import { TableVirtualScrollStrategy } from '../scroll-strategy';
7
7
  import { VirtualScrollOptions } from '../../classes/table-builder-general-settings';
8
+ import { DataStore } from '../../classes/data-store';
9
+ import { GenericTableComponent } from '../generic-table/generic-table.component';
8
10
  import * as i0 from "@angular/core";
9
11
  import * as i1 from "@angular/cdk/scrolling";
10
12
  export class VirtualScrollContainer {
11
13
  state = inject(TableStore);
14
+ dataStore = inject(DataStore);
15
+ genericTable = contentChild(GenericTableComponent);
16
+ sub;
17
+ footerStyle = 'regular-footer';
12
18
  viewport = viewChild(CdkVirtualScrollViewport);
13
19
  defaultOptions = new VirtualScrollOptions();
14
20
  scrollStrategy = new TableVirtualScrollStrategy(this.computedRowHeight(), this.computedHeaderHeight());
15
- dataLength$ = this.state.state$.pipe(map(s => ({
21
+ dataLength$ = combineLatest([this.state.state$, this.dataStore.state$]).pipe(map(([s, d]) => ({
16
22
  paginated: s.notPersistedTableSettings.usePaginator && !s.showAll,
17
23
  pageSize: s.userDefined?.pageSize || s.pageSize,
18
24
  pageNumber: s.currentPage,
19
- dataLen: s.dataLen
25
+ dataLen: d.dataLen
20
26
  })), distinctUntilChanged((a, b) => a.dataLen === b.dataLen &&
21
27
  a.pageSize === b.pageSize &&
22
28
  a.pageNumber === b.pageNumber &&
@@ -37,7 +43,7 @@ export class VirtualScrollContainer {
37
43
  if (!!viewport) {
38
44
  addEventListener('resize', this.resizeHandler);
39
45
  this.subscriber.on(viewport.renderedRangeStream, (range) => {
40
- this.state.updateState({
46
+ this.dataStore.patchState({
41
47
  virtualEnds: {
42
48
  start: range.start,
43
49
  end: range.end + 25,
@@ -46,15 +52,22 @@ export class VirtualScrollContainer {
46
52
  });
47
53
  var offset$ = viewport.scrolledIndexChange.pipe(map(() => viewport.getOffsetToRenderedContentStart() ?? 0), distinctUntilChanged(), defaultShareReplay());
48
54
  this.subscriber.on(offset$, (offset) => {
49
- this.state.updateState({ virtualScrollOffset: offset });
55
+ this.dataStore.patchState({ virtualScrollOffset: offset });
50
56
  });
51
57
  this.setSize(this.viewport().elementRef);
52
58
  }
53
59
  ;
54
60
  });
55
61
  });
62
+ ngAfterViewInit() {
63
+ const footerRowStyle$ = this.genericTable()?.$footerRowStyle();
64
+ if (footerRowStyle$) {
65
+ this.footerStyle = footerRowStyle$;
66
+ }
67
+ }
56
68
  ngOnDestroy() {
57
69
  removeEventListener('resize', this.resizeHandler);
70
+ this.sub?.unsubscribe();
58
71
  }
59
72
  setSize(el) {
60
73
  const vsViewport = el.nativeElement;
@@ -62,7 +75,20 @@ export class VirtualScrollContainer {
62
75
  const rowHeight = this.computedRowHeight();
63
76
  let amountOfVisibleItems = virtualScrollOptions?.amountOfVisibleItems || this.defaultOptions.amountOfVisibleItems;
64
77
  virtualScrollOptions?.amountOfVisibleItems || this.defaultOptions.amountOfVisibleItems;
65
- let height = (rowHeight * amountOfVisibleItems);
78
+ let height = 0;
79
+ var sub = this.dataLength$.subscribe(dataLength => {
80
+ if (dataLength < amountOfVisibleItems) {
81
+ height = +(this.computedRowHeight() * dataLength);
82
+ }
83
+ else {
84
+ height = (rowHeight * amountOfVisibleItems);
85
+ }
86
+ });
87
+ if (this.footerStyle !== 'no-footer') {
88
+ height += rowHeight;
89
+ console.log(height);
90
+ console.log('regular-footer');
91
+ }
66
92
  if (!this.state.tableSettings().hideHeader) {
67
93
  const headerHeight = this.computedHeaderHeight();
68
94
  height += headerHeight;
@@ -72,7 +98,7 @@ export class VirtualScrollContainer {
72
98
  vsViewport.setAttribute('style', `height: ${height}px !important;`);
73
99
  this.viewport()?.checkViewportSize();
74
100
  const virtualScrollOffset = this.viewport()?.getOffsetToRenderedContentStart() ?? 0;
75
- this.state.updateState({ virtualScrollOffset });
101
+ this.dataStore.patchState({ virtualScrollOffset });
76
102
  }
77
103
  resizeHandler = () => {
78
104
  if (this.viewport()) {
@@ -90,7 +116,7 @@ export class VirtualScrollContainer {
90
116
  return headerHeight;
91
117
  }
92
118
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: VirtualScrollContainer, deps: [], target: i0.ɵɵFactoryTarget.Component });
93
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "18.2.2", type: VirtualScrollContainer, isStandalone: true, selector: "tb-virtual-scroll-container", viewQueries: [{ propertyName: "viewport", first: true, predicate: CdkVirtualScrollViewport, descendants: true, isSignal: true }], ngImport: i0, template: `
119
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "18.2.2", type: VirtualScrollContainer, isStandalone: true, selector: "tb-virtual-scroll-container", queries: [{ propertyName: "genericTable", first: true, predicate: GenericTableComponent, descendants: true, isSignal: true }], viewQueries: [{ propertyName: "viewport", first: true, predicate: CdkVirtualScrollViewport, descendants: true, isSignal: true }], ngImport: i0, template: `
94
120
  <cdk-virtual-scroll-viewport>
95
121
  <ng-content/>
96
122
  </cdk-virtual-scroll-viewport>
@@ -123,4 +149,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImpor
123
149
  ],
124
150
  }]
125
151
  }] });
126
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"virtual-scroll-container.js","sourceRoot":"","sources":["../../../../../../projects/angular-utilities/src/table-builder/components/table-container/virtual-scroll-container.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, ElementRef, OnDestroy, effect, forwardRef, untracked, viewChild, inject } from '@angular/core';\nimport {\n  CdkVirtualScrollViewport,\n  ScrollingModule,\n  VIRTUAL_SCROLL_STRATEGY,\n} from '@angular/cdk/scrolling';\nimport { distinctUntilChanged, map } from 'rxjs';\nimport { defaultShareReplay, subscriber } from '../../../rxjs';\nimport { TableStore } from '../../classes/table-store';\nimport { TableVirtualScrollStrategy } from '../scroll-strategy';\nimport { VirtualScrollOptions } from '../../classes/table-builder-general-settings';\n\n@Component({\n  selector: 'tb-virtual-scroll-container',\n  template: `\n    <cdk-virtual-scroll-viewport>\n      <ng-content/>\n    </cdk-virtual-scroll-viewport>\n    `,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [ScrollingModule],\n  viewProviders: [\n    {\n      provide: VIRTUAL_SCROLL_STRATEGY,\n      useFactory: (c: VirtualScrollContainer) => c.scrollStrategy,\n      deps: [forwardRef(() => VirtualScrollContainer)],\n    },\n  ],\n})\nexport class VirtualScrollContainer implements  OnDestroy {\n  private state = inject(TableStore);\n\n  viewport = viewChild(CdkVirtualScrollViewport);\n\n  defaultOptions = new VirtualScrollOptions();\n  scrollStrategy = new TableVirtualScrollStrategy(\n    this.computedRowHeight(),\n    this.computedHeaderHeight()\n    );\n\n\n  dataLength$ = this.state.state$.pipe(\n    map(s => ({\n      paginated: s.notPersistedTableSettings.usePaginator && !s.showAll,\n      pageSize: s.userDefined?.pageSize || s.pageSize,\n      pageNumber: s.currentPage,\n      dataLen: s.dataLen\n    })),\n    distinctUntilChanged((a, b) =>\n      a.dataLen === b.dataLen &&\n      a.pageSize === b.pageSize &&\n      a.pageNumber === b.pageNumber &&\n      a.paginated === b.paginated),\n    map(({dataLen, pageNumber, pageSize, paginated}) => {\n      if(paginated) return Math.min(dataLen - (pageNumber * pageSize), pageSize);\n      return dataLen;\n    }),\n    distinctUntilChanged()\n  );\n\n\n  subscriber = subscriber(this.dataLength$, (dataLength) => {\n    this.scrollStrategy.setDataLength(dataLength);\n\n    if(this.viewport()){\n      this.setSize(this.viewport()!.elementRef);\n    }\n  });\n\n\n  _ = effect(() => {\n    const viewport = this.viewport();\n    untracked(() => {\n      if(!!viewport){\n        addEventListener('resize', this.resizeHandler);\n        this.subscriber.on(viewport.renderedRangeStream, (range) => {\n          this.state.updateState({\n            virtualEnds: {\n              start: range.start,\n              end: range.end + 25,\n            }\n          });\n        });\n        var offset$ = viewport.scrolledIndexChange.pipe(\n          map(() => viewport.getOffsetToRenderedContentStart() ?? 0),\n          distinctUntilChanged(),\n          defaultShareReplay()\n        );\n    \n        this.subscriber.on(offset$, (offset) => {\n          this.state.updateState({ virtualScrollOffset: offset });\n        });\n        this.setSize(this.viewport()!.elementRef);\n      };\n    })\n\n  })\n\n\n  ngOnDestroy(): void {\n    removeEventListener('resize', this.resizeHandler);\n  }\n\n  setSize(el: ElementRef<HTMLElement>) {\n    const vsViewport = el.nativeElement;\n    const virtualScrollOptions = this.state.tableSettings().useVirtualScroll! as VirtualScrollOptions;\n    const rowHeight = this.computedRowHeight();\n    let amountOfVisibleItems = virtualScrollOptions?.amountOfVisibleItems || this.defaultOptions.amountOfVisibleItems;\n      virtualScrollOptions?.amountOfVisibleItems || this.defaultOptions.amountOfVisibleItems;\n    let height = (rowHeight * amountOfVisibleItems);\n    if(!this.state.tableSettings().hideHeader){\n      const headerHeight = this.computedHeaderHeight();\n      height += headerHeight;\n    }\n    if(virtualScrollOptions?.maxViewPortHeight && virtualScrollOptions.maxViewPortHeight < height) height = virtualScrollOptions.maxViewPortHeight;\n    vsViewport.setAttribute(\n      'style',\n      `height: ${height}px !important;`,\n    );\n    this.viewport()?.checkViewportSize();\n    const virtualScrollOffset = this.viewport()?.getOffsetToRenderedContentStart() ?? 0\n    this.state.updateState({ virtualScrollOffset });\n  }\n\n  resizeHandler = () => {\n    if (this.viewport()) {\n      this.setSize(this.viewport()!.elementRef);\n    }\n  };\n\n  computedRowHeight(){\n    const virtualScrollOptions = this.state.tableSettings().useVirtualScroll! as VirtualScrollOptions;\n    const rowHeight = virtualScrollOptions?.rowHeight|| (typeof this.state.tableSettings().rowHeight === 'number' && this.state.tableSettings().rowHeight as number) || this.defaultOptions.rowHeight;\n    return rowHeight;\n  }\n\n  computedHeaderHeight(){\n    const virtualScrollOptions = this.state.tableSettings().useVirtualScroll! as VirtualScrollOptions;\n    const headerHeight = virtualScrollOptions?.headerHeight|| (typeof  this.state.tableSettings().headerHeight === 'number' && this.state.tableSettings().headerHeight as number) || this.defaultOptions.headerHeight;\n    return headerHeight;\n  }\n}\n"]}
152
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"virtual-scroll-container.js","sourceRoot":"","sources":["../../../../../../projects/angular-utilities/src/table-builder/components/table-container/virtual-scroll-container.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAyB,MAAM,EAAE,UAAU,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,EAAiB,YAAY,EAAE,MAAM,eAAe,CAAC;AACzK,OAAO,EACL,wBAAwB,EACxB,eAAe,EACf,uBAAuB,GACxB,MAAM,wBAAwB,CAAC;AAChC,OAAO,EAAE,aAAa,EAAE,oBAAoB,EAAE,GAAG,EAAgB,MAAM,MAAM,CAAC;AAC9E,OAAO,EAAE,kBAAkB,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAC/D,OAAO,EAAE,UAAU,EAAE,MAAM,2BAA2B,CAAC;AACvD,OAAO,EAAE,0BAA0B,EAAE,MAAM,oBAAoB,CAAC;AAChE,OAAO,EAAE,oBAAoB,EAAE,MAAM,8CAA8C,CAAC;AACpF,OAAO,EAAE,SAAS,EAAE,MAAM,0BAA0B,CAAC;AAErD,OAAO,EAAE,qBAAqB,EAAE,MAAM,0CAA0C,CAAC;;;AAoBjF,MAAM,OAAO,sBAAsB;IAGzB,KAAK,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;IAC3B,SAAS,GAAG,MAAM,CAAC,SAAS,CAAC,CAAC;IAC9B,YAAY,GAAG,YAAY,CAAC,qBAAqB,CAAC,CAAC;IAC3D,GAAG,CAA2B;IAC9B,WAAW,GAAG,gBAAgB,CAAC;IAE/B,QAAQ,GAAG,SAAS,CAAC,wBAAwB,CAAC,CAAC;IAE/C,cAAc,GAAG,IAAI,oBAAoB,EAAE,CAAC;IAC5C,cAAc,GAAG,IAAI,0BAA0B,CAC7C,IAAI,CAAC,iBAAiB,EAAE,EACxB,IAAI,CAAC,oBAAoB,EAAE,CAC5B,CAAC;IAGF,WAAW,GAAG,aAAa,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAC1E,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;QACf,SAAS,EAAE,CAAC,CAAC,yBAAyB,CAAC,YAAY,IAAI,CAAC,CAAC,CAAC,OAAO;QACjE,QAAQ,EAAE,CAAC,CAAC,WAAW,EAAE,QAAQ,IAAI,CAAC,CAAC,QAAQ;QAC/C,UAAU,EAAE,CAAC,CAAC,WAAW;QACzB,OAAO,EAAE,CAAC,CAAC,OAAO;KACnB,CAAC,CAAC,EACH,oBAAoB,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAC5B,CAAC,CAAC,OAAO,KAAK,CAAC,CAAC,OAAO;QACvB,CAAC,CAAC,QAAQ,KAAK,CAAC,CAAC,QAAQ;QACzB,CAAC,CAAC,UAAU,KAAK,CAAC,CAAC,UAAU;QAC7B,CAAC,CAAC,SAAS,KAAK,CAAC,CAAC,SAAS,CAAC,EAC9B,GAAG,CAAC,CAAC,EAAE,OAAO,EAAE,UAAU,EAAE,QAAQ,EAAE,SAAS,EAAE,EAAE,EAAE;QACnD,IAAI,SAAS;YAAE,OAAO,IAAI,CAAC,GAAG,CAAC,OAAO,GAAG,CAAC,UAAU,GAAG,QAAQ,CAAC,EAAE,QAAQ,CAAC,CAAC;QAC5E,OAAO,OAAO,CAAC;IACjB,CAAC,CAAC,EACF,oBAAoB,EAAE,CACvB,CAAC;IAGF,UAAU,GAAG,UAAU,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,UAAU,EAAE,EAAE;QACvD,IAAI,CAAC,cAAc,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;QAE9C,IAAI,IAAI,CAAC,QAAQ,EAAE,EAAE,CAAC;YACpB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,EAAG,CAAC,UAAU,CAAC,CAAC;QAC5C,CAAC;IACH,CAAC,CAAC,CAAC;IAGH,CAAC,GAAG,MAAM,CAAC,GAAG,EAAE;QACd,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC;QACjC,SAAS,CAAC,GAAG,EAAE;YACb,IAAI,CAAC,CAAC,QAAQ,EAAE,CAAC;gBACf,gBAAgB,CAAC,QAAQ,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;gBAC/C,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC,QAAQ,CAAC,mBAAmB,EAAE,CAAC,KAAK,EAAE,EAAE;oBACzD,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC;wBACxB,WAAW,EAAE;4BACX,KAAK,EAAE,KAAK,CAAC,KAAK;4BAClB,GAAG,EAAE,KAAK,CAAC,GAAG,GAAG,EAAE;yBACpB;qBACF,CAAC,CAAC;gBACL,CAAC,CAAC,CAAC;gBACH,IAAI,OAAO,GAAG,QAAQ,CAAC,mBAAmB,CAAC,IAAI,CAC7C,GAAG,CAAC,GAAG,EAAE,CAAC,QAAQ,CAAC,+BAA+B,EAAE,IAAI,CAAC,CAAC,EAC1D,oBAAoB,EAAE,EACtB,kBAAkB,EAAE,CACrB,CAAC;gBAEF,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC,MAAM,EAAE,EAAE;oBACrC,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,EAAE,mBAAmB,EAAE,MAAM,EAAE,CAAC,CAAC;gBAC7D,CAAC,CAAC,CAAC;gBACH,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,EAAG,CAAC,UAAU,CAAC,CAAC;YAC5C,CAAC;YAAA,CAAC;QACJ,CAAC,CAAC,CAAA;IAEJ,CAAC,CAAC,CAAA;IAEF,eAAe;QACb,MAAM,eAAe,GAAG,IAAI,CAAC,YAAY,EAAE,EAAE,eAAe,EAAE,CAAC;QAC/D,IAAI,eAAe,EAAE,CAAC;YACpB,IAAI,CAAC,WAAW,GAAE,eAAe,CAAC;QACpC,CAAC;IACH,CAAC;IAED,WAAW;QACT,mBAAmB,CAAC,QAAQ,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;QAClD,IAAI,CAAC,GAAG,EAAE,WAAW,EAAE,CAAC;IAC1B,CAAC;IAED,OAAO,CAAC,EAA2B;QACjC,MAAM,UAAU,GAAG,EAAE,CAAC,aAAa,CAAC;QACpC,MAAM,oBAAoB,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC,gBAAyC,CAAC;QAClG,MAAM,SAAS,GAAG,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAC3C,IAAI,oBAAoB,GAAG,oBAAoB,EAAE,oBAAoB,IAAI,IAAI,CAAC,cAAc,CAAC,oBAAoB,CAAC;QAClH,oBAAoB,EAAE,oBAAoB,IAAI,IAAI,CAAC,cAAc,CAAC,oBAAoB,CAAC;QAEvF,IAAI,MAAM,GAAG,CAAC,CAAC;QACf,IAAI,GAAG,GAAG,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,UAAU,CAAC,EAAE;YAChD,IAAI,UAAU,GAAG,oBAAoB,EAAE,CAAC;gBACtC,MAAM,GAAE,CAAE,CAAC,IAAI,CAAC,iBAAiB,EAAE,GAAG,UAAU,CAAC,CAAC;YACpD,CAAC;iBAAM,CAAC;gBACN,MAAM,GAAG,CAAC,SAAS,GAAG,oBAAoB,CAAC,CAAC;YAC9C,CAAC;QACH,CAAC,CACA,CAAC;QACF,IAAI,IAAI,CAAC,WAAW,KAAK,WAAW,EAAE,CAAC;YACrC,MAAM,IAAI,SAAS,CAAC;YACpB,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,CAAA;YACnB,OAAO,CAAC,GAAG,CAAC,gBAAgB,CAAC,CAAC;QAChC,CAAC;QACD,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC,UAAU,EAAE,CAAC;YAC3C,MAAM,YAAY,GAAG,IAAI,CAAC,oBAAoB,EAAE,CAAC;YACjD,MAAM,IAAI,YAAY,CAAC;QACzB,CAAC;QACD,IAAI,oBAAoB,EAAE,iBAAiB,IAAI,oBAAoB,CAAC,iBAAiB,GAAG,MAAM;YAAE,MAAM,GAAG,oBAAoB,CAAC,iBAAiB,CAAC;QAChJ,UAAU,CAAC,YAAY,CACrB,OAAO,EACP,WAAW,MAAM,gBAAgB,CAClC,CAAC;QACF,IAAI,CAAC,QAAQ,EAAE,EAAE,iBAAiB,EAAE,CAAC;QACrC,MAAM,mBAAmB,GAAG,IAAI,CAAC,QAAQ,EAAE,EAAE,+BAA+B,EAAE,IAAI,CAAC,CAAA;QACnF,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,EAAE,mBAAmB,EAAE,CAAC,CAAC;IACrD,CAAC;IAED,aAAa,GAAG,GAAG,EAAE;QACnB,IAAI,IAAI,CAAC,QAAQ,EAAE,EAAE,CAAC;YACpB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,EAAG,CAAC,UAAU,CAAC,CAAC;QAC5C,CAAC;IACH,CAAC,CAAC;IAEF,iBAAiB;QACf,MAAM,oBAAoB,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC,gBAAyC,CAAC;QAClG,MAAM,SAAS,GAAG,oBAAoB,EAAE,SAAS,IAAI,CAAC,OAAO,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC,SAAS,KAAK,QAAQ,IAAI,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC,SAAmB,CAAC,IAAI,IAAI,CAAC,cAAc,CAAC,SAAS,CAAC;QACnM,OAAO,SAAS,CAAC;IACnB,CAAC;IAED,oBAAoB;QAClB,MAAM,oBAAoB,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC,gBAAyC,CAAC;QAClG,MAAM,YAAY,GAAG,oBAAoB,EAAE,YAAY,IAAI,CAAC,OAAO,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC,YAAY,KAAK,QAAQ,IAAI,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC,YAAsB,CAAC,IAAI,IAAI,CAAC,cAAc,CAAC,YAAY,CAAC;QAClN,OAAO,YAAY,CAAC;IACtB,CAAC;uGA1IU,sBAAsB;2FAAtB,sBAAsB,iIAKG,qBAAqB,0GAIpC,wBAAwB,gEAzBnC;;;;KAIP,2DAGO,eAAe,gMACV;YACb;gBACE,OAAO,EAAE,uBAAuB;gBAChC,UAAU,EAAE,CAAC,CAAyB,EAAE,EAAE,CAAC,CAAC,CAAC,cAAc;gBAC3D,IAAI,EAAE,CAAC,UAAU,CAAC,GAAG,EAAE,CAAC,sBAAsB,CAAC,CAAC;aACjD;SACF;;2FAEU,sBAAsB;kBAlBlC,SAAS;mBAAC;oBACT,QAAQ,EAAE,6BAA6B;oBACvC,QAAQ,EAAE;;;;KAIP;oBACH,eAAe,EAAE,uBAAuB,CAAC,MAAM;oBAC/C,UAAU,EAAE,IAAI;oBAChB,OAAO,EAAE,CAAC,eAAe,CAAC;oBAC1B,aAAa,EAAE;wBACb;4BACE,OAAO,EAAE,uBAAuB;4BAChC,UAAU,EAAE,CAAC,CAAyB,EAAE,EAAE,CAAC,CAAC,CAAC,cAAc;4BAC3D,IAAI,EAAE,CAAC,UAAU,CAAC,GAAG,EAAE,uBAAuB,CAAC,CAAC;yBACjD;qBACF;iBACF","sourcesContent":["import { ChangeDetectionStrategy, Component, ElementRef, OnDestroy, effect, forwardRef, untracked, viewChild, inject, AfterViewInit, contentChild } from '@angular/core';\nimport {\n  CdkVirtualScrollViewport,\n  ScrollingModule,\n  VIRTUAL_SCROLL_STRATEGY,\n} from '@angular/cdk/scrolling';\nimport { combineLatest, distinctUntilChanged, map, Subscription } from 'rxjs';\nimport { defaultShareReplay, subscriber } from '../../../rxjs';\nimport { TableStore } from '../../classes/table-store';\nimport { TableVirtualScrollStrategy } from '../scroll-strategy';\nimport { VirtualScrollOptions } from '../../classes/table-builder-general-settings';\nimport { DataStore } from '../../classes/data-store';\nimport { toSignal } from '@angular/core/rxjs-interop';\nimport { GenericTableComponent } from '../generic-table/generic-table.component';\n\n@Component({\n  selector: 'tb-virtual-scroll-container',\n  template: `\n    <cdk-virtual-scroll-viewport>\n      <ng-content/>\n    </cdk-virtual-scroll-viewport>\n    `,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [ScrollingModule],\n  viewProviders: [\n    {\n      provide: VIRTUAL_SCROLL_STRATEGY,\n      useFactory: (c: VirtualScrollContainer) => c.scrollStrategy,\n      deps: [forwardRef(() => VirtualScrollContainer)],\n    },\n  ],\n})\nexport class VirtualScrollContainer implements OnDestroy, AfterViewInit {\n\n\n  private state = inject(TableStore);\n  private dataStore = inject(DataStore);\n  private genericTable = contentChild(GenericTableComponent);\n  sub: Subscription | undefined;\n  footerStyle = 'regular-footer';\n\n  viewport = viewChild(CdkVirtualScrollViewport);\n\n  defaultOptions = new VirtualScrollOptions();\n  scrollStrategy = new TableVirtualScrollStrategy(\n    this.computedRowHeight(),\n    this.computedHeaderHeight()\n  );\n\n\n  dataLength$ = combineLatest([this.state.state$, this.dataStore.state$]).pipe(\n    map(([s, d]) => ({\n      paginated: s.notPersistedTableSettings.usePaginator && !s.showAll,\n      pageSize: s.userDefined?.pageSize || s.pageSize,\n      pageNumber: s.currentPage,\n      dataLen: d.dataLen\n    })),\n    distinctUntilChanged((a, b) =>\n      a.dataLen === b.dataLen &&\n      a.pageSize === b.pageSize &&\n      a.pageNumber === b.pageNumber &&\n      a.paginated === b.paginated),\n    map(({ dataLen, pageNumber, pageSize, paginated }) => {\n      if (paginated) return Math.min(dataLen - (pageNumber * pageSize), pageSize);\n      return dataLen;\n    }),\n    distinctUntilChanged()\n  );\n\n\n  subscriber = subscriber(this.dataLength$, (dataLength) => {\n    this.scrollStrategy.setDataLength(dataLength);\n\n    if (this.viewport()) {\n      this.setSize(this.viewport()!.elementRef);\n    }\n  });\n\n\n  _ = effect(() => {\n    const viewport = this.viewport();\n    untracked(() => {\n      if (!!viewport) {\n        addEventListener('resize', this.resizeHandler);\n        this.subscriber.on(viewport.renderedRangeStream, (range) => {\n          this.dataStore.patchState({\n            virtualEnds: {\n              start: range.start,\n              end: range.end + 25,\n            }\n          });\n        });\n        var offset$ = viewport.scrolledIndexChange.pipe(\n          map(() => viewport.getOffsetToRenderedContentStart() ?? 0),\n          distinctUntilChanged(),\n          defaultShareReplay()\n        );\n\n        this.subscriber.on(offset$, (offset) => {\n          this.dataStore.patchState({ virtualScrollOffset: offset });\n        });\n        this.setSize(this.viewport()!.elementRef);\n      };\n    })\n\n  })\n\n  ngAfterViewInit(): void {\n    const footerRowStyle$ = this.genericTable()?.$footerRowStyle();\n    if (footerRowStyle$) {\n      this.footerStyle =footerRowStyle$;\n    }\n  }\n\n  ngOnDestroy(): void {\n    removeEventListener('resize', this.resizeHandler);\n    this.sub?.unsubscribe();\n  }\n\n  setSize(el: ElementRef<HTMLElement>) {\n    const vsViewport = el.nativeElement;\n    const virtualScrollOptions = this.state.tableSettings().useVirtualScroll! as VirtualScrollOptions;\n    const rowHeight = this.computedRowHeight();\n    let amountOfVisibleItems = virtualScrollOptions?.amountOfVisibleItems || this.defaultOptions.amountOfVisibleItems;\n    virtualScrollOptions?.amountOfVisibleItems || this.defaultOptions.amountOfVisibleItems;\n\n    let height = 0;\n    var sub = this.dataLength$.subscribe(dataLength => {\n      if (dataLength < amountOfVisibleItems) {\n        height =+ (this.computedRowHeight() * dataLength);\n      } else {\n        height = (rowHeight * amountOfVisibleItems);\n      }\n    }\n    );\n    if (this.footerStyle !== 'no-footer') {\n      height += rowHeight;\n      console.log(height)\n      console.log('regular-footer');\n    }\n    if (!this.state.tableSettings().hideHeader) {\n      const headerHeight = this.computedHeaderHeight();\n      height += headerHeight;\n    }\n    if (virtualScrollOptions?.maxViewPortHeight && virtualScrollOptions.maxViewPortHeight < height) height = virtualScrollOptions.maxViewPortHeight;\n    vsViewport.setAttribute(\n      'style',\n      `height: ${height}px !important;`,\n    );\n    this.viewport()?.checkViewportSize();\n    const virtualScrollOffset = this.viewport()?.getOffsetToRenderedContentStart() ?? 0\n    this.dataStore.patchState({ virtualScrollOffset });\n  }\n\n  resizeHandler = () => {\n    if (this.viewport()) {\n      this.setSize(this.viewport()!.elementRef);\n    }\n  };\n\n  computedRowHeight() {\n    const virtualScrollOptions = this.state.tableSettings().useVirtualScroll! as VirtualScrollOptions;\n    const rowHeight = virtualScrollOptions?.rowHeight || (typeof this.state.tableSettings().rowHeight === 'number' && this.state.tableSettings().rowHeight as number) || this.defaultOptions.rowHeight;\n    return rowHeight;\n  }\n\n  computedHeaderHeight() {\n    const virtualScrollOptions = this.state.tableSettings().useVirtualScroll! as VirtualScrollOptions;\n    const headerHeight = virtualScrollOptions?.headerHeight || (typeof this.state.tableSettings().headerHeight === 'number' && this.state.tableSettings().headerHeight as number) || this.defaultOptions.headerHeight;\n    return headerHeight;\n  }\n}\n"]}
@@ -1,7 +1,6 @@
1
- import { ChangeDetectionStrategy, Component, inject } from '@angular/core';
1
+ import { ChangeDetectionStrategy, Component, computed, inject } from '@angular/core';
2
2
  import { TableStore } from '../../../classes/table-store';
3
3
  import { isFilterInfo } from '../../../classes/filter-info';
4
- import { map } from 'rxjs/operators';
5
4
  import { WrapperFilterStore } from '../table-wrapper-filter-store';
6
5
  import { LetDirective } from '@ngrx/component';
7
6
  import { AsyncPipe } from '@angular/common';
@@ -21,7 +20,7 @@ import * as i4 from "@angular/material/chips";
21
20
  export class FilterChipsComponent {
22
21
  tableState = inject(TableStore);
23
22
  filterStore = inject(WrapperFilterStore);
24
- filters$ = this.tableState.filters$.pipe(map(filters => Object.values(filters).filter(f => isFilterInfo(f) && !f._isExternallyManaged)));
23
+ $filters = computed(() => Object.values(this.tableState.$filters()).filter(f => isFilterInfo(f) && !f._isExternallyManaged));
25
24
  deleteByIndex(index) {
26
25
  this.filterStore.deleteByIndex(index);
27
26
  }
@@ -33,13 +32,13 @@ export class FilterChipsComponent {
33
32
  }
34
33
  currentFilters$ = this.filterStore.currentFilters$;
35
34
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: FilterChipsComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
36
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.2", type: FilterChipsComponent, isStandalone: true, selector: "lib-filter-list", ngImport: i0, template: "<div class=\"d-w\" *ngrxLet=\"currentFilters$ as currentFilters\" >\n\n @if (currentFilters.length) {\n <button class=\"cancel-button\" mat-icon-button (click)=\"clearAll()\" matTooltip=\"Close all Filters Cards\">\n <mat-icon class=\"cancel-button\" color=\"primary\">close</mat-icon>\n </button>\n <div class=\"float\">\n @for (filter of currentFilters; track filter.key) {\n <div class=\"filter\">\n <tb-filter [filter]=\"filter\" (close)=\"deleteByIndex($index)\" />\n </div>\n }\n </div>\n }\n\n <mat-chip-set *ngrxLet=\"filters$ as filters\">\n @for (filter of filters; track filter.key) {\n <mat-chip (dblclick)=\"addFilter(filter)\" (removed)=\"tableState.removeFilter(filter.filterId!)\">\n {{ filter.key | keyDisplay | async }} {{filter.filterType | formatFilterType : filter.filterValue}} {{ filter.filterValue | formatFilterValue: filter.key : filter.filterType | async }}\n <mat-icon matChipRemove>cancel</mat-icon>\n </mat-chip>\n }\n @if (filters.length > 1) {\n <mat-chip (removed)=\"tableState.clearFilters()\">\n Clear All\n <mat-icon matChipRemove>cancel</mat-icon>\n </mat-chip>\n }\n </mat-chip-set>\n\n</div>\n", styles: [".filter{margin:15px;display:inline-block}.filter-button{color:#6495ed;font-size:22px;font-weight:700}.cancel-button{margin-right:30px;font-weight:700}.filter-wrapper{margin-top:1em;margin-bottom:1em;float:right}.menu{margin-bottom:10px;width:109.1%}.filter-labels{color:#6495ed;font-size:17px;font-weight:600}.float{position:absolute;width:fit-content;z-index:101;top:10px;right:180px;max-width:90vw}.d-w{display:flex;flex-direction:row;justify-content:flex-end}\n"], dependencies: [{ kind: "directive", type: LetDirective, selector: "[ngrxLet]", inputs: ["ngrxLet", "ngrxLetSuspenseTpl"] }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i1.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: i2.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: FilterComponent, selector: "tb-filter", inputs: ["filter"], outputs: ["close"] }, { kind: "ngmodule", type: MatChipsModule }, { kind: "component", type: i4.MatChip, selector: "mat-basic-chip, [mat-basic-chip], mat-chip, [mat-chip]", inputs: ["role", "id", "aria-label", "aria-description", "value", "color", "removable", "highlighted", "disableRipple", "disabled"], outputs: ["removed", "destroyed"], exportAs: ["matChip"] }, { kind: "directive", type: i4.MatChipRemove, selector: "[matChipRemove]" }, { kind: "component", type: i4.MatChipSet, selector: "mat-chip-set", inputs: ["disabled", "role", "tabIndex"] }, { kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "pipe", type: KeyDisplayPipe, name: "keyDisplay" }, { kind: "pipe", type: FormatFilterTypePipe, name: "formatFilterType" }, { kind: "pipe", type: FormatFilterValuePipe, name: "formatFilterValue" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
35
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.2", type: FilterChipsComponent, isStandalone: true, selector: "lib-filter-list", ngImport: i0, template: "<div class=\"d-w\" *ngrxLet=\"currentFilters$ as currentFilters\" >\n\n @if (currentFilters.length) {\n <button class=\"cancel-button\" mat-icon-button (click)=\"clearAll()\" matTooltip=\"Close all Filters Cards\">\n <mat-icon class=\"cancel-button\" color=\"primary\">close</mat-icon>\n </button>\n <div class=\"float\">\n @for (filter of currentFilters; track filter.key) {\n <div class=\"filter\">\n <tb-filter [filter]=\"filter\" (close)=\"deleteByIndex($index)\" />\n </div>\n }\n </div>\n }\n\n <mat-chip-set>\n @for (filter of $filters(); track filter.key) {\n <mat-chip (dblclick)=\"addFilter(filter)\" (removed)=\"tableState.removeFilter(filter.filterId!)\">\n {{ filter.key | keyDisplay | async }} {{filter.filterType | formatFilterType : filter.filterValue}} {{ filter.filterValue | formatFilterValue: filter.key : filter.filterType | async }}\n <mat-icon matChipRemove>cancel</mat-icon>\n </mat-chip>\n }\n @if ($filters().length > 1) {\n <mat-chip (removed)=\"tableState.clearFilters()\">\n Clear All\n <mat-icon matChipRemove>cancel</mat-icon>\n </mat-chip>\n }\n </mat-chip-set>\n\n</div>\n", styles: [".filter{margin:15px;display:inline-block}.filter-button{color:#6495ed;font-size:22px;font-weight:700}.cancel-button{margin-right:30px;font-weight:700}.filter-wrapper{margin-top:1em;margin-bottom:1em;float:right}.menu{margin-bottom:10px;width:109.1%}.filter-labels{color:#6495ed;font-size:17px;font-weight:600}.float{position:absolute;width:fit-content;z-index:101;top:10px;right:180px;max-width:90vw}.d-w{display:flex;flex-direction:row;justify-content:flex-end}\n"], dependencies: [{ kind: "directive", type: LetDirective, selector: "[ngrxLet]", inputs: ["ngrxLet", "ngrxLetSuspenseTpl"] }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i1.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: i2.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: FilterComponent, selector: "tb-filter", inputs: ["filter"], outputs: ["close"] }, { kind: "ngmodule", type: MatChipsModule }, { kind: "component", type: i4.MatChip, selector: "mat-basic-chip, [mat-basic-chip], mat-chip, [mat-chip]", inputs: ["role", "id", "aria-label", "aria-description", "value", "color", "removable", "highlighted", "disableRipple", "disabled"], outputs: ["removed", "destroyed"], exportAs: ["matChip"] }, { kind: "directive", type: i4.MatChipRemove, selector: "[matChipRemove]" }, { kind: "component", type: i4.MatChipSet, selector: "mat-chip-set", inputs: ["disabled", "role", "tabIndex"] }, { kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "pipe", type: KeyDisplayPipe, name: "keyDisplay" }, { kind: "pipe", type: FormatFilterTypePipe, name: "formatFilterType" }, { kind: "pipe", type: FormatFilterValuePipe, name: "formatFilterValue" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
37
36
  }
38
37
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: FilterChipsComponent, decorators: [{
39
38
  type: Component,
40
39
  args: [{ selector: 'lib-filter-list', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [
41
40
  LetDirective, MatButtonModule, MatTooltipModule, MatIconModule, FilterComponent,
42
41
  MatChipsModule, AsyncPipe, KeyDisplayPipe, FormatFilterTypePipe, FormatFilterValuePipe
43
- ], template: "<div class=\"d-w\" *ngrxLet=\"currentFilters$ as currentFilters\" >\n\n @if (currentFilters.length) {\n <button class=\"cancel-button\" mat-icon-button (click)=\"clearAll()\" matTooltip=\"Close all Filters Cards\">\n <mat-icon class=\"cancel-button\" color=\"primary\">close</mat-icon>\n </button>\n <div class=\"float\">\n @for (filter of currentFilters; track filter.key) {\n <div class=\"filter\">\n <tb-filter [filter]=\"filter\" (close)=\"deleteByIndex($index)\" />\n </div>\n }\n </div>\n }\n\n <mat-chip-set *ngrxLet=\"filters$ as filters\">\n @for (filter of filters; track filter.key) {\n <mat-chip (dblclick)=\"addFilter(filter)\" (removed)=\"tableState.removeFilter(filter.filterId!)\">\n {{ filter.key | keyDisplay | async }} {{filter.filterType | formatFilterType : filter.filterValue}} {{ filter.filterValue | formatFilterValue: filter.key : filter.filterType | async }}\n <mat-icon matChipRemove>cancel</mat-icon>\n </mat-chip>\n }\n @if (filters.length > 1) {\n <mat-chip (removed)=\"tableState.clearFilters()\">\n Clear All\n <mat-icon matChipRemove>cancel</mat-icon>\n </mat-chip>\n }\n </mat-chip-set>\n\n</div>\n", styles: [".filter{margin:15px;display:inline-block}.filter-button{color:#6495ed;font-size:22px;font-weight:700}.cancel-button{margin-right:30px;font-weight:700}.filter-wrapper{margin-top:1em;margin-bottom:1em;float:right}.menu{margin-bottom:10px;width:109.1%}.filter-labels{color:#6495ed;font-size:17px;font-weight:600}.float{position:absolute;width:fit-content;z-index:101;top:10px;right:180px;max-width:90vw}.d-w{display:flex;flex-direction:row;justify-content:flex-end}\n"] }]
42
+ ], template: "<div class=\"d-w\" *ngrxLet=\"currentFilters$ as currentFilters\" >\n\n @if (currentFilters.length) {\n <button class=\"cancel-button\" mat-icon-button (click)=\"clearAll()\" matTooltip=\"Close all Filters Cards\">\n <mat-icon class=\"cancel-button\" color=\"primary\">close</mat-icon>\n </button>\n <div class=\"float\">\n @for (filter of currentFilters; track filter.key) {\n <div class=\"filter\">\n <tb-filter [filter]=\"filter\" (close)=\"deleteByIndex($index)\" />\n </div>\n }\n </div>\n }\n\n <mat-chip-set>\n @for (filter of $filters(); track filter.key) {\n <mat-chip (dblclick)=\"addFilter(filter)\" (removed)=\"tableState.removeFilter(filter.filterId!)\">\n {{ filter.key | keyDisplay | async }} {{filter.filterType | formatFilterType : filter.filterValue}} {{ filter.filterValue | formatFilterValue: filter.key : filter.filterType | async }}\n <mat-icon matChipRemove>cancel</mat-icon>\n </mat-chip>\n }\n @if ($filters().length > 1) {\n <mat-chip (removed)=\"tableState.clearFilters()\">\n Clear All\n <mat-icon matChipRemove>cancel</mat-icon>\n </mat-chip>\n }\n </mat-chip-set>\n\n</div>\n", styles: [".filter{margin:15px;display:inline-block}.filter-button{color:#6495ed;font-size:22px;font-weight:700}.cancel-button{margin-right:30px;font-weight:700}.filter-wrapper{margin-top:1em;margin-bottom:1em;float:right}.menu{margin-bottom:10px;width:109.1%}.filter-labels{color:#6495ed;font-size:17px;font-weight:600}.float{position:absolute;width:fit-content;z-index:101;top:10px;right:180px;max-width:90vw}.d-w{display:flex;flex-direction:row;justify-content:flex-end}\n"] }]
44
43
  }] });
45
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLWxpc3QuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYW5ndWxhci11dGlsaXRpZXMvc3JjL3RhYmxlLWJ1aWxkZXIvY29tcG9uZW50cy90YWJsZS1jb250YWluZXItZmlsdGVyL2ZpbHRlci1saXN0L2ZpbHRlci1saXN0LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItdXRpbGl0aWVzL3NyYy90YWJsZS1idWlsZGVyL2NvbXBvbmVudHMvdGFibGUtY29udGFpbmVyLWZpbHRlci9maWx0ZXItbGlzdC9maWx0ZXItbGlzdC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzRSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDMUQsT0FBTyxFQUFjLFlBQVksRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQ3hFLE9BQU8sRUFBRSxHQUFHLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNyQyxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUVuRSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQzVDLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUM3RCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDdkQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLCtCQUErQixDQUFDO0FBQ2hFLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFDNUQsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sd0NBQXdDLENBQUM7QUFDOUUsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0seUNBQXlDLENBQUM7Ozs7OztBQWFoRixNQUFNLE9BQU8sb0JBQW9CO0lBRS9CLFVBQVUsR0FBRyxNQUFNLENBQUMsVUFBVSxDQUFDLENBQUM7SUFDaEMsV0FBVyxHQUFHLE1BQU0sQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDO0lBRXpDLFFBQVEsR0FBa0MsSUFBSSxDQUFDLFVBQVUsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUNyRSxHQUFHLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FDWixNQUFNLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxvQkFBb0IsQ0FBc0IsQ0FDcEcsQ0FBQyxDQUFDO0lBRUwsYUFBYSxDQUFDLEtBQWE7UUFDekIsSUFBSSxDQUFDLFdBQVcsQ0FBQyxhQUFhLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDeEMsQ0FBQztJQUVELFNBQVMsQ0FBQyxNQUFzQjtRQUM5QixJQUFJLENBQUMsV0FBVyxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUNyQyxDQUFDO0lBRUQsUUFBUTtRQUNKLElBQUksQ0FBQyxXQUFXLENBQUMsUUFBUSxFQUFFLENBQUM7SUFDaEMsQ0FBQztJQUVELGVBQWUsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLGVBQWUsQ0FBQzt1R0F0QnhDLG9CQUFvQjsyRkFBcEIsb0JBQW9CLDJFQzVCakMsb3VDQStCQSwwZ0JEUEksWUFBWSxnR0FBRSxlQUFlLDJJQUFFLGdCQUFnQiw0VEFBRSxhQUFhLG9MQUFFLGVBQWUsNkZBQy9FLGNBQWMsa2dCQUFFLFNBQVMseUNBQUUsY0FBYyw4Q0FBRSxvQkFBb0Isb0RBQUUscUJBQXFCOzsyRkFHN0Usb0JBQW9CO2tCQVhoQyxTQUFTOytCQUNFLGlCQUFpQixtQkFHVix1QkFBdUIsQ0FBQyxNQUFNLGNBQ25DLElBQUksV0FDUDt3QkFDUCxZQUFZLEVBQUUsZUFBZSxFQUFFLGdCQUFnQixFQUFFLGFBQWEsRUFBRSxlQUFlO3dCQUMvRSxjQUFjLEVBQUUsU0FBUyxFQUFFLGNBQWMsRUFBRSxvQkFBb0IsRUFBRSxxQkFBcUI7cUJBQ3ZGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgaW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBUYWJsZVN0b3JlIH0gZnJvbSAnLi4vLi4vLi4vY2xhc3Nlcy90YWJsZS1zdG9yZSc7XG5pbXBvcnQgeyBGaWx0ZXJJbmZvLCBpc0ZpbHRlckluZm8gfSBmcm9tICcuLi8uLi8uLi9jbGFzc2VzL2ZpbHRlci1pbmZvJztcbmltcG9ydCB7IG1hcCB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcbmltcG9ydCB7IFdyYXBwZXJGaWx0ZXJTdG9yZSB9IGZyb20gJy4uL3RhYmxlLXdyYXBwZXItZmlsdGVyLXN0b3JlJztcbmltcG9ydCB7IE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IExldERpcmVjdGl2ZSB9IGZyb20gJ0BuZ3J4L2NvbXBvbmVudCc7XG5pbXBvcnQgeyBBc3luY1BpcGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTWF0QnV0dG9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvYnV0dG9uJztcbmltcG9ydCB7IE1hdFRvb2x0aXBNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC90b29sdGlwJztcbmltcG9ydCB7IE1hdEljb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pY29uJztcbmltcG9ydCB7IEZpbHRlckNvbXBvbmVudCB9IGZyb20gJy4uLy4uL2ZpbHRlci9maWx0ZXIuY29tcG9uZW50JztcbmltcG9ydCB7IE1hdENoaXBzTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvY2hpcHMnO1xuaW1wb3J0IHsgS2V5RGlzcGxheVBpcGUgfSBmcm9tICcuLi8uLi8uLi9waXBlcy9rZXktZGlzcGxheSc7XG5pbXBvcnQgeyBGb3JtYXRGaWx0ZXJUeXBlUGlwZSB9IGZyb20gJy4uLy4uLy4uL3BpcGVzL2Zvcm1hdC1maWx0ZXItdHlwZS5waXBlJztcbmltcG9ydCB7IEZvcm1hdEZpbHRlclZhbHVlUGlwZSB9IGZyb20gJy4uLy4uLy4uL3BpcGVzL2Zvcm1hdC1maWx0ZXItdmFsdWUucGlwZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2xpYi1maWx0ZXItbGlzdCcsXG4gIHRlbXBsYXRlVXJsOiAnLi9maWx0ZXItbGlzdC5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuLi9nZW4tZmlsdGVyLWRpc3BsYXllci9nZW4tZmlsdGVyLWRpc3BsYXllci5jb21wb25lbnQuY3NzJ10sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbXG4gICAgTGV0RGlyZWN0aXZlLCBNYXRCdXR0b25Nb2R1bGUsIE1hdFRvb2x0aXBNb2R1bGUsIE1hdEljb25Nb2R1bGUsIEZpbHRlckNvbXBvbmVudCxcbiAgICBNYXRDaGlwc01vZHVsZSwgQXN5bmNQaXBlLCBLZXlEaXNwbGF5UGlwZSwgRm9ybWF0RmlsdGVyVHlwZVBpcGUsIEZvcm1hdEZpbHRlclZhbHVlUGlwZVxuICBdXG59KVxuZXhwb3J0IGNsYXNzIEZpbHRlckNoaXBzQ29tcG9uZW50IHtcblxuICB0YWJsZVN0YXRlID0gaW5qZWN0KFRhYmxlU3RvcmUpO1xuICBmaWx0ZXJTdG9yZSA9IGluamVjdChXcmFwcGVyRmlsdGVyU3RvcmUpO1xuXG4gIGZpbHRlcnMkOiBPYnNlcnZhYmxlPEZpbHRlckluZm88YW55PltdPiA9IHRoaXMudGFibGVTdGF0ZS5maWx0ZXJzJC5waXBlKFxuICAgIG1hcChmaWx0ZXJzID0+XG4gICAgICBPYmplY3QudmFsdWVzKGZpbHRlcnMpLmZpbHRlcihmID0+IGlzRmlsdGVySW5mbyhmKSAmJiAhZi5faXNFeHRlcm5hbGx5TWFuYWdlZCkgYXMgRmlsdGVySW5mbzxhbnk+W11cbiAgICApKTtcblxuICBkZWxldGVCeUluZGV4KGluZGV4OiBudW1iZXIpIHtcbiAgICB0aGlzLmZpbHRlclN0b3JlLmRlbGV0ZUJ5SW5kZXgoaW5kZXgpO1xuICB9XG5cbiAgYWRkRmlsdGVyKGZpbHRlcjpGaWx0ZXJJbmZvPGFueT4pe1xuICAgIHRoaXMuZmlsdGVyU3RvcmUuYWRkRmlsdGVyKGZpbHRlcik7XG4gIH1cblxuICBjbGVhckFsbCgpIHtcbiAgICAgIHRoaXMuZmlsdGVyU3RvcmUuY2xlYXJBbGwoKTtcbiAgfVxuXG4gIGN1cnJlbnRGaWx0ZXJzJCA9IHRoaXMuZmlsdGVyU3RvcmUuY3VycmVudEZpbHRlcnMkO1xufVxuIiwiPGRpdiBjbGFzcz1cImQtd1wiICpuZ3J4TGV0PVwiY3VycmVudEZpbHRlcnMkIGFzIGN1cnJlbnRGaWx0ZXJzXCIgPlxuXG4gIEBpZiAoY3VycmVudEZpbHRlcnMubGVuZ3RoKSB7XG4gICAgPGJ1dHRvbiBjbGFzcz1cImNhbmNlbC1idXR0b25cIiBtYXQtaWNvbi1idXR0b24gKGNsaWNrKT1cImNsZWFyQWxsKClcIiBtYXRUb29sdGlwPVwiQ2xvc2UgYWxsIEZpbHRlcnMgQ2FyZHNcIj5cbiAgICAgIDxtYXQtaWNvbiBjbGFzcz1cImNhbmNlbC1idXR0b25cIiBjb2xvcj1cInByaW1hcnlcIj5jbG9zZTwvbWF0LWljb24+XG4gICAgPC9idXR0b24+XG4gICAgPGRpdiBjbGFzcz1cImZsb2F0XCI+XG4gICAgICBAZm9yIChmaWx0ZXIgb2YgY3VycmVudEZpbHRlcnM7IHRyYWNrIGZpbHRlci5rZXkpIHtcbiAgICAgICAgPGRpdiBjbGFzcz1cImZpbHRlclwiPlxuICAgICAgICAgIDx0Yi1maWx0ZXIgW2ZpbHRlcl09XCJmaWx0ZXJcIiAoY2xvc2UpPVwiZGVsZXRlQnlJbmRleCgkaW5kZXgpXCIgLz5cbiAgICAgICAgPC9kaXY+XG4gICAgICB9XG4gICAgPC9kaXY+XG4gIH1cblxuICA8bWF0LWNoaXAtc2V0ICpuZ3J4TGV0PVwiZmlsdGVycyQgYXMgZmlsdGVyc1wiPlxuICAgIEBmb3IgKGZpbHRlciBvZiBmaWx0ZXJzOyB0cmFjayBmaWx0ZXIua2V5KSB7XG4gICAgICA8bWF0LWNoaXAgKGRibGNsaWNrKT1cImFkZEZpbHRlcihmaWx0ZXIpXCIgIChyZW1vdmVkKT1cInRhYmxlU3RhdGUucmVtb3ZlRmlsdGVyKGZpbHRlci5maWx0ZXJJZCEpXCI+XG4gICAgICAgIHt7IGZpbHRlci5rZXkgfCBrZXlEaXNwbGF5IHwgYXN5bmMgIH19IHt7ZmlsdGVyLmZpbHRlclR5cGUgfCBmb3JtYXRGaWx0ZXJUeXBlIDogZmlsdGVyLmZpbHRlclZhbHVlfX0ge3sgZmlsdGVyLmZpbHRlclZhbHVlIHwgZm9ybWF0RmlsdGVyVmFsdWU6IGZpbHRlci5rZXkgOiBmaWx0ZXIuZmlsdGVyVHlwZSAgfCBhc3luYyB9fVxuICAgICAgICA8bWF0LWljb24gbWF0Q2hpcFJlbW92ZT5jYW5jZWw8L21hdC1pY29uPlxuICAgICAgPC9tYXQtY2hpcD5cbiAgICB9XG4gICAgQGlmIChmaWx0ZXJzLmxlbmd0aCA+IDEpIHtcbiAgICAgIDxtYXQtY2hpcCAgKHJlbW92ZWQpPVwidGFibGVTdGF0ZS5jbGVhckZpbHRlcnMoKVwiPlxuICAgICAgICBDbGVhciBBbGxcbiAgICAgICAgPG1hdC1pY29uIG1hdENoaXBSZW1vdmU+Y2FuY2VsPC9tYXQtaWNvbj5cbiAgICAgIDwvbWF0LWNoaXA+XG4gICAgfVxuICA8L21hdC1jaGlwLXNldD5cblxuPC9kaXY+XG4iXX0=
44
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLWxpc3QuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYW5ndWxhci11dGlsaXRpZXMvc3JjL3RhYmxlLWJ1aWxkZXIvY29tcG9uZW50cy90YWJsZS1jb250YWluZXItZmlsdGVyL2ZpbHRlci1saXN0L2ZpbHRlci1saXN0LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItdXRpbGl0aWVzL3NyYy90YWJsZS1idWlsZGVyL2NvbXBvbmVudHMvdGFibGUtY29udGFpbmVyLWZpbHRlci9maWx0ZXItbGlzdC9maWx0ZXItbGlzdC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLFFBQVEsRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDckYsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQzFELE9BQU8sRUFBYyxZQUFZLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUN4RSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUNuRSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQzVDLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUM3RCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDdkQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLCtCQUErQixDQUFDO0FBQ2hFLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFDNUQsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sd0NBQXdDLENBQUM7QUFDOUUsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0seUNBQXlDLENBQUM7Ozs7OztBQWFoRixNQUFNLE9BQU8sb0JBQW9CO0lBRS9CLFVBQVUsR0FBRyxNQUFNLENBQUMsVUFBVSxDQUFDLENBQUM7SUFDaEMsV0FBVyxHQUFHLE1BQU0sQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDO0lBRXpDLFFBQVEsR0FBRyxRQUFRLENBQUMsR0FBRyxFQUFFLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLFFBQVEsRUFBRSxDQUFDLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsWUFBWSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLG9CQUFvQixDQUFpQixDQUFDLENBQUE7SUFDNUksYUFBYSxDQUFDLEtBQWE7UUFDekIsSUFBSSxDQUFDLFdBQVcsQ0FBQyxhQUFhLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDeEMsQ0FBQztJQUVELFNBQVMsQ0FBQyxNQUFzQjtRQUM5QixJQUFJLENBQUMsV0FBVyxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUNyQyxDQUFDO0lBRUQsUUFBUTtRQUNKLElBQUksQ0FBQyxXQUFXLENBQUMsUUFBUSxFQUFFLENBQUM7SUFDaEMsQ0FBQztJQUVELGVBQWUsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLGVBQWUsQ0FBQzt1R0FsQnhDLG9CQUFvQjsyRkFBcEIsb0JBQW9CLDJFQzFCakMseXNDQStCQSwwZ0JEVEksWUFBWSxnR0FBRSxlQUFlLDJJQUFFLGdCQUFnQiw0VEFBRSxhQUFhLG9MQUFFLGVBQWUsNkZBQy9FLGNBQWMsa2dCQUFFLFNBQVMseUNBQUUsY0FBYyw4Q0FBRSxvQkFBb0Isb0RBQUUscUJBQXFCOzsyRkFHN0Usb0JBQW9CO2tCQVhoQyxTQUFTOytCQUNFLGlCQUFpQixtQkFHVix1QkFBdUIsQ0FBQyxNQUFNLGNBQ25DLElBQUksV0FDUDt3QkFDUCxZQUFZLEVBQUUsZUFBZSxFQUFFLGdCQUFnQixFQUFFLGFBQWEsRUFBRSxlQUFlO3dCQUMvRSxjQUFjLEVBQUUsU0FBUyxFQUFFLGNBQWMsRUFBRSxvQkFBb0IsRUFBRSxxQkFBcUI7cUJBQ3ZGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgY29tcHV0ZWQsIGluamVjdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgVGFibGVTdG9yZSB9IGZyb20gJy4uLy4uLy4uL2NsYXNzZXMvdGFibGUtc3RvcmUnO1xuaW1wb3J0IHsgRmlsdGVySW5mbywgaXNGaWx0ZXJJbmZvIH0gZnJvbSAnLi4vLi4vLi4vY2xhc3Nlcy9maWx0ZXItaW5mbyc7XG5pbXBvcnQgeyBXcmFwcGVyRmlsdGVyU3RvcmUgfSBmcm9tICcuLi90YWJsZS13cmFwcGVyLWZpbHRlci1zdG9yZSc7XG5pbXBvcnQgeyBMZXREaXJlY3RpdmUgfSBmcm9tICdAbmdyeC9jb21wb25lbnQnO1xuaW1wb3J0IHsgQXN5bmNQaXBlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IE1hdEJ1dHRvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2J1dHRvbic7XG5pbXBvcnQgeyBNYXRUb29sdGlwTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvdG9vbHRpcCc7XG5pbXBvcnQgeyBNYXRJY29uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaWNvbic7XG5pbXBvcnQgeyBGaWx0ZXJDb21wb25lbnQgfSBmcm9tICcuLi8uLi9maWx0ZXIvZmlsdGVyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBNYXRDaGlwc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2NoaXBzJztcbmltcG9ydCB7IEtleURpc3BsYXlQaXBlIH0gZnJvbSAnLi4vLi4vLi4vcGlwZXMva2V5LWRpc3BsYXknO1xuaW1wb3J0IHsgRm9ybWF0RmlsdGVyVHlwZVBpcGUgfSBmcm9tICcuLi8uLi8uLi9waXBlcy9mb3JtYXQtZmlsdGVyLXR5cGUucGlwZSc7XG5pbXBvcnQgeyBGb3JtYXRGaWx0ZXJWYWx1ZVBpcGUgfSBmcm9tICcuLi8uLi8uLi9waXBlcy9mb3JtYXQtZmlsdGVyLXZhbHVlLnBpcGUnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdsaWItZmlsdGVyLWxpc3QnLFxuICB0ZW1wbGF0ZVVybDogJy4vZmlsdGVyLWxpc3QuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi4vZ2VuLWZpbHRlci1kaXNwbGF5ZXIvZ2VuLWZpbHRlci1kaXNwbGF5ZXIuY29tcG9uZW50LmNzcyddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW1xuICAgIExldERpcmVjdGl2ZSwgTWF0QnV0dG9uTW9kdWxlLCBNYXRUb29sdGlwTW9kdWxlLCBNYXRJY29uTW9kdWxlLCBGaWx0ZXJDb21wb25lbnQsXG4gICAgTWF0Q2hpcHNNb2R1bGUsIEFzeW5jUGlwZSwgS2V5RGlzcGxheVBpcGUsIEZvcm1hdEZpbHRlclR5cGVQaXBlLCBGb3JtYXRGaWx0ZXJWYWx1ZVBpcGVcbiAgXVxufSlcbmV4cG9ydCBjbGFzcyBGaWx0ZXJDaGlwc0NvbXBvbmVudCB7XG5cbiAgdGFibGVTdGF0ZSA9IGluamVjdChUYWJsZVN0b3JlKTtcbiAgZmlsdGVyU3RvcmUgPSBpbmplY3QoV3JhcHBlckZpbHRlclN0b3JlKTtcblxuICAkZmlsdGVycyA9IGNvbXB1dGVkKCgpID0+IE9iamVjdC52YWx1ZXModGhpcy50YWJsZVN0YXRlLiRmaWx0ZXJzKCkpLmZpbHRlcihmID0+IGlzRmlsdGVySW5mbyhmKSAmJiAhZi5faXNFeHRlcm5hbGx5TWFuYWdlZCkgYXMgRmlsdGVySW5mb1tdKVxuICBkZWxldGVCeUluZGV4KGluZGV4OiBudW1iZXIpIHtcbiAgICB0aGlzLmZpbHRlclN0b3JlLmRlbGV0ZUJ5SW5kZXgoaW5kZXgpO1xuICB9XG5cbiAgYWRkRmlsdGVyKGZpbHRlcjpGaWx0ZXJJbmZvPGFueT4pe1xuICAgIHRoaXMuZmlsdGVyU3RvcmUuYWRkRmlsdGVyKGZpbHRlcik7XG4gIH1cblxuICBjbGVhckFsbCgpIHtcbiAgICAgIHRoaXMuZmlsdGVyU3RvcmUuY2xlYXJBbGwoKTtcbiAgfVxuXG4gIGN1cnJlbnRGaWx0ZXJzJCA9IHRoaXMuZmlsdGVyU3RvcmUuY3VycmVudEZpbHRlcnMkO1xufVxuIiwiPGRpdiBjbGFzcz1cImQtd1wiICpuZ3J4TGV0PVwiY3VycmVudEZpbHRlcnMkIGFzIGN1cnJlbnRGaWx0ZXJzXCIgPlxuXG4gIEBpZiAoY3VycmVudEZpbHRlcnMubGVuZ3RoKSB7XG4gICAgPGJ1dHRvbiBjbGFzcz1cImNhbmNlbC1idXR0b25cIiBtYXQtaWNvbi1idXR0b24gKGNsaWNrKT1cImNsZWFyQWxsKClcIiBtYXRUb29sdGlwPVwiQ2xvc2UgYWxsIEZpbHRlcnMgQ2FyZHNcIj5cbiAgICAgIDxtYXQtaWNvbiBjbGFzcz1cImNhbmNlbC1idXR0b25cIiBjb2xvcj1cInByaW1hcnlcIj5jbG9zZTwvbWF0LWljb24+XG4gICAgPC9idXR0b24+XG4gICAgPGRpdiBjbGFzcz1cImZsb2F0XCI+XG4gICAgICBAZm9yIChmaWx0ZXIgb2YgY3VycmVudEZpbHRlcnM7IHRyYWNrIGZpbHRlci5rZXkpIHtcbiAgICAgICAgPGRpdiBjbGFzcz1cImZpbHRlclwiPlxuICAgICAgICAgIDx0Yi1maWx0ZXIgW2ZpbHRlcl09XCJmaWx0ZXJcIiAoY2xvc2UpPVwiZGVsZXRlQnlJbmRleCgkaW5kZXgpXCIgLz5cbiAgICAgICAgPC9kaXY+XG4gICAgICB9XG4gICAgPC9kaXY+XG4gIH1cblxuICA8bWF0LWNoaXAtc2V0PlxuICAgIEBmb3IgKGZpbHRlciBvZiAkZmlsdGVycygpOyB0cmFjayBmaWx0ZXIua2V5KSB7XG4gICAgICA8bWF0LWNoaXAgKGRibGNsaWNrKT1cImFkZEZpbHRlcihmaWx0ZXIpXCIgIChyZW1vdmVkKT1cInRhYmxlU3RhdGUucmVtb3ZlRmlsdGVyKGZpbHRlci5maWx0ZXJJZCEpXCI+XG4gICAgICAgIHt7IGZpbHRlci5rZXkgfCBrZXlEaXNwbGF5IHwgYXN5bmMgIH19IHt7ZmlsdGVyLmZpbHRlclR5cGUgfCBmb3JtYXRGaWx0ZXJUeXBlIDogZmlsdGVyLmZpbHRlclZhbHVlfX0ge3sgZmlsdGVyLmZpbHRlclZhbHVlIHwgZm9ybWF0RmlsdGVyVmFsdWU6IGZpbHRlci5rZXkgOiBmaWx0ZXIuZmlsdGVyVHlwZSAgfCBhc3luYyB9fVxuICAgICAgICA8bWF0LWljb24gbWF0Q2hpcFJlbW92ZT5jYW5jZWw8L21hdC1pY29uPlxuICAgICAgPC9tYXQtY2hpcD5cbiAgICB9XG4gICAgQGlmICgkZmlsdGVycygpLmxlbmd0aCA+IDEpIHtcbiAgICAgIDxtYXQtY2hpcCAgKHJlbW92ZWQpPVwidGFibGVTdGF0ZS5jbGVhckZpbHRlcnMoKVwiPlxuICAgICAgICBDbGVhciBBbGxcbiAgICAgICAgPG1hdC1pY29uIG1hdENoaXBSZW1vdmU+Y2FuY2VsPC9tYXQtaWNvbj5cbiAgICAgIDwvbWF0LWNoaXA+XG4gICAgfVxuICA8L21hdC1jaGlwLXNldD5cblxuPC9kaXY+XG4iXX0=
@@ -1,7 +1,6 @@
1
- import { Component, ChangeDetectionStrategy, inject } from '@angular/core';
1
+ import { Component, ChangeDetectionStrategy, inject, computed } from '@angular/core';
2
2
  import { FieldType } from '../../../interfaces/report-def';
3
3
  import { TableStore } from '../../../classes/table-store';
4
- import { map } from 'rxjs/operators';
5
4
  import { WrapperFilterStore } from '../table-wrapper-filter-store';
6
5
  import { MatButtonModule } from '@angular/material/button';
7
6
  import { MatMenuModule } from '@angular/material/menu';
@@ -17,22 +16,21 @@ import * as i4 from "@angular/material/icon";
17
16
  export class GenFilterDisplayerComponent {
18
17
  tableState = inject(TableStore);
19
18
  filterStore = inject(WrapperFilterStore);
20
- constructor() {
21
- const tableState = this.tableState;
22
- this.filterCols$ = tableState.metaDataArray$.pipe(map(md => Object.values(md).filter(m => m.fieldType !== FieldType.Hidden && m.fieldType !== FieldType.NotMapped && !m.noFilter)));
23
- }
24
- filterCols$;
19
+ $filterCols = computed(() => {
20
+ const mds = this.tableState.$metaDataArray();
21
+ return mds.filter(m => m.fieldType !== FieldType.Hidden && m.fieldType !== FieldType.NotMapped && !m.noFilter);
22
+ });
25
23
  addFilter(metaData) {
26
24
  this.filterStore.addFilter({ key: metaData.key, fieldType: metaData.fieldType });
27
25
  }
28
26
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: GenFilterDisplayerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
29
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.2", type: GenFilterDisplayerComponent, isStandalone: true, selector: "tb-filter-displayer", ngImport: i0, template: "<button stop-propagation class=\"filter-button\" mat-icon-button [matMenuTriggerFor]=\"menu\" matTooltip=\"Add Filter\">\n <mat-icon class=\"filter-icon\" color=\"primary\">filter_list</mat-icon>\n</button>\n<mat-menu #menu=\"matMenu\">\n @for (md of filterCols$ | async; track md.key) {\n <button (click)=\"addFilter(md)\" mat-menu-item>\n <span class=\"filter-labels\">{{md.displayName || (md.key | spaceCase)}}</span>\n </button>\n }\n</mat-menu>\n", styles: [".filter{margin:15px;display:inline-block}.filter-button{color:#6495ed;font-size:22px;font-weight:700}.cancel-button{margin-right:30px;font-weight:700}.filter-wrapper{margin-top:1em;margin-bottom:1em;float:right}.menu{margin-bottom:10px;width:109.1%}.filter-labels{color:#6495ed;font-size:17px;font-weight:600}.float{position:absolute;width:fit-content;z-index:101;top:10px;right:180px;max-width:90vw}.d-w{display:flex;flex-direction:row;justify-content:flex-end}\n"], dependencies: [{ kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i1.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "ngmodule", type: MatMenuModule }, { kind: "component", type: i2.MatMenu, selector: "mat-menu", inputs: ["backdropClass", "aria-label", "aria-labelledby", "aria-describedby", "xPosition", "yPosition", "overlapTrigger", "hasBackdrop", "class", "classList"], outputs: ["closed", "close"], exportAs: ["matMenu"] }, { kind: "component", type: i2.MatMenuItem, selector: "[mat-menu-item]", inputs: ["role", "disabled", "disableRipple"], exportAs: ["matMenuItem"] }, { kind: "directive", type: i2.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", inputs: ["mat-menu-trigger-for", "matMenuTriggerFor", "matMenuTriggerData", "matMenuTriggerRestoreFocus"], outputs: ["menuOpened", "onMenuOpen", "menuClosed", "onMenuClose"], exportAs: ["matMenuTrigger"] }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: i3.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "directive", type: StopPropagationDirective, selector: "[stop-propagation]" }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "pipe", type: SpaceCasePipe, name: "spaceCase" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
27
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.2", type: GenFilterDisplayerComponent, isStandalone: true, selector: "tb-filter-displayer", ngImport: i0, template: "<button stop-propagation class=\"filter-button\" mat-icon-button [matMenuTriggerFor]=\"menu\" matTooltip=\"Add Filter\">\n <mat-icon class=\"filter-icon\" color=\"primary\">filter_list</mat-icon>\n</button>\n<mat-menu #menu=\"matMenu\">\n @for (md of $filterCols(); track md.key) {\n <button (click)=\"addFilter(md)\" mat-menu-item>\n <span class=\"filter-labels\">{{md.displayName || (md.key | spaceCase)}}</span>\n </button>\n }\n</mat-menu>\n", styles: [".filter{margin:15px;display:inline-block}.filter-button{color:#6495ed;font-size:22px;font-weight:700}.cancel-button{margin-right:30px;font-weight:700}.filter-wrapper{margin-top:1em;margin-bottom:1em;float:right}.menu{margin-bottom:10px;width:109.1%}.filter-labels{color:#6495ed;font-size:17px;font-weight:600}.float{position:absolute;width:fit-content;z-index:101;top:10px;right:180px;max-width:90vw}.d-w{display:flex;flex-direction:row;justify-content:flex-end}\n"], dependencies: [{ kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i1.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "ngmodule", type: MatMenuModule }, { kind: "component", type: i2.MatMenu, selector: "mat-menu", inputs: ["backdropClass", "aria-label", "aria-labelledby", "aria-describedby", "xPosition", "yPosition", "overlapTrigger", "hasBackdrop", "class", "classList"], outputs: ["closed", "close"], exportAs: ["matMenu"] }, { kind: "component", type: i2.MatMenuItem, selector: "[mat-menu-item]", inputs: ["role", "disabled", "disableRipple"], exportAs: ["matMenuItem"] }, { kind: "directive", type: i2.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", inputs: ["mat-menu-trigger-for", "matMenuTriggerFor", "matMenuTriggerData", "matMenuTriggerRestoreFocus"], outputs: ["menuOpened", "onMenuOpen", "menuClosed", "onMenuClose"], exportAs: ["matMenuTrigger"] }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: i3.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "directive", type: StopPropagationDirective, selector: "[stop-propagation]" }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "pipe", type: SpaceCasePipe, name: "spaceCase" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
30
28
  }
31
29
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: GenFilterDisplayerComponent, decorators: [{
32
30
  type: Component,
33
31
  args: [{ selector: 'tb-filter-displayer', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [
34
32
  MatButtonModule, MatMenuModule, MatTooltipModule, StopPropagationDirective, MatIconModule,
35
33
  AsyncPipe, SpaceCasePipe
36
- ], template: "<button stop-propagation class=\"filter-button\" mat-icon-button [matMenuTriggerFor]=\"menu\" matTooltip=\"Add Filter\">\n <mat-icon class=\"filter-icon\" color=\"primary\">filter_list</mat-icon>\n</button>\n<mat-menu #menu=\"matMenu\">\n @for (md of filterCols$ | async; track md.key) {\n <button (click)=\"addFilter(md)\" mat-menu-item>\n <span class=\"filter-labels\">{{md.displayName || (md.key | spaceCase)}}</span>\n </button>\n }\n</mat-menu>\n", styles: [".filter{margin:15px;display:inline-block}.filter-button{color:#6495ed;font-size:22px;font-weight:700}.cancel-button{margin-right:30px;font-weight:700}.filter-wrapper{margin-top:1em;margin-bottom:1em;float:right}.menu{margin-bottom:10px;width:109.1%}.filter-labels{color:#6495ed;font-size:17px;font-weight:600}.float{position:absolute;width:fit-content;z-index:101;top:10px;right:180px;max-width:90vw}.d-w{display:flex;flex-direction:row;justify-content:flex-end}\n"] }]
37
- }], ctorParameters: () => [] });
38
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2VuLWZpbHRlci1kaXNwbGF5ZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYW5ndWxhci11dGlsaXRpZXMvc3JjL3RhYmxlLWJ1aWxkZXIvY29tcG9uZW50cy90YWJsZS1jb250YWluZXItZmlsdGVyL2dlbi1maWx0ZXItZGlzcGxheWVyL2dlbi1maWx0ZXItZGlzcGxheWVyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItdXRpbGl0aWVzL3NyYy90YWJsZS1idWlsZGVyL2NvbXBvbmVudHMvdGFibGUtY29udGFpbmVyLWZpbHRlci9nZW4tZmlsdGVyLWRpc3BsYXllci9nZW4tZmlsdGVyLWRpc3BsYXllci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzRSxPQUFPLEVBQVksU0FBUyxFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFFckUsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQzFELE9BQU8sRUFBRSxHQUFHLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNyQyxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUNuRSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQzdELE9BQU8sRUFBRSxhQUFhLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUNoRixPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDdkQsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGlCQUFpQixDQUFDOzs7Ozs7QUFhNUMsTUFBTSxPQUFPLDJCQUEyQjtJQUM1QixVQUFVLEdBQUcsTUFBTSxDQUFDLFVBQVUsQ0FBQyxDQUFDO0lBQ2hDLFdBQVcsR0FBRyxNQUFNLENBQUMsa0JBQWtCLENBQUMsQ0FBQztJQUduRDtRQUNFLE1BQU0sVUFBVSxHQUFHLElBQUksQ0FBQyxVQUFVLENBQUM7UUFFbkMsSUFBSSxDQUFDLFdBQVcsR0FBSSxVQUFVLENBQUMsY0FBYyxDQUFDLElBQUksQ0FDaEQsR0FBRyxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBRSxFQUFFLENBQUUsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsU0FBUyxLQUFLLFNBQVMsQ0FBQyxNQUFNLElBQUksQ0FBQyxDQUFDLFNBQVMsS0FBSyxTQUFTLENBQUMsU0FBUyxJQUFJLENBQUMsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQ25JLENBQUM7SUFDSixDQUFDO0lBRUMsV0FBVyxDQUF5QjtJQUVwQyxTQUFTLENBQUMsUUFBa0I7UUFDMUIsSUFBSSxDQUFDLFdBQVcsQ0FBQyxTQUFTLENBQUMsRUFBQyxHQUFHLEVBQUUsUUFBUSxDQUFDLEdBQUcsRUFBRSxTQUFTLEVBQUUsUUFBUSxDQUFDLFNBQVMsRUFBQyxDQUFDLENBQUM7SUFDakYsQ0FBQzt1R0FqQlEsMkJBQTJCOzJGQUEzQiwyQkFBMkIsK0VDeEJ4QyxtZEFVQSx5Z0JEVU0sZUFBZSwySUFBRSxhQUFhLDZ2QkFBRSxnQkFBZ0IsNlRBQUUsd0JBQXdCLDhEQUFFLGFBQWEsK0tBQ3pGLFNBQVMseUNBQUUsYUFBYTs7MkZBR2pCLDJCQUEyQjtrQkFYdkMsU0FBUzsrQkFDSSxxQkFBcUIsbUJBR2QsdUJBQXVCLENBQUMsTUFBTSxjQUNuQyxJQUFJLFdBQ1A7d0JBQ1AsZUFBZSxFQUFFLGFBQWEsRUFBRSxnQkFBZ0IsRUFBRSx3QkFBd0IsRUFBRSxhQUFhO3dCQUN6RixTQUFTLEVBQUUsYUFBYTtxQkFDekIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBpbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE1ldGFEYXRhLCBGaWVsZFR5cGUgfSBmcm9tICcuLi8uLi8uLi9pbnRlcmZhY2VzL3JlcG9ydC1kZWYnO1xuaW1wb3J0IHsgT2JzZXJ2YWJsZSB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgVGFibGVTdG9yZSB9IGZyb20gJy4uLy4uLy4uL2NsYXNzZXMvdGFibGUtc3RvcmUnO1xuaW1wb3J0IHsgbWFwIH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xuaW1wb3J0IHsgV3JhcHBlckZpbHRlclN0b3JlIH0gZnJvbSAnLi4vdGFibGUtd3JhcHBlci1maWx0ZXItc3RvcmUnO1xuaW1wb3J0IHsgTWF0QnV0dG9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvYnV0dG9uJztcbmltcG9ydCB7IE1hdE1lbnVNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9tZW51JztcbmltcG9ydCB7IE1hdFRvb2x0aXBNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC90b29sdGlwJztcbmltcG9ydCB7IFNwYWNlQ2FzZVBpcGUsIFN0b3BQcm9wYWdhdGlvbkRpcmVjdGl2ZSB9IGZyb20gJy4uLy4uLy4uLy4uL3V0aWxpdGllcyc7XG5pbXBvcnQgeyBNYXRJY29uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaWNvbic7XG5pbXBvcnQgeyBBc3luY1BpcGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ3RiLWZpbHRlci1kaXNwbGF5ZXInLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9nZW4tZmlsdGVyLWRpc3BsYXllci5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJy4vZ2VuLWZpbHRlci1kaXNwbGF5ZXIuY29tcG9uZW50LmNzcyddLFxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgaW1wb3J0czogW1xuICAgICAgTWF0QnV0dG9uTW9kdWxlLCBNYXRNZW51TW9kdWxlLCBNYXRUb29sdGlwTW9kdWxlLCBTdG9wUHJvcGFnYXRpb25EaXJlY3RpdmUsIE1hdEljb25Nb2R1bGUsXG4gICAgICBBc3luY1BpcGUsIFNwYWNlQ2FzZVBpcGVcbiAgICBdXG59KVxuZXhwb3J0IGNsYXNzIEdlbkZpbHRlckRpc3BsYXllckNvbXBvbmVudCB7XG4gIHByb3RlY3RlZCB0YWJsZVN0YXRlID0gaW5qZWN0KFRhYmxlU3RvcmUpO1xuICBwcm90ZWN0ZWQgZmlsdGVyU3RvcmUgPSBpbmplY3QoV3JhcHBlckZpbHRlclN0b3JlKTtcblxuXG4gIGNvbnN0cnVjdG9yKCkge1xuICAgIGNvbnN0IHRhYmxlU3RhdGUgPSB0aGlzLnRhYmxlU3RhdGU7XG5cbiAgICB0aGlzLmZpbHRlckNvbHMkID0gIHRhYmxlU3RhdGUubWV0YURhdGFBcnJheSQucGlwZShcbiAgICAgIG1hcChtZCA9PiBPYmplY3QudmFsdWVzKCBtZCApLmZpbHRlcihtID0+IG0uZmllbGRUeXBlICE9PSBGaWVsZFR5cGUuSGlkZGVuICYmIG0uZmllbGRUeXBlICE9PSBGaWVsZFR5cGUuTm90TWFwcGVkICYmICFtLm5vRmlsdGVyKSksXG4gICAgKTtcbiAgfVxuXG4gICAgZmlsdGVyQ29scyQ6IE9ic2VydmFibGU8TWV0YURhdGFbXT47XG5cbiAgICBhZGRGaWx0ZXIobWV0YURhdGE6IE1ldGFEYXRhKSB7XG4gICAgICB0aGlzLmZpbHRlclN0b3JlLmFkZEZpbHRlcih7a2V5OiBtZXRhRGF0YS5rZXksIGZpZWxkVHlwZTogbWV0YURhdGEuZmllbGRUeXBlfSk7XG4gICAgfVxufVxuIiwiPGJ1dHRvbiBzdG9wLXByb3BhZ2F0aW9uIGNsYXNzPVwiZmlsdGVyLWJ1dHRvblwiIG1hdC1pY29uLWJ1dHRvbiBbbWF0TWVudVRyaWdnZXJGb3JdPVwibWVudVwiIG1hdFRvb2x0aXA9XCJBZGQgRmlsdGVyXCI+XG4gIDxtYXQtaWNvbiBjbGFzcz1cImZpbHRlci1pY29uXCIgY29sb3I9XCJwcmltYXJ5XCI+ZmlsdGVyX2xpc3Q8L21hdC1pY29uPlxuPC9idXR0b24+XG48bWF0LW1lbnUgI21lbnU9XCJtYXRNZW51XCI+XG4gIEBmb3IgKG1kIG9mIGZpbHRlckNvbHMkIHwgYXN5bmM7IHRyYWNrIG1kLmtleSkge1xuICAgIDxidXR0b24gKGNsaWNrKT1cImFkZEZpbHRlcihtZClcIiBtYXQtbWVudS1pdGVtPlxuICAgICAgPHNwYW4gY2xhc3M9XCJmaWx0ZXItbGFiZWxzXCI+e3ttZC5kaXNwbGF5TmFtZSB8fCAobWQua2V5IHwgc3BhY2VDYXNlKX19PC9zcGFuPlxuICAgIDwvYnV0dG9uPlxuICB9XG48L21hdC1tZW51PlxuIl19
34
+ ], template: "<button stop-propagation class=\"filter-button\" mat-icon-button [matMenuTriggerFor]=\"menu\" matTooltip=\"Add Filter\">\n <mat-icon class=\"filter-icon\" color=\"primary\">filter_list</mat-icon>\n</button>\n<mat-menu #menu=\"matMenu\">\n @for (md of $filterCols(); track md.key) {\n <button (click)=\"addFilter(md)\" mat-menu-item>\n <span class=\"filter-labels\">{{md.displayName || (md.key | spaceCase)}}</span>\n </button>\n }\n</mat-menu>\n", styles: [".filter{margin:15px;display:inline-block}.filter-button{color:#6495ed;font-size:22px;font-weight:700}.cancel-button{margin-right:30px;font-weight:700}.filter-wrapper{margin-top:1em;margin-bottom:1em;float:right}.menu{margin-bottom:10px;width:109.1%}.filter-labels{color:#6495ed;font-size:17px;font-weight:600}.float{position:absolute;width:fit-content;z-index:101;top:10px;right:180px;max-width:90vw}.d-w{display:flex;flex-direction:row;justify-content:flex-end}\n"] }]
35
+ }] });
36
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2VuLWZpbHRlci1kaXNwbGF5ZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYW5ndWxhci11dGlsaXRpZXMvc3JjL3RhYmxlLWJ1aWxkZXIvY29tcG9uZW50cy90YWJsZS1jb250YWluZXItZmlsdGVyL2dlbi1maWx0ZXItZGlzcGxheWVyL2dlbi1maWx0ZXItZGlzcGxheWVyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItdXRpbGl0aWVzL3NyYy90YWJsZS1idWlsZGVyL2NvbXBvbmVudHMvdGFibGUtY29udGFpbmVyLWZpbHRlci9nZW4tZmlsdGVyLWRpc3BsYXllci9nZW4tZmlsdGVyLWRpc3BsYXllci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDckYsT0FBTyxFQUFZLFNBQVMsRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBQ3JFLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUMxRCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUNuRSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQzdELE9BQU8sRUFBRSxhQUFhLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUNoRixPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDdkQsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGlCQUFpQixDQUFDOzs7Ozs7QUFhNUMsTUFBTSxPQUFPLDJCQUEyQjtJQUM1QixVQUFVLEdBQUcsTUFBTSxDQUFDLFVBQVUsQ0FBQyxDQUFDO0lBQ2hDLFdBQVcsR0FBRyxNQUFNLENBQUMsa0JBQWtCLENBQUMsQ0FBQztJQUNuRCxXQUFXLEdBQUcsUUFBUSxDQUFDLEdBQUcsRUFBRTtRQUMxQixNQUFNLEdBQUcsR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLGNBQWMsRUFBRSxDQUFDO1FBQzdDLE9BQU8sR0FBRyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxTQUFTLEtBQUssU0FBUyxDQUFDLE1BQU0sSUFBSSxDQUFDLENBQUMsU0FBUyxLQUFLLFNBQVMsQ0FBQyxTQUFTLElBQUksQ0FBQyxDQUFDLENBQUMsUUFBUSxDQUFDLENBQUE7SUFDaEgsQ0FBQyxDQUFDLENBQUM7SUFFRCxTQUFTLENBQUMsUUFBa0I7UUFDMUIsSUFBSSxDQUFDLFdBQVcsQ0FBQyxTQUFTLENBQUMsRUFBQyxHQUFHLEVBQUUsUUFBUSxDQUFDLEdBQUcsRUFBRSxTQUFTLEVBQUUsUUFBUSxDQUFDLFNBQVMsRUFBQyxDQUFDLENBQUM7SUFDakYsQ0FBQzt1R0FWUSwyQkFBMkI7MkZBQTNCLDJCQUEyQiwrRUN0QnhDLDZjQVVBLHlnQkRRTSxlQUFlLDJJQUFFLGFBQWEsNnZCQUFFLGdCQUFnQiw2VEFBRSx3QkFBd0IsOERBQUUsYUFBYSwrS0FDOUUsYUFBYTs7MkZBR2pCLDJCQUEyQjtrQkFYdkMsU0FBUzsrQkFDSSxxQkFBcUIsbUJBR2QsdUJBQXVCLENBQUMsTUFBTSxjQUNuQyxJQUFJLFdBQ1A7d0JBQ1AsZUFBZSxFQUFFLGFBQWEsRUFBRSxnQkFBZ0IsRUFBRSx3QkFBd0IsRUFBRSxhQUFhO3dCQUN6RixTQUFTLEVBQUUsYUFBYTtxQkFDekIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBpbmplY3QsIGNvbXB1dGVkIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBNZXRhRGF0YSwgRmllbGRUeXBlIH0gZnJvbSAnLi4vLi4vLi4vaW50ZXJmYWNlcy9yZXBvcnQtZGVmJztcbmltcG9ydCB7IFRhYmxlU3RvcmUgfSBmcm9tICcuLi8uLi8uLi9jbGFzc2VzL3RhYmxlLXN0b3JlJztcbmltcG9ydCB7IFdyYXBwZXJGaWx0ZXJTdG9yZSB9IGZyb20gJy4uL3RhYmxlLXdyYXBwZXItZmlsdGVyLXN0b3JlJztcbmltcG9ydCB7IE1hdEJ1dHRvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2J1dHRvbic7XG5pbXBvcnQgeyBNYXRNZW51TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvbWVudSc7XG5pbXBvcnQgeyBNYXRUb29sdGlwTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvdG9vbHRpcCc7XG5pbXBvcnQgeyBTcGFjZUNhc2VQaXBlLCBTdG9wUHJvcGFnYXRpb25EaXJlY3RpdmUgfSBmcm9tICcuLi8uLi8uLi8uLi91dGlsaXRpZXMnO1xuaW1wb3J0IHsgTWF0SWNvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xuaW1wb3J0IHsgQXN5bmNQaXBlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICd0Yi1maWx0ZXItZGlzcGxheWVyJyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vZ2VuLWZpbHRlci1kaXNwbGF5ZXIuY29tcG9uZW50Lmh0bWwnLFxuICAgIHN0eWxlVXJsczogWycuL2dlbi1maWx0ZXItZGlzcGxheWVyLmNvbXBvbmVudC5jc3MnXSxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIGltcG9ydHM6IFtcbiAgICAgIE1hdEJ1dHRvbk1vZHVsZSwgTWF0TWVudU1vZHVsZSwgTWF0VG9vbHRpcE1vZHVsZSwgU3RvcFByb3BhZ2F0aW9uRGlyZWN0aXZlLCBNYXRJY29uTW9kdWxlLFxuICAgICAgQXN5bmNQaXBlLCBTcGFjZUNhc2VQaXBlXG4gICAgXVxufSlcbmV4cG9ydCBjbGFzcyBHZW5GaWx0ZXJEaXNwbGF5ZXJDb21wb25lbnQge1xuICBwcm90ZWN0ZWQgdGFibGVTdGF0ZSA9IGluamVjdChUYWJsZVN0b3JlKTtcbiAgcHJvdGVjdGVkIGZpbHRlclN0b3JlID0gaW5qZWN0KFdyYXBwZXJGaWx0ZXJTdG9yZSk7XG4gICRmaWx0ZXJDb2xzID0gY29tcHV0ZWQoKCkgPT4ge1xuICAgIGNvbnN0IG1kcyA9IHRoaXMudGFibGVTdGF0ZS4kbWV0YURhdGFBcnJheSgpO1xuICAgIHJldHVybiBtZHMuZmlsdGVyKG0gPT4gbS5maWVsZFR5cGUgIT09IEZpZWxkVHlwZS5IaWRkZW4gJiYgbS5maWVsZFR5cGUgIT09IEZpZWxkVHlwZS5Ob3RNYXBwZWQgJiYgIW0ubm9GaWx0ZXIpXG4gIH0pO1xuXG4gICAgYWRkRmlsdGVyKG1ldGFEYXRhOiBNZXRhRGF0YSkge1xuICAgICAgdGhpcy5maWx0ZXJTdG9yZS5hZGRGaWx0ZXIoe2tleTogbWV0YURhdGEua2V5LCBmaWVsZFR5cGU6IG1ldGFEYXRhLmZpZWxkVHlwZX0pO1xuICAgIH1cbn1cbiIsIjxidXR0b24gc3RvcC1wcm9wYWdhdGlvbiBjbGFzcz1cImZpbHRlci1idXR0b25cIiBtYXQtaWNvbi1idXR0b24gW21hdE1lbnVUcmlnZ2VyRm9yXT1cIm1lbnVcIiBtYXRUb29sdGlwPVwiQWRkIEZpbHRlclwiPlxuICA8bWF0LWljb24gY2xhc3M9XCJmaWx0ZXItaWNvblwiIGNvbG9yPVwicHJpbWFyeVwiPmZpbHRlcl9saXN0PC9tYXQtaWNvbj5cbjwvYnV0dG9uPlxuPG1hdC1tZW51ICNtZW51PVwibWF0TWVudVwiPlxuICBAZm9yIChtZCBvZiAkZmlsdGVyQ29scygpOyB0cmFjayBtZC5rZXkpIHtcbiAgICA8YnV0dG9uIChjbGljayk9XCJhZGRGaWx0ZXIobWQpXCIgbWF0LW1lbnUtaXRlbT5cbiAgICAgIDxzcGFuIGNsYXNzPVwiZmlsdGVyLWxhYmVsc1wiPnt7bWQuZGlzcGxheU5hbWUgfHwgKG1kLmtleSB8IHNwYWNlQ2FzZSl9fTwvc3Bhbj5cbiAgICA8L2J1dHRvbj5cbiAgfVxuPC9tYXQtbWVudT5cbiJdfQ==
@@ -1,6 +1,7 @@
1
1
  import { Directive, TemplateRef, Input, inject } from '@angular/core';
2
2
  import { CdkColumnDef } from '@angular/cdk/table';
3
3
  import { FieldType } from '../interfaces/report-def';
4
+ import { ReplaySubject } from 'rxjs';
4
5
  import * as i0 from "@angular/core";
5
6
  // here is how to use it
6
7
  // <generic-table [report]="report">
@@ -25,23 +26,21 @@ export class CustomCellDirective {
25
26
  if (this.templateRef !== null)
26
27
  this.TemplateRef = this.templateRef;
27
28
  }
28
- ngAfterContentInit() {
29
- if (this.TemplateRef === null && this.templateRef !== null) {
30
- this.TemplateRef = this.templateRef;
31
- }
29
+ ngOnInit() {
30
+ this.$metaData.next(this.getMetaData());
32
31
  }
33
- getMetaData(metaData) {
32
+ $metaData = new ReplaySubject();
33
+ getMetaData = () => {
34
34
  return {
35
35
  key: this.customCell,
36
- displayName: this.displayName ?? metaData?.displayName,
37
- preSort: this.preSort ?? metaData?.preSort,
38
- fieldType: metaData?.fieldType ?? (this.customCellNotMapped ? FieldType.NotMapped : FieldType.Unknown),
39
- order: this.customCellOrder ?? metaData?.order,
40
- width: this.customCellWidth ?? metaData?.width,
36
+ displayName: this.displayName,
37
+ preSort: this.preSort,
38
+ fieldType: this.customCellNotMapped ? FieldType.NotMapped : FieldType.Unknown,
39
+ order: this.customCellOrder,
40
+ width: this.customCellWidth,
41
41
  customCell: true,
42
- noExport: !metaData,
43
42
  };
44
- }
43
+ };
45
44
  static ngTemplateContextGuard(dir, ctx) {
46
45
  return true;
47
46
  }
@@ -71,4 +70,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImpor
71
70
  }], customCellNotMapped: [{
72
71
  type: Input
73
72
  }] } });
74
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VzdG9tLWNlbGwtZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYW5ndWxhci11dGlsaXRpZXMvc3JjL3RhYmxlLWJ1aWxkZXIvZGlyZWN0aXZlcy9jdXN0b20tY2VsbC1kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxXQUFXLEVBQUUsS0FBSyxFQUFvQixNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDeEYsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQ2xELE9BQU8sRUFBcUIsU0FBUyxFQUFFLE1BQU0sMEJBQTBCLENBQUM7O0FBUXhFLHdCQUF3QjtBQUN4QixvQ0FBb0M7QUFDcEMscUhBQXFIO0FBQ3JILDJEQUEyRDtBQUMzRCxtQkFBbUI7QUFLbkIsTUFBTSxPQUFPLG1CQUFtQjtJQUNwQixXQUFXLEdBQUcsTUFBTSxDQUFtQixXQUFXLEVBQUUsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztJQUN6RSxTQUFTLEdBQUcsTUFBTSxDQUFDLFlBQVksRUFBRSxFQUFFLFFBQVEsRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDO0lBQ25ELFVBQVUsQ0FBVTtJQUNwQixXQUFXLENBQVU7SUFDckIsT0FBTyxDQUFXO0lBQ2xCLFdBQVcsQ0FBb0I7SUFDL0IsZUFBZSxDQUFVO0lBQ3pCLGVBQWUsQ0FBVTtJQUN6QixrQkFBa0IsQ0FBbUI7SUFDOUM7O09BRUc7SUFDTSxtQkFBbUIsR0FBRyxLQUFLLENBQUM7SUFDckM7UUFDRSxJQUFHLElBQUksQ0FBQyxXQUFXLEtBQUssSUFBSTtZQUMxQixJQUFJLENBQUMsV0FBVyxHQUFHLElBQUksQ0FBQyxXQUFXLENBQUM7SUFDdkMsQ0FBQztJQUNELGtCQUFrQjtRQUNqQixJQUFJLElBQUksQ0FBQyxXQUFXLEtBQUssSUFBSSxJQUFJLElBQUksQ0FBQyxXQUFXLEtBQUssSUFBSSxFQUFFLENBQUM7WUFDM0QsSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDO1FBQ3RDLENBQUM7SUFDSCxDQUFDO0lBRUQsV0FBVyxDQUFDLFFBQW9CO1FBQzlCLE9BQU87WUFDTCxHQUFHLEVBQUUsSUFBSSxDQUFDLFVBQVU7WUFDcEIsV0FBVyxFQUFFLElBQUksQ0FBQyxXQUFXLElBQUksUUFBUSxFQUFFLFdBQVc7WUFDdEQsT0FBTyxFQUFFLElBQUksQ0FBQyxPQUFPLElBQUksUUFBUSxFQUFFLE9BQU87WUFDMUMsU0FBUyxFQUFFLFFBQVEsRUFBRSxTQUFTLElBQUksQ0FBQyxJQUFJLENBQUMsbUJBQW1CLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxPQUFPLENBQUM7WUFDdEcsS0FBSyxFQUFFLElBQUksQ0FBQyxlQUFlLElBQUksUUFBUSxFQUFFLEtBQUs7WUFDOUMsS0FBSyxFQUFFLElBQUksQ0FBQyxlQUFlLElBQUksUUFBUSxFQUFFLEtBQUs7WUFDOUMsVUFBVSxFQUFFLElBQUk7WUFDaEIsUUFBUSxFQUFFLENBQUMsUUFBUTtTQUNwQixDQUFDO0lBQ0osQ0FBQztJQUNELE1BQU0sQ0FBQyxzQkFBc0IsQ0FBSSxHQUEyQixFQUFFLEdBQVE7UUFDcEUsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDO3VHQXRDUSxtQkFBbUI7MkZBQW5CLG1CQUFtQjs7MkZBQW5CLG1CQUFtQjtrQkFKL0IsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsY0FBYztvQkFDeEIsVUFBVSxFQUFFLElBQUk7aUJBQ25CO3dEQUlZLFVBQVU7c0JBQWxCLEtBQUs7Z0JBQ0csV0FBVztzQkFBbkIsS0FBSztnQkFDRyxPQUFPO3NCQUFmLEtBQUs7Z0JBQ0csV0FBVztzQkFBbkIsS0FBSztnQkFDRyxlQUFlO3NCQUF2QixLQUFLO2dCQUNHLGVBQWU7c0JBQXZCLEtBQUs7Z0JBQ0csa0JBQWtCO3NCQUExQixLQUFLO2dCQUlHLG1CQUFtQjtzQkFBM0IsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgVGVtcGxhdGVSZWYsIElucHV0LCBBZnRlckNvbnRlbnRJbml0LCBpbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENka0NvbHVtbkRlZiB9IGZyb20gJ0Bhbmd1bGFyL2Nkay90YWJsZSc7XG5pbXBvcnQgeyBTb3J0RGVmLCBNZXRhRGF0YSwgRmllbGRUeXBlIH0gZnJvbSAnLi4vaW50ZXJmYWNlcy9yZXBvcnQtZGVmJztcbmltcG9ydCB7IFRhYmxlQnVpbGRlciB9IGZyb20gJy4uL2NsYXNzZXMvdGFibGUtYnVpbGRlcic7XG5pbXBvcnQge1RhYmxlU3RvcmV9IGZyb20gXCIuLi9jbGFzc2VzL3RhYmxlLXN0b3JlXCI7XG5cbmludGVyZmFjZSBDdXN0b21DZWxsQ29udGV4dDxUPiB7XG4gICRpbXBsaWNpdDogVCxcbiAgZWxlbWVudDogVCxcbn1cbi8vIGhlcmUgaXMgaG93IHRvIHVzZSBpdFxuLy8gPGdlbmVyaWMtdGFibGUgW3JlcG9ydF09XCJyZXBvcnRcIj5cbi8vICAgICA8cCAqY3VzdG9tQ2VsbD1cIidjb2x1bW4xJzsgbGV0IGVsZW1lbnQgPSBlbGVtZW50XCIgW2NsYXNzLm1ha2VNZVJlZF09XCJlbGVtZW50Py5wb3J0XCI+SWYgUG9ydCwgaSB3aWxsIGJlIHJlZDwvcD5cbi8vICAgICA8cCAqY3VzdG9tQ2VsbD1cIidjb2x1bW4yJ1wiPkkgYW0gY3VzdG9tIGNlbGwgdHdvIDwvcD5cbi8vIDwvZ2VuZXJpYy10YWJsZT5cbkBEaXJlY3RpdmUoe1xuICAgIHNlbGVjdG9yOiAnW2N1c3RvbUNlbGxdJyxcbiAgICBzdGFuZGFsb25lOiB0cnVlXG59KVxuZXhwb3J0IGNsYXNzIEN1c3RvbUNlbGxEaXJlY3RpdmU8VCA9IGFueT4gaW1wbGVtZW50cyBBZnRlckNvbnRlbnRJbml0IHtcbiAgICBwcml2YXRlIHRlbXBsYXRlUmVmID0gaW5qZWN0PFRlbXBsYXRlUmVmPGFueT4+KFRlbXBsYXRlUmVmLCB7IG9wdGlvbmFsOiB0cnVlIH0pO1xuICAgIHB1YmxpYyBjb2x1bW5EZWYgPSBpbmplY3QoQ2RrQ29sdW1uRGVmLCB7IG9wdGlvbmFsOiB0cnVlIH0pO1xuICAgIEBJbnB1dCgpIGN1c3RvbUNlbGwhOiBzdHJpbmc7XG4gICAgQElucHV0KCkgZGlzcGxheU5hbWU/OiBzdHJpbmc7XG4gICAgQElucHV0KCkgcHJlU29ydD86IFNvcnREZWY7XG4gICAgQElucHV0KCkgVGVtcGxhdGVSZWYhOiBUZW1wbGF0ZVJlZjxhbnk+O1xuICAgIEBJbnB1dCgpIGN1c3RvbUNlbGxPcmRlcj86IG51bWJlcjtcbiAgICBASW5wdXQoKSBjdXN0b21DZWxsV2lkdGg/OiBzdHJpbmc7XG4gICAgQElucHV0KCkgY3VzdG9tQ2VsbFRhYmxlUmVmPzogVGFibGVCdWlsZGVyPFQ+O1xuICAgIC8qKlxuICAgICAqIHRydWUgaWYgY29sdW1uIG5vdCBtYXBwZWQgdG8gYSBwcm9wZXJ0eSBpbiB0aGUgZGF0YSBzb3VyY2UuIERlZmF1bHQgaXMgZmFsc2UuXG4gICAgICovXG4gICAgQElucHV0KCkgY3VzdG9tQ2VsbE5vdE1hcHBlZCA9IGZhbHNlO1xuICAgIGNvbnN0cnVjdG9yKCkge1xuICAgICAgaWYodGhpcy50ZW1wbGF0ZVJlZiAhPT0gbnVsbClcbiAgICAgICAgdGhpcy5UZW1wbGF0ZVJlZiA9IHRoaXMudGVtcGxhdGVSZWY7XG4gICAgIH1cbiAgICAgbmdBZnRlckNvbnRlbnRJbml0KCkge1xuICAgICAgaWYgKHRoaXMuVGVtcGxhdGVSZWYgPT09IG51bGwgJiYgdGhpcy50ZW1wbGF0ZVJlZiAhPT0gbnVsbCkge1xuICAgICAgICB0aGlzLlRlbXBsYXRlUmVmID0gdGhpcy50ZW1wbGF0ZVJlZjtcbiAgICAgIH1cbiAgICB9XG5cbiAgICBnZXRNZXRhRGF0YShtZXRhRGF0YT8gOiBNZXRhRGF0YSk6IE1ldGFEYXRhIHtcbiAgICAgIHJldHVybiB7XG4gICAgICAgIGtleTogdGhpcy5jdXN0b21DZWxsLFxuICAgICAgICBkaXNwbGF5TmFtZTogdGhpcy5kaXNwbGF5TmFtZSA/PyBtZXRhRGF0YT8uZGlzcGxheU5hbWUsXG4gICAgICAgIHByZVNvcnQ6IHRoaXMucHJlU29ydCA/PyBtZXRhRGF0YT8ucHJlU29ydCxcbiAgICAgICAgZmllbGRUeXBlOiBtZXRhRGF0YT8uZmllbGRUeXBlID8/ICh0aGlzLmN1c3RvbUNlbGxOb3RNYXBwZWQgPyBGaWVsZFR5cGUuTm90TWFwcGVkIDogRmllbGRUeXBlLlVua25vd24pLFxuICAgICAgICBvcmRlcjogdGhpcy5jdXN0b21DZWxsT3JkZXIgPz8gbWV0YURhdGE/Lm9yZGVyLFxuICAgICAgICB3aWR0aDogdGhpcy5jdXN0b21DZWxsV2lkdGggPz8gbWV0YURhdGE/LndpZHRoLFxuICAgICAgICBjdXN0b21DZWxsOiB0cnVlLFxuICAgICAgICBub0V4cG9ydDogIW1ldGFEYXRhLFxuICAgICAgfTtcbiAgICB9XG4gICAgc3RhdGljIG5nVGVtcGxhdGVDb250ZXh0R3VhcmQ8VD4oZGlyOiBDdXN0b21DZWxsRGlyZWN0aXZlPFQ+LCBjdHg6IGFueSk6IGN0eCBpcyBDdXN0b21DZWxsQ29udGV4dDxUPiB7XG4gICAgICByZXR1cm4gdHJ1ZTtcbiAgICB9XG59XG4iXX0=
73
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VzdG9tLWNlbGwtZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYW5ndWxhci11dGlsaXRpZXMvc3JjL3RhYmxlLWJ1aWxkZXIvZGlyZWN0aXZlcy9jdXN0b20tY2VsbC1kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxXQUFXLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUM5RSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDbEQsT0FBTyxFQUFxQixTQUFTLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUV4RSxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sTUFBTSxDQUFDOztBQU1yQyx3QkFBd0I7QUFDeEIsb0NBQW9DO0FBQ3BDLHFIQUFxSDtBQUNySCwyREFBMkQ7QUFDM0QsbUJBQW1CO0FBS25CLE1BQU0sT0FBTyxtQkFBbUI7SUFDcEIsV0FBVyxHQUFHLE1BQU0sQ0FBbUIsV0FBVyxFQUFFLEVBQUUsUUFBUSxFQUFFLElBQUksRUFBRSxDQUFDLENBQUM7SUFDekUsU0FBUyxHQUFHLE1BQU0sQ0FBQyxZQUFZLEVBQUUsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztJQUNuRCxVQUFVLENBQVU7SUFDcEIsV0FBVyxDQUFVO0lBQ3JCLE9BQU8sQ0FBVztJQUNsQixXQUFXLENBQW9CO0lBQy9CLGVBQWUsQ0FBVTtJQUN6QixlQUFlLENBQVU7SUFDekIsa0JBQWtCLENBQW1CO0lBQzlDOztPQUVHO0lBQ00sbUJBQW1CLEdBQUcsS0FBSyxDQUFDO0lBQ3JDO1FBQ0UsSUFBRyxJQUFJLENBQUMsV0FBVyxLQUFLLElBQUk7WUFDMUIsSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDO0lBQ3ZDLENBQUM7SUFDRCxRQUFRO1FBQ1AsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDLENBQUE7SUFDekMsQ0FBQztJQUNELFNBQVMsR0FBRyxJQUFJLGFBQWEsRUFBWSxDQUFDO0lBQzFDLFdBQVcsR0FBRyxHQUFhLEVBQUU7UUFDM0IsT0FBTztZQUNMLEdBQUcsRUFBRSxJQUFJLENBQUMsVUFBVTtZQUNwQixXQUFXLEVBQUUsSUFBSSxDQUFDLFdBQVc7WUFDN0IsT0FBTyxFQUFFLElBQUksQ0FBQyxPQUFPO1lBQ3JCLFNBQVMsRUFBRSxJQUFJLENBQUMsbUJBQW1CLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxPQUFPO1lBQzdFLEtBQUssRUFBRSxJQUFJLENBQUMsZUFBZTtZQUMzQixLQUFLLEVBQUUsSUFBSSxDQUFDLGVBQWU7WUFDM0IsVUFBVSxFQUFFLElBQUk7U0FDakIsQ0FBQztJQUNKLENBQUMsQ0FBQTtJQUdELE1BQU0sQ0FBQyxzQkFBc0IsQ0FBSSxHQUEyQixFQUFFLEdBQVE7UUFDcEUsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDO3VHQXJDUSxtQkFBbUI7MkZBQW5CLG1CQUFtQjs7MkZBQW5CLG1CQUFtQjtrQkFKL0IsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsY0FBYztvQkFDeEIsVUFBVSxFQUFFLElBQUk7aUJBQ25CO3dEQUlZLFVBQVU7c0JBQWxCLEtBQUs7Z0JBQ0csV0FBVztzQkFBbkIsS0FBSztnQkFDRyxPQUFPO3NCQUFmLEtBQUs7Z0JBQ0csV0FBVztzQkFBbkIsS0FBSztnQkFDRyxlQUFlO3NCQUF2QixLQUFLO2dCQUNHLGVBQWU7c0JBQXZCLEtBQUs7Z0JBQ0csa0JBQWtCO3NCQUExQixLQUFLO2dCQUlHLG1CQUFtQjtzQkFBM0IsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgVGVtcGxhdGVSZWYsIElucHV0LCBpbmplY3QsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ2RrQ29sdW1uRGVmIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL3RhYmxlJztcbmltcG9ydCB7IFNvcnREZWYsIE1ldGFEYXRhLCBGaWVsZFR5cGUgfSBmcm9tICcuLi9pbnRlcmZhY2VzL3JlcG9ydC1kZWYnO1xuaW1wb3J0IHsgVGFibGVCdWlsZGVyIH0gZnJvbSAnLi4vY2xhc3Nlcy90YWJsZS1idWlsZGVyJztcbmltcG9ydCB7IFJlcGxheVN1YmplY3QgfSBmcm9tICdyeGpzJztcblxuaW50ZXJmYWNlIEN1c3RvbUNlbGxDb250ZXh0PFQ+IHtcbiAgJGltcGxpY2l0OiBULFxuICBlbGVtZW50OiBULFxufVxuLy8gaGVyZSBpcyBob3cgdG8gdXNlIGl0XG4vLyA8Z2VuZXJpYy10YWJsZSBbcmVwb3J0XT1cInJlcG9ydFwiPlxuLy8gICAgIDxwICpjdXN0b21DZWxsPVwiJ2NvbHVtbjEnOyBsZXQgZWxlbWVudCA9IGVsZW1lbnRcIiBbY2xhc3MubWFrZU1lUmVkXT1cImVsZW1lbnQ/LnBvcnRcIj5JZiBQb3J0LCBpIHdpbGwgYmUgcmVkPC9wPlxuLy8gICAgIDxwICpjdXN0b21DZWxsPVwiJ2NvbHVtbjInXCI+SSBhbSBjdXN0b20gY2VsbCB0d28gPC9wPlxuLy8gPC9nZW5lcmljLXRhYmxlPlxuQERpcmVjdGl2ZSh7XG4gICAgc2VsZWN0b3I6ICdbY3VzdG9tQ2VsbF0nLFxuICAgIHN0YW5kYWxvbmU6IHRydWVcbn0pXG5leHBvcnQgY2xhc3MgQ3VzdG9tQ2VsbERpcmVjdGl2ZTxUID0gYW55PiBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gICAgcHJpdmF0ZSB0ZW1wbGF0ZVJlZiA9IGluamVjdDxUZW1wbGF0ZVJlZjxhbnk+PihUZW1wbGF0ZVJlZiwgeyBvcHRpb25hbDogdHJ1ZSB9KTtcbiAgICBwdWJsaWMgY29sdW1uRGVmID0gaW5qZWN0KENka0NvbHVtbkRlZiwgeyBvcHRpb25hbDogdHJ1ZSB9KTtcbiAgICBASW5wdXQoKSBjdXN0b21DZWxsITogc3RyaW5nO1xuICAgIEBJbnB1dCgpIGRpc3BsYXlOYW1lPzogc3RyaW5nO1xuICAgIEBJbnB1dCgpIHByZVNvcnQ/OiBTb3J0RGVmO1xuICAgIEBJbnB1dCgpIFRlbXBsYXRlUmVmITogVGVtcGxhdGVSZWY8YW55PjtcbiAgICBASW5wdXQoKSBjdXN0b21DZWxsT3JkZXI/OiBudW1iZXI7XG4gICAgQElucHV0KCkgY3VzdG9tQ2VsbFdpZHRoPzogc3RyaW5nO1xuICAgIEBJbnB1dCgpIGN1c3RvbUNlbGxUYWJsZVJlZj86IFRhYmxlQnVpbGRlcjxUPjtcbiAgICAvKipcbiAgICAgKiB0cnVlIGlmIGNvbHVtbiBub3QgbWFwcGVkIHRvIGEgcHJvcGVydHkgaW4gdGhlIGRhdGEgc291cmNlLiBEZWZhdWx0IGlzIGZhbHNlLlxuICAgICAqL1xuICAgIEBJbnB1dCgpIGN1c3RvbUNlbGxOb3RNYXBwZWQgPSBmYWxzZTtcbiAgICBjb25zdHJ1Y3RvcigpIHtcbiAgICAgIGlmKHRoaXMudGVtcGxhdGVSZWYgIT09IG51bGwpXG4gICAgICAgIHRoaXMuVGVtcGxhdGVSZWYgPSB0aGlzLnRlbXBsYXRlUmVmO1xuICAgICB9XG4gICAgIG5nT25Jbml0KCkge1xuICAgICAgdGhpcy4kbWV0YURhdGEubmV4dCh0aGlzLmdldE1ldGFEYXRhKCkpXG4gICAgfVxuICAgICRtZXRhRGF0YSA9IG5ldyBSZXBsYXlTdWJqZWN0PE1ldGFEYXRhPigpO1xuICAgIGdldE1ldGFEYXRhID0gKCk6IE1ldGFEYXRhID0+IHtcbiAgICAgIHJldHVybiB7XG4gICAgICAgIGtleTogdGhpcy5jdXN0b21DZWxsLFxuICAgICAgICBkaXNwbGF5TmFtZTogdGhpcy5kaXNwbGF5TmFtZSxcbiAgICAgICAgcHJlU29ydDogdGhpcy5wcmVTb3J0LFxuICAgICAgICBmaWVsZFR5cGU6IHRoaXMuY3VzdG9tQ2VsbE5vdE1hcHBlZCA/IEZpZWxkVHlwZS5Ob3RNYXBwZWQgOiBGaWVsZFR5cGUuVW5rbm93bixcbiAgICAgICAgb3JkZXI6IHRoaXMuY3VzdG9tQ2VsbE9yZGVyLFxuICAgICAgICB3aWR0aDogdGhpcy5jdXN0b21DZWxsV2lkdGgsXG4gICAgICAgIGN1c3RvbUNlbGw6IHRydWUsXG4gICAgICB9O1xuICAgIH1cbiAgICBcblxuICAgIHN0YXRpYyBuZ1RlbXBsYXRlQ29udGV4dEd1YXJkPFQ+KGRpcjogQ3VzdG9tQ2VsbERpcmVjdGl2ZTxUPiwgY3R4OiBhbnkpOiBjdHggaXMgQ3VzdG9tQ2VsbENvbnRleHQ8VD4ge1xuICAgICAgcmV0dXJuIHRydWU7XG4gICAgfVxufVxuIl19
@@ -1,9 +1,9 @@
1
- import { Directive } from "@angular/core";
1
+ import { Directive, signal } from "@angular/core";
2
2
  import * as i0 from "@angular/core";
3
3
  export class TableWrapperDirective {
4
- registrations = [];
4
+ $registrations = signal([]);
5
5
  register(filter) {
6
- this.registrations.push(filter);
6
+ this.$registrations.update(registrations => [...registrations, filter]);
7
7
  }
8
8
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: TableWrapperDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
9
9
  static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.2", type: TableWrapperDirective, isStandalone: true, selector: "[tbWrapper]", ngImport: i0 });
@@ -15,4 +15,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImpor
15
15
  standalone: true,
16
16
  }]
17
17
  }] });
18
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtd3JhcHBlci5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyLXV0aWxpdGllcy9zcmMvdGFibGUtYnVpbGRlci9kaXJlY3RpdmVzL3RhYmxlLXdyYXBwZXIuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBbUIsU0FBUyxFQUFhLE1BQU0sZUFBZSxDQUFDOztBQU90RSxNQUFNLE9BQU8scUJBQXFCO0lBQ2hDLGFBQWEsR0FBNEQsRUFBRSxDQUFDO0lBRTVFLFFBQVEsQ0FBQyxNQUF5RDtRQUNoRSxJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUNsQyxDQUFDO3VHQUxVLHFCQUFxQjsyRkFBckIscUJBQXFCOzsyRkFBckIscUJBQXFCO2tCQUpqQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxhQUFhO29CQUN2QixVQUFVLEVBQUUsSUFBSTtpQkFDakIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb250ZW50Q2hpbGRyZW4sIERpcmVjdGl2ZSwgUXVlcnlMaXN0IH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcbmltcG9ydCB7IFRhYmxlQ3VzdG9tRmlsdGVyRGlyZWN0aXZlLCBUYWJsZUZpbHRlckRpcmVjdGl2ZSB9IGZyb20gXCIuL3RiLWZpbHRlci5kaXJlY3RpdmVcIjtcblxuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnW3RiV3JhcHBlcl0nLFxuICBzdGFuZGFsb25lOiB0cnVlLFxufSlcbmV4cG9ydCBjbGFzcyBUYWJsZVdyYXBwZXJEaXJlY3RpdmUge1xuICByZWdpc3RyYXRpb25zIDogKFRhYmxlQ3VzdG9tRmlsdGVyRGlyZWN0aXZlIHwgVGFibGVGaWx0ZXJEaXJlY3RpdmUpIFtdID0gW107XG5cbiAgcmVnaXN0ZXIoZmlsdGVyOiBUYWJsZUN1c3RvbUZpbHRlckRpcmVjdGl2ZSB8IFRhYmxlRmlsdGVyRGlyZWN0aXZlKSB7XG4gICAgdGhpcy5yZWdpc3RyYXRpb25zLnB1c2goZmlsdGVyKTtcbiAgfVxufVxuIl19
18
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtd3JhcHBlci5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyLXV0aWxpdGllcy9zcmMvdGFibGUtYnVpbGRlci9kaXJlY3RpdmVzL3RhYmxlLXdyYXBwZXIuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQU9sRCxNQUFNLE9BQU8scUJBQXFCO0lBQ2hDLGNBQWMsR0FBRyxNQUFNLENBQUMsRUFBMkQsQ0FBQyxDQUFDO0lBRXJGLFFBQVEsQ0FBQyxNQUF5RDtRQUNoRSxJQUFJLENBQUMsY0FBYyxDQUFDLE1BQU0sQ0FBRSxhQUFhLENBQUMsRUFBRSxDQUFFLENBQUMsR0FBRyxhQUFhLEVBQUMsTUFBTSxDQUFDLENBQUUsQ0FBQztJQUM1RSxDQUFDO3VHQUxVLHFCQUFxQjsyRkFBckIscUJBQXFCOzsyRkFBckIscUJBQXFCO2tCQUpqQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxhQUFhO29CQUN2QixVQUFVLEVBQUUsSUFBSTtpQkFDakIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIHNpZ25hbCB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQgeyBUYWJsZUN1c3RvbUZpbHRlckRpcmVjdGl2ZSwgVGFibGVGaWx0ZXJEaXJlY3RpdmUgfSBmcm9tIFwiLi90Yi1maWx0ZXIuZGlyZWN0aXZlXCI7XG5cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ1t0YldyYXBwZXJdJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbn0pXG5leHBvcnQgY2xhc3MgVGFibGVXcmFwcGVyRGlyZWN0aXZlIHtcbiAgJHJlZ2lzdHJhdGlvbnMgPSBzaWduYWwoW10gYXMgKFRhYmxlQ3VzdG9tRmlsdGVyRGlyZWN0aXZlIHwgVGFibGVGaWx0ZXJEaXJlY3RpdmUpW10pO1xuXG4gIHJlZ2lzdGVyKGZpbHRlcjogVGFibGVDdXN0b21GaWx0ZXJEaXJlY3RpdmUgfCBUYWJsZUZpbHRlckRpcmVjdGl2ZSkge1xuICAgIHRoaXMuJHJlZ2lzdHJhdGlvbnMudXBkYXRlKCByZWdpc3RyYXRpb25zID0+ICBbLi4ucmVnaXN0cmF0aW9ucyxmaWx0ZXJdICk7XG4gIH1cbn1cbiJdfQ==
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQ29sdW1uSW5mby5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItdXRpbGl0aWVzL3NyYy90YWJsZS1idWlsZGVyL2ludGVyZmFjZXMvQ29sdW1uSW5mby50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ3VzdG9tQ2VsbERpcmVjdGl2ZSB9IGZyb20gXCIuLi9kaXJlY3RpdmVzL2N1c3RvbS1jZWxsLWRpcmVjdGl2ZVwiO1xuaW1wb3J0IHsgTWV0YURhdGEgfSBmcm9tIFwiLi9yZXBvcnQtZGVmXCI7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ29sdW1uSW5mbyB7XG4gIG1ldGFEYXRhOiBNZXRhRGF0YTtcbiAgY3VzdG9tQ2VsbDogQ3VzdG9tQ2VsbERpcmVjdGl2ZTtcbn1cbiJdfQ==
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQ29sdW1uSW5mby5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItdXRpbGl0aWVzL3NyYy90YWJsZS1idWlsZGVyL2ludGVyZmFjZXMvQ29sdW1uSW5mby50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ3VzdG9tQ2VsbERpcmVjdGl2ZSB9IGZyb20gXCIuLi9kaXJlY3RpdmVzL2N1c3RvbS1jZWxsLWRpcmVjdGl2ZVwiO1xuaW1wb3J0IHsgTWV0YURhdGEgfSBmcm9tIFwiLi9yZXBvcnQtZGVmXCI7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ29sdW1uSW5mbyB7XG4gIG1ldGFEYXRhOiBNZXRhRGF0YTtcbiAgY3VzdG9tQ2VsbD86IEN1c3RvbUNlbGxEaXJlY3RpdmU7XG59XG4iXX0=
@@ -2,7 +2,7 @@ import { DatePipe } from '@angular/common';
2
2
  import { Injectable, inject } from '@angular/core';
3
3
  import { first, map } from 'rxjs/operators';
4
4
  import { combineLatest } from 'rxjs';
5
- import { orderMetaData, TableStore } from '../classes/table-store';
5
+ import { orderStateMetaData, TableStore } from '../classes/table-store';
6
6
  import { TableBuilderConfigToken } from '../classes/TableBuilderConfig';
7
7
  import { downloadData } from '../functions/download-data';
8
8
  import { ArrayStyle, FieldType } from '../interfaces/report-def';
@@ -72,7 +72,7 @@ export class ExportToCsvService {
72
72
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: ExportToCsvService, decorators: [{
73
73
  type: Injectable
74
74
  }] });
75
- export const removeFromMetaData = (state, keysToRemove) => orderMetaData(state)
75
+ export const removeFromMetaData = (state, keysToRemove) => orderStateMetaData(state)
76
76
  .filter(meta => !keysToRemove.includes(meta.key));
77
77
  export const nonExportableFields = (state) => Object.values(state.metaData)
78
78
  .filter(md => md.noExport)
@@ -82,4 +82,4 @@ export const mapExportableFields = (state) => {
82
82
  .concat(state.hiddenKeys);
83
83
  return removeFromMetaData(state, fieldsToRemove);
84
84
  };
85
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"export-to-csv.service.js","sourceRoot":"","sources":["../../../../../projects/angular-utilities/src/table-builder/services/export-to-csv.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { DatePipe } from '@angular/common';\nimport { Injectable, inject } from '@angular/core';\nimport { Observable } from 'rxjs';\nimport { first, map  } from 'rxjs/operators';\nimport { combineLatest} from 'rxjs';\nimport { orderMetaData, TableStore } from '../classes/table-store';\nimport { TableBuilderConfigToken } from '../classes/TableBuilderConfig';\nimport { downloadData } from '../functions/download-data';\nimport { ArrayAdditional, ArrayStyle, FieldType, MetaData } from '../interfaces/report-def';\nimport { TableState } from '../classes/TableState';\nimport { isPipe } from './transform-creator';\nimport { get } from 'lodash';\n\n@Injectable()\nexport class ExportToCsvService<T> {\n  state = inject(TableStore);\n  private config = inject(TableBuilderConfigToken);\n  private datePipe = inject(DatePipe);\n\n\n  exportToCsv = (data: Observable<T[]>) => {\n    const exportableFields$ = this.state.state$.pipe(\n      map(mapExportableFields)\n    );\n\n    combineLatest([data,exportableFields$]).pipe(\n      first(),\n      map(([data,fields]) => this.csvData(data,fields)),\n    ).subscribe(csv => downloadData(csv,'export.csv','text/csv') );\n  }\n\n  csvData = (data:Array<T>, metaData: MetaData<T>[]) => {\n    const res = data.map(row => metaData.map(meta => this.metaToField(meta, row)).join(','));\n    res.unshift(metaData.map(meta => meta.displayName || meta.key).join(','));\n    return res.join('\\n');\n  }\n\n  metaToField = (meta: MetaData<T>, row: T) => {\n    let val: any = get( row,meta.key);\n    if (val == null && !meta.transform) return val\n    if(meta.transform && meta.fieldType !== FieldType.Expression){\n      const transform = meta.transform as any;\n      return  isPipe(transform) ? transform.transform(val) : transform(val);\n    }\n    if(meta.map){\n      return meta.map(row);\n    }\n    switch (meta.fieldType) {\n      case FieldType.Date:\n        const dateFormat = meta.additional?.export?.dateFormat || this.config?.export?.dateFormat || meta.additional?.dateFormat;\n        val = this.transform(val, dateFormat);\n        break;\n      case FieldType.DateTime:\n        const dateTimeFormat = meta.additional?.export?.dateTimeFormat || this.config?.export?.dateTimeFormat || meta.additional?.dateTimeOptions?.format;\n        val = this.transform(val, dateTimeFormat);\n        break;\n      case FieldType.String:\n        const prepend: string = meta.additional?.export?.prepend || this.config?.export?.prepend || '';\n        val = prepend + val;\n        break;\n      case FieldType.Array:\n        const additional = meta.additional as ArrayAdditional;\n        val = (val as Array<string>).slice(0,additional.limit).join(additional.arrayStyle === ArrayStyle.NewLine ? '\\n' : ', ');\n        break;\n      case FieldType.Expression:\n        val = (meta.transform as any)(row);\n        break;\n    }\n    if (typeof val === 'string' && (val.includes(',') || val.includes('\"') || val.includes('\\n'))) {\n      val = val.replaceAll('\"', '\"\"');\n      val = '\"' + val + '\"';\n    }\n    return val;\n  }\n\n  private transform(val: any, dateFormat: any) {\n    if (this.config.transformers && this.config.transformers[FieldType.Date]) {\n      return this.config.transformers[FieldType.Date]!(val);\n    }\n    return this.datePipe.transform(val, dateFormat);\n  }\n}\n\nexport const removeFromMetaData = (state: TableState, keysToRemove: string[]) =>\n    orderMetaData(state)\n  .filter( meta => !keysToRemove.includes(meta.key));\n\n\nexport const nonExportableFields = (state: TableState) => Object.values( state.metaData)\n  .filter(md => md.noExport )\n  .map( md => md.key );\n\nexport const mapExportableFields = (state: TableState) => {\n  const fieldsToRemove = nonExportableFields(state)\n    .concat(state.hiddenKeys);\n   return removeFromMetaData(state, fieldsToRemove);\n}\n"]}
85
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"export-to-csv.service.js","sourceRoot":"","sources":["../../../../../projects/angular-utilities/src/table-builder/services/export-to-csv.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { DatePipe } from '@angular/common';\nimport { Injectable, inject } from '@angular/core';\nimport { Observable } from 'rxjs';\nimport { first, map  } from 'rxjs/operators';\nimport { combineLatest} from 'rxjs';\nimport { orderStateMetaData, TableStore } from '../classes/table-store';\nimport { TableBuilderConfigToken } from '../classes/TableBuilderConfig';\nimport { downloadData } from '../functions/download-data';\nimport { ArrayAdditional, ArrayStyle, FieldType, MetaData } from '../interfaces/report-def';\nimport { TableState } from '../classes/TableState';\nimport { isPipe } from './transform-creator';\nimport { get } from 'lodash';\n\n@Injectable()\nexport class ExportToCsvService<T> {\n  state = inject(TableStore);\n  private config = inject(TableBuilderConfigToken);\n  private datePipe = inject(DatePipe);\n\n\n  exportToCsv = (data: Observable<T[]>) => {\n    const exportableFields$ = this.state.state$.pipe(\n      map(mapExportableFields)\n    );\n\n    combineLatest([data,exportableFields$]).pipe(\n      first(),\n      map(([data,fields]) => this.csvData(data,fields)),\n    ).subscribe(csv => downloadData(csv,'export.csv','text/csv') );\n  }\n\n  csvData = (data:Array<T>, metaData: MetaData<T>[]) => {\n    const res = data.map(row => metaData.map(meta => this.metaToField(meta, row)).join(','));\n    res.unshift(metaData.map(meta => meta.displayName || meta.key).join(','));\n    return res.join('\\n');\n  }\n\n  metaToField = (meta: MetaData<T>, row: T) => {\n    let val: any = get( row,meta.key);\n    if (val == null && !meta.transform) return val\n    if(meta.transform && meta.fieldType !== FieldType.Expression){\n      const transform = meta.transform as any;\n      return  isPipe(transform) ? transform.transform(val) : transform(val);\n    }\n    if(meta.map){\n      return meta.map(row);\n    }\n    switch (meta.fieldType) {\n      case FieldType.Date:\n        const dateFormat = meta.additional?.export?.dateFormat || this.config?.export?.dateFormat || meta.additional?.dateFormat;\n        val = this.transform(val, dateFormat);\n        break;\n      case FieldType.DateTime:\n        const dateTimeFormat = meta.additional?.export?.dateTimeFormat || this.config?.export?.dateTimeFormat || meta.additional?.dateTimeOptions?.format;\n        val = this.transform(val, dateTimeFormat);\n        break;\n      case FieldType.String:\n        const prepend: string = meta.additional?.export?.prepend || this.config?.export?.prepend || '';\n        val = prepend + val;\n        break;\n      case FieldType.Array:\n        const additional = meta.additional as ArrayAdditional;\n        val = (val as Array<string>).slice(0,additional.limit).join(additional.arrayStyle === ArrayStyle.NewLine ? '\\n' : ', ');\n        break;\n      case FieldType.Expression:\n        val = (meta.transform as any)(row);\n        break;\n    }\n    if (typeof val === 'string' && (val.includes(',') || val.includes('\"') || val.includes('\\n'))) {\n      val = val.replaceAll('\"', '\"\"');\n      val = '\"' + val + '\"';\n    }\n    return val;\n  }\n\n  private transform(val: any, dateFormat: any) {\n    if (this.config.transformers && this.config.transformers[FieldType.Date]) {\n      return this.config.transformers[FieldType.Date]!(val);\n    }\n    return this.datePipe.transform(val, dateFormat);\n  }\n}\n\nexport const removeFromMetaData = (state: TableState, keysToRemove: string[]) =>\n    orderStateMetaData(state)\n  .filter( meta => !keysToRemove.includes(meta.key));\n\n\nexport const nonExportableFields = (state: TableState) => Object.values( state.metaData)\n  .filter(md => md.noExport )\n  .map( md => md.key );\n\nexport const mapExportableFields = (state: TableState) => {\n  const fieldsToRemove = nonExportableFields(state)\n    .concat(state.hiddenKeys);\n   return removeFromMetaData(state, fieldsToRemove);\n}\n"]}