@mintplayer/ng-bootstrap 15.16.0 → 15.16.1
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/esm2020/navbar/src/navbar-dropdown/navbar-dropdown.component.mjs +54 -10
- package/esm2020/navbar/src/navbar-item/navbar-item.component.mjs +29 -10
- package/esm2020/navbar/src/navbar.module.mjs +7 -5
- package/fesm2015/mintplayer-ng-bootstrap-navbar.mjs +79 -16
- package/fesm2015/mintplayer-ng-bootstrap-navbar.mjs.map +1 -1
- package/fesm2020/mintplayer-ng-bootstrap-navbar.mjs +79 -16
- package/fesm2020/mintplayer-ng-bootstrap-navbar.mjs.map +1 -1
- package/navbar/src/navbar-dropdown/navbar-dropdown.component.d.ts +8 -3
- package/navbar/src/navbar-item/navbar-item.component.d.ts +7 -6
- package/navbar/src/navbar.module.d.ts +2 -1
- package/package.json +1 -1
|
@@ -1,18 +1,23 @@
|
|
|
1
1
|
import { DOCUMENT, isPlatformServer } from '@angular/common';
|
|
2
|
-
import { Component, ContentChildren, ElementRef, forwardRef, Host, Inject, Input, Optional, PLATFORM_ID, QueryList, SkipSelf, ViewChild } from '@angular/core';
|
|
2
|
+
import { Component, ContentChildren, ElementRef, forwardRef, Host, Inject, Injector, Input, Optional, PLATFORM_ID, QueryList, SkipSelf, ViewChild } from '@angular/core';
|
|
3
3
|
import { BehaviorSubject, combineLatest, map, Subject, takeUntil } from 'rxjs';
|
|
4
4
|
import { BsNavbarComponent } from '../navbar/navbar.component';
|
|
5
5
|
import { BsNavbarItemComponent } from '../navbar-item/navbar-item.component';
|
|
6
|
+
import { DomPortal } from '@angular/cdk/portal';
|
|
6
7
|
import * as i0 from "@angular/core";
|
|
7
8
|
import * as i1 from "../navbar/navbar.component";
|
|
8
9
|
import * as i2 from "@mintplayer/ng-click-outside";
|
|
9
|
-
import * as i3 from "@
|
|
10
|
-
import * as i4 from "
|
|
10
|
+
import * as i3 from "@mintplayer/ng-bootstrap/no-noscript";
|
|
11
|
+
import * as i4 from "@mintplayer/ng-bootstrap/has-overlay";
|
|
12
|
+
import * as i5 from "@angular/common";
|
|
13
|
+
import * as i6 from "../navbar-item/navbar-item.component";
|
|
11
14
|
export class BsNavbarDropdownComponent {
|
|
12
|
-
constructor(navbar, parentDropdown, navbarItem, element, document, platformId) {
|
|
15
|
+
constructor(navbar, parentDropdown, navbarItem, element, injector, document, platformId) {
|
|
13
16
|
this.navbar = navbar;
|
|
14
17
|
this.element = element;
|
|
18
|
+
this.injector = injector;
|
|
15
19
|
this.document = document;
|
|
20
|
+
this.isAttached = false;
|
|
16
21
|
this.autoclose = true;
|
|
17
22
|
this.destroyed$ = new Subject();
|
|
18
23
|
this.isBrowser = false;
|
|
@@ -24,6 +29,7 @@ export class BsNavbarDropdownComponent {
|
|
|
24
29
|
this.isBrowser = !isPlatformServer(platformId);
|
|
25
30
|
this.isVisible$.pipe(takeUntil(this.destroyed$)).subscribe((isVisible) => {
|
|
26
31
|
if (isVisible) {
|
|
32
|
+
setTimeout(() => this.overlay && this.overlay.updatePosition(), 20);
|
|
27
33
|
this.topPos$.next(this.element.nativeElement.offsetTop);
|
|
28
34
|
}
|
|
29
35
|
else {
|
|
@@ -47,10 +53,48 @@ export class BsNavbarDropdownComponent {
|
|
|
47
53
|
if (isSmallMode) {
|
|
48
54
|
return null;
|
|
49
55
|
}
|
|
56
|
+
else if (isPlatformServer(platformId)) {
|
|
57
|
+
// Javascript disabled
|
|
58
|
+
// Only apply max-height to the top-dropdown
|
|
59
|
+
return parentDropdown ? null : maxHeight;
|
|
60
|
+
}
|
|
50
61
|
else {
|
|
62
|
+
// If javascript enabled
|
|
51
63
|
return maxHeight;
|
|
52
64
|
}
|
|
53
65
|
}));
|
|
66
|
+
if (!!parentDropdown) {
|
|
67
|
+
// Setup overlay
|
|
68
|
+
import('@angular/cdk/overlay').then(({ OverlayModule, Overlay }) => {
|
|
69
|
+
const overlayService = this.injector.get(Overlay);
|
|
70
|
+
return overlayService;
|
|
71
|
+
}).then((overlayService) => {
|
|
72
|
+
this.domPortal = new DomPortal(this.element);
|
|
73
|
+
this.overlay = overlayService.create({
|
|
74
|
+
positionStrategy: overlayService.position()
|
|
75
|
+
.flexibleConnectedTo(this.navbarItem.element)
|
|
76
|
+
.withPositions([
|
|
77
|
+
{ originX: 'end', originY: 'top', overlayX: 'start', overlayY: 'top', offsetX: -7, offsetY: -9 }
|
|
78
|
+
])
|
|
79
|
+
});
|
|
80
|
+
// For some reason we have to trigger this from the BsDropdownItem
|
|
81
|
+
// this.showInOverlay = true;
|
|
82
|
+
});
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
set showInOverlay(value) {
|
|
86
|
+
if (this.overlay && this.domPortal) {
|
|
87
|
+
console.log('showInOverlay', value);
|
|
88
|
+
// if (value && !this.overlay.hasAttached()) {
|
|
89
|
+
if (value && !this.isAttached) {
|
|
90
|
+
this.overlay.attach(this.domPortal);
|
|
91
|
+
this.isAttached = true;
|
|
92
|
+
}
|
|
93
|
+
if (!value && this.isAttached) {
|
|
94
|
+
this.overlay.detach();
|
|
95
|
+
this.isAttached = false;
|
|
96
|
+
}
|
|
97
|
+
}
|
|
54
98
|
}
|
|
55
99
|
get isVisible() {
|
|
56
100
|
return this.isVisible$.value;
|
|
@@ -66,23 +110,23 @@ export class BsNavbarDropdownComponent {
|
|
|
66
110
|
this.destroyed$.next(true);
|
|
67
111
|
}
|
|
68
112
|
}
|
|
69
|
-
BsNavbarDropdownComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: BsNavbarDropdownComponent, deps: [{ token: i1.BsNavbarComponent }, { token: BsNavbarDropdownComponent, host: true, optional: true, skipSelf: true }, { token: forwardRef(() => BsNavbarItemComponent), host: true }, { token: i0.ElementRef }, { token: DOCUMENT }, { token: PLATFORM_ID }], target: i0.ɵɵFactoryTarget.Component });
|
|
70
|
-
BsNavbarDropdownComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.0", type: BsNavbarDropdownComponent, selector: "bs-navbar-dropdown", inputs: { autoclose: "autoclose" }, queries: [{ propertyName: "childDropdowns", predicate: i0.forwardRef(function () { return BsNavbarDropdownComponent; }), descendants: true }], viewQueries: [{ propertyName: "dropdownElement", first: true, predicate: ["dd"], descendants: true }], ngImport: i0, template: "
|
|
113
|
+
BsNavbarDropdownComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: BsNavbarDropdownComponent, deps: [{ token: i1.BsNavbarComponent }, { token: BsNavbarDropdownComponent, host: true, optional: true, skipSelf: true }, { token: forwardRef(() => BsNavbarItemComponent), host: true }, { token: i0.ElementRef }, { token: i0.Injector }, { token: DOCUMENT }, { token: PLATFORM_ID }], target: i0.ɵɵFactoryTarget.Component });
|
|
114
|
+
BsNavbarDropdownComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.0", type: BsNavbarDropdownComponent, selector: "bs-navbar-dropdown", inputs: { autoclose: "autoclose" }, queries: [{ propertyName: "childDropdowns", predicate: i0.forwardRef(function () { return BsNavbarDropdownComponent; }), descendants: true }], viewQueries: [{ propertyName: "dropdownElement", first: true, predicate: ["dd"], descendants: true }], ngImport: i0, template: "<bs-has-overlay></bs-has-overlay>\n<ul #dd class=\"dropdown-menu\" [class.show]=\"isVisible$ | async\" [class.submenu]=\"!!parentDropdown\" [class.overflow-y-auto]=\"isBrowser\" [style.max-height]=\"maxHeightOrNull$ | async\" bsNoNoscript (clickOutside)=\"isVisible = false\" [exclude]=\"elementsToExclude\" aria-labelledby=\"navbarDropdown\">\n <ng-content></ng-content>\n</ul>\n\n<!-- \n - Working demo: https://codepen.io/agop/pen/VwwMGR\n - Location must be set through javascript\n - bsNoScript => If noscript, 2nd-level submenus must be shown inside the 1st-level submenu\n -->\n <!-- \n - Another option: https://stackblitz.com/edit/web-platform-vmsr4l?file=index.html\n - But this doesn't seem to work here\n -->", styles: [".submenu:not(.noscript){margin:0 .5rem!important}.submenu.noscript{margin:0 .5rem;position:initial!important}:not(.submenu).noscript{max-height:calc(100vh - 100% - 1rem);overflow-y:auto}.overflow-y-auto{overflow-y:auto}\n"], dependencies: [{ kind: "directive", type: i2.ClickOutsideDirective, selector: "[clickOutside]", inputs: ["clickOutsideEnabled", "attachOutsideOnClick", "delayClickOutsideInit", "emitOnBlur", "exclude", "excludeBeforeClick", "clickOutsideEvents"], outputs: ["clickOutside"] }, { kind: "directive", type: i3.BsNoNoscriptDirective, selector: "[bsNoNoscript]" }, { kind: "component", type: i4.BsHasOverlayComponent, selector: "bs-has-overlay" }, { kind: "pipe", type: i5.AsyncPipe, name: "async" }] });
|
|
71
115
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: BsNavbarDropdownComponent, decorators: [{
|
|
72
116
|
type: Component,
|
|
73
|
-
args: [{ selector: 'bs-navbar-dropdown', template: "
|
|
117
|
+
args: [{ selector: 'bs-navbar-dropdown', template: "<bs-has-overlay></bs-has-overlay>\n<ul #dd class=\"dropdown-menu\" [class.show]=\"isVisible$ | async\" [class.submenu]=\"!!parentDropdown\" [class.overflow-y-auto]=\"isBrowser\" [style.max-height]=\"maxHeightOrNull$ | async\" bsNoNoscript (clickOutside)=\"isVisible = false\" [exclude]=\"elementsToExclude\" aria-labelledby=\"navbarDropdown\">\n <ng-content></ng-content>\n</ul>\n\n<!-- \n - Working demo: https://codepen.io/agop/pen/VwwMGR\n - Location must be set through javascript\n - bsNoScript => If noscript, 2nd-level submenus must be shown inside the 1st-level submenu\n -->\n <!-- \n - Another option: https://stackblitz.com/edit/web-platform-vmsr4l?file=index.html\n - But this doesn't seem to work here\n -->", styles: [".submenu:not(.noscript){margin:0 .5rem!important}.submenu.noscript{margin:0 .5rem;position:initial!important}:not(.submenu).noscript{max-height:calc(100vh - 100% - 1rem);overflow-y:auto}.overflow-y-auto{overflow-y:auto}\n"] }]
|
|
74
118
|
}], ctorParameters: function () { return [{ type: i1.BsNavbarComponent }, { type: BsNavbarDropdownComponent, decorators: [{
|
|
75
119
|
type: SkipSelf
|
|
76
120
|
}, {
|
|
77
121
|
type: Host
|
|
78
122
|
}, {
|
|
79
123
|
type: Optional
|
|
80
|
-
}] }, { type:
|
|
124
|
+
}] }, { type: i6.BsNavbarItemComponent, decorators: [{
|
|
81
125
|
type: Host
|
|
82
126
|
}, {
|
|
83
127
|
type: Inject,
|
|
84
128
|
args: [forwardRef(() => BsNavbarItemComponent)]
|
|
85
|
-
}] }, { type: i0.ElementRef }, { type: Document, decorators: [{
|
|
129
|
+
}] }, { type: i0.ElementRef }, { type: i0.Injector }, { type: Document, decorators: [{
|
|
86
130
|
type: Inject,
|
|
87
131
|
args: [DOCUMENT]
|
|
88
132
|
}] }, { type: Object, decorators: [{
|
|
@@ -97,4 +141,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImpor
|
|
|
97
141
|
type: ContentChildren,
|
|
98
142
|
args: [forwardRef(() => BsNavbarDropdownComponent), { descendants: true }]
|
|
99
143
|
}] } });
|
|
100
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"navbar-dropdown.component.js","sourceRoot":"","sources":["../../../../../../../libs/mintplayer-ng-bootstrap/navbar/src/navbar-dropdown/navbar-dropdown.component.ts","../../../../../../../libs/mintplayer-ng-bootstrap/navbar/src/navbar-dropdown/navbar-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DOCUMENT, isPlatformServer } from '@angular/common';\nimport { Component, ContentChildren, ElementRef, forwardRef, Host, Inject, Input, OnDestroy, Optional, PLATFORM_ID, QueryList, SkipSelf, ViewChild } from '@angular/core';\nimport { BehaviorSubject, combineLatest, map, Observable, Subject, takeUntil } from 'rxjs';\nimport { BsNavbarComponent } from '../navbar/navbar.component';\nimport { BsNavbarItemComponent } from '../navbar-item/navbar-item.component';\n\n@Component({\n  selector: 'bs-navbar-dropdown',\n  templateUrl: './navbar-dropdown.component.html',\n  styleUrls: ['./navbar-dropdown.component.scss']\n})\nexport class BsNavbarDropdownComponent implements OnDestroy {\n\n  constructor(\n    private navbar: BsNavbarComponent,\n    @SkipSelf() @Host() @Optional() parentDropdown: BsNavbarDropdownComponent,\n    @Host() @Inject(forwardRef(() => BsNavbarItemComponent)) navbarItem: BsNavbarItemComponent,\n    public element: ElementRef<HTMLElement>,\n    @Inject(DOCUMENT) private document: Document,\n    @Inject(PLATFORM_ID) platformId: Object,\n  ) {\n    this.parentDropdown = parentDropdown;\n    this.navbarItem = navbarItem;\n    this.isBrowser = !isPlatformServer(platformId);\n\n    this.isVisible$.pipe(takeUntil(this.destroyed$)).subscribe((isVisible) => {\n      if (isVisible) {\n        this.topPos$.next(this.element.nativeElement.offsetTop);\n      } else {\n        this.topPos$.next(null);\n      }\n    });\n\n    this.maxHeight$ = this.topPos$.pipe(map((topPos) => {\n      const w: Window | null = this.document.defaultView;\n      if (!topPos) {\n        return null;\n      } else if (w) {\n        const style = w.getComputedStyle(this.dropdownElement.nativeElement);\n        return `calc(100vh - ${topPos}px - ${style.getPropertyValue('padding-top')} - ${style.getPropertyValue('padding-bottom')})`;\n      } else {\n        return null;\n      }\n    }));\n\n    this.maxHeightOrNull$ = combineLatest([this.maxHeight$, this.navbar.isSmallMode$]).pipe(map(([maxHeight, isSmallMode]) => {\n      if (isSmallMode) {\n        return null;\n      } else {\n        return maxHeight;\n      }\n    }));\n  }\n\n  @Input() public autoclose = true;\n  navbarItem: BsNavbarItemComponent;\n  parentDropdown: BsNavbarDropdownComponent;\n  private destroyed$ = new Subject();\n  @ViewChild('dd') dropdownElement!: ElementRef<HTMLDivElement>;\n  isBrowser = false;\n  topPos$ = new BehaviorSubject<number | null>(null);\n  maxHeight$: Observable<string | null>;\n  maxHeightOrNull$: Observable<string | null>;\n\n  //#region IsVisible\n  isVisible$ = new BehaviorSubject<boolean>(false);\n  public get isVisible() {\n    return this.isVisible$.value;\n  }\n  public set isVisible(value: boolean) {\n    this.isVisible$.next(value);\n  }\n  //#endregion\n\n  get elementsToExclude() {\n    return [this.navbarItem.anchorTag].filter((a) => a).map((a) => <HTMLElement>a);\n  }\n\n  @ContentChildren(forwardRef(() => BsNavbarDropdownComponent), { descendants: true }) childDropdowns!: QueryList<BsNavbarDropdownComponent>;\n\n  ngOnDestroy() {\n    this.destroyed$.next(true);\n  }\n}\n","<!-- <bs-has-overlay></bs-has-overlay> -->\n<!-- [class.overflow-auto]=\"isBrowser\" -->\n<!-- [style.max-height]=\"maxHeightOrNull$ | async\" -->\n<ul #dd class=\"dropdown-menu\" [class.show]=\"isVisible$ | async\" [class.submenu]=\"!!parentDropdown\" (clickOutside)=\"isVisible = false\" [exclude]=\"elementsToExclude\" aria-labelledby=\"navbarDropdown\">\n    <ng-content></ng-content>\n</ul>\n\n<!-- \n    - Working demo: https://codepen.io/agop/pen/VwwMGR\n    - Location must be set through javascript\n    - bsNoScript => If noscript, 2nd-level submenus must be shown inside the 1st-level submenu\n -->\n <!-- \n    - Another option: https://stackblitz.com/edit/web-platform-vmsr4l?file=index.html\n    - But this doesn't seem to work here\n  -->"]}
|
|
144
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"navbar-dropdown.component.js","sourceRoot":"","sources":["../../../../../../../libs/mintplayer-ng-bootstrap/navbar/src/navbar-dropdown/navbar-dropdown.component.ts","../../../../../../../libs/mintplayer-ng-bootstrap/navbar/src/navbar-dropdown/navbar-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DOCUMENT, isPlatformServer } from '@angular/common';\nimport { Component, ContentChildren, ElementRef, forwardRef, Host, Inject, Injector, Input, OnDestroy, Optional, PLATFORM_ID, QueryList, SkipSelf, ViewChild } from '@angular/core';\nimport { BehaviorSubject, combineLatest, map, Observable, Subject, takeUntil } from 'rxjs';\nimport { BsNavbarComponent } from '../navbar/navbar.component';\nimport { BsNavbarItemComponent } from '../navbar-item/navbar-item.component';\nimport { DomPortal } from '@angular/cdk/portal';\nimport { OverlayRef } from '@angular/cdk/overlay';\n\n@Component({\n  selector: 'bs-navbar-dropdown',\n  templateUrl: './navbar-dropdown.component.html',\n  styleUrls: ['./navbar-dropdown.component.scss']\n})\nexport class BsNavbarDropdownComponent implements OnDestroy {\n\n  constructor(\n    private navbar: BsNavbarComponent,\n    @SkipSelf() @Host() @Optional() parentDropdown: BsNavbarDropdownComponent,\n    @Host() @Inject(forwardRef(() => BsNavbarItemComponent)) navbarItem: BsNavbarItemComponent,\n    public element: ElementRef<HTMLElement>,\n    private injector: Injector,\n    @Inject(DOCUMENT) private document: Document,\n    @Inject(PLATFORM_ID) platformId: Object,\n  ) {\n    this.parentDropdown = parentDropdown;\n    this.navbarItem = navbarItem;\n    this.isBrowser = !isPlatformServer(platformId);\n\n    this.isVisible$.pipe(takeUntil(this.destroyed$)).subscribe((isVisible) => {\n      if (isVisible) {\n        setTimeout(() => this.overlay && this.overlay.updatePosition(), 20);\n        this.topPos$.next(this.element.nativeElement.offsetTop);\n      } else {\n        this.topPos$.next(null);\n      }\n    });\n\n    this.maxHeight$ = this.topPos$.pipe(map((topPos) => {\n      const w: Window | null = this.document.defaultView;\n      if (!topPos) {\n        return null;\n      } else if (w) {\n        const style = w.getComputedStyle(this.dropdownElement.nativeElement);\n        return `calc(100vh - ${topPos}px - ${style.getPropertyValue('padding-top')} - ${style.getPropertyValue('padding-bottom')})`;\n      } else {\n        return null;\n      }\n    }));\n\n    this.maxHeightOrNull$ = combineLatest([this.maxHeight$, this.navbar.isSmallMode$]).pipe(map(([maxHeight, isSmallMode]) => {\n      if (isSmallMode) {\n        return null;\n      } else if (isPlatformServer(platformId)) {\n        // Javascript disabled\n        // Only apply max-height to the top-dropdown\n        return parentDropdown ? null : maxHeight;\n      } else {\n        // If javascript enabled\n        return maxHeight;\n      }\n    }));\n\n    if (!!parentDropdown) {\n      // Setup overlay\n      import('@angular/cdk/overlay').then(({ OverlayModule, Overlay }) => {\n        const overlayService = this.injector.get(Overlay);\n        return overlayService;\n      }).then((overlayService) => {\n\n        this.domPortal = new DomPortal(this.element);\n        this.overlay = overlayService.create({\n          positionStrategy: overlayService.position()\n            .flexibleConnectedTo(this.navbarItem.element)\n            .withPositions([\n              { originX: 'end', originY: 'top', overlayX: 'start', overlayY: 'top', offsetX: -7, offsetY: -9 }\n            ])\n        });\n\n        // For some reason we have to trigger this from the BsDropdownItem\n        // this.showInOverlay = true;\n      });\n    }\n\n  }\n\n  private isAttached = false;\n  private domPortal?: DomPortal;\n  private overlay?: OverlayRef;\n  public set showInOverlay(value: boolean) {\n    if (this.overlay && this.domPortal) {\n      console.log('showInOverlay', value);\n      // if (value && !this.overlay.hasAttached()) {\n      if (value && !this.isAttached) {\n        this.overlay.attach(this.domPortal);\n        this.isAttached = true;\n      }\n      if (!value && this.isAttached) {\n        this.overlay.detach();\n        this.isAttached = false;\n      }\n    }\n  }\n\n  @Input() public autoclose = true;\n  navbarItem: BsNavbarItemComponent;\n  parentDropdown: BsNavbarDropdownComponent;\n  private destroyed$ = new Subject();\n  @ViewChild('dd') dropdownElement!: ElementRef<HTMLDivElement>;\n  isBrowser = false;\n  topPos$ = new BehaviorSubject<number | null>(null);\n  maxHeight$: Observable<string | null>;\n  maxHeightOrNull$: Observable<string | null>;\n\n  //#region IsVisible\n  isVisible$ = new BehaviorSubject<boolean>(false);\n  public get isVisible() {\n    return this.isVisible$.value;\n  }\n  public set isVisible(value: boolean) {\n    this.isVisible$.next(value);\n  }\n  //#endregion\n\n  get elementsToExclude() {\n    return [this.navbarItem.anchorTag].filter((a) => a).map((a) => <HTMLElement>a);\n  }\n\n  @ContentChildren(forwardRef(() => BsNavbarDropdownComponent), { descendants: true }) childDropdowns!: QueryList<BsNavbarDropdownComponent>;\n\n  ngOnDestroy() {\n    this.destroyed$.next(true);\n  }\n}\n","<bs-has-overlay></bs-has-overlay>\n<ul #dd class=\"dropdown-menu\" [class.show]=\"isVisible$ | async\" [class.submenu]=\"!!parentDropdown\" [class.overflow-y-auto]=\"isBrowser\" [style.max-height]=\"maxHeightOrNull$ | async\" bsNoNoscript (clickOutside)=\"isVisible = false\" [exclude]=\"elementsToExclude\" aria-labelledby=\"navbarDropdown\">\n    <ng-content></ng-content>\n</ul>\n\n<!-- \n    - Working demo: https://codepen.io/agop/pen/VwwMGR\n    - Location must be set through javascript\n    - bsNoScript => If noscript, 2nd-level submenus must be shown inside the 1st-level submenu\n -->\n <!-- \n    - Another option: https://stackblitz.com/edit/web-platform-vmsr4l?file=index.html\n    - But this doesn't seem to work here\n  -->"]}
|
|
@@ -1,18 +1,22 @@
|
|
|
1
|
-
import { Component, ContentChildren, ElementRef, forwardRef, Inject,
|
|
1
|
+
import { Component, ContentChildren, ElementRef, forwardRef, Inject, Optional, PLATFORM_ID, QueryList } from '@angular/core';
|
|
2
|
+
import { isPlatformServer } from '@angular/common';
|
|
3
|
+
import { Subject } from 'rxjs';
|
|
4
|
+
import { takeUntil } from 'rxjs/operators';
|
|
2
5
|
import { BsNavbarComponent } from '../navbar/navbar.component';
|
|
3
6
|
import { BsNavbarDropdownComponent } from '../navbar-dropdown/navbar-dropdown.component';
|
|
4
|
-
import { isPlatformServer } from '@angular/common';
|
|
5
7
|
import * as i0 from "@angular/core";
|
|
6
8
|
import * as i1 from "../navbar/navbar.component";
|
|
7
9
|
import * as i2 from "../navbar-dropdown/navbar-dropdown.component";
|
|
8
10
|
export class BsNavbarItemComponent {
|
|
9
|
-
constructor(navbar, element,
|
|
11
|
+
constructor(navbar, element,
|
|
12
|
+
// private injector: Injector,
|
|
13
|
+
platformId, parentDropdown) {
|
|
10
14
|
this.navbar = navbar;
|
|
11
|
-
this.element = element;
|
|
12
|
-
this.injector = injector;
|
|
13
15
|
this.platformId = platformId;
|
|
14
16
|
this.hasDropdown = false;
|
|
15
17
|
this.anchorTag = null;
|
|
18
|
+
this.destroyed$ = new Subject();
|
|
19
|
+
this.element = element;
|
|
16
20
|
this.parentDropdown = parentDropdown;
|
|
17
21
|
}
|
|
18
22
|
ngAfterContentChecked() {
|
|
@@ -33,16 +37,28 @@ export class BsNavbarItemComponent {
|
|
|
33
37
|
dropdown.childDropdowns.forEach((child) => {
|
|
34
38
|
child.isVisible = false;
|
|
35
39
|
});
|
|
36
|
-
|
|
40
|
+
}
|
|
41
|
+
else if (this.parentDropdown) {
|
|
37
42
|
// import('@angular/cdk/overlay').then(({ OverlayModule, Overlay }) => {
|
|
38
43
|
// const overlayService = this.injector.get(Overlay);
|
|
39
44
|
// return overlayService;
|
|
40
45
|
// }).then((overlayService) => {
|
|
41
46
|
// const p = new DomPortal(dropdown.element);
|
|
42
47
|
// const overlayRef = overlayService.create({
|
|
48
|
+
// positionStrategy: overlayService.position()
|
|
49
|
+
// .flexibleConnectedTo(this.element)
|
|
50
|
+
// .withPositions([
|
|
51
|
+
// { originX: 'end', originY: 'top', overlayX: 'start', overlayY: 'top' }
|
|
52
|
+
// ])
|
|
43
53
|
// });
|
|
44
|
-
//
|
|
54
|
+
// overlayRef.attach(p);
|
|
45
55
|
// });
|
|
56
|
+
// dropdown.showInOverlay = true;
|
|
57
|
+
this.navbar.isSmallMode$
|
|
58
|
+
.pipe(takeUntil(this.destroyed$))
|
|
59
|
+
.subscribe((isSmallMode) => {
|
|
60
|
+
dropdown.showInOverlay = !isSmallMode;
|
|
61
|
+
});
|
|
46
62
|
}
|
|
47
63
|
});
|
|
48
64
|
return false;
|
|
@@ -67,13 +83,16 @@ export class BsNavbarItemComponent {
|
|
|
67
83
|
}
|
|
68
84
|
}
|
|
69
85
|
}
|
|
86
|
+
ngOnDestroy() {
|
|
87
|
+
this.destroyed$.next(true);
|
|
88
|
+
}
|
|
70
89
|
}
|
|
71
|
-
BsNavbarItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: BsNavbarItemComponent, deps: [{ token: i1.BsNavbarComponent }, { token: i0.ElementRef }, { token:
|
|
90
|
+
BsNavbarItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: BsNavbarItemComponent, deps: [{ token: i1.BsNavbarComponent }, { token: i0.ElementRef }, { token: PLATFORM_ID }, { token: i2.BsNavbarDropdownComponent, optional: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
72
91
|
BsNavbarItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.0", type: BsNavbarItemComponent, selector: "bs-navbar-item", queries: [{ propertyName: "dropdowns", predicate: i0.forwardRef(function () { return BsNavbarDropdownComponent; }) }], ngImport: i0, template: "<li [class.nav-item]=\"parentDropdown === null\" [class.dropdown]=\"(dropdowns.length > 0) && (parentDropdown === null)\" [class.dropend]=\"(dropdowns.length > 0) && (parentDropdown !== null)\">\n <ng-content></ng-content>\n</li>", styles: ["li.dropend ::ng-deep a.dropdown-toggle{padding-right:1.5rem}li.dropend ::ng-deep a.dropdown-toggle:after{position:absolute;right:.5rem;top:.75rem}\n"] });
|
|
73
92
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: BsNavbarItemComponent, decorators: [{
|
|
74
93
|
type: Component,
|
|
75
94
|
args: [{ selector: 'bs-navbar-item', template: "<li [class.nav-item]=\"parentDropdown === null\" [class.dropdown]=\"(dropdowns.length > 0) && (parentDropdown === null)\" [class.dropend]=\"(dropdowns.length > 0) && (parentDropdown !== null)\">\n <ng-content></ng-content>\n</li>", styles: ["li.dropend ::ng-deep a.dropdown-toggle{padding-right:1.5rem}li.dropend ::ng-deep a.dropdown-toggle:after{position:absolute;right:.5rem;top:.75rem}\n"] }]
|
|
76
|
-
}], ctorParameters: function () { return [{ type: i1.BsNavbarComponent }, { type: i0.ElementRef }, { type:
|
|
95
|
+
}], ctorParameters: function () { return [{ type: i1.BsNavbarComponent }, { type: i0.ElementRef }, { type: Object, decorators: [{
|
|
77
96
|
type: Inject,
|
|
78
97
|
args: [PLATFORM_ID]
|
|
79
98
|
}] }, { type: i2.BsNavbarDropdownComponent, decorators: [{
|
|
@@ -82,4 +101,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImpor
|
|
|
82
101
|
type: ContentChildren,
|
|
83
102
|
args: [forwardRef(() => BsNavbarDropdownComponent)]
|
|
84
103
|
}] } });
|
|
85
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"navbar-item.component.js","sourceRoot":"","sources":["../../../../../../../libs/mintplayer-ng-bootstrap/navbar/src/navbar-item/navbar-item.component.ts","../../../../../../../libs/mintplayer-ng-bootstrap/navbar/src/navbar-item/navbar-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterContentChecked, Component, ContentChildren, ElementRef, forwardRef, Inject, Injector, Optional, PLATFORM_ID, QueryList, ViewContainerRef } from '@angular/core';\nimport { BsNavbarComponent } from '../navbar/navbar.component';\nimport { BsNavbarDropdownComponent } from '../navbar-dropdown/navbar-dropdown.component';\nimport { isPlatformServer } from '@angular/common';\nimport { DomPortal } from '@angular/cdk/portal';\n\n@Component({\n  selector: 'bs-navbar-item',\n  templateUrl: './navbar-item.component.html',\n  styleUrls: ['./navbar-item.component.scss']\n})\nexport class BsNavbarItemComponent implements AfterContentChecked {\n\n  constructor(\n    private navbar: BsNavbarComponent,\n    private element: ElementRef,\n    private injector: Injector,\n    @Inject(PLATFORM_ID) private platformId: Object,\n    @Optional() parentDropdown: BsNavbarDropdownComponent,\n  ) {\n    this.parentDropdown = parentDropdown;\n  }\n\n  parentDropdown: BsNavbarDropdownComponent;\n  hasDropdown = false;\n  anchorTag: HTMLAnchorElement | null = null;\n  @ContentChildren(forwardRef(() => BsNavbarDropdownComponent)) dropdowns!: QueryList<BsNavbarDropdownComponent>;\n\n  ngAfterContentChecked() {\n    this.anchorTag = this.element.nativeElement.querySelector('li a');\n\n    if (this.hasDropdown) {\n      if (this.anchorTag) {\n        this.anchorTag.classList.add('dropdown-toggle');\n\n        if (isPlatformServer(this.platformId)) {\n          this.anchorTag.href = 'javascript:;';\n        }\n  \n        if (!this.anchorTag.getAttribute('close-init-b')) {\n          this.anchorTag.setAttribute('close-init-b', '1');\n          this.anchorTag.addEventListener('click', (ev: MouseEvent) => {\n            ev.preventDefault();\n            // Normally there should be only one dropdown in this list\n            this.dropdowns.forEach((dropdown) => {\n              if (!(dropdown.isVisible = !dropdown.isVisible)) {\n                dropdown.childDropdowns.forEach((child) => {\n                  child.isVisible = false;\n                });\n              // } else {\n                // import('@angular/cdk/overlay').then(({ OverlayModule, Overlay }) => {\n                //   const overlayService = this.injector.get(Overlay);\n                //   return overlayService;\n                // }).then((overlayService) => {\n\n                //   const p = new DomPortal(dropdown.element);\n                //   const overlayRef = overlayService.create({\n                //   });\n                //   overlayRef.attach(p);\n\n                // });\n\n              }\n            });\n            return false;\n          });\n        }\n      }\n    } else {\n\n      // Close if this is a link\n      if ((this.dropdowns.length === 0) && this.anchorTag && !this.anchorTag.getAttribute('close-init-a')) {\n        this.anchorTag.setAttribute('close-init-a', '1');\n        this.anchorTag.addEventListener('click', (ev: MouseEvent) => {\n          let d = this.parentDropdown;\n          while (d && d.autoclose) {\n            d.isVisible = false;\n            d = d.parentDropdown;\n          }\n          if (this.navbar.autoclose) {\n            this.navbar.isExpanded$.next(false);\n          }\n        });\n      }\n\n    }\n  }\n}\n","<li [class.nav-item]=\"parentDropdown === null\" [class.dropdown]=\"(dropdowns.length > 0) && (parentDropdown === null)\" [class.dropend]=\"(dropdowns.length > 0) && (parentDropdown !== null)\">\n    <ng-content></ng-content>\n</li>"]}
|
|
104
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"navbar-item.component.js","sourceRoot":"","sources":["../../../../../../../libs/mintplayer-ng-bootstrap/navbar/src/navbar-item/navbar-item.component.ts","../../../../../../../libs/mintplayer-ng-bootstrap/navbar/src/navbar-item/navbar-item.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAkC,SAAS,EAAE,eAAe,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,EAAY,QAAQ,EAAE,WAAW,EAAE,SAAS,EAAoB,MAAM,eAAe,CAAC;AACzL,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AAEnD,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/B,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAC3C,OAAO,EAAE,iBAAiB,EAAE,MAAM,4BAA4B,CAAC;AAC/D,OAAO,EAAE,yBAAyB,EAAE,MAAM,8CAA8C,CAAC;;;;AAOzF,MAAM,OAAO,qBAAqB;IAEhC,YACU,MAAyB,EACjC,OAAmB;IACnB,8BAA8B;IACD,UAAkB,EACnC,cAAyC;QAJ7C,WAAM,GAAN,MAAM,CAAmB;QAGJ,eAAU,GAAV,UAAU,CAAQ;QASjD,gBAAW,GAAG,KAAK,CAAC;QACpB,cAAS,GAA6B,IAAI,CAAC;QACnC,eAAU,GAAG,IAAI,OAAO,EAAE,CAAC;QARjC,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;QACvB,IAAI,CAAC,cAAc,GAAG,cAAc,CAAC;IACvC,CAAC;IASD,qBAAqB;QACnB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;QAElE,IAAI,IAAI,CAAC,WAAW,EAAE;YACpB,IAAI,IAAI,CAAC,SAAS,EAAE;gBAClB,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC;gBAEhD,IAAI,gBAAgB,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE;oBACrC,IAAI,CAAC,SAAS,CAAC,IAAI,GAAG,cAAc,CAAC;iBACtC;gBAED,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,cAAc,CAAC,EAAE;oBAChD,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,cAAc,EAAE,GAAG,CAAC,CAAC;oBACjD,IAAI,CAAC,SAAS,CAAC,gBAAgB,CAAC,OAAO,EAAE,CAAC,EAAc,EAAE,EAAE;wBAC1D,EAAE,CAAC,cAAc,EAAE,CAAC;wBACpB,0DAA0D;wBAC1D,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,QAAQ,EAAE,EAAE;4BAClC,IAAI,CAAC,CAAC,QAAQ,CAAC,SAAS,GAAG,CAAC,QAAQ,CAAC,SAAS,CAAC,EAAE;gCAC/C,QAAQ,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE;oCACxC,KAAK,CAAC,SAAS,GAAG,KAAK,CAAC;gCAC1B,CAAC,CAAC,CAAC;6BACJ;iCAAM,IAAI,IAAI,CAAC,cAAc,EAAE;gCAC9B,wEAAwE;gCACxE,uDAAuD;gCACvD,2BAA2B;gCAC3B,gCAAgC;gCAEhC,+CAA+C;gCAC/C,+CAA+C;gCAC/C,kDAAkD;gCAClD,2CAA2C;gCAC3C,yBAAyB;gCACzB,iFAAiF;gCACjF,WAAW;gCACX,QAAQ;gCACN,wBAAwB;gCAE1B,MAAM;gCACN,iCAAiC;gCAEjC,IAAI,CAAC,MAAM,CAAC,YAAY;qCACrB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;qCAChC,SAAS,CAAC,CAAC,WAAW,EAAE,EAAE;oCACzB,QAAQ,CAAC,aAAa,GAAG,CAAC,WAAW,CAAC;gCACxC,CAAC,CAAC,CAAC;6BACN;wBACH,CAAC,CAAC,CAAC;wBACH,OAAO,KAAK,CAAC;oBACf,CAAC,CAAC,CAAC;iBACJ;aACF;SACF;aAAM;YAEL,0BAA0B;YAC1B,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,KAAK,CAAC,CAAC,IAAI,IAAI,CAAC,SAAS,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,cAAc,CAAC,EAAE;gBACnG,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,cAAc,EAAE,GAAG,CAAC,CAAC;gBACjD,IAAI,CAAC,SAAS,CAAC,gBAAgB,CAAC,OAAO,EAAE,CAAC,EAAc,EAAE,EAAE;oBAC1D,IAAI,CAAC,GAAG,IAAI,CAAC,cAAc,CAAC;oBAC5B,OAAO,CAAC,IAAI,CAAC,CAAC,SAAS,EAAE;wBACvB,CAAC,CAAC,SAAS,GAAG,KAAK,CAAC;wBACpB,CAAC,GAAG,CAAC,CAAC,cAAc,CAAC;qBACtB;oBACD,IAAI,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE;wBACzB,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;qBACrC;gBACH,CAAC,CAAC,CAAC;aACJ;SAEF;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC7B,CAAC;;kHA7FU,qBAAqB,6EAMtB,WAAW;sGANV,qBAAqB,mHAkBE,yBAAyB,iCC/B7D,0OAEK;2FDWQ,qBAAqB;kBALjC,SAAS;+BACE,gBAAgB;;0BAUvB,MAAM;2BAAC,WAAW;;0BAClB,QAAQ;4CAWmD,SAAS;sBAAtE,eAAe;uBAAC,UAAU,CAAC,GAAG,EAAE,CAAC,yBAAyB,CAAC","sourcesContent":["import { AfterContentChecked, OnDestroy, Component, ContentChildren, ElementRef, forwardRef, Inject, Injector, Optional, PLATFORM_ID, QueryList, ViewContainerRef } from '@angular/core';\nimport { isPlatformServer } from '@angular/common';\nimport { DomPortal } from '@angular/cdk/portal';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { BsNavbarComponent } from '../navbar/navbar.component';\nimport { BsNavbarDropdownComponent } from '../navbar-dropdown/navbar-dropdown.component';\n\n@Component({\n  selector: 'bs-navbar-item',\n  templateUrl: './navbar-item.component.html',\n  styleUrls: ['./navbar-item.component.scss']\n})\nexport class BsNavbarItemComponent implements AfterContentChecked, OnDestroy {\n\n  constructor(\n    private navbar: BsNavbarComponent,\n    element: ElementRef,\n    // private injector: Injector,\n    @Inject(PLATFORM_ID) private platformId: Object,\n    @Optional() parentDropdown: BsNavbarDropdownComponent,\n  ) {\n    this.element = element;\n    this.parentDropdown = parentDropdown;\n  }\n\n  element: ElementRef;\n  parentDropdown: BsNavbarDropdownComponent;\n  hasDropdown = false;\n  anchorTag: HTMLAnchorElement | null = null;\n  private destroyed$ = new Subject();\n  @ContentChildren(forwardRef(() => BsNavbarDropdownComponent)) dropdowns!: QueryList<BsNavbarDropdownComponent>;\n\n  ngAfterContentChecked() {\n    this.anchorTag = this.element.nativeElement.querySelector('li a');\n\n    if (this.hasDropdown) {\n      if (this.anchorTag) {\n        this.anchorTag.classList.add('dropdown-toggle');\n\n        if (isPlatformServer(this.platformId)) {\n          this.anchorTag.href = 'javascript:;';\n        }\n  \n        if (!this.anchorTag.getAttribute('close-init-b')) {\n          this.anchorTag.setAttribute('close-init-b', '1');\n          this.anchorTag.addEventListener('click', (ev: MouseEvent) => {\n            ev.preventDefault();\n            // Normally there should be only one dropdown in this list\n            this.dropdowns.forEach((dropdown) => {\n              if (!(dropdown.isVisible = !dropdown.isVisible)) {\n                dropdown.childDropdowns.forEach((child) => {\n                  child.isVisible = false;\n                });\n              } else if (this.parentDropdown) {\n                // import('@angular/cdk/overlay').then(({ OverlayModule, Overlay }) => {\n                //   const overlayService = this.injector.get(Overlay);\n                //   return overlayService;\n                // }).then((overlayService) => {\n\n                //   const p = new DomPortal(dropdown.element);\n                //   const overlayRef = overlayService.create({\n                //     positionStrategy: overlayService.position()\n                //       .flexibleConnectedTo(this.element)\n                //       .withPositions([\n                //         { originX: 'end', originY: 'top', overlayX: 'start', overlayY: 'top' }\n                //       ])\n                //   });\n                  // overlayRef.attach(p);\n\n                // });\n                // dropdown.showInOverlay = true;\n\n                this.navbar.isSmallMode$\n                  .pipe(takeUntil(this.destroyed$))\n                  .subscribe((isSmallMode) => {\n                    dropdown.showInOverlay = !isSmallMode;\n                  });\n              }\n            });\n            return false;\n          });\n        }\n      }\n    } else {\n\n      // Close if this is a link\n      if ((this.dropdowns.length === 0) && this.anchorTag && !this.anchorTag.getAttribute('close-init-a')) {\n        this.anchorTag.setAttribute('close-init-a', '1');\n        this.anchorTag.addEventListener('click', (ev: MouseEvent) => {\n          let d = this.parentDropdown;\n          while (d && d.autoclose) {\n            d.isVisible = false;\n            d = d.parentDropdown;\n          }\n          if (this.navbar.autoclose) {\n            this.navbar.isExpanded$.next(false);\n          }\n        });\n      }\n\n    }\n  }\n\n  ngOnDestroy() {\n    this.destroyed$.next(true);\n  }\n}\n","<li [class.nav-item]=\"parentDropdown === null\" [class.dropdown]=\"(dropdowns.length > 0) && (parentDropdown === null)\" [class.dropend]=\"(dropdowns.length > 0) && (parentDropdown !== null)\">\n    <ng-content></ng-content>\n</li>"]}
|
|
@@ -13,8 +13,8 @@ import { BsNavbarContentDirective } from './navbar-content/navbar-content.direct
|
|
|
13
13
|
import { BsNavbarBrandComponent } from './navbar-brand/navbar-brand.component';
|
|
14
14
|
import { BsExpandButtonDirective } from './expand-button/expand-button.directive';
|
|
15
15
|
import { BsNavbarTogglerComponent } from './navbar-toggler/navbar-toggler.component';
|
|
16
|
+
import { BsHasOverlayModule } from '@mintplayer/ng-bootstrap/has-overlay';
|
|
16
17
|
import * as i0 from "@angular/core";
|
|
17
|
-
// import { BsHasOverlayModule } from '@mintplayer/ng-bootstrap/has-overlay';
|
|
18
18
|
export class BsNavbarModule {
|
|
19
19
|
}
|
|
20
20
|
BsNavbarModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: BsNavbarModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
@@ -30,7 +30,8 @@ BsNavbarModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version:
|
|
|
30
30
|
BsNavbarTogglerComponent], imports: [CommonModule,
|
|
31
31
|
ClickOutsideModule,
|
|
32
32
|
BsUserAgentModule,
|
|
33
|
-
BsNoNoscriptModule
|
|
33
|
+
BsNoNoscriptModule,
|
|
34
|
+
BsHasOverlayModule], exports: [BsNavbarComponent,
|
|
34
35
|
BsNavbarNavComponent,
|
|
35
36
|
BsNavbarDropdownComponent,
|
|
36
37
|
BsNavbarItemComponent,
|
|
@@ -43,7 +44,8 @@ BsNavbarModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version:
|
|
|
43
44
|
BsNavbarModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: BsNavbarModule, imports: [CommonModule,
|
|
44
45
|
ClickOutsideModule,
|
|
45
46
|
BsUserAgentModule,
|
|
46
|
-
BsNoNoscriptModule
|
|
47
|
+
BsNoNoscriptModule,
|
|
48
|
+
BsHasOverlayModule] });
|
|
47
49
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: BsNavbarModule, decorators: [{
|
|
48
50
|
type: NgModule,
|
|
49
51
|
args: [{
|
|
@@ -64,7 +66,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImpor
|
|
|
64
66
|
ClickOutsideModule,
|
|
65
67
|
BsUserAgentModule,
|
|
66
68
|
BsNoNoscriptModule,
|
|
67
|
-
|
|
69
|
+
BsHasOverlayModule,
|
|
68
70
|
],
|
|
69
71
|
exports: [
|
|
70
72
|
BsNavbarComponent,
|
|
@@ -80,4 +82,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImpor
|
|
|
80
82
|
]
|
|
81
83
|
}]
|
|
82
84
|
}] });
|
|
83
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
85
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmF2YmFyLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvbWludHBsYXllci1uZy1ib290c3RyYXAvbmF2YmFyL3NyYy9uYXZiYXIubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHFDQUFxQyxDQUFDO0FBQ3hFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHNDQUFzQyxDQUFDO0FBQzFFLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQzlELE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBQ3pFLE9BQU8sRUFBRSx5QkFBeUIsRUFBRSxNQUFNLDZDQUE2QyxDQUFDO0FBQ3hGLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHFDQUFxQyxDQUFDO0FBQzVFLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLDZDQUE2QyxDQUFDO0FBQ3RGLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLCtCQUErQixDQUFDO0FBQ2pFLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLDJDQUEyQyxDQUFDO0FBQ3JGLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLHVDQUF1QyxDQUFDO0FBQy9FLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLHlDQUF5QyxDQUFDO0FBQ2xGLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLDJDQUEyQyxDQUFDO0FBQ3JGLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHNDQUFzQyxDQUFDOztBQXFDMUUsTUFBTSxPQUFPLGNBQWM7OzJHQUFkLGNBQWM7NEdBQWQsY0FBYyxpQkFqQ3ZCLGlCQUFpQjtRQUNqQixvQkFBb0I7UUFDcEIseUJBQXlCO1FBQ3pCLHFCQUFxQjtRQUVyQix1QkFBdUI7UUFDdkIsZ0JBQWdCO1FBQ2hCLHdCQUF3QjtRQUN4QixzQkFBc0I7UUFDdEIsdUJBQXVCO1FBQ3ZCLHdCQUF3QixhQUd4QixZQUFZO1FBQ1osa0JBQWtCO1FBQ2xCLGlCQUFpQjtRQUNqQixrQkFBa0I7UUFDbEIsa0JBQWtCLGFBR2xCLGlCQUFpQjtRQUNqQixvQkFBb0I7UUFDcEIseUJBQXlCO1FBQ3pCLHFCQUFxQjtRQUVyQix1QkFBdUI7UUFDdkIsZ0JBQWdCO1FBQ2hCLHdCQUF3QjtRQUN4QixzQkFBc0I7UUFDdEIsdUJBQXVCO1FBQ3ZCLHdCQUF3Qjs0R0FHZixjQUFjLFlBcEJ2QixZQUFZO1FBQ1osa0JBQWtCO1FBQ2xCLGlCQUFpQjtRQUNqQixrQkFBa0I7UUFDbEIsa0JBQWtCOzJGQWdCVCxjQUFjO2tCQW5DMUIsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUU7d0JBQ1osaUJBQWlCO3dCQUNqQixvQkFBb0I7d0JBQ3BCLHlCQUF5Qjt3QkFDekIscUJBQXFCO3dCQUVyQix1QkFBdUI7d0JBQ3ZCLGdCQUFnQjt3QkFDaEIsd0JBQXdCO3dCQUN4QixzQkFBc0I7d0JBQ3RCLHVCQUF1Qjt3QkFDdkIsd0JBQXdCO3FCQUN6QjtvQkFDRCxPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixrQkFBa0I7d0JBQ2xCLGlCQUFpQjt3QkFDakIsa0JBQWtCO3dCQUNsQixrQkFBa0I7cUJBQ25CO29CQUNELE9BQU8sRUFBRTt3QkFDUCxpQkFBaUI7d0JBQ2pCLG9CQUFvQjt3QkFDcEIseUJBQXlCO3dCQUN6QixxQkFBcUI7d0JBRXJCLHVCQUF1Qjt3QkFDdkIsZ0JBQWdCO3dCQUNoQix3QkFBd0I7d0JBQ3hCLHNCQUFzQjt3QkFDdEIsdUJBQXVCO3dCQUN2Qix3QkFBd0I7cUJBQ3pCO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBDbGlja091dHNpZGVNb2R1bGUgfSBmcm9tICdAbWludHBsYXllci9uZy1jbGljay1vdXRzaWRlJztcbmltcG9ydCB7IEJzVXNlckFnZW50TW9kdWxlIH0gZnJvbSAnQG1pbnRwbGF5ZXIvbmctYm9vdHN0cmFwL3VzZXItYWdlbnQnO1xuaW1wb3J0IHsgQnNOb05vc2NyaXB0TW9kdWxlIH0gZnJvbSAnQG1pbnRwbGF5ZXIvbmctYm9vdHN0cmFwL25vLW5vc2NyaXB0JztcbmltcG9ydCB7IEJzTmF2YmFyQ29tcG9uZW50IH0gZnJvbSAnLi9uYXZiYXIvbmF2YmFyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBCc05hdmJhck5hdkNvbXBvbmVudCB9IGZyb20gJy4vbmF2YmFyLW5hdi9uYXZiYXItbmF2LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBCc05hdmJhckRyb3Bkb3duQ29tcG9uZW50IH0gZnJvbSAnLi9uYXZiYXItZHJvcGRvd24vbmF2YmFyLWRyb3Bkb3duLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBCc05hdmJhckl0ZW1Db21wb25lbnQgfSBmcm9tICcuL25hdmJhci1pdGVtL25hdmJhci1pdGVtLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEcm9wZG93blRvZ2dsZURpcmVjdGl2ZSB9IGZyb20gJy4vZHJvcGRvd24tdG9nZ2xlL2Ryb3Bkb3duLXRvZ2dsZS5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgTmF2TGlua0RpcmVjdGl2ZSB9IGZyb20gJy4vbmF2LWxpbmsvbmF2LWxpbmsuZGlyZWN0aXZlJztcbmltcG9ydCB7IEJzTmF2YmFyQ29udGVudERpcmVjdGl2ZSB9IGZyb20gJy4vbmF2YmFyLWNvbnRlbnQvbmF2YmFyLWNvbnRlbnQuZGlyZWN0aXZlJztcbmltcG9ydCB7IEJzTmF2YmFyQnJhbmRDb21wb25lbnQgfSBmcm9tICcuL25hdmJhci1icmFuZC9uYXZiYXItYnJhbmQuY29tcG9uZW50JztcbmltcG9ydCB7IEJzRXhwYW5kQnV0dG9uRGlyZWN0aXZlIH0gZnJvbSAnLi9leHBhbmQtYnV0dG9uL2V4cGFuZC1idXR0b24uZGlyZWN0aXZlJztcbmltcG9ydCB7IEJzTmF2YmFyVG9nZ2xlckNvbXBvbmVudCB9IGZyb20gJy4vbmF2YmFyLXRvZ2dsZXIvbmF2YmFyLXRvZ2dsZXIuY29tcG9uZW50JztcbmltcG9ydCB7IEJzSGFzT3ZlcmxheU1vZHVsZSB9IGZyb20gJ0BtaW50cGxheWVyL25nLWJvb3RzdHJhcC9oYXMtb3ZlcmxheSc7XG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogW1xuICAgIEJzTmF2YmFyQ29tcG9uZW50LFxuICAgIEJzTmF2YmFyTmF2Q29tcG9uZW50LFxuICAgIEJzTmF2YmFyRHJvcGRvd25Db21wb25lbnQsXG4gICAgQnNOYXZiYXJJdGVtQ29tcG9uZW50LFxuXG4gICAgRHJvcGRvd25Ub2dnbGVEaXJlY3RpdmUsXG4gICAgTmF2TGlua0RpcmVjdGl2ZSxcbiAgICBCc05hdmJhckNvbnRlbnREaXJlY3RpdmUsXG4gICAgQnNOYXZiYXJCcmFuZENvbXBvbmVudCxcbiAgICBCc0V4cGFuZEJ1dHRvbkRpcmVjdGl2ZSxcbiAgICBCc05hdmJhclRvZ2dsZXJDb21wb25lbnQsXG4gIF0sXG4gIGltcG9ydHM6IFtcbiAgICBDb21tb25Nb2R1bGUsXG4gICAgQ2xpY2tPdXRzaWRlTW9kdWxlLFxuICAgIEJzVXNlckFnZW50TW9kdWxlLFxuICAgIEJzTm9Ob3NjcmlwdE1vZHVsZSxcbiAgICBCc0hhc092ZXJsYXlNb2R1bGUsXG4gIF0sXG4gIGV4cG9ydHM6IFtcbiAgICBCc05hdmJhckNvbXBvbmVudCxcbiAgICBCc05hdmJhck5hdkNvbXBvbmVudCxcbiAgICBCc05hdmJhckRyb3Bkb3duQ29tcG9uZW50LFxuICAgIEJzTmF2YmFySXRlbUNvbXBvbmVudCxcblxuICAgIERyb3Bkb3duVG9nZ2xlRGlyZWN0aXZlLFxuICAgIE5hdkxpbmtEaXJlY3RpdmUsXG4gICAgQnNOYXZiYXJDb250ZW50RGlyZWN0aXZlLFxuICAgIEJzTmF2YmFyQnJhbmRDb21wb25lbnQsXG4gICAgQnNFeHBhbmRCdXR0b25EaXJlY3RpdmUsXG4gICAgQnNOYXZiYXJUb2dnbGVyQ29tcG9uZW50LFxuICBdXG59KVxuZXhwb3J0IGNsYXNzIEJzTmF2YmFyTW9kdWxlIHsgfVxuIl19
|
|
@@ -11,6 +11,10 @@ import { BsNoNoscriptModule } from '@mintplayer/ng-bootstrap/no-noscript';
|
|
|
11
11
|
import { Color } from '@mintplayer/ng-bootstrap';
|
|
12
12
|
import { BehaviorSubject, Subject, map, combineLatest, filter, debounceTime, takeUntil, take } from 'rxjs';
|
|
13
13
|
import { SlideUpDownAnimation } from '@mintplayer/ng-animations';
|
|
14
|
+
import { takeUntil as takeUntil$1 } from 'rxjs/operators';
|
|
15
|
+
import { DomPortal } from '@angular/cdk/portal';
|
|
16
|
+
import * as i4 from '@mintplayer/ng-bootstrap/has-overlay';
|
|
17
|
+
import { BsHasOverlayModule } from '@mintplayer/ng-bootstrap/has-overlay';
|
|
14
18
|
|
|
15
19
|
class BsNavbarComponent {
|
|
16
20
|
constructor() {
|
|
@@ -209,13 +213,15 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImpor
|
|
|
209
213
|
}] } });
|
|
210
214
|
|
|
211
215
|
class BsNavbarItemComponent {
|
|
212
|
-
constructor(navbar, element,
|
|
216
|
+
constructor(navbar, element,
|
|
217
|
+
// private injector: Injector,
|
|
218
|
+
platformId, parentDropdown) {
|
|
213
219
|
this.navbar = navbar;
|
|
214
|
-
this.element = element;
|
|
215
|
-
this.injector = injector;
|
|
216
220
|
this.platformId = platformId;
|
|
217
221
|
this.hasDropdown = false;
|
|
218
222
|
this.anchorTag = null;
|
|
223
|
+
this.destroyed$ = new Subject();
|
|
224
|
+
this.element = element;
|
|
219
225
|
this.parentDropdown = parentDropdown;
|
|
220
226
|
}
|
|
221
227
|
ngAfterContentChecked() {
|
|
@@ -236,16 +242,28 @@ class BsNavbarItemComponent {
|
|
|
236
242
|
dropdown.childDropdowns.forEach((child) => {
|
|
237
243
|
child.isVisible = false;
|
|
238
244
|
});
|
|
239
|
-
|
|
245
|
+
}
|
|
246
|
+
else if (this.parentDropdown) {
|
|
240
247
|
// import('@angular/cdk/overlay').then(({ OverlayModule, Overlay }) => {
|
|
241
248
|
// const overlayService = this.injector.get(Overlay);
|
|
242
249
|
// return overlayService;
|
|
243
250
|
// }).then((overlayService) => {
|
|
244
251
|
// const p = new DomPortal(dropdown.element);
|
|
245
252
|
// const overlayRef = overlayService.create({
|
|
253
|
+
// positionStrategy: overlayService.position()
|
|
254
|
+
// .flexibleConnectedTo(this.element)
|
|
255
|
+
// .withPositions([
|
|
256
|
+
// { originX: 'end', originY: 'top', overlayX: 'start', overlayY: 'top' }
|
|
257
|
+
// ])
|
|
246
258
|
// });
|
|
247
|
-
//
|
|
259
|
+
// overlayRef.attach(p);
|
|
248
260
|
// });
|
|
261
|
+
// dropdown.showInOverlay = true;
|
|
262
|
+
this.navbar.isSmallMode$
|
|
263
|
+
.pipe(takeUntil$1(this.destroyed$))
|
|
264
|
+
.subscribe((isSmallMode) => {
|
|
265
|
+
dropdown.showInOverlay = !isSmallMode;
|
|
266
|
+
});
|
|
249
267
|
}
|
|
250
268
|
});
|
|
251
269
|
return false;
|
|
@@ -270,14 +288,17 @@ class BsNavbarItemComponent {
|
|
|
270
288
|
}
|
|
271
289
|
}
|
|
272
290
|
}
|
|
291
|
+
ngOnDestroy() {
|
|
292
|
+
this.destroyed$.next(true);
|
|
293
|
+
}
|
|
273
294
|
}
|
|
274
|
-
BsNavbarItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: BsNavbarItemComponent, deps: [{ token: BsNavbarComponent }, { token: i0.ElementRef }, { token:
|
|
295
|
+
BsNavbarItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: BsNavbarItemComponent, deps: [{ token: BsNavbarComponent }, { token: i0.ElementRef }, { token: PLATFORM_ID }, { token: BsNavbarDropdownComponent, optional: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
275
296
|
BsNavbarItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.0", type: BsNavbarItemComponent, selector: "bs-navbar-item", queries: [{ propertyName: "dropdowns", predicate: i0.forwardRef(function () { return BsNavbarDropdownComponent; }) }], ngImport: i0, template: "<li [class.nav-item]=\"parentDropdown === null\" [class.dropdown]=\"(dropdowns.length > 0) && (parentDropdown === null)\" [class.dropend]=\"(dropdowns.length > 0) && (parentDropdown !== null)\">\n <ng-content></ng-content>\n</li>", styles: ["li.dropend ::ng-deep a.dropdown-toggle{padding-right:1.5rem}li.dropend ::ng-deep a.dropdown-toggle:after{position:absolute;right:.5rem;top:.75rem}\n"] });
|
|
276
297
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: BsNavbarItemComponent, decorators: [{
|
|
277
298
|
type: Component,
|
|
278
299
|
args: [{ selector: 'bs-navbar-item', template: "<li [class.nav-item]=\"parentDropdown === null\" [class.dropdown]=\"(dropdowns.length > 0) && (parentDropdown === null)\" [class.dropend]=\"(dropdowns.length > 0) && (parentDropdown !== null)\">\n <ng-content></ng-content>\n</li>", styles: ["li.dropend ::ng-deep a.dropdown-toggle{padding-right:1.5rem}li.dropend ::ng-deep a.dropdown-toggle:after{position:absolute;right:.5rem;top:.75rem}\n"] }]
|
|
279
300
|
}], ctorParameters: function () {
|
|
280
|
-
return [{ type: BsNavbarComponent }, { type: i0.ElementRef }, { type:
|
|
301
|
+
return [{ type: BsNavbarComponent }, { type: i0.ElementRef }, { type: Object, decorators: [{
|
|
281
302
|
type: Inject,
|
|
282
303
|
args: [PLATFORM_ID]
|
|
283
304
|
}] }, { type: BsNavbarDropdownComponent, decorators: [{
|
|
@@ -289,10 +310,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImpor
|
|
|
289
310
|
}] } });
|
|
290
311
|
|
|
291
312
|
class BsNavbarDropdownComponent {
|
|
292
|
-
constructor(navbar, parentDropdown, navbarItem, element, document, platformId) {
|
|
313
|
+
constructor(navbar, parentDropdown, navbarItem, element, injector, document, platformId) {
|
|
293
314
|
this.navbar = navbar;
|
|
294
315
|
this.element = element;
|
|
316
|
+
this.injector = injector;
|
|
295
317
|
this.document = document;
|
|
318
|
+
this.isAttached = false;
|
|
296
319
|
this.autoclose = true;
|
|
297
320
|
this.destroyed$ = new Subject();
|
|
298
321
|
this.isBrowser = false;
|
|
@@ -304,6 +327,7 @@ class BsNavbarDropdownComponent {
|
|
|
304
327
|
this.isBrowser = !isPlatformServer(platformId);
|
|
305
328
|
this.isVisible$.pipe(takeUntil(this.destroyed$)).subscribe((isVisible) => {
|
|
306
329
|
if (isVisible) {
|
|
330
|
+
setTimeout(() => this.overlay && this.overlay.updatePosition(), 20);
|
|
307
331
|
this.topPos$.next(this.element.nativeElement.offsetTop);
|
|
308
332
|
}
|
|
309
333
|
else {
|
|
@@ -327,10 +351,48 @@ class BsNavbarDropdownComponent {
|
|
|
327
351
|
if (isSmallMode) {
|
|
328
352
|
return null;
|
|
329
353
|
}
|
|
354
|
+
else if (isPlatformServer(platformId)) {
|
|
355
|
+
// Javascript disabled
|
|
356
|
+
// Only apply max-height to the top-dropdown
|
|
357
|
+
return parentDropdown ? null : maxHeight;
|
|
358
|
+
}
|
|
330
359
|
else {
|
|
360
|
+
// If javascript enabled
|
|
331
361
|
return maxHeight;
|
|
332
362
|
}
|
|
333
363
|
}));
|
|
364
|
+
if (!!parentDropdown) {
|
|
365
|
+
// Setup overlay
|
|
366
|
+
import('@angular/cdk/overlay').then(({ OverlayModule, Overlay }) => {
|
|
367
|
+
const overlayService = this.injector.get(Overlay);
|
|
368
|
+
return overlayService;
|
|
369
|
+
}).then((overlayService) => {
|
|
370
|
+
this.domPortal = new DomPortal(this.element);
|
|
371
|
+
this.overlay = overlayService.create({
|
|
372
|
+
positionStrategy: overlayService.position()
|
|
373
|
+
.flexibleConnectedTo(this.navbarItem.element)
|
|
374
|
+
.withPositions([
|
|
375
|
+
{ originX: 'end', originY: 'top', overlayX: 'start', overlayY: 'top', offsetX: -7, offsetY: -9 }
|
|
376
|
+
])
|
|
377
|
+
});
|
|
378
|
+
// For some reason we have to trigger this from the BsDropdownItem
|
|
379
|
+
// this.showInOverlay = true;
|
|
380
|
+
});
|
|
381
|
+
}
|
|
382
|
+
}
|
|
383
|
+
set showInOverlay(value) {
|
|
384
|
+
if (this.overlay && this.domPortal) {
|
|
385
|
+
console.log('showInOverlay', value);
|
|
386
|
+
// if (value && !this.overlay.hasAttached()) {
|
|
387
|
+
if (value && !this.isAttached) {
|
|
388
|
+
this.overlay.attach(this.domPortal);
|
|
389
|
+
this.isAttached = true;
|
|
390
|
+
}
|
|
391
|
+
if (!value && this.isAttached) {
|
|
392
|
+
this.overlay.detach();
|
|
393
|
+
this.isAttached = false;
|
|
394
|
+
}
|
|
395
|
+
}
|
|
334
396
|
}
|
|
335
397
|
get isVisible() {
|
|
336
398
|
return this.isVisible$.value;
|
|
@@ -346,11 +408,11 @@ class BsNavbarDropdownComponent {
|
|
|
346
408
|
this.destroyed$.next(true);
|
|
347
409
|
}
|
|
348
410
|
}
|
|
349
|
-
BsNavbarDropdownComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: BsNavbarDropdownComponent, deps: [{ token: BsNavbarComponent }, { token: BsNavbarDropdownComponent, host: true, optional: true, skipSelf: true }, { token: forwardRef(() => BsNavbarItemComponent), host: true }, { token: i0.ElementRef }, { token: DOCUMENT }, { token: PLATFORM_ID }], target: i0.ɵɵFactoryTarget.Component });
|
|
350
|
-
BsNavbarDropdownComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.0", type: BsNavbarDropdownComponent, selector: "bs-navbar-dropdown", inputs: { autoclose: "autoclose" }, queries: [{ propertyName: "childDropdowns", predicate: i0.forwardRef(function () { return BsNavbarDropdownComponent; }), descendants: true }], viewQueries: [{ propertyName: "dropdownElement", first: true, predicate: ["dd"], descendants: true }], ngImport: i0, template: "
|
|
411
|
+
BsNavbarDropdownComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: BsNavbarDropdownComponent, deps: [{ token: BsNavbarComponent }, { token: BsNavbarDropdownComponent, host: true, optional: true, skipSelf: true }, { token: forwardRef(() => BsNavbarItemComponent), host: true }, { token: i0.ElementRef }, { token: i0.Injector }, { token: DOCUMENT }, { token: PLATFORM_ID }], target: i0.ɵɵFactoryTarget.Component });
|
|
412
|
+
BsNavbarDropdownComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.0", type: BsNavbarDropdownComponent, selector: "bs-navbar-dropdown", inputs: { autoclose: "autoclose" }, queries: [{ propertyName: "childDropdowns", predicate: i0.forwardRef(function () { return BsNavbarDropdownComponent; }), descendants: true }], viewQueries: [{ propertyName: "dropdownElement", first: true, predicate: ["dd"], descendants: true }], ngImport: i0, template: "<bs-has-overlay></bs-has-overlay>\n<ul #dd class=\"dropdown-menu\" [class.show]=\"isVisible$ | async\" [class.submenu]=\"!!parentDropdown\" [class.overflow-y-auto]=\"isBrowser\" [style.max-height]=\"maxHeightOrNull$ | async\" bsNoNoscript (clickOutside)=\"isVisible = false\" [exclude]=\"elementsToExclude\" aria-labelledby=\"navbarDropdown\">\n <ng-content></ng-content>\n</ul>\n\n<!-- \n - Working demo: https://codepen.io/agop/pen/VwwMGR\n - Location must be set through javascript\n - bsNoScript => If noscript, 2nd-level submenus must be shown inside the 1st-level submenu\n -->\n <!-- \n - Another option: https://stackblitz.com/edit/web-platform-vmsr4l?file=index.html\n - But this doesn't seem to work here\n -->", styles: [".submenu:not(.noscript){margin:0 .5rem!important}.submenu.noscript{margin:0 .5rem;position:initial!important}:not(.submenu).noscript{max-height:calc(100vh - 100% - 1rem);overflow-y:auto}.overflow-y-auto{overflow-y:auto}\n"], dependencies: [{ kind: "directive", type: i2$1.ClickOutsideDirective, selector: "[clickOutside]", inputs: ["clickOutsideEnabled", "attachOutsideOnClick", "delayClickOutsideInit", "emitOnBlur", "exclude", "excludeBeforeClick", "clickOutsideEvents"], outputs: ["clickOutside"] }, { kind: "directive", type: i3.BsNoNoscriptDirective, selector: "[bsNoNoscript]" }, { kind: "component", type: i4.BsHasOverlayComponent, selector: "bs-has-overlay" }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }] });
|
|
351
413
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: BsNavbarDropdownComponent, decorators: [{
|
|
352
414
|
type: Component,
|
|
353
|
-
args: [{ selector: 'bs-navbar-dropdown', template: "
|
|
415
|
+
args: [{ selector: 'bs-navbar-dropdown', template: "<bs-has-overlay></bs-has-overlay>\n<ul #dd class=\"dropdown-menu\" [class.show]=\"isVisible$ | async\" [class.submenu]=\"!!parentDropdown\" [class.overflow-y-auto]=\"isBrowser\" [style.max-height]=\"maxHeightOrNull$ | async\" bsNoNoscript (clickOutside)=\"isVisible = false\" [exclude]=\"elementsToExclude\" aria-labelledby=\"navbarDropdown\">\n <ng-content></ng-content>\n</ul>\n\n<!-- \n - Working demo: https://codepen.io/agop/pen/VwwMGR\n - Location must be set through javascript\n - bsNoScript => If noscript, 2nd-level submenus must be shown inside the 1st-level submenu\n -->\n <!-- \n - Another option: https://stackblitz.com/edit/web-platform-vmsr4l?file=index.html\n - But this doesn't seem to work here\n -->", styles: [".submenu:not(.noscript){margin:0 .5rem!important}.submenu.noscript{margin:0 .5rem;position:initial!important}:not(.submenu).noscript{max-height:calc(100vh - 100% - 1rem);overflow-y:auto}.overflow-y-auto{overflow-y:auto}\n"] }]
|
|
354
416
|
}], ctorParameters: function () {
|
|
355
417
|
return [{ type: BsNavbarComponent }, { type: BsNavbarDropdownComponent, decorators: [{
|
|
356
418
|
type: SkipSelf
|
|
@@ -363,7 +425,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImpor
|
|
|
363
425
|
}, {
|
|
364
426
|
type: Inject,
|
|
365
427
|
args: [forwardRef(() => BsNavbarItemComponent)]
|
|
366
|
-
}] }, { type: i0.ElementRef }, { type: Document, decorators: [{
|
|
428
|
+
}] }, { type: i0.ElementRef }, { type: i0.Injector }, { type: Document, decorators: [{
|
|
367
429
|
type: Inject,
|
|
368
430
|
args: [DOCUMENT]
|
|
369
431
|
}] }, { type: Object, decorators: [{
|
|
@@ -592,7 +654,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImpor
|
|
|
592
654
|
args: ['click', ['$event']]
|
|
593
655
|
}] } });
|
|
594
656
|
|
|
595
|
-
// import { BsHasOverlayModule } from '@mintplayer/ng-bootstrap/has-overlay';
|
|
596
657
|
class BsNavbarModule {
|
|
597
658
|
}
|
|
598
659
|
BsNavbarModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: BsNavbarModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
@@ -608,7 +669,8 @@ BsNavbarModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version:
|
|
|
608
669
|
BsNavbarTogglerComponent], imports: [CommonModule,
|
|
609
670
|
ClickOutsideModule,
|
|
610
671
|
BsUserAgentModule,
|
|
611
|
-
BsNoNoscriptModule
|
|
672
|
+
BsNoNoscriptModule,
|
|
673
|
+
BsHasOverlayModule], exports: [BsNavbarComponent,
|
|
612
674
|
BsNavbarNavComponent,
|
|
613
675
|
BsNavbarDropdownComponent,
|
|
614
676
|
BsNavbarItemComponent,
|
|
@@ -621,7 +683,8 @@ BsNavbarModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version:
|
|
|
621
683
|
BsNavbarModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: BsNavbarModule, imports: [CommonModule,
|
|
622
684
|
ClickOutsideModule,
|
|
623
685
|
BsUserAgentModule,
|
|
624
|
-
BsNoNoscriptModule
|
|
686
|
+
BsNoNoscriptModule,
|
|
687
|
+
BsHasOverlayModule] });
|
|
625
688
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: BsNavbarModule, decorators: [{
|
|
626
689
|
type: NgModule,
|
|
627
690
|
args: [{
|
|
@@ -642,7 +705,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImpor
|
|
|
642
705
|
ClickOutsideModule,
|
|
643
706
|
BsUserAgentModule,
|
|
644
707
|
BsNoNoscriptModule,
|
|
645
|
-
|
|
708
|
+
BsHasOverlayModule,
|
|
646
709
|
],
|
|
647
710
|
exports: [
|
|
648
711
|
BsNavbarComponent,
|