@dereekb/dbx-web 10.0.23 → 10.0.24

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@dereekb/dbx-web/calendar",
3
- "version": "10.0.23",
3
+ "version": "10.0.24",
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=
@@ -33,9 +33,9 @@ export class DbxLoadingProgressComponent {
33
33
  <mat-progress-bar *ngSwitchCase="true" [mode]="bmode" [color]="color" [bufferValue]="bufferValue" [value]="value" style="margin: auto;"></mat-progress-bar>
34
34
  <mat-progress-spinner *ngSwitchDefault [diameter]="diameter || 96" [mode]="smode" [color]="color" [value]="value" style="margin: auto;"></mat-progress-spinner>
35
35
  </ng-container>
36
- <div *ngIf="text" class="hint">{{ text }}</div>
36
+ <div *ngIf="text" class="dbx-loading-progress-hint dbx-hint dbx-small" [ngClass]="{ 'text-center': !linear }">{{ text }}</div>
37
37
  </div>
38
- `, isInline: true, dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i1.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { kind: "component", type: i2.MatProgressSpinner, selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "mode", "value", "diameter", "strokeWidth"], exportAs: ["matProgressSpinner"] }, { kind: "component", type: i3.MatProgressBar, selector: "mat-progress-bar", inputs: ["color", "value", "bufferValue", "mode"], outputs: ["animationEnd"], exportAs: ["matProgressBar"] }] }); }
38
+ `, isInline: true, dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i1.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { kind: "component", type: i2.MatProgressSpinner, selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "mode", "value", "diameter", "strokeWidth"], exportAs: ["matProgressSpinner"] }, { kind: "component", type: i3.MatProgressBar, selector: "mat-progress-bar", inputs: ["color", "value", "bufferValue", "mode"], outputs: ["animationEnd"], exportAs: ["matProgressBar"] }] }); }
39
39
  }
