@mintplayer/ng-bootstrap 13.4.1 → 13.4.2
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/index.mjs +2 -1
- package/esm2020/lib/components/navbar/navbar-toggler/navbar-toggler.component.mjs +2 -2
- package/esm2020/lib/components/offcanvas/components/offcanvas/offcanvas.component.mjs +16 -14
- package/esm2020/lib/components/offcanvas/components/offcanvas-host/offcanvas-host.component.mjs +15 -15
- package/esm2020/lib/components/offcanvas/directives/offcanvas-close/offcanvas-close.directive.mjs +2 -2
- package/esm2020/lib/types/index.mjs +2 -0
- package/esm2020/lib/types/view-state.type.mjs +2 -0
- package/fesm2015/mintplayer-ng-bootstrap.mjs +30 -28
- package/fesm2015/mintplayer-ng-bootstrap.mjs.map +1 -1
- package/fesm2020/mintplayer-ng-bootstrap.mjs +30 -28
- package/fesm2020/mintplayer-ng-bootstrap.mjs.map +1 -1
- package/index.d.ts +1 -0
- package/lib/components/navbar/navbar-toggler/navbar-toggler.component.d.ts +5 -4
- package/lib/components/offcanvas/components/offcanvas/offcanvas.component.d.ts +7 -5
- package/lib/components/offcanvas/components/offcanvas-host/offcanvas-host.component.d.ts +6 -5
- package/lib/types/index.d.ts +1 -0
- package/lib/types/view-state.type.d.ts +1 -0
- package/package.json +1 -1
package/esm2020/index.mjs
CHANGED
|
@@ -2,4 +2,5 @@ export * from './lib/components';
|
|
|
2
2
|
export * from './lib/enums';
|
|
3
3
|
export * from './lib/interfaces';
|
|
4
4
|
export * from './lib/pipes';
|
|
5
|
-
|
|
5
|
+
export * from './lib/types';
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9saWJzL21pbnRwbGF5ZXItbmctYm9vdHN0cmFwL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsYUFBYSxDQUFDO0FBQzVCLGNBQWMsa0JBQWtCLENBQUM7QUFDakMsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxhQUFhLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2VudW1zJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ludGVyZmFjZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcGlwZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdHlwZXMnOyJdfQ==
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Component, EventEmitter, HostListener, Input, Output
|
|
1
|
+
import { Component, EventEmitter, HostListener, Input, Output } from '@angular/core';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
3
|
import * as i1 from "@angular/common";
|
|
4
4
|
export class BsNavbarTogglerComponent {
|
|
@@ -44,4 +44,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.6", ngImpor
|
|
|
44
44
|
type: HostListener,
|
|
45
45
|
args: ['click', ['$event']]
|
|
46
46
|
}] } });
|
|
47
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
47
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmF2YmFyLXRvZ2dsZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9taW50cGxheWVyLW5nLWJvb3RzdHJhcC9zcmMvbGliL2NvbXBvbmVudHMvbmF2YmFyL25hdmJhci10b2dnbGVyL25hdmJhci10b2dnbGVyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvbWludHBsYXllci1uZy1ib290c3RyYXAvc3JjL2xpYi9jb21wb25lbnRzL25hdmJhci9uYXZiYXItdG9nZ2xlci9uYXZiYXItdG9nZ2xlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQzs7O0FBUXJGLE1BQU0sT0FBTyx3QkFBd0I7SUFMckM7UUFNRSxlQUFlO1FBQ2YsV0FBTSxHQUFnQixRQUFRLENBQUM7UUFDZCxnQkFBVyxHQUFHLElBQUksWUFBWSxFQUFlLENBQUM7UUFRL0QsWUFBWTtRQUVJLGtCQUFhLEdBQUcsSUFBSSxDQUFDO0tBZXRDO0lBeEJDLElBQVcsS0FBSztRQUNkLE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQztJQUNyQixDQUFDO0lBQ0QsSUFBb0IsS0FBSyxDQUFDLEtBQWtCO1FBQzFDLElBQUksQ0FBQyxNQUFNLEdBQUcsS0FBSyxDQUFDO1FBQ3BCLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUNyQyxDQUFDO0lBTUQsV0FBVyxDQUFDLEVBQWM7UUFDeEIsSUFBSSxJQUFJLENBQUMsYUFBYSxFQUFFO1lBQ3RCLFFBQVEsSUFBSSxDQUFDLE1BQU0sRUFBRTtnQkFDbkIsS0FBSyxNQUFNO29CQUNULElBQUksQ0FBQyxLQUFLLEdBQUcsUUFBUSxDQUFDO29CQUN0QixNQUFNO2dCQUNSO29CQUNFLElBQUksQ0FBQyxLQUFLLEdBQUcsTUFBTSxDQUFDO29CQUNwQixNQUFNO2FBQ1Q7U0FDRjtJQUNILENBQUM7O3FIQTNCVSx3QkFBd0I7eUdBQXhCLHdCQUF3Qix1TkNSckMsMEhBSU07MkZESU8sd0JBQXdCO2tCQUxwQyxTQUFTOytCQUNFLG1CQUFtQjs4QkFPWixXQUFXO3NCQUEzQixNQUFNO2dCQUlhLEtBQUs7c0JBQXhCLEtBQUs7Z0JBTVUsYUFBYTtzQkFBNUIsS0FBSztnQkFHTixXQUFXO3NCQURWLFlBQVk7dUJBQUMsT0FBTyxFQUFFLENBQUMsUUFBUSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIEhvc3RMaXN0ZW5lciwgSW5wdXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQnNWaWV3U3RhdGUgfSBmcm9tICcuLi8uLi8uLi90eXBlcy92aWV3LXN0YXRlLnR5cGUnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdicy1uYXZiYXItdG9nZ2xlcicsXG4gIHRlbXBsYXRlVXJsOiAnLi9uYXZiYXItdG9nZ2xlci5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL25hdmJhci10b2dnbGVyLmNvbXBvbmVudC5zY3NzJ10sXG59KVxuZXhwb3J0IGNsYXNzIEJzTmF2YmFyVG9nZ2xlckNvbXBvbmVudCB7XG4gIC8vI3JlZ2lvbiBTdGF0ZVxuICBfc3RhdGU6IEJzVmlld1N0YXRlID0gJ2Nsb3NlZCc7XG4gIEBPdXRwdXQoKSBwdWJsaWMgc3RhdGVDaGFuZ2UgPSBuZXcgRXZlbnRFbWl0dGVyPEJzVmlld1N0YXRlPigpO1xuICBwdWJsaWMgZ2V0IHN0YXRlKCkge1xuICAgIHJldHVybiB0aGlzLl9zdGF0ZTtcbiAgfVxuICBASW5wdXQoKSBwdWJsaWMgc2V0IHN0YXRlKHZhbHVlOiBCc1ZpZXdTdGF0ZSkge1xuICAgIHRoaXMuX3N0YXRlID0gdmFsdWU7XG4gICAgdGhpcy5zdGF0ZUNoYW5nZS5lbWl0KHRoaXMuX3N0YXRlKTtcbiAgfVxuICAvLyNlbmRyZWdpb25cblxuICBASW5wdXQoKSBwdWJsaWMgdG9nZ2xlT25DbGljayA9IHRydWU7XG5cbiAgQEhvc3RMaXN0ZW5lcignY2xpY2snLCBbJyRldmVudCddKVxuICB0b2dnbGVTdGF0ZShldjogTW91c2VFdmVudCkge1xuICAgIGlmICh0aGlzLnRvZ2dsZU9uQ2xpY2spIHtcbiAgICAgIHN3aXRjaCAodGhpcy5fc3RhdGUpIHtcbiAgICAgICAgY2FzZSAnb3Blbic6XG4gICAgICAgICAgdGhpcy5zdGF0ZSA9ICdjbG9zZWQnO1xuICAgICAgICAgIGJyZWFrO1xuICAgICAgICBkZWZhdWx0OlxuICAgICAgICAgIHRoaXMuc3RhdGUgPSAnb3Blbic7XG4gICAgICAgICAgYnJlYWs7XG4gICAgICB9XG4gICAgfVxuICB9XG59XG4iLCI8ZGl2IGNsYXNzPVwibmF2YmFyLXRvZ2dsZXIgZmxvYXQtbGVmdFwiIFtuZ0NsYXNzXT1cInN0YXRlXCI+XG4gICAgPGRpdj48L2Rpdj5cbiAgICA8ZGl2PjwvZGl2PlxuICAgIDxkaXY+PC9kaXY+XG48L2Rpdj4iXX0=
|
|
@@ -16,13 +16,13 @@ export class BsOffcanvasComponent {
|
|
|
16
16
|
//#region Size
|
|
17
17
|
this.size$ = new BehaviorSubject(null);
|
|
18
18
|
//#endregion
|
|
19
|
-
//#region
|
|
20
|
-
this.
|
|
21
|
-
this.
|
|
19
|
+
//#region State
|
|
20
|
+
this.state$ = new BehaviorSubject('closed');
|
|
21
|
+
this.stateChange = new EventEmitter();
|
|
22
22
|
//#endregion
|
|
23
23
|
this.backdropClick = new EventEmitter();
|
|
24
24
|
this.contentTemplate = contentTemplate;
|
|
25
|
-
this.visibility$ = this.
|
|
25
|
+
this.visibility$ = this.state$
|
|
26
26
|
.pipe(delayWhen((val, i) => val ? of(0) : interval(300)))
|
|
27
27
|
.pipe(map((val) => val ? 'visible' : 'hidden'));
|
|
28
28
|
this.position$
|
|
@@ -50,8 +50,10 @@ export class BsOffcanvasComponent {
|
|
|
50
50
|
return null;
|
|
51
51
|
}
|
|
52
52
|
}));
|
|
53
|
-
this.showBackdrop$ = combineLatest([this.hasBackdrop$, this.
|
|
54
|
-
.pipe(map(([hasBackdrop,
|
|
53
|
+
this.showBackdrop$ = combineLatest([this.hasBackdrop$, this.state$])
|
|
54
|
+
.pipe(map(([hasBackdrop, state]) => hasBackdrop && (state === 'open')));
|
|
55
|
+
this.show$ = this.state$
|
|
56
|
+
.pipe(map((state) => state === 'open'));
|
|
55
57
|
}
|
|
56
58
|
set position(value) {
|
|
57
59
|
this.position$.next(value);
|
|
@@ -65,11 +67,11 @@ export class BsOffcanvasComponent {
|
|
|
65
67
|
get size() {
|
|
66
68
|
return this.size$.value;
|
|
67
69
|
}
|
|
68
|
-
set
|
|
69
|
-
this.
|
|
70
|
+
set state(value) {
|
|
71
|
+
this.state$.next(value);
|
|
70
72
|
}
|
|
71
|
-
get
|
|
72
|
-
return this.
|
|
73
|
+
get state() {
|
|
74
|
+
return this.state$.value;
|
|
73
75
|
}
|
|
74
76
|
onBackdropClick(ev) {
|
|
75
77
|
console.log(1);
|
|
@@ -80,7 +82,7 @@ export class BsOffcanvasComponent {
|
|
|
80
82
|
}
|
|
81
83
|
}
|
|
82
84
|
BsOffcanvasComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.6", ngImport: i0, type: BsOffcanvasComponent, deps: [{ token: OFFCANVAS_CONTENT }], target: i0.ɵɵFactoryTarget.Component });
|
|
83
|
-
BsOffcanvasComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.6", type: BsOffcanvasComponent, selector: "bs-offcanvas-holder", inputs: { position: "position", size: "size",
|
|
85
|
+
BsOffcanvasComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.6", type: BsOffcanvasComponent, selector: "bs-offcanvas-holder", inputs: { position: "position", size: "size", state: "state" }, outputs: { stateChange: "stateChange", backdropClick: "backdropClick" }, ngImport: i0, template: "<div [@fadeInOut]=\"{value: ':leave', params: {duration: '300ms'} }\" *ngIf=\"showBackdrop$ | async\">\n <div class=\"modal-backdrop show\" (click)=\"onBackdropClick($event)\"></div>\n</div>\n\n<div class=\"offcanvas overflow-hidden\"\n [class.show]=\"show$ | async\"\n [class.disable-transition]=\"disableTransition$ | async\"\n [class]=\"offcanvasClass$ | async\"\n [style.height.px]=\"height$ | async\"\n [style.width.px]=\"width$ | async\">\n <ng-container *ngTemplateOutlet=\"contentTemplate\"></ng-container>\n</div>", styles: [".offcanvas.oc-max-width{max-width:calc(100% - 40px)}.offcanvas.oc-max-height{max-height:calc(100% - 40px)}.modal-backdrop{z-index:1040}.offcanvas{visibility:unset}.offcanvas.disable-transition{transition:none}.offcanvas.offcanvas-top{height:auto;bottom:unset}.offcanvas.offcanvas-bottom{height:auto;top:unset}\n"], directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }], pipes: { "async": i1.AsyncPipe }, animations: [FadeInOutAnimation] });
|
|
84
86
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.6", ngImport: i0, type: BsOffcanvasComponent, decorators: [{
|
|
85
87
|
type: Component,
|
|
86
88
|
args: [{ selector: 'bs-offcanvas-holder', animations: [FadeInOutAnimation], template: "<div [@fadeInOut]=\"{value: ':leave', params: {duration: '300ms'} }\" *ngIf=\"showBackdrop$ | async\">\n <div class=\"modal-backdrop show\" (click)=\"onBackdropClick($event)\"></div>\n</div>\n\n<div class=\"offcanvas overflow-hidden\"\n [class.show]=\"show$ | async\"\n [class.disable-transition]=\"disableTransition$ | async\"\n [class]=\"offcanvasClass$ | async\"\n [style.height.px]=\"height$ | async\"\n [style.width.px]=\"width$ | async\">\n <ng-container *ngTemplateOutlet=\"contentTemplate\"></ng-container>\n</div>", styles: [".offcanvas.oc-max-width{max-width:calc(100% - 40px)}.offcanvas.oc-max-height{max-height:calc(100% - 40px)}.modal-backdrop{z-index:1040}.offcanvas{visibility:unset}.offcanvas.disable-transition{transition:none}.offcanvas.offcanvas-top{height:auto;bottom:unset}.offcanvas.offcanvas-bottom{height:auto;top:unset}\n"] }]
|
|
@@ -91,11 +93,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.6", ngImpor
|
|
|
91
93
|
type: Input
|
|
92
94
|
}], size: [{
|
|
93
95
|
type: Input
|
|
94
|
-
}],
|
|
96
|
+
}], stateChange: [{
|
|
95
97
|
type: Output
|
|
96
|
-
}],
|
|
98
|
+
}], state: [{
|
|
97
99
|
type: Input
|
|
98
100
|
}], backdropClick: [{
|
|
99
101
|
type: Output
|
|
100
102
|
}] } });
|
|
101
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"offcanvas.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/mintplayer-ng-bootstrap/src/lib/components/offcanvas/components/offcanvas/offcanvas.component.ts","../../../../../../../../../libs/mintplayer-ng-bootstrap/src/lib/components/offcanvas/components/offcanvas/offcanvas.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,EAAE,KAAK,EAAa,MAAM,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AACvG,OAAO,EAAE,eAAe,EAAE,aAAa,EAAE,SAAS,EAAE,QAAQ,EAAE,GAAG,EAAc,EAAE,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AACpH,OAAO,EAAE,kBAAkB,EAAE,MAAM,2BAA2B,CAAC;AAE/D,OAAO,EAAE,iBAAiB,EAAE,MAAM,4CAA4C,CAAC;;;AAQ/E,MAAM,OAAO,oBAAoB;IAE/B,YAAuC,eAAiC;QAuCxE,eAAU,GAAG,IAAI,OAAO,EAAE,CAAC;QAE3B,uBAAkB,GAAG,IAAI,eAAe,CAAU,KAAK,CAAC,CAAC;QACzD,oBAAe,GAAG,IAAI,eAAe,CAAgB,IAAI,CAAC,CAAC;QAG3D,iBAAY,GAAG,IAAI,eAAe,CAAU,KAAK,CAAC,CAAC;QAGnD,kBAAkB;QAClB,cAAS,GAAG,IAAI,eAAe,CAAoB,QAAQ,CAAC,CAAC;QAO7D,YAAY;QAEZ,cAAc;QACd,UAAK,GAAG,IAAI,eAAe,CAAgB,IAAI,CAAC,CAAC;QAOjD,YAAY;QAEZ,cAAc;QACd,UAAK,GAAG,IAAI,eAAe,CAAU,KAAK,CAAC,CAAC;QAC3B,eAAU,GAAG,IAAI,YAAY,EAAW,CAAC;QAO1D,YAAY;QAEF,kBAAa,GAAG,IAAI,YAAY,EAAc,CAAC;QA9EvD,IAAI,CAAC,eAAe,GAAG,eAAe,CAAC;QAEvC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,KAAK;aAC1B,IAAI,CAAC,SAAS,CAAC,CAAC,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC;aACxD,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC;QAElD,IAAI,CAAC,SAAS;aACX,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;aAChC,SAAS,CAAC,CAAC,QAAQ,EAAE,EAAE;YACtB,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACnC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,aAAa,QAAQ,EAAE,CAAC,CAAC;YACnD,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;QACxD,CAAC,CAAC,CAAC;QAEL,IAAI,CAAC,MAAM,GAAG,aAAa,CAAC,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;aACtD,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,QAAQ,EAAE,IAAI,CAAC,EAAE,EAAE;YAC7B,IAAI,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE;gBACvC,OAAO,IAAI,CAAC;aACb;iBAAM;gBACL,OAAO,IAAI,CAAC;aACb;QACH,CAAC,CAAC,CAAC,CAAC;QAEN,IAAI,CAAC,OAAO,GAAG,aAAa,CAAC,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;aACvD,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,QAAQ,EAAE,IAAI,CAAC,EAAE,EAAE;YAC7B,IAAI,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE;gBACxC,OAAO,IAAI,CAAC;aACb;iBAAM;gBACL,OAAO,IAAI,CAAC;aACb;QACH,CAAC,CAAC,CAAC,CAAC;QAEN,IAAI,CAAC,aAAa,GAAG,aAAa,CAAC,CAAC,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;aAChE,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,WAAW,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC,WAAW,IAAI,IAAI,CAAC,CAAC,CAAC;IAC7D,CAAC;IAeD,IAAoB,QAAQ,CAAC,KAAwB;QACnD,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC7B,CAAC;IACD,IAAW,QAAQ;QACjB,OAAO,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC;IAC9B,CAAC;IAKD,IAAoB,IAAI,CAAC,KAAoB;QAC3C,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACzB,CAAC;IACD,IAAW,IAAI;QACb,OAAO,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC;IAC1B,CAAC;IAMD,IAAoB,IAAI,CAAC,KAAc;QACrC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACzB,CAAC;IACD,IAAW,IAAI;QACb,OAAO,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC;IAC1B,CAAC;IAID,eAAe,CAAC,EAAc;QAC5B,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QACf,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAC9B,CAAC;IAED,WAAW;QACT,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC7B,CAAC;;iHAzFU,oBAAoB,kBAEX,iBAAiB;qGAF1B,oBAAoB,gMCZjC,iiBAWM,4kBDDQ,CAAC,kBAAkB,CAAC;2FAErB,oBAAoB;kBANhC,SAAS;+BACE,qBAAqB,cAGnB,CAAC,kBAAkB,CAAC;;0BAInB,MAAM;2BAAC,iBAAiB;4CAkDjB,QAAQ;sBAA3B,KAAK;gBAUc,IAAI;sBAAvB,KAAK;gBAUW,UAAU;sBAA1B,MAAM;gBACa,IAAI;sBAAvB,KAAK;gBAQI,aAAa;sBAAtB,MAAM","sourcesContent":["import { Component, EventEmitter, Inject, Input, OnDestroy, Output, TemplateRef } from '@angular/core';\nimport { BehaviorSubject, combineLatest, delayWhen, interval, map, Observable, of, Subject, takeUntil } from 'rxjs';\nimport { FadeInOutAnimation } from '@mintplayer/ng-animations';\nimport { OffcanvasPosition } from '../../types/position';\nimport { OFFCANVAS_CONTENT } from '../../providers/offcanvas-content.provider';\n\n@Component({\n  selector: 'bs-offcanvas-holder',\n  templateUrl: './offcanvas.component.html',\n  styleUrls: ['./offcanvas.component.scss'],\n  animations: [FadeInOutAnimation]\n})\nexport class BsOffcanvasComponent implements OnDestroy {\n\n  constructor(@Inject(OFFCANVAS_CONTENT) contentTemplate: TemplateRef<any>) {\n    this.contentTemplate = contentTemplate;\n\n    this.visibility$ = this.show$\n      .pipe(delayWhen((val, i) => val ? of(0) : interval(300)))\n      .pipe(map((val) => val ? 'visible' : 'hidden'));\n\n    this.position$\n      .pipe(takeUntil(this.destroyed$))\n      .subscribe((position) => {\n        this.disableTransition$.next(true);\n        this.offcanvasClass$.next(`offcanvas-${position}`);\n        setTimeout(() => this.disableTransition$.next(false));\n      });\n\n    this.width$ = combineLatest([this.position$, this.size$])\n      .pipe(map(([position, size]) => {\n        if (['start', 'end'].includes(position)) {\n          return size;\n        } else {\n          return null;\n        }\n      }));\n\n    this.height$ = combineLatest([this.position$, this.size$])\n      .pipe(map(([position, size]) => {\n        if (['top', 'bottom'].includes(position)) {\n          return size;\n        } else {\n          return null;\n        }\n      }));\n\n    this.showBackdrop$ = combineLatest([this.hasBackdrop$, this.show$])\n      .pipe(map(([hasBackdrop, show]) => hasBackdrop && show));\n  }\n\n  contentTemplate: TemplateRef<any>;\n  \n  destroyed$ = new Subject();\n  visibility$: Observable<string>;\n  disableTransition$ = new BehaviorSubject<boolean>(false);\n  offcanvasClass$ = new BehaviorSubject<string | null>(null);\n  width$: Observable<number | null>;\n  height$: Observable<number | null>;\n  hasBackdrop$ = new BehaviorSubject<boolean>(false);\n  showBackdrop$: Observable<boolean>;\n\n  //#region Position\n  position$ = new BehaviorSubject<OffcanvasPosition>('bottom');\n  @Input() public set position(value: OffcanvasPosition) {\n    this.position$.next(value);\n  }\n  public get position() {\n    return this.position$.value;\n  }\n  //#endregion\n\n  //#region Size\n  size$ = new BehaviorSubject<number | null>(null);\n  @Input() public set size(value: number | null) {\n    this.size$.next(value);\n  }\n  public get size() {\n    return this.size$.value;\n  }\n  //#endregion\n\n  //#region Show\n  show$ = new BehaviorSubject<boolean>(false);\n  @Output() public showChange = new EventEmitter<boolean>();\n  @Input() public set show(value: boolean) {\n    this.show$.next(value);\n  }\n  public get show() {\n    return this.show$.value;\n  }\n  //#endregion\n\n  @Output() backdropClick = new EventEmitter<MouseEvent>();\n  onBackdropClick(ev: MouseEvent) {\n    console.log(1);\n    this.backdropClick.emit(ev);\n  }\n  \n  ngOnDestroy() {\n    this.destroyed$.next(true);\n  }\n\n}\n","<div [@fadeInOut]=\"{value: ':leave', params: {duration: '300ms'} }\" *ngIf=\"showBackdrop$ | async\">\n    <div class=\"modal-backdrop show\" (click)=\"onBackdropClick($event)\"></div>\n</div>\n\n<div class=\"offcanvas overflow-hidden\"\n    [class.show]=\"show$ | async\"\n    [class.disable-transition]=\"disableTransition$ | async\"\n    [class]=\"offcanvasClass$ | async\"\n    [style.height.px]=\"height$ | async\"\n    [style.width.px]=\"width$ | async\">\n    <ng-container *ngTemplateOutlet=\"contentTemplate\"></ng-container>\n</div>"]}
|
|
103
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"offcanvas.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/mintplayer-ng-bootstrap/src/lib/components/offcanvas/components/offcanvas/offcanvas.component.ts","../../../../../../../../../libs/mintplayer-ng-bootstrap/src/lib/components/offcanvas/components/offcanvas/offcanvas.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Inject, Input, OnDestroy, Output, TemplateRef } from '@angular/core';\nimport { BehaviorSubject, combineLatest, delayWhen, interval, map, Observable, of, Subject, takeUntil } from 'rxjs';\nimport { FadeInOutAnimation } from '@mintplayer/ng-animations';\nimport { OffcanvasPosition } from '../../types/position';\nimport { OFFCANVAS_CONTENT } from '../../providers/offcanvas-content.provider';\nimport { BsViewState } from '../../../../types/view-state.type';\n\n@Component({\n  selector: 'bs-offcanvas-holder',\n  templateUrl: './offcanvas.component.html',\n  styleUrls: ['./offcanvas.component.scss'],\n  animations: [FadeInOutAnimation]\n})\nexport class BsOffcanvasComponent implements OnDestroy {\n\n  constructor(@Inject(OFFCANVAS_CONTENT) contentTemplate: TemplateRef<any>) {\n    this.contentTemplate = contentTemplate;\n\n    this.visibility$ = this.state$\n      .pipe(delayWhen((val, i) => val ? of(0) : interval(300)))\n      .pipe(map((val) => val ? 'visible' : 'hidden'));\n\n    this.position$\n      .pipe(takeUntil(this.destroyed$))\n      .subscribe((position) => {\n        this.disableTransition$.next(true);\n        this.offcanvasClass$.next(`offcanvas-${position}`);\n        setTimeout(() => this.disableTransition$.next(false));\n      });\n\n    this.width$ = combineLatest([this.position$, this.size$])\n      .pipe(map(([position, size]) => {\n        if (['start', 'end'].includes(position)) {\n          return size;\n        } else {\n          return null;\n        }\n      }));\n\n    this.height$ = combineLatest([this.position$, this.size$])\n      .pipe(map(([position, size]) => {\n        if (['top', 'bottom'].includes(position)) {\n          return size;\n        } else {\n          return null;\n        }\n      }));\n\n    this.showBackdrop$ = combineLatest([this.hasBackdrop$, this.state$])\n      .pipe(map(([hasBackdrop, state]) => hasBackdrop && (state === 'open')));\n\n    this.show$ = this.state$\n      .pipe(map((state) => state === 'open'));\n  }\n\n  contentTemplate: TemplateRef<any>;\n  \n  destroyed$ = new Subject();\n  visibility$: Observable<string>;\n  disableTransition$ = new BehaviorSubject<boolean>(false);\n  offcanvasClass$ = new BehaviorSubject<string | null>(null);\n  width$: Observable<number | null>;\n  height$: Observable<number | null>;\n  hasBackdrop$ = new BehaviorSubject<boolean>(false);\n  show$: Observable<boolean>;\n  showBackdrop$: Observable<boolean>;\n\n  //#region Position\n  position$ = new BehaviorSubject<OffcanvasPosition>('bottom');\n  @Input() public set position(value: OffcanvasPosition) {\n    this.position$.next(value);\n  }\n  public get position() {\n    return this.position$.value;\n  }\n  //#endregion\n\n  //#region Size\n  size$ = new BehaviorSubject<number | null>(null);\n  @Input() public set size(value: number | null) {\n    this.size$.next(value);\n  }\n  public get size() {\n    return this.size$.value;\n  }\n  //#endregion\n\n  //#region State\n  state$ = new BehaviorSubject<BsViewState>('closed');\n  @Output() public stateChange = new EventEmitter<boolean>();\n  @Input() public set state(value: BsViewState) {\n    this.state$.next(value);\n  }\n  public get state() {\n    return this.state$.value;\n  }\n  //#endregion\n\n  @Output() backdropClick = new EventEmitter<MouseEvent>();\n  onBackdropClick(ev: MouseEvent) {\n    console.log(1);\n    this.backdropClick.emit(ev);\n  }\n  \n  ngOnDestroy() {\n    this.destroyed$.next(true);\n  }\n\n}\n","<div [@fadeInOut]=\"{value: ':leave', params: {duration: '300ms'} }\" *ngIf=\"showBackdrop$ | async\">\n    <div class=\"modal-backdrop show\" (click)=\"onBackdropClick($event)\"></div>\n</div>\n\n<div class=\"offcanvas overflow-hidden\"\n    [class.show]=\"show$ | async\"\n    [class.disable-transition]=\"disableTransition$ | async\"\n    [class]=\"offcanvasClass$ | async\"\n    [style.height.px]=\"height$ | async\"\n    [style.width.px]=\"width$ | async\">\n    <ng-container *ngTemplateOutlet=\"contentTemplate\"></ng-container>\n</div>"]}
|
package/esm2020/lib/components/offcanvas/components/offcanvas-host/offcanvas-host.component.mjs
CHANGED
|
@@ -11,20 +11,20 @@ export class BsOffcanvasHostComponent {
|
|
|
11
11
|
this.rootInjector = rootInjector;
|
|
12
12
|
this.portalFactory = portalFactory;
|
|
13
13
|
this.viewInited$ = new BehaviorSubject(false);
|
|
14
|
-
this.
|
|
14
|
+
this.state$ = new BehaviorSubject('closed');
|
|
15
15
|
this.size$ = new BehaviorSubject(null);
|
|
16
16
|
this.position$ = new BehaviorSubject('bottom');
|
|
17
17
|
this.hasBackdrop$ = new BehaviorSubject(false);
|
|
18
18
|
this.destroyed$ = new Subject();
|
|
19
19
|
this.backdropClick = new EventEmitter();
|
|
20
|
-
//#region
|
|
21
|
-
this.
|
|
22
|
-
this.
|
|
20
|
+
//#region State
|
|
21
|
+
this.stateChange = new EventEmitter();
|
|
22
|
+
this.state$
|
|
23
23
|
.pipe(takeUntil(this.destroyed$))
|
|
24
|
-
.subscribe((
|
|
24
|
+
.subscribe((state) => {
|
|
25
25
|
if (this.component) {
|
|
26
|
-
this.
|
|
27
|
-
this.component.instance.
|
|
26
|
+
this.stateChange.emit(state);
|
|
27
|
+
this.component.instance.state$.next(state);
|
|
28
28
|
}
|
|
29
29
|
});
|
|
30
30
|
combineLatest([this.position$, this.viewInited$])
|
|
@@ -78,11 +78,11 @@ export class BsOffcanvasHostComponent {
|
|
|
78
78
|
ngOnDestroy() {
|
|
79
79
|
this.destroyed$.next(true);
|
|
80
80
|
}
|
|
81
|
-
set
|
|
82
|
-
this.
|
|
81
|
+
set state(value) {
|
|
82
|
+
this.state$.next(value);
|
|
83
83
|
}
|
|
84
|
-
get
|
|
85
|
-
return this.
|
|
84
|
+
get state() {
|
|
85
|
+
return this.state$.value;
|
|
86
86
|
}
|
|
87
87
|
//#endregion
|
|
88
88
|
//#region Position
|
|
@@ -110,7 +110,7 @@ export class BsOffcanvasHostComponent {
|
|
|
110
110
|
}
|
|
111
111
|
}
|
|
112
112
|
BsOffcanvasHostComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.6", ngImport: i0, type: BsOffcanvasHostComponent, deps: [{ token: i1.Overlay }, { token: i0.Injector }, { token: PORTAL_FACTORY }], target: i0.ɵɵFactoryTarget.Component });
|
|
113
|
-
BsOffcanvasHostComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.6", type: BsOffcanvasHostComponent, selector: "bs-offcanvas", inputs: {
|
|
113
|
+
BsOffcanvasHostComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.6", type: BsOffcanvasHostComponent, selector: "bs-offcanvas", inputs: { state: "state", position: "position", size: "size", hasBackdrop: "hasBackdrop" }, outputs: { backdropClick: "backdropClick", stateChange: "stateChange" }, ngImport: i0, template: "", styles: [""] });
|
|
114
114
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.6", ngImport: i0, type: BsOffcanvasHostComponent, decorators: [{
|
|
115
115
|
type: Component,
|
|
116
116
|
args: [{ selector: 'bs-offcanvas', template: "", styles: [""] }]
|
|
@@ -119,9 +119,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.6", ngImpor
|
|
|
119
119
|
args: [PORTAL_FACTORY]
|
|
120
120
|
}] }]; }, propDecorators: { backdropClick: [{
|
|
121
121
|
type: Output
|
|
122
|
-
}],
|
|
122
|
+
}], stateChange: [{
|
|
123
123
|
type: Output
|
|
124
|
-
}],
|
|
124
|
+
}], state: [{
|
|
125
125
|
type: Input
|
|
126
126
|
}], position: [{
|
|
127
127
|
type: Input
|
|
@@ -130,4 +130,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.6", ngImpor
|
|
|
130
130
|
}], hasBackdrop: [{
|
|
131
131
|
type: Input
|
|
132
132
|
}] } });
|
|
133
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"offcanvas-host.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/mintplayer-ng-bootstrap/src/lib/components/offcanvas/components/offcanvas-host/offcanvas-host.component.ts","../../../../../../../../../libs/mintplayer-ng-bootstrap/src/lib/components/offcanvas/components/offcanvas-host/offcanvas-host.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Overlay } from '@angular/cdk/overlay';\nimport { ComponentPortal } from '@angular/cdk/portal';\nimport { AfterViewInit, Component, ComponentRef, EventEmitter, Inject, Injector, Input, OnDestroy, Output, TemplateRef } from '@angular/core';\nimport { BehaviorSubject, combineLatest, filter, Subject, takeUntil } from 'rxjs';\nimport { OFFCANVAS_CONTENT } from '../../providers/offcanvas-content.provider';\nimport { PORTAL_FACTORY } from '../../providers/portal-factory.provider';\nimport { OffcanvasPosition } from '../../types/position';\nimport { BsOffcanvasComponent } from '../offcanvas/offcanvas.component';\n\n@Component({\n  selector: 'bs-offcanvas',\n  templateUrl: './offcanvas-host.component.html',\n  styleUrls: ['./offcanvas-host.component.scss']\n})\nexport class BsOffcanvasHostComponent implements AfterViewInit, OnDestroy {\n\n  constructor(private overlayService: Overlay, private rootInjector: Injector, @Inject(PORTAL_FACTORY) private portalFactory: (injector: Injector) => ComponentPortal<any>) {\n    this.show$\n      .pipe(takeUntil(this.destroyed$))\n      .subscribe((show) => {\n        if (this.component) {\n          this.showChange.emit(show);\n          this.component.instance.show$.next(show);\n        }\n      });\n\n    combineLatest([this.position$, this.viewInited$])\n      .pipe(filter(([position, viewInited]) => viewInited))\n      .pipe(takeUntil(this.destroyed$))\n      .subscribe(([position, viewInited]) => {\n        if (this.component) {\n          this.component.instance.position$.next(position);\n        }\n      });\n\n    combineLatest([this.size$, this.viewInited$])\n      .pipe(filter(([size, viewInited]) => viewInited))\n      .pipe(takeUntil(this.destroyed$))\n      .subscribe(([size, viewInited]) => {\n        if (this.component) {\n          this.component.instance.size$.next(size);\n        }\n      });\n      \n    combineLatest([this.hasBackdrop$, this.viewInited$])\n      .pipe(filter(([hasBackdrop, viewInited]) => viewInited))\n      .pipe(takeUntil(this.destroyed$))\n      .subscribe(([hasBackdrop, viewInited]) => {\n        if (this.component) {\n          this.component.instance.hasBackdrop$.next(hasBackdrop);\n        }\n      });\n  }\n\n  content!: TemplateRef<any>;\n  component!: ComponentRef<BsOffcanvasComponent>;\n  viewInited$ = new BehaviorSubject<boolean>(false);\n  show$ = new BehaviorSubject<boolean>(false);\n  size$ = new BehaviorSubject<number | null>(null);\n  position$ = new BehaviorSubject<OffcanvasPosition>('bottom');\n  hasBackdrop$ = new BehaviorSubject<boolean>(false);\n  destroyed$ = new Subject();\n\n  @Output() backdropClick = new EventEmitter<MouseEvent>();\n\n  ngAfterViewInit() {\n    const injector = Injector.create({\n      providers: [\n        { provide: OFFCANVAS_CONTENT, useValue: this.content },\n      ],\n      parent: this.rootInjector,\n    });\n    // const portal = new ComponentPortal(BsOffcanvasComponent, null, injector);\n    const portal = this.portalFactory(injector);\n    const overlayRef = this.overlayService.create({\n      scrollStrategy: this.overlayService.scrollStrategies.block(),\n      positionStrategy: this.overlayService.position().global()\n        .top('0').left('0').bottom('0').right('0'),\n      hasBackdrop: false\n    });\n\n    this.component = overlayRef.attach<BsOffcanvasComponent>(portal);\n\n    this.component.instance.backdropClick\n      .pipe(takeUntil(this.destroyed$))\n      .subscribe((ev) => {\n        this.backdropClick.emit(ev);\n      });\n\n    this.viewInited$.next(true);\n  }\n\n  ngOnDestroy(): void {\n    this.destroyed$.next(true);\n  }\n\n  //#region Show\n  @Output() public showChange = new EventEmitter<boolean>();\n  @Input() public set show(value: boolean) {\n    this.show$.next(value);\n  }\n  public get show() {\n    return this.show$.value;\n  }\n  //#endregion\n\n  //#region Position\n  @Input() public set position(value: OffcanvasPosition) {\n    this.position$.next(value);\n  }\n  public get position() {\n    return this.position$.value;\n  }\n  //#endregion\n\n  //#region Size\n  @Input() public set size(value: number | null) {\n    this.size$.next(value);\n  }\n  public get size() {\n    return this.size$.value;\n  }\n  //#endregion\n\n  //#region HasBackdrop\n  @Input() public set hasBackdrop(value: boolean) {\n    this.hasBackdrop$.next(value);\n  }\n  public get hasBackdrop() {\n    return this.hasBackdrop$.value;\n  }\n  //#endregion\n\n}\n",""]}
|
|
133
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"offcanvas-host.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/mintplayer-ng-bootstrap/src/lib/components/offcanvas/components/offcanvas-host/offcanvas-host.component.ts","../../../../../../../../../libs/mintplayer-ng-bootstrap/src/lib/components/offcanvas/components/offcanvas-host/offcanvas-host.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Overlay } from '@angular/cdk/overlay';\nimport { ComponentPortal } from '@angular/cdk/portal';\nimport { AfterViewInit, Component, ComponentRef, EventEmitter, Inject, Injector, Input, OnDestroy, Output, TemplateRef } from '@angular/core';\nimport { BsViewState } from '../../../../types/view-state.type';\nimport { BehaviorSubject, combineLatest, filter, Subject, takeUntil } from 'rxjs';\nimport { OFFCANVAS_CONTENT } from '../../providers/offcanvas-content.provider';\nimport { PORTAL_FACTORY } from '../../providers/portal-factory.provider';\nimport { OffcanvasPosition } from '../../types/position';\nimport { BsOffcanvasComponent } from '../offcanvas/offcanvas.component';\n\n@Component({\n  selector: 'bs-offcanvas',\n  templateUrl: './offcanvas-host.component.html',\n  styleUrls: ['./offcanvas-host.component.scss']\n})\nexport class BsOffcanvasHostComponent implements AfterViewInit, OnDestroy {\n\n  constructor(private overlayService: Overlay, private rootInjector: Injector, @Inject(PORTAL_FACTORY) private portalFactory: (injector: Injector) => ComponentPortal<any>) {\n    this.state$\n      .pipe(takeUntil(this.destroyed$))\n      .subscribe((state) => {\n        if (this.component) {\n          this.stateChange.emit(state);\n          this.component.instance.state$.next(state);\n        }\n      });\n\n    combineLatest([this.position$, this.viewInited$])\n      .pipe(filter(([position, viewInited]) => viewInited))\n      .pipe(takeUntil(this.destroyed$))\n      .subscribe(([position, viewInited]) => {\n        if (this.component) {\n          this.component.instance.position$.next(position);\n        }\n      });\n\n    combineLatest([this.size$, this.viewInited$])\n      .pipe(filter(([size, viewInited]) => viewInited))\n      .pipe(takeUntil(this.destroyed$))\n      .subscribe(([size, viewInited]) => {\n        if (this.component) {\n          this.component.instance.size$.next(size);\n        }\n      });\n      \n    combineLatest([this.hasBackdrop$, this.viewInited$])\n      .pipe(filter(([hasBackdrop, viewInited]) => viewInited))\n      .pipe(takeUntil(this.destroyed$))\n      .subscribe(([hasBackdrop, viewInited]) => {\n        if (this.component) {\n          this.component.instance.hasBackdrop$.next(hasBackdrop);\n        }\n      });\n  }\n\n  content!: TemplateRef<any>;\n  component!: ComponentRef<BsOffcanvasComponent>;\n  viewInited$ = new BehaviorSubject<boolean>(false);\n  state$ = new BehaviorSubject<BsViewState>('closed');\n  size$ = new BehaviorSubject<number | null>(null);\n  position$ = new BehaviorSubject<OffcanvasPosition>('bottom');\n  hasBackdrop$ = new BehaviorSubject<boolean>(false);\n  destroyed$ = new Subject();\n\n  @Output() backdropClick = new EventEmitter<MouseEvent>();\n\n  ngAfterViewInit() {\n    const injector = Injector.create({\n      providers: [\n        { provide: OFFCANVAS_CONTENT, useValue: this.content },\n      ],\n      parent: this.rootInjector,\n    });\n    // const portal = new ComponentPortal(BsOffcanvasComponent, null, injector);\n    const portal = this.portalFactory(injector);\n    const overlayRef = this.overlayService.create({\n      scrollStrategy: this.overlayService.scrollStrategies.block(),\n      positionStrategy: this.overlayService.position().global()\n        .top('0').left('0').bottom('0').right('0'),\n      hasBackdrop: false\n    });\n\n    this.component = overlayRef.attach<BsOffcanvasComponent>(portal);\n\n    this.component.instance.backdropClick\n      .pipe(takeUntil(this.destroyed$))\n      .subscribe((ev) => {\n        this.backdropClick.emit(ev);\n      });\n\n    this.viewInited$.next(true);\n  }\n\n  ngOnDestroy(): void {\n    this.destroyed$.next(true);\n  }\n\n  //#region State\n  @Output() public stateChange = new EventEmitter<BsViewState>();\n  @Input() public set state(value: BsViewState) {\n    this.state$.next(value);\n  }\n  public get state() {\n    return this.state$.value;\n  }\n  //#endregion\n\n  //#region Position\n  @Input() public set position(value: OffcanvasPosition) {\n    this.position$.next(value);\n  }\n  public get position() {\n    return this.position$.value;\n  }\n  //#endregion\n\n  //#region Size\n  @Input() public set size(value: number | null) {\n    this.size$.next(value);\n  }\n  public get size() {\n    return this.size$.value;\n  }\n  //#endregion\n\n  //#region HasBackdrop\n  @Input() public set hasBackdrop(value: boolean) {\n    this.hasBackdrop$.next(value);\n  }\n  public get hasBackdrop() {\n    return this.hasBackdrop$.value;\n  }\n  //#endregion\n\n}\n",""]}
|
package/esm2020/lib/components/offcanvas/directives/offcanvas-close/offcanvas-close.directive.mjs
CHANGED
|
@@ -7,7 +7,7 @@ export class BsOffcanvasCloseDirective {
|
|
|
7
7
|
this.offcanvas = offcanvas;
|
|
8
8
|
}
|
|
9
9
|
onClick() {
|
|
10
|
-
this.offcanvas.
|
|
10
|
+
this.offcanvas.state = 'closed';
|
|
11
11
|
}
|
|
12
12
|
}
|
|
13
13
|
BsOffcanvasCloseDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.6", ngImport: i0, type: BsOffcanvasCloseDirective, deps: [{ token: i1.BsOffcanvasHostComponent }], target: i0.ɵɵFactoryTarget.Directive });
|
|
@@ -21,4 +21,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.6", ngImpor
|
|
|
21
21
|
type: HostListener,
|
|
22
22
|
args: ['click']
|
|
23
23
|
}] } });
|
|
24
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib2ZmY2FudmFzLWNsb3NlLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvbWludHBsYXllci1uZy1ib290c3RyYXAvc3JjL2xpYi9jb21wb25lbnRzL29mZmNhbnZhcy9kaXJlY3RpdmVzL29mZmNhbnZhcy1jbG9zZS9vZmZjYW52YXMtY2xvc2UuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3hELE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLDBEQUEwRCxDQUFDOzs7QUFLcEcsTUFBTSxPQUFPLHlCQUF5QjtJQUNwQyxZQUFvQixTQUFtQztRQUFuQyxjQUFTLEdBQVQsU0FBUyxDQUEwQjtJQUFJLENBQUM7SUFFckMsT0FBTztRQUM1QixJQUFJLENBQUMsU0FBUyxDQUFDLEtBQUssR0FBRyxRQUFRLENBQUM7SUFDbEMsQ0FBQzs7c0hBTFUseUJBQXlCOzBHQUF6Qix5QkFBeUI7MkZBQXpCLHlCQUF5QjtrQkFIckMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsb0JBQW9CO2lCQUMvQjsrR0FJd0IsT0FBTztzQkFBN0IsWUFBWTt1QkFBQyxPQUFPIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBIb3N0TGlzdGVuZXIgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEJzT2ZmY2FudmFzSG9zdENvbXBvbmVudCB9IGZyb20gJy4uLy4uL2NvbXBvbmVudHMvb2ZmY2FudmFzLWhvc3Qvb2ZmY2FudmFzLWhvc3QuY29tcG9uZW50JztcblxuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnW2JzT2ZmY2FudmFzQ2xvc2VdJ1xufSlcbmV4cG9ydCBjbGFzcyBCc09mZmNhbnZhc0Nsb3NlRGlyZWN0aXZlIHtcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBvZmZjYW52YXM6IEJzT2ZmY2FudmFzSG9zdENvbXBvbmVudCkgeyB9XG5cbiAgQEhvc3RMaXN0ZW5lcignY2xpY2snKSBvbkNsaWNrKCkge1xuICAgIHRoaXMub2ZmY2FudmFzLnN0YXRlID0gJ2Nsb3NlZCc7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export * from './view-state.type';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL21pbnRwbGF5ZXItbmctYm9vdHN0cmFwL3NyYy9saWIvdHlwZXMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxtQkFBbUIsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vdmlldy1zdGF0ZS50eXBlJyJdfQ==
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmlldy1zdGF0ZS50eXBlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9taW50cGxheWVyLW5nLWJvb3RzdHJhcC9zcmMvbGliL3R5cGVzL3ZpZXctc3RhdGUudHlwZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHR5cGUgQnNWaWV3U3RhdGUgPSAnb3BlbicgfCAnY2xvc2VkJzsiXX0=
|
|
@@ -3738,13 +3738,13 @@ class BsOffcanvasComponent {
|
|
|
3738
3738
|
//#region Size
|
|
3739
3739
|
this.size$ = new BehaviorSubject(null);
|
|
3740
3740
|
//#endregion
|
|
3741
|
-
//#region
|
|
3742
|
-
this.
|
|
3743
|
-
this.
|
|
3741
|
+
//#region State
|
|
3742
|
+
this.state$ = new BehaviorSubject('closed');
|
|
3743
|
+
this.stateChange = new EventEmitter();
|
|
3744
3744
|
//#endregion
|
|
3745
3745
|
this.backdropClick = new EventEmitter();
|
|
3746
3746
|
this.contentTemplate = contentTemplate;
|
|
3747
|
-
this.visibility$ = this.
|
|
3747
|
+
this.visibility$ = this.state$
|
|
3748
3748
|
.pipe(delayWhen((val, i) => val ? of(0) : interval(300)))
|
|
3749
3749
|
.pipe(map((val) => val ? 'visible' : 'hidden'));
|
|
3750
3750
|
this.position$
|
|
@@ -3772,8 +3772,10 @@ class BsOffcanvasComponent {
|
|
|
3772
3772
|
return null;
|
|
3773
3773
|
}
|
|
3774
3774
|
}));
|
|
3775
|
-
this.showBackdrop$ = combineLatest([this.hasBackdrop$, this.
|
|
3776
|
-
.pipe(map(([hasBackdrop,
|
|
3775
|
+
this.showBackdrop$ = combineLatest([this.hasBackdrop$, this.state$])
|
|
3776
|
+
.pipe(map(([hasBackdrop, state]) => hasBackdrop && (state === 'open')));
|
|
3777
|
+
this.show$ = this.state$
|
|
3778
|
+
.pipe(map((state) => state === 'open'));
|
|
3777
3779
|
}
|
|
3778
3780
|
set position(value) {
|
|
3779
3781
|
this.position$.next(value);
|
|
@@ -3787,11 +3789,11 @@ class BsOffcanvasComponent {
|
|
|
3787
3789
|
get size() {
|
|
3788
3790
|
return this.size$.value;
|
|
3789
3791
|
}
|
|
3790
|
-
set
|
|
3791
|
-
this.
|
|
3792
|
+
set state(value) {
|
|
3793
|
+
this.state$.next(value);
|
|
3792
3794
|
}
|
|
3793
|
-
get
|
|
3794
|
-
return this.
|
|
3795
|
+
get state() {
|
|
3796
|
+
return this.state$.value;
|
|
3795
3797
|
}
|
|
3796
3798
|
onBackdropClick(ev) {
|
|
3797
3799
|
console.log(1);
|
|
@@ -3802,7 +3804,7 @@ class BsOffcanvasComponent {
|
|
|
3802
3804
|
}
|
|
3803
3805
|
}
|
|
3804
3806
|
BsOffcanvasComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.6", ngImport: i0, type: BsOffcanvasComponent, deps: [{ token: OFFCANVAS_CONTENT }], target: i0.ɵɵFactoryTarget.Component });
|
|
3805
|
-
BsOffcanvasComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.6", type: BsOffcanvasComponent, selector: "bs-offcanvas-holder", inputs: { position: "position", size: "size",
|
|
3807
|
+
BsOffcanvasComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.6", type: BsOffcanvasComponent, selector: "bs-offcanvas-holder", inputs: { position: "position", size: "size", state: "state" }, outputs: { stateChange: "stateChange", backdropClick: "backdropClick" }, ngImport: i0, template: "<div [@fadeInOut]=\"{value: ':leave', params: {duration: '300ms'} }\" *ngIf=\"showBackdrop$ | async\">\n <div class=\"modal-backdrop show\" (click)=\"onBackdropClick($event)\"></div>\n</div>\n\n<div class=\"offcanvas overflow-hidden\"\n [class.show]=\"show$ | async\"\n [class.disable-transition]=\"disableTransition$ | async\"\n [class]=\"offcanvasClass$ | async\"\n [style.height.px]=\"height$ | async\"\n [style.width.px]=\"width$ | async\">\n <ng-container *ngTemplateOutlet=\"contentTemplate\"></ng-container>\n</div>", styles: [".offcanvas.oc-max-width{max-width:calc(100% - 40px)}.offcanvas.oc-max-height{max-height:calc(100% - 40px)}.modal-backdrop{z-index:1040}.offcanvas{visibility:unset}.offcanvas.disable-transition{transition:none}.offcanvas.offcanvas-top{height:auto;bottom:unset}.offcanvas.offcanvas-bottom{height:auto;top:unset}\n"], directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }], pipes: { "async": i1.AsyncPipe }, animations: [FadeInOutAnimation] });
|
|
3806
3808
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.6", ngImport: i0, type: BsOffcanvasComponent, decorators: [{
|
|
3807
3809
|
type: Component,
|
|
3808
3810
|
args: [{ selector: 'bs-offcanvas-holder', animations: [FadeInOutAnimation], template: "<div [@fadeInOut]=\"{value: ':leave', params: {duration: '300ms'} }\" *ngIf=\"showBackdrop$ | async\">\n <div class=\"modal-backdrop show\" (click)=\"onBackdropClick($event)\"></div>\n</div>\n\n<div class=\"offcanvas overflow-hidden\"\n [class.show]=\"show$ | async\"\n [class.disable-transition]=\"disableTransition$ | async\"\n [class]=\"offcanvasClass$ | async\"\n [style.height.px]=\"height$ | async\"\n [style.width.px]=\"width$ | async\">\n <ng-container *ngTemplateOutlet=\"contentTemplate\"></ng-container>\n</div>", styles: [".offcanvas.oc-max-width{max-width:calc(100% - 40px)}.offcanvas.oc-max-height{max-height:calc(100% - 40px)}.modal-backdrop{z-index:1040}.offcanvas{visibility:unset}.offcanvas.disable-transition{transition:none}.offcanvas.offcanvas-top{height:auto;bottom:unset}.offcanvas.offcanvas-bottom{height:auto;top:unset}\n"] }]
|
|
@@ -3815,9 +3817,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.6", ngImpor
|
|
|
3815
3817
|
type: Input
|
|
3816
3818
|
}], size: [{
|
|
3817
3819
|
type: Input
|
|
3818
|
-
}],
|
|
3820
|
+
}], stateChange: [{
|
|
3819
3821
|
type: Output
|
|
3820
|
-
}],
|
|
3822
|
+
}], state: [{
|
|
3821
3823
|
type: Input
|
|
3822
3824
|
}], backdropClick: [{
|
|
3823
3825
|
type: Output
|
|
@@ -3831,20 +3833,20 @@ class BsOffcanvasHostComponent {
|
|
|
3831
3833
|
this.rootInjector = rootInjector;
|
|
3832
3834
|
this.portalFactory = portalFactory;
|
|
3833
3835
|
this.viewInited$ = new BehaviorSubject(false);
|
|
3834
|
-
this.
|
|
3836
|
+
this.state$ = new BehaviorSubject('closed');
|
|
3835
3837
|
this.size$ = new BehaviorSubject(null);
|
|
3836
3838
|
this.position$ = new BehaviorSubject('bottom');
|
|
3837
3839
|
this.hasBackdrop$ = new BehaviorSubject(false);
|
|
3838
3840
|
this.destroyed$ = new Subject();
|
|
3839
3841
|
this.backdropClick = new EventEmitter();
|
|
3840
|
-
//#region
|
|
3841
|
-
this.
|
|
3842
|
-
this.
|
|
3842
|
+
//#region State
|
|
3843
|
+
this.stateChange = new EventEmitter();
|
|
3844
|
+
this.state$
|
|
3843
3845
|
.pipe(takeUntil(this.destroyed$))
|
|
3844
|
-
.subscribe((
|
|
3846
|
+
.subscribe((state) => {
|
|
3845
3847
|
if (this.component) {
|
|
3846
|
-
this.
|
|
3847
|
-
this.component.instance.
|
|
3848
|
+
this.stateChange.emit(state);
|
|
3849
|
+
this.component.instance.state$.next(state);
|
|
3848
3850
|
}
|
|
3849
3851
|
});
|
|
3850
3852
|
combineLatest([this.position$, this.viewInited$])
|
|
@@ -3898,11 +3900,11 @@ class BsOffcanvasHostComponent {
|
|
|
3898
3900
|
ngOnDestroy() {
|
|
3899
3901
|
this.destroyed$.next(true);
|
|
3900
3902
|
}
|
|
3901
|
-
set
|
|
3902
|
-
this.
|
|
3903
|
+
set state(value) {
|
|
3904
|
+
this.state$.next(value);
|
|
3903
3905
|
}
|
|
3904
|
-
get
|
|
3905
|
-
return this.
|
|
3906
|
+
get state() {
|
|
3907
|
+
return this.state$.value;
|
|
3906
3908
|
}
|
|
3907
3909
|
//#endregion
|
|
3908
3910
|
//#region Position
|
|
@@ -3930,7 +3932,7 @@ class BsOffcanvasHostComponent {
|
|
|
3930
3932
|
}
|
|
3931
3933
|
}
|
|
3932
3934
|
BsOffcanvasHostComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.6", ngImport: i0, type: BsOffcanvasHostComponent, deps: [{ token: i1$1.Overlay }, { token: i0.Injector }, { token: PORTAL_FACTORY }], target: i0.ɵɵFactoryTarget.Component });
|
|
3933
|
-
BsOffcanvasHostComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.6", type: BsOffcanvasHostComponent, selector: "bs-offcanvas", inputs: {
|
|
3935
|
+
BsOffcanvasHostComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.6", type: BsOffcanvasHostComponent, selector: "bs-offcanvas", inputs: { state: "state", position: "position", size: "size", hasBackdrop: "hasBackdrop" }, outputs: { backdropClick: "backdropClick", stateChange: "stateChange" }, ngImport: i0, template: "", styles: [""] });
|
|
3934
3936
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.6", ngImport: i0, type: BsOffcanvasHostComponent, decorators: [{
|
|
3935
3937
|
type: Component,
|
|
3936
3938
|
args: [{ selector: 'bs-offcanvas', template: "", styles: [""] }]
|
|
@@ -3941,9 +3943,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.6", ngImpor
|
|
|
3941
3943
|
}] }];
|
|
3942
3944
|
}, propDecorators: { backdropClick: [{
|
|
3943
3945
|
type: Output
|
|
3944
|
-
}],
|
|
3946
|
+
}], stateChange: [{
|
|
3945
3947
|
type: Output
|
|
3946
|
-
}],
|
|
3948
|
+
}], state: [{
|
|
3947
3949
|
type: Input
|
|
3948
3950
|
}], position: [{
|
|
3949
3951
|
type: Input
|
|
@@ -3972,7 +3974,7 @@ class BsOffcanvasCloseDirective {
|
|
|
3972
3974
|
this.offcanvas = offcanvas;
|
|
3973
3975
|
}
|
|
3974
3976
|
onClick() {
|
|
3975
|
-
this.offcanvas.
|
|
3977
|
+
this.offcanvas.state = 'closed';
|
|
3976
3978
|
}
|
|
3977
3979
|
}
|
|
3978
3980
|
BsOffcanvasCloseDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.6", ngImport: i0, type: BsOffcanvasCloseDirective, deps: [{ token: BsOffcanvasHostComponent }], target: i0.ɵɵFactoryTarget.Directive });
|