@skyux/modals 6.13.0 → 6.16.0

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.
Files changed (44) hide show
  1. package/documentation.json +340 -529
  2. package/esm2020/lib/modules/confirm/confirm-config-token.mjs +6 -0
  3. package/esm2020/lib/modules/confirm/confirm.component.mjs +103 -97
  4. package/esm2020/lib/modules/confirm/confirm.service.mjs +9 -5
  5. package/esm2020/lib/modules/modal/modal-adapter.service.mjs +20 -15
  6. package/esm2020/lib/modules/modal/modal-close-args.mjs +1 -1
  7. package/esm2020/lib/modules/modal/modal-component-adapter.service.mjs +17 -13
  8. package/esm2020/lib/modules/modal/modal-host-context-args.mjs +2 -0
  9. package/esm2020/lib/modules/modal/modal-host-context.mjs +9 -6
  10. package/esm2020/lib/modules/modal/modal-host.component.mjs +41 -14
  11. package/esm2020/lib/modules/modal/modal-host.service.mjs +21 -15
  12. package/esm2020/lib/modules/modal/modal-instance.mjs +31 -29
  13. package/esm2020/lib/modules/modal/modal-scroll-shadow.directive.mjs +71 -65
  14. package/esm2020/lib/modules/modal/modal.component.mjs +59 -74
  15. package/esm2020/lib/modules/modal/modal.service.mjs +50 -42
  16. package/esm2020/testing/modal-fixture.mjs +60 -84
  17. package/fesm2015/skyux-modals-testing.mjs +60 -83
  18. package/fesm2015/skyux-modals-testing.mjs.map +1 -1
  19. package/fesm2015/skyux-modals.mjs +412 -368
  20. package/fesm2015/skyux-modals.mjs.map +1 -1
  21. package/fesm2020/skyux-modals-testing.mjs +60 -83
  22. package/fesm2020/skyux-modals-testing.mjs.map +1 -1
  23. package/fesm2020/skyux-modals.mjs +409 -368
  24. package/fesm2020/skyux-modals.mjs.map +1 -1
  25. package/lib/modules/confirm/confirm-config-token.d.ts +6 -0
  26. package/lib/modules/confirm/confirm.component.d.ts +6 -12
  27. package/lib/modules/confirm/confirm.service.d.ts +1 -1
  28. package/lib/modules/modal/modal-adapter.service.d.ts +1 -5
  29. package/lib/modules/modal/modal-close-args.d.ts +1 -1
  30. package/lib/modules/modal/modal-component-adapter.service.d.ts +1 -2
  31. package/lib/modules/modal/modal-host-context-args.d.ts +7 -0
  32. package/lib/modules/modal/modal-host-context.d.ts +3 -2
  33. package/lib/modules/modal/modal-host.component.d.ts +1 -6
  34. package/lib/modules/modal/modal-host.service.d.ts +2 -2
  35. package/lib/modules/modal/modal-instance.d.ts +1 -5
  36. package/lib/modules/modal/modal-scroll-shadow.directive.d.ts +1 -13
  37. package/lib/modules/modal/modal.component.d.ts +12 -23
  38. package/lib/modules/modal/modal.service.d.ts +1 -3
  39. package/package.json +5 -6
  40. package/testing/modal-fixture.d.ts +6 -8
  41. package/esm2020/lib/modules/confirm/confirm-modal-context.mjs +0 -6
  42. package/esm2020/lib/modules/modal/modal-state-animation.mjs +0 -8
  43. package/lib/modules/confirm/confirm-modal-context.d.ts +0 -13
  44. package/lib/modules/modal/modal-state-animation.d.ts +0 -1
@@ -0,0 +1,6 @@
1
+ import { InjectionToken } from '@angular/core';
2
+ /**
3
+ * @internal
4
+ */
5
+ export const SKY_CONFIRM_CONFIG = new InjectionToken('SkyConfirmConfig');
6
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlybS1jb25maWctdG9rZW4uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvbW9kYWxzL3NyYy9saWIvbW9kdWxlcy9jb25maXJtL2NvbmZpcm0tY29uZmlnLXRva2VuLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFJL0M7O0dBRUc7QUFDSCxNQUFNLENBQUMsTUFBTSxrQkFBa0IsR0FBRyxJQUFJLGNBQWMsQ0FDbEQsa0JBQWtCLENBQ25CLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3Rpb25Ub2tlbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBTa3lDb25maXJtQ29uZmlnIH0gZnJvbSAnLi9jb25maXJtLWNvbmZpZyc7XG5cbi8qKlxuICogQGludGVybmFsXG4gKi9cbmV4cG9ydCBjb25zdCBTS1lfQ09ORklSTV9DT05GSUcgPSBuZXcgSW5qZWN0aW9uVG9rZW48U2t5Q29uZmlybUNvbmZpZz4oXG4gICdTa3lDb25maXJtQ29uZmlnJ1xuKTtcbiJdfQ==
@@ -1,123 +1,129 @@
1
- import { Component, Optional } from '@angular/core';
1
+ var _SkyConfirmComponent_instances, _SkyConfirmComponent_config, _SkyConfirmComponent_modal, _SkyConfirmComponent_resourcesService, _SkyConfirmComponent_getPresetButtons, _SkyConfirmComponent_getCustomButtons;
2
+ import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
3
+ import { Component, Inject, Optional } from '@angular/core';
2
4
  import { SkyLibResourcesService } from '@skyux/i18n';
3
5
  import { BehaviorSubject, zip as observableZip } from 'rxjs';
4
6
  import { SkyModalInstance } from '../modal/modal-instance';
5
- import { SkyConfirmModalContext } from './confirm-modal-context';
7
+ import { SKY_CONFIRM_CONFIG } from './confirm-config-token';
6
8
  import { SkyConfirmType } from './confirm-type';
7
9
  import * as i0 from "@angular/core";
