@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.
Files changed (42) hide show
  1. package/calendar/package.json +1 -1
  2. package/esm2022/lib/extension/download/index.mjs +2 -0
  3. package/esm2022/lib/extension/download/text/download.text.component.mjs +126 -0
  4. package/esm2022/lib/extension/download/text/download.text.mjs +2 -0
  5. package/esm2022/lib/extension/download/text/download.text.module.mjs +42 -0
  6. package/esm2022/lib/extension/download/text/index.mjs +4 -0
  7. package/esm2022/lib/extension/index.mjs +3 -2
  8. package/esm2022/lib/layout/content/content.pit.directive.mjs +8 -5
  9. package/esm2022/lib/layout/list/index.mjs +4 -1
  10. package/esm2022/lib/layout/list/list.grid.view.component.mjs +13 -11
  11. package/esm2022/lib/layout/list/list.layout.module.mjs +41 -45
  12. package/esm2022/lib/layout/list/list.view.value.component.mjs +126 -22
  13. package/esm2022/lib/layout/list/list.view.value.group.mjs +32 -0
  14. package/esm2022/lib/layout/list/list.view.value.group.title.directive.mjs +132 -0
  15. package/esm2022/lib/layout/list/list.view.value.group.title.mjs +2 -0
  16. package/esm2022/lib/layout/list/list.view.value.selection.component.mjs +20 -13
  17. package/esm2022/lib/loading/loading-progress.component.mjs +4 -4
  18. package/fesm2022/dereekb-dbx-web.mjs +522 -115
  19. package/fesm2022/dereekb-dbx-web.mjs.map +1 -1
  20. package/lib/extension/download/index.d.ts +1 -0
  21. package/lib/extension/download/text/download.text.component.d.ts +40 -0
  22. package/lib/extension/download/text/download.text.component.scss +0 -0
  23. package/lib/extension/download/text/download.text.d.ts +5 -0
  24. package/lib/extension/download/text/download.text.module.d.ts +12 -0
  25. package/lib/extension/download/text/index.d.ts +3 -0
  26. package/lib/extension/index.d.ts +1 -0
  27. package/lib/layout/content/_content.scss +6 -0
  28. package/lib/layout/content/content.pit.directive.d.ts +3 -1
  29. package/lib/layout/list/_list.scss +40 -0
  30. package/lib/layout/list/index.d.ts +3 -0
  31. package/lib/layout/list/list.grid.view.component.d.ts +4 -4
  32. package/lib/layout/list/list.layout.module.d.ts +15 -14
  33. package/lib/layout/list/list.view.value.component.d.ts +39 -8
  34. package/lib/layout/list/list.view.value.group.d.ts +44 -0
  35. package/lib/layout/list/list.view.value.group.title.d.ts +49 -0
  36. package/lib/layout/list/list.view.value.group.title.directive.d.ts +31 -0
  37. package/lib/layout/list/list.view.value.selection.component.d.ts +6 -5
  38. package/lib/layout/style/_style.scss +4 -0
  39. package/lib/loading/_loading.scss +4 -0
  40. package/mapbox/package.json +1 -1
  41. package/package.json +1 -1
  42. package/table/package.json +1 -1
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@dereekb/dbx-web/calendar",
3
- "version": "10.0.23",
3
+ "version": "10.1.0",
4
4
  "module": "fesm2022/dereekb-dbx-web-calendar.mjs",
5
5
  "typings": "index.d.ts",
