@skyux/core 7.0.0-beta.3 → 7.0.0-beta.5

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.
@@ -1,6 +1,6 @@
1
- var _SkyDockComponent_instances, _SkyDockComponent_changeDetector, _SkyDockComponent_domAdapter, _SkyDockComponent_elementRef, _SkyDockComponent_injector, _SkyDockComponent_itemRefs, _SkyDockComponent_options, _SkyDockComponent_resolver, _SkyDockComponent_sortItemsByStackOrder, _SkyDockComponent_getHighestStackOrder;
1
+ var _SkyDockComponent_instances, _SkyDockComponent_changeDetector, _SkyDockComponent_domAdapter, _SkyDockComponent_elementRef, _SkyDockComponent_injector, _SkyDockComponent_itemRefs, _SkyDockComponent_options, _SkyDockComponent_sortItemsByStackOrder, _SkyDockComponent_getHighestStackOrder;
2
2
  import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
3
- import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ComponentFactoryResolver, ElementRef, Injector, ViewChild, ViewContainerRef, } from '@angular/core';
3
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, Injector, ViewChild, ViewContainerRef, } from '@angular/core';
4
4
  import { SkyDockDomAdapterService } from './dock-dom-adapter.service';
5
5
  import { SkyDockLocation } from './dock-location';
6
6
  import { sortByStackOrder } from './sort-by-stack-order';
@@ -10,8 +10,7 @@ import * as i1 from "./dock-dom-adapter.service";
10
10
  * @internal
11
11
  */
12
12
  export class SkyDockComponent {
13
- // TODO: Replace deprecated `ComponentFactoryResolver`.
14
- constructor(changeDetector, resolver, elementRef, injector, domAdapter) {
13
+ constructor(changeDetector, elementRef, injector, domAdapter) {
15
14
  _SkyDockComponent_instances.add(this);
16
15
  _SkyDockComponent_changeDetector.set(this, void 0);
17
16
  _SkyDockComponent_domAdapter.set(this, void 0);
@@ -19,9 +18,7 @@ export class SkyDockComponent {
19
18
  _SkyDockComponent_injector.set(this, void 0);
20
19
  _SkyDockComponent_itemRefs.set(this, []);
21
20
  _SkyDockComponent_options.set(this, void 0);
22
- _SkyDockComponent_resolver.set(this, void 0);
23
21
  __classPrivateFieldSet(this, _SkyDockComponent_changeDetector, changeDetector, "f");
24
- __classPrivateFieldSet(this, _SkyDockComponent_resolver, resolver, "f");
25
22
  __classPrivateFieldSet(this, _SkyDockComponent_elementRef, elementRef, "f");
26
23
  __classPrivateFieldSet(this, _SkyDockComponent_injector, injector, "f");
27
24
  __classPrivateFieldSet(this, _SkyDockComponent_domAdapter, domAdapter, "f");
@@ -31,12 +28,13 @@ export class SkyDockComponent {
31
28
  if (!this.target) {
32
29
  throw Error('[SkyDockComponent] Could not insert the component because the target element could not be found.');
33
30
  }
34
- const factory = __classPrivateFieldGet(this, _SkyDockComponent_resolver, "f").resolveComponentFactory(component);
35
31
  const injector = Injector.create({
36
32
  providers: config.providers || [],
37
33
  parent: __classPrivateFieldGet(this, _SkyDockComponent_injector, "f"),
38
34
  });
39
- const componentRef = this.target.createComponent(factory, undefined, injector);
35
+ const componentRef = this.target.createComponent(component, {
36
+ injector,
37
+ });
40
38
  const stackOrder = config.stackOrder !== null && config.stackOrder !== undefined
41
39
  ? config.stackOrder
42
40
  : __classPrivateFieldGet(this, _SkyDockComponent_instances, "m", _SkyDockComponent_getHighestStackOrder).call(this);
@@ -82,7 +80,7 @@ export class SkyDockComponent {
82
80
  }
83
81
  }
84
82
  }
85
- _SkyDockComponent_changeDetector = new WeakMap(), _SkyDockComponent_domAdapter = new WeakMap(), _SkyDockComponent_elementRef = new WeakMap(), _SkyDockComponent_injector = new WeakMap(), _SkyDockComponent_itemRefs = new WeakMap(), _SkyDockComponent_options = new WeakMap(), _SkyDockComponent_resolver = new WeakMap(), _SkyDockComponent_instances = new WeakSet(), _SkyDockComponent_sortItemsByStackOrder = function _SkyDockComponent_sortItemsByStackOrder() {
83
+ _SkyDockComponent_changeDetector = new WeakMap(), _SkyDockComponent_domAdapter = new WeakMap(), _SkyDockComponent_elementRef = new WeakMap(), _SkyDockComponent_injector = new WeakMap(), _SkyDockComponent_itemRefs = new WeakMap(), _SkyDockComponent_options = new WeakMap(), _SkyDockComponent_instances = new WeakSet(), _SkyDockComponent_sortItemsByStackOrder = function _SkyDockComponent_sortItemsByStackOrder() {
86
84
  if (this.target) {
87
85
  __classPrivateFieldGet(this, _SkyDockComponent_itemRefs, "f").sort(sortByStackOrder);
88
86
  // Reassign the correct index for each view.
@@ -97,16 +95,16 @@ _SkyDockComponent_changeDetector = new WeakMap(), _SkyDockComponent_domAdapter =
97
95
  }
98
96
  return __classPrivateFieldGet(this, _SkyDockComponent_itemRefs, "f")[0].stackOrder + 1;
99
97
  };
100
- SkyDockComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyDockComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.ComponentFactoryResolver }, { token: i0.ElementRef }, { token: i0.Injector }, { token: i1.SkyDockDomAdapterService }], target: i0.ɵɵFactoryTarget.Component });
98
+ SkyDockComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyDockComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.ElementRef }, { token: i0.Injector }, { token: i1.SkyDockDomAdapterService }], target: i0.ɵɵFactoryTarget.Component });
101
99
  SkyDockComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: SkyDockComponent, selector: "sky-dock", providers: [SkyDockDomAdapterService], viewQueries: [{ propertyName: "target", first: true, predicate: ["target"], descendants: true, read: ViewContainerRef, static: true }], ngImport: i0, template: "<ng-container #target></ng-container>\n", styles: [":host{display:flex;flex-direction:column;width:100%}:host:not(.sky-dock-unbound){position:fixed;left:0;bottom:0;right:0}:host.sky-dock-sticky{position:sticky}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush });
102
100
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyDockComponent, decorators: [{
103
101
  type: Component,
104
102
  args: [{ selector: 'sky-dock', providers: [SkyDockDomAdapterService], changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container #target></ng-container>\n", styles: [":host{display:flex;flex-direction:column;width:100%}:host:not(.sky-dock-unbound){position:fixed;left:0;bottom:0;right:0}:host.sky-dock-sticky{position:sticky}\n"] }]
105
- }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i0.ComponentFactoryResolver }, { type: i0.ElementRef }, { type: i0.Injector }, { type: i1.SkyDockDomAdapterService }]; }, propDecorators: { target: [{
103
+ }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i0.ElementRef }, { type: i0.Injector }, { type: i1.SkyDockDomAdapterService }]; }, propDecorators: { target: [{
106
104
  type: ViewChild,
107
105
  args: ['target', {
108
106
  read: ViewContainerRef,
109
107
  static: true,
110
108
  }]
111
109
  }] } });
