@one-paragon/angular-utilities 1.2.11 → 1.2.13

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 (26) hide show
  1. package/action-state/ngrx.d.ts +1 -1
  2. package/esm2022/table-builder/classes/TableBuilderDataSource.mjs +18 -27
  3. package/esm2022/table-builder/classes/table-builder.mjs +2 -2
  4. package/esm2022/table-builder/classes/table-store.mjs +9 -13
  5. package/esm2022/table-builder/components/column-builder/column-helpers.mjs +1 -3
  6. package/esm2022/table-builder/components/gen-col-displayer/gen-col-displayer.component.mjs +11 -17
  7. package/esm2022/table-builder/components/generic-table/generic-table.component.mjs +21 -20
  8. package/esm2022/table-builder/components/generic-table/paginator.component.mjs +58 -56
  9. package/esm2022/table-builder/components/table-container/table-container.mjs +55 -51
  10. package/esm2022/table-builder/components/table-container/virtual-scroll-container.mjs +57 -34
  11. package/esm2022/table-builder/directives/tb-filter.directive.mjs +10 -19
  12. package/esm2022/table-builder/services/export-to-csv.service.mjs +6 -16
  13. package/fesm2022/one-paragon-angular-utilities.mjs +239 -242
  14. package/fesm2022/one-paragon-angular-utilities.mjs.map +1 -1
  15. package/package.json +1 -1
  16. package/table-builder/classes/TableBuilderDataSource.d.ts +4 -4
  17. package/table-builder/classes/table-store.d.ts +5 -3
  18. package/table-builder/components/gen-col-displayer/gen-col-displayer.component.d.ts +5 -3
  19. package/table-builder/components/generic-table/generic-table.component.d.ts +3 -1
  20. package/table-builder/components/generic-table/paginator.component.d.ts +20 -19
  21. package/table-builder/components/table-container/table-container-imports.d.ts +2 -2
  22. package/table-builder/components/table-container/table-container.d.ts +10 -11
  23. package/table-builder/components/table-container/virtual-scroll-container.d.ts +15 -2
  24. package/table-builder/directives/table-wrapper.directive.d.ts +1 -1
  25. package/table-builder/directives/tb-filter.directive.d.ts +2 -3
  26. package/table-builder/services/export-to-csv.service.d.ts +1 -6
@@ -1,11 +1,12 @@
1
- import { ChangeDetectionStrategy, Component, effect, forwardRef, untracked, viewChild, inject } from '@angular/core';
1
+ import { ChangeDetectionStrategy, Component, effect, forwardRef, untracked, viewChild, inject, computed } from '@angular/core';
2
2
  import { CdkVirtualScrollViewport, ScrollingModule, VIRTUAL_SCROLL_STRATEGY, } from '@angular/cdk/scrolling';
