@skyux/core 11.44.0 → 11.45.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.
@@ -1,3 +1,6 @@
1
+ function useViewportForBounds(element) {
2
+ return 'BODY' === element.tagName;
3
+ }
1
4
  /**
2
5
  * Returns the offset values of a given element.
3
6
  * @param element The HTML element.
@@ -94,7 +97,7 @@ export function getOverflowParents(child) {
94
97
  */
95
98
  export function isOffsetFullyVisibleWithinParent(viewportRuler, parent, offset, bufferOffset) {
96
99
  let parentOffset;
97
- if (parent.matches('body')) {
100
+ if (useViewportForBounds(parent)) {
98
101
  const viewportRect = viewportRuler.getViewportRect();
99
102
  parentOffset = {
100
103
  top: 0,
@@ -115,12 +118,25 @@ export function isOffsetFullyVisibleWithinParent(viewportRuler, parent, offset,
115
118
  parentOffset.left <= offset.left);
116
119
  }
117
120
  export function isOffsetPartiallyVisibleWithinParent(viewportRuler, parent, offset, bufferOffset) {
118
- const parentOffset = bufferOffset
119
- ? getElementOffset(parent, bufferOffset)
120
- : getVisibleRectForElement(viewportRuler, parent);
121
+ let parentOffset;
122
+ if (useViewportForBounds(parent)) {
123
+ const viewportRect = viewportRuler.getViewportRect();
124
+ parentOffset = {
125
+ top: 0,
126
+ left: 0,
127
+ right: viewportRect.width,
128
+ bottom: viewportRect.height,
129
+ };
130
+ }
131
+ else if (bufferOffset) {
132
+ parentOffset = getElementOffset(parent, bufferOffset);
133
+ }
134
+ else {
135
+ parentOffset = getVisibleRectForElement(viewportRuler, parent);
136
+ }
121
137
  return !(parentOffset.top >= offset.bottom ||
122
138
  parentOffset.right <= offset.left ||
123
139
  parentOffset.bottom <= offset.top ||
124
140
  parentOffset.left >= offset.right);
125
141
  }
126
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dom-utils.js","sourceRoot":"","sources":["../../../../../../../../libs/components/core/src/lib/modules/affix/dom-utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { ViewportRuler } from '@angular/cdk/overlay';\n\nimport { SkyAffixOffset } from './affix-offset';\nimport { AffixRect } from './affix-rect';\n\n/**\n * Returns the offset values of a given element.\n * @param element The HTML element.\n * @param bufferOffset An optional offset to add/subtract to the element's actual offset.\n */\nexport function getElementOffset(\n  element: HTMLElement,\n  bufferOffset?: SkyAffixOffset,\n): Required<SkyAffixOffset> {\n  const bufferOffsetBottom = bufferOffset?.bottom || 0;\n  const bufferOffsetLeft = bufferOffset?.left || 0;\n  const bufferOffsetRight = bufferOffset?.right || 0;\n  const bufferOffsetTop = bufferOffset?.top || 0;\n\n  let top: number;\n  let left: number;\n  let right: number;\n  let bottom: number;\n\n  const clientRect = element.getBoundingClientRect();\n  left = clientRect.left;\n  top = clientRect.top;\n  right = clientRect.right;\n  bottom = clientRect.bottom;\n\n  bottom -= bufferOffsetBottom;\n  left += bufferOffsetLeft;\n  right -= bufferOffsetRight;\n  top += bufferOffsetTop;\n\n  return {\n    bottom,\n    left,\n    right,\n    top,\n  };\n}\n\n/**\n * Returns an AffixRect that represents the outer dimensions of a given element.\n */\nexport function getOuterRect(element: HTMLElement): Required<AffixRect> {\n  const rect = element.getBoundingClientRect();\n  const computedStyle = window.getComputedStyle(element, undefined);\n  const marginTop = parseFloat(computedStyle.marginTop);\n  const marginLeft = parseFloat(computedStyle.marginLeft);\n  const marginRight = parseFloat(computedStyle.marginRight);\n  const marginBottom = parseFloat(computedStyle.marginBottom);\n\n  return {\n    top: rect.top - marginTop,\n    left: rect.left - marginLeft,\n    bottom: rect.top + rect.height + marginBottom,\n    right: rect.left + rect.width + marginLeft + marginRight,\n    width: rect.width + marginLeft + marginRight,\n    height: rect.height + marginTop + marginBottom,\n  };\n}\n\n/**\n * Returns the visible rect for a given element.\n */\nexport function getVisibleRectForElement(\n  viewportRuler: ViewportRuler,\n  element: HTMLElement,\n): Required<AffixRect> {\n  const elementRect = getOuterRect(element);\n  const viewportRect = viewportRuler.getViewportRect();\n\n  const visibleRect = {\n    top: Math.max(elementRect.top, 0),\n    left: Math.max(elementRect.left, 0),\n    bottom: Math.min(elementRect.bottom, viewportRect.height),\n    right: Math.min(elementRect.right, viewportRect.width),\n  };\n\n  return {\n    ...visibleRect,\n    width: visibleRect.right - visibleRect.left,\n    height: visibleRect.bottom - visibleRect.top,\n  };\n}\n\nexport function getOverflowParents(child: HTMLElement): HTMLElement[] {\n  const bodyElement = window.document.body;\n  const results = [];\n\n  let parentElement = child?.parentNode;\n\n  while (parentElement !== undefined && parentElement instanceof HTMLElement) {\n    if (parentElement.matches('body')) {\n      break;\n    }\n\n    const computedStyle = window.getComputedStyle(parentElement, undefined);\n    const overflowY = computedStyle.overflowY.toLowerCase();\n\n    const largerThanTheDocumentElement =\n      window.document.documentElement.scrollWidth < parentElement.scrollWidth ||\n      window.document.documentElement.scrollHeight < parentElement.scrollHeight;\n    const hasOverflowRules =\n      overflowY === 'auto' || overflowY === 'hidden' || overflowY === 'scroll';\n\n    if (largerThanTheDocumentElement || hasOverflowRules) {\n      results.push(parentElement);\n    }\n    if (computedStyle.position === 'fixed') {\n      break;\n    }\n\n    parentElement = parentElement.parentNode;\n  }\n\n  results.push(bodyElement);\n\n  return results;\n}\n\n/**\n * Confirms offset is fully visible within a parent element.\n */\nexport function isOffsetFullyVisibleWithinParent(\n  viewportRuler: ViewportRuler,\n  parent: HTMLElement,\n  offset: Required<SkyAffixOffset>,\n  bufferOffset?: SkyAffixOffset,\n): boolean {\n  let parentOffset: Required<SkyAffixOffset>;\n\n  if (parent.matches('body')) {\n    const viewportRect = viewportRuler.getViewportRect();\n    parentOffset = {\n      top: 0,\n      left: 0,\n      right: viewportRect.width,\n      bottom: viewportRect.height,\n    };\n  } else if (bufferOffset) {\n    parentOffset = getElementOffset(parent, bufferOffset);\n  } else {\n    parentOffset = getVisibleRectForElement(viewportRuler, parent);\n  }\n\n  return (\n    parentOffset.top <= offset.top &&\n    parentOffset.right >= offset.right &&\n    parentOffset.bottom >= offset.bottom &&\n    parentOffset.left <= offset.left\n  );\n}\n\nexport function isOffsetPartiallyVisibleWithinParent(\n  viewportRuler: ViewportRuler,\n  parent: HTMLElement,\n  offset: Required<SkyAffixOffset>,\n  bufferOffset?: SkyAffixOffset,\n): boolean {\n  const parentOffset = bufferOffset\n    ? getElementOffset(parent, bufferOffset)\n    : getVisibleRectForElement(viewportRuler, parent);\n\n  return !(\n    parentOffset.top >= offset.bottom ||\n    parentOffset.right <= offset.left ||\n    parentOffset.bottom <= offset.top ||\n    parentOffset.left >= offset.right\n  );\n}\n"]}
142
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dom-utils.js","sourceRoot":"","sources":["../../../../../../../../libs/components/core/src/lib/modules/affix/dom-utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { ViewportRuler } from '@angular/cdk/overlay';\n\nimport { SkyAffixOffset } from './affix-offset';\nimport { AffixRect } from './affix-rect';\n\nfunction useViewportForBounds(element: HTMLElement) {\n  return 'BODY' === element.tagName;\n}\n\n/**\n * Returns the offset values of a given element.\n * @param element The HTML element.\n * @param bufferOffset An optional offset to add/subtract to the element's actual offset.\n */\nexport function getElementOffset(\n  element: HTMLElement,\n  bufferOffset?: SkyAffixOffset,\n): Required<SkyAffixOffset> {\n  const bufferOffsetBottom = bufferOffset?.bottom || 0;\n  const bufferOffsetLeft = bufferOffset?.left || 0;\n  const bufferOffsetRight = bufferOffset?.right || 0;\n  const bufferOffsetTop = bufferOffset?.top || 0;\n\n  let top: number;\n  let left: number;\n  let right: number;\n  let bottom: number;\n\n  const clientRect = element.getBoundingClientRect();\n  left = clientRect.left;\n  top = clientRect.top;\n  right = clientRect.right;\n  bottom = clientRect.bottom;\n\n  bottom -= bufferOffsetBottom;\n  left += bufferOffsetLeft;\n  right -= bufferOffsetRight;\n  top += bufferOffsetTop;\n\n  return {\n    bottom,\n    left,\n    right,\n    top,\n  };\n}\n\n/**\n * Returns an AffixRect that represents the outer dimensions of a given element.\n */\nexport function getOuterRect(element: HTMLElement): Required<AffixRect> {\n  const rect = element.getBoundingClientRect();\n  const computedStyle = window.getComputedStyle(element, undefined);\n  const marginTop = parseFloat(computedStyle.marginTop);\n  const marginLeft = parseFloat(computedStyle.marginLeft);\n  const marginRight = parseFloat(computedStyle.marginRight);\n  const marginBottom = parseFloat(computedStyle.marginBottom);\n\n  return {\n    top: rect.top - marginTop,\n    left: rect.left - marginLeft,\n    bottom: rect.top + rect.height + marginBottom,\n    right: rect.left + rect.width + marginLeft + marginRight,\n    width: rect.width + marginLeft + marginRight,\n    height: rect.height + marginTop + marginBottom,\n  };\n}\n\n/**\n * Returns the visible rect for a given element.\n */\nexport function getVisibleRectForElement(\n  viewportRuler: ViewportRuler,\n  element: HTMLElement,\n): Required<AffixRect> {\n  const elementRect = getOuterRect(element);\n  const viewportRect = viewportRuler.getViewportRect();\n\n  const visibleRect = {\n    top: Math.max(elementRect.top, 0),\n    left: Math.max(elementRect.left, 0),\n    bottom: Math.min(elementRect.bottom, viewportRect.height),\n    right: Math.min(elementRect.right, viewportRect.width),\n  };\n\n  return {\n    ...visibleRect,\n    width: visibleRect.right - visibleRect.left,\n    height: visibleRect.bottom - visibleRect.top,\n  };\n}\n\nexport function getOverflowParents(child: HTMLElement): HTMLElement[] {\n  const bodyElement = window.document.body;\n  const results = [];\n\n  let parentElement = child?.parentNode;\n\n  while (parentElement !== undefined && parentElement instanceof HTMLElement) {\n    if (parentElement.matches('body')) {\n      break;\n    }\n\n    const computedStyle = window.getComputedStyle(parentElement, undefined);\n    const overflowY = computedStyle.overflowY.toLowerCase();\n\n    const largerThanTheDocumentElement =\n      window.document.documentElement.scrollWidth < parentElement.scrollWidth ||\n      window.document.documentElement.scrollHeight < parentElement.scrollHeight;\n    const hasOverflowRules =\n      overflowY === 'auto' || overflowY === 'hidden' || overflowY === 'scroll';\n\n    if (largerThanTheDocumentElement || hasOverflowRules) {\n      results.push(parentElement);\n    }\n    if (computedStyle.position === 'fixed') {\n      break;\n    }\n\n    parentElement = parentElement.parentNode;\n  }\n\n  results.push(bodyElement);\n\n  return results;\n}\n\n/**\n * Confirms offset is fully visible within a parent element.\n */\nexport function isOffsetFullyVisibleWithinParent(\n  viewportRuler: ViewportRuler,\n  parent: HTMLElement,\n  offset: Required<SkyAffixOffset>,\n  bufferOffset?: SkyAffixOffset,\n): boolean {\n  let parentOffset: Required<SkyAffixOffset>;\n\n  if (useViewportForBounds(parent)) {\n    const viewportRect = viewportRuler.getViewportRect();\n    parentOffset = {\n      top: 0,\n      left: 0,\n      right: viewportRect.width,\n      bottom: viewportRect.height,\n    };\n  } else if (bufferOffset) {\n    parentOffset = getElementOffset(parent, bufferOffset);\n  } else {\n    parentOffset = getVisibleRectForElement(viewportRuler, parent);\n  }\n\n  return (\n    parentOffset.top <= offset.top &&\n    parentOffset.right >= offset.right &&\n    parentOffset.bottom >= offset.bottom &&\n    parentOffset.left <= offset.left\n  );\n}\n\nexport function isOffsetPartiallyVisibleWithinParent(\n  viewportRuler: ViewportRuler,\n  parent: HTMLElement,\n  offset: Required<SkyAffixOffset>,\n  bufferOffset?: SkyAffixOffset,\n): boolean {\n  let parentOffset: Required<SkyAffixOffset>;\n  if (useViewportForBounds(parent)) {\n    const viewportRect = viewportRuler.getViewportRect();\n    parentOffset = {\n      top: 0,\n      left: 0,\n      right: viewportRect.width,\n      bottom: viewportRect.height,\n    };\n  } else if (bufferOffset) {\n    parentOffset = getElementOffset(parent, bufferOffset);\n  } else {\n    parentOffset = getVisibleRectForElement(viewportRuler, parent);\n  }\n\n  return !(\n    parentOffset.top >= offset.bottom ||\n    parentOffset.right <= offset.left ||\n    parentOffset.bottom <= offset.top ||\n    parentOffset.left >= offset.right\n  );\n}\n"]}
@@ -1,5 +1,5 @@
1
1
  import { ApplicationRef, Injectable, NgZone, inject, } from '@angular/core';
2
- import { Observable, Subject, animationFrames, distinctUntilChanged, filter, map, shareReplay, take, takeUntil, throttle, } from 'rxjs';
2
+ import { Observable, Subject, animationFrameScheduler, distinctUntilChanged, filter, map, observeOn, shareReplay, takeUntil, } from 'rxjs';
3
3
  import { SkyAppWindowRef } from '../window/window-ref';
4
4
  import * as i0 from "@angular/core";
5
5
  const errorTest = /ResizeObserver loop completed with undelivered notifications/i;
@@ -33,11 +33,11 @@ const onError = (event) => {
33
33
  */
34
34
  export class SkyResizeObserverService {
35
35
  #ngUnsubscribe = new Subject();
36
- #resizeObserver = new ResizeObserver((entries) => this.#resizeSubject.next(entries));
36
+ #zone = inject(NgZone);
37
+ #resizeObserver = this.#zone.runOutsideAngular(() => new ResizeObserver((entries) => this.#zone.run(() => this.#resizeSubject.next(entries))));
37
38
  #resizeSubject = new Subject();
38
39
  #tracking = new Map();
39
40
  #window = inject(SkyAppWindowRef);
40
- #zone = inject(NgZone);
41
41
  constructor() {
42
42
  this.#expectWindowError();
43
43
  // Because the resize observer is a native browser API, it does not shut down
@@ -75,10 +75,7 @@ export class SkyResizeObserverService {
75
75
  // un-observes when all subscribers are gone.
76
76
  shareReplay({ bufferSize: 1, refCount: true }),
77
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)));
78
+ observeOn(animationFrameScheduler), takeUntil(this.#ngUnsubscribe)));
82
79
  }
83
80
  return this.#tracking.get(element.nativeElement);
84
81
  }
@@ -112,4 +109,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
112
109
  providedIn: 'root',
113
110
  }]
114
111
  }], 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":"AAAA,OAAO,EACL,cAAc,EAEd,UAAU,EACV,MAAM,EAEN,MAAM,GACP,MAAM,eAAe,CAAC;AAEvB,OAAO,EACL,UAAU,EACV,OAAO,EACP,eAAe,EACf,oBAAoB,EACpB,MAAM,EACN,GAAG,EACH,WAAW,EACX,IAAI,EACJ,SAAS,EACT,QAAQ,GACT,MAAM,MAAM,CAAC;AAEd,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;;AAEvD,MAAM,SAAS,GACb,+DAA+D,CAAC;AAClE,IAAI,kBAAkB,GAAG,KAAK,CAAC;AAC/B,IAAI,eAAe,GAEH,SAAS,CAAC;AAE1B,MAAM,YAAY,GAAG,CAAC,KAAiB,EAAuB,EAAE;IAC9D,IAAI,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE,CAAC;QAClC,KAAK,CAAC,wBAAwB,EAAE,CAAC;QACjC,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,OAAO,KAAK,CAAC;IACf,CAAC;IACD,OAAO,SAAS,CAAC;AACnB,CAAC,CAAC;AAEF,MAAM,OAAO,GAAG,CAAC,KAA0B,EAAuB,EAAE;IAClE,MAAM,OAAO,GAAG,OAAO,KAAK,KAAK,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC;IAClE,yGAAyG;IACzG,0BAA0B;IAC1B,IAAI,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC;QAC5B,IAAI,KAAK,YAAY,UAAU,EAAE,CAAC;YAChC,KAAK,CAAC,wBAAwB,EAAE,CAAC;YACjC,KAAK,CAAC,eAAe,EAAE,CAAC;YACxB,KAAK,CAAC,cAAc,EAAE,CAAC;QACzB,CAAC;QACD,OAAO,KAAK,CAAC;IACf,CAAC;IACD,OAAO,eAAe,EAAE,IAAI,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;AAC9C,CAAC,CAAC;AAEF;;GAEG;AAIH,MAAM,OAAO,wBAAwB;IAC1B,cAAc,GAAG,IAAI,OAAO,EAAQ,CAAC;IACrC,eAAe,GAAG,IAAI,cAAc,CAAC,CAAC,OAAO,EAAE,EAAE,CACxD,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,OAAO,CAAC,CAClC,CAAC;IACO,cAAc,GAAG,IAAI,OAAO,EAAyB,CAAC;IACtD,SAAS,GAAG,IAAI,GAAG,EAA4C,CAAC;IAChE,OAAO,GAAG,MAAM,CAAC,eAAe,CAAC,CAAC;IAClC,KAAK,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC;IAEhC;QACE,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAC1B,6EAA6E;QAC7E,wEAAwE;QACxE,6EAA6E;QAC7E,uBAAuB;QACvB,MAAM,CAAC,cAAc,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,iBAAiB,EAAE,CAAC,CAAC;IACnE,CAAC;IAEM,WAAW;QAChB,IAAI,CAAC,cAAc,CAAC,IAAI,EAAE,CAAC;QAC3B,IAAI,CAAC,cAAc,CAAC,QAAQ,EAAE,CAAC;QAC/B,IAAI,CAAC,eAAe,CAAC,UAAU,EAAE,CAAC;IACpC,CAAC;IAED;;OAEG;IACI,OAAO,CAAC,OAAmB;QAChC,MAAM,aAAa,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;QAEhE,IAAI,CAAC,aAAa,EAAE,CAAC;YACnB,IAAI,CAAC,SAAS,CAAC,GAAG,CAChB,OAAO,CAAC,aAAa,EACrB,IAAI,UAAU,CAAwB,CAAC,QAAQ,EAAE,EAAE;gBACjD,MAAM,YAAY,GAAG,IAAI,CAAC,cAAc,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;gBAC7D,IAAI,CAAC,eAAe,EAAE,OAAO,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;gBACrD,OAAO,GAAG,EAAE;oBACV,IAAI,CAAC,eAAe,EAAE,SAAS,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;oBACvD,YAAY,CAAC,WAAW,EAAE,CAAC;oBAC3B,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;gBAC/C,CAAC,CAAC;YACJ,CAAC,CAAC,CAAC,IAAI,CACL,MAAM,CAAC,OAAO,CAAC,EACf,MAAM,CAAC,CAAC,OAAO,EAAE,EAAE,CACjB,OAAO,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,MAAM,KAAK,OAAO,CAAC,aAAa,CAAC,CAChE,EACD,GAAG,CACD,CAAC,OAAO,EAAE,EAAE,CACV,OAAO,CAAC,IAAI,CACV,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,MAAM,KAAK,OAAO,CAAC,aAAa,CAC3B,CAC3B;YACD,2BAA2B;YAC3B,oBAAoB,CAClB,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CACP,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,WAAW,CAAC,KAAK,CAAC;gBAC7B,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,WAAW,CAAC,KAAK,CAAC;gBACjC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,WAAW,CAAC,MAAM,CAAC;oBAC9B,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,WAAW,CAAC,MAAM,CAAC,CACrC;YACD,mEAAmE;YACnE,6CAA6C;YAC7C,WAAW,CAAC,EAAE,UAAU,EAAE,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;YAC9C,qEAAqE;YACrE,QAAQ,CAAC,GAAG,EAAE,CAAC,eAAe,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE;gBAC9C,OAAO,EAAE,KAAK;gBACd,QAAQ,EAAE,IAAI;aACf,CAAC,EACF,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,CAC/B,CACF,CAAC;QACJ,CAAC;QAED,OAAO,IAAI,CAAC,SAAS,CAAC,GAAG,CACvB,OAAO,CAAC,aAAa,CACa,CAAC;IACvC,CAAC;IAED,kBAAkB;QAChB,IAAI,CAAC,kBAAkB,EAAE,CAAC;YACxB,kBAAkB,GAAG,IAAI,CAAC;YAC1B,qEAAqE;YACrE,0EAA0E;YAC1E,oBAAoB;YACpB,IAAI,CAAC,KAAK,CAAC,iBAAiB,CAAC,GAAG,EAAE,CAChC,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,gBAAgB,CAAC,OAAO,EAAE,YAAY,CAAC,CAClE,CAAC;QACJ,CAAC;QACD,IAAI,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,OAAO,KAAK,OAAO,EAAE,CAAC;YAClD,eAAe,GAAG,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,OAAO,CAAC;YACpD,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,OAAO,GAAG,OAAO,CAAC;QAC9C,CAAC;IACH,CAAC;IAED,iBAAiB;QACf,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,mBAAmB,CAAC,OAAO,EAAE,YAAY,CAAC,CAAC;QACrE,IAAI,eAAe,EAAE,CAAC;YACpB,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,OAAO,GAAG,eAAe,CAAC;YACpD,eAAe,GAAG,SAAS,CAAC;QAC9B,CAAC;QACD,kBAAkB,GAAG,KAAK,CAAC;IAC7B,CAAC;+GAtGU,wBAAwB;mHAAxB,wBAAwB,cAFvB,MAAM;;4FAEP,wBAAwB;kBAHpC,UAAU;mBAAC;oBACV,UAAU,EAAE,MAAM;iBACnB","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"]}
