@skyux/core 11.37.0 → 11.38.1

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.
@@ -58,7 +58,7 @@ export class SkyDockDomAdapterService {
58
58
  }
59
59
  // Create a style element to avoid overwriting any existing inline body styles.
60
60
  const styleElement = this.#renderer.createElement('style');
61
- const textNode = this.#renderer.createText(`body { margin-bottom: ${dockHeight}px; }`);
61
+ const textNode = this.#renderer.createText(`body { margin-bottom: ${dockHeight}px; --sky-dock-height: ${dockHeight}px; }`);
62
62
  // Apply a `data-` attribute to make unit testing easier.
63
63
  this.#renderer.setAttribute(styleElement, 'data-test-selector', 'sky-layout-dock-bottom-styles');
64
64
  this.#renderer.appendChild(styleElement, textNode);
@@ -78,4 +78,4 @@ export class SkyDockDomAdapterService {
78
78
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SkyDockDomAdapterService, decorators: [{
79
79
  type: Injectable
80
80
  }], ctorParameters: () => [{ type: i1.SkyMutationObserverService }, { type: i0.RendererFactory2 }] });
81
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG9jay1kb20tYWRhcHRlci5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL2NvcmUvc3JjL2xpYi9tb2R1bGVzL2RvY2svZG9jay1kb20tYWRhcHRlci5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFFTCxVQUFVLEdBSVgsTUFBTSxlQUFlLENBQUM7QUFFdkIsT0FBTyxFQUFFLE9BQU8sRUFBRSxTQUFTLElBQUksbUJBQW1CLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDakUsT0FBTyxFQUFFLFlBQVksRUFBRSxTQUFTLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7O0FBSXpEOztHQUVHO0FBRUgsTUFBTSxPQUFPLHdCQUF3QjtJQUNuQyxrQkFBa0IsQ0FBcUI7SUFFdkMsWUFBWSxDQUE2QjtJQUV6QyxjQUFjLEdBQUcsSUFBSSxPQUFPLEVBQVEsQ0FBQztJQUVyQyxTQUFTLENBQStCO0lBRXhDLFNBQVMsQ0FBWTtJQUVyQixhQUFhLENBQStCO0lBRTVDLFlBQ0UsV0FBdUMsRUFDdkMsZUFBaUM7UUFFakMsSUFBSSxDQUFDLFlBQVksR0FBRyxXQUFXLENBQUM7UUFDaEMsSUFBSSxDQUFDLFNBQVMsR0FBRyxlQUFlLENBQUMsY0FBYyxDQUFDLFNBQVMsRUFBRSxJQUFJLENBQUMsQ0FBQztJQUNuRSxDQUFDO0lBRU0sV0FBVztRQUNoQixJQUFJLElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQztZQUNuQixJQUFJLENBQUMsU0FBUyxDQUFDLFVBQVUsRUFBRSxDQUFDO1FBQzlCLENBQUM7UUFDRCxJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksRUFBRSxDQUFDO1FBQzNCLElBQUksQ0FBQyxjQUFjLENBQUMsUUFBUSxFQUFFLENBQUM7UUFFL0IsSUFBSSxJQUFJLENBQUMsYUFBYSxFQUFFLENBQUM7WUFDdkIsSUFBSSxDQUFDLG9CQUFvQixFQUFF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Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgRWxlbWVudFJlZixcbiAgSW5qZWN0YWJsZSxcbiAgT25EZXN0cm95LFxuICBSZW5kZXJlcjIsXG4gIFJlbmRlcmVyRmFjdG9yeTIsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBTdWJqZWN0LCBmcm9tRXZlbnQgYXMgb2JzZXJ2YWJsZUZyb21FdmVudCB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgZGVib3VuY2VUaW1lLCB0YWtlVW50aWwgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5cbmltcG9ydCB7IFNreU11dGF0aW9uT2JzZXJ2ZXJTZXJ2aWNlIH0gZnJvbSAnLi4vbXV0YXRpb24vbXV0YXRpb24tb2JzZXJ2ZXItc2VydmljZSc7XG5cbi8qKlxuICogQGludGVybmFsXG4gKi9cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBTa3lEb2NrRG9tQWRhcHRlclNlcnZpY2UgaW1wbGVtZW50cyBPbkRlc3Ryb3kge1xuICAjY3VycmVudERvY2tIZWlnaHQ6IG51bWJlciB8IHVuZGVmaW5lZDtcblxuICAjbXV0YXRpb25TdmM6IFNreU11dGF0aW9uT2JzZXJ2ZXJTZXJ2aWNlO1xuXG4gICNuZ1Vuc3Vic2NyaWJlID0gbmV3IFN1YmplY3Q8dm9pZD4oKTtcblxuICAjb2JzZXJ2ZXI6IE11dGF0aW9uT2JzZXJ2ZXIgfCB1bmRlZmluZWQ7XG5cbiAgI3JlbmRlcmVyOiBSZW5kZXJlcjI7XG5cbiAgI3N0eWxlRWxlbWVudDogSFRNTFN0eWxlRWxlbWVudCB8IHVuZGVmaW5lZDtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBtdXRhdGlvblN2YzogU2t5TXV0YXRpb25PYnNlcnZlclNlcnZpY2UsXG4gICAgcmVuZGVyZXJGYWN0b3J5OiBSZW5kZXJlckZhY3RvcnkyLFxuICApIHtcbiAgICB0aGlzLiNtdXRhdGlvblN2YyA9IG11dGF0aW9uU3ZjO1xuICAgIHRoaXMuI3JlbmRlcmVyID0gcmVuZGVyZXJGYWN0b3J5LmNyZWF0ZVJlbmRlcmVyKHVuZGVmaW5lZCwgbnVsbCk7XG4gIH1cblxuICBwdWJsaWMgbmdPbkRlc3Ryb3koKTogdm9pZCB7XG4gICAgaWYgKHRoaXMuI29ic2VydmVyKSB7XG4gICAgICB0aGlzLiNvYnNlcnZlci5kaXNjb25uZWN0KCk7XG4gICAgfVxuICAgIHRoaXMuI25nVW5zdWJzY3JpYmUubmV4dCgpO1xuICAgIHRoaXMuI25nVW5zdWJzY3JpYmUuY29tcGxldGUoKTtcblxuICAgIGlmICh0aGlzLiNzdHlsZUVsZW1lbnQpIHtcbiAgICAgIHRoaXMuI2Rlc3Ryb3lTdHlsZUVsZW1lbnQoKTtcbiAgICB9XG5cbiAgICB0aGlzLiNjdXJyZW50RG9ja0hlaWdodCA9IHRoaXMuI29ic2VydmVyID0gdGhpcy4jc3R5bGVFbGVtZW50ID0gdW5kZWZpbmVkO1xuICB9XG5cbiAgcHVibGljIHNldFN0aWNreShlbGVtZW50UmVmOiBFbGVtZW50UmVmKTogdm9pZCB7XG4gICAgdGhpcy4jcmVuZGVyZXIuYWRkQ2xhc3MoZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50LCAnc2t5LWRvY2stc3RpY2t5Jyk7XG4gIH1cblxuICBwdWJsaWMgc2V0WkluZGV4KHpJbmRleDogbnVtYmVyLCBlbGVtZW50UmVmOiBFbGVtZW50UmVmKTogdm9pZCB7XG4gICAgdGhpcy4jcmVuZGVyZXIuc2V0U3R5bGUoZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50LCAnei1pbmRleCcsIHpJbmRleCk7XG4gIH1cblxuICBwdWJsaWMgdW5iaW5kRG9jayhlbGVtZW50UmVmOiBFbGVtZW50UmVmKTogdm9pZCB7XG4gICAgdGhpcy4jcmVuZGVyZXIuYWRkQ2xhc3MoZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50LCAnc2t5LWRvY2stdW5ib3VuZCcpO1xuICB9XG5cbiAgcHVibGljIHdhdGNoRG9tQ2hhbmdlcyhlbGVtZW50UmVmOiBFbGVtZW50UmVmKTogdm9pZCB7XG4gICAgdGhpcy4jb2JzZXJ2ZXIgPSB0aGlzLiNtdXRhdGlvblN2Yy5jcmVhdGUoKCkgPT4ge1xuICAgICAgdGhpcy4jYWRqdXN0Qm9keVN0eWxlcyhlbGVtZW50UmVmKTtcbiAgICB9KTtcblxuICAgIHRoaXMuI29ic2VydmVyLm9ic2VydmUoZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50LCB7XG4gICAgICBhdHRyaWJ1dGVzOiB0cnVlLFxuICAgICAgY2hpbGRMaXN0OiB0cnVlLFxuICAgICAgY2hhcmFjdGVyRGF0YTogdHJ1ZSxcbiAgICAgIHN1YnRyZWU6IHRydWUsXG4gICAgfSk7XG5cbiAgICBvYnNlcnZhYmxlRnJvbUV2ZW50KHdpbmRvdywgJ3Jlc2l6ZScpXG4gICAgICAucGlwZShkZWJvdW5jZVRpbWUoMjUwKSwgdGFrZVVudGlsKHRoaXMuI25nVW5zdWJzY3JpYmUpKVxuICAgICAgLnN1YnNjcmliZSgoKSA9PiB0aGlzLiNhZGp1c3RCb2R5U3R5bGVzKGVsZW1lbnRSZWYpKTtcbiAgfVxuXG4gICNhZGp1c3RCb2R5U3R5bGVzKGVsZW1lbnRSZWY6IEVsZW1lbnRSZWYpOiB2b2lkIHtcbiAgICBjb25zdCBkb2NrSGVpZ2h0ID0gZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50LmdldEJvdW5kaW5nQ2xpZW50UmVjdCgpLmhlaWdodDtcbiAgICBpZiAoZG9ja0hlaWdodCA9PT0gdGhpcy4jY3VycmVudERvY2tIZWlnaHQpIHtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICAvLyBDcmVhdGUgYSBzdHlsZSBlbGVtZW50IHRvIGF2b2lkIG92ZXJ3cml0aW5nIGFueSBleGlzdGluZyBpbmxpbmUgYm9keSBzdHlsZXMuXG4gICAgY29uc3Qgc3R5bGVFbGVtZW50ID0gdGhpcy4jcmVuZGVyZXIuY3JlYXRlRWxlbWVudCgnc3R5bGUnKTtcbiAgICBjb25zdCB0ZXh0Tm9kZSA9IHRoaXMuI3JlbmRlcmVyLmNyZWF0ZVRleHQoXG4gICAgICBgYm9keSB7IG1hcmdpbi1ib3R0b206ICR7ZG9ja0hlaWdodH1weDsgfWAsXG4gICAgKTtcblxuICAgIC8vIEFwcGx5IGEgYGRhdGEtYCBhdHRyaWJ1dGUgdG8gbWFrZSB1bml0IHRlc3RpbmcgZWFzaWVyLlxuICAgIHRoaXMuI3JlbmRlcmVyLnNldEF0dHJpYnV0ZShcbiAgICAgIHN0eWxlRWxlbWVudCxcbiAgICAgICdkYXRhLXRlc3Qtc2VsZWN0b3InLFxuICAgICAgJ3NreS1sYXlvdXQtZG9jay1ib3R0b20tc3R5bGVzJyxcbiAgICApO1xuXG4gICAgdGhpcy4jcmVuZGVyZXIuYXBwZW5kQ2hpbGQoc3R5bGVFbGVtZW50LCB0ZXh0Tm9kZSk7XG4gICAgdGhpcy4jcmVuZGVyZXIuYXBwZW5kQ2hpbGQoZG9jdW1lbnQuaGVhZCwgc3R5bGVFbGVtZW50KTtcblxuICAgIGlmICh0aGlzLiNzdHlsZUVsZW1lbnQpIHtcbiAgICAgIHRoaXMuI2Rlc3Ryb3lTdHlsZUVsZW1lbnQoKTtcbiAgICB9XG5cbiAgICB0aGlzLiNjdXJyZW50RG9ja0hlaWdodCA9IGRvY2tIZWlnaHQ7XG4gICAgdGhpcy4jc3R5bGVFbGVtZW50ID0gc3R5bGVFbGVtZW50O1xuICB9XG5cbiAgI2Rlc3Ryb3lTdHlsZUVsZW1lbnQoKTogdm9pZCB7XG4gICAgdGhpcy4jcmVuZGVyZXIucmVtb3ZlQ2hpbGQoZG9jdW1lbnQuaGVhZCwgdGhpcy4jc3R5bGVFbGVtZW50KTtcbiAgfVxufVxuIl19
81
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dock-dom-adapter.service.js","sourceRoot":"","sources":["../../../../../../../../libs/components/core/src/lib/modules/dock/dock-dom-adapter.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ElementRef,\n  Injectable,\n  OnDestroy,\n  Renderer2,\n  RendererFactory2,\n} from '@angular/core';\n\nimport { Subject, fromEvent as observableFromEvent } from 'rxjs';\nimport { debounceTime, takeUntil } from 'rxjs/operators';\n\nimport { SkyMutationObserverService } from '../mutation/mutation-observer-service';\n\n/**\n * @internal\n */\n@Injectable()\nexport class SkyDockDomAdapterService implements OnDestroy {\n  #currentDockHeight: number | undefined;\n\n  #mutationSvc: SkyMutationObserverService;\n\n  #ngUnsubscribe = new Subject<void>();\n\n  #observer: MutationObserver | undefined;\n\n  #renderer: Renderer2;\n\n  #styleElement: HTMLStyleElement | undefined;\n\n  constructor(\n    mutationSvc: SkyMutationObserverService,\n    rendererFactory: RendererFactory2,\n  ) {\n    this.#mutationSvc = mutationSvc;\n    this.#renderer = rendererFactory.createRenderer(undefined, null);\n  }\n\n  public ngOnDestroy(): void {\n    if (this.#observer) {\n      this.#observer.disconnect();\n    }\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n\n    if (this.#styleElement) {\n      this.#destroyStyleElement();\n    }\n\n    this.#currentDockHeight = this.#observer = this.#styleElement = undefined;\n  }\n\n  public setSticky(elementRef: ElementRef): void {\n    this.#renderer.addClass(elementRef.nativeElement, 'sky-dock-sticky');\n  }\n\n  public setZIndex(zIndex: number, elementRef: ElementRef): void {\n    this.#renderer.setStyle(elementRef.nativeElement, 'z-index', zIndex);\n  }\n\n  public unbindDock(elementRef: ElementRef): void {\n    this.#renderer.addClass(elementRef.nativeElement, 'sky-dock-unbound');\n  }\n\n  public watchDomChanges(elementRef: ElementRef): void {\n    this.#observer = this.#mutationSvc.create(() => {\n      this.#adjustBodyStyles(elementRef);\n    });\n\n    this.#observer.observe(elementRef.nativeElement, {\n      attributes: true,\n      childList: true,\n      characterData: true,\n      subtree: true,\n    });\n\n    observableFromEvent(window, 'resize')\n      .pipe(debounceTime(250), takeUntil(this.#ngUnsubscribe))\n      .subscribe(() => this.#adjustBodyStyles(elementRef));\n  }\n\n  #adjustBodyStyles(elementRef: ElementRef): void {\n    const dockHeight = elementRef.nativeElement.getBoundingClientRect().height;\n    if (dockHeight === this.#currentDockHeight) {\n      return;\n    }\n\n    // Create a style element to avoid overwriting any existing inline body styles.\n    const styleElement = this.#renderer.createElement('style');\n    const textNode = this.#renderer.createText(\n      `body { margin-bottom: ${dockHeight}px; --sky-dock-height: ${dockHeight}px; }`,\n    );\n\n    // Apply a `data-` attribute to make unit testing easier.\n    this.#renderer.setAttribute(\n      styleElement,\n      'data-test-selector',\n      'sky-layout-dock-bottom-styles',\n    );\n\n    this.#renderer.appendChild(styleElement, textNode);\n    this.#renderer.appendChild(document.head, styleElement);\n\n    if (this.#styleElement) {\n      this.#destroyStyleElement();\n    }\n\n    this.#currentDockHeight = dockHeight;\n    this.#styleElement = styleElement;\n  }\n\n  #destroyStyleElement(): void {\n    this.#renderer.removeChild(document.head, this.#styleElement);\n  }\n}\n"]}
@@ -1,12 +1,13 @@
1
1
  var _a;
2
- import { Injectable } from '@angular/core';
2
+ import { Injectable, inject } from '@angular/core';
3
+ import { Subscription } from 'rxjs';
3
4
  import { SkyDynamicComponentLocation } from '../dynamic-component/dynamic-component-location';
5
+ import { SkyDynamicComponentService } from '../dynamic-component/dynamic-component.service';
4
6
  import { SkyDockItem } from './dock-item';
5
7
  import { SkyDockLocation } from './dock-location';
6
8
  import { SkyDockComponent } from './dock.component';
7
9
  import { sortByStackOrder } from './sort-by-stack-order';
8
10
  import * as i0 from "@angular/core";
9
- import * as i1 from "../dynamic-component/dynamic-component.service";
10
11
  /**
11
12
  * This service docks components to specific areas on the page.
12
13
  */
@@ -18,28 +19,27 @@ export class SkyDockService {
18
19
  get items() {
19
20
  return _a._items;
20
21
  }
21
- #dynamicComponentSvc;
22
+ #dynamicComponentSvc = inject(SkyDynamicComponentService);
23
+ #subscription;
22
24
  #options;
23
- constructor(dynamicComponentSvc) {
24
- this.#dynamicComponentSvc = dynamicComponentSvc;
25
- }
26
25
  /**
27
26
  * Docks a component to the bottom of the page.
28
27
  * @param component The component to dock.
29
28
  * @param config Options that affect the docking action.
30
29
  */
31
30
  insertComponent(component, config) {
31
+ this.#subscription ??= new Subscription();
32
32
  const dockRef = (_a.dockRef =
33
33
  _a.dockRef || this.#createDock());
34
34
  const itemRef = dockRef.instance.insertComponent(component, config);
35
35
  const item = new SkyDockItem(itemRef.componentRef.instance, itemRef.stackOrder);
36
- item.destroyed.subscribe(() => {
36
+ this.#subscription?.add(item.destroyed.subscribe(() => {
37
37
  dockRef.instance.removeItem(itemRef);
38
38
  _a._items.splice(_a._items.indexOf(item), 1);
39
39
  if (_a._items.length === 0) {
40
40
  this.#destroyDock();
41
41
  }
42
- });
42
+ }));
43
43
  _a._items.push(item);
44
44
  _a._items.sort(sortByStackOrder);
45
45
  return item;
@@ -79,10 +79,12 @@ export class SkyDockService {
79
79
  return dockRef;
80
80
  }
81
81
  #destroyDock() {
82
+ this.#subscription?.unsubscribe();
83
+ this.#subscription = undefined;
82
84
  this.#dynamicComponentSvc.removeComponent(_a.dockRef);
83
85
  _a.dockRef = undefined;
84
86
  }
