@dereekb/dbx-web 12.3.1 → 12.3.3
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/esm2022/lib/action/action.confirm.directive.mjs +4 -1
- package/esm2022/lib/action/snackbar/action.snackbar.component.mjs +2 -2
- package/esm2022/lib/action/transition/transition.safety.dialog.component.mjs +2 -2
- package/esm2022/lib/button/button.component.mjs +15 -9
- package/esm2022/lib/extension/download/text/download.text.component.mjs +2 -2
- package/esm2022/lib/interaction/filter/filter.wrapper.component.mjs +2 -2
- package/esm2022/lib/interaction/popup/popup.controls.buttons.component.mjs +1 -1
- package/esm2022/lib/interaction/prompt/prompt.confirm.dialog.component.mjs +2 -2
- package/esm2022/lib/interaction/prompt/prompt.confirm.directive.mjs +9 -10
- package/esm2022/lib/layout/text/detail.block.component.mjs +6 -5
- package/esm2022/lib/layout/text/detail.block.header.component.mjs +29 -7
- package/esm2022/lib/layout/text/index.mjs +2 -1
- package/esm2022/lib/layout/text/number.limit.component.mjs +82 -0
- package/esm2022/lib/layout/text/text.module.mjs +4 -3
- package/esm2022/table/lib/table.component.mjs +4 -3
- package/esm2022/table/lib/table.mjs +1 -1
- package/esm2022/table/lib/table.reader.mjs +1 -1
- package/esm2022/table/lib/table.store.mjs +4 -1
- package/fesm2022/dereekb-dbx-web-table.mjs +6 -3
- package/fesm2022/dereekb-dbx-web-table.mjs.map +1 -1
- package/fesm2022/dereekb-dbx-web.mjs +144 -35
- package/fesm2022/dereekb-dbx-web.mjs.map +1 -1
- package/lib/action/action.confirm.directive.d.ts +1 -0
- package/lib/button/_button.scss +12 -0
- package/lib/button/button.component.d.ts +17 -2
- package/lib/extension/table/_table.scss +4 -2
- package/lib/interaction/dialog/_dialog.scss +29 -0
- package/lib/interaction/prompt/prompt.confirm.directive.d.ts +3 -5
- package/lib/layout/list/_list.scss +12 -0
- package/lib/layout/text/_text.scss +23 -1
- package/lib/layout/text/detail.block.component.d.ts +2 -1
- package/lib/layout/text/detail.block.header.component.d.ts +2 -1
- package/lib/layout/text/index.d.ts +1 -0
- package/lib/layout/text/number.limit.component.d.ts +40 -0
- package/lib/layout/text/text.module.d.ts +9 -8
- package/lib/style/_mixin.scss +20 -23
- package/lib/style/_root-variables.scss +41 -1
- package/lib/style/_variables.scss +32 -3
- package/package.json +1 -1
- package/table/lib/table.component.d.ts +1 -0
- package/table/lib/table.d.ts +5 -1
- package/table/lib/table.reader.d.ts +1 -1
- package/table/lib/table.store.d.ts +2 -0
|
@@ -7,22 +7,23 @@ import * as i0 from "@angular/core";
|
|
|
7
7
|
export class DbxDetailBlockComponent {
|
|
8
8
|
icon = input();
|
|
9
9
|
header = input();
|
|
10
|
+
alignHeader = input(false);
|
|
10
11
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxDetailBlockComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
11
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: DbxDetailBlockComponent, isStandalone: true, selector: "dbx-detail-block", inputs: { icon: { classPropertyName: "icon", publicName: "icon", isSignal: true, isRequired: false, transformFunction: null }, header: { classPropertyName: "header", publicName: "header", isSignal: true, isRequired: false, transformFunction: null } }, host: { classAttribute: "dbx-detail-block d-block" }, ngImport: i0, template: `
|
|
12
|
-
<dbx-detail-block-header [icon]="icon()" [header]="header()">
|
|
12
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: DbxDetailBlockComponent, isStandalone: true, selector: "dbx-detail-block", inputs: { icon: { classPropertyName: "icon", publicName: "icon", isSignal: true, isRequired: false, transformFunction: null }, header: { classPropertyName: "header", publicName: "header", isSignal: true, isRequired: false, transformFunction: null }, alignHeader: { classPropertyName: "alignHeader", publicName: "alignHeader", isSignal: true, isRequired: false, transformFunction: null } }, host: { classAttribute: "dbx-detail-block d-block" }, ngImport: i0, template: `
|
|
13
|
+
<dbx-detail-block-header [icon]="icon()" [header]="header()" [alignHeader]="alignHeader()">
|
|
13
14
|
<ng-content select="[header]"></ng-content>
|
|
14
15
|
</dbx-detail-block-header>
|
|
15
16
|
<div class="dbx-detail-block-content">
|
|
16
17
|
<ng-content></ng-content>
|
|
17
18
|
</div>
|
|
18
|
-
`, isInline: true, dependencies: [{ kind: "component", type: DbxDetailBlockHeaderComponent, selector: "dbx-detail-block-header", inputs: ["icon", "header"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
19
|
+
`, isInline: true, dependencies: [{ kind: "component", type: DbxDetailBlockHeaderComponent, selector: "dbx-detail-block-header", inputs: ["icon", "header", "alignHeader"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
19
20
|
}
|
|
20
21
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxDetailBlockComponent, decorators: [{
|
|
21
22
|
type: Component,
|
|
22
23
|
args: [{
|
|
23
24
|
selector: 'dbx-detail-block',
|
|
24
25
|
template: `
|
|
25
|
-
<dbx-detail-block-header [icon]="icon()" [header]="header()">
|
|
26
|
+
<dbx-detail-block-header [icon]="icon()" [header]="header()" [alignHeader]="alignHeader()">
|
|
26
27
|
<ng-content select="[header]"></ng-content>
|
|
27
28
|
</dbx-detail-block-header>
|
|
28
29
|
<div class="dbx-detail-block-content">
|
|
@@ -37,4 +38,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
37
38
|
changeDetection: ChangeDetectionStrategy.OnPush
|
|
38
39
|
}]
|
|
39
40
|
}] });
|
|
40
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
41
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGV0YWlsLmJsb2NrLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC13ZWIvc3JjL2xpYi9sYXlvdXQvdGV4dC9kZXRhaWwuYmxvY2suY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTFFLE9BQU8sRUFBRSw2QkFBNkIsRUFBRSxNQUFNLGlDQUFpQyxDQUFDOztBQUVoRjs7R0FFRztBQWtCSCxNQUFNLE9BQU8sdUJBQXVCO0lBQ3pCLElBQUksR0FBRyxLQUFLLEVBQWlCLENBQUM7SUFDOUIsTUFBTSxHQUFHLEtBQUssRUFBaUIsQ0FBQztJQUNoQyxXQUFXLEdBQUcsS0FBSyxDQUFVLEtBQUssQ0FBQyxDQUFDO3dHQUhsQyx1QkFBdUI7NEZBQXZCLHVCQUF1Qix3Z0JBZnhCOzs7Ozs7O0dBT1QsNERBSVMsNkJBQTZCOzs0RkFJNUIsdUJBQXVCO2tCQWpCbkMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsa0JBQWtCO29CQUM1QixRQUFRLEVBQUU7Ozs7Ozs7R0FPVDtvQkFDRCxJQUFJLEVBQUU7d0JBQ0osS0FBSyxFQUFFLDBCQUEwQjtxQkFDbEM7b0JBQ0QsT0FBTyxFQUFFLENBQUMsNkJBQTZCLENBQUM7b0JBQ3hDLFVBQVUsRUFBRSxJQUFJO29CQUNoQixlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTtpQkFDaEQiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBpbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgdHlwZSBNYXliZSB9IGZyb20gJ0BkZXJlZWtiL3V0aWwnO1xuaW1wb3J0IHsgRGJ4RGV0YWlsQmxvY2tIZWFkZXJDb21wb25lbnQgfSBmcm9tICcuL2RldGFpbC5ibG9jay5oZWFkZXIuY29tcG9uZW50JztcblxuLyoqXG4gKiBIZWFkZXIgYW5kIGRldGFpbHMgb2Zmc2V0IHdpdGggYW4gaWNvbi5cbiAqL1xuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnZGJ4LWRldGFpbC1ibG9jaycsXG4gIHRlbXBsYXRlOiBgXG4gICAgPGRieC1kZXRhaWwtYmxvY2staGVhZGVyIFtpY29uXT1cImljb24oKVwiIFtoZWFkZXJdPVwiaGVhZGVyKClcIiBbYWxpZ25IZWFkZXJdPVwiYWxpZ25IZWFkZXIoKVwiPlxuICAgICAgPG5nLWNvbnRlbnQgc2VsZWN0PVwiW2hlYWRlcl1cIj48L25nLWNvbnRlbnQ+XG4gICAgPC9kYngtZGV0YWlsLWJsb2NrLWhlYWRlcj5cbiAgICA8ZGl2IGNsYXNzPVwiZGJ4LWRldGFpbC1ibG9jay1jb250ZW50XCI+XG4gICAgICA8bmctY29udGVudD48L25nLWNvbnRlbnQ+XG4gICAgPC9kaXY+XG4gIGAsXG4gIGhvc3Q6IHtcbiAgICBjbGFzczogJ2RieC1kZXRhaWwtYmxvY2sgZC1ibG9jaydcbiAgfSxcbiAgaW1wb3J0czogW0RieERldGFpbEJsb2NrSGVhZGVyQ29tcG9uZW50XSxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcbn0pXG5leHBvcnQgY2xhc3MgRGJ4RGV0YWlsQmxvY2tDb21wb25lbnQge1xuICByZWFkb25seSBpY29uID0gaW5wdXQ8TWF5YmU8c3RyaW5nPj4oKTtcbiAgcmVhZG9ubHkgaGVhZGVyID0gaW5wdXQ8TWF5YmU8c3RyaW5nPj4oKTtcbiAgcmVhZG9ubHkgYWxpZ25IZWFkZXIgPSBpbnB1dDxib29sZWFuPihmYWxzZSk7XG59XG4iXX0=
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { NgTemplateOutlet } from '@angular/common';
|
|
1
2
|
import { ChangeDetectionStrategy, Component, input } from '@angular/core';
|
|
2
3
|
import { MatIconModule } from '@angular/material/icon';
|
|
3
4
|
import * as i0 from "@angular/core";
|
|
@@ -5,16 +6,27 @@ import * as i1 from "@angular/material/icon";
|
|
|
5
6
|
export class DbxDetailBlockHeaderComponent {
|
|
6
7
|
icon = input();
|
|
7
8
|
header = input();
|
|
9
|
+
alignHeader = input(false);
|
|
8
10
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxDetailBlockHeaderComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
9
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: DbxDetailBlockHeaderComponent, isStandalone: true, selector: "dbx-detail-block-header", inputs: { icon: { classPropertyName: "icon", publicName: "icon", isSignal: true, isRequired: false, transformFunction: null }, header: { classPropertyName: "header", publicName: "header", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "class": "{ \"dbx-detail-block-header-no-icon\": !icon() }" }, classAttribute: "dbx-detail-block-header" }, ngImport: i0, template: `
|
|
11
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: DbxDetailBlockHeaderComponent, isStandalone: true, selector: "dbx-detail-block-header", inputs: { icon: { classPropertyName: "icon", publicName: "icon", isSignal: true, isRequired: false, transformFunction: null }, header: { classPropertyName: "header", publicName: "header", isSignal: true, isRequired: false, transformFunction: null }, alignHeader: { classPropertyName: "alignHeader", publicName: "alignHeader", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "class": "{ \"dbx-detail-block-header-no-icon\": !icon(), \"dbx-detail-block-header-align\": alignHeader() }" }, classAttribute: "dbx-detail-block-header" }, ngImport: i0, template: `
|
|
10
12
|
@if (icon()) {
|
|
11
13
|
<mat-icon>{{ icon() }}</mat-icon>
|
|
12
14
|
}
|
|
13
15
|
@if (header()) {
|
|
14
16
|
<span class="dbx-detail-block-header-label">{{ header() }}</span>
|
|
15
17
|
}
|
|
16
|
-
|
|
17
|
-
|
|
18
|
+
@if (alignHeader()) {
|
|
19
|
+
<div class="dbx-flex dbx-w100">
|
|
20
|
+
<span class="dbx-spacer"></span>
|
|
21
|
+
<ng-template *ngTemplateOutlet="content"></ng-template>
|
|
22
|
+
</div>
|
|
23
|
+
} @else {
|
|
24
|
+
<ng-template *ngTemplateOutlet="content"></ng-template>
|
|
25
|
+
}
|
|
26
|
+
<ng-template #content>
|
|
27
|
+
<ng-content></ng-content>
|
|
28
|
+
</ng-template>
|
|
29
|
+
`, isInline: true, dependencies: [{ kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i1.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
18
30
|
}
|
|
19
31
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxDetailBlockHeaderComponent, decorators: [{
|
|
20
32
|
type: Component,
|
|
@@ -27,15 +39,25 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
27
39
|
@if (header()) {
|
|
28
40
|
<span class="dbx-detail-block-header-label">{{ header() }}</span>
|
|
29
41
|
}
|
|
30
|
-
|
|
42
|
+
@if (alignHeader()) {
|
|
43
|
+
<div class="dbx-flex dbx-w100">
|
|
44
|
+
<span class="dbx-spacer"></span>
|
|
45
|
+
<ng-template *ngTemplateOutlet="content"></ng-template>
|
|
46
|
+
</div>
|
|
47
|
+
} @else {
|
|
48
|
+
<ng-template *ngTemplateOutlet="content"></ng-template>
|
|
49
|
+
}
|
|
50
|
+
<ng-template #content>
|
|
51
|
+
<ng-content></ng-content>
|
|
52
|
+
</ng-template>
|
|
31
53
|
`,
|
|
32
54
|
host: {
|
|
33
55
|
class: 'dbx-detail-block-header',
|
|
34
|
-
'[class]': '{ "dbx-detail-block-header-no-icon": !icon() }'
|
|
56
|
+
'[class]': '{ "dbx-detail-block-header-no-icon": !icon(), "dbx-detail-block-header-align": alignHeader() }'
|
|
35
57
|
},
|
|
36
|
-
imports: [MatIconModule],
|
|
58
|
+
imports: [MatIconModule, NgTemplateOutlet],
|
|
37
59
|
standalone: true,
|
|
38
60
|
changeDetection: ChangeDetectionStrategy.OnPush
|
|
39
61
|
}]
|
|
40
62
|
}] });
|
|
41
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
63
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGV0YWlsLmJsb2NrLmhlYWRlci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3NyYy9saWIvbGF5b3V0L3RleHQvZGV0YWlsLmJsb2NrLmhlYWRlci5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDbkQsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDMUUsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDOzs7QUFnQ3ZELE1BQU0sT0FBTyw2QkFBNkI7SUFDL0IsSUFBSSxHQUFHLEtBQUssRUFBaUIsQ0FBQztJQUM5QixNQUFNLEdBQUcsS0FBSyxFQUFpQixDQUFDO0lBQ2hDLFdBQVcsR0FBRyxLQUFLLENBQVUsS0FBSyxDQUFDLENBQUM7d0dBSGxDLDZCQUE2Qjs0RkFBN0IsNkJBQTZCLDZvQkEzQjlCOzs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FrQlQsMkRBS1MsYUFBYSxvTEFBRSxnQkFBZ0I7OzRGQUk5Qiw2QkFBNkI7a0JBN0J6QyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSx5QkFBeUI7b0JBQ25DLFFBQVEsRUFBRTs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBa0JUO29CQUNELElBQUksRUFBRTt3QkFDSixLQUFLLEVBQUUseUJBQXlCO3dCQUNoQyxTQUFTLEVBQUUsZ0dBQWdHO3FCQUM1RztvQkFDRCxPQUFPLEVBQUUsQ0FBQyxhQUFhLEVBQUUsZ0JBQWdCLENBQUM7b0JBQzFDLFVBQVUsRUFBRSxJQUFJO29CQUNoQixlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTtpQkFDaEQiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ1RlbXBsYXRlT3V0bGV0IH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIGlucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBNYXRJY29uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaWNvbic7XG5pbXBvcnQgeyB0eXBlIE1heWJlIH0gZnJvbSAnQGRlcmVla2IvdXRpbCc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2RieC1kZXRhaWwtYmxvY2staGVhZGVyJyxcbiAgdGVtcGxhdGU6IGBcbiAgICBAaWYgKGljb24oKSkge1xuICAgICAgPG1hdC1pY29uPnt7IGljb24oKSB9fTwvbWF0LWljb24+XG4gICAgfVxuICAgIEBpZiAoaGVhZGVyKCkpIHtcbiAgICAgIDxzcGFuIGNsYXNzPVwiZGJ4LWRldGFpbC1ibG9jay1oZWFkZXItbGFiZWxcIj57eyBoZWFkZXIoKSB9fTwvc3Bhbj5cbiAgICB9XG4gICAgQGlmIChhbGlnbkhlYWRlcigpKSB7XG4gICAgICA8ZGl2IGNsYXNzPVwiZGJ4LWZsZXggZGJ4LXcxMDBcIj5cbiAgICAgICAgPHNwYW4gY2xhc3M9XCJkYngtc3BhY2VyXCI+PC9zcGFuPlxuICAgICAgICA8bmctdGVtcGxhdGUgKm5nVGVtcGxhdGVPdXRsZXQ9XCJjb250ZW50XCI+PC9uZy10ZW1wbGF0ZT5cbiAgICAgIDwvZGl2PlxuICAgIH0gQGVsc2Uge1xuICAgICAgPG5nLXRlbXBsYXRlICpuZ1RlbXBsYXRlT3V0bGV0PVwiY29udGVudFwiPjwvbmctdGVtcGxhdGU+XG4gICAgfVxuICAgIDxuZy10ZW1wbGF0ZSAjY29udGVudD5cbiAgICAgIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cbiAgICA8L25nLXRlbXBsYXRlPlxuICBgLFxuICBob3N0OiB7XG4gICAgY2xhc3M6ICdkYngtZGV0YWlsLWJsb2NrLWhlYWRlcicsXG4gICAgJ1tjbGFzc10nOiAneyBcImRieC1kZXRhaWwtYmxvY2staGVhZGVyLW5vLWljb25cIjogIWljb24oKSwgXCJkYngtZGV0YWlsLWJsb2NrLWhlYWRlci1hbGlnblwiOiBhbGlnbkhlYWRlcigpIH0nXG4gIH0sXG4gIGltcG9ydHM6IFtNYXRJY29uTW9kdWxlLCBOZ1RlbXBsYXRlT3V0bGV0XSxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcbn0pXG5leHBvcnQgY2xhc3MgRGJ4RGV0YWlsQmxvY2tIZWFkZXJDb21wb25lbnQge1xuICByZWFkb25seSBpY29uID0gaW5wdXQ8TWF5YmU8c3RyaW5nPj4oKTtcbiAgcmVhZG9ubHkgaGVhZGVyID0gaW5wdXQ8TWF5YmU8c3RyaW5nPj4oKTtcbiAgcmVhZG9ubHkgYWxpZ25IZWFkZXIgPSBpbnB1dDxib29sZWFuPihmYWxzZSk7XG59XG4iXX0=
|
|
@@ -6,5 +6,6 @@ export * from './label.block.component';
|
|
|
6
6
|
export * from './linkify.component';
|
|
7
7
|
export * from './text.chip.directive';
|
|
8
8
|
export * from './text.chips.component';
|
|
9
|
+
export * from './number.limit.component';
|
|
9
10
|
export * from './text.module';
|
|
10
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
11
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3NyYy9saWIvbGF5b3V0L3RleHQvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxxQkFBcUIsQ0FBQztBQUNwQyxjQUFjLDBCQUEwQixDQUFDO0FBQ3pDLGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMscUJBQXFCLENBQUM7QUFDcEMsY0FBYyx1QkFBdUIsQ0FBQztBQUN0QyxjQUFjLHdCQUF3QixDQUFDO0FBQ3ZDLGNBQWMsMEJBQTBCLENBQUM7QUFDekMsY0FBYyxlQUFlLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2FkZHJlc3MuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vZGV0YWlsLmJsb2NrLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2RldGFpbC5ibG9jay5oZWFkZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vaWNvbi5zcGFjZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGFiZWwuYmxvY2suY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGlua2lmeS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi90ZXh0LmNoaXAuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vdGV4dC5jaGlwcy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9udW1iZXIubGltaXQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vdGV4dC5tb2R1bGUnO1xuIl19
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, computed, input } from '@angular/core';
|
|
2
|
+
import { DbxColorDirective } from '../style/style.color.directive';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class DbxNumberWithLimitComponent {
|
|
5
|
+
number = input();
|
|
6
|
+
rounded = input();
|
|
7
|
+
valueSignal = computed(() => {
|
|
8
|
+
const number = this.number();
|
|
9
|
+
return number?.formatNumber ? number.formatNumber(number.value) : number?.value;
|
|
10
|
+
});
|
|
11
|
+
limitSignal = computed(() => {
|
|
12
|
+
const number = this.number();
|
|
13
|
+
return number?.limit != null ? (number?.formatNumber ? number.formatNumber(number.limit) : number?.limit) : undefined;
|
|
14
|
+
});
|
|
15
|
+
hasLimitSignal = computed(() => {
|
|
16
|
+
return this.number()?.limit != null;
|
|
17
|
+
});
|
|
18
|
+
prefixSignal = computed(() => {
|
|
19
|
+
return this.number()?.prefix;
|
|
20
|
+
});
|
|
21
|
+
suffixSignal = computed(() => {
|
|
22
|
+
return this.number()?.suffix;
|
|
23
|
+
});
|
|
24
|
+
colorSignal = computed(() => {
|
|
25
|
+
const number = this.number();
|
|
26
|
+
let color;
|
|
27
|
+
if (number != null) {
|
|
28
|
+
const { value, limit } = number;
|
|
29
|
+
if (limit != null) {
|
|
30
|
+
if (value > limit) {
|
|
31
|
+
color = 'warn';
|
|
32
|
+
}
|
|
33
|
+
else if (value === limit) {
|
|
34
|
+
color = 'notice';
|
|
35
|
+
}
|
|
36
|
+
else {
|
|
37
|
+
const ratio = limit === 0 ? 1 : value / limit;
|
|
38
|
+
if (ratio > 0.8) {
|
|
39
|
+
color = 'notice';
|
|
40
|
+
}
|
|
41
|
+
else {
|
|
42
|
+
color = 'ok';
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
return color;
|
|
48
|
+
});
|
|
49
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxNumberWithLimitComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
50
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: DbxNumberWithLimitComponent, isStandalone: true, selector: "dbx-number-with-limit", inputs: { number: { classPropertyName: "number", publicName: "number", isSignal: true, isRequired: false, transformFunction: null }, rounded: { classPropertyName: "rounded", publicName: "rounded", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: `
|
|
51
|
+
<span class="dbx-number-with-limit" [class]="{ 'dbx-number-with-limit-rounded': rounded() }" [dbxColor]="colorSignal()">
|
|
52
|
+
<span>{{ prefixSignal() }}</span>
|
|
53
|
+
<span>{{ valueSignal() }}</span>
|
|
54
|
+
@if (hasLimitSignal()) {
|
|
55
|
+
<span class="dbx-number-with-limit-divider">/</span>
|
|
56
|
+
<span>{{ limitSignal() }}</span>
|
|
57
|
+
}
|
|
58
|
+
<span>{{ suffixSignal() }}</span>
|
|
59
|
+
</span>
|
|
60
|
+
`, isInline: true, dependencies: [{ kind: "directive", type: DbxColorDirective, selector: "[dbxColor]", inputs: ["dbxColor"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
61
|
+
}
|
|
62
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxNumberWithLimitComponent, decorators: [{
|
|
63
|
+
type: Component,
|
|
64
|
+
args: [{
|
|
65
|
+
selector: 'dbx-number-with-limit',
|
|
66
|
+
template: `
|
|
67
|
+
<span class="dbx-number-with-limit" [class]="{ 'dbx-number-with-limit-rounded': rounded() }" [dbxColor]="colorSignal()">
|
|
68
|
+
<span>{{ prefixSignal() }}</span>
|
|
69
|
+
<span>{{ valueSignal() }}</span>
|
|
70
|
+
@if (hasLimitSignal()) {
|
|
71
|
+
<span class="dbx-number-with-limit-divider">/</span>
|
|
72
|
+
<span>{{ limitSignal() }}</span>
|
|
73
|
+
}
|
|
74
|
+
<span>{{ suffixSignal() }}</span>
|
|
75
|
+
</span>
|
|
76
|
+
`,
|
|
77
|
+
imports: [DbxColorDirective],
|
|
78
|
+
standalone: true,
|
|
79
|
+
changeDetection: ChangeDetectionStrategy.OnPush
|
|
80
|
+
}]
|
|
81
|
+
}] });
|
|
82
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnVtYmVyLmxpbWl0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC13ZWIvc3JjL2xpYi9sYXlvdXQvdGV4dC9udW1iZXIubGltaXQuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsUUFBUSxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUVwRixPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQzs7QUE4Q25FLE1BQU0sT0FBTywyQkFBMkI7SUFDN0IsTUFBTSxHQUFHLEtBQUssRUFBc0IsQ0FBQztJQUNyQyxPQUFPLEdBQUcsS0FBSyxFQUFXLENBQUM7SUFFM0IsV0FBVyxHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUU7UUFDbkMsTUFBTSxNQUFNLEdBQUcsSUFBSSxDQUFDLE1BQU0sRUFBRSxDQUFDO1FBQzdCLE9BQU8sTUFBTSxFQUFFLFlBQVksQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLFlBQVksQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLE1BQU0sRUFBRSxLQUFLLENBQUM7SUFDbEYsQ0FBQyxDQUFDLENBQUM7SUFFTSxXQUFXLEdBQUcsUUFBUSxDQUFDLEdBQUcsRUFBRTtRQUNuQyxNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7UUFDN0IsT0FBTyxNQUFNLEVBQUUsS0FBSyxJQUFJLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxNQUFNLEVBQUUsWUFBWSxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsWUFBWSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsTUFBTSxFQUFFLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUM7SUFDeEgsQ0FBQyxDQUFDLENBQUM7SUFFTSxjQUFjLEdBQUcsUUFBUSxDQUFDLEdBQUcsRUFBRTtRQUN0QyxPQUFPLElBQUksQ0FBQyxNQUFNLEVBQUUsRUFBRSxLQUFLLElBQUksSUFBSSxDQUFDO0lBQ3RDLENBQUMsQ0FBQyxDQUFDO0lBRU0sWUFBWSxHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUU7UUFDcEMsT0FBTyxJQUFJLENBQUMsTUFBTSxFQUFFLEVBQUUsTUFBTSxDQUFDO0lBQy9CLENBQUMsQ0FBQyxDQUFDO0lBRU0sWUFBWSxHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUU7UUFDcEMsT0FBTyxJQUFJLENBQUMsTUFBTSxFQUFFLEVBQUUsTUFBTSxDQUFDO0lBQy9CLENBQUMsQ0FBQyxDQUFDO0lBRU0sV0FBVyxHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUU7UUFDbkMsTUFBTSxNQUFNLEdBQUcsSUFBSSxDQUFDLE1BQU0sRUFBRSxDQUFDO1FBQzdCLElBQUksS0FBMkIsQ0FBQztRQUVoQyxJQUFJLE1BQU0sSUFBSSxJQUFJLEVBQUUsQ0FBQztZQUNuQixNQUFNLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxHQUFHLE1BQU0sQ0FBQztZQUVoQyxJQUFJLEtBQUssSUFBSSxJQUFJLEVBQUUsQ0FBQztnQkFDbEIsSUFBSSxLQUFLLEdBQUcsS0FBSyxFQUFFLENBQUM7b0JBQ2xCLEtBQUssR0FBRyxNQUFNLENBQUM7Z0JBQ2pCLENBQUM7cUJBQU0sSUFBSSxLQUFLLEtBQUssS0FBSyxFQUFFLENBQUM7b0JBQzNCLEtBQUssR0FBRyxRQUFRLENBQUM7Z0JBQ25CLENBQUM7cUJBQU0sQ0FBQztvQkFDTixNQUFNLEtBQUssR0FBRyxLQUFLLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLEtBQUssR0FBRyxLQUFLLENBQUM7b0JBRTlDLElBQUksS0FBSyxHQUFHLEdBQUcsRUFBRSxDQUFDO3dCQUNoQixLQUFLLEdBQUcsUUFBUSxDQUFDO29CQUNuQixDQUFDO3lCQUFNLENBQUM7d0JBQ04sS0FBSyxHQUFHLElBQUksQ0FBQztvQkFDZixDQUFDO2dCQUNILENBQUM7WUFDSCxDQUFDO1FBQ0gsQ0FBQztRQUVELE9BQU8sS0FBSyxDQUFDO0lBQ2YsQ0FBQyxDQUFDLENBQUM7d0dBbkRRLDJCQUEyQjs0RkFBM0IsMkJBQTJCLHNWQWY1Qjs7Ozs7Ozs7OztHQVVULDREQUNTLGlCQUFpQjs7NEZBSWhCLDJCQUEyQjtrQkFqQnZDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLHVCQUF1QjtvQkFDakMsUUFBUSxFQUFFOzs7Ozs7Ozs7O0dBVVQ7b0JBQ0QsT0FBTyxFQUFFLENBQUMsaUJBQWlCLENBQUM7b0JBQzVCLFVBQVUsRUFBRSxJQUFJO29CQUNoQixlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTtpQkFDaEQiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBjb21wdXRlZCwgaW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE1heWJlIH0gZnJvbSAnQGRlcmVla2IvdXRpbCc7XG5pbXBvcnQgeyBEYnhDb2xvckRpcmVjdGl2ZSB9IGZyb20gJy4uL3N0eWxlL3N0eWxlLmNvbG9yLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBEYnhUaGVtZUNvbG9yIH0gZnJvbSAnLi4vc3R5bGUvc3R5bGUnO1xuXG4vKipcbiAqIENvbmZpZ3VyYXRpb24gZm9yIHRoZSBEYnhOdW1iZXJXaXRoTGltaXRDb21wb25lbnQuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgTnVtYmVyV2l0aExpbWl0PFQgZXh0ZW5kcyBudW1iZXI+IHtcbiAgLyoqXG4gICAqIE51bWJlciB0byBkaXNwbGF5LCBpZiBhcHBsaWNhYmxlLlxuICAgKi9cbiAgcmVhZG9ubHkgdmFsdWU6IFQ7XG4gIC8qKlxuICAgKiBMaW1pdCB0byBkaXNwbGF5LCBpZiBhcHBsaWNhYmxlLlxuICAgKi9cbiAgcmVhZG9ubHkgbGltaXQ/OiBNYXliZTxUPjtcbiAgLyoqXG4gICAqIEZ1bmN0aW9uIHRvIGZvcm1hdCB0aGUgaW5wdXQgbnVtYmVyKHMpIHRvIGEgc3RyaW5nIGJlZm9yZSBiZWluZyBkaXNwbGF5ZWQsIGlmIGFwcGxpY2FibGUuXG4gICAqL1xuICByZWFkb25seSBmb3JtYXROdW1iZXI/OiBNYXliZTwobnVtYmVyOiBUKSA9PiBzdHJpbmc+O1xuICAvKipcbiAgICogUHJlZml4IHRvIGFkZCBiZWZvcmUgdGhlIHZhbHVlXG4gICAqL1xuICByZWFkb25seSBwcmVmaXg/OiBNYXliZTxzdHJpbmc+O1xuICAvKipcbiAgICogU3VmZml4IHRvIGFkZCBhZnRlciB0aGUgdmFsdWVcbiAgICovXG4gIHJlYWRvbmx5IHN1ZmZpeD86IE1heWJlPHN0cmluZz47XG59XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2RieC1udW1iZXItd2l0aC1saW1pdCcsXG4gIHRlbXBsYXRlOiBgXG4gICAgPHNwYW4gY2xhc3M9XCJkYngtbnVtYmVyLXdpdGgtbGltaXRcIiBbY2xhc3NdPVwieyAnZGJ4LW51bWJlci13aXRoLWxpbWl0LXJvdW5kZWQnOiByb3VuZGVkKCkgfVwiIFtkYnhDb2xvcl09XCJjb2xvclNpZ25hbCgpXCI+XG4gICAgICA8c3Bhbj57eyBwcmVmaXhTaWduYWwoKSB9fTwvc3Bhbj5cbiAgICAgIDxzcGFuPnt7IHZhbHVlU2lnbmFsKCkgfX08L3NwYW4+XG4gICAgICBAaWYgKGhhc0xpbWl0U2lnbmFsKCkpIHtcbiAgICAgICAgPHNwYW4gY2xhc3M9XCJkYngtbnVtYmVyLXdpdGgtbGltaXQtZGl2aWRlclwiPi88L3NwYW4+XG4gICAgICAgIDxzcGFuPnt7IGxpbWl0U2lnbmFsKCkgfX08L3NwYW4+XG4gICAgICB9XG4gICAgICA8c3Bhbj57eyBzdWZmaXhTaWduYWwoKSB9fTwvc3Bhbj5cbiAgICA8L3NwYW4+XG4gIGAsXG4gIGltcG9ydHM6IFtEYnhDb2xvckRpcmVjdGl2ZV0sXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXG59KVxuZXhwb3J0IGNsYXNzIERieE51bWJlcldpdGhMaW1pdENvbXBvbmVudDxUIGV4dGVuZHMgbnVtYmVyPiB7XG4gIHJlYWRvbmx5IG51bWJlciA9IGlucHV0PE51bWJlcldpdGhMaW1pdDxUPj4oKTtcbiAgcmVhZG9ubHkgcm91bmRlZCA9IGlucHV0PGJvb2xlYW4+KCk7XG5cbiAgcmVhZG9ubHkgdmFsdWVTaWduYWwgPSBjb21wdXRlZCgoKSA9PiB7XG4gICAgY29uc3QgbnVtYmVyID0gdGhpcy5udW1iZXIoKTtcbiAgICByZXR1cm4gbnVtYmVyPy5mb3JtYXROdW1iZXIgPyBudW1iZXIuZm9ybWF0TnVtYmVyKG51bWJlci52YWx1ZSkgOiBudW1iZXI/LnZhbHVlO1xuICB9KTtcblxuICByZWFkb25seSBsaW1pdFNpZ25hbCA9IGNvbXB1dGVkKCgpID0+IHtcbiAgICBjb25zdCBudW1iZXIgPSB0aGlzLm51bWJlcigpO1xuICAgIHJldHVybiBudW1iZXI/LmxpbWl0ICE9IG51bGwgPyAobnVtYmVyPy5mb3JtYXROdW1iZXIgPyBudW1iZXIuZm9ybWF0TnVtYmVyKG51bWJlci5saW1pdCkgOiBudW1iZXI/LmxpbWl0KSA6IHVuZGVmaW5lZDtcbiAgfSk7XG5cbiAgcmVhZG9ubHkgaGFzTGltaXRTaWduYWwgPSBjb21wdXRlZCgoKSA9PiB7XG4gICAgcmV0dXJuIHRoaXMubnVtYmVyKCk/LmxpbWl0ICE9IG51bGw7XG4gIH0pO1xuXG4gIHJlYWRvbmx5IHByZWZpeFNpZ25hbCA9IGNvbXB1dGVkKCgpID0+IHtcbiAgICByZXR1cm4gdGhpcy5udW1iZXIoKT8ucHJlZml4O1xuICB9KTtcblxuICByZWFkb25seSBzdWZmaXhTaWduYWwgPSBjb21wdXRlZCgoKSA9PiB7XG4gICAgcmV0dXJuIHRoaXMubnVtYmVyKCk/LnN1ZmZpeDtcbiAgfSk7XG5cbiAgcmVhZG9ubHkgY29sb3JTaWduYWwgPSBjb21wdXRlZCgoKSA9PiB7XG4gICAgY29uc3QgbnVtYmVyID0gdGhpcy5udW1iZXIoKTtcbiAgICBsZXQgY29sb3I6IE1heWJlPERieFRoZW1lQ29sb3I+O1xuXG4gICAgaWYgKG51bWJlciAhPSBudWxsKSB7XG4gICAgICBjb25zdCB7IHZhbHVlLCBsaW1pdCB9ID0gbnVtYmVyO1xuXG4gICAgICBpZiAobGltaXQgIT0gbnVsbCkge1xuICAgICAgICBpZiAodmFsdWUgPiBsaW1pdCkge1xuICAgICAgICAgIGNvbG9yID0gJ3dhcm4nO1xuICAgICAgICB9IGVsc2UgaWYgKHZhbHVlID09PSBsaW1pdCkge1xuICAgICAgICAgIGNvbG9yID0gJ25vdGljZSc7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgY29uc3QgcmF0aW8gPSBsaW1pdCA9PT0gMCA/IDEgOiB2YWx1ZSAvIGxpbWl0O1xuXG4gICAgICAgICAgaWYgKHJhdGlvID4gMC44KSB7XG4gICAgICAgICAgICBjb2xvciA9ICdub3RpY2UnO1xuICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICBjb2xvciA9ICdvayc7XG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICB9XG4gICAgfVxuXG4gICAgcmV0dXJuIGNvbG9yO1xuICB9KTtcbn1cbiJdfQ==
|
|
@@ -7,11 +7,12 @@ import { DbxLabelBlockComponent } from './label.block.component';
|
|
|
7
7
|
import { DbxLinkifyComponent } from './linkify.component';
|
|
8
8
|
import { DbxChipDirective } from './text.chip.directive';
|
|
9
9
|
import { DbxTextChipsComponent } from './text.chips.component';
|
|
10
|
+
import { DbxNumberWithLimitComponent } from './number.limit.component';
|
|
10
11
|
import * as i0 from "@angular/core";
|
|
11
|
-
const importsAndExports = [DbxUnitedStatesAddressComponent, DbxChipDirective, DbxDetailBlockComponent, DbxDetailBlockHeaderComponent, DbxLabelBlockComponent, DbxLinkifyComponent, DbxTextChipsComponent, DbxIconSpacerDirective];
|
|
12
|
+
const importsAndExports = [DbxUnitedStatesAddressComponent, DbxNumberWithLimitComponent, DbxChipDirective, DbxDetailBlockComponent, DbxDetailBlockHeaderComponent, DbxLabelBlockComponent, DbxLinkifyComponent, DbxTextChipsComponent, DbxIconSpacerDirective];
|
|
12
13
|
export class DbxTextModule {
|
|
13
14
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxTextModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
14
|
-
static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.13", ngImport: i0, type: DbxTextModule, imports: [DbxUnitedStatesAddressComponent, DbxChipDirective, DbxDetailBlockComponent, DbxDetailBlockHeaderComponent, DbxLabelBlockComponent, DbxLinkifyComponent, DbxTextChipsComponent, DbxIconSpacerDirective], exports: [DbxUnitedStatesAddressComponent, DbxChipDirective, DbxDetailBlockComponent, DbxDetailBlockHeaderComponent, DbxLabelBlockComponent, DbxLinkifyComponent, DbxTextChipsComponent, DbxIconSpacerDirective] });
|
|
15
|
+
static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.13", ngImport: i0, type: DbxTextModule, imports: [DbxUnitedStatesAddressComponent, DbxNumberWithLimitComponent, DbxChipDirective, DbxDetailBlockComponent, DbxDetailBlockHeaderComponent, DbxLabelBlockComponent, DbxLinkifyComponent, DbxTextChipsComponent, DbxIconSpacerDirective], exports: [DbxUnitedStatesAddressComponent, DbxNumberWithLimitComponent, DbxChipDirective, DbxDetailBlockComponent, DbxDetailBlockHeaderComponent, DbxLabelBlockComponent, DbxLinkifyComponent, DbxTextChipsComponent, DbxIconSpacerDirective] });
|
|
15
16
|
static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxTextModule, imports: [DbxDetailBlockComponent, DbxDetailBlockHeaderComponent, DbxTextChipsComponent] });
|
|
16
17
|
}
|
|
17
18
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxTextModule, decorators: [{
|
|
@@ -21,4 +22,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
21
22
|
exports: importsAndExports
|
|
22
23
|
}]
|
|
23
24
|
}] });
|
|
24
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
25
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGV4dC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3NyYy9saWIvbGF5b3V0L3RleHQvdGV4dC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsK0JBQStCLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUN0RSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUNuRSxPQUFPLEVBQUUsNkJBQTZCLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUNoRixPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUNqRSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUNqRSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUMxRCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUN6RCxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUMvRCxPQUFPLEVBQUUsMkJBQTJCLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQzs7QUFFdkUsTUFBTSxpQkFBaUIsR0FBRyxDQUFDLCtCQUErQixFQUFFLDJCQUEyQixFQUFFLGdCQUFnQixFQUFFLHVCQUF1QixFQUFFLDZCQUE2QixFQUFFLHNCQUFzQixFQUFFLG1CQUFtQixFQUFFLHFCQUFxQixFQUFFLHNCQUFzQixDQUFDLENBQUM7QUFNL1AsTUFBTSxPQUFPLGFBQWE7d0dBQWIsYUFBYTt5R0FBYixhQUFhLFlBTkMsK0JBQStCLEVBQUUsMkJBQTJCLEVBQUUsZ0JBQWdCLEVBQUUsdUJBQXVCLEVBQUUsNkJBQTZCLEVBQUUsc0JBQXNCLEVBQUUsbUJBQW1CLEVBQUUscUJBQXFCLEVBQUUsc0JBQXNCLGFBQWxPLCtCQUErQixFQUFFLDJCQUEyQixFQUFFLGdCQUFnQixFQUFFLHVCQUF1QixFQUFFLDZCQUE2QixFQUFFLHNCQUFzQixFQUFFLG1CQUFtQixFQUFFLHFCQUFxQixFQUFFLHNCQUFzQjt5R0FNaFAsYUFBYSxZQU5pRix1QkFBdUIsRUFBRSw2QkFBNkIsRUFBK0MscUJBQXFCOzs0RkFNeE4sYUFBYTtrQkFKekIsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUUsaUJBQWlCO29CQUMxQixPQUFPLEVBQUUsaUJBQWlCO2lCQUMzQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBEYnhVbml0ZWRTdGF0ZXNBZGRyZXNzQ29tcG9uZW50IH0gZnJvbSAnLi9hZGRyZXNzLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEYnhEZXRhaWxCbG9ja0NvbXBvbmVudCB9IGZyb20gJy4vZGV0YWlsLmJsb2NrLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEYnhEZXRhaWxCbG9ja0hlYWRlckNvbXBvbmVudCB9IGZyb20gJy4vZGV0YWlsLmJsb2NrLmhlYWRlci5jb21wb25lbnQnO1xuaW1wb3J0IHsgRGJ4SWNvblNwYWNlckRpcmVjdGl2ZSB9IGZyb20gJy4vaWNvbi5zcGFjZXIuY29tcG9uZW50JztcbmltcG9ydCB7IERieExhYmVsQmxvY2tDb21wb25lbnQgfSBmcm9tICcuL2xhYmVsLmJsb2NrLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEYnhMaW5raWZ5Q29tcG9uZW50IH0gZnJvbSAnLi9saW5raWZ5LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEYnhDaGlwRGlyZWN0aXZlIH0gZnJvbSAnLi90ZXh0LmNoaXAuZGlyZWN0aXZlJztcbmltcG9ydCB7IERieFRleHRDaGlwc0NvbXBvbmVudCB9IGZyb20gJy4vdGV4dC5jaGlwcy5jb21wb25lbnQnO1xuaW1wb3J0IHsgRGJ4TnVtYmVyV2l0aExpbWl0Q29tcG9uZW50IH0gZnJvbSAnLi9udW1iZXIubGltaXQuY29tcG9uZW50JztcblxuY29uc3QgaW1wb3J0c0FuZEV4cG9ydHMgPSBbRGJ4VW5pdGVkU3RhdGVzQWRkcmVzc0NvbXBvbmVudCwgRGJ4TnVtYmVyV2l0aExpbWl0Q29tcG9uZW50LCBEYnhDaGlwRGlyZWN0aXZlLCBEYnhEZXRhaWxCbG9ja0NvbXBvbmVudCwgRGJ4RGV0YWlsQmxvY2tIZWFkZXJDb21wb25lbnQsIERieExhYmVsQmxvY2tDb21wb25lbnQsIERieExpbmtpZnlDb21wb25lbnQsIERieFRleHRDaGlwc0NvbXBvbmVudCwgRGJ4SWNvblNwYWNlckRpcmVjdGl2ZV07XG5cbkBOZ01vZHVsZSh7XG4gIGltcG9ydHM6IGltcG9ydHNBbmRFeHBvcnRzLFxuICBleHBvcnRzOiBpbXBvcnRzQW5kRXhwb3J0c1xufSlcbmV4cG9ydCBjbGFzcyBEYnhUZXh0TW9kdWxlIHt9XG4iXX0=
|
|
@@ -118,6 +118,7 @@ export class DbxTableViewComponent {
|
|
|
118
118
|
dataLoadingContextSignal = toSignal(this.dataLoadingContext.state$);
|
|
119
119
|
viewDelegateSignal = toSignal(this.tableStore.viewDelegate$);
|
|
120
120
|
elementsSignal = toSignal(this.elements$, { initialValue: [] });
|
|
121
|
+
tableCssClasses = toSignal(this.tableStore.spaceSeparatedTableCssClasses$);
|
|
121
122
|
onScrollDown() {
|
|
122
123
|
this.tableStore.loadMore();
|
|
123
124
|
}
|
|
@@ -145,7 +146,7 @@ export class DbxTableViewComponent {
|
|
|
145
146
|
provide: DBX_TABLE_COLUMN_SIZE_PARENT_ELEMENT_REF_TOKEN,
|
|
146
147
|
useExisting: ElementRef
|
|
147
148
|
}
|
|
148
|
-
], viewQueries: [{ propertyName: "table", first: true, predicate: MatTable, descendants: true, isSignal: true }], ngImport: i0, template: "<dbx-loading [context]=\"context\">\n <dbx-loading class=\"dbx-table-view-loading\" [linear]=\"true\" [context]=\"dataLoadingContext\"></dbx-loading>\n <section class=\"dbx-table-view\" dbx-table-column-size #columnSize=\"dbxTableColumnSize\" infinite-scroll [infiniteScrollDistance]=\"scrollDistance()\" [infiniteScrollThrottle]=\"throttleScroll()\" [scrollWindow]=\"false\" (scrolled)=\"onScrollDown()\">\n
|
|
149
|
+
], viewQueries: [{ propertyName: "table", first: true, predicate: MatTable, descendants: true, isSignal: true }], ngImport: i0, template: "<dbx-loading [context]=\"context\">\n <dbx-loading class=\"dbx-table-view-loading\" [linear]=\"true\" [context]=\"dataLoadingContext\"></dbx-loading>\n <div class=\"dbx-table-view\" [ngClass]=\"tableCssClasses()\">\n <section class=\"dbx-table-view-table-wrapper\" dbx-table-column-size #columnSize=\"dbxTableColumnSize\" infinite-scroll [infiniteScrollDistance]=\"scrollDistance()\" [infiniteScrollThrottle]=\"throttleScroll()\" [scrollWindow]=\"false\" (scrolled)=\"onScrollDown()\">\n <table class=\"dbx-table-view-table\" mat-table [dataSource]=\"elementsSignal()\" [trackBy]=\"trackElementByFunctionSignal()\" multiTemplateDataRows>\n <!-- Groups -->\n <!-- Group Header column -->\n <ng-container matColumnDef=\"groupHeaderColumn\" [sticky]=\"true\">\n <td mat-cell [attr.colspan]=\"columnSize.visibleColumnsSignal()\" *matCellDef=\"let element\">\n <dbx-table-group-header [group]=\"element.group\"></dbx-table-group-header>\n </td>\n </ng-container>\n\n <!-- Group Footer column -->\n <ng-container matColumnDef=\"groupFooterColumn\" [sticky]=\"true\">\n <td mat-cell [attr.colspan]=\"columnSize.visibleColumnsSignal()\" *matCellDef=\"let element\">\n <dbx-table-group-footer [group]=\"element.group\"></dbx-table-group-footer>\n </td>\n </ng-container>\n\n <!-- Items -->\n <!-- Header/Item column -->\n <ng-container [matColumnDef]=\"itemsColumnName\" [sticky]=\"true\">\n <th dbx-column-size-column=\"head\" mat-header-cell *matHeaderCellDef>\n <dbx-table-input-cell></dbx-table-input-cell>\n </th>\n <td mat-cell *matCellDef=\"let element\">\n <dbx-table-item-header [item]=\"element.item\"></dbx-table-item-header>\n </td>\n <td mat-footer-cell *matFooterCellDef>\n <dbx-table-summary-start-cell></dbx-table-summary-start-cell>\n </td>\n </ng-container>\n\n <!-- Column Definitions -->\n @for (column of innerColumnsSignal(); track column.columnName) {\n <ng-container [matColumnDef]=\"column.columnName\" [sticky]=\"false\">\n <th [dbx-column-size-column]=\"$index\" mat-header-cell *matHeaderCellDef>\n <dbx-table-column-header [column]=\"column\"></dbx-table-column-header>\n </th>\n <td mat-cell *matCellDef=\"let element\">\n <dbx-table-item-cell [item]=\"element.item\" [column]=\"column\"></dbx-table-item-cell>\n </td>\n <td mat-footer-cell *matFooterCellDef>\n <dbx-table-column-footer [column]=\"column\"></dbx-table-column-footer>\n </td>\n </ng-container>\n }\n\n <!-- Tail/Action column -->\n <ng-container [matColumnDef]=\"actionsColumnName\" [stickyEnd]=\"true\">\n <th dbx-column-size-column=\"tail\" mat-header-cell *matHeaderCellDef>\n <dbx-table-action-cell></dbx-table-action-cell>\n </th>\n <td mat-cell *matCellDef=\"let element\">\n <dbx-table-item-action [item]=\"element.item\"></dbx-table-item-action>\n </td>\n <td mat-footer-cell *matFooterCellDef>\n <dbx-table-summary-end-cell></dbx-table-summary-end-cell>\n </td>\n </ng-container>\n\n <!-- Table View -->\n <tr mat-header-row *matHeaderRowDef=\"displayedColumnsSignal(); sticky: true\"></tr>\n\n <tr mat-row *matRowDef=\"let row; columns: ['groupHeaderColumn']; when: showGroupHeaderRow\"></tr>\n <tr mat-row *matRowDef=\"let row; columns: displayedColumnsSignal(); when: showItemRow\"></tr>\n <tr mat-row *matRowDef=\"let row; columns: ['groupFooterColumn']; when: showGroupFooterRow\"></tr>\n\n <tr [ngClass]=\"{ 'dbx-hide': !showFooterRowSignal() }\" mat-footer-row *matFooterRowDef=\"displayedColumnsSignal(); sticky: true\"></tr>\n </table>\n </section>\n <!-- Full summary row -->\n @if (showFullSummaryRowSignal()) {\n <div class=\"mat-mdc-table dbx-table-view-full-summary-row-container\">\n <div class=\"mdc-data-table__cell mat-mdc-row\">\n <dbx-table-full-summary-row></dbx-table-full-summary-row>\n </div>\n </div>\n }\n </div>\n</dbx-loading>\n", dependencies: [{ kind: "component", type: DbxLoadingComponent, selector: "dbx-loading", inputs: ["padding", "show", "text", "mode", "color", "diameter", "linear", "loading", "error", "context"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: InfiniteScrollDirective, selector: "[infiniteScroll], [infinite-scroll], [data-infinite-scroll]", inputs: ["infiniteScrollDistance", "infiniteScrollUpDistance", "infiniteScrollThrottle", "infiniteScrollDisabled", "infiniteScrollContainer", "scrollWindow", "immediateCheck", "horizontal", "alwaysCallback", "fromRoot"], outputs: ["scrolled", "scrolledUp"] }, { 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: "component", type: DbxTableInputCellComponent, selector: "dbx-table-input-cell" }, { kind: "component", type: DbxTableItemHeaderComponent, selector: "dbx-table-item-header" }, { kind: "component", type: DbxTableItemCellComponent, selector: "dbx-table-item-cell", inputs: ["column"] }, { kind: "component", type: DbxTableItemActionComponent, selector: "dbx-table-item-action" }, { kind: "component", type: DbxTableActionCellComponent, selector: "dbx-table-action-cell" }, { kind: "component", type: DbxTableColumnHeaderComponent, selector: "dbx-table-column-header" }, { kind: "component", type: DbxTableColumnFooterComponent, selector: "dbx-table-column-footer" }, { kind: "component", type: DbxTableSummaryStartCellComponent, selector: "dbx-table-summary-start-cell" }, { kind: "component", type: DbxTableSummaryEndCellComponent, selector: "dbx-table-summary-end-cell" }, { kind: "component", type: DbxTableGroupHeaderComponent, selector: "dbx-table-group-header" }, { kind: "component", type: DbxTableGroupFooterComponent, selector: "dbx-table-group-footer" }, { kind: "component", type: DbxTableFullSummaryRowComponent, selector: "dbx-table-full-summary-row" }, { kind: "directive", type: DbxTableColumnSizeDirective, selector: "[dbx-table-column-size]", exportAs: ["dbxTableColumnSize"] }, { kind: "directive", type: DbxColumnSizeColumnDirective, selector: "[dbx-column-size-column]", inputs: ["dbx-column-size-column"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
149
150
|
}
|
|
150
151
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxTableViewComponent, decorators: [{
|
|
151
152
|
type: Component,
|
|
@@ -173,6 +174,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
173
174
|
provide: DBX_TABLE_COLUMN_SIZE_PARENT_ELEMENT_REF_TOKEN,
|
|
174
175
|
useExisting: ElementRef
|
|
175
176
|
}
|
|
176
|
-
], changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, template: "<dbx-loading [context]=\"context\">\n <dbx-loading class=\"dbx-table-view-loading\" [linear]=\"true\" [context]=\"dataLoadingContext\"></dbx-loading>\n <section class=\"dbx-table-view\" dbx-table-column-size #columnSize=\"dbxTableColumnSize\" infinite-scroll [infiniteScrollDistance]=\"scrollDistance()\" [infiniteScrollThrottle]=\"throttleScroll()\" [scrollWindow]=\"false\" (scrolled)=\"onScrollDown()\">\n
|
|
177
|
+
], changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, template: "<dbx-loading [context]=\"context\">\n <dbx-loading class=\"dbx-table-view-loading\" [linear]=\"true\" [context]=\"dataLoadingContext\"></dbx-loading>\n <div class=\"dbx-table-view\" [ngClass]=\"tableCssClasses()\">\n <section class=\"dbx-table-view-table-wrapper\" dbx-table-column-size #columnSize=\"dbxTableColumnSize\" infinite-scroll [infiniteScrollDistance]=\"scrollDistance()\" [infiniteScrollThrottle]=\"throttleScroll()\" [scrollWindow]=\"false\" (scrolled)=\"onScrollDown()\">\n <table class=\"dbx-table-view-table\" mat-table [dataSource]=\"elementsSignal()\" [trackBy]=\"trackElementByFunctionSignal()\" multiTemplateDataRows>\n <!-- Groups -->\n <!-- Group Header column -->\n <ng-container matColumnDef=\"groupHeaderColumn\" [sticky]=\"true\">\n <td mat-cell [attr.colspan]=\"columnSize.visibleColumnsSignal()\" *matCellDef=\"let element\">\n <dbx-table-group-header [group]=\"element.group\"></dbx-table-group-header>\n </td>\n </ng-container>\n\n <!-- Group Footer column -->\n <ng-container matColumnDef=\"groupFooterColumn\" [sticky]=\"true\">\n <td mat-cell [attr.colspan]=\"columnSize.visibleColumnsSignal()\" *matCellDef=\"let element\">\n <dbx-table-group-footer [group]=\"element.group\"></dbx-table-group-footer>\n </td>\n </ng-container>\n\n <!-- Items -->\n <!-- Header/Item column -->\n <ng-container [matColumnDef]=\"itemsColumnName\" [sticky]=\"true\">\n <th dbx-column-size-column=\"head\" mat-header-cell *matHeaderCellDef>\n <dbx-table-input-cell></dbx-table-input-cell>\n </th>\n <td mat-cell *matCellDef=\"let element\">\n <dbx-table-item-header [item]=\"element.item\"></dbx-table-item-header>\n </td>\n <td mat-footer-cell *matFooterCellDef>\n <dbx-table-summary-start-cell></dbx-table-summary-start-cell>\n </td>\n </ng-container>\n\n <!-- Column Definitions -->\n @for (column of innerColumnsSignal(); track column.columnName) {\n <ng-container [matColumnDef]=\"column.columnName\" [sticky]=\"false\">\n <th [dbx-column-size-column]=\"$index\" mat-header-cell *matHeaderCellDef>\n <dbx-table-column-header [column]=\"column\"></dbx-table-column-header>\n </th>\n <td mat-cell *matCellDef=\"let element\">\n <dbx-table-item-cell [item]=\"element.item\" [column]=\"column\"></dbx-table-item-cell>\n </td>\n <td mat-footer-cell *matFooterCellDef>\n <dbx-table-column-footer [column]=\"column\"></dbx-table-column-footer>\n </td>\n </ng-container>\n }\n\n <!-- Tail/Action column -->\n <ng-container [matColumnDef]=\"actionsColumnName\" [stickyEnd]=\"true\">\n <th dbx-column-size-column=\"tail\" mat-header-cell *matHeaderCellDef>\n <dbx-table-action-cell></dbx-table-action-cell>\n </th>\n <td mat-cell *matCellDef=\"let element\">\n <dbx-table-item-action [item]=\"element.item\"></dbx-table-item-action>\n </td>\n <td mat-footer-cell *matFooterCellDef>\n <dbx-table-summary-end-cell></dbx-table-summary-end-cell>\n </td>\n </ng-container>\n\n <!-- Table View -->\n <tr mat-header-row *matHeaderRowDef=\"displayedColumnsSignal(); sticky: true\"></tr>\n\n <tr mat-row *matRowDef=\"let row; columns: ['groupHeaderColumn']; when: showGroupHeaderRow\"></tr>\n <tr mat-row *matRowDef=\"let row; columns: displayedColumnsSignal(); when: showItemRow\"></tr>\n <tr mat-row *matRowDef=\"let row; columns: ['groupFooterColumn']; when: showGroupFooterRow\"></tr>\n\n <tr [ngClass]=\"{ 'dbx-hide': !showFooterRowSignal() }\" mat-footer-row *matFooterRowDef=\"displayedColumnsSignal(); sticky: true\"></tr>\n </table>\n </section>\n <!-- Full summary row -->\n @if (showFullSummaryRowSignal()) {\n <div class=\"mat-mdc-table dbx-table-view-full-summary-row-container\">\n <div class=\"mdc-data-table__cell mat-mdc-row\">\n <dbx-table-full-summary-row></dbx-table-full-summary-row>\n </div>\n </div>\n }\n </div>\n</dbx-loading>\n" }]
|
|
177
178
|
}] });
|
|
178
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../../packages/dbx-web/table/src/lib/table.component.ts","../../../../../../packages/dbx-web/table/src/lib/table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, TrackByFunction, inject, computed, input, Signal, viewChild, ElementRef } from '@angular/core';\nimport { toSignal } from '@angular/core/rxjs-interop';\nimport { DbxTableStore } from './table.store';\nimport { LoadingState, loadingStateContext, mapLoadingStateValueWithOperator, valueFromFinishedLoadingState } from '@dereekb/rxjs';\nimport { shareReplay, map, Observable, switchMap, throttleTime } from 'rxjs';\nimport { DbxLoadingComponent } from '@dereekb/dbx-web';\nimport { InfiniteScrollDirective } from 'ngx-infinite-scroll';\nimport { MatTable, MatTableModule } from '@angular/material/table';\nimport { DbxTableInputCellComponent } from './table.cell.input.component';\nimport { DbxTableSummaryEndCellComponent } from './table.cell.summaryend.component';\nimport { DbxTableSummaryStartCellComponent } from './table.cell.summarystart.component';\nimport { DbxTableColumnFooterComponent } from './table.column.footer.component';\nimport { DbxTableItemCellComponent } from './table.item.cell.component';\nimport { DbxTableItemHeaderComponent } from './table.item.header.component';\nimport { DbxTableItemActionComponent } from './table.item.action.component';\nimport { DbxTableActionCellComponent } from './table.cell.action.component';\nimport { DbxTableColumnHeaderComponent } from './table.column.header.component';\nimport { DbxTableItemGroup, DefaultDbxTableItemGroup } from './table';\nimport { DbxTableGroupHeaderComponent } from './table.group.header.component';\nimport { DbxTableGroupFooterComponent } from './table.group.footer.component';\nimport { pushArrayItemsIntoArray } from '@dereekb/util';\nimport { NgClass } from '@angular/common';\nimport { DbxTableFullSummaryRowComponent } from './table.fullsummaryrow.component';\nimport { DbxTableColumnSizeDirective, DbxColumnSizeColumnDirective } from './table.column.size.directive';\nimport { DBX_TABLE_COLUMN_SIZE_PARENT_ELEMENT_REF_TOKEN } from './table.column.size';\n\nexport const DBX_TABLE_ITEMS_COLUMN_NAME = '_items';\nexport const DBX_TABLE_ACTIONS_COLUMN_NAME = '_actions';\n\nexport interface DbxTableViewGroupElement<T, G> {\n  readonly type: 'group';\n  readonly location: 'header' | 'footer';\n  readonly group: DbxTableItemGroup<T, G>;\n}\n\nexport interface DbxTableViewItemElement<T, G> {\n  readonly type: 'item';\n  readonly item: T;\n}\n\nexport type DbxTableViewElement<T, G> = DbxTableViewGroupElement<T, G> | DbxTableViewItemElement<T, G>;\n\nexport function isDbxTableViewGroupElement<T, G>(element: DbxTableViewElement<T, G>): element is DbxTableViewGroupElement<T, G> {\n  return element.type === 'group';\n}\n\nexport function isDbxTableViewItemElement<T, G>(element: DbxTableViewElement<T, G>): element is DbxTableViewItemElement<T, G> {\n  return element.type === 'item';\n}\n\n/**\n * A table with fixed content\n */\n@Component({\n  selector: 'dbx-table-view',\n  templateUrl: './table.component.html',\n  imports: [\n    DbxLoadingComponent,\n    NgClass,\n    InfiniteScrollDirective,\n    MatTableModule,\n    DbxTableInputCellComponent,\n    DbxTableItemHeaderComponent,\n    DbxTableItemCellComponent,\n    DbxTableItemActionComponent,\n    DbxTableActionCellComponent,\n    DbxTableColumnHeaderComponent,\n    DbxTableColumnFooterComponent,\n    DbxTableSummaryStartCellComponent,\n    DbxTableSummaryEndCellComponent,\n    DbxTableGroupHeaderComponent,\n    DbxTableGroupFooterComponent,\n    DbxTableFullSummaryRowComponent,\n    DbxTableColumnSizeDirective,\n    DbxColumnSizeColumnDirective\n  ],\n  providers: [\n    {\n      provide: DBX_TABLE_COLUMN_SIZE_PARENT_ELEMENT_REF_TOKEN,\n      useExisting: ElementRef\n    }\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true\n})\nexport class DbxTableViewComponent<I, C, T, G = unknown> {\n  readonly tableStore = inject(DbxTableStore<I, C, T, G>);\n  readonly table = viewChild.required<MatTable<DbxTableViewElement<T, G>>>(MatTable);\n\n  readonly DEFAULT_TRACK_BY_FUNCTION: TrackByFunction<any> = (index) => {\n    return index;\n  };\n\n  readonly scrollDistance = input<number>(0.5);\n  readonly throttleScroll = input<number>(50);\n\n  readonly itemsColumnName = DBX_TABLE_ITEMS_COLUMN_NAME;\n  readonly actionsColumnName = DBX_TABLE_ACTIONS_COLUMN_NAME;\n\n  readonly innerColumns$ = this.tableStore.columns$;\n  readonly innerColumnNames$ = this.innerColumns$.pipe(\n    map((x) => x.map((y) => y.columnName)),\n    shareReplay(1)\n  );\n\n  readonly innerColumnsSignal = toSignal(this.innerColumns$);\n  readonly innerColumnNamesSignal = toSignal(this.innerColumnNames$);\n\n  readonly elementsState$: Observable<LoadingState<DbxTableViewElement<T, G>[]>> = this.tableStore.groupsState$.pipe(\n    mapLoadingStateValueWithOperator(\n      switchMap((groups) => {\n        return this.tableStore.viewDelegate$.pipe(\n          map((viewDelegate) => {\n            const { groupHeader: inputGroupHeader, groupFooter: inputGroupFooter } = viewDelegate;\n            const hasGroupHeader = inputGroupHeader != null ? (group: DbxTableItemGroup<T, G>) => inputGroupHeader(group) != null : () => false;\n            const hasGroupFooter = inputGroupFooter != null ? (group: DbxTableItemGroup<T, G>) => inputGroupFooter(group) != null : () => false;\n\n            return groups\n              .map((group) => {\n                const { items } = group;\n\n                const itemElements: DbxTableViewItemElement<T, G>[] = items.map((item) => ({\n                  type: 'item',\n                  item\n                }));\n\n                let elements: DbxTableViewElement<T, G>[];\n\n                if ((group as DefaultDbxTableItemGroup<T, G>).default) {\n                  elements = itemElements;\n                } else {\n                  const header = hasGroupHeader(group);\n                  const footer = hasGroupFooter(group);\n\n                  elements = [];\n\n                  if (header) {\n                    elements.push({\n                      type: 'group',\n                      location: 'header',\n                      group\n                    });\n                  }\n\n                  pushArrayItemsIntoArray(elements, itemElements);\n\n                  if (footer) {\n                    elements.push({\n                      type: 'group',\n                      location: 'footer',\n                      group\n                    });\n                  }\n                }\n\n                return elements;\n              })\n              .flat();\n          })\n        );\n      })\n    ),\n    shareReplay(1)\n  );\n\n  readonly elements$ = this.elementsState$.pipe(\n    valueFromFinishedLoadingState(() => []),\n    throttleTime(50, undefined, { leading: true, trailing: true }),\n    shareReplay(1)\n  );\n\n  readonly displayedColumns$ = this.innerColumnNames$.pipe(\n    map((columnNames) => {\n      return [this.itemsColumnName, ...columnNames, this.actionsColumnName];\n    }),\n    shareReplay(1)\n  );\n\n  readonly displayedColumnsSignal = computed(() => {\n    const columnNames = this.innerColumnNamesSignal() || [];\n    return [this.itemsColumnName, ...columnNames, this.actionsColumnName];\n  });\n\n  readonly trackByFunction$: Observable<TrackByFunction<T>> = this.tableStore.viewDelegate$.pipe(\n    map((x) => x.trackBy ?? this.DEFAULT_TRACK_BY_FUNCTION),\n    shareReplay(1)\n  );\n\n  readonly inputTrackByFunctionSignal = toSignal(this.trackByFunction$, { initialValue: this.DEFAULT_TRACK_BY_FUNCTION });\n  readonly trackElementByFunctionSignal: Signal<TrackByFunction<DbxTableViewElement<T, G>>> = computed(() => {\n    const trackByFunction = this.inputTrackByFunctionSignal() as TrackByFunction<T>;\n\n    const fn: TrackByFunction<DbxTableViewElement<T, G>> = (index: number, element: DbxTableViewElement<T, G>) => {\n      if (element.type === 'item') {\n        return `i_${trackByFunction(index, element.item as T)}`;\n      } else {\n        return `g_${element.group.groupId}`;\n      }\n    };\n\n    return fn;\n  });\n\n  readonly context = loadingStateContext({ obs: this.tableStore.dataState$ });\n  readonly dataLoadingContext = loadingStateContext({ obs: this.elementsState$ });\n\n  readonly contextSignal = toSignal(this.context.state$);\n  readonly dataLoadingContextSignal = toSignal(this.dataLoadingContext.state$);\n\n  readonly viewDelegateSignal = toSignal(this.tableStore.viewDelegate$);\n  readonly elementsSignal = toSignal(this.elements$, { initialValue: [] });\n\n  onScrollDown(): void {\n    this.tableStore.loadMore();\n  }\n\n  showItemRow(_: number, row: DbxTableViewElement<T, G>): boolean {\n    return row.type === 'item';\n  }\n\n  showGroupHeaderRow(_: number, row: DbxTableViewElement<T, G>): boolean {\n    return row.type === 'group' && row.location === 'header';\n  }\n\n  showGroupFooterRow(_: number, row: DbxTableViewElement<T, G>): boolean {\n    return row.type === 'group' && row.location === 'footer';\n  }\n\n  readonly showFooterRowSignal = computed(() => {\n    const viewDelegate = this.viewDelegateSignal();\n    const showFooterRow = viewDelegate && (viewDelegate.summaryRowHeader != null || viewDelegate.columnFooter != null || viewDelegate.summaryRowEnd != null);\n    return showFooterRow;\n  });\n\n  readonly showFullSummaryRowSignal = computed(() => {\n    const viewDelegate = this.viewDelegateSignal();\n    return viewDelegate?.fullSummaryRow != null;\n  });\n}\n","<dbx-loading [context]=\"context\">\n  <dbx-loading class=\"dbx-table-view-loading\" [linear]=\"true\" [context]=\"dataLoadingContext\"></dbx-loading>\n  <section class=\"dbx-table-view\" dbx-table-column-size #columnSize=\"dbxTableColumnSize\" infinite-scroll [infiniteScrollDistance]=\"scrollDistance()\" [infiniteScrollThrottle]=\"throttleScroll()\" [scrollWindow]=\"false\" (scrolled)=\"onScrollDown()\">\n    <table class=\"dbx-table-view-table\" mat-table [dataSource]=\"elementsSignal()\" [trackBy]=\"trackElementByFunctionSignal()\" multiTemplateDataRows>\n      <!-- Groups -->\n      <!-- Group Header column -->\n      <ng-container matColumnDef=\"groupHeaderColumn\" [sticky]=\"true\">\n        <td mat-cell [attr.colspan]=\"columnSize.visibleColumnsSignal()\" *matCellDef=\"let element\">\n          <dbx-table-group-header [group]=\"element.group\"></dbx-table-group-header>\n        </td>\n      </ng-container>\n\n      <!-- Group Footer column -->\n      <ng-container matColumnDef=\"groupFooterColumn\" [sticky]=\"true\">\n        <td mat-cell [attr.colspan]=\"columnSize.visibleColumnsSignal()\" *matCellDef=\"let element\">\n          <dbx-table-group-footer [group]=\"element.group\"></dbx-table-group-footer>\n        </td>\n      </ng-container>\n\n      <!-- Items -->\n      <!-- Header/Item column -->\n      <ng-container [matColumnDef]=\"itemsColumnName\" [sticky]=\"true\">\n        <th dbx-column-size-column=\"head\" mat-header-cell *matHeaderCellDef>\n          <dbx-table-input-cell></dbx-table-input-cell>\n        </th>\n        <td mat-cell *matCellDef=\"let element\">\n          <dbx-table-item-header [item]=\"element.item\"></dbx-table-item-header>\n        </td>\n        <td mat-footer-cell *matFooterCellDef>\n          <dbx-table-summary-start-cell></dbx-table-summary-start-cell>\n        </td>\n      </ng-container>\n\n      <!-- Column Definitions -->\n      @for (column of innerColumnsSignal(); track column.columnName) {\n        <ng-container [matColumnDef]=\"column.columnName\" [sticky]=\"false\">\n          <th [dbx-column-size-column]=\"$index\" mat-header-cell *matHeaderCellDef>\n            <dbx-table-column-header [column]=\"column\"></dbx-table-column-header>\n          </th>\n          <td mat-cell *matCellDef=\"let element\">\n            <dbx-table-item-cell [item]=\"element.item\" [column]=\"column\"></dbx-table-item-cell>\n          </td>\n          <td mat-footer-cell *matFooterCellDef>\n            <dbx-table-column-footer [column]=\"column\"></dbx-table-column-footer>\n          </td>\n        </ng-container>\n      }\n\n      <!-- Tail/Action column -->\n      <ng-container [matColumnDef]=\"actionsColumnName\" [stickyEnd]=\"true\">\n        <th dbx-column-size-column=\"tail\" mat-header-cell *matHeaderCellDef>\n          <dbx-table-action-cell></dbx-table-action-cell>\n        </th>\n        <td mat-cell *matCellDef=\"let element\">\n          <dbx-table-item-action [item]=\"element.item\"></dbx-table-item-action>\n        </td>\n        <td mat-footer-cell *matFooterCellDef>\n          <dbx-table-summary-end-cell></dbx-table-summary-end-cell>\n        </td>\n      </ng-container>\n\n      <!-- Table View -->\n      <tr mat-header-row *matHeaderRowDef=\"displayedColumnsSignal(); sticky: true\"></tr>\n\n      <tr mat-row *matRowDef=\"let row; columns: ['groupHeaderColumn']; when: showGroupHeaderRow\"></tr>\n      <tr mat-row *matRowDef=\"let row; columns: displayedColumnsSignal(); when: showItemRow\"></tr>\n      <tr mat-row *matRowDef=\"let row; columns: ['groupFooterColumn']; when: showGroupFooterRow\"></tr>\n\n      <tr [ngClass]=\"{ 'dbx-hide': !showFooterRowSignal() }\" mat-footer-row *matFooterRowDef=\"displayedColumnsSignal(); sticky: true\"></tr>\n    </table>\n  </section>\n  <!-- Full summary row -->\n  @if (showFullSummaryRowSignal()) {\n    <div class=\"mat-mdc-table dbx-table-view-full-summary-row-container\">\n      <div class=\"mdc-data-table__cell mat-mdc-row\">\n        <dbx-table-full-summary-row></dbx-table-full-summary-row>\n      </div>\n    </div>\n  }\n</dbx-loading>\n"]}
|
|
179
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../../packages/dbx-web/table/src/lib/table.component.ts","../../../../../../packages/dbx-web/table/src/lib/table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, TrackByFunction, inject, computed, input, Signal, viewChild, ElementRef } from '@angular/core';\nimport { toSignal } from '@angular/core/rxjs-interop';\nimport { DbxTableStore } from './table.store';\nimport { LoadingState, loadingStateContext, mapLoadingStateValueWithOperator, valueFromFinishedLoadingState } from '@dereekb/rxjs';\nimport { shareReplay, map, Observable, switchMap, throttleTime } from 'rxjs';\nimport { DbxLoadingComponent } from '@dereekb/dbx-web';\nimport { InfiniteScrollDirective } from 'ngx-infinite-scroll';\nimport { MatTable, MatTableModule } from '@angular/material/table';\nimport { DbxTableInputCellComponent } from './table.cell.input.component';\nimport { DbxTableSummaryEndCellComponent } from './table.cell.summaryend.component';\nimport { DbxTableSummaryStartCellComponent } from './table.cell.summarystart.component';\nimport { DbxTableColumnFooterComponent } from './table.column.footer.component';\nimport { DbxTableItemCellComponent } from './table.item.cell.component';\nimport { DbxTableItemHeaderComponent } from './table.item.header.component';\nimport { DbxTableItemActionComponent } from './table.item.action.component';\nimport { DbxTableActionCellComponent } from './table.cell.action.component';\nimport { DbxTableColumnHeaderComponent } from './table.column.header.component';\nimport { DbxTableItemGroup, DefaultDbxTableItemGroup } from './table';\nimport { DbxTableGroupHeaderComponent } from './table.group.header.component';\nimport { DbxTableGroupFooterComponent } from './table.group.footer.component';\nimport { pushArrayItemsIntoArray } from '@dereekb/util';\nimport { NgClass } from '@angular/common';\nimport { DbxTableFullSummaryRowComponent } from './table.fullsummaryrow.component';\nimport { DbxTableColumnSizeDirective, DbxColumnSizeColumnDirective } from './table.column.size.directive';\nimport { DBX_TABLE_COLUMN_SIZE_PARENT_ELEMENT_REF_TOKEN } from './table.column.size';\n\nexport const DBX_TABLE_ITEMS_COLUMN_NAME = '_items';\nexport const DBX_TABLE_ACTIONS_COLUMN_NAME = '_actions';\n\nexport interface DbxTableViewGroupElement<T, G> {\n  readonly type: 'group';\n  readonly location: 'header' | 'footer';\n  readonly group: DbxTableItemGroup<T, G>;\n}\n\nexport interface DbxTableViewItemElement<T, G> {\n  readonly type: 'item';\n  readonly item: T;\n}\n\nexport type DbxTableViewElement<T, G> = DbxTableViewGroupElement<T, G> | DbxTableViewItemElement<T, G>;\n\nexport function isDbxTableViewGroupElement<T, G>(element: DbxTableViewElement<T, G>): element is DbxTableViewGroupElement<T, G> {\n  return element.type === 'group';\n}\n\nexport function isDbxTableViewItemElement<T, G>(element: DbxTableViewElement<T, G>): element is DbxTableViewItemElement<T, G> {\n  return element.type === 'item';\n}\n\n/**\n * A table with fixed content\n */\n@Component({\n  selector: 'dbx-table-view',\n  templateUrl: './table.component.html',\n  imports: [\n    DbxLoadingComponent,\n    NgClass,\n    InfiniteScrollDirective,\n    MatTableModule,\n    DbxTableInputCellComponent,\n    DbxTableItemHeaderComponent,\n    DbxTableItemCellComponent,\n    DbxTableItemActionComponent,\n    DbxTableActionCellComponent,\n    DbxTableColumnHeaderComponent,\n    DbxTableColumnFooterComponent,\n    DbxTableSummaryStartCellComponent,\n    DbxTableSummaryEndCellComponent,\n    DbxTableGroupHeaderComponent,\n    DbxTableGroupFooterComponent,\n    DbxTableFullSummaryRowComponent,\n    DbxTableColumnSizeDirective,\n    DbxColumnSizeColumnDirective\n  ],\n  providers: [\n    {\n      provide: DBX_TABLE_COLUMN_SIZE_PARENT_ELEMENT_REF_TOKEN,\n      useExisting: ElementRef\n    }\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true\n})\nexport class DbxTableViewComponent<I, C, T, G = unknown> {\n  readonly tableStore = inject(DbxTableStore<I, C, T, G>);\n  readonly table = viewChild.required<MatTable<DbxTableViewElement<T, G>>>(MatTable);\n\n  readonly DEFAULT_TRACK_BY_FUNCTION: TrackByFunction<any> = (index) => {\n    return index;\n  };\n\n  readonly scrollDistance = input<number>(0.5);\n  readonly throttleScroll = input<number>(50);\n\n  readonly itemsColumnName = DBX_TABLE_ITEMS_COLUMN_NAME;\n  readonly actionsColumnName = DBX_TABLE_ACTIONS_COLUMN_NAME;\n\n  readonly innerColumns$ = this.tableStore.columns$;\n  readonly innerColumnNames$ = this.innerColumns$.pipe(\n    map((x) => x.map((y) => y.columnName)),\n    shareReplay(1)\n  );\n\n  readonly innerColumnsSignal = toSignal(this.innerColumns$);\n  readonly innerColumnNamesSignal = toSignal(this.innerColumnNames$);\n\n  readonly elementsState$: Observable<LoadingState<DbxTableViewElement<T, G>[]>> = this.tableStore.groupsState$.pipe(\n    mapLoadingStateValueWithOperator(\n      switchMap((groups) => {\n        return this.tableStore.viewDelegate$.pipe(\n          map((viewDelegate) => {\n            const { groupHeader: inputGroupHeader, groupFooter: inputGroupFooter } = viewDelegate;\n            const hasGroupHeader = inputGroupHeader != null ? (group: DbxTableItemGroup<T, G>) => inputGroupHeader(group) != null : () => false;\n            const hasGroupFooter = inputGroupFooter != null ? (group: DbxTableItemGroup<T, G>) => inputGroupFooter(group) != null : () => false;\n\n            return groups\n              .map((group) => {\n                const { items } = group;\n\n                const itemElements: DbxTableViewItemElement<T, G>[] = items.map((item) => ({\n                  type: 'item',\n                  item\n                }));\n\n                let elements: DbxTableViewElement<T, G>[];\n\n                if ((group as DefaultDbxTableItemGroup<T, G>).default) {\n                  elements = itemElements;\n                } else {\n                  const header = hasGroupHeader(group);\n                  const footer = hasGroupFooter(group);\n\n                  elements = [];\n\n                  if (header) {\n                    elements.push({\n                      type: 'group',\n                      location: 'header',\n                      group\n                    });\n                  }\n\n                  pushArrayItemsIntoArray(elements, itemElements);\n\n                  if (footer) {\n                    elements.push({\n                      type: 'group',\n                      location: 'footer',\n                      group\n                    });\n                  }\n                }\n\n                return elements;\n              })\n              .flat();\n          })\n        );\n      })\n    ),\n    shareReplay(1)\n  );\n\n  readonly elements$ = this.elementsState$.pipe(\n    valueFromFinishedLoadingState(() => []),\n    throttleTime(50, undefined, { leading: true, trailing: true }),\n    shareReplay(1)\n  );\n\n  readonly displayedColumns$ = this.innerColumnNames$.pipe(\n    map((columnNames) => {\n      return [this.itemsColumnName, ...columnNames, this.actionsColumnName];\n    }),\n    shareReplay(1)\n  );\n\n  readonly displayedColumnsSignal = computed(() => {\n    const columnNames = this.innerColumnNamesSignal() || [];\n    return [this.itemsColumnName, ...columnNames, this.actionsColumnName];\n  });\n\n  readonly trackByFunction$: Observable<TrackByFunction<T>> = this.tableStore.viewDelegate$.pipe(\n    map((x) => x.trackBy ?? this.DEFAULT_TRACK_BY_FUNCTION),\n    shareReplay(1)\n  );\n\n  readonly inputTrackByFunctionSignal = toSignal(this.trackByFunction$, { initialValue: this.DEFAULT_TRACK_BY_FUNCTION });\n  readonly trackElementByFunctionSignal: Signal<TrackByFunction<DbxTableViewElement<T, G>>> = computed(() => {\n    const trackByFunction = this.inputTrackByFunctionSignal() as TrackByFunction<T>;\n\n    const fn: TrackByFunction<DbxTableViewElement<T, G>> = (index: number, element: DbxTableViewElement<T, G>) => {\n      if (element.type === 'item') {\n        return `i_${trackByFunction(index, element.item as T)}`;\n      } else {\n        return `g_${element.group.groupId}`;\n      }\n    };\n\n    return fn;\n  });\n\n  readonly context = loadingStateContext({ obs: this.tableStore.dataState$ });\n  readonly dataLoadingContext = loadingStateContext({ obs: this.elementsState$ });\n\n  readonly contextSignal = toSignal(this.context.state$);\n  readonly dataLoadingContextSignal = toSignal(this.dataLoadingContext.state$);\n\n  readonly viewDelegateSignal = toSignal(this.tableStore.viewDelegate$);\n  readonly elementsSignal = toSignal(this.elements$, { initialValue: [] });\n\n  readonly tableCssClasses = toSignal(this.tableStore.spaceSeparatedTableCssClasses$);\n\n  onScrollDown(): void {\n    this.tableStore.loadMore();\n  }\n\n  showItemRow(_: number, row: DbxTableViewElement<T, G>): boolean {\n    return row.type === 'item';\n  }\n\n  showGroupHeaderRow(_: number, row: DbxTableViewElement<T, G>): boolean {\n    return row.type === 'group' && row.location === 'header';\n  }\n\n  showGroupFooterRow(_: number, row: DbxTableViewElement<T, G>): boolean {\n    return row.type === 'group' && row.location === 'footer';\n  }\n\n  readonly showFooterRowSignal = computed(() => {\n    const viewDelegate = this.viewDelegateSignal();\n    const showFooterRow = viewDelegate && (viewDelegate.summaryRowHeader != null || viewDelegate.columnFooter != null || viewDelegate.summaryRowEnd != null);\n    return showFooterRow;\n  });\n\n  readonly showFullSummaryRowSignal = computed(() => {\n    const viewDelegate = this.viewDelegateSignal();\n    return viewDelegate?.fullSummaryRow != null;\n  });\n}\n","<dbx-loading [context]=\"context\">\n  <dbx-loading class=\"dbx-table-view-loading\" [linear]=\"true\" [context]=\"dataLoadingContext\"></dbx-loading>\n  <div class=\"dbx-table-view\" [ngClass]=\"tableCssClasses()\">\n    <section class=\"dbx-table-view-table-wrapper\" dbx-table-column-size #columnSize=\"dbxTableColumnSize\" infinite-scroll [infiniteScrollDistance]=\"scrollDistance()\" [infiniteScrollThrottle]=\"throttleScroll()\" [scrollWindow]=\"false\" (scrolled)=\"onScrollDown()\">\n      <table class=\"dbx-table-view-table\" mat-table [dataSource]=\"elementsSignal()\" [trackBy]=\"trackElementByFunctionSignal()\" multiTemplateDataRows>\n        <!-- Groups -->\n        <!-- Group Header column -->\n        <ng-container matColumnDef=\"groupHeaderColumn\" [sticky]=\"true\">\n          <td mat-cell [attr.colspan]=\"columnSize.visibleColumnsSignal()\" *matCellDef=\"let element\">\n            <dbx-table-group-header [group]=\"element.group\"></dbx-table-group-header>\n          </td>\n        </ng-container>\n\n        <!-- Group Footer column -->\n        <ng-container matColumnDef=\"groupFooterColumn\" [sticky]=\"true\">\n          <td mat-cell [attr.colspan]=\"columnSize.visibleColumnsSignal()\" *matCellDef=\"let element\">\n            <dbx-table-group-footer [group]=\"element.group\"></dbx-table-group-footer>\n          </td>\n        </ng-container>\n\n        <!-- Items -->\n        <!-- Header/Item column -->\n        <ng-container [matColumnDef]=\"itemsColumnName\" [sticky]=\"true\">\n          <th dbx-column-size-column=\"head\" mat-header-cell *matHeaderCellDef>\n            <dbx-table-input-cell></dbx-table-input-cell>\n          </th>\n          <td mat-cell *matCellDef=\"let element\">\n            <dbx-table-item-header [item]=\"element.item\"></dbx-table-item-header>\n          </td>\n          <td mat-footer-cell *matFooterCellDef>\n            <dbx-table-summary-start-cell></dbx-table-summary-start-cell>\n          </td>\n        </ng-container>\n\n        <!-- Column Definitions -->\n        @for (column of innerColumnsSignal(); track column.columnName) {\n          <ng-container [matColumnDef]=\"column.columnName\" [sticky]=\"false\">\n            <th [dbx-column-size-column]=\"$index\" mat-header-cell *matHeaderCellDef>\n              <dbx-table-column-header [column]=\"column\"></dbx-table-column-header>\n            </th>\n            <td mat-cell *matCellDef=\"let element\">\n              <dbx-table-item-cell [item]=\"element.item\" [column]=\"column\"></dbx-table-item-cell>\n            </td>\n            <td mat-footer-cell *matFooterCellDef>\n              <dbx-table-column-footer [column]=\"column\"></dbx-table-column-footer>\n            </td>\n          </ng-container>\n        }\n\n        <!-- Tail/Action column -->\n        <ng-container [matColumnDef]=\"actionsColumnName\" [stickyEnd]=\"true\">\n          <th dbx-column-size-column=\"tail\" mat-header-cell *matHeaderCellDef>\n            <dbx-table-action-cell></dbx-table-action-cell>\n          </th>\n          <td mat-cell *matCellDef=\"let element\">\n            <dbx-table-item-action [item]=\"element.item\"></dbx-table-item-action>\n          </td>\n          <td mat-footer-cell *matFooterCellDef>\n            <dbx-table-summary-end-cell></dbx-table-summary-end-cell>\n          </td>\n        </ng-container>\n\n        <!-- Table View -->\n        <tr mat-header-row *matHeaderRowDef=\"displayedColumnsSignal(); sticky: true\"></tr>\n\n        <tr mat-row *matRowDef=\"let row; columns: ['groupHeaderColumn']; when: showGroupHeaderRow\"></tr>\n        <tr mat-row *matRowDef=\"let row; columns: displayedColumnsSignal(); when: showItemRow\"></tr>\n        <tr mat-row *matRowDef=\"let row; columns: ['groupFooterColumn']; when: showGroupFooterRow\"></tr>\n\n        <tr [ngClass]=\"{ 'dbx-hide': !showFooterRowSignal() }\" mat-footer-row *matFooterRowDef=\"displayedColumnsSignal(); sticky: true\"></tr>\n      </table>\n    </section>\n    <!-- Full summary row -->\n    @if (showFullSummaryRowSignal()) {\n      <div class=\"mat-mdc-table dbx-table-view-full-summary-row-container\">\n        <div class=\"mdc-data-table__cell mat-mdc-row\">\n          <dbx-table-full-summary-row></dbx-table-full-summary-row>\n        </div>\n      </div>\n    }\n  </div>\n</dbx-loading>\n"]}
|
|
@@ -7,4 +7,4 @@ export function defaultDbxTableItemGroup(items) {
|
|
|
7
7
|
default: true
|
|
8
8
|
};
|
|
9
9
|
}
|
|
10
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3RhYmxlL3NyYy9saWIvdGFibGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBZ0RBLE1BQU0sQ0FBQyxNQUFNLFlBQVksR0FBRyxNQUFNLENBQUM7QUFrQm5DLE1BQU0sVUFBVSx3QkFBd0IsQ0FBaUIsS0FBVTtJQUNqRSxPQUFPO1FBQ0wsT0FBTyxFQUFFLFlBQVk7UUFDckIsS0FBSztRQUNMLElBQUksRUFBRSxTQUFjO1FBQ3BCLE9BQU8sRUFBRSxJQUFJO0tBQ2QsQ0FBQztBQUNKLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBPYnNlcnZhYmxlIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBMb2FkaW5nU3RhdGUsIE9ic2VydmFibGVPclZhbHVlLCBQYWdlTGlzdExvYWRpbmdTdGF0ZSB9IGZyb20gJ0BkZXJlZWtiL3J4anMnO1xuaW1wb3J0IHsgQ3NzQ2xhc3Nlc0FycmF5LCB0eXBlIE1heWJlIH0gZnJvbSAnQGRlcmVla2IvdXRpbCc7XG5pbXBvcnQgeyBEYnhJbmplY3Rpb25Db21wb25lbnRDb25maWcgfSBmcm9tICdAZGVyZWVrYi9kYngtY29yZSc7XG5pbXBvcnQgeyBUcmFja0J5RnVuY3Rpb24gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuLyoqXG4gKiBEZWxlZ2F0ZSB1c2VkIGZvciByZXRyaWV2aW5nIGRhdGEgZm9yIGEgdGFibGUuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRGJ4VGFibGVDb250ZXh0RGF0YURlbGVnYXRlPEksIEMsIFQ+IHtcbiAgLyoqXG4gICAqIExvYWRzIGRhdGEgZ2l2ZW4gdGhlIGlucHV0LlxuICAgKlxuICAgKiBAcGFyYW0gaW5wdXRcbiAgICovXG4gIGxvYWREYXRhKGlucHV0OiBJKTogT2JzZXJ2YWJsZTxMb2FkaW5nU3RhdGU8RGJ4VGFibGVDb250ZXh0RGF0YTxJLCBDLCBUPj4+O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIERieFRhYmxlQ29udGV4dERhdGE8SSwgQywgVD4ge1xuICAvKipcbiAgICogT3JpZ2luYWwgY29udGV4dCBpbnB1dFxuICAgKi9cbiAgcmVhZG9ubHkgaW5wdXQ6IEk7XG4gIC8qKlxuICAgKiBBbGwgY29sdW1ucyBpbiB0aGlzIGRhdGEgY29udGV4dC5cbiAgICovXG4gIHJlYWRvbmx5IGNvbHVtbnM6IERieFRhYmxlQ29sdW1uPEM+W107XG4gIC8qKlxuICAgKiBBbGwgY3VycmVudGx5IGxvYWRlZCBpdGVtcy5cbiAgICovXG4gIHJlYWRvbmx5IGl0ZW1zJDogT2JzZXJ2YWJsZTxQYWdlTGlzdExvYWRpbmdTdGF0ZTxUPj47XG4gIC8qKlxuICAgKiBMb2FkcyBtb3JlIGl0ZW1zLCBpZiBhcHBsaWNhYmxlLlxuICAgKi9cbiAgbG9hZE1vcmU/KCk6IHZvaWQ7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRGJ4VGFibGVDb2x1bW48Qz4ge1xuICAvKipcbiAgICogVW5pcXVlIGNvbHVtbiBuYW1lXG4gICAqL1xuICByZWFkb25seSBjb2x1bW5OYW1lOiBzdHJpbmc7XG4gIC8qKlxuICAgKiBDb2x1bW4gbWV0YWRhdGFcbiAgICovXG4gIHJlYWRvbmx5IG1ldGE6IEM7XG59XG5cbmV4cG9ydCBjb25zdCBOT19HUk9VUFNfSUQgPSAnbm9uZSc7XG5cbi8qKlxuICogVW5pcXVlIGlkZW50aWZpZXIgdXNlZCBmb3IgZ3JvdXBpbmcgaXRlbXMgdG9nZXRoZXIuXG4gKi9cbmV4cG9ydCB0eXBlIERieFRhYmxlR3JvdXBJZCA9IHN0cmluZztcblxuZXhwb3J0IGludGVyZmFjZSBEYnhUYWJsZUl0ZW1Hcm91cDxULCBHID0gdW5rbm93bj4ge1xuICByZWFkb25seSBncm91cElkOiBEYnhUYWJsZUdyb3VwSWQ7XG4gIHJlYWRvbmx5IGl0ZW1zOiBUW107XG4gIHJlYWRvbmx5IG1ldGE6IEc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRGVmYXVsdERieFRhYmxlSXRlbUdyb3VwPFQsIEcgPSB1bmtub3duPiBleHRlbmRzIERieFRhYmxlSXRlbUdyb3VwPFQsIEc+IHtcbiAgcmVhZG9ubHkgZ3JvdXBJZDogdHlwZW9mIE5PX0dST1VQU19JRDtcbiAgcmVhZG9ubHkgZGVmYXVsdDogdHJ1ZTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGRlZmF1bHREYnhUYWJsZUl0ZW1Hcm91cDxULCBHID0gdW5rbm93bj4oaXRlbXM6IFRbXSk6IERlZmF1bHREYnhUYWJsZUl0ZW1Hcm91cDxULCBHPiB7XG4gIHJldHVybiB7XG4gICAgZ3JvdXBJZDogTk9fR1JPVVBTX0lELFxuICAgIGl0ZW1zLFxuICAgIG1ldGE6IHVuZGVmaW5lZCBhcyBHLFxuICAgIGRlZmF1bHQ6IHRydWVcbiAgfTtcbn1cblxuZXhwb3J0IHR5cGUgRGJ4VGFibGVHcm91cEJ5RnVuY3Rpb248VCwgRyA9IHVua25vd24+ID0gKGl0ZW1zOiBUW10pID0+IE9ic2VydmFibGVPclZhbHVlPERieFRhYmxlSXRlbUdyb3VwPFQsIEc+W10+O1xuXG4vKipcbiAqIERlbGVnYXRlIHVzZWQgZm9yIGdlbmVyYXRpbmcgdmlldyBjb25maWd1cmF0aW9ucyBnaXZlbiB0aGUgaW5wdXQuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRGJ4VGFibGVWaWV3RGVsZWdhdGU8SSA9IHVua25vd24sIEMgPSB1bmtub3duLCBUID0gdW5rbm93biwgRyA9IHVua25vd24+IHtcbiAgLyoqXG4gICAqIFRyYWNrIGJ5XG4gICAqL1xuICByZWFkb25seSB0cmFja0J5PzogVHJhY2tCeUZ1bmN0aW9uPFQ+O1xuICAvKipcbiAgICogSWYgcHJvdmlkZWQsIHdpbGwgZ3JvdXAgaXRlbXMgdG9nZXRoZXJcbiAgICovXG4gIHJlYWRvbmx5IGdyb3VwQnk/OiBEYnhUYWJsZUdyb3VwQnlGdW5jdGlvbjxULCBHPjtcbiAgLyoqXG4gICAqIElucHV0IHBpY2tlciB2aWV3IGNvbmZpZ3VyYXRpb25cbiAgICovXG4gIHJlYWRvbmx5IGlucHV0SGVhZGVyPzogTWF5YmU8RGJ4SW5qZWN0aW9uQ29tcG9uZW50Q29uZmlnPGFueT4+O1xuICAvKipcbiAgICogQWN0aW9uIGhlYWRlciB2aWV3IGNvbmZpZ3VyYXRpb25cbiAgICovXG4gIHJlYWRvbmx5IGFjdGlvbkhlYWRlcj86IE1heWJlPERieEluamVjdGlvbkNvbXBvbmVudENvbmZpZzxhbnk+PjtcbiAgLyoqXG4gICAqIEZ1bGwtd2lkdGggc3VtbWFyeSByb3cgdmlldyBjb25maWd1cmF0aW9uLlxuICAgKi9cbiAgcmVhZG9ubHkgZnVsbFN1bW1hcnlSb3c/OiBNYXliZTxEYnhJbmplY3Rpb25Db21wb25lbnRDb25maWc8YW55Pj47XG4gIC8qKlxuICAgKiBTdW1tYXJ5IHJvdyBoZWFkZXIgdmlldyBjb25maWd1cmF0aW9uLlxuICAgKi9cbiAgcmVhZG9ubHkgc3VtbWFyeVJvd0hlYWRlcj86IE1heWJlPERieEluamVjdGlvbkNvbXBvbmVudENvbmZpZzxhbnk+PjtcbiAgLyoqXG4gICAqIFN1bW1hcnkgcm93IGVuZCB2aWV3IGNvbmZpZ3VyYXRpb25cbiAgICovXG4gIHJlYWRvbmx5IHN1bW1hcnlSb3dFbmQ/OiBNYXliZTxEYnhJbmplY3Rpb25Db21wb25lbnRDb25maWc8YW55Pj47XG4gIC8qKlxuICAgKiBHcm91cCByb3cgaGVhZGVyIHZpZXcgY29uZmlndXJhdGlvbiBmb3IgYSBzcGVjaWZpYyBncm91cC5cbiAgICpcbiAgICogSWYgdGhpcyBmdW5jdGlvbiByZXR1cm5zIHVuZGVmaW5lZCwgdGhlIGdyb3VwIHJvdyB3aWxsIG5vdCBiZSBzaG93bi5cbiAgICpcbiAgICogQHBhcmFtIGdyb3VwXG4gICAqL1xuICBncm91cEhlYWRlcj8oZ3JvdXA6IERieFRhYmxlSXRlbUdyb3VwPFQsIEc+KTogTWF5YmU8RGJ4SW5qZWN0aW9uQ29tcG9uZW50Q29uZmlnPGFueT4+O1xuICAvKipcbiAgICogR3JvdXAgcm93IGZvb3RlciB2aWV3IGNvbmZpZ3VyYXRpb24gZm9yIGEgc3BlY2lmaWMgZ3JvdXAuXG4gICAqXG4gICAqIElmIHRoaXMgZnVuY3Rpb24gcmV0dXJucyB1bmRlZmluZWQsIHRoZSBncm91cCByb3cgd2lsbCBub3QgYmUgc2hvd24uXG4gICAqXG4gICAqIEBwYXJhbSBncm91cFxuICAgKi9cbiAgZ3JvdXBGb290ZXI/KGdyb3VwOiBEYnhUYWJsZUl0ZW1Hcm91cDxULCBHPik6IE1heWJlPERieEluamVjdGlvbkNvbXBvbmVudENvbmZpZzxhbnk+PjtcbiAgLyoqXG4gICAqIENvbHVtbiBoZWFkZXIgdmlldyBjb25maWd1cmF0aW9uIGZvciBhIHNwZWNpZmljIGNvbHVtbi5cbiAgICpcbiAgICogQHBhcmFtIGl0ZW1cbiAgICovXG4gIGNvbHVtbkhlYWRlcj8oY29sdW1uOiBEYnhUYWJsZUNvbHVtbjxDPik6IE1heWJlPERieEluamVjdGlvbkNvbXBvbmVudENvbmZpZzxhbnk+PjtcbiAgLyoqXG4gICAqIE9wdGlvbmFsIGNvbHVtbiBmb290ZXIgdmlldyBjb25maWd1cmF0aW9uIGZvciBhIHNwZWNpZmljIGNvbHVtbi5cbiAgICpcbiAgICogQHBhcmFtIGl0ZW1cbiAgICovXG4gIGNvbHVtbkZvb3Rlcj8oY29sdW1uOiBEYnhUYWJsZUNvbHVtbjxDPik6IE1heWJlPERieEluamVjdGlvbkNvbXBvbmVudENvbmZpZzxhbnk+PjtcbiAgLyoqXG4gICAqIEl0ZW0gaGVhZGVyIHZpZXcgKGxlZnQtbW9zdCBjb2x1bW4gZm9yIGFuIGl0ZW0gcm93KSBjb25maWd1cmF0aW9uIGZvciBhIHNwZWNpZmljIGl0ZW0uXG4gICAqXG4gICAqIEBwYXJhbSBpdGVtXG4gICAqL1xuICBpdGVtSGVhZGVyKGl0ZW06IFQpOiBNYXliZTxEYnhJbmplY3Rpb25Db21wb25lbnRDb25maWc8YW55Pj47XG4gIC8qKlxuICAgKiBJdGVtIGNlbGwgdmlldyAobWlkZGxlIGNvbHVtbnMgZm9yIGFuIGl0ZW0gcm93KSBjb25maWd1cmF0aW9uIGZvciBhIHNwZWNpZmljIGl0ZW0gYW5kIGNvbHVtbi5cbiAgICpcbiAgICogQHBhcmFtIGl0ZW1cbiAgICovXG4gIGl0ZW1DZWxsKGNvbHVtbjogRGJ4VGFibGVDb2x1bW48Qz4sIGl0ZW06IFQpOiBNYXliZTxEYnhJbmplY3Rpb25Db21wb25lbnRDb25maWc8YW55Pj47XG4gIC8qKlxuICAgKiBJdGVtIGFjdGlvbiB2aWV3IChyaWdodC1tb3N0IGNvbHVtbiBmb3IgYW4gaXRlbSByb3cpIGNvbmZpZ3VyYXRpb24gZm9yIGEgc3BlY2lmaWMgaXRlbS5cbiAgICpcbiAgICogQHBhcmFtIGl0ZW1cbiAgICovXG4gIGl0ZW1BY3Rpb24/KGl0ZW06IFQpOiBNYXliZTxEYnhJbmplY3Rpb25Db21wb25lbnRDb25maWc8YW55Pj47XG4gIC8qKlxuICAgKiBPcHRpb25hbCBjbGFzc2VzIHRvIGFwcGx5IHRvIHRoZSB0YWJsZS5cbiAgICovXG4gIHRhYmxlQ2xhc3Nlcz86IENzc0NsYXNzZXNBcnJheTtcbn1cbiJdfQ==
|