@skyux/core 8.7.0 → 9.0.0-alpha.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/{esm2020 → esm2022}/lib/modules/adapter-service/adapter.module.mjs +5 -5
- package/esm2022/lib/modules/adapter-service/adapter.service.mjs +225 -0
- package/esm2022/lib/modules/affix/affix.directive.mjs +116 -0
- package/{esm2020 → esm2022}/lib/modules/affix/affix.module.mjs +5 -5
- package/esm2022/lib/modules/affix/affix.service.mjs +25 -0
- package/esm2022/lib/modules/affix/affixer.mjs +398 -0
- package/esm2022/lib/modules/default-input-provider/default-input-provider.mjs +26 -0
- package/esm2022/lib/modules/dock/dock-dom-adapter.service.mjs +81 -0
- package/esm2022/lib/modules/dock/dock-item.mjs +31 -0
- package/esm2022/lib/modules/dock/dock.component.mjs +108 -0
- package/{esm2020 → esm2022}/lib/modules/dock/dock.module.mjs +5 -5
- package/esm2022/lib/modules/dock/dock.service.mjs +96 -0
- package/{esm2020 → esm2022}/lib/modules/dynamic-component/dynamic-component.module.mjs +5 -5
- package/esm2022/lib/modules/dynamic-component/dynamic-component.service.mjs +106 -0
- package/{esm2020 → esm2022}/lib/modules/format/app-format.mjs +4 -4
- package/esm2022/lib/modules/id/id.directive.mjs +31 -0
- package/{esm2020 → esm2022}/lib/modules/id/id.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/modules/id/id.service.mjs +4 -4
- package/esm2022/lib/modules/layout-host/layout-host.service.mjs +22 -0
- package/esm2022/lib/modules/live-announcer/live-announcer.service.mjs +79 -0
- package/{esm2020 → esm2022}/lib/modules/log/log.module.mjs +5 -5
- package/esm2022/lib/modules/log/log.service.mjs +148 -0
- package/{esm2020 → esm2022}/lib/modules/media-query/media-query.module.mjs +5 -5
- package/esm2022/lib/modules/media-query/media-query.service.mjs +123 -0
- package/{esm2020 → esm2022}/lib/modules/mutation/mutation-observer-service.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/numeric/numeric.module.mjs +5 -5
- package/esm2022/lib/modules/numeric/numeric.pipe.mjs +81 -0
- package/esm2022/lib/modules/numeric/numeric.service.mjs +205 -0
- package/esm2022/lib/modules/overlay/overlay-adapter.service.mjs +44 -0
- package/esm2022/lib/modules/overlay/overlay-instance.mjs +62 -0
- package/esm2022/lib/modules/overlay/overlay.component.mjs +193 -0
- package/{esm2020 → esm2022}/lib/modules/overlay/overlay.module.mjs +5 -5
- package/esm2022/lib/modules/overlay/overlay.service.mjs +124 -0
- package/{esm2020 → esm2022}/lib/modules/percent-pipe/percent-pipe.module.mjs +5 -5
- package/esm2022/lib/modules/percent-pipe/percent.pipe.mjs +56 -0
- package/esm2022/lib/modules/resize-observer/resize-observer-media-query.service.mjs +120 -0
- package/esm2022/lib/modules/resize-observer/resize-observer.service.mjs +77 -0
- package/esm2022/lib/modules/scrollable-host/scrollable-host.service.mjs +223 -0
- package/esm2022/lib/modules/shared/number-format/number-format-utility.mjs +72 -0
- package/esm2022/lib/modules/shared/sky-core-resources.module.mjs +50 -0
- package/esm2022/lib/modules/title/title.service.mjs +31 -0
- package/esm2022/lib/modules/trim/trim.directive.mjs +64 -0
- package/{esm2020 → esm2022}/lib/modules/trim/trim.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/modules/ui-config/ui-config.service.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/viewkeeper/viewkeeper-host-options.mjs +4 -4
- package/esm2022/lib/modules/viewkeeper/viewkeeper.directive.mjs +131 -0
- package/esm2022/lib/modules/viewkeeper/viewkeeper.mjs +283 -0
- package/{esm2020 → esm2022}/lib/modules/viewkeeper/viewkeeper.module.mjs +5 -5
- package/esm2022/lib/modules/viewkeeper/viewkeeper.service.mjs +39 -0
- package/{esm2020 → esm2022}/lib/modules/window/window-ref.mjs +4 -4
- package/esm2022/testing/core-testing.module.mjs +32 -0
- package/esm2022/testing/mock-media-query.service.mjs +46 -0
- package/{esm2020 → esm2022}/testing/mock-ui-config.service.mjs +4 -4
- package/esm2022/testing/overlay/overlay-harness.mjs +43 -0
- package/esm2022/testing/shared/component-harness.mjs +13 -0
- package/{fesm2020 → fesm2022}/skyux-core-testing.mjs +28 -34
- package/{fesm2020 → fesm2022}/skyux-core-testing.mjs.map +1 -1
- package/fesm2022/skyux-core.mjs +3858 -0
- package/fesm2022/skyux-core.mjs.map +1 -0
- package/lib/modules/affix/affix.directive.d.ts +1 -1
- package/lib/modules/viewkeeper/viewkeeper.directive.d.ts +1 -1
- package/package.json +14 -22
- package/esm2020/lib/modules/adapter-service/adapter.service.mjs +0 -227
- package/esm2020/lib/modules/affix/affix.directive.mjs +0 -118
- package/esm2020/lib/modules/affix/affix.service.mjs +0 -28
- package/esm2020/lib/modules/affix/affixer.mjs +0 -377
- package/esm2020/lib/modules/default-input-provider/default-input-provider.mjs +0 -31
- package/esm2020/lib/modules/dock/dock-dom-adapter.service.mjs +0 -83
- package/esm2020/lib/modules/dock/dock-item.mjs +0 -34
- package/esm2020/lib/modules/dock/dock.component.mjs +0 -110
- package/esm2020/lib/modules/dock/dock.service.mjs +0 -98
- package/esm2020/lib/modules/dynamic-component/dynamic-component.service.mjs +0 -109
- package/esm2020/lib/modules/id/id.directive.mjs +0 -34
- package/esm2020/lib/modules/layout-host/layout-host.service.mjs +0 -27
- package/esm2020/lib/modules/live-announcer/live-announcer.service.mjs +0 -80
- package/esm2020/lib/modules/log/log.service.mjs +0 -147
- package/esm2020/lib/modules/media-query/media-query.service.mjs +0 -124
- package/esm2020/lib/modules/numeric/numeric.pipe.mjs +0 -84
- package/esm2020/lib/modules/numeric/numeric.service.mjs +0 -179
- package/esm2020/lib/modules/overlay/overlay-adapter.service.mjs +0 -47
- package/esm2020/lib/modules/overlay/overlay-instance.mjs +0 -65
- package/esm2020/lib/modules/overlay/overlay.component.mjs +0 -192
- package/esm2020/lib/modules/overlay/overlay.service.mjs +0 -125
- package/esm2020/lib/modules/percent-pipe/percent.pipe.mjs +0 -59
- package/esm2020/lib/modules/resize-observer/resize-observer-media-query.service.mjs +0 -121
- package/esm2020/lib/modules/resize-observer/resize-observer.service.mjs +0 -79
- package/esm2020/lib/modules/scrollable-host/scrollable-host.service.mjs +0 -218
- package/esm2020/lib/modules/shared/number-format/number-format-utility.mjs +0 -72
- package/esm2020/lib/modules/shared/sky-core-resources.module.mjs +0 -50
- package/esm2020/lib/modules/title/title.service.mjs +0 -34
- package/esm2020/lib/modules/trim/trim.directive.mjs +0 -65
- package/esm2020/lib/modules/viewkeeper/viewkeeper.directive.mjs +0 -131
- package/esm2020/lib/modules/viewkeeper/viewkeeper.mjs +0 -276
- package/esm2020/lib/modules/viewkeeper/viewkeeper.service.mjs +0 -42
- package/esm2020/testing/core-testing.module.mjs +0 -32
- package/esm2020/testing/mock-media-query.service.mjs +0 -46
- package/esm2020/testing/overlay/overlay-harness.mjs +0 -43
- package/esm2020/testing/shared/component-harness.mjs +0 -19
- package/fesm2015/skyux-core-testing.mjs +0 -209
- package/fesm2015/skyux-core-testing.mjs.map +0 -1
- package/fesm2015/skyux-core.mjs +0 -3835
- package/fesm2015/skyux-core.mjs.map +0 -1
- package/fesm2020/skyux-core.mjs +0 -3825
- package/fesm2020/skyux-core.mjs.map +0 -1
- /package/{esm2020 → esm2022}/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/adapter-service/focusable-children-options.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/affix/affix-auto-fit-context.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/affix/affix-config.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/affix/affix-horizontal-alignment.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/affix/affix-offset-change.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/affix/affix-offset.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/affix/affix-placement-change.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/affix/affix-placement.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/affix/affix-position.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/affix/affix-rect.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/affix/affix-utils.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/affix/affix-vertical-alignment.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/affix/dom-utils.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/dock/dock-insert-component-config.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/dock/dock-item-config.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/dock/dock-item-reference.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/dock/dock-location.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/dock/dock-options.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/dock/sort-by-stack-order.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/dynamic-component/dynamic-component-location.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/dynamic-component/dynamic-component-options.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/layout-host/layout-host-for-child-args.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/live-announcer/types/live-announcer-args.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/live-announcer/types/live-announcer-politeness.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/log/types/log-deprecation-args.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/log/types/log-level-token.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/log/types/log-level.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/media-query/media-breakpoints.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/media-query/media-query-listener.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/numeric/numeric-symbol.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/numeric/numeric.options.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/overlay/overlay-config.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/overlay/overlay-context.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/overlay/overlay-position.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/stacking-context/stacking-context-token.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/stacking-context/stacking-context.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/title/set-title-args.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/viewkeeper/viewkeeper-boundary-info.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/viewkeeper/viewkeeper-fixed-styles.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/viewkeeper/viewkeeper-offset.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/viewkeeper/viewkeeper-options.mjs +0 -0
- /package/{esm2020 → esm2022}/skyux-core.mjs +0 -0
- /package/{esm2020 → esm2022}/testing/overlay/overlay-harness-filters.mjs +0 -0
- /package/{esm2020 → esm2022}/testing/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/testing/shared/harness-filters.mjs +0 -0
- /package/{esm2020 → esm2022}/testing/skyux-core-testing.mjs +0 -0
@@ -0,0 +1,108 @@
|
|
1
|
+
import { ChangeDetectionStrategy, Component, Injector, ViewChild, ViewContainerRef, } from '@angular/core';
|
2
|
+
import { SkyDockDomAdapterService } from './dock-dom-adapter.service';
|
3
|
+
import { SkyDockLocation } from './dock-location';
|
4
|
+
import { sortByStackOrder } from './sort-by-stack-order';
|
5
|
+
import * as i0 from "@angular/core";
|
6
|
+
import * as i1 from "./dock-dom-adapter.service";
|
7
|
+
/**
|
8
|
+
* @internal
|
9
|
+
*/
|
10
|
+
export class SkyDockComponent {
|
11
|
+
#changeDetector;
|
12
|
+
#domAdapter;
|
13
|
+
#elementRef;
|
14
|
+
#injector;
|
15
|
+
#itemRefs = [];
|
16
|
+
#options;
|
17
|
+
constructor(changeDetector, elementRef, injector, domAdapter) {
|
18
|
+
this.#changeDetector = changeDetector;
|
19
|
+
this.#elementRef = elementRef;
|
20
|
+
this.#injector = injector;
|
21
|
+
this.#domAdapter = domAdapter;
|
22
|
+
}
|
23
|
+
insertComponent(component, config = {}) {
|
24
|
+
/*istanbul ignore if: untestable*/
|
25
|
+
if (!this.target) {
|
26
|
+
throw Error('[SkyDockComponent] Could not insert the component because the target element could not be found.');
|
27
|
+
}
|
28
|
+
const injector = Injector.create({
|
29
|
+
providers: config.providers || [],
|
30
|
+
parent: this.#injector,
|
31
|
+
});
|
32
|
+
const componentRef = this.target.createComponent(component, {
|
33
|
+
injector,
|
34
|
+
});
|
35
|
+
const stackOrder = config.stackOrder !== null && config.stackOrder !== undefined
|
36
|
+
? config.stackOrder
|
37
|
+
: this.#getHighestStackOrder();
|
38
|
+
this.#itemRefs.push({
|
39
|
+
componentRef,
|
40
|
+
stackOrder,
|
41
|
+
});
|
42
|
+
this.#sortItemsByStackOrder();
|
43
|
+
this.#changeDetector.markForCheck();
|
44
|
+
return {
|
45
|
+
componentRef,
|
46
|
+
stackOrder,
|
47
|
+
};
|
48
|
+
}
|
49
|
+
removeItem(item) {
|
50
|
+
/*istanbul ignore if: untestable*/
|
51
|
+
if (!this.target) {
|
52
|
+
throw Error('[SkyDockComponent] Could not remove the item because the target element could not be found.');
|
53
|
+
}
|
54
|
+
const viewRef = item.componentRef.hostView;
|
55
|
+
this.target.remove(this.target.indexOf(viewRef));
|
56
|
+
const found = this.#itemRefs.find((i) => i.componentRef.hostView === viewRef);
|
57
|
+
if (found) {
|
58
|
+
this.#itemRefs.splice(this.#itemRefs.indexOf(found), 1);
|
59
|
+
}
|
60
|
+
}
|
61
|
+
setOptions(options) {
|
62
|
+
this.#options = options;
|
63
|
+
switch (this.#options?.location) {
|
64
|
+
case SkyDockLocation.BeforeElement:
|
65
|
+
this.#domAdapter.unbindDock(this.#elementRef);
|
66
|
+
break;
|
67
|
+
case SkyDockLocation.ElementBottom:
|
68
|
+
this.#domAdapter.setSticky(this.#elementRef);
|
69
|
+
break;
|
70
|
+
case SkyDockLocation.BodyBottom:
|
71
|
+
default:
|
72
|
+
this.#domAdapter.watchDomChanges(this.#elementRef);
|
73
|
+
break;
|
74
|
+
}
|
75
|
+
if (this.#options?.zIndex) {
|
76
|
+
this.#domAdapter.setZIndex(this.#options.zIndex, this.#elementRef);
|
77
|
+
}
|
78
|
+
}
|
79
|
+
#sortItemsByStackOrder() {
|
80
|
+
if (this.target) {
|
81
|
+
this.#itemRefs.sort(sortByStackOrder);
|
82
|
+
// Reassign the correct index for each view.
|
83
|
+
for (let i = 0, len = this.#itemRefs.length; i < len; i++) {
|
84
|
+
const item = this.#itemRefs[i];
|
85
|
+
this.target.move(item.componentRef.hostView, i);
|
86
|
+
}
|
87
|
+
}
|
88
|
+
}
|
89
|
+
#getHighestStackOrder() {
|
90
|
+
if (this.#itemRefs.length === 0) {
|
91
|
+
return 0;
|
92
|
+
}
|
93
|
+
return this.#itemRefs[0].stackOrder + 1;
|
94
|
+
}
|
95
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyDockComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.ElementRef }, { token: i0.Injector }, { token: i1.SkyDockDomAdapterService }], target: i0.ɵɵFactoryTarget.Component }); }
|
96
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.7", 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:var(--sky-viewport-left, 0);bottom:var(--sky-viewport-bottom, 0);right:var(--sky-viewport-right, 0);width:auto}:host.sky-dock-sticky{position:sticky}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
97
|
+
}
|
98
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyDockComponent, decorators: [{
|
99
|
+
type: Component,
|
100
|
+
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:var(--sky-viewport-left, 0);bottom:var(--sky-viewport-bottom, 0);right:var(--sky-viewport-right, 0);width:auto}:host.sky-dock-sticky{position:sticky}\n"] }]
|
101
|
+
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i0.ElementRef }, { type: i0.Injector }, { type: i1.SkyDockDomAdapterService }]; }, propDecorators: { target: [{
|
102
|
+
type: ViewChild,
|
103
|
+
args: ['target', {
|
104
|
+
read: ViewContainerRef,
|
105
|
+
static: true,
|
106
|
+
}]
|
107
|
+
}] } });
|
108
|
+
//# 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  public 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"]}
|
@@ -4,11 +4,11 @@ import { SkyMutationObserverService } from '../mutation/mutation-observer-servic
|
|
4
4
|
import { SkyDockComponent } from './dock.component';
|
5
5
|
import * as i0 from "@angular/core";
|
6
6
|
export class SkyDockModule {
|
7
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyDockModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
8
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.1.7", ngImport: i0, type: SkyDockModule, declarations: [SkyDockComponent], imports: [CommonModule] }); }
|
9
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyDockModule, providers: [SkyMutationObserverService], imports: [CommonModule] }); }
|
7
10
|
}
|
8
|
-
|
9
|
-
SkyDockModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.9", ngImport: i0, type: SkyDockModule, declarations: [SkyDockComponent], imports: [CommonModule] });
|
10
|
-
SkyDockModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyDockModule, providers: [SkyMutationObserverService], imports: [CommonModule] });
|
11
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyDockModule, decorators: [{
|
11
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyDockModule, decorators: [{
|
12
12
|
type: NgModule,
|
13
13
|
args: [{
|
14
14
|
imports: [CommonModule],
|
@@ -16,4 +16,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
|
|
16
16
|
providers: [SkyMutationObserverService],
|
17
17
|
}]
|
18
18
|
}] });
|
19
|
-
//# sourceMappingURL=data:application/json;base64,
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG9jay5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvY29yZS9zcmMvbGliL21vZHVsZXMvZG9jay9kb2NrLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV6QyxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQztBQUVuRixPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQzs7QUFPcEQsTUFBTSxPQUFPLGFBQWE7OEdBQWIsYUFBYTsrR0FBYixhQUFhLGlCQUhULGdCQUFnQixhQURyQixZQUFZOytHQUlYLGFBQWEsYUFGYixDQUFDLDBCQUEwQixDQUFDLFlBRjdCLFlBQVk7OzJGQUlYLGFBQWE7a0JBTHpCLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFLENBQUMsWUFBWSxDQUFDO29CQUN2QixZQUFZLEVBQUUsQ0FBQyxnQkFBZ0IsQ0FBQztvQkFDaEMsU0FBUyxFQUFFLENBQUMsMEJBQTBCLENBQUM7aUJBQ3hDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IFNreU11dGF0aW9uT2JzZXJ2ZXJTZXJ2aWNlIH0gZnJvbSAnLi4vbXV0YXRpb24vbXV0YXRpb24tb2JzZXJ2ZXItc2VydmljZSc7XG5cbmltcG9ydCB7IFNreURvY2tDb21wb25lbnQgfSBmcm9tICcuL2RvY2suY29tcG9uZW50JztcblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZV0sXG4gIGRlY2xhcmF0aW9uczogW1NreURvY2tDb21wb25lbnRdLFxuICBwcm92aWRlcnM6IFtTa3lNdXRhdGlvbk9ic2VydmVyU2VydmljZV0sXG59KVxuZXhwb3J0IGNsYXNzIFNreURvY2tNb2R1bGUge31cbiJdfQ==
|
@@ -0,0 +1,96 @@
|
|
1
|
+
import { Injectable } from '@angular/core';
|
2
|
+
import { SkyDynamicComponentLocation } from '../dynamic-component/dynamic-component-location';
|
3
|
+
import { SkyDockItem } from './dock-item';
|
4
|
+
import { SkyDockLocation } from './dock-location';
|
5
|
+
import { SkyDockComponent } from './dock.component';
|
6
|
+
import { sortByStackOrder } from './sort-by-stack-order';
|
7
|
+
import * as i0 from "@angular/core";
|
8
|
+
import * as i1 from "../dynamic-component/dynamic-component.service";
|
9
|
+
/**
|
10
|
+
* This service docks components to specific areas on the page.
|
11
|
+
*/
|
12
|
+
export class SkyDockService {
|
13
|
+
static { this._items = []; }
|
14
|
+
/**
|
15
|
+
* Returns all docked items.
|
16
|
+
*/
|
17
|
+
get items() {
|
18
|
+
return SkyDockService._items;
|
19
|
+
}
|
20
|
+
#dynamicComponentSvc;
|
21
|
+
#options;
|
22
|
+
constructor(dynamicComponentSvc) {
|
23
|
+
this.#dynamicComponentSvc = dynamicComponentSvc;
|
24
|
+
}
|
25
|
+
/**
|
26
|
+
* Docks a component to the bottom of the page.
|
27
|
+
* @param component The component to dock.
|
28
|
+
* @param config Options that affect the docking action.
|
29
|
+
*/
|
30
|
+
insertComponent(component, config) {
|
31
|
+
const dockRef = (SkyDockService.dockRef =
|
32
|
+
SkyDockService.dockRef || this.#createDock());
|
33
|
+
const itemRef = dockRef.instance.insertComponent(component, config);
|
34
|
+
const item = new SkyDockItem(itemRef.componentRef.instance, itemRef.stackOrder);
|
35
|
+
item.destroyed.subscribe(() => {
|
36
|
+
dockRef.instance.removeItem(itemRef);
|
37
|
+
SkyDockService._items.splice(SkyDockService._items.indexOf(item), 1);
|
38
|
+
if (SkyDockService._items.length === 0) {
|
39
|
+
this.#destroyDock();
|
40
|
+
}
|
41
|
+
});
|
42
|
+
SkyDockService._items.push(item);
|
43
|
+
SkyDockService._items.sort(sortByStackOrder);
|
44
|
+
return item;
|
45
|
+
}
|
46
|
+
/**
|
47
|
+
* Sets options for the positioning and styling of the dock component. Since the dock service is a
|
48
|
+
* singleton instance, these options will be applied to all components inserted into the dock. In
|
49
|
+
* order to create a separate dock with different options, consumers should provide a different
|
50
|
+
* instance of the dock service.
|
51
|
+
* @param options The options for positioning and styling
|
52
|
+
*/
|
53
|
+
setDockOptions(options) {
|
54
|
+
this.#options = options;
|
55
|
+
}
|
56
|
+
#createDock() {
|
57
|
+
let dockOptions;
|
58
|
+
if (this.#options) {
|
59
|
+
let dynamicLocation;
|
60
|
+
switch (this.#options.location) {
|
61
|
+
case SkyDockLocation.BeforeElement:
|
62
|
+
dynamicLocation = SkyDynamicComponentLocation.BeforeElement;
|
63
|
+
break;
|
64
|
+
case SkyDockLocation.ElementBottom:
|
65
|
+
dynamicLocation = SkyDynamicComponentLocation.ElementBottom;
|
66
|
+
break;
|
67
|
+
default:
|
68
|
+
dynamicLocation = SkyDynamicComponentLocation.BodyTop;
|
69
|
+
break;
|
70
|
+
}
|
71
|
+
dockOptions = {
|
72
|
+
location: dynamicLocation,
|
73
|
+
referenceEl: this.#options.referenceEl,
|
74
|
+
};
|
75
|
+
}
|
76
|
+
const dockRef = this.#dynamicComponentSvc.createComponent(SkyDockComponent, dockOptions);
|
77
|
+
dockRef.instance.setOptions(this.#options);
|
78
|
+
return dockRef;
|
79
|
+
}
|
80
|
+
#destroyDock() {
|
81
|
+
this.#dynamicComponentSvc.removeComponent(SkyDockService.dockRef);
|
82
|
+
SkyDockService.dockRef = undefined;
|
83
|
+
}
|
84
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyDockService, deps: [{ token: i1.SkyDynamicComponentService }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
85
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyDockService, providedIn: 'any' }); }
|
86
|
+
}
|
87
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyDockService, decorators: [{
|
88
|
+
type: Injectable,
|
89
|
+
args: [{
|
90
|
+
// Must be 'any' so that the dock component is created in the context of its module's injector.
|
91
|
+
// If set to 'root', the component's dependency injections would only be derived from the root
|
92
|
+
// injector and may loose context if the dock was opened from within a lazy-loaded module.
|
93
|
+
providedIn: 'any',
|
94
|
+
}]
|
95
|
+
}], ctorParameters: function () { return [{ type: i1.SkyDynamicComponentService }]; } });
|
96
|
+
//# 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  // Must be 'any' so that the dock 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 dock was opened from within a lazy-loaded module.\n  providedIn: 'any',\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"]}
|
@@ -6,12 +6,12 @@ import * as i0 from "@angular/core";
|
|
6
6
|
* The `SkyDynamicComponentModule` can be removed from your project.
|
7
7
|
*/
|
8
8
|
export class SkyDynamicComponentModule {
|
9
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyDynamicComponentModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
10
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.1.7", ngImport: i0, type: SkyDynamicComponentModule }); }
|
11
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyDynamicComponentModule }); }
|
9
12
|
}
|
10
|
-
|
11
|
-
SkyDynamicComponentModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.9", ngImport: i0, type: SkyDynamicComponentModule });
|
12
|
-
SkyDynamicComponentModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyDynamicComponentModule });
|
13
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyDynamicComponentModule, decorators: [{
|
13
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyDynamicComponentModule, decorators: [{
|
14
14
|
type: NgModule,
|
15
15
|
args: [{}]
|
16
16
|
}] });
|
17
|
-
//# sourceMappingURL=data:application/json;base64,
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHluYW1pYy1jb21wb25lbnQubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL2NvcmUvc3JjL2xpYi9tb2R1bGVzL2R5bmFtaWMtY29tcG9uZW50L2R5bmFtaWMtY29tcG9uZW50Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUV6Qzs7OztHQUlHO0FBRUgsTUFBTSxPQUFPLHlCQUF5Qjs4R0FBekIseUJBQXlCOytHQUF6Qix5QkFBeUI7K0dBQXpCLHlCQUF5Qjs7MkZBQXpCLHlCQUF5QjtrQkFEckMsUUFBUTttQkFBQyxFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuLyoqXG4gKiBQcm92aWRlcyBzZXJ2aWNlcyByZXF1aXJlZCB0byBjcmVhdGUgZHluYW1pYyBjb21wb25lbnRzIG9uIHRoZSBwYWdlLlxuICogQGRlcHJlY2F0ZWQgVGhlIGBTa3lEeW5hbWljQ29tcG9uZW50U2VydmljZWAgbm8gbG9uZ2VyIG5lZWRzIHRoZSBgU2t5RHluYW1pY0NvbXBvbmVudE1vZHVsZWAuXG4gKiBUaGUgYFNreUR5bmFtaWNDb21wb25lbnRNb2R1bGVgIGNhbiBiZSByZW1vdmVkIGZyb20geW91ciBwcm9qZWN0LlxuICovXG5ATmdNb2R1bGUoe30pXG5leHBvcnQgY2xhc3MgU2t5RHluYW1pY0NvbXBvbmVudE1vZHVsZSB7fVxuIl19
|
@@ -0,0 +1,106 @@
|
|
1
|
+
import { Injectable, Injector, createComponent, } from '@angular/core';
|
2
|
+
import { SkyDynamicComponentLocation } from './dynamic-component-location';
|
3
|
+
import * as i0 from "@angular/core";
|
4
|
+
import * as i1 from "../window/window-ref";
|
5
|
+
/**
|
6
|
+
* Angular service for creating and rendering a dynamic component.
|
7
|
+
* @internal
|
8
|
+
*/
|
9
|
+
export class SkyDynamicComponentService {
|
10
|
+
#applicationRef;
|
11
|
+
#environmentInjector;
|
12
|
+
#injector;
|
13
|
+
#renderer;
|
14
|
+
#windowRef;
|
15
|
+
constructor(applicationRef, injector, windowRef, rendererFactory, environmentInjector) {
|
16
|
+
this.#applicationRef = applicationRef;
|
17
|
+
this.#injector = injector;
|
18
|
+
this.#windowRef = windowRef;
|
19
|
+
this.#environmentInjector = environmentInjector;
|
20
|
+
// Based on suggestions from https://github.com/angular/angular/issues/17824
|
21
|
+
// for accessing an instance of Renderer2 in a service since Renderer2 can't
|
22
|
+
// be injected into a service. Passing undefined for both parameters results
|
23
|
+
// in the default renderer which is what we want here.
|
24
|
+
this.#renderer = rendererFactory.createRenderer(undefined, null);
|
25
|
+
}
|
26
|
+
/**
|
27
|
+
* Creates an instance of the specified component and adds it to the specified location
|
28
|
+
* on the page.
|
29
|
+
*/
|
30
|
+
createComponent(componentType, options) {
|
31
|
+
options = options || {
|
32
|
+
location: SkyDynamicComponentLocation.BodyBottom,
|
33
|
+
};
|
34
|
+
const injector = Injector.create({
|
35
|
+
providers: options.providers || [],
|
36
|
+
parent: options.parentInjector || this.#injector,
|
37
|
+
});
|
38
|
+
let componentRef;
|
39
|
+
if (options.viewContainerRef) {
|
40
|
+
componentRef = options.viewContainerRef.createComponent(componentType, {
|
41
|
+
injector,
|
42
|
+
});
|
43
|
+
}
|
44
|
+
else {
|
45
|
+
componentRef = createComponent(componentType, {
|
46
|
+
environmentInjector: this.#environmentInjector,
|
47
|
+
elementInjector: injector,
|
48
|
+
});
|
49
|
+
this.#applicationRef.attachView(componentRef.hostView);
|
50
|
+
const el = this.#getRootNode(componentRef);
|
51
|
+
const bodyEl = this.#windowRef.nativeWindow.document.body;
|
52
|
+
switch (options.location) {
|
53
|
+
case SkyDynamicComponentLocation.BeforeElement:
|
54
|
+
if (!options.referenceEl) {
|
55
|
+
throw new Error('[SkyDynamicComponentService] Could not create a component at location `SkyDynamicComponentLocation.BeforeElement` because a reference element was not provided.');
|
56
|
+
}
|
57
|
+
this.#renderer.insertBefore(options.referenceEl.parentElement, el, options.referenceEl);
|
58
|
+
break;
|
59
|
+
case SkyDynamicComponentLocation.ElementTop:
|
60
|
+
if (!options.referenceEl) {
|
61
|
+
throw new Error('[SkyDynamicComponentService] Could not create a component at location `SkyDynamicComponentLocation.ElementTop` because a reference element was not provided.');
|
62
|
+
}
|
63
|
+
this.#renderer.insertBefore(options.referenceEl, el, options.referenceEl.firstChild);
|
64
|
+
break;
|
65
|
+
case SkyDynamicComponentLocation.ElementBottom:
|
66
|
+
this.#renderer.appendChild(options.referenceEl, el);
|
67
|
+
break;
|
68
|
+
case SkyDynamicComponentLocation.BodyTop:
|
69
|
+
this.#renderer.insertBefore(bodyEl, el, bodyEl.firstChild);
|
70
|
+
break;
|
71
|
+
default:
|
72
|
+
this.#renderer.appendChild(bodyEl, el);
|
73
|
+
break;
|
74
|
+
}
|
75
|
+
}
|
76
|
+
return componentRef;
|
77
|
+
}
|
78
|
+
/**
|
79
|
+
* Removes a component ref from the page
|
80
|
+
* @param componentRef Component ref for the component being removed
|
81
|
+
*/
|
82
|
+
removeComponent(componentRef) {
|
83
|
+
if (!componentRef) {
|
84
|
+
return;
|
85
|
+
}
|
86
|
+
this.#applicationRef.detachView(componentRef.hostView);
|
87
|
+
componentRef.destroy();
|
88
|
+
}
|
89
|
+
#getRootNode(componentRef) {
|
90
|
+
// Technique for retrieving the component's root node taken from here:
|
91
|
+
// https://malcoded.com/posts/angular-dynamic-components
|
92
|
+
return componentRef.hostView.rootNodes[0];
|
93
|
+
}
|
94
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyDynamicComponentService, deps: [{ token: i0.ApplicationRef }, { token: i0.Injector }, { token: i1.SkyAppWindowRef }, { token: i0.RendererFactory2 }, { token: i0.EnvironmentInjector }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
95
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyDynamicComponentService, providedIn: 'any' }); }
|
96
|
+
}
|
97
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyDynamicComponentService, decorators: [{
|
98
|
+
type: Injectable,
|
99
|
+
args: [{
|
100
|
+
// Must be 'any' so that the component is created in the context of its module's injector.
|
101
|
+
// If set to 'root', the component's dependency injections would only be derived from the root
|
102
|
+
// injector and may lose context if the component is created within a lazy-loaded module.
|
103
|
+
providedIn: 'any',
|
104
|
+
}]
|
105
|
+
}], ctorParameters: function () { return [{ type: i0.ApplicationRef }, { type: i0.Injector }, { type: i1.SkyAppWindowRef }, { type: i0.RendererFactory2 }, { type: i0.EnvironmentInjector }]; } });
|
106
|
+
//# 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  EnvironmentInjector,\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 * @internal\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 lose context if the component is created within a lazy-loaded module.\n  providedIn: 'any',\n})\nexport class SkyDynamicComponentService {\n  #applicationRef: ApplicationRef;\n\n  #environmentInjector: EnvironmentInjector;\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    environmentInjector: EnvironmentInjector\n  ) {\n    this.#applicationRef = applicationRef;\n    this.#injector = injector;\n    this.#windowRef = windowRef;\n    this.#environmentInjector = environmentInjector;\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: options.parentInjector || this.#injector,\n    });\n\n    let componentRef: ComponentRef<T>;\n\n    if (options.viewContainerRef) {\n      componentRef = options.viewContainerRef.createComponent(componentType, {\n        injector,\n      });\n    } else {\n      componentRef = createComponent<T>(componentType, {\n        environmentInjector: this.#environmentInjector,\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\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"]}
|
@@ -6,13 +6,13 @@ export class SkyAppFormat {
|
|
6
6
|
return args[parseInt(capture, 10)];
|
7
7
|
});
|
8
8
|
}
|
9
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyAppFormat, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
10
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyAppFormat, providedIn: 'root' }); }
|
9
11
|
}
|
10
|
-
|
11
|
-
SkyAppFormat.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyAppFormat, providedIn: 'root' });
|
12
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyAppFormat, decorators: [{
|
12
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyAppFormat, decorators: [{
|
13
13
|
type: Injectable,
|
14
14
|
args: [{
|
15
15
|
providedIn: 'root',
|
16
16
|
}]
|
17
17
|
}] });
|
18
|
-
//# sourceMappingURL=data:application/json;base64,
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBwLWZvcm1hdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9jb3JlL3NyYy9saWIvbW9kdWxlcy9mb3JtYXQvYXBwLWZvcm1hdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUszQyxNQUFNLE9BQU8sWUFBWTtJQUNoQixVQUFVLENBQUMsTUFBYyxFQUFFLEdBQUcsSUFBVztRQUM5QyxPQUFPLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQyxPQUFPLENBQzNCLFlBQVksRUFDWixVQUFVLEtBQUssRUFBRSxPQUFPO1lBQ3RCLE9BQU8sSUFBSSxDQUFDLFFBQVEsQ0FBQyxPQUFPLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQztRQUNyQyxDQUFDLENBQ0YsQ0FBQztJQUNKLENBQUM7OEdBUlUsWUFBWTtrSEFBWixZQUFZLGNBRlgsTUFBTTs7MkZBRVAsWUFBWTtrQkFIeEIsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBJbmplY3RhYmxlKHtcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnLFxufSlcbmV4cG9ydCBjbGFzcyBTa3lBcHBGb3JtYXQge1xuICBwdWJsaWMgZm9ybWF0VGV4dChmb3JtYXQ6IHN0cmluZywgLi4uYXJnczogYW55W10pOiBzdHJpbmcge1xuICAgIHJldHVybiBTdHJpbmcoZm9ybWF0KS5yZXBsYWNlKFxuICAgICAgL1xceyhcXGQrKVxcfS9nLFxuICAgICAgZnVuY3Rpb24gKG1hdGNoLCBjYXB0dXJlKTogc3RyaW5nIHtcbiAgICAgICAgcmV0dXJuIGFyZ3NbcGFyc2VJbnQoY2FwdHVyZSwgMTApXTtcbiAgICAgIH1cbiAgICApO1xuICB9XG59XG4iXX0=
|
@@ -0,0 +1,31 @@
|
|
1
|
+
import { Directive } from '@angular/core';
|
2
|
+
import * as i0 from "@angular/core";
|
3
|
+
import * as i1 from "./id.service";
|
4
|
+
/**
|
5
|
+
* Sets the element's `id` attribute to a unique ID. To reference this unique ID on other elements,
|
6
|
+
* such as in a `label` element's `for` attribute, assign this directive to a template reference
|
7
|
+
* variable, then use its `id` property.
|
8
|
+
*/
|
9
|
+
export class SkyIdDirective {
|
10
|
+
get id() {
|
11
|
+
return this.#_id;
|
12
|
+
}
|
13
|
+
#_id;
|
14
|
+
constructor(elRef, renderer, idSvc) {
|
15
|
+
// Generate and apply the ID before the template is rendered
|
16
|
+
// to avoid a changed-after-checked error.
|
17
|
+
const id = idSvc.generateId();
|
18
|
+
renderer.setAttribute(elRef.nativeElement, 'id', id);
|
19
|
+
this.#_id = id;
|
20
|
+
}
|
21
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyIdDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i1.SkyIdService }], target: i0.ɵɵFactoryTarget.Directive }); }
|
22
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.1.7", type: SkyIdDirective, selector: "[skyId]", exportAs: ["skyId"], ngImport: i0 }); }
|
23
|
+
}
|
24
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyIdDirective, decorators: [{
|
25
|
+
type: Directive,
|
26
|
+
args: [{
|
27
|
+
selector: '[skyId]',
|
28
|
+
exportAs: 'skyId',
|
29
|
+
}]
|
30
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i1.SkyIdService }]; } });
|
31
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWQuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL2NvcmUvc3JjL2xpYi9tb2R1bGVzL2lkL2lkLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUF5QixNQUFNLGVBQWUsQ0FBQzs7O0FBSWpFOzs7O0dBSUc7QUFLSCxNQUFNLE9BQU8sY0FBYztJQUN6QixJQUFXLEVBQUU7UUFDWCxPQUFPLElBQUksQ0FBQyxJQUFJLENBQUM7SUFDbkIsQ0FBQztJQUVELElBQUksQ0FBUztJQUViLFlBQVksS0FBaUIsRUFBRSxRQUFtQixFQUFFLEtBQW1CO1FBQ3JFLDREQUE0RDtRQUM1RCwwQ0FBMEM7UUFDMUMsTUFBTSxFQUFFLEdBQUcsS0FBSyxDQUFDLFVBQVUsRUFBRSxDQUFDO1FBRTlCLFFBQVEsQ0FBQyxZQUFZLENBQUMsS0FBSyxDQUFDLGFBQWEsRUFBRSxJQUFJLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFFckQsSUFBSSxDQUFDLElBQUksR0FBRyxFQUFFLENBQUM7SUFDakIsQ0FBQzs4R0FmVSxjQUFjO2tHQUFkLGNBQWM7OzJGQUFkLGNBQWM7a0JBSjFCLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLFNBQVM7b0JBQ25CLFFBQVEsRUFBRSxPQUFPO2lCQUNsQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgRWxlbWVudFJlZiwgUmVuZGVyZXIyIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IFNreUlkU2VydmljZSB9IGZyb20gJy4vaWQuc2VydmljZSc7XG5cbi8qKlxuICogU2V0cyB0aGUgZWxlbWVudCdzIGBpZGAgYXR0cmlidXRlIHRvIGEgdW5pcXVlIElELiBUbyByZWZlcmVuY2UgdGhpcyB1bmlxdWUgSUQgb24gb3RoZXIgZWxlbWVudHMsXG4gKiBzdWNoIGFzIGluIGEgYGxhYmVsYCBlbGVtZW50J3MgYGZvcmAgYXR0cmlidXRlLCBhc3NpZ24gdGhpcyBkaXJlY3RpdmUgdG8gYSB0ZW1wbGF0ZSByZWZlcmVuY2VcbiAqIHZhcmlhYmxlLCB0aGVuIHVzZSBpdHMgYGlkYCBwcm9wZXJ0eS5cbiAqL1xuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnW3NreUlkXScsXG4gIGV4cG9ydEFzOiAnc2t5SWQnLFxufSlcbmV4cG9ydCBjbGFzcyBTa3lJZERpcmVjdGl2ZSB7XG4gIHB1YmxpYyBnZXQgaWQoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gdGhpcy4jX2lkO1xuICB9XG5cbiAgI19pZDogc3RyaW5nO1xuXG4gIGNvbnN0cnVjdG9yKGVsUmVmOiBFbGVtZW50UmVmLCByZW5kZXJlcjogUmVuZGVyZXIyLCBpZFN2YzogU2t5SWRTZXJ2aWNlKSB7XG4gICAgLy8gR2VuZXJhdGUgYW5kIGFwcGx5IHRoZSBJRCBiZWZvcmUgdGhlIHRlbXBsYXRlIGlzIHJlbmRlcmVkXG4gICAgLy8gdG8gYXZvaWQgYSBjaGFuZ2VkLWFmdGVyLWNoZWNrZWQgZXJyb3IuXG4gICAgY29uc3QgaWQgPSBpZFN2Yy5nZW5lcmF0ZUlkKCk7XG5cbiAgICByZW5kZXJlci5zZXRBdHRyaWJ1dGUoZWxSZWYubmF0aXZlRWxlbWVudCwgJ2lkJywgaWQpO1xuXG4gICAgdGhpcy4jX2lkID0gaWQ7XG4gIH1cbn1cbiJdfQ==
|
@@ -2,15 +2,15 @@ import { NgModule } from '@angular/core';
|
|
2
2
|
import { SkyIdDirective } from './id.directive';
|
3
3
|
import * as i0 from "@angular/core";
|
4
4
|
export class SkyIdModule {
|
5
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyIdModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
6
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.1.7", ngImport: i0, type: SkyIdModule, declarations: [SkyIdDirective], exports: [SkyIdDirective] }); }
|
7
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyIdModule }); }
|
5
8
|
}
|
6
|
-
|
7
|
-
SkyIdModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.9", ngImport: i0, type: SkyIdModule, declarations: [SkyIdDirective], exports: [SkyIdDirective] });
|
8
|
-
SkyIdModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyIdModule });
|
9
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyIdModule, decorators: [{
|
9
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyIdModule, decorators: [{
|
10
10
|
type: NgModule,
|
11
11
|
args: [{
|
12
12
|
declarations: [SkyIdDirective],
|
13
13
|
exports: [SkyIdDirective],
|
14
14
|
}]
|
15
15
|
}] });
|
16
|
-
//# sourceMappingURL=data:application/json;base64,
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWQubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL2NvcmUvc3JjL2xpYi9tb2R1bGVzL2lkL2lkLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXpDLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7QUFNaEQsTUFBTSxPQUFPLFdBQVc7OEdBQVgsV0FBVzsrR0FBWCxXQUFXLGlCQUhQLGNBQWMsYUFDbkIsY0FBYzsrR0FFYixXQUFXOzsyRkFBWCxXQUFXO2tCQUp2QixRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRSxDQUFDLGNBQWMsQ0FBQztvQkFDOUIsT0FBTyxFQUFFLENBQUMsY0FBYyxDQUFDO2lCQUMxQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IFNreUlkRGlyZWN0aXZlIH0gZnJvbSAnLi9pZC5kaXJlY3RpdmUnO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtTa3lJZERpcmVjdGl2ZV0sXG4gIGV4cG9ydHM6IFtTa3lJZERpcmVjdGl2ZV0sXG59KVxuZXhwb3J0IGNsYXNzIFNreUlkTW9kdWxlIHt9XG4iXX0=
|
@@ -12,13 +12,13 @@ export class SkyIdService {
|
|
12
12
|
// elements with the same ID across sessions.
|
13
13
|
return `sky-id-gen__${new Date().getTime()}__${idIndex}`;
|
14
14
|
}
|
15
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyIdService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
16
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyIdService, providedIn: 'root' }); }
|
15
17
|
}
|
16
|
-
|
17
|
-
SkyIdService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyIdService, providedIn: 'root' });
|
18
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyIdService, decorators: [{
|
18
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyIdService, decorators: [{
|
19
19
|
type: Injectable,
|
20
20
|
args: [{
|
21
21
|
providedIn: 'root',
|
22
22
|
}]
|
23
23
|
}] });
|
24
|
-
//# sourceMappingURL=data:application/json;base64,
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWQuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9jb3JlL3NyYy9saWIvbW9kdWxlcy9pZC9pZC5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBRTNDLElBQUksT0FBTyxHQUFHLENBQUMsQ0FBQztBQUVoQjs7R0FFRztBQUlILE1BQU0sT0FBTyxZQUFZO0lBQ2hCLFVBQVU7UUFDZixPQUFPLEVBQUUsQ0FBQztRQUVWLGtHQUFrRztRQUNsRyxpR0FBaUc7UUFDakcsNkNBQTZDO1FBQzdDLE9BQU8sZUFBZSxJQUFJLElBQUksRUFBRSxDQUFDLE9BQU8sRUFBRSxLQUFLLE9BQU8sRUFBRSxDQUFDO0lBQzNELENBQUM7OEdBUlUsWUFBWTtrSEFBWixZQUFZLGNBRlgsTUFBTTs7MkZBRVAsWUFBWTtrQkFIeEIsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmxldCBpZEluZGV4ID0gMDtcblxuLyoqXG4gKiBHZW5lcmF0ZXMgdW5pcXVlIElEcyB0byBiZSB1c2VkIHdpdGggSFRNTCBlbGVtZW50cy5cbiAqL1xuQEluamVjdGFibGUoe1xuICBwcm92aWRlZEluOiAncm9vdCcsXG59KVxuZXhwb3J0IGNsYXNzIFNreUlkU2VydmljZSB7XG4gIHB1YmxpYyBnZW5lcmF0ZUlkKCk6IHN0cmluZyB7XG4gICAgaWRJbmRleCsrO1xuXG4gICAgLy8gSW5jbHVkZSB0aW1lc3RhbXAgYW5kIGFuIGluY3JlbWVudGluZyBpbmRleCB0byBndWFyYW50ZWUgdW5pcXVlIElEcyBib3RoIGR1cmluZyB0aGUgYXBwbGljYXRpb25cbiAgICAvLyBsaWZlY3ljbGUgYXMgd2VsbCBhcyBhY3Jvc3Mgc2Vzc2lvbnMsIHNpbmNlIGJyb3dzZXJzIHdpbGwgdHJ5IHRvIGFwcGx5IGF1dG9jb21wbGV0ZSBvcHRpb25zIHRvXG4gICAgLy8gZWxlbWVudHMgd2l0aCB0aGUgc2FtZSBJRCBhY3Jvc3Mgc2Vzc2lvbnMuXG4gICAgcmV0dXJuIGBza3ktaWQtZ2VuX18ke25ldyBEYXRlKCkuZ2V0VGltZSgpfV9fJHtpZEluZGV4fWA7XG4gIH1cbn1cbiJdfQ==
|
@@ -0,0 +1,22 @@
|
|
1
|
+
import { Injectable } from '@angular/core';
|
2
|
+
import { Subject } from 'rxjs';
|
3
|
+
import * as i0 from "@angular/core";
|
4
|
+
/**
|
5
|
+
* @internal
|
6
|
+
*/
|
7
|
+
export class SkyLayoutHostService {
|
8
|
+
get hostLayoutForChild() {
|
9
|
+
return this.#hostLayoutForChildObs;
|
10
|
+
}
|
11
|
+
#hostLayoutForChild = new Subject();
|
12
|
+
#hostLayoutForChildObs = this.#hostLayoutForChild.asObservable();
|
13
|
+
setHostLayoutForChild(layout) {
|
14
|
+
this.#hostLayoutForChild.next(layout);
|
15
|
+
}
|
16
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyLayoutHostService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
17
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyLayoutHostService }); }
|
18
|
+
}
|
19
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyLayoutHostService, decorators: [{
|
20
|
+
type: Injectable
|
21
|
+
}] });
|
22
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGF5b3V0LWhvc3Quc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9jb3JlL3NyYy9saWIvbW9kdWxlcy9sYXlvdXQtaG9zdC9sYXlvdXQtaG9zdC5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFM0MsT0FBTyxFQUFjLE9BQU8sRUFBRSxNQUFNLE1BQU0sQ0FBQzs7QUFJM0M7O0dBRUc7QUFFSCxNQUFNLE9BQU8sb0JBQW9CO0lBQy9CLElBQVcsa0JBQWtCO1FBQzNCLE9BQU8sSUFBSSxDQUFDLHNCQUFzQixDQUFDO0lBQ3JDLENBQUM7SUFFRCxtQkFBbUIsR0FBRyxJQUFJLE9BQU8sRUFBNkIsQ0FBQztJQUMvRCxzQkFBc0IsR0FBRyxJQUFJLENBQUMsbUJBQW1CLENBQUMsWUFBWSxFQUFFLENBQUM7SUFFMUQscUJBQXFCLENBQUMsTUFBaUM7UUFDNUQsSUFBSSxDQUFDLG1CQUFtQixDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUN4QyxDQUFDOzhHQVZVLG9CQUFvQjtrSEFBcEIsb0JBQW9COzsyRkFBcEIsb0JBQW9CO2tCQURoQyxVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBPYnNlcnZhYmxlLCBTdWJqZWN0IH0gZnJvbSAncnhqcyc7XG5cbmltcG9ydCB7IFNreUxheW91dEhvc3RGb3JDaGlsZEFyZ3MgfSBmcm9tICcuL2xheW91dC1ob3N0LWZvci1jaGlsZC1hcmdzJztcblxuLyoqXG4gKiBAaW50ZXJuYWxcbiAqL1xuQEluamVjdGFibGUoKVxuZXhwb3J0IGNsYXNzIFNreUxheW91dEhvc3RTZXJ2aWNlIHtcbiAgcHVibGljIGdldCBob3N0TGF5b3V0Rm9yQ2hpbGQoKTogT2JzZXJ2YWJsZTxTa3lMYXlvdXRIb3N0Rm9yQ2hpbGRBcmdzPiB7XG4gICAgcmV0dXJuIHRoaXMuI2hvc3RMYXlvdXRGb3JDaGlsZE9icztcbiAgfVxuXG4gICNob3N0TGF5b3V0Rm9yQ2hpbGQgPSBuZXcgU3ViamVjdDxTa3lMYXlvdXRIb3N0Rm9yQ2hpbGRBcmdzPigpO1xuICAjaG9zdExheW91dEZvckNoaWxkT2JzID0gdGhpcy4jaG9zdExheW91dEZvckNoaWxkLmFzT2JzZXJ2YWJsZSgpO1xuXG4gIHB1YmxpYyBzZXRIb3N0TGF5b3V0Rm9yQ2hpbGQobGF5b3V0OiBTa3lMYXlvdXRIb3N0Rm9yQ2hpbGRBcmdzKTogdm9pZCB7XG4gICAgdGhpcy4jaG9zdExheW91dEZvckNoaWxkLm5leHQobGF5b3V0KTtcbiAgfVxufVxuIl19
|