3
- import { combineLatest, distinctUntilChanged, map } from 'rxjs';
4
- import { defaultShareReplay, subscriber } from '../../../rxjs';
3
+ import { switchMap } from 'rxjs';
4
+ import { notNull, 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
8
  import { DataStore } from '../../classes/data-store';
9
+ import { toObservable, toSignal } from '@angular/core/rxjs-interop';
9
10
  import * as i0 from "@angular/core";
10
11
  import * as i1 from "@angular/cdk/scrolling";
11
12
  export class VirtualScrollContainer {
@@ -14,47 +15,69 @@ export class VirtualScrollContainer {
14
15
  viewport = viewChild(CdkVirtualScrollViewport);
15
16
  defaultOptions = new VirtualScrollOptions();
16
17
  scrollStrategy = new TableVirtualScrollStrategy(this.computedRowHeight(), this.computedHeaderHeight());
17
- dataLength$ = combineLatest([this.state.state$, this.dataStore.state$]).pipe(map(([s, d]) => ({
18
- paginated: s.notPersistedTableSettings.usePaginator && !s.showAll,
19
- pageSize: s.userDefined?.pageSize || s.pageSize,
20
- pageNumber: s.currentPage,
21
- dataLen: d.dataLen
22
- })), distinctUntilChanged((a, b) => a.dataLen === b.dataLen &&
23
- a.pageSize === b.pageSize &&
24
- a.pageNumber === b.pageNumber &&
25
- a.paginated === b.paginated), map(({ dataLen, pageNumber, pageSize, paginated }) => {
18
+ $usePaginator = this.state.selectSignal(s => s.notPersistedTableSettings.usePaginator);
19
+ $pageSize = this.state.$pageSize;
20
+ $currentPage = this.state.$currentPage;
21
+ $showAll = this.state.selectSignal(s => s.showAll);
22
+ $stateDataLength = this.dataStore.selectSignal(s => s.dataLen);
23
+ $dataLength = computed(() => {
24
+ const paginated = this.$usePaginator() && !this.$showAll();
25
+ const pageSize = this.$pageSize();
26
+ const pageNumber = this.$currentPage();
27
+ const dataLen = this.$stateDataLength();
26
28
  if (paginated)
27
29
  return Math.min(dataLen - (pageNumber * pageSize), pageSize);
28
30
  return dataLen;
29
- }), distinctUntilChanged());
30
- subscriber = subscriber(this.dataLength$, (dataLength) => {
31
- this.scrollStrategy.setDataLength(dataLength);
32
- if (this.viewport()) {
33
- this.setSize(this.viewport().elementRef);
34
- }
35
31
  });
36
- _ = effect(() => {
32
+ constructor() {
33
+ addEventListener('resize', this.resizeHandler);
34
+ }
35
+ setViewportEffect = effect(() => {
37
36
  const viewport = this.viewport();
38
37
  untracked(() => {
39
38
  if (!!viewport) {
40
- addEventListener('resize', this.resizeHandler);
41
- this.subscriber.on(viewport.renderedRangeStream, (range) => {
42
- this.dataStore.patchState({
43
- virtualEnds: {
44
- start: range.start,
45
- end: range.end + 25,
46
- }
47
- });
48
- });
49
- var offset$ = viewport.scrolledIndexChange.pipe(map(() => viewport.getOffsetToRenderedContentStart() ?? 0), distinctUntilChanged(), defaultShareReplay());
50
- this.subscriber.on(offset$, (offset) => {
51
- this.dataStore.patchState({ virtualScrollOffset: offset });
52
- });
53
39
  this.setSize(this.viewport().elementRef);
54
40
  }
55
41
  ;
56
42
  });
57
43
  });
44
+ subscriber = subscriber();
45
+ onRenderedRangeEffect = effect(() => {
46
+ const renderedRange = this.$renderedRange();
47
+ if (!renderedRange)
48
+ return;
49
+ untracked(() => {
50
+ this.dataStore.patchState({
51
+ virtualEnds: {
52
+ start: renderedRange.start,
53
+ end: renderedRange.end + 25,
54
+ }
55
+ });
56
+ this.setSize(this.viewport().elementRef);
57
+ });
58
+ });
59
+ onDataLengthEffect = effect(() => {
60
+ const dataLength = this.$dataLength();
61
+ untracked(() => {
62
+ this.scrollStrategy.setDataLength(dataLength);
63
+ });
64
+ });
65
+ onOffsetEffect = effect(() => {
66
+ const offset = this.$offset();
67
+ untracked(() => {
68
+ this.dataStore.patchState({ virtualScrollOffset: offset });
69
+ });
70
+ });
71
+ viewPort$ = toObservable(this.viewport).pipe(notNull());
72
+ $scrolledIndexChange = toSignal(this.viewPort$.pipe(switchMap(v => v.scrolledIndexChange)));
73
+ $renderedRange = toSignal(this.viewPort$.pipe(switchMap(v => v.renderedRangeStream)));
74
+ $offset = computed(() => {
75
+ const viewport = this.viewport();
76
+ const scrolledIndexChange = this.$scrolledIndexChange();
77
+ if (!scrolledIndexChange || !viewport)
78
+ return 0;
79
+ return viewport.getOffsetToRenderedContentStart() ?? 0;
80
+ });
58
81
  ngOnDestroy() {
59
82
  removeEventListener('resize', this.resizeHandler);
60
83
  }
@@ -124,5 +147,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImpor
124
147
  },
125
148
  ],
126
149
  }]
127
- }] });
128
- //# 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';\r\nimport {\r\n  CdkVirtualScrollViewport,\r\n  ScrollingModule,\r\n  VIRTUAL_SCROLL_STRATEGY,\r\n} from '@angular/cdk/scrolling';\r\nimport { combineLatest, distinctUntilChanged, map } from 'rxjs';\r\nimport { defaultShareReplay, subscriber } from '../../../rxjs';\r\nimport { TableStore } from '../../classes/table-store';\r\nimport { TableVirtualScrollStrategy } from '../scroll-strategy';\r\nimport { VirtualScrollOptions } from '../../classes/table-builder-general-settings';\r\nimport { DataStore } from '../../classes/data-store';\r\n\r\n@Component({\r\n  selector: 'tb-virtual-scroll-container',\r\n  template: `\r\n    <cdk-virtual-scroll-viewport>\r\n      <ng-content/>\r\n    </cdk-virtual-scroll-viewport>\r\n    `,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  standalone: true,\r\n  imports: [ScrollingModule],\r\n  viewProviders: [\r\n    {\r\n      provide: VIRTUAL_SCROLL_STRATEGY,\r\n      useFactory: (c: VirtualScrollContainer) => c.scrollStrategy,\r\n      deps: [forwardRef(() => VirtualScrollContainer)],\r\n    },\r\n  ],\r\n})\r\nexport class VirtualScrollContainer implements  OnDestroy {\r\n  private state = inject(TableStore);\r\n  private dataStore = inject(DataStore); \r\n\r\n  viewport = viewChild(CdkVirtualScrollViewport);\r\n\r\n  defaultOptions = new VirtualScrollOptions();\r\n  scrollStrategy = new TableVirtualScrollStrategy(\r\n    this.computedRowHeight(),\r\n    this.computedHeaderHeight()\r\n    );\r\n\r\n\r\n  dataLength$ = combineLatest([this.state.state$, this.dataStore.state$]).pipe(\r\n    map(([s, d]) => ({\r\n      paginated: s.notPersistedTableSettings.usePaginator && !s.showAll,\r\n      pageSize: s.userDefined?.pageSize || s.pageSize,\r\n      pageNumber: s.currentPage,\r\n      dataLen: d.dataLen\r\n    })),\r\n    distinctUntilChanged((a, b) =>\r\n      a.dataLen === b.dataLen &&\r\n      a.pageSize === b.pageSize &&\r\n      a.pageNumber === b.pageNumber &&\r\n      a.paginated === b.paginated),\r\n    map(({dataLen, pageNumber, pageSize, paginated}) => {\r\n      if(paginated) return Math.min(dataLen - (pageNumber * pageSize), pageSize);\r\n      return dataLen;\r\n    }),\r\n    distinctUntilChanged()\r\n  );\r\n\r\n\r\n  subscriber = subscriber(this.dataLength$, (dataLength) => {\r\n    this.scrollStrategy.setDataLength(dataLength);\r\n\r\n    if(this.viewport()){\r\n      this.setSize(this.viewport()!.elementRef);\r\n    }\r\n  });\r\n\r\n\r\n  _ = effect(() => {\r\n    const viewport = this.viewport();\r\n    untracked(() => {\r\n      if(!!viewport){\r\n        addEventListener('resize', this.resizeHandler);\r\n        this.subscriber.on(viewport.renderedRangeStream, (range) => {\r\n          this.dataStore.patchState({\r\n            virtualEnds: {\r\n              start: range.start,\r\n              end: range.end + 25,\r\n            }\r\n          });\r\n        });\r\n        var offset$ = viewport.scrolledIndexChange.pipe(\r\n          map(() => viewport.getOffsetToRenderedContentStart() ?? 0),\r\n          distinctUntilChanged(),\r\n          defaultShareReplay()\r\n        );\r\n    \r\n        this.subscriber.on(offset$, (offset) => {\r\n          this.dataStore.patchState({ virtualScrollOffset: offset });\r\n        });\r\n        this.setSize(this.viewport()!.elementRef);\r\n      };\r\n    })\r\n\r\n  })\r\n\r\n\r\n  ngOnDestroy(): void {\r\n    removeEventListener('resize', this.resizeHandler);\r\n  }\r\n\r\n  setSize(el: ElementRef<HTMLElement>) {\r\n    const vsViewport = el.nativeElement;\r\n    const virtualScrollOptions = this.state.tableSettings().useVirtualScroll! as VirtualScrollOptions;\r\n    const rowHeight = this.computedRowHeight();\r\n    let amountOfVisibleItems = virtualScrollOptions?.amountOfVisibleItems || this.defaultOptions.amountOfVisibleItems;\r\n      virtualScrollOptions?.amountOfVisibleItems || this.defaultOptions.amountOfVisibleItems;\r\n    let height = (rowHeight * amountOfVisibleItems);\r\n    if(!this.state.tableSettings().hideHeader){\r\n      const headerHeight = this.computedHeaderHeight();\r\n      height += headerHeight;\r\n    }\r\n    if(virtualScrollOptions?.maxViewPortHeight && virtualScrollOptions.maxViewPortHeight < height) height = virtualScrollOptions.maxViewPortHeight;\r\n    vsViewport.setAttribute(\r\n      'style',\r\n      `height: ${height}px !important;`,\r\n    );\r\n    this.viewport()?.checkViewportSize();\r\n    const virtualScrollOffset = this.viewport()?.getOffsetToRenderedContentStart() ?? 0\r\n    this.dataStore.patchState({ virtualScrollOffset });\r\n  }\r\n\r\n  resizeHandler = () => {\r\n    if (this.viewport()) {\r\n      this.setSize(this.viewport()!.elementRef);\r\n    }\r\n  };\r\n\r\n  computedRowHeight(){\r\n    const virtualScrollOptions = this.state.tableSettings().useVirtualScroll! as VirtualScrollOptions;\r\n    const rowHeight = virtualScrollOptions?.rowHeight|| (typeof this.state.tableSettings().rowHeight === 'number' && this.state.tableSettings().rowHeight as number) || this.defaultOptions.rowHeight;\r\n    return rowHeight;\r\n  }\r\n\r\n  computedHeaderHeight(){\r\n    const virtualScrollOptions = this.state.tableSettings().useVirtualScroll! as VirtualScrollOptions;\r\n    const headerHeight = virtualScrollOptions?.headerHeight|| (typeof  this.state.tableSettings().headerHeight === 'number' && this.state.tableSettings().headerHeight as number) || this.defaultOptions.headerHeight;\r\n    return headerHeight;\r\n  }\r\n}\r\n"]}
150
+ }], ctorParameters: () => [] });
151
+ //# 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, computed } from '@angular/core';\r\nimport {\r\n  CdkVirtualScrollViewport,\r\n  ScrollingModule,\r\n  VIRTUAL_SCROLL_STRATEGY,\r\n} from '@angular/cdk/scrolling';\r\nimport { switchMap } from 'rxjs';\r\nimport { notNull, subscriber } from '../../../rxjs';\r\nimport { TableStore } from '../../classes/table-store';\r\nimport { TableVirtualScrollStrategy } from '../scroll-strategy';\r\nimport { VirtualScrollOptions } from '../../classes/table-builder-general-settings';\r\nimport { DataStore } from '../../classes/data-store';\r\nimport { toObservable, toSignal } from '@angular/core/rxjs-interop';\r\n\r\n@Component({\r\n  selector: 'tb-virtual-scroll-container',\r\n  template: `\r\n    <cdk-virtual-scroll-viewport>\r\n      <ng-content/>\r\n    </cdk-virtual-scroll-viewport>\r\n    `,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  standalone: true,\r\n  imports: [ScrollingModule],\r\n  viewProviders: [\r\n    {\r\n      provide: VIRTUAL_SCROLL_STRATEGY,\r\n      useFactory: (c: VirtualScrollContainer) => c.scrollStrategy,\r\n      deps: [forwardRef(() => VirtualScrollContainer)],\r\n    },\r\n  ],\r\n})\r\nexport class VirtualScrollContainer implements  OnDestroy {\r\n  private state = inject(TableStore);\r\n  private dataStore = inject(DataStore); \r\n\r\n  viewport = viewChild(CdkVirtualScrollViewport);\r\n\r\n  defaultOptions = new VirtualScrollOptions();\r\n  scrollStrategy = new TableVirtualScrollStrategy(\r\n    this.computedRowHeight(),\r\n    this.computedHeaderHeight()\r\n    );\r\n\r\n  $usePaginator = this.state.selectSignal(s => s.notPersistedTableSettings.usePaginator);\r\n  $pageSize = this.state.$pageSize;\r\n  $currentPage = this.state.$currentPage;\r\n  $showAll = this.state.selectSignal(s => s.showAll);\r\n  $stateDataLength = this.dataStore.selectSignal(s => s.dataLen);\r\n  $dataLength  = computed(() => {\r\n    const paginated = this.$usePaginator() && !this.$showAll();\r\n    const pageSize = this.$pageSize();\r\n    const pageNumber = this.$currentPage();\r\n    const dataLen = this.$stateDataLength();\r\n    if(paginated) return Math.min(dataLen - (pageNumber * pageSize), pageSize);\r\n    return dataLen;\r\n  });\r\n  constructor() {\r\n    addEventListener('resize', this.resizeHandler);\r\n  }\r\n  setViewportEffect = effect(() => {\r\n    const viewport = this.viewport();\r\n    untracked(() => {\r\n      if(!!viewport){\r\n        this.setSize(this.viewport()!.elementRef);\r\n      };\r\n    })\r\n  })\r\n\r\n  subscriber = subscriber();\r\n\r\n  onRenderedRangeEffect = effect(() => {\r\n    const renderedRange = this.$renderedRange();\r\n    if(!renderedRange) return;\r\n    untracked(() => {\r\n      this.dataStore.patchState({\r\n        virtualEnds: {\r\n          start: renderedRange.start,\r\n          end: renderedRange.end + 25,\r\n        }});\r\n      this.setSize(this.viewport()!.elementRef);\r\n    })\r\n  })\r\n\r\n  onDataLengthEffect = effect(() => {\r\n    const dataLength = this.$dataLength();\r\n    untracked(() => {\r\n      this.scrollStrategy.setDataLength(dataLength);\r\n    })\r\n  })\r\n\r\n  onOffsetEffect = effect(() => {\r\n    const offset = this.$offset();\r\n    untracked(() => {\r\n      this.dataStore.patchState({ virtualScrollOffset: offset });\r\n    })\r\n  })\r\n  viewPort$ = toObservable(this.viewport).pipe(notNull());\r\n  $scrolledIndexChange = toSignal(this.viewPort$.pipe(switchMap(v => v.scrolledIndexChange)));\r\n  $renderedRange = toSignal(this.viewPort$.pipe(switchMap(v => v.renderedRangeStream)));\r\n\r\n  $offset = computed(() => {\r\n    const viewport = this.viewport();\r\n    const scrolledIndexChange = this.$scrolledIndexChange();\r\n    if(!scrolledIndexChange || !viewport) return 0;\r\n    return viewport.getOffsetToRenderedContentStart() ?? 0;\r\n  })\r\n\r\n  ngOnDestroy(): void {\r\n    removeEventListener('resize', this.resizeHandler);\r\n  }\r\n\r\n  setSize(el: ElementRef<HTMLElement>) {\r\n    const vsViewport = el.nativeElement;\r\n    const virtualScrollOptions = this.state.tableSettings().useVirtualScroll! as VirtualScrollOptions;\r\n    const rowHeight = this.computedRowHeight();\r\n    let amountOfVisibleItems = virtualScrollOptions?.amountOfVisibleItems || this.defaultOptions.amountOfVisibleItems;\r\n      virtualScrollOptions?.amountOfVisibleItems || this.defaultOptions.amountOfVisibleItems;\r\n    let height = (rowHeight * amountOfVisibleItems);\r\n    if(!this.state.tableSettings().hideHeader){\r\n      const headerHeight = this.computedHeaderHeight();\r\n      height += headerHeight;\r\n    }\r\n    if(virtualScrollOptions?.maxViewPortHeight && virtualScrollOptions.maxViewPortHeight < height) height = virtualScrollOptions.maxViewPortHeight;\r\n    vsViewport.setAttribute(\r\n      'style',\r\n      `height: ${height}px !important;`,\r\n    );\r\n    this.viewport()?.checkViewportSize();\r\n    const virtualScrollOffset = this.viewport()?.getOffsetToRenderedContentStart() ?? 0\r\n    this.dataStore.patchState({ virtualScrollOffset });\r\n  }\r\n\r\n  resizeHandler = () => {\r\n    if (this.viewport()) {\r\n      this.setSize(this.viewport()!.elementRef);\r\n    }\r\n  };\r\n\r\n  computedRowHeight(){\r\n    const virtualScrollOptions = this.state.tableSettings().useVirtualScroll! as VirtualScrollOptions;\r\n    const rowHeight = virtualScrollOptions?.rowHeight|| (typeof this.state.tableSettings().rowHeight === 'number' && this.state.tableSettings().rowHeight as number) || this.defaultOptions.rowHeight;\r\n    return rowHeight;\r\n  }\r\n\r\n  computedHeaderHeight(){\r\n    const virtualScrollOptions = this.state.tableSettings().useVirtualScroll! as VirtualScrollOptions;\r\n    const headerHeight = virtualScrollOptions?.headerHeight|| (typeof  this.state.tableSettings().headerHeight === 'number' && this.state.tableSettings().headerHeight as number) || this.defaultOptions.headerHeight;\r\n    return headerHeight;\r\n  }\r\n}\r\n"]}
@@ -1,5 +1,5 @@
1
1
  import { Directive, Input, inject } from "@angular/core";
