@dereekb/dbx-web 12.6.21 → 12.7.0

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.
Files changed (102) hide show
  1. package/esm2022/lib/action/snackbar/action.snackbar.component.mjs +10 -14
  2. package/esm2022/lib/action/snackbar/action.snackbar.directive.mjs +8 -7
  3. package/esm2022/lib/action/transition/transition.safety.dialog.component.mjs +1 -1
  4. package/esm2022/lib/button/progress/abstract.progress.button.directive.mjs +5 -5
  5. package/esm2022/lib/error/error.action.directive.mjs +9 -9
  6. package/esm2022/lib/error/error.loading.directive.mjs +7 -6
  7. package/esm2022/lib/error/error.snackbar.action.directive.mjs +6 -7
  8. package/esm2022/lib/error/error.snackbar.component.mjs +9 -13
  9. package/esm2022/lib/extension/download/blob/download.blob.button.component.mjs +6 -10
  10. package/esm2022/lib/extension/download/text/download.text.component.mjs +1 -6
  11. package/esm2022/lib/extension/help/help.context.service.mjs +3 -5
  12. package/esm2022/lib/extension/model/model.tracker.view.storage.mjs +3 -5
  13. package/esm2022/lib/extension/zip/zip.blob.preview.component.mjs +4 -7
  14. package/esm2022/lib/extension/zip/zip.preview.component.mjs +4 -7
  15. package/esm2022/lib/interaction/dialog/dialog.action.directive.mjs +1 -1
  16. package/esm2022/lib/interaction/filter/filter.popover.component.mjs +9 -12
  17. package/esm2022/lib/interaction/filter/filter.wrapper.component.mjs +3 -2
  18. package/esm2022/lib/interaction/iframe/embed.component.mjs +7 -12
  19. package/esm2022/lib/interaction/iframe/iframe.component.mjs +7 -12
  20. package/esm2022/lib/interaction/popover/abstract.popover.ref.directive.mjs +8 -7
  21. package/esm2022/lib/interaction/popover/popover.action.directive.mjs +1 -1
  22. package/esm2022/lib/interaction/popover/popover.component.mjs +1 -3
  23. package/esm2022/lib/interaction/popover/popover.coordinator.component.mjs +5 -6
  24. package/esm2022/lib/interaction/popover/popover.coordinator.service.mjs +3 -5
  25. package/esm2022/lib/interaction/popup/popup.component.mjs +4 -9
  26. package/esm2022/lib/interaction/popup/popup.coordinator.component.mjs +5 -6
  27. package/esm2022/lib/interaction/popup/popup.coordinator.service.mjs +3 -5
  28. package/esm2022/lib/interaction/prompt/prompt.confirm.dialog.component.mjs +1 -1
  29. package/esm2022/lib/interaction/upload/upload.action.directive.mjs +8 -15
  30. package/esm2022/lib/layout/column/two/two.column.back.directive.mjs +8 -8
  31. package/esm2022/lib/layout/column/two/two.column.component.mjs +4 -5
  32. package/esm2022/lib/layout/column/two/two.column.sref.showright.directive.mjs +5 -6
  33. package/esm2022/lib/layout/column/two/two.column.store.mjs +3 -7
  34. package/esm2022/lib/layout/flex/flex.group.directive.mjs +4 -5
  35. package/esm2022/lib/layout/list/list.view.directive.mjs +16 -21
  36. package/esm2022/lib/layout/list/modifier/list.view.value.modifier.directive.mjs +11 -15
  37. package/esm2022/lib/layout/list/modifier/list.view.value.modifier.ripple.directive.mjs +1 -1
  38. package/esm2022/lib/layout/list/modifier/list.view.value.modifier.selection.directive.mjs +1 -1
  39. package/esm2022/lib/layout/style/style.body.directive.mjs +9 -9
  40. package/esm2022/lib/layout/style/style.directive.mjs +9 -9
  41. package/esm2022/lib/layout/style/style.set.directive.mjs +10 -10
  42. package/esm2022/lib/loading/loading.action.directive.mjs +3 -7
  43. package/esm2022/mapbox/lib/mapbox.injection.store.mjs +1 -1
  44. package/esm2022/mapbox/lib/mapbox.layout.resize.sync.directive.mjs +8 -8
  45. package/esm2022/mapbox/lib/mapbox.menu.component.mjs +17 -19
  46. package/esm2022/mapbox/lib/mapbox.store.mjs +1 -1
  47. package/esm2022/table/lib/date/daterange.table.cell.input.component.mjs +8 -11
  48. package/esm2022/table/lib/table.column.size.directive.mjs +8 -9
  49. package/fesm2022/dereekb-dbx-web-mapbox.mjs +22 -24
  50. package/fesm2022/dereekb-dbx-web-mapbox.mjs.map +1 -1
  51. package/fesm2022/dereekb-dbx-web-table.mjs +13 -19
  52. package/fesm2022/dereekb-dbx-web-table.mjs.map +1 -1
  53. package/fesm2022/dereekb-dbx-web.mjs +150 -229
  54. package/fesm2022/dereekb-dbx-web.mjs.map +1 -1
  55. package/lib/action/snackbar/action.snackbar.component.d.ts +4 -5
  56. package/lib/action/snackbar/action.snackbar.directive.d.ts +3 -2
  57. package/lib/action/transition/transition.safety.dialog.component.d.ts +1 -2
  58. package/lib/button/progress/abstract.progress.button.directive.d.ts +3 -3
  59. package/lib/error/error.action.directive.d.ts +3 -4
  60. package/lib/error/error.loading.directive.d.ts +2 -2
  61. package/lib/error/error.snackbar.action.directive.d.ts +2 -2
  62. package/lib/error/error.snackbar.component.d.ts +2 -4
  63. package/lib/extension/download/blob/download.blob.button.component.d.ts +3 -4
  64. package/lib/extension/download/text/download.text.component.d.ts +2 -4
  65. package/lib/extension/help/help.context.service.d.ts +1 -3
  66. package/lib/extension/model/model.tracker.view.storage.d.ts +2 -3
  67. package/lib/extension/zip/zip.blob.preview.component.d.ts +2 -3
  68. package/lib/extension/zip/zip.preview.component.d.ts +1 -3
  69. package/lib/interaction/dialog/dialog.action.directive.d.ts +2 -2
  70. package/lib/interaction/filter/filter.popover.component.d.ts +3 -5
  71. package/lib/interaction/filter/filter.wrapper.component.d.ts +1 -1
  72. package/lib/interaction/iframe/embed.component.d.ts +2 -4
  73. package/lib/interaction/iframe/iframe.component.d.ts +2 -4
  74. package/lib/interaction/popover/abstract.popover.ref.directive.d.ts +4 -4
  75. package/lib/interaction/popover/popover.action.directive.d.ts +2 -2
  76. package/lib/interaction/popover/popover.coordinator.component.d.ts +2 -4
  77. package/lib/interaction/popover/popover.coordinator.service.d.ts +2 -4
  78. package/lib/interaction/popup/popup.component.d.ts +2 -3
  79. package/lib/interaction/popup/popup.coordinator.component.d.ts +2 -4
  80. package/lib/interaction/popup/popup.coordinator.service.d.ts +1 -3
  81. package/lib/interaction/prompt/prompt.confirm.dialog.component.d.ts +1 -2
  82. package/lib/interaction/upload/upload.action.directive.d.ts +2 -6
  83. package/lib/layout/column/two/two.column.back.directive.d.ts +2 -4
  84. package/lib/layout/column/two/two.column.component.d.ts +1 -3
  85. package/lib/layout/column/two/two.column.sref.showright.directive.d.ts +1 -2
  86. package/lib/layout/column/two/two.column.store.d.ts +2 -3
  87. package/lib/layout/flex/flex.group.directive.d.ts +1 -2
  88. package/lib/layout/list/list.view.directive.d.ts +9 -10
  89. package/lib/layout/list/modifier/list.view.value.modifier.directive.d.ts +3 -6
  90. package/lib/layout/list/modifier/list.view.value.modifier.ripple.directive.d.ts +1 -2
  91. package/lib/layout/list/modifier/list.view.value.modifier.selection.directive.d.ts +1 -2
  92. package/lib/layout/style/style.body.directive.d.ts +2 -4
  93. package/lib/layout/style/style.directive.d.ts +2 -4
  94. package/lib/layout/style/style.set.directive.d.ts +2 -4
  95. package/lib/loading/loading.action.directive.d.ts +1 -3
  96. package/mapbox/lib/mapbox.injection.store.d.ts +1 -2
  97. package/mapbox/lib/mapbox.layout.resize.sync.directive.d.ts +2 -4
  98. package/mapbox/lib/mapbox.menu.component.d.ts +5 -6
  99. package/mapbox/lib/mapbox.store.d.ts +1 -2
  100. package/package.json +1 -1
  101. package/table/lib/date/daterange.table.cell.input.component.d.ts +2 -4
  102. package/table/lib/table.column.size.directive.d.ts +4 -5
@@ -1,8 +1,8 @@
1
- import { DbxInjectionComponent } from '@dereekb/dbx-core';
1
+ import { cleanSubscription, DbxInjectionComponent } from '@dereekb/dbx-core';
2
2
  import { Component, signal, ChangeDetectionStrategy } from '@angular/core';
3
3
  import { map, skip, first, defaultIfEmpty } from 'rxjs';
4
4
  import { AbstractPopoverDirective } from '../popover/abstract.popover.directive';
5
- import { filterMaybe, SubscriptionObject } from '@dereekb/rxjs';
5
+ import { filterMaybe } from '@dereekb/rxjs';
6
6
  import { toObservable, toSignal } from '@angular/core/rxjs-interop';
7
7
  import { DbxPopoverInteractionModule } from '../popover';
8
8
  import { MatButtonModule } from '@angular/material/button';
@@ -14,7 +14,6 @@ import * as i3 from "../popover/popover.scroll.content.directive";
14
14
  import * as i4 from "@angular/material/button";
15
15
  export const DEFAULT_FILTER_POPOVER_KEY = 'filter';
16
16
  export class DbxFilterPopoverComponent extends AbstractPopoverDirective {
17
- _closeOnChangeSub = new SubscriptionObject();
18
17
  config = this.popover.data;
19
18
  icon = this.config.icon ?? 'filter_list';
20
19
  header = this.config.header ?? 'Filter';
@@ -47,9 +46,9 @@ export class DbxFilterPopoverComponent extends AbstractPopoverDirective {
47
46
  filterSource.initWithFilter(initialFilterObs);
48
47
  }
49
48
  if (closeOnFilterChange !== false) {
50
- this._closeOnChangeSub.subscription = filterSource.filter$.pipe(skip(1), filterMaybe(), first(), defaultIfEmpty(undefined)).subscribe(() => {
49
+ cleanSubscription(filterSource.filter$.pipe(skip(1), filterMaybe(), first(), defaultIfEmpty(undefined)).subscribe(() => {
51
50
  this.close();
52
- });
51
+ }));
53
52
  }
54
53
  // run the next init if provided
55
54
  baseConfig?.init?.(filterSource);
@@ -82,7 +81,8 @@ export class DbxFilterPopoverComponent extends AbstractPopoverDirective {
82
81
  }
83
82
  });
84
83
  }
