@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.
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@dereekb/dbx-web/calendar",
3
- "version": "9.24.16",
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.16"
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLnBvcG92ZXIuYnV0dG9uLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC13ZWIvc3JjL2xpYi9pbnRlcmFjdGlvbi9maWx0ZXIvZmlsdGVyLnBvcG92ZXIuYnV0dG9uLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFjLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUU3RCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUMvRCxPQUFPLEVBQUUseUJBQXlCLEVBQTRCLE1BQU0sNEJBQTRCLENBQUM7QUFDakcsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sMkNBQTJDLENBQUM7OztBQUt4RixNQUFNLE9BQWdCLG9DQUF1RCxTQUFRLDJCQUE2QztJQUloSSxZQUE2QixZQUErQjtRQUMxRCxLQUFLLEVBQUUsQ0FBQztRQURtQixpQkFBWSxHQUFaLFlBQVksQ0FBbUI7SUFFNUQsQ0FBQztJQUVrQixlQUFlLENBQUMsTUFBbUI7UUFDcEQsTUFBTSxNQUFNLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQztRQUUzQixJQUFJLENBQUMsTUFBTSxFQUFFO1lBQ1gsTUFBTSxJQUFJLEtBQUssQ0FBQyw2QkFBNkIsQ0FBQyxDQUFDO1NBQ2hEO2FBQU0sSUFBSSxDQUFDLE1BQU0sRUFBRTtZQUNsQixNQUFNLElBQUksS0FBSyxDQUFDLGlCQUFpQixDQUFDLENBQUM7U0FDcEM7UUFFRCxPQUFPLHlCQUF5QixDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsWUFBWSxFQUFFO1lBQzlELE1BQU07WUFDTixHQUFHLE1BQU07U0FDVixDQUFDLENBQUM7SUFDTCxDQUFDOztrSUFyQm1CLG9DQUFvQztzSEFBcEMsb0NBQW9DOzRGQUFwQyxvQ0FBb0M7a0JBRHpELFNBQVM7d0dBR1IsTUFBTTtzQkFETCxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBFbGVtZW50UmVmLCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTmdQb3BvdmVyUmVmIH0gZnJvbSAnbmctb3ZlcmxheS1jb250YWluZXInO1xuaW1wb3J0IHsgRGJ4UG9wb3ZlclNlcnZpY2UgfSBmcm9tICcuLi9wb3BvdmVyL3BvcG92ZXIuc2VydmljZSc7XG5pbXBvcnQgeyBEYnhGaWx0ZXJQb3BvdmVyQ29tcG9uZW50LCBEYnhGaWx0ZXJDb21wb25lbnRQYXJhbXMgfSBmcm9tICcuL2ZpbHRlci5wb3BvdmVyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBBYnN0cmFjdFBvcG92ZXJSZWZEaXJlY3RpdmUgfSBmcm9tICcuLi9wb3BvdmVyL2Fic3RyYWN0LnBvcG92ZXIucmVmLmRpcmVjdGl2ZSc7XG5cbmV4cG9ydCB0eXBlIERieEZpbHRlckJ1dHRvbkNvbmZpZzxGIGV4dGVuZHMgb2JqZWN0PiA9IERieEZpbHRlckNvbXBvbmVudFBhcmFtczxGPjtcblxuQERpcmVjdGl2ZSgpXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgQWJzdHJhY3RGaWx0ZXJQb3BvdmVyQnV0dG9uRGlyZWN0aXZlPEYgZXh0ZW5kcyBvYmplY3Q+IGV4dGVuZHMgQWJzdHJhY3RQb3BvdmVyUmVmRGlyZWN0aXZlPHVua25vd24sIHVua25vd24+IHtcbiAgQElucHV0KClcbiAgY29uZmlnPzogRGJ4RmlsdGVyQnV0dG9uQ29uZmlnPEY+O1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgcmVhZG9ubHkgcG9wdXBTZXJ2aWNlOiBEYnhQb3BvdmVyU2VydmljZSkge1xuICAgIHN1cGVyKCk7XG4gIH1cblxuICBwcm90ZWN0ZWQgb3ZlcnJpZGUgX21ha2VQb3BvdmVyUmVmKG9yaWdpbj86IEVsZW1lbnRSZWYpOiBOZ1BvcG92ZXJSZWY8dW5rbm93biwgdW5rbm93bj4ge1xuICAgIGNvbnN0IGNvbmZpZyA9IHRoaXMuY29uZmlnO1xuXG4gICAgaWYgKCFjb25maWcpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcignTWlzc2luZyBmaWx0ZXJCdXR0b25Db25maWcuJyk7XG4gICAgfSBlbHNlIGlmICghb3JpZ2luKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoJ01pc3Npbmcgb3JpZ2luLicpO1xuICAgIH1cblxuICAgIHJldHVybiBEYnhGaWx0ZXJQb3BvdmVyQ29tcG9uZW50Lm9wZW5Qb3BvdmVyKHRoaXMucG9wdXBTZXJ2aWNlLCB7XG4gICAgICBvcmlnaW4sXG4gICAgICAuLi5jb25maWdcbiAgICB9KTtcbiAgfVxufVxuIl19
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 "@dereekb/dbx-core";
13
- import * as i7 from "@angular/material/button";
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()\">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", 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: "component", type: i6.DbxInjectionComponent, selector: "dbx-injection, [dbxInjection], [dbx-injection]", inputs: ["config", "template"] }, { kind: "component", type: i7.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" }] });
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()\">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" }]
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":"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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';\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: { presets: [{
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":"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","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
- const { closeOnFilterChange = true, connector, initialFilterObs, customFilterComponentClass, presetFilterComponentClass } = this.config;
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
- componentClass,
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()\">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", 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: "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" }] });
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()\">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" }]
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: { presets: [{
2356
+ }], ctorParameters: function () { return [{ type: i1$2.FilterSourceDirective }]; }, propDecorators: { presetSelected: [{
2357
+ type: Output
2358
+ }], presets: [{
2342
2359
  type: Input
2343
2360
  }] } });
2344
2361