@one-paragon/angular-utilities 2.2.4 → 2.2.6
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/karma.conf.js +44 -0
- package/ng-package.json +7 -0
- package/package.json +15 -27
- package/src/action-state/action-state-spinner/action-state-spinner.component.css +16 -0
- package/src/action-state/action-state-spinner/action-state-spinner.component.html +7 -0
- package/src/action-state/action-state-spinner/action-state-spinner.component.spec.ts +25 -0
- package/src/action-state/action-state-spinner/action-state-spinner.component.ts +25 -0
- package/src/action-state/action-state-ui/action-state-ui.module.ts +13 -0
- package/{action-state/index.d.ts → src/action-state/index.ts} +8 -4
- package/src/action-state/ngrx-ext/ngrx-ext.module.ts +14 -0
- package/src/action-state/ngrx.ts +69 -0
- package/src/http-request-state/RequestStateFactory.ts +56 -0
- package/src/http-request-state/RequestStateStore.ts +284 -0
- package/{http-request-state/deprecated.d.ts → src/http-request-state/deprecated.ts} +20 -20
- package/src/http-request-state/directives/HttpStateDirectiveBase.ts +29 -0
- package/src/http-request-state/directives/http-error-state-directive.ts +21 -0
- package/src/http-request-state/directives/http-inProgress-state-directive.ts +19 -0
- package/src/http-request-state/directives/http-notStarted-state-directive.ts +19 -0
- package/src/http-request-state/directives/http-success-state-directive.ts +29 -0
- package/{http-request-state/directives/index.d.ts → src/http-request-state/directives/index.ts} +5 -5
- package/src/http-request-state/directives/request-state-directive.spec.ts +73 -0
- package/src/http-request-state/directives/request-state-directive.ts +78 -0
- package/src/http-request-state/helpers.ts +30 -0
- package/src/http-request-state/http-state-module.ts +23 -0
- package/{http-request-state/index.d.ts → src/http-request-state/index.ts} +7 -7
- package/src/http-request-state/models/view-context.ts +18 -0
- package/src/http-request-state/observable.spec.ts +43 -0
- package/src/http-request-state/request-state.ts +66 -0
- package/src/http-request-state/rxjs/getRequestorBody.ts +10 -0
- package/src/http-request-state/rxjs/getRequestorState.ts +8 -0
- package/{http-request-state/rxjs/index.d.ts → src/http-request-state/rxjs/index.ts} +4 -4
- package/src/http-request-state/rxjs/tapError.ts +16 -0
- package/src/http-request-state/rxjs/tapSuccess.ts +16 -0
- package/src/http-request-state/strategies.spec.ts +42 -0
- package/src/http-request-state/types.ts +54 -0
- package/src/ngrx/actionable-selector.ts +160 -0
- package/src/ngrx/index.ts +1 -0
- package/{public-api.d.ts → src/public-api.ts} +35 -16
- package/src/rxjs/defaultShareReplay.ts +8 -0
- package/{rxjs/index.d.ts → src/rxjs/index.ts} +5 -5
- package/src/rxjs/mapError.ts +8 -0
- package/src/rxjs/rxjs-operators.ts +130 -0
- package/src/rxjs/subjectifier.ts +17 -0
- package/src/rxjs/subscriber.directive.ts +57 -0
- package/src/specs/clickSubject.spec.ts +95 -0
- package/src/specs/dialog.spec.ts +101 -0
- package/src/specs/toggleGroupDirective.spec.ts +229 -0
- package/src/table-builder/classes/DefaultSettings.ts +11 -0
- package/src/table-builder/classes/MatTableObservableDataSource.ts +23 -0
- package/src/table-builder/classes/TableBuilderConfig.ts +50 -0
- package/src/table-builder/classes/TableBuilderDataSource.ts +64 -0
- package/src/table-builder/classes/TableState.ts +125 -0
- package/src/table-builder/classes/data-store.ts +10 -0
- package/{table-builder/classes/display-col.d.ts → src/table-builder/classes/display-col.ts} +5 -5
- package/src/table-builder/classes/filter-info.ts +125 -0
- package/src/table-builder/classes/table-builder-general-settings.ts +205 -0
- package/src/table-builder/classes/table-builder.ts +105 -0
- package/src/table-builder/classes/table-store.helpers.ts +104 -0
- package/src/table-builder/classes/table-store.ts +440 -0
- package/src/table-builder/components/array-column.component.ts +34 -0
- package/src/table-builder/components/column-builder/column-builder.component.html +87 -0
- package/src/table-builder/components/column-builder/column-builder.component.scss +43 -0
- package/src/table-builder/components/column-builder/column-builder.component.spec.ts +49 -0
- package/src/table-builder/components/column-builder/column-builder.component.ts +129 -0
- package/src/table-builder/components/column-builder/column-helpers.ts +54 -0
- package/src/table-builder/components/column-header-menu/column-header-menu.component.html +110 -0
- package/src/table-builder/components/column-header-menu/column-header-menu.component.scss +97 -0
- package/src/table-builder/components/column-header-menu/column-header-menu.component.ts +94 -0
- package/src/table-builder/components/date-filter/date-filter.component.html +25 -0
- package/src/table-builder/components/date-filter/date-filter.component.ts +22 -0
- package/src/table-builder/components/date-time-filter/date-time-filter.component.html +11 -0
- package/src/table-builder/components/date-time-filter/date-time-filter.component.ts +20 -0
- package/src/table-builder/components/filter/filter.component.html +109 -0
- package/src/table-builder/components/filter/filter.component.scss +60 -0
- package/src/table-builder/components/filter/filter.component.spec.ts +86 -0
- package/src/table-builder/components/filter/filter.component.ts +64 -0
- package/src/table-builder/components/filter/in-list/in-list-filter.component.ts +102 -0
- package/src/table-builder/components/gen-col-displayer/gen-col-displayer.component.html +60 -0
- package/src/table-builder/components/gen-col-displayer/gen-col-displayer.component.scss +57 -0
- package/src/table-builder/components/gen-col-displayer/gen-col-displayer.component.ts +44 -0
- package/src/table-builder/components/generic-table/generic-table.component.html +97 -0
- package/src/table-builder/components/generic-table/generic-table.component.scss +38 -0
- package/src/table-builder/components/generic-table/generic-table.component.ts +403 -0
- package/src/table-builder/components/generic-table/paginator.component.ts +112 -0
- package/src/table-builder/components/group-by-list/group-by-list.component.css +17 -0
- package/src/table-builder/components/group-by-list/group-by-list.component.html +14 -0
- package/src/table-builder/components/group-by-list/group-by-list.component.spec.ts +23 -0
- package/src/table-builder/components/group-by-list/group-by-list.component.ts +25 -0
- package/src/table-builder/components/in-filter/in-filter.component.css +3 -0
- package/src/table-builder/components/in-filter/in-filter.component.html +23 -0
- package/src/table-builder/components/in-filter/in-filter.component.ts +65 -0
- package/{table-builder/components/index.d.ts → src/table-builder/components/index.ts} +9 -9
- package/src/table-builder/components/initialization-component/initialization.component.html +78 -0
- package/src/table-builder/components/initialization-component/initialization.component.ts +27 -0
- package/src/table-builder/components/link-column.component.ts +42 -0
- package/src/table-builder/components/number-filter/number-filter.component.css +10 -0
- package/src/table-builder/components/number-filter/number-filter.component.html +25 -0
- package/src/table-builder/components/number-filter/number-filter.component.spec.ts +30 -0
- package/src/table-builder/components/number-filter/number-filter.component.ts +25 -0
- package/src/table-builder/components/profiles-menu/profiles-menu.component.html +77 -0
- package/src/table-builder/components/profiles-menu/profiles-menu.component.scss +126 -0
- package/src/table-builder/components/profiles-menu/profiles-menu.component.spec.ts +23 -0
- package/src/table-builder/components/profiles-menu/profiles-menu.component.ts +63 -0
- package/src/table-builder/components/reset-menu/reset-menu.component.css +3 -0
- package/src/table-builder/components/reset-menu/reset-menu.component.html +10 -0
- package/src/table-builder/components/reset-menu/reset-menu.component.ts +87 -0
- package/src/table-builder/components/scroll-strategy.ts +139 -0
- package/src/table-builder/components/sort-menu/sort-menu.component-store.ts +57 -0
- package/src/table-builder/components/sort-menu/sort-menu.component.html +115 -0
- package/src/table-builder/components/sort-menu/sort-menu.component.scss +119 -0
- package/src/table-builder/components/sort-menu/sort-menu.component.ts +88 -0
- package/src/table-builder/components/table-container/table-container.component.html +81 -0
- package/src/table-builder/components/table-container/table-container.component.ts +403 -0
- package/src/table-builder/components/table-container/table-container.helpers/data-state.helpers.ts +113 -0
- package/src/table-builder/components/table-container/table-container.helpers/filter-state.helpers.ts +125 -0
- package/src/table-builder/components/table-container/table-container.helpers/groupBy.helpers.ts +122 -0
- package/src/table-builder/components/table-container/table-container.helpers/meta-data.helpers.ts +16 -0
- package/src/table-builder/components/table-container/table-container.helpers/sort-state.helpers.ts +47 -0
- package/src/table-builder/components/table-container/table-container.scss +47 -0
- package/src/table-builder/components/table-container/tableProps.ts +18 -0
- package/src/table-builder/components/table-container/virtual-scroll-container.ts +216 -0
- package/src/table-builder/components/table-container-filter/filter-list/filter-list.component.html +35 -0
- package/src/table-builder/components/table-container-filter/filter-list/filter-list.component.ts +44 -0
- package/src/table-builder/components/table-container-filter/gen-filter-displayer/gen-filter-displayer.component.css +40 -0
- package/src/table-builder/components/table-container-filter/gen-filter-displayer/gen-filter-displayer.component.html +11 -0
- package/src/table-builder/components/table-container-filter/gen-filter-displayer/gen-filter-displayer.component.spec.ts +85 -0
- package/src/table-builder/components/table-container-filter/gen-filter-displayer/gen-filter-displayer.component.ts +36 -0
- package/src/table-builder/components/table-container-filter/table-wrapper-filter-store.ts +23 -0
- package/src/table-builder/components/table-header-menu/table-header-menu.component.css +21 -0
- package/src/table-builder/components/table-header-menu/table-header-menu.component.html +50 -0
- package/src/table-builder/components/table-header-menu/table-header-menu.component.ts +35 -0
- package/src/table-builder/directives/custom-cell-directive.ts +57 -0
- package/{table-builder/directives/index.d.ts → src/table-builder/directives/index.ts} +6 -5
- package/src/table-builder/directives/multi-sort.directive.spec.ts +124 -0
- package/src/table-builder/directives/multi-sort.directive.ts +50 -0
- package/src/table-builder/directives/resize-column.directive.ts +107 -0
- package/src/table-builder/directives/table-wrapper.directive.ts +13 -0
- package/src/table-builder/directives/tb-filter.directive.ts +376 -0
- package/src/table-builder/enums/filterTypes.ts +40 -0
- package/src/table-builder/functions/boolean-filter-function.ts +12 -0
- package/src/table-builder/functions/date-filter-function.ts +78 -0
- package/src/table-builder/functions/download-data.ts +11 -0
- package/src/table-builder/functions/null-filter-function.ts +9 -0
- package/src/table-builder/functions/number-filter-function.ts +41 -0
- package/src/table-builder/functions/sort-data-function.ts +80 -0
- package/src/table-builder/functions/string-filter-function.ts +53 -0
- package/{table-builder/interfaces/ColumnInfo.d.ts → src/table-builder/interfaces/ColumnInfo.ts} +7 -6
- package/{table-builder/interfaces/dictionary.d.ts → src/table-builder/interfaces/dictionary.ts} +3 -3
- package/src/table-builder/interfaces/report-def.ts +254 -0
- package/src/table-builder/ngrx/tableBuilderStateStore.ts +197 -0
- package/src/table-builder/pipes/column-total.pipe.ts +16 -0
- package/src/table-builder/pipes/format-filter-type.pipe.ts +12 -0
- package/src/table-builder/pipes/format-filter-value.pipe.ts +67 -0
- package/src/table-builder/pipes/key-display.ts +13 -0
- package/src/table-builder/services/export-to-csv.service.ts +113 -0
- package/src/table-builder/services/link-creator.service.ts +98 -0
- package/src/table-builder/services/table-template-service.ts +47 -0
- package/src/table-builder/services/transform-creator.ts +96 -0
- package/src/table-builder/specs/table-custom-filters.spec.ts +262 -0
- package/src/table-builder/styles/collapser.styles.scss +16 -0
- package/src/table-builder/table-builder.module.ts +38 -0
- package/src/test.ts +17 -0
- package/src/utilities/array-helpers.ts +13 -0
- package/src/utilities/directives/auto-focus.directive.ts +20 -0
- package/src/utilities/directives/clickEmitterDirective.ts +15 -0
- package/src/utilities/directives/clickSubject.ts +19 -0
- package/src/utilities/directives/conditional-classes.directive.ts +36 -0
- package/src/utilities/directives/dialog-service.ts +19 -0
- package/src/utilities/directives/dialog.ts +144 -0
- package/src/utilities/directives/mat-toggle-group-directive.ts +60 -0
- package/src/utilities/directives/prevent-enter.directive.ts +12 -0
- package/src/utilities/directives/stop-propagation.directive.ts +19 -0
- package/src/utilities/directives/styler.ts +44 -0
- package/src/utilities/directives/trim-whitespace.directive.ts +20 -0
- package/{utilities/index.d.ts → src/utilities/index.ts} +22 -15
- package/src/utilities/module.ts +53 -0
- package/src/utilities/pipes/function.pipe.ts +21 -0
- package/src/utilities/pipes/phone.pipe.ts +20 -0
- package/src/utilities/pipes/space-case.pipes.spec.ts +47 -0
- package/src/utilities/pipes/space-case.pipes.ts +26 -0
- package/tsconfig.lib.json +20 -0
- package/tsconfig.lib.prod.json +10 -0
- package/tsconfig.spec.json +17 -0
- package/action-state/action-state-spinner/action-state-spinner.component.d.ts +0 -12
- package/action-state/action-state-ui/action-state-ui.module.d.ts +0 -7
- package/action-state/ngrx-ext/ngrx-ext.module.d.ts +0 -8
- package/action-state/ngrx.d.ts +0 -31
- package/fesm2022/one-paragon-angular-utilities.mjs +0 -6531
- package/fesm2022/one-paragon-angular-utilities.mjs.map +0 -1
- package/http-request-state/RequestStateFactory.d.ts +0 -17
- package/http-request-state/RequestStateStore.d.ts +0 -101
- package/http-request-state/directives/HttpStateDirectiveBase.d.ts +0 -14
- package/http-request-state/directives/http-error-state-directive.d.ts +0 -10
- package/http-request-state/directives/http-inProgress-state-directive.d.ts +0 -10
- package/http-request-state/directives/http-notStarted-state-directive.d.ts +0 -10
- package/http-request-state/directives/http-success-state-directive.d.ts +0 -17
- package/http-request-state/directives/request-state-directive.d.ts +0 -34
- package/http-request-state/helpers.d.ts +0 -9
- package/http-request-state/http-state-module.d.ts +0 -11
- package/http-request-state/request-state.d.ts +0 -12
- package/http-request-state/rxjs/getRequestorBody.d.ts +0 -3
- package/http-request-state/rxjs/getRequestorState.d.ts +0 -3
- package/http-request-state/rxjs/tapError.d.ts +0 -3
- package/http-request-state/rxjs/tapSuccess.d.ts +0 -3
- package/http-request-state/types.d.ts +0 -41
- package/index.d.ts +0 -5
- package/ngrx/actionable-selector.d.ts +0 -32
- package/ngrx/index.d.ts +0 -1
- package/rxjs/defaultShareReplay.d.ts +0 -2
- package/rxjs/mapError.d.ts +0 -2
- package/rxjs/rxjs-operators.d.ts +0 -13
- package/rxjs/subjectifier.d.ts +0 -10
- package/rxjs/subscriber.directive.d.ts +0 -14
- package/table-builder/classes/DefaultSettings.d.ts +0 -9
- package/table-builder/classes/MatTableObservableDataSource.d.ts +0 -9
- package/table-builder/classes/TableBuilderConfig.d.ts +0 -23
- package/table-builder/classes/TableBuilderDataSource.d.ts +0 -18
- package/table-builder/classes/TableState.d.ts +0 -81
- package/table-builder/classes/data-store.d.ts +0 -8
- package/table-builder/classes/filter-info.d.ts +0 -39
- package/table-builder/classes/table-builder-general-settings.d.ts +0 -119
- package/table-builder/classes/table-builder.d.ts +0 -22
- package/table-builder/classes/table-store.d.ts +0 -146
- package/table-builder/classes/table-store.helpers.d.ts +0 -31
- package/table-builder/components/array-column.component.d.ts +0 -15
- package/table-builder/components/column-builder/column-builder.component.d.ts +0 -41
- package/table-builder/components/column-builder/column-helpers.d.ts +0 -38
- package/table-builder/components/column-header-menu/column-header-menu.component.d.ts +0 -50
- package/table-builder/components/date-filter/date-filter.component.d.ts +0 -37
- package/table-builder/components/date-time-filter/date-time-filter.component.d.ts +0 -37
- package/table-builder/components/filter/filter.component.d.ts +0 -48
- package/table-builder/components/filter/in-list/in-list-filter.component.d.ts +0 -22
- package/table-builder/components/gen-col-displayer/gen-col-displayer.component.d.ts +0 -17
- package/table-builder/components/generic-table/generic-table.component.d.ts +0 -85
- package/table-builder/components/generic-table/paginator.component.d.ts +0 -26
- package/table-builder/components/group-by-list/group-by-list.component.d.ts +0 -11
- package/table-builder/components/in-filter/in-filter.component.d.ts +0 -20
- package/table-builder/components/initialization-component/initialization.component.d.ts +0 -15
- package/table-builder/components/link-column.component.d.ts +0 -23
- package/table-builder/components/number-filter/number-filter.component.d.ts +0 -39
- package/table-builder/components/profiles-menu/profiles-menu.component.d.ts +0 -33
- package/table-builder/components/reset-menu/reset-menu.component.d.ts +0 -25
- package/table-builder/components/scroll-strategy.d.ts +0 -45
- package/table-builder/components/sort-menu/sort-menu.component-store.d.ts +0 -24
- package/table-builder/components/sort-menu/sort-menu.component.d.ts +0 -19
- package/table-builder/components/table-container/table-container.component.d.ts +0 -104
- package/table-builder/components/table-container/table-container.helpers/data-state.helpers.d.ts +0 -7
- package/table-builder/components/table-container/table-container.helpers/filter-state.helpers.d.ts +0 -19
- package/table-builder/components/table-container/table-container.helpers/groupBy.helpers.d.ts +0 -19
- package/table-builder/components/table-container/table-container.helpers/meta-data.helpers.d.ts +0 -2
- package/table-builder/components/table-container/table-container.helpers/sort-state.helpers.d.ts +0 -12
- package/table-builder/components/table-container/tableProps.d.ts +0 -10
- package/table-builder/components/table-container/virtual-scroll-container.d.ts +0 -40
- package/table-builder/components/table-container-filter/filter-list/filter-list.component.d.ts +0 -15
- package/table-builder/components/table-container-filter/gen-filter-displayer/gen-filter-displayer.component.d.ts +0 -12
- package/table-builder/components/table-container-filter/table-wrapper-filter-store.d.ts +0 -14
- package/table-builder/components/table-header-menu/table-header-menu.component.d.ts +0 -15
- package/table-builder/directives/custom-cell-directive.d.ts +0 -34
- package/table-builder/directives/multi-sort.directive.d.ts +0 -10
- package/table-builder/directives/resize-column.directive.d.ts +0 -43
- package/table-builder/directives/table-wrapper.directive.d.ts +0 -8
- package/table-builder/directives/tb-filter.directive.d.ts +0 -116
- package/table-builder/enums/filterTypes.d.ts +0 -36
- package/table-builder/functions/boolean-filter-function.d.ts +0 -3
- package/table-builder/functions/date-filter-function.d.ts +0 -4
- package/table-builder/functions/download-data.d.ts +0 -1
- package/table-builder/functions/null-filter-function.d.ts +0 -2
- package/table-builder/functions/number-filter-function.d.ts +0 -4
- package/table-builder/functions/sort-data-function.d.ts +0 -6
- package/table-builder/functions/string-filter-function.d.ts +0 -5
- package/table-builder/interfaces/report-def.d.ts +0 -223
- package/table-builder/ngrx/tableBuilderStateStore.d.ts +0 -69
- package/table-builder/pipes/column-total.pipe.d.ts +0 -8
- package/table-builder/pipes/format-filter-type.pipe.d.ts +0 -8
- package/table-builder/pipes/format-filter-value.pipe.d.ts +0 -11
- package/table-builder/pipes/key-display.d.ts +0 -9
- package/table-builder/services/export-to-csv.service.d.ts +0 -14
- package/table-builder/services/link-creator.service.d.ts +0 -16
- package/table-builder/services/table-template-service.d.ts +0 -14
- package/table-builder/services/transform-creator.d.ts +0 -9
- package/table-builder/table-builder.module.d.ts +0 -14
- package/utilities/array-helpers.d.ts +0 -1
- package/utilities/directives/auto-focus.directive.d.ts +0 -9
- package/utilities/directives/clickEmitterDirective.d.ts +0 -7
- package/utilities/directives/clickSubject.d.ts +0 -9
- package/utilities/directives/conditional-classes.directive.d.ts +0 -12
- package/utilities/directives/dialog-service.d.ts +0 -10
- package/utilities/directives/dialog.d.ts +0 -45
- package/utilities/directives/mat-toggle-group-directive.d.ts +0 -21
- package/utilities/directives/prevent-enter.directive.d.ts +0 -6
- package/utilities/directives/stop-propagation.directive.d.ts +0 -7
- package/utilities/directives/styler.d.ts +0 -16
- package/utilities/directives/trim-whitespace.directive.d.ts +0 -7
- package/utilities/module.d.ts +0 -19
- package/utilities/pipes/function.pipe.d.ts +0 -11
- package/utilities/pipes/phone.pipe.d.ts +0 -8
- package/utilities/pipes/space-case.pipes.d.ts +0 -17
|
@@ -0,0 +1,229 @@
|
|
|
1
|
+
import { Component, DebugElement } from "@angular/core";
|
|
2
|
+
import { ComponentFixture, TestBed, waitForAsync } from "@angular/core/testing";
|
|
3
|
+
import { MatSlideToggle, MatSlideToggleModule } from "@angular/material/slide-toggle";
|
|
4
|
+
import { MatSlideToggleGroupDirective } from "../utilities/directives/mat-toggle-group-directive";
|
|
5
|
+
import { HarnessLoader } from '@angular/cdk/testing';
|
|
6
|
+
import { TestbedHarnessEnvironment } from '@angular/cdk/testing/testbed';
|
|
7
|
+
import { MatSlideToggleHarness } from '@angular/material/slide-toggle/testing';
|
|
8
|
+
import { By } from "@angular/platform-browser";
|
|
9
|
+
import { count, firstValueFrom, lastValueFrom, skip, Subject, takeUntil } from "rxjs";
|
|
10
|
+
|
|
11
|
+
abstract class ToggleTestComponent {
|
|
12
|
+
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
|
|
16
|
+
@Component({
|
|
17
|
+
template: `
|
|
18
|
+
<ng-container opMatSlideToggleGroup >
|
|
19
|
+
<mat-slide-toggle name='toggle1' > Slide me! </mat-slide-toggle>
|
|
20
|
+
</ng-container>
|
|
21
|
+
`
|
|
22
|
+
}) export class SingleToggleTestComponent extends ToggleTestComponent {
|
|
23
|
+
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
@Component({
|
|
27
|
+
template: `
|
|
28
|
+
<ng-container opMatSlideToggleGroup [allowMultiple]='true' >
|
|
29
|
+
<mat-slide-toggle name='toggle1' > Slide me! </mat-slide-toggle>
|
|
30
|
+
<mat-slide-toggle name='toggle2' > Slide me! </mat-slide-toggle>
|
|
31
|
+
</ng-container>
|
|
32
|
+
`
|
|
33
|
+
}) export class MultiToggleWithMultipleTestComponent extends ToggleTestComponent {
|
|
34
|
+
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
@Component({
|
|
38
|
+
template: `
|
|
39
|
+
<ng-container opMatSlideToggleGroup >
|
|
40
|
+
<mat-slide-toggle name='toggle1' > Slide me! </mat-slide-toggle>
|
|
41
|
+
<mat-slide-toggle name='toggle2' > Slide me! </mat-slide-toggle>
|
|
42
|
+
</ng-container>
|
|
43
|
+
`
|
|
44
|
+
}) export class MultiToggleTestComponent extends ToggleTestComponent {
|
|
45
|
+
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
|
|
49
|
+
let fixture: ComponentFixture<ToggleTestComponent>;
|
|
50
|
+
let loader: HarnessLoader;
|
|
51
|
+
let toggleHarnesses: MatSlideToggleHarness [];
|
|
52
|
+
let toggleGroupDirective: MatSlideToggleGroupDirective;
|
|
53
|
+
|
|
54
|
+
let toggles: DebugElement[];
|
|
55
|
+
|
|
56
|
+
|
|
57
|
+
const setupTest = (type) => async (): Promise<void> => {
|
|
58
|
+
|
|
59
|
+
TestBed.configureTestingModule({
|
|
60
|
+
imports: [MatSlideToggleModule],
|
|
61
|
+
declarations: [
|
|
62
|
+
type,
|
|
63
|
+
MatSlideToggleGroupDirective,
|
|
64
|
+
],
|
|
65
|
+
providers: []
|
|
66
|
+
});
|
|
67
|
+
fixture = TestBed.createComponent(type);
|
|
68
|
+
fixture.detectChanges();
|
|
69
|
+
|
|
70
|
+
loader = TestbedHarnessEnvironment.documentRootLoader(fixture);
|
|
71
|
+
toggleHarnesses = await loader.getAllHarnesses(MatSlideToggleHarness);
|
|
72
|
+
toggles = fixture.debugElement.queryAll(By.directive(MatSlideToggle));
|
|
73
|
+
toggleGroupDirective = toggles[0].injector.get(MatSlideToggleGroupDirective);
|
|
74
|
+
|
|
75
|
+
|
|
76
|
+
};
|
|
77
|
+
|
|
78
|
+
|
|
79
|
+
async function toggleAndReturnValues(index: number) {
|
|
80
|
+
const firstVal = firstValueFrom(toggleGroupDirective.valueEmitter.pipe(skip(1)));
|
|
81
|
+
await toggleHarnesses[index].toggle();
|
|
82
|
+
return await firstVal;
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
describe("opMatSlideToggleGroup", () => {
|
|
86
|
+
describe("Single Toggle", () => {
|
|
87
|
+
beforeEach(waitForAsync(setupTest(SingleToggleTestComponent)));
|
|
88
|
+
|
|
89
|
+
it('should create', async () => {
|
|
90
|
+
expect(toggleGroupDirective).toBeDefined();
|
|
91
|
+
})
|
|
92
|
+
|
|
93
|
+
it('starts with an initial value', async () => {
|
|
94
|
+
const firstVal = firstValueFrom(toggleGroupDirective.valueEmitter);
|
|
95
|
+
const val = await firstVal;
|
|
96
|
+
expect(val).toEqual({ 'toggle1': false });
|
|
97
|
+
});
|
|
98
|
+
|
|
99
|
+
it('when toggling on should emit the latest value as true', async () => {
|
|
100
|
+
const val = await toggleAndReturnValues(0);
|
|
101
|
+
expect(val).toEqual({ 'toggle1': true });
|
|
102
|
+
});
|
|
103
|
+
|
|
104
|
+
it('can toggle on and then off', async () => {
|
|
105
|
+
|
|
106
|
+
const val = await toggleAndReturnValues(0);
|
|
107
|
+
expect(val).toEqual({ 'toggle1': true });
|
|
108
|
+
const val2 = await toggleAndReturnValues(0);
|
|
109
|
+
expect(val2).toEqual({ 'toggle1': false });
|
|
110
|
+
});
|
|
111
|
+
});
|
|
112
|
+
|
|
113
|
+
describe("Multi Toggle", () => {
|
|
114
|
+
beforeEach(waitForAsync(setupTest(MultiToggleWithMultipleTestComponent)));
|
|
115
|
+
|
|
116
|
+
it('starts with an initial value', async () => {
|
|
117
|
+
const firstVal = firstValueFrom(toggleGroupDirective.valueEmitter);
|
|
118
|
+
const val = await firstVal;
|
|
119
|
+
expect(val).toEqual({ 'toggle1': false, 'toggle2': false });
|
|
120
|
+
});
|
|
121
|
+
|
|
122
|
+
it('can toggle first toggle', async () => {
|
|
123
|
+
const val = await toggleAndReturnValues(0);
|
|
124
|
+
expect(val).toEqual({ 'toggle1': true, 'toggle2': false });
|
|
125
|
+
});
|
|
126
|
+
|
|
127
|
+
it('can toggle second toggle', async () => {
|
|
128
|
+
const val = await toggleAndReturnValues(1);
|
|
129
|
+
expect(val).toEqual({ 'toggle1': false, 'toggle2': true });
|
|
130
|
+
});
|
|
131
|
+
|
|
132
|
+
it('can toggle both toggles', async () => {
|
|
133
|
+
const val = await toggleAndReturnValues(0);
|
|
134
|
+
expect(val).toEqual({ 'toggle1': true, 'toggle2': false });
|
|
135
|
+
|
|
136
|
+
const val2 = await toggleAndReturnValues(1);
|
|
137
|
+
expect(val2).toEqual({ 'toggle1': true, 'toggle2': true });
|
|
138
|
+
});
|
|
139
|
+
|
|
140
|
+
it('can toggle both toggles multiple times', async () => {
|
|
141
|
+
let val = await toggleAndReturnValues(0);
|
|
142
|
+
expect(val).toEqual({ 'toggle1': true, 'toggle2': false });
|
|
143
|
+
|
|
144
|
+
val = await toggleAndReturnValues(1);
|
|
145
|
+
expect(val).toEqual({ 'toggle1': true, 'toggle2': true });
|
|
146
|
+
|
|
147
|
+
val = await toggleAndReturnValues(1);
|
|
148
|
+
expect(val).toEqual({ 'toggle1': true, 'toggle2': false });
|
|
149
|
+
|
|
150
|
+
val = await toggleAndReturnValues(1);
|
|
151
|
+
expect(val).toEqual({ 'toggle1': true, 'toggle2': true });
|
|
152
|
+
|
|
153
|
+
val = await toggleAndReturnValues(0);
|
|
154
|
+
expect(val).toEqual({ 'toggle1': false, 'toggle2': true });
|
|
155
|
+
val = await toggleAndReturnValues(1);
|
|
156
|
+
expect(val).toEqual({ 'toggle1': false, 'toggle2': false });
|
|
157
|
+
});
|
|
158
|
+
|
|
159
|
+
});
|
|
160
|
+
|
|
161
|
+
describe("Multi Toggle Only One Allowed", () => {
|
|
162
|
+
beforeEach(waitForAsync(setupTest(MultiToggleTestComponent)));
|
|
163
|
+
|
|
164
|
+
it('starts with an initial value', async () => {
|
|
165
|
+
const firstVal = firstValueFrom(toggleGroupDirective.valueEmitter);
|
|
166
|
+
const val = await firstVal;
|
|
167
|
+
expect(val).toEqual({ 'toggle1': false, 'toggle2': false });
|
|
168
|
+
});
|
|
169
|
+
|
|
170
|
+
it('can toggle first toggle', async () => {
|
|
171
|
+
const val = await toggleAndReturnValues(0);
|
|
172
|
+
expect(val).toEqual({ 'toggle1': true, 'toggle2': false });
|
|
173
|
+
});
|
|
174
|
+
|
|
175
|
+
it('can toggle second toggle', async () => {
|
|
176
|
+
const val = await toggleAndReturnValues(1);
|
|
177
|
+
expect(val).toEqual({ 'toggle1': false, 'toggle2': true });
|
|
178
|
+
});
|
|
179
|
+
|
|
180
|
+
it('when toggle both toggles only the last one remains set', async () => {
|
|
181
|
+
const val = await toggleAndReturnValues(0);
|
|
182
|
+
expect(val).toEqual({ 'toggle1': true, 'toggle2': false });
|
|
183
|
+
|
|
184
|
+
const val2 = await toggleAndReturnValues(1);
|
|
185
|
+
expect(val2).toEqual({ 'toggle1': false, 'toggle2': true });
|
|
186
|
+
|
|
187
|
+
var toggle1Value = await toggleHarnesses[0].isChecked();
|
|
188
|
+
|
|
189
|
+
expect(toggle1Value).toBeFalse();
|
|
190
|
+
});
|
|
191
|
+
|
|
192
|
+
it('can toggle both toggles multiple times and only the last one will be set', async () => {
|
|
193
|
+
let val = await toggleAndReturnValues(0);
|
|
194
|
+
expect(val).toEqual({ 'toggle1': true, 'toggle2': false });
|
|
195
|
+
|
|
196
|
+
val = await toggleAndReturnValues(1);
|
|
197
|
+
expect(val).toEqual({ 'toggle1': false, 'toggle2': true });
|
|
198
|
+
|
|
199
|
+
val = await toggleAndReturnValues(1);
|
|
200
|
+
expect(val).toEqual({ 'toggle1': false, 'toggle2': false });
|
|
201
|
+
|
|
202
|
+
val = await toggleAndReturnValues(1);
|
|
203
|
+
expect(val).toEqual({ 'toggle1': false, 'toggle2': true });
|
|
204
|
+
|
|
205
|
+
val = await toggleAndReturnValues(0);
|
|
206
|
+
expect(val).toEqual({ 'toggle1': true, 'toggle2': false });
|
|
207
|
+
val = await toggleAndReturnValues(1);
|
|
208
|
+
expect(val).toEqual({ 'toggle1': false, 'toggle2': true });
|
|
209
|
+
});
|
|
210
|
+
|
|
211
|
+
it('can toggle 2nd toggle doesnt emit an extra time', async () => {
|
|
212
|
+
const end = new Subject();
|
|
213
|
+
const total = lastValueFrom( toggleGroupDirective.valueEmitter.pipe(
|
|
214
|
+
takeUntil(end),
|
|
215
|
+
count( (a, i) => true ),
|
|
216
|
+
));
|
|
217
|
+
|
|
218
|
+
await toggleHarnesses[0].toggle();
|
|
219
|
+
await toggleHarnesses[1].toggle();
|
|
220
|
+
|
|
221
|
+
end.next(null);
|
|
222
|
+
const result = await total;
|
|
223
|
+
|
|
224
|
+
expect(result).toEqual(3);
|
|
225
|
+
});
|
|
226
|
+
|
|
227
|
+
});
|
|
228
|
+
|
|
229
|
+
});
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { MatTableDataSource } from '@angular/material/table';
|
|
2
|
+
import { Observable, Subscription } from 'rxjs';
|
|
3
|
+
|
|
4
|
+
export class MatTableObservableDataSource<T> extends MatTableDataSource<T> {
|
|
5
|
+
subscription?: Subscription;
|
|
6
|
+
constructor(private dataSrc: Observable<T[]>) {
|
|
7
|
+
super([]);
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
connect() {
|
|
11
|
+
if(!this.subscription) {
|
|
12
|
+
this.subscription = this.dataSrc.subscribe( data => this.data = data );
|
|
13
|
+
}
|
|
14
|
+
return super.connect();
|
|
15
|
+
}
|
|
16
|
+
disconnect() {
|
|
17
|
+
if(this.subscription) {
|
|
18
|
+
this.subscription.unsubscribe();
|
|
19
|
+
this.subscription = undefined;
|
|
20
|
+
}
|
|
21
|
+
super.disconnect();
|
|
22
|
+
}
|
|
23
|
+
}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { EnvironmentProviders, InjectionToken, makeEnvironmentProviders } from '@angular/core';
|
|
2
|
+
import { ArrayDefaults, DefaultSettings } from './DefaultSettings';
|
|
3
|
+
import { ArrayAdditional, FieldType } from '../interfaces/report-def';
|
|
4
|
+
import { MultiSortDirective } from '../directives';
|
|
5
|
+
import { PhoneNumberPipe } from '../../utilities/pipes/phone.pipe';
|
|
6
|
+
import { CurrencyPipe, DatePipe } from '@angular/common';
|
|
7
|
+
import { SpaceCasePipe } from '../../utilities/pipes/space-case.pipes';
|
|
8
|
+
import { TableBuilderSettings } from './table-builder-general-settings';
|
|
9
|
+
export interface TableBuilderConfig {
|
|
10
|
+
defaultTableSettings: Partial<Omit<TableBuilderSettings, 'injector' >> & { pageSize?: number };
|
|
11
|
+
/**
|
|
12
|
+
* @deprecated use `defaultTableSettings.tableSettings.exportSettings`.
|
|
13
|
+
*/
|
|
14
|
+
export?: TableBuilderExport;
|
|
15
|
+
dateFormats?: DefaultSettings;
|
|
16
|
+
arrayDefaults?: ArrayAdditional;
|
|
17
|
+
transformers?: Partial<{ [key in keyof typeof FieldType]: (val: any) => any }>
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
const defaultConfig: TableBuilderConfig = {
|
|
21
|
+
defaultTableSettings: {
|
|
22
|
+
pageSize: 10
|
|
23
|
+
},
|
|
24
|
+
arrayDefaults: ArrayDefaults
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
export interface TableBuilderExport {
|
|
28
|
+
dateFormat?: string;
|
|
29
|
+
dateTimeFormat?: string;
|
|
30
|
+
prepend? : string;
|
|
31
|
+
mapEnumToString?: boolean;
|
|
32
|
+
mapLinkOptions?: {
|
|
33
|
+
mapLinkToString?: boolean;
|
|
34
|
+
excellStyle?: boolean;
|
|
35
|
+
domainPrefix?: string
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
export const TableBuilderConfigToken = new InjectionToken<TableBuilderConfig>('TableBuilderConfig');
|
|
40
|
+
|
|
41
|
+
export function provideTableBuilder(config?: TableBuilderConfig) : EnvironmentProviders {
|
|
42
|
+
return makeEnvironmentProviders([
|
|
43
|
+
MultiSortDirective,
|
|
44
|
+
SpaceCasePipe,
|
|
45
|
+
DatePipe,
|
|
46
|
+
CurrencyPipe,
|
|
47
|
+
PhoneNumberPipe,
|
|
48
|
+
{ provide: TableBuilderConfigToken, useValue: config || defaultConfig }
|
|
49
|
+
])
|
|
50
|
+
}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
import { MatTableDataSource } from '@angular/material/table';
|
|
2
|
+
import { Subscription } from 'rxjs';
|
|
3
|
+
import { TableStore } from './table-store';
|
|
4
|
+
import { DataStore } from './data-store';
|
|
5
|
+
import { computed, effect, signal, Signal, untracked } from '@angular/core';
|
|
6
|
+
|
|
7
|
+
export class TableBuilderDataSource<T> extends MatTableDataSource<T> {
|
|
8
|
+
subscription?: Subscription;
|
|
9
|
+
#$dataSrc = signal<T[]>([]);
|
|
10
|
+
$dataSize: Signal<{ start: number, end: number }> = signal({ start: 0, end: 0 }, {
|
|
11
|
+
equal: (a, b) => a.start === b.start && a.end === b.end
|
|
12
|
+
});
|
|
13
|
+
_ = effect(() => {
|
|
14
|
+
const data = this.#$dataSrc();
|
|
15
|
+
const dataSize = this.$dataSize();
|
|
16
|
+
untracked(() => this.data = data.slice(dataSize.start, dataSize.end));
|
|
17
|
+
});
|
|
18
|
+
setData(data: T[]) {
|
|
19
|
+
this.#$dataSrc.set(data);
|
|
20
|
+
}
|
|
21
|
+
constructor(
|
|
22
|
+
state: TableStore,
|
|
23
|
+
data: DataStore,
|
|
24
|
+
) {
|
|
25
|
+
super([]);
|
|
26
|
+
|
|
27
|
+
const $currentPage = state.$currentPage;
|
|
28
|
+
const $pageSize = state.$pageSize;
|
|
29
|
+
const $virtualEnds = data.selectSignal(d => d.virtualEnds);
|
|
30
|
+
|
|
31
|
+
const $dataLength = computed(() => this.#$dataSrc().length);
|
|
32
|
+
|
|
33
|
+
this.$dataSize = computed(() => {
|
|
34
|
+
const viewType = state.$viewType();
|
|
35
|
+
const dataLength = $dataLength();
|
|
36
|
+
const currentPage = $currentPage();
|
|
37
|
+
const pageSize = $pageSize();
|
|
38
|
+
const virtualEnds = $virtualEnds();
|
|
39
|
+
const previousPageRecords = currentPage * pageSize;
|
|
40
|
+
if(viewType === 'virtual paginator'){
|
|
41
|
+
return ({ start: virtualEnds.start + previousPageRecords, end: Math.min(virtualEnds.end, pageSize) + previousPageRecords });
|
|
42
|
+
}
|
|
43
|
+
if(viewType === 'paginator'){
|
|
44
|
+
return ({ start: previousPageRecords, end: previousPageRecords + pageSize });
|
|
45
|
+
}
|
|
46
|
+
if(viewType === 'all'){
|
|
47
|
+
return ({ start: 0, end: dataLength });
|
|
48
|
+
}
|
|
49
|
+
return ({ start: virtualEnds.start, end: virtualEnds.end });
|
|
50
|
+
});
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
|
|
54
|
+
connect() {
|
|
55
|
+
return super.connect();
|
|
56
|
+
}
|
|
57
|
+
disconnect() {
|
|
58
|
+
if(this.subscription) {
|
|
59
|
+
this.subscription.unsubscribe();
|
|
60
|
+
this.subscription = undefined;
|
|
61
|
+
}
|
|
62
|
+
super.disconnect();
|
|
63
|
+
}
|
|
64
|
+
}
|
|
@@ -0,0 +1,125 @@
|
|
|
1
|
+
import { CustomFilter, FilterInfo } from './filter-info';
|
|
2
|
+
import { Dictionary } from '../interfaces/dictionary';
|
|
3
|
+
import { Sort } from '@angular/material/sort';
|
|
4
|
+
import { MetaData } from '../interfaces/report-def';
|
|
5
|
+
import { NotPersistedTableSettings, PersistedTableSettings } from './table-builder-general-settings';
|
|
6
|
+
import { LinkInfo } from '../services/link-creator.service';
|
|
7
|
+
import { TableProps } from '../components/table-container/tableProps';
|
|
8
|
+
|
|
9
|
+
export type NoneGroupHeader = { isGroupHeader: never } ;
|
|
10
|
+
export interface BaseGroup {
|
|
11
|
+
key: string;
|
|
12
|
+
groupName: string;
|
|
13
|
+
groupHeaderDisplay: string;
|
|
14
|
+
uniqueName: string;
|
|
15
|
+
isGroupHeader: true;
|
|
16
|
+
padding: number;
|
|
17
|
+
length: number;
|
|
18
|
+
hasTheData: boolean;
|
|
19
|
+
level: number;
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
export interface DataGroup<T extends NoneGroupHeader = any> extends BaseGroup {
|
|
23
|
+
children: T[];
|
|
24
|
+
hasTheData: true;
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
export interface GroupGroup<T extends NoneGroupHeader = any> extends BaseGroup {
|
|
28
|
+
groups: (DataGroup<T> | GroupGroup<T>)[];
|
|
29
|
+
hasTheData: false;
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
export type Group<T extends NoneGroupHeader = any> = GroupGroup<T> | DataGroup<T>
|
|
33
|
+
|
|
34
|
+
export interface GroupedData {
|
|
35
|
+
key: string,
|
|
36
|
+
expandedHeaders: string[]
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
export function isGroupHeader(data: any): data is Group {
|
|
40
|
+
return !!data?.isGroupHeader;
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
export interface PersistedTableState {
|
|
44
|
+
hiddenKeys?: string [];
|
|
45
|
+
filters: Dictionary<FilterInfo | CustomFilter>;
|
|
46
|
+
sorted : Sort [];
|
|
47
|
+
userDefined : {
|
|
48
|
+
order:Dictionary<number>,
|
|
49
|
+
widths:Dictionary<number>,
|
|
50
|
+
table:{ width?:number },
|
|
51
|
+
pageSize?: number,
|
|
52
|
+
showAll?: boolean,
|
|
53
|
+
rowHeight?: number,
|
|
54
|
+
headerHeight?: number,
|
|
55
|
+
};
|
|
56
|
+
persistedTableSettings : PersistedTableSettings;
|
|
57
|
+
groupBy: GroupedData[];
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
export interface TableState extends Required<PersistedTableState> {
|
|
61
|
+
initializationState: InitializationState;
|
|
62
|
+
metaData: Dictionary<MetaData>;
|
|
63
|
+
notPersistedTableSettings : NotPersistedTableSettings;
|
|
64
|
+
pageSize: number;
|
|
65
|
+
currentPage: number;
|
|
66
|
+
linkMaps: Dictionary<LinkInfo>;
|
|
67
|
+
props: TableProps;
|
|
68
|
+
showAll: boolean;
|
|
69
|
+
}
|
|
70
|
+
export interface DataState {
|
|
71
|
+
virtualScrollOffset: number;
|
|
72
|
+
virtualEnds: {start: number, end: number};
|
|
73
|
+
sortedFilteredDataLength: number;
|
|
74
|
+
sortedFilteredGroupedDataLength: number;
|
|
75
|
+
}
|
|
76
|
+
type RequireNull<T> = { [K in keyof T]: null };
|
|
77
|
+
class KeysToDelete implements RequireNull<Omit<TableState, keyof PersistedTableState>> {
|
|
78
|
+
initializationState = null;
|
|
79
|
+
metaData = null;
|
|
80
|
+
notPersistedTableSettings = null;
|
|
81
|
+
linkMaps = null;
|
|
82
|
+
pageSize = null;
|
|
83
|
+
currentPage = null;
|
|
84
|
+
virtualScrollOffset = null;
|
|
85
|
+
dataLen = null;
|
|
86
|
+
virtualEnds = null;
|
|
87
|
+
virtualEnd = null;
|
|
88
|
+
props = null;
|
|
89
|
+
showAll = null;
|
|
90
|
+
minColumnWidth = null;
|
|
91
|
+
}
|
|
92
|
+
export const keysToDelete = Object.keys(new KeysToDelete());
|
|
93
|
+
|
|
94
|
+
export enum InitializationState {
|
|
95
|
+
Created,
|
|
96
|
+
MetaDataLoaded,
|
|
97
|
+
TableSettingsLoaded,
|
|
98
|
+
Ready,
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
export const defaultTableState: TableState = {
|
|
102
|
+
initializationState: InitializationState.Created,
|
|
103
|
+
metaData: {},
|
|
104
|
+
filters: {},
|
|
105
|
+
hiddenKeys: [],
|
|
106
|
+
sorted: [],
|
|
107
|
+
userDefined: { order: {}, widths: {}, table: {} },
|
|
108
|
+
persistedTableSettings: new PersistedTableSettings(),
|
|
109
|
+
notPersistedTableSettings: new NotPersistedTableSettings(),
|
|
110
|
+
pageSize: 10,
|
|
111
|
+
linkMaps: {},
|
|
112
|
+
groupBy: [],
|
|
113
|
+
currentPage: 0,
|
|
114
|
+
|
|
115
|
+
props: {} as TableProps,
|
|
116
|
+
showAll: false,
|
|
117
|
+
};
|
|
118
|
+
export const defaultDataState: DataState = {
|
|
119
|
+
virtualScrollOffset: 0,
|
|
120
|
+
sortedFilteredDataLength: 0,
|
|
121
|
+
sortedFilteredGroupedDataLength: 0,
|
|
122
|
+
virtualEnds: {
|
|
123
|
+
start: 0, end: 20
|
|
124
|
+
},
|
|
125
|
+
}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { Injectable } from "@angular/core";
|
|
2
|
+
import { ComponentStore } from "@ngrx/component-store";
|
|
3
|
+
import { DataState, defaultDataState } from "./TableState";
|
|
4
|
+
|
|
5
|
+
@Injectable()
|
|
6
|
+
export class DataStore extends ComponentStore<DataState> {
|
|
7
|
+
constructor() {
|
|
8
|
+
super({ ...defaultDataState });
|
|
9
|
+
}
|
|
10
|
+
}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
export interface DisplayCol {
|
|
2
|
-
key: string;
|
|
3
|
-
displayName?: string;
|
|
4
|
-
isVisible: boolean;
|
|
5
|
-
}
|
|
1
|
+
export interface DisplayCol {
|
|
2
|
+
key: string;
|
|
3
|
+
displayName?: string;
|
|
4
|
+
isVisible: boolean;
|
|
5
|
+
}
|
|
@@ -0,0 +1,125 @@
|
|
|
1
|
+
import { FilterType } from '../enums/filterTypes';
|
|
2
|
+
import { EnumFilterFuncs, StringFilterFuncs } from '../functions/string-filter-function';
|
|
3
|
+
import { NumberFilterFuncs } from '../functions/number-filter-function';
|
|
4
|
+
import { DateFilterFuncs, DateTimeFilterFuncs } from '../functions/date-filter-function';
|
|
5
|
+
import { BooleanFilterFuncs } from '../functions/boolean-filter-function';
|
|
6
|
+
import { FieldType } from '../interfaces/report-def';
|
|
7
|
+
import { Dictionary } from '../interfaces/dictionary';
|
|
8
|
+
import { Predicate } from '@angular/core';
|
|
9
|
+
import { getFactory } from '../functions/sort-data-function';
|
|
10
|
+
|
|
11
|
+
const filterFactoryMap: Dictionary<FilterFunc<any, any>> = {
|
|
12
|
+
[FilterType.And]: (filter: FilterInfo ): ((obj: any) => boolean) => {
|
|
13
|
+
const filters = createFilterFuncs(filter.filterValue as FilterInfo[]);
|
|
14
|
+
return (obj: any) : boolean => filters.every( f => f(obj));
|
|
15
|
+
},
|
|
16
|
+
[FilterType.In]: (filter: FilterInfo ): (obj: any) => boolean => {
|
|
17
|
+
const filters = createFilterFuncs(filter.filterValue as FilterInfo[]);
|
|
18
|
+
return (obj: any) : boolean => filters.some( f => f(obj));
|
|
19
|
+
},
|
|
20
|
+
};
|
|
21
|
+
|
|
22
|
+
const filterTypeFuncMap : Record<FieldType, FilterFuncs<any>> = {
|
|
23
|
+
[FieldType.Array]: StringFilterFuncs,
|
|
24
|
+
[FieldType.Boolean]: BooleanFilterFuncs,
|
|
25
|
+
[FieldType.Currency]: NumberFilterFuncs,
|
|
26
|
+
[FieldType.Date]: DateFilterFuncs,
|
|
27
|
+
[FieldType.DateTime]: DateTimeFilterFuncs,
|
|
28
|
+
[FieldType.Enum]: EnumFilterFuncs,
|
|
29
|
+
[FieldType.Link]: StringFilterFuncs,
|
|
30
|
+
[FieldType.Number]: NumberFilterFuncs,
|
|
31
|
+
[FieldType.PhoneNumber]: StringFilterFuncs,
|
|
32
|
+
[FieldType.String]: StringFilterFuncs,
|
|
33
|
+
[FieldType.Unknown]: StringFilterFuncs,
|
|
34
|
+
} as Record<FieldType, FilterFuncs<any>>;
|
|
35
|
+
|
|
36
|
+
export const filterTypeMap = Object.entries(filterTypeFuncMap).reduce(
|
|
37
|
+
(acc, [key, value]) => ({ ...acc, [key]: Object.keys(value) }), {} as Record<FieldType, FilterType[]>
|
|
38
|
+
)
|
|
39
|
+
|
|
40
|
+
export interface FilterState {
|
|
41
|
+
filterId: string;
|
|
42
|
+
filterType: FilterType;
|
|
43
|
+
filterValue?: any;
|
|
44
|
+
active?: boolean;
|
|
45
|
+
filterBy?: (t: any) => any
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
export interface FilterInfo<T extends FieldType = any, U = any> extends FilterState {
|
|
49
|
+
key: string & keyof U;
|
|
50
|
+
fieldType: T;
|
|
51
|
+
_isExternallyManaged?: boolean;
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
export interface PartialFilter {
|
|
55
|
+
filterId?: string;
|
|
56
|
+
key: string;
|
|
57
|
+
fieldType: FieldType;
|
|
58
|
+
filterType?: FilterType;
|
|
59
|
+
filterValue?: any;
|
|
60
|
+
filterBy?: (t: any) => any
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
|
|
64
|
+
export interface CustomFilter<T = any> extends FilterState {
|
|
65
|
+
predicate: Predicate<T>;
|
|
66
|
+
filterType: typeof FilterType.Custom;
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
export function isCustomFilter(filter : FilterInfo | CustomFilter) : filter is CustomFilter {
|
|
70
|
+
return filter && filter.filterType === FilterType.Custom;
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
export function isFilterInfo(filter : FilterInfo | CustomFilter) : filter is FilterInfo {
|
|
74
|
+
return filter && typeof (filter as FilterInfo).key === 'string' && filter.filterType !== FilterType.Custom;
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
const defaultPredicate: Predicate<any> = () => true;
|
|
78
|
+
|
|
79
|
+
export function createFilterFuncs(filters: (FilterInfo | CustomFilter)[]){
|
|
80
|
+
return filters.filter(needsFilterCreation).map(createFilterFunc);
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
export function needsFilterCreation(filter: FilterInfo | CustomFilter): boolean {
|
|
84
|
+
if(isCustomFilter(filter)) {
|
|
85
|
+
return filter.active !== false;
|
|
86
|
+
}
|
|
87
|
+
return filter.filterValue != undefined && filter.active !== false;
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
export function createFilterFunc(filter: FilterInfo | CustomFilter): Predicate<any> {
|
|
91
|
+
if(isCustomFilter(filter)) {
|
|
92
|
+
return filter.active ? filter.predicate : defaultPredicate;
|
|
93
|
+
}
|
|
94
|
+
if(filter.filterValue == undefined) {
|
|
95
|
+
return defaultPredicate;
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
const func = filterTypeFuncMap[filter.fieldType][filter.filterType](filter);
|
|
99
|
+
if(!func) {
|
|
100
|
+
if(filterFactoryMap[filter.filterType]){
|
|
101
|
+
return filterFactoryMap[filter.filterType!](filter);
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
const cannotBeTrueForNull = !FalseyValueCanBeIncludedFilterTypes.includes(filter.filterType!);
|
|
106
|
+
const getter = filter.filterBy || getFactory(filter.key);
|
|
107
|
+
return (rowObj) => {
|
|
108
|
+
const value = getter(rowObj);
|
|
109
|
+
return ((value == undefined) && cannotBeTrueForNull)
|
|
110
|
+
? false
|
|
111
|
+
: func( value);
|
|
112
|
+
};
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
export type FilterFunc<T, V = T> = (filterInfo:FilterInfo) => (val:V) => boolean;
|
|
116
|
+
export type Range<T> = { Start:T, End:T };
|
|
117
|
+
|
|
118
|
+
const FalseyValueCanBeIncludedFilterTypes = [
|
|
119
|
+
FilterType.IsNull,
|
|
120
|
+
FilterType.NumberNotEqual,
|
|
121
|
+
FilterType.DateIsNotOn,
|
|
122
|
+
FilterType.StringDoesNotContain,
|
|
123
|
+
] as FilterType[];
|
|
124
|
+
|
|
125
|
+
export type FilterFuncs<T extends FilterType > = Partial<Record<T, FilterFunc<any, any>>>;
|