@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.
@@ -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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kYWwtYWRhcHRlci5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL21vZGFscy9zcmMvbGliL21vZHVsZXMvbW9kYWwvbW9kYWwtYWRhcHRlci5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzQyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sYUFBYSxDQUFDOzs7QUFFOUM7O0dBRUc7QUFFSCxNQUFNLE9BQU8sc0JBQXNCO0lBU2pDLFlBQVksU0FBMEI7O1FBTHRDLGlEQUFhO1FBQ2IsaURBQXFCO1FBRXJCLG9EQUE0QjtRQUcxQix1QkFBQSxJQUFJLHFDQUFjLFNBQVMsTUFBQSxDQUFDO1FBQzVCLHVCQUFBLElBQUksa0NBQVcsdUJBQUEsSUFBSSx5Q0FBVyxDQUFDLFlBQVksQ0FBQyxRQUFRLE1BQUEsQ0FBQztRQUNyRCx1QkFBQSxJQUFJLGtDQUFXLHVCQUFBLElBQUkseUNBQVcsQ0FBQyxZQUFZLENBQUMsUUFBUSxDQUFDLElBQUksTUFBQSxDQUFDO0lBQzVELENBQUM7SUFFTSx3QkFBd0IsQ0FBQyxTQUFrQjtRQUNoRCxJQUFJLFNBQVMsRUFBRTtZQUNiLHVCQUFBLElBQUksaUZBQWdCLE1BQXBCLElBQUksRUFBaUIsc0JBQXNCLENBQUMscUJBQXFCLENBQUMsQ0FBQztTQUNwRTthQUFNO1lBQ0wsdUJBQUEsSUFBSSxzRkFBcUIsTUFBekIsSUFBSSxFQUFzQixzQkFBc0IsQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDO1NBQ3pFO0lBQ0gsQ0FBQztJQUVNLGFBQWEsQ0FBQyxLQUFjO1FBQ2pDLElBQUksS0FBSyxFQUFFO1lBQ1QsdUJBQUEsSUFBSSxpRkFBZ0IsTUFBcEIsSUFBSSxFQUFpQixzQkFBc0IsQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO1NBQy9EO2FBQU07WUFDTCx1QkFBQSxJQUFJLHNGQUFxQixNQUF6QixJQUFJLEVBQXNCLHNCQUFzQixDQUFDLGdCQUFnQixDQUFDLENBQUM7U0FDcEU7SUFDSCxDQUFDO0lBRU0sY0FBYztRQUNuQixPQUFPLHVCQUFBLElBQUksc0NBQVEsQ0FBQyxhQUFhLENBQUM7SUFDcEMsQ0FBQzs7K1JBRWUsU0FBaUI7SUFDL0IsdUJBQUEsSUFBSSxzQ0FBUSxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsU0FBUyxDQUFDLENBQUM7QUFDeEMsQ0FBQyxxR0FFb0IsU0FBaUI7SUFDcEMsdUJBQUEsSUFBSSxzQ0FBUSxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsU0FBUyxDQUFDLENBQUM7QUFDM0MsQ0FBQztBQXhDdUIsNENBQXFCLEdBQUcsMEJBQTJCLENBQUE7QUFDbkQsdUNBQWdCLEdBQUcscUJBQXNCLENBQUE7bUhBRnRELHNCQUFzQjt1SEFBdEIsc0JBQXNCOzJGQUF0QixzQkFBc0I7a0JBRGxDLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBTa3lBcHBXaW5kb3dSZWYgfSBmcm9tICdAc2t5dXgvY29yZSc7XG5cbi8qKlxuICogQGludGVybmFsXG4gKi9cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBTa3lNb2RhbEFkYXB0ZXJTZXJ2aWNlIHtcbiAgcHJpdmF0ZSBzdGF0aWMgcmVhZG9ubHkgTU9EQUxfQk9EWV9GVUxMX0NMQVNTID0gJ3NreS1tb2RhbC1ib2R5LWZ1bGwtcGFnZSc7XG4gIHByaXZhdGUgc3RhdGljIHJlYWRvbmx5IE1PREFMX0JPRFlfQ0xBU1MgPSAnc2t5LW1vZGFsLWJvZHktb3Blbic7XG5cbiAgI2RvY1JlZjogYW55O1xuICAjYm9keUVsOiBIVE1MRWxlbWVudDtcblxuICAjd2luZG93UmVmOiBTa3lBcHBXaW5kb3dSZWY7XG5cbiAgY29uc3RydWN0b3Iod2luZG93UmVmOiBTa3lBcHBXaW5kb3dSZWYpIHtcbiAgICB0aGlzLiN3aW5kb3dSZWYgPSB3aW5kb3dSZWY7XG4gICAgdGhpcy4jZG9jUmVmID0gdGhpcy4jd2luZG93UmVmLm5hdGl2ZVdpbmRvdy5kb2N1bWVudDtcbiAgICB0aGlzLiNib2R5RWwgPSB0aGlzLiN3aW5kb3dSZWYubmF0aXZlV2luZG93LmRvY3VtZW50LmJvZHk7XG4gIH1cblxuICBwdWJsaWMgdG9nZ2xlRnVsbFBhZ2VNb2RhbENsYXNzKGlzQWRkRnVsbDogYm9vbGVhbik6IHZvaWQge1xuICAgIGlmIChpc0FkZEZ1bGwpIHtcbiAgICAgIHRoaXMuI2FkZENsYXNzVG9Cb2R5KFNreU1vZGFsQWRhcHRlclNlcnZpY2UuTU9EQUxfQk9EWV9GVUxMX0NMQVNTKTtcbiAgICB9IGVsc2Uge1xuICAgICAgdGhpcy4jcmVtb3ZlQ2xhc3NGcm9tQm9keShTa3lNb2RhbEFkYXB0ZXJTZXJ2aWNlLk1PREFMX0JPRFlfRlVMTF9DTEFTUyk7XG4gICAgfVxuICB9XG5cbiAgcHVibGljIHNldFBhZ2VTY3JvbGwoaXNBZGQ6IGJvb2xlYW4pOiB2b2lkIHtcbiAgICBpZiAoaXNBZGQpIHtcbiAgICAgIHRoaXMuI2FkZENsYXNzVG9Cb2R5KFNreU1vZGFsQWRhcHRlclNlcnZpY2UuTU9EQUxfQk9EWV9DTEFTUyk7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRoaXMuI3JlbW92ZUNsYXNzRnJvbUJvZHkoU2t5TW9kYWxBZGFwdGVyU2VydmljZS5NT0RBTF9CT0RZX0NMQVNTKTtcbiAgICB9XG4gIH1cblxuICBwdWJsaWMgZ2V0TW9kYWxPcGVuZXIoKTogSFRNTEVsZW1lbnQge1xuICAgIHJldHVybiB0aGlzLiNkb2NSZWYuYWN0aXZlRWxlbWVudDtcbiAgfVxuXG4gICNhZGRDbGFzc1RvQm9keShjbGFzc05hbWU6IHN0cmluZyk6IHZvaWQge1xuICAgIHRoaXMuI2JvZHlFbC5jbGFzc0xpc3QuYWRkKGNsYXNzTmFtZSk7XG4gIH1cblxuICAjcmVtb3ZlQ2xhc3NGcm9tQm9keShjbGFzc05hbWU6IHN0cmluZyk6IHZvaWQge1xuICAgIHRoaXMuI2JvZHlFbC5jbGFzc0xpc3QucmVtb3ZlKGNsYXNzTmFtZSk7XG4gIH1cbn1cbiJdfQ==
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
- function closeModal() {
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
- function closeModal() {
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,