@dereekb/dbx-web 9.24.16 → 9.24.18
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/filter/filter.popover.button.directive.mjs +1 -1
- package/esm2020/lib/interaction/filter/filter.popover.component.mjs +28 -14
- package/esm2020/lib/interaction/filter/filter.preset.mjs +9 -4
- package/fesm2015/dereekb-dbx-web.mjs +35 -18
- package/fesm2015/dereekb-dbx-web.mjs.map +1 -1
- package/fesm2020/dereekb-dbx-web.mjs +31 -13
- package/fesm2020/dereekb-dbx-web.mjs.map +1 -1
- package/lib/interaction/filter/filter.popover.button.directive.d.ts +4 -1
- package/lib/interaction/filter/filter.popover.component.d.ts +28 -4
- package/lib/interaction/filter/filter.preset.d.ts +3 -2
- 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.24.
|
|
3
|
+
"version": "9.24.18",
|
|
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.24.
|
|
11
|
+
"@dereekb/dbx-web": "9.24.18"
|
|
12
12
|
},
|
|
13
13
|
"dependencies": {
|
|
14
14
|
"tslib": "^2.3.0"
|
|
@@ -30,4 +30,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
30
30
|
}], ctorParameters: function () { return [{ type: i1.DbxPopoverService }]; }, propDecorators: { config: [{
|
|
31
31
|
type: Input
|
|
32
32
|
}] } });
|
|
33
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
33
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLnBvcG92ZXIuYnV0dG9uLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC13ZWIvc3JjL2xpYi9pbnRlcmFjdGlvbi9maWx0ZXIvZmlsdGVyLnBvcG92ZXIuYnV0dG9uLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFjLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUU3RCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUMvRCxPQUFPLEVBQUUseUJBQXlCLEVBQTRCLE1BQU0sNEJBQTRCLENBQUM7QUFDakcsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sMkNBQTJDLENBQUM7OztBQVF4RixNQUFNLE9BQWdCLG9DQUF1RCxTQUFRLDJCQUE2QztJQUloSSxZQUE2QixZQUErQjtRQUMxRCxLQUFLLEVBQUUsQ0FBQztRQURtQixpQkFBWSxHQUFaLFlBQVksQ0FBbUI7SUFFNUQsQ0FBQztJQUVrQixlQUFlLENBQUMsTUFBbUI7UUFDcEQsTUFBTSxNQUFNLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQztRQUUzQixJQUFJLENBQUMsTUFBTSxFQUFFO1lBQ1gsTUFBTSxJQUFJLEtBQUssQ0FBQyw2QkFBNkIsQ0FBQyxDQUFDO1NBQ2hEO2FBQU0sSUFBSSxDQUFDLE1BQU0sRUFBRTtZQUNsQixNQUFNLElBQUksS0FBSyxDQUFDLGlCQUFpQixDQUFDLENBQUM7U0FDcEM7UUFFRCxPQUFPLHlCQUF5QixDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsWUFBWSxFQUFFO1lBQzlELE1BQU07WUFDTixHQUFHLE1BQU07U0FDVixDQUFDLENBQUM7SUFDTCxDQUFDOztrSUFyQm1CLG9DQUFvQztzSEFBcEMsb0NBQW9DOzRGQUFwQyxvQ0FBb0M7a0JBRHpELFNBQVM7d0dBR1IsTUFBTTtzQkFETCxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBFbGVtZW50UmVmLCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTmdQb3BvdmVyUmVmIH0gZnJvbSAnbmctb3ZlcmxheS1jb250YWluZXInO1xuaW1wb3J0IHsgRGJ4UG9wb3ZlclNlcnZpY2UgfSBmcm9tICcuLi9wb3BvdmVyL3BvcG92ZXIuc2VydmljZSc7XG5pbXBvcnQgeyBEYnhGaWx0ZXJQb3BvdmVyQ29tcG9uZW50LCBEYnhGaWx0ZXJDb21wb25lbnRQYXJhbXMgfSBmcm9tICcuL2ZpbHRlci5wb3BvdmVyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBBYnN0cmFjdFBvcG92ZXJSZWZEaXJlY3RpdmUgfSBmcm9tICcuLi9wb3BvdmVyL2Fic3RyYWN0LnBvcG92ZXIucmVmLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBGaWx0ZXJTb3VyY2UsIFByZXNldEZpbHRlclNvdXJjZSB9IGZyb20gJ0BkZXJlZWtiL3J4anMnO1xuXG5leHBvcnQgdHlwZSBEYnhGaWx0ZXJCdXR0b25Db25maWc8RiBleHRlbmRzIG9iamVjdD4gPSBEYnhGaWx0ZXJDb21wb25lbnRQYXJhbXM8Rj47XG5leHBvcnQgdHlwZSBEYnhGaWx0ZXJCdXR0b25Db25maWdXaXRoQ3VzdG9tRmlsdGVyPEYgZXh0ZW5kcyBvYmplY3QsIENGIGV4dGVuZHMgRmlsdGVyU291cmNlPEY+ID0gRmlsdGVyU291cmNlPEY+PiA9IE9taXQ8RGJ4RmlsdGVyQ29tcG9uZW50UGFyYW1zPEYsIGFueSwgQ0YsIGFueT4sICdwcmVzZXRGaWx0ZXInIHwgJ3ByZXNldEZpbHRlckNvbXBvbmVudENvbmZpZyc+O1xuZXhwb3J0IHR5cGUgRGJ4RmlsdGVyQnV0dG9uQ29uZmlnV2l0aFByZXNldEZpbHRlcjxGIGV4dGVuZHMgb2JqZWN0LCBQRiBleHRlbmRzIFByZXNldEZpbHRlclNvdXJjZTxGLCBhbnk+ID0gUHJlc2V0RmlsdGVyU291cmNlPEYsIGFueT4+ID0gT21pdDxEYnhGaWx0ZXJDb21wb25lbnRQYXJhbXM8RiwgYW55LCBhbnksIFBGPiwgJ2N1c3RvbUZpbHRlcicgfCAnY3VzdG9tRmlsdGVyQ29tcG9uZW50Q29uZmlnJz47XG5cbkBEaXJlY3RpdmUoKVxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIEFic3RyYWN0RmlsdGVyUG9wb3ZlckJ1dHRvbkRpcmVjdGl2ZTxGIGV4dGVuZHMgb2JqZWN0PiBleHRlbmRzIEFic3RyYWN0UG9wb3ZlclJlZkRpcmVjdGl2ZTx1bmtub3duLCB1bmtub3duPiB7XG4gIEBJbnB1dCgpXG4gIGNvbmZpZz86IERieEZpbHRlckNvbXBvbmVudFBhcmFtczxGLCBhbnksIGFueSwgYW55PjtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHJlYWRvbmx5IHBvcHVwU2VydmljZTogRGJ4UG9wb3ZlclNlcnZpY2UpIHtcbiAgICBzdXBlcigpO1xuICB9XG5cbiAgcHJvdGVjdGVkIG92ZXJyaWRlIF9tYWtlUG9wb3ZlclJlZihvcmlnaW4/OiBFbGVtZW50UmVmKTogTmdQb3BvdmVyUmVmPHVua25vd24sIHVua25vd24+IHtcbiAgICBjb25zdCBjb25maWcgPSB0aGlzLmNvbmZpZztcblxuICAgIGlmICghY29uZmlnKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoJ01pc3NpbmcgZmlsdGVyQnV0dG9uQ29uZmlnLicpO1xuICAgIH0gZWxzZSBpZiAoIW9yaWdpbikge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKCdNaXNzaW5nIG9yaWdpbi4nKTtcbiAgICB9XG5cbiAgICByZXR1cm4gRGJ4RmlsdGVyUG9wb3ZlckNvbXBvbmVudC5vcGVuUG9wb3Zlcih0aGlzLnBvcHVwU2VydmljZSwge1xuICAgICAgb3JpZ2luLFxuICAgICAgLi4uY29uZmlnXG4gICAgfSk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -9,13 +9,17 @@ import * as i2 from "@angular/common";
|
|
|
9
9
|
import * as i3 from "../popover/popover.content.component";
|
|
10
10
|
import * as i4 from "../popover/popover.header.component";
|
|
11
11
|
import * as i5 from "../popover/popover.scroll.content.component";
|
|
12
|
-
import * as i6 from "
|
|
13
|
-
import * as i7 from "@
|
|
12
|
+
import * as i6 from "../../button/button.spacer.component";
|
|
13
|
+
import * as i7 from "@dereekb/dbx-core";
|
|
14
|
+
import * as i8 from "@angular/material/button";
|
|
14
15
|
export const DEFAULT_FILTER_POPOVER_KEY = 'filter';
|
|
15
16
|
export class DbxFilterPopoverComponent extends AbstractPopoverDirective {
|
|
16
17
|
constructor(popover) {
|
|
17
18
|
super(popover);
|
|
18
19
|
this._closeOnChangeSub = new SubscriptionObject();
|
|
20
|
+
this.showCloseButton = this.config.showCloseButton ?? !(this.config.closeOnFilterChange ?? true);
|
|
21
|
+
this.closeButtonText = this.config.closeButtonText ?? 'Close';
|
|
22
|
+
this.customizeButtonText = this.config.customizeButtonText ?? 'Customize';
|
|
19
23
|
/**
|
|
20
24
|
* Whether or not to display buttons to toggle between custom and preset filters.
|
|
21
25
|
*/
|
|
@@ -23,15 +27,19 @@ export class DbxFilterPopoverComponent extends AbstractPopoverDirective {
|
|
|
23
27
|
this._showPreset = new BehaviorSubject(false);
|
|
24
28
|
this.showPreset$ = this._showPreset.asObservable();
|
|
25
29
|
this.config$ = this._showPreset.pipe(map((showPreset) => {
|
|
26
|
-
const { closeOnFilterChange = true, connector, initialFilterObs, customFilterComponentClass, presetFilterComponentClass } = this.config;
|
|
30
|
+
const { closeOnFilterChange = true, connector, initialFilterObs, customFilterComponentClass, presetFilterComponentClass, customFilterComponentConfig, presetFilterComponentConfig } = this.config;
|
|
27
31
|
let componentClass;
|
|
32
|
+
let baseConfig;
|
|
28
33
|
if (showPreset) {
|
|
29
|
-
componentClass = presetFilterComponentClass;
|
|
34
|
+
componentClass = (presetFilterComponentConfig?.componentClass ?? presetFilterComponentClass);
|
|
35
|
+
baseConfig = presetFilterComponentConfig;
|
|
30
36
|
}
|
|
31
37
|
else {
|
|
32
|
-
componentClass = customFilterComponentClass;
|
|
38
|
+
componentClass = (customFilterComponentConfig?.componentClass ?? customFilterComponentClass);
|
|
39
|
+
baseConfig = customFilterComponentConfig;
|
|
33
40
|
}
|
|
34
41
|
const config = {
|
|
42
|
+
...baseConfig,
|
|
35
43
|
componentClass,
|
|
36
44
|
init: (filterSource) => {
|
|
37
45
|
connector.connectWithSource(filterSource);
|
|
@@ -40,16 +48,17 @@ export class DbxFilterPopoverComponent extends AbstractPopoverDirective {
|
|
|
40
48
|
}
|
|
41
49
|
if (closeOnFilterChange !== false) {
|
|
42
50
|
this._closeOnChangeSub.subscription = filterSource.filter$.pipe(skip(1), filterMaybe(), first(), defaultIfEmpty(undefined)).subscribe(() => {
|
|
43
|
-
console.log();
|
|
44
51
|
this.close();
|
|
45
52
|
});
|
|
46
53
|
}
|
|
54
|
+
// run the next init if provided
|
|
55
|
+
baseConfig?.init?.(filterSource);
|
|
47
56
|
}
|
|
48
57
|
};
|
|
49
58
|
return config;
|
|
50
59
|
}));
|
|
51
60
|
}
|
|
52
|
-
static openPopover(popupService, { width, height, isResizable, origin, header, icon, customFilterComponentClass, presetFilterComponentClass, connector, initialFilterObs, closeOnFilterChange }, popoverKey) {
|
|
61
|
+
static openPopover(popupService, { width, height, isResizable, origin, header, icon, customFilterComponentClass, presetFilterComponentClass, customFilterComponentConfig, presetFilterComponentConfig, connector, initialFilterObs, closeOnFilterChange, customizeButtonText, showCloseButton, closeButtonText }, popoverKey) {
|
|
53
62
|
return popupService.open({
|
|
54
63
|
key: popoverKey ?? DEFAULT_FILTER_POPOVER_KEY,
|
|
55
64
|
origin,
|
|
@@ -60,8 +69,13 @@ export class DbxFilterPopoverComponent extends AbstractPopoverDirective {
|
|
|
60
69
|
data: {
|
|
61
70
|
header,
|
|
62
71
|
icon,
|
|
72
|
+
customizeButtonText,
|
|
73
|
+
showCloseButton,
|
|
74
|
+
closeButtonText,
|
|
63
75
|
customFilterComponentClass,
|
|
64
76
|
presetFilterComponentClass,
|
|
77
|
+
customFilterComponentConfig,
|
|
78
|
+
presetFilterComponentConfig,
|
|
65
79
|
connector,
|
|
66
80
|
initialFilterObs,
|
|
67
81
|
closeOnFilterChange
|
|
@@ -79,14 +93,14 @@ export class DbxFilterPopoverComponent extends AbstractPopoverDirective {
|
|
|
79
93
|
}
|
|
80
94
|
ngOnInit() {
|
|
81
95
|
let showPreset = false;
|
|
82
|
-
const { customFilterComponentClass, presetFilterComponentClass } = this.config;
|
|
83
|
-
if (customFilterComponentClass) {
|
|
96
|
+
const { customFilterComponentClass, presetFilterComponentClass, customFilterComponentConfig, presetFilterComponentConfig } = this.config;
|
|
97
|
+
if (customFilterComponentClass || customFilterComponentConfig) {
|
|
84
98
|
showPreset = false;
|
|
85
99
|
}
|
|
86
|
-
if (presetFilterComponentClass) {
|
|
100
|
+
if (presetFilterComponentClass || presetFilterComponentConfig) {
|
|
87
101
|
showPreset = true;
|
|
88
102
|
}
|
|
89
|
-
if (!customFilterComponentClass && !presetFilterComponentClass) {
|
|
103
|
+
if (!(customFilterComponentClass || customFilterComponentConfig) && !(presetFilterComponentClass || presetFilterComponentConfig)) {
|
|
90
104
|
throw new Error('Requires a preset or custom class provided for DbxFilterPopover.');
|
|
91
105
|
}
|
|
92
106
|
this._showPreset.next(showPreset);
|
|
@@ -103,9 +117,9 @@ export class DbxFilterPopoverComponent extends AbstractPopoverDirective {
|
|
|
103
117
|
}
|
|
104
118
|
}
|
|
105
119
|
DbxFilterPopoverComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxFilterPopoverComponent, deps: [{ token: i1.DbxPopoverComponent }], target: i0.ɵɵFactoryTarget.Component });
|
|
106
|
-
DbxFilterPopoverComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: DbxFilterPopoverComponent, selector: "ng-component", usesInheritance: true, ngImport: i0, 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()\">
|
|
120
|
+
DbxFilterPopoverComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: DbxFilterPopoverComponent, selector: "ng-component", usesInheritance: true, ngImport: i0, 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()\">{{ customizeButtonText }}</button>\n <button *ngSwitchCase=\"false\" mat-flat-button color=\"accent\" (click)=\"showPresets()\">Presets</button>\n </ng-container>\n <ng-container *ngIf=\"showCloseButton\">\n <dbx-button-spacer *ngIf=\"showSwitchButtons\"></dbx-button-spacer>\n <button mat-stroked-button color=\"accent\" (click)=\"close()\">{{ closeButtonText }}</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", dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i2.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "component", type: i3.DbxPopoverContentComponent, selector: "dbx-popover-content" }, { kind: "component", type: i4.DbxPopoverHeaderComponent, selector: "dbx-popover-header", inputs: ["header", "icon"] }, { kind: "component", type: i5.DbxPopoverScrollContentComponent, selector: "dbx-popover-scroll-content" }, { kind: "directive", type: i6.DbxButtonSpacerDirective, selector: "dbx-button-spacer,[dbxButtonSpacer]" }, { kind: "component", type: i7.DbxInjectionComponent, selector: "dbx-injection, [dbxInjection], [dbx-injection]", inputs: ["config", "template"] }, { kind: "component", type: i8.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"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }] });
|
|
107
121
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxFilterPopoverComponent, decorators: [{
|
|
108
122
|
type: Component,
|
|
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()\">
|
|
123
|
+
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()\">{{ customizeButtonText }}</button>\n <button *ngSwitchCase=\"false\" mat-flat-button color=\"accent\" (click)=\"showPresets()\">Presets</button>\n </ng-container>\n <ng-container *ngIf=\"showCloseButton\">\n <dbx-button-spacer *ngIf=\"showSwitchButtons\"></dbx-button-spacer>\n <button mat-stroked-button color=\"accent\" (click)=\"close()\">{{ closeButtonText }}</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" }]
|
|
110
124
|
}], ctorParameters: function () { return [{ type: i1.DbxPopoverComponent }]; } });
|
|
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":"AACA,OAAO,EAAE,SAAS,EAAuC,MAAM,eAAe,CAAC;AAE/E,OAAO,EAAc,eAAe,EAAE,GAAG,EAAE,IAAI,EAAE,KAAK,EAAE,cAAc,EAAE,MAAM,MAAM,CAAC;AACrF,OAAO,EAAE,wBAAwB,EAAE,MAAM,uCAAuC,CAAC;AACjF,OAAO,EAAE,mBAAmB,EAAE,MAAM,8BAA8B,CAAC;AAEnE,OAAO,EAA2D,WAAW,EAAE,kBAAkB,EAAE,MAAM,eAAe,CAAC;;;;;;;;;AA+CzH,MAAM,CAAC,MAAM,0BAA0B,GAAG,QAAQ,CAAC;AAKnD,MAAM,OAAO,yBAA4C,SAAQ,wBAA8D;IAgE7H,YAAY,OAAkE;QAC5E,KAAK,CAAC,OAAO,CAAC,CAAC;QAhET,sBAAiB,GAAG,IAAI,kBAAkB,EAAE,CAAC;QAErD;;WAEG;QACM,sBAAiB,GAAG,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,0BAA0B,IAAI,IAAI,CAAC,MAAM,CAAC,0BAA0B,CAAC,CAAC;QAE/G,gBAAW,GAAG,IAAI,eAAe,CAAU,KAAK,CAAC,CAAC;QACjD,gBAAW,GAAG,IAAI,CAAC,WAAW,CAAC,YAAY,EAAE,CAAC;QAE9C,YAAO,GAA6D,IAAI,CAAC,WAAW,CAAC,IAAI,CAChG,GAAG,CAAC,CAAC,UAAU,EAAE,EAAE;YACjB,MAAM,EAAE,mBAAmB,GAAG,IAAI,EAAE,SAAS,EAAE,gBAAgB,EAAE,0BAA0B,EAAE,0BAA0B,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC;YACxI,IAAI,cAAqC,CAAC;YAE1C,IAAI,UAAU,EAAE;gBACd,cAAc,GAAG,0BAAmD,CAAC;aACtE;iBAAM;gBACL,cAAc,GAAG,0BAAmD,CAAC;aACtE;YAED,MAAM,MAAM,GAAiD;gBAC3D,cAAc;gBACd,IAAI,EAAE,CAAC,YAAY,EAAE,EAAE;oBACrB,SAAS,CAAC,iBAAiB,CAAC,YAAY,CAAC,CAAC;oBAE1C,IAAI,gBAAgB,IAAI,YAAY,CAAC,cAAc,EAAE;wBACnD,YAAY,CAAC,cAAc,CAAC,gBAAgB,CAAC,CAAC;qBAC/C;oBAED,IAAI,mBAAmB,KAAK,KAAK,EAAE;wBACjC,IAAI,CAAC,iBAAiB,CAAC,YAAY,GAAG,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,WAAW,EAAE,EAAE,KAAK,EAAE,EAAE,cAAc,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;4BACzI,OAAO,CAAC,GAAG,EAAE,CAAC;4BACd,IAAI,CAAC,KAAK,EAAE,CAAC;wBACf,CAAC,CAAC,CAAC;qBACJ;gBACH,CAAC;aACF,CAAC;YAEF,OAAO,MAAM,CAAC;QAChB,CAAC,CAAC,CACH,CAAC;IAwBF,CAAC;IAtBD,MAAM,CAAC,WAAW,CAAmB,YAA+B,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,0BAA0B,EAAE,0BAA0B,EAAE,SAAS,EAAE,gBAAgB,EAAE,mBAAmB,EAAsC,EAAE,UAA0B;QAClS,OAAO,YAAY,CAAC,IAAI,CAAC;YACvB,GAAG,EAAE,UAAU,IAAI,0BAA0B;YAC7C,MAAM;YACN,cAAc,EAAE,yBAAyB;YACzC,KAAK;YACL,MAAM;YACN,WAAW;YACX,IAAI,EAAE;gBACJ,MAAM;gBACN,IAAI;gBACJ,0BAA0B;gBAC1B,0BAA0B;gBAC1B,SAAS;gBACT,gBAAgB;gBAChB,mBAAmB;aACW;SACjC,CAAC,CAAC;IACL,CAAC;IAMD,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,OAAO,CAAC,IAAmC,CAAC;IAC1D,CAAC;IAED,IAAI,IAAI;QACN,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,IAAI,aAAa,CAAC;IAC3C,CAAC;IAED,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,MAAM,CAAC,MAAM,IAAI,QAAQ,CAAC;IACxC,CAAC;IAED,QAAQ;QACN,IAAI,UAAU,GAAG,KAAK,CAAC;QACvB,MAAM,EAAE,0BAA0B,EAAE,0BAA0B,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC;QAE/E,IAAI,0BAA0B,EAAE;YAC9B,UAAU,GAAG,KAAK,CAAC;SACpB;QAED,IAAI,0BAA0B,EAAE;YAC9B,UAAU,GAAG,IAAI,CAAC;SACnB;QAED,IAAI,CAAC,0BAA0B,IAAI,CAAC,0BAA0B,EAAE;YAC9D,MAAM,IAAI,KAAK,CAAC,kEAAkE,CAAC,CAAC;SACrF;QAED,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IACpC,CAAC;IAED,WAAW;QACT,IAAI,CAAC,iBAAiB,CAAC,OAAO,EAAE,CAAC;QACjC,IAAI,CAAC,WAAW,CAAC,QAAQ,EAAE,CAAC;IAC9B,CAAC;IAED,WAAW;QACT,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC9B,CAAC;IAED,UAAU;QACR,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC/B,CAAC;;uHA9GU,yBAAyB;2GAAzB,yBAAyB,2EC3DtC,2nBAaA;4FD8Ca,yBAAyB;kBAHrC,SAAS","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 } 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"]}
|
|
125
|
+
//# 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 } from '@dereekb/rxjs';\nimport { DbxPopoverKey } from '../popover/popover';\nimport { Maybe } from '@dereekb/util';\n\nexport interface DbxFilterComponentParams<F extends object = object, P extends string = string, CF extends FilterSource<F> = FilterSource<F>, PF extends PresetFilterSource<F, P> = PresetFilterSource<F, P>> 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 customize button text. If not defined, defaults to \"Customize\"\n   */\n  customizeButtonText?: string;\n  /**\n   * Custom close button text. If not defined, defaults to \"Close\"\n   */\n  closeButtonText?: string;\n  /**\n   * Whether or not to show the close button. Defaults to the value of !closeOnFilterChange\n   */\n  showCloseButton?: Maybe<boolean>;\n  /**\n   * Custom filter component to initialize.\n   */\n  customFilterComponentClass?: Type<CF>;\n  /**\n   * Preset filter component to initialize.\n   */\n  presetFilterComponentClass?: Type<PF>;\n  /**\n   * DbxInjectionComponentConfig for the custom filter component to initialize.\n   */\n  customFilterComponentConfig?: DbxInjectionComponentConfig<CF>;\n  /**\n   * DbxInjectionComponentConfig for the preset filter component to initialize.\n   */\n  presetFilterComponentConfig?: DbxInjectionComponentConfig<PF>;\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  readonly showCloseButton = this.config.showCloseButton ?? !(this.config.closeOnFilterChange ?? true);\n  readonly closeButtonText = this.config.closeButtonText ?? 'Close';\n  readonly customizeButtonText = this.config.customizeButtonText ?? 'Customize';\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, customFilterComponentConfig, presetFilterComponentConfig } = this.config;\n      let componentClass: Type<FilterSource<F>>;\n      let baseConfig: Maybe<DbxInjectionComponentConfig<FilterSource<F>>>;\n\n      if (showPreset) {\n        componentClass = (presetFilterComponentConfig?.componentClass ?? presetFilterComponentClass) as Type<FilterSource<F>>;\n        baseConfig = presetFilterComponentConfig;\n      } else {\n        componentClass = (customFilterComponentConfig?.componentClass ?? customFilterComponentClass) as Type<FilterSource<F>>;\n        baseConfig = customFilterComponentConfig;\n      }\n\n      const config: DbxInjectionComponentConfig<FilterSource<F>> = {\n        ...baseConfig,\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              this.close();\n            });\n          }\n\n          // run the next init if provided\n          baseConfig?.init?.(filterSource);\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, customFilterComponentConfig, presetFilterComponentConfig, connector, initialFilterObs, closeOnFilterChange, customizeButtonText, showCloseButton, closeButtonText }: 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        customizeButtonText,\n        showCloseButton,\n        closeButtonText,\n        customFilterComponentClass,\n        presetFilterComponentClass,\n        customFilterComponentConfig,\n        presetFilterComponentConfig,\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, customFilterComponentConfig, presetFilterComponentConfig } = this.config;\n\n    if (customFilterComponentClass || customFilterComponentConfig) {\n      showPreset = false;\n    }\n\n    if (presetFilterComponentClass || presetFilterComponentConfig) {\n      showPreset = true;\n    }\n\n    if (!(customFilterComponentClass || customFilterComponentConfig) && !(presetFilterComponentClass || presetFilterComponentConfig)) {\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()\">{{ customizeButtonText }}</button>\n      <button *ngSwitchCase=\"false\" mat-flat-button color=\"accent\" (click)=\"showPresets()\">Presets</button>\n    </ng-container>\n    <ng-container *ngIf=\"showCloseButton\">\n      <dbx-button-spacer *ngIf=\"showSwitchButtons\"></dbx-button-spacer>\n      <button mat-stroked-button color=\"accent\" (click)=\"close()\">{{ closeButtonText }}</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"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { shareReplay, BehaviorSubject, map, combineLatest, distinctUntilChanged, startWith } from 'rxjs';
|
|
2
|
-
import { Directive, Input } from '@angular/core';
|
|
2
|
+
import { Directive, EventEmitter, Input, Output } from '@angular/core';
|
|
3
3
|
import { FilterSourceDirective, isClickableFilterPreset } from '@dereekb/dbx-core';
|
|
4
4
|
import { getValueFromGetter, objectHasNoKeys } from '@dereekb/util';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
@@ -11,6 +11,7 @@ export class AbstractDbxPresetFilterMenuComponent {
|
|
|
11
11
|
constructor(filterSourceDirective) {
|
|
12
12
|
this.filterSourceDirective = filterSourceDirective;
|
|
13
13
|
//TODO: Rename to AbstractDbxPresetFilterMenuDirective with next breaking changes
|
|
14
|
+
this.presetSelected = new EventEmitter();
|
|
14
15
|
this._presets = new BehaviorSubject([]);
|
|
15
16
|
this.selected$ = this.filterSourceDirective.filter$.pipe(startWith(undefined), distinctUntilChanged(), shareReplay(1));
|
|
16
17
|
this.presetsWithPresetStringOnly$ = this._presets.pipe(map((x) => x.filter((y) => Boolean(y.preset))));
|
|
@@ -74,16 +75,20 @@ export class AbstractDbxPresetFilterMenuComponent {
|
|
|
74
75
|
}
|
|
75
76
|
this.filterSourceDirective.setFilter(filter);
|
|
76
77
|
}
|
|
78
|
+
this.presetSelected.next(preset);
|
|
77
79
|
}
|
|
78
80
|
ngOnDestroy() {
|
|
79
81
|
this._presets.complete();
|
|
82
|
+
this.presetSelected.complete();
|
|
80
83
|
}
|
|
81
84
|
}
|
|
82
85
|
AbstractDbxPresetFilterMenuComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: AbstractDbxPresetFilterMenuComponent, deps: [{ token: i1.FilterSourceDirective }], target: i0.ɵɵFactoryTarget.Directive });
|
|
83
|
-
AbstractDbxPresetFilterMenuComponent.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.12", type: AbstractDbxPresetFilterMenuComponent, inputs: { presets: "presets" }, ngImport: i0 });
|
|
86
|
+
AbstractDbxPresetFilterMenuComponent.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.12", type: AbstractDbxPresetFilterMenuComponent, inputs: { presets: "presets" }, outputs: { presetSelected: "presetSelected" }, ngImport: i0 });
|
|
84
87
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: AbstractDbxPresetFilterMenuComponent, decorators: [{
|
|
85
88
|
type: Directive
|
|
86
|
-
}], ctorParameters: function () { return [{ type: i1.FilterSourceDirective }]; }, propDecorators: {
|
|
89
|
+
}], ctorParameters: function () { return [{ type: i1.FilterSourceDirective }]; }, propDecorators: { presetSelected: [{
|
|
90
|
+
type: Output
|
|
91
|
+
}], presets: [{
|
|
87
92
|
type: Input
|
|
88
93
|
}] } });
|
|
89
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter.preset.js","sourceRoot":"","sources":["../../../../../../../packages/dbx-web/src/lib/interaction/filter/filter.preset.ts"],"names":[],"mappings":"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","sourcesContent":["import { shareReplay, BehaviorSubject, map, Observable, combineLatest, distinctUntilChanged, startWith } from 'rxjs';\nimport { Directive, Input, OnDestroy } from '@angular/core';\nimport { ClickableFilterPreset, ClickableAnchorLink, FilterSourceDirective, ClickablePartialFilterPreset, ClickableFilterPresetOrPartialPreset, isClickableFilterPreset } from '@dereekb/dbx-core';\nimport { getValueFromGetter, Maybe, objectHasNoKeys } from '@dereekb/util';\nimport { FilterWithPreset } from '@dereekb/rxjs';\n\n/**\n * Displays a button and menu for filtering presets.\n */\n@Directive()\nexport abstract class AbstractDbxPresetFilterMenuComponent<F extends FilterWithPreset> implements OnDestroy {\n  //TODO: Rename to AbstractDbxPresetFilterMenuDirective with next breaking changes\n\n  private _presets = new BehaviorSubject<ClickableFilterPresetOrPartialPreset<F>[]>([]);\n\n  readonly selected$: Observable<Maybe<F>> = this.filterSourceDirective.filter$.pipe(startWith(undefined), distinctUntilChanged(), shareReplay(1));\n  readonly presetsWithPresetStringOnly$: Observable<ClickableFilterPreset<F>[]> = this._presets.pipe(map((x) => x.filter((y) => Boolean((y as ClickableFilterPreset<F>).preset)) as ClickableFilterPreset<F>[]));\n\n  readonly selectedPresetString$: Observable<Maybe<string>> = this.selected$.pipe(\n    map((selectedFilter) => (selectedFilter ? selectedFilter.preset : undefined)),\n    distinctUntilChanged()\n  );\n\n  readonly presetAnchorsPairs$: Observable<['preset' | 'partialPreset', ClickableFilterPresetOrPartialPreset<F>, ClickableAnchorLink][]> = combineLatest([this._presets, this.selected$, this.selectedPresetString$]).pipe(\n    map(([presets, currentFilterValue, selectedPresetString]) => {\n      return presets.map((x) => {\n        let selected: boolean;\n        let type: 'preset' | 'partialPreset';\n\n        if (isClickableFilterPreset(x)) {\n          selected = x.preset === selectedPresetString;\n          type = 'preset';\n        } else {\n          selected = x.isActive(currentFilterValue);\n          type = 'partialPreset';\n        }\n\n        return [\n          type,\n          x,\n          {\n            ...x,\n            selected,\n            onClick: () => {\n              this.selectPreset(x);\n            }\n          }\n        ] as [typeof type, ClickableFilterPresetOrPartialPreset<F>, ClickableAnchorLink];\n      });\n    }),\n    shareReplay(1)\n  );\n\n  readonly presetAnchors$: Observable<ClickableAnchorLink[]> = this.presetAnchorsPairs$.pipe(\n    map((x) => x.map((x) => x[2])),\n    shareReplay(1)\n  );\n\n  readonly firstSelectedAnchorPair$ = this.presetAnchorsPairs$.pipe(\n    map((presets) => {\n      const firstSelected = presets.find((x) => x[2].selected);\n      return firstSelected ? firstSelected : undefined;\n    }),\n    shareReplay(1)\n  );\n\n  readonly selectedPreset$: Observable<Maybe<ClickableFilterPreset<F>>> = this.presetAnchorsPairs$.pipe(\n    map((presets) => {\n      const firstSelected = presets.filter((x) => x[0] === 'preset').find((x) => x[2].selected);\n      return firstSelected ? (firstSelected[1] as ClickableFilterPreset<F>) : undefined;\n    }),\n    shareReplay(1)\n  );\n\n  @Input()\n  get presets(): ClickableFilterPresetOrPartialPreset<F>[] {\n    return this._presets.value;\n  }\n\n  set presets(presets: ClickableFilterPresetOrPartialPreset<F>[]) {\n    this._presets.next(presets);\n  }\n\n  constructor(readonly filterSourceDirective: FilterSourceDirective<F>) {}\n\n  selectPreset(preset: ClickableFilterPresetOrPartialPreset<F>) {\n    const presetString = (preset as ClickableFilterPreset<F>).preset;\n    const presetValue = (preset as ClickableFilterPreset<F>).presetValue || (preset as ClickablePartialFilterPreset<F>).partialPresetValue;\n\n    if (presetValue == null || (typeof presetValue !== 'function' && objectHasNoKeys(presetValue))) {\n      // set and then reset if the value is null or empty\n      this.filterSourceDirective.setFilter((presetValue ?? {}) as F);\n      this.filterSourceDirective.resetFilter();\n    } else {\n      let filter = getValueFromGetter(presetValue) as F;\n\n      if (filter.preset !== presetString) {\n        filter = {\n          ...filter,\n          preset: presetString\n        };\n      }\n\n      this.filterSourceDirective.setFilter(filter);\n    }\n  }\n\n  ngOnDestroy(): void {\n    this._presets.complete();\n  }\n}\n"]}
|
|
94
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter.preset.js","sourceRoot":"","sources":["../../../../../../../packages/dbx-web/src/lib/interaction/filter/filter.preset.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,eAAe,EAAE,GAAG,EAAc,aAAa,EAAE,oBAAoB,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AACrH,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAa,MAAM,EAAE,MAAM,eAAe,CAAC;AAClF,OAAO,EAA8C,qBAAqB,EAAsE,uBAAuB,EAAE,MAAM,mBAAmB,CAAC;AACnM,OAAO,EAAE,kBAAkB,EAAS,eAAe,EAAE,MAAM,eAAe,CAAC;;;AAG3E;;GAEG;AAEH,MAAM,OAAgB,oCAAoC;IA4ExD,YAAqB,qBAA+C;QAA/C,0BAAqB,GAArB,qBAAqB,CAA0B;QA3EpE,iFAAiF;QAGjF,mBAAc,GAAG,IAAI,YAAY,EAA2C,CAAC;QAErE,aAAQ,GAAG,IAAI,eAAe,CAA4C,EAAE,CAAC,CAAC;QAE7E,cAAS,GAAyB,IAAI,CAAC,qBAAqB,CAAC,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,EAAE,oBAAoB,EAAE,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC;QACxI,iCAA4B,GAA2C,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,OAAO,CAAE,CAA8B,CAAC,MAAM,CAAC,CAA+B,CAAC,CAAC,CAAC;QAEtM,0BAAqB,GAA8B,IAAI,CAAC,SAAS,CAAC,IAAI,CAC7E,GAAG,CAAC,CAAC,cAAc,EAAE,EAAE,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,EAC7E,oBAAoB,EAAE,CACvB,CAAC;QAEO,wBAAmB,GAA6G,aAAa,CAAC,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,qBAAqB,CAAC,CAAC,CAAC,IAAI,CACtN,GAAG,CAAC,CAAC,CAAC,OAAO,EAAE,kBAAkB,EAAE,oBAAoB,CAAC,EAAE,EAAE;YAC1D,OAAO,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE;gBACvB,IAAI,QAAiB,CAAC;gBACtB,IAAI,IAAgC,CAAC;gBAErC,IAAI,uBAAuB,CAAC,CAAC,CAAC,EAAE;oBAC9B,QAAQ,GAAG,CAAC,CAAC,MAAM,KAAK,oBAAoB,CAAC;oBAC7C,IAAI,GAAG,QAAQ,CAAC;iBACjB;qBAAM;oBACL,QAAQ,GAAG,CAAC,CAAC,QAAQ,CAAC,kBAAkB,CAAC,CAAC;oBAC1C,IAAI,GAAG,eAAe,CAAC;iBACxB;gBAED,OAAO;oBACL,IAAI;oBACJ,CAAC;oBACD;wBACE,GAAG,CAAC;wBACJ,QAAQ;wBACR,OAAO,EAAE,GAAG,EAAE;4BACZ,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;wBACvB,CAAC;qBACF;iBAC6E,CAAC;YACnF,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,EACF,WAAW,CAAC,CAAC,CAAC,CACf,CAAC;QAEO,mBAAc,GAAsC,IAAI,CAAC,mBAAmB,CAAC,IAAI,CACxF,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAC9B,WAAW,CAAC,CAAC,CAAC,CACf,CAAC;QAEO,6BAAwB,GAAG,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAC/D,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE;YACd,MAAM,aAAa,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC;YACzD,OAAO,aAAa,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,SAAS,CAAC;QACnD,CAAC,CAAC,EACF,WAAW,CAAC,CAAC,CAAC,CACf,CAAC;QAEO,oBAAe,GAAgD,IAAI,CAAC,mBAAmB,CAAC,IAAI,CACnG,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE;YACd,MAAM,aAAa,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,QAAQ,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC;YAC1F,OAAO,aAAa,CAAC,CAAC,CAAE,aAAa,CAAC,CAAC,CAA8B,CAAC,CAAC,CAAC,SAAS,CAAC;QACpF,CAAC,CAAC,EACF,WAAW,CAAC,CAAC,CAAC,CACf,CAAC;IAWqE,CAAC;IATxE,IACI,OAAO;QACT,OAAO,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC;IAC7B,CAAC;IAED,IAAI,OAAO,CAAC,OAAkD;QAC5D,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IAC9B,CAAC;IAID,YAAY,CAAC,MAA+C;QAC1D,MAAM,YAAY,GAAI,MAAmC,CAAC,MAAM,CAAC;QACjE,MAAM,WAAW,GAAI,MAAmC,CAAC,WAAW,IAAK,MAA0C,CAAC,kBAAkB,CAAC;QAEvI,IAAI,WAAW,IAAI,IAAI,IAAI,CAAC,OAAO,WAAW,KAAK,UAAU,IAAI,eAAe,CAAC,WAAW,CAAC,CAAC,EAAE;YAC9F,mDAAmD;YACnD,IAAI,CAAC,qBAAqB,CAAC,SAAS,CAAC,CAAC,WAAW,IAAI,EAAE,CAAM,CAAC,CAAC;YAC/D,IAAI,CAAC,qBAAqB,CAAC,WAAW,EAAE,CAAC;SAC1C;aAAM;YACL,IAAI,MAAM,GAAG,kBAAkB,CAAC,WAAW,CAAM,CAAC;YAElD,IAAI,MAAM,CAAC,MAAM,KAAK,YAAY,EAAE;gBAClC,MAAM,GAAG;oBACP,GAAG,MAAM;oBACT,MAAM,EAAE,YAAY;iBACrB,CAAC;aACH;YAED,IAAI,CAAC,qBAAqB,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;SAC9C;QAED,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IACnC,CAAC;IAED,WAAW;QACT,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;QACzB,IAAI,CAAC,cAAc,CAAC,QAAQ,EAAE,CAAC;IACjC,CAAC;;kIAzGmB,oCAAoC;sHAApC,oCAAoC;4FAApC,oCAAoC;kBADzD,SAAS;4GAKR,cAAc;sBADb,MAAM;gBAiEH,OAAO;sBADV,KAAK","sourcesContent":["import { shareReplay, BehaviorSubject, map, Observable, combineLatest, distinctUntilChanged, startWith } from 'rxjs';\nimport { Directive, EventEmitter, Input, OnDestroy, Output } from '@angular/core';\nimport { ClickableFilterPreset, ClickableAnchorLink, FilterSourceDirective, ClickablePartialFilterPreset, ClickableFilterPresetOrPartialPreset, isClickableFilterPreset } from '@dereekb/dbx-core';\nimport { getValueFromGetter, Maybe, objectHasNoKeys } from '@dereekb/util';\nimport { FilterWithPreset } from '@dereekb/rxjs';\n\n/**\n * Displays a button and menu for filtering presets.\n */\n@Directive()\nexport abstract class AbstractDbxPresetFilterMenuComponent<F extends FilterWithPreset> implements OnDestroy {\n  //TODO: Rename to AbstractDbxPresetFilterMenuDirective with next breaking changes\n\n  @Output()\n  presetSelected = new EventEmitter<ClickableFilterPresetOrPartialPreset<F>>();\n\n  private _presets = new BehaviorSubject<ClickableFilterPresetOrPartialPreset<F>[]>([]);\n\n  readonly selected$: Observable<Maybe<F>> = this.filterSourceDirective.filter$.pipe(startWith(undefined), distinctUntilChanged(), shareReplay(1));\n  readonly presetsWithPresetStringOnly$: Observable<ClickableFilterPreset<F>[]> = this._presets.pipe(map((x) => x.filter((y) => Boolean((y as ClickableFilterPreset<F>).preset)) as ClickableFilterPreset<F>[]));\n\n  readonly selectedPresetString$: Observable<Maybe<string>> = this.selected$.pipe(\n    map((selectedFilter) => (selectedFilter ? selectedFilter.preset : undefined)),\n    distinctUntilChanged()\n  );\n\n  readonly presetAnchorsPairs$: Observable<['preset' | 'partialPreset', ClickableFilterPresetOrPartialPreset<F>, ClickableAnchorLink][]> = combineLatest([this._presets, this.selected$, this.selectedPresetString$]).pipe(\n    map(([presets, currentFilterValue, selectedPresetString]) => {\n      return presets.map((x) => {\n        let selected: boolean;\n        let type: 'preset' | 'partialPreset';\n\n        if (isClickableFilterPreset(x)) {\n          selected = x.preset === selectedPresetString;\n          type = 'preset';\n        } else {\n          selected = x.isActive(currentFilterValue);\n          type = 'partialPreset';\n        }\n\n        return [\n          type,\n          x,\n          {\n            ...x,\n            selected,\n            onClick: () => {\n              this.selectPreset(x);\n            }\n          }\n        ] as [typeof type, ClickableFilterPresetOrPartialPreset<F>, ClickableAnchorLink];\n      });\n    }),\n    shareReplay(1)\n  );\n\n  readonly presetAnchors$: Observable<ClickableAnchorLink[]> = this.presetAnchorsPairs$.pipe(\n    map((x) => x.map((x) => x[2])),\n    shareReplay(1)\n  );\n\n  readonly firstSelectedAnchorPair$ = this.presetAnchorsPairs$.pipe(\n    map((presets) => {\n      const firstSelected = presets.find((x) => x[2].selected);\n      return firstSelected ? firstSelected : undefined;\n    }),\n    shareReplay(1)\n  );\n\n  readonly selectedPreset$: Observable<Maybe<ClickableFilterPreset<F>>> = this.presetAnchorsPairs$.pipe(\n    map((presets) => {\n      const firstSelected = presets.filter((x) => x[0] === 'preset').find((x) => x[2].selected);\n      return firstSelected ? (firstSelected[1] as ClickableFilterPreset<F>) : undefined;\n    }),\n    shareReplay(1)\n  );\n\n  @Input()\n  get presets(): ClickableFilterPresetOrPartialPreset<F>[] {\n    return this._presets.value;\n  }\n\n  set presets(presets: ClickableFilterPresetOrPartialPreset<F>[]) {\n    this._presets.next(presets);\n  }\n\n  constructor(readonly filterSourceDirective: FilterSourceDirective<F>) {}\n\n  selectPreset(preset: ClickableFilterPresetOrPartialPreset<F>) {\n    const presetString = (preset as ClickableFilterPreset<F>).preset;\n    const presetValue = (preset as ClickableFilterPreset<F>).presetValue || (preset as ClickablePartialFilterPreset<F>).partialPresetValue;\n\n    if (presetValue == null || (typeof presetValue !== 'function' && objectHasNoKeys(presetValue))) {\n      // set and then reset if the value is null or empty\n      this.filterSourceDirective.setFilter((presetValue ?? {}) as F);\n      this.filterSourceDirective.resetFilter();\n    } else {\n      let filter = getValueFromGetter(presetValue) as F;\n\n      if (filter.preset !== presetString) {\n        filter = {\n          ...filter,\n          preset: presetString\n        };\n      }\n\n      this.filterSourceDirective.setFilter(filter);\n    }\n\n    this.presetSelected.next(preset);\n  }\n\n  ngOnDestroy(): void {\n    this._presets.complete();\n    this.presetSelected.complete();\n  }\n}\n"]}
|
|
@@ -1845,8 +1845,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
1845
1845
|
const DEFAULT_FILTER_POPOVER_KEY = 'filter';
|
|
1846
1846
|
class DbxFilterPopoverComponent extends AbstractPopoverDirective {
|
|
1847
1847
|
constructor(popover) {
|
|
1848
|
+
var _a, _b, _c, _d;
|
|
1848
1849
|
super(popover);
|
|
1849
1850
|
this._closeOnChangeSub = new SubscriptionObject();
|
|
1851
|
+
this.showCloseButton = (_a = this.config.showCloseButton) !== null && _a !== void 0 ? _a : !((_b = this.config.closeOnFilterChange) !== null && _b !== void 0 ? _b : true);
|
|
1852
|
+
this.closeButtonText = (_c = this.config.closeButtonText) !== null && _c !== void 0 ? _c : 'Close';
|
|
1853
|
+
this.customizeButtonText = (_d = this.config.customizeButtonText) !== null && _d !== void 0 ? _d : 'Customize';
|
|
1850
1854
|
/**
|
|
1851
1855
|
* Whether or not to display buttons to toggle between custom and preset filters.
|
|
1852
1856
|
*/
|
|
@@ -1854,33 +1858,36 @@ class DbxFilterPopoverComponent extends AbstractPopoverDirective {
|
|
|
1854
1858
|
this._showPreset = new BehaviorSubject(false);
|
|
1855
1859
|
this.showPreset$ = this._showPreset.asObservable();
|
|
1856
1860
|
this.config$ = this._showPreset.pipe(map((showPreset) => {
|
|
1857
|
-
|
|
1861
|
+
var _a, _b;
|
|
1862
|
+
const { closeOnFilterChange = true, connector, initialFilterObs, customFilterComponentClass, presetFilterComponentClass, customFilterComponentConfig, presetFilterComponentConfig } = this.config;
|
|
1858
1863
|
let componentClass;
|
|
1864
|
+
let baseConfig;
|
|
1859
1865
|
if (showPreset) {
|
|
1860
|
-
componentClass = presetFilterComponentClass;
|
|
1866
|
+
componentClass = ((_a = presetFilterComponentConfig === null || presetFilterComponentConfig === void 0 ? void 0 : presetFilterComponentConfig.componentClass) !== null && _a !== void 0 ? _a : presetFilterComponentClass);
|
|
1867
|
+
baseConfig = presetFilterComponentConfig;
|
|
1861
1868
|
}
|
|
1862
1869
|
else {
|
|
1863
|
-
componentClass = customFilterComponentClass;
|
|
1870
|
+
componentClass = ((_b = customFilterComponentConfig === null || customFilterComponentConfig === void 0 ? void 0 : customFilterComponentConfig.componentClass) !== null && _b !== void 0 ? _b : customFilterComponentClass);
|
|
1871
|
+
baseConfig = customFilterComponentConfig;
|
|
1864
1872
|
}
|
|
1865
|
-
const config = {
|
|
1866
|
-
|
|
1867
|
-
init: (filterSource) => {
|
|
1873
|
+
const config = Object.assign(Object.assign({}, baseConfig), { componentClass, init: (filterSource) => {
|
|
1874
|
+
var _a;
|
|
1868
1875
|
connector.connectWithSource(filterSource);
|
|
1869
1876
|
if (initialFilterObs && filterSource.initWithFilter) {
|
|
1870
1877
|
filterSource.initWithFilter(initialFilterObs);
|
|
1871
1878
|
}
|
|
1872
1879
|
if (closeOnFilterChange !== false) {
|
|
1873
1880
|
this._closeOnChangeSub.subscription = filterSource.filter$.pipe(skip(1), filterMaybe(), first(), defaultIfEmpty(undefined)).subscribe(() => {
|
|
1874
|
-
console.log();
|
|
1875
1881
|
this.close();
|
|
1876
1882
|
});
|
|
1877
1883
|
}
|
|
1878
|
-
|
|
1879
|
-
|
|
1884
|
+
// run the next init if provided
|
|
1885
|
+
(_a = baseConfig === null || baseConfig === void 0 ? void 0 : baseConfig.init) === null || _a === void 0 ? void 0 : _a.call(baseConfig, filterSource);
|
|
1886
|
+
} });
|
|
1880
1887
|
return config;
|
|
1881
1888
|
}));
|
|
1882
1889
|
}
|
|
1883
|
-
static openPopover(popupService, { width, height, isResizable, origin, header, icon, customFilterComponentClass, presetFilterComponentClass, connector, initialFilterObs, closeOnFilterChange }, popoverKey) {
|
|
1890
|
+
static openPopover(popupService, { width, height, isResizable, origin, header, icon, customFilterComponentClass, presetFilterComponentClass, customFilterComponentConfig, presetFilterComponentConfig, connector, initialFilterObs, closeOnFilterChange, customizeButtonText, showCloseButton, closeButtonText }, popoverKey) {
|
|
1884
1891
|
return popupService.open({
|
|
1885
1892
|
key: popoverKey !== null && popoverKey !== void 0 ? popoverKey : DEFAULT_FILTER_POPOVER_KEY,
|
|
1886
1893
|
origin,
|
|
@@ -1891,8 +1898,13 @@ class DbxFilterPopoverComponent extends AbstractPopoverDirective {
|
|
|
1891
1898
|
data: {
|
|
1892
1899
|
header,
|
|
1893
1900
|
icon,
|
|
1901
|
+
customizeButtonText,
|
|
1902
|
+
showCloseButton,
|
|
1903
|
+
closeButtonText,
|
|
1894
1904
|
customFilterComponentClass,
|
|
1895
1905
|
presetFilterComponentClass,
|
|
1906
|
+
customFilterComponentConfig,
|
|
1907
|
+
presetFilterComponentConfig,
|
|
1896
1908
|
connector,
|
|
1897
1909
|
initialFilterObs,
|
|
1898
1910
|
closeOnFilterChange
|
|
@@ -1912,14 +1924,14 @@ class DbxFilterPopoverComponent extends AbstractPopoverDirective {
|
|
|
1912
1924
|
}
|
|
1913
1925
|
ngOnInit() {
|
|
1914
1926
|
let showPreset = false;
|
|
1915
|
-
const { customFilterComponentClass, presetFilterComponentClass } = this.config;
|
|
1916
|
-
if (customFilterComponentClass) {
|
|
1927
|
+
const { customFilterComponentClass, presetFilterComponentClass, customFilterComponentConfig, presetFilterComponentConfig } = this.config;
|
|
1928
|
+
if (customFilterComponentClass || customFilterComponentConfig) {
|
|
1917
1929
|
showPreset = false;
|
|
1918
1930
|
}
|
|
1919
|
-
if (presetFilterComponentClass) {
|
|
1931
|
+
if (presetFilterComponentClass || presetFilterComponentConfig) {
|
|
1920
1932
|
showPreset = true;
|
|
1921
1933
|
}
|
|
1922
|
-
if (!customFilterComponentClass && !presetFilterComponentClass) {
|
|
1934
|
+
if (!(customFilterComponentClass || customFilterComponentConfig) && !(presetFilterComponentClass || presetFilterComponentConfig)) {
|
|
1923
1935
|
throw new Error('Requires a preset or custom class provided for DbxFilterPopover.');
|
|
1924
1936
|
}
|
|
1925
1937
|
this._showPreset.next(showPreset);
|
|
@@ -1936,10 +1948,10 @@ class DbxFilterPopoverComponent extends AbstractPopoverDirective {
|
|
|
1936
1948
|
}
|
|
1937
1949
|
}
|
|
1938
1950
|
DbxFilterPopoverComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxFilterPopoverComponent, deps: [{ token: DbxPopoverComponent }], target: i0.ɵɵFactoryTarget.Component });
|
|
1939
|
-
DbxFilterPopoverComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: DbxFilterPopoverComponent, selector: "ng-component", usesInheritance: true, ngImport: i0, 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()\">
|
|
1951
|
+
DbxFilterPopoverComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: DbxFilterPopoverComponent, selector: "ng-component", usesInheritance: true, ngImport: i0, 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()\">{{ customizeButtonText }}</button>\n <button *ngSwitchCase=\"false\" mat-flat-button color=\"accent\" (click)=\"showPresets()\">Presets</button>\n </ng-container>\n <ng-container *ngIf=\"showCloseButton\">\n <dbx-button-spacer *ngIf=\"showSwitchButtons\"></dbx-button-spacer>\n <button mat-stroked-button color=\"accent\" (click)=\"close()\">{{ closeButtonText }}</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", 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: "component", type: DbxPopoverContentComponent, selector: "dbx-popover-content" }, { kind: "component", type: DbxPopoverHeaderComponent, selector: "dbx-popover-header", inputs: ["header", "icon"] }, { kind: "component", type: DbxPopoverScrollContentComponent, selector: "dbx-popover-scroll-content" }, { kind: "directive", type: DbxButtonSpacerDirective, selector: "dbx-button-spacer,[dbxButtonSpacer]" }, { kind: "component", type: i1$2.DbxInjectionComponent, selector: "dbx-injection, [dbxInjection], [dbx-injection]", inputs: ["config", "template"] }, { kind: "component", type: i2.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"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }] });
|
|
1940
1952
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxFilterPopoverComponent, decorators: [{
|
|
1941
1953
|
type: Component,
|
|
1942
|
-
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()\">
|
|
1954
|
+
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()\">{{ customizeButtonText }}</button>\n <button *ngSwitchCase=\"false\" mat-flat-button color=\"accent\" (click)=\"showPresets()\">Presets</button>\n </ng-container>\n <ng-container *ngIf=\"showCloseButton\">\n <dbx-button-spacer *ngIf=\"showSwitchButtons\"></dbx-button-spacer>\n <button mat-stroked-button color=\"accent\" (click)=\"close()\">{{ closeButtonText }}</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" }]
|
|
1943
1955
|
}], ctorParameters: function () { return [{ type: DbxPopoverComponent }]; } });
|
|
1944
1956
|
|
|
1945
1957
|
/**
|
|
@@ -2273,6 +2285,7 @@ class AbstractDbxPresetFilterMenuComponent {
|
|
|
2273
2285
|
constructor(filterSourceDirective) {
|
|
2274
2286
|
this.filterSourceDirective = filterSourceDirective;
|
|
2275
2287
|
//TODO: Rename to AbstractDbxPresetFilterMenuDirective with next breaking changes
|
|
2288
|
+
this.presetSelected = new EventEmitter();
|
|
2276
2289
|
this._presets = new BehaviorSubject([]);
|
|
2277
2290
|
this.selected$ = this.filterSourceDirective.filter$.pipe(startWith(undefined), distinctUntilChanged(), shareReplay(1));
|
|
2278
2291
|
this.presetsWithPresetStringOnly$ = this._presets.pipe(map((x) => x.filter((y) => Boolean(y.preset))));
|
|
@@ -2329,16 +2342,20 @@ class AbstractDbxPresetFilterMenuComponent {
|
|
|
2329
2342
|
}
|
|
2330
2343
|
this.filterSourceDirective.setFilter(filter);
|
|
2331
2344
|
}
|
|
2345
|
+
this.presetSelected.next(preset);
|
|
2332
2346
|
}
|
|
2333
2347
|
ngOnDestroy() {
|
|
2334
2348
|
this._presets.complete();
|
|
2349
|
+
this.presetSelected.complete();
|
|
2335
2350
|
}
|
|
2336
2351
|
}
|
|
2337
2352
|
AbstractDbxPresetFilterMenuComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: AbstractDbxPresetFilterMenuComponent, deps: [{ token: i1$2.FilterSourceDirective }], target: i0.ɵɵFactoryTarget.Directive });
|
|
2338
|
-
AbstractDbxPresetFilterMenuComponent.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.12", type: AbstractDbxPresetFilterMenuComponent, inputs: { presets: "presets" }, ngImport: i0 });
|
|
2353
|
+
AbstractDbxPresetFilterMenuComponent.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.12", type: AbstractDbxPresetFilterMenuComponent, inputs: { presets: "presets" }, outputs: { presetSelected: "presetSelected" }, ngImport: i0 });
|
|
2339
2354
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: AbstractDbxPresetFilterMenuComponent, decorators: [{
|
|
2340
2355
|
type: Directive
|
|
2341
|
-
}], ctorParameters: function () { return [{ type: i1$2.FilterSourceDirective }]; }, propDecorators: {
|
|
2356
|
+
}], ctorParameters: function () { return [{ type: i1$2.FilterSourceDirective }]; }, propDecorators: { presetSelected: [{
|
|
2357
|
+
type: Output
|
|
2358
|
+
}], presets: [{
|
|
2342
2359
|
type: Input
|
|
2343
2360
|
}] } });
|
|
2344
2361
|
|