@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.
Files changed (151) hide show
  1. package/{esm2020 → esm2022}/lib/modules/adapter-service/adapter.module.mjs +5 -5
  2. package/esm2022/lib/modules/adapter-service/adapter.service.mjs +225 -0
  3. package/esm2022/lib/modules/affix/affix.directive.mjs +116 -0
  4. package/{esm2020 → esm2022}/lib/modules/affix/affix.module.mjs +5 -5
  5. package/esm2022/lib/modules/affix/affix.service.mjs +25 -0
  6. package/esm2022/lib/modules/affix/affixer.mjs +398 -0
  7. package/esm2022/lib/modules/default-input-provider/default-input-provider.mjs +26 -0
  8. package/esm2022/lib/modules/dock/dock-dom-adapter.service.mjs +81 -0
  9. package/esm2022/lib/modules/dock/dock-item.mjs +31 -0
  10. package/esm2022/lib/modules/dock/dock.component.mjs +108 -0
  11. package/{esm2020 → esm2022}/lib/modules/dock/dock.module.mjs +5 -5
  12. package/esm2022/lib/modules/dock/dock.service.mjs +96 -0
  13. package/{esm2020 → esm2022}/lib/modules/dynamic-component/dynamic-component.module.mjs +5 -5
  14. package/esm2022/lib/modules/dynamic-component/dynamic-component.service.mjs +106 -0
  15. package/{esm2020 → esm2022}/lib/modules/format/app-format.mjs +4 -4
  16. package/esm2022/lib/modules/id/id.directive.mjs +31 -0
  17. package/{esm2020 → esm2022}/lib/modules/id/id.module.mjs +5 -5
  18. package/{esm2020 → esm2022}/lib/modules/id/id.service.mjs +4 -4
  19. package/esm2022/lib/modules/layout-host/layout-host.service.mjs +22 -0
  20. package/esm2022/lib/modules/live-announcer/live-announcer.service.mjs +79 -0
  21. package/{esm2020 → esm2022}/lib/modules/log/log.module.mjs +5 -5
  22. package/esm2022/lib/modules/log/log.service.mjs +148 -0
  23. package/{esm2020 → esm2022}/lib/modules/media-query/media-query.module.mjs +5 -5
  24. package/esm2022/lib/modules/media-query/media-query.service.mjs +123 -0
  25. package/{esm2020 → esm2022}/lib/modules/mutation/mutation-observer-service.mjs +4 -4
  26. package/{esm2020 → esm2022}/lib/modules/numeric/numeric.module.mjs +5 -5
  27. package/esm2022/lib/modules/numeric/numeric.pipe.mjs +81 -0
  28. package/esm2022/lib/modules/numeric/numeric.service.mjs +205 -0
  29. package/esm2022/lib/modules/overlay/overlay-adapter.service.mjs +44 -0
  30. package/esm2022/lib/modules/overlay/overlay-instance.mjs +62 -0
  31. package/esm2022/lib/modules/overlay/overlay.component.mjs +193 -0
  32. package/{esm2020 → esm2022}/lib/modules/overlay/overlay.module.mjs +5 -5
  33. package/esm2022/lib/modules/overlay/overlay.service.mjs +124 -0
  34. package/{esm2020 → esm2022}/lib/modules/percent-pipe/percent-pipe.module.mjs +5 -5
  35. package/esm2022/lib/modules/percent-pipe/percent.pipe.mjs +56 -0
  36. package/esm2022/lib/modules/resize-observer/resize-observer-media-query.service.mjs +120 -0
  37. package/esm2022/lib/modules/resize-observer/resize-observer.service.mjs +77 -0
  38. package/esm2022/lib/modules/scrollable-host/scrollable-host.service.mjs +223 -0
  39. package/esm2022/lib/modules/shared/number-format/number-format-utility.mjs +72 -0
  40. package/esm2022/lib/modules/shared/sky-core-resources.module.mjs +50 -0
  41. package/esm2022/lib/modules/title/title.service.mjs +31 -0
  42. package/esm2022/lib/modules/trim/trim.directive.mjs +64 -0
  43. package/{esm2020 → esm2022}/lib/modules/trim/trim.module.mjs +5 -5
  44. package/{esm2020 → esm2022}/lib/modules/ui-config/ui-config.service.mjs +4 -4
  45. package/{esm2020 → esm2022}/lib/modules/viewkeeper/viewkeeper-host-options.mjs +4 -4
  46. package/esm2022/lib/modules/viewkeeper/viewkeeper.directive.mjs +131 -0
  47. package/esm2022/lib/modules/viewkeeper/viewkeeper.mjs +283 -0
  48. package/{esm2020 → esm2022}/lib/modules/viewkeeper/viewkeeper.module.mjs +5 -5
  49. package/esm2022/lib/modules/viewkeeper/viewkeeper.service.mjs +39 -0
  50. package/{esm2020 → esm2022}/lib/modules/window/window-ref.mjs +4 -4
  51. package/esm2022/testing/core-testing.module.mjs +32 -0
  52. package/esm2022/testing/mock-media-query.service.mjs +46 -0
  53. package/{esm2020 → esm2022}/testing/mock-ui-config.service.mjs +4 -4
  54. package/esm2022/testing/overlay/overlay-harness.mjs +43 -0
  55. package/esm2022/testing/shared/component-harness.mjs +13 -0
  56. package/{fesm2020 → fesm2022}/skyux-core-testing.mjs +28 -34
  57. package/{fesm2020 → fesm2022}/skyux-core-testing.mjs.map +1 -1
  58. package/fesm2022/skyux-core.mjs +3858 -0
  59. package/fesm2022/skyux-core.mjs.map +1 -0
  60. package/lib/modules/affix/affix.directive.d.ts +1 -1
  61. package/lib/modules/viewkeeper/viewkeeper.directive.d.ts +1 -1
  62. package/package.json +14 -22
  63. package/esm2020/lib/modules/adapter-service/adapter.service.mjs +0 -227
  64. package/esm2020/lib/modules/affix/affix.directive.mjs +0 -118
  65. package/esm2020/lib/modules/affix/affix.service.mjs +0 -28
  66. package/esm2020/lib/modules/affix/affixer.mjs +0 -377
  67. package/esm2020/lib/modules/default-input-provider/default-input-provider.mjs +0 -31
  68. package/esm2020/lib/modules/dock/dock-dom-adapter.service.mjs +0 -83
  69. package/esm2020/lib/modules/dock/dock-item.mjs +0 -34
  70. package/esm2020/lib/modules/dock/dock.component.mjs +0 -110
  71. package/esm2020/lib/modules/dock/dock.service.mjs +0 -98
  72. package/esm2020/lib/modules/dynamic-component/dynamic-component.service.mjs +0 -109
  73. package/esm2020/lib/modules/id/id.directive.mjs +0 -34
  74. package/esm2020/lib/modules/layout-host/layout-host.service.mjs +0 -27
  75. package/esm2020/lib/modules/live-announcer/live-announcer.service.mjs +0 -80
  76. package/esm2020/lib/modules/log/log.service.mjs +0 -147
  77. package/esm2020/lib/modules/media-query/media-query.service.mjs +0 -124
  78. package/esm2020/lib/modules/numeric/numeric.pipe.mjs +0 -84
  79. package/esm2020/lib/modules/numeric/numeric.service.mjs +0 -179
  80. package/esm2020/lib/modules/overlay/overlay-adapter.service.mjs +0 -47
  81. package/esm2020/lib/modules/overlay/overlay-instance.mjs +0 -65
  82. package/esm2020/lib/modules/overlay/overlay.component.mjs +0 -192
  83. package/esm2020/lib/modules/overlay/overlay.service.mjs +0 -125
  84. package/esm2020/lib/modules/percent-pipe/percent.pipe.mjs +0 -59
  85. package/esm2020/lib/modules/resize-observer/resize-observer-media-query.service.mjs +0 -121
  86. package/esm2020/lib/modules/resize-observer/resize-observer.service.mjs +0 -79
  87. package/esm2020/lib/modules/scrollable-host/scrollable-host.service.mjs +0 -218
  88. package/esm2020/lib/modules/shared/number-format/number-format-utility.mjs +0 -72
  89. package/esm2020/lib/modules/shared/sky-core-resources.module.mjs +0 -50
  90. package/esm2020/lib/modules/title/title.service.mjs +0 -34
  91. package/esm2020/lib/modules/trim/trim.directive.mjs +0 -65
  92. package/esm2020/lib/modules/viewkeeper/viewkeeper.directive.mjs +0 -131
  93. package/esm2020/lib/modules/viewkeeper/viewkeeper.mjs +0 -276
  94. package/esm2020/lib/modules/viewkeeper/viewkeeper.service.mjs +0 -42
  95. package/esm2020/testing/core-testing.module.mjs +0 -32
  96. package/esm2020/testing/mock-media-query.service.mjs +0 -46
  97. package/esm2020/testing/overlay/overlay-harness.mjs +0 -43
  98. package/esm2020/testing/shared/component-harness.mjs +0 -19
  99. package/fesm2015/skyux-core-testing.mjs +0 -209
  100. package/fesm2015/skyux-core-testing.mjs.map +0 -1
  101. package/fesm2015/skyux-core.mjs +0 -3835
  102. package/fesm2015/skyux-core.mjs.map +0 -1
  103. package/fesm2020/skyux-core.mjs +0 -3825
  104. package/fesm2020/skyux-core.mjs.map +0 -1
  105. /package/{esm2020 → esm2022}/index.mjs +0 -0
  106. /package/{esm2020 → esm2022}/lib/modules/adapter-service/focusable-children-options.mjs +0 -0
  107. /package/{esm2020 → esm2022}/lib/modules/affix/affix-auto-fit-context.mjs +0 -0
  108. /package/{esm2020 → esm2022}/lib/modules/affix/affix-config.mjs +0 -0
  109. /package/{esm2020 → esm2022}/lib/modules/affix/affix-horizontal-alignment.mjs +0 -0
  110. /package/{esm2020 → esm2022}/lib/modules/affix/affix-offset-change.mjs +0 -0
  111. /package/{esm2020 → esm2022}/lib/modules/affix/affix-offset.mjs +0 -0
  112. /package/{esm2020 → esm2022}/lib/modules/affix/affix-placement-change.mjs +0 -0
  113. /package/{esm2020 → esm2022}/lib/modules/affix/affix-placement.mjs +0 -0
  114. /package/{esm2020 → esm2022}/lib/modules/affix/affix-position.mjs +0 -0
  115. /package/{esm2020 → esm2022}/lib/modules/affix/affix-rect.mjs +0 -0
  116. /package/{esm2020 → esm2022}/lib/modules/affix/affix-utils.mjs +0 -0
  117. /package/{esm2020 → esm2022}/lib/modules/affix/affix-vertical-alignment.mjs +0 -0
  118. /package/{esm2020 → esm2022}/lib/modules/affix/dom-utils.mjs +0 -0
  119. /package/{esm2020 → esm2022}/lib/modules/dock/dock-insert-component-config.mjs +0 -0
  120. /package/{esm2020 → esm2022}/lib/modules/dock/dock-item-config.mjs +0 -0
  121. /package/{esm2020 → esm2022}/lib/modules/dock/dock-item-reference.mjs +0 -0
  122. /package/{esm2020 → esm2022}/lib/modules/dock/dock-location.mjs +0 -0
  123. /package/{esm2020 → esm2022}/lib/modules/dock/dock-options.mjs +0 -0
  124. /package/{esm2020 → esm2022}/lib/modules/dock/sort-by-stack-order.mjs +0 -0
  125. /package/{esm2020 → esm2022}/lib/modules/dynamic-component/dynamic-component-location.mjs +0 -0
  126. /package/{esm2020 → esm2022}/lib/modules/dynamic-component/dynamic-component-options.mjs +0 -0
  127. /package/{esm2020 → esm2022}/lib/modules/layout-host/layout-host-for-child-args.mjs +0 -0
  128. /package/{esm2020 → esm2022}/lib/modules/live-announcer/types/live-announcer-args.mjs +0 -0
  129. /package/{esm2020 → esm2022}/lib/modules/live-announcer/types/live-announcer-politeness.mjs +0 -0
  130. /package/{esm2020 → esm2022}/lib/modules/log/types/log-deprecation-args.mjs +0 -0
  131. /package/{esm2020 → esm2022}/lib/modules/log/types/log-level-token.mjs +0 -0
  132. /package/{esm2020 → esm2022}/lib/modules/log/types/log-level.mjs +0 -0
  133. /package/{esm2020 → esm2022}/lib/modules/media-query/media-breakpoints.mjs +0 -0
  134. /package/{esm2020 → esm2022}/lib/modules/media-query/media-query-listener.mjs +0 -0
  135. /package/{esm2020 → esm2022}/lib/modules/numeric/numeric-symbol.mjs +0 -0
  136. /package/{esm2020 → esm2022}/lib/modules/numeric/numeric.options.mjs +0 -0
  137. /package/{esm2020 → esm2022}/lib/modules/overlay/overlay-config.mjs +0 -0
  138. /package/{esm2020 → esm2022}/lib/modules/overlay/overlay-context.mjs +0 -0
  139. /package/{esm2020 → esm2022}/lib/modules/overlay/overlay-position.mjs +0 -0
  140. /package/{esm2020 → esm2022}/lib/modules/stacking-context/stacking-context-token.mjs +0 -0
  141. /package/{esm2020 → esm2022}/lib/modules/stacking-context/stacking-context.mjs +0 -0
  142. /package/{esm2020 → esm2022}/lib/modules/title/set-title-args.mjs +0 -0
  143. /package/{esm2020 → esm2022}/lib/modules/viewkeeper/viewkeeper-boundary-info.mjs +0 -0
  144. /package/{esm2020 → esm2022}/lib/modules/viewkeeper/viewkeeper-fixed-styles.mjs +0 -0
  145. /package/{esm2020 → esm2022}/lib/modules/viewkeeper/viewkeeper-offset.mjs +0 -0
  146. /package/{esm2020 → esm2022}/lib/modules/viewkeeper/viewkeeper-options.mjs +0 -0
  147. /package/{esm2020 → esm2022}/skyux-core.mjs +0 -0
  148. /package/{esm2020 → esm2022}/testing/overlay/overlay-harness-filters.mjs +0 -0
  149. /package/{esm2020 → esm2022}/testing/public-api.mjs +0 -0
  150. /package/{esm2020 → esm2022}/testing/shared/harness-filters.mjs +0 -0
  151. /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
- SkyViewkeeperModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyViewkeeperModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmlld2tlZXBlci5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvY29yZS9zcmMvbGliL21vZHVsZXMvdmlld2tlZXBlci92aWV3a2VlcGVyLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXpDLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLHdCQUF3QixDQUFDOztBQU1oRSxNQUFNLE9BQU8sbUJBQW1COztnSEFBbkIsbUJBQW1CO2lIQUFuQixtQkFBbUIsaUJBSGYsc0JBQXNCLGFBQzNCLHNCQUFzQjtpSEFFckIsbUJBQW1COzJGQUFuQixtQkFBbUI7a0JBSi9CLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLENBQUMsc0JBQXNCLENBQUM7b0JBQ3RDLE9BQU8sRUFBRSxDQUFDLHNCQUFzQixDQUFDO2lCQUNsQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IFNreVZpZXdrZWVwZXJEaXJlY3RpdmUgfSBmcm9tICcuL3ZpZXdrZWVwZXIuZGlyZWN0aXZlJztcblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbU2t5Vmlld2tlZXBlckRpcmVjdGl2ZV0sXG4gIGV4cG9ydHM6IFtTa3lWaWV3a2VlcGVyRGlyZWN0aXZlXSxcbn0pXG5leHBvcnQgY2xhc3MgU2t5Vmlld2tlZXBlck1vZHVsZSB7fVxuIl19
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
- SkyAppWindowRef.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyAppWindowRef, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2luZG93LXJlZi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9jb3JlL3NyYy9saWIvbW9kdWxlcy93aW5kb3cvd2luZG93LXJlZi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUUzQzs7R0FFRztBQUNILE1BQU0sVUFBVSxTQUFTO0lBQ3ZCLE9BQU8sTUFBTSxDQUFDO0FBQ2hCLENBQUM7QUFFRDs7OztHQUlHO0FBSUgsTUFBTSxPQUFPLGVBQWU7SUFDMUI7O09BRUc7SUFDSCxJQUFXLFlBQVk7UUFDckIsT0FBTyxTQUFTLEVBQUUsQ0FBQztJQUNyQixDQUFDOzs0R0FOVSxlQUFlO2dIQUFmLGVBQWUsY0FGZCxNQUFNOzJGQUVQLGVBQWU7a0JBSDNCLFVBQVU7bUJBQUM7b0JBQ1YsVUFBVSxFQUFFLE1BQU07aUJBQ25CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG4vKipcbiAqIEBpbnRlcm5hbFxuICovXG5leHBvcnQgZnVuY3Rpb24gZ2V0V2luZG93KCk6IGFueSB7XG4gIHJldHVybiB3aW5kb3c7XG59XG5cbi8qKlxuICogVGhlIGFwcGxpY2F0aW9uIHdpbmRvdyByZWZlcmVuY2Ugc2VydmljZSByZWZlcmVuY2VzIHRoZSBnbG9iYWwgd2luZG93IHZhcmlhYmxlLlxuICogQWZ0ZXIgdXNlcnMgaW5qZWN0IFNreUFwcFdpbmRvd1JlZiBpbnRvIGEgY29tcG9uZW50LCB0aGV5IGNhbiB1c2UgdGhlIHNlcnZpY2UgdG8gaW50ZXJhY3Qgd2l0aFxuICogd2luZG93IHByb3BlcnRpZXMgYW5kIGV2ZW50IGhhbmRsZXJzIGJ5IHJlZmVyZW5jaW5nIGl0cyBuYXRpdmVXaW5kb3cgcHJvcGVydHkuXG4gKi9cbkBJbmplY3RhYmxlKHtcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnLFxufSlcbmV4cG9ydCBjbGFzcyBTa3lBcHBXaW5kb3dSZWYge1xuICAvKipcbiAgICogVGhlIGdsb2JhbCBgd2luZG93YCB2YXJpYWJsZS5cbiAgICovXG4gIHB1YmxpYyBnZXQgbmF0aXZlV2luZG93KCk6IGFueSB7XG4gICAgcmV0dXJuIGdldFdpbmRvdygpO1xuICB9XG59XG4iXX0=
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=