@skyux/modals 5.6.2 → 6.0.0-beta.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 +6 -6
- package/esm2020/index.mjs +26 -0
- package/esm2020/lib/modules/confirm/confirm-button-action.mjs +2 -0
- package/esm2020/lib/modules/confirm/confirm-button-config.mjs +2 -0
- package/esm2020/lib/modules/confirm/confirm-button.mjs +2 -0
- package/esm2020/lib/modules/confirm/confirm-closed-event-args.mjs +2 -0
- package/esm2020/lib/modules/confirm/confirm-config.mjs +2 -0
- package/esm2020/lib/modules/confirm/confirm-instance.mjs +12 -0
- package/esm2020/lib/modules/confirm/confirm-modal-context.mjs +4 -0
- package/esm2020/lib/modules/confirm/confirm-type.mjs +25 -0
- package/esm2020/lib/modules/confirm/confirm.component.mjs +123 -0
- package/esm2020/lib/modules/confirm/confirm.module.mjs +34 -0
- package/esm2020/lib/modules/confirm/confirm.service.mjs +55 -0
- package/esm2020/lib/modules/modal/modal-adapter.service.mjs +47 -0
- package/esm2020/lib/modules/modal/modal-before-close-handler.mjs +7 -0
- package/esm2020/lib/modules/modal/modal-close-args.mjs +3 -0
- package/esm2020/lib/modules/modal/modal-component-adapter.service.mjs +98 -0
- package/esm2020/lib/modules/modal/modal-configuration.mjs +19 -0
- package/esm2020/lib/modules/modal/modal-content.component.mjs +14 -0
- package/esm2020/lib/modules/modal/modal-footer.component.mjs +14 -0
- package/esm2020/lib/modules/modal/modal-header.component.mjs +15 -0
- package/esm2020/lib/modules/modal/modal-host.component.mjs +96 -0
- package/esm2020/lib/modules/modal/modal-host.service.mjs +55 -0
- package/esm2020/lib/modules/modal/modal-instance.mjs +105 -0
- package/esm2020/lib/modules/modal/modal-scroll-shadow-event-args.mjs +2 -0
- package/esm2020/lib/modules/modal/modal-scroll-shadow.directive.mjs +122 -0
- package/esm2020/lib/modules/modal/modal-state-animation.mjs +8 -0
- package/esm2020/lib/modules/modal/modal.component.mjs +178 -0
- package/esm2020/lib/modules/modal/modal.interface.mjs +4 -0
- package/esm2020/lib/modules/modal/modal.module.mjs +63 -0
- package/esm2020/lib/modules/modal/modal.service.mjs +85 -0
- package/esm2020/lib/modules/shared/sky-modals-resources.module.mjs +54 -0
- package/esm2020/skyux-modals.mjs +5 -0
- package/esm2020/testing/modal-fixture.mjs +168 -0
- package/esm2020/testing/public-api.mjs +2 -0
- package/esm2020/testing/skyux-modals-testing.mjs +5 -0
- package/fesm2015/{skyux-modals-testing.js → skyux-modals-testing.mjs} +1 -1
- package/fesm2015/skyux-modals-testing.mjs.map +1 -0
- package/fesm2015/skyux-modals.mjs +1159 -0
- package/fesm2015/skyux-modals.mjs.map +1 -0
- package/{esm2015/testing/modal-fixture.js → fesm2020/skyux-modals-testing.mjs} +8 -2
- package/fesm2020/skyux-modals-testing.mjs.map +1 -0
- package/{fesm2015/skyux-modals.js → fesm2020/skyux-modals.mjs} +60 -90
- package/fesm2020/skyux-modals.mjs.map +1 -0
- package/lib/modules/modal/modal-instance.d.ts +1 -1
- package/lib/modules/shared/sky-modals-resources.module.d.ts +1 -1
- package/package.json +35 -14
- package/testing/package.json +5 -5
- package/bundles/skyux-modals-testing.umd.js +0 -538
- package/bundles/skyux-modals.umd.js +0 -1356
- package/esm2015/index.js +0 -26
- package/esm2015/index.js.map +0 -1
- package/esm2015/lib/modules/confirm/confirm-button-action.js +0 -2
- package/esm2015/lib/modules/confirm/confirm-button-action.js.map +0 -1
- package/esm2015/lib/modules/confirm/confirm-button-config.js +0 -2
- package/esm2015/lib/modules/confirm/confirm-button-config.js.map +0 -1
- package/esm2015/lib/modules/confirm/confirm-button.js +0 -2
- package/esm2015/lib/modules/confirm/confirm-button.js.map +0 -1
- package/esm2015/lib/modules/confirm/confirm-closed-event-args.js +0 -2
- package/esm2015/lib/modules/confirm/confirm-closed-event-args.js.map +0 -1
- package/esm2015/lib/modules/confirm/confirm-config.js +0 -2
- package/esm2015/lib/modules/confirm/confirm-config.js.map +0 -1
- package/esm2015/lib/modules/confirm/confirm-instance.js +0 -12
- package/esm2015/lib/modules/confirm/confirm-instance.js.map +0 -1
- package/esm2015/lib/modules/confirm/confirm-modal-context.js +0 -4
- package/esm2015/lib/modules/confirm/confirm-modal-context.js.map +0 -1
- package/esm2015/lib/modules/confirm/confirm-type.js +0 -25
- package/esm2015/lib/modules/confirm/confirm-type.js.map +0 -1
- package/esm2015/lib/modules/confirm/confirm.component.js +0 -127
- package/esm2015/lib/modules/confirm/confirm.component.js.map +0 -1
- package/esm2015/lib/modules/confirm/confirm.module.js +0 -35
- package/esm2015/lib/modules/confirm/confirm.module.js.map +0 -1
- package/esm2015/lib/modules/confirm/confirm.service.js +0 -55
- package/esm2015/lib/modules/confirm/confirm.service.js.map +0 -1
- package/esm2015/lib/modules/modal/modal-adapter.service.js +0 -47
- package/esm2015/lib/modules/modal/modal-adapter.service.js.map +0 -1
- package/esm2015/lib/modules/modal/modal-before-close-handler.js +0 -7
- package/esm2015/lib/modules/modal/modal-before-close-handler.js.map +0 -1
- package/esm2015/lib/modules/modal/modal-close-args.js +0 -3
- package/esm2015/lib/modules/modal/modal-close-args.js.map +0 -1
- package/esm2015/lib/modules/modal/modal-component-adapter.service.js +0 -98
- package/esm2015/lib/modules/modal/modal-component-adapter.service.js.map +0 -1
- package/esm2015/lib/modules/modal/modal-configuration.js +0 -19
- package/esm2015/lib/modules/modal/modal-configuration.js.map +0 -1
- package/esm2015/lib/modules/modal/modal-content.component.js +0 -19
- package/esm2015/lib/modules/modal/modal-content.component.js.map +0 -1
- package/esm2015/lib/modules/modal/modal-footer.component.js +0 -18
- package/esm2015/lib/modules/modal/modal-footer.component.js.map +0 -1
- package/esm2015/lib/modules/modal/modal-header.component.js +0 -19
- package/esm2015/lib/modules/modal/modal-header.component.js.map +0 -1
- package/esm2015/lib/modules/modal/modal-host.component.js +0 -101
- package/esm2015/lib/modules/modal/modal-host.component.js.map +0 -1
- package/esm2015/lib/modules/modal/modal-host.service.js +0 -55
- package/esm2015/lib/modules/modal/modal-host.service.js.map +0 -1
- package/esm2015/lib/modules/modal/modal-instance.js +0 -105
- package/esm2015/lib/modules/modal/modal-instance.js.map +0 -1
- package/esm2015/lib/modules/modal/modal-scroll-shadow-event-args.js +0 -2
- package/esm2015/lib/modules/modal/modal-scroll-shadow-event-args.js.map +0 -1
- package/esm2015/lib/modules/modal/modal-scroll-shadow.directive.js +0 -122
- package/esm2015/lib/modules/modal/modal-scroll-shadow.directive.js.map +0 -1
- package/esm2015/lib/modules/modal/modal-state-animation.js +0 -8
- package/esm2015/lib/modules/modal/modal-state-animation.js.map +0 -1
- package/esm2015/lib/modules/modal/modal.component.js +0 -184
- package/esm2015/lib/modules/modal/modal.component.js.map +0 -1
- package/esm2015/lib/modules/modal/modal.interface.js +0 -4
- package/esm2015/lib/modules/modal/modal.interface.js.map +0 -1
- package/esm2015/lib/modules/modal/modal.module.js +0 -64
- package/esm2015/lib/modules/modal/modal.module.js.map +0 -1
- package/esm2015/lib/modules/modal/modal.service.js +0 -85
- package/esm2015/lib/modules/modal/modal.service.js.map +0 -1
- package/esm2015/lib/modules/shared/sky-modals-resources.module.js +0 -54
- package/esm2015/lib/modules/shared/sky-modals-resources.module.js.map +0 -1
- package/esm2015/skyux-modals.js +0 -5
- package/esm2015/skyux-modals.js.map +0 -1
- package/esm2015/testing/modal-fixture.js.map +0 -1
- package/esm2015/testing/public-api.js +0 -2
- package/esm2015/testing/public-api.js.map +0 -1
- package/esm2015/testing/skyux-modals-testing.js +0 -5
- package/esm2015/testing/skyux-modals-testing.js.map +0 -1
- package/fesm2015/skyux-modals-testing.js.map +0 -1
- package/fesm2015/skyux-modals.js.map +0 -1
package/documentation.json
CHANGED
|
@@ -411,7 +411,7 @@
|
|
|
411
411
|
"name": "NgModule"
|
|
412
412
|
},
|
|
413
413
|
"arguments": {
|
|
414
|
-
"obj": "{\n declarations: [SkyConfirmComponent],\n imports: [\n CommonModule,\n SkyModalModule,\n SkyModalsResourcesModule,\n SkyThemeModule,\n ],\n exports: [SkyConfirmComponent],\n
|
|
414
|
+
"obj": "{\n declarations: [SkyConfirmComponent],\n imports: [\n CommonModule,\n SkyModalModule,\n SkyModalsResourcesModule,\n SkyThemeModule,\n ],\n exports: [SkyConfirmComponent],\n}"
|
|
415
415
|
}
|
|
416
416
|
}
|
|
417
417
|
],
|
|
@@ -428,7 +428,7 @@
|
|
|
428
428
|
"sources": [
|
|
429
429
|
{
|
|
430
430
|
"fileName": "projects/modals/src/modules/confirm/confirm.module.ts",
|
|
431
|
-
"line":
|
|
431
|
+
"line": 20,
|
|
432
432
|
"character": 13
|
|
433
433
|
}
|
|
434
434
|
]
|
|
@@ -829,7 +829,7 @@
|
|
|
829
829
|
"kindString": "Get signature",
|
|
830
830
|
"flags": {},
|
|
831
831
|
"comment": {
|
|
832
|
-
"shortText": "An event that the modal instance emits when it closes.\nIt emits a `
|
|
832
|
+
"shortText": "An event that the modal instance emits when it closes.\nIt emits a `SkyModalCloseArgs` object with a `data` property that includes\ndata passed from users on close or save and a `reason` property that indicates\nwhether the modal was saved or closed without saving.\nThe `reason` property accepts any string value.\nCommon examples include `cancel`, `close`, and `save`."
|
|
833
833
|
},
|
|
834
834
|
"type": {
|
|
835
835
|
"type": "reference",
|
|
@@ -1179,7 +1179,7 @@
|
|
|
1179
1179
|
"name": "NgModule"
|
|
1180
1180
|
},
|
|
1181
1181
|
"arguments": {
|
|
1182
|
-
"obj": "{\n declarations: [\n SkyModalComponent,\n SkyModalContentComponent,\n SkyModalFooterComponent,\n SkyModalHeaderComponent,\n SkyModalHostComponent,\n SkyModalScrollShadowDirective,\n ],\n imports: [\n CommonModule,\n RouterModule,\n SkyIconModule,\n SkyModalsResourcesModule,\n SkyThemeModule,\n ],\n exports: [\n SkyModalComponent,\n SkyModalContentComponent,\n SkyModalFooterComponent,\n SkyModalHeaderComponent,\n ],\n
|
|
1182
|
+
"obj": "{\n declarations: [\n SkyModalComponent,\n SkyModalContentComponent,\n SkyModalFooterComponent,\n SkyModalHeaderComponent,\n SkyModalHostComponent,\n SkyModalScrollShadowDirective,\n ],\n imports: [\n CommonModule,\n RouterModule,\n SkyIconModule,\n SkyModalsResourcesModule,\n SkyThemeModule,\n ],\n exports: [\n SkyModalComponent,\n SkyModalContentComponent,\n SkyModalFooterComponent,\n SkyModalHeaderComponent,\n ],\n}"
|
|
1183
1183
|
}
|
|
1184
1184
|
}
|
|
1185
1185
|
],
|
|
@@ -1196,7 +1196,7 @@
|
|
|
1196
1196
|
"sources": [
|
|
1197
1197
|
{
|
|
1198
1198
|
"fileName": "projects/modals/src/modules/modal/modal.module.ts",
|
|
1199
|
-
"line":
|
|
1199
|
+
"line": 39,
|
|
1200
1200
|
"character": 13
|
|
1201
1201
|
}
|
|
1202
1202
|
]
|
|
@@ -3507,7 +3507,7 @@
|
|
|
3507
3507
|
{
|
|
3508
3508
|
"fileName": "modal-demo.module.ts",
|
|
3509
3509
|
"filePath": "/projects/modals/documentation/code-examples/modal/modal-demo.module.ts",
|
|
3510
|
-
"rawContents": "import { CommonModule } from '@angular/common';\nimport { NgModule } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { SkyIdModule } from '@skyux/core';\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 SkyIdModule,\n SkyInputBoxModule,\n SkyModalModule,\n ],\n declarations: [ModalDemoComponent, ModalDemoModalComponent],\n exports: [ModalDemoComponent],\n
|
|
3510
|
+
"rawContents": "import { CommonModule } from '@angular/common';\nimport { NgModule } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { SkyIdModule } from '@skyux/core';\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 SkyIdModule,\n SkyInputBoxModule,\n SkyModalModule,\n ],\n declarations: [ModalDemoComponent, ModalDemoModalComponent],\n exports: [ModalDemoComponent],\n})\nexport class ModalDemoModule {}\n"
|
|
3511
3511
|
}
|
|
3512
3512
|
]
|
|
3513
3513
|
}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
export * from './lib/modules/confirm/confirm-button';
|
|
2
|
+
export * from './lib/modules/confirm/confirm-button-action';
|
|
3
|
+
export * from './lib/modules/confirm/confirm-button-config';
|
|
4
|
+
export * from './lib/modules/confirm/confirm-closed-event-args';
|
|
5
|
+
export * from './lib/modules/confirm/confirm-config';
|
|
6
|
+
export * from './lib/modules/confirm/confirm-instance';
|
|
7
|
+
export * from './lib/modules/confirm/confirm-modal-context';
|
|
8
|
+
export * from './lib/modules/confirm/confirm-type';
|
|
9
|
+
export * from './lib/modules/confirm/confirm.module';
|
|
10
|
+
export * from './lib/modules/confirm/confirm.service';
|
|
11
|
+
export * from './lib/modules/modal/modal-before-close-handler';
|
|
12
|
+
export * from './lib/modules/modal/modal-close-args';
|
|
13
|
+
export * from './lib/modules/modal/modal-configuration';
|
|
14
|
+
export * from './lib/modules/modal/modal-host.service';
|
|
15
|
+
export * from './lib/modules/modal/modal-instance';
|
|
16
|
+
export * from './lib/modules/modal/modal.interface';
|
|
17
|
+
export * from './lib/modules/modal/modal.module';
|
|
18
|
+
export * from './lib/modules/modal/modal.service';
|
|
19
|
+
// Components and directives must be exported to support Angular's "partial" Ivy compiler.
|
|
20
|
+
// Obscure names are used to indicate types are not part of the public API.
|
|
21
|
+
export { SkyConfirmComponent as λ1 } from './lib/modules/confirm/confirm.component';
|
|
22
|
+
export { SkyModalContentComponent as λ2 } from './lib/modules/modal/modal-content.component';
|
|
23
|
+
export { SkyModalFooterComponent as λ3 } from './lib/modules/modal/modal-footer.component';
|
|
24
|
+
export { SkyModalHeaderComponent as λ4 } from './lib/modules/modal/modal-header.component';
|
|
25
|
+
export { SkyModalComponent as λ5 } from './lib/modules/modal/modal.component';
|
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvbW9kYWxzL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLHNDQUFzQyxDQUFDO0FBQ3JELGNBQWMsNkNBQTZDLENBQUM7QUFDNUQsY0FBYyw2Q0FBNkMsQ0FBQztBQUM1RCxjQUFjLGlEQUFpRCxDQUFDO0FBQ2hFLGNBQWMsc0NBQXNDLENBQUM7QUFDckQsY0FBYyx3Q0FBd0MsQ0FBQztBQUN2RCxjQUFjLDZDQUE2QyxDQUFDO0FBQzVELGNBQWMsb0NBQW9DLENBQUM7QUFDbkQsY0FBYyxzQ0FBc0MsQ0FBQztBQUNyRCxjQUFjLHVDQUF1QyxDQUFDO0FBRXRELGNBQWMsZ0RBQWdELENBQUM7QUFDL0QsY0FBYyxzQ0FBc0MsQ0FBQztBQUNyRCxjQUFjLHlDQUF5QyxDQUFDO0FBQ3hELGNBQWMsd0NBQXdDLENBQUM7QUFDdkQsY0FBYyxvQ0FBb0MsQ0FBQztBQUNuRCxjQUFjLHFDQUFxQyxDQUFDO0FBQ3BELGNBQWMsa0NBQWtDLENBQUM7QUFDakQsY0FBYyxtQ0FBbUMsQ0FBQztBQUVsRCwwRkFBMEY7QUFDMUYsMkVBQTJFO0FBQzNFLE9BQU8sRUFBRSxtQkFBbUIsSUFBSSxFQUFFLEVBQUUsTUFBTSx5Q0FBeUMsQ0FBQztBQUNwRixPQUFPLEVBQUUsd0JBQXdCLElBQUksRUFBRSxFQUFFLE1BQU0sNkNBQTZDLENBQUM7QUFDN0YsT0FBTyxFQUFFLHVCQUF1QixJQUFJLEVBQUUsRUFBRSxNQUFNLDRDQUE0QyxDQUFDO0FBQzNGLE9BQU8sRUFBRSx1QkFBdUIsSUFBSSxFQUFFLEVBQUUsTUFBTSw0Q0FBNEMsQ0FBQztBQUMzRixPQUFPLEVBQUUsaUJBQWlCLElBQUksRUFBRSxFQUFFLE1BQU0scUNBQXFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2xpYi9tb2R1bGVzL2NvbmZpcm0vY29uZmlybS1idXR0b24nO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kdWxlcy9jb25maXJtL2NvbmZpcm0tYnV0dG9uLWFjdGlvbic7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2R1bGVzL2NvbmZpcm0vY29uZmlybS1idXR0b24tY29uZmlnJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZHVsZXMvY29uZmlybS9jb25maXJtLWNsb3NlZC1ldmVudC1hcmdzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZHVsZXMvY29uZmlybS9jb25maXJtLWNvbmZpZyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2R1bGVzL2NvbmZpcm0vY29uZmlybS1pbnN0YW5jZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2R1bGVzL2NvbmZpcm0vY29uZmlybS1tb2RhbC1jb250ZXh0JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZHVsZXMvY29uZmlybS9jb25maXJtLXR5cGUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kdWxlcy9jb25maXJtL2NvbmZpcm0ubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZHVsZXMvY29uZmlybS9jb25maXJtLnNlcnZpY2UnO1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2R1bGVzL21vZGFsL21vZGFsLWJlZm9yZS1jbG9zZS1oYW5kbGVyJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZHVsZXMvbW9kYWwvbW9kYWwtY2xvc2UtYXJncyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2R1bGVzL21vZGFsL21vZGFsLWNvbmZpZ3VyYXRpb24nO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kdWxlcy9tb2RhbC9tb2RhbC1ob3N0LnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kdWxlcy9tb2RhbC9tb2RhbC1pbnN0YW5jZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2R1bGVzL21vZGFsL21vZGFsLmludGVyZmFjZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2R1bGVzL21vZGFsL21vZGFsLm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2R1bGVzL21vZGFsL21vZGFsLnNlcnZpY2UnO1xuXG4vLyBDb21wb25lbnRzIGFuZCBkaXJlY3RpdmVzIG11c3QgYmUgZXhwb3J0ZWQgdG8gc3VwcG9ydCBBbmd1bGFyJ3MgXCJwYXJ0aWFsXCIgSXZ5IGNvbXBpbGVyLlxuLy8gT2JzY3VyZSBuYW1lcyBhcmUgdXNlZCB0byBpbmRpY2F0ZSB0eXBlcyBhcmUgbm90IHBhcnQgb2YgdGhlIHB1YmxpYyBBUEkuXG5leHBvcnQgeyBTa3lDb25maXJtQ29tcG9uZW50IGFzIM67MSB9IGZyb20gJy4vbGliL21vZHVsZXMvY29uZmlybS9jb25maXJtLmNvbXBvbmVudCc7XG5leHBvcnQgeyBTa3lNb2RhbENvbnRlbnRDb21wb25lbnQgYXMgzrsyIH0gZnJvbSAnLi9saWIvbW9kdWxlcy9tb2RhbC9tb2RhbC1jb250ZW50LmNvbXBvbmVudCc7XG5leHBvcnQgeyBTa3lNb2RhbEZvb3RlckNvbXBvbmVudCBhcyDOuzMgfSBmcm9tICcuL2xpYi9tb2R1bGVzL21vZGFsL21vZGFsLWZvb3Rlci5jb21wb25lbnQnO1xuZXhwb3J0IHsgU2t5TW9kYWxIZWFkZXJDb21wb25lbnQgYXMgzrs0IH0gZnJvbSAnLi9saWIvbW9kdWxlcy9tb2RhbC9tb2RhbC1oZWFkZXIuY29tcG9uZW50JztcbmV4cG9ydCB7IFNreU1vZGFsQ29tcG9uZW50IGFzIM67NSB9IGZyb20gJy4vbGliL21vZHVsZXMvbW9kYWwvbW9kYWwuY29tcG9uZW50JztcbiJdfQ==
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlybS1idXR0b24tYWN0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL21vZGFscy9zcmMvbGliL21vZHVsZXMvY29uZmlybS9jb25maXJtLWJ1dHRvbi1hY3Rpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB0eXBlIFNreUNvbmZpcm1CdXR0b25BY3Rpb24gPSAnb2snIHwgJ3llcycgfCAnbm8nIHwgJ2NhbmNlbCc7XG4iXX0=
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlybS1idXR0b24tY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL21vZGFscy9zcmMvbGliL21vZHVsZXMvY29uZmlybS9jb25maXJtLWJ1dHRvbi1jb25maWcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgU2t5Q29uZmlybUJ1dHRvbkNvbmZpZyB7XG4gIC8qKlxuICAgKiBTcGVjaWZpZXMgYW4gaWRlbnRpZmllciB0byByZXR1cm4gd2hlbiB1c2VycyBzZWxlY3QgdGhlIGJ1dHRvbiB0byBjbG9zZSB0aGVcbiAgICogY29uZmlybWF0aW9uIGRpYWxvZy4gVGhpcyBpcyB1c2VmdWwgdG8gZGV0ZXJtaW5lIHdoaWNoIGJ1dHRvbiB1c2VycyBzZWxlY3QuXG4gICAqL1xuICBhY3Rpb246IHN0cmluZztcbiAgLyoqXG4gICAqIFNwZWNpZmllcyB0aGUgbGFiZWwgZm9yIHRoZSBidXR0b24uXG4gICAqL1xuICB0ZXh0OiBzdHJpbmc7XG4gIC8qKlxuICAgKiBTcGVjaWZpZXMgYVxuICAgKiBbU0tZIFVYIGJ1dHRvbiBjbGFzc10oaHR0cHM6Ly9kZXZlbG9wZXIuYmxhY2tiYXVkLmNvbS9za3l1eC10aGVtZS9kb2NzL2J1dHRvbjtkb2NzLWFjdGl2ZS10YWI9ZGVzaWduKVxuICAgKiB0byBhcHBseSB0byB0aGUgYnV0dG9uLiBUaGUgdmFsaWQgb3B0aW9ucyBhcmVcbiAgICogYHByaW1hcnlgIHRvIGZvcm1hdCB0aGUgcHJpbWFyeSBhY3Rpb24gb24gdGhlIGRpYWxvZywgYGRlZmF1bHRgIHRvIGZvcm1hdCBhIHNlY29uZGFyeVxuICAgKiBhY3Rpb24sIGFuZCBgbGlua2AgdG8gZm9ybWF0IGFuIGFjdGlvbiB0aGF0IHRha2VzIHVzZXJzIHRvIGFub3RoZXIgcGFnZS5cbiAgICovXG4gIHN0eWxlVHlwZT86IHN0cmluZztcbiAgLyoqXG4gICAqIEluZGljYXRlcyB3aGV0aGVyIHRvIHBsYWNlIGZvY3VzIG9uIHRoaXMgYnV0dG9uIGJ5IGRlZmF1bHQuXG4gICAqL1xuICBhdXRvZm9jdXM/OiBib29sZWFuO1xufVxuIl19
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlybS1idXR0b24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvbW9kYWxzL3NyYy9saWIvbW9kdWxlcy9jb25maXJtL2NvbmZpcm0tYnV0dG9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTa3lDb25maXJtQnV0dG9uQWN0aW9uIH0gZnJvbSAnLi9jb25maXJtLWJ1dHRvbi1hY3Rpb24nO1xuXG5leHBvcnQgaW50ZXJmYWNlIFNreUNvbmZpcm1CdXR0b24ge1xuICBhY3Rpb246IFNreUNvbmZpcm1CdXR0b25BY3Rpb247XG4gIHN0eWxlVHlwZTogc3RyaW5nO1xuICB0ZXh0OiBzdHJpbmc7XG4gIGF1dG9mb2N1cz86IGJvb2xlYW47XG59XG4iXX0=
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlybS1jbG9zZWQtZXZlbnQtYXJncy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9tb2RhbHMvc3JjL2xpYi9tb2R1bGVzL2NvbmZpcm0vY29uZmlybS1jbG9zZWQtZXZlbnQtYXJncy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBTa3lDb25maXJtQ2xvc2VFdmVudEFyZ3Mge1xuICAvKipcbiAgICogVGhlIGlkZW50aWZpZXIgZm9yIHRoZSBidXR0b24gdGhhdCB1c2VycyBzZWxlY3RlZCB0byBjbG9zZSB0aGUgY29uZmlybWF0aW9uIGRpYWxvZy5cbiAgICovXG4gIGFjdGlvbjogc3RyaW5nO1xufVxuIl19
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlybS1jb25maWcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvbW9kYWxzL3NyYy9saWIvbW9kdWxlcy9jb25maXJtL2NvbmZpcm0tY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTa3lDb25maXJtQnV0dG9uQ29uZmlnIH0gZnJvbSAnLi9jb25maXJtLWJ1dHRvbi1jb25maWcnO1xuaW1wb3J0IHsgU2t5Q29uZmlybVR5cGUgfSBmcm9tICcuL2NvbmZpcm0tdHlwZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgU2t5Q29uZmlybUNvbmZpZyB7XG4gIC8qKlxuICAgKiBTcGVjaWZpZXMgdGhlIG1lc3NhZ2UgdG8gZGlzcGxheSBpbiBib2xkIGF0IHRoZSB0b3Agb2YgdGhlIGRpYWxvZy5cbiAgICogQHJlcXVpcmVkXG4gICAqL1xuICBtZXNzYWdlOiBzdHJpbmc7XG4gIC8qKlxuICAgKiBTcGVjaWZpZXMgc2Vjb25kYXJ5IHRleHQgdG8gZGlzcGxheSB1bmRlciB0aGUgcHJpbWFyeSBtZXNzYWdlLlxuICAgKi9cbiAgYm9keT86IHN0cmluZztcbiAgLyoqXG4gICAqIFNwZWNpZmllcyBhbiBhcnJheSBvZiBgU2t5Q29uZmlybUJ1dHRvbkNvbmZpZ2Agb2JqZWN0cyB0aGF0IG92ZXJ3cml0ZSB0aGUgZGVmYXVsdFxuICAgKiBjb25maWd1cmF0aW9uIGZvciBidXR0b25zLiBUaGUgbnVtYmVyIG9mIGl0ZW1zIGluIHRoZSBhcnJheSBtdXN0IG1hdGNoIHRoZSBudW1iZXIgb2ZcbiAgICogYnV0dG9ucyB0aGF0IHRoZSBgdHlwZWAgcHJvcGVydHkgc3BlY2lmaWVzLlxuICAgKi9cbiAgYnV0dG9ucz86IFNreUNvbmZpcm1CdXR0b25Db25maWdbXTtcbiAgLyoqXG4gICAqIEluZGljYXRlcyB3aGV0aGVyIHRvIHByZXNlcnZlIHdoaXRlc3BhY2UgYW5kIG5ldyBsaW5lcyBpbnNpZGUgdGhlIGNvbmZpcm0gY29tcG9uZW50LlxuICAgKiBAZGVmYXVsdCBmYWxzZVxuICAgKi9cbiAgcHJlc2VydmVXaGl0ZVNwYWNlPzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIFNwZWNpZmllcyBhIFNreUNvbmZpcm1UeXBlIGVudW0gdGhhdCBpbmRpY2F0ZXMgaG93IG1hbnkgYnV0dG9ucyB0byBpbmNsdWRlIGluIHRoZSBkaWFsb2cuXG4gICAqL1xuICB0eXBlPzogU2t5Q29uZmlybVR5cGU7XG59XG4iXX0=
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { EventEmitter } from '@angular/core';
|
|
2
|
+
export class SkyConfirmInstance {
|
|
3
|
+
constructor() {
|
|
4
|
+
/**
|
|
5
|
+
* Fires when users select an action to close the confirmation dialog. This event
|
|
6
|
+
* returns a `SkyConfirmCloseEventArgs` object with information about the button that
|
|
7
|
+
* users select.
|
|
8
|
+
*/
|
|
9
|
+
this.closed = new EventEmitter();
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlybS1pbnN0YW5jZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9tb2RhbHMvc3JjL2xpYi9tb2R1bGVzL2NvbmZpcm0vY29uZmlybS1pbnN0YW5jZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBSTdDLE1BQU0sT0FBTyxrQkFBa0I7SUFBL0I7UUFDRTs7OztXQUlHO1FBQ0ksV0FBTSxHQUFHLElBQUksWUFBWSxFQUE0QixDQUFDO0lBQy9ELENBQUM7Q0FBQSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEV2ZW50RW1pdHRlciB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBTa3lDb25maXJtQ2xvc2VFdmVudEFyZ3MgfSBmcm9tICcuL2NvbmZpcm0tY2xvc2VkLWV2ZW50LWFyZ3MnO1xuXG5leHBvcnQgY2xhc3MgU2t5Q29uZmlybUluc3RhbmNlIHtcbiAgLyoqXG4gICAqIEZpcmVzIHdoZW4gdXNlcnMgc2VsZWN0IGFuIGFjdGlvbiB0byBjbG9zZSB0aGUgY29uZmlybWF0aW9uIGRpYWxvZy4gVGhpcyBldmVudFxuICAgKiByZXR1cm5zIGEgYFNreUNvbmZpcm1DbG9zZUV2ZW50QXJnc2Agb2JqZWN0IHdpdGggaW5mb3JtYXRpb24gYWJvdXQgdGhlIGJ1dHRvbiB0aGF0XG4gICAqIHVzZXJzIHNlbGVjdC5cbiAgICovXG4gIHB1YmxpYyBjbG9zZWQgPSBuZXcgRXZlbnRFbWl0dGVyPFNreUNvbmZpcm1DbG9zZUV2ZW50QXJncz4oKTtcbn1cbiJdfQ==
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
/* istanbul ignore next */
|
|
2
|
+
export class SkyConfirmModalContext {
|
|
3
|
+
}
|
|
4
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlybS1tb2RhbC1jb250ZXh0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL21vZGFscy9zcmMvbGliL21vZHVsZXMvY29uZmlybS9jb25maXJtLW1vZGFsLWNvbnRleHQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBSUEsMEJBQTBCO0FBQzFCLE1BQU0sT0FBTyxzQkFBc0I7Q0FNbEMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTa3lDb25maXJtQnV0dG9uQ29uZmlnIH0gZnJvbSAnLi9jb25maXJtLWJ1dHRvbi1jb25maWcnO1xuaW1wb3J0IHsgU2t5Q29uZmlybUNvbmZpZyB9IGZyb20gJy4vY29uZmlybS1jb25maWcnO1xuaW1wb3J0IHsgU2t5Q29uZmlybVR5cGUgfSBmcm9tICcuL2NvbmZpcm0tdHlwZSc7XG5cbi8qIGlzdGFuYnVsIGlnbm9yZSBuZXh0ICovXG5leHBvcnQgY2xhc3MgU2t5Q29uZmlybU1vZGFsQ29udGV4dCBpbXBsZW1lbnRzIFNreUNvbmZpcm1Db25maWcge1xuICBwdWJsaWMgbWVzc2FnZTogc3RyaW5nO1xuICBwdWJsaWMgYm9keTogc3RyaW5nO1xuICBwdWJsaWMgYnV0dG9uczogU2t5Q29uZmlybUJ1dHRvbkNvbmZpZ1tdO1xuICBwdWJsaWMgcHJlc2VydmVXaGl0ZVNwYWNlOiBib29sZWFuO1xuICBwdWJsaWMgdHlwZTogU2t5Q29uZmlybVR5cGU7XG59XG4iXX0=
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
export var SkyConfirmType;
|
|
2
|
+
(function (SkyConfirmType) {
|
|
3
|
+
/**
|
|
4
|
+
* Allows you to define your own `buttons` using the buttons property to
|
|
5
|
+
* specify an array of `SkyConfirmButtonConfig` objects.
|
|
6
|
+
*/
|
|
7
|
+
SkyConfirmType[SkyConfirmType["Custom"] = 0] = "Custom";
|
|
8
|
+
/**
|
|
9
|
+
* Displays one button with an **OK** label.
|
|
10
|
+
*/
|
|
11
|
+
SkyConfirmType[SkyConfirmType["OK"] = 1] = "OK";
|
|
12
|
+
/**
|
|
13
|
+
* Displays two buttons with **Yes** and **Cancel** labels.
|
|
14
|
+
* @deprecated Use the `Custom` type to follow the guidance that labels
|
|
15
|
+
* should clearly indicate the actions that occur when users select buttons.
|
|
16
|
+
*/
|
|
17
|
+
SkyConfirmType[SkyConfirmType["YesCancel"] = 2] = "YesCancel";
|
|
18
|
+
/**
|
|
19
|
+
* Displays three buttons with **Yes**, **No**, and **Cancel** labels.
|
|
20
|
+
* @deprecated Use the `Custom` type to follow the guidance that labels
|
|
21
|
+
* should clearly indicate the actions that occur when users select buttons.
|
|
22
|
+
*/
|
|
23
|
+
SkyConfirmType[SkyConfirmType["YesNoCancel"] = 3] = "YesNoCancel";
|
|
24
|
+
})(SkyConfirmType || (SkyConfirmType = {}));
|
|
25
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlybS10eXBlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL21vZGFscy9zcmMvbGliL21vZHVsZXMvY29uZmlybS9jb25maXJtLXR5cGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFOLElBQVksY0FzQlg7QUF0QkQsV0FBWSxjQUFjO0lBQ3hCOzs7T0FHRztJQUNILHVEQUFVLENBQUE7SUFDVjs7T0FFRztJQUNILCtDQUFNLENBQUE7SUFDTjs7OztPQUlHO0lBQ0gsNkRBQWEsQ0FBQTtJQUNiOzs7O09BSUc7SUFDSCxpRUFBZSxDQUFBO0FBQ2pCLENBQUMsRUF0QlcsY0FBYyxLQUFkLGNBQWMsUUFzQnpCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGVudW0gU2t5Q29uZmlybVR5cGUge1xuICAvKipcbiAgICogQWxsb3dzIHlvdSB0byBkZWZpbmUgeW91ciBvd24gYGJ1dHRvbnNgIHVzaW5nIHRoZSBidXR0b25zIHByb3BlcnR5IHRvXG4gICAqIHNwZWNpZnkgYW4gYXJyYXkgb2YgYFNreUNvbmZpcm1CdXR0b25Db25maWdgIG9iamVjdHMuXG4gICAqL1xuICBDdXN0b20gPSAwLFxuICAvKipcbiAgICogRGlzcGxheXMgb25lIGJ1dHRvbiB3aXRoIGFuICoqT0sqKiBsYWJlbC5cbiAgICovXG4gIE9LID0gMSxcbiAgLyoqXG4gICAqIERpc3BsYXlzIHR3byBidXR0b25zIHdpdGggKipZZXMqKiBhbmQgKipDYW5jZWwqKiBsYWJlbHMuXG4gICAqIEBkZXByZWNhdGVkIFVzZSB0aGUgYEN1c3RvbWAgdHlwZSB0byBmb2xsb3cgdGhlIGd1aWRhbmNlIHRoYXQgbGFiZWxzXG4gICAqIHNob3VsZCBjbGVhcmx5IGluZGljYXRlIHRoZSBhY3Rpb25zIHRoYXQgb2NjdXIgd2hlbiB1c2VycyBzZWxlY3QgYnV0dG9ucy5cbiAgICovXG4gIFllc0NhbmNlbCA9IDIsXG4gIC8qKlxuICAgKiBEaXNwbGF5cyB0aHJlZSBidXR0b25zIHdpdGggKipZZXMqKiwgKipObyoqLCBhbmQgKipDYW5jZWwqKiBsYWJlbHMuXG4gICAqIEBkZXByZWNhdGVkIFVzZSB0aGUgYEN1c3RvbWAgdHlwZSB0byBmb2xsb3cgdGhlIGd1aWRhbmNlIHRoYXQgbGFiZWxzXG4gICAqIHNob3VsZCBjbGVhcmx5IGluZGljYXRlIHRoZSBhY3Rpb25zIHRoYXQgb2NjdXIgd2hlbiB1c2VycyBzZWxlY3QgYnV0dG9ucy5cbiAgICovXG4gIFllc05vQ2FuY2VsID0gMyxcbn1cbiJdfQ==
|
|
@@ -0,0 +1,123 @@
|
|
|
1
|
+
import { Component, Optional } from '@angular/core';
|
|
2
|
+
import { SkyLibResourcesService } from '@skyux/i18n';
|
|
3
|
+
import { BehaviorSubject, zip as observableZip } from 'rxjs';
|
|
4
|
+
import { SkyModalInstance } from '../modal/modal-instance';
|
|
5
|
+
import { SkyConfirmModalContext } from './confirm-modal-context';
|
|
6
|
+
import { SkyConfirmType } from './confirm-type';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
import * as i1 from "./confirm-modal-context";
|
|
9
|
+
import * as i2 from "../modal/modal-instance";
|
|
10
|
+
import * as i3 from "@skyux/i18n";
|
|
11
|
+
import * as i4 from "../modal/modal.component";
|
|
12
|
+
import * as i5 from "../modal/modal-content.component";
|
|
13
|
+
import * as i6 from "@angular/common";
|
|
14
|
+
import * as i7 from "@skyux/theme";
|
|
15
|
+
export class SkyConfirmComponent {
|
|
16
|
+
constructor(config, modal, resourcesService) {
|
|
17
|
+
this.config = config;
|
|
18
|
+
this.modal = modal;
|
|
19
|
+
this.resourcesService = resourcesService;
|
|
20
|
+
this.preserveWhiteSpace = false;
|
|
21
|
+
}
|
|
22
|
+
ngOnInit() {
|
|
23
|
+
if (this.config.type === SkyConfirmType.Custom &&
|
|
24
|
+
this.config.buttons.length > 0) {
|
|
25
|
+
this.buttons = this.getCustomButtons(this.config.buttons);
|
|
26
|
+
}
|
|
27
|
+
else {
|
|
28
|
+
this.getPresetButtons().subscribe((buttons) => {
|
|
29
|
+
this.buttons = buttons;
|
|
30
|
+
});
|
|
31
|
+
}
|
|
32
|
+
this.message = this.config.message;
|
|
33
|
+
this.body = this.config.body;
|
|
34
|
+
this.preserveWhiteSpace = this.config.preserveWhiteSpace || false;
|
|
35
|
+
}
|
|
36
|
+
close(button) {
|
|
37
|
+
const result = {
|
|
38
|
+
action: button.action,
|
|
39
|
+
};
|
|
40
|
+
this.modal.close(result);
|
|
41
|
+
}
|
|
42
|
+
getPresetButtons() {
|
|
43
|
+
const emitter = new BehaviorSubject([]);
|
|
44
|
+
switch (this.config.type) {
|
|
45
|
+
default:
|
|
46
|
+
case SkyConfirmType.OK:
|
|
47
|
+
this.resourcesService
|
|
48
|
+
.getString('skyux_confirm_dialog_default_ok_text')
|
|
49
|
+
.subscribe((value) => {
|
|
50
|
+
emitter.next([
|
|
51
|
+
{
|
|
52
|
+
text: value,
|
|
53
|
+
autofocus: true,
|
|
54
|
+
styleType: 'primary',
|
|
55
|
+
action: 'ok',
|
|
56
|
+
},
|
|
57
|
+
]);
|
|
58
|
+
});
|
|
59
|
+
break;
|
|
60
|
+
case SkyConfirmType.YesNoCancel:
|
|
61
|
+
observableZip(this.resourcesService.getString('skyux_confirm_dialog_default_yes_text'), this.resourcesService.getString('skyux_confirm_dialog_default_no_text'), this.resourcesService.getString('skyux_confirm_dialog_default_cancel_text')).subscribe((values) => {
|
|
62
|
+
emitter.next([
|
|
63
|
+
{
|
|
64
|
+
text: values[0],
|
|
65
|
+
autofocus: true,
|
|
66
|
+
styleType: 'primary',
|
|
67
|
+
action: 'yes',
|
|
68
|
+
},
|
|
69
|
+
{
|
|
70
|
+
text: values[1],
|
|
71
|
+
styleType: 'default',
|
|
72
|
+
action: 'no',
|
|
73
|
+
},
|
|
74
|
+
{
|
|
75
|
+
text: values[2],
|
|
76
|
+
styleType: 'link',
|
|
77
|
+
action: 'cancel',
|
|
78
|
+
},
|
|
79
|
+
]);
|
|
80
|
+
});
|
|
81
|
+
break;
|
|
82
|
+
case SkyConfirmType.YesCancel:
|
|
83
|
+
observableZip(this.resourcesService.getString('skyux_confirm_dialog_default_yes_text'), this.resourcesService.getString('skyux_confirm_dialog_default_cancel_text')).subscribe((values) => {
|
|
84
|
+
emitter.next([
|
|
85
|
+
{
|
|
86
|
+
text: values[0],
|
|
87
|
+
autofocus: true,
|
|
88
|
+
styleType: 'primary',
|
|
89
|
+
action: 'yes',
|
|
90
|
+
},
|
|
91
|
+
{
|
|
92
|
+
text: values[1],
|
|
93
|
+
styleType: 'link',
|
|
94
|
+
action: 'cancel',
|
|
95
|
+
},
|
|
96
|
+
]);
|
|
97
|
+
});
|
|
98
|
+
break;
|
|
99
|
+
}
|
|
100
|
+
return emitter;
|
|
101
|
+
}
|
|
102
|
+
getCustomButtons(buttonConfig) {
|
|
103
|
+
const buttons = [];
|
|
104
|
+
buttonConfig.forEach((config) => {
|
|
105
|
+
buttons.push({
|
|
106
|
+
text: config.text,
|
|
107
|
+
action: config.action,
|
|
108
|
+
styleType: config.styleType || 'default',
|
|
109
|
+
autofocus: config.autofocus || false,
|
|
110
|
+
});
|
|
111
|
+
});
|
|
112
|
+
return buttons;
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
SkyConfirmComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: SkyConfirmComponent, deps: [{ token: i1.SkyConfirmModalContext }, { token: i2.SkyModalInstance }, { token: i3.SkyLibResourcesService, optional: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
116
|
+
SkyConfirmComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.7", type: SkyConfirmComponent, selector: "sky-confirm", ngImport: i0, template: "<div class=\"sky-confirm\">\n <sky-modal ariaRole=\"alertdialog\">\n <sky-modal-content class=\"sky-confirm-content\">\n <div\n class=\"sky-confirm-message\"\n [ngClass]=\"{\n 'sky-confirm-preserve-white-space': preserveWhiteSpace\n }\"\n [skyThemeClass]=\"{\n 'sky-emphasized': 'default',\n 'sky-font-heading-1 sky-font-display-3': 'modern'\n }\"\n >\n {{ message }}\n </div>\n\n <div\n *ngIf=\"body\"\n class=\"sky-confirm-body\"\n [ngClass]=\"{\n 'sky-confirm-preserve-white-space': preserveWhiteSpace\n }\"\n >\n {{ body }}\n </div>\n\n <div class=\"sky-confirm-buttons\">\n <button\n *ngFor=\"let button of buttons\"\n type=\"button\"\n class=\"sky-btn\"\n [ngClass]=\"['sky-btn-' + button.styleType]\"\n [skyThemeClass]=\"{\n 'sky-margin-inline-sm': 'modern',\n 'sky-margin-inline-compact': 'default'\n }\"\n (click)=\"close(button)\"\n [attr.autofocus]=\"button.autofocus ? 'autofocus' : null\"\n >\n {{ button.text }}\n </button>\n </div>\n </sky-modal-content>\n </sky-modal>\n</div>\n", styles: [".sky-confirm-message{margin-top:5px}.sky-confirm-body{margin-top:10px}.sky-confirm-buttons{margin-top:20px}.sky-confirm-preserve-white-space{white-space:pre-wrap}:host-context(.sky-theme-modern) .sky-confirm-content{padding:20px 30px}:host-context(.sky-theme-modern) .sky-confirm-message{padding-bottom:20px}:host-context(.sky-theme-modern) .sky-confirm-body{margin:0}.sky-theme-modern .sky-confirm-content{padding:20px 30px}.sky-theme-modern .sky-confirm-message{padding-bottom:20px}.sky-theme-modern .sky-confirm-body{margin:0}:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-confirm-message{color:#fbfcfe}.sky-theme-modern.sky-theme-mode-dark .sky-confirm-message{color:#fbfcfe}\n"], components: [{ type: i4.SkyModalComponent, selector: "sky-modal", inputs: ["ariaRole", "tiledBody"] }, { type: i5.SkyModalContentComponent, selector: "sky-modal-content" }], directives: [{ type: i6.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i7.λ2, selector: "[skyThemeClass]", inputs: ["class", "skyThemeClass"] }, { type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
|
|
117
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: SkyConfirmComponent, decorators: [{
|
|
118
|
+
type: Component,
|
|
119
|
+
args: [{ selector: 'sky-confirm', template: "<div class=\"sky-confirm\">\n <sky-modal ariaRole=\"alertdialog\">\n <sky-modal-content class=\"sky-confirm-content\">\n <div\n class=\"sky-confirm-message\"\n [ngClass]=\"{\n 'sky-confirm-preserve-white-space': preserveWhiteSpace\n }\"\n [skyThemeClass]=\"{\n 'sky-emphasized': 'default',\n 'sky-font-heading-1 sky-font-display-3': 'modern'\n }\"\n >\n {{ message }}\n </div>\n\n <div\n *ngIf=\"body\"\n class=\"sky-confirm-body\"\n [ngClass]=\"{\n 'sky-confirm-preserve-white-space': preserveWhiteSpace\n }\"\n >\n {{ body }}\n </div>\n\n <div class=\"sky-confirm-buttons\">\n <button\n *ngFor=\"let button of buttons\"\n type=\"button\"\n class=\"sky-btn\"\n [ngClass]=\"['sky-btn-' + button.styleType]\"\n [skyThemeClass]=\"{\n 'sky-margin-inline-sm': 'modern',\n 'sky-margin-inline-compact': 'default'\n }\"\n (click)=\"close(button)\"\n [attr.autofocus]=\"button.autofocus ? 'autofocus' : null\"\n >\n {{ button.text }}\n </button>\n </div>\n </sky-modal-content>\n </sky-modal>\n</div>\n", styles: [".sky-confirm-message{margin-top:5px}.sky-confirm-body{margin-top:10px}.sky-confirm-buttons{margin-top:20px}.sky-confirm-preserve-white-space{white-space:pre-wrap}:host-context(.sky-theme-modern) .sky-confirm-content{padding:20px 30px}:host-context(.sky-theme-modern) .sky-confirm-message{padding-bottom:20px}:host-context(.sky-theme-modern) .sky-confirm-body{margin:0}.sky-theme-modern .sky-confirm-content{padding:20px 30px}.sky-theme-modern .sky-confirm-message{padding-bottom:20px}.sky-theme-modern .sky-confirm-body{margin:0}:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-confirm-message{color:#fbfcfe}.sky-theme-modern.sky-theme-mode-dark .sky-confirm-message{color:#fbfcfe}\n"] }]
|
|
120
|
+
}], ctorParameters: function () { return [{ type: i1.SkyConfirmModalContext }, { type: i2.SkyModalInstance }, { type: i3.SkyLibResourcesService, decorators: [{
|
|
121
|
+
type: Optional
|
|
122
|
+
}] }]; } });
|
|
123
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"confirm.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/modals/src/lib/modules/confirm/confirm.component.ts","../../../../../../../../libs/components/modals/src/lib/modules/confirm/confirm.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Optional } from '@angular/core';\nimport { SkyLibResourcesService } from '@skyux/i18n';\n\nimport { BehaviorSubject, Observable, zip as observableZip } from 'rxjs';\n\nimport { SkyModalInstance } from '../modal/modal-instance';\n\nimport { SkyConfirmButton } from './confirm-button';\nimport { SkyConfirmButtonConfig } from './confirm-button-config';\nimport { SkyConfirmCloseEventArgs } from './confirm-closed-event-args';\nimport { SkyConfirmModalContext } from './confirm-modal-context';\nimport { SkyConfirmType } from './confirm-type';\n\n@Component({\n  selector: 'sky-confirm',\n  templateUrl: './confirm.component.html',\n  styleUrls: ['./confirm.component.scss'],\n})\nexport class SkyConfirmComponent implements OnInit {\n  public buttons: SkyConfirmButton[];\n  public message: string;\n  public body: string;\n  public preserveWhiteSpace = false;\n\n  constructor(\n    private config: SkyConfirmModalContext,\n    private modal: SkyModalInstance,\n    @Optional() private resourcesService: SkyLibResourcesService\n  ) {}\n\n  public ngOnInit() {\n    if (\n      this.config.type === SkyConfirmType.Custom &&\n      this.config.buttons.length > 0\n    ) {\n      this.buttons = this.getCustomButtons(this.config.buttons);\n    } else {\n      this.getPresetButtons().subscribe((buttons: SkyConfirmButton[]) => {\n        this.buttons = buttons;\n      });\n    }\n\n    this.message = this.config.message;\n    this.body = this.config.body;\n    this.preserveWhiteSpace = this.config.preserveWhiteSpace || false;\n  }\n\n  public close(button: SkyConfirmButton) {\n    const result: SkyConfirmCloseEventArgs = {\n      action: button.action,\n    };\n\n    this.modal.close(result);\n  }\n\n  private getPresetButtons(): Observable<SkyConfirmButton[]> {\n    const emitter = new BehaviorSubject<SkyConfirmButton[]>([]);\n\n    switch (this.config.type) {\n      default:\n      case SkyConfirmType.OK:\n        this.resourcesService\n          .getString('skyux_confirm_dialog_default_ok_text')\n          .subscribe((value: string) => {\n            emitter.next([\n              {\n                text: value,\n                autofocus: true,\n                styleType: 'primary',\n                action: 'ok',\n              },\n            ]);\n          });\n        break;\n\n      case SkyConfirmType.YesNoCancel:\n        observableZip(\n          this.resourcesService.getString(\n            'skyux_confirm_dialog_default_yes_text'\n          ),\n          this.resourcesService.getString(\n            'skyux_confirm_dialog_default_no_text'\n          ),\n          this.resourcesService.getString(\n            'skyux_confirm_dialog_default_cancel_text'\n          )\n        ).subscribe((values: any) => {\n          emitter.next([\n            {\n              text: values[0],\n              autofocus: true,\n              styleType: 'primary',\n              action: 'yes',\n            },\n            {\n              text: values[1],\n              styleType: 'default',\n              action: 'no',\n            },\n            {\n              text: values[2],\n              styleType: 'link',\n              action: 'cancel',\n            },\n          ]);\n        });\n        break;\n\n      case SkyConfirmType.YesCancel:\n        observableZip(\n          this.resourcesService.getString(\n            'skyux_confirm_dialog_default_yes_text'\n          ),\n          this.resourcesService.getString(\n            'skyux_confirm_dialog_default_cancel_text'\n          )\n        ).subscribe((values: any) => {\n          emitter.next([\n            {\n              text: values[0],\n              autofocus: true,\n              styleType: 'primary',\n              action: 'yes',\n            },\n            {\n              text: values[1],\n              styleType: 'link',\n              action: 'cancel',\n            },\n          ]);\n        });\n        break;\n    }\n\n    return emitter;\n  }\n\n  private getCustomButtons(\n    buttonConfig: SkyConfirmButtonConfig[]\n  ): SkyConfirmButton[] {\n    const buttons: SkyConfirmButton[] = [];\n\n    buttonConfig.forEach((config: SkyConfirmButtonConfig) => {\n      buttons.push({\n        text: config.text,\n        action: config.action,\n        styleType: config.styleType || 'default',\n        autofocus: config.autofocus || false,\n      } as SkyConfirmButton);\n    });\n\n    return buttons;\n  }\n}\n","<div class=\"sky-confirm\">\n  <sky-modal ariaRole=\"alertdialog\">\n    <sky-modal-content class=\"sky-confirm-content\">\n      <div\n        class=\"sky-confirm-message\"\n        [ngClass]=\"{\n          'sky-confirm-preserve-white-space': preserveWhiteSpace\n        }\"\n        [skyThemeClass]=\"{\n          'sky-emphasized': 'default',\n          'sky-font-heading-1 sky-font-display-3': 'modern'\n        }\"\n      >\n        {{ message }}\n      </div>\n\n      <div\n        *ngIf=\"body\"\n        class=\"sky-confirm-body\"\n        [ngClass]=\"{\n          'sky-confirm-preserve-white-space': preserveWhiteSpace\n        }\"\n      >\n        {{ body }}\n      </div>\n\n      <div class=\"sky-confirm-buttons\">\n        <button\n          *ngFor=\"let button of buttons\"\n          type=\"button\"\n          class=\"sky-btn\"\n          [ngClass]=\"['sky-btn-' + button.styleType]\"\n          [skyThemeClass]=\"{\n            'sky-margin-inline-sm': 'modern',\n            'sky-margin-inline-compact': 'default'\n          }\"\n          (click)=\"close(button)\"\n          [attr.autofocus]=\"button.autofocus ? 'autofocus' : null\"\n        >\n          {{ button.text }}\n        </button>\n      </div>\n    </sky-modal-content>\n  </sky-modal>\n</div>\n"]}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { NgModule } from '@angular/core';
|
|
3
|
+
import { SkyThemeModule } from '@skyux/theme';
|
|
4
|
+
import { SkyModalModule } from '../modal/modal.module';
|
|
5
|
+
import { SkyModalsResourcesModule } from '../shared/sky-modals-resources.module';
|
|
6
|
+
import { SkyConfirmComponent } from './confirm.component';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
export class SkyConfirmModule {
|
|
9
|
+
}
|
|
10
|
+
SkyConfirmModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: SkyConfirmModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
11
|
+
SkyConfirmModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: SkyConfirmModule, declarations: [SkyConfirmComponent], imports: [CommonModule,
|
|
12
|
+
SkyModalModule,
|
|
13
|
+
SkyModalsResourcesModule,
|
|
14
|
+
SkyThemeModule], exports: [SkyConfirmComponent] });
|
|
15
|
+
SkyConfirmModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: SkyConfirmModule, imports: [[
|
|
16
|
+
CommonModule,
|
|
17
|
+
SkyModalModule,
|
|
18
|
+
SkyModalsResourcesModule,
|
|
19
|
+
SkyThemeModule,
|
|
20
|
+
]] });
|
|
21
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: SkyConfirmModule, decorators: [{
|
|
22
|
+
type: NgModule,
|
|
23
|
+
args: [{
|
|
24
|
+
declarations: [SkyConfirmComponent],
|
|
25
|
+
imports: [
|
|
26
|
+
CommonModule,
|
|
27
|
+
SkyModalModule,
|
|
28
|
+
SkyModalsResourcesModule,
|
|
29
|
+
SkyThemeModule,
|
|
30
|
+
],
|
|
31
|
+
exports: [SkyConfirmComponent],
|
|
32
|
+
}]
|
|
33
|
+
}] });
|
|
34
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlybS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvbW9kYWxzL3NyYy9saWIvbW9kdWxlcy9jb25maXJtL2NvbmZpcm0ubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFFOUMsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLHVDQUF1QyxDQUFDO0FBRWpGLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHFCQUFxQixDQUFDOztBQVkxRCxNQUFNLE9BQU8sZ0JBQWdCOzs2R0FBaEIsZ0JBQWdCOzhHQUFoQixnQkFBZ0IsaUJBVFosbUJBQW1CLGFBRWhDLFlBQVk7UUFDWixjQUFjO1FBQ2Qsd0JBQXdCO1FBQ3hCLGNBQWMsYUFFTixtQkFBbUI7OEdBRWxCLGdCQUFnQixZQVJsQjtZQUNQLFlBQVk7WUFDWixjQUFjO1lBQ2Qsd0JBQXdCO1lBQ3hCLGNBQWM7U0FDZjsyRkFHVSxnQkFBZ0I7a0JBVjVCLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLENBQUMsbUJBQW1CLENBQUM7b0JBQ25DLE9BQU8sRUFBRTt3QkFDUCxZQUFZO3dCQUNaLGNBQWM7d0JBQ2Qsd0JBQXdCO3dCQUN4QixjQUFjO3FCQUNmO29CQUNELE9BQU8sRUFBRSxDQUFDLG1CQUFtQixDQUFDO2lCQUMvQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgU2t5VGhlbWVNb2R1bGUgfSBmcm9tICdAc2t5dXgvdGhlbWUnO1xuXG5pbXBvcnQgeyBTa3lNb2RhbE1vZHVsZSB9IGZyb20gJy4uL21vZGFsL21vZGFsLm1vZHVsZSc7XG5pbXBvcnQgeyBTa3lNb2RhbHNSZXNvdXJjZXNNb2R1bGUgfSBmcm9tICcuLi9zaGFyZWQvc2t5LW1vZGFscy1yZXNvdXJjZXMubW9kdWxlJztcblxuaW1wb3J0IHsgU2t5Q29uZmlybUNvbXBvbmVudCB9IGZyb20gJy4vY29uZmlybS5jb21wb25lbnQnO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtTa3lDb25maXJtQ29tcG9uZW50XSxcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZSxcbiAgICBTa3lNb2RhbE1vZHVsZSxcbiAgICBTa3lNb2RhbHNSZXNvdXJjZXNNb2R1bGUsXG4gICAgU2t5VGhlbWVNb2R1bGUsXG4gIF0sXG4gIGV4cG9ydHM6IFtTa3lDb25maXJtQ29tcG9uZW50XSxcbn0pXG5leHBvcnQgY2xhc3MgU2t5Q29uZmlybU1vZHVsZSB7fVxuIl19
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import { SkyModalService } from '../modal/modal.service';
|
|
3
|
+
import { SkyConfirmInstance } from './confirm-instance';
|
|
4
|
+
import { SkyConfirmModalContext } from './confirm-modal-context';
|
|
5
|
+
import { SkyConfirmComponent } from './confirm.component';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "../modal/modal.service";
|
|
8
|
+
/**
|
|
9
|
+
* The `SkyConfirmService` provider launches the confirmation dialog.
|
|
10
|
+
* Within the service, you can specify the dialog's message and customize the button text.
|
|
11
|
+
*/
|
|
12
|
+
export class SkyConfirmService {
|
|
13
|
+
constructor(modalService) {
|
|
14
|
+
this.modalService = modalService;
|
|
15
|
+
}
|
|
16
|
+
/**
|
|
17
|
+
* Opens a confirmation dialog and passes the `config` parameter of type `SkyConfirmConfig`
|
|
18
|
+
* to the component's constructor. This method returns an object of type `SkyConfirmInstance`.
|
|
19
|
+
*/
|
|
20
|
+
open(config) {
|
|
21
|
+
const modalInstance = this.modalService.open(SkyConfirmComponent, {
|
|
22
|
+
providers: [
|
|
23
|
+
{
|
|
24
|
+
provide: SkyConfirmModalContext,
|
|
25
|
+
useValue: config,
|
|
26
|
+
},
|
|
27
|
+
],
|
|
28
|
+
});
|
|
29
|
+
const confirmInstance = new SkyConfirmInstance();
|
|
30
|
+
modalInstance.closed.subscribe((args) => {
|
|
31
|
+
let result = args.data;
|
|
32
|
+
// The modal was closed using the ESC key.
|
|
33
|
+
if (result === undefined) {
|
|
34
|
+
result = {
|
|
35
|
+
action: 'cancel',
|
|
36
|
+
};
|
|
37
|
+
}
|
|
38
|
+
confirmInstance.closed.emit(result);
|
|
39
|
+
confirmInstance.closed.complete();
|
|
40
|
+
});
|
|
41
|
+
return confirmInstance;
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
SkyConfirmService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: SkyConfirmService, deps: [{ token: i1.SkyModalService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
45
|
+
SkyConfirmService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: SkyConfirmService, providedIn: 'any' });
|
|
46
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: SkyConfirmService, decorators: [{
|
|
47
|
+
type: Injectable,
|
|
48
|
+
args: [{
|
|
49
|
+
// Must be 'any' so that the modal component is created in the context of its module's injector.
|
|
50
|
+
// If set to 'root', the component's dependency injections would only be derived from the root
|
|
51
|
+
// injector and may loose context if the modal was opened from within a lazy-loaded module.
|
|
52
|
+
providedIn: 'any',
|
|
53
|
+
}]
|
|
54
|
+
}], ctorParameters: function () { return [{ type: i1.SkyModalService }]; } });
|
|
55
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlybS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL21vZGFscy9zcmMvbGliL21vZHVsZXMvY29uZmlybS9jb25maXJtLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUkzQyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFJekQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDeEQsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDakUsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0scUJBQXFCLENBQUM7OztBQUUxRDs7O0dBR0c7QUFPSCxNQUFNLE9BQU8saUJBQWlCO0lBQzVCLFlBQW9CLFlBQTZCO1FBQTdCLGlCQUFZLEdBQVosWUFBWSxDQUFpQjtJQUFHLENBQUM7SUFFckQ7OztPQUdHO0lBQ0ksSUFBSSxDQUFDLE1BQXdCO1FBQ2xDLE1BQU0sYUFBYSxHQUFxQixJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksQ0FDNUQsbUJBQW1CLEVBQ25CO1lBQ0UsU0FBUyxFQUFFO2dCQUNUO29CQUNFLE9BQU8sRUFBRSxzQkFBc0I7b0JBQy9CLFFBQVEsRUFBRSxNQUFNO2lCQUNqQjthQUNGO1NBQ0YsQ0FDRixDQUFDO1FBRUYsTUFBTSxlQUFlLEdBQUcsSUFBSSxrQkFBa0IsRUFBRSxDQUFDO1FBRWpELGFBQWEsQ0FBQyxNQUFNLENBQUMsU0FBUyxDQUFDLENBQUMsSUFBdUIsRUFBRSxFQUFFO1lBQ3pELElBQUksTUFBTSxHQUE2QixJQUFJLENBQUMsSUFBSSxDQUFDO1lBRWpELDBDQUEwQztZQUMxQyxJQUFJLE1BQU0sS0FBSyxTQUFTLEVBQUU7Z0JBQ3hCLE1BQU0sR0FBRztvQkFDUCxNQUFNLEVBQUUsUUFBUTtpQkFDakIsQ0FBQzthQUNIO1lBRUQsZUFBZSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7WUFDcEMsZUFBZSxDQUFDLE1BQU0sQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUNwQyxDQUFDLENBQUMsQ0FBQztRQUVILE9BQU8sZUFBZSxDQUFDO0lBQ3pCLENBQUM7OzhHQXJDVSxpQkFBaUI7a0hBQWpCLGlCQUFpQixjQUZoQixLQUFLOzJGQUVOLGlCQUFpQjtrQkFON0IsVUFBVTttQkFBQztvQkFDVixnR0FBZ0c7b0JBQ2hHLDhGQUE4RjtvQkFDOUYsMkZBQTJGO29CQUMzRixVQUFVLEVBQUUsS0FBSztpQkFDbEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IFNreU1vZGFsQ2xvc2VBcmdzIH0gZnJvbSAnLi4vbW9kYWwvbW9kYWwtY2xvc2UtYXJncyc7XG5pbXBvcnQgeyBTa3lNb2RhbEluc3RhbmNlIH0gZnJvbSAnLi4vbW9kYWwvbW9kYWwtaW5zdGFuY2UnO1xuaW1wb3J0IHsgU2t5TW9kYWxTZXJ2aWNlIH0gZnJvbSAnLi4vbW9kYWwvbW9kYWwuc2VydmljZSc7XG5cbmltcG9ydCB7IFNreUNvbmZpcm1DbG9zZUV2ZW50QXJncyB9IGZyb20gJy4vY29uZmlybS1jbG9zZWQtZXZlbnQtYXJncyc7XG5pbXBvcnQgeyBTa3lDb25maXJtQ29uZmlnIH0gZnJvbSAnLi9jb25maXJtLWNvbmZpZyc7XG5pbXBvcnQgeyBTa3lDb25maXJtSW5zdGFuY2UgfSBmcm9tICcuL2NvbmZpcm0taW5zdGFuY2UnO1xuaW1wb3J0IHsgU2t5Q29uZmlybU1vZGFsQ29udGV4dCB9IGZyb20gJy4vY29uZmlybS1tb2RhbC1jb250ZXh0JztcbmltcG9ydCB7IFNreUNvbmZpcm1Db21wb25lbnQgfSBmcm9tICcuL2NvbmZpcm0uY29tcG9uZW50JztcblxuLyoqXG4gKiAgVGhlIGBTa3lDb25maXJtU2VydmljZWAgcHJvdmlkZXIgbGF1bmNoZXMgdGhlIGNvbmZpcm1hdGlvbiBkaWFsb2cuXG4gKiBXaXRoaW4gdGhlIHNlcnZpY2UsIHlvdSBjYW4gc3BlY2lmeSB0aGUgZGlhbG9nJ3MgbWVzc2FnZSBhbmQgY3VzdG9taXplIHRoZSBidXR0b24gdGV4dC5cbiAqL1xuQEluamVjdGFibGUoe1xuICAvLyBNdXN0IGJlICdhbnknIHNvIHRoYXQgdGhlIG1vZGFsIGNvbXBvbmVudCBpcyBjcmVhdGVkIGluIHRoZSBjb250ZXh0IG9mIGl0cyBtb2R1bGUncyBpbmplY3Rvci5cbiAgLy8gSWYgc2V0IHRvICdyb290JywgdGhlIGNvbXBvbmVudCdzIGRlcGVuZGVuY3kgaW5qZWN0aW9ucyB3b3VsZCBvbmx5IGJlIGRlcml2ZWQgZnJvbSB0aGUgcm9vdFxuICAvLyBpbmplY3RvciBhbmQgbWF5IGxvb3NlIGNvbnRleHQgaWYgdGhlIG1vZGFsIHdhcyBvcGVuZWQgZnJvbSB3aXRoaW4gYSBsYXp5LWxvYWRlZCBtb2R1bGUuXG4gIHByb3ZpZGVkSW46ICdhbnknLFxufSlcbmV4cG9ydCBjbGFzcyBTa3lDb25maXJtU2VydmljZSB7XG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgbW9kYWxTZXJ2aWNlOiBTa3lNb2RhbFNlcnZpY2UpIHt9XG5cbiAgLyoqXG4gICAqIE9wZW5zIGEgY29uZmlybWF0aW9uIGRpYWxvZyBhbmQgcGFzc2VzIHRoZSBgY29uZmlnYCBwYXJhbWV0ZXIgb2YgdHlwZSBgU2t5Q29uZmlybUNvbmZpZ2BcbiAgICogdG8gdGhlIGNvbXBvbmVudCdzIGNvbnN0cnVjdG9yLiBUaGlzIG1ldGhvZCByZXR1cm5zIGFuIG9iamVjdCBvZiB0eXBlIGBTa3lDb25maXJtSW5zdGFuY2VgLlxuICAgKi9cbiAgcHVibGljIG9wZW4oY29uZmlnOiBTa3lDb25maXJtQ29uZmlnKTogU2t5Q29uZmlybUluc3RhbmNlIHtcbiAgICBjb25zdCBtb2RhbEluc3RhbmNlOiBTa3lNb2RhbEluc3RhbmNlID0gdGhpcy5tb2RhbFNlcnZpY2Uub3BlbihcbiAgICAgIFNreUNvbmZpcm1Db21wb25lbnQsXG4gICAgICB7XG4gICAgICAgIHByb3ZpZGVyczogW1xuICAgICAgICAgIHtcbiAgICAgICAgICAgIHByb3ZpZGU6IFNreUNvbmZpcm1Nb2RhbENvbnRleHQsXG4gICAgICAgICAgICB1c2VWYWx1ZTogY29uZmlnLFxuICAgICAgICAgIH0sXG4gICAgICAgIF0sXG4gICAgICB9XG4gICAgKTtcblxuICAgIGNvbnN0IGNvbmZpcm1JbnN0YW5jZSA9IG5ldyBTa3lDb25maXJtSW5zdGFuY2UoKTtcblxuICAgIG1vZGFsSW5zdGFuY2UuY2xvc2VkLnN1YnNjcmliZSgoYXJnczogU2t5TW9kYWxDbG9zZUFyZ3MpID0+IHtcbiAgICAgIGxldCByZXN1bHQ6IFNreUNvbmZpcm1DbG9zZUV2ZW50QXJncyA9IGFyZ3MuZGF0YTtcblxuICAgICAgLy8gVGhlIG1vZGFsIHdhcyBjbG9zZWQgdXNpbmcgdGhlIEVTQyBrZXkuXG4gICAgICBpZiAocmVzdWx0ID09PSB1bmRlZmluZWQpIHtcbiAgICAgICAgcmVzdWx0ID0ge1xuICAgICAgICAgIGFjdGlvbjogJ2NhbmNlbCcsXG4gICAgICAgIH07XG4gICAgICB9XG5cbiAgICAgIGNvbmZpcm1JbnN0YW5jZS5jbG9zZWQuZW1pdChyZXN1bHQpO1xuICAgICAgY29uZmlybUluc3RhbmNlLmNsb3NlZC5jb21wbGV0ZSgpO1xuICAgIH0pO1xuXG4gICAgcmV0dXJuIGNvbmZpcm1JbnN0YW5jZTtcbiAgfVxufVxuIl19
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import { SkyAppWindowRef } from '@skyux/core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@skyux/core";
|
|
5
|
+
/**
|
|
6
|
+
* @internal
|
|
7
|
+
*/
|
|
8
|
+
export class SkyModalAdapterService {
|
|
9
|
+
constructor(windowRef) {
|
|
10
|
+
this.windowRef = windowRef;
|
|
11
|
+
this.docRef = this.windowRef.nativeWindow.document;
|
|
12
|
+
this.bodyEl = this.windowRef.nativeWindow.document.body;
|
|
13
|
+
}
|
|
14
|
+
toggleFullPageModalClass(isAddFull) {
|
|
15
|
+
if (isAddFull) {
|
|
16
|
+
this.addClassToBody(SkyModalAdapterService.MODAL_BODY_FULL_CLASS);
|
|
17
|
+
}
|
|
18
|
+
else {
|
|
19
|
+
this.removeClassFromBody(SkyModalAdapterService.MODAL_BODY_FULL_CLASS);
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
setPageScroll(isAdd) {
|
|
23
|
+
if (isAdd) {
|
|
24
|
+
this.addClassToBody(SkyModalAdapterService.MODAL_BODY_CLASS);
|
|
25
|
+
}
|
|
26
|
+
else {
|
|
27
|
+
this.removeClassFromBody(SkyModalAdapterService.MODAL_BODY_CLASS);
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
getModalOpener() {
|
|
31
|
+
return this.docRef.activeElement;
|
|
32
|
+
}
|
|
33
|
+
addClassToBody(className) {
|
|
34
|
+
this.bodyEl.classList.add(className);
|
|
35
|
+
}
|
|
36
|
+
removeClassFromBody(className) {
|
|
37
|
+
this.bodyEl.classList.remove(className);
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
SkyModalAdapterService.MODAL_BODY_FULL_CLASS = 'sky-modal-body-full-page';
|
|
41
|
+
SkyModalAdapterService.MODAL_BODY_CLASS = 'sky-modal-body-open';
|
|
42
|
+
SkyModalAdapterService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: SkyModalAdapterService, deps: [{ token: i1.SkyAppWindowRef }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
43
|
+
SkyModalAdapterService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: SkyModalAdapterService });
|
|
44
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: SkyModalAdapterService, decorators: [{
|
|
45
|
+
type: Injectable
|
|
46
|
+
}], ctorParameters: function () { return [{ type: i1.SkyAppWindowRef }]; } });
|
|
47
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kYWwtYWRhcHRlci5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL21vZGFscy9zcmMvbGliL21vZHVsZXMvbW9kYWwvbW9kYWwtYWRhcHRlci5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDM0MsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLGFBQWEsQ0FBQzs7O0FBRTlDOztHQUVHO0FBRUgsTUFBTSxPQUFPLHNCQUFzQjtJQU9qQyxZQUFvQixTQUEwQjtRQUExQixjQUFTLEdBQVQsU0FBUyxDQUFpQjtRQUM1QyxJQUFJLENBQUMsTUFBTSxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsWUFBWSxDQUFDLFFBQVEsQ0FBQztRQUNuRCxJQUFJLENBQUMsTUFBTSxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsWUFBWSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUM7SUFDMUQsQ0FBQztJQUVNLHdCQUF3QixDQUFDLFNBQWtCO1FBQ2hELElBQUksU0FBUyxFQUFFO1lBQ2IsSUFBSSxDQUFDLGNBQWMsQ0FBQyxzQkFBc0IsQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDO1NBQ25FO2FBQU07WUFDTCxJQUFJLENBQUMsbUJBQW1CLENBQUMsc0JBQXNCLENBQUMscUJBQXFCLENBQUMsQ0FBQztTQUN4RTtJQUNILENBQUM7SUFFTSxhQUFhLENBQUMsS0FBYztRQUNqQyxJQUFJLEtBQUssRUFBRTtZQUNULElBQUksQ0FBQyxjQUFjLENBQUMsc0JBQXNCLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztTQUM5RDthQUFNO1lBQ0wsSUFBSSxDQUFDLG1CQUFtQixDQUFDLHNCQUFzQixDQUFDLGdCQUFnQixDQUFDLENBQUM7U0FDbkU7SUFDSCxDQUFDO0lBRU0sY0FBYztRQUNuQixPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsYUFBYSxDQUFDO0lBQ25DLENBQUM7SUFFTyxjQUFjLENBQUMsU0FBaUI7UUFDdEMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLFNBQVMsQ0FBQyxDQUFDO0lBQ3ZDLENBQUM7SUFFTyxtQkFBbUIsQ0FBQyxTQUFpQjtRQUMzQyxJQUFJLENBQUMsTUFBTSxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsU0FBUyxDQUFDLENBQUM7SUFDMUMsQ0FBQzs7QUFyQ3VCLDRDQUFxQixHQUFHLDBCQUEyQixDQUFBO0FBQ25ELHVDQUFnQixHQUFHLHFCQUFzQixDQUFBO21IQUZ0RCxzQkFBc0I7dUhBQXRCLHNCQUFzQjsyRkFBdEIsc0JBQXNCO2tCQURsQyxVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgU2t5QXBwV2luZG93UmVmIH0gZnJvbSAnQHNreXV4L2NvcmUnO1xuXG4vKipcbiAqIEBpbnRlcm5hbFxuICovXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgU2t5TW9kYWxBZGFwdGVyU2VydmljZSB7XG4gIHByaXZhdGUgc3RhdGljIHJlYWRvbmx5IE1PREFMX0JPRFlfRlVMTF9DTEFTUyA9ICdza3ktbW9kYWwtYm9keS1mdWxsLXBhZ2UnO1xuICBwcml2YXRlIHN0YXRpYyByZWFkb25seSBNT0RBTF9CT0RZX0NMQVNTID0gJ3NreS1tb2RhbC1ib2R5LW9wZW4nO1xuXG4gIHByaXZhdGUgZG9jUmVmOiBhbnk7XG4gIHByaXZhdGUgYm9keUVsOiBIVE1MRWxlbWVudDtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHdpbmRvd1JlZjogU2t5QXBwV2luZG93UmVmKSB7XG4gICAgdGhpcy5kb2NSZWYgPSB0aGlzLndpbmRvd1JlZi5uYXRpdmVXaW5kb3cuZG9jdW1lbnQ7XG4gICAgdGhpcy5ib2R5RWwgPSB0aGlzLndpbmRvd1JlZi5uYXRpdmVXaW5kb3cuZG9jdW1lbnQuYm9keTtcbiAgfVxuXG4gIHB1YmxpYyB0b2dnbGVGdWxsUGFnZU1vZGFsQ2xhc3MoaXNBZGRGdWxsOiBib29sZWFuKTogdm9pZCB7XG4gICAgaWYgKGlzQWRkRnVsbCkge1xuICAgICAgdGhpcy5hZGRDbGFzc1RvQm9keShTa3lNb2RhbEFkYXB0ZXJTZXJ2aWNlLk1PREFMX0JPRFlfRlVMTF9DTEFTUyk7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRoaXMucmVtb3ZlQ2xhc3NGcm9tQm9keShTa3lNb2RhbEFkYXB0ZXJTZXJ2aWNlLk1PREFMX0JPRFlfRlVMTF9DTEFTUyk7XG4gICAgfVxuICB9XG5cbiAgcHVibGljIHNldFBhZ2VTY3JvbGwoaXNBZGQ6IGJvb2xlYW4pOiB2b2lkIHtcbiAgICBpZiAoaXNBZGQpIHtcbiAgICAgIHRoaXMuYWRkQ2xhc3NUb0JvZHkoU2t5TW9kYWxBZGFwdGVyU2VydmljZS5NT0RBTF9CT0RZX0NMQVNTKTtcbiAgICB9IGVsc2Uge1xuICAgICAgdGhpcy5yZW1vdmVDbGFzc0Zyb21Cb2R5KFNreU1vZGFsQWRhcHRlclNlcnZpY2UuTU9EQUxfQk9EWV9DTEFTUyk7XG4gICAgfVxuICB9XG5cbiAgcHVibGljIGdldE1vZGFsT3BlbmVyKCk6IEhUTUxFbGVtZW50IHtcbiAgICByZXR1cm4gdGhpcy5kb2NSZWYuYWN0aXZlRWxlbWVudDtcbiAgfVxuXG4gIHByaXZhdGUgYWRkQ2xhc3NUb0JvZHkoY2xhc3NOYW1lOiBzdHJpbmcpOiB2b2lkIHtcbiAgICB0aGlzLmJvZHlFbC5jbGFzc0xpc3QuYWRkKGNsYXNzTmFtZSk7XG4gIH1cblxuICBwcml2YXRlIHJlbW92ZUNsYXNzRnJvbUJvZHkoY2xhc3NOYW1lOiBzdHJpbmcpOiB2b2lkIHtcbiAgICB0aGlzLmJvZHlFbC5jbGFzc0xpc3QucmVtb3ZlKGNsYXNzTmFtZSk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export class SkyModalBeforeCloseHandler {
|
|
2
|
+
constructor(closeModal, closeArgs) {
|
|
3
|
+
this.closeModal = closeModal;
|
|
4
|
+
this.closeArgs = closeArgs;
|
|
5
|
+
}
|
|
6
|
+
}
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kYWwtYmVmb3JlLWNsb3NlLWhhbmRsZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvbW9kYWxzL3NyYy9saWIvbW9kdWxlcy9tb2RhbC9tb2RhbC1iZWZvcmUtY2xvc2UtaGFuZGxlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxNQUFNLE9BQU8sMEJBQTBCO0lBQ3JDLFlBQ2tCLFVBQW9CLEVBQ3BCLFNBQTRCO1FBRDVCLGVBQVUsR0FBVixVQUFVLENBQVU7UUFDcEIsY0FBUyxHQUFULFNBQVMsQ0FBbUI7SUFDM0MsQ0FBQztDQUNMIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU2t5TW9kYWxDbG9zZUFyZ3MgfSBmcm9tICcuL21vZGFsLWNsb3NlLWFyZ3MnO1xuXG5leHBvcnQgY2xhc3MgU2t5TW9kYWxCZWZvcmVDbG9zZUhhbmRsZXIge1xuICBjb25zdHJ1Y3RvcihcbiAgICBwdWJsaWMgcmVhZG9ubHkgY2xvc2VNb2RhbDogRnVuY3Rpb24sXG4gICAgcHVibGljIHJlYWRvbmx5IGNsb3NlQXJnczogU2t5TW9kYWxDbG9zZUFyZ3NcbiAgKSB7fVxufVxuIl19
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export class SkyModalCloseArgs {
|
|
2
|
+
}
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kYWwtY2xvc2UtYXJncy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9tb2RhbHMvc3JjL2xpYi9tb2R1bGVzL21vZGFsL21vZGFsLWNsb3NlLWFyZ3MudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxPQUFPLGlCQUFpQjtDQUc3QiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjbGFzcyBTa3lNb2RhbENsb3NlQXJncyB7XG4gIHB1YmxpYyByZWFzb246IHN0cmluZztcbiAgcHVibGljIGRhdGE6IGFueTtcbn1cbiJdfQ==
|
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import { SkyCoreAdapterService } from '@skyux/core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@skyux/core";
|
|
5
|
+
/**
|
|
6
|
+
* @internal
|
|
7
|
+
*/
|
|
8
|
+
export class SkyModalComponentAdapterService {
|
|
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
|
+
modalOpened(modalEl) {
|
|
67
|
+
/* istanbul ignore else */
|
|
68
|
+
/* handle the case where somehow there is a focused element already in the modal */
|
|
69
|
+
if (!(document.activeElement &&
|
|
70
|
+
modalEl.nativeElement.contains(document.activeElement))) {
|
|
71
|
+
const currentScrollX = window.pageXOffset;
|
|
72
|
+
const currentScrollY = window.pageYOffset;
|
|
73
|
+
const inputWithAutofocus = modalEl.nativeElement.querySelector('[autofocus]');
|
|
74
|
+
if (inputWithAutofocus) {
|
|
75
|
+
inputWithAutofocus.focus();
|
|
76
|
+
}
|
|
77
|
+
else {
|
|
78
|
+
this.coreAdapter.getFocusableChildrenAndApplyFocus(modalEl, '.sky-modal-content', true);
|
|
79
|
+
}
|
|
80
|
+
window.scrollTo(currentScrollX, currentScrollY);
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
setFullPageHeight(fullPageModalEl) {
|
|
84
|
+
const windowHeight = window.innerHeight;
|
|
85
|
+
const fullPageModalStyle = getComputedStyle(fullPageModalEl);
|
|
86
|
+
const marginTopBottom = parseInt(fullPageModalStyle.marginTop, 10) +
|
|
87
|
+
parseInt(fullPageModalStyle.marginBottom, 10);
|
|
88
|
+
const fullPageModalHeight = windowHeight - marginTopBottom + 'px';
|
|
89
|
+
fullPageModalEl.style.height = fullPageModalHeight;
|
|
90
|
+
fullPageModalEl.style.maxHeight = fullPageModalHeight;
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
SkyModalComponentAdapterService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: SkyModalComponentAdapterService, deps: [{ token: i1.SkyCoreAdapterService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
94
|
+
SkyModalComponentAdapterService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: SkyModalComponentAdapterService });
|
|
95
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: SkyModalComponentAdapterService, decorators: [{
|
|
96
|
+
type: Injectable
|
|
97
|
+
}], ctorParameters: function () { return [{ type: i1.SkyCoreAdapterService }]; } });
|
|
98
|
+
//# 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  constructor(private coreAdapter: SkyCoreAdapterService) {}\n\n  public handleWindowChange(modalEl: ElementRef): void {\n    const boundedHeightEl = modalEl.nativeElement.querySelector('.sky-modal');\n    const fullPageModalEl = modalEl.nativeElement.querySelector(\n      '.sky-modal-full-page'\n    );\n    /*\n      Set modal height equal to max height of window (accounting for padding above and below modal)\n    */\n    const newHeight = window.innerHeight - 40;\n\n    boundedHeightEl.style.maxHeight = newHeight.toString() + 'px';\n    if (fullPageModalEl) {\n      this.setFullPageHeight(fullPageModalEl);\n    } else {\n      /*\n        IE11 doesn't handle flex and max-height correctly so we have to explicitly add\n        max-height to the content that accounts for standard header and footer height.\n      */\n      const modalContentEl =\n        modalEl.nativeElement.querySelector('.sky-modal-content');\n      const contentHeight = newHeight - 114;\n      modalContentEl.style.maxHeight = contentHeight.toString() + 'px';\n    }\n  }\n\n  public isFocusInFirstItem(\n    event: KeyboardEvent,\n    list: Array<HTMLElement>\n  ): boolean {\n    /* istanbul ignore next */\n    /* sanity check */\n    const eventTarget = event.target || event.srcElement;\n    return list.length > 0 && eventTarget === list[0];\n  }\n\n  public isFocusInLastItem(\n    event: KeyboardEvent,\n    list: Array<HTMLElement>\n  ): boolean {\n    /* istanbul ignore next */\n    /* sanity check */\n    const eventTarget = event.target || event.srcElement;\n    return list.length > 0 && eventTarget === list[list.length - 1];\n  }\n\n  public isModalFocused(event: KeyboardEvent, modalEl: ElementRef): boolean {\n    /* istanbul ignore next */\n    /* sanity check */\n    const eventTarget = event.target || event.srcElement;\n    return (\n      modalEl &&\n      eventTarget === modalEl.nativeElement.querySelector('.sky-modal-dialog')\n    );\n  }\n\n  public focusLastElement(list: Array<HTMLElement>): boolean {\n    if (list.length > 0) {\n      list[list.length - 1].focus();\n      return true;\n    }\n    return false;\n  }\n\n  public focusFirstElement(list: Array<HTMLElement>): boolean {\n    if (list.length > 0) {\n      list[0].focus();\n      return true;\n    }\n    return false;\n  }\n\n  public modalOpened(modalEl: ElementRef): void {\n    /* istanbul ignore else */\n    /* handle the case where somehow there is a focused element already in the modal */\n    if (\n      !(\n        document.activeElement &&\n        modalEl.nativeElement.contains(document.activeElement)\n      )\n    ) {\n      const currentScrollX = window.pageXOffset;\n      const currentScrollY = window.pageYOffset;\n\n      const inputWithAutofocus =\n        modalEl.nativeElement.querySelector('[autofocus]');\n\n      if (inputWithAutofocus) {\n        inputWithAutofocus.focus();\n      } else {\n        this.coreAdapter.getFocusableChildrenAndApplyFocus(\n          modalEl,\n          '.sky-modal-content',\n          true\n        );\n      }\n      window.scrollTo(currentScrollX, currentScrollY);\n    }\n  }\n\n  private setFullPageHeight(fullPageModalEl: HTMLElement): void {\n    const windowHeight = window.innerHeight;\n    const fullPageModalStyle = getComputedStyle(fullPageModalEl);\n\n    const marginTopBottom =\n      parseInt(fullPageModalStyle.marginTop, 10) +\n      parseInt(fullPageModalStyle.marginBottom, 10);\n\n    const fullPageModalHeight = windowHeight - marginTopBottom + 'px';\n\n    fullPageModalEl.style.height = fullPageModalHeight;\n    fullPageModalEl.style.maxHeight = fullPageModalHeight;\n  }\n}\n"]}
|