@dereekb/dbx-web 10.0.24 → 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.
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@dereekb/dbx-web/calendar",
3
- "version": "10.0.24",
3
+ "version": "10.1.0",
4
4
  "module": "fesm2022/dereekb-dbx-web-calendar.mjs",
5
5
  "typings": "index.d.ts",
6
6
  "exports": {
@@ -6,6 +6,9 @@ export * from './list.track';
6
6
  export * from './list.grid.view.directive';
7
7
  export * from './list.grid.view.component';
8
8
  export * from './list.view.directive';
9
+ export * from './list.view.value.group';
10
+ export * from './list.view.value.group.title';
11
+ export * from './list.view.value.group.title.directive';
9
12
  export * from './list.view.selection.directive';
10
13
  export * from './list.view.value.component';
11
14
  export * from './list.view.value.directive';
@@ -18,4 +21,4 @@ export * from './list.view.value.selection.component';
18
21
  export * from './list.view.value';
19
22
  export * from './list.view';
20
23
  export * from './list.wrapper';
21
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3NyYy9saWIvbGF5b3V0L2xpc3QvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxnQ0FBZ0MsQ0FBQztBQUMvQyxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsa0JBQWtCLENBQUM7QUFDakMsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLDRCQUE0QixDQUFDO0FBQzNDLGNBQWMsNEJBQTRCLENBQUM7QUFDM0MsY0FBYyx1QkFBdUIsQ0FBQztBQUN0QyxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMsNkJBQTZCLENBQUM7QUFDNUMsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLGtDQUFrQyxDQUFDO0FBQ2pELGNBQWMsNEJBQTRCLENBQUM7QUFDM0MsY0FBYyxzQ0FBc0MsQ0FBQztBQUNyRCxjQUFjLDZDQUE2QyxDQUFDO0FBQzVELGNBQWMsZ0RBQWdELENBQUM7QUFDL0QsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLG1CQUFtQixDQUFDO0FBQ2xDLGNBQWMsYUFBYSxDQUFDO0FBQzVCLGNBQWMsZ0JBQWdCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2xpc3QuY29udGVudC5lbXB0eS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saXN0LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpc3QuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vbGlzdC5sYXlvdXQubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vbGlzdC50cmFjayc7XG5leHBvcnQgKiBmcm9tICcuL2xpc3QuZ3JpZC52aWV3LmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpc3QuZ3JpZC52aWV3LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpc3Qudmlldy5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9saXN0LnZpZXcuc2VsZWN0aW9uLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpc3Qudmlldy52YWx1ZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saXN0LnZpZXcudmFsdWUuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vbGlzdC52aWV3LnZhbHVlLml0ZW0uZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vbGlzdC52aWV3LnZhbHVlLm1vZGlmaWVyJztcbmV4cG9ydCAqIGZyb20gJy4vbGlzdC52aWV3LnZhbHVlLm1vZGlmaWVyLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpc3Qudmlldy52YWx1ZS5tb2RpZmllci5yaXBwbGUuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vbGlzdC52aWV3LnZhbHVlLm1vZGlmaWVyLnNlbGVjdGlvbi5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9saXN0LnZpZXcudmFsdWUuc2VsZWN0aW9uLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpc3Qudmlldy52YWx1ZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpc3Qudmlldyc7XG5leHBvcnQgKiBmcm9tICcuL2xpc3Qud3JhcHBlcic7XG4iXX0=
24
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3NyYy9saWIvbGF5b3V0L2xpc3QvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxnQ0FBZ0MsQ0FBQztBQUMvQyxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsa0JBQWtCLENBQUM7QUFDakMsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLDRCQUE0QixDQUFDO0FBQzNDLGNBQWMsNEJBQTRCLENBQUM7QUFDM0MsY0FBYyx1QkFBdUIsQ0FBQztBQUN0QyxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYyx5Q0FBeUMsQ0FBQztBQUN4RCxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMsNkJBQTZCLENBQUM7QUFDNUMsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLGtDQUFrQyxDQUFDO0FBQ2pELGNBQWMsNEJBQTRCLENBQUM7QUFDM0MsY0FBYyxzQ0FBc0MsQ0FBQztBQUNyRCxjQUFjLDZDQUE2QyxDQUFDO0FBQzVELGNBQWMsZ0RBQWdELENBQUM7QUFDL0QsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLG1CQUFtQixDQUFDO0FBQ2xDLGNBQWMsYUFBYSxDQUFDO0FBQzVCLGNBQWMsZ0JBQWdCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2xpc3QuY29udGVudC5lbXB0eS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saXN0LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpc3QuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vbGlzdC5sYXlvdXQubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vbGlzdC50cmFjayc7XG5leHBvcnQgKiBmcm9tICcuL2xpc3QuZ3JpZC52aWV3LmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpc3QuZ3JpZC52aWV3LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpc3Qudmlldy5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9saXN0LnZpZXcudmFsdWUuZ3JvdXAnO1xuZXhwb3J0ICogZnJvbSAnLi9saXN0LnZpZXcudmFsdWUuZ3JvdXAudGl0bGUnO1xuZXhwb3J0ICogZnJvbSAnLi9saXN0LnZpZXcudmFsdWUuZ3JvdXAudGl0bGUuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vbGlzdC52aWV3LnNlbGVjdGlvbi5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9saXN0LnZpZXcudmFsdWUuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGlzdC52aWV3LnZhbHVlLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpc3Qudmlldy52YWx1ZS5pdGVtLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpc3Qudmlldy52YWx1ZS5tb2RpZmllcic7XG5leHBvcnQgKiBmcm9tICcuL2xpc3Qudmlldy52YWx1ZS5tb2RpZmllci5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9saXN0LnZpZXcudmFsdWUubW9kaWZpZXIucmlwcGxlLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpc3Qudmlldy52YWx1ZS5tb2RpZmllci5zZWxlY3Rpb24uZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vbGlzdC52aWV3LnZhbHVlLnNlbGVjdGlvbi5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saXN0LnZpZXcudmFsdWUnO1xuZXhwb3J0ICogZnJvbSAnLi9saXN0LnZpZXcnO1xuZXhwb3J0ICogZnJvbSAnLi9saXN0LndyYXBwZXInO1xuIl19
@@ -1,8 +1,8 @@
1
- import { Component, Directive, Input, Optional } from '@angular/core';
1
+ import { ChangeDetectionStrategy, Component, Directive, Input, Optional } from '@angular/core';
2
2
  import { shareReplay, map, BehaviorSubject, combineLatest, of } from 'rxjs';
3
3
  import { AbstractDbxValueListViewDirective } from './list.view.value.directive';
4
4
  import { mergeObjects } from '@dereekb/util';
5
- import { DbxValueListItemViewComponent } from './list.view.value.component';
5
+ import { DbxValueListViewContentComponent } from './list.view.value.component';
6
6
  import { DbxListView } from './list.view';
7
7
  import * as i0 from "@angular/core";
8
8
  import * as i1 from "@angular/common";
@@ -23,7 +23,7 @@ export class DbxValueListGridViewComponent extends AbstractDbxValueListViewDirec
23
23
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DbxValueListGridViewComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
24
24
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DbxValueListGridViewComponent, selector: "dbx-list-grid-view", usesInheritance: true, ngImport: i0, template: `
25
25
  <dbx-list-grid-view-content [grid]="grid$ | async" [items]="items$ | async" [emitAllClicks]="emitAllClicks$ | async"></dbx-list-grid-view-content>
26
- `, isInline: true, dependencies: [{ kind: "component", type: i0.forwardRef(function () { return DbxValueListGridItemViewComponent; }), selector: "dbx-list-grid-view-content", inputs: ["grid"] }, { kind: "pipe", type: i0.forwardRef(function () { return i1.AsyncPipe; }), name: "async" }] }); }
26
+ `, isInline: true, dependencies: [{ kind: "component", type: i0.forwardRef(function () { return DbxValueListGridViewContentComponent; }), selector: "dbx-list-grid-view-content", inputs: ["grid"] }, { kind: "pipe", type: i0.forwardRef(function () { return i1.AsyncPipe; }), name: "async" }] }); }
27
27
  }
28
28
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DbxValueListGridViewComponent, decorators: [{
29
29
  type: Component,
@@ -72,9 +72,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
72
72
  /**
73
73
  * Content view for a DbxValueListGridView. It can be used directly in cases where the items are already configured, or want to be configured in a non-standard fashion.
74
74
  */
75
- export class DbxValueListGridItemViewComponent extends DbxValueListItemViewComponent {
75
+ export class DbxValueListGridViewContentComponent extends DbxValueListViewContentComponent {
76
76
  constructor(dbxListView, _gridSizeOverride) {
77
- super(dbxListView);
77
+ super(dbxListView, undefined);
78
78
  this._gridSizeOverride = _gridSizeOverride;
79
79
  this._defaultGrid = new BehaviorSubject(undefined);
80
80
  this.grid$ = combineLatest([this._defaultGrid, this._gridSizeOverride?.gridSize$ ?? of(undefined)]).pipe(map(([defaultGrid, overrideGrid]) => {
@@ -88,18 +88,19 @@ export class DbxValueListGridItemViewComponent extends DbxValueListItemViewCompo
88
88
  this._defaultGrid.next(grid);
89
89
  }
90
90
  ngOnDestroy() {
91
+ super.ngOnDestroy();
91
92
  this._defaultGrid.complete();
92
93
  }
93
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DbxValueListGridItemViewComponent, deps: [{ token: i2.DbxListView }, { token: DbxValueListGridSizeDirective, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
94
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DbxValueListGridItemViewComponent, selector: "dbx-list-grid-view-content", inputs: { grid: "grid" }, host: { classAttribute: "dbx-list-grid-view" }, usesInheritance: true, ngImport: i0, template: `
94
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DbxValueListGridViewContentComponent, deps: [{ token: i2.DbxListView }, { token: DbxValueListGridSizeDirective, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
95
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DbxValueListGridViewContentComponent, selector: "dbx-list-grid-view-content", inputs: { grid: "grid" }, host: { classAttribute: "dbx-list-grid-view" }, usesInheritance: true, ngImport: i0, template: `
95
96
  <div [gdGap]="gap$ | async" [gdColumns]="columns$ | async">
96
97
  <dbx-anchor *ngFor="let item of items; trackBy: trackByFunction" matRipple [matRippleDisabled]="rippleDisabledOnItem(item)" class="dbx-list-grid-view-item" [anchor]="item.anchor" [disabled]="item.disabled" (click)="onClickItem(item)">
97
98
  <div dbx-injection [config]="item.config"></div>
98
99
  </dbx-anchor>
99
100
  </div>
100
- `, isInline: true, dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.MatRipple, selector: "[mat-ripple], [matRipple]", inputs: ["matRippleColor", "matRippleUnbounded", "matRippleCentered", "matRippleRadius", "matRippleAnimation", "matRippleDisabled", "matRippleTrigger"], exportAs: ["matRipple"] }, { kind: "directive", type: i4.DefaultGridColumnsDirective, selector: " [gdColumns], [gdColumns.xs], [gdColumns.sm], [gdColumns.md], [gdColumns.lg], [gdColumns.xl], [gdColumns.lt-sm], [gdColumns.lt-md], [gdColumns.lt-lg], [gdColumns.lt-xl], [gdColumns.gt-xs], [gdColumns.gt-sm], [gdColumns.gt-md], [gdColumns.gt-lg]", inputs: ["gdColumns", "gdColumns.xs", "gdColumns.sm", "gdColumns.md", "gdColumns.lg", "gdColumns.xl", "gdColumns.lt-sm", "gdColumns.lt-md", "gdColumns.lt-lg", "gdColumns.lt-xl", "gdColumns.gt-xs", "gdColumns.gt-sm", "gdColumns.gt-md", "gdColumns.gt-lg"] }, { kind: "directive", type: i4.DefaultGridGapDirective, selector: " [gdGap], [gdGap.xs], [gdGap.sm], [gdGap.md], [gdGap.lg], [gdGap.xl], [gdGap.lt-sm], [gdGap.lt-md], [gdGap.lt-lg], [gdGap.lt-xl], [gdGap.gt-xs], [gdGap.gt-sm], [gdGap.gt-md], [gdGap.gt-lg]", inputs: ["gdGap", "gdGap.xs", "gdGap.sm", "gdGap.md", "gdGap.lg", "gdGap.xl", "gdGap.lt-sm", "gdGap.lt-md", "gdGap.lt-lg", "gdGap.lt-xl", "gdGap.gt-xs", "gdGap.gt-sm", "gdGap.gt-md", "gdGap.gt-lg"] }, { kind: "component", type: i5.DbxAnchorComponent, selector: "dbx-anchor, [dbx-anchor]", inputs: ["block"] }, { kind: "component", type: i6.DbxInjectionComponent, selector: "dbx-injection, [dbxInjection], [dbx-injection]", inputs: ["config", "template"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }] }); }
101
+ `, isInline: true, dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.MatRipple, selector: "[mat-ripple], [matRipple]", inputs: ["matRippleColor", "matRippleUnbounded", "matRippleCentered", "matRippleRadius", "matRippleAnimation", "matRippleDisabled", "matRippleTrigger"], exportAs: ["matRipple"] }, { kind: "directive", type: i4.DefaultGridColumnsDirective, selector: " [gdColumns], [gdColumns.xs], [gdColumns.sm], [gdColumns.md], [gdColumns.lg], [gdColumns.xl], [gdColumns.lt-sm], [gdColumns.lt-md], [gdColumns.lt-lg], [gdColumns.lt-xl], [gdColumns.gt-xs], [gdColumns.gt-sm], [gdColumns.gt-md], [gdColumns.gt-lg]", inputs: ["gdColumns", "gdColumns.xs", "gdColumns.sm", "gdColumns.md", "gdColumns.lg", "gdColumns.xl", "gdColumns.lt-sm", "gdColumns.lt-md", "gdColumns.lt-lg", "gdColumns.lt-xl", "gdColumns.gt-xs", "gdColumns.gt-sm", "gdColumns.gt-md", "gdColumns.gt-lg"] }, { kind: "directive", type: i4.DefaultGridGapDirective, selector: " [gdGap], [gdGap.xs], [gdGap.sm], [gdGap.md], [gdGap.lg], [gdGap.xl], [gdGap.lt-sm], [gdGap.lt-md], [gdGap.lt-lg], [gdGap.lt-xl], [gdGap.gt-xs], [gdGap.gt-sm], [gdGap.gt-md], [gdGap.gt-lg]", inputs: ["gdGap", "gdGap.xs", "gdGap.sm", "gdGap.md", "gdGap.lg", "gdGap.xl", "gdGap.lt-sm", "gdGap.lt-md", "gdGap.lt-lg", "gdGap.lt-xl", "gdGap.gt-xs", "gdGap.gt-sm", "gdGap.gt-md", "gdGap.gt-lg"] }, { kind: "component", type: i5.DbxAnchorComponent, selector: "dbx-anchor, [dbx-anchor]", inputs: ["block"] }, { kind: "component", type: i6.DbxInjectionComponent, selector: "dbx-injection, [dbxInjection], [dbx-injection]", inputs: ["config", "template"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
101
102
  }
102
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DbxValueListGridItemViewComponent, decorators: [{
103
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DbxValueListGridViewContentComponent, decorators: [{
103
104
  type: Component,
104
105
  args: [{
105
106
  selector: 'dbx-list-grid-view-content',
@@ -112,11 +113,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
112
113
  `,