8
- import * as i1 from "./confirm-modal-context";
9
- import * as i2 from "../modal/modal-instance";
10
- import * as i3 from "@skyux/i18n";
11
- import * as i4 from "../modal/modal.component";
12
- import * as i5 from "../modal/modal-content.component";
13
- import * as i6 from "@angular/common";
14
- import * as i7 from "@skyux/theme";
10
+ import * as i1 from "../modal/modal-instance";
11
+ import * as i2 from "@skyux/i18n";
12
+ import * as i3 from "../modal/modal.component";
13
+ import * as i4 from "../modal/modal-content.component";
14
+ import * as i5 from "@angular/common";
15
+ import * as i6 from "@skyux/theme";
15
16
  export class SkyConfirmComponent {
16
17
  constructor(config, modal, resourcesService) {
17
- this.config = config;
18
- this.modal = modal;
19
- this.resourcesService = resourcesService;
18
+ _SkyConfirmComponent_instances.add(this);
20
19
  this.preserveWhiteSpace = false;
21
- }
22
- ngOnInit() {
23
- if (this.config.type === SkyConfirmType.Custom &&
24
- this.config.buttons.length > 0) {
25
- this.buttons = this.getCustomButtons(this.config.buttons);
20
+ _SkyConfirmComponent_config.set(this, void 0);
21
+ _SkyConfirmComponent_modal.set(this, void 0);
22
+ _SkyConfirmComponent_resourcesService.set(this, void 0);
23
+ __classPrivateFieldSet(this, _SkyConfirmComponent_config, config, "f");
24
+ __classPrivateFieldSet(this, _SkyConfirmComponent_modal, modal, "f");
25
+ __classPrivateFieldSet(this, _SkyConfirmComponent_resourcesService, resourcesService, "f");
26
+ if (config.type === SkyConfirmType.Custom &&
27
+ config.buttons &&
28
+ config.buttons.length > 0) {
29
+ this.buttons = __classPrivateFieldGet(this, _SkyConfirmComponent_instances, "m", _SkyConfirmComponent_getCustomButtons).call(this, config.buttons);
26
30
  }
27
31
  else {
28
- this.getPresetButtons().subscribe((buttons) => {
32
+ __classPrivateFieldGet(this, _SkyConfirmComponent_instances, "m", _SkyConfirmComponent_getPresetButtons).call(this).subscribe((buttons) => {
29
33
  this.buttons = buttons;
30
34
  });
31
35
  }
32
- this.message = this.config.message;
33
- this.body = this.config.body;
34
- this.preserveWhiteSpace = this.config.preserveWhiteSpace || false;
36
+ this.message = config.message;
37
+ this.body = config.body;
38
+ this.preserveWhiteSpace = !!config.preserveWhiteSpace;
35
39
  }
36
40
  close(button) {
37
41
  const result = {
38
42
  action: button.action,
39
43
  };
40
- this.modal.close(result);
41
- }
42
- getPresetButtons() {
43
- const emitter = new BehaviorSubject([]);
44
- switch (this.config.type) {
45
- default:
46
- case SkyConfirmType.OK:
47
- this.resourcesService
48
- .getString('skyux_confirm_dialog_default_ok_text')
49
- .subscribe((value) => {
50
- emitter.next([
51
- {
52
- text: value,
53
- autofocus: true,
54
- styleType: 'primary',
55
- action: 'ok',
56
- },
57
- ]);
58
- });
59
- break;
60
- case SkyConfirmType.YesNoCancel:
61
- observableZip(this.resourcesService.getString('skyux_confirm_dialog_default_yes_text'), this.resourcesService.getString('skyux_confirm_dialog_default_no_text'), this.resourcesService.getString('skyux_confirm_dialog_default_cancel_text')).subscribe((values) => {
62
- emitter.next([
63
- {
64
- text: values[0],
65
- autofocus: true,
66
- styleType: 'primary',
67
- action: 'yes',
68
- },
69
- {
70
- text: values[1],
71
- styleType: 'default',
72
- action: 'no',
73
- },
74
- {
75
- text: values[2],
76
- styleType: 'link',
77
- action: 'cancel',
78
- },
79
- ]);
80
- });
81
- break;
82
- case SkyConfirmType.YesCancel:
83
- observableZip(this.resourcesService.getString('skyux_confirm_dialog_default_yes_text'), this.resourcesService.getString('skyux_confirm_dialog_default_cancel_text')).subscribe((values) => {
84
- emitter.next([
85
- {
86
- text: values[0],
87
- autofocus: true,
88
- styleType: 'primary',
89
- action: 'yes',
90
- },
91
- {
92
- text: values[1],
93
- styleType: 'link',
94
- action: 'cancel',
95
- },
96
- ]);
97
- });
98
- break;
99
- }
100
- return emitter;
44
+ __classPrivateFieldGet(this, _SkyConfirmComponent_modal, "f").close(result);
101
45
  }
102
- getCustomButtons(buttonConfig) {
103
- const buttons = [];
104
- buttonConfig.forEach((config) => {
105
- buttons.push({
106
- text: config.text,
107
- action: config.action,
108
- styleType: config.styleType || 'default',
109
- autofocus: config.autofocus || false,
46
+ }
47
+ _SkyConfirmComponent_config = new WeakMap(), _SkyConfirmComponent_modal = new WeakMap(), _SkyConfirmComponent_resourcesService = new WeakMap(), _SkyConfirmComponent_instances = new WeakSet(), _SkyConfirmComponent_getPresetButtons = function _SkyConfirmComponent_getPresetButtons() {
48
+ const emitter = new BehaviorSubject([]);
49
+ switch (__classPrivateFieldGet(this, _SkyConfirmComponent_config, "f").type) {
50
+ default:
51
+ case SkyConfirmType.OK:
52
+ __classPrivateFieldGet(this, _SkyConfirmComponent_resourcesService, "f")
53
+ .getString('skyux_confirm_dialog_default_ok_text')
54
+ .subscribe((value) => {
55
+ emitter.next([
56
+ {
57
+ text: value,
58
+ autofocus: true,
59
+ styleType: 'primary',
60
+ action: 'ok',
61
+ },
62
+ ]);
110
63
  });
111
- });
112
- return buttons;
64
+ break;
65
+ case SkyConfirmType.YesNoCancel:
66
+ observableZip(__classPrivateFieldGet(this, _SkyConfirmComponent_resourcesService, "f").getString('skyux_confirm_dialog_default_yes_text'), __classPrivateFieldGet(this, _SkyConfirmComponent_resourcesService, "f").getString('skyux_confirm_dialog_default_no_text'), __classPrivateFieldGet(this, _SkyConfirmComponent_resourcesService, "f").getString('skyux_confirm_dialog_default_cancel_text')).subscribe((values) => {
67
+ emitter.next([
68
+ {
69
+ text: values[0],
70
+ autofocus: true,
71
+ styleType: 'primary',
72
+ action: 'yes',
73
+ },
74
+ {
75
+ text: values[1],
76
+ styleType: 'default',
77
+ action: 'no',
78
+ },
79
+ {
80
+ text: values[2],
81
+ styleType: 'link',
82
+ action: 'cancel',
83
+ },
84
+ ]);
85
+ });
86
+ break;
87
+ case SkyConfirmType.YesCancel:
88
+ observableZip(__classPrivateFieldGet(this, _SkyConfirmComponent_resourcesService, "f").getString('skyux_confirm_dialog_default_yes_text'), __classPrivateFieldGet(this, _SkyConfirmComponent_resourcesService, "f").getString('skyux_confirm_dialog_default_cancel_text')).subscribe((values) => {
89
+ emitter.next([
90
+ {
91
+ text: values[0],
92
+ autofocus: true,
93
+ styleType: 'primary',
94
+ action: 'yes',
95
+ },
96
+ {
97
+ text: values[1],
98
+ styleType: 'link',
99
+ action: 'cancel',
100
+ },
101
+ ]);
102
+ });
103
+ break;
113
104
  }
114
- }
115
- SkyConfirmComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyConfirmComponent, deps: [{ token: i1.SkyConfirmModalContext }, { token: i2.SkyModalInstance }, { token: i3.SkyLibResourcesService, optional: true }], target: i0.ɵɵFactoryTarget.Component });
116
- SkyConfirmComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.2", type: SkyConfirmComponent, selector: "sky-confirm", ngImport: i0, template: "<div class=\"sky-confirm\">\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", styles: [".sky-confirm-message{margin-top:5px}.sky-confirm-body{margin-top:10px}.sky-confirm-buttons{margin-top:20px}.sky-confirm-preserve-white-space{white-space:pre-wrap}:host-context(.sky-theme-modern) .sky-confirm-content{padding:20px 30px}:host-context(.sky-theme-modern) .sky-confirm-message{padding-bottom:20px}:host-context(.sky-theme-modern) .sky-confirm-body{margin:0}.sky-theme-modern .sky-confirm-content{padding:20px 30px}.sky-theme-modern .sky-confirm-message{padding-bottom:20px}.sky-theme-modern .sky-confirm-body{margin:0}:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-confirm-message{color:#fbfcfe}.sky-theme-modern.sky-theme-mode-dark .sky-confirm-message{color:#fbfcfe}\n"], components: [{ type: i4.SkyModalComponent, selector: "sky-modal", inputs: ["ariaRole", "tiledBody"] }, { type: i5.SkyModalContentComponent, selector: "sky-modal-content" }], directives: [{ type: i6.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i7.λ2, selector: "[skyThemeClass]", inputs: ["class", "skyThemeClass"] }, { type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
105
+ return emitter;
106
+ }, _SkyConfirmComponent_getCustomButtons = function _SkyConfirmComponent_getCustomButtons(buttonConfig) {
107
+ const buttons = [];
108
+ buttonConfig.forEach((config) => {
109
+ buttons.push({
110
+ text: config.text,
111
+ action: config.action,
112
+ styleType: config.styleType || 'default',
113
+ autofocus: config.autofocus || false,
114
+ });
115
+ });
116
+ return buttons;
117
+ };
118
+ SkyConfirmComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyConfirmComponent, deps: [{ token: SKY_CONFIRM_CONFIG }, { token: i1.SkyModalInstance }, { token: i2.SkyLibResourcesService, optional: true }], target: i0.ɵɵFactoryTarget.Component });
119
+ SkyConfirmComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.2", type: SkyConfirmComponent, selector: "sky-confirm", ngImport: i0, template: "<div class=\"sky-confirm\">\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", styles: [".sky-confirm-message{margin-top:5px}.sky-confirm-body{margin-top:10px}.sky-confirm-buttons{margin-top:20px}.sky-confirm-preserve-white-space{white-space:pre-wrap}:host-context(.sky-theme-modern) .sky-confirm-content{padding:20px 30px}:host-context(.sky-theme-modern) .sky-confirm-message{padding-bottom:20px}:host-context(.sky-theme-modern) .sky-confirm-body{margin:0}.sky-theme-modern .sky-confirm-content{padding:20px 30px}.sky-theme-modern .sky-confirm-message{padding-bottom:20px}.sky-theme-modern .sky-confirm-body{margin:0}:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-confirm-message{color:#fbfcfe}.sky-theme-modern.sky-theme-mode-dark .sky-confirm-message{color:#fbfcfe}\n"], components: [{ type: i3.SkyModalComponent, selector: "sky-modal", inputs: ["ariaRole", "tiledBody"] }, { type: i4.SkyModalContentComponent, selector: "sky-modal-content" }], directives: [{ type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i6.λ2, selector: "[skyThemeClass]", inputs: ["class", "skyThemeClass"] }, { type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
117
120
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyConfirmComponent, decorators: [{
118
121
  type: Component,
119
122
  args: [{ selector: 'sky-confirm', template: "<div class=\"sky-confirm\">\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", styles: [".sky-confirm-message{margin-top:5px}.sky-confirm-body{margin-top:10px}.sky-confirm-buttons{margin-top:20px}.sky-confirm-preserve-white-space{white-space:pre-wrap}:host-context(.sky-theme-modern) .sky-confirm-content{padding:20px 30px}:host-context(.sky-theme-modern) .sky-confirm-message{padding-bottom:20px}:host-context(.sky-theme-modern) .sky-confirm-body{margin:0}.sky-theme-modern .sky-confirm-content{padding:20px 30px}.sky-theme-modern .sky-confirm-message{padding-bottom:20px}.sky-theme-modern .sky-confirm-body{margin:0}:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-confirm-message{color:#fbfcfe}.sky-theme-modern.sky-theme-mode-dark .sky-confirm-message{color:#fbfcfe}\n"] }]
120
- }], ctorParameters: function () { return [{ type: i1.SkyConfirmModalContext }, { type: i2.SkyModalInstance }, { type: i3.SkyLibResourcesService, decorators: [{
123
+ }], ctorParameters: function () { return [{ type: undefined, decorators: [{
124
+ type: Inject,
125
+ args: [SKY_CONFIRM_CONFIG]
126
+ }] }, { type: i1.SkyModalInstance }, { type: i2.SkyLibResourcesService, decorators: [{
121
127
  type: Optional
122
128
  }] }]; } });
123
- //# 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, OnInit, 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 { SkyConfirmModalContext } from './confirm-modal-context';\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 implements OnInit {\n  public buttons: SkyConfirmButton[];\n  public message: string;\n  public body: string;\n  public preserveWhiteSpace = false;\n\n  constructor(\n    private config: SkyConfirmModalContext,\n    private modal: SkyModalInstance,\n    @Optional() private resourcesService: SkyLibResourcesService\n  ) {}\n\n  public ngOnInit() {\n    if (\n      this.config.type === SkyConfirmType.Custom &&\n      this.config.buttons.length > 0\n    ) {\n      this.buttons = this.getCustomButtons(this.config.buttons);\n    } else {\n      this.getPresetButtons().subscribe((buttons: SkyConfirmButton[]) => {\n        this.buttons = buttons;\n      });\n    }\n\n    this.message = this.config.message;\n    this.body = this.config.body;\n    this.preserveWhiteSpace = this.config.preserveWhiteSpace || false;\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  private 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  private 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\">\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"]}
129
+ //# 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":";;AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AAC5D,OAAO,EAAE,sBAAsB,EAAE,MAAM,aAAa,CAAC;AAErD,OAAO,EAAE,eAAe,EAAc,GAAG,IAAI,aAAa,EAAE,MAAM,MAAM,CAAC;AAEzE,OAAO,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAC;AAM3D,OAAO,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAC5D,OAAO,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAC;;;;;;;;AAOhD,MAAM,OAAO,mBAAmB;IAU9B,YAEE,MAAwB,EACxB,KAAuB,EACX,gBAAwC;;QAV/C,uBAAkB,GAAG,KAAK,CAAC;QAElC,8CAA0B;QAC1B,6CAAyB;QACzB,wDAA0C;QAQxC,uBAAA,IAAI,+BAAW,MAAM,MAAA,CAAC;QACtB,uBAAA,IAAI,8BAAU,KAAK,MAAA,CAAC;QACpB,uBAAA,IAAI,yCAAqB,gBAAiB,MAAA,CAAC;QAE3C,IACE,MAAM,CAAC,IAAI,KAAK,cAAc,CAAC,MAAM;YACrC,MAAM,CAAC,OAAO;YACd,MAAM,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,EACzB;YACA,IAAI,CAAC,OAAO,GAAG,uBAAA,IAAI,6EAAkB,MAAtB,IAAI,EAAmB,MAAM,CAAC,OAAO,CAAC,CAAC;SACvD;aAAM;YACL,uBAAA,IAAI,6EAAkB,MAAtB,IAAI,CAAoB,CAAC,SAAS,CAAC,CAAC,OAA2B,EAAE,EAAE;gBACjE,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;YACzB,CAAC,CAAC,CAAC;SACJ;QAED,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC,OAAO,CAAC;QAC9B,IAAI,CAAC,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC;QACxB,IAAI,CAAC,kBAAkB,GAAG,CAAC,CAAC,MAAM,CAAC,kBAAkB,CAAC;IACxD,CAAC;IAEM,KAAK,CAAC,MAAwB;QACnC,MAAM,MAAM,GAA6B;YACvC,MAAM,EAAE,MAAM,CAAC,MAAM;SACtB,CAAC;QAEF,uBAAA,IAAI,kCAAO,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;IAC5B,CAAC;;;IAGC,MAAM,OAAO,GAAG,IAAI,eAAe,CAAqB,EAAE,CAAC,CAAC;IAE5D,QAAQ,uBAAA,IAAI,mCAAQ,CAAC,IAAI,EAAE;QACzB,QAAQ;QACR,KAAK,cAAc,CAAC,EAAE;YACpB,uBAAA,IAAI,6CAAkB;iBACnB,SAAS,CAAC,sCAAsC,CAAC;iBACjD,SAAS,CAAC,CAAC,KAAa,EAAE,EAAE;gBAC3B,OAAO,CAAC,IAAI,CAAC;oBACX;wBACE,IAAI,EAAE,KAAK;wBACX,SAAS,EAAE,IAAI;wBACf,SAAS,EAAE,SAAS;wBACpB,MAAM,EAAE,IAAI;qBACb;iBACF,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;YACL,MAAM;QAER,KAAK,cAAc,CAAC,WAAW;YAC7B,aAAa,CACX,uBAAA,IAAI,6CAAkB,CAAC,SAAS,CAC9B,uCAAuC,CACxC,EACD,uBAAA,IAAI,6CAAkB,CAAC,SAAS,CAC9B,sCAAsC,CACvC,EACD,uBAAA,IAAI,6CAAkB,CAAC,SAAS,CAC9B,0CAA0C,CAC3C,CACF,CAAC,SAAS,CAAC,CAAC,MAAW,EAAE,EAAE;gBAC1B,OAAO,CAAC,IAAI,CAAC;oBACX;wBACE,IAAI,EAAE,MAAM,CAAC,CAAC,CAAC;wBACf,SAAS,EAAE,IAAI;wBACf,SAAS,EAAE,SAAS;wBACpB,MAAM,EAAE,KAAK;qBACd;oBACD;wBACE,IAAI,EAAE,MAAM,CAAC,CAAC,CAAC;wBACf,SAAS,EAAE,SAAS;wBACpB,MAAM,EAAE,IAAI;qBACb;oBACD;wBACE,IAAI,EAAE,MAAM,CAAC,CAAC,CAAC;wBACf,SAAS,EAAE,MAAM;wBACjB,MAAM,EAAE,QAAQ;qBACjB;iBACF,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;YACH,MAAM;QAER,KAAK,cAAc,CAAC,SAAS;YAC3B,aAAa,CACX,uBAAA,IAAI,6CAAkB,CAAC,SAAS,CAC9B,uCAAuC,CACxC,EACD,uBAAA,IAAI,6CAAkB,CAAC,SAAS,CAC9B,0CAA0C,CAC3C,CACF,CAAC,SAAS,CAAC,CAAC,MAAW,EAAE,EAAE;gBAC1B,OAAO,CAAC,IAAI,CAAC;oBACX;wBACE,IAAI,EAAE,MAAM,CAAC,CAAC,CAAC;wBACf,SAAS,EAAE,IAAI;wBACf,SAAS,EAAE,SAAS;wBACpB,MAAM,EAAE,KAAK;qBACd;oBACD;wBACE,IAAI,EAAE,MAAM,CAAC,CAAC,CAAC;wBACf,SAAS,EAAE,MAAM;wBACjB,MAAM,EAAE,QAAQ;qBACjB;iBACF,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;YACH,MAAM;KACT;IAED,OAAO,OAAO,CAAC;AACjB,CAAC,yFAGC,YAAsC;IAEtC,MAAM,OAAO,GAAuB,EAAE,CAAC;IAEvC,YAAY,CAAC,OAAO,CAAC,CAAC,MAA8B,EAAE,EAAE;QACtD,OAAO,CAAC,IAAI,CAAC;YACX,IAAI,EAAE,MAAM,CAAC,IAAI;YACjB,MAAM,EAAE,MAAM,CAAC,MAAM;YACrB,SAAS,EAAE,MAAM,CAAC,SAAS,IAAI,SAAS;YACxC,SAAS,EAAE,MAAM,CAAC,SAAS,IAAI,KAAK;SACjB,CAAC,CAAC;IACzB,CAAC,CAAC,CAAC;IAEH,OAAO,OAAO,CAAC;AACjB,CAAC;gHA9IU,mBAAmB,kBAWpB,kBAAkB;oGAXjB,mBAAmB,mDCnBhC,iwCA6CA;2FD1Ba,mBAAmB;kBAL/B,SAAS;+BACE,aAAa;;0BAepB,MAAM;2BAAC,kBAAkB;;0BAGzB,QAAQ","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\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  }\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\">\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,7 +1,9 @@
1
+ var _SkyConfirmService_modalService;
2
+ import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
1
3
  import { Injectable } from '@angular/core';
2
4
  import { SkyModalService } from '../modal/modal.service';
5
+ import { SKY_CONFIRM_CONFIG } from './confirm-config-token';
3
6
  import { SkyConfirmInstance } from './confirm-instance';
4
- import { SkyConfirmModalContext } from './confirm-modal-context';
5
7
  import { SkyConfirmComponent } from './confirm.component';
6
8
  import * as i0 from "@angular/core";
7
9
  import * as i1 from "../modal/modal.service";
@@ -10,17 +12,18 @@ import * as i1 from "../modal/modal.service";
10
12
  */
11
13
  export class SkyConfirmService {
12
14
  constructor(modalService) {
13
- this.modalService = modalService;
15
+ _SkyConfirmService_modalService.set(this, void 0);
16
+ __classPrivateFieldSet(this, _SkyConfirmService_modalService, modalService, "f");
14
17
  }
15
18
  /**
16
19
  * Opens a dialog using the specified options.
17
20
  * @param config Specifies configuration options for the dialog.
18
21
  */
19
22
  open(config) {
20
- const modalInstance = this.modalService.open(SkyConfirmComponent, {
23
+ const modalInstance = __classPrivateFieldGet(this, _SkyConfirmService_modalService, "f").open(SkyConfirmComponent, {
21
24
  providers: [
22
25
  {
23
- provide: SkyConfirmModalContext,
26
+ provide: SKY_CONFIRM_CONFIG,
24
27
  useValue: config,
25
28
  },
26
29
  ],
@@ -40,6 +43,7 @@ export class SkyConfirmService {
40
43
  return confirmInstance;
41
44
  }
42
45
  }
46
+ _SkyConfirmService_modalService = new WeakMap();
43
47
  SkyConfirmService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyConfirmService, deps: [{ token: i1.SkyModalService }], target: i0.ɵɵFactoryTarget.Injectable });
44
48
  SkyConfirmService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyConfirmService, providedIn: 'any' });
45
49
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyConfirmService, decorators: [{
@@ -51,4 +55,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
51
55
  providedIn: 'any',
52
56
  }]
53
57
  }], ctorParameters: function () { return [{ type: i1.SkyModalService }]; } });
54
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlybS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL21vZGFscy9zcmMvbGliL21vZHVsZXMvY29uZmlybS9jb25maXJtLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUkzQyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFJekQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDeEQsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDakUsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0scUJBQXFCLENBQUM7OztBQUUxRDs7R0FFRztBQU9ILE1BQU0sT0FBTyxpQkFBaUI7SUFDNUIsWUFBb0IsWUFBNkI7UUFBN0IsaUJBQVksR0FBWixZQUFZLENBQWlCO0lBQUcsQ0FBQztJQUVyRDs7O09BR0c7SUFDSSxJQUFJLENBQUMsTUFBd0I7UUFDbEMsTUFBTSxhQUFhLEdBQXFCLElBQUksQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUM1RCxtQkFBbUIsRUFDbkI7WUFDRSxTQUFTLEVBQUU7Z0JBQ1Q7b0JBQ0UsT0FBTyxFQUFFLHNCQUFzQjtvQkFDL0IsUUFBUSxFQUFFLE1BQU07aUJBQ2pCO2FBQ0Y7U0FDRixDQUNGLENBQUM7UUFFRixNQUFNLGVBQWUsR0FBRyxJQUFJLGtCQUFrQixFQUFFLENBQUM7UUFFakQsYUFBYSxDQUFDLE1BQU0sQ0FBQyxTQUFTLENBQUMsQ0FBQyxJQUF1QixFQUFFLEVBQUU7WUFDekQsSUFBSSxNQUFNLEdBQTZCLElBQUksQ0FBQyxJQUFJLENBQUM7WUFFakQsMENBQTBDO1lBQzFDLElBQUksTUFBTSxLQUFLLFNBQVMsRUFBRTtnQkFDeEIsTUFBTSxHQUFHO29CQUNQLE1BQU0sRUFBRSxRQUFRO2lCQUNqQixDQUFDO2FBQ0g7WUFFRCxlQUFlLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztZQUNwQyxlQUFlLENBQUMsTUFBTSxDQUFDLFFBQVEsRUFBRSxDQUFDO1FBQ3BDLENBQUMsQ0FBQyxDQUFDO1FBRUgsT0FBTyxlQUFlLENBQUM7SUFDekIsQ0FBQzs7OEdBckNVLGlCQUFpQjtrSEFBakIsaUJBQWlCLGNBRmhCLEtBQUs7MkZBRU4saUJBQWlCO2tCQU43QixVQUFVO21CQUFDO29CQUNWLGdHQUFnRztvQkFDaEcsOEZBQThGO29CQUM5RiwyRkFBMkY7b0JBQzNGLFVBQVUsRUFBRSxLQUFLO2lCQUNsQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgU2t5TW9kYWxDbG9zZUFyZ3MgfSBmcm9tICcuLi9tb2RhbC9tb2RhbC1jbG9zZS1hcmdzJztcbmltcG9ydCB7IFNreU1vZGFsSW5zdGFuY2UgfSBmcm9tICcuLi9tb2RhbC9tb2RhbC1pbnN0YW5jZSc7XG5pbXBvcnQgeyBTa3lNb2RhbFNlcnZpY2UgfSBmcm9tICcuLi9tb2RhbC9tb2RhbC5zZXJ2aWNlJztcblxuaW1wb3J0IHsgU2t5Q29uZmlybUNsb3NlRXZlbnRBcmdzIH0gZnJvbSAnLi9jb25maXJtLWNsb3NlZC1ldmVudC1hcmdzJztcbmltcG9ydCB7IFNreUNvbmZpcm1Db25maWcgfSBmcm9tICcuL2NvbmZpcm0tY29uZmlnJztcbmltcG9ydCB7IFNreUNvbmZpcm1JbnN0YW5jZSB9IGZyb20gJy4vY29uZmlybS1pbnN0YW5jZSc7XG5pbXBvcnQgeyBTa3lDb25maXJtTW9kYWxDb250ZXh0IH0gZnJvbSAnLi9jb25maXJtLW1vZGFsLWNvbnRleHQnO1xuaW1wb3J0IHsgU2t5Q29uZmlybUNvbXBvbmVudCB9IGZyb20gJy4vY29uZmlybS5jb21wb25lbnQnO1xuXG4vKipcbiAqIExhdW5jaGVzIGEgZGlhbG9nLlxuICovXG5ASW5qZWN0YWJsZSh7XG4gIC8vIE11c3QgYmUgJ2FueScgc28gdGhhdCB0aGUgbW9kYWwgY29tcG9uZW50IGlzIGNyZWF0ZWQgaW4gdGhlIGNvbnRleHQgb2YgaXRzIG1vZHVsZSdzIGluamVjdG9yLlxuICAvLyBJZiBzZXQgdG8gJ3Jvb3QnLCB0aGUgY29tcG9uZW50J3MgZGVwZW5kZW5jeSBpbmplY3Rpb25zIHdvdWxkIG9ubHkgYmUgZGVyaXZlZCBmcm9tIHRoZSByb290XG4gIC8vIGluamVjdG9yIGFuZCBtYXkgbG9vc2UgY29udGV4dCBpZiB0aGUgbW9kYWwgd2FzIG9wZW5lZCBmcm9tIHdpdGhpbiBhIGxhenktbG9hZGVkIG1vZHVsZS5cbiAgcHJvdmlkZWRJbjogJ2FueScsXG59KVxuZXhwb3J0IGNsYXNzIFNreUNvbmZpcm1TZXJ2aWNlIHtcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBtb2RhbFNlcnZpY2U6IFNreU1vZGFsU2VydmljZSkge31cblxuICAvKipcbiAgICogT3BlbnMgYSBkaWFsb2cgdXNpbmcgdGhlIHNwZWNpZmllZCBvcHRpb25zLlxuICAgKiBAcGFyYW0gY29uZmlnIFNwZWNpZmllcyBjb25maWd1cmF0aW9uIG9wdGlvbnMgZm9yIHRoZSBkaWFsb2cuXG4gICAqL1xuICBwdWJsaWMgb3Blbihjb25maWc6IFNreUNvbmZpcm1Db25maWcpOiBTa3lDb25maXJtSW5zdGFuY2Uge1xuICAgIGNvbnN0IG1vZGFsSW5zdGFuY2U6IFNreU1vZGFsSW5zdGFuY2UgPSB0aGlzLm1vZGFsU2VydmljZS5vcGVuKFxuICAgICAgU2t5Q29uZmlybUNvbXBvbmVudCxcbiAgICAgIHtcbiAgICAgICAgcHJvdmlkZXJzOiBbXG4gICAgICAgICAge1xuICAgICAgICAgICAgcHJvdmlkZTogU2t5Q29uZmlybU1vZGFsQ29udGV4dCxcbiAgICAgICAgICAgIHVzZVZhbHVlOiBjb25maWcsXG4gICAgICAgICAgfSxcbiAgICAgICAgXSxcbiAgICAgIH1cbiAgICApO1xuXG4gICAgY29uc3QgY29uZmlybUluc3RhbmNlID0gbmV3IFNreUNvbmZpcm1JbnN0YW5jZSgpO1xuXG4gICAgbW9kYWxJbnN0YW5jZS5jbG9zZWQuc3Vic2NyaWJlKChhcmdzOiBTa3lNb2RhbENsb3NlQXJncykgPT4ge1xuICAgICAgbGV0IHJlc3VsdDogU2t5Q29uZmlybUNsb3NlRXZlbnRBcmdzID0gYXJncy5kYXRhO1xuXG4gICAgICAvLyBUaGUgbW9kYWwgd2FzIGNsb3NlZCB1c2luZyB0aGUgRVNDIGtleS5cbiAgICAgIGlmIChyZXN1bHQgPT09IHVuZGVmaW5lZCkge1xuICAgICAgICByZXN1bHQgPSB7XG4gICAgICAgICAgYWN0aW9uOiAnY2FuY2VsJyxcbiAgICAgICAgfTtcbiAgICAgIH1cblxuICAgICAgY29uZmlybUluc3RhbmNlLmNsb3NlZC5lbWl0KHJlc3VsdCk7XG4gICAgICBjb25maXJtSW5zdGFuY2UuY2xvc2VkLmNvbXBsZXRlKCk7XG4gICAgfSk7XG5cbiAgICByZXR1cm4gY29uZmlybUluc3RhbmNlO1xuICB9XG59XG4iXX0=
58
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlybS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL21vZGFscy9zcmMvbGliL21vZHVsZXMvY29uZmlybS9jb25maXJtLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBSTNDLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUl6RCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUM1RCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUN4RCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQzs7O0FBRTFEOztHQUVHO0FBT0gsTUFBTSxPQUFPLGlCQUFpQjtJQUc1QixZQUFZLFlBQTZCO1FBRnpDLGtEQUErQjtRQUc3Qix1QkFBQSxJQUFJLG1DQUFpQixZQUFZLE1BQUEsQ0FBQztJQUNwQyxDQUFDO0lBRUQ7OztPQUdHO0lBQ0ksSUFBSSxDQUFDLE1BQXdCO1FBQ2xDLE1BQU0sYUFBYSxHQUFxQix1QkFBQSxJQUFJLHVDQUFjLENBQUMsSUFBSSxDQUM3RCxtQkFBbUIsRUFDbkI7WUFDRSxTQUFTLEVBQUU7Z0JBQ1Q7b0JBQ0UsT0FBTyxFQUFFLGtCQUFrQjtvQkFDM0IsUUFBUSxFQUFFLE1BQU07aUJBQ2pCO2FBQ0Y7U0FDRixDQUNGLENBQUM7UUFFRixNQUFNLGVBQWUsR0FBRyxJQUFJLGtCQUFrQixFQUFFLENBQUM7UUFFakQsYUFBYSxDQUFDLE1BQU0sQ0FBQyxTQUFTLENBQUMsQ0FBQyxJQUF1QixFQUFFLEVBQUU7WUFDekQsSUFBSSxNQUFNLEdBQTZCLElBQUksQ0FBQyxJQUFJLENBQUM7WUFFakQsMENBQTBDO1lBQzFDLElBQUksTUFBTSxLQUFLLFNBQVMsRUFBRTtnQkFDeEIsTUFBTSxHQUFHO29CQUNQLE1BQU0sRUFBRSxRQUFRO2lCQUNqQixDQUFDO2FBQ0g7WUFFRCxlQUFlLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztZQUNwQyxlQUFlLENBQUMsTUFBTSxDQUFDLFFBQVEsRUFBRSxDQUFDO1FBQ3BDLENBQUMsQ0FBQyxDQUFDO1FBRUgsT0FBTyxlQUFlLENBQUM7SUFDekIsQ0FBQzs7OzhHQXpDVSxpQkFBaUI7a0hBQWpCLGlCQUFpQixjQUZoQixLQUFLOzJGQUVOLGlCQUFpQjtrQkFON0IsVUFBVTttQkFBQztvQkFDVixnR0FBZ0c7b0JBQ2hHLDhGQUE4RjtvQkFDOUYsMkZBQTJGO29CQUMzRixVQUFVLEVBQUUsS0FBSztpQkFDbEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IFNreU1vZGFsQ2xvc2VBcmdzIH0gZnJvbSAnLi4vbW9kYWwvbW9kYWwtY2xvc2UtYXJncyc7XG5pbXBvcnQgeyBTa3lNb2RhbEluc3RhbmNlIH0gZnJvbSAnLi4vbW9kYWwvbW9kYWwtaW5zdGFuY2UnO1xuaW1wb3J0IHsgU2t5TW9kYWxTZXJ2aWNlIH0gZnJvbSAnLi4vbW9kYWwvbW9kYWwuc2VydmljZSc7XG5cbmltcG9ydCB7IFNreUNvbmZpcm1DbG9zZUV2ZW50QXJncyB9IGZyb20gJy4vY29uZmlybS1jbG9zZWQtZXZlbnQtYXJncyc7XG5pbXBvcnQgeyBTa3lDb25maXJtQ29uZmlnIH0gZnJvbSAnLi9jb25maXJtLWNvbmZpZyc7XG5pbXBvcnQgeyBTS1lfQ09ORklSTV9DT05GSUcgfSBmcm9tICcuL2NvbmZpcm0tY29uZmlnLXRva2VuJztcbmltcG9ydCB7IFNreUNvbmZpcm1JbnN0YW5jZSB9IGZyb20gJy4vY29uZmlybS1pbnN0YW5jZSc7XG5pbXBvcnQgeyBTa3lDb25maXJtQ29tcG9uZW50IH0gZnJvbSAnLi9jb25maXJtLmNvbXBvbmVudCc7XG5cbi8qKlxuICogTGF1bmNoZXMgYSBkaWFsb2cuXG4gKi9cbkBJbmplY3RhYmxlKHtcbiAgLy8gTXVzdCBiZSAnYW55JyBzbyB0aGF0IHRoZSBtb2RhbCBjb21wb25lbnQgaXMgY3JlYXRlZCBpbiB0aGUgY29udGV4dCBvZiBpdHMgbW9kdWxlJ3MgaW5qZWN0b3IuXG4gIC8vIElmIHNldCB0byAncm9vdCcsIHRoZSBjb21wb25lbnQncyBkZXBlbmRlbmN5IGluamVjdGlvbnMgd291bGQgb25seSBiZSBkZXJpdmVkIGZyb20gdGhlIHJvb3RcbiAgLy8gaW5qZWN0b3IgYW5kIG1heSBsb29zZSBjb250ZXh0IGlmIHRoZSBtb2RhbCB3YXMgb3BlbmVkIGZyb20gd2l0aGluIGEgbGF6eS1sb2FkZWQgbW9kdWxlLlxuICBwcm92aWRlZEluOiAnYW55Jyxcbn0pXG5leHBvcnQgY2xhc3MgU2t5Q29uZmlybVNlcnZpY2Uge1xuICAjbW9kYWxTZXJ2aWNlOiBTa3lNb2RhbFNlcnZpY2U7XG5cbiAgY29uc3RydWN0b3IobW9kYWxTZXJ2aWNlOiBTa3lNb2RhbFNlcnZpY2UpIHtcbiAgICB0aGlzLiNtb2RhbFNlcnZpY2UgPSBtb2RhbFNlcnZpY2U7XG4gIH1cblxuICAvKipcbiAgICogT3BlbnMgYSBkaWFsb2cgdXNpbmcgdGhlIHNwZWNpZmllZCBvcHRpb25zLlxuICAgKiBAcGFyYW0gY29uZmlnIFNwZWNpZmllcyBjb25maWd1cmF0aW9uIG9wdGlvbnMgZm9yIHRoZSBkaWFsb2cuXG4gICAqL1xuICBwdWJsaWMgb3Blbihjb25maWc6IFNreUNvbmZpcm1Db25maWcpOiBTa3lDb25maXJtSW5zdGFuY2Uge1xuICAgIGNvbnN0IG1vZGFsSW5zdGFuY2U6IFNreU1vZGFsSW5zdGFuY2UgPSB0aGlzLiNtb2RhbFNlcnZpY2Uub3BlbihcbiAgICAgIFNreUNvbmZpcm1Db21wb25lbnQsXG4gICAgICB7XG4gICAgICAgIHByb3ZpZGVyczogW1xuICAgICAgICAgIHtcbiAgICAgICAgICAgIHByb3ZpZGU6IFNLWV9DT05GSVJNX0NPTkZJRyxcbiAgICAgICAgICAgIHVzZVZhbHVlOiBjb25maWcsXG4gICAgICAgICAgfSxcbiAgICAgICAgXSxcbiAgICAgIH1cbiAgICApO1xuXG4gICAgY29uc3QgY29uZmlybUluc3RhbmNlID0gbmV3IFNreUNvbmZpcm1JbnN0YW5jZSgpO1xuXG4gICAgbW9kYWxJbnN0YW5jZS5jbG9zZWQuc3Vic2NyaWJlKChhcmdzOiBTa3lNb2RhbENsb3NlQXJncykgPT4ge1xuICAgICAgbGV0IHJlc3VsdDogU2t5Q29uZmlybUNsb3NlRXZlbnRBcmdzID0gYXJncy5kYXRhO1xuXG4gICAgICAvLyBUaGUgbW9kYWwgd2FzIGNsb3NlZCB1c2luZyB0aGUgRVNDIGtleS5cbiAgICAgIGlmIChyZXN1bHQgPT09IHVuZGVmaW5lZCkge1xuICAgICAgICByZXN1bHQgPSB7XG4gICAgICAgICAgYWN0aW9uOiAnY2FuY2VsJyxcbiAgICAgICAgfTtcbiAgICAgIH1cblxuICAgICAgY29uZmlybUluc3RhbmNlLmNsb3NlZC5lbWl0KHJlc3VsdCk7XG4gICAgICBjb25maXJtSW5zdGFuY2UuY2xvc2VkLmNvbXBsZXRlKCk7XG4gICAgfSk7XG5cbiAgICByZXR1cm4gY29uZmlybUluc3RhbmNlO1xuICB9XG59XG4iXX0=
@@ -1,3 +1,5 @@
1
+ var _SkyModalAdapterService_instances, _SkyModalAdapterService_docRef, _SkyModalAdapterService_bodyEl, _SkyModalAdapterService_windowRef, _SkyModalAdapterService_addClassToBody, _SkyModalAdapterService_removeClassFromBody;
2
+ import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
1
3
  import { Injectable } from '@angular/core';
2
4
  import { SkyAppWindowRef } from '@skyux/core';
3
5
  import * as i0 from "@angular/core";
@@ -7,36 +9,39 @@ import * as i1 from "@skyux/core";
7
9
  */
8
10
  export class SkyModalAdapterService {
9
11
  constructor(windowRef) {
10
- this.windowRef = windowRef;
11
- this.docRef = this.windowRef.nativeWindow.document;
12
- this.bodyEl = this.windowRef.nativeWindow.document.body;
12
+ _SkyModalAdapterService_instances.add(this);
13
+ _SkyModalAdapterService_docRef.set(this, void 0);
14
+ _SkyModalAdapterService_bodyEl.set(this, void 0);
15
+ _SkyModalAdapterService_windowRef.set(this, void 0);
16
+ __classPrivateFieldSet(this, _SkyModalAdapterService_windowRef, windowRef, "f");
17
+ __classPrivateFieldSet(this, _SkyModalAdapterService_docRef, __classPrivateFieldGet(this, _SkyModalAdapterService_windowRef, "f").nativeWindow.document, "f");
18
+ __classPrivateFieldSet(this, _SkyModalAdapterService_bodyEl, __classPrivateFieldGet(this, _SkyModalAdapterService_windowRef, "f").nativeWindow.document.body, "f");
13
19
  }
14
20
  toggleFullPageModalClass(isAddFull) {
15
21
  if (isAddFull) {
16
- this.addClassToBody(SkyModalAdapterService.MODAL_BODY_FULL_CLASS);
22
+ __classPrivateFieldGet(this, _SkyModalAdapterService_instances, "m", _SkyModalAdapterService_addClassToBody).call(this, SkyModalAdapterService.MODAL_BODY_FULL_CLASS);
17
23
  }
18
24
  else {
19
- this.removeClassFromBody(SkyModalAdapterService.MODAL_BODY_FULL_CLASS);
25
+ __classPrivateFieldGet(this, _SkyModalAdapterService_instances, "m", _SkyModalAdapterService_removeClassFromBody).call(this, SkyModalAdapterService.MODAL_BODY_FULL_CLASS);
20
26
  }
21
27
  }
22
28
  setPageScroll(isAdd) {
23
29
  if (isAdd) {
24
- this.addClassToBody(SkyModalAdapterService.MODAL_BODY_CLASS);
30
+ __classPrivateFieldGet(this, _SkyModalAdapterService_instances, "m", _SkyModalAdapterService_addClassToBody).call(this, SkyModalAdapterService.MODAL_BODY_CLASS);
25
31
  }
26
32
  else {
27
- this.removeClassFromBody(SkyModalAdapterService.MODAL_BODY_CLASS);
33
+ __classPrivateFieldGet(this, _SkyModalAdapterService_instances, "m", _SkyModalAdapterService_removeClassFromBody).call(this, SkyModalAdapterService.MODAL_BODY_CLASS);
28
34
  }
29
35
  }
30
36
  getModalOpener() {
31
- return this.docRef.activeElement;
32
- }
33
- addClassToBody(className) {
34
- this.bodyEl.classList.add(className);
35
- }
36
- removeClassFromBody(className) {
37
- this.bodyEl.classList.remove(className);
37
+ return __classPrivateFieldGet(this, _SkyModalAdapterService_docRef, "f").activeElement;
38
38
  }
39
39
  }
40
+ _SkyModalAdapterService_docRef = new WeakMap(), _SkyModalAdapterService_bodyEl = new WeakMap(), _SkyModalAdapterService_windowRef = new WeakMap(), _SkyModalAdapterService_instances = new WeakSet(), _SkyModalAdapterService_addClassToBody = function _SkyModalAdapterService_addClassToBody(className) {
41
+ __classPrivateFieldGet(this, _SkyModalAdapterService_bodyEl, "f").classList.add(className);
42
+ }, _SkyModalAdapterService_removeClassFromBody = function _SkyModalAdapterService_removeClassFromBody(className) {
43
+ __classPrivateFieldGet(this, _SkyModalAdapterService_bodyEl, "f").classList.remove(className);
44
+ };
40
45
  SkyModalAdapterService.MODAL_BODY_FULL_CLASS = 'sky-modal-body-full-page';
41
46
  SkyModalAdapterService.MODAL_BODY_CLASS = 'sky-modal-body-open';
42
47
  SkyModalAdapterService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyModalAdapterService, deps: [{ token: i1.SkyAppWindowRef }], target: i0.ɵɵFactoryTarget.Injectable });
@@ -44,4 +49,4 @@ SkyModalAdapterService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0
44
49
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyModalAdapterService, decorators: [{
45
50
  type: Injectable
46
51
  }], ctorParameters: function () { return [{ type: i1.SkyAppWindowRef }]; } });
