@skyux/core 11.39.0 → 12.0.0-alpha.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (143) hide show
  1. package/documentation.json +600 -536
  2. package/fesm2022/skyux-core-testing.mjs +26 -26
  3. package/fesm2022/skyux-core-testing.mjs.map +1 -1
  4. package/fesm2022/skyux-core.mjs +188 -188
  5. package/fesm2022/skyux-core.mjs.map +1 -1
  6. package/lib/modules/content-info-provider/content-info-provider.d.ts +0 -3
  7. package/lib/modules/dock/dock.service.d.ts +2 -0
  8. package/package.json +8 -12
  9. package/esm2022/index.mjs +0 -67
  10. package/esm2022/lib/modules/adapter-service/adapter.module.mjs +0 -16
  11. package/esm2022/lib/modules/adapter-service/adapter.service.mjs +0 -205
  12. package/esm2022/lib/modules/adapter-service/focusable-children-options.mjs +0 -2
  13. package/esm2022/lib/modules/affix/affix-auto-fit-context.mjs +0 -12
  14. package/esm2022/lib/modules/affix/affix-config.mjs +0 -2
  15. package/esm2022/lib/modules/affix/affix-horizontal-alignment.mjs +0 -2
  16. package/esm2022/lib/modules/affix/affix-offset-change.mjs +0 -2
  17. package/esm2022/lib/modules/affix/affix-offset.mjs +0 -2
  18. package/esm2022/lib/modules/affix/affix-placement-change.mjs +0 -2
  19. package/esm2022/lib/modules/affix/affix-placement.mjs +0 -2
  20. package/esm2022/lib/modules/affix/affix-position.mjs +0 -2
  21. package/esm2022/lib/modules/affix/affix-rect.mjs +0 -2
  22. package/esm2022/lib/modules/affix/affix-utils.mjs +0 -18
  23. package/esm2022/lib/modules/affix/affix-vertical-alignment.mjs +0 -2
  24. package/esm2022/lib/modules/affix/affix.directive.mjs +0 -116
  25. package/esm2022/lib/modules/affix/affix.module.mjs +0 -18
  26. package/esm2022/lib/modules/affix/affix.service.mjs +0 -48
  27. package/esm2022/lib/modules/affix/affixer.mjs +0 -426
  28. package/esm2022/lib/modules/affix/dom-utils.mjs +0 -126
  29. package/esm2022/lib/modules/breakpoint-observer/breakpoint-observer.mjs +0 -2
  30. package/esm2022/lib/modules/breakpoint-observer/breakpoint-observer.token.mjs +0 -7
  31. package/esm2022/lib/modules/breakpoint-observer/breakpoint-utils.mjs +0 -38
  32. package/esm2022/lib/modules/breakpoint-observer/breakpoint.mjs +0 -6
  33. package/esm2022/lib/modules/breakpoint-observer/container-breakpoint-observer.mjs +0 -64
  34. package/esm2022/lib/modules/breakpoint-observer/media-breakpoint-observer.mjs +0 -58
  35. package/esm2022/lib/modules/breakpoint-observer/provide-breakpoint-observer.mjs +0 -24
  36. package/esm2022/lib/modules/breakpoint-observer/responsive-host.directive.mjs +0 -55
  37. package/esm2022/lib/modules/content-info-provider/content-info-descriptor.mjs +0 -2
  38. package/esm2022/lib/modules/content-info-provider/content-info-provider.mjs +0 -31
  39. package/esm2022/lib/modules/content-info-provider/content-info.mjs +0 -2
  40. package/esm2022/lib/modules/default-input-provider/default-input-provider.mjs +0 -26
  41. package/esm2022/lib/modules/dock/dock-dom-adapter.service.mjs +0 -81
  42. package/esm2022/lib/modules/dock/dock-insert-component-config.mjs +0 -2
  43. package/esm2022/lib/modules/dock/dock-item-config.mjs +0 -2
  44. package/esm2022/lib/modules/dock/dock-item-reference.mjs +0 -2
  45. package/esm2022/lib/modules/dock/dock-item.mjs +0 -31
  46. package/esm2022/lib/modules/dock/dock-location.mjs +0 -19
  47. package/esm2022/lib/modules/dock/dock-options.mjs +0 -2
  48. package/esm2022/lib/modules/dock/dock.component.mjs +0 -101
  49. package/esm2022/lib/modules/dock/dock.module.mjs +0 -15
  50. package/esm2022/lib/modules/dock/dock.service.mjs +0 -97
  51. package/esm2022/lib/modules/dock/sort-by-stack-order.mjs +0 -13
  52. package/esm2022/lib/modules/dynamic-component/dynamic-component-location.mjs +0 -27
  53. package/esm2022/lib/modules/dynamic-component/dynamic-component-options.mjs +0 -2
  54. package/esm2022/lib/modules/dynamic-component/dynamic-component.module.mjs +0 -17
  55. package/esm2022/lib/modules/dynamic-component/dynamic-component.service.mjs +0 -113
  56. package/esm2022/lib/modules/file-reader/file-reader.service.mjs +0 -32
  57. package/esm2022/lib/modules/format/app-format.mjs +0 -18
  58. package/esm2022/lib/modules/help/help-global-options-token.mjs +0 -6
  59. package/esm2022/lib/modules/help/help-global-options.mjs +0 -2
  60. package/esm2022/lib/modules/help/help-open-args.mjs +0 -2
  61. package/esm2022/lib/modules/help/help-update-args.mjs +0 -2
  62. package/esm2022/lib/modules/help/help.service.mjs +0 -20
  63. package/esm2022/lib/modules/id/id.directive.mjs +0 -31
  64. package/esm2022/lib/modules/id/id.module.mjs +0 -16
  65. package/esm2022/lib/modules/id/id.service.mjs +0 -24
  66. package/esm2022/lib/modules/layout-host/layout-host-for-child-args.mjs +0 -2
  67. package/esm2022/lib/modules/layout-host/layout-host.service.mjs +0 -22
  68. package/esm2022/lib/modules/live-announcer/live-announcer.service.mjs +0 -81
  69. package/esm2022/lib/modules/live-announcer/types/live-announcer-args.mjs +0 -2
  70. package/esm2022/lib/modules/live-announcer/types/live-announcer-politeness.mjs +0 -2
  71. package/esm2022/lib/modules/log/log.module.mjs +0 -16
  72. package/esm2022/lib/modules/log/log.service.mjs +0 -148
  73. package/esm2022/lib/modules/log/types/log-deprecation-args.mjs +0 -2
  74. package/esm2022/lib/modules/log/types/log-level-token.mjs +0 -6
  75. package/esm2022/lib/modules/log/types/log-level.mjs +0 -10
  76. package/esm2022/lib/modules/media-query/media-breakpoints.mjs +0 -24
  77. package/esm2022/lib/modules/media-query/media-query-listener.mjs +0 -2
  78. package/esm2022/lib/modules/media-query/media-query.module.mjs +0 -16
  79. package/esm2022/lib/modules/media-query/media-query.service.mjs +0 -82
  80. package/esm2022/lib/modules/mutation/mutation-observer-service.mjs +0 -19
  81. package/esm2022/lib/modules/numeric/numeric-symbol.mjs +0 -2
  82. package/esm2022/lib/modules/numeric/numeric.module.mjs +0 -19
  83. package/esm2022/lib/modules/numeric/numeric.options.mjs +0 -24
  84. package/esm2022/lib/modules/numeric/numeric.pipe.mjs +0 -84
  85. package/esm2022/lib/modules/numeric/numeric.service.mjs +0 -200
  86. package/esm2022/lib/modules/overlay/overlay-adapter.service.mjs +0 -74
  87. package/esm2022/lib/modules/overlay/overlay-config.mjs +0 -2
  88. package/esm2022/lib/modules/overlay/overlay-context.mjs +0 -10
  89. package/esm2022/lib/modules/overlay/overlay-instance.mjs +0 -62
  90. package/esm2022/lib/modules/overlay/overlay-position.mjs +0 -2
  91. package/esm2022/lib/modules/overlay/overlay.component.mjs +0 -203
  92. package/esm2022/lib/modules/overlay/overlay.module.mjs +0 -15
  93. package/esm2022/lib/modules/overlay/overlay.service.mjs +0 -134
  94. package/esm2022/lib/modules/percent-pipe/percent-pipe.module.mjs +0 -19
  95. package/esm2022/lib/modules/percent-pipe/percent.pipe.mjs +0 -56
  96. package/esm2022/lib/modules/resize-observer/resize-observer-media-query.service.mjs +0 -153
  97. package/esm2022/lib/modules/resize-observer/resize-observer.service.mjs +0 -115
  98. package/esm2022/lib/modules/screen-reader-label/screen-reader-label.directive.mjs +0 -66
  99. package/esm2022/lib/modules/scroll-shadow/scroll-shadow-event-args.mjs +0 -2
  100. package/esm2022/lib/modules/scroll-shadow/scroll-shadow.directive.mjs +0 -123
  101. package/esm2022/lib/modules/scrollable-host/scrollable-host.service.mjs +0 -223
  102. package/esm2022/lib/modules/shared/number-format/number-format-utility.mjs +0 -72
  103. package/esm2022/lib/modules/shared/sky-core-resources.module.mjs +0 -34
  104. package/esm2022/lib/modules/stacking-context/stacking-context-token.mjs +0 -6
  105. package/esm2022/lib/modules/stacking-context/stacking-context.mjs +0 -2
  106. package/esm2022/lib/modules/title/set-title-args.mjs +0 -2
  107. package/esm2022/lib/modules/title/title.service.mjs +0 -31
  108. package/esm2022/lib/modules/trim/trim.directive.mjs +0 -64
  109. package/esm2022/lib/modules/trim/trim.module.mjs +0 -16
  110. package/esm2022/lib/modules/ui-config/ui-config.service.mjs +0 -21
  111. package/esm2022/lib/modules/viewkeeper/viewkeeper-boundary-info.mjs +0 -2
  112. package/esm2022/lib/modules/viewkeeper/viewkeeper-fixed-styles.mjs +0 -2
  113. package/esm2022/lib/modules/viewkeeper/viewkeeper-host-options.mjs +0 -10
  114. package/esm2022/lib/modules/viewkeeper/viewkeeper-offset.mjs +0 -2
  115. package/esm2022/lib/modules/viewkeeper/viewkeeper-options.mjs +0 -2
  116. package/esm2022/lib/modules/viewkeeper/viewkeeper.directive.mjs +0 -131
  117. package/esm2022/lib/modules/viewkeeper/viewkeeper.mjs +0 -296
  118. package/esm2022/lib/modules/viewkeeper/viewkeeper.module.mjs +0 -16
  119. package/esm2022/lib/modules/viewkeeper/viewkeeper.service.mjs +0 -39
  120. package/esm2022/lib/modules/window/window-ref.mjs +0 -30
  121. package/esm2022/skyux-core.mjs +0 -5
  122. package/esm2022/testing/legacy/core-testing.module.mjs +0 -32
  123. package/esm2022/testing/legacy/mock-media-query.service.mjs +0 -47
  124. package/esm2022/testing/legacy/mock-ui-config.service.mjs +0 -62
  125. package/esm2022/testing/legacy/resize-observer-mock.mjs +0 -50
  126. package/esm2022/testing/modules/file-reader/file-reader-testing.service.mjs +0 -19
  127. package/esm2022/testing/modules/file-reader/provide-file-reader-testing.mjs +0 -22
  128. package/esm2022/testing/modules/help/help-testing-controller.mjs +0 -28
  129. package/esm2022/testing/modules/help/help-testing.module.mjs +0 -32
  130. package/esm2022/testing/modules/help/help-testing.service.mjs +0 -37
  131. package/esm2022/testing/modules/media-query/breakpoint-observer-testing.mjs +0 -26
  132. package/esm2022/testing/modules/media-query/media-query-testing-controller.mjs +0 -22
  133. package/esm2022/testing/modules/media-query/provide-media-query-testing.mjs +0 -26
  134. package/esm2022/testing/modules/overlay/overlay-harness-filters.mjs +0 -2
  135. package/esm2022/testing/modules/overlay/overlay-harness.mjs +0 -20
  136. package/esm2022/testing/public-api.mjs +0 -15
  137. package/esm2022/testing/shared/component-harness.mjs +0 -13
  138. package/esm2022/testing/shared/harness-filters.mjs +0 -2
  139. package/esm2022/testing/shared/harness-utility.mjs +0 -7
  140. package/esm2022/testing/shared/input-harness.mjs +0 -63
  141. package/esm2022/testing/shared/queryable-component-harness.mjs +0 -43
  142. package/esm2022/testing/skyux-core-testing.mjs +0 -5
  143. package/esm2022/version.mjs +0 -19
