@skyux/modals 6.17.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/esm2020/lib/modules/modal/modal-adapter.service.mjs +50 -3
- package/esm2020/lib/modules/modal/modal-host.component.mjs +28 -9
- package/fesm2015/skyux-modals.mjs +75 -9
- package/fesm2015/skyux-modals.mjs.map +1 -1
- package/fesm2020/skyux-modals.mjs +75 -9
- package/fesm2020/skyux-modals.mjs.map +1 -1
- package/lib/modules/modal/modal-adapter.service.d.ts +12 -0
- package/lib/modules/modal/modal-host.component.d.ts +2 -2
- package/package.json +5 -5
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
var _SkyModalAdapterService_instances, _SkyModalAdapterService_docRef, _SkyModalAdapterService_bodyEl, _SkyModalAdapterService_windowRef, _SkyModalAdapterService_addClassToBody, _SkyModalAdapterService_removeClassFromBody;
|
|
1
|
+
var _SkyModalAdapterService_instances, _SkyModalAdapterService_docRef, _SkyModalAdapterService_bodyEl, _SkyModalAdapterService_windowRef, _SkyModalAdapterService_hostSiblingAriaHiddenCache, _SkyModalAdapterService_addClassToBody, _SkyModalAdapterService_removeClassFromBody;
|
|
2
2
|
import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
|
|
3
3
|
import { Injectable } from '@angular/core';
|
|
4
4
|
import { SkyAppWindowRef } from '@skyux/core';
|
|
@@ -13,6 +13,7 @@ export class SkyModalAdapterService {
|
|
|
13
13
|
_SkyModalAdapterService_docRef.set(this, void 0);
|
|
14
14
|
_SkyModalAdapterService_bodyEl.set(this, void 0);
|
|
15
15
|
_SkyModalAdapterService_windowRef.set(this, void 0);
|
|
16
|
+
_SkyModalAdapterService_hostSiblingAriaHiddenCache.set(this, new Map());
|
|
16
17
|
__classPrivateFieldSet(this, _SkyModalAdapterService_windowRef, windowRef, "f");
|
|
17
18
|
__classPrivateFieldSet(this, _SkyModalAdapterService_docRef, __classPrivateFieldGet(this, _SkyModalAdapterService_windowRef, "f").nativeWindow.document, "f");
|
|
18
19
|
__classPrivateFieldSet(this, _SkyModalAdapterService_bodyEl, __classPrivateFieldGet(this, _SkyModalAdapterService_windowRef, "f").nativeWindow.document.body, "f");
|
|
@@ -36,8 +37,54 @@ export class SkyModalAdapterService {
|
|
|
36
37
|
getModalOpener() {
|
|
37
38
|
return __classPrivateFieldGet(this, _SkyModalAdapterService_docRef, "f").activeElement;
|
|
38
39
|
}
|
|
40
|
+
/**
|
|
41
|
+
* Hides siblings of modal-host from screen readers
|
|
42
|
+
* @param hostElRef reference to modal-host element
|
|
43
|
+
*/
|
|
44
|
+
hideHostSiblingsFromScreenReaders(hostElRef) {
|
|
45
|
+
const hostElement = hostElRef.nativeElement;
|
|
46
|
+
const hostSiblings = hostElement.parentElement.children;
|
|
47
|
+
for (let i = 0; i < hostSiblings.length; i++) {
|
|
48
|
+
const element = hostSiblings[i];
|
|
49
|
+
if (element !== hostElement &&
|
|
50
|
+
!element.hasAttribute('aria-live') &&
|
|
51
|
+
element.nodeName.toLowerCase() !== 'script' &&
|
|
52
|
+
element.nodeName.toLowerCase() !== 'style') {
|
|
53
|
+
// preserve previous aria-hidden status of elements outside of modal host
|
|
54
|
+
__classPrivateFieldGet(this, _SkyModalAdapterService_hostSiblingAriaHiddenCache, "f").set(element, element.getAttribute('aria-hidden'));
|
|
55
|
+
element.setAttribute('aria-hidden', 'true');
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
/**
|
|
60
|
+
* Restores modal-host siblings to screenreader status prior to modals being opened
|
|
61
|
+
*/
|
|
62
|
+
unhideOrRestoreHostSiblingsFromScreenReaders() {
|
|
63
|
+
__classPrivateFieldGet(this, _SkyModalAdapterService_hostSiblingAriaHiddenCache, "f").forEach((previousValue, element) => {
|
|
64
|
+
// if element had aria-hidden status prior, restore status
|
|
65
|
+
if (element.parentElement) {
|
|
66
|
+
if (previousValue) {
|
|
67
|
+
element.setAttribute('aria-hidden', previousValue);
|
|
68
|
+
}
|
|
69
|
+
else {
|
|
70
|
+
element.removeAttribute('aria-hidden');
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
});
|
|
74
|
+
__classPrivateFieldGet(this, _SkyModalAdapterService_hostSiblingAriaHiddenCache, "f").clear();
|
|
75
|
+
}
|
|
76
|
+
hidePreviousModalFromScreenReaders(topModal) {
|
|
77
|
+
if (topModal && topModal.nativeElement.previousElementSibling) {
|
|
78
|
+
topModal.nativeElement.previousElementSibling.setAttribute('aria-hidden', 'true');
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
unhidePreviousModalFromScreenReaders(topModal) {
|
|
82
|
+
if (topModal && topModal.nativeElement.previousElementSibling) {
|
|
83
|
+
topModal.nativeElement.previousElementSibling.removeAttribute('aria-hidden');
|
|
84
|
+
}
|
|
85
|
+
}
|
|
39
86
|
}
|
|
40
|
-
_SkyModalAdapterService_docRef = new WeakMap(), _SkyModalAdapterService_bodyEl = new WeakMap(), _SkyModalAdapterService_windowRef = new WeakMap(), _SkyModalAdapterService_instances = new WeakSet(), _SkyModalAdapterService_addClassToBody = function _SkyModalAdapterService_addClassToBody(className) {
|
|
87
|
+
_SkyModalAdapterService_docRef = new WeakMap(), _SkyModalAdapterService_bodyEl = new WeakMap(), _SkyModalAdapterService_windowRef = new WeakMap(), _SkyModalAdapterService_hostSiblingAriaHiddenCache = new WeakMap(), _SkyModalAdapterService_instances = new WeakSet(), _SkyModalAdapterService_addClassToBody = function _SkyModalAdapterService_addClassToBody(className) {
|
|
41
88
|
__classPrivateFieldGet(this, _SkyModalAdapterService_bodyEl, "f").classList.add(className);
|
|
42
89
|
}, _SkyModalAdapterService_removeClassFromBody = function _SkyModalAdapterService_removeClassFromBody(className) {
|
|
43
90
|
__classPrivateFieldGet(this, _SkyModalAdapterService_bodyEl, "f").classList.remove(className);
|
|
@@ -49,4 +96,4 @@ SkyModalAdapterService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0
|
|
|
49
96
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyModalAdapterService, decorators: [{
|
|
50
97
|
type: Injectable
|
|
51
98
|
}], ctorParameters: function () { return [{ type: i1.SkyAppWindowRef }]; } });
|
|
52
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
99
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal-adapter.service.js","sourceRoot":"","sources":["../../../../../../../../libs/components/modals/src/lib/modules/modal/modal-adapter.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { ElementRef, Injectable } from '@angular/core';\nimport { SkyAppWindowRef } from '@skyux/core';\n\n/**\n * @internal\n */\n@Injectable()\nexport class SkyModalAdapterService {\n  private static readonly MODAL_BODY_FULL_CLASS = 'sky-modal-body-full-page';\n  private static readonly MODAL_BODY_CLASS = 'sky-modal-body-open';\n\n  #docRef: any;\n  #bodyEl: HTMLElement;\n\n  #windowRef: SkyAppWindowRef;\n  #hostSiblingAriaHiddenCache = new Map<Element, string | null>();\n\n  constructor(windowRef: SkyAppWindowRef) {\n    this.#windowRef = windowRef;\n    this.#docRef = this.#windowRef.nativeWindow.document;\n    this.#bodyEl = this.#windowRef.nativeWindow.document.body;\n  }\n\n  public toggleFullPageModalClass(isAddFull: boolean): void {\n    if (isAddFull) {\n      this.#addClassToBody(SkyModalAdapterService.MODAL_BODY_FULL_CLASS);\n    } else {\n      this.#removeClassFromBody(SkyModalAdapterService.MODAL_BODY_FULL_CLASS);\n    }\n  }\n\n  public setPageScroll(isAdd: boolean): void {\n    if (isAdd) {\n      this.#addClassToBody(SkyModalAdapterService.MODAL_BODY_CLASS);\n    } else {\n      this.#removeClassFromBody(SkyModalAdapterService.MODAL_BODY_CLASS);\n    }\n  }\n\n  public getModalOpener(): HTMLElement {\n    return this.#docRef.activeElement;\n  }\n\n  #addClassToBody(className: string): void {\n    this.#bodyEl.classList.add(className);\n  }\n\n  #removeClassFromBody(className: string): void {\n    this.#bodyEl.classList.remove(className);\n  }\n\n  /**\n   * Hides siblings of modal-host from screen readers\n   * @param hostElRef reference to modal-host element\n   */\n  public hideHostSiblingsFromScreenReaders(hostElRef: ElementRef): void {\n    const hostElement = hostElRef.nativeElement;\n    const hostSiblings = hostElement.parentElement.children;\n\n    for (let i = 0; i < hostSiblings.length; i++) {\n      const element = hostSiblings[i];\n      if (\n        element !== hostElement &&\n        !element.hasAttribute('aria-live') &&\n        element.nodeName.toLowerCase() !== 'script' &&\n        element.nodeName.toLowerCase() !== 'style'\n      ) {\n        // preserve previous aria-hidden status of elements outside of modal host\n        this.#hostSiblingAriaHiddenCache.set(\n          element,\n          element.getAttribute('aria-hidden')\n        );\n        element.setAttribute('aria-hidden', 'true');\n      }\n    }\n  }\n\n  /**\n   * Restores modal-host siblings to screenreader status prior to modals being opened\n   */\n  public unhideOrRestoreHostSiblingsFromScreenReaders(): void {\n    this.#hostSiblingAriaHiddenCache.forEach((previousValue, element) => {\n      // if element had aria-hidden status prior, restore status\n      if (element.parentElement) {\n        if (previousValue) {\n          element.setAttribute('aria-hidden', previousValue);\n        } else {\n          element.removeAttribute('aria-hidden');\n        }\n      }\n    });\n    this.#hostSiblingAriaHiddenCache.clear();\n  }\n\n  public hidePreviousModalFromScreenReaders(topModal: ElementRef): void {\n    if (topModal && topModal.nativeElement.previousElementSibling) {\n      topModal.nativeElement.previousElementSibling.setAttribute(\n        'aria-hidden',\n        'true'\n      );\n    }\n  }\n\n  public unhidePreviousModalFromScreenReaders(topModal: ElementRef): void {\n    if (topModal && topModal.nativeElement.previousElementSibling) {\n      topModal.nativeElement.previousElementSibling.removeAttribute(\n        'aria-hidden'\n      );\n    }\n  }\n}\n"]}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
var _SkyModalHostComponent_instances, _SkyModalHostComponent_resolver, _SkyModalHostComponent_adapter, _SkyModalHostComponent_injector, _SkyModalHostComponent_router, _SkyModalHostComponent_changeDetector, _SkyModalHostComponent_modalHostContext, _SkyModalHostComponent_modalInstances, _SkyModalHostComponent_registerModalInstance, _SkyModalHostComponent_unregisterModalInstance, _SkyModalHostComponent_closeAllModalInstances;
|
|
1
|
+
var _SkyModalHostComponent_instances, _SkyModalHostComponent_resolver, _SkyModalHostComponent_adapter, _SkyModalHostComponent_injector, _SkyModalHostComponent_router, _SkyModalHostComponent_changeDetector, _SkyModalHostComponent_modalHostContext, _SkyModalHostComponent_elRef, _SkyModalHostComponent_modalInstances, _SkyModalHostComponent_registerModalInstance, _SkyModalHostComponent_unregisterModalInstance, _SkyModalHostComponent_closeAllModalInstances;
|
|
2
2
|
import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
|
|
3
|
-
import { ChangeDetectorRef, Component, ComponentFactoryResolver, Injector, ViewChild, ViewContainerRef, } from '@angular/core';
|
|
3
|
+
import { ChangeDetectorRef, Component, ComponentFactoryResolver, ElementRef, Injector, ViewChild, ViewContainerRef, } from '@angular/core';
|
|
4
4
|
import { NavigationStart, Router } from '@angular/router';
|
|
5
5
|
import { SkyMediaQueryService, SkyResizeObserverMediaQueryService, } from '@skyux/core';
|
|
6
6
|
import { takeWhile } from 'rxjs/operators';
|
|
@@ -17,7 +17,7 @@ import * as i4 from "@angular/common";
|
|
|
17
17
|
* @internal
|
|
18
18
|
*/
|
|
19
19
|
export class SkyModalHostComponent {
|
|
20
|
-
constructor(resolver, adapter, injector, router, changeDetector, modalHostContext) {
|
|
20
|
+
constructor(resolver, adapter, injector, router, changeDetector, modalHostContext, elRef) {
|
|
21
21
|
_SkyModalHostComponent_instances.add(this);
|
|
22
22
|
_SkyModalHostComponent_resolver.set(this, void 0);
|
|
23
23
|
_SkyModalHostComponent_adapter.set(this, void 0);
|
|
@@ -25,6 +25,7 @@ export class SkyModalHostComponent {
|
|
|
25
25
|
_SkyModalHostComponent_router.set(this, void 0);
|
|
26
26
|
_SkyModalHostComponent_changeDetector.set(this, void 0);
|
|
27
27
|
_SkyModalHostComponent_modalHostContext.set(this, void 0);
|
|
28
|
+
_SkyModalHostComponent_elRef.set(this, void 0);
|
|
28
29
|
_SkyModalHostComponent_modalInstances.set(this, []);
|
|
29
30
|
__classPrivateFieldSet(this, _SkyModalHostComponent_resolver, resolver, "f");
|
|
30
31
|
__classPrivateFieldSet(this, _SkyModalHostComponent_adapter, adapter, "f");
|
|
@@ -32,6 +33,7 @@ export class SkyModalHostComponent {
|
|
|
32
33
|
__classPrivateFieldSet(this, _SkyModalHostComponent_router, router, "f");
|
|
33
34
|
__classPrivateFieldSet(this, _SkyModalHostComponent_changeDetector, changeDetector, "f");
|
|
34
35
|
__classPrivateFieldSet(this, _SkyModalHostComponent_modalHostContext, modalHostContext, "f");
|
|
36
|
+
__classPrivateFieldSet(this, _SkyModalHostComponent_elRef, elRef, "f");
|
|
35
37
|
}
|
|
36
38
|
get modalOpen() {
|
|
37
39
|
return SkyModalHostService.openModalCount > 0;
|
|
@@ -80,9 +82,26 @@ export class SkyModalHostComponent {
|
|
|
80
82
|
parent: __classPrivateFieldGet(this, _SkyModalHostComponent_injector, "f"),
|
|
81
83
|
});
|
|
82
84
|
const modalComponentRef = this.target.createComponent(factory, undefined, injector);
|
|
85
|
+
// modal element that was just opened
|
|
86
|
+
const modalElement = modalComponentRef.location;
|
|
83
87
|
modalInstance.componentInstance = modalComponentRef.instance;
|
|
84
88
|
__classPrivateFieldGet(this, _SkyModalHostComponent_instances, "m", _SkyModalHostComponent_registerModalInstance).call(this, modalInstance);
|
|
85
|
-
|
|
89
|
+
// hidding all elements at the modal-host level from screenreaders when the a modal is opened
|
|
90
|
+
__classPrivateFieldGet(this, _SkyModalHostComponent_adapter, "f").hideHostSiblingsFromScreenReaders(__classPrivateFieldGet(this, _SkyModalHostComponent_elRef, "f"));
|
|
91
|
+
if (SkyModalHostService.openModalCount > 1 &&
|
|
92
|
+
SkyModalHostService.topModal === hostService) {
|
|
93
|
+
// hiding the lower modals when more than one modal is opened
|
|
94
|
+
__classPrivateFieldGet(this, _SkyModalHostComponent_adapter, "f").hidePreviousModalFromScreenReaders(modalElement);
|
|
95
|
+
}
|
|
96
|
+
const closeModal = () => {
|
|
97
|
+
// unhide siblings if last modal is closing
|
|
98
|
+
if (SkyModalHostService.openModalCount === 1) {
|
|
99
|
+
__classPrivateFieldGet(this, _SkyModalHostComponent_adapter, "f").unhideOrRestoreHostSiblingsFromScreenReaders();
|
|
100
|
+
}
|
|
101
|
+
else if (SkyModalHostService.topModal === hostService) {
|
|
102
|
+
// if there are more than 1 modal then unhide the one behind this one before closing it
|
|
103
|
+
__classPrivateFieldGet(this, _SkyModalHostComponent_adapter, "f").unhidePreviousModalFromScreenReaders(modalElement);
|
|
104
|
+
}
|
|
86
105
|
hostService.destroy();
|
|
87
106
|
adapter.setPageScroll(SkyModalHostService.openModalCount > 0);
|
|
88
107
|
adapter.toggleFullPageModalClass(SkyModalHostService.fullPageModalCount > 0);
|
|
@@ -92,7 +111,7 @@ export class SkyModalHostComponent {
|
|
|
92
111
|
modalOpener.focus();
|
|
93
112
|
}
|
|
94
113
|
modalComponentRef.destroy();
|
|
95
|
-
}
|
|
114
|
+
};
|
|
96
115
|
hostService.openHelp.subscribe((helpKey) => {
|
|
97
116
|
modalInstance.openHelp(helpKey);
|
|
98
117
|
});
|
|
@@ -114,7 +133,7 @@ export class SkyModalHostComponent {
|
|
|
114
133
|
__classPrivateFieldGet(this, _SkyModalHostComponent_changeDetector, "f").detectChanges();
|
|
115
134
|
}
|
|
116
135
|
}
|
|
117
|
-
_SkyModalHostComponent_resolver = new WeakMap(), _SkyModalHostComponent_adapter = new WeakMap(), _SkyModalHostComponent_injector = new WeakMap(), _SkyModalHostComponent_router = new WeakMap(), _SkyModalHostComponent_changeDetector = new WeakMap(), _SkyModalHostComponent_modalHostContext = new WeakMap(), _SkyModalHostComponent_modalInstances = new WeakMap(), _SkyModalHostComponent_instances = new WeakSet(), _SkyModalHostComponent_registerModalInstance = function _SkyModalHostComponent_registerModalInstance(instance) {
|
|
136
|
+
_SkyModalHostComponent_resolver = new WeakMap(), _SkyModalHostComponent_adapter = new WeakMap(), _SkyModalHostComponent_injector = new WeakMap(), _SkyModalHostComponent_router = new WeakMap(), _SkyModalHostComponent_changeDetector = new WeakMap(), _SkyModalHostComponent_modalHostContext = new WeakMap(), _SkyModalHostComponent_elRef = new WeakMap(), _SkyModalHostComponent_modalInstances = new WeakMap(), _SkyModalHostComponent_instances = new WeakSet(), _SkyModalHostComponent_registerModalInstance = function _SkyModalHostComponent_registerModalInstance(instance) {
|
|
118
137
|
__classPrivateFieldGet(this, _SkyModalHostComponent_modalInstances, "f").push(instance);
|
|
119
138
|
}, _SkyModalHostComponent_unregisterModalInstance = function _SkyModalHostComponent_unregisterModalInstance(instance) {
|
|
120
139
|
__classPrivateFieldGet(this, _SkyModalHostComponent_modalInstances, "f").slice(__classPrivateFieldGet(this, _SkyModalHostComponent_modalInstances, "f").indexOf(instance), 1);
|
|
@@ -123,16 +142,16 @@ _SkyModalHostComponent_resolver = new WeakMap(), _SkyModalHostComponent_adapter
|
|
|
123
142
|
instance.close();
|
|
124
143
|
}
|
|
125
144
|
};
|
|
126
|
-
SkyModalHostComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyModalHostComponent, deps: [{ token: i0.ComponentFactoryResolver }, { token: i1.SkyModalAdapterService }, { token: i0.Injector }, { token: i2.Router }, { token: i0.ChangeDetectorRef }, { token: i3.SkyModalHostContext }], target: i0.ɵɵFactoryTarget.Component });
|
|
145
|
+
SkyModalHostComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyModalHostComponent, deps: [{ token: i0.ComponentFactoryResolver }, { token: i1.SkyModalAdapterService }, { token: i0.Injector }, { token: i2.Router }, { token: i0.ChangeDetectorRef }, { token: i3.SkyModalHostContext }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
127
146
|
SkyModalHostComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.2", type: SkyModalHostComponent, selector: "sky-modal-host", viewQueries: [{ propertyName: "target", first: true, predicate: ["target"], descendants: true, read: ViewContainerRef, static: true }], ngImport: i0, template: "<div\n class=\"sky-modal-host-backdrop\"\n [hidden]=\"!modalOpen\"\n [ngStyle]=\"{\n zIndex: backdropZIndex\n }\"\n></div>\n<div #target></div>\n", styles: [".sky-modal-host-backdrop{background-color:#00000080;position:fixed;top:0;left:0;bottom:0;right:0}\n"], directives: [{ type: i4.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }], viewProviders: [SkyModalAdapterService] });
|
|
128
147
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyModalHostComponent, decorators: [{
|
|
129
148
|
type: Component,
|
|
130
149
|
args: [{ selector: 'sky-modal-host', viewProviders: [SkyModalAdapterService], template: "<div\n class=\"sky-modal-host-backdrop\"\n [hidden]=\"!modalOpen\"\n [ngStyle]=\"{\n zIndex: backdropZIndex\n }\"\n></div>\n<div #target></div>\n", styles: [".sky-modal-host-backdrop{background-color:#00000080;position:fixed;top:0;left:0;bottom:0;right:0}\n"] }]
|
|
131
|
-
}], ctorParameters: function () { return [{ type: i0.ComponentFactoryResolver }, { type: i1.SkyModalAdapterService }, { type: i0.Injector }, { type: i2.Router }, { type: i0.ChangeDetectorRef }, { type: i3.SkyModalHostContext }]; }, propDecorators: { target: [{
|
|
150
|
+
}], ctorParameters: function () { return [{ type: i0.ComponentFactoryResolver }, { type: i1.SkyModalAdapterService }, { type: i0.Injector }, { type: i2.Router }, { type: i0.ChangeDetectorRef }, { type: i3.SkyModalHostContext }, { type: i0.ElementRef }]; }, propDecorators: { target: [{
|
|
132
151
|
type: ViewChild,
|
|
133
152
|
args: ['target', {
|
|
134
153
|
read: ViewContainerRef,
|
|
135
154
|
static: true,
|
|
136
155
|
}]
|
|
137
156
|
}] } });
|
|
138
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal-host.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/modals/src/lib/modules/modal/modal-host.component.ts","../../../../../../../../libs/components/modals/src/lib/modules/modal/modal-host.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectorRef,\n  Component,\n  ComponentFactoryResolver,\n  Injector,\n  OnDestroy,\n  ViewChild,\n  ViewContainerRef,\n} from '@angular/core';\nimport { NavigationStart, Router } from '@angular/router';\nimport {\n  SkyMediaQueryService,\n  SkyResizeObserverMediaQueryService,\n} from '@skyux/core';\n\nimport { takeWhile } from 'rxjs/operators';\n\nimport { SkyModalAdapterService } from './modal-adapter.service';\nimport { SkyModalConfiguration } from './modal-configuration';\nimport { SkyModalHostContext } from './modal-host-context';\nimport { SkyModalHostService } from './modal-host.service';\nimport { SkyModalInstance } from './modal-instance';\nimport { SkyModalConfigurationInterface } from './modal.interface';\n\n/**\n * @internal\n */\n@Component({\n  selector: 'sky-modal-host',\n  templateUrl: './modal-host.component.html',\n  styleUrls: ['./modal-host.component.scss'],\n  viewProviders: [SkyModalAdapterService],\n})\nexport class SkyModalHostComponent implements OnDestroy {\n  public get modalOpen() {\n    return SkyModalHostService.openModalCount > 0;\n  }\n\n  public get backdropZIndex() {\n    return SkyModalHostService.backdropZIndex;\n  }\n\n  /**\n   * Use `any` for backwards-compatibility with Angular 4-7.\n   * See: https://github.com/angular/angular/issues/30654\n   * TODO: Remove the `any` in a breaking change.\n   * @internal\n   */\n  @ViewChild('target', {\n    read: ViewContainerRef,\n    static: true,\n  } as any)\n  public target: ViewContainerRef | undefined;\n\n  #resolver: ComponentFactoryResolver;\n  #adapter: SkyModalAdapterService;\n  #injector: Injector;\n  #router: Router;\n  #changeDetector: ChangeDetectorRef;\n\n  #modalHostContext: SkyModalHostContext;\n\n  #modalInstances: SkyModalInstance[] = [];\n\n  constructor(\n    resolver: ComponentFactoryResolver,\n    adapter: SkyModalAdapterService,\n    injector: Injector,\n    router: Router,\n    changeDetector: ChangeDetectorRef,\n    modalHostContext: SkyModalHostContext\n  ) {\n    this.#resolver = resolver;\n    this.#adapter = adapter;\n    this.#injector = injector;\n    this.#router = router;\n    this.#changeDetector = changeDetector;\n    this.#modalHostContext = modalHostContext;\n  }\n\n  public ngOnDestroy(): void {\n    // Close all modal instances before disposing of the host container.\n    this.#closeAllModalInstances();\n    this.#modalHostContext.args.teardownCallback();\n  }\n\n  public open(\n    modalInstance: SkyModalInstance,\n    component: any,\n    config?: SkyModalConfigurationInterface\n  ): void {\n    /* Ignore coverage as we specify the target element and so the view child should never be undefined unless\n     * we were to call the `open` method in an early lifecycle hook. */\n    /* istanbul ignore next */\n    if (!this.target) {\n      return;\n    }\n\n    const params: SkyModalConfigurationInterface = Object.assign({}, config);\n    const factory = this.#resolver.resolveComponentFactory(component);\n\n    const hostService = new SkyModalHostService();\n    hostService.fullPage = !!params.fullPage;\n\n    const adapter = this.#adapter;\n    const modalOpener: HTMLElement = adapter.getModalOpener();\n\n    let isOpen = true;\n\n    /* eslint-disable @typescript-eslint/no-non-null-assertion */\n    params.providers!.push({\n      provide: SkyModalHostService,\n      useValue: hostService,\n    });\n    params.providers!.push({\n      provide: SkyModalConfiguration,\n      useValue: params,\n    });\n    params.providers!.push({\n      provide: SkyMediaQueryService,\n      useExisting: SkyResizeObserverMediaQueryService,\n    });\n    /* eslint-enable @typescript-eslint/no-non-null-assertion */\n\n    adapter.setPageScroll(SkyModalHostService.openModalCount > 0);\n    adapter.toggleFullPageModalClass(\n      SkyModalHostService.fullPageModalCount > 0\n    );\n\n    const providers = params.providers || /* istanbul ignore next */ [];\n    const injector = Injector.create({\n      providers,\n      parent: this.#injector,\n    });\n\n    const modalComponentRef = this.target.createComponent(\n      factory,\n      undefined,\n      injector\n    );\n\n    modalInstance.componentInstance = modalComponentRef.instance;\n\n    this.#registerModalInstance(modalInstance);\n\n    function closeModal() {\n      hostService.destroy();\n      adapter.setPageScroll(SkyModalHostService.openModalCount > 0);\n      adapter.toggleFullPageModalClass(\n        SkyModalHostService.fullPageModalCount > 0\n      );\n      /* istanbul ignore else */\n      /* sanity check */\n      if (modalOpener && modalOpener.focus) {\n        modalOpener.focus();\n      }\n      modalComponentRef.destroy();\n    }\n\n    hostService.openHelp.subscribe((helpKey) => {\n      modalInstance.openHelp(helpKey);\n    });\n\n    hostService.close.subscribe(() => {\n      modalInstance.close();\n    });\n\n    this.#router.events.pipe(takeWhile(() => isOpen)).subscribe((event) => {\n      /* istanbul ignore else */\n      if (event instanceof NavigationStart) {\n        modalInstance.close();\n      }\n    });\n\n    modalInstance.closed.subscribe(() => {\n      isOpen = false;\n      this.#unregisterModalInstance(modalInstance);\n      closeModal();\n    });\n\n    // Necessary if the host was created via a consumer's lifecycle hook such as ngOnInit\n    this.#changeDetector.detectChanges();\n  }\n\n  #registerModalInstance(instance: SkyModalInstance): void {\n    this.#modalInstances.push(instance);\n  }\n\n  #unregisterModalInstance(instance: SkyModalInstance): void {\n    this.#modalInstances.slice(this.#modalInstances.indexOf(instance), 1);\n  }\n\n  #closeAllModalInstances(): void {\n    for (const instance of this.#modalInstances) {\n      instance.close();\n    }\n  }\n}\n","<div\n  class=\"sky-modal-host-backdrop\"\n  [hidden]=\"!modalOpen\"\n  [ngStyle]=\"{\n    zIndex: backdropZIndex\n  }\"\n></div>\n<div #target></div>\n"]}
|
|
157
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal-host.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/modals/src/lib/modules/modal/modal-host.component.ts","../../../../../../../../libs/components/modals/src/lib/modules/modal/modal-host.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectorRef,\n  Component,\n  ComponentFactoryResolver,\n  ElementRef,\n  Injector,\n  OnDestroy,\n  ViewChild,\n  ViewContainerRef,\n} from '@angular/core';\nimport { NavigationStart, Router } from '@angular/router';\nimport {\n  SkyMediaQueryService,\n  SkyResizeObserverMediaQueryService,\n} from '@skyux/core';\n\nimport { takeWhile } from 'rxjs/operators';\n\nimport { SkyModalAdapterService } from './modal-adapter.service';\nimport { SkyModalConfiguration } from './modal-configuration';\nimport { SkyModalHostContext } from './modal-host-context';\nimport { SkyModalHostService } from './modal-host.service';\nimport { SkyModalInstance } from './modal-instance';\nimport { SkyModalConfigurationInterface } from './modal.interface';\n\n/**\n * @internal\n */\n@Component({\n  selector: 'sky-modal-host',\n  templateUrl: './modal-host.component.html',\n  styleUrls: ['./modal-host.component.scss'],\n  viewProviders: [SkyModalAdapterService],\n})\nexport class SkyModalHostComponent implements OnDestroy {\n  public get modalOpen() {\n    return SkyModalHostService.openModalCount > 0;\n  }\n\n  public get backdropZIndex() {\n    return SkyModalHostService.backdropZIndex;\n  }\n\n  /**\n   * Use `any` for backwards-compatibility with Angular 4-7.\n   * See: https://github.com/angular/angular/issues/30654\n   * TODO: Remove the `any` in a breaking change.\n   * @internal\n   */\n  @ViewChild('target', {\n    read: ViewContainerRef,\n    static: true,\n  } as any)\n  public target: ViewContainerRef | undefined;\n\n  #resolver: ComponentFactoryResolver;\n  #adapter: SkyModalAdapterService;\n  #injector: Injector;\n  #router: Router;\n  #changeDetector: ChangeDetectorRef;\n  #modalHostContext: SkyModalHostContext;\n  #elRef: ElementRef;\n\n  #modalInstances: SkyModalInstance[] = [];\n\n  constructor(\n    resolver: ComponentFactoryResolver,\n    adapter: SkyModalAdapterService,\n    injector: Injector,\n    router: Router,\n    changeDetector: ChangeDetectorRef,\n    modalHostContext: SkyModalHostContext,\n    elRef: ElementRef\n  ) {\n    this.#resolver = resolver;\n    this.#adapter = adapter;\n    this.#injector = injector;\n    this.#router = router;\n    this.#changeDetector = changeDetector;\n    this.#modalHostContext = modalHostContext;\n    this.#elRef = elRef;\n  }\n\n  public ngOnDestroy(): void {\n    // Close all modal instances before disposing of the host container.\n    this.#closeAllModalInstances();\n    this.#modalHostContext.args.teardownCallback();\n  }\n\n  public open(\n    modalInstance: SkyModalInstance,\n    component: any,\n    config?: SkyModalConfigurationInterface\n  ): void {\n    /* Ignore coverage as we specify the target element and so the view child should never be undefined unless\n     * we were to call the `open` method in an early lifecycle hook. */\n    /* istanbul ignore next */\n    if (!this.target) {\n      return;\n    }\n\n    const params: SkyModalConfigurationInterface = Object.assign({}, config);\n    const factory = this.#resolver.resolveComponentFactory(component);\n\n    const hostService = new SkyModalHostService();\n    hostService.fullPage = !!params.fullPage;\n\n    const adapter = this.#adapter;\n    const modalOpener: HTMLElement = adapter.getModalOpener();\n\n    let isOpen = true;\n\n    /* eslint-disable @typescript-eslint/no-non-null-assertion */\n    params.providers!.push({\n      provide: SkyModalHostService,\n      useValue: hostService,\n    });\n    params.providers!.push({\n      provide: SkyModalConfiguration,\n      useValue: params,\n    });\n    params.providers!.push({\n      provide: SkyMediaQueryService,\n      useExisting: SkyResizeObserverMediaQueryService,\n    });\n    /* eslint-enable @typescript-eslint/no-non-null-assertion */\n\n    adapter.setPageScroll(SkyModalHostService.openModalCount > 0);\n    adapter.toggleFullPageModalClass(\n      SkyModalHostService.fullPageModalCount > 0\n    );\n\n    const providers = params.providers || /* istanbul ignore next */ [];\n    const injector = Injector.create({\n      providers,\n      parent: this.#injector,\n    });\n\n    const modalComponentRef = this.target.createComponent(\n      factory,\n      undefined,\n      injector\n    );\n\n    // modal element that was just opened\n    const modalElement = modalComponentRef.location;\n\n    modalInstance.componentInstance = modalComponentRef.instance;\n\n    this.#registerModalInstance(modalInstance);\n\n    // hidding all elements at the modal-host level from screenreaders when the a modal is opened\n    this.#adapter.hideHostSiblingsFromScreenReaders(this.#elRef);\n    if (\n      SkyModalHostService.openModalCount > 1 &&\n      SkyModalHostService.topModal === hostService\n    ) {\n      // hiding the lower modals when more than one modal is opened\n      this.#adapter.hidePreviousModalFromScreenReaders(modalElement);\n    }\n\n    const closeModal = () => {\n      // unhide siblings if last modal is closing\n      if (SkyModalHostService.openModalCount === 1) {\n        this.#adapter.unhideOrRestoreHostSiblingsFromScreenReaders();\n      } else if (SkyModalHostService.topModal === hostService) {\n        // if there are more than 1 modal then unhide the one behind this one before closing it\n        this.#adapter.unhidePreviousModalFromScreenReaders(modalElement);\n      }\n\n      hostService.destroy();\n      adapter.setPageScroll(SkyModalHostService.openModalCount > 0);\n      adapter.toggleFullPageModalClass(\n        SkyModalHostService.fullPageModalCount > 0\n      );\n      /* istanbul ignore else */\n      /* sanity check */\n      if (modalOpener && modalOpener.focus) {\n        modalOpener.focus();\n      }\n      modalComponentRef.destroy();\n    };\n\n    hostService.openHelp.subscribe((helpKey) => {\n      modalInstance.openHelp(helpKey);\n    });\n\n    hostService.close.subscribe(() => {\n      modalInstance.close();\n    });\n\n    this.#router.events.pipe(takeWhile(() => isOpen)).subscribe((event) => {\n      /* istanbul ignore else */\n      if (event instanceof NavigationStart) {\n        modalInstance.close();\n      }\n    });\n\n    modalInstance.closed.subscribe(() => {\n      isOpen = false;\n      this.#unregisterModalInstance(modalInstance);\n      closeModal();\n    });\n\n    // Necessary if the host was created via a consumer's lifecycle hook such as ngOnInit\n    this.#changeDetector.detectChanges();\n  }\n\n  #registerModalInstance(instance: SkyModalInstance): void {\n    this.#modalInstances.push(instance);\n  }\n\n  #unregisterModalInstance(instance: SkyModalInstance): void {\n    this.#modalInstances.slice(this.#modalInstances.indexOf(instance), 1);\n  }\n\n  #closeAllModalInstances(): void {\n    for (const instance of this.#modalInstances) {\n      instance.close();\n    }\n  }\n}\n","<div\n  class=\"sky-modal-host-backdrop\"\n  [hidden]=\"!modalOpen\"\n  [ngStyle]=\"{\n    zIndex: backdropZIndex\n  }\"\n></div>\n<div #target></div>\n"]}
|
|
@@ -138,7 +138,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
|
|
|
138
138
|
args: [{ selector: 'sky-modal-header', template: "<h1\n class=\"sky-emphasized\"\n [skyThemeClass]=\"{\n 'sky-font-display-3': 'modern'\n }\"\n>\n <ng-content></ng-content>\n</h1>\n", styles: ["h1{margin:0;line-height:1.2}:host-context(.sky-theme-modern.sky-theme-mode-dark) h1{color:#fbfcfe}.sky-theme-modern.sky-theme-mode-dark h1{color:#fbfcfe}\n"] }]
|
|
139
139
|
}] });
|
|
140
140
|
|
|
141
|
-
var _SkyModalAdapterService_instances, _SkyModalAdapterService_docRef, _SkyModalAdapterService_bodyEl, _SkyModalAdapterService_windowRef, _SkyModalAdapterService_addClassToBody, _SkyModalAdapterService_removeClassFromBody;
|
|
141
|
+
var _SkyModalAdapterService_instances, _SkyModalAdapterService_docRef, _SkyModalAdapterService_bodyEl, _SkyModalAdapterService_windowRef, _SkyModalAdapterService_hostSiblingAriaHiddenCache, _SkyModalAdapterService_addClassToBody, _SkyModalAdapterService_removeClassFromBody;
|
|
142
142
|
/**
|
|
143
143
|
* @internal
|
|
144
144
|
*/
|
|
@@ -148,6 +148,7 @@ class SkyModalAdapterService {
|
|
|
148
148
|
_SkyModalAdapterService_docRef.set(this, void 0);
|
|
149
149
|
_SkyModalAdapterService_bodyEl.set(this, void 0);
|
|
150
150
|
_SkyModalAdapterService_windowRef.set(this, void 0);
|
|
151
|
+
_SkyModalAdapterService_hostSiblingAriaHiddenCache.set(this, new Map());
|
|
151
152
|
__classPrivateFieldSet(this, _SkyModalAdapterService_windowRef, windowRef, "f");
|
|
152
153
|
__classPrivateFieldSet(this, _SkyModalAdapterService_docRef, __classPrivateFieldGet(this, _SkyModalAdapterService_windowRef, "f").nativeWindow.document, "f");
|
|
153
154
|
__classPrivateFieldSet(this, _SkyModalAdapterService_bodyEl, __classPrivateFieldGet(this, _SkyModalAdapterService_windowRef, "f").nativeWindow.document.body, "f");
|
|
@@ -171,8 +172,54 @@ class SkyModalAdapterService {
|
|
|
171
172
|
getModalOpener() {
|
|
172
173
|
return __classPrivateFieldGet(this, _SkyModalAdapterService_docRef, "f").activeElement;
|
|
173
174
|
}
|
|
175
|
+
/**
|
|
176
|
+
* Hides siblings of modal-host from screen readers
|
|
177
|
+
* @param hostElRef reference to modal-host element
|
|
178
|
+
*/
|
|
179
|
+
hideHostSiblingsFromScreenReaders(hostElRef) {
|
|
180
|
+
const hostElement = hostElRef.nativeElement;
|
|
181
|
+
const hostSiblings = hostElement.parentElement.children;
|
|
182
|
+
for (let i = 0; i < hostSiblings.length; i++) {
|
|
183
|
+
const element = hostSiblings[i];
|
|
184
|
+
if (element !== hostElement &&
|
|
185
|
+
!element.hasAttribute('aria-live') &&
|
|
186
|
+
element.nodeName.toLowerCase() !== 'script' &&
|
|
187
|
+
element.nodeName.toLowerCase() !== 'style') {
|
|
188
|
+
// preserve previous aria-hidden status of elements outside of modal host
|
|
189
|
+
__classPrivateFieldGet(this, _SkyModalAdapterService_hostSiblingAriaHiddenCache, "f").set(element, element.getAttribute('aria-hidden'));
|
|
190
|
+
element.setAttribute('aria-hidden', 'true');
|
|
191
|
+
}
|
|
192
|
+
}
|
|
193
|
+
}
|
|
194
|
+
/**
|
|
195
|
+
* Restores modal-host siblings to screenreader status prior to modals being opened
|
|
196
|
+
*/
|
|
197
|
+
unhideOrRestoreHostSiblingsFromScreenReaders() {
|
|
198
|
+
__classPrivateFieldGet(this, _SkyModalAdapterService_hostSiblingAriaHiddenCache, "f").forEach((previousValue, element) => {
|
|
199
|
+
// if element had aria-hidden status prior, restore status
|
|
200
|
+
if (element.parentElement) {
|
|
201
|
+
if (previousValue) {
|
|
202
|
+
element.setAttribute('aria-hidden', previousValue);
|
|
203
|
+
}
|
|
204
|
+
else {
|
|
205
|
+
element.removeAttribute('aria-hidden');
|
|
206
|
+
}
|
|
207
|
+
}
|
|
208
|
+
});
|
|
209
|
+
__classPrivateFieldGet(this, _SkyModalAdapterService_hostSiblingAriaHiddenCache, "f").clear();
|
|
210
|
+
}
|
|
211
|
+
hidePreviousModalFromScreenReaders(topModal) {
|
|
212
|
+
if (topModal && topModal.nativeElement.previousElementSibling) {
|
|
213
|
+
topModal.nativeElement.previousElementSibling.setAttribute('aria-hidden', 'true');
|
|
214
|
+
}
|
|
215
|
+
}
|
|
216
|
+
unhidePreviousModalFromScreenReaders(topModal) {
|
|
217
|
+
if (topModal && topModal.nativeElement.previousElementSibling) {
|
|
218
|
+
topModal.nativeElement.previousElementSibling.removeAttribute('aria-hidden');
|
|
219
|
+
}
|
|
220
|
+
}
|
|
174
221
|
}
|
|
175
|
-
_SkyModalAdapterService_docRef = new WeakMap(), _SkyModalAdapterService_bodyEl = new WeakMap(), _SkyModalAdapterService_windowRef = new WeakMap(), _SkyModalAdapterService_instances = new WeakSet(), _SkyModalAdapterService_addClassToBody = function _SkyModalAdapterService_addClassToBody(className) {
|
|
222
|
+
_SkyModalAdapterService_docRef = new WeakMap(), _SkyModalAdapterService_bodyEl = new WeakMap(), _SkyModalAdapterService_windowRef = new WeakMap(), _SkyModalAdapterService_hostSiblingAriaHiddenCache = new WeakMap(), _SkyModalAdapterService_instances = new WeakSet(), _SkyModalAdapterService_addClassToBody = function _SkyModalAdapterService_addClassToBody(className) {
|
|
176
223
|
__classPrivateFieldGet(this, _SkyModalAdapterService_bodyEl, "f").classList.add(className);
|
|
177
224
|
}, _SkyModalAdapterService_removeClassFromBody = function _SkyModalAdapterService_removeClassFromBody(className) {
|
|
178
225
|
__classPrivateFieldGet(this, _SkyModalAdapterService_bodyEl, "f").classList.remove(className);
|
|
@@ -282,12 +329,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
|
|
|
282
329
|
}] }];
|
|
283
330
|
} });
|
|
284
331
|
|
|
285
|
-
var _SkyModalHostComponent_instances, _SkyModalHostComponent_resolver, _SkyModalHostComponent_adapter, _SkyModalHostComponent_injector, _SkyModalHostComponent_router, _SkyModalHostComponent_changeDetector, _SkyModalHostComponent_modalHostContext, _SkyModalHostComponent_modalInstances, _SkyModalHostComponent_registerModalInstance, _SkyModalHostComponent_unregisterModalInstance, _SkyModalHostComponent_closeAllModalInstances;
|
|
332
|
+
var _SkyModalHostComponent_instances, _SkyModalHostComponent_resolver, _SkyModalHostComponent_adapter, _SkyModalHostComponent_injector, _SkyModalHostComponent_router, _SkyModalHostComponent_changeDetector, _SkyModalHostComponent_modalHostContext, _SkyModalHostComponent_elRef, _SkyModalHostComponent_modalInstances, _SkyModalHostComponent_registerModalInstance, _SkyModalHostComponent_unregisterModalInstance, _SkyModalHostComponent_closeAllModalInstances;
|
|
286
333
|
/**
|
|
287
334
|
* @internal
|
|
288
335
|
*/
|
|
289
336
|
class SkyModalHostComponent {
|
|
290
|
-
constructor(resolver, adapter, injector, router, changeDetector, modalHostContext) {
|
|
337
|
+
constructor(resolver, adapter, injector, router, changeDetector, modalHostContext, elRef) {
|
|
291
338
|
_SkyModalHostComponent_instances.add(this);
|
|
292
339
|
_SkyModalHostComponent_resolver.set(this, void 0);
|
|
293
340
|
_SkyModalHostComponent_adapter.set(this, void 0);
|
|
@@ -295,6 +342,7 @@ class SkyModalHostComponent {
|
|
|
295
342
|
_SkyModalHostComponent_router.set(this, void 0);
|
|
296
343
|
_SkyModalHostComponent_changeDetector.set(this, void 0);
|
|
297
344
|
_SkyModalHostComponent_modalHostContext.set(this, void 0);
|
|
345
|
+
_SkyModalHostComponent_elRef.set(this, void 0);
|
|
298
346
|
_SkyModalHostComponent_modalInstances.set(this, []);
|
|
299
347
|
__classPrivateFieldSet(this, _SkyModalHostComponent_resolver, resolver, "f");
|
|
300
348
|
__classPrivateFieldSet(this, _SkyModalHostComponent_adapter, adapter, "f");
|
|
@@ -302,6 +350,7 @@ class SkyModalHostComponent {
|
|
|
302
350
|
__classPrivateFieldSet(this, _SkyModalHostComponent_router, router, "f");
|
|
303
351
|
__classPrivateFieldSet(this, _SkyModalHostComponent_changeDetector, changeDetector, "f");
|
|
304
352
|
__classPrivateFieldSet(this, _SkyModalHostComponent_modalHostContext, modalHostContext, "f");
|
|
353
|
+
__classPrivateFieldSet(this, _SkyModalHostComponent_elRef, elRef, "f");
|
|
305
354
|
}
|
|
306
355
|
get modalOpen() {
|
|
307
356
|
return SkyModalHostService.openModalCount > 0;
|
|
@@ -350,9 +399,26 @@ class SkyModalHostComponent {
|
|
|
350
399
|
parent: __classPrivateFieldGet(this, _SkyModalHostComponent_injector, "f"),
|
|
351
400
|
});
|
|
352
401
|
const modalComponentRef = this.target.createComponent(factory, undefined, injector);
|
|
402
|
+
// modal element that was just opened
|
|
403
|
+
const modalElement = modalComponentRef.location;
|
|
353
404
|
modalInstance.componentInstance = modalComponentRef.instance;
|
|
354
405
|
__classPrivateFieldGet(this, _SkyModalHostComponent_instances, "m", _SkyModalHostComponent_registerModalInstance).call(this, modalInstance);
|
|
355
|
-
|
|
406
|
+
// hidding all elements at the modal-host level from screenreaders when the a modal is opened
|
|
407
|
+
__classPrivateFieldGet(this, _SkyModalHostComponent_adapter, "f").hideHostSiblingsFromScreenReaders(__classPrivateFieldGet(this, _SkyModalHostComponent_elRef, "f"));
|
|
408
|
+
if (SkyModalHostService.openModalCount > 1 &&
|
|
409
|
+
SkyModalHostService.topModal === hostService) {
|
|
410
|
+
// hiding the lower modals when more than one modal is opened
|
|
411
|
+
__classPrivateFieldGet(this, _SkyModalHostComponent_adapter, "f").hidePreviousModalFromScreenReaders(modalElement);
|
|
412
|
+
}
|
|
413
|
+
const closeModal = () => {
|
|
414
|
+
// unhide siblings if last modal is closing
|
|
415
|
+
if (SkyModalHostService.openModalCount === 1) {
|
|
416
|
+
__classPrivateFieldGet(this, _SkyModalHostComponent_adapter, "f").unhideOrRestoreHostSiblingsFromScreenReaders();
|
|
417
|
+
}
|
|
418
|
+
else if (SkyModalHostService.topModal === hostService) {
|
|
419
|
+
// if there are more than 1 modal then unhide the one behind this one before closing it
|
|
420
|
+
__classPrivateFieldGet(this, _SkyModalHostComponent_adapter, "f").unhidePreviousModalFromScreenReaders(modalElement);
|
|
421
|
+
}
|
|
356
422
|
hostService.destroy();
|
|
357
423
|
adapter.setPageScroll(SkyModalHostService.openModalCount > 0);
|
|
358
424
|
adapter.toggleFullPageModalClass(SkyModalHostService.fullPageModalCount > 0);
|
|
@@ -362,7 +428,7 @@ class SkyModalHostComponent {
|
|
|
362
428
|
modalOpener.focus();
|
|
363
429
|
}
|
|
364
430
|
modalComponentRef.destroy();
|
|
365
|
-
}
|
|
431
|
+
};
|
|
366
432
|
hostService.openHelp.subscribe((helpKey) => {
|
|
367
433
|
modalInstance.openHelp(helpKey);
|
|
368
434
|
});
|
|
@@ -384,7 +450,7 @@ class SkyModalHostComponent {
|
|
|
384
450
|
__classPrivateFieldGet(this, _SkyModalHostComponent_changeDetector, "f").detectChanges();
|
|
385
451
|
}
|
|
386
452
|
}
|
|
387
|
-
_SkyModalHostComponent_resolver = new WeakMap(), _SkyModalHostComponent_adapter = new WeakMap(), _SkyModalHostComponent_injector = new WeakMap(), _SkyModalHostComponent_router = new WeakMap(), _SkyModalHostComponent_changeDetector = new WeakMap(), _SkyModalHostComponent_modalHostContext = new WeakMap(), _SkyModalHostComponent_modalInstances = new WeakMap(), _SkyModalHostComponent_instances = new WeakSet(), _SkyModalHostComponent_registerModalInstance = function _SkyModalHostComponent_registerModalInstance(instance) {
|
|
453
|
+
_SkyModalHostComponent_resolver = new WeakMap(), _SkyModalHostComponent_adapter = new WeakMap(), _SkyModalHostComponent_injector = new WeakMap(), _SkyModalHostComponent_router = new WeakMap(), _SkyModalHostComponent_changeDetector = new WeakMap(), _SkyModalHostComponent_modalHostContext = new WeakMap(), _SkyModalHostComponent_elRef = new WeakMap(), _SkyModalHostComponent_modalInstances = new WeakMap(), _SkyModalHostComponent_instances = new WeakSet(), _SkyModalHostComponent_registerModalInstance = function _SkyModalHostComponent_registerModalInstance(instance) {
|
|
388
454
|
__classPrivateFieldGet(this, _SkyModalHostComponent_modalInstances, "f").push(instance);
|
|
389
455
|
}, _SkyModalHostComponent_unregisterModalInstance = function _SkyModalHostComponent_unregisterModalInstance(instance) {
|
|
390
456
|
__classPrivateFieldGet(this, _SkyModalHostComponent_modalInstances, "f").slice(__classPrivateFieldGet(this, _SkyModalHostComponent_modalInstances, "f").indexOf(instance), 1);
|
|
@@ -393,12 +459,12 @@ _SkyModalHostComponent_resolver = new WeakMap(), _SkyModalHostComponent_adapter
|
|
|
393
459
|
instance.close();
|
|
394
460
|
}
|
|
395
461
|
};
|
|
396
|
-
SkyModalHostComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyModalHostComponent, deps: [{ token: i0.ComponentFactoryResolver }, { token: SkyModalAdapterService }, { token: i0.Injector }, { token: i2$1.Router }, { token: i0.ChangeDetectorRef }, { token: SkyModalHostContext }], target: i0.ɵɵFactoryTarget.Component });
|
|
462
|
+
SkyModalHostComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyModalHostComponent, deps: [{ token: i0.ComponentFactoryResolver }, { token: SkyModalAdapterService }, { token: i0.Injector }, { token: i2$1.Router }, { token: i0.ChangeDetectorRef }, { token: SkyModalHostContext }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
397
463
|
SkyModalHostComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.2", type: SkyModalHostComponent, selector: "sky-modal-host", viewQueries: [{ propertyName: "target", first: true, predicate: ["target"], descendants: true, read: ViewContainerRef, static: true }], ngImport: i0, template: "<div\n class=\"sky-modal-host-backdrop\"\n [hidden]=\"!modalOpen\"\n [ngStyle]=\"{\n zIndex: backdropZIndex\n }\"\n></div>\n<div #target></div>\n", styles: [".sky-modal-host-backdrop{background-color:#00000080;position:fixed;top:0;left:0;bottom:0;right:0}\n"], directives: [{ type: i6.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }], viewProviders: [SkyModalAdapterService] });
|
|
398
464
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyModalHostComponent, decorators: [{
|
|
399
465
|
type: Component,
|
|
400
466
|
args: [{ selector: 'sky-modal-host', viewProviders: [SkyModalAdapterService], template: "<div\n class=\"sky-modal-host-backdrop\"\n [hidden]=\"!modalOpen\"\n [ngStyle]=\"{\n zIndex: backdropZIndex\n }\"\n></div>\n<div #target></div>\n", styles: [".sky-modal-host-backdrop{background-color:#00000080;position:fixed;top:0;left:0;bottom:0;right:0}\n"] }]
|
|
401
|
-
}], ctorParameters: function () { return [{ type: i0.ComponentFactoryResolver }, { type: SkyModalAdapterService }, { type: i0.Injector }, { type: i2$1.Router }, { type: i0.ChangeDetectorRef }, { type: SkyModalHostContext }]; }, propDecorators: { target: [{
|
|
467
|
+
}], ctorParameters: function () { return [{ type: i0.ComponentFactoryResolver }, { type: SkyModalAdapterService }, { type: i0.Injector }, { type: i2$1.Router }, { type: i0.ChangeDetectorRef }, { type: SkyModalHostContext }, { type: i0.ElementRef }]; }, propDecorators: { target: [{
|
|
402
468
|
type: ViewChild,
|
|
403
469
|
args: ['target', {
|
|
404
470
|
read: ViewContainerRef,
|