@dereekb/dbx-web 12.6.18 → 12.6.19
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/help/absract.help.widget.directive.mjs +3 -3
- package/esm2022/lib/extension/help/help.context.directive.mjs +4 -4
- package/esm2022/lib/extension/help/help.context.mjs +3 -3
- package/esm2022/lib/extension/help/help.context.service.mjs +3 -3
- package/esm2022/lib/extension/help/help.mjs +1 -1
- package/esm2022/lib/extension/help/help.view.list.component.mjs +30 -11
- package/esm2022/lib/extension/help/help.view.list.entry.component.mjs +4 -3
- package/esm2022/lib/extension/help/help.view.popover.component.mjs +5 -4
- package/esm2022/lib/extension/help/help.widget.mjs +1 -1
- package/esm2022/lib/extension/help/help.widget.service.mjs +18 -10
- package/esm2022/lib/router/layout/anchor/anchor.component.mjs +20 -7
- package/esm2022/lib/router/provider/ngrouter/anchor.component.mjs +13 -4
- package/esm2022/lib/router/provider/uirouter/anchor.component.mjs +7 -51
- package/esm2022/lib/screen/resize.mjs +2 -2
- package/esm2022/lib/util/click.mjs +56 -0
- package/esm2022/lib/util/index.mjs +2 -1
- package/fesm2022/dereekb-dbx-web.mjs +148 -90
- package/fesm2022/dereekb-dbx-web.mjs.map +1 -1
- package/lib/extension/help/absract.help.widget.directive.d.ts +8 -7
- package/lib/extension/help/help.context.d.ts +2 -2
- package/lib/extension/help/help.context.directive.d.ts +2 -2
- package/lib/extension/help/help.context.service.d.ts +3 -3
- package/lib/extension/help/help.d.ts +3 -3
- package/lib/extension/help/help.view.list.component.d.ts +16 -9
- package/lib/extension/help/help.view.list.entry.component.d.ts +1 -1
- package/lib/extension/help/help.view.popover.component.d.ts +8 -3
- package/lib/extension/help/help.widget.d.ts +13 -9
- package/lib/extension/help/help.widget.service.d.ts +15 -8
- package/lib/router/layout/anchor/anchor.component.d.ts +4 -1
- package/lib/router/provider/ngrouter/anchor.component.d.ts +5 -0
- package/lib/router/provider/uirouter/anchor.component.d.ts +2 -14
- package/lib/screen/resize.d.ts +1 -1
- package/lib/util/click.d.ts +29 -0
- package/lib/util/index.d.ts +1 -0
- package/package.json +1 -1
|
@@ -7,8 +7,8 @@ import * as i0 from "@angular/core";
|
|
|
7
7
|
export class DbxAbstractHelpWidgetDirective {
|
|
8
8
|
helpWidgetData = inject(DBX_HELP_WIDGET_ENTRY_DATA_TOKEN);
|
|
9
9
|
helpWidgetEntry = this.helpWidgetData.helpWidgetEntry;
|
|
10
|
-
get
|
|
11
|
-
return this.helpWidgetEntry.
|
|
10
|
+
get helpContextKey() {
|
|
11
|
+
return this.helpWidgetEntry.helpContextKey;
|
|
12
12
|
}
|
|
13
13
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxAbstractHelpWidgetDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
14
14
|
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: DbxAbstractHelpWidgetDirective, ngImport: i0 });
|
|
@@ -17,4 +17,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
17
17
|
type: Directive,
|
|
18
18
|
args: [{}]
|
|
19
19
|
}] });
|
|
20
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWJzcmFjdC5oZWxwLndpZGdldC5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3NyYy9saWIvZXh0ZW5zaW9uL2hlbHAvYWJzcmFjdC5oZWxwLndpZGdldC5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDbEQsT0FBTyxFQUFFLGdDQUFnQyxFQUEwQixNQUFNLGVBQWUsQ0FBQzs7QUFHekY7O0dBRUc7QUFFSCxNQUFNLE9BQWdCLDhCQUE4QjtJQUN6QyxjQUFjLEdBQUcsTUFBTSxDQUE0QixnQ0FBZ0MsQ0FBQyxDQUFDO0lBQ3JGLGVBQWUsR0FBRyxJQUFJLENBQUMsY0FBYyxDQUFDLGVBQWUsQ0FBQztJQUUvRCxJQUFJLGNBQWM7UUFDaEIsT0FBTyxJQUFJLENBQUMsZUFBZSxDQUFDLGNBQWMsQ0FBQztJQUM3QyxDQUFDO3dHQU5tQiw4QkFBOEI7NEZBQTlCLDhCQUE4Qjs7NEZBQTlCLDhCQUE4QjtrQkFEbkQsU0FBUzttQkFBQyxFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBpbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IERCWF9IRUxQX1dJREdFVF9FTlRSWV9EQVRBX1RPS0VOLCBEYnhIZWxwV2lkZ2V0RW50cnlEYXRhIH0gZnJvbSAnLi9oZWxwLndpZGdldCc7XG5pbXBvcnQgeyBEYnhIZWxwQ29udGV4dEtleSB9IGZyb20gJy4vaGVscCc7XG5cbi8qKlxuICogQWJzdHJhY3QgaGVscCB3aWRnZXQgZGlyZWN0aXZlIHRoYXQgaW5qZWN0cyB0aGUgaGVscCB3aWRnZXQgZGF0YS5cbiAqL1xuQERpcmVjdGl2ZSh7fSlcbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBEYnhBYnN0cmFjdEhlbHBXaWRnZXREaXJlY3RpdmU8RCA9IHVua25vd24+IHtcbiAgcmVhZG9ubHkgaGVscFdpZGdldERhdGEgPSBpbmplY3Q8RGJ4SGVscFdpZGdldEVudHJ5RGF0YTxEPj4oREJYX0hFTFBfV0lER0VUX0VOVFJZX0RBVEFfVE9LRU4pO1xuICByZWFkb25seSBoZWxwV2lkZ2V0RW50cnkgPSB0aGlzLmhlbHBXaWRnZXREYXRhLmhlbHBXaWRnZXRFbnRyeTtcblxuICBnZXQgaGVscENvbnRleHRLZXkoKTogRGJ4SGVscENvbnRleHRLZXkge1xuICAgIHJldHVybiB0aGlzLmhlbHBXaWRnZXRFbnRyeS5oZWxwQ29udGV4dEtleTtcbiAgfVxufVxuIl19
|
|
@@ -2,7 +2,7 @@ import { Directive, input } from '@angular/core';
|
|
|
2
2
|
import { asArray } from '@dereekb/util';
|
|
3
3
|
import { map } from 'rxjs';
|
|
4
4
|
import { toObservable } from '@angular/core/rxjs-interop';
|
|
5
|
-
import {
|
|
5
|
+
import { registerHelpContextKeysWithDbxHelpContextService } from './help.context';
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
7
7
|
/**
|
|
8
8
|
* Directive that registers one or more help contexts to the current context.
|
|
@@ -12,9 +12,9 @@ export class DbxHelpContextDirective {
|
|
|
12
12
|
* The input help context string(s) to add.
|
|
13
13
|
*/
|
|
14
14
|
dbxHelpContext = input.required();
|
|
15
|
-
|
|
15
|
+
helpContextKeys$ = toObservable(this.dbxHelpContext).pipe(map(asArray));
|
|
16
16
|
constructor() {
|
|
17
|
-
|
|
17
|
+
registerHelpContextKeysWithDbxHelpContextService(this.helpContextKeys$);
|
|
18
18
|
}
|
|
19
19
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxHelpContextDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
20
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 });
|
|
@@ -26,4 +26,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
26
26
|
standalone: true
|
|
27
27
|
}]
|
|
28
28
|
}], ctorParameters: () => [] });
|
|
29
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVscC5jb250ZXh0LmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC13ZWIvc3JjL2xpYi9leHRlbnNpb24vaGVscC9oZWxwLmNvbnRleHQuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRWpELE9BQU8sRUFBZ0IsT0FBTyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3RELE9BQU8sRUFBRSxHQUFHLEVBQWMsTUFBTSxNQUFNLENBQUM7QUFDdkMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQzFELE9BQU8sRUFBRSxnREFBZ0QsRUFBRSxNQUFNLGdCQUFnQixDQUFDOztBQUVsRjs7R0FFRztBQUtILE1BQU0sT0FBTyx1QkFBdUI7SUFDbEM7O09BRUc7SUFDTSxjQUFjLEdBQUcsS0FBSyxDQUFDLFFBQVEsRUFBbUMsQ0FBQztJQUNuRSxnQkFBZ0IsR0FBb0MsWUFBWSxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUM7SUFFbEg7UUFDRSxnREFBZ0QsQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztJQUMxRSxDQUFDO3dHQVRVLHVCQUF1Qjs0RkFBdkIsdUJBQXVCOzs0RkFBdkIsdUJBQXVCO2tCQUpuQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxrQkFBa0I7b0JBQzVCLFVBQVUsRUFBRSxJQUFJO2lCQUNqQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgaW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IERieEhlbHBDb250ZXh0S2V5IH0gZnJvbSAnLi9oZWxwJztcbmltcG9ydCB7IEFycmF5T3JWYWx1ZSwgYXNBcnJheSB9IGZyb20gJ0BkZXJlZWtiL3V0aWwnO1xuaW1wb3J0IHsgbWFwLCBPYnNlcnZhYmxlIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyB0b09ic2VydmFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlL3J4anMtaW50ZXJvcCc7XG5pbXBvcnQgeyByZWdpc3RlckhlbHBDb250ZXh0S2V5c1dpdGhEYnhIZWxwQ29udGV4dFNlcnZpY2UgfSBmcm9tICcuL2hlbHAuY29udGV4dCc7XG5cbi8qKlxuICogRGlyZWN0aXZlIHRoYXQgcmVnaXN0ZXJzIG9uZSBvciBtb3JlIGhlbHAgY29udGV4dHMgdG8gdGhlIGN1cnJlbnQgY29udGV4dC5cbiAqL1xuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnW2RieEhlbHBDb250ZXh0XScsXG4gIHN0YW5kYWxvbmU6IHRydWVcbn0pXG5leHBvcnQgY2xhc3MgRGJ4SGVscENvbnRleHREaXJlY3RpdmUge1xuICAvKipcbiAgICogVGhlIGlucHV0IGhlbHAgY29udGV4dCBzdHJpbmcocykgdG8gYWRkLlxuICAgKi9cbiAgcmVhZG9ubHkgZGJ4SGVscENvbnRleHQgPSBpbnB1dC5yZXF1aXJlZDxBcnJheU9yVmFsdWU8RGJ4SGVscENvbnRleHRLZXk+PigpO1xuICByZWFkb25seSBoZWxwQ29udGV4dEtleXMkOiBPYnNlcnZhYmxlPERieEhlbHBDb250ZXh0S2V5W10+ID0gdG9PYnNlcnZhYmxlKHRoaXMuZGJ4SGVscENvbnRleHQpLnBpcGUobWFwKGFzQXJyYXkpKTtcblxuICBjb25zdHJ1Y3RvcigpIHtcbiAgICByZWdpc3RlckhlbHBDb250ZXh0S2V5c1dpdGhEYnhIZWxwQ29udGV4dFNlcnZpY2UodGhpcy5oZWxwQ29udGV4dEtleXMkKTtcbiAgfVxufVxuIl19
|
|
@@ -8,11 +8,11 @@ import { DbxHelpContextService } from './help.context.service';
|
|
|
8
8
|
*
|
|
9
9
|
* Automatically cleans up, but returns a destroy function for manual cleanup.
|
|
10
10
|
*/
|
|
11
|
-
export function
|
|
11
|
+
export function registerHelpContextKeysWithDbxHelpContextService(helpContextKeys) {
|
|
12
12
|
const helpContextService = inject(DbxHelpContextService);
|
|
13
13
|
const destroyRef = inject(DestroyRef);
|
|
14
14
|
const helpContextReference = {
|
|
15
|
-
|
|
15
|
+
helpContextKeys$: asObservable(helpContextKeys)
|
|
16
16
|
};
|
|
17
17
|
helpContextService.register(helpContextReference);
|
|
18
18
|
function _destroy() {
|
|
@@ -21,4 +21,4 @@ export function registerHelpContextStringsWithDbxHelpContextService(helpContextS
|
|
|
21
21
|
destroyRef.onDestroy(_destroy);
|
|
22
22
|
return _destroy;
|
|
23
23
|
}
|
|
24
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVscC5jb250ZXh0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LXdlYi9zcmMvbGliL2V4dGVuc2lvbi9oZWxwL2hlbHAuY29udGV4dC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUEwQixNQUFNLGVBQWUsQ0FBQztBQUVyRSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNuRCxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUcvRDs7Ozs7O0dBTUc7QUFDSCxNQUFNLFVBQVUsZ0RBQWdELENBQUMsZUFBdUQ7SUFDdEgsTUFBTSxrQkFBa0IsR0FBRyxNQUFNLENBQUMscUJBQXFCLENBQUMsQ0FBQztJQUN6RCxNQUFNLFVBQVUsR0FBRyxNQUFNLENBQUMsVUFBVSxDQUFDLENBQUM7SUFFdEMsTUFBTSxvQkFBb0IsR0FBNEI7UUFDcEQsZ0JBQWdCLEVBQUUsWUFBWSxDQUFDLGVBQWUsQ0FBQztLQUNoRCxDQUFDO0lBRUYsa0JBQWtCLENBQUMsUUFBUSxDQUFDLG9CQUFvQixDQUFDLENBQUM7SUFFbEQsU0FBUyxRQUFRO1FBQ2Ysa0JBQWtCLENBQUMsVUFBVSxDQUFDLG9CQUFvQixDQUFDLENBQUM7SUFDdEQsQ0FBQztJQUVELFVBQVUsQ0FBQyxTQUFTLENBQUMsUUFBUSxDQUFDLENBQUM7SUFFL0IsT0FBTyxRQUFRLENBQUM7QUFDbEIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGFzT2JzZXJ2YWJsZSwgdHlwZSBPYnNlcnZhYmxlT3JWYWx1ZSB9IGZyb20gJ0BkZXJlZWtiL3J4anMnO1xuaW1wb3J0IHsgdHlwZSBEYnhIZWxwQ29udGV4dFJlZmVyZW5jZSwgdHlwZSBEYnhIZWxwQ29udGV4dEtleSB9IGZyb20gJy4vaGVscCc7XG5pbXBvcnQgeyBEZXN0cm95UmVmLCBpbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IERieEhlbHBDb250ZXh0U2VydmljZSB9IGZyb20gJy4vaGVscC5jb250ZXh0LnNlcnZpY2UnO1xuaW1wb3J0IHsgdHlwZSBEZXN0cm95RnVuY3Rpb24gfSBmcm9tICdAZGVyZWVrYi91dGlsJztcblxuLyoqXG4gKiBSZWdpc3RlcnMgdGhlIGlucHV0IG9ic2VydmFibGUgd2l0aCB0aGUgRGJ4SGVscENvbnRleHRTZXJ2aWNlLlxuICpcbiAqIE11c3QgYmUgcnVuIGluIGFuIGluamVjdGFibGUgY29udGV4dC5cbiAqXG4gKiBBdXRvbWF0aWNhbGx5IGNsZWFucyB1cCwgYnV0IHJldHVybnMgYSBkZXN0cm95IGZ1bmN0aW9uIGZvciBtYW51YWwgY2xlYW51cC5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHJlZ2lzdGVySGVscENvbnRleHRLZXlzV2l0aERieEhlbHBDb250ZXh0U2VydmljZShoZWxwQ29udGV4dEtleXM6IE9ic2VydmFibGVPclZhbHVlPERieEhlbHBDb250ZXh0S2V5W10+KTogRGVzdHJveUZ1bmN0aW9uIHtcbiAgY29uc3QgaGVscENvbnRleHRTZXJ2aWNlID0gaW5qZWN0KERieEhlbHBDb250ZXh0U2VydmljZSk7XG4gIGNvbnN0IGRlc3Ryb3lSZWYgPSBpbmplY3QoRGVzdHJveVJlZik7XG5cbiAgY29uc3QgaGVscENvbnRleHRSZWZlcmVuY2U6IERieEhlbHBDb250ZXh0UmVmZXJlbmNlID0ge1xuICAgIGhlbHBDb250ZXh0S2V5cyQ6IGFzT2JzZXJ2YWJsZShoZWxwQ29udGV4dEtleXMpXG4gIH07XG5cbiAgaGVscENvbnRleHRTZXJ2aWNlLnJlZ2lzdGVyKGhlbHBDb250ZXh0UmVmZXJlbmNlKTtcblxuICBmdW5jdGlvbiBfZGVzdHJveSgpIHtcbiAgICBoZWxwQ29udGV4dFNlcnZpY2UudW5yZWdpc3RlcihoZWxwQ29udGV4dFJlZmVyZW5jZSk7XG4gIH1cblxuICBkZXN0cm95UmVmLm9uRGVzdHJveShfZGVzdHJveSk7XG5cbiAgcmV0dXJuIF9kZXN0cm95O1xufVxuIl19
|
|
@@ -10,8 +10,8 @@ export class DbxHelpContextService {
|
|
|
10
10
|
/**
|
|
11
11
|
* Observable of all currently active help context strings.
|
|
12
12
|
*/
|
|
13
|
-
|
|
14
|
-
|
|
13
|
+
activeHelpContextKeys$ = this._contextReferences.pipe(switchMap((allReferences) => combineLatest(Array.from(allReferences).map((ref) => ref.helpContextKeys$)).pipe(map((x) => x.flat()), defaultIfEmpty([]), map((x) => new Set(x)))), distinctUntilHasDifferentValues(), shareReplay(1));
|
|
14
|
+
activeHelpContextKeysArray$ = this.activeHelpContextKeys$.pipe(map((x) => Array.from(x)), shareReplay(1));
|
|
15
15
|
register(reference) {
|
|
16
16
|
const referenceSet = this._contextReferences.value;
|
|
17
17
|
referenceSet.add(reference);
|
|
@@ -31,4 +31,4 @@ export class DbxHelpContextService {
|
|
|
31
31
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxHelpContextService, decorators: [{
|
|
32
32
|
type: Injectable
|
|
33
33
|
}] });
|
|
34
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
34
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVscC5jb250ZXh0LnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3NyYy9saWIvZXh0ZW5zaW9uL2hlbHAvaGVscC5jb250ZXh0LnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBYSxNQUFNLGVBQWUsQ0FBQztBQUN0RCxPQUFPLEVBQUUsZUFBZSxFQUFjLGFBQWEsRUFBRSxjQUFjLEVBQUUsR0FBRyxFQUFFLFdBQVcsRUFBRSxTQUFTLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFFL0csT0FBTyxFQUFFLCtCQUErQixFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUVoRTs7R0FFRztBQUVILE1BQU0sT0FBTyxxQkFBcUI7SUFDZixrQkFBa0IsR0FBRyxJQUFJLGVBQWUsQ0FBK0IsSUFBSSxHQUFHLEVBQUUsQ0FBQyxDQUFDO0lBRW5HOztPQUVHO0lBQ00sc0JBQXNCLEdBQXVDLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxJQUFJLENBQ2hHLFNBQVMsQ0FBQyxDQUFDLGFBQWEsRUFBRSxFQUFFLENBQzFCLGFBQWEsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLEdBQUcsRUFBRSxFQUFFLENBQUMsR0FBRyxDQUFDLGdCQUFnQixDQUFDLENBQUMsQ0FBQyxJQUFJLENBQzlFLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLElBQUksRUFBRSxDQUFDLEVBQ3BCLGNBQWMsQ0FBQyxFQUFFLENBQUMsRUFDbEIsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxJQUFJLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUN2QixDQUNGLEVBQ0QsK0JBQStCLEVBQUUsRUFDakMsV0FBVyxDQUFDLENBQUMsQ0FBQyxDQUNmLENBQUM7SUFFTywyQkFBMkIsR0FBRyxJQUFJLENBQUMsc0JBQXNCLENBQUMsSUFBSSxDQUNyRSxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFDekIsV0FBVyxDQUFDLENBQUMsQ0FBQyxDQUNmLENBQUM7SUFFRixRQUFRLENBQUMsU0FBa0M7UUFDekMsTUFBTSxZQUFZLEdBQUcsSUFBSSxDQUFDLGtCQUFrQixDQUFDLEtBQUssQ0FBQztRQUNuRCxZQUFZLENBQUMsR0FBRyxDQUFDLFNBQVMsQ0FBQyxDQUFDO1FBQzVCLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLENBQUM7SUFDN0MsQ0FBQztJQUVELFVBQVUsQ0FBQyxTQUFrQztRQUMzQyxNQUFNLFlBQVksR0FBRyxJQUFJLENBQUMsa0JBQWtCLENBQUMsS0FBSyxDQUFDO1FBQ25ELFlBQVksQ0FBQyxNQUFNLENBQUMsU0FBUyxDQUFDLENBQUM7UUFDL0IsSUFBSSxDQUFDLGtCQUFrQixDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQztJQUM3QyxDQUFDO0lBRUQsV0FBVztRQUNULElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxRQUFRLEVBQUUsQ0FBQztJQUNyQyxDQUFDO3dHQXJDVSxxQkFBcUI7NEdBQXJCLHFCQUFxQjs7NEZBQXJCLHFCQUFxQjtrQkFEakMsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUsIE9uRGVzdHJveSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQmVoYXZpb3JTdWJqZWN0LCBPYnNlcnZhYmxlLCBjb21iaW5lTGF0ZXN0LCBkZWZhdWx0SWZFbXB0eSwgbWFwLCBzaGFyZVJlcGxheSwgc3dpdGNoTWFwIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBEYnhIZWxwQ29udGV4dEtleSwgRGJ4SGVscENvbnRleHRSZWZlcmVuY2UgfSBmcm9tICcuL2hlbHAnO1xuaW1wb3J0IHsgZGlzdGluY3RVbnRpbEhhc0RpZmZlcmVudFZhbHVlcyB9IGZyb20gJ0BkZXJlZWtiL3J4anMnO1xuXG4vKipcbiAqIFNlcnZpY2UgdGhhdCB0cmFja3MgYWxsIGFjdGl2ZSBoZWxwIGNvbnRleHQgc3RyaW5ncyBpbiB0aGUgY3VycmVudCBjb250ZXh0LlxuICovXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgRGJ4SGVscENvbnRleHRTZXJ2aWNlIGltcGxlbWVudHMgT25EZXN0cm95IHtcbiAgcHJpdmF0ZSByZWFkb25seSBfY29udGV4dFJlZmVyZW5jZXMgPSBuZXcgQmVoYXZpb3JTdWJqZWN0PFNldDxEYnhIZWxwQ29udGV4dFJlZmVyZW5jZT4+KG5ldyBTZXQoKSk7XG5cbiAgLyoqXG4gICAqIE9ic2VydmFibGUgb2YgYWxsIGN1cnJlbnRseSBhY3RpdmUgaGVscCBjb250ZXh0IHN0cmluZ3MuXG4gICAqL1xuICByZWFkb25seSBhY3RpdmVIZWxwQ29udGV4dEtleXMkOiBPYnNlcnZhYmxlPFNldDxEYnhIZWxwQ29udGV4dEtleT4+ID0gdGhpcy5fY29udGV4dFJlZmVyZW5jZXMucGlwZShcbiAgICBzd2l0Y2hNYXAoKGFsbFJlZmVyZW5jZXMpID0+XG4gICAgICBjb21iaW5lTGF0ZXN0KEFycmF5LmZyb20oYWxsUmVmZXJlbmNlcykubWFwKChyZWYpID0+IHJlZi5oZWxwQ29udGV4dEtleXMkKSkucGlwZShcbiAgICAgICAgbWFwKCh4KSA9PiB4LmZsYXQoKSksXG4gICAgICAgIGRlZmF1bHRJZkVtcHR5KFtdKSxcbiAgICAgICAgbWFwKCh4KSA9PiBuZXcgU2V0KHgpKVxuICAgICAgKVxuICAgICksXG4gICAgZGlzdGluY3RVbnRpbEhhc0RpZmZlcmVudFZhbHVlcygpLFxuICAgIHNoYXJlUmVwbGF5KDEpXG4gICk7XG5cbiAgcmVhZG9ubHkgYWN0aXZlSGVscENvbnRleHRLZXlzQXJyYXkkID0gdGhpcy5hY3RpdmVIZWxwQ29udGV4dEtleXMkLnBpcGUoXG4gICAgbWFwKCh4KSA9PiBBcnJheS5mcm9tKHgpKSxcbiAgICBzaGFyZVJlcGxheSgxKVxuICApO1xuXG4gIHJlZ2lzdGVyKHJlZmVyZW5jZTogRGJ4SGVscENvbnRleHRSZWZlcmVuY2UpOiB2b2lkIHtcbiAgICBjb25zdCByZWZlcmVuY2VTZXQgPSB0aGlzLl9jb250ZXh0UmVmZXJlbmNlcy52YWx1ZTtcbiAgICByZWZlcmVuY2VTZXQuYWRkKHJlZmVyZW5jZSk7XG4gICAgdGhpcy5fY29udGV4dFJlZmVyZW5jZXMubmV4dChyZWZlcmVuY2VTZXQpO1xuICB9XG5cbiAgdW5yZWdpc3RlcihyZWZlcmVuY2U6IERieEhlbHBDb250ZXh0UmVmZXJlbmNlKTogdm9pZCB7XG4gICAgY29uc3QgcmVmZXJlbmNlU2V0ID0gdGhpcy5fY29udGV4dFJlZmVyZW5jZXMudmFsdWU7XG4gICAgcmVmZXJlbmNlU2V0LmRlbGV0ZShyZWZlcmVuY2UpO1xuICAgIHRoaXMuX2NvbnRleHRSZWZlcmVuY2VzLm5leHQocmVmZXJlbmNlU2V0KTtcbiAgfVxuXG4gIG5nT25EZXN0cm95KCk6IHZvaWQge1xuICAgIHRoaXMuX2NvbnRleHRSZWZlcmVuY2VzLmNvbXBsZXRlKCk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVscC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC13ZWIvc3JjL2xpYi9leHRlbnNpb24vaGVscC9oZWxwLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyB0eXBlIE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcblxuLyoqXG4gKiBLZXlzIHVzZWQgZm9yIGlkZW50aWZ5aW5nIGhlbHAgdG9waWNzLlxuICovXG5leHBvcnQgdHlwZSBEYnhIZWxwQ29udGV4dEtleSA9IHN0cmluZztcblxuLyoqXG4gKiBSZWZlcmVuY2Ugb2JqZWN0IGZvciB0cmFja2luZyBoZWxwIGNvbnRleHQgcmVnaXN0cmF0aW9ucy5cbiAqIFVzZWQgaW50ZXJuYWxseSB0byB0cmFjayBtdWx0aXBsZSBkaXJlY3RpdmVzIHdpdGggdGhlIHNhbWUgY29udGV4dCBzdHJpbmcuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRGJ4SGVscENvbnRleHRSZWZlcmVuY2Uge1xuICAvKipcbiAgICogT2JzZXJ2YWJsZSBvZiBjb250ZXh0IHN0cmluZ3MgdGhhdCB0aGlzIHJlZmVyZW5jZSBwcm92aWRlcy5cbiAgICovXG4gIHJlYWRvbmx5IGhlbHBDb250ZXh0S2V5cyQ6IE9ic2VydmFibGU8RGJ4SGVscENvbnRleHRLZXlbXT47XG59XG4iXX0=
|
|
@@ -14,26 +14,39 @@ export class DbxHelpViewListComponent {
|
|
|
14
14
|
/**
|
|
15
15
|
* Whether the accordion should allow multiple expanded panels.
|
|
16
16
|
*/
|
|
17
|
-
multi = input(
|
|
17
|
+
multi = input();
|
|
18
18
|
/**
|
|
19
19
|
* Whether or not to show the empty list content.
|
|
20
20
|
*/
|
|
21
21
|
allowEmptyListContent = input(true);
|
|
22
22
|
/**
|
|
23
|
-
* Optional
|
|
23
|
+
* Optional header component config to inject before the list.
|
|
24
24
|
*
|
|
25
|
-
* If set null, then will not show any
|
|
25
|
+
* If set null, then will not show any header.
|
|
26
|
+
*/
|
|
27
|
+
helpListHeaderComponentConfig = input(undefined);
|
|
28
|
+
/**
|
|
29
|
+
* Optional header component config to inject before the list.
|
|
30
|
+
*
|
|
31
|
+
* If set null, then will not show any header.
|
|
26
32
|
*/
|
|
27
33
|
helpListFooterComponentConfig = input(undefined);
|
|
28
|
-
|
|
29
|
-
|
|
34
|
+
helpContextKeys = input.required();
|
|
35
|
+
helpContextKeys$ = toObservable(this.helpContextKeys).pipe(switchMap((x) => asObservable(x) ?? of([])), map(asArray), distinctUntilHasDifferentValues(), map((x) => {
|
|
30
36
|
const sortPriorityMap = this.helpWidgetService.getSortPriorityMap();
|
|
31
37
|
const sorted = [...x].sort(sortByNumberFunction((x) => sortPriorityMap.get(x) ?? -2));
|
|
32
38
|
return sorted;
|
|
33
39
|
}), shareReplay(1));
|
|
34
|
-
|
|
35
|
-
helpWidgetEntriesSignal = computed(() => this.helpWidgetService.
|
|
40
|
+
helpContextKeysSignal = toSignal(this.helpContextKeys$, { initialValue: [] });
|
|
41
|
+
helpWidgetEntriesSignal = computed(() => this.helpWidgetService.getHelpWidgetEntriesForHelpContextKeys(this.helpContextKeysSignal()));
|
|
36
42
|
hasNoHelpWidgetEntriesSignal = computed(() => !this.helpWidgetEntriesSignal()?.length);
|
|
43
|
+
helpListHeaderComponentConfigSignal = computed(() => {
|
|
44
|
+
let config = this.helpListHeaderComponentConfig();
|
|
45
|
+
if (config !== null) {
|
|
46
|
+
config = this.helpWidgetService.getHelpListHeaderComponentConfig();
|
|
47
|
+
}
|
|
48
|
+
return config;
|
|
49
|
+
});
|
|
37
50
|
helpListFooterComponentConfigSignal = computed(() => {
|
|
38
51
|
let config = this.helpListFooterComponentConfig();
|
|
39
52
|
if (config !== null) {
|
|
@@ -42,9 +55,12 @@ export class DbxHelpViewListComponent {
|
|
|
42
55
|
return config;
|
|
43
56
|
});
|
|
44
57
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxHelpViewListComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
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 },
|
|
58
|
+
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 }, helpListHeaderComponentConfig: { classPropertyName: "helpListHeaderComponentConfig", publicName: "helpListHeaderComponentConfig", isSignal: true, isRequired: false, transformFunction: null }, helpListFooterComponentConfig: { classPropertyName: "helpListFooterComponentConfig", publicName: "helpListFooterComponentConfig", isSignal: true, isRequired: false, transformFunction: null }, helpContextKeys: { classPropertyName: "helpContextKeys", publicName: "helpContextKeys", isSignal: true, isRequired: true, transformFunction: null } }, host: { classAttribute: "dbx-help-view-list dbx-block" }, ngImport: i0, template: `
|
|
59
|
+
<div class="dbx-help-view-list-header">
|
|
60
|
+
<dbx-injection [config]="helpListHeaderComponentConfigSignal()"></dbx-injection>
|
|
61
|
+
</div>
|
|
46
62
|
<mat-accordion [multi]="multi()">
|
|
47
|
-
@for (widgetEntry of helpWidgetEntriesSignal(); track widgetEntry.
|
|
63
|
+
@for (widgetEntry of helpWidgetEntriesSignal(); track widgetEntry.helpContextKey) {
|
|
48
64
|
<dbx-help-view-list-entry [helpWidgetEntry]="widgetEntry"></dbx-help-view-list-entry>
|
|
49
65
|
}
|
|
50
66
|
</mat-accordion>
|
|
@@ -63,8 +79,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
63
79
|
args: [{
|
|
64
80
|
selector: 'dbx-help-view-list',
|
|
65
81
|
template: `
|
|
82
|
+
<div class="dbx-help-view-list-header">
|
|
83
|
+
<dbx-injection [config]="helpListHeaderComponentConfigSignal()"></dbx-injection>
|
|
84
|
+
</div>
|
|
66
85
|
<mat-accordion [multi]="multi()">
|
|
67
|
-
@for (widgetEntry of helpWidgetEntriesSignal(); track widgetEntry.
|
|
86
|
+
@for (widgetEntry of helpWidgetEntriesSignal(); track widgetEntry.helpContextKey) {
|
|
68
87
|
<dbx-help-view-list-entry [helpWidgetEntry]="widgetEntry"></dbx-help-view-list-entry>
|
|
69
88
|
}
|
|
70
89
|
</mat-accordion>
|
|
@@ -85,4 +104,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
85
104
|
changeDetection: ChangeDetectionStrategy.OnPush
|
|
86
105
|
}]
|
|
87
106
|
}] });
|
|
88
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
107
|
+
//# 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":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AAE5F,OAAO,EAAE,YAAY,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAC;AACpE,OAAO,EAAE,YAAY,EAAE,+BAA+B,EAAqB,MAAM,eAAe,CAAC;AACjG,OAAO,EAAE,GAAG,EAAc,EAAE,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AACnE,OAAO,EAAE,oBAAoB,EAAE,MAAM,uBAAuB,CAAC;AAC7D,OAAO,EAAE,6BAA6B,EAAE,MAAM,kCAAkC,CAAC;AACjF,OAAO,EAAgB,OAAO,EAAS,oBAAoB,EAAE,MAAM,eAAe,CAAC;AACnF,OAAO,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAC;AAC3D,OAAO,EAAE,4BAA4B,EAAE,MAAM,gDAAgD,CAAC;AAC9F,OAAO,EAAE,qBAAqB,EAA+B,MAAM,mBAAmB,CAAC;;AA6BvF,MAAM,OAAO,wBAAwB;IAC1B,iBAAiB,GAAG,MAAM,CAAC,oBAAoB,CAAC,CAAC;IAE1D;;OAEG;IACM,KAAK,GAAG,KAAK,EAAkB,CAAC;IAEzC;;OAEG;IACM,qBAAqB,GAAG,KAAK,CAAU,IAAI,CAAC,CAAC;IAEtD;;;;OAIG;IACM,6BAA6B,GAAG,KAAK,CAAqC,SAAS,CAAC,CAAC;IAE9F;;;;OAIG;IACM,6BAA6B,GAAG,KAAK,CAAqC,SAAS,CAAC,CAAC;IAErF,eAAe,GAAG,KAAK,CAAC,QAAQ,EAAsD,CAAC;IACvF,gBAAgB,GAAoC,YAAY,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,IAAI,CAClG,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,EAAE,CAAC,CAAC,EAC3C,GAAG,CAAC,OAAO,CAAC,EACZ,+BAA+B,EAAE,EACjC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE;QACR,MAAM,eAAe,GAAG,IAAI,CAAC,iBAAiB,CAAC,kBAAkB,EAAE,CAAC;QACpE,MAAM,MAAM,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;QACtF,OAAO,MAAM,CAAC;IAChB,CAAC,CAAC,EACF,WAAW,CAAC,CAAC,CAAC,CACf,CAAC;IAEO,qBAAqB,GAAG,QAAQ,CAAC,IAAI,CAAC,gBAAgB,EAAE,EAAE,YAAY,EAAE,EAAE,EAAE,CAAC,CAAC;IAC9E,uBAAuB,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,iBAAiB,CAAC,sCAAsC,CAAC,IAAI,CAAC,qBAAqB,EAAE,CAAC,CAAC,CAAC;IAEtI,4BAA4B,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,uBAAuB,EAAE,EAAE,MAAM,CAAC,CAAC;IAEvF,mCAAmC,GAAG,QAAQ,CAAC,GAAG,EAAE;QAC3D,IAAI,MAAM,GAAuC,IAAI,CAAC,6BAA6B,EAAE,CAAC;QAEtF,IAAI,MAAM,KAAK,IAAI,EAAE,CAAC;YACpB,MAAM,GAAG,IAAI,CAAC,iBAAiB,CAAC,gCAAgC,EAAE,CAAC;QACrE,CAAC;QAED,OAAO,MAAM,CAAC;IAChB,CAAC,CAAC,CAAC;IAEM,mCAAmC,GAAG,QAAQ,CAAC,GAAG,EAAE;QAC3D,IAAI,MAAM,GAAuC,IAAI,CAAC,6BAA6B,EAAE,CAAC;QAEtF,IAAI,MAAM,KAAK,IAAI,EAAE,CAAC;YACpB,MAAM,GAAG,IAAI,CAAC,iBAAiB,CAAC,gCAAgC,EAAE,CAAC;QACrE,CAAC;QAED,OAAO,MAAM,CAAC;IAChB,CAAC,CAAC,CAAC;wGA/DQ,wBAAwB;4FAAxB,wBAAwB,y8BAzBzB;;;;;;;;;;;;;;;;;GAiBT,4DAIS,YAAY,+IAAE,6BAA6B,kGAAE,4BAA4B,mEAAE,qBAAqB;;4FAI/F,wBAAwB;kBA3BpC,SAAS;mBAAC;oBACT,QAAQ,EAAE,oBAAoB;oBAC9B,QAAQ,EAAE;;;;;;;;;;;;;;;;;GAiBT;oBACD,IAAI,EAAE;wBACJ,KAAK,EAAE,8BAA8B;qBACtC;oBACD,OAAO,EAAE,CAAC,YAAY,EAAE,6BAA6B,EAAE,4BAA4B,EAAE,qBAAqB,CAAC;oBAC3G,UAAU,EAAE,IAAI;oBAChB,eAAe,EAAE,uBAAuB,CAAC,MAAM;iBAChD","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, inject, input } from '@angular/core';\nimport { DbxHelpContextKey } 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    <div class=\"dbx-help-view-list-header\">\n      <dbx-injection [config]=\"helpListHeaderComponentConfigSignal()\"></dbx-injection>\n    </div>\n    <mat-accordion [multi]=\"multi()\">\n      @for (widgetEntry of helpWidgetEntriesSignal(); track widgetEntry.helpContextKey) {\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<Maybe<boolean>>();\n\n  /**\n   * Whether or not to show the empty list content.\n   */\n  readonly allowEmptyListContent = input<boolean>(true);\n\n  /**\n   * Optional header component config to inject before the list.\n   *\n   * If set null, then will not show any header.\n   */\n  readonly helpListHeaderComponentConfig = input<Maybe<DbxInjectionComponentConfig>>(undefined);\n\n  /**\n   * Optional header component config to inject before the list.\n   *\n   * If set null, then will not show any header.\n   */\n  readonly helpListFooterComponentConfig = input<Maybe<DbxInjectionComponentConfig>>(undefined);\n\n  readonly helpContextKeys = input.required<ObservableOrValue<ArrayOrValue<DbxHelpContextKey>>>();\n  readonly helpContextKeys$: Observable<DbxHelpContextKey[]> = toObservable(this.helpContextKeys).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 helpContextKeysSignal = toSignal(this.helpContextKeys$, { initialValue: [] });\n  readonly helpWidgetEntriesSignal = computed(() => this.helpWidgetService.getHelpWidgetEntriesForHelpContextKeys(this.helpContextKeysSignal()));\n\n  readonly hasNoHelpWidgetEntriesSignal = computed(() => !this.helpWidgetEntriesSignal()?.length);\n\n  readonly helpListHeaderComponentConfigSignal = computed(() => {\n    let config: Maybe<DbxInjectionComponentConfig> = this.helpListHeaderComponentConfig();\n\n    if (config !== null) {\n      config = this.helpWidgetService.getHelpListHeaderComponentConfig();\n    }\n\n    return config;\n  });\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"]}
|
|
@@ -4,6 +4,7 @@ import { MatExpansionPanel, MatExpansionPanelHeader, MatExpansionPanelTitle, Mat
|
|
|
4
4
|
import { MatIcon } from '@angular/material/icon';
|
|
5
5
|
import { AsyncPipe } from '@angular/common';
|
|
6
6
|
import { DBX_HELP_WIDGET_ENTRY_DATA_TOKEN } from './help.widget';
|
|
7
|
+
import { getValueFromGetter } from '@dereekb/util';
|
|
7
8
|
import { DbxHelpWidgetService } from './help.widget.service';
|
|
8
9
|
import * as i0 from "@angular/core";
|
|
9
10
|
export class DbxHelpViewListEntryComponent {
|
|
@@ -13,7 +14,7 @@ export class DbxHelpViewListEntryComponent {
|
|
|
13
14
|
iconSignal = computed(() => this.helpWidgetEntry().icon ?? this.helpWidgetService.getDefaultIcon());
|
|
14
15
|
widgetInjectionConfigSignal = computed(() => {
|
|
15
16
|
const helpWidgetEntry = this.helpWidgetEntry();
|
|
16
|
-
const widgetComponentClass = helpWidgetEntry.widgetComponentClass;
|
|
17
|
+
const widgetComponentClass = getValueFromGetter(helpWidgetEntry.widgetComponentClass);
|
|
17
18
|
const widgetData = {
|
|
18
19
|
helpWidgetEntry
|
|
19
20
|
};
|
|
@@ -30,7 +31,7 @@ export class DbxHelpViewListEntryComponent {
|
|
|
30
31
|
});
|
|
31
32
|
headerInjectionConfigSignal = computed(() => {
|
|
32
33
|
const helpWidgetEntry = this.helpWidgetEntry();
|
|
33
|
-
const headerComponentClass = helpWidgetEntry.headerComponentClass;
|
|
34
|
+
const headerComponentClass = getValueFromGetter(helpWidgetEntry.headerComponentClass);
|
|
34
35
|
let config = undefined;
|
|
35
36
|
if (headerComponentClass) {
|
|
36
37
|
const widgetData = {
|
|
@@ -55,4 +56,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
55
56
|
type: Component,
|
|
56
57
|
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
|
}] });
|
|
58
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
59
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVscC52aWV3Lmxpc3QuZW50cnkuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LXdlYi9zcmMvbGliL2V4dGVuc2lvbi9oZWxwL2hlbHAudmlldy5saXN0LmVudHJ5LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC13ZWIvc3JjL2xpYi9leHRlbnNpb24vaGVscC9oZWxwLnZpZXcubGlzdC5lbnRyeS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLFFBQVEsRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFVLE1BQU0sZUFBZSxDQUFDO0FBQ3BHLE9BQU8sRUFBRSxxQkFBcUIsRUFBK0IsTUFBTSxtQkFBbUIsQ0FBQztBQUN2RixPQUFPLEVBQUUsaUJBQWlCLEVBQUUsdUJBQXVCLEVBQUUsc0JBQXNCLEVBQUUsNEJBQTRCLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQUN6SyxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDakQsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQzVDLE9BQU8sRUFBRSxnQ0FBZ0MsRUFBcUQsTUFBTSxlQUFlLENBQUM7QUFDcEgsT0FBTyxFQUFFLGtCQUFrQixFQUFTLE1BQU0sZUFBZSxDQUFDO0FBQzFELE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHVCQUF1QixDQUFDOztBQVM3RCxNQUFNLE9BQU8sNkJBQTZCO0lBQy9CLGVBQWUsR0FBRyxLQUFLLENBQUMsUUFBUSxFQUE2QixDQUFDO0lBQzlELGlCQUFpQixHQUFHLE1BQU0sQ0FBQyxvQkFBb0IsQ0FBQyxDQUFDO0lBRWpELFdBQVcsR0FBRyxRQUFRLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLGVBQWUsRUFBRSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQzNELFVBQVUsR0FBRyxRQUFRLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLGVBQWUsRUFBRSxDQUFDLElBQUksSUFBSSxJQUFJLENBQUMsaUJBQWlCLENBQUMsY0FBYyxFQUFFLENBQUMsQ0FBQztJQUVwRywyQkFBMkIsR0FBd0MsUUFBUSxDQUFDLEdBQUcsRUFBRTtRQUN4RixNQUFNLGVBQWUsR0FBRyxJQUFJLENBQUMsZUFBZSxFQUFFLENBQUM7UUFDL0MsTUFBTSxvQkFBb0IsR0FBRyxrQkFBa0IsQ0FBQyxlQUFlLENBQUMsb0JBQW9CLENBQUMsQ0FBQztRQUV0RixNQUFNLFVBQVUsR0FBMkI7WUFDekMsZUFBZTtTQUNoQixDQUFDO1FBRUYsTUFBTSxNQUFNLEdBQWdDO1lBQzFDLGNBQWMsRUFBRSxvQkFBb0I7WUFDcEMsU0FBUyxFQUFFO2dCQUNUO29CQUNFLE9BQU8sRUFBRSxnQ0FBZ0M7b0JBQ3pDLFFBQVEsRUFBRSxVQUFVO2lCQUNyQjthQUNGO1NBQ0YsQ0FBQztRQUVGLE9BQU8sTUFBTSxDQUFDO0lBQ2hCLENBQUMsQ0FBQyxDQUFDO0lBRU0sMkJBQTJCLEdBQStDLFFBQVEsQ0FBQyxHQUFHLEVBQUU7UUFDL0YsTUFBTSxlQUFlLEdBQUcsSUFBSSxDQUFDLGVBQWUsRUFBRSxDQUFDO1FBQy9DLE1BQU0sb0JBQW9CLEdBQUcsa0JBQWtCLENBQUMsZUFBZSxDQUFDLG9CQUFvQixDQUFDLENBQUM7UUFFdEYsSUFBSSxNQUFNLEdBQXVDLFNBQVMsQ0FBQztRQUUzRCxJQUFJLG9CQUFvQixFQUFFLENBQUM7WUFDekIsTUFBTSxVQUFVLEdBQTJCO2dCQUN6QyxlQUFlO2FBQ2hCLENBQUM7WUFFRixNQUFNLEdBQUc7Z0JBQ1AsY0FBYyxFQUFFLG9CQUFvQjtnQkFDcEMsU0FBUyxFQUFFO29CQUNUO3dCQUNFLE9BQU8sRUFBRSxnQ0FBZ0M7d0JBQ3pDLFFBQVEsRUFBRSxVQUFVO3FCQUNyQjtpQkFDRjthQUNGLENBQUM7UUFDSixDQUFDO1FBRUQsT0FBTyxNQUFNLENBQUM7SUFDaEIsQ0FBQyxDQUFDLENBQUM7d0dBbkRRLDZCQUE2Qjs0RkFBN0IsNkJBQTZCLHFQQ2hCMUMsbzBCQXVCQSw0Q0RYWSxxQkFBcUIsMkhBQUUsaUJBQWlCLHNMQUFFLHVCQUF1QixrSUFBRSxzQkFBc0IsNERBQUUsNEJBQTRCLGtFQUFFLHdCQUF3QixrRkFBRSxPQUFPOzs0RkFJekosNkJBQTZCO2tCQVB6QyxTQUFTOytCQUNFLDBCQUEwQixXQUUzQixDQUFDLHFCQUFxQixFQUFFLGlCQUFpQixFQUFFLHVCQUF1QixFQUFFLHNCQUFzQixFQUFFLDRCQUE0QixFQUFFLHdCQUF3QixFQUFFLE9BQU8sRUFBRSxTQUFTLENBQUMsbUJBQy9KLHVCQUF1QixDQUFDLE1BQU0sY0FDbkMsSUFBSSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIGNvbXB1dGVkLCBpbmplY3QsIGlucHV0LCBTaWduYWwgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IERieEluamVjdGlvbkNvbXBvbmVudCwgRGJ4SW5qZWN0aW9uQ29tcG9uZW50Q29uZmlnIH0gZnJvbSAnQGRlcmVla2IvZGJ4LWNvcmUnO1xuaW1wb3J0IHsgTWF0RXhwYW5zaW9uUGFuZWwsIE1hdEV4cGFuc2lvblBhbmVsSGVhZGVyLCBNYXRFeHBhbnNpb25QYW5lbFRpdGxlLCBNYXRFeHBhbnNpb25QYW5lbERlc2NyaXB0aW9uLCBNYXRFeHBhbnNpb25QYW5lbENvbnRlbnQgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9leHBhbnNpb24nO1xuaW1wb3J0IHsgTWF0SWNvbiB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xuaW1wb3J0IHsgQXN5bmNQaXBlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IERCWF9IRUxQX1dJREdFVF9FTlRSWV9EQVRBX1RPS0VOLCBEYnhIZWxwV2lkZ2V0RW50cnlEYXRhLCBEYnhIZWxwV2lkZ2V0U2VydmljZUVudHJ5IH0gZnJvbSAnLi9oZWxwLndpZGdldCc7XG5pbXBvcnQgeyBnZXRWYWx1ZUZyb21HZXR0ZXIsIE1heWJlIH0gZnJvbSAnQGRlcmVla2IvdXRpbCc7XG5pbXBvcnQgeyBEYnhIZWxwV2lkZ2V0U2VydmljZSB9IGZyb20gJy4vaGVscC53aWRnZXQuc2VydmljZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2RieC1oZWxwLXZpZXctbGlzdC1lbnRyeScsXG4gIHRlbXBsYXRlVXJsOiAnLi9oZWxwLnZpZXcubGlzdC5lbnRyeS5jb21wb25lbnQuaHRtbCcsXG4gIGltcG9ydHM6IFtEYnhJbmplY3Rpb25Db21wb25lbnQsIE1hdEV4cGFuc2lvblBhbmVsLCBNYXRFeHBhbnNpb25QYW5lbEhlYWRlciwgTWF0RXhwYW5zaW9uUGFuZWxUaXRsZSwgTWF0RXhwYW5zaW9uUGFuZWxEZXNjcmlwdGlvbiwgTWF0RXhwYW5zaW9uUGFuZWxDb250ZW50LCBNYXRJY29uLCBBc3luY1BpcGVdLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgc3RhbmRhbG9uZTogdHJ1ZVxufSlcbmV4cG9ydCBjbGFzcyBEYnhIZWxwVmlld0xpc3RFbnRyeUNvbXBvbmVudCB7XG4gIHJlYWRvbmx5IGhlbHBXaWRnZXRFbnRyeSA9IGlucHV0LnJlcXVpcmVkPERieEhlbHBXaWRnZXRTZXJ2aWNlRW50cnk+KCk7XG4gIHJlYWRvbmx5IGhlbHBXaWRnZXRTZXJ2aWNlID0gaW5qZWN0KERieEhlbHBXaWRnZXRTZXJ2aWNlKTtcblxuICByZWFkb25seSB0aXRsZVNpZ25hbCA9IGNvbXB1dGVkKCgpID0+IHRoaXMuaGVscFdpZGdldEVudHJ5KCkudGl0bGUpO1xuICByZWFkb25seSBpY29uU2lnbmFsID0gY29tcHV0ZWQoKCkgPT4gdGhpcy5oZWxwV2lkZ2V0RW50cnkoKS5pY29uID8/IHRoaXMuaGVscFdpZGdldFNlcnZpY2UuZ2V0RGVmYXVsdEljb24oKSk7XG5cbiAgcmVhZG9ubHkgd2lkZ2V0SW5qZWN0aW9uQ29uZmlnU2lnbmFsOiBTaWduYWw8RGJ4SW5qZWN0aW9uQ29tcG9uZW50Q29uZmlnPiA9IGNvbXB1dGVkKCgpID0+IHtcbiAgICBjb25zdCBoZWxwV2lkZ2V0RW50cnkgPSB0aGlzLmhlbHBXaWRnZXRFbnRyeSgpO1xuICAgIGNvbnN0IHdpZGdldENvbXBvbmVudENsYXNzID0gZ2V0VmFsdWVGcm9tR2V0dGVyKGhlbHBXaWRnZXRFbnRyeS53aWRnZXRDb21wb25lbnRDbGFzcyk7XG5cbiAgICBjb25zdCB3aWRnZXREYXRhOiBEYnhIZWxwV2lkZ2V0RW50cnlEYXRhID0ge1xuICAgICAgaGVscFdpZGdldEVudHJ5XG4gICAgfTtcblxuICAgIGNvbnN0IGNvbmZpZzogRGJ4SW5qZWN0aW9uQ29tcG9uZW50Q29uZmlnID0ge1xuICAgICAgY29tcG9uZW50Q2xhc3M6IHdpZGdldENvbXBvbmVudENsYXNzLFxuICAgICAgcHJvdmlkZXJzOiBbXG4gICAgICAgIHtcbiAgICAgICAgICBwcm92aWRlOiBEQlhfSEVMUF9XSURHRVRfRU5UUllfREFUQV9UT0tFTixcbiAgICAgICAgICB1c2VWYWx1ZTogd2lkZ2V0RGF0YVxuICAgICAgICB9XG4gICAgICBdXG4gICAgfTtcblxuICAgIHJldHVybiBjb25maWc7XG4gIH0pO1xuXG4gIHJlYWRvbmx5IGhlYWRlckluamVjdGlvbkNvbmZpZ1NpZ25hbDogU2lnbmFsPE1heWJlPERieEluamVjdGlvbkNvbXBvbmVudENvbmZpZz4+ID0gY29tcHV0ZWQoKCkgPT4ge1xuICAgIGNvbnN0IGhlbHBXaWRnZXRFbnRyeSA9IHRoaXMuaGVscFdpZGdldEVudHJ5KCk7XG4gICAgY29uc3QgaGVhZGVyQ29tcG9uZW50Q2xhc3MgPSBnZXRWYWx1ZUZyb21HZXR0ZXIoaGVscFdpZGdldEVudHJ5LmhlYWRlckNvbXBvbmVudENsYXNzKTtcblxuICAgIGxldCBjb25maWc6IE1heWJlPERieEluamVjdGlvbkNvbXBvbmVudENvbmZpZz4gPSB1bmRlZmluZWQ7XG5cbiAgICBpZiAoaGVhZGVyQ29tcG9uZW50Q2xhc3MpIHtcbiAgICAgIGNvbnN0IHdpZGdldERhdGE6IERieEhlbHBXaWRnZXRFbnRyeURhdGEgPSB7XG4gICAgICAgIGhlbHBXaWRnZXRFbnRyeVxuICAgICAgfTtcblxuICAgICAgY29uZmlnID0ge1xuICAgICAgICBjb21wb25lbnRDbGFzczogaGVhZGVyQ29tcG9uZW50Q2xhc3MsXG4gICAgICAgIHByb3ZpZGVyczogW1xuICAgICAgICAgIHtcbiAgICAgICAgICAgIHByb3ZpZGU6IERCWF9IRUxQX1dJREdFVF9FTlRSWV9EQVRBX1RPS0VOLFxuICAgICAgICAgICAgdXNlVmFsdWU6IHdpZGdldERhdGFcbiAgICAgICAgICB9XG4gICAgICAgIF1cbiAgICAgIH07XG4gICAgfVxuXG4gICAgcmV0dXJuIGNvbmZpZztcbiAgfSk7XG59XG4iLCI8bWF0LWV4cGFuc2lvbi1wYW5lbD5cbiAgPG1hdC1leHBhbnNpb24tcGFuZWwtaGVhZGVyPlxuICAgIDxtYXQtcGFuZWwtdGl0bGU+XG4gICAgICBAaWYgKGljb25TaWduYWwoKTsgYXMgaWNvbikge1xuICAgICAgICA8bWF0LWljb24gY2xhc3M9XCJkYngtYnV0dG9uLXNwYWNlclwiPnt7IGljb24gfX08L21hdC1pY29uPlxuICAgICAgfVxuICAgICAgPHNwYW4+e3sgdGl0bGVTaWduYWwoKSB9fTwvc3Bhbj5cbiAgICA8L21hdC1wYW5lbC10aXRsZT5cbiAgICA8bmctY29udGFpbmVyPlxuICAgICAgQGlmIChoZWFkZXJJbmplY3Rpb25Db25maWdTaWduYWwoKTsgYXMgaGVhZGVySW5qZWN0aW9uQ29uZmlnKSB7XG4gICAgICAgIDxtYXQtcGFuZWwtZGVzY3JpcHRpb24+XG4gICAgICAgICAgPHNwYW4gY2xhc3M9XCJkYngtc3BhY2VyXCI+PC9zcGFuPlxuICAgICAgICAgIDxkYngtaW5qZWN0aW9uIFtjb25maWddPVwiaGVhZGVySW5qZWN0aW9uQ29uZmlnXCI+PC9kYngtaW5qZWN0aW9uPlxuICAgICAgICA8L21hdC1wYW5lbC1kZXNjcmlwdGlvbj5cbiAgICAgIH1cbiAgICA8L25nLWNvbnRhaW5lcj5cbiAgPC9tYXQtZXhwYW5zaW9uLXBhbmVsLWhlYWRlcj5cbiAgPG5nLXRlbXBsYXRlIG1hdEV4cGFuc2lvblBhbmVsQ29udGVudD5cbiAgICA8ZGl2IGNsYXNzPVwiZGJ4LWhlbHAtdmlldy1saXN0LWVudHJ5LWNvbnRlbnRcIj5cbiAgICAgIDxkYngtaW5qZWN0aW9uIFtjb25maWddPVwid2lkZ2V0SW5qZWN0aW9uQ29uZmlnU2lnbmFsKClcIj48L2RieC1pbmplY3Rpb24+XG4gICAgPC9kaXY+XG4gIDwvbmctdGVtcGxhdGU+XG48L21hdC1leHBhbnNpb24tcGFuZWw+XG4iXX0=
|
|
@@ -13,7 +13,7 @@ export const DEFAULT_DBX_HELP_VIEW_POPOVER_KEY = 'help';
|
|
|
13
13
|
export class DbxHelpViewPopoverComponent extends AbstractPopoverDirective {
|
|
14
14
|
_helpContextService = inject(DbxHelpContextService);
|
|
15
15
|
_helpWidgetService = inject(DbxHelpWidgetService);
|
|
16
|
-
|
|
16
|
+
helpContextKeys$ = this.popover.data?.helpContextKeys ?? this._helpContextService.activeHelpContextKeysArray$;
|
|
17
17
|
static openPopover(popoverService, config, popoverKey) {
|
|
18
18
|
const { origin, popoverSizingConfig, ...data } = config;
|
|
19
19
|
return popoverService.open({
|
|
@@ -32,6 +32,7 @@ export class DbxHelpViewPopoverComponent extends AbstractPopoverDirective {
|
|
|
32
32
|
}
|
|
33
33
|
icon = this.config.icon ?? 'help';
|
|
34
34
|
header = this.config.header ?? 'Help';
|
|
35
|
+
multi = this.config.multi;
|
|
35
36
|
emptyText = this.config.emptyText ?? 'No help topics available in current context.';
|
|
36
37
|
allowEmptyListContent = this.config.allowEmptyListContent ?? true;
|
|
37
38
|
helpListFooterComponentConfig = this.config.helpListFooterComponentConfig;
|
|
@@ -43,10 +44,10 @@ export class DbxHelpViewPopoverComponent extends AbstractPopoverDirective {
|
|
|
43
44
|
return config;
|
|
44
45
|
})();
|
|
45
46
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxHelpViewPopoverComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
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 [
|
|
47
|
+
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 [helpContextKeys]=\"helpContextKeys$\" [multi]=\"multi\" [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", "helpListHeaderComponentConfig", "helpListFooterComponentConfig", "helpContextKeys"] }, { kind: "component", type: DbxInjectionComponent, selector: "dbx-injection, [dbxInjection], [dbx-injection]", inputs: ["config", "template"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
47
48
|
}
|
|
48
49
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxHelpViewPopoverComponent, decorators: [{
|
|
49
50
|
type: Component,
|
|
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 [
|
|
51
|
+
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 [helpContextKeys]=\"helpContextKeys$\" [multi]=\"multi\" [allowEmptyListContent]=\"allowEmptyListContent\" [helpListFooterComponentConfig]=\"helpListFooterComponentConfig\">\n <p empty>{{ emptyText }}</p>\n </dbx-help-view-list>\n </dbx-popover-scroll-content>\n</dbx-popover-content>\n" }]
|
|
51
52
|
}] });
|
|
52
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
53
|
+
//# 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;AA2DxD;;GAEG;AAOH,MAAM,OAAO,2BAA4B,SAAQ,wBAA2D;IACzF,mBAAmB,GAAG,MAAM,CAAC,qBAAqB,CAAC,CAAC;IACpD,kBAAkB,GAAG,MAAM,CAAC,oBAAoB,CAAC,CAAC;IAE1D,gBAAgB,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,eAAe,IAAI,IAAI,CAAC,mBAAmB,CAAC,2BAA2B,CAAC;IAEvH,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,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC;IAC1B,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;wGAxCM,2BAA2B;4FAA3B,2BAA2B,+FClFxC,0jBAYA,4CDkEY,0BAA0B,gEAAE,yBAAyB,2FAAE,gCAAgC,6HAAE,wBAAwB,gMAAE,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 { DbxHelpContextKey } 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 helpContextKeys?: Maybe<ObservableOrValue<ArrayOrValue<DbxHelpContextKey>>>;\n\n  /**\n   * Optional footer component config to inject after the list.\n   */\n  readonly helpListFooterComponentConfig?: Maybe<DbxInjectionComponentConfig>;\n\n  /**\n   * Whether the accordion should allow multiple expanded panels.\n   */\n  readonly multi?: Maybe<boolean>;\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 helpContextKeys$ = this.popover.data?.helpContextKeys ?? this._helpContextService.activeHelpContextKeysArray$;\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 multi = this.config.multi;\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 [helpContextKeys]=\"helpContextKeys$\" [multi]=\"multi\" [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,
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVscC53aWRnZXQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3NyYy9saWIvZXh0ZW5zaW9uL2hlbHAvaGVscC53aWRnZXQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGNBQWMsRUFBYSxNQUFNLGVBQWUsQ0FBQztBQW9EMUQ7O0dBRUc7QUFDSCxNQUFNLENBQUMsTUFBTSxnQ0FBZ0MsR0FBRyxJQUFJLGNBQWMsQ0FBeUIsd0JBQXdCLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGlvblRva2VuLCB0eXBlIFR5cGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IHR5cGUgR2V0dGVyT3JWYWx1ZSwgdHlwZSBNYXliZSB9IGZyb20gJ0BkZXJlZWtiL3V0aWwnO1xuaW1wb3J0IHsgdHlwZSBEYnhIZWxwQ29udGV4dEtleSB9IGZyb20gJy4vaGVscCc7XG5cbi8qKlxuICogRW50cnkgZGVmaW5pbmcgYSBoZWxwIHdpZGdldCBmb3IgYSBzcGVjaWZpYyBjb250ZXh0XG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRGJ4SGVscFdpZGdldFNlcnZpY2VFbnRyeTxEID0gdW5rbm93bj4ge1xuICAvKipcbiAgICogSGVscCBjb250ZXh0IHN0cmluZyBzcGVjaWZpYyB0byB0aGlzIGVudHJ5LlxuICAgKi9cbiAgcmVhZG9ubHkgaGVscENvbnRleHRLZXk6IERieEhlbHBDb250ZXh0S2V5O1xuICAvKipcbiAgICogVGl0bGUvTGFiZWwgZm9yIHRoZSBoZWxwIHRvcGljLlxuICAgKi9cbiAgcmVhZG9ubHkgdGl0bGU6IHN0cmluZztcbiAgLyoqXG4gICAqIEljb24gZm9yIHRoZSBoZWxwIHRvcGljLCBpZiBhcHBsaWNhYmxlLlxuICAgKi9cbiAgcmVhZG9ubHkgaWNvbj86IE1heWJlPHN0cmluZz47XG4gIC8qKlxuICAgKiBBcmJpdHJhcnkgbWV0YWRhdGEgYXNzb2NpYXRlZCB3aXRoIHRoZSBlbnRyeS5cbiAgICovXG4gIHJlYWRvbmx5IG1ldGE/OiBNYXliZTxEPjtcbiAgLyoqXG4gICAqIFRoZSBwcmlvcml0eSB0byB1c2Ugd2hlbiBzb3J0aW5nIHRoZSBlbnRpdGllcy5cbiAgICpcbiAgICogSGlnaGVyIHZhbHVlcyBhcmUgZGlzcGxheWVkIGZpcnN0IGluIHRoZSBsaXN0LlxuICAgKi9cbiAgcmVhZG9ubHkgc29ydFByaW9yaXR5PzogTWF5YmU8bnVtYmVyPjtcbiAgLyoqXG4gICAqIEN1c3RvbSBoZWxwIHdpZGdldCBjb21wb25lbnQgY2xhc3MgdG8gdXNlLlxuICAgKlxuICAgKiBUaGUgY29tcG9uZW50IHdpbGwgcmVjZWl2ZSB0aGUgY29udGV4dCBzdHJpbmcgYXMgZGF0YS5cbiAgICovXG4gIHJlYWRvbmx5IHdpZGdldENvbXBvbmVudENsYXNzOiBHZXR0ZXJPclZhbHVlPFR5cGU8dW5rbm93bj4+O1xuICAvKipcbiAgICogQ3VzdG9tIGhlYWRlciBjb21wb25lbnQgY2xhc3MgdG8gdXNlIHRoYXQgc2hvd3MgdXAgb24gdGhlIHdpZGdldC5cbiAgICpcbiAgICogVGhlIGNvbXBvbmVudCB3aWxsIHJlY2VpdmUgdGhlIGNvbnRleHQgc3RyaW5nIGFzIGRhdGEuXG4gICAqL1xuICByZWFkb25seSBoZWFkZXJDb21wb25lbnRDbGFzcz86IEdldHRlck9yVmFsdWU8TWF5YmU8VHlwZTx1bmtub3duPj4+O1xufVxuXG4vLyBNQVJLOiBJbmplY3Rpb25cbmV4cG9ydCBpbnRlcmZhY2UgRGJ4SGVscFdpZGdldEVudHJ5RGF0YTxEID0gdW5rbm93bj4ge1xuICAvKipcbiAgICogQ29ycmVzcG9uZGluZyB3aWRnZXQgZW50cnkuXG4gICAqL1xuICByZWFkb25seSBoZWxwV2lkZ2V0RW50cnk6IERieEhlbHBXaWRnZXRTZXJ2aWNlRW50cnk8RD47XG59XG5cbi8qKlxuICogSW5qZWN0aW9uIHRva2VuIGZvciBEYnhIZWxwV2lkZ2V0RGF0YS5cbiAqL1xuZXhwb3J0IGNvbnN0IERCWF9IRUxQX1dJREdFVF9FTlRSWV9EQVRBX1RPS0VOID0gbmV3IEluamVjdGlvblRva2VuPERieEhlbHBXaWRnZXRFbnRyeURhdGE+KCdEYnhIZWxwV2lkZ2V0RW50cnlEYXRhJyk7XG4iXX0=
|
|
@@ -12,16 +12,18 @@ export class DbxHelpWidgetServiceConfig {
|
|
|
12
12
|
export class DbxHelpWidgetService {
|
|
13
13
|
_entries = new Map();
|
|
14
14
|
_sortPriorityMap = cachedGetter(() => {
|
|
15
|
-
return new Map(mapIterable(this._entries.values(), (entry) => [entry.
|
|
15
|
+
return new Map(mapIterable(this._entries.values(), (entry) => [entry.helpContextKey, entry.sortPriority ?? -1]));
|
|
16
16
|
});
|
|
17
17
|
_defaultWidgetComponentClass;
|
|
18
|
+
_helpListHeaderComponentConfig;
|
|
18
19
|
_helpListFooterComponentConfig;
|
|
19
20
|
_defaultIcon;
|
|
20
21
|
_popoverHeaderComponentConfig;
|
|
21
22
|
constructor(initialConfig) {
|
|
22
23
|
this.setDefaultWidgetComponentClass(initialConfig?.defaultWidgetComponentClass);
|
|
23
|
-
this.setDefaultIcon(initialConfig?.defaultIcon
|
|
24
|
+
this.setDefaultIcon(initialConfig?.defaultIcon);
|
|
24
25
|
this.setPopoverHeaderComponentConfig(initialConfig?.popoverHeaderComponentConfig);
|
|
26
|
+
this.setHelpListHeaderComponentConfig(initialConfig?.helpListHeaderComponentConfig);
|
|
25
27
|
this.setHelpListFooterComponentConfig(initialConfig?.helpListFooterComponentConfig);
|
|
26
28
|
if (initialConfig?.entries) {
|
|
27
29
|
this.register(initialConfig.entries);
|
|
@@ -45,6 +47,12 @@ export class DbxHelpWidgetService {
|
|
|
45
47
|
setPopoverHeaderComponentConfig(componentConfig) {
|
|
46
48
|
this._popoverHeaderComponentConfig = componentConfig;
|
|
47
49
|
}
|
|
50
|
+
getHelpListHeaderComponentConfig() {
|
|
51
|
+
return this._helpListHeaderComponentConfig;
|
|
52
|
+
}
|
|
53
|
+
setHelpListHeaderComponentConfig(componentConfig) {
|
|
54
|
+
this._helpListHeaderComponentConfig = componentConfig;
|
|
55
|
+
}
|
|
48
56
|
getHelpListFooterComponentConfig() {
|
|
49
57
|
return this._helpListFooterComponentConfig;
|
|
50
58
|
}
|
|
@@ -62,21 +70,21 @@ export class DbxHelpWidgetService {
|
|
|
62
70
|
register(entries, override = true) {
|
|
63
71
|
const entriesArray = asArray(entries);
|
|
64
72
|
entriesArray.forEach((entry) => {
|
|
65
|
-
if (override || !this._entries.has(entry.
|
|
66
|
-
this._entries.set(entry.
|
|
73
|
+
if (override || !this._entries.has(entry.helpContextKey)) {
|
|
74
|
+
this._entries.set(entry.helpContextKey, entry);
|
|
67
75
|
}
|
|
68
76
|
});
|
|
69
77
|
return true;
|
|
70
78
|
}
|
|
71
79
|
// MARK: Get
|
|
72
|
-
|
|
80
|
+
getAllRegisteredHelpContextKeys() {
|
|
73
81
|
return Array.from(this._entries.keys());
|
|
74
82
|
}
|
|
75
|
-
getHelpWidgetEntry(
|
|
76
|
-
return this._entries.get(
|
|
83
|
+
getHelpWidgetEntry(helpContextKey) {
|
|
84
|
+
return this._entries.get(helpContextKey) ?? (this._defaultWidgetComponentClass ? { helpContextKey, title: '<Missing Help Topic>', widgetComponentClass: this._defaultWidgetComponentClass } : undefined);
|
|
77
85
|
}
|
|
78
|
-
|
|
79
|
-
return
|
|
86
|
+
getHelpWidgetEntriesForHelpContextKeys(helpContextKeys) {
|
|
87
|
+
return helpContextKeys.map((context) => this.getHelpWidgetEntry(context)).filter((entry) => !!entry);
|
|
80
88
|
}
|
|
81
89
|
hasHelpWidgetEntry(context) {
|
|
82
90
|
return this._entries.has(context);
|
|
@@ -95,4 +103,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
95
103
|
type: Inject,
|
|
96
104
|
args: [DbxHelpWidgetServiceConfig]
|
|
97
105
|
}] }] });
|
|
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"]}
|
|
106
|
+
//# 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 { DbxHelpContextKey } 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 header component class to use for the list view.\n   */\n  abstract readonly helpListHeaderComponentConfig?: Maybe<DbxInjectionComponentConfig>;\n  /**\n   * Optional footer component class to use for the list view.\n   */\n  abstract readonly helpListFooterComponentConfig?: Maybe<DbxInjectionComponentConfig>;\n  /**\n   * Optional header component class to use for the popover 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<DbxHelpContextKey, DbxHelpWidgetServiceEntry>();\n\n  private readonly _sortPriorityMap = cachedGetter(() => {\n    return new Map<DbxHelpContextKey, number>(mapIterable(this._entries.values(), (entry) => [entry.helpContextKey, entry.sortPriority ?? -1]));\n  });\n\n  private _defaultWidgetComponentClass: Maybe<Type<unknown>>;\n  private _helpListHeaderComponentConfig: Maybe<DbxInjectionComponentConfig>;\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);\n    this.setPopoverHeaderComponentConfig(initialConfig?.popoverHeaderComponentConfig);\n    this.setHelpListHeaderComponentConfig(initialConfig?.helpListHeaderComponentConfig);\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  getHelpListHeaderComponentConfig(): Maybe<DbxInjectionComponentConfig> {\n    return this._helpListHeaderComponentConfig;\n  }\n\n  setHelpListHeaderComponentConfig(componentConfig: Maybe<DbxInjectionComponentConfig>): void {\n    this._helpListHeaderComponentConfig = 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.helpContextKey)) {\n        this._entries.set(entry.helpContextKey, entry);\n      }\n    });\n\n    return true;\n  }\n\n  // MARK: Get\n  getAllRegisteredHelpContextKeys(): DbxHelpContextKey[] {\n    return Array.from(this._entries.keys());\n  }\n\n  getHelpWidgetEntry(helpContextKey: DbxHelpContextKey): Maybe<DbxHelpWidgetServiceEntry> {\n    return this._entries.get(helpContextKey) ?? (this._defaultWidgetComponentClass ? { helpContextKey, title: '<Missing Help Topic>', widgetComponentClass: this._defaultWidgetComponentClass } : undefined);\n  }\n\n  getHelpWidgetEntriesForHelpContextKeys(helpContextKeys: DbxHelpContextKey[]): DbxHelpWidgetServiceEntry[] {\n    return helpContextKeys.map((context) => this.getHelpWidgetEntry(context)).filter((entry) => !!entry) as DbxHelpWidgetServiceEntry[];\n  }\n\n  hasHelpWidgetEntry(context: DbxHelpContextKey): boolean {\n    return this._entries.has(context);\n  }\n\n  getSortPriorityMap() {\n    return this._sortPriorityMap();\n  }\n}\n"]}
|