@skyux/modals 6.13.0 → 6.16.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/documentation.json +340 -529
- package/esm2020/lib/modules/confirm/confirm-config-token.mjs +6 -0
- package/esm2020/lib/modules/confirm/confirm.component.mjs +103 -97
- package/esm2020/lib/modules/confirm/confirm.service.mjs +9 -5
- package/esm2020/lib/modules/modal/modal-adapter.service.mjs +20 -15
- package/esm2020/lib/modules/modal/modal-close-args.mjs +1 -1
- package/esm2020/lib/modules/modal/modal-component-adapter.service.mjs +17 -13
- package/esm2020/lib/modules/modal/modal-host-context-args.mjs +2 -0
- package/esm2020/lib/modules/modal/modal-host-context.mjs +9 -6
- package/esm2020/lib/modules/modal/modal-host.component.mjs +41 -14
- package/esm2020/lib/modules/modal/modal-host.service.mjs +21 -15
- package/esm2020/lib/modules/modal/modal-instance.mjs +31 -29
- package/esm2020/lib/modules/modal/modal-scroll-shadow.directive.mjs +71 -65
- package/esm2020/lib/modules/modal/modal.component.mjs +59 -74
- package/esm2020/lib/modules/modal/modal.service.mjs +50 -42
- package/esm2020/testing/modal-fixture.mjs +60 -84
- package/fesm2015/skyux-modals-testing.mjs +60 -83
- package/fesm2015/skyux-modals-testing.mjs.map +1 -1
- package/fesm2015/skyux-modals.mjs +412 -368
- package/fesm2015/skyux-modals.mjs.map +1 -1
- package/fesm2020/skyux-modals-testing.mjs +60 -83
- package/fesm2020/skyux-modals-testing.mjs.map +1 -1
- package/fesm2020/skyux-modals.mjs +409 -368
- package/fesm2020/skyux-modals.mjs.map +1 -1
- package/lib/modules/confirm/confirm-config-token.d.ts +6 -0
- package/lib/modules/confirm/confirm.component.d.ts +6 -12
- package/lib/modules/confirm/confirm.service.d.ts +1 -1
- package/lib/modules/modal/modal-adapter.service.d.ts +1 -5
- package/lib/modules/modal/modal-close-args.d.ts +1 -1
- package/lib/modules/modal/modal-component-adapter.service.d.ts +1 -2
- package/lib/modules/modal/modal-host-context-args.d.ts +7 -0
- package/lib/modules/modal/modal-host-context.d.ts +3 -2
- package/lib/modules/modal/modal-host.component.d.ts +1 -6
- package/lib/modules/modal/modal-host.service.d.ts +2 -2
- package/lib/modules/modal/modal-instance.d.ts +1 -5
- package/lib/modules/modal/modal-scroll-shadow.directive.d.ts +1 -13
- package/lib/modules/modal/modal.component.d.ts +12 -23
- package/lib/modules/modal/modal.service.d.ts +1 -3
- package/package.json +5 -6
- package/testing/modal-fixture.d.ts +6 -8
- package/esm2020/lib/modules/confirm/confirm-modal-context.mjs +0 -6
- package/esm2020/lib/modules/modal/modal-state-animation.mjs +0 -8
- package/lib/modules/confirm/confirm-modal-context.d.ts +0 -13
- package/lib/modules/modal/modal-state-animation.d.ts +0 -1
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
var _SkyModalHostComponent_modalHostContext;
|
|
1
|
+
var _SkyModalHostComponent_instances, _SkyModalHostComponent_resolver, _SkyModalHostComponent_adapter, _SkyModalHostComponent_injector, _SkyModalHostComponent_router, _SkyModalHostComponent_changeDetector, _SkyModalHostComponent_modalHostContext, _SkyModalHostComponent_modalInstances, _SkyModalHostComponent_registerModalInstance, _SkyModalHostComponent_unregisterModalInstance, _SkyModalHostComponent_closeAllModalInstances;
|
|
2
2
|
import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
|
|
3
3
|
import { ChangeDetectorRef, Component, ComponentFactoryResolver, Injector, ViewChild, ViewContainerRef, } from '@angular/core';
|
|
4
4
|
import { NavigationStart, Router } from '@angular/router';
|
|
@@ -18,12 +18,19 @@ import * as i4 from "@angular/common";
|
|
|
18
18
|
*/
|
|
19
19
|
export class SkyModalHostComponent {
|
|
20
20
|
constructor(resolver, adapter, injector, router, changeDetector, modalHostContext) {
|
|
21
|
-
this
|
|
22
|
-
this
|
|
23
|
-
this
|
|
24
|
-
this
|
|
25
|
-
this
|
|
21
|
+
_SkyModalHostComponent_instances.add(this);
|
|
22
|
+
_SkyModalHostComponent_resolver.set(this, void 0);
|
|
23
|
+
_SkyModalHostComponent_adapter.set(this, void 0);
|
|
24
|
+
_SkyModalHostComponent_injector.set(this, void 0);
|
|
25
|
+
_SkyModalHostComponent_router.set(this, void 0);
|
|
26
|
+
_SkyModalHostComponent_changeDetector.set(this, void 0);
|
|
26
27
|
_SkyModalHostComponent_modalHostContext.set(this, void 0);
|
|
28
|
+
_SkyModalHostComponent_modalInstances.set(this, []);
|
|
29
|
+
__classPrivateFieldSet(this, _SkyModalHostComponent_resolver, resolver, "f");
|
|
30
|
+
__classPrivateFieldSet(this, _SkyModalHostComponent_adapter, adapter, "f");
|
|
31
|
+
__classPrivateFieldSet(this, _SkyModalHostComponent_injector, injector, "f");
|
|
32
|
+
__classPrivateFieldSet(this, _SkyModalHostComponent_router, router, "f");
|
|
33
|
+
__classPrivateFieldSet(this, _SkyModalHostComponent_changeDetector, changeDetector, "f");
|
|
27
34
|
__classPrivateFieldSet(this, _SkyModalHostComponent_modalHostContext, modalHostContext, "f");
|
|
28
35
|
}
|
|
29
36
|
get modalOpen() {
|
|
@@ -33,16 +40,25 @@ export class SkyModalHostComponent {
|
|
|
33
40
|
return SkyModalHostService.backdropZIndex;
|
|
34
41
|
}
|
|
35
42
|
ngOnDestroy() {
|
|
36
|
-
|
|
43
|
+
// Close all modal instances before disposing of the host container.
|
|
44
|
+
__classPrivateFieldGet(this, _SkyModalHostComponent_instances, "m", _SkyModalHostComponent_closeAllModalInstances).call(this);
|
|
45
|
+
__classPrivateFieldGet(this, _SkyModalHostComponent_modalHostContext, "f").args.teardownCallback();
|
|
37
46
|
}
|
|
38
47
|
open(modalInstance, component, config) {
|
|
48
|
+
/* Ignore coverage as we specify the target element and so the view child should never be undefined unless
|
|
49
|
+
* we were to call the `open` method in an early lifecycle hook. */
|
|
50
|
+
/* istanbul ignore next */
|
|
51
|
+
if (!this.target) {
|
|
52
|
+
return;
|
|
53
|
+
}
|
|
39
54
|
const params = Object.assign({}, config);
|
|
40
|
-
const factory = this.
|
|
55
|
+
const factory = __classPrivateFieldGet(this, _SkyModalHostComponent_resolver, "f").resolveComponentFactory(component);
|
|
41
56
|
const hostService = new SkyModalHostService();
|
|
42
57
|
hostService.fullPage = !!params.fullPage;
|
|
43
|
-
const adapter = this
|
|
58
|
+
const adapter = __classPrivateFieldGet(this, _SkyModalHostComponent_adapter, "f");
|
|
44
59
|
const modalOpener = adapter.getModalOpener();
|
|
45
60
|
let isOpen = true;
|
|
61
|
+
/* eslint-disable @typescript-eslint/no-non-null-assertion */
|
|
46
62
|
params.providers.push({
|
|
47
63
|
provide: SkyModalHostService,
|
|
48
64
|
useValue: hostService,
|
|
@@ -55,15 +71,17 @@ export class SkyModalHostComponent {
|
|
|
55
71
|
provide: SkyMediaQueryService,
|
|
56
72
|
useExisting: SkyResizeObserverMediaQueryService,
|
|
57
73
|
});
|
|
74
|
+
/* eslint-enable @typescript-eslint/no-non-null-assertion */
|
|
58
75
|
adapter.setPageScroll(SkyModalHostService.openModalCount > 0);
|
|
59
76
|
adapter.toggleFullPageModalClass(SkyModalHostService.fullPageModalCount > 0);
|
|
60
77
|
const providers = params.providers || /* istanbul ignore next */ [];
|
|
61
78
|
const injector = Injector.create({
|
|
62
79
|
providers,
|
|
63
|
-
parent: this
|
|
80
|
+
parent: __classPrivateFieldGet(this, _SkyModalHostComponent_injector, "f"),
|
|
64
81
|
});
|
|
65
82
|
const modalComponentRef = this.target.createComponent(factory, undefined, injector);
|
|
66
83
|
modalInstance.componentInstance = modalComponentRef.instance;
|
|
84
|
+
__classPrivateFieldGet(this, _SkyModalHostComponent_instances, "m", _SkyModalHostComponent_registerModalInstance).call(this, modalInstance);
|
|
67
85
|
function closeModal() {
|
|
68
86
|
hostService.destroy();
|
|
69
87
|
adapter.setPageScroll(SkyModalHostService.openModalCount > 0);
|
|
@@ -81,7 +99,7 @@ export class SkyModalHostComponent {
|
|
|
81
99
|
hostService.close.subscribe(() => {
|
|
82
100
|
modalInstance.close();
|
|
83
101
|
});
|
|
84
|
-
this.
|
|
102
|
+
__classPrivateFieldGet(this, _SkyModalHostComponent_router, "f").events.pipe(takeWhile(() => isOpen)).subscribe((event) => {
|
|
85
103
|
/* istanbul ignore else */
|
|
86
104
|
if (event instanceof NavigationStart) {
|
|
87
105
|
modalInstance.close();
|
|
@@ -89,13 +107,22 @@ export class SkyModalHostComponent {
|
|
|
89
107
|
});
|
|
90
108
|
modalInstance.closed.subscribe(() => {
|
|
91
109
|
isOpen = false;
|
|
110
|
+
__classPrivateFieldGet(this, _SkyModalHostComponent_instances, "m", _SkyModalHostComponent_unregisterModalInstance).call(this, modalInstance);
|
|
92
111
|
closeModal();
|
|
93
112
|
});
|
|
94
113
|
// Necessary if the host was created via a consumer's lifecycle hook such as ngOnInit
|
|
95
|
-
this.
|
|
114
|
+
__classPrivateFieldGet(this, _SkyModalHostComponent_changeDetector, "f").detectChanges();
|
|
96
115
|
}
|
|
97
116
|
}
|
|
98
|
-
_SkyModalHostComponent_modalHostContext = new WeakMap()
|
|
117
|
+
_SkyModalHostComponent_resolver = new WeakMap(), _SkyModalHostComponent_adapter = new WeakMap(), _SkyModalHostComponent_injector = new WeakMap(), _SkyModalHostComponent_router = new WeakMap(), _SkyModalHostComponent_changeDetector = new WeakMap(), _SkyModalHostComponent_modalHostContext = new WeakMap(), _SkyModalHostComponent_modalInstances = new WeakMap(), _SkyModalHostComponent_instances = new WeakSet(), _SkyModalHostComponent_registerModalInstance = function _SkyModalHostComponent_registerModalInstance(instance) {
|
|
118
|
+
__classPrivateFieldGet(this, _SkyModalHostComponent_modalInstances, "f").push(instance);
|
|
119
|
+
}, _SkyModalHostComponent_unregisterModalInstance = function _SkyModalHostComponent_unregisterModalInstance(instance) {
|
|
120
|
+
__classPrivateFieldGet(this, _SkyModalHostComponent_modalInstances, "f").slice(__classPrivateFieldGet(this, _SkyModalHostComponent_modalInstances, "f").indexOf(instance), 1);
|
|
121
|
+
}, _SkyModalHostComponent_closeAllModalInstances = function _SkyModalHostComponent_closeAllModalInstances() {
|
|
122
|
+
for (const instance of __classPrivateFieldGet(this, _SkyModalHostComponent_modalInstances, "f")) {
|
|
123
|
+
instance.close();
|
|
124
|
+
}
|
|
125
|
+
};
|
|
99
126
|
SkyModalHostComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyModalHostComponent, deps: [{ token: i0.ComponentFactoryResolver }, { token: i1.SkyModalAdapterService }, { token: i0.Injector }, { token: i2.Router }, { token: i0.ChangeDetectorRef }, { token: i3.SkyModalHostContext }], target: i0.ɵɵFactoryTarget.Component });
|
|
100
127
|
SkyModalHostComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.2", type: SkyModalHostComponent, selector: "sky-modal-host", viewQueries: [{ propertyName: "target", first: true, predicate: ["target"], descendants: true, read: ViewContainerRef, static: true }], ngImport: i0, template: "<div\n class=\"sky-modal-host-backdrop\"\n [hidden]=\"!modalOpen\"\n [ngStyle]=\"{\n zIndex: backdropZIndex\n }\"\n></div>\n<div #target></div>\n", styles: [".sky-modal-host-backdrop{background-color:#00000080;position:fixed;top:0;left:0;bottom:0;right:0}\n"], directives: [{ type: i4.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }], viewProviders: [SkyModalAdapterService] });
|
|
101
128
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyModalHostComponent, decorators: [{
|
|
@@ -108,4 +135,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
|
|
|
108
135
|
static: true,
|
|
109
136
|
}]
|
|
110
137
|
}] } });
|
|
111
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal-host.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/modals/src/lib/modules/modal/modal-host.component.ts","../../../../../../../../libs/components/modals/src/lib/modules/modal/modal-host.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectorRef,\n  Component,\n  ComponentFactoryResolver,\n  Injector,\n  OnDestroy,\n  ViewChild,\n  ViewContainerRef,\n} from '@angular/core';\nimport { NavigationStart, Router } from '@angular/router';\nimport {\n  SkyMediaQueryService,\n  SkyResizeObserverMediaQueryService,\n} from '@skyux/core';\n\nimport { takeWhile } from 'rxjs/operators';\n\nimport { SkyModalAdapterService } from './modal-adapter.service';\nimport { SkyModalConfiguration } from './modal-configuration';\nimport { SkyModalHostContext } from './modal-host-context';\nimport { SkyModalHostService } from './modal-host.service';\nimport { SkyModalInstance } from './modal-instance';\nimport { SkyModalConfigurationInterface } from './modal.interface';\n\n/**\n * @internal\n */\n@Component({\n  selector: 'sky-modal-host',\n  templateUrl: './modal-host.component.html',\n  styleUrls: ['./modal-host.component.scss'],\n  viewProviders: [SkyModalAdapterService],\n})\nexport class SkyModalHostComponent implements OnDestroy {\n  public get modalOpen() {\n    return SkyModalHostService.openModalCount > 0;\n  }\n\n  public get backdropZIndex() {\n    return SkyModalHostService.backdropZIndex;\n  }\n\n  /**\n   * Use `any` for backwards-compatibility with Angular 4-7.\n   * See: https://github.com/angular/angular/issues/30654\n   * TODO: Remove the `any` in a breaking change.\n   * @internal\n   */\n  @ViewChild('target', {\n    read: ViewContainerRef,\n    static: true,\n  } as any)\n  public target: ViewContainerRef;\n\n  #modalHostContext: SkyModalHostContext;\n\n  constructor(\n    private resolver: ComponentFactoryResolver,\n    private adapter: SkyModalAdapterService,\n    private injector: Injector,\n    private router: Router,\n    private changeDetector: ChangeDetectorRef,\n    modalHostContext: SkyModalHostContext\n  ) {\n    this.#modalHostContext = modalHostContext;\n  }\n\n  public ngOnDestroy(): void {\n    this.#modalHostContext.teardownCallback();\n  }\n\n  public open(\n    modalInstance: SkyModalInstance,\n    component: any,\n    config?: SkyModalConfigurationInterface\n  ) {\n    const params: SkyModalConfigurationInterface = Object.assign({}, config);\n    const factory = this.resolver.resolveComponentFactory(component);\n\n    const hostService = new SkyModalHostService();\n    hostService.fullPage = !!params.fullPage;\n\n    const adapter = this.adapter;\n    const modalOpener: HTMLElement = adapter.getModalOpener();\n\n    let isOpen = true;\n\n    params.providers.push({\n      provide: SkyModalHostService,\n      useValue: hostService,\n    });\n    params.providers.push({\n      provide: SkyModalConfiguration,\n      useValue: params,\n    });\n    params.providers.push({\n      provide: SkyMediaQueryService,\n      useExisting: SkyResizeObserverMediaQueryService,\n    });\n\n    adapter.setPageScroll(SkyModalHostService.openModalCount > 0);\n    adapter.toggleFullPageModalClass(\n      SkyModalHostService.fullPageModalCount > 0\n    );\n\n    const providers = params.providers || /* istanbul ignore next */ [];\n    const injector = Injector.create({\n      providers,\n      parent: this.injector,\n    });\n\n    const modalComponentRef = this.target.createComponent(\n      factory,\n      undefined,\n      injector\n    );\n\n    modalInstance.componentInstance = modalComponentRef.instance;\n\n    function closeModal() {\n      hostService.destroy();\n      adapter.setPageScroll(SkyModalHostService.openModalCount > 0);\n      adapter.toggleFullPageModalClass(\n        SkyModalHostService.fullPageModalCount > 0\n      );\n      /* istanbul ignore else */\n      /* sanity check */\n      if (modalOpener && modalOpener.focus) {\n        modalOpener.focus();\n      }\n      modalComponentRef.destroy();\n    }\n\n    hostService.openHelp.subscribe((helpKey?: string) => {\n      modalInstance.openHelp(helpKey);\n    });\n\n    hostService.close.subscribe(() => {\n      modalInstance.close();\n    });\n\n    this.router.events.pipe(takeWhile(() => isOpen)).subscribe((event) => {\n      /* istanbul ignore else */\n      if (event instanceof NavigationStart) {\n        modalInstance.close();\n      }\n    });\n\n    modalInstance.closed.subscribe(() => {\n      isOpen = false;\n      closeModal();\n    });\n\n    // Necessary if the host was created via a consumer's lifecycle hook such as ngOnInit\n    this.changeDetector.detectChanges();\n  }\n}\n","<div\n  class=\"sky-modal-host-backdrop\"\n  [hidden]=\"!modalOpen\"\n  [ngStyle]=\"{\n    zIndex: backdropZIndex\n  }\"\n></div>\n<div #target></div>\n"]}
|
|
138
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal-host.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/modals/src/lib/modules/modal/modal-host.component.ts","../../../../../../../../libs/components/modals/src/lib/modules/modal/modal-host.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectorRef,\n  Component,\n  ComponentFactoryResolver,\n  Injector,\n  OnDestroy,\n  ViewChild,\n  ViewContainerRef,\n} from '@angular/core';\nimport { NavigationStart, Router } from '@angular/router';\nimport {\n  SkyMediaQueryService,\n  SkyResizeObserverMediaQueryService,\n} from '@skyux/core';\n\nimport { takeWhile } from 'rxjs/operators';\n\nimport { SkyModalAdapterService } from './modal-adapter.service';\nimport { SkyModalConfiguration } from './modal-configuration';\nimport { SkyModalHostContext } from './modal-host-context';\nimport { SkyModalHostService } from './modal-host.service';\nimport { SkyModalInstance } from './modal-instance';\nimport { SkyModalConfigurationInterface } from './modal.interface';\n\n/**\n * @internal\n */\n@Component({\n  selector: 'sky-modal-host',\n  templateUrl: './modal-host.component.html',\n  styleUrls: ['./modal-host.component.scss'],\n  viewProviders: [SkyModalAdapterService],\n})\nexport class SkyModalHostComponent implements OnDestroy {\n  public get modalOpen() {\n    return SkyModalHostService.openModalCount > 0;\n  }\n\n  public get backdropZIndex() {\n    return SkyModalHostService.backdropZIndex;\n  }\n\n  /**\n   * Use `any` for backwards-compatibility with Angular 4-7.\n   * See: https://github.com/angular/angular/issues/30654\n   * TODO: Remove the `any` in a breaking change.\n   * @internal\n   */\n  @ViewChild('target', {\n    read: ViewContainerRef,\n    static: true,\n  } as any)\n  public target: ViewContainerRef | undefined;\n\n  #resolver: ComponentFactoryResolver;\n  #adapter: SkyModalAdapterService;\n  #injector: Injector;\n  #router: Router;\n  #changeDetector: ChangeDetectorRef;\n\n  #modalHostContext: SkyModalHostContext;\n\n  #modalInstances: SkyModalInstance[] = [];\n\n  constructor(\n    resolver: ComponentFactoryResolver,\n    adapter: SkyModalAdapterService,\n    injector: Injector,\n    router: Router,\n    changeDetector: ChangeDetectorRef,\n    modalHostContext: SkyModalHostContext\n  ) {\n    this.#resolver = resolver;\n    this.#adapter = adapter;\n    this.#injector = injector;\n    this.#router = router;\n    this.#changeDetector = changeDetector;\n    this.#modalHostContext = modalHostContext;\n  }\n\n  public ngOnDestroy(): void {\n    // Close all modal instances before disposing of the host container.\n    this.#closeAllModalInstances();\n    this.#modalHostContext.args.teardownCallback();\n  }\n\n  public open(\n    modalInstance: SkyModalInstance,\n    component: any,\n    config?: SkyModalConfigurationInterface\n  ): void {\n    /* Ignore coverage as we specify the target element and so the view child should never be undefined unless\n     * we were to call the `open` method in an early lifecycle hook. */\n    /* istanbul ignore next */\n    if (!this.target) {\n      return;\n    }\n\n    const params: SkyModalConfigurationInterface = Object.assign({}, config);\n    const factory = this.#resolver.resolveComponentFactory(component);\n\n    const hostService = new SkyModalHostService();\n    hostService.fullPage = !!params.fullPage;\n\n    const adapter = this.#adapter;\n    const modalOpener: HTMLElement = adapter.getModalOpener();\n\n    let isOpen = true;\n\n    /* eslint-disable @typescript-eslint/no-non-null-assertion */\n    params.providers!.push({\n      provide: SkyModalHostService,\n      useValue: hostService,\n    });\n    params.providers!.push({\n      provide: SkyModalConfiguration,\n      useValue: params,\n    });\n    params.providers!.push({\n      provide: SkyMediaQueryService,\n      useExisting: SkyResizeObserverMediaQueryService,\n    });\n    /* eslint-enable @typescript-eslint/no-non-null-assertion */\n\n    adapter.setPageScroll(SkyModalHostService.openModalCount > 0);\n    adapter.toggleFullPageModalClass(\n      SkyModalHostService.fullPageModalCount > 0\n    );\n\n    const providers = params.providers || /* istanbul ignore next */ [];\n    const injector = Injector.create({\n      providers,\n      parent: this.#injector,\n    });\n\n    const modalComponentRef = this.target.createComponent(\n      factory,\n      undefined,\n      injector\n    );\n\n    modalInstance.componentInstance = modalComponentRef.instance;\n\n    this.#registerModalInstance(modalInstance);\n\n    function closeModal() {\n      hostService.destroy();\n      adapter.setPageScroll(SkyModalHostService.openModalCount > 0);\n      adapter.toggleFullPageModalClass(\n        SkyModalHostService.fullPageModalCount > 0\n      );\n      /* istanbul ignore else */\n      /* sanity check */\n      if (modalOpener && modalOpener.focus) {\n        modalOpener.focus();\n      }\n      modalComponentRef.destroy();\n    }\n\n    hostService.openHelp.subscribe((helpKey?: string) => {\n      modalInstance.openHelp(helpKey);\n    });\n\n    hostService.close.subscribe(() => {\n      modalInstance.close();\n    });\n\n    this.#router.events.pipe(takeWhile(() => isOpen)).subscribe((event) => {\n      /* istanbul ignore else */\n      if (event instanceof NavigationStart) {\n        modalInstance.close();\n      }\n    });\n\n    modalInstance.closed.subscribe(() => {\n      isOpen = false;\n      this.#unregisterModalInstance(modalInstance);\n      closeModal();\n    });\n\n    // Necessary if the host was created via a consumer's lifecycle hook such as ngOnInit\n    this.#changeDetector.detectChanges();\n  }\n\n  #registerModalInstance(instance: SkyModalInstance): void {\n    this.#modalInstances.push(instance);\n  }\n\n  #unregisterModalInstance(instance: SkyModalInstance): void {\n    this.#modalInstances.slice(this.#modalInstances.indexOf(instance), 1);\n  }\n\n  #closeAllModalInstances(): void {\n    for (const instance of this.#modalInstances) {\n      instance.close();\n    }\n  }\n}\n","<div\n  class=\"sky-modal-host-backdrop\"\n  [hidden]=\"!modalOpen\"\n  [ngStyle]=\"{\n    zIndex: backdropZIndex\n  }\"\n></div>\n<div #target></div>\n"]}
|
|
@@ -1,5 +1,7 @@
|
|
|
1
1
|
import { EventEmitter, Injectable } from '@angular/core';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
|
+
const BASE_Z_INDEX = 1040;
|
|
4
|
+
const modalHosts = [];
|
|
3
5
|
/**
|
|
4
6
|
* @internal
|
|
5
7
|
* @dynamic
|
|
@@ -9,29 +11,24 @@ export class SkyModalHostService {
|
|
|
9
11
|
this.close = new EventEmitter();
|
|
10
12
|
this.fullPage = false;
|
|
11
13
|
this.openHelp = new EventEmitter();
|
|
12
|
-
|
|
14
|
+
this.zIndex = this.calculateZIndex();
|
|
15
|
+
modalHosts.push(this);
|
|
13
16
|
}
|
|
14
17
|
static get openModalCount() {
|
|
15
|
-
return
|
|
18
|
+
return modalHosts.length;
|
|
16
19
|
}
|
|
17
20
|
static get fullPageModalCount() {
|
|
18
|
-
const fullPageModals =
|
|
21
|
+
const fullPageModals = modalHosts.filter((modal) => modal.fullPage);
|
|
19
22
|
return fullPageModals.length;
|
|
20
23
|
}
|
|
21
|
-
static get BASE_Z_INDEX() {
|
|
22
|
-
return 1040;
|
|
23
|
-
}
|
|
24
24
|
static get backdropZIndex() {
|
|
25
|
-
return
|
|
26
|
-
SkyModalHostService.modalHosts.length * 10);
|
|
25
|
+
return BASE_Z_INDEX + modalHosts.length * 10;
|
|
27
26
|
}
|
|
28
27
|
static get topModal() {
|
|
29
|
-
return
|
|
28
|
+
return modalHosts[modalHosts.length - 1];
|
|
30
29
|
}
|
|
31
30
|
getModalZIndex() {
|
|
32
|
-
|
|
33
|
-
zIndex += (SkyModalHostService.modalHosts.indexOf(this) + 1) * 10;
|
|
34
|
-
return zIndex;
|
|
31
|
+
return this.zIndex;
|
|
35
32
|
}
|
|
36
33
|
onClose() {
|
|
37
34
|
this.close.emit();
|
|
@@ -40,10 +37,19 @@ export class SkyModalHostService {
|
|
|
40
37
|
this.openHelp.emit(helpKey);
|
|
41
38
|
}
|
|
42
39
|
destroy() {
|
|
43
|
-
|
|
40
|
+
modalHosts.splice(modalHosts.indexOf(this), 1);
|
|
41
|
+
}
|
|
42
|
+
calculateZIndex() {
|
|
43
|
+
const zIndexArray = modalHosts.map((hostService) => hostService.zIndex);
|
|
44
|
+
if (zIndexArray.length === 0) {
|
|
45
|
+
return BASE_Z_INDEX + 11;
|
|
46
|
+
}
|
|
47
|
+
else {
|
|
48
|
+
const currentMaxZIndex = Math.max(...zIndexArray);
|
|
49
|
+
return currentMaxZIndex + 10;
|
|
50
|
+
}
|
|
44
51
|
}
|
|
45
52
|
}
|
|
46
|
-
SkyModalHostService.modalHosts = [];
|
|
47
53
|
SkyModalHostService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyModalHostService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
48
54
|
SkyModalHostService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyModalHostService, providedIn: 'root' });
|
|
49
55
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyModalHostService, decorators: [{
|
|
@@ -52,4 +58,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
|
|
|
52
58
|
providedIn: 'root',
|
|
53
59
|
}]
|
|
54
60
|
}], ctorParameters: function () { return []; } });
|
|
55
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
61
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kYWwtaG9zdC5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL21vZGFscy9zcmMvbGliL21vZHVsZXMvbW9kYWwvbW9kYWwtaG9zdC5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUV6RCxNQUFNLFlBQVksR0FBRyxJQUFJLENBQUM7QUFDMUIsTUFBTSxVQUFVLEdBQTBCLEVBQUUsQ0FBQztBQUU3Qzs7O0dBR0c7QUFJSCxNQUFNLE9BQU8sbUJBQW1CO0lBdUI5QjtRQUxPLFVBQUssR0FBRyxJQUFJLFlBQVksRUFBUSxDQUFDO1FBQ2pDLGFBQVEsR0FBRyxLQUFLLENBQUM7UUFDakIsYUFBUSxHQUFHLElBQUksWUFBWSxFQUFPLENBQUM7UUFJeEMsSUFBSSxDQUFDLE1BQU0sR0FBRyxJQUFJLENBQUMsZUFBZSxFQUFFLENBQUM7UUFDckMsVUFBVSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUN4QixDQUFDO0lBekJNLE1BQU0sS0FBSyxjQUFjO1FBQzlCLE9BQU8sVUFBVSxDQUFDLE1BQU0sQ0FBQztJQUMzQixDQUFDO0lBRU0sTUFBTSxLQUFLLGtCQUFrQjtRQUNsQyxNQUFNLGNBQWMsR0FBRyxVQUFVLENBQUMsTUFBTSxDQUFDLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLENBQUM7UUFDcEUsT0FBTyxjQUFjLENBQUMsTUFBTSxDQUFDO0lBQy9CLENBQUM7SUFFTSxNQUFNLEtBQUssY0FBYztRQUM5QixPQUFPLFlBQVksR0FBRyxVQUFVLENBQUMsTUFBTSxHQUFHLEVBQUUsQ0FBQztJQUMvQyxDQUFDO0lBRU0sTUFBTSxLQUFLLFFBQVE7UUFDeEIsT0FBTyxVQUFVLENBQUMsVUFBVSxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUMsQ0FBQztJQUMzQyxDQUFDO0lBWU0sY0FBYztRQUNuQixPQUFPLElBQUksQ0FBQyxNQUFNLENBQUM7SUFDckIsQ0FBQztJQUVNLE9BQU87UUFDWixJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksRUFBRSxDQUFDO0lBQ3BCLENBQUM7SUFFTSxVQUFVLENBQUMsT0FBZ0I7UUFDaEMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDOUIsQ0FBQztJQUVNLE9BQU87UUFDWixVQUFVLENBQUMsTUFBTSxDQUFDLFVBQVUsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7SUFDakQsQ0FBQztJQUVPLGVBQWU7UUFDckIsTUFBTSxXQUFXLEdBQUcsVUFBVSxDQUFDLEdBQUcsQ0FBQyxDQUFDLFdBQVcsRUFBRSxFQUFFLENBQUMsV0FBVyxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQ3hFLElBQUksV0FBVyxDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQUU7WUFDNUIsT0FBTyxZQUFZLEdBQUcsRUFBRSxDQUFDO1NBQzFCO2FBQU07WUFDTCxNQUFNLGdCQUFnQixHQUFHLElBQUksQ0FBQyxHQUFHLENBQUMsR0FBRyxXQUFXLENBQUMsQ0FBQztZQUNsRCxPQUFPLGdCQUFnQixHQUFHLEVBQUUsQ0FBQztTQUM5QjtJQUNILENBQUM7O2dIQXBEVSxtQkFBbUI7b0hBQW5CLG1CQUFtQixjQUZsQixNQUFNOzJGQUVQLG1CQUFtQjtrQkFIL0IsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBFdmVudEVtaXR0ZXIsIEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuY29uc3QgQkFTRV9aX0lOREVYID0gMTA0MDtcbmNvbnN0IG1vZGFsSG9zdHM6IFNreU1vZGFsSG9zdFNlcnZpY2VbXSA9IFtdO1xuXG4vKipcbiAqIEBpbnRlcm5hbFxuICogQGR5bmFtaWNcbiAqL1xuQEluamVjdGFibGUoe1xuICBwcm92aWRlZEluOiAncm9vdCcsXG59KVxuZXhwb3J0IGNsYXNzIFNreU1vZGFsSG9zdFNlcnZpY2Uge1xuICBwdWJsaWMgc3RhdGljIGdldCBvcGVuTW9kYWxDb3VudCgpOiBudW1iZXIge1xuICAgIHJldHVybiBtb2RhbEhvc3RzLmxlbmd0aDtcbiAgfVxuXG4gIHB1YmxpYyBzdGF0aWMgZ2V0IGZ1bGxQYWdlTW9kYWxDb3VudCgpOiBudW1iZXIge1xuICAgIGNvbnN0IGZ1bGxQYWdlTW9kYWxzID0gbW9kYWxIb3N0cy5maWx0ZXIoKG1vZGFsKSA9PiBtb2RhbC5mdWxsUGFnZSk7XG4gICAgcmV0dXJuIGZ1bGxQYWdlTW9kYWxzLmxlbmd0aDtcbiAgfVxuXG4gIHB1YmxpYyBzdGF0aWMgZ2V0IGJhY2tkcm9wWkluZGV4KCk6IG51bWJlciB7XG4gICAgcmV0dXJuIEJBU0VfWl9JTkRFWCArIG1vZGFsSG9zdHMubGVuZ3RoICogMTA7XG4gIH1cblxuICBwdWJsaWMgc3RhdGljIGdldCB0b3BNb2RhbCgpOiBTa3lNb2RhbEhvc3RTZXJ2aWNlIHtcbiAgICByZXR1cm4gbW9kYWxIb3N0c1ttb2RhbEhvc3RzLmxlbmd0aCAtIDFdO1xuICB9XG5cbiAgcHVibGljIGNsb3NlID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xuICBwdWJsaWMgZnVsbFBhZ2UgPSBmYWxzZTtcbiAgcHVibGljIG9wZW5IZWxwID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XG4gIHB1YmxpYyB6SW5kZXg6IG51bWJlcjtcblxuICBjb25zdHJ1Y3RvcigpIHtcbiAgICB0aGlzLnpJbmRleCA9IHRoaXMuY2FsY3VsYXRlWkluZGV4KCk7XG4gICAgbW9kYWxIb3N0cy5wdXNoKHRoaXMpO1xuICB9XG5cbiAgcHVibGljIGdldE1vZGFsWkluZGV4KCk6IG51bWJlciB7XG4gICAgcmV0dXJuIHRoaXMuekluZGV4O1xuICB9XG5cbiAgcHVibGljIG9uQ2xvc2UoKTogdm9pZCB7XG4gICAgdGhpcy5jbG9zZS5lbWl0KCk7XG4gIH1cblxuICBwdWJsaWMgb25PcGVuSGVscChoZWxwS2V5Pzogc3RyaW5nKSB7XG4gICAgdGhpcy5vcGVuSGVscC5lbWl0KGhlbHBLZXkpO1xuICB9XG5cbiAgcHVibGljIGRlc3Ryb3koKTogdm9pZCB7XG4gICAgbW9kYWxIb3N0cy5zcGxpY2UobW9kYWxIb3N0cy5pbmRleE9mKHRoaXMpLCAxKTtcbiAgfVxuXG4gIHByaXZhdGUgY2FsY3VsYXRlWkluZGV4KCk6IG51bWJlciB7XG4gICAgY29uc3QgekluZGV4QXJyYXkgPSBtb2RhbEhvc3RzLm1hcCgoaG9zdFNlcnZpY2UpID0+IGhvc3RTZXJ2aWNlLnpJbmRleCk7XG4gICAgaWYgKHpJbmRleEFycmF5Lmxlbmd0aCA9PT0gMCkge1xuICAgICAgcmV0dXJuIEJBU0VfWl9JTkRFWCArIDExO1xuICAgIH0gZWxzZSB7XG4gICAgICBjb25zdCBjdXJyZW50TWF4WkluZGV4ID0gTWF0aC5tYXgoLi4uekluZGV4QXJyYXkpO1xuICAgICAgcmV0dXJuIGN1cnJlbnRNYXhaSW5kZXggKyAxMDtcbiAgICB9XG4gIH1cbn1cbiJdfQ==
|
|
@@ -1,11 +1,14 @@
|
|
|
1
|
+
var _SkyModalInstance_instances, _SkyModalInstance__beforeClose, _SkyModalInstance__closed, _SkyModalInstance__helpOpened, _SkyModalInstance_closeModal, _SkyModalInstance_notifyClosed;
|
|
2
|
+
import { __classPrivateFieldGet } from "tslib";
|
|
1
3
|
import { Subject } from 'rxjs';
|
|
2
4
|
import { SkyModalBeforeCloseHandler } from './modal-before-close-handler';
|
|
3
5
|
import { SkyModalCloseArgs } from './modal-close-args';
|
|
4
6
|
export class SkyModalInstance {
|
|
5
7
|
constructor() {
|
|
6
|
-
|
|
7
|
-
this
|
|
8
|
-
this
|
|
8
|
+
_SkyModalInstance_instances.add(this);
|
|
9
|
+
_SkyModalInstance__beforeClose.set(this, new Subject());
|
|
10
|
+
_SkyModalInstance__closed.set(this, new Subject());
|
|
11
|
+
_SkyModalInstance__helpOpened.set(this, new Subject());
|
|
9
12
|
}
|
|
10
13
|
/**
|
|
11
14
|
* An event that the modal instance emits when it is about to close.
|
|
@@ -14,7 +17,7 @@ export class SkyModalInstance {
|
|
|
14
17
|
* the modal does not close until the subscriber calls the `closeModal` method.
|
|
15
18
|
*/
|
|
16
19
|
get beforeClose() {
|
|
17
|
-
return this
|
|
20
|
+
return __classPrivateFieldGet(this, _SkyModalInstance__beforeClose, "f");
|
|
18
21
|
}
|
|
19
22
|
/**
|
|
20
23
|
* An event that the modal instance emits when it closes.
|
|
@@ -25,7 +28,7 @@ export class SkyModalInstance {
|
|
|
25
28
|
* Common examples include `"cancel"`, `"close"`, and `"save"`.
|
|
26
29
|
*/
|
|
27
30
|
get closed() {
|
|
28
|
-
return this
|
|
31
|
+
return __classPrivateFieldGet(this, _SkyModalInstance__closed, "f");
|
|
29
32
|
}
|
|
30
33
|
/**
|
|
31
34
|
* An event that the modal instance emits when users click
|
|
@@ -33,7 +36,7 @@ export class SkyModalInstance {
|
|
|
33
36
|
* If a `helpKey` parameter was specified, the `helpOpened` event broadcasts the `helpKey`.
|
|
34
37
|
*/
|
|
35
38
|
get helpOpened() {
|
|
36
|
-
return this
|
|
39
|
+
return __classPrivateFieldGet(this, _SkyModalInstance__helpOpened, "f");
|
|
37
40
|
}
|
|
38
41
|
/**
|
|
39
42
|
* Closes the modal instance.
|
|
@@ -47,7 +50,7 @@ export class SkyModalInstance {
|
|
|
47
50
|
if (reason === undefined) {
|
|
48
51
|
reason = 'close';
|
|
49
52
|
}
|
|
50
|
-
this.
|
|
53
|
+
__classPrivateFieldGet(this, _SkyModalInstance_instances, "m", _SkyModalInstance_closeModal).call(this, reason, result, ignoreBeforeClose);
|
|
51
54
|
}
|
|
52
55
|
/**
|
|
53
56
|
* Closes the modal instance with `reason="cancel"`.
|
|
@@ -56,7 +59,7 @@ export class SkyModalInstance {
|
|
|
56
59
|
* that this cancel function can be called from a button in the `sky-modal-footer`.
|
|
57
60
|
*/
|
|
58
61
|
cancel(result) {
|
|
59
|
-
this.
|
|
62
|
+
__classPrivateFieldGet(this, _SkyModalInstance_instances, "m", _SkyModalInstance_closeModal).call(this, 'cancel', result);
|
|
60
63
|
}
|
|
61
64
|
/**
|
|
62
65
|
* Closes the modal instance with `reason="save"`.
|
|
@@ -65,7 +68,7 @@ export class SkyModalInstance {
|
|
|
65
68
|
* that this `save` function can be called from a button in `the sky-modal-footer`.
|
|
66
69
|
*/
|
|
67
70
|
save(result) {
|
|
68
|
-
this.
|
|
71
|
+
__classPrivateFieldGet(this, _SkyModalInstance_instances, "m", _SkyModalInstance_closeModal).call(this, 'save', result);
|
|
69
72
|
}
|
|
70
73
|
/**
|
|
71
74
|
* Triggers the `helpOpened` event that broadcasts a `helpKey` parameter to open
|
|
@@ -75,26 +78,25 @@ export class SkyModalInstance {
|
|
|
75
78
|
* into a component's constructor to call the `openHelp` function in the modal template.
|
|
76
79
|
*/
|
|
77
80
|
openHelp(helpKey) {
|
|
78
|
-
this.
|
|
81
|
+
__classPrivateFieldGet(this, _SkyModalInstance__helpOpened, "f").next(helpKey);
|
|
79
82
|
}
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
else {
|
|
88
|
-
this._beforeClose.next(new SkyModalBeforeCloseHandler(() => {
|
|
89
|
-
this.notifyClosed(args);
|
|
90
|
-
}, args));
|
|
91
|
-
}
|
|
83
|
+
}
|
|
84
|
+
_SkyModalInstance__beforeClose = new WeakMap(), _SkyModalInstance__closed = new WeakMap(), _SkyModalInstance__helpOpened = new WeakMap(), _SkyModalInstance_instances = new WeakSet(), _SkyModalInstance_closeModal = function _SkyModalInstance_closeModal(type, result, ignoreBeforeClose = false) {
|
|
85
|
+
const args = new SkyModalCloseArgs();
|
|
86
|
+
args.reason = type;
|
|
87
|
+
args.data = result;
|
|
88
|
+
if (__classPrivateFieldGet(this, _SkyModalInstance__beforeClose, "f").observers.length === 0 || ignoreBeforeClose) {
|
|
89
|
+
__classPrivateFieldGet(this, _SkyModalInstance_instances, "m", _SkyModalInstance_notifyClosed).call(this, args);
|
|
92
90
|
}
|
|
93
|
-
|
|
94
|
-
this.
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
this._helpOpened.complete();
|
|
91
|
+
else {
|
|
92
|
+
__classPrivateFieldGet(this, _SkyModalInstance__beforeClose, "f").next(new SkyModalBeforeCloseHandler(() => {
|
|
93
|
+
__classPrivateFieldGet(this, _SkyModalInstance_instances, "m", _SkyModalInstance_notifyClosed).call(this, args);
|
|
94
|
+
}, args));
|
|
98
95
|
}
|
|
99
|
-
}
|
|
100
|
-
|
|
96
|
+
}, _SkyModalInstance_notifyClosed = function _SkyModalInstance_notifyClosed(args) {
|
|
97
|
+
__classPrivateFieldGet(this, _SkyModalInstance__closed, "f").next(args);
|
|
98
|
+
__classPrivateFieldGet(this, _SkyModalInstance__closed, "f").complete();
|
|
99
|
+
__classPrivateFieldGet(this, _SkyModalInstance__beforeClose, "f").complete();
|
|
100
|
+
__classPrivateFieldGet(this, _SkyModalInstance__helpOpened, "f").complete();
|
|
101
|
+
};
|
|
102
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal-instance.js","sourceRoot":"","sources":["../../../../../../../../libs/components/modals/src/lib/modules/modal/modal-instance.ts"],"names":[],"mappings":";;AAAA,OAAO,EAAc,OAAO,EAAE,MAAM,MAAM,CAAC;AAE3C,OAAO,EAAE,0BAA0B,EAAE,MAAM,8BAA8B,CAAC;AAC1E,OAAO,EAAE,iBAAiB,EAAE,MAAM,oBAAoB,CAAC;AAEvD,MAAM,OAAO,gBAAgB;IAA7B;;QAqCE,yCAAgB,IAAI,OAAO,EAA8B,EAAC;QAE1D,oCAAW,IAAI,OAAO,EAAqB,EAAC;QAE5C,wCAAe,IAAI,OAAO,EAAU,EAAC;IA4EvC,CAAC;IApHC;;;;;OAKG;IACH,IAAW,WAAW;QACpB,OAAO,uBAAA,IAAI,sCAAc,CAAC;IAC5B,CAAC;IAED;;;;;;;OAOG;IACH,IAAW,MAAM;QACf,OAAO,uBAAA,IAAI,iCAAS,CAAC;IACvB,CAAC;IAED;;;;OAIG;IACH,IAAW,UAAU;QACnB,OAAO,uBAAA,IAAI,qCAAa,CAAC;IAC3B,CAAC;IAaD;;;;;;;OAOG;IACI,KAAK,CACV,MAAY,EACZ,MAAe,EACf,iBAA2B;QAE3B,IAAI,MAAM,KAAK,SAAS,EAAE;YACxB,MAAM,GAAG,OAAO,CAAC;SAClB;QAED,uBAAA,IAAI,iEAAY,MAAhB,IAAI,EAAa,MAAM,EAAE,MAAM,EAAE,iBAAiB,CAAC,CAAC;IACtD,CAAC;IAED;;;;;OAKG;IACI,MAAM,CAAC,MAAY;QACxB,uBAAA,IAAI,iEAAY,MAAhB,IAAI,EAAa,QAAQ,EAAE,MAAM,CAAC,CAAC;IACrC,CAAC;IAED;;;;;OAKG;IACI,IAAI,CAAC,MAAY;QACtB,uBAAA,IAAI,iEAAY,MAAhB,IAAI,EAAa,MAAM,EAAE,MAAM,CAAC,CAAC;IACnC,CAAC;IAED;;;;;;OAMG;IACI,QAAQ,CAAC,OAAgB;QAC9B,uBAAA,IAAI,qCAAa,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IAClC,CAAC;CAyBF;4PAvBa,IAAY,EAAE,MAAY,EAAE,iBAAiB,GAAG,KAAK;IAC/D,MAAM,IAAI,GAAG,IAAI,iBAAiB,EAAE,CAAC;IAErC,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;IACnB,IAAI,CAAC,IAAI,GAAG,MAAM,CAAC;IAEnB,IAAI,uBAAA,IAAI,sCAAc,CAAC,SAAS,CAAC,MAAM,KAAK,CAAC,IAAI,iBAAiB,EAAE;QAClE,uBAAA,IAAI,mEAAc,MAAlB,IAAI,EAAe,IAAI,CAAC,CAAC;KAC1B;SAAM;QACL,uBAAA,IAAI,sCAAc,CAAC,IAAI,CACrB,IAAI,0BAA0B,CAAC,GAAG,EAAE;YAClC,uBAAA,IAAI,mEAAc,MAAlB,IAAI,EAAe,IAAI,CAAC,CAAC;QAC3B,CAAC,EAAE,IAAI,CAAC,CACT,CAAC;KACH;AACH,CAAC,2EAEa,IAAuB;IACnC,uBAAA,IAAI,iCAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACzB,uBAAA,IAAI,iCAAS,CAAC,QAAQ,EAAE,CAAC;IACzB,uBAAA,IAAI,sCAAc,CAAC,QAAQ,EAAE,CAAC;IAC9B,uBAAA,IAAI,qCAAa,CAAC,QAAQ,EAAE,CAAC;AAC/B,CAAC","sourcesContent":["import { Observable, Subject } from 'rxjs';\n\nimport { SkyModalBeforeCloseHandler } from './modal-before-close-handler';\nimport { SkyModalCloseArgs } from './modal-close-args';\n\nexport class SkyModalInstance {\n  /**\n   * An event that the modal instance emits when it is about to close.\n   * It emits a `SkyModalBeforeCloseHandler` object with a `closeModal` method\n   * that closes the modal. If a subscription exists for this event,\n   * the modal does not close until the subscriber calls the `closeModal` method.\n   */\n  public get beforeClose(): Observable<SkyModalBeforeCloseHandler> {\n    return this.#_beforeClose;\n  }\n\n  /**\n   * An event that the modal instance emits when it closes.\n   * It emits a `SkyModalCloseArgs` object with a `data` property that includes\n   * data passed from users on close or save and a `reason` property that indicates\n   * whether the modal was saved or closed without saving.\n   * The `reason` property accepts any string value.\n   * Common examples include `\"cancel\"`, `\"close\"`, and `\"save\"`.\n   */\n  public get closed(): Observable<SkyModalCloseArgs> {\n    return this.#_closed;\n  }\n\n  /**\n   * An event that the modal instance emits when users click\n   * the <i class=\"fa fa-question-circle\" aria-hidden=\"true\"></i> button.\n   * If a `helpKey` parameter was specified, the `helpOpened` event broadcasts the `helpKey`.\n   */\n  public get helpOpened(): Observable<string> {\n    return this.#_helpOpened;\n  }\n\n  /**\n   * A direct reference to the provided component's class.\n   */\n  public componentInstance: any;\n\n  #_beforeClose = new Subject<SkyModalBeforeCloseHandler>();\n\n  #_closed = new Subject<SkyModalCloseArgs>();\n\n  #_helpOpened = new Subject<string>();\n\n  /**\n   * Closes the modal instance.\n   * @param result Specifies an object to emit to subscribers of the `closed` event of the\n   * modal instance. The `SkyModalInstance` provider can be injected into a component's constructor\n   * so that this `close` function can be called from a button in the `sky-modal-footer`.\n   * @param reason Specifies the reason for the modal closing, with the default reason of `\"close\"`.\n   * @param ignoreBeforeClose Indicates whether to ignore the modal instance's `beforeClose` event.\n   */\n  public close(\n    result?: any,\n    reason?: string,\n    ignoreBeforeClose?: boolean\n  ): void {\n    if (reason === undefined) {\n      reason = 'close';\n    }\n\n    this.#closeModal(reason, result, ignoreBeforeClose);\n  }\n\n  /**\n   * Closes the modal instance with `reason=\"cancel\"`.\n   * @param result Specifies an object to emit to subscribers of the `closed` event of the modal\n   * instance. The `SkyModalInstance` provider can be injected into a component's constructor so\n   * that this cancel function can be called from a button in the `sky-modal-footer`.\n   */\n  public cancel(result?: any): void {\n    this.#closeModal('cancel', result);\n  }\n\n  /**\n   * Closes the modal instance with `reason=\"save\"`.\n   * @param result Specifies an object to emit to subscribers of the `closed` event of the modal\n   * instance. The `SkyModalInstance` provider can be injected into a component's constructor so\n   * that this `save` function can be called from a button in `the sky-modal-footer`.\n   */\n  public save(result?: any): void {\n    this.#closeModal('save', result);\n  }\n\n  /**\n   * Triggers the `helpOpened` event that broadcasts a `helpKey` parameter to open\n   * when users click the <i class=\"fa fa-question-circle\" aria-hidden=\"true\"></i> button.\n   * @param helpKey Specifies a string to emit to subscribers of\n   * the modal instance's `helpOpened` event. Consumers can inject the `SkyModalInstance` provider\n   * into a component's constructor to call the `openHelp` function in the modal template.\n   */\n  public openHelp(helpKey?: string): void {\n    this.#_helpOpened.next(helpKey);\n  }\n\n  #closeModal(type: string, result?: any, ignoreBeforeClose = false): void {\n    const args = new SkyModalCloseArgs();\n\n    args.reason = type;\n    args.data = result;\n\n    if (this.#_beforeClose.observers.length === 0 || ignoreBeforeClose) {\n      this.#notifyClosed(args);\n    } else {\n      this.#_beforeClose.next(\n        new SkyModalBeforeCloseHandler(() => {\n          this.#notifyClosed(args);\n        }, args)\n      );\n    }\n  }\n\n  #notifyClosed(args: SkyModalCloseArgs): void {\n    this.#_closed.next(args);\n    this.#_closed.complete();\n    this.#_beforeClose.complete();\n    this.#_helpOpened.complete();\n  }\n}\n"]}
|