113
114
  host: {
114
115
  class: 'dbx-list-grid-view'
115
- }
116
+ },
117
+ changeDetection: ChangeDetectionStrategy.OnPush
116
118
  }]
117
119
  }], ctorParameters: function () { return [{ type: i2.DbxListView }, { type: DbxValueListGridSizeDirective, decorators: [{
118
120
  type: Optional
119
121
  }] }]; }, propDecorators: { grid: [{
120
122
  type: Input
121
123
  }] } });
122
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list.grid.view.component.js","sourceRoot":"","sources":["../../../../../../../packages/dbx-web/src/lib/layout/list/list.grid.view.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Directive, Input, OnDestroy, Optional } from '@angular/core';\nimport { shareReplay, map, BehaviorSubject, combineLatest, of, Observable } from 'rxjs';\nimport { DbxValueListItem } from './list.view.value';\nimport { AbstractDbxValueListViewDirective } from './list.view.value.directive';\nimport { Maybe, mergeObjects } from '@dereekb/util';\nimport { DbxValueListItemViewComponent, DbxValueListViewConfig } from './list.view.value.component';\nimport { DbxListView } from './list.view';\n\nexport interface DbxValueListGridViewConfig<T, I extends DbxValueListItem<T> = DbxValueListItem<T>, V = unknown> extends DbxValueListViewConfig<T, I, V> {\n  grid?: Maybe<Partial<DbxValueListGridItemViewGridSizeConfig>>;\n}\n\n/**\n * Renders a grid view using input configuration. Requires a parent DbxListView.\n */\n@Component({\n  selector: 'dbx-list-grid-view',\n  template: `\n    <dbx-list-grid-view-content [grid]=\"grid$ | async\" [items]=\"items$ | async\" [emitAllClicks]=\"emitAllClicks$ | async\"></dbx-list-grid-view-content>\n  `\n})\nexport class DbxValueListGridViewComponent<T, I extends DbxValueListItem<T> = DbxValueListItem<T>, V = unknown, C extends DbxValueListGridViewConfig<T, I, V> = DbxValueListGridViewConfig<T, I, V>> extends AbstractDbxValueListViewDirective<T, I, V, C> {\n  readonly grid$ = this.config$.pipe(map((x) => x.grid));\n  readonly emitAllClicks$ = this.config$.pipe(\n    map((x) => x.emitAllClicks),\n    shareReplay(1)\n  );\n}\n\nexport interface DbxValueListGridItemViewGridSizeConfig {\n  /**\n   * Gap size in %, px, vw, vh\n   */\n  gap: string;\n  /**\n   * Columns configuration.\n   *\n   * Example: repeat(auto-fill, minmax(200px, 1fr))\n   */\n  columns: string;\n}\n\nexport const DEFAULT_LIST_GRID_SIZE_CONFIG: DbxValueListGridItemViewGridSizeConfig = {\n  columns: 'repeat(auto-fill, minmax(320px, 1fr))',\n  gap: '8px'\n};\n\n/**\n * Optional parent directive used to control grid size.\n */\n@Directive({\n  selector: '[dbxListGridSize]'\n})\nexport class DbxValueListGridSizeDirective implements OnDestroy {\n  private _gridSize = new BehaviorSubject<Maybe<Partial<DbxValueListGridItemViewGridSizeConfig>>>(undefined);\n\n  readonly gridSize$ = this._gridSize.asObservable();\n\n  @Input('dbxListGridSize')\n  get gridSize(): Maybe<Partial<DbxValueListGridItemViewGridSizeConfig>> {\n    return this._gridSize.value;\n  }\n\n  set gridSize(gridSize: Maybe<Partial<DbxValueListGridItemViewGridSizeConfig>>) {\n    if (gridSize) {\n      this._gridSize.next(gridSize);\n    }\n  }\n\n  ngOnDestroy(): void {\n    this._gridSize.complete();\n  }\n}\n\n/**\n * Content view for a DbxValueListGridView. 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-grid-view-content',\n  template: `\n    <div [gdGap]=\"gap$ | async\" [gdColumns]=\"columns$ | async\">\n      <dbx-anchor *ngFor=\"let item of items; trackBy: trackByFunction\" matRipple [matRippleDisabled]=\"rippleDisabledOnItem(item)\" class=\"dbx-list-grid-view-item\" [anchor]=\"item.anchor\" [disabled]=\"item.disabled\" (click)=\"onClickItem(item)\">\n        <div dbx-injection [config]=\"item.config\"></div>\n      </dbx-anchor>\n    </div>\n  `,\n  host: {\n    class: 'dbx-list-grid-view'\n  }\n})\nexport class DbxValueListGridItemViewComponent<T, I extends DbxValueListItem<T> = DbxValueListItem<T>> extends DbxValueListItemViewComponent<T, I> implements OnDestroy {\n  private _defaultGrid = new BehaviorSubject<Maybe<Partial<DbxValueListGridItemViewGridSizeConfig>>>(undefined);\n\n  readonly grid$: Observable<DbxValueListGridItemViewGridSizeConfig> = combineLatest([this._defaultGrid, this._gridSizeOverride?.gridSize$ ?? of(undefined)]).pipe(\n    map(([defaultGrid, overrideGrid]) => {\n      const grid = mergeObjects<DbxValueListGridItemViewGridSizeConfig>([DEFAULT_LIST_GRID_SIZE_CONFIG, defaultGrid, overrideGrid]);\n      return grid as DbxValueListGridItemViewGridSizeConfig;\n    }),\n    shareReplay(1)\n  );\n\n  readonly gap$ = this.grid$.pipe(map((x) => x.gap));\n  readonly columns$ = this.grid$.pipe(map((x) => x.columns));\n\n  constructor(dbxListView: DbxListView<T>, @Optional() private _gridSizeOverride?: DbxValueListGridSizeDirective) {\n    super(dbxListView);\n  }\n\n  @Input()\n  set grid(grid: Maybe<Partial<DbxValueListGridItemViewGridSizeConfig>>) {\n    this._defaultGrid.next(grid);\n  }\n\n  ngOnDestroy(): void {\n    this._defaultGrid.complete();\n  }\n}\n"]}
124
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list.grid.view.component.js","sourceRoot":"","sources":["../../../../../../../packages/dbx-web/src/lib/layout/list/list.grid.view.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, Directive, Input, OnDestroy, Optional } from '@angular/core';\nimport { shareReplay, map, BehaviorSubject, combineLatest, of, Observable } from 'rxjs';\nimport { DbxValueListItem } from './list.view.value';\nimport { AbstractDbxValueListViewDirective } from './list.view.value.directive';\nimport { Maybe, mergeObjects } from '@dereekb/util';\nimport { DbxValueListViewContentComponent, DbxValueListViewConfig } from './list.view.value.component';\nimport { DbxListView } from './list.view';\n\nexport interface DbxValueListGridViewConfig<T, I extends DbxValueListItem<T> = DbxValueListItem<T>, V = unknown> extends DbxValueListViewConfig<T, I, V> {\n  grid?: Maybe<Partial<DbxValueListGridItemViewGridSizeConfig>>;\n}\n\n/**\n * Renders a grid view using input configuration. Requires a parent DbxListView.\n */\n@Component({\n  selector: 'dbx-list-grid-view',\n  template: `\n    <dbx-list-grid-view-content [grid]=\"grid$ | async\" [items]=\"items$ | async\" [emitAllClicks]=\"emitAllClicks$ | async\"></dbx-list-grid-view-content>\n  `\n})\nexport class DbxValueListGridViewComponent<T, I extends DbxValueListItem<T> = DbxValueListItem<T>, V = unknown, C extends DbxValueListGridViewConfig<T, I, V> = DbxValueListGridViewConfig<T, I, V>> extends AbstractDbxValueListViewDirective<T, I, V, C> {\n  readonly grid$ = this.config$.pipe(map((x) => x.grid));\n  readonly emitAllClicks$ = this.config$.pipe(\n    map((x) => x.emitAllClicks),\n    shareReplay(1)\n  );\n}\n\nexport interface DbxValueListGridItemViewGridSizeConfig {\n  /**\n   * Gap size in %, px, vw, vh\n   */\n  gap: string;\n  /**\n   * Columns configuration.\n   *\n   * Example: repeat(auto-fill, minmax(200px, 1fr))\n   */\n  columns: string;\n}\n\nexport const DEFAULT_LIST_GRID_SIZE_CONFIG: DbxValueListGridItemViewGridSizeConfig = {\n  columns: 'repeat(auto-fill, minmax(320px, 1fr))',\n  gap: '8px'\n};\n\n/**\n * Optional parent directive used to control grid size.\n */\n@Directive({\n  selector: '[dbxListGridSize]'\n})\nexport class DbxValueListGridSizeDirective implements OnDestroy {\n  private _gridSize = new BehaviorSubject<Maybe<Partial<DbxValueListGridItemViewGridSizeConfig>>>(undefined);\n\n  readonly gridSize$ = this._gridSize.asObservable();\n\n  @Input('dbxListGridSize')\n  get gridSize(): Maybe<Partial<DbxValueListGridItemViewGridSizeConfig>> {\n    return this._gridSize.value;\n  }\n\n  set gridSize(gridSize: Maybe<Partial<DbxValueListGridItemViewGridSizeConfig>>) {\n    if (gridSize) {\n      this._gridSize.next(gridSize);\n    }\n  }\n\n  ngOnDestroy(): void {\n    this._gridSize.complete();\n  }\n}\n\n/**\n * Content view for a DbxValueListGridView. 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-grid-view-content',\n  template: `\n    <div [gdGap]=\"gap$ | async\" [gdColumns]=\"columns$ | async\">\n      <dbx-anchor *ngFor=\"let item of items; trackBy: trackByFunction\" matRipple [matRippleDisabled]=\"rippleDisabledOnItem(item)\" class=\"dbx-list-grid-view-item\" [anchor]=\"item.anchor\" [disabled]=\"item.disabled\" (click)=\"onClickItem(item)\">\n        <div dbx-injection [config]=\"item.config\"></div>\n      </dbx-anchor>\n    </div>\n  `,\n  host: {\n    class: 'dbx-list-grid-view'\n  },\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class DbxValueListGridViewContentComponent<T, I extends DbxValueListItem<T> = DbxValueListItem<T>> extends DbxValueListViewContentComponent<T, I> implements OnDestroy {\n  private _defaultGrid = new BehaviorSubject<Maybe<Partial<DbxValueListGridItemViewGridSizeConfig>>>(undefined);\n\n  readonly grid$: Observable<DbxValueListGridItemViewGridSizeConfig> = combineLatest([this._defaultGrid, this._gridSizeOverride?.gridSize$ ?? of(undefined)]).pipe(\n    map(([defaultGrid, overrideGrid]) => {\n      const grid = mergeObjects<DbxValueListGridItemViewGridSizeConfig>([DEFAULT_LIST_GRID_SIZE_CONFIG, defaultGrid, overrideGrid]);\n      return grid as DbxValueListGridItemViewGridSizeConfig;\n    }),\n    shareReplay(1)\n  );\n\n  readonly gap$ = this.grid$.pipe(map((x) => x.gap));\n  readonly columns$ = this.grid$.pipe(map((x) => x.columns));\n\n  constructor(dbxListView: DbxListView<T>, @Optional() private _gridSizeOverride?: DbxValueListGridSizeDirective) {\n    super(dbxListView, undefined);\n  }\n\n  @Input()\n  set grid(grid: Maybe<Partial<DbxValueListGridItemViewGridSizeConfig>>) {\n    this._defaultGrid.next(grid);\n  }\n\n  override ngOnDestroy(): void {\n    super.ngOnDestroy();\n    this._defaultGrid.complete();\n  }\n}\n"]}
@@ -9,41 +9,66 @@ import { DbxInjectionComponentModule } from '@dereekb/dbx-core';
9
9
  import { DbxListComponent, DbxListInternalContentDirective } from './list.component';
10
10
  import { DbxListEmptyContentComponent } from './list.content.empty.component';
11
11
  import { InfiniteScrollModule } from 'ngx-infinite-scroll';
12
- import { DbxSelectionValueListItemViewComponent, DbxSelectionValueListViewComponent } from './list.view.value.selection.component';
13
- import { DbxValueListItemViewComponent, DbxValueListViewComponent } from './list.view.value.component';
12
+ import { DbxSelectionValueListViewContentComponent, DbxSelectionValueListViewComponent } from './list.view.value.selection.component';
13
+ import { DbxValueListViewContentComponent, DbxValueListViewComponent, DbxValueListViewContentGroupComponent } from './list.view.value.component';
14
14
  import { DbxValueListItemModifierDirective } from './list.view.value.modifier.directive';
15
15
  import { DbxListItemDisableRippleModifierDirective } from './list.view.value.modifier.ripple.directive';
16
- import { DbxValueListGridItemViewComponent, DbxValueListGridSizeDirective, DbxValueListGridViewComponent } from './list.grid.view.component';
16
+ import { DbxValueListGridViewContentComponent, DbxValueListGridSizeDirective, DbxValueListGridViewComponent } from './list.grid.view.component';
17
17
  import { FlexLayoutModule } from '@ngbracket/ngx-layout';
18
18
  import { DbxListItemIsSelectedModifierDirective } from './list.view.value.modifier.selection.directive';
19
+ import { DbxListTitleGroupDirective, DbxListTitleGroupHeaderComponent } from './list.view.value.group.title.directive';
19
20
  import * as i0 from "@angular/core";
21
+ const privateDeclarations = [DbxListInternalContentDirective];
22
+ const declarations = [
23
+ // directives
24
+ DbxListComponent,
25
+ DbxListEmptyContentComponent,
26
+ DbxValueListViewComponent,
27
+ DbxValueListViewContentComponent,
28
+ DbxValueListViewContentGroupComponent,
29
+ DbxValueListGridSizeDirective,
30
+ DbxValueListGridViewComponent,
31
+ DbxValueListGridViewContentComponent,
32
+ DbxListTitleGroupDirective,
33
+ DbxListTitleGroupHeaderComponent,
34
+ DbxSelectionValueListViewComponent,
35
+ DbxSelectionValueListViewContentComponent,
36
+ DbxValueListItemModifierDirective,
37
+ DbxListItemDisableRippleModifierDirective,
38
+ DbxListItemIsSelectedModifierDirective
39
+ ];
20
40
  export class DbxListLayoutModule {
21
41
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DbxListLayoutModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
22
42
  static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: DbxListLayoutModule, declarations: [
23
- //
43
+ // directives
24
44
  DbxListComponent,
25
- DbxListInternalContentDirective,
26
45
  DbxListEmptyContentComponent,
27
46
  DbxValueListViewComponent,
28
- DbxValueListItemViewComponent,
47
+ DbxValueListViewContentComponent,
48
+ DbxValueListViewContentGroupComponent,
29
49
  DbxValueListGridSizeDirective,
30
50
  DbxValueListGridViewComponent,
31
- DbxValueListGridItemViewComponent,
51
+ DbxValueListGridViewContentComponent,
52
+ DbxListTitleGroupDirective,
53
+ DbxListTitleGroupHeaderComponent,
32
54
  DbxSelectionValueListViewComponent,
33
- DbxSelectionValueListItemViewComponent,
55
+ DbxSelectionValueListViewContentComponent,
34
56
  DbxValueListItemModifierDirective,
35
57
  DbxListItemDisableRippleModifierDirective,
36
- DbxListItemIsSelectedModifierDirective], imports: [CommonModule, MatRippleModule, FlexLayoutModule, DbxLoadingModule, DbxRouterAnchorModule, InfiniteScrollModule, DbxInjectionComponentModule, MatListModule, MatIconModule], exports: [
37
- //
58
+ DbxListItemIsSelectedModifierDirective, DbxListInternalContentDirective], imports: [CommonModule, MatRippleModule, FlexLayoutModule, DbxLoadingModule, DbxRouterAnchorModule, InfiniteScrollModule, DbxInjectionComponentModule, MatListModule, MatIconModule], exports: [
59
+ // directives
38
60
  DbxListComponent,
39
61
  DbxListEmptyContentComponent,
40
62
  DbxValueListViewComponent,
41
- DbxValueListItemViewComponent,
63
+ DbxValueListViewContentComponent,
64
+ DbxValueListViewContentGroupComponent,
42
65
  DbxValueListGridSizeDirective,
43
66
  DbxValueListGridViewComponent,
44
- DbxValueListGridItemViewComponent,
67
+ DbxValueListGridViewContentComponent,
68
+ DbxListTitleGroupDirective,
69
+ DbxListTitleGroupHeaderComponent,
45
70
  DbxSelectionValueListViewComponent,
46
- DbxSelectionValueListItemViewComponent,
71
+ DbxSelectionValueListViewContentComponent,
47
72
  DbxValueListItemModifierDirective,
48
73
  DbxListItemDisableRippleModifierDirective,
49
74
  DbxListItemIsSelectedModifierDirective] }); }
@@ -53,37 +78,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
53
78
  type: NgModule,
54
79
  args: [{
55
80
  imports: [CommonModule, MatRippleModule, FlexLayoutModule, DbxLoadingModule, DbxRouterAnchorModule, InfiniteScrollModule, DbxInjectionComponentModule, MatListModule, MatIconModule],
56
- declarations: [
57
- //
58
- DbxListComponent,
59
- DbxListInternalContentDirective,
60
- DbxListEmptyContentComponent,
61
- DbxValueListViewComponent,
62
- DbxValueListItemViewComponent,
63
- DbxValueListGridSizeDirective,
64
- DbxValueListGridViewComponent,
65
- DbxValueListGridItemViewComponent,
66
- DbxSelectionValueListViewComponent,
67
- DbxSelectionValueListItemViewComponent,
68
- DbxValueListItemModifierDirective,
69
- DbxListItemDisableRippleModifierDirective,
70
- DbxListItemIsSelectedModifierDirective
71
- ],
72
- exports: [
73
- //
74
- DbxListComponent,
75
- DbxListEmptyContentComponent,
76
- DbxValueListViewComponent,
77
- DbxValueListItemViewComponent,
78
- DbxValueListGridSizeDirective,
79
- DbxValueListGridViewComponent,
80
- DbxValueListGridItemViewComponent,
81
- DbxSelectionValueListViewComponent,
82
- DbxSelectionValueListItemViewComponent,
83
- DbxValueListItemModifierDirective,
84
- DbxListItemDisableRippleModifierDirective,
85
- DbxListItemIsSelectedModifierDirective
86
- ]
81
+ declarations: [...declarations, ...privateDeclarations],
82
+ exports: declarations
87
83
  }]
88
84
  }] });
89
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlzdC5sYXlvdXQubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LXdlYi9zcmMvbGliL2xheW91dC9saXN0L2xpc3QubGF5b3V0Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDekQsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sMENBQTBDLENBQUM7QUFDakYsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDaEUsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN2RCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsMkJBQTJCLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUNoRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsK0JBQStCLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUNyRixPQUFPLEVBQUUsNEJBQTRCLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUM5RSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsc0NBQXNDLEVBQUUsa0NBQWtDLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQztBQUNuSSxPQUFPLEVBQUUsNkJBQTZCLEVBQUUseUJBQXlCLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQUN2RyxPQUFPLEVBQUUsaUNBQWlDLEVBQUUsTUFBTSxzQ0FBc0MsQ0FBQztBQUN6RixPQUFPLEVBQUUseUNBQXlDLEVBQUUsTUFBTSw2Q0FBNkMsQ0FBQztBQUN4RyxPQUFPLEVBQUUsaUNBQWlDLEVBQUUsNkJBQTZCLEVBQUUsNkJBQTZCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUM3SSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsc0NBQXNDLEVBQUUsTUFBTSxnREFBZ0QsQ0FBQzs7QUFvQ3hHLE1BQU0sT0FBTyxtQkFBbUI7K0dBQW5CLG1CQUFtQjtnSEFBbkIsbUJBQW1CO1lBL0I1QixFQUFFO1lBQ0YsZ0JBQWdCO1lBQ2hCLCtCQUErQjtZQUMvQiw0QkFBNEI7WUFDNUIseUJBQXlCO1lBQ3pCLDZCQUE2QjtZQUM3Qiw2QkFBNkI7WUFDN0IsNkJBQTZCO1lBQzdCLGlDQUFpQztZQUNqQyxrQ0FBa0M7WUFDbEMsc0NBQXNDO1lBQ3RDLGlDQUFpQztZQUNqQyx5Q0FBeUM7WUFDekMsc0NBQXNDLGFBZjlCLFlBQVksRUFBRSxlQUFlLEVBQUUsZ0JBQWdCLEVBQUUsZ0JBQWdCLEVBQUUscUJBQXFCLEVBQUUsb0JBQW9CLEVBQUUsMkJBQTJCLEVBQUUsYUFBYSxFQUFFLGFBQWE7WUFrQmpMLEVBQUU7WUFDRixnQkFBZ0I7WUFDaEIsNEJBQTRCO1lBQzVCLHlCQUF5QjtZQUN6Qiw2QkFBNkI7WUFDN0IsNkJBQTZCO1lBQzdCLDZCQUE2QjtZQUM3QixpQ0FBaUM7WUFDakMsa0NBQWtDO1lBQ2xDLHNDQUFzQztZQUN0QyxpQ0FBaUM7WUFDakMseUNBQXlDO1lBQ3pDLHNDQUFzQztnSEFHN0IsbUJBQW1CLFlBakNwQixZQUFZLEVBQUUsZUFBZSxFQUFFLGdCQUFnQixFQUFFLGdCQUFnQixFQUFFLHFCQUFxQixFQUFFLG9CQUFvQixFQUFFLDJCQUEyQixFQUFFLGFBQWEsRUFBRSxhQUFhOzs0RkFpQ3hLLG1CQUFtQjtrQkFsQy9CLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFLENBQUMsWUFBWSxFQUFFLGVBQWUsRUFBRSxnQkFBZ0IsRUFBRSxnQkFBZ0IsRUFBRSxxQkFBcUIsRUFBRSxvQkFBb0IsRUFBRSwyQkFBMkIsRUFBRSxhQUFhLEVBQUUsYUFBYSxDQUFDO29CQUNwTCxZQUFZLEVBQUU7d0JBQ1osRUFBRTt3QkFDRixnQkFBZ0I7d0JBQ2hCLCtCQUErQjt3QkFDL0IsNEJBQTRCO3dCQUM1Qix5QkFBeUI7d0JBQ3pCLDZCQUE2Qjt3QkFDN0IsNkJBQTZCO3dCQUM3Qiw2QkFBNkI7d0JBQzdCLGlDQUFpQzt3QkFDakMsa0NBQWtDO3dCQUNsQyxzQ0FBc0M7d0JBQ3RDLGlDQUFpQzt3QkFDakMseUNBQXlDO3dCQUN6QyxzQ0FBc0M7cUJBQ3ZDO29CQUNELE9BQU8sRUFBRTt3QkFDUCxFQUFFO3dCQUNGLGdCQUFnQjt3QkFDaEIsNEJBQTRCO3dCQUM1Qix5QkFBeUI7d0JBQ3pCLDZCQUE2Qjt3QkFDN0IsNkJBQTZCO3dCQUM3Qiw2QkFBNkI7d0JBQzdCLGlDQUFpQzt3QkFDakMsa0NBQWtDO3dCQUNsQyxzQ0FBc0M7d0JBQ3RDLGlDQUFpQzt3QkFDakMseUNBQXlDO3dCQUN6QyxzQ0FBc0M7cUJBQ3ZDO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTWF0UmlwcGxlTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvY29yZSc7XG5pbXBvcnQgeyBEYnhSb3V0ZXJBbmNob3JNb2R1bGUgfSBmcm9tICcuLi8uLi9yb3V0ZXIvbGF5b3V0L2FuY2hvci9hbmNob3IubW9kdWxlJztcbmltcG9ydCB7IERieExvYWRpbmdNb2R1bGUgfSBmcm9tICcuLi8uLi9sb2FkaW5nL2xvYWRpbmcubW9kdWxlJztcbmltcG9ydCB7IE1hdEljb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pY29uJztcbmltcG9ydCB7IE1hdExpc3RNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9saXN0JztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRGJ4SW5qZWN0aW9uQ29tcG9uZW50TW9kdWxlIH0gZnJvbSAnQGRlcmVla2IvZGJ4LWNvcmUnO1xuaW1wb3J0IHsgRGJ4TGlzdENvbXBvbmVudCwgRGJ4TGlzdEludGVybmFsQ29udGVudERpcmVjdGl2ZSB9IGZyb20gJy4vbGlzdC5jb21wb25lbnQnO1xuaW1wb3J0IHsgRGJ4TGlzdEVtcHR5Q29udGVudENvbXBvbmVudCB9IGZyb20gJy4vbGlzdC5jb250ZW50LmVtcHR5LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBJbmZpbml0ZVNjcm9sbE1vZHVsZSB9IGZyb20gJ25neC1pbmZpbml0ZS1zY3JvbGwnO1xuaW1wb3J0IHsgRGJ4U2VsZWN0aW9uVmFsdWVMaXN0SXRlbVZpZXdDb21wb25lbnQsIERieFNlbGVjdGlvblZhbHVlTGlzdFZpZXdDb21wb25lbnQgfSBmcm9tICcuL2xpc3Qudmlldy52YWx1ZS5zZWxlY3Rpb24uY29tcG9uZW50JztcbmltcG9ydCB7IERieFZhbHVlTGlzdEl0ZW1WaWV3Q29tcG9uZW50LCBEYnhWYWx1ZUxpc3RWaWV3Q29tcG9uZW50IH0gZnJvbSAnLi9saXN0LnZpZXcudmFsdWUuY29tcG9uZW50JztcbmltcG9ydCB7IERieFZhbHVlTGlzdEl0ZW1Nb2RpZmllckRpcmVjdGl2ZSB9IGZyb20gJy4vbGlzdC52aWV3LnZhbHVlLm1vZGlmaWVyLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBEYnhMaXN0SXRlbURpc2FibGVSaXBwbGVNb2RpZmllckRpcmVjdGl2ZSB9IGZyb20gJy4vbGlzdC52aWV3LnZhbHVlLm1vZGlmaWVyLnJpcHBsZS5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgRGJ4VmFsdWVMaXN0R3JpZEl0ZW1WaWV3Q29tcG9uZW50LCBEYnhWYWx1ZUxpc3RHcmlkU2l6ZURpcmVjdGl2ZSwgRGJ4VmFsdWVMaXN0R3JpZFZpZXdDb21wb25lbnQgfSBmcm9tICcuL2xpc3QuZ3JpZC52aWV3LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBGbGV4TGF5b3V0TW9kdWxlIH0gZnJvbSAnQG5nYnJhY2tldC9uZ3gtbGF5b3V0JztcbmltcG9ydCB7IERieExpc3RJdGVtSXNTZWxlY3RlZE1vZGlmaWVyRGlyZWN0aXZlIH0gZnJvbSAnLi9saXN0LnZpZXcudmFsdWUubW9kaWZpZXIuc2VsZWN0aW9uLmRpcmVjdGl2ZSc7XG5cbkBOZ01vZHVsZSh7XG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIE1hdFJpcHBsZU1vZHVsZSwgRmxleExheW91dE1vZHVsZSwgRGJ4TG9hZGluZ01vZHVsZSwgRGJ4Um91dGVyQW5jaG9yTW9kdWxlLCBJbmZpbml0ZVNjcm9sbE1vZHVsZSwgRGJ4SW5qZWN0aW9uQ29tcG9uZW50TW9kdWxlLCBNYXRMaXN0TW9kdWxlLCBNYXRJY29uTW9kdWxlXSxcbiAgZGVjbGFyYXRpb25zOiBbXG4gICAgLy9cbiAgICBEYnhMaXN0Q29tcG9uZW50LFxuICAgIERieExpc3RJbnRlcm5hbENvbnRlbnREaXJlY3RpdmUsXG4gICAgRGJ4TGlzdEVtcHR5Q29udGVudENvbXBvbmVudCxcbiAgICBEYnhWYWx1ZUxpc3RWaWV3Q29tcG9uZW50LFxuICAgIERieFZhbHVlTGlzdEl0ZW1WaWV3Q29tcG9uZW50LFxuICAgIERieFZhbHVlTGlzdEdyaWRTaXplRGlyZWN0aXZlLFxuICAgIERieFZhbHVlTGlzdEdyaWRWaWV3Q29tcG9uZW50LFxuICAgIERieFZhbHVlTGlzdEdyaWRJdGVtVmlld0NvbXBvbmVudCxcbiAgICBEYnhTZWxlY3Rpb25WYWx1ZUxpc3RWaWV3Q29tcG9uZW50LFxuICAgIERieFNlbGVjdGlvblZhbHVlTGlzdEl0ZW1WaWV3Q29tcG9uZW50LFxuICAgIERieFZhbHVlTGlzdEl0ZW1Nb2RpZmllckRpcmVjdGl2ZSxcbiAgICBEYnhMaXN0SXRlbURpc2FibGVSaXBwbGVNb2RpZmllckRpcmVjdGl2ZSxcbiAgICBEYnhMaXN0SXRlbUlzU2VsZWN0ZWRNb2RpZmllckRpcmVjdGl2ZVxuICBdLFxuICBleHBvcnRzOiBbXG4gICAgLy9cbiAgICBEYnhMaXN0Q29tcG9uZW50LFxuICAgIERieExpc3RFbXB0eUNvbnRlbnRDb21wb25lbnQsXG4gICAgRGJ4VmFsdWVMaXN0Vmlld0NvbXBvbmVudCxcbiAgICBEYnhWYWx1ZUxpc3RJdGVtVmlld0NvbXBvbmVudCxcbiAgICBEYnhWYWx1ZUxpc3RHcmlkU2l6ZURpcmVjdGl2ZSxcbiAgICBEYnhWYWx1ZUxpc3RHcmlkVmlld0NvbXBvbmVudCxcbiAgICBEYnhWYWx1ZUxpc3RHcmlkSXRlbVZpZXdDb21wb25lbnQsXG4gICAgRGJ4U2VsZWN0aW9uVmFsdWVMaXN0Vmlld0NvbXBvbmVudCxcbiAgICBEYnhTZWxlY3Rpb25WYWx1ZUxpc3RJdGVtVmlld0NvbXBvbmVudCxcbiAgICBEYnhWYWx1ZUxpc3RJdGVtTW9kaWZpZXJEaXJlY3RpdmUsXG4gICAgRGJ4TGlzdEl0ZW1EaXNhYmxlUmlwcGxlTW9kaWZpZXJEaXJlY3RpdmUsXG4gICAgRGJ4TGlzdEl0ZW1Jc1NlbGVjdGVkTW9kaWZpZXJEaXJlY3RpdmVcbiAgXVxufSlcbmV4cG9ydCBjbGFzcyBEYnhMaXN0TGF5b3V0TW9kdWxlIHt9XG4iXX0=
85
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlzdC5sYXlvdXQubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LXdlYi9zcmMvbGliL2xheW91dC9saXN0L2xpc3QubGF5b3V0Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDekQsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sMENBQTBDLENBQUM7QUFDakYsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDaEUsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN2RCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsMkJBQTJCLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUNoRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsK0JBQStCLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUNyRixPQUFPLEVBQUUsNEJBQTRCLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUM5RSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUMzRCxPQUFPLEVBQUUseUNBQXlDLEVBQUUsa0NBQWtDLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQztBQUN0SSxPQUFPLEVBQUUsZ0NBQWdDLEVBQUUseUJBQXlCLEVBQUUscUNBQXFDLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQUNqSixPQUFPLEVBQUUsaUNBQWlDLEVBQUUsTUFBTSxzQ0FBc0MsQ0FBQztBQUN6RixPQUFPLEVBQUUseUNBQXlDLEVBQUUsTUFBTSw2Q0FBNkMsQ0FBQztBQUN4RyxPQUFPLEVBQUUsb0NBQW9DLEVBQUUsNkJBQTZCLEVBQUUsNkJBQTZCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUNoSixPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsc0NBQXNDLEVBQUUsTUFBTSxnREFBZ0QsQ0FBQztBQUN4RyxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsZ0NBQWdDLEVBQUUsTUFBTSx5Q0FBeUMsQ0FBQzs7QUFFdkgsTUFBTSxtQkFBbUIsR0FBRyxDQUFDLCtCQUErQixDQUFDLENBQUM7QUFFOUQsTUFBTSxZQUFZLEdBQUc7SUFDbkIsYUFBYTtJQUNiLGdCQUFnQjtJQUNoQiw0QkFBNEI7SUFDNUIseUJBQXlCO0lBQ3pCLGdDQUFnQztJQUNoQyxxQ0FBcUM7SUFDckMsNkJBQTZCO0lBQzdCLDZCQUE2QjtJQUM3QixvQ0FBb0M7SUFDcEMsMEJBQTBCO0lBQzFCLGdDQUFnQztJQUNoQyxrQ0FBa0M7SUFDbEMseUNBQXlDO0lBQ3pDLGlDQUFpQztJQUNqQyx5Q0FBeUM7SUFDekMsc0NBQXNDO0NBQ3ZDLENBQUM7QUFPRixNQUFNLE9BQU8sbUJBQW1COytHQUFuQixtQkFBbUI7Z0hBQW5CLG1CQUFtQjtZQXZCOUIsYUFBYTtZQUNiLGdCQUFnQjtZQUNoQiw0QkFBNEI7WUFDNUIseUJBQXlCO1lBQ3pCLGdDQUFnQztZQUNoQyxxQ0FBcUM7WUFDckMsNkJBQTZCO1lBQzdCLDZCQUE2QjtZQUM3QixvQ0FBb0M7WUFDcEMsMEJBQTBCO1lBQzFCLGdDQUFnQztZQUNoQyxrQ0FBa0M7WUFDbEMseUNBQXlDO1lBQ3pDLGlDQUFpQztZQUNqQyx5Q0FBeUM7WUFDekMsc0NBQXNDLEVBbEJYLCtCQUErQixhQXNCaEQsWUFBWSxFQUFFLGVBQWUsRUFBRSxnQkFBZ0IsRUFBRSxnQkFBZ0IsRUFBRSxxQkFBcUIsRUFBRSxvQkFBb0IsRUFBRSwyQkFBMkIsRUFBRSxhQUFhLEVBQUUsYUFBYTtZQW5CbkwsYUFBYTtZQUNiLGdCQUFnQjtZQUNoQiw0QkFBNEI7WUFDNUIseUJBQXlCO1lBQ3pCLGdDQUFnQztZQUNoQyxxQ0FBcUM7WUFDckMsNkJBQTZCO1lBQzdCLDZCQUE2QjtZQUM3QixvQ0FBb0M7WUFDcEMsMEJBQTBCO1lBQzFCLGdDQUFnQztZQUNoQyxrQ0FBa0M7WUFDbEMseUNBQXlDO1lBQ3pDLGlDQUFpQztZQUNqQyx5Q0FBeUM7WUFDekMsc0NBQXNDO2dIQVEzQixtQkFBbUIsWUFKcEIsWUFBWSxFQUFFLGVBQWUsRUFBRSxnQkFBZ0IsRUFBRSxnQkFBZ0IsRUFBRSxxQkFBcUIsRUFBRSxvQkFBb0IsRUFBRSwyQkFBMkIsRUFBRSxhQUFhLEVBQUUsYUFBYTs7NEZBSXhLLG1CQUFtQjtrQkFML0IsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUUsQ0FBQyxZQUFZLEVBQUUsZUFBZSxFQUFFLGdCQUFnQixFQUFFLGdCQUFnQixFQUFFLHFCQUFxQixFQUFFLG9CQUFvQixFQUFFLDJCQUEyQixFQUFFLGFBQWEsRUFBRSxhQUFhLENBQUM7b0JBQ3BMLFlBQVksRUFBRSxDQUFDLEdBQUcsWUFBWSxFQUFFLEdBQUcsbUJBQW1CLENBQUM7b0JBQ3ZELE9BQU8sRUFBRSxZQUFZO2lCQUN0QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE1hdFJpcHBsZU1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2NvcmUnO1xuaW1wb3J0IHsgRGJ4Um91dGVyQW5jaG9yTW9kdWxlIH0gZnJvbSAnLi4vLi4vcm91dGVyL2xheW91dC9hbmNob3IvYW5jaG9yLm1vZHVsZSc7XG5pbXBvcnQgeyBEYnhMb2FkaW5nTW9kdWxlIH0gZnJvbSAnLi4vLi4vbG9hZGluZy9sb2FkaW5nLm1vZHVsZSc7XG5pbXBvcnQgeyBNYXRJY29uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaWNvbic7XG5pbXBvcnQgeyBNYXRMaXN0TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvbGlzdCc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IERieEluamVjdGlvbkNvbXBvbmVudE1vZHVsZSB9IGZyb20gJ0BkZXJlZWtiL2RieC1jb3JlJztcbmltcG9ydCB7IERieExpc3RDb21wb25lbnQsIERieExpc3RJbnRlcm5hbENvbnRlbnREaXJlY3RpdmUgfSBmcm9tICcuL2xpc3QuY29tcG9uZW50JztcbmltcG9ydCB7IERieExpc3RFbXB0eUNvbnRlbnRDb21wb25lbnQgfSBmcm9tICcuL2xpc3QuY29udGVudC5lbXB0eS5jb21wb25lbnQnO1xuaW1wb3J0IHsgSW5maW5pdGVTY3JvbGxNb2R1bGUgfSBmcm9tICduZ3gtaW5maW5pdGUtc2Nyb2xsJztcbmltcG9ydCB7IERieFNlbGVjdGlvblZhbHVlTGlzdFZpZXdDb250ZW50Q29tcG9uZW50LCBEYnhTZWxlY3Rpb25WYWx1ZUxpc3RWaWV3Q29tcG9uZW50IH0gZnJvbSAnLi9saXN0LnZpZXcudmFsdWUuc2VsZWN0aW9uLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEYnhWYWx1ZUxpc3RWaWV3Q29udGVudENvbXBvbmVudCwgRGJ4VmFsdWVMaXN0Vmlld0NvbXBvbmVudCwgRGJ4VmFsdWVMaXN0Vmlld0NvbnRlbnRHcm91cENvbXBvbmVudCB9IGZyb20gJy4vbGlzdC52aWV3LnZhbHVlLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEYnhWYWx1ZUxpc3RJdGVtTW9kaWZpZXJEaXJlY3RpdmUgfSBmcm9tICcuL2xpc3Qudmlldy52YWx1ZS5tb2RpZmllci5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgRGJ4TGlzdEl0ZW1EaXNhYmxlUmlwcGxlTW9kaWZpZXJEaXJlY3RpdmUgfSBmcm9tICcuL2xpc3Qudmlldy52YWx1ZS5tb2RpZmllci5yaXBwbGUuZGlyZWN0aXZlJztcbmltcG9ydCB7IERieFZhbHVlTGlzdEdyaWRWaWV3Q29udGVudENvbXBvbmVudCwgRGJ4VmFsdWVMaXN0R3JpZFNpemVEaXJlY3RpdmUsIERieFZhbHVlTGlzdEdyaWRWaWV3Q29tcG9uZW50IH0gZnJvbSAnLi9saXN0LmdyaWQudmlldy5jb21wb25lbnQnO1xuaW1wb3J0IHsgRmxleExheW91dE1vZHVsZSB9IGZyb20gJ0BuZ2JyYWNrZXQvbmd4LWxheW91dCc7XG5pbXBvcnQgeyBEYnhMaXN0SXRlbUlzU2VsZWN0ZWRNb2RpZmllckRpcmVjdGl2ZSB9IGZyb20gJy4vbGlzdC52aWV3LnZhbHVlLm1vZGlmaWVyLnNlbGVjdGlvbi5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgRGJ4TGlzdFRpdGxlR3JvdXBEaXJlY3RpdmUsIERieExpc3RUaXRsZUdyb3VwSGVhZGVyQ29tcG9uZW50IH0gZnJvbSAnLi9saXN0LnZpZXcudmFsdWUuZ3JvdXAudGl0bGUuZGlyZWN0aXZlJztcblxuY29uc3QgcHJpdmF0ZURlY2xhcmF0aW9ucyA9IFtEYnhMaXN0SW50ZXJuYWxDb250ZW50RGlyZWN0aXZlXTtcblxuY29uc3QgZGVjbGFyYXRpb25zID0gW1xuICAvLyBkaXJlY3RpdmVzXG4gIERieExpc3RDb21wb25lbnQsXG4gIERieExpc3RFbXB0eUNvbnRlbnRDb21wb25lbnQsXG4gIERieFZhbHVlTGlzdFZpZXdDb21wb25lbnQsXG4gIERieFZhbHVlTGlzdFZpZXdDb250ZW50Q29tcG9uZW50LFxuICBEYnhWYWx1ZUxpc3RWaWV3Q29udGVudEdyb3VwQ29tcG9uZW50LFxuICBEYnhWYWx1ZUxpc3RHcmlkU2l6ZURpcmVjdGl2ZSxcbiAgRGJ4VmFsdWVMaXN0R3JpZFZpZXdDb21wb25lbnQsXG4gIERieFZhbHVlTGlzdEdyaWRWaWV3Q29udGVudENvbXBvbmVudCxcbiAgRGJ4TGlzdFRpdGxlR3JvdXBEaXJlY3RpdmUsXG4gIERieExpc3RUaXRsZUdyb3VwSGVhZGVyQ29tcG9uZW50LFxuICBEYnhTZWxlY3Rpb25WYWx1ZUxpc3RWaWV3Q29tcG9uZW50LFxuICBEYnhTZWxlY3Rpb25WYWx1ZUxpc3RWaWV3Q29udGVudENvbXBvbmVudCxcbiAgRGJ4VmFsdWVMaXN0SXRlbU1vZGlmaWVyRGlyZWN0aXZlLFxuICBEYnhMaXN0SXRlbURpc2FibGVSaXBwbGVNb2RpZmllckRpcmVjdGl2ZSxcbiAgRGJ4TGlzdEl0ZW1Jc1NlbGVjdGVkTW9kaWZpZXJEaXJlY3RpdmVcbl07XG5cbkBOZ01vZHVsZSh7XG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIE1hdFJpcHBsZU1vZHVsZSwgRmxleExheW91dE1vZHVsZSwgRGJ4TG9hZGluZ01vZHVsZSwgRGJ4Um91dGVyQW5jaG9yTW9kdWxlLCBJbmZpbml0ZVNjcm9sbE1vZHVsZSwgRGJ4SW5qZWN0aW9uQ29tcG9uZW50TW9kdWxlLCBNYXRMaXN0TW9kdWxlLCBNYXRJY29uTW9kdWxlXSxcbiAgZGVjbGFyYXRpb25zOiBbLi4uZGVjbGFyYXRpb25zLCAuLi5wcml2YXRlRGVjbGFyYXRpb25zXSxcbiAgZXhwb3J0czogZGVjbGFyYXRpb25zXG59KVxuZXhwb3J0IGNsYXNzIERieExpc3RMYXlvdXRNb2R1bGUge31cbiJdfQ==
@@ -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 "../../router/layout/anchor/anchor.component";
10
- import * as i4 from "@dereekb/dbx-core";
11
- import * as i5 from "@angular/material/list";
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 DbxValueListItemViewComponent; }), selector: "dbx-list-view-content", inputs: ["emitAllClicks", "items"] }, { kind: "pipe", type: i0.forwardRef(function () { return i1.AsyncPipe; }), name: "async" }] }); }
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 DbxValueListItemViewComponent {
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: DbxValueListItemViewComponent, deps: [{ token: i2.DbxListView }], target: i0.ɵɵFactoryTarget.Component }); }
61
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DbxValueListItemViewComponent, selector: "dbx-list-view-content", inputs: { emitAllClicks: "emitAllClicks", items: "items" }, host: { classAttribute: "dbx-list-view" }, ngImport: i0, template: `
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
- </mat-nav-list>
70
- `, 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: i3.DbxAnchorComponent, selector: "dbx-anchor, [dbx-anchor]", inputs: ["block"] }, { kind: "component", type: i4.DbxInjectionComponent, selector: "dbx-injection, [dbxInjection], [dbx-injection]", inputs: ["config", "template"] }, { kind: "component", type: i5.MatNavList, selector: "mat-nav-list", exportAs: ["matNavList"] }, { kind: "component", type: i5.MatListItem, selector: "mat-list-item, a[mat-list-item], button[mat-list-item]", inputs: ["activated"], exportAs: ["matListItem"] }, { kind: "directive", type: i5.MatListItemIcon, selector: "[matListItemIcon]" }, { kind: "component", type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }] }); }
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: DbxValueListItemViewComponent, decorators: [{
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
- <mat-nav-list [disabled]="disabled$ | async">
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
- </mat-nav-list>
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: i2.DbxListView }]; }, propDecorators: { emitAllClicks: [{
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