112
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dock.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/core/src/lib/modules/dock/dock.component.ts","../../../../../../../../libs/components/core/src/lib/modules/dock/dock.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ComponentFactoryResolver,\n  ElementRef,\n  Injector,\n  Type,\n  ViewChild,\n  ViewContainerRef,\n} from '@angular/core';\n\nimport { SkyDockDomAdapterService } from './dock-dom-adapter.service';\nimport { SkyDockInsertComponentConfig } from './dock-insert-component-config';\nimport { SkyDockItemReference } from './dock-item-reference';\nimport { SkyDockLocation } from './dock-location';\nimport { SkyDockOptions } from './dock-options';\nimport { sortByStackOrder } from './sort-by-stack-order';\n\n/**\n * @internal\n */\n@Component({\n  selector: 'sky-dock',\n  templateUrl: './dock.component.html',\n  styleUrls: ['./dock.component.scss'],\n  providers: [SkyDockDomAdapterService],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class SkyDockComponent {\n  @ViewChild('target', {\n    read: ViewContainerRef,\n    static: true,\n  })\n  private target: ViewContainerRef | undefined;\n\n  #changeDetector: ChangeDetectorRef;\n\n  #domAdapter: SkyDockDomAdapterService;\n\n  #elementRef: ElementRef;\n\n  #injector: Injector;\n\n  #itemRefs: SkyDockItemReference<unknown>[] = [];\n\n  #options: SkyDockOptions | undefined;\n\n  #resolver: ComponentFactoryResolver;\n\n  // TODO: Replace deprecated `ComponentFactoryResolver`.\n  constructor(\n    changeDetector: ChangeDetectorRef,\n    resolver: ComponentFactoryResolver,\n    elementRef: ElementRef,\n    injector: Injector,\n    domAdapter: SkyDockDomAdapterService\n  ) {\n    this.#changeDetector = changeDetector;\n    this.#resolver = resolver;\n    this.#elementRef = elementRef;\n    this.#injector = injector;\n    this.#domAdapter = domAdapter;\n  }\n\n  public insertComponent<T>(\n    component: Type<T>,\n    config: SkyDockInsertComponentConfig = {}\n  ): SkyDockItemReference<T> {\n    /*istanbul ignore if: untestable*/\n    if (!this.target) {\n      throw Error(\n        '[SkyDockComponent] Could not insert the component because the target element could not be found.'\n      );\n    }\n\n    const factory = this.#resolver.resolveComponentFactory(component);\n    const injector = Injector.create({\n      providers: config.providers || [],\n      parent: this.#injector,\n    });\n\n    const componentRef = this.target.createComponent<T>(\n      factory,\n      undefined,\n      injector\n    );\n    const stackOrder =\n      config.stackOrder !== null && config.stackOrder !== undefined\n        ? config.stackOrder\n        : this.#getHighestStackOrder();\n\n    this.#itemRefs.push({\n      componentRef,\n      stackOrder,\n    });\n\n    this.#sortItemsByStackOrder();\n\n    this.#changeDetector.markForCheck();\n\n    return {\n      componentRef,\n      stackOrder,\n    };\n  }\n\n  public removeItem(item: SkyDockItemReference<any>): void {\n    /*istanbul ignore if: untestable*/\n    if (!this.target) {\n      throw Error(\n        '[SkyDockComponent] Could not remove the item because the target element could not be found.'\n      );\n    }\n\n    const viewRef = item.componentRef.hostView;\n    this.target.remove(this.target.indexOf(viewRef));\n\n    const found = this.#itemRefs.find(\n      (i) => i.componentRef.hostView === viewRef\n    );\n\n    if (found) {\n      this.#itemRefs.splice(this.#itemRefs.indexOf(found), 1);\n    }\n  }\n\n  public setOptions(options: SkyDockOptions | undefined): void {\n    this.#options = options;\n\n    switch (this.#options?.location) {\n      case SkyDockLocation.BeforeElement:\n        this.#domAdapter.unbindDock(this.#elementRef);\n        break;\n      case SkyDockLocation.ElementBottom:\n        this.#domAdapter.setSticky(this.#elementRef);\n        break;\n      case SkyDockLocation.BodyBottom:\n      default:\n        this.#domAdapter.watchDomChanges(this.#elementRef);\n        break;\n    }\n\n    if (this.#options?.zIndex) {\n      this.#domAdapter.setZIndex(this.#options.zIndex, this.#elementRef);\n    }\n  }\n\n  #sortItemsByStackOrder(): void {\n    if (this.target) {\n      this.#itemRefs.sort(sortByStackOrder);\n\n      // Reassign the correct index for each view.\n      for (let i = 0, len = this.#itemRefs.length; i < len; i++) {\n        const item = this.#itemRefs[i];\n        this.target.move(item.componentRef.hostView, i);\n      }\n    }\n  }\n\n  #getHighestStackOrder(): number {\n    if (this.#itemRefs.length === 0) {\n      return 0;\n    }\n\n    return this.#itemRefs[0].stackOrder + 1;\n  }\n}\n","<ng-container #target></ng-container>\n"]}
110
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dock.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/core/src/lib/modules/dock/dock.component.ts","../../../../../../../../libs/components/core/src/lib/modules/dock/dock.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  Injector,\n  Type,\n  ViewChild,\n  ViewContainerRef,\n} from '@angular/core';\n\nimport { SkyDockDomAdapterService } from './dock-dom-adapter.service';\nimport { SkyDockInsertComponentConfig } from './dock-insert-component-config';\nimport { SkyDockItemReference } from './dock-item-reference';\nimport { SkyDockLocation } from './dock-location';\nimport { SkyDockOptions } from './dock-options';\nimport { sortByStackOrder } from './sort-by-stack-order';\n\n/**\n * @internal\n */\n@Component({\n  selector: 'sky-dock',\n  templateUrl: './dock.component.html',\n  styleUrls: ['./dock.component.scss'],\n  providers: [SkyDockDomAdapterService],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class SkyDockComponent {\n  @ViewChild('target', {\n    read: ViewContainerRef,\n    static: true,\n  })\n  private target: ViewContainerRef | undefined;\n\n  #changeDetector: ChangeDetectorRef;\n\n  #domAdapter: SkyDockDomAdapterService;\n\n  #elementRef: ElementRef;\n\n  #injector: Injector;\n\n  #itemRefs: SkyDockItemReference<unknown>[] = [];\n\n  #options: SkyDockOptions | undefined;\n\n  constructor(\n    changeDetector: ChangeDetectorRef,\n    elementRef: ElementRef,\n    injector: Injector,\n    domAdapter: SkyDockDomAdapterService\n  ) {\n    this.#changeDetector = changeDetector;\n    this.#elementRef = elementRef;\n    this.#injector = injector;\n    this.#domAdapter = domAdapter;\n  }\n\n  public insertComponent<T>(\n    component: Type<T>,\n    config: SkyDockInsertComponentConfig = {}\n  ): SkyDockItemReference<T> {\n    /*istanbul ignore if: untestable*/\n    if (!this.target) {\n      throw Error(\n        '[SkyDockComponent] Could not insert the component because the target element could not be found.'\n      );\n    }\n\n    const injector = Injector.create({\n      providers: config.providers || [],\n      parent: this.#injector,\n    });\n\n    const componentRef = this.target.createComponent<T>(component, {\n      injector,\n    });\n    const stackOrder =\n      config.stackOrder !== null && config.stackOrder !== undefined\n        ? config.stackOrder\n        : this.#getHighestStackOrder();\n\n    this.#itemRefs.push({\n      componentRef,\n      stackOrder,\n    });\n\n    this.#sortItemsByStackOrder();\n\n    this.#changeDetector.markForCheck();\n\n    return {\n      componentRef,\n      stackOrder,\n    };\n  }\n\n  public removeItem(item: SkyDockItemReference<any>): void {\n    /*istanbul ignore if: untestable*/\n    if (!this.target) {\n      throw Error(\n        '[SkyDockComponent] Could not remove the item because the target element could not be found.'\n      );\n    }\n\n    const viewRef = item.componentRef.hostView;\n    this.target.remove(this.target.indexOf(viewRef));\n\n    const found = this.#itemRefs.find(\n      (i) => i.componentRef.hostView === viewRef\n    );\n\n    if (found) {\n      this.#itemRefs.splice(this.#itemRefs.indexOf(found), 1);\n    }\n  }\n\n  public setOptions(options: SkyDockOptions | undefined): void {\n    this.#options = options;\n\n    switch (this.#options?.location) {\n      case SkyDockLocation.BeforeElement:\n        this.#domAdapter.unbindDock(this.#elementRef);\n        break;\n      case SkyDockLocation.ElementBottom:\n        this.#domAdapter.setSticky(this.#elementRef);\n        break;\n      case SkyDockLocation.BodyBottom:\n      default:\n        this.#domAdapter.watchDomChanges(this.#elementRef);\n        break;\n    }\n\n    if (this.#options?.zIndex) {\n      this.#domAdapter.setZIndex(this.#options.zIndex, this.#elementRef);\n    }\n  }\n\n  #sortItemsByStackOrder(): void {\n    if (this.target) {\n      this.#itemRefs.sort(sortByStackOrder);\n\n      // Reassign the correct index for each view.\n      for (let i = 0, len = this.#itemRefs.length; i < len; i++) {\n        const item = this.#itemRefs[i];\n        this.target.move(item.componentRef.hostView, i);\n      }\n    }\n  }\n\n  #getHighestStackOrder(): number {\n    if (this.#itemRefs.length === 0) {\n      return 0;\n    }\n\n    return this.#itemRefs[0].stackOrder + 1;\n  }\n}\n","<ng-container #target></ng-container>\n"]}
@@ -1,6 +1,6 @@
1
- var _SkyDynamicComponentService_instances, _SkyDynamicComponentService_applicationRef, _SkyDynamicComponentService_componentFactoryResolver, _SkyDynamicComponentService_injector, _SkyDynamicComponentService_renderer, _SkyDynamicComponentService_windowRef, _SkyDynamicComponentService_getRootNode;
1
+ var _SkyDynamicComponentService_instances, _SkyDynamicComponentService_applicationRef, _SkyDynamicComponentService_injector, _SkyDynamicComponentService_renderer, _SkyDynamicComponentService_windowRef, _SkyDynamicComponentService_getRootNode;
2
2
  import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
3
- import { ApplicationRef, ComponentFactoryResolver, Injectable, Injector, RendererFactory2, } from '@angular/core';
3
+ import { ApplicationRef, Injectable, Injector, RendererFactory2, createComponent, } from '@angular/core';
4
4
  import { SkyAppWindowRef } from '../window/window-ref';
5
5
  import { SkyDynamicComponentLocation } from './dynamic-component-location';
6
6
  import * as i0 from "@angular/core";
@@ -9,15 +9,12 @@ import * as i1 from "../window/window-ref";
9
9
  * Angular service for creating and rendering a dynamic component.
10
10
  */
11
11
  export class SkyDynamicComponentService {
12
- // TODO: Replace deprecated `ComponentFactoryResolver`.
13
- constructor(componentFactoryResolver, applicationRef, injector, windowRef, rendererFactory) {
12
+ constructor(applicationRef, injector, windowRef, rendererFactory) {
14
13
  _SkyDynamicComponentService_instances.add(this);
15
14
  _SkyDynamicComponentService_applicationRef.set(this, void 0);
16
- _SkyDynamicComponentService_componentFactoryResolver.set(this, void 0);
17
15
  _SkyDynamicComponentService_injector.set(this, void 0);
18
16
  _SkyDynamicComponentService_renderer.set(this, void 0);
19
17
  _SkyDynamicComponentService_windowRef.set(this, void 0);
20
- __classPrivateFieldSet(this, _SkyDynamicComponentService_componentFactoryResolver, componentFactoryResolver, "f");
21
18
  __classPrivateFieldSet(this, _SkyDynamicComponentService_applicationRef, applicationRef, "f");
22
19
  __classPrivateFieldSet(this, _SkyDynamicComponentService_injector, injector, "f");
23
20
  __classPrivateFieldSet(this, _SkyDynamicComponentService_windowRef, windowRef, "f");
@@ -30,7 +27,6 @@ export class SkyDynamicComponentService {
30
27
  /**
31
28
  * Creates an instance of the specified component and adds it to the specified location
32
29
  * on the page.
33
- * @param options Options for creating the dynamic component.
34
30
  */
35
31
  createComponent(componentType, options) {
36
32
  options = options || {
@@ -40,9 +36,10 @@ export class SkyDynamicComponentService {
40
36
  providers: options.providers || [],
41
37
  parent: __classPrivateFieldGet(this, _SkyDynamicComponentService_injector, "f"),
42
38
  });
43
- const componentRef = __classPrivateFieldGet(this, _SkyDynamicComponentService_componentFactoryResolver, "f")
44
- .resolveComponentFactory(componentType)
45
- .create(injector);
39
+ const componentRef = createComponent(componentType, {
40
+ environmentInjector: __classPrivateFieldGet(this, _SkyDynamicComponentService_applicationRef, "f").injector,
41
+ elementInjector: injector,
42
+ });
46
43
  __classPrivateFieldGet(this, _SkyDynamicComponentService_applicationRef, "f").attachView(componentRef.hostView);
47
44
  const el = __classPrivateFieldGet(this, _SkyDynamicComponentService_instances, "m", _SkyDynamicComponentService_getRootNode).call(this, componentRef);
48
45
  const bodyEl = __classPrivateFieldGet(this, _SkyDynamicComponentService_windowRef, "f").nativeWindow.document.body;
@@ -83,12 +80,12 @@ export class SkyDynamicComponentService {
83
80
  componentRef.destroy();
84
81
  }
85
82
  }
86
- _SkyDynamicComponentService_applicationRef = new WeakMap(), _SkyDynamicComponentService_componentFactoryResolver = new WeakMap(), _SkyDynamicComponentService_injector = new WeakMap(), _SkyDynamicComponentService_renderer = new WeakMap(), _SkyDynamicComponentService_windowRef = new WeakMap(), _SkyDynamicComponentService_instances = new WeakSet(), _SkyDynamicComponentService_getRootNode = function _SkyDynamicComponentService_getRootNode(componentRef) {
83
+ _SkyDynamicComponentService_applicationRef = new WeakMap(), _SkyDynamicComponentService_injector = new WeakMap(), _SkyDynamicComponentService_renderer = new WeakMap(), _SkyDynamicComponentService_windowRef = new WeakMap(), _SkyDynamicComponentService_instances = new WeakSet(), _SkyDynamicComponentService_getRootNode = function _SkyDynamicComponentService_getRootNode(componentRef) {
87
84
  // Technique for retrieving the component's root node taken from here:
88
85
  // https://malcoded.com/posts/angular-dynamic-components
89
86
  return componentRef.hostView.rootNodes[0];
90
87
  };
91
- SkyDynamicComponentService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyDynamicComponentService, deps: [{ token: i0.ComponentFactoryResolver }, { token: i0.ApplicationRef }, { token: i0.Injector }, { token: i1.SkyAppWindowRef }, { token: i0.RendererFactory2 }], target: i0.ɵɵFactoryTarget.Injectable });
88
+ SkyDynamicComponentService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyDynamicComponentService, deps: [{ token: i0.ApplicationRef }, { token: i0.Injector }, { token: i1.SkyAppWindowRef }, { token: i0.RendererFactory2 }], target: i0.ɵɵFactoryTarget.Injectable });
92
89
  SkyDynamicComponentService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyDynamicComponentService, providedIn: 'any' });
93
90
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyDynamicComponentService, decorators: [{
94
91
  type: Injectable,
@@ -98,5 +95,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
98
95
  // injector and may loose context if the component is created within a lazy-loaded module.
99
96
  providedIn: 'any',
100
97
  }]
101
- }], ctorParameters: function () { return [{ type: i0.ComponentFactoryResolver }, { type: i0.ApplicationRef }, { type: i0.Injector }, { type: i1.SkyAppWindowRef }, { type: i0.RendererFactory2 }]; } });
102
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-component.service.js","sourceRoot":"","sources":["../../../../../../../../libs/components/core/src/lib/modules/dynamic-component/dynamic-component.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ApplicationRef,\n  ComponentFactoryResolver,\n  ComponentRef,\n  EmbeddedViewRef,\n  Injectable,\n  Injector,\n  Renderer2,\n  RendererFactory2,\n  Type,\n} from '@angular/core';\n\nimport { SkyAppWindowRef } from '../window/window-ref';\n\nimport { SkyDynamicComponentLocation } from './dynamic-component-location';\nimport { SkyDynamicComponentOptions } from './dynamic-component-options';\n\n/**\n * Angular service for creating and rendering a dynamic component.\n */\n@Injectable({\n  // Must be 'any' so that the 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 loose context if the component is created within a lazy-loaded module.\n  providedIn: 'any',\n})\nexport class SkyDynamicComponentService {\n  #applicationRef: ApplicationRef;\n\n  #componentFactoryResolver: ComponentFactoryResolver;\n\n  #injector: Injector;\n\n  #renderer: Renderer2;\n\n  #windowRef: SkyAppWindowRef;\n\n  // TODO: Replace deprecated `ComponentFactoryResolver`.\n  constructor(\n    componentFactoryResolver: ComponentFactoryResolver,\n    applicationRef: ApplicationRef,\n    injector: Injector,\n    windowRef: SkyAppWindowRef,\n    rendererFactory: RendererFactory2\n  ) {\n    this.#componentFactoryResolver = componentFactoryResolver;\n    this.#applicationRef = applicationRef;\n    this.#injector = injector;\n    this.#windowRef = windowRef;\n\n    // Based on suggestions from https://github.com/angular/angular/issues/17824\n    // for accessing an instance of Renderer2 in a service since Renderer2 can't\n    // be injected into a service.  Passing undefined for both parameters results\n    // in the default renderer which is what we want here.\n    this.#renderer = rendererFactory.createRenderer(undefined, null);\n  }\n\n  /**\n   * Creates an instance of the specified component and adds it to the specified location\n   * on the page.\n   * @param options Options for creating the dynamic component.\n   */\n  public createComponent<T>(\n    componentType: Type<T>,\n    options?: SkyDynamicComponentOptions\n  ): ComponentRef<T> {\n    options = options || {\n      location: SkyDynamicComponentLocation.BodyBottom,\n    };\n\n    const injector = Injector.create({\n      providers: options.providers || [],\n      parent: this.#injector,\n    });\n\n    const componentRef = this.#componentFactoryResolver\n      .resolveComponentFactory<T>(componentType)\n      .create(injector);\n\n    this.#applicationRef.attachView(componentRef.hostView);\n\n    const el = this.#getRootNode(componentRef);\n\n    const bodyEl = this.#windowRef.nativeWindow.document.body;\n\n    switch (options.location) {\n      case SkyDynamicComponentLocation.BeforeElement:\n        if (!options.referenceEl) {\n          throw new Error(\n            '[SkyDynamicComponentService] Could not create a component at location `SkyDynamicComponentLocation.BeforeElement` because a reference element was not provided.'\n          );\n        }\n\n        this.#renderer.insertBefore(\n          options.referenceEl.parentElement,\n          el,\n          options.referenceEl\n        );\n        break;\n      case SkyDynamicComponentLocation.ElementTop:\n        if (!options.referenceEl) {\n          throw new Error(\n            '[SkyDynamicComponentService] Could not create a component at location `SkyDynamicComponentLocation.ElementTop` because a reference element was not provided.'\n          );\n        }\n\n        this.#renderer.insertBefore(\n          options.referenceEl,\n          el,\n          options.referenceEl.firstChild\n        );\n        break;\n      case SkyDynamicComponentLocation.ElementBottom:\n        this.#renderer.appendChild(options.referenceEl, el);\n        break;\n      case SkyDynamicComponentLocation.BodyTop:\n        this.#renderer.insertBefore(bodyEl, el, bodyEl.firstChild);\n        break;\n      default:\n        this.#renderer.appendChild(bodyEl, el);\n        break;\n    }\n\n    return componentRef;\n  }\n\n  /**\n   * Removes a component ref from the page\n   * @param componentRef Component ref for the component being removed\n   */\n  public removeComponent<T>(componentRef: ComponentRef<T> | undefined): void {\n    if (!componentRef) {\n      return;\n    }\n\n    this.#applicationRef.detachView(componentRef.hostView);\n    componentRef.destroy();\n  }\n\n  #getRootNode<T>(componentRef: ComponentRef<T>): any {\n    // Technique for retrieving the component's root node taken from here:\n    // https://malcoded.com/posts/angular-dynamic-components\n    return (componentRef.hostView as EmbeddedViewRef<T>).rootNodes[0];\n  }\n}\n"]}
98
+ }], ctorParameters: function () { return [{ type: i0.ApplicationRef }, { type: i0.Injector }, { type: i1.SkyAppWindowRef }, { type: i0.RendererFactory2 }]; } });
99
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-component.service.js","sourceRoot":"","sources":["../../../../../../../../libs/components/core/src/lib/modules/dynamic-component/dynamic-component.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ApplicationRef,\n  ComponentRef,\n  EmbeddedViewRef,\n  Injectable,\n  Injector,\n  Renderer2,\n  RendererFactory2,\n  Type,\n  createComponent,\n} from '@angular/core';\n\nimport { SkyAppWindowRef } from '../window/window-ref';\n\nimport { SkyDynamicComponentLocation } from './dynamic-component-location';\nimport { SkyDynamicComponentOptions } from './dynamic-component-options';\n\n/**\n * Angular service for creating and rendering a dynamic component.\n */\n@Injectable({\n  // Must be 'any' so that the 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 loose context if the component is created within a lazy-loaded module.\n  providedIn: 'any',\n})\nexport class SkyDynamicComponentService {\n  #applicationRef: ApplicationRef;\n\n  #injector: Injector;\n\n  #renderer: Renderer2;\n\n  #windowRef: SkyAppWindowRef;\n\n  constructor(\n    applicationRef: ApplicationRef,\n    injector: Injector,\n    windowRef: SkyAppWindowRef,\n    rendererFactory: RendererFactory2\n  ) {\n    this.#applicationRef = applicationRef;\n    this.#injector = injector;\n    this.#windowRef = windowRef;\n\n    // Based on suggestions from https://github.com/angular/angular/issues/17824\n    // for accessing an instance of Renderer2 in a service since Renderer2 can't\n    // be injected into a service.  Passing undefined for both parameters results\n    // in the default renderer which is what we want here.\n    this.#renderer = rendererFactory.createRenderer(undefined, null);\n  }\n\n  /**\n   * Creates an instance of the specified component and adds it to the specified location\n   * on the page.\n   */\n  public createComponent<T>(\n    componentType: Type<T>,\n    options?: SkyDynamicComponentOptions\n  ): ComponentRef<T> {\n    options = options || {\n      location: SkyDynamicComponentLocation.BodyBottom,\n    };\n\n    const injector = Injector.create({\n      providers: options.providers || [],\n      parent: this.#injector,\n    });\n\n    const componentRef = createComponent<T>(componentType, {\n      environmentInjector: this.#applicationRef.injector,\n      elementInjector: injector,\n    });\n\n    this.#applicationRef.attachView(componentRef.hostView);\n\n    const el = this.#getRootNode(componentRef);\n\n    const bodyEl = this.#windowRef.nativeWindow.document.body;\n\n    switch (options.location) {\n      case SkyDynamicComponentLocation.BeforeElement:\n        if (!options.referenceEl) {\n          throw new Error(\n            '[SkyDynamicComponentService] Could not create a component at location `SkyDynamicComponentLocation.BeforeElement` because a reference element was not provided.'\n          );\n        }\n\n        this.#renderer.insertBefore(\n          options.referenceEl.parentElement,\n          el,\n          options.referenceEl\n        );\n        break;\n      case SkyDynamicComponentLocation.ElementTop:\n        if (!options.referenceEl) {\n          throw new Error(\n            '[SkyDynamicComponentService] Could not create a component at location `SkyDynamicComponentLocation.ElementTop` because a reference element was not provided.'\n          );\n        }\n\n        this.#renderer.insertBefore(\n          options.referenceEl,\n          el,\n          options.referenceEl.firstChild\n        );\n        break;\n      case SkyDynamicComponentLocation.ElementBottom:\n        this.#renderer.appendChild(options.referenceEl, el);\n        break;\n      case SkyDynamicComponentLocation.BodyTop:\n        this.#renderer.insertBefore(bodyEl, el, bodyEl.firstChild);\n        break;\n      default:\n        this.#renderer.appendChild(bodyEl, el);\n        break;\n    }\n\n    return componentRef;\n  }\n\n  /**\n   * Removes a component ref from the page\n   * @param componentRef Component ref for the component being removed\n   */\n  public removeComponent<T>(componentRef: ComponentRef<T> | undefined): void {\n    if (!componentRef) {\n      return;\n    }\n\n    this.#applicationRef.detachView(componentRef.hostView);\n    componentRef.destroy();\n  }\n\n  #getRootNode<T>(componentRef: ComponentRef<T>): any {\n    // Technique for retrieving the component's root node taken from here:\n    // https://malcoded.com/posts/angular-dynamic-components\n    return (componentRef.hostView as EmbeddedViewRef<T>).rootNodes[0];\n  }\n}\n"]}
@@ -1,6 +1,6 @@
1
- var _SkyOverlayComponent_instances, _SkyOverlayComponent_backdropClick, _SkyOverlayComponent_backdropClickObs, _SkyOverlayComponent_changeDetector, _SkyOverlayComponent_closed, _SkyOverlayComponent_closedObs, _SkyOverlayComponent_context, _SkyOverlayComponent_coreAdapter, _SkyOverlayComponent_injector, _SkyOverlayComponent_ngUnsubscribe, _SkyOverlayComponent_resolver, _SkyOverlayComponent_router, _SkyOverlayComponent_routerSubscription, _SkyOverlayComponent_applyConfig, _SkyOverlayComponent_addBackdropClickListener, _SkyOverlayComponent_addRouteListener, _SkyOverlayComponent_removeRouteListener;
1
+ var _SkyOverlayComponent_instances, _SkyOverlayComponent_backdropClick, _SkyOverlayComponent_backdropClickObs, _SkyOverlayComponent_changeDetector, _SkyOverlayComponent_closed, _SkyOverlayComponent_closedObs, _SkyOverlayComponent_context, _SkyOverlayComponent_coreAdapter, _SkyOverlayComponent_injector, _SkyOverlayComponent_ngUnsubscribe, _SkyOverlayComponent_router, _SkyOverlayComponent_routerSubscription, _SkyOverlayComponent_applyConfig, _SkyOverlayComponent_addBackdropClickListener, _SkyOverlayComponent_addRouteListener, _SkyOverlayComponent_removeRouteListener;
2
2
  import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
3
- import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ComponentFactoryResolver, ElementRef, HostBinding, Injector, Optional, ViewChild, ViewContainerRef, } from '@angular/core';
3
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, HostBinding, Injector, Optional, ViewChild, ViewContainerRef, } from '@angular/core';
4
4
  import { NavigationStart, Router } from '@angular/router';