85
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SkyDockService, deps: [{ token: i1.SkyDynamicComponentService }], target: i0.ɵɵFactoryTarget.Injectable }); }
87
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SkyDockService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
86
88
  static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SkyDockService, providedIn: 'root' }); }
87
89
  }
88
90
  _a = SkyDockService;
@@ -91,5 +93,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
91
93
  args: [{
92
94
  providedIn: 'root',
93
95
  }]
94
- }], ctorParameters: () => [{ type: i1.SkyDynamicComponentService }] });
95
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dock.service.js","sourceRoot":"","sources":["../../../../../../../../libs/components/core/src/lib/modules/dock/dock.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { ComponentRef, Injectable, Type } from '@angular/core';\n\nimport { SkyDynamicComponentLocation } from '../dynamic-component/dynamic-component-location';\nimport { SkyDynamicComponentOptions } from '../dynamic-component/dynamic-component-options';\nimport { SkyDynamicComponentService } from '../dynamic-component/dynamic-component.service';\n\nimport { SkyDockInsertComponentConfig } from './dock-insert-component-config';\nimport { SkyDockItem } from './dock-item';\nimport { SkyDockLocation } from './dock-location';\nimport { SkyDockOptions } from './dock-options';\nimport { SkyDockComponent } from './dock.component';\nimport { sortByStackOrder } from './sort-by-stack-order';\n\n/**\n * This service docks components to specific areas on the page.\n */\n@Injectable({\n  providedIn: 'root',\n})\nexport class SkyDockService {\n  private static dockRef: ComponentRef<SkyDockComponent> | undefined;\n  private static _items: SkyDockItem<any>[] = [];\n\n  /**\n   * Returns all docked items.\n   */\n  public get items(): SkyDockItem<any>[] {\n    return SkyDockService._items;\n  }\n\n  #dynamicComponentSvc: SkyDynamicComponentService;\n\n  #options: SkyDockOptions | undefined;\n\n  constructor(dynamicComponentSvc: SkyDynamicComponentService) {\n    this.#dynamicComponentSvc = dynamicComponentSvc;\n  }\n\n  /**\n   * Docks a component to the bottom of the page.\n   * @param component The component to dock.\n   * @param config Options that affect the docking action.\n   */\n  public insertComponent<T>(\n    component: Type<T>,\n    config?: SkyDockInsertComponentConfig,\n  ): SkyDockItem<T> {\n    const dockRef = (SkyDockService.dockRef =\n      SkyDockService.dockRef || this.#createDock());\n\n    const itemRef = dockRef.instance.insertComponent(component, config);\n    const item = new SkyDockItem(\n      itemRef.componentRef.instance,\n      itemRef.stackOrder,\n    );\n\n    item.destroyed.subscribe(() => {\n      dockRef.instance.removeItem(itemRef);\n      SkyDockService._items.splice(SkyDockService._items.indexOf(item), 1);\n      if (SkyDockService._items.length === 0) {\n        this.#destroyDock();\n      }\n    });\n\n    SkyDockService._items.push(item);\n    SkyDockService._items.sort(sortByStackOrder);\n\n    return item;\n  }\n\n  /**\n   * Sets options for the positioning and styling of the dock component. Since the dock service is a\n   * singleton instance, these options will be applied to all components inserted into the dock. In\n   * order to create a separate dock with different options, consumers should provide a different\n   * instance of the dock service.\n   * @param options The options for positioning and styling\n   */\n  public setDockOptions(options: SkyDockOptions): void {\n    this.#options = options;\n  }\n\n  #createDock(): ComponentRef<SkyDockComponent> {\n    let dockOptions: SkyDynamicComponentOptions | undefined;\n\n    if (this.#options) {\n      let dynamicLocation: SkyDynamicComponentLocation;\n      switch (this.#options.location) {\n        case SkyDockLocation.BeforeElement:\n          dynamicLocation = SkyDynamicComponentLocation.BeforeElement;\n          break;\n        case SkyDockLocation.ElementBottom:\n          dynamicLocation = SkyDynamicComponentLocation.ElementBottom;\n          break;\n        default:\n          dynamicLocation = SkyDynamicComponentLocation.BodyTop;\n          break;\n      }\n\n      dockOptions = {\n        location: dynamicLocation,\n        referenceEl: this.#options.referenceEl,\n      };\n    }\n\n    const dockRef = this.#dynamicComponentSvc.createComponent(\n      SkyDockComponent,\n      dockOptions,\n    );\n\n    dockRef.instance.setOptions(this.#options);\n\n    return dockRef;\n  }\n\n  #destroyDock(): void {\n    this.#dynamicComponentSvc.removeComponent(SkyDockService.dockRef);\n    SkyDockService.dockRef = undefined;\n  }\n}\n"]}
96
+ }] });
97
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dock.service.js","sourceRoot":"","sources":["../../../../../../../../libs/components/core/src/lib/modules/dock/dock.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { ComponentRef, Injectable, Type, inject } from '@angular/core';\n\nimport { Subscription } from 'rxjs';\n\nimport { SkyDynamicComponentLocation } from '../dynamic-component/dynamic-component-location';\nimport { SkyDynamicComponentOptions } from '../dynamic-component/dynamic-component-options';\nimport { SkyDynamicComponentService } from '../dynamic-component/dynamic-component.service';\n\nimport { SkyDockInsertComponentConfig } from './dock-insert-component-config';\nimport { SkyDockItem } from './dock-item';\nimport { SkyDockLocation } from './dock-location';\nimport { SkyDockOptions } from './dock-options';\nimport { SkyDockComponent } from './dock.component';\nimport { sortByStackOrder } from './sort-by-stack-order';\n\n/**\n * This service docks components to specific areas on the page.\n */\n@Injectable({\n  providedIn: 'root',\n})\nexport class SkyDockService {\n  private static dockRef: ComponentRef<SkyDockComponent> | undefined;\n  private static _items: SkyDockItem<any>[] = [];\n\n  /**\n   * Returns all docked items.\n   */\n  public get items(): SkyDockItem<any>[] {\n    return SkyDockService._items;\n  }\n\n  readonly #dynamicComponentSvc = inject(SkyDynamicComponentService);\n  #subscription: Subscription | undefined;\n\n  #options: SkyDockOptions | undefined;\n\n  /**\n   * Docks a component to the bottom of the page.\n   * @param component The component to dock.\n   * @param config Options that affect the docking action.\n   */\n  public insertComponent<T>(\n    component: Type<T>,\n    config?: SkyDockInsertComponentConfig,\n  ): SkyDockItem<T> {\n    this.#subscription ??= new Subscription();\n    const dockRef = (SkyDockService.dockRef =\n      SkyDockService.dockRef || this.#createDock());\n\n    const itemRef = dockRef.instance.insertComponent(component, config);\n    const item = new SkyDockItem(\n      itemRef.componentRef.instance,\n      itemRef.stackOrder,\n    );\n\n    this.#subscription?.add(\n      item.destroyed.subscribe(() => {\n        dockRef.instance.removeItem(itemRef);\n        SkyDockService._items.splice(SkyDockService._items.indexOf(item), 1);\n        if (SkyDockService._items.length === 0) {\n          this.#destroyDock();\n        }\n      }),\n    );\n\n    SkyDockService._items.push(item);\n    SkyDockService._items.sort(sortByStackOrder);\n\n    return item;\n  }\n\n  /**\n   * Sets options for the positioning and styling of the dock component. Since the dock service is a\n   * singleton instance, these options will be applied to all components inserted into the dock. In\n   * order to create a separate dock with different options, consumers should provide a different\n   * instance of the dock service.\n   * @param options The options for positioning and styling\n   */\n  public setDockOptions(options: SkyDockOptions): void {\n    this.#options = options;\n  }\n\n  #createDock(): ComponentRef<SkyDockComponent> {\n    let dockOptions: SkyDynamicComponentOptions | undefined;\n\n    if (this.#options) {\n      let dynamicLocation: SkyDynamicComponentLocation;\n      switch (this.#options.location) {\n        case SkyDockLocation.BeforeElement:\n          dynamicLocation = SkyDynamicComponentLocation.BeforeElement;\n          break;\n        case SkyDockLocation.ElementBottom:\n          dynamicLocation = SkyDynamicComponentLocation.ElementBottom;\n          break;\n        default:\n          dynamicLocation = SkyDynamicComponentLocation.BodyTop;\n          break;\n      }\n\n      dockOptions = {\n        location: dynamicLocation,\n        referenceEl: this.#options.referenceEl,\n      };\n    }\n\n    const dockRef = this.#dynamicComponentSvc.createComponent(\n      SkyDockComponent,\n      dockOptions,\n    );\n\n    dockRef.instance.setOptions(this.#options);\n\n    return dockRef;\n  }\n\n  #destroyDock(): void {\n    this.#subscription?.unsubscribe();\n    this.#subscription = undefined;\n    this.#dynamicComponentSvc.removeComponent(SkyDockService.dockRef);\n    SkyDockService.dockRef = undefined;\n  }\n}\n"]}
@@ -15,5 +15,5 @@ export class Version {
15
15
  /**
16
16
  * Represents the version of @skyux/core.
17
17
  */
18
- export const VERSION = new Version('11.37.0');
18
+ export const VERSION = new Version('11.38.1');
19
19
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9jb3JlL3NyYy92ZXJzaW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLHdDQUF3QztBQUN4QyxtRkFBbUY7QUFFbkY7OztHQUdHO0FBQ0gsTUFBTSxPQUFPLE9BQU87SUFLbEIsWUFBNEIsSUFBWTtRQUFaLFNBQUksR0FBSixJQUFJLENBQVE7UUFDdEMsSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQ2hDLElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUNoQyxJQUFJLENBQUMsS0FBSyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUNsRCxDQUFDO0NBQ0Y7QUFFRDs7R0FFRztBQUNILE1BQU0sQ0FBQyxNQUFNLE9BQU8sR0FBRyxJQUFJLE9BQU8sQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLy8gVGFrZW4gZnJvbSBBbmd1bGFyJ3MgdmVyc2lvbi50cyBmaWxlLlxuLy8gU2VlOiBodHRwczovL2dpdGh1Yi5jb20vYW5ndWxhci9hbmd1bGFyL2Jsb2IvMTYuMi54L3BhY2thZ2VzL2NvcmUvc3JjL3ZlcnNpb24udHNcblxuLyoqXG4gKiBSZXByZXNlbnRzIHRoZSB2ZXJzaW9uIG9mIGEgcGFja2FnZS5cbiAqIEBpbnRlcm5hbFxuICovXG5leHBvcnQgY2xhc3MgVmVyc2lvbiB7XG4gIHB1YmxpYyByZWFkb25seSBtYWpvcjogc3RyaW5nO1xuICBwdWJsaWMgcmVhZG9ubHkgbWlub3I6IHN0cmluZztcbiAgcHVibGljIHJlYWRvbmx5IHBhdGNoOiBzdHJpbmc7XG5cbiAgY29uc3RydWN0b3IocHVibGljIHJlYWRvbmx5IGZ1bGw6IHN0cmluZykge1xuICAgIHRoaXMubWFqb3IgPSBmdWxsLnNwbGl0KCcuJylbMF07XG4gICAgdGhpcy5taW5vciA9IGZ1bGwuc3BsaXQoJy4nKVsxXTtcbiAgICB0aGlzLnBhdGNoID0gZnVsbC5zcGxpdCgnLicpLnNsaWNlKDIpLmpvaW4oJy4nKTtcbiAgfVxufVxuXG4vKipcbiAqIFJlcHJlc2VudHMgdGhlIHZlcnNpb24gb2YgQHNreXV4L2NvcmUuXG4gKi9cbmV4cG9ydCBjb25zdCBWRVJTSU9OID0gbmV3IFZlcnNpb24oJzAuMC4wLVBMQUNFSE9MREVSJyk7XG4iXX0=
@@ -1384,7 +1384,7 @@ class SkyDockDomAdapterService {
1384
1384
  }
1385
1385
  // Create a style element to avoid overwriting any existing inline body styles.
1386
1386
  const styleElement = this.#renderer.createElement('style');
1387
- const textNode = this.#renderer.createText(`body { margin-bottom: ${dockHeight}px; }`);
1387
+ const textNode = this.#renderer.createText(`body { margin-bottom: ${dockHeight}px; --sky-dock-height: ${dockHeight}px; }`);
1388
1388
  // Apply a `data-` attribute to make unit testing easier.
1389
1389
  this.#renderer.setAttribute(styleElement, 'data-test-selector', 'sky-layout-dock-bottom-styles');
1390
1390
  this.#renderer.appendChild(styleElement, textNode);
@@ -1525,28 +1525,27 @@ class SkyDockService {
1525
1525
  get items() {
1526
1526
  return _a$1._items;
1527
1527
  }
1528
- #dynamicComponentSvc;
1528
+ #dynamicComponentSvc = inject(SkyDynamicComponentService);
1529
+ #subscription;
1529
1530
  #options;
1530
- constructor(dynamicComponentSvc) {
1531
- this.#dynamicComponentSvc = dynamicComponentSvc;
1532
- }
1533
1531
  /**
1534
1532
  * Docks a component to the bottom of the page.
1535
1533
  * @param component The component to dock.
1536
1534
  * @param config Options that affect the docking action.
1537
1535
  */
1538
1536
  insertComponent(component, config) {
1537
+ this.#subscription ??= new Subscription();
1539
1538
  const dockRef = (_a$1.dockRef =
1540
1539
  _a$1.dockRef || this.#createDock());
1541
1540
  const itemRef = dockRef.instance.insertComponent(component, config);
1542
1541
  const item = new SkyDockItem(itemRef.componentRef.instance, itemRef.stackOrder);
1543
- item.destroyed.subscribe(() => {
1542
+ this.#subscription?.add(item.destroyed.subscribe(() => {
1544
1543
  dockRef.instance.removeItem(itemRef);
1545
1544
  _a$1._items.splice(_a$1._items.indexOf(item), 1);
1546
1545
  if (_a$1._items.length === 0) {
1547
1546
  this.#destroyDock();
1548
1547
  }
1549
- });
1548
+ }));
1550
1549
  _a$1._items.push(item);
1551
1550
  _a$1._items.sort(sortByStackOrder);
1552
1551
  return item;
@@ -1586,10 +1585,12 @@ class SkyDockService {
1586
1585
  return dockRef;
1587
1586
  }
1588
1587
  #destroyDock() {
1588
+ this.#subscription?.unsubscribe();
1589
+ this.#subscription = undefined;
1589
1590
  this.#dynamicComponentSvc.removeComponent(_a$1.dockRef);
1590
1591
  _a$1.dockRef = undefined;
1591
1592
  }
1592
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SkyDockService, deps: [{ token: SkyDynamicComponentService }], target: i0.ɵɵFactoryTarget.Injectable }); }
1593
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SkyDockService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
1593
1594
  static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SkyDockService, providedIn: 'root' }); }
1594
1595
  }
1595
1596
  _a$1 = SkyDockService;
@@ -1598,7 +1599,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
1598
1599
  args: [{
1599
1600
  providedIn: 'root',
1600
1601
  }]
1601
- }], ctorParameters: () => [{ type: SkyDynamicComponentService }] });
1602
+ }] });
1602
1603
 
1603
1604
  /**
1604
1605
  * Provides services required to create dynamic components on the page.
@@ -4512,7 +4513,7 @@ class Version {
4512
4513
  /**
4513
4514
  * Represents the version of @skyux/core.
4514
4515
  */
4515
- const VERSION = new Version('11.37.0');
4516
+ const VERSION = new Version('11.38.1');
4516
4517
 
4517
4518
  /**
4518
4519
  * Generated bundle index. Do not edit.