85
- ngOnInit() {
84
+ constructor() {
85
+ super();
86
86
  let showPreset = false;
87
87
  const { customFilterComponentClass, presetFilterComponentClass, customFilterComponentConfig, presetFilterComponentConfig } = this.config;
88
88
  if (customFilterComponentClass || customFilterComponentConfig) {
@@ -96,20 +96,17 @@ export class DbxFilterPopoverComponent extends AbstractPopoverDirective {
96
96
  }
97
97
  this.showPresetSignal.set(showPreset);
98
98
  }
99
- ngOnDestroy() {
100
- this._closeOnChangeSub.destroy();
101
- }
102
99
  showPresets() {
103
100
  this.showPresetSignal.set(true);
104
101
  }
105
102
  showCustom() {
106
103
  this.showPresetSignal.set(false);
107
104
  }
108
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxFilterPopoverComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
105
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxFilterPopoverComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
109
106
  static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: DbxFilterPopoverComponent, isStandalone: true, selector: "ng-component", usesInheritance: true, ngImport: i0, template: "<dbx-popover-content>\n <!-- Header -->\n <dbx-popover-header [icon]=\"icon\" [header]=\"header\">\n @if (showSwitchButtons) {\n @switch (showPresetSignal()) {\n @case (true) {\n <button mat-flat-button color=\"accent\" (click)=\"showCustom()\">{{ customizeButtonText }}</button>\n }\n @case (false) {\n <button mat-flat-button color=\"accent\" (click)=\"showPresets()\">Presets</button>\n }\n }\n }\n @if (showCloseButton) {\n @if (showSwitchButtons) {\n <dbx-button-spacer></dbx-button-spacer>\n }\n <button mat-stroked-button color=\"accent\" (click)=\"close()\">{{ closeButtonText }}</button>\n }\n </dbx-popover-header>\n <!-- Content -->\n <dbx-popover-scroll-content>\n <dbx-injection [config]=\"configSignal()\"></dbx-injection>\n </dbx-popover-scroll-content>\n</dbx-popover-content>\n", dependencies: [{ kind: "ngmodule", type: DbxPopoverInteractionModule }, { kind: "component", type: i1.DbxPopoverContentComponent, selector: "dbx-popover-content" }, { kind: "component", type: i2.DbxPopoverHeaderComponent, selector: "dbx-popover-header", inputs: ["header", "icon"] }, { kind: "directive", type: i3.DbxPopoverScrollContentDirective, selector: "dbx-popover-scroll-content,[dbxPopoverScrollContent],.dbx-popover-scroll-content" }, { kind: "component", type: DbxInjectionComponent, selector: "dbx-injection, [dbxInjection], [dbx-injection]", inputs: ["config", "template"] }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i4.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "directive", type: DbxButtonSpacerDirective, selector: "dbx-button-spacer,[dbxButtonSpacer]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
110
107
  }
111
108
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxFilterPopoverComponent, decorators: [{
112
109
  type: Component,
113
110
  args: [{ imports: [DbxPopoverInteractionModule, DbxInjectionComponent, MatButtonModule, DbxButtonSpacerDirective], changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, template: "<dbx-popover-content>\n <!-- Header -->\n <dbx-popover-header [icon]=\"icon\" [header]=\"header\">\n @if (showSwitchButtons) {\n @switch (showPresetSignal()) {\n @case (true) {\n <button mat-flat-button color=\"accent\" (click)=\"showCustom()\">{{ customizeButtonText }}</button>\n }\n @case (false) {\n <button mat-flat-button color=\"accent\" (click)=\"showPresets()\">Presets</button>\n }\n }\n }\n @if (showCloseButton) {\n @if (showSwitchButtons) {\n <dbx-button-spacer></dbx-button-spacer>\n }\n <button mat-stroked-button color=\"accent\" (click)=\"close()\">{{ closeButtonText }}</button>\n }\n </dbx-popover-header>\n <!-- Content -->\n <dbx-popover-scroll-content>\n <dbx-injection [config]=\"configSignal()\"></dbx-injection>\n </dbx-popover-scroll-content>\n</dbx-popover-content>\n" }]
114
- }] });
115
- //# 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 { DbxInjectionComponent, DbxInjectionComponentConfig } from '@dereekb/dbx-core';\nimport { Component, ElementRef, Type, OnInit, OnDestroy, signal, ChangeDetectionStrategy } from '@angular/core';\nimport { NgPopoverRef } from 'ng-overlay-container';\nimport { Observable, map, skip, first, defaultIfEmpty } from 'rxjs';\nimport { AbstractPopoverDirective } from '../popover/abstract.popover.directive';\nimport { DbxPopoverService } from '../popover/popover.service';\nimport { FilterSource, filterMaybe, SubscriptionObject } from '@dereekb/rxjs';\nimport { DbxPopoverKey } from '../popover/popover';\nimport { type Maybe } from '@dereekb/util';\nimport { toObservable, toSignal } from '@angular/core/rxjs-interop';\nimport { DbxFilterComponentConfig } from './filter.config';\nimport { DbxPopoverInteractionModule } from '../popover';\nimport { MatButtonModule } from '@angular/material/button';\nimport { DbxButtonSpacerDirective } from '../../button/button.spacer.directive';\n\nexport interface DbxFilterPopoverComponentConfig<F extends object = object> extends DbxFilterComponentConfig<F> {\n  /**\n   * Origin to add the popover to.\n   */\n  readonly origin: ElementRef;\n}\n\nexport const DEFAULT_FILTER_POPOVER_KEY = 'filter';\n\n@Component({\n  templateUrl: './filter.popover.component.html',\n  imports: [DbxPopoverInteractionModule, DbxInjectionComponent, MatButtonModule, DbxButtonSpacerDirective],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true\n})\nexport class DbxFilterPopoverComponent<F extends object> extends AbstractPopoverDirective<unknown, DbxFilterComponentConfig<F>> implements OnInit, OnDestroy {\n  private readonly _closeOnChangeSub = new SubscriptionObject();\n\n  readonly config: DbxFilterComponentConfig<F> = this.popover.data as DbxFilterComponentConfig<F>;\n\n  readonly icon = this.config.icon ?? 'filter_list';\n  readonly header = this.config.header ?? 'Filter';\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  readonly showPresetSignal = signal<boolean>(false);\n\n  readonly config$: Observable<DbxInjectionComponentConfig<FilterSource<F>>> = toObservable(this.showPresetSignal).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  readonly configSignal = toSignal(this.config$);\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 }: DbxFilterPopoverComponentConfig<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 DbxFilterComponentConfig<F>\n    });\n  }\n\n  ngOnInit(): void {\n    let showPreset: boolean = false;\n\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.showPresetSignal.set(showPreset);\n  }\n\n  ngOnDestroy(): void {\n    this._closeOnChangeSub.destroy();\n  }\n\n  showPresets() {\n    this.showPresetSignal.set(true);\n  }\n\n  showCustom() {\n    this.showPresetSignal.set(false);\n  }\n}\n","<dbx-popover-content>\n  <!-- Header -->\n  <dbx-popover-header [icon]=\"icon\" [header]=\"header\">\n    @if (showSwitchButtons) {\n      @switch (showPresetSignal()) {\n        @case (true) {\n          <button mat-flat-button color=\"accent\" (click)=\"showCustom()\">{{ customizeButtonText }}</button>\n        }\n        @case (false) {\n          <button mat-flat-button color=\"accent\" (click)=\"showPresets()\">Presets</button>\n        }\n      }\n    }\n    @if (showCloseButton) {\n      @if (showSwitchButtons) {\n        <dbx-button-spacer></dbx-button-spacer>\n      }\n      <button mat-stroked-button color=\"accent\" (click)=\"close()\">{{ closeButtonText }}</button>\n    }\n  </dbx-popover-header>\n  <!-- Content -->\n  <dbx-popover-scroll-content>\n    <dbx-injection [config]=\"configSignal()\"></dbx-injection>\n  </dbx-popover-scroll-content>\n</dbx-popover-content>\n"]}
111
+ }], ctorParameters: () => [] });
112
+ //# 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":"AAAA,OAAO,EAAE,iBAAiB,EAAE,qBAAqB,EAA+B,MAAM,mBAAmB,CAAC;AAC1G,OAAO,EAAE,SAAS,EAAoB,MAAM,EAAE,uBAAuB,EAAE,MAAM,eAAe,CAAC;AAE7F,OAAO,EAAc,GAAG,EAAE,IAAI,EAAE,KAAK,EAAE,cAAc,EAAE,MAAM,MAAM,CAAC;AACpE,OAAO,EAAE,wBAAwB,EAAE,MAAM,uCAAuC,CAAC;AAEjF,OAAO,EAAgB,WAAW,EAAE,MAAM,eAAe,CAAC;AAG1D,OAAO,EAAE,YAAY,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAC;AAEpE,OAAO,EAAE,2BAA2B,EAAE,MAAM,YAAY,CAAC;AACzD,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAC3D,OAAO,EAAE,wBAAwB,EAAE,MAAM,sCAAsC,CAAC;;;;;;AAShF,MAAM,CAAC,MAAM,0BAA0B,GAAG,QAAQ,CAAC;AAQnD,MAAM,OAAO,yBAA4C,SAAQ,wBAA8D;IACpH,MAAM,GAAgC,IAAI,CAAC,OAAO,CAAC,IAAmC,CAAC;IAEvF,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,IAAI,aAAa,CAAC;IACzC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,IAAI,QAAQ,CAAC;IAExC,eAAe,GAAG,IAAI,CAAC,MAAM,CAAC,eAAe,IAAI,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,mBAAmB,IAAI,IAAI,CAAC,CAAC;IAC5F,eAAe,GAAG,IAAI,CAAC,MAAM,CAAC,eAAe,IAAI,OAAO,CAAC;IACzD,mBAAmB,GAAG,IAAI,CAAC,MAAM,CAAC,mBAAmB,IAAI,WAAW,CAAC;IAE9E;;OAEG;IACM,iBAAiB,GAAG,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,0BAA0B,IAAI,IAAI,CAAC,MAAM,CAAC,0BAA0B,CAAC,CAAC;IAE9G,gBAAgB,GAAG,MAAM,CAAU,KAAK,CAAC,CAAC;IAE1C,OAAO,GAA6D,YAAY,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC,IAAI,CACnH,GAAG,CAAC,CAAC,UAAU,EAAE,EAAE;QACjB,MAAM,EAAE,mBAAmB,GAAG,IAAI,EAAE,SAAS,EAAE,gBAAgB,EAAE,0BAA0B,EAAE,0BAA0B,EAAE,2BAA2B,EAAE,2BAA2B,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC;QAClM,IAAI,cAAqC,CAAC;QAC1C,IAAI,UAA+D,CAAC;QAEpE,IAAI,UAAU,EAAE,CAAC;YACf,cAAc,GAAG,CAAC,2BAA2B,EAAE,cAAc,IAAI,0BAA0B,CAA0B,CAAC;YACtH,UAAU,GAAG,2BAA2B,CAAC;QAC3C,CAAC;aAAM,CAAC;YACN,cAAc,GAAG,CAAC,2BAA2B,EAAE,cAAc,IAAI,0BAA0B,CAA0B,CAAC;YACtH,UAAU,GAAG,2BAA2B,CAAC;QAC3C,CAAC;QAED,MAAM,MAAM,GAAiD;YAC3D,GAAG,UAAU;YACb,cAAc;YACd,IAAI,EAAE,CAAC,YAAY,EAAE,EAAE;gBACrB,SAAS,CAAC,iBAAiB,CAAC,YAAY,CAAC,CAAC;gBAE1C,IAAI,gBAAgB,IAAI,YAAY,CAAC,cAAc,EAAE,CAAC;oBACpD,YAAY,CAAC,cAAc,CAAC,gBAAgB,CAAC,CAAC;gBAChD,CAAC;gBAED,IAAI,mBAAmB,KAAK,KAAK,EAAE,CAAC;oBAClC,iBAAiB,CACf,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,WAAW,EAAE,EAAE,KAAK,EAAE,EAAE,cAAc,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;wBACnG,IAAI,CAAC,KAAK,EAAE,CAAC;oBACf,CAAC,CAAC,CACH,CAAC;gBACJ,CAAC;gBAED,gCAAgC;gBAChC,UAAU,EAAE,IAAI,EAAE,CAAC,YAAY,CAAC,CAAC;YACnC,CAAC;SACF,CAAC;QAEF,OAAO,MAAM,CAAC;IAChB,CAAC,CAAC,CACH,CAAC;IAEO,YAAY,GAAG,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IAE/C,MAAM,CAAC,WAAW,CAAmB,YAA+B,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,0BAA0B,EAAE,0BAA0B,EAAE,2BAA2B,EAAE,2BAA2B,EAAE,SAAS,EAAE,gBAAgB,EAAE,mBAAmB,EAAE,mBAAmB,EAAE,eAAe,EAAE,eAAe,EAAsC,EAAE,UAA0B;QACnZ,OAAO,YAAY,CAAC,IAAI,CAAC;YACvB,GAAG,EAAE,UAAU,IAAI,0BAA0B;YAC7C,MAAM;YACN,cAAc,EAAE,yBAAyB;YACzC,KAAK;YACL,MAAM;YACN,WAAW;YACX,IAAI,EAAE;gBACJ,MAAM;gBACN,IAAI;gBACJ,mBAAmB;gBACnB,eAAe;gBACf,eAAe;gBACf,0BAA0B;gBAC1B,0BAA0B;gBAC1B,2BAA2B;gBAC3B,2BAA2B;gBAC3B,SAAS;gBACT,gBAAgB;gBAChB,mBAAmB;aACW;SACjC,CAAC,CAAC;IACL,CAAC;IAED;QACE,KAAK,EAAE,CAAC;QAER,IAAI,UAAU,GAAY,KAAK,CAAC;QAEhC,MAAM,EAAE,0BAA0B,EAAE,0BAA0B,EAAE,2BAA2B,EAAE,2BAA2B,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC;QAEzI,IAAI,0BAA0B,IAAI,2BAA2B,EAAE,CAAC;YAC9D,UAAU,GAAG,KAAK,CAAC;QACrB,CAAC;QAED,IAAI,0BAA0B,IAAI,2BAA2B,EAAE,CAAC;YAC9D,UAAU,GAAG,IAAI,CAAC;QACpB,CAAC;QAED,IAAI,CAAC,CAAC,0BAA0B,IAAI,2BAA2B,CAAC,IAAI,CAAC,CAAC,0BAA0B,IAAI,2BAA2B,CAAC,EAAE,CAAC;YACjI,MAAM,IAAI,KAAK,CAAC,kEAAkE,CAAC,CAAC;QACtF,CAAC;QAED,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;IACxC,CAAC;IAED,WAAW;QACT,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IAClC,CAAC;IAED,UAAU;QACR,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;IACnC,CAAC;wGAjHU,yBAAyB;4FAAzB,yBAAyB,+FC9BtC,+3BAyBA,2CDCY,2BAA2B,mZAAE,qBAAqB,0HAAE,eAAe,4NAAE,wBAAwB;;4FAI5F,yBAAyB;kBANrC,SAAS;8BAEC,CAAC,2BAA2B,EAAE,qBAAqB,EAAE,eAAe,EAAE,wBAAwB,CAAC,mBACvF,uBAAuB,CAAC,MAAM,cACnC,IAAI","sourcesContent":["import { cleanSubscription, DbxInjectionComponent, DbxInjectionComponentConfig } from '@dereekb/dbx-core';\nimport { Component, ElementRef, Type, signal, ChangeDetectionStrategy } from '@angular/core';\nimport { NgPopoverRef } from 'ng-overlay-container';\nimport { Observable, map, skip, first, defaultIfEmpty } from 'rxjs';\nimport { AbstractPopoverDirective } from '../popover/abstract.popover.directive';\nimport { DbxPopoverService } from '../popover/popover.service';\nimport { FilterSource, filterMaybe } from '@dereekb/rxjs';\nimport { DbxPopoverKey } from '../popover/popover';\nimport { type Maybe } from '@dereekb/util';\nimport { toObservable, toSignal } from '@angular/core/rxjs-interop';\nimport { DbxFilterComponentConfig } from './filter.config';\nimport { DbxPopoverInteractionModule } from '../popover';\nimport { MatButtonModule } from '@angular/material/button';\nimport { DbxButtonSpacerDirective } from '../../button/button.spacer.directive';\n\nexport interface DbxFilterPopoverComponentConfig<F extends object = object> extends DbxFilterComponentConfig<F> {\n  /**\n   * Origin to add the popover to.\n   */\n  readonly origin: ElementRef;\n}\n\nexport const DEFAULT_FILTER_POPOVER_KEY = 'filter';\n\n@Component({\n  templateUrl: './filter.popover.component.html',\n  imports: [DbxPopoverInteractionModule, DbxInjectionComponent, MatButtonModule, DbxButtonSpacerDirective],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true\n})\nexport class DbxFilterPopoverComponent<F extends object> extends AbstractPopoverDirective<unknown, DbxFilterComponentConfig<F>> {\n  readonly config: DbxFilterComponentConfig<F> = this.popover.data as DbxFilterComponentConfig<F>;\n\n  readonly icon = this.config.icon ?? 'filter_list';\n  readonly header = this.config.header ?? 'Filter';\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  readonly showPresetSignal = signal<boolean>(false);\n\n  readonly config$: Observable<DbxInjectionComponentConfig<FilterSource<F>>> = toObservable(this.showPresetSignal).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            cleanSubscription(\n              filterSource.filter$.pipe(skip(1), filterMaybe(), first(), defaultIfEmpty(undefined)).subscribe(() => {\n                this.close();\n              })\n            );\n          }\n\n          // run the next init if provided\n          baseConfig?.init?.(filterSource);\n        }\n      };\n\n      return config;\n    })\n  );\n\n  readonly configSignal = toSignal(this.config$);\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 }: DbxFilterPopoverComponentConfig<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 DbxFilterComponentConfig<F>\n    });\n  }\n\n  constructor() {\n    super();\n\n    let showPreset: boolean = false;\n\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.showPresetSignal.set(showPreset);\n  }\n\n  showPresets() {\n    this.showPresetSignal.set(true);\n  }\n\n  showCustom() {\n    this.showPresetSignal.set(false);\n  }\n}\n","<dbx-popover-content>\n  <!-- Header -->\n  <dbx-popover-header [icon]=\"icon\" [header]=\"header\">\n    @if (showSwitchButtons) {\n      @switch (showPresetSignal()) {\n        @case (true) {\n          <button mat-flat-button color=\"accent\" (click)=\"showCustom()\">{{ customizeButtonText }}</button>\n        }\n        @case (false) {\n          <button mat-flat-button color=\"accent\" (click)=\"showPresets()\">Presets</button>\n        }\n      }\n    }\n    @if (showCloseButton) {\n      @if (showSwitchButtons) {\n        <dbx-button-spacer></dbx-button-spacer>\n      }\n      <button mat-stroked-button color=\"accent\" (click)=\"close()\">{{ closeButtonText }}</button>\n    }\n  </dbx-popover-header>\n  <!-- Content -->\n  <dbx-popover-scroll-content>\n    <dbx-injection [config]=\"configSignal()\"></dbx-injection>\n  </dbx-popover-scroll-content>\n</dbx-popover-content>\n"]}
@@ -13,7 +13,7 @@ import * as i5 from "@ngbracket/ngx-layout/flex";
13
13
  /**
14
14
  * Action component used to simplify creating a filter form.
15
15
  *
16
- * Provides a DbxAction and configures the action to set the filter on a FilterSourceDirective when triggered.
16
+ * Provides a ActionContextStoreSource and configures the action to set the filter on a FilterSourceDirective when triggered.
17
17
  */
18
18
  export class DbxFilterWrapperComponent extends AbstractDbxActionHandlerDirective {
19
19
  filterSourceDirective = inject((FilterSourceDirective));
@@ -23,6 +23,7 @@ export class DbxFilterWrapperComponent extends AbstractDbxActionHandlerDirective
23
23
  applyText = input('Filter');
24
24
  constructor() {
25
25
  super();
26
+ // TODO: Consider throwing an error if dbxAction is provided at the same time as this, since the source would not be used?
26
27
  // configure handler function
27
28
  this._dbxActionHandlerInstance.setHandlerFunction((filter, instance) => {
28
29
  this.filterSourceDirective.setFilter(filter);
@@ -43,4 +44,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
43
44
  type: Component,
44
45
  args: [{ selector: 'dbx-filter-wrapper', providers: [provideActionStoreSource(null)], standalone: true, imports: [DbxButtonModule, MatButtonModule, MatIconModule, FlexLayoutModule], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"dbx-filter-wrapper\">\n <div class=\"dbx-filter-wrapper-content\">\n <ng-content></ng-content>\n </div>\n @if (showButtons()) {\n <div fxLayout=\"row\">\n <dbx-button dbxActionButton [raised]=\"applyRaised()\" [text]=\"applyText()\" [icon]=\"applyIcon()\"></dbx-button>\n <div class=\"spacer\"></div>\n <button mat-icon-button (click)=\"resetFilter()\">\n <mat-icon>clear</mat-icon>\n </button>\n </div>\n }\n</div>\n" }]
45
46
  }], ctorParameters: () => [] });