2
- import { BehaviorSubject, ReplaySubject, takeUntil, tap } from "rxjs";
2
+ import { BehaviorSubject, ReplaySubject, Subject, takeUntil, tap } from "rxjs";
3
3
  import { v4 as uuid } from 'uuid';
4
4
  import { FilterTypes } from "../enums/filterTypes";
5
5
  import { MatSlideToggle } from "@angular/material/slide-toggle";
@@ -8,9 +8,9 @@ import { MatButtonToggle } from '@angular/material/button-toggle';
8
8
  import { MatCheckbox } from "@angular/material/checkbox";
9
9
  import { FieldType } from "../interfaces/report-def";
10
10
  import { NgControl } from "@angular/forms";
11
- import { ComponentStore } from "@ngrx/component-store";
12
11
  import { TableWrapperDirective } from "./table-wrapper.directive";
13
12
  import { MatOption } from "@angular/material/core";
13
+ import { subscriber } from "../../rxjs";
14
14
  import * as i0 from "@angular/core";
15
15
  import * as i1 from "rxjs";
16
16
  const inputs = [
@@ -30,27 +30,24 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImpor
30
30
  selector: ' '
31
31
  }]
32
32
  }] });
33
- export class TableFilterDirective extends ComponentStore {
33
+ export class TableFilterDirective {
34
34
  model = inject(NgControl, { optional: true });
35
35
  wrapper = inject(TableWrapperDirective, { optional: true });
36
36
  constructor() {
37
- super();
38
37
  if (this.wrapper) {
39
38
  this.wrapper.register(this);
40
39
  }
41
40
  if (this.model) {
42
- this.effect(() => {
43
- return this.model.valueChanges.pipe(tap(val => {
44
- this.filterValue = val;
45
- this.update();
46
- }));
41
+ subscriber(this.model.valueChanges, val => {
42
+ this.filterValue = val;
43
+ this.update();
47
44
  });
48
45
  }
49
46
  }
50
47
  reset() {
51
48
  this.filterValue = undefined;
52
49
  }
53
- filter$ = this.state$;
50
+ filter$ = new Subject;
54
51
  filterType;
55
52
  key;
56
53
  fieldType;
@@ -85,7 +82,7 @@ export class TableFilterDirective extends ComponentStore {
85
82
  this.update();
86
83
  }
87
84
  setFilter(filter) {
88
- this.setState(filter);
85
+ this.filter$.next(filter);
89
86
  }
90
87
  update() {
91
88
  if (this.ready) {
@@ -101,7 +98,7 @@ export class TableFilterDirective extends ComponentStore {
101
98
  }
102
99
  }
103
100
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: TableFilterDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
104
- static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.2", type: TableFilterDirective, isStandalone: true, selector: "[tbFilter]", inputs: { filterType: "filterType", key: "key", fieldType: "fieldType", filterId: "filterId", active: "active", filterValue: "filterValue" }, usesInheritance: true, usesOnChanges: true, ngImport: i0 });
101
+ static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.2", type: TableFilterDirective, isStandalone: true, selector: "[tbFilter]", inputs: { filterType: "filterType", key: "key", fieldType: "fieldType", filterId: "filterId", active: "active", filterValue: "filterValue" }, usesOnChanges: true, ngImport: i0 });
105
102
  }
106
103
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: TableFilterDirective, decorators: [{
107
104
  type: Directive,
@@ -127,12 +124,6 @@ export class TableFilterStringContainsDirective extends TableFilterDirective {
127
124
  super();
128
125
  this.filterType = FilterTypes.StringContains;
129
126
  this.fieldType = FieldType.String;
130
- this.effect(() => {
131
- return this.model.valueChanges.pipe(tap(val => {
132
- this.filterValue = val;
133
- this.update();
134
- }));
135
- });
136
127
  }
137
128
  reset() {
138
129
  if (this.model) {
@@ -402,4 +393,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImpor
402
393
  standalone: true,
403
394
  }]
404
395
  }], ctorParameters: () => [] });
405
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tb-filter.directive.js","sourceRoot":"","sources":["../../../../../projects/angular-utilities/src/table-builder/directives/tb-filter.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, Input, Predicate, SimpleChanges, inject } from \"@angular/core\";\r\nimport { BehaviorSubject, Observable, ReplaySubject, Subject, takeUntil, tap } from \"rxjs\";\r\nimport { CustomFilter, FilterInfo } from \"../classes/filter-info\";\r\nimport { v4 as uuid } from 'uuid';\r\nimport { FilterType, FilterTypes } from \"../enums/filterTypes\";\r\nimport { MatSlideToggle } from \"@angular/material/slide-toggle\";\r\nimport { MatRadioButton } from \"@angular/material/radio\";\r\nimport { MatButtonToggle } from '@angular/material/button-toggle';\r\nimport { MatCheckbox } from \"@angular/material/checkbox\";\r\nimport { FieldType } from \"../interfaces/report-def\";\r\nimport { NgControl } from \"@angular/forms\";\r\nimport { ComponentStore } from \"@ngrx/component-store\";\r\nimport { TableWrapperDirective } from \"./table-wrapper.directive\";\r\nimport { MatOption } from \"@angular/material/core\";\r\n\r\n\r\nconst inputs = [\r\n  'predicate: tbCustomFilter',\r\n  'filterId: filterId',\r\n];\r\n\r\n\r\n@Directive({\r\n  selector: ' '\r\n})\r\nexport abstract class TableCustomFilterDirective<T = any> {\r\n  abstract filter$ : Observable<CustomFilter>;\r\n  filterId!: string;\r\n  savable = false;\r\n  used = false;\r\n  abstract active: boolean;\r\n  abstract reset(): void;\r\n}\r\n\r\n\r\n\r\n\r\n@Directive({\r\n  selector: \"[tbFilter]\",\r\n  standalone: true,\r\n}) export class TableFilterDirective extends ComponentStore<FilterInfo> {\r\n  protected model = inject(NgControl, { optional: true });\r\n  private wrapper = inject(TableWrapperDirective, { optional: true });\r\n  constructor() {\r\n    super();\r\n    if(this.wrapper) {\r\n      this.wrapper.register(this);\r\n    }\r\n    if(this.model) {\r\n      this.effect( () => {\r\n        return this.model!.valueChanges!.pipe(\r\n          tap( val => {\r\n            this.filterValue = val;\r\n            this.update();\r\n          })\r\n        )\r\n      })\r\n    }\r\n  }\r\n  reset() {\r\n    this.filterValue = undefined;\r\n  }\r\n  filter$ = this.state$;\r\n\r\n  @Input() filterType!: FilterType;\r\n  @Input() key!: string;\r\n  @Input() fieldType!: FieldType;\r\n  @Input() filterId!: string;\r\n  @Input() active = true;\r\n  @Input() filterValue: any = null;\r\n\r\n  setFilterValue(value: any) {\r\n    if(this.model) {\r\n      setTimeout(() => {\r\n        this.model!.reset(value);\r\n      }, 0);\r\n    } else {\r\n      this.filterValue = value;\r\n    }\r\n  }\r\n\r\n  used = false;\r\n  savable = false;\r\n  ready = false;\r\n\r\n  _userActive = true;\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    this.update();\r\n  }\r\n\r\n  ngOnInit() {\r\n    if(!this.filterId) {\r\n      this.filterId = uuid();\r\n    } else {\r\n      this.savable = true;\r\n    }\r\n    this.ready = true;\r\n    this.update();\r\n  }\r\n\r\n  protected setFilter(filter: FilterInfo ) {\r\n    this.setState(filter);\r\n  }\r\n\r\n  update() {\r\n    if (this.ready) {\r\n      this.setFilter(\r\n        {\r\n          filterId: this.filterId,\r\n          key: this.key,\r\n          filterType: this.filterType,\r\n          fieldType: this.fieldType,\r\n          filterValue: this.filterValue,\r\n          active: this.active && this.filterValue !== undefined,\r\n          _isExternallyManaged: true,\r\n        }\r\n      );\r\n\r\n    }\r\n  }\r\n}\r\n\r\n@Directive({\r\n  selector: '[tbFilterStringContains]',\r\n  providers: [{ provide: TableFilterDirective, useExisting: TableFilterStringContainsDirective }],\r\n  inputs: [\r\n    'key:tbFilterStringContains',\r\n    'filterValue:filterValue',\r\n    'filterId: filterId',\r\n    'active: active',\r\n  ],\r\n  standalone: true,\r\n}) export class TableFilterStringContainsDirective extends TableFilterDirective {\r\n  constructor() {\r\n\r\n    super();\r\n    this.filterType = FilterTypes.StringContains;\r\n    this.fieldType = FieldType.String;\r\n    this.effect( () => {\r\n      return this.model!.valueChanges!.pipe(\r\n        tap( val => {\r\n          this.filterValue = val;\r\n          this.update();\r\n        })\r\n      )\r\n    })\r\n  }\r\n\r\n  override reset() {\r\n    if(this.model) {\r\n      this.model.reset();\r\n    }\r\n    super.reset();\r\n  }\r\n\r\n  override setFilter(filter: FilterInfo) {\r\n    filter.active = filter.filterValue && this._userActive;\r\n    super.setFilter(filter);\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    if(changes['active']) {\r\n      this._userActive = changes['active'].currentValue;\r\n    }\r\n    super.ngOnChanges(changes);\r\n  }\r\n}\r\n\r\n@Directive({\r\n  selector: \"[tbCustomFilter]\",\r\n})\r\nexport abstract class TableCustomFilterDirectiveBase<T = any> extends TableCustomFilterDirective<T> {\r\n\r\n  filter$! : Subject<CustomFilter>;\r\n  filter!: CustomFilter;\r\n\r\n  _predicate!: Predicate<T>;\r\n  @Input('tbCustomFilter') set predicate( val: Predicate<T> ) {\r\n    this._predicate = val;\r\n    this.update({predicate:val});\r\n  }\r\n\r\n  _active: boolean = false;\r\n  ready = false;\r\n\r\n  update(val: Partial<CustomFilter> ) {\r\n    if(this.ready) {\r\n      this.filter = {...this.filter,...val};\r\n      this.filter$.next(this.filter);\r\n    }\r\n  }\r\n\r\n  @Input() set active(val: boolean) {\r\n    if(this._active !== val) {\r\n      this._active = val;\r\n      this.update({active:val});\r\n    }\r\n  }\r\n  get active(): boolean {\r\n    return this._active;\r\n  }\r\n\r\n  ngOnInit() {\r\n    if(!this.filterId) {\r\n      this.filterId = uuid();\r\n    } else {\r\n      this.savable = true;\r\n    }\r\n\r\n    this.filter = {\r\n      filterType: FilterTypes.Custom,\r\n      filterId: this.filterId,\r\n      active: this._active,\r\n      predicate: this._predicate,\r\n    };\r\n    this.ready = true;\r\n    this.filter$ = new BehaviorSubject(this.filter);\r\n  }\r\n}\r\n\r\n@Directive()\r\nexport abstract class TbSelectedFilterDirective<T = any>  extends TableCustomFilterDirectiveBase<T> {\r\n\r\n  protected wrapper = inject(TableWrapperDirective, { optional: true });\r\n  protected constructor(private change: Observable<any>, private isActive: () => boolean) {\r\n    super();\r\n    if(this.wrapper) {\r\n      this.wrapper.register(this);\r\n    }\r\n  }\r\n\r\n  reset() {\r\n    this.active = false;\r\n  }\r\n\r\n  destroySubject$ = new ReplaySubject<void>(1);\r\n  ngOnDestroy() {\r\n    this.destroySubject$.next();\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this._active = this.isActive();\r\n    super.ngOnInit();\r\n    this.change.pipe(takeUntil(this.destroySubject$)).subscribe( () => {\r\n      this.active = this.isActive();\r\n    });\r\n  }\r\n}\r\n\r\n// Checkbox\r\n@Directive({\r\n  selector: 'mat-checkbox[tbCustomFilter]',\r\n  inputs: [\r\n    ...inputs\r\n  ],\r\n  providers: [{ provide: TableCustomFilterDirective, useExisting: MatCheckboxTbFilterDirective }],\r\n  standalone: true,\r\n})\r\nexport class MatCheckboxTbFilterDirective extends TbSelectedFilterDirective {\r\n  private matCheckbox = inject(MatCheckbox);\r\n\r\n\r\n  override set active(val: boolean) {\r\n    this.matCheckbox.checked = val;\r\n    super.active = val;\r\n  }\r\n  constructor() {\r\n    const matCheckbox = inject(MatCheckbox);\r\n    super(matCheckbox.change, () => matCheckbox.checked);\r\n    this.matCheckbox = matCheckbox;\r\n  }\r\n}\r\n\r\n\r\n@Directive({\r\n  selector: 'mat-slide-toggle[tbCustomFilter]',\r\n  inputs: [\r\n    ...inputs\r\n  ],\r\n  providers: [{ provide: TableCustomFilterDirective, useExisting: MatSlideToggleTbFilterDirective }],\r\n  standalone: true,\r\n})\r\nexport class MatSlideToggleTbFilterDirective<T = any> extends TbSelectedFilterDirective<T> {\r\n  private matSlideToggle: MatSlideToggle;\r\n\r\n  override set active(val: boolean) {\r\n    this.matSlideToggle.checked = val;\r\n    super.active = val;\r\n  }\r\n  constructor() {\r\n    const matSlideToggle = inject(MatSlideToggle);\r\n\r\n    super(matSlideToggle.change, () => matSlideToggle.checked);\r\n    this.matSlideToggle = matSlideToggle;\r\n\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    super.ngOnInit();\r\n  }\r\n}\r\n\r\n// Radio button\r\n@Directive({\r\n  selector: 'mat-radio-button[tbCustomFilter]',\r\n  inputs: ['predicate: tbCustomFilter'],\r\n  providers: [{ provide: TableCustomFilterDirective, useExisting: MatRadioButtonTbFilterDirective }],\r\n  standalone: true,\r\n})\r\nexport class MatRadioButtonTbFilterDirective extends TbSelectedFilterDirective {\r\n  private matRadioButton: MatRadioButton;\r\n\r\n\r\n  override set active(val: boolean) {\r\n    this.matRadioButton.checked = val;\r\n    super.active = val;\r\n  }\r\n  constructor() {\r\n    const matRadioButton = inject(MatRadioButton);\r\n\r\n    super(matRadioButton.change, () => matRadioButton.checked);\r\n    this.matRadioButton = matRadioButton;\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    super.ngOnInit();\r\n  }\r\n}\r\n\r\n// Option (select)\r\n@Directive({\r\n  selector: 'mat-option[tbCustomFilter]',\r\n  inputs: [\r\n    ...inputs\r\n  ],\r\n  providers: [{ provide: TableCustomFilterDirective, useExisting: MatOptionTbFilterDirective }],\r\n  standalone: true,\r\n})\r\nexport class MatOptionTbFilterDirective extends TbSelectedFilterDirective {\r\n  private matOption: MatOption;\r\n\r\n\r\n  override set active(val: boolean) {\r\n    if(val) {\r\n      this.matOption.select();\r\n    } else {\r\n      this.matOption.deselect();\r\n    }\r\n    super.active = val;\r\n  }\r\n  constructor() {\r\n    const matOption = inject(MatOption);\r\n\r\n    super( matOption.onSelectionChange.pipe(tap( d => {\r\n      if(!matOption.value) {\r\n        matOption.value = uuid();\r\n      }\r\n    }\r\n\r\n    )), () => matOption.selected);\r\n    this.matOption = matOption;\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    super.ngOnInit();\r\n  }\r\n}\r\n\r\n// Button toggle\r\n@Directive({\r\n  selector: 'mat-button-toggle[tbCustomFilter]',\r\n  inputs: [\r\n    ...inputs\r\n  ],\r\n  providers: [{ provide: TableCustomFilterDirective, useExisting: MatButtonToggleFilterDirective }],\r\n  standalone: true,\r\n})\r\nexport class MatButtonToggleFilterDirective extends TbSelectedFilterDirective {\r\n  private matButtonToggle: MatButtonToggle;\r\n\r\n  override set active(val: boolean) {\r\n    this.matButtonToggle.checked = val;\r\n    super.active = val;\r\n  }\r\n  constructor() {\r\n    const matButtonToggle = inject(MatButtonToggle);\r\n\r\n    super(matButtonToggle.change, () => matButtonToggle.checked);\r\n    this.matButtonToggle = matButtonToggle;\r\n\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    super.ngOnInit();\r\n  }\r\n}\r\n"]}
396
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tb-filter.directive.js","sourceRoot":"","sources":["../../../../../projects/angular-utilities/src/table-builder/directives/tb-filter.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, Input, Predicate, SimpleChanges, inject } from \"@angular/core\";\r\nimport { BehaviorSubject, Observable, ReplaySubject, Subject, takeUntil, tap } from \"rxjs\";\r\nimport { CustomFilter, FilterInfo } from \"../classes/filter-info\";\r\nimport { v4 as uuid } from 'uuid';\r\nimport { FilterType, FilterTypes } from \"../enums/filterTypes\";\r\nimport { MatSlideToggle } from \"@angular/material/slide-toggle\";\r\nimport { MatRadioButton } from \"@angular/material/radio\";\r\nimport { MatButtonToggle } from '@angular/material/button-toggle';\r\nimport { MatCheckbox } from \"@angular/material/checkbox\";\r\nimport { FieldType } from \"../interfaces/report-def\";\r\nimport { NgControl } from \"@angular/forms\";\r\nimport { TableWrapperDirective } from \"./table-wrapper.directive\";\r\nimport { MatOption } from \"@angular/material/core\";\r\nimport { subscriber } from \"../../rxjs\";\r\n\r\n\r\nconst inputs = [\r\n  'predicate: tbCustomFilter',\r\n  'filterId: filterId',\r\n];\r\n\r\n\r\n@Directive({\r\n  selector: ' '\r\n})\r\nexport abstract class TableCustomFilterDirective<T = any> {\r\n  abstract filter$ : Observable<CustomFilter>;\r\n  filterId!: string;\r\n  savable = false;\r\n  used = false;\r\n  abstract active: boolean;\r\n  abstract reset(): void;\r\n}\r\n\r\n\r\n\r\n\r\n@Directive({\r\n  selector: \"[tbFilter]\",\r\n  standalone: true,\r\n}) export class TableFilterDirective {\r\n  protected model = inject(NgControl, { optional: true });\r\n  private wrapper = inject(TableWrapperDirective, { optional: true });\r\n  constructor() {\r\n    if(this.wrapper) {\r\n      this.wrapper.register(this);\r\n    }\r\n    if(this.model) {\r\n      subscriber(this.model!.valueChanges!, val => {\r\n        this.filterValue = val;\r\n        this.update();\r\n      })\r\n    }\r\n  }\r\n  reset() {\r\n    this.filterValue = undefined;\r\n  }\r\n  filter$ = new Subject<FilterInfo>;\r\n\r\n  @Input() filterType!: FilterType;\r\n  @Input() key!: string;\r\n  @Input() fieldType!: FieldType;\r\n  @Input() filterId!: string;\r\n  @Input() active = true;\r\n  @Input() filterValue: any = null;\r\n\r\n  setFilterValue(value: any) {\r\n    if(this.model) {\r\n      setTimeout(() => {\r\n        this.model!.reset(value);\r\n      }, 0);\r\n    } else {\r\n      this.filterValue = value;\r\n    }\r\n  }\r\n\r\n  used = false;\r\n  savable = false;\r\n  ready = false;\r\n\r\n  _userActive = true;\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    this.update();\r\n  }\r\n\r\n  ngOnInit() {\r\n    if(!this.filterId) {\r\n      this.filterId = uuid();\r\n    } else {\r\n      this.savable = true;\r\n    }\r\n    this.ready = true;\r\n    this.update();\r\n  }\r\n\r\n  protected setFilter(filter: FilterInfo ) {\r\n    this.filter$.next(filter);\r\n  }\r\n\r\n  update() {\r\n    if (this.ready) {\r\n      this.setFilter(\r\n        {\r\n          filterId: this.filterId,\r\n          key: this.key,\r\n          filterType: this.filterType,\r\n          fieldType: this.fieldType,\r\n          filterValue: this.filterValue,\r\n          active: this.active && this.filterValue !== undefined,\r\n          _isExternallyManaged: true,\r\n        }\r\n      );\r\n\r\n    }\r\n  }\r\n}\r\n\r\n@Directive({\r\n  selector: '[tbFilterStringContains]',\r\n  providers: [{ provide: TableFilterDirective, useExisting: TableFilterStringContainsDirective }],\r\n  inputs: [\r\n    'key:tbFilterStringContains',\r\n    'filterValue:filterValue',\r\n    'filterId: filterId',\r\n    'active: active',\r\n  ],\r\n  standalone: true,\r\n}) export class TableFilterStringContainsDirective extends TableFilterDirective {\r\n  constructor() {\r\n    super();\r\n    this.filterType = FilterTypes.StringContains;\r\n    this.fieldType = FieldType.String;\r\n  }\r\n\r\n  override reset() {\r\n    if(this.model) {\r\n      this.model.reset();\r\n    }\r\n    super.reset();\r\n  }\r\n\r\n  override setFilter(filter: FilterInfo) {\r\n    filter.active = filter.filterValue && this._userActive;\r\n    super.setFilter(filter);\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    if(changes['active']) {\r\n      this._userActive = changes['active'].currentValue;\r\n    }\r\n    super.ngOnChanges(changes);\r\n  }\r\n}\r\n\r\n@Directive({\r\n  selector: \"[tbCustomFilter]\",\r\n})\r\nexport abstract class TableCustomFilterDirectiveBase<T = any> extends TableCustomFilterDirective<T> {\r\n\r\n  filter$! : Subject<CustomFilter>;\r\n  filter!: CustomFilter;\r\n\r\n  _predicate!: Predicate<T>;\r\n  @Input('tbCustomFilter') set predicate( val: Predicate<T> ) {\r\n    this._predicate = val;\r\n    this.update({predicate:val});\r\n  }\r\n\r\n  _active: boolean = false;\r\n  ready = false;\r\n\r\n  update(val: Partial<CustomFilter> ) {\r\n    if(this.ready) {\r\n      this.filter = {...this.filter,...val};\r\n      this.filter$.next(this.filter);\r\n    }\r\n  }\r\n\r\n  @Input() set active(val: boolean) {\r\n    if(this._active !== val) {\r\n      this._active = val;\r\n      this.update({active:val});\r\n    }\r\n  }\r\n  get active(): boolean {\r\n    return this._active;\r\n  }\r\n\r\n  ngOnInit() {\r\n    if(!this.filterId) {\r\n      this.filterId = uuid();\r\n    } else {\r\n      this.savable = true;\r\n    }\r\n\r\n    this.filter = {\r\n      filterType: FilterTypes.Custom,\r\n      filterId: this.filterId,\r\n      active: this._active,\r\n      predicate: this._predicate,\r\n    };\r\n    this.ready = true;\r\n    this.filter$ = new BehaviorSubject(this.filter);\r\n  }\r\n}\r\n\r\n@Directive()\r\nexport abstract class TbSelectedFilterDirective<T = any>  extends TableCustomFilterDirectiveBase<T> {\r\n\r\n  protected wrapper = inject(TableWrapperDirective, { optional: true });\r\n  protected constructor(private change: Observable<any>, private isActive: () => boolean) {\r\n    super();\r\n    if(this.wrapper) {\r\n      this.wrapper.register(this);\r\n    }\r\n  }\r\n\r\n  reset() {\r\n    this.active = false;\r\n  }\r\n\r\n  destroySubject$ = new ReplaySubject<void>(1);\r\n  ngOnDestroy() {\r\n    this.destroySubject$.next();\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this._active = this.isActive();\r\n    super.ngOnInit();\r\n    this.change.pipe(takeUntil(this.destroySubject$)).subscribe( () => {\r\n      this.active = this.isActive();\r\n    });\r\n  }\r\n}\r\n\r\n// Checkbox\r\n@Directive({\r\n  selector: 'mat-checkbox[tbCustomFilter]',\r\n  inputs: [\r\n    ...inputs\r\n  ],\r\n  providers: [{ provide: TableCustomFilterDirective, useExisting: MatCheckboxTbFilterDirective }],\r\n  standalone: true,\r\n})\r\nexport class MatCheckboxTbFilterDirective extends TbSelectedFilterDirective {\r\n  private matCheckbox = inject(MatCheckbox);\r\n\r\n\r\n  override set active(val: boolean) {\r\n    this.matCheckbox.checked = val;\r\n    super.active = val;\r\n  }\r\n  constructor() {\r\n    const matCheckbox = inject(MatCheckbox);\r\n    super(matCheckbox.change, () => matCheckbox.checked);\r\n    this.matCheckbox = matCheckbox;\r\n  }\r\n}\r\n\r\n\r\n@Directive({\r\n  selector: 'mat-slide-toggle[tbCustomFilter]',\r\n  inputs: [\r\n    ...inputs\r\n  ],\r\n  providers: [{ provide: TableCustomFilterDirective, useExisting: MatSlideToggleTbFilterDirective }],\r\n  standalone: true,\r\n})\r\nexport class MatSlideToggleTbFilterDirective<T = any> extends TbSelectedFilterDirective<T> {\r\n  private matSlideToggle: MatSlideToggle;\r\n\r\n  override set active(val: boolean) {\r\n    this.matSlideToggle.checked = val;\r\n    super.active = val;\r\n  }\r\n  constructor() {\r\n    const matSlideToggle = inject(MatSlideToggle);\r\n\r\n    super(matSlideToggle.change, () => matSlideToggle.checked);\r\n    this.matSlideToggle = matSlideToggle;\r\n\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    super.ngOnInit();\r\n  }\r\n}\r\n\r\n// Radio button\r\n@Directive({\r\n  selector: 'mat-radio-button[tbCustomFilter]',\r\n  inputs: ['predicate: tbCustomFilter'],\r\n  providers: [{ provide: TableCustomFilterDirective, useExisting: MatRadioButtonTbFilterDirective }],\r\n  standalone: true,\r\n})\r\nexport class MatRadioButtonTbFilterDirective extends TbSelectedFilterDirective {\r\n  private matRadioButton: MatRadioButton;\r\n\r\n\r\n  override set active(val: boolean) {\r\n    this.matRadioButton.checked = val;\r\n    super.active = val;\r\n  }\r\n  constructor() {\r\n    const matRadioButton = inject(MatRadioButton);\r\n\r\n    super(matRadioButton.change, () => matRadioButton.checked);\r\n    this.matRadioButton = matRadioButton;\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    super.ngOnInit();\r\n  }\r\n}\r\n\r\n// Option (select)\r\n@Directive({\r\n  selector: 'mat-option[tbCustomFilter]',\r\n  inputs: [\r\n    ...inputs\r\n  ],\r\n  providers: [{ provide: TableCustomFilterDirective, useExisting: MatOptionTbFilterDirective }],\r\n  standalone: true,\r\n})\r\nexport class MatOptionTbFilterDirective extends TbSelectedFilterDirective {\r\n  private matOption: MatOption;\r\n\r\n\r\n  override set active(val: boolean) {\r\n    if(val) {\r\n      this.matOption.select();\r\n    } else {\r\n      this.matOption.deselect();\r\n    }\r\n    super.active = val;\r\n  }\r\n  constructor() {\r\n    const matOption = inject(MatOption);\r\n\r\n    super( matOption.onSelectionChange.pipe(tap( d => {\r\n      if(!matOption.value) {\r\n        matOption.value = uuid();\r\n      }\r\n    }\r\n\r\n    )), () => matOption.selected);\r\n    this.matOption = matOption;\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    super.ngOnInit();\r\n  }\r\n}\r\n\r\n// Button toggle\r\n@Directive({\r\n  selector: 'mat-button-toggle[tbCustomFilter]',\r\n  inputs: [\r\n    ...inputs\r\n  ],\r\n  providers: [{ provide: TableCustomFilterDirective, useExisting: MatButtonToggleFilterDirective }],\r\n  standalone: true,\r\n})\r\nexport class MatButtonToggleFilterDirective extends TbSelectedFilterDirective {\r\n  private matButtonToggle: MatButtonToggle;\r\n\r\n  override set active(val: boolean) {\r\n    this.matButtonToggle.checked = val;\r\n    super.active = val;\r\n  }\r\n  constructor() {\r\n    const matButtonToggle = inject(MatButtonToggle);\r\n\r\n    super(matButtonToggle.change, () => matButtonToggle.checked);\r\n    this.matButtonToggle = matButtonToggle;\r\n\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    super.ngOnInit();\r\n  }\r\n}\r\n"]}
@@ -1,8 +1,6 @@
1
1
  import { DatePipe } from '@angular/common';
