@skyux/modals 10.31.1 → 10.32.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 +1231 -723
- package/esm2022/lib/modules/confirm/confirm.component.mjs +2 -2
- package/esm2022/lib/modules/modal/modal-configuration.mjs +1 -1
- package/esm2022/lib/modules/modal/modal-footer.component.mjs +1 -1
- package/esm2022/lib/modules/modal/modal-header.component.mjs +3 -3
- package/esm2022/lib/modules/modal/modal-host.service.mjs +7 -1
- package/esm2022/lib/modules/modal/modal-instance.mjs +6 -1
- package/esm2022/lib/modules/modal/modal.component.mjs +31 -10
- package/esm2022/lib/modules/modal/modal.interface.mjs +1 -1
- package/esm2022/testing/modal/modal-harness.mjs +38 -3
- package/fesm2022/skyux-modals-testing.mjs +37 -2
- package/fesm2022/skyux-modals-testing.mjs.map +1 -1
- package/fesm2022/skyux-modals.mjs +58 -27
- package/fesm2022/skyux-modals.mjs.map +1 -1
- package/lib/modules/modal/modal-configuration.d.ts +12 -0
- package/lib/modules/modal/modal-host.service.d.ts +6 -0
- package/lib/modules/modal/modal-instance.d.ts +2 -0
- package/lib/modules/modal/modal.component.d.ts +39 -3
- package/lib/modules/modal/modal.interface.d.ts +4 -1
- package/package.json +7 -6
- package/testing/modal/modal-harness.d.ts +21 -2
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { CommonModule } from '@angular/common';
|
|
2
2
|
import { ChangeDetectorRef, Component, ElementRef, HostBinding, HostListener, Input, ViewChild, inject, } from '@angular/core';
|
|
3
3
|
import { SkyAppWindowRef, SkyCoreAdapterService, SkyDockLocation, SkyDockService, SkyIdModule, SkyLiveAnnouncerService, SkyResizeObserverMediaQueryService, } from '@skyux/core';
|
|
4
|
+
import { SkyHelpInlineModule } from '@skyux/help-inline';
|
|
4
5
|
import { SkyIconModule } from '@skyux/icon';
|
|
5
6
|
import { Subject } from 'rxjs';
|
|
6
7
|
import { takeUntil } from 'rxjs/operators';
|
|
@@ -8,13 +9,15 @@ import { SkyModalsResourcesModule } from '../shared/sky-modals-resources.module'
|
|
|
8
9
|
import { SkyModalComponentAdapterService } from './modal-component-adapter.service';
|
|
9
10
|
import { SkyModalConfiguration } from './modal-configuration';
|
|
10
11
|
import { SkyModalErrorsService } from './modal-errors.service';
|
|
12
|
+
import { SkyModalHeaderComponent } from './modal-header.component';
|
|
11
13
|
import { SkyModalHostService } from './modal-host.service';
|
|
12
14
|
import { SkyModalScrollShadowDirective } from './modal-scroll-shadow.directive';
|
|
13
15
|
import * as i0 from "@angular/core";
|
|
14
16
|
import * as i1 from "@angular/common";
|
|
15
|
-
import * as i2 from "@skyux/
|
|
16
|
-
import * as i3 from "@skyux/
|
|
17
|
-
import * as i4 from "@skyux/
|
|
17
|
+
import * as i2 from "@skyux/help-inline";
|
|
18
|
+
import * as i3 from "@skyux/icon";
|
|
19
|
+
import * as i4 from "@skyux/core";
|
|
20
|
+
import * as i5 from "@skyux/i18n";
|
|
18
21
|
const ARIA_ROLE_DEFAULT = 'dialog';
|
|
19
22
|
/**
|
|
20
23
|
* Provides a common look-and-feel for modal content with options to display
|
|
@@ -29,12 +32,15 @@ export class SkyModalComponent {
|
|
|
29
32
|
this.#errorsSvc.updateErrors(value);
|
|
30
33
|
}
|
|
31
34
|
/**
|
|
35
|
+
* Used by the confirm component to set a different role for the modal.
|
|
32
36
|
* @internal
|
|
33
37
|
*/
|
|
34
38
|
set ariaRole(value) {
|
|
35
39
|
this.ariaRoleOrDefault = value || ARIA_ROLE_DEFAULT;
|
|
36
40
|
}
|
|
37
41
|
/**
|
|
42
|
+
* Used by the confirm component to set descriptive text without using a
|
|
43
|
+
* modal header.
|
|
38
44
|
* @internal
|
|
39
45
|
*/
|
|
40
46
|
set ariaDescribedBy(id) {
|
|
@@ -44,6 +50,8 @@ export class SkyModalComponent {
|
|
|
44
50
|
return this.#_ariaDescribedBy;
|
|
45
51
|
}
|
|
46
52
|
/**
|
|
53
|
+
* Used by the confirm component to set descriptive text without using a
|
|
54
|
+
* modal header.
|
|
47
55
|
* @internal
|
|
48
56
|
*/
|
|
49
57
|
set ariaLabelledBy(id) {
|
|
@@ -100,7 +108,7 @@ export class SkyModalComponent {
|
|
|
100
108
|
this.ariaDescribedBy = this.#config.ariaDescribedBy;
|
|
101
109
|
this.ariaLabelledBy = this.#config.ariaLabelledBy;
|
|
102
110
|
this.ariaRole = this.#config.ariaRole;
|
|
103
|
-
this.
|
|
111
|
+
this.legacyHelpKey = this.#config.helpKey;
|
|
104
112
|
this.tiledBody = this.#config.tiledBody;
|
|
105
113
|
this.wrapperClass = this.#config.wrapperClass;
|
|
106
114
|
this.size = this.#config.fullPage
|
|
@@ -188,9 +196,12 @@ export class SkyModalComponent {
|
|
|
188
196
|
this.#ngUnsubscribe.next();
|
|
189
197
|
this.#ngUnsubscribe.complete();
|
|
190
198
|
}
|
|
199
|
+
/**
|
|
200
|
+
* @deprecated
|
|
201
|
+
*/
|
|
191
202
|
helpButtonClick() {
|
|
192
|
-
if (this.
|
|
193
|
-
this.#hostService.onOpenHelp(this.
|
|
203
|
+
if (this.legacyHelpKey) {
|
|
204
|
+
this.#hostService.onOpenHelp(this.legacyHelpKey);
|
|
194
205
|
}
|
|
195
206
|
}
|
|
196
207
|
closeButtonClick() {
|
|
@@ -206,11 +217,11 @@ export class SkyModalComponent {
|
|
|
206
217
|
return this.#componentAdapter.modalContentHasDirectChildViewkeeper(this.#elRef);
|
|
207
218
|
}
|
|
208
219
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: SkyModalComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
209
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
|
220
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.4", type: SkyModalComponent, isStandalone: true, selector: "sky-modal", inputs: { formErrors: "formErrors", headingText: "headingText", helpKey: "helpKey", helpPopoverContent: "helpPopoverContent", helpPopoverTitle: "helpPopoverTitle", ariaRole: "ariaRole", tiledBody: "tiledBody", ariaDescribedBy: "ariaDescribedBy", ariaLabelledBy: "ariaLabelledBy" }, host: { listeners: { "document:keyup": "onDocumentKeyUp($event)", "document:keydown": "onDocumentKeyDown($event)" }, properties: { "class": "this.wrapperClass" } }, providers: [
|
|
210
221
|
SkyModalComponentAdapterService,
|
|
211
222
|
SkyModalErrorsService,
|
|
212
223
|
SkyDockService,
|
|
213
|
-
], 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 || modalContentId.id\"\n [attr.aria-labelledby]=\"ariaLabelledBy || headerId.id\"\n [attr.aria-owns]=\"ariaOwns\"\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 [
|
|
224
|
+
], 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 || modalContentId.id\"\n [attr.aria-labelledby]=\"ariaLabelledBy || headerId.id\"\n [attr.aria-owns]=\"ariaOwns\"\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 [ngStyle]=\"{\n 'box-shadow': scrollShadow?.topShadow\n }\"\n >\n <div\n class=\"sky-modal-header-content\"\n skyId\n [ngClass]=\"{\n 'sky-font-heading-2': size === 'full-page'\n }\"\n #headerId=\"skyId\"\n >\n @if (headingText) {\n <sky-modal-header>\n {{ headingText }}\n @if (helpKey || helpPopoverContent) {\n <sky-help-inline\n class=\"sky-control-help\"\n [helpKey]=\"helpKey\"\n [labelText]=\"headingText\"\n [popoverContent]=\"helpPopoverContent\"\n [popoverTitle]=\"helpPopoverTitle\"\n />\n }\n </sky-modal-header>\n } @else {\n <ng-content select=\"sky-modal-header\" />\n }\n </div>\n <div class=\"sky-modal-header-buttons\">\n <button\n *ngIf=\"legacyHelpKey\"\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\" />\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\" />\n </button>\n </div>\n </div>\n <div\n class=\"sky-modal-content sky-padding-even-large\"\n role=\"region\"\n tabindex=\"0\"\n skyId\n [attr.aria-labelledby]=\"headerId.id\"\n (skyModalScrollShadow)=\"scrollShadowChange($event)\"\n #modalContentId=\"skyId\"\n #modalContentWrapper\n >\n <ng-content select=\"sky-modal-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\" />\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}.sky-modal-header:has(.sky-modal-header-content:empty){display: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-background-color-page-default: #fff}.sky-modal-content:focus{outline-style:dotted;outline-width:thin;outline-offset:-1px}.sky-modal-tiled .sky-modal-content{background-color:#eeeeef;--sky-background-color-page-default: $sky-background-color-neutral-light}.sky-modal-tiled .sky-modal-content ::ng-deep .sky-tile-title{font-family:BLKB Sans,Helvetica Neue,Arial,sans-serif;color:var(--sky-text-color-deemphasized);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-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}.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;--sky-background-color-page-default: #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;--sky-background-color-page-default: #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-background-color-page-default: $sky-theme-modern-mode-dark-background-color-page-default}.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;--sky-background-color-page-default: $sky-theme-modern-mode-dark-background-color-page-default}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "ngmodule", type: SkyHelpInlineModule }, { kind: "component", type: i2.λ1, selector: "sky-help-inline", inputs: ["ariaControls", "ariaExpanded", "ariaLabel", "labelledBy", "labelText", "popoverContent", "popoverTitle", "helpKey"], outputs: ["actionClick"] }, { kind: "ngmodule", type: SkyIconModule }, { kind: "component", type: i3.λ1, selector: "sky-icon", inputs: ["icon", "iconType", "size", "fixedWidth", "variant"] }, { kind: "ngmodule", type: SkyIdModule }, { kind: "directive", type: i4.λ2, selector: "[skyId]", exportAs: ["skyId"] }, { kind: "component", type: SkyModalHeaderComponent, selector: "sky-modal-header" }, { kind: "directive", type: SkyModalScrollShadowDirective, selector: "[skyModalScrollShadow]", outputs: ["skyModalScrollShadow"] }, { kind: "ngmodule", type: SkyModalsResourcesModule }, { kind: "pipe", type: i5.SkyLibResourcesPipe, name: "skyLibResources" }] }); }
|
|
214
225
|
}
|
|
215
226
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: SkyModalComponent, decorators: [{
|
|
216
227
|
type: Component,
|
|
@@ -220,16 +231,26 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.4", ngImpor
|
|
|
220
231
|
SkyDockService,
|
|
221
232
|
], imports: [
|
|
222
233
|
CommonModule,
|
|
234
|
+
SkyHelpInlineModule,
|
|
223
235
|
SkyIconModule,
|
|
224
236
|
SkyIdModule,
|
|
237
|
+
SkyModalHeaderComponent,
|
|
225
238
|
SkyModalScrollShadowDirective,
|
|
226
239
|
SkyModalsResourcesModule,
|
|
227
|
-
], template: "<div\n class=\"sky-modal-dialog\"\n aria-modal=\"true\"\n [attr.aria-describedby]=\"ariaDescribedBy || modalContentId.id\"\n [attr.aria-labelledby]=\"ariaLabelledBy || headerId.id\"\n [attr.aria-owns]=\"ariaOwns\"\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 [
|
|
240
|
+
], template: "<div\n class=\"sky-modal-dialog\"\n aria-modal=\"true\"\n [attr.aria-describedby]=\"ariaDescribedBy || modalContentId.id\"\n [attr.aria-labelledby]=\"ariaLabelledBy || headerId.id\"\n [attr.aria-owns]=\"ariaOwns\"\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 [ngStyle]=\"{\n 'box-shadow': scrollShadow?.topShadow\n }\"\n >\n <div\n class=\"sky-modal-header-content\"\n skyId\n [ngClass]=\"{\n 'sky-font-heading-2': size === 'full-page'\n }\"\n #headerId=\"skyId\"\n >\n @if (headingText) {\n <sky-modal-header>\n {{ headingText }}\n @if (helpKey || helpPopoverContent) {\n <sky-help-inline\n class=\"sky-control-help\"\n [helpKey]=\"helpKey\"\n [labelText]=\"headingText\"\n [popoverContent]=\"helpPopoverContent\"\n [popoverTitle]=\"helpPopoverTitle\"\n />\n }\n </sky-modal-header>\n } @else {\n <ng-content select=\"sky-modal-header\" />\n }\n </div>\n <div class=\"sky-modal-header-buttons\">\n <button\n *ngIf=\"legacyHelpKey\"\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\" />\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\" />\n </button>\n </div>\n </div>\n <div\n class=\"sky-modal-content sky-padding-even-large\"\n role=\"region\"\n tabindex=\"0\"\n skyId\n [attr.aria-labelledby]=\"headerId.id\"\n (skyModalScrollShadow)=\"scrollShadowChange($event)\"\n #modalContentId=\"skyId\"\n #modalContentWrapper\n >\n <ng-content select=\"sky-modal-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\" />\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}.sky-modal-header:has(.sky-modal-header-content:empty){display: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-background-color-page-default: #fff}.sky-modal-content:focus{outline-style:dotted;outline-width:thin;outline-offset:-1px}.sky-modal-tiled .sky-modal-content{background-color:#eeeeef;--sky-background-color-page-default: $sky-background-color-neutral-light}.sky-modal-tiled .sky-modal-content ::ng-deep .sky-tile-title{font-family:BLKB Sans,Helvetica Neue,Arial,sans-serif;color:var(--sky-text-color-deemphasized);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-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}.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;--sky-background-color-page-default: #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;--sky-background-color-page-default: #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-background-color-page-default: $sky-theme-modern-mode-dark-background-color-page-default}.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;--sky-background-color-page-default: $sky-theme-modern-mode-dark-background-color-page-default}\n"] }]
|
|
228
241
|
}], ctorParameters: () => [], propDecorators: { wrapperClass: [{
|
|
229
242
|
type: HostBinding,
|
|
230
243
|
args: ['class']
|
|
231
244
|
}], formErrors: [{
|
|
232
245
|
type: Input
|
|
246
|
+
}], headingText: [{
|
|
247
|
+
type: Input
|
|
248
|
+
}], helpKey: [{
|
|
249
|
+
type: Input
|
|
250
|
+
}], helpPopoverContent: [{
|
|
251
|
+
type: Input
|
|
252
|
+
}], helpPopoverTitle: [{
|
|
253
|
+
type: Input
|
|
233
254
|
}], ariaRole: [{
|
|
234
255
|
type: Input
|
|
235
256
|
}], tiledBody: [{
|
|
@@ -248,4 +269,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.4", ngImpor
|
|
|
248
269
|
type: HostListener,
|
|
249
270
|
args: ['document:keydown', ['$event']]
|
|
250
271
|
}] } });
|
|
251
|
-
//# 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 { CommonModule } from '@angular/common';\nimport {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  HostBinding,\n  HostListener,\n  Input,\n  OnDestroy,\n  OnInit,\n  ViewChild,\n  inject,\n} from '@angular/core';\nimport {\n  SkyAppWindowRef,\n  SkyCoreAdapterService,\n  SkyDockLocation,\n  SkyDockService,\n  SkyIdModule,\n  SkyLiveAnnouncerService,\n  SkyResizeObserverMediaQueryService,\n} from '@skyux/core';\nimport { SkyIconModule } from '@skyux/icon';\n\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyModalsResourcesModule } from '../shared/sky-modals-resources.module';\n\nimport { SkyModalComponentAdapterService } from './modal-component-adapter.service';\nimport { SkyModalConfiguration } from './modal-configuration';\nimport { SkyModalError } from './modal-error';\nimport { SkyModalErrorsService } from './modal-errors.service';\nimport { SkyModalHostService } from './modal-host.service';\nimport { SkyModalScrollShadowEventArgs } from './modal-scroll-shadow-event-args';\nimport { SkyModalScrollShadowDirective } from './modal-scroll-shadow.directive';\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  standalone: true,\n  selector: 'sky-modal',\n  templateUrl: './modal.component.html',\n  styleUrls: ['./modal.component.scss'],\n  providers: [\n    SkyModalComponentAdapterService,\n    SkyModalErrorsService,\n    SkyDockService,\n  ],\n  imports: [\n    CommonModule,\n    SkyIconModule,\n    SkyIdModule,\n    SkyModalScrollShadowDirective,\n    SkyModalsResourcesModule,\n  ],\n})\nexport class SkyModalComponent implements AfterViewInit, OnDestroy, OnInit {\n  @HostBinding('class')\n  public wrapperClass: string | undefined;\n\n  /**\n   * A list of form-level errors to display to the user.\n   */\n  @Input()\n  public set formErrors(value: SkyModalError[] | undefined) {\n    this.#errorsSvc.updateErrors(value);\n  }\n\n  /**\n   * @internal\n   */\n  @Input()\n  public set ariaRole(value: string | undefined) {\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  /**\n   * @internal\n   */\n  @Input()\n  public set ariaDescribedBy(id: string | undefined) {\n    this.#_ariaDescribedBy = id;\n  }\n\n  public get ariaDescribedBy(): string | undefined {\n    return this.#_ariaDescribedBy;\n  }\n\n  /**\n   * @internal\n   */\n  @Input()\n  public set ariaLabelledBy(id: string | undefined) {\n    this.#_ariaLabelledBy = id;\n  }\n\n  public get ariaLabelledBy(): string | undefined {\n    return this.#_ariaLabelledBy;\n  }\n\n  public ariaOwns: string | null = null;\n\n  public helpKey: string | undefined;\n\n  public modalState = 'in';\n\n  public modalZIndex: number | undefined;\n\n  public scrollShadow: SkyModalScrollShadowEventArgs | undefined;\n\n  public size: string;\n\n  @ViewChild('modalContentWrapper', { read: ElementRef })\n  public modalContentWrapperElement: ElementRef | undefined;\n\n  #ngUnsubscribe = new Subject<void>();\n\n  #_ariaDescribedBy: string | undefined;\n  #_ariaLabelledBy: string | undefined;\n\n  readonly #changeDetector = inject(ChangeDetectorRef);\n  readonly #componentAdapter = inject(SkyModalComponentAdapterService);\n  readonly #coreAdapter = inject(SkyCoreAdapterService);\n  readonly #dockService = inject(SkyDockService, { host: true });\n  readonly #elRef = inject(ElementRef);\n  readonly #errorsSvc = inject(SkyModalErrorsService);\n  readonly #hostService = inject(SkyModalHostService);\n  readonly #liveAnnouncerSvc = inject(SkyLiveAnnouncerService);\n  readonly #mediaQueryService = inject(SkyResizeObserverMediaQueryService, {\n    optional: true,\n  });\n  readonly #windowRef = inject(SkyAppWindowRef);\n\n  /**\n   * This provider is optional to account for situations where a modal component\n   * is implemented without the modal service. For example, when a consumer tests\n   * a component that uses the modal component but doesn't launch the modal from\n   * the modal service before executing assertions.\n   */\n  readonly #config =\n    inject(SkyModalConfiguration, { optional: true }) ??\n    new SkyModalConfiguration();\n\n  constructor() {\n    this.ariaDescribedBy = this.#config.ariaDescribedBy;\n    this.ariaLabelledBy = this.#config.ariaLabelledBy;\n    this.ariaRole = this.#config.ariaRole;\n    this.helpKey = this.#config.helpKey;\n    this.tiledBody = this.#config.tiledBody;\n    this.wrapperClass = this.#config.wrapperClass;\n\n    this.size = this.#config.fullPage\n      ? 'full-page'\n      : this.#config.size?.toLowerCase() || 'medium';\n\n    this.modalZIndex = this.#hostService.zIndex;\n  }\n\n  @HostListener('document:keyup', ['$event'])\n  public onDocumentKeyUp(event: KeyboardEvent): void {\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): void {\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 ngOnInit(): void {\n    this.#liveAnnouncerSvc.announcerElementChanged\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((element) => {\n        if (element?.id) {\n          this.ariaOwns = element.id;\n          this.#changeDetector.markForCheck();\n        }\n      });\n  }\n\n  public ngAfterViewInit(): void {\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        updateResponsiveClasses: true,\n      });\n    }\n  }\n\n  public ngOnDestroy(): void {\n    /* istanbul ignore next */\n    if (this.#mediaQueryService) {\n      this.#mediaQueryService.unobserve();\n    }\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n  }\n\n  public helpButtonClick(): void {\n    if (this.helpKey) {\n      this.#hostService.onOpenHelp(this.helpKey);\n    }\n  }\n\n  public closeButtonClick(): void {\n    this.#hostService.onClose();\n  }\n\n  public windowResize(): void {\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 || modalContentId.id\"\n  [attr.aria-labelledby]=\"ariaLabelledBy || headerId.id\"\n  [attr.aria-owns]=\"ariaOwns\"\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        skyId\n        [ngClass]=\"{\n          'sky-font-heading-2': size === 'full-page'\n        }\"\n        #headerContent\n        #headerId=\"skyId\"\n      >\n        <ng-content select=\"sky-modal-header\" />\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\" />\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\" />\n        </button>\n      </div>\n    </div>\n    <div\n      class=\"sky-modal-content sky-padding-even-large\"\n      role=\"region\"\n      tabindex=\"0\"\n      skyId\n      [attr.aria-labelledby]=\"headerId.id\"\n      (skyModalScrollShadow)=\"scrollShadowChange($event)\"\n      #modalContentId=\"skyId\"\n      #modalContentWrapper\n    >\n      <ng-content select=\"sky-modal-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\" />\n    </div>\n  </div>\n</div>\n"]}
|
|
272
|
+
//# 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 { CommonModule } from '@angular/common';\nimport {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  HostBinding,\n  HostListener,\n  Input,\n  OnDestroy,\n  OnInit,\n  TemplateRef,\n  ViewChild,\n  inject,\n} from '@angular/core';\nimport {\n  SkyAppWindowRef,\n  SkyCoreAdapterService,\n  SkyDockLocation,\n  SkyDockService,\n  SkyIdModule,\n  SkyLiveAnnouncerService,\n  SkyResizeObserverMediaQueryService,\n} from '@skyux/core';\nimport { SkyHelpInlineModule } from '@skyux/help-inline';\nimport { SkyIconModule } from '@skyux/icon';\n\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyModalsResourcesModule } from '../shared/sky-modals-resources.module';\n\nimport { SkyModalComponentAdapterService } from './modal-component-adapter.service';\nimport { SkyModalConfiguration } from './modal-configuration';\nimport { SkyModalError } from './modal-error';\nimport { SkyModalErrorsService } from './modal-errors.service';\nimport { SkyModalHeaderComponent } from './modal-header.component';\nimport { SkyModalHostService } from './modal-host.service';\nimport { SkyModalScrollShadowEventArgs } from './modal-scroll-shadow-event-args';\nimport { SkyModalScrollShadowDirective } from './modal-scroll-shadow.directive';\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  standalone: true,\n  selector: 'sky-modal',\n  templateUrl: './modal.component.html',\n  styleUrls: ['./modal.component.scss'],\n  providers: [\n    SkyModalComponentAdapterService,\n    SkyModalErrorsService,\n    SkyDockService,\n  ],\n  imports: [\n    CommonModule,\n    SkyHelpInlineModule,\n    SkyIconModule,\n    SkyIdModule,\n    SkyModalHeaderComponent,\n    SkyModalScrollShadowDirective,\n    SkyModalsResourcesModule,\n  ],\n})\nexport class SkyModalComponent implements AfterViewInit, OnDestroy, OnInit {\n  @HostBinding('class')\n  public wrapperClass: string | undefined;\n\n  /**\n   * A list of form-level errors to display to the user.\n   */\n  @Input()\n  public set formErrors(value: SkyModalError[] | undefined) {\n    this.#errorsSvc.updateErrors(value);\n  }\n\n  /**\n   * The text to display as the modal's heading.\n   * @preview\n   */\n  @Input()\n  public headingText: string | undefined;\n\n  /**\n   * A help key that identifies the global help content to display. When specified, a [help inline](https://developer.blackbaud.com/skyux/components/help-inline) button is\n   * added to the modal header. Clicking the button invokes global help as configured by the application.\n   * @preview\n   */\n  @Input()\n  public helpKey: string | undefined;\n\n  /**\n   * The content of the help popover. When specified, a [help inline](https://developer.blackbaud.com/skyux/components/help-inline)\n   * button is added to the modal header. The help inline button displays a [popover](https://developer.blackbaud.com/skyux/components/popover)\n   * when clicked using the specified content and optional title.\n   * @preview\n   */\n  @Input()\n  public helpPopoverContent: string | TemplateRef<unknown> | undefined;\n\n  /**\n   * The title of the help popover. This property only applies when `helpPopoverContent` is\n   * also specified.\n   * @preview\n   */\n  @Input()\n  public helpPopoverTitle: string | undefined;\n\n  /**\n   * Used by the confirm component to set a different role for the modal.\n   * @internal\n   */\n  @Input()\n  public set ariaRole(value: string | undefined) {\n    this.ariaRoleOrDefault = value || ARIA_ROLE_DEFAULT;\n  }\n\n  public ariaRoleOrDefault = ARIA_ROLE_DEFAULT;\n\n  /**\n   * @internal\n   * @deprecated\n   */\n  @Input()\n  public tiledBody: boolean | undefined;\n\n  /**\n   * Used by the confirm component to set descriptive text without using a\n   * modal header.\n   * @internal\n   */\n  @Input()\n  public set ariaDescribedBy(id: string | undefined) {\n    this.#_ariaDescribedBy = id;\n  }\n\n  public get ariaDescribedBy(): string | undefined {\n    return this.#_ariaDescribedBy;\n  }\n\n  /**\n   * Used by the confirm component to set descriptive text without using a\n   * modal header.\n   * @internal\n   */\n  @Input()\n  public set ariaLabelledBy(id: string | undefined) {\n    this.#_ariaLabelledBy = id;\n  }\n\n  public get ariaLabelledBy(): string | undefined {\n    return this.#_ariaLabelledBy;\n  }\n\n  public ariaOwns: string | null = null;\n\n  /**\n   * @deprecated\n   */\n  public legacyHelpKey: string | undefined;\n\n  public modalState = 'in';\n\n  public modalZIndex: number | undefined;\n\n  public scrollShadow: SkyModalScrollShadowEventArgs | undefined;\n\n  public size: string;\n\n  @ViewChild('modalContentWrapper', { read: ElementRef })\n  public modalContentWrapperElement: ElementRef | undefined;\n\n  #ngUnsubscribe = new Subject<void>();\n\n  #_ariaDescribedBy: string | undefined;\n  #_ariaLabelledBy: string | undefined;\n\n  readonly #changeDetector = inject(ChangeDetectorRef);\n  readonly #componentAdapter = inject(SkyModalComponentAdapterService);\n  readonly #coreAdapter = inject(SkyCoreAdapterService);\n  readonly #dockService = inject(SkyDockService, { host: true });\n  readonly #elRef = inject(ElementRef);\n  readonly #errorsSvc = inject(SkyModalErrorsService);\n  readonly #hostService = inject(SkyModalHostService);\n  readonly #liveAnnouncerSvc = inject(SkyLiveAnnouncerService);\n  readonly #mediaQueryService = inject(SkyResizeObserverMediaQueryService, {\n    optional: true,\n  });\n  readonly #windowRef = inject(SkyAppWindowRef);\n\n  /**\n   * This provider is optional to account for situations where a modal component\n   * is implemented without the modal service. For example, when a consumer tests\n   * a component that uses the modal component but doesn't launch the modal from\n   * the modal service before executing assertions.\n   */\n  readonly #config =\n    inject(SkyModalConfiguration, { optional: true }) ??\n    new SkyModalConfiguration();\n\n  constructor() {\n    this.ariaDescribedBy = this.#config.ariaDescribedBy;\n    this.ariaLabelledBy = this.#config.ariaLabelledBy;\n    this.ariaRole = this.#config.ariaRole;\n    this.legacyHelpKey = this.#config.helpKey;\n    this.tiledBody = this.#config.tiledBody;\n    this.wrapperClass = this.#config.wrapperClass;\n\n    this.size = this.#config.fullPage\n      ? 'full-page'\n      : this.#config.size?.toLowerCase() || 'medium';\n\n    this.modalZIndex = this.#hostService.zIndex;\n  }\n\n  @HostListener('document:keyup', ['$event'])\n  public onDocumentKeyUp(event: KeyboardEvent): void {\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): void {\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 ngOnInit(): void {\n    this.#liveAnnouncerSvc.announcerElementChanged\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((element) => {\n        if (element?.id) {\n          this.ariaOwns = element.id;\n          this.#changeDetector.markForCheck();\n        }\n      });\n  }\n\n  public ngAfterViewInit(): void {\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        updateResponsiveClasses: true,\n      });\n    }\n  }\n\n  public ngOnDestroy(): void {\n    /* istanbul ignore next */\n    if (this.#mediaQueryService) {\n      this.#mediaQueryService.unobserve();\n    }\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n  }\n\n  /**\n   * @deprecated\n   */\n  public helpButtonClick(): void {\n    if (this.legacyHelpKey) {\n      this.#hostService.onOpenHelp(this.legacyHelpKey);\n    }\n  }\n\n  public closeButtonClick(): void {\n    this.#hostService.onClose();\n  }\n\n  public windowResize(): void {\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 || modalContentId.id\"\n  [attr.aria-labelledby]=\"ariaLabelledBy || headerId.id\"\n  [attr.aria-owns]=\"ariaOwns\"\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      [ngStyle]=\"{\n        'box-shadow': scrollShadow?.topShadow\n      }\"\n    >\n      <div\n        class=\"sky-modal-header-content\"\n        skyId\n        [ngClass]=\"{\n          'sky-font-heading-2': size === 'full-page'\n        }\"\n        #headerId=\"skyId\"\n      >\n        @if (headingText) {\n          <sky-modal-header>\n            {{ headingText }}\n            @if (helpKey || helpPopoverContent) {\n              <sky-help-inline\n                class=\"sky-control-help\"\n                [helpKey]=\"helpKey\"\n                [labelText]=\"headingText\"\n                [popoverContent]=\"helpPopoverContent\"\n                [popoverTitle]=\"helpPopoverTitle\"\n              />\n            }\n          </sky-modal-header>\n        } @else {\n          <ng-content select=\"sky-modal-header\" />\n        }\n      </div>\n      <div class=\"sky-modal-header-buttons\">\n        <button\n          *ngIf=\"legacyHelpKey\"\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\" />\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\" />\n        </button>\n      </div>\n    </div>\n    <div\n      class=\"sky-modal-content sky-padding-even-large\"\n      role=\"region\"\n      tabindex=\"0\"\n      skyId\n      [attr.aria-labelledby]=\"headerId.id\"\n      (skyModalScrollShadow)=\"scrollShadowChange($event)\"\n      #modalContentId=\"skyId\"\n      #modalContentWrapper\n    >\n      <ng-content select=\"sky-modal-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\" />\n    </div>\n  </div>\n</div>\n"]}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kYWwuaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL21vZGFscy9zcmMvbGliL21vZHVsZXMvbW9kYWwvbW9kYWwuaW50ZXJmYWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTdGF0aWNQcm92aWRlciB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG4vLyBUT0RPOiBkZWZhdWx0cyB3b24ndCBzaG93IGluIHRoZSBnZW5lcmF0ZWQgZG9jcyB1bnRpbCB0aGlzIHdvcmsgaXMgZG9uZTpcbi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9ibGFja2JhdWQvc2t5dXgtZG9jcy10b29scy9pc3N1ZXMvMzhcblxuLyoqXG4gKiBTcGVjaWZpZXMgY29uZmlndXJhdGlvbiBvcHRpb25zIGZvciBjcmVhdGluZyBhIG1vZGFsLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFNreU1vZGFsQ29uZmlndXJhdGlvbkludGVyZmFjZSB7XG4gIC8qKlxuICAgKiBXaGV0aGVyIHRvIGRpc3BsYXkgdGhlIG1vZGFsIGZ1bGwgc2NyZWVuLlxuICAgKiBUaGlzIHByb3BlcnR5IGRlZmF1bHRzIHRvIGBmYWxzZWAuXG4gICAqL1xuICBmdWxsUGFnZT86IGJvb2xlYW47XG5cbiAgLyoqXG4gICAqIFRoZSBzaXplIGZvciB0aGUgbW9kYWwuIFRoZSB2YWxpZCBvcHRpb25zIGFyZSBgc21hbGxgLCBgbWVkaXVtYCwgYW5kIGBsYXJnZWAuXG4gICAqIFRoaXMgcHJvcGVydHkgZGVmYXVsdHMgdG8gYG1lZGl1bWAuXG4gICAqL1xuICBzaXplPzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBBbiBhcnJheSBwcm9wZXJ0eSBvZiBgcHJvdmlkZXJzYC5cbiAgICogSW4gQW5ndWxhciwgYSBwcm92aWRlciBpcyBzb21ldGhpbmcgdGhhdCBjYW4gY3JlYXRlIG9yIGRlbGl2ZXIgYSBzZXJ2aWNlLlxuICAgKiBUaGlzIHByb3BlcnR5IGNhbiBiZSB1c2VkIHRvIHBhc3MgY29udGV4dCB2YWx1ZXMgZnJvbSB0aGUgY29tcG9uZW50IHRoYXQgbGF1bmNoZXMgdGhlIG1vZGFsIHRvIHRoZSBtb2RhbCBjb21wb25lbnQuXG4gICAqL1xuICBwcm92aWRlcnM/
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kYWwuaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL21vZGFscy9zcmMvbGliL21vZHVsZXMvbW9kYWwvbW9kYWwuaW50ZXJmYWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTdGF0aWNQcm92aWRlciB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG4vLyBUT0RPOiBkZWZhdWx0cyB3b24ndCBzaG93IGluIHRoZSBnZW5lcmF0ZWQgZG9jcyB1bnRpbCB0aGlzIHdvcmsgaXMgZG9uZTpcbi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9ibGFja2JhdWQvc2t5dXgtZG9jcy10b29scy9pc3N1ZXMvMzhcblxuLyoqXG4gKiBTcGVjaWZpZXMgY29uZmlndXJhdGlvbiBvcHRpb25zIGZvciBjcmVhdGluZyBhIG1vZGFsLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFNreU1vZGFsQ29uZmlndXJhdGlvbkludGVyZmFjZSB7XG4gIC8qKlxuICAgKiBXaGV0aGVyIHRvIGRpc3BsYXkgdGhlIG1vZGFsIGZ1bGwgc2NyZWVuLlxuICAgKiBUaGlzIHByb3BlcnR5IGRlZmF1bHRzIHRvIGBmYWxzZWAuXG4gICAqL1xuICBmdWxsUGFnZT86IGJvb2xlYW47XG5cbiAgLyoqXG4gICAqIFRoZSBzaXplIGZvciB0aGUgbW9kYWwuIFRoZSB2YWxpZCBvcHRpb25zIGFyZSBgc21hbGxgLCBgbWVkaXVtYCwgYW5kIGBsYXJnZWAuXG4gICAqIFRoaXMgcHJvcGVydHkgZGVmYXVsdHMgdG8gYG1lZGl1bWAuXG4gICAqL1xuICBzaXplPzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBBbiBhcnJheSBwcm9wZXJ0eSBvZiBgcHJvdmlkZXJzYC5cbiAgICogSW4gQW5ndWxhciwgYSBwcm92aWRlciBpcyBzb21ldGhpbmcgdGhhdCBjYW4gY3JlYXRlIG9yIGRlbGl2ZXIgYSBzZXJ2aWNlLlxuICAgKiBUaGlzIHByb3BlcnR5IGNhbiBiZSB1c2VkIHRvIHBhc3MgY29udGV4dCB2YWx1ZXMgZnJvbSB0aGUgY29tcG9uZW50IHRoYXQgbGF1bmNoZXMgdGhlIG1vZGFsIHRvIHRoZSBtb2RhbCBjb21wb25lbnQuXG4gICAqL1xuICBwcm92aWRlcnM/OiBTdGF0aWNQcm92aWRlcltdO1xuXG4gIC8qKlxuICAgKiBUaGUgSFRNTCBlbGVtZW50IElEIG9mIHRoZSBlbGVtZW50IHRoYXQgZGVzY3JpYmVzXG4gICAqIHRoZSBtb2RhbC4gVGhpcyBzZXRzIHRoZSBtb2RhbCdzIGBhcmlhLWRlc2NyaWJlZGJ5YCBhdHRyaWJ1dGUgdG8gcHJvdmlkZSBhIHRleHQgZXF1aXZhbGVudCBmb3JcbiAgICogW3RvIHN1cHBvcnQgYWNjZXNzaWJpbGl0eV0oaHR0cHM6Ly9kZXZlbG9wZXIuYmxhY2tiYXVkLmNvbS9za3l1eC9sZWFybi9hY2Nlc3NpYmlsaXR5KS5cbiAgICogVGhlIGRlc2NyaXB0aW9uIHR5cGljYWxseSBpbmNsdWRlcyB0ZXh0IG9uIHRoZSBtb2RhbCBidXQgbm90IG9uIGl0ZW1zIHRoYXQgdXNlcnMgaW50ZXJhY3RcbiAgICogd2l0aCwgc3VjaCBhcyBidXR0b25zIGFuZCBmb3Jtcy4gSWYgeW91IGRvIG5vdCBzcGVjaWZ5IGFuIElELCB0aGUgZGVmYXVsdCBkZXNjcmlwdGlvbiBpc1xuICAgKiB0aGUgY29udGVudCBvZiB0aGUgYHNreS1tb2RhbC1jb250ZW50YCBjb21wb25lbnQuXG4gICAqIEZvciBtb3JlIGluZm9ybWF0aW9uIGFib3V0IHRoZSBgYXJpYS1kZXNjcmliZWRieWAgYXR0cmlidXRlLCBzZWUgdGhlIFtXQUktQVJJQSBkZWZpbml0aW9uXShodHRwczovL3d3dy53My5vcmcvVFIvd2FpLWFyaWEvI2FyaWEtZGVzY3JpYmVkYnkpLlxuICAgKiBAZGVwcmVjYXRlZCBTZXQgYGhlYWRpbmdUZXh0YCBvbiB0aGUgbW9kYWwgY29tcG9uZW50IGluc3RlYWQuXG4gICAqL1xuICBhcmlhRGVzY3JpYmVkQnk/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFRoZSBIVE1MIGVsZW1lbnQgSUQgb2YgdGhlIGVsZW1lbnQgdGhhdCBsYWJlbHNcbiAgICogdGhlIG1vZGFsLiBUaGlzIHNldHMgdGhlIGBhcmlhLWxhYmVsbGVkYnlgIGF0dHJpYnV0ZSBmb3IgdGhlIG1vZGFsIHRvIHByb3ZpZGUgYSB0ZXh0IGVxdWl2YWxlbnQgZm9yXG4gICAqIFt0byBzdXBwb3J0IGFjY2Vzc2liaWxpdHldKGh0dHBzOi8vZGV2ZWxvcGVyLmJsYWNrYmF1ZC5jb20vc2t5dXgvbGVhcm4vYWNjZXNzaWJpbGl0eSkuXG4gICAqIFRoaXMgaXMgdHlwaWNhbGx5IGEgaGVhZGVyIGVsZW1lbnQsIGFuZCBpZiB5b3UgZG8gbm90IHNwZWNpZnkgYW4gSUQsIHRoZSBkZWZhdWx0IHZhbHVlXG4gICAqIGlzIHRoZSBjb250ZW50IG9mIHRoZSBgc2t5LW1vZGFsLWhlYWRlcmAgY29tcG9uZW50LlxuICAgKiBGb3IgbW9yZSBpbmZvcm1hdGlvbiBhYm91dCB0aGUgYGFyaWEtbGFiZWxsZWRieWAgYXR0cmlidXRlLCBzZWUgdGhlIFtXQUktQVJJQSBkZWZpbml0aW9uXShodHRwczovL3d3dy53My5vcmcvVFIvd2FpLWFyaWEvI2FyaWEtbGFiZWxsZWRieSkuXG4gICAqIEBkZXByZWNhdGVkIFNldCBgaGVhZGluZ1RleHRgIG9uIHRoZSBtb2RhbCBjb21wb25lbnQgaW5zdGVhZC5cbiAgICovXG4gIGFyaWFMYWJlbGxlZEJ5Pzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBUaGUgQVJJQSByb2xlIGZvciB0aGUgbW9kYWxcbiAgICogW3RvIHN1cHBvcnQgYWNjZXNzaWJpbGl0eV0oaHR0cHM6Ly9kZXZlbG9wZXIuYmxhY2tiYXVkLmNvbS9za3l1eC9sZWFybi9hY2Nlc3NpYmlsaXR5KVxuICAgKiBieSBpbmRpY2F0aW5nIGhvdyB0aGUgbW9kYWwgZnVuY3Rpb25zIGFuZCB3aGF0IGl0IGNvbnRyb2xzLiBGb3IgaW5mb3JtYXRpb24gYWJvdXRcbiAgICogaG93IGFuIEFSSUEgcm9sZSBpbmRpY2F0ZXMgd2hhdCBhbiBpdGVtIHJlcHJlc2VudHMgb24gYSB3ZWIgcGFnZSwgc2VlIHRoZVxuICAgKiBbV0FJLUFSSUEgcm9sZXMgbW9kZWxdKGh0dHA6Ly93d3cudzMub3JnL1dBSS9QRi9hcmlhLyNyb2xlcykuIEJ5IGRlZmF1bHQsIG1vZGFscyBzZXRcbiAgICogdGhlIEFSSUEgcm9sZSB0byBgZGlhbG9nYC5cbiAgICogQGRlZmF1bHQgXCJkaWFsb2dcIlxuICAgKi9cbiAgYXJpYVJvbGU/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFdoZXRoZXIgdGhlIG1vZGFsIHVzZXMgdGlsZXMuIFdoZW4gc2V0IHRvIGB0cnVlYCwgdGhlIG1vZGFsJ3MgYmFja2dyb3VuZCBzd2l0Y2hlc1xuICAgKiB0byBgJHNreS1iYWNrZ3JvdW5kLWNvbG9yLW5ldXRyYWwtbGlnaHRgIGFuZCB0aWxlIGhlYWRpbmdzIGFyZSBzdHlsZWQgYXMgc3Vic2VjdGlvbiBoZWFkaW5ncy5cbiAgICogVGhpcyBwcm9wZXJ0eSBkZWZhdWx0cyB0byBgZmFsc2VgLlxuICAgKiBAZGVwcmVjYXRlZCBUaWxlcyBpbnNpZGUgbW9kYWxzIGFyZSBubyBsb25nZXIgYSByZWNvbW1lbmRlZCBkZXNpZ24gcGF0dGVybi4gRm9yIGNvbXBsZXggZm9ybXMsIHVzZSBbc2VjdGlvbmVkIGZvcm1zXShodHRwczovL2RldmVsb3Blci5ibGFja2JhdWQuY29tL3NreXV4L2NvbXBvbmVudHMvc2VjdGlvbmVkLWZvcm0pIG9yIFtvdGhlciBmb3JtIGNvbnRhaW5lcnNdKGh0dHBzOi8vZGV2ZWxvcGVyLmJsYWNrYmF1ZC5jb20vc2t5dXgvZGVzaWduL2d1aWRlbGluZXMvZm9ybS1kZXNpZ24pIGluc3RlYWQuXG4gICAqL1xuICB0aWxlZEJvZHk/OiBib29sZWFuO1xuXG4gIC8qKlxuICAgKiBUaGUgYGhlbHBLZXlgIHN0cmluZy4gVGhpcyBwcm9wZXJ0eSBkaXNwbGF5c1xuICAgKiB0aGUgPGkgY2xhc3M9XCJmYSBmYS1xdWVzdGlvbi1jaXJjbGVcIiBhcmlhLWhpZGRlbj1cInRydWVcIj48L2k+IGJ1dHRvbiBpbiB0aGUgbW9kYWwgaGVhZGVyLlxuICAgKiBXaGVuIHVzZXJzIGNsaWNrIHRoaXMgYnV0dG9uLCB0aGUgYGhlbHBPcGVuZWRgIGV2ZW50IGJyb2FkY2FzdHMgdGhlIGBoZWxwS2V5YCBwYXJhbWV0ZXIuXG4gICAqIEJsYWNrYmF1ZCBkZXZlbG9wZXJzIGNhbiB1c2UgdGhlIEhlbHAgV2lkZ2V0LCB3aGljaCBpcyBmb3IgaW50ZXJuYWwgQmxhY2tiYXVkIHVzZSBvbmx5LCB0b1xuICAgKiBbZGlzcGxheSBoZWxwIGNvbnRlbnQgaW4gYSBmbHlvdXQgcGFuZWxdKGh0dHBzOi8vZG9jcy5ibGFja2JhdWQuY29tL2JiLWhlbHAtZG9jcy9jb21wb25lbnRzL21vZGFsLWhlYWRlcikuXG4gICAqIEBkZXByZWNhdGVkIFRvIGRpc3BsYXkgYSBoZWxwIGJ1dHRvbiBpbiB0aGUgbW9kYWwgaGVhZGVyLCBzZXQgZWl0aGVyIHRoZVxuICAgKiBgaGVscEtleWAgb3IgYGhlbHBQb3BvdmVyQ29udGVudGAgaW5wdXRzIG9uIHRoZSBtb2RhbCBjb21wb25lbnQuXG4gICAqL1xuICBoZWxwS2V5Pzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBUaGUgQ1NTIGNsYXNzIHRvIGFkZCB0byB0aGUgbW9kYWwsIHN1Y2ggYXMgYGFnLWN1c3RvbS1jb21wb25lbnQtcG9wdXBgIGZvclxuICAgKiB1c2luZyBhIG1vZGFsIGFzIHBhcnQgb2YgYSBjZWxsIGVkaXRvciBpbiBEYXRhIEVudHJ5IEdyaWQuXG4gICAqL1xuICB3cmFwcGVyQ2xhc3M/OiBzdHJpbmc7XG59XG4iXX0=
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { SkyComponentHarness } from '@skyux/core/testing';
|
|
2
|
+
import { SkyHelpInlineHarness } from '@skyux/help-inline/testing';
|
|
2
3
|
/**
|
|
3
4
|
* Harness for interacting with a modal component in tests.
|
|
4
5
|
*/
|
|
@@ -9,6 +10,7 @@ export class SkyModalHarness extends SkyComponentHarness {
|
|
|
9
10
|
static { this.hostSelector = 'sky-modal'; }
|
|
10
11
|
#getModal = this.locatorFor('.sky-modal');
|
|
11
12
|
#getModalDialog = this.locatorFor('.sky-modal-dialog');
|
|
13
|
+
#getModalHeading = this.locatorFor('.sky-modal-heading');
|
|
12
14
|
/**
|
|
13
15
|
* Gets a `HarnessPredicate` that can be used to search for a
|
|
14
16
|
* `SkyModalHarness` that meets certain criteria
|
|
@@ -17,13 +19,21 @@ export class SkyModalHarness extends SkyComponentHarness {
|
|
|
17
19
|
return SkyModalHarness.getDataSkyIdPredicate(filters);
|
|
18
20
|
}
|
|
19
21
|
/**
|
|
20
|
-
*
|
|
22
|
+
* Clicks the help inline button.
|
|
23
|
+
*/
|
|
24
|
+
async clickHelpInline() {
|
|
25
|
+
return (await this.#getHelpInline()).click();
|
|
26
|
+
}
|
|
27
|
+
/**
|
|
28
|
+
* Gets the aria-describedBy property of the modal.
|
|
29
|
+
* @deprecated
|
|
21
30
|
*/
|
|
22
31
|
async getAriaDescribedBy() {
|
|
23
32
|
return (await this.#getModalDialog()).getAttribute('aria-describedby');
|
|
24
33
|
}
|
|
25
34
|
/**
|
|
26
|
-
* Gets the aria-labelledBy property of the modal
|
|
35
|
+
* Gets the aria-labelledBy property of the modal.
|
|
36
|
+
* @deprecated
|
|
27
37
|
*/
|
|
28
38
|
async getAriaLabelledBy() {
|
|
29
39
|
return (await this.#getModalDialog()).getAttribute('aria-labelledby');
|
|
@@ -34,6 +44,24 @@ export class SkyModalHarness extends SkyComponentHarness {
|
|
|
34
44
|
async getAriaRole() {
|
|
35
45
|
return (await this.#getModalDialog()).getAttribute('role');
|
|
36
46
|
}
|
|
47
|
+
/**
|
|
48
|
+
* Gets the modal's heading text.
|
|
49
|
+
*/
|
|
50
|
+
async getHeadingText() {
|
|
51
|
+
return (await this.#getModalHeading()).text();
|
|
52
|
+
}
|
|
53
|
+
/**
|
|
54
|
+
* Gets the help popover content.
|
|
55
|
+
*/
|
|
56
|
+
async getHelpPopoverContent() {
|
|
57
|
+
return (await this.#getHelpInline()).getPopoverContent();
|
|
58
|
+
}
|
|
59
|
+
/**
|
|
60
|
+
* Gets the help popover title.
|
|
61
|
+
*/
|
|
62
|
+
async getHelpPopoverTitle() {
|
|
63
|
+
return (await this.#getHelpInline()).getPopoverTitle();
|
|
64
|
+
}
|
|
37
65
|
/**
|
|
38
66
|
* Gets the modal size.
|
|
39
67
|
*/
|
|
@@ -71,5 +99,12 @@ export class SkyModalHarness extends SkyComponentHarness {
|
|
|
71
99
|
const isDirtyAttribute = await modalHost.getAttribute('data-sky-modal-is-dirty');
|
|
72
100
|
return isDirtyAttribute === 'true';
|
|
73
101
|
}
|
|
102
|
+
async #getHelpInline() {
|
|
103
|
+
const harness = await this.locatorForOptional(SkyHelpInlineHarness)();
|
|
104
|
+
if (harness) {
|
|
105
|
+
return harness;
|
|
106
|
+
}
|
|
107
|
+
throw Error('No help inline found.');
|
|
108
|
+
}
|
|
74
109
|
}
|
|
75
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
110
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal-harness.js","sourceRoot":"","sources":["../../../../../../../libs/components/modals/testing/src/modal/modal-harness.ts"],"names":[],"mappings":"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","sourcesContent":["import { HarnessPredicate } from '@angular/cdk/testing';\nimport { TemplateRef } from '@angular/core';\nimport { SkyComponentHarness } from '@skyux/core/testing';\nimport { SkyHelpInlineHarness } from '@skyux/help-inline/testing';\n\nimport { SkyModalHarnessFilters } from './modal-harness-filters';\n\n/**\n * Harness for interacting with a modal component in tests.\n */\nexport class SkyModalHarness extends SkyComponentHarness {\n  /**\n   * @internal\n   */\n  public static hostSelector = 'sky-modal';\n\n  #getModal = this.locatorFor('.sky-modal');\n  #getModalDialog = this.locatorFor('.sky-modal-dialog');\n  #getModalHeading = this.locatorFor('.sky-modal-heading');\n\n  /**\n   * Gets a `HarnessPredicate` that can be used to search for a\n   * `SkyModalHarness` that meets certain criteria\n   */\n  public static with(\n    filters: SkyModalHarnessFilters,\n  ): HarnessPredicate<SkyModalHarness> {\n    return SkyModalHarness.getDataSkyIdPredicate(filters);\n  }\n\n  /**\n   * Clicks the help inline button.\n   */\n  public async clickHelpInline(): Promise<void> {\n    return (await this.#getHelpInline()).click();\n  }\n\n  /**\n   * Gets the aria-describedBy property of the modal.\n   * @deprecated\n   */\n  public async getAriaDescribedBy(): Promise<string | null> {\n    return (await this.#getModalDialog()).getAttribute('aria-describedby');\n  }\n\n  /**\n   * Gets the aria-labelledBy property of the modal.\n   * @deprecated\n   */\n  public async getAriaLabelledBy(): Promise<string | null> {\n    return (await this.#getModalDialog()).getAttribute('aria-labelledby');\n  }\n\n  /**\n   * Gets the role of the modal.\n   */\n  public async getAriaRole(): Promise<string | null> {\n    return (await this.#getModalDialog()).getAttribute('role');\n  }\n\n  /**\n   * Gets the modal's heading text.\n   */\n  public async getHeadingText(): Promise<string | undefined> {\n    return (await this.#getModalHeading()).text();\n  }\n\n  /**\n   * Gets the help popover content.\n   */\n  public async getHelpPopoverContent(): Promise<\n    TemplateRef<unknown> | string | undefined\n  > {\n    return (await this.#getHelpInline()).getPopoverContent();\n  }\n\n  /**\n   * Gets the help popover title.\n   */\n  public async getHelpPopoverTitle(): Promise<string | undefined> {\n    return (await this.#getHelpInline()).getPopoverTitle();\n  }\n\n  /**\n   * Gets the modal size.\n   */\n  public async getSize(): Promise<string> {\n    if (await this.isFullPage()) {\n      throw new Error(\n        'Size cannot be determined because size property is overridden when modal is full page',\n      );\n    }\n\n    const modal = await this.#getModal();\n\n    if (await modal.hasClass('sky-modal-small')) {\n      return 'small';\n    }\n\n    if (await modal.hasClass('sky-modal-large')) {\n      return 'large';\n    }\n\n    return 'medium';\n  }\n\n  /**\n   * Gets the wrapper class of the modal.\n   */\n  public async getWrapperClass(): Promise<string | undefined> {\n    return await (await this.host()).getProperty('className');\n  }\n\n  /**\n   * Whether the modal is full page.\n   */\n  public async isFullPage(): Promise<boolean> {\n    const modal = this.#getModal();\n    return (await modal).hasClass('sky-modal-full-page');\n  }\n\n  /**\n   * Whether the modal has {@link SkyModalIsDirtyDirective.isDirty} set to dirty.\n   */\n  public async isDirty(): Promise<boolean> {\n    const modalHost = await this.host();\n    const isDirtyAttribute = await modalHost.getAttribute(\n      'data-sky-modal-is-dirty',\n    );\n    return isDirtyAttribute === 'true';\n  }\n\n  async #getHelpInline(): Promise<SkyHelpInlineHarness> {\n    const harness = await this.locatorForOptional(SkyHelpInlineHarness)();\n\n    if (harness) {\n      return harness;\n    }\n\n    throw Error('No help inline found.');\n  }\n}\n"]}
|
|
@@ -3,6 +3,7 @@ import { SkyComponentHarness } from '@skyux/core/testing';
|
|
|
3
3
|
import { SkyConfirmType, SkyConfirmInstance, SkyConfirmService, SkyModalInstance, SkyModalService } from '@skyux/modals';
|
|
4
4
|
import * as i0 from '@angular/core';
|
|
5
5
|
import { NgModule, Injectable } from '@angular/core';
|
|
6
|
+
import { SkyHelpInlineHarness } from '@skyux/help-inline/testing';
|
|
6
7
|
|
|
7
8
|
/**
|
|
8
9
|
* Allows interaction with a SKY UX modal component.
|
|
@@ -525,6 +526,7 @@ class SkyModalHarness extends SkyComponentHarness {
|
|
|
525
526
|
static { this.hostSelector = 'sky-modal'; }
|
|
526
527
|
#getModal = this.locatorFor('.sky-modal');
|
|
527
528
|
#getModalDialog = this.locatorFor('.sky-modal-dialog');
|
|
529
|
+
#getModalHeading = this.locatorFor('.sky-modal-heading');
|
|
528
530
|
/**
|
|
529
531
|
* Gets a `HarnessPredicate` that can be used to search for a
|
|
530
532
|
* `SkyModalHarness` that meets certain criteria
|
|
@@ -533,13 +535,21 @@ class SkyModalHarness extends SkyComponentHarness {
|
|
|
533
535
|
return SkyModalHarness.getDataSkyIdPredicate(filters);
|
|
534
536
|
}
|
|
535
537
|
/**
|
|
536
|
-
*
|
|
538
|
+
* Clicks the help inline button.
|
|
539
|
+
*/
|
|
540
|
+
async clickHelpInline() {
|
|
541
|
+
return (await this.#getHelpInline()).click();
|
|
542
|
+
}
|
|
543
|
+
/**
|
|
544
|
+
* Gets the aria-describedBy property of the modal.
|
|
545
|
+
* @deprecated
|
|
537
546
|
*/
|
|
538
547
|
async getAriaDescribedBy() {
|
|
539
548
|
return (await this.#getModalDialog()).getAttribute('aria-describedby');
|
|
540
549
|
}
|
|
541
550
|
/**
|
|
542
|
-
* Gets the aria-labelledBy property of the modal
|
|
551
|
+
* Gets the aria-labelledBy property of the modal.
|
|
552
|
+
* @deprecated
|
|
543
553
|
*/
|
|
544
554
|
async getAriaLabelledBy() {
|
|
545
555
|
return (await this.#getModalDialog()).getAttribute('aria-labelledby');
|
|
@@ -550,6 +560,24 @@ class SkyModalHarness extends SkyComponentHarness {
|
|
|
550
560
|
async getAriaRole() {
|
|
551
561
|
return (await this.#getModalDialog()).getAttribute('role');
|
|
552
562
|
}
|
|
563
|
+
/**
|
|
564
|
+
* Gets the modal's heading text.
|
|
565
|
+
*/
|
|
566
|
+
async getHeadingText() {
|
|
567
|
+
return (await this.#getModalHeading()).text();
|
|
568
|
+
}
|
|
569
|
+
/**
|
|
570
|
+
* Gets the help popover content.
|
|
571
|
+
*/
|
|
572
|
+
async getHelpPopoverContent() {
|
|
573
|
+
return (await this.#getHelpInline()).getPopoverContent();
|
|
574
|
+
}
|
|
575
|
+
/**
|
|
576
|
+
* Gets the help popover title.
|
|
577
|
+
*/
|
|
578
|
+
async getHelpPopoverTitle() {
|
|
579
|
+
return (await this.#getHelpInline()).getPopoverTitle();
|
|
580
|
+
}
|
|
553
581
|
/**
|
|
554
582
|
* Gets the modal size.
|
|
555
583
|
*/
|
|
@@ -587,6 +615,13 @@ class SkyModalHarness extends SkyComponentHarness {
|
|
|
587
615
|
const isDirtyAttribute = await modalHost.getAttribute('data-sky-modal-is-dirty');
|
|
588
616
|
return isDirtyAttribute === 'true';
|
|
589
617
|
}
|
|
618
|
+
async #getHelpInline() {
|
|
619
|
+
const harness = await this.locatorForOptional(SkyHelpInlineHarness)();
|
|
620
|
+
if (harness) {
|
|
621
|
+
return harness;
|
|
622
|
+
}
|
|
623
|
+
throw Error('No help inline found.');
|
|
624
|
+
}
|
|
590
625
|
}
|
|
591
626
|
|
|
592
627
|
/**
|