@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,131 @@
|
|
1
|
+
import { Directive, Input, Optional, } from '@angular/core';
|
2
|
+
import { Subject } from 'rxjs';
|
3
|
+
import { takeUntil } from 'rxjs/operators';
|
4
|
+
import * as i0 from "@angular/core";
|
5
|
+
import * as i1 from "../mutation/mutation-observer-service";
|
6
|
+
import * as i2 from "./viewkeeper.service";
|
7
|
+
import * as i3 from "../scrollable-host/scrollable-host.service";
|
8
|
+
export class SkyViewkeeperDirective {
|
9
|
+
set skyViewkeeper(value) {
|
10
|
+
this.#_skyViewkeeper = value;
|
11
|
+
this.#detectElements();
|
12
|
+
}
|
13
|
+
get skyViewkeeper() {
|
14
|
+
return this.#_skyViewkeeper;
|
15
|
+
}
|
16
|
+
#_skyViewkeeper;
|
17
|
+
#currentViewkeeperEls;
|
18
|
+
#el;
|
19
|
+
#mutationObserverSvc;
|
20
|
+
#observer;
|
21
|
+
#scrollableHostSvc;
|
22
|
+
#scrollableHostWatchUnsubscribe;
|
23
|
+
#viewkeepers = [];
|
24
|
+
#viewkeeperSvc;
|
25
|
+
constructor(el, mutationObserverSvc, viewkeeperSvc, scrollableHostSvc) {
|
26
|
+
this.#el = el;
|
27
|
+
this.#mutationObserverSvc = mutationObserverSvc;
|
28
|
+
this.#viewkeeperSvc = viewkeeperSvc;
|
29
|
+
this.#scrollableHostSvc = scrollableHostSvc;
|
30
|
+
}
|
31
|
+
ngOnInit() {
|
32
|
+
this.#observer = this.#mutationObserverSvc.create(() => this.#detectElements());
|
33
|
+
this.#observer.observe(this.#el.nativeElement, {
|
34
|
+
childList: true,
|
35
|
+
subtree: true,
|
36
|
+
});
|
37
|
+
}
|
38
|
+
ngOnDestroy() {
|
39
|
+
/*istanbul ignore else*/
|
40
|
+
if (this.#observer) {
|
41
|
+
this.#observer.disconnect();
|
42
|
+
}
|
43
|
+
/*istanbul ignore else*/
|
44
|
+
if (this.#scrollableHostWatchUnsubscribe) {
|
45
|
+
this.#scrollableHostWatchUnsubscribe.next();
|
46
|
+
this.#scrollableHostWatchUnsubscribe.complete();
|
47
|
+
}
|
48
|
+
this.#destroyViewkeepers();
|
49
|
+
}
|
50
|
+
#destroyViewkeepers() {
|
51
|
+
for (const viewkeeper of this.#viewkeepers) {
|
52
|
+
this.#viewkeeperSvc.destroy(viewkeeper);
|
53
|
+
}
|
54
|
+
this.#viewkeepers = [];
|
55
|
+
}
|
56
|
+
#getViewkeeperEls() {
|
57
|
+
let viewkeeperEls = [];
|
58
|
+
if (this.skyViewkeeper) {
|
59
|
+
viewkeeperEls = [];
|
60
|
+
for (const item of this.skyViewkeeper) {
|
61
|
+
const matchingEls = Array.from(this.#el.nativeElement.querySelectorAll(item));
|
62
|
+
viewkeeperEls = [...viewkeeperEls, ...matchingEls];
|
63
|
+
}
|
64
|
+
}
|
65
|
+
return viewkeeperEls;
|
66
|
+
}
|
67
|
+
#viewkeeperElsChanged(viewkeeperEls) {
|
68
|
+
if (!viewkeeperEls !== !this.#currentViewkeeperEls) {
|
69
|
+
return true;
|
70
|
+
}
|
71
|
+
if (viewkeeperEls && this.#currentViewkeeperEls) {
|
72
|
+
if (viewkeeperEls.length !== this.#currentViewkeeperEls.length) {
|
73
|
+
return true;
|
74
|
+
}
|
75
|
+
for (let i = 0, n = viewkeeperEls.length; i < n; i++) {
|
76
|
+
if (viewkeeperEls[i] !== this.#currentViewkeeperEls[i]) {
|
77
|
+
return true;
|
78
|
+
}
|
79
|
+
}
|
80
|
+
}
|
81
|
+
return false;
|
82
|
+
}
|
83
|
+
#detectElements() {
|
84
|
+
const viewkeeperEls = this.#getViewkeeperEls();
|
85
|
+
if (this.#viewkeeperElsChanged(viewkeeperEls)) {
|
86
|
+
if (this.#scrollableHostWatchUnsubscribe) {
|
87
|
+
this.#scrollableHostWatchUnsubscribe.next();
|
88
|
+
this.#scrollableHostWatchUnsubscribe.complete();
|
89
|
+
this.#scrollableHostWatchUnsubscribe = new Subject();
|
90
|
+
}
|
91
|
+
else {
|
92
|
+
this.#scrollableHostWatchUnsubscribe = new Subject();
|
93
|
+
}
|
94
|
+
if (this.#scrollableHostSvc) {
|
95
|
+
this.#scrollableHostSvc
|
96
|
+
.watchScrollableHost(this.#el)
|
97
|
+
.pipe(takeUntil(this.#scrollableHostWatchUnsubscribe))
|
98
|
+
.subscribe((scrollableHost) => {
|
99
|
+
this.#destroyViewkeepers();
|
100
|
+
let previousViewkeeperEl;
|
101
|
+
for (const viewkeeperEl of viewkeeperEls) {
|
102
|
+
this.#viewkeepers.push(this.#viewkeeperSvc.create({
|
103
|
+
boundaryEl: this.#el.nativeElement,
|
104
|
+
scrollableHost: scrollableHost instanceof HTMLElement
|
105
|
+
? scrollableHost
|
106
|
+
: undefined,
|
107
|
+
el: viewkeeperEl,
|
108
|
+
setWidth: true,
|
109
|
+
verticalOffsetEl: previousViewkeeperEl,
|
110
|
+
}));
|
111
|
+
previousViewkeeperEl = viewkeeperEl;
|
112
|
+
}
|
113
|
+
});
|
114
|
+
}
|
115
|
+
this.#currentViewkeeperEls = viewkeeperEls;
|
116
|
+
}
|
117
|
+
}
|
118
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyViewkeeperDirective, deps: [{ token: i0.ElementRef }, { token: i1.SkyMutationObserverService }, { token: i2.SkyViewkeeperService }, { token: i3.SkyScrollableHostService, optional: true }], target: i0.ɵɵFactoryTarget.Directive }); }
|
119
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.1.7", type: SkyViewkeeperDirective, selector: "[skyViewkeeper]", inputs: { skyViewkeeper: "skyViewkeeper" }, ngImport: i0 }); }
|
120
|
+
}
|
121
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyViewkeeperDirective, decorators: [{
|
122
|
+
type: Directive,
|
123
|
+
args: [{
|
124
|
+
selector: '[skyViewkeeper]',
|
125
|
+
}]
|
126
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.SkyMutationObserverService }, { type: i2.SkyViewkeeperService }, { type: i3.SkyScrollableHostService, decorators: [{
|
127
|
+
type: Optional
|
128
|
+
}] }]; }, propDecorators: { skyViewkeeper: [{
|
129
|
+
type: Input
|
130
|
+
}] } });
|
131
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"viewkeeper.directive.js","sourceRoot":"","sources":["../../../../../../../../libs/components/core/src/lib/modules/viewkeeper/viewkeeper.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  ElementRef,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n} from '@angular/core';\n\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyMutationObserverService } from '../mutation/mutation-observer-service';\nimport { SkyScrollableHostService } from '../scrollable-host/scrollable-host.service';\n\nimport { SkyViewkeeper } from './viewkeeper';\nimport { SkyViewkeeperService } from './viewkeeper.service';\n\n@Directive({\n  selector: '[skyViewkeeper]',\n})\nexport class SkyViewkeeperDirective implements OnInit, OnDestroy {\n  @Input()\n  public set skyViewkeeper(value: string[] | undefined) {\n    this.#_skyViewkeeper = value;\n\n    this.#detectElements();\n  }\n\n  public get skyViewkeeper(): string[] | undefined {\n    return this.#_skyViewkeeper;\n  }\n\n  #_skyViewkeeper: string[] | undefined;\n\n  #currentViewkeeperEls: HTMLElement[] | undefined;\n\n  #el: ElementRef;\n\n  #mutationObserverSvc: SkyMutationObserverService;\n\n  #observer: MutationObserver | undefined;\n\n  #scrollableHostSvc: SkyScrollableHostService | undefined;\n\n  #scrollableHostWatchUnsubscribe: Subject<void> | undefined;\n\n  #viewkeepers: SkyViewkeeper[] = [];\n\n  #viewkeeperSvc: SkyViewkeeperService;\n\n  constructor(\n    el: ElementRef,\n    mutationObserverSvc: SkyMutationObserverService,\n    viewkeeperSvc: SkyViewkeeperService,\n    @Optional() scrollableHostSvc?: SkyScrollableHostService\n  ) {\n    this.#el = el;\n    this.#mutationObserverSvc = mutationObserverSvc;\n    this.#viewkeeperSvc = viewkeeperSvc;\n    this.#scrollableHostSvc = scrollableHostSvc;\n  }\n\n  public ngOnInit(): void {\n    this.#observer = this.#mutationObserverSvc.create(() =>\n      this.#detectElements()\n    );\n\n    this.#observer.observe(this.#el.nativeElement, {\n      childList: true,\n      subtree: true,\n    });\n  }\n\n  public ngOnDestroy(): void {\n    /*istanbul ignore else*/\n    if (this.#observer) {\n      this.#observer.disconnect();\n    }\n\n    /*istanbul ignore else*/\n    if (this.#scrollableHostWatchUnsubscribe) {\n      this.#scrollableHostWatchUnsubscribe.next();\n      this.#scrollableHostWatchUnsubscribe.complete();\n    }\n\n    this.#destroyViewkeepers();\n  }\n\n  #destroyViewkeepers(): void {\n    for (const viewkeeper of this.#viewkeepers) {\n      this.#viewkeeperSvc.destroy(viewkeeper);\n    }\n\n    this.#viewkeepers = [];\n  }\n\n  #getViewkeeperEls(): HTMLElement[] {\n    let viewkeeperEls: HTMLElement[] = [];\n\n    if (this.skyViewkeeper) {\n      viewkeeperEls = [];\n\n      for (const item of this.skyViewkeeper) {\n        const matchingEls = Array.from(\n          (this.#el.nativeElement as HTMLElement).querySelectorAll(item)\n        ) as HTMLElement[];\n\n        viewkeeperEls = [...viewkeeperEls, ...matchingEls];\n      }\n    }\n\n    return viewkeeperEls;\n  }\n\n  #viewkeeperElsChanged(viewkeeperEls: HTMLElement[]): boolean {\n    if (!viewkeeperEls !== !this.#currentViewkeeperEls) {\n      return true;\n    }\n\n    if (viewkeeperEls && this.#currentViewkeeperEls) {\n      if (viewkeeperEls.length !== this.#currentViewkeeperEls.length) {\n        return true;\n      }\n\n      for (let i = 0, n = viewkeeperEls.length; i < n; i++) {\n        if (viewkeeperEls[i] !== this.#currentViewkeeperEls[i]) {\n          return true;\n        }\n      }\n    }\n\n    return false;\n  }\n\n  #detectElements(): void {\n    const viewkeeperEls = this.#getViewkeeperEls();\n\n    if (this.#viewkeeperElsChanged(viewkeeperEls)) {\n      if (this.#scrollableHostWatchUnsubscribe) {\n        this.#scrollableHostWatchUnsubscribe.next();\n        this.#scrollableHostWatchUnsubscribe.complete();\n        this.#scrollableHostWatchUnsubscribe = new Subject();\n      } else {\n        this.#scrollableHostWatchUnsubscribe = new Subject();\n      }\n\n      if (this.#scrollableHostSvc) {\n        this.#scrollableHostSvc\n          .watchScrollableHost(this.#el)\n          .pipe(takeUntil(this.#scrollableHostWatchUnsubscribe))\n          .subscribe((scrollableHost) => {\n            this.#destroyViewkeepers();\n\n            let previousViewkeeperEl: HTMLElement | undefined;\n\n            for (const viewkeeperEl of viewkeeperEls) {\n              this.#viewkeepers.push(\n                this.#viewkeeperSvc.create({\n                  boundaryEl: this.#el.nativeElement,\n                  scrollableHost:\n                    scrollableHost instanceof HTMLElement\n                      ? scrollableHost\n                      : undefined,\n                  el: viewkeeperEl,\n                  setWidth: true,\n                  verticalOffsetEl: previousViewkeeperEl,\n                })\n              );\n\n              previousViewkeeperEl = viewkeeperEl;\n            }\n          });\n      }\n\n      this.#currentViewkeeperEls = viewkeeperEls;\n    }\n  }\n}\n"]}
|
@@ -0,0 +1,283 @@
|
|
1
|
+
const CLS_VIEWKEEPER_FIXED = 'sky-viewkeeper-fixed';
|
2
|
+
const EVT_AFTER_VIEWKEEPER_SYNC = 'afterViewkeeperSync';
|
3
|
+
let styleEl;
|
4
|
+
let nextIdIndex;
|
5
|
+
function ensureStyleEl() {
|
6
|
+
if (!styleEl) {
|
7
|
+
styleEl = document.createElement('style');
|
8
|
+
const css = document.createTextNode(`
|
9
|
+
.${CLS_VIEWKEEPER_FIXED} {
|
10
|
+
position: fixed !important;
|
11
|
+
z-index: 999;
|
12
|
+
opacity: 0.95;
|
13
|
+
overflow: hidden;
|
14
|
+
}
|
15
|
+
|
16
|
+
.sky-theme-modern .${CLS_VIEWKEEPER_FIXED} {
|
17
|
+
box-shadow: 0px 1px 8px -1px rgba(0, 0, 0, 0.3);
|
18
|
+
opacity: initial;
|
19
|
+
}
|
20
|
+
`);
|
21
|
+
styleEl.appendChild(css);
|
22
|
+
document.head.appendChild(styleEl);
|
23
|
+
}
|
24
|
+
}
|
25
|
+
function nextId() {
|
26
|
+
nextIdIndex = (nextIdIndex || 0) + 1;
|
27
|
+
return 'viewkeeper-' + nextIdIndex;
|
28
|
+
}
|
29
|
+
function getOffset(el, scrollableHost) {
|
30
|
+
const rect = el.getBoundingClientRect();
|
31
|
+
const parent = scrollableHost ? scrollableHost : document.documentElement;
|
32
|
+
return {
|
33
|
+
top: rect.top + parent.scrollTop,
|
34
|
+
left: rect.left + parent.scrollLeft,
|
35
|
+
};
|
36
|
+
}
|
37
|
+
function px(value) {
|
38
|
+
let pxValue = value ? value.toString() : '';
|
39
|
+
if (typeof value === 'number') {
|
40
|
+
pxValue = value + 'px';
|
41
|
+
}
|
42
|
+
return pxValue;
|
43
|
+
}
|
44
|
+
function setElPosition(el, left, top, width, marginTop, clipTop, clipLeft) {
|
45
|
+
el.style.top = px(top);
|
46
|
+
el.style.left = px(left);
|
47
|
+
el.style.marginTop = px(marginTop);
|
48
|
+
el.style.clipPath =
|
49
|
+
clipTop || clipLeft ? `inset(${px(clipTop)} 0 0 ${px(clipLeft)})` : 'none';
|
50
|
+
/*istanbul ignore else*/
|
51
|
+
/* sanity check */
|
52
|
+
if (width !== null) {
|
53
|
+
el.style.width = px(width);
|
54
|
+
}
|
55
|
+
}
|
56
|
+
function getHeightWithMargin(el) {
|
57
|
+
const computedStyle = getComputedStyle(el);
|
58
|
+
return (el.offsetHeight +
|
59
|
+
parseInt(computedStyle.marginTop, 10) +
|
60
|
+
parseInt(computedStyle.marginBottom, 10));
|
61
|
+
}
|
62
|
+
function createCustomEvent(name) {
|
63
|
+
const evt = document.createEvent('CustomEvent');
|
64
|
+
evt.initCustomEvent(name, false, false, undefined);
|
65
|
+
return evt;
|
66
|
+
}
|
67
|
+
export class SkyViewkeeper {
|
68
|
+
#boundaryEl;
|
69
|
+
#el;
|
70
|
+
#id;
|
71
|
+
#setWidth;
|
72
|
+
#verticalOffset;
|
73
|
+
#verticalOffsetEl;
|
74
|
+
#viewportMarginTop = 0;
|
75
|
+
#currentElFixedLeft;
|
76
|
+
#currentElFixedTop;
|
77
|
+
#currentElFixedWidth;
|
78
|
+
#currentElClipLeft;
|
79
|
+
#currentElClipTop;
|
80
|
+
#isDestroyed = false;
|
81
|
+
#scrollableHost;
|
82
|
+
#syncElPositionHandler;
|
83
|
+
#intersectionObserver;
|
84
|
+
constructor(options) {
|
85
|
+
options = options || /* istanbul ignore next */ {};
|
86
|
+
this.#el = options.el;
|
87
|
+
this.#boundaryEl = options.boundaryEl;
|
88
|
+
if (!this.#el) {
|
89
|
+
throw new Error('[SkyViewkeeper] The option `el` is required.');
|
90
|
+
}
|
91
|
+
if (!this.#boundaryEl) {
|
92
|
+
throw new Error('[SkyViewkeeper] The option `boundaryEl` is required.');
|
93
|
+
}
|
94
|
+
const el = this.#el;
|
95
|
+
const boundaryEl = this.#boundaryEl;
|
96
|
+
this.#setWidth = !!options.setWidth;
|
97
|
+
this.#id = nextId();
|
98
|
+
this.#scrollableHost = options.scrollableHost;
|
99
|
+
this.#verticalOffset = options.verticalOffset || 0;
|
100
|
+
this.#verticalOffsetEl = options.verticalOffsetEl;
|
101
|
+
// Only set viewport margin if the scrollable host is undefined.
|
102
|
+
if (!this.#scrollableHost) {
|
103
|
+
this.#viewportMarginTop = options.viewportMarginTop ?? 0;
|
104
|
+
}
|
105
|
+
this.#syncElPositionHandler = () => this.syncElPosition(el, boundaryEl);
|
106
|
+
if (this.#verticalOffsetEl) {
|
107
|
+
this.#verticalOffsetEl.addEventListener(EVT_AFTER_VIEWKEEPER_SYNC, this.#syncElPositionHandler);
|
108
|
+
}
|
109
|
+
window.addEventListener('scroll', this.#syncElPositionHandler, true);
|
110
|
+
window.addEventListener('resize', this.#syncElPositionHandler);
|
111
|
+
window.addEventListener('orientationchange', this.#syncElPositionHandler);
|
112
|
+
ensureStyleEl();
|
113
|
+
this.syncElPosition(el, boundaryEl);
|
114
|
+
}
|
115
|
+
syncElPosition(el, boundaryEl) {
|
116
|
+
const verticalOffset = this.#calculateVerticalOffset();
|
117
|
+
// When the element isn't visible, its size can't be calculated, so don't attempt syncing position in this case.
|
118
|
+
if (el.offsetWidth === 0 && el.offsetHeight === 0) {
|
119
|
+
return;
|
120
|
+
}
|
121
|
+
const boundaryInfo = this.#getBoundaryInfo(el, boundaryEl);
|
122
|
+
const fixedStyles = this.#getFixedStyles(boundaryInfo, verticalOffset);
|
123
|
+
const doFixEl = this.#shouldFixEl(el, boundaryInfo, verticalOffset);
|
124
|
+
if (this.#needsUpdating(doFixEl, fixedStyles)) {
|
125
|
+
if (doFixEl) {
|
126
|
+
this.#fixEl(el, boundaryInfo, fixedStyles);
|
127
|
+
}
|
128
|
+
else {
|
129
|
+
this.#unfixEl(el);
|
130
|
+
}
|
131
|
+
}
|
132
|
+
const evt = createCustomEvent(EVT_AFTER_VIEWKEEPER_SYNC);
|
133
|
+
el.dispatchEvent(evt);
|
134
|
+
}
|
135
|
+
destroy() {
|
136
|
+
if (!this.#isDestroyed) {
|
137
|
+
this.#intersectionObserver?.disconnect();
|
138
|
+
window.removeEventListener('scroll', this.#syncElPositionHandler, true);
|
139
|
+
window.removeEventListener('resize', this.#syncElPositionHandler);
|
140
|
+
window.removeEventListener('orientationchange', this.#syncElPositionHandler);
|
141
|
+
if (this.#el) {
|
142
|
+
this.#unfixEl(this.#el);
|
143
|
+
}
|
144
|
+
if (this.#verticalOffsetEl) {
|
145
|
+
this.#verticalOffsetEl.removeEventListener(EVT_AFTER_VIEWKEEPER_SYNC, this.#syncElPositionHandler);
|
146
|
+
}
|
147
|
+
this.#el = this.#boundaryEl = this.#verticalOffsetEl = undefined;
|
148
|
+
this.#isDestroyed = true;
|
149
|
+
}
|
150
|
+
}
|
151
|
+
#getSpacerId() {
|
152
|
+
return this.#id + '-spacer';
|
153
|
+
}
|
154
|
+
#unfixEl(el) {
|
155
|
+
const spacerEl = document.getElementById(this.#getSpacerId());
|
156
|
+
/*istanbul ignore else*/
|
157
|
+
if (spacerEl?.parentElement) {
|
158
|
+
spacerEl.parentElement.removeChild(spacerEl);
|
159
|
+
}
|
160
|
+
el.classList.remove(CLS_VIEWKEEPER_FIXED);
|
161
|
+
this.#currentElFixedLeft =
|
162
|
+
this.#currentElFixedTop =
|
163
|
+
this.#currentElFixedWidth =
|
164
|
+
undefined;
|
165
|
+
let width = '';
|
166
|
+
if (this.#setWidth) {
|
167
|
+
width = 'auto';
|
168
|
+
}
|
169
|
+
setElPosition(el, '', '', width, '', 0, 0);
|
170
|
+
}
|
171
|
+
#calculateVerticalOffset() {
|
172
|
+
let offset = this.#verticalOffset;
|
173
|
+
if (this.#verticalOffsetEl) {
|
174
|
+
const verticalOffsetElTopStyle = this.#verticalOffsetEl.style.top;
|
175
|
+
const verticalOffsetElTop = parseInt(verticalOffsetElTopStyle, 10) || 0;
|
176
|
+
offset += this.#verticalOffsetEl.offsetHeight + verticalOffsetElTop;
|
177
|
+
}
|
178
|
+
else if (this.#scrollableHost) {
|
179
|
+
offset += this.#scrollableHost.getBoundingClientRect().top;
|
180
|
+
}
|
181
|
+
return offset;
|
182
|
+
}
|
183
|
+
#shouldFixEl(el, boundaryInfo, verticalOffset) {
|
184
|
+
let anchorTop;
|
185
|
+
if (boundaryInfo.spacerEl) {
|
186
|
+
anchorTop = getOffset(boundaryInfo.spacerEl, this.#scrollableHost).top;
|
187
|
+
}
|
188
|
+
else {
|
189
|
+
anchorTop = getOffset(el, this.#scrollableHost).top;
|
190
|
+
}
|
191
|
+
const doFixEl = boundaryInfo.scrollTop + verticalOffset + this.#viewportMarginTop >
|
192
|
+
anchorTop;
|
193
|
+
return doFixEl;
|
194
|
+
}
|
195
|
+
#getFixedStyles(boundaryInfo, verticalOffset) {
|
196
|
+
// If the element needs to be fixed, this will calculate its position. The position
|
197
|
+
// will be 0 (fully visible) unless the user is scrolling the boundary out of view.
|
198
|
+
// In that case, the element should begin to scroll out of view with the
|
199
|
+
// rest of the boundary by setting its top position to a negative value.
|
200
|
+
const elTop = boundaryInfo.boundaryBottom -
|
201
|
+
boundaryInfo.elHeight -
|
202
|
+
boundaryInfo.scrollTop;
|
203
|
+
const elClipTop = elTop < verticalOffset ? verticalOffset - elTop : 0;
|
204
|
+
const elFixedTop = Math.min(elTop, verticalOffset);
|
205
|
+
const elFixedWidth = boundaryInfo.boundaryEl.getBoundingClientRect().width;
|
206
|
+
const elFixedLeft = boundaryInfo.boundaryOffset.left - boundaryInfo.scrollLeft;
|
207
|
+
const elClipLeft = elFixedLeft < 0 ? 0 - elFixedLeft : 0;
|
208
|
+
return {
|
209
|
+
elFixedLeft,
|
210
|
+
elFixedTop,
|
211
|
+
elFixedWidth,
|
212
|
+
elClipLeft,
|
213
|
+
elClipTop,
|
214
|
+
};
|
215
|
+
}
|
216
|
+
#needsUpdating(doFixEl, fixedStyles) {
|
217
|
+
if ((doFixEl &&
|
218
|
+
this.#currentElFixedLeft === fixedStyles.elFixedLeft &&
|
219
|
+
this.#currentElFixedTop === fixedStyles.elFixedTop &&
|
220
|
+
this.#currentElClipLeft === fixedStyles.elClipLeft &&
|
221
|
+
this.#currentElClipTop === fixedStyles.elClipTop &&
|
222
|
+
this.#currentElFixedWidth === fixedStyles.elFixedWidth) ||
|
223
|
+
(!doFixEl &&
|
224
|
+
!(this.#currentElFixedLeft !== undefined &&
|
225
|
+
this.#currentElFixedLeft !== null))) {
|
226
|
+
// The element is either currently fixed and its position and width do not need
|
227
|
+
// to change, or the element is not currently fixed and does not need to be fixed.
|
228
|
+
// No changes are needed.
|
229
|
+
return false;
|
230
|
+
}
|
231
|
+
return true;
|
232
|
+
}
|
233
|
+
#fixEl(el, boundaryInfo, fixedStyles) {
|
234
|
+
/* istanbul ignore else */
|
235
|
+
/* sanity check */
|
236
|
+
if (!boundaryInfo.spacerEl) {
|
237
|
+
const spacerHeight = boundaryInfo.elHeight;
|
238
|
+
const spacerEl = document.createElement('div');
|
239
|
+
spacerEl.id = boundaryInfo.spacerId;
|
240
|
+
spacerEl.style.height = px(spacerHeight);
|
241
|
+
/*istanbul ignore else*/
|
242
|
+
if (el.parentNode) {
|
243
|
+
el.parentNode.insertBefore(spacerEl, el.nextSibling);
|
244
|
+
}
|
245
|
+
}
|
246
|
+
el.classList.add(CLS_VIEWKEEPER_FIXED);
|
247
|
+
this.#currentElFixedTop = fixedStyles.elFixedTop;
|
248
|
+
this.#currentElFixedLeft = fixedStyles.elFixedLeft;
|
249
|
+
this.#currentElClipTop = fixedStyles.elClipTop;
|
250
|
+
this.#currentElClipLeft = fixedStyles.elClipLeft;
|
251
|
+
this.#currentElFixedWidth = fixedStyles.elFixedWidth;
|
252
|
+
let width = 0;
|
253
|
+
if (this.#setWidth) {
|
254
|
+
width = fixedStyles.elFixedWidth;
|
255
|
+
}
|
256
|
+
setElPosition(el, fixedStyles.elFixedLeft, fixedStyles.elFixedTop, width, this.#viewportMarginTop, fixedStyles.elClipTop, fixedStyles.elClipLeft);
|
257
|
+
}
|
258
|
+
#getBoundaryInfo(el, boundaryEl) {
|
259
|
+
const spacerId = this.#getSpacerId();
|
260
|
+
const spacerEl = document.getElementById(spacerId);
|
261
|
+
const boundaryOffset = getOffset(boundaryEl, this.#scrollableHost);
|
262
|
+
const boundaryTop = boundaryOffset.top;
|
263
|
+
const boundaryBottom = boundaryTop + boundaryEl.getBoundingClientRect().height;
|
264
|
+
const scrollLeft = this.#scrollableHost
|
265
|
+
? this.#scrollableHost.scrollLeft
|
266
|
+
: document.documentElement.scrollLeft;
|
267
|
+
const scrollTop = this.#scrollableHost
|
268
|
+
? this.#scrollableHost.scrollTop
|
269
|
+
: document.documentElement.scrollTop;
|
270
|
+
const elHeight = getHeightWithMargin(el);
|
271
|
+
return {
|
272
|
+
boundaryBottom,
|
273
|
+
boundaryOffset,
|
274
|
+
boundaryEl,
|
275
|
+
elHeight,
|
276
|
+
scrollLeft,
|
277
|
+
scrollTop,
|
278
|
+
spacerId,
|
279
|
+
spacerEl,
|
280
|
+
};
|
281
|
+
}
|
282
|
+
}
|
283
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"viewkeeper.js","sourceRoot":"","sources":["../../../../../../../../libs/components/core/src/lib/modules/viewkeeper/viewkeeper.ts"],"names":[],"mappings":"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","sourcesContent":["import { SkyViewkeeperBoundaryInfo } from './viewkeeper-boundary-info';\nimport { SkyViewkeeperFixedStyles } from './viewkeeper-fixed-styles';\nimport { SkyViewkeeperOffset } from './viewkeeper-offset';\nimport { SkyViewkeeperOptions } from './viewkeeper-options';\n\nconst CLS_VIEWKEEPER_FIXED = 'sky-viewkeeper-fixed';\nconst EVT_AFTER_VIEWKEEPER_SYNC = 'afterViewkeeperSync';\n\nlet styleEl: HTMLStyleElement;\nlet nextIdIndex: number;\n\nfunction ensureStyleEl(): void {\n  if (!styleEl) {\n    styleEl = document.createElement('style');\n\n    const css = document.createTextNode(`\n.${CLS_VIEWKEEPER_FIXED} {\n  position: fixed !important;\n  z-index: 999;\n  opacity: 0.95;\n  overflow: hidden;\n}\n\n.sky-theme-modern .${CLS_VIEWKEEPER_FIXED} {\n  box-shadow: 0px 1px 8px -1px rgba(0, 0, 0, 0.3);\n  opacity: initial;\n}\n`);\n\n    styleEl.appendChild(css);\n\n    document.head.appendChild(styleEl);\n  }\n}\n\nfunction nextId(): string {\n  nextIdIndex = (nextIdIndex || 0) + 1;\n\n  return 'viewkeeper-' + nextIdIndex;\n}\n\nfunction getOffset(\n  el: HTMLElement,\n  scrollableHost?: HTMLElement\n): SkyViewkeeperOffset {\n  const rect = el.getBoundingClientRect();\n  const parent = scrollableHost ? scrollableHost : document.documentElement;\n\n  return {\n    top: rect.top + parent.scrollTop,\n    left: rect.left + parent.scrollLeft,\n  };\n}\n\nfunction px(value: number | string): string {\n  let pxValue = value ? value.toString() : '';\n\n  if (typeof value === 'number') {\n    pxValue = value + 'px';\n  }\n\n  return pxValue;\n}\n\nfunction setElPosition(\n  el: HTMLElement,\n  left: number | string,\n  top: number | string,\n  width: number | string,\n  marginTop: number | string,\n  clipTop: number | string,\n  clipLeft: number | string\n): void {\n  el.style.top = px(top);\n  el.style.left = px(left);\n  el.style.marginTop = px(marginTop);\n  el.style.clipPath =\n    clipTop || clipLeft ? `inset(${px(clipTop)} 0 0 ${px(clipLeft)})` : 'none';\n\n  /*istanbul ignore else*/\n  /* sanity check */\n  if (width !== null) {\n    el.style.width = px(width);\n  }\n}\n\nfunction getHeightWithMargin(el: HTMLElement): number {\n  const computedStyle = getComputedStyle(el);\n\n  return (\n    el.offsetHeight +\n    parseInt(computedStyle.marginTop, 10) +\n    parseInt(computedStyle.marginBottom, 10)\n  );\n}\n\nfunction createCustomEvent(name: any): CustomEvent<any> {\n  const evt = document.createEvent('CustomEvent');\n\n  evt.initCustomEvent(name, false, false, undefined);\n\n  return evt;\n}\n\nexport class SkyViewkeeper {\n  #boundaryEl: HTMLElement | undefined;\n\n  #el: HTMLElement | undefined;\n\n  #id: string;\n\n  #setWidth: boolean;\n\n  #verticalOffset: number;\n\n  #verticalOffsetEl: HTMLElement | undefined;\n\n  #viewportMarginTop = 0;\n\n  #currentElFixedLeft: number | undefined;\n\n  #currentElFixedTop: number | undefined;\n\n  #currentElFixedWidth: number | undefined;\n\n  #currentElClipLeft: number | undefined;\n\n  #currentElClipTop: number | undefined;\n\n  #isDestroyed = false;\n\n  #scrollableHost: HTMLElement | undefined;\n\n  #syncElPositionHandler: () => void;\n\n  #intersectionObserver: IntersectionObserver | undefined;\n\n  constructor(options: SkyViewkeeperOptions) {\n    options = options || /* istanbul ignore next */ {};\n\n    this.#el = options.el;\n    this.#boundaryEl = options.boundaryEl;\n\n    if (!this.#el) {\n      throw new Error('[SkyViewkeeper] The option `el` is required.');\n    }\n\n    if (!this.#boundaryEl) {\n      throw new Error('[SkyViewkeeper] The option `boundaryEl` is required.');\n    }\n\n    const el = this.#el;\n    const boundaryEl = this.#boundaryEl;\n\n    this.#setWidth = !!options.setWidth;\n    this.#id = nextId();\n    this.#scrollableHost = options.scrollableHost;\n    this.#verticalOffset = options.verticalOffset || 0;\n    this.#verticalOffsetEl = options.verticalOffsetEl;\n\n    // Only set viewport margin if the scrollable host is undefined.\n    if (!this.#scrollableHost) {\n      this.#viewportMarginTop = options.viewportMarginTop ?? 0;\n    }\n\n    this.#syncElPositionHandler = () => this.syncElPosition(el, boundaryEl);\n\n    if (this.#verticalOffsetEl) {\n      this.#verticalOffsetEl.addEventListener(\n        EVT_AFTER_VIEWKEEPER_SYNC,\n        this.#syncElPositionHandler\n      );\n    }\n\n    window.addEventListener('scroll', this.#syncElPositionHandler, true);\n    window.addEventListener('resize', this.#syncElPositionHandler);\n    window.addEventListener('orientationchange', this.#syncElPositionHandler);\n\n    ensureStyleEl();\n\n    this.syncElPosition(el, boundaryEl);\n  }\n\n  public syncElPosition(el: HTMLElement, boundaryEl: HTMLElement): void {\n    const verticalOffset = this.#calculateVerticalOffset();\n\n    // When the element isn't visible, its size can't be calculated, so don't attempt syncing position in this case.\n    if (el.offsetWidth === 0 && el.offsetHeight === 0) {\n      return;\n    }\n\n    const boundaryInfo = this.#getBoundaryInfo(el, boundaryEl);\n    const fixedStyles = this.#getFixedStyles(boundaryInfo, verticalOffset);\n\n    const doFixEl = this.#shouldFixEl(el, boundaryInfo, verticalOffset);\n\n    if (this.#needsUpdating(doFixEl, fixedStyles)) {\n      if (doFixEl) {\n        this.#fixEl(el, boundaryInfo, fixedStyles);\n      } else {\n        this.#unfixEl(el);\n      }\n    }\n\n    const evt = createCustomEvent(EVT_AFTER_VIEWKEEPER_SYNC);\n\n    el.dispatchEvent(evt);\n  }\n\n  public destroy(): void {\n    if (!this.#isDestroyed) {\n      this.#intersectionObserver?.disconnect();\n      window.removeEventListener('scroll', this.#syncElPositionHandler, true);\n      window.removeEventListener('resize', this.#syncElPositionHandler);\n      window.removeEventListener(\n        'orientationchange',\n        this.#syncElPositionHandler\n      );\n\n      if (this.#el) {\n        this.#unfixEl(this.#el);\n      }\n\n      if (this.#verticalOffsetEl) {\n        this.#verticalOffsetEl.removeEventListener(\n          EVT_AFTER_VIEWKEEPER_SYNC,\n          this.#syncElPositionHandler\n        );\n      }\n\n      this.#el = this.#boundaryEl = this.#verticalOffsetEl = undefined;\n\n      this.#isDestroyed = true;\n    }\n  }\n\n  #getSpacerId(): string {\n    return this.#id + '-spacer';\n  }\n\n  #unfixEl(el: HTMLElement): void {\n    const spacerEl = document.getElementById(this.#getSpacerId());\n\n    /*istanbul ignore else*/\n    if (spacerEl?.parentElement) {\n      spacerEl.parentElement.removeChild(spacerEl);\n    }\n\n    el.classList.remove(CLS_VIEWKEEPER_FIXED);\n\n    this.#currentElFixedLeft =\n      this.#currentElFixedTop =\n      this.#currentElFixedWidth =\n        undefined;\n\n    let width = '';\n\n    if (this.#setWidth) {\n      width = 'auto';\n    }\n\n    setElPosition(el, '', '', width, '', 0, 0);\n  }\n\n  #calculateVerticalOffset(): number {\n    let offset = this.#verticalOffset;\n\n    if (this.#verticalOffsetEl) {\n      const verticalOffsetElTopStyle = this.#verticalOffsetEl.style.top;\n      const verticalOffsetElTop = parseInt(verticalOffsetElTopStyle, 10) || 0;\n\n      offset += this.#verticalOffsetEl.offsetHeight + verticalOffsetElTop;\n    } else if (this.#scrollableHost) {\n      offset += this.#scrollableHost.getBoundingClientRect().top;\n    }\n\n    return offset;\n  }\n\n  #shouldFixEl(\n    el: HTMLElement,\n    boundaryInfo: SkyViewkeeperBoundaryInfo,\n    verticalOffset: number\n  ): boolean {\n    let anchorTop: number;\n\n    if (boundaryInfo.spacerEl) {\n      anchorTop = getOffset(boundaryInfo.spacerEl, this.#scrollableHost).top;\n    } else {\n      anchorTop = getOffset(el, this.#scrollableHost).top;\n    }\n\n    const doFixEl =\n      boundaryInfo.scrollTop + verticalOffset + this.#viewportMarginTop >\n      anchorTop;\n\n    return doFixEl;\n  }\n\n  #getFixedStyles(\n    boundaryInfo: SkyViewkeeperBoundaryInfo,\n    verticalOffset: number\n  ): SkyViewkeeperFixedStyles {\n    // If the element needs to be fixed, this will calculate its position.  The position\n    // will be 0 (fully visible) unless the user is scrolling the boundary out of view.\n    // In that case, the element should begin to scroll out of view with the\n    // rest of the boundary by setting its top position to a negative value.\n    const elTop =\n      boundaryInfo.boundaryBottom -\n      boundaryInfo.elHeight -\n      boundaryInfo.scrollTop;\n    const elClipTop = elTop < verticalOffset ? verticalOffset - elTop : 0;\n    const elFixedTop = Math.min(elTop, verticalOffset);\n\n    const elFixedWidth = boundaryInfo.boundaryEl.getBoundingClientRect().width;\n    const elFixedLeft =\n      boundaryInfo.boundaryOffset.left - boundaryInfo.scrollLeft;\n    const elClipLeft = elFixedLeft < 0 ? 0 - elFixedLeft : 0;\n\n    return {\n      elFixedLeft,\n      elFixedTop,\n      elFixedWidth,\n      elClipLeft,\n      elClipTop,\n    };\n  }\n\n  #needsUpdating(\n    doFixEl: boolean,\n    fixedStyles: SkyViewkeeperFixedStyles\n  ): boolean {\n    if (\n      (doFixEl &&\n        this.#currentElFixedLeft === fixedStyles.elFixedLeft &&\n        this.#currentElFixedTop === fixedStyles.elFixedTop &&\n        this.#currentElClipLeft === fixedStyles.elClipLeft &&\n        this.#currentElClipTop === fixedStyles.elClipTop &&\n        this.#currentElFixedWidth === fixedStyles.elFixedWidth) ||\n      (!doFixEl &&\n        !(\n          this.#currentElFixedLeft !== undefined &&\n          this.#currentElFixedLeft !== null\n        ))\n    ) {\n      // The element is either currently fixed and its position and width do not need\n      // to change, or the element is not currently fixed and does not need to be fixed.\n      // No changes are needed.\n      return false;\n    }\n\n    return true;\n  }\n\n  #fixEl(\n    el: HTMLElement,\n    boundaryInfo: SkyViewkeeperBoundaryInfo,\n    fixedStyles: SkyViewkeeperFixedStyles\n  ): void {\n    /* istanbul ignore else */\n    /* sanity check */\n    if (!boundaryInfo.spacerEl) {\n      const spacerHeight = boundaryInfo.elHeight;\n\n      const spacerEl = document.createElement('div');\n      spacerEl.id = boundaryInfo.spacerId;\n      spacerEl.style.height = px(spacerHeight);\n\n      /*istanbul ignore else*/\n      if (el.parentNode) {\n        el.parentNode.insertBefore(spacerEl, el.nextSibling);\n      }\n    }\n\n    el.classList.add(CLS_VIEWKEEPER_FIXED);\n\n    this.#currentElFixedTop = fixedStyles.elFixedTop;\n    this.#currentElFixedLeft = fixedStyles.elFixedLeft;\n    this.#currentElClipTop = fixedStyles.elClipTop;\n    this.#currentElClipLeft = fixedStyles.elClipLeft;\n    this.#currentElFixedWidth = fixedStyles.elFixedWidth;\n\n    let width = 0;\n\n    if (this.#setWidth) {\n      width = fixedStyles.elFixedWidth;\n    }\n\n    setElPosition(\n      el,\n      fixedStyles.elFixedLeft,\n      fixedStyles.elFixedTop,\n      width,\n      this.#viewportMarginTop,\n      fixedStyles.elClipTop,\n      fixedStyles.elClipLeft\n    );\n  }\n\n  #getBoundaryInfo(\n    el: HTMLElement,\n    boundaryEl: HTMLElement\n  ): SkyViewkeeperBoundaryInfo {\n    const spacerId = this.#getSpacerId();\n\n    const spacerEl = document.getElementById(spacerId);\n\n    const boundaryOffset = getOffset(boundaryEl, this.#scrollableHost);\n    const boundaryTop = boundaryOffset.top;\n    const boundaryBottom =\n      boundaryTop + boundaryEl.getBoundingClientRect().height;\n\n    const scrollLeft = this.#scrollableHost\n      ? this.#scrollableHost.scrollLeft\n      : document.documentElement.scrollLeft;\n    const scrollTop = this.#scrollableHost\n      ? this.#scrollableHost.scrollTop\n      : document.documentElement.scrollTop;\n\n    const elHeight = getHeightWithMargin(el);\n\n    return {\n      boundaryBottom,\n      boundaryOffset,\n      boundaryEl,\n      elHeight,\n      scrollLeft,\n      scrollTop,\n      spacerId,\n      spacerEl,\n    };\n  }\n}\n"]}
|
@@ -2,15 +2,15 @@ import { NgModule } from '@angular/core';
|
|
2
2
|
import { SkyViewkeeperDirective } from './viewkeeper.directive';
|
3
3
|
import * as i0 from "@angular/core";
|
4
4
|
export class SkyViewkeeperModule {
|
5
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyViewkeeperModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
6
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.1.7", ngImport: i0, type: SkyViewkeeperModule, declarations: [SkyViewkeeperDirective], exports: [SkyViewkeeperDirective] }); }
|
7
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyViewkeeperModule }); }
|
5
8
|
}
|
6
|
-
|
7
|
-
SkyViewkeeperModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.9", ngImport: i0, type: SkyViewkeeperModule, declarations: [SkyViewkeeperDirective], exports: [SkyViewkeeperDirective] });
|
8
|
-
SkyViewkeeperModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyViewkeeperModule });
|
9
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyViewkeeperModule, decorators: [{
|
9
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyViewkeeperModule, decorators: [{
|
10
10
|
type: NgModule,
|
11
11
|
args: [{
|
12
12
|
declarations: [SkyViewkeeperDirective],
|
13
13
|
exports: [SkyViewkeeperDirective],
|
14
14
|
}]
|
15
15
|
}] });
|
16
|
-
//# sourceMappingURL=data:application/json;base64,
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmlld2tlZXBlci5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvY29yZS9zcmMvbGliL21vZHVsZXMvdmlld2tlZXBlci92aWV3a2VlcGVyLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXpDLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLHdCQUF3QixDQUFDOztBQU1oRSxNQUFNLE9BQU8sbUJBQW1COzhHQUFuQixtQkFBbUI7K0dBQW5CLG1CQUFtQixpQkFIZixzQkFBc0IsYUFDM0Isc0JBQXNCOytHQUVyQixtQkFBbUI7OzJGQUFuQixtQkFBbUI7a0JBSi9CLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLENBQUMsc0JBQXNCLENBQUM7b0JBQ3RDLE9BQU8sRUFBRSxDQUFDLHNCQUFzQixDQUFDO2lCQUNsQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IFNreVZpZXdrZWVwZXJEaXJlY3RpdmUgfSBmcm9tICcuL3ZpZXdrZWVwZXIuZGlyZWN0aXZlJztcblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbU2t5Vmlld2tlZXBlckRpcmVjdGl2ZV0sXG4gIGV4cG9ydHM6IFtTa3lWaWV3a2VlcGVyRGlyZWN0aXZlXSxcbn0pXG5leHBvcnQgY2xhc3MgU2t5Vmlld2tlZXBlck1vZHVsZSB7fVxuIl19
|
@@ -0,0 +1,39 @@
|
|
1
|
+
import { Injectable, Optional } from '@angular/core';
|
2
|
+
import { SkyViewkeeper } from './viewkeeper';
|
3
|
+
import * as i0 from "@angular/core";
|
4
|
+
import * as i1 from "./viewkeeper-host-options";
|
5
|
+
/**
|
6
|
+
* Provides methods for creating and destroying viewkeeper instances.
|
7
|
+
*/
|
8
|
+
export class SkyViewkeeperService {
|
9
|
+
#hostOptions;
|
10
|
+
constructor(hostOptions) {
|
11
|
+
this.#hostOptions = hostOptions;
|
12
|
+
}
|
13
|
+
/**
|
14
|
+
*
|
15
|
+
* @param options Creates a viewkeeper instance, applying host options where applicable.
|
16
|
+
*/
|
17
|
+
create(options) {
|
18
|
+
options = Object.assign({}, this.#hostOptions || {}, options);
|
19
|
+
return new SkyViewkeeper(options);
|
20
|
+
}
|
21
|
+
/**
|
22
|
+
* Destroys a viewkeeper instance.
|
23
|
+
* @param vk Viewkeeper instance to destroy.
|
24
|
+
*/
|
25
|
+
destroy(vk) {
|
26
|
+
vk.destroy();
|
27
|
+
}
|
28
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyViewkeeperService, deps: [{ token: i1.SkyViewkeeperHostOptions, optional: true }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
29
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyViewkeeperService, providedIn: 'root' }); }
|
30
|
+
}
|
31
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyViewkeeperService, decorators: [{
|
32
|
+
type: Injectable,
|
33
|
+
args: [{
|
34
|
+
providedIn: 'root',
|
35
|
+
}]
|
36
|
+
}], ctorParameters: function () { return [{ type: i1.SkyViewkeeperHostOptions, decorators: [{
|
37
|
+
type: Optional
|
38
|
+
}] }]; } });
|
39
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmlld2tlZXBlci5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL2NvcmUvc3JjL2xpYi9tb2R1bGVzL3ZpZXdrZWVwZXIvdmlld2tlZXBlci5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXJELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxjQUFjLENBQUM7OztBQUk3Qzs7R0FFRztBQUlILE1BQU0sT0FBTyxvQkFBb0I7SUFDL0IsWUFBWSxDQUF1QztJQUVuRCxZQUF3QixXQUFzQztRQUM1RCxJQUFJLENBQUMsWUFBWSxHQUFHLFdBQVcsQ0FBQztJQUNsQyxDQUFDO0lBRUQ7OztPQUdHO0lBQ0ksTUFBTSxDQUFDLE9BQTZCO1FBQ3pDLE9BQU8sR0FBRyxNQUFNLENBQUMsTUFBTSxDQUFDLEVBQUUsRUFBRSxJQUFJLENBQUMsWUFBWSxJQUFJLEVBQUUsRUFBRSxPQUFPLENBQUMsQ0FBQztRQUU5RCxPQUFPLElBQUksYUFBYSxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQ3BDLENBQUM7SUFFRDs7O09BR0c7SUFDSSxPQUFPLENBQUMsRUFBaUI7UUFDOUIsRUFBRSxDQUFDLE9BQU8sRUFBRSxDQUFDO0lBQ2YsQ0FBQzs4R0F2QlUsb0JBQW9CO2tIQUFwQixvQkFBb0IsY0FGbkIsTUFBTTs7MkZBRVAsb0JBQW9CO2tCQUhoQyxVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQjs7MEJBSWMsUUFBUSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUsIE9wdGlvbmFsIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IFNreVZpZXdrZWVwZXIgfSBmcm9tICcuL3ZpZXdrZWVwZXInO1xuaW1wb3J0IHsgU2t5Vmlld2tlZXBlckhvc3RPcHRpb25zIH0gZnJvbSAnLi92aWV3a2VlcGVyLWhvc3Qtb3B0aW9ucyc7XG5pbXBvcnQgeyBTa3lWaWV3a2VlcGVyT3B0aW9ucyB9IGZyb20gJy4vdmlld2tlZXBlci1vcHRpb25zJztcblxuLyoqXG4gKiBQcm92aWRlcyBtZXRob2RzIGZvciBjcmVhdGluZyBhbmQgZGVzdHJveWluZyB2aWV3a2VlcGVyIGluc3RhbmNlcy5cbiAqL1xuQEluamVjdGFibGUoe1xuICBwcm92aWRlZEluOiAncm9vdCcsXG59KVxuZXhwb3J0IGNsYXNzIFNreVZpZXdrZWVwZXJTZXJ2aWNlIHtcbiAgI2hvc3RPcHRpb25zOiBTa3lWaWV3a2VlcGVySG9zdE9wdGlvbnMgfCB1bmRlZmluZWQ7XG5cbiAgY29uc3RydWN0b3IoQE9wdGlvbmFsKCkgaG9zdE9wdGlvbnM/OiBTa3lWaWV3a2VlcGVySG9zdE9wdGlvbnMpIHtcbiAgICB0aGlzLiNob3N0T3B0aW9ucyA9IGhvc3RPcHRpb25zO1xuICB9XG5cbiAgLyoqXG4gICAqXG4gICAqIEBwYXJhbSBvcHRpb25zIENyZWF0ZXMgYSB2aWV3a2VlcGVyIGluc3RhbmNlLCBhcHBseWluZyBob3N0IG9wdGlvbnMgd2hlcmUgYXBwbGljYWJsZS5cbiAgICovXG4gIHB1YmxpYyBjcmVhdGUob3B0aW9uczogU2t5Vmlld2tlZXBlck9wdGlvbnMpOiBTa3lWaWV3a2VlcGVyIHtcbiAgICBvcHRpb25zID0gT2JqZWN0LmFzc2lnbih7fSwgdGhpcy4jaG9zdE9wdGlvbnMgfHwge30sIG9wdGlvbnMpO1xuXG4gICAgcmV0dXJuIG5ldyBTa3lWaWV3a2VlcGVyKG9wdGlvbnMpO1xuICB9XG5cbiAgLyoqXG4gICAqIERlc3Ryb3lzIGEgdmlld2tlZXBlciBpbnN0YW5jZS5cbiAgICogQHBhcmFtIHZrIFZpZXdrZWVwZXIgaW5zdGFuY2UgdG8gZGVzdHJveS5cbiAgICovXG4gIHB1YmxpYyBkZXN0cm95KHZrOiBTa3lWaWV3a2VlcGVyKTogdm9pZCB7XG4gICAgdmsuZGVzdHJveSgpO1xuICB9XG59XG4iXX0=
|
@@ -18,13 +18,13 @@ export class SkyAppWindowRef {
|
|
18
18
|
get nativeWindow() {
|
19
19
|
return getWindow();
|
20
20
|
}
|
21
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyAppWindowRef, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
22
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyAppWindowRef, providedIn: 'root' }); }
|
21
23
|
}
|
22
|
-
|
23
|
-
SkyAppWindowRef.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyAppWindowRef, providedIn: 'root' });
|
24
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyAppWindowRef, decorators: [{
|
24
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyAppWindowRef, decorators: [{
|
25
25
|
type: Injectable,
|
26
26
|
args: [{
|
27
27
|
providedIn: 'root',
|
28
28
|
}]
|
29
29
|
}] });
|
30
|
-
//# sourceMappingURL=data:application/json;base64,
|
30
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2luZG93LXJlZi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9jb3JlL3NyYy9saWIvbW9kdWxlcy93aW5kb3cvd2luZG93LXJlZi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUUzQzs7R0FFRztBQUNILE1BQU0sVUFBVSxTQUFTO0lBQ3ZCLE9BQU8sTUFBTSxDQUFDO0FBQ2hCLENBQUM7QUFFRDs7OztHQUlHO0FBSUgsTUFBTSxPQUFPLGVBQWU7SUFDMUI7O09BRUc7SUFDSCxJQUFXLFlBQVk7UUFDckIsT0FBTyxTQUFTLEVBQUUsQ0FBQztJQUNyQixDQUFDOzhHQU5VLGVBQWU7a0hBQWYsZUFBZSxjQUZkLE1BQU07OzJGQUVQLGVBQWU7a0JBSDNCLFVBQVU7bUJBQUM7b0JBQ1YsVUFBVSxFQUFFLE1BQU07aUJBQ25CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG4vKipcbiAqIEBpbnRlcm5hbFxuICovXG5leHBvcnQgZnVuY3Rpb24gZ2V0V2luZG93KCk6IGFueSB7XG4gIHJldHVybiB3aW5kb3c7XG59XG5cbi8qKlxuICogVGhlIGFwcGxpY2F0aW9uIHdpbmRvdyByZWZlcmVuY2Ugc2VydmljZSByZWZlcmVuY2VzIHRoZSBnbG9iYWwgd2luZG93IHZhcmlhYmxlLlxuICogQWZ0ZXIgdXNlcnMgaW5qZWN0IFNreUFwcFdpbmRvd1JlZiBpbnRvIGEgY29tcG9uZW50LCB0aGV5IGNhbiB1c2UgdGhlIHNlcnZpY2UgdG8gaW50ZXJhY3Qgd2l0aFxuICogd2luZG93IHByb3BlcnRpZXMgYW5kIGV2ZW50IGhhbmRsZXJzIGJ5IHJlZmVyZW5jaW5nIGl0cyBuYXRpdmVXaW5kb3cgcHJvcGVydHkuXG4gKi9cbkBJbmplY3RhYmxlKHtcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnLFxufSlcbmV4cG9ydCBjbGFzcyBTa3lBcHBXaW5kb3dSZWYge1xuICAvKipcbiAgICogVGhlIGdsb2JhbCBgd2luZG93YCB2YXJpYWJsZS5cbiAgICovXG4gIHB1YmxpYyBnZXQgbmF0aXZlV2luZG93KCk6IGFueSB7XG4gICAgcmV0dXJuIGdldFdpbmRvdygpO1xuICB9XG59XG4iXX0=
|
@@ -0,0 +1,32 @@
|
|
1
|
+
import { NgModule } from '@angular/core';
|
2
|
+
import { SkyMediaQueryService, SkyUIConfigService } from '@skyux/core';
|
3
|
+
import { MockSkyMediaQueryService } from './mock-media-query.service';
|
4
|
+
import { MockSkyUIConfigService } from './mock-ui-config.service';
|
5
|
+
import * as i0 from "@angular/core";
|
6
|
+
/**
|
7
|
+
* @internal
|
8
|
+
*/
|
9
|
+
export class SkyCoreTestingModule {
|
10
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyCoreTestingModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
11
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.1.7", ngImport: i0, type: SkyCoreTestingModule }); }
|
12
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyCoreTestingModule, providers: [
|
13
|
+
{ provide: SkyMediaQueryService, useClass: MockSkyMediaQueryService },
|
14
|
+
{
|
15
|
+
provide: SkyUIConfigService,
|
16
|
+
useClass: MockSkyUIConfigService,
|
17
|
+
},
|
18
|
+
] }); }
|
19
|
+
}
|
20
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyCoreTestingModule, decorators: [{
|
21
|
+
type: NgModule,
|
22
|
+
args: [{
|
23
|
+
providers: [
|
24
|
+
{ provide: SkyMediaQueryService, useClass: MockSkyMediaQueryService },
|
25
|
+
{
|
26
|
+
provide: SkyUIConfigService,
|
27
|
+
useClass: MockSkyUIConfigService,
|
28
|
+
},
|
29
|
+
],
|
30
|
+
}]
|
31
|
+
}] });
|
32
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29yZS10ZXN0aW5nLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9jb3JlL3Rlc3Rpbmcvc3JjL2NvcmUtdGVzdGluZy5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFFdkUsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFDdEUsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7O0FBRWxFOztHQUVHO0FBVUgsTUFBTSxPQUFPLG9CQUFvQjs4R0FBcEIsb0JBQW9COytHQUFwQixvQkFBb0I7K0dBQXBCLG9CQUFvQixhQVJwQjtZQUNULEVBQUUsT0FBTyxFQUFFLG9CQUFvQixFQUFFLFFBQVEsRUFBRSx3QkFBd0IsRUFBRTtZQUNyRTtnQkFDRSxPQUFPLEVBQUUsa0JBQWtCO2dCQUMzQixRQUFRLEVBQUUsc0JBQXNCO2FBQ2pDO1NBQ0Y7OzJGQUVVLG9CQUFvQjtrQkFUaEMsUUFBUTttQkFBQztvQkFDUixTQUFTLEVBQUU7d0JBQ1QsRUFBRSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsUUFBUSxFQUFFLHdCQUF3QixFQUFFO3dCQUNyRTs0QkFDRSxPQUFPLEVBQUUsa0JBQWtCOzRCQUMzQixRQUFRLEVBQUUsc0JBQXNCO3lCQUNqQztxQkFDRjtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBTa3lNZWRpYVF1ZXJ5U2VydmljZSwgU2t5VUlDb25maWdTZXJ2aWNlIH0gZnJvbSAnQHNreXV4L2NvcmUnO1xuXG5pbXBvcnQgeyBNb2NrU2t5TWVkaWFRdWVyeVNlcnZpY2UgfSBmcm9tICcuL21vY2stbWVkaWEtcXVlcnkuc2VydmljZSc7XG5pbXBvcnQgeyBNb2NrU2t5VUlDb25maWdTZXJ2aWNlIH0gZnJvbSAnLi9tb2NrLXVpLWNvbmZpZy5zZXJ2aWNlJztcblxuLyoqXG4gKiBAaW50ZXJuYWxcbiAqL1xuQE5nTW9kdWxlKHtcbiAgcHJvdmlkZXJzOiBbXG4gICAgeyBwcm92aWRlOiBTa3lNZWRpYVF1ZXJ5U2VydmljZSwgdXNlQ2xhc3M6IE1vY2tTa3lNZWRpYVF1ZXJ5U2VydmljZSB9LFxuICAgIHtcbiAgICAgIHByb3ZpZGU6IFNreVVJQ29uZmlnU2VydmljZSxcbiAgICAgIHVzZUNsYXNzOiBNb2NrU2t5VUlDb25maWdTZXJ2aWNlLFxuICAgIH0sXG4gIF0sXG59KVxuZXhwb3J0IGNsYXNzIFNreUNvcmVUZXN0aW5nTW9kdWxlIHt9XG4iXX0=
|