47
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kYWwtYWRhcHRlci5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL21vZGFscy9zcmMvbGliL21vZHVsZXMvbW9kYWwvbW9kYWwtYWRhcHRlci5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDM0MsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLGFBQWEsQ0FBQzs7O0FBRTlDOztHQUVHO0FBRUgsTUFBTSxPQUFPLHNCQUFzQjtJQU9qQyxZQUFvQixTQUEwQjtRQUExQixjQUFTLEdBQVQsU0FBUyxDQUFpQjtRQUM1QyxJQUFJLENBQUMsTUFBTSxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsWUFBWSxDQUFDLFFBQVEsQ0FBQztRQUNuRCxJQUFJLENBQUMsTUFBTSxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsWUFBWSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUM7SUFDMUQsQ0FBQztJQUVNLHdCQUF3QixDQUFDLFNBQWtCO1FBQ2hELElBQUksU0FBUyxFQUFFO1lBQ2IsSUFBSSxDQUFDLGNBQWMsQ0FBQyxzQkFBc0IsQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDO1NBQ25FO2FBQU07WUFDTCxJQUFJLENBQUMsbUJBQW1CLENBQUMsc0JBQXNCLENBQUMscUJBQXFCLENBQUMsQ0FBQztTQUN4RTtJQUNILENBQUM7SUFFTSxhQUFhLENBQUMsS0FBYztRQUNqQyxJQUFJLEtBQUssRUFBRTtZQUNULElBQUksQ0FBQyxjQUFjLENBQUMsc0JBQXNCLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztTQUM5RDthQUFNO1lBQ0wsSUFBSSxDQUFDLG1CQUFtQixDQUFDLHNCQUFzQixDQUFDLGdCQUFnQixDQUFDLENBQUM7U0FDbkU7SUFDSCxDQUFDO0lBRU0sY0FBYztRQUNuQixPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsYUFBYSxDQUFDO0lBQ25DLENBQUM7SUFFTyxjQUFjLENBQUMsU0FBaUI7UUFDdEMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLFNBQVMsQ0FBQyxDQUFDO0lBQ3ZDLENBQUM7SUFFTyxtQkFBbUIsQ0FBQyxTQUFpQjtRQUMzQyxJQUFJLENBQUMsTUFBTSxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsU0FBUyxDQUFDLENBQUM7SUFDMUMsQ0FBQzs7QUFyQ3VCLDRDQUFxQixHQUFHLDBCQUEyQixDQUFBO0FBQ25ELHVDQUFnQixHQUFHLHFCQUFzQixDQUFBO21IQUZ0RCxzQkFBc0I7dUhBQXRCLHNCQUFzQjsyRkFBdEIsc0JBQXNCO2tCQURsQyxVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgU2t5QXBwV2luZG93UmVmIH0gZnJvbSAnQHNreXV4L2NvcmUnO1xuXG4vKipcbiAqIEBpbnRlcm5hbFxuICovXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgU2t5TW9kYWxBZGFwdGVyU2VydmljZSB7XG4gIHByaXZhdGUgc3RhdGljIHJlYWRvbmx5IE1PREFMX0JPRFlfRlVMTF9DTEFTUyA9ICdza3ktbW9kYWwtYm9keS1mdWxsLXBhZ2UnO1xuICBwcml2YXRlIHN0YXRpYyByZWFkb25seSBNT0RBTF9CT0RZX0NMQVNTID0gJ3NreS1tb2RhbC1ib2R5LW9wZW4nO1xuXG4gIHByaXZhdGUgZG9jUmVmOiBhbnk7XG4gIHByaXZhdGUgYm9keUVsOiBIVE1MRWxlbWVudDtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHdpbmRvd1JlZjogU2t5QXBwV2luZG93UmVmKSB7XG4gICAgdGhpcy5kb2NSZWYgPSB0aGlzLndpbmRvd1JlZi5uYXRpdmVXaW5kb3cuZG9jdW1lbnQ7XG4gICAgdGhpcy5ib2R5RWwgPSB0aGlzLndpbmRvd1JlZi5uYXRpdmVXaW5kb3cuZG9jdW1lbnQuYm9keTtcbiAgfVxuXG4gIHB1YmxpYyB0b2dnbGVGdWxsUGFnZU1vZGFsQ2xhc3MoaXNBZGRGdWxsOiBib29sZWFuKTogdm9pZCB7XG4gICAgaWYgKGlzQWRkRnVsbCkge1xuICAgICAgdGhpcy5hZGRDbGFzc1RvQm9keShTa3lNb2RhbEFkYXB0ZXJTZXJ2aWNlLk1PREFMX0JPRFlfRlVMTF9DTEFTUyk7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRoaXMucmVtb3ZlQ2xhc3NGcm9tQm9keShTa3lNb2RhbEFkYXB0ZXJTZXJ2aWNlLk1PREFMX0JPRFlfRlVMTF9DTEFTUyk7XG4gICAgfVxuICB9XG5cbiAgcHVibGljIHNldFBhZ2VTY3JvbGwoaXNBZGQ6IGJvb2xlYW4pOiB2b2lkIHtcbiAgICBpZiAoaXNBZGQpIHtcbiAgICAgIHRoaXMuYWRkQ2xhc3NUb0JvZHkoU2t5TW9kYWxBZGFwdGVyU2VydmljZS5NT0RBTF9CT0RZX0NMQVNTKTtcbiAgICB9IGVsc2Uge1xuICAgICAgdGhpcy5yZW1vdmVDbGFzc0Zyb21Cb2R5KFNreU1vZGFsQWRhcHRlclNlcnZpY2UuTU9EQUxfQk9EWV9DTEFTUyk7XG4gICAgfVxuICB9XG5cbiAgcHVibGljIGdldE1vZGFsT3BlbmVyKCk6IEhUTUxFbGVtZW50IHtcbiAgICByZXR1cm4gdGhpcy5kb2NSZWYuYWN0aXZlRWxlbWVudDtcbiAgfVxuXG4gIHByaXZhdGUgYWRkQ2xhc3NUb0JvZHkoY2xhc3NOYW1lOiBzdHJpbmcpOiB2b2lkIHtcbiAgICB0aGlzLmJvZHlFbC5jbGFzc0xpc3QuYWRkKGNsYXNzTmFtZSk7XG4gIH1cblxuICBwcml2YXRlIHJlbW92ZUNsYXNzRnJvbUJvZHkoY2xhc3NOYW1lOiBzdHJpbmcpOiB2b2lkIHtcbiAgICB0aGlzLmJvZHlFbC5jbGFzc0xpc3QucmVtb3ZlKGNsYXNzTmFtZSk7XG4gIH1cbn1cbiJdfQ==
52
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kYWwtYWRhcHRlci5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL21vZGFscy9zcmMvbGliL21vZHVsZXMvbW9kYWwvbW9kYWwtYWRhcHRlci5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzQyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sYUFBYSxDQUFDOzs7QUFFOUM7O0dBRUc7QUFFSCxNQUFNLE9BQU8sc0JBQXNCO0lBU2pDLFlBQVksU0FBMEI7O1FBTHRDLGlEQUFhO1FBQ2IsaURBQXFCO1FBRXJCLG9EQUE0QjtRQUcxQix1QkFBQSxJQUFJLHFDQUFjLFNBQVMsTUFBQSxDQUFDO1FBQzVCLHVCQUFBLElBQUksa0NBQVcsdUJBQUEsSUFBSSx5Q0FBVyxDQUFDLFlBQVksQ0FBQyxRQUFRLE1BQUEsQ0FBQztRQUNyRCx1QkFBQSxJQUFJLGtDQUFXLHVCQUFBLElBQUkseUNBQVcsQ0FBQyxZQUFZLENBQUMsUUFBUSxDQUFDLElBQUksTUFBQSxDQUFDO0lBQzVELENBQUM7SUFFTSx3QkFBd0IsQ0FBQyxTQUFrQjtRQUNoRCxJQUFJLFNBQVMsRUFBRTtZQUNiLHVCQUFBLElBQUksaUZBQWdCLE1BQXBCLElBQUksRUFBaUIsc0JBQXNCLENBQUMscUJBQXFCLENBQUMsQ0FBQztTQUNwRTthQUFNO1lBQ0wsdUJBQUEsSUFBSSxzRkFBcUIsTUFBekIsSUFBSSxFQUFzQixzQkFBc0IsQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDO1NBQ3pFO0lBQ0gsQ0FBQztJQUVNLGFBQWEsQ0FBQyxLQUFjO1FBQ2pDLElBQUksS0FBSyxFQUFFO1lBQ1QsdUJBQUEsSUFBSSxpRkFBZ0IsTUFBcEIsSUFBSSxFQUFpQixzQkFBc0IsQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO1NBQy9EO2FBQU07WUFDTCx1QkFBQSxJQUFJLHNGQUFxQixNQUF6QixJQUFJLEVBQXNCLHNCQUFzQixDQUFDLGdCQUFnQixDQUFDLENBQUM7U0FDcEU7SUFDSCxDQUFDO0lBRU0sY0FBYztRQUNuQixPQUFPLHVCQUFBLElBQUksc0NBQVEsQ0FBQyxhQUFhLENBQUM7SUFDcEMsQ0FBQzs7K1JBRWUsU0FBaUI7SUFDL0IsdUJBQUEsSUFBSSxzQ0FBUSxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsU0FBUyxDQUFDLENBQUM7QUFDeEMsQ0FBQyxxR0FFb0IsU0FBaUI7SUFDcEMsdUJBQUEsSUFBSSxzQ0FBUSxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsU0FBUyxDQUFDLENBQUM7QUFDM0MsQ0FBQztBQXhDdUIsNENBQXFCLEdBQUcsMEJBQTJCLENBQUE7QUFDbkQsdUNBQWdCLEdBQUcscUJBQXNCLENBQUE7bUhBRnRELHNCQUFzQjt1SEFBdEIsc0JBQXNCOzJGQUF0QixzQkFBc0I7a0JBRGxDLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBTa3lBcHBXaW5kb3dSZWYgfSBmcm9tICdAc2t5dXgvY29yZSc7XG5cbi8qKlxuICogQGludGVybmFsXG4gKi9cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBTa3lNb2RhbEFkYXB0ZXJTZXJ2aWNlIHtcbiAgcHJpdmF0ZSBzdGF0aWMgcmVhZG9ubHkgTU9EQUxfQk9EWV9GVUxMX0NMQVNTID0gJ3NreS1tb2RhbC1ib2R5LWZ1bGwtcGFnZSc7XG4gIHByaXZhdGUgc3RhdGljIHJlYWRvbmx5IE1PREFMX0JPRFlfQ0xBU1MgPSAnc2t5LW1vZGFsLWJvZHktb3Blbic7XG5cbiAgI2RvY1JlZjogYW55O1xuICAjYm9keUVsOiBIVE1MRWxlbWVudDtcblxuICAjd2luZG93UmVmOiBTa3lBcHBXaW5kb3dSZWY7XG5cbiAgY29uc3RydWN0b3Iod2luZG93UmVmOiBTa3lBcHBXaW5kb3dSZWYpIHtcbiAgICB0aGlzLiN3aW5kb3dSZWYgPSB3aW5kb3dSZWY7XG4gICAgdGhpcy4jZG9jUmVmID0gdGhpcy4jd2luZG93UmVmLm5hdGl2ZVdpbmRvdy5kb2N1bWVudDtcbiAgICB0aGlzLiNib2R5RWwgPSB0aGlzLiN3aW5kb3dSZWYubmF0aXZlV2luZG93LmRvY3VtZW50LmJvZHk7XG4gIH1cblxuICBwdWJsaWMgdG9nZ2xlRnVsbFBhZ2VNb2RhbENsYXNzKGlzQWRkRnVsbDogYm9vbGVhbik6IHZvaWQge1xuICAgIGlmIChpc0FkZEZ1bGwpIHtcbiAgICAgIHRoaXMuI2FkZENsYXNzVG9Cb2R5KFNreU1vZGFsQWRhcHRlclNlcnZpY2UuTU9EQUxfQk9EWV9GVUxMX0NMQVNTKTtcbiAgICB9IGVsc2Uge1xuICAgICAgdGhpcy4jcmVtb3ZlQ2xhc3NGcm9tQm9keShTa3lNb2RhbEFkYXB0ZXJTZXJ2aWNlLk1PREFMX0JPRFlfRlVMTF9DTEFTUyk7XG4gICAgfVxuICB9XG5cbiAgcHVibGljIHNldFBhZ2VTY3JvbGwoaXNBZGQ6IGJvb2xlYW4pOiB2b2lkIHtcbiAgICBpZiAoaXNBZGQpIHtcbiAgICAgIHRoaXMuI2FkZENsYXNzVG9Cb2R5KFNreU1vZGFsQWRhcHRlclNlcnZpY2UuTU9EQUxfQk9EWV9DTEFTUyk7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRoaXMuI3JlbW92ZUNsYXNzRnJvbUJvZHkoU2t5TW9kYWxBZGFwdGVyU2VydmljZS5NT0RBTF9CT0RZX0NMQVNTKTtcbiAgICB9XG4gIH1cblxuICBwdWJsaWMgZ2V0TW9kYWxPcGVuZXIoKTogSFRNTEVsZW1lbnQge1xuICAgIHJldHVybiB0aGlzLiNkb2NSZWYuYWN0aXZlRWxlbWVudDtcbiAgfVxuXG4gICNhZGRDbGFzc1RvQm9keShjbGFzc05hbWU6IHN0cmluZyk6IHZvaWQge1xuICAgIHRoaXMuI2JvZHlFbC5jbGFzc0xpc3QuYWRkKGNsYXNzTmFtZSk7XG4gIH1cblxuICAjcmVtb3ZlQ2xhc3NGcm9tQm9keShjbGFzc05hbWU6IHN0cmluZyk6IHZvaWQge1xuICAgIHRoaXMuI2JvZHlFbC5jbGFzc0xpc3QucmVtb3ZlKGNsYXNzTmFtZSk7XG4gIH1cbn1cbiJdfQ==
@@ -4,4 +4,4 @@
4
4
  */