6
6
  "exports": {
@@ -0,0 +1,2 @@
1
+ export * from './text';
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3NyYy9saWIvZXh0ZW5zaW9uL2Rvd25sb2FkL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsUUFBUSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi90ZXh0JztcbiJdfQ==
@@ -0,0 +1,126 @@
1
+ import { Component, ElementRef, Input, ViewChild } from '@angular/core';
2
+ import { MatSnackBar } from '@angular/material/snack-bar';
3
+ import { AbstractSubscriptionDirective } from '@dereekb/dbx-core';
4
+ import { filterMaybe, loadingStateContext, successResult, valueFromFinishedLoadingState } from '@dereekb/rxjs';
5
+ import { MS_IN_SECOND } from '@dereekb/util';
6
+ import { BehaviorSubject, combineLatest, distinctUntilChanged, first, map, of, shareReplay, switchMap, tap } from 'rxjs';
7
+ import { Clipboard } from '@angular/cdk/clipboard';
8
+ import { DomSanitizer } from '@angular/platform-browser';
9
+ import * as i0 from "@angular/core";
10
+ import * as i1 from "@angular/cdk/clipboard";
11
+ import * as i2 from "@angular/material/snack-bar";
12
+ import * as i3 from "@angular/platform-browser";
13
+ import * as i4 from "@angular/common";
14
+ import * as i5 from "../../../loading/loading.component";
15
+ import * as i6 from "@dereekb/dbx-core";
16
+ import * as i7 from "../../../button/button.component";
17
+ import * as i8 from "../../../button/button.spacer.component";
18
+ /**
19
+ * DbxStructureDirective used specifically on the body of the app.
20
+ */
21
+ export class DbxDownloadTextViewComponent extends AbstractSubscriptionDirective {
22
+ constructor(_clipboard, _matSnackbar, _sanitizer) {
23
+ super();
24
+ this._clipboard = _clipboard;
25
+ this._matSnackbar = _matSnackbar;
26
+ this._sanitizer = _sanitizer;
27
+ this.showTitle = true;
28
+ this.showPreview = true;
29
+ this._downloadButton = new BehaviorSubject(undefined);
30
+ this.downloadButton$ = this._downloadButton.asObservable();
31
+ this._contentLoadingState = new BehaviorSubject(undefined);
32
+ this.contentLoadingState$ = this._contentLoadingState.pipe(filterMaybe(), shareReplay(1));
33
+ this.content$ = this._contentLoadingState.pipe(switchMap((x) => {
34
+ if (x) {
35
+ return this.contentLoadingState$.pipe(valueFromFinishedLoadingState());
36
+ }
37
+ else {
38
+ return of(undefined);
39
+ }
40
+ }));
41
+ this.contentData$ = this.content$.pipe(map((x) => x?.content));
42
+ this.context = loadingStateContext({ obs: this.contentLoadingState$ });
43
+ this.fileName$ = this.content$.pipe(map((x) => x?.name ?? 'File'), shareReplay(1));
44
+ this.fileUrl$ = this.content$.pipe(map((content) => {
45
+ let fileUrl = undefined;
46
+ if (content) {
47
+ const blob = new Blob([content.content], { type: content.mimeType ?? 'application/octet-stream' });
48
+ fileUrl = this._sanitizer.bypassSecurityTrustResourceUrl(window.URL.createObjectURL(blob));
49
+ }
50
+ return fileUrl;
51
+ }), shareReplay(1));
52
+ this.downloadReady$ = combineLatest([this._downloadButton, this.fileName$, this.fileUrl$]).pipe(map(([button, name, url]) => Boolean(button && name && url)), distinctUntilChanged(), shareReplay(1));
53
+ this.handleCopyToClipboard = () => {
54
+ return this.content$.pipe(first(), switchMap((downloadTextContent) => {
55
+ if (downloadTextContent) {
56
+ return new Promise((resolve, reject) => {
57
+ const pending = this._clipboard.beginCopy(downloadTextContent.content);
58
+ let secondsRemainingForCopy = 20; // attempt to copy for up to 20 seconds
59
+ const attempt = () => {
60
+ const copyIsFinished = pending.copy();
61
+ if (!copyIsFinished && --secondsRemainingForCopy) {
62
+ setTimeout(attempt, MS_IN_SECOND);
63
+ }
64
+ else {
65
+ // Remember to destroy when you're done!
66
+ pending.destroy();
67
+ if (copyIsFinished) {
68
+ resolve(true);
69
+ }
70
+ else {
71
+ reject(false);
72
+ }
73
+ }
74
+ };
75
+ attempt();
76
+ });
77
+ }
78
+ else {
79
+ return of(false);
80
+ }
81
+ }), tap((success) => {
82
+ if (success) {
83
+ this._matSnackbar.open('Copied to clipboard', undefined, { duration: 3 * MS_IN_SECOND });
84
+ }
85
+ else {
86
+ this._matSnackbar.open('Content failed to copy...', undefined, { duration: 3 * MS_IN_SECOND });
87
+ }
88
+ }));
89
+ };
90
+ }
91
+ set content(content) {
92
+ this._contentLoadingState.next(content ? successResult(content) : undefined);
93
+ }
94
+ set contentState(contentState) {
95
+ this._contentLoadingState.next(contentState);
96
+ }
97
+ set downloadButton(downloadButton) {
98
+ this._downloadButton.next(downloadButton);
99
+ }
100
+ ngOnDestroy() {
101
+ super.ngOnDestroy();
102
+ this._contentLoadingState.complete();
103
+ }
104
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DbxDownloadTextViewComponent, deps: [{ token: i1.Clipboard }, { token: i2.MatSnackBar }, { token: i3.DomSanitizer }], target: i0.ɵɵFactoryTarget.Component }); }
105
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DbxDownloadTextViewComponent, selector: "dbx-download-text-view", inputs: { loadingText: "loadingText", linear: "linear", showTitle: "showTitle", showPreview: "showPreview", content: "content", contentState: "contentState" }, viewQueries: [{ propertyName: "downloadButton", first: true, predicate: ["downloadButton"], descendants: true, read: ElementRef }], usesInheritance: true, ngImport: i0, template: "<div class=\"dbx-download-text-view\">\n <dbx-loading [context]=\"context\" [linear]=\"linear\" [text]=\"loadingText\">\n <ng-container *ngTemplateOutlet=\"contentView\"></ng-container>\n </dbx-loading>\n</div>\n\n<!-- Template -->\n<ng-template #contentView>\n <div class=\"dbx-download-text-view-content\">\n <div *ngIf=\"showTitle\" class=\"dbx-download-text-view-content-title dbx-mb2 mat-subtitle-2\">{{ fileName$ | async }}</div>\n <div *ngIf=\"showPreview\" class=\"dbx-download-text-preview dbx-json dbx-content-pit dbx-content-pit-scrollable dbx-mb3\">{{ contentData$ | async }}</div>\n <div class=\"dbx-download-text-view-actions\">\n <dbx-button dbxAction dbxActionValue [raised]=\"true\" [dbxActionHandler]=\"handleCopyToClipboard\" icon=\"content_copy\" dbxActionButton text=\"Copy To Clipboard\"></dbx-button>\n <dbx-button-spacer></dbx-button-spacer>\n <a #downloadButton [href]=\"fileUrl$ | async\" [attr.download]=\"fileName$ | async\"><dbx-button icon=\"download\" text=\"Download\" [raised]=\"true\" [working]=\"!(downloadReady$ | async)\" [disabled]=\"!(downloadReady$ | async)\"></dbx-button></a>\n </div>\n </div>\n</ng-template>\n", dependencies: [{ kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i5.DbxLoadingComponent, selector: "dbx-loading", inputs: ["show", "text", "mode", "color", "diameter", "linear", "padding", "context", "loading", "error"] }, { kind: "directive", type: i6.DbxActionButtonDirective, selector: "[dbxActionButton]" }, { kind: "component", type: i7.DbxButtonComponent, selector: "dbx-button", inputs: ["type", "raised", "stroked", "flat", "iconOnly", "color", "customButtonColor", "customTextColor", "customSpinnerColor"] }, { kind: "directive", type: i8.DbxButtonSpacerDirective, selector: "dbx-button-spacer,[dbxButtonSpacer]" }, { kind: "directive", type: i6.DbxActionDirective, selector: "dbx-action,[dbxAction],dbx-action-context,[dbxActionContext]", exportAs: ["action", "dbxAction"] }, { kind: "directive", type: i6.DbxActionHandlerDirective, selector: "[dbxActionHandler]", inputs: ["dbxActionHandler"] }, { kind: "directive", type: i6.DbxActionValueDirective, selector: "[dbxActionValue]", inputs: ["dbxActionValue"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }] }); }
106
+ }
107
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DbxDownloadTextViewComponent, decorators: [{
108
+ type: Component,
109
+ args: [{ selector: 'dbx-download-text-view', template: "<div class=\"dbx-download-text-view\">\n <dbx-loading [context]=\"context\" [linear]=\"linear\" [text]=\"loadingText\">\n <ng-container *ngTemplateOutlet=\"contentView\"></ng-container>\n </dbx-loading>\n</div>\n\n<!-- Template -->\n<ng-template #contentView>\n <div class=\"dbx-download-text-view-content\">\n <div *ngIf=\"showTitle\" class=\"dbx-download-text-view-content-title dbx-mb2 mat-subtitle-2\">{{ fileName$ | async }}</div>\n <div *ngIf=\"showPreview\" class=\"dbx-download-text-preview dbx-json dbx-content-pit dbx-content-pit-scrollable dbx-mb3\">{{ contentData$ | async }}</div>\n <div class=\"dbx-download-text-view-actions\">\n <dbx-button dbxAction dbxActionValue [raised]=\"true\" [dbxActionHandler]=\"handleCopyToClipboard\" icon=\"content_copy\" dbxActionButton text=\"Copy To Clipboard\"></dbx-button>\n <dbx-button-spacer></dbx-button-spacer>\n <a #downloadButton [href]=\"fileUrl$ | async\" [attr.download]=\"fileName$ | async\"><dbx-button icon=\"download\" text=\"Download\" [raised]=\"true\" [working]=\"!(downloadReady$ | async)\" [disabled]=\"!(downloadReady$ | async)\"></dbx-button></a>\n </div>\n </div>\n</ng-template>\n" }]
110
+ }], ctorParameters: function () { return [{ type: i1.Clipboard }, { type: i2.MatSnackBar }, { type: i3.DomSanitizer }]; }, propDecorators: { loadingText: [{
111
+ type: Input
112
+ }], linear: [{
113
+ type: Input
114
+ }], showTitle: [{
115
+ type: Input
116
+ }], showPreview: [{
117
+ type: Input
118
+ }], content: [{
119
+ type: Input
120
+ }], contentState: [{
121
+ type: Input
122
+ }], downloadButton: [{
123
+ type: ViewChild,
124
+ args: ['downloadButton', { read: ElementRef }]
125
+ }] } });
126
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"download.text.component.js","sourceRoot":"","sources":["../../../../../../../../packages/dbx-web/src/lib/extension/download/text/download.text.component.ts","../../../../../../../../packages/dbx-web/src/lib/extension/download/text/download.text.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, Input, ViewChild } from '@angular/core';\nimport { MatSnackBar } from '@angular/material/snack-bar';\nimport { AbstractSubscriptionDirective, HandleActionFunction } from '@dereekb/dbx-core';\nimport { LoadingState, filterMaybe, loadingStateContext, successResult, valueFromFinishedLoadingState } from '@dereekb/rxjs';\nimport { MS_IN_SECOND, Maybe } from '@dereekb/util';\nimport { BehaviorSubject, Observable, combineLatest, distinctUntilChanged, first, map, of, shareReplay, switchMap, tap } from 'rxjs';\nimport { Clipboard } from '@angular/cdk/clipboard';\nimport { DownloadTextContent } from './download.text';\nimport { DomSanitizer, SafeResourceUrl } from '@angular/platform-browser';\n\n/**\n * DbxStructureDirective used specifically on the body of the app.\n */\n@Component({\n  templateUrl: './download.text.component.html',\n  selector: 'dbx-download-text-view'\n})\nexport class DbxDownloadTextViewComponent extends AbstractSubscriptionDirective {\n  @Input()\n  loadingText?: Maybe<string>;\n\n  @Input()\n  linear?: Maybe<boolean>;\n\n  @Input()\n  showTitle: boolean = true;\n\n  @Input()\n  showPreview: boolean = true;\n\n  private _downloadButton = new BehaviorSubject<Maybe<ElementRef>>(undefined);\n  readonly downloadButton$ = this._downloadButton.asObservable();\n\n  private _contentLoadingState = new BehaviorSubject<Maybe<LoadingState<DownloadTextContent>>>(undefined);\n  readonly contentLoadingState$ = this._contentLoadingState.pipe(filterMaybe(), shareReplay(1));\n\n  readonly content$ = this._contentLoadingState.pipe(\n    switchMap((x) => {\n      if (x) {\n        return this.contentLoadingState$.pipe(valueFromFinishedLoadingState());\n      } else {\n        return of(undefined);\n      }\n    })\n  );\n\n  readonly contentData$ = this.content$.pipe(map((x) => x?.content));\n\n  readonly context = loadingStateContext({ obs: this.contentLoadingState$ });\n\n  readonly fileName$ = this.content$.pipe(\n    map((x) => x?.name ?? 'File'),\n    shareReplay(1)\n  );\n  readonly fileUrl$: Observable<Maybe<SafeResourceUrl>> = this.content$.pipe(\n    map((content) => {\n      let fileUrl: Maybe<SafeResourceUrl> = undefined;\n\n      if (content) {\n        const blob = new Blob([content.content], { type: content.mimeType ?? 'application/octet-stream' });\n        fileUrl = this._sanitizer.bypassSecurityTrustResourceUrl(window.URL.createObjectURL(blob));\n      }\n\n      return fileUrl;\n    }),\n    shareReplay(1)\n  );\n\n  readonly downloadReady$ = combineLatest([this._downloadButton, this.fileName$, this.fileUrl$]).pipe(\n    map(([button, name, url]) => Boolean(button && name && url)),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  constructor(private readonly _clipboard: Clipboard, private readonly _matSnackbar: MatSnackBar, private readonly _sanitizer: DomSanitizer) {\n    super();\n  }\n\n  @Input()\n  set content(content: Maybe<DownloadTextContent>) {\n    this._contentLoadingState.next(content ? successResult(content) : undefined);\n  }\n\n  @Input()\n  set contentState(contentState: Maybe<LoadingState<DownloadTextContent>>) {\n    this._contentLoadingState.next(contentState);\n  }\n\n  @ViewChild('downloadButton', { read: ElementRef })\n  set downloadButton(downloadButton: ElementRef) {\n    this._downloadButton.next(downloadButton);\n  }\n\n  override ngOnDestroy(): void {\n    super.ngOnDestroy();\n    this._contentLoadingState.complete();\n  }\n\n  readonly handleCopyToClipboard: HandleActionFunction = () => {\n    return this.content$.pipe(\n      first(),\n      switchMap((downloadTextContent: Maybe<DownloadTextContent>) => {\n        if (downloadTextContent) {\n          return new Promise<boolean>((resolve, reject) => {\n            const pending = this._clipboard.beginCopy(downloadTextContent.content);\n\n            let secondsRemainingForCopy = 20; // attempt to copy for up to 20 seconds\n\n            const attempt = () => {\n              const copyIsFinished = pending.copy();\n\n              if (!copyIsFinished && --secondsRemainingForCopy) {\n                setTimeout(attempt, MS_IN_SECOND);\n              } else {\n                // Remember to destroy when you're done!\n                pending.destroy();\n\n                if (copyIsFinished) {\n                  resolve(true);\n                } else {\n                  reject(false);\n                }\n              }\n            };\n\n            attempt();\n          });\n        } else {\n          return of(false);\n        }\n      }),\n      tap((success) => {\n        if (success) {\n          this._matSnackbar.open('Copied to clipboard', undefined, { duration: 3 * MS_IN_SECOND });\n        } else {\n          this._matSnackbar.open('Content failed to copy...', undefined, { duration: 3 * MS_IN_SECOND });\n        }\n      })\n    );\n  };\n}\n","<div class=\"dbx-download-text-view\">\n  <dbx-loading [context]=\"context\" [linear]=\"linear\" [text]=\"loadingText\">\n    <ng-container *ngTemplateOutlet=\"contentView\"></ng-container>\n  </dbx-loading>\n</div>\n\n<!-- Template -->\n<ng-template #contentView>\n  <div class=\"dbx-download-text-view-content\">\n    <div *ngIf=\"showTitle\" class=\"dbx-download-text-view-content-title dbx-mb2 mat-subtitle-2\">{{ fileName$ | async }}</div>\n    <div *ngIf=\"showPreview\" class=\"dbx-download-text-preview dbx-json dbx-content-pit dbx-content-pit-scrollable dbx-mb3\">{{ contentData$ | async }}</div>\n    <div class=\"dbx-download-text-view-actions\">\n      <dbx-button dbxAction dbxActionValue [raised]=\"true\" [dbxActionHandler]=\"handleCopyToClipboard\" icon=\"content_copy\" dbxActionButton text=\"Copy To Clipboard\"></dbx-button>\n      <dbx-button-spacer></dbx-button-spacer>\n      <a #downloadButton [href]=\"fileUrl$ | async\" [attr.download]=\"fileName$ | async\"><dbx-button icon=\"download\" text=\"Download\" [raised]=\"true\" [working]=\"!(downloadReady$ | async)\" [disabled]=\"!(downloadReady$ | async)\"></dbx-button></a>\n    </div>\n  </div>\n</ng-template>\n"]}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG93bmxvYWQudGV4dC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC13ZWIvc3JjL2xpYi9leHRlbnNpb24vZG93bmxvYWQvdGV4dC9kb3dubG9hZC50ZXh0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgaW50ZXJmYWNlIERvd25sb2FkVGV4dENvbnRlbnQge1xuICByZWFkb25seSBjb250ZW50OiBzdHJpbmc7XG4gIHJlYWRvbmx5IG5hbWU6IHN0cmluZztcbiAgcmVhZG9ubHkgbWltZVR5cGU/OiBzdHJpbmc7XG59XG4iXX0=
@@ -0,0 +1,42 @@
1
+ import { CommonModule } from '@angular/common';
2
+ import { NgModule } from '@angular/core';
3
+ import { DbxDownloadTextViewComponent } from './download.text.component';
4
+ import { DbxButtonModule } from '../../../button/button.module';
5
+ import { DbxLoadingModule } from '../../../loading/loading.module';
6
+ import { DbxActionModule } from '../../../action/action.module';
7
+ import { MatSnackBarModule } from '@angular/material/snack-bar';
8
+ import * as i0 from "@angular/core";
9
+ const declarations = [DbxDownloadTextViewComponent];
10
+ export class DbxDownloadTextModule {
11
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DbxDownloadTextModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
12
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: DbxDownloadTextModule, declarations: [DbxDownloadTextViewComponent], imports: [
13
+ //
14
+ CommonModule,
15
+ DbxLoadingModule,
16
+ DbxButtonModule,
17
+ DbxActionModule,
18
+ MatSnackBarModule], exports: [DbxDownloadTextViewComponent] }); }
19
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DbxDownloadTextModule, imports: [
20
+ //
21
+ CommonModule,
22
+ DbxLoadingModule,
23
+ DbxButtonModule,
24
+ DbxActionModule,
25
+ MatSnackBarModule] }); }
26
+ }
27
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DbxDownloadTextModule, decorators: [{
28
+ type: NgModule,
29
+ args: [{
30
+ imports: [
31
+ //
32
+ CommonModule,
33
+ DbxLoadingModule,
34
+ DbxButtonModule,
35
+ DbxActionModule,
36
+ MatSnackBarModule
37
+ ],
38
+ declarations,
39
+ exports: declarations
40
+ }]
41
+ }] });
42
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG93bmxvYWQudGV4dC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3NyYy9saWIvZXh0ZW5zaW9uL2Rvd25sb2FkL3RleHQvZG93bmxvYWQudGV4dC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLDRCQUE0QixFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDekUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLCtCQUErQixDQUFDO0FBQ2hFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBQ25FLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUNoRSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQzs7QUFFaEUsTUFBTSxZQUFZLEdBQUcsQ0FBQyw0QkFBNEIsQ0FBQyxDQUFDO0FBY3BELE1BQU0sT0FBTyxxQkFBcUI7K0dBQXJCLHFCQUFxQjtnSEFBckIscUJBQXFCLGlCQWRaLDRCQUE0QjtZQUk5QyxFQUFFO1lBQ0YsWUFBWTtZQUNaLGdCQUFnQjtZQUNoQixlQUFlO1lBQ2YsZUFBZTtZQUNmLGlCQUFpQixhQVRDLDRCQUE0QjtnSEFjckMscUJBQXFCO1lBVjlCLEVBQUU7WUFDRixZQUFZO1lBQ1osZ0JBQWdCO1lBQ2hCLGVBQWU7WUFDZixlQUFlO1lBQ2YsaUJBQWlCOzs0RkFLUixxQkFBcUI7a0JBWmpDLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFO3dCQUNQLEVBQUU7d0JBQ0YsWUFBWTt3QkFDWixnQkFBZ0I7d0JBQ2hCLGVBQWU7d0JBQ2YsZUFBZTt3QkFDZixpQkFBaUI7cUJBQ2xCO29CQUNELFlBQVk7b0JBQ1osT0FBTyxFQUFFLFlBQVk7aUJBQ3RCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBEYnhEb3dubG9hZFRleHRWaWV3Q29tcG9uZW50IH0gZnJvbSAnLi9kb3dubG9hZC50ZXh0LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEYnhCdXR0b25Nb2R1bGUgfSBmcm9tICcuLi8uLi8uLi9idXR0b24vYnV0dG9uLm1vZHVsZSc7XG5pbXBvcnQgeyBEYnhMb2FkaW5nTW9kdWxlIH0gZnJvbSAnLi4vLi4vLi4vbG9hZGluZy9sb2FkaW5nLm1vZHVsZSc7XG5pbXBvcnQgeyBEYnhBY3Rpb25Nb2R1bGUgfSBmcm9tICcuLi8uLi8uLi9hY3Rpb24vYWN0aW9uLm1vZHVsZSc7XG5pbXBvcnQgeyBNYXRTbmFja0Jhck1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3NuYWNrLWJhcic7XG5cbmNvbnN0IGRlY2xhcmF0aW9ucyA9IFtEYnhEb3dubG9hZFRleHRWaWV3Q29tcG9uZW50XTtcblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW1xuICAgIC8vXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIERieExvYWRpbmdNb2R1bGUsXG4gICAgRGJ4QnV0dG9uTW9kdWxlLFxuICAgIERieEFjdGlvbk1vZHVsZSxcbiAgICBNYXRTbmFja0Jhck1vZHVsZVxuICBdLFxuICBkZWNsYXJhdGlvbnMsXG4gIGV4cG9ydHM6IGRlY2xhcmF0aW9uc1xufSlcbmV4cG9ydCBjbGFzcyBEYnhEb3dubG9hZFRleHRNb2R1bGUge31cbiJdfQ==
@@ -0,0 +1,4 @@
1
+ export * from './download.text.component';
2
+ export * from './download.text.module';
3
+ export * from './download.text';
4
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3NyYy9saWIvZXh0ZW5zaW9uL2Rvd25sb2FkL3RleHQvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYywyQkFBMkIsQ0FBQztBQUMxQyxjQUFjLHdCQUF3QixDQUFDO0FBQ3ZDLGNBQWMsaUJBQWlCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2Rvd25sb2FkLnRleHQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vZG93bmxvYWQudGV4dC5tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi9kb3dubG9hZC50ZXh0JztcbiJdfQ==
@@ -1,6 +1,7 @@
1
- // export * from './calendar';
1
+ // export * from './calendar'; // nothing to export
2
2
  export * from './model';
