@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
@@ -67,5 +67,5 @@ export declare class SkyAffixDirective implements OnInit, OnChanges, OnDestroy {
67
67
  ngOnChanges(changes: SimpleChanges): void;
68
68
  ngOnDestroy(): void;
69
69
  static ɵfac: i0.ɵɵFactoryDeclaration<SkyAffixDirective, never>;
70
- static ɵdir: i0.ɵɵDirectiveDeclaration<SkyAffixDirective, "[skyAffixTo]", never, { "skyAffixTo": "skyAffixTo"; "affixAutoFitContext": "affixAutoFitContext"; "affixAutoFitOverflowOffset": "affixAutoFitOverflowOffset"; "affixEnableAutoFit": "affixEnableAutoFit"; "affixHorizontalAlignment": "affixHorizontalAlignment"; "affixIsSticky": "affixIsSticky"; "affixPlacement": "affixPlacement"; "affixPosition": "affixPosition"; "affixVerticalAlignment": "affixVerticalAlignment"; }, { "affixOffsetChange": "affixOffsetChange"; "affixOverflowScroll": "affixOverflowScroll"; "affixPlacementChange": "affixPlacementChange"; }, never, never, false, never>;
70
+ static ɵdir: i0.ɵɵDirectiveDeclaration<SkyAffixDirective, "[skyAffixTo]", never, { "skyAffixTo": { "alias": "skyAffixTo"; "required": false; }; "affixAutoFitContext": { "alias": "affixAutoFitContext"; "required": false; }; "affixAutoFitOverflowOffset": { "alias": "affixAutoFitOverflowOffset"; "required": false; }; "affixEnableAutoFit": { "alias": "affixEnableAutoFit"; "required": false; }; "affixHorizontalAlignment": { "alias": "affixHorizontalAlignment"; "required": false; }; "affixIsSticky": { "alias": "affixIsSticky"; "required": false; }; "affixPlacement": { "alias": "affixPlacement"; "required": false; }; "affixPosition": { "alias": "affixPosition"; "required": false; }; "affixVerticalAlignment": { "alias": "affixVerticalAlignment"; "required": false; }; }, { "affixOffsetChange": "affixOffsetChange"; "affixOverflowScroll": "affixOverflowScroll"; "affixPlacementChange": "affixPlacementChange"; }, never, never, false, never>;
71
71
  }
@@ -11,5 +11,5 @@ export declare class SkyViewkeeperDirective implements OnInit, OnDestroy {
11
11
  ngOnInit(): void;
12
12
  ngOnDestroy(): void;
13
13
  static ɵfac: i0.ɵɵFactoryDeclaration<SkyViewkeeperDirective, [null, null, null, { optional: true; }]>;
14
- static ɵdir: i0.ɵɵDirectiveDeclaration<SkyViewkeeperDirective, "[skyViewkeeper]", never, { "skyViewkeeper": "skyViewkeeper"; }, {}, never, never, false, never>;
14
+ static ɵdir: i0.ɵɵDirectiveDeclaration<SkyViewkeeperDirective, "[skyViewkeeper]", never, { "skyViewkeeper": { "alias": "skyViewkeeper"; "required": false; }; }, {}, never, never, false, never>;
15
15
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@skyux/core",
3
- "version": "8.7.0",
3
+ "version": "9.0.0-alpha.0",
4
4
  "author": "Blackbaud, Inc.",
5
5
  "keywords": [
6
6
  "blackbaud",
@@ -21,40 +21,32 @@
21
21
  },
22
22
  ".": {
23
23
  "types": "./index.d.ts",
24
- "esm2020": "./esm2020/skyux-core.mjs",
25
- "es2020": "./fesm2020/skyux-core.mjs",
26
- "es2015": "./fesm2015/skyux-core.mjs",
27
- "node": "./fesm2015/skyux-core.mjs",
28
- "default": "./fesm2020/skyux-core.mjs"
24
+ "esm2022": "./esm2022/skyux-core.mjs",
25
+ "esm": "./esm2022/skyux-core.mjs",
26
+ "default": "./fesm2022/skyux-core.mjs"
29
27
  },
30
28
  "./testing": {
31
29
  "types": "./testing/index.d.ts",
32
- "esm2020": "./esm2020/testing/skyux-core-testing.mjs",
33
- "es2020": "./fesm2020/skyux-core-testing.mjs",
34
- "es2015": "./fesm2015/skyux-core-testing.mjs",
35
- "node": "./fesm2015/skyux-core-testing.mjs",
36
- "default": "./fesm2020/skyux-core-testing.mjs"
30
+ "esm2022": "./esm2022/testing/skyux-core-testing.mjs",
31
+ "esm": "./esm2022/testing/skyux-core-testing.mjs",
32
+ "default": "./fesm2022/skyux-core-testing.mjs"
37
33
  },
38
34
  "./documentation.json": {
39
35
  "default": "./documentation.json"
40
36
  }
41
37
  },
42
38
  "peerDependencies": {
43
- "@angular/cdk": "^15.2.9",
44
- "@angular/common": "^15.2.9",
45
- "@angular/core": "^15.2.9",
46
- "@angular/platform-browser": "^15.2.9",
47
- "@angular/router": "^15.2.9",
48
- "@skyux/i18n": "8.7.0"
39
+ "@angular/cdk": "^16.1.6",
40
+ "@angular/common": "^16.1.7",
41
+ "@angular/core": "^16.1.7",
42
+ "@angular/platform-browser": "^16.1.7",
43
+ "@angular/router": "^16.1.7",
44
+ "@skyux/i18n": "9.0.0-alpha.0"
49
45
  },