@@ -1,153 +0,0 @@
1
- import { Injectable, inject } from '@angular/core';
2
- import { ReplaySubject, Subject } from 'rxjs';
3
- import { takeUntil } from 'rxjs/operators';
4
- import { toSkyBreakpoint } from '../breakpoint-observer/breakpoint-utils';
5
- import { SkyMediaBreakpoints } from '../media-query/media-breakpoints';
6
- import { SkyMediaQueryService } from '../media-query/media-query.service';
7
- import { SkyResizeObserverService } from './resize-observer.service';
8
- import * as i0 from "@angular/core";
9
- const DEFAULT_BREAKPOINT = SkyMediaBreakpoints.md;
10
- /**
11
- * Acts like `SkyMediaQueryService` for a container element, emitting the same responsive breakpoints.
12
- * @deprecated Use the `SkyResponsiveHostDirective` instead.
13
- */
14
- export class SkyResizeObserverMediaQueryService extends SkyMediaQueryService {
15
- /**
16
- * Emits when the breakpoint changes.
17
- */
18
- get breakpointChange() {
19
- return this.#breakpointChangeObs;
20
- }
21
- /**
22
- * Returns the current breakpoint.
23
- * @deprecated Subscribe to the `breakpointChange` observable instead.
24
- */
25
- get current() {
26
- return this.#currentBreakpoint;
27
- }
28
- #breakpointChange = new ReplaySubject(1);
29
- #breakpointChangeObs = this.#breakpointChange.asObservable();
30
- #breakpoints = [
31
- {
32
- check: (width) => width > 0 && width <= 767,
33
- name: SkyMediaBreakpoints.xs,
34
- },
35
- {
36
- check: (width) => width > 767 && width <= 991,
37
- name: SkyMediaBreakpoints.sm,
38
- },
39
- {
40
- check: (width) => width > 991 && width <= 1199,
41
- name: SkyMediaBreakpoints.md,
42
- },
43
- {
44
- check: (width) => width > 1199,
45
- name: SkyMediaBreakpoints.lg,
46
- },
47
- ];
48
- #currentBreakpoint = DEFAULT_BREAKPOINT;
49
- #currentBreakpointObs = new ReplaySubject(1);
50
- #ngUnsubscribe = new Subject();
51
- #resizeObserverSvc = inject(SkyResizeObserverService);
52
- #target;
53
- ngOnDestroy() {
54
- this.unobserve();
55
- this.#target = undefined;
56
- this.#currentBreakpointObs.complete();
57
- this.#breakpointChange.complete();
58
- }
59
- /**
60
- * @internal
61
- */
62
- destroy() {
63
- this.ngOnDestroy();
64
- }
65
- /**
66
- * Sets the container element to watch. The `SkyResizeObserverMediaQueryService` will only observe one element at a
67
- * time. Any previous subscriptions will be unsubscribed when a new element is observed.
68
- */
69
- observe(element, options) {
70
- if (this.#target) {
71
- if (this.#target === element) {
72
- return this;
73
- }
74
- this.unobserve();
75
- }
76
- this.#target = element;
77
- this.#checkWidth(element, options?.updateResponsiveClasses);
78
- this.#resizeObserverSvc
79
- .observe(element)
80
- .pipe(takeUntil(this.#ngUnsubscribe))
81
- .subscribe((value) => {
82
- const breakpoint = this.#checkBreakpoint(value.contentRect.width);
83
- if (breakpoint) {
84
- this.#updateBreakpoint(breakpoint, options?.updateResponsiveClasses);
85
- }
86
- });
87
- return this;
88
- }
89
- /**
90
- * Stop watching the container element and remove any added classes.
91
- */
92
- unobserve() {
93
- this.#removeResponsiveClasses();
94
- this.#ngUnsubscribe.next();
95
- this.#ngUnsubscribe.complete();
96
- }
97
- /**
98
- * Subscribes to element size changes that cross breakpoints.
99
- */
100
- subscribe(listener) {
101
- return this.#currentBreakpointObs
102
- .pipe(takeUntil(this.#ngUnsubscribe))
103
- .subscribe((value) => {
104
- listener(value);
105
- });
106
- }
107
- #updateBreakpoint(breakpoint, updateResponsiveClasses) {
108
- if (updateResponsiveClasses) {
109
- this.#updateResponsiveClasses(this.current, breakpoint);
110
- }
111
- if (this.current !== breakpoint) {
112
- this.#currentBreakpointObs.next(breakpoint);
113
- const breakpointType = toSkyBreakpoint(breakpoint);
114
- this.#breakpointChange.next(breakpointType);
115
- }
116
- this.#currentBreakpoint = breakpoint;
117
- }
118
- #updateResponsiveClasses(oldBreakpoint, newBreakpoint) {
119
- const oldClass = this.#getClassForBreakpoint(oldBreakpoint);
120
- const newClass = this.#getClassForBreakpoint(newBreakpoint);
121
- const targetClassList = this.#target?.nativeElement?.classList;
122
- targetClassList?.remove(oldClass);
123
- targetClassList?.add(newClass);
124
- }
125
- #removeResponsiveClasses() {
126
- for (const breakpoint of Object.values(SkyMediaBreakpoints)) {
127
- if (typeof breakpoint === 'number') {
128
- const className = this.#getClassForBreakpoint(breakpoint);
129
- this.#target?.nativeElement?.classList?.remove(className);
130
- }
131
- }
132
- }
133
- #getClassForBreakpoint(breakpoint) {
134
- return `sky-responsive-container-${SkyMediaBreakpoints[breakpoint]}`;
135
- }
136
- #checkBreakpoint(width) {
137
- const breakpoint = this.#breakpoints.find((breakpoint) => breakpoint.check(width));
138
- return breakpoint ? breakpoint.name : undefined;
139
- }
140
- #checkWidth(el, updateResponsiveClasses) {
141
- const width = el.nativeElement.offsetWidth || 0;
142
- const breakpoint = this.#checkBreakpoint(width);
143
- if (breakpoint) {
144
- this.#updateBreakpoint(breakpoint, updateResponsiveClasses);
145
- }
146
- }
147
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SkyResizeObserverMediaQueryService, deps: null, target: i0.ɵɵFactoryTarget.Injectable }); }
148
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SkyResizeObserverMediaQueryService }); }
149
- }
150
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SkyResizeObserverMediaQueryService, decorators: [{
151
- type: Injectable
152
- }] });
153
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resize-observer-media-query.service.js","sourceRoot":"","sources":["../../../../../../../../libs/components/core/src/lib/modules/resize-observer/resize-observer-media-query.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { ElementRef, Injectable, OnDestroy, inject } from '@angular/core';\n\nimport { Observable, ReplaySubject, Subject, Subscription } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyBreakpoint } from '../breakpoint-observer/breakpoint';\nimport { toSkyBreakpoint } from '../breakpoint-observer/breakpoint-utils';\nimport { SkyMediaBreakpoints } from '../media-query/media-breakpoints';\nimport { SkyMediaQueryListener } from '../media-query/media-query-listener';\nimport { SkyMediaQueryService } from '../media-query/media-query.service';\n\nimport { SkyResizeObserverService } from './resize-observer.service';\n\nconst DEFAULT_BREAKPOINT = SkyMediaBreakpoints.md;\n\n/**\n * Acts like `SkyMediaQueryService` for a container element, emitting the same responsive breakpoints.\n * @deprecated Use the `SkyResponsiveHostDirective` instead.\n */\n@Injectable()\nexport class SkyResizeObserverMediaQueryService\n  extends SkyMediaQueryService\n  implements OnDestroy\n{\n  /**\n   * Emits when the breakpoint changes.\n   */\n  public override get breakpointChange(): Observable<SkyBreakpoint> {\n    return this.#breakpointChangeObs;\n  }\n\n  /**\n   * Returns the current breakpoint.\n   * @deprecated Subscribe to the `breakpointChange` observable instead.\n   */\n  public override get current(): SkyMediaBreakpoints {\n    return this.#currentBreakpoint;\n  }\n\n  #breakpointChange = new ReplaySubject<SkyBreakpoint>(1);\n  #breakpointChangeObs = this.#breakpointChange.asObservable();\n\n  #breakpoints: {\n    check: (width: number) => boolean;\n    name: SkyMediaBreakpoints;\n  }[] = [\n    {\n      check: (width: number): boolean => width > 0 && width <= 767,\n      name: SkyMediaBreakpoints.xs,\n    },\n    {\n      check: (width: number): boolean => width > 767 && width <= 991,\n      name: SkyMediaBreakpoints.sm,\n    },\n    {\n      check: (width: number): boolean => width > 991 && width <= 1199,\n      name: SkyMediaBreakpoints.md,\n    },\n    {\n      check: (width: number): boolean => width > 1199,\n      name: SkyMediaBreakpoints.lg,\n    },\n  ];\n\n  #currentBreakpoint: SkyMediaBreakpoints = DEFAULT_BREAKPOINT;\n\n  #currentBreakpointObs = new ReplaySubject<SkyMediaBreakpoints>(1);\n\n  #ngUnsubscribe = new Subject<void>();\n\n  #resizeObserverSvc = inject(SkyResizeObserverService);\n\n  #target: ElementRef | undefined;\n\n  public override ngOnDestroy(): void {\n    this.unobserve();\n\n    this.#target = undefined;\n    this.#currentBreakpointObs.complete();\n    this.#breakpointChange.complete();\n  }\n\n  /**\n   * @internal\n   */\n  public override destroy(): void {\n    this.ngOnDestroy();\n  }\n\n  /**\n   * Sets the container element to watch. The `SkyResizeObserverMediaQueryService` will only observe one element at a\n   * time. Any previous subscriptions will be unsubscribed when a new element is observed.\n   */\n  public observe(\n    element: ElementRef,\n    options?: {\n      updateResponsiveClasses?: boolean;\n    },\n  ): SkyResizeObserverMediaQueryService {\n    if (this.#target) {\n      if (this.#target === element) {\n        return this;\n      }\n\n      this.unobserve();\n    }\n\n    this.#target = element;\n\n    this.#checkWidth(element, options?.updateResponsiveClasses);\n\n    this.#resizeObserverSvc\n      .observe(element)\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((value) => {\n        const breakpoint = this.#checkBreakpoint(value.contentRect.width);\n        if (breakpoint) {\n          this.#updateBreakpoint(breakpoint, options?.updateResponsiveClasses);\n        }\n      });\n    return this;\n  }\n\n  /**\n   * Stop watching the container element and remove any added classes.\n   */\n  public unobserve(): void {\n    this.#removeResponsiveClasses();\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n  }\n\n  /**\n   * Subscribes to element size changes that cross breakpoints.\n   */\n  public override subscribe(listener: SkyMediaQueryListener): Subscription {\n    return this.#currentBreakpointObs\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((value) => {\n        listener(value);\n      });\n  }\n\n  #updateBreakpoint(\n    breakpoint: SkyMediaBreakpoints,\n    updateResponsiveClasses?: boolean,\n  ): void {\n    if (updateResponsiveClasses) {\n      this.#updateResponsiveClasses(this.current, breakpoint);\n    }\n\n    if (this.current !== breakpoint) {\n      this.#currentBreakpointObs.next(breakpoint);\n      const breakpointType = toSkyBreakpoint(breakpoint);\n      this.#breakpointChange.next(breakpointType);\n    }\n    this.#currentBreakpoint = breakpoint;\n  }\n\n  #updateResponsiveClasses(\n    oldBreakpoint: SkyMediaBreakpoints,\n    newBreakpoint: SkyMediaBreakpoints,\n  ): void {\n    const oldClass = this.#getClassForBreakpoint(oldBreakpoint);\n    const newClass = this.#getClassForBreakpoint(newBreakpoint);\n\n    const targetClassList = this.#target?.nativeElement?.classList;\n\n    targetClassList?.remove(oldClass);\n    targetClassList?.add(newClass);\n  }\n\n  #removeResponsiveClasses(): void {\n    for (const breakpoint of Object.values(SkyMediaBreakpoints)) {\n      if (typeof breakpoint === 'number') {\n        const className = this.#getClassForBreakpoint(breakpoint);\n\n        this.#target?.nativeElement?.classList?.remove(className);\n      }\n    }\n  }\n\n  #getClassForBreakpoint(breakpoint: SkyMediaBreakpoints): string {\n    return `sky-responsive-container-${SkyMediaBreakpoints[breakpoint]}`;\n  }\n\n  #checkBreakpoint(width: number): SkyMediaBreakpoints | undefined {\n    const breakpoint = this.#breakpoints.find((breakpoint) =>\n      breakpoint.check(width),\n    );\n\n    return breakpoint ? breakpoint.name : undefined;\n  }\n\n  #checkWidth(el: ElementRef, updateResponsiveClasses?: boolean): void {\n    const width = (el.nativeElement as HTMLElement).offsetWidth || 0;\n    const breakpoint = this.#checkBreakpoint(width);\n\n    if (breakpoint) {\n      this.#updateBreakpoint(breakpoint, updateResponsiveClasses);\n    }\n  }\n}\n"]}
@@ -1,115 +0,0 @@
1
- import { ApplicationRef, Injectable, NgZone, inject, } from '@angular/core';
2
- import { Observable, Subject, animationFrames, distinctUntilChanged, filter, map, shareReplay, take, takeUntil, throttle, } from 'rxjs';
3
- import { SkyAppWindowRef } from '../window/window-ref';
4
- import * as i0 from "@angular/core";
5
- const errorTest = /ResizeObserver loop completed with undelivered notifications/i;
6
- let errorLogRegistered = false;
7
- let originalOnError = undefined;
8
- const errorHandler = (event) => {
9
- if (errorTest.test(event.message)) {
10
- event.stopImmediatePropagation();
11
- event.stopPropagation();
12
- event.preventDefault();
13
- return false;
14
- }
15
- return undefined;
16
- };
17
- const onError = (event) => {
18
- const message = typeof event === 'string' ? event : event.message;
19
- // This is necessary to prevent the test runner from failing on errors, but challenging to reliably test.
20
- /* istanbul ignore next */
21
- if (errorTest.test(message)) {
22
- if (event instanceof ErrorEvent) {
23
- event.stopImmediatePropagation();
24
- event.stopPropagation();
25
- event.preventDefault();
26
- }
27
- return false;
28
- }
29
- return originalOnError?.call(window, event);
30
- };
31
- /**
32
- * Service to create rxjs observables for changes to the content box dimensions of elements.
33
- */
34
- export class SkyResizeObserverService {
35
- #ngUnsubscribe = new Subject();
36
- #resizeObserver = new ResizeObserver((entries) => this.#resizeSubject.next(entries));
37
- #resizeSubject = new Subject();
38
- #tracking = new Map();
39
- #window = inject(SkyAppWindowRef);
40
- #zone = inject(NgZone);
41
- constructor() {
42
- this.#expectWindowError();
43
- // Because the resize observer is a native browser API, it does not shut down
44
- // synchronously when the service is destroyed. Leave the error handling
45
- // accommodation in place until the application is destroyed. This also works
46
- // for the test runner.
47
- inject(ApplicationRef).onDestroy(() => this.#resetWindowError());
48
- }
49
- ngOnDestroy() {
50
- this.#ngUnsubscribe.next();
51
- this.#ngUnsubscribe.complete();
52
- this.#resizeObserver.disconnect();
53
- }
54
- /**
55
- * Create rxjs observable to get size changes for an element ref.
56
- */
57
- observe(element) {
58
- const checkTracking = this.#tracking.has(element.nativeElement);
59
- if (!checkTracking) {
60
- this.#tracking.set(element.nativeElement, new Observable((observer) => {
61
- const subscription = this.#resizeSubject.subscribe(observer);
62
- this.#resizeObserver?.observe(element.nativeElement);
63
- return () => {
64
- this.#resizeObserver?.unobserve(element.nativeElement);
65
- subscription.unsubscribe();
66
- this.#tracking.delete(element.nativeElement);
67
- };
68
- }).pipe(filter(Boolean), filter((entries) => entries.some((entry) => entry.target === element.nativeElement)), map((entries) => entries.find((entry) => entry.target === element.nativeElement)),
69
- // Ignore subpixel changes.
70
- distinctUntilChanged((a, b) => Math.round(a.contentRect.width) ===
71
- Math.round(b.contentRect.width) &&
72
- Math.round(a.contentRect.height) ===
73
- Math.round(b.contentRect.height)),
74
- // Emit the last value for late subscribers. Track references so it
75
- // un-observes when all subscribers are gone.
76
- shareReplay({ bufferSize: 1, refCount: true }),
77
- // Only emit prior to an animation frame to prevent layout thrashing.
78
- throttle(() => animationFrames().pipe(take(1)), {
79
- leading: false,
80
- trailing: true,
81
- }), takeUntil(this.#ngUnsubscribe)));
82
- }
83
- return this.#tracking.get(element.nativeElement);
84
- }
85
- #expectWindowError() {
86
- if (!errorLogRegistered) {
87
- errorLogRegistered = true;
88
- // ResizeObserver throws an error when it is disconnected while it is
89
- // still observing an element. When an element is no longer observed, this
90
- // is not a concern.
91
- this.#zone.runOutsideAngular(() => this.#window.nativeWindow.addEventListener('error', errorHandler));
92
- }
93
- if (this.#window.nativeWindow.onerror !== onError) {
94
- originalOnError = this.#window.nativeWindow.onerror;
95
- this.#window.nativeWindow.onerror = onError;
96
- }
97
- }
98
- #resetWindowError() {
99
- this.#window.nativeWindow.removeEventListener('error', errorHandler);
100
- if (originalOnError) {
101
- this.#window.nativeWindow.onerror = originalOnError;
102
- originalOnError = undefined;
103
- }
104
- errorLogRegistered = false;
105
- }
106
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SkyResizeObserverService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
107
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SkyResizeObserverService, providedIn: 'root' }); }
108
- }
109
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SkyResizeObserverService, decorators: [{
110
- type: Injectable,
111
- args: [{
112
- providedIn: 'root',
113
- }]
114
- }], ctorParameters: () => [] });
115
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resize-observer.service.js","sourceRoot":"","sources":["../../../../../../../../libs/components/core/src/lib/modules/resize-observer/resize-observer.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ApplicationRef,\n  ElementRef,\n  Injectable,\n  NgZone,\n  OnDestroy,\n  inject,\n} from '@angular/core';\n\nimport {\n  Observable,\n  Subject,\n  animationFrames,\n  distinctUntilChanged,\n  filter,\n  map,\n  shareReplay,\n  take,\n  takeUntil,\n  throttle,\n} from 'rxjs';\n\nimport { SkyAppWindowRef } from '../window/window-ref';\n\nconst errorTest =\n  /ResizeObserver loop completed with undelivered notifications/i;\nlet errorLogRegistered = false;\nlet originalOnError:\n  | ((event: string | Event) => boolean | undefined)\n  | undefined = undefined;\n\nconst errorHandler = (event: ErrorEvent): boolean | undefined => {\n  if (errorTest.test(event.message)) {\n    event.stopImmediatePropagation();\n    event.stopPropagation();\n    event.preventDefault();\n    return false;\n  }\n  return undefined;\n};\n\nconst onError = (event: string | ErrorEvent): boolean | undefined => {\n  const message = typeof event === 'string' ? event : event.message;\n  // This is necessary to prevent the test runner from failing on errors, but challenging to reliably test.\n  /* istanbul ignore next */\n  if (errorTest.test(message)) {\n    if (event instanceof ErrorEvent) {\n      event.stopImmediatePropagation();\n      event.stopPropagation();\n      event.preventDefault();\n    }\n    return false;\n  }\n  return originalOnError?.call(window, event);\n};\n\n/**\n * Service to create rxjs observables for changes to the content box dimensions of elements.\n */\n@Injectable({\n  providedIn: 'root',\n})\nexport class SkyResizeObserverService implements OnDestroy {\n  readonly #ngUnsubscribe = new Subject<void>();\n  readonly #resizeObserver = new ResizeObserver((entries) =>\n    this.#resizeSubject.next(entries),\n  );\n  readonly #resizeSubject = new Subject<ResizeObserverEntry[]>();\n  readonly #tracking = new Map<Element, Observable<ResizeObserverEntry>>();\n  readonly #window = inject(SkyAppWindowRef);\n  readonly #zone = inject(NgZone);\n\n  constructor() {\n    this.#expectWindowError();\n    // Because the resize observer is a native browser API, it does not shut down\n    // synchronously when the service is destroyed. Leave the error handling\n    // accommodation in place until the application is destroyed. This also works\n    // for the test runner.\n    inject(ApplicationRef).onDestroy(() => this.#resetWindowError());\n  }\n\n  public ngOnDestroy(): void {\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n    this.#resizeObserver.disconnect();\n  }\n\n  /**\n   * Create rxjs observable to get size changes for an element ref.\n   */\n  public observe(element: ElementRef): Observable<ResizeObserverEntry> {\n    const checkTracking = this.#tracking.has(element.nativeElement);\n\n    if (!checkTracking) {\n      this.#tracking.set(\n        element.nativeElement,\n        new Observable<ResizeObserverEntry[]>((observer) => {\n          const subscription = this.#resizeSubject.subscribe(observer);\n          this.#resizeObserver?.observe(element.nativeElement);\n          return () => {\n            this.#resizeObserver?.unobserve(element.nativeElement);\n            subscription.unsubscribe();\n            this.#tracking.delete(element.nativeElement);\n          };\n        }).pipe(\n          filter(Boolean),\n          filter((entries) =>\n            entries.some((entry) => entry.target === element.nativeElement),\n          ),\n          map(\n            (entries) =>\n              entries.find(\n                (entry) => entry.target === element.nativeElement,\n              ) as ResizeObserverEntry,\n          ),\n          // Ignore subpixel changes.\n          distinctUntilChanged(\n            (a, b) =>\n              Math.round(a.contentRect.width) ===\n                Math.round(b.contentRect.width) &&\n              Math.round(a.contentRect.height) ===\n                Math.round(b.contentRect.height),\n          ),\n          // Emit the last value for late subscribers. Track references so it\n          // un-observes when all subscribers are gone.\n          shareReplay({ bufferSize: 1, refCount: true }),\n          // Only emit prior to an animation frame to prevent layout thrashing.\n          throttle(() => animationFrames().pipe(take(1)), {\n            leading: false,\n            trailing: true,\n          }),\n          takeUntil(this.#ngUnsubscribe),\n        ),\n      );\n    }\n\n    return this.#tracking.get(\n      element.nativeElement,\n    ) as Observable<ResizeObserverEntry>;\n  }\n\n  #expectWindowError(): void {\n    if (!errorLogRegistered) {\n      errorLogRegistered = true;\n      // ResizeObserver throws an error when it is disconnected while it is\n      // still observing an element. When an element is no longer observed, this\n      // is not a concern.\n      this.#zone.runOutsideAngular(() =>\n        this.#window.nativeWindow.addEventListener('error', errorHandler),\n      );\n    }\n    if (this.#window.nativeWindow.onerror !== onError) {\n      originalOnError = this.#window.nativeWindow.onerror;\n      this.#window.nativeWindow.onerror = onError;\n    }\n  }\n\n  #resetWindowError(): void {\n    this.#window.nativeWindow.removeEventListener('error', errorHandler);\n    if (originalOnError) {\n      this.#window.nativeWindow.onerror = originalOnError;\n      originalOnError = undefined;\n    }\n    errorLogRegistered = false;\n  }\n}\n"]}
@@ -1,66 +0,0 @@
1
- import { Directive, ElementRef, Input, Renderer2, inject, } from '@angular/core';
2
- import * as i0 from "@angular/core";
3
- const SCREEN_READER_LABELS_CONTAINER_ID = 'sky-screen-reader-labels-container';
4
- /**
5
- * Adds the element to a screen reader only section of the body.
6
- * This prevents components' DOM from including text only intended for screen readers.
7
- *
8
- * @internal
9
- */
10
- export class SkyScreenReaderLabelDirective {
11
- ngOnDestroy() {
12
- this.#removeLabelEl();
13
- }
14
- /**
15
- * Indicates if the label should be created in the DOM.
16
- * @default false
17
- */
18
- set createLabel(value) {
19
- this.#_createLabel = value ?? false;
20
- this.#updateLabelEl();
21
- }
22
- get createLabel() {
23
- return this.#_createLabel;
24
- }
25
- #elementRef = inject(ElementRef);
26
- #renderer = inject(Renderer2);
27
- #_createLabel = false;
28
- #updateLabelEl() {
29
- if (this.createLabel) {
30
- const containerEl = this.#getContainerEl() || this.#createContainerEl();
31
- this.#renderer.appendChild(containerEl, this.#elementRef.nativeElement);
32
- }
33
- else {
34
- this.#removeLabelEl();
35
- }
36
- }
37
- #getContainerEl() {
38
- return document.getElementById(SCREEN_READER_LABELS_CONTAINER_ID);
39
- }
40
- #createContainerEl() {
41
- const el = document.createElement('div');
42
- el.id = SCREEN_READER_LABELS_CONTAINER_ID;
43
- el.style.display = 'none';
44
- this.#renderer.appendChild(document.body, el);
45
- return el;
46
- }
47
- #removeLabelEl() {
48
- const containerEl = this.#getContainerEl();
49
- this.#elementRef.nativeElement.remove();
50
- if (containerEl && containerEl.childNodes.length === 0) {
51
- containerEl.remove();
52
- }
53
- }
54
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SkyScreenReaderLabelDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
55
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: SkyScreenReaderLabelDirective, isStandalone: true, selector: "[skyScreenReaderLabel]", inputs: { createLabel: "createLabel" }, ngImport: i0 }); }
56
- }
57
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SkyScreenReaderLabelDirective, decorators: [{
58
- type: Directive,
59
- args: [{
60
- selector: '[skyScreenReaderLabel]',
61
- standalone: true,
62
- }]
63
- }], propDecorators: { createLabel: [{
64
- type: Input
65
- }] } });
66
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2NyZWVuLXJlYWRlci1sYWJlbC5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvY29yZS9zcmMvbGliL21vZHVsZXMvc2NyZWVuLXJlYWRlci1sYWJlbC9zY3JlZW4tcmVhZGVyLWxhYmVsLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsU0FBUyxFQUNULFVBQVUsRUFDVixLQUFLLEVBRUwsU0FBUyxFQUNULE1BQU0sR0FDUCxNQUFNLGVBQWUsQ0FBQzs7QUFFdkIsTUFBTSxpQ0FBaUMsR0FBRyxvQ0FBb0MsQ0FBQztBQUUvRTs7Ozs7R0FLRztBQUtILE1BQU0sT0FBTyw2QkFBNkI7SUFDakMsV0FBVztRQUNoQixJQUFJLENBQUMsY0FBYyxFQUFFLENBQUM7SUFDeEIsQ0FBQztJQUVEOzs7T0FHRztJQUNILElBQ1csV0FBVyxDQUFDLEtBQTBCO1FBQy9DLElBQUksQ0FBQyxhQUFhLEdBQUcsS0FBSyxJQUFJLEtBQUssQ0FBQztRQUNwQyxJQUFJLENBQUMsY0FBYyxFQUFFLENBQUM7SUFDeEIsQ0FBQztJQUVELElBQVcsV0FBVztRQUNwQixPQUFPLElBQUksQ0FBQyxhQUFhLENBQUM7SUFDNUIsQ0FBQztJQUVRLFdBQVcsR0FBRyxNQUFNLENBQUMsVUFBVSxDQUFDLENBQUM7SUFDakMsU0FBUyxHQUFHLE1BQU0sQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUN2QyxhQUFhLEdBQUcsS0FBSyxDQUFDO0lBRXRCLGNBQWM7UUFDWixJQUFJLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQztZQUNyQixNQUFNLFdBQVcsR0FBRyxJQUFJLENBQUMsZUFBZSxFQUFFLElBQUksSUFBSSxDQUFDLGtCQUFrQixFQUFFLENBQUM7WUFFeEUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxXQUFXLENBQUMsV0FBVyxFQUFFLElBQUksQ0FBQyxXQUFXLENBQUMsYUFBYSxDQUFDLENBQUM7UUFDMUUsQ0FBQzthQUFNLENBQUM7WUFDTixJQUFJLENBQUMsY0FBYyxFQUFFLENBQUM7UUFDeEIsQ0FBQztJQUNILENBQUM7SUFFRCxlQUFlO1FBQ2IsT0FBTyxRQUFRLENBQUMsY0FBYyxDQUFDLGlDQUFpQyxDQUFDLENBQUM7SUFDcEUsQ0FBQztJQUVELGtCQUFrQjtRQUNoQixNQUFNLEVBQUUsR0FBRyxRQUFRLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ3pDLEVBQUUsQ0FBQyxFQUFFLEdBQUcsaUNBQWlDLENBQUM7UUFDMUMsRUFBRSxDQUFDLEtBQUssQ0FBQyxPQUFPLEdBQUcsTUFBTSxDQUFDO1FBRTFCLElBQUksQ0FBQyxTQUFTLENBQUMsV0FBVyxDQUFDLFFBQVEsQ0FBQyxJQUFJLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFFOUMsT0FBTyxFQUFFLENBQUM7SUFDWixDQUFDO0lBRUQsY0FBYztRQUNaLE1BQU0sV0FBVyxHQUFHLElBQUksQ0FBQyxlQUFlLEVBQUUsQ0FBQztRQUUzQyxJQUFJLENBQUMsV0FBVyxDQUFDLGFBQWEsQ0FBQyxNQUFNLEVBQUUsQ0FBQztRQUV4QyxJQUFJLFdBQVcsSUFBSSxXQUFXLENBQUMsVUFBVSxDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQUUsQ0FBQztZQUN2RCxXQUFXLENBQUMsTUFBTSxFQUFFLENBQUM7UUFDdkIsQ0FBQztJQUNILENBQUM7K0dBdkRVLDZCQUE2QjttR0FBN0IsNkJBQTZCOzs0RkFBN0IsNkJBQTZCO2tCQUp6QyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSx3QkFBd0I7b0JBQ2xDLFVBQVUsRUFBRSxJQUFJO2lCQUNqQjs4QkFXWSxXQUFXO3NCQURyQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgRGlyZWN0aXZlLFxuICBFbGVtZW50UmVmLFxuICBJbnB1dCxcbiAgT25EZXN0cm95LFxuICBSZW5kZXJlcjIsXG4gIGluamVjdCxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmNvbnN0IFNDUkVFTl9SRUFERVJfTEFCRUxTX0NPTlRBSU5FUl9JRCA9ICdza3ktc2NyZWVuLXJlYWRlci1sYWJlbHMtY29udGFpbmVyJztcblxuLyoqXG4gKiBBZGRzIHRoZSBlbGVtZW50IHRvIGEgc2NyZWVuIHJlYWRlciBvbmx5IHNlY3Rpb24gb2YgdGhlIGJvZHkuXG4gKiBUaGlzIHByZXZlbnRzIGNvbXBvbmVudHMnIERPTSBmcm9tIGluY2x1ZGluZyB0ZXh0IG9ubHkgaW50ZW5kZWQgZm9yIHNjcmVlbiByZWFkZXJzLlxuICpcbiAqIEBpbnRlcm5hbFxuICovXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdbc2t5U2NyZWVuUmVhZGVyTGFiZWxdJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbn0pXG5leHBvcnQgY2xhc3MgU2t5U2NyZWVuUmVhZGVyTGFiZWxEaXJlY3RpdmUgaW1wbGVtZW50cyBPbkRlc3Ryb3kge1xuICBwdWJsaWMgbmdPbkRlc3Ryb3koKTogdm9pZCB7XG4gICAgdGhpcy4jcmVtb3ZlTGFiZWxFbCgpO1xuICB9XG5cbiAgLyoqXG4gICAqIEluZGljYXRlcyBpZiB0aGUgbGFiZWwgc2hvdWxkIGJlIGNyZWF0ZWQgaW4gdGhlIERPTS5cbiAgICogQGRlZmF1bHQgZmFsc2VcbiAgICovXG4gIEBJbnB1dCgpXG4gIHB1YmxpYyBzZXQgY3JlYXRlTGFiZWwodmFsdWU6IGJvb2xlYW4gfCB1bmRlZmluZWQpIHtcbiAgICB0aGlzLiNfY3JlYXRlTGFiZWwgPSB2YWx1ZSA/PyBmYWxzZTtcbiAgICB0aGlzLiN1cGRhdGVMYWJlbEVsKCk7XG4gIH1cblxuICBwdWJsaWMgZ2V0IGNyZWF0ZUxhYmVsKCk6IGJvb2xlYW4ge1xuICAgIHJldHVybiB0aGlzLiNfY3JlYXRlTGFiZWw7XG4gIH1cblxuICByZWFkb25seSAjZWxlbWVudFJlZiA9IGluamVjdChFbGVtZW50UmVmKTtcbiAgcmVhZG9ubHkgI3JlbmRlcmVyID0gaW5qZWN0KFJlbmRlcmVyMik7XG4gICNfY3JlYXRlTGFiZWwgPSBmYWxzZTtcblxuICAjdXBkYXRlTGFiZWxFbCgpOiB2b2lkIHtcbiAgICBpZiAodGhpcy5jcmVhdGVMYWJlbCkge1xuICAgICAgY29uc3QgY29udGFpbmVyRWwgPSB0aGlzLiNnZXRDb250YWluZXJFbCgpIHx8IHRoaXMuI2NyZWF0ZUNvbnRhaW5lckVsKCk7XG5cbiAgICAgIHRoaXMuI3JlbmRlcmVyLmFwcGVuZENoaWxkKGNvbnRhaW5lckVsLCB0aGlzLiNlbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQpO1xuICAgIH0gZWxzZSB7XG4gICAgICB0aGlzLiNyZW1vdmVMYWJlbEVsKCk7XG4gICAgfVxuICB9XG5cbiAgI2dldENvbnRhaW5lckVsKCk6IEhUTUxFbGVtZW50IHwgbnVsbCB7XG4gICAgcmV0dXJuIGRvY3VtZW50LmdldEVsZW1lbnRCeUlkKFNDUkVFTl9SRUFERVJfTEFCRUxTX0NPTlRBSU5FUl9JRCk7XG4gIH1cblxuICAjY3JlYXRlQ29udGFpbmVyRWwoKTogSFRNTEVsZW1lbnQge1xuICAgIGNvbnN0IGVsID0gZG9jdW1lbnQuY3JlYXRlRWxlbWVudCgnZGl2Jyk7XG4gICAgZWwuaWQgPSBTQ1JFRU5fUkVBREVSX0xBQkVMU19DT05UQUlORVJfSUQ7XG4gICAgZWwuc3R5bGUuZGlzcGxheSA9ICdub25lJztcblxuICAgIHRoaXMuI3JlbmRlcmVyLmFwcGVuZENoaWxkKGRvY3VtZW50LmJvZHksIGVsKTtcblxuICAgIHJldHVybiBlbDtcbiAgfVxuXG4gICNyZW1vdmVMYWJlbEVsKCk6IHZvaWQge1xuICAgIGNvbnN0IGNvbnRhaW5lckVsID0gdGhpcy4jZ2V0Q29udGFpbmVyRWwoKTtcblxuICAgIHRoaXMuI2VsZW1lbnRSZWYubmF0aXZlRWxlbWVudC5yZW1vdmUoKTtcblxuICAgIGlmIChjb250YWluZXJFbCAmJiBjb250YWluZXJFbC5jaGlsZE5vZGVzLmxlbmd0aCA9PT0gMCkge1xuICAgICAgY29udGFpbmVyRWwucmVtb3ZlKCk7XG4gICAgfVxuICB9XG59XG4iXX0=
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2Nyb2xsLXNoYWRvdy1ldmVudC1hcmdzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL2NvcmUvc3JjL2xpYi9tb2R1bGVzL3Njcm9sbC1zaGFkb3cvc2Nyb2xsLXNoYWRvdy1ldmVudC1hcmdzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBpbnRlcm5hbFxuICovXG5leHBvcnQgaW50ZXJmYWNlIFNreVNjcm9sbFNoYWRvd0V2ZW50QXJncyB7XG4gIGJvdHRvbVNoYWRvdzogc3RyaW5nO1xuXG4gIHRvcFNoYWRvdzogc3RyaW5nO1xufVxuIl19
@@ -1,123 +0,0 @@
1
- import { Directive, ElementRef, EventEmitter, HostListener, Input, NgZone, Output, inject, } from '@angular/core';
2
- import { Subject } from 'rxjs';
3
- import { SkyMutationObserverService } from '../mutation/mutation-observer-service';
4
- import * as i0 from "@angular/core";
5
- /**
6
- * Raises an event when the box shadow for a component's header or footer should be adjusted
7
- * based on the scroll position of the host element.
8
- * @internal
9
- */
10
- export class SkyScrollShadowDirective {
11
- constructor() {
12
- this.skyScrollShadow = new EventEmitter();
13
- this.#ngUnsubscribe = new Subject();
14
- this.#elRef = inject(ElementRef);
15
- this.#mutationObserverSvc = inject(SkyMutationObserverService);
16
- this.#ngZone = inject(NgZone);
17
- this.#_enabled = false;
18
- }
19
- set skyScrollShadowEnabled(value) {
20
- this.#_enabled = value;
21
- if (value) {
22
- this.#initMutationObserver();
23
- }
24
- else {
25
- this.#emitShadow({
26
- bottomShadow: 'none',
27
- topShadow: 'none',
28
- });
29
- this.#destroyMutationObserver();
30
- }
31
- }
32
- get skyScrollShadowEnabled() {
33
- return this.#_enabled;
34
- }
35
- #currentShadow;
36
- #mutationObserver;
37
- #ngUnsubscribe;
38
- #elRef;
39
- #mutationObserverSvc;
40
- #ngZone;
41
- #_enabled;
42
- windowResize() {
43
- this.#checkForShadow();
44
- }
45
- scroll() {
46
- this.#checkForShadow();
47
- }
48
- ngOnDestroy() {
49
- this.#ngUnsubscribe.next();
50
- this.#ngUnsubscribe.complete();
51
- this.#destroyMutationObserver();
52
- }
53
- #initMutationObserver() {
54
- if (!this.#mutationObserver) {
55
- const el = this.#elRef.nativeElement;
56
- // MutationObserver is patched by Zone.js and therefore becomes part of the
57
- // Angular change detection cycle, but this can lead to infinite loops in some
58
- // scenarios. This will keep MutationObserver from triggering change detection.
59
- this.#ngZone.runOutsideAngular(() => {
60
- this.#mutationObserver = this.#mutationObserverSvc.create(() => {
61
- this.#checkForShadow();
62
- });
63
- this.#mutationObserver.observe(el, {
64
- attributes: true,
65
- characterData: true,
66
- childList: true,
67
- subtree: true,
68
- });
69
- });
70
- }
71
- }
72
- #destroyMutationObserver() {
73
- if (this.#mutationObserver) {
74
- this.#mutationObserver.disconnect();
75
- this.#mutationObserver = undefined;
76
- }
77
- }
78
- #checkForShadow() {
79
- if (this.skyScrollShadowEnabled) {
80
- const el = this.#elRef.nativeElement;
81
- const topShadow = this.#buildShadowStyle(el.scrollTop);
82
- const bottomShadow = this.#buildShadowStyle(el.scrollHeight - el.scrollTop - el.clientHeight);
83
- this.#emitShadow({
84
- bottomShadow,
85
- topShadow,
86
- });
87
- }
88
- }
89
- #buildShadowStyle(pixelsFromEnd) {
90
- // Progressively darken the shadow until the user scrolls 30 pixels from the top or bottom
91
- // of the scrollable element, with a max opacity of 0.3.
92
- const opacity = Math.min(pixelsFromEnd / 30, 1) * 0.3;
93
- return opacity > 0 ? `0px 1px 8px 0px rgba(0, 0, 0, ${opacity})` : 'none';
94
- }
95
- #emitShadow(shadow) {
96
- if (!this.#currentShadow ||
97
- this.#currentShadow.bottomShadow !== shadow.bottomShadow ||
98
- this.#currentShadow.topShadow !== shadow.topShadow) {
99
- this.skyScrollShadow.emit(shadow);
100
- this.#currentShadow = shadow;
101
- }
102
- }
103
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SkyScrollShadowDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
104
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: SkyScrollShadowDirective, isStandalone: true, selector: "[skyScrollShadow]", inputs: { skyScrollShadowEnabled: "skyScrollShadowEnabled" }, outputs: { skyScrollShadow: "skyScrollShadow" }, host: { listeners: { "window:resize": "windowResize()", "scroll": "scroll()" } }, ngImport: i0 }); }
105
- }
106
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SkyScrollShadowDirective, decorators: [{
107
- type: Directive,
108
- args: [{
109
- standalone: true,
110
- selector: '[skyScrollShadow]',
111
- }]
112
- }], propDecorators: { skyScrollShadowEnabled: [{
113
- type: Input
114
- }], skyScrollShadow: [{
115
- type: Output
116
- }], windowResize: [{
117
- type: HostListener,
118
- args: ['window:resize']
119
- }], scroll: [{
120
- type: HostListener,
121
- args: ['scroll']
122
- }] } });
123
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scroll-shadow.directive.js","sourceRoot":"","sources":["../../../../../../../../libs/components/core/src/lib/modules/scroll-shadow/scroll-shadow.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  Input,\n  NgZone,\n  OnDestroy,\n  Output,\n  inject,\n} from '@angular/core';\n\nimport { Subject } from 'rxjs';\n\nimport { SkyMutationObserverService } from '../mutation/mutation-observer-service';\n\nimport { SkyScrollShadowEventArgs } from './scroll-shadow-event-args';\n\n/**\n * Raises an event when the box shadow for a component's header or footer should be adjusted\n * based on the scroll position of the host element.\n * @internal\n */\n@Directive({\n  standalone: true,\n  selector: '[skyScrollShadow]',\n})\nexport class SkyScrollShadowDirective implements OnDestroy {\n  @Input()\n  public set skyScrollShadowEnabled(value: boolean) {\n    this.#_enabled = value;\n\n    if (value) {\n      this.#initMutationObserver();\n    } else {\n      this.#emitShadow({\n        bottomShadow: 'none',\n        topShadow: 'none',\n      });\n\n      this.#destroyMutationObserver();\n    }\n  }\n\n  public get skyScrollShadowEnabled(): boolean {\n    return this.#_enabled;\n  }\n\n  @Output()\n  public skyScrollShadow = new EventEmitter<SkyScrollShadowEventArgs>();\n\n  #currentShadow: SkyScrollShadowEventArgs | undefined;\n\n  #mutationObserver: MutationObserver | undefined;\n\n  #ngUnsubscribe = new Subject<void>();\n\n  readonly #elRef = inject(ElementRef);\n  readonly #mutationObserverSvc = inject(SkyMutationObserverService);\n  readonly #ngZone = inject(NgZone);\n\n  #_enabled = false;\n\n  @HostListener('window:resize')\n  public windowResize(): void {\n    this.#checkForShadow();\n  }\n\n  @HostListener('scroll')\n  public scroll(): void {\n    this.#checkForShadow();\n  }\n\n  public ngOnDestroy(): void {\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n\n    this.#destroyMutationObserver();\n  }\n\n  #initMutationObserver(): void {\n    if (!this.#mutationObserver) {\n      const el = this.#elRef.nativeElement;\n\n      // MutationObserver is patched by Zone.js and therefore becomes part of the\n      // Angular change detection cycle, but this can lead to infinite loops in some\n      // scenarios. This will keep MutationObserver from triggering change detection.\n      this.#ngZone.runOutsideAngular(() => {\n        this.#mutationObserver = this.#mutationObserverSvc.create(() => {\n          this.#checkForShadow();\n        });\n\n        this.#mutationObserver.observe(el, {\n          attributes: true,\n          characterData: true,\n          childList: true,\n          subtree: true,\n        });\n      });\n    }\n  }\n\n  #destroyMutationObserver(): void {\n    if (this.#mutationObserver) {\n      this.#mutationObserver.disconnect();\n      this.#mutationObserver = undefined;\n    }\n  }\n\n  #checkForShadow(): void {\n    if (this.skyScrollShadowEnabled) {\n      const el: Element = this.#elRef.nativeElement;\n\n      const topShadow = this.#buildShadowStyle(el.scrollTop);\n\n      const bottomShadow = this.#buildShadowStyle(\n        el.scrollHeight - el.scrollTop - el.clientHeight,\n      );\n\n      this.#emitShadow({\n        bottomShadow,\n        topShadow,\n      });\n    }\n  }\n\n  #buildShadowStyle(pixelsFromEnd: number): string {\n    // Progressively darken the shadow until the user scrolls 30 pixels from the top or bottom\n    // of the scrollable element, with a max opacity of 0.3.\n    const opacity = Math.min(pixelsFromEnd / 30, 1) * 0.3;\n\n    return opacity > 0 ? `0px 1px 8px 0px rgba(0, 0, 0, ${opacity})` : 'none';\n  }\n\n  #emitShadow(shadow: SkyScrollShadowEventArgs): void {\n    if (\n      !this.#currentShadow ||\n      this.#currentShadow.bottomShadow !== shadow.bottomShadow ||\n      this.#currentShadow.topShadow !== shadow.topShadow\n    ) {\n      this.skyScrollShadow.emit(shadow);\n      this.#currentShadow = shadow;\n    }\n  }\n}\n"]}