@skyux/core 6.15.0 → 6.17.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/documentation.json +1042 -892
- package/esm2020/lib/modules/adapter-service/adapter.service.mjs +21 -22
- package/esm2020/lib/modules/affix/affix-offset.mjs +1 -1
- package/esm2020/lib/modules/affix/affix.directive.mjs +38 -23
- package/esm2020/lib/modules/affix/affixer.mjs +266 -260
- package/esm2020/lib/modules/affix/dom-utils.mjs +7 -7
- package/esm2020/lib/modules/dock/dock-dom-adapter.service.mjs +48 -44
- package/esm2020/lib/modules/dock/dock-item.mjs +10 -5
- package/esm2020/lib/modules/dock/dock.component.mjs +55 -31
- package/esm2020/lib/modules/dock/dock.service.mjs +40 -36
- package/esm2020/lib/modules/dynamic-component/dynamic-component.service.mjs +37 -22
- package/esm2020/lib/modules/log/log.service.mjs +37 -37
- package/esm2020/lib/modules/media-query/media-query.service.mjs +50 -47
- package/esm2020/lib/modules/mutation/mutation-observer-service.mjs +3 -1
- package/esm2020/lib/modules/numeric/numeric.pipe.mjs +26 -19
- package/esm2020/lib/modules/numeric/numeric.service.mjs +84 -99
- package/esm2020/lib/modules/overlay/overlay-adapter.service.mjs +23 -17
- package/esm2020/lib/modules/overlay/overlay-instance.mjs +18 -9
- package/esm2020/lib/modules/overlay/overlay.component.mjs +79 -55
- package/esm2020/lib/modules/overlay/overlay.service.mjs +55 -49
- package/esm2020/lib/modules/percent-pipe/percent.pipe.mjs +32 -21
- package/esm2020/lib/modules/resize-observer/resize-observer-media-query.service.mjs +38 -46
- package/esm2020/lib/modules/scrollable-host/scrollable-host.service.mjs +66 -67
- package/esm2020/lib/modules/title/title.service.mjs +8 -4
- package/esm2020/lib/modules/trim/trim.directive.mjs +10 -11
- package/esm2020/lib/modules/viewkeeper/viewkeeper-boundary-info.mjs +1 -1
- package/esm2020/lib/modules/viewkeeper/viewkeeper.directive.mjs +75 -60
- package/esm2020/lib/modules/viewkeeper/viewkeeper.mjs +166 -156
- package/esm2020/lib/modules/viewkeeper/viewkeeper.service.mjs +7 -3
- package/esm2020/testing/core-testing.module.mjs +4 -1
- package/esm2020/testing/mock-media-query.service.mjs +4 -1
- package/esm2020/testing/mock-ui-config.service.mjs +4 -1
- package/esm2020/testing/overlay/overlay-harness-filters.mjs +1 -1
- package/esm2020/testing/overlay/overlay-harness.mjs +2 -1
- package/esm2020/testing/shared/component-harness.mjs +4 -1
- package/esm2020/testing/shared/harness-filters.mjs +1 -1
- package/fesm2015/skyux-core-testing.mjs +13 -0
- package/fesm2015/skyux-core-testing.mjs.map +1 -1
- package/fesm2015/skyux-core.mjs +1276 -1151
- package/fesm2015/skyux-core.mjs.map +1 -1
- package/fesm2020/skyux-core-testing.mjs +13 -0
- package/fesm2020/skyux-core-testing.mjs.map +1 -1
- package/fesm2020/skyux-core.mjs +1278 -1150
- package/fesm2020/skyux-core.mjs.map +1 -1
- package/lib/modules/adapter-service/adapter.service.d.ts +3 -5
- package/lib/modules/affix/affix-offset.d.ts +1 -1
- package/lib/modules/affix/affix.directive.d.ts +12 -13
- package/lib/modules/affix/affixer.d.ts +2 -34
- package/lib/modules/affix/dom-utils.d.ts +3 -3
- package/lib/modules/dock/dock-dom-adapter.service.d.ts +2 -9
- package/lib/modules/dock/dock-item.d.ts +1 -1
- package/lib/modules/dock/dock.component.d.ts +2 -10
- package/lib/modules/dock/dock.service.d.ts +2 -5
- package/lib/modules/dynamic-component/dynamic-component.service.d.ts +2 -7
- package/lib/modules/log/log.service.d.ts +2 -6
- package/lib/modules/media-query/media-query.service.d.ts +1 -8
- package/lib/modules/numeric/numeric.pipe.d.ts +2 -8
- package/lib/modules/numeric/numeric.service.d.ts +3 -36
- package/lib/modules/overlay/overlay-adapter.service.d.ts +1 -3
- package/lib/modules/overlay/overlay-instance.d.ts +1 -2
- package/lib/modules/overlay/overlay.component.d.ts +1 -14
- package/lib/modules/overlay/overlay.service.d.ts +1 -7
- package/lib/modules/percent-pipe/percent.pipe.d.ts +2 -9
- package/lib/modules/resize-observer/resize-observer-media-query.service.d.ts +2 -7
- package/lib/modules/scrollable-host/scrollable-host.service.d.ts +2 -11
- package/lib/modules/title/title.service.d.ts +2 -2
- package/lib/modules/trim/trim.directive.d.ts +0 -2
- package/lib/modules/viewkeeper/viewkeeper-boundary-info.d.ts +1 -1
- package/lib/modules/viewkeeper/viewkeeper.d.ts +2 -24
- package/lib/modules/viewkeeper/viewkeeper.directive.d.ts +4 -16
- package/lib/modules/viewkeeper/viewkeeper.service.d.ts +1 -1
- package/package.json +2 -2
- package/testing/core-testing.module.d.ts +3 -0
- package/testing/mock-media-query.service.d.ts +3 -0
- package/testing/mock-ui-config.service.d.ts +3 -0
- package/testing/overlay/overlay-harness-filters.d.ts +1 -0
- package/testing/overlay/overlay-harness.d.ts +1 -0
- package/testing/shared/component-harness.d.ts +3 -0
- package/testing/shared/harness-filters.d.ts +1 -0
@@ -1,3 +1,5 @@
|
|
1
|
+
var _SkyOverlayInstance_backdropClick, _SkyOverlayInstance_backdropClickObs, _SkyOverlayInstance_closed, _SkyOverlayInstance_closedObs;
|
2
|
+
import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
|
1
3
|
import { Subject } from 'rxjs';
|
2
4
|
/**
|
3
5
|
* Represents a new overlay instance. It is used to manage the "closed" state of the overlay,
|
@@ -11,29 +13,35 @@ export class SkyOverlayInstance {
|
|
11
13
|
config, componentRef) {
|
12
14
|
this.config = config;
|
13
15
|
this.componentRef = componentRef;
|
14
|
-
this
|
15
|
-
this
|
16
|
+
_SkyOverlayInstance_backdropClick.set(this, void 0);
|
17
|
+
_SkyOverlayInstance_backdropClickObs.set(this, void 0);
|
18
|
+
_SkyOverlayInstance_closed.set(this, void 0);
|
19
|
+
_SkyOverlayInstance_closedObs.set(this, void 0);
|
16
20
|
this.id = this.componentRef.instance.id;
|
17
21
|
this.componentRef.instance.closed.subscribe(() => {
|
18
|
-
this.
|
19
|
-
this.
|
20
|
-
this.
|
22
|
+
__classPrivateFieldGet(this, _SkyOverlayInstance_closed, "f").next();
|
23
|
+
__classPrivateFieldGet(this, _SkyOverlayInstance_closed, "f").complete();
|
24
|
+
__classPrivateFieldGet(this, _SkyOverlayInstance_backdropClick, "f").complete();
|
21
25
|
});
|
22
26
|
this.componentRef.instance.backdropClick.subscribe(() => {
|
23
|
-
this.
|
27
|
+
__classPrivateFieldGet(this, _SkyOverlayInstance_backdropClick, "f").next();
|
24
28
|
});
|
29
|
+
__classPrivateFieldSet(this, _SkyOverlayInstance_backdropClick, new Subject(), "f");
|
30
|
+
__classPrivateFieldSet(this, _SkyOverlayInstance_closed, new Subject(), "f");
|
31
|
+
__classPrivateFieldSet(this, _SkyOverlayInstance_backdropClickObs, __classPrivateFieldGet(this, _SkyOverlayInstance_backdropClick, "f").asObservable(), "f");
|
32
|
+
__classPrivateFieldSet(this, _SkyOverlayInstance_closedObs, __classPrivateFieldGet(this, _SkyOverlayInstance_closed, "f").asObservable(), "f");
|
25
33
|
}
|
26
34
|
/**
|
27
35
|
* Emits when the overlay is clicked (but not its content).
|
28
36
|
*/
|
29
37
|
get backdropClick() {
|
30
|
-
return this
|
38
|
+
return __classPrivateFieldGet(this, _SkyOverlayInstance_backdropClickObs, "f");
|
31
39
|
}
|
32
40
|
/**
|
33
41
|
* Emits after the overlay is closed.
|
34
42
|
*/
|
35
43
|
get closed() {
|
36
|
-
return this
|
44
|
+
return __classPrivateFieldGet(this, _SkyOverlayInstance_closedObs, "f");
|
37
45
|
}
|
38
46
|
/**
|
39
47
|
* Creates and attaches a component to the overlay.
|
@@ -53,4 +61,5 @@ export class SkyOverlayInstance {
|
|
53
61
|
this.componentRef.instance.attachTemplate(templateRef, context);
|
54
62
|
}
|
55
63
|
}
|
56
|
-
|
64
|
+
_SkyOverlayInstance_backdropClick = new WeakMap(), _SkyOverlayInstance_backdropClickObs = new WeakMap(), _SkyOverlayInstance_closed = new WeakMap(), _SkyOverlayInstance_closedObs = new WeakMap();
|
65
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3ZlcmxheS1pbnN0YW5jZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9jb3JlL3NyYy9saWIvbW9kdWxlcy9vdmVybGF5L292ZXJsYXktaW5zdGFuY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFFQSxPQUFPLEVBQWMsT0FBTyxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBSzNDOzs7R0FHRztBQUNILE1BQU0sT0FBTyxrQkFBa0I7SUF5QjdCO0lBQ0U7O09BRUc7SUFDYSxNQUF3QixFQUN4QixZQUErQztRQUQvQyxXQUFNLEdBQU4sTUFBTSxDQUFrQjtRQUN4QixpQkFBWSxHQUFaLFlBQVksQ0FBbUM7UUFiakUsb0RBQThCO1FBRTlCLHVEQUFvQztRQUVwQyw2Q0FBdUI7UUFFdkIsZ0RBQTZCO1FBUzNCLElBQUksQ0FBQyxFQUFFLEdBQUcsSUFBSSxDQUFDLFlBQVksQ0FBQyxRQUFRLENBQUMsRUFBRSxDQUFDO1FBRXhDLElBQUksQ0FBQyxZQUFZLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFO1lBQy9DLHVCQUFBLElBQUksa0NBQVEsQ0FBQyxJQUFJLEVBQUUsQ0FBQztZQUNwQix1QkFBQSxJQUFJLGtDQUFRLENBQUMsUUFBUSxFQUFFLENBQUM7WUFDeEIsdUJBQUEsSUFBSSx5Q0FBZSxDQUFDLFFBQVEsRUFBRSxDQUFDO1FBQ2pDLENBQUMsQ0FBQyxDQUFDO1FBRUgsSUFBSSxDQUFDLFlBQVksQ0FBQyxRQUFRLENBQUMsYUFBYSxDQUFDLFNBQVMsQ0FBQyxHQUFHLEVBQUU7WUFDdEQsdUJBQUEsSUFBSSx5Q0FBZSxDQUFDLElBQUksRUFBRSxDQUFDO1FBQzdCLENBQUMsQ0FBQyxDQUFDO1FBRUgsdUJBQUEsSUFBSSxxQ0FBa0IsSUFBSSxPQUFPLEVBQVEsTUFBQSxDQUFDO1FBQzFDLHVCQUFBLElBQUksOEJBQVcsSUFBSSxPQUFPLEVBQVEsTUFBQSxDQUFDO1FBRW5DLHVCQUFBLElBQUksd0NBQXFCLHVCQUFBLElBQUkseUNBQWUsQ0FBQyxZQUFZLEVBQUUsTUFBQSxDQUFDO1FBQzVELHVCQUFBLElBQUksaUNBQWMsdUJBQUEsSUFBSSxrQ0FBUSxDQUFDLFlBQVksRUFBRSxNQUFBLENBQUM7SUFDaEQsQ0FBQztJQWhERDs7T0FFRztJQUNILElBQVcsYUFBYTtRQUN0QixPQUFPLHVCQUFBLElBQUksNENBQWtCLENBQUM7SUFDaEMsQ0FBQztJQUVEOztPQUVHO0lBQ0gsSUFBVyxNQUFNO1FBQ2YsT0FBTyx1QkFBQSxJQUFJLHFDQUFXLENBQUM7SUFDekIsQ0FBQztJQXNDRDs7OztPQUlHO0lBQ0ksZUFBZSxDQUNwQixTQUFrQixFQUNsQixTQUE0QjtRQUU1QixNQUFNLFlBQVksR0FBRyxJQUFJLENBQUMsWUFBWSxDQUFDLFFBQVEsQ0FBQyxlQUFlLENBQzdELFNBQVMsRUFDVCxTQUFTLENBQ1YsQ0FBQztRQUNGLE9BQU8sWUFBWSxDQUFDLFFBQVEsQ0FBQztJQUMvQixDQUFDO0lBRUQ7Ozs7T0FJRztJQUNJLGNBQWMsQ0FBSSxXQUEyQixFQUFFLE9BQVc7UUFDL0QsSUFBSSxDQUFDLFlBQVksQ0FBQyxRQUFRLENBQUMsY0FBYyxDQUFDLFdBQVcsRUFBRSxPQUFPLENBQUMsQ0FBQztJQUNsRSxDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnRSZWYsIFN0YXRpY1Byb3ZpZGVyLCBUZW1wbGF0ZVJlZiwgVHlwZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBPYnNlcnZhYmxlLCBTdWJqZWN0IH0gZnJvbSAncnhqcyc7XG5cbmltcG9ydCB7IFNreU92ZXJsYXlDb25maWcgfSBmcm9tICcuL292ZXJsYXktY29uZmlnJztcbmltcG9ydCB7IFNreU92ZXJsYXlDb21wb25lbnQgfSBmcm9tICcuL292ZXJsYXkuY29tcG9uZW50JztcblxuLyoqXG4gKiBSZXByZXNlbnRzIGEgbmV3IG92ZXJsYXkgaW5zdGFuY2UuIEl0IGlzIHVzZWQgdG8gbWFuYWdlIHRoZSBcImNsb3NlZFwiIHN0YXRlIG9mIHRoZSBvdmVybGF5LFxuICogYW5kIGFjY2VzcyBhbnkgcHVibGljIG1lbWJlcnMgb24gdGhlIGFwcGVuZGVkIGNvbnRlbnQgY29tcG9uZW50IGluc3RhbmNlLlxuICovXG5leHBvcnQgY2xhc3MgU2t5T3ZlcmxheUluc3RhbmNlIHtcbiAgLyoqXG4gICAqIEVtaXRzIHdoZW4gdGhlIG92ZXJsYXkgaXMgY2xpY2tlZCAoYnV0IG5vdCBpdHMgY29udGVudCkuXG4gICAqL1xuICBwdWJsaWMgZ2V0IGJhY2tkcm9wQ2xpY2soKTogT2JzZXJ2YWJsZTx2b2lkPiB7XG4gICAgcmV0dXJuIHRoaXMuI2JhY2tkcm9wQ2xpY2tPYnM7XG4gIH1cblxuICAvKipcbiAgICogRW1pdHMgYWZ0ZXIgdGhlIG92ZXJsYXkgaXMgY2xvc2VkLlxuICAgKi9cbiAgcHVibGljIGdldCBjbG9zZWQoKTogT2JzZXJ2YWJsZTx2b2lkPiB7XG4gICAgcmV0dXJuIHRoaXMuI2Nsb3NlZE9icztcbiAgfVxuXG4gIHB1YmxpYyBpZDogc3RyaW5nO1xuXG4gICNiYWNrZHJvcENsaWNrOiBTdWJqZWN0PHZvaWQ+O1xuXG4gICNiYWNrZHJvcENsaWNrT2JzOiBPYnNlcnZhYmxlPHZvaWQ+O1xuXG4gICNjbG9zZWQ6IFN1YmplY3Q8dm9pZD47XG5cbiAgI2Nsb3NlZE9iczogT2JzZXJ2YWJsZTx2b2lkPjtcblxuICBjb25zdHJ1Y3RvcihcbiAgICAvKipcbiAgICAgKiBUaGUgY29uZmlndXJhdGlvbiBmb3IgdGhlIG92ZXJsYXkuXG4gICAgICovXG4gICAgcHVibGljIHJlYWRvbmx5IGNvbmZpZzogU2t5T3ZlcmxheUNvbmZpZyxcbiAgICBwdWJsaWMgcmVhZG9ubHkgY29tcG9uZW50UmVmOiBDb21wb25lbnRSZWY8U2t5T3ZlcmxheUNvbXBvbmVudD5cbiAgKSB7XG4gICAgdGhpcy5pZCA9IHRoaXMuY29tcG9uZW50UmVmLmluc3RhbmNlLmlkO1xuXG4gICAgdGhpcy5jb21wb25lbnRSZWYuaW5zdGFuY2UuY2xvc2VkLnN1YnNjcmliZSgoKSA9PiB7XG4gICAgICB0aGlzLiNjbG9zZWQubmV4dCgpO1xuICAgICAgdGhpcy4jY2xvc2VkLmNvbXBsZXRlKCk7XG4gICAgICB0aGlzLiNiYWNrZHJvcENsaWNrLmNvbXBsZXRlKCk7XG4gICAgfSk7XG5cbiAgICB0aGlzLmNvbXBvbmVudFJlZi5pbnN0YW5jZS5iYWNrZHJvcENsaWNrLnN1YnNjcmliZSgoKSA9PiB7XG4gICAgICB0aGlzLiNiYWNrZHJvcENsaWNrLm5leHQoKTtcbiAgICB9KTtcblxuICAgIHRoaXMuI2JhY2tkcm9wQ2xpY2sgPSBuZXcgU3ViamVjdDx2b2lkPigpO1xuICAgIHRoaXMuI2Nsb3NlZCA9IG5ldyBTdWJqZWN0PHZvaWQ+KCk7XG5cbiAgICB0aGlzLiNiYWNrZHJvcENsaWNrT2JzID0gdGhpcy4jYmFja2Ryb3BDbGljay5hc09ic2VydmFibGUoKTtcbiAgICB0aGlzLiNjbG9zZWRPYnMgPSB0aGlzLiNjbG9zZWQuYXNPYnNlcnZhYmxlKCk7XG4gIH1cblxuICAvKipcbiAgICogQ3JlYXRlcyBhbmQgYXR0YWNoZXMgYSBjb21wb25lbnQgdG8gdGhlIG92ZXJsYXkuXG4gICAqIEBwYXJhbSBjb21wb25lbnQgVGhlIGNvbXBvbmVudCB0byBhdHRhY2guXG4gICAqIEBwYXJhbSBwcm92aWRlcnMgQ3VzdG9tIHByb3ZpZGVycyB0byBhcHBseSB0byB0aGUgY29tcG9uZW50LlxuICAgKi9cbiAgcHVibGljIGF0dGFjaENvbXBvbmVudDxDPihcbiAgICBjb21wb25lbnQ6IFR5cGU8Qz4sXG4gICAgcHJvdmlkZXJzPzogU3RhdGljUHJvdmlkZXJbXVxuICApOiBDIHtcbiAgICBjb25zdCBjb21wb25lbnRSZWYgPSB0aGlzLmNvbXBvbmVudFJlZi5pbnN0YW5jZS5hdHRhY2hDb21wb25lbnQoXG4gICAgICBjb21wb25lbnQsXG4gICAgICBwcm92aWRlcnNcbiAgICApO1xuICAgIHJldHVybiBjb21wb25lbnRSZWYuaW5zdGFuY2U7XG4gIH1cblxuICAvKipcbiAgICogQXR0YWNoZXMgYSBgVGVtcGxhdGVSZWZgIHRvIHRoZSBvdmVybGF5LlxuICAgKiBAcGFyYW0gdGVtcGxhdGVSZWYgVGhlIGBUZW1wbGF0ZVJlZmAgdG8gYXR0YWNoLlxuICAgKiBAcGFyYW0gY29udGV4dCBUaGUgY29udGV4dCB0byBwcm92aWRlIHRvIHRoZSB0ZW1wbGF0ZS5cbiAgICovXG4gIHB1YmxpYyBhdHRhY2hUZW1wbGF0ZTxUPih0ZW1wbGF0ZVJlZjogVGVtcGxhdGVSZWY8VD4sIGNvbnRleHQ/OiBUKTogdm9pZCB7XG4gICAgdGhpcy5jb21wb25lbnRSZWYuaW5zdGFuY2UuYXR0YWNoVGVtcGxhdGUodGVtcGxhdGVSZWYsIGNvbnRleHQpO1xuICB9XG59XG4iXX0=
|
@@ -1,3 +1,5 @@
|
|
1
|
+
var _SkyOverlayComponent_instances, _SkyOverlayComponent_backdropClick, _SkyOverlayComponent_backdropClickObs, _SkyOverlayComponent_changeDetector, _SkyOverlayComponent_closed, _SkyOverlayComponent_closedObs, _SkyOverlayComponent_context, _SkyOverlayComponent_coreAdapter, _SkyOverlayComponent_injector, _SkyOverlayComponent_ngUnsubscribe, _SkyOverlayComponent_resolver, _SkyOverlayComponent_router, _SkyOverlayComponent_routerSubscription, _SkyOverlayComponent_applyConfig, _SkyOverlayComponent_addBackdropClickListener, _SkyOverlayComponent_addRouteListener, _SkyOverlayComponent_removeRouteListener;
|
2
|
+
import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
|
1
3
|
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ComponentFactoryResolver, ElementRef, HostBinding, Injector, Optional, ViewChild, ViewContainerRef, } from '@angular/core';
|
2
4
|
import { NavigationStart, Router } from '@angular/router';
|
3
5
|
import { Subject, fromEvent } from 'rxjs';
|
@@ -29,51 +31,70 @@ let uniqueZIndex = 5000;
|
|
29
31
|
* @internal
|
30
32
|
*/
|
31
33
|
export class SkyOverlayComponent {
|
34
|
+
// TODO: Replace deprecated `ComponentFactoryResolver`.
|
32
35
|
constructor(changeDetector, resolver, injector, coreAdapter, context, idSvc, router) {
|
33
|
-
this
|
34
|
-
this.resolver = resolver;
|
35
|
-
this.injector = injector;
|
36
|
-
this.coreAdapter = coreAdapter;
|
37
|
-
this.context = context;
|
38
|
-
this.router = router;
|
36
|
+
_SkyOverlayComponent_instances.add(this);
|
39
37
|
this.wrapperClass = '';
|
40
38
|
this.enablePointerEvents = false;
|
41
39
|
this.showBackdrop = false;
|
42
40
|
this.zIndex = `${++uniqueZIndex}`;
|
43
|
-
this
|
44
|
-
this
|
45
|
-
this
|
41
|
+
_SkyOverlayComponent_backdropClick.set(this, void 0);
|
42
|
+
_SkyOverlayComponent_backdropClickObs.set(this, void 0);
|
43
|
+
_SkyOverlayComponent_changeDetector.set(this, void 0);
|
44
|
+
_SkyOverlayComponent_closed.set(this, void 0);
|
45
|
+
_SkyOverlayComponent_closedObs.set(this, void 0);
|
46
|
+
_SkyOverlayComponent_context.set(this, void 0);
|
47
|
+
_SkyOverlayComponent_coreAdapter.set(this, void 0);
|
48
|
+
_SkyOverlayComponent_injector.set(this, void 0);
|
49
|
+
_SkyOverlayComponent_ngUnsubscribe.set(this, new Subject());
|
50
|
+
_SkyOverlayComponent_resolver.set(this, void 0);
|
51
|
+
_SkyOverlayComponent_router.set(this, void 0);
|
52
|
+
_SkyOverlayComponent_routerSubscription.set(this, void 0);
|
53
|
+
__classPrivateFieldSet(this, _SkyOverlayComponent_changeDetector, changeDetector, "f");
|
54
|
+
__classPrivateFieldSet(this, _SkyOverlayComponent_resolver, resolver, "f");
|
55
|
+
__classPrivateFieldSet(this, _SkyOverlayComponent_injector, injector, "f");
|
56
|
+
__classPrivateFieldSet(this, _SkyOverlayComponent_coreAdapter, coreAdapter, "f");
|
57
|
+
__classPrivateFieldSet(this, _SkyOverlayComponent_context, context, "f");
|
58
|
+
__classPrivateFieldSet(this, _SkyOverlayComponent_router, router, "f");
|
46
59
|
this.id = idSvc.generateId();
|
60
|
+
__classPrivateFieldSet(this, _SkyOverlayComponent_backdropClick, new Subject(), "f");
|
61
|
+
__classPrivateFieldSet(this, _SkyOverlayComponent_closed, new Subject(), "f");
|
62
|
+
__classPrivateFieldSet(this, _SkyOverlayComponent_backdropClickObs, __classPrivateFieldGet(this, _SkyOverlayComponent_backdropClick, "f").asObservable(), "f");
|
63
|
+
__classPrivateFieldSet(this, _SkyOverlayComponent_closedObs, __classPrivateFieldGet(this, _SkyOverlayComponent_closed, "f").asObservable(), "f");
|
47
64
|
}
|
48
65
|
get backdropClick() {
|
49
|
-
return this
|
66
|
+
return __classPrivateFieldGet(this, _SkyOverlayComponent_backdropClickObs, "f");
|
50
67
|
}
|
51
68
|
get closed() {
|
52
|
-
return this
|
69
|
+
return __classPrivateFieldGet(this, _SkyOverlayComponent_closedObs, "f");
|
53
70
|
}
|
54
71
|
ngOnInit() {
|
55
|
-
this.
|
72
|
+
__classPrivateFieldGet(this, _SkyOverlayComponent_instances, "m", _SkyOverlayComponent_applyConfig).call(this, __classPrivateFieldGet(this, _SkyOverlayComponent_context, "f").config);
|
56
73
|
setTimeout(() => {
|
57
|
-
this.
|
74
|
+
__classPrivateFieldGet(this, _SkyOverlayComponent_instances, "m", _SkyOverlayComponent_addBackdropClickListener).call(this);
|
58
75
|
});
|
59
|
-
if (this.
|
60
|
-
this.
|
76
|
+
if (__classPrivateFieldGet(this, _SkyOverlayComponent_context, "f").config.closeOnNavigation) {
|
77
|
+
__classPrivateFieldGet(this, _SkyOverlayComponent_instances, "m", _SkyOverlayComponent_addRouteListener).call(this);
|
61
78
|
}
|
62
79
|
}
|
63
80
|
ngOnDestroy() {
|
64
|
-
this.
|
65
|
-
this.
|
66
|
-
this.
|
67
|
-
this.
|
68
|
-
this.
|
69
|
-
this.
|
81
|
+
__classPrivateFieldGet(this, _SkyOverlayComponent_instances, "m", _SkyOverlayComponent_removeRouteListener).call(this);
|
82
|
+
__classPrivateFieldGet(this, _SkyOverlayComponent_ngUnsubscribe, "f").next();
|
83
|
+
__classPrivateFieldGet(this, _SkyOverlayComponent_ngUnsubscribe, "f").complete();
|
84
|
+
__classPrivateFieldGet(this, _SkyOverlayComponent_backdropClick, "f").complete();
|
85
|
+
__classPrivateFieldGet(this, _SkyOverlayComponent_closed, "f").next();
|
86
|
+
__classPrivateFieldGet(this, _SkyOverlayComponent_closed, "f").complete();
|
70
87
|
}
|
71
88
|
attachComponent(component, providers = []) {
|
89
|
+
/*istanbul ignore if: untestable*/
|
90
|
+
if (!this.targetRef) {
|
91
|
+
throw new Error('[SkyOverlayComponent] Could not attach the component because the target element could not be found.');
|
92
|
+
}
|
72
93
|
this.targetRef.clear();
|
73
|
-
const factory = this.
|
94
|
+
const factory = __classPrivateFieldGet(this, _SkyOverlayComponent_resolver, "f").resolveComponentFactory(component);
|
74
95
|
const injector = Injector.create({
|
75
96
|
providers,
|
76
|
-
parent: this
|
97
|
+
parent: __classPrivateFieldGet(this, _SkyOverlayComponent_injector, "f"),
|
77
98
|
});
|
78
99
|
const componentRef = this.targetRef.createComponent(factory, undefined, injector);
|
79
100
|
// Run an initial change detection cycle after the component has been created.
|
@@ -81,48 +102,51 @@ export class SkyOverlayComponent {
|
|
81
102
|
return componentRef;
|
82
103
|
}
|
83
104
|
attachTemplate(templateRef, context) {
|
105
|
+
/*istanbul ignore if: untestable*/
|
106
|
+
if (!this.targetRef) {
|
107
|
+
throw new Error('[SkyOverlayComponent] Could not attach the template because the target element could not be found.');
|
108
|
+
}
|
84
109
|
this.targetRef.clear();
|
85
110
|
return this.targetRef.createEmbeddedView(templateRef, context);
|
86
111
|
}
|
87
|
-
|
88
|
-
|
89
|
-
|
90
|
-
|
91
|
-
|
92
|
-
|
93
|
-
|
94
|
-
|
95
|
-
|
96
|
-
|
112
|
+
}
|
113
|
+
_SkyOverlayComponent_backdropClick = new WeakMap(), _SkyOverlayComponent_backdropClickObs = new WeakMap(), _SkyOverlayComponent_changeDetector = new WeakMap(), _SkyOverlayComponent_closed = new WeakMap(), _SkyOverlayComponent_closedObs = new WeakMap(), _SkyOverlayComponent_context = new WeakMap(), _SkyOverlayComponent_coreAdapter = new WeakMap(), _SkyOverlayComponent_injector = new WeakMap(), _SkyOverlayComponent_ngUnsubscribe = new WeakMap(), _SkyOverlayComponent_resolver = new WeakMap(), _SkyOverlayComponent_router = new WeakMap(), _SkyOverlayComponent_routerSubscription = new WeakMap(), _SkyOverlayComponent_instances = new WeakSet(), _SkyOverlayComponent_applyConfig = function _SkyOverlayComponent_applyConfig(config) {
|
114
|
+
this.wrapperClass = config.wrapperClass || '';
|
115
|
+
this.showBackdrop = !!config.showBackdrop;
|
116
|
+
this.enablePointerEvents = !!config.enablePointerEvents;
|
117
|
+
__classPrivateFieldGet(this, _SkyOverlayComponent_changeDetector, "f").markForCheck();
|
118
|
+
}, _SkyOverlayComponent_addBackdropClickListener = function _SkyOverlayComponent_addBackdropClickListener() {
|
119
|
+
fromEvent(window.document, 'click')
|
120
|
+
.pipe(takeUntil(__classPrivateFieldGet(this, _SkyOverlayComponent_ngUnsubscribe, "f")))
|
121
|
+
.subscribe((event) => {
|
122
|
+
if (event.target && this.overlayContentRef && this.overlayRef) {
|
97
123
|
const isChild = this.overlayContentRef.nativeElement.contains(event.target);
|
98
|
-
const isAbove = this.
|
124
|
+
const isAbove = __classPrivateFieldGet(this, _SkyOverlayComponent_coreAdapter, "f").isTargetAboveElement(event.target, this.overlayRef.nativeElement);
|
99
125
|
/* istanbul ignore else */
|
100
126
|
if (!isChild && !isAbove) {
|
101
|
-
this.
|
102
|
-
if (this.
|
103
|
-
this.
|
127
|
+
__classPrivateFieldGet(this, _SkyOverlayComponent_backdropClick, "f").next();
|
128
|
+
if (__classPrivateFieldGet(this, _SkyOverlayComponent_context, "f").config.enableClose) {
|
129
|
+
__classPrivateFieldGet(this, _SkyOverlayComponent_closed, "f").next();
|
104
130
|
}
|
105
131
|
}
|
106
|
-
});
|
107
|
-
}
|
108
|
-
addRouteListener() {
|
109
|
-
/*istanbul ignore else*/
|
110
|
-
if (this.router) {
|
111
|
-
this.routerSubscription = this.router.events.subscribe((event) => {
|
112
|
-
/* istanbul ignore else */
|
113
|
-
if (event instanceof NavigationStart) {
|
114
|
-
this._closed.next();
|
115
|
-
}
|
116
|
-
});
|
117
132
|
}
|
133
|
+
});
|
134
|
+
}, _SkyOverlayComponent_addRouteListener = function _SkyOverlayComponent_addRouteListener() {
|
135
|
+
/*istanbul ignore else*/
|
136
|
+
if (__classPrivateFieldGet(this, _SkyOverlayComponent_router, "f")) {
|
137
|
+
__classPrivateFieldSet(this, _SkyOverlayComponent_routerSubscription, __classPrivateFieldGet(this, _SkyOverlayComponent_router, "f").events.subscribe((event) => {
|
138
|
+
/* istanbul ignore else */
|
139
|
+
if (event instanceof NavigationStart) {
|
140
|
+
__classPrivateFieldGet(this, _SkyOverlayComponent_closed, "f").next();
|
141
|
+
}
|
142
|
+
}), "f");
|
118
143
|
}
|
119
|
-
|
120
|
-
|
121
|
-
|
122
|
-
|
123
|
-
}
|
144
|
+
}, _SkyOverlayComponent_removeRouteListener = function _SkyOverlayComponent_removeRouteListener() {
|
145
|
+
if (__classPrivateFieldGet(this, _SkyOverlayComponent_routerSubscription, "f")) {
|
146
|
+
__classPrivateFieldGet(this, _SkyOverlayComponent_routerSubscription, "f").unsubscribe();
|
147
|
+
__classPrivateFieldSet(this, _SkyOverlayComponent_routerSubscription, undefined, "f");
|
124
148
|
}
|
125
|
-
}
|
149
|
+
};
|
126
150
|
SkyOverlayComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyOverlayComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.ComponentFactoryResolver }, { token: i0.Injector }, { token: i1.SkyCoreAdapterService }, { token: i2.SkyOverlayContext }, { token: i3.SkyIdService }, { token: i4.Router, optional: true }], target: i0.ɵɵFactoryTarget.Component });
|
127
151
|
SkyOverlayComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.2", type: SkyOverlayComponent, selector: "sky-overlay", host: { properties: { "id": "this.id" } }, viewQueries: [{ propertyName: "overlayContentRef", first: true, predicate: ["overlayContentRef"], descendants: true, read: ElementRef, static: true }, { propertyName: "overlayRef", first: true, predicate: ["overlayRef"], descendants: true, read: ElementRef, static: true }, { propertyName: "targetRef", first: true, predicate: ["target"], descendants: true, read: ViewContainerRef, static: true }], ngImport: i0, template: "<div\n [class]=\"wrapperClass\"\n [style.zIndex]=\"zIndex\"\n [ngClass]=\"{\n 'enable-pointer-events-pass-through': enablePointerEvents,\n 'sky-overlay': true\n }\"\n #overlayRef\n>\n <div class=\"sky-overlay-content\" #overlayContentRef>\n <ng-template #target> </ng-template>\n </div>\n <div *ngIf=\"showBackdrop\" class=\"sky-overlay-backdrop\"></div>\n</div>\n", styles: [".sky-overlay{position:fixed;top:0;right:0;left:0;bottom:0;width:100%;height:100%;display:flex;pointer-events:auto}.sky-overlay-content{position:relative;z-index:1;display:inline-flex;align-self:start;pointer-events:auto}.sky-overlay-backdrop{background:rgba(0,0,0,.5);top:0;right:0;left:0;bottom:0;width:100%;height:100%;position:absolute}.enable-pointer-events-pass-through,.enable-pointer-events-pass-through .sky-overlay-backdrop{pointer-events:none}.enable-pointer-events-pass-through .sky-overlay-content{pointer-events:auto}\n"], directives: [{ type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
128
152
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyOverlayComponent, decorators: [{
|
@@ -152,4 +176,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
|
|
152
176
|
static: true,
|
153
177
|
}]
|
154
178
|
}] } });
|
155
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"overlay.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/core/src/lib/modules/overlay/overlay.component.ts","../../../../../../../../libs/components/core/src/lib/modules/overlay/overlay.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ComponentFactoryResolver,\n  ComponentRef,\n  ElementRef,\n  EmbeddedViewRef,\n  HostBinding,\n  Injector,\n  OnDestroy,\n  OnInit,\n  Optional,\n  StaticProvider,\n  TemplateRef,\n  Type,\n  ViewChild,\n  ViewContainerRef,\n} from '@angular/core';\nimport { NavigationStart, Router } from '@angular/router';\n\nimport { Observable, Subject, Subscription, fromEvent } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyCoreAdapterService } from '../adapter-service/adapter.service';\nimport { SkyIdService } from '../id/id.service';\n\nimport { SkyOverlayConfig } from './overlay-config';\nimport { SkyOverlayContext } from './overlay-context';\n\n/**\n * Omnibar is 1000.\n * See: https://github.com/blackbaud/auth-client/blob/master/src/omnibar/omnibar.ts#L139\n * ---\n * Modals start their z-indexes at 1040. However, each modal's z-index is a multiple of 10, so it\n * will be difficult to reliably predict a z-index that will always appear above all other\n * layers. Starting the z-index for overlays at a number much greater than modals will accommodate\n * the most reasonable of scenarios.\n * See: https://github.com/blackbaud/skyux-modals/blob/master/src/app/public/modules/modal/modal-host.service.ts#L22\n * (NOTE: It should be noted that modals do not use the overlay service, which is something we\n * should do in the near future to make sure z-indexes are predictable across all component\n * libraries.)\n */\nlet uniqueZIndex = 5000;\n\n/**\n * @internal\n */\n@Component({\n  selector: 'sky-overlay',\n  templateUrl: './overlay.component.html',\n  styleUrls: ['./overlay.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class SkyOverlayComponent implements OnInit, OnDestroy {\n  public wrapperClass = '';\n\n  public get backdropClick(): Observable<void> {\n    return this._backdropClick.asObservable();\n  }\n\n  public get closed(): Observable<void> {\n    return this._closed.asObservable();\n  }\n\n  public enablePointerEvents = false;\n\n  @HostBinding('id')\n  public id: string;\n\n  public showBackdrop = false;\n\n  public zIndex = `${++uniqueZIndex}`;\n\n  @ViewChild('overlayContentRef', {\n    read: ElementRef,\n    static: true,\n  })\n  private overlayContentRef: ElementRef;\n\n  @ViewChild('overlayRef', {\n    read: ElementRef,\n    static: true,\n  })\n  private overlayRef: ElementRef;\n\n  @ViewChild('target', {\n    read: ViewContainerRef,\n    static: true,\n  })\n  private targetRef: ViewContainerRef;\n\n  private ngUnsubscribe = new Subject<void>();\n\n  private routerSubscription: Subscription;\n\n  private _backdropClick = new Subject<void>();\n\n  private _closed = new Subject<void>();\n\n  constructor(\n    private changeDetector: ChangeDetectorRef,\n    private resolver: ComponentFactoryResolver,\n    private injector: Injector,\n    private coreAdapter: SkyCoreAdapterService,\n    private context: SkyOverlayContext,\n    idSvc: SkyIdService,\n    @Optional() private router?: Router\n  ) {\n    this.id = idSvc.generateId();\n  }\n\n  public ngOnInit(): void {\n    this.applyConfig(this.context.config);\n\n    setTimeout(() => {\n      this.addBackdropClickListener();\n    });\n\n    if (this.context.config.closeOnNavigation) {\n      this.addRouteListener();\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this.removeRouteListener();\n    this.ngUnsubscribe.next();\n    this.ngUnsubscribe.complete();\n\n    this._backdropClick.complete();\n\n    this._closed.next();\n    this._closed.complete();\n  }\n\n  public attachComponent<C>(\n    component: Type<C>,\n    providers: StaticProvider[] = []\n  ): ComponentRef<C> {\n    this.targetRef.clear();\n\n    const factory = this.resolver.resolveComponentFactory(component);\n    const injector = Injector.create({\n      providers,\n      parent: this.injector,\n    });\n\n    const componentRef = this.targetRef.createComponent<C>(\n      factory,\n      undefined,\n      injector\n    );\n\n    // Run an initial change detection cycle after the component has been created.\n    componentRef.changeDetectorRef.detectChanges();\n\n    return componentRef;\n  }\n\n  public attachTemplate<T>(\n    templateRef: TemplateRef<T>,\n    context: T\n  ): EmbeddedViewRef<T> {\n    this.targetRef.clear();\n\n    return this.targetRef.createEmbeddedView(templateRef, context);\n  }\n\n  private applyConfig(config: SkyOverlayConfig): void {\n    this.wrapperClass = config.wrapperClass || '';\n    this.showBackdrop = config.showBackdrop;\n    this.enablePointerEvents = config.enablePointerEvents;\n    this.changeDetector.markForCheck();\n  }\n\n  private addBackdropClickListener(): void {\n    fromEvent(window.document, 'click')\n      .pipe(takeUntil(this.ngUnsubscribe))\n      .subscribe((event: MouseEvent) => {\n        const isChild = this.overlayContentRef.nativeElement.contains(\n          event.target\n        );\n        const isAbove = this.coreAdapter.isTargetAboveElement(\n          event.target,\n          this.overlayRef.nativeElement\n        );\n\n        /* istanbul ignore else */\n        if (!isChild && !isAbove) {\n          this._backdropClick.next();\n          if (this.context.config.enableClose) {\n            this._closed.next();\n          }\n        }\n      });\n  }\n\n  private addRouteListener(): void {\n    /*istanbul ignore else*/\n    if (this.router) {\n      this.routerSubscription = this.router.events.subscribe((event) => {\n        /* istanbul ignore else */\n        if (event instanceof NavigationStart) {\n          this._closed.next();\n        }\n      });\n    }\n  }\n\n  private removeRouteListener(): void {\n    if (this.routerSubscription) {\n      this.routerSubscription.unsubscribe();\n      this.routerSubscription = undefined;\n    }\n  }\n}\n","<div\n  [class]=\"wrapperClass\"\n  [style.zIndex]=\"zIndex\"\n  [ngClass]=\"{\n    'enable-pointer-events-pass-through': enablePointerEvents,\n    'sky-overlay': true\n  }\"\n  #overlayRef\n>\n  <div class=\"sky-overlay-content\" #overlayContentRef>\n    <ng-template #target> </ng-template>\n  </div>\n  <div *ngIf=\"showBackdrop\" class=\"sky-overlay-backdrop\"></div>\n</div>\n"]}
|
179
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"overlay.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/core/src/lib/modules/overlay/overlay.component.ts","../../../../../../../../libs/components/core/src/lib/modules/overlay/overlay.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ComponentFactoryResolver,\n  ComponentRef,\n  ElementRef,\n  EmbeddedViewRef,\n  HostBinding,\n  Injector,\n  OnDestroy,\n  OnInit,\n  Optional,\n  StaticProvider,\n  TemplateRef,\n  Type,\n  ViewChild,\n  ViewContainerRef,\n} from '@angular/core';\nimport { NavigationStart, Router } from '@angular/router';\n\nimport { Observable, Subject, Subscription, fromEvent } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyCoreAdapterService } from '../adapter-service/adapter.service';\nimport { SkyIdService } from '../id/id.service';\n\nimport { SkyOverlayConfig } from './overlay-config';\nimport { SkyOverlayContext } from './overlay-context';\n\n/**\n * Omnibar is 1000.\n * See: https://github.com/blackbaud/auth-client/blob/master/src/omnibar/omnibar.ts#L139\n * ---\n * Modals start their z-indexes at 1040. However, each modal's z-index is a multiple of 10, so it\n * will be difficult to reliably predict a z-index that will always appear above all other\n * layers. Starting the z-index for overlays at a number much greater than modals will accommodate\n * the most reasonable of scenarios.\n * See: https://github.com/blackbaud/skyux-modals/blob/master/src/app/public/modules/modal/modal-host.service.ts#L22\n * (NOTE: It should be noted that modals do not use the overlay service, which is something we\n * should do in the near future to make sure z-indexes are predictable across all component\n * libraries.)\n */\nlet uniqueZIndex = 5000;\n\n/**\n * @internal\n */\n@Component({\n  selector: 'sky-overlay',\n  templateUrl: './overlay.component.html',\n  styleUrls: ['./overlay.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class SkyOverlayComponent implements OnInit, OnDestroy {\n  public wrapperClass = '';\n\n  public get backdropClick(): Observable<void> {\n    return this.#backdropClickObs;\n  }\n\n  public get closed(): Observable<void> {\n    return this.#closedObs;\n  }\n\n  public enablePointerEvents = false;\n\n  @HostBinding('id')\n  public id: string;\n\n  public showBackdrop = false;\n\n  public zIndex = `${++uniqueZIndex}`;\n\n  @ViewChild('overlayContentRef', {\n    read: ElementRef,\n    static: true,\n  })\n  private overlayContentRef: ElementRef | undefined;\n\n  @ViewChild('overlayRef', {\n    read: ElementRef,\n    static: true,\n  })\n  private overlayRef: ElementRef | undefined;\n\n  @ViewChild('target', {\n    read: ViewContainerRef,\n    static: true,\n  })\n  private targetRef: ViewContainerRef | undefined;\n\n  #backdropClick: Subject<void>;\n\n  #backdropClickObs: Observable<void>;\n\n  #changeDetector: ChangeDetectorRef;\n\n  #closed: Subject<void>;\n\n  #closedObs: Observable<void>;\n\n  #context: SkyOverlayContext;\n\n  #coreAdapter: SkyCoreAdapterService;\n\n  #injector: Injector;\n\n  #ngUnsubscribe = new Subject<void>();\n\n  #resolver: ComponentFactoryResolver;\n\n  #router: Router | undefined;\n\n  #routerSubscription: Subscription | undefined;\n\n  // TODO: Replace deprecated `ComponentFactoryResolver`.\n  constructor(\n    changeDetector: ChangeDetectorRef,\n    resolver: ComponentFactoryResolver,\n    injector: Injector,\n    coreAdapter: SkyCoreAdapterService,\n    context: SkyOverlayContext,\n    idSvc: SkyIdService,\n    @Optional() router?: Router\n  ) {\n    this.#changeDetector = changeDetector;\n    this.#resolver = resolver;\n    this.#injector = injector;\n    this.#coreAdapter = coreAdapter;\n    this.#context = context;\n    this.#router = router;\n\n    this.id = idSvc.generateId();\n\n    this.#backdropClick = new Subject<void>();\n    this.#closed = new Subject<void>();\n\n    this.#backdropClickObs = this.#backdropClick.asObservable();\n    this.#closedObs = this.#closed.asObservable();\n  }\n\n  public ngOnInit(): void {\n    this.#applyConfig(this.#context.config);\n\n    setTimeout(() => {\n      this.#addBackdropClickListener();\n    });\n\n    if (this.#context.config.closeOnNavigation) {\n      this.#addRouteListener();\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this.#removeRouteListener();\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n\n    this.#backdropClick.complete();\n\n    this.#closed.next();\n    this.#closed.complete();\n  }\n\n  public attachComponent<C>(\n    component: Type<C>,\n    providers: StaticProvider[] = []\n  ): ComponentRef<C> {\n    /*istanbul ignore if: untestable*/\n    if (!this.targetRef) {\n      throw new Error(\n        '[SkyOverlayComponent] Could not attach the component because the target element could not be found.'\n      );\n    }\n\n    this.targetRef.clear();\n\n    const factory = this.#resolver.resolveComponentFactory(component);\n    const injector = Injector.create({\n      providers,\n      parent: this.#injector,\n    });\n\n    const componentRef = this.targetRef.createComponent<C>(\n      factory,\n      undefined,\n      injector\n    );\n\n    // Run an initial change detection cycle after the component has been created.\n    componentRef.changeDetectorRef.detectChanges();\n\n    return componentRef;\n  }\n\n  public attachTemplate<T>(\n    templateRef: TemplateRef<T>,\n    context: T\n  ): EmbeddedViewRef<T> {\n    /*istanbul ignore if: untestable*/\n    if (!this.targetRef) {\n      throw new Error(\n        '[SkyOverlayComponent] Could not attach the template because the target element could not be found.'\n      );\n    }\n\n    this.targetRef.clear();\n\n    return this.targetRef.createEmbeddedView(templateRef, context);\n  }\n\n  #applyConfig(config: SkyOverlayConfig): void {\n    this.wrapperClass = config.wrapperClass || '';\n    this.showBackdrop = !!config.showBackdrop;\n    this.enablePointerEvents = !!config.enablePointerEvents;\n    this.#changeDetector.markForCheck();\n  }\n\n  #addBackdropClickListener(): void {\n    fromEvent<MouseEvent>(window.document, 'click')\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((event) => {\n        if (event.target && this.overlayContentRef && this.overlayRef) {\n          const isChild = this.overlayContentRef.nativeElement.contains(\n            event.target\n          );\n\n          const isAbove = this.#coreAdapter.isTargetAboveElement(\n            event.target,\n            this.overlayRef.nativeElement\n          );\n\n          /* istanbul ignore else */\n          if (!isChild && !isAbove) {\n            this.#backdropClick.next();\n            if (this.#context.config.enableClose) {\n              this.#closed.next();\n            }\n          }\n        }\n      });\n  }\n\n  #addRouteListener(): void {\n    /*istanbul ignore else*/\n    if (this.#router) {\n      this.#routerSubscription = this.#router.events.subscribe((event) => {\n        /* istanbul ignore else */\n        if (event instanceof NavigationStart) {\n          this.#closed.next();\n        }\n      });\n    }\n  }\n\n  #removeRouteListener(): void {\n    if (this.#routerSubscription) {\n      this.#routerSubscription.unsubscribe();\n      this.#routerSubscription = undefined;\n    }\n  }\n}\n","<div\n  [class]=\"wrapperClass\"\n  [style.zIndex]=\"zIndex\"\n  [ngClass]=\"{\n    'enable-pointer-events-pass-through': enablePointerEvents,\n    'sky-overlay': true\n  }\"\n  #overlayRef\n>\n  <div class=\"sky-overlay-content\" #overlayContentRef>\n    <ng-template #target> </ng-template>\n  </div>\n  <div *ngIf=\"showBackdrop\" class=\"sky-overlay-backdrop\"></div>\n</div>\n"]}
|
@@ -1,3 +1,5 @@
|
|
1
|
+
var _SkyOverlayService_instances, _SkyOverlayService_adapter, _SkyOverlayService_applicationRef, _SkyOverlayService_componentFactoryResolver, _SkyOverlayService_injector, _SkyOverlayService_createOverlay, _SkyOverlayService_prepareConfig, _SkyOverlayService_destroyOverlay;
|
2
|
+
import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
|
1
3
|
import { ApplicationRef, ComponentFactoryResolver, Injectable, Injector, } from '@angular/core';
|
2
4
|
import { SkyOverlayAdapterService } from './overlay-adapter.service';
|
3
5
|
import { SkyOverlayContext } from './overlay-context';
|
@@ -10,22 +12,28 @@ import * as i1 from "./overlay-adapter.service";
|
|
10
12
|
* @dynamic
|
11
13
|
*/
|
12
14
|
export class SkyOverlayService {
|
15
|
+
// TODO: Replace deprecated `ComponentFactoryResolver`.
|
13
16
|
constructor(applicationRef, componentFactoryResolver, injector, adapter) {
|
14
|
-
this
|
15
|
-
this
|
16
|
-
this
|
17
|
-
this
|
17
|
+
_SkyOverlayService_instances.add(this);
|
18
|
+
_SkyOverlayService_adapter.set(this, void 0);
|
19
|
+
_SkyOverlayService_applicationRef.set(this, void 0);
|
20
|
+
_SkyOverlayService_componentFactoryResolver.set(this, void 0);
|
21
|
+
_SkyOverlayService_injector.set(this, void 0);
|
22
|
+
__classPrivateFieldSet(this, _SkyOverlayService_applicationRef, applicationRef, "f");
|
23
|
+
__classPrivateFieldSet(this, _SkyOverlayService_componentFactoryResolver, componentFactoryResolver, "f");
|
24
|
+
__classPrivateFieldSet(this, _SkyOverlayService_injector, injector, "f");
|
25
|
+
__classPrivateFieldSet(this, _SkyOverlayService_adapter, adapter, "f");
|
18
26
|
}
|
19
27
|
/**
|
20
28
|
* Creates an empty overlay. Use the returned `SkyOverlayInstance` to append content.
|
21
29
|
* @param config Configuration for the overlay.
|
22
30
|
*/
|
23
31
|
create(config) {
|
24
|
-
const settings = this.
|
32
|
+
const settings = __classPrivateFieldGet(this, _SkyOverlayService_instances, "m", _SkyOverlayService_prepareConfig).call(this, config);
|
25
33
|
if (settings.enableScroll === false) {
|
26
|
-
this.
|
34
|
+
__classPrivateFieldGet(this, _SkyOverlayService_adapter, "f").restrictBodyScroll();
|
27
35
|
}
|
28
|
-
const componentRef = this.
|
36
|
+
const componentRef = __classPrivateFieldGet(this, _SkyOverlayService_instances, "m", _SkyOverlayService_createOverlay).call(this, settings);
|
29
37
|
const instance = new SkyOverlayInstance(settings, componentRef);
|
30
38
|
instance.closed.subscribe(() => {
|
31
39
|
// Only execute the service's close method if the instance still exists.
|
@@ -42,8 +50,8 @@ export class SkyOverlayService {
|
|
42
50
|
* @param instance The instance to close.
|
43
51
|
*/
|
44
52
|
close(instance) {
|
45
|
-
this.
|
46
|
-
this.
|
53
|
+
__classPrivateFieldGet(this, _SkyOverlayService_instances, "m", _SkyOverlayService_destroyOverlay).call(this, instance);
|
54
|
+
__classPrivateFieldGet(this, _SkyOverlayService_applicationRef, "f").detachView(instance.componentRef.hostView);
|
47
55
|
instance.componentRef.destroy();
|
48
56
|
// In some cases, Angular keeps dynamically-generated component's nodes in the DOM during
|
49
57
|
// unit tests. This can make querying difficult because the older DOM nodes still exist and
|
@@ -67,47 +75,45 @@ export class SkyOverlayService {
|
|
67
75
|
this.close(SkyOverlayService.overlays[0]);
|
68
76
|
}
|
69
77
|
}
|
70
|
-
|
71
|
-
|
72
|
-
|
73
|
-
|
74
|
-
|
75
|
-
|
76
|
-
|
77
|
-
|
78
|
-
|
79
|
-
|
80
|
-
|
81
|
-
|
82
|
-
|
83
|
-
|
84
|
-
|
85
|
-
|
86
|
-
|
87
|
-
|
88
|
-
|
89
|
-
|
90
|
-
|
91
|
-
|
92
|
-
|
93
|
-
|
94
|
-
|
95
|
-
|
96
|
-
|
97
|
-
|
98
|
-
|
99
|
-
|
100
|
-
|
101
|
-
|
102
|
-
if
|
103
|
-
|
104
|
-
|
105
|
-
|
106
|
-
this.adapter.releaseBodyScroll();
|
107
|
-
}
|
78
|
+
}
|
79
|
+
_SkyOverlayService_adapter = new WeakMap(), _SkyOverlayService_applicationRef = new WeakMap(), _SkyOverlayService_componentFactoryResolver = new WeakMap(), _SkyOverlayService_injector = new WeakMap(), _SkyOverlayService_instances = new WeakSet(), _SkyOverlayService_createOverlay = function _SkyOverlayService_createOverlay(config) {
|
80
|
+
const injector = Injector.create({
|
81
|
+
parent: __classPrivateFieldGet(this, _SkyOverlayService_injector, "f"),
|
82
|
+
providers: [
|
83
|
+
{
|
84
|
+
provide: SkyOverlayContext,
|
85
|
+
useValue: new SkyOverlayContext(config),
|
86
|
+
},
|
87
|
+
],
|
88
|
+
});
|
89
|
+
const componentRef = __classPrivateFieldGet(this, _SkyOverlayService_componentFactoryResolver, "f")
|
90
|
+
.resolveComponentFactory(SkyOverlayComponent)
|
91
|
+
.create(injector);
|
92
|
+
__classPrivateFieldGet(this, _SkyOverlayService_applicationRef, "f").attachView(componentRef.hostView);
|
93
|
+
const domElem = componentRef.hostView
|
94
|
+
.rootNodes[0];
|
95
|
+
document.body.appendChild(domElem);
|
96
|
+
return componentRef;
|
97
|
+
}, _SkyOverlayService_prepareConfig = function _SkyOverlayService_prepareConfig(config = {}) {
|
98
|
+
const defaults = {
|
99
|
+
closeOnNavigation: true,
|
100
|
+
enableClose: false,
|
101
|
+
enablePointerEvents: false,
|
102
|
+
enableScroll: true,
|
103
|
+
showBackdrop: false,
|
104
|
+
wrapperClass: '',
|
105
|
+
};
|
106
|
+
return { ...defaults, ...config };
|
107
|
+
}, _SkyOverlayService_destroyOverlay = function _SkyOverlayService_destroyOverlay(instance) {
|
108
|
+
SkyOverlayService.overlays.splice(SkyOverlayService.overlays.indexOf(instance), 1);
|
109
|
+
if (instance.config.enableScroll === false) {
|
110
|
+
// Only release the body scroll if no other overlay wishes it to be disabled.
|
111
|
+
const anotherOverlayDisablesScroll = SkyOverlayService.overlays.some((o) => !o.config.enableScroll);
|
112
|
+
if (!anotherOverlayDisablesScroll) {
|
113
|
+
__classPrivateFieldGet(this, _SkyOverlayService_adapter, "f").releaseBodyScroll();
|
108
114
|
}
|
109
115
|
}
|
110
|
-
}
|
116
|
+
};
|
111
117
|
SkyOverlayService.overlays = [];
|
112
118
|
SkyOverlayService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyOverlayService, deps: [{ token: i0.ApplicationRef }, { token: i0.ComponentFactoryResolver }, { token: i0.Injector }, { token: i1.SkyOverlayAdapterService }], target: i0.ɵɵFactoryTarget.Injectable });
|
113
119
|
SkyOverlayService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyOverlayService, providedIn: 'root' });
|
@@ -117,4 +123,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
|
|
117
123
|
providedIn: 'root',
|
118
124
|
}]
|
119
125
|
}], ctorParameters: function () { return [{ type: i0.ApplicationRef }, { type: i0.ComponentFactoryResolver }, { type: i0.Injector }, { type: i1.SkyOverlayAdapterService }]; } });
|
120
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"overlay.service.js","sourceRoot":"","sources":["../../../../../../../../libs/components/core/src/lib/modules/overlay/overlay.service.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,cAAc,EACd,wBAAwB,EAGxB,UAAU,EACV,QAAQ,GACT,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,wBAAwB,EAAE,MAAM,2BAA2B,CAAC;AAErE,OAAO,EAAE,iBAAiB,EAAE,MAAM,mBAAmB,CAAC;AACtD,OAAO,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;AACxD,OAAO,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;;;AAE1D;;;GAGG;AAIH,MAAM,OAAO,iBAAiB;IAG5B,YACU,cAA8B,EAC9B,wBAAkD,EAClD,QAAkB,EAClB,OAAiC;QAHjC,mBAAc,GAAd,cAAc,CAAgB;QAC9B,6BAAwB,GAAxB,wBAAwB,CAA0B;QAClD,aAAQ,GAAR,QAAQ,CAAU;QAClB,YAAO,GAAP,OAAO,CAA0B;IACxC,CAAC;IAEJ;;;OAGG;IACI,MAAM,CAAC,MAAyB;QACrC,MAAM,QAAQ,GAAG,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;QAE5C,IAAI,QAAQ,CAAC,YAAY,KAAK,KAAK,EAAE;YACnC,IAAI,CAAC,OAAO,CAAC,kBAAkB,EAAE,CAAC;SACnC;QAED,MAAM,YAAY,GAAG,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;QAClD,MAAM,QAAQ,GAAG,IAAI,kBAAkB,CAAC,QAAQ,EAAE,YAAY,CAAC,CAAC;QAEhE,QAAQ,CAAC,MAAM,CAAC,SAAS,CAAC,GAAG,EAAE;YAC7B,wEAAwE;YACxE,sGAAsG;YACtG,IAAI,iBAAiB,CAAC,QAAQ,CAAC,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,EAAE;gBACrD,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;aACtB;QACH,CAAC,CAAC,CAAC;QAEH,iBAAiB,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAE1C,OAAO,QAAQ,CAAC;IAClB,CAAC;IAED;;;OAGG;IACI,KAAK,CAAC,QAA4B;QACvC,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC;QAC9B,IAAI,CAAC,cAAc,CAAC,UAAU,CAAC,QAAQ,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;QAC/D,QAAQ,CAAC,YAAY,CAAC,OAAO,EAAE,CAAC;QAEhC,yFAAyF;QACzF,2FAA2F;QAC3F,gCAAgC;QAChC,2DAA2D;QAC3D,kGAAkG;QAClG,iFAAiF;QACjF,MAAM,gBAAgB,GAAG,QAAQ,CAAC,YAAY,CAAC,QAAQ,CAAC,aAAa,CAAC;QACtE,wBAAwB;QACxB,IAAI,gBAAgB,CAAC,UAAU,KAAK,IAAI,EAAE;YACxC,gBAAgB,CAAC,UAAU,CAAC,WAAW,CAAC,gBAAgB,CAAC,CAAC;SAC3D;IACH,CAAC;IAED;;OAEG;IACI,QAAQ;QACb,wFAAwF;QACxF,4CAA4C;QAC5C,OAAO,iBAAiB,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE;YAC5C,IAAI,CAAC,KAAK,CAAC,iBAAiB,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC;SAC3C;IACH,CAAC;IAEO,aAAa,CACnB,MAAyB;QAEzB,MAAM,QAAQ,GAAG,QAAQ,CAAC,MAAM,CAAC;YAC/B,MAAM,EAAE,IAAI,CAAC,QAAQ;YACrB,SAAS,EAAE;gBACT;oBACE,OAAO,EAAE,iBAAiB;oBAC1B,QAAQ,EAAE,IAAI,iBAAiB,CAAC,MAAM,CAAC;iBACxC;aACF;SACF,CAAC,CAAC;QAEH,MAAM,YAAY,GAAG,IAAI,CAAC,wBAAwB;aAC/C,uBAAuB,CAAC,mBAAmB,CAAC;aAC5C,MAAM,CAAC,QAAQ,CAAC,CAAC;QAEpB,IAAI,CAAC,cAAc,CAAC,UAAU,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;QAEtD,MAAM,OAAO,GAAI,YAAY,CAAC,QAAiC;aAC5D,SAAS,CAAC,CAAC,CAAgB,CAAC;QAE/B,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;QAEnC,OAAO,YAAY,CAAC;IACtB,CAAC;IAEO,aAAa,CAAC,MAAwB;QAC5C,MAAM,QAAQ,GAAqB;YACjC,iBAAiB,EAAE,IAAI;YACvB,WAAW,EAAE,KAAK;YAClB,mBAAmB,EAAE,KAAK;YAC1B,YAAY,EAAE,IAAI;YAClB,YAAY,EAAE,KAAK;YACnB,YAAY,EAAE,EAAE;SACjB,CAAC;QAEF,OAAO,EAAE,GAAG,QAAQ,EAAE,GAAG,MAAM,EAAE,CAAC;IACpC,CAAC;IAEO,cAAc,CAAC,QAA4B;QACjD,iBAAiB,CAAC,QAAQ,CAAC,MAAM,CAC/B,iBAAiB,CAAC,QAAQ,CAAC,OAAO,CAAC,QAAQ,CAAC,EAC5C,CAAC,CACF,CAAC;QAEF,IAAI,QAAQ,CAAC,MAAM,CAAC,YAAY,KAAK,KAAK,EAAE;YAC1C,6EAA6E;YAC7E,MAAM,4BAA4B,GAAG,iBAAiB,CAAC,QAAQ,CAAC,IAAI,CAClE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,YAAY,CAC9B,CAAC;YACF,IAAI,CAAC,4BAA4B,EAAE;gBACjC,IAAI,CAAC,OAAO,CAAC,iBAAiB,EAAE,CAAC;aAClC;SACF;IACH,CAAC;;AA5Hc,0BAAQ,GAAyB,EAAG,CAAA;8GADxC,iBAAiB;kHAAjB,iBAAiB,cAFhB,MAAM;2FAEP,iBAAiB;kBAH7B,UAAU;mBAAC;oBACV,UAAU,EAAE,MAAM;iBACnB","sourcesContent":["import {\n  ApplicationRef,\n  ComponentFactoryResolver,\n  ComponentRef,\n  EmbeddedViewRef,\n  Injectable,\n  Injector,\n} from '@angular/core';\n\nimport { SkyOverlayAdapterService } from './overlay-adapter.service';\nimport { SkyOverlayConfig } from './overlay-config';\nimport { SkyOverlayContext } from './overlay-context';\nimport { SkyOverlayInstance } from './overlay-instance';\nimport { SkyOverlayComponent } from './overlay.component';\n\n/**\n * This service is used to create new overlays.\n * @dynamic\n */\n@Injectable({\n  providedIn: 'root',\n})\nexport class SkyOverlayService {\n  private static overlays: SkyOverlayInstance[] = [];\n\n  constructor(\n    private applicationRef: ApplicationRef,\n    private componentFactoryResolver: ComponentFactoryResolver,\n    private injector: Injector,\n    private adapter: SkyOverlayAdapterService\n  ) {}\n\n  /**\n   * Creates an empty overlay. Use the returned `SkyOverlayInstance` to append content.\n   * @param config Configuration for the overlay.\n   */\n  public create(config?: SkyOverlayConfig): SkyOverlayInstance {\n    const settings = this.prepareConfig(config);\n\n    if (settings.enableScroll === false) {\n      this.adapter.restrictBodyScroll();\n    }\n\n    const componentRef = this.createOverlay(settings);\n    const instance = new SkyOverlayInstance(settings, componentRef);\n\n    instance.closed.subscribe(() => {\n      // Only execute the service's close method if the instance still exists.\n      // This is needed to address a race condition if the deprecated instance.close method is used instead.\n      if (SkyOverlayService.overlays.indexOf(instance) > -1) {\n        this.close(instance);\n      }\n    });\n\n    SkyOverlayService.overlays.push(instance);\n\n    return instance;\n  }\n\n  /**\n   * Closes (and destroys) an overlay instance.\n   * @param instance The instance to close.\n   */\n  public close(instance: SkyOverlayInstance): void {\n    this.destroyOverlay(instance);\n    this.applicationRef.detachView(instance.componentRef.hostView);\n    instance.componentRef.destroy();\n\n    // In some cases, Angular keeps dynamically-generated component's nodes in the DOM during\n    // unit tests. This can make querying difficult because the older DOM nodes still exist and\n    // produce inconsistent results.\n    // Angular Material's overlay appears to do the same thing:\n    // https://github.com/angular/components/blob/master/src/cdk/portal/dom-portal-outlet.ts#L143-L145\n    // (Ignoring coverage since this branch will only be hit by consumer unit tests.)\n    const componentElement = instance.componentRef.location.nativeElement;\n    /* istanbul ignore if */\n    if (componentElement.parentNode !== null) {\n      componentElement.parentNode.removeChild(componentElement);\n    }\n  }\n\n  /**\n   * Closes all overlay instances.\n   */\n  public closeAll(): void {\n    // The `close` event handler for each instance alters the array's length asynchronously,\n    // so the only \"safe\" index to call is zero.\n    while (SkyOverlayService.overlays.length > 0) {\n      this.close(SkyOverlayService.overlays[0]);\n    }\n  }\n\n  private createOverlay(\n    config?: SkyOverlayConfig\n  ): ComponentRef<SkyOverlayComponent> {\n    const injector = Injector.create({\n      parent: this.injector,\n      providers: [\n        {\n          provide: SkyOverlayContext,\n          useValue: new SkyOverlayContext(config),\n        },\n      ],\n    });\n\n    const componentRef = this.componentFactoryResolver\n      .resolveComponentFactory(SkyOverlayComponent)\n      .create(injector);\n\n    this.applicationRef.attachView(componentRef.hostView);\n\n    const domElem = (componentRef.hostView as EmbeddedViewRef<any>)\n      .rootNodes[0] as HTMLElement;\n\n    document.body.appendChild(domElem);\n\n    return componentRef;\n  }\n\n  private prepareConfig(config: SkyOverlayConfig): SkyOverlayConfig {\n    const defaults: SkyOverlayConfig = {\n      closeOnNavigation: true,\n      enableClose: false,\n      enablePointerEvents: false,\n      enableScroll: true,\n      showBackdrop: false,\n      wrapperClass: '',\n    };\n\n    return { ...defaults, ...config };\n  }\n\n  private destroyOverlay(instance: SkyOverlayInstance): void {\n    SkyOverlayService.overlays.splice(\n      SkyOverlayService.overlays.indexOf(instance),\n      1\n    );\n\n    if (instance.config.enableScroll === false) {\n      // Only release the body scroll if no other overlay wishes it to be disabled.\n      const anotherOverlayDisablesScroll = SkyOverlayService.overlays.some(\n        (o) => !o.config.enableScroll\n      );\n      if (!anotherOverlayDisablesScroll) {\n        this.adapter.releaseBodyScroll();\n      }\n    }\n  }\n}\n"]}
|
126
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"overlay.service.js","sourceRoot":"","sources":["../../../../../../../../libs/components/core/src/lib/modules/overlay/overlay.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ApplicationRef,\n  ComponentFactoryResolver,\n  ComponentRef,\n  EmbeddedViewRef,\n  Injectable,\n  Injector,\n} from '@angular/core';\n\nimport { SkyOverlayAdapterService } from './overlay-adapter.service';\nimport { SkyOverlayConfig } from './overlay-config';\nimport { SkyOverlayContext } from './overlay-context';\nimport { SkyOverlayInstance } from './overlay-instance';\nimport { SkyOverlayComponent } from './overlay.component';\n\n/**\n * This service is used to create new overlays.\n * @dynamic\n */\n@Injectable({\n  providedIn: 'root',\n})\nexport class SkyOverlayService {\n  private static overlays: SkyOverlayInstance[] = [];\n\n  #adapter: SkyOverlayAdapterService;\n\n  #applicationRef: ApplicationRef;\n\n  #componentFactoryResolver: ComponentFactoryResolver;\n\n  #injector: Injector;\n\n  // TODO: Replace deprecated `ComponentFactoryResolver`.\n  constructor(\n    applicationRef: ApplicationRef,\n    componentFactoryResolver: ComponentFactoryResolver,\n    injector: Injector,\n    adapter: SkyOverlayAdapterService\n  ) {\n    this.#applicationRef = applicationRef;\n    this.#componentFactoryResolver = componentFactoryResolver;\n    this.#injector = injector;\n    this.#adapter = adapter;\n  }\n\n  /**\n   * Creates an empty overlay. Use the returned `SkyOverlayInstance` to append content.\n   * @param config Configuration for the overlay.\n   */\n  public create(config?: SkyOverlayConfig): SkyOverlayInstance {\n    const settings = this.#prepareConfig(config);\n\n    if (settings.enableScroll === false) {\n      this.#adapter.restrictBodyScroll();\n    }\n\n    const componentRef = this.#createOverlay(settings);\n    const instance = new SkyOverlayInstance(settings, componentRef);\n\n    instance.closed.subscribe(() => {\n      // Only execute the service's close method if the instance still exists.\n      // This is needed to address a race condition if the deprecated instance.close method is used instead.\n      if (SkyOverlayService.overlays.indexOf(instance) > -1) {\n        this.close(instance);\n      }\n    });\n\n    SkyOverlayService.overlays.push(instance);\n\n    return instance;\n  }\n\n  /**\n   * Closes (and destroys) an overlay instance.\n   * @param instance The instance to close.\n   */\n  public close(instance: SkyOverlayInstance): void {\n    this.#destroyOverlay(instance);\n    this.#applicationRef.detachView(instance.componentRef.hostView);\n    instance.componentRef.destroy();\n\n    // In some cases, Angular keeps dynamically-generated component's nodes in the DOM during\n    // unit tests. This can make querying difficult because the older DOM nodes still exist and\n    // produce inconsistent results.\n    // Angular Material's overlay appears to do the same thing:\n    // https://github.com/angular/components/blob/master/src/cdk/portal/dom-portal-outlet.ts#L143-L145\n    // (Ignoring coverage since this branch will only be hit by consumer unit tests.)\n    const componentElement = instance.componentRef.location.nativeElement;\n    /* istanbul ignore if */\n    if (componentElement.parentNode !== null) {\n      componentElement.parentNode.removeChild(componentElement);\n    }\n  }\n\n  /**\n   * Closes all overlay instances.\n   */\n  public closeAll(): void {\n    // The `close` event handler for each instance alters the array's length asynchronously,\n    // so the only \"safe\" index to call is zero.\n    while (SkyOverlayService.overlays.length > 0) {\n      this.close(SkyOverlayService.overlays[0]);\n    }\n  }\n\n  #createOverlay(config: SkyOverlayConfig): ComponentRef<SkyOverlayComponent> {\n    const injector = Injector.create({\n      parent: this.#injector,\n      providers: [\n        {\n          provide: SkyOverlayContext,\n          useValue: new SkyOverlayContext(config),\n        },\n      ],\n    });\n\n    const componentRef = this.#componentFactoryResolver\n      .resolveComponentFactory(SkyOverlayComponent)\n      .create(injector);\n\n    this.#applicationRef.attachView(componentRef.hostView);\n\n    const domElem = (componentRef.hostView as EmbeddedViewRef<any>)\n      .rootNodes[0] as HTMLElement;\n\n    document.body.appendChild(domElem);\n\n    return componentRef;\n  }\n\n  #prepareConfig(config: SkyOverlayConfig = {}): SkyOverlayConfig {\n    const defaults: SkyOverlayConfig = {\n      closeOnNavigation: true,\n      enableClose: false,\n      enablePointerEvents: false,\n      enableScroll: true,\n      showBackdrop: false,\n      wrapperClass: '',\n    };\n\n    return { ...defaults, ...config };\n  }\n\n  #destroyOverlay(instance: SkyOverlayInstance): void {\n    SkyOverlayService.overlays.splice(\n      SkyOverlayService.overlays.indexOf(instance),\n      1\n    );\n\n    if (instance.config.enableScroll === false) {\n      // Only release the body scroll if no other overlay wishes it to be disabled.\n      const anotherOverlayDisablesScroll = SkyOverlayService.overlays.some(\n        (o) => !o.config.enableScroll\n      );\n      if (!anotherOverlayDisablesScroll) {\n        this.#adapter.releaseBodyScroll();\n      }\n    }\n  }\n}\n"]}
|