@wavemaker/app-ng-runtime 11.14.1-1.6289 → 11.14.1-10.6348
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/components/base/bundles/index.umd.js +86 -17
- package/components/base/esm2022/pipes/custom-pipes.mjs +10 -10
- package/components/base/esm2022/utils/widget-utils.mjs +3 -3
- package/components/base/esm2022/widgets/common/base/base.component.mjs +67 -7
- package/components/base/esm2022/widgets/common/lazy-load/lazy-load.directive.mjs +7 -3
- package/components/base/esm2022/widgets/framework/property-change-handler.mjs +7 -2
- package/components/base/fesm2022/index.mjs +87 -18
- package/components/base/fesm2022/index.mjs.map +1 -1
- package/components/base/pipes/custom-pipes.d.ts +5 -5
- package/components/basic/label/bundles/index.umd.js +9 -1
- package/components/basic/label/esm2022/label.directive.mjs +10 -2
- package/components/basic/label/fesm2022/index.mjs +9 -1
- package/components/basic/label/fesm2022/index.mjs.map +1 -1
- package/components/data/pagination/bundles/index.umd.js +4 -0
- package/components/data/pagination/esm2022/pagination.component.mjs +5 -1
- package/components/data/pagination/fesm2022/index.mjs +4 -0
- package/components/data/pagination/fesm2022/index.mjs.map +1 -1
- package/components/data/table/bundles/index.umd.js +371 -15
- package/components/data/table/esm2022/table-action/table-action.directive.mjs +8 -1
- package/components/data/table/esm2022/table-column/table-column.directive.mjs +107 -3
- package/components/data/table/esm2022/table-column-group/table-column-group.directive.mjs +9 -1
- package/components/data/table/esm2022/table-cud.directive.mjs +8 -2
- package/components/data/table/esm2022/table-filter.directive.mjs +12 -2
- package/components/data/table/esm2022/table-row/table-row.directive.mjs +8 -1
- package/components/data/table/esm2022/table-row-action/table-row-action.directive.mjs +8 -1
- package/components/data/table/esm2022/table.component.mjs +219 -12
- package/components/data/table/fesm2022/index.mjs +371 -15
- package/components/data/table/fesm2022/index.mjs.map +1 -1
- package/components/data/table/table-action/table-action.directive.d.ts +3 -2
- package/components/data/table/table-column/table-column.directive.d.ts +3 -2
- package/components/data/table/table-column-group/table-column-group.directive.d.ts +3 -2
- package/components/data/table/table-cud.directive.d.ts +3 -1
- package/components/data/table/table-filter.directive.d.ts +3 -1
- package/components/data/table/table-row/table-row.directive.d.ts +3 -2
- package/components/data/table/table-row-action/table-row-action.directive.d.ts +3 -2
- package/components/data/table/table.component.d.ts +6 -2
- package/components/navigation/menu/bundles/index.umd.js +5 -0
- package/components/navigation/menu/esm2022/menu.component.mjs +6 -1
- package/components/navigation/menu/fesm2022/index.mjs +5 -0
- package/components/navigation/menu/fesm2022/index.mjs.map +1 -1
- package/components/navigation/popover/bundles/index.umd.js +6 -6
- package/components/navigation/popover/esm2022/popover.component.mjs +4 -4
- package/components/navigation/popover/fesm2022/index.mjs +3 -3
- package/components/navigation/popover/fesm2022/index.mjs.map +1 -1
- package/components/navigation/popover/popover.component.d.ts +6 -0
- package/core/bundles/index.umd.js +411 -82
- package/core/esm2022/public_api.mjs +3 -3
- package/core/esm2022/utils/utils.mjs +6 -2
- package/core/esm2022/utils/watcher.mjs +402 -81
- package/core/fesm2022/index.mjs +410 -84
- package/core/fesm2022/index.mjs.map +1 -1
- package/core/public_api.d.ts +2 -2
- package/core/utils/utils.d.ts +1 -0
- package/core/utils/watcher.d.ts +28 -5
- package/npm-shrinkwrap.json +2 -2
- package/package-lock.json +2 -2
- package/package.json +1 -1
- package/runtime/base/bundles/index.umd.js +22 -2
- package/runtime/base/esm2022/components/app-component/app.component.mjs +4 -2
- package/runtime/base/esm2022/components/base-page.component.mjs +6 -2
- package/runtime/base/esm2022/components/base-partial.component.mjs +7 -2
- package/runtime/base/esm2022/components/base-prefab.component.mjs +7 -2
- package/runtime/base/esm2022/components/base-spa-page.component.mjs +6 -2
- package/runtime/base/esm2022/services/pipe-provider.service.mjs +4 -4
- package/runtime/base/fesm2022/index.mjs +23 -3
- package/runtime/base/fesm2022/index.mjs.map +1 -1
- package/scripts/datatable/datatable.js +101 -15
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import { Injector, OnInit } from '@angular/core';
|
|
1
|
+
import { Injector, OnDestroy, OnInit } from '@angular/core';
|
|
2
2
|
import { BaseComponent } from '@wm/components/base';
|
|
3
3
|
import { TableComponent } from '../table.component';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
|
-
export declare class TableActionDirective extends BaseComponent implements OnInit {
|
|
5
|
+
export declare class TableActionDirective extends BaseComponent implements OnInit, OnDestroy {
|
|
6
6
|
table: TableComponent;
|
|
7
7
|
static initializeProps: void;
|
|
8
8
|
accessroles: any;
|
|
@@ -29,6 +29,7 @@ export declare class TableActionDirective extends BaseComponent implements OnIni
|
|
|
29
29
|
populateAction(): void;
|
|
30
30
|
ngOnInit(): void;
|
|
31
31
|
onPropertyChange(key: any, nv: any): void;
|
|
32
|
+
ngOnDestroy(): void;
|
|
32
33
|
static ɵfac: i0.ɵɵFactoryDeclaration<TableActionDirective, [null, { optional: true; }, { optional: true; }]>;
|
|
33
34
|
static ɵdir: i0.ɵɵDirectiveDeclaration<TableActionDirective, "[wmTableAction]", never, {}, {}, never, never, true, never>;
|
|
34
35
|
}
|
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
import { AfterContentInit, AfterViewInit, Injector, OnInit, TemplateRef } from '@angular/core';
|
|
1
|
+
import { AfterContentInit, AfterViewInit, Injector, OnDestroy, OnInit, TemplateRef } from '@angular/core';
|
|
2
2
|
import { AppDefaults } from '@wm/core';
|
|
3
3
|
import { BaseComponent } from '@wm/components/base';
|
|
4
4
|
import { TableComponent } from '../table.component';
|
|
5
5
|
import { TableColumnGroupDirective } from '../table-column-group/table-column-group.directive';
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
7
|
-
export declare class TableColumnDirective extends BaseComponent implements OnInit, AfterContentInit, AfterViewInit {
|
|
7
|
+
export declare class TableColumnDirective extends BaseComponent implements OnInit, AfterContentInit, AfterViewInit, OnDestroy {
|
|
8
8
|
private appDefaults;
|
|
9
9
|
table: TableComponent;
|
|
10
10
|
group: TableColumnGroupDirective;
|
|
@@ -146,6 +146,7 @@ export declare class TableColumnDirective extends BaseComponent implements OnIni
|
|
|
146
146
|
populateFieldDef(): void;
|
|
147
147
|
onPropertyChange(key: any, nv: any, ov: any): void;
|
|
148
148
|
setProperty(property: any, nv: any): void;
|
|
149
|
+
ngOnDestroy(): void;
|
|
149
150
|
static ɵfac: i0.ɵɵFactoryDeclaration<TableColumnDirective, [null, null, { optional: true; }, { optional: true; }, { attribute: "filterdataset.bind"; }, { attribute: "dataset.bind"; }, { optional: true; }]>;
|
|
150
151
|
static ɵdir: i0.ɵɵDirectiveDeclaration<TableColumnDirective, "[wmTableColumn]", never, {}, {}, ["customExprTmpl", "inlineWidthTempRef", "filterTemplateRef", "_filterInstances", "_inlineInstances", "_inlineInstancesNew"], never, true, never>;
|
|
151
152
|
}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import { Injector, OnInit } from '@angular/core';
|
|
1
|
+
import { Injector, OnDestroy, OnInit } from '@angular/core';
|
|
2
2
|
import { BaseComponent } from '@wm/components/base';
|
|
3
3
|
import { TableComponent } from '../table.component';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
|
-
export declare class TableColumnGroupDirective extends BaseComponent implements OnInit {
|
|
5
|
+
export declare class TableColumnGroupDirective extends BaseComponent implements OnInit, OnDestroy {
|
|
6
6
|
group: TableColumnGroupDirective;
|
|
7
7
|
table: TableComponent;
|
|
8
8
|
static initializeProps: void;
|
|
@@ -17,6 +17,7 @@ export declare class TableColumnGroupDirective extends BaseComponent implements
|
|
|
17
17
|
populateConfig(): void;
|
|
18
18
|
onPropertyChange(key: any, nv: any, ov?: any): void;
|
|
19
19
|
ngOnInit(): void;
|
|
20
|
+
ngOnDestroy(): void;
|
|
20
21
|
static ɵfac: i0.ɵɵFactoryDeclaration<TableColumnGroupDirective, [null, { optional: true; skipSelf: true; }, { optional: true; }, { optional: true; }]>;
|
|
21
22
|
static ɵdir: i0.ɵɵDirectiveDeclaration<TableColumnGroupDirective, "[wmTableColumnGroup]", never, {}, {}, never, never, true, never>;
|
|
22
23
|
}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
|
+
import { OnDestroy } from '@angular/core';
|
|
1
2
|
import { AbstractDialogService, App } from '@wm/core';
|
|
2
3
|
import * as i0 from "@angular/core";
|
|
3
|
-
export declare class TableCUDDirective {
|
|
4
|
+
export declare class TableCUDDirective implements OnDestroy {
|
|
4
5
|
private table;
|
|
5
6
|
private dialogService;
|
|
6
7
|
private app;
|
|
@@ -27,6 +28,7 @@ export declare class TableCUDDirective {
|
|
|
27
28
|
hideEditRow(): void;
|
|
28
29
|
saveRow(): void;
|
|
29
30
|
cancelRow(): void;
|
|
31
|
+
ngOnDestroy(): void;
|
|
30
32
|
static ɵfac: i0.ɵɵFactoryDeclaration<TableCUDDirective, [{ self: true; }, null, null]>;
|
|
31
33
|
static ɵdir: i0.ɵɵDirectiveDeclaration<TableCUDDirective, "[wmTableCUD]", never, {}, {}, never, never, true, never>;
|
|
32
34
|
}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
|
+
import { OnDestroy } from '@angular/core';
|
|
1
2
|
import * as i0 from "@angular/core";
|
|
2
|
-
export declare class TableFilterSortDirective {
|
|
3
|
+
export declare class TableFilterSortDirective implements OnDestroy {
|
|
3
4
|
private table;
|
|
4
5
|
constructor(table: any);
|
|
5
6
|
adjustContainer(fieldName: any): void;
|
|
@@ -28,6 +29,7 @@ export declare class TableFilterSortDirective {
|
|
|
28
29
|
private getFilterOnFieldValues;
|
|
29
30
|
onRowFilterChange(fieldName: any): void;
|
|
30
31
|
refreshData(isSamePage: any): void;
|
|
32
|
+
ngOnDestroy(): void;
|
|
31
33
|
static ɵfac: i0.ɵɵFactoryDeclaration<TableFilterSortDirective, [{ self: true; }]>;
|
|
32
34
|
static ɵdir: i0.ɵɵDirectiveDeclaration<TableFilterSortDirective, "[wmTableFilterSort]", never, {}, {}, never, never, true, never>;
|
|
33
35
|
}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import { Injector, OnInit } from '@angular/core';
|
|
1
|
+
import { Injector, OnDestroy, OnInit } from '@angular/core';
|
|
2
2
|
import { BaseComponent } from '@wm/components/base';
|
|
3
3
|
import { TableComponent } from '../table.component';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
|
-
export declare class TableRowDirective extends BaseComponent implements OnInit {
|
|
5
|
+
export declare class TableRowDirective extends BaseComponent implements OnInit, OnDestroy {
|
|
6
6
|
table: TableComponent;
|
|
7
7
|
static initializeProps: void;
|
|
8
8
|
config: any;
|
|
@@ -19,6 +19,7 @@ export declare class TableRowDirective extends BaseComponent implements OnInit {
|
|
|
19
19
|
populateConfig(): void;
|
|
20
20
|
ngOnInit(): void;
|
|
21
21
|
onPropertyChange(key: string, nv: any): void;
|
|
22
|
+
ngOnDestroy(): void;
|
|
22
23
|
static ɵfac: i0.ɵɵFactoryDeclaration<TableRowDirective, [null, { optional: true; skipSelf: true; }, { optional: true; }]>;
|
|
23
24
|
static ɵdir: i0.ɵɵDirectiveDeclaration<TableRowDirective, "[wmTableRow]", never, {}, {}, never, never, true, never>;
|
|
24
25
|
}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import { Injector, OnInit } from '@angular/core';
|
|
1
|
+
import { Injector, OnDestroy, OnInit } from '@angular/core';
|
|
2
2
|
import { BaseComponent } from '@wm/components/base';
|
|
3
3
|
import { TableComponent } from '../table.component';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
|
-
export declare class TableRowActionDirective extends BaseComponent implements OnInit {
|
|
5
|
+
export declare class TableRowActionDirective extends BaseComponent implements OnInit, OnDestroy {
|
|
6
6
|
table: TableComponent;
|
|
7
7
|
static initializeProps: void;
|
|
8
8
|
accessroles: any;
|
|
@@ -25,6 +25,7 @@ export declare class TableRowActionDirective extends BaseComponent implements On
|
|
|
25
25
|
getTitle(): any;
|
|
26
26
|
populateAction(): void;
|
|
27
27
|
ngOnInit(): void;
|
|
28
|
+
ngOnDestroy(): void;
|
|
28
29
|
static ɵfac: i0.ɵɵFactoryDeclaration<TableRowActionDirective, [null, { optional: true; }, { self: true; }, { optional: true; }]>;
|
|
29
30
|
static ɵdir: i0.ɵɵDirectiveDeclaration<TableRowActionDirective, "[wmTableRowAction]", never, {}, {}, never, never, true, never>;
|
|
30
31
|
}
|
|
@@ -109,7 +109,7 @@ export declare class TableComponent extends StylableComponent implements AfterCo
|
|
|
109
109
|
exportOptions: any[];
|
|
110
110
|
exportdatasize: any;
|
|
111
111
|
formWidgets: any;
|
|
112
|
-
headerConfig: any
|
|
112
|
+
headerConfig: any;
|
|
113
113
|
items: any[];
|
|
114
114
|
navControls: any;
|
|
115
115
|
rowActions: any[];
|
|
@@ -128,10 +128,11 @@ export declare class TableComponent extends StylableComponent implements AfterCo
|
|
|
128
128
|
actionRowIndex: any;
|
|
129
129
|
actionRowPage: any;
|
|
130
130
|
prevFilterExpression: any;
|
|
131
|
-
fieldDefs: any
|
|
131
|
+
fieldDefs: any;
|
|
132
132
|
rowDef: any;
|
|
133
133
|
rowInstance: any;
|
|
134
134
|
pagesizeoptions: any;
|
|
135
|
+
prevPagesizeoptions: any;
|
|
135
136
|
multiselecttitle: any;
|
|
136
137
|
multiselectarialabel: any;
|
|
137
138
|
radioselecttitle: any;
|
|
@@ -378,6 +379,9 @@ export declare class TableComponent extends StylableComponent implements AfterCo
|
|
|
378
379
|
getSortExpr(): any;
|
|
379
380
|
onPropertyChange(key: string, nv: any, ov?: any): void;
|
|
380
381
|
setDefaultPageSize(nv: any): void;
|
|
382
|
+
isPageSizeOptionsChanged(): boolean;
|
|
383
|
+
selectPageSize(pagesize: number): void;
|
|
384
|
+
sanitizeCommaSeparatedIntegers(input: string): string;
|
|
381
385
|
onDataSourceChange(): void;
|
|
382
386
|
private clearActionRowVars;
|
|
383
387
|
onStyleChange(key: any, nv: any, ov: any): void;
|
|
@@ -768,6 +768,11 @@
|
|
|
768
768
|
}
|
|
769
769
|
ngAfterViewInit() {
|
|
770
770
|
super.ngAfterViewInit();
|
|
771
|
+
// Fix tabindex if it's NaN (ensure it's fixed after view initialization)
|
|
772
|
+
if (this.widget.tabindex !== undefined && (typeof this.widget.tabindex === 'number' && isNaN(this.widget.tabindex))) {
|
|
773
|
+
this.widget.tabindex = 0;
|
|
774
|
+
this.tabindex = 0;
|
|
775
|
+
}
|
|
771
776
|
base.styler(this.nativeElement.querySelector('.dropdown-toggle'), this);
|
|
772
777
|
}
|
|
773
778
|
static { this.ɵfac = i0__namespace.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0__namespace, type: MenuComponent, deps: [{ token: i0__namespace.Injector }, { token: i1__namespace.Router }, { token: i2__namespace.UserDefinedExecutionContext }, { token: i2__namespace.App }, { token: i3$1__namespace.BsDropdownDirective, optional: true, self: true }, { token: NavComponent, optional: true }, { token: 'select.event', attribute: true }, { token: 'EXPLICIT_CONTEXT', optional: true }], target: i0__namespace.ɵɵFactoryTarget.Component }); }
|
|
@@ -218,6 +218,11 @@ export class MenuComponent extends DatasetAwareNavComponent {
|
|
|
218
218
|
}
|
|
219
219
|
ngAfterViewInit() {
|
|
220
220
|
super.ngAfterViewInit();
|
|
221
|
+
// Fix tabindex if it's NaN (ensure it's fixed after view initialization)
|
|
222
|
+
if (this.widget.tabindex !== undefined && (typeof this.widget.tabindex === 'number' && isNaN(this.widget.tabindex))) {
|
|
223
|
+
this.widget.tabindex = 0;
|
|
224
|
+
this.tabindex = 0;
|
|
225
|
+
}
|
|
221
226
|
styler(this.nativeElement.querySelector('.dropdown-toggle'), this);
|
|
222
227
|
}
|
|
223
228
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MenuComponent, deps: [{ token: i0.Injector }, { token: i1.Router }, { token: i2.UserDefinedExecutionContext }, { token: i2.App }, { token: i3.BsDropdownDirective, optional: true, self: true }, { token: i4.NavComponent, optional: true }, { token: 'select.event', attribute: true }, { token: 'EXPLICIT_CONTEXT', optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
@@ -272,4 +277,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
272
277
|
type: HostListener,
|
|
273
278
|
args: ['keydown.enter', ['$event', '"ENTER"']]
|
|
274
279
|
}] } });
|
|
275
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"menu.component.js","sourceRoot":"","sources":["../../../../../projects/components/widgets/navigation/menu/src/menu.component.ts","../../../../../projects/components/widgets/navigation/menu/src/menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { ButtonComponent } from '@wm/components/input/button';\nimport { MenuDropdownComponent } from './menu-dropdown/menu-dropdown.component';\nimport {\n    AfterViewInit,\n    Attribute,\n    Component,\n    HostListener,\n    Inject,\n    Injector,\n    OnDestroy,\n    OnInit,\n    Optional,\n    Self\n} from '@angular/core';\nimport {Router} from '@angular/router';\n\nimport {BsDropdownDirective, BsDropdownModule} from 'ngx-bootstrap/dropdown';\n\nimport {\n    $appDigest,\n    addClass,\n    App,\n    removeClass,\n    toggleClass,\n    triggerItemAction,\n    UserDefinedExecutionContext\n} from '@wm/core';\nimport {\n    AUTOCLOSE_TYPE,\n    DatasetAwareNavComponent,\n    hasLinkToCurrentPage,\n    provideAsWidgetRef,\n    styler,\n    TextContentDirective\n} from '@wm/components/base';\nimport {NavComponent} from './nav/nav.component';\n\nimport {registerProps} from './menu.props';\nimport {clone, forEach, includes, isEmpty} from \"lodash-es\";\nimport { AnchorComponent } from '@wm/components/basic/anchor';\n\nexport const KEYBOARD_MOVEMENTS = {\n    MOVE_UP: 'UP-ARROW',\n    MOVE_LEFT: 'LEFT-ARROW',\n    MOVE_RIGHT: 'RIGHT-ARROW',\n    MOVE_DOWN: 'DOWN-ARROW',\n    ON_ENTER: 'ENTER',\n    ON_MOUSE_ENTER: 'MOUSE-ENTER',\n    ON_MOUSE_LEAVE: 'MOUSE-LEAVE',\n    ON_TAB: 'TAB',\n    ON_SHIFT_TAB: 'SHIFT-TAB',\n    ON_ESCAPE: 'ESC'\n};\n\nexport const MENU_POSITION = {\n    UP_LEFT: 'up,left',\n    UP_RIGHT: 'up,right',\n    DOWN_LEFT: 'down,left',\n    DOWN_RIGHT: 'down,right',\n    INLINE: 'inline'\n};\n\nconst POSITION = {\n    DOWN_RIGHT: 'down,right',\n    DOWN_LEFT: 'down,left',\n    UP_RIGHT: 'up,right',\n    UP_LEFT: 'up,left',\n    INLINE: 'inline'\n};\nconst CARET_CLS = {\n    UP: 'fa-caret-up',\n    DOWN: 'fa-caret-down'\n};\nconst PULL_CLS = {\n    LEFT: 'pull-left',\n    RIGHT: 'pull-right'\n};\n\nconst AUTO_OPEN = {\n    NEVER: 'never',\n    ACTIVE_PAGE: 'activepage',\n    ALWAYS: 'always'\n};\n\nconst WIDGET_CONFIG = { widgetType: 'wm-menu', hostClass: 'dropdown app-menu' };\n@Component({\n    standalone: true,\n    imports: [BsDropdownModule, CommonModule, TextContentDirective, AnchorComponent, ButtonComponent, MenuDropdownComponent],\n    selector: '[wmMenu]',\n    templateUrl: './menu.component.html',\n    providers: [\n        provideAsWidgetRef(MenuComponent),\n\n    ]\n})\nexport class MenuComponent extends DatasetAwareNavComponent implements OnInit, OnDestroy, AfterViewInit {\n    static initializeProps = registerProps();\n\n    public menualign: string;\n    public menuposition: string;\n    public menulayout: string;\n    public menuclass: string;\n    public linktarget: string;\n    public iconclass: string;\n    public animateitems: string;\n    public disableMenuContext: boolean;\n    public showonhover: boolean;\n    public autoclose: string;\n    public autoopen: string;\n    public hint: string;\n    public arialabel: string;\n\n    private itemActionFn: Function;\n    private menuCaret = 'fa-caret-down';\n    private _selectFirstItem = false;\n\n    public type: any;\n    public _menuposition: string;\n\n    @HostListener('onShown') onShow() {\n        this._menuposition = this.menuposition;\n        if (this._selectFirstItem) {\n            setTimeout(() => {\n                this.$element.find('> ul[wmmenudropdown] li.app-menu-item').first().find('> a').focus();\n            });\n        }\n        $appDigest();\n    }\n    @HostListener('onHidden') onHide() {\n        this.$element.find('li').removeClass('open');\n        this._selectFirstItem = false;\n        // reset the menuposition when dropdown is closed\n        this.menuposition = this._menuposition ? this._menuposition : MENU_POSITION.DOWN_RIGHT;\n        this.setMenuPosition();\n        $appDigest();\n    }\n\n    @HostListener('keydown.arrowup', ['$event', '\"UP-ARROW\"'])\n    @HostListener('mouseenter', ['$event', '\"MOUSE-ENTER\"'])\n    @HostListener('mouseleave', ['$event', '\"MOUSE-LEAVE\"'])\n    @HostListener('keydown.arrowdown', ['$event', '\"DOWN-ARROW\"'])\n    @HostListener('keydown.arrowright', ['$event', '\"RIGHT-ARROW\"'])\n    @HostListener('keydown.arrowleft', ['$event', '\"LEFT-ARROW\"'])\n    @HostListener('keydown.enter', ['$event', '\"ENTER\"']) onKeyDown($event, eventAction) {\n        const KEY_MOVEMENTS = clone(KEYBOARD_MOVEMENTS);\n        if (this.menuposition === MENU_POSITION.UP_RIGHT) {\n            KEY_MOVEMENTS.MOVE_UP = 'DOWN-ARROW';\n            KEY_MOVEMENTS.MOVE_DOWN = 'UP-ARROW';\n        } else if (this.menuposition === MENU_POSITION.UP_LEFT) {\n            KEY_MOVEMENTS.MOVE_UP = 'DOWN-ARROW';\n            KEY_MOVEMENTS.MOVE_DOWN = 'UP-ARROW';\n            KEY_MOVEMENTS.MOVE_LEFT = 'RIGHT-ARROW';\n            KEY_MOVEMENTS.MOVE_RIGHT = 'LEFT-ARROW';\n        } else if (this.menuposition === MENU_POSITION.DOWN_LEFT) {\n            KEY_MOVEMENTS.MOVE_LEFT = 'RIGHT-ARROW';\n            KEY_MOVEMENTS.MOVE_RIGHT = 'LEFT-ARROW';\n        }\n\n        if (includes([KEY_MOVEMENTS.MOVE_DOWN, KEY_MOVEMENTS.MOVE_RIGHT], eventAction)) {\n            if (!this.bsDropdown.isOpen) {\n                this._selectFirstItem = true;\n                this.bsDropdown.show();\n            } else {\n                this.$element.find('> ul[wmmenudropdown] li.app-menu-item').first().find('> a').focus();\n            }\n        } else if (eventAction === KEY_MOVEMENTS.ON_ENTER || (eventAction === KEY_MOVEMENTS.ON_MOUSE_ENTER && this.showonhover)) {\n            this.bsDropdown.toggle(true);\n        } else if (includes([KEY_MOVEMENTS.MOVE_UP, KEY_MOVEMENTS.MOVE_LEFT], eventAction) || (eventAction == KEY_MOVEMENTS.ON_MOUSE_LEAVE && this.autoclose == AUTOCLOSE_TYPE.ALWAYS && this.showonhover)) {\n            this.bsDropdown.hide();\n        }\n        $event.preventDefault();\n    }\n\n    constructor(\n        inj: Injector,\n        public route: Router,\n        private userDefinedExecutionContext: UserDefinedExecutionContext,\n        private app: App,\n        @Self() @Optional() public bsDropdown: BsDropdownDirective,\n        @Optional() private parentNav: NavComponent,\n        @Attribute('select.event') public selectEventCB: string,\n        @Inject('EXPLICIT_CONTEXT') @Optional() explicitContext: any\n    ) {\n        super(inj, WIDGET_CONFIG, explicitContext);\n        if (parentNav) {\n            this.disableMenuContext = !!parentNav.disableMenuContext;\n        } else {\n            this.disableMenuContext = !!selectEventCB;\n        }\n        // For selecting the item on load\n        const datasetSubscription = this.nodes$.subscribe(() => {\n            if (!isEmpty(this.nodes)) {\n                if (hasLinkToCurrentPage(this.nodes, this.route.url)) {\n                    addClass(this.nativeElement.querySelector('.dropdown-toggle') as HTMLElement, 'active');\n                }\n                // If menu widget is inside nav widget then dont check for item isactive property because these will be handled form nav widget.\n                if (this.parentNav) {\n                    return;\n                }\n                let itemFound = false;\n                const getItem = (nodes) => {\n                    forEach(nodes, (item) => {\n                        if (itemFound) {\n                            return;\n                        }\n                        if (item.isactive) {\n                            itemFound = true;\n                            this.onMenuItemSelect({ $event: {}, $item: item });\n                            // Trigger the action associated with active item\n                            triggerItemAction(this, item);\n                            return false;\n                        }\n                        if (!isEmpty(item.children)) {\n                            getItem(item.children);\n                        }\n\n                    });\n                };\n                getItem(this.nodes);\n            }\n        });\n        this.registerDestroyListener(() => datasetSubscription.unsubscribe());\n\n    }\n\n    protected resetNodes() {\n        super.resetNodes();\n        // open the menu if any of its menu items has link to current page and if autoopen value is 'active page'\n        if ((this.autoopen === AUTO_OPEN.ACTIVE_PAGE && hasLinkToCurrentPage(this.nodes, this.route.url)) || this.autoopen === AUTO_OPEN.ALWAYS) {\n            this.bsDropdown.show();\n        }\n    }\n\n    ngOnInit() {\n        super.ngOnInit();\n        this.setMenuPosition();\n\n        const cancelSubscription = this.app.subscribe(\"highlightActiveLink\", (data) => {\n            toggleClass(this.nativeElement.querySelector('.dropdown-toggle') as HTMLElement, 'active', hasLinkToCurrentPage(this.nodes, this.route.url ));\n        });\n        this.registerDestroyListener(() => cancelSubscription());\n    }\n\n    onPropertyChange(key: string, nv: any, ov?: any) {\n\n        if (key === 'tabindex') {\n            return;\n        }\n\n        if (key === 'autoclose') {\n            this.bsDropdown.autoClose = nv !== AUTOCLOSE_TYPE.DISABLED;\n            this.autoclose = nv;\n        } else {\n            super.onPropertyChange(key, nv, ov);\n        }\n    }\n\n    public setMenuPosition() {\n        switch (this.menuposition) {\n            case POSITION.DOWN_RIGHT:\n                removeClass(this.nativeElement, 'dropup');\n                this.menualign = PULL_CLS.LEFT;\n                this.menuCaret = CARET_CLS.DOWN;\n                break;\n            case POSITION.DOWN_LEFT:\n                removeClass(this.nativeElement, 'dropup');\n                this.menualign = PULL_CLS.RIGHT;\n                this.menuCaret = CARET_CLS.DOWN;\n                break;\n            case POSITION.UP_LEFT:\n                addClass(this.nativeElement, 'dropup');\n                this.menualign = PULL_CLS.RIGHT;\n                this.menuCaret = CARET_CLS.UP;\n                break;\n            case POSITION.UP_RIGHT:\n                addClass(this.nativeElement, 'dropup');\n                this.menualign = PULL_CLS.LEFT;\n                this.menuCaret = CARET_CLS.UP;\n                break;\n            case POSITION.INLINE:\n                this.menualign = 'dropinline-menu';\n                break;\n        }\n    }\n\n    public onMenuItemSelect(args) {\n        const { $event } = args;\n        const $item = args.$item.value;\n        this.invokeEventCallback('select', { $event, $item });\n    }\n\n    ngAfterViewInit() {\n        super.ngAfterViewInit();\n        styler(this.nativeElement.querySelector('.dropdown-toggle') as HTMLElement, this);\n    }\n}\n","\n\n<ng-template #innerTemplate>\n  <i class=\"app-icon {{iconclass}}\"></i>\n  <span class=\"caption\" [textContent]=\"caption\"></span>\n  <span class=\"pull-right caret fa {{menuCaret}}\"></span>\n</ng-template>\n\n@if (type === 'anchor') {\n  <a wmAnchor\n    dropdownToggle\n    [attr.aria-label]=\"arialabel || 'Menu'\"\n    href=\"javascript:void(0);\"\n    role=\"button\"\n    aria-haspopup=\"true\"\n    aria-expanded=\"false\"\n    hint.bind=\"hint\"\n    class=\"dropdown-toggle {{menuclass}}\"\n    shortcutkey.bind=\"shortcutkey\"\n    tabindex.bind=\"tabindex\"\n    caption.bind=\"caption\"\n    iconclass.bind=\"iconclass\"\n    iconposition.bind=\"iconposition\"\n    badgevalue.bind=\"badgevalue\"\n    >\n    <span class=\"pull-right caret fa\" [ngClass]=\"[menuCaret]\"></span>\n  </a>\n} @else {\n  <button wmButton\n    dropdownToggle\n    aria-haspopup=\"true\"\n    aria-expanded=\"false\"\n    [attr.aria-label]=\"arialabel || 'Menu'\"\n    class=\"btn app-button dropdown-toggle {{menuclass}}\"\n    hint.bind=\"hint\"\n    shortcutkey.bind=\"shortcutkey\"\n    tabindex.bind=\"tabindex\"\n    caption.bind=\"caption\"\n    iconclass.bind=\"iconclass\"\n    iconposition.bind=\"iconposition\">\n    <span class=\"pull-right caret fa\" [ngClass]=\"[menuCaret]\"></span>\n  </button>\n}\n\n<ul *dropdownMenu [items]=\"nodes\" [ngClass]=\"menulayout\" class=\"icon-position-{{iconposition}}\" role=\"menubar\"\nwmMenuDropdown></ul>\n"]}
|
|
280
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"menu.component.js","sourceRoot":"","sources":["../../../../../projects/components/widgets/navigation/menu/src/menu.component.ts","../../../../../projects/components/widgets/navigation/menu/src/menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { ButtonComponent } from '@wm/components/input/button';\nimport { MenuDropdownComponent } from './menu-dropdown/menu-dropdown.component';\nimport {\n    AfterViewInit,\n    Attribute,\n    Component,\n    HostListener,\n    Inject,\n    Injector,\n    OnDestroy,\n    OnInit,\n    Optional,\n    Self\n} from '@angular/core';\nimport {Router} from '@angular/router';\n\nimport {BsDropdownDirective, BsDropdownModule} from 'ngx-bootstrap/dropdown';\n\nimport {\n    $appDigest,\n    addClass,\n    App,\n    removeClass,\n    toggleClass,\n    triggerItemAction,\n    UserDefinedExecutionContext\n} from '@wm/core';\nimport {\n    AUTOCLOSE_TYPE,\n    DatasetAwareNavComponent,\n    hasLinkToCurrentPage,\n    provideAsWidgetRef,\n    styler,\n    TextContentDirective\n} from '@wm/components/base';\nimport {NavComponent} from './nav/nav.component';\n\nimport {registerProps} from './menu.props';\nimport {clone, forEach, includes, isEmpty} from \"lodash-es\";\nimport { AnchorComponent } from '@wm/components/basic/anchor';\n\nexport const KEYBOARD_MOVEMENTS = {\n    MOVE_UP: 'UP-ARROW',\n    MOVE_LEFT: 'LEFT-ARROW',\n    MOVE_RIGHT: 'RIGHT-ARROW',\n    MOVE_DOWN: 'DOWN-ARROW',\n    ON_ENTER: 'ENTER',\n    ON_MOUSE_ENTER: 'MOUSE-ENTER',\n    ON_MOUSE_LEAVE: 'MOUSE-LEAVE',\n    ON_TAB: 'TAB',\n    ON_SHIFT_TAB: 'SHIFT-TAB',\n    ON_ESCAPE: 'ESC'\n};\n\nexport const MENU_POSITION = {\n    UP_LEFT: 'up,left',\n    UP_RIGHT: 'up,right',\n    DOWN_LEFT: 'down,left',\n    DOWN_RIGHT: 'down,right',\n    INLINE: 'inline'\n};\n\nconst POSITION = {\n    DOWN_RIGHT: 'down,right',\n    DOWN_LEFT: 'down,left',\n    UP_RIGHT: 'up,right',\n    UP_LEFT: 'up,left',\n    INLINE: 'inline'\n};\nconst CARET_CLS = {\n    UP: 'fa-caret-up',\n    DOWN: 'fa-caret-down'\n};\nconst PULL_CLS = {\n    LEFT: 'pull-left',\n    RIGHT: 'pull-right'\n};\n\nconst AUTO_OPEN = {\n    NEVER: 'never',\n    ACTIVE_PAGE: 'activepage',\n    ALWAYS: 'always'\n};\n\nconst WIDGET_CONFIG = { widgetType: 'wm-menu', hostClass: 'dropdown app-menu' };\n@Component({\n    standalone: true,\n    imports: [BsDropdownModule, CommonModule, TextContentDirective, AnchorComponent, ButtonComponent, MenuDropdownComponent],\n    selector: '[wmMenu]',\n    templateUrl: './menu.component.html',\n    providers: [\n        provideAsWidgetRef(MenuComponent),\n\n    ]\n})\nexport class MenuComponent extends DatasetAwareNavComponent implements OnInit, OnDestroy, AfterViewInit {\n    static initializeProps = registerProps();\n\n    public menualign: string;\n    public menuposition: string;\n    public menulayout: string;\n    public menuclass: string;\n    public linktarget: string;\n    public iconclass: string;\n    public animateitems: string;\n    public disableMenuContext: boolean;\n    public showonhover: boolean;\n    public autoclose: string;\n    public autoopen: string;\n    public hint: string;\n    public arialabel: string;\n\n    private itemActionFn: Function;\n    private menuCaret = 'fa-caret-down';\n    private _selectFirstItem = false;\n\n    public type: any;\n    public _menuposition: string;\n\n    @HostListener('onShown') onShow() {\n        this._menuposition = this.menuposition;\n        if (this._selectFirstItem) {\n            setTimeout(() => {\n                this.$element.find('> ul[wmmenudropdown] li.app-menu-item').first().find('> a').focus();\n            });\n        }\n        $appDigest();\n    }\n    @HostListener('onHidden') onHide() {\n        this.$element.find('li').removeClass('open');\n        this._selectFirstItem = false;\n        // reset the menuposition when dropdown is closed\n        this.menuposition = this._menuposition ? this._menuposition : MENU_POSITION.DOWN_RIGHT;\n        this.setMenuPosition();\n        $appDigest();\n    }\n\n    @HostListener('keydown.arrowup', ['$event', '\"UP-ARROW\"'])\n    @HostListener('mouseenter', ['$event', '\"MOUSE-ENTER\"'])\n    @HostListener('mouseleave', ['$event', '\"MOUSE-LEAVE\"'])\n    @HostListener('keydown.arrowdown', ['$event', '\"DOWN-ARROW\"'])\n    @HostListener('keydown.arrowright', ['$event', '\"RIGHT-ARROW\"'])\n    @HostListener('keydown.arrowleft', ['$event', '\"LEFT-ARROW\"'])\n    @HostListener('keydown.enter', ['$event', '\"ENTER\"']) onKeyDown($event, eventAction) {\n        const KEY_MOVEMENTS = clone(KEYBOARD_MOVEMENTS);\n        if (this.menuposition === MENU_POSITION.UP_RIGHT) {\n            KEY_MOVEMENTS.MOVE_UP = 'DOWN-ARROW';\n            KEY_MOVEMENTS.MOVE_DOWN = 'UP-ARROW';\n        } else if (this.menuposition === MENU_POSITION.UP_LEFT) {\n            KEY_MOVEMENTS.MOVE_UP = 'DOWN-ARROW';\n            KEY_MOVEMENTS.MOVE_DOWN = 'UP-ARROW';\n            KEY_MOVEMENTS.MOVE_LEFT = 'RIGHT-ARROW';\n            KEY_MOVEMENTS.MOVE_RIGHT = 'LEFT-ARROW';\n        } else if (this.menuposition === MENU_POSITION.DOWN_LEFT) {\n            KEY_MOVEMENTS.MOVE_LEFT = 'RIGHT-ARROW';\n            KEY_MOVEMENTS.MOVE_RIGHT = 'LEFT-ARROW';\n        }\n\n        if (includes([KEY_MOVEMENTS.MOVE_DOWN, KEY_MOVEMENTS.MOVE_RIGHT], eventAction)) {\n            if (!this.bsDropdown.isOpen) {\n                this._selectFirstItem = true;\n                this.bsDropdown.show();\n            } else {\n                this.$element.find('> ul[wmmenudropdown] li.app-menu-item').first().find('> a').focus();\n            }\n        } else if (eventAction === KEY_MOVEMENTS.ON_ENTER || (eventAction === KEY_MOVEMENTS.ON_MOUSE_ENTER && this.showonhover)) {\n            this.bsDropdown.toggle(true);\n        } else if (includes([KEY_MOVEMENTS.MOVE_UP, KEY_MOVEMENTS.MOVE_LEFT], eventAction) || (eventAction == KEY_MOVEMENTS.ON_MOUSE_LEAVE && this.autoclose == AUTOCLOSE_TYPE.ALWAYS && this.showonhover)) {\n            this.bsDropdown.hide();\n        }\n        $event.preventDefault();\n    }\n\n    constructor(\n        inj: Injector,\n        public route: Router,\n        private userDefinedExecutionContext: UserDefinedExecutionContext,\n        private app: App,\n        @Self() @Optional() public bsDropdown: BsDropdownDirective,\n        @Optional() private parentNav: NavComponent,\n        @Attribute('select.event') public selectEventCB: string,\n        @Inject('EXPLICIT_CONTEXT') @Optional() explicitContext: any\n    ) {\n        super(inj, WIDGET_CONFIG, explicitContext);\n        if (parentNav) {\n            this.disableMenuContext = !!parentNav.disableMenuContext;\n        } else {\n            this.disableMenuContext = !!selectEventCB;\n        }\n        // For selecting the item on load\n        const datasetSubscription = this.nodes$.subscribe(() => {\n            if (!isEmpty(this.nodes)) {\n                if (hasLinkToCurrentPage(this.nodes, this.route.url)) {\n                    addClass(this.nativeElement.querySelector('.dropdown-toggle') as HTMLElement, 'active');\n                }\n                // If menu widget is inside nav widget then dont check for item isactive property because these will be handled form nav widget.\n                if (this.parentNav) {\n                    return;\n                }\n                let itemFound = false;\n                const getItem = (nodes) => {\n                    forEach(nodes, (item) => {\n                        if (itemFound) {\n                            return;\n                        }\n                        if (item.isactive) {\n                            itemFound = true;\n                            this.onMenuItemSelect({ $event: {}, $item: item });\n                            // Trigger the action associated with active item\n                            triggerItemAction(this, item);\n                            return false;\n                        }\n                        if (!isEmpty(item.children)) {\n                            getItem(item.children);\n                        }\n\n                    });\n                };\n                getItem(this.nodes);\n            }\n        });\n        this.registerDestroyListener(() => datasetSubscription.unsubscribe());\n\n    }\n\n    protected resetNodes() {\n        super.resetNodes();\n        // open the menu if any of its menu items has link to current page and if autoopen value is 'active page'\n        if ((this.autoopen === AUTO_OPEN.ACTIVE_PAGE && hasLinkToCurrentPage(this.nodes, this.route.url)) || this.autoopen === AUTO_OPEN.ALWAYS) {\n            this.bsDropdown.show();\n        }\n    }\n\n    ngOnInit() {\n        super.ngOnInit();\n        this.setMenuPosition();\n\n        const cancelSubscription = this.app.subscribe(\"highlightActiveLink\", (data) => {\n            toggleClass(this.nativeElement.querySelector('.dropdown-toggle') as HTMLElement, 'active', hasLinkToCurrentPage(this.nodes, this.route.url ));\n        });\n        this.registerDestroyListener(() => cancelSubscription());\n    }\n\n    onPropertyChange(key: string, nv: any, ov?: any) {\n\n        if (key === 'tabindex') {\n            return;\n        }\n\n        if (key === 'autoclose') {\n            this.bsDropdown.autoClose = nv !== AUTOCLOSE_TYPE.DISABLED;\n            this.autoclose = nv;\n        } else {\n            super.onPropertyChange(key, nv, ov);\n        }\n    }\n\n    public setMenuPosition() {\n        switch (this.menuposition) {\n            case POSITION.DOWN_RIGHT:\n                removeClass(this.nativeElement, 'dropup');\n                this.menualign = PULL_CLS.LEFT;\n                this.menuCaret = CARET_CLS.DOWN;\n                break;\n            case POSITION.DOWN_LEFT:\n                removeClass(this.nativeElement, 'dropup');\n                this.menualign = PULL_CLS.RIGHT;\n                this.menuCaret = CARET_CLS.DOWN;\n                break;\n            case POSITION.UP_LEFT:\n                addClass(this.nativeElement, 'dropup');\n                this.menualign = PULL_CLS.RIGHT;\n                this.menuCaret = CARET_CLS.UP;\n                break;\n            case POSITION.UP_RIGHT:\n                addClass(this.nativeElement, 'dropup');\n                this.menualign = PULL_CLS.LEFT;\n                this.menuCaret = CARET_CLS.UP;\n                break;\n            case POSITION.INLINE:\n                this.menualign = 'dropinline-menu';\n                break;\n        }\n    }\n\n    public onMenuItemSelect(args) {\n        const { $event } = args;\n        const $item = args.$item.value;\n        this.invokeEventCallback('select', { $event, $item });\n    }\n\n    ngAfterViewInit() {\n        super.ngAfterViewInit();\n        // Fix tabindex if it's NaN (ensure it's fixed after view initialization)\n        if (this.widget.tabindex !== undefined && (typeof this.widget.tabindex === 'number' && isNaN(this.widget.tabindex))) {\n            this.widget.tabindex = 0;\n            (this as any).tabindex = 0;\n        }\n        styler(this.nativeElement.querySelector('.dropdown-toggle') as HTMLElement, this);\n    }\n}\n","\n\n<ng-template #innerTemplate>\n  <i class=\"app-icon {{iconclass}}\"></i>\n  <span class=\"caption\" [textContent]=\"caption\"></span>\n  <span class=\"pull-right caret fa {{menuCaret}}\"></span>\n</ng-template>\n\n@if (type === 'anchor') {\n  <a wmAnchor\n    dropdownToggle\n    [attr.aria-label]=\"arialabel || 'Menu'\"\n    href=\"javascript:void(0);\"\n    role=\"button\"\n    aria-haspopup=\"true\"\n    aria-expanded=\"false\"\n    hint.bind=\"hint\"\n    class=\"dropdown-toggle {{menuclass}}\"\n    shortcutkey.bind=\"shortcutkey\"\n    tabindex.bind=\"tabindex\"\n    caption.bind=\"caption\"\n    iconclass.bind=\"iconclass\"\n    iconposition.bind=\"iconposition\"\n    badgevalue.bind=\"badgevalue\"\n    >\n    <span class=\"pull-right caret fa\" [ngClass]=\"[menuCaret]\"></span>\n  </a>\n} @else {\n  <button wmButton\n    dropdownToggle\n    aria-haspopup=\"true\"\n    aria-expanded=\"false\"\n    [attr.aria-label]=\"arialabel || 'Menu'\"\n    class=\"btn app-button dropdown-toggle {{menuclass}}\"\n    hint.bind=\"hint\"\n    shortcutkey.bind=\"shortcutkey\"\n    tabindex.bind=\"tabindex\"\n    caption.bind=\"caption\"\n    iconclass.bind=\"iconclass\"\n    iconposition.bind=\"iconposition\">\n    <span class=\"pull-right caret fa\" [ngClass]=\"[menuCaret]\"></span>\n  </button>\n}\n\n<ul *dropdownMenu [items]=\"nodes\" [ngClass]=\"menulayout\" class=\"icon-position-{{iconposition}}\" role=\"menubar\"\nwmMenuDropdown></ul>\n"]}
|
|
@@ -756,6 +756,11 @@ class MenuComponent extends DatasetAwareNavComponent {
|
|
|
756
756
|
}
|
|
757
757
|
ngAfterViewInit() {
|
|
758
758
|
super.ngAfterViewInit();
|
|
759
|
+
// Fix tabindex if it's NaN (ensure it's fixed after view initialization)
|
|
760
|
+
if (this.widget.tabindex !== undefined && (typeof this.widget.tabindex === 'number' && isNaN(this.widget.tabindex))) {
|
|
761
|
+
this.widget.tabindex = 0;
|
|
762
|
+
this.tabindex = 0;
|
|
763
|
+
}
|
|
759
764
|
styler(this.nativeElement.querySelector('.dropdown-toggle'), this);
|
|
760
765
|
}
|
|
761
766
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MenuComponent, deps: [{ token: i0.Injector }, { token: i1.Router }, { token: i2.UserDefinedExecutionContext }, { token: i2.App }, { token: i3$1.BsDropdownDirective, optional: true, self: true }, { token: NavComponent, optional: true }, { token: 'select.event', attribute: true }, { token: 'EXPLICIT_CONTEXT', optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
|