@dereekb/dbx-web 12.6.16 → 12.6.18

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -4,9 +4,10 @@ import { asObservable, distinctUntilHasDifferentValues } from '@dereekb/rxjs';
4
4
  import { map, of, shareReplay, switchMap } from 'rxjs';
5
5
  import { DbxHelpWidgetService } from './help.widget.service';
6
6
  import { DbxHelpViewListEntryComponent } from './help.view.list.entry.component';
7
- import { asArray } from '@dereekb/util';
7
+ import { asArray, sortByNumberFunction } from '@dereekb/util';
8
8
  import { MatAccordion } from '@angular/material/expansion';
9
9
  import { DbxListEmptyContentComponent } from '../../layout/list/list.content.empty.component';
10
+ import { DbxInjectionComponent } from '@dereekb/dbx-core';
10
11
  import * as i0 from "@angular/core";
11
12
  export class DbxHelpViewListComponent {
12
13
  helpWidgetService = inject(DbxHelpWidgetService);
@@ -14,13 +15,34 @@ export class DbxHelpViewListComponent {
14
15
  * Whether the accordion should allow multiple expanded panels.
15
16
  */
16
17
  multi = input(true);
18
+ /**
19
+ * Whether or not to show the empty list content.
20
+ */
21
+ allowEmptyListContent = input(true);
22
+ /**
23
+ * Optional footer component config to inject after the list.
24
+ *
25
+ * If set null, then will not show any footer.
26
+ */
27
+ helpListFooterComponentConfig = input(undefined);
17
28
  helpContextStrings = input.required();
18
- helpContextStrings$ = toObservable(this.helpContextStrings).pipe(switchMap((x) => asObservable(x) ?? of([])), map(asArray), distinctUntilHasDifferentValues(), shareReplay(1));
29
+ helpContextStrings$ = toObservable(this.helpContextStrings).pipe(switchMap((x) => asObservable(x) ?? of([])), map(asArray), distinctUntilHasDifferentValues(), map((x) => {
30
+ const sortPriorityMap = this.helpWidgetService.getSortPriorityMap();
31
+ const sorted = [...x].sort(sortByNumberFunction((x) => sortPriorityMap.get(x) ?? -2));
32
+ return sorted;
33
+ }), shareReplay(1));
19
34
  helpContextStringsSignal = toSignal(this.helpContextStrings$, { initialValue: [] });
20
35
  helpWidgetEntriesSignal = computed(() => this.helpWidgetService.getHelpWidgetEntriesForHelpContextStrings(this.helpContextStringsSignal()));
21
36
  hasNoHelpWidgetEntriesSignal = computed(() => !this.helpWidgetEntriesSignal()?.length);
37
+ helpListFooterComponentConfigSignal = computed(() => {
38
+ let config = this.helpListFooterComponentConfig();
39
+ if (config !== null) {
40
+ config = this.helpWidgetService.getHelpListFooterComponentConfig();
41
+ }
42
+ return config;
43
+ });
22
44
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxHelpViewListComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
23
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: DbxHelpViewListComponent, isStandalone: true, selector: "dbx-help-view-list", inputs: { multi: { classPropertyName: "multi", publicName: "multi", isSignal: true, isRequired: false, transformFunction: null }, helpContextStrings: { classPropertyName: "helpContextStrings", publicName: "helpContextStrings", isSignal: true, isRequired: true, transformFunction: null } }, host: { classAttribute: "dbx-help-view-list dbx-block" }, ngImport: i0, template: `
45
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: DbxHelpViewListComponent, isStandalone: true, selector: "dbx-help-view-list", inputs: { multi: { classPropertyName: "multi", publicName: "multi", isSignal: true, isRequired: false, transformFunction: null }, allowEmptyListContent: { classPropertyName: "allowEmptyListContent", publicName: "allowEmptyListContent", isSignal: true, isRequired: false, transformFunction: null }, helpListFooterComponentConfig: { classPropertyName: "helpListFooterComponentConfig", publicName: "helpListFooterComponentConfig", isSignal: true, isRequired: false, transformFunction: null }, helpContextStrings: { classPropertyName: "helpContextStrings", publicName: "helpContextStrings", isSignal: true, isRequired: true, transformFunction: null } }, host: { classAttribute: "dbx-help-view-list dbx-block" }, ngImport: i0, template: `
24
46
  <mat-accordion [multi]="multi()">
25
47
  @for (widgetEntry of helpWidgetEntriesSignal(); track widgetEntry.helpContextString) {
26
48
  <dbx-help-view-list-entry [helpWidgetEntry]="widgetEntry"></dbx-help-view-list-entry>
@@ -31,7 +53,10 @@ export class DbxHelpViewListComponent {
31
53
  <ng-content select="[empty]"></ng-content>
32
54
  </dbx-list-empty-content>
33
55
  }
34
- `, isInline: true, dependencies: [{ kind: "directive", type: MatAccordion, selector: "mat-accordion", inputs: ["hideToggle", "displayMode", "togglePosition"], exportAs: ["matAccordion"] }, { kind: "component", type: DbxHelpViewListEntryComponent, selector: "dbx-help-view-list-entry", inputs: ["helpWidgetEntry"] }, { kind: "component", type: DbxListEmptyContentComponent, selector: "dbx-list-empty-content" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
56
+ <div class="dbx-help-view-list-footer">
57
+ <dbx-injection [config]="helpListFooterComponentConfigSignal()"></dbx-injection>
58
+ </div>
59
+ `, isInline: true, dependencies: [{ kind: "directive", type: MatAccordion, selector: "mat-accordion", inputs: ["hideToggle", "displayMode", "togglePosition"], exportAs: ["matAccordion"] }, { kind: "component", type: DbxHelpViewListEntryComponent, selector: "dbx-help-view-list-entry", inputs: ["helpWidgetEntry"] }, { kind: "component", type: DbxListEmptyContentComponent, selector: "dbx-list-empty-content" }, { kind: "component", type: DbxInjectionComponent, selector: "dbx-injection, [dbxInjection], [dbx-injection]", inputs: ["config", "template"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
35
60
  }
36
61
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxHelpViewListComponent, decorators: [{
37
62
  type: Component,
@@ -48,13 +73,16 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
48
73
  <ng-content select="[empty]"></ng-content>
49
74
  </dbx-list-empty-content>
50
75
  }
76
+ <div class="dbx-help-view-list-footer">
77
+ <dbx-injection [config]="helpListFooterComponentConfigSignal()"></dbx-injection>
78
+ </div>
51
79
  `,
52
80
  host: {
53
81
  class: 'dbx-help-view-list dbx-block'
54
82
  },
55
- imports: [MatAccordion, DbxHelpViewListEntryComponent, DbxListEmptyContentComponent],
83
+ imports: [MatAccordion, DbxHelpViewListEntryComponent, DbxListEmptyContentComponent, DbxInjectionComponent],
56
84
  standalone: true,
57
85
  changeDetection: ChangeDetectionStrategy.OnPush
58
86
  }]
59
87
  }] });
60
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVscC52aWV3Lmxpc3QuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LXdlYi9zcmMvbGliL2V4dGVuc2lvbi9oZWxwL2hlbHAudmlldy5saXN0LmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLFFBQVEsRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTVGLE9BQU8sRUFBRSxZQUFZLEVBQUUsUUFBUSxFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFDcEUsT0FBTyxFQUFFLFlBQVksRUFBRSwrQkFBK0IsRUFBcUIsTUFBTSxlQUFlLENBQUM7QUFDakcsT0FBTyxFQUFFLEdBQUcsRUFBYyxFQUFFLEVBQUUsV0FBVyxFQUFFLFNBQVMsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUNuRSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUM3RCxPQUFPLEVBQUUsNkJBQTZCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUNqRixPQUFPLEVBQWdCLE9BQU8sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN0RCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFDM0QsT0FBTyxFQUFFLDRCQUE0QixFQUFFLE1BQU0sZ0RBQWdELENBQUM7O0FBdUI5RixNQUFNLE9BQU8sd0JBQXdCO0lBQzFCLGlCQUFpQixHQUFHLE1BQU0sQ0FBQyxvQkFBb0IsQ0FBQyxDQUFDO0lBRTFEOztPQUVHO0lBQ00sS0FBSyxHQUFHLEtBQUssQ0FBVSxJQUFJLENBQUMsQ0FBQztJQUU3QixrQkFBa0IsR0FBRyxLQUFLLENBQUMsUUFBUSxFQUF5RCxDQUFDO0lBQzdGLG1CQUFtQixHQUF1QyxZQUFZLENBQUMsSUFBSSxDQUFDLGtCQUFrQixDQUFDLENBQUMsSUFBSSxDQUMzRyxTQUFTLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUMsSUFBSSxFQUFFLENBQUMsRUFBRSxDQUFDLENBQUMsRUFDM0MsR0FBRyxDQUFDLE9BQU8sQ0FBQyxFQUNaLCtCQUErQixFQUFFLEVBQ2pDLFdBQVcsQ0FBQyxDQUFDLENBQUMsQ0FDZixDQUFDO0lBRU8sd0JBQXdCLEdBQUcsUUFBUSxDQUFDLElBQUksQ0FBQyxtQkFBbUIsRUFBRSxFQUFFLFlBQVksRUFBRSxFQUFFLEVBQUUsQ0FBQyxDQUFDO0lBQ3BGLHVCQUF1QixHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsaUJBQWlCLENBQUMseUNBQXlDLENBQUMsSUFBSSxDQUFDLHdCQUF3QixFQUFFLENBQUMsQ0FBQyxDQUFDO0lBRTVJLDRCQUE0QixHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxDQUFDLElBQUksQ0FBQyx1QkFBdUIsRUFBRSxFQUFFLE1BQU0sQ0FBQyxDQUFDO3dHQW5CckYsd0JBQXdCOzRGQUF4Qix3QkFBd0IsMGFBbkJ6Qjs7Ozs7Ozs7Ozs7R0FXVCw0REFJUyxZQUFZLCtJQUFFLDZCQUE2QixrR0FBRSw0QkFBNEI7OzRGQUl4RSx3QkFBd0I7a0JBckJwQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxvQkFBb0I7b0JBQzlCLFFBQVEsRUFBRTs7Ozs7Ozs7Ozs7R0FXVDtvQkFDRCxJQUFJLEVBQUU7d0JBQ0osS0FBSyxFQUFFLDhCQUE4QjtxQkFDdEM7b0JBQ0QsT0FBTyxFQUFFLENBQUMsWUFBWSxFQUFFLDZCQUE2QixFQUFFLDRCQUE0QixDQUFDO29CQUNwRixVQUFVLEVBQUUsSUFBSTtvQkFDaEIsZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07aUJBQ2hEIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgY29tcHV0ZWQsIGluamVjdCwgaW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IERieEhlbHBDb250ZXh0U3RyaW5nIH0gZnJvbSAnLi9oZWxwJztcbmltcG9ydCB7IHRvT2JzZXJ2YWJsZSwgdG9TaWduYWwgfSBmcm9tICdAYW5ndWxhci9jb3JlL3J4anMtaW50ZXJvcCc7XG5pbXBvcnQgeyBhc09ic2VydmFibGUsIGRpc3RpbmN0VW50aWxIYXNEaWZmZXJlbnRWYWx1ZXMsIE9ic2VydmFibGVPclZhbHVlIH0gZnJvbSAnQGRlcmVla2Ivcnhqcyc7XG5pbXBvcnQgeyBtYXAsIE9ic2VydmFibGUsIG9mLCBzaGFyZVJlcGxheSwgc3dpdGNoTWFwIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBEYnhIZWxwV2lkZ2V0U2VydmljZSB9IGZyb20gJy4vaGVscC53aWRnZXQuc2VydmljZSc7XG5pbXBvcnQgeyBEYnhIZWxwVmlld0xpc3RFbnRyeUNvbXBvbmVudCB9IGZyb20gJy4vaGVscC52aWV3Lmxpc3QuZW50cnkuY29tcG9uZW50JztcbmltcG9ydCB7IEFycmF5T3JWYWx1ZSwgYXNBcnJheSB9IGZyb20gJ0BkZXJlZWtiL3V0aWwnO1xuaW1wb3J0IHsgTWF0QWNjb3JkaW9uIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvZXhwYW5zaW9uJztcbmltcG9ydCB7IERieExpc3RFbXB0eUNvbnRlbnRDb21wb25lbnQgfSBmcm9tICcuLi8uLi9sYXlvdXQvbGlzdC9saXN0LmNvbnRlbnQuZW1wdHkuY29tcG9uZW50JztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnZGJ4LWhlbHAtdmlldy1saXN0JyxcbiAgdGVtcGxhdGU6IGBcbiAgICA8bWF0LWFjY29yZGlvbiBbbXVsdGldPVwibXVsdGkoKVwiPlxuICAgICAgQGZvciAod2lkZ2V0RW50cnkgb2YgaGVscFdpZGdldEVudHJpZXNTaWduYWwoKTsgdHJhY2sgd2lkZ2V0RW50cnkuaGVscENvbnRleHRTdHJpbmcpIHtcbiAgICAgICAgPGRieC1oZWxwLXZpZXctbGlzdC1lbnRyeSBbaGVscFdpZGdldEVudHJ5XT1cIndpZGdldEVudHJ5XCI+PC9kYngtaGVscC12aWV3LWxpc3QtZW50cnk+XG4gICAgICB9XG4gICAgPC9tYXQtYWNjb3JkaW9uPlxuICAgIEBpZiAoaGFzTm9IZWxwV2lkZ2V0RW50cmllc1NpZ25hbCgpKSB7XG4gICAgICA8ZGJ4LWxpc3QtZW1wdHktY29udGVudD5cbiAgICAgICAgPG5nLWNvbnRlbnQgc2VsZWN0PVwiW2VtcHR5XVwiPjwvbmctY29udGVudD5cbiAgICAgIDwvZGJ4LWxpc3QtZW1wdHktY29udGVudD5cbiAgICB9XG4gIGAsXG4gIGhvc3Q6IHtcbiAgICBjbGFzczogJ2RieC1oZWxwLXZpZXctbGlzdCBkYngtYmxvY2snXG4gIH0sXG4gIGltcG9ydHM6IFtNYXRBY2NvcmRpb24sIERieEhlbHBWaWV3TGlzdEVudHJ5Q29tcG9uZW50LCBEYnhMaXN0RW1wdHlDb250ZW50Q29tcG9uZW50XSxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcbn0pXG5leHBvcnQgY2xhc3MgRGJ4SGVscFZpZXdMaXN0Q29tcG9uZW50IHtcbiAgcmVhZG9ubHkgaGVscFdpZGdldFNlcnZpY2UgPSBpbmplY3QoRGJ4SGVscFdpZGdldFNlcnZpY2UpO1xuXG4gIC8qKlxuICAgKiBXaGV0aGVyIHRoZSBhY2NvcmRpb24gc2hvdWxkIGFsbG93IG11bHRpcGxlIGV4cGFuZGVkIHBhbmVscy5cbiAgICovXG4gIHJlYWRvbmx5IG11bHRpID0gaW5wdXQ8Ym9vbGVhbj4odHJ1ZSk7XG5cbiAgcmVhZG9ubHkgaGVscENvbnRleHRTdHJpbmdzID0gaW5wdXQucmVxdWlyZWQ8T2JzZXJ2YWJsZU9yVmFsdWU8QXJyYXlPclZhbHVlPERieEhlbHBDb250ZXh0U3RyaW5nPj4+KCk7XG4gIHJlYWRvbmx5IGhlbHBDb250ZXh0U3RyaW5ncyQ6IE9ic2VydmFibGU8RGJ4SGVscENvbnRleHRTdHJpbmdbXT4gPSB0b09ic2VydmFibGUodGhpcy5oZWxwQ29udGV4dFN0cmluZ3MpLnBpcGUoXG4gICAgc3dpdGNoTWFwKCh4KSA9PiBhc09ic2VydmFibGUoeCkgPz8gb2YoW10pKSxcbiAgICBtYXAoYXNBcnJheSksXG4gICAgZGlzdGluY3RVbnRpbEhhc0RpZmZlcmVudFZhbHVlcygpLFxuICAgIHNoYXJlUmVwbGF5KDEpXG4gICk7XG5cbiAgcmVhZG9ubHkgaGVscENvbnRleHRTdHJpbmdzU2lnbmFsID0gdG9TaWduYWwodGhpcy5oZWxwQ29udGV4dFN0cmluZ3MkLCB7IGluaXRpYWxWYWx1ZTogW10gfSk7XG4gIHJlYWRvbmx5IGhlbHBXaWRnZXRFbnRyaWVzU2lnbmFsID0gY29tcHV0ZWQoKCkgPT4gdGhpcy5oZWxwV2lkZ2V0U2VydmljZS5nZXRIZWxwV2lkZ2V0RW50cmllc0ZvckhlbHBDb250ZXh0U3RyaW5ncyh0aGlzLmhlbHBDb250ZXh0U3RyaW5nc1NpZ25hbCgpKSk7XG5cbiAgcmVhZG9ubHkgaGFzTm9IZWxwV2lkZ2V0RW50cmllc1NpZ25hbCA9IGNvbXB1dGVkKCgpID0+ICF0aGlzLmhlbHBXaWRnZXRFbnRyaWVzU2lnbmFsKCk/Lmxlbmd0aCk7XG59XG4iXX0=
88
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"help.view.list.component.js","sourceRoot":"","sources":["../../../../../../../packages/dbx-web/src/lib/extension/help/help.view.list.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, inject, input } from '@angular/core';\nimport { DbxHelpContextString } from './help';\nimport { toObservable, toSignal } from '@angular/core/rxjs-interop';\nimport { asObservable, distinctUntilHasDifferentValues, ObservableOrValue } from '@dereekb/rxjs';\nimport { map, Observable, of, shareReplay, switchMap } from 'rxjs';\nimport { DbxHelpWidgetService } from './help.widget.service';\nimport { DbxHelpViewListEntryComponent } from './help.view.list.entry.component';\nimport { ArrayOrValue, asArray, Maybe, sortByNumberFunction } from '@dereekb/util';\nimport { MatAccordion } from '@angular/material/expansion';\nimport { DbxListEmptyContentComponent } from '../../layout/list/list.content.empty.component';\nimport { DbxInjectionComponent, DbxInjectionComponentConfig } from '@dereekb/dbx-core';\n\n@Component({\n  selector: 'dbx-help-view-list',\n  template: `\n    <mat-accordion [multi]=\"multi()\">\n      @for (widgetEntry of helpWidgetEntriesSignal(); track widgetEntry.helpContextString) {\n        <dbx-help-view-list-entry [helpWidgetEntry]=\"widgetEntry\"></dbx-help-view-list-entry>\n      }\n    </mat-accordion>\n    @if (hasNoHelpWidgetEntriesSignal()) {\n      <dbx-list-empty-content>\n        <ng-content select=\"[empty]\"></ng-content>\n      </dbx-list-empty-content>\n    }\n    <div class=\"dbx-help-view-list-footer\">\n      <dbx-injection [config]=\"helpListFooterComponentConfigSignal()\"></dbx-injection>\n    </div>\n  `,\n  host: {\n    class: 'dbx-help-view-list dbx-block'\n  },\n  imports: [MatAccordion, DbxHelpViewListEntryComponent, DbxListEmptyContentComponent, DbxInjectionComponent],\n  standalone: true,\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class DbxHelpViewListComponent {\n  readonly helpWidgetService = inject(DbxHelpWidgetService);\n\n  /**\n   * Whether the accordion should allow multiple expanded panels.\n   */\n  readonly multi = input<boolean>(true);\n\n  /**\n   * Whether or not to show the empty list content.\n   */\n  readonly allowEmptyListContent = input<boolean>(true);\n\n  /**\n   * Optional footer component config to inject after the list.\n   *\n   * If set null, then will not show any footer.\n   */\n  readonly helpListFooterComponentConfig = input<Maybe<DbxInjectionComponentConfig>>(undefined);\n\n  readonly helpContextStrings = input.required<ObservableOrValue<ArrayOrValue<DbxHelpContextString>>>();\n  readonly helpContextStrings$: Observable<DbxHelpContextString[]> = toObservable(this.helpContextStrings).pipe(\n    switchMap((x) => asObservable(x) ?? of([])),\n    map(asArray),\n    distinctUntilHasDifferentValues(),\n    map((x) => {\n      const sortPriorityMap = this.helpWidgetService.getSortPriorityMap();\n      const sorted = [...x].sort(sortByNumberFunction((x) => sortPriorityMap.get(x) ?? -2));\n      return sorted;\n    }),\n    shareReplay(1)\n  );\n\n  readonly helpContextStringsSignal = toSignal(this.helpContextStrings$, { initialValue: [] });\n  readonly helpWidgetEntriesSignal = computed(() => this.helpWidgetService.getHelpWidgetEntriesForHelpContextStrings(this.helpContextStringsSignal()));\n\n  readonly hasNoHelpWidgetEntriesSignal = computed(() => !this.helpWidgetEntriesSignal()?.length);\n\n  readonly helpListFooterComponentConfigSignal = computed(() => {\n    let config: Maybe<DbxInjectionComponentConfig> = this.helpListFooterComponentConfig();\n\n    if (config !== null) {\n      config = this.helpWidgetService.getHelpListFooterComponentConfig();\n    }\n\n    return config;\n  });\n}\n"]}
@@ -15,15 +15,16 @@ export class DbxHelpViewPopoverComponent extends AbstractPopoverDirective {
15
15
  _helpWidgetService = inject(DbxHelpWidgetService);
16
16
  helpContextStrings$ = this.popover.data?.helpContextStrings ?? this._helpContextService.activeHelpContextStringsArray$;
17
17
  static openPopover(popoverService, config, popoverKey) {
18
- const { origin, ...data } = config;
18
+ const { origin, popoverSizingConfig, ...data } = config;
19
19
  return popoverService.open({
20
20
  height: '500px',
21
21
  width: '600px',
22
+ ...popoverSizingConfig,
22
23
  key: popoverKey ?? DEFAULT_DBX_HELP_VIEW_POPOVER_KEY,
23
- origin,
24
24
  componentClass: DbxHelpViewPopoverComponent,
25
25
  data,
26
- isResizable: true
26
+ isResizable: true,
27
+ origin
27
28
  });
28
29
  }
29
30
  get config() {
@@ -32,6 +33,8 @@ export class DbxHelpViewPopoverComponent extends AbstractPopoverDirective {
32
33
  icon = this.config.icon ?? 'help';
33
34
  header = this.config.header ?? 'Help';
34
35
  emptyText = this.config.emptyText ?? 'No help topics available in current context.';
36
+ allowEmptyListContent = this.config.allowEmptyListContent ?? true;
37
+ helpListFooterComponentConfig = this.config.helpListFooterComponentConfig;
35
38
  popoverHeaderConfig = (() => {
36
39
  let config = this.config.popoverHeaderConfig;
37
40
  if (!config) {
@@ -40,10 +43,10 @@ export class DbxHelpViewPopoverComponent extends AbstractPopoverDirective {
40
43
  return config;
41
44
  })();
42
45
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxHelpViewPopoverComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
43
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DbxHelpViewPopoverComponent, isStandalone: true, selector: "ng-component", usesInheritance: true, ngImport: i0, template: "<dbx-popover-content>\n <!-- Header -->\n <dbx-popover-header [icon]=\"icon\" [header]=\"header\">\n <dbx-injection [config]=\"popoverHeaderConfig\"></dbx-injection>\n </dbx-popover-header>\n <!-- Content -->\n <dbx-popover-scroll-content>\n <dbx-help-view-list [helpContextStrings]=\"helpContextStrings$\">\n <p empty>{{ emptyText }}</p>\n </dbx-help-view-list>\n </dbx-popover-scroll-content>\n</dbx-popover-content>\n", dependencies: [{ kind: "component", type: DbxPopoverContentComponent, selector: "dbx-popover-content" }, { kind: "component", type: DbxPopoverHeaderComponent, selector: "dbx-popover-header", inputs: ["header", "icon"] }, { kind: "directive", type: DbxPopoverScrollContentDirective, selector: "dbx-popover-scroll-content,[dbxPopoverScrollContent],.dbx-popover-scroll-content" }, { kind: "component", type: DbxHelpViewListComponent, selector: "dbx-help-view-list", inputs: ["multi", "helpContextStrings"] }, { kind: "component", type: DbxInjectionComponent, selector: "dbx-injection, [dbxInjection], [dbx-injection]", inputs: ["config", "template"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
46
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DbxHelpViewPopoverComponent, isStandalone: true, selector: "ng-component", usesInheritance: true, ngImport: i0, template: "<dbx-popover-content>\n <!-- Header -->\n <dbx-popover-header [icon]=\"icon\" [header]=\"header\">\n <dbx-injection [config]=\"popoverHeaderConfig\"></dbx-injection>\n </dbx-popover-header>\n <!-- Content -->\n <dbx-popover-scroll-content>\n <dbx-help-view-list [helpContextStrings]=\"helpContextStrings$\" [allowEmptyListContent]=\"allowEmptyListContent\" [helpListFooterComponentConfig]=\"helpListFooterComponentConfig\">\n <p empty>{{ emptyText }}</p>\n </dbx-help-view-list>\n </dbx-popover-scroll-content>\n</dbx-popover-content>\n", dependencies: [{ kind: "component", type: DbxPopoverContentComponent, selector: "dbx-popover-content" }, { kind: "component", type: DbxPopoverHeaderComponent, selector: "dbx-popover-header", inputs: ["header", "icon"] }, { kind: "directive", type: DbxPopoverScrollContentDirective, selector: "dbx-popover-scroll-content,[dbxPopoverScrollContent],.dbx-popover-scroll-content" }, { kind: "component", type: DbxHelpViewListComponent, selector: "dbx-help-view-list", inputs: ["multi", "allowEmptyListContent", "helpListFooterComponentConfig", "helpContextStrings"] }, { kind: "component", type: DbxInjectionComponent, selector: "dbx-injection, [dbxInjection], [dbx-injection]", inputs: ["config", "template"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
44
47
  }
45
48
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxHelpViewPopoverComponent, decorators: [{
46
49
  type: Component,
47
- args: [{ imports: [DbxPopoverContentComponent, DbxPopoverHeaderComponent, DbxPopoverScrollContentDirective, DbxHelpViewListComponent, DbxInjectionComponent], changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, template: "<dbx-popover-content>\n <!-- Header -->\n <dbx-popover-header [icon]=\"icon\" [header]=\"header\">\n <dbx-injection [config]=\"popoverHeaderConfig\"></dbx-injection>\n </dbx-popover-header>\n <!-- Content -->\n <dbx-popover-scroll-content>\n <dbx-help-view-list [helpContextStrings]=\"helpContextStrings$\">\n <p empty>{{ emptyText }}</p>\n </dbx-help-view-list>\n </dbx-popover-scroll-content>\n</dbx-popover-content>\n" }]
50
+ args: [{ imports: [DbxPopoverContentComponent, DbxPopoverHeaderComponent, DbxPopoverScrollContentDirective, DbxHelpViewListComponent, DbxInjectionComponent], changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, template: "<dbx-popover-content>\n <!-- Header -->\n <dbx-popover-header [icon]=\"icon\" [header]=\"header\">\n <dbx-injection [config]=\"popoverHeaderConfig\"></dbx-injection>\n </dbx-popover-header>\n <!-- Content -->\n <dbx-popover-scroll-content>\n <dbx-help-view-list [helpContextStrings]=\"helpContextStrings$\" [allowEmptyListContent]=\"allowEmptyListContent\" [helpListFooterComponentConfig]=\"helpListFooterComponentConfig\">\n <p empty>{{ emptyText }}</p>\n </dbx-help-view-list>\n </dbx-popover-scroll-content>\n</dbx-popover-content>\n" }]
48
51
  }] });
49
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"help.view.popover.component.js","sourceRoot":"","sources":["../../../../../../../packages/dbx-web/src/lib/extension/help/help.view.popover.component.ts","../../../../../../../packages/dbx-web/src/lib/extension/help/help.view.popover.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAc,MAAM,EAAE,MAAM,eAAe,CAAC;AAEvF,OAAO,EAAE,wBAAwB,EAAE,MAAM,sDAAsD,CAAC;AAGhG,OAAO,EAAE,0BAA0B,EAAE,yBAAyB,EAAE,gCAAgC,EAAE,MAAM,mBAAmB,CAAC;AAC5H,OAAO,EAAE,wBAAwB,EAAE,MAAM,4BAA4B,CAAC;AAItE,OAAO,EAAE,qBAAqB,EAAE,MAAM,wBAAwB,CAAC;AAC/D,OAAO,EAAE,qBAAqB,EAA+B,MAAM,mBAAmB,CAAC;AACvF,OAAO,EAAE,oBAAoB,EAAE,MAAM,uBAAuB,CAAC;;AAE7D,MAAM,CAAC,MAAM,iCAAiC,GAAG,MAAM,CAAC;AAqCxD;;GAEG;AAOH,MAAM,OAAO,2BAA4B,SAAQ,wBAA2D;IACzF,mBAAmB,GAAG,MAAM,CAAC,qBAAqB,CAAC,CAAC;IACpD,kBAAkB,GAAG,MAAM,CAAC,oBAAoB,CAAC,CAAC;IAE1D,mBAAmB,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,kBAAkB,IAAI,IAAI,CAAC,mBAAmB,CAAC,8BAA8B,CAAC;IAEhI,MAAM,CAAC,WAAW,CAAC,cAAiC,EAAE,MAAgC,EAAE,UAA0B;QAChH,MAAM,EAAE,MAAM,EAAE,GAAG,IAAI,EAAE,GAAG,MAAM,CAAC;QAEnC,OAAO,cAAc,CAAC,IAAI,CAAC;YACzB,MAAM,EAAE,OAAO;YACf,KAAK,EAAE,OAAO;YACd,GAAG,EAAE,UAAU,IAAI,iCAAiC;YACpD,MAAM;YACN,cAAc,EAAE,2BAA2B;YAC3C,IAAI;YACJ,WAAW,EAAE,IAAI;SAClB,CAAC,CAAC;IACL,CAAC;IAED,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,OAAO,CAAC,IAAgC,CAAC;IACvD,CAAC;IAEQ,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,IAAI,MAAM,CAAC;IAClC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,IAAI,MAAM,CAAC;IACtC,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,IAAI,8CAA8C,CAAC;IAEpF,mBAAmB,GAAuC,CAAC,GAAG,EAAE;QACvE,IAAI,MAAM,GAAuC,IAAI,CAAC,MAAM,CAAC,mBAAmB,CAAC;QAEjF,IAAI,CAAC,MAAM,EAAE,CAAC;YACZ,MAAM,GAAG,IAAI,CAAC,kBAAkB,CAAC,+BAA+B,EAAE,CAAC;QACrE,CAAC;QAED,OAAO,MAAM,CAAC;IAChB,CAAC,CAAC,EAAE,CAAC;wGApCM,2BAA2B;4FAA3B,2BAA2B,+FC5DxC,0bAYA,4CD4CY,0BAA0B,gEAAE,yBAAyB,2FAAE,gCAAgC,6HAAE,wBAAwB,wGAAE,qBAAqB;;4FAIvI,2BAA2B;kBANvC,SAAS;8BAEC,CAAC,0BAA0B,EAAE,yBAAyB,EAAE,gCAAgC,EAAE,wBAAwB,EAAE,qBAAqB,CAAC,mBAClI,uBAAuB,CAAC,MAAM,cACnC,IAAI","sourcesContent":["import { ChangeDetectionStrategy, Component, ElementRef, inject } from '@angular/core';\nimport { ArrayOrValue, Maybe } from '@dereekb/util';\nimport { AbstractPopoverDirective } from '../../interaction/popover/abstract.popover.directive';\nimport { DbxPopoverKey } from '../../interaction/popover/popover';\nimport { DbxPopoverService } from '../../interaction/popover/popover.service';\nimport { DbxPopoverContentComponent, DbxPopoverHeaderComponent, DbxPopoverScrollContentDirective } from '../../interaction';\nimport { DbxHelpViewListComponent } from './help.view.list.component';\nimport { DbxHelpContextString } from './help';\nimport { NgPopoverRef } from 'ng-overlay-container';\nimport { ObservableOrValue } from '@dereekb/rxjs';\nimport { DbxHelpContextService } from './help.context.service';\nimport { DbxInjectionComponent, DbxInjectionComponentConfig } from '@dereekb/dbx-core';\nimport { DbxHelpWidgetService } from './help.widget.service';\n\nexport const DEFAULT_DBX_HELP_VIEW_POPOVER_KEY = 'help';\n\nexport interface DbxHelpViewPopoverConfig {\n  /**\n   * Custom icon\n   *\n   * Defaults to \"help\"\n   */\n  readonly icon?: string;\n  /**\n   * Custom header text\n   *\n   * Defaults to \"Help\"\n   */\n  readonly header?: string;\n  /**\n   * Custom empty text when no help contexts are available.\n   */\n  readonly emptyText?: string;\n  /**\n   * Origin element to attach the popover to.\n   */\n  readonly origin: ElementRef;\n  /**\n   * Specific contexts to display. If not provided, shows all active contexts from the DbxHelpContextService.\n   */\n  readonly helpContextStrings?: Maybe<ObservableOrValue<ArrayOrValue<DbxHelpContextString>>>;\n  /**\n   * Overrides the default popover header config.\n   *\n   * If not provided, the default popover header config will be used from DbxHelpWidgetService.\n   */\n  readonly popoverHeaderConfig?: Maybe<DbxInjectionComponentConfig>;\n}\n\nexport type DbxHelpViewPopoverConfigWithoutOrigin = Omit<DbxHelpViewPopoverConfig, 'origin'>;\n\n/**\n * Popover component for displaying help contexts.\n */\n@Component({\n  templateUrl: './help.view.popover.component.html',\n  imports: [DbxPopoverContentComponent, DbxPopoverHeaderComponent, DbxPopoverScrollContentDirective, DbxHelpViewListComponent, DbxInjectionComponent],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true\n})\nexport class DbxHelpViewPopoverComponent extends AbstractPopoverDirective<unknown, DbxHelpViewPopoverConfig> {\n  private readonly _helpContextService = inject(DbxHelpContextService);\n  private readonly _helpWidgetService = inject(DbxHelpWidgetService);\n\n  readonly helpContextStrings$ = this.popover.data?.helpContextStrings ?? this._helpContextService.activeHelpContextStringsArray$;\n\n  static openPopover(popoverService: DbxPopoverService, config: DbxHelpViewPopoverConfig, popoverKey?: DbxPopoverKey): NgPopoverRef {\n    const { origin, ...data } = config;\n\n    return popoverService.open({\n      height: '500px',\n      width: '600px',\n      key: popoverKey ?? DEFAULT_DBX_HELP_VIEW_POPOVER_KEY,\n      origin,\n      componentClass: DbxHelpViewPopoverComponent,\n      data,\n      isResizable: true\n    });\n  }\n\n  get config(): DbxHelpViewPopoverConfig {\n    return this.popover.data as DbxHelpViewPopoverConfig;\n  }\n\n  readonly icon = this.config.icon ?? 'help';\n  readonly header = this.config.header ?? 'Help';\n  readonly emptyText = this.config.emptyText ?? 'No help topics available in current context.';\n\n  readonly popoverHeaderConfig: Maybe<DbxInjectionComponentConfig> = (() => {\n    let config: Maybe<DbxInjectionComponentConfig> = this.config.popoverHeaderConfig;\n\n    if (!config) {\n      config = this._helpWidgetService.getPopoverHeaderComponentConfig();\n    }\n\n    return config;\n  })();\n}\n","<dbx-popover-content>\n  <!-- Header -->\n  <dbx-popover-header [icon]=\"icon\" [header]=\"header\">\n    <dbx-injection [config]=\"popoverHeaderConfig\"></dbx-injection>\n  </dbx-popover-header>\n  <!-- Content -->\n  <dbx-popover-scroll-content>\n    <dbx-help-view-list [helpContextStrings]=\"helpContextStrings$\">\n      <p empty>{{ emptyText }}</p>\n    </dbx-help-view-list>\n  </dbx-popover-scroll-content>\n</dbx-popover-content>\n"]}
52
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"help.view.popover.component.js","sourceRoot":"","sources":["../../../../../../../packages/dbx-web/src/lib/extension/help/help.view.popover.component.ts","../../../../../../../packages/dbx-web/src/lib/extension/help/help.view.popover.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAc,MAAM,EAAE,MAAM,eAAe,CAAC;AAEvF,OAAO,EAAE,wBAAwB,EAAE,MAAM,sDAAsD,CAAC;AAGhG,OAAO,EAAE,0BAA0B,EAAE,yBAAyB,EAAE,gCAAgC,EAAE,MAAM,mBAAmB,CAAC;AAC5H,OAAO,EAAE,wBAAwB,EAAE,MAAM,4BAA4B,CAAC;AAItE,OAAO,EAAE,qBAAqB,EAAE,MAAM,wBAAwB,CAAC;AAC/D,OAAO,EAAE,qBAAqB,EAA+B,MAAM,mBAAmB,CAAC;AACvF,OAAO,EAAE,oBAAoB,EAAE,MAAM,uBAAuB,CAAC;;AAE7D,MAAM,CAAC,MAAM,iCAAiC,GAAG,MAAM,CAAC;AAsDxD;;GAEG;AAOH,MAAM,OAAO,2BAA4B,SAAQ,wBAA2D;IACzF,mBAAmB,GAAG,MAAM,CAAC,qBAAqB,CAAC,CAAC;IACpD,kBAAkB,GAAG,MAAM,CAAC,oBAAoB,CAAC,CAAC;IAE1D,mBAAmB,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,kBAAkB,IAAI,IAAI,CAAC,mBAAmB,CAAC,8BAA8B,CAAC;IAEhI,MAAM,CAAC,WAAW,CAAC,cAAiC,EAAE,MAAgC,EAAE,UAA0B;QAChH,MAAM,EAAE,MAAM,EAAE,mBAAmB,EAAE,GAAG,IAAI,EAAE,GAAG,MAAM,CAAC;QAExD,OAAO,cAAc,CAAC,IAAI,CAAC;YACzB,MAAM,EAAE,OAAO;YACf,KAAK,EAAE,OAAO;YACd,GAAG,mBAAmB;YACtB,GAAG,EAAE,UAAU,IAAI,iCAAiC;YACpD,cAAc,EAAE,2BAA2B;YAC3C,IAAI;YACJ,WAAW,EAAE,IAAI;YACjB,MAAM;SACP,CAAC,CAAC;IACL,CAAC;IAED,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,OAAO,CAAC,IAAgC,CAAC;IACvD,CAAC;IAEQ,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,IAAI,MAAM,CAAC;IAClC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,IAAI,MAAM,CAAC;IACtC,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,IAAI,8CAA8C,CAAC;IACpF,qBAAqB,GAAG,IAAI,CAAC,MAAM,CAAC,qBAAqB,IAAI,IAAI,CAAC;IAClE,6BAA6B,GAAG,IAAI,CAAC,MAAM,CAAC,6BAA6B,CAAC;IAE1E,mBAAmB,GAAuC,CAAC,GAAG,EAAE;QACvE,IAAI,MAAM,GAAuC,IAAI,CAAC,MAAM,CAAC,mBAAmB,CAAC;QAEjF,IAAI,CAAC,MAAM,EAAE,CAAC;YACZ,MAAM,GAAG,IAAI,CAAC,kBAAkB,CAAC,+BAA+B,EAAE,CAAC;QACrE,CAAC;QAED,OAAO,MAAM,CAAC;IAChB,CAAC,CAAC,EAAE,CAAC;wGAvCM,2BAA2B;4FAA3B,2BAA2B,+FC7ExC,8iBAYA,4CD6DY,0BAA0B,gEAAE,yBAAyB,2FAAE,gCAAgC,6HAAE,wBAAwB,kKAAE,qBAAqB;;4FAIvI,2BAA2B;kBANvC,SAAS;8BAEC,CAAC,0BAA0B,EAAE,yBAAyB,EAAE,gCAAgC,EAAE,wBAAwB,EAAE,qBAAqB,CAAC,mBAClI,uBAAuB,CAAC,MAAM,cACnC,IAAI","sourcesContent":["import { ChangeDetectionStrategy, Component, ElementRef, inject } from '@angular/core';\nimport { ArrayOrValue, Maybe } from '@dereekb/util';\nimport { AbstractPopoverDirective } from '../../interaction/popover/abstract.popover.directive';\nimport { DbxPopoverKey } from '../../interaction/popover/popover';\nimport { DbxPopoverConfigSizing, DbxPopoverService } from '../../interaction/popover/popover.service';\nimport { DbxPopoverContentComponent, DbxPopoverHeaderComponent, DbxPopoverScrollContentDirective } from '../../interaction';\nimport { DbxHelpViewListComponent } from './help.view.list.component';\nimport { DbxHelpContextString } from './help';\nimport { NgPopoverRef } from 'ng-overlay-container';\nimport { ObservableOrValue } from '@dereekb/rxjs';\nimport { DbxHelpContextService } from './help.context.service';\nimport { DbxInjectionComponent, DbxInjectionComponentConfig } from '@dereekb/dbx-core';\nimport { DbxHelpWidgetService } from './help.widget.service';\n\nexport const DEFAULT_DBX_HELP_VIEW_POPOVER_KEY = 'help';\n\nexport interface DbxHelpViewPopoverConfig {\n  /**\n   * Custom icon\n   *\n   * Defaults to \"help\"\n   */\n  readonly icon?: string;\n  /**\n   * Custom header text\n   *\n   * Defaults to \"Help\"\n   */\n  readonly header?: string;\n  /**\n   * Custom empty text when no help contexts are available.\n   */\n  readonly emptyText?: string;\n  /**\n   * Origin element to attach the popover to.\n   */\n  readonly origin: ElementRef;\n  /**\n   * Specific contexts to display. If not provided, shows all active contexts from the DbxHelpContextService.\n   */\n  readonly helpContextStrings?: Maybe<ObservableOrValue<ArrayOrValue<DbxHelpContextString>>>;\n\n  /**\n   * Optional footer component config to inject after the list.\n   */\n  readonly helpListFooterComponentConfig?: Maybe<DbxInjectionComponentConfig>;\n\n  /**\n   * Whether to show the empty list content.\n   *\n   * Defaults to true.\n   */\n  readonly allowEmptyListContent?: Maybe<boolean>;\n\n  /**\n   * Overrides the default popover header config.\n   *\n   * If not provided, the default popover header config will be used from DbxHelpWidgetService.\n   */\n  readonly popoverHeaderConfig?: Maybe<DbxInjectionComponentConfig>;\n  /**\n   * Additional popover configuration.\n   */\n  readonly popoverSizingConfig?: Maybe<DbxPopoverConfigSizing>;\n}\n\nexport type DbxHelpViewPopoverConfigWithoutOrigin = Omit<DbxHelpViewPopoverConfig, 'origin'>;\n\n/**\n * Popover component for displaying help contexts.\n */\n@Component({\n  templateUrl: './help.view.popover.component.html',\n  imports: [DbxPopoverContentComponent, DbxPopoverHeaderComponent, DbxPopoverScrollContentDirective, DbxHelpViewListComponent, DbxInjectionComponent],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true\n})\nexport class DbxHelpViewPopoverComponent extends AbstractPopoverDirective<unknown, DbxHelpViewPopoverConfig> {\n  private readonly _helpContextService = inject(DbxHelpContextService);\n  private readonly _helpWidgetService = inject(DbxHelpWidgetService);\n\n  readonly helpContextStrings$ = this.popover.data?.helpContextStrings ?? this._helpContextService.activeHelpContextStringsArray$;\n\n  static openPopover(popoverService: DbxPopoverService, config: DbxHelpViewPopoverConfig, popoverKey?: DbxPopoverKey): NgPopoverRef {\n    const { origin, popoverSizingConfig, ...data } = config;\n\n    return popoverService.open({\n      height: '500px',\n      width: '600px',\n      ...popoverSizingConfig,\n      key: popoverKey ?? DEFAULT_DBX_HELP_VIEW_POPOVER_KEY,\n      componentClass: DbxHelpViewPopoverComponent,\n      data,\n      isResizable: true,\n      origin\n    });\n  }\n\n  get config(): DbxHelpViewPopoverConfig {\n    return this.popover.data as DbxHelpViewPopoverConfig;\n  }\n\n  readonly icon = this.config.icon ?? 'help';\n  readonly header = this.config.header ?? 'Help';\n  readonly emptyText = this.config.emptyText ?? 'No help topics available in current context.';\n  readonly allowEmptyListContent = this.config.allowEmptyListContent ?? true;\n  readonly helpListFooterComponentConfig = this.config.helpListFooterComponentConfig;\n\n  readonly popoverHeaderConfig: Maybe<DbxInjectionComponentConfig> = (() => {\n    let config: Maybe<DbxInjectionComponentConfig> = this.config.popoverHeaderConfig;\n\n    if (!config) {\n      config = this._helpWidgetService.getPopoverHeaderComponentConfig();\n    }\n\n    return config;\n  })();\n}\n","<dbx-popover-content>\n  <!-- Header -->\n  <dbx-popover-header [icon]=\"icon\" [header]=\"header\">\n    <dbx-injection [config]=\"popoverHeaderConfig\"></dbx-injection>\n  </dbx-popover-header>\n  <!-- Content -->\n  <dbx-popover-scroll-content>\n    <dbx-help-view-list [helpContextStrings]=\"helpContextStrings$\" [allowEmptyListContent]=\"allowEmptyListContent\" [helpListFooterComponentConfig]=\"helpListFooterComponentConfig\">\n      <p empty>{{ emptyText }}</p>\n    </dbx-help-view-list>\n  </dbx-popover-scroll-content>\n</dbx-popover-content>\n"]}
@@ -3,4 +3,4 @@ import { InjectionToken } from '@angular/core';
3
3
  * Injection token for DbxHelpWidgetData.
4
4
  */
5
5
  export const DBX_HELP_WIDGET_ENTRY_DATA_TOKEN = new InjectionToken('DbxHelpWidgetEntryData');
6
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVscC53aWRnZXQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3NyYy9saWIvZXh0ZW5zaW9uL2hlbHAvaGVscC53aWRnZXQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGNBQWMsRUFBYSxNQUFNLGVBQWUsQ0FBQztBQTBDMUQ7O0dBRUc7QUFDSCxNQUFNLENBQUMsTUFBTSxnQ0FBZ0MsR0FBRyxJQUFJLGNBQWMsQ0FBeUIsd0JBQXdCLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGlvblRva2VuLCB0eXBlIFR5cGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IHR5cGUgTWF5YmUgfSBmcm9tICdAZGVyZWVrYi91dGlsJztcbmltcG9ydCB7IHR5cGUgRGJ4SGVscENvbnRleHRTdHJpbmcgfSBmcm9tICcuL2hlbHAnO1xuXG4vKipcbiAqIEVudHJ5IGRlZmluaW5nIGEgaGVscCB3aWRnZXQgZm9yIGEgc3BlY2lmaWMgY29udGV4dFxuICovXG5leHBvcnQgaW50ZXJmYWNlIERieEhlbHBXaWRnZXRTZXJ2aWNlRW50cnkge1xuICAvKipcbiAgICogSGVscCBjb250ZXh0IHN0cmluZyBzcGVjaWZpYyB0byB0aGlzIGVudHJ5LlxuICAgKi9cbiAgcmVhZG9ubHkgaGVscENvbnRleHRTdHJpbmc6IERieEhlbHBDb250ZXh0U3RyaW5nO1xuICAvKipcbiAgICogVGl0bGUvTGFiZWwgZm9yIHRoZSBoZWxwIHRvcGljLlxuICAgKi9cbiAgcmVhZG9ubHkgdGl0bGU6IHN0cmluZztcbiAgLyoqXG4gICAqIEljb24gZm9yIHRoZSBoZWxwIHRvcGljLCBpZiBhcHBsaWNhYmxlLlxuICAgKi9cbiAgcmVhZG9ubHkgaWNvbj86IE1heWJlPHN0cmluZz47XG4gIC8qKlxuICAgKiBDdXN0b20gaGVscCB3aWRnZXQgY29tcG9uZW50IGNsYXNzIHRvIHVzZS5cbiAgICpcbiAgICogVGhlIGNvbXBvbmVudCB3aWxsIHJlY2VpdmUgdGhlIGNvbnRleHQgc3RyaW5nIGFzIGRhdGEuXG4gICAqL1xuICByZWFkb25seSB3aWRnZXRDb21wb25lbnRDbGFzczogVHlwZTx1bmtub3duPjtcbiAgLyoqXG4gICAqIEN1c3RvbSBoZWFkZXIgY29tcG9uZW50IGNsYXNzIHRvIHVzZSB0aGF0IHNob3dzIHVwIG9uIHRoZSB3aWRnZXQuXG4gICAqXG4gICAqIFRoZSBjb21wb25lbnQgd2lsbCByZWNlaXZlIHRoZSBjb250ZXh0IHN0cmluZyBhcyBkYXRhLlxuICAgKi9cbiAgcmVhZG9ubHkgaGVhZGVyQ29tcG9uZW50Q2xhc3M/OiBNYXliZTxUeXBlPHVua25vd24+Pjtcbn1cblxuLy8gTUFSSzogSW5qZWN0aW9uXG5leHBvcnQgaW50ZXJmYWNlIERieEhlbHBXaWRnZXRFbnRyeURhdGEge1xuICAvKipcbiAgICogQ29ycmVzcG9uZGluZyB3aWRnZXQgZW50cnkuXG4gICAqL1xuICByZWFkb25seSBoZWxwV2lkZ2V0RW50cnk6IERieEhlbHBXaWRnZXRTZXJ2aWNlRW50cnk7XG59XG5cbi8qKlxuICogSW5qZWN0aW9uIHRva2VuIGZvciBEYnhIZWxwV2lkZ2V0RGF0YS5cbiAqL1xuZXhwb3J0IGNvbnN0IERCWF9IRUxQX1dJREdFVF9FTlRSWV9EQVRBX1RPS0VOID0gbmV3IEluamVjdGlvblRva2VuPERieEhlbHBXaWRnZXRFbnRyeURhdGE+KCdEYnhIZWxwV2lkZ2V0RW50cnlEYXRhJyk7XG4iXX0=
6
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVscC53aWRnZXQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3NyYy9saWIvZXh0ZW5zaW9uL2hlbHAvaGVscC53aWRnZXQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGNBQWMsRUFBYSxNQUFNLGVBQWUsQ0FBQztBQWdEMUQ7O0dBRUc7QUFDSCxNQUFNLENBQUMsTUFBTSxnQ0FBZ0MsR0FBRyxJQUFJLGNBQWMsQ0FBeUIsd0JBQXdCLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGlvblRva2VuLCB0eXBlIFR5cGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IHR5cGUgTWF5YmUgfSBmcm9tICdAZGVyZWVrYi91dGlsJztcbmltcG9ydCB7IHR5cGUgRGJ4SGVscENvbnRleHRTdHJpbmcgfSBmcm9tICcuL2hlbHAnO1xuXG4vKipcbiAqIEVudHJ5IGRlZmluaW5nIGEgaGVscCB3aWRnZXQgZm9yIGEgc3BlY2lmaWMgY29udGV4dFxuICovXG5leHBvcnQgaW50ZXJmYWNlIERieEhlbHBXaWRnZXRTZXJ2aWNlRW50cnkge1xuICAvKipcbiAgICogSGVscCBjb250ZXh0IHN0cmluZyBzcGVjaWZpYyB0byB0aGlzIGVudHJ5LlxuICAgKi9cbiAgcmVhZG9ubHkgaGVscENvbnRleHRTdHJpbmc6IERieEhlbHBDb250ZXh0U3RyaW5nO1xuICAvKipcbiAgICogVGl0bGUvTGFiZWwgZm9yIHRoZSBoZWxwIHRvcGljLlxuICAgKi9cbiAgcmVhZG9ubHkgdGl0bGU6IHN0cmluZztcbiAgLyoqXG4gICAqIEljb24gZm9yIHRoZSBoZWxwIHRvcGljLCBpZiBhcHBsaWNhYmxlLlxuICAgKi9cbiAgcmVhZG9ubHkgaWNvbj86IE1heWJlPHN0cmluZz47XG4gIC8qKlxuICAgKiBUaGUgcHJpb3JpdHkgdG8gdXNlIHdoZW4gc29ydGluZyB0aGUgZW50aXRpZXMuXG4gICAqXG4gICAqIEhpZ2hlciB2YWx1ZXMgYXJlIGRpc3BsYXllZCBmaXJzdCBpbiB0aGUgbGlzdC5cbiAgICovXG4gIHJlYWRvbmx5IHNvcnRQcmlvcml0eT86IE1heWJlPG51bWJlcj47XG4gIC8qKlxuICAgKiBDdXN0b20gaGVscCB3aWRnZXQgY29tcG9uZW50IGNsYXNzIHRvIHVzZS5cbiAgICpcbiAgICogVGhlIGNvbXBvbmVudCB3aWxsIHJlY2VpdmUgdGhlIGNvbnRleHQgc3RyaW5nIGFzIGRhdGEuXG4gICAqL1xuICByZWFkb25seSB3aWRnZXRDb21wb25lbnRDbGFzczogVHlwZTx1bmtub3duPjtcbiAgLyoqXG4gICAqIEN1c3RvbSBoZWFkZXIgY29tcG9uZW50IGNsYXNzIHRvIHVzZSB0aGF0IHNob3dzIHVwIG9uIHRoZSB3aWRnZXQuXG4gICAqXG4gICAqIFRoZSBjb21wb25lbnQgd2lsbCByZWNlaXZlIHRoZSBjb250ZXh0IHN0cmluZyBhcyBkYXRhLlxuICAgKi9cbiAgcmVhZG9ubHkgaGVhZGVyQ29tcG9uZW50Q2xhc3M/OiBNYXliZTxUeXBlPHVua25vd24+Pjtcbn1cblxuLy8gTUFSSzogSW5qZWN0aW9uXG5leHBvcnQgaW50ZXJmYWNlIERieEhlbHBXaWRnZXRFbnRyeURhdGEge1xuICAvKipcbiAgICogQ29ycmVzcG9uZGluZyB3aWRnZXQgZW50cnkuXG4gICAqL1xuICByZWFkb25seSBoZWxwV2lkZ2V0RW50cnk6IERieEhlbHBXaWRnZXRTZXJ2aWNlRW50cnk7XG59XG5cbi8qKlxuICogSW5qZWN0aW9uIHRva2VuIGZvciBEYnhIZWxwV2lkZ2V0RGF0YS5cbiAqL1xuZXhwb3J0IGNvbnN0IERCWF9IRUxQX1dJREdFVF9FTlRSWV9EQVRBX1RPS0VOID0gbmV3IEluamVjdGlvblRva2VuPERieEhlbHBXaWRnZXRFbnRyeURhdGE+KCdEYnhIZWxwV2lkZ2V0RW50cnlEYXRhJyk7XG4iXX0=
@@ -1,5 +1,5 @@
1
1
  import { Inject, Injectable, Optional } from '@angular/core';
2
- import { asArray } from '@dereekb/util';
2
+ import { asArray, cachedGetter, mapIterable } from '@dereekb/util';
3
3
  import * as i0 from "@angular/core";
4
4
  export class DbxHelpWidgetServiceConfig {
5
5
  }
@@ -11,13 +11,18 @@ export class DbxHelpWidgetServiceConfig {
11
11
  */
12
12
  export class DbxHelpWidgetService {
13
13
  _entries = new Map();
14
+ _sortPriorityMap = cachedGetter(() => {
15
+ return new Map(mapIterable(this._entries.values(), (entry) => [entry.helpContextString, entry.sortPriority ?? -1]));
16
+ });
14
17
  _defaultWidgetComponentClass;
18
+ _helpListFooterComponentConfig;
15
19
  _defaultIcon;
16
20
  _popoverHeaderComponentConfig;
17
21
  constructor(initialConfig) {
18
22
  this.setDefaultWidgetComponentClass(initialConfig?.defaultWidgetComponentClass);
19
23
  this.setDefaultIcon(initialConfig?.defaultIcon !== undefined ? initialConfig?.defaultIcon : 'help');
20
24
  this.setPopoverHeaderComponentConfig(initialConfig?.popoverHeaderComponentConfig);
25
+ this.setHelpListFooterComponentConfig(initialConfig?.helpListFooterComponentConfig);
21
26
  if (initialConfig?.entries) {
22
27
  this.register(initialConfig.entries);
23
28
  }
@@ -40,6 +45,12 @@ export class DbxHelpWidgetService {
40
45
  setPopoverHeaderComponentConfig(componentConfig) {
41
46
  this._popoverHeaderComponentConfig = componentConfig;
42
47
  }
48
+ getHelpListFooterComponentConfig() {
49
+ return this._helpListFooterComponentConfig;
50
+ }
51
+ setHelpListFooterComponentConfig(componentConfig) {
52
+ this._helpListFooterComponentConfig = componentConfig;
53
+ }
43
54
  /**
44
55
  * Used to register one or more entries.
45
56
  *
@@ -70,6 +81,9 @@ export class DbxHelpWidgetService {
70
81
  hasHelpWidgetEntry(context) {
71
82
  return this._entries.has(context);
72
83
  }
84
+ getSortPriorityMap() {
85
+ return this._sortPriorityMap();
86
+ }
73
87
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxHelpWidgetService, deps: [{ token: DbxHelpWidgetServiceConfig, optional: true }], target: i0.ɵɵFactoryTarget.Injectable });
74
88
  static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxHelpWidgetService });
75
89
  }
@@ -81,4 +95,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
81
95
  type: Inject,
82
96
  args: [DbxHelpWidgetServiceConfig]
83
97
  }] }] });
84
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"help.widget.service.js","sourceRoot":"","sources":["../../../../../../../packages/dbx-web/src/lib/extension/help/help.widget.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable, Optional, Type } from '@angular/core';\nimport { ArrayOrValue, Maybe, asArray } from '@dereekb/util';\nimport { DbxHelpContextString } from './help';\nimport { DbxHelpWidgetServiceEntry } from './help.widget';\nimport { DbxInjectionComponentConfig } from '@dereekb/dbx-core';\n\nexport abstract class DbxHelpWidgetServiceConfig {\n  abstract readonly entries?: Maybe<DbxHelpWidgetServiceEntry[]>;\n  /**\n   * Default icon to use for unknown help topics.\n   */\n  abstract readonly defaultIcon?: Maybe<string>;\n  /**\n   * Default/Unknown help topic component class.\n   */\n  abstract readonly defaultWidgetComponentClass?: Maybe<Type<unknown>>;\n  /**\n   * Optional header component class to use for the list view.\n   */\n  abstract readonly popoverHeaderComponentConfig?: Maybe<DbxInjectionComponentConfig>;\n}\n\n/**\n * Service used to register help widgets.\n *\n * Similar to DbxErrorWidgetService, this maintains a registry of help widgets\n * that can be displayed for specific help context strings.\n */\n@Injectable()\nexport class DbxHelpWidgetService {\n  private readonly _entries = new Map<DbxHelpContextString, DbxHelpWidgetServiceEntry>();\n\n  private _defaultWidgetComponentClass: Maybe<Type<unknown>>;\n  private _defaultIcon?: Maybe<string>;\n  private _popoverHeaderComponentConfig: Maybe<DbxInjectionComponentConfig>;\n\n  constructor(@Optional() @Inject(DbxHelpWidgetServiceConfig) initialConfig?: DbxHelpWidgetServiceConfig) {\n    this.setDefaultWidgetComponentClass(initialConfig?.defaultWidgetComponentClass);\n    this.setDefaultIcon(initialConfig?.defaultIcon !== undefined ? initialConfig?.defaultIcon : 'help');\n    this.setPopoverHeaderComponentConfig(initialConfig?.popoverHeaderComponentConfig);\n\n    if (initialConfig?.entries) {\n      this.register(initialConfig.entries);\n    }\n  }\n\n  getDefaultWidgetComponentClass(): Maybe<Type<unknown>> {\n    return this._defaultWidgetComponentClass;\n  }\n\n  setDefaultWidgetComponentClass(componentClass: Maybe<Type<unknown>>): void {\n    this._defaultWidgetComponentClass = componentClass;\n  }\n\n  getDefaultIcon(): Maybe<string> {\n    return this._defaultIcon;\n  }\n\n  setDefaultIcon(icon: Maybe<string>): void {\n    this._defaultIcon = icon;\n  }\n\n  getPopoverHeaderComponentConfig(): Maybe<DbxInjectionComponentConfig> {\n    return this._popoverHeaderComponentConfig;\n  }\n\n  setPopoverHeaderComponentConfig(componentConfig: Maybe<DbxInjectionComponentConfig>): void {\n    this._popoverHeaderComponentConfig = componentConfig;\n  }\n\n  /**\n   * Used to register one or more entries.\n   *\n   * If an entry with the same identity is already registered, this will override it by default.\n   *\n   * @param entries The entries to register\n   * @param override Whether to override existing entries (default: true)\n   */\n  register(entries: ArrayOrValue<DbxHelpWidgetServiceEntry>, override: boolean = true): boolean {\n    const entriesArray = asArray(entries);\n\n    entriesArray.forEach((entry) => {\n      if (override || !this._entries.has(entry.helpContextString)) {\n        this._entries.set(entry.helpContextString, entry);\n      }\n    });\n\n    return true;\n  }\n\n  // MARK: Get\n  getAllRegisteredHelpContextStrings(): DbxHelpContextString[] {\n    return Array.from(this._entries.keys());\n  }\n\n  getHelpWidgetEntry(helpContextString: DbxHelpContextString): Maybe<DbxHelpWidgetServiceEntry> {\n    return this._entries.get(helpContextString) ?? (this._defaultWidgetComponentClass ? { helpContextString, title: '<Missing Help Topic>', widgetComponentClass: this._defaultWidgetComponentClass } : undefined);\n  }\n\n  getHelpWidgetEntriesForHelpContextStrings(helpContextStrings: DbxHelpContextString[]): DbxHelpWidgetServiceEntry[] {\n    return helpContextStrings.map((context) => this.getHelpWidgetEntry(context)).filter((entry) => !!entry) as DbxHelpWidgetServiceEntry[];\n  }\n\n  hasHelpWidgetEntry(context: DbxHelpContextString): boolean {\n    return this._entries.has(context);\n  }\n}\n"]}
98
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"help.widget.service.js","sourceRoot":"","sources":["../../../../../../../packages/dbx-web/src/lib/extension/help/help.widget.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable, Optional, Type } from '@angular/core';\nimport { ArrayOrValue, Maybe, asArray, cachedGetter, mapIterable } from '@dereekb/util';\nimport { DbxHelpContextString } from './help';\nimport { DbxHelpWidgetServiceEntry } from './help.widget';\nimport { DbxInjectionComponentConfig } from '@dereekb/dbx-core';\n\nexport abstract class DbxHelpWidgetServiceConfig {\n  /**\n   * All help widget service entries.\n   */\n  abstract readonly entries?: Maybe<DbxHelpWidgetServiceEntry[]>;\n  /**\n   * Default icon to use for unknown help topics.\n   */\n  abstract readonly defaultIcon?: Maybe<string>;\n  /**\n   * Default/Unknown help topic component class.\n   */\n  abstract readonly defaultWidgetComponentClass?: Maybe<Type<unknown>>;\n  /**\n   * Optional component class that shows up under the help content in the list view.\n   */\n  abstract readonly helpListFooterComponentConfig?: Maybe<DbxInjectionComponentConfig>;\n  /**\n   * Optional header component class to use for the list view.\n   */\n  abstract readonly popoverHeaderComponentConfig?: Maybe<DbxInjectionComponentConfig>;\n}\n\n/**\n * Service used to register help widgets.\n *\n * Similar to DbxErrorWidgetService, this maintains a registry of help widgets\n * that can be displayed for specific help context strings.\n */\n@Injectable()\nexport class DbxHelpWidgetService {\n  private readonly _entries = new Map<DbxHelpContextString, DbxHelpWidgetServiceEntry>();\n\n  private readonly _sortPriorityMap = cachedGetter(() => {\n    return new Map<DbxHelpContextString, number>(mapIterable(this._entries.values(), (entry) => [entry.helpContextString, entry.sortPriority ?? -1]));\n  });\n\n  private _defaultWidgetComponentClass: Maybe<Type<unknown>>;\n  private _helpListFooterComponentConfig: Maybe<DbxInjectionComponentConfig>;\n\n  private _defaultIcon?: Maybe<string>;\n  private _popoverHeaderComponentConfig: Maybe<DbxInjectionComponentConfig>;\n\n  constructor(@Optional() @Inject(DbxHelpWidgetServiceConfig) initialConfig?: DbxHelpWidgetServiceConfig) {\n    this.setDefaultWidgetComponentClass(initialConfig?.defaultWidgetComponentClass);\n    this.setDefaultIcon(initialConfig?.defaultIcon !== undefined ? initialConfig?.defaultIcon : 'help');\n    this.setPopoverHeaderComponentConfig(initialConfig?.popoverHeaderComponentConfig);\n    this.setHelpListFooterComponentConfig(initialConfig?.helpListFooterComponentConfig);\n\n    if (initialConfig?.entries) {\n      this.register(initialConfig.entries);\n    }\n  }\n\n  getDefaultWidgetComponentClass(): Maybe<Type<unknown>> {\n    return this._defaultWidgetComponentClass;\n  }\n\n  setDefaultWidgetComponentClass(componentClass: Maybe<Type<unknown>>): void {\n    this._defaultWidgetComponentClass = componentClass;\n  }\n\n  getDefaultIcon(): Maybe<string> {\n    return this._defaultIcon;\n  }\n\n  setDefaultIcon(icon: Maybe<string>): void {\n    this._defaultIcon = icon;\n  }\n\n  getPopoverHeaderComponentConfig(): Maybe<DbxInjectionComponentConfig> {\n    return this._popoverHeaderComponentConfig;\n  }\n\n  setPopoverHeaderComponentConfig(componentConfig: Maybe<DbxInjectionComponentConfig>): void {\n    this._popoverHeaderComponentConfig = componentConfig;\n  }\n\n  getHelpListFooterComponentConfig(): Maybe<DbxInjectionComponentConfig> {\n    return this._helpListFooterComponentConfig;\n  }\n\n  setHelpListFooterComponentConfig(componentConfig: Maybe<DbxInjectionComponentConfig>): void {\n    this._helpListFooterComponentConfig = componentConfig;\n  }\n\n  /**\n   * Used to register one or more entries.\n   *\n   * If an entry with the same identity is already registered, this will override it by default.\n   *\n   * @param entries The entries to register\n   * @param override Whether to override existing entries (default: true)\n   */\n  register(entries: ArrayOrValue<DbxHelpWidgetServiceEntry>, override: boolean = true): boolean {\n    const entriesArray = asArray(entries);\n\n    entriesArray.forEach((entry) => {\n      if (override || !this._entries.has(entry.helpContextString)) {\n        this._entries.set(entry.helpContextString, entry);\n      }\n    });\n\n    return true;\n  }\n\n  // MARK: Get\n  getAllRegisteredHelpContextStrings(): DbxHelpContextString[] {\n    return Array.from(this._entries.keys());\n  }\n\n  getHelpWidgetEntry(helpContextString: DbxHelpContextString): Maybe<DbxHelpWidgetServiceEntry> {\n    return this._entries.get(helpContextString) ?? (this._defaultWidgetComponentClass ? { helpContextString, title: '<Missing Help Topic>', widgetComponentClass: this._defaultWidgetComponentClass } : undefined);\n  }\n\n  getHelpWidgetEntriesForHelpContextStrings(helpContextStrings: DbxHelpContextString[]): DbxHelpWidgetServiceEntry[] {\n    return helpContextStrings.map((context) => this.getHelpWidgetEntry(context)).filter((entry) => !!entry) as DbxHelpWidgetServiceEntry[];\n  }\n\n  hasHelpWidgetEntry(context: DbxHelpContextString): boolean {\n    return this._entries.has(context);\n  }\n\n  getSortPriorityMap() {\n    return this._sortPriorityMap();\n  }\n}\n"]}
@@ -44,4 +44,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
44
44
  providedIn: 'root'
45
45
  }]
46
46
  }] });
47
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9wb3Zlci5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LXdlYi9zcmMvbGliL2ludGVyYWN0aW9uL3BvcG92ZXIvcG9wb3Zlci5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxtQkFBbUIsRUFBc0UsTUFBTSxxQkFBcUIsQ0FBQztBQUM5SCxPQUFPLEVBQUUsVUFBVSxFQUFFLFFBQVEsRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDN0QsT0FBTyxFQUFtQyx5QkFBeUIsRUFBZ0IsTUFBTSxzQkFBc0IsQ0FBQztBQUNoSCxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sc0JBQXNCLENBQUM7O0FBUS9DOztHQUVHO0FBSUgsTUFBTSxPQUFPLGlCQUFpQjtJQUNYLFFBQVEsR0FBRyxNQUFNLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDM0IsU0FBUyxHQUFHLE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQztJQUM3Qix3QkFBd0IsR0FBOEIsSUFBSSx5QkFBeUIsQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUVwSSxJQUFJLENBQVUsTUFBaUM7UUFDN0MsTUFBTSxPQUFPLEdBQUcsTUFBTSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsSUFBSSx5QkFBeUIsQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLHdCQUF3QixDQUFDO1FBRWhJLE1BQU0sYUFBYSxHQUFvQztZQUNyRCxVQUFVLEVBQUUsdUJBQXVCO1lBQ25DLE9BQU8sRUFBRSxNQUFNLENBQUMsT0FBTyxJQUFJLE9BQU87WUFDbEMsT0FBTyxFQUFFLE1BQU0sQ0FBQyxPQUFPLElBQUksS0FBSztZQUNoQyw2QkFBNkI7WUFDN0IsU0FBUyxFQUFFLE1BQU0sQ0FBQyxTQUFTO1lBQzNCLFFBQVEsRUFBRSxNQUFNLENBQUMsUUFBUTtZQUN6QixNQUFNLEVBQUUsTUFBTSxDQUFDLE1BQU0sSUFBSSxPQUFPO1lBQ2hDLEtBQUssRUFBRSxNQUFNLENBQUMsS0FBSyxJQUFJLE9BQU87WUFDOUIsV0FBVyxFQUFFLElBQUk7WUFDakIsV0FBVyxFQUFFLEtBQUs7WUFDbEIsV0FBVyxFQUFFLE1BQU0sQ0FBQyxXQUFXLElBQUksS0FBSztZQUN4QyxvQkFBb0IsRUFBRSxLQUFLO1NBQzVCLENBQUM7UUFFRixPQUFPLE9BQU8sQ0FBQyxJQUFJLENBQTRDO1lBQzdELE9BQU8sRUFBRSxtQkFBbUI7WUFDNUIsSUFBSSxFQUFFO2dCQUNKLEdBQUcsTUFBTTtnQkFDVCxhQUFhO2FBQ2Q7WUFDRCxhQUFhO1NBQ2QsQ0FBQyxDQUFDO0lBQ0wsQ0FBQzt3R0EvQlUsaUJBQWlCOzRHQUFqQixpQkFBaUIsY0FGaEIsTUFBTTs7NEZBRVAsaUJBQWlCO2tCQUg3QixVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERieFBvcG92ZXJDb21wb25lbnQsIHR5cGUgRGJ4UG9wb3ZlckNvbXBvbmVudENvbmZpZywgdHlwZSBGdWxsRGJ4UG9wb3ZlckNvbXBvbmVudENvbmZpZyB9IGZyb20gJy4vcG9wb3Zlci5jb21wb25lbnQnO1xuaW1wb3J0IHsgSW5qZWN0YWJsZSwgSW5qZWN0b3IsIGluamVjdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTmdPdmVybGF5Q29udGFpbmVyQ29uZmlndXJhdGlvbiwgTmdPdmVybGF5Q29udGFpbmVyU2VydmljZSwgTmdQb3BvdmVyUmVmIH0gZnJvbSAnbmctb3ZlcmxheS1jb250YWluZXInO1xuaW1wb3J0IHsgT3ZlcmxheSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9vdmVybGF5JztcblxuZXhwb3J0IHR5cGUgRGJ4UG9wb3ZlckNvbmZpZ1NpemluZyA9IFBpY2s8TmdPdmVybGF5Q29udGFpbmVyQ29uZmlndXJhdGlvbiwgJ29yaWdpblgnIHwgJ29yaWdpblknIHwgJ2hlaWdodCcgfCAnd2lkdGgnIHwgJ21pbkhlaWdodCcgfCAnbWluV2lkdGgnIHwgJ2lzUmVzaXphYmxlJz47XG5cbmV4cG9ydCBpbnRlcmZhY2UgRGJ4UG9wb3ZlckNvbmZpZzxPLCBJLCBUPiBleHRlbmRzIERieFBvcG92ZXJDb21wb25lbnRDb25maWc8TywgSSwgVD4sIERieFBvcG92ZXJDb25maWdTaXppbmcge1xuICBpbmplY3Rvcj86IEluamVjdG9yO1xufVxuXG4vKipcbiAqIFVzZWQgZm9yIGRpc3BsYXlpbmcgYSBwb3BvdmVyLlxuICovXG5ASW5qZWN0YWJsZSh7XG4gIHByb3ZpZGVkSW46ICdyb290J1xufSlcbmV4cG9ydCBjbGFzcyBEYnhQb3BvdmVyU2VydmljZSB7XG4gIHByaXZhdGUgcmVhZG9ubHkgX292ZXJsYXkgPSBpbmplY3QoT3ZlcmxheSk7XG4gIHByaXZhdGUgcmVhZG9ubHkgX2luamVjdG9yID0gaW5qZWN0KEluamVjdG9yKTtcbiAgcHJpdmF0ZSByZWFkb25seSBfb3ZlcmxheUNvbnRhaW5lclNlcnZpY2U6IE5nT3ZlcmxheUNvbnRhaW5lclNlcnZpY2UgPSBuZXcgTmdPdmVybGF5Q29udGFpbmVyU2VydmljZSh0aGlzLl9vdmVybGF5LCB0aGlzLl9pbmplY3Rvcik7XG5cbiAgb3BlbjxPLCBJLCBUPihjb25maWc6IERieFBvcG92ZXJDb25maWc8TywgSSwgVD4pOiBOZ1BvcG92ZXJSZWY8RGJ4UG9wb3ZlckNvbXBvbmVudENvbmZpZzxPLCBJLCBUPiwgTz4ge1xuICAgIGNvbnN0IHNlcnZpY2UgPSBjb25maWcuaW5qZWN0b3IgPyBuZXcgTmdPdmVybGF5Q29udGFpbmVyU2VydmljZSh0aGlzLl9vdmVybGF5LCBjb25maWcuaW5qZWN0b3IpIDogdGhpcy5fb3ZlcmxheUNvbnRhaW5lclNlcnZpY2U7XG5cbiAgICBjb25zdCBjb25maWd1cmF0aW9uOiBOZ092ZXJsYXlDb250YWluZXJDb25maWd1cmF0aW9uID0ge1xuICAgICAgcGFuZWxDbGFzczogJ2RieC1wb3BvdmVyLWNvbnRhaW5lcicsXG4gICAgICBvcmlnaW5YOiBjb25maWcub3JpZ2luWCA/PyAnc3RhcnQnLFxuICAgICAgb3JpZ2luWTogY29uZmlnLm9yaWdpblkgPz8gJ3RvcCcsXG4gICAgICAvLyBUT0RPOiBSZXNpemUgaGVpZ2h0L3dpZHRoLlxuICAgICAgbWluSGVpZ2h0OiBjb25maWcubWluSGVpZ2h0LFxuICAgICAgbWluV2lkdGg6IGNvbmZpZy5taW5XaWR0aCxcbiAgICAgIGhlaWdodDogY29uZmlnLmhlaWdodCA/PyAnNTAwcHgnLFxuICAgICAgd2lkdGg6IGNvbmZpZy53aWR0aCA/PyAnNDAwcHgnLFxuICAgICAgaGFzQmFja2Ryb3A6IHRydWUsXG4gICAgICBpc0RyYWdnYWJsZTogZmFsc2UsXG4gICAgICBpc1Jlc2l6YWJsZTogY29uZmlnLmlzUmVzaXphYmxlID8/IGZhbHNlLFxuICAgICAgZGlzYWJsZUJhY2tkcm9wQ2xvc2U6IGZhbHNlXG4gICAgfTtcblxuICAgIHJldHVybiBzZXJ2aWNlLm9wZW48RnVsbERieFBvcG92ZXJDb21wb25lbnRDb25maWc8TywgSSwgVD4sIE8+KHtcbiAgICAgIGNvbnRlbnQ6IERieFBvcG92ZXJDb21wb25lbnQsXG4gICAgICBkYXRhOiB7XG4gICAgICAgIC4uLmNvbmZpZyxcbiAgICAgICAgY29uZmlndXJhdGlvblxuICAgICAgfSxcbiAgICAgIGNvbmZpZ3VyYXRpb25cbiAgICB9KTtcbiAgfVxufVxuIl19
47
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9wb3Zlci5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LXdlYi9zcmMvbGliL2ludGVyYWN0aW9uL3BvcG92ZXIvcG9wb3Zlci5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxtQkFBbUIsRUFBc0UsTUFBTSxxQkFBcUIsQ0FBQztBQUM5SCxPQUFPLEVBQUUsVUFBVSxFQUFFLFFBQVEsRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDN0QsT0FBTyxFQUFtQyx5QkFBeUIsRUFBZ0IsTUFBTSxzQkFBc0IsQ0FBQztBQUNoSCxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sc0JBQXNCLENBQUM7O0FBUS9DOztHQUVHO0FBSUgsTUFBTSxPQUFPLGlCQUFpQjtJQUNYLFFBQVEsR0FBRyxNQUFNLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDM0IsU0FBUyxHQUFHLE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQztJQUM3Qix3QkFBd0IsR0FBOEIsSUFBSSx5QkFBeUIsQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUVwSSxJQUFJLENBQVUsTUFBaUM7UUFDN0MsTUFBTSxPQUFPLEdBQUcsTUFBTSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsSUFBSSx5QkFBeUIsQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLHdCQUF3QixDQUFDO1FBRWhJLE1BQU0sYUFBYSxHQUFvQztZQUNyRCxVQUFVLEVBQUUsdUJBQXVCO1lBQ25DLE9BQU8sRUFBRSxNQUFNLENBQUMsT0FBTyxJQUFJLE9BQU87WUFDbEMsT0FBTyxFQUFFLE1BQU0sQ0FBQyxPQUFPLElBQUksS0FBSztZQUNoQyw2QkFBNkI7WUFDN0IsU0FBUyxFQUFFLE1BQU0sQ0FBQyxTQUFTO1lBQzNCLFFBQVEsRUFBRSxNQUFNLENBQUMsUUFBUTtZQUN6QixNQUFNLEVBQUUsTUFBTSxDQUFDLE1BQU0sSUFBSSxPQUFPO1lBQ2hDLEtBQUssRUFBRSxNQUFNLENBQUMsS0FBSyxJQUFJLE9BQU87WUFDOUIsV0FBVyxFQUFFLElBQUk7WUFDakIsV0FBVyxFQUFFLEtBQUs7WUFDbEIsV0FBVyxFQUFFLE1BQU0sQ0FBQyxXQUFXLElBQUksS0FBSztZQUN4QyxvQkFBb0IsRUFBRSxLQUFLO1NBQzVCLENBQUM7UUFFRixPQUFPLE9BQU8sQ0FBQyxJQUFJLENBQTRDO1lBQzdELE9BQU8sRUFBRSxtQkFBbUI7WUFDNUIsSUFBSSxFQUFFO2dCQUNKLEdBQUcsTUFBTTtnQkFDVCxhQUFhO2FBQ2Q7WUFDRCxhQUFhO1NBQ2QsQ0FBQyxDQUFDO0lBQ0wsQ0FBQzt3R0EvQlUsaUJBQWlCOzRHQUFqQixpQkFBaUIsY0FGaEIsTUFBTTs7NEZBRVAsaUJBQWlCO2tCQUg3QixVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERieFBvcG92ZXJDb21wb25lbnQsIHR5cGUgRGJ4UG9wb3ZlckNvbXBvbmVudENvbmZpZywgdHlwZSBGdWxsRGJ4UG9wb3ZlckNvbXBvbmVudENvbmZpZyB9IGZyb20gJy4vcG9wb3Zlci5jb21wb25lbnQnO1xuaW1wb3J0IHsgSW5qZWN0YWJsZSwgSW5qZWN0b3IsIGluamVjdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTmdPdmVybGF5Q29udGFpbmVyQ29uZmlndXJhdGlvbiwgTmdPdmVybGF5Q29udGFpbmVyU2VydmljZSwgTmdQb3BvdmVyUmVmIH0gZnJvbSAnbmctb3ZlcmxheS1jb250YWluZXInO1xuaW1wb3J0IHsgT3ZlcmxheSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9vdmVybGF5JztcblxuZXhwb3J0IHR5cGUgRGJ4UG9wb3ZlckNvbmZpZ1NpemluZyA9IFBpY2s8TmdPdmVybGF5Q29udGFpbmVyQ29uZmlndXJhdGlvbiwgJ29yaWdpblgnIHwgJ29yaWdpblknIHwgJ2hlaWdodCcgfCAnd2lkdGgnIHwgJ21pbkhlaWdodCcgfCAnbWluV2lkdGgnIHwgJ2lzUmVzaXphYmxlJz47XG5cbmV4cG9ydCBpbnRlcmZhY2UgRGJ4UG9wb3ZlckNvbmZpZzxPLCBJLCBUPiBleHRlbmRzIERieFBvcG92ZXJDb21wb25lbnRDb25maWc8TywgSSwgVD4sIERieFBvcG92ZXJDb25maWdTaXppbmcge1xuICByZWFkb25seSBpbmplY3Rvcj86IEluamVjdG9yO1xufVxuXG4vKipcbiAqIFVzZWQgZm9yIGRpc3BsYXlpbmcgYSBwb3BvdmVyLlxuICovXG5ASW5qZWN0YWJsZSh7XG4gIHByb3ZpZGVkSW46ICdyb290J1xufSlcbmV4cG9ydCBjbGFzcyBEYnhQb3BvdmVyU2VydmljZSB7XG4gIHByaXZhdGUgcmVhZG9ubHkgX292ZXJsYXkgPSBpbmplY3QoT3ZlcmxheSk7XG4gIHByaXZhdGUgcmVhZG9ubHkgX2luamVjdG9yID0gaW5qZWN0KEluamVjdG9yKTtcbiAgcHJpdmF0ZSByZWFkb25seSBfb3ZlcmxheUNvbnRhaW5lclNlcnZpY2U6IE5nT3ZlcmxheUNvbnRhaW5lclNlcnZpY2UgPSBuZXcgTmdPdmVybGF5Q29udGFpbmVyU2VydmljZSh0aGlzLl9vdmVybGF5LCB0aGlzLl9pbmplY3Rvcik7XG5cbiAgb3BlbjxPLCBJLCBUPihjb25maWc6IERieFBvcG92ZXJDb25maWc8TywgSSwgVD4pOiBOZ1BvcG92ZXJSZWY8RGJ4UG9wb3ZlckNvbXBvbmVudENvbmZpZzxPLCBJLCBUPiwgTz4ge1xuICAgIGNvbnN0IHNlcnZpY2UgPSBjb25maWcuaW5qZWN0b3IgPyBuZXcgTmdPdmVybGF5Q29udGFpbmVyU2VydmljZSh0aGlzLl9vdmVybGF5LCBjb25maWcuaW5qZWN0b3IpIDogdGhpcy5fb3ZlcmxheUNvbnRhaW5lclNlcnZpY2U7XG5cbiAgICBjb25zdCBjb25maWd1cmF0aW9uOiBOZ092ZXJsYXlDb250YWluZXJDb25maWd1cmF0aW9uID0ge1xuICAgICAgcGFuZWxDbGFzczogJ2RieC1wb3BvdmVyLWNvbnRhaW5lcicsXG4gICAgICBvcmlnaW5YOiBjb25maWcub3JpZ2luWCA/PyAnc3RhcnQnLFxuICAgICAgb3JpZ2luWTogY29uZmlnLm9yaWdpblkgPz8gJ3RvcCcsXG4gICAgICAvLyBUT0RPOiBSZXNpemUgaGVpZ2h0L3dpZHRoLlxuICAgICAgbWluSGVpZ2h0OiBjb25maWcubWluSGVpZ2h0LFxuICAgICAgbWluV2lkdGg6IGNvbmZpZy5taW5XaWR0aCxcbiAgICAgIGhlaWdodDogY29uZmlnLmhlaWdodCA/PyAnNTAwcHgnLFxuICAgICAgd2lkdGg6IGNvbmZpZy53aWR0aCA/PyAnNDAwcHgnLFxuICAgICAgaGFzQmFja2Ryb3A6IHRydWUsXG4gICAgICBpc0RyYWdnYWJsZTogZmFsc2UsXG4gICAgICBpc1Jlc2l6YWJsZTogY29uZmlnLmlzUmVzaXphYmxlID8/IGZhbHNlLFxuICAgICAgZGlzYWJsZUJhY2tkcm9wQ2xvc2U6IGZhbHNlXG4gICAgfTtcblxuICAgIHJldHVybiBzZXJ2aWNlLm9wZW48RnVsbERieFBvcG92ZXJDb21wb25lbnRDb25maWc8TywgSSwgVD4sIE8+KHtcbiAgICAgIGNvbnRlbnQ6IERieFBvcG92ZXJDb21wb25lbnQsXG4gICAgICBkYXRhOiB7XG4gICAgICAgIC4uLmNvbmZpZyxcbiAgICAgICAgY29uZmlndXJhdGlvblxuICAgICAgfSxcbiAgICAgIGNvbmZpZ3VyYXRpb25cbiAgICB9KTtcbiAgfVxufVxuIl19
@@ -1,4 +1,4 @@
1
- import { Component, computed } from '@angular/core';
1
+ import { ChangeDetectionStrategy, Component, computed, effect, ElementRef, viewChild } from '@angular/core';
2
2
  import { AbstractDbxSegueAnchorDirective } from '../../layout/anchor/anchor.segue.directive';
3
3
  import { UIRouterModule } from '@uirouter/angular';
4
4
  import { DbxInjectionComponent } from '@dereekb/dbx-core';
@@ -9,15 +9,68 @@ import * as i1 from "@uirouter/angular";
9
9
  * SegueAnchor implementation for UIRouter.
10
10
  */
11
11
  export class DbxUIRouterSegueAnchorComponent extends AbstractDbxSegueAnchorDirective {
12
+ _cleanupClickOverride = null;
12
13
  _parentAnchorSignal = toSignal(this.parent.anchor$, { initialValue: undefined });
14
+ anchorElement = viewChild.required('anchor', { read: ElementRef });
15
+ injectionElement = viewChild.required('injection', { read: ElementRef });
16
+ anchorDisabledSignal = computed(() => this.anchorSignal()?.disabled ?? false);
17
+ /**
18
+ * This effect exists to solve the issue of an injected element that utilizes event.stopPropogation() and doesn't also call event.preventDefault().
19
+ *
20
+ * We didn't want to use css's pointer-events: none as that would disable the Angular Material button effects.
21
+ *
22
+ * For example, dbx-button would call event.stopPropagation() on click, which would prevent the uiSref from being triggered, but the default behavior
23
+ * of the anchor element would still be triggered, causing the browser to load/reload the page at the given href instead of navigating to the new state using uiSref.
24
+ *
25
+ * NOTE: Those nested event listeners are still ultimately triggered.
26
+ */
27
+ _overrideClickElementEffect = effect(() => {
28
+ const anchorElement = this.anchorElement();
29
+ const injectionElement = this.injectionElement();
30
+ const anchorDisabled = this.anchorDisabledSignal();
31
+ if (injectionElement) {
32
+ // cleanup/remove the previous/existing click function
33
+ if (this._cleanupClickOverride) {
34
+ this._cleanupClickOverride();
35
+ }
36
+ if (!anchorDisabled) {
37
+ const clickOverride = (event) => {
38
+ // Allow ctrl+click, cmd+click, shift+click, and middle-click for new tab/window
39
+ // Don't preventDefault or stopPropagation - let browser handle it naturally
40
+ if (event.ctrlKey || event.metaKey || event.shiftKey || event.button === 1) {
41
+ return; // Browser will open in new tab/window
42
+ }
43
+ else {
44
+ // otherwise, also trigger a click on the uiSref anchor element
45
+ anchorElement?.nativeElement.click();
46
+ // Prevents the default behavior of the anchor element's href from being triggered
47
+ event.preventDefault();
48
+ event.stopPropagation();
49
+ }
50
+ };
51
+ this._cleanupClickOverride = () => {
52
+ injectionElement.nativeElement.removeEventListener('click', clickOverride);
53
+ delete this._cleanupClickOverride;
54
+ };
55
+ injectionElement.nativeElement.addEventListener('click', clickOverride, {
56
+ capture: true // Use capture to ensure this event listener is called before any nested child's event listeners
57
+ });
58
+ }
59
+ }
60
+ });
13
61
  uiSrefSignal = computed(() => (this._parentAnchorSignal()?.ref ?? ''));
14
62
  uiParamsSignal = computed(() => this._parentAnchorSignal()?.refParams);
15
63
  uiOptionsSignal = computed(() => this._parentAnchorSignal()?.refOptions ?? {});
64
+ ngOnDestroy() {
65
+ if (this._cleanupClickOverride) {
66
+ this._cleanupClickOverride();
67
+ }
68
+ }
16
69
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxUIRouterSegueAnchorComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
17
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DbxUIRouterSegueAnchorComponent, isStandalone: true, selector: "ng-component", usesInheritance: true, ngImport: i0, template: "<a class=\"dbx-anchor-a dbx-anchor-sref\" [attr.target]=\"targetSignal()\" [uiSref]=\"uiSrefSignal()\" [uiParams]=\"uiParamsSignal()\" [uiOptions]=\"uiOptionsSignal()\" uiSrefActive=\"dbx-anchor-active\" uiSrefActiveEq=\"dbx-anchor-active-eq\">\n <dbx-injection [template]=\"templateConfigSignal()\"></dbx-injection>\n</a>\n", dependencies: [{ kind: "ngmodule", type: UIRouterModule }, { kind: "directive", type: i1.UISref, selector: "[uiSref]", inputs: ["uiSref", "uiParams", "uiOptions"], exportAs: ["uiSref"] }, { kind: "directive", type: i1.AnchorUISref, selector: "a[uiSref]" }, { kind: "directive", type: i1.UISrefActive, selector: "[uiSrefActive],[uiSrefActiveEq]", inputs: ["uiSrefActive", "uiSrefActiveEq"] }, { kind: "component", type: DbxInjectionComponent, selector: "dbx-injection, [dbxInjection], [dbx-injection]", inputs: ["config", "template"] }] });
70
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "18.2.13", type: DbxUIRouterSegueAnchorComponent, isStandalone: true, selector: "ng-component", viewQueries: [{ propertyName: "anchorElement", first: true, predicate: ["anchor"], descendants: true, read: ElementRef, isSignal: true }, { propertyName: "injectionElement", first: true, predicate: ["injection"], descendants: true, read: ElementRef, isSignal: true }], usesInheritance: true, ngImport: i0, template: "<a class=\"dbx-anchor-a dbx-anchor-sref\" #anchor [attr.target]=\"targetSignal()\" [uiSref]=\"uiSrefSignal()\" [uiParams]=\"uiParamsSignal()\" [uiOptions]=\"uiOptionsSignal()\" uiSrefActive=\"dbx-anchor-active\" uiSrefActiveEq=\"dbx-anchor-active-eq\">\n <dbx-injection #injection [template]=\"templateConfigSignal()\"></dbx-injection>\n</a>\n", dependencies: [{ kind: "ngmodule", type: UIRouterModule }, { kind: "directive", type: i1.UISref, selector: "[uiSref]", inputs: ["uiSref", "uiParams", "uiOptions"], exportAs: ["uiSref"] }, { kind: "directive", type: i1.AnchorUISref, selector: "a[uiSref]" }, { kind: "directive", type: i1.UISrefActive, selector: "[uiSrefActive],[uiSrefActiveEq]", inputs: ["uiSrefActive", "uiSrefActiveEq"] }, { kind: "component", type: DbxInjectionComponent, selector: "dbx-injection, [dbxInjection], [dbx-injection]", inputs: ["config", "template"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
18
71
  }
19
72
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxUIRouterSegueAnchorComponent, decorators: [{
20
73
  type: Component,
21
- args: [{ imports: [UIRouterModule, DbxInjectionComponent], standalone: true, template: "<a class=\"dbx-anchor-a dbx-anchor-sref\" [attr.target]=\"targetSignal()\" [uiSref]=\"uiSrefSignal()\" [uiParams]=\"uiParamsSignal()\" [uiOptions]=\"uiOptionsSignal()\" uiSrefActive=\"dbx-anchor-active\" uiSrefActiveEq=\"dbx-anchor-active-eq\">\n <dbx-injection [template]=\"templateConfigSignal()\"></dbx-injection>\n</a>\n" }]
74
+ args: [{ imports: [UIRouterModule, DbxInjectionComponent], changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, template: "<a class=\"dbx-anchor-a dbx-anchor-sref\" #anchor [attr.target]=\"targetSignal()\" [uiSref]=\"uiSrefSignal()\" [uiParams]=\"uiParamsSignal()\" [uiOptions]=\"uiOptionsSignal()\" uiSrefActive=\"dbx-anchor-active\" uiSrefActiveEq=\"dbx-anchor-active-eq\">\n <dbx-injection #injection [template]=\"templateConfigSignal()\"></dbx-injection>\n</a>\n" }]
22
75
  }] });
23
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5jaG9yLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC13ZWIvc3JjL2xpYi9yb3V0ZXIvcHJvdmlkZXIvdWlyb3V0ZXIvYW5jaG9yLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC13ZWIvc3JjL2xpYi9yb3V0ZXIvcHJvdmlkZXIvdWlyb3V0ZXIvYW5jaG9yLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3BELE9BQU8sRUFBRSwrQkFBK0IsRUFBRSxNQUFNLDRDQUE0QyxDQUFDO0FBQzdGLE9BQU8sRUFBdUMsY0FBYyxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDeEYsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDMUQsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLDRCQUE0QixDQUFDOzs7QUFFdEQ7O0dBRUc7QUFNSCxNQUFNLE9BQU8sK0JBQWdDLFNBQVEsK0JBQStCO0lBQ2pFLG1CQUFtQixHQUFHLFFBQVEsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLE9BQU8sRUFBRSxFQUFFLFlBQVksRUFBRSxTQUFTLEVBQUUsQ0FBQyxDQUFDO0lBRXpGLFlBQVksR0FBRyxRQUFRLENBQWMsR0FBRyxFQUFFLENBQUMsQ0FBQyxJQUFJLENBQUMsbUJBQW1CLEVBQUUsRUFBRSxHQUFHLElBQUksRUFBRSxDQUFnQixDQUFDLENBQUM7SUFDbkcsY0FBYyxHQUFHLFFBQVEsQ0FBa0IsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLG1CQUFtQixFQUFFLEVBQUUsU0FBUyxDQUFDLENBQUM7SUFDeEYsZUFBZSxHQUFHLFFBQVEsQ0FBb0IsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLG1CQUFtQixFQUFFLEVBQUUsVUFBVSxJQUFLLEVBQXdCLENBQUMsQ0FBQzt3R0FMdkgsK0JBQStCOzRGQUEvQiwrQkFBK0IsK0ZDZDVDLHVVQUdBLDJDRFFZLGNBQWMsNFdBQUUscUJBQXFCOzs0RkFHcEMsK0JBQStCO2tCQUwzQyxTQUFTOzhCQUVDLENBQUMsY0FBYyxFQUFFLHFCQUFxQixDQUFDLGNBQ3BDLElBQUkiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIGNvbXB1dGVkIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBBYnN0cmFjdERieFNlZ3VlQW5jaG9yRGlyZWN0aXZlIH0gZnJvbSAnLi4vLi4vbGF5b3V0L2FuY2hvci9hbmNob3Iuc2VndWUuZGlyZWN0aXZlJztcbmltcG9ydCB7IE9iaiwgU3RhdGVPck5hbWUsIFRyYW5zaXRpb25PcHRpb25zLCBVSVJvdXRlck1vZHVsZSB9IGZyb20gJ0B1aXJvdXRlci9hbmd1bGFyJztcbmltcG9ydCB7IERieEluamVjdGlvbkNvbXBvbmVudCB9IGZyb20gJ0BkZXJlZWtiL2RieC1jb3JlJztcbmltcG9ydCB7IHRvU2lnbmFsIH0gZnJvbSAnQGFuZ3VsYXIvY29yZS9yeGpzLWludGVyb3AnO1xuXG4vKipcbiAqIFNlZ3VlQW5jaG9yIGltcGxlbWVudGF0aW9uIGZvciBVSVJvdXRlci5cbiAqL1xuQENvbXBvbmVudCh7XG4gIHRlbXBsYXRlVXJsOiAnLi9hbmNob3IuY29tcG9uZW50Lmh0bWwnLFxuICBpbXBvcnRzOiBbVUlSb3V0ZXJNb2R1bGUsIERieEluamVjdGlvbkNvbXBvbmVudF0sXG4gIHN0YW5kYWxvbmU6IHRydWVcbn0pXG5leHBvcnQgY2xhc3MgRGJ4VUlSb3V0ZXJTZWd1ZUFuY2hvckNvbXBvbmVudCBleHRlbmRzIEFic3RyYWN0RGJ4U2VndWVBbmNob3JEaXJlY3RpdmUge1xuICBwcml2YXRlIHJlYWRvbmx5IF9wYXJlbnRBbmNob3JTaWduYWwgPSB0b1NpZ25hbCh0aGlzLnBhcmVudC5hbmNob3IkLCB7IGluaXRpYWxWYWx1ZTogdW5kZWZpbmVkIH0pO1xuXG4gIHJlYWRvbmx5IHVpU3JlZlNpZ25hbCA9IGNvbXB1dGVkPFN0YXRlT3JOYW1lPigoKSA9PiAodGhpcy5fcGFyZW50QW5jaG9yU2lnbmFsKCk/LnJlZiA/PyAnJykgYXMgU3RhdGVPck5hbWUpO1xuICByZWFkb25seSB1aVBhcmFtc1NpZ25hbCA9IGNvbXB1dGVkPE9iaiB8IHVuZGVmaW5lZD4oKCkgPT4gdGhpcy5fcGFyZW50QW5jaG9yU2lnbmFsKCk/LnJlZlBhcmFtcyk7XG4gIHJlYWRvbmx5IHVpT3B0aW9uc1NpZ25hbCA9IGNvbXB1dGVkPFRyYW5zaXRpb25PcHRpb25zPigoKSA9PiB0aGlzLl9wYXJlbnRBbmNob3JTaWduYWwoKT8ucmVmT3B0aW9ucyA/PyAoe30gYXMgVHJhbnNpdGlvbk9wdGlvbnMpKTtcbn1cbiIsIjxhIGNsYXNzPVwiZGJ4LWFuY2hvci1hIGRieC1hbmNob3Itc3JlZlwiIFthdHRyLnRhcmdldF09XCJ0YXJnZXRTaWduYWwoKVwiIFt1aVNyZWZdPVwidWlTcmVmU2lnbmFsKClcIiBbdWlQYXJhbXNdPVwidWlQYXJhbXNTaWduYWwoKVwiIFt1aU9wdGlvbnNdPVwidWlPcHRpb25zU2lnbmFsKClcIiB1aVNyZWZBY3RpdmU9XCJkYngtYW5jaG9yLWFjdGl2ZVwiIHVpU3JlZkFjdGl2ZUVxPVwiZGJ4LWFuY2hvci1hY3RpdmUtZXFcIj5cbiAgPGRieC1pbmplY3Rpb24gW3RlbXBsYXRlXT1cInRlbXBsYXRlQ29uZmlnU2lnbmFsKClcIj48L2RieC1pbmplY3Rpb24+XG48L2E+XG4iXX0=
76
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"anchor.component.js","sourceRoot":"","sources":["../../../../../../../../packages/dbx-web/src/lib/router/provider/uirouter/anchor.component.ts","../../../../../../../../packages/dbx-web/src/lib/router/provider/uirouter/anchor.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,EAAE,UAAU,EAAa,SAAS,EAAE,MAAM,eAAe,CAAC;AACvH,OAAO,EAAE,+BAA+B,EAAE,MAAM,4CAA4C,CAAC;AAC7F,OAAO,EAAuC,cAAc,EAAE,MAAM,mBAAmB,CAAC;AACxF,OAAO,EAAE,qBAAqB,EAAE,MAAM,mBAAmB,CAAC;AAC1D,OAAO,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAC;;;AAGtD;;GAEG;AAOH,MAAM,OAAO,+BAAgC,SAAQ,+BAA+B;IAC1E,qBAAqB,GAAsB,IAAI,CAAC;IAEvC,mBAAmB,GAAG,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,EAAE,YAAY,EAAE,SAAS,EAAE,CAAC,CAAC;IAEzF,aAAa,GAAG,SAAS,CAAC,QAAQ,CAAkC,QAAQ,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC,CAAC;IACpG,gBAAgB,GAAG,SAAS,CAAC,QAAQ,CAAkC,WAAW,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC,CAAC;IAC1G,oBAAoB,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,YAAY,EAAE,EAAE,QAAQ,IAAI,KAAK,CAAC,CAAC;IAEvF;;;;;;;;;OASG;IACgB,2BAA2B,GAAG,MAAM,CAAC,GAAG,EAAE;QAC3D,MAAM,aAAa,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC;QAC3C,MAAM,gBAAgB,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACjD,MAAM,cAAc,GAAG,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAEnD,IAAI,gBAAgB,EAAE,CAAC;YACrB,sDAAsD;YACtD,IAAI,IAAI,CAAC,qBAAqB,EAAE,CAAC;gBAC/B,IAAI,CAAC,qBAAqB,EAAE,CAAC;YAC/B,CAAC;YAED,IAAI,CAAC,cAAc,EAAE,CAAC;gBACpB,MAAM,aAAa,GAAG,CAAC,KAAiB,EAAE,EAAE;oBAC1C,gFAAgF;oBAChF,4EAA4E;oBAC5E,IAAI,KAAK,CAAC,OAAO,IAAI,KAAK,CAAC,OAAO,IAAI,KAAK,CAAC,QAAQ,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;wBAC3E,OAAO,CAAC,sCAAsC;oBAChD,CAAC;yBAAM,CAAC;wBACN,+DAA+D;wBAC/D,aAAa,EAAE,aAAa,CAAC,KAAK,EAAE,CAAC;wBACrC,kFAAkF;wBAClF,KAAK,CAAC,cAAc,EAAE,CAAC;wBACvB,KAAK,CAAC,eAAe,EAAE,CAAC;oBAC1B,CAAC;gBACH,CAAC,CAAC;gBAEF,IAAI,CAAC,qBAAqB,GAAG,GAAG,EAAE;oBAChC,gBAAgB,CAAC,aAAa,CAAC,mBAAmB,CAAC,OAAO,EAAE,aAAa,CAAC,CAAC;oBAC3E,OAAO,IAAI,CAAC,qBAAqB,CAAC;gBACpC,CAAC,CAAC;gBAEF,gBAAgB,CAAC,aAAa,CAAC,gBAAgB,CAAC,OAAO,EAAE,aAAa,EAAE;oBACtE,OAAO,EAAE,IAAI,CAAC,gGAAgG;iBAC/G,CAAC,CAAC;YACL,CAAC;QACH,CAAC;IACH,CAAC,CAAC,CAAC;IAEM,YAAY,GAAG,QAAQ,CAAc,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,mBAAmB,EAAE,EAAE,GAAG,IAAI,EAAE,CAAgB,CAAC,CAAC;IACnG,cAAc,GAAG,QAAQ,CAAkB,GAAG,EAAE,CAAC,IAAI,CAAC,mBAAmB,EAAE,EAAE,SAAS,CAAC,CAAC;IACxF,eAAe,GAAG,QAAQ,CAAoB,GAAG,EAAE,CAAC,IAAI,CAAC,mBAAmB,EAAE,EAAE,UAAU,IAAK,EAAwB,CAAC,CAAC;IAElI,WAAW;QACT,IAAI,IAAI,CAAC,qBAAqB,EAAE,CAAC;YAC/B,IAAI,CAAC,qBAAqB,EAAE,CAAC;QAC/B,CAAC;IACH,CAAC;wGAjEU,+BAA+B;4FAA/B,+BAA+B,4JAKqD,UAAU,wHACJ,UAAU,oECtBjH,0VAGA,2CDSY,cAAc,4WAAE,qBAAqB;;4FAIpC,+BAA+B;kBAN3C,SAAS;8BAEC,CAAC,cAAc,EAAE,qBAAqB,CAAC,mBAC/B,uBAAuB,CAAC,MAAM,cACnC,IAAI","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, effect, ElementRef, OnDestroy, viewChild } from '@angular/core';\nimport { AbstractDbxSegueAnchorDirective } from '../../layout/anchor/anchor.segue.directive';\nimport { Obj, StateOrName, TransitionOptions, UIRouterModule } from '@uirouter/angular';\nimport { DbxInjectionComponent } from '@dereekb/dbx-core';\nimport { toSignal } from '@angular/core/rxjs-interop';\nimport { Maybe } from '@dereekb/util';\n\n/**\n * SegueAnchor implementation for UIRouter.\n */\n@Component({\n  templateUrl: './anchor.component.html',\n  imports: [UIRouterModule, DbxInjectionComponent],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true\n})\nexport class DbxUIRouterSegueAnchorComponent extends AbstractDbxSegueAnchorDirective implements OnDestroy {\n  private _cleanupClickOverride: Maybe<() => void> = null;\n\n  private readonly _parentAnchorSignal = toSignal(this.parent.anchor$, { initialValue: undefined });\n\n  readonly anchorElement = viewChild.required<string, ElementRef<HTMLElement>>('anchor', { read: ElementRef });\n  readonly injectionElement = viewChild.required<string, ElementRef<HTMLElement>>('injection', { read: ElementRef });\n  readonly anchorDisabledSignal = computed(() => this.anchorSignal()?.disabled ?? false);\n\n  /**\n   * This effect exists to solve the issue of an injected element that utilizes event.stopPropogation() and doesn't also call event.preventDefault().\n   *\n   * We didn't want to use css's pointer-events: none as that would disable the Angular Material button effects.\n   *\n   * For example, dbx-button would call event.stopPropagation() on click, which would prevent the uiSref from being triggered, but the default behavior\n   * of the anchor element would still be triggered, causing the browser to load/reload the page at the given href instead of navigating to the new state using uiSref.\n   *\n   * NOTE: Those nested event listeners are still ultimately triggered.\n   */\n  protected readonly _overrideClickElementEffect = effect(() => {\n    const anchorElement = this.anchorElement();\n    const injectionElement = this.injectionElement();\n    const anchorDisabled = this.anchorDisabledSignal();\n\n    if (injectionElement) {\n      // cleanup/remove the previous/existing click function\n      if (this._cleanupClickOverride) {\n        this._cleanupClickOverride();\n      }\n\n      if (!anchorDisabled) {\n        const clickOverride = (event: MouseEvent) => {\n          // Allow ctrl+click, cmd+click, shift+click, and middle-click for new tab/window\n          // Don't preventDefault or stopPropagation - let browser handle it naturally\n          if (event.ctrlKey || event.metaKey || event.shiftKey || event.button === 1) {\n            return; // Browser will open in new tab/window\n          } else {\n            // otherwise, also trigger a click on the uiSref anchor element\n            anchorElement?.nativeElement.click();\n            // Prevents the default behavior of the anchor element's href from being triggered\n            event.preventDefault();\n            event.stopPropagation();\n          }\n        };\n\n        this._cleanupClickOverride = () => {\n          injectionElement.nativeElement.removeEventListener('click', clickOverride);\n          delete this._cleanupClickOverride;\n        };\n\n        injectionElement.nativeElement.addEventListener('click', clickOverride, {\n          capture: true // Use capture to ensure this event listener is called before any nested child's event listeners\n        });\n      }\n    }\n  });\n\n  readonly uiSrefSignal = computed<StateOrName>(() => (this._parentAnchorSignal()?.ref ?? '') as StateOrName);\n  readonly uiParamsSignal = computed<Obj | undefined>(() => this._parentAnchorSignal()?.refParams);\n  readonly uiOptionsSignal = computed<TransitionOptions>(() => this._parentAnchorSignal()?.refOptions ?? ({} as TransitionOptions));\n\n  ngOnDestroy(): void {\n    if (this._cleanupClickOverride) {\n      this._cleanupClickOverride();\n    }\n  }\n}\n","<a class=\"dbx-anchor-a dbx-anchor-sref\" #anchor [attr.target]=\"targetSignal()\" [uiSref]=\"uiSrefSignal()\" [uiParams]=\"uiParamsSignal()\" [uiOptions]=\"uiOptionsSignal()\" uiSrefActive=\"dbx-anchor-active\" uiSrefActiveEq=\"dbx-anchor-active-eq\">\n  <dbx-injection #injection [template]=\"templateConfigSignal()\"></dbx-injection>\n</a>\n"]}