@skyux/modals 7.0.0-beta.0 → 7.0.0-beta.10
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/documentation.json +297 -207
- package/esm2020/index.mjs +1 -3
- package/esm2020/lib/modules/confirm/confirm-button.mjs +1 -1
- package/esm2020/lib/modules/confirm/confirm.component.mjs +8 -5
- package/esm2020/lib/modules/modal/modal-header.component.mjs +4 -3
- package/esm2020/lib/modules/modal/modal-host.component.mjs +10 -8
- package/esm2020/lib/modules/modal/modal-host.service.mjs +15 -12
- package/esm2020/lib/modules/modal/modal-scroll-shadow.directive.mjs +4 -4
- package/esm2020/lib/modules/modal/modal.component.mjs +1 -1
- package/esm2020/lib/modules/modal/modal.interface.mjs +1 -3
- package/esm2020/lib/modules/modal/modal.module.mjs +7 -3
- package/esm2020/lib/modules/modal/modal.service.mjs +1 -3
- package/fesm2015/skyux-modals.mjs +46 -38
- package/fesm2015/skyux-modals.mjs.map +1 -1
- package/fesm2020/skyux-modals.mjs +43 -40
- package/fesm2020/skyux-modals.mjs.map +1 -1
- package/index.d.ts +0 -1
- package/lib/modules/confirm/confirm-button.d.ts +1 -1
- package/lib/modules/modal/modal-header.component.d.ts +1 -1
- package/lib/modules/modal/modal-host.component.d.ts +2 -2
- package/lib/modules/modal/modal-host.service.d.ts +1 -1
- package/lib/modules/modal/modal-scroll-shadow.directive.d.ts +2 -2
- package/lib/modules/modal/modal.component.d.ts +1 -1
- package/lib/modules/modal/modal.interface.d.ts +3 -1
- package/lib/modules/modal/modal.module.d.ts +2 -1
- package/lib/modules/modal/modal.service.d.ts +1 -1
- package/package.json +5 -5
package/esm2020/index.mjs
CHANGED
|
@@ -1,5 +1,3 @@
|
|
|
1
|
-
// TODO: confirm-button is internal and should be removed in a future version
|
|
2
|
-
export * from './lib/modules/confirm/confirm-button';
|
|
3
1
|
export * from './lib/modules/confirm/confirm-button-action';
|
|
4
2
|
export * from './lib/modules/confirm/confirm-button-config';
|
|
5
3
|
export * from './lib/modules/confirm/confirm-button-style-type';
|
|
@@ -24,4 +22,4 @@ export { SkyModalContentComponent as λ2 } from './lib/modules/modal/modal-conte
|
|
|
24
22
|
export { SkyModalFooterComponent as λ3 } from './lib/modules/modal/modal-footer.component';
|
|
25
23
|
export { SkyModalHeaderComponent as λ4 } from './lib/modules/modal/modal-header.component';
|
|
26
24
|
export { SkyModalComponent as λ5 } from './lib/modules/modal/modal.component';
|
|
27
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
25
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvbW9kYWxzL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDZDQUE2QyxDQUFDO0FBQzVELGNBQWMsNkNBQTZDLENBQUM7QUFDNUQsY0FBYyxpREFBaUQsQ0FBQztBQUNoRSxjQUFjLGlEQUFpRCxDQUFDO0FBQ2hFLGNBQWMsc0NBQXNDLENBQUM7QUFDckQsY0FBYyx3Q0FBd0MsQ0FBQztBQUN2RCxjQUFjLG9DQUFvQyxDQUFDO0FBQ25ELGNBQWMsc0NBQXNDLENBQUM7QUFDckQsY0FBYyx1Q0FBdUMsQ0FBQztBQUV0RCxjQUFjLGdEQUFnRCxDQUFDO0FBQy9ELGNBQWMsc0NBQXNDLENBQUM7QUFDckQsY0FBYyx5Q0FBeUMsQ0FBQztBQUN4RCxjQUFjLHdDQUF3QyxDQUFDO0FBQ3ZELGNBQWMsb0NBQW9DLENBQUM7QUFDbkQsY0FBYyxxQ0FBcUMsQ0FBQztBQUNwRCxjQUFjLGtDQUFrQyxDQUFDO0FBQ2pELGNBQWMsbUNBQW1DLENBQUM7QUFFbEQsMEZBQTBGO0FBQzFGLDJFQUEyRTtBQUMzRSxPQUFPLEVBQUUsbUJBQW1CLElBQUksRUFBRSxFQUFFLE1BQU0seUNBQXlDLENBQUM7QUFDcEYsT0FBTyxFQUFFLHdCQUF3QixJQUFJLEVBQUUsRUFBRSxNQUFNLDZDQUE2QyxDQUFDO0FBQzdGLE9BQU8sRUFBRSx1QkFBdUIsSUFBSSxFQUFFLEVBQUUsTUFBTSw0Q0FBNEMsQ0FBQztBQUMzRixPQUFPLEVBQUUsdUJBQXVCLElBQUksRUFBRSxFQUFFLE1BQU0sNENBQTRDLENBQUM7QUFDM0YsT0FBTyxFQUFFLGlCQUFpQixJQUFJLEVBQUUsRUFBRSxNQUFNLHFDQUFxQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kdWxlcy9jb25maXJtL2NvbmZpcm0tYnV0dG9uLWFjdGlvbic7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2R1bGVzL2NvbmZpcm0vY29uZmlybS1idXR0b24tY29uZmlnJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZHVsZXMvY29uZmlybS9jb25maXJtLWJ1dHRvbi1zdHlsZS10eXBlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZHVsZXMvY29uZmlybS9jb25maXJtLWNsb3NlZC1ldmVudC1hcmdzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZHVsZXMvY29uZmlybS9jb25maXJtLWNvbmZpZyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2R1bGVzL2NvbmZpcm0vY29uZmlybS1pbnN0YW5jZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2R1bGVzL2NvbmZpcm0vY29uZmlybS10eXBlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZHVsZXMvY29uZmlybS9jb25maXJtLm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2R1bGVzL2NvbmZpcm0vY29uZmlybS5zZXJ2aWNlJztcblxuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kdWxlcy9tb2RhbC9tb2RhbC1iZWZvcmUtY2xvc2UtaGFuZGxlcic7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2R1bGVzL21vZGFsL21vZGFsLWNsb3NlLWFyZ3MnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kdWxlcy9tb2RhbC9tb2RhbC1jb25maWd1cmF0aW9uJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZHVsZXMvbW9kYWwvbW9kYWwtaG9zdC5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZHVsZXMvbW9kYWwvbW9kYWwtaW5zdGFuY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kdWxlcy9tb2RhbC9tb2RhbC5pbnRlcmZhY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kdWxlcy9tb2RhbC9tb2RhbC5tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kdWxlcy9tb2RhbC9tb2RhbC5zZXJ2aWNlJztcblxuLy8gQ29tcG9uZW50cyBhbmQgZGlyZWN0aXZlcyBtdXN0IGJlIGV4cG9ydGVkIHRvIHN1cHBvcnQgQW5ndWxhcidzIFwicGFydGlhbFwiIEl2eSBjb21waWxlci5cbi8vIE9ic2N1cmUgbmFtZXMgYXJlIHVzZWQgdG8gaW5kaWNhdGUgdHlwZXMgYXJlIG5vdCBwYXJ0IG9mIHRoZSBwdWJsaWMgQVBJLlxuZXhwb3J0IHsgU2t5Q29uZmlybUNvbXBvbmVudCBhcyDOuzEgfSBmcm9tICcuL2xpYi9tb2R1bGVzL2NvbmZpcm0vY29uZmlybS5jb21wb25lbnQnO1xuZXhwb3J0IHsgU2t5TW9kYWxDb250ZW50Q29tcG9uZW50IGFzIM67MiB9IGZyb20gJy4vbGliL21vZHVsZXMvbW9kYWwvbW9kYWwtY29udGVudC5jb21wb25lbnQnO1xuZXhwb3J0IHsgU2t5TW9kYWxGb290ZXJDb21wb25lbnQgYXMgzrszIH0gZnJvbSAnLi9saWIvbW9kdWxlcy9tb2RhbC9tb2RhbC1mb290ZXIuY29tcG9uZW50JztcbmV4cG9ydCB7IFNreU1vZGFsSGVhZGVyQ29tcG9uZW50IGFzIM67NCB9IGZyb20gJy4vbGliL21vZHVsZXMvbW9kYWwvbW9kYWwtaGVhZGVyLmNvbXBvbmVudCc7XG5leHBvcnQgeyBTa3lNb2RhbENvbXBvbmVudCBhcyDOuzUgfSBmcm9tICcuL2xpYi9tb2R1bGVzL21vZGFsL21vZGFsLmNvbXBvbmVudCc7XG4iXX0=
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlybS1idXR0b24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvbW9kYWxzL3NyYy9saWIvbW9kdWxlcy9jb25maXJtL2NvbmZpcm0tYnV0dG9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTa3lDb25maXJtQnV0dG9uQWN0aW9uIH0gZnJvbSAnLi9jb25maXJtLWJ1dHRvbi1hY3Rpb24nO1xuaW1wb3J0IHsgU2t5Q29uZmlybUJ1dHRvblN0eWxlVHlwZSB9IGZyb20gJy4vY29uZmlybS1idXR0b24tc3R5bGUtdHlwZSc7XG5cbi8qKlxuICogVGhlIHZpZXcgbW9kZWwgZm9yIGJ1dHRvbiBjb25maWd1cmF0aW9uIHRoYXQgdGhlIGNvbmZpcm0gY29tcG9uZW50IHVzZXMuXG4gKiBAaW50ZXJuYWxcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBTa3lDb25maXJtQnV0dG9uIHtcbiAgYWN0aW9uOiBTa3lDb25maXJtQnV0dG9uQWN0aW9uO1xuICBzdHlsZVR5cGU6IFNreUNvbmZpcm1CdXR0b25TdHlsZVR5cGU7XG4gIHRleHQ6IHN0cmluZztcbiAgYXV0b2ZvY3VzPzogYm9vbGVhbjtcbn1cbiJdfQ==
|
|
@@ -2,7 +2,8 @@ var _SkyConfirmComponent_instances, _SkyConfirmComponent_config, _SkyConfirmComp
|
|
|
2
2
|
import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
|
|
3
3
|
import { Component, Inject, Optional } from '@angular/core';
|
|
4
4
|
import { SkyLibResourcesService } from '@skyux/i18n';
|
|
5
|
-
import {
|
|
5
|
+
import { ReplaySubject, zip as observableZip } from 'rxjs';
|
|
6
|
+
import { take } from 'rxjs/operators';
|
|
6
7
|
import { SkyModalInstance } from '../modal/modal-instance';
|
|
7
8
|
import { SKY_CONFIRM_CONFIG } from './confirm-config-token';
|
|
8
9
|
import { SkyConfirmType } from './confirm-type';
|
|
@@ -30,7 +31,9 @@ export class SkyConfirmComponent {
|
|
|
30
31
|
this.buttons = __classPrivateFieldGet(this, _SkyConfirmComponent_instances, "m", _SkyConfirmComponent_getCustomButtons).call(this, config.buttons);
|
|
31
32
|
}
|
|
32
33
|
else {
|
|
33
|
-
__classPrivateFieldGet(this, _SkyConfirmComponent_instances, "m", _SkyConfirmComponent_getPresetButtons).call(this)
|
|
34
|
+
__classPrivateFieldGet(this, _SkyConfirmComponent_instances, "m", _SkyConfirmComponent_getPresetButtons).call(this)
|
|
35
|
+
.pipe(take(1))
|
|
36
|
+
.subscribe((buttons) => {
|
|
34
37
|
this.buttons = buttons;
|
|
35
38
|
});
|
|
36
39
|
}
|
|
@@ -47,7 +50,7 @@ export class SkyConfirmComponent {
|
|
|
47
50
|
}
|
|
48
51
|
}
|
|
49
52
|
_SkyConfirmComponent_config = new WeakMap(), _SkyConfirmComponent_modal = new WeakMap(), _SkyConfirmComponent_resourcesService = new WeakMap(), _SkyConfirmComponent_instances = new WeakSet(), _SkyConfirmComponent_getPresetButtons = function _SkyConfirmComponent_getPresetButtons() {
|
|
50
|
-
const emitter = new
|
|
53
|
+
const emitter = new ReplaySubject(1);
|
|
51
54
|
switch (__classPrivateFieldGet(this, _SkyConfirmComponent_config, "f").type) {
|
|
52
55
|
default:
|
|
53
56
|
case SkyConfirmType.OK:
|
|
@@ -104,7 +107,7 @@ _SkyConfirmComponent_config = new WeakMap(), _SkyConfirmComponent_modal = new We
|
|
|
104
107
|
});
|
|
105
108
|
break;
|
|
106
109
|
}
|
|
107
|
-
return emitter;
|
|
110
|
+
return emitter.asObservable();
|
|
108
111
|
}, _SkyConfirmComponent_getCustomButtons = function _SkyConfirmComponent_getCustomButtons(buttonConfig) {
|
|
109
112
|
const buttons = [];
|
|
110
113
|
buttonConfig.forEach((config) => {
|
|
@@ -128,4 +131,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
|
|
|
128
131
|
}] }, { type: i1.SkyModalInstance }, { type: i2.SkyLibResourcesService, decorators: [{
|
|
129
132
|
type: Optional
|
|
130
133
|
}] }]; } });
|
|
131
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"confirm.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/modals/src/lib/modules/confirm/confirm.component.ts","../../../../../../../../libs/components/modals/src/lib/modules/confirm/confirm.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Inject, Optional } from '@angular/core';\nimport { SkyLibResourcesService } from '@skyux/i18n';\n\nimport { BehaviorSubject, Observable, zip as observableZip } from 'rxjs';\n\nimport { SkyModalInstance } from '../modal/modal-instance';\n\nimport { SkyConfirmButton } from './confirm-button';\nimport { SkyConfirmButtonConfig } from './confirm-button-config';\nimport { SkyConfirmCloseEventArgs } from './confirm-closed-event-args';\nimport { SkyConfirmConfig } from './confirm-config';\nimport { SKY_CONFIRM_CONFIG } from './confirm-config-token';\nimport { SkyConfirmType } from './confirm-type';\n\n@Component({\n  selector: 'sky-confirm',\n  templateUrl: './confirm.component.html',\n  styleUrls: ['./confirm.component.scss'],\n})\nexport class SkyConfirmComponent {\n  public buttons: SkyConfirmButton[] | undefined;\n  public message: string;\n  public body: string | undefined;\n  public preserveWhiteSpace = false;\n  public isOkType = false;\n\n  #config: SkyConfirmConfig;\n  #modal: SkyModalInstance;\n  #resourcesService: SkyLibResourcesService;\n\n  constructor(\n    @Inject(SKY_CONFIRM_CONFIG)\n    config: SkyConfirmConfig,\n    modal: SkyModalInstance,\n    @Optional() resourcesService: SkyLibResourcesService\n  ) {\n    this.#config = config;\n    this.#modal = modal;\n    this.#resourcesService = resourcesService!;\n\n    if (\n      config.type === SkyConfirmType.Custom &&\n      config.buttons &&\n      config.buttons.length > 0\n    ) {\n      this.buttons = this.#getCustomButtons(config.buttons);\n    } else {\n      this.#getPresetButtons().subscribe((buttons: SkyConfirmButton[]) => {\n        this.buttons = buttons;\n      });\n    }\n\n    this.message = config.message;\n    this.body = config.body;\n    this.preserveWhiteSpace = !!config.preserveWhiteSpace;\n    this.isOkType = config.type === SkyConfirmType.OK;\n  }\n\n  public close(button: SkyConfirmButton) {\n    const result: SkyConfirmCloseEventArgs = {\n      action: button.action,\n    };\n\n    this.#modal.close(result);\n  }\n\n  #getPresetButtons(): Observable<SkyConfirmButton[]> {\n    const emitter = new BehaviorSubject<SkyConfirmButton[]>([]);\n\n    switch (this.#config.type) {\n      default:\n      case SkyConfirmType.OK:\n        this.#resourcesService\n          .getString('skyux_confirm_dialog_default_ok_text')\n          .subscribe((value: string) => {\n            emitter.next([\n              {\n                text: value,\n                autofocus: true,\n                styleType: 'primary',\n                action: 'ok',\n              },\n            ]);\n          });\n        break;\n\n      case SkyConfirmType.YesNoCancel:\n        observableZip(\n          this.#resourcesService.getString(\n            'skyux_confirm_dialog_default_yes_text'\n          ),\n          this.#resourcesService.getString(\n            'skyux_confirm_dialog_default_no_text'\n          ),\n          this.#resourcesService.getString(\n            'skyux_confirm_dialog_default_cancel_text'\n          )\n        ).subscribe((values: any) => {\n          emitter.next([\n            {\n              text: values[0],\n              autofocus: true,\n              styleType: 'primary',\n              action: 'yes',\n            },\n            {\n              text: values[1],\n              styleType: 'default',\n              action: 'no',\n            },\n            {\n              text: values[2],\n              styleType: 'link',\n              action: 'cancel',\n            },\n          ]);\n        });\n        break;\n\n      case SkyConfirmType.YesCancel:\n        observableZip(\n          this.#resourcesService.getString(\n            'skyux_confirm_dialog_default_yes_text'\n          ),\n          this.#resourcesService.getString(\n            'skyux_confirm_dialog_default_cancel_text'\n          )\n        ).subscribe((values: any) => {\n          emitter.next([\n            {\n              text: values[0],\n              autofocus: true,\n              styleType: 'primary',\n              action: 'yes',\n            },\n            {\n              text: values[1],\n              styleType: 'link',\n              action: 'cancel',\n            },\n          ]);\n        });\n        break;\n    }\n\n    return emitter;\n  }\n\n  #getCustomButtons(\n    buttonConfig: SkyConfirmButtonConfig[]\n  ): SkyConfirmButton[] {\n    const buttons: SkyConfirmButton[] = [];\n\n    buttonConfig.forEach((config: SkyConfirmButtonConfig) => {\n      buttons.push({\n        text: config.text,\n        action: config.action,\n        styleType: config.styleType || 'default',\n        autofocus: config.autofocus || false,\n      } as SkyConfirmButton);\n    });\n\n    return buttons;\n  }\n}\n","<div class=\"sky-confirm\" [ngClass]=\"{ 'sky-confirm-type-ok': isOkType }\">\n  <sky-modal ariaRole=\"alertdialog\">\n    <sky-modal-content class=\"sky-confirm-content\">\n      <div\n        class=\"sky-confirm-message\"\n        [ngClass]=\"{\n          'sky-confirm-preserve-white-space': preserveWhiteSpace\n        }\"\n        [skyThemeClass]=\"{\n          'sky-emphasized': 'default',\n          'sky-font-heading-1 sky-font-display-3': 'modern'\n        }\"\n      >\n        {{ message }}\n      </div>\n\n      <div\n        *ngIf=\"body\"\n        class=\"sky-confirm-body\"\n        [ngClass]=\"{\n          'sky-confirm-preserve-white-space': preserveWhiteSpace\n        }\"\n      >\n        {{ body }}\n      </div>\n\n      <div class=\"sky-confirm-buttons\">\n        <button\n          *ngFor=\"let button of buttons\"\n          type=\"button\"\n          class=\"sky-btn\"\n          [ngClass]=\"['sky-btn-' + button.styleType]\"\n          [skyThemeClass]=\"{\n            'sky-margin-inline-sm': 'modern',\n            'sky-margin-inline-compact': 'default'\n          }\"\n          (click)=\"close(button)\"\n          [attr.autofocus]=\"button.autofocus ? 'autofocus' : null\"\n        >\n          {{ button.text }}\n        </button>\n      </div>\n    </sky-modal-content>\n  </sky-modal>\n</div>\n"]}
|
|
134
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"confirm.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/modals/src/lib/modules/confirm/confirm.component.ts","../../../../../../../../libs/components/modals/src/lib/modules/confirm/confirm.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Inject, Optional } from '@angular/core';\nimport { SkyLibResourcesService } from '@skyux/i18n';\n\nimport { Observable, ReplaySubject, zip as observableZip } from 'rxjs';\nimport { take } from 'rxjs/operators';\n\nimport { SkyModalInstance } from '../modal/modal-instance';\n\nimport { SkyConfirmButton } from './confirm-button';\nimport { SkyConfirmButtonConfig } from './confirm-button-config';\nimport { SkyConfirmCloseEventArgs } from './confirm-closed-event-args';\nimport { SkyConfirmConfig } from './confirm-config';\nimport { SKY_CONFIRM_CONFIG } from './confirm-config-token';\nimport { SkyConfirmType } from './confirm-type';\n\n@Component({\n  selector: 'sky-confirm',\n  templateUrl: './confirm.component.html',\n  styleUrls: ['./confirm.component.scss'],\n})\nexport class SkyConfirmComponent {\n  public buttons: SkyConfirmButton[] | undefined;\n  public message: string;\n  public body: string | undefined;\n  public preserveWhiteSpace = false;\n  public isOkType = false;\n\n  #config: SkyConfirmConfig;\n  #modal: SkyModalInstance;\n  #resourcesService: SkyLibResourcesService;\n\n  constructor(\n    @Inject(SKY_CONFIRM_CONFIG)\n    config: SkyConfirmConfig,\n    modal: SkyModalInstance,\n    @Optional() resourcesService: SkyLibResourcesService\n  ) {\n    this.#config = config;\n    this.#modal = modal;\n    this.#resourcesService = resourcesService!;\n\n    if (\n      config.type === SkyConfirmType.Custom &&\n      config.buttons &&\n      config.buttons.length > 0\n    ) {\n      this.buttons = this.#getCustomButtons(config.buttons);\n    } else {\n      this.#getPresetButtons()\n        .pipe(take(1))\n        .subscribe((buttons: SkyConfirmButton[]) => {\n          this.buttons = buttons;\n        });\n    }\n\n    this.message = config.message;\n    this.body = config.body;\n    this.preserveWhiteSpace = !!config.preserveWhiteSpace;\n    this.isOkType = config.type === SkyConfirmType.OK;\n  }\n\n  public close(button: SkyConfirmButton) {\n    const result: SkyConfirmCloseEventArgs = {\n      action: button.action,\n    };\n\n    this.#modal.close(result);\n  }\n\n  #getPresetButtons(): Observable<SkyConfirmButton[]> {\n    const emitter = new ReplaySubject<SkyConfirmButton[]>(1);\n\n    switch (this.#config.type) {\n      default:\n      case SkyConfirmType.OK:\n        this.#resourcesService\n          .getString('skyux_confirm_dialog_default_ok_text')\n          .subscribe((value: string) => {\n            emitter.next([\n              {\n                text: value,\n                autofocus: true,\n                styleType: 'primary',\n                action: 'ok',\n              },\n            ]);\n          });\n        break;\n\n      case SkyConfirmType.YesNoCancel:\n        observableZip(\n          this.#resourcesService.getString(\n            'skyux_confirm_dialog_default_yes_text'\n          ),\n          this.#resourcesService.getString(\n            'skyux_confirm_dialog_default_no_text'\n          ),\n          this.#resourcesService.getString(\n            'skyux_confirm_dialog_default_cancel_text'\n          )\n        ).subscribe((values: any) => {\n          emitter.next([\n            {\n              text: values[0],\n              autofocus: true,\n              styleType: 'primary',\n              action: 'yes',\n            },\n            {\n              text: values[1],\n              styleType: 'default',\n              action: 'no',\n            },\n            {\n              text: values[2],\n              styleType: 'link',\n              action: 'cancel',\n            },\n          ]);\n        });\n        break;\n\n      case SkyConfirmType.YesCancel:\n        observableZip(\n          this.#resourcesService.getString(\n            'skyux_confirm_dialog_default_yes_text'\n          ),\n          this.#resourcesService.getString(\n            'skyux_confirm_dialog_default_cancel_text'\n          )\n        ).subscribe((values: any) => {\n          emitter.next([\n            {\n              text: values[0],\n              autofocus: true,\n              styleType: 'primary',\n              action: 'yes',\n            },\n            {\n              text: values[1],\n              styleType: 'link',\n              action: 'cancel',\n            },\n          ]);\n        });\n        break;\n    }\n\n    return emitter.asObservable();\n  }\n\n  #getCustomButtons(\n    buttonConfig: SkyConfirmButtonConfig[]\n  ): SkyConfirmButton[] {\n    const buttons: SkyConfirmButton[] = [];\n\n    buttonConfig.forEach((config: SkyConfirmButtonConfig) => {\n      buttons.push({\n        text: config.text,\n        action: config.action,\n        styleType: config.styleType || 'default',\n        autofocus: config.autofocus || false,\n      } as SkyConfirmButton);\n    });\n\n    return buttons;\n  }\n}\n","<div class=\"sky-confirm\" [ngClass]=\"{ 'sky-confirm-type-ok': isOkType }\">\n  <sky-modal ariaRole=\"alertdialog\">\n    <sky-modal-content class=\"sky-confirm-content\">\n      <div\n        class=\"sky-confirm-message\"\n        [ngClass]=\"{\n          'sky-confirm-preserve-white-space': preserveWhiteSpace\n        }\"\n        [skyThemeClass]=\"{\n          'sky-emphasized': 'default',\n          'sky-font-heading-1 sky-font-display-3': 'modern'\n        }\"\n      >\n        {{ message }}\n      </div>\n\n      <div\n        *ngIf=\"body\"\n        class=\"sky-confirm-body\"\n        [ngClass]=\"{\n          'sky-confirm-preserve-white-space': preserveWhiteSpace\n        }\"\n      >\n        {{ body }}\n      </div>\n\n      <div class=\"sky-confirm-buttons\">\n        <button\n          *ngFor=\"let button of buttons\"\n          type=\"button\"\n          class=\"sky-btn\"\n          [ngClass]=\"['sky-btn-' + button.styleType]\"\n          [skyThemeClass]=\"{\n            'sky-margin-inline-sm': 'modern',\n            'sky-margin-inline-compact': 'default'\n          }\"\n          (click)=\"close(button)\"\n          [attr.autofocus]=\"button.autofocus ? 'autofocus' : null\"\n        >\n          {{ button.text }}\n        </button>\n      </div>\n    </sky-modal-content>\n  </sky-modal>\n</div>\n"]}
|
|
@@ -1,15 +1,16 @@
|
|
|
1
1
|
import { Component } from '@angular/core';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
3
|
import * as i1 from "@skyux/theme";
|
|
4
|
+
import * as i2 from "@skyux/core";
|
|
4
5
|
/**
|
|
5
6
|
* Specifies a header for the modal.
|
|
6
7
|
*/
|
|
7
8
|
export class SkyModalHeaderComponent {
|
|
8
9
|
}
|
|
9
10
|
SkyModalHeaderComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyModalHeaderComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
10
|
-
SkyModalHeaderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: SkyModalHeaderComponent, selector: "sky-modal-header", ngImport: i0, 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"], dependencies: [{ kind: "directive", type: i1.λ2, selector: "[skyThemeClass]", inputs: ["class", "skyThemeClass"] }] });
|
|
11
|
+
SkyModalHeaderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: SkyModalHeaderComponent, selector: "sky-modal-header", ngImport: i0, template: "<h1\n class=\"sky-emphasized\"\n [skyThemeClass]=\"{\n 'sky-font-display-3': 'modern'\n }\"\n skyTrim\n>\n <ng-content></ng-content>\n</h1>\n<span class=\"sky-control-help-container\" skyTrim\n ><ng-content select=\".sky-control-help\"></ng-content\n></span>\n", styles: ["h1{margin:0;line-height:1.2;display:inline}:host-context(.sky-theme-modern.sky-theme-mode-dark) h1{color:#fbfcfe}.sky-theme-modern.sky-theme-mode-dark h1{color:#fbfcfe}\n"], dependencies: [{ kind: "directive", type: i1.λ2, selector: "[skyThemeClass]", inputs: ["class", "skyThemeClass"] }, { kind: "directive", type: i2.λ4, selector: "[skyTrim]" }] });
|
|
11
12
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyModalHeaderComponent, decorators: [{
|
|
12
13
|
type: Component,
|
|
13
|
-
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"] }]
|
|
14
|
+
args: [{ selector: 'sky-modal-header', template: "<h1\n class=\"sky-emphasized\"\n [skyThemeClass]=\"{\n 'sky-font-display-3': 'modern'\n }\"\n skyTrim\n>\n <ng-content></ng-content>\n</h1>\n<span class=\"sky-control-help-container\" skyTrim\n ><ng-content select=\".sky-control-help\"></ng-content\n></span>\n", styles: ["h1{margin:0;line-height:1.2;display:inline}:host-context(.sky-theme-modern.sky-theme-mode-dark) h1{color:#fbfcfe}.sky-theme-modern.sky-theme-mode-dark h1{color:#fbfcfe}\n"] }]
|
|
14
15
|
}] });
|
|
15
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kYWwtaGVhZGVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9tb2RhbHMvc3JjL2xpYi9tb2R1bGVzL21vZGFsL21vZGFsLWhlYWRlci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvbW9kYWxzL3NyYy9saWIvbW9kdWxlcy9tb2RhbC9tb2RhbC1oZWFkZXIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7OztBQUUxQzs7R0FFRztBQU1ILE1BQU0sT0FBTyx1QkFBdUI7O29IQUF2Qix1QkFBdUI7d0dBQXZCLHVCQUF1Qix3RENWcEMsK1FBWUE7MkZERmEsdUJBQXVCO2tCQUxuQyxTQUFTOytCQUNFLGtCQUFrQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG4vKipcbiAqIFNwZWNpZmllcyBhIGhlYWRlciBmb3IgdGhlIG1vZGFsLlxuICovXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdza3ktbW9kYWwtaGVhZGVyJyxcbiAgdGVtcGxhdGVVcmw6ICcuL21vZGFsLWhlYWRlci5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL21vZGFsLWhlYWRlci5jb21wb25lbnQuc2NzcyddLFxufSlcbmV4cG9ydCBjbGFzcyBTa3lNb2RhbEhlYWRlckNvbXBvbmVudCB7fVxuIiwiPGgxXG4gIGNsYXNzPVwic2t5LWVtcGhhc2l6ZWRcIlxuICBbc2t5VGhlbWVDbGFzc109XCJ7XG4gICAgJ3NreS1mb250LWRpc3BsYXktMyc6ICdtb2Rlcm4nXG4gIH1cIlxuICBza3lUcmltXG4+XG4gIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cbjwvaDE+XG48c3BhbiBjbGFzcz1cInNreS1jb250cm9sLWhlbHAtY29udGFpbmVyXCIgc2t5VHJpbVxuICA+PG5nLWNvbnRlbnQgc2VsZWN0PVwiLnNreS1jb250cm9sLWhlbHBcIj48L25nLWNvbnRlbnRcbj48L3NwYW4+XG4iXX0=
|
|
@@ -1,6 +1,6 @@
|
|
|
1
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, ElementRef, Injector, ViewChild, ViewContainerRef, } from '@angular/core';
|
|
3
|
+
import { ChangeDetectorRef, Component, ComponentFactoryResolver, ElementRef, Injector, Optional, 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';
|
|
@@ -10,14 +10,14 @@ import { SkyModalHostContext } from './modal-host-context';
|
|
|
10
10
|
import { SkyModalHostService } from './modal-host.service';
|
|
11
11
|
import * as i0 from "@angular/core";
|
|
12
12
|
import * as i1 from "./modal-adapter.service";
|
|
13
|
-
import * as i2 from "
|
|
14
|
-
import * as i3 from "
|
|
13
|
+
import * as i2 from "./modal-host-context";
|
|
14
|
+
import * as i3 from "@angular/router";
|
|
15
15
|
import * as i4 from "@angular/common";
|
|
16
16
|
/**
|
|
17
17
|
* @internal
|
|
18
18
|
*/
|
|
19
19
|
export class SkyModalHostComponent {
|
|
20
|
-
constructor(resolver, adapter, injector,
|
|
20
|
+
constructor(resolver, adapter, injector, changeDetector, modalHostContext, elRef, router) {
|
|
21
21
|
_SkyModalHostComponent_instances.add(this);
|
|
22
22
|
_SkyModalHostComponent_resolver.set(this, void 0);
|
|
23
23
|
_SkyModalHostComponent_adapter.set(this, void 0);
|
|
@@ -118,7 +118,7 @@ export class SkyModalHostComponent {
|
|
|
118
118
|
hostService.close.subscribe(() => {
|
|
119
119
|
modalInstance.close();
|
|
120
120
|
});
|
|
121
|
-
__classPrivateFieldGet(this, _SkyModalHostComponent_router, "f")
|
|
121
|
+
__classPrivateFieldGet(this, _SkyModalHostComponent_router, "f")?.events.pipe(takeWhile(() => isOpen)).subscribe((event) => {
|
|
122
122
|
/* istanbul ignore else */
|
|
123
123
|
if (event instanceof NavigationStart) {
|
|
124
124
|
modalInstance.close();
|
|
@@ -142,16 +142,18 @@ _SkyModalHostComponent_resolver = new WeakMap(), _SkyModalHostComponent_adapter
|
|
|
142
142
|
instance.close();
|
|
143
143
|
}
|
|
144
144
|
};
|
|
145
|
-
SkyModalHostComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyModalHostComponent, deps: [{ token: i0.ComponentFactoryResolver }, { token: i1.SkyModalAdapterService }, { token: i0.Injector }, { token:
|
|
145
|
+
SkyModalHostComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyModalHostComponent, deps: [{ token: i0.ComponentFactoryResolver }, { token: i1.SkyModalAdapterService }, { token: i0.Injector }, { token: i0.ChangeDetectorRef }, { token: i2.SkyModalHostContext }, { token: i0.ElementRef }, { token: i3.Router, optional: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
146
146
|
SkyModalHostComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", 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;inset:0}\n"], dependencies: [{ kind: "directive", type: i4.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }], viewProviders: [SkyModalAdapterService] });
|
|
147
147
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyModalHostComponent, decorators: [{
|
|
148
148
|
type: Component,
|
|
149
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;inset:0}\n"] }]
|
|
150
|
-
}], ctorParameters: function () { return [{ type: i0.ComponentFactoryResolver }, { type: i1.SkyModalAdapterService }, { type: i0.Injector }, { type:
|
|
150
|
+
}], ctorParameters: function () { return [{ type: i0.ComponentFactoryResolver }, { type: i1.SkyModalAdapterService }, { type: i0.Injector }, { type: i0.ChangeDetectorRef }, { type: i2.SkyModalHostContext }, { type: i0.ElementRef }, { type: i3.Router, decorators: [{
|
|
151
|
+
type: Optional
|
|
152
|
+
}] }]; }, propDecorators: { target: [{
|
|
151
153
|
type: ViewChild,
|
|
152
154
|
args: ['target', {
|
|
153
155
|
read: ViewContainerRef,
|
|
154
156
|
static: true,
|
|
155
157
|
}]
|
|
156
158
|
}] } });
|
|
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"]}
|
|
159
|
+
//# 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  Optional,\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 | undefined;\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    changeDetector: ChangeDetectorRef,\n    modalHostContext: SkyModalHostContext,\n    elRef: ElementRef,\n    @Optional() router?: Router\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"]}
|
|
@@ -1,3 +1,5 @@
|
|
|
1
|
+
var _SkyModalHostService_instances, _SkyModalHostService_calculateZIndex;
|
|
2
|
+
import { __classPrivateFieldGet } from "tslib";
|
|
1
3
|
import { Injectable } from '@angular/core';
|
|
2
4
|
import { Subject } from 'rxjs';
|
|
3
5
|
import * as i0 from "@angular/core";
|
|
@@ -9,10 +11,11 @@ const modalHosts = [];
|
|
|
9
11
|
*/
|
|
10
12
|
export class SkyModalHostService {
|
|
11
13
|
constructor() {
|
|
14
|
+
_SkyModalHostService_instances.add(this);
|
|
12
15
|
this.close = new Subject();
|
|
13
16
|
this.fullPage = false;
|
|
14
17
|
this.openHelp = new Subject();
|
|
15
|
-
this.zIndex = this.
|
|
18
|
+
this.zIndex = __classPrivateFieldGet(this, _SkyModalHostService_instances, "m", _SkyModalHostService_calculateZIndex).call(this);
|
|
16
19
|
modalHosts.push(this);
|
|
17
20
|
}
|
|
18
21
|
static get openModalCount() {
|
|
@@ -40,17 +43,17 @@ export class SkyModalHostService {
|
|
|
40
43
|
destroy() {
|
|
41
44
|
modalHosts.splice(modalHosts.indexOf(this), 1);
|
|
42
45
|
}
|
|
43
|
-
calculateZIndex() {
|
|
44
|
-
const zIndexArray = modalHosts.map((hostService) => hostService.zIndex);
|
|
45
|
-
if (zIndexArray.length === 0) {
|
|
46
|
-
return BASE_Z_INDEX + 11;
|
|
47
|
-
}
|
|
48
|
-
else {
|
|
49
|
-
const currentMaxZIndex = Math.max(...zIndexArray);
|
|
50
|
-
return currentMaxZIndex + 10;
|
|
51
|
-
}
|
|
52
|
-
}
|
|
53
46
|
}
|
|
47
|
+
_SkyModalHostService_instances = new WeakSet(), _SkyModalHostService_calculateZIndex = function _SkyModalHostService_calculateZIndex() {
|
|
48
|
+
const zIndexArray = modalHosts.map((hostService) => hostService.zIndex);
|
|
49
|
+
if (zIndexArray.length === 0) {
|
|
50
|
+
return BASE_Z_INDEX + 11;
|
|
51
|
+
}
|
|
52
|
+
else {
|
|
53
|
+
const currentMaxZIndex = Math.max(...zIndexArray);
|
|
54
|
+
return currentMaxZIndex + 10;
|
|
55
|
+
}
|
|
56
|
+
};
|
|
54
57
|
SkyModalHostService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyModalHostService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
55
58
|
SkyModalHostService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyModalHostService, providedIn: 'root' });
|
|
56
59
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyModalHostService, decorators: [{
|
|
@@ -59,4 +62,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
|
|
|
59
62
|
providedIn: 'root',
|
|
60
63
|
}]
|
|
61
64
|
}], ctorParameters: function () { return []; } });
|
|
62
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
65
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kYWwtaG9zdC5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL21vZGFscy9zcmMvbGliL21vZHVsZXMvbW9kYWwvbW9kYWwtaG9zdC5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUzQyxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sTUFBTSxDQUFDOztBQUUvQixNQUFNLFlBQVksR0FBRyxJQUFJLENBQUM7QUFDMUIsTUFBTSxVQUFVLEdBQTBCLEVBQUUsQ0FBQztBQUU3Qzs7O0dBR0c7QUFJSCxNQUFNLE9BQU8sbUJBQW1CO0lBdUI5Qjs7UUFMTyxVQUFLLEdBQUcsSUFBSSxPQUFPLEVBQVEsQ0FBQztRQUM1QixhQUFRLEdBQUcsS0FBSyxDQUFDO1FBQ2pCLGFBQVEsR0FBRyxJQUFJLE9BQU8sRUFBVSxDQUFDO1FBSXRDLElBQUksQ0FBQyxNQUFNLEdBQUcsdUJBQUEsSUFBSSw0RUFBaUIsTUFBckIsSUFBSSxDQUFtQixDQUFDO1FBQ3RDLFVBQVUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDeEIsQ0FBQztJQXpCTSxNQUFNLEtBQUssY0FBYztRQUM5QixPQUFPLFVBQVUsQ0FBQyxNQUFNLENBQUM7SUFDM0IsQ0FBQztJQUVNLE1BQU0sS0FBSyxrQkFBa0I7UUFDbEMsTUFBTSxjQUFjLEdBQUcsVUFBVSxDQUFDLE1BQU0sQ0FBQyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBQ3BFLE9BQU8sY0FBYyxDQUFDLE1BQU0sQ0FBQztJQUMvQixDQUFDO0lBRU0sTUFBTSxLQUFLLGNBQWM7UUFDOUIsT0FBTyxZQUFZLEdBQUcsVUFBVSxDQUFDLE1BQU0sR0FBRyxFQUFFLENBQUM7SUFDL0MsQ0FBQztJQUVNLE1BQU0sS0FBSyxRQUFRO1FBQ3hCLE9BQU8sVUFBVSxDQUFDLFVBQVUsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDLENBQUM7SUFDM0MsQ0FBQztJQVlNLGNBQWM7UUFDbkIsT0FBTyxJQUFJLENBQUMsTUFBTSxDQUFDO0lBQ3JCLENBQUM7SUFFTSxPQUFPO1FBQ1osSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUNwQixDQUFDO0lBRU0sVUFBVSxDQUFDLE9BQWU7UUFDL0IsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDOUIsQ0FBQztJQUVNLE9BQU87UUFDWixVQUFVLENBQUMsTUFBTSxDQUFDLFVBQVUsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7SUFDakQsQ0FBQzs7O0lBR0MsTUFBTSxXQUFXLEdBQUcsVUFBVSxDQUFDLEdBQUcsQ0FBQyxDQUFDLFdBQVcsRUFBRSxFQUFFLENBQUMsV0FBVyxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQ3hFLElBQUksV0FBVyxDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQUU7UUFDNUIsT0FBTyxZQUFZLEdBQUcsRUFBRSxDQUFDO0tBQzFCO1NBQU07UUFDTCxNQUFNLGdCQUFnQixHQUFHLElBQUksQ0FBQyxHQUFHLENBQUMsR0FBRyxXQUFXLENBQUMsQ0FBQztRQUNsRCxPQUFPLGdCQUFnQixHQUFHLEVBQUUsQ0FBQztLQUM5QjtBQUNILENBQUM7Z0hBcERVLG1CQUFtQjtvSEFBbkIsbUJBQW1CLGNBRmxCLE1BQU07MkZBRVAsbUJBQW1CO2tCQUgvQixVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgU3ViamVjdCB9IGZyb20gJ3J4anMnO1xuXG5jb25zdCBCQVNFX1pfSU5ERVggPSAxMDQwO1xuY29uc3QgbW9kYWxIb3N0czogU2t5TW9kYWxIb3N0U2VydmljZVtdID0gW107XG5cbi8qKlxuICogQGludGVybmFsXG4gKiBAZHluYW1pY1xuICovXG5ASW5qZWN0YWJsZSh7XG4gIHByb3ZpZGVkSW46ICdyb290Jyxcbn0pXG5leHBvcnQgY2xhc3MgU2t5TW9kYWxIb3N0U2VydmljZSB7XG4gIHB1YmxpYyBzdGF0aWMgZ2V0IG9wZW5Nb2RhbENvdW50KCk6IG51bWJlciB7XG4gICAgcmV0dXJuIG1vZGFsSG9zdHMubGVuZ3RoO1xuICB9XG5cbiAgcHVibGljIHN0YXRpYyBnZXQgZnVsbFBhZ2VNb2RhbENvdW50KCk6IG51bWJlciB7XG4gICAgY29uc3QgZnVsbFBhZ2VNb2RhbHMgPSBtb2RhbEhvc3RzLmZpbHRlcigobW9kYWwpID0+IG1vZGFsLmZ1bGxQYWdlKTtcbiAgICByZXR1cm4gZnVsbFBhZ2VNb2RhbHMubGVuZ3RoO1xuICB9XG5cbiAgcHVibGljIHN0YXRpYyBnZXQgYmFja2Ryb3BaSW5kZXgoKTogbnVtYmVyIHtcbiAgICByZXR1cm4gQkFTRV9aX0lOREVYICsgbW9kYWxIb3N0cy5sZW5ndGggKiAxMDtcbiAgfVxuXG4gIHB1YmxpYyBzdGF0aWMgZ2V0IHRvcE1vZGFsKCk6IFNreU1vZGFsSG9zdFNlcnZpY2Uge1xuICAgIHJldHVybiBtb2RhbEhvc3RzW21vZGFsSG9zdHMubGVuZ3RoIC0gMV07XG4gIH1cblxuICBwdWJsaWMgY2xvc2UgPSBuZXcgU3ViamVjdDx2b2lkPigpO1xuICBwdWJsaWMgZnVsbFBhZ2UgPSBmYWxzZTtcbiAgcHVibGljIG9wZW5IZWxwID0gbmV3IFN1YmplY3Q8c3RyaW5nPigpO1xuICBwdWJsaWMgekluZGV4OiBudW1iZXI7XG5cbiAgY29uc3RydWN0b3IoKSB7XG4gICAgdGhpcy56SW5kZXggPSB0aGlzLiNjYWxjdWxhdGVaSW5kZXgoKTtcbiAgICBtb2RhbEhvc3RzLnB1c2godGhpcyk7XG4gIH1cblxuICBwdWJsaWMgZ2V0TW9kYWxaSW5kZXgoKTogbnVtYmVyIHtcbiAgICByZXR1cm4gdGhpcy56SW5kZXg7XG4gIH1cblxuICBwdWJsaWMgb25DbG9zZSgpOiB2b2lkIHtcbiAgICB0aGlzLmNsb3NlLm5leHQoKTtcbiAgfVxuXG4gIHB1YmxpYyBvbk9wZW5IZWxwKGhlbHBLZXk6IHN0cmluZykge1xuICAgIHRoaXMub3BlbkhlbHAubmV4dChoZWxwS2V5KTtcbiAgfVxuXG4gIHB1YmxpYyBkZXN0cm95KCk6IHZvaWQge1xuICAgIG1vZGFsSG9zdHMuc3BsaWNlKG1vZGFsSG9zdHMuaW5kZXhPZih0aGlzKSwgMSk7XG4gIH1cblxuICAjY2FsY3VsYXRlWkluZGV4KCk6IG51bWJlciB7XG4gICAgY29uc3QgekluZGV4QXJyYXkgPSBtb2RhbEhvc3RzLm1hcCgoaG9zdFNlcnZpY2UpID0+IGhvc3RTZXJ2aWNlLnpJbmRleCk7XG4gICAgaWYgKHpJbmRleEFycmF5Lmxlbmd0aCA9PT0gMCkge1xuICAgICAgcmV0dXJuIEJBU0VfWl9JTkRFWCArIDExO1xuICAgIH0gZWxzZSB7XG4gICAgICBjb25zdCBjdXJyZW50TWF4WkluZGV4ID0gTWF0aC5tYXgoLi4uekluZGV4QXJyYXkpO1xuICAgICAgcmV0dXJuIGN1cnJlbnRNYXhaSW5kZXggKyAxMDtcbiAgICB9XG4gIH1cbn1cbiJdfQ==
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
var _SkyModalScrollShadowDirective_instances, _SkyModalScrollShadowDirective_currentShadow, _SkyModalScrollShadowDirective_currentTheme, _SkyModalScrollShadowDirective_mutationObserver, _SkyModalScrollShadowDirective_ngUnsubscribe, _SkyModalScrollShadowDirective_elRef, _SkyModalScrollShadowDirective_mutationObserverSvc, _SkyModalScrollShadowDirective_ngZone, _SkyModalScrollShadowDirective_themeSvc, _SkyModalScrollShadowDirective_initMutationObserver, _SkyModalScrollShadowDirective_destroyMutationObserver, _SkyModalScrollShadowDirective_checkForShadow, _SkyModalScrollShadowDirective_buildShadowStyle, _SkyModalScrollShadowDirective_emitShadow;
|
|
2
2
|
import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
|
|
3
3
|
import { Directive, ElementRef, EventEmitter, HostListener, NgZone, Optional, Output, } from '@angular/core';
|
|
4
|
-
import {
|
|
4
|
+
import { SkyMutationObserverService } from '@skyux/core';
|
|
5
5
|
import { SkyTheme, SkyThemeService } from '@skyux/theme';
|
|
6
6
|
import { Subject } from 'rxjs';
|
|
7
7
|
import { takeUntil } from 'rxjs/operators';
|
|
@@ -107,14 +107,14 @@ _SkyModalScrollShadowDirective_currentShadow = new WeakMap(), _SkyModalScrollSha
|
|
|
107
107
|
__classPrivateFieldSet(this, _SkyModalScrollShadowDirective_currentShadow, shadow, "f");
|
|
108
108
|
}
|
|
109
109
|
};
|
|
110
|
-
SkyModalScrollShadowDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyModalScrollShadowDirective, deps: [{ token: i0.ElementRef }, { token: i1.
|
|
110
|
+
SkyModalScrollShadowDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyModalScrollShadowDirective, deps: [{ token: i0.ElementRef }, { token: i1.SkyMutationObserverService }, { token: i0.NgZone }, { token: i2.SkyThemeService, optional: true }], target: i0.ɵɵFactoryTarget.Directive });
|
|
111
111
|
SkyModalScrollShadowDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.0", type: SkyModalScrollShadowDirective, selector: "[skyModalScrollShadow]", outputs: { skyModalScrollShadow: "skyModalScrollShadow" }, host: { listeners: { "window:resize": "windowResize()", "scroll": "scroll()" } }, ngImport: i0 });
|
|
112
112
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyModalScrollShadowDirective, decorators: [{
|
|
113
113
|
type: Directive,
|
|
114
114
|
args: [{
|
|
115
115
|
selector: '[skyModalScrollShadow]',
|
|
116
116
|
}]
|
|
117
|
-
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.
|
|
117
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.SkyMutationObserverService }, { type: i0.NgZone }, { type: i2.SkyThemeService, decorators: [{
|
|
118
118
|
type: Optional
|
|
119
119
|
}] }]; }, propDecorators: { skyModalScrollShadow: [{
|
|
120
120
|
type: Output
|
|
@@ -125,4 +125,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
|
|
|
125
125
|
type: HostListener,
|
|
126
126
|
args: ['scroll']
|
|
127
127
|
}] } });
|
|
128
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal-scroll-shadow.directive.js","sourceRoot":"","sources":["../../../../../../../../libs/components/modals/src/lib/modules/modal/modal-scroll-shadow.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  NgZone,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n} from '@angular/core';\nimport { MutationObserverService } from '@skyux/core';\nimport { SkyTheme, SkyThemeService } from '@skyux/theme';\n\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyModalScrollShadowEventArgs } from './modal-scroll-shadow-event-args';\n\n/**\n * Raises an event when the box shadow for the modal header or footer should be adjusted\n * based on the scroll position of the host element.\n * @internal\n */\n@Directive({\n  selector: '[skyModalScrollShadow]',\n})\nexport class SkyModalScrollShadowDirective implements OnInit, OnDestroy {\n  @Output()\n  public skyModalScrollShadow = new EventEmitter<SkyModalScrollShadowEventArgs>();\n\n  #currentShadow: SkyModalScrollShadowEventArgs | undefined;\n\n  #currentTheme: SkyTheme | undefined;\n\n  #mutationObserver: MutationObserver | undefined;\n\n  #ngUnsubscribe = new Subject<void>();\n\n  #elRef: ElementRef;\n  #mutationObserverSvc: MutationObserverService;\n  #ngZone: NgZone;\n  #themeSvc: SkyThemeService | undefined;\n\n  constructor(\n    elRef: ElementRef,\n    mutationObserverSvc: MutationObserverService,\n    ngZone: NgZone,\n    @Optional() themeSvc?: SkyThemeService\n  ) {\n    this.#elRef = elRef;\n    this.#mutationObserverSvc = mutationObserverSvc;\n    this.#ngZone = ngZone;\n    this.#themeSvc = themeSvc;\n  }\n\n  @HostListener('window:resize')\n  public windowResize(): void {\n    this.#checkForShadow();\n  }\n\n  @HostListener('scroll')\n  public scroll(): void {\n    this.#checkForShadow();\n  }\n\n  public ngOnInit(): void {\n    if (this.#themeSvc) {\n      this.#themeSvc.settingsChange\n        .pipe(takeUntil(this.#ngUnsubscribe))\n        .subscribe((themeSettings) => {\n          this.#currentTheme = themeSettings.currentSettings.theme;\n\n          if (this.#currentTheme === SkyTheme.presets.modern) {\n            this.#initMutationObserver();\n          } else {\n            this.#emitShadow({\n              bottomShadow: 'none',\n              topShadow: 'none',\n            });\n\n            this.#destroyMutationObserver();\n          }\n        });\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n\n    this.#destroyMutationObserver();\n  }\n\n  #initMutationObserver(): void {\n    if (!this.#mutationObserver) {\n      const el = this.#elRef.nativeElement;\n\n      // MutationObserver is patched by Zone.js and therefore becomes part of the\n      // Angular change detection cycle, but this can lead to infinite loops in some\n      // secnarios. This will keep MutationObserver from triggering change detection.\n      this.#ngZone.runOutsideAngular(() => {\n        this.#mutationObserver = this.#mutationObserverSvc.create(() => {\n          this.#checkForShadow();\n        });\n\n        this.#mutationObserver.observe(el, {\n          attributes: true,\n          characterData: true,\n          childList: true,\n          subtree: true,\n        });\n      });\n    }\n  }\n\n  #destroyMutationObserver(): void {\n    if (this.#mutationObserver) {\n      this.#mutationObserver.disconnect();\n      this.#mutationObserver = undefined;\n    }\n  }\n\n  #checkForShadow(): void {\n    if (this.#currentTheme === SkyTheme.presets.modern) {\n      const el = this.#elRef.nativeElement;\n\n      const topShadow = this.#buildShadowStyle(el.scrollTop);\n\n      const bottomShadow = this.#buildShadowStyle(\n        el.scrollHeight - el.scrollTop - el.clientHeight\n      );\n\n      this.#emitShadow({\n        bottomShadow,\n        topShadow,\n      });\n    }\n  }\n\n  #buildShadowStyle(pixelsFromEnd: number): string {\n    // Progressively darken the shadow until the user scrolls 30 pixels from the top or bottom\n    // of the scrollable element, with a max opacity of 0.3.\n    const opacity = Math.min(pixelsFromEnd / 30, 1) * 0.3;\n\n    return opacity > 0 ? `0px 1px 8px 0px rgba(0, 0, 0, ${opacity})` : 'none';\n  }\n\n  #emitShadow(shadow: SkyModalScrollShadowEventArgs): void {\n    if (\n      !this.#currentShadow ||\n      this.#currentShadow.bottomShadow !== shadow.bottomShadow ||\n      this.#currentShadow.topShadow !== shadow.topShadow\n    ) {\n      this.skyModalScrollShadow.emit(shadow);\n      this.#currentShadow = shadow;\n    }\n  }\n}\n"]}
|
|
128
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal-scroll-shadow.directive.js","sourceRoot":"","sources":["../../../../../../../../libs/components/modals/src/lib/modules/modal/modal-scroll-shadow.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  NgZone,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n} from '@angular/core';\nimport { SkyMutationObserverService } from '@skyux/core';\nimport { SkyTheme, SkyThemeService } from '@skyux/theme';\n\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyModalScrollShadowEventArgs } from './modal-scroll-shadow-event-args';\n\n/**\n * Raises an event when the box shadow for the modal header or footer should be adjusted\n * based on the scroll position of the host element.\n * @internal\n */\n@Directive({\n  selector: '[skyModalScrollShadow]',\n})\nexport class SkyModalScrollShadowDirective implements OnInit, OnDestroy {\n  @Output()\n  public skyModalScrollShadow = new EventEmitter<SkyModalScrollShadowEventArgs>();\n\n  #currentShadow: SkyModalScrollShadowEventArgs | undefined;\n\n  #currentTheme: SkyTheme | undefined;\n\n  #mutationObserver: MutationObserver | undefined;\n\n  #ngUnsubscribe = new Subject<void>();\n\n  #elRef: ElementRef;\n  #mutationObserverSvc: SkyMutationObserverService;\n  #ngZone: NgZone;\n  #themeSvc: SkyThemeService | undefined;\n\n  constructor(\n    elRef: ElementRef,\n    mutationObserverSvc: SkyMutationObserverService,\n    ngZone: NgZone,\n    @Optional() themeSvc?: SkyThemeService\n  ) {\n    this.#elRef = elRef;\n    this.#mutationObserverSvc = mutationObserverSvc;\n    this.#ngZone = ngZone;\n    this.#themeSvc = themeSvc;\n  }\n\n  @HostListener('window:resize')\n  public windowResize(): void {\n    this.#checkForShadow();\n  }\n\n  @HostListener('scroll')\n  public scroll(): void {\n    this.#checkForShadow();\n  }\n\n  public ngOnInit(): void {\n    if (this.#themeSvc) {\n      this.#themeSvc.settingsChange\n        .pipe(takeUntil(this.#ngUnsubscribe))\n        .subscribe((themeSettings) => {\n          this.#currentTheme = themeSettings.currentSettings.theme;\n\n          if (this.#currentTheme === SkyTheme.presets.modern) {\n            this.#initMutationObserver();\n          } else {\n            this.#emitShadow({\n              bottomShadow: 'none',\n              topShadow: 'none',\n            });\n\n            this.#destroyMutationObserver();\n          }\n        });\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n\n    this.#destroyMutationObserver();\n  }\n\n  #initMutationObserver(): void {\n    if (!this.#mutationObserver) {\n      const el = this.#elRef.nativeElement;\n\n      // MutationObserver is patched by Zone.js and therefore becomes part of the\n      // Angular change detection cycle, but this can lead to infinite loops in some\n      // secnarios. This will keep MutationObserver from triggering change detection.\n      this.#ngZone.runOutsideAngular(() => {\n        this.#mutationObserver = this.#mutationObserverSvc.create(() => {\n          this.#checkForShadow();\n        });\n\n        this.#mutationObserver.observe(el, {\n          attributes: true,\n          characterData: true,\n          childList: true,\n          subtree: true,\n        });\n      });\n    }\n  }\n\n  #destroyMutationObserver(): void {\n    if (this.#mutationObserver) {\n      this.#mutationObserver.disconnect();\n      this.#mutationObserver = undefined;\n    }\n  }\n\n  #checkForShadow(): void {\n    if (this.#currentTheme === SkyTheme.presets.modern) {\n      const el = this.#elRef.nativeElement;\n\n      const topShadow = this.#buildShadowStyle(el.scrollTop);\n\n      const bottomShadow = this.#buildShadowStyle(\n        el.scrollHeight - el.scrollTop - el.clientHeight\n      );\n\n      this.#emitShadow({\n        bottomShadow,\n        topShadow,\n      });\n    }\n  }\n\n  #buildShadowStyle(pixelsFromEnd: number): string {\n    // Progressively darken the shadow until the user scrolls 30 pixels from the top or bottom\n    // of the scrollable element, with a max opacity of 0.3.\n    const opacity = Math.min(pixelsFromEnd / 30, 1) * 0.3;\n\n    return opacity > 0 ? `0px 1px 8px 0px rgba(0, 0, 0, ${opacity})` : 'none';\n  }\n\n  #emitShadow(shadow: SkyModalScrollShadowEventArgs): void {\n    if (\n      !this.#currentShadow ||\n      this.#currentShadow.bottomShadow !== shadow.bottomShadow ||\n      this.#currentShadow.topShadow !== shadow.topShadow\n    ) {\n      this.skyModalScrollShadow.emit(shadow);\n      this.#currentShadow = shadow;\n    }\n  }\n}\n"]}
|
|
@@ -177,4 +177,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
|
|
|
177
177
|
type: HostListener,
|
|
178
178
|
args: ['document:keydown', ['$event']]
|
|
179
179
|
}] } });
|
|
180
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/modals/src/lib/modules/modal/modal.component.ts","../../../../../../../../libs/components/modals/src/lib/modules/modal/modal.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  Host,\n  HostBinding,\n  HostListener,\n  Input,\n  OnDestroy,\n  Optional,\n  ViewChild,\n} from '@angular/core';\nimport {\n  SkyAppWindowRef,\n  SkyCoreAdapterService,\n  SkyDockLocation,\n  SkyDockService,\n  SkyResizeObserverMediaQueryService,\n} from '@skyux/core';\n\nimport { SkyModalComponentAdapterService } from './modal-component-adapter.service';\nimport { SkyModalConfiguration } from './modal-configuration';\nimport { SkyModalHostService } from './modal-host.service';\nimport { SkyModalScrollShadowEventArgs } from './modal-scroll-shadow-event-args';\n\nlet skyModalUniqueIdentifier = 0;\n\nconst ARIA_ROLE_DEFAULT = 'dialog';\n\n/**\n * Provides a common look-and-feel for modal content with options to display\n * a common modal header, specify body content, and display a common modal footer\n * and buttons.\n */\n@Component({\n  selector: 'sky-modal',\n  templateUrl: './modal.component.html',\n  styleUrls: ['./modal.component.scss'],\n  providers: [SkyModalComponentAdapterService, SkyDockService],\n})\nexport class SkyModalComponent implements AfterViewInit, OnDestroy {\n  @HostBinding('class')\n  public wrapperClass: string | undefined;\n\n  // Ignoring coverage as we only use the setter internally and do not export the class externally for users to be able to use the getter.\n  // istanbul ignore next\n  /**\n   * @internal\n   */\n  @Input()\n  public get ariaRole() {\n    return this.#_ariaRole;\n  }\n\n  public set ariaRole(value: string | undefined) {\n    this.#_ariaRole = value;\n    this.ariaRoleOrDefault = value || ARIA_ROLE_DEFAULT;\n  }\n\n  public ariaRoleOrDefault = ARIA_ROLE_DEFAULT;\n\n  /**\n   * @internal\n   */\n  @Input()\n  public tiledBody: boolean | undefined;\n\n  public ariaDescribedBy: string;\n\n  public ariaLabelledBy: string;\n\n  public helpKey: string | undefined;\n\n  public modalState = 'in';\n\n  public modalContentId: string =\n    'sky-modal-content-id-' + skyModalUniqueIdentifier.toString();\n\n  public modalHeaderId: string =\n    'sky-modal-header-id-' + skyModalUniqueIdentifier.toString();\n\n  public modalZIndex: number | undefined;\n\n  public scrollShadow: SkyModalScrollShadowEventArgs | undefined;\n\n  public size: string;\n\n  @ViewChild('modalContentWrapper', { read: ElementRef })\n  private modalContentWrapperElement: ElementRef | undefined;\n\n  #hostService: SkyModalHostService;\n  #elRef: ElementRef;\n  #windowRef: SkyAppWindowRef;\n  #componentAdapter: SkyModalComponentAdapterService;\n  #coreAdapter: SkyCoreAdapterService;\n  #dockService: SkyDockService;\n  #mediaQueryService: SkyResizeObserverMediaQueryService | undefined;\n\n  #_ariaRole: string | undefined;\n\n  constructor(\n    hostService: SkyModalHostService,\n    config: SkyModalConfiguration,\n    elRef: ElementRef,\n    windowRef: SkyAppWindowRef,\n    componentAdapter: SkyModalComponentAdapterService,\n    coreAdapter: SkyCoreAdapterService,\n    @Host() dockService: SkyDockService,\n    @Optional()\n    mediaQueryService?: SkyResizeObserverMediaQueryService\n  ) {\n    this.#hostService = hostService;\n    this.#elRef = elRef;\n    this.#windowRef = windowRef;\n    this.#componentAdapter = componentAdapter;\n    this.#coreAdapter = coreAdapter;\n    this.#dockService = dockService;\n    this.#mediaQueryService = mediaQueryService;\n\n    this.ariaDescribedBy = config.ariaDescribedBy || this.modalContentId;\n    this.ariaLabelledBy = config.ariaLabelledBy || this.modalHeaderId;\n    this.ariaRole = config.ariaRole;\n    this.helpKey = config.helpKey;\n    this.tiledBody = config.tiledBody;\n    this.wrapperClass = config.wrapperClass;\n\n    this.size = config.fullPage\n      ? 'full-page'\n      : config.size?.toLowerCase() || 'medium';\n\n    this.modalZIndex = this.#hostService.zIndex;\n  }\n\n  @HostListener('document:keyup', ['$event'])\n  public onDocumentKeyUp(event: KeyboardEvent) {\n    /* istanbul ignore else */\n    /* sanity check */\n    if (SkyModalHostService.openModalCount > 0) {\n      const topModal = SkyModalHostService.topModal;\n      if (topModal && topModal === this.#hostService) {\n        if (event.which === 27) {\n          // Escape key up\n          event.preventDefault();\n          this.closeButtonClick();\n        }\n      }\n    }\n  }\n\n  @HostListener('document:keydown', ['$event'])\n  public onDocumentKeyDown(event: KeyboardEvent) {\n    /* istanbul ignore else */\n    /* sanity check */\n    if (SkyModalHostService.openModalCount > 0) {\n      const topModal = SkyModalHostService.topModal;\n      if (topModal && topModal === this.#hostService) {\n        if (event.which === 9) {\n          // Tab pressed\n          let focusChanged = false;\n\n          const focusElementList = this.#coreAdapter.getFocusableChildren(\n            this.#elRef.nativeElement\n          );\n\n          if (\n            event.shiftKey &&\n            (this.#componentAdapter.isFocusInFirstItem(\n              event,\n              focusElementList\n            ) ||\n              this.#componentAdapter.isModalFocused(event, this.#elRef))\n          ) {\n            focusChanged =\n              this.#componentAdapter.focusLastElement(focusElementList);\n          } else if (\n            !event.shiftKey &&\n            this.#componentAdapter.isFocusInLastItem(event, focusElementList)\n          ) {\n            focusChanged =\n              this.#componentAdapter.focusFirstElement(focusElementList);\n          }\n\n          if (focusChanged) {\n            event.preventDefault();\n            event.stopPropagation();\n          }\n        }\n      }\n    }\n  }\n\n  public ngAfterViewInit() {\n    skyModalUniqueIdentifier++;\n    this.#componentAdapter.handleWindowChange(this.#elRef);\n\n    // Adding a timeout to avoid ExpressionChangedAfterItHasBeenCheckedError.\n    // https://stackoverflow.com/questions/40562845\n    this.#windowRef.nativeWindow.setTimeout(() => {\n      this.#componentAdapter.modalOpened(this.#elRef);\n    });\n\n    this.#dockService.setDockOptions({\n      location: SkyDockLocation.ElementBottom,\n      referenceEl: this.modalContentWrapperElement!.nativeElement,\n      zIndex: 5,\n    });\n\n    /* istanbul ignore next */\n    if (this.#mediaQueryService) {\n      this.#mediaQueryService.observe(this.modalContentWrapperElement!);\n    }\n  }\n\n  public ngOnDestroy(): void {\n    /* istanbul ignore next */\n    if (this.#mediaQueryService) {\n      this.#mediaQueryService.unobserve();\n    }\n  }\n\n  public helpButtonClick() {\n    if (this.helpKey) {\n      this.#hostService.onOpenHelp(this.helpKey);\n    }\n  }\n\n  public closeButtonClick() {\n    this.#hostService.onClose();\n  }\n\n  public windowResize() {\n    this.#componentAdapter.handleWindowChange(this.#elRef);\n  }\n\n  public scrollShadowChange(args: SkyModalScrollShadowEventArgs): void {\n    this.scrollShadow = args;\n  }\n\n  public viewkeeperEnabled(): boolean {\n    return this.#componentAdapter.modalContentHasDirectChildViewkeeper(\n      this.#elRef\n    );\n  }\n}\n","<div\n  class=\"sky-modal-dialog\"\n  aria-modal=\"true\"\n  [attr.aria-describedby]=\"ariaDescribedBy\"\n  [attr.aria-labelledby]=\"ariaLabelledBy\"\n  [attr.role]=\"ariaRoleOrDefault\"\n  (window:resize)=\"windowResize()\"\n>\n  <div\n    class=\"sky-modal sky-shadow sky-box sky-elevation-16 sky-modal-{{ size }}\"\n    tabindex=\"-1\"\n    [ngClass]=\"{\n      'sky-modal-tiled': tiledBody,\n      'sky-modal-viewkeeper': viewkeeperEnabled()\n    }\"\n    [ngStyle]=\"{\n      zIndex: modalZIndex\n    }\"\n  >\n    <div\n      class=\"sky-modal-header\"\n      [hidden]=\"!headerContent || !headerContent.children || headerContent.children.length &lt; 1\"\n      [ngStyle]=\"{\n        'box-shadow': scrollShadow?.topShadow\n      }\"\n    >\n      <div\n        class=\"sky-modal-header-content\"\n        [attr.id]=\"modalHeaderId\"\n        [ngClass]=\"{\n          'sky-section-heading': size === 'full-page'\n        }\"\n        #headerContent\n      >\n        <ng-content select=\"sky-modal-header\"></ng-content>\n      </div>\n      <div class=\"sky-modal-header-buttons\">\n        <button\n          *ngIf=\"helpKey\"\n          class=\"sky-btn sky-modal-btn-help\"\n          name=\"help-button\"\n          type=\"button\"\n          [attr.aria-label]=\"'skyux_modal_open_help' | skyLibResources\"\n          (click)=\"helpButtonClick()\"\n        >\n          <sky-icon icon=\"question-circle\"></sky-icon>\n        </button>\n\n        <button\n          type=\"button\"\n          class=\"sky-btn sky-modal-btn-close\"\n          [attr.aria-label]=\"'skyux_modal_close' | skyLibResources\"\n          (click)=\"closeButtonClick()\"\n        >\n          <sky-icon icon=\"close\"></sky-icon>\n        </button>\n      </div>\n    </div>\n    <div\n      class=\"sky-modal-content sky-padding-even-large\"\n      role=\"region\"\n      tabindex=\"0\"\n      [attr.aria-labelledby]=\"modalHeaderId\"\n      [attr.id]=\"modalContentId\"\n      (skyModalScrollShadow)=\"scrollShadowChange($event)\"\n      #modalContentWrapper\n    >\n      <ng-content select=\"sky-modal-content\"></ng-content>\n    </div>\n    <div\n      class=\"sky-modal-footer\"\n      [ngStyle]=\"{\n        'box-shadow': scrollShadow?.bottomShadow\n      }\"\n    >\n      <ng-content select=\"sky-modal-footer\"></ng-content>\n    </div>\n  </div>\n</div>\n"]}
|
|
180
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/modals/src/lib/modules/modal/modal.component.ts","../../../../../../../../libs/components/modals/src/lib/modules/modal/modal.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  Host,\n  HostBinding,\n  HostListener,\n  Input,\n  OnDestroy,\n  Optional,\n  ViewChild,\n} from '@angular/core';\nimport {\n  SkyAppWindowRef,\n  SkyCoreAdapterService,\n  SkyDockLocation,\n  SkyDockService,\n  SkyResizeObserverMediaQueryService,\n} from '@skyux/core';\n\nimport { SkyModalComponentAdapterService } from './modal-component-adapter.service';\nimport { SkyModalConfiguration } from './modal-configuration';\nimport { SkyModalHostService } from './modal-host.service';\nimport { SkyModalScrollShadowEventArgs } from './modal-scroll-shadow-event-args';\n\nlet skyModalUniqueIdentifier = 0;\n\nconst ARIA_ROLE_DEFAULT = 'dialog';\n\n/**\n * Provides a common look-and-feel for modal content with options to display\n * a common modal header, specify body content, and display a common modal footer\n * and buttons.\n */\n@Component({\n  selector: 'sky-modal',\n  templateUrl: './modal.component.html',\n  styleUrls: ['./modal.component.scss'],\n  providers: [SkyModalComponentAdapterService, SkyDockService],\n})\nexport class SkyModalComponent implements AfterViewInit, OnDestroy {\n  @HostBinding('class')\n  public wrapperClass: string | undefined;\n\n  // Ignoring coverage as we only use the setter internally and do not export the class externally for users to be able to use the getter.\n  // istanbul ignore next\n  /**\n   * @internal\n   */\n  @Input()\n  public get ariaRole() {\n    return this.#_ariaRole;\n  }\n\n  public set ariaRole(value: string | undefined) {\n    this.#_ariaRole = value;\n    this.ariaRoleOrDefault = value || ARIA_ROLE_DEFAULT;\n  }\n\n  public ariaRoleOrDefault = ARIA_ROLE_DEFAULT;\n\n  /**\n   * @internal\n   */\n  @Input()\n  public tiledBody: boolean | undefined;\n\n  public ariaDescribedBy: string;\n\n  public ariaLabelledBy: string;\n\n  public helpKey: string | undefined;\n\n  public modalState = 'in';\n\n  public modalContentId: string =\n    'sky-modal-content-id-' + skyModalUniqueIdentifier.toString();\n\n  public modalHeaderId: string =\n    'sky-modal-header-id-' + skyModalUniqueIdentifier.toString();\n\n  public modalZIndex: number | undefined;\n\n  public scrollShadow: SkyModalScrollShadowEventArgs | undefined;\n\n  public size: string;\n\n  @ViewChild('modalContentWrapper', { read: ElementRef })\n  public modalContentWrapperElement: ElementRef | undefined;\n\n  #hostService: SkyModalHostService;\n  #elRef: ElementRef;\n  #windowRef: SkyAppWindowRef;\n  #componentAdapter: SkyModalComponentAdapterService;\n  #coreAdapter: SkyCoreAdapterService;\n  #dockService: SkyDockService;\n  #mediaQueryService: SkyResizeObserverMediaQueryService | undefined;\n\n  #_ariaRole: string | undefined;\n\n  constructor(\n    hostService: SkyModalHostService,\n    config: SkyModalConfiguration,\n    elRef: ElementRef,\n    windowRef: SkyAppWindowRef,\n    componentAdapter: SkyModalComponentAdapterService,\n    coreAdapter: SkyCoreAdapterService,\n    @Host() dockService: SkyDockService,\n    @Optional()\n    mediaQueryService?: SkyResizeObserverMediaQueryService\n  ) {\n    this.#hostService = hostService;\n    this.#elRef = elRef;\n    this.#windowRef = windowRef;\n    this.#componentAdapter = componentAdapter;\n    this.#coreAdapter = coreAdapter;\n    this.#dockService = dockService;\n    this.#mediaQueryService = mediaQueryService;\n\n    this.ariaDescribedBy = config.ariaDescribedBy || this.modalContentId;\n    this.ariaLabelledBy = config.ariaLabelledBy || this.modalHeaderId;\n    this.ariaRole = config.ariaRole;\n    this.helpKey = config.helpKey;\n    this.tiledBody = config.tiledBody;\n    this.wrapperClass = config.wrapperClass;\n\n    this.size = config.fullPage\n      ? 'full-page'\n      : config.size?.toLowerCase() || 'medium';\n\n    this.modalZIndex = this.#hostService.zIndex;\n  }\n\n  @HostListener('document:keyup', ['$event'])\n  public onDocumentKeyUp(event: KeyboardEvent) {\n    /* istanbul ignore else */\n    /* sanity check */\n    if (SkyModalHostService.openModalCount > 0) {\n      const topModal = SkyModalHostService.topModal;\n      if (topModal && topModal === this.#hostService) {\n        if (event.which === 27) {\n          // Escape key up\n          event.preventDefault();\n          this.closeButtonClick();\n        }\n      }\n    }\n  }\n\n  @HostListener('document:keydown', ['$event'])\n  public onDocumentKeyDown(event: KeyboardEvent) {\n    /* istanbul ignore else */\n    /* sanity check */\n    if (SkyModalHostService.openModalCount > 0) {\n      const topModal = SkyModalHostService.topModal;\n      if (topModal && topModal === this.#hostService) {\n        if (event.which === 9) {\n          // Tab pressed\n          let focusChanged = false;\n\n          const focusElementList = this.#coreAdapter.getFocusableChildren(\n            this.#elRef.nativeElement\n          );\n\n          if (\n            event.shiftKey &&\n            (this.#componentAdapter.isFocusInFirstItem(\n              event,\n              focusElementList\n            ) ||\n              this.#componentAdapter.isModalFocused(event, this.#elRef))\n          ) {\n            focusChanged =\n              this.#componentAdapter.focusLastElement(focusElementList);\n          } else if (\n            !event.shiftKey &&\n            this.#componentAdapter.isFocusInLastItem(event, focusElementList)\n          ) {\n            focusChanged =\n              this.#componentAdapter.focusFirstElement(focusElementList);\n          }\n\n          if (focusChanged) {\n            event.preventDefault();\n            event.stopPropagation();\n          }\n        }\n      }\n    }\n  }\n\n  public ngAfterViewInit() {\n    skyModalUniqueIdentifier++;\n    this.#componentAdapter.handleWindowChange(this.#elRef);\n\n    // Adding a timeout to avoid ExpressionChangedAfterItHasBeenCheckedError.\n    // https://stackoverflow.com/questions/40562845\n    this.#windowRef.nativeWindow.setTimeout(() => {\n      this.#componentAdapter.modalOpened(this.#elRef);\n    });\n\n    this.#dockService.setDockOptions({\n      location: SkyDockLocation.ElementBottom,\n      referenceEl: this.modalContentWrapperElement!.nativeElement,\n      zIndex: 5,\n    });\n\n    /* istanbul ignore next */\n    if (this.#mediaQueryService) {\n      this.#mediaQueryService.observe(this.modalContentWrapperElement!);\n    }\n  }\n\n  public ngOnDestroy(): void {\n    /* istanbul ignore next */\n    if (this.#mediaQueryService) {\n      this.#mediaQueryService.unobserve();\n    }\n  }\n\n  public helpButtonClick() {\n    if (this.helpKey) {\n      this.#hostService.onOpenHelp(this.helpKey);\n    }\n  }\n\n  public closeButtonClick() {\n    this.#hostService.onClose();\n  }\n\n  public windowResize() {\n    this.#componentAdapter.handleWindowChange(this.#elRef);\n  }\n\n  public scrollShadowChange(args: SkyModalScrollShadowEventArgs): void {\n    this.scrollShadow = args;\n  }\n\n  public viewkeeperEnabled(): boolean {\n    return this.#componentAdapter.modalContentHasDirectChildViewkeeper(\n      this.#elRef\n    );\n  }\n}\n","<div\n  class=\"sky-modal-dialog\"\n  aria-modal=\"true\"\n  [attr.aria-describedby]=\"ariaDescribedBy\"\n  [attr.aria-labelledby]=\"ariaLabelledBy\"\n  [attr.role]=\"ariaRoleOrDefault\"\n  (window:resize)=\"windowResize()\"\n>\n  <div\n    class=\"sky-modal sky-shadow sky-box sky-elevation-16 sky-modal-{{ size }}\"\n    tabindex=\"-1\"\n    [ngClass]=\"{\n      'sky-modal-tiled': tiledBody,\n      'sky-modal-viewkeeper': viewkeeperEnabled()\n    }\"\n    [ngStyle]=\"{\n      zIndex: modalZIndex\n    }\"\n  >\n    <div\n      class=\"sky-modal-header\"\n      [hidden]=\"!headerContent || !headerContent.children || headerContent.children.length &lt; 1\"\n      [ngStyle]=\"{\n        'box-shadow': scrollShadow?.topShadow\n      }\"\n    >\n      <div\n        class=\"sky-modal-header-content\"\n        [attr.id]=\"modalHeaderId\"\n        [ngClass]=\"{\n          'sky-section-heading': size === 'full-page'\n        }\"\n        #headerContent\n      >\n        <ng-content select=\"sky-modal-header\"></ng-content>\n      </div>\n      <div class=\"sky-modal-header-buttons\">\n        <button\n          *ngIf=\"helpKey\"\n          class=\"sky-btn sky-modal-btn-help\"\n          name=\"help-button\"\n          type=\"button\"\n          [attr.aria-label]=\"'skyux_modal_open_help' | skyLibResources\"\n          (click)=\"helpButtonClick()\"\n        >\n          <sky-icon icon=\"question-circle\"></sky-icon>\n        </button>\n\n        <button\n          type=\"button\"\n          class=\"sky-btn sky-modal-btn-close\"\n          [attr.aria-label]=\"'skyux_modal_close' | skyLibResources\"\n          (click)=\"closeButtonClick()\"\n        >\n          <sky-icon icon=\"close\"></sky-icon>\n        </button>\n      </div>\n    </div>\n    <div\n      class=\"sky-modal-content sky-padding-even-large\"\n      role=\"region\"\n      tabindex=\"0\"\n      [attr.aria-labelledby]=\"modalHeaderId\"\n      [attr.id]=\"modalContentId\"\n      (skyModalScrollShadow)=\"scrollShadowChange($event)\"\n      #modalContentWrapper\n    >\n      <ng-content select=\"sky-modal-content\"></ng-content>\n    </div>\n    <div\n      class=\"sky-modal-footer\"\n      [ngStyle]=\"{\n        'box-shadow': scrollShadow?.bottomShadow\n      }\"\n    >\n      <ng-content select=\"sky-modal-footer\"></ng-content>\n    </div>\n  </div>\n</div>\n"]}
|
|
@@ -1,4 +1,2 @@
|
|
|
1
|
-
// TODO: defaults won't show in the generated docs until this work is done:
|
|
2
|
-
// https://github.com/blackbaud/skyux-docs-tools/issues/38
|
|
3
1
|
export {};
|
|
4
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kYWwuaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL21vZGFscy9zcmMvbGliL21vZHVsZXMvbW9kYWwvbW9kYWwuaW50ZXJmYWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTdGF0aWNQcm92aWRlciB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG4vLyBUT0RPOiBkZWZhdWx0cyB3b24ndCBzaG93IGluIHRoZSBnZW5lcmF0ZWQgZG9jcyB1bnRpbCB0aGlzIHdvcmsgaXMgZG9uZTpcbi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9ibGFja2JhdWQvc2t5dXgtZG9jcy10b29scy9pc3N1ZXMvMzhcblxuLyoqXG4gKiBTcGVjaWZpZXMgY29uZmlndXJhdGlvbiBvcHRpb25zIGZvciBjcmVhdGluZyBhIG1vZGFsLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFNreU1vZGFsQ29uZmlndXJhdGlvbkludGVyZmFjZSB7XG4gIC8qKlxuICAgKiBJbmRpY2F0ZXMgd2hldGhlciB0byBkaXNwbGF5IHRoZSBtb2RhbCBmdWxsIHNjcmVlbi5cbiAgICogVGhpcyBwcm9wZXJ0eSBkZWZhdWx0cyB0byBgZmFsc2VgLlxuICAgKi9cbiAgZnVsbFBhZ2U/OiBib29sZWFuO1xuXG4gIC8qKlxuICAgKiBTcGVjaWZpZXMgYSBzaXplIGZvciB0aGUgbW9kYWwuIFRoZSB2YWxpZCBvcHRpb25zIGFyZSBgc21hbGxgLCBgbWVkaXVtYCwgYW5kIGBsYXJnZWAuXG4gICAqIFRoaXMgcHJvcGVydHkgZGVmYXVsdHMgdG8gYG1lZGl1bWAuXG4gICAqL1xuICBzaXplPzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBBbiBhcnJheSBwcm9wZXJ0eSBvZiBgcHJvdmlkZXJzYC5cbiAgICogSW4gQW5ndWxhciwgYSBwcm92aWRlciBpcyBzb21ldGhpbmcgdGhhdCBjYW4gY3JlYXRlIG9yIGRlbGl2ZXIgYSBzZXJ2aWNlLlxuICAgKiBUaGlzIHByb3BlcnR5IGNhbiBiZSB1c2VkIHRvIHBhc3MgY29udGV4dCB2YWx1ZXMgZnJvbSB0aGUgY29tcG9uZW50IHRoYXQgbGF1bmNoZXMgdGhlIG1vZGFsIHRvIHRoZSBtb2RhbCBjb21wb25lbnQuXG4gICAqL1xuICBwcm92aWRlcnM/OiBTdGF0aWNQcm92aWRlcltdO1xuXG4gIC8qKlxuICAgKiBTcGVjaWZpZXMgdGhlIEhUTUwgZWxlbWVudCBJRCAod2l0aG91dCB0aGUgbGVhZGluZyBgI2ApIG9mIHRoZSBlbGVtZW50IHRoYXQgZGVzY3JpYmVzXG4gICAqIHRoZSBtb2RhbC4gVGhpcyBzZXRzIHRoZSBtb2RhbCdzIGBhcmlhLWRlc2NyaWJlZGJ5YCBhdHRyaWJ1dGVcbiAgICogW3RvIHN1cHBvcnQgYWNjZXNzaWJpbGl0eV0oaHR0cHM6Ly9kZXZlbG9wZXIuYmxhY2tiYXVkLmNvbS9za3l1eC9sZWFybi9hY2Nlc3NpYmlsaXR5KS5cbiAgICogVGhlIGRlc2NyaXB0aW9uIHR5cGljYWxseSBpbmNsdWRlcyB0ZXh0IG9uIHRoZSBtb2RhbCBidXQgbm90IG9uIGl0ZW1zIHRoYXQgdXNlcnMgaW50ZXJhY3RcbiAgICogd2l0aCwgc3VjaCBhcyBidXR0b25zIGFuZCBmb3Jtcy4gSWYgeW91IGRvIG5vdCBzcGVjaWZ5IGFuIElELCB0aGUgZGVmYXVsdCBkZXNjcmlwdGlvbiBpc1xuICAgKiB0aGUgY29udGVudCBvZiB0aGUgYHNreS1tb2RhbC1jb250ZW50YCBjb21wb25lbnQuXG4gICAqL1xuICBhcmlhRGVzY3JpYmVkQnk/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFNwZWNpZmllcyB0aGUgSFRNTCBlbGVtZW50IElEICh3aXRob3V0IHRoZSBsZWFkaW5nIGAjYCkgb2YgdGhlIGVsZW1lbnQgdGhhdCBsYWJlbHNcbiAgICogdGhlIG1vZGFsLiBUaGlzIHNldHMgdGhlIGBhcmlhLWxhYmVsbGVkYnlgIGF0dHJpYnV0ZSBmb3IgdGhlIG1vZGFsXG4gICAqIFt0byBzdXBwb3J0IGFjY2Vzc2liaWxpdHldKGh0dHBzOi8vZGV2ZWxvcGVyLmJsYWNrYmF1ZC5jb20vc2t5dXgvbGVhcm4vYWNjZXNzaWJpbGl0eSkuXG4gICAqIFRoaXMgaXMgdHlwaWNhbGx5IGEgaGVhZGVyIGVsZW1lbnQsIGFuZCBpZiB5b3UgZG8gbm90IHNwZWNpZnkgYW4gSUQsIHRoZSBkZWZhdWx0IHZhbHVlXG4gICAqIGlzIHRoZSBjb250ZW50IG9mIHRoZSBgc2t5LW1vZGFsLWhlYWRlcmAgY29tcG9uZW50LlxuICAgKi9cbiAgYXJpYUxhYmVsbGVkQnk/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFNwZWNpZmllcyBhbiBBUklBIHJvbGUgZm9yIHRoZSBtb2RhbFxuICAgKiBbdG8gc3VwcG9ydCBhY2Nlc3NpYmlsaXR5XShodHRwczovL2RldmVsb3Blci5ibGFja2JhdWQuY29tL3NreXV4L2xlYXJuL2FjY2Vzc2liaWxpdHkpXG4gICAqIGJ5IGluZGljYXRpbmcgaG93IHRoZSBtb2RhbCBmdW5jdGlvbnMgYW5kIHdoYXQgaXQgY29udHJvbHMuIEZvciBpbmZvcm1hdGlvbiBhYm91dFxuICAgKiBob3cgYW4gQVJJQSByb2xlIGluZGljYXRlcyB3aGF0IGFuIGl0ZW0gcmVwcmVzZW50cyBvbiBhIHdlYiBwYWdlLCBzZWUgdGhlXG4gICAqIFtXQUktQVJJQSByb2xlcyBtb2RlbF0oaHR0cDovL3d3dy53My5vcmcvV0FJL1BGL2FyaWEvcm9sZXMpLiBCeSBkZWZhdWx0LCBtb2RhbHMgc2V0XG4gICAqIHRoZSBBUklBIHJvbGUgdG8gYGRpYWxvZ2AuXG4gICAqIEBkZWZhdWx0IFwiZGlhbG9nXCJcbiAgICovXG4gIGFyaWFSb2xlPzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBJbmRpY2F0ZXMgd2hldGhlciB0aGUgbW9kYWwgdXNlcyB0aWxlcy4gV2hlbiBzZXQgdG8gYHRydWVgLCB0aGUgbW9kYWwncyBiYWNrZ3JvdW5kIHN3aXRjaGVzXG4gICAqIHRvIGAkc2t5LWJhY2tncm91bmQtY29sb3ItbmV1dHJhbC1saWdodGAgYW5kIHRpbGUgaGVhZGluZ3MgYXJlIHN0eWxlZCBhcyBzdWJzZWN0aW9uIGhlYWRpbmdzLlxuICAgKiBUaGlzIHByb3BlcnR5IGRlZmF1bHRzIHRvIGBmYWxzZWAuXG4gICAqL1xuICB0aWxlZEJvZHk/OiBib29sZWFuO1xuXG4gIC8qKlxuICAgKiBAZGVwcmVjYXRlZCBUbyBkaXNwbGF5IGEgaGVscCBidXR0b24gaW4gdGhlIG1vZGFsIGhlYWRlciwgaW5jbHVkZSBhIGhlbHAgYnV0dG9uIGVsZW1lbnQsIHN1Y2ggYXMgYHNreS1oZWxwLWlubGluZWAsIGluIHRoZSBgc2t5LW1vZGFsLWhlYWRlcmAgZWxlbWVudCBhbmQgYSBgc2t5LWNvbnRyb2wtaGVscGAgQ1NTIGNsYXNzIG9uIHRoYXQgaGVscCBidXR0b24gZWxlbWVudFxuICAgKiBTcGVjaWZpZXMgYSBgaGVscEtleWAgc3RyaW5nLiBUaGlzIHByb3BlcnR5IGRpc3BsYXlzXG4gICAqIHRoZSA8aSBjbGFzcz1cImZhIGZhLXF1ZXN0aW9uLWNpcmNsZVwiIGFyaWEtaGlkZGVuPVwidHJ1ZVwiPjwvaT4gYnV0dG9uIGluIHRoZSBtb2RhbCBoZWFkZXIuXG4gICAqIFdoZW4gdXNlcnMgY2xpY2sgdGhpcyBidXR0b24sIHRoZSBgaGVscE9wZW5lZGAgZXZlbnQgYnJvYWRjYXN0cyB0aGUgYGhlbHBLZXlgIHBhcmFtZXRlci5cbiAgICogQmxhY2tiYXVkIGRldmVsb3BlcnMgY2FuIHVzZSB0aGUgSGVscCBXaWRnZXQsIHdoaWNoIGlzIGZvciBpbnRlcm5hbCBCbGFja2JhdWQgdXNlIG9ubHksIHRvXG4gICAqIFtkaXNwbGF5IGhlbHAgY29udGVudCBpbiBhIGZseW91dCBwYW5lbF0oaHR0cHM6Ly9kb2NzLmJsYWNrYmF1ZC5jb20vYmItaGVscC1kb2NzL2NvbXBvbmVudHMvbW9kYWwtaGVhZGVyKS5cbiAgICovXG4gIGhlbHBLZXk/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFNwZWNpZmllcyBhIENTUyBjbGFzcyB0byBhZGQgdG8gdGhlIG1vZGFsLCBzdWNoIGFzIGBhZy1jdXN0b20tY29tcG9uZW50LXBvcHVwYCBmb3JcbiAgICogdXNpbmcgYSBtb2RhbCBhcyBwYXJ0IG9mIGEgY2VsbCBlZGl0b3IgaW4gRGF0YSBFbnRyeSBHcmlkLlxuICAgKi9cbiAgd3JhcHBlckNsYXNzPzogc3RyaW5nO1xufVxuIl19
|