@one-paragon/angular-utilities 1.3.0 → 1.3.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.
- package/fesm2022/one-paragon-angular-utilities.mjs +251 -252
- package/fesm2022/one-paragon-angular-utilities.mjs.map +1 -1
- package/http-request-state/HttpRequestStateStore.d.ts +1 -1
- package/http-request-state/directives/HttpStateDirectiveBase.d.ts +1 -1
- package/package.json +1 -3
- package/rxjs/subscriber.directive.d.ts +1 -1
- package/table-builder/classes/table-store.d.ts +3 -3
- package/table-builder/components/link-column.component.d.ts +3 -3
- package/table-builder/components/table-container/table-container-imports.d.ts +1 -1
- package/table-builder/components/table-container/table-container.helpers/filter-state.helpers.d.ts +1 -1
- package/table-builder/directives/tb-filter.directive.d.ts +3 -3
- package/table-builder/ngrx/tableBuilderStateStore.d.ts +4 -4
- package/esm2022/action-state/action-state-spinner/action-state-spinner.component.mjs +0 -24
- package/esm2022/action-state/action-state-ui/action-state-ui.module.mjs +0 -20
- package/esm2022/action-state/index.mjs +0 -8
- package/esm2022/action-state/ngrx-ext/ngrx-ext.module.mjs +0 -23
- package/esm2022/action-state/ngrx.mjs +0 -47
- package/esm2022/http-request-state/HttpRequestStateFactory.mjs +0 -51
- package/esm2022/http-request-state/HttpRequestStateStore.mjs +0 -135
- package/esm2022/http-request-state/directives/HttpStateDirectiveBase.mjs +0 -30
- package/esm2022/http-request-state/directives/http-error-state-directive.mjs +0 -23
- package/esm2022/http-request-state/directives/http-inProgress-state-directive.mjs +0 -23
- package/esm2022/http-request-state/directives/http-notStarted-state-directive.mjs +0 -23
- package/esm2022/http-request-state/directives/http-success-state-directive.mjs +0 -29
- package/esm2022/http-request-state/directives/index.mjs +0 -6
- package/esm2022/http-request-state/directives/request-state-directive.mjs +0 -61
- package/esm2022/http-request-state/helpers.mjs +0 -22
- package/esm2022/http-request-state/http-request-state.mjs +0 -39
- package/esm2022/http-request-state/http-state-module.mjs +0 -40
- package/esm2022/http-request-state/index.mjs +0 -7
- package/esm2022/http-request-state/rxjs/getRequestorBody.mjs +0 -4
- package/esm2022/http-request-state/rxjs/getRequestorState.mjs +0 -3
- package/esm2022/http-request-state/rxjs/index.mjs +0 -5
- package/esm2022/http-request-state/rxjs/tapError.mjs +0 -12
- package/esm2022/http-request-state/rxjs/tapSuccess.mjs +0 -12
- package/esm2022/http-request-state/types.mjs +0 -16
- package/esm2022/ngrx/actionable-selector.mjs +0 -107
- package/esm2022/ngrx/index.mjs +0 -2
- package/esm2022/one-paragon-angular-utilities.mjs +0 -5
- package/esm2022/public-api.mjs +0 -20
- package/esm2022/rxjs/defaultShareReplay.mjs +0 -7
- package/esm2022/rxjs/index.mjs +0 -6
- package/esm2022/rxjs/mapError.mjs +0 -8
- package/esm2022/rxjs/rxjs-operators.mjs +0 -92
- package/esm2022/rxjs/subjectifier.mjs +0 -15
- package/esm2022/rxjs/subscriber.directive.mjs +0 -50
- package/esm2022/table-builder/classes/DefaultSettings.mjs +0 -6
- package/esm2022/table-builder/classes/MatTableObservableDataSource.mjs +0 -23
- package/esm2022/table-builder/classes/TableBuilderConfig.mjs +0 -18
- package/esm2022/table-builder/classes/TableBuilderDataSource.mjs +0 -48
- package/esm2022/table-builder/classes/TableState.mjs +0 -48
- package/esm2022/table-builder/classes/data-store.mjs +0 -15
- package/esm2022/table-builder/classes/display-col.mjs +0 -2
- package/esm2022/table-builder/classes/filter-info.mjs +0 -61
- package/esm2022/table-builder/classes/table-builder-general-settings.mjs +0 -116
- package/esm2022/table-builder/classes/table-builder.mjs +0 -77
- package/esm2022/table-builder/classes/table-store.mjs +0 -388
- package/esm2022/table-builder/components/array-column.component.mjs +0 -53
- package/esm2022/table-builder/components/column-builder/column-builder.component.mjs +0 -145
- package/esm2022/table-builder/components/column-builder/column-helpers.mjs +0 -45
- package/esm2022/table-builder/components/date-filter/date-filter.component.mjs +0 -29
- package/esm2022/table-builder/components/date-time-filter/date-time-filter.component.mjs +0 -24
- package/esm2022/table-builder/components/filter/filter.component.mjs +0 -64
- package/esm2022/table-builder/components/filter/in-list/in-list-filter.component.mjs +0 -102
- package/esm2022/table-builder/components/gen-col-displayer/gen-col-displayer.component.mjs +0 -47
- package/esm2022/table-builder/components/generic-table/generic-table.component.mjs +0 -306
- package/esm2022/table-builder/components/generic-table/paginator.component.mjs +0 -104
- package/esm2022/table-builder/components/group-by-list/group-by-list.component.mjs +0 -21
- package/esm2022/table-builder/components/header-menu/header-menu.component.mjs +0 -103
- package/esm2022/table-builder/components/in-filter/in-filter.component.mjs +0 -65
- package/esm2022/table-builder/components/index.mjs +0 -10
- package/esm2022/table-builder/components/initialization-component/initialization-component.mjs +0 -47
- package/esm2022/table-builder/components/link-column.component.mjs +0 -74
- package/esm2022/table-builder/components/number-filter/number-filter.component.mjs +0 -29
- package/esm2022/table-builder/components/profiles-menu/profiles-menu.component.mjs +0 -64
- package/esm2022/table-builder/components/scroll-strategy.mjs +0 -60
- package/esm2022/table-builder/components/sort-menu/sort-menu.component-store.mjs +0 -46
- package/esm2022/table-builder/components/sort-menu/sort-menu.component.mjs +0 -82
- package/esm2022/table-builder/components/table-container/table-container-imports.mjs +0 -26
- package/esm2022/table-builder/components/table-container/table-container.helpers/data-state.helpers.mjs +0 -135
- package/esm2022/table-builder/components/table-container/table-container.helpers/filter-state.helpers.mjs +0 -83
- package/esm2022/table-builder/components/table-container/table-container.helpers/groupBy.helpers.mjs +0 -71
- package/esm2022/table-builder/components/table-container/table-container.helpers/sort-state.helpers.mjs +0 -36
- package/esm2022/table-builder/components/table-container/table-container.mjs +0 -334
- package/esm2022/table-builder/components/table-container/tableProps.mjs +0 -8
- package/esm2022/table-builder/components/table-container/virtual-scroll-container.mjs +0 -155
- package/esm2022/table-builder/components/table-container-filter/filter-list/filter-list.component.mjs +0 -44
- package/esm2022/table-builder/components/table-container-filter/gen-filter-displayer/gen-filter-displayer.component.mjs +0 -35
- package/esm2022/table-builder/components/table-container-filter/table-wrapper-filter-store.mjs +0 -25
- package/esm2022/table-builder/directives/custom-cell-directive.mjs +0 -73
- package/esm2022/table-builder/directives/index.mjs +0 -6
- package/esm2022/table-builder/directives/multi-sort.directive.mjs +0 -50
- package/esm2022/table-builder/directives/resize-column.directive.mjs +0 -87
- package/esm2022/table-builder/directives/table-wrapper.directive.mjs +0 -18
- package/esm2022/table-builder/directives/tb-filter.directive.mjs +0 -396
- package/esm2022/table-builder/enums/filterTypes.mjs +0 -29
- package/esm2022/table-builder/functions/boolean-filter-function.mjs +0 -10
- package/esm2022/table-builder/functions/date-filter-function.mjs +0 -58
- package/esm2022/table-builder/functions/download-data.mjs +0 -12
- package/esm2022/table-builder/functions/null-filter-function.mjs +0 -8
- package/esm2022/table-builder/functions/number-filter-function.mjs +0 -32
- package/esm2022/table-builder/functions/sort-data-function.mjs +0 -17
- package/esm2022/table-builder/functions/string-filter-function.mjs +0 -41
- package/esm2022/table-builder/interfaces/ColumnInfo.mjs +0 -2
- package/esm2022/table-builder/interfaces/dictionary.mjs +0 -2
- package/esm2022/table-builder/interfaces/report-def.mjs +0 -50
- package/esm2022/table-builder/ngrx/tableBuilderStateStore.mjs +0 -154
- package/esm2022/table-builder/pipes/column-total.pipe.mjs +0 -22
- package/esm2022/table-builder/pipes/format-filter-type.pipe.mjs +0 -18
- package/esm2022/table-builder/pipes/format-filter-value.pipe.mjs +0 -43
- package/esm2022/table-builder/pipes/key-display.mjs +0 -18
- package/esm2022/table-builder/services/export-to-csv.service.mjs +0 -75
- package/esm2022/table-builder/services/link-creator.service.mjs +0 -50
- package/esm2022/table-builder/services/table-template-service.mjs +0 -60
- package/esm2022/table-builder/services/transform-creator.mjs +0 -100
- package/esm2022/table-builder/table-builder.module.mjs +0 -124
- package/esm2022/utilities/array-helpers.mjs +0 -14
- package/esm2022/utilities/directives/auto-focus.directive.mjs +0 -25
- package/esm2022/utilities/directives/clickEmitterDirective.mjs +0 -22
- package/esm2022/utilities/directives/clickSubject.mjs +0 -29
- package/esm2022/utilities/directives/conditional-classes.directive.mjs +0 -36
- package/esm2022/utilities/directives/dialog-service.mjs +0 -21
- package/esm2022/utilities/directives/dialog.mjs +0 -145
- package/esm2022/utilities/directives/mat-toggle-group-directive.mjs +0 -59
- package/esm2022/utilities/directives/prevent-enter.directive.mjs +0 -20
- package/esm2022/utilities/directives/stop-propagation.directive.mjs +0 -26
- package/esm2022/utilities/directives/styler.mjs +0 -41
- package/esm2022/utilities/directives/trim-whitespace.directive.mjs +0 -28
- package/esm2022/utilities/index.mjs +0 -16
- package/esm2022/utilities/module.mjs +0 -90
- package/esm2022/utilities/pipes/function.pipe.mjs +0 -22
- package/esm2022/utilities/pipes/phone.pipe.mjs +0 -20
- package/esm2022/utilities/pipes/space-case.pipes.mjs +0 -28
|
@@ -1,102 +0,0 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Input, inject } from '@angular/core';
|
|
2
|
-
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
3
|
-
import { map, tap } from 'rxjs/operators';
|
|
4
|
-
import { TableStore } from '../../../classes/table-store';
|
|
5
|
-
import { FieldType } from '../../../interfaces/report-def';
|
|
6
|
-
import { AsyncPipe, KeyValuePipe } from '@angular/common';
|
|
7
|
-
import { MatCheckboxModule } from '@angular/material/checkbox';
|
|
8
|
-
import { SpaceCasePipe, StopPropagationDirective } from '../../../../utilities';
|
|
9
|
-
import * as i0 from "@angular/core";
|
|
10
|
-
import * as i1 from "@angular/material/checkbox";
|
|
11
|
-
export class InListFilterComponent {
|
|
12
|
-
ref = inject(ChangeDetectorRef);
|
|
13
|
-
tableState = inject(TableStore);
|
|
14
|
-
value = [];
|
|
15
|
-
FieldType = FieldType;
|
|
16
|
-
writeValue(obj) {
|
|
17
|
-
this.value = obj;
|
|
18
|
-
if (this.value) {
|
|
19
|
-
this.selectedKeys = this.value.map(f => f);
|
|
20
|
-
}
|
|
21
|
-
this.ref.markForCheck();
|
|
22
|
-
}
|
|
23
|
-
onChange = (_) => { };
|
|
24
|
-
registerOnChange(fn) {
|
|
25
|
-
this.onChange = fn;
|
|
26
|
-
}
|
|
27
|
-
onTouched = () => { };
|
|
28
|
-
registerOnTouched(fn) {
|
|
29
|
-
this.onTouched = fn;
|
|
30
|
-
}
|
|
31
|
-
key;
|
|
32
|
-
keyValues$;
|
|
33
|
-
selectedKeys = [];
|
|
34
|
-
metaData;
|
|
35
|
-
ngOnInit() {
|
|
36
|
-
this.keyValues$ = this.tableState.getMetaData$(this.key).pipe(tap(metaData => this.metaData = metaData), map(metaData => {
|
|
37
|
-
if (metaData.additional?.filterOptions?.filterableValues) {
|
|
38
|
-
return metaData.additional.filterOptions.filterableValues.reduce((prev, cur) => { prev[cur] = cur; return prev; }, {});
|
|
39
|
-
}
|
|
40
|
-
else {
|
|
41
|
-
if (metaData.fieldType === FieldType.Enum) {
|
|
42
|
-
return metaData.additional.enumMap;
|
|
43
|
-
}
|
|
44
|
-
}
|
|
45
|
-
return {};
|
|
46
|
-
}));
|
|
47
|
-
}
|
|
48
|
-
selectFilterChanged($event, val) {
|
|
49
|
-
if ($event.checked) {
|
|
50
|
-
this.selectedKeys = [...this.selectedKeys, val];
|
|
51
|
-
}
|
|
52
|
-
else {
|
|
53
|
-
this.selectedKeys = this.selectedKeys.filter(item => item !== val);
|
|
54
|
-
}
|
|
55
|
-
this.value = this.selectedKeys;
|
|
56
|
-
this.onChange(this.value);
|
|
57
|
-
}
|
|
58
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: InListFilterComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
59
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.2", type: InListFilterComponent, isStandalone: true, selector: "tb-in-list-filter , [tb-in-list-filter]", inputs: { key: "key" }, providers: [{
|
|
60
|
-
provide: NG_VALUE_ACCESSOR,
|
|
61
|
-
useExisting: InListFilterComponent,
|
|
62
|
-
multi: true
|
|
63
|
-
}], ngImport: i0, template: `
|
|
64
|
-
@for (item of keyValues$ | async| keyvalue; track item.key) {
|
|
65
|
-
<div>
|
|
66
|
-
<mat-checkbox [checked]='selectedKeys.includes(item.key)' stop-propagation (change)='selectFilterChanged($event, item.key)' >
|
|
67
|
-
{{metaData.fieldType === FieldType.Enum ? (item.value | spaceCase) : item.value}}
|
|
68
|
-
</mat-checkbox>
|
|
69
|
-
</div>
|
|
70
|
-
}
|
|
71
|
-
|
|
72
|
-
`, isInline: true, dependencies: [{ kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "pipe", type: KeyValuePipe, name: "keyvalue" }, { kind: "ngmodule", type: MatCheckboxModule }, { kind: "component", type: i1.MatCheckbox, selector: "mat-checkbox", inputs: ["aria-label", "aria-labelledby", "aria-describedby", "id", "required", "labelPosition", "name", "value", "disableRipple", "tabIndex", "color", "disabledInteractive", "checked", "disabled", "indeterminate"], outputs: ["change", "indeterminateChange"], exportAs: ["matCheckbox"] }, { kind: "directive", type: StopPropagationDirective, selector: "[stop-propagation]" }, { kind: "pipe", type: SpaceCasePipe, name: "spaceCase" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
73
|
-
}
|
|
74
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: InListFilterComponent, decorators: [{
|
|
75
|
-
type: Component,
|
|
76
|
-
args: [{
|
|
77
|
-
selector: 'tb-in-list-filter , [tb-in-list-filter]',
|
|
78
|
-
template: `
|
|
79
|
-
@for (item of keyValues$ | async| keyvalue; track item.key) {
|
|
80
|
-
<div>
|
|
81
|
-
<mat-checkbox [checked]='selectedKeys.includes(item.key)' stop-propagation (change)='selectFilterChanged($event, item.key)' >
|
|
82
|
-
{{metaData.fieldType === FieldType.Enum ? (item.value | spaceCase) : item.value}}
|
|
83
|
-
</mat-checkbox>
|
|
84
|
-
</div>
|
|
85
|
-
}
|
|
86
|
-
|
|
87
|
-
`,
|
|
88
|
-
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
89
|
-
providers: [{
|
|
90
|
-
provide: NG_VALUE_ACCESSOR,
|
|
91
|
-
useExisting: InListFilterComponent,
|
|
92
|
-
multi: true
|
|
93
|
-
}],
|
|
94
|
-
standalone: true,
|
|
95
|
-
imports: [
|
|
96
|
-
AsyncPipe, KeyValuePipe, MatCheckboxModule, StopPropagationDirective, SpaceCasePipe
|
|
97
|
-
]
|
|
98
|
-
}]
|
|
99
|
-
}], propDecorators: { key: [{
|
|
100
|
-
type: Input
|
|
101
|
-
}] } });
|
|
102
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"in-list-filter.component.js","sourceRoot":"","sources":["../../../../../../../projects/angular-utilities/src/table-builder/components/filter/in-list/in-list-filter.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,iBAAiB,EAAE,SAAS,EAAE,KAAK,EAAoB,MAAM,EAAE,MAAM,eAAe,CAAC;AACvH,OAAO,EAAwB,iBAAiB,EAAC,MAAM,gBAAgB,CAAC;AAExE,OAAO,EAAE,GAAG,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AAC1C,OAAO,EAAE,UAAU,EAAE,MAAM,8BAA8B,CAAC;AAE1D,OAAO,EAAE,SAAS,EAAY,MAAM,gCAAgC,CAAC;AACrE,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC1D,OAAO,EAAE,iBAAiB,EAAE,MAAM,4BAA4B,CAAC;AAC/D,OAAO,EAAE,aAAa,EAAE,wBAAwB,EAAE,MAAM,uBAAuB,CAAC;;;AA0BhF,MAAM,OAAO,qBAAqB;IACxB,GAAG,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;IAChC,UAAU,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;IAExC,KAAK,GAAa,EAAE,CAAC;IACrB,SAAS,GAAG,SAAS,CAAC;IACtB,UAAU,CAAC,GAAa;QACtB,IAAI,CAAC,KAAK,GAAG,GAAG,CAAC;QAEjB,IAAG,IAAI,CAAC,KAAK,EAAE,CAAC;YACd,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAE,CAAC;QAC/C,CAAC;QACD,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;IAC1B,CAAC;IAED,QAAQ,GAAG,CAAC,CAAM,EAAE,EAAE,GAAG,CAAC,CAAC;IAE3B,gBAAgB,CAAC,EAAO;QACtB,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACrB,CAAC;IACD,SAAS,GAAG,GAAG,EAAE,GAAG,CAAC,CAAC;IACtB,iBAAiB,CAAC,EAAO;QACvB,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACtB,CAAC;IACQ,GAAG,CAAU;IAEtB,UAAU,CAAmC;IAC7C,YAAY,GAAc,EAAE,CAAC;IAC7B,QAAQ,CAAY;IAEpB,QAAQ;QACN,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC,YAAY,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,CAC3D,GAAG,CAAC,QAAQ,CAAC,EAAE,CAAC,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC,EACzC,GAAG,CAAE,QAAQ,CAAC,EAAE;YACd,IAAG,QAAQ,CAAC,UAAU,EAAE,aAAa,EAAE,gBAAgB,EAAG,CAAC;gBACzD,OAAQ,QAAQ,CAAC,UAAU,CAAC,aAAa,CAAC,gBAAgB,CAAC,MAAM,CAAE,CAAC,IAAS,EAAE,GAAG,EAAC,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC,CAAC,OAAO,IAAI,CAAA,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;YAC9H,CAAC;iBAAM,CAAC;gBACN,IAAG,QAAQ,CAAC,SAAS,KAAK,SAAS,CAAC,IAAI,EAAG,CAAC;oBAC1C,OAAO,QAAQ,CAAC,UAAW,CAAC,OAAO,CAAC;gBACtC,CAAC;YACH,CAAC;YACD,OAAO,EAAE,CAAC;QACZ,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAED,mBAAmB,CAAC,MAAM,EAAE,GAAG;QAC7B,IAAG,MAAM,CAAC,OAAO,EAAE,CAAC;YAClB,IAAI,CAAC,YAAY,GAAG,CAAC,GAAG,IAAI,CAAC,YAAY,EAAE,GAAG,CAAC,CAAC;QAClD,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,YAAY,CAAC,MAAM,CAAE,IAAI,CAAC,EAAE,CAAC,IAAI,KAAK,GAAG,CAAC,CAAC;QACtE,CAAC;QAED,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,YAAY,CAAC;QAC/B,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC5B,CAAC;uGAvDU,qBAAqB;2FAArB,qBAAqB,8GAVrB,CAAC;gBACV,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,qBAAqB;gBAClC,KAAK,EAAE,IAAI;aACZ,CAAC,0BAfQ;;;;;;;;;GAST,uDASC,SAAS,yCAAE,YAAY,gDAAE,iBAAiB,qYAAE,wBAAwB,0DAAE,aAAa;;2FAG1E,qBAAqB;kBAvBjC,SAAS;mBAAC;oBACT,QAAQ,EAAE,yCAAyC;oBACnD,QAAQ,EAAE;;;;;;;;;GAST;oBACD,eAAe,EAAE,uBAAuB,CAAC,MAAM;oBAC/C,SAAS,EAAE,CAAC;4BACV,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,uBAAuB;4BAClC,KAAK,EAAE,IAAI;yBACZ,CAAC;oBACF,UAAU,EAAE,IAAI;oBAChB,OAAO,EAAE;wBACP,SAAS,EAAE,YAAY,EAAE,iBAAiB,EAAE,wBAAwB,EAAE,aAAa;qBACpF;iBACF;8BAyBU,GAAG;sBAAX,KAAK","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Input, ViewContainerRef, inject } from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR} from '@angular/forms';\r\nimport { Observable } from 'rxjs';\r\nimport { map, tap } from 'rxjs/operators';\r\nimport { TableStore } from '../../../classes/table-store';\r\nimport { Dictionary } from '../../../interfaces/dictionary';\r\nimport { FieldType, MetaData } from '../../../interfaces/report-def';\r\nimport { AsyncPipe, KeyValuePipe } from '@angular/common';\r\nimport { MatCheckboxModule } from '@angular/material/checkbox';\r\nimport { SpaceCasePipe, StopPropagationDirective } from '../../../../utilities';\r\n\r\n\r\n@Component({\r\n  selector: 'tb-in-list-filter , [tb-in-list-filter]',\r\n  template: `\r\n  @for (item of keyValues$ | async| keyvalue; track item.key) {\r\n    <div>\r\n      <mat-checkbox [checked]='selectedKeys.includes(item.key)' stop-propagation (change)='selectFilterChanged($event, item.key)' >\r\n        {{metaData.fieldType === FieldType.Enum ? (item.value | spaceCase) : item.value}}\r\n      </mat-checkbox>\r\n    </div>\r\n  }\r\n\r\n  `,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [{\r\n    provide: NG_VALUE_ACCESSOR,\r\n    useExisting: InListFilterComponent,\r\n    multi: true\r\n  }],\r\n  standalone: true,\r\n  imports: [\r\n    AsyncPipe, KeyValuePipe, MatCheckboxModule, StopPropagationDirective, SpaceCasePipe\r\n  ]\r\n})\r\nexport class InListFilterComponent implements ControlValueAccessor {\r\n  private ref = inject(ChangeDetectorRef);\r\n  private tableState = inject(TableStore);\r\n\r\n  value: string[] = [];\r\n  FieldType = FieldType;\r\n  writeValue(obj: string[]): void {\r\n    this.value = obj;\r\n\r\n    if(this.value) {\r\n      this.selectedKeys = this.value.map( f => f );\r\n    }\r\n    this.ref.markForCheck();\r\n  }\r\n\r\n  onChange = (_: any) => { };\r\n\r\n  registerOnChange(fn: any): void {\r\n    this.onChange = fn;\r\n  }\r\n  onTouched = () => { };\r\n  registerOnTouched(fn: any): void {\r\n    this.onTouched = fn;\r\n  }\r\n  @Input() key!: string;\r\n\r\n  keyValues$! : Observable<Dictionary<string>>;\r\n  selectedKeys : string[] = [];\r\n  metaData!: MetaData;\r\n\r\n  ngOnInit() {\r\n    this.keyValues$ = this.tableState.getMetaData$(this.key).pipe(\r\n      tap(metaData => this.metaData = metaData),\r\n      map( metaData => {\r\n        if(metaData.additional?.filterOptions?.filterableValues ) {\r\n          return  metaData.additional.filterOptions.filterableValues.reduce( (prev: any, cur)=> { prev[cur] = cur; return prev }, {});\r\n        } else {\r\n          if(metaData.fieldType === FieldType.Enum ) {\r\n            return metaData.additional!.enumMap;\r\n          }\r\n        }\r\n        return {};\r\n      })\r\n    );\r\n  }\r\n\r\n  selectFilterChanged($event, val) {\r\n    if($event.checked) {\r\n      this.selectedKeys = [...this.selectedKeys, val];\r\n    } else {\r\n      this.selectedKeys = this.selectedKeys.filter( item => item !== val);\r\n    }\r\n\r\n    this.value = this.selectedKeys;\r\n    this.onChange(this.value);\r\n  }\r\n\r\n}\r\n"]}
|
|
@@ -1,47 +0,0 @@
|
|
|
1
|
-
import { Component, ChangeDetectionStrategy, inject, computed } from '@angular/core';
|
|
2
|
-
import { TableStore } from '../../classes/table-store';
|
|
3
|
-
import { DragDropModule } from '@angular/cdk/drag-drop';
|
|
4
|
-
import { AsyncPipe } from '@angular/common';
|
|
5
|
-
import { MatTooltipModule } from '@angular/material/tooltip';
|
|
6
|
-
import { MatIconModule } from '@angular/material/icon';
|
|
7
|
-
import { MatButtonModule } from '@angular/material/button';
|
|
8
|
-
import { MatMenuModule } from '@angular/material/menu';
|
|
9
|
-
import { SpaceCasePipe, StopPropagationDirective } from '../../../utilities';
|
|
10
|
-
import * as i0 from "@angular/core";
|
|
11
|
-
import * as i1 from "@angular/material/tooltip";
|
|
12
|
-
import * as i2 from "@angular/material/icon";
|
|
13
|
-
import * as i3 from "@angular/material/button";
|
|
14
|
-
import * as i4 from "@angular/material/menu";
|
|
15
|
-
import * as i5 from "@angular/cdk/drag-drop";
|
|
16
|
-
export class GenColDisplayerComponent {
|
|
17
|
-
tableState = inject(TableStore);
|
|
18
|
-
$columns = computed(() => this.tableState.$orderedCodeVisibleMetaDatas().map(md => ({
|
|
19
|
-
key: md.key,
|
|
20
|
-
displayName: md.displayName,
|
|
21
|
-
isVisible: !this.tableState.$hiddenKeys().includes(md.key)
|
|
22
|
-
})));
|
|
23
|
-
reset(displayCols) {
|
|
24
|
-
displayCols.forEach(c => c.isVisible = true);
|
|
25
|
-
this.emit(displayCols);
|
|
26
|
-
}
|
|
27
|
-
drop(event) {
|
|
28
|
-
this.tableState.setUserDefinedOrder({ newOrder: event.currentIndex, oldOrder: event.previousIndex });
|
|
29
|
-
}
|
|
30
|
-
unset(displayCols) {
|
|
31
|
-
displayCols.forEach(c => c.isVisible = false);
|
|
32
|
-
this.emit(displayCols);
|
|
33
|
-
}
|
|
34
|
-
emit(displayCols) {
|
|
35
|
-
this.tableState.setHiddenColumns(displayCols.map(c => ({ key: c.key, visible: c.isVisible })));
|
|
36
|
-
}
|
|
37
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: GenColDisplayerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
38
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.2", type: GenColDisplayerComponent, isStandalone: true, selector: "tb-col-displayer", ngImport: i0, template: "@if($columns(); as displayCols){\r\n <span matTooltip=\"Show/hide columns\">\r\n <button mat-icon-button [matMenuTriggerFor]=\"menu\">\r\n <mat-icon color=\"primary\">visibility_off</mat-icon>\r\n </button>\r\n </span>\r\n <mat-menu #menu=\"matMenu\" class=\"my-mat-menu\">\r\n\r\n <button mat-menu-item>\r\n <span matTooltip=\"Close\">\r\n <button class=\"filter-button\" mat-icon-button>\r\n <mat-icon>close</mat-icon>\r\n </button>\r\n </span>\r\n </button>\r\n\r\n <button mat-menu-item stop-propagation>\r\n <span matTooltip=\"Show all columns\">\r\n <button mat-icon-button (click)=\"reset(displayCols)\">\r\n <mat-icon color=\"primary\">done_all</mat-icon>\r\n </button>\r\n </span>\r\n\r\n <span matTooltip=\"Hide all columns\">\r\n <button mat-icon-button (click)=\"unset(displayCols)\">\r\n <mat-icon color=\"primary\">cancel</mat-icon>\r\n </button>\r\n </span>\r\n </button>\r\n\r\n <div cdkDropList (cdkDropListDropped)=\"drop($event)\" stop-propagation [cdkDropListLockAxis]=\"'y'\">\r\n @for (col of displayCols; track col.key) {\r\n <button [class.isHidden]=\"!col.isVisible\" stop-propagation mat-menu-item cdkDrag [cdkDragData]=\"col\">\r\n <div (click)=\"col.isVisible = !col.isVisible; emit(displayCols)\" style=\"display: flex; align-items: center;\">\r\n @if(col.isVisible){\r\n <button mat-icon-button matTooltip=\"Hide Column\" class=\"show-hide\">\r\n <mat-icon color=\"primary\">check_box</mat-icon>\r\n </button>\r\n } @else {\r\n <button mat-icon-button matTooltip=\"Show Column\" class=\"show-hide\">\r\n <mat-icon>indeterminate_check_box</mat-icon>\r\n </button>\r\n }\r\n \r\n <p class=\"label\">\r\n {{col.displayName || (col.key | spaceCase) }}\r\n </p>\r\n\r\n </div>\r\n </button>\r\n }\r\n\r\n </div>\r\n </mat-menu>\r\n}", styles: [".show-hide{margin-right:15px;height:24px;width:24px;padding:4px}.label{color:#6495ed;text-overflow:ellipsis;overflow:hidden;white-space:nowrap;text-align:left;margin:0;font-size:17px;font-weight:700;display:inline-block;width:66%}.row{margin:0;padding:0}.isHidden{background-color:#d3d3d3;color:#a9a9a9;font-weight:700;font-size:17px;white-space:nowrap}.filter-button{margin-top:10px}.cdk-drag-preview{box-sizing:border-box;border-radius:4px;box-shadow:0 5px 5px -3px #0003,0 8px 10px 1px #00000024,0 3px 14px 2px #0000001f}.cdk-drag-placeholder{opacity:0}.cdk-drag-animating{transition:transform .25s cubic-bezier(0,0,.2,1)}.mdc-list-item__primary-text{display:inline-block;width:100%}\n"], dependencies: [{ kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: i1.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i3.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "ngmodule", type: MatMenuModule }, { kind: "component", type: i4.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: i4.MatMenuItem, selector: "[mat-menu-item]", inputs: ["role", "disabled", "disableRipple"], exportAs: ["matMenuItem"] }, { kind: "directive", type: i4.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", inputs: ["mat-menu-trigger-for", "matMenuTriggerFor", "matMenuTriggerData", "matMenuTriggerRestoreFocus"], outputs: ["menuOpened", "onMenuOpen", "menuClosed", "onMenuClose"], exportAs: ["matMenuTrigger"] }, { kind: "directive", type: StopPropagationDirective, selector: "[stop-propagation]" }, { kind: "ngmodule", type: DragDropModule }, { kind: "directive", type: i5.CdkDropList, selector: "[cdkDropList], cdk-drop-list", inputs: ["cdkDropListConnectedTo", "cdkDropListData", "cdkDropListOrientation", "id", "cdkDropListLockAxis", "cdkDropListDisabled", "cdkDropListSortingDisabled", "cdkDropListEnterPredicate", "cdkDropListSortPredicate", "cdkDropListAutoScrollDisabled", "cdkDropListAutoScrollStep", "cdkDropListElementContainer"], outputs: ["cdkDropListDropped", "cdkDropListEntered", "cdkDropListExited", "cdkDropListSorted"], exportAs: ["cdkDropList"] }, { kind: "directive", type: i5.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer", "cdkDragScale"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { kind: "pipe", type: SpaceCasePipe, name: "spaceCase" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
39
|
-
}
|
|
40
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: GenColDisplayerComponent, decorators: [{
|
|
41
|
-
type: Component,
|
|
42
|
-
args: [{ selector: 'tb-col-displayer', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [
|
|
43
|
-
AsyncPipe, MatTooltipModule, MatIconModule, MatButtonModule, MatMenuModule, StopPropagationDirective,
|
|
44
|
-
DragDropModule, SpaceCasePipe
|
|
45
|
-
], template: "@if($columns(); as displayCols){\r\n <span matTooltip=\"Show/hide columns\">\r\n <button mat-icon-button [matMenuTriggerFor]=\"menu\">\r\n <mat-icon color=\"primary\">visibility_off</mat-icon>\r\n </button>\r\n </span>\r\n <mat-menu #menu=\"matMenu\" class=\"my-mat-menu\">\r\n\r\n <button mat-menu-item>\r\n <span matTooltip=\"Close\">\r\n <button class=\"filter-button\" mat-icon-button>\r\n <mat-icon>close</mat-icon>\r\n </button>\r\n </span>\r\n </button>\r\n\r\n <button mat-menu-item stop-propagation>\r\n <span matTooltip=\"Show all columns\">\r\n <button mat-icon-button (click)=\"reset(displayCols)\">\r\n <mat-icon color=\"primary\">done_all</mat-icon>\r\n </button>\r\n </span>\r\n\r\n <span matTooltip=\"Hide all columns\">\r\n <button mat-icon-button (click)=\"unset(displayCols)\">\r\n <mat-icon color=\"primary\">cancel</mat-icon>\r\n </button>\r\n </span>\r\n </button>\r\n\r\n <div cdkDropList (cdkDropListDropped)=\"drop($event)\" stop-propagation [cdkDropListLockAxis]=\"'y'\">\r\n @for (col of displayCols; track col.key) {\r\n <button [class.isHidden]=\"!col.isVisible\" stop-propagation mat-menu-item cdkDrag [cdkDragData]=\"col\">\r\n <div (click)=\"col.isVisible = !col.isVisible; emit(displayCols)\" style=\"display: flex; align-items: center;\">\r\n @if(col.isVisible){\r\n <button mat-icon-button matTooltip=\"Hide Column\" class=\"show-hide\">\r\n <mat-icon color=\"primary\">check_box</mat-icon>\r\n </button>\r\n } @else {\r\n <button mat-icon-button matTooltip=\"Show Column\" class=\"show-hide\">\r\n <mat-icon>indeterminate_check_box</mat-icon>\r\n </button>\r\n }\r\n \r\n <p class=\"label\">\r\n {{col.displayName || (col.key | spaceCase) }}\r\n </p>\r\n\r\n </div>\r\n </button>\r\n }\r\n\r\n </div>\r\n </mat-menu>\r\n}", styles: [".show-hide{margin-right:15px;height:24px;width:24px;padding:4px}.label{color:#6495ed;text-overflow:ellipsis;overflow:hidden;white-space:nowrap;text-align:left;margin:0;font-size:17px;font-weight:700;display:inline-block;width:66%}.row{margin:0;padding:0}.isHidden{background-color:#d3d3d3;color:#a9a9a9;font-weight:700;font-size:17px;white-space:nowrap}.filter-button{margin-top:10px}.cdk-drag-preview{box-sizing:border-box;border-radius:4px;box-shadow:0 5px 5px -3px #0003,0 8px 10px 1px #00000024,0 3px 14px 2px #0000001f}.cdk-drag-placeholder{opacity:0}.cdk-drag-animating{transition:transform .25s cubic-bezier(0,0,.2,1)}.mdc-list-item__primary-text{display:inline-block;width:100%}\n"] }]
|
|
46
|
-
}] });
|
|
47
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gen-col-displayer.component.js","sourceRoot":"","sources":["../../../../../../projects/angular-utilities/src/table-builder/components/gen-col-displayer/gen-col-displayer.component.ts","../../../../../../projects/angular-utilities/src/table-builder/components/gen-col-displayer/gen-col-displayer.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,uBAAuB,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AAErF,OAAO,EAAE,UAAU,EAAE,MAAM,2BAA2B,CAAC;AACvD,OAAO,EAAc,cAAc,EAAC,MAAM,wBAAwB,CAAC;AACnE,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAC5C,OAAO,EAAE,gBAAgB,EAAE,MAAM,2BAA2B,CAAC;AAC7D,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAC3D,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,EAAE,aAAa,EAAE,wBAAwB,EAAE,MAAM,oBAAoB,CAAC;;;;;;;AAa7E,MAAM,OAAO,wBAAwB;IAC3B,UAAU,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;IACxC,QAAQ,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,4BAA4B,EAAE,CAAC,GAAG,CAAE,EAAE,CAAC,EAAE,CAAC,CAAC;QACnF,GAAG,EAAE,EAAE,CAAC,GAAG;QACX,WAAW,EAAE,EAAE,CAAC,WAAW;QAC3B,SAAS,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,GAAG,CAAC;KAC3D,CAAC,CAAC,CAAC,CAAC;IAEL,KAAK,CAAC,WAAyB;QAC7B,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,SAAS,GAAG,IAAI,CAAC,CAAC;QAC7C,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;IACzB,CAAC;IACD,IAAI,CAAC,KAA4B;QAC/B,IAAI,CAAC,UAAU,CAAC,mBAAmB,CAAC,EAAE,QAAQ,EAAE,KAAK,CAAC,YAAY,EAAE,QAAQ,EAAC,KAAK,CAAC,aAAa,EAAE,CAAC,CAAA;IACrG,CAAC;IACD,KAAK,CAAC,WAAyB;QAC7B,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,SAAS,GAAG,KAAK,CAAC,CAAC;QAC9C,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;IACzB,CAAC;IAED,IAAI,CAAC,WAAyB;QAC5B,IAAI,CAAC,UAAU,CAAC,gBAAgB,CAAC,WAAW,CAAC,GAAG,CAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAC,GAAG,EAAE,CAAC,CAAC,GAAG,EAAE,OAAO,EAAE,CAAC,CAAC,SAAS,EAAC,CAAC,CAAC,CAAC,CAAC;IAChG,CAAC;uGAtBU,wBAAwB;2FAAxB,wBAAwB,4ECtBrC,8gEAsDC,yuBDpCc,gBAAgB,4TAAE,aAAa,mLAAE,eAAe,2IAAE,aAAa,8vBAAE,wBAAwB,8DACpG,cAAc,w/BAAE,aAAa;;2FAGpB,wBAAwB;kBAXpC,SAAS;+BACE,kBAAkB,mBAGX,uBAAuB,CAAC,MAAM,cACnC,IAAI,WACP;wBACP,SAAS,EAAE,gBAAgB,EAAE,aAAa,EAAE,eAAe,EAAE,aAAa,EAAE,wBAAwB;wBACpG,cAAc,EAAE,aAAa;qBAC9B","sourcesContent":["import { Component, ChangeDetectionStrategy, inject, computed } from '@angular/core';\r\nimport { DisplayCol } from '../../classes/display-col';\r\nimport { TableStore } from '../../classes/table-store';\r\nimport {CdkDragDrop, DragDropModule} from '@angular/cdk/drag-drop';\r\nimport { AsyncPipe } from '@angular/common';\r\nimport { MatTooltipModule } from '@angular/material/tooltip';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport { MatMenuModule } from '@angular/material/menu';\r\nimport { SpaceCasePipe, StopPropagationDirective } from '../../../utilities';\r\n\r\n@Component({\r\n  selector: 'tb-col-displayer',\r\n  templateUrl: './gen-col-displayer.component.html',\r\n  styleUrls: ['./gen-col-displayer.component.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush ,\r\n  standalone: true,\r\n  imports: [\r\n    AsyncPipe, MatTooltipModule, MatIconModule, MatButtonModule, MatMenuModule, StopPropagationDirective,\r\n    DragDropModule, SpaceCasePipe\r\n  ]\r\n})\r\nexport class GenColDisplayerComponent {\r\n  private tableState = inject(TableStore);\r\n  $columns = computed(() => this.tableState.$orderedCodeVisibleMetaDatas().map( md => ({\r\n    key: md.key,\r\n    displayName: md.displayName,\r\n    isVisible: !this.tableState.$hiddenKeys().includes(md.key)\r\n  })));\r\n\r\n  reset(displayCols: DisplayCol[]) {\r\n    displayCols.forEach(c => c.isVisible = true);\r\n    this.emit(displayCols);\r\n  }\r\n  drop(event: CdkDragDrop<string[]>) {\r\n    this.tableState.setUserDefinedOrder({ newOrder: event.currentIndex, oldOrder:event.previousIndex })\r\n  }\r\n  unset(displayCols: DisplayCol[]) {\r\n    displayCols.forEach(c => c.isVisible = false);\r\n    this.emit(displayCols);\r\n  }\r\n\r\n  emit(displayCols: DisplayCol[]) {\r\n    this.tableState.setHiddenColumns(displayCols.map( c => ({key: c.key, visible: c.isVisible})));\r\n  }\r\n}\r\n","@if($columns(); as displayCols){\r\n  <span matTooltip=\"Show/hide columns\">\r\n    <button mat-icon-button [matMenuTriggerFor]=\"menu\">\r\n      <mat-icon color=\"primary\">visibility_off</mat-icon>\r\n    </button>\r\n  </span>\r\n  <mat-menu #menu=\"matMenu\" class=\"my-mat-menu\">\r\n\r\n    <button mat-menu-item>\r\n      <span matTooltip=\"Close\">\r\n        <button class=\"filter-button\" mat-icon-button>\r\n          <mat-icon>close</mat-icon>\r\n        </button>\r\n      </span>\r\n    </button>\r\n\r\n    <button mat-menu-item stop-propagation>\r\n      <span matTooltip=\"Show all columns\">\r\n        <button mat-icon-button (click)=\"reset(displayCols)\">\r\n          <mat-icon color=\"primary\">done_all</mat-icon>\r\n        </button>\r\n      </span>\r\n\r\n      <span matTooltip=\"Hide all columns\">\r\n        <button mat-icon-button (click)=\"unset(displayCols)\">\r\n          <mat-icon color=\"primary\">cancel</mat-icon>\r\n        </button>\r\n      </span>\r\n    </button>\r\n\r\n    <div cdkDropList (cdkDropListDropped)=\"drop($event)\" stop-propagation [cdkDropListLockAxis]=\"'y'\">\r\n      @for (col of displayCols; track col.key) {\r\n        <button [class.isHidden]=\"!col.isVisible\" stop-propagation mat-menu-item cdkDrag [cdkDragData]=\"col\">\r\n        <div (click)=\"col.isVisible = !col.isVisible; emit(displayCols)\" style=\"display: flex; align-items: center;\">\r\n          @if(col.isVisible){\r\n            <button mat-icon-button matTooltip=\"Hide Column\" class=\"show-hide\">\r\n              <mat-icon color=\"primary\">check_box</mat-icon>\r\n            </button>\r\n          } @else {\r\n            <button mat-icon-button matTooltip=\"Show Column\" class=\"show-hide\">\r\n              <mat-icon>indeterminate_check_box</mat-icon>\r\n            </button>\r\n          }\r\n          \r\n          <p class=\"label\">\r\n            {{col.displayName || (col.key | spaceCase) }}\r\n          </p>\r\n\r\n        </div>\r\n      </button>\r\n      }\r\n\r\n    </div>\r\n  </mat-menu>\r\n}"]}
|
|
@@ -1,306 +0,0 @@
|
|
|
1
|
-
import { Component, ViewChild, Input, ChangeDetectionStrategy, Output, ViewContainerRef, Injector, EventEmitter, computed, inject, input, viewChild, effect, untracked, signal } from '@angular/core';
|
|
2
|
-
import { MatFooterRowDef, MatHeaderRowDef, MatTable, MatTableModule } from '@angular/material/table';
|
|
3
|
-
import { SelectionModel } from '@angular/cdk/collections';
|
|
4
|
-
import { TableStore } from '../../classes/table-store';
|
|
5
|
-
import { map } from 'rxjs/operators';
|
|
6
|
-
import { ColumnBuilderComponent } from '../column-builder/column-builder.component';
|
|
7
|
-
import { previousAndCurrent } from '../../../rxjs/rxjs-operators';
|
|
8
|
-
import { CdkDropList, DragDropModule } from '@angular/cdk/drag-drop';
|
|
9
|
-
import { FunctionPipe } from '../../../utilities';
|
|
10
|
-
import { MatCheckboxModule } from '@angular/material/checkbox';
|
|
11
|
-
import { MatButtonModule } from '@angular/material/button';
|
|
12
|
-
import { MatIconModule } from '@angular/material/icon';
|
|
13
|
-
import { AsyncPipe, NgTemplateOutlet } from '@angular/common';
|
|
14
|
-
import { MatTooltipModule } from '@angular/material/tooltip';
|
|
15
|
-
import { TransformCreator } from '../../services/transform-creator';
|
|
16
|
-
import { initIndexSymbol } from '../table-container/table-container.helpers/sort-state.helpers';
|
|
17
|
-
import { toObservable } from '@angular/core/rxjs-interop';
|
|
18
|
-
import { DataStore } from '../../classes/data-store';
|
|
19
|
-
import * as i0 from "@angular/core";
|
|
20
|
-
import * as i1 from "@angular/material/table";
|
|
21
|
-
import * as i2 from "@angular/cdk/drag-drop";
|
|
22
|
-
import * as i3 from "@angular/material/checkbox";
|
|
23
|
-
import * as i4 from "@angular/material/button";
|
|
24
|
-
import * as i5 from "@angular/material/icon";
|
|
25
|
-
export class GenericTableComponent {
|
|
26
|
-
state = inject(TableStore);
|
|
27
|
-
dataStore = inject(DataStore);
|
|
28
|
-
viewContainer = inject(ViewContainerRef);
|
|
29
|
-
transformCreator = inject(TransformCreator);
|
|
30
|
-
smallFooter = 10;
|
|
31
|
-
$headerRow = viewChild(MatHeaderRowDef);
|
|
32
|
-
$footerRow = viewChild(MatFooterRowDef);
|
|
33
|
-
$table = viewChild(MatTable);
|
|
34
|
-
drop(event) {
|
|
35
|
-
this.state.setUserDefinedOrder({ newOrder: event.currentIndex, oldOrder: event.previousIndex });
|
|
36
|
-
}
|
|
37
|
-
_trackBy;
|
|
38
|
-
set trackBy(trackBy) {
|
|
39
|
-
if (trackBy) {
|
|
40
|
-
this._trackBy = trackBy;
|
|
41
|
-
this.trackByFunction = (index, item) => item[trackBy];
|
|
42
|
-
}
|
|
43
|
-
this.setUpSelections(trackBy);
|
|
44
|
-
}
|
|
45
|
-
get trackBy() { return this._trackBy; }
|
|
46
|
-
$displayData = input.required({ alias: 'displayData' });
|
|
47
|
-
$displayDataLength = computed(() => this.$displayData()?.length || 0);
|
|
48
|
-
$hasFooterMeta = computed(() => this.state.$metaDataArray().some(md => !!md.additional?.footer));
|
|
49
|
-
$data = input.required({ alias: 'data' });
|
|
50
|
-
data$ = toObservable(this.$data);
|
|
51
|
-
$rows = input([], { alias: 'rows' });
|
|
52
|
-
$columnInfos = input.required({ alias: 'columnInfos' });
|
|
53
|
-
$hasCustomFooter = computed(() => this.$columnInfos()?.some(ci => !!ci.customCell?.columnDef?.footerCell));
|
|
54
|
-
dropList;
|
|
55
|
-
$footerRowStyle = computed(() => {
|
|
56
|
-
const hasData = !!this.$displayDataLength();
|
|
57
|
-
const metaFooter = this.$hasFooterMeta();
|
|
58
|
-
const customFooter = this.$hasCustomFooter();
|
|
59
|
-
const hasSelectionColumn = this.state.props().selectionColumn;
|
|
60
|
-
return customFooter || (hasData && (metaFooter || hasSelectionColumn)) ? 'regular-footer' : hasData ? 'no-footer' : 'small-footer';
|
|
61
|
-
});
|
|
62
|
-
$showFooterRow = computed(() => this.$footerRowStyle() !== 'no-footer');
|
|
63
|
-
_injector = inject(Injector);
|
|
64
|
-
injector = Injector.create({
|
|
65
|
-
providers: [
|
|
66
|
-
{ provide: MatTable, useFactory: () => this.$table() },
|
|
67
|
-
{ provide: CdkDropList, useFactory: () => this.dropList },
|
|
68
|
-
],
|
|
69
|
-
parent: this._injector
|
|
70
|
-
});
|
|
71
|
-
$hasSelectColumn = computed(() => this.state.selectSignal(state => state.props.selectionColumn)());
|
|
72
|
-
$hasIndexColumn = computed(() => this.state.selectSignal(state => state.props.indexColumn)());
|
|
73
|
-
$columns = signal({});
|
|
74
|
-
$showHeader = computed(() => !this.state.tableSettings().hideColumnHeader);
|
|
75
|
-
offset$ = this.dataStore.select(s => s.virtualScrollOffset);
|
|
76
|
-
constructor() {
|
|
77
|
-
this.setUpSelections();
|
|
78
|
-
effect(() => {
|
|
79
|
-
const columnInfos = this.$columnInfos() || [];
|
|
80
|
-
const table = this.$table();
|
|
81
|
-
if (!table)
|
|
82
|
-
return;
|
|
83
|
-
untracked(() => {
|
|
84
|
-
Object.entries(this.$columns()).forEach(([key, value]) => {
|
|
85
|
-
const columnInfo = columnInfos.find(ci => ci.metaData.key === key);
|
|
86
|
-
if (!columnInfo || columnInfo.customCell !== value.customCell) {
|
|
87
|
-
delete this.$columns()[key];
|
|
88
|
-
table?.removeColumnDef(value.columnDef);
|
|
89
|
-
}
|
|
90
|
-
});
|
|
91
|
-
columnInfos.forEach(ci => this.buildColumn(ci));
|
|
92
|
-
});
|
|
93
|
-
});
|
|
94
|
-
effect(() => {
|
|
95
|
-
const table = this.$table();
|
|
96
|
-
const rows = this.$rows();
|
|
97
|
-
const keys = this.$keys();
|
|
98
|
-
if (!table)
|
|
99
|
-
return;
|
|
100
|
-
untracked(() => {
|
|
101
|
-
rows.forEach(row => {
|
|
102
|
-
table.removeRowDef(row);
|
|
103
|
-
row.columns = keys;
|
|
104
|
-
table.addRowDef(row);
|
|
105
|
-
});
|
|
106
|
-
});
|
|
107
|
-
});
|
|
108
|
-
effect(() => {
|
|
109
|
-
const headerRow = this.$headerRow();
|
|
110
|
-
const showHeader = this.$showHeader();
|
|
111
|
-
const table = this.$table();
|
|
112
|
-
untracked(() => {
|
|
113
|
-
if (headerRow && showHeader && table)
|
|
114
|
-
table.addHeaderRowDef(headerRow);
|
|
115
|
-
else if (headerRow && table)
|
|
116
|
-
table.removeHeaderRowDef(headerRow);
|
|
117
|
-
});
|
|
118
|
-
});
|
|
119
|
-
effect(() => {
|
|
120
|
-
const footerRow = this.$footerRow();
|
|
121
|
-
const showFooter = this.$showFooterRow();
|
|
122
|
-
const table = this.$table();
|
|
123
|
-
untracked(() => {
|
|
124
|
-
if (footerRow && showFooter && table)
|
|
125
|
-
table.addFooterRowDef(footerRow);
|
|
126
|
-
else if (footerRow && table)
|
|
127
|
-
table.removeFooterRowDef(footerRow);
|
|
128
|
-
});
|
|
129
|
-
});
|
|
130
|
-
}
|
|
131
|
-
defaultTrackBy = (index, item) => item[initIndexSymbol];
|
|
132
|
-
trackByFunction = this.defaultTrackBy;
|
|
133
|
-
$keys = computed(() => {
|
|
134
|
-
const displayed = this.state.$orderedVisibleColumns();
|
|
135
|
-
const built = this.$columns();
|
|
136
|
-
const keys = displayed.filter(d => !!built[d]);
|
|
137
|
-
if (this.$hasSelectColumn()) {
|
|
138
|
-
keys.unshift('select');
|
|
139
|
-
}
|
|
140
|
-
if (this.$hasIndexColumn()) {
|
|
141
|
-
keys.unshift('index');
|
|
142
|
-
}
|
|
143
|
-
return keys;
|
|
144
|
-
});
|
|
145
|
-
keys$ = toObservable(this.$keys);
|
|
146
|
-
ngOnInit() {
|
|
147
|
-
this.state.on(this.selectableData$, (data) => {
|
|
148
|
-
if (this.selection.selected.length) {
|
|
149
|
-
const trackByFunction = this.trackBy ? (s) => data.every(d => d[this.trackBy] !== s[this.trackBy]) : s => !data.includes(s);
|
|
150
|
-
const removed = this.selection.selected.filter(trackByFunction);
|
|
151
|
-
this.selection.deselect(...removed);
|
|
152
|
-
}
|
|
153
|
-
});
|
|
154
|
-
}
|
|
155
|
-
$usePaginator = computed(() => this.state.tableSettings().usePaginator);
|
|
156
|
-
$useVirtualScroll = computed(() => this.state.$viewType().includes('virtual'));
|
|
157
|
-
$offsetIndex = computed(() => {
|
|
158
|
-
const virtualStart = this.dataStore.selectSignal(d => d.virtualEnds.start)();
|
|
159
|
-
const pageSize = this.state.$pageSize();
|
|
160
|
-
const currentPage = this.state.$currentPage();
|
|
161
|
-
if (this.$useVirtualScroll()) {
|
|
162
|
-
return virtualStart;
|
|
163
|
-
}
|
|
164
|
-
if (this.$usePaginator()) {
|
|
165
|
-
return pageSize * currentPage;
|
|
166
|
-
}
|
|
167
|
-
return 0;
|
|
168
|
-
});
|
|
169
|
-
isGroupHeader(_, row) {
|
|
170
|
-
return row.isGroupHeader;
|
|
171
|
-
}
|
|
172
|
-
setExpanded(key, groupKey, isExpanded) {
|
|
173
|
-
this.state.updateExpandedGroups({ key, isExpanded, groupKey });
|
|
174
|
-
}
|
|
175
|
-
buildColumn(column) {
|
|
176
|
-
const alreadyBuiltColumn = this.$columns()[column.metaData.key];
|
|
177
|
-
if (alreadyBuiltColumn) {
|
|
178
|
-
alreadyBuiltColumn.metaData = column.metaData;
|
|
179
|
-
}
|
|
180
|
-
else {
|
|
181
|
-
const component = this.viewContainer.createComponent(ColumnBuilderComponent, {
|
|
182
|
-
index: 0,
|
|
183
|
-
injector: this.injector
|
|
184
|
-
});
|
|
185
|
-
component.instance.customCell = column.customCell;
|
|
186
|
-
component.instance.metaData = column.metaData;
|
|
187
|
-
component.instance.data$ = this.data$;
|
|
188
|
-
component.instance.whenViewInited(() => {
|
|
189
|
-
this.$columns.update(columnsDict => ({
|
|
190
|
-
...columnsDict,
|
|
191
|
-
[column.metaData.key]: component.instance
|
|
192
|
-
}));
|
|
193
|
-
});
|
|
194
|
-
}
|
|
195
|
-
}
|
|
196
|
-
selection;
|
|
197
|
-
selection$ = new EventEmitter();
|
|
198
|
-
masterToggleChecked$ = this.selection$.pipe(map(() => this.selection.hasValue() && this.isAllSelected()));
|
|
199
|
-
masterToggleIndeterminate$ = this.selection$.pipe(map(() => this.selection.hasValue() && !this.isAllSelected()));
|
|
200
|
-
setUpSelections(trackBy) {
|
|
201
|
-
this.selection = trackBy ? new SelectionModel(true, [], true, (a, b) => a[trackBy] === b[trackBy]) : new SelectionModel(true, []);
|
|
202
|
-
this.state.on(this.selection.changed, c => this.selection$.emit(c));
|
|
203
|
-
}
|
|
204
|
-
$selectableData = computed(() => {
|
|
205
|
-
if (this.state.$viewType() === 'virtual paginator' || this.state.$viewType() === 'paginator') {
|
|
206
|
-
const previousPageRecords = this.state.$currentPage() * this.state.$pageSize();
|
|
207
|
-
return this.$data().slice(previousPageRecords, previousPageRecords + this.state.$pageSize());
|
|
208
|
-
}
|
|
209
|
-
else if (this.state.$viewType() === 'all' || this.state.$viewType() === 'virtual all') {
|
|
210
|
-
return this.$data();
|
|
211
|
-
}
|
|
212
|
-
return [];
|
|
213
|
-
});
|
|
214
|
-
selectableData$ = toObservable(this.$selectableData);
|
|
215
|
-
isAllSelected() {
|
|
216
|
-
const numSelected = this.selection.selected.length;
|
|
217
|
-
const numRows = this.$selectableData()?.length || 0;
|
|
218
|
-
return numSelected === numRows;
|
|
219
|
-
}
|
|
220
|
-
/** Selects all rows if they are not all selected; otherwise clear selection. */
|
|
221
|
-
masterToggle() {
|
|
222
|
-
if (this.isAllSelected()) {
|
|
223
|
-
this.selection.clear();
|
|
224
|
-
}
|
|
225
|
-
else {
|
|
226
|
-
this.selection.select(...this.$selectableData());
|
|
227
|
-
}
|
|
228
|
-
}
|
|
229
|
-
tableWidth = this.state.getUserDefinedTableSize$.pipe(previousAndCurrent(0), map(([previousUserDefinedWidth, currentUserDefinedWidth]) => {
|
|
230
|
-
if (currentUserDefinedWidth) {
|
|
231
|
-
return ({ width: `${currentUserDefinedWidth}px`, minWidth: 'fit-content' });
|
|
232
|
-
}
|
|
233
|
-
if (wasReset()) {
|
|
234
|
-
return ({ width: 'initial' });
|
|
235
|
-
}
|
|
236
|
-
return ({});
|
|
237
|
-
function wasReset() {
|
|
238
|
-
return (previousUserDefinedWidth ?? 0) >= 0 && currentUserDefinedWidth == null;
|
|
239
|
-
}
|
|
240
|
-
}));
|
|
241
|
-
getTransform = (key, val) => {
|
|
242
|
-
if (val == undefined || val === 'null')
|
|
243
|
-
return '';
|
|
244
|
-
try {
|
|
245
|
-
return this.transformCreator.createTransformer(this.$columns[key].metaData, true)({ [key]: val });
|
|
246
|
-
}
|
|
247
|
-
catch (error) {
|
|
248
|
-
return val;
|
|
249
|
-
}
|
|
250
|
-
};
|
|
251
|
-
$rowHeight = this.state.selectSignal(s => {
|
|
252
|
-
if (this.state.$isVirtual() && s.notPersistedTableSettings.useVirtualScroll?.enforceRowHeight) {
|
|
253
|
-
const height = s.notPersistedTableSettings.useVirtualScroll.rowHeight;
|
|
254
|
-
return height + 'px';
|
|
255
|
-
}
|
|
256
|
-
if (typeof s.notPersistedTableSettings.rowHeight === 'number') {
|
|
257
|
-
return s.notPersistedTableSettings.rowHeight + 'px';
|
|
258
|
-
}
|
|
259
|
-
return s.notPersistedTableSettings.rowHeight;
|
|
260
|
-
});
|
|
261
|
-
$headerHeight = this.state.selectSignal(s => {
|
|
262
|
-
if (this.state.$isVirtual() && s.notPersistedTableSettings.useVirtualScroll?.enforceHeaderHeight) {
|
|
263
|
-
const height = s.notPersistedTableSettings.useVirtualScroll.headerHeight;
|
|
264
|
-
return height + 'px';
|
|
265
|
-
}
|
|
266
|
-
if (typeof s.notPersistedTableSettings.headerHeight === 'number') {
|
|
267
|
-
return s.notPersistedTableSettings.headerHeight + 'px';
|
|
268
|
-
}
|
|
269
|
-
return s.notPersistedTableSettings.headerHeight;
|
|
270
|
-
});
|
|
271
|
-
$groupHeaderHeight = this.state.selectSignal(s => {
|
|
272
|
-
if (s.notPersistedTableSettings.groupHeaderHeight) {
|
|
273
|
-
return s.notPersistedTableSettings.groupHeaderHeight + 'px';
|
|
274
|
-
}
|
|
275
|
-
return this.$rowHeight();
|
|
276
|
-
});
|
|
277
|
-
$footerHeight = this.state.selectSignal(s => {
|
|
278
|
-
const footerStyle = this.$footerRowStyle();
|
|
279
|
-
switch (footerStyle) {
|
|
280
|
-
case 'regular-footer':
|
|
281
|
-
return this.$rowHeight();
|
|
282
|
-
case 'small-footer':
|
|
283
|
-
return `${this.smallFooter}px`;
|
|
284
|
-
default:
|
|
285
|
-
return '0px';
|
|
286
|
-
}
|
|
287
|
-
});
|
|
288
|
-
$stickyFooter = computed(() => this.state.props().stickyFooter || this.state.$isVirtual());
|
|
289
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: GenericTableComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
290
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.2", type: GenericTableComponent, isStandalone: true, selector: "tb-generic-table", inputs: { trackBy: { classPropertyName: "trackBy", publicName: "trackBy", isSignal: false, isRequired: false, transformFunction: null }, $displayData: { classPropertyName: "$displayData", publicName: "displayData", isSignal: true, isRequired: true, transformFunction: null }, $data: { classPropertyName: "$data", publicName: "data", isSignal: true, isRequired: true, transformFunction: null }, $rows: { classPropertyName: "$rows", publicName: "rows", isSignal: true, isRequired: false, transformFunction: null }, $columnInfos: { classPropertyName: "$columnInfos", publicName: "columnInfos", isSignal: true, isRequired: true, transformFunction: null } }, outputs: { selection$: "selection$" }, viewQueries: [{ propertyName: "$headerRow", first: true, predicate: MatHeaderRowDef, descendants: true, isSignal: true }, { propertyName: "$footerRow", first: true, predicate: MatFooterRowDef, descendants: true, isSignal: true }, { propertyName: "$table", first: true, predicate: MatTable, descendants: true, isSignal: true }, { propertyName: "dropList", first: true, predicate: CdkDropList, descendants: true, static: true }], ngImport: i0, template: "<mat-table\r\n cdkDropList\r\n cdkDropListLockAxis='x'\r\n cdkDropListOrientation=\"horizontal\"\r\n (cdkDropListDropped)=\"drop($event)\"\r\n class=\"table-drag-list\"\r\n #table\r\n [dataSource]=\"state.props().dataSource!\"\r\n [trackBy]=\"trackByFunction\"\r\n [style]=\"tableWidth | async \"\r\n>\r\n\r\n <!-- select column -->\r\n <ng-container matColumnDef=\"select\">\r\n\r\n <mat-header-cell *matHeaderCellDef class=\"select-column\">\r\n <mat-checkbox (change)=\"$event ? masterToggle() : null\"\r\n [checked]=\"!!(masterToggleChecked$ | async)\"\r\n [indeterminate]=\"masterToggleIndeterminate$ | async\">\r\n </mat-checkbox>\r\n </mat-header-cell>\r\n\r\n <mat-cell *matCellDef=\"let row\" class=\"select-column\">\r\n <mat-checkbox\r\n (click)=\"$event.stopPropagation()\"\r\n (change)=\"$event ? selection.toggle(row) : null\"\r\n [checked]=\"selection.isSelected(row)\"/>\r\n </mat-cell>\r\n\r\n <mat-footer-cell *matFooterCellDef class=\"select-column\">\r\n {{ selection.selected.length }}\r\n </mat-footer-cell>\r\n </ng-container>\r\n\r\n\r\n <!-- index column -->\r\n <ng-container matColumnDef=\"index\">\r\n <mat-header-cell *matHeaderCellDef class=\"f-mat-header-cell\" class=\"index-column\">#\r\n </mat-header-cell>\r\n <mat-cell *matCellDef=\"let i = index;\" class=\"index-column\">\r\n {{ 1 + i + $offsetIndex() }}\r\n </mat-cell>\r\n <mat-footer-cell *matFooterCellDef class=\"index-column\"></mat-footer-cell>\r\n </ng-container>\r\n\r\n <!-- Grouping -->\r\n <ng-container matColumnDef=\"groupHeader\">\r\n <mat-cell *matCellDef=\"let row\">\r\n @let expanded = (state.getIsExpanded | func : row.key : row.groupName );\r\n <div [style.paddingLeft]=\"row.padding + 'px !important'\">\r\n <button mat-icon-button (click)=\"setExpanded(row.key, row.groupName, !expanded());\">\r\n @if (!expanded()) {\r\n <mat-icon>chevron_right</mat-icon>\r\n } @else {\r\n <mat-icon>expand_more</mat-icon>\r\n }\r\n </button>\r\n {{ getTransform | func : row.key : row.groupHeaderDisplay }} ({{ row.length }})\r\n </div>\r\n <div style=\"flex-grow: 1\">\r\n <ng-container *ngTemplateOutlet=\"state.props().groupHeaderTemplate!; context: { element: row }\"></ng-container>\r\n </div>\r\n </mat-cell>\r\n </ng-container>\r\n\r\n <mat-row [style.height]=\"$rowHeight()\" [style.min-height]=\"$rowHeight()\"\r\n *matRowDef=\"let row; columns: $keys(); let i = index\"/>\r\n <mat-row [style.height]=\"state.props().groupHeaderHeight ? state.props().groupHeaderHeight + 'px' : $groupHeaderHeight()\"\r\n [style.min-height]=\"state.props().groupHeaderHeight ? state.props().groupHeaderHeight + 'px' : $groupHeaderHeight()\"\r\n *matRowDef=\"let row; columns: ['groupHeader']; when: isGroupHeader\" style=\"background-color: white;\"/>\r\n</mat-table>\r\n\r\n<mat-header-row [style.height]=\"$headerHeight()\" [style.min-height]=\"$headerHeight()\"\r\n *matHeaderRowDef=\"$keys(); sticky: state.props().isSticky\" [style.top.px]=\"((offset$ | async)! * -1)\"/>\r\n<mat-footer-row [style.height]=\"$footerHeight()\" [style.min-height]=\"$footerHeight()\"\r\n *matFooterRowDef=\"$keys(); sticky: $stickyFooter() \"\r\n [style.bottom.px]=\"$stickyFooter() ? (offset$ | async) : undefined\"/>\r\n", styles: [":host{--mat-paginator-container-size: initial}.select-column{min-width:var(--tb-min-select-column-width, 42px)}.index-column{min-width:var(--tb-min-index-column-width, 42px)}.mat-mdc-row:nth-child(odd){background-color:var(--tb-odd-row-background-color, #cdeefe)}.page-amounts{color:#0000008a;font-family:Roboto,Helvetica Neue,sans-serif;font-size:12px;margin-right:.2rem}:host::ng-deep .table-drag-list.cdk-drop-list-dragging .drag-header:not(.cdk-drag-placeholder){transition:transform .25s cubic-bezier(0,0,.2,1)}:host::ng-deep .mdc-data-table__cell,:host::ng-deep .mdc-data-table__header-cell{padding:var(--tb-cell-padding, 0 0 0 .2rem);line-height:var(--tb-cell-line-height, normal)}::ng-deep .op-date-time-input{line-height:3rem;font-size:.9rem;font-family:Roboto,Helvetica Neue,sans-serif;padding-left:.2rem;width:12rem}\n"], dependencies: [{ kind: "ngmodule", type: MatTableModule }, { kind: "component", type: i1.MatTable, selector: "mat-table, table[mat-table]", exportAs: ["matTable"] }, { kind: "directive", type: i1.MatHeaderCellDef, selector: "[matHeaderCellDef]" }, { kind: "directive", type: i1.MatHeaderRowDef, selector: "[matHeaderRowDef]", inputs: ["matHeaderRowDef", "matHeaderRowDefSticky"] }, { kind: "directive", type: i1.MatColumnDef, selector: "[matColumnDef]", inputs: ["matColumnDef"] }, { kind: "directive", type: i1.MatCellDef, selector: "[matCellDef]" }, { kind: "directive", type: i1.MatRowDef, selector: "[matRowDef]", inputs: ["matRowDefColumns", "matRowDefWhen"] }, { kind: "directive", type: i1.MatFooterCellDef, selector: "[matFooterCellDef]" }, { kind: "directive", type: i1.MatFooterRowDef, selector: "[matFooterRowDef]", inputs: ["matFooterRowDef", "matFooterRowDefSticky"] }, { kind: "directive", type: i1.MatHeaderCell, selector: "mat-header-cell, th[mat-header-cell]" }, { kind: "directive", type: i1.MatCell, selector: "mat-cell, td[mat-cell]" }, { kind: "directive", type: i1.MatFooterCell, selector: "mat-footer-cell, td[mat-footer-cell]" }, { kind: "component", type: i1.MatHeaderRow, selector: "mat-header-row, tr[mat-header-row]", exportAs: ["matHeaderRow"] }, { kind: "component", type: i1.MatRow, selector: "mat-row, tr[mat-row]", exportAs: ["matRow"] }, { kind: "component", type: i1.MatFooterRow, selector: "mat-footer-row, tr[mat-footer-row]", exportAs: ["matFooterRow"] }, { kind: "ngmodule", type: DragDropModule }, { kind: "directive", type: i2.CdkDropList, selector: "[cdkDropList], cdk-drop-list", inputs: ["cdkDropListConnectedTo", "cdkDropListData", "cdkDropListOrientation", "id", "cdkDropListLockAxis", "cdkDropListDisabled", "cdkDropListSortingDisabled", "cdkDropListEnterPredicate", "cdkDropListSortPredicate", "cdkDropListAutoScrollDisabled", "cdkDropListAutoScrollStep", "cdkDropListElementContainer"], outputs: ["cdkDropListDropped", "cdkDropListEntered", "cdkDropListExited", "cdkDropListSorted"], exportAs: ["cdkDropList"] }, { kind: "ngmodule", type: MatCheckboxModule }, { kind: "component", type: i3.MatCheckbox, selector: "mat-checkbox", inputs: ["aria-label", "aria-labelledby", "aria-describedby", "id", "required", "labelPosition", "name", "value", "disableRipple", "tabIndex", "color", "disabledInteractive", "checked", "disabled", "indeterminate"], outputs: ["change", "indeterminateChange"], exportAs: ["matCheckbox"] }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i4.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "pipe", type: FunctionPipe, name: "func" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
291
|
-
}
|
|
292
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: GenericTableComponent, decorators: [{
|
|
293
|
-
type: Component,
|
|
294
|
-
args: [{ selector: 'tb-generic-table', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [
|
|
295
|
-
MatTableModule, DragDropModule, MatCheckboxModule, MatButtonModule, MatIconModule, NgTemplateOutlet,
|
|
296
|
-
MatTooltipModule, AsyncPipe, FunctionPipe,
|
|
297
|
-
], template: "<mat-table\r\n cdkDropList\r\n cdkDropListLockAxis='x'\r\n cdkDropListOrientation=\"horizontal\"\r\n (cdkDropListDropped)=\"drop($event)\"\r\n class=\"table-drag-list\"\r\n #table\r\n [dataSource]=\"state.props().dataSource!\"\r\n [trackBy]=\"trackByFunction\"\r\n [style]=\"tableWidth | async \"\r\n>\r\n\r\n <!-- select column -->\r\n <ng-container matColumnDef=\"select\">\r\n\r\n <mat-header-cell *matHeaderCellDef class=\"select-column\">\r\n <mat-checkbox (change)=\"$event ? masterToggle() : null\"\r\n [checked]=\"!!(masterToggleChecked$ | async)\"\r\n [indeterminate]=\"masterToggleIndeterminate$ | async\">\r\n </mat-checkbox>\r\n </mat-header-cell>\r\n\r\n <mat-cell *matCellDef=\"let row\" class=\"select-column\">\r\n <mat-checkbox\r\n (click)=\"$event.stopPropagation()\"\r\n (change)=\"$event ? selection.toggle(row) : null\"\r\n [checked]=\"selection.isSelected(row)\"/>\r\n </mat-cell>\r\n\r\n <mat-footer-cell *matFooterCellDef class=\"select-column\">\r\n {{ selection.selected.length }}\r\n </mat-footer-cell>\r\n </ng-container>\r\n\r\n\r\n <!-- index column -->\r\n <ng-container matColumnDef=\"index\">\r\n <mat-header-cell *matHeaderCellDef class=\"f-mat-header-cell\" class=\"index-column\">#\r\n </mat-header-cell>\r\n <mat-cell *matCellDef=\"let i = index;\" class=\"index-column\">\r\n {{ 1 + i + $offsetIndex() }}\r\n </mat-cell>\r\n <mat-footer-cell *matFooterCellDef class=\"index-column\"></mat-footer-cell>\r\n </ng-container>\r\n\r\n <!-- Grouping -->\r\n <ng-container matColumnDef=\"groupHeader\">\r\n <mat-cell *matCellDef=\"let row\">\r\n @let expanded = (state.getIsExpanded | func : row.key : row.groupName );\r\n <div [style.paddingLeft]=\"row.padding + 'px !important'\">\r\n <button mat-icon-button (click)=\"setExpanded(row.key, row.groupName, !expanded());\">\r\n @if (!expanded()) {\r\n <mat-icon>chevron_right</mat-icon>\r\n } @else {\r\n <mat-icon>expand_more</mat-icon>\r\n }\r\n </button>\r\n {{ getTransform | func : row.key : row.groupHeaderDisplay }} ({{ row.length }})\r\n </div>\r\n <div style=\"flex-grow: 1\">\r\n <ng-container *ngTemplateOutlet=\"state.props().groupHeaderTemplate!; context: { element: row }\"></ng-container>\r\n </div>\r\n </mat-cell>\r\n </ng-container>\r\n\r\n <mat-row [style.height]=\"$rowHeight()\" [style.min-height]=\"$rowHeight()\"\r\n *matRowDef=\"let row; columns: $keys(); let i = index\"/>\r\n <mat-row [style.height]=\"state.props().groupHeaderHeight ? state.props().groupHeaderHeight + 'px' : $groupHeaderHeight()\"\r\n [style.min-height]=\"state.props().groupHeaderHeight ? state.props().groupHeaderHeight + 'px' : $groupHeaderHeight()\"\r\n *matRowDef=\"let row; columns: ['groupHeader']; when: isGroupHeader\" style=\"background-color: white;\"/>\r\n</mat-table>\r\n\r\n<mat-header-row [style.height]=\"$headerHeight()\" [style.min-height]=\"$headerHeight()\"\r\n *matHeaderRowDef=\"$keys(); sticky: state.props().isSticky\" [style.top.px]=\"((offset$ | async)! * -1)\"/>\r\n<mat-footer-row [style.height]=\"$footerHeight()\" [style.min-height]=\"$footerHeight()\"\r\n *matFooterRowDef=\"$keys(); sticky: $stickyFooter() \"\r\n [style.bottom.px]=\"$stickyFooter() ? (offset$ | async) : undefined\"/>\r\n", styles: [":host{--mat-paginator-container-size: initial}.select-column{min-width:var(--tb-min-select-column-width, 42px)}.index-column{min-width:var(--tb-min-index-column-width, 42px)}.mat-mdc-row:nth-child(odd){background-color:var(--tb-odd-row-background-color, #cdeefe)}.page-amounts{color:#0000008a;font-family:Roboto,Helvetica Neue,sans-serif;font-size:12px;margin-right:.2rem}:host::ng-deep .table-drag-list.cdk-drop-list-dragging .drag-header:not(.cdk-drag-placeholder){transition:transform .25s cubic-bezier(0,0,.2,1)}:host::ng-deep .mdc-data-table__cell,:host::ng-deep .mdc-data-table__header-cell{padding:var(--tb-cell-padding, 0 0 0 .2rem);line-height:var(--tb-cell-line-height, normal)}::ng-deep .op-date-time-input{line-height:3rem;font-size:.9rem;font-family:Roboto,Helvetica Neue,sans-serif;padding-left:.2rem;width:12rem}\n"] }]
|
|
298
|
-
}], ctorParameters: () => [], propDecorators: { trackBy: [{
|
|
299
|
-
type: Input
|
|
300
|
-
}], dropList: [{
|
|
301
|
-
type: ViewChild,
|
|
302
|
-
args: [CdkDropList, { static: true }]
|
|
303
|
-
}], selection$: [{
|
|
304
|
-
type: Output
|
|
305
|
-
}] } });
|
|
306
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"generic-table.component.js","sourceRoot":"","sources":["../../../../../../projects/angular-utilities/src/table-builder/components/generic-table/generic-table.component.ts","../../../../../../projects/angular-utilities/src/table-builder/components/generic-table/generic-table.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,SAAS,EAAE,KAAK,EAAE,uBAAuB,EAAE,MAAM,EAAoC,gBAAgB,EAAE,QAAQ,EAAE,YAAY,EAAE,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACxO,OAAO,EAAE,eAAe,EAAE,eAAe,EAAa,QAAQ,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AAEhH,OAAO,EAAmB,cAAc,EAAE,MAAM,0BAA0B,CAAC;AAC3E,OAAO,EAAE,UAAU,EAAE,MAAM,2BAA2B,CAAC;AACvD,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACrC,OAAO,EAAE,sBAAsB,EAAE,MAAM,4CAA4C,CAAC;AAGpF,OAAO,EAAE,kBAAkB,EAAE,MAAM,8BAA8B,CAAC;AAElE,OAAO,EAAe,WAAW,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AAClF,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,EAAE,iBAAiB,EAAE,MAAM,4BAA4B,CAAC;AAC/D,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAC3D,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,EAAE,SAAS,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AAC9D,OAAO,EAAE,gBAAgB,EAAE,MAAM,2BAA2B,CAAC;AAC7D,OAAO,EAAE,gBAAgB,EAAE,MAAM,kCAAkC,CAAC;AACpE,OAAO,EAAE,eAAe,EAAE,MAAM,+DAA+D,CAAC;AAEhG,OAAO,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAC;AAC1D,OAAO,EAAE,SAAS,EAAE,MAAM,0BAA0B,CAAC;;;;;;;AAarD,MAAM,OAAO,qBAAqB;IACtB,KAAK,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;IAC7B,SAAS,GAAG,MAAM,CAAC,SAAS,CAAC,CAAC;IAC9B,aAAa,GAAG,MAAM,CAAC,gBAAgB,CAAC,CAAC;IACzC,gBAAgB,GAAG,MAAM,CAAC,gBAAgB,CAAC,CAAC;IACpD,WAAW,GAAG,EAAE,CAAA;IAEhB,UAAU,GAAG,SAAS,CAAC,eAAe,CAAC,CAAC;IACxC,UAAU,GAAG,SAAS,CAAC,eAAe,CAAC,CAAC;IACxC,MAAM,GAAG,SAAS,CAAC,QAAQ,CAAC,CAAC;IAE7B,IAAI,CAAC,KAA4B;QAC/B,IAAI,CAAC,KAAK,CAAC,mBAAmB,CAAC,EAAE,QAAQ,EAAC,KAAK,CAAC,YAAY,EAAE,QAAQ,EAAC,KAAK,CAAC,aAAa,EAAE,CAAC,CAAA;IAC/F,CAAC;IACD,QAAQ,CAAU;IAClB,IAAa,OAAO,CAAC,OAAe;QAClC,IAAG,OAAO,EAAC,CAAC;YACV,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC;YACxB,IAAI,CAAC,eAAe,GAAG,CAAC,KAAY,EAAE,IAAS,EAAE,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACpE,CAAC;QACD,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC;IAChC,CAAC;IACD,IAAI,OAAO,KAAyB,OAAO,IAAI,CAAC,QAAQ,CAAA,CAAC,CAAC;IAC1D,YAAY,GAAG,KAAK,CAAC,QAAQ,CAAQ,EAAE,KAAK,EAAE,aAAa,EAAE,CAAC,CAAC;IAC/D,kBAAkB,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,YAAY,EAAE,EAAE,MAAM,IAAI,CAAC,CAAC,CAAC;IACtE,cAAc,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,cAAc,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,UAAU,EAAE,MAAM,CAAC,CAAC,CAAA;IAChG,KAAK,GAAG,KAAK,CAAC,QAAQ,CAAQ,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC,CAAA;IAChD,KAAK,GAAG,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACjC,KAAK,GAAG,KAAK,CAAmB,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC,CAAC;IACvD,YAAY,GAAG,KAAK,CAAC,QAAQ,CAAe,EAAE,KAAK,EAAE,aAAa,EAAE,CAAC,CAAC;IACtE,gBAAgB,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,YAAY,EAAE,EAAE,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,UAAU,EAAE,SAAS,EAAE,UAAU,CAAC,CAAC,CAAA;IAChE,QAAQ,CAAe;IACjE,eAAe,GAAG,QAAQ,CAAC,GAAG,EAAE;QAC9B,MAAM,OAAO,GAAG,CAAC,CAAC,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAC5C,MAAM,UAAU,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC;QACzC,MAAM,YAAY,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAC7C,MAAM,kBAAkB,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC,eAAe,CAAC;QAC9D,OAAO,YAAY,IAAI,CAAC,OAAO,IAAI,CAAC,UAAU,IAAI,kBAAkB,CAAC,CAAC,CAAC,CAAC,CAAC,gBAAgB,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,cAAc,CAAC;IACrI,CAAC,CAAC,CAAC;IACH,cAAc,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,eAAe,EAAE,KAAK,WAAW,CAAC,CAAC;IACxE,SAAS,GAAG,MAAM,CAAC,QAAQ,CAAC,CAAC;IAC7B,QAAQ,GAAG,QAAQ,CAAC,MAAM,CAAC;QACzB,SAAS,EAAE;YACT,EAAC,OAAO,EAAE,QAAQ,EAAE,UAAU,EAAE,GAAE,EAAE,CAAC,IAAI,CAAC,MAAM,EAAE,EAAE;YACpD,EAAC,OAAO,EAAE,WAAW,EAAE,UAAU,EAAE,GAAE,EAAE,CAAC,IAAI,CAAC,QAAQ,EAAE;SACxD;QACD,MAAM,EAAE,IAAI,CAAC,SAAS;KACvB,CAAC,CAAC;IAEH,gBAAgB,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,eAAe,CAAC,EAAE,CAAC,CAAC;IACnG,eAAe,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC;IAC9F,QAAQ,GAAG,MAAM,CAAqC,EAAE,CAAC,CAAC;IAC1D,WAAW,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC,gBAAgB,CAAC,CAAA;IAC1E,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,mBAAmB,CAAE,CAAC;IAE9D;QACE,IAAI,CAAC,eAAe,EAAE,CAAC;QAEvB,MAAM,CAAC,GAAG,EAAE;YACV,MAAM,WAAW,GAAG,IAAI,CAAC,YAAY,EAAE,IAAI,EAAE,CAAC;YAC9C,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;YAC5B,IAAG,CAAC,KAAK;gBAAE,OAAO;YAElB,SAAS,CAAC,GAAG,EAAE;gBAEb,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,EAAE;oBACvD,MAAM,UAAU,GAAG,WAAW,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,QAAQ,CAAC,GAAG,KAAK,GAAG,CAAC,CAAC;oBACnE,IAAG,CAAC,UAAU,IAAI,UAAU,CAAC,UAAU,KAAK,KAAK,CAAC,UAAU,EAAE,CAAC;wBAC7D,OAAO,IAAI,CAAC,QAAQ,EAAE,CAAC,GAAG,CAAC,CAAC;wBAC5B,KAAK,EAAE,eAAe,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;oBAC1C,CAAC;gBACH,CAAC,CAAC,CAAC;gBAEH,WAAW,CAAC,OAAO,CAAC,EAAE,CAAC,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC,CAAA;YACjD,CAAC,CAAC,CAAA;QACJ,CAAC,CAAC,CAAC;QAEH,MAAM,CAAC,GAAG,EAAE;YACV,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;YAC5B,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,EAAE,CAAC;YAC1B,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,EAAE,CAAC;YAC1B,IAAG,CAAC,KAAK;gBAAE,OAAO;YAElB,SAAS,CAAC,GAAG,EAAE;gBACb,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;oBACjB,KAAK,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC;oBACxB,GAAG,CAAC,OAAO,GAAG,IAAI,CAAC;oBACnB,KAAK,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;gBACvB,CAAC,CAAC,CAAC;YACL,CAAC,CAAC,CAAA;QACJ,CAAC,CAAC,CAAA;QAEF,MAAM,CAAC,GAAG,EAAE;YACV,MAAM,SAAS,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;YACpC,MAAM,UAAU,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;YACtC,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;YAC5B,SAAS,CAAC,GAAG,EAAE;gBACb,IAAG,SAAS,IAAI,UAAU,IAAI,KAAK;oBAAE,KAAK,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC;qBACjE,IAAG,SAAS,IAAI,KAAK;oBAAE,KAAK,CAAC,kBAAkB,CAAC,SAAS,CAAC,CAAC;YAClE,CAAC,CAAC,CAAA;QACJ,CAAC,CAAC,CAAC;QAEH,MAAM,CAAC,GAAG,EAAE;YACV,MAAM,SAAS,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;YACpC,MAAM,UAAU,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC;YACzC,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;YAE5B,SAAS,CAAC,GAAG,EAAE;gBACb,IAAG,SAAS,IAAI,UAAU,IAAI,KAAK;oBAAE,KAAK,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC;qBACjE,IAAG,SAAS,IAAI,KAAK;oBAAE,KAAK,CAAC,kBAAkB,CAAC,SAAS,CAAC,CAAC;YAClE,CAAC,CAAC,CAAA;QACJ,CAAC,CAAC,CAAC;IACL,CAAC;IAED,cAAc,GAAG,CAAC,KAAY,EAAE,IAAS,EAAE,EAAE,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;IACpE,eAAe,GAAG,IAAI,CAAC,cAAc,CAAC;IAEtC,KAAK,GAAG,QAAQ,CAAC,GAAG,EAAE;QACpB,MAAM,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,sBAAsB,EAAE,CAAC;QACtD,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC;QAC9B,MAAM,IAAI,GAAG,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;QAC/C,IAAG,IAAI,CAAC,gBAAgB,EAAE,EAAC,CAAC;YAC1B,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;QACzB,CAAC;QACD,IAAG,IAAI,CAAC,eAAe,EAAE,EAAE,CAAC;YAC1B,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;QACxB,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC,CAAC,CAAA;IACF,KAAK,GAAG,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACjC,QAAQ;QAEN,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC,IAAI,EAAE,EAAE;YAC3C,IAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,MAAM,EAAC,CAAC;gBACjC,MAAM,eAAe,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAE,CAAC,CAAC,IAAI,CAAC,OAAQ,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,OAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;gBAC/H,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC;gBAChE,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,GAAG,OAAO,CAAC,CAAC;YACtC,CAAC;QACH,CAAC,CAAC,CAAC;IAEL,CAAC;IAED,aAAa,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC,YAAY,CAAC,CAAC;IACxE,iBAAiB,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,SAAS,EAAE,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC;IAC/E,YAAY,GAAG,QAAQ,CAAC,GAAG,EAAE;QAC3B,MAAM,YAAY,GAAG,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,CAAC,KAAK,CAAC,EAAE,CAAC;QAC7E,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,SAAS,EAAE,CAAC;QACxC,MAAM,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,EAAE,CAAC;QAC9C,IAAG,IAAI,CAAC,iBAAiB,EAAE,EAAC,CAAC;YAC3B,OAAO,YAAY,CAAC;QACtB,CAAC;QACD,IAAG,IAAI,CAAC,aAAa,EAAE,EAAC,CAAC;YACvB,OAAO,QAAQ,GAAG,WAAW,CAAC;QAChC,CAAC;QACD,OAAO,CAAC,CAAC;IACX,CAAC,CAAC,CAAC;IAGH,aAAa,CAAC,CAAS,EAAE,GAA+B;QACtD,OAAO,GAAG,CAAC,aAAa,CAAC;IAC3B,CAAC;IAED,WAAW,CAAC,GAAW,EAAE,QAAgB,EAAE,UAAmB;QAC5D,IAAI,CAAC,KAAK,CAAC,oBAAoB,CAAC,EAAE,GAAG,EAAG,UAAU,EAAE,QAAQ,EAAE,CAAC,CAAC;IAClE,CAAC;IAED,WAAW,CAAC,MAAkB;QAC5B,MAAM,kBAAkB,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC,MAAM,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;QAChE,IAAG,kBAAkB,EAAE,CAAC;YACtB,kBAAkB,CAAC,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC;QAChD,CAAC;aAAM,CAAC;YACN,MAAM,SAAS,GAAG,IAAI,CAAC,aAAa,CAAC,eAAe,CAAC,sBAAsB,EAAE;gBAC3E,KAAK,EAAE,CAAC;gBACR,QAAQ,EAAE,IAAI,CAAC,QAAQ;aACxB,CAAC,CAAC;YACH,SAAS,CAAC,QAAQ,CAAC,UAAU,GAAG,MAAM,CAAC,UAAU,CAAC;YAClD,SAAS,CAAC,QAAQ,CAAC,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC;YAC9C,SAAS,CAAC,QAAQ,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC;YACtC,SAAS,CAAC,QAAQ,CAAC,cAAc,CAAC,GAAG,EAAE;gBACrC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC;oBACnC,GAAG,WAAW;oBACd,CAAC,MAAM,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,SAAS,CAAC,QAAQ;iBAC1C,CAAC,CAAC,CAAC;YACN,CAAC,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAED,SAAS,CAAwB;IACvB,UAAU,GAAG,IAAI,YAAY,EAAwB,CAAC;IAChE,oBAAoB,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,GAAG,CAAC,GAAE,EAAE,CAAA,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC;IACxG,0BAA0B,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,GAAG,CAAC,GAAE,EAAE,CAAA,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC;IAC/G,eAAe,CAAC,OAAgB;QAC9B,IAAI,CAAC,SAAS,GAAG,OAAO,CAAC,CAAC,CAAC,IAAI,cAAc,CAAM,IAAI,EAAE,EAAE,EAAE,IAAI,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,cAAc,CAAM,IAAI,EAAE,EAAE,CAAC,CAAC;QAC5I,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;IACtE,CAAC;IACD,eAAe,GAAG,QAAQ,CAAC,GAAG,EAAE;QAC9B,IAAG,IAAI,CAAC,KAAK,CAAC,SAAS,EAAE,KAAK,mBAAmB,IAAI,IAAI,CAAC,KAAK,CAAC,SAAS,EAAE,KAAK,WAAW,EAAC,CAAC;YAC3F,MAAM,mBAAmB,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,SAAS,EAAE,CAAC;YAC/E,OAAO,IAAI,CAAC,KAAK,EAAE,CAAC,KAAK,CAAC,mBAAmB,EAAE,mBAAmB,GAAG,IAAI,CAAC,KAAK,CAAC,SAAS,EAAE,CAAC,CAAC;QAC/F,CAAC;aAAK,IAAG,IAAI,CAAC,KAAK,CAAC,SAAS,EAAE,KAAK,KAAK,IAAI,IAAI,CAAC,KAAK,CAAC,SAAS,EAAE,KAAK,aAAa,EAAC,CAAC;YACrF,OAAO,IAAI,CAAC,KAAK,EAAE,CAAC;QACtB,CAAC;QACD,OAAO,EAAE,CAAC;IACZ,CAAC,CAAC,CAAC;IACH,eAAe,GAAG,YAAY,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;IACrD,aAAa;QACX,MAAM,WAAW,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,MAAM,CAAC;QACnD,MAAM,OAAO,GAAG,IAAI,CAAC,eAAe,EAAE,EAAE,MAAM,IAAI,CAAC,CAAC;QACpD,OAAO,WAAW,KAAK,OAAO,CAAC;IACjC,CAAC;IAED,gFAAgF;IAChF,YAAY;QACV,IAAG,IAAI,CAAC,aAAa,EAAE,EAAC,CAAC;YACvB,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,CAAA;QACxB,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC,CAAC;QACnD,CAAC;IACH,CAAC;IAED,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,wBAAwB,CAAC,IAAI,CACnD,kBAAkB,CAAqB,CAAC,CAAC,EACzC,GAAG,CAAC,CAAC,CAAC,wBAAwB,EAAE,uBAAuB,CAAC,EAAE,EAAE;QAC1D,IAAI,uBAAuB,EAAC,CAAC;YAC3B,OAAO,CAAC,EAAC,KAAK,EAAC,GAAG,uBAAuB,IAAI,EAAE,QAAQ,EAAE,aAAa,EAAC,CAAC,CAAC;QAC3E,CAAC;QAAC,IAAI,QAAQ,EAAE,EAAE,CAAC;YACjB,OAAO,CAAC,EAAC,KAAK,EAAC,SAAS,EAAC,CAAC,CAAC;QAC7B,CAAC;QACD,OAAO,CAAC,EAAE,CAAC,CAAC;QAEZ,SAAS,QAAQ;YACf,OAAO,CAAC,wBAAwB,IAAI,CAAC,CAAC,IAAG,CAAC,IAAI,uBAAuB,IAAI,IAAI,CAAC;QAChF,CAAC;IACH,CAAC,CAAC,CACH,CAAC;IAEF,YAAY,GAAG,CAAC,GAAW,EAAE,GAAW,EAAE,EAAE;QAC1C,IAAG,GAAG,IAAI,SAAS,IAAI,GAAG,KAAK,MAAM;YAAE,OAAO,EAAE,CAAC;QACjD,IAAI,CAAC;YACH,OAAO,IAAI,CAAC,gBAAgB,CAAC,iBAAiB,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,GAAG,EAAC,CAAC,CAAC;QACnG,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,GAAG,CAAC;QACb,CAAC;IACH,CAAC,CAAA;IAED,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,CAAC,EAAE;QACrC,IAAG,IAAI,CAAC,KAAK,CAAC,UAAU,EAAE,IAAK,CAAC,CAAC,yBAAyB,CAAC,gBAAyC,EAAE,gBAAgB,EAAC,CAAC;YACtH,MAAM,MAAM,GAAI,CAAC,CAAC,yBAAyB,CAAC,gBAA0C,CAAC,SAAS,CAAC;YACjG,OAAO,MAAM,GAAG,IAAI,CAAE;QACxB,CAAC;QACD,IAAG,OAAO,CAAC,CAAC,yBAAyB,CAAC,SAAS,KAAK,QAAQ,EAAC,CAAC;YAC5D,OAAO,CAAC,CAAC,yBAAyB,CAAC,SAAS,GAAG,IAAI,CAAC;QACtD,CAAC;QACD,OAAO,CAAC,CAAC,yBAAyB,CAAC,SAAS,CAAC;IAE/C,CAAC,CAAC,CAAC;IAEL,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,CAAC,EAAE;QAC1C,IAAG,IAAI,CAAC,KAAK,CAAC,UAAU,EAAE,IAAK,CAAC,CAAC,yBAAyB,CAAC,gBAAyC,EAAE,mBAAmB,EAAC,CAAC;YACzH,MAAM,MAAM,GAAI,CAAC,CAAC,yBAAyB,CAAC,gBAA0C,CAAC,YAAY,CAAC;YACpG,OAAO,MAAM,GAAG,IAAI,CAAC;QACvB,CAAC;QACD,IAAG,OAAO,CAAC,CAAC,yBAAyB,CAAC,YAAY,KAAK,QAAQ,EAAC,CAAC;YAC/D,OAAO,CAAC,CAAC,yBAAyB,CAAC,YAAY,GAAG,IAAI,CAAC;QACzD,CAAC;QACD,OAAO,CAAC,CAAC,yBAAyB,CAAC,YAAY,CAAC;IAClD,CAAC,CAAC,CAAC;IAEH,kBAAkB,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,CAAC,EAAE;QAC/C,IAAG,CAAC,CAAC,yBAAyB,CAAC,iBAAiB,EAAC,CAAC;YAChD,OAAO,CAAC,CAAC,yBAAyB,CAAC,iBAAiB,GAAG,IAAI,CAAC;QAC9D,CAAC;QACD,OAAO,IAAI,CAAC,UAAU,EAAE,CAAC;IAC3B,CAAC,CAAC,CAAC;IAEH,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,CAAC,EAAE;QAC1C,MAAM,WAAW,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;QAC3C,QAAQ,WAAW,EAAE,CAAC;YACpB,KAAK,gBAAgB;gBACnB,OAAO,IAAI,CAAC,UAAU,EAAE,CAAC;YAC3B,KAAK,cAAc;gBACjB,OAAO,GAAG,IAAI,CAAC,WAAW,IAAI,CAAC;YACjC;gBACE,OAAO,KAAK,CAAC;QACjB,CAAC;IACH,CAAC,CAAC,CAAC;IAGH,aAAa,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC,YAAY,IAAI,IAAI,CAAC,KAAK,CAAC,UAAU,EAAE,CAAC,CAAC;uGAhShF,qBAAqB;2FAArB,qBAAqB,6yBAOT,eAAe,6FACf,eAAe,yFACnB,QAAQ,2FAsBhB,WAAW,8DClExB,u5GA6EA,s3BD9CI,cAAc,y7CAAE,cAAc,0iBAAE,iBAAiB,oYAAE,eAAe,2IAAE,aAAa,oLAAE,gBAAgB,mJACnG,gBAAgB,0BAAE,SAAS,yCAAE,YAAY;;2FAGhC,qBAAqB;kBAXjC,SAAS;+BACE,kBAAkB,mBAGX,uBAAuB,CAAC,MAAM,cACnC,IAAI,WACP;wBACP,cAAc,EAAE,cAAc,EAAE,iBAAiB,EAAE,eAAe,EAAE,aAAa,EAAE,gBAAgB;wBACnG,gBAAgB,EAAE,SAAS,EAAE,YAAY;qBAC1C;wDAiBY,OAAO;sBAAnB,KAAK;gBAgBoC,QAAQ;sBAAjD,SAAS;uBAAC,WAAW,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBA6J9B,UAAU;sBAAnB,MAAM","sourcesContent":["import { Component, ViewChild, Input, ChangeDetectionStrategy, Output, SimpleChanges, OnInit, QueryList, ViewContainerRef, Injector, EventEmitter, computed, inject, input, viewChild, effect, untracked, signal } from '@angular/core';\r\nimport { MatFooterRowDef, MatHeaderRowDef, MatRowDef, MatTable, MatTableModule } from '@angular/material/table';\r\nimport { Observable, combineLatest } from 'rxjs';\r\nimport { SelectionChange, SelectionModel } from '@angular/cdk/collections';\r\nimport { TableStore } from '../../classes/table-store';\r\nimport { map } from 'rxjs/operators';\r\nimport { ColumnBuilderComponent } from '../column-builder/column-builder.component';\r\nimport { Dictionary } from '../../interfaces/dictionary';\r\nimport { FieldType } from '../../interfaces/report-def';\r\nimport { previousAndCurrent } from '../../../rxjs/rxjs-operators';\r\nimport { ColumnInfo } from '../../interfaces/ColumnInfo';\r\nimport { CdkDragDrop, CdkDropList, DragDropModule } from '@angular/cdk/drag-drop';\r\nimport { FunctionPipe } from '../../../utilities';\r\nimport { MatCheckboxModule } from '@angular/material/checkbox';\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { AsyncPipe, NgTemplateOutlet } from '@angular/common';\r\nimport { MatTooltipModule } from '@angular/material/tooltip';\r\nimport { TransformCreator } from '../../services/transform-creator';\r\nimport { initIndexSymbol } from '../table-container/table-container.helpers/sort-state.helpers';\r\nimport { VirtualScrollOptions } from '../../classes/table-builder-general-settings';\r\nimport { toObservable } from '@angular/core/rxjs-interop';\r\nimport { DataStore } from '../../classes/data-store';\r\n\r\n@Component({\r\n  selector: 'tb-generic-table',\r\n  templateUrl: './generic-table.component.html',\r\n  styleUrls: ['./generic-table.component.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  standalone: true,\r\n  imports: [\r\n    MatTableModule, DragDropModule, MatCheckboxModule, MatButtonModule, MatIconModule, NgTemplateOutlet,\r\n    MatTooltipModule, AsyncPipe, FunctionPipe,\r\n  ],\r\n})\r\nexport class GenericTableComponent implements OnInit {\r\n  protected state = inject(TableStore);\r\n  private dataStore = inject(DataStore);\r\n  private viewContainer = inject(ViewContainerRef);\r\n  private transformCreator = inject(TransformCreator);\r\n  smallFooter = 10\r\n\r\n  $headerRow = viewChild(MatHeaderRowDef);\r\n  $footerRow = viewChild(MatFooterRowDef);\r\n  $table = viewChild(MatTable);\r\n\r\n  drop(event: CdkDragDrop<string[]>) {\r\n    this.state.setUserDefinedOrder({ newOrder:event.currentIndex, oldOrder:event.previousIndex })\r\n  }\r\n  _trackBy?: string;\r\n  @Input() set trackBy(trackBy: string){\r\n    if(trackBy){\r\n      this._trackBy = trackBy;\r\n      this.trackByFunction = (index:number, item: any) => item[trackBy];\r\n    }\r\n    this.setUpSelections(trackBy);\r\n  }\r\n  get trackBy(): string | undefined { return this._trackBy }\r\n  $displayData = input.required<any[]>({ alias: 'displayData' });\r\n  $displayDataLength = computed(() => this.$displayData()?.length || 0);\r\n  $hasFooterMeta = computed(() => this.state.$metaDataArray().some(md => !!md.additional?.footer))\r\n  $data = input.required<any[]>({ alias: 'data' })\r\n  data$ = toObservable(this.$data);\r\n  $rows = input<MatRowDef<any>[]>([], { alias: 'rows' });\r\n  $columnInfos = input.required<ColumnInfo[]>({ alias: 'columnInfos' });\r\n  $hasCustomFooter = computed(() => this.$columnInfos()?.some(ci => !!ci.customCell?.columnDef?.footerCell))\r\n  @ViewChild(CdkDropList, { static: true }) dropList!: CdkDropList;\r\n  $footerRowStyle = computed(() => {\r\n    const hasData = !!this.$displayDataLength();\r\n    const metaFooter = this.$hasFooterMeta();\r\n    const customFooter = this.$hasCustomFooter();\r\n    const hasSelectionColumn = this.state.props().selectionColumn;\r\n    return customFooter || (hasData && (metaFooter || hasSelectionColumn)) ? 'regular-footer' : hasData ? 'no-footer' : 'small-footer';\r\n  });\r\n  $showFooterRow = computed(() => this.$footerRowStyle() !== 'no-footer');\r\n  _injector = inject(Injector);\r\n  injector = Injector.create({\r\n    providers: [\r\n      {provide: MatTable, useFactory: ()=> this.$table() },\r\n      {provide: CdkDropList, useFactory: ()=> this.dropList },\r\n    ],\r\n    parent: this._injector\r\n  });\r\n\r\n  $hasSelectColumn = computed(() => this.state.selectSignal(state => state.props.selectionColumn)());\r\n  $hasIndexColumn = computed(() => this.state.selectSignal(state => state.props.indexColumn)());\r\n  $columns = signal<Dictionary<ColumnBuilderComponent>>({});\r\n  $showHeader = computed(() => !this.state.tableSettings().hideColumnHeader)\r\n  offset$ = this.dataStore.select( s => s.virtualScrollOffset );\r\n\r\n  constructor() {\r\n    this.setUpSelections();\r\n\r\n    effect(() => {\r\n      const columnInfos = this.$columnInfos() || [];\r\n      const table = this.$table();\r\n      if(!table) return;\r\n\r\n      untracked(() => {\r\n\r\n        Object.entries(this.$columns()).forEach(([key, value]) => {\r\n          const columnInfo = columnInfos.find(ci => ci.metaData.key === key);\r\n          if(!columnInfo || columnInfo.customCell !== value.customCell) {\r\n            delete this.$columns()[key];\r\n            table?.removeColumnDef(value.columnDef);\r\n          }\r\n        });\r\n\r\n        columnInfos.forEach(ci => this.buildColumn(ci))\r\n      })\r\n    });\r\n\r\n    effect(() => {\r\n      const table = this.$table();\r\n      const rows = this.$rows();\r\n      const keys = this.$keys();\r\n      if(!table) return;\r\n\r\n      untracked(() => {\r\n        rows.forEach(row => {\r\n          table.removeRowDef(row);\r\n          row.columns = keys;\r\n          table.addRowDef(row);\r\n        });\r\n      })\r\n    })\r\n\r\n    effect(() => {\r\n      const headerRow = this.$headerRow();\r\n      const showHeader = this.$showHeader();\r\n      const table = this.$table();\r\n      untracked(() => {\r\n        if(headerRow && showHeader && table) table.addHeaderRowDef(headerRow);\r\n        else if(headerRow && table) table.removeHeaderRowDef(headerRow);\r\n      })\r\n    });\r\n\r\n    effect(() => {\r\n      const footerRow = this.$footerRow();\r\n      const showFooter = this.$showFooterRow();\r\n      const table = this.$table();\r\n      \r\n      untracked(() => {\r\n        if(footerRow && showFooter && table) table.addFooterRowDef(footerRow);\r\n        else if(footerRow && table) table.removeFooterRowDef(footerRow);\r\n      })\r\n    });\r\n  }\r\n\r\n  defaultTrackBy = (index:number, item: any) => item[initIndexSymbol];\r\n  trackByFunction = this.defaultTrackBy;\r\n\r\n  $keys = computed(() => {\r\n    const displayed = this.state.$orderedVisibleColumns();\r\n    const built = this.$columns();\r\n    const keys = displayed.filter(d => !!built[d]);\r\n    if(this.$hasSelectColumn()){\r\n      keys.unshift('select');\r\n    }\r\n    if(this.$hasIndexColumn()) {\r\n      keys.unshift('index');\r\n    }\r\n    return keys;\r\n  })\r\n  keys$ = toObservable(this.$keys);\r\n  ngOnInit() {\r\n\r\n    this.state.on(this.selectableData$, (data) => {\r\n      if(this.selection.selected.length){\r\n        const trackByFunction = this.trackBy ? (s) => data.every(d =>  d[this.trackBy!] !== s[this.trackBy!]) : s => !data.includes(s);\r\n        const removed = this.selection.selected.filter(trackByFunction);\r\n        this.selection.deselect(...removed);\r\n      }\r\n    });\r\n\r\n  }\r\n\r\n  $usePaginator = computed(() => this.state.tableSettings().usePaginator);\r\n  $useVirtualScroll = computed(() => this.state.$viewType().includes('virtual'));\r\n  $offsetIndex = computed(() => {\r\n    const virtualStart = this.dataStore.selectSignal(d => d.virtualEnds.start)();\r\n    const pageSize = this.state.$pageSize();\r\n    const currentPage = this.state.$currentPage();\r\n    if(this.$useVirtualScroll()){\r\n      return virtualStart;\r\n    }\r\n    if(this.$usePaginator()){\r\n      return pageSize * currentPage;\r\n    }\r\n    return 0;\r\n  });\r\n\r\n\r\n  isGroupHeader(_: number, row: { isGroupHeader: boolean }) {\r\n    return row.isGroupHeader;\r\n  }\r\n\r\n  setExpanded(key: string, groupKey: string, isExpanded: boolean): void {\r\n    this.state.updateExpandedGroups({ key , isExpanded, groupKey });\r\n  }\r\n\r\n  buildColumn(column: ColumnInfo) {\r\n    const alreadyBuiltColumn = this.$columns()[column.metaData.key];\r\n    if(alreadyBuiltColumn) {\r\n      alreadyBuiltColumn.metaData = column.metaData;\r\n    } else {\r\n      const component = this.viewContainer.createComponent(ColumnBuilderComponent, {\r\n        index: 0,\r\n        injector: this.injector\r\n      });\r\n      component.instance.customCell = column.customCell;\r\n      component.instance.metaData = column.metaData;\r\n      component.instance.data$ = this.data$;\r\n      component.instance.whenViewInited(() => {\r\n        this.$columns.update(columnsDict => ({\r\n          ...columnsDict,\r\n          [column.metaData.key]: component.instance\r\n        }));\r\n      });\r\n    }\r\n  }\r\n\r\n  selection! : SelectionModel<any>;\r\n  @Output() selection$ = new EventEmitter<SelectionChange<any>>();\r\n  masterToggleChecked$ = this.selection$.pipe(map(()=>this.selection.hasValue() && this.isAllSelected()));\r\n  masterToggleIndeterminate$ = this.selection$.pipe(map(()=>this.selection.hasValue() && !this.isAllSelected()));\r\n  setUpSelections(trackBy?: string){\r\n    this.selection = trackBy ? new SelectionModel<any>(true, [], true, (a, b) => a[trackBy] === b[trackBy]) : new SelectionModel<any>(true, []);\r\n    this.state.on(this.selection.changed, c => this.selection$.emit(c));\r\n  }\r\n  $selectableData = computed(() => {\r\n    if(this.state.$viewType() === 'virtual paginator' || this.state.$viewType() === 'paginator'){\r\n      const previousPageRecords = this.state.$currentPage() * this.state.$pageSize();\r\n      return this.$data().slice(previousPageRecords, previousPageRecords + this.state.$pageSize());\r\n    }else if(this.state.$viewType() === 'all' || this.state.$viewType() === 'virtual all'){\r\n      return this.$data();\r\n    }\r\n    return [];\r\n  });\r\n  selectableData$ = toObservable(this.$selectableData);\r\n  isAllSelected() {\r\n    const numSelected = this.selection.selected.length;\r\n    const numRows = this.$selectableData()?.length || 0;\r\n    return numSelected === numRows;\r\n  }\r\n\r\n  /** Selects all rows if they are not all selected; otherwise clear selection. */\r\n  masterToggle() {\r\n    if(this.isAllSelected()){\r\n      this.selection.clear()\r\n    } else {\r\n      this.selection.select(...this.$selectableData());\r\n    }\r\n  }\r\n\r\n  tableWidth = this.state.getUserDefinedTableSize$.pipe(\r\n    previousAndCurrent<number | undefined>(0),\r\n    map(([previousUserDefinedWidth, currentUserDefinedWidth]) => {\r\n      if( currentUserDefinedWidth){\r\n        return ({width:`${currentUserDefinedWidth}px`, minWidth: 'fit-content'});\r\n      } if( wasReset() ){\r\n        return ({width:'initial'});\r\n      }\r\n      return ({});\r\n\r\n      function wasReset(){\r\n        return (previousUserDefinedWidth ?? 0) >=0 && currentUserDefinedWidth == null;\r\n      }\r\n    })\r\n  );\r\n\r\n  getTransform = (key: string, val: string) => {\r\n    if(val == undefined || val === 'null') return '';\r\n    try {\r\n      return this.transformCreator.createTransformer(this.$columns[key].metaData, true)({ [key]: val});\r\n    } catch (error) {\r\n      return val;\r\n    }\r\n  }\r\n\r\n  $rowHeight = this.state.selectSignal(s => {\r\n      if(this.state.$isVirtual() && (s.notPersistedTableSettings.useVirtualScroll as VirtualScrollOptions)?.enforceRowHeight){\r\n        const height = (s.notPersistedTableSettings.useVirtualScroll as VirtualScrollOptions)!.rowHeight;\r\n        return height + 'px' ;\r\n      }\r\n      if(typeof s.notPersistedTableSettings.rowHeight === 'number'){\r\n        return s.notPersistedTableSettings.rowHeight + 'px';\r\n      }\r\n      return s.notPersistedTableSettings.rowHeight;\r\n\r\n    });\r\n\r\n  $headerHeight = this.state.selectSignal(s => {\r\n    if(this.state.$isVirtual() && (s.notPersistedTableSettings.useVirtualScroll as VirtualScrollOptions)?.enforceHeaderHeight){\r\n      const height = (s.notPersistedTableSettings.useVirtualScroll as VirtualScrollOptions)!.headerHeight;\r\n      return height + 'px';\r\n    }\r\n    if(typeof s.notPersistedTableSettings.headerHeight === 'number'){\r\n      return s.notPersistedTableSettings.headerHeight + 'px';\r\n    }\r\n    return s.notPersistedTableSettings.headerHeight;\r\n  });\r\n\r\n  $groupHeaderHeight = this.state.selectSignal(s => {\r\n    if(s.notPersistedTableSettings.groupHeaderHeight){\r\n      return s.notPersistedTableSettings.groupHeaderHeight + 'px';\r\n    }\r\n    return this.$rowHeight();\r\n  });\r\n\r\n  $footerHeight = this.state.selectSignal(s => {\r\n    const footerStyle = this.$footerRowStyle();\r\n    switch (footerStyle) {\r\n      case 'regular-footer':\r\n        return this.$rowHeight();\r\n      case 'small-footer':\r\n        return `${this.smallFooter}px`;\r\n      default:\r\n        return '0px';\r\n    }\r\n  });\r\n\r\n\r\n  $stickyFooter = computed(() => this.state.props().stickyFooter || this.state.$isVirtual());\r\n}\r\n","<mat-table\r\n  cdkDropList\r\n  cdkDropListLockAxis='x'\r\n  cdkDropListOrientation=\"horizontal\"\r\n  (cdkDropListDropped)=\"drop($event)\"\r\n  class=\"table-drag-list\"\r\n  #table\r\n  [dataSource]=\"state.props().dataSource!\"\r\n  [trackBy]=\"trackByFunction\"\r\n  [style]=\"tableWidth | async \"\r\n>\r\n\r\n  <!-- select column -->\r\n  <ng-container matColumnDef=\"select\">\r\n\r\n    <mat-header-cell *matHeaderCellDef  class=\"select-column\">\r\n      <mat-checkbox (change)=\"$event ? masterToggle() : null\"\r\n                    [checked]=\"!!(masterToggleChecked$ | async)\"\r\n                    [indeterminate]=\"masterToggleIndeterminate$ | async\">\r\n      </mat-checkbox>\r\n    </mat-header-cell>\r\n\r\n    <mat-cell *matCellDef=\"let row\" class=\"select-column\">\r\n      <mat-checkbox\r\n        (click)=\"$event.stopPropagation()\"\r\n        (change)=\"$event ? selection.toggle(row) : null\"\r\n        [checked]=\"selection.isSelected(row)\"/>\r\n    </mat-cell>\r\n\r\n    <mat-footer-cell *matFooterCellDef class=\"select-column\">\r\n      {{ selection.selected.length }}\r\n    </mat-footer-cell>\r\n  </ng-container>\r\n\r\n\r\n  <!-- index column -->\r\n  <ng-container matColumnDef=\"index\">\r\n    <mat-header-cell *matHeaderCellDef class=\"f-mat-header-cell\" class=\"index-column\">#\r\n    </mat-header-cell>\r\n    <mat-cell *matCellDef=\"let i = index;\" class=\"index-column\">\r\n      {{ 1 + i + $offsetIndex() }}\r\n    </mat-cell>\r\n    <mat-footer-cell *matFooterCellDef class=\"index-column\"></mat-footer-cell>\r\n  </ng-container>\r\n\r\n  <!-- Grouping -->\r\n  <ng-container matColumnDef=\"groupHeader\">\r\n    <mat-cell *matCellDef=\"let row\">\r\n      @let expanded = (state.getIsExpanded | func : row.key : row.groupName );\r\n      <div [style.paddingLeft]=\"row.padding + 'px !important'\">\r\n        <button mat-icon-button (click)=\"setExpanded(row.key, row.groupName, !expanded());\">\r\n          @if (!expanded()) {\r\n            <mat-icon>chevron_right</mat-icon>\r\n          } @else {\r\n            <mat-icon>expand_more</mat-icon>\r\n          }\r\n        </button>\r\n        {{ getTransform | func : row.key :  row.groupHeaderDisplay }} ({{ row.length }})\r\n      </div>\r\n      <div style=\"flex-grow: 1\">\r\n        <ng-container *ngTemplateOutlet=\"state.props().groupHeaderTemplate!; context: { element: row }\"></ng-container>\r\n      </div>\r\n    </mat-cell>\r\n  </ng-container>\r\n\r\n  <mat-row [style.height]=\"$rowHeight()\" [style.min-height]=\"$rowHeight()\"\r\n           *matRowDef=\"let row; columns: $keys(); let i = index\"/>\r\n  <mat-row [style.height]=\"state.props().groupHeaderHeight ? state.props().groupHeaderHeight + 'px' : $groupHeaderHeight()\"\r\n           [style.min-height]=\"state.props().groupHeaderHeight ? state.props().groupHeaderHeight + 'px' : $groupHeaderHeight()\"\r\n           *matRowDef=\"let row; columns: ['groupHeader']; when: isGroupHeader\" style=\"background-color: white;\"/>\r\n</mat-table>\r\n\r\n<mat-header-row [style.height]=\"$headerHeight()\" [style.min-height]=\"$headerHeight()\"\r\n  *matHeaderRowDef=\"$keys(); sticky: state.props().isSticky\" [style.top.px]=\"((offset$ | async)! * -1)\"/>\r\n<mat-footer-row [style.height]=\"$footerHeight()\" [style.min-height]=\"$footerHeight()\"\r\n  *matFooterRowDef=\"$keys(); sticky: $stickyFooter() \"\r\n  [style.bottom.px]=\"$stickyFooter() ? (offset$ | async) : undefined\"/>\r\n"]}
|