@dereekb/dbx-web 10.0.23 → 10.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/calendar/package.json +1 -1
- package/esm2022/lib/extension/download/index.mjs +2 -0
- package/esm2022/lib/extension/download/text/download.text.component.mjs +126 -0
- package/esm2022/lib/extension/download/text/download.text.mjs +2 -0
- package/esm2022/lib/extension/download/text/download.text.module.mjs +42 -0
- package/esm2022/lib/extension/download/text/index.mjs +4 -0
- package/esm2022/lib/extension/index.mjs +3 -2
- package/esm2022/lib/layout/content/content.pit.directive.mjs +8 -5
- package/esm2022/lib/layout/list/index.mjs +4 -1
- package/esm2022/lib/layout/list/list.grid.view.component.mjs +13 -11
- package/esm2022/lib/layout/list/list.layout.module.mjs +41 -45
- package/esm2022/lib/layout/list/list.view.value.component.mjs +126 -22
- package/esm2022/lib/layout/list/list.view.value.group.mjs +32 -0
- package/esm2022/lib/layout/list/list.view.value.group.title.directive.mjs +132 -0
- package/esm2022/lib/layout/list/list.view.value.group.title.mjs +2 -0
- package/esm2022/lib/layout/list/list.view.value.selection.component.mjs +20 -13
- package/esm2022/lib/loading/loading-progress.component.mjs +4 -4
- package/fesm2022/dereekb-dbx-web.mjs +522 -115
- package/fesm2022/dereekb-dbx-web.mjs.map +1 -1
- package/lib/extension/download/index.d.ts +1 -0
- package/lib/extension/download/text/download.text.component.d.ts +40 -0
- package/lib/extension/download/text/download.text.component.scss +0 -0
- package/lib/extension/download/text/download.text.d.ts +5 -0
- package/lib/extension/download/text/download.text.module.d.ts +12 -0
- package/lib/extension/download/text/index.d.ts +3 -0
- package/lib/extension/index.d.ts +1 -0
- package/lib/layout/content/_content.scss +6 -0
- package/lib/layout/content/content.pit.directive.d.ts +3 -1
- package/lib/layout/list/_list.scss +40 -0
- package/lib/layout/list/index.d.ts +3 -0
- package/lib/layout/list/list.grid.view.component.d.ts +4 -4
- package/lib/layout/list/list.layout.module.d.ts +15 -14
- package/lib/layout/list/list.view.value.component.d.ts +39 -8
- package/lib/layout/list/list.view.value.group.d.ts +44 -0
- package/lib/layout/list/list.view.value.group.title.d.ts +49 -0
- package/lib/layout/list/list.view.value.group.title.directive.d.ts +31 -0
- package/lib/layout/list/list.view.value.selection.component.d.ts +6 -5
- package/lib/layout/style/_style.scss +4 -0
- package/lib/loading/_loading.scss +4 -0
- package/mapbox/package.json +1 -1
- package/package.json +1 -1
- package/table/package.json +1 -1
package/calendar/package.json
CHANGED
|
@@ -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":"AAAA,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AACxE,OAAO,EAAE,WAAW,EAAE,MAAM,6BAA6B,CAAC;AAC1D,OAAO,EAAE,6BAA6B,EAAwB,MAAM,mBAAmB,CAAC;AACxF,OAAO,EAAgB,WAAW,EAAE,mBAAmB,EAAE,aAAa,EAAE,6BAA6B,EAAE,MAAM,eAAe,CAAC;AAC7H,OAAO,EAAE,YAAY,EAAS,MAAM,eAAe,CAAC;AACpD,OAAO,EAAE,eAAe,EAAc,aAAa,EAAE,oBAAoB,EAAE,KAAK,EAAE,GAAG,EAAE,EAAE,EAAE,WAAW,EAAE,SAAS,EAAE,GAAG,EAAE,MAAM,MAAM,CAAC;AACrI,OAAO,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AAEnD,OAAO,EAAE,YAAY,EAAmB,MAAM,2BAA2B,CAAC;;;;;;;;;;AAE1E;;GAEG;AAKH,MAAM,OAAO,4BAA6B,SAAQ,6BAA6B;IAyD7E,YAA6B,UAAqB,EAAmB,YAAyB,EAAmB,UAAwB;QACvI,KAAK,EAAE,CAAC;QADmB,eAAU,GAAV,UAAU,CAAW;QAAmB,iBAAY,GAAZ,YAAY,CAAa;QAAmB,eAAU,GAAV,UAAU,CAAc;QAjDzI,cAAS,GAAY,IAAI,CAAC;QAG1B,gBAAW,GAAY,IAAI,CAAC;QAEpB,oBAAe,GAAG,IAAI,eAAe,CAAoB,SAAS,CAAC,CAAC;QACnE,oBAAe,GAAG,IAAI,CAAC,eAAe,CAAC,YAAY,EAAE,CAAC;QAEvD,yBAAoB,GAAG,IAAI,eAAe,CAA2C,SAAS,CAAC,CAAC;QAC/F,yBAAoB,GAAG,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,WAAW,EAAE,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC;QAErF,aAAQ,GAAG,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAChD,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE;YACd,IAAI,CAAC,EAAE;gBACL,OAAO,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,6BAA6B,EAAE,CAAC,CAAC;aACxE;iBAAM;gBACL,OAAO,EAAE,CAAC,SAAS,CAAC,CAAC;aACtB;QACH,CAAC,CAAC,CACH,CAAC;QAEO,iBAAY,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC,CAAC;QAE1D,YAAO,GAAG,mBAAmB,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,oBAAoB,EAAE,CAAC,CAAC;QAElE,cAAS,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CACrC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,IAAI,IAAI,MAAM,CAAC,EAC7B,WAAW,CAAC,CAAC,CAAC,CACf,CAAC;QACO,aAAQ,GAAuC,IAAI,CAAC,QAAQ,CAAC,IAAI,CACxE,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE;YACd,IAAI,OAAO,GAA2B,SAAS,CAAC;YAEhD,IAAI,OAAO,EAAE;gBACX,MAAM,IAAI,GAAG,IAAI,IAAI,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,EAAE,IAAI,EAAE,OAAO,CAAC,QAAQ,IAAI,0BAA0B,EAAE,CAAC,CAAC;gBACnG,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,8BAA8B,CAAC,MAAM,CAAC,GAAG,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC,CAAC;aAC5F;YAED,OAAO,OAAO,CAAC;QACjB,CAAC,CAAC,EACF,WAAW,CAAC,CAAC,CAAC,CACf,CAAC;QAEO,mBAAc,GAAG,aAAa,CAAC,CAAC,IAAI,CAAC,eAAe,EAAE,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CACjG,GAAG,CAAC,CAAC,CAAC,MAAM,EAAE,IAAI,EAAE,GAAG,CAAC,EAAE,EAAE,CAAC,OAAO,CAAC,MAAM,IAAI,IAAI,IAAI,GAAG,CAAC,CAAC,EAC5D,oBAAoB,EAAE,EACtB,WAAW,CAAC,CAAC,CAAC,CACf,CAAC;QA0BO,0BAAqB,GAAyB,GAAG,EAAE;YAC1D,OAAO,IAAI,CAAC,QAAQ,CAAC,IAAI,CACvB,KAAK,EAAE,EACP,SAAS,CAAC,CAAC,mBAA+C,EAAE,EAAE;gBAC5D,IAAI,mBAAmB,EAAE;oBACvB,OAAO,IAAI,OAAO,CAAU,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;wBAC9C,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,mBAAmB,CAAC,OAAO,CAAC,CAAC;wBAEvE,IAAI,uBAAuB,GAAG,EAAE,CAAC,CAAC,uCAAuC;wBAEzE,MAAM,OAAO,GAAG,GAAG,EAAE;4BACnB,MAAM,cAAc,GAAG,OAAO,CAAC,IAAI,EAAE,CAAC;4BAEtC,IAAI,CAAC,cAAc,IAAI,EAAE,uBAAuB,EAAE;gCAChD,UAAU,CAAC,OAAO,EAAE,YAAY,CAAC,CAAC;6BACnC;iCAAM;gCACL,wCAAwC;gCACxC,OAAO,CAAC,OAAO,EAAE,CAAC;gCAElB,IAAI,cAAc,EAAE;oCAClB,OAAO,CAAC,IAAI,CAAC,CAAC;iCACf;qCAAM;oCACL,MAAM,CAAC,KAAK,CAAC,CAAC;iCACf;6BACF;wBACH,CAAC,CAAC;wBAEF,OAAO,EAAE,CAAC;oBACZ,CAAC,CAAC,CAAC;iBACJ;qBAAM;oBACL,OAAO,EAAE,CAAC,KAAK,CAAC,CAAC;iBAClB;YACH,CAAC,CAAC,EACF,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE;gBACd,IAAI,OAAO,EAAE;oBACX,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,qBAAqB,EAAE,SAAS,EAAE,EAAE,QAAQ,EAAE,CAAC,GAAG,YAAY,EAAE,CAAC,CAAC;iBAC1F;qBAAM;oBACL,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,2BAA2B,EAAE,SAAS,EAAE,EAAE,QAAQ,EAAE,CAAC,GAAG,YAAY,EAAE,CAAC,CAAC;iBAChG;YACH,CAAC,CAAC,CACH,CAAC;QACJ,CAAC,CAAC;IA/DF,CAAC;IAED,IACI,OAAO,CAAC,OAAmC;QAC7C,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC;IAC/E,CAAC;IAED,IACI,YAAY,CAAC,YAAsD;QACrE,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IAC/C,CAAC;IAED,IACI,cAAc,CAAC,cAA0B;QAC3C,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;IAC5C,CAAC;IAEQ,WAAW;QAClB,KAAK,CAAC,WAAW,EAAE,CAAC;QACpB,IAAI,CAAC,oBAAoB,CAAC,QAAQ,EAAE,CAAC;IACvC,CAAC;+GA/EU,4BAA4B;mGAA5B,4BAA4B,2TAuEF,UAAU,oDCxFjD,qqCAkBA;;4FDDa,4BAA4B;kBAJxC,SAAS;+BAEE,wBAAwB;qJAIlC,WAAW;sBADV,KAAK;gBAIN,MAAM;sBADL,KAAK;gBAIN,SAAS;sBADR,KAAK;gBAIN,WAAW;sBADV,KAAK;gBAoDF,OAAO;sBADV,KAAK;gBAMF,YAAY;sBADf,KAAK;gBAMF,cAAc;sBADjB,SAAS;uBAAC,gBAAgB,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE","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,
|
|
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
|
-
|
|
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,
|
|
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 {
|
|
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
|
|
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
|
|
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:
|
|
94
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type:
|
|
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:
|
|
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":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,SAAS,EAAE,KAAK,EAAa,QAAQ,EAAE,MAAM,eAAe,CAAC;AAC1G,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,gCAAgC,EAA0B,MAAM,6BAA6B,CAAC;AACvG,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,+FAwEU,oCAAoC;;4FAtEpC,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;AAeH,MAAM,OAAO,oCAA6F,SAAQ,gCAAsC;IActJ,YAAY,WAA2B,EAAsB,iBAAiD;QAC5G,KAAK,CAAC,WAAW,EAAE,SAAS,CAAC,CAAC;QAD6B,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;IAEQ,WAAW;QAClB,KAAK,CAAC,WAAW,EAAE,CAAC;QACpB,IAAI,CAAC,YAAY,CAAC,QAAQ,EAAE,CAAC;IAC/B,CAAC;+GA1BU,oCAAoC;mGAApC,oCAAoC,mKAZrC;;;;;;GAMT;;4FAMU,oCAAoC;kBAdhD,SAAS;mBAAC;oBACT,QAAQ,EAAE,4BAA4B;oBACtC,QAAQ,EAAE;;;;;;GAMT;oBACD,IAAI,EAAE;wBACJ,KAAK,EAAE,oBAAoB;qBAC5B;oBACD,eAAe,EAAE,uBAAuB,CAAC,MAAM;iBAChD;;0BAe2C,QAAQ;4CAK9C,IAAI;sBADP,KAAK","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 {
|
|
13
|
-
import {
|
|
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 {
|
|
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
|
-
|
|
47
|
+
DbxValueListViewContentComponent,
|
|
48
|
+
DbxValueListViewContentGroupComponent,
|
|
29
49
|
DbxValueListGridSizeDirective,
|
|
30
50
|
DbxValueListGridViewComponent,
|
|
31
|
-
|
|
51
|
+
DbxValueListGridViewContentComponent,
|
|
52
|
+
DbxListTitleGroupDirective,
|
|
53
|
+
DbxListTitleGroupHeaderComponent,
|
|
32
54
|
DbxSelectionValueListViewComponent,
|
|
33
|
-
|
|
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
|
-
|
|
63
|
+
DbxValueListViewContentComponent,
|
|
64
|
+
DbxValueListViewContentGroupComponent,
|
|
42
65
|
DbxValueListGridSizeDirective,
|
|
43
66
|
DbxValueListGridViewComponent,
|
|
44
|
-
|
|
67
|
+
DbxValueListGridViewContentComponent,
|
|
68
|
+
DbxListTitleGroupDirective,
|
|
69
|
+
DbxListTitleGroupHeaderComponent,
|
|
45
70
|
DbxSelectionValueListViewComponent,
|
|
46
|
-
|
|
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,
|
|
85
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlzdC5sYXlvdXQubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LXdlYi9zcmMvbGliL2xheW91dC9saXN0L2xpc3QubGF5b3V0Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDekQsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sMENBQTBDLENBQUM7QUFDakYsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDaEUsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN2RCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsMkJBQTJCLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUNoRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsK0JBQStCLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUNyRixPQUFPLEVBQUUsNEJBQTRCLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUM5RSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUMzRCxPQUFPLEVBQUUseUNBQXlDLEVBQUUsa0NBQWtDLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQztBQUN0SSxPQUFPLEVBQUUsZ0NBQWdDLEVBQUUseUJBQXlCLEVBQUUscUNBQXFDLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQUNqSixPQUFPLEVBQUUsaUNBQWlDLEVBQUUsTUFBTSxzQ0FBc0MsQ0FBQztBQUN6RixPQUFPLEVBQUUseUNBQXlDLEVBQUUsTUFBTSw2Q0FBNkMsQ0FBQztBQUN4RyxPQUFPLEVBQUUsb0NBQW9DLEVBQUUsNkJBQTZCLEVBQUUsNkJBQTZCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUNoSixPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsc0NBQXNDLEVBQUUsTUFBTSxnREFBZ0QsQ0FBQztBQUN4RyxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsZ0NBQWdDLEVBQUUsTUFBTSx5Q0FBeUMsQ0FBQzs7QUFFdkgsTUFBTSxtQkFBbUIsR0FBRyxDQUFDLCtCQUErQixDQUFDLENBQUM7QUFFOUQsTUFBTSxZQUFZLEdBQUc7SUFDbkIsYUFBYTtJQUNiLGdCQUFnQjtJQUNoQiw0QkFBNEI7SUFDNUIseUJBQXlCO0lBQ3pCLGdDQUFnQztJQUNoQyxxQ0FBcUM7SUFDckMsNkJBQTZCO0lBQzdCLDZCQUE2QjtJQUM3QixvQ0FBb0M7SUFDcEMsMEJBQTBCO0lBQzFCLGdDQUFnQztJQUNoQyxrQ0FBa0M7SUFDbEMseUNBQXlDO0lBQ3pDLGlDQUFpQztJQUNqQyx5Q0FBeUM7SUFDekMsc0NBQXNDO0NBQ3ZDLENBQUM7QUFPRixNQUFNLE9BQU8sbUJBQW1COytHQUFuQixtQkFBbUI7Z0hBQW5CLG1CQUFtQjtZQXZCOUIsYUFBYTtZQUNiLGdCQUFnQjtZQUNoQiw0QkFBNEI7WUFDNUIseUJBQXlCO1lBQ3pCLGdDQUFnQztZQUNoQyxxQ0FBcUM7WUFDckMsNkJBQTZCO1lBQzdCLDZCQUE2QjtZQUM3QixvQ0FBb0M7WUFDcEMsMEJBQTBCO1lBQzFCLGdDQUFnQztZQUNoQyxrQ0FBa0M7WUFDbEMseUNBQXlDO1lBQ3pDLGlDQUFpQztZQUNqQyx5Q0FBeUM7WUFDekMsc0NBQXNDLEVBbEJYLCtCQUErQixhQXNCaEQsWUFBWSxFQUFFLGVBQWUsRUFBRSxnQkFBZ0IsRUFBRSxnQkFBZ0IsRUFBRSxxQkFBcUIsRUFBRSxvQkFBb0IsRUFBRSwyQkFBMkIsRUFBRSxhQUFhLEVBQUUsYUFBYTtZQW5CbkwsYUFBYTtZQUNiLGdCQUFnQjtZQUNoQiw0QkFBNEI7WUFDNUIseUJBQXlCO1lBQ3pCLGdDQUFnQztZQUNoQyxxQ0FBcUM7WUFDckMsNkJBQTZCO1lBQzdCLDZCQUE2QjtZQUM3QixvQ0FBb0M7WUFDcEMsMEJBQTBCO1lBQzFCLGdDQUFnQztZQUNoQyxrQ0FBa0M7WUFDbEMseUNBQXlDO1lBQ3pDLGlDQUFpQztZQUNqQyx5Q0FBeUM7WUFDekMsc0NBQXNDO2dIQVEzQixtQkFBbUIsWUFKcEIsWUFBWSxFQUFFLGVBQWUsRUFBRSxnQkFBZ0IsRUFBRSxnQkFBZ0IsRUFBRSxxQkFBcUIsRUFBRSxvQkFBb0IsRUFBRSwyQkFBMkIsRUFBRSxhQUFhLEVBQUUsYUFBYTs7NEZBSXhLLG1CQUFtQjtrQkFML0IsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUUsQ0FBQyxZQUFZLEVBQUUsZUFBZSxFQUFFLGdCQUFnQixFQUFFLGdCQUFnQixFQUFFLHFCQUFxQixFQUFFLG9CQUFvQixFQUFFLDJCQUEyQixFQUFFLGFBQWEsRUFBRSxhQUFhLENBQUM7b0JBQ3BMLFlBQVksRUFBRSxDQUFDLEdBQUcsWUFBWSxFQUFFLEdBQUcsbUJBQW1CLENBQUM7b0JBQ3ZELE9BQU8sRUFBRSxZQUFZO2lCQUN0QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE1hdFJpcHBsZU1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2NvcmUnO1xuaW1wb3J0IHsgRGJ4Um91dGVyQW5jaG9yTW9kdWxlIH0gZnJvbSAnLi4vLi4vcm91dGVyL2xheW91dC9hbmNob3IvYW5jaG9yLm1vZHVsZSc7XG5pbXBvcnQgeyBEYnhMb2FkaW5nTW9kdWxlIH0gZnJvbSAnLi4vLi4vbG9hZGluZy9sb2FkaW5nLm1vZHVsZSc7XG5pbXBvcnQgeyBNYXRJY29uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaWNvbic7XG5pbXBvcnQgeyBNYXRMaXN0TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvbGlzdCc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IERieEluamVjdGlvbkNvbXBvbmVudE1vZHVsZSB9IGZyb20gJ0BkZXJlZWtiL2RieC1jb3JlJztcbmltcG9ydCB7IERieExpc3RDb21wb25lbnQsIERieExpc3RJbnRlcm5hbENvbnRlbnREaXJlY3RpdmUgfSBmcm9tICcuL2xpc3QuY29tcG9uZW50JztcbmltcG9ydCB7IERieExpc3RFbXB0eUNvbnRlbnRDb21wb25lbnQgfSBmcm9tICcuL2xpc3QuY29udGVudC5lbXB0eS5jb21wb25lbnQnO1xuaW1wb3J0IHsgSW5maW5pdGVTY3JvbGxNb2R1bGUgfSBmcm9tICduZ3gtaW5maW5pdGUtc2Nyb2xsJztcbmltcG9ydCB7IERieFNlbGVjdGlvblZhbHVlTGlzdFZpZXdDb250ZW50Q29tcG9uZW50LCBEYnhTZWxlY3Rpb25WYWx1ZUxpc3RWaWV3Q29tcG9uZW50IH0gZnJvbSAnLi9saXN0LnZpZXcudmFsdWUuc2VsZWN0aW9uLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEYnhWYWx1ZUxpc3RWaWV3Q29udGVudENvbXBvbmVudCwgRGJ4VmFsdWVMaXN0Vmlld0NvbXBvbmVudCwgRGJ4VmFsdWVMaXN0Vmlld0NvbnRlbnRHcm91cENvbXBvbmVudCB9IGZyb20gJy4vbGlzdC52aWV3LnZhbHVlLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEYnhWYWx1ZUxpc3RJdGVtTW9kaWZpZXJEaXJlY3RpdmUgfSBmcm9tICcuL2xpc3Qudmlldy52YWx1ZS5tb2RpZmllci5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgRGJ4TGlzdEl0ZW1EaXNhYmxlUmlwcGxlTW9kaWZpZXJEaXJlY3RpdmUgfSBmcm9tICcuL2xpc3Qudmlldy52YWx1ZS5tb2RpZmllci5yaXBwbGUuZGlyZWN0aXZlJztcbmltcG9ydCB7IERieFZhbHVlTGlzdEdyaWRWaWV3Q29udGVudENvbXBvbmVudCwgRGJ4VmFsdWVMaXN0R3JpZFNpemVEaXJlY3RpdmUsIERieFZhbHVlTGlzdEdyaWRWaWV3Q29tcG9uZW50IH0gZnJvbSAnLi9saXN0LmdyaWQudmlldy5jb21wb25lbnQnO1xuaW1wb3J0IHsgRmxleExheW91dE1vZHVsZSB9IGZyb20gJ0BuZ2JyYWNrZXQvbmd4LWxheW91dCc7XG5pbXBvcnQgeyBEYnhMaXN0SXRlbUlzU2VsZWN0ZWRNb2RpZmllckRpcmVjdGl2ZSB9IGZyb20gJy4vbGlzdC52aWV3LnZhbHVlLm1vZGlmaWVyLnNlbGVjdGlvbi5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgRGJ4TGlzdFRpdGxlR3JvdXBEaXJlY3RpdmUsIERieExpc3RUaXRsZUdyb3VwSGVhZGVyQ29tcG9uZW50IH0gZnJvbSAnLi9saXN0LnZpZXcudmFsdWUuZ3JvdXAudGl0bGUuZGlyZWN0aXZlJztcblxuY29uc3QgcHJpdmF0ZURlY2xhcmF0aW9ucyA9IFtEYnhMaXN0SW50ZXJuYWxDb250ZW50RGlyZWN0aXZlXTtcblxuY29uc3QgZGVjbGFyYXRpb25zID0gW1xuICAvLyBkaXJlY3RpdmVzXG4gIERieExpc3RDb21wb25lbnQsXG4gIERieExpc3RFbXB0eUNvbnRlbnRDb21wb25lbnQsXG4gIERieFZhbHVlTGlzdFZpZXdDb21wb25lbnQsXG4gIERieFZhbHVlTGlzdFZpZXdDb250ZW50Q29tcG9uZW50LFxuICBEYnhWYWx1ZUxpc3RWaWV3Q29udGVudEdyb3VwQ29tcG9uZW50LFxuICBEYnhWYWx1ZUxpc3RHcmlkU2l6ZURpcmVjdGl2ZSxcbiAgRGJ4VmFsdWVMaXN0R3JpZFZpZXdDb21wb25lbnQsXG4gIERieFZhbHVlTGlzdEdyaWRWaWV3Q29udGVudENvbXBvbmVudCxcbiAgRGJ4TGlzdFRpdGxlR3JvdXBEaXJlY3RpdmUsXG4gIERieExpc3RUaXRsZUdyb3VwSGVhZGVyQ29tcG9uZW50LFxuICBEYnhTZWxlY3Rpb25WYWx1ZUxpc3RWaWV3Q29tcG9uZW50LFxuICBEYnhTZWxlY3Rpb25WYWx1ZUxpc3RWaWV3Q29udGVudENvbXBvbmVudCxcbiAgRGJ4VmFsdWVMaXN0SXRlbU1vZGlmaWVyRGlyZWN0aXZlLFxuICBEYnhMaXN0SXRlbURpc2FibGVSaXBwbGVNb2RpZmllckRpcmVjdGl2ZSxcbiAgRGJ4TGlzdEl0ZW1Jc1NlbGVjdGVkTW9kaWZpZXJEaXJlY3RpdmVcbl07XG5cbkBOZ01vZHVsZSh7XG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIE1hdFJpcHBsZU1vZHVsZSwgRmxleExheW91dE1vZHVsZSwgRGJ4TG9hZGluZ01vZHVsZSwgRGJ4Um91dGVyQW5jaG9yTW9kdWxlLCBJbmZpbml0ZVNjcm9sbE1vZHVsZSwgRGJ4SW5qZWN0aW9uQ29tcG9uZW50TW9kdWxlLCBNYXRMaXN0TW9kdWxlLCBNYXRJY29uTW9kdWxlXSxcbiAgZGVjbGFyYXRpb25zOiBbLi4uZGVjbGFyYXRpb25zLCAuLi5wcml2YXRlRGVjbGFyYXRpb25zXSxcbiAgZXhwb3J0czogZGVjbGFyYXRpb25zXG59KVxuZXhwb3J0IGNsYXNzIERieExpc3RMYXlvdXRNb2R1bGUge31cbiJdfQ==
|