@skyux/modals 9.14.0 → 9.15.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.
@@ -34,7 +34,7 @@ export class SkyModalHostComponent {
34
34
  this.#closeAllModalInstances();
35
35
  this.#modalHostContext.args.teardownCallback();
36
36
  }
37
- open(modalInstance, component, config) {
37
+ open(modalInstance, component, config, environmentInjector) {
38
38
  /* Ignore coverage as we specify the target element and so the view child should never be undefined unless
39
39
  * we were to call the `open` method in an early lifecycle hook. */
40
40
  /* istanbul ignore next */
@@ -67,8 +67,9 @@ export class SkyModalHostComponent {
67
67
  });
68
68
  adapter.setPageScroll(SkyModalHostService.openModalCount > 0);
69
69
  adapter.toggleFullPageModalClass(SkyModalHostService.fullPageModalCount > 0);
70
+ environmentInjector ||= this.#environmentInjector;
70
71
  const modalComponentRef = this.#dynamicComponentSvc.createComponent(component, {
71
- environmentInjector: this.#environmentInjector,
72
+ environmentInjector: environmentInjector,
72
73
  providers: params.providers,
73
74
  viewContainerRef: this.target,
74
75
  });
@@ -147,4 +148,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.9", ngImpor
147
148
  static: true,
148
149
  }]
149
150
  }] } });