40
40
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DbxLoadingProgressComponent, decorators: [{
41
41
  type: Component,
@@ -47,7 +47,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
47
47
  <mat-progress-bar *ngSwitchCase="true" [mode]="bmode" [color]="color" [bufferValue]="bufferValue" [value]="value" style="margin: auto;"></mat-progress-bar>
48
48
  <mat-progress-spinner *ngSwitchDefault [diameter]="diameter || 96" [mode]="smode" [color]="color" [value]="value" style="margin: auto;"></mat-progress-spinner>
49
49
  </ng-container>
50
- <div *ngIf="text" class="hint">{{ text }}</div>
50
+ <div *ngIf="text" class="dbx-loading-progress-hint dbx-hint dbx-small" [ngClass]="{ 'text-center': !linear }">{{ text }}</div>
51
51
  </div>
52
52
  `
53
53
  }]
@@ -66,4 +66,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
66
66
  }], diameter: [{
67
67
  type: Input
68
68
  }] } });
69
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9hZGluZy1wcm9ncmVzcy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3NyYy9saWIvbG9hZGluZy9sb2FkaW5nLXByb2dyZXNzLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQzs7Ozs7QUFNakQsTUFBTSxDQUFDLE1BQU0saUNBQWlDLEdBQUcsRUFBRSxDQUFDO0FBRXBEOztHQUVHO0FBYUgsTUFBTSxPQUFPLDJCQUEyQjtJQVp4QztRQWFVLGNBQVMsR0FBVyxpQ0FBaUMsQ0FBQztRQVM5RCxTQUFJLEdBQTBDLGVBQWUsQ0FBQztRQUc5RCxVQUFLLEdBQWlCLFNBQVMsQ0FBQztRQU1oQyxnQkFBVyxHQUFXLFNBQThCLENBQUMsQ0FBQyw2REFBNkQ7S0FrQnBIO0lBaEJDLElBQ0ksUUFBUTtRQUNWLE9BQU8sSUFBSSxDQUFDLFNBQVMsQ0FBQztJQUN4QixDQUFDO0lBRUQsSUFBSSxRQUFRLENBQUMsUUFBdUI7UUFDbEMsSUFBSSxDQUFDLFNBQVMsR0FBRyxRQUFRLElBQUksaUNBQWlDLENBQUM7SUFDakUsQ0FBQztJQUVELElBQUksS0FBSztRQUNQLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQztJQUNuQixDQUFDO0lBRUQsSUFBSSxLQUFLO1FBQ1AsT0FBTyxJQUFJLENBQUMsSUFBMkIsQ0FBQztJQUMxQyxDQUFDOytHQXBDVSwyQkFBMkI7bUdBQTNCLDJCQUEyQix3TUFWNUI7Ozs7Ozs7O0dBUVQ7OzRGQUVVLDJCQUEyQjtrQkFadkMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsc0JBQXNCO29CQUNoQyxRQUFRLEVBQUU7Ozs7Ozs7O0dBUVQ7aUJBQ0Y7OEJBS0MsSUFBSTtzQkFESCxLQUFLO2dCQUlOLE1BQU07c0JBREwsS0FBSztnQkFJTixJQUFJO3NCQURILEtBQUs7Z0JBSU4sS0FBSztzQkFESixLQUFLO2dCQUlOLEtBQUs7c0JBREosS0FBSztnQkFJTixXQUFXO3NCQURWLEtBQUs7Z0JBSUYsUUFBUTtzQkFEWCxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgVGhlbWVQYWxldHRlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvY29yZSc7XG5pbXBvcnQgeyBQcm9ncmVzc0Jhck1vZGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9wcm9ncmVzcy1iYXInO1xuaW1wb3J0IHsgUHJvZ3Jlc3NTcGlubmVyTW9kZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3Byb2dyZXNzLXNwaW5uZXInO1xuaW1wb3J0IHsgTWF5YmUgfSBmcm9tICdAZGVyZWVrYi91dGlsJztcblxuZXhwb3J0IGNvbnN0IERFRkFVTFRfTE9BRElOR19QUk9HUkVTU19ESUFNRVRFUiA9IDk2O1xuXG4vKipcbiAqIEJhc2ljIGxvYWRpbmcgcHJvZ3Jlc3MgY29tcG9uZW50LlxuICovXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdkYngtbG9hZGluZy1wcm9ncmVzcycsXG4gIHRlbXBsYXRlOiBgXG4gICAgPGRpdiBjbGFzcz1cImxvYWRpbmctcHJvZ3Jlc3Mtdmlld1wiPlxuICAgICAgPG5nLWNvbnRhaW5lciBbbmdTd2l0Y2hdPVwibGluZWFyXCI+XG4gICAgICAgIDxtYXQtcHJvZ3Jlc3MtYmFyICpuZ1N3aXRjaENhc2U9XCJ0cnVlXCIgW21vZGVdPVwiYm1vZGVcIiBbY29sb3JdPVwiY29sb3JcIiBbYnVmZmVyVmFsdWVdPVwiYnVmZmVyVmFsdWVcIiBbdmFsdWVdPVwidmFsdWVcIiBzdHlsZT1cIm1hcmdpbjogYXV0bztcIj48L21hdC1wcm9ncmVzcy1iYXI+XG4gICAgICAgIDxtYXQtcHJvZ3Jlc3Mtc3Bpbm5lciAqbmdTd2l0Y2hEZWZhdWx0IFtkaWFtZXRlcl09XCJkaWFtZXRlciB8fCA5NlwiIFttb2RlXT1cInNtb2RlXCIgW2NvbG9yXT1cImNvbG9yXCIgW3ZhbHVlXT1cInZhbHVlXCIgc3R5bGU9XCJtYXJnaW46IGF1dG87XCI+PC9tYXQtcHJvZ3Jlc3Mtc3Bpbm5lcj5cbiAgICAgIDwvbmctY29udGFpbmVyPlxuICAgICAgPGRpdiAqbmdJZj1cInRleHRcIiBjbGFzcz1cImhpbnRcIj57eyB0ZXh0IH19PC9kaXY+XG4gICAgPC9kaXY+XG4gIGBcbn0pXG5leHBvcnQgY2xhc3MgRGJ4TG9hZGluZ1Byb2dyZXNzQ29tcG9uZW50IHtcbiAgcHJpdmF0ZSBfZGlhbWV0ZXI6IG51bWJlciA9IERFRkFVTFRfTE9BRElOR19QUk9HUkVTU19ESUFNRVRFUjtcblxuICBASW5wdXQoKVxuICB0ZXh0PzogTWF5YmU8c3RyaW5nPjtcblxuICBASW5wdXQoKVxuICBsaW5lYXI/OiBNYXliZTxib29sZWFuPjtcblxuICBASW5wdXQoKVxuICBtb2RlOiBQcm9ncmVzc0Jhck1vZGUgfCBQcm9ncmVzc1NwaW5uZXJNb2RlID0gJ2luZGV0ZXJtaW5hdGUnO1xuXG4gIEBJbnB1dCgpXG4gIGNvbG9yOiBUaGVtZVBhbGV0dGUgPSAncHJpbWFyeSc7XG5cbiAgQElucHV0KClcbiAgdmFsdWU/OiBudW1iZXI7XG5cbiAgQElucHV0KClcbiAgYnVmZmVyVmFsdWU6IG51bWJlciA9IHVuZGVmaW5lZCBhcyB1bmtub3duIGFzIG51bWJlcjsgLy8gbWF0LXByb2dyZXNzLWJhciB0eXBpbmcgcHJldmVudHMgdXNpbmcgdW5kZWZpbmVkIGFzIGEgdHlwZVxuXG4gIEBJbnB1dCgpXG4gIGdldCBkaWFtZXRlcigpOiBudW1iZXIge1xuICAgIHJldHVybiB0aGlzLl9kaWFtZXRlcjtcbiAgfVxuXG4gIHNldCBkaWFtZXRlcihkaWFtZXRlcjogTWF5YmU8bnVtYmVyPikge1xuICAgIHRoaXMuX2RpYW1ldGVyID0gZGlhbWV0ZXIgPz8gREVGQVVMVF9MT0FESU5HX1BST0dSRVNTX0RJQU1FVEVSO1xuICB9XG5cbiAgZ2V0IGJtb2RlKCk6IFByb2dyZXNzQmFyTW9kZSB7XG4gICAgcmV0dXJuIHRoaXMubW9kZTtcbiAgfVxuXG4gIGdldCBzbW9kZSgpOiBQcm9ncmVzc1NwaW5uZXJNb2RlIHtcbiAgICByZXR1cm4gdGhpcy5tb2RlIGFzIFByb2dyZXNzU3Bpbm5lck1vZGU7XG4gIH1cbn1cbiJdfQ==
69
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9hZGluZy1wcm9ncmVzcy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3NyYy9saWIvbG9hZGluZy9sb2FkaW5nLXByb2dyZXNzLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQzs7Ozs7QUFNakQsTUFBTSxDQUFDLE1BQU0saUNBQWlDLEdBQUcsRUFBRSxDQUFDO0FBRXBEOztHQUVHO0FBYUgsTUFBTSxPQUFPLDJCQUEyQjtJQVp4QztRQWFVLGNBQVMsR0FBVyxpQ0FBaUMsQ0FBQztRQVM5RCxTQUFJLEdBQTBDLGVBQWUsQ0FBQztRQUc5RCxVQUFLLEdBQWlCLFNBQVMsQ0FBQztRQU1oQyxnQkFBVyxHQUFXLFNBQThCLENBQUMsQ0FBQyw2REFBNkQ7S0FrQnBIO0lBaEJDLElBQ0ksUUFBUTtRQUNWLE9BQU8sSUFBSSxDQUFDLFNBQVMsQ0FBQztJQUN4QixDQUFDO0lBRUQsSUFBSSxRQUFRLENBQUMsUUFBdUI7UUFDbEMsSUFBSSxDQUFDLFNBQVMsR0FBRyxRQUFRLElBQUksaUNBQWlDLENBQUM7SUFDakUsQ0FBQztJQUVELElBQUksS0FBSztRQUNQLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQztJQUNuQixDQUFDO0lBRUQsSUFBSSxLQUFLO1FBQ1AsT0FBTyxJQUFJLENBQUMsSUFBMkIsQ0FBQztJQUMxQyxDQUFDOytHQXBDVSwyQkFBMkI7bUdBQTNCLDJCQUEyQix3TUFWNUI7Ozs7Ozs7O0dBUVQ7OzRGQUVVLDJCQUEyQjtrQkFadkMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsc0JBQXNCO29CQUNoQyxRQUFRLEVBQUU7Ozs7Ozs7O0dBUVQ7aUJBQ0Y7OEJBS0MsSUFBSTtzQkFESCxLQUFLO2dCQUlOLE1BQU07c0JBREwsS0FBSztnQkFJTixJQUFJO3NCQURILEtBQUs7Z0JBSU4sS0FBSztzQkFESixLQUFLO2dCQUlOLEtBQUs7c0JBREosS0FBSztnQkFJTixXQUFXO3NCQURWLEtBQUs7Z0JBSUYsUUFBUTtzQkFEWCxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgVGhlbWVQYWxldHRlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvY29yZSc7XG5pbXBvcnQgeyBQcm9ncmVzc0Jhck1vZGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9wcm9ncmVzcy1iYXInO1xuaW1wb3J0IHsgUHJvZ3Jlc3NTcGlubmVyTW9kZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3Byb2dyZXNzLXNwaW5uZXInO1xuaW1wb3J0IHsgTWF5YmUgfSBmcm9tICdAZGVyZWVrYi91dGlsJztcblxuZXhwb3J0IGNvbnN0IERFRkFVTFRfTE9BRElOR19QUk9HUkVTU19ESUFNRVRFUiA9IDk2O1xuXG4vKipcbiAqIEJhc2ljIGxvYWRpbmcgcHJvZ3Jlc3MgY29tcG9uZW50LlxuICovXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdkYngtbG9hZGluZy1wcm9ncmVzcycsXG4gIHRlbXBsYXRlOiBgXG4gICAgPGRpdiBjbGFzcz1cImxvYWRpbmctcHJvZ3Jlc3Mtdmlld1wiPlxuICAgICAgPG5nLWNvbnRhaW5lciBbbmdTd2l0Y2hdPVwibGluZWFyXCI+XG4gICAgICAgIDxtYXQtcHJvZ3Jlc3MtYmFyICpuZ1N3aXRjaENhc2U9XCJ0cnVlXCIgW21vZGVdPVwiYm1vZGVcIiBbY29sb3JdPVwiY29sb3JcIiBbYnVmZmVyVmFsdWVdPVwiYnVmZmVyVmFsdWVcIiBbdmFsdWVdPVwidmFsdWVcIiBzdHlsZT1cIm1hcmdpbjogYXV0bztcIj48L21hdC1wcm9ncmVzcy1iYXI+XG4gICAgICAgIDxtYXQtcHJvZ3Jlc3Mtc3Bpbm5lciAqbmdTd2l0Y2hEZWZhdWx0IFtkaWFtZXRlcl09XCJkaWFtZXRlciB8fCA5NlwiIFttb2RlXT1cInNtb2RlXCIgW2NvbG9yXT1cImNvbG9yXCIgW3ZhbHVlXT1cInZhbHVlXCIgc3R5bGU9XCJtYXJnaW46IGF1dG87XCI+PC9tYXQtcHJvZ3Jlc3Mtc3Bpbm5lcj5cbiAgICAgIDwvbmctY29udGFpbmVyPlxuICAgICAgPGRpdiAqbmdJZj1cInRleHRcIiBjbGFzcz1cImRieC1sb2FkaW5nLXByb2dyZXNzLWhpbnQgZGJ4LWhpbnQgZGJ4LXNtYWxsXCIgW25nQ2xhc3NdPVwieyAndGV4dC1jZW50ZXInOiAhbGluZWFyIH1cIj57eyB0ZXh0IH19PC9kaXY+XG4gICAgPC9kaXY+XG4gIGBcbn0pXG5leHBvcnQgY2xhc3MgRGJ4TG9hZGluZ1Byb2dyZXNzQ29tcG9uZW50IHtcbiAgcHJpdmF0ZSBfZGlhbWV0ZXI6IG51bWJlciA9IERFRkFVTFRfTE9BRElOR19QUk9HUkVTU19ESUFNRVRFUjtcblxuICBASW5wdXQoKVxuICB0ZXh0PzogTWF5YmU8c3RyaW5nPjtcblxuICBASW5wdXQoKVxuICBsaW5lYXI/OiBNYXliZTxib29sZWFuPjtcblxuICBASW5wdXQoKVxuICBtb2RlOiBQcm9ncmVzc0Jhck1vZGUgfCBQcm9ncmVzc1NwaW5uZXJNb2RlID0gJ2luZGV0ZXJtaW5hdGUnO1xuXG4gIEBJbnB1dCgpXG4gIGNvbG9yOiBUaGVtZVBhbGV0dGUgPSAncHJpbWFyeSc7XG5cbiAgQElucHV0KClcbiAgdmFsdWU/OiBudW1iZXI7XG5cbiAgQElucHV0KClcbiAgYnVmZmVyVmFsdWU6IG51bWJlciA9IHVuZGVmaW5lZCBhcyB1bmtub3duIGFzIG51bWJlcjsgLy8gbWF0LXByb2dyZXNzLWJhciB0eXBpbmcgcHJldmVudHMgdXNpbmcgdW5kZWZpbmVkIGFzIGEgdHlwZVxuXG4gIEBJbnB1dCgpXG4gIGdldCBkaWFtZXRlcigpOiBudW1iZXIge1xuICAgIHJldHVybiB0aGlzLl9kaWFtZXRlcjtcbiAgfVxuXG4gIHNldCBkaWFtZXRlcihkaWFtZXRlcjogTWF5YmU8bnVtYmVyPikge1xuICAgIHRoaXMuX2RpYW1ldGVyID0gZGlhbWV0ZXIgPz8gREVGQVVMVF9MT0FESU5HX1BST0dSRVNTX0RJQU1FVEVSO1xuICB9XG5cbiAgZ2V0IGJtb2RlKCk6IFByb2dyZXNzQmFyTW9kZSB7XG4gICAgcmV0dXJuIHRoaXMubW9kZTtcbiAgfVxuXG4gIGdldCBzbW9kZSgpOiBQcm9ncmVzc1NwaW5uZXJNb2RlIHtcbiAgICByZXR1cm4gdGhpcy5tb2RlIGFzIFByb2dyZXNzU3Bpbm5lck1vZGU7XG4gIH1cbn1cbiJdfQ==