@dereekb/dbx-web 10.0.23 → 10.1.0
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/calendar/package.json +1 -1
- package/esm2022/lib/extension/download/index.mjs +2 -0
- package/esm2022/lib/extension/download/text/download.text.component.mjs +126 -0
- package/esm2022/lib/extension/download/text/download.text.mjs +2 -0
- package/esm2022/lib/extension/download/text/download.text.module.mjs +42 -0
- package/esm2022/lib/extension/download/text/index.mjs +4 -0
- package/esm2022/lib/extension/index.mjs +3 -2
- package/esm2022/lib/layout/content/content.pit.directive.mjs +8 -5
- package/esm2022/lib/layout/list/index.mjs +4 -1
- package/esm2022/lib/layout/list/list.grid.view.component.mjs +13 -11
- package/esm2022/lib/layout/list/list.layout.module.mjs +41 -45
- package/esm2022/lib/layout/list/list.view.value.component.mjs +126 -22
- package/esm2022/lib/layout/list/list.view.value.group.mjs +32 -0
- package/esm2022/lib/layout/list/list.view.value.group.title.directive.mjs +132 -0
- package/esm2022/lib/layout/list/list.view.value.group.title.mjs +2 -0
- package/esm2022/lib/layout/list/list.view.value.selection.component.mjs +20 -13
- package/esm2022/lib/loading/loading-progress.component.mjs +4 -4
- package/fesm2022/dereekb-dbx-web.mjs +522 -115
- package/fesm2022/dereekb-dbx-web.mjs.map +1 -1
- package/lib/extension/download/index.d.ts +1 -0
- package/lib/extension/download/text/download.text.component.d.ts +40 -0
- package/lib/extension/download/text/download.text.component.scss +0 -0
- package/lib/extension/download/text/download.text.d.ts +5 -0
- package/lib/extension/download/text/download.text.module.d.ts +12 -0
- package/lib/extension/download/text/index.d.ts +3 -0
- package/lib/extension/index.d.ts +1 -0
- package/lib/layout/content/_content.scss +6 -0
- package/lib/layout/content/content.pit.directive.d.ts +3 -1
- package/lib/layout/list/_list.scss +40 -0
- package/lib/layout/list/index.d.ts +3 -0
- package/lib/layout/list/list.grid.view.component.d.ts +4 -4
- package/lib/layout/list/list.layout.module.d.ts +15 -14
- package/lib/layout/list/list.view.value.component.d.ts +39 -8
- package/lib/layout/list/list.view.value.group.d.ts +44 -0
- package/lib/layout/list/list.view.value.group.title.d.ts +49 -0
- package/lib/layout/list/list.view.value.group.title.directive.d.ts +31 -0
- package/lib/layout/list/list.view.value.selection.component.d.ts +6 -5
- package/lib/layout/style/_style.scss +4 -0
- package/lib/loading/_loading.scss +4 -0
- package/mapbox/package.json +1 -1
- package/package.json +1 -1
- package/table/package.json +1 -1
|
@@ -1,14 +1,17 @@
|
|
|
1
|
-
import { Component, Input } from '@angular/core';
|
|
2
|
-
import { shareReplay, map } from 'rxjs';
|
|
1
|
+
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Inject, Input, Optional } from '@angular/core';
|
|
2
|
+
import { shareReplay, map, BehaviorSubject, switchMap } from 'rxjs';
|
|
3
3
|
import { AbstractDbxValueListViewDirective } from './list.view.value.directive';
|
|
4
4
|
import { AnchorType, anchorTypeForAnchor } from '@dereekb/dbx-core';
|
|
5
5
|
import { DbxListView } from './list.view';
|
|
6
|
+
import { spaceSeparatedCssClasses } from '@dereekb/util';
|
|
7
|
+
import { DbxValueListViewGroupDelegate, defaultDbxValueListViewGroupDelegate } from './list.view.value.group';
|
|
8
|
+
import { asObservable } from '@dereekb/rxjs';
|
|
6
9
|
import * as i0 from "@angular/core";
|
|
7
10
|
import * as i1 from "@angular/common";
|
|
8
11
|
import * as i2 from "./list.view";
|
|
9
|
-
import * as i3 from "
|
|
10
|
-
import * as i4 from "
|
|
11
|
-
import * as i5 from "@
|
|
12
|
+
import * as i3 from "@angular/material/list";
|
|
13
|
+
import * as i4 from "../../router/layout/anchor/anchor.component";
|
|
14
|
+
import * as i5 from "@dereekb/dbx-core";
|
|
12
15
|
import * as i6 from "@angular/material/icon";
|
|
13
16
|
/**
|
|
14
17
|
* Renders a list view using input configuration. Requires a parent DbxListView.
|
|
@@ -21,7 +24,7 @@ export class DbxValueListViewComponent extends AbstractDbxValueListViewDirective
|
|
|
21
24
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DbxValueListViewComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
22
25
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DbxValueListViewComponent, selector: "dbx-list-view", usesInheritance: true, ngImport: i0, template: `
|
|
23
26
|
<dbx-list-view-content [items]="items$ | async" [emitAllClicks]="emitAllClicks$ | async"></dbx-list-view-content>
|
|
24
|
-
`, isInline: true, dependencies: [{ kind: "component", type: i0.forwardRef(function () { return
|
|
27
|
+
`, isInline: true, dependencies: [{ kind: "component", type: i0.forwardRef(function () { return DbxValueListViewContentComponent; }), selector: "dbx-list-view-content", inputs: ["emitAllClicks", "items"] }, { kind: "pipe", type: i0.forwardRef(function () { return i1.AsyncPipe; }), name: "async" }] }); }
|
|
25
28
|
}
|
|
26
29
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DbxValueListViewComponent, decorators: [{
|
|
27
30
|
type: Component,
|
|
@@ -35,13 +38,28 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
35
38
|
/**
|
|
36
39
|
* Content view for a DbxValueListView. It can be used directly in cases where the items are already configured, or want to be configured in a non-standard fashion.
|
|
37
40
|
*/
|
|
38
|
-
export class
|
|
39
|
-
constructor(dbxListView) {
|
|
41
|
+
export class DbxValueListViewContentComponent {
|
|
42
|
+
constructor(dbxListView, inputDbxListGroupDelegate) {
|
|
40
43
|
this.dbxListView = dbxListView;
|
|
44
|
+
this._items = new BehaviorSubject(undefined);
|
|
45
|
+
this.groups$ = this._items.pipe(switchMap((items) => asObservable(this._dbxListGroupDelegate.groupValues(items ?? []))), shareReplay(1));
|
|
41
46
|
this.disabled$ = this.dbxListView.disabled$;
|
|
47
|
+
this.trackGroupByFunction = (_, v) => {
|
|
48
|
+
return v.id; // track by the id
|
|
49
|
+
};
|
|
50
|
+
this._dbxListGroupDelegate = inputDbxListGroupDelegate ?? defaultDbxValueListViewGroupDelegate();
|
|
42
51
|
const trackBy = dbxListView.trackBy;
|
|
43
52
|
this.trackByFunction = trackBy ? (index, item) => trackBy(index, item.itemValue) : () => undefined;
|
|
44
53
|
}
|
|
54
|
+
ngOnDestroy() {
|
|
55
|
+
this._items.complete();
|
|
56
|
+
}
|
|
57
|
+
get items() {
|
|
58
|
+
return this._items.value;
|
|
59
|
+
}
|
|
60
|
+
set items(items) {
|
|
61
|
+
this._items.next(items);
|
|
62
|
+
}
|
|
45
63
|
onClickItem(item) {
|
|
46
64
|
// do not emit clicks for disabled items.
|
|
47
65
|
if (!item.disabled) {
|
|
@@ -57,39 +75,125 @@ export class DbxValueListItemViewComponent {
|
|
|
57
75
|
rippleDisabledOnItem(item) {
|
|
58
76
|
return item.rippleDisabled || (!this.emitAllClicks && !item.anchor);
|
|
59
77
|
}
|
|
60
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type:
|
|
61
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type:
|
|
78
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DbxValueListViewContentComponent, deps: [{ token: i2.DbxListView }, { token: DbxValueListViewGroupDelegate, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
79
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DbxValueListViewContentComponent, selector: "dbx-list-view-content", inputs: { emitAllClicks: "emitAllClicks", items: "items" }, host: { classAttribute: "dbx-list-view" }, ngImport: i0, template: `
|
|
62
80
|
<mat-nav-list [disabled]="disabled$ | async">
|
|
81
|
+
<ng-container *ngFor="let group of groups$ | async; trackBy: trackGroupByFunction">
|
|
82
|
+
<dbx-list-view-content-group [group]="group"></dbx-list-view-content-group>
|
|
83
|
+
</ng-container>
|
|
84
|
+
</mat-nav-list>
|
|
85
|
+
`, isInline: true, dependencies: [{ kind: "directive", type: i0.forwardRef(function () { return i1.NgForOf; }), selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: i0.forwardRef(function () { return i3.MatNavList; }), selector: "mat-nav-list", exportAs: ["matNavList"] }, { kind: "component", type: i0.forwardRef(function () { return DbxValueListViewContentGroupComponent; }), selector: "dbx-list-view-content-group", inputs: ["group"] }, { kind: "pipe", type: i0.forwardRef(function () { return i1.AsyncPipe; }), name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
86
|
+
}
|
|
87
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DbxValueListViewContentComponent, decorators: [{
|
|
88
|
+
type: Component,
|
|
89
|
+
args: [{
|
|
90
|
+
selector: 'dbx-list-view-content',
|
|
91
|
+
template: `
|
|
92
|
+
<mat-nav-list [disabled]="disabled$ | async">
|
|
93
|
+
<ng-container *ngFor="let group of groups$ | async; trackBy: trackGroupByFunction">
|
|
94
|
+
<dbx-list-view-content-group [group]="group"></dbx-list-view-content-group>
|
|
95
|
+
</ng-container>
|
|
96
|
+
</mat-nav-list>
|
|
97
|
+
`,
|
|
98
|
+
host: {
|
|
99
|
+
class: 'dbx-list-view'
|
|
100
|
+
},
|
|
101
|
+
changeDetection: ChangeDetectionStrategy.OnPush
|
|
102
|
+
}]
|
|
103
|
+
}], ctorParameters: function () { return [{ type: i2.DbxListView }, { type: undefined, decorators: [{
|
|
104
|
+
type: Optional
|
|
105
|
+
}, {
|
|
106
|
+
type: Inject,
|
|
107
|
+
args: [DbxValueListViewGroupDelegate]
|
|
108
|
+
}] }]; }, propDecorators: { emitAllClicks: [{
|
|
109
|
+
type: Input
|
|
110
|
+
}], items: [{
|
|
111
|
+
type: Input
|
|
112
|
+
}] } });
|
|
113
|
+
/**
|
|
114
|
+
* Content view for a DbxValueListView. It can be used directly in cases where the items are already configured, or want to be configured in a non-standard fashion.
|
|
115
|
+
*/
|
|
116
|
+
export class DbxValueListViewContentGroupComponent {
|
|
117
|
+
get cssClasses() {
|
|
118
|
+
return this._cssClasses;
|
|
119
|
+
}
|
|
120
|
+
get items() {
|
|
121
|
+
return this._group?.items;
|
|
122
|
+
}
|
|
123
|
+
get headerConfig() {
|
|
124
|
+
return this._group?.headerConfig;
|
|
125
|
+
}
|
|
126
|
+
get footerConfig() {
|
|
127
|
+
return this._group?.footerConfig;
|
|
128
|
+
}
|
|
129
|
+
constructor(dbxValueListViewContentComponent, cdRef) {
|
|
130
|
+
this.dbxValueListViewContentComponent = dbxValueListViewContentComponent;
|
|
131
|
+
this.cdRef = cdRef;
|
|
132
|
+
this.disabled$ = this.dbxValueListViewContentComponent.disabled$;
|
|
133
|
+
this.trackByFunction = this.dbxValueListViewContentComponent.trackByFunction;
|
|
134
|
+
}
|
|
135
|
+
get group() {
|
|
136
|
+
return this._group;
|
|
137
|
+
}
|
|
138
|
+
set group(group) {
|
|
139
|
+
this._group = group;
|
|
140
|
+
this._cssClasses = spaceSeparatedCssClasses(group?.cssClasses);
|
|
141
|
+
this.cdRef.markForCheck();
|
|
142
|
+
}
|
|
143
|
+
onClickItem(item) {
|
|
144
|
+
this.dbxValueListViewContentComponent.onClickItem(item);
|
|
145
|
+
}
|
|
146
|
+
onClickValue(value) {
|
|
147
|
+
this.dbxValueListViewContentComponent.onClickValue(value);
|
|
148
|
+
}
|
|
149
|
+
rippleDisabledOnItem(item) {
|
|
150
|
+
return this.dbxValueListViewContentComponent.rippleDisabledOnItem(item);
|
|
151
|
+
}
|
|
152
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DbxValueListViewContentGroupComponent, deps: [{ token: DbxValueListViewContentComponent }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
153
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DbxValueListViewContentGroupComponent, selector: "dbx-list-view-content-group", inputs: { group: "group" }, host: { properties: { "class": "cssClasses" }, classAttribute: "dbx-list-view-group" }, ngImport: i0, template: `
|
|
154
|
+
<div class="dbx-list-view-group-content">
|
|
155
|
+
<div class="dbx-list-view-group-header" *ngIf="headerConfig">
|
|
156
|
+
<dbx-injection [config]="headerConfig"></dbx-injection>
|
|
157
|
+
</div>
|
|
63
158
|
<dbx-anchor *ngFor="let item of items; trackBy: trackByFunction" [anchor]="item.anchor" [disabled]="item.disabled">
|
|
64
159
|
<a mat-list-item class="dbx-list-view-item" [disabled]="item.disabled" [disableRipple]="rippleDisabledOnItem(item)" (click)="onClickItem(item)">
|
|
65
160
|
<mat-icon matListItemIcon *ngIf="item.icon">{{ item.icon }}</mat-icon>
|
|
66
161
|
<dbx-injection [config]="item.config"></dbx-injection>
|
|
67
162
|
</a>
|
|
68
163
|
</dbx-anchor>
|
|
69
|
-
|
|
70
|
-
|
|
164
|
+
<div class="dbx-list-view-group-footer" *ngIf="footerConfig">
|
|
165
|
+
<dbx-injection [config]="footerConfig"></dbx-injection>
|
|
166
|
+
</div>
|
|
167
|
+
</div>
|
|
168
|
+
`, isInline: true, dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.DbxAnchorComponent, selector: "dbx-anchor, [dbx-anchor]", inputs: ["block"] }, { kind: "component", type: i5.DbxInjectionComponent, selector: "dbx-injection, [dbxInjection], [dbx-injection]", inputs: ["config", "template"] }, { kind: "component", type: i3.MatListItem, selector: "mat-list-item, a[mat-list-item], button[mat-list-item]", inputs: ["activated"], exportAs: ["matListItem"] }, { kind: "directive", type: i3.MatListItemIcon, selector: "[matListItemIcon]" }, { kind: "component", type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
71
169
|
}
|
|
72
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type:
|
|
170
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DbxValueListViewContentGroupComponent, decorators: [{
|
|
73
171
|
type: Component,
|
|
74
172
|
args: [{
|
|
75
|
-
selector: 'dbx-list-view-content',
|
|
173
|
+
selector: 'dbx-list-view-content-group',
|
|
76
174
|
template: `
|
|
77
|
-
<
|
|
175
|
+
<div class="dbx-list-view-group-content">
|
|
176
|
+
<div class="dbx-list-view-group-header" *ngIf="headerConfig">
|
|
177
|
+
<dbx-injection [config]="headerConfig"></dbx-injection>
|
|
178
|
+
</div>
|
|
78
179
|
<dbx-anchor *ngFor="let item of items; trackBy: trackByFunction" [anchor]="item.anchor" [disabled]="item.disabled">
|
|
79
180
|
<a mat-list-item class="dbx-list-view-item" [disabled]="item.disabled" [disableRipple]="rippleDisabledOnItem(item)" (click)="onClickItem(item)">
|
|
80
181
|
<mat-icon matListItemIcon *ngIf="item.icon">{{ item.icon }}</mat-icon>
|
|
81
182
|
<dbx-injection [config]="item.config"></dbx-injection>
|
|
82
183
|
</a>
|
|
83
184
|
</dbx-anchor>
|
|
84
|
-
|
|
185
|
+
<div class="dbx-list-view-group-footer" *ngIf="footerConfig">
|
|
186
|
+
<dbx-injection [config]="footerConfig"></dbx-injection>
|
|
187
|
+
</div>
|
|
188
|
+
</div>
|
|
85
189
|
`,
|
|
86
190
|
host: {
|
|
87
|
-
class: 'dbx-list-view'
|
|
88
|
-
|
|
191
|
+
class: 'dbx-list-view-group',
|
|
192
|
+
'[class]': 'cssClasses'
|
|
193
|
+
},
|
|
194
|
+
changeDetection: ChangeDetectionStrategy.OnPush
|
|
89
195
|
}]
|
|
90
|
-
}], ctorParameters: function () { return [{ type:
|
|
91
|
-
type: Input
|
|
92
|
-
}], items: [{
|
|
196
|
+
}], ctorParameters: function () { return [{ type: DbxValueListViewContentComponent }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { group: [{
|
|
93
197
|
type: Input
|
|
94
198
|
}] } });
|
|
95
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlzdC52aWV3LnZhbHVlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC13ZWIvc3JjL2xpYi9sYXlvdXQvbGlzdC9saXN0LnZpZXcudmFsdWUuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFtQixNQUFNLGVBQWUsQ0FBQztBQUNsRSxPQUFPLEVBQUUsV0FBVyxFQUFFLEdBQUcsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUV4QyxPQUFPLEVBQUUsaUNBQWlDLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQUNoRixPQUFPLEVBQUUsVUFBVSxFQUFFLG1CQUFtQixFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDcEUsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGFBQWEsQ0FBQzs7Ozs7Ozs7QUFPMUM7O0dBRUc7QUFPSCxNQUFNLE9BQU8seUJBQTRLLFNBQVEsaUNBQTZDO0lBTjlPOztRQU9XLG1CQUFjLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQ3pDLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLGFBQWEsQ0FBQyxFQUMzQixXQUFXLENBQUMsQ0FBQyxDQUFDLENBQ2YsQ0FBQztLQUNIOytHQUxZLHlCQUF5QjttR0FBekIseUJBQXlCLDRFQUoxQjs7R0FFVCwrRkE0QlUsNkJBQTZCOzs0RkExQjdCLHlCQUF5QjtrQkFOckMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsZUFBZTtvQkFDekIsUUFBUSxFQUFFOztHQUVUO2lCQUNGOztBQVFEOztHQUVHO0FBaUJILE1BQU0sT0FBTyw2QkFBNkI7SUFXeEMsWUFBcUIsV0FBMkI7UUFBM0IsZ0JBQVcsR0FBWCxXQUFXLENBQWdCO1FBSnZDLGNBQVMsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLFNBQVMsQ0FBQztRQUs5QyxNQUFNLE9BQU8sR0FBRyxXQUFXLENBQUMsT0FBTyxDQUFDO1FBQ3BDLElBQUksQ0FBQyxlQUFlLEdBQUcsT0FBTyxDQUFDLENBQUMsQ0FBQyxDQUFDLEtBQWEsRUFBRSxJQUFrQyxFQUFFLEVBQUUsQ0FBQyxPQUFPLENBQUMsS0FBSyxFQUFFLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLENBQUMsR0FBRyxFQUFFLENBQUMsU0FBUyxDQUFDO0lBQzNJLENBQUM7SUFFRCxXQUFXLENBQUMsSUFBTztRQUNqQix5Q0FBeUM7UUFDekMsSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLEVBQUU7WUFDbEIsSUFBSSxJQUFJLENBQUMsYUFBYSxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sSUFBSSxtQkFBbUIsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLEtBQUssVUFBVSxDQUFDLEtBQUssRUFBRTtnQkFDL0YsK0RBQStEO2dCQUMvRCxJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQzthQUNuQztTQUNGO0lBQ0gsQ0FBQztJQUVELFlBQVksQ0FBQyxLQUFRO1FBQ25CLElBQUksQ0FBQyxXQUFXLENBQUMsVUFBVSxFQUFFLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUMzQyxDQUFDO0lBRUQsb0JBQW9CLENBQUMsSUFBTztRQUMxQixPQUFPLElBQUksQ0FBQyxjQUFjLElBQUksQ0FBQyxDQUFDLElBQUksQ0FBQyxhQUFhLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDdEUsQ0FBQzsrR0FoQ1UsNkJBQTZCO21HQUE3Qiw2QkFBNkIsb0tBZDlCOzs7Ozs7Ozs7R0FTVDs7NEZBS1UsNkJBQTZCO2tCQWhCekMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsdUJBQXVCO29CQUNqQyxRQUFRLEVBQUU7Ozs7Ozs7OztHQVNUO29CQUNELElBQUksRUFBRTt3QkFDSixLQUFLLEVBQUUsZUFBZTtxQkFDdkI7aUJBQ0Y7a0dBR0MsYUFBYTtzQkFEWixLQUFLO2dCQUlOLEtBQUs7c0JBREosS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQsIFRyYWNrQnlGdW5jdGlvbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgc2hhcmVSZXBsYXksIG1hcCB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgRGJ4VmFsdWVMaXN0SXRlbSwgQWJzdHJhY3REYnhWYWx1ZUxpc3RWaWV3Q29uZmlnLCBEYnhWYWx1ZUxpc3RJdGVtQ29uZmlnIH0gZnJvbSAnLi9saXN0LnZpZXcudmFsdWUnO1xuaW1wb3J0IHsgQWJzdHJhY3REYnhWYWx1ZUxpc3RWaWV3RGlyZWN0aXZlIH0gZnJvbSAnLi9saXN0LnZpZXcudmFsdWUuZGlyZWN0aXZlJztcbmltcG9ydCB7IEFuY2hvclR5cGUsIGFuY2hvclR5cGVGb3JBbmNob3IgfSBmcm9tICdAZGVyZWVrYi9kYngtY29yZSc7XG5pbXBvcnQgeyBEYnhMaXN0VmlldyB9IGZyb20gJy4vbGlzdC52aWV3JztcbmltcG9ydCB7IE1heWJlIH0gZnJvbSAnQGRlcmVla2IvdXRpbCc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgRGJ4VmFsdWVMaXN0Vmlld0NvbmZpZzxULCBJIGV4dGVuZHMgRGJ4VmFsdWVMaXN0SXRlbTxUPiA9IERieFZhbHVlTGlzdEl0ZW08VD4sIFYgPSB1bmtub3duPiBleHRlbmRzIEFic3RyYWN0RGJ4VmFsdWVMaXN0Vmlld0NvbmZpZzxULCBJLCBWPiB7XG4gIGVtaXRBbGxDbGlja3M/OiBib29sZWFuO1xufVxuXG4vKipcbiAqIFJlbmRlcnMgYSBsaXN0IHZpZXcgdXNpbmcgaW5wdXQgY29uZmlndXJhdGlvbi4gUmVxdWlyZXMgYSBwYXJlbnQgRGJ4TGlzdFZpZXcuXG4gKi9cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2RieC1saXN0LXZpZXcnLFxuICB0ZW1wbGF0ZTogYFxuICAgIDxkYngtbGlzdC12aWV3LWNvbnRlbnQgW2l0ZW1zXT1cIml0ZW1zJCB8IGFzeW5jXCIgW2VtaXRBbGxDbGlja3NdPVwiZW1pdEFsbENsaWNrcyQgfCBhc3luY1wiPjwvZGJ4LWxpc3Qtdmlldy1jb250ZW50PlxuICBgXG59KVxuZXhwb3J0IGNsYXNzIERieFZhbHVlTGlzdFZpZXdDb21wb25lbnQ8VCwgSSBleHRlbmRzIERieFZhbHVlTGlzdEl0ZW08VD4gPSBEYnhWYWx1ZUxpc3RJdGVtPFQ+LCBWID0gdW5rbm93biwgQyBleHRlbmRzIERieFZhbHVlTGlzdFZpZXdDb25maWc8VCwgSSwgVj4gPSBEYnhWYWx1ZUxpc3RWaWV3Q29uZmlnPFQsIEksIFY+PiBleHRlbmRzIEFic3RyYWN0RGJ4VmFsdWVMaXN0Vmlld0RpcmVjdGl2ZTxULCBJLCBWLCBDPiB7XG4gIHJlYWRvbmx5IGVtaXRBbGxDbGlja3MkID0gdGhpcy5jb25maWckLnBpcGUoXG4gICAgbWFwKCh4KSA9PiB4LmVtaXRBbGxDbGlja3MpLFxuICAgIHNoYXJlUmVwbGF5KDEpXG4gICk7XG59XG5cbi8qKlxuICogQ29udGVudCB2aWV3IGZvciBhIERieFZhbHVlTGlzdFZpZXcuIEl0IGNhbiBiZSB1c2VkIGRpcmVjdGx5IGluIGNhc2VzIHdoZXJlIHRoZSBpdGVtcyBhcmUgYWxyZWFkeSBjb25maWd1cmVkLCBvciB3YW50IHRvIGJlIGNvbmZpZ3VyZWQgaW4gYSBub24tc3RhbmRhcmQgZmFzaGlvbi5cbiAqL1xuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnZGJ4LWxpc3Qtdmlldy1jb250ZW50JyxcbiAgdGVtcGxhdGU6IGBcbiAgICA8bWF0LW5hdi1saXN0IFtkaXNhYmxlZF09XCJkaXNhYmxlZCQgfCBhc3luY1wiPlxuICAgICAgPGRieC1hbmNob3IgKm5nRm9yPVwibGV0IGl0ZW0gb2YgaXRlbXM7IHRyYWNrQnk6IHRyYWNrQnlGdW5jdGlvblwiIFthbmNob3JdPVwiaXRlbS5hbmNob3JcIiBbZGlzYWJsZWRdPVwiaXRlbS5kaXNhYmxlZFwiPlxuICAgICAgICA8YSBtYXQtbGlzdC1pdGVtIGNsYXNzPVwiZGJ4LWxpc3Qtdmlldy1pdGVtXCIgW2Rpc2FibGVkXT1cIml0ZW0uZGlzYWJsZWRcIiBbZGlzYWJsZVJpcHBsZV09XCJyaXBwbGVEaXNhYmxlZE9uSXRlbShpdGVtKVwiIChjbGljayk9XCJvbkNsaWNrSXRlbShpdGVtKVwiPlxuICAgICAgICAgIDxtYXQtaWNvbiBtYXRMaXN0SXRlbUljb24gKm5nSWY9XCJpdGVtLmljb25cIj57eyBpdGVtLmljb24gfX08L21hdC1pY29uPlxuICAgICAgICAgIDxkYngtaW5qZWN0aW9uIFtjb25maWddPVwiaXRlbS5jb25maWdcIj48L2RieC1pbmplY3Rpb24+XG4gICAgICAgIDwvYT5cbiAgICAgIDwvZGJ4LWFuY2hvcj5cbiAgICA8L21hdC1uYXYtbGlzdD5cbiAgYCxcbiAgaG9zdDoge1xuICAgIGNsYXNzOiAnZGJ4LWxpc3QtdmlldydcbiAgfVxufSlcbmV4cG9ydCBjbGFzcyBEYnhWYWx1ZUxpc3RJdGVtVmlld0NvbXBvbmVudDxULCBJIGV4dGVuZHMgRGJ4VmFsdWVMaXN0SXRlbTxUPiA9IERieFZhbHVlTGlzdEl0ZW08VD4+IHtcbiAgQElucHV0KClcbiAgZW1pdEFsbENsaWNrcz86IE1heWJlPGJvb2xlYW4+O1xuXG4gIEBJbnB1dCgpXG4gIGl0ZW1zPzogTWF5YmU8RGJ4VmFsdWVMaXN0SXRlbUNvbmZpZzxULCBJPltdPjtcblxuICByZWFkb25seSBkaXNhYmxlZCQgPSB0aGlzLmRieExpc3RWaWV3LmRpc2FibGVkJDtcblxuICByZWFkb25seSB0cmFja0J5RnVuY3Rpb246IFRyYWNrQnlGdW5jdGlvbjxEYnhWYWx1ZUxpc3RJdGVtQ29uZmlnPFQsIEk+PjtcblxuICBjb25zdHJ1Y3RvcihyZWFkb25seSBkYnhMaXN0VmlldzogRGJ4TGlzdFZpZXc8VD4pIHtcbiAgICBjb25zdCB0cmFja0J5ID0gZGJ4TGlzdFZpZXcudHJhY2tCeTtcbiAgICB0aGlzLnRyYWNrQnlGdW5jdGlvbiA9IHRyYWNrQnkgPyAoaW5kZXg6IG51bWJlciwgaXRlbTogRGJ4VmFsdWVMaXN0SXRlbUNvbmZpZzxULCBJPikgPT4gdHJhY2tCeShpbmRleCwgaXRlbS5pdGVtVmFsdWUpIDogKCkgPT4gdW5kZWZpbmVkO1xuICB9XG5cbiAgb25DbGlja0l0ZW0oaXRlbTogSSkge1xuICAgIC8vIGRvIG5vdCBlbWl0IGNsaWNrcyBmb3IgZGlzYWJsZWQgaXRlbXMuXG4gICAgaWYgKCFpdGVtLmRpc2FibGVkKSB7XG4gICAgICBpZiAodGhpcy5lbWl0QWxsQ2xpY2tzIHx8ICFpdGVtLmFuY2hvciB8fCBhbmNob3JUeXBlRm9yQW5jaG9yKGl0ZW0uYW5jaG9yKSA9PT0gQW5jaG9yVHlwZS5QTEFJTikge1xuICAgICAgICAvLyBvbmx5IGVtaXQgY2xpY2tzIGZvciBpdGVtcyB3aXRoIG5vIGFuY2hvciwgb3IgcGxhaW4gYW5jaG9ycy5cbiAgICAgICAgdGhpcy5vbkNsaWNrVmFsdWUoaXRlbS5pdGVtVmFsdWUpO1xuICAgICAgfVxuICAgIH1cbiAgfVxuXG4gIG9uQ2xpY2tWYWx1ZSh2YWx1ZTogVCkge1xuICAgIHRoaXMuZGJ4TGlzdFZpZXcuY2xpY2tWYWx1ZT8ubmV4dCh2YWx1ZSk7XG4gIH1cblxuICByaXBwbGVEaXNhYmxlZE9uSXRlbShpdGVtOiBJKTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIGl0ZW0ucmlwcGxlRGlzYWJsZWQgfHwgKCF0aGlzLmVtaXRBbGxDbGlja3MgJiYgIWl0ZW0uYW5jaG9yKTtcbiAgfVxufVxuIl19
|
|
199
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list.view.value.component.js","sourceRoot":"","sources":["../../../../../../../packages/dbx-web/src/lib/layout/list/list.view.value.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Inject, Input, Optional, TrackByFunction } from '@angular/core';\nimport { shareReplay, map, Observable, BehaviorSubject, switchMap } from 'rxjs';\nimport { DbxValueListItem, AbstractDbxValueListViewConfig, DbxValueListItemConfig } from './list.view.value';\nimport { AbstractDbxValueListViewDirective } from './list.view.value.directive';\nimport { AnchorType, anchorTypeForAnchor } from '@dereekb/dbx-core';\nimport { DbxListView } from './list.view';\nimport { Maybe, SpaceSeparatedCssClasses, spaceSeparatedCssClasses } from '@dereekb/util';\nimport { DbxValueListItemGroup, DbxValueListViewGroupDelegate, defaultDbxValueListViewGroupDelegate } from './list.view.value.group';\nimport { asObservable } from '@dereekb/rxjs';\n\nexport interface DbxValueListViewConfig<T, I extends DbxValueListItem<T> = DbxValueListItem<T>, V = unknown> extends AbstractDbxValueListViewConfig<T, I, V> {\n  emitAllClicks?: boolean;\n}\n\n/**\n * Renders a list view using input configuration. Requires a parent DbxListView.\n */\n@Component({\n  selector: 'dbx-list-view',\n  template: `\n    <dbx-list-view-content [items]=\"items$ | async\" [emitAllClicks]=\"emitAllClicks$ | async\"></dbx-list-view-content>\n  `\n})\nexport class DbxValueListViewComponent<T, I extends DbxValueListItem<T> = DbxValueListItem<T>, V = unknown, C extends DbxValueListViewConfig<T, I, V> = DbxValueListViewConfig<T, I, V>> extends AbstractDbxValueListViewDirective<T, I, V, C> {\n  readonly emitAllClicks$ = this.config$.pipe(\n    map((x) => x.emitAllClicks),\n    shareReplay(1)\n  );\n}\n\n/**\n * Content view for a DbxValueListView. It can be used directly in cases where the items are already configured, or want to be configured in a non-standard fashion.\n */\n@Component({\n  selector: 'dbx-list-view-content',\n  template: `\n    <mat-nav-list [disabled]=\"disabled$ | async\">\n      <ng-container *ngFor=\"let group of groups$ | async; trackBy: trackGroupByFunction\">\n        <dbx-list-view-content-group [group]=\"group\"></dbx-list-view-content-group>\n      </ng-container>\n    </mat-nav-list>\n  `,\n  host: {\n    class: 'dbx-list-view'\n  },\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class DbxValueListViewContentComponent<T, I extends DbxValueListItem<T> = DbxValueListItem<T>> {\n  readonly _dbxListGroupDelegate: DbxValueListViewGroupDelegate<any, T, I>;\n\n  private _items = new BehaviorSubject<Maybe<DbxValueListItemConfig<T, I>[]>>(undefined);\n\n  readonly groups$: Observable<DbxValueListItemGroup<any, T, I>[]> = this._items.pipe(\n    switchMap((items) => asObservable(this._dbxListGroupDelegate.groupValues(items ?? []))),\n    shareReplay(1)\n  );\n\n  @Input()\n  emitAllClicks?: Maybe<boolean>;\n\n  readonly disabled$ = this.dbxListView.disabled$;\n\n  readonly trackByFunction: TrackByFunction<DbxValueListItemConfig<T, I>>;\n  readonly trackGroupByFunction: TrackByFunction<DbxValueListItemGroup<any, T, I>> = (_, v) => {\n    return v.id; // track by the id\n  };\n\n  constructor(readonly dbxListView: DbxListView<T>, @Optional() @Inject(DbxValueListViewGroupDelegate) inputDbxListGroupDelegate: Maybe<DbxValueListViewGroupDelegate<any, T, I>>) {\n    this._dbxListGroupDelegate = inputDbxListGroupDelegate ?? defaultDbxValueListViewGroupDelegate();\n    const trackBy = dbxListView.trackBy;\n    this.trackByFunction = trackBy ? (index: number, item: DbxValueListItemConfig<T, I>) => trackBy(index, item.itemValue) : () => undefined;\n  }\n\n  ngOnDestroy(): void {\n    this._items.complete();\n  }\n\n  @Input()\n  get items(): Maybe<DbxValueListItemConfig<T, I>[]> {\n    return this._items.value;\n  }\n\n  set items(items: Maybe<DbxValueListItemConfig<T, I>[]>) {\n    this._items.next(items);\n  }\n\n  onClickItem(item: I) {\n    // do not emit clicks for disabled items.\n    if (!item.disabled) {\n      if (this.emitAllClicks || !item.anchor || anchorTypeForAnchor(item.anchor) === AnchorType.PLAIN) {\n        // only emit clicks for items with no anchor, or plain anchors.\n        this.onClickValue(item.itemValue);\n      }\n    }\n  }\n\n  onClickValue(value: T) {\n    this.dbxListView.clickValue?.next(value);\n  }\n\n  rippleDisabledOnItem(item: I): boolean {\n    return item.rippleDisabled || (!this.emitAllClicks && !item.anchor);\n  }\n}\n\n/**\n * Content view for a DbxValueListView. It can be used directly in cases where the items are already configured, or want to be configured in a non-standard fashion.\n */\n@Component({\n  selector: 'dbx-list-view-content-group',\n  template: `\n    <div class=\"dbx-list-view-group-content\">\n      <div class=\"dbx-list-view-group-header\" *ngIf=\"headerConfig\">\n        <dbx-injection [config]=\"headerConfig\"></dbx-injection>\n      </div>\n      <dbx-anchor *ngFor=\"let item of items; trackBy: trackByFunction\" [anchor]=\"item.anchor\" [disabled]=\"item.disabled\">\n        <a mat-list-item class=\"dbx-list-view-item\" [disabled]=\"item.disabled\" [disableRipple]=\"rippleDisabledOnItem(item)\" (click)=\"onClickItem(item)\">\n          <mat-icon matListItemIcon *ngIf=\"item.icon\">{{ item.icon }}</mat-icon>\n          <dbx-injection [config]=\"item.config\"></dbx-injection>\n        </a>\n      </dbx-anchor>\n      <div class=\"dbx-list-view-group-footer\" *ngIf=\"footerConfig\">\n        <dbx-injection [config]=\"footerConfig\"></dbx-injection>\n      </div>\n    </div>\n  `,\n  host: {\n    class: 'dbx-list-view-group',\n    '[class]': 'cssClasses'\n  },\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class DbxValueListViewContentGroupComponent<G, T, I extends DbxValueListItem<T> = DbxValueListItem<T>> {\n  private _group: Maybe<DbxValueListItemGroup<G, T, I>>;\n  private _cssClasses: Maybe<SpaceSeparatedCssClasses>;\n\n  get cssClasses() {\n    return this._cssClasses;\n  }\n\n  get items(): Maybe<DbxValueListItemConfig<T, I>[]> {\n    return this._group?.items;\n  }\n\n  get headerConfig() {\n    return this._group?.headerConfig;\n  }\n\n  get footerConfig() {\n    return this._group?.footerConfig;\n  }\n\n  readonly disabled$: Observable<boolean>;\n  readonly trackByFunction: TrackByFunction<DbxValueListItemConfig<T, I>>;\n\n  constructor(readonly dbxValueListViewContentComponent: DbxValueListViewContentComponent<T>, readonly cdRef: ChangeDetectorRef) {\n    this.disabled$ = this.dbxValueListViewContentComponent.disabled$;\n    this.trackByFunction = this.dbxValueListViewContentComponent.trackByFunction;\n  }\n\n  @Input()\n  get group() {\n    return this._group;\n  }\n\n  set group(group: Maybe<DbxValueListItemGroup<G, T, I>>) {\n    this._group = group;\n    this._cssClasses = spaceSeparatedCssClasses(group?.cssClasses);\n    this.cdRef.markForCheck();\n  }\n\n  onClickItem(item: I) {\n    this.dbxValueListViewContentComponent.onClickItem(item);\n  }\n\n  onClickValue(value: T) {\n    this.dbxValueListViewContentComponent.onClickValue(value);\n  }\n\n  rippleDisabledOnItem(item: I): boolean {\n    return this.dbxValueListViewContentComponent.rippleDisabledOnItem(item);\n  }\n}\n"]}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { forwardRef } from '@angular/core';
|
|
2
|
+
export const defaultDbxValueListViewGroupValuesFunction = (items) => {
|
|
3
|
+
const data = {};
|
|
4
|
+
const result = {
|
|
5
|
+
id: '_',
|
|
6
|
+
data,
|
|
7
|
+
items
|
|
8
|
+
};
|
|
9
|
+
return [result];
|
|
10
|
+
};
|
|
11
|
+
/**
|
|
12
|
+
* Interface for a view that renders the items of a DbxList.
|
|
13
|
+
*/
|
|
14
|
+
export class DbxValueListViewGroupDelegate {
|
|
15
|
+
}
|
|
16
|
+
export function defaultDbxValueListViewGroupDelegate() {
|
|
17
|
+
const result = {
|
|
18
|
+
groupValues: defaultDbxValueListViewGroupValuesFunction
|
|
19
|
+
};
|
|
20
|
+
return result;
|
|
21
|
+
}
|
|
22
|
+
// eslint-disable-next-line
|
|
23
|
+
export function provideDbxValueListViewGroupDelegate(sourceType) {
|
|
24
|
+
// use of any here is allowed as typings are not relevant for providers
|
|
25
|
+
return [
|
|
26
|
+
{
|
|
27
|
+
provide: DbxValueListViewGroupDelegate,
|
|
28
|
+
useExisting: forwardRef(() => sourceType)
|
|
29
|
+
}
|
|
30
|
+
];
|
|
31
|
+
}
|
|
32
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlzdC52aWV3LnZhbHVlLmdyb3VwLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LXdlYi9zcmMvbGliL2xheW91dC9saXN0L2xpc3Qudmlldy52YWx1ZS5ncm91cC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFHQSxPQUFPLEVBQWtCLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQWdDM0QsTUFBTSxDQUFDLE1BQU0sMENBQTBDLEdBQUcsQ0FBbUMsS0FBcUMsRUFBRSxFQUFFO0lBQ3BJLE1BQU0sSUFBSSxHQUFHLEVBQUUsQ0FBQztJQUNoQixNQUFNLE1BQU0sR0FBeUM7UUFDbkQsRUFBRSxFQUFFLEdBQUc7UUFDUCxJQUFJO1FBQ0osS0FBSztLQUNOLENBQUM7SUFFRixPQUFPLENBQUMsTUFBTSxDQUFDLENBQUM7QUFDbEIsQ0FBQyxDQUFDO0FBRUY7O0dBRUc7QUFDSCxNQUFNLE9BQWdCLDZCQUE2QjtDQUtsRDtBQUVELE1BQU0sVUFBVSxvQ0FBb0M7SUFDbEQsTUFBTSxNQUFNLEdBQUc7UUFDYixXQUFXLEVBQUUsMENBQTBDO0tBQ3hELENBQUM7SUFFRixPQUFPLE1BQU0sQ0FBQztBQUNoQixDQUFDO0FBRUQsMkJBQTJCO0FBQzNCLE1BQU0sVUFBVSxvQ0FBb0MsQ0FBOEQsVUFBbUI7SUFDbkksdUVBQXVFO0lBQ3ZFLE9BQU87UUFDTDtZQUNFLE9BQU8sRUFBRSw2QkFBNkI7WUFDdEMsV0FBVyxFQUFFLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxVQUFVLENBQUM7U0FDMUM7S0FDRixDQUFDO0FBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENzc0NsYXNzZXNBcnJheSwgTWF5YmUsIFVuaXF1ZU1vZGVsIH0gZnJvbSAnQGRlcmVla2IvdXRpbCc7XG5pbXBvcnQgeyBEYnhWYWx1ZUxpc3RJdGVtLCBEYnhWYWx1ZUxpc3RJdGVtQ29uZmlnIH0gZnJvbSAnLi9saXN0LnZpZXcudmFsdWUnO1xuaW1wb3J0IHsgRGJ4SW5qZWN0aW9uQ29tcG9uZW50Q29uZmlnIH0gZnJvbSAnQGRlcmVla2IvZGJ4LWNvcmUnO1xuaW1wb3J0IHsgUHJvdmlkZXIsIFR5cGUsIGZvcndhcmRSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE9ic2VydmFibGVPclZhbHVlIH0gZnJvbSAnQGRlcmVla2Ivcnhqcyc7XG5cbi8qKlxuICogQSBncm91cCBvZiBEYnhWYWx1ZUxpc3RJdGVtIHZhbHVlcywgZ3JvdXBlZCBieSBjb21tb24gZGF0YSwgbmFtZSwgYW5kIGlkLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIERieFZhbHVlTGlzdEl0ZW1Hcm91cDxHLCBULCBJIGV4dGVuZHMgRGJ4VmFsdWVMaXN0SXRlbTxUPiwgSCA9IHVua25vd24sIEYgPSB1bmtub3duPiBleHRlbmRzIE9taXQ8RGJ4VmFsdWVMaXN0SXRlbTxhbnk+LCAnaXRlbVZhbHVlJyB8ICdpY29uJz4sIFJlYWRvbmx5PFJlcXVpcmVkPFVuaXF1ZU1vZGVsPj4ge1xuICByZWFkb25seSBkYXRhOiBHO1xuICByZWFkb25seSBpdGVtczogRGJ4VmFsdWVMaXN0SXRlbUNvbmZpZzxULCBJPltdO1xuICAvKipcbiAgICogKE9wdGlvbmFsKSBWaWV3IGNvbmZpZ3VyYXRpb24gZm9yIHRoZSBncm91cCdzIGhlYWRlci5cbiAgICovXG4gIHJlYWRvbmx5IGhlYWRlckNvbmZpZz86IE1heWJlPERieEluamVjdGlvbkNvbXBvbmVudENvbmZpZzxIPj47XG4gIC8qKlxuICAgKiAoT3B0aW9uYWwpIFZpZXcgY29uZmlndXJhdGlvbiBmb3IgdGhlIGdyb3VwJ3MgaGVhZGVyLlxuICAgKi9cbiAgcmVhZG9ubHkgZm9vdGVyQ29uZmlnPzogTWF5YmU8RGJ4SW5qZWN0aW9uQ29tcG9uZW50Q29uZmlnPEY+PjtcbiAgLyoqXG4gICAqIFdoZXRoZXIgb3Igbm90IHRvIHNob3cgdGhlIGdyb3VwJ3MgaXRlbXMuIERlZmF1bHRzIHRvIHRydWUuXG4gICAqL1xuICByZWFkb25seSBzaG93R3JvdXBJdGVtcz86IGJvb2xlYW47XG4gIC8qKlxuICAgKiBDdXN0b20gQ1NTIGNsYXNzZXMgdG8gYXBwbHkgdG8gYWxsIGdyb3Vwcy5cbiAgICovXG4gIHJlYWRvbmx5IGNzc0NsYXNzZXM/OiBDc3NDbGFzc2VzQXJyYXk7XG59XG5cbi8qKlxuICogRnVuY3Rpb24gdGhhdCBnZW5lcmF0ZXMgYW4gYXJyYXkgb2YgRGJ4VmFsdWVMaXN0SXRlbUdyb3VwIHZhbHVlcyBmcm9tIGEgbGlzdCBvZiBpdGVtcy5cbiAqL1xuZXhwb3J0IHR5cGUgRGJ4VmFsdWVMaXN0Vmlld0dyb3VwVmFsdWVzRnVuY3Rpb248RywgVCwgSSBleHRlbmRzIERieFZhbHVlTGlzdEl0ZW08VD4sIEggPSB1bmtub3duLCBGID0gdW5rbm93bj4gPSAoaXRlbXM6IERieFZhbHVlTGlzdEl0ZW1Db25maWc8VCwgST5bXSkgPT4gT2JzZXJ2YWJsZU9yVmFsdWU8RGJ4VmFsdWVMaXN0SXRlbUdyb3VwPEcsIFQsIEksIEgsIEY+W10+O1xuXG5leHBvcnQgY29uc3QgZGVmYXVsdERieFZhbHVlTGlzdFZpZXdHcm91cFZhbHVlc0Z1bmN0aW9uID0gPFQsIEkgZXh0ZW5kcyBEYnhWYWx1ZUxpc3RJdGVtPFQ+PihpdGVtczogRGJ4VmFsdWVMaXN0SXRlbUNvbmZpZzxULCBJPltdKSA9PiB7XG4gIGNvbnN0IGRhdGEgPSB7fTtcbiAgY29uc3QgcmVzdWx0OiBEYnhWYWx1ZUxpc3RJdGVtR3JvdXA8dW5rbm93biwgVCwgST4gPSB7XG4gICAgaWQ6ICdfJyxcbiAgICBkYXRhLFxuICAgIGl0ZW1zXG4gIH07XG5cbiAgcmV0dXJuIFtyZXN1bHRdO1xufTtcblxuLyoqXG4gKiBJbnRlcmZhY2UgZm9yIGEgdmlldyB0aGF0IHJlbmRlcnMgdGhlIGl0ZW1zIG9mIGEgRGJ4TGlzdC5cbiAqL1xuZXhwb3J0IGFic3RyYWN0IGNsYXNzIERieFZhbHVlTGlzdFZpZXdHcm91cERlbGVnYXRlPEcsIFQsIEkgZXh0ZW5kcyBEYnhWYWx1ZUxpc3RJdGVtPFQ+ID0gRGJ4VmFsdWVMaXN0SXRlbTxUPiwgSCA9IHVua25vd24sIEYgPSB1bmtub3duPiB7XG4gIC8qKlxuICAgKiBHcm91cHMgYWxsIGlucHV0IGl0ZW1zIGludG8gZ3JvdXBzLlxuICAgKi9cbiAgYWJzdHJhY3QgcmVhZG9ubHkgZ3JvdXBWYWx1ZXM6IERieFZhbHVlTGlzdFZpZXdHcm91cFZhbHVlc0Z1bmN0aW9uPEcsIFQsIEksIEgsIEY+O1xufVxuXG5leHBvcnQgZnVuY3Rpb24gZGVmYXVsdERieFZhbHVlTGlzdFZpZXdHcm91cERlbGVnYXRlPFQsIEkgZXh0ZW5kcyBEYnhWYWx1ZUxpc3RJdGVtPFQ+PigpOiBEYnhWYWx1ZUxpc3RWaWV3R3JvdXBEZWxlZ2F0ZTxhbnksIFQsIEk+IHtcbiAgY29uc3QgcmVzdWx0ID0ge1xuICAgIGdyb3VwVmFsdWVzOiBkZWZhdWx0RGJ4VmFsdWVMaXN0Vmlld0dyb3VwVmFsdWVzRnVuY3Rpb25cbiAgfTtcblxuICByZXR1cm4gcmVzdWx0O1xufVxuXG4vLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmVcbmV4cG9ydCBmdW5jdGlvbiBwcm92aWRlRGJ4VmFsdWVMaXN0Vmlld0dyb3VwRGVsZWdhdGU8RCBleHRlbmRzIERieFZhbHVlTGlzdFZpZXdHcm91cERlbGVnYXRlPGFueSwgYW55LCBhbnksIGFueT4+KHNvdXJjZVR5cGU6IFR5cGU8RD4pOiBQcm92aWRlcltdIHtcbiAgLy8gdXNlIG9mIGFueSBoZXJlIGlzIGFsbG93ZWQgYXMgdHlwaW5ncyBhcmUgbm90IHJlbGV2YW50IGZvciBwcm92aWRlcnNcbiAgcmV0dXJuIFtcbiAgICB7XG4gICAgICBwcm92aWRlOiBEYnhWYWx1ZUxpc3RWaWV3R3JvdXBEZWxlZ2F0ZSxcbiAgICAgIHVzZUV4aXN0aW5nOiBmb3J3YXJkUmVmKCgpID0+IHNvdXJjZVR5cGUpXG4gICAgfVxuICBdO1xufVxuIl19
|
|
@@ -0,0 +1,132 @@
|
|
|
1
|
+
import { Directive, Input, InjectionToken, Component, ChangeDetectionStrategy, Inject } from '@angular/core';
|
|
2
|
+
import { provideDbxValueListViewGroupDelegate } from './list.view.value.group';
|
|
3
|
+
import { BehaviorSubject, map } from 'rxjs';
|
|
4
|
+
import { compareWithMappedValuesFunction, makeValuesGroupMap } from '@dereekb/util';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "@angular/common";
|
|
7
|
+
import * as i2 from "@angular/material/icon";
|
|
8
|
+
export const DBX_LIST_TITLE_GROUP_DATA = new InjectionToken('DbxListTitleGroupData');
|
|
9
|
+
/**
|
|
10
|
+
* Delegate used to for grouping DbxValueListItemConfig<T, I> values.
|
|
11
|
+
*/
|
|
12
|
+
export class DbxListTitleGroupDirective {
|
|
13
|
+
constructor() {
|
|
14
|
+
this._delegate = new BehaviorSubject(undefined);
|
|
15
|
+
this.groupValues = (items) => {
|
|
16
|
+
return this._delegate.pipe(map((delegate) => {
|
|
17
|
+
let groups;
|
|
18
|
+
if (delegate != null) {
|
|
19
|
+
const groupsValuesMap = makeValuesGroupMap(items, delegate.groupValueForItem);
|
|
20
|
+
const { sortGroupsByData, cssClasses: inputCssClasses } = delegate;
|
|
21
|
+
const cssClassesForAllGroups = inputCssClasses ?? [];
|
|
22
|
+
const componentClass = delegate.headerComponentClass ?? DbxListTitleGroupHeaderComponent;
|
|
23
|
+
groups = Array.from(groupsValuesMap.entries()).map(([value, items]) => {
|
|
24
|
+
const data = delegate.dataForGroupValue(value, items);
|
|
25
|
+
data.value = value;
|
|
26
|
+
const cssClasses = data.cssClasses ? [...cssClassesForAllGroups, ...data.cssClasses] : cssClassesForAllGroups;
|
|
27
|
+
const group = {
|
|
28
|
+
id: String(value),
|
|
29
|
+
data,
|
|
30
|
+
items,
|
|
31
|
+
headerConfig: {
|
|
32
|
+
componentClass,
|
|
33
|
+
providers: [
|
|
34
|
+
{
|
|
35
|
+
provide: DBX_LIST_TITLE_GROUP_DATA,
|
|
36
|
+
useValue: data
|
|
37
|
+
}
|
|
38
|
+
]
|
|
39
|
+
},
|
|
40
|
+
cssClasses
|
|
41
|
+
};
|
|
42
|
+
return group;
|
|
43
|
+
});
|
|
44
|
+
if (sortGroupsByData) {
|
|
45
|
+
groups.sort(compareWithMappedValuesFunction((x) => x.data, sortGroupsByData));
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
else {
|
|
49
|
+
groups = [
|
|
50
|
+
{
|
|
51
|
+
id: '_',
|
|
52
|
+
data: { value: null, title: '' },
|
|
53
|
+
items
|
|
54
|
+
}
|
|
55
|
+
];
|
|
56
|
+
}
|
|
57
|
+
return groups;
|
|
58
|
+
}));
|
|
59
|
+
};
|
|
60
|
+
}
|
|
61
|
+
ngOnDestroy() {
|
|
62
|
+
this._delegate.complete();
|
|
63
|
+
}
|
|
64
|
+
get delegate() {
|
|
65
|
+
return this._delegate.value;
|
|
66
|
+
}
|
|
67
|
+
set delegate(delegate) {
|
|
68
|
+
this._delegate.next(delegate);
|
|
69
|
+
}
|
|
70
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DbxListTitleGroupDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
71
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: DbxListTitleGroupDirective, selector: "[dbxListTitleGroup]", inputs: { delegate: ["dbxListTitleGroup", "delegate"] }, providers: [provideDbxValueListViewGroupDelegate(DbxListTitleGroupDirective)], ngImport: i0 }); }
|
|
72
|
+
}
|
|
73
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DbxListTitleGroupDirective, decorators: [{
|
|
74
|
+
type: Directive,
|
|
75
|
+
args: [{
|
|
76
|
+
selector: '[dbxListTitleGroup]',
|
|
77
|
+
providers: [provideDbxValueListViewGroupDelegate(DbxListTitleGroupDirective)]
|
|
78
|
+
}]
|
|
79
|
+
}], propDecorators: { delegate: [{
|
|
80
|
+
type: Input,
|
|
81
|
+
args: ['dbxListTitleGroup']
|
|
82
|
+
}] } });
|
|
83
|
+
/**
|
|
84
|
+
*
|
|
85
|
+
*/
|
|
86
|
+
export class DbxListTitleGroupHeaderComponent {
|
|
87
|
+
get icon() {
|
|
88
|
+
return this.data.icon;
|
|
89
|
+
}
|
|
90
|
+
get title() {
|
|
91
|
+
return this.data.title;
|
|
92
|
+
}
|
|
93
|
+
get hint() {
|
|
94
|
+
return this.data.hint;
|
|
95
|
+
}
|
|
96
|
+
constructor(data) {
|
|
97
|
+
this.data = data;
|
|
98
|
+
}
|
|
99
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DbxListTitleGroupHeaderComponent, deps: [{ token: DBX_LIST_TITLE_GROUP_DATA }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
100
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DbxListTitleGroupHeaderComponent, selector: "dbx-list-title-group-header", host: { classAttribute: "dbx-list-title-group-header" }, ngImport: i0, template: `
|
|
101
|
+
<div class="dbx-list-item-padded dbx-list-two-line-item">
|
|
102
|
+
<mat-icon class="item-icon" *ngIf="icon">{{ icon }}</mat-icon>
|
|
103
|
+
<div class="item-left">
|
|
104
|
+
<div class="mat-subtitle-2">{{ title }}</div>
|
|
105
|
+
<div *ngIf="hint" class="item-details">{{ hint }}</div>
|
|
106
|
+
</div>
|
|
107
|
+
</div>
|
|
108
|
+
`, isInline: true, dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
109
|
+
}
|
|
110
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DbxListTitleGroupHeaderComponent, decorators: [{
|
|
111
|
+
type: Component,
|
|
112
|
+
args: [{
|
|
113
|
+
selector: 'dbx-list-title-group-header',
|
|
114
|
+
template: `
|
|
115
|
+
<div class="dbx-list-item-padded dbx-list-two-line-item">
|
|
116
|
+
<mat-icon class="item-icon" *ngIf="icon">{{ icon }}</mat-icon>
|
|
117
|
+
<div class="item-left">
|
|
118
|
+
<div class="mat-subtitle-2">{{ title }}</div>
|
|
119
|
+
<div *ngIf="hint" class="item-details">{{ hint }}</div>
|
|
120
|
+
</div>
|
|
121
|
+
</div>
|
|
122
|
+
`,
|
|
123
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
124
|
+
host: {
|
|
125
|
+
class: 'dbx-list-title-group-header'
|
|
126
|
+
}
|
|
127
|
+
}]
|
|
128
|
+
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
129
|
+
type: Inject,
|
|
130
|
+
args: [DBX_LIST_TITLE_GROUP_DATA]
|
|
131
|
+
}] }]; } });
|
|
132
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list.view.value.group.title.directive.js","sourceRoot":"","sources":["../../../../../../../packages/dbx-web/src/lib/layout/list/list.view.value.group.title.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, Input, InjectionToken, Component, ChangeDetectionStrategy, Inject } from '@angular/core';\nimport { DbxValueListItem, DbxValueListItemConfig } from './list.view.value';\nimport { DbxValueListItemGroup, DbxValueListViewGroupDelegate, DbxValueListViewGroupValuesFunction, provideDbxValueListViewGroupDelegate } from './list.view.value.group';\nimport { BehaviorSubject, map } from 'rxjs';\nimport { Building, Maybe, PrimativeKey, compareWithMappedValuesFunction, makeValuesGroupMap } from '@dereekb/util';\nimport { DbxListTitleGroupData, DbxListTitleGroupTitleDelegate } from './list.view.value.group.title';\n\nexport const DBX_LIST_TITLE_GROUP_DATA = new InjectionToken<unknown>('DbxListTitleGroupData');\n\n/**\n * Delegate used to for grouping DbxValueListItemConfig<T, I> values.\n */\n@Directive({\n  selector: '[dbxListTitleGroup]',\n  providers: [provideDbxValueListViewGroupDelegate(DbxListTitleGroupDirective)]\n})\nexport class DbxListTitleGroupDirective<T, O extends PrimativeKey = PrimativeKey, D extends DbxListTitleGroupData<O> = DbxListTitleGroupData<O>, I extends DbxValueListItem<T> = DbxValueListItem<T>> implements DbxValueListViewGroupDelegate<D, T, I> {\n  private _delegate = new BehaviorSubject<Maybe<DbxListTitleGroupTitleDelegate<T, O, D, I>>>(undefined);\n\n  readonly groupValues: DbxValueListViewGroupValuesFunction<D, T, I, unknown, unknown> = (items: DbxValueListItemConfig<T, I>[]) => {\n    return this._delegate.pipe(\n      map((delegate) => {\n        let groups: DbxValueListItemGroup<D, T, I>[];\n\n        if (delegate != null) {\n          const groupsValuesMap = makeValuesGroupMap(items, delegate.groupValueForItem);\n          const { sortGroupsByData, cssClasses: inputCssClasses } = delegate;\n          const cssClassesForAllGroups = inputCssClasses ?? [];\n\n          const componentClass = delegate.headerComponentClass ?? DbxListTitleGroupHeaderComponent;\n          groups = Array.from(groupsValuesMap.entries()).map(([value, items]) => {\n            const data = delegate.dataForGroupValue(value as O, items);\n            (data as Building<D>).value = value as O;\n            const cssClasses = data.cssClasses ? [...cssClassesForAllGroups, ...data.cssClasses] : cssClassesForAllGroups;\n\n            const group: DbxValueListItemGroup<D, T, I> = {\n              id: String(value),\n              data,\n              items,\n              headerConfig: {\n                componentClass,\n                providers: [\n                  {\n                    provide: DBX_LIST_TITLE_GROUP_DATA,\n                    useValue: data\n                  }\n                ]\n              },\n              cssClasses\n            };\n\n            return group;\n          });\n\n          if (sortGroupsByData) {\n            groups.sort(compareWithMappedValuesFunction((x) => x.data, sortGroupsByData));\n          }\n        } else {\n          groups = [\n            {\n              id: '_',\n              data: { value: null as any, title: '' } as D,\n              items\n            }\n          ];\n        }\n\n        return groups;\n      })\n    );\n  };\n\n  ngOnDestroy(): void {\n    this._delegate.complete();\n  }\n\n  @Input('dbxListTitleGroup')\n  get delegate() {\n    return this._delegate.value;\n  }\n\n  set delegate(delegate: Maybe<DbxListTitleGroupTitleDelegate<T, O, D, I>>) {\n    this._delegate.next(delegate);\n  }\n}\n\n/**\n *\n */\n@Component({\n  selector: 'dbx-list-title-group-header',\n  template: `\n    <div class=\"dbx-list-item-padded dbx-list-two-line-item\">\n      <mat-icon class=\"item-icon\" *ngIf=\"icon\">{{ icon }}</mat-icon>\n      <div class=\"item-left\">\n        <div class=\"mat-subtitle-2\">{{ title }}</div>\n        <div *ngIf=\"hint\" class=\"item-details\">{{ hint }}</div>\n      </div>\n    </div>\n  `,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  host: {\n    class: 'dbx-list-title-group-header'\n  }\n})\nexport class DbxListTitleGroupHeaderComponent<O extends PrimativeKey, D extends DbxListTitleGroupData<O>> {\n  get icon() {\n    return this.data.icon;\n  }\n\n  get title() {\n    return this.data.title;\n  }\n\n  get hint() {\n    return this.data.hint;\n  }\n\n  constructor(@Inject(DBX_LIST_TITLE_GROUP_DATA) readonly data: D) {}\n}\n"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlzdC52aWV3LnZhbHVlLmdyb3VwLnRpdGxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LXdlYi9zcmMvbGliL2xheW91dC9saXN0L2xpc3Qudmlldy52YWx1ZS5ncm91cC50aXRsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVHlwZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgUHJpbWF0aXZlS2V5LCBTb3J0Q29tcGFyZUZ1bmN0aW9uLCBDc3NDbGFzc2VzQXJyYXkgfSBmcm9tICdAZGVyZWVrYi91dGlsJztcbmltcG9ydCB7IERieFZhbHVlTGlzdEl0ZW0sIERieFZhbHVlTGlzdEl0ZW1Db25maWcgfSBmcm9tICcuL2xpc3Qudmlldy52YWx1ZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgRGJ4TGlzdFRpdGxlR3JvdXBEYXRhPE8gZXh0ZW5kcyBQcmltYXRpdmVLZXk+IHtcbiAgLyoqXG4gICAqIERhdGEgVmFsdWUuIFNob3VsZCBnZW5lcmFsbHkgYmUgZGVmaW5lZCwgYnV0IGNhbiBiZSBudWxsIGlmIHRoZSBncm91cCBpcyBhIGRlZmF1bHQgZ3JvdXAuXG4gICAqL1xuICByZWFkb25seSB2YWx1ZTogTztcbiAgLyoqXG4gICAqIE9wdGlvbmFsIGljb24gdG8gc2hvdyBhdCB0aGUgbGVmdC5cbiAgICovXG4gIHJlYWRvbmx5IGljb24/OiBzdHJpbmc7XG4gIHJlYWRvbmx5IHRpdGxlOiBzdHJpbmc7XG4gIHJlYWRvbmx5IGhpbnQ/OiBzdHJpbmc7XG4gIC8qKlxuICAgKiBDdXN0b20gQ1NTIGNsYXNzZXMgdG8gYXBwbHkgb25seSB0byB0aGlzIGdyb3VwLlxuICAgKi9cbiAgcmVhZG9ubHkgY3NzQ2xhc3Nlcz86IENzc0NsYXNzZXNBcnJheTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBEYnhMaXN0VGl0bGVHcm91cFRpdGxlRGVsZWdhdGU8VCwgTyBleHRlbmRzIFByaW1hdGl2ZUtleSwgRCBleHRlbmRzIERieExpc3RUaXRsZUdyb3VwRGF0YTxPPiA9IERieExpc3RUaXRsZUdyb3VwRGF0YTxPPiwgSSBleHRlbmRzIERieFZhbHVlTGlzdEl0ZW08VD4gPSBEYnhWYWx1ZUxpc3RJdGVtPFQ+PiB7XG4gIC8qKlxuICAgKiBSZXR1cm5zIGEga2V5IHZhbHVlIGZvciB0aGUgaW5wdXQgaXRlbS4gSWYgdGhlIGl0ZW0gZG9lcyBub3QgYmVsb25nIHRvIGEgZ3JvdXAsIHJldHVybnMgdW5kZWZpbmVkLlxuICAgKlxuICAgKiBAcGFyYW0gaXRlbVxuICAgKiBAcmV0dXJuc1xuICAgKi9cbiAgcmVhZG9ubHkgZ3JvdXBWYWx1ZUZvckl0ZW06IChpdGVtOiBEYnhWYWx1ZUxpc3RJdGVtQ29uZmlnPFQsIEk+KSA9PiBPO1xuICAvKipcbiAgICogQ29udmVydHMgYSBrZXkgdmFsdWUgdG8gYSBEYnhMaXN0VGl0bGVHcm91cERhdGEgZm9yIGEgZ3JvdXAuXG4gICAqXG4gICAqIEBwYXJhbSB2YWx1ZVxuICAgKiBAcmV0dXJuc1xuICAgKi9cbiAgcmVhZG9ubHkgZGF0YUZvckdyb3VwVmFsdWU6ICh2YWx1ZTogTywgaXRlbXM6IERieFZhbHVlTGlzdEl0ZW1Db25maWc8VCwgST5bXSkgPT4gRDtcbiAgLyoqXG4gICAqIChPcHRpb25hbCkgc29ydCBmdW5jdGlvbiBmb3Igc29ydGluZyBncm91cHMgYnkgdGhlaXIgZGF0YS5cbiAgICovXG4gIHJlYWRvbmx5IHNvcnRHcm91cHNCeURhdGE/OiBTb3J0Q29tcGFyZUZ1bmN0aW9uPEQ+O1xuICAvKipcbiAgICogQ3VzdG9tIGhlYWRlciBjb21wb25lbnQgY2xhc3MgdG8gaW5qZWN0LlxuICAgKlxuICAgKiBEYnhMaXN0VGl0bGVHcm91cEhlYWRlckNvbXBvbmVudCBpcyBpbmplY3RlZCBieSBkZWZhdWx0LlxuICAgKi9cbiAgcmVhZG9ubHkgaGVhZGVyQ29tcG9uZW50Q2xhc3M/OiBUeXBlPHVua25vd24+O1xuICAvKipcbiAgICogKE9wdGlvbmFsKSBDU1MgY2xhc3NlcyB0byBhcHBseSB0byB0aGUgZ3JvdXAuXG4gICAqL1xuICByZWFkb25seSBjc3NDbGFzc2VzPzogQ3NzQ2xhc3Nlc0FycmF5O1xufVxuIl19
|
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
import { map, shareReplay, distinctUntilChanged, of } from 'rxjs';
|
|
2
|
-
import { Component, Input } from '@angular/core';
|
|
2
|
+
import { ChangeDetectionStrategy, Component, Inject, Input, Optional } from '@angular/core';
|
|
3
3
|
import { DbxListView } from './list.view';
|
|
4
4
|
import { AbstractDbxValueListViewDirective } from './list.view.value.directive';
|
|
5
|
-
import {
|
|
5
|
+
import { DbxValueListViewContentComponent } from './list.view.value.component';
|
|
6
|
+
import { DbxValueListViewGroupDelegate } from './list.view.value.group';
|
|
6
7
|
import * as i0 from "@angular/core";
|
|
7
8
|
import * as i1 from "@angular/common";
|
|
8
9
|
import * as i2 from "./list.view";
|
|
@@ -22,7 +23,7 @@ export class DbxSelectionValueListViewComponent extends AbstractDbxValueListView
|
|
|
22
23
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DbxSelectionValueListViewComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
23
24
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DbxSelectionValueListViewComponent, selector: "dbx-selection-list-view", usesInheritance: true, ngImport: i0, template: `
|
|
24
25
|
<dbx-selection-list-view-content [selectionMode]="selectionMode$ | async" [multiple]="multiple$ | async" [items]="items$ | async"></dbx-selection-list-view-content>
|
|
25
|
-
`, isInline: true, dependencies: [{ kind: "component", type: i0.forwardRef(function () { return
|
|
26
|
+
`, isInline: true, dependencies: [{ kind: "component", type: i0.forwardRef(function () { return DbxSelectionValueListViewContentComponent; }), selector: "dbx-selection-list-view-content", inputs: ["multiple", "selectionMode"] }, { kind: "pipe", type: i0.forwardRef(function () { return i1.AsyncPipe; }), name: "async" }] }); }
|
|
26
27
|
}
|
|
27
28
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DbxSelectionValueListViewComponent, decorators: [{
|
|
28
29
|
type: Component,
|
|
@@ -36,9 +37,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
36
37
|
/**
|
|
37
38
|
* Content view for a DbxSelectionValueListView. It can be used directly in cases where the items are already configured, or want to be configured in a non-standard fashion.
|
|
38
39
|
*/
|
|
39
|
-
export class
|
|
40
|
-
constructor(dbxListView) {
|
|
41
|
-
super(dbxListView);
|
|
40
|
+
export class DbxSelectionValueListViewContentComponent extends DbxValueListViewContentComponent {
|
|
41
|
+
constructor(dbxListView, inputDbxListGroupDelegate) {
|
|
42
|
+
super(dbxListView, inputDbxListGroupDelegate);
|
|
42
43
|
if (!dbxListView.selectionChange) {
|
|
43
44
|
throw new Error('Parent dbxListView to DbxSelectionValueListViewComponent has no selectionChange emitter.');
|
|
44
45
|
}
|
|
@@ -54,8 +55,8 @@ export class DbxSelectionValueListItemViewComponent extends DbxValueListItemView
|
|
|
54
55
|
items
|
|
55
56
|
});
|
|
56
57
|
}
|
|
57
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type:
|
|
58
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type:
|
|
58
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DbxSelectionValueListViewContentComponent, deps: [{ token: i2.DbxListView }, { token: DbxValueListViewGroupDelegate, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
59
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DbxSelectionValueListViewContentComponent, selector: "dbx-selection-list-view-content", inputs: { multiple: "multiple", selectionMode: "selectionMode" }, host: { classAttribute: "dbx-list-view dbx-selection-list-view" }, usesInheritance: true, ngImport: i0, template: `
|
|
59
60
|
<ng-container [ngSwitch]="selectionMode">
|
|
60
61
|
<ng-container *ngSwitchCase="'view'">
|
|
61
62
|
<dbx-list-view-content [items]="items"></dbx-list-view-content>
|
|
@@ -69,9 +70,9 @@ export class DbxSelectionValueListItemViewComponent extends DbxValueListItemView
|
|
|
69
70
|
</mat-selection-list>
|
|
70
71
|
</ng-container>
|
|
71
72
|
</ng-container>
|
|
72
|
-
`, isInline: true, dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i1.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { kind: "component", type: i3.DbxInjectionComponent, selector: "dbx-injection, [dbxInjection], [dbx-injection]", inputs: ["config", "template"] }, { kind: "component", type: i4.MatSelectionList, selector: "mat-selection-list", inputs: ["color", "compareWith", "multiple", "hideSingleSelectionIndicator", "disabled"], outputs: ["selectionChange"], exportAs: ["matSelectionList"] }, { kind: "component", type: i4.MatListOption, selector: "mat-list-option", inputs: ["togglePosition", "checkboxPosition", "color", "value", "selected"], outputs: ["selectedChange"], exportAs: ["matListOption"] }, { kind: "directive", type: i4.MatListItemIcon, selector: "[matListItemIcon]" }, { kind: "component", type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i6.
|
|
73
|
+
`, isInline: true, dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i1.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { kind: "component", type: i3.DbxInjectionComponent, selector: "dbx-injection, [dbxInjection], [dbx-injection]", inputs: ["config", "template"] }, { kind: "component", type: i4.MatSelectionList, selector: "mat-selection-list", inputs: ["color", "compareWith", "multiple", "hideSingleSelectionIndicator", "disabled"], outputs: ["selectionChange"], exportAs: ["matSelectionList"] }, { kind: "component", type: i4.MatListOption, selector: "mat-list-option", inputs: ["togglePosition", "checkboxPosition", "color", "value", "selected"], outputs: ["selectedChange"], exportAs: ["matListOption"] }, { kind: "directive", type: i4.MatListItemIcon, selector: "[matListItemIcon]" }, { kind: "component", type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i6.DbxValueListViewContentComponent, selector: "dbx-list-view-content", inputs: ["emitAllClicks", "items"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
73
74
|
}
|
|
74
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type:
|
|
75
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DbxSelectionValueListViewContentComponent, decorators: [{
|
|
75
76
|
type: Component,
|
|
76
77
|
args: [{
|
|
77
78
|
selector: 'dbx-selection-list-view-content',
|
|
@@ -92,11 +93,17 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
92
93
|
`,
|
|
93
94
|
host: {
|
|
94
95
|
class: 'dbx-list-view dbx-selection-list-view'
|
|
95
|
-
}
|
|
96
|
+
},
|
|
97
|
+
changeDetection: ChangeDetectionStrategy.OnPush
|
|
96
98
|
}]
|
|
97
|
-
}], ctorParameters: function () { return [{ type: i2.DbxListView }
|
|
99
|
+
}], ctorParameters: function () { return [{ type: i2.DbxListView }, { type: undefined, decorators: [{
|
|
100
|
+
type: Optional
|
|
101
|
+
}, {
|
|
102
|
+
type: Inject,
|
|
103
|
+
args: [DbxValueListViewGroupDelegate]
|
|
104
|
+
}] }]; }, propDecorators: { multiple: [{
|
|
98
105
|
type: Input
|
|
99
106
|
}], selectionMode: [{
|
|
100
107
|
type: Input
|
|
101
108
|
}] } });
|
|
102
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
109
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list.view.value.selection.component.js","sourceRoot":"","sources":["../../../../../../../packages/dbx-web/src/lib/layout/list/list.view.value.selection.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAc,GAAG,EAAE,WAAW,EAAE,oBAAoB,EAAE,EAAE,EAAE,MAAM,MAAM,CAAC;AAC9E,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAgB,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AAE1G,OAAO,EAAwB,WAAW,EAA8C,MAAM,aAAa,CAAC;AAE5G,OAAO,EAAE,iCAAiC,EAAE,MAAM,6BAA6B,CAAC;AAEhF,OAAO,EAAE,gCAAgC,EAAE,MAAM,6BAA6B,CAAC;AAC/E,OAAO,EAAE,6BAA6B,EAAE,MAAM,yBAAyB,CAAC;;;;;;;;AAMxE;;GAEG;AAOH,MAAM,OAAO,kCAAwG,SAAQ,iCAAoF;IANjN;;QAOW,mBAAc,GAAqC,CAAC,IAAI,CAAC,WAAW,CAAC,cAAc,IAAI,EAAE,CAAC,QAAgC,CAAC,CAAC,CAAC,IAAI,CACxI,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,IAAI,QAAQ,CAAC,EACzB,oBAAoB,EAAE,CACvB,CAAC;QACO,cAAS,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CACpC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,IAAI,IAAI,CAAC,EAC9B,oBAAoB,EAAE,EACtB,WAAW,CAAC,CAAC,CAAC,CACf,CAAC;KACH;+GAVY,kCAAkC;mGAAlC,kCAAkC,sFAJnC;;GAET,+FAuCU,yCAAyC;;4FArCzC,kCAAkC;kBAN9C,SAAS;mBAAC;oBACT,QAAQ,EAAE,yBAAyB;oBACnC,QAAQ,EAAE;;GAET;iBACF;;AAaD;;GAEG;AAuBH,MAAM,OAAO,yCAAkG,SAAQ,gCAAsC;IAO3J,YAAY,WAA2B,EAAqD,yBAA0E;QACpK,KAAK,CAAC,WAAW,EAAE,yBAAyB,CAAC,CAAC;QAE9C,IAAI,CAAC,WAAW,CAAC,eAAe,EAAE;YAChC,MAAM,IAAI,KAAK,CAAC,0FAA0F,CAAC,CAAC;SAC7G;IACH,CAAC;IAED,mBAAmB,CAAC,SAAiC;QACnD,MAAM,OAAO,GAAG,SAAS,CAAC,MAAM,CAAC,eAAe,CAAC,QAAQ,CAAC;QAC1D,MAAM,KAAK,GAAgC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE;YAC3D,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,QAAQ,EAAE,QAAQ,EAAE,GAAG,CAAC,CAAC;YACnD,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,QAAQ,EAAE,CAAC;QAC3C,CAAC,CAAC,CAAC;QAEF,IAAI,CAAC,WAAW,CAAC,eAAuD,CAAC,IAAI,CAAC;YAC7E,0BAA0B;YAC1B,KAAK;SACN,CAAC,CAAC;IACL,CAAC;+GA1BU,yCAAyC,6CAOS,6BAA6B;mGAP/E,yCAAyC,mOApB1C;;;;;;;;;;;;;;GAcT;;4FAMU,yCAAyC;kBAtBrD,SAAS;mBAAC;oBACT,QAAQ,EAAE,iCAAiC;oBAC3C,QAAQ,EAAE;;;;;;;;;;;;;;GAcT;oBACD,IAAI,EAAE;wBACJ,KAAK,EAAE,uCAAuC;qBAC/C;oBACD,eAAe,EAAE,uBAAuB,CAAC,MAAM;iBAChD;;0BAQ2C,QAAQ;;0BAAI,MAAM;2BAAC,6BAA6B;4CAL1F,QAAQ;sBADP,KAAK;gBAIN,aAAa;sBADZ,KAAK","sourcesContent":["import { Observable, map, shareReplay, distinctUntilChanged, of } from 'rxjs';\nimport { ChangeDetectionStrategy, Component, EventEmitter, Inject, Input, Optional } from '@angular/core';\nimport { MatSelectionListChange } from '@angular/material/list';\nimport { DbxListSelectionMode, DbxListView, ListSelectionState, ListSelectionStateItem } from './list.view';\nimport { DbxValueListItem, AbstractDbxValueListViewConfig } from './list.view.value';\nimport { AbstractDbxValueListViewDirective } from './list.view.value.directive';\nimport { Maybe } from '@dereekb/util';\nimport { DbxValueListViewContentComponent } from './list.view.value.component';\nimport { DbxValueListViewGroupDelegate } from './list.view.value.group';\n\nexport interface DbxSelectionValueListViewConfig<T, I extends DbxValueListItem<T> = DbxValueListItem<T>, V = unknown> extends AbstractDbxValueListViewConfig<T, I, V> {\n  readonly multiple?: boolean;\n}\n\n/**\n * Renders a selection list view using input configuration. Requires a parent DbxListView.\n */\n@Component({\n  selector: 'dbx-selection-list-view',\n  template: `\n    <dbx-selection-list-view-content [selectionMode]=\"selectionMode$ | async\" [multiple]=\"multiple$ | async\" [items]=\"items$ | async\"></dbx-selection-list-view-content>\n  `\n})\nexport class DbxSelectionValueListViewComponent<T, I extends DbxValueListItem<T> = DbxValueListItem<T>, V = unknown> extends AbstractDbxValueListViewDirective<T, I, V, DbxSelectionValueListViewConfig<T, I, V>> {\n  readonly selectionMode$: Observable<DbxListSelectionMode> = (this.dbxListView.selectionMode$ ?? of('select' as DbxListSelectionMode)).pipe(\n    map((x) => x ?? 'select'),\n    distinctUntilChanged()\n  );\n  readonly multiple$ = this.config$.pipe(\n    map((x) => x.multiple ?? true),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n}\n\n/**\n * Content view for a DbxSelectionValueListView. It can be used directly in cases where the items are already configured, or want to be configured in a non-standard fashion.\n */\n@Component({\n  selector: 'dbx-selection-list-view-content',\n  template: `\n    <ng-container [ngSwitch]=\"selectionMode\">\n      <ng-container *ngSwitchCase=\"'view'\">\n        <dbx-list-view-content [items]=\"items\"></dbx-list-view-content>\n      </ng-container>\n      <ng-container *ngSwitchDefault>\n        <mat-selection-list [disabled]=\"disabled$ | async\" [multiple]=\"multiple\" (selectionChange)=\"matSelectionChanged($event)\">\n          <mat-list-option class=\"dbx-list-view-item\" *ngFor=\"let item of items; trackBy: trackByFunction\" [selected]=\"item.selected\" [disabled]=\"item.disabled\" [value]=\"item.itemValue\" (click)=\"onClickValue(item.itemValue)\">\n            <mat-icon matListItemIcon *ngIf=\"item.icon\">{{ item.icon }}</mat-icon>\n            <dbx-injection [config]=\"item.config\"></dbx-injection>\n          </mat-list-option>\n        </mat-selection-list>\n      </ng-container>\n    </ng-container>\n  `,\n  host: {\n    class: 'dbx-list-view dbx-selection-list-view'\n  },\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class DbxSelectionValueListViewContentComponent<T, I extends DbxValueListItem<T> = DbxValueListItem<T>> extends DbxValueListViewContentComponent<T, I> {\n  @Input()\n  multiple?: Maybe<boolean>;\n\n  @Input()\n  selectionMode: Maybe<DbxListSelectionMode>;\n\n  constructor(dbxListView: DbxListView<T>, @Optional() @Inject(DbxValueListViewGroupDelegate) inputDbxListGroupDelegate: Maybe<DbxValueListViewGroupDelegate<any, T, I>>) {\n    super(dbxListView, inputDbxListGroupDelegate);\n\n    if (!dbxListView.selectionChange) {\n      throw new Error('Parent dbxListView to DbxSelectionValueListViewComponent has no selectionChange emitter.');\n    }\n  }\n\n  matSelectionChanged(selection: MatSelectionListChange): void {\n    const options = selection.source.selectedOptions.selected;\n    const items: ListSelectionStateItem<T>[] = options.map((x) => {\n      const { value: itemValue, selected, disabled } = x;\n      return { itemValue, selected, disabled };\n    });\n\n    (this.dbxListView.selectionChange as EventEmitter<ListSelectionState<T>>).next({\n      // asserted in constructor\n      items\n    });\n  }\n}\n"]}
|