5
5
  import { Subject, fromEvent } from 'rxjs';
6
6
  import { takeUntil } from 'rxjs/operators';
@@ -31,8 +31,7 @@ let uniqueZIndex = 5000;
31
31
  * @internal
32
32
  */
33
33
  export class SkyOverlayComponent {
34
- // TODO: Replace deprecated `ComponentFactoryResolver`.
35
- constructor(changeDetector, resolver, injector, coreAdapter, context, idSvc, router) {
34
+ constructor(changeDetector, injector, coreAdapter, context, idSvc, router) {
36
35
  _SkyOverlayComponent_instances.add(this);
37
36
  this.wrapperClass = '';
38
37
  this.enablePointerEvents = false;
@@ -47,11 +46,9 @@ export class SkyOverlayComponent {
47
46
  _SkyOverlayComponent_coreAdapter.set(this, void 0);
48
47
  _SkyOverlayComponent_injector.set(this, void 0);
49
48
  _SkyOverlayComponent_ngUnsubscribe.set(this, new Subject());
50
- _SkyOverlayComponent_resolver.set(this, void 0);
51
49
  _SkyOverlayComponent_router.set(this, void 0);
52
50
  _SkyOverlayComponent_routerSubscription.set(this, void 0);
53
51
  __classPrivateFieldSet(this, _SkyOverlayComponent_changeDetector, changeDetector, "f");
54
- __classPrivateFieldSet(this, _SkyOverlayComponent_resolver, resolver, "f");
55
52
  __classPrivateFieldSet(this, _SkyOverlayComponent_injector, injector, "f");
56
53
  __classPrivateFieldSet(this, _SkyOverlayComponent_coreAdapter, coreAdapter, "f");
57
54
  __classPrivateFieldSet(this, _SkyOverlayComponent_context, context, "f");
@@ -91,12 +88,13 @@ export class SkyOverlayComponent {
91
88
  throw new Error('[SkyOverlayComponent] Could not attach the component because the target element could not be found.');
92
89
  }
93
90
  this.targetRef.clear();
94
- const factory = __classPrivateFieldGet(this, _SkyOverlayComponent_resolver, "f").resolveComponentFactory(component);
95
91
  const injector = Injector.create({
96
92
  providers,
97
93
  parent: __classPrivateFieldGet(this, _SkyOverlayComponent_injector, "f"),
98
94
  });
99
- const componentRef = this.targetRef.createComponent(factory, undefined, injector);
95
+ const componentRef = this.targetRef.createComponent(component, {
96
+ injector,
97
+ });
100
98
  // Run an initial change detection cycle after the component has been created.
101
99
  componentRef.changeDetectorRef.detectChanges();
102
100
  return componentRef;
@@ -110,7 +108,7 @@ export class SkyOverlayComponent {
110
108
  return this.targetRef.createEmbeddedView(templateRef, context);
111
109
  }
112
110
  }
113
- _SkyOverlayComponent_backdropClick = new WeakMap(), _SkyOverlayComponent_backdropClickObs = new WeakMap(), _SkyOverlayComponent_changeDetector = new WeakMap(), _SkyOverlayComponent_closed = new WeakMap(), _SkyOverlayComponent_closedObs = new WeakMap(), _SkyOverlayComponent_context = new WeakMap(), _SkyOverlayComponent_coreAdapter = new WeakMap(), _SkyOverlayComponent_injector = new WeakMap(), _SkyOverlayComponent_ngUnsubscribe = new WeakMap(), _SkyOverlayComponent_resolver = new WeakMap(), _SkyOverlayComponent_router = new WeakMap(), _SkyOverlayComponent_routerSubscription = new WeakMap(), _SkyOverlayComponent_instances = new WeakSet(), _SkyOverlayComponent_applyConfig = function _SkyOverlayComponent_applyConfig(config) {
111
+ _SkyOverlayComponent_backdropClick = new WeakMap(), _SkyOverlayComponent_backdropClickObs = new WeakMap(), _SkyOverlayComponent_changeDetector = new WeakMap(), _SkyOverlayComponent_closed = new WeakMap(), _SkyOverlayComponent_closedObs = new WeakMap(), _SkyOverlayComponent_context = new WeakMap(), _SkyOverlayComponent_coreAdapter = new WeakMap(), _SkyOverlayComponent_injector = new WeakMap(), _SkyOverlayComponent_ngUnsubscribe = new WeakMap(), _SkyOverlayComponent_router = new WeakMap(), _SkyOverlayComponent_routerSubscription = new WeakMap(), _SkyOverlayComponent_instances = new WeakSet(), _SkyOverlayComponent_applyConfig = function _SkyOverlayComponent_applyConfig(config) {
114
112
  this.wrapperClass = config.wrapperClass || '';
115
113
  this.showBackdrop = !!config.showBackdrop;
116
114
  this.enablePointerEvents = !!config.enablePointerEvents;
@@ -147,12 +145,12 @@ _SkyOverlayComponent_backdropClick = new WeakMap(), _SkyOverlayComponent_backdro
147
145
  __classPrivateFieldSet(this, _SkyOverlayComponent_routerSubscription, undefined, "f");
148
146
  }
149
147
  };
150
- SkyOverlayComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyOverlayComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.ComponentFactoryResolver }, { token: i0.Injector }, { token: i1.SkyCoreAdapterService }, { token: i2.SkyOverlayContext }, { token: i3.SkyIdService }, { token: i4.Router, optional: true }], target: i0.ɵɵFactoryTarget.Component });
148
+ SkyOverlayComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyOverlayComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.Injector }, { token: i1.SkyCoreAdapterService }, { token: i2.SkyOverlayContext }, { token: i3.SkyIdService }, { token: i4.Router, optional: true }], target: i0.ɵɵFactoryTarget.Component });
151
149
  SkyOverlayComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: SkyOverlayComponent, selector: "sky-overlay", host: { properties: { "id": "this.id" } }, viewQueries: [{ propertyName: "overlayContentRef", first: true, predicate: ["overlayContentRef"], descendants: true, read: ElementRef, static: true }, { propertyName: "overlayRef", first: true, predicate: ["overlayRef"], descendants: true, read: ElementRef, static: true }, { propertyName: "targetRef", first: true, predicate: ["target"], descendants: true, read: ViewContainerRef, static: true }], ngImport: i0, template: "<div\n [class]=\"wrapperClass\"\n [style.zIndex]=\"zIndex\"\n [ngClass]=\"{\n 'enable-pointer-events-pass-through': enablePointerEvents,\n 'sky-overlay': true\n }\"\n #overlayRef\n>\n <div class=\"sky-overlay-content\" #overlayContentRef>\n <ng-template #target> </ng-template>\n </div>\n <div *ngIf=\"showBackdrop\" class=\"sky-overlay-backdrop\"></div>\n</div>\n", styles: [".sky-overlay{position:fixed;inset:0;width:100%;height:100%;display:flex;pointer-events:auto}.sky-overlay-content{position:relative;z-index:1;display:inline-flex;align-self:start;pointer-events:auto}.sky-overlay-backdrop{background:rgba(0,0,0,.5);inset:0;width:100%;height:100%;position:absolute}.enable-pointer-events-pass-through,.enable-pointer-events-pass-through .sky-overlay-backdrop{pointer-events:none}.enable-pointer-events-pass-through .sky-overlay-content{pointer-events:auto}\n"], dependencies: [{ kind: "directive", type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
152
150
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyOverlayComponent, decorators: [{
153
151
  type: Component,
154
152
  args: [{ selector: 'sky-overlay', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n [class]=\"wrapperClass\"\n [style.zIndex]=\"zIndex\"\n [ngClass]=\"{\n 'enable-pointer-events-pass-through': enablePointerEvents,\n 'sky-overlay': true\n }\"\n #overlayRef\n>\n <div class=\"sky-overlay-content\" #overlayContentRef>\n <ng-template #target> </ng-template>\n </div>\n <div *ngIf=\"showBackdrop\" class=\"sky-overlay-backdrop\"></div>\n</div>\n", styles: [".sky-overlay{position:fixed;inset:0;width:100%;height:100%;display:flex;pointer-events:auto}.sky-overlay-content{position:relative;z-index:1;display:inline-flex;align-self:start;pointer-events:auto}.sky-overlay-backdrop{background:rgba(0,0,0,.5);inset:0;width:100%;height:100%;position:absolute}.enable-pointer-events-pass-through,.enable-pointer-events-pass-through .sky-overlay-backdrop{pointer-events:none}.enable-pointer-events-pass-through .sky-overlay-content{pointer-events:auto}\n"] }]
155
- }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i0.ComponentFactoryResolver }, { type: i0.Injector }, { type: i1.SkyCoreAdapterService }, { type: i2.SkyOverlayContext }, { type: i3.SkyIdService }, { type: i4.Router, decorators: [{
153
+ }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i0.Injector }, { type: i1.SkyCoreAdapterService }, { type: i2.SkyOverlayContext }, { type: i3.SkyIdService }, { type: i4.Router, decorators: [{
156
154
  type: Optional
157
155
  }] }]; }, propDecorators: { id: [{
158
156
  type: HostBinding,
@@ -176,4 +174,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
176
174
  static: true,
177
175
  }]
178
176
  }] } });