46
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLndyYXBwZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LXdlYi9zcmMvbGliL2ludGVyYWN0aW9uL2ZpbHRlci9maWx0ZXIud3JhcHBlci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3NyYy9saWIvaW50ZXJhY3Rpb24vZmlsdGVyL2ZpbHRlci53cmFwcGVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNsRixPQUFPLEVBQUUsaUNBQWlDLEVBQUUscUJBQXFCLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUN2SCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUM3RCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQzs7Ozs7OztBQUd6RDs7OztHQUlHO0FBU0gsTUFBTSxPQUFPLHlCQUF1QyxTQUFRLGlDQUFvQztJQUNyRixxQkFBcUIsR0FBRyxNQUFNLENBQUMsQ0FBQSxxQkFBd0IsQ0FBQSxDQUFDLENBQUM7SUFFekQsV0FBVyxHQUFHLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUMxQixXQUFXLEdBQUcsS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQzFCLFNBQVMsR0FBRyxLQUFLLENBQUMsYUFBYSxDQUFDLENBQUM7SUFDakMsU0FBUyxHQUFHLEtBQUssQ0FBQyxRQUFRLENBQUMsQ0FBQztJQUVyQztRQUNFLEtBQUssRUFBRSxDQUFDO1FBRVIsNkJBQTZCO1FBQzdCLElBQUksQ0FBQyx5QkFBeUIsQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDLE1BQVMsRUFBRSxRQUFrQyxFQUFFLEVBQUU7WUFDbEcsSUFBSSxDQUFDLHFCQUFxQixDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsQ0FBQztZQUM3QyxRQUFRLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ3pCLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELFdBQVc7UUFDVCxJQUFJLENBQUMsTUFBTSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLDBCQUEwQjtRQUMzRCxJQUFJLENBQUMsTUFBTSxDQUFDLE9BQU8sRUFBRSxDQUFDO0lBQ3hCLENBQUM7SUFFRCxXQUFXO1FBQ1QsSUFBSSxDQUFDLHFCQUFxQixDQUFDLFdBQVcsRUFBRSxDQUFDO0lBQzNDLENBQUM7d0dBekJVLHlCQUF5Qjs0RkFBekIseUJBQXlCLHltQkFMekIsQ0FBQyx3QkFBd0IsQ0FBQyxJQUFJLENBQUMsQ0FBQyxpRENoQjdDLHdkQWNBLDJDRElZLGVBQWUsbVlBQUUsZUFBZSwySUFBRSxhQUFhLG1MQUFFLGdCQUFnQjs7NEZBR2hFLHlCQUF5QjtrQkFSckMsU0FBUzsrQkFDRSxvQkFBb0IsYUFFbkIsQ0FBQyx3QkFBd0IsQ0FBQyxJQUFJLENBQUMsQ0FBQyxjQUMvQixJQUFJLFdBQ1AsQ0FBQyxlQUFlLEVBQUUsZUFBZSxFQUFFLGFBQWEsRUFBRSxnQkFBZ0IsQ0FBQyxtQkFDM0QsdUJBQXVCLENBQUMsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIGluamVjdCwgaW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEFic3RyYWN0RGJ4QWN0aW9uSGFuZGxlckRpcmVjdGl2ZSwgRmlsdGVyU291cmNlRGlyZWN0aXZlLCBwcm92aWRlQWN0aW9uU3RvcmVTb3VyY2UgfSBmcm9tICdAZGVyZWVrYi9kYngtY29yZSc7XG5pbXBvcnQgeyBNYXRCdXR0b25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9idXR0b24nO1xuaW1wb3J0IHsgTWF0SWNvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xuaW1wb3J0IHsgRGJ4QnV0dG9uTW9kdWxlIH0gZnJvbSAnLi4vLi4vYnV0dG9uL2J1dHRvbi5tb2R1bGUnO1xuaW1wb3J0IHsgRmxleExheW91dE1vZHVsZSB9IGZyb20gJ0BuZ2JyYWNrZXQvbmd4LWxheW91dCc7XG5pbXBvcnQgeyBXb3JrSW5zdGFuY2UgfSBmcm9tICdAZGVyZWVrYi9yeGpzJztcblxuLyoqXG4gKiBBY3Rpb24gY29tcG9uZW50IHVzZWQgdG8gc2ltcGxpZnkgY3JlYXRpbmcgYSBmaWx0ZXIgZm9ybS5cbiAqXG4gKiBQcm92aWRlcyBhIERieEFjdGlvbiBhbmQgY29uZmlndXJlcyB0aGUgYWN0aW9uIHRvIHNldCB0aGUgZmlsdGVyIG9uIGEgRmlsdGVyU291cmNlRGlyZWN0aXZlIHdoZW4gdHJpZ2dlcmVkLlxuICovXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdkYngtZmlsdGVyLXdyYXBwZXInLFxuICB0ZW1wbGF0ZVVybDogJy4vZmlsdGVyLndyYXBwZXIuY29tcG9uZW50Lmh0bWwnLFxuICBwcm92aWRlcnM6IFtwcm92aWRlQWN0aW9uU3RvcmVTb3VyY2UobnVsbCldLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbRGJ4QnV0dG9uTW9kdWxlLCBNYXRCdXR0b25Nb2R1bGUsIE1hdEljb25Nb2R1bGUsIEZsZXhMYXlvdXRNb2R1bGVdLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxufSlcbmV4cG9ydCBjbGFzcyBEYnhGaWx0ZXJXcmFwcGVyQ29tcG9uZW50PEYgPSB1bmtub3duPiBleHRlbmRzIEFic3RyYWN0RGJ4QWN0aW9uSGFuZGxlckRpcmVjdGl2ZTxGPiB7XG4gIHJlYWRvbmx5IGZpbHRlclNvdXJjZURpcmVjdGl2ZSA9IGluamVjdChGaWx0ZXJTb3VyY2VEaXJlY3RpdmU8Rj4pO1xuXG4gIHJlYWRvbmx5IHNob3dCdXR0b25zID0gaW5wdXQodHJ1ZSk7XG4gIHJlYWRvbmx5IGFwcGx5UmFpc2VkID0gaW5wdXQodHJ1ZSk7XG4gIHJlYWRvbmx5IGFwcGx5SWNvbiA9IGlucHV0KCdmaWx0ZXJfbGlzdCcpO1xuICByZWFkb25seSBhcHBseVRleHQgPSBpbnB1dCgnRmlsdGVyJyk7XG5cbiAgY29uc3RydWN0b3IoKSB7XG4gICAgc3VwZXIoKTtcblxuICAgIC8vIGNvbmZpZ3VyZSBoYW5kbGVyIGZ1bmN0aW9uXG4gICAgdGhpcy5fZGJ4QWN0aW9uSGFuZGxlckluc3RhbmNlLnNldEhhbmRsZXJGdW5jdGlvbigoZmlsdGVyOiBGLCBpbnN0YW5jZTogV29ya0luc3RhbmNlPEYsIHVua25vd24+KSA9PiB7XG4gICAgICB0aGlzLmZpbHRlclNvdXJjZURpcmVjdGl2ZS5zZXRGaWx0ZXIoZmlsdGVyKTtcbiAgICAgIGluc3RhbmNlLnN1Y2Nlc3ModHJ1ZSk7XG4gICAgfSk7XG4gIH1cblxuICBhcHBseUZpbHRlcigpOiB2b2lkIHtcbiAgICB0aGlzLnNvdXJjZS5zZXRJc01vZGlmaWVkKHRydWUpOyAvLyBGb3JjZSBzZXR0aW5nIG1vZGlmaWVkLlxuICAgIHRoaXMuc291cmNlLnRyaWdnZXIoKTtcbiAgfVxuXG4gIHJlc2V0RmlsdGVyKCk6IHZvaWQge1xuICAgIHRoaXMuZmlsdGVyU291cmNlRGlyZWN0aXZlLnJlc2V0RmlsdGVyKCk7XG4gIH1cbn1cbiIsIjxkaXYgY2xhc3M9XCJkYngtZmlsdGVyLXdyYXBwZXJcIj5cbiAgPGRpdiBjbGFzcz1cImRieC1maWx0ZXItd3JhcHBlci1jb250ZW50XCI+XG4gICAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuICA8L2Rpdj5cbiAgQGlmIChzaG93QnV0dG9ucygpKSB7XG4gICAgPGRpdiBmeExheW91dD1cInJvd1wiPlxuICAgICAgPGRieC1idXR0b24gZGJ4QWN0aW9uQnV0dG9uIFtyYWlzZWRdPVwiYXBwbHlSYWlzZWQoKVwiIFt0ZXh0XT1cImFwcGx5VGV4dCgpXCIgW2ljb25dPVwiYXBwbHlJY29uKClcIj48L2RieC1idXR0b24+XG4gICAgICA8ZGl2IGNsYXNzPVwic3BhY2VyXCI+PC9kaXY+XG4gICAgICA8YnV0dG9uIG1hdC1pY29uLWJ1dHRvbiAoY2xpY2spPVwicmVzZXRGaWx0ZXIoKVwiPlxuICAgICAgICA8bWF0LWljb24+Y2xlYXI8L21hdC1pY29uPlxuICAgICAgPC9idXR0b24+XG4gICAgPC9kaXY+XG4gIH1cbjwvZGl2PlxuIl19
47
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLndyYXBwZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LXdlYi9zcmMvbGliL2ludGVyYWN0aW9uL2ZpbHRlci9maWx0ZXIud3JhcHBlci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3NyYy9saWIvaW50ZXJhY3Rpb24vZmlsdGVyL2ZpbHRlci53cmFwcGVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNsRixPQUFPLEVBQUUsaUNBQWlDLEVBQUUscUJBQXFCLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUN2SCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUM3RCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQzs7Ozs7OztBQUd6RDs7OztHQUlHO0FBU0gsTUFBTSxPQUFPLHlCQUF1QyxTQUFRLGlDQUFvQztJQUNyRixxQkFBcUIsR0FBRyxNQUFNLENBQUMsQ0FBQSxxQkFBd0IsQ0FBQSxDQUFDLENBQUM7SUFFekQsV0FBVyxHQUFHLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUMxQixXQUFXLEdBQUcsS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQzFCLFNBQVMsR0FBRyxLQUFLLENBQUMsYUFBYSxDQUFDLENBQUM7SUFDakMsU0FBUyxHQUFHLEtBQUssQ0FBQyxRQUFRLENBQUMsQ0FBQztJQUVyQztRQUNFLEtBQUssRUFBRSxDQUFDO1FBRVIsMEhBQTBIO1FBRTFILDZCQUE2QjtRQUM3QixJQUFJLENBQUMseUJBQXlCLENBQUMsa0JBQWtCLENBQUMsQ0FBQyxNQUFTLEVBQUUsUUFBa0MsRUFBRSxFQUFFO1lBQ2xHLElBQUksQ0FBQyxxQkFBcUIsQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDLENBQUM7WUFDN0MsUUFBUSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUN6QixDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRCxXQUFXO1FBQ1QsSUFBSSxDQUFDLE1BQU0sQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQywwQkFBMEI7UUFDM0QsSUFBSSxDQUFDLE1BQU0sQ0FBQyxPQUFPLEVBQUUsQ0FBQztJQUN4QixDQUFDO0lBRUQsV0FBVztRQUNULElBQUksQ0FBQyxxQkFBcUIsQ0FBQyxXQUFXLEVBQUUsQ0FBQztJQUMzQyxDQUFDO3dHQTNCVSx5QkFBeUI7NEZBQXpCLHlCQUF5Qix5bUJBTHpCLENBQUMsd0JBQXdCLENBQUMsSUFBSSxDQUFDLENBQUMsaURDaEI3Qyx3ZEFjQSwyQ0RJWSxlQUFlLG1ZQUFFLGVBQWUsMklBQUUsYUFBYSxtTEFBRSxnQkFBZ0I7OzRGQUdoRSx5QkFBeUI7a0JBUnJDLFNBQVM7K0JBQ0Usb0JBQW9CLGFBRW5CLENBQUMsd0JBQXdCLENBQUMsSUFBSSxDQUFDLENBQUMsY0FDL0IsSUFBSSxXQUNQLENBQUMsZUFBZSxFQUFFLGVBQWUsRUFBRSxhQUFhLEVBQUUsZ0JBQWdCLENBQUMsbUJBQzNELHVCQUF1QixDQUFDLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBpbmplY3QsIGlucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBBYnN0cmFjdERieEFjdGlvbkhhbmRsZXJEaXJlY3RpdmUsIEZpbHRlclNvdXJjZURpcmVjdGl2ZSwgcHJvdmlkZUFjdGlvblN0b3JlU291cmNlIH0gZnJvbSAnQGRlcmVla2IvZGJ4LWNvcmUnO1xuaW1wb3J0IHsgTWF0QnV0dG9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvYnV0dG9uJztcbmltcG9ydCB7IE1hdEljb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pY29uJztcbmltcG9ydCB7IERieEJ1dHRvbk1vZHVsZSB9IGZyb20gJy4uLy4uL2J1dHRvbi9idXR0b24ubW9kdWxlJztcbmltcG9ydCB7IEZsZXhMYXlvdXRNb2R1bGUgfSBmcm9tICdAbmdicmFja2V0L25neC1sYXlvdXQnO1xuaW1wb3J0IHsgV29ya0luc3RhbmNlIH0gZnJvbSAnQGRlcmVla2Ivcnhqcyc7XG5cbi8qKlxuICogQWN0aW9uIGNvbXBvbmVudCB1c2VkIHRvIHNpbXBsaWZ5IGNyZWF0aW5nIGEgZmlsdGVyIGZvcm0uXG4gKlxuICogUHJvdmlkZXMgYSBBY3Rpb25Db250ZXh0U3RvcmVTb3VyY2UgYW5kIGNvbmZpZ3VyZXMgdGhlIGFjdGlvbiB0byBzZXQgdGhlIGZpbHRlciBvbiBhIEZpbHRlclNvdXJjZURpcmVjdGl2ZSB3aGVuIHRyaWdnZXJlZC5cbiAqL1xuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnZGJ4LWZpbHRlci13cmFwcGVyJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2ZpbHRlci53cmFwcGVyLmNvbXBvbmVudC5odG1sJyxcbiAgcHJvdmlkZXJzOiBbcHJvdmlkZUFjdGlvblN0b3JlU291cmNlKG51bGwpXSxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW0RieEJ1dHRvbk1vZHVsZSwgTWF0QnV0dG9uTW9kdWxlLCBNYXRJY29uTW9kdWxlLCBGbGV4TGF5b3V0TW9kdWxlXSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcbn0pXG5leHBvcnQgY2xhc3MgRGJ4RmlsdGVyV3JhcHBlckNvbXBvbmVudDxGID0gdW5rbm93bj4gZXh0ZW5kcyBBYnN0cmFjdERieEFjdGlvbkhhbmRsZXJEaXJlY3RpdmU8Rj4ge1xuICByZWFkb25seSBmaWx0ZXJTb3VyY2VEaXJlY3RpdmUgPSBpbmplY3QoRmlsdGVyU291cmNlRGlyZWN0aXZlPEY+KTtcblxuICByZWFkb25seSBzaG93QnV0dG9ucyA9IGlucHV0KHRydWUpO1xuICByZWFkb25seSBhcHBseVJhaXNlZCA9IGlucHV0KHRydWUpO1xuICByZWFkb25seSBhcHBseUljb24gPSBpbnB1dCgnZmlsdGVyX2xpc3QnKTtcbiAgcmVhZG9ubHkgYXBwbHlUZXh0ID0gaW5wdXQoJ0ZpbHRlcicpO1xuXG4gIGNvbnN0cnVjdG9yKCkge1xuICAgIHN1cGVyKCk7XG5cbiAgICAvLyBUT0RPOiBDb25zaWRlciB0aHJvd2luZyBhbiBlcnJvciBpZiBkYnhBY3Rpb24gaXMgcHJvdmlkZWQgYXQgdGhlIHNhbWUgdGltZSBhcyB0aGlzLCBzaW5jZSB0aGUgc291cmNlIHdvdWxkIG5vdCBiZSB1c2VkP1xuXG4gICAgLy8gY29uZmlndXJlIGhhbmRsZXIgZnVuY3Rpb25cbiAgICB0aGlzLl9kYnhBY3Rpb25IYW5kbGVySW5zdGFuY2Uuc2V0SGFuZGxlckZ1bmN0aW9uKChmaWx0ZXI6IEYsIGluc3RhbmNlOiBXb3JrSW5zdGFuY2U8RiwgdW5rbm93bj4pID0+IHtcbiAgICAgIHRoaXMuZmlsdGVyU291cmNlRGlyZWN0aXZlLnNldEZpbHRlcihmaWx0ZXIpO1xuICAgICAgaW5zdGFuY2Uuc3VjY2Vzcyh0cnVlKTtcbiAgICB9KTtcbiAgfVxuXG4gIGFwcGx5RmlsdGVyKCk6IHZvaWQge1xuICAgIHRoaXMuc291cmNlLnNldElzTW9kaWZpZWQodHJ1ZSk7IC8vIEZvcmNlIHNldHRpbmcgbW9kaWZpZWQuXG4gICAgdGhpcy5zb3VyY2UudHJpZ2dlcigpO1xuICB9XG5cbiAgcmVzZXRGaWx0ZXIoKTogdm9pZCB7XG4gICAgdGhpcy5maWx0ZXJTb3VyY2VEaXJlY3RpdmUucmVzZXRGaWx0ZXIoKTtcbiAgfVxufVxuIiwiPGRpdiBjbGFzcz1cImRieC1maWx0ZXItd3JhcHBlclwiPlxuICA8ZGl2IGNsYXNzPVwiZGJ4LWZpbHRlci13cmFwcGVyLWNvbnRlbnRcIj5cbiAgICA8bmctY29udGVudD48L25nLWNvbnRlbnQ+XG4gIDwvZGl2PlxuICBAaWYgKHNob3dCdXR0b25zKCkpIHtcbiAgICA8ZGl2IGZ4TGF5b3V0PVwicm93XCI+XG4gICAgICA8ZGJ4LWJ1dHRvbiBkYnhBY3Rpb25CdXR0b24gW3JhaXNlZF09XCJhcHBseVJhaXNlZCgpXCIgW3RleHRdPVwiYXBwbHlUZXh0KClcIiBbaWNvbl09XCJhcHBseUljb24oKVwiPjwvZGJ4LWJ1dHRvbj5cbiAgICAgIDxkaXYgY2xhc3M9XCJzcGFjZXJcIj48L2Rpdj5cbiAgICAgIDxidXR0b24gbWF0LWljb24tYnV0dG9uIChjbGljayk9XCJyZXNldEZpbHRlcigpXCI+XG4gICAgICAgIDxtYXQtaWNvbj5jbGVhcjwvbWF0LWljb24+XG4gICAgICA8L2J1dHRvbj5cbiAgICA8L2Rpdj5cbiAgfVxuPC9kaXY+XG4iXX0=
@@ -1,12 +1,12 @@
1
1
  import { Component, viewChild, ElementRef, ChangeDetectionStrategy, computed, inject, SecurityContext, effect, signal, model } from '@angular/core';