150
- //# 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 { CommonModule } from '@angular/common';\nimport {\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EnvironmentInjector,\n  OnDestroy,\n  Type,\n  ViewChild,\n  ViewContainerRef,\n  inject,\n} from '@angular/core';\nimport { NavigationStart, Router, RouterModule } from '@angular/router';\nimport {\n  SKY_STACKING_CONTEXT,\n  SkyDynamicComponentService,\n  SkyMediaQueryService,\n  SkyResizeObserverMediaQueryService,\n} from '@skyux/core';\n\nimport { BehaviorSubject } from 'rxjs';\nimport { takeUntil, takeWhile } from 'rxjs/operators';\n\nimport { SkyModalsResourcesModule } from '../shared/sky-modals-resources.module';\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  standalone: true,\n  selector: 'sky-modal-host',\n  templateUrl: './modal-host.component.html',\n  styleUrls: ['./modal-host.component.scss'],\n  viewProviders: [SkyModalAdapterService],\n  imports: [CommonModule, RouterModule, SkyModalsResourcesModule],\n})\nexport class SkyModalHostComponent implements OnDestroy {\n  public get modalOpen(): boolean {\n    return SkyModalHostService.openModalCount > 0;\n  }\n\n  public get backdropZIndex(): number {\n    return SkyModalHostService.backdropZIndex;\n  }\n\n  @ViewChild('target', {\n    read: ViewContainerRef,\n    static: true,\n  })\n  public target: ViewContainerRef | undefined;\n\n  #modalInstances: SkyModalInstance[] = [];\n\n  readonly #adapter = inject(SkyModalAdapterService);\n  readonly #changeDetector = inject(ChangeDetectorRef);\n  readonly #dynamicComponentSvc = inject(SkyDynamicComponentService);\n  readonly #elRef = inject(ElementRef);\n  readonly #environmentInjector = inject(EnvironmentInjector);\n  readonly #modalHostContext = inject(SkyModalHostContext);\n  readonly #router = inject(Router, { optional: true });\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<T>(\n    modalInstance: SkyModalInstance,\n    component: Type<T>,\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\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 ||= [];\n    params.providers.push(\n      { provide: SkyResizeObserverMediaQueryService },\n      {\n        provide: SkyModalHostService,\n        useValue: hostService,\n      },\n      {\n        provide: SkyModalConfiguration,\n        useValue: params,\n      },\n      {\n        provide: SkyMediaQueryService,\n        useExisting: SkyResizeObserverMediaQueryService,\n      },\n      {\n        provide: SKY_STACKING_CONTEXT,\n        useValue: {\n          zIndex: new BehaviorSubject(hostService.getModalZIndex())\n            .asObservable()\n            .pipe(takeUntil(modalInstance.closed)),\n        },\n      },\n    );\n\n    adapter.setPageScroll(SkyModalHostService.openModalCount > 0);\n    adapter.toggleFullPageModalClass(\n      SkyModalHostService.fullPageModalCount > 0,\n    );\n\n    const modalComponentRef = this.#dynamicComponentSvc.createComponent(\n      component,\n      {\n        environmentInjector: this.#environmentInjector,\n        providers: params.providers,\n        viewContainerRef: this.target,\n      },\n    );\n\n    // modal element that was just opened\n    const modalElement = modalComponentRef.location;\n\n    modalInstance.adapter = this.#adapter;\n    modalInstance.componentRef = modalComponentRef;\n\n    this.#registerModalInstance(modalInstance);\n\n    // hiding all elements at the modal-host level from screen readers when the a modal is opened\n    this.#adapter.hideHostSiblingsFromScreenReaders(this.#elRef);\n    if (\n      SkyModalHostService.openModalCount > 1 &&\n      SkyModalHostService.topModal === hostService\n    ) {\n      // hiding the lower modals when more than one modal is opened\n      this.#adapter.hidePreviousModalFromScreenReaders(modalElement);\n    }\n\n    const closeModal = (): void => {\n      // unhide siblings if last modal is closing\n      if (SkyModalHostService.openModalCount === 1) {\n        this.#adapter.unhideOrRestoreHostSiblingsFromScreenReaders();\n      } else if (SkyModalHostService.topModal === hostService) {\n        // if there are more than 1 modal then unhide the one behind this one before closing it\n        this.#adapter.unhidePreviousModalFromScreenReaders(modalElement);\n      }\n\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) => {\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"]}
151
+ //# 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 { CommonModule } from '@angular/common';\nimport {\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EnvironmentInjector,\n  OnDestroy,\n  Type,\n  ViewChild,\n  ViewContainerRef,\n  inject,\n} from '@angular/core';\nimport { NavigationStart, Router, RouterModule } from '@angular/router';\nimport {\n  SKY_STACKING_CONTEXT,\n  SkyDynamicComponentService,\n  SkyMediaQueryService,\n  SkyResizeObserverMediaQueryService,\n} from '@skyux/core';\n\nimport { BehaviorSubject } from 'rxjs';\nimport { takeUntil, takeWhile } from 'rxjs/operators';\n\nimport { SkyModalsResourcesModule } from '../shared/sky-modals-resources.module';\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  standalone: true,\n  selector: 'sky-modal-host',\n  templateUrl: './modal-host.component.html',\n  styleUrls: ['./modal-host.component.scss'],\n  viewProviders: [SkyModalAdapterService],\n  imports: [CommonModule, RouterModule, SkyModalsResourcesModule],\n})\nexport class SkyModalHostComponent implements OnDestroy {\n  public get modalOpen(): boolean {\n    return SkyModalHostService.openModalCount > 0;\n  }\n\n  public get backdropZIndex(): number {\n    return SkyModalHostService.backdropZIndex;\n  }\n\n  @ViewChild('target', {\n    read: ViewContainerRef,\n    static: true,\n  })\n  public target: ViewContainerRef | undefined;\n\n  #modalInstances: SkyModalInstance[] = [];\n\n  readonly #adapter = inject(SkyModalAdapterService);\n  readonly #changeDetector = inject(ChangeDetectorRef);\n  readonly #dynamicComponentSvc = inject(SkyDynamicComponentService);\n  readonly #elRef = inject(ElementRef);\n  readonly #environmentInjector = inject(EnvironmentInjector);\n  readonly #modalHostContext = inject(SkyModalHostContext);\n  readonly #router = inject(Router, { optional: true });\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<T>(\n    modalInstance: SkyModalInstance,\n    component: Type<T>,\n    config?: SkyModalConfigurationInterface,\n    environmentInjector?: EnvironmentInjector,\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\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 ||= [];\n    params.providers.push(\n      { provide: SkyResizeObserverMediaQueryService },\n      {\n        provide: SkyModalHostService,\n        useValue: hostService,\n      },\n      {\n        provide: SkyModalConfiguration,\n        useValue: params,\n      },\n      {\n        provide: SkyMediaQueryService,\n        useExisting: SkyResizeObserverMediaQueryService,\n      },\n      {\n        provide: SKY_STACKING_CONTEXT,\n        useValue: {\n          zIndex: new BehaviorSubject(hostService.getModalZIndex())\n            .asObservable()\n            .pipe(takeUntil(modalInstance.closed)),\n        },\n      },\n    );\n\n    adapter.setPageScroll(SkyModalHostService.openModalCount > 0);\n    adapter.toggleFullPageModalClass(\n      SkyModalHostService.fullPageModalCount > 0,\n    );\n\n    environmentInjector ||= this.#environmentInjector;\n    const modalComponentRef = this.#dynamicComponentSvc.createComponent(\n      component,\n      {\n        environmentInjector: environmentInjector,\n        providers: params.providers,\n        viewContainerRef: this.target,\n      },\n    );\n\n    // modal element that was just opened\n    const modalElement = modalComponentRef.location;\n\n    modalInstance.adapter = this.#adapter;\n    modalInstance.componentRef = modalComponentRef;\n\n    this.#registerModalInstance(modalInstance);\n\n    // hiding all elements at the modal-host level from screen readers when the a modal is opened\n    this.#adapter.hideHostSiblingsFromScreenReaders(this.#elRef);\n    if (\n      SkyModalHostService.openModalCount > 1 &&\n      SkyModalHostService.topModal === hostService\n    ) {\n      // hiding the lower modals when more than one modal is opened\n      this.#adapter.hidePreviousModalFromScreenReaders(modalElement);\n    }\n\n    const closeModal = (): void => {\n      // unhide siblings if last modal is closing\n      if (SkyModalHostService.openModalCount === 1) {\n        this.#adapter.unhideOrRestoreHostSiblingsFromScreenReaders();\n      } else if (SkyModalHostService.topModal === hostService) {\n        // if there are more than 1 modal then unhide the one behind this one before closing it\n        this.#adapter.unhidePreviousModalFromScreenReaders(modalElement);\n      }\n\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) => {\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"]}
@@ -40,7 +40,7 @@ export class SkyModalService {
40
40
  useValue: modalInstance,
41
41
  });