50
46
  "dependencies": {
51
47
  "tslib": "^2.5.0"
52
48
  },
53
- "module": "fesm2015/skyux-core.mjs",
54
- "es2020": "fesm2020/skyux-core.mjs",
55
- "esm2020": "esm2020/skyux-core.mjs",
56
- "fesm2020": "fesm2020/skyux-core.mjs",
57
- "fesm2015": "fesm2015/skyux-core.mjs",
49
+ "module": "fesm2022/skyux-core.mjs",
58
50
  "typings": "index.d.ts",
59
51
  "sideEffects": false
60
52
  }
@@ -1,227 +0,0 @@
1
- var _SkyCoreAdapterService_instances, _SkyCoreAdapterService_renderer, _SkyCoreAdapterService_focusFirstElement, _SkyCoreAdapterService_isVisible;
2
- import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
3
- import { Injectable, } from '@angular/core';
4
- import { SkyMediaBreakpoints } from '../media-query/media-breakpoints';
5
- import * as i0 from "@angular/core";
6
- const SKY_TABBABLE_SELECTOR = [
7
- 'a[href]',
8
- 'area[href]',
9
- 'input:not([disabled])',
10
- 'button:not([disabled])',
11
- 'select:not([disabled])',
12
- 'textarea:not([disabled])',
13
- 'iframe',
14
- 'object',
15
- 'embed',
16
- '*[contenteditable=true]:not([disabled])',
17
- '*[tabindex]:not([disabled])',
18
- ].join(', ');
19
- export class SkyCoreAdapterService {
20
- constructor(rendererFactory) {
21
- _SkyCoreAdapterService_instances.add(this);
22
- _SkyCoreAdapterService_renderer.set(this, void 0);
23
- __classPrivateFieldSet(this, _SkyCoreAdapterService_renderer, rendererFactory.createRenderer(undefined, null), "f");
24
- }
25
- /**
26
- * Set the responsive container CSS class for a given element.
27
- *
28
- * @param elementRef - The element that will receive the new CSS class.
29
- * @param breakpoint - The SkyMediaBreakpoint will determine which class
30
- * gets set. For example a SkyMediaBreakpoint of `xs` will set a CSS class of `sky-responsive-container-xs`.
31
- */
32
- setResponsiveContainerClass(elementRef, breakpoint) {
33
- const nativeEl = elementRef.nativeElement;
34
- __classPrivateFieldGet(this, _SkyCoreAdapterService_renderer, "f").removeClass(nativeEl, 'sky-responsive-container-xs');
35
- __classPrivateFieldGet(this, _SkyCoreAdapterService_renderer, "f").removeClass(nativeEl, 'sky-responsive-container-sm');
36
- __classPrivateFieldGet(this, _SkyCoreAdapterService_renderer, "f").removeClass(nativeEl, 'sky-responsive-container-md');
37
- __classPrivateFieldGet(this, _SkyCoreAdapterService_renderer, "f").removeClass(nativeEl, 'sky-responsive-container-lg');
38
- let newClass;
39
- switch (breakpoint) {
40
- case SkyMediaBreakpoints.xs: {
41
- newClass = 'sky-responsive-container-xs';
42
- break;
43
- }
44
- case SkyMediaBreakpoints.sm: {
45
- newClass = 'sky-responsive-container-sm';
46
- break;
47
- }
48
- case SkyMediaBreakpoints.md: {
49
- newClass = 'sky-responsive-container-md';
50
- break;
51
- }
52
- default: {
53
- newClass = 'sky-responsive-container-lg';
54
- break;
55
- }
56
- }
57
- __classPrivateFieldGet(this, _SkyCoreAdapterService_renderer, "f").addClass(nativeEl, newClass);
58
- }
59
- /**
60
- * This method temporarily enables/disables pointer events.
61
- * This is helpful to prevent iFrames from interfering with drag events.
62
- *
63
- * @param enable - Set to `true` to enable pointer events. Set to `false` to disable.
64
- */
65
- toggleIframePointerEvents(enable) {
66
- const iframes = document.querySelectorAll('iframe');
67
- for (let i = 0; i < iframes.length; i++) {
68
- // Setting to empty string will allow iframe to fall back to its prior CSS assignment.
69
- iframes[i].style.pointerEvents = enable ? '' : 'none';
70
- }
71
- }
72
- /**
73
- * Focuses on the first element found with an `autofocus` attribute inside the supplied `elementRef`.
74
- *
75
- * @param elementRef - The element to search within.
76
- * @return Returns `true` if a child element with autofocus is found.
77
- */
78
- applyAutoFocus(elementRef) {
79
- if (!elementRef) {
80
- return false;
81
- }
82
- const elementWithAutoFocus = elementRef.nativeElement.querySelector('[autofocus]');
83
- // Child was found with the autofocus property. Set focus and return true.
84
- if (elementWithAutoFocus) {
85
- elementWithAutoFocus.focus();
86
- return true;
87
- }
88
- // No children were found with autofocus property. Return false.
89
- return false;
90
- }
91
- /**
92
- * Sets focus on the first focusable child of the `elementRef` parameter.
93
- * If no focusable children are found, and `focusOnContainerIfNoChildrenFound` is `true`,
94
- * focus will be set on the container element.
95
- *
96
- * @param elementRef - The element to search within.
97
- * @param containerSelector - A CSS selector indicating the container that should
98
- * receive focus if no focusable children are found.
99
- * @param focusOnContainerIfNoChildrenFound - It set to `true`, the container will
100
- * receive focus if no focusable children are found.
101
- */
102
- getFocusableChildrenAndApplyFocus(elementRef, containerSelector, focusOnContainerIfNoChildrenFound = false) {
103
- const containerElement = elementRef.nativeElement.querySelector(containerSelector);
104
- if (containerElement) {
105
- const focusableChildren = this.getFocusableChildren(containerElement);
106
- // Focus first focusable child if available. Otherwise, set focus on container.
107
- if (!__classPrivateFieldGet(this, _SkyCoreAdapterService_instances, "m", _SkyCoreAdapterService_focusFirstElement).call(this, focusableChildren) &&
108
- focusOnContainerIfNoChildrenFound) {
109
- containerElement.focus();
110
- }
111
- }
112
- }
113
- /**
114
- * Returns an array of all focusable children of provided `element`.
115
- *
116
- * @param element - The HTMLElement to search within.
117
- * @param options - Options for getting focusable children.
118
- */
119
- getFocusableChildren(element, options) {
120
- if (!element) {
121
- return [];
122
- }
123
- let elements = Array.prototype.slice.call(element.querySelectorAll(SKY_TABBABLE_SELECTOR));
124
- // Unless ignoreTabIndex = true, filter out elements with tabindex = -1.
125
- if (!options || !options.ignoreTabIndex) {
126
- elements = elements.filter((el) => {
127
- return el.tabIndex !== -1;
128
- });
129
- }
130
- // Unless ignoreVisibility = true, filter out elements that are not visible.
131
- if (!options || !options.ignoreVisibility) {
132
- elements = elements.filter((el) => {
133
- return __classPrivateFieldGet(this, _SkyCoreAdapterService_instances, "m", _SkyCoreAdapterService_isVisible).call(this, el);
134
- });
135
- }
136
- return elements;
137
- }
138
- /**
139
- * Returns the clientWidth of the provided elementRef.
140
- * @param elementRef - The element to calculate width from.
141
- */
142
- getWidth(elementRef) {
143
- return elementRef.nativeElement.clientWidth;
144
- }
145
- /**
146
- * Checks if an event target has a higher z-index than a given element.
147
- * @param target The event target element.
148
- * @param element The element to test against. A z-index must be explicitly set for this element.
149
- */
150
- isTargetAboveElement(target, element) {
151
- const zIndex = getComputedStyle(element).zIndex;
152
- let el = target;
153
- while (el) {
154
- // Getting the computed style only works for elements that exist in the DOM.
155
- // In certain scenarios, an element is removed after a click event; by the time the event
156
- // bubbles up to other elements, however, the element has been removed and the computed style returns empty.
157
- // In this case, we'll need to check the z-index directly, via the style property.
158
- const targetZIndex = getComputedStyle(el).zIndex || el.style.zIndex;
159
- if (targetZIndex !== '' &&
160
- targetZIndex !== 'auto' &&
161
- +targetZIndex > +zIndex) {
162
- return true;
163
- }
164
- el = el.parentElement;
165
- }
166
- return false;
167
- }
168
- /**
169
- * Remove inline height styles from the provided elements.
170
- * @param elementRef - The element to search within.
171
- * @param selector - The CSS selector to use when finding elements for removing height.
172
- */
173
- resetHeight(elementRef, selector) {
174
- const children = elementRef.nativeElement.querySelectorAll(selector);
175
- /* istanbul ignore else */
176
- if (children.length > 0) {
177
- for (let i = 0; i < children.length; i++) {
178
- // Setting style attributes with Web API requires null instead of undefined.
179
- children[i].style.height = null;
180
- }
181
- }
182
- }
183
- /**
184
- * Sets all element heights to match the height of the tallest element.
185
- * @param elementRef - The element to search within.
186
- * @param selector - The CSS selector to use when finding elements for syncing height.
187
- */
188
- syncMaxHeight(elementRef, selector) {
189
- const children = elementRef.nativeElement.querySelectorAll(selector);
190
- /* istanbul ignore else */
191
- if (children.length > 0) {
192
- let maxHeight = 0;
193
- for (let i = 0; i < children.length; i++) {
194
- maxHeight = Math.max(maxHeight, children[i].offsetHeight);
195
- }
196
- for (let i = 0; i < children.length; i++) {
197
- children[i].style.height = maxHeight + 'px';
198
- }
199
- }
200
- }
201
- }
202
- _SkyCoreAdapterService_renderer = new WeakMap(), _SkyCoreAdapterService_instances = new WeakSet(), _SkyCoreAdapterService_focusFirstElement = function _SkyCoreAdapterService_focusFirstElement(list) {
203
- if (list.length > 0) {
204
- list[0].focus();
205
- return true;
206
- }
207
- return false;
208
- }, _SkyCoreAdapterService_isVisible = function _SkyCoreAdapterService_isVisible(element) {
209
- const style = window.getComputedStyle(element);
210
- const isHidden = style.display === 'none' || style.visibility === 'hidden';
211
- if (isHidden) {
212
- return false;
213
- }
214
- const hasBounds = !!(element.offsetWidth ||
215
- element.offsetHeight ||
216
- element.getClientRects().length);
217
- return hasBounds;
218
- };
219
- SkyCoreAdapterService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyCoreAdapterService, deps: [{ token: i0.RendererFactory2 }], target: i0.ɵɵFactoryTarget.Injectable });
220
- SkyCoreAdapterService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyCoreAdapterService, providedIn: 'root' });
221
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyCoreAdapterService, decorators: [{
222
- type: Injectable,
223
- args: [{
224
- providedIn: 'root',
225
- }]
226
- }], ctorParameters: function () { return [{ type: i0.RendererFactory2 }]; } });
227
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"adapter.service.js","sourceRoot":"","sources":["../../../../../../../../libs/components/core/src/lib/modules/adapter-service/adapter.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ElementRef,\n  Injectable,\n  Renderer2,\n  RendererFactory2,\n} from '@angular/core';\n\nimport { SkyMediaBreakpoints } from '../media-query/media-breakpoints';\n\nimport { SkyFocusableChildrenOptions } from './focusable-children-options';\n\nconst SKY_TABBABLE_SELECTOR = [\n  'a[href]',\n  'area[href]',\n  'input:not([disabled])',\n  'button:not([disabled])',\n  'select:not([disabled])',\n  'textarea:not([disabled])',\n  'iframe',\n  'object',\n  'embed',\n  '*[contenteditable=true]:not([disabled])',\n  '*[tabindex]:not([disabled])',\n].join(', ');\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class SkyCoreAdapterService {\n  #renderer: Renderer2;\n\n  constructor(rendererFactory: RendererFactory2) {\n    this.#renderer = rendererFactory.createRenderer(undefined, null);\n  }\n\n  /**\n   * Set the responsive container CSS class for a given element.\n   *\n   * @param elementRef - The element that will receive the new CSS class.\n   * @param breakpoint - The SkyMediaBreakpoint will determine which class\n   * gets set. For example a SkyMediaBreakpoint of `xs` will set a CSS class of `sky-responsive-container-xs`.\n   */\n  public setResponsiveContainerClass(\n    elementRef: ElementRef,\n    breakpoint: SkyMediaBreakpoints\n  ): void {\n    const nativeEl = elementRef.nativeElement;\n\n    this.#renderer.removeClass(nativeEl, 'sky-responsive-container-xs');\n    this.#renderer.removeClass(nativeEl, 'sky-responsive-container-sm');\n    this.#renderer.removeClass(nativeEl, 'sky-responsive-container-md');\n    this.#renderer.removeClass(nativeEl, 'sky-responsive-container-lg');\n\n    let newClass: string;\n\n    switch (breakpoint) {\n      case SkyMediaBreakpoints.xs: {\n        newClass = 'sky-responsive-container-xs';\n        break;\n      }\n      case SkyMediaBreakpoints.sm: {\n        newClass = 'sky-responsive-container-sm';\n        break;\n      }\n      case SkyMediaBreakpoints.md: {\n        newClass = 'sky-responsive-container-md';\n        break;\n      }\n      default: {\n        newClass = 'sky-responsive-container-lg';\n        break;\n      }\n    }\n\n    this.#renderer.addClass(nativeEl, newClass);\n  }\n\n  /**\n   * This method temporarily enables/disables pointer events.\n   * This is helpful to prevent iFrames from interfering with drag events.\n   *\n   * @param enable - Set to `true` to enable pointer events. Set to `false` to disable.\n   */\n  public toggleIframePointerEvents(enable: boolean): void {\n    const iframes = document.querySelectorAll('iframe');\n    for (let i = 0; i < iframes.length; i++) {\n      // Setting to empty string will allow iframe to fall back to its prior CSS assignment.\n      iframes[i].style.pointerEvents = enable ? '' : 'none';\n    }\n  }\n\n  /**\n   * Focuses on the first element found with an `autofocus` attribute inside the supplied `elementRef`.\n   *\n   * @param elementRef - The element to search within.\n   * @return Returns `true` if a child element with autofocus is found.\n   */\n  public applyAutoFocus(elementRef?: ElementRef): boolean {\n    if (!elementRef) {\n      return false;\n    }\n\n    const elementWithAutoFocus =\n      elementRef.nativeElement.querySelector('[autofocus]');\n\n    // Child was found with the autofocus property. Set focus and return true.\n    if (elementWithAutoFocus) {\n      elementWithAutoFocus.focus();\n      return true;\n    }\n\n    // No children were found with autofocus property. Return false.\n    return false;\n  }\n\n  /**\n   * Sets focus on the first focusable child of the `elementRef` parameter.\n   * If no focusable children are found, and `focusOnContainerIfNoChildrenFound` is `true`,\n   * focus will be set on the container element.\n   *\n   * @param elementRef - The element to search within.\n   * @param containerSelector - A CSS selector indicating the container that should\n   * receive focus if no focusable children are found.\n   * @param focusOnContainerIfNoChildrenFound - It set to `true`, the container will\n   * receive focus if no focusable children are found.\n   */\n  public getFocusableChildrenAndApplyFocus(\n    elementRef: ElementRef,\n    containerSelector?: string,\n    focusOnContainerIfNoChildrenFound = false\n  ): void {\n    const containerElement =\n      elementRef.nativeElement.querySelector(containerSelector);\n\n    if (containerElement) {\n      const focusableChildren = this.getFocusableChildren(containerElement);\n\n      // Focus first focusable child if available. Otherwise, set focus on container.\n      if (\n        !this.#focusFirstElement(focusableChildren) &&\n        focusOnContainerIfNoChildrenFound\n      ) {\n        containerElement.focus();\n      }\n    }\n  }\n\n  /**\n   * Returns an array of all focusable children of provided `element`.\n   *\n   * @param element - The HTMLElement to search within.\n   * @param options - Options for getting focusable children.\n   */\n  public getFocusableChildren(\n    element?: HTMLElement,\n    options?: SkyFocusableChildrenOptions\n  ): HTMLElement[] {\n    if (!element) {\n      return [];\n    }\n\n    let elements = Array.prototype.slice.call(\n      element.querySelectorAll(SKY_TABBABLE_SELECTOR)\n    );\n\n    // Unless ignoreTabIndex = true, filter out elements with tabindex = -1.\n    if (!options || !options.ignoreTabIndex) {\n      elements = elements.filter((el: HTMLElement) => {\n        return el.tabIndex !== -1;\n      });\n    }\n\n    // Unless ignoreVisibility = true, filter out elements that are not visible.\n    if (!options || !options.ignoreVisibility) {\n      elements = elements.filter((el: HTMLElement) => {\n        return this.#isVisible(el);\n      });\n    }\n\n    return elements;\n  }\n\n  /**\n   * Returns the clientWidth of the provided elementRef.\n   * @param elementRef - The element to calculate width from.\n   */\n  public getWidth(elementRef: ElementRef): number {\n    return elementRef.nativeElement.clientWidth;\n  }\n\n  /**\n   * Checks if an event target has a higher z-index than a given element.\n   * @param target The event target element.\n   * @param element The element to test against. A z-index must be explicitly set for this element.\n   */\n  public isTargetAboveElement(\n    target: EventTarget,\n    element: HTMLElement\n  ): boolean {\n    const zIndex = getComputedStyle(element).zIndex;\n\n    let el = target as HTMLElement;\n\n    while (el) {\n      // Getting the computed style only works for elements that exist in the DOM.\n      // In certain scenarios, an element is removed after a click event; by the time the event\n      // bubbles up to other elements, however, the element has been removed and the computed style returns empty.\n      // In this case, we'll need to check the z-index directly, via the style property.\n      const targetZIndex = getComputedStyle(el).zIndex || el.style.zIndex;\n      if (\n        targetZIndex !== '' &&\n        targetZIndex !== 'auto' &&\n        +targetZIndex > +zIndex\n      ) {\n        return true;\n      }\n\n      el = el.parentElement as HTMLElement;\n    }\n\n    return false;\n  }\n\n  /**\n   * Remove inline height styles from the provided elements.\n   * @param elementRef - The element to search within.\n   * @param selector - The CSS selector to use when finding elements for removing height.\n   */\n  public resetHeight(elementRef: ElementRef, selector: string): void {\n    const children = elementRef.nativeElement.querySelectorAll(selector);\n    /* istanbul ignore else */\n    if (children.length > 0) {\n      for (let i = 0; i < children.length; i++) {\n        // Setting style attributes with Web API requires null instead of undefined.\n        children[i].style.height = null;\n      }\n    }\n  }\n\n  /**\n   * Sets all element heights to match the height of the tallest element.\n   * @param elementRef - The element to search within.\n   * @param selector - The CSS selector to use when finding elements for syncing height.\n   */\n  public syncMaxHeight(elementRef: ElementRef, selector: string): void {\n    const children = elementRef.nativeElement.querySelectorAll(selector);\n    /* istanbul ignore else */\n    if (children.length > 0) {\n      let maxHeight = 0;\n      for (let i = 0; i < children.length; i++) {\n        maxHeight = Math.max(maxHeight, children[i].offsetHeight);\n      }\n      for (let i = 0; i < children.length; i++) {\n        children[i].style.height = maxHeight + 'px';\n      }\n    }\n  }\n\n  #focusFirstElement(list: Array<HTMLElement>): boolean {\n    if (list.length > 0) {\n      list[0].focus();\n      return true;\n    }\n    return false;\n  }\n\n  #isVisible(element: HTMLElement): boolean {\n    const style = window.getComputedStyle(element);\n    const isHidden = style.display === 'none' || style.visibility === 'hidden';\n    if (isHidden) {\n      return false;\n    }\n\n    const hasBounds = !!(\n      element.offsetWidth ||\n      element.offsetHeight ||\n      element.getClientRects().length\n    );\n    return hasBounds;\n  }\n}\n"]}
@@ -1,118 +0,0 @@
1
- var _SkyAffixDirective_instances, _SkyAffixDirective_affixer, _SkyAffixDirective_affixService, _SkyAffixDirective_elementRef, _SkyAffixDirective_ngUnsubscribe, _SkyAffixDirective_updateAlignment;
2
- import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
3
- import { Directive, EventEmitter, Input, Output, } from '@angular/core';
4
- import { Subject } from 'rxjs';
5
- import { takeUntil } from 'rxjs/operators';
6
- import * as i0 from "@angular/core";
7
- import * as i1 from "./affix.service";
8
- /**
9
- * Affixes the host element to a base element.
10
- */
11
- export class SkyAffixDirective {
12
- constructor(elementRef, affixService) {
13
- _SkyAffixDirective_instances.add(this);
14
- /**
15
- * Fires when the affixed element's offset changes.
16
- */
17
- this.affixOffsetChange = new EventEmitter();
18
- /**
19
- * Fires when the affixed element's overflow container is scrolled.
20
- */
21
- this.affixOverflowScroll = new EventEmitter();
22
- /**
23
- * Fires when the placement value changes.
24
- */
25
- this.affixPlacementChange = new EventEmitter();
26
- _SkyAffixDirective_affixer.set(this, void 0);
27
- _SkyAffixDirective_affixService.set(this, void 0);
28
- _SkyAffixDirective_elementRef.set(this, void 0);
29
- _SkyAffixDirective_ngUnsubscribe.set(this, new Subject());
30
- __classPrivateFieldSet(this, _SkyAffixDirective_elementRef, elementRef, "f");
31
- __classPrivateFieldSet(this, _SkyAffixDirective_affixService, affixService, "f");
32
- }
33
- ngOnInit() {
34
- __classPrivateFieldSet(this, _SkyAffixDirective_affixer, __classPrivateFieldGet(this, _SkyAffixDirective_affixService, "f").createAffixer(__classPrivateFieldGet(this, _SkyAffixDirective_elementRef, "f")), "f");
35
- __classPrivateFieldGet(this, _SkyAffixDirective_affixer, "f").offsetChange
36
- .pipe(takeUntil(__classPrivateFieldGet(this, _SkyAffixDirective_ngUnsubscribe, "f")))
37
- .subscribe((change) => this.affixOffsetChange.emit(change));
38
- __classPrivateFieldGet(this, _SkyAffixDirective_affixer, "f").overflowScroll
39
- .pipe(takeUntil(__classPrivateFieldGet(this, _SkyAffixDirective_ngUnsubscribe, "f")))
40
- .subscribe((change) => this.affixOverflowScroll.emit(change));
41
- __classPrivateFieldGet(this, _SkyAffixDirective_affixer, "f").placementChange
42
- .pipe(takeUntil(__classPrivateFieldGet(this, _SkyAffixDirective_ngUnsubscribe, "f")))
43
- .subscribe((change) => this.affixPlacementChange.emit(change));
44
- __classPrivateFieldGet(this, _SkyAffixDirective_instances, "m", _SkyAffixDirective_updateAlignment).call(this);
45
- }
46
- ngOnChanges(changes) {
47
- /* istanbul ignore else */
48
- if (changes['affixAutoFitContext'] ||
49
- changes['affixAutoFitOverflowOffset'] ||
50
- changes['affixEnableAutoFit'] ||
51
- changes['affixHorizontalAlignment'] ||
52
- changes['affixIsSticky'] ||
53
- changes['affixPlacement'] ||
54
- changes['affixPosition'] ||
55
- changes['affixVerticalAlignment']) {
56
- __classPrivateFieldGet(this, _SkyAffixDirective_instances, "m", _SkyAffixDirective_updateAlignment).call(this);
57
- }
58
- }
59
- ngOnDestroy() {
60
- this.affixOffsetChange.complete();
61
- this.affixOverflowScroll.complete();
62
- this.affixPlacementChange.complete();
63
- __classPrivateFieldGet(this, _SkyAffixDirective_ngUnsubscribe, "f").next();
64
- __classPrivateFieldGet(this, _SkyAffixDirective_ngUnsubscribe, "f").complete();
65
- /*istanbul ignore else*/
66
- if (__classPrivateFieldGet(this, _SkyAffixDirective_affixer, "f")) {
67
- __classPrivateFieldGet(this, _SkyAffixDirective_affixer, "f").destroy();
68
- __classPrivateFieldSet(this, _SkyAffixDirective_affixer, undefined, "f");
69
- }
70
- }
71
- }
72
- _SkyAffixDirective_affixer = new WeakMap(), _SkyAffixDirective_affixService = new WeakMap(), _SkyAffixDirective_elementRef = new WeakMap(), _SkyAffixDirective_ngUnsubscribe = new WeakMap(), _SkyAffixDirective_instances = new WeakSet(), _SkyAffixDirective_updateAlignment = function _SkyAffixDirective_updateAlignment() {
73
- if (this.skyAffixTo && __classPrivateFieldGet(this, _SkyAffixDirective_affixer, "f")) {
74
- __classPrivateFieldGet(this, _SkyAffixDirective_affixer, "f").affixTo(this.skyAffixTo, {
75
- autoFitContext: this.affixAutoFitContext,
76
- autoFitOverflowOffset: this.affixAutoFitOverflowOffset,
77
- enableAutoFit: this.affixEnableAutoFit,
78
- horizontalAlignment: this.affixHorizontalAlignment,
79
- isSticky: this.affixIsSticky,
80
- placement: this.affixPlacement,
81
- position: this.affixPosition,
82
- verticalAlignment: this.affixVerticalAlignment,
83
- });
84
- }
85
- };
86
- SkyAffixDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyAffixDirective, deps: [{ token: i0.ElementRef }, { token: i1.SkyAffixService }], target: i0.ɵɵFactoryTarget.Directive });
87
- SkyAffixDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.9", type: SkyAffixDirective, selector: "[skyAffixTo]", inputs: { skyAffixTo: "skyAffixTo", affixAutoFitContext: "affixAutoFitContext", affixAutoFitOverflowOffset: "affixAutoFitOverflowOffset", affixEnableAutoFit: "affixEnableAutoFit", affixHorizontalAlignment: "affixHorizontalAlignment", affixIsSticky: "affixIsSticky", affixPlacement: "affixPlacement", affixPosition: "affixPosition", affixVerticalAlignment: "affixVerticalAlignment" }, outputs: { affixOffsetChange: "affixOffsetChange", affixOverflowScroll: "affixOverflowScroll", affixPlacementChange: "affixPlacementChange" }, usesOnChanges: true, ngImport: i0 });
88
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyAffixDirective, decorators: [{
89
- type: Directive,
90
- args: [{
91
- selector: '[skyAffixTo]',
92
- }]
93
- }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.SkyAffixService }]; }, propDecorators: { skyAffixTo: [{
94
- type: Input
95
- }], affixAutoFitContext: [{
96
- type: Input
97
- }], affixAutoFitOverflowOffset: [{
98
- type: Input
99
- }], affixEnableAutoFit: [{
100
- type: Input
101
- }], affixHorizontalAlignment: [{
102
- type: Input
103
- }], affixIsSticky: [{
104
- type: Input
105
- }], affixPlacement: [{
106
- type: Input
107
- }], affixPosition: [{
108
- type: Input
109
- }], affixVerticalAlignment: [{
110
- type: Input
111
- }], affixOffsetChange: [{
112
- type: Output
113
- }], affixOverflowScroll: [{
114
- type: Output
115
- }], affixPlacementChange: [{
116
- type: Output
117
- }] } });
118
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"affix.directive.js","sourceRoot":"","sources":["../../../../../../../../libs/components/core/src/lib/modules/affix/affix.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  SimpleChanges,\n} from '@angular/core';\n\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyAffixAutoFitContext } from './affix-auto-fit-context';\nimport { SkyAffixHorizontalAlignment } from './affix-horizontal-alignment';\nimport { SkyAffixOffset } from './affix-offset';\nimport { SkyAffixOffsetChange } from './affix-offset-change';\nimport { SkyAffixPlacement } from './affix-placement';\nimport { SkyAffixPlacementChange } from './affix-placement-change';\nimport { SkyAffixPosition } from './affix-position';\nimport { SkyAffixVerticalAlignment } from './affix-vertical-alignment';\nimport { SkyAffixService } from './affix.service';\nimport { SkyAffixer } from './affixer';\n\n/**\n * Affixes the host element to a base element.\n */\n@Directive({\n  selector: '[skyAffixTo]',\n})\nexport class SkyAffixDirective implements OnInit, OnChanges, OnDestroy {\n  /**\n   * The base element to affix the host element.\n   */\n  @Input()\n  public skyAffixTo: HTMLElement | undefined;\n\n  /**\n   * Sets the `autoFitContext` property of [[SkyAffixConfig]].\n   */\n  @Input()\n  public affixAutoFitContext: SkyAffixAutoFitContext | undefined;\n\n  /**\n   * Sets the `autoFitOverflowOffset` property of [[SkyAffixConfig]].\n   */\n  @Input()\n  public affixAutoFitOverflowOffset: SkyAffixOffset | undefined;\n\n  /**\n   * Sets the `enableAutoFit` property of [[SkyAffixConfig]].\n   */\n  @Input()\n  public affixEnableAutoFit: boolean | undefined;\n\n  /**\n   * Sets the `horizontalAlignment` property of [[SkyAffixConfig]].\n   */\n  @Input()\n  public affixHorizontalAlignment: SkyAffixHorizontalAlignment | undefined;\n\n  /**\n   * Sets the `isSticky` property of [[SkyAffixConfig]].\n   */\n  @Input()\n  public affixIsSticky: boolean | undefined;\n\n  /**\n   * Sets the `placement` property of [[SkyAffixConfig]].\n   */\n  @Input()\n  public affixPlacement: SkyAffixPlacement | undefined;\n\n  /**\n   * Sets the `position` property of [[SkyAffixConfig]].\n   */\n  @Input()\n  public affixPosition: SkyAffixPosition | undefined;\n\n  /**\n   * Sets the `verticalAlignment` property of [[SkyAffixConfig]].\n   */\n  @Input()\n  public affixVerticalAlignment: SkyAffixVerticalAlignment | undefined;\n\n  /**\n   * Fires when the affixed element's offset changes.\n   */\n  @Output()\n  public affixOffsetChange = new EventEmitter<SkyAffixOffsetChange>();\n\n  /**\n   * Fires when the affixed element's overflow container is scrolled.\n   */\n  @Output()\n  public affixOverflowScroll = new EventEmitter<void>();\n\n  /**\n   * Fires when the placement value changes.\n   */\n  @Output()\n  public affixPlacementChange = new EventEmitter<SkyAffixPlacementChange>();\n\n  #affixer: SkyAffixer | undefined;\n\n  #affixService: SkyAffixService;\n\n  #elementRef: ElementRef;\n\n  #ngUnsubscribe = new Subject<void>();\n\n  constructor(elementRef: ElementRef, affixService: SkyAffixService) {\n    this.#elementRef = elementRef;\n    this.#affixService = affixService;\n  }\n\n  public ngOnInit(): void {\n    this.#affixer = this.#affixService.createAffixer(this.#elementRef);\n\n    this.#affixer.offsetChange\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((change) => this.affixOffsetChange.emit(change));\n\n    this.#affixer.overflowScroll\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((change) => this.affixOverflowScroll.emit(change));\n\n    this.#affixer.placementChange\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((change) => this.affixPlacementChange.emit(change));\n\n    this.#updateAlignment();\n  }\n\n  public ngOnChanges(changes: SimpleChanges): void {\n    /* istanbul ignore else */\n    if (\n      changes['affixAutoFitContext'] ||\n      changes['affixAutoFitOverflowOffset'] ||\n      changes['affixEnableAutoFit'] ||\n      changes['affixHorizontalAlignment'] ||\n      changes['affixIsSticky'] ||\n      changes['affixPlacement'] ||\n      changes['affixPosition'] ||\n      changes['affixVerticalAlignment']\n    ) {\n      this.#updateAlignment();\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this.affixOffsetChange.complete();\n    this.affixOverflowScroll.complete();\n    this.affixPlacementChange.complete();\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n\n    /*istanbul ignore else*/\n    if (this.#affixer) {\n      this.#affixer.destroy();\n      this.#affixer = undefined;\n    }\n  }\n\n  #updateAlignment(): void {\n    if (this.skyAffixTo && this.#affixer) {\n      this.#affixer.affixTo(this.skyAffixTo, {\n        autoFitContext: this.affixAutoFitContext,\n        autoFitOverflowOffset: this.affixAutoFitOverflowOffset,\n        enableAutoFit: this.affixEnableAutoFit,\n        horizontalAlignment: this.affixHorizontalAlignment,\n        isSticky: this.affixIsSticky,\n        placement: this.affixPlacement,\n        position: this.affixPosition,\n        verticalAlignment: this.affixVerticalAlignment,\n      });\n    }\n  }\n}\n"]}
@@ -1,28 +0,0 @@
1
- var _SkyAffixService_renderer;
2
- import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
3
- import { Injectable, } from '@angular/core';
4
- import { SkyAffixer } from './affixer';
5
- import * as i0 from "@angular/core";
6
- export class SkyAffixService {
7
- constructor(rendererFactory) {
8
- _SkyAffixService_renderer.set(this, void 0);
9
- __classPrivateFieldSet(this, _SkyAffixService_renderer, rendererFactory.createRenderer(undefined, null), "f");
10
- }
11
- /**
12
- * Creates an instance of [[SkyAffixer]].
13
- * @param affixed The element to be affixed.
14
- */
15
- createAffixer(affixed) {
16
- return new SkyAffixer(affixed.nativeElement, __classPrivateFieldGet(this, _SkyAffixService_renderer, "f"));
17
- }
18
- }
19
- _SkyAffixService_renderer = new WeakMap();
20
- SkyAffixService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyAffixService, deps: [{ token: i0.RendererFactory2 }], target: i0.ɵɵFactoryTarget.Injectable });
21
- SkyAffixService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyAffixService, providedIn: 'root' });
22
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyAffixService, decorators: [{
23
- type: Injectable,
24
- args: [{
25
- providedIn: 'root',
26
- }]
27
- }], ctorParameters: function () { return [{ type: i0.RendererFactory2 }]; } });
28
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWZmaXguc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9jb3JlL3NyYy9saWIvbW9kdWxlcy9hZmZpeC9hZmZpeC5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsT0FBTyxFQUVMLFVBQVUsR0FHWCxNQUFNLGVBQWUsQ0FBQztBQUV2QixPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sV0FBVyxDQUFDOztBQUt2QyxNQUFNLE9BQU8sZUFBZTtJQUcxQixZQUFZLGVBQWlDO1FBRjdDLDRDQUFxQjtRQUduQix1QkFBQSxJQUFJLDZCQUFhLGVBQWUsQ0FBQyxjQUFjLENBQUMsU0FBUyxFQUFFLElBQUksQ0FBQyxNQUFBLENBQUM7SUFDbkUsQ0FBQztJQUVEOzs7T0FHRztJQUNJLGFBQWEsQ0FBQyxPQUFtQjtRQUN0QyxPQUFPLElBQUksVUFBVSxDQUFDLE9BQU8sQ0FBQyxhQUFhLEVBQUUsdUJBQUEsSUFBSSxpQ0FBVSxDQUFDLENBQUM7SUFDL0QsQ0FBQzs7OzRHQWJVLGVBQWU7Z0hBQWYsZUFBZSxjQUZkLE1BQU07MkZBRVAsZUFBZTtrQkFIM0IsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBFbGVtZW50UmVmLFxuICBJbmplY3RhYmxlLFxuICBSZW5kZXJlcjIsXG4gIFJlbmRlcmVyRmFjdG9yeTIsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBTa3lBZmZpeGVyIH0gZnJvbSAnLi9hZmZpeGVyJztcblxuQEluamVjdGFibGUoe1xuICBwcm92aWRlZEluOiAncm9vdCcsXG59KVxuZXhwb3J0IGNsYXNzIFNreUFmZml4U2VydmljZSB7XG4gICNyZW5kZXJlcjogUmVuZGVyZXIyO1xuXG4gIGNvbnN0cnVjdG9yKHJlbmRlcmVyRmFjdG9yeTogUmVuZGVyZXJGYWN0b3J5Mikge1xuICAgIHRoaXMuI3JlbmRlcmVyID0gcmVuZGVyZXJGYWN0b3J5LmNyZWF0ZVJlbmRlcmVyKHVuZGVmaW5lZCwgbnVsbCk7XG4gIH1cblxuICAvKipcbiAgICogQ3JlYXRlcyBhbiBpbnN0YW5jZSBvZiBbW1NreUFmZml4ZXJdXS5cbiAgICogQHBhcmFtIGFmZml4ZWQgVGhlIGVsZW1lbnQgdG8gYmUgYWZmaXhlZC5cbiAgICovXG4gIHB1YmxpYyBjcmVhdGVBZmZpeGVyKGFmZml4ZWQ6IEVsZW1lbnRSZWYpOiBTa3lBZmZpeGVyIHtcbiAgICByZXR1cm4gbmV3IFNreUFmZml4ZXIoYWZmaXhlZC5uYXRpdmVFbGVtZW50LCB0aGlzLiNyZW5kZXJlcik7XG4gIH1cbn1cbiJdfQ==