179
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"overlay.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/core/src/lib/modules/overlay/overlay.component.ts","../../../../../../../../libs/components/core/src/lib/modules/overlay/overlay.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ComponentFactoryResolver,\n  ComponentRef,\n  ElementRef,\n  EmbeddedViewRef,\n  HostBinding,\n  Injector,\n  OnDestroy,\n  OnInit,\n  Optional,\n  StaticProvider,\n  TemplateRef,\n  Type,\n  ViewChild,\n  ViewContainerRef,\n} from '@angular/core';\nimport { NavigationStart, Router } from '@angular/router';\n\nimport { Observable, Subject, Subscription, fromEvent } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyCoreAdapterService } from '../adapter-service/adapter.service';\nimport { SkyIdService } from '../id/id.service';\n\nimport { SkyOverlayConfig } from './overlay-config';\nimport { SkyOverlayContext } from './overlay-context';\n\n/**\n * Omnibar is 1000.\n * See: https://github.com/blackbaud/auth-client/blob/master/src/omnibar/omnibar.ts#L139\n * ---\n * Modals start their z-indexes at 1040. However, each modal's z-index is a multiple of 10, so it\n * will be difficult to reliably predict a z-index that will always appear above all other\n * layers. Starting the z-index for overlays at a number much greater than modals will accommodate\n * the most reasonable of scenarios.\n * See: https://github.com/blackbaud/skyux-modals/blob/master/src/app/public/modules/modal/modal-host.service.ts#L22\n * (NOTE: It should be noted that modals do not use the overlay service, which is something we\n * should do in the near future to make sure z-indexes are predictable across all component\n * libraries.)\n */\nlet uniqueZIndex = 5000;\n\n/**\n * @internal\n */\n@Component({\n  selector: 'sky-overlay',\n  templateUrl: './overlay.component.html',\n  styleUrls: ['./overlay.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class SkyOverlayComponent implements OnInit, OnDestroy {\n  public wrapperClass = '';\n\n  public get backdropClick(): Observable<void> {\n    return this.#backdropClickObs;\n  }\n\n  public get closed(): Observable<void> {\n    return this.#closedObs;\n  }\n\n  public enablePointerEvents = false;\n\n  @HostBinding('id')\n  public id: string;\n\n  public showBackdrop = false;\n\n  public zIndex = `${++uniqueZIndex}`;\n\n  @ViewChild('overlayContentRef', {\n    read: ElementRef,\n    static: true,\n  })\n  private overlayContentRef: ElementRef | undefined;\n\n  @ViewChild('overlayRef', {\n    read: ElementRef,\n    static: true,\n  })\n  private overlayRef: ElementRef | undefined;\n\n  @ViewChild('target', {\n    read: ViewContainerRef,\n    static: true,\n  })\n  private targetRef: ViewContainerRef | undefined;\n\n  #backdropClick: Subject<void>;\n\n  #backdropClickObs: Observable<void>;\n\n  #changeDetector: ChangeDetectorRef;\n\n  #closed: Subject<void>;\n\n  #closedObs: Observable<void>;\n\n  #context: SkyOverlayContext;\n\n  #coreAdapter: SkyCoreAdapterService;\n\n  #injector: Injector;\n\n  #ngUnsubscribe = new Subject<void>();\n\n  #resolver: ComponentFactoryResolver;\n\n  #router: Router | undefined;\n\n  #routerSubscription: Subscription | undefined;\n\n  // TODO: Replace deprecated `ComponentFactoryResolver`.\n  constructor(\n    changeDetector: ChangeDetectorRef,\n    resolver: ComponentFactoryResolver,\n    injector: Injector,\n    coreAdapter: SkyCoreAdapterService,\n    context: SkyOverlayContext,\n    idSvc: SkyIdService,\n    @Optional() router?: Router\n  ) {\n    this.#changeDetector = changeDetector;\n    this.#resolver = resolver;\n    this.#injector = injector;\n    this.#coreAdapter = coreAdapter;\n    this.#context = context;\n    this.#router = router;\n\n    this.id = idSvc.generateId();\n\n    this.#backdropClick = new Subject<void>();\n    this.#closed = new Subject<void>();\n\n    this.#backdropClickObs = this.#backdropClick.asObservable();\n    this.#closedObs = this.#closed.asObservable();\n  }\n\n  public ngOnInit(): void {\n    this.#applyConfig(this.#context.config);\n\n    setTimeout(() => {\n      this.#addBackdropClickListener();\n    });\n\n    if (this.#context.config.closeOnNavigation) {\n      this.#addRouteListener();\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this.#removeRouteListener();\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n\n    this.#backdropClick.complete();\n\n    this.#closed.next();\n    this.#closed.complete();\n  }\n\n  public attachComponent<C>(\n    component: Type<C>,\n    providers: StaticProvider[] = []\n  ): ComponentRef<C> {\n    /*istanbul ignore if: untestable*/\n    if (!this.targetRef) {\n      throw new Error(\n        '[SkyOverlayComponent] Could not attach the component because the target element could not be found.'\n      );\n    }\n\n    this.targetRef.clear();\n\n    const factory = this.#resolver.resolveComponentFactory(component);\n    const injector = Injector.create({\n      providers,\n      parent: this.#injector,\n    });\n\n    const componentRef = this.targetRef.createComponent<C>(\n      factory,\n      undefined,\n      injector\n    );\n\n    // Run an initial change detection cycle after the component has been created.\n    componentRef.changeDetectorRef.detectChanges();\n\n    return componentRef;\n  }\n\n  public attachTemplate<T>(\n    templateRef: TemplateRef<T>,\n    context: T\n  ): EmbeddedViewRef<T> {\n    /*istanbul ignore if: untestable*/\n    if (!this.targetRef) {\n      throw new Error(\n        '[SkyOverlayComponent] Could not attach the template because the target element could not be found.'\n      );\n    }\n\n    this.targetRef.clear();\n\n    return this.targetRef.createEmbeddedView(templateRef, context);\n  }\n\n  #applyConfig(config: SkyOverlayConfig): void {\n    this.wrapperClass = config.wrapperClass || '';\n    this.showBackdrop = !!config.showBackdrop;\n    this.enablePointerEvents = !!config.enablePointerEvents;\n    this.#changeDetector.markForCheck();\n  }\n\n  #addBackdropClickListener(): void {\n    fromEvent<MouseEvent>(window.document, 'click')\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((event) => {\n        if (event.target && this.overlayContentRef && this.overlayRef) {\n          const isChild = this.overlayContentRef.nativeElement.contains(\n            event.target\n          );\n\n          const isAbove = this.#coreAdapter.isTargetAboveElement(\n            event.target,\n            this.overlayRef.nativeElement\n          );\n\n          /* istanbul ignore else */\n          if (!isChild && !isAbove) {\n            this.#backdropClick.next();\n            if (this.#context.config.enableClose) {\n              this.#closed.next();\n            }\n          }\n        }\n      });\n  }\n\n  #addRouteListener(): void {\n    /*istanbul ignore else*/\n    if (this.#router) {\n      this.#routerSubscription = this.#router.events.subscribe((event) => {\n        /* istanbul ignore else */\n        if (event instanceof NavigationStart) {\n          this.#closed.next();\n        }\n      });\n    }\n  }\n\n  #removeRouteListener(): void {\n    if (this.#routerSubscription) {\n      this.#routerSubscription.unsubscribe();\n      this.#routerSubscription = undefined;\n    }\n  }\n}\n","<div\n  [class]=\"wrapperClass\"\n  [style.zIndex]=\"zIndex\"\n  [ngClass]=\"{\n    'enable-pointer-events-pass-through': enablePointerEvents,\n    'sky-overlay': true\n  }\"\n  #overlayRef\n>\n  <div class=\"sky-overlay-content\" #overlayContentRef>\n    <ng-template #target> </ng-template>\n  </div>\n  <div *ngIf=\"showBackdrop\" class=\"sky-overlay-backdrop\"></div>\n</div>\n"]}
177
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"overlay.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/core/src/lib/modules/overlay/overlay.component.ts","../../../../../../../../libs/components/core/src/lib/modules/overlay/overlay.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ComponentRef,\n  ElementRef,\n  EmbeddedViewRef,\n  HostBinding,\n  Injector,\n  OnDestroy,\n  OnInit,\n  Optional,\n  StaticProvider,\n  TemplateRef,\n  Type,\n  ViewChild,\n  ViewContainerRef,\n} from '@angular/core';\nimport { NavigationStart, Router } from '@angular/router';\n\nimport { Observable, Subject, Subscription, fromEvent } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyCoreAdapterService } from '../adapter-service/adapter.service';\nimport { SkyIdService } from '../id/id.service';\n\nimport { SkyOverlayConfig } from './overlay-config';\nimport { SkyOverlayContext } from './overlay-context';\n\n/**\n * Omnibar is 1000.\n * See: https://github.com/blackbaud/auth-client/blob/master/src/omnibar/omnibar.ts#L139\n * ---\n * Modals start their z-indexes at 1040. However, each modal's z-index is a multiple of 10, so it\n * will be difficult to reliably predict a z-index that will always appear above all other\n * layers. Starting the z-index for overlays at a number much greater than modals will accommodate\n * the most reasonable of scenarios.\n * See: https://github.com/blackbaud/skyux-modals/blob/master/src/app/public/modules/modal/modal-host.service.ts#L22\n * (NOTE: It should be noted that modals do not use the overlay service, which is something we\n * should do in the near future to make sure z-indexes are predictable across all component\n * libraries.)\n */\nlet uniqueZIndex = 5000;\n\n/**\n * @internal\n */\n@Component({\n  selector: 'sky-overlay',\n  templateUrl: './overlay.component.html',\n  styleUrls: ['./overlay.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class SkyOverlayComponent implements OnInit, OnDestroy {\n  public wrapperClass = '';\n\n  public get backdropClick(): Observable<void> {\n    return this.#backdropClickObs;\n  }\n\n  public get closed(): Observable<void> {\n    return this.#closedObs;\n  }\n\n  public enablePointerEvents = false;\n\n  @HostBinding('id')\n  public id: string;\n\n  public showBackdrop = false;\n\n  public zIndex = `${++uniqueZIndex}`;\n\n  @ViewChild('overlayContentRef', {\n    read: ElementRef,\n    static: true,\n  })\n  private overlayContentRef: ElementRef | undefined;\n\n  @ViewChild('overlayRef', {\n    read: ElementRef,\n    static: true,\n  })\n  private overlayRef: ElementRef | undefined;\n\n  @ViewChild('target', {\n    read: ViewContainerRef,\n    static: true,\n  })\n  private targetRef: ViewContainerRef | undefined;\n\n  #backdropClick: Subject<void>;\n\n  #backdropClickObs: Observable<void>;\n\n  #changeDetector: ChangeDetectorRef;\n\n  #closed: Subject<void>;\n\n  #closedObs: Observable<void>;\n\n  #context: SkyOverlayContext;\n\n  #coreAdapter: SkyCoreAdapterService;\n\n  #injector: Injector;\n\n  #ngUnsubscribe = new Subject<void>();\n\n  #router: Router | undefined;\n\n  #routerSubscription: Subscription | undefined;\n\n  constructor(\n    changeDetector: ChangeDetectorRef,\n    injector: Injector,\n    coreAdapter: SkyCoreAdapterService,\n    context: SkyOverlayContext,\n    idSvc: SkyIdService,\n    @Optional() router?: Router\n  ) {\n    this.#changeDetector = changeDetector;\n    this.#injector = injector;\n    this.#coreAdapter = coreAdapter;\n    this.#context = context;\n    this.#router = router;\n\n    this.id = idSvc.generateId();\n\n    this.#backdropClick = new Subject<void>();\n    this.#closed = new Subject<void>();\n\n    this.#backdropClickObs = this.#backdropClick.asObservable();\n    this.#closedObs = this.#closed.asObservable();\n  }\n\n  public ngOnInit(): void {\n    this.#applyConfig(this.#context.config);\n\n    setTimeout(() => {\n      this.#addBackdropClickListener();\n    });\n\n    if (this.#context.config.closeOnNavigation) {\n      this.#addRouteListener();\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this.#removeRouteListener();\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n\n    this.#backdropClick.complete();\n\n    this.#closed.next();\n    this.#closed.complete();\n  }\n\n  public attachComponent<C>(\n    component: Type<C>,\n    providers: StaticProvider[] = []\n  ): ComponentRef<C> {\n    /*istanbul ignore if: untestable*/\n    if (!this.targetRef) {\n      throw new Error(\n        '[SkyOverlayComponent] Could not attach the component because the target element could not be found.'\n      );\n    }\n\n    this.targetRef.clear();\n\n    const injector = Injector.create({\n      providers,\n      parent: this.#injector,\n    });\n\n    const componentRef = this.targetRef.createComponent<C>(component, {\n      injector,\n    });\n\n    // Run an initial change detection cycle after the component has been created.\n    componentRef.changeDetectorRef.detectChanges();\n\n    return componentRef;\n  }\n\n  public attachTemplate<T>(\n    templateRef: TemplateRef<T>,\n    context: T\n  ): EmbeddedViewRef<T> {\n    /*istanbul ignore if: untestable*/\n    if (!this.targetRef) {\n      throw new Error(\n        '[SkyOverlayComponent] Could not attach the template because the target element could not be found.'\n      );\n    }\n\n    this.targetRef.clear();\n\n    return this.targetRef.createEmbeddedView(templateRef, context);\n  }\n\n  #applyConfig(config: SkyOverlayConfig): void {\n    this.wrapperClass = config.wrapperClass || '';\n    this.showBackdrop = !!config.showBackdrop;\n    this.enablePointerEvents = !!config.enablePointerEvents;\n    this.#changeDetector.markForCheck();\n  }\n\n  #addBackdropClickListener(): void {\n    fromEvent<MouseEvent>(window.document, 'click')\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((event) => {\n        if (event.target && this.overlayContentRef && this.overlayRef) {\n          const isChild = this.overlayContentRef.nativeElement.contains(\n            event.target\n          );\n\n          const isAbove = this.#coreAdapter.isTargetAboveElement(\n            event.target,\n            this.overlayRef.nativeElement\n          );\n\n          /* istanbul ignore else */\n          if (!isChild && !isAbove) {\n            this.#backdropClick.next();\n            if (this.#context.config.enableClose) {\n              this.#closed.next();\n            }\n          }\n        }\n      });\n  }\n\n  #addRouteListener(): void {\n    /*istanbul ignore else*/\n    if (this.#router) {\n      this.#routerSubscription = this.#router.events.subscribe((event) => {\n        /* istanbul ignore else */\n        if (event instanceof NavigationStart) {\n          this.#closed.next();\n        }\n      });\n    }\n  }\n\n  #removeRouteListener(): void {\n    if (this.#routerSubscription) {\n      this.#routerSubscription.unsubscribe();\n      this.#routerSubscription = undefined;\n    }\n  }\n}\n","<div\n  [class]=\"wrapperClass\"\n  [style.zIndex]=\"zIndex\"\n  [ngClass]=\"{\n    'enable-pointer-events-pass-through': enablePointerEvents,\n    'sky-overlay': true\n  }\"\n  #overlayRef\n>\n  <div class=\"sky-overlay-content\" #overlayContentRef>\n    <ng-template #target> </ng-template>\n  </div>\n  <div *ngIf=\"showBackdrop\" class=\"sky-overlay-backdrop\"></div>\n</div>\n"]}