2
2
  import { toObservable } from '@angular/core/rxjs-interop';
3
3
  import { combineLatest, throttleTime } from 'rxjs';
4
- import { AbstractSubscriptionDirective } from '@dereekb/dbx-core';
5
4
  import { DomSanitizer } from '@angular/platform-browser';
6
5
  import { browserObjectUrlRef } from '@dereekb/browser';
6
+ import { clean, cleanSubscription } from '@dereekb/dbx-core';
7
7
  import * as i0 from "@angular/core";
8
- export class DbxEmbedComponent extends AbstractSubscriptionDirective {
9
- _browserObjectUrlRef = browserObjectUrlRef();
8
+ export class DbxEmbedComponent {
9
+ _browserObjectUrlRef = clean(browserObjectUrlRef());
10
10
  sanitizer = inject(DomSanitizer);
11
11
  root = viewChild('root', { read: ElementRef });
12
12
  /**
@@ -55,8 +55,7 @@ export class DbxEmbedComponent extends AbstractSubscriptionDirective {
55
55
  type$ = toObservable(this.typeSignal);
56
56
  embedElementName$ = toObservable(this.embedElement);
57
57
  constructor() {
58
- super();
59
- this.sub = combineLatest([this.srcUrl$, this.root$, this.type$, this.embedElementName$])
58
+ cleanSubscription(combineLatest([this.srcUrl$, this.root$, this.type$, this.embedElementName$])
60
59
  .pipe(throttleTime(100, undefined, { leading: true, trailing: true }))
61
60
  .subscribe(([srcUrl, root, type, forceEmbedElementName]) => {
62
61
  const element = root?.nativeElement;
@@ -99,14 +98,10 @@ export class DbxEmbedComponent extends AbstractSubscriptionDirective {
99
98
  element.appendChild(embed);
100
99
  }
101
100
  }
102
- });
103
- }
104
- ngOnDestroy() {
105
- super.ngOnDestroy();
106
- this._browserObjectUrlRef.destroy();
101
+ }));
107
102
  }
108
103
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxEmbedComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
109
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "18.2.13", type: DbxEmbedComponent, isStandalone: true, selector: "dbx-embed", inputs: { embedElement: { classPropertyName: "embedElement", publicName: "embedElement", isSignal: true, isRequired: false, transformFunction: null }, sanitizeUrl: { classPropertyName: "sanitizeUrl", publicName: "sanitizeUrl", isSignal: true, isRequired: false, transformFunction: null }, srcUrl: { classPropertyName: "srcUrl", publicName: "srcUrl", isSignal: true, isRequired: false, transformFunction: null }, type: { classPropertyName: "type", publicName: "type", isSignal: true, isRequired: false, transformFunction: null }, blob: { classPropertyName: "blob", publicName: "blob", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { embedElement: "embedElementChange", sanitizeUrl: "sanitizeUrlChange", srcUrl: "srcUrlChange", type: "typeChange", blob: "blobChange" }, viewQueries: [{ propertyName: "root", first: true, predicate: ["root"], descendants: true, read: ElementRef, isSignal: true }], usesInheritance: true, ngImport: i0, template: `
104
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "18.2.13", type: DbxEmbedComponent, isStandalone: true, selector: "dbx-embed", inputs: { embedElement: { classPropertyName: "embedElement", publicName: "embedElement", isSignal: true, isRequired: false, transformFunction: null }, sanitizeUrl: { classPropertyName: "sanitizeUrl", publicName: "sanitizeUrl", isSignal: true, isRequired: false, transformFunction: null }, srcUrl: { classPropertyName: "srcUrl", publicName: "srcUrl", isSignal: true, isRequired: false, transformFunction: null }, type: { classPropertyName: "type", publicName: "type", isSignal: true, isRequired: false, transformFunction: null }, blob: { classPropertyName: "blob", publicName: "blob", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { embedElement: "embedElementChange", sanitizeUrl: "sanitizeUrlChange", srcUrl: "srcUrlChange", type: "typeChange", blob: "blobChange" }, viewQueries: [{ propertyName: "root", first: true, predicate: ["root"], descendants: true, read: ElementRef, isSignal: true }], ngImport: i0, template: `
110
105
  <span #root></span>
111
106
  `, isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush });
112
107
  }
@@ -121,4 +116,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
121
116
  standalone: true
122
117
  }]
123
118
  }], ctorParameters: () => [] });
124
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"embed.component.js","sourceRoot":"","sources":["../../../../../../../packages/dbx-web/src/lib/interaction/iframe/embed.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, viewChild, ElementRef, ChangeDetectionStrategy, computed, inject, SecurityContext, effect, signal, OnDestroy, model } from '@angular/core';\nimport { toObservable } from '@angular/core/rxjs-interop';\nimport { combineLatest, throttleTime } from 'rxjs';\nimport { ContentTypeMimeType, Maybe } from '@dereekb/util';\nimport { AbstractSubscriptionDirective } from '@dereekb/dbx-core';\nimport { DomSanitizer, SafeResourceUrl } from '@angular/platform-browser';\nimport { browserObjectUrlRef } from '@dereekb/browser';\n\nexport type DbxEmbedComponentElement = 'embed' | 'img';\n\n@Component({\n  selector: 'dbx-embed',\n  template: `\n    <span #root></span>\n  `,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true\n})\nexport class DbxEmbedComponent extends AbstractSubscriptionDirective implements OnDestroy {\n  private readonly _browserObjectUrlRef = browserObjectUrlRef();\n\n  readonly sanitizer = inject(DomSanitizer);\n\n  readonly root = viewChild<string, ElementRef<HTMLSpanElement>>('root', { read: ElementRef });\n\n  /**\n   * The element to embed. Can be either embed or img. If not provided, will be determined by the input mimetype.\n   *\n   * If set to 'embed', the embed element will be used.\n   * If set to 'img', the img element will be used.\n   */\n  readonly embedElement = model<Maybe<DbxEmbedComponentElement>>();\n\n  readonly sanitizeUrl = model<Maybe<boolean>>();\n\n  readonly srcUrl = model<Maybe<string | SafeResourceUrl>>();\n  readonly type = model<Maybe<ContentTypeMimeType | string>>();\n\n  /**\n   * The input blob or media source to use.\n   *\n   * If set, the srcUrl will be updated with the browser object URL.\n   */\n  readonly blob = model<Maybe<Blob>>();\n\n  readonly srcUrlFromBlob = signal<Maybe<string>>(undefined);\n  readonly typeFromBlob = signal<Maybe<string>>(undefined);\n\n  readonly blobEffect = effect(\n    () => {\n      const blob = this.blob();\n      this.srcUrlFromBlob.set(this._browserObjectUrlRef.createBrowserUrl(blob));\n      this.typeFromBlob.set(blob?.type);\n    },\n    {\n      allowSignalWrites: true\n    }\n  );\n\n  readonly srcUrlSignal = computed(() => {\n    const srcUrl = this.srcUrl();\n    const srcUrlFromBlob = this.srcUrlFromBlob();\n\n    const baseUrl = srcUrl ?? srcUrlFromBlob;\n\n    let url: Maybe<string | SafeResourceUrl> = baseUrl;\n    const sanitizeUrl = this.sanitizeUrl();\n\n    if (url && typeof url === 'string' && sanitizeUrl) {\n      url = this.sanitizer.bypassSecurityTrustResourceUrl(url);\n    }\n\n    return url;\n  });\n\n  readonly typeSignal = computed(() => {\n    const type = this.type();\n    const typeFromBlob = this.typeFromBlob();\n    return type ?? typeFromBlob;\n  });\n\n  readonly root$ = toObservable(this.root);\n  readonly srcUrl$ = toObservable(this.srcUrlSignal);\n  readonly type$ = toObservable(this.typeSignal);\n  readonly embedElementName$ = toObservable(this.embedElement);\n\n  constructor() {\n    super();\n    this.sub = combineLatest([this.srcUrl$, this.root$, this.type$, this.embedElementName$])\n      .pipe(throttleTime(100, undefined, { leading: true, trailing: true }))\n      .subscribe(([srcUrl, root, type, forceEmbedElementName]) => {\n        const element = root?.nativeElement;\n\n        if (element) {\n          // remove all embeds from the element\n          element?.childNodes.forEach((x) => element.removeChild(x));\n\n          if (srcUrl) {\n            const isImageType = type?.startsWith('image/');\n            const embedElementName = forceEmbedElementName ?? (isImageType ? 'img' : 'embed');\n\n            // NOTE: We do this because of the following chromium behavior:\n            // https://issues.chromium.org/issues/40508296\n            //\n            // Embed cannot have src change dynamically, so we create a new embed element each time the src changes.\n            //\n            const embed = document.createElement(embedElementName);\n\n            let url: Maybe<string> = undefined;\n\n            if (srcUrl != null && typeof srcUrl !== 'string') {\n              url = this.sanitizer.sanitize(SecurityContext.URL, srcUrl);\n            } else {\n              url = srcUrl;\n            }\n\n            // both embed and img use src\n            embed.setAttribute('src', url ?? '');\n\n            // if the type is an image, add the embed class\n            if (isImageType) {\n              embed.setAttribute('class', 'embed embed-img');\n            } else {\n              embed.setAttribute('class', 'embed');\n            }\n\n            switch (embedElementName) {\n              case 'embed':\n                // only set the type if it is presented\n                if (type) {\n                  embed.setAttribute('type', type);\n                }\n                break;\n            }\n\n            element.appendChild(embed);\n          }\n        }\n      });\n  }\n\n  override ngOnDestroy(): void {\n    super.ngOnDestroy();\n    this._browserObjectUrlRef.destroy();\n  }\n}\n"]}
119
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"embed.component.js","sourceRoot":"","sources":["../../../../../../../packages/dbx-web/src/lib/interaction/iframe/embed.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, viewChild, ElementRef, ChangeDetectionStrategy, computed, inject, SecurityContext, effect, signal, model } from '@angular/core';\nimport { toObservable } from '@angular/core/rxjs-interop';\nimport { combineLatest, throttleTime } from 'rxjs';\nimport { ContentTypeMimeType, Maybe } from '@dereekb/util';\nimport { DomSanitizer, SafeResourceUrl } from '@angular/platform-browser';\nimport { browserObjectUrlRef } from '@dereekb/browser';\nimport { clean, cleanSubscription } from '@dereekb/dbx-core';\n\nexport type DbxEmbedComponentElement = 'embed' | 'img';\n\n@Component({\n  selector: 'dbx-embed',\n  template: `\n    <span #root></span>\n  `,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true\n})\nexport class DbxEmbedComponent {\n  private readonly _browserObjectUrlRef = clean(browserObjectUrlRef());\n\n  readonly sanitizer = inject(DomSanitizer);\n\n  readonly root = viewChild<string, ElementRef<HTMLSpanElement>>('root', { read: ElementRef });\n\n  /**\n   * The element to embed. Can be either embed or img. If not provided, will be determined by the input mimetype.\n   *\n   * If set to 'embed', the embed element will be used.\n   * If set to 'img', the img element will be used.\n   */\n  readonly embedElement = model<Maybe<DbxEmbedComponentElement>>();\n\n  readonly sanitizeUrl = model<Maybe<boolean>>();\n\n  readonly srcUrl = model<Maybe<string | SafeResourceUrl>>();\n  readonly type = model<Maybe<ContentTypeMimeType | string>>();\n\n  /**\n   * The input blob or media source to use.\n   *\n   * If set, the srcUrl will be updated with the browser object URL.\n   */\n  readonly blob = model<Maybe<Blob>>();\n\n  readonly srcUrlFromBlob = signal<Maybe<string>>(undefined);\n  readonly typeFromBlob = signal<Maybe<string>>(undefined);\n\n  readonly blobEffect = effect(\n    () => {\n      const blob = this.blob();\n      this.srcUrlFromBlob.set(this._browserObjectUrlRef.createBrowserUrl(blob));\n      this.typeFromBlob.set(blob?.type);\n    },\n    {\n      allowSignalWrites: true\n    }\n  );\n\n  readonly srcUrlSignal = computed(() => {\n    const srcUrl = this.srcUrl();\n    const srcUrlFromBlob = this.srcUrlFromBlob();\n\n    const baseUrl = srcUrl ?? srcUrlFromBlob;\n\n    let url: Maybe<string | SafeResourceUrl> = baseUrl;\n    const sanitizeUrl = this.sanitizeUrl();\n\n    if (url && typeof url === 'string' && sanitizeUrl) {\n      url = this.sanitizer.bypassSecurityTrustResourceUrl(url);\n    }\n\n    return url;\n  });\n\n  readonly typeSignal = computed(() => {\n    const type = this.type();\n    const typeFromBlob = this.typeFromBlob();\n    return type ?? typeFromBlob;\n  });\n\n  readonly root$ = toObservable(this.root);\n  readonly srcUrl$ = toObservable(this.srcUrlSignal);\n  readonly type$ = toObservable(this.typeSignal);\n  readonly embedElementName$ = toObservable(this.embedElement);\n\n  constructor() {\n    cleanSubscription(\n      combineLatest([this.srcUrl$, this.root$, this.type$, this.embedElementName$])\n        .pipe(throttleTime(100, undefined, { leading: true, trailing: true }))\n        .subscribe(([srcUrl, root, type, forceEmbedElementName]) => {\n          const element = root?.nativeElement;\n\n          if (element) {\n            // remove all embeds from the element\n            element?.childNodes.forEach((x) => element.removeChild(x));\n\n            if (srcUrl) {\n              const isImageType = type?.startsWith('image/');\n              const embedElementName = forceEmbedElementName ?? (isImageType ? 'img' : 'embed');\n\n              // NOTE: We do this because of the following chromium behavior:\n              // https://issues.chromium.org/issues/40508296\n              //\n              // Embed cannot have src change dynamically, so we create a new embed element each time the src changes.\n              //\n              const embed = document.createElement(embedElementName);\n\n              let url: Maybe<string> = undefined;\n\n              if (srcUrl != null && typeof srcUrl !== 'string') {\n                url = this.sanitizer.sanitize(SecurityContext.URL, srcUrl);\n              } else {\n                url = srcUrl;\n              }\n\n              // both embed and img use src\n              embed.setAttribute('src', url ?? '');\n\n              // if the type is an image, add the embed class\n              if (isImageType) {\n                embed.setAttribute('class', 'embed embed-img');\n              } else {\n                embed.setAttribute('class', 'embed');\n              }\n\n              switch (embedElementName) {\n                case 'embed':\n                  // only set the type if it is presented\n                  if (type) {\n                    embed.setAttribute('type', type);\n                  }\n                  break;\n              }\n\n              element.appendChild(embed);\n            }\n          }\n        })\n    );\n  }\n}\n"]}
@@ -1,10 +1,10 @@
1
1
  import { Component, viewChild, ElementRef, ChangeDetectionStrategy, computed, inject, SecurityContext, output, input, model } from '@angular/core';
2
2
  import { toObservable } from '@angular/core/rxjs-interop';
3
3
  import { asyncScheduler, combineLatest, delayWhen, map, Subject, switchMap, timer, startWith } from 'rxjs';
4
- import { AbstractSubscriptionDirective } from '@dereekb/dbx-core';
4
+ import { cleanSubscription, completeOnDestroy } from '@dereekb/dbx-core';
5
5
  import { DomSanitizer } from '@angular/platform-browser';
6
6
  import * as i0 from "@angular/core";
7
- export class DbxIframeComponent extends AbstractSubscriptionDirective {
7
+ export class DbxIframeComponent {
8
8
  sanitizer = inject(DomSanitizer);
9
9
  iframeLocationChanged = output();
10
10
  iframe = viewChild('iframe', { read: ElementRef });
@@ -21,10 +21,9 @@ export class DbxIframeComponent extends AbstractSubscriptionDirective {
21
21
  });
22
22
  iframe$ = toObservable(this.iframe);
23
23
  contentUrl$ = toObservable(this.contentUrl);
24
- retry = new Subject();
24
+ retry = completeOnDestroy(new Subject());
25
25
  constructor() {
26
- super();
27
- this.sub = combineLatest([this.contentUrl$, this.iframe$])
26
+ cleanSubscription(() => combineLatest([this.contentUrl$, this.iframe$])
28
27
  .pipe(
29
28
  // delay retries by 50ms
30
29
  switchMap((x) => this.retry.pipe(startWith(undefined), delayWhen((_, i) => timer(i ? 50 : 0, asyncScheduler)), map(() => x))))
@@ -43,14 +42,10 @@ export class DbxIframeComponent extends AbstractSubscriptionDirective {
43
42
  else {
44
43
  this.retry.next(); // queue up another retry for setting the iframe value
45
44
  }
46
- });
47
- }
48
- ngOnDestroy() {
49
- super.ngOnDestroy();
50
- this.retry.complete();
45
+ }));
51
46
  }
52
47
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxIframeComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
53
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "18.2.13", type: DbxIframeComponent, isStandalone: true, selector: "dbx-iframe", inputs: { scrolling: { classPropertyName: "scrolling", publicName: "scrolling", isSignal: true, isRequired: false, transformFunction: null }, sanitizeUrl: { classPropertyName: "sanitizeUrl", publicName: "sanitizeUrl", isSignal: true, isRequired: false, transformFunction: null }, contentUrl: { classPropertyName: "contentUrl", publicName: "contentUrl", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { iframeLocationChanged: "iframeLocationChanged", contentUrl: "contentUrlChange" }, viewQueries: [{ propertyName: "iframe", first: true, predicate: ["iframe"], descendants: true, read: ElementRef, isSignal: true }], usesInheritance: true, ngImport: i0, template: `
48
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "18.2.13", type: DbxIframeComponent, isStandalone: true, selector: "dbx-iframe", inputs: { scrolling: { classPropertyName: "scrolling", publicName: "scrolling", isSignal: true, isRequired: false, transformFunction: null }, sanitizeUrl: { classPropertyName: "sanitizeUrl", publicName: "sanitizeUrl", isSignal: true, isRequired: false, transformFunction: null }, contentUrl: { classPropertyName: "contentUrl", publicName: "contentUrl", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { iframeLocationChanged: "iframeLocationChanged", contentUrl: "contentUrlChange" }, viewQueries: [{ propertyName: "iframe", first: true, predicate: ["iframe"], descendants: true, read: ElementRef, isSignal: true }], ngImport: i0, template: `
54
49
  <iframe #iframe src="about:blank" frameborder="0" [scrolling]="scrolling()" allow="autoplay"></iframe>
55
50
  `, isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush });
56
51
  }
@@ -65,4 +60,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
65
60
  standalone: true
66
61
  }]
67
62
  }], ctorParameters: () => [] });
68
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWZyYW1lLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC13ZWIvc3JjL2xpYi9pbnRlcmFjdGlvbi9pZnJhbWUvaWZyYW1lLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFNBQVMsRUFBRSxVQUFVLEVBQWEsdUJBQXVCLEVBQUUsUUFBUSxFQUFFLE1BQU0sRUFBRSxlQUFlLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDOUosT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQzFELE9BQU8sRUFBRSxjQUFjLEVBQUUsYUFBYSxFQUFFLFNBQVMsRUFBRSxHQUFHLEVBQUUsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsU0FBUyxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBRTNHLE9BQU8sRUFBRSw2QkFBNkIsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxZQUFZLEVBQW1CLE1BQU0sMkJBQTJCLENBQUM7O0FBVTFFLE1BQU0sT0FBTyxrQkFBbUIsU0FBUSw2QkFBNkI7SUFDMUQsU0FBUyxHQUFHLE1BQU0sQ0FBQyxZQUFZLENBQUMsQ0FBQztJQUVqQyxxQkFBcUIsR0FBRyxNQUFNLEVBQWlDLENBQUM7SUFDaEUsTUFBTSxHQUFHLFNBQVMsQ0FBd0MsUUFBUSxFQUFFLEVBQUUsSUFBSSxFQUFFLFVBQVUsRUFBRSxDQUFDLENBQUM7SUFFMUYsU0FBUyxHQUFHLEtBQUssQ0FBeUQsSUFBSSxFQUFFLEVBQUUsU0FBUyxFQUFFLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsSUFBSSxJQUFJLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLEtBQUssUUFBUSxDQUFDLENBQUMs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QWUsRUFBRSx1QkFBdUIsQ0FBQyxNQUFNO29CQUMvQyxVQUFVLEVBQUUsSUFBSTtpQkFDakIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIHZpZXdDaGlsZCwgRWxlbWVudFJlZiwgT25EZXN0cm95LCBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgY29tcHV0ZWQsIGluamVjdCwgU2VjdXJpdHlDb250ZXh0LCBvdXRwdXQsIGlucHV0LCBtb2RlbCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgdG9PYnNlcnZhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZS9yeGpzLWludGVyb3AnO1xuaW1wb3J0IHsgYXN5bmNTY2hlZHVsZXIsIGNvbWJpbmVMYXRlc3QsIGRlbGF5V2hlbiwgbWFwLCBTdWJqZWN0LCBzd2l0Y2hNYXAsIHRpbWVyLCBzdGFydFdpdGggfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IE1heWJlIH0gZnJvbSAnQGRlcmVla2IvdXRpbCc7XG5pbXBvcnQgeyBBYnN0cmFjdFN1YnNjcmlwdGlvbkRpcmVjdGl2ZSB9IGZyb20gJ0BkZXJlZWtiL2RieC1jb3JlJztcbmltcG9ydCB7IERvbVNhbml0aXplciwgU2FmZVJlc291cmNlVXJsIH0gZnJvbSAnQGFuZ3VsYXIvcGxhdGZvcm0tYnJvd3Nlcic7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2RieC1pZnJhbWUnLFxuICB0ZW1wbGF0ZTogYFxuICAgIDxpZnJhbWUgI2lmcmFtZSBzcmM9XCJhYm91dDpibGFua1wiIGZyYW1lYm9yZGVyPVwiMFwiIFtzY3JvbGxpbmddPVwic2Nyb2xsaW5nKClcIiBhbGxvdz1cImF1dG9wbGF5XCI+PC9pZnJhbWU+XG4gIGAsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICBzdGFuZGFsb25lOiB0cnVlXG59KVxuZXhwb3J0IGNsYXNzIERieElmcmFtZUNvbXBvbmVudCBleHRlbmRzIEFic3RyYWN0U3Vic2NyaXB0aW9uRGlyZWN0aXZlIGltcGxlbWVudHMgT25EZXN0cm95IHtcbiAgcmVhZG9ubHkgc2FuaXRpemVyID0gaW5qZWN0KERvbVNhbml0aXplcik7XG5cbiAgcmVhZG9ubHkgaWZyYW1lTG9jYXRpb25DaGFuZ2VkID0gb3V0cHV0PEVsZW1lbnRSZWY8SFRNTElGcmFtZUVsZW1lbnQ+PigpO1xuICByZWFkb25seSBpZnJhbWUgPSB2aWV3Q2hpbGQ8c3RyaW5nLCBFbGVtZW50UmVmPEhUTUxJRnJhbWVFbGVtZW50Pj4oJ2lmcmFtZScsIHsgcmVhZDogRWxlbWVudFJlZiB9KTtcblxuICByZWFkb25seSBzY3JvbGxpbmcgPSBpbnB1dDwnYXV0bycgfCAnbm8nIHwgJ3llcycsICdhdXRvJyB8ICdubycgfCAneWVzJyB8IGJvb2xlYW4+KCdubycsIHsgdHJhbnNmb3JtOiAoeCkgPT4gKHggPT0gbnVsbCA/ICdubycgOiB0eXBlb2YgeCA9PT0gJ3N0cmluZycgPyB4IDogeCA9PT0gdHJ1ZSA/ICdhdXRvJyA6ICdubycpIH0pO1xuXG4gIHJlYWRvbmx5IHNhbml0aXplVXJsID0gaW5wdXQ8Ym9vbGVhbj4oZmFsc2UpO1xuICByZWFkb25seSBjb250ZW50VXJsID0gbW9kZWw8TWF5YmU8c3RyaW5nIHwgU2FmZVJlc291cmNlVXJsPj4oKTtcblxuICByZWFkb25seSBjb250ZW50VXJsU2lnbmFsID0gY29tcHV0ZWQoKCkgPT4ge1xuICAgIGxldCB1cmw6IE1heWJlPHN0cmluZyB8IFNhZmVSZXNvdXJjZVVybD4gPSB0aGlzLmNvbnRlbnRVcmwoKTtcbiAgICBjb25zdCBzYW5pdGl6ZVVybCA9IHRoaXMuc2FuaXRpemVVcmwoKTtcblxuICAgIGlmICh1cmwgJiYgdHlwZW9mIHVybCA9PT0gJ3N0cmluZycgJiYgc2FuaXRpemVVcmwpIHtcbiAgICAgIHVybCA9IHRoaXMuc2FuaXRpemVyLmJ5cGFzc1NlY3VyaXR5VHJ1c3RSZXNvdXJjZVVybCh1cmwpO1xuICAgIH1cblxuICAgIHJldHVybiB1cmw7XG4gIH0pO1xuXG4gIHJlYWRvbmx5IGlmcmFtZSQgPSB0b09ic2VydmFibGUodGhpcy5pZnJhbWUpO1xuICByZWFkb25seSBjb250ZW50VXJsJCA9IHRvT2JzZXJ2YWJsZSh0aGlzLmNvbnRlbnRVcmwpO1xuXG4gIHJlYWRvbmx5IHJldHJ5ID0gbmV3IFN1YmplY3Q8dm9pZD4oKTtcblxuICBjb25zdHJ1Y3RvcigpIHtcbiAgICBzdXBlcigpO1xuICAgIHRoaXMuc3ViID0gY29tYmluZUxhdGVzdChbdGhpcy5jb250ZW50VXJsJCwgdGhpcy5pZnJhbWUkXSlcbiAgICAgIC5waXBlKFxuICAgICAgICAvLyBkZWxheSByZXRyaWVzIGJ5IDUwbXNcbiAgICAgICAgc3dpdGNoTWFwKCh4KSA9PlxuICAgICAgICAgIHRoaXMucmV0cnkucGlwZShcbiAgICAgICAgICAgIHN0YXJ0V2l0aCh1bmRlZmluZWQpLFxuICAgICAgICAgICAgZGVsYXlXaGVuKChfLCBpKSA9PiB0aW1lcihpID8gNTAgOiAwLCBhc3luY1NjaGVkdWxlcikpLFxuICAgICAgICAgICAgbWFwKCgpID0+IHgpXG4gICAgICAgICAgKVxuICAgICAgICApXG4gICAgICApXG4gICAgICAuc3Vic2NyaWJlKChbeCwgaWZyYW1lXSkgPT4ge1xuICAgICAgICBjb25zdCBjb250ZW50V2luZG93ID0gaWZyYW1lPy5uYXRpdmVFbGVtZW50LmNvbnRlbnRXaW5kb3c7XG5cbiAgICAgICAgaWYgKGNvbnRlbnRXaW5kb3cpIHtcbiAgICAgICAgICBsZXQgdXJsOiBNYXliZTxzdHJpbmc+ID0gdW5kZWZpbmVkO1xuXG4gICAgICAgICAgaWYgKHggIT0gbnVsbCAmJiB0eXBlb2YgeCAhPT0gJ3N0cmluZycpIHtcbiAgICAgICAgICAgIHVybCA9IHRoaXMuc2FuaXRpemVyLnNhbml0aXplKFNlY3VyaXR5Q29udGV4dC5VUkwsIHgpO1xuICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICB1cmwgPSB4O1xuICAgICAgICAgIH1cblxuICAgICAgICAgIGNvbnRlbnRXaW5kb3cubG9jYXRpb24ucmVwbGFjZSh1cmwgPz8gJycpO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIHRoaXMucmV0cnkubmV4dCgpOyAvLyBxdWV1ZSB1cCBhbm90aGVyIHJldHJ5IGZvciBzZXR0aW5nIHRoZSBpZnJhbWUgdmFsdWVcbiAgICAgICAgfVxuICAgICAgfSk7XG4gIH1cblxuICBvdmVycmlkZSBuZ09uRGVzdHJveSgpOiB2b2lkIHtcbiAgICBzdXBlci5uZ09uRGVzdHJveSgpO1xuICAgIHRoaXMucmV0cnkuY29tcGxldGUoKTtcbiAgfVxufVxuIl19
63
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWZyYW1lLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC13ZWIvc3JjL2xpYi9pbnRlcmFjdGlvbi9pZnJhbWUvaWZyYW1lLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFNBQVMsRUFBRSxVQUFVLEVBQUUsdUJBQXVCLEVBQUUsUUFBUSxFQUFFLE1BQU0sRUFBRSxlQUFlLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDbkosT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQzFELE9BQU8sRUFBRSxjQUFjLEVBQUUsYUFBYSxFQUFFLFNBQVMsRUFBRSxHQUFHLEVBQUUsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsU0FBUyxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBRTNHLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxpQkFBaUIsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQ3pFLE9BQU8sRUFBRSxZQUFZLEVBQW1CLE1BQU0sMkJBQTJCLENBQUM7O0FBVTFFLE1BQU0sT0FBTyxrQkFBa0I7SUFDcEIsU0FBUyxHQUFHLE1BQU0sQ0FBQyxZQUFZLENBQUMsQ0FBQztJQUVqQyxxQkFBcUIsR0FBRyxNQUFNLEVBQWlDLENBQUM7SUFDaEUsTUFBTSxHQUFHLFNBQVMsQ0FBd0MsUUFBUSxFQUFFLEVBQUUsSUFBSSxFQUFFLFVBQVUsRUFBRSxDQUFDLENBQUM7SUFFMUYsU0FBUyxHQUFHLEtBQUssQ0FBeUQsSUFBSSxFQUFFLEVBQUUsU0FBUyxFQUFFLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsSUFBSSxJQUFJLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLEtBQUssUUFBUSxDQUFDLENBQUMs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Q29tcG9uZW50LCB2aWV3Q2hpbGQsIEVsZW1lbnRSZWYsIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBjb21wdXRlZCwgaW5qZWN0LCBTZWN1cml0eUNvbnRleHQsIG91dHB1dCwgaW5wdXQsIG1vZGVsIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyB0b09ic2VydmFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlL3J4anMtaW50ZXJvcCc7XG5pbXBvcnQgeyBhc3luY1NjaGVkdWxlciwgY29tYmluZUxhdGVzdCwgZGVsYXlXaGVuLCBtYXAsIFN1YmplY3QsIHN3aXRjaE1hcCwgdGltZXIsIHN0YXJ0V2l0aCB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgTWF5YmUgfSBmcm9tICdAZGVyZWVrYi91dGlsJztcbmltcG9ydCB7IGNsZWFuU3Vic2NyaXB0aW9uLCBjb21wbGV0ZU9uRGVzdHJveSB9IGZyb20gJ0BkZXJlZWtiL2RieC1jb3JlJztcbmltcG9ydCB7IERvbVNhbml0aXplciwgU2FmZVJlc291cmNlVXJsIH0gZnJvbSAnQGFuZ3VsYXIvcGxhdGZvcm0tYnJvd3Nlcic7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2RieC1pZnJhbWUnLFxuICB0ZW1wbGF0ZTogYFxuICAgIDxpZnJhbWUgI2lmcmFtZSBzcmM9XCJhYm91dDpibGFua1wiIGZyYW1lYm9yZGVyPVwiMFwiIFtzY3JvbGxpbmddPVwic2Nyb2xsaW5nKClcIiBhbGxvdz1cImF1dG9wbGF5XCI+PC9pZnJhbWU+XG4gIGAsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICBzdGFuZGFsb25lOiB0cnVlXG59KVxuZXhwb3J0IGNsYXNzIERieElmcmFtZUNvbXBvbmVudCB7XG4gIHJlYWRvbmx5IHNhbml0aXplciA9IGluamVjdChEb21TYW5pdGl6ZXIpO1xuXG4gIHJlYWRvbmx5IGlmcmFtZUxvY2F0aW9uQ2hhbmdlZCA9IG91dHB1dDxFbGVtZW50UmVmPEhUTUxJRnJhbWVFbGVtZW50Pj4oKTtcbiAgcmVhZG9ubHkgaWZyYW1lID0gdmlld0NoaWxkPHN0cmluZywgRWxlbWVudFJlZjxIVE1MSUZyYW1lRWxlbWVudD4+KCdpZnJhbWUnLCB7IHJlYWQ6IEVsZW1lbnRSZWYgfSk7XG5cbiAgcmVhZG9ubHkgc2Nyb2xsaW5nID0gaW5wdXQ8J2F1dG8nIHwgJ25vJyB8ICd5ZXMnLCAnYXV0bycgfCAnbm8nIHwgJ3llcycgfCBib29sZWFuPignbm8nLCB7IHRyYW5zZm9ybTogKHgpID0+ICh4ID09IG51bGwgPyAnbm8nIDogdHlwZW9mIHggPT09ICdzdHJpbmcnID8geCA6IHggPT09IHRydWUgPyAnYXV0bycgOiAnbm8nKSB9KTtcblxuICByZWFkb25seSBzYW5pdGl6ZVVybCA9IGlucHV0PGJvb2xlYW4+KGZhbHNlKTtcbiAgcmVhZG9ubHkgY29udGVudFVybCA9IG1vZGVsPE1heWJlPHN0cmluZyB8IFNhZmVSZXNvdXJjZVVybD4+KCk7XG5cbiAgcmVhZG9ubHkgY29udGVudFVybFNpZ25hbCA9IGNvbXB1dGVkKCgpID0+IHtcbiAgICBsZXQgdXJsOiBNYXliZTxzdHJpbmcgfCBTYWZlUmVzb3VyY2VVcmw+ID0gdGhpcy5jb250ZW50VXJsKCk7XG4gICAgY29uc3Qgc2FuaXRpemVVcmwgPSB0aGlzLnNhbml0aXplVXJsKCk7XG5cbiAgICBpZiAodXJsICYmIHR5cGVvZiB1cmwgPT09ICdzdHJpbmcnICYmIHNhbml0aXplVXJsKSB7XG4gICAgICB1cmwgPSB0aGlzLnNhbml0aXplci5ieXBhc3NTZWN1cml0eVRydXN0UmVzb3VyY2VVcmwodXJsKTtcbiAgICB9XG5cbiAgICByZXR1cm4gdXJsO1xuICB9KTtcblxuICByZWFkb25seSBpZnJhbWUkID0gdG9PYnNlcnZhYmxlKHRoaXMuaWZyYW1lKTtcbiAgcmVhZG9ubHkgY29udGVudFVybCQgPSB0b09ic2VydmFibGUodGhpcy5jb250ZW50VXJsKTtcblxuICByZWFkb25seSByZXRyeSA9IGNvbXBsZXRlT25EZXN0cm95KG5ldyBTdWJqZWN0PHZvaWQ+KCkpO1xuXG4gIGNvbnN0cnVjdG9yKCkge1xuICAgIGNsZWFuU3Vic2NyaXB0aW9uKCgpID0+XG4gICAgICBjb21iaW5lTGF0ZXN0KFt0aGlzLmNvbnRlbnRVcmwkLCB0aGlzLmlmcmFtZSRdKVxuICAgICAgICAucGlwZShcbiAgICAgICAgICAvLyBkZWxheSByZXRyaWVzIGJ5IDUwbXNcbiAgICAgICAgICBzd2l0Y2hNYXAoKHgpID0+XG4gICAgICAgICAgICB0aGlzLnJldHJ5LnBpcGUoXG4gICAgICAgICAgICAgIHN0YXJ0V2l0aCh1bmRlZmluZWQpLFxuICAgICAgICAgICAgICBkZWxheVdoZW4oKF8sIGkpID0+IHRpbWVyKGkgPyA1MCA6IDAsIGFzeW5jU2NoZWR1bGVyKSksXG4gICAgICAgICAgICAgIG1hcCgoKSA9PiB4KVxuICAgICAgICAgICAgKVxuICAgICAgICAgIClcbiAgICAgICAgKVxuICAgICAgICAuc3Vic2NyaWJlKChbeCwgaWZyYW1lXSkgPT4ge1xuICAgICAgICAgIGNvbnN0IGNvbnRlbnRXaW5kb3cgPSBpZnJhbWU/Lm5hdGl2ZUVsZW1lbnQuY29udGVudFdpbmRvdztcblxuICAgICAgICAgIGlmIChjb250ZW50V2luZG93KSB7XG4gICAgICAgICAgICBsZXQgdXJsOiBNYXliZTxzdHJpbmc+ID0gdW5kZWZpbmVkO1xuXG4gICAgICAgICAgICBpZiAoeCAhPSBudWxsICYmIHR5cGVvZiB4ICE9PSAnc3RyaW5nJykge1xuICAgICAgICAgICAgICB1cmwgPSB0aGlzLnNhbml0aXplci5zYW5pdGl6ZShTZWN1cml0eUNvbnRleHQuVVJMLCB4KTtcbiAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgIHVybCA9IHg7XG4gICAgICAgICAgICB9XG5cbiAgICAgICAgICAgIGNvbnRlbnRXaW5kb3cubG9jYXRpb24ucmVwbGFjZSh1cmwgPz8gJycpO1xuICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICB0aGlzLnJldHJ5Lm5leHQoKTsgLy8gcXVldWUgdXAgYW5vdGhlciByZXRyeSBmb3Igc2V0dGluZyB0aGUgaWZyYW1lIHZhbHVlXG4gICAgICAgICAgfVxuICAgICAgICB9KVxuICAgICk7XG4gIH1cbn1cbiJdfQ==
@@ -1,11 +1,12 @@
1
1
  import { Directive, output } from '@angular/core';
2
- import { AbstractSubscriptionDirective } from '@dereekb/dbx-core';
2
+ import { cleanSubscription } from '@dereekb/dbx-core';
3
3
  import * as i0 from "@angular/core";
4
4
  /**
5
5
  * Abstract class for showing and handling a popover ref.
6
6
  */
7
- export class AbstractPopoverRefDirective extends AbstractSubscriptionDirective {
7
+ export class AbstractPopoverRefDirective {
8
8
  _popoverRef;
9
+ _popoverSub = cleanSubscription();
9
10
  showPopover(origin) {
10
11
  if (!this._popoverRef) {
11
12
  this._showPopoverRef(origin);
@@ -14,10 +15,10 @@ export class AbstractPopoverRefDirective extends AbstractSubscriptionDirective {
14
15
  _showPopoverRef(origin) {
15
16
  this._popoverRef = this._makePopoverRef(origin);
16
17
  this._afterOpened(this._popoverRef);
17
- this.sub = this._popoverRef.afterClosed$.subscribe((x) => {
18
+ this._popoverSub.setSub(this._popoverRef.afterClosed$.subscribe((x) => {
18
19
  this._afterClosed(x);
19
20
  this._popoverRef = undefined;
20
- });
21
+ }));
21
22
  }
22
23
  _afterOpened(popoverRef) {
23
24
  // Do nothing. Override in parent type
@@ -25,8 +26,8 @@ export class AbstractPopoverRefDirective extends AbstractSubscriptionDirective {
25
26
  _afterClosed(value) {
26
27
  // Do nothing. Override in parent type
27
28
  }
28
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AbstractPopoverRefDirective, deps: null, target: i0.ɵɵFactoryTarget.Directive });
29
- static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: AbstractPopoverRefDirective, usesInheritance: true, ngImport: i0 });
29
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AbstractPopoverRefDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
30
+ static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: AbstractPopoverRefDirective, ngImport: i0 });
30
31
  }
31
32
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AbstractPopoverRefDirective, decorators: [{
32
33
  type: Directive
@@ -49,4 +50,4 @@ export class AbstractPopoverRefWithEventsDirective extends AbstractPopoverRefDir
49
50
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AbstractPopoverRefWithEventsDirective, decorators: [{
50
51
  type: Directive
51
52
  }] });
52
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWJzdHJhY3QucG9wb3Zlci5yZWYuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LXdlYi9zcmMvbGliL2ludGVyYWN0aW9uL3BvcG92ZXIvYWJzdHJhY3QucG9wb3Zlci5yZWYuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBYSxTQUFTLEVBQWMsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pFLE9BQU8sRUFBRSw2QkFBNkIsRUFBRSxNQUFNLG1CQUFtQixDQUFDOztBQUdsRTs7R0FFRztBQUVILE1BQU0sT0FBZ0IsMkJBQXNELFNBQVEsNkJBQTZCO0lBQ3ZHLFdBQVcsQ0FBc0I7SUFFekMsV0FBVyxDQUFDLE1BQW1CO1FBQzdCLElBQUksQ0FBQyxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7WUFDdEIsSUFBSSxDQUFDLGVBQWUsQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUMvQixDQUFDO0lBQ0gsQ0FBQztJQUVPLGVBQWUsQ0FBQyxNQUFtQjtRQUN6QyxJQUFJLENBQUMsV0FBVyxHQUFHLElBQUksQ0FBQyxlQUFlLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDaEQsSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLENBQUM7UUFDcEMsSUFBSSxDQUFDLEdBQUcsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLFlBQVksQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRTtZQUN2RCxJQUFJLENBQUMsWUFBWSxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQ3JCLElBQUksQ0FBQyxXQUFXLEdBQUcsU0FBUyxDQUFDO1FBQy9CLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUlTLFlBQVksQ0FBQyxVQUE4QjtRQUNuRCxzQ0FBc0M7SUFDeEMsQ0FBQztJQUVTLFlBQVksQ0FBQyxLQUE2QjtRQUNsRCxzQ0FBc0M7SUFDeEMsQ0FBQzt3R0ExQm1CLDJCQUEyQjs0RkFBM0IsMkJBQTJCOzs0RkFBM0IsMkJBQTJCO2tCQURoRCxTQUFTOztBQThCVjs7R0FFRztBQUVILE1BQU0sT0FBZ0IscUNBQWdFLFNBQVEsMkJBQWlDO0lBQ3BILGFBQWEsR0FBRyxNQUFNLEVBQXNCLENBQUM7SUFDN0MsYUFBYSxHQUFHLE1BQU0sRUFBMEIsQ0FBQztJQUV2QyxZQUFZLENBQUMsVUFBOEI7UUFDNUQsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUM7SUFDdEMsQ0FBQztJQUVrQixZQUFZLENBQUMsS0FBNkI7UUFDM0QsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDakMsQ0FBQzt3R0FWbUIscUNBQXFDOzRGQUFyQyxxQ0FBcUM7OzRGQUFyQyxxQ0FBcUM7a0JBRDFELFNBQVMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBPbkRlc3Ryb3ksIERpcmVjdGl2ZSwgRWxlbWVudFJlZiwgb3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBBYnN0cmFjdFN1YnNjcmlwdGlvbkRpcmVjdGl2ZSB9IGZyb20gJ0BkZXJlZWtiL2RieC1jb3JlJztcbmltcG9ydCB7IE5nUG9wb3ZlckNsb3NlRXZlbnQsIE5nUG9wb3ZlclJlZiB9IGZyb20gJ25nLW92ZXJsYXktY29udGFpbmVyJztcblxuLyoqXG4gKiBBYnN0cmFjdCBjbGFzcyBmb3Igc2hvd2luZyBhbmQgaGFuZGxpbmcgYSBwb3BvdmVyIHJlZi5cbiAqL1xuQERpcmVjdGl2ZSgpXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgQWJzdHJhY3RQb3BvdmVyUmVmRGlyZWN0aXZlPFQgPSB1bmtub3duLCBSID0gdW5rbm93bj4gZXh0ZW5kcyBBYnN0cmFjdFN1YnNjcmlwdGlvbkRpcmVjdGl2ZSB7XG4gIHByaXZhdGUgX3BvcG92ZXJSZWY/OiBOZ1BvcG92ZXJSZWY8VCwgUj47XG5cbiAgc2hvd1BvcG92ZXIob3JpZ2luPzogRWxlbWVudFJlZik6IHZvaWQge1xuICAgIGlmICghdGhpcy5fcG9wb3ZlclJlZikge1xuICAgICAgdGhpcy5fc2hvd1BvcG92ZXJSZWYob3JpZ2luKTtcbiAgICB9XG4gIH1cblxuICBwcml2YXRlIF9zaG93UG9wb3ZlclJlZihvcmlnaW4/OiBFbGVtZW50UmVmKTogdm9pZCB7XG4gICAgdGhpcy5fcG9wb3ZlclJlZiA9IHRoaXMuX21ha2VQb3BvdmVyUmVmKG9yaWdpbik7XG4gICAgdGhpcy5fYWZ0ZXJPcGVuZWQodGhpcy5fcG9wb3ZlclJlZik7XG4gICAgdGhpcy5zdWIgPSB0aGlzLl9wb3BvdmVyUmVmLmFmdGVyQ2xvc2VkJC5zdWJzY3JpYmUoKHgpID0+IHtcbiAgICAgIHRoaXMuX2FmdGVyQ2xvc2VkKHgpO1xuICAgICAgdGhpcy5fcG9wb3ZlclJlZiA9IHVuZGVmaW5lZDtcbiAgICB9KTtcbiAgfVxuXG4gIHByb3RlY3RlZCBhYnN0cmFjdCBfbWFrZVBvcG92ZXJSZWYob3JpZ2luPzogRWxlbWVudFJlZik6IE5nUG9wb3ZlclJlZjxULCBSPjtcblxuICBwcm90ZWN0ZWQgX2FmdGVyT3BlbmVkKHBvcG92ZXJSZWY6IE5nUG9wb3ZlclJlZjxULCBSPik6IHZvaWQge1xuICAgIC8vIERvIG5vdGhpbmcuIE92ZXJyaWRlIGluIHBhcmVudCB0eXBlXG4gIH1cblxuICBwcm90ZWN0ZWQgX2FmdGVyQ2xvc2VkKHZhbHVlOiBOZ1BvcG92ZXJDbG9zZUV2ZW50PFI+KTogdm9pZCB7XG4gICAgLy8gRG8gbm90aGluZy4gT3ZlcnJpZGUgaW4gcGFyZW50IHR5cGVcbiAgfVxufVxuXG4vKipcbiAqIHtAbGluayBBYnN0cmFjdFBvcG92ZXJSZWZEaXJlY3RpdmV9IGV4dGVuc2lvbiB0aGF0IGluY2x1ZGVzIG9wZW4vY2xvc2VkIGV2ZW50cy5cbiAqL1xuQERpcmVjdGl2ZSgpXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgQWJzdHJhY3RQb3BvdmVyUmVmV2l0aEV2ZW50c0RpcmVjdGl2ZTxUID0gdW5rbm93biwgUiA9IHVua25vd24+IGV4dGVuZHMgQWJzdHJhY3RQb3BvdmVyUmVmRGlyZWN0aXZlPFQsIFI+IGltcGxlbWVudHMgT25EZXN0cm95IHtcbiAgcmVhZG9ubHkgcG9wb3Zlck9wZW5lZCA9IG91dHB1dDxOZ1BvcG92ZXJSZWY8VCwgUj4+KCk7XG4gIHJlYWRvbmx5IHBvcG92ZXJDbG9zZWQgPSBvdXRwdXQ8TmdQb3BvdmVyQ2xvc2VFdmVudDxSPj4oKTtcblxuICBwcm90ZWN0ZWQgb3ZlcnJpZGUgX2FmdGVyT3BlbmVkKHBvcG92ZXJSZWY6IE5nUG9wb3ZlclJlZjxULCBSPik6IHZvaWQge1xuICAgIHRoaXMucG9wb3Zlck9wZW5lZC5lbWl0KHBvcG92ZXJSZWYpO1xuICB9XG5cbiAgcHJvdGVjdGVkIG92ZXJyaWRlIF9hZnRlckNsb3NlZChldmVudDogTmdQb3BvdmVyQ2xvc2VFdmVudDxSPik6IHZvaWQge1xuICAgIHRoaXMucG9wb3ZlckNsb3NlZC5lbWl0KGV2ZW50KTtcbiAgfVxufVxuIl19
53
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWJzdHJhY3QucG9wb3Zlci5yZWYuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LXdlYi9zcmMvbGliL2ludGVyYWN0aW9uL3BvcG92ZXIvYWJzdHJhY3QucG9wb3Zlci5yZWYuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQWMsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzlELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLG1CQUFtQixDQUFDOztBQUd0RDs7R0FFRztBQUVILE1BQU0sT0FBZ0IsMkJBQTJCO0lBQ3ZDLFdBQVcsQ0FBc0I7SUFFdEIsV0FBVyxHQUFHLGlCQUFpQixFQUFFLENBQUM7SUFFckQsV0FBVyxDQUFDLE1BQW1CO1FBQzdCLElBQUksQ0FBQyxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7WUFDdEIsSUFBSSxDQUFDLGVBQWUsQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUMvQixDQUFDO0lBQ0gsQ0FBQztJQUVPLGVBQWUsQ0FBQyxNQUFtQjtRQUN6QyxJQUFJLENBQUMsV0FBVyxHQUFHLElBQUksQ0FBQyxlQUFlLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDaEQsSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLENBQUM7UUFDcEMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxNQUFNLENBQ3JCLElBQUksQ0FBQyxXQUFZLENBQUMsWUFBWSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFO1lBQzdDLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDckIsSUFBSSxDQUFDLFdBQVcsR0FBRyxTQUFTLENBQUM7UUFDL0IsQ0FBQyxDQUFDLENBQ0gsQ0FBQztJQUNKLENBQUM7SUFJUyxZQUFZLENBQUMsVUFBOEI7UUFDbkQsc0NBQXNDO0lBQ3hDLENBQUM7SUFFUyxZQUFZLENBQUMsS0FBNkI7UUFDbEQsc0NBQXNDO0lBQ3hDLENBQUM7d0dBOUJtQiwyQkFBMkI7NEZBQTNCLDJCQUEyQjs7NEZBQTNCLDJCQUEyQjtrQkFEaEQsU0FBUzs7QUFrQ1Y7O0dBRUc7QUFFSCxNQUFNLE9BQWdCLHFDQUFnRSxTQUFRLDJCQUFpQztJQUNwSCxhQUFhLEdBQUcsTUFBTSxFQUFzQixDQUFDO0lBQzdDLGFBQWEsR0FBRyxNQUFNLEVBQTBCLENBQUM7SUFFdkMsWUFBWSxDQUFDLFVBQThCO1FBQzVELElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDO0lBQ3RDLENBQUM7SUFFa0IsWUFBWSxDQUFDLEtBQTZCO1FBQzNELElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ2pDLENBQUM7d0dBVm1CLHFDQUFxQzs0RkFBckMscUNBQXFDOzs0RkFBckMscUNBQXFDO2tCQUQxRCxTQUFTIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBFbGVtZW50UmVmLCBvdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IGNsZWFuU3Vic2NyaXB0aW9uIH0gZnJvbSAnQGRlcmVla2IvZGJ4LWNvcmUnO1xuaW1wb3J0IHsgTmdQb3BvdmVyQ2xvc2VFdmVudCwgTmdQb3BvdmVyUmVmIH0gZnJvbSAnbmctb3ZlcmxheS1jb250YWluZXInO1xuXG4vKipcbiAqIEFic3RyYWN0IGNsYXNzIGZvciBzaG93aW5nIGFuZCBoYW5kbGluZyBhIHBvcG92ZXIgcmVmLlxuICovXG5ARGlyZWN0aXZlKClcbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBBYnN0cmFjdFBvcG92ZXJSZWZEaXJlY3RpdmU8VCA9IHVua25vd24sIFIgPSB1bmtub3duPiB7XG4gIHByaXZhdGUgX3BvcG92ZXJSZWY/OiBOZ1BvcG92ZXJSZWY8VCwgUj47XG5cbiAgcHJvdGVjdGVkIHJlYWRvbmx5IF9wb3BvdmVyU3ViID0gY2xlYW5TdWJzY3JpcHRpb24oKTtcblxuICBzaG93UG9wb3ZlcihvcmlnaW4/OiBFbGVtZW50UmVmKTogdm9pZCB7XG4gICAgaWYgKCF0aGlzLl9wb3BvdmVyUmVmKSB7XG4gICAgICB0aGlzLl9zaG93UG9wb3ZlclJlZihvcmlnaW4pO1xuICAgIH1cbiAgfVxuXG4gIHByaXZhdGUgX3Nob3dQb3BvdmVyUmVmKG9yaWdpbj86IEVsZW1lbnRSZWYpOiB2b2lkIHtcbiAgICB0aGlzLl9wb3BvdmVyUmVmID0gdGhpcy5fbWFrZVBvcG92ZXJSZWYob3JpZ2luKTtcbiAgICB0aGlzLl9hZnRlck9wZW5lZCh0aGlzLl9wb3BvdmVyUmVmKTtcbiAgICB0aGlzLl9wb3BvdmVyU3ViLnNldFN1YihcbiAgICAgIHRoaXMuX3BvcG92ZXJSZWYhLmFmdGVyQ2xvc2VkJC5zdWJzY3JpYmUoKHgpID0+IHtcbiAgICAgICAgdGhpcy5fYWZ0ZXJDbG9zZWQoeCk7XG4gICAgICAgIHRoaXMuX3BvcG92ZXJSZWYgPSB1bmRlZmluZWQ7XG4gICAgICB9KVxuICAgICk7XG4gIH1cblxuICBwcm90ZWN0ZWQgYWJzdHJhY3QgX21ha2VQb3BvdmVyUmVmKG9yaWdpbj86IEVsZW1lbnRSZWYpOiBOZ1BvcG92ZXJSZWY8VCwgUj47XG5cbiAgcHJvdGVjdGVkIF9hZnRlck9wZW5lZChwb3BvdmVyUmVmOiBOZ1BvcG92ZXJSZWY8VCwgUj4pOiB2b2lkIHtcbiAgICAvLyBEbyBub3RoaW5nLiBPdmVycmlkZSBpbiBwYXJlbnQgdHlwZVxuICB9XG5cbiAgcHJvdGVjdGVkIF9hZnRlckNsb3NlZCh2YWx1ZTogTmdQb3BvdmVyQ2xvc2VFdmVudDxSPik6IHZvaWQge1xuICAgIC8vIERvIG5vdGhpbmcuIE92ZXJyaWRlIGluIHBhcmVudCB0eXBlXG4gIH1cbn1cblxuLyoqXG4gKiB7QGxpbmsgQWJzdHJhY3RQb3BvdmVyUmVmRGlyZWN0aXZlfSBleHRlbnNpb24gdGhhdCBpbmNsdWRlcyBvcGVuL2Nsb3NlZCBldmVudHMuXG4gKi9cbkBEaXJlY3RpdmUoKVxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIEFic3RyYWN0UG9wb3ZlclJlZldpdGhFdmVudHNEaXJlY3RpdmU8VCA9IHVua25vd24sIFIgPSB1bmtub3duPiBleHRlbmRzIEFic3RyYWN0UG9wb3ZlclJlZkRpcmVjdGl2ZTxULCBSPiB7XG4gIHJlYWRvbmx5IHBvcG92ZXJPcGVuZWQgPSBvdXRwdXQ8TmdQb3BvdmVyUmVmPFQsIFI+PigpO1xuICByZWFkb25seSBwb3BvdmVyQ2xvc2VkID0gb3V0cHV0PE5nUG9wb3ZlckNsb3NlRXZlbnQ8Uj4+KCk7XG5cbiAgcHJvdGVjdGVkIG92ZXJyaWRlIF9hZnRlck9wZW5lZChwb3BvdmVyUmVmOiBOZ1BvcG92ZXJSZWY8VCwgUj4pOiB2b2lkIHtcbiAgICB0aGlzLnBvcG92ZXJPcGVuZWQuZW1pdChwb3BvdmVyUmVmKTtcbiAgfVxuXG4gIHByb3RlY3RlZCBvdmVycmlkZSBfYWZ0ZXJDbG9zZWQoZXZlbnQ6IE5nUG9wb3ZlckNsb3NlRXZlbnQ8Uj4pOiB2b2lkIHtcbiAgICB0aGlzLnBvcG92ZXJDbG9zZWQuZW1pdChldmVudCk7XG4gIH1cbn1cbiJdfQ==
@@ -39,4 +39,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
39
39
  standalone: true
40
40
  }]
41
41
  }], ctorParameters: () => [] });
42
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9wb3Zlci5hY3Rpb24uZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LXdlYi9zcmMvbGliL2ludGVyYWN0aW9uL3BvcG92ZXIvcG9wb3Zlci5hY3Rpb24uZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxLQUFLLEVBQWMsR0FBRyxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQzlDLE9BQU8sRUFBRSxTQUFTLEVBQXFCLFVBQVUsRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXhGLE9BQU8sRUFBRSxxQ0FBcUMsRUFBRSxNQUFNLG1CQUFtQixDQUFDOztBQVUxRTs7R0FFRztBQU1ILE1BQU0sT0FBTyx5QkFBdUMsU0FBUSxxQ0FBd0M7SUFDekYsVUFBVSxHQUFHLE1BQU0sQ0FBQyxVQUFVLENBQUMsQ0FBQztJQUVoQyxnQkFBZ0IsR0FBRyxLQUFLLENBQUMsUUFBUSxFQUErQixDQUFDO0lBQ2pFLDBCQUEwQixHQUFHLEtBQUssRUFBNkIsQ0FBQztJQUNoRSx1QkFBdUIsR0FBRyxLQUFLLEVBQTBCLENBQUM7SUFFbkU7UUFDRSxLQUFLLEVBQUUsQ0FBQztRQUNSLElBQUksQ0FBQyxlQUFlLENBQUM7WUFDbkIsZ0JBQWdCLEVBQUUsSUFBSSxDQUFDLDBCQUEwQjtZQUNqRCxhQUFhLEVBQUUsSUFBSSxDQUFDLHVCQUF1QjtTQUM1QyxDQUFDLENBQUM7UUFDSCxJQUFJLENBQUMsc0JBQXNCLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLG1CQUFtQixFQUFFLENBQUMsQ0FBQztJQUNoRSxDQUFDO0lBRVMsbUJBQW1CO1FBQzNCLE9BQU8sSUFBSSxDQUFDLGVBQWUsRUFBRSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQzdDLEtBQUssRUFBRSxFQUNQLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUNuQixDQUFDO0lBQ0osQ0FBQztJQUVTLGVBQWU7UUFDdkIsTUFBTSxNQUFNLEdBQUcsSUFBSSxDQUFDLFVBQVUsQ0FBQztRQUMvQixNQUFNLEVBQUUsR0FBRyxJQUFJLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQztRQUVuQyxPQUFPLEVBQUUsQ0FBQztZQUNSLE1BQU07U0FDUCxDQUFDLENBQUM7SUFDTCxDQUFDO3dHQTlCVSx5QkFBeUI7NEZBQXpCLHlCQUF5Qjs7NEZBQXpCLHlCQUF5QjtrQkFMckMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsa0JBQWtCO29CQUM1QixRQUFRLEVBQUUsb0JBQW9CO29CQUM5QixVQUFVLEVBQUUsSUFBSTtpQkFDakIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBmaXJzdCwgT2JzZXJ2YWJsZSwgbWFwIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBEaXJlY3RpdmUsIE9uSW5pdCwgT25EZXN0cm95LCBFbGVtZW50UmVmLCBpbmplY3QsIGlucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBOZ1BvcG92ZXJSZWYgfSBmcm9tICduZy1vdmVybGF5LWNvbnRhaW5lcic7XG5pbXBvcnQgeyBBYnN0cmFjdERieEFjdGlvblZhbHVlR2V0dGVyRGlyZWN0aXZlIH0gZnJvbSAnQGRlcmVla2IvZGJ4LWNvcmUnO1xuaW1wb3J0IHsgSXNFcXVhbEZ1bmN0aW9uLCBJc01vZGlmaWVkRnVuY3Rpb24gfSBmcm9tICdAZGVyZWVrYi9yeGpzJztcbmltcG9ydCB7IHR5cGUgTWF5YmUgfSBmcm9tICdAZGVyZWVrYi91dGlsJztcblxuZXhwb3J0IGludGVyZmFjZSBEYnhBY3Rpb25Qb3BvdmVyRnVuY3Rpb25QYXJhbXMge1xuICByZWFkb25seSBvcmlnaW46IEVsZW1lbnRSZWY7XG59XG5cbmV4cG9ydCB0eXBlIERieEFjdGlvblBvcG92ZXJGdW5jdGlvbjxUID0gdW5rbm93bj4gPSAocGFyYW1zOiBEYnhBY3Rpb25Qb3BvdmVyRnVuY3Rpb25QYXJhbXMpID0+IE5nUG9wb3ZlclJlZjx1bmtub3duLCBNYXliZTxUPj47XG5cbi8qKlxuICogQWN0aW9uIGRpcmVjdGl2ZSB0aGF0IGlzIHVzZWQgdG8gdHJpZ2dlci9kaXNwbGF5IGEgcG9wb3ZlciwgdGhlbiB3YXRjaGVzIHRoYXQgcG9wb3ZlciBmb3IgYSB2YWx1ZS5cbiAqL1xuQERpcmVjdGl2ZSh7XG4gIGV4cG9ydEFzOiAnZGJ4QWN0aW9uUG9wb3ZlcicsXG4gIHNlbGVjdG9yOiAnW2RieEFjdGlvblBvcG92ZXJdJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZVxufSlcbmV4cG9ydCBjbGFzcyBEYnhBY3Rpb25Qb3BvdmVyRGlyZWN0aXZlPFQgPSB1bmtub3duPiBleHRlbmRzIEFic3RyYWN0RGJ4QWN0aW9uVmFsdWVHZXR0ZXJEaXJlY3RpdmU8VD4gaW1wbGVtZW50cyBPbkluaXQsIE9uRGVzdHJveSB7XG4gIHJlYWRvbmx5IGVsZW1lbnRSZWYgPSBpbmplY3QoRWxlbWVudFJlZik7XG5cbiAgcmVhZG9ubHkgZGJ4QWN0aW9uUG9wb3ZlciA9IGlucHV0LnJlcXVpcmVkPERieEFjdGlvblBvcG92ZXJGdW5jdGlvbjxUPj4oKTtcbiAgcmVhZG9ubHkgZGJ4QWN0aW9uUG9wb3ZlcklzTW9kaWZpZWQgPSBpbnB1dDxNYXliZTxJc01vZGlmaWVkRnVuY3Rpb24+PigpO1xuICByZWFkb25seSBkYnhBY3Rpb25Qb3BvdmVySXNFcXVhbCA9IGlucHV0PE1heWJlPElzRXF1YWxGdW5jdGlvbj4+KCk7XG5cbiAgY29uc3RydWN0b3IoKSB7XG4gICAgc3VwZXIoKTtcbiAgICB0aGlzLmNvbmZpZ3VyZUlucHV0cyh7XG4gICAgICBpc01vZGlmaWVkU2lnbmFsOiB0aGlzLmRieEFjdGlvblBvcG92ZXJJc01vZGlmaWVkLFxuICAgICAgaXNFcXVhbFNpZ25hbDogdGhpcy5kYnhBY3Rpb25Qb3BvdmVySXNFcXVhbFxuICAgIH0pO1xuICAgIHRoaXMuc2V0VmFsdWVHZXR0ZXJGdW5jdGlvbigoKSA9PiB0aGlzLl9nZXREYXRhRnJvbVBvcG92ZXIoKSk7XG4gIH1cblxuICBwcm90ZWN0ZWQgX2dldERhdGFGcm9tUG9wb3ZlcigpOiBPYnNlcnZhYmxlPE1heWJlPFQ+PiB7XG4gICAgcmV0dXJuIHRoaXMuX21ha2VQb3BvdmVyUmVmKCkuYWZ0ZXJDbG9zZWQkLnBpcGUoXG4gICAgICBmaXJzdCgpLFxuICAgICAgbWFwKCh4KSA9PiB4LmRhdGEpXG4gICAgKTtcbiAgfVxuXG4gIHByb3RlY3RlZCBfbWFrZVBvcG92ZXJSZWYoKTogTmdQb3BvdmVyUmVmPHVua25vd24sIE1heWJlPFQ+PiB7XG4gICAgY29uc3Qgb3JpZ2luID0gdGhpcy5lbGVtZW50UmVmO1xuICAgIGNvbnN0IGZuID0gdGhpcy5kYnhBY3Rpb25Qb3BvdmVyKCk7XG5cbiAgICByZXR1cm4gZm4oe1xuICAgICAgb3JpZ2luXG4gICAgfSk7XG4gIH1cbn1cbiJdfQ==
42
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9wb3Zlci5hY3Rpb24uZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LXdlYi9zcmMvbGliL2ludGVyYWN0aW9uL3BvcG92ZXIvcG9wb3Zlci5hY3Rpb24uZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxLQUFLLEVBQWMsR0FBRyxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQzlDLE9BQU8sRUFBRSxTQUFTLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFckUsT0FBTyxFQUFFLHFDQUFxQyxFQUFFLE1BQU0sbUJBQW1CLENBQUM7O0FBVTFFOztHQUVHO0FBTUgsTUFBTSxPQUFPLHlCQUF1QyxTQUFRLHFDQUF3QztJQUN6RixVQUFVLEdBQUcsTUFBTSxDQUFDLFVBQVUsQ0FBQyxDQUFDO0lBRWhDLGdCQUFnQixHQUFHLEtBQUssQ0FBQyxRQUFRLEVBQStCLENBQUM7SUFDakUsMEJBQTBCLEdBQUcsS0FBSyxFQUE2QixDQUFDO0lBQ2hFLHVCQUF1QixHQUFHLEtBQUssRUFBMEIsQ0FBQztJQUVuRTtRQUNFLEtBQUssRUFBRSxDQUFDO1FBQ1IsSUFBSSxDQUFDLGVBQWUsQ0FBQztZQUNuQixnQkFBZ0IsRUFBRSxJQUFJLENBQUMsMEJBQTBCO1lBQ2pELGFBQWEsRUFBRSxJQUFJLENBQUMsdUJBQXVCO1NBQzVDLENBQUMsQ0FBQztRQUNILElBQUksQ0FBQyxzQkFBc0IsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsbUJBQW1CLEVBQUUsQ0FBQyxDQUFDO0lBQ2hFLENBQUM7SUFFUyxtQkFBbUI7UUFDM0IsT0FBTyxJQUFJLENBQUMsZUFBZSxFQUFFLENBQUMsWUFBWSxDQUFDLElBQUksQ0FDN0MsS0FBSyxFQUFFLEVBQ1AsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQ25CLENBQUM7SUFDSixDQUFDO0lBRVMsZUFBZTtRQUN2QixNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDO1FBQy9CLE1BQU0sRUFBRSxHQUFHLElBQUksQ0FBQyxnQkFBZ0IsRUFBRSxDQUFDO1FBRW5DLE9BQU8sRUFBRSxDQUFDO1lBQ1IsTUFBTTtTQUNQLENBQUMsQ0FBQztJQUNMLENBQUM7d0dBOUJVLHlCQUF5Qjs0RkFBekIseUJBQXlCOzs0RkFBekIseUJBQXlCO2tCQUxyQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxrQkFBa0I7b0JBQzVCLFFBQVEsRUFBRSxvQkFBb0I7b0JBQzlCLFVBQVUsRUFBRSxJQUFJO2lCQUNqQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGZpcnN0LCBPYnNlcnZhYmxlLCBtYXAgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IERpcmVjdGl2ZSwgRWxlbWVudFJlZiwgaW5qZWN0LCBpbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTmdQb3BvdmVyUmVmIH0gZnJvbSAnbmctb3ZlcmxheS1jb250YWluZXInO1xuaW1wb3J0IHsgQWJzdHJhY3REYnhBY3Rpb25WYWx1ZUdldHRlckRpcmVjdGl2ZSB9IGZyb20gJ0BkZXJlZWtiL2RieC1jb3JlJztcbmltcG9ydCB7IElzRXF1YWxGdW5jdGlvbiwgSXNNb2RpZmllZEZ1bmN0aW9uIH0gZnJvbSAnQGRlcmVla2Ivcnhqcyc7XG5pbXBvcnQgeyB0eXBlIE1heWJlIH0gZnJvbSAnQGRlcmVla2IvdXRpbCc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgRGJ4QWN0aW9uUG9wb3ZlckZ1bmN0aW9uUGFyYW1zIHtcbiAgcmVhZG9ubHkgb3JpZ2luOiBFbGVtZW50UmVmO1xufVxuXG5leHBvcnQgdHlwZSBEYnhBY3Rpb25Qb3BvdmVyRnVuY3Rpb248VCA9IHVua25vd24+ID0gKHBhcmFtczogRGJ4QWN0aW9uUG9wb3ZlckZ1bmN0aW9uUGFyYW1zKSA9PiBOZ1BvcG92ZXJSZWY8dW5rbm93biwgTWF5YmU8VD4+O1xuXG4vKipcbiAqIEFjdGlvbiBkaXJlY3RpdmUgdGhhdCBpcyB1c2VkIHRvIHRyaWdnZXIvZGlzcGxheSBhIHBvcG92ZXIsIHRoZW4gd2F0Y2hlcyB0aGF0IHBvcG92ZXIgZm9yIGEgdmFsdWUuXG4gKi9cbkBEaXJlY3RpdmUoe1xuICBleHBvcnRBczogJ2RieEFjdGlvblBvcG92ZXInLFxuICBzZWxlY3RvcjogJ1tkYnhBY3Rpb25Qb3BvdmVyXScsXG4gIHN0YW5kYWxvbmU6IHRydWVcbn0pXG5leHBvcnQgY2xhc3MgRGJ4QWN0aW9uUG9wb3ZlckRpcmVjdGl2ZTxUID0gdW5rbm93bj4gZXh0ZW5kcyBBYnN0cmFjdERieEFjdGlvblZhbHVlR2V0dGVyRGlyZWN0aXZlPFQ+IHtcbiAgcmVhZG9ubHkgZWxlbWVudFJlZiA9IGluamVjdChFbGVtZW50UmVmKTtcblxuICByZWFkb25seSBkYnhBY3Rpb25Qb3BvdmVyID0gaW5wdXQucmVxdWlyZWQ8RGJ4QWN0aW9uUG9wb3ZlckZ1bmN0aW9uPFQ+PigpO1xuICByZWFkb25seSBkYnhBY3Rpb25Qb3BvdmVySXNNb2RpZmllZCA9IGlucHV0PE1heWJlPElzTW9kaWZpZWRGdW5jdGlvbj4+KCk7XG4gIHJlYWRvbmx5IGRieEFjdGlvblBvcG92ZXJJc0VxdWFsID0gaW5wdXQ8TWF5YmU8SXNFcXVhbEZ1bmN0aW9uPj4oKTtcblxuICBjb25zdHJ1Y3RvcigpIHtcbiAgICBzdXBlcigpO1xuICAgIHRoaXMuY29uZmlndXJlSW5wdXRzKHtcbiAgICAgIGlzTW9kaWZpZWRTaWduYWw6IHRoaXMuZGJ4QWN0aW9uUG9wb3ZlcklzTW9kaWZpZWQsXG4gICAgICBpc0VxdWFsU2lnbmFsOiB0aGlzLmRieEFjdGlvblBvcG92ZXJJc0VxdWFsXG4gICAgfSk7XG4gICAgdGhpcy5zZXRWYWx1ZUdldHRlckZ1bmN0aW9uKCgpID0+IHRoaXMuX2dldERhdGFGcm9tUG9wb3ZlcigpKTtcbiAgfVxuXG4gIHByb3RlY3RlZCBfZ2V0RGF0YUZyb21Qb3BvdmVyKCk6IE9ic2VydmFibGU8TWF5YmU8VD4+IHtcbiAgICByZXR1cm4gdGhpcy5fbWFrZVBvcG92ZXJSZWYoKS5hZnRlckNsb3NlZCQucGlwZShcbiAgICAgIGZpcnN0KCksXG4gICAgICBtYXAoKHgpID0+IHguZGF0YSlcbiAgICApO1xuICB9XG5cbiAgcHJvdGVjdGVkIF9tYWtlUG9wb3ZlclJlZigpOiBOZ1BvcG92ZXJSZWY8dW5rbm93biwgTWF5YmU8VD4+IHtcbiAgICBjb25zdCBvcmlnaW4gPSB0aGlzLmVsZW1lbnRSZWY7XG4gICAgY29uc3QgZm4gPSB0aGlzLmRieEFjdGlvblBvcG92ZXIoKTtcblxuICAgIHJldHVybiBmbih7XG4gICAgICBvcmlnaW5cbiAgICB9KTtcbiAgfVxufVxuIl19
@@ -81,14 +81,12 @@ export class DbxPopoverComponent extends AbstractTransitionWatcherDirective {
81
81
  return this._triggerCloseKeys;
82
82
  }
83
83
  ngOnInit() {
84
- super.ngOnInit();
85
84
  if (this.config.closeOnEscape) {
86
85
  this._triggerCloseKeys = ['Escape'];
87
86
  }
88
87
  }
89
88
  ngOnDestroy() {
90
89
  this.lockSet.destroyOnNextUnlock(() => {
91
- super.ngOnDestroy();
92
90
  this._closing.complete();
93
91
  });
94
92
  }
@@ -166,4 +164,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
166
164
  changeDetection: ChangeDetectionStrategy.OnPush
167
165
  }]
168
166
  }], ctorParameters: () => [] });
169
- //# 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, Type, OnInit, OnDestroy, ElementRef, inject, ChangeDetectionStrategy } from '@angular/core';\nimport { NgOverlayContainerConfiguration, NgPopoverCloseType, NgPopoverRef } from 'ng-overlay-container';\nimport { AbstractTransitionWatcherDirective, DbxInjectionComponent, 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';\nimport { DbxPopoverCoordinatorComponent } from './popover.coordinator.component';\nimport { DbxWindowKeyDownListenerDirective } from '../../keypress';\nimport { DbxStyleDirective } from '../../layout/style/style.directive';\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  readonly key: DbxPopoverKey;\n  /**\n   * Origin element to position on.\n   */\n  readonly origin: ElementRef;\n  /**\n   * Whether or not to close if a transition occurs.\n   */\n  readonly closeOnTransition?: boolean;\n  /**\n   * Whether or not to dismiss when the escape button is pressed.\n   *\n   * False by default.\n   */\n  readonly closeOnEscape?: boolean;\n  /**\n   * Component to inject into the popover.\n   */\n  readonly componentClass: Type<T>;\n  /**\n   * Panel classes to add to the popover.\n   */\n  readonly panelClass?: Maybe<SpaceSeparatedCssClasses>;\n  /**\n   * Data available to the popover.\n   */\n  readonly data?: Maybe<I>;\n  /**\n   * Optional function to initialize the popover component.\n   *\n   * @param component\n   * @param controller\n   */\n  readonly 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  imports: [DbxPopoverCoordinatorComponent, DbxWindowKeyDownListenerDirective, DbxStyleDirective, DbxInjectionComponent],\n  standalone: true,\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class DbxPopoverComponent<O = unknown, I = unknown, T = unknown> extends AbstractTransitionWatcherDirective implements DbxPopoverController<O, I>, OnInit, OnDestroy {\n  private readonly popoverRef = inject(NgPopoverRef<FullDbxPopoverComponentConfig<O, I, T>, O>);\n  private readonly compactContextState = inject(CompactContextStore);\n\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\n  readonly closing$ = this.isClosing$.pipe(filter((x) => x));\n\n  getClosingValueFn?: (value: Maybe<I>, closeType: NgPopoverCloseType) => PromiseOrValue<O | undefined>;\n\n  constructor() {\n    super();\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 = (this.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, Type, OnInit, OnDestroy, ElementRef, inject, ChangeDetectionStrategy } from '@angular/core';\nimport { NgOverlayContainerConfiguration, NgPopoverCloseType, NgPopoverRef } from 'ng-overlay-container';\nimport { AbstractTransitionWatcherDirective, DbxInjectionComponent, 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';\nimport { DbxPopoverCoordinatorComponent } from './popover.coordinator.component';\nimport { DbxWindowKeyDownListenerDirective } from '../../keypress';\nimport { DbxStyleDirective } from '../../layout/style/style.directive';\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  readonly key: DbxPopoverKey;\n  /**\n   * Origin element to position on.\n   */\n  readonly origin: ElementRef;\n  /**\n   * Whether or not to close if a transition occurs.\n   */\n  readonly closeOnTransition?: boolean;\n  /**\n   * Whether or not to dismiss when the escape button is pressed.\n   *\n   * False by default.\n   */\n  readonly closeOnEscape?: boolean;\n  /**\n   * Component to inject into the popover.\n   */\n  readonly componentClass: Type<T>;\n  /**\n   * Panel classes to add to the popover.\n   */\n  readonly panelClass?: Maybe<SpaceSeparatedCssClasses>;\n  /**\n   * Data available to the popover.\n   */\n  readonly data?: Maybe<I>;\n  /**\n   * Optional function to initialize the popover component.\n   *\n   * @param component\n   * @param controller\n   */\n  readonly 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  imports: [DbxPopoverCoordinatorComponent, DbxWindowKeyDownListenerDirective, DbxStyleDirective, DbxInjectionComponent],\n  standalone: true,\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class DbxPopoverComponent<O = unknown, I = unknown, T = unknown> extends AbstractTransitionWatcherDirective implements DbxPopoverController<O, I>, OnInit, OnDestroy {\n  private readonly popoverRef = inject(NgPopoverRef<FullDbxPopoverComponentConfig<O, I, T>, O>);\n  private readonly compactContextState = inject(CompactContextStore);\n\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\n  readonly closing$ = this.isClosing$.pipe(filter((x) => x));\n\n  getClosingValueFn?: (value: Maybe<I>, closeType: NgPopoverCloseType) => PromiseOrValue<O | undefined>;\n\n  constructor() {\n    super();\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 = (this.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  ngOnInit(): void {\n    if (this.config.closeOnEscape) {\n      this._triggerCloseKeys = ['Escape'];\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.lockSet.destroyOnNextUnlock(() => {\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"]}