@dereekb/dbx-web 12.6.12 → 12.6.13
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/extension/download/text/download.text.component.mjs +7 -39
- package/esm2022/lib/extension/download/text/download.text.module.mjs +2 -2
- package/esm2022/lib/extension/help/absract.help.widget.directive.mjs +20 -0
- package/esm2022/lib/extension/help/help.context.directive.mjs +29 -0
- package/esm2022/lib/extension/help/help.context.mjs +24 -0
- package/esm2022/lib/extension/help/help.context.service.mjs +34 -0
- package/esm2022/lib/extension/help/help.mjs +2 -0
- package/esm2022/lib/extension/help/help.providers.mjs +20 -0
- package/esm2022/lib/extension/help/help.view.list.component.mjs +60 -0
- package/esm2022/lib/extension/help/help.view.list.entry.component.mjs +58 -0
- package/esm2022/lib/extension/help/help.view.popover.button.component.mjs +45 -0
- package/esm2022/lib/extension/help/help.view.popover.component.mjs +49 -0
- package/esm2022/lib/extension/help/help.widget.mjs +6 -0
- package/esm2022/lib/extension/help/help.widget.service.mjs +84 -0
- package/esm2022/lib/extension/help/index.mjs +13 -0
- package/esm2022/lib/extension/index.mjs +2 -1
- package/esm2022/lib/layout/content/content.pit.directive.mjs +4 -2
- package/esm2022/lib/layout/text/copy.text.component.mjs +39 -0
- package/esm2022/lib/layout/text/copy.text.directive.mjs +56 -0
- package/esm2022/lib/layout/text/detail.block.component.mjs +5 -3
- package/esm2022/lib/layout/text/index.mjs +3 -1
- package/esm2022/lib/layout/text/text.module.mjs +6 -4
- package/esm2022/lib/util/clipboard.directive.mjs +20 -0
- package/esm2022/lib/util/clipboard.mjs +98 -0
- package/esm2022/lib/util/index.mjs +3 -1
- package/fesm2022/dereekb-dbx-web.mjs +592 -44
- package/fesm2022/dereekb-dbx-web.mjs.map +1 -1
- package/lib/extension/_extension.scss +19 -0
- package/lib/extension/download/text/download.text.component.d.ts +2 -4
- package/lib/extension/download/text/download.text.module.d.ts +1 -1
- package/lib/extension/help/_help.scss +27 -0
- package/lib/extension/help/absract.help.widget.directive.d.ts +12 -0
- package/lib/extension/help/help.context.d.ts +11 -0
- package/lib/extension/help/help.context.directive.d.ts +17 -0
- package/lib/extension/help/help.context.service.d.ts +20 -0
- package/lib/extension/help/help.d.ts +15 -0
- package/lib/extension/help/help.providers.d.ts +22 -0
- package/lib/extension/help/help.view.list.component.d.ts +20 -0
- package/lib/extension/help/help.view.list.entry.component.d.ts +16 -0
- package/lib/extension/help/help.view.popover.button.component.d.ts +19 -0
- package/lib/extension/help/help.view.popover.component.d.ts +60 -0
- package/lib/extension/help/help.widget.d.ts +42 -0
- package/lib/extension/help/help.widget.service.d.ts +55 -0
- package/lib/extension/help/index.d.ts +12 -0
- package/lib/extension/index.d.ts +1 -0
- package/lib/layout/content/_content.scss +4 -0
- package/lib/layout/content/content.pit.directive.d.ts +2 -1
- package/lib/layout/text/_text.scss +20 -2
- package/lib/layout/text/copy.text.component.d.ts +17 -0
- package/lib/layout/text/copy.text.directive.d.ts +23 -0
- package/lib/layout/text/detail.block.component.d.ts +2 -1
- package/lib/layout/text/index.d.ts +2 -0
- package/lib/layout/text/text.module.d.ts +10 -8
- package/lib/style/_config.scss +7 -1
- package/lib/style/_root-variables.scss +2 -0
- package/lib/style/_variables.scss +3 -0
- package/lib/util/clipboard.d.ts +78 -0
- package/lib/util/clipboard.directive.d.ts +12 -0
- package/lib/util/index.d.ts +2 -0
- package/package.json +1 -1
|
@@ -1,10 +1,7 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component, ElementRef, computed,
|
|
2
|
-
import { MatSnackBar } from '@angular/material/snack-bar';
|
|
1
|
+
import { ChangeDetectionStrategy, Component, ElementRef, computed, input, viewChild } from '@angular/core';
|
|
3
2
|
import { loadingStateContext, successResult, valueFromFinishedLoadingState, maybeValueFromObservableOrValue } from '@dereekb/rxjs';
|
|
4
|
-
import {
|
|
5
|
-
import {
|
|
6
|
-
import { Clipboard } from '@angular/cdk/clipboard';
|
|
7
|
-
import { AbstractSubscriptionDirective, DbxActionButtonDirective } from '@dereekb/dbx-core';
|
|
3
|
+
import { first, of, shareReplay, switchMap } from 'rxjs';
|
|
4
|
+
import { DbxActionButtonDirective } from '@dereekb/dbx-core';
|
|
8
5
|
import { toObservable, toSignal } from '@angular/core/rxjs-interop';
|
|
9
6
|
import { DbxLoadingComponent } from '../../../loading/loading.component';
|
|
10
7
|
import { NgTemplateOutlet } from '@angular/common';
|
|
@@ -13,14 +10,13 @@ import { DbxActionModule } from '../../../action/action.module';
|
|
|
13
10
|
import { DbxButtonSpacerDirective } from '../../../button/button.spacer.directive';
|
|
14
11
|
import { browserObjectUrlRef } from '@dereekb/browser';
|
|
15
12
|
import { DbxDownloadBlobButtonComponent } from '../blob/download.blob.button.component';
|
|
13
|
+
import { AbstractDbxClipboardDirective } from '../../../util/clipboard.directive';
|
|
16
14
|
import * as i0 from "@angular/core";
|
|
17
15
|
import * as i1 from "@dereekb/dbx-core";
|
|
18
16
|
/**
|
|
19
17
|
* View for previewing and downloading arbitrary text content.
|
|
20
18
|
*/
|
|
21
|
-
export class DbxDownloadTextViewComponent extends
|
|
22
|
-
_clipboard = inject(Clipboard);
|
|
23
|
-
_matSnackbar = inject(MatSnackBar);
|
|
19
|
+
export class DbxDownloadTextViewComponent extends AbstractDbxClipboardDirective {
|
|
24
20
|
_browserObjectUrl = browserObjectUrlRef();
|
|
25
21
|
downloadButton = viewChild('downloadButton', { read: ElementRef });
|
|
26
22
|
loadingText = input(undefined);
|
|
@@ -71,42 +67,14 @@ export class DbxDownloadTextViewComponent extends AbstractSubscriptionDirective
|
|
|
71
67
|
handleCopyToClipboard = () => {
|
|
72
68
|
return this.content$.pipe(first(), switchMap((downloadTextContent) => {
|
|
73
69
|
if (downloadTextContent) {
|
|
74
|
-
return
|
|
75
|
-
const pending = this._clipboard.beginCopy(downloadTextContent.content);
|
|
76
|
-
let secondsRemainingForCopy = 20; // attempt to copy for up to 20 seconds
|
|
77
|
-
const attempt = () => {
|
|
78
|
-
const copyIsFinished = pending.copy();
|
|
79
|
-
if (!copyIsFinished && --secondsRemainingForCopy) {
|
|
80
|
-
setTimeout(attempt, MS_IN_SECOND);
|
|
81
|
-
}
|
|
82
|
-
else {
|
|
83
|
-
// Remember to destroy when you're done!
|
|
84
|
-
pending.destroy();
|
|
85
|
-
if (copyIsFinished) {
|
|
86
|
-
resolve(true);
|
|
87
|
-
}
|
|
88
|
-
else {
|
|
89
|
-
reject(false);
|
|
90
|
-
}
|
|
91
|
-
}
|
|
92
|
-
};
|
|
93
|
-
attempt();
|
|
94
|
-
});
|
|
70
|
+
return this._copyToClipboard(downloadTextContent.content);
|
|
95
71
|
}
|
|
96
72
|
else {
|
|
97
73
|
return of(false);
|
|
98
74
|
}
|
|
99
|
-
}), tap((success) => {
|
|
100
|
-
if (success) {
|
|
101
|
-
this._matSnackbar.open('Copied to clipboard', undefined, { duration: 3 * MS_IN_SECOND });
|
|
102
|
-
}
|
|
103
|
-
else {
|
|
104
|
-
this._matSnackbar.open('Content failed to copy...', undefined, { duration: 3 * MS_IN_SECOND });
|
|
105
|
-
}
|
|
106
75
|
}));
|
|
107
76
|
};
|
|
108
77
|
ngOnDestroy() {
|
|
109
|
-
super.ngOnDestroy();
|
|
110
78
|
this._browserObjectUrl.destroy();
|
|
111
79
|
}
|
|
112
80
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxDownloadTextViewComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
@@ -116,4 +84,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
116
84
|
type: Component,
|
|
117
85
|
args: [{ selector: 'dbx-download-text-view', standalone: true, imports: [NgTemplateOutlet, DbxLoadingComponent, DbxActionModule, DbxActionButtonDirective, DbxButtonComponent, DbxButtonSpacerDirective, DbxDownloadBlobButtonComponent], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"dbx-download-text-view\">\n <dbx-loading [context]=\"context\" [linear]=\"linear()\" [text]=\"loadingText()\">\n <ng-container *ngTemplateOutlet=\"contentView\"></ng-container>\n </dbx-loading>\n</div>\n\n<!-- Template -->\n<ng-template #contentView>\n <div class=\"dbx-download-text-view-content\">\n @if (showTitle()) {\n <div class=\"dbx-download-text-view-content-title dbx-mb2 mat-subtitle-2\">{{ fileNameSignal() }}</div>\n }\n @if (showPreview()) {\n <div class=\"dbx-download-text-preview dbx-json dbx-content-pit dbx-content-pit-scrollable dbx-mb3\">{{ contentDataSignal() }}</div>\n }\n <div class=\"dbx-download-text-view-actions\">\n <dbx-button dbxAction dbxActionValue [raised]=\"true\" [dbxActionHandler]=\"handleCopyToClipboard\" icon=\"content_copy\" dbxActionButton text=\"Copy To Clipboard\"></dbx-button>\n <dbx-button-spacer></dbx-button-spacer>\n <dbx-download-blob-button [config]=\"downloadConfigSignal()\"></dbx-download-blob-button>\n </div>\n </div>\n</ng-template>\n" }]
|
|
118
86
|
}] });
|
|
119
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"download.text.component.js","sourceRoot":"","sources":["../../../../../../../../packages/dbx-web/src/lib/extension/download/text/download.text.component.ts","../../../../../../../../packages/dbx-web/src/lib/extension/download/text/download.text.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, ElementRef, OnDestroy, computed, inject, input, viewChild } from '@angular/core';\nimport { MatSnackBar } from '@angular/material/snack-bar';\nimport { WorkUsingObservable, LoadingState, loadingStateContext, successResult, valueFromFinishedLoadingState, MaybeObservableOrValue, maybeValueFromObservableOrValue } from '@dereekb/rxjs';\nimport { MS_IN_SECOND, type Maybe } from '@dereekb/util';\nimport { Observable, first, of, shareReplay, switchMap, tap } from 'rxjs';\nimport { Clipboard } from '@angular/cdk/clipboard';\nimport { DownloadTextContent } from './download.text';\nimport { AbstractSubscriptionDirective, DbxActionButtonDirective } from '@dereekb/dbx-core';\nimport { toObservable, toSignal } from '@angular/core/rxjs-interop';\nimport { DbxLoadingComponent } from '../../../loading/loading.component';\nimport { NgTemplateOutlet } from '@angular/common';\nimport { DbxButtonComponent } from '../../../button/button.component';\nimport { DbxActionModule } from '../../../action/action.module';\nimport { DbxButtonSpacerDirective } from '../../../button/button.spacer.directive';\nimport { browserObjectUrlRef } from '@dereekb/browser';\nimport { DbxDownloadBlobButtonComponent, DbxDownloadBlobButtonConfig } from '../blob/download.blob.button.component';\n\n/**\n * View for previewing and downloading arbitrary text content.\n */\n@Component({\n  templateUrl: './download.text.component.html',\n  selector: 'dbx-download-text-view',\n  standalone: true,\n  imports: [NgTemplateOutlet, DbxLoadingComponent, DbxActionModule, DbxActionButtonDirective, DbxButtonComponent, DbxButtonSpacerDirective, DbxDownloadBlobButtonComponent],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class DbxDownloadTextViewComponent extends AbstractSubscriptionDirective implements OnDestroy {\n  private readonly _clipboard = inject(Clipboard);\n  private readonly _matSnackbar = inject(MatSnackBar);\n\n  private readonly _browserObjectUrl = browserObjectUrlRef();\n\n  readonly downloadButton = viewChild<string, Maybe<ElementRef>>('downloadButton', { read: ElementRef });\n\n  readonly loadingText = input<Maybe<string>>(undefined);\n  readonly linear = input<Maybe<boolean>>(undefined);\n  readonly showTitle = input<boolean>(true);\n  readonly showPreview = input<boolean>(true);\n\n  readonly content = input<Maybe<DownloadTextContent>>(undefined);\n  readonly contentState = input<MaybeObservableOrValue<LoadingState<DownloadTextContent>>>(undefined);\n\n  readonly contentState$ = toObservable(this.contentState).pipe(maybeValueFromObservableOrValue(), shareReplay(1));\n\n  readonly contentStateSignal = toSignal(this.contentState$);\n\n  readonly contentLoadingStateSignal = computed(() => {\n    const content = this.content();\n    const contentState = this.contentStateSignal();\n\n    let result: Maybe<LoadingState<DownloadTextContent>>;\n\n    if (contentState) {\n      result = contentState;\n    } else if (content) {\n      result = successResult(content);\n    }\n\n    return result;\n  });\n\n  readonly contentLoadingState$ = toObservable(this.contentLoadingStateSignal);\n  readonly content$: Observable<Maybe<DownloadTextContent>> = this.contentLoadingState$.pipe(\n    switchMap((x) => {\n      if (x) {\n        return of(x).pipe(valueFromFinishedLoadingState());\n      } else {\n        return of(undefined);\n      }\n    })\n  );\n\n  readonly contentSignal = toSignal(this.content$);\n  readonly contentDataSignal = computed(() => this.contentSignal()?.content);\n  readonly fileNameSignal = computed(() => this.contentSignal()?.name ?? 'download.txt');\n\n  readonly downloadConfigSignal = computed(() => {\n    const content = this.contentSignal();\n    const fileName = this.fileNameSignal();\n    let result: Maybe<DbxDownloadBlobButtonConfig> = undefined;\n\n    if (content) {\n      result = {\n        blob: new Blob([content.content], { type: content.mimeType ?? 'application/octet-stream' }),\n        fileName\n      };\n    }\n\n    return result;\n  });\n\n  readonly context = loadingStateContext({ obs: this.contentLoadingState$ });\n\n  readonly handleCopyToClipboard: WorkUsingObservable = () => {\n    return this.content$.pipe(\n      first(),\n      switchMap((downloadTextContent: Maybe<DownloadTextContent>) => {\n        if (downloadTextContent) {\n          return new Promise<boolean>((resolve, reject) => {\n            const pending = this._clipboard.beginCopy(downloadTextContent.content);\n\n            let secondsRemainingForCopy = 20; // attempt to copy for up to 20 seconds\n\n            const attempt = () => {\n              const copyIsFinished = pending.copy();\n\n              if (!copyIsFinished && --secondsRemainingForCopy) {\n                setTimeout(attempt, MS_IN_SECOND);\n              } else {\n                // Remember to destroy when you're done!\n                pending.destroy();\n\n                if (copyIsFinished) {\n                  resolve(true);\n                } else {\n                  reject(false);\n                }\n              }\n            };\n\n            attempt();\n          });\n        } else {\n          return of(false);\n        }\n      }),\n      tap((success) => {\n        if (success) {\n          this._matSnackbar.open('Copied to clipboard', undefined, { duration: 3 * MS_IN_SECOND });\n        } else {\n          this._matSnackbar.open('Content failed to copy...', undefined, { duration: 3 * MS_IN_SECOND });\n        }\n      })\n    );\n  };\n\n  override ngOnDestroy() {\n    super.ngOnDestroy();\n    this._browserObjectUrl.destroy();\n  }\n}\n","<div class=\"dbx-download-text-view\">\n  <dbx-loading [context]=\"context\" [linear]=\"linear()\" [text]=\"loadingText()\">\n    <ng-container *ngTemplateOutlet=\"contentView\"></ng-container>\n  </dbx-loading>\n</div>\n\n<!-- Template -->\n<ng-template #contentView>\n  <div class=\"dbx-download-text-view-content\">\n    @if (showTitle()) {\n      <div class=\"dbx-download-text-view-content-title dbx-mb2 mat-subtitle-2\">{{ fileNameSignal() }}</div>\n    }\n    @if (showPreview()) {\n      <div class=\"dbx-download-text-preview dbx-json dbx-content-pit dbx-content-pit-scrollable dbx-mb3\">{{ contentDataSignal() }}</div>\n    }\n    <div class=\"dbx-download-text-view-actions\">\n      <dbx-button dbxAction dbxActionValue [raised]=\"true\" [dbxActionHandler]=\"handleCopyToClipboard\" icon=\"content_copy\" dbxActionButton text=\"Copy To Clipboard\"></dbx-button>\n      <dbx-button-spacer></dbx-button-spacer>\n      <dbx-download-blob-button [config]=\"downloadConfigSignal()\"></dbx-download-blob-button>\n    </div>\n  </div>\n</ng-template>\n"]}
|
|
87
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"download.text.component.js","sourceRoot":"","sources":["../../../../../../../../packages/dbx-web/src/lib/extension/download/text/download.text.component.ts","../../../../../../../../packages/dbx-web/src/lib/extension/download/text/download.text.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, ElementRef, OnDestroy, computed, input, viewChild } from '@angular/core';\nimport { WorkUsingObservable, LoadingState, loadingStateContext, successResult, valueFromFinishedLoadingState, MaybeObservableOrValue, maybeValueFromObservableOrValue } from '@dereekb/rxjs';\nimport { type Maybe } from '@dereekb/util';\nimport { Observable, first, of, shareReplay, switchMap } from 'rxjs';\nimport { DownloadTextContent } from './download.text';\nimport { DbxActionButtonDirective } from '@dereekb/dbx-core';\nimport { toObservable, toSignal } from '@angular/core/rxjs-interop';\nimport { DbxLoadingComponent } from '../../../loading/loading.component';\nimport { NgTemplateOutlet } from '@angular/common';\nimport { DbxButtonComponent } from '../../../button/button.component';\nimport { DbxActionModule } from '../../../action/action.module';\nimport { DbxButtonSpacerDirective } from '../../../button/button.spacer.directive';\nimport { browserObjectUrlRef } from '@dereekb/browser';\nimport { DbxDownloadBlobButtonComponent, DbxDownloadBlobButtonConfig } from '../blob/download.blob.button.component';\nimport { AbstractDbxClipboardDirective } from '../../../util/clipboard.directive';\n\n/**\n * View for previewing and downloading arbitrary text content.\n */\n@Component({\n  templateUrl: './download.text.component.html',\n  selector: 'dbx-download-text-view',\n  standalone: true,\n  imports: [NgTemplateOutlet, DbxLoadingComponent, DbxActionModule, DbxActionButtonDirective, DbxButtonComponent, DbxButtonSpacerDirective, DbxDownloadBlobButtonComponent],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class DbxDownloadTextViewComponent extends AbstractDbxClipboardDirective implements OnDestroy {\n  private readonly _browserObjectUrl = browserObjectUrlRef();\n\n  readonly downloadButton = viewChild<string, Maybe<ElementRef>>('downloadButton', { read: ElementRef });\n\n  readonly loadingText = input<Maybe<string>>(undefined);\n  readonly linear = input<Maybe<boolean>>(undefined);\n  readonly showTitle = input<boolean>(true);\n  readonly showPreview = input<boolean>(true);\n\n  readonly content = input<Maybe<DownloadTextContent>>(undefined);\n  readonly contentState = input<MaybeObservableOrValue<LoadingState<DownloadTextContent>>>(undefined);\n\n  readonly contentState$ = toObservable(this.contentState).pipe(maybeValueFromObservableOrValue(), shareReplay(1));\n\n  readonly contentStateSignal = toSignal(this.contentState$);\n\n  readonly contentLoadingStateSignal = computed(() => {\n    const content = this.content();\n    const contentState = this.contentStateSignal();\n\n    let result: Maybe<LoadingState<DownloadTextContent>>;\n\n    if (contentState) {\n      result = contentState;\n    } else if (content) {\n      result = successResult(content);\n    }\n\n    return result;\n  });\n\n  readonly contentLoadingState$ = toObservable(this.contentLoadingStateSignal);\n  readonly content$: Observable<Maybe<DownloadTextContent>> = this.contentLoadingState$.pipe(\n    switchMap((x) => {\n      if (x) {\n        return of(x).pipe(valueFromFinishedLoadingState());\n      } else {\n        return of(undefined);\n      }\n    })\n  );\n\n  readonly contentSignal = toSignal(this.content$);\n  readonly contentDataSignal = computed(() => this.contentSignal()?.content);\n  readonly fileNameSignal = computed(() => this.contentSignal()?.name ?? 'download.txt');\n\n  readonly downloadConfigSignal = computed(() => {\n    const content = this.contentSignal();\n    const fileName = this.fileNameSignal();\n    let result: Maybe<DbxDownloadBlobButtonConfig> = undefined;\n\n    if (content) {\n      result = {\n        blob: new Blob([content.content], { type: content.mimeType ?? 'application/octet-stream' }),\n        fileName\n      };\n    }\n\n    return result;\n  });\n\n  readonly context = loadingStateContext({ obs: this.contentLoadingState$ });\n\n  readonly handleCopyToClipboard: WorkUsingObservable = () => {\n    return this.content$.pipe(\n      first(),\n      switchMap((downloadTextContent: Maybe<DownloadTextContent>) => {\n        if (downloadTextContent) {\n          return this._copyToClipboard(downloadTextContent.content);\n        } else {\n          return of(false);\n        }\n      })\n    );\n  };\n\n  ngOnDestroy() {\n    this._browserObjectUrl.destroy();\n  }\n}\n","<div class=\"dbx-download-text-view\">\n  <dbx-loading [context]=\"context\" [linear]=\"linear()\" [text]=\"loadingText()\">\n    <ng-container *ngTemplateOutlet=\"contentView\"></ng-container>\n  </dbx-loading>\n</div>\n\n<!-- Template -->\n<ng-template #contentView>\n  <div class=\"dbx-download-text-view-content\">\n    @if (showTitle()) {\n      <div class=\"dbx-download-text-view-content-title dbx-mb2 mat-subtitle-2\">{{ fileNameSignal() }}</div>\n    }\n    @if (showPreview()) {\n      <div class=\"dbx-download-text-preview dbx-json dbx-content-pit dbx-content-pit-scrollable dbx-mb3\">{{ contentDataSignal() }}</div>\n    }\n    <div class=\"dbx-download-text-view-actions\">\n      <dbx-button dbxAction dbxActionValue [raised]=\"true\" [dbxActionHandler]=\"handleCopyToClipboard\" icon=\"content_copy\" dbxActionButton text=\"Copy To Clipboard\"></dbx-button>\n      <dbx-button-spacer></dbx-button-spacer>\n      <dbx-download-blob-button [config]=\"downloadConfigSignal()\"></dbx-download-blob-button>\n    </div>\n  </div>\n</ng-template>\n"]}
|
|
@@ -3,7 +3,7 @@ import { DbxDownloadTextViewComponent } from './download.text.component';
|
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
const importsAndExports = [DbxDownloadTextViewComponent];
|
|
5
5
|
/**
|
|
6
|
-
* @deprecated import
|
|
6
|
+
* @deprecated import DbxDownloadTextViewComponent directly instead.
|
|
7
7
|
*/
|
|
8
8
|
export class DbxDownloadTextModule {
|
|
9
9
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxDownloadTextModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
@@ -17,4 +17,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
17
17
|
exports: importsAndExports
|
|
18
18
|
}]
|
|
19
19
|
}] });
|
|
20
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG93bmxvYWQudGV4dC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3NyYy9saWIvZXh0ZW5zaW9uL2Rvd25sb2FkL3RleHQvZG93bmxvYWQudGV4dC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsNEJBQTRCLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQzs7QUFFekUsTUFBTSxpQkFBaUIsR0FBRyxDQUFDLDRCQUE0QixDQUFDLENBQUM7QUFFekQ7O0dBRUc7QUFLSCxNQUFNLE9BQU8scUJBQXFCO3dHQUFyQixxQkFBcUI7eUdBQXJCLHFCQUFxQixZQVRQLDRCQUE0QixhQUE1Qiw0QkFBNEI7eUdBUzFDLHFCQUFxQixZQUh2QixpQkFBaUI7OzRGQUdmLHFCQUFxQjtrQkFKakMsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUUsaUJBQWlCO29CQUMxQixPQUFPLEVBQUUsaUJBQWlCO2lCQUMzQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBEYnhEb3dubG9hZFRleHRWaWV3Q29tcG9uZW50IH0gZnJvbSAnLi9kb3dubG9hZC50ZXh0LmNvbXBvbmVudCc7XG5cbmNvbnN0IGltcG9ydHNBbmRFeHBvcnRzID0gW0RieERvd25sb2FkVGV4dFZpZXdDb21wb25lbnRdO1xuXG4vKipcbiAqIEBkZXByZWNhdGVkIGltcG9ydCBEYnhEb3dubG9hZFRleHRWaWV3Q29tcG9uZW50IGRpcmVjdGx5IGluc3RlYWQuXG4gKi9cbkBOZ01vZHVsZSh7XG4gIGltcG9ydHM6IGltcG9ydHNBbmRFeHBvcnRzLFxuICBleHBvcnRzOiBpbXBvcnRzQW5kRXhwb3J0c1xufSlcbmV4cG9ydCBjbGFzcyBEYnhEb3dubG9hZFRleHRNb2R1bGUge31cbiJdfQ==
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { Directive, inject } from '@angular/core';
|
|
2
|
+
import { DBX_HELP_WIDGET_ENTRY_DATA_TOKEN } from './help.widget';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
/**
|
|
5
|
+
* Abstract help widget directive that injects the help widget data.
|
|
6
|
+
*/
|
|
7
|
+
export class DbxAbstractHelpWidgetDirective {
|
|
8
|
+
helpWidgetData = inject(DBX_HELP_WIDGET_ENTRY_DATA_TOKEN);
|
|
9
|
+
helpWidgetEntry = this.helpWidgetData.helpWidgetEntry;
|
|
10
|
+
get helpContextString() {
|
|
11
|
+
return this.helpWidgetEntry.helpContextString;
|
|
12
|
+
}
|
|
13
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxAbstractHelpWidgetDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
14
|
+
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: DbxAbstractHelpWidgetDirective, ngImport: i0 });
|
|
15
|
+
}
|
|
16
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxAbstractHelpWidgetDirective, decorators: [{
|
|
17
|
+
type: Directive,
|
|
18
|
+
args: [{}]
|
|
19
|
+
}] });
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWJzcmFjdC5oZWxwLndpZGdldC5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3NyYy9saWIvZXh0ZW5zaW9uL2hlbHAvYWJzcmFjdC5oZWxwLndpZGdldC5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDbEQsT0FBTyxFQUFFLGdDQUFnQyxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUdqRTs7R0FFRztBQUVILE1BQU0sT0FBZ0IsOEJBQThCO0lBQ3pDLGNBQWMsR0FBRyxNQUFNLENBQUMsZ0NBQWdDLENBQUMsQ0FBQztJQUMxRCxlQUFlLEdBQUcsSUFBSSxDQUFDLGNBQWMsQ0FBQyxlQUFlLENBQUM7SUFFL0QsSUFBSSxpQkFBaUI7UUFDbkIsT0FBTyxJQUFJLENBQUMsZUFBZSxDQUFDLGlCQUFpQixDQUFDO0lBQ2hELENBQUM7d0dBTm1CLDhCQUE4Qjs0RkFBOUIsOEJBQThCOzs0RkFBOUIsOEJBQThCO2tCQURuRCxTQUFTO21CQUFDLEVBQUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIGluamVjdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgREJYX0hFTFBfV0lER0VUX0VOVFJZX0RBVEFfVE9LRU4gfSBmcm9tICcuL2hlbHAud2lkZ2V0JztcbmltcG9ydCB7IERieEhlbHBDb250ZXh0U3RyaW5nIH0gZnJvbSAnLi9oZWxwJztcblxuLyoqXG4gKiBBYnN0cmFjdCBoZWxwIHdpZGdldCBkaXJlY3RpdmUgdGhhdCBpbmplY3RzIHRoZSBoZWxwIHdpZGdldCBkYXRhLlxuICovXG5ARGlyZWN0aXZlKHt9KVxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIERieEFic3RyYWN0SGVscFdpZGdldERpcmVjdGl2ZSB7XG4gIHJlYWRvbmx5IGhlbHBXaWRnZXREYXRhID0gaW5qZWN0KERCWF9IRUxQX1dJREdFVF9FTlRSWV9EQVRBX1RPS0VOKTtcbiAgcmVhZG9ubHkgaGVscFdpZGdldEVudHJ5ID0gdGhpcy5oZWxwV2lkZ2V0RGF0YS5oZWxwV2lkZ2V0RW50cnk7XG5cbiAgZ2V0IGhlbHBDb250ZXh0U3RyaW5nKCk6IERieEhlbHBDb250ZXh0U3RyaW5nIHtcbiAgICByZXR1cm4gdGhpcy5oZWxwV2lkZ2V0RW50cnkuaGVscENvbnRleHRTdHJpbmc7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { Directive, input } from '@angular/core';
|
|
2
|
+
import { asArray } from '@dereekb/util';
|
|
3
|
+
import { map } from 'rxjs';
|
|
4
|
+
import { toObservable } from '@angular/core/rxjs-interop';
|
|
5
|
+
import { registerHelpContextStringsWithDbxHelpContextService } from './help.context';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
/**
|
|
8
|
+
* Directive that registers one or more help contexts to the current context.
|
|
9
|
+
*/
|
|
10
|
+
export class DbxHelpContextDirective {
|
|
11
|
+
/**
|
|
12
|
+
* The input help context string(s) to add.
|
|
13
|
+
*/
|
|
14
|
+
dbxHelpContext = input.required();
|
|
15
|
+
helpContextStrings$ = toObservable(this.dbxHelpContext).pipe(map(asArray));
|
|
16
|
+
constructor() {
|
|
17
|
+
registerHelpContextStringsWithDbxHelpContextService(this.helpContextStrings$);
|
|
18
|
+
}
|
|
19
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxHelpContextDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
20
|
+
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.13", type: DbxHelpContextDirective, isStandalone: true, selector: "[dbxHelpContext]", inputs: { dbxHelpContext: { classPropertyName: "dbxHelpContext", publicName: "dbxHelpContext", isSignal: true, isRequired: true, transformFunction: null } }, ngImport: i0 });
|
|
21
|
+
}
|
|
22
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxHelpContextDirective, decorators: [{
|
|
23
|
+
type: Directive,
|
|
24
|
+
args: [{
|
|
25
|
+
selector: '[dbxHelpContext]',
|
|
26
|
+
standalone: true
|
|
27
|
+
}]
|
|
28
|
+
}], ctorParameters: () => [] });
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVscC5jb250ZXh0LmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC13ZWIvc3JjL2xpYi9leHRlbnNpb24vaGVscC9oZWxwLmNvbnRleHQuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRWpELE9BQU8sRUFBZ0IsT0FBTyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3RELE9BQU8sRUFBRSxHQUFHLEVBQWMsTUFBTSxNQUFNLENBQUM7QUFDdkMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQzFELE9BQU8sRUFBRSxtREFBbUQsRUFBRSxNQUFNLGdCQUFnQixDQUFDOztBQUVyRjs7R0FFRztBQUtILE1BQU0sT0FBTyx1QkFBdUI7SUFDbEM7O09BRUc7SUFDTSxjQUFjLEdBQUcsS0FBSyxDQUFDLFFBQVEsRUFBc0MsQ0FBQztJQUN0RSxtQkFBbUIsR0FBdUMsWUFBWSxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUM7SUFFeEg7UUFDRSxtREFBbUQsQ0FBQyxJQUFJLENBQUMsbUJBQW1CLENBQUMsQ0FBQztJQUNoRixDQUFDO3dHQVRVLHVCQUF1Qjs0RkFBdkIsdUJBQXVCOzs0RkFBdkIsdUJBQXVCO2tCQUpuQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxrQkFBa0I7b0JBQzVCLFVBQVUsRUFBRSxJQUFJO2lCQUNqQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgaW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IERieEhlbHBDb250ZXh0U3RyaW5nIH0gZnJvbSAnLi9oZWxwJztcbmltcG9ydCB7IEFycmF5T3JWYWx1ZSwgYXNBcnJheSB9IGZyb20gJ0BkZXJlZWtiL3V0aWwnO1xuaW1wb3J0IHsgbWFwLCBPYnNlcnZhYmxlIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyB0b09ic2VydmFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlL3J4anMtaW50ZXJvcCc7XG5pbXBvcnQgeyByZWdpc3RlckhlbHBDb250ZXh0U3RyaW5nc1dpdGhEYnhIZWxwQ29udGV4dFNlcnZpY2UgfSBmcm9tICcuL2hlbHAuY29udGV4dCc7XG5cbi8qKlxuICogRGlyZWN0aXZlIHRoYXQgcmVnaXN0ZXJzIG9uZSBvciBtb3JlIGhlbHAgY29udGV4dHMgdG8gdGhlIGN1cnJlbnQgY29udGV4dC5cbiAqL1xuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnW2RieEhlbHBDb250ZXh0XScsXG4gIHN0YW5kYWxvbmU6IHRydWVcbn0pXG5leHBvcnQgY2xhc3MgRGJ4SGVscENvbnRleHREaXJlY3RpdmUge1xuICAvKipcbiAgICogVGhlIGlucHV0IGhlbHAgY29udGV4dCBzdHJpbmcocykgdG8gYWRkLlxuICAgKi9cbiAgcmVhZG9ubHkgZGJ4SGVscENvbnRleHQgPSBpbnB1dC5yZXF1aXJlZDxBcnJheU9yVmFsdWU8RGJ4SGVscENvbnRleHRTdHJpbmc+PigpO1xuICByZWFkb25seSBoZWxwQ29udGV4dFN0cmluZ3MkOiBPYnNlcnZhYmxlPERieEhlbHBDb250ZXh0U3RyaW5nW10+ID0gdG9PYnNlcnZhYmxlKHRoaXMuZGJ4SGVscENvbnRleHQpLnBpcGUobWFwKGFzQXJyYXkpKTtcblxuICBjb25zdHJ1Y3RvcigpIHtcbiAgICByZWdpc3RlckhlbHBDb250ZXh0U3RyaW5nc1dpdGhEYnhIZWxwQ29udGV4dFNlcnZpY2UodGhpcy5oZWxwQ29udGV4dFN0cmluZ3MkKTtcbiAgfVxufVxuIl19
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { asObservable } from '@dereekb/rxjs';
|
|
2
|
+
import { DestroyRef, inject } from '@angular/core';
|
|
3
|
+
import { DbxHelpContextService } from './help.context.service';
|
|
4
|
+
/**
|
|
5
|
+
* Registers the input observable with the DbxHelpContextService.
|
|
6
|
+
*
|
|
7
|
+
* Must be run in an injectable context.
|
|
8
|
+
*
|
|
9
|
+
* Automatically cleans up, but returns a destroy function for manual cleanup.
|
|
10
|
+
*/
|
|
11
|
+
export function registerHelpContextStringsWithDbxHelpContextService(helpContextStrings) {
|
|
12
|
+
const helpContextService = inject(DbxHelpContextService);
|
|
13
|
+
const destroyRef = inject(DestroyRef);
|
|
14
|
+
const helpContextReference = {
|
|
15
|
+
helpContextStrings$: asObservable(helpContextStrings)
|
|
16
|
+
};
|
|
17
|
+
helpContextService.register(helpContextReference);
|
|
18
|
+
function _destroy() {
|
|
19
|
+
helpContextService.unregister(helpContextReference);
|
|
20
|
+
}
|
|
21
|
+
destroyRef.onDestroy(_destroy);
|
|
22
|
+
return _destroy;
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVscC5jb250ZXh0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LXdlYi9zcmMvbGliL2V4dGVuc2lvbi9oZWxwL2hlbHAuY29udGV4dC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUEwQixNQUFNLGVBQWUsQ0FBQztBQUVyRSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNuRCxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUcvRDs7Ozs7O0dBTUc7QUFDSCxNQUFNLFVBQVUsbURBQW1ELENBQUMsa0JBQTZEO0lBQy9ILE1BQU0sa0JBQWtCLEdBQUcsTUFBTSxDQUFDLHFCQUFxQixDQUFDLENBQUM7SUFDekQsTUFBTSxVQUFVLEdBQUcsTUFBTSxDQUFDLFVBQVUsQ0FBQyxDQUFDO0lBRXRDLE1BQU0sb0JBQW9CLEdBQTRCO1FBQ3BELG1CQUFtQixFQUFFLFlBQVksQ0FBQyxrQkFBa0IsQ0FBQztLQUN0RCxDQUFDO0lBRUYsa0JBQWtCLENBQUMsUUFBUSxDQUFDLG9CQUFvQixDQUFDLENBQUM7SUFFbEQsU0FBUyxRQUFRO1FBQ2Ysa0JBQWtCLENBQUMsVUFBVSxDQUFDLG9CQUFvQixDQUFDLENBQUM7SUFDdEQsQ0FBQztJQUVELFVBQVUsQ0FBQyxTQUFTLENBQUMsUUFBUSxDQUFDLENBQUM7SUFFL0IsT0FBTyxRQUFRLENBQUM7QUFDbEIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGFzT2JzZXJ2YWJsZSwgdHlwZSBPYnNlcnZhYmxlT3JWYWx1ZSB9IGZyb20gJ0BkZXJlZWtiL3J4anMnO1xuaW1wb3J0IHsgdHlwZSBEYnhIZWxwQ29udGV4dFJlZmVyZW5jZSwgdHlwZSBEYnhIZWxwQ29udGV4dFN0cmluZyB9IGZyb20gJy4vaGVscCc7XG5pbXBvcnQgeyBEZXN0cm95UmVmLCBpbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IERieEhlbHBDb250ZXh0U2VydmljZSB9IGZyb20gJy4vaGVscC5jb250ZXh0LnNlcnZpY2UnO1xuaW1wb3J0IHsgdHlwZSBEZXN0cm95RnVuY3Rpb24gfSBmcm9tICdAZGVyZWVrYi91dGlsJztcblxuLyoqXG4gKiBSZWdpc3RlcnMgdGhlIGlucHV0IG9ic2VydmFibGUgd2l0aCB0aGUgRGJ4SGVscENvbnRleHRTZXJ2aWNlLlxuICpcbiAqIE11c3QgYmUgcnVuIGluIGFuIGluamVjdGFibGUgY29udGV4dC5cbiAqXG4gKiBBdXRvbWF0aWNhbGx5IGNsZWFucyB1cCwgYnV0IHJldHVybnMgYSBkZXN0cm95IGZ1bmN0aW9uIGZvciBtYW51YWwgY2xlYW51cC5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHJlZ2lzdGVySGVscENvbnRleHRTdHJpbmdzV2l0aERieEhlbHBDb250ZXh0U2VydmljZShoZWxwQ29udGV4dFN0cmluZ3M6IE9ic2VydmFibGVPclZhbHVlPERieEhlbHBDb250ZXh0U3RyaW5nW10+KTogRGVzdHJveUZ1bmN0aW9uIHtcbiAgY29uc3QgaGVscENvbnRleHRTZXJ2aWNlID0gaW5qZWN0KERieEhlbHBDb250ZXh0U2VydmljZSk7XG4gIGNvbnN0IGRlc3Ryb3lSZWYgPSBpbmplY3QoRGVzdHJveVJlZik7XG5cbiAgY29uc3QgaGVscENvbnRleHRSZWZlcmVuY2U6IERieEhlbHBDb250ZXh0UmVmZXJlbmNlID0ge1xuICAgIGhlbHBDb250ZXh0U3RyaW5ncyQ6IGFzT2JzZXJ2YWJsZShoZWxwQ29udGV4dFN0cmluZ3MpXG4gIH07XG5cbiAgaGVscENvbnRleHRTZXJ2aWNlLnJlZ2lzdGVyKGhlbHBDb250ZXh0UmVmZXJlbmNlKTtcblxuICBmdW5jdGlvbiBfZGVzdHJveSgpIHtcbiAgICBoZWxwQ29udGV4dFNlcnZpY2UudW5yZWdpc3RlcihoZWxwQ29udGV4dFJlZmVyZW5jZSk7XG4gIH1cblxuICBkZXN0cm95UmVmLm9uRGVzdHJveShfZGVzdHJveSk7XG5cbiAgcmV0dXJuIF9kZXN0cm95O1xufVxuIl19
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import { BehaviorSubject, combineLatest, defaultIfEmpty, map, shareReplay, switchMap } from 'rxjs';
|
|
3
|
+
import { distinctUntilHasDifferentValues } from '@dereekb/rxjs';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
/**
|
|
6
|
+
* Service that tracks all active help context strings in the current context.
|
|
7
|
+
*/
|
|
8
|
+
export class DbxHelpContextService {
|
|
9
|
+
_contextReferences = new BehaviorSubject(new Set());
|
|
10
|
+
/**
|
|
11
|
+
* Observable of all currently active help context strings.
|
|
12
|
+
*/
|
|
13
|
+
activeHelpContextStrings$ = this._contextReferences.pipe(switchMap((allReferences) => combineLatest(Array.from(allReferences).map((ref) => ref.helpContextStrings$)).pipe(map((x) => x.flat()), defaultIfEmpty([]), map((x) => new Set(x)))), distinctUntilHasDifferentValues(), shareReplay(1));
|
|
14
|
+
activeHelpContextStringsArray$ = this.activeHelpContextStrings$.pipe(map((x) => Array.from(x)), shareReplay(1));
|
|
15
|
+
register(reference) {
|
|
16
|
+
const referenceSet = this._contextReferences.value;
|
|
17
|
+
referenceSet.add(reference);
|
|
18
|
+
this._contextReferences.next(referenceSet);
|
|
19
|
+
}
|
|
20
|
+
unregister(reference) {
|
|
21
|
+
const referenceSet = this._contextReferences.value;
|
|
22
|
+
referenceSet.delete(reference);
|
|
23
|
+
this._contextReferences.next(referenceSet);
|
|
24
|
+
}
|
|
25
|
+
ngOnDestroy() {
|
|
26
|
+
this._contextReferences.complete();
|
|
27
|
+
}
|
|
28
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxHelpContextService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
29
|
+
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxHelpContextService });
|
|
30
|
+
}
|
|
31
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxHelpContextService, decorators: [{
|
|
32
|
+
type: Injectable
|
|
33
|
+
}] });
|
|
34
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVscC5jb250ZXh0LnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3NyYy9saWIvZXh0ZW5zaW9uL2hlbHAvaGVscC5jb250ZXh0LnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBYSxNQUFNLGVBQWUsQ0FBQztBQUN0RCxPQUFPLEVBQUUsZUFBZSxFQUFjLGFBQWEsRUFBRSxjQUFjLEVBQUUsR0FBRyxFQUFFLFdBQVcsRUFBRSxTQUFTLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFFL0csT0FBTyxFQUFFLCtCQUErQixFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUVoRTs7R0FFRztBQUVILE1BQU0sT0FBTyxxQkFBcUI7SUFDZixrQkFBa0IsR0FBRyxJQUFJLGVBQWUsQ0FBK0IsSUFBSSxHQUFHLEVBQUUsQ0FBQyxDQUFDO0lBRW5HOztPQUVHO0lBQ00seUJBQXlCLEdBQTBDLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxJQUFJLENBQ3RHLFNBQVMsQ0FBQyxDQUFDLGFBQWEsRUFBRSxFQUFFLENBQzFCLGFBQWEsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLEdBQUcsRUFBRSxFQUFFLENBQUMsR0FBRyxDQUFDLG1CQUFtQixDQUFDLENBQUMsQ0FBQyxJQUFJLENBQ2pGLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLElBQUksRUFBRSxDQUFDLEVBQ3BCLGNBQWMsQ0FBQyxFQUFFLENBQUMsRUFDbEIsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxJQUFJLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUN2QixDQUNGLEVBQ0QsK0JBQStCLEVBQUUsRUFDakMsV0FBVyxDQUFDLENBQUMsQ0FBQyxDQUNmLENBQUM7SUFFTyw4QkFBOEIsR0FBRyxJQUFJLENBQUMseUJBQXlCLENBQUMsSUFBSSxDQUMzRSxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFDekIsV0FBVyxDQUFDLENBQUMsQ0FBQyxDQUNmLENBQUM7SUFFRixRQUFRLENBQUMsU0FBa0M7UUFDekMsTUFBTSxZQUFZLEdBQUcsSUFBSSxDQUFDLGtCQUFrQixDQUFDLEtBQUssQ0FBQztRQUNuRCxZQUFZLENBQUMsR0FBRyxDQUFDLFNBQVMsQ0FBQyxDQUFDO1FBQzVCLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLENBQUM7SUFDN0MsQ0FBQztJQUVELFVBQVUsQ0FBQyxTQUFrQztRQUMzQyxNQUFNLFlBQVksR0FBRyxJQUFJLENBQUMsa0JBQWtCLENBQUMsS0FBSyxDQUFDO1FBQ25ELFlBQVksQ0FBQyxNQUFNLENBQUMsU0FBUyxDQUFDLENBQUM7UUFDL0IsSUFBSSxDQUFDLGtCQUFrQixDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQztJQUM3QyxDQUFDO0lBRUQsV0FBVztRQUNULElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxRQUFRLEVBQUUsQ0FBQztJQUNyQyxDQUFDO3dHQXJDVSxxQkFBcUI7NEdBQXJCLHFCQUFxQjs7NEZBQXJCLHFCQUFxQjtrQkFEakMsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUsIE9uRGVzdHJveSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQmVoYXZpb3JTdWJqZWN0LCBPYnNlcnZhYmxlLCBjb21iaW5lTGF0ZXN0LCBkZWZhdWx0SWZFbXB0eSwgbWFwLCBzaGFyZVJlcGxheSwgc3dpdGNoTWFwIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBEYnhIZWxwQ29udGV4dFN0cmluZywgRGJ4SGVscENvbnRleHRSZWZlcmVuY2UgfSBmcm9tICcuL2hlbHAnO1xuaW1wb3J0IHsgZGlzdGluY3RVbnRpbEhhc0RpZmZlcmVudFZhbHVlcyB9IGZyb20gJ0BkZXJlZWtiL3J4anMnO1xuXG4vKipcbiAqIFNlcnZpY2UgdGhhdCB0cmFja3MgYWxsIGFjdGl2ZSBoZWxwIGNvbnRleHQgc3RyaW5ncyBpbiB0aGUgY3VycmVudCBjb250ZXh0LlxuICovXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgRGJ4SGVscENvbnRleHRTZXJ2aWNlIGltcGxlbWVudHMgT25EZXN0cm95IHtcbiAgcHJpdmF0ZSByZWFkb25seSBfY29udGV4dFJlZmVyZW5jZXMgPSBuZXcgQmVoYXZpb3JTdWJqZWN0PFNldDxEYnhIZWxwQ29udGV4dFJlZmVyZW5jZT4+KG5ldyBTZXQoKSk7XG5cbiAgLyoqXG4gICAqIE9ic2VydmFibGUgb2YgYWxsIGN1cnJlbnRseSBhY3RpdmUgaGVscCBjb250ZXh0IHN0cmluZ3MuXG4gICAqL1xuICByZWFkb25seSBhY3RpdmVIZWxwQ29udGV4dFN0cmluZ3MkOiBPYnNlcnZhYmxlPFNldDxEYnhIZWxwQ29udGV4dFN0cmluZz4+ID0gdGhpcy5fY29udGV4dFJlZmVyZW5jZXMucGlwZShcbiAgICBzd2l0Y2hNYXAoKGFsbFJlZmVyZW5jZXMpID0+XG4gICAgICBjb21iaW5lTGF0ZXN0KEFycmF5LmZyb20oYWxsUmVmZXJlbmNlcykubWFwKChyZWYpID0+IHJlZi5oZWxwQ29udGV4dFN0cmluZ3MkKSkucGlwZShcbiAgICAgICAgbWFwKCh4KSA9PiB4LmZsYXQoKSksXG4gICAgICAgIGRlZmF1bHRJZkVtcHR5KFtdKSxcbiAgICAgICAgbWFwKCh4KSA9PiBuZXcgU2V0KHgpKVxuICAgICAgKVxuICAgICksXG4gICAgZGlzdGluY3RVbnRpbEhhc0RpZmZlcmVudFZhbHVlcygpLFxuICAgIHNoYXJlUmVwbGF5KDEpXG4gICk7XG5cbiAgcmVhZG9ubHkgYWN0aXZlSGVscENvbnRleHRTdHJpbmdzQXJyYXkkID0gdGhpcy5hY3RpdmVIZWxwQ29udGV4dFN0cmluZ3MkLnBpcGUoXG4gICAgbWFwKCh4KSA9PiBBcnJheS5mcm9tKHgpKSxcbiAgICBzaGFyZVJlcGxheSgxKVxuICApO1xuXG4gIHJlZ2lzdGVyKHJlZmVyZW5jZTogRGJ4SGVscENvbnRleHRSZWZlcmVuY2UpOiB2b2lkIHtcbiAgICBjb25zdCByZWZlcmVuY2VTZXQgPSB0aGlzLl9jb250ZXh0UmVmZXJlbmNlcy52YWx1ZTtcbiAgICByZWZlcmVuY2VTZXQuYWRkKHJlZmVyZW5jZSk7XG4gICAgdGhpcy5fY29udGV4dFJlZmVyZW5jZXMubmV4dChyZWZlcmVuY2VTZXQpO1xuICB9XG5cbiAgdW5yZWdpc3RlcihyZWZlcmVuY2U6IERieEhlbHBDb250ZXh0UmVmZXJlbmNlKTogdm9pZCB7XG4gICAgY29uc3QgcmVmZXJlbmNlU2V0ID0gdGhpcy5fY29udGV4dFJlZmVyZW5jZXMudmFsdWU7XG4gICAgcmVmZXJlbmNlU2V0LmRlbGV0ZShyZWZlcmVuY2UpO1xuICAgIHRoaXMuX2NvbnRleHRSZWZlcmVuY2VzLm5leHQocmVmZXJlbmNlU2V0KTtcbiAgfVxuXG4gIG5nT25EZXN0cm95KCk6IHZvaWQge1xuICAgIHRoaXMuX2NvbnRleHRSZWZlcmVuY2VzLmNvbXBsZXRlKCk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVscC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC13ZWIvc3JjL2xpYi9leHRlbnNpb24vaGVscC9oZWxwLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyB0eXBlIE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcblxuLyoqXG4gKiBTdHJpbmcgdHlwZSBmb3IgaWRlbnRpZnlpbmcgaGVscCB0b3BpY3NcbiAqL1xuZXhwb3J0IHR5cGUgRGJ4SGVscENvbnRleHRTdHJpbmcgPSBzdHJpbmc7XG5cbi8qKlxuICogUmVmZXJlbmNlIG9iamVjdCBmb3IgdHJhY2tpbmcgaGVscCBjb250ZXh0IHJlZ2lzdHJhdGlvbnMuXG4gKiBVc2VkIGludGVybmFsbHkgdG8gdHJhY2sgbXVsdGlwbGUgZGlyZWN0aXZlcyB3aXRoIHRoZSBzYW1lIGNvbnRleHQgc3RyaW5nLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIERieEhlbHBDb250ZXh0UmVmZXJlbmNlIHtcbiAgLyoqXG4gICAqIE9ic2VydmFibGUgb2YgY29udGV4dCBzdHJpbmdzIHRoYXQgdGhpcyByZWZlcmVuY2UgcHJvdmlkZXMuXG4gICAqL1xuICByZWFkb25seSBoZWxwQ29udGV4dFN0cmluZ3MkOiBPYnNlcnZhYmxlPERieEhlbHBDb250ZXh0U3RyaW5nW10+O1xufVxuIl19
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { makeEnvironmentProviders } from '@angular/core';
|
|
2
|
+
import { DbxHelpWidgetService, DbxHelpWidgetServiceConfig } from './help.widget.service';
|
|
3
|
+
import { DbxHelpContextService } from './help.context.service';
|
|
4
|
+
/**
|
|
5
|
+
* Creates EnvironmentProviders for the help context system.
|
|
6
|
+
*
|
|
7
|
+
* @param config Optional configuration
|
|
8
|
+
* @returns EnvironmentProviders
|
|
9
|
+
*/
|
|
10
|
+
export function provideDbxHelpServices(config) {
|
|
11
|
+
const providers = [DbxHelpWidgetService, DbxHelpContextService];
|
|
12
|
+
if (config?.dbxHelpWidgetServiceConfigFactory) {
|
|
13
|
+
providers.push({
|
|
14
|
+
provide: DbxHelpWidgetServiceConfig,
|
|
15
|
+
useFactory: config.dbxHelpWidgetServiceConfigFactory
|
|
16
|
+
});
|
|
17
|
+
}
|
|
18
|
+
return makeEnvironmentProviders(providers);
|
|
19
|
+
}
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVscC5wcm92aWRlcnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3NyYy9saWIvZXh0ZW5zaW9uL2hlbHAvaGVscC5wcm92aWRlcnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUEyRCx3QkFBd0IsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNsSCxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUN6RixPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQWlCL0Q7Ozs7O0dBS0c7QUFDSCxNQUFNLFVBQVUsc0JBQXNCLENBQUMsTUFBcUM7SUFDMUUsTUFBTSxTQUFTLEdBQWUsQ0FBQyxvQkFBb0IsRUFBRSxxQkFBcUIsQ0FBQyxDQUFDO0lBRTVFLElBQUksTUFBTSxFQUFFLGlDQUFpQyxFQUFFLENBQUM7UUFDOUMsU0FBUyxDQUFDLElBQUksQ0FBQztZQUNiLE9BQU8sRUFBRSwwQkFBMEI7WUFDbkMsVUFBVSxFQUFFLE1BQU0sQ0FBQyxpQ0FBaUM7U0FDckQsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELE9BQU8sd0JBQXdCLENBQUMsU0FBUyxDQUFDLENBQUM7QUFDN0MsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHR5cGUgRW52aXJvbm1lbnRQcm92aWRlcnMsIHR5cGUgSW5qZWN0b3IsIHR5cGUgUHJvdmlkZXIsIG1ha2VFbnZpcm9ubWVudFByb3ZpZGVycyB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRGJ4SGVscFdpZGdldFNlcnZpY2UsIERieEhlbHBXaWRnZXRTZXJ2aWNlQ29uZmlnIH0gZnJvbSAnLi9oZWxwLndpZGdldC5zZXJ2aWNlJztcbmltcG9ydCB7IERieEhlbHBDb250ZXh0U2VydmljZSB9IGZyb20gJy4vaGVscC5jb250ZXh0LnNlcnZpY2UnO1xuXG4vKipcbiAqIEZhY3RvcnkgZm9yIERieEhlbHBXaWRnZXRTZXJ2aWNlQ29uZmlnLlxuICovXG5leHBvcnQgdHlwZSBEYnhIZWxwV2lkZ2V0U2VydmljZUNvbmZpZ0ZhY3RvcnkgPSAoaW5qZWN0b3I6IEluamVjdG9yKSA9PiBEYnhIZWxwV2lkZ2V0U2VydmljZUNvbmZpZztcblxuLyoqXG4gKiBDb25maWd1cmF0aW9uIGZvciBwcm92aWRlRGJ4SGVscFNlcnZpY2VzKCkuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgUHJvdmlkZURieEhlbHBTZXJ2aWNlc0NvbmZpZyB7XG4gIC8qKlxuICAgKiBJbml0aWFsIGhlbHAgd2lkZ2V0IGVudHJpZXMgdG8gcmVnaXN0ZXIuXG4gICAqL1xuICByZWFkb25seSBkYnhIZWxwV2lkZ2V0U2VydmljZUNvbmZpZ0ZhY3Rvcnk/OiBEYnhIZWxwV2lkZ2V0U2VydmljZUNvbmZpZ0ZhY3Rvcnk7XG59XG5cbi8qKlxuICogQ3JlYXRlcyBFbnZpcm9ubWVudFByb3ZpZGVycyBmb3IgdGhlIGhlbHAgY29udGV4dCBzeXN0ZW0uXG4gKlxuICogQHBhcmFtIGNvbmZpZyBPcHRpb25hbCBjb25maWd1cmF0aW9uXG4gKiBAcmV0dXJucyBFbnZpcm9ubWVudFByb3ZpZGVyc1xuICovXG5leHBvcnQgZnVuY3Rpb24gcHJvdmlkZURieEhlbHBTZXJ2aWNlcyhjb25maWc/OiBQcm92aWRlRGJ4SGVscFNlcnZpY2VzQ29uZmlnKTogRW52aXJvbm1lbnRQcm92aWRlcnMge1xuICBjb25zdCBwcm92aWRlcnM6IFByb3ZpZGVyW10gPSBbRGJ4SGVscFdpZGdldFNlcnZpY2UsIERieEhlbHBDb250ZXh0U2VydmljZV07XG5cbiAgaWYgKGNvbmZpZz8uZGJ4SGVscFdpZGdldFNlcnZpY2VDb25maWdGYWN0b3J5KSB7XG4gICAgcHJvdmlkZXJzLnB1c2goe1xuICAgICAgcHJvdmlkZTogRGJ4SGVscFdpZGdldFNlcnZpY2VDb25maWcsXG4gICAgICB1c2VGYWN0b3J5OiBjb25maWcuZGJ4SGVscFdpZGdldFNlcnZpY2VDb25maWdGYWN0b3J5XG4gICAgfSk7XG4gIH1cblxuICByZXR1cm4gbWFrZUVudmlyb25tZW50UHJvdmlkZXJzKHByb3ZpZGVycyk7XG59XG4iXX0=
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, computed, inject, input } from '@angular/core';
|
|
2
|
+
import { toObservable, toSignal } from '@angular/core/rxjs-interop';
|
|
3
|
+
import { asObservable, distinctUntilHasDifferentValues } from '@dereekb/rxjs';
|
|
4
|
+
import { map, of, shareReplay, switchMap } from 'rxjs';
|
|
5
|
+
import { DbxHelpWidgetService } from './help.widget.service';
|
|
6
|
+
import { DbxHelpViewListEntryComponent } from './help.view.list.entry.component';
|
|
7
|
+
import { asArray } from '@dereekb/util';
|
|
8
|
+
import { MatAccordion } from '@angular/material/expansion';
|
|
9
|
+
import { DbxListEmptyContentComponent } from '../../layout/list/list.content.empty.component';
|
|
10
|
+
import * as i0 from "@angular/core";
|
|
11
|
+
export class DbxHelpViewListComponent {
|
|
12
|
+
helpWidgetService = inject(DbxHelpWidgetService);
|
|
13
|
+
/**
|
|
14
|
+
* Whether the accordion should allow multiple expanded panels.
|
|
15
|
+
*/
|
|
16
|
+
multi = input(true);
|
|
17
|
+
helpContextStrings = input.required();
|
|
18
|
+
helpContextStrings$ = toObservable(this.helpContextStrings).pipe(switchMap((x) => asObservable(x) ?? of([])), map(asArray), distinctUntilHasDifferentValues(), shareReplay(1));
|
|
19
|
+
helpContextStringsSignal = toSignal(this.helpContextStrings$, { initialValue: [] });
|
|
20
|
+
helpWidgetEntriesSignal = computed(() => this.helpWidgetService.getHelpWidgetEntriesForHelpContextStrings(this.helpContextStringsSignal()));
|
|
21
|
+
hasNoHelpWidgetEntriesSignal = computed(() => !this.helpWidgetEntriesSignal()?.length);
|
|
22
|
+
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: `
|
|
24
|
+
<mat-accordion [multi]="multi()">
|
|
25
|
+
@for (widgetEntry of helpWidgetEntriesSignal(); track widgetEntry.helpContextString) {
|
|
26
|
+
<dbx-help-view-list-entry [helpWidgetEntry]="widgetEntry"></dbx-help-view-list-entry>
|
|
27
|
+
}
|
|
28
|
+
</mat-accordion>
|
|
29
|
+
@if (hasNoHelpWidgetEntriesSignal()) {
|
|
30
|
+
<dbx-list-empty-content>
|
|
31
|
+
<ng-content select="[empty]"></ng-content>
|
|
32
|
+
</dbx-list-empty-content>
|
|
33
|
+
}
|
|
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 });
|
|
35
|
+
}
|
|
36
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxHelpViewListComponent, decorators: [{
|
|
37
|
+
type: Component,
|
|
38
|
+
args: [{
|
|
39
|
+
selector: 'dbx-help-view-list',
|
|
40
|
+
template: `
|
|
41
|
+
<mat-accordion [multi]="multi()">
|
|
42
|
+
@for (widgetEntry of helpWidgetEntriesSignal(); track widgetEntry.helpContextString) {
|
|
43
|
+
<dbx-help-view-list-entry [helpWidgetEntry]="widgetEntry"></dbx-help-view-list-entry>
|
|
44
|
+
}
|
|
45
|
+
</mat-accordion>
|
|
46
|
+
@if (hasNoHelpWidgetEntriesSignal()) {
|
|
47
|
+
<dbx-list-empty-content>
|
|
48
|
+
<ng-content select="[empty]"></ng-content>
|
|
49
|
+
</dbx-list-empty-content>
|
|
50
|
+
}
|
|
51
|
+
`,
|
|
52
|
+
host: {
|
|
53
|
+
class: 'dbx-help-view-list dbx-block'
|
|
54
|
+
},
|
|
55
|
+
imports: [MatAccordion, DbxHelpViewListEntryComponent, DbxListEmptyContentComponent],
|
|
56
|
+
standalone: true,
|
|
57
|
+
changeDetection: ChangeDetectionStrategy.OnPush
|
|
58
|
+
}]
|
|
59
|
+
}] });
|
|
60
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVscC52aWV3Lmxpc3QuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LXdlYi9zcmMvbGliL2V4dGVuc2lvbi9oZWxwL2hlbHAudmlldy5saXN0LmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLFFBQVEsRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTVGLE9BQU8sRUFBRSxZQUFZLEVBQUUsUUFBUSxFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFDcEUsT0FBTyxFQUFFLFlBQVksRUFBRSwrQkFBK0IsRUFBcUIsTUFBTSxlQUFlLENBQUM7QUFDakcsT0FBTyxFQUFFLEdBQUcsRUFBYyxFQUFFLEVBQUUsV0FBVyxFQUFFLFNBQVMsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUNuRSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUM3RCxPQUFPLEVBQUUsNkJBQTZCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUNqRixPQUFPLEVBQWdCLE9BQU8sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN0RCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFDM0QsT0FBTyxFQUFFLDRCQUE0QixFQUFFLE1BQU0sZ0RBQWdELENBQUM7O0FBdUI5RixNQUFNLE9BQU8sd0JBQXdCO0lBQzFCLGlCQUFpQixHQUFHLE1BQU0sQ0FBQyxvQkFBb0IsQ0FBQyxDQUFDO0lBRTFEOztPQUVHO0lBQ00sS0FBSyxHQUFHLEtBQUssQ0FBVSxJQUFJLENBQUMsQ0FBQztJQUU3QixrQkFBa0IsR0FBRyxLQUFLLENBQUMsUUFBUSxFQUF5RCxDQUFDO0lBQzdGLG1CQUFtQixHQUF1QyxZQUFZLENBQUMsSUFBSSxDQUFDLGtCQUFrQixDQUFDLENBQUMsSUFBSSxDQUMzRyxTQUFTLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUMsSUFBSSxFQUFFLENBQUMsRUFBRSxDQUFDLENBQUMsRUFDM0MsR0FBRyxDQUFDLE9BQU8sQ0FBQyxFQUNaLCtCQUErQixFQUFFLEVBQ2pDLFdBQVcsQ0FBQyxDQUFDLENBQUMsQ0FDZixDQUFDO0lBRU8sd0JBQXdCLEdBQUcsUUFBUSxDQUFDLElBQUksQ0FBQyxtQkFBbUIsRUFBRSxFQUFFLFlBQVksRUFBRSxFQUFFLEVBQUUsQ0FBQyxDQUFDO0lBQ3BGLHVCQUF1QixHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsaUJBQWlCLENBQUMseUNBQXlDLENBQUMsSUFBSSxDQUFDLHdCQUF3QixFQUFFLENBQUMsQ0FBQyxDQUFDO0lBRTVJLDRCQUE0QixHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxDQUFDLElBQUksQ0FBQyx1QkFBdUIsRUFBRSxFQUFFLE1BQU0sQ0FBQyxDQUFDO3dHQW5CckYsd0JBQXdCOzRGQUF4Qix3QkFBd0IsMGFBbkJ6Qjs7Ozs7Ozs7Ozs7R0FXVCw0REFJUyxZQUFZLCtJQUFFLDZCQUE2QixrR0FBRSw0QkFBNEI7OzRGQUl4RSx3QkFBd0I7a0JBckJwQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxvQkFBb0I7b0JBQzlCLFFBQVEsRUFBRTs7Ozs7Ozs7Ozs7R0FXVDtvQkFDRCxJQUFJLEVBQUU7d0JBQ0osS0FBSyxFQUFFLDhCQUE4QjtxQkFDdEM7b0JBQ0QsT0FBTyxFQUFFLENBQUMsWUFBWSxFQUFFLDZCQUE2QixFQUFFLDRCQUE0QixDQUFDO29CQUNwRixVQUFVLEVBQUUsSUFBSTtvQkFDaEIsZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07aUJBQ2hEIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgY29tcHV0ZWQsIGluamVjdCwgaW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IERieEhlbHBDb250ZXh0U3RyaW5nIH0gZnJvbSAnLi9oZWxwJztcbmltcG9ydCB7IHRvT2JzZXJ2YWJsZSwgdG9TaWduYWwgfSBmcm9tICdAYW5ndWxhci9jb3JlL3J4anMtaW50ZXJvcCc7XG5pbXBvcnQgeyBhc09ic2VydmFibGUsIGRpc3RpbmN0VW50aWxIYXNEaWZmZXJlbnRWYWx1ZXMsIE9ic2VydmFibGVPclZhbHVlIH0gZnJvbSAnQGRlcmVla2Ivcnhqcyc7XG5pbXBvcnQgeyBtYXAsIE9ic2VydmFibGUsIG9mLCBzaGFyZVJlcGxheSwgc3dpdGNoTWFwIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBEYnhIZWxwV2lkZ2V0U2VydmljZSB9IGZyb20gJy4vaGVscC53aWRnZXQuc2VydmljZSc7XG5pbXBvcnQgeyBEYnhIZWxwVmlld0xpc3RFbnRyeUNvbXBvbmVudCB9IGZyb20gJy4vaGVscC52aWV3Lmxpc3QuZW50cnkuY29tcG9uZW50JztcbmltcG9ydCB7IEFycmF5T3JWYWx1ZSwgYXNBcnJheSB9IGZyb20gJ0BkZXJlZWtiL3V0aWwnO1xuaW1wb3J0IHsgTWF0QWNjb3JkaW9uIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvZXhwYW5zaW9uJztcbmltcG9ydCB7IERieExpc3RFbXB0eUNvbnRlbnRDb21wb25lbnQgfSBmcm9tICcuLi8uLi9sYXlvdXQvbGlzdC9saXN0LmNvbnRlbnQuZW1wdHkuY29tcG9uZW50JztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnZGJ4LWhlbHAtdmlldy1saXN0JyxcbiAgdGVtcGxhdGU6IGBcbiAgICA8bWF0LWFjY29yZGlvbiBbbXVsdGldPVwibXVsdGkoKVwiPlxuICAgICAgQGZvciAod2lkZ2V0RW50cnkgb2YgaGVscFdpZGdldEVudHJpZXNTaWduYWwoKTsgdHJhY2sgd2lkZ2V0RW50cnkuaGVscENvbnRleHRTdHJpbmcpIHtcbiAgICAgICAgPGRieC1oZWxwLXZpZXctbGlzdC1lbnRyeSBbaGVscFdpZGdldEVudHJ5XT1cIndpZGdldEVudHJ5XCI+PC9kYngtaGVscC12aWV3LWxpc3QtZW50cnk+XG4gICAgICB9XG4gICAgPC9tYXQtYWNjb3JkaW9uPlxuICAgIEBpZiAoaGFzTm9IZWxwV2lkZ2V0RW50cmllc1NpZ25hbCgpKSB7XG4gICAgICA8ZGJ4LWxpc3QtZW1wdHktY29udGVudD5cbiAgICAgICAgPG5nLWNvbnRlbnQgc2VsZWN0PVwiW2VtcHR5XVwiPjwvbmctY29udGVudD5cbiAgICAgIDwvZGJ4LWxpc3QtZW1wdHktY29udGVudD5cbiAgICB9XG4gIGAsXG4gIGhvc3Q6IHtcbiAgICBjbGFzczogJ2RieC1oZWxwLXZpZXctbGlzdCBkYngtYmxvY2snXG4gIH0sXG4gIGltcG9ydHM6IFtNYXRBY2NvcmRpb24sIERieEhlbHBWaWV3TGlzdEVudHJ5Q29tcG9uZW50LCBEYnhMaXN0RW1wdHlDb250ZW50Q29tcG9uZW50XSxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcbn0pXG5leHBvcnQgY2xhc3MgRGJ4SGVscFZpZXdMaXN0Q29tcG9uZW50IHtcbiAgcmVhZG9ubHkgaGVscFdpZGdldFNlcnZpY2UgPSBpbmplY3QoRGJ4SGVscFdpZGdldFNlcnZpY2UpO1xuXG4gIC8qKlxuICAgKiBXaGV0aGVyIHRoZSBhY2NvcmRpb24gc2hvdWxkIGFsbG93IG11bHRpcGxlIGV4cGFuZGVkIHBhbmVscy5cbiAgICovXG4gIHJlYWRvbmx5IG11bHRpID0gaW5wdXQ8Ym9vbGVhbj4odHJ1ZSk7XG5cbiAgcmVhZG9ubHkgaGVscENvbnRleHRTdHJpbmdzID0gaW5wdXQucmVxdWlyZWQ8T2JzZXJ2YWJsZU9yVmFsdWU8QXJyYXlPclZhbHVlPERieEhlbHBDb250ZXh0U3RyaW5nPj4+KCk7XG4gIHJlYWRvbmx5IGhlbHBDb250ZXh0U3RyaW5ncyQ6IE9ic2VydmFibGU8RGJ4SGVscENvbnRleHRTdHJpbmdbXT4gPSB0b09ic2VydmFibGUodGhpcy5oZWxwQ29udGV4dFN0cmluZ3MpLnBpcGUoXG4gICAgc3dpdGNoTWFwKCh4KSA9PiBhc09ic2VydmFibGUoeCkgPz8gb2YoW10pKSxcbiAgICBtYXAoYXNBcnJheSksXG4gICAgZGlzdGluY3RVbnRpbEhhc0RpZmZlcmVudFZhbHVlcygpLFxuICAgIHNoYXJlUmVwbGF5KDEpXG4gICk7XG5cbiAgcmVhZG9ubHkgaGVscENvbnRleHRTdHJpbmdzU2lnbmFsID0gdG9TaWduYWwodGhpcy5oZWxwQ29udGV4dFN0cmluZ3MkLCB7IGluaXRpYWxWYWx1ZTogW10gfSk7XG4gIHJlYWRvbmx5IGhlbHBXaWRnZXRFbnRyaWVzU2lnbmFsID0gY29tcHV0ZWQoKCkgPT4gdGhpcy5oZWxwV2lkZ2V0U2VydmljZS5nZXRIZWxwV2lkZ2V0RW50cmllc0ZvckhlbHBDb250ZXh0U3RyaW5ncyh0aGlzLmhlbHBDb250ZXh0U3RyaW5nc1NpZ25hbCgpKSk7XG5cbiAgcmVhZG9ubHkgaGFzTm9IZWxwV2lkZ2V0RW50cmllc1NpZ25hbCA9IGNvbXB1dGVkKCgpID0+ICF0aGlzLmhlbHBXaWRnZXRFbnRyaWVzU2lnbmFsKCk/Lmxlbmd0aCk7XG59XG4iXX0=
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, computed, inject, input } from '@angular/core';
|
|
2
|
+
import { DbxInjectionComponent } from '@dereekb/dbx-core';
|
|
3
|
+
import { MatExpansionPanel, MatExpansionPanelHeader, MatExpansionPanelTitle, MatExpansionPanelDescription, MatExpansionPanelContent } from '@angular/material/expansion';
|
|
4
|
+
import { MatIcon } from '@angular/material/icon';
|
|
5
|
+
import { AsyncPipe } from '@angular/common';
|
|
6
|
+
import { DBX_HELP_WIDGET_ENTRY_DATA_TOKEN } from './help.widget';
|
|
7
|
+
import { DbxHelpWidgetService } from './help.widget.service';
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
9
|
+
export class DbxHelpViewListEntryComponent {
|
|
10
|
+
helpWidgetEntry = input.required();
|
|
11
|
+
helpWidgetService = inject(DbxHelpWidgetService);
|
|
12
|
+
titleSignal = computed(() => this.helpWidgetEntry().title);
|
|
13
|
+
iconSignal = computed(() => this.helpWidgetEntry().icon ?? this.helpWidgetService.getDefaultIcon());
|
|
14
|
+
widgetInjectionConfigSignal = computed(() => {
|
|
15
|
+
const helpWidgetEntry = this.helpWidgetEntry();
|
|
16
|
+
const widgetComponentClass = helpWidgetEntry.widgetComponentClass;
|
|
17
|
+
const widgetData = {
|
|
18
|
+
helpWidgetEntry
|
|
19
|
+
};
|
|
20
|
+
const config = {
|
|
21
|
+
componentClass: widgetComponentClass,
|
|
22
|
+
providers: [
|
|
23
|
+
{
|
|
24
|
+
provide: DBX_HELP_WIDGET_ENTRY_DATA_TOKEN,
|
|
25
|
+
useValue: widgetData
|
|
26
|
+
}
|
|
27
|
+
]
|
|
28
|
+
};
|
|
29
|
+
return config;
|
|
30
|
+
});
|
|
31
|
+
headerInjectionConfigSignal = computed(() => {
|
|
32
|
+
const helpWidgetEntry = this.helpWidgetEntry();
|
|
33
|
+
const headerComponentClass = helpWidgetEntry.headerComponentClass;
|
|
34
|
+
let config = undefined;
|
|
35
|
+
if (headerComponentClass) {
|
|
36
|
+
const widgetData = {
|
|
37
|
+
helpWidgetEntry
|
|
38
|
+
};
|
|
39
|
+
config = {
|
|
40
|
+
componentClass: headerComponentClass,
|
|
41
|
+
providers: [
|
|
42
|
+
{
|
|
43
|
+
provide: DBX_HELP_WIDGET_ENTRY_DATA_TOKEN,
|
|
44
|
+
useValue: widgetData
|
|
45
|
+
}
|
|
46
|
+
]
|
|
47
|
+
};
|
|
48
|
+
}
|
|
49
|
+
return config;
|
|
50
|
+
});
|
|
51
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxHelpViewListEntryComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
52
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: DbxHelpViewListEntryComponent, isStandalone: true, selector: "dbx-help-view-list-entry", inputs: { helpWidgetEntry: { classPropertyName: "helpWidgetEntry", publicName: "helpWidgetEntry", isSignal: true, isRequired: true, transformFunction: null } }, ngImport: i0, template: "<mat-expansion-panel>\n <mat-expansion-panel-header>\n <mat-panel-title>\n @if (iconSignal(); as icon) {\n <mat-icon class=\"dbx-button-spacer\">{{ icon }}</mat-icon>\n }\n <span>{{ titleSignal() }}</span>\n </mat-panel-title>\n <ng-container>\n @if (headerInjectionConfigSignal(); as headerInjectionConfig) {\n <mat-panel-description>\n <span class=\"dbx-spacer\"></span>\n <dbx-injection [config]=\"headerInjectionConfig\"></dbx-injection>\n </mat-panel-description>\n }\n </ng-container>\n </mat-expansion-panel-header>\n <ng-template matExpansionPanelContent>\n <div class=\"dbx-help-view-list-entry-content\">\n <dbx-injection [config]=\"widgetInjectionConfigSignal()\"></dbx-injection>\n </div>\n </ng-template>\n</mat-expansion-panel>\n", dependencies: [{ kind: "component", type: DbxInjectionComponent, selector: "dbx-injection, [dbxInjection], [dbx-injection]", inputs: ["config", "template"] }, { kind: "component", type: MatExpansionPanel, selector: "mat-expansion-panel", inputs: ["hideToggle", "togglePosition"], outputs: ["afterExpand", "afterCollapse"], exportAs: ["matExpansionPanel"] }, { kind: "component", type: MatExpansionPanelHeader, selector: "mat-expansion-panel-header", inputs: ["expandedHeight", "collapsedHeight", "tabIndex"] }, { kind: "directive", type: MatExpansionPanelTitle, selector: "mat-panel-title" }, { kind: "directive", type: MatExpansionPanelDescription, selector: "mat-panel-description" }, { kind: "directive", type: MatExpansionPanelContent, selector: "ng-template[matExpansionPanelContent]" }, { kind: "component", type: MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
53
|
+
}
|
|
54
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxHelpViewListEntryComponent, decorators: [{
|
|
55
|
+
type: Component,
|
|
56
|
+
args: [{ selector: 'dbx-help-view-list-entry', imports: [DbxInjectionComponent, MatExpansionPanel, MatExpansionPanelHeader, MatExpansionPanelTitle, MatExpansionPanelDescription, MatExpansionPanelContent, MatIcon, AsyncPipe], changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, template: "<mat-expansion-panel>\n <mat-expansion-panel-header>\n <mat-panel-title>\n @if (iconSignal(); as icon) {\n <mat-icon class=\"dbx-button-spacer\">{{ icon }}</mat-icon>\n }\n <span>{{ titleSignal() }}</span>\n </mat-panel-title>\n <ng-container>\n @if (headerInjectionConfigSignal(); as headerInjectionConfig) {\n <mat-panel-description>\n <span class=\"dbx-spacer\"></span>\n <dbx-injection [config]=\"headerInjectionConfig\"></dbx-injection>\n </mat-panel-description>\n }\n </ng-container>\n </mat-expansion-panel-header>\n <ng-template matExpansionPanelContent>\n <div class=\"dbx-help-view-list-entry-content\">\n <dbx-injection [config]=\"widgetInjectionConfigSignal()\"></dbx-injection>\n </div>\n </ng-template>\n</mat-expansion-panel>\n" }]
|
|
57
|
+
}] });
|
|
58
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVscC52aWV3Lmxpc3QuZW50cnkuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LXdlYi9zcmMvbGliL2V4dGVuc2lvbi9oZWxwL2hlbHAudmlldy5saXN0LmVudHJ5LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC13ZWIvc3JjL2xpYi9leHRlbnNpb24vaGVscC9oZWxwLnZpZXcubGlzdC5lbnRyeS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLFFBQVEsRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFVLE1BQU0sZUFBZSxDQUFDO0FBQ3BHLE9BQU8sRUFBRSxxQkFBcUIsRUFBK0IsTUFBTSxtQkFBbUIsQ0FBQztBQUN2RixPQUFPLEVBQUUsaUJBQWlCLEVBQUUsdUJBQXVCLEVBQUUsc0JBQXNCLEVBQUUsNEJBQTRCLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQUN6SyxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDakQsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQzVDLE9BQU8sRUFBRSxnQ0FBZ0MsRUFBcUQsTUFBTSxlQUFlLENBQUM7QUFFcEgsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7O0FBUzdELE1BQU0sT0FBTyw2QkFBNkI7SUFDL0IsZUFBZSxHQUFHLEtBQUssQ0FBQyxRQUFRLEVBQTZCLENBQUM7SUFDOUQsaUJBQWlCLEdBQUcsTUFBTSxDQUFDLG9CQUFvQixDQUFDLENBQUM7SUFFakQsV0FBVyxHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsZUFBZSxFQUFFLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDM0QsVUFBVSxHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsZUFBZSxFQUFFLENBQUMsSUFBSSxJQUFJLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxjQUFjLEVBQUUsQ0FBQyxDQUFDO0lBRXBHLDJCQUEyQixHQUF3QyxRQUFRLENBQUMsR0FBRyxFQUFFO1FBQ3hGLE1BQU0sZUFBZSxHQUFHLElBQUksQ0FBQyxlQUFlLEVBQUUsQ0FBQztRQUMvQyxNQUFNLG9CQUFvQixHQUFHLGVBQWUsQ0FBQyxvQkFBb0IsQ0FBQztRQUVsRSxNQUFNLFVBQVUsR0FBMkI7WUFDekMsZUFBZTtTQUNoQixDQUFDO1FBRUYsTUFBTSxNQUFNLEdBQWdDO1lBQzFDLGNBQWMsRUFBRSxvQkFBb0I7WUFDcEMsU0FBUyxFQUFFO2dCQUNUO29CQUNFLE9BQU8sRUFBRSxnQ0FBZ0M7b0JBQ3pDLFFBQVEsRUFBRSxVQUFVO2lCQUNyQjthQUNGO1NBQ0YsQ0FBQztRQUVGLE9BQU8sTUFBTSxDQUFDO0lBQ2hCLENBQUMsQ0FBQyxDQUFDO0lBRU0sMkJBQTJCLEdBQStDLFFBQVEsQ0FBQyxHQUFHLEVBQUU7UUFDL0YsTUFBTSxlQUFlLEdBQUcsSUFBSSxDQUFDLGVBQWUsRUFBRSxDQUFDO1FBQy9DLE1BQU0sb0JBQW9CLEdBQUcsZUFBZSxDQUFDLG9CQUFvQixDQUFDO1FBRWxFLElBQUksTUFBTSxHQUF1QyxTQUFTLENBQUM7UUFFM0QsSUFBSSxvQkFBb0IsRUFBRSxDQUFDO1lBQ3pCLE1BQU0sVUFBVSxHQUEyQjtnQkFDekMsZUFBZTthQUNoQixDQUFDO1lBRUYsTUFBTSxHQUFHO2dCQUNQLGNBQWMsRUFBRSxvQkFBb0I7Z0JBQ3BDLFNBQVMsRUFBRTtvQkFDVDt3QkFDRSxPQUFPLEVBQUUsZ0NBQWdDO3dCQUN6QyxRQUFRLEVBQUUsVUFBVTtxQkFDckI7aUJBQ0Y7YUFDRixDQUFDO1FBQ0osQ0FBQztRQUVELE9BQU8sTUFBTSxDQUFDO0lBQ2hCLENBQUMsQ0FBQyxDQUFDO3dHQW5EUSw2QkFBNkI7NEZBQTdCLDZCQUE2QixxUENoQjFDLG8wQkF1QkEsNENEWFkscUJBQXFCLDJIQUFFLGlCQUFpQixzTEFBRSx1QkFBdUIsa0lBQUUsc0JBQXNCLDREQUFFLDRCQUE0QixrRUFBRSx3QkFBd0Isa0ZBQUUsT0FBTzs7NEZBSXpKLDZCQUE2QjtrQkFQekMsU0FBUzsrQkFDRSwwQkFBMEIsV0FFM0IsQ0FBQyxxQkFBcUIsRUFBRSxpQkFBaUIsRUFBRSx1QkFBdUIsRUFBRSxzQkFBc0IsRUFBRSw0QkFBNEIsRUFBRSx3QkFBd0IsRUFBRSxPQUFPLEVBQUUsU0FBUyxDQUFDLG1CQUMvSix1QkFBdUIsQ0FBQyxNQUFNLGNBQ25DLElBQUkiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBjb21wdXRlZCwgaW5qZWN0LCBpbnB1dCwgU2lnbmFsIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBEYnhJbmplY3Rpb25Db21wb25lbnQsIERieEluamVjdGlvbkNvbXBvbmVudENvbmZpZyB9IGZyb20gJ0BkZXJlZWtiL2RieC1jb3JlJztcbmltcG9ydCB7IE1hdEV4cGFuc2lvblBhbmVsLCBNYXRFeHBhbnNpb25QYW5lbEhlYWRlciwgTWF0RXhwYW5zaW9uUGFuZWxUaXRsZSwgTWF0RXhwYW5zaW9uUGFuZWxEZXNjcmlwdGlvbiwgTWF0RXhwYW5zaW9uUGFuZWxDb250ZW50IH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvZXhwYW5zaW9uJztcbmltcG9ydCB7IE1hdEljb24gfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pY29uJztcbmltcG9ydCB7IEFzeW5jUGlwZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBEQlhfSEVMUF9XSURHRVRfRU5UUllfREFUQV9UT0tFTiwgRGJ4SGVscFdpZGdldEVudHJ5RGF0YSwgRGJ4SGVscFdpZGdldFNlcnZpY2VFbnRyeSB9IGZyb20gJy4vaGVscC53aWRnZXQnO1xuaW1wb3J0IHsgTWF5YmUgfSBmcm9tICdAZGVyZWVrYi91dGlsJztcbmltcG9ydCB7IERieEhlbHBXaWRnZXRTZXJ2aWNlIH0gZnJvbSAnLi9oZWxwLndpZGdldC5zZXJ2aWNlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnZGJ4LWhlbHAtdmlldy1saXN0LWVudHJ5JyxcbiAgdGVtcGxhdGVVcmw6ICcuL2hlbHAudmlldy5saXN0LmVudHJ5LmNvbXBvbmVudC5odG1sJyxcbiAgaW1wb3J0czogW0RieEluamVjdGlvbkNvbXBvbmVudCwgTWF0RXhwYW5zaW9uUGFuZWwsIE1hdEV4cGFuc2lvblBhbmVsSGVhZGVyLCBNYXRFeHBhbnNpb25QYW5lbFRpdGxlLCBNYXRFeHBhbnNpb25QYW5lbERlc2NyaXB0aW9uLCBNYXRFeHBhbnNpb25QYW5lbENvbnRlbnQsIE1hdEljb24sIEFzeW5jUGlwZV0sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICBzdGFuZGFsb25lOiB0cnVlXG59KVxuZXhwb3J0IGNsYXNzIERieEhlbHBWaWV3TGlzdEVudHJ5Q29tcG9uZW50IHtcbiAgcmVhZG9ubHkgaGVscFdpZGdldEVudHJ5ID0gaW5wdXQucmVxdWlyZWQ8RGJ4SGVscFdpZGdldFNlcnZpY2VFbnRyeT4oKTtcbiAgcmVhZG9ubHkgaGVscFdpZGdldFNlcnZpY2UgPSBpbmplY3QoRGJ4SGVscFdpZGdldFNlcnZpY2UpO1xuXG4gIHJlYWRvbmx5IHRpdGxlU2lnbmFsID0gY29tcHV0ZWQoKCkgPT4gdGhpcy5oZWxwV2lkZ2V0RW50cnkoKS50aXRsZSk7XG4gIHJlYWRvbmx5IGljb25TaWduYWwgPSBjb21wdXRlZCgoKSA9PiB0aGlzLmhlbHBXaWRnZXRFbnRyeSgpLmljb24gPz8gdGhpcy5oZWxwV2lkZ2V0U2VydmljZS5nZXREZWZhdWx0SWNvbigpKTtcblxuICByZWFkb25seSB3aWRnZXRJbmplY3Rpb25Db25maWdTaWduYWw6IFNpZ25hbDxEYnhJbmplY3Rpb25Db21wb25lbnRDb25maWc+ID0gY29tcHV0ZWQoKCkgPT4ge1xuICAgIGNvbnN0IGhlbHBXaWRnZXRFbnRyeSA9IHRoaXMuaGVscFdpZGdldEVudHJ5KCk7XG4gICAgY29uc3Qgd2lkZ2V0Q29tcG9uZW50Q2xhc3MgPSBoZWxwV2lkZ2V0RW50cnkud2lkZ2V0Q29tcG9uZW50Q2xhc3M7XG5cbiAgICBjb25zdCB3aWRnZXREYXRhOiBEYnhIZWxwV2lkZ2V0RW50cnlEYXRhID0ge1xuICAgICAgaGVscFdpZGdldEVudHJ5XG4gICAgfTtcblxuICAgIGNvbnN0IGNvbmZpZzogRGJ4SW5qZWN0aW9uQ29tcG9uZW50Q29uZmlnID0ge1xuICAgICAgY29tcG9uZW50Q2xhc3M6IHdpZGdldENvbXBvbmVudENsYXNzLFxuICAgICAgcHJvdmlkZXJzOiBbXG4gICAgICAgIHtcbiAgICAgICAgICBwcm92aWRlOiBEQlhfSEVMUF9XSURHRVRfRU5UUllfREFUQV9UT0tFTixcbiAgICAgICAgICB1c2VWYWx1ZTogd2lkZ2V0RGF0YVxuICAgICAgICB9XG4gICAgICBdXG4gICAgfTtcblxuICAgIHJldHVybiBjb25maWc7XG4gIH0pO1xuXG4gIHJlYWRvbmx5IGhlYWRlckluamVjdGlvbkNvbmZpZ1NpZ25hbDogU2lnbmFsPE1heWJlPERieEluamVjdGlvbkNvbXBvbmVudENvbmZpZz4+ID0gY29tcHV0ZWQoKCkgPT4ge1xuICAgIGNvbnN0IGhlbHBXaWRnZXRFbnRyeSA9IHRoaXMuaGVscFdpZGdldEVudHJ5KCk7XG4gICAgY29uc3QgaGVhZGVyQ29tcG9uZW50Q2xhc3MgPSBoZWxwV2lkZ2V0RW50cnkuaGVhZGVyQ29tcG9uZW50Q2xhc3M7XG5cbiAgICBsZXQgY29uZmlnOiBNYXliZTxEYnhJbmplY3Rpb25Db21wb25lbnRDb25maWc+ID0gdW5kZWZpbmVkO1xuXG4gICAgaWYgKGhlYWRlckNvbXBvbmVudENsYXNzKSB7XG4gICAgICBjb25zdCB3aWRnZXREYXRhOiBEYnhIZWxwV2lkZ2V0RW50cnlEYXRhID0ge1xuICAgICAgICBoZWxwV2lkZ2V0RW50cnlcbiAgICAgIH07XG5cbiAgICAgIGNvbmZpZyA9IHtcbiAgICAgICAgY29tcG9uZW50Q2xhc3M6IGhlYWRlckNvbXBvbmVudENsYXNzLFxuICAgICAgICBwcm92aWRlcnM6IFtcbiAgICAgICAgICB7XG4gICAgICAgICAgICBwcm92aWRlOiBEQlhfSEVMUF9XSURHRVRfRU5UUllfREFUQV9UT0tFTixcbiAgICAgICAgICAgIHVzZVZhbHVlOiB3aWRnZXREYXRhXG4gICAgICAgICAgfVxuICAgICAgICBdXG4gICAgICB9O1xuICAgIH1cblxuICAgIHJldHVybiBjb25maWc7XG4gIH0pO1xufVxuIiwiPG1hdC1leHBhbnNpb24tcGFuZWw+XG4gIDxtYXQtZXhwYW5zaW9uLXBhbmVsLWhlYWRlcj5cbiAgICA8bWF0LXBhbmVsLXRpdGxlPlxuICAgICAgQGlmIChpY29uU2lnbmFsKCk7IGFzIGljb24pIHtcbiAgICAgICAgPG1hdC1pY29uIGNsYXNzPVwiZGJ4LWJ1dHRvbi1zcGFjZXJcIj57eyBpY29uIH19PC9tYXQtaWNvbj5cbiAgICAgIH1cbiAgICAgIDxzcGFuPnt7IHRpdGxlU2lnbmFsKCkgfX08L3NwYW4+XG4gICAgPC9tYXQtcGFuZWwtdGl0bGU+XG4gICAgPG5nLWNvbnRhaW5lcj5cbiAgICAgIEBpZiAoaGVhZGVySW5qZWN0aW9uQ29uZmlnU2lnbmFsKCk7IGFzIGhlYWRlckluamVjdGlvbkNvbmZpZykge1xuICAgICAgICA8bWF0LXBhbmVsLWRlc2NyaXB0aW9uPlxuICAgICAgICAgIDxzcGFuIGNsYXNzPVwiZGJ4LXNwYWNlclwiPjwvc3Bhbj5cbiAgICAgICAgICA8ZGJ4LWluamVjdGlvbiBbY29uZmlnXT1cImhlYWRlckluamVjdGlvbkNvbmZpZ1wiPjwvZGJ4LWluamVjdGlvbj5cbiAgICAgICAgPC9tYXQtcGFuZWwtZGVzY3JpcHRpb24+XG4gICAgICB9XG4gICAgPC9uZy1jb250YWluZXI+XG4gIDwvbWF0LWV4cGFuc2lvbi1wYW5lbC1oZWFkZXI+XG4gIDxuZy10ZW1wbGF0ZSBtYXRFeHBhbnNpb25QYW5lbENvbnRlbnQ+XG4gICAgPGRpdiBjbGFzcz1cImRieC1oZWxwLXZpZXctbGlzdC1lbnRyeS1jb250ZW50XCI+XG4gICAgICA8ZGJ4LWluamVjdGlvbiBbY29uZmlnXT1cIndpZGdldEluamVjdGlvbkNvbmZpZ1NpZ25hbCgpXCI+PC9kYngtaW5qZWN0aW9uPlxuICAgIDwvZGl2PlxuICA8L25nLXRlbXBsYXRlPlxuPC9tYXQtZXhwYW5zaW9uLXBhbmVsPlxuIl19
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, ElementRef, inject, input, viewChild } from '@angular/core';
|
|
2
|
+
import { AbstractPopoverRefDirective } from '../../interaction/popover/abstract.popover.ref.directive';
|
|
3
|
+
import { DbxPopoverService } from '../../interaction/popover/popover.service';
|
|
4
|
+
import { DbxIconButtonComponent } from '../../button';
|
|
5
|
+
import { DbxHelpViewPopoverComponent } from './help.view.popover.component';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
/**
|
|
8
|
+
* Button component that opens a help popover showing active help contexts.
|
|
9
|
+
*/
|
|
10
|
+
export class DbxHelpViewPopoverButtonComponent extends AbstractPopoverRefDirective {
|
|
11
|
+
_dbxPopoverService = inject(DbxPopoverService);
|
|
12
|
+
buttonElement = viewChild.required('button', { read: ElementRef });
|
|
13
|
+
config = input();
|
|
14
|
+
_makePopoverRef(origin) {
|
|
15
|
+
if (!origin) {
|
|
16
|
+
throw new Error('Missing origin.');
|
|
17
|
+
}
|
|
18
|
+
const config = this.config();
|
|
19
|
+
return DbxHelpViewPopoverComponent.openPopover(this._dbxPopoverService, {
|
|
20
|
+
origin,
|
|
21
|
+
...config
|
|
22
|
+
});
|
|
23
|
+
}
|
|
24
|
+
showHelpPopover() {
|
|
25
|
+
const origin = this.buttonElement();
|
|
26
|
+
this.showPopover(origin);
|
|
27
|
+
}
|
|
28
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxHelpViewPopoverButtonComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
29
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "18.2.13", type: DbxHelpViewPopoverButtonComponent, isStandalone: true, selector: "dbx-help-view-popover-button", inputs: { config: { classPropertyName: "config", publicName: "config", isSignal: true, isRequired: false, transformFunction: null } }, viewQueries: [{ propertyName: "buttonElement", first: true, predicate: ["button"], descendants: true, read: ElementRef, isSignal: true }], usesInheritance: true, ngImport: i0, template: `
|
|
30
|
+
<dbx-icon-button #button (buttonClick)="showHelpPopover()" icon="help_center"></dbx-icon-button>
|
|
31
|
+
`, isInline: true, dependencies: [{ kind: "component", type: DbxIconButtonComponent, selector: "dbx-icon-button" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
32
|
+
}
|
|
33
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxHelpViewPopoverButtonComponent, decorators: [{
|
|
34
|
+
type: Component,
|
|
35
|
+
args: [{
|
|
36
|
+
selector: 'dbx-help-view-popover-button',
|
|
37
|
+
template: `
|
|
38
|
+
<dbx-icon-button #button (buttonClick)="showHelpPopover()" icon="help_center"></dbx-icon-button>
|
|
39
|
+
`,
|
|
40
|
+
standalone: true,
|
|
41
|
+
imports: [DbxIconButtonComponent],
|
|
42
|
+
changeDetection: ChangeDetectionStrategy.OnPush
|
|
43
|
+
}]
|
|
44
|
+
}] });
|
|
45
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVscC52aWV3LnBvcG92ZXIuYnV0dG9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC13ZWIvc3JjL2xpYi9leHRlbnNpb24vaGVscC9oZWxwLnZpZXcucG9wb3Zlci5idXR0b24uY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXpHLE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxNQUFNLDBEQUEwRCxDQUFDO0FBQ3ZHLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLDJDQUEyQyxDQUFDO0FBQzlFLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUV0RCxPQUFPLEVBQUUsMkJBQTJCLEVBQXlDLE1BQU0sK0JBQStCLENBQUM7O0FBSW5IOztHQUVHO0FBVUgsTUFBTSxPQUFPLGlDQUFrQyxTQUFRLDJCQUE2QztJQUNqRixrQkFBa0IsR0FBRyxNQUFNLENBQUMsaUJBQWlCLENBQUMsQ0FBQztJQUV2RCxhQUFhLEdBQUcsU0FBUyxDQUFDLFFBQVEsQ0FBcUIsUUFBUSxFQUFFLEVBQUUsSUFBSSxFQUFFLFVBQVUsRUFBRSxDQUFDLENBQUM7SUFDdkYsTUFBTSxHQUFHLEtBQUssRUFBeUMsQ0FBQztJQUU5QyxlQUFlLENBQUMsTUFBMEI7UUFDM0QsSUFBSSxDQUFDLE1BQU0sRUFBRSxDQUFDO1lBQ1osTUFBTSxJQUFJLEtBQUssQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDO1FBQ3JDLENBQUM7UUFFRCxNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7UUFFN0IsT0FBTywyQkFBMkIsQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLGtCQUFrQixFQUFFO1lBQ3RFLE1BQU07WUFDTixHQUFHLE1BQU07U0FDVixDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQsZUFBZTtRQUNiLE1BQU0sTUFBTSxHQUFHLElBQUksQ0FBQyxhQUFhLEVBQUUsQ0FBQztRQUNwQyxJQUFJLENBQUMsV0FBVyxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQzNCLENBQUM7d0dBdEJVLGlDQUFpQzs0RkFBakMsaUNBQWlDLG1UQUdzQyxVQUFVLG9FQVZsRjs7R0FFVCw0REFFUyxzQkFBc0I7OzRGQUdyQixpQ0FBaUM7a0JBVDdDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLDhCQUE4QjtvQkFDeEMsUUFBUSxFQUFFOztHQUVUO29CQUNELFVBQVUsRUFBRSxJQUFJO29CQUNoQixPQUFPLEVBQUUsQ0FBQyxzQkFBc0IsQ0FBQztvQkFDakMsZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07aUJBQ2hEIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgRWxlbWVudFJlZiwgaW5qZWN0LCBpbnB1dCwgdmlld0NoaWxkIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBNYXliZSB9IGZyb20gJ0BkZXJlZWtiL3V0aWwnO1xuaW1wb3J0IHsgQWJzdHJhY3RQb3BvdmVyUmVmRGlyZWN0aXZlIH0gZnJvbSAnLi4vLi4vaW50ZXJhY3Rpb24vcG9wb3Zlci9hYnN0cmFjdC5wb3BvdmVyLnJlZi5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgRGJ4UG9wb3ZlclNlcnZpY2UgfSBmcm9tICcuLi8uLi9pbnRlcmFjdGlvbi9wb3BvdmVyL3BvcG92ZXIuc2VydmljZSc7XG5pbXBvcnQgeyBEYnhJY29uQnV0dG9uQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vYnV0dG9uJztcbmltcG9ydCB7IE5nUG9wb3ZlclJlZiB9IGZyb20gJ25nLW92ZXJsYXktY29udGFpbmVyJztcbmltcG9ydCB7IERieEhlbHBWaWV3UG9wb3ZlckNvbXBvbmVudCwgRGJ4SGVscFZpZXdQb3BvdmVyQ29uZmlnV2l0aG91dE9yaWdpbiB9IGZyb20gJy4vaGVscC52aWV3LnBvcG92ZXIuY29tcG9uZW50JztcblxuZXhwb3J0IHR5cGUgRGJ4SGVscFZpZXdQb3BvdmVyQnV0dG9uQ29uZmlnID0gRGJ4SGVscFZpZXdQb3BvdmVyQ29uZmlnV2l0aG91dE9yaWdpbjtcblxuLyoqXG4gKiBCdXR0b24gY29tcG9uZW50IHRoYXQgb3BlbnMgYSBoZWxwIHBvcG92ZXIgc2hvd2luZyBhY3RpdmUgaGVscCBjb250ZXh0cy5cbiAqL1xuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnZGJ4LWhlbHAtdmlldy1wb3BvdmVyLWJ1dHRvbicsXG4gIHRlbXBsYXRlOiBgXG4gICAgPGRieC1pY29uLWJ1dHRvbiAjYnV0dG9uIChidXR0b25DbGljayk9XCJzaG93SGVscFBvcG92ZXIoKVwiIGljb249XCJoZWxwX2NlbnRlclwiPjwvZGJ4LWljb24tYnV0dG9uPlxuICBgLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbRGJ4SWNvbkJ1dHRvbkNvbXBvbmVudF0sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXG59KVxuZXhwb3J0IGNsYXNzIERieEhlbHBWaWV3UG9wb3ZlckJ1dHRvbkNvbXBvbmVudCBleHRlbmRzIEFic3RyYWN0UG9wb3ZlclJlZkRpcmVjdGl2ZTx1bmtub3duLCB1bmtub3duPiB7XG4gIHByaXZhdGUgcmVhZG9ubHkgX2RieFBvcG92ZXJTZXJ2aWNlID0gaW5qZWN0KERieFBvcG92ZXJTZXJ2aWNlKTtcblxuICByZWFkb25seSBidXR0b25FbGVtZW50ID0gdmlld0NoaWxkLnJlcXVpcmVkPHN0cmluZywgRWxlbWVudFJlZj4oJ2J1dHRvbicsIHsgcmVhZDogRWxlbWVudFJlZiB9KTtcbiAgcmVhZG9ubHkgY29uZmlnID0gaW5wdXQ8TWF5YmU8RGJ4SGVscFZpZXdQb3BvdmVyQnV0dG9uQ29uZmlnPj4oKTtcblxuICBwcm90ZWN0ZWQgb3ZlcnJpZGUgX21ha2VQb3BvdmVyUmVmKG9yaWdpbj86IE1heWJlPEVsZW1lbnRSZWY+KTogTmdQb3BvdmVyUmVmPHVua25vd24sIHVua25vd24+IHtcbiAgICBpZiAoIW9yaWdpbikge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKCdNaXNzaW5nIG9yaWdpbi4nKTtcbiAgICB9XG5cbiAgICBjb25zdCBjb25maWcgPSB0aGlzLmNvbmZpZygpO1xuXG4gICAgcmV0dXJuIERieEhlbHBWaWV3UG9wb3ZlckNvbXBvbmVudC5vcGVuUG9wb3Zlcih0aGlzLl9kYnhQb3BvdmVyU2VydmljZSwge1xuICAgICAgb3JpZ2luLFxuICAgICAgLi4uY29uZmlnXG4gICAgfSk7XG4gIH1cblxuICBzaG93SGVscFBvcG92ZXIoKTogdm9pZCB7XG4gICAgY29uc3Qgb3JpZ2luID0gdGhpcy5idXR0b25FbGVtZW50KCk7XG4gICAgdGhpcy5zaG93UG9wb3ZlcihvcmlnaW4pO1xuICB9XG59XG4iXX0=
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, inject } from '@angular/core';
|
|
2
|
+
import { AbstractPopoverDirective } from '../../interaction/popover/abstract.popover.directive';
|
|
3
|
+
import { DbxPopoverContentComponent, DbxPopoverHeaderComponent, DbxPopoverScrollContentDirective } from '../../interaction';
|
|
4
|
+
import { DbxHelpViewListComponent } from './help.view.list.component';
|
|
5
|
+
import { DbxHelpContextService } from './help.context.service';
|
|
6
|
+
import { DbxInjectionComponent } from '@dereekb/dbx-core';
|
|
7
|
+
import { DbxHelpWidgetService } from './help.widget.service';
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
9
|
+
export const DEFAULT_DBX_HELP_VIEW_POPOVER_KEY = 'help';
|
|
10
|
+
/**
|
|
11
|
+
* Popover component for displaying help contexts.
|
|
12
|
+
*/
|
|
13
|
+
export class DbxHelpViewPopoverComponent extends AbstractPopoverDirective {
|
|
14
|
+
_helpContextService = inject(DbxHelpContextService);
|
|
15
|
+
_helpWidgetService = inject(DbxHelpWidgetService);
|
|
16
|
+
helpContextStrings$ = this.popover.data?.helpContextStrings ?? this._helpContextService.activeHelpContextStringsArray$;
|
|
17
|
+
static openPopover(popoverService, config, popoverKey) {
|
|
18
|
+
const { origin, ...data } = config;
|
|
19
|
+
return popoverService.open({
|
|
20
|
+
height: '500px',
|
|
21
|
+
width: '600px',
|
|
22
|
+
key: popoverKey ?? DEFAULT_DBX_HELP_VIEW_POPOVER_KEY,
|
|
23
|
+
origin,
|
|
24
|
+
componentClass: DbxHelpViewPopoverComponent,
|
|
25
|
+
data,
|
|
26
|
+
isResizable: true
|
|
27
|
+
});
|
|
28
|
+
}
|
|
29
|
+
get config() {
|
|
30
|
+
return this.popover.data;
|
|
31
|
+
}
|
|
32
|
+
icon = this.config.icon ?? 'help';
|
|
33
|
+
header = this.config.header ?? 'Help';
|
|
34
|
+
emptyText = this.config.emptyText ?? 'No help topics available in current context.';
|
|
35
|
+
popoverHeaderConfig = (() => {
|
|
36
|
+
let config = this.config.popoverHeaderConfig;
|
|
37
|
+
if (!config) {
|
|
38
|
+
config = this._helpWidgetService.getPopoverHeaderComponentConfig();
|
|
39
|
+
}
|
|
40
|
+
return config;
|
|
41
|
+
})();
|
|
42
|
+
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 });
|
|
44
|
+
}
|
|
45
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxHelpViewPopoverComponent, decorators: [{
|
|
46
|
+
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" }]
|
|
48
|
+
}] });
|
|
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"]}
|