5
5
  export class SkyModalCloseArgs {
6
6
  }
7
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kYWwtY2xvc2UtYXJncy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9tb2RhbHMvc3JjL2xpYi9tb2R1bGVzL21vZGFsL21vZGFsLWNsb3NlLWFyZ3MudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7OztHQUdHO0FBQ0gsTUFBTSxPQUFPLGlCQUFpQjtDQVU3QiIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29udGFpbnMgYW4gb2JqZWN0IHdpdGggdGhlIGRhdGEgcGFzc2VkIGZyb20gdXNlcnMgd2hlblxuICogYSBtb2RhbCBpcyBjbG9zZWQgYW5kIHRoZSByZWFzb24gdGhhdCB0aGUgbW9kYWwgd2FzIGNsb3NlZC5cbiAqL1xuZXhwb3J0IGNsYXNzIFNreU1vZGFsQ2xvc2VBcmdzIHtcbiAgLyoqXG4gICAqIEluZGljYXRlcyB0aGUgcmVhc29uIHRoZSBtb2RhbCB3YXMgY2xvc2VkLlxuICAgKiBPcHRpb25zIGluY2x1ZGUgYFwiY2xvc2VcImAsIGBcInNhdmVcImAsIGFuZCBgXCJjYW5jZWxcImAuXG4gICAqL1xuICBwdWJsaWMgcmVhc29uOiBzdHJpbmc7XG4gIC8qKlxuICAgKiBUaGUgZGF0YSBwYXNzZWQgZnJvbSB1c2VycyB3aGVuIHRoZSBtb2RhbCBpcyBjbG9zZWQuXG4gICAqL1xuICBwdWJsaWMgZGF0YTogYW55O1xufVxuIl19
7
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kYWwtY2xvc2UtYXJncy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9tb2RhbHMvc3JjL2xpYi9tb2R1bGVzL21vZGFsL21vZGFsLWNsb3NlLWFyZ3MudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7OztHQUdHO0FBQ0gsTUFBTSxPQUFPLGlCQUFpQjtDQVU3QiIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29udGFpbnMgYW4gb2JqZWN0IHdpdGggdGhlIGRhdGEgcGFzc2VkIGZyb20gdXNlcnMgd2hlblxuICogYSBtb2RhbCBpcyBjbG9zZWQgYW5kIHRoZSByZWFzb24gdGhhdCB0aGUgbW9kYWwgd2FzIGNsb3NlZC5cbiAqL1xuZXhwb3J0IGNsYXNzIFNreU1vZGFsQ2xvc2VBcmdzIHtcbiAgLyoqXG4gICAqIEluZGljYXRlcyB0aGUgcmVhc29uIHRoZSBtb2RhbCB3YXMgY2xvc2VkLlxuICAgKiBPcHRpb25zIGluY2x1ZGUgYFwiY2xvc2VcImAsIGBcInNhdmVcImAsIGFuZCBgXCJjYW5jZWxcImAuXG4gICAqL1xuICBwdWJsaWMgcmVhc29uOiBzdHJpbmcgfCB1bmRlZmluZWQ7XG4gIC8qKlxuICAgKiBUaGUgZGF0YSBwYXNzZWQgZnJvbSB1c2VycyB3aGVuIHRoZSBtb2RhbCBpcyBjbG9zZWQuXG4gICAqL1xuICBwdWJsaWMgZGF0YTogYW55O1xufVxuIl19
@@ -1,3 +1,5 @@
1
+ var _SkyModalComponentAdapterService_instances, _SkyModalComponentAdapterService_coreAdapter, _SkyModalComponentAdapterService_setFullPageHeight;
2
+ import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
1
3
  import { Injectable } from '@angular/core';
