@dereekb/dbx-web 9.24.8 → 9.24.10
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.component.mjs +1 -1
- package/esm2020/lib/interaction/filter/filter.preset.mjs +39 -15
- package/esm2020/lib/interaction/popover/popover.component.mjs +1 -1
- package/esm2020/lib/interaction/popover/popover.service.mjs +1 -1
- package/fesm2015/dereekb-dbx-web.mjs +35 -11
- package/fesm2015/dereekb-dbx-web.mjs.map +1 -1
- package/fesm2020/dereekb-dbx-web.mjs +38 -14
- package/fesm2020/dereekb-dbx-web.mjs.map +1 -1
- package/lib/interaction/filter/filter.preset.d.ts +7 -4
- package/lib/interaction/popover/popover.service.d.ts +1 -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.10",
|
|
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.10"
|
|
12
12
|
},
|
|
13
13
|
"dependencies": {
|
|
14
14
|
"tslib": "^2.3.0"
|
|
@@ -108,4 +108,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
108
108
|
type: Component,
|
|
109
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" }]
|
|
110
110
|
}], 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, tapLog } from '@dereekb/rxjs';\nimport { DbxPopoverKey } from '../popover/popover';\n\nexport interface DbxFilterComponentParams<F extends object = object, P extends string = string> extends DbxPopoverConfigSizing {\n  /**\n   * Custom icon\n   *\n   * Defaults to \"filter_list\"\n   */\n  icon?: string;\n  /**\n   * Custom header text\n   *\n   * Defaults to \"Filter\"\n   */\n  header?: string;\n  /**\n   * Custom filter component to initialize.\n   */\n  customFilterComponentClass?: Type<FilterSource<F>>;\n  /**\n   * Preset filter component to initialize.\n   */\n  presetFilterComponentClass?: Type<PresetFilterSource<F, P>>;\n  /**\n   * The connector to use.\n   */\n  connector: FilterSourceConnector<F>;\n  /**\n   * (Optional) Inital filter to pass to the filter source.\n   */\n  initialFilterObs?: Observable<F>;\n  /**\n   * (Optional) Whether or not to close the component if the filter changes.\n   *\n   * True by default.\n   */\n  closeOnFilterChange?: boolean;\n}\n\nexport interface DbxFilterPopoverComponentParams<F extends object = object> extends DbxFilterComponentParams<F> {\n  /**\n   * Origin to add the popover to.\n   */\n  origin: ElementRef;\n}\n\nexport const DEFAULT_FILTER_POPOVER_KEY = 'filter';\n\n@Component({\n  templateUrl: './filter.popover.component.html'\n})\nexport class DbxFilterPopoverComponent<F extends object> extends AbstractPopoverDirective<unknown, DbxFilterComponentParams<F>> implements OnInit, OnDestroy {\n  private _closeOnChangeSub = new SubscriptionObject();\n\n  /**\n   * Whether or not to display buttons to toggle between custom and preset filters.\n   */\n  readonly showSwitchButtons = Boolean(this.config.customFilterComponentClass && this.config.presetFilterComponentClass);\n\n  private _showPreset = new BehaviorSubject<boolean>(false);\n  readonly showPreset$ = this._showPreset.asObservable();\n\n  readonly config$: Observable<DbxInjectionComponentConfig<FilterSource<F>>> = this._showPreset.pipe(\n    map((showPreset) => {\n      const { closeOnFilterChange = true, connector, initialFilterObs, customFilterComponentClass, presetFilterComponentClass } = this.config;\n      let componentClass: Type<FilterSource<F>>;\n\n      if (showPreset) {\n        componentClass = presetFilterComponentClass as Type<FilterSource<F>>;\n      } else {\n        componentClass = customFilterComponentClass as Type<FilterSource<F>>;\n      }\n\n      const config: DbxInjectionComponentConfig<FilterSource<F>> = {\n        componentClass,\n        init: (filterSource) => {\n          connector.connectWithSource(filterSource);\n\n          if (initialFilterObs && filterSource.initWithFilter) {\n            filterSource.initWithFilter(initialFilterObs);\n          }\n\n          if (closeOnFilterChange !== false) {\n            this._closeOnChangeSub.subscription = filterSource.filter$.pipe(skip(1), filterMaybe(), first(), defaultIfEmpty(undefined)).subscribe(() => {\n              console.log();\n              this.close();\n            });\n          }\n        }\n      };\n\n      return config;\n    })\n  );\n\n  static openPopover<F extends object>(popupService: DbxPopoverService, { width, height, isResizable, origin, header, icon, customFilterComponentClass, presetFilterComponentClass, connector, initialFilterObs, closeOnFilterChange }: DbxFilterPopoverComponentParams<F>, popoverKey?: DbxPopoverKey): NgPopoverRef {\n    return popupService.open({\n      key: popoverKey ?? DEFAULT_FILTER_POPOVER_KEY,\n      origin,\n      componentClass: DbxFilterPopoverComponent,\n      width,\n      height,\n      isResizable,\n      data: {\n        header,\n        icon,\n        customFilterComponentClass,\n        presetFilterComponentClass,\n        connector,\n        initialFilterObs,\n        closeOnFilterChange\n      } as DbxFilterComponentParams<F>\n    });\n  }\n\n  constructor(popover: DbxPopoverComponent<unknown, DbxFilterComponentParams<F>>) {\n    super(popover);\n  }\n\n  get config(): DbxFilterComponentParams<F> {\n    return this.popover.data as DbxFilterComponentParams<F>;\n  }\n\n  get icon() {\n    return this.config.icon ?? 'filter_list';\n  }\n\n  get header() {\n    return this.config.header ?? 'Filter';\n  }\n\n  ngOnInit(): void {\n    let showPreset = false;\n    const { customFilterComponentClass, presetFilterComponentClass } = this.config;\n\n    if (customFilterComponentClass) {\n      showPreset = false;\n    }\n\n    if (presetFilterComponentClass) {\n      showPreset = true;\n    }\n\n    if (!customFilterComponentClass && !presetFilterComponentClass) {\n      throw new Error('Requires a preset or custom class provided for DbxFilterPopover.');\n    }\n\n    this._showPreset.next(showPreset);\n  }\n\n  ngOnDestroy(): void {\n    this._closeOnChangeSub.destroy();\n    this._showPreset.complete();\n  }\n\n  showPresets() {\n    this._showPreset.next(true);\n  }\n\n  showCustom() {\n    this._showPreset.next(false);\n  }\n}\n","<dbx-popover-content>\n  <!-- Header -->\n  <dbx-popover-header [icon]=\"icon\" [header]=\"header\">\n    <ng-container *ngIf=\"showSwitchButtons\" [ngSwitch]=\"showPreset$ | async\">\n      <button *ngSwitchCase=\"true\" mat-flat-button color=\"accent\" (click)=\"showCustom()\">Custom</button>\n      <button *ngSwitchCase=\"false\" mat-flat-button color=\"accent\" (click)=\"showPresets()\">Presets</button>\n    </ng-container>\n  </dbx-popover-header>\n  <!-- Content -->\n  <dbx-popover-scroll-content>\n    <dbx-injection [config]=\"config$ | async\"></dbx-injection>\n  </dbx-popover-scroll-content>\n</dbx-popover-content>\n"]}
|
|
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"]}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { shareReplay, BehaviorSubject, map, combineLatest, distinctUntilChanged, startWith } from 'rxjs';
|
|
2
2
|
import { Directive, Input } from '@angular/core';
|
|
3
|
-
import { FilterSourceDirective } from '@dereekb/dbx-core';
|
|
3
|
+
import { FilterSourceDirective, isClickableFilterPreset } from '@dereekb/dbx-core';
|
|
4
4
|
import { getValueFromGetter, objectHasNoKeys } from '@dereekb/util';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
import * as i1 from "@dereekb/dbx-core";
|
|
@@ -13,18 +13,41 @@ export class AbstractDbxPresetFilterMenuComponent {
|
|
|
13
13
|
//TODO: Rename to AbstractDbxPresetFilterMenuDirective with next breaking changes
|
|
14
14
|
this._presets = new BehaviorSubject([]);
|
|
15
15
|
this.selected$ = this.filterSourceDirective.filter$.pipe(startWith(undefined), distinctUntilChanged(), shareReplay(1));
|
|
16
|
+
this.presetsWithPresetStringOnly$ = this._presets.pipe(map((x) => x.filter((y) => Boolean(y.preset))));
|
|
16
17
|
this.selectedPresetString$ = this.selected$.pipe(map((selectedFilter) => (selectedFilter ? selectedFilter.preset : undefined)), distinctUntilChanged());
|
|
17
|
-
this.
|
|
18
|
-
return presets.map((x) =>
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
18
|
+
this.presetAnchorsPairs$ = combineLatest([this._presets, this.selected$, this.selectedPresetString$]).pipe(map(([presets, currentFilterValue, selectedPresetString]) => {
|
|
19
|
+
return presets.map((x) => {
|
|
20
|
+
let selected;
|
|
21
|
+
let type;
|
|
22
|
+
if (isClickableFilterPreset(x)) {
|
|
23
|
+
selected = x.preset === selectedPresetString;
|
|
24
|
+
type = 'preset';
|
|
23
25
|
}
|
|
24
|
-
|
|
26
|
+
else {
|
|
27
|
+
selected = x.isActive(currentFilterValue);
|
|
28
|
+
type = 'partialPreset';
|
|
29
|
+
}
|
|
30
|
+
return [
|
|
31
|
+
type,
|
|
32
|
+
x,
|
|
33
|
+
{
|
|
34
|
+
...x,
|
|
35
|
+
selected,
|
|
36
|
+
onClick: () => {
|
|
37
|
+
this.selectPreset(x);
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
];
|
|
41
|
+
});
|
|
42
|
+
}), shareReplay(1));
|
|
43
|
+
this.presetAnchors$ = this.presetAnchorsPairs$.pipe(map((x) => x.map((x) => x[2])), shareReplay(1));
|
|
44
|
+
this.firstSelectedAnchorPair$ = this.presetAnchorsPairs$.pipe(map((presets) => {
|
|
45
|
+
const firstSelected = presets.find((x) => x[2].selected);
|
|
46
|
+
return firstSelected ? firstSelected : undefined;
|
|
25
47
|
}), shareReplay(1));
|
|
26
|
-
this.selectedPreset$ =
|
|
27
|
-
|
|
48
|
+
this.selectedPreset$ = this.presetAnchorsPairs$.pipe(map((presets) => {
|
|
49
|
+
const firstSelected = presets.filter((x) => x[0] === 'preset').find((x) => x[2].selected);
|
|
50
|
+
return firstSelected ? firstSelected[1] : undefined;
|
|
28
51
|
}), shareReplay(1));
|
|
29
52
|
}
|
|
30
53
|
get presets() {
|
|
@@ -34,18 +57,19 @@ export class AbstractDbxPresetFilterMenuComponent {
|
|
|
34
57
|
this._presets.next(presets);
|
|
35
58
|
}
|
|
36
59
|
selectPreset(preset) {
|
|
37
|
-
const
|
|
60
|
+
const presetString = preset.preset;
|
|
61
|
+
const presetValue = preset.presetValue || preset.partialPresetValue;
|
|
38
62
|
if (presetValue == null || (typeof presetValue !== 'function' && objectHasNoKeys(presetValue))) {
|
|
39
63
|
// set and then reset if the value is null or empty
|
|
40
64
|
this.filterSourceDirective.setFilter((presetValue ?? {}));
|
|
41
65
|
this.filterSourceDirective.resetFilter();
|
|
42
66
|
}
|
|
43
67
|
else {
|
|
44
|
-
let filter = getValueFromGetter(
|
|
45
|
-
if (filter.preset !==
|
|
68
|
+
let filter = getValueFromGetter(presetValue);
|
|
69
|
+
if (filter.preset !== presetString) {
|
|
46
70
|
filter = {
|
|
47
71
|
...filter,
|
|
48
|
-
preset:
|
|
72
|
+
preset: presetString
|
|
49
73
|
};
|
|
50
74
|
}
|
|
51
75
|
this.filterSourceDirective.setFilter(filter);
|
|
@@ -62,4 +86,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
62
86
|
}], ctorParameters: function () { return [{ type: i1.FilterSourceDirective }]; }, propDecorators: { presets: [{
|
|
63
87
|
type: Input
|
|
64
88
|
}] } });
|
|
65
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLnByZXNldC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC13ZWIvc3JjL2xpYi9pbnRlcmFjdGlvbi9maWx0ZXIvZmlsdGVyLnByZXNldC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsV0FBVyxFQUFFLGVBQWUsRUFBRSxHQUFHLEVBQWMsYUFBYSxFQUFFLG9CQUFvQixFQUFFLFNBQVMsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUNySCxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBYSxNQUFNLGVBQWUsQ0FBQztBQUM1RCxPQUFPLEVBQThDLHFCQUFxQixFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDdEcsT0FBTyxFQUFFLGtCQUFrQixFQUFTLGVBQWUsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7O0FBRzNFOztHQUVHO0FBRUgsTUFBTSxPQUFnQixvQ0FBb0M7SUF5Q3hELFlBQXFCLHFCQUErQztRQUEvQywwQkFBcUIsR0FBckIscUJBQXFCLENBQTBCO1FBeENwRSxpRkFBaUY7UUFFekUsYUFBUSxHQUFHLElBQUksZUFBZSxDQUE2QixFQUFFLENBQUMsQ0FBQztRQUU5RCxjQUFTLEdBQXlCLElBQUksQ0FBQyxxQkFBcUIsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxTQUFTLENBQUMsRUFBRSxvQkFBb0IsRUFBRSxFQUFFLFdBQVcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBRXhJLDBCQUFxQixHQUE4QixJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FDN0UsR0FBRyxDQUFDLENBQUMsY0FBYyxFQUFFLEVBQUUsQ0FBQyxDQUFDLGNBQWMsQ0FBQyxDQUFDLENBQUMsY0FBYyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsU0FBUyxDQUFDLENBQUMsRUFDN0Usb0JBQW9CLEVBQUUsQ0FDdkIsQ0FBQztRQUVPLG1CQUFjLEdBQXNDLGFBQWEsQ0FBQyxDQUFDLElBQUksQ0FBQyxRQUFRLEVBQUUsSUFBSSxDQUFDLHFCQUFxQixDQUFDLENBQUMsQ0FBQyxJQUFJLENBQzFILEdBQUcsQ0FBQyxDQUFDLENBQUMsT0FBTyxFQUFFLG9CQUFvQixDQUFDLEVBQUUsRUFBRTtZQUN0QyxPQUFPLE9BQU8sQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUM7Z0JBQ3pCLEdBQUcsQ0FBQztnQkFDSixRQUFRLEVBQUUsQ0FBQyxDQUFDLE1BQU0sS0FBSyxvQkFBb0I7Z0JBQzNDLE9BQU8sRUFBRSxHQUFHLEVBQUU7b0JBQ1osSUFBSSxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUMsQ0FBQztnQkFDdkIsQ0FBQzthQUNGLENBQUMsQ0FBQyxDQUFDO1FBQ04sQ0FBQyxDQUFDLEVBQ0YsV0FBVyxDQUFDLENBQUMsQ0FBQyxDQUNmLENBQUM7UUFFTyxvQkFBZSxHQUFnRCxhQUFhLENBQUMsQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLElBQUksQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUNySSxHQUFHLENBQUMsQ0FBQyxDQUFDLE9BQU8sRUFBRSxvQkFBb0IsQ0FBQyxFQUFFLEVBQUU7WUFDdEMsT0FBTyxvQkFBb0IsSUFBSSxJQUFJLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxNQUFNLEtBQUssb0JBQW9CLENBQUMsQ0FBQyxDQUFDLENBQUMsU0FBUyxDQUFDO1FBQzNHLENBQUMsQ0FBQyxFQUNGLFdBQVcsQ0FBQyxDQUFDLENBQUMsQ0FDZixDQUFDO0lBV3FFLENBQUM7SUFUeEUsSUFDSSxPQUFPO1FBQ1QsT0FBTyxJQUFJLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQztJQUM3QixDQUFDO0lBRUQsSUFBSSxPQUFPLENBQUMsT0FBbUM7UUFDN0MsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDOUIsQ0FBQztJQUlELFlBQVksQ0FBQyxNQUFnQztRQUMzQyxNQUFNLFdBQVcsR0FBRyxNQUFNLENBQUMsV0FBVyxDQUFDO1FBRXZDLElBQUksV0FBVyxJQUFJLElBQUksSUFBSSxDQUFDLE9BQU8sV0FBVyxLQUFLLFVBQVUsSUFBSSxlQUFlLENBQUMsV0FBVyxDQUFDLENBQUMsRUFBRTtZQUM5RixtREFBbUQ7WUFDbkQsSUFBSSxDQUFDLHFCQUFxQixDQUFDLFNBQVMsQ0FBQyxDQUFDLFdBQVcsSUFBSSxFQUFFLENBQU0sQ0FBQyxDQUFDO1lBQy9ELElBQUksQ0FBQyxxQkFBcUIsQ0FBQyxXQUFXLEVBQUUsQ0FBQztTQUMxQzthQUFNO1lBQ0wsSUFBSSxNQUFNLEdBQUcsa0JBQWtCLENBQUMsTUFBTSxDQUFDLFdBQVcsQ0FBTSxDQUFDO1lBRXpELElBQUksTUFBTSxDQUFDLE1BQU0sS0FBSyxNQUFNLENBQUMsTUFBTSxFQUFFO2dCQUNuQyxNQUFNLEdBQUc7b0JBQ1AsR0FBRyxNQUFNO29CQUNULE1BQU0sRUFBRSxNQUFNLENBQUMsTUFBTTtpQkFDdEIsQ0FBQzthQUNIO1lBRUQsSUFBSSxDQUFDLHFCQUFxQixDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsQ0FBQztTQUM5QztJQUNILENBQUM7SUFFRCxXQUFXO1FBQ1QsSUFBSSxDQUFDLFFBQVEsQ0FBQyxRQUFRLEVBQUUsQ0FBQztJQUMzQixDQUFDOztrSUFsRW1CLG9DQUFvQztzSEFBcEMsb0NBQW9DOzRGQUFwQyxvQ0FBb0M7a0JBRHpELFNBQVM7NEdBa0NKLE9BQU87c0JBRFYsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHNoYXJlUmVwbGF5LCBCZWhhdmlvclN1YmplY3QsIG1hcCwgT2JzZXJ2YWJsZSwgY29tYmluZUxhdGVzdCwgZGlzdGluY3RVbnRpbENoYW5nZWQsIHN0YXJ0V2l0aCB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgRGlyZWN0aXZlLCBJbnB1dCwgT25EZXN0cm95IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDbGlja2FibGVGaWx0ZXJQcmVzZXQsIENsaWNrYWJsZUFuY2hvckxpbmssIEZpbHRlclNvdXJjZURpcmVjdGl2ZSB9IGZyb20gJ0BkZXJlZWtiL2RieC1jb3JlJztcbmltcG9ydCB7IGdldFZhbHVlRnJvbUdldHRlciwgTWF5YmUsIG9iamVjdEhhc05vS2V5cyB9IGZyb20gJ0BkZXJlZWtiL3V0aWwnO1xuaW1wb3J0IHsgRmlsdGVyV2l0aFByZXNldCB9IGZyb20gJ0BkZXJlZWtiL3J4anMnO1xuXG4vKipcbiAqIERpc3BsYXlzIGEgYnV0dG9uIGFuZCBtZW51IGZvciBmaWx0ZXJpbmcgcHJlc2V0cy5cbiAqL1xuQERpcmVjdGl2ZSgpXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgQWJzdHJhY3REYnhQcmVzZXRGaWx0ZXJNZW51Q29tcG9uZW50PEYgZXh0ZW5kcyBGaWx0ZXJXaXRoUHJlc2V0PiBpbXBsZW1lbnRzIE9uRGVzdHJveSB7XG4gIC8vVE9ETzogUmVuYW1lIHRvIEFic3RyYWN0RGJ4UHJlc2V0RmlsdGVyTWVudURpcmVjdGl2ZSB3aXRoIG5leHQgYnJlYWtpbmcgY2hhbmdlc1xuXG4gIHByaXZhdGUgX3ByZXNldHMgPSBuZXcgQmVoYXZpb3JTdWJqZWN0PENsaWNrYWJsZUZpbHRlclByZXNldDxGPltdPihbXSk7XG5cbiAgcmVhZG9ubHkgc2VsZWN0ZWQkOiBPYnNlcnZhYmxlPE1heWJlPEY+PiA9IHRoaXMuZmlsdGVyU291cmNlRGlyZWN0aXZlLmZpbHRlciQucGlwZShzdGFydFdpdGgodW5kZWZpbmVkKSwgZGlzdGluY3RVbnRpbENoYW5nZWQoKSwgc2hhcmVSZXBsYXkoMSkpO1xuXG4gIHJlYWRvbmx5IHNlbGVjdGVkUHJlc2V0U3RyaW5nJDogT2JzZXJ2YWJsZTxNYXliZTxzdHJpbmc+PiA9IHRoaXMuc2VsZWN0ZWQkLnBpcGUoXG4gICAgbWFwKChzZWxlY3RlZEZpbHRlcikgPT4gKHNlbGVjdGVkRmlsdGVyID8gc2VsZWN0ZWRGaWx0ZXIucHJlc2V0IDogdW5kZWZpbmVkKSksXG4gICAgZGlzdGluY3RVbnRpbENoYW5nZWQoKVxuICApO1xuXG4gIHJlYWRvbmx5IHByZXNldEFuY2hvcnMkOiBPYnNlcnZhYmxlPENsaWNrYWJsZUFuY2hvckxpbmtbXT4gPSBjb21iaW5lTGF0ZXN0KFt0aGlzLl9wcmVzZXRzLCB0aGlzLnNlbGVjdGVkUHJlc2V0U3RyaW5nJF0pLnBpcGUoXG4gICAgbWFwKChbcHJlc2V0cywgc2VsZWN0ZWRQcmVzZXRTdHJpbmddKSA9PiB7XG4gICAgICByZXR1cm4gcHJlc2V0cy5tYXAoKHgpID0+ICh7XG4gICAgICAgIC4uLngsXG4gICAgICAgIHNlbGVjdGVkOiB4LnByZXNldCA9PT0gc2VsZWN0ZWRQcmVzZXRTdHJpbmcsXG4gICAgICAgIG9uQ2xpY2s6ICgpID0+IHtcbiAgICAgICAgICB0aGlzLnNlbGVjdFByZXNldCh4KTtcbiAgICAgICAgfVxuICAgICAgfSkpO1xuICAgIH0pLFxuICAgIHNoYXJlUmVwbGF5KDEpXG4gICk7XG5cbiAgcmVhZG9ubHkgc2VsZWN0ZWRQcmVzZXQkOiBPYnNlcnZhYmxlPE1heWJlPENsaWNrYWJsZUZpbHRlclByZXNldDxGPj4+ID0gY29tYmluZUxhdGVzdChbdGhpcy5fcHJlc2V0cywgdGhpcy5zZWxlY3RlZFByZXNldFN0cmluZyRdKS5waXBlKFxuICAgIG1hcCgoW3ByZXNldHMsIHNlbGVjdGVkUHJlc2V0U3RyaW5nXSkgPT4ge1xuICAgICAgcmV0dXJuIHNlbGVjdGVkUHJlc2V0U3RyaW5nICE9IG51bGwgPyBwcmVzZXRzLmZpbmQoKHgpID0+IHgucHJlc2V0ID09PSBzZWxlY3RlZFByZXNldFN0cmluZykgOiB1bmRlZmluZWQ7XG4gICAgfSksXG4gICAgc2hhcmVSZXBsYXkoMSlcbiAgKTtcblxuICBASW5wdXQoKVxuICBnZXQgcHJlc2V0cygpOiBDbGlja2FibGVGaWx0ZXJQcmVzZXQ8Rj5bXSB7XG4gICAgcmV0dXJuIHRoaXMuX3ByZXNldHMudmFsdWU7XG4gIH1cblxuICBzZXQgcHJlc2V0cyhwcmVzZXRzOiBDbGlja2FibGVGaWx0ZXJQcmVzZXQ8Rj5bXSkge1xuICAgIHRoaXMuX3ByZXNldHMubmV4dChwcmVzZXRzKTtcbiAgfVxuXG4gIGNvbnN0cnVjdG9yKHJlYWRvbmx5IGZpbHRlclNvdXJjZURpcmVjdGl2ZTogRmlsdGVyU291cmNlRGlyZWN0aXZlPEY+KSB7fVxuXG4gIHNlbGVjdFByZXNldChwcmVzZXQ6IENsaWNrYWJsZUZpbHRlclByZXNldDxGPikge1xuICAgIGNvbnN0IHByZXNldFZhbHVlID0gcHJlc2V0LnByZXNldFZhbHVlO1xuXG4gICAgaWYgKHByZXNldFZhbHVlID09IG51bGwgfHwgKHR5cGVvZiBwcmVzZXRWYWx1ZSAhPT0gJ2Z1bmN0aW9uJyAmJiBvYmplY3RIYXNOb0tleXMocHJlc2V0VmFsdWUpKSkge1xuICAgICAgLy8gc2V0IGFuZCB0aGVuIHJlc2V0IGlmIHRoZSB2YWx1ZSBpcyBudWxsIG9yIGVtcHR5XG4gICAgICB0aGlzLmZpbHRlclNvdXJjZURpcmVjdGl2ZS5zZXRGaWx0ZXIoKHByZXNldFZhbHVlID8/IHt9KSBhcyBGKTtcbiAgICAgIHRoaXMuZmlsdGVyU291cmNlRGlyZWN0aXZlLnJlc2V0RmlsdGVyKCk7XG4gICAgfSBlbHNlIHtcbiAgICAgIGxldCBmaWx0ZXIgPSBnZXRWYWx1ZUZyb21HZXR0ZXIocHJlc2V0LnByZXNldFZhbHVlKSBhcyBGO1xuXG4gICAgICBpZiAoZmlsdGVyLnByZXNldCAhPT0gcHJlc2V0LnByZXNldCkge1xuICAgICAgICBmaWx0ZXIgPSB7XG4gICAgICAgICAgLi4uZmlsdGVyLFxuICAgICAgICAgIHByZXNldDogcHJlc2V0LnByZXNldFxuICAgICAgICB9O1xuICAgICAgfVxuXG4gICAgICB0aGlzLmZpbHRlclNvdXJjZURpcmVjdGl2ZS5zZXRGaWx0ZXIoZmlsdGVyKTtcbiAgICB9XG4gIH1cblxuICBuZ09uRGVzdHJveSgpOiB2b2lkIHtcbiAgICB0aGlzLl9wcmVzZXRzLmNvbXBsZXRlKCk7XG4gIH1cbn1cbiJdfQ==
|
|
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"]}
|
|
@@ -164,4 +164,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
164
164
|
}
|
|
165
165
|
}]
|
|
166
166
|
}], ctorParameters: function () { return [{ type: i1.NgPopoverRef }, { type: i2.CompactContextStore }, { type: i3.DbxRouterTransitionService }, { type: i0.NgZone }]; } });
|
|
167
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popover.component.js","sourceRoot":"","sources":["../../../../../../../packages/dbx-web/src/lib/interaction/popover/popover.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, NgZone, Type, OnInit, OnDestroy, ElementRef } from '@angular/core';\nimport { NgOverlayContainerConfiguration, NgPopoverCloseType, NgPopoverRef } from 'ng-overlay-container';\nimport { AbstractTransitionWatcherDirective, DbxRouterTransitionService, DbxInjectionComponentConfig } from '@dereekb/dbx-core';\nimport { Subject, filter, first, map, shareReplay, startWith } from 'rxjs';\nimport { PopoverPositionStrategy } from './popover.position.strategy';\nimport { Overlay } from '@angular/cdk/overlay';\nimport { LockSet } from '@dereekb/rxjs';\nimport { CompactContextStore, CompactMode } from '../../layout/compact';\nimport { ArrayOrValue, asPromise, Maybe, PromiseOrValue, SpaceSeparatedCssClasses } from '@dereekb/util';\nimport { DbxPopoverController, DbxPopoverKey } from './popover';\n\nexport abstract class DbxPopoverComponentController<O, I> extends DbxPopoverController<O, I> {\n  getClosingValueFn?: (value?: I) => Promise<O>;\n}\n\nexport interface DbxPopoverComponentConfig<O, I, T> {\n  /**\n   * Key used for uniquely identifying a limited instance.\n   *\n   * Only one popover should exist at a time given a certain key.\n   */\n  key: DbxPopoverKey;\n  /**\n   * Origin element to position on.\n   */\n  origin: ElementRef;\n  /**\n   * Whether or not to close if a transition occurs.\n   */\n  closeOnTransition?: boolean;\n  /**\n   * Whether or not to dismiss when the escape button is pressed.\n   *\n   * False by default.\n   */\n  closeOnEscape?: boolean;\n  /**\n   * Component to inject into the popover.\n   */\n  componentClass: Type<T>;\n  /**\n   * Panel classes to add to the popover.\n   */\n  panelClass?: Maybe<SpaceSeparatedCssClasses>;\n  /**\n   * Data available to the popover.\n   */\n  data?: Maybe<I>;\n  init?: (component: T, controller: DbxPopoverController<O, I>) => void;\n}\n\nexport interface FullDbxPopoverComponentConfig<O, I, T> extends DbxPopoverComponentConfig<O, I, T> {\n  configuration: NgOverlayContainerConfiguration;\n}\n\n/**\n * Popover component.\n */\n@Component({\n  template: `\n    <dbx-popover-coordinator (dbxWindowKeyDownListener)=\"handleKeydown()\" [appWindowKeyDownFilter]=\"triggerCloseKeys\">\n      <div dbxStyle class=\"dbx-popover-component\" dbx-injection [config]=\"contentConfig\"></div>\n    </dbx-popover-coordinator>\n  `,\n  providers: [\n    {\n      provide: DbxPopoverController,\n      useExisting: DbxPopoverComponent\n    },\n    {\n      provide: CompactContextStore\n    }\n  ],\n  host: {\n    '[class]': 'config.panelClass'\n  }\n})\nexport class DbxPopoverComponent<O = unknown, I = unknown, T = unknown> extends AbstractTransitionWatcherDirective implements DbxPopoverController<O, I>, OnInit, OnDestroy {\n  readonly lockSet = new LockSet();\n\n  readonly contentConfig: DbxInjectionComponentConfig = {\n    componentClass: this.config.componentClass,\n    init: this.config.init ? (instance) => (this.config as Required<FullDbxPopoverComponentConfig<O, I, T>>).init(instance as T, this) : undefined\n  };\n\n  private _startedClosing = false;\n  private readonly _closing = new Subject<void>();\n\n  private _triggerCloseKeys: string[] = [];\n\n  readonly isClosing$ = this._closing.pipe(\n    first(),\n    map(() => true),\n    startWith(false),\n    shareReplay(1)\n  );\n  readonly closing$ = this.isClosing$.pipe(filter((x) => x));\n\n  getClosingValueFn?: (value: Maybe<I>, closeType: NgPopoverCloseType) => PromiseOrValue<O | undefined>;\n\n  constructor(private popoverRef: NgPopoverRef<FullDbxPopoverComponentConfig<O, I, T>, O>, private compactContextState: CompactContextStore, dbxRouterTransitionService: DbxRouterTransitionService, ngZone: NgZone) {\n    super(dbxRouterTransitionService, ngZone);\n\n    // Override Close to properly signal to listeners when a close is occuring.\n    const originalClose = this.popoverRef.close;\n    this.popoverRef.close = (x) => {\n      if (!this._startedClosing) {\n        this.lockSet.lockForSeconds(1);\n        this._startedClosing = true;\n        this.close();\n        originalClose.call(this.popoverRef, x);\n      }\n    };\n\n    // Also intercept the _close function to capture backdropClose, etc.\n    const original_close = (this.popoverRef as any)._close;\n    (this.popoverRef as any)._close = (closeType: NgPopoverCloseType, inputValue: O | undefined) => {\n      const closeWithValue = (value?: O | undefined) => {\n        original_close.call(this.popoverRef, closeType, value);\n      };\n\n      if (closeType === 'close' || inputValue != null) {\n        closeWithValue(inputValue);\n      } else {\n        // expected to be a backdrop close. Get the closing value then close.\n        this._useClosingValue(closeType, (x) => closeWithValue(x));\n      }\n    };\n\n    // eslint-disable-next-line\n    const overlay = (popoverRef as any)._overlay as Overlay; // overlay is not publically accessible\n    const elementRef = this.config.origin;\n    const configuration = this.config.configuration;\n\n    this.compactContextState.setMode(CompactMode.COMPACT);\n    const position = PopoverPositionStrategy.make(overlay, elementRef, configuration);\n    this.popoverRef.overlay.updatePositionStrategy(position);\n  }\n\n  get config(): FullDbxPopoverComponentConfig<O, I, T> {\n    return this.popoverRef.data;\n  }\n\n  get panelClass(): Maybe<SpaceSeparatedCssClasses> {\n    return this.config.panelClass;\n  }\n\n  get key(): DbxPopoverKey {\n    return this.config.key;\n  }\n\n  get data(): Maybe<I> {\n    return this.config.data;\n  }\n\n  get triggerCloseKeys(): string[] {\n    return this._triggerCloseKeys;\n  }\n\n  override ngOnInit(): void {\n    super.ngOnInit();\n\n    if (this.config.closeOnEscape) {\n      this._triggerCloseKeys = ['Escape'];\n    }\n  }\n\n  override ngOnDestroy(): void {\n    this.lockSet.destroyOnNextUnlock(() => {\n      super.ngOnDestroy();\n      this._closing.complete();\n    });\n  }\n\n  protected updateForSuccessfulTransition(): void {\n    if (this.config.closeOnTransition !== false) {\n      this.close();\n    }\n  }\n\n  // Popover Controls\n  public close(): void {\n    if (!this._startedClosing && this.getClosingValueFn != null) {\n      this._useClosingValue('close', (x) => this.return(x));\n    } else {\n      this.return();\n    }\n  }\n\n  public return(value?: O | undefined): void {\n    this._closing.next();\n    this.popoverRef.close(value);\n  }\n\n  private _useClosingValue(closeType: NgPopoverCloseType, useValue: (value?: O | undefined) => void) {\n    if (this.getClosingValueFn != null) {\n      asPromise(this.getClosingValueFn(this.data, closeType)).then(\n        (x) => {\n          useValue(x);\n        },\n        () => {\n          useValue();\n        }\n      );\n    } else {\n      useValue();\n    }\n  }\n\n  // Keypresses\n  handleKeydown() {\n    this.close();\n  }\n}\n"]}
|
|
167
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popover.component.js","sourceRoot":"","sources":["../../../../../../../packages/dbx-web/src/lib/interaction/popover/popover.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, NgZone, Type, OnInit, OnDestroy, ElementRef } from '@angular/core';\nimport { NgOverlayContainerConfiguration, NgPopoverCloseType, NgPopoverRef } from 'ng-overlay-container';\nimport { AbstractTransitionWatcherDirective, DbxRouterTransitionService, DbxInjectionComponentConfig } from '@dereekb/dbx-core';\nimport { Subject, filter, first, map, shareReplay, startWith } from 'rxjs';\nimport { PopoverPositionStrategy } from './popover.position.strategy';\nimport { Overlay } from '@angular/cdk/overlay';\nimport { LockSet } from '@dereekb/rxjs';\nimport { CompactContextStore, CompactMode } from '../../layout/compact';\nimport { asPromise, Maybe, PromiseOrValue, SpaceSeparatedCssClasses } from '@dereekb/util';\nimport { DbxPopoverController, DbxPopoverKey } from './popover';\n\nexport abstract class DbxPopoverComponentController<O, I> extends DbxPopoverController<O, I> {\n  getClosingValueFn?: (value?: I) => Promise<O>;\n}\n\nexport interface DbxPopoverComponentConfig<O, I, T> {\n  /**\n   * Key used for uniquely identifying a limited instance.\n   *\n   * Only one popover should exist at a time given a certain key.\n   */\n  key: DbxPopoverKey;\n  /**\n   * Origin element to position on.\n   */\n  origin: ElementRef;\n  /**\n   * Whether or not to close if a transition occurs.\n   */\n  closeOnTransition?: boolean;\n  /**\n   * Whether or not to dismiss when the escape button is pressed.\n   *\n   * False by default.\n   */\n  closeOnEscape?: boolean;\n  /**\n   * Component to inject into the popover.\n   */\n  componentClass: Type<T>;\n  /**\n   * Panel classes to add to the popover.\n   */\n  panelClass?: Maybe<SpaceSeparatedCssClasses>;\n  /**\n   * Data available to the popover.\n   */\n  data?: Maybe<I>;\n  init?: (component: T, controller: DbxPopoverController<O, I>) => void;\n}\n\nexport interface FullDbxPopoverComponentConfig<O, I, T> extends DbxPopoverComponentConfig<O, I, T> {\n  configuration: NgOverlayContainerConfiguration;\n}\n\n/**\n * Popover component.\n */\n@Component({\n  template: `\n    <dbx-popover-coordinator (dbxWindowKeyDownListener)=\"handleKeydown()\" [appWindowKeyDownFilter]=\"triggerCloseKeys\">\n      <div dbxStyle class=\"dbx-popover-component\" dbx-injection [config]=\"contentConfig\"></div>\n    </dbx-popover-coordinator>\n  `,\n  providers: [\n    {\n      provide: DbxPopoverController,\n      useExisting: DbxPopoverComponent\n    },\n    {\n      provide: CompactContextStore\n    }\n  ],\n  host: {\n    '[class]': 'config.panelClass'\n  }\n})\nexport class DbxPopoverComponent<O = unknown, I = unknown, T = unknown> extends AbstractTransitionWatcherDirective implements DbxPopoverController<O, I>, OnInit, OnDestroy {\n  readonly lockSet = new LockSet();\n\n  readonly contentConfig: DbxInjectionComponentConfig = {\n    componentClass: this.config.componentClass,\n    init: this.config.init ? (instance) => (this.config as Required<FullDbxPopoverComponentConfig<O, I, T>>).init(instance as T, this) : undefined\n  };\n\n  private _startedClosing = false;\n  private readonly _closing = new Subject<void>();\n\n  private _triggerCloseKeys: string[] = [];\n\n  readonly isClosing$ = this._closing.pipe(\n    first(),\n    map(() => true),\n    startWith(false),\n    shareReplay(1)\n  );\n  readonly closing$ = this.isClosing$.pipe(filter((x) => x));\n\n  getClosingValueFn?: (value: Maybe<I>, closeType: NgPopoverCloseType) => PromiseOrValue<O | undefined>;\n\n  constructor(private popoverRef: NgPopoverRef<FullDbxPopoverComponentConfig<O, I, T>, O>, private compactContextState: CompactContextStore, dbxRouterTransitionService: DbxRouterTransitionService, ngZone: NgZone) {\n    super(dbxRouterTransitionService, ngZone);\n\n    // Override Close to properly signal to listeners when a close is occuring.\n    const originalClose = this.popoverRef.close;\n    this.popoverRef.close = (x) => {\n      if (!this._startedClosing) {\n        this.lockSet.lockForSeconds(1);\n        this._startedClosing = true;\n        this.close();\n        originalClose.call(this.popoverRef, x);\n      }\n    };\n\n    // Also intercept the _close function to capture backdropClose, etc.\n    const original_close = (this.popoverRef as any)._close;\n    (this.popoverRef as any)._close = (closeType: NgPopoverCloseType, inputValue: O | undefined) => {\n      const closeWithValue = (value?: O | undefined) => {\n        original_close.call(this.popoverRef, closeType, value);\n      };\n\n      if (closeType === 'close' || inputValue != null) {\n        closeWithValue(inputValue);\n      } else {\n        // expected to be a backdrop close. Get the closing value then close.\n        this._useClosingValue(closeType, (x) => closeWithValue(x));\n      }\n    };\n\n    // eslint-disable-next-line\n    const overlay = (popoverRef as any)._overlay as Overlay; // overlay is not publically accessible\n    const elementRef = this.config.origin;\n    const configuration = this.config.configuration;\n\n    this.compactContextState.setMode(CompactMode.COMPACT);\n    const position = PopoverPositionStrategy.make(overlay, elementRef, configuration);\n    this.popoverRef.overlay.updatePositionStrategy(position);\n  }\n\n  get config(): FullDbxPopoverComponentConfig<O, I, T> {\n    return this.popoverRef.data;\n  }\n\n  get panelClass(): Maybe<SpaceSeparatedCssClasses> {\n    return this.config.panelClass;\n  }\n\n  get key(): DbxPopoverKey {\n    return this.config.key;\n  }\n\n  get data(): Maybe<I> {\n    return this.config.data;\n  }\n\n  get triggerCloseKeys(): string[] {\n    return this._triggerCloseKeys;\n  }\n\n  override ngOnInit(): void {\n    super.ngOnInit();\n\n    if (this.config.closeOnEscape) {\n      this._triggerCloseKeys = ['Escape'];\n    }\n  }\n\n  override ngOnDestroy(): void {\n    this.lockSet.destroyOnNextUnlock(() => {\n      super.ngOnDestroy();\n      this._closing.complete();\n    });\n  }\n\n  protected updateForSuccessfulTransition(): void {\n    if (this.config.closeOnTransition !== false) {\n      this.close();\n    }\n  }\n\n  // Popover Controls\n  public close(): void {\n    if (!this._startedClosing && this.getClosingValueFn != null) {\n      this._useClosingValue('close', (x) => this.return(x));\n    } else {\n      this.return();\n    }\n  }\n\n  public return(value?: O | undefined): void {\n    this._closing.next();\n    this.popoverRef.close(value);\n  }\n\n  private _useClosingValue(closeType: NgPopoverCloseType, useValue: (value?: O | undefined) => void) {\n    if (this.getClosingValueFn != null) {\n      asPromise(this.getClosingValueFn(this.data, closeType)).then(\n        (x) => {\n          useValue(x);\n        },\n        () => {\n          useValue();\n        }\n      );\n    } else {\n      useValue();\n    }\n  }\n\n  // Keypresses\n  handleKeydown() {\n    this.close();\n  }\n}\n"]}
|
|
@@ -47,4 +47,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
47
47
|
providedIn: 'root'
|
|
48
48
|
}]
|
|
49
49
|
}], ctorParameters: function () { return [{ type: i1.Overlay }, { type: i0.Injector }]; } });
|
|
50
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
50
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9wb3Zlci5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LXdlYi9zcmMvbGliL2ludGVyYWN0aW9uL3BvcG92ZXIvcG9wb3Zlci5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxtQkFBbUIsRUFBNEQsTUFBTSxxQkFBcUIsQ0FBQztBQUNwSCxPQUFPLEVBQUUsVUFBVSxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNyRCxPQUFPLEVBQW1DLHlCQUF5QixFQUFnQixNQUFNLHNCQUFzQixDQUFDO0FBQ2hILE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQzs7O0FBUS9DOztHQUVHO0FBSUgsTUFBTSxPQUFPLGlCQUFpQjtJQUc1QixZQUFvQixRQUFpQixFQUFVLFNBQW1CO1FBQTlDLGFBQVEsR0FBUixRQUFRLENBQVM7UUFBVSxjQUFTLEdBQVQsU0FBUyxDQUFVO1FBQ2hFLElBQUksQ0FBQyx3QkFBd0IsR0FBRyxJQUFJLHlCQUF5QixDQUFDLElBQUksQ0FBQyxRQUFRLEVBQUUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDO0lBQy9GLENBQUM7SUFFRCxJQUFJLENBQVUsTUFBaUM7UUFDN0MsTUFBTSxPQUFPLEdBQUcsTUFBTSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsSUFBSSx5QkFBeUIsQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLHdCQUF3QixDQUFDO1FBRWhJLE1BQU0sYUFBYSxHQUFvQztZQUNyRCxVQUFVLEVBQUUsdUJBQXVCO1lBQ25DLE9BQU8sRUFBRSxNQUFNLENBQUMsT0FBTyxJQUFJLE9BQU87WUFDbEMsT0FBTyxFQUFFLE1BQU0sQ0FBQyxPQUFPLElBQUksS0FBSztZQUNoQyw2QkFBNkI7WUFDN0IsU0FBUyxFQUFFLE1BQU0sQ0FBQyxTQUFTO1lBQzNCLFFBQVEsRUFBRSxNQUFNLENBQUMsUUFBUTtZQUN6QixNQUFNLEVBQUUsTUFBTSxDQUFDLE1BQU0sSUFBSSxPQUFPO1lBQ2hDLEtBQUssRUFBRSxNQUFNLENBQUMsS0FBSyxJQUFJLE9BQU87WUFDOUIsV0FBVyxFQUFFLElBQUk7WUFDakIsV0FBVyxFQUFFLEtBQUs7WUFDbEIsV0FBVyxFQUFFLE1BQU0sQ0FBQyxXQUFXLElBQUksS0FBSztZQUN4QyxvQkFBb0IsRUFBRSxLQUFLO1NBQzVCLENBQUM7UUFFRixPQUFPLE9BQU8sQ0FBQyxJQUFJLENBQTRDO1lBQzdELE9BQU8sRUFBRSxtQkFBbUI7WUFDNUIsSUFBSSxFQUFFO2dCQUNKLEdBQUcsTUFBTTtnQkFDVCxhQUFhO2FBQ2Q7WUFDRCxhQUFhO1NBQ2QsQ0FBQyxDQUFDO0lBQ0wsQ0FBQzs7K0dBakNVLGlCQUFpQjttSEFBakIsaUJBQWlCLGNBRmhCLE1BQU07NEZBRVAsaUJBQWlCO2tCQUg3QixVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERieFBvcG92ZXJDb21wb25lbnQsIERieFBvcG92ZXJDb21wb25lbnRDb25maWcsIEZ1bGxEYnhQb3BvdmVyQ29tcG9uZW50Q29uZmlnIH0gZnJvbSAnLi9wb3BvdmVyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBJbmplY3RhYmxlLCBJbmplY3RvciB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTmdPdmVybGF5Q29udGFpbmVyQ29uZmlndXJhdGlvbiwgTmdPdmVybGF5Q29udGFpbmVyU2VydmljZSwgTmdQb3BvdmVyUmVmIH0gZnJvbSAnbmctb3ZlcmxheS1jb250YWluZXInO1xuaW1wb3J0IHsgT3ZlcmxheSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9vdmVybGF5JztcblxuZXhwb3J0IHR5cGUgRGJ4UG9wb3ZlckNvbmZpZ1NpemluZyA9IFBpY2s8TmdPdmVybGF5Q29udGFpbmVyQ29uZmlndXJhdGlvbiwgJ29yaWdpblgnIHwgJ29yaWdpblknIHwgJ2hlaWdodCcgfCAnd2lkdGgnIHwgJ21pbkhlaWdodCcgfCAnbWluV2lkdGgnIHwgJ2lzUmVzaXphYmxlJz47XG5cbmV4cG9ydCBpbnRlcmZhY2UgRGJ4UG9wb3ZlckNvbmZpZzxPLCBJLCBUPiBleHRlbmRzIERieFBvcG92ZXJDb21wb25lbnRDb25maWc8TywgSSwgVD4sIERieFBvcG92ZXJDb25maWdTaXppbmcge1xuICBpbmplY3Rvcj86IEluamVjdG9yO1xufVxuXG4vKipcbiAqIFVzZWQgZm9yIGRpc3BsYXlpbmcgYSBwb3BvdmVyLlxuICovXG5ASW5qZWN0YWJsZSh7XG4gIHByb3ZpZGVkSW46ICdyb290J1xufSlcbmV4cG9ydCBjbGFzcyBEYnhQb3BvdmVyU2VydmljZSB7XG4gIHByaXZhdGUgX292ZXJsYXlDb250YWluZXJTZXJ2aWNlOiBOZ092ZXJsYXlDb250YWluZXJTZXJ2aWNlO1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgX292ZXJsYXk6IE92ZXJsYXksIHByaXZhdGUgX2luamVjdG9yOiBJbmplY3Rvcikge1xuICAgIHRoaXMuX292ZXJsYXlDb250YWluZXJTZXJ2aWNlID0gbmV3IE5nT3ZlcmxheUNvbnRhaW5lclNlcnZpY2UodGhpcy5fb3ZlcmxheSwgdGhpcy5faW5qZWN0b3IpO1xuICB9XG5cbiAgb3BlbjxPLCBJLCBUPihjb25maWc6IERieFBvcG92ZXJDb25maWc8TywgSSwgVD4pOiBOZ1BvcG92ZXJSZWY8RGJ4UG9wb3ZlckNvbXBvbmVudENvbmZpZzxPLCBJLCBUPiwgTz4ge1xuICAgIGNvbnN0IHNlcnZpY2UgPSBjb25maWcuaW5qZWN0b3IgPyBuZXcgTmdPdmVybGF5Q29udGFpbmVyU2VydmljZSh0aGlzLl9vdmVybGF5LCBjb25maWcuaW5qZWN0b3IpIDogdGhpcy5fb3ZlcmxheUNvbnRhaW5lclNlcnZpY2U7XG5cbiAgICBjb25zdCBjb25maWd1cmF0aW9uOiBOZ092ZXJsYXlDb250YWluZXJDb25maWd1cmF0aW9uID0ge1xuICAgICAgcGFuZWxDbGFzczogJ2RieC1wb3BvdmVyLWNvbnRhaW5lcicsXG4gICAgICBvcmlnaW5YOiBjb25maWcub3JpZ2luWCA/PyAnc3RhcnQnLFxuICAgICAgb3JpZ2luWTogY29uZmlnLm9yaWdpblkgPz8gJ3RvcCcsXG4gICAgICAvLyBUT0RPOiBSZXNpemUgaGVpZ2h0L3dpZHRoLlxuICAgICAgbWluSGVpZ2h0OiBjb25maWcubWluSGVpZ2h0LFxuICAgICAgbWluV2lkdGg6IGNvbmZpZy5taW5XaWR0aCxcbiAgICAgIGhlaWdodDogY29uZmlnLmhlaWdodCA/PyAnNTAwcHgnLFxuICAgICAgd2lkdGg6IGNvbmZpZy53aWR0aCA/PyAnNDAwcHgnLFxuICAgICAgaGFzQmFja2Ryb3A6IHRydWUsXG4gICAgICBpc0RyYWdnYWJsZTogZmFsc2UsXG4gICAgICBpc1Jlc2l6YWJsZTogY29uZmlnLmlzUmVzaXphYmxlID8/IGZhbHNlLFxuICAgICAgZGlzYWJsZUJhY2tkcm9wQ2xvc2U6IGZhbHNlXG4gICAgfTtcblxuICAgIHJldHVybiBzZXJ2aWNlLm9wZW48RnVsbERieFBvcG92ZXJDb21wb25lbnRDb25maWc8TywgSSwgVD4sIE8+KHtcbiAgICAgIGNvbnRlbnQ6IERieFBvcG92ZXJDb21wb25lbnQsXG4gICAgICBkYXRhOiB7XG4gICAgICAgIC4uLmNvbmZpZyxcbiAgICAgICAgY29uZmlndXJhdGlvblxuICAgICAgfSxcbiAgICAgIGNvbmZpZ3VyYXRpb25cbiAgICB9KTtcbiAgfVxufVxuIl19
|
|
@@ -5,7 +5,7 @@ import { BehaviorSubject, map, combineLatest, distinctUntilChanged, shareReplay,
|
|
|
5
5
|
import * as i1$1 from '@angular/material/snack-bar';
|
|
6
6
|
import { MAT_SNACK_BAR_DATA, MatSnackBarModule } from '@angular/material/snack-bar';
|
|
7
7
|
import * as i1$2 from '@dereekb/dbx-core';
|
|
8
|
-
import { AbstractSubscriptionDirective, safeMarkForCheck, AbstractDbxButtonDirective, provideDbxButton, DbxCoreButtonModule, AbstractTransitionWatcherDirective, AbstractDbxActionValueOnTriggerDirective, safeDetectChanges, DbxInjectionComponentModule, AbstractDbxActionHandlerDirective, provideActionStoreSource, AbstractDbxAnchorDirective, expandClickableAnchorLinkTrees, AbstractTransitionDirective, tapDetectChanges, AbstractIfDirective, DbxCoreFilterModule, asSegueRef, isSegueRefActive, DBX_INJECTION_COMPONENT_DATA, checkNgContentWrapperHasContent, anchorTypeForAnchor, AnchorType, DbxCoreActionModule, isIdleActionState, canTriggerAction, onDbxAppAuth, SimpleStorageAccessorFactory } from '@dereekb/dbx-core';
|
|
8
|
+
import { AbstractSubscriptionDirective, safeMarkForCheck, AbstractDbxButtonDirective, provideDbxButton, DbxCoreButtonModule, AbstractTransitionWatcherDirective, AbstractDbxActionValueOnTriggerDirective, safeDetectChanges, DbxInjectionComponentModule, AbstractDbxActionHandlerDirective, provideActionStoreSource, isClickableFilterPreset, AbstractDbxAnchorDirective, expandClickableAnchorLinkTrees, AbstractTransitionDirective, tapDetectChanges, AbstractIfDirective, DbxCoreFilterModule, asSegueRef, isSegueRefActive, DBX_INJECTION_COMPONENT_DATA, checkNgContentWrapperHasContent, anchorTypeForAnchor, AnchorType, DbxCoreActionModule, isIdleActionState, canTriggerAction, onDbxAppAuth, SimpleStorageAccessorFactory } from '@dereekb/dbx-core';
|
|
9
9
|
import ms from 'ms';
|
|
10
10
|
import * as i1 from '@angular/common';
|
|
11
11
|
import { CommonModule } from '@angular/common';
|
|
@@ -2286,14 +2286,37 @@ class AbstractDbxPresetFilterMenuComponent {
|
|
|
2286
2286
|
//TODO: Rename to AbstractDbxPresetFilterMenuDirective with next breaking changes
|
|
2287
2287
|
this._presets = new BehaviorSubject([]);
|
|
2288
2288
|
this.selected$ = this.filterSourceDirective.filter$.pipe(startWith(undefined), distinctUntilChanged(), shareReplay(1));
|
|
2289
|
+
this.presetsWithPresetStringOnly$ = this._presets.pipe(map((x) => x.filter((y) => Boolean(y.preset))));
|
|
2289
2290
|
this.selectedPresetString$ = this.selected$.pipe(map((selectedFilter) => (selectedFilter ? selectedFilter.preset : undefined)), distinctUntilChanged());
|
|
2290
|
-
this.
|
|
2291
|
-
return presets.map((x) =>
|
|
2292
|
-
|
|
2293
|
-
|
|
2291
|
+
this.presetAnchorsPairs$ = combineLatest([this._presets, this.selected$, this.selectedPresetString$]).pipe(map(([presets, currentFilterValue, selectedPresetString]) => {
|
|
2292
|
+
return presets.map((x) => {
|
|
2293
|
+
let selected;
|
|
2294
|
+
let type;
|
|
2295
|
+
if (isClickableFilterPreset(x)) {
|
|
2296
|
+
selected = x.preset === selectedPresetString;
|
|
2297
|
+
type = 'preset';
|
|
2298
|
+
}
|
|
2299
|
+
else {
|
|
2300
|
+
selected = x.isActive(currentFilterValue);
|
|
2301
|
+
type = 'partialPreset';
|
|
2302
|
+
}
|
|
2303
|
+
return [
|
|
2304
|
+
type,
|
|
2305
|
+
x,
|
|
2306
|
+
Object.assign(Object.assign({}, x), { selected, onClick: () => {
|
|
2307
|
+
this.selectPreset(x);
|
|
2308
|
+
} })
|
|
2309
|
+
];
|
|
2310
|
+
});
|
|
2311
|
+
}), shareReplay(1));
|
|
2312
|
+
this.presetAnchors$ = this.presetAnchorsPairs$.pipe(map((x) => x.map((x) => x[2])), shareReplay(1));
|
|
2313
|
+
this.firstSelectedAnchorPair$ = this.presetAnchorsPairs$.pipe(map((presets) => {
|
|
2314
|
+
const firstSelected = presets.find((x) => x[2].selected);
|
|
2315
|
+
return firstSelected ? firstSelected : undefined;
|
|
2294
2316
|
}), shareReplay(1));
|
|
2295
|
-
this.selectedPreset$ =
|
|
2296
|
-
|
|
2317
|
+
this.selectedPreset$ = this.presetAnchorsPairs$.pipe(map((presets) => {
|
|
2318
|
+
const firstSelected = presets.filter((x) => x[0] === 'preset').find((x) => x[2].selected);
|
|
2319
|
+
return firstSelected ? firstSelected[1] : undefined;
|
|
2297
2320
|
}), shareReplay(1));
|
|
2298
2321
|
}
|
|
2299
2322
|
get presets() {
|
|
@@ -2303,16 +2326,17 @@ class AbstractDbxPresetFilterMenuComponent {
|
|
|
2303
2326
|
this._presets.next(presets);
|
|
2304
2327
|
}
|
|
2305
2328
|
selectPreset(preset) {
|
|
2306
|
-
const
|
|
2329
|
+
const presetString = preset.preset;
|
|
2330
|
+
const presetValue = preset.presetValue || preset.partialPresetValue;
|
|
2307
2331
|
if (presetValue == null || (typeof presetValue !== 'function' && objectHasNoKeys(presetValue))) {
|
|
2308
2332
|
// set and then reset if the value is null or empty
|
|
2309
2333
|
this.filterSourceDirective.setFilter((presetValue !== null && presetValue !== void 0 ? presetValue : {}));
|
|
2310
2334
|
this.filterSourceDirective.resetFilter();
|
|
2311
2335
|
}
|
|
2312
2336
|
else {
|
|
2313
|
-
let filter = getValueFromGetter(
|
|
2314
|
-
if (filter.preset !==
|
|
2315
|
-
filter = Object.assign(Object.assign({}, filter), { preset:
|
|
2337
|
+
let filter = getValueFromGetter(presetValue);
|
|
2338
|
+
if (filter.preset !== presetString) {
|
|
2339
|
+
filter = Object.assign(Object.assign({}, filter), { preset: presetString });
|
|
2316
2340
|
}
|
|
2317
2341
|
this.filterSourceDirective.setFilter(filter);
|
|
2318
2342
|
}
|