@skyux/modals 6.14.0 → 6.17.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.
- package/documentation.json +341 -568
- package/esm2020/lib/modules/confirm/confirm-config-token.mjs +6 -0
- package/esm2020/lib/modules/confirm/confirm.component.mjs +103 -97
- package/esm2020/lib/modules/confirm/confirm.service.mjs +9 -5
- package/esm2020/lib/modules/modal/modal-adapter.service.mjs +20 -15
- package/esm2020/lib/modules/modal/modal-close-args.mjs +1 -1
- package/esm2020/lib/modules/modal/modal-component-adapter.service.mjs +17 -13
- package/esm2020/lib/modules/modal/modal-host.component.mjs +26 -13
- package/esm2020/lib/modules/modal/modal-host.service.mjs +27 -20
- package/esm2020/lib/modules/modal/modal-instance.mjs +31 -29
- package/esm2020/lib/modules/modal/modal-scroll-shadow.directive.mjs +71 -65
- package/esm2020/lib/modules/modal/modal.component.mjs +61 -74
- package/esm2020/lib/modules/modal/modal.service.mjs +51 -45
- package/esm2020/testing/modal-fixture.mjs +61 -84
- package/fesm2015/skyux-modals-testing.mjs +61 -83
- package/fesm2015/skyux-modals-testing.mjs.map +1 -1
- package/fesm2015/skyux-modals.mjs +395 -370
- package/fesm2015/skyux-modals.mjs.map +1 -1
- package/fesm2020/skyux-modals-testing.mjs +61 -83
- package/fesm2020/skyux-modals-testing.mjs.map +1 -1
- package/fesm2020/skyux-modals.mjs +394 -370
- package/fesm2020/skyux-modals.mjs.map +1 -1
- package/lib/modules/confirm/confirm-config-token.d.ts +6 -0
- package/lib/modules/confirm/confirm.component.d.ts +6 -12
- package/lib/modules/confirm/confirm.service.d.ts +1 -1
- package/lib/modules/modal/modal-adapter.service.d.ts +1 -5
- package/lib/modules/modal/modal-close-args.d.ts +1 -1
- package/lib/modules/modal/modal-component-adapter.service.d.ts +1 -2
- package/lib/modules/modal/modal-host.component.d.ts +1 -6
- package/lib/modules/modal/modal-host.service.d.ts +6 -6
- package/lib/modules/modal/modal-instance.d.ts +2 -6
- package/lib/modules/modal/modal-scroll-shadow.directive.d.ts +1 -13
- package/lib/modules/modal/modal.component.d.ts +12 -23
- package/lib/modules/modal/modal.service.d.ts +1 -3
- package/package.json +5 -6
- package/testing/modal-fixture.d.ts +7 -8
- package/esm2020/lib/modules/confirm/confirm-modal-context.mjs +0 -6
- package/esm2020/lib/modules/modal/modal-state-animation.mjs +0 -8
- package/lib/modules/confirm/confirm-modal-context.d.ts +0 -13
- package/lib/modules/modal/modal-state-animation.d.ts +0 -1
|
@@ -1,9 +1,10 @@
|
|
|
1
|
+
var _SkyModalComponent_hostService, _SkyModalComponent_elRef, _SkyModalComponent_windowRef, _SkyModalComponent_componentAdapter, _SkyModalComponent_coreAdapter, _SkyModalComponent_dockService, _SkyModalComponent_mediaQueryService, _SkyModalComponent__ariaRole;
|
|
2
|
+
import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
|
|
1
3
|
import { Component, ElementRef, Host, HostBinding, HostListener, Input, Optional, ViewChild, } from '@angular/core';
|
|
2
4
|
import { SkyAppWindowRef, SkyCoreAdapterService, SkyDockLocation, SkyDockService, SkyResizeObserverMediaQueryService, } from '@skyux/core';
|
|
3
5
|
import { SkyModalComponentAdapterService } from './modal-component-adapter.service';
|
|
4
6
|
import { SkyModalConfiguration } from './modal-configuration';
|
|
5
7
|
import { SkyModalHostService } from './modal-host.service';
|
|
6
|
-
import { skyAnimationModalState } from './modal-state-animation';
|
|
7
8
|
import * as i0 from "@angular/core";
|
|
8
9
|
import * as i1 from "./modal-host.service";
|
|
9
10
|
import * as i2 from "./modal-configuration";
|
|
@@ -14,6 +15,7 @@ import * as i6 from "@angular/common";
|
|
|
14
15
|
import * as i7 from "./modal-scroll-shadow.directive";
|
|
15
16
|
import * as i8 from "@skyux/i18n";
|
|
16
17
|
let skyModalUniqueIdentifier = 0;
|
|
18
|
+
const ARIA_ROLE_DEFAULT = 'dialog';
|
|
17
19
|
/**
|
|
18
20
|
* Provides a common look-and-feel for modal content with options to display
|
|
19
21
|
* a common modal header, specify body content, and display a common modal footer
|
|
@@ -21,69 +23,54 @@ let skyModalUniqueIdentifier = 0;
|
|
|
21
23
|
*/
|
|
22
24
|
export class SkyModalComponent {
|
|
23
25
|
constructor(hostService, config, elRef, windowRef, componentAdapter, coreAdapter, dockService, mediaQueryService) {
|
|
24
|
-
this.
|
|
25
|
-
this.config = config;
|
|
26
|
-
this.elRef = elRef;
|
|
27
|
-
this.windowRef = windowRef;
|
|
28
|
-
this.componentAdapter = componentAdapter;
|
|
29
|
-
this.coreAdapter = coreAdapter;
|
|
30
|
-
this.dockService = dockService;
|
|
31
|
-
this.mediaQueryService = mediaQueryService;
|
|
26
|
+
this.ariaRoleOrDefault = ARIA_ROLE_DEFAULT;
|
|
32
27
|
this.modalState = 'in';
|
|
33
28
|
this.modalContentId = 'sky-modal-content-id-' + skyModalUniqueIdentifier.toString();
|
|
34
29
|
this.modalHeaderId = 'sky-modal-header-id-' + skyModalUniqueIdentifier.toString();
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
30
|
+
_SkyModalComponent_hostService.set(this, void 0);
|
|
31
|
+
_SkyModalComponent_elRef.set(this, void 0);
|
|
32
|
+
_SkyModalComponent_windowRef.set(this, void 0);
|
|
33
|
+
_SkyModalComponent_componentAdapter.set(this, void 0);
|
|
34
|
+
_SkyModalComponent_coreAdapter.set(this, void 0);
|
|
35
|
+
_SkyModalComponent_dockService.set(this, void 0);
|
|
36
|
+
_SkyModalComponent_mediaQueryService.set(this, void 0);
|
|
37
|
+
_SkyModalComponent__ariaRole.set(this, void 0);
|
|
38
|
+
__classPrivateFieldSet(this, _SkyModalComponent_hostService, hostService, "f");
|
|
39
|
+
__classPrivateFieldSet(this, _SkyModalComponent_elRef, elRef, "f");
|
|
40
|
+
__classPrivateFieldSet(this, _SkyModalComponent_windowRef, windowRef, "f");
|
|
41
|
+
__classPrivateFieldSet(this, _SkyModalComponent_componentAdapter, componentAdapter, "f");
|
|
42
|
+
__classPrivateFieldSet(this, _SkyModalComponent_coreAdapter, coreAdapter, "f");
|
|
43
|
+
__classPrivateFieldSet(this, _SkyModalComponent_dockService, dockService, "f");
|
|
44
|
+
__classPrivateFieldSet(this, _SkyModalComponent_mediaQueryService, mediaQueryService, "f");
|
|
45
|
+
this.ariaDescribedBy = config.ariaDescribedBy || this.modalContentId;
|
|
46
|
+
this.ariaLabelledBy = config.ariaLabelledBy || this.modalHeaderId;
|
|
47
|
+
this.ariaRole = config.ariaRole;
|
|
48
|
+
this.helpKey = config.helpKey;
|
|
49
|
+
this.tiledBody = config.tiledBody;
|
|
50
|
+
this.wrapperClass = config.wrapperClass;
|
|
51
|
+
this.size = config.fullPage
|
|
52
|
+
? 'full-page'
|
|
53
|
+
: config.size?.toLowerCase() || 'medium';
|
|
54
|
+
this.modalZIndex = __classPrivateFieldGet(this, _SkyModalComponent_hostService, "f").zIndex;
|
|
55
|
+
}
|
|
56
|
+
// 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.
|
|
57
|
+
// istanbul ignore next
|
|
39
58
|
/**
|
|
40
59
|
* @internal
|
|
41
60
|
*/
|
|
42
61
|
get ariaRole() {
|
|
43
|
-
return this
|
|
62
|
+
return __classPrivateFieldGet(this, _SkyModalComponent__ariaRole, "f");
|
|
44
63
|
}
|
|
45
64
|
set ariaRole(value) {
|
|
46
|
-
this
|
|
47
|
-
|
|
48
|
-
/**
|
|
49
|
-
* @internal
|
|
50
|
-
*/
|
|
51
|
-
set tiledBody(value) {
|
|
52
|
-
this.config.tiledBody = value;
|
|
53
|
-
}
|
|
54
|
-
get modalZIndex() {
|
|
55
|
-
return this.hostService.getModalZIndex();
|
|
56
|
-
}
|
|
57
|
-
get modalFullPage() {
|
|
58
|
-
return this.config.fullPage;
|
|
59
|
-
}
|
|
60
|
-
get isSmallSize() {
|
|
61
|
-
return !this.modalFullPage && this.isSizeEqual(this.config.size, 'small');
|
|
62
|
-
}
|
|
63
|
-
get isMediumSize() {
|
|
64
|
-
return !this.modalFullPage && !(this.isSmallSize || this.isLargeSize);
|
|
65
|
-
}
|
|
66
|
-
get isLargeSize() {
|
|
67
|
-
return !this.modalFullPage && this.isSizeEqual(this.config.size, 'large');
|
|
68
|
-
}
|
|
69
|
-
get isTiledBody() {
|
|
70
|
-
return this.config.tiledBody;
|
|
71
|
-
}
|
|
72
|
-
get ariaDescribedBy() {
|
|
73
|
-
return this.config.ariaDescribedBy || this.modalContentId;
|
|
74
|
-
}
|
|
75
|
-
get ariaLabelledBy() {
|
|
76
|
-
return this.config.ariaLabelledBy || this.modalHeaderId;
|
|
77
|
-
}
|
|
78
|
-
get helpKey() {
|
|
79
|
-
return this.config.helpKey;
|
|
65
|
+
__classPrivateFieldSet(this, _SkyModalComponent__ariaRole, value, "f");
|
|
66
|
+
this.ariaRoleOrDefault = value || ARIA_ROLE_DEFAULT;
|
|
80
67
|
}
|
|
81
68
|
onDocumentKeyUp(event) {
|
|
82
69
|
/* istanbul ignore else */
|
|
83
70
|
/* sanity check */
|
|
84
71
|
if (SkyModalHostService.openModalCount > 0) {
|
|
85
72
|
const topModal = SkyModalHostService.topModal;
|
|
86
|
-
if (topModal && topModal === this
|
|
73
|
+
if (topModal && topModal === __classPrivateFieldGet(this, _SkyModalComponent_hostService, "f")) {
|
|
87
74
|
if (event.which === 27) {
|
|
88
75
|
// Escape key up
|
|
89
76
|
event.preventDefault();
|
|
@@ -97,21 +84,21 @@ export class SkyModalComponent {
|
|
|
97
84
|
/* sanity check */
|
|
98
85
|
if (SkyModalHostService.openModalCount > 0) {
|
|
99
86
|
const topModal = SkyModalHostService.topModal;
|
|
100
|
-
if (topModal && topModal === this
|
|
87
|
+
if (topModal && topModal === __classPrivateFieldGet(this, _SkyModalComponent_hostService, "f")) {
|
|
101
88
|
if (event.which === 9) {
|
|
102
89
|
// Tab pressed
|
|
103
90
|
let focusChanged = false;
|
|
104
|
-
const focusElementList = this.
|
|
91
|
+
const focusElementList = __classPrivateFieldGet(this, _SkyModalComponent_coreAdapter, "f").getFocusableChildren(__classPrivateFieldGet(this, _SkyModalComponent_elRef, "f").nativeElement);
|
|
105
92
|
if (event.shiftKey &&
|
|
106
|
-
(this.
|
|
107
|
-
this.
|
|
93
|
+
(__classPrivateFieldGet(this, _SkyModalComponent_componentAdapter, "f").isFocusInFirstItem(event, focusElementList) ||
|
|
94
|
+
__classPrivateFieldGet(this, _SkyModalComponent_componentAdapter, "f").isModalFocused(event, __classPrivateFieldGet(this, _SkyModalComponent_elRef, "f")))) {
|
|
108
95
|
focusChanged =
|
|
109
|
-
this.
|
|
96
|
+
__classPrivateFieldGet(this, _SkyModalComponent_componentAdapter, "f").focusLastElement(focusElementList);
|
|
110
97
|
}
|
|
111
98
|
else if (!event.shiftKey &&
|
|
112
|
-
this.
|
|
99
|
+
__classPrivateFieldGet(this, _SkyModalComponent_componentAdapter, "f").isFocusInLastItem(event, focusElementList)) {
|
|
113
100
|
focusChanged =
|
|
114
|
-
this.
|
|
101
|
+
__classPrivateFieldGet(this, _SkyModalComponent_componentAdapter, "f").focusFirstElement(focusElementList);
|
|
115
102
|
}
|
|
116
103
|
if (focusChanged) {
|
|
117
104
|
event.preventDefault();
|
|
@@ -123,52 +110,52 @@ export class SkyModalComponent {
|
|
|
123
110
|
}
|
|
124
111
|
ngAfterViewInit() {
|
|
125
112
|
skyModalUniqueIdentifier++;
|
|
126
|
-
this.
|
|
113
|
+
__classPrivateFieldGet(this, _SkyModalComponent_componentAdapter, "f").handleWindowChange(__classPrivateFieldGet(this, _SkyModalComponent_elRef, "f"));
|
|
127
114
|
// Adding a timeout to avoid ExpressionChangedAfterItHasBeenCheckedError.
|
|
128
115
|
// https://stackoverflow.com/questions/40562845
|
|
129
|
-
this.
|
|
130
|
-
this.
|
|
116
|
+
__classPrivateFieldGet(this, _SkyModalComponent_windowRef, "f").nativeWindow.setTimeout(() => {
|
|
117
|
+
__classPrivateFieldGet(this, _SkyModalComponent_componentAdapter, "f").modalOpened(__classPrivateFieldGet(this, _SkyModalComponent_elRef, "f"));
|
|
131
118
|
});
|
|
132
|
-
this.
|
|
119
|
+
__classPrivateFieldGet(this, _SkyModalComponent_dockService, "f").setDockOptions({
|
|
133
120
|
location: SkyDockLocation.ElementBottom,
|
|
134
121
|
referenceEl: this.modalContentWrapperElement.nativeElement,
|
|
135
122
|
zIndex: 5,
|
|
136
123
|
});
|
|
137
124
|
/* istanbul ignore next */
|
|
138
|
-
if (this
|
|
139
|
-
this.
|
|
125
|
+
if (__classPrivateFieldGet(this, _SkyModalComponent_mediaQueryService, "f")) {
|
|
126
|
+
__classPrivateFieldGet(this, _SkyModalComponent_mediaQueryService, "f").observe(this.modalContentWrapperElement);
|
|
140
127
|
}
|
|
141
128
|
}
|
|
142
129
|
ngOnDestroy() {
|
|
143
130
|
/* istanbul ignore next */
|
|
144
|
-
if (this
|
|
145
|
-
this.
|
|
131
|
+
if (__classPrivateFieldGet(this, _SkyModalComponent_mediaQueryService, "f")) {
|
|
132
|
+
__classPrivateFieldGet(this, _SkyModalComponent_mediaQueryService, "f").unobserve();
|
|
146
133
|
}
|
|
147
134
|
}
|
|
148
135
|
helpButtonClick() {
|
|
149
|
-
|
|
136
|
+
if (this.helpKey) {
|
|
137
|
+
__classPrivateFieldGet(this, _SkyModalComponent_hostService, "f").onOpenHelp(this.helpKey);
|
|
138
|
+
}
|
|
150
139
|
}
|
|
151
140
|
closeButtonClick() {
|
|
152
|
-
this.
|
|
141
|
+
__classPrivateFieldGet(this, _SkyModalComponent_hostService, "f").onClose();
|
|
153
142
|
}
|
|
154
143
|
windowResize() {
|
|
155
|
-
this.
|
|
144
|
+
__classPrivateFieldGet(this, _SkyModalComponent_componentAdapter, "f").handleWindowChange(__classPrivateFieldGet(this, _SkyModalComponent_elRef, "f"));
|
|
156
145
|
}
|
|
157
146
|
scrollShadowChange(args) {
|
|
158
147
|
this.scrollShadow = args;
|
|
159
148
|
}
|
|
160
149
|
viewkeeperEnabled() {
|
|
161
|
-
return this.
|
|
162
|
-
}
|
|
163
|
-
isSizeEqual(actualSize, size) {
|
|
164
|
-
return actualSize && actualSize.toLowerCase() === size;
|
|
150
|
+
return __classPrivateFieldGet(this, _SkyModalComponent_componentAdapter, "f").modalContentHasDirectChildViewkeeper(__classPrivateFieldGet(this, _SkyModalComponent_elRef, "f"));
|
|
165
151
|
}
|
|
166
152
|
}
|
|
153
|
+
_SkyModalComponent_hostService = new WeakMap(), _SkyModalComponent_elRef = new WeakMap(), _SkyModalComponent_windowRef = new WeakMap(), _SkyModalComponent_componentAdapter = new WeakMap(), _SkyModalComponent_coreAdapter = new WeakMap(), _SkyModalComponent_dockService = new WeakMap(), _SkyModalComponent_mediaQueryService = new WeakMap(), _SkyModalComponent__ariaRole = new WeakMap();
|
|
167
154
|
SkyModalComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyModalComponent, deps: [{ token: i1.SkyModalHostService }, { token: i2.SkyModalConfiguration }, { token: i0.ElementRef }, { token: i3.SkyAppWindowRef }, { token: i4.SkyModalComponentAdapterService }, { token: i3.SkyCoreAdapterService }, { token: i3.SkyDockService, host: true }, { token: i3.SkyResizeObserverMediaQueryService, optional: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
168
|
-
SkyModalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.2", type: SkyModalComponent, selector: "sky-modal", inputs: { ariaRole: "ariaRole", tiledBody: "tiledBody" }, host: { listeners: { "document:keyup": "onDocumentKeyUp($event)", "document:keydown": "onDocumentKeyDown($event)" }, properties: { "class": "this.wrapperClass" } }, providers: [SkyModalComponentAdapterService, SkyDockService], viewQueries: [{ propertyName: "modalContentWrapperElement", first: true, predicate: ["modalContentWrapper"], descendants: true, read: ElementRef }], ngImport: i0, template: "
|
|
155
|
+
SkyModalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.2", type: SkyModalComponent, selector: "sky-modal", inputs: { ariaRole: "ariaRole", tiledBody: "tiledBody" }, host: { listeners: { "document:keyup": "onDocumentKeyUp($event)", "document:keydown": "onDocumentKeyDown($event)" }, properties: { "class": "this.wrapperClass" } }, providers: [SkyModalComponentAdapterService, SkyDockService], viewQueries: [{ propertyName: "modalContentWrapperElement", first: true, predicate: ["modalContentWrapper"], descendants: true, read: ElementRef }], ngImport: i0, template: "<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 < 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", styles: [".sky-modal{border-top:1px solid #cdcfd2;border-bottom:1px solid #cdcfd2;border-left:1px solid #cdcfd2;border-right:1px solid #cdcfd2;position:fixed;width:auto;left:0;right:0;top:20px;margin:10px;display:flex;flex-direction:column;overflow:hidden}.sky-modal:focus{outline:none}@media (min-width: 768px){.sky-modal:not(.sky-modal-large){margin:0 auto}.sky-modal-small{width:300px}.sky-modal-small .sky-modal-content,.sky-modal-small .sky-modal-header,.sky-modal-small .sky-modal-footer{max-width:300px}.sky-modal-medium{width:600px}.sky-modal-medium .sky-modal-content,.sky-modal-medium .sky-modal-header,.sky-modal-medium .sky-modal-footer{max-width:600px}}@media (min-width: 920px){.sky-modal-large{margin:0 auto;width:900px}.sky-modal-large .sky-modal-content,.sky-modal-large .sky-modal-header,.sky-modal-large .sky-modal-footer{max-width:900px}}.sky-modal-content{background-color:#fff}.sky-modal-content:focus{outline-style:dotted;outline-width:thin;outline-offset:-1px}.sky-modal-tiled .sky-modal-content{background-color:#eeeeef}.sky-modal-tiled .sky-modal-content ::ng-deep .sky-tile-title{font-family:BLKB Sans,Helvetica Neue,Arial,sans-serif;color:#686c73;font-weight:300;font-size:19px}.sky-modal-header{padding:9px 3px 9px 15px;background-color:#fff;display:flex;align-items:baseline;border-bottom:1px solid #e2e3e4}.sky-modal-header-buttons{flex-shrink:.0001}.sky-modal-header-buttons .sky-btn{border:none;color:#cdcfd2;cursor:pointer}.sky-modal-header-buttons .sky-btn:hover{color:#979ba2;transition:color .15s}.sky-modal-header-content{flex-grow:1}.sky-modal-header{flex-shrink:0;z-index:2}.sky-modal-content{overflow-y:auto}.sky-modal-footer{flex-shrink:0;z-index:2}.sky-modal-footer ::ng-deep .sky-btn+.sky-btn{margin-left:10px}.sky-modal-footer ::ng-deep .sky-btn+.sky-btn-link{margin-left:-2px}.sky-modal-full-page{width:100%;top:0;margin:0}.sky-modal-full-page .sky-modal-header-buttons sky-icon[icon=close]{font-size:20px}.sky-modal-full-page .sky-modal-content{flex-grow:1}:host ::ng-deep .sky-sectioned-form{min-height:460px;margin:-15px}.sky-modal-content>::ng-deep sky-dock{bottom:-15px;margin-left:-15px;margin-bottom:-15px;padding-top:15px;width:calc(100% + 30px)}:host-context(.sky-theme-modern) .sky-modal-header{border:none;padding:20px 30px}:host-context(.sky-theme-modern) .sky-modal-btn-help,:host-context(.sky-theme-modern) .sky-modal-btn-close{display:none}:host-context(.sky-theme-modern) .sky-modal-content{padding:0}:host-context(.sky-theme-modern) .sky-modal-full-page{width:calc(100% - 60px);margin:30px}:host-context(.sky-theme-modern) .sky-modal-content>::ng-deep sky-dock{bottom:0;margin-left:initial;margin-bottom:initial;padding-top:initial;width:100%}:host-context(.sky-theme-modern) .sky-modal-viewkeeper .sky-modal-header{box-shadow:none!important}:host-context(.sky-theme-modern) .sky-modal-viewkeeper .sky-modal-content ::ng-deep sky-modal-content>.sky-viewkeeper-fixed{box-shadow:0 4px 8px -4px #0000004d}:host-context(.sky-theme-modern) .sky-modal-viewkeeper .sky-modal-content ::ng-deep sky-modal-content>.sky-viewkeeper-fixed>sky-toolbar .sky-toolbar-container{background-color:#fff;padding-left:30px;padding-right:30px}.sky-theme-modern .sky-modal-header{border:none;padding:20px 30px}.sky-theme-modern .sky-modal-btn-help,.sky-theme-modern .sky-modal-btn-close{display:none}.sky-theme-modern .sky-modal-content{padding:0}.sky-theme-modern .sky-modal-full-page{width:calc(100% - 60px);margin:30px}.sky-theme-modern .sky-modal-content>::ng-deep sky-dock{bottom:0;margin-left:initial;margin-bottom:initial;padding-top:initial;width:100%}.sky-theme-modern .sky-modal-viewkeeper .sky-modal-header{box-shadow:none!important}.sky-theme-modern .sky-modal-viewkeeper .sky-modal-content ::ng-deep sky-modal-content>.sky-viewkeeper-fixed{box-shadow:0 4px 8px -4px #0000004d}.sky-theme-modern .sky-modal-viewkeeper .sky-modal-content ::ng-deep sky-modal-content>.sky-viewkeeper-fixed>sky-toolbar .sky-toolbar-container{background-color:#fff;padding-left:30px;padding-right:30px}:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-modal{border-color:#121212}:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-modal-header{color:#fbfcfe}:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-modal-header,:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-modal-content{background-color:transparent}.sky-theme-modern.sky-theme-mode-dark .sky-modal{border-color:#121212}.sky-theme-modern.sky-theme-mode-dark .sky-modal-header{color:#fbfcfe}.sky-theme-modern.sky-theme-mode-dark .sky-modal-header,.sky-theme-modern.sky-theme-mode-dark .sky-modal-content{background-color:transparent}\n"], components: [{ type: i5.λ4, selector: "sky-icon", inputs: ["icon", "iconType", "size", "fixedWidth", "variant"] }], directives: [{ type: i6.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i6.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i7.SkyModalScrollShadowDirective, selector: "[skyModalScrollShadow]", outputs: ["skyModalScrollShadow"] }], pipes: { "skyLibResources": i8.SkyLibResourcesPipe } });
|
|
169
156
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyModalComponent, decorators: [{
|
|
170
157
|
type: Component,
|
|
171
|
-
args: [{ selector: 'sky-modal',
|
|
158
|
+
args: [{ selector: 'sky-modal', providers: [SkyModalComponentAdapterService, SkyDockService], template: "<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 < 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", styles: [".sky-modal{border-top:1px solid #cdcfd2;border-bottom:1px solid #cdcfd2;border-left:1px solid #cdcfd2;border-right:1px solid #cdcfd2;position:fixed;width:auto;left:0;right:0;top:20px;margin:10px;display:flex;flex-direction:column;overflow:hidden}.sky-modal:focus{outline:none}@media (min-width: 768px){.sky-modal:not(.sky-modal-large){margin:0 auto}.sky-modal-small{width:300px}.sky-modal-small .sky-modal-content,.sky-modal-small .sky-modal-header,.sky-modal-small .sky-modal-footer{max-width:300px}.sky-modal-medium{width:600px}.sky-modal-medium .sky-modal-content,.sky-modal-medium .sky-modal-header,.sky-modal-medium .sky-modal-footer{max-width:600px}}@media (min-width: 920px){.sky-modal-large{margin:0 auto;width:900px}.sky-modal-large .sky-modal-content,.sky-modal-large .sky-modal-header,.sky-modal-large .sky-modal-footer{max-width:900px}}.sky-modal-content{background-color:#fff}.sky-modal-content:focus{outline-style:dotted;outline-width:thin;outline-offset:-1px}.sky-modal-tiled .sky-modal-content{background-color:#eeeeef}.sky-modal-tiled .sky-modal-content ::ng-deep .sky-tile-title{font-family:BLKB Sans,Helvetica Neue,Arial,sans-serif;color:#686c73;font-weight:300;font-size:19px}.sky-modal-header{padding:9px 3px 9px 15px;background-color:#fff;display:flex;align-items:baseline;border-bottom:1px solid #e2e3e4}.sky-modal-header-buttons{flex-shrink:.0001}.sky-modal-header-buttons .sky-btn{border:none;color:#cdcfd2;cursor:pointer}.sky-modal-header-buttons .sky-btn:hover{color:#979ba2;transition:color .15s}.sky-modal-header-content{flex-grow:1}.sky-modal-header{flex-shrink:0;z-index:2}.sky-modal-content{overflow-y:auto}.sky-modal-footer{flex-shrink:0;z-index:2}.sky-modal-footer ::ng-deep .sky-btn+.sky-btn{margin-left:10px}.sky-modal-footer ::ng-deep .sky-btn+.sky-btn-link{margin-left:-2px}.sky-modal-full-page{width:100%;top:0;margin:0}.sky-modal-full-page .sky-modal-header-buttons sky-icon[icon=close]{font-size:20px}.sky-modal-full-page .sky-modal-content{flex-grow:1}:host ::ng-deep .sky-sectioned-form{min-height:460px;margin:-15px}.sky-modal-content>::ng-deep sky-dock{bottom:-15px;margin-left:-15px;margin-bottom:-15px;padding-top:15px;width:calc(100% + 30px)}:host-context(.sky-theme-modern) .sky-modal-header{border:none;padding:20px 30px}:host-context(.sky-theme-modern) .sky-modal-btn-help,:host-context(.sky-theme-modern) .sky-modal-btn-close{display:none}:host-context(.sky-theme-modern) .sky-modal-content{padding:0}:host-context(.sky-theme-modern) .sky-modal-full-page{width:calc(100% - 60px);margin:30px}:host-context(.sky-theme-modern) .sky-modal-content>::ng-deep sky-dock{bottom:0;margin-left:initial;margin-bottom:initial;padding-top:initial;width:100%}:host-context(.sky-theme-modern) .sky-modal-viewkeeper .sky-modal-header{box-shadow:none!important}:host-context(.sky-theme-modern) .sky-modal-viewkeeper .sky-modal-content ::ng-deep sky-modal-content>.sky-viewkeeper-fixed{box-shadow:0 4px 8px -4px #0000004d}:host-context(.sky-theme-modern) .sky-modal-viewkeeper .sky-modal-content ::ng-deep sky-modal-content>.sky-viewkeeper-fixed>sky-toolbar .sky-toolbar-container{background-color:#fff;padding-left:30px;padding-right:30px}.sky-theme-modern .sky-modal-header{border:none;padding:20px 30px}.sky-theme-modern .sky-modal-btn-help,.sky-theme-modern .sky-modal-btn-close{display:none}.sky-theme-modern .sky-modal-content{padding:0}.sky-theme-modern .sky-modal-full-page{width:calc(100% - 60px);margin:30px}.sky-theme-modern .sky-modal-content>::ng-deep sky-dock{bottom:0;margin-left:initial;margin-bottom:initial;padding-top:initial;width:100%}.sky-theme-modern .sky-modal-viewkeeper .sky-modal-header{box-shadow:none!important}.sky-theme-modern .sky-modal-viewkeeper .sky-modal-content ::ng-deep sky-modal-content>.sky-viewkeeper-fixed{box-shadow:0 4px 8px -4px #0000004d}.sky-theme-modern .sky-modal-viewkeeper .sky-modal-content ::ng-deep sky-modal-content>.sky-viewkeeper-fixed>sky-toolbar .sky-toolbar-container{background-color:#fff;padding-left:30px;padding-right:30px}:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-modal{border-color:#121212}:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-modal-header{color:#fbfcfe}:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-modal-header,:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-modal-content{background-color:transparent}.sky-theme-modern.sky-theme-mode-dark .sky-modal{border-color:#121212}.sky-theme-modern.sky-theme-mode-dark .sky-modal-header{color:#fbfcfe}.sky-theme-modern.sky-theme-mode-dark .sky-modal-header,.sky-theme-modern.sky-theme-mode-dark .sky-modal-content{background-color:transparent}\n"] }]
|
|
172
159
|
}], ctorParameters: function () { return [{ type: i1.SkyModalHostService }, { type: i2.SkyModalConfiguration }, { type: i0.ElementRef }, { type: i3.SkyAppWindowRef }, { type: i4.SkyModalComponentAdapterService }, { type: i3.SkyCoreAdapterService }, { type: i3.SkyDockService, decorators: [{
|
|
173
160
|
type: Host
|
|
174
161
|
}] }, { type: i3.SkyResizeObserverMediaQueryService, decorators: [{
|
|
@@ -190,4 +177,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
|
|
|
190
177
|
type: HostListener,
|
|
191
178
|
args: ['document:keydown', ['$event']]
|
|
192
179
|
}] } });
|
|
193
|
-
//# 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';\nimport { skyAnimationModalState } from './modal-state-animation';\n\nlet skyModalUniqueIdentifier = 0;\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  animations: [skyAnimationModalState],\n  providers: [SkyModalComponentAdapterService, SkyDockService],\n})\nexport class SkyModalComponent implements AfterViewInit, OnDestroy {\n  @HostBinding('class')\n  public get wrapperClass(): string {\n    return this.config.wrapperClass;\n  }\n\n  /**\n   * @internal\n   */\n  @Input()\n  public get ariaRole() {\n    return this.config.ariaRole || 'dialog';\n  }\n  public set ariaRole(value: string) {\n    this.config.ariaRole = value;\n  }\n\n  /**\n   * @internal\n   */\n  @Input()\n  public set tiledBody(value: boolean) {\n    this.config.tiledBody = value;\n  }\n\n  public get modalZIndex() {\n    return this.hostService.getModalZIndex();\n  }\n\n  public get modalFullPage() {\n    return this.config.fullPage;\n  }\n\n  public get isSmallSize() {\n    return !this.modalFullPage && this.isSizeEqual(this.config.size, 'small');\n  }\n\n  public get isMediumSize() {\n    return !this.modalFullPage && !(this.isSmallSize || this.isLargeSize);\n  }\n\n  public get isLargeSize() {\n    return !this.modalFullPage && this.isSizeEqual(this.config.size, 'large');\n  }\n\n  public get isTiledBody() {\n    return this.config.tiledBody;\n  }\n\n  public get ariaDescribedBy() {\n    return this.config.ariaDescribedBy || this.modalContentId;\n  }\n\n  public get ariaLabelledBy() {\n    return this.config.ariaLabelledBy || this.modalHeaderId;\n  }\n\n  public get helpKey() {\n    return this.config.helpKey;\n  }\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 scrollShadow: SkyModalScrollShadowEventArgs;\n\n  @ViewChild('modalContentWrapper', { read: ElementRef })\n  private modalContentWrapperElement: ElementRef;\n\n  constructor(\n    private hostService: SkyModalHostService,\n    private config: SkyModalConfiguration,\n    private elRef: ElementRef,\n    private windowRef: SkyAppWindowRef,\n    private componentAdapter: SkyModalComponentAdapterService,\n    private coreAdapter: SkyCoreAdapterService,\n    @Host() private dockService: SkyDockService,\n    @Optional()\n    private mediaQueryService?: SkyResizeObserverMediaQueryService\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    this.hostService.onOpenHelp(this.helpKey);\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  private isSizeEqual(actualSize: string, size: string) {\n    return actualSize && actualSize.toLowerCase() === size;\n  }\n}\n","<!--\n  Animations are broken in Chrome v52. Angular 2 RC5 will fix it.\n  https://github.com/angular/angular/issues/10245\n-->\n<!--<div @modalState=\"modalState\">-->\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]=\"ariaRole\"\n  (window:resize)=\"windowResize()\"\n>\n  <div\n    class=\"sky-modal sky-shadow sky-box sky-elevation-16\"\n    tabindex=\"-1\"\n    [ngClass]=\"{\n      'sky-modal-full-page': modalFullPage,\n      'sky-modal-small': isSmallSize,\n      'sky-modal-medium': isMediumSize,\n      'sky-modal-large': isLargeSize,\n      'sky-modal-tiled': isTiledBody,\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': modalFullPage\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  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"]}
|
|
@@ -1,3 +1,5 @@
|
|
|
1
|
+
var _SkyModalService_instances, _SkyModalService_dynamicComponentService, _SkyModalService_getConfigFromParameter, _SkyModalService_createHostComponent;
|
|
2
|
+
import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
|
|
1
3
|
import { Injectable } from '@angular/core';
|
|
2
4
|
import { SkyDynamicComponentService } from '@skyux/core';
|
|
3
5
|
import { SkyModalHostContext } from './modal-host-context';
|
|
@@ -10,9 +12,12 @@ import * as i1 from "@skyux/core";
|
|
|
10
12
|
* @dynamic
|
|
11
13
|
*/
|
|
12
14
|
export class SkyModalService {
|
|
13
|
-
// TODO:
|
|
15
|
+
// TODO: Make `dynamicComponentService` required. It is optional today to maintain binary compatibility for consumers when they construct
|
|
16
|
+
// the service for unit testing.
|
|
14
17
|
constructor(dynamicComponentService) {
|
|
15
|
-
this
|
|
18
|
+
_SkyModalService_instances.add(this);
|
|
19
|
+
_SkyModalService_dynamicComponentService.set(this, void 0);
|
|
20
|
+
__classPrivateFieldSet(this, _SkyModalService_dynamicComponentService, dynamicComponentService, "f");
|
|
16
21
|
}
|
|
17
22
|
/**
|
|
18
23
|
* @internal
|
|
@@ -20,7 +25,7 @@ export class SkyModalService {
|
|
|
20
25
|
*/
|
|
21
26
|
dispose() {
|
|
22
27
|
if (SkyModalService.host) {
|
|
23
|
-
this.
|
|
28
|
+
__classPrivateFieldGet(this, _SkyModalService_dynamicComponentService, "f").removeComponent(SkyModalService.host);
|
|
24
29
|
SkyModalService.host = undefined;
|
|
25
30
|
}
|
|
26
31
|
}
|
|
@@ -31,56 +36,57 @@ export class SkyModalService {
|
|
|
31
36
|
*/
|
|
32
37
|
open(component, config) {
|
|
33
38
|
const modalInstance = new SkyModalInstance();
|
|
34
|
-
this.
|
|
35
|
-
const params = this.
|
|
39
|
+
__classPrivateFieldGet(this, _SkyModalService_instances, "m", _SkyModalService_createHostComponent).call(this);
|
|
40
|
+
const params = __classPrivateFieldGet(this, _SkyModalService_instances, "m", _SkyModalService_getConfigFromParameter).call(this, config);
|
|
41
|
+
/* eslint-disable @typescript-eslint/no-non-null-assertion */
|
|
36
42
|
params.providers.push({
|
|
37
43
|
provide: SkyModalInstance,
|
|
38
44
|
useValue: modalInstance,
|
|
39
45
|
});
|
|
40
46
|
SkyModalService.host.instance.open(modalInstance, component, params);
|
|
47
|
+
/* eslint-enable @typescript-eslint/no-non-null-assertion */
|
|
41
48
|
return modalInstance;
|
|
42
49
|
}
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
}
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
else {
|
|
63
|
-
params = method['config'];
|
|
64
|
-
}
|
|
65
|
-
return params;
|
|
50
|
+
}
|
|
51
|
+
_SkyModalService_dynamicComponentService = new WeakMap(), _SkyModalService_instances = new WeakSet(), _SkyModalService_getConfigFromParameter = function _SkyModalService_getConfigFromParameter(providersOrConfig) {
|
|
52
|
+
const defaultParams = {
|
|
53
|
+
providers: [],
|
|
54
|
+
fullPage: false,
|
|
55
|
+
size: 'medium',
|
|
56
|
+
tiledBody: false,
|
|
57
|
+
};
|
|
58
|
+
let params = {};
|
|
59
|
+
let method = undefined;
|
|
60
|
+
// Object Literal Lookup for backwards compatability.
|
|
61
|
+
method = {
|
|
62
|
+
'providers?': Object.assign({}, defaultParams, {
|
|
63
|
+
providers: providersOrConfig,
|
|
64
|
+
}),
|
|
65
|
+
config: Object.assign({}, defaultParams, providersOrConfig),
|
|
66
|
+
};
|
|
67
|
+
if (Array.isArray(providersOrConfig) === true) {
|
|
68
|
+
params = method['providers?'];
|
|
66
69
|
}
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
SkyModalService.host = this.dynamicComponentService.createComponent(SkyModalHostComponent, {
|
|
70
|
-
providers: [
|
|
71
|
-
{
|
|
72
|
-
provide: SkyModalHostContext,
|
|
73
|
-
useValue: new SkyModalHostContext({
|
|
74
|
-
teardownCallback: () => {
|
|
75
|
-
this.dispose();
|
|
76
|
-
},
|
|
77
|
-
}),
|
|
78
|
-
},
|
|
79
|
-
],
|
|
80
|
-
});
|
|
81
|
-
}
|
|
70
|
+
else {
|
|
71
|
+
params = method['config'];
|
|
82
72
|
}
|
|
83
|
-
|
|
73
|
+
return params;
|
|
74
|
+
}, _SkyModalService_createHostComponent = function _SkyModalService_createHostComponent() {
|
|
75
|
+
if (!SkyModalService.host) {
|
|
76
|
+
SkyModalService.host = __classPrivateFieldGet(this, _SkyModalService_dynamicComponentService, "f").createComponent(SkyModalHostComponent, {
|
|
77
|
+
providers: [
|
|
78
|
+
{
|
|
79
|
+
provide: SkyModalHostContext,
|
|
80
|
+
useValue: new SkyModalHostContext({
|
|
81
|
+
teardownCallback: () => {
|
|
82
|
+
this.dispose();
|
|
83
|
+
},
|
|
84
|
+
}),
|
|
85
|
+
},
|
|
86
|
+
],
|
|
87
|
+
});
|
|
88
|
+
}
|
|
89
|
+
};
|
|
84
90
|
SkyModalService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyModalService, deps: [{ token: i1.SkyDynamicComponentService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
85
91
|
SkyModalService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyModalService, providedIn: 'any' });
|
|
86
92
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyModalService, decorators: [{
|
|
@@ -92,4 +98,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
|
|
|
92
98
|
providedIn: 'any',
|
|
93
99
|
}]
|
|
94
100
|
}], ctorParameters: function () { return [{ type: i1.SkyDynamicComponentService }]; } });
|
|
95
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
101
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kYWwuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9tb2RhbHMvc3JjL2xpYi9tb2R1bGVzL21vZGFsL21vZGFsLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxPQUFPLEVBQWdCLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6RCxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFFekQsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDM0QsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDL0QsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sa0JBQWtCLENBQUM7OztBQUdwRDs7O0dBR0c7QUFPSCxNQUFNLE9BQU8sZUFBZTtJQUsxQix5SUFBeUk7SUFDekksZ0NBQWdDO0lBQ2hDLFlBQVksdUJBQW9EOztRQUpoRSwyREFBcUQ7UUFLbkQsdUJBQUEsSUFBSSw0Q0FBNEIsdUJBQXdCLE1BQUEsQ0FBQztJQUMzRCxDQUFDO0lBRUQ7OztPQUdHO0lBQ0ksT0FBTztRQUNaLElBQUksZUFBZSxDQUFDLElBQUksRUFBRTtZQUN4Qix1QkFBQSxJQUFJLGdEQUF5QixDQUFDLGVBQWUsQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLENBQUM7WUFDcEUsZUFBZSxDQUFDLElBQUksR0FBRyxTQUFTLENBQUM7U0FDbEM7SUFDSCxDQUFDO0lBRUQ7Ozs7T0FJRztJQUNJLElBQUksQ0FDVCxTQUFjLEVBQ2QsTUFBK0M7UUFFL0MsTUFBTSxhQUFhLEdBQUcsSUFBSSxnQkFBZ0IsRUFBRSxDQUFDO1FBQzdDLHVCQUFBLElBQUksd0VBQXFCLE1BQXpCLElBQUksQ0FBdUIsQ0FBQztRQUM1QixNQUFNLE1BQU0sR0FBRyx1QkFBQSxJQUFJLDJFQUF3QixNQUE1QixJQUFJLEVBQXlCLE1BQU0sQ0FBQyxDQUFDO1FBRXBELDZEQUE2RDtRQUM3RCxNQUFNLENBQUMsU0FBVSxDQUFDLElBQUksQ0FBQztZQUNyQixPQUFPLEVBQUUsZ0JBQWdCO1lBQ3pCLFFBQVEsRUFBRSxhQUFhO1NBQ3hCLENBQUMsQ0FBQztRQUVILGVBQWUsQ0FBQyxJQUFLLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxhQUFhLEVBQUUsU0FBUyxFQUFFLE1BQU0sQ0FBQyxDQUFDO1FBQ3RFLDREQUE0RDtRQUU1RCxPQUFPLGFBQWEsQ0FBQztJQUN2QixDQUFDOztpTUFHQyxpQkFBc0I7SUFFdEIsTUFBTSxhQUFhLEdBQW1DO1FBQ3BELFNBQVMsRUFBRSxFQUFFO1FBQ2IsUUFBUSxFQUFFLEtBQUs7UUFDZixJQUFJLEVBQUUsUUFBUTtRQUNkLFNBQVMsRUFBRSxLQUFLO0tBQ2pCLENBQUM7SUFDRixJQUFJLE1BQU0sR0FBbUMsRUFBRSxDQUFDO0lBQ2hELElBQUksTUFBTSxHQUFRLFNBQVMsQ0FBQztJQUU1QixxREFBcUQ7SUFDckQsTUFBTSxHQUFHO1FBQ1AsWUFBWSxFQUFFLE1BQU0sQ0FBQyxNQUFNLENBQUMsRUFBRSxFQUFFLGFBQWEsRUFBRTtZQUM3QyxTQUFTLEVBQUUsaUJBQWlCO1NBQzdCLENBQUM7UUFDRixNQUFNLEVBQUUsTUFBTSxDQUFDLE1BQU0sQ0FBQyxFQUFFLEVBQUUsYUFBYSxFQUFFLGlCQUFpQixDQUFDO0tBQzVELENBQUM7SUFFRixJQUFJLEtBQUssQ0FBQyxPQUFPLENBQUMsaUJBQWlCLENBQUMsS0FBSyxJQUFJLEVBQUU7UUFDN0MsTUFBTSxHQUFHLE1BQU0sQ0FBQyxZQUFZLENBQUMsQ0FBQztLQUMvQjtTQUFNO1FBQ0wsTUFBTSxHQUFHLE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQztLQUMzQjtJQUVELE9BQU8sTUFBTSxDQUFDO0FBQ2hCLENBQUM7SUFHQyxJQUFJLENBQUMsZUFBZSxDQUFDLElBQUksRUFBRTtRQUN6QixlQUFlLENBQUMsSUFBSSxHQUFHLHVCQUFBLElBQUksZ0RBQXlCLENBQUMsZUFBZSxDQUNsRSxxQkFBcUIsRUFDckI7WUFDRSxTQUFTLEVBQUU7Z0JBQ1Q7b0JBQ0UsT0FBTyxFQUFFLG1CQUFtQjtvQkFDNUIsUUFBUSxFQUFFLElBQUksbUJBQW1CLENBQUM7d0JBQ2hDLGdCQUFnQixFQUFFLEdBQUcsRUFBRTs0QkFDckIsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDO3dCQUNqQixDQUFDO3FCQUNGLENBQUM7aUJBQ0g7YUFDRjtTQUNGLENBQ0YsQ0FBQztLQUNIO0FBQ0gsQ0FBQzs0R0E5RlUsZUFBZTtnSEFBZixlQUFlLGNBRmQsS0FBSzsyRkFFTixlQUFlO2tCQU4zQixVQUFVO21CQUFDO29CQUNWLGdHQUFnRztvQkFDaEcsOEZBQThGO29CQUM5RiwwRkFBMEY7b0JBQzFGLFVBQVUsRUFBRSxLQUFLO2lCQUNsQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudFJlZiwgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgU2t5RHluYW1pY0NvbXBvbmVudFNlcnZpY2UgfSBmcm9tICdAc2t5dXgvY29yZSc7XG5cbmltcG9ydCB7IFNreU1vZGFsSG9zdENvbnRleHQgfSBmcm9tICcuL21vZGFsLWhvc3QtY29udGV4dCc7XG5pbXBvcnQgeyBTa3lNb2RhbEhvc3RDb21wb25lbnQgfSBmcm9tICcuL21vZGFsLWhvc3QuY29tcG9uZW50JztcbmltcG9ydCB7IFNreU1vZGFsSW5zdGFuY2UgfSBmcm9tICcuL21vZGFsLWluc3RhbmNlJztcbmltcG9ydCB7IFNreU1vZGFsQ29uZmlndXJhdGlvbkludGVyZmFjZSB9IGZyb20gJy4vbW9kYWwuaW50ZXJmYWNlJztcblxuLyoqXG4gKiBBIHNlcnZpY2UgdGhhdCBsYXVuY2hlcyBtb2RhbHMuXG4gKiBAZHluYW1pY1xuICovXG5ASW5qZWN0YWJsZSh7XG4gIC8vIE11c3QgYmUgJ2FueScgc28gdGhhdCB0aGUgbW9kYWwgY29tcG9uZW50IGlzIGNyZWF0ZWQgaW4gdGhlIGNvbnRleHQgb2YgaXRzIG1vZHVsZSdzIGluamVjdG9yLlxuICAvLyBJZiBzZXQgdG8gJ3Jvb3QnLCB0aGUgY29tcG9uZW50J3MgZGVwZW5kZW5jeSBpbmplY3Rpb25zIHdvdWxkIG9ubHkgYmUgZGVyaXZlZCBmcm9tIHRoZSByb290XG4gIC8vIGluamVjdG9yIGFuZCBtYXkgbG9zZSBjb250ZXh0IGlmIHRoZSBtb2RhbCB3YXMgb3BlbmVkIGZyb20gd2l0aGluIGEgbGF6eS1sb2FkZWQgbW9kdWxlLlxuICBwcm92aWRlZEluOiAnYW55Jyxcbn0pXG5leHBvcnQgY2xhc3MgU2t5TW9kYWxTZXJ2aWNlIHtcbiAgcHJpdmF0ZSBzdGF0aWMgaG9zdDogQ29tcG9uZW50UmVmPFNreU1vZGFsSG9zdENvbXBvbmVudD4gfCB1bmRlZmluZWQ7XG5cbiAgI2R5bmFtaWNDb21wb25lbnRTZXJ2aWNlOiBTa3lEeW5hbWljQ29tcG9uZW50U2VydmljZTtcblxuICAvLyBUT0RPOiBNYWtlIGBkeW5hbWljQ29tcG9uZW50U2VydmljZWAgcmVxdWlyZWQuIEl0IGlzIG9wdGlvbmFsIHRvZGF5IHRvIG1haW50YWluIGJpbmFyeSBjb21wYXRpYmlsaXR5IGZvciBjb25zdW1lcnMgd2hlbiB0aGV5IGNvbnN0cnVjdFxuICAvLyB0aGUgc2VydmljZSBmb3IgdW5pdCB0ZXN0aW5nLlxuICBjb25zdHJ1Y3RvcihkeW5hbWljQ29tcG9uZW50U2VydmljZT86IFNreUR5bmFtaWNDb21wb25lbnRTZXJ2aWNlKSB7XG4gICAgdGhpcy4jZHluYW1pY0NvbXBvbmVudFNlcnZpY2UgPSBkeW5hbWljQ29tcG9uZW50U2VydmljZSE7XG4gIH1cblxuICAvKipcbiAgICogQGludGVybmFsXG4gICAqIFJlbW92ZXMgdGhlIG1vZGFsIGhvc3QgZnJvbSB0aGUgRE9NLlxuICAgKi9cbiAgcHVibGljIGRpc3Bvc2UoKTogdm9pZCB7XG4gICAgaWYgKFNreU1vZGFsU2VydmljZS5ob3N0KSB7XG4gICAgICB0aGlzLiNkeW5hbWljQ29tcG9uZW50U2VydmljZS5yZW1vdmVDb21wb25lbnQoU2t5TW9kYWxTZXJ2aWNlLmhvc3QpO1xuICAgICAgU2t5TW9kYWxTZXJ2aWNlLmhvc3QgPSB1bmRlZmluZWQ7XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIE9wZW5zIGEgbW9kYWwgdXNpbmcgdGhlIHNwZWNpZmllZCBjb21wb25lbnQuXG4gICAqIEBwYXJhbSBjb21wb25lbnQgRGV0ZXJtaW5lcyB0aGUgY29tcG9uZW50IHRvIHJlbmRlci5cbiAgICogQHBhcmFtIHtTa3lNb2RhbENvbmZpZ3VyYXRpb25JbnRlcmZhY2V9IGNvbmZpZyBTcGVjaWZpZXMgY29uZmlndXJhdGlvbiBvcHRpb25zIGZvciB0aGUgbW9kYWwuXG4gICAqL1xuICBwdWJsaWMgb3BlbihcbiAgICBjb21wb25lbnQ6IGFueSxcbiAgICBjb25maWc/OiBTa3lNb2RhbENvbmZpZ3VyYXRpb25JbnRlcmZhY2UgfCBhbnlbXVxuICApOiBTa3lNb2RhbEluc3RhbmNlIHtcbiAgICBjb25zdCBtb2RhbEluc3RhbmNlID0gbmV3IFNreU1vZGFsSW5zdGFuY2UoKTtcbiAgICB0aGlzLiNjcmVhdGVIb3N0Q29tcG9uZW50KCk7XG4gICAgY29uc3QgcGFyYW1zID0gdGhpcy4jZ2V0Q29uZmlnRnJvbVBhcmFtZXRlcihjb25maWcpO1xuXG4gICAgLyogZXNsaW50LWRpc2FibGUgQHR5cGVzY3JpcHQtZXNsaW50L25vLW5vbi1udWxsLWFzc2VydGlvbiAqL1xuICAgIHBhcmFtcy5wcm92aWRlcnMhLnB1c2goe1xuICAgICAgcHJvdmlkZTogU2t5TW9kYWxJbnN0YW5jZSxcbiAgICAgIHVzZVZhbHVlOiBtb2RhbEluc3RhbmNlLFxuICAgIH0pO1xuXG4gICAgU2t5TW9kYWxTZXJ2aWNlLmhvc3QhLmluc3RhbmNlLm9wZW4obW9kYWxJbnN0YW5jZSwgY29tcG9uZW50LCBwYXJhbXMpO1xuICAgIC8qIGVzbGludC1lbmFibGUgQHR5cGVzY3JpcHQtZXNsaW50L25vLW5vbi1udWxsLWFzc2VydGlvbiAqL1xuXG4gICAgcmV0dXJuIG1vZGFsSW5zdGFuY2U7XG4gIH1cblxuICAjZ2V0Q29uZmlnRnJvbVBhcmFtZXRlcihcbiAgICBwcm92aWRlcnNPckNvbmZpZzogYW55XG4gICk6IFNreU1vZGFsQ29uZmlndXJhdGlvbkludGVyZmFjZSB7XG4gICAgY29uc3QgZGVmYXVsdFBhcmFtczogU2t5TW9kYWxDb25maWd1cmF0aW9uSW50ZXJmYWNlID0ge1xuICAgICAgcHJvdmlkZXJzOiBbXSxcbiAgICAgIGZ1bGxQYWdlOiBmYWxzZSxcbiAgICAgIHNpemU6ICdtZWRpdW0nLFxuICAgICAgdGlsZWRCb2R5OiBmYWxzZSxcbiAgICB9O1xuICAgIGxldCBwYXJhbXM6IFNreU1vZGFsQ29uZmlndXJhdGlvbkludGVyZmFjZSA9IHt9O1xuICAgIGxldCBtZXRob2Q6IGFueSA9IHVuZGVmaW5lZDtcblxuICAgIC8vIE9iamVjdCBMaXRlcmFsIExvb2t1cCBmb3IgYmFja3dhcmRzIGNvbXBhdGFiaWxpdHkuXG4gICAgbWV0aG9kID0ge1xuICAgICAgJ3Byb3ZpZGVycz8nOiBPYmplY3QuYXNzaWduKHt9LCBkZWZhdWx0UGFyYW1zLCB7XG4gICAgICAgIHByb3ZpZGVyczogcHJvdmlkZXJzT3JDb25maWcsXG4gICAgICB9KSxcbiAgICAgIGNvbmZpZzogT2JqZWN0LmFzc2lnbih7fSwgZGVmYXVsdFBhcmFtcywgcHJvdmlkZXJzT3JDb25maWcpLFxuICAgIH07XG5cbiAgICBpZiAoQXJyYXkuaXNBcnJheShwcm92aWRlcnNPckNvbmZpZykgPT09IHRydWUpIHtcbiAgICAgIHBhcmFtcyA9IG1ldGhvZFsncHJvdmlkZXJzPyddO1xuICAgIH0gZWxzZSB7XG4gICAgICBwYXJhbXMgPSBtZXRob2RbJ2NvbmZpZyddO1xuICAgIH1cblxuICAgIHJldHVybiBwYXJhbXM7XG4gIH1cblxuICAjY3JlYXRlSG9zdENvbXBvbmVudCgpOiB2b2lkIHtcbiAgICBpZiAoIVNreU1vZGFsU2VydmljZS5ob3N0KSB7XG4gICAgICBTa3lNb2RhbFNlcnZpY2UuaG9zdCA9IHRoaXMuI2R5bmFtaWNDb21wb25lbnRTZXJ2aWNlLmNyZWF0ZUNvbXBvbmVudChcbiAgICAgICAgU2t5TW9kYWxIb3N0Q29tcG9uZW50LFxuICAgICAgICB7XG4gICAgICAgICAgcHJvdmlkZXJzOiBbXG4gICAgICAgICAgICB7XG4gICAgICAgICAgICAgIHByb3ZpZGU6IFNreU1vZGFsSG9zdENvbnRleHQsXG4gICAgICAgICAgICAgIHVzZVZhbHVlOiBuZXcgU2t5TW9kYWxIb3N0Q29udGV4dCh7XG4gICAgICAgICAgICAgICAgdGVhcmRvd25DYWxsYmFjazogKCkgPT4ge1xuICAgICAgICAgICAgICAgICAgdGhpcy5kaXNwb3NlKCk7XG4gICAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICAgfSksXG4gICAgICAgICAgICB9LFxuICAgICAgICAgIF0sXG4gICAgICAgIH1cbiAgICAgICk7XG4gICAgfVxuICB9XG59XG4iXX0=
|