2
4
  import { SkyCoreAdapterService } from '@skyux/core';
3
5
  import * as i0 from "@angular/core";
@@ -7,7 +9,9 @@ import * as i1 from "@skyux/core";
7
9
  */
8
10
  export class SkyModalComponentAdapterService {
9
11
  constructor(coreAdapter) {
10
- this.coreAdapter = coreAdapter;
12
+ _SkyModalComponentAdapterService_instances.add(this);
13
+ _SkyModalComponentAdapterService_coreAdapter.set(this, void 0);
14
+ __classPrivateFieldSet(this, _SkyModalComponentAdapterService_coreAdapter, coreAdapter, "f");
11
15
  }
12
16
  handleWindowChange(modalEl) {
13
17
  const boundedHeightEl = modalEl.nativeElement.querySelector('.sky-modal');
@@ -18,7 +22,7 @@ export class SkyModalComponentAdapterService {
18
22
  const newHeight = window.innerHeight - 40;
19
23
  boundedHeightEl.style.maxHeight = newHeight.toString() + 'px';
20
24
  if (fullPageModalEl) {
21
- this.setFullPageHeight(fullPageModalEl);
25
+ __classPrivateFieldGet(this, _SkyModalComponentAdapterService_instances, "m", _SkyModalComponentAdapterService_setFullPageHeight).call(this, fullPageModalEl);
22
26
  }
23
27
  else {
24
28
  /*
@@ -78,24 +82,24 @@ export class SkyModalComponentAdapterService {
78
82
  inputWithAutofocus.focus();
79
83
  }
80
84
  else {
81
- this.coreAdapter.getFocusableChildrenAndApplyFocus(modalEl, '.sky-modal-content', true);
85
+ __classPrivateFieldGet(this, _SkyModalComponentAdapterService_coreAdapter, "f").getFocusableChildrenAndApplyFocus(modalEl, '.sky-modal-content', true);
82
86
  }
83
87
  window.scrollTo(currentScrollX, currentScrollY);
84
88
  }
85
89
  }
86
- setFullPageHeight(fullPageModalEl) {
87
- const windowHeight = window.innerHeight;
88
- const fullPageModalStyle = getComputedStyle(fullPageModalEl);
89
- const marginTopBottom = parseInt(fullPageModalStyle.marginTop, 10) +
90
- parseInt(fullPageModalStyle.marginBottom, 10);
91
- const fullPageModalHeight = windowHeight - marginTopBottom + 'px';
92
- fullPageModalEl.style.height = fullPageModalHeight;
93
- fullPageModalEl.style.maxHeight = fullPageModalHeight;
94
- }
95
90
  }
91
+ _SkyModalComponentAdapterService_coreAdapter = new WeakMap(), _SkyModalComponentAdapterService_instances = new WeakSet(), _SkyModalComponentAdapterService_setFullPageHeight = function _SkyModalComponentAdapterService_setFullPageHeight(fullPageModalEl) {
92
+ const windowHeight = window.innerHeight;
93
+ const fullPageModalStyle = getComputedStyle(fullPageModalEl);
94
+ const marginTopBottom = parseInt(fullPageModalStyle.marginTop, 10) +
95
+ parseInt(fullPageModalStyle.marginBottom, 10);
96
+ const fullPageModalHeight = windowHeight - marginTopBottom + 'px';
97
+ fullPageModalEl.style.height = fullPageModalHeight;
98
+ fullPageModalEl.style.maxHeight = fullPageModalHeight;
99
+ };
96
100
  SkyModalComponentAdapterService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyModalComponentAdapterService, deps: [{ token: i1.SkyCoreAdapterService }], target: i0.ɵɵFactoryTarget.Injectable });
97
101
  SkyModalComponentAdapterService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyModalComponentAdapterService });
98
102
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyModalComponentAdapterService, decorators: [{
99
103
  type: Injectable
100
104
  }], ctorParameters: function () { return [{ type: i1.SkyCoreAdapterService }]; } });
101
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal-component-adapter.service.js","sourceRoot":"","sources":["../../../../../../../../libs/components/modals/src/lib/modules/modal/modal-component-adapter.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAc,UAAU,EAAE,MAAM,eAAe,CAAC;AACvD,OAAO,EAAE,qBAAqB,EAAE,MAAM,aAAa,CAAC;;;AAEpD;;GAEG;AAEH,MAAM,OAAO,+BAA+B;IAC1C,YAAoB,WAAkC;QAAlC,gBAAW,GAAX,WAAW,CAAuB;IAAG,CAAC;IAEnD,kBAAkB,CAAC,OAAmB;QAC3C,MAAM,eAAe,GAAG,OAAO,CAAC,aAAa,CAAC,aAAa,CAAC,YAAY,CAAC,CAAC;QAC1E,MAAM,eAAe,GAAG,OAAO,CAAC,aAAa,CAAC,aAAa,CACzD,sBAAsB,CACvB,CAAC;QACF;;UAEE;QACF,MAAM,SAAS,GAAG,MAAM,CAAC,WAAW,GAAG,EAAE,CAAC;QAE1C,eAAe,CAAC,KAAK,CAAC,SAAS,GAAG,SAAS,CAAC,QAAQ,EAAE,GAAG,IAAI,CAAC;QAC9D,IAAI,eAAe,EAAE;YACnB,IAAI,CAAC,iBAAiB,CAAC,eAAe,CAAC,CAAC;SACzC;aAAM;YACL;;;cAGE;YACF,MAAM,cAAc,GAClB,OAAO,CAAC,aAAa,CAAC,aAAa,CAAC,oBAAoB,CAAC,CAAC;YAC5D,MAAM,aAAa,GAAG,SAAS,GAAG,GAAG,CAAC;YACtC,cAAc,CAAC,KAAK,CAAC,SAAS,GAAG,aAAa,CAAC,QAAQ,EAAE,GAAG,IAAI,CAAC;SAClE;IACH,CAAC;IAEM,kBAAkB,CACvB,KAAoB,EACpB,IAAwB;QAExB,0BAA0B;QAC1B,kBAAkB;QAClB,MAAM,WAAW,GAAG,KAAK,CAAC,MAAM,IAAI,KAAK,CAAC,UAAU,CAAC;QACrD,OAAO,IAAI,CAAC,MAAM,GAAG,CAAC,IAAI,WAAW,KAAK,IAAI,CAAC,CAAC,CAAC,CAAC;IACpD,CAAC;IAEM,iBAAiB,CACtB,KAAoB,EACpB,IAAwB;QAExB,0BAA0B;QAC1B,kBAAkB;QAClB,MAAM,WAAW,GAAG,KAAK,CAAC,MAAM,IAAI,KAAK,CAAC,UAAU,CAAC;QACrD,OAAO,IAAI,CAAC,MAAM,GAAG,CAAC,IAAI,WAAW,KAAK,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;IAClE,CAAC;IAEM,cAAc,CAAC,KAAoB,EAAE,OAAmB;QAC7D,0BAA0B;QAC1B,kBAAkB;QAClB,MAAM,WAAW,GAAG,KAAK,CAAC,MAAM,IAAI,KAAK,CAAC,UAAU,CAAC;QACrD,OAAO,CACL,OAAO;YACP,WAAW,KAAK,OAAO,CAAC,aAAa,CAAC,aAAa,CAAC,mBAAmB,CAAC,CACzE,CAAC;IACJ,CAAC;IAEM,gBAAgB,CAAC,IAAwB;QAC9C,IAAI,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE;YACnB,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC;YAC9B,OAAO,IAAI,CAAC;SACb;QACD,OAAO,KAAK,CAAC;IACf,CAAC;IAEM,iBAAiB,CAAC,IAAwB;QAC/C,IAAI,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE;YACnB,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC;YAChB,OAAO,IAAI,CAAC;SACb;QACD,OAAO,KAAK,CAAC;IACf,CAAC;IAEM,oCAAoC,CACzC,cAA0B;QAE1B,OAAO,CAAC,CAAC,cAAc,CAAC,aAAa,CAAC,aAAa,CACjD,2CAA2C,CAC5C,CAAC;IACJ,CAAC;IAEM,WAAW,CAAC,OAAmB;QACpC,0BAA0B;QAC1B,mFAAmF;QACnF,IACE,CAAC,CACC,QAAQ,CAAC,aAAa;YACtB,OAAO,CAAC,aAAa,CAAC,QAAQ,CAAC,QAAQ,CAAC,aAAa,CAAC,CACvD,EACD;YACA,MAAM,cAAc,GAAG,MAAM,CAAC,WAAW,CAAC;YAC1C,MAAM,cAAc,GAAG,MAAM,CAAC,WAAW,CAAC;YAE1C,MAAM,kBAAkB,GACtB,OAAO,CAAC,aAAa,CAAC,aAAa,CAAC,aAAa,CAAC,CAAC;YAErD,IAAI,kBAAkB,EAAE;gBACtB,kBAAkB,CAAC,KAAK,EAAE,CAAC;aAC5B;iBAAM;gBACL,IAAI,CAAC,WAAW,CAAC,iCAAiC,CAChD,OAAO,EACP,oBAAoB,EACpB,IAAI,CACL,CAAC;aACH;YACD,MAAM,CAAC,QAAQ,CAAC,cAAc,EAAE,cAAc,CAAC,CAAC;SACjD;IACH,CAAC;IAEO,iBAAiB,CAAC,eAA4B;QACpD,MAAM,YAAY,GAAG,MAAM,CAAC,WAAW,CAAC;QACxC,MAAM,kBAAkB,GAAG,gBAAgB,CAAC,eAAe,CAAC,CAAC;QAE7D,MAAM,eAAe,GACnB,QAAQ,CAAC,kBAAkB,CAAC,SAAS,EAAE,EAAE,CAAC;YAC1C,QAAQ,CAAC,kBAAkB,CAAC,YAAY,EAAE,EAAE,CAAC,CAAC;QAEhD,MAAM,mBAAmB,GAAG,YAAY,GAAG,eAAe,GAAG,IAAI,CAAC;QAElE,eAAe,CAAC,KAAK,CAAC,MAAM,GAAG,mBAAmB,CAAC;QACnD,eAAe,CAAC,KAAK,CAAC,SAAS,GAAG,mBAAmB,CAAC;IACxD,CAAC;;4HA1HU,+BAA+B;gIAA/B,+BAA+B;2FAA/B,+BAA+B;kBAD3C,UAAU","sourcesContent":["import { ElementRef, Injectable } from '@angular/core';\nimport { SkyCoreAdapterService } from '@skyux/core';\n\n/**\n * @internal\n */\n@Injectable()\nexport class SkyModalComponentAdapterService {\n  constructor(private coreAdapter: SkyCoreAdapterService) {}\n\n  public handleWindowChange(modalEl: ElementRef): void {\n    const boundedHeightEl = modalEl.nativeElement.querySelector('.sky-modal');\n    const fullPageModalEl = modalEl.nativeElement.querySelector(\n      '.sky-modal-full-page'\n    );\n    /*\n      Set modal height equal to max height of window (accounting for padding above and below modal)\n    */\n    const newHeight = window.innerHeight - 40;\n\n    boundedHeightEl.style.maxHeight = newHeight.toString() + 'px';\n    if (fullPageModalEl) {\n      this.setFullPageHeight(fullPageModalEl);\n    } else {\n      /*\n        IE11 doesn't handle flex and max-height correctly so we have to explicitly add\n        max-height to the content that accounts for standard header and footer height.\n      */\n      const modalContentEl =\n        modalEl.nativeElement.querySelector('.sky-modal-content');\n      const contentHeight = newHeight - 114;\n      modalContentEl.style.maxHeight = contentHeight.toString() + 'px';\n    }\n  }\n\n  public isFocusInFirstItem(\n    event: KeyboardEvent,\n    list: Array<HTMLElement>\n  ): boolean {\n    /* istanbul ignore next */\n    /* sanity check */\n    const eventTarget = event.target || event.srcElement;\n    return list.length > 0 && eventTarget === list[0];\n  }\n\n  public isFocusInLastItem(\n    event: KeyboardEvent,\n    list: Array<HTMLElement>\n  ): boolean {\n    /* istanbul ignore next */\n    /* sanity check */\n    const eventTarget = event.target || event.srcElement;\n    return list.length > 0 && eventTarget === list[list.length - 1];\n  }\n\n  public isModalFocused(event: KeyboardEvent, modalEl: ElementRef): boolean {\n    /* istanbul ignore next */\n    /* sanity check */\n    const eventTarget = event.target || event.srcElement;\n    return (\n      modalEl &&\n      eventTarget === modalEl.nativeElement.querySelector('.sky-modal-dialog')\n    );\n  }\n\n  public focusLastElement(list: Array<HTMLElement>): boolean {\n    if (list.length > 0) {\n      list[list.length - 1].focus();\n      return true;\n    }\n    return false;\n  }\n\n  public focusFirstElement(list: Array<HTMLElement>): boolean {\n    if (list.length > 0) {\n      list[0].focus();\n      return true;\n    }\n    return false;\n  }\n\n  public modalContentHasDirectChildViewkeeper(\n    modalContentEl: ElementRef\n  ): boolean {\n    return !!modalContentEl.nativeElement.querySelector(\n      'sky-modal-content > .sky-viewkeeper-fixed'\n    );\n  }\n\n  public modalOpened(modalEl: ElementRef): void {\n    /* istanbul ignore else */\n    /* handle the case where somehow there is a focused element already in the modal */\n    if (\n      !(\n        document.activeElement &&\n        modalEl.nativeElement.contains(document.activeElement)\n      )\n    ) {\n      const currentScrollX = window.pageXOffset;\n      const currentScrollY = window.pageYOffset;\n\n      const inputWithAutofocus =\n        modalEl.nativeElement.querySelector('[autofocus]');\n\n      if (inputWithAutofocus) {\n        inputWithAutofocus.focus();\n      } else {\n        this.coreAdapter.getFocusableChildrenAndApplyFocus(\n          modalEl,\n          '.sky-modal-content',\n          true\n        );\n      }\n      window.scrollTo(currentScrollX, currentScrollY);\n    }\n  }\n\n  private setFullPageHeight(fullPageModalEl: HTMLElement): void {\n    const windowHeight = window.innerHeight;\n    const fullPageModalStyle = getComputedStyle(fullPageModalEl);\n\n    const marginTopBottom =\n      parseInt(fullPageModalStyle.marginTop, 10) +\n      parseInt(fullPageModalStyle.marginBottom, 10);\n\n    const fullPageModalHeight = windowHeight - marginTopBottom + 'px';\n\n    fullPageModalEl.style.height = fullPageModalHeight;\n    fullPageModalEl.style.maxHeight = fullPageModalHeight;\n  }\n}\n"]}
105
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal-component-adapter.service.js","sourceRoot":"","sources":["../../../../../../../../libs/components/modals/src/lib/modules/modal/modal-component-adapter.service.ts"],"names":[],"mappings":";;AAAA,OAAO,EAAc,UAAU,EAAE,MAAM,eAAe,CAAC;AACvD,OAAO,EAAE,qBAAqB,EAAE,MAAM,aAAa,CAAC;;;AAEpD;;GAEG;AAEH,MAAM,OAAO,+BAA+B;IAG1C,YAAY,WAAkC;;QAF9C,+DAAoC;QAGlC,uBAAA,IAAI,gDAAgB,WAAW,MAAA,CAAC;IAClC,CAAC;IAEM,kBAAkB,CAAC,OAAmB;QAC3C,MAAM,eAAe,GAAG,OAAO,CAAC,aAAa,CAAC,aAAa,CAAC,YAAY,CAAC,CAAC;QAC1E,MAAM,eAAe,GAAG,OAAO,CAAC,aAAa,CAAC,aAAa,CACzD,sBAAsB,CACvB,CAAC;QACF;;UAEE;QACF,MAAM,SAAS,GAAG,MAAM,CAAC,WAAW,GAAG,EAAE,CAAC;QAE1C,eAAe,CAAC,KAAK,CAAC,SAAS,GAAG,SAAS,CAAC,QAAQ,EAAE,GAAG,IAAI,CAAC;QAC9D,IAAI,eAAe,EAAE;YACnB,uBAAA,IAAI,sGAAmB,MAAvB,IAAI,EAAoB,eAAe,CAAC,CAAC;SAC1C;aAAM;YACL;;;cAGE;YACF,MAAM,cAAc,GAClB,OAAO,CAAC,aAAa,CAAC,aAAa,CAAC,oBAAoB,CAAC,CAAC;YAC5D,MAAM,aAAa,GAAG,SAAS,GAAG,GAAG,CAAC;YACtC,cAAc,CAAC,KAAK,CAAC,SAAS,GAAG,aAAa,CAAC,QAAQ,EAAE,GAAG,IAAI,CAAC;SAClE;IACH,CAAC;IAEM,kBAAkB,CACvB,KAAoB,EACpB,IAAwB;QAExB,0BAA0B;QAC1B,kBAAkB;QAClB,MAAM,WAAW,GAAG,KAAK,CAAC,MAAM,IAAI,KAAK,CAAC,UAAU,CAAC;QACrD,OAAO,IAAI,CAAC,MAAM,GAAG,CAAC,IAAI,WAAW,KAAK,IAAI,CAAC,CAAC,CAAC,CAAC;IACpD,CAAC;IAEM,iBAAiB,CACtB,KAAoB,EACpB,IAAwB;QAExB,0BAA0B;QAC1B,kBAAkB;QAClB,MAAM,WAAW,GAAG,KAAK,CAAC,MAAM,IAAI,KAAK,CAAC,UAAU,CAAC;QACrD,OAAO,IAAI,CAAC,MAAM,GAAG,CAAC,IAAI,WAAW,KAAK,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;IAClE,CAAC;IAEM,cAAc,CAAC,KAAoB,EAAE,OAAmB;QAC7D,0BAA0B;QAC1B,kBAAkB;QAClB,MAAM,WAAW,GAAG,KAAK,CAAC,MAAM,IAAI,KAAK,CAAC,UAAU,CAAC;QACrD,OAAO,CACL,OAAO;YACP,WAAW,KAAK,OAAO,CAAC,aAAa,CAAC,aAAa,CAAC,mBAAmB,CAAC,CACzE,CAAC;IACJ,CAAC;IAEM,gBAAgB,CAAC,IAAwB;QAC9C,IAAI,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE;YACnB,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC;YAC9B,OAAO,IAAI,CAAC;SACb;QACD,OAAO,KAAK,CAAC;IACf,CAAC;IAEM,iBAAiB,CAAC,IAAwB;QAC/C,IAAI,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE;YACnB,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC;YAChB,OAAO,IAAI,CAAC;SACb;QACD,OAAO,KAAK,CAAC;IACf,CAAC;IAEM,oCAAoC,CACzC,cAA0B;QAE1B,OAAO,CAAC,CAAC,cAAc,CAAC,aAAa,CAAC,aAAa,CACjD,2CAA2C,CAC5C,CAAC;IACJ,CAAC;IAEM,WAAW,CAAC,OAAmB;QACpC,0BAA0B;QAC1B,mFAAmF;QACnF,IACE,CAAC,CACC,QAAQ,CAAC,aAAa;YACtB,OAAO,CAAC,aAAa,CAAC,QAAQ,CAAC,QAAQ,CAAC,aAAa,CAAC,CACvD,EACD;YACA,MAAM,cAAc,GAAG,MAAM,CAAC,WAAW,CAAC;YAC1C,MAAM,cAAc,GAAG,MAAM,CAAC,WAAW,CAAC;YAE1C,MAAM,kBAAkB,GACtB,OAAO,CAAC,aAAa,CAAC,aAAa,CAAC,aAAa,CAAC,CAAC;YAErD,IAAI,kBAAkB,EAAE;gBACtB,kBAAkB,CAAC,KAAK,EAAE,CAAC;aAC5B;iBAAM;gBACL,uBAAA,IAAI,oDAAa,CAAC,iCAAiC,CACjD,OAAO,EACP,oBAAoB,EACpB,IAAI,CACL,CAAC;aACH;YACD,MAAM,CAAC,QAAQ,CAAC,cAAc,EAAE,cAAc,CAAC,CAAC;SACjD;IACH,CAAC;;2OAEkB,eAA4B;IAC7C,MAAM,YAAY,GAAG,MAAM,CAAC,WAAW,CAAC;IACxC,MAAM,kBAAkB,GAAG,gBAAgB,CAAC,eAAe,CAAC,CAAC;IAE7D,MAAM,eAAe,GACnB,QAAQ,CAAC,kBAAkB,CAAC,SAAS,EAAE,EAAE,CAAC;QAC1C,QAAQ,CAAC,kBAAkB,CAAC,YAAY,EAAE,EAAE,CAAC,CAAC;IAEhD,MAAM,mBAAmB,GAAG,YAAY,GAAG,eAAe,GAAG,IAAI,CAAC;IAElE,eAAe,CAAC,KAAK,CAAC,MAAM,GAAG,mBAAmB,CAAC;IACnD,eAAe,CAAC,KAAK,CAAC,SAAS,GAAG,mBAAmB,CAAC;AACxD,CAAC;4HA9HU,+BAA+B;gIAA/B,+BAA+B;2FAA/B,+BAA+B;kBAD3C,UAAU","sourcesContent":["import { ElementRef, Injectable } from '@angular/core';\nimport { SkyCoreAdapterService } from '@skyux/core';\n\n/**\n * @internal\n */\n@Injectable()\nexport class SkyModalComponentAdapterService {\n  #coreAdapter: SkyCoreAdapterService;\n\n  constructor(coreAdapter: SkyCoreAdapterService) {\n    this.#coreAdapter = coreAdapter;\n  }\n\n  public handleWindowChange(modalEl: ElementRef): void {\n    const boundedHeightEl = modalEl.nativeElement.querySelector('.sky-modal');\n    const fullPageModalEl = modalEl.nativeElement.querySelector(\n      '.sky-modal-full-page'\n    );\n    /*\n      Set modal height equal to max height of window (accounting for padding above and below modal)\n    */\n    const newHeight = window.innerHeight - 40;\n\n    boundedHeightEl.style.maxHeight = newHeight.toString() + 'px';\n    if (fullPageModalEl) {\n      this.#setFullPageHeight(fullPageModalEl);\n    } else {\n      /*\n        IE11 doesn't handle flex and max-height correctly so we have to explicitly add\n        max-height to the content that accounts for standard header and footer height.\n      */\n      const modalContentEl =\n        modalEl.nativeElement.querySelector('.sky-modal-content');\n      const contentHeight = newHeight - 114;\n      modalContentEl.style.maxHeight = contentHeight.toString() + 'px';\n    }\n  }\n\n  public isFocusInFirstItem(\n    event: KeyboardEvent,\n    list: Array<HTMLElement>\n  ): boolean {\n    /* istanbul ignore next */\n    /* sanity check */\n    const eventTarget = event.target || event.srcElement;\n    return list.length > 0 && eventTarget === list[0];\n  }\n\n  public isFocusInLastItem(\n    event: KeyboardEvent,\n    list: Array<HTMLElement>\n  ): boolean {\n    /* istanbul ignore next */\n    /* sanity check */\n    const eventTarget = event.target || event.srcElement;\n    return list.length > 0 && eventTarget === list[list.length - 1];\n  }\n\n  public isModalFocused(event: KeyboardEvent, modalEl: ElementRef): boolean {\n    /* istanbul ignore next */\n    /* sanity check */\n    const eventTarget = event.target || event.srcElement;\n    return (\n      modalEl &&\n      eventTarget === modalEl.nativeElement.querySelector('.sky-modal-dialog')\n    );\n  }\n\n  public focusLastElement(list: Array<HTMLElement>): boolean {\n    if (list.length > 0) {\n      list[list.length - 1].focus();\n      return true;\n    }\n    return false;\n  }\n\n  public focusFirstElement(list: Array<HTMLElement>): boolean {\n    if (list.length > 0) {\n      list[0].focus();\n      return true;\n    }\n    return false;\n  }\n\n  public modalContentHasDirectChildViewkeeper(\n    modalContentEl: ElementRef\n  ): boolean {\n    return !!modalContentEl.nativeElement.querySelector(\n      'sky-modal-content > .sky-viewkeeper-fixed'\n    );\n  }\n\n  public modalOpened(modalEl: ElementRef): void {\n    /* istanbul ignore else */\n    /* handle the case where somehow there is a focused element already in the modal */\n    if (\n      !(\n        document.activeElement &&\n        modalEl.nativeElement.contains(document.activeElement)\n      )\n    ) {\n      const currentScrollX = window.pageXOffset;\n      const currentScrollY = window.pageYOffset;\n\n      const inputWithAutofocus =\n        modalEl.nativeElement.querySelector('[autofocus]');\n\n      if (inputWithAutofocus) {\n        inputWithAutofocus.focus();\n      } else {\n        this.#coreAdapter.getFocusableChildrenAndApplyFocus(\n          modalEl,\n          '.sky-modal-content',\n          true\n        );\n      }\n      window.scrollTo(currentScrollX, currentScrollY);\n    }\n  }\n\n  #setFullPageHeight(fullPageModalEl: HTMLElement): void {\n    const windowHeight = window.innerHeight;\n    const fullPageModalStyle = getComputedStyle(fullPageModalEl);\n\n    const marginTopBottom =\n      parseInt(fullPageModalStyle.marginTop, 10) +\n      parseInt(fullPageModalStyle.marginBottom, 10);\n\n    const fullPageModalHeight = windowHeight - marginTopBottom + 'px';\n\n    fullPageModalEl.style.height = fullPageModalHeight;\n    fullPageModalEl.style.maxHeight = fullPageModalHeight;\n  }\n}\n"]}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kYWwtaG9zdC1jb250ZXh0LWFyZ3MuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvbW9kYWxzL3NyYy9saWIvbW9kdWxlcy9tb2RhbC9tb2RhbC1ob3N0LWNvbnRleHQtYXJncy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBBZGRpdGlvbmFsIGNvbnRleHQgYW5kIGZlYXR1cmVzIGZvciB0aGUgbW9kYWwgaG9zdCBjb21wb25lbnQuXG4gKiBAaW50ZXJuYWxcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBTa3lNb2RhbEhvc3RDb250ZXh0QXJncyB7XG4gIHRlYXJkb3duQ2FsbGJhY2s6ICgpID0+IHZvaWQ7XG59XG4iXX0=
@@ -1,4 +1,4 @@
1
- import { Injectable } from '@angular/core';
1
+ import { Inject, Injectable } from '@angular/core';
2
2
  import * as i0 from "@angular/core";
3
3
  /**
4
4
  * Provided by the modal service to give the modal host
@@ -6,13 +6,16 @@ import * as i0 from "@angular/core";
6
6
  * @internal
7
7
  */
8
8
  export class SkyModalHostContext {
9
- constructor(teardownCallback) {
10
- this.teardownCallback = teardownCallback;
9
+ constructor(args) {
10
+ this.args = args;
11
11
  }
12
12
  }
13
- SkyModalHostContext.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyModalHostContext, deps: "invalid", target: i0.ɵɵFactoryTarget.Injectable });
13
+ SkyModalHostContext.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyModalHostContext, deps: [{ token: 'SkyModalHostContextArgs' }], target: i0.ɵɵFactoryTarget.Injectable });
14
14
  SkyModalHostContext.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyModalHostContext });
15
15
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyModalHostContext, decorators: [{
16
16
  type: Injectable
17
- }], ctorParameters: function () { return [{ type: undefined }]; } });
18
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kYWwtaG9zdC1jb250ZXh0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL21vZGFscy9zcmMvbGliL21vZHVsZXMvbW9kYWwvbW9kYWwtaG9zdC1jb250ZXh0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBRTNDOzs7O0dBSUc7QUFFSCxNQUFNLE9BQU8sbUJBQW1CO0lBQzlCLFlBQW1CLGdCQUE0QjtRQUE1QixxQkFBZ0IsR0FBaEIsZ0JBQWdCLENBQVk7SUFBRyxDQUFDOztnSEFEeEMsbUJBQW1CO29IQUFuQixtQkFBbUI7MkZBQW5CLG1CQUFtQjtrQkFEL0IsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuLyoqXG4gKiBQcm92aWRlZCBieSB0aGUgbW9kYWwgc2VydmljZSB0byBnaXZlIHRoZSBtb2RhbCBob3N0XG4gKiBjb21wb25lbnQgYWRkaXRpb25hbCBjb250ZXh0IGFuZCBmZWF0dXJlcy5cbiAqIEBpbnRlcm5hbFxuICovXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgU2t5TW9kYWxIb3N0Q29udGV4dCB7XG4gIGNvbnN0cnVjdG9yKHB1YmxpYyB0ZWFyZG93bkNhbGxiYWNrOiAoKSA9PiB2b2lkKSB7fVxufVxuIl19
17
+ }], ctorParameters: function () { return [{ type: undefined, decorators: [{
18
+ type: Inject,
19
+ args: ['SkyModalHostContextArgs']
20
+ }] }]; } });
21
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kYWwtaG9zdC1jb250ZXh0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL21vZGFscy9zcmMvbGliL21vZHVsZXMvbW9kYWwvbW9kYWwtaG9zdC1jb250ZXh0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxNQUFNLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUluRDs7OztHQUlHO0FBRUgsTUFBTSxPQUFPLG1CQUFtQjtJQUM5QixZQUM0QyxJQUE2QjtRQUE3QixTQUFJLEdBQUosSUFBSSxDQUF5QjtJQUN0RSxDQUFDOztnSEFITyxtQkFBbUIsa0JBRXBCLHlCQUF5QjtvSEFGeEIsbUJBQW1COzJGQUFuQixtQkFBbUI7a0JBRC9CLFVBQVU7OzBCQUdOLE1BQU07MkJBQUMseUJBQXlCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0LCBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IFNreU1vZGFsSG9zdENvbnRleHRBcmdzIH0gZnJvbSAnLi9tb2RhbC1ob3N0LWNvbnRleHQtYXJncyc7XG5cbi8qKlxuICogUHJvdmlkZWQgYnkgdGhlIG1vZGFsIHNlcnZpY2UgdG8gZ2l2ZSB0aGUgbW9kYWwgaG9zdFxuICogY29tcG9uZW50IGFkZGl0aW9uYWwgY29udGV4dCBhbmQgZmVhdHVyZXMuXG4gKiBAaW50ZXJuYWxcbiAqL1xuQEluamVjdGFibGUoKVxuZXhwb3J0IGNsYXNzIFNreU1vZGFsSG9zdENvbnRleHQge1xuICBjb25zdHJ1Y3RvcihcbiAgICBASW5qZWN0KCdTa3lNb2RhbEhvc3RDb250ZXh0QXJncycpIHB1YmxpYyBhcmdzOiBTa3lNb2RhbEhvc3RDb250ZXh0QXJnc1xuICApIHt9XG59XG4iXX0=