@dereekb/dbx-web 9.23.28 → 9.24.1
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 +2 -2
- package/esm2020/lib/interaction/dialog/dialog.content.footer.component.mjs +13 -4
- package/esm2020/lib/interaction/filter/filter.popover.component.mjs +13 -8
- package/esm2020/lib/interaction/filter/filter.wrapper.component.mjs +12 -8
- package/esm2020/lib/interaction/popover/popover.service.mjs +8 -5
- package/esm2020/lib/router/layout/anchorlist/anchorlist.component.mjs +7 -4
- package/fesm2015/dereekb-dbx-web.mjs +62 -39
- package/fesm2015/dereekb-dbx-web.mjs.map +1 -1
- package/fesm2020/dereekb-dbx-web.mjs +58 -36
- package/fesm2020/dereekb-dbx-web.mjs.map +1 -1
- package/lib/interaction/dialog/dialog.content.footer.component.d.ts +9 -1
- package/lib/interaction/filter/filter.popover.component.d.ts +3 -3
- package/lib/interaction/filter/filter.wrapper.component.d.ts +2 -1
- package/lib/interaction/popover/popover.service.d.ts +5 -5
- package/lib/router/layout/anchorlist/_anchorlist.scss +2 -2
- package/lib/router/layout/anchorlist/anchorlist.component.d.ts +6 -2
- package/lib/router/layout/sidenav/_sidenav.scss +22 -4
- package/mapbox/package.json +3 -3
- package/package.json +3 -3
- package/table/package.json +3 -3
package/calendar/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@dereekb/dbx-web/calendar",
|
|
3
|
-
"version": "9.
|
|
3
|
+
"version": "9.24.1",
|
|
4
4
|
"peerDependencies": {
|
|
5
5
|
"@angular/common": "^14.2.0",
|
|
6
6
|
"@angular/core": "^14.2.0",
|
|
@@ -8,7 +8,7 @@
|
|
|
8
8
|
"rxjs": "^7.5.0",
|
|
9
9
|
"@angular/material": "^14.2.0",
|
|
10
10
|
"angular-calendar": "^0.30.1",
|
|
11
|
-
"@dereekb/dbx-web": "9.
|
|
11
|
+
"@dereekb/dbx-web": "9.24.1"
|
|
12
12
|
},
|
|
13
13
|
"dependencies": {
|
|
14
14
|
"tslib": "^2.3.0"
|
|
@@ -7,8 +7,13 @@ import * as i1 from "@angular/material/button";
|
|
|
7
7
|
export class DbxDialogContentFooterComponent {
|
|
8
8
|
constructor() {
|
|
9
9
|
this.closeText = 'Close';
|
|
10
|
+
this.buttonColor = undefined;
|
|
10
11
|
this.close = new EventEmitter();
|
|
11
12
|
}
|
|
13
|
+
set config(config) {
|
|
14
|
+
this.closeText = config?.closeText ?? 'Close';
|
|
15
|
+
this.buttonColor = config?.buttonColor ?? undefined;
|
|
16
|
+
}
|
|
12
17
|
closeClicked() {
|
|
13
18
|
this.close.emit(undefined);
|
|
14
19
|
}
|
|
@@ -17,15 +22,15 @@ export class DbxDialogContentFooterComponent {
|
|
|
17
22
|
}
|
|
18
23
|
}
|
|
19
24
|
DbxDialogContentFooterComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxDialogContentFooterComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
20
|
-
DbxDialogContentFooterComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: DbxDialogContentFooterComponent, selector: "dbx-dialog-content-footer", inputs: { closeText: "closeText" }, outputs: { close: "close" }, host: { classAttribute: "dbx-dialog-content-footer" }, ngImport: i0, template: `
|
|
21
|
-
<button mat-raised-button (click)="closeClicked()">{{ closeText }}</button>
|
|
25
|
+
DbxDialogContentFooterComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: DbxDialogContentFooterComponent, selector: "dbx-dialog-content-footer", inputs: { closeText: "closeText", buttonColor: "buttonColor", config: "config" }, outputs: { close: "close" }, host: { classAttribute: "dbx-dialog-content-footer" }, ngImport: i0, template: `
|
|
26
|
+
<button mat-raised-button [color]="buttonColor" (click)="closeClicked()">{{ closeText }}</button>
|
|
22
27
|
`, isInline: true, dependencies: [{ kind: "component", type: i1.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }] });
|
|
23
28
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxDialogContentFooterComponent, decorators: [{
|
|
24
29
|
type: Component,
|
|
25
30
|
args: [{
|
|
26
31
|
selector: 'dbx-dialog-content-footer',
|
|
27
32
|
template: `
|
|
28
|
-
<button mat-raised-button (click)="closeClicked()">{{ closeText }}</button>
|
|
33
|
+
<button mat-raised-button [color]="buttonColor" (click)="closeClicked()">{{ closeText }}</button>
|
|
29
34
|
`,
|
|
30
35
|
host: {
|
|
31
36
|
class: 'dbx-dialog-content-footer'
|
|
@@ -33,7 +38,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
33
38
|
}]
|
|
34
39
|
}], propDecorators: { closeText: [{
|
|
35
40
|
type: Input
|
|
41
|
+
}], buttonColor: [{
|
|
42
|
+
type: Input
|
|
36
43
|
}], close: [{
|
|
37
44
|
type: Output
|
|
45
|
+
}], config: [{
|
|
46
|
+
type: Input
|
|
38
47
|
}] } });
|
|
39
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
48
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlhbG9nLmNvbnRlbnQuZm9vdGVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC13ZWIvc3JjL2xpYi9pbnRlcmFjdGlvbi9kaWFsb2cvZGlhbG9nLmNvbnRlbnQuZm9vdGVyLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQWEsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7QUFTbEY7O0dBRUc7QUFVSCxNQUFNLE9BQU8sK0JBQStCO0lBVDVDO1FBV0UsY0FBUyxHQUFHLE9BQU8sQ0FBQztRQUdwQixnQkFBVyxHQUFpQixTQUFTLENBQUM7UUFHN0IsVUFBSyxHQUFHLElBQUksWUFBWSxFQUFRLENBQUM7S0FlM0M7SUFiQyxJQUNJLE1BQU0sQ0FBQyxNQUEyQztRQUNwRCxJQUFJLENBQUMsU0FBUyxHQUFHLE1BQU0sRUFBRSxTQUFTLElBQUksT0FBTyxDQUFDO1FBQzlDLElBQUksQ0FBQyxXQUFXLEdBQUcsTUFBTSxFQUFFLFdBQVcsSUFBSSxTQUFTLENBQUM7SUFDdEQsQ0FBQztJQUVELFlBQVk7UUFDVixJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUM3QixDQUFDO0lBRUQsV0FBVztRQUNULElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxFQUFFLENBQUM7SUFDeEIsQ0FBQzs7NkhBdEJVLCtCQUErQjtpSEFBL0IsK0JBQStCLHVPQVBoQzs7R0FFVDs0RkFLVSwrQkFBK0I7a0JBVDNDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLDJCQUEyQjtvQkFDckMsUUFBUSxFQUFFOztHQUVUO29CQUNELElBQUksRUFBRTt3QkFDSixLQUFLLEVBQUUsMkJBQTJCO3FCQUNuQztpQkFDRjs4QkFHQyxTQUFTO3NCQURSLEtBQUs7Z0JBSU4sV0FBVztzQkFEVixLQUFLO2dCQUlHLEtBQUs7c0JBRGIsTUFBTTtnQkFJSCxNQUFNO3NCQURULEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE9uRGVzdHJveSwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBUaGVtZVBhbGV0dGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9jb3JlJztcbmltcG9ydCB7IE1heWJlIH0gZnJvbSAnQGRlcmVla2IvdXRpbCc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgRGJ4RGlhbG9nQ29udGVudEZvb3RlckNvbmZpZyB7XG4gIGJ1dHRvbkNvbG9yPzogVGhlbWVQYWxldHRlO1xuICBjbG9zZVRleHQ/OiBzdHJpbmc7XG59XG5cbi8qKlxuICogQ29tcG9uZW50IHVzZWQgdG8gc2hvdyBhIGNsb3NlIGJ1dHRvbiBhdCB0aGUgYm90dG9tIG9mIGEgZGlhbG9nLlxuICovXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdkYngtZGlhbG9nLWNvbnRlbnQtZm9vdGVyJyxcbiAgdGVtcGxhdGU6IGBcbiAgICA8YnV0dG9uIG1hdC1yYWlzZWQtYnV0dG9uIFtjb2xvcl09XCJidXR0b25Db2xvclwiIChjbGljayk9XCJjbG9zZUNsaWNrZWQoKVwiPnt7IGNsb3NlVGV4dCB9fTwvYnV0dG9uPlxuICBgLFxuICBob3N0OiB7XG4gICAgY2xhc3M6ICdkYngtZGlhbG9nLWNvbnRlbnQtZm9vdGVyJ1xuICB9XG59KVxuZXhwb3J0IGNsYXNzIERieERpYWxvZ0NvbnRlbnRGb290ZXJDb21wb25lbnQgaW1wbGVtZW50cyBPbkRlc3Ryb3kge1xuICBASW5wdXQoKVxuICBjbG9zZVRleHQgPSAnQ2xvc2UnO1xuXG4gIEBJbnB1dCgpXG4gIGJ1dHRvbkNvbG9yOiBUaGVtZVBhbGV0dGUgPSB1bmRlZmluZWQ7XG5cbiAgQE91dHB1dCgpXG4gIHJlYWRvbmx5IGNsb3NlID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xuXG4gIEBJbnB1dCgpXG4gIHNldCBjb25maWcoY29uZmlnOiBNYXliZTxEYnhEaWFsb2dDb250ZW50Rm9vdGVyQ29uZmlnPikge1xuICAgIHRoaXMuY2xvc2VUZXh0ID0gY29uZmlnPy5jbG9zZVRleHQgPz8gJ0Nsb3NlJztcbiAgICB0aGlzLmJ1dHRvbkNvbG9yID0gY29uZmlnPy5idXR0b25Db2xvciA/PyB1bmRlZmluZWQ7XG4gIH1cblxuICBjbG9zZUNsaWNrZWQoKSB7XG4gICAgdGhpcy5jbG9zZS5lbWl0KHVuZGVmaW5lZCk7XG4gIH1cblxuICBuZ09uRGVzdHJveSgpOiB2b2lkIHtcbiAgICB0aGlzLmNsb3NlLmNvbXBsZXRlKCk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { Component } from '@angular/core';
|
|
2
|
-
import { BehaviorSubject, map, skip, first } from 'rxjs';
|
|
2
|
+
import { BehaviorSubject, map, skip, first, defaultIfEmpty } from 'rxjs';
|
|
3
3
|
import { AbstractPopoverDirective } from '../popover/abstract.popover.directive';
|
|
4
4
|
import { DbxPopoverComponent } from '../popover/popover.component';
|
|
5
5
|
import { filterMaybe, SubscriptionObject } from '@dereekb/rxjs';
|
|
@@ -38,8 +38,9 @@ export class DbxFilterPopoverComponent extends AbstractPopoverDirective {
|
|
|
38
38
|
if (initialFilterObs && filterSource.initWithFilter) {
|
|
39
39
|
filterSource.initWithFilter(initialFilterObs);
|
|
40
40
|
}
|
|
41
|
-
if (closeOnFilterChange) {
|
|
42
|
-
this._closeOnChangeSub.subscription = filterSource.filter$.pipe(skip(1), filterMaybe(), first()).subscribe(() => {
|
|
41
|
+
if (closeOnFilterChange !== false) {
|
|
42
|
+
this._closeOnChangeSub.subscription = filterSource.filter$.pipe(skip(1), filterMaybe(), first(), defaultIfEmpty(undefined)).subscribe(() => {
|
|
43
|
+
console.log();
|
|
43
44
|
this.close();
|
|
44
45
|
});
|
|
45
46
|
}
|
|
@@ -48,18 +49,22 @@ export class DbxFilterPopoverComponent extends AbstractPopoverDirective {
|
|
|
48
49
|
return config;
|
|
49
50
|
}));
|
|
50
51
|
}
|
|
51
|
-
static openPopover(popupService, { origin, header, icon,
|
|
52
|
+
static openPopover(popupService, { width, height, isResizable, origin, header, icon, customFilterComponentClass, presetFilterComponentClass, connector, initialFilterObs, closeOnFilterChange }, popoverKey) {
|
|
52
53
|
return popupService.open({
|
|
53
54
|
key: popoverKey ?? DEFAULT_FILTER_POPOVER_KEY,
|
|
54
55
|
origin,
|
|
55
56
|
componentClass: DbxFilterPopoverComponent,
|
|
57
|
+
width,
|
|
58
|
+
height,
|
|
59
|
+
isResizable,
|
|
56
60
|
data: {
|
|
57
61
|
header,
|
|
58
62
|
icon,
|
|
59
|
-
initialFilterObs: inputSource,
|
|
60
|
-
connector,
|
|
61
63
|
customFilterComponentClass,
|
|
62
|
-
presetFilterComponentClass
|
|
64
|
+
presetFilterComponentClass,
|
|
65
|
+
connector,
|
|
66
|
+
initialFilterObs,
|
|
67
|
+
closeOnFilterChange
|
|
63
68
|
}
|
|
64
69
|
});
|
|
65
70
|
}
|
|
@@ -103,4 +108,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
103
108
|
type: Component,
|
|
104
109
|
args: [{ template: "<dbx-popover-content>\n <!-- Header -->\n <dbx-popover-header [icon]=\"icon\" [header]=\"header\">\n <ng-container *ngIf=\"showSwitchButtons\" [ngSwitch]=\"showPreset$ | async\">\n <button *ngSwitchCase=\"true\" mat-flat-button color=\"accent\" (click)=\"showCustom()\">Custom</button>\n <button *ngSwitchCase=\"false\" mat-flat-button color=\"accent\" (click)=\"showPresets()\">Presets</button>\n </ng-container>\n </dbx-popover-header>\n <!-- Content -->\n <dbx-popover-scroll-content>\n <dbx-injection [config]=\"config$ | async\"></dbx-injection>\n </dbx-popover-scroll-content>\n</dbx-popover-content>\n" }]
|
|
105
110
|
}], ctorParameters: function () { return [{ type: i1.DbxPopoverComponent }]; } });
|
|
106
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter.popover.component.js","sourceRoot":"","sources":["../../../../../../../packages/dbx-web/src/lib/interaction/filter/filter.popover.component.ts","../../../../../../../packages/dbx-web/src/lib/interaction/filter/filter.popover.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DbxInjectionComponentConfig } from '@dereekb/dbx-core';\nimport { Component, ElementRef, Type, OnInit, OnDestroy } from '@angular/core';\nimport { NgPopoverRef } from 'ng-overlay-container';\nimport { Observable, BehaviorSubject, map, skip, first } from 'rxjs';\nimport { AbstractPopoverDirective } from '../popover/abstract.popover.directive';\nimport { DbxPopoverComponent } from '../popover/popover.component';\nimport { DbxPopoverService } from '../popover/popover.service';\nimport { FilterSource, FilterSourceConnector, PresetFilterSource, filterMaybe, SubscriptionObject } from '@dereekb/rxjs';\nimport { DbxPopoverKey } from '../popover/popover';\n\nexport interface DbxFilterComponentParams<F extends object = object, P extends string = string> {\n  /**\n   * Custom icon\n   *\n   * Defaults to \"filter_list\"\n   */\n  icon?: string;\n  /**\n   * Custom header text\n   *\n   * Defaults to \"Filter\"\n   */\n  header?: string;\n  /**\n   * Custom filter component to initialize.\n   */\n  customFilterComponentClass?: Type<FilterSource<F>>;\n  /**\n   * Preset filter component to initialize.\n   */\n  presetFilterComponentClass?: Type<PresetFilterSource<F, P>>;\n  /**\n   * The connector to use.\n   */\n  connector: FilterSourceConnector<F>;\n  /**\n   * (Optional) Inital filter to pass to the filter source.\n   */\n  initialFilterObs?: Observable<F>;\n  /**\n   * (Optional) Whether or not to close the component if the filter changes.\n   *\n   * True by default.\n   */\n  closeOnFilterChange?: boolean;\n}\n\nexport interface DbxFilterPopoverComponentParams<F extends object = object> extends DbxFilterComponentParams<F> {\n  /**\n   * Origin to add the popover to.\n   */\n  origin: ElementRef;\n}\n\nexport const DEFAULT_FILTER_POPOVER_KEY = 'filter';\n\n@Component({\n  templateUrl: './filter.popover.component.html'\n})\nexport class DbxFilterPopoverComponent<F extends object> extends AbstractPopoverDirective<unknown, DbxFilterComponentParams<F>> implements OnInit, OnDestroy {\n  private _closeOnChangeSub = new SubscriptionObject();\n\n  /**\n   * Whether or not to display buttons to toggle between custom and preset filters.\n   */\n  readonly showSwitchButtons = Boolean(this.config.customFilterComponentClass && this.config.presetFilterComponentClass);\n\n  private _showPreset = new BehaviorSubject<boolean>(false);\n  readonly showPreset$ = this._showPreset.asObservable();\n\n  readonly config$: Observable<DbxInjectionComponentConfig<FilterSource<F>>> = this._showPreset.pipe(\n    map((showPreset) => {\n      const { closeOnFilterChange = true, connector, initialFilterObs, customFilterComponentClass, presetFilterComponentClass } = this.config;\n      let componentClass: Type<FilterSource<F>>;\n\n      if (showPreset) {\n        componentClass = presetFilterComponentClass as Type<FilterSource<F>>;\n      } else {\n        componentClass = customFilterComponentClass as Type<FilterSource<F>>;\n      }\n\n      const config: DbxInjectionComponentConfig<FilterSource<F>> = {\n        componentClass,\n        init: (filterSource) => {\n          connector.connectWithSource(filterSource);\n\n          if (initialFilterObs && filterSource.initWithFilter) {\n            filterSource.initWithFilter(initialFilterObs);\n          }\n\n          if (closeOnFilterChange) {\n            this._closeOnChangeSub.subscription = filterSource.filter$.pipe(skip(1), filterMaybe(), first()).subscribe(() => {\n              this.close();\n            });\n          }\n        }\n      };\n\n      return config;\n    })\n  );\n\n  static openPopover<F extends object>(popupService: DbxPopoverService, { origin, header, icon, initialFilterObs: inputSource, connector, customFilterComponentClass, presetFilterComponentClass }: DbxFilterPopoverComponentParams<F>, popoverKey?: DbxPopoverKey): NgPopoverRef {\n    return popupService.open({\n      key: popoverKey ?? DEFAULT_FILTER_POPOVER_KEY,\n      origin,\n      componentClass: DbxFilterPopoverComponent,\n      data: {\n        header,\n        icon,\n        initialFilterObs: inputSource,\n        connector,\n        customFilterComponentClass,\n        presetFilterComponentClass\n      } as DbxFilterComponentParams<F>\n    });\n  }\n\n  constructor(popover: DbxPopoverComponent<unknown, DbxFilterComponentParams<F>>) {\n    super(popover);\n  }\n\n  get config(): DbxFilterComponentParams<F> {\n    return this.popover.data as DbxFilterComponentParams<F>;\n  }\n\n  get icon() {\n    return this.config.icon ?? 'filter_list';\n  }\n\n  get header() {\n    return this.config.header ?? 'Filter';\n  }\n\n  ngOnInit(): void {\n    let showPreset = false;\n    const { customFilterComponentClass, presetFilterComponentClass } = this.config;\n\n    if (customFilterComponentClass) {\n      showPreset = false;\n    }\n\n    if (presetFilterComponentClass) {\n      showPreset = true;\n    }\n\n    if (!customFilterComponentClass && !presetFilterComponentClass) {\n      throw new Error('Requires a preset or custom class provided for DbxFilterPopover.');\n    }\n\n    this._showPreset.next(showPreset);\n  }\n\n  ngOnDestroy(): void {\n    this._closeOnChangeSub.destroy();\n    this._showPreset.complete();\n  }\n\n  showPresets() {\n    this._showPreset.next(true);\n  }\n\n  showCustom() {\n    this._showPreset.next(false);\n  }\n}\n","<dbx-popover-content>\n  <!-- Header -->\n  <dbx-popover-header [icon]=\"icon\" [header]=\"header\">\n    <ng-container *ngIf=\"showSwitchButtons\" [ngSwitch]=\"showPreset$ | async\">\n      <button *ngSwitchCase=\"true\" mat-flat-button color=\"accent\" (click)=\"showCustom()\">Custom</button>\n      <button *ngSwitchCase=\"false\" mat-flat-button color=\"accent\" (click)=\"showPresets()\">Presets</button>\n    </ng-container>\n  </dbx-popover-header>\n  <!-- Content -->\n  <dbx-popover-scroll-content>\n    <dbx-injection [config]=\"config$ | async\"></dbx-injection>\n  </dbx-popover-scroll-content>\n</dbx-popover-content>\n"]}
|
|
111
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter.popover.component.js","sourceRoot":"","sources":["../../../../../../../packages/dbx-web/src/lib/interaction/filter/filter.popover.component.ts","../../../../../../../packages/dbx-web/src/lib/interaction/filter/filter.popover.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DbxInjectionComponentConfig } from '@dereekb/dbx-core';\nimport { Component, ElementRef, Type, OnInit, OnDestroy } from '@angular/core';\nimport { NgPopoverRef } from 'ng-overlay-container';\nimport { Observable, BehaviorSubject, map, skip, first, defaultIfEmpty } from 'rxjs';\nimport { AbstractPopoverDirective } from '../popover/abstract.popover.directive';\nimport { DbxPopoverComponent } from '../popover/popover.component';\nimport { DbxPopoverConfigSizing, DbxPopoverService } from '../popover/popover.service';\nimport { FilterSource, FilterSourceConnector, PresetFilterSource, filterMaybe, SubscriptionObject, tapLog } from '@dereekb/rxjs';\nimport { DbxPopoverKey } from '../popover/popover';\n\nexport interface DbxFilterComponentParams<F extends object = object, P extends string = string> extends DbxPopoverConfigSizing {\n  /**\n   * Custom icon\n   *\n   * Defaults to \"filter_list\"\n   */\n  icon?: string;\n  /**\n   * Custom header text\n   *\n   * Defaults to \"Filter\"\n   */\n  header?: string;\n  /**\n   * Custom filter component to initialize.\n   */\n  customFilterComponentClass?: Type<FilterSource<F>>;\n  /**\n   * Preset filter component to initialize.\n   */\n  presetFilterComponentClass?: Type<PresetFilterSource<F, P>>;\n  /**\n   * The connector to use.\n   */\n  connector: FilterSourceConnector<F>;\n  /**\n   * (Optional) Inital filter to pass to the filter source.\n   */\n  initialFilterObs?: Observable<F>;\n  /**\n   * (Optional) Whether or not to close the component if the filter changes.\n   *\n   * True by default.\n   */\n  closeOnFilterChange?: boolean;\n}\n\nexport interface DbxFilterPopoverComponentParams<F extends object = object> extends DbxFilterComponentParams<F> {\n  /**\n   * Origin to add the popover to.\n   */\n  origin: ElementRef;\n}\n\nexport const DEFAULT_FILTER_POPOVER_KEY = 'filter';\n\n@Component({\n  templateUrl: './filter.popover.component.html'\n})\nexport class DbxFilterPopoverComponent<F extends object> extends AbstractPopoverDirective<unknown, DbxFilterComponentParams<F>> implements OnInit, OnDestroy {\n  private _closeOnChangeSub = new SubscriptionObject();\n\n  /**\n   * Whether or not to display buttons to toggle between custom and preset filters.\n   */\n  readonly showSwitchButtons = Boolean(this.config.customFilterComponentClass && this.config.presetFilterComponentClass);\n\n  private _showPreset = new BehaviorSubject<boolean>(false);\n  readonly showPreset$ = this._showPreset.asObservable();\n\n  readonly config$: Observable<DbxInjectionComponentConfig<FilterSource<F>>> = this._showPreset.pipe(\n    map((showPreset) => {\n      const { closeOnFilterChange = true, connector, initialFilterObs, customFilterComponentClass, presetFilterComponentClass } = this.config;\n      let componentClass: Type<FilterSource<F>>;\n\n      if (showPreset) {\n        componentClass = presetFilterComponentClass as Type<FilterSource<F>>;\n      } else {\n        componentClass = customFilterComponentClass as Type<FilterSource<F>>;\n      }\n\n      const config: DbxInjectionComponentConfig<FilterSource<F>> = {\n        componentClass,\n        init: (filterSource) => {\n          connector.connectWithSource(filterSource);\n\n          if (initialFilterObs && filterSource.initWithFilter) {\n            filterSource.initWithFilter(initialFilterObs);\n          }\n\n          if (closeOnFilterChange !== false) {\n            this._closeOnChangeSub.subscription = filterSource.filter$.pipe(skip(1), filterMaybe(), first(), defaultIfEmpty(undefined)).subscribe(() => {\n              console.log();\n              this.close();\n            });\n          }\n        }\n      };\n\n      return config;\n    })\n  );\n\n  static openPopover<F extends object>(popupService: DbxPopoverService, { width, height, isResizable, origin, header, icon, customFilterComponentClass, presetFilterComponentClass, connector, initialFilterObs, closeOnFilterChange }: DbxFilterPopoverComponentParams<F>, popoverKey?: DbxPopoverKey): NgPopoverRef {\n    return popupService.open({\n      key: popoverKey ?? DEFAULT_FILTER_POPOVER_KEY,\n      origin,\n      componentClass: DbxFilterPopoverComponent,\n      width,\n      height,\n      isResizable,\n      data: {\n        header,\n        icon,\n        customFilterComponentClass,\n        presetFilterComponentClass,\n        connector,\n        initialFilterObs,\n        closeOnFilterChange\n      } as DbxFilterComponentParams<F>\n    });\n  }\n\n  constructor(popover: DbxPopoverComponent<unknown, DbxFilterComponentParams<F>>) {\n    super(popover);\n  }\n\n  get config(): DbxFilterComponentParams<F> {\n    return this.popover.data as DbxFilterComponentParams<F>;\n  }\n\n  get icon() {\n    return this.config.icon ?? 'filter_list';\n  }\n\n  get header() {\n    return this.config.header ?? 'Filter';\n  }\n\n  ngOnInit(): void {\n    let showPreset = false;\n    const { customFilterComponentClass, presetFilterComponentClass } = this.config;\n\n    if (customFilterComponentClass) {\n      showPreset = false;\n    }\n\n    if (presetFilterComponentClass) {\n      showPreset = true;\n    }\n\n    if (!customFilterComponentClass && !presetFilterComponentClass) {\n      throw new Error('Requires a preset or custom class provided for DbxFilterPopover.');\n    }\n\n    this._showPreset.next(showPreset);\n  }\n\n  ngOnDestroy(): void {\n    this._closeOnChangeSub.destroy();\n    this._showPreset.complete();\n  }\n\n  showPresets() {\n    this._showPreset.next(true);\n  }\n\n  showCustom() {\n    this._showPreset.next(false);\n  }\n}\n","<dbx-popover-content>\n  <!-- Header -->\n  <dbx-popover-header [icon]=\"icon\" [header]=\"header\">\n    <ng-container *ngIf=\"showSwitchButtons\" [ngSwitch]=\"showPreset$ | async\">\n      <button *ngSwitchCase=\"true\" mat-flat-button color=\"accent\" (click)=\"showCustom()\">Custom</button>\n      <button *ngSwitchCase=\"false\" mat-flat-button color=\"accent\" (click)=\"showPresets()\">Presets</button>\n    </ng-container>\n  </dbx-popover-header>\n  <!-- Content -->\n  <dbx-popover-scroll-content>\n    <dbx-injection [config]=\"config$ | async\"></dbx-injection>\n  </dbx-popover-scroll-content>\n</dbx-popover-content>\n"]}
|
|
@@ -3,10 +3,11 @@ import { AbstractDbxActionHandlerDirective, DbxActionContextStoreSourceInstance,
|
|
|
3
3
|
import { of } from 'rxjs';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
import * as i1 from "@dereekb/dbx-core";
|
|
6
|
-
import * as i2 from "
|
|
7
|
-
import * as i3 from "
|
|
8
|
-
import * as i4 from "@angular/
|
|
9
|
-
import * as i5 from "@angular/material/
|
|
6
|
+
import * as i2 from "@angular/common";
|
|
7
|
+
import * as i3 from "../../button/button.component";
|
|
8
|
+
import * as i4 from "@angular/flex-layout/flex";
|
|
9
|
+
import * as i5 from "@angular/material/icon";
|
|
10
|
+
import * as i6 from "@angular/material/button";
|
|
10
11
|
/**
|
|
11
12
|
* Action component used to simplify creating a filter form.
|
|
12
13
|
*
|
|
@@ -16,6 +17,7 @@ export class DbxFilterWrapperComponent extends AbstractDbxActionHandlerDirective
|
|
|
16
17
|
constructor(source, filterSourceDirective) {
|
|
17
18
|
super(source);
|
|
18
19
|
this.filterSourceDirective = filterSourceDirective;
|
|
20
|
+
this.showButtons = true;
|
|
19
21
|
this.applyRaised = true;
|
|
20
22
|
this.applyIcon = 'filter_list';
|
|
21
23
|
this.applyText = 'Filter';
|
|
@@ -34,15 +36,17 @@ export class DbxFilterWrapperComponent extends AbstractDbxActionHandlerDirective
|
|
|
34
36
|
}
|
|
35
37
|
}
|
|
36
38
|
DbxFilterWrapperComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxFilterWrapperComponent, deps: [{ token: i1.DbxActionContextStoreSourceInstance }, { token: i1.FilterSourceDirective }], target: i0.ɵɵFactoryTarget.Component });
|
|
37
|
-
DbxFilterWrapperComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: DbxFilterWrapperComponent, selector: "dbx-filter-wrapper", inputs: { applyRaised: "applyRaised", applyIcon: "applyIcon", applyText: "applyText" }, providers: [provideActionStoreSource(null)], usesInheritance: true, ngImport: i0, template: "<div class=\"dbx-filter-wrapper\">\n <div class=\"dbx-filter-wrapper-content\">\n <ng-content></ng-content>\n </div>\n <div fxLayout=\"row\">\n <dbx-button dbxActionButton [raised]=\"applyRaised\" [text]=\"applyText\" [icon]=\"applyIcon\"></dbx-button>\n <div class=\"spacer\"></div>\n <button mat-icon-button (click)=\"resetFilter()\">\n <mat-icon>clear</mat-icon>\n </button>\n </div>\n</div>\n", dependencies: [{ kind: "directive", type: i1.DbxActionButtonDirective, selector: "[dbxActionButton]" }, { kind: "component", type:
|
|
39
|
+
DbxFilterWrapperComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: DbxFilterWrapperComponent, selector: "dbx-filter-wrapper", inputs: { showButtons: "showButtons", applyRaised: "applyRaised", applyIcon: "applyIcon", applyText: "applyText" }, providers: [provideActionStoreSource(null)], usesInheritance: true, ngImport: i0, template: "<div class=\"dbx-filter-wrapper\">\n <div class=\"dbx-filter-wrapper-content\">\n <ng-content></ng-content>\n </div>\n <div *ngIf=\"showButtons\" fxLayout=\"row\">\n <dbx-button dbxActionButton [raised]=\"applyRaised\" [text]=\"applyText\" [icon]=\"applyIcon\"></dbx-button>\n <div class=\"spacer\"></div>\n <button mat-icon-button (click)=\"resetFilter()\">\n <mat-icon>clear</mat-icon>\n </button>\n </div>\n</div>\n", dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.DbxActionButtonDirective, selector: "[dbxActionButton]" }, { kind: "component", type: i3.DbxButtonComponent, selector: "dbx-button", inputs: ["type", "raised", "stroked", "flat", "iconOnly", "color", "customButtonColor", "customTextColor", "customSpinnerColor"] }, { kind: "directive", type: i4.DefaultLayoutDirective, selector: " [fxLayout], [fxLayout.xs], [fxLayout.sm], [fxLayout.md], [fxLayout.lg], [fxLayout.xl], [fxLayout.lt-sm], [fxLayout.lt-md], [fxLayout.lt-lg], [fxLayout.lt-xl], [fxLayout.gt-xs], [fxLayout.gt-sm], [fxLayout.gt-md], [fxLayout.gt-lg]", inputs: ["fxLayout", "fxLayout.xs", "fxLayout.sm", "fxLayout.md", "fxLayout.lg", "fxLayout.xl", "fxLayout.lt-sm", "fxLayout.lt-md", "fxLayout.lt-lg", "fxLayout.lt-xl", "fxLayout.gt-xs", "fxLayout.gt-sm", "fxLayout.gt-md", "fxLayout.gt-lg"] }, { kind: "component", type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i6.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }] });
|
|
38
40
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxFilterWrapperComponent, decorators: [{
|
|
39
41
|
type: Component,
|
|
40
|
-
args: [{ selector: 'dbx-filter-wrapper', providers: [provideActionStoreSource(null)], template: "<div class=\"dbx-filter-wrapper\">\n <div class=\"dbx-filter-wrapper-content\">\n <ng-content></ng-content>\n </div>\n <div fxLayout=\"row\">\n <dbx-button dbxActionButton [raised]=\"applyRaised\" [text]=\"applyText\" [icon]=\"applyIcon\"></dbx-button>\n <div class=\"spacer\"></div>\n <button mat-icon-button (click)=\"resetFilter()\">\n <mat-icon>clear</mat-icon>\n </button>\n </div>\n</div>\n" }]
|
|
41
|
-
}], ctorParameters: function () { return [{ type: i1.DbxActionContextStoreSourceInstance }, { type: i1.FilterSourceDirective }]; }, propDecorators: {
|
|
42
|
+
args: [{ selector: 'dbx-filter-wrapper', providers: [provideActionStoreSource(null)], template: "<div class=\"dbx-filter-wrapper\">\n <div class=\"dbx-filter-wrapper-content\">\n <ng-content></ng-content>\n </div>\n <div *ngIf=\"showButtons\" fxLayout=\"row\">\n <dbx-button dbxActionButton [raised]=\"applyRaised\" [text]=\"applyText\" [icon]=\"applyIcon\"></dbx-button>\n <div class=\"spacer\"></div>\n <button mat-icon-button (click)=\"resetFilter()\">\n <mat-icon>clear</mat-icon>\n </button>\n </div>\n</div>\n" }]
|
|
43
|
+
}], ctorParameters: function () { return [{ type: i1.DbxActionContextStoreSourceInstance }, { type: i1.FilterSourceDirective }]; }, propDecorators: { showButtons: [{
|
|
44
|
+
type: Input
|
|
45
|
+
}], applyRaised: [{
|
|
42
46
|
type: Input
|
|
43
47
|
}], applyIcon: [{
|
|
44
48
|
type: Input
|
|
45
49
|
}], applyText: [{
|
|
46
50
|
type: Input
|
|
47
51
|
}] } });
|
|
48
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
52
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLndyYXBwZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LXdlYi9zcmMvbGliL2ludGVyYWN0aW9uL2ZpbHRlci9maWx0ZXIud3JhcHBlci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3NyYy9saWIvaW50ZXJhY3Rpb24vZmlsdGVyL2ZpbHRlci53cmFwcGVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2pELE9BQU8sRUFBRSxpQ0FBaUMsRUFBRSxtQ0FBbUMsRUFBRSxxQkFBcUIsRUFBRSx3QkFBd0IsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQzVKLE9BQU8sRUFBRSxFQUFFLEVBQUUsTUFBTSxNQUFNLENBQUM7Ozs7Ozs7O0FBRTFCOzs7O0dBSUc7QUFNSCxNQUFNLE9BQU8seUJBQXVDLFNBQVEsaUNBQW9DO0lBYTlGLFlBQVksTUFBOEMsRUFBVyxxQkFBK0M7UUFDbEgsS0FBSyxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBRHFELDBCQUFxQixHQUFyQixxQkFBcUIsQ0FBMEI7UUFYcEgsZ0JBQVcsR0FBRyxJQUFJLENBQUM7UUFHbkIsZ0JBQVcsR0FBRyxJQUFJLENBQUM7UUFHbkIsY0FBUyxHQUFHLGFBQWEsQ0FBQztRQUcxQixjQUFTLEdBQUcsUUFBUSxDQUFDO1FBSW5CLDZCQUE2QjtRQUM3QixJQUFJLENBQUMseUJBQXlCLENBQUMsZUFBZSxHQUFHLENBQUMsTUFBUyxFQUFFLEVBQUU7WUFDN0QsSUFBSSxDQUFDLHFCQUFxQixDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsQ0FBQztZQUM3QyxPQUFPLEVBQUUsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUNsQixDQUFDLENBQUM7SUFDSixDQUFDO0lBRUQsV0FBVztRQUNULElBQUksQ0FBQyxNQUFNLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsMEJBQTBCO1FBQzNELElBQUksQ0FBQyxNQUFNLENBQUMsT0FBTyxFQUFFLENBQUM7SUFDeEIsQ0FBQztJQUVELFdBQVc7UUFDVCxJQUFJLENBQUMscUJBQXFCLENBQUMsV0FBVyxFQUFFLENBQUM7SUFDM0MsQ0FBQzs7dUhBN0JVLHlCQUF5QjsyR0FBekIseUJBQXlCLGlLQUZ6QixDQUFDLHdCQUF3QixDQUFDLElBQUksQ0FBQyxDQUFDLGlEQ1o3Qyw0YkFZQTs0RkRFYSx5QkFBeUI7a0JBTHJDLFNBQVM7K0JBQ0Usb0JBQW9CLGFBRW5CLENBQUMsd0JBQXdCLENBQUMsSUFBSSxDQUFDLENBQUM7OEpBSTNDLFdBQVc7c0JBRFYsS0FBSztnQkFJTixXQUFXO3NCQURWLEtBQUs7Z0JBSU4sU0FBUztzQkFEUixLQUFLO2dCQUlOLFNBQVM7c0JBRFIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEFic3RyYWN0RGJ4QWN0aW9uSGFuZGxlckRpcmVjdGl2ZSwgRGJ4QWN0aW9uQ29udGV4dFN0b3JlU291cmNlSW5zdGFuY2UsIEZpbHRlclNvdXJjZURpcmVjdGl2ZSwgcHJvdmlkZUFjdGlvblN0b3JlU291cmNlIH0gZnJvbSAnQGRlcmVla2IvZGJ4LWNvcmUnO1xuaW1wb3J0IHsgb2YgfSBmcm9tICdyeGpzJztcblxuLyoqXG4gKiBBY3Rpb24gY29tcG9uZW50IHVzZWQgdG8gc2ltcGxpZnkgY3JlYXRpbmcgYSBmaWx0ZXIgZm9ybS5cbiAqXG4gKiBQcm92aWRlcyBhIERieEFjdGlvbiBhbmQgY29uZmlndXJlcyB0aGUgYWN0aW9uIHRvIHNldCB0aGUgZmlsdGVyIG9uIGEgRmlsdGVyU291cmNlRGlyZWN0aXZlIHdoZW4gdHJpZ2dlcmVkLlxuICovXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdkYngtZmlsdGVyLXdyYXBwZXInLFxuICB0ZW1wbGF0ZVVybDogJy4vZmlsdGVyLndyYXBwZXIuY29tcG9uZW50Lmh0bWwnLFxuICBwcm92aWRlcnM6IFtwcm92aWRlQWN0aW9uU3RvcmVTb3VyY2UobnVsbCldXG59KVxuZXhwb3J0IGNsYXNzIERieEZpbHRlcldyYXBwZXJDb21wb25lbnQ8RiA9IHVua25vd24+IGV4dGVuZHMgQWJzdHJhY3REYnhBY3Rpb25IYW5kbGVyRGlyZWN0aXZlPEY+IHtcbiAgQElucHV0KClcbiAgc2hvd0J1dHRvbnMgPSB0cnVlO1xuXG4gIEBJbnB1dCgpXG4gIGFwcGx5UmFpc2VkID0gdHJ1ZTtcblxuICBASW5wdXQoKVxuICBhcHBseUljb24gPSAnZmlsdGVyX2xpc3QnO1xuXG4gIEBJbnB1dCgpXG4gIGFwcGx5VGV4dCA9ICdGaWx0ZXInO1xuXG4gIGNvbnN0cnVjdG9yKHNvdXJjZTogRGJ4QWN0aW9uQ29udGV4dFN0b3JlU291cmNlSW5zdGFuY2U8Rj4sIHJlYWRvbmx5IGZpbHRlclNvdXJjZURpcmVjdGl2ZTogRmlsdGVyU291cmNlRGlyZWN0aXZlPEY+KSB7XG4gICAgc3VwZXIoc291cmNlKTtcbiAgICAvLyBjb25maWd1cmUgaGFuZGxlciBmdW5jdGlvblxuICAgIHRoaXMuX2RieEFjdGlvbkhhbmRsZXJJbnN0YW5jZS5oYW5kbGVyRnVuY3Rpb24gPSAoZmlsdGVyOiBGKSA9PiB7XG4gICAgICB0aGlzLmZpbHRlclNvdXJjZURpcmVjdGl2ZS5zZXRGaWx0ZXIoZmlsdGVyKTtcbiAgICAgIHJldHVybiBvZih0cnVlKTtcbiAgICB9O1xuICB9XG5cbiAgYXBwbHlGaWx0ZXIoKTogdm9pZCB7XG4gICAgdGhpcy5zb3VyY2Uuc2V0SXNNb2RpZmllZCh0cnVlKTsgLy8gRm9yY2Ugc2V0dGluZyBtb2RpZmllZC5cbiAgICB0aGlzLnNvdXJjZS50cmlnZ2VyKCk7XG4gIH1cblxuICByZXNldEZpbHRlcigpOiB2b2lkIHtcbiAgICB0aGlzLmZpbHRlclNvdXJjZURpcmVjdGl2ZS5yZXNldEZpbHRlcigpO1xuICB9XG59XG4iLCI8ZGl2IGNsYXNzPVwiZGJ4LWZpbHRlci13cmFwcGVyXCI+XG4gIDxkaXYgY2xhc3M9XCJkYngtZmlsdGVyLXdyYXBwZXItY29udGVudFwiPlxuICAgIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cbiAgPC9kaXY+XG4gIDxkaXYgKm5nSWY9XCJzaG93QnV0dG9uc1wiIGZ4TGF5b3V0PVwicm93XCI+XG4gICAgPGRieC1idXR0b24gZGJ4QWN0aW9uQnV0dG9uIFtyYWlzZWRdPVwiYXBwbHlSYWlzZWRcIiBbdGV4dF09XCJhcHBseVRleHRcIiBbaWNvbl09XCJhcHBseUljb25cIj48L2RieC1idXR0b24+XG4gICAgPGRpdiBjbGFzcz1cInNwYWNlclwiPjwvZGl2PlxuICAgIDxidXR0b24gbWF0LWljb24tYnV0dG9uIChjbGljayk9XCJyZXNldEZpbHRlcigpXCI+XG4gICAgICA8bWF0LWljb24+Y2xlYXI8L21hdC1pY29uPlxuICAgIDwvYnV0dG9uPlxuICA8L2Rpdj5cbjwvZGl2PlxuIl19
|
|
@@ -2,6 +2,7 @@ import { DbxPopoverComponent } from './popover.component';
|
|
|
2
2
|
import { Injectable, Injector } from '@angular/core';
|
|
3
3
|
import { NgOverlayContainerService } from 'ng-overlay-container';
|
|
4
4
|
import { Overlay } from '@angular/cdk/overlay';
|
|
5
|
+
import { joinStringsWithSpaces } from '@dereekb/util';
|
|
5
6
|
import * as i0 from "@angular/core";
|
|
6
7
|
import * as i1 from "@angular/cdk/overlay";
|
|
7
8
|
/**
|
|
@@ -16,12 +17,14 @@ export class DbxPopoverService {
|
|
|
16
17
|
open(config) {
|
|
17
18
|
const service = config.injector ? new NgOverlayContainerService(this._overlay, config.injector) : this._overlayContainerService;
|
|
18
19
|
const configuration = {
|
|
19
|
-
panelClass: 'dbx-popover-container',
|
|
20
|
-
originX: 'start',
|
|
21
|
-
originY: 'top',
|
|
20
|
+
panelClass: joinStringsWithSpaces(['dbx-popover-container', config.panelClass]),
|
|
21
|
+
originX: config.originX ?? 'start',
|
|
22
|
+
originY: config.originY ?? 'top',
|
|
22
23
|
// TODO: Resize height/width.
|
|
24
|
+
minHeight: config.minHeight,
|
|
25
|
+
minWidth: config.minWidth,
|
|
23
26
|
height: config.height ?? '500px',
|
|
24
|
-
width: config.
|
|
27
|
+
width: config.width ?? '400px',
|
|
25
28
|
hasBackdrop: true,
|
|
26
29
|
isDraggable: false,
|
|
27
30
|
isResizable: config.isResizable ?? false,
|
|
@@ -45,4 +48,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
45
48
|
providedIn: 'root'
|
|
46
49
|
}]
|
|
47
50
|
}], ctorParameters: function () { return [{ type: i1.Overlay }, { type: i0.Injector }]; } });
|
|
48
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
51
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9wb3Zlci5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LXdlYi9zcmMvbGliL2ludGVyYWN0aW9uL3BvcG92ZXIvcG9wb3Zlci5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxtQkFBbUIsRUFBNEQsTUFBTSxxQkFBcUIsQ0FBQztBQUNwSCxPQUFPLEVBQUUsVUFBVSxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNyRCxPQUFPLEVBQW1DLHlCQUF5QixFQUFnQixNQUFNLHNCQUFzQixDQUFDO0FBQ2hILE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUMvQyxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxlQUFlLENBQUM7OztBQVN0RDs7R0FFRztBQUlILE1BQU0sT0FBTyxpQkFBaUI7SUFHNUIsWUFBb0IsUUFBaUIsRUFBVSxTQUFtQjtRQUE5QyxhQUFRLEdBQVIsUUFBUSxDQUFTO1FBQVUsY0FBUyxHQUFULFNBQVMsQ0FBVTtRQUNoRSxJQUFJLENBQUMsd0JBQXdCLEdBQUcsSUFBSSx5QkFBeUIsQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUMvRixDQUFDO0lBRUQsSUFBSSxDQUFVLE1BQWlDO1FBQzdDLE1BQU0sT0FBTyxHQUFHLE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLElBQUkseUJBQXlCLENBQUMsSUFBSSxDQUFDLFFBQVEsRUFBRSxNQUFNLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyx3QkFBd0IsQ0FBQztRQUVoSSxNQUFNLGFBQWEsR0FBb0M7WUFDckQsVUFBVSxFQUFFLHFCQUFxQixDQUFDLENBQUMsdUJBQXVCLEVBQUUsTUFBTSxDQUFDLFVBQVUsQ0FBQyxDQUFDO1lBQy9FLE9BQU8sRUFBRSxNQUFNLENBQUMsT0FBTyxJQUFJLE9BQU87WUFDbEMsT0FBTyxFQUFFLE1BQU0sQ0FBQyxPQUFPLElBQUksS0FBSztZQUNoQyw2QkFBNkI7WUFDN0IsU0FBUyxFQUFFLE1BQU0sQ0FBQyxTQUFTO1lBQzNCLFFBQVEsRUFBRSxNQUFNLENBQUMsUUFBUTtZQUN6QixNQUFNLEVBQUUsTUFBTSxDQUFDLE1BQU0sSUFBSSxPQUFPO1lBQ2hDLEtBQUssRUFBRSxNQUFNLENBQUMsS0FBSyxJQUFJLE9BQU87WUFDOUIsV0FBVyxFQUFFLElBQUk7WUFDakIsV0FBVyxFQUFFLEtBQUs7WUFDbEIsV0FBVyxFQUFFLE1BQU0sQ0FBQyxXQUFXLElBQUksS0FBSztZQUN4QyxvQkFBb0IsRUFBRSxLQUFLO1NBQzVCLENBQUM7UUFFRixPQUFPLE9BQU8sQ0FBQyxJQUFJLENBQTRDO1lBQzdELE9BQU8sRUFBRSxtQkFBbUI7WUFDNUIsSUFBSSxFQUFFO2dCQUNKLEdBQUcsTUFBTTtnQkFDVCxhQUFhO2FBQ2Q7WUFDRCxhQUFhO1NBQ2QsQ0FBQyxDQUFDO0lBQ0wsQ0FBQzs7K0dBakNVLGlCQUFpQjttSEFBakIsaUJBQWlCLGNBRmhCLE1BQU07NEZBRVAsaUJBQWlCO2tCQUg3QixVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERieFBvcG92ZXJDb21wb25lbnQsIERieFBvcG92ZXJDb21wb25lbnRDb25maWcsIEZ1bGxEYnhQb3BvdmVyQ29tcG9uZW50Q29uZmlnIH0gZnJvbSAnLi9wb3BvdmVyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBJbmplY3RhYmxlLCBJbmplY3RvciB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTmdPdmVybGF5Q29udGFpbmVyQ29uZmlndXJhdGlvbiwgTmdPdmVybGF5Q29udGFpbmVyU2VydmljZSwgTmdQb3BvdmVyUmVmIH0gZnJvbSAnbmctb3ZlcmxheS1jb250YWluZXInO1xuaW1wb3J0IHsgT3ZlcmxheSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9vdmVybGF5JztcbmltcG9ydCB7IGpvaW5TdHJpbmdzV2l0aFNwYWNlcyB9IGZyb20gJ0BkZXJlZWtiL3V0aWwnO1xuXG5leHBvcnQgaW50ZXJmYWNlIERieFBvcG92ZXJDb25maWdTaXppbmcgZXh0ZW5kcyBQaWNrPE5nT3ZlcmxheUNvbnRhaW5lckNvbmZpZ3VyYXRpb24sICdvcmlnaW5YJyB8ICdvcmlnaW5ZJyB8ICdoZWlnaHQnIHwgJ3dpZHRoJyB8ICdtaW5IZWlnaHQnIHwgJ21pbldpZHRoJyB8ICdpc1Jlc2l6YWJsZSc+IHt9XG5cbmV4cG9ydCBpbnRlcmZhY2UgRGJ4UG9wb3ZlckNvbmZpZzxPLCBJLCBUPiBleHRlbmRzIERieFBvcG92ZXJDb21wb25lbnRDb25maWc8TywgSSwgVD4sIERieFBvcG92ZXJDb25maWdTaXppbmcge1xuICBwYW5lbENsYXNzPzogc3RyaW5nO1xuICBpbmplY3Rvcj86IEluamVjdG9yO1xufVxuXG4vKipcbiAqIFVzZWQgZm9yIGRpc3BsYXlpbmcgYSBwb3BvdmVyLlxuICovXG5ASW5qZWN0YWJsZSh7XG4gIHByb3ZpZGVkSW46ICdyb290J1xufSlcbmV4cG9ydCBjbGFzcyBEYnhQb3BvdmVyU2VydmljZSB7XG4gIHByaXZhdGUgX292ZXJsYXlDb250YWluZXJTZXJ2aWNlOiBOZ092ZXJsYXlDb250YWluZXJTZXJ2aWNlO1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgX292ZXJsYXk6IE92ZXJsYXksIHByaXZhdGUgX2luamVjdG9yOiBJbmplY3Rvcikge1xuICAgIHRoaXMuX292ZXJsYXlDb250YWluZXJTZXJ2aWNlID0gbmV3IE5nT3ZlcmxheUNvbnRhaW5lclNlcnZpY2UodGhpcy5fb3ZlcmxheSwgdGhpcy5faW5qZWN0b3IpO1xuICB9XG5cbiAgb3BlbjxPLCBJLCBUPihjb25maWc6IERieFBvcG92ZXJDb25maWc8TywgSSwgVD4pOiBOZ1BvcG92ZXJSZWY8RGJ4UG9wb3ZlckNvbXBvbmVudENvbmZpZzxPLCBJLCBUPiwgTz4ge1xuICAgIGNvbnN0IHNlcnZpY2UgPSBjb25maWcuaW5qZWN0b3IgPyBuZXcgTmdPdmVybGF5Q29udGFpbmVyU2VydmljZSh0aGlzLl9vdmVybGF5LCBjb25maWcuaW5qZWN0b3IpIDogdGhpcy5fb3ZlcmxheUNvbnRhaW5lclNlcnZpY2U7XG5cbiAgICBjb25zdCBjb25maWd1cmF0aW9uOiBOZ092ZXJsYXlDb250YWluZXJDb25maWd1cmF0aW9uID0ge1xuICAgICAgcGFuZWxDbGFzczogam9pblN0cmluZ3NXaXRoU3BhY2VzKFsnZGJ4LXBvcG92ZXItY29udGFpbmVyJywgY29uZmlnLnBhbmVsQ2xhc3NdKSxcbiAgICAgIG9yaWdpblg6IGNvbmZpZy5vcmlnaW5YID8/ICdzdGFydCcsXG4gICAgICBvcmlnaW5ZOiBjb25maWcub3JpZ2luWSA/PyAndG9wJyxcbiAgICAgIC8vIFRPRE86IFJlc2l6ZSBoZWlnaHQvd2lkdGguXG4gICAgICBtaW5IZWlnaHQ6IGNvbmZpZy5taW5IZWlnaHQsXG4gICAgICBtaW5XaWR0aDogY29uZmlnLm1pbldpZHRoLFxuICAgICAgaGVpZ2h0OiBjb25maWcuaGVpZ2h0ID8/ICc1MDBweCcsXG4gICAgICB3aWR0aDogY29uZmlnLndpZHRoID8/ICc0MDBweCcsXG4gICAgICBoYXNCYWNrZHJvcDogdHJ1ZSxcbiAgICAgIGlzRHJhZ2dhYmxlOiBmYWxzZSxcbiAgICAgIGlzUmVzaXphYmxlOiBjb25maWcuaXNSZXNpemFibGUgPz8gZmFsc2UsXG4gICAgICBkaXNhYmxlQmFja2Ryb3BDbG9zZTogZmFsc2VcbiAgICB9O1xuXG4gICAgcmV0dXJuIHNlcnZpY2Uub3BlbjxGdWxsRGJ4UG9wb3ZlckNvbXBvbmVudENvbmZpZzxPLCBJLCBUPiwgTz4oe1xuICAgICAgY29udGVudDogRGJ4UG9wb3ZlckNvbXBvbmVudCxcbiAgICAgIGRhdGE6IHtcbiAgICAgICAgLi4uY29uZmlnLFxuICAgICAgICBjb25maWd1cmF0aW9uXG4gICAgICB9LFxuICAgICAgY29uZmlndXJhdGlvblxuICAgIH0pO1xuICB9XG59XG4iXX0=
|
|
@@ -15,7 +15,10 @@ import * as i7 from "../anchor/anchor.component";
|
|
|
15
15
|
export class DbxAnchorListComponent {
|
|
16
16
|
constructor() {
|
|
17
17
|
this._anchors = new BehaviorSubject([]);
|
|
18
|
-
this.expandedAnchors$ = this._anchors.pipe(distinctUntilChanged(), map((x) => expandClickableAnchorLinkTrees(x))
|
|
18
|
+
this.expandedAnchors$ = this._anchors.pipe(distinctUntilChanged(), map((x) => expandClickableAnchorLinkTrees(x).map((y) => {
|
|
19
|
+
y.classes = `${y.depth > 0 ? `dbx-anchor-list-child` : 'dbx-anchor-list-root'} dbx-anchor-list-depth-${y.depth}`;
|
|
20
|
+
return y;
|
|
21
|
+
})), shareReplay(1));
|
|
19
22
|
}
|
|
20
23
|
set anchors(anchors) {
|
|
21
24
|
this._anchors.next(anchors ?? []);
|
|
@@ -25,11 +28,11 @@ export class DbxAnchorListComponent {
|
|
|
25
28
|
}
|
|
26
29
|
}
|
|
27
30
|
DbxAnchorListComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxAnchorListComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
28
|
-
DbxAnchorListComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: DbxAnchorListComponent, selector: "dbx-anchor-list", inputs: { anchors: "anchors" }, ngImport: i0, template: "<mat-nav-list class=\"dbx-anchor-list\">\n <ng-container *ngFor=\"let expanded of expandedAnchors$ | async; let last = last\">\n <dbx-anchor [anchor]=\"expanded.value\">\n <a mat-list-item [disabled]=\"expanded.value.disabled\"
|
|
31
|
+
DbxAnchorListComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: DbxAnchorListComponent, selector: "dbx-anchor-list", inputs: { anchors: "anchors" }, ngImport: i0, template: "<mat-nav-list class=\"dbx-anchor-list\">\n <ng-container *ngFor=\"let expanded of expandedAnchors$ | async; let last = last\">\n <dbx-anchor [anchor]=\"expanded.value\" [ngClass]=\"expanded.classes\">\n <a mat-list-item [disabled]=\"expanded.value.disabled\">\n <mat-icon mat-list-icon *ngIf=\"expanded.value.icon\">{{ expanded.value.icon }}</mat-icon>\n <!-- TODO: Add an icon from a letter if anchor.icon is unavailable. -->\n <div mat-line>{{ expanded.value.title }}</div>\n <div class=\"dbx-hint dbx-small\" *ngIf=\"expanded.value.hint\" mat-line>{{ expanded.value.hint }}</div>\n <dbx-injection *ngIf=\"expanded.value.content\" mat-line [config]=\"expanded.value.content\"></dbx-injection>\n <mat-divider *ngIf=\"!last\"></mat-divider>\n </a>\n </dbx-anchor>\n </ng-container>\n</mat-nav-list>\n", dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.DbxInjectionComponent, selector: "dbx-injection, [dbxInjection], [dbx-injection]", inputs: ["config", "template"] }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i4.MatNavList, selector: "mat-nav-list", inputs: ["disableRipple", "disabled"], exportAs: ["matNavList"] }, { kind: "component", type: i4.MatListItem, selector: "mat-list-item, a[mat-list-item], button[mat-list-item]", inputs: ["disableRipple", "disabled"], exportAs: ["matListItem"] }, { kind: "directive", type: i5.MatLine, selector: "[mat-line], [matLine]" }, { kind: "directive", type: i4.MatListIconCssMatStyler, selector: "[mat-list-icon], [matListIcon]" }, { kind: "component", type: i6.MatDivider, selector: "mat-divider", inputs: ["vertical", "inset"] }, { kind: "component", type: i7.DbxAnchorComponent, selector: "dbx-anchor, [dbx-anchor]", inputs: ["block"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }] });
|
|
29
32
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxAnchorListComponent, decorators: [{
|
|
30
33
|
type: Component,
|
|
31
|
-
args: [{ selector: 'dbx-anchor-list', template: "<mat-nav-list class=\"dbx-anchor-list\">\n <ng-container *ngFor=\"let expanded of expandedAnchors$ | async; let last = last\">\n <dbx-anchor [anchor]=\"expanded.value\">\n <a mat-list-item [disabled]=\"expanded.value.disabled\"
|
|
34
|
+
args: [{ selector: 'dbx-anchor-list', template: "<mat-nav-list class=\"dbx-anchor-list\">\n <ng-container *ngFor=\"let expanded of expandedAnchors$ | async; let last = last\">\n <dbx-anchor [anchor]=\"expanded.value\" [ngClass]=\"expanded.classes\">\n <a mat-list-item [disabled]=\"expanded.value.disabled\">\n <mat-icon mat-list-icon *ngIf=\"expanded.value.icon\">{{ expanded.value.icon }}</mat-icon>\n <!-- TODO: Add an icon from a letter if anchor.icon is unavailable. -->\n <div mat-line>{{ expanded.value.title }}</div>\n <div class=\"dbx-hint dbx-small\" *ngIf=\"expanded.value.hint\" mat-line>{{ expanded.value.hint }}</div>\n <dbx-injection *ngIf=\"expanded.value.content\" mat-line [config]=\"expanded.value.content\"></dbx-injection>\n <mat-divider *ngIf=\"!last\"></mat-divider>\n </a>\n </dbx-anchor>\n </ng-container>\n</mat-nav-list>\n" }]
|
|
32
35
|
}], propDecorators: { anchors: [{
|
|
33
36
|
type: Input
|
|
34
37
|
}] } });
|
|
35
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
38
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5jaG9ybGlzdC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3NyYy9saWIvcm91dGVyL2xheW91dC9hbmNob3JsaXN0L2FuY2hvcmxpc3QuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LXdlYi9zcmMvbGliL3JvdXRlci9sYXlvdXQvYW5jaG9ybGlzdC9hbmNob3JsaXN0LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBYSxLQUFLLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzVELE9BQU8sRUFBRSxlQUFlLEVBQUUsR0FBRyxFQUFFLFdBQVcsRUFBRSxvQkFBb0IsRUFBYyxNQUFNLE1BQU0sQ0FBQztBQUMzRixPQUFPLEVBQTRELDhCQUE4QixFQUFFLE1BQU0sbUJBQW1CLENBQUM7Ozs7Ozs7OztBQU83SDs7R0FFRztBQUtILE1BQU0sT0FBTyxzQkFBc0I7SUFKbkM7UUFLVSxhQUFRLEdBQUcsSUFBSSxlQUFlLENBQTRCLEVBQUUsQ0FBQyxDQUFDO1FBRTdELHFCQUFnQixHQUE4QyxJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FDdkYsb0JBQW9CLEVBQUUsRUFDdEIsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FDUiw4QkFBOEIsQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRTtZQUN6QyxDQUFpQyxDQUFDLE9BQU8sR0FBRyxHQUFHLENBQUMsQ0FBQyxLQUFLLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyx1QkFBdUIsQ0FBQyxDQUFDLENBQUMsc0JBQXNCLDBCQUEwQixDQUFDLENBQUMsS0FBSyxFQUFFLENBQUM7WUFDbEosT0FBTyxDQUFnQyxDQUFDO1FBQzFDLENBQUMsQ0FBQyxDQUNILEVBQ0QsV0FBVyxDQUFDLENBQUMsQ0FBQyxDQUNmLENBQUM7S0FVSDtJQVJDLElBQ0ksT0FBTyxDQUFDLE9BQXlDO1FBQ25ELElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLE9BQU8sSUFBSSxFQUFFLENBQUMsQ0FBQztJQUNwQyxDQUFDO0lBRUQsV0FBVztRQUNULElBQUksQ0FBQyxRQUFRLENBQUMsUUFBUSxFQUFFLENBQUM7SUFDM0IsQ0FBQzs7b0hBckJVLHNCQUFzQjt3R0FBdEIsc0JBQXNCLHVGQ2hCbkMsODFCQWNBOzRGREVhLHNCQUFzQjtrQkFKbEMsU0FBUzsrQkFDRSxpQkFBaUI7OEJBa0J2QixPQUFPO3NCQURWLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBPbkRlc3Ryb3ksIElucHV0LCBDb21wb25lbnQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEJlaGF2aW9yU3ViamVjdCwgbWFwLCBzaGFyZVJlcGxheSwgZGlzdGluY3RVbnRpbENoYW5nZWQsIE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IENsaWNrYWJsZUFuY2hvckxpbmtUcmVlLCBFeHBhbmRlZENsaWNrYWJsZUFuY2hvckxpbmtUcmVlLCBleHBhbmRDbGlja2FibGVBbmNob3JMaW5rVHJlZXMgfSBmcm9tICdAZGVyZWVrYi9kYngtY29yZSc7XG5pbXBvcnQgeyBNYXliZSB9IGZyb20gJ0BkZXJlZWtiL3V0aWwnO1xuXG5leHBvcnQgaW50ZXJmYWNlIERieEFuY2hvckxpc3RFeHBhbmRlZEFuY2hvciBleHRlbmRzIEV4cGFuZGVkQ2xpY2thYmxlQW5jaG9yTGlua1RyZWUge1xuICBjbGFzc2VzOiBzdHJpbmc7XG59XG5cbi8qKlxuICogQ29tcG9uZW50IHRoYXQgZGlzcGxheXMgYSBsaXN0IG9mIENsaWNrYWJsZUFuY2hvckxpbmsgdmFsdWVzIHdpdGhpbiBhIE1hdE5hdkxpc3QuXG4gKi9cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2RieC1hbmNob3ItbGlzdCcsXG4gIHRlbXBsYXRlVXJsOiAnLi9hbmNob3JsaXN0LmNvbXBvbmVudC5odG1sJ1xufSlcbmV4cG9ydCBjbGFzcyBEYnhBbmNob3JMaXN0Q29tcG9uZW50IGltcGxlbWVudHMgT25EZXN0cm95IHtcbiAgcHJpdmF0ZSBfYW5jaG9ycyA9IG5ldyBCZWhhdmlvclN1YmplY3Q8Q2xpY2thYmxlQW5jaG9yTGlua1RyZWVbXT4oW10pO1xuXG4gIHJlYWRvbmx5IGV4cGFuZGVkQW5jaG9ycyQ6IE9ic2VydmFibGU8RGJ4QW5jaG9yTGlzdEV4cGFuZGVkQW5jaG9yW10+ID0gdGhpcy5fYW5jaG9ycy5waXBlKFxuICAgIGRpc3RpbmN0VW50aWxDaGFuZ2VkKCksXG4gICAgbWFwKCh4KSA9PlxuICAgICAgZXhwYW5kQ2xpY2thYmxlQW5jaG9yTGlua1RyZWVzKHgpLm1hcCgoeSkgPT4ge1xuICAgICAgICAoeSBhcyBEYnhBbmNob3JMaXN0RXhwYW5kZWRBbmNob3IpLmNsYXNzZXMgPSBgJHt5LmRlcHRoID4gMCA/IGBkYngtYW5jaG9yLWxpc3QtY2hpbGRgIDogJ2RieC1hbmNob3ItbGlzdC1yb290J30gZGJ4LWFuY2hvci1saXN0LWRlcHRoLSR7eS5kZXB0aH1gO1xuICAgICAgICByZXR1cm4geSBhcyBEYnhBbmNob3JMaXN0RXhwYW5kZWRBbmNob3I7XG4gICAgICB9KVxuICAgICksXG4gICAgc2hhcmVSZXBsYXkoMSlcbiAgKTtcblxuICBASW5wdXQoKVxuICBzZXQgYW5jaG9ycyhhbmNob3JzOiBNYXliZTxDbGlja2FibGVBbmNob3JMaW5rVHJlZVtdPikge1xuICAgIHRoaXMuX2FuY2hvcnMubmV4dChhbmNob3JzID8/IFtdKTtcbiAgfVxuXG4gIG5nT25EZXN0cm95KCk6IHZvaWQge1xuICAgIHRoaXMuX2FuY2hvcnMuY29tcGxldGUoKTtcbiAgfVxufVxuIiwiPG1hdC1uYXYtbGlzdCBjbGFzcz1cImRieC1hbmNob3ItbGlzdFwiPlxuICA8bmctY29udGFpbmVyICpuZ0Zvcj1cImxldCBleHBhbmRlZCBvZiBleHBhbmRlZEFuY2hvcnMkIHwgYXN5bmM7IGxldCBsYXN0ID0gbGFzdFwiPlxuICAgIDxkYngtYW5jaG9yIFthbmNob3JdPVwiZXhwYW5kZWQudmFsdWVcIiBbbmdDbGFzc109XCJleHBhbmRlZC5jbGFzc2VzXCI+XG4gICAgICA8YSBtYXQtbGlzdC1pdGVtIFtkaXNhYmxlZF09XCJleHBhbmRlZC52YWx1ZS5kaXNhYmxlZFwiPlxuICAgICAgICA8bWF0LWljb24gbWF0LWxpc3QtaWNvbiAqbmdJZj1cImV4cGFuZGVkLnZhbHVlLmljb25cIj57eyBleHBhbmRlZC52YWx1ZS5pY29uIH19PC9tYXQtaWNvbj5cbiAgICAgICAgPCEtLSBUT0RPOiBBZGQgYW4gaWNvbiBmcm9tIGEgbGV0dGVyIGlmIGFuY2hvci5pY29uIGlzIHVuYXZhaWxhYmxlLiAtLT5cbiAgICAgICAgPGRpdiBtYXQtbGluZT57eyBleHBhbmRlZC52YWx1ZS50aXRsZSB9fTwvZGl2PlxuICAgICAgICA8ZGl2IGNsYXNzPVwiZGJ4LWhpbnQgZGJ4LXNtYWxsXCIgKm5nSWY9XCJleHBhbmRlZC52YWx1ZS5oaW50XCIgbWF0LWxpbmU+e3sgZXhwYW5kZWQudmFsdWUuaGludCB9fTwvZGl2PlxuICAgICAgICA8ZGJ4LWluamVjdGlvbiAqbmdJZj1cImV4cGFuZGVkLnZhbHVlLmNvbnRlbnRcIiBtYXQtbGluZSBbY29uZmlnXT1cImV4cGFuZGVkLnZhbHVlLmNvbnRlbnRcIj48L2RieC1pbmplY3Rpb24+XG4gICAgICAgIDxtYXQtZGl2aWRlciAqbmdJZj1cIiFsYXN0XCI+PC9tYXQtZGl2aWRlcj5cbiAgICAgIDwvYT5cbiAgICA8L2RieC1hbmNob3I+XG4gIDwvbmctY29udGFpbmVyPlxuPC9tYXQtbmF2LWxpc3Q+XG4iXX0=
|