3
+ export * from './download';
3
4
  export * from './structure';
4
5
  // export * from './table'; // nothing to export
5
6
  export * from './widget';
6
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3NyYy9saWIvZXh0ZW5zaW9uL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLDhCQUE4QjtBQUM5QixjQUFjLFNBQVMsQ0FBQztBQUN4QixjQUFjLGFBQWEsQ0FBQztBQUM1QixnREFBZ0Q7QUFDaEQsY0FBYyxVQUFVLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBleHBvcnQgKiBmcm9tICcuL2NhbGVuZGFyJztcbmV4cG9ydCAqIGZyb20gJy4vbW9kZWwnO1xuZXhwb3J0ICogZnJvbSAnLi9zdHJ1Y3R1cmUnO1xuLy8gZXhwb3J0ICogZnJvbSAnLi90YWJsZSc7IC8vIG5vdGhpbmcgdG8gZXhwb3J0XG5leHBvcnQgKiBmcm9tICcuL3dpZGdldCc7XG4iXX0=
7
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3NyYy9saWIvZXh0ZW5zaW9uL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLG1EQUFtRDtBQUNuRCxjQUFjLFNBQVMsQ0FBQztBQUN4QixjQUFjLFlBQVksQ0FBQztBQUMzQixjQUFjLGFBQWEsQ0FBQztBQUM1QixnREFBZ0Q7QUFDaEQsY0FBYyxVQUFVLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBleHBvcnQgKiBmcm9tICcuL2NhbGVuZGFyJzsgLy8gbm90aGluZyB0byBleHBvcnRcbmV4cG9ydCAqIGZyb20gJy4vbW9kZWwnO1xuZXhwb3J0ICogZnJvbSAnLi9kb3dubG9hZCc7XG5leHBvcnQgKiBmcm9tICcuL3N0cnVjdHVyZSc7XG4vLyBleHBvcnQgKiBmcm9tICcuL3RhYmxlJzsgLy8gbm90aGluZyB0byBleHBvcnRcbmV4cG9ydCAqIGZyb20gJy4vd2lkZ2V0JztcbiJdfQ==
@@ -1,19 +1,22 @@
1
- import { Directive } from '@angular/core';
1
+ import { Directive, Input } from '@angular/core';
2
2
  import * as i0 from "@angular/core";