112
+ //# 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  animationFrameScheduler,\n  distinctUntilChanged,\n  filter,\n  map,\n  observeOn,\n  shareReplay,\n  takeUntil,\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 #zone = inject(NgZone);\n  readonly #resizeObserver = this.#zone.runOutsideAngular(\n    () =>\n      new ResizeObserver((entries) =>\n        this.#zone.run(() => this.#resizeSubject.next(entries)),\n      ),\n  );\n  readonly #resizeSubject = new Subject<ResizeObserverEntry[]>();\n  readonly #tracking = new Map<Element, Observable<ResizeObserverEntry>>();\n  readonly #window = inject(SkyAppWindowRef);\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          observeOn(animationFrameScheduler),\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"]}
@@ -15,5 +15,5 @@ export class Version {
15
15
  /**
16
16
  * Represents the version of @skyux/core.
17
17
  */
18
- export const VERSION = new Version('11.44.0');
18
+ export const VERSION = new Version('11.45.1');
19
19
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9jb3JlL3NyYy92ZXJzaW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLHdDQUF3QztBQUN4QyxtRkFBbUY7QUFFbkY7OztHQUdHO0FBQ0gsTUFBTSxPQUFPLE9BQU87SUFLbEIsWUFBNEIsSUFBWTtRQUFaLFNBQUksR0FBSixJQUFJLENBQVE7UUFDdEMsSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQ2hDLElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUNoQyxJQUFJLENBQUMsS0FBSyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUNsRCxDQUFDO0NBQ0Y7QUFFRDs7R0FFRztBQUNILE1BQU0sQ0FBQyxNQUFNLE9BQU8sR0FBRyxJQUFJLE9BQU8sQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLy8gVGFrZW4gZnJvbSBBbmd1bGFyJ3MgdmVyc2lvbi50cyBmaWxlLlxuLy8gU2VlOiBodHRwczovL2dpdGh1Yi5jb20vYW5ndWxhci9hbmd1bGFyL2Jsb2IvMTYuMi54L3BhY2thZ2VzL2NvcmUvc3JjL3ZlcnNpb24udHNcblxuLyoqXG4gKiBSZXByZXNlbnRzIHRoZSB2ZXJzaW9uIG9mIGEgcGFja2FnZS5cbiAqIEBpbnRlcm5hbFxuICovXG5leHBvcnQgY2xhc3MgVmVyc2lvbiB7XG4gIHB1YmxpYyByZWFkb25seSBtYWpvcjogc3RyaW5nO1xuICBwdWJsaWMgcmVhZG9ubHkgbWlub3I6IHN0cmluZztcbiAgcHVibGljIHJlYWRvbmx5IHBhdGNoOiBzdHJpbmc7XG5cbiAgY29uc3RydWN0b3IocHVibGljIHJlYWRvbmx5IGZ1bGw6IHN0cmluZykge1xuICAgIHRoaXMubWFqb3IgPSBmdWxsLnNwbGl0KCcuJylbMF07XG4gICAgdGhpcy5taW5vciA9IGZ1bGwuc3BsaXQoJy4nKVsxXTtcbiAgICB0aGlzLnBhdGNoID0gZnVsbC5zcGxpdCgnLicpLnNsaWNlKDIpLmpvaW4oJy4nKTtcbiAgfVxufVxuXG4vKipcbiAqIFJlcHJlc2VudHMgdGhlIHZlcnNpb24gb2YgQHNreXV4L2NvcmUuXG4gKi9cbmV4cG9ydCBjb25zdCBWRVJTSU9OID0gbmV3IFZlcnNpb24oJzAuMC4wLVBMQUNFSE9MREVSJyk7XG4iXX0=
@@ -2,7 +2,7 @@ import * as i0 from '@angular/core';
2
2
  import { NgModule, Injectable, inject, RendererFactory2, NgZone, EventEmitter, Directive, Input, Output, EnvironmentInjector, createEnvironmentInjector, createComponent, ChangeDetectorRef, ElementRef, ViewContainerRef, Component, ChangeDetectionStrategy, ViewChild, InjectionToken, input, effect, Optional, Inject, ApplicationRef, afterNextRender, Injector, Pipe, HostBinding, Renderer2, HostListener } from '@angular/core';
3
3
  import * as i1$1 from '@angular/common';
4
4
  import { DOCUMENT, CommonModule } from '@angular/common';
5
- import { Subject, Subscription, ReplaySubject, fromEvent, of, Observable, filter, map, distinctUntilChanged, shareReplay, throttle, animationFrames, take, takeUntil as takeUntil$1, BehaviorSubject, concat, animationFrameScheduler } from 'rxjs';
5
+ import { Subject, Subscription, ReplaySubject, fromEvent, of, Observable, filter, map, distinctUntilChanged, shareReplay, observeOn, animationFrameScheduler, takeUntil as takeUntil$1, BehaviorSubject, concat } from 'rxjs';
6
6
  import { takeUntil, debounceTime, switchMap, map as map$1 } from 'rxjs/operators';
7
7
  import { ViewportRuler } from '@angular/cdk/overlay';
8
8
  import { toSignal, takeUntilDestroyed } from '@angular/core/rxjs-interop';
@@ -322,6 +322,9 @@ function getInversePlacement(placement) {
322
322
  return pairings[placement];
323
323
  }
324
324
 
325
+ function useViewportForBounds(element) {
326
+ return 'BODY' === element.tagName;
327
+ }
325
328
  /**
326
329
  * Returns the offset values of a given element.
327
330
  * @param element The HTML element.
@@ -418,7 +421,7 @@ function getOverflowParents(child) {
418
421
  */
419
422
  function isOffsetFullyVisibleWithinParent(viewportRuler, parent, offset, bufferOffset) {
420
423
  let parentOffset;
421
- if (parent.matches('body')) {
424
+ if (useViewportForBounds(parent)) {
422
425
  const viewportRect = viewportRuler.getViewportRect();
423
426
  parentOffset = {
424
427
  top: 0,
@@ -439,9 +442,22 @@ function isOffsetFullyVisibleWithinParent(viewportRuler, parent, offset, bufferO
439
442
  parentOffset.left <= offset.left);
440
443
  }
441
444
  function isOffsetPartiallyVisibleWithinParent(viewportRuler, parent, offset, bufferOffset) {
442
- const parentOffset = bufferOffset
443
- ? getElementOffset(parent, bufferOffset)
444
- : getVisibleRectForElement(viewportRuler, parent);
445
+ let parentOffset;
446
+ if (useViewportForBounds(parent)) {
447
+ const viewportRect = viewportRuler.getViewportRect();
448
+ parentOffset = {
449
+ top: 0,
450
+ left: 0,
451
+ right: viewportRect.width,
452
+ bottom: viewportRect.height,
453
+ };
454
+ }
455
+ else if (bufferOffset) {
456
+ parentOffset = getElementOffset(parent, bufferOffset);
457
+ }
458
+ else {
459
+ parentOffset = getVisibleRectForElement(viewportRuler, parent);
460
+ }
445
461
  return !(parentOffset.top >= offset.bottom ||
446
462
  parentOffset.right <= offset.left ||
447
463
  parentOffset.bottom <= offset.top ||
@@ -2099,11 +2115,11 @@ const onError = (event) => {
2099
2115
  */
2100
2116
  class SkyResizeObserverService {
2101
2117
  #ngUnsubscribe = new Subject();
2102
- #resizeObserver = new ResizeObserver((entries) => this.#resizeSubject.next(entries));
2118
+ #zone = inject(NgZone);
2119
+ #resizeObserver = this.#zone.runOutsideAngular(() => new ResizeObserver((entries) => this.#zone.run(() => this.#resizeSubject.next(entries))));
2103
2120
  #resizeSubject = new Subject();
2104
2121
  #tracking = new Map();
2105
2122
  #window = inject(SkyAppWindowRef);
2106
- #zone = inject(NgZone);
2107
2123
  constructor() {
2108
2124
  this.#expectWindowError();
2109
2125
  // Because the resize observer is a native browser API, it does not shut down
@@ -2141,10 +2157,7 @@ class SkyResizeObserverService {
2141
2157
  // un-observes when all subscribers are gone.
2142
2158
  shareReplay({ bufferSize: 1, refCount: true }),
2143
2159
  // Only emit prior to an animation frame to prevent layout thrashing.
2144
- throttle(() => animationFrames().pipe(take(1)), {
2145
- leading: false,
2146
- trailing: true,
2147
- }), takeUntil$1(this.#ngUnsubscribe)));
2160
+ observeOn(animationFrameScheduler), takeUntil$1(this.#ngUnsubscribe)));
2148
2161
  }
2149
2162
  return this.#tracking.get(element.nativeElement);
2150
2163
  }
@@ -4577,7 +4590,7 @@ class Version {
4577
4590
  /**
4578
4591
  * Represents the version of @skyux/core.
4579
4592
  */
4580
- const VERSION = new Version('11.44.0');
4593
+ const VERSION = new Version('11.45.1');
4581
4594
 
4582
4595
  /**
4583
4596
  * Generated bundle index. Do not edit.