42
42
  if (SkyModalService.host) {
43
- SkyModalService.host.instance.open(modalInstance, component, params);
43
+ SkyModalService.host.instance.open(modalInstance, component, params, this.#environmentInjector);
44
44
  }
45
45
  return modalInstance;
46
46
  }
@@ -115,4 +115,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.9", ngImpor
115
115
  providedIn: 'any',
116
116
  }]
117
117
  }], ctorParameters: function () { return [{ type: i1.SkyDynamicComponentLegacyService }]; } });
118
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal.service.js","sourceRoot":"","sources":["../../../../../../../../libs/components/modals/src/lib/modules/modal/modal.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ComponentRef,\n  EnvironmentInjector,\n  Injectable,\n  inject,\n} from '@angular/core';\nimport {\n  SkyDynamicComponentLegacyService,\n  SkyDynamicComponentService,\n} from '@skyux/core';\n\nimport { SkyModalHostContext } from './modal-host-context';\nimport { SkyModalHostComponent } from './modal-host.component';\nimport { SkyModalInstance } from './modal-instance';\nimport { SkyModalConfigurationInterface } from './modal.interface';\n\n/**\n * A service that launches modals.\n */\n@Injectable({\n  providedIn: 'root',\n})\nexport class SkyModalService {\n  private static host: ComponentRef<SkyModalHostComponent> | undefined; // <-- how do we handle only having one of these?\n\n  #dynamicComponentService: SkyDynamicComponentService;\n  #environmentInjector = inject(EnvironmentInjector);\n\n  constructor(dynamicComponentService: SkyDynamicComponentService) {\n    this.#dynamicComponentService = dynamicComponentService;\n  }\n\n  /**\n   * @internal\n   * Removes the modal host from the DOM.\n   */\n  public dispose(): void {\n    if (SkyModalService.host) {\n      this.#dynamicComponentService.removeComponent(SkyModalService.host);\n      SkyModalService.host = undefined;\n    }\n  }\n\n  /**\n   * Opens a modal using the specified component.\n   * @param component Determines the component to render.\n   * @param {SkyModalConfigurationInterface} config Specifies configuration options for the modal.\n   */\n  public open(\n    component: any,\n    config?: SkyModalConfigurationInterface | any[],\n  ): SkyModalInstance {\n    const modalInstance = new SkyModalInstance();\n\n    if (!SkyModalService.host) {\n      SkyModalService.host = this.#createHostComponent();\n    }\n\n    const params = this.#getConfigFromParameter(config);\n\n    params.providers ||= [];\n    params.providers.push({\n      provide: SkyModalInstance,\n      useValue: modalInstance,\n    });\n\n    if (SkyModalService.host) {\n      SkyModalService.host.instance.open(modalInstance, component, params);\n    }\n\n    return modalInstance;\n  }\n\n  #getConfigFromParameter(\n    providersOrConfig: any,\n  ): SkyModalConfigurationInterface {\n    const defaultParams: SkyModalConfigurationInterface = {\n      providers: [],\n      fullPage: false,\n      size: 'medium',\n      tiledBody: false,\n    };\n    let params: SkyModalConfigurationInterface = {};\n    let method: any = undefined;\n\n    // Object Literal Lookup for backwards compatibility.\n    method = {\n      'providers?': Object.assign({}, defaultParams, {\n        providers: providersOrConfig,\n      }),\n      config: Object.assign({}, defaultParams, providersOrConfig),\n    };\n\n    if (Array.isArray(providersOrConfig) === true) {\n      params = method['providers?'];\n    } else {\n      params = method['config'];\n    }\n\n    return params;\n  }\n\n  #createHostComponent(): ComponentRef<SkyModalHostComponent> {\n    const componentRef = this.#dynamicComponentService.createComponent(\n      SkyModalHostComponent,\n      {\n        environmentInjector: this.#environmentInjector,\n        providers: [\n          {\n            provide: SkyModalHostContext,\n            useValue: new SkyModalHostContext({\n              teardownCallback: (): void => {\n                this.dispose();\n              },\n            }),\n          },\n        ],\n      },\n    );\n\n    return componentRef;\n  }\n}\n\n/**\n * A service that launches modals.\n * @internal\n * @deprecated Use `SkyModalService` to open a standalone component instead.\n */\n@Injectable({\n  // Must be 'any' so that the modal component is created in the context of its module's injector.\n  // If set to 'root', the component's dependency injections would only be derived from the root\n  // injector and may lose context if the modal was opened from within a lazy-loaded module.\n  providedIn: 'any',\n})\nexport class SkyModalLegacyService extends SkyModalService {\n  /* istanbul ignore next */\n  constructor(dynamicComponentSvc: SkyDynamicComponentLegacyService) {\n    super(dynamicComponentSvc);\n  }\n}\n"]}
118
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal.service.js","sourceRoot":"","sources":["../../../../../../../../libs/components/modals/src/lib/modules/modal/modal.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ComponentRef,\n  EnvironmentInjector,\n  Injectable,\n  inject,\n} from '@angular/core';\nimport {\n  SkyDynamicComponentLegacyService,\n  SkyDynamicComponentService,\n} from '@skyux/core';\n\nimport { SkyModalHostContext } from './modal-host-context';\nimport { SkyModalHostComponent } from './modal-host.component';\nimport { SkyModalInstance } from './modal-instance';\nimport { SkyModalConfigurationInterface } from './modal.interface';\n\n/**\n * A service that launches modals.\n */\n@Injectable({\n  providedIn: 'root',\n})\nexport class SkyModalService {\n  private static host: ComponentRef<SkyModalHostComponent> | undefined; // <-- how do we handle only having one of these?\n\n  #dynamicComponentService: SkyDynamicComponentService;\n  #environmentInjector = inject(EnvironmentInjector);\n\n  constructor(dynamicComponentService: SkyDynamicComponentService) {\n    this.#dynamicComponentService = dynamicComponentService;\n  }\n\n  /**\n   * @internal\n   * Removes the modal host from the DOM.\n   */\n  public dispose(): void {\n    if (SkyModalService.host) {\n      this.#dynamicComponentService.removeComponent(SkyModalService.host);\n      SkyModalService.host = undefined;\n    }\n  }\n\n  /**\n   * Opens a modal using the specified component.\n   * @param component Determines the component to render.\n   * @param {SkyModalConfigurationInterface} config Specifies configuration options for the modal.\n   */\n  public open(\n    component: any,\n    config?: SkyModalConfigurationInterface | any[],\n  ): SkyModalInstance {\n    const modalInstance = new SkyModalInstance();\n\n    if (!SkyModalService.host) {\n      SkyModalService.host = this.#createHostComponent();\n    }\n\n    const params = this.#getConfigFromParameter(config);\n\n    params.providers ||= [];\n    params.providers.push({\n      provide: SkyModalInstance,\n      useValue: modalInstance,\n    });\n\n    if (SkyModalService.host) {\n      SkyModalService.host.instance.open(\n        modalInstance,\n        component,\n        params,\n        this.#environmentInjector,\n      );\n    }\n\n    return modalInstance;\n  }\n\n  #getConfigFromParameter(\n    providersOrConfig: any,\n  ): SkyModalConfigurationInterface {\n    const defaultParams: SkyModalConfigurationInterface = {\n      providers: [],\n      fullPage: false,\n      size: 'medium',\n      tiledBody: false,\n    };\n    let params: SkyModalConfigurationInterface = {};\n    let method: any = undefined;\n\n    // Object Literal Lookup for backwards compatibility.\n    method = {\n      'providers?': Object.assign({}, defaultParams, {\n        providers: providersOrConfig,\n      }),\n      config: Object.assign({}, defaultParams, providersOrConfig),\n    };\n\n    if (Array.isArray(providersOrConfig) === true) {\n      params = method['providers?'];\n    } else {\n      params = method['config'];\n    }\n\n    return params;\n  }\n\n  #createHostComponent(): ComponentRef<SkyModalHostComponent> {\n    const componentRef = this.#dynamicComponentService.createComponent(\n      SkyModalHostComponent,\n      {\n        environmentInjector: this.#environmentInjector,\n        providers: [\n          {\n            provide: SkyModalHostContext,\n            useValue: new SkyModalHostContext({\n              teardownCallback: (): void => {\n                this.dispose();\n              },\n            }),\n          },\n        ],\n      },\n    );\n\n    return componentRef;\n  }\n}\n\n/**\n * A service that launches modals.\n * @internal\n * @deprecated Use `SkyModalService` to open a standalone component instead.\n */\n@Injectable({\n  // Must be 'any' so that the modal component is created in the context of its module's injector.\n  // If set to 'root', the component's dependency injections would only be derived from the root\n  // injector and may lose context if the modal was opened from within a lazy-loaded module.\n  providedIn: 'any',\n})\nexport class SkyModalLegacyService extends SkyModalService {\n  /* istanbul ignore next */\n  constructor(dynamicComponentSvc: SkyDynamicComponentLegacyService) {\n    super(dynamicComponentSvc);\n  }\n}\n"]}
@@ -1064,7 +1064,7 @@ class SkyModalHostComponent {
1064
1064
  this.#closeAllModalInstances();
1065
1065
  this.#modalHostContext.args.teardownCallback();
1066
1066
  }
1067
- open(modalInstance, component, config) {
1067
+ open(modalInstance, component, config, environmentInjector) {
1068
1068
  /* Ignore coverage as we specify the target element and so the view child should never be undefined unless
1069
1069
  * we were to call the `open` method in an early lifecycle hook. */
1070
1070
  /* istanbul ignore next */
@@ -1097,8 +1097,9 @@ class SkyModalHostComponent {
1097
1097
  });
1098
1098
  adapter.setPageScroll(SkyModalHostService.openModalCount > 0);
1099
1099
  adapter.toggleFullPageModalClass(SkyModalHostService.fullPageModalCount > 0);
1100
+ environmentInjector ||= this.#environmentInjector;
1100
1101
  const modalComponentRef = this.#dynamicComponentSvc.createComponent(component, {
1101
- environmentInjector: this.#environmentInjector,
1102
+ environmentInjector: environmentInjector,
1102
1103
  providers: params.providers,
1103
1104
  viewContainerRef: this.target,
1104
1105
  });
@@ -1214,7 +1215,7 @@ class SkyModalService {
1214
1215
  useValue: modalInstance,
1215
1216
  });
1216
1217
  if (SkyModalService.host) {
1217
- SkyModalService.host.instance.open(modalInstance, component, params);
1218
+ SkyModalService.host.instance.open(modalInstance, component, params, this.#environmentInjector);
1218
1219
  }
1219
1220
  return modalInstance;
1220
1221
  }