3
3
  /**
4
4
  * Component used to wrap content in a pit with a label.
5
5
  */
6
6
  export class DbxContentPitDirective {
7
7
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DbxContentPitDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
8
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: DbxContentPitDirective, selector: "dbx-content-pit, [dbxContentPit]", host: { classAttribute: "d-block dbx-content-pit" }, ngImport: i0 }); }
8
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: DbxContentPitDirective, selector: "dbx-content-pit, [dbxContentPit]", inputs: { scrollable: "scrollable" }, host: { properties: { "class.dbx-content-pit-scrollable": "scrollable" }, classAttribute: "d-block dbx-content-pit" }, ngImport: i0 }); }
9
9
  }
10
10
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DbxContentPitDirective, decorators: [{
11
11
  type: Directive,
12
12
  args: [{
13
13
  selector: 'dbx-content-pit, [dbxContentPit]',
14
14
  host: {
15
- class: 'd-block dbx-content-pit'
15
+ class: 'd-block dbx-content-pit',
16
+ '[class.dbx-content-pit-scrollable]': 'scrollable'
16
17
  }
17
18
  }]
18
- }] });
19
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGVudC5waXQuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LXdlYi9zcmMvbGliL2xheW91dC9jb250ZW50L2NvbnRlbnQucGl0LmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUUxQzs7R0FFRztBQU9ILE1BQU0sT0FBTyxzQkFBc0I7K0dBQXRCLHNCQUFzQjttR0FBdEIsc0JBQXNCOzs0RkFBdEIsc0JBQXNCO2tCQU5sQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxrQ0FBa0M7b0JBQzVDLElBQUksRUFBRTt3QkFDSixLQUFLLEVBQUUseUJBQXlCO3FCQUNqQztpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG4vKipcbiAqIENvbXBvbmVudCB1c2VkIHRvIHdyYXAgY29udGVudCBpbiBhIHBpdCB3aXRoIGEgbGFiZWwuXG4gKi9cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ2RieC1jb250ZW50LXBpdCwgW2RieENvbnRlbnRQaXRdJyxcbiAgaG9zdDoge1xuICAgIGNsYXNzOiAnZC1ibG9jayBkYngtY29udGVudC1waXQnXG4gIH1cbn0pXG5leHBvcnQgY2xhc3MgRGJ4Q29udGVudFBpdERpcmVjdGl2ZSB7fVxuIl19
19
+ }], propDecorators: { scrollable: [{
20
+ type: Input
21
+ }] } });
22
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGVudC5waXQuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LXdlYi9zcmMvbGliL2xheW91dC9jb250ZW50L2NvbnRlbnQucGl0LmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFHakQ7O0dBRUc7QUFRSCxNQUFNLE9BQU8sc0JBQXNCOytHQUF0QixzQkFBc0I7bUdBQXRCLHNCQUFzQjs7NEZBQXRCLHNCQUFzQjtrQkFQbEMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsa0NBQWtDO29CQUM1QyxJQUFJLEVBQUU7d0JBQ0osS0FBSyxFQUFFLHlCQUF5Qjt3QkFDaEMsb0NBQW9DLEVBQUUsWUFBWTtxQkFDbkQ7aUJBQ0Y7OEJBR0MsVUFBVTtzQkFEVCxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTWF5YmUgfSBmcm9tICdAZGVyZWVrYi91dGlsJztcblxuLyoqXG4gKiBDb21wb25lbnQgdXNlZCB0byB3cmFwIGNvbnRlbnQgaW4gYSBwaXQgd2l0aCBhIGxhYmVsLlxuICovXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdkYngtY29udGVudC1waXQsIFtkYnhDb250ZW50UGl0XScsXG4gIGhvc3Q6IHtcbiAgICBjbGFzczogJ2QtYmxvY2sgZGJ4LWNvbnRlbnQtcGl0JyxcbiAgICAnW2NsYXNzLmRieC1jb250ZW50LXBpdC1zY3JvbGxhYmxlXSc6ICdzY3JvbGxhYmxlJ1xuICB9XG59KVxuZXhwb3J0IGNsYXNzIERieENvbnRlbnRQaXREaXJlY3RpdmUge1xuICBASW5wdXQoKVxuICBzY3JvbGxhYmxlPzogTWF5YmU8Ym9vbGVhbj47XG59XG4iXX0=
@@ -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":"AAAA,OAAO,EAAE,SAAS,EAAE,SAAS,EAAE,KAAK,EAAa,QAAQ,EAAE,MAAM,eAAe,CAAC;AACjF,OAAO,EAAE,WAAW,EAAE,GAAG,EAAE,eAAe,EAAE,aAAa,EAAE,EAAE,EAAc,MAAM,MAAM,CAAC;AAExF,OAAO,EAAE,iCAAiC,EAAE,MAAM,6BAA6B,CAAC;AAChF,OAAO,EAAS,YAAY,EAAE,MAAM,eAAe,CAAC;AACpD,OAAO,EAAE,6BAA6B,EAA0B,MAAM,6BAA6B,CAAC;AACpG,OAAO,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;;;;;;;;AAM1C;;GAEG;AAOH,MAAM,OAAO,6BAAwL,SAAQ,iCAA6C;IAN1P;;QAOW,UAAK,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;QAC9C,mBAAc,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CACzC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,aAAa,CAAC,EAC3B,WAAW,CAAC,CAAC,CAAC,CACf,CAAC;KACH;+GANY,6BAA6B;mGAA7B,6BAA6B,iFAJ9B;;GAET,+FAuEU,iCAAiC;;4FArEjC,6BAA6B;kBANzC,SAAS;mBAAC;oBACT,QAAQ,EAAE,oBAAoB;oBAC9B,QAAQ,EAAE;;GAET;iBACF;;AAsBD,MAAM,CAAC,MAAM,6BAA6B,GAA2C;IACnF,OAAO,EAAE,uCAAuC;IAChD,GAAG,EAAE,KAAK;CACX,CAAC;AAEF;;GAEG;AAIH,MAAM,OAAO,6BAA6B;IAH1C;QAIU,cAAS,GAAG,IAAI,eAAe,CAAyD,SAAS,CAAC,CAAC;QAElG,cAAS,GAAG,IAAI,CAAC,SAAS,CAAC,YAAY,EAAE,CAAC;KAgBpD;IAdC,IACI,QAAQ;QACV,OAAO,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC;IAC9B,CAAC;IAED,IAAI,QAAQ,CAAC,QAAgE;QAC3E,IAAI,QAAQ,EAAE;YACZ,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;SAC/B;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC;IAC5B,CAAC;+GAlBU,6BAA6B;mGAA7B,6BAA6B;;4FAA7B,6BAA6B;kBAHzC,SAAS;mBAAC;oBACT,QAAQ,EAAE,mBAAmB;iBAC9B;8BAOK,QAAQ;sBADX,KAAK;uBAAC,iBAAiB;;AAgB1B;;GAEG;AAcH,MAAM,OAAO,iCAA0F,SAAQ,6BAAmC;IAchJ,YAAY,WAA2B,EAAsB,iBAAiD;QAC5G,KAAK,CAAC,WAAW,CAAC,CAAC;QADwC,sBAAiB,GAAjB,iBAAiB,CAAgC;QAbtG,iBAAY,GAAG,IAAI,eAAe,CAAyD,SAAS,CAAC,CAAC;QAErG,UAAK,GAAuD,aAAa,CAAC,CAAC,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,iBAAiB,EAAE,SAAS,IAAI,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,IAAI,CAC9J,GAAG,CAAC,CAAC,CAAC,WAAW,EAAE,YAAY,CAAC,EAAE,EAAE;YAClC,MAAM,IAAI,GAAG,YAAY,CAAyC,CAAC,6BAA6B,EAAE,WAAW,EAAE,YAAY,CAAC,CAAC,CAAC;YAC9H,OAAO,IAA8C,CAAC;QACxD,CAAC,CAAC,EACF,WAAW,CAAC,CAAC,CAAC,CACf,CAAC;QAEO,SAAI,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;QAC1C,aAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC;IAI3D,CAAC;IAED,IACI,IAAI,CAAC,IAA4D;QACnE,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC/B,CAAC;IAED,WAAW;QACT,IAAI,CAAC,YAAY,CAAC,QAAQ,EAAE,CAAC;IAC/B,CAAC;+GAzBU,iCAAiC;mGAAjC,iCAAiC,mKAXlC;;;;;;GAMT;;4FAKU,iCAAiC;kBAb7C,SAAS;mBAAC;oBACT,QAAQ,EAAE,4BAA4B;oBACtC,QAAQ,EAAE;;;;;;GAMT;oBACD,IAAI,EAAE;wBACJ,KAAK,EAAE,oBAAoB;qBAC5B;iBACF;;0BAe2C,QAAQ;4CAK9C,IAAI;sBADP,KAAK","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==