2
2
  import { Injectable, inject } from '@angular/core';
3
- import { first, map } from 'rxjs/operators';
4
- import { combineLatest } from 'rxjs';
5
- import { orderStateMetaData, TableStore } from '../classes/table-store';
3
+ import { TableStore } from '../classes/table-store';
6
4
  import { TableBuilderConfigToken } from '../classes/TableBuilderConfig';
7
5
  import { downloadData } from '../functions/download-data';
8
6
  import { ArrayStyle, FieldType } from '../interfaces/report-def';
@@ -14,8 +12,10 @@ export class ExportToCsvService {
14
12
  config = inject(TableBuilderConfigToken);
15
13
  datePipe = inject(DatePipe);
16
14
  exportToCsv = (data) => {
17
- const exportableFields$ = this.state.state$.pipe(map(mapExportableFields));
18
- combineLatest([data, exportableFields$]).pipe(first(), map(([data, fields]) => this.csvData(data, fields))).subscribe(csv => downloadData(csv, 'export.csv', 'text/csv'));
15
+ const hiddenKeys = this.state.selectSignal(s => s.hiddenKeys)();
16
+ const meta = this.state.$metaDataArray().filter(md => !md.noExport && !hiddenKeys.includes(md.key));
17
+ const csv = this.csvData(data, meta);
18
+ downloadData(csv, 'export.csv', 'text/csv');
19
19
  };
20
20
  csvData = (data, metaData) => {
21
21
  const res = data.map(row => metaData.map(meta => this.metaToField(meta, row)).join(','));
@@ -72,14 +72,4 @@ 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) => orderStateMetaData(state)
76
- .filter(meta => !keysToRemove.includes(meta.key));
77
- export const nonExportableFields = (state) => Object.values(state.metaData)
78
- .filter(md => md.noExport)
79
- .map(md => md.key);
80
- export const mapExportableFields = (state) => {
81
- const fieldsToRemove = nonExportableFields(state)
82
- .concat(state.hiddenKeys);
83
- return removeFromMetaData(state, fieldsToRemove);
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';\r\nimport { Injectable, inject } from '@angular/core';\r\nimport { Observable } from 'rxjs';\r\nimport { first, map  } from 'rxjs/operators';\r\nimport { combineLatest} from 'rxjs';\r\nimport { orderStateMetaData, TableStore } from '../classes/table-store';\r\nimport { TableBuilderConfigToken } from '../classes/TableBuilderConfig';\r\nimport { downloadData } from '../functions/download-data';\r\nimport { ArrayAdditional, ArrayStyle, FieldType, MetaData } from '../interfaces/report-def';\r\nimport { TableState } from '../classes/TableState';\r\nimport { isPipe } from './transform-creator';\r\nimport { get } from 'lodash';\r\n\r\n@Injectable()\r\nexport class ExportToCsvService<T> {\r\n  state = inject(TableStore);\r\n  private config = inject(TableBuilderConfigToken);\r\n  private datePipe = inject(DatePipe);\r\n\r\n\r\n  exportToCsv = (data: Observable<T[]>) => {\r\n    const exportableFields$ = this.state.state$.pipe(\r\n      map(mapExportableFields)\r\n    );\r\n\r\n    combineLatest([data,exportableFields$]).pipe(\r\n      first(),\r\n      map(([data,fields]) => this.csvData(data,fields)),\r\n    ).subscribe(csv => downloadData(csv,'export.csv','text/csv') );\r\n  }\r\n\r\n  csvData = (data:Array<T>, metaData: MetaData<T>[]) => {\r\n    const res = data.map(row => metaData.map(meta => this.metaToField(meta, row)).join(','));\r\n    res.unshift(metaData.map(meta => meta.displayName || meta.key).join(','));\r\n    return res.join('\\n');\r\n  }\r\n\r\n  metaToField = (meta: MetaData<T>, row: T) => {\r\n    let val: any = get( row,meta.key);\r\n    if (val == null && !meta.transform) return val\r\n    if(meta.transform && meta.fieldType !== FieldType.Expression){\r\n      const transform = meta.transform as any;\r\n      return  isPipe(transform) ? transform.transform(val) : transform(val);\r\n    }\r\n    if(meta.map){\r\n      return meta.map(row);\r\n    }\r\n    switch (meta.fieldType) {\r\n      case FieldType.Date:\r\n        const dateFormat = meta.additional?.export?.dateFormat || this.config?.export?.dateFormat || meta.additional?.dateFormat;\r\n        val = this.transform(val, dateFormat);\r\n        break;\r\n      case FieldType.DateTime:\r\n        const dateTimeFormat = meta.additional?.export?.dateTimeFormat || this.config?.export?.dateTimeFormat || meta.additional?.dateTimeOptions?.format;\r\n        val = this.transform(val, dateTimeFormat);\r\n        break;\r\n      case FieldType.String:\r\n        const prepend: string = meta.additional?.export?.prepend || this.config?.export?.prepend || '';\r\n        val = prepend + val;\r\n        break;\r\n      case FieldType.Array:\r\n        const additional = meta.additional as ArrayAdditional;\r\n        val = (val as Array<string>).slice(0,additional.limit).join(additional.arrayStyle === ArrayStyle.NewLine ? '\\n' : ', ');\r\n        break;\r\n      case FieldType.Expression:\r\n        val = (meta.transform as any)(row);\r\n        break;\r\n    }\r\n    if (typeof val === 'string' && (val.includes(',') || val.includes('\"') || val.includes('\\n'))) {\r\n      val = val.replaceAll('\"', '\"\"');\r\n      val = '\"' + val + '\"';\r\n    }\r\n    return val;\r\n  }\r\n\r\n  private transform(val: any, dateFormat: any) {\r\n    if (this.config.transformers && this.config.transformers[FieldType.Date]) {\r\n      return this.config.transformers[FieldType.Date]!(val);\r\n    }\r\n    return this.datePipe.transform(val, dateFormat);\r\n  }\r\n}\r\n\r\nexport const removeFromMetaData = (state: TableState, keysToRemove: string[]) =>\r\n    orderStateMetaData(state)\r\n  .filter( meta => !keysToRemove.includes(meta.key));\r\n\r\n\r\nexport const nonExportableFields = (state: TableState) => Object.values( state.metaData)\r\n  .filter(md => md.noExport )\r\n  .map( md => md.key );\r\n\r\nexport const mapExportableFields = (state: TableState) => {\r\n  const fieldsToRemove = nonExportableFields(state)\r\n    .concat(state.hiddenKeys);\r\n   return removeFromMetaData(state, fieldsToRemove);\r\n}\r\n"]}
75
+ //# 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';\r\nimport { Injectable, inject } from '@angular/core';\r\nimport { Observable } from 'rxjs';\r\nimport { first, map  } from 'rxjs/operators';\r\nimport { combineLatest} from 'rxjs';\r\nimport { orderStateMetaData, TableStore } from '../classes/table-store';\r\nimport { TableBuilderConfigToken } from '../classes/TableBuilderConfig';\r\nimport { downloadData } from '../functions/download-data';\r\nimport { ArrayAdditional, ArrayStyle, FieldType, MetaData } from '../interfaces/report-def';\r\nimport { TableState } from '../classes/TableState';\r\nimport { isPipe } from './transform-creator';\r\nimport { get } from 'lodash';\r\n\r\n@Injectable()\r\nexport class ExportToCsvService<T> {\r\n  state = inject(TableStore);\r\n  private config = inject(TableBuilderConfigToken);\r\n  private datePipe = inject(DatePipe);\r\n\r\n\r\n  exportToCsv = (data: T[]) => {\r\n    const hiddenKeys = this.state.selectSignal(s => s.hiddenKeys)();\r\n    const meta = this.state.$metaDataArray().filter(md => !md.noExport && !hiddenKeys.includes(md.key));\r\n    const csv = this.csvData(data, meta);\r\n    downloadData(csv,'export.csv', 'text/csv') ;\r\n  }\r\n\r\n  csvData = (data:Array<T>, metaData: MetaData<T>[]) => {\r\n    const res = data.map(row => metaData.map(meta => this.metaToField(meta, row)).join(','));\r\n    res.unshift(metaData.map(meta => meta.displayName || meta.key).join(','));\r\n    return res.join('\\n');\r\n  }\r\n\r\n  metaToField = (meta: MetaData<T>, row: T) => {\r\n    let val: any = get( row,meta.key);\r\n    if (val == null && !meta.transform) return val\r\n    if(meta.transform && meta.fieldType !== FieldType.Expression){\r\n      const transform = meta.transform as any;\r\n      return  isPipe(transform) ? transform.transform(val) : transform(val);\r\n    }\r\n    if(meta.map){\r\n      return meta.map(row);\r\n    }\r\n    switch (meta.fieldType) {\r\n      case FieldType.Date:\r\n        const dateFormat = meta.additional?.export?.dateFormat || this.config?.export?.dateFormat || meta.additional?.dateFormat;\r\n        val = this.transform(val, dateFormat);\r\n        break;\r\n      case FieldType.DateTime:\r\n        const dateTimeFormat = meta.additional?.export?.dateTimeFormat || this.config?.export?.dateTimeFormat || meta.additional?.dateTimeOptions?.format;\r\n        val = this.transform(val, dateTimeFormat);\r\n        break;\r\n      case FieldType.String:\r\n        const prepend: string = meta.additional?.export?.prepend || this.config?.export?.prepend || '';\r\n        val = prepend + val;\r\n        break;\r\n      case FieldType.Array:\r\n        const additional = meta.additional as ArrayAdditional;\r\n        val = (val as Array<string>).slice(0,additional.limit).join(additional.arrayStyle === ArrayStyle.NewLine ? '\\n' : ', ');\r\n        break;\r\n      case FieldType.Expression:\r\n        val = (meta.transform as any)(row);\r\n        break;\r\n    }\r\n    if (typeof val === 'string' && (val.includes(',') || val.includes('\"') || val.includes('\\n'))) {\r\n      val = val.replaceAll('\"', '\"\"');\r\n      val = '\"' + val + '\"';\r\n    }\r\n    return val;\r\n  }\r\n\r\n  private transform(val: any, dateFormat: any) {\r\n    if (this.config.transformers && this.config.transformers[FieldType.Date]) {\r\n      return this.config.transformers[FieldType.Date]!(val);\r\n    }\r\n    return this.datePipe.transform(val, dateFormat);\r\n  }\r\n}\r\n"]}