@skyux/modals 8.6.0 → 9.0.0-alpha.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 +4 -4
- package/esm2022/lib/modules/confirm/confirm.component.mjs +112 -0
- package/{esm2020 → esm2022}/lib/modules/confirm/confirm.module.mjs +13 -13
- package/esm2022/lib/modules/confirm/confirm.service.mjs +54 -0
- package/esm2022/lib/modules/modal/modal-adapter.service.mjs +99 -0
- package/esm2022/lib/modules/modal/modal-component-adapter.service.mjs +101 -0
- package/{esm2020 → esm2022}/lib/modules/modal/modal-configuration.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/modal/modal-content.component.mjs +4 -4
- package/esm2022/lib/modules/modal/modal-errors.service.mjs +21 -0
- package/{esm2020 → esm2022}/lib/modules/modal/modal-footer.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/modal/modal-header.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/modal/modal-host-context.mjs +4 -4
- package/esm2022/lib/modules/modal/modal-host.component.mjs +163 -0
- package/esm2022/lib/modules/modal/modal-host.service.mjs +62 -0
- package/esm2022/lib/modules/modal/modal-instance.mjs +123 -0
- package/esm2022/lib/modules/modal/modal-is-dirty.directive.mjs +94 -0
- package/esm2022/lib/modules/modal/modal-scroll-shadow.directive.mjs +129 -0
- package/esm2022/lib/modules/modal/modal.component.mjs +229 -0
- package/{esm2020 → esm2022}/lib/modules/modal/modal.module.mjs +29 -29
- package/esm2022/lib/modules/modal/modal.service.mjs +97 -0
- package/esm2022/lib/modules/shared/sky-modals-resources.module.mjs +61 -0
- package/esm2022/testing/confirm/confirm-button-harness.mjs +46 -0
- package/esm2022/testing/confirm/confirm-harness.mjs +90 -0
- package/esm2022/testing/modal/modal-harness.mjs +75 -0
- package/esm2022/testing/modal-fixture.mjs +143 -0
- package/{fesm2020 → fesm2022}/skyux-modals-testing.mjs +60 -73
- package/{fesm2020 → fesm2022}/skyux-modals-testing.mjs.map +1 -1
- package/fesm2022/skyux-modals.mjs +1502 -0
- package/{fesm2015 → fesm2022}/skyux-modals.mjs.map +1 -1
- package/lib/modules/modal/modal-is-dirty.directive.d.ts +1 -1
- package/lib/modules/modal/modal.component.d.ts +1 -1
- package/package.json +16 -24
- package/esm2020/lib/modules/confirm/confirm.component.mjs +0 -114
- package/esm2020/lib/modules/confirm/confirm.service.mjs +0 -57
- package/esm2020/lib/modules/modal/modal-adapter.service.mjs +0 -101
- package/esm2020/lib/modules/modal/modal-component-adapter.service.mjs +0 -104
- package/esm2020/lib/modules/modal/modal-errors.service.mjs +0 -24
- package/esm2020/lib/modules/modal/modal-host.component.mjs +0 -164
- package/esm2020/lib/modules/modal/modal-host.service.mjs +0 -65
- package/esm2020/lib/modules/modal/modal-instance.mjs +0 -127
- package/esm2020/lib/modules/modal/modal-is-dirty.directive.mjs +0 -93
- package/esm2020/lib/modules/modal/modal-scroll-shadow.directive.mjs +0 -127
- package/esm2020/lib/modules/modal/modal.component.mjs +0 -228
- package/esm2020/lib/modules/modal/modal.service.mjs +0 -99
- package/esm2020/lib/modules/shared/sky-modals-resources.module.mjs +0 -61
- package/esm2020/testing/confirm/confirm-button-harness.mjs +0 -46
- package/esm2020/testing/confirm/confirm-harness.mjs +0 -97
- package/esm2020/testing/modal/modal-harness.mjs +0 -81
- package/esm2020/testing/modal-fixture.mjs +0 -145
- package/fesm2015/skyux-modals-testing.mjs +0 -409
- package/fesm2015/skyux-modals-testing.mjs.map +0 -1
- package/fesm2015/skyux-modals.mjs +0 -1522
- package/fesm2020/skyux-modals.mjs +0 -1510
- package/fesm2020/skyux-modals.mjs.map +0 -1
- /package/{esm2020 → esm2022}/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/confirm/confirm-button-action.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/confirm/confirm-button-config.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/confirm/confirm-button-style-type.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/confirm/confirm-button.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/confirm/confirm-closed-event-args.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/confirm/confirm-config-token.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/confirm/confirm-config.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/confirm/confirm-instance.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/confirm/confirm-type.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/modal/modal-before-close-handler.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/modal/modal-close-args.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/modal/modal-error.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/modal/modal-host-context-args.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/modal/modal-scroll-shadow-event-args.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/modal/modal.interface.mjs +0 -0
- /package/{esm2020 → esm2022}/skyux-modals.mjs +0 -0
- /package/{esm2020 → esm2022}/testing/confirm/confirm-button-harness-filters.mjs +0 -0
- /package/{esm2020 → esm2022}/testing/modal/modal-harness-filters.mjs +0 -0
- /package/{esm2020 → esm2022}/testing/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/testing/skyux-modals-testing.mjs +0 -0
package/documentation.json
CHANGED
|
@@ -4702,7 +4702,7 @@
|
|
|
4702
4702
|
{
|
|
4703
4703
|
"fileName": "modal-demo-modal.component.html",
|
|
4704
4704
|
"filePath": "/projects/modals/documentation/code-examples/inline-help/modal-demo-modal.component.html",
|
|
4705
|
-
"rawContents": "<form [formGroup]=\"demoForm\" (submit)=\"saveForm()\">\n <sky-modal>\n <sky-modal-header>\n Modal title\n <sky-help-inline\n class=\"sky-control-help\"\n (actionClick)=\"onActionClick()\"\n ></sky-help-inline>\n </sky-modal-header>\n <sky-modal-content>\n <sky-input-box
|
|
4705
|
+
"rawContents": "<form [formGroup]=\"demoForm\" (submit)=\"saveForm()\">\n <sky-modal>\n <sky-modal-header>\n Modal title\n <sky-help-inline\n class=\"sky-control-help\"\n (actionClick)=\"onActionClick()\"\n ></sky-help-inline>\n </sky-modal-header>\n <sky-modal-content>\n <sky-input-box labelText=\"An input inside a modal\">\n <input formControlName=\"value1\" type=\"text\" />\n </sky-input-box>\n </sky-modal-content>\n <sky-modal-footer>\n <button class=\"sky-btn sky-btn-primary\" type=\"submit\">Save</button>\n <button class=\"sky-btn sky-btn-link\" type=\"button\" (click)=\"cancelForm()\">\n Cancel\n </button>\n </sky-modal-footer>\n </sky-modal>\n</form>\n"
|
|
4706
4706
|
},
|
|
4707
4707
|
{
|
|
4708
4708
|
"fileName": "modal-demo-modal.component.ts",
|
|
@@ -4722,7 +4722,7 @@
|
|
|
4722
4722
|
{
|
|
4723
4723
|
"fileName": "modal-demo.module.ts",
|
|
4724
4724
|
"filePath": "/projects/modals/documentation/code-examples/inline-help/modal-demo.module.ts",
|
|
4725
|
-
"rawContents": "import { CommonModule } from '@angular/common';\nimport { NgModule } from '@angular/core';\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport {
|
|
4725
|
+
"rawContents": "import { CommonModule } from '@angular/common';\nimport { NgModule } from '@angular/core';\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport { SkyInputBoxModule } from '@skyux/forms';\nimport { SkyHelpInlineModule } from '@skyux/indicators';\nimport { SkyModalModule } from '@skyux/modals';\n\nimport { ModalDemoModalComponent } from './modal-demo-modal.component';\nimport { ModalDemoComponent } from './modal-demo.component';\n\n@NgModule({\n imports: [\n CommonModule,\n FormsModule,\n ReactiveFormsModule,\n SkyInputBoxModule,\n SkyModalModule,\n SkyHelpInlineModule,\n ],\n declarations: [ModalDemoComponent, ModalDemoModalComponent],\n exports: [ModalDemoComponent],\n})\nexport class ModalDemoModule {}\n"
|
|
4726
4726
|
},
|
|
4727
4727
|
{
|
|
4728
4728
|
"fileName": "modal-demo-context.ts",
|
|
@@ -4742,7 +4742,7 @@
|
|
|
4742
4742
|
{
|
|
4743
4743
|
"fileName": "modal-demo-modal.component.html",
|
|
4744
4744
|
"filePath": "/projects/modals/documentation/code-examples/modal/modal-demo-modal.component.html",
|
|
4745
|
-
"rawContents": "<form [formGroup]=\"demoForm\" (submit)=\"saveForm()\">\n <sky-modal data-sky-id=\"modal-demo\" [isDirty]=\"demoForm.dirty\">\n <sky-modal-header> Modal title </sky-modal-header>\n <sky-modal-content>\n <sky-input-box
|
|
4745
|
+
"rawContents": "<form [formGroup]=\"demoForm\" (submit)=\"saveForm()\">\n <sky-modal data-sky-id=\"modal-demo\" [isDirty]=\"demoForm.dirty\">\n <sky-modal-header> Modal title </sky-modal-header>\n <sky-modal-content>\n <sky-input-box labelText=\"An input inside a modal\">\n <input formControlName=\"value1\" type=\"text\" />\n </sky-input-box>\n </sky-modal-content>\n <sky-modal-footer>\n <button class=\"sky-btn sky-btn-primary\" type=\"submit\">Save</button>\n <button class=\"sky-btn sky-btn-link\" type=\"button\" (click)=\"cancelForm()\">\n Cancel\n </button>\n </sky-modal-footer>\n </sky-modal>\n</form>\n"
|
|
4746
4746
|
},
|
|
4747
4747
|
{
|
|
4748
4748
|
"fileName": "modal-demo-modal.component.ts",
|
|
@@ -4767,7 +4767,7 @@
|
|
|
4767
4767
|
{
|
|
4768
4768
|
"fileName": "modal-demo.module.ts",
|
|
4769
4769
|
"filePath": "/projects/modals/documentation/code-examples/modal/modal-demo.module.ts",
|
|
4770
|
-
"rawContents": "import { CommonModule } from '@angular/common';\nimport { NgModule } from '@angular/core';\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport {
|
|
4770
|
+
"rawContents": "import { CommonModule } from '@angular/common';\nimport { NgModule } from '@angular/core';\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport { SkyInputBoxModule } from '@skyux/forms';\nimport { SkyModalModule } from '@skyux/modals';\n\nimport { ModalDemoModalComponent } from './modal-demo-modal.component';\nimport { ModalDemoComponent } from './modal-demo.component';\n\n@NgModule({\n imports: [\n CommonModule,\n FormsModule,\n ReactiveFormsModule,\n SkyInputBoxModule,\n SkyModalModule,\n ],\n declarations: [ModalDemoComponent, ModalDemoModalComponent],\n exports: [ModalDemoComponent],\n})\nexport class ModalDemoModule {}\n"
|
|
4771
4771
|
}
|
|
4772
4772
|
]
|
|
4773
4773
|
}
|
|
@@ -0,0 +1,112 @@
|
|
|
1
|
+
import { Component, Inject } from '@angular/core';
|
|
2
|
+
import { ReplaySubject } from 'rxjs';
|
|
3
|
+
import { take } from 'rxjs/operators';
|
|
4
|
+
import { SKY_CONFIRM_CONFIG } from './confirm-config-token';
|
|
5
|
+
import { SkyConfirmType } from './confirm-type';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "../modal/modal-instance";
|
|
8
|
+
import * as i2 from "@skyux/i18n";
|
|
9
|
+
import * as i3 from "@skyux/core";
|
|
10
|
+
import * as i4 from "@angular/common";
|
|
11
|
+
import * as i5 from "../modal/modal.component";
|
|
12
|
+
import * as i6 from "../modal/modal-content.component";
|
|
13
|
+
import * as i7 from "@skyux/theme";
|
|
14
|
+
export class SkyConfirmComponent {
|
|
15
|
+
#config;
|
|
16
|
+
#modal;
|
|
17
|
+
#resourcesService;
|
|
18
|
+
constructor(config, modal, resourcesService, idService) {
|
|
19
|
+
this.preserveWhiteSpace = false;
|
|
20
|
+
this.isOkType = false;
|
|
21
|
+
this.#config = config;
|
|
22
|
+
this.#modal = modal;
|
|
23
|
+
this.#resourcesService = resourcesService;
|
|
24
|
+
if (config.type === SkyConfirmType.Custom &&
|
|
25
|
+
config.buttons &&
|
|
26
|
+
config.buttons.length > 0) {
|
|
27
|
+
this.buttons = this.#getCustomButtons(config.buttons);
|
|
28
|
+
}
|
|
29
|
+
else {
|
|
30
|
+
this.#getPresetButtons()
|
|
31
|
+
.pipe(take(1))
|
|
32
|
+
.subscribe((buttons) => {
|
|
33
|
+
this.buttons = buttons;
|
|
34
|
+
});
|
|
35
|
+
}
|
|
36
|
+
this.message = config.message;
|
|
37
|
+
this.body = config.body;
|
|
38
|
+
// Using the service here instead of the directive due to the confirm component's "body" container being conditional and thus a template variable being unavailable at an outer scope
|
|
39
|
+
this.bodyId = idService.generateId();
|
|
40
|
+
this.preserveWhiteSpace = !!config.preserveWhiteSpace;
|
|
41
|
+
this.isOkType = config.type === SkyConfirmType.OK;
|
|
42
|
+
}
|
|
43
|
+
close(button) {
|
|
44
|
+
const result = {
|
|
45
|
+
action: button.action,
|
|
46
|
+
};
|
|
47
|
+
this.#modal.close(result);
|
|
48
|
+
}
|
|
49
|
+
#getPresetButtons() {
|
|
50
|
+
const emitter = new ReplaySubject(1);
|
|
51
|
+
this.#resourcesService
|
|
52
|
+
.getStrings({
|
|
53
|
+
cancel: 'skyux_confirm_dialog_default_cancel_text',
|
|
54
|
+
no: 'skyux_confirm_dialog_default_no_text',
|
|
55
|
+
ok: 'skyux_confirm_dialog_default_ok_text',
|
|
56
|
+
yes: 'skyux_confirm_dialog_default_yes_text',
|
|
57
|
+
})
|
|
58
|
+
.subscribe((values) => {
|
|
59
|
+
const confirmButtons = [];
|
|
60
|
+
switch (this.#config.type) {
|
|
61
|
+
case SkyConfirmType.YesNoCancel:
|
|
62
|
+
case SkyConfirmType.YesCancel:
|
|
63
|
+
confirmButtons.push({
|
|
64
|
+
text: values.yes,
|
|
65
|
+
autofocus: true,
|
|
66
|
+
styleType: 'primary',
|
|
67
|
+
action: 'yes',
|
|
68
|
+
});
|
|
69
|
+
if (this.#config.type === SkyConfirmType.YesNoCancel) {
|
|
70
|
+
confirmButtons.push({
|
|
71
|
+
text: values.no,
|
|
72
|
+
styleType: 'default',
|
|
73
|
+
action: 'no',
|
|
74
|
+
});
|
|
75
|
+
}
|
|
76
|
+
confirmButtons.push({
|
|
77
|
+
text: values.cancel,
|
|
78
|
+
styleType: 'link',
|
|
79
|
+
action: 'cancel',
|
|
80
|
+
});
|
|
81
|
+
break;
|
|
82
|
+
default:
|
|
83
|
+
confirmButtons.push({
|
|
84
|
+
text: values.ok,
|
|
85
|
+
autofocus: true,
|
|
86
|
+
styleType: 'primary',
|
|
87
|
+
action: 'ok',
|
|
88
|
+
});
|
|
89
|
+
}
|
|
90
|
+
emitter.next(confirmButtons);
|
|
91
|
+
});
|
|
92
|
+
return emitter.asObservable();
|
|
93
|
+
}
|
|
94
|
+
#getCustomButtons(buttonConfig) {
|
|
95
|
+
return buttonConfig.map((config) => ({
|
|
96
|
+
text: config.text,
|
|
97
|
+
action: config.action,
|
|
98
|
+
styleType: config.styleType || 'default',
|
|
99
|
+
autofocus: config.autofocus || false,
|
|
100
|
+
}));
|
|
101
|
+
}
|
|
102
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyConfirmComponent, deps: [{ token: SKY_CONFIRM_CONFIG }, { token: i1.SkyModalInstance }, { token: i2.SkyLibResourcesService }, { token: i3.SkyIdService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
103
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.7", type: SkyConfirmComponent, selector: "sky-confirm", ngImport: i0, template: "<div class=\"sky-confirm\" [ngClass]=\"{ 'sky-confirm-type-ok': isOkType }\">\n <sky-modal\n ariaRole=\"alertdialog\"\n [ariaLabelledBy]=\"confirmMessage.id\"\n [ariaDescribedBy]=\"body ? bodyId : undefined\"\n >\n <sky-modal-content class=\"sky-confirm-content\">\n <!--\n The following \"magic comment\" keeps Prettier from adding line breaks\n inside the div and causing leading and trailing whitespace when\n `preserveWhiteSpace` is `true`.\n https://prettier.io/blog/2018/11/07/1.15.0.html#whitespace-sensitive-formatting\n -->\n <!-- display: inline -->\n <div\n class=\"sky-confirm-message\"\n [ngClass]=\"{\n 'sky-confirm-preserve-white-space': preserveWhiteSpace\n }\"\n [skyThemeClass]=\"{\n 'sky-font-display-4': 'default',\n 'sky-font-heading-1 sky-font-display-3': 'modern'\n }\"\n skyId\n #confirmMessage=\"skyId\"\n >{{ message }}</div\n >\n\n <!--\n The following \"magic comment\" keeps Prettier from adding line breaks\n inside the div and causing leading and trailing whitespace when\n `preserveWhiteSpace` is `true`.\n https://prettier.io/blog/2018/11/07/1.15.0.html#whitespace-sensitive-formatting\n -->\n <!-- display: inline -->\n <div\n *ngIf=\"body\"\n class=\"sky-confirm-body\"\n [id]=\"bodyId\"\n [ngClass]=\"{\n 'sky-confirm-preserve-white-space': preserveWhiteSpace\n }\"\n >{{ body }}</div\n >\n\n <div class=\"sky-confirm-buttons\">\n <button\n *ngFor=\"let button of buttons\"\n type=\"button\"\n class=\"sky-btn\"\n [ngClass]=\"'sky-btn-' + button.styleType\"\n [skyThemeClass]=\"{\n 'sky-margin-inline-sm': 'modern',\n 'sky-margin-inline-compact': 'default'\n }\"\n (click)=\"close(button)\"\n [attr.autofocus]=\"button.autofocus ? 'autofocus' : null\"\n >\n {{ button.text }}\n </button>\n </div>\n </sky-modal-content>\n </sky-modal>\n</div>\n", styles: [".sky-confirm{--sky-confirm-body-margin-top: var(--sky-margin-stacked-sm);--sky-confirm-buttons-margin-top: var(--sky-margin-stacked-xl);--sky-confirm-content-padding: 0;--sky-confirm-message-padding-bottom: 0}:host-context(.sky-theme-modern) .sky-confirm{--sky-confirm-body-margin-top: 0;--sky-confirm-buttons-margin-top: var(--sky-margin-stacked-lg);--sky-confirm-content-padding: var(--sky-margin-stacked-lg) var(--sky-margin-inline-xl);--sky-confirm-message-padding-bottom: var(--sky-margin-stacked-lg)}.sky-theme-modern .sky-confirm{--sky-confirm-body-margin-top: 0;--sky-confirm-buttons-margin-top: var(--sky-margin-stacked-lg);--sky-confirm-content-padding: var(--sky-margin-stacked-lg) var(--sky-margin-inline-xl);--sky-confirm-message-padding-bottom: var(--sky-margin-stacked-lg)}.sky-confirm-content{padding:var(--sky-confirm-content-padding)}.sky-confirm-message{margin-top:var(--sky-margin-stacked-xs);padding-bottom:var(--sky-confirm-message-padding-bottom)}.sky-confirm-body{margin-top:var(--sky-confirm-body-margin-top)}.sky-confirm-buttons{margin-top:var(--sky-confirm-buttons-margin-top)}.sky-confirm-preserve-white-space{white-space:pre-wrap}\n"], dependencies: [{ kind: "directive", type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.λ2, selector: "[skyId]", exportAs: ["skyId"] }, { kind: "component", type: i5.SkyModalComponent, selector: "sky-modal", inputs: ["formErrors", "ariaRole", "tiledBody", "ariaDescribedBy", "ariaLabelledBy"] }, { kind: "component", type: i6.SkyModalContentComponent, selector: "sky-modal-content" }, { kind: "directive", type: i7.λ2, selector: "[skyThemeClass]", inputs: ["class", "skyThemeClass"] }] }); }
|
|
104
|
+
}
|
|
105
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyConfirmComponent, decorators: [{
|
|
106
|
+
type: Component,
|
|
107
|
+
args: [{ selector: 'sky-confirm', template: "<div class=\"sky-confirm\" [ngClass]=\"{ 'sky-confirm-type-ok': isOkType }\">\n <sky-modal\n ariaRole=\"alertdialog\"\n [ariaLabelledBy]=\"confirmMessage.id\"\n [ariaDescribedBy]=\"body ? bodyId : undefined\"\n >\n <sky-modal-content class=\"sky-confirm-content\">\n <!--\n The following \"magic comment\" keeps Prettier from adding line breaks\n inside the div and causing leading and trailing whitespace when\n `preserveWhiteSpace` is `true`.\n https://prettier.io/blog/2018/11/07/1.15.0.html#whitespace-sensitive-formatting\n -->\n <!-- display: inline -->\n <div\n class=\"sky-confirm-message\"\n [ngClass]=\"{\n 'sky-confirm-preserve-white-space': preserveWhiteSpace\n }\"\n [skyThemeClass]=\"{\n 'sky-font-display-4': 'default',\n 'sky-font-heading-1 sky-font-display-3': 'modern'\n }\"\n skyId\n #confirmMessage=\"skyId\"\n >{{ message }}</div\n >\n\n <!--\n The following \"magic comment\" keeps Prettier from adding line breaks\n inside the div and causing leading and trailing whitespace when\n `preserveWhiteSpace` is `true`.\n https://prettier.io/blog/2018/11/07/1.15.0.html#whitespace-sensitive-formatting\n -->\n <!-- display: inline -->\n <div\n *ngIf=\"body\"\n class=\"sky-confirm-body\"\n [id]=\"bodyId\"\n [ngClass]=\"{\n 'sky-confirm-preserve-white-space': preserveWhiteSpace\n }\"\n >{{ body }}</div\n >\n\n <div class=\"sky-confirm-buttons\">\n <button\n *ngFor=\"let button of buttons\"\n type=\"button\"\n class=\"sky-btn\"\n [ngClass]=\"'sky-btn-' + button.styleType\"\n [skyThemeClass]=\"{\n 'sky-margin-inline-sm': 'modern',\n 'sky-margin-inline-compact': 'default'\n }\"\n (click)=\"close(button)\"\n [attr.autofocus]=\"button.autofocus ? 'autofocus' : null\"\n >\n {{ button.text }}\n </button>\n </div>\n </sky-modal-content>\n </sky-modal>\n</div>\n", styles: [".sky-confirm{--sky-confirm-body-margin-top: var(--sky-margin-stacked-sm);--sky-confirm-buttons-margin-top: var(--sky-margin-stacked-xl);--sky-confirm-content-padding: 0;--sky-confirm-message-padding-bottom: 0}:host-context(.sky-theme-modern) .sky-confirm{--sky-confirm-body-margin-top: 0;--sky-confirm-buttons-margin-top: var(--sky-margin-stacked-lg);--sky-confirm-content-padding: var(--sky-margin-stacked-lg) var(--sky-margin-inline-xl);--sky-confirm-message-padding-bottom: var(--sky-margin-stacked-lg)}.sky-theme-modern .sky-confirm{--sky-confirm-body-margin-top: 0;--sky-confirm-buttons-margin-top: var(--sky-margin-stacked-lg);--sky-confirm-content-padding: var(--sky-margin-stacked-lg) var(--sky-margin-inline-xl);--sky-confirm-message-padding-bottom: var(--sky-margin-stacked-lg)}.sky-confirm-content{padding:var(--sky-confirm-content-padding)}.sky-confirm-message{margin-top:var(--sky-margin-stacked-xs);padding-bottom:var(--sky-confirm-message-padding-bottom)}.sky-confirm-body{margin-top:var(--sky-confirm-body-margin-top)}.sky-confirm-buttons{margin-top:var(--sky-confirm-buttons-margin-top)}.sky-confirm-preserve-white-space{white-space:pre-wrap}\n"] }]
|
|
108
|
+
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
109
|
+
type: Inject,
|
|
110
|
+
args: [SKY_CONFIRM_CONFIG]
|
|
111
|
+
}] }, { type: i1.SkyModalInstance }, { type: i2.SkyLibResourcesService }, { type: i3.SkyIdService }]; } });
|
|
112
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"confirm.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/modals/src/lib/modules/confirm/confirm.component.ts","../../../../../../../../libs/components/modals/src/lib/modules/confirm/confirm.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Inject } from '@angular/core';\nimport { SkyIdService } from '@skyux/core';\nimport { SkyLibResourcesService } from '@skyux/i18n';\n\nimport { Observable, ReplaySubject } from 'rxjs';\nimport { take } from 'rxjs/operators';\n\nimport { SkyModalInstance } from '../modal/modal-instance';\n\nimport { SkyConfirmButton } from './confirm-button';\nimport { SkyConfirmButtonConfig } from './confirm-button-config';\nimport { SkyConfirmCloseEventArgs } from './confirm-closed-event-args';\nimport { SkyConfirmConfig } from './confirm-config';\nimport { SKY_CONFIRM_CONFIG } from './confirm-config-token';\nimport { SkyConfirmType } from './confirm-type';\n\n@Component({\n  selector: 'sky-confirm',\n  templateUrl: './confirm.component.html',\n  styleUrls: ['./confirm.component.scss'],\n})\nexport class SkyConfirmComponent {\n  public buttons: SkyConfirmButton[] | undefined;\n  public message: string;\n  public body: string | undefined;\n  public bodyId: string;\n  public preserveWhiteSpace = false;\n  public isOkType = false;\n\n  #config: SkyConfirmConfig;\n  #modal: SkyModalInstance;\n  #resourcesService: SkyLibResourcesService;\n\n  constructor(\n    @Inject(SKY_CONFIRM_CONFIG)\n    config: SkyConfirmConfig,\n    modal: SkyModalInstance,\n    resourcesService: SkyLibResourcesService,\n    idService: SkyIdService\n  ) {\n    this.#config = config;\n    this.#modal = modal;\n    this.#resourcesService = resourcesService;\n\n    if (\n      config.type === SkyConfirmType.Custom &&\n      config.buttons &&\n      config.buttons.length > 0\n    ) {\n      this.buttons = this.#getCustomButtons(config.buttons);\n    } else {\n      this.#getPresetButtons()\n        .pipe(take(1))\n        .subscribe((buttons: SkyConfirmButton[]) => {\n          this.buttons = buttons;\n        });\n    }\n\n    this.message = config.message;\n    this.body = config.body;\n    // Using the service here instead of the directive due to the confirm component's \"body\" container being conditional and thus a template variable being unavailable at an outer scope\n    this.bodyId = idService.generateId();\n    this.preserveWhiteSpace = !!config.preserveWhiteSpace;\n    this.isOkType = config.type === SkyConfirmType.OK;\n  }\n\n  public close(button: SkyConfirmButton): void {\n    const result: SkyConfirmCloseEventArgs = {\n      action: button.action,\n    };\n\n    this.#modal.close(result);\n  }\n\n  #getPresetButtons(): Observable<SkyConfirmButton[]> {\n    const emitter = new ReplaySubject<SkyConfirmButton[]>(1);\n\n    this.#resourcesService\n      .getStrings({\n        cancel: 'skyux_confirm_dialog_default_cancel_text',\n        no: 'skyux_confirm_dialog_default_no_text',\n        ok: 'skyux_confirm_dialog_default_ok_text',\n        yes: 'skyux_confirm_dialog_default_yes_text',\n      })\n      .subscribe((values) => {\n        const confirmButtons: SkyConfirmButton[] = [];\n\n        switch (this.#config.type) {\n          case SkyConfirmType.YesNoCancel:\n          case SkyConfirmType.YesCancel:\n            confirmButtons.push({\n              text: values.yes,\n              autofocus: true,\n              styleType: 'primary',\n              action: 'yes',\n            });\n\n            if (this.#config.type === SkyConfirmType.YesNoCancel) {\n              confirmButtons.push({\n                text: values.no,\n                styleType: 'default',\n                action: 'no',\n              });\n            }\n\n            confirmButtons.push({\n              text: values.cancel,\n              styleType: 'link',\n              action: 'cancel',\n            });\n            break;\n          default:\n            confirmButtons.push({\n              text: values.ok,\n              autofocus: true,\n              styleType: 'primary',\n              action: 'ok',\n            });\n        }\n\n        emitter.next(confirmButtons);\n      });\n\n    return emitter.asObservable();\n  }\n\n  #getCustomButtons(\n    buttonConfig: SkyConfirmButtonConfig[]\n  ): SkyConfirmButton[] {\n    return buttonConfig.map(\n      (config) =>\n        ({\n          text: config.text,\n          action: config.action,\n          styleType: config.styleType || 'default',\n          autofocus: config.autofocus || false,\n        } as SkyConfirmButton)\n    );\n  }\n}\n","<div class=\"sky-confirm\" [ngClass]=\"{ 'sky-confirm-type-ok': isOkType }\">\n  <sky-modal\n    ariaRole=\"alertdialog\"\n    [ariaLabelledBy]=\"confirmMessage.id\"\n    [ariaDescribedBy]=\"body ? bodyId : undefined\"\n  >\n    <sky-modal-content class=\"sky-confirm-content\">\n      <!--\n        The following \"magic comment\" keeps Prettier from adding line breaks\n        inside the div and causing leading and trailing whitespace when\n        `preserveWhiteSpace` is `true`.\n        https://prettier.io/blog/2018/11/07/1.15.0.html#whitespace-sensitive-formatting\n      -->\n      <!-- display: inline -->\n      <div\n        class=\"sky-confirm-message\"\n        [ngClass]=\"{\n          'sky-confirm-preserve-white-space': preserveWhiteSpace\n        }\"\n        [skyThemeClass]=\"{\n          'sky-font-display-4': 'default',\n          'sky-font-heading-1 sky-font-display-3': 'modern'\n        }\"\n        skyId\n        #confirmMessage=\"skyId\"\n        >{{ message }}</div\n      >\n\n      <!--\n        The following \"magic comment\" keeps Prettier from adding line breaks\n        inside the div and causing leading and trailing whitespace when\n        `preserveWhiteSpace` is `true`.\n        https://prettier.io/blog/2018/11/07/1.15.0.html#whitespace-sensitive-formatting\n      -->\n      <!-- display: inline -->\n      <div\n        *ngIf=\"body\"\n        class=\"sky-confirm-body\"\n        [id]=\"bodyId\"\n        [ngClass]=\"{\n          'sky-confirm-preserve-white-space': preserveWhiteSpace\n        }\"\n        >{{ body }}</div\n      >\n\n      <div class=\"sky-confirm-buttons\">\n        <button\n          *ngFor=\"let button of buttons\"\n          type=\"button\"\n          class=\"sky-btn\"\n          [ngClass]=\"'sky-btn-' + button.styleType\"\n          [skyThemeClass]=\"{\n            'sky-margin-inline-sm': 'modern',\n            'sky-margin-inline-compact': 'default'\n          }\"\n          (click)=\"close(button)\"\n          [attr.autofocus]=\"button.autofocus ? 'autofocus' : null\"\n        >\n          {{ button.text }}\n        </button>\n      </div>\n    </sky-modal-content>\n  </sky-modal>\n</div>\n"]}
|
|
@@ -7,19 +7,19 @@ import { SkyModalsResourcesModule } from '../shared/sky-modals-resources.module'
|
|
|
7
7
|
import { SkyConfirmComponent } from './confirm.component';
|
|
8
8
|
import * as i0 from "@angular/core";
|
|
9
9
|
export class SkyConfirmModule {
|
|
10
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyConfirmModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
11
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.1.7", ngImport: i0, type: SkyConfirmModule, declarations: [SkyConfirmComponent], imports: [CommonModule,
|
|
12
|
+
SkyIdModule,
|
|
13
|
+
SkyModalModule,
|
|
14
|
+
SkyModalsResourcesModule,
|
|
15
|
+
SkyThemeModule], exports: [SkyConfirmComponent] }); }
|
|
16
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyConfirmModule, imports: [CommonModule,
|
|
17
|
+
SkyIdModule,
|
|
18
|
+
SkyModalModule,
|
|
19
|
+
SkyModalsResourcesModule,
|
|
20
|
+
SkyThemeModule] }); }
|
|
10
21
|
}
|
|
11
|
-
|
|
12
|
-
SkyConfirmModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.9", ngImport: i0, type: SkyConfirmModule, declarations: [SkyConfirmComponent], imports: [CommonModule,
|
|
13
|
-
SkyIdModule,
|
|
14
|
-
SkyModalModule,
|
|
15
|
-
SkyModalsResourcesModule,
|
|
16
|
-
SkyThemeModule], exports: [SkyConfirmComponent] });
|
|
17
|
-
SkyConfirmModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyConfirmModule, imports: [CommonModule,
|
|
18
|
-
SkyIdModule,
|
|
19
|
-
SkyModalModule,
|
|
20
|
-
SkyModalsResourcesModule,
|
|
21
|
-
SkyThemeModule] });
|
|
22
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyConfirmModule, decorators: [{
|
|
22
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyConfirmModule, decorators: [{
|
|
23
23
|
type: NgModule,
|
|
24
24
|
args: [{
|
|
25
25
|
declarations: [SkyConfirmComponent],
|
|
@@ -33,4 +33,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
|
|
|
33
33
|
exports: [SkyConfirmComponent],
|
|
34
34
|
}]
|
|
35
35
|
}] });
|
|
36
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
36
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlybS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvbW9kYWxzL3NyYy9saWIvbW9kdWxlcy9jb25maXJtL2NvbmZpcm0ubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFDMUMsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUU5QyxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFDdkQsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sdUNBQXVDLENBQUM7QUFFakYsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0scUJBQXFCLENBQUM7O0FBYTFELE1BQU0sT0FBTyxnQkFBZ0I7OEdBQWhCLGdCQUFnQjsrR0FBaEIsZ0JBQWdCLGlCQVZaLG1CQUFtQixhQUVoQyxZQUFZO1lBQ1osV0FBVztZQUNYLGNBQWM7WUFDZCx3QkFBd0I7WUFDeEIsY0FBYyxhQUVOLG1CQUFtQjsrR0FFbEIsZ0JBQWdCLFlBUnpCLFlBQVk7WUFDWixXQUFXO1lBQ1gsY0FBYztZQUNkLHdCQUF3QjtZQUN4QixjQUFjOzsyRkFJTCxnQkFBZ0I7a0JBWDVCLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLENBQUMsbUJBQW1CLENBQUM7b0JBQ25DLE9BQU8sRUFBRTt3QkFDUCxZQUFZO3dCQUNaLFdBQVc7d0JBQ1gsY0FBYzt3QkFDZCx3QkFBd0I7d0JBQ3hCLGNBQWM7cUJBQ2Y7b0JBQ0QsT0FBTyxFQUFFLENBQUMsbUJBQW1CLENBQUM7aUJBQy9CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBTa3lJZE1vZHVsZSB9IGZyb20gJ0Bza3l1eC9jb3JlJztcbmltcG9ydCB7IFNreVRoZW1lTW9kdWxlIH0gZnJvbSAnQHNreXV4L3RoZW1lJztcblxuaW1wb3J0IHsgU2t5TW9kYWxNb2R1bGUgfSBmcm9tICcuLi9tb2RhbC9tb2RhbC5tb2R1bGUnO1xuaW1wb3J0IHsgU2t5TW9kYWxzUmVzb3VyY2VzTW9kdWxlIH0gZnJvbSAnLi4vc2hhcmVkL3NreS1tb2RhbHMtcmVzb3VyY2VzLm1vZHVsZSc7XG5cbmltcG9ydCB7IFNreUNvbmZpcm1Db21wb25lbnQgfSBmcm9tICcuL2NvbmZpcm0uY29tcG9uZW50JztcblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbU2t5Q29uZmlybUNvbXBvbmVudF0sXG4gIGltcG9ydHM6IFtcbiAgICBDb21tb25Nb2R1bGUsXG4gICAgU2t5SWRNb2R1bGUsXG4gICAgU2t5TW9kYWxNb2R1bGUsXG4gICAgU2t5TW9kYWxzUmVzb3VyY2VzTW9kdWxlLFxuICAgIFNreVRoZW1lTW9kdWxlLFxuICBdLFxuICBleHBvcnRzOiBbU2t5Q29uZmlybUNvbXBvbmVudF0sXG59KVxuZXhwb3J0IGNsYXNzIFNreUNvbmZpcm1Nb2R1bGUge31cbiJdfQ==
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import { SKY_CONFIRM_CONFIG } from './confirm-config-token';
|
|
3
|
+
import { SkyConfirmInstance } from './confirm-instance';
|
|
4
|
+
import { SkyConfirmComponent } from './confirm.component';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "../modal/modal.service";
|
|
7
|
+
/**
|
|
8
|
+
* Launches a dialog.
|
|
9
|
+
*/
|
|
10
|
+
export class SkyConfirmService {
|
|
11
|
+
#modalService;
|
|
12
|
+
constructor(modalService) {
|
|
13
|
+
this.#modalService = modalService;
|
|
14
|
+
}
|
|
15
|
+
/**
|
|
16
|
+
* Opens a dialog using the specified options.
|
|
17
|
+
* @param config Specifies configuration options for the dialog.
|
|
18
|
+
*/
|
|
19
|
+
open(config) {
|
|
20
|
+
const modalInstance = this.#modalService.open(SkyConfirmComponent, {
|
|
21
|
+
providers: [
|
|
22
|
+
{
|
|
23
|
+
provide: SKY_CONFIRM_CONFIG,
|
|
24
|
+
useValue: config,
|
|
25
|
+
},
|
|
26
|
+
],
|
|
27
|
+
});
|
|
28
|
+
const confirmInstance = new SkyConfirmInstance();
|
|
29
|
+
modalInstance.closed.subscribe((args) => {
|
|
30
|
+
let result = args.data;
|
|
31
|
+
// The modal was closed using the ESC key.
|
|
32
|
+
if (result === undefined) {
|
|
33
|
+
result = {
|
|
34
|
+
action: 'cancel',
|
|
35
|
+
};
|
|
36
|
+
}
|
|
37
|
+
confirmInstance.closed.emit(result);
|
|
38
|
+
confirmInstance.closed.complete();
|
|
39
|
+
});
|
|
40
|
+
return confirmInstance;
|
|
41
|
+
}
|
|
42
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyConfirmService, deps: [{ token: i1.SkyModalService }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
43
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyConfirmService, providedIn: 'any' }); }
|
|
44
|
+
}
|
|
45
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyConfirmService, decorators: [{
|
|
46
|
+
type: Injectable,
|
|
47
|
+
args: [{
|
|
48
|
+
// Must be 'any' so that the modal component is created in the context of its module's injector.
|
|
49
|
+
// If set to 'root', the component's dependency injections would only be derived from the root
|
|
50
|
+
// injector and may loose context if the modal was opened from within a lazy-loaded module.
|
|
51
|
+
providedIn: 'any',
|
|
52
|
+
}]
|
|
53
|
+
}], ctorParameters: function () { return [{ type: i1.SkyModalService }]; } });
|
|
54
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlybS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL21vZGFscy9zcmMvbGliL21vZHVsZXMvY29uZmlybS9jb25maXJtLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQVEzQyxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUM1RCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUN4RCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQzs7O0FBRTFEOztHQUVHO0FBT0gsTUFBTSxPQUFPLGlCQUFpQjtJQUM1QixhQUFhLENBQWtCO0lBRS9CLFlBQVksWUFBNkI7UUFDdkMsSUFBSSxDQUFDLGFBQWEsR0FBRyxZQUFZLENBQUM7SUFDcEMsQ0FBQztJQUVEOzs7T0FHRztJQUNJLElBQUksQ0FBQyxNQUF3QjtRQUNsQyxNQUFNLGFBQWEsR0FBcUIsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQzdELG1CQUFtQixFQUNuQjtZQUNFLFNBQVMsRUFBRTtnQkFDVDtvQkFDRSxPQUFPLEVBQUUsa0JBQWtCO29CQUMzQixRQUFRLEVBQUUsTUFBTTtpQkFDakI7YUFDRjtTQUNGLENBQ0YsQ0FBQztRQUVGLE1BQU0sZUFBZSxHQUFHLElBQUksa0JBQWtCLEVBQUUsQ0FBQztRQUVqRCxhQUFhLENBQUMsTUFBTSxDQUFDLFNBQVMsQ0FBQyxDQUFDLElBQXVCLEVBQUUsRUFBRTtZQUN6RCxJQUFJLE1BQU0sR0FBNkIsSUFBSSxDQUFDLElBQUksQ0FBQztZQUVqRCwwQ0FBMEM7WUFDMUMsSUFBSSxNQUFNLEtBQUssU0FBUyxFQUFFO2dCQUN4QixNQUFNLEdBQUc7b0JBQ1AsTUFBTSxFQUFFLFFBQVE7aUJBQ2pCLENBQUM7YUFDSDtZQUVELGVBQWUsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1lBQ3BDLGVBQWUsQ0FBQyxNQUFNLENBQUMsUUFBUSxFQUFFLENBQUM7UUFDcEMsQ0FBQyxDQUFDLENBQUM7UUFFSCxPQUFPLGVBQWUsQ0FBQztJQUN6QixDQUFDOzhHQXpDVSxpQkFBaUI7a0hBQWpCLGlCQUFpQixjQUZoQixLQUFLOzsyRkFFTixpQkFBaUI7a0JBTjdCLFVBQVU7bUJBQUM7b0JBQ1YsZ0dBQWdHO29CQUNoRyw4RkFBOEY7b0JBQzlGLDJGQUEyRjtvQkFDM0YsVUFBVSxFQUFFLEtBQUs7aUJBQ2xCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBTa3lNb2RhbENsb3NlQXJncyB9IGZyb20gJy4uL21vZGFsL21vZGFsLWNsb3NlLWFyZ3MnO1xuaW1wb3J0IHsgU2t5TW9kYWxJbnN0YW5jZSB9IGZyb20gJy4uL21vZGFsL21vZGFsLWluc3RhbmNlJztcbmltcG9ydCB7IFNreU1vZGFsU2VydmljZSB9IGZyb20gJy4uL21vZGFsL21vZGFsLnNlcnZpY2UnO1xuXG5pbXBvcnQgeyBTa3lDb25maXJtQ2xvc2VFdmVudEFyZ3MgfSBmcm9tICcuL2NvbmZpcm0tY2xvc2VkLWV2ZW50LWFyZ3MnO1xuaW1wb3J0IHsgU2t5Q29uZmlybUNvbmZpZyB9IGZyb20gJy4vY29uZmlybS1jb25maWcnO1xuaW1wb3J0IHsgU0tZX0NPTkZJUk1fQ09ORklHIH0gZnJvbSAnLi9jb25maXJtLWNvbmZpZy10b2tlbic7XG5pbXBvcnQgeyBTa3lDb25maXJtSW5zdGFuY2UgfSBmcm9tICcuL2NvbmZpcm0taW5zdGFuY2UnO1xuaW1wb3J0IHsgU2t5Q29uZmlybUNvbXBvbmVudCB9IGZyb20gJy4vY29uZmlybS5jb21wb25lbnQnO1xuXG4vKipcbiAqIExhdW5jaGVzIGEgZGlhbG9nLlxuICovXG5ASW5qZWN0YWJsZSh7XG4gIC8vIE11c3QgYmUgJ2FueScgc28gdGhhdCB0aGUgbW9kYWwgY29tcG9uZW50IGlzIGNyZWF0ZWQgaW4gdGhlIGNvbnRleHQgb2YgaXRzIG1vZHVsZSdzIGluamVjdG9yLlxuICAvLyBJZiBzZXQgdG8gJ3Jvb3QnLCB0aGUgY29tcG9uZW50J3MgZGVwZW5kZW5jeSBpbmplY3Rpb25zIHdvdWxkIG9ubHkgYmUgZGVyaXZlZCBmcm9tIHRoZSByb290XG4gIC8vIGluamVjdG9yIGFuZCBtYXkgbG9vc2UgY29udGV4dCBpZiB0aGUgbW9kYWwgd2FzIG9wZW5lZCBmcm9tIHdpdGhpbiBhIGxhenktbG9hZGVkIG1vZHVsZS5cbiAgcHJvdmlkZWRJbjogJ2FueScsXG59KVxuZXhwb3J0IGNsYXNzIFNreUNvbmZpcm1TZXJ2aWNlIHtcbiAgI21vZGFsU2VydmljZTogU2t5TW9kYWxTZXJ2aWNlO1xuXG4gIGNvbnN0cnVjdG9yKG1vZGFsU2VydmljZTogU2t5TW9kYWxTZXJ2aWNlKSB7XG4gICAgdGhpcy4jbW9kYWxTZXJ2aWNlID0gbW9kYWxTZXJ2aWNlO1xuICB9XG5cbiAgLyoqXG4gICAqIE9wZW5zIGEgZGlhbG9nIHVzaW5nIHRoZSBzcGVjaWZpZWQgb3B0aW9ucy5cbiAgICogQHBhcmFtIGNvbmZpZyBTcGVjaWZpZXMgY29uZmlndXJhdGlvbiBvcHRpb25zIGZvciB0aGUgZGlhbG9nLlxuICAgKi9cbiAgcHVibGljIG9wZW4oY29uZmlnOiBTa3lDb25maXJtQ29uZmlnKTogU2t5Q29uZmlybUluc3RhbmNlIHtcbiAgICBjb25zdCBtb2RhbEluc3RhbmNlOiBTa3lNb2RhbEluc3RhbmNlID0gdGhpcy4jbW9kYWxTZXJ2aWNlLm9wZW4oXG4gICAgICBTa3lDb25maXJtQ29tcG9uZW50LFxuICAgICAge1xuICAgICAgICBwcm92aWRlcnM6IFtcbiAgICAgICAgICB7XG4gICAgICAgICAgICBwcm92aWRlOiBTS1lfQ09ORklSTV9DT05GSUcsXG4gICAgICAgICAgICB1c2VWYWx1ZTogY29uZmlnLFxuICAgICAgICAgIH0sXG4gICAgICAgIF0sXG4gICAgICB9XG4gICAgKTtcblxuICAgIGNvbnN0IGNvbmZpcm1JbnN0YW5jZSA9IG5ldyBTa3lDb25maXJtSW5zdGFuY2UoKTtcblxuICAgIG1vZGFsSW5zdGFuY2UuY2xvc2VkLnN1YnNjcmliZSgoYXJnczogU2t5TW9kYWxDbG9zZUFyZ3MpID0+IHtcbiAgICAgIGxldCByZXN1bHQ6IFNreUNvbmZpcm1DbG9zZUV2ZW50QXJncyA9IGFyZ3MuZGF0YTtcblxuICAgICAgLy8gVGhlIG1vZGFsIHdhcyBjbG9zZWQgdXNpbmcgdGhlIEVTQyBrZXkuXG4gICAgICBpZiAocmVzdWx0ID09PSB1bmRlZmluZWQpIHtcbiAgICAgICAgcmVzdWx0ID0ge1xuICAgICAgICAgIGFjdGlvbjogJ2NhbmNlbCcsXG4gICAgICAgIH07XG4gICAgICB9XG5cbiAgICAgIGNvbmZpcm1JbnN0YW5jZS5jbG9zZWQuZW1pdChyZXN1bHQpO1xuICAgICAgY29uZmlybUluc3RhbmNlLmNsb3NlZC5jb21wbGV0ZSgpO1xuICAgIH0pO1xuXG4gICAgcmV0dXJuIGNvbmZpcm1JbnN0YW5jZTtcbiAgfVxufVxuIl19
|
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@skyux/core";
|
|
4
|
+
/**
|
|
5
|
+
* @internal
|
|
6
|
+
*/
|
|
7
|
+
export class SkyModalAdapterService {
|
|
8
|
+
static { this.MODAL_BODY_FULL_CLASS = 'sky-modal-body-full-page'; }
|
|
9
|
+
static { this.MODAL_BODY_CLASS = 'sky-modal-body-open'; }
|
|
10
|
+
#docRef;
|
|
11
|
+
#bodyEl;
|
|
12
|
+
#windowRef;
|
|
13
|
+
#hostSiblingAriaHiddenCache = new Map();
|
|
14
|
+
constructor(windowRef) {
|
|
15
|
+
this.#windowRef = windowRef;
|
|
16
|
+
this.#docRef = this.#windowRef.nativeWindow.document;
|
|
17
|
+
this.#bodyEl = this.#windowRef.nativeWindow.document.body;
|
|
18
|
+
}
|
|
19
|
+
toggleFullPageModalClass(isAddFull) {
|
|
20
|
+
if (isAddFull) {
|
|
21
|
+
this.#addClassToBody(SkyModalAdapterService.MODAL_BODY_FULL_CLASS);
|
|
22
|
+
}
|
|
23
|
+
else {
|
|
24
|
+
this.#removeClassFromBody(SkyModalAdapterService.MODAL_BODY_FULL_CLASS);
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
setPageScroll(isAdd) {
|
|
28
|
+
if (isAdd) {
|
|
29
|
+
this.#addClassToBody(SkyModalAdapterService.MODAL_BODY_CLASS);
|
|
30
|
+
}
|
|
31
|
+
else {
|
|
32
|
+
this.#removeClassFromBody(SkyModalAdapterService.MODAL_BODY_CLASS);
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
getModalOpener() {
|
|
36
|
+
return this.#docRef.activeElement;
|
|
37
|
+
}
|
|
38
|
+
#addClassToBody(className) {
|
|
39
|
+
this.#bodyEl.classList.add(className);
|
|
40
|
+
}
|
|
41
|
+
#removeClassFromBody(className) {
|
|
42
|
+
this.#bodyEl.classList.remove(className);
|
|
43
|
+
}
|
|
44
|
+
scrollContentToTop(element) {
|
|
45
|
+
element.nativeElement.querySelector('.sky-modal-content').scrollTop = 0;
|
|
46
|
+
}
|
|
47
|
+
/**
|
|
48
|
+
* Hides siblings of modal-host from screen readers
|
|
49
|
+
* @param hostElRef reference to modal-host element
|
|
50
|
+
*/
|
|
51
|
+
hideHostSiblingsFromScreenReaders(hostElRef) {
|
|
52
|
+
const hostElement = hostElRef.nativeElement;
|
|
53
|
+
const hostSiblings = hostElement.parentElement.children;
|
|
54
|
+
for (let i = 0; i < hostSiblings.length; i++) {
|
|
55
|
+
const element = hostSiblings[i];
|
|
56
|
+
if (element !== hostElement &&
|
|
57
|
+
!element.hasAttribute('aria-live') &&
|
|
58
|
+
element.nodeName.toLowerCase() !== 'script' &&
|
|
59
|
+
element.nodeName.toLowerCase() !== 'style') {
|
|
60
|
+
// preserve previous aria-hidden status of elements outside of modal host
|
|
61
|
+
this.#hostSiblingAriaHiddenCache.set(element, element.getAttribute('aria-hidden'));
|
|
62
|
+
element.setAttribute('aria-hidden', 'true');
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
/**
|
|
67
|
+
* Restores modal-host siblings to screen reader status prior to modals being opened
|
|
68
|
+
*/
|
|
69
|
+
unhideOrRestoreHostSiblingsFromScreenReaders() {
|
|
70
|
+
this.#hostSiblingAriaHiddenCache.forEach((previousValue, element) => {
|
|
71
|
+
// if element had aria-hidden status prior, restore status
|
|
72
|
+
if (element.parentElement) {
|
|
73
|
+
if (previousValue) {
|
|
74
|
+
element.setAttribute('aria-hidden', previousValue);
|
|
75
|
+
}
|
|
76
|
+
else {
|
|
77
|
+
element.removeAttribute('aria-hidden');
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
});
|
|
81
|
+
this.#hostSiblingAriaHiddenCache.clear();
|
|
82
|
+
}
|
|
83
|
+
hidePreviousModalFromScreenReaders(topModal) {
|
|
84
|
+
if (topModal && topModal.nativeElement.previousElementSibling) {
|
|
85
|
+
topModal.nativeElement.previousElementSibling.setAttribute('aria-hidden', 'true');
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
unhidePreviousModalFromScreenReaders(topModal) {
|
|
89
|
+
if (topModal && topModal.nativeElement.previousElementSibling) {
|
|
90
|
+
topModal.nativeElement.previousElementSibling.removeAttribute('aria-hidden');
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyModalAdapterService, deps: [{ token: i1.SkyAppWindowRef }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
94
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyModalAdapterService }); }
|
|
95
|
+
}
|
|
96
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyModalAdapterService, decorators: [{
|
|
97
|
+
type: Injectable
|
|
98
|
+
}], ctorParameters: function () { return [{ type: i1.SkyAppWindowRef }]; } });
|
|
99
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal-adapter.service.js","sourceRoot":"","sources":["../../../../../../../../libs/components/modals/src/lib/modules/modal/modal-adapter.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { ElementRef, Injectable } from '@angular/core';\nimport { SkyAppWindowRef } from '@skyux/core';\n\n/**\n * @internal\n */\n@Injectable()\nexport class SkyModalAdapterService {\n  private static readonly MODAL_BODY_FULL_CLASS = 'sky-modal-body-full-page';\n  private static readonly MODAL_BODY_CLASS = 'sky-modal-body-open';\n\n  #docRef: any;\n  #bodyEl: HTMLElement;\n\n  #windowRef: SkyAppWindowRef;\n  #hostSiblingAriaHiddenCache = new Map<Element, string | null>();\n\n  constructor(windowRef: SkyAppWindowRef) {\n    this.#windowRef = windowRef;\n    this.#docRef = this.#windowRef.nativeWindow.document;\n    this.#bodyEl = this.#windowRef.nativeWindow.document.body;\n  }\n\n  public toggleFullPageModalClass(isAddFull: boolean): void {\n    if (isAddFull) {\n      this.#addClassToBody(SkyModalAdapterService.MODAL_BODY_FULL_CLASS);\n    } else {\n      this.#removeClassFromBody(SkyModalAdapterService.MODAL_BODY_FULL_CLASS);\n    }\n  }\n\n  public setPageScroll(isAdd: boolean): void {\n    if (isAdd) {\n      this.#addClassToBody(SkyModalAdapterService.MODAL_BODY_CLASS);\n    } else {\n      this.#removeClassFromBody(SkyModalAdapterService.MODAL_BODY_CLASS);\n    }\n  }\n\n  public getModalOpener(): HTMLElement {\n    return this.#docRef.activeElement;\n  }\n\n  #addClassToBody(className: string): void {\n    this.#bodyEl.classList.add(className);\n  }\n\n  #removeClassFromBody(className: string): void {\n    this.#bodyEl.classList.remove(className);\n  }\n\n  public scrollContentToTop(element: ElementRef): void {\n    element.nativeElement.querySelector('.sky-modal-content').scrollTop = 0;\n  }\n\n  /**\n   * Hides siblings of modal-host from screen readers\n   * @param hostElRef reference to modal-host element\n   */\n  public hideHostSiblingsFromScreenReaders(hostElRef: ElementRef): void {\n    const hostElement = hostElRef.nativeElement;\n    const hostSiblings = hostElement.parentElement.children;\n\n    for (let i = 0; i < hostSiblings.length; i++) {\n      const element = hostSiblings[i];\n      if (\n        element !== hostElement &&\n        !element.hasAttribute('aria-live') &&\n        element.nodeName.toLowerCase() !== 'script' &&\n        element.nodeName.toLowerCase() !== 'style'\n      ) {\n        // preserve previous aria-hidden status of elements outside of modal host\n        this.#hostSiblingAriaHiddenCache.set(\n          element,\n          element.getAttribute('aria-hidden')\n        );\n        element.setAttribute('aria-hidden', 'true');\n      }\n    }\n  }\n\n  /**\n   * Restores modal-host siblings to screen reader status prior to modals being opened\n   */\n  public unhideOrRestoreHostSiblingsFromScreenReaders(): void {\n    this.#hostSiblingAriaHiddenCache.forEach((previousValue, element) => {\n      // if element had aria-hidden status prior, restore status\n      if (element.parentElement) {\n        if (previousValue) {\n          element.setAttribute('aria-hidden', previousValue);\n        } else {\n          element.removeAttribute('aria-hidden');\n        }\n      }\n    });\n    this.#hostSiblingAriaHiddenCache.clear();\n  }\n\n  public hidePreviousModalFromScreenReaders(topModal: ElementRef): void {\n    if (topModal && topModal.nativeElement.previousElementSibling) {\n      topModal.nativeElement.previousElementSibling.setAttribute(\n        'aria-hidden',\n        'true'\n      );\n    }\n  }\n\n  public unhidePreviousModalFromScreenReaders(topModal: ElementRef): void {\n    if (topModal && topModal.nativeElement.previousElementSibling) {\n      topModal.nativeElement.previousElementSibling.removeAttribute(\n        'aria-hidden'\n      );\n    }\n  }\n}\n"]}
|
|
@@ -0,0 +1,101 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@skyux/core";
|
|
4
|
+
/**
|
|
5
|
+
* @internal
|
|
6
|
+
*/
|
|
7
|
+
export class SkyModalComponentAdapterService {
|
|
8
|
+
#coreAdapter;
|
|
9
|
+
constructor(coreAdapter) {
|
|
10
|
+
this.#coreAdapter = coreAdapter;
|
|
11
|
+
}
|
|
12
|
+
handleWindowChange(modalEl) {
|
|
13
|
+
const boundedHeightEl = modalEl.nativeElement.querySelector('.sky-modal');
|
|
14
|
+
const fullPageModalEl = modalEl.nativeElement.querySelector('.sky-modal-full-page');
|
|
15
|
+
/*
|
|
16
|
+
Set modal height equal to max height of window (accounting for padding above and below modal)
|
|
17
|
+
*/
|
|
18
|
+
const newHeight = window.innerHeight - 40;
|
|
19
|
+
boundedHeightEl.style.maxHeight = newHeight.toString() + 'px';
|
|
20
|
+
if (fullPageModalEl) {
|
|
21
|
+
this.#setFullPageHeight(fullPageModalEl);
|
|
22
|
+
}
|
|
23
|
+
else {
|
|
24
|
+
/*
|
|
25
|
+
IE11 doesn't handle flex and max-height correctly so we have to explicitly add
|
|
26
|
+
max-height to the content that accounts for standard header and footer height.
|
|
27
|
+
*/
|
|
28
|
+
const modalContentEl = modalEl.nativeElement.querySelector('.sky-modal-content');
|
|
29
|
+
const contentHeight = newHeight - 114;
|
|
30
|
+
modalContentEl.style.maxHeight = contentHeight.toString() + 'px';
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
isFocusInFirstItem(event, list) {
|
|
34
|
+
/* istanbul ignore next */
|
|
35
|
+
/* sanity check */
|
|
36
|
+
const eventTarget = event.target || event.srcElement;
|
|
37
|
+
return list.length > 0 && eventTarget === list[0];
|
|
38
|
+
}
|
|
39
|
+
isFocusInLastItem(event, list) {
|
|
40
|
+
/* istanbul ignore next */
|
|
41
|
+
/* sanity check */
|
|
42
|
+
const eventTarget = event.target || event.srcElement;
|
|
43
|
+
return list.length > 0 && eventTarget === list[list.length - 1];
|
|
44
|
+
}
|
|
45
|
+
isModalFocused(event, modalEl) {
|
|
46
|
+
/* istanbul ignore next */
|
|
47
|
+
/* sanity check */
|
|
48
|
+
const eventTarget = event.target || event.srcElement;
|
|
49
|
+
return (modalEl &&
|
|
50
|
+
eventTarget === modalEl.nativeElement.querySelector('.sky-modal-dialog'));
|
|
51
|
+
}
|
|
52
|
+
focusLastElement(list) {
|
|
53
|
+
if (list.length > 0) {
|
|
54
|
+
list[list.length - 1].focus();
|
|
55
|
+
return true;
|
|
56
|
+
}
|
|
57
|
+
return false;
|
|
58
|
+
}
|
|
59
|
+
focusFirstElement(list) {
|
|
60
|
+
if (list.length > 0) {
|
|
61
|
+
list[0].focus();
|
|
62
|
+
return true;
|
|
63
|
+
}
|
|
64
|
+
return false;
|
|
65
|
+
}
|
|
66
|
+
modalContentHasDirectChildViewkeeper(modalContentEl) {
|
|
67
|
+
return !!modalContentEl.nativeElement.querySelector('sky-modal-content > .sky-viewkeeper-fixed');
|
|
68
|
+
}
|
|
69
|
+
modalOpened(modalEl) {
|
|
70
|
+
/* istanbul ignore else */
|
|
71
|
+
/* handle the case where somehow there is a focused element already in the modal */
|
|
72
|
+
if (!(document.activeElement &&
|
|
73
|
+
modalEl.nativeElement.contains(document.activeElement))) {
|
|
74
|
+
const currentScrollX = window.pageXOffset;
|
|
75
|
+
const currentScrollY = window.pageYOffset;
|
|
76
|
+
const inputWithAutofocus = modalEl.nativeElement.querySelector('[autofocus]');
|
|
77
|
+
if (inputWithAutofocus) {
|
|
78
|
+
inputWithAutofocus.focus();
|
|
79
|
+
}
|
|
80
|
+
else {
|
|
81
|
+
this.#coreAdapter.getFocusableChildrenAndApplyFocus(modalEl, '.sky-modal-content', true);
|
|
82
|
+
}
|
|
83
|
+
window.scrollTo(currentScrollX, currentScrollY);
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
#setFullPageHeight(fullPageModalEl) {
|
|
87
|
+
const windowHeight = window.innerHeight;
|
|
88
|
+
const fullPageModalStyle = getComputedStyle(fullPageModalEl);
|
|
89
|
+
const marginTopBottom = parseInt(fullPageModalStyle.marginTop, 10) +
|
|
90
|
+
parseInt(fullPageModalStyle.marginBottom, 10);
|
|
91
|
+
const fullPageModalHeight = windowHeight - marginTopBottom + 'px';
|
|
92
|
+
fullPageModalEl.style.height = fullPageModalHeight;
|
|
93
|
+
fullPageModalEl.style.maxHeight = fullPageModalHeight;
|
|
94
|
+
}
|
|
95
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyModalComponentAdapterService, deps: [{ token: i1.SkyCoreAdapterService }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
96
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyModalComponentAdapterService }); }
|
|
97
|
+
}
|
|
98
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyModalComponentAdapterService, decorators: [{
|
|
99
|
+
type: Injectable
|
|
100
|
+
}], ctorParameters: function () { return [{ type: i1.SkyCoreAdapterService }]; } });
|
|
101
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal-component-adapter.service.js","sourceRoot":"","sources":["../../../../../../../../libs/components/modals/src/lib/modules/modal/modal-component-adapter.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { ElementRef, Injectable } from '@angular/core';\nimport { SkyCoreAdapterService } from '@skyux/core';\n\n/**\n * @internal\n */\n@Injectable()\nexport class SkyModalComponentAdapterService {\n  #coreAdapter: SkyCoreAdapterService;\n\n  constructor(coreAdapter: SkyCoreAdapterService) {\n    this.#coreAdapter = coreAdapter;\n  }\n\n  public handleWindowChange(modalEl: ElementRef): void {\n    const boundedHeightEl = modalEl.nativeElement.querySelector('.sky-modal');\n    const fullPageModalEl = modalEl.nativeElement.querySelector(\n      '.sky-modal-full-page'\n    );\n    /*\n      Set modal height equal to max height of window (accounting for padding above and below modal)\n    */\n    const newHeight = window.innerHeight - 40;\n\n    boundedHeightEl.style.maxHeight = newHeight.toString() + 'px';\n    if (fullPageModalEl) {\n      this.#setFullPageHeight(fullPageModalEl);\n    } else {\n      /*\n        IE11 doesn't handle flex and max-height correctly so we have to explicitly add\n        max-height to the content that accounts for standard header and footer height.\n      */\n      const modalContentEl =\n        modalEl.nativeElement.querySelector('.sky-modal-content');\n      const contentHeight = newHeight - 114;\n      modalContentEl.style.maxHeight = contentHeight.toString() + 'px';\n    }\n  }\n\n  public isFocusInFirstItem(\n    event: KeyboardEvent,\n    list: Array<HTMLElement>\n  ): boolean {\n    /* istanbul ignore next */\n    /* sanity check */\n    const eventTarget = event.target || event.srcElement;\n    return list.length > 0 && eventTarget === list[0];\n  }\n\n  public isFocusInLastItem(\n    event: KeyboardEvent,\n    list: Array<HTMLElement>\n  ): boolean {\n    /* istanbul ignore next */\n    /* sanity check */\n    const eventTarget = event.target || event.srcElement;\n    return list.length > 0 && eventTarget === list[list.length - 1];\n  }\n\n  public isModalFocused(event: KeyboardEvent, modalEl: ElementRef): boolean {\n    /* istanbul ignore next */\n    /* sanity check */\n    const eventTarget = event.target || event.srcElement;\n    return (\n      modalEl &&\n      eventTarget === modalEl.nativeElement.querySelector('.sky-modal-dialog')\n    );\n  }\n\n  public focusLastElement(list: Array<HTMLElement>): boolean {\n    if (list.length > 0) {\n      list[list.length - 1].focus();\n      return true;\n    }\n    return false;\n  }\n\n  public focusFirstElement(list: Array<HTMLElement>): boolean {\n    if (list.length > 0) {\n      list[0].focus();\n      return true;\n    }\n    return false;\n  }\n\n  public modalContentHasDirectChildViewkeeper(\n    modalContentEl: ElementRef\n  ): boolean {\n    return !!modalContentEl.nativeElement.querySelector(\n      'sky-modal-content > .sky-viewkeeper-fixed'\n    );\n  }\n\n  public modalOpened(modalEl: ElementRef): void {\n    /* istanbul ignore else */\n    /* handle the case where somehow there is a focused element already in the modal */\n    if (\n      !(\n        document.activeElement &&\n        modalEl.nativeElement.contains(document.activeElement)\n      )\n    ) {\n      const currentScrollX = window.pageXOffset;\n      const currentScrollY = window.pageYOffset;\n\n      const inputWithAutofocus =\n        modalEl.nativeElement.querySelector('[autofocus]');\n\n      if (inputWithAutofocus) {\n        inputWithAutofocus.focus();\n      } else {\n        this.#coreAdapter.getFocusableChildrenAndApplyFocus(\n          modalEl,\n          '.sky-modal-content',\n          true\n        );\n      }\n      window.scrollTo(currentScrollX, currentScrollY);\n    }\n  }\n\n  #setFullPageHeight(fullPageModalEl: HTMLElement): void {\n    const windowHeight = window.innerHeight;\n    const fullPageModalStyle = getComputedStyle(fullPageModalEl);\n\n    const marginTopBottom =\n      parseInt(fullPageModalStyle.marginTop, 10) +\n      parseInt(fullPageModalStyle.marginBottom, 10);\n\n    const fullPageModalHeight = windowHeight - marginTopBottom + 'px';\n\n    fullPageModalEl.style.height = fullPageModalHeight;\n    fullPageModalEl.style.maxHeight = fullPageModalHeight;\n  }\n}\n"]}
|
|
@@ -7,13 +7,13 @@ export class SkyModalConfiguration {
|
|
|
7
7
|
constructor() {
|
|
8
8
|
this.size = 'medium';
|
|
9
9
|
}
|
|
10
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyModalConfiguration, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
11
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyModalConfiguration, providedIn: 'any' }); }
|
|
10
12
|
}
|
|
11
|
-
|
|
12
|
-
SkyModalConfiguration.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyModalConfiguration, providedIn: 'any' });
|
|
13
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyModalConfiguration, decorators: [{
|
|
13
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyModalConfiguration, decorators: [{
|
|
14
14
|
type: Injectable,
|
|
15
15
|
args: [{
|
|
16
16
|
providedIn: 'any',
|
|
17
17
|
}]
|
|
18
18
|
}], ctorParameters: function () { return []; } });
|
|
19
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kYWwtY29uZmlndXJhdGlvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9tb2RhbHMvc3JjL2xpYi9tb2R1bGVzL21vZGFsL21vZGFsLWNvbmZpZ3VyYXRpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFFM0M7O0dBRUc7QUFJSCxNQUFNLE9BQU8scUJBQXFCO0lBVWhDO1FBQ0UsSUFBSSxDQUFDLElBQUksR0FBRyxRQUFRLENBQUM7SUFDdkIsQ0FBQzs4R0FaVSxxQkFBcUI7a0hBQXJCLHFCQUFxQixjQUZwQixLQUFLOzsyRkFFTixxQkFBcUI7a0JBSGpDLFVBQVU7bUJBQUM7b0JBQ1YsVUFBVSxFQUFFLEtBQUs7aUJBQ2xCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG4vKipcbiAqIEBpbnRlcm5hbFxuICovXG5ASW5qZWN0YWJsZSh7XG4gIHByb3ZpZGVkSW46ICdhbnknLFxufSlcbmV4cG9ydCBjbGFzcyBTa3lNb2RhbENvbmZpZ3VyYXRpb24ge1xuICBwdWJsaWMgZnVsbFBhZ2U/OiBib29sZWFuO1xuICBwdWJsaWMgc2l6ZT86IHN0cmluZztcbiAgcHVibGljIGFyaWFEZXNjcmliZWRCeT86IHN0cmluZztcbiAgcHVibGljIGFyaWFMYWJlbGxlZEJ5Pzogc3RyaW5nO1xuICBwdWJsaWMgYXJpYVJvbGU/OiBzdHJpbmc7XG4gIHB1YmxpYyB0aWxlZEJvZHk/OiBib29sZWFuO1xuICBwdWJsaWMgaGVscEtleT86IHN0cmluZztcbiAgcHVibGljIHdyYXBwZXJDbGFzcz86IHN0cmluZztcblxuICBjb25zdHJ1Y3RvcigpIHtcbiAgICB0aGlzLnNpemUgPSAnbWVkaXVtJztcbiAgfVxufVxuIl19
|
|
@@ -4,11 +4,11 @@ import * as i0 from "@angular/core";
|
|
|
4
4
|
* Specifies content to display in the modal's body.
|
|
5
5
|
*/
|
|
6
6
|
export class SkyModalContentComponent {
|
|
7
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyModalContentComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
8
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.7", type: SkyModalContentComponent, selector: "sky-modal-content", ngImport: i0, template: "<ng-content></ng-content>\n", styles: ["sky-modal-content{display:block;min-height:100%}.sky-theme-modern sky-modal-content{padding:10px 30px 30px}\n"], encapsulation: i0.ViewEncapsulation.None }); }
|
|
7
9
|
}
|
|
8
|
-
|
|
9
|
-
SkyModalContentComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: SkyModalContentComponent, selector: "sky-modal-content", ngImport: i0, template: "<ng-content></ng-content>\n", styles: ["sky-modal-content{display:block;min-height:100%}.sky-theme-modern sky-modal-content{padding:10px 30px 30px}\n"], encapsulation: i0.ViewEncapsulation.None });
|
|
10
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyModalContentComponent, decorators: [{
|
|
10
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyModalContentComponent, decorators: [{
|
|
11
11
|
type: Component,
|
|
12
12
|
args: [{ selector: 'sky-modal-content', encapsulation: ViewEncapsulation.None, template: "<ng-content></ng-content>\n", styles: ["sky-modal-content{display:block;min-height:100%}.sky-theme-modern sky-modal-content{padding:10px 30px 30px}\n"] }]
|
|
13
13
|
}] });
|
|
14
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
14
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kYWwtY29udGVudC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvbW9kYWxzL3NyYy9saWIvbW9kdWxlcy9tb2RhbC9tb2RhbC1jb250ZW50LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9tb2RhbHMvc3JjL2xpYi9tb2R1bGVzL21vZGFsL21vZGFsLWNvbnRlbnQuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFFN0Q7O0dBRUc7QUFPSCxNQUFNLE9BQU8sd0JBQXdCOzhHQUF4Qix3QkFBd0I7a0dBQXhCLHdCQUF3Qix5RENYckMsNkJBQ0E7OzJGRFVhLHdCQUF3QjtrQkFOcEMsU0FBUzsrQkFDRSxtQkFBbUIsaUJBR2QsaUJBQWlCLENBQUMsSUFBSSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgVmlld0VuY2Fwc3VsYXRpb24gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuLyoqXG4gKiBTcGVjaWZpZXMgY29udGVudCB0byBkaXNwbGF5IGluIHRoZSBtb2RhbCdzIGJvZHkuXG4gKi9cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3NreS1tb2RhbC1jb250ZW50JyxcbiAgdGVtcGxhdGVVcmw6ICcuL21vZGFsLWNvbnRlbnQuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9tb2RhbC1jb250ZW50LmNvbXBvbmVudC5zY3NzJ10sXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXG59KVxuZXhwb3J0IGNsYXNzIFNreU1vZGFsQ29udGVudENvbXBvbmVudCB7fVxuIiwiPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuIl19
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import { BehaviorSubject } from 'rxjs';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
/**
|
|
5
|
+
* @internal
|
|
6
|
+
*/
|
|
7
|
+
export class SkyModalErrorsService {
|
|
8
|
+
#formErrors = new BehaviorSubject(undefined);
|
|
9
|
+
constructor() {
|
|
10
|
+
this.formErrors = this.#formErrors.asObservable();
|
|
11
|
+
}
|
|
12
|
+
updateErrors(value) {
|
|
13
|
+
this.#formErrors.next(value);
|
|
14
|
+
}
|
|
15
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyModalErrorsService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
16
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyModalErrorsService }); }
|
|
17
|
+
}
|
|
18
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyModalErrorsService, decorators: [{
|
|
19
|
+
type: Injectable
|
|
20
|
+
}], ctorParameters: function () { return []; } });
|
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kYWwtZXJyb3JzLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvbW9kYWxzL3NyYy9saWIvbW9kdWxlcy9tb2RhbC9tb2RhbC1lcnJvcnMuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTNDLE9BQU8sRUFBRSxlQUFlLEVBQWMsTUFBTSxNQUFNLENBQUM7O0FBSW5EOztHQUVHO0FBRUgsTUFBTSxPQUFPLHFCQUFxQjtJQUdoQyxXQUFXLEdBQUcsSUFBSSxlQUFlLENBQThCLFNBQVMsQ0FBQyxDQUFDO0lBRTFFO1FBQ0UsSUFBSSxDQUFDLFVBQVUsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLFlBQVksRUFBRSxDQUFDO0lBQ3BELENBQUM7SUFFTSxZQUFZLENBQUMsS0FBa0M7UUFDcEQsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDL0IsQ0FBQzs4R0FYVSxxQkFBcUI7a0hBQXJCLHFCQUFxQjs7MkZBQXJCLHFCQUFxQjtrQkFEakMsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgQmVoYXZpb3JTdWJqZWN0LCBPYnNlcnZhYmxlIH0gZnJvbSAncnhqcyc7XG5cbmltcG9ydCB7IFNreU1vZGFsRXJyb3IgfSBmcm9tICcuL21vZGFsLWVycm9yJztcblxuLyoqXG4gKiBAaW50ZXJuYWxcbiAqL1xuQEluamVjdGFibGUoKVxuZXhwb3J0IGNsYXNzIFNreU1vZGFsRXJyb3JzU2VydmljZSB7XG4gIHB1YmxpYyBmb3JtRXJyb3JzOiBPYnNlcnZhYmxlPFNreU1vZGFsRXJyb3JbXSB8IHVuZGVmaW5lZD47XG5cbiAgI2Zvcm1FcnJvcnMgPSBuZXcgQmVoYXZpb3JTdWJqZWN0PFNreU1vZGFsRXJyb3JbXSB8IHVuZGVmaW5lZD4odW5kZWZpbmVkKTtcblxuICBjb25zdHJ1Y3RvcigpIHtcbiAgICB0aGlzLmZvcm1FcnJvcnMgPSB0aGlzLiNmb3JtRXJyb3JzLmFzT2JzZXJ2YWJsZSgpO1xuICB9XG5cbiAgcHVibGljIHVwZGF0ZUVycm9ycyh2YWx1ZTogU2t5TW9kYWxFcnJvcltdIHwgdW5kZWZpbmVkKTogdm9pZCB7XG4gICAgdGhpcy4jZm9ybUVycm9ycy5uZXh0KHZhbHVlKTtcbiAgfVxufVxuIl19
|