@ethlete/core 3.4.0 → 3.6.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/structured-data/structured-data.component.mjs +3 -3
- package/esm2022/lib/directives/animatable/animatable.directive.mjs +3 -3
- package/esm2022/lib/directives/animated-if/animated-if.directive.mjs +54 -0
- package/esm2022/lib/directives/animated-if/public-api.mjs +2 -0
- package/esm2022/lib/directives/animated-lifecycle/animated-lifecycle.directive.mjs +20 -4
- package/esm2022/lib/directives/animated-overlay/animated-overlay.directive.mjs +3 -3
- package/esm2022/lib/directives/click-outside/click-outside.directive.mjs +3 -3
- package/esm2022/lib/directives/cursor-drag-scroll/cursor-drag-scroll.directive.mjs +3 -3
- package/esm2022/lib/directives/delayable/delayable.directive.mjs +3 -3
- package/esm2022/lib/directives/is-active-element/is-active-element.directive.mjs +3 -3
- package/esm2022/lib/directives/is-element/is-element.directive.mjs +3 -3
- package/esm2022/lib/directives/let/let.directive.mjs +3 -3
- package/esm2022/lib/directives/observe-content/observe-content.directive.mjs +3 -3
- package/esm2022/lib/directives/observe-resize/observe-resize.directive.mjs +3 -3
- package/esm2022/lib/directives/observe-scroll-state/observe-scroll-state.directive.mjs +3 -3
- package/esm2022/lib/directives/observe-visibility/observe-visibility.directive.mjs +53 -0
- package/esm2022/lib/directives/observe-visibility/public-api.mjs +2 -0
- package/esm2022/lib/directives/public-api.mjs +3 -1
- package/esm2022/lib/directives/repeat/repeat.directive.mjs +3 -3
- package/esm2022/lib/directives/scroll-observer-first-element/scroll-observer-first-element.directive.mjs +3 -3
- package/esm2022/lib/directives/scroll-observer-ignore-target/scroll-observer-ignore-target.directive.mjs +3 -3
- package/esm2022/lib/directives/scroll-observer-last-element/scroll-observer-last-element.directive.mjs +3 -3
- package/esm2022/lib/directives/seo/seo.directive.mjs +3 -3
- package/esm2022/lib/pipes/normalize-game-result-type/normalize-game-result-type.pipe.mjs +3 -3
- package/esm2022/lib/pipes/normalize-match-participants/normalize-match-participants.pipe.mjs +3 -3
- package/esm2022/lib/pipes/normalize-match-score/normalize-match-score.pipe.mjs +3 -3
- package/esm2022/lib/pipes/normalize-match-state/normalize-match-state.pipe.mjs +3 -3
- package/esm2022/lib/pipes/normalize-match-type/normalize-match-type.pipe.mjs +3 -3
- package/esm2022/lib/pipes/to-array/to-array.pipe.mjs +3 -3
- package/esm2022/lib/services/click-observer.service.mjs +6 -6
- package/esm2022/lib/services/content-observer.service.mjs +6 -6
- package/esm2022/lib/services/focus-visible.service.mjs +3 -3
- package/esm2022/lib/services/intersection-observer.service.mjs +75 -0
- package/esm2022/lib/services/public-api.mjs +2 -1
- package/esm2022/lib/services/resize-observer.service.mjs +6 -6
- package/esm2022/lib/services/router-state.service.mjs +3 -3
- package/esm2022/lib/services/viewport.service.mjs +17 -17
- package/esm2022/lib/utils/form.utils.mjs +40 -0
- package/esm2022/lib/utils/public-api.mjs +3 -1
- package/esm2022/lib/utils/resize-observable.util.mjs +12 -0
- package/esm2022/lib/utils/scrollable.utils.mjs +8 -2
- package/esm2022/lib/utils/smart-block-scroll-strategy.utils.mjs +35 -17
- package/fesm2022/ethlete-core.mjs +388 -132
- package/fesm2022/ethlete-core.mjs.map +1 -1
- package/lib/directives/animated-if/animated-if.directive.d.ts +12 -0
- package/lib/directives/animated-if/public-api.d.ts +1 -0
- package/lib/directives/animated-lifecycle/animated-lifecycle.directive.d.ts +9 -4
- package/lib/directives/observe-visibility/observe-visibility.directive.d.ts +13 -0
- package/lib/directives/observe-visibility/public-api.d.ts +1 -0
- package/lib/directives/public-api.d.ts +2 -0
- package/lib/services/intersection-observer.service.d.ts +20 -0
- package/lib/services/public-api.d.ts +1 -0
- package/lib/services/viewport.service.d.ts +1 -1
- package/lib/utils/form.utils.d.ts +2 -0
- package/lib/utils/public-api.d.ts +2 -0
- package/lib/utils/resize-observable.util.d.ts +5 -0
- package/lib/utils/scrollable.utils.d.ts +1 -1
- package/lib/utils/smart-block-scroll-strategy.utils.d.ts +2 -0
- package/package.json +6 -6
|
@@ -1,6 +1,12 @@
|
|
|
1
1
|
import { clamp } from './clamp.util';
|
|
2
|
-
export const elementCanScroll = (element) => {
|
|
2
|
+
export const elementCanScroll = (element, direction) => {
|
|
3
3
|
const { scrollHeight, clientHeight, scrollWidth, clientWidth } = element;
|
|
4
|
+
if (direction === 'x') {
|
|
5
|
+
return scrollWidth > clientWidth;
|
|
6
|
+
}
|
|
7
|
+
else if (direction === 'y') {
|
|
8
|
+
return scrollHeight > clientHeight;
|
|
9
|
+
}
|
|
4
10
|
return scrollHeight > clientHeight || scrollWidth > clientWidth;
|
|
5
11
|
};
|
|
6
12
|
export const isElementVisible = (options) => {
|
|
@@ -107,4 +113,4 @@ export const getElementVisibleStates = (options) => {
|
|
|
107
113
|
.filter(Boolean);
|
|
108
114
|
return elementVisibleStates;
|
|
109
115
|
};
|
|
110
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scrollable.utils.js","sourceRoot":"","sources":["../../../../../../libs/core/src/lib/utils/scrollable.utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { clamp } from './clamp.util';\n\nexport const elementCanScroll = (element: HTMLElement) => {\n  const { scrollHeight, clientHeight, scrollWidth, clientWidth } = element;\n\n  return scrollHeight > clientHeight || scrollWidth > clientWidth;\n};\n\nexport interface IsElementVisibleOptions {\n  /**\n   * The element to check if it is visible inside a container.\n   */\n  element?: HTMLElement | null;\n\n  /**\n   * The container to check if the element is visible inside.\n   * @default document.documentElement\n   */\n  container?: HTMLElement | null;\n\n  /**\n   * The container's rect to check if the element is visible inside. Can be supplied to reduce the amount of DOM reads.\n   * @default container.getBoundingClientRect()\n   */\n  containerRect?: DOMRect | null;\n}\n\nexport interface CurrentElementVisibility {\n  /**\n   * Whether the element is visible in the inline direction.\n   */\n  inline: boolean;\n\n  /**\n   * Whether the element is visible in the block direction.\n   */\n  block: boolean;\n\n  /**\n   * The percentage of the element that is visible in the inline direction.\n   */\n  inlineIntersection: number;\n\n  /**\n   * The percentage of the element that is visible in the block direction.\n   */\n  blockIntersection: number;\n\n  /**\n   * The element that is being checked for visibility.\n   */\n  element: HTMLElement;\n}\n\nexport const isElementVisible = (options: IsElementVisibleOptions): CurrentElementVisibility | null => {\n  let { container } = options;\n  const { element } = options;\n\n  if (!element || container === null) {\n    return null;\n  }\n\n  container ||= document.documentElement;\n\n  const canScroll = elementCanScroll(container);\n\n  if (!canScroll) {\n    return { inline: true, block: true, blockIntersection: 100, inlineIntersection: 100, element };\n  }\n\n  const elementRect = element.getBoundingClientRect();\n  const containerRect = options.containerRect || container.getBoundingClientRect();\n\n  const elementInlineStart = elementRect.left;\n  const elementBlockStart = elementRect.top;\n\n  const containerInlineStart = containerRect.left;\n  const containerBlockStart = containerRect.top;\n\n  const elementInlineEnd = elementInlineStart + elementRect.width;\n  const elementBlockEnd = elementBlockStart + elementRect.height;\n\n  const containerInlineEnd = containerInlineStart + containerRect.width;\n  const containerBlockEnd = containerBlockStart + containerRect.height;\n\n  const isElementInlineVisible = elementInlineStart >= containerInlineStart && elementInlineEnd <= containerInlineEnd;\n  const isElementBlockVisible = elementBlockStart >= containerBlockStart && elementBlockEnd <= containerBlockEnd;\n\n  const inlineIntersection =\n    Math.min(elementInlineEnd, containerInlineEnd) - Math.max(elementInlineStart, containerInlineStart);\n  const blockIntersection =\n    Math.min(elementBlockEnd, containerBlockEnd) - Math.max(elementBlockStart, containerBlockStart);\n\n  const inlineIntersectionPercentage = clamp((inlineIntersection / elementRect.width) * 100);\n  const blockIntersectionPercentage = clamp((blockIntersection / elementRect.height) * 100);\n\n  return {\n    inline: isElementInlineVisible,\n    block: isElementBlockVisible,\n    inlineIntersection: inlineIntersectionPercentage,\n    blockIntersection: blockIntersectionPercentage,\n    element,\n  };\n};\n\nexport interface ScrollToElementOptions {\n  /**\n   * The element to scroll to.\n   */\n  element?: HTMLElement | null;\n\n  /**\n   * The scroll container to scroll to the element in.\n   * @default document.documentElement\n   */\n  container?: HTMLElement | null;\n\n  /**\n   * The direction to scroll in.\n   * @default 'both'\n   */\n  direction?: 'inline' | 'block' | 'both';\n\n  /**\n   * The origin of the element to scroll to.\n   * @default 'nearest'\n   */\n  origin?: 'start' | 'end' | 'center' | 'nearest';\n\n  /**\n   * The scroll behavior.\n   * @default 'smooth'\n   */\n  behavior?: ScrollBehavior;\n\n  /**\n   * The scroll inline-margin\n   * @default 0\n   */\n  scrollInlineMargin?: number;\n\n  /**\n   * The scroll block-margin\n   * @default 0\n   */\n  scrollBlockMargin?: number;\n}\n\nexport const scrollToElement = (options: ScrollToElementOptions) => {\n  let { container } = options;\n  const {\n    element,\n    direction,\n    behavior = 'smooth',\n    origin = 'nearest',\n    scrollBlockMargin = 0,\n    scrollInlineMargin = 0,\n  } = options;\n\n  if (!element || container === null) {\n    return;\n  }\n\n  container ||= document.documentElement;\n\n  const canScroll = elementCanScroll(container);\n\n  if (!canScroll) {\n    return;\n  }\n\n  const elementRect = element.getBoundingClientRect();\n  const containerRect = container.getBoundingClientRect();\n\n  const elementInlineSize = elementRect.width;\n  const elementBlockSize = elementRect.height;\n\n  const containerInlineSize = containerRect.width;\n  const containerBlockSize = containerRect.height;\n\n  const elementInlineStart = elementRect.left;\n  const elementBlockStart = elementRect.top;\n\n  const containerInlineStart = containerRect.left;\n  const containerBlockStart = containerRect.top;\n\n  const elementInlineEnd = elementInlineStart + elementInlineSize;\n  const elementBlockEnd = elementBlockStart + elementBlockSize;\n\n  const containerInlineEnd = containerInlineStart + containerInlineSize;\n  const containerBlockEnd = containerBlockStart + containerBlockSize;\n\n  const elementInlineCenter = elementInlineStart + elementInlineSize / 2;\n  const elementBlockCenter = elementBlockStart + elementBlockSize / 2;\n\n  const containerInlineCenter = containerInlineStart + containerInlineSize / 2;\n  const containerBlockCenter = containerBlockStart + containerBlockSize / 2;\n\n  const elementInlineOrigin =\n    origin === 'center' ? elementInlineCenter : origin === 'end' ? elementInlineEnd : elementInlineStart;\n  const elementBlockOrigin =\n    origin === 'center' ? elementBlockCenter : origin === 'end' ? elementBlockEnd : elementBlockStart;\n\n  const containerInlineOrigin =\n    origin === 'center' ? containerInlineCenter : origin === 'end' ? containerInlineEnd : containerInlineStart;\n  const containerBlockOrigin =\n    origin === 'center' ? containerBlockCenter : origin === 'end' ? containerBlockEnd : containerBlockStart;\n\n  const inlineOffset = elementInlineOrigin - containerInlineOrigin - scrollInlineMargin;\n  const blockOffset = elementBlockOrigin - containerBlockOrigin - scrollBlockMargin;\n\n  let inlineScroll: number | undefined = direction === 'block' ? undefined : inlineOffset;\n  let blockScroll: number | undefined = direction === 'inline' ? undefined : blockOffset;\n\n  if (origin === 'nearest') {\n    const elVisible = isElementVisible({ element, container, containerRect });\n\n    if (elVisible?.inline && elVisible?.block) {\n      return;\n    }\n\n    if (elVisible?.inline) {\n      inlineScroll = undefined;\n    }\n\n    if (elVisible?.block) {\n      blockScroll = undefined;\n    }\n  }\n\n  container.scrollTo({\n    left: container.scrollLeft + (inlineScroll || 0),\n    top: container.scrollTop + (blockScroll || 0),\n    behavior,\n  });\n};\n\nexport interface GetVisibleElementsOptions {\n  /**\n   * The container to check for visible elements.\n   * @default document.documentElement\n   */\n  container?: HTMLElement | null;\n\n  /**\n   * The elements to check if they are visible inside a container.\n   */\n  elements: HTMLElement[];\n}\n\nexport const getElementVisibleStates = (options: GetVisibleElementsOptions) => {\n  let { container } = options;\n  const { elements } = options;\n\n  container ||= document.documentElement;\n\n  const rect = container.getBoundingClientRect();\n\n  const elementVisibleStates = elements\n    .map((e) => {\n      if (!e || !container) return null;\n\n      return isElementVisible({ container, element: e, containerRect: rect });\n    })\n    .filter(Boolean) as CurrentElementVisibility[];\n\n  return elementVisibleStates;\n};\n"]}
|
|
116
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scrollable.utils.js","sourceRoot":"","sources":["../../../../../../libs/core/src/lib/utils/scrollable.utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { clamp } from './clamp.util';\n\nexport const elementCanScroll = (element: HTMLElement, direction?: 'x' | 'y') => {\n  const { scrollHeight, clientHeight, scrollWidth, clientWidth } = element;\n\n  if (direction === 'x') {\n    return scrollWidth > clientWidth;\n  } else if (direction === 'y') {\n    return scrollHeight > clientHeight;\n  }\n\n  return scrollHeight > clientHeight || scrollWidth > clientWidth;\n};\n\nexport interface IsElementVisibleOptions {\n  /**\n   * The element to check if it is visible inside a container.\n   */\n  element?: HTMLElement | null;\n\n  /**\n   * The container to check if the element is visible inside.\n   * @default document.documentElement\n   */\n  container?: HTMLElement | null;\n\n  /**\n   * The container's rect to check if the element is visible inside. Can be supplied to reduce the amount of DOM reads.\n   * @default container.getBoundingClientRect()\n   */\n  containerRect?: DOMRect | null;\n}\n\nexport interface CurrentElementVisibility {\n  /**\n   * Whether the element is visible in the inline direction.\n   */\n  inline: boolean;\n\n  /**\n   * Whether the element is visible in the block direction.\n   */\n  block: boolean;\n\n  /**\n   * The percentage of the element that is visible in the inline direction.\n   */\n  inlineIntersection: number;\n\n  /**\n   * The percentage of the element that is visible in the block direction.\n   */\n  blockIntersection: number;\n\n  /**\n   * The element that is being checked for visibility.\n   */\n  element: HTMLElement;\n}\n\nexport const isElementVisible = (options: IsElementVisibleOptions): CurrentElementVisibility | null => {\n  let { container } = options;\n  const { element } = options;\n\n  if (!element || container === null) {\n    return null;\n  }\n\n  container ||= document.documentElement;\n\n  const canScroll = elementCanScroll(container);\n\n  if (!canScroll) {\n    return { inline: true, block: true, blockIntersection: 100, inlineIntersection: 100, element };\n  }\n\n  const elementRect = element.getBoundingClientRect();\n  const containerRect = options.containerRect || container.getBoundingClientRect();\n\n  const elementInlineStart = elementRect.left;\n  const elementBlockStart = elementRect.top;\n\n  const containerInlineStart = containerRect.left;\n  const containerBlockStart = containerRect.top;\n\n  const elementInlineEnd = elementInlineStart + elementRect.width;\n  const elementBlockEnd = elementBlockStart + elementRect.height;\n\n  const containerInlineEnd = containerInlineStart + containerRect.width;\n  const containerBlockEnd = containerBlockStart + containerRect.height;\n\n  const isElementInlineVisible = elementInlineStart >= containerInlineStart && elementInlineEnd <= containerInlineEnd;\n  const isElementBlockVisible = elementBlockStart >= containerBlockStart && elementBlockEnd <= containerBlockEnd;\n\n  const inlineIntersection =\n    Math.min(elementInlineEnd, containerInlineEnd) - Math.max(elementInlineStart, containerInlineStart);\n  const blockIntersection =\n    Math.min(elementBlockEnd, containerBlockEnd) - Math.max(elementBlockStart, containerBlockStart);\n\n  const inlineIntersectionPercentage = clamp((inlineIntersection / elementRect.width) * 100);\n  const blockIntersectionPercentage = clamp((blockIntersection / elementRect.height) * 100);\n\n  return {\n    inline: isElementInlineVisible,\n    block: isElementBlockVisible,\n    inlineIntersection: inlineIntersectionPercentage,\n    blockIntersection: blockIntersectionPercentage,\n    element,\n  };\n};\n\nexport interface ScrollToElementOptions {\n  /**\n   * The element to scroll to.\n   */\n  element?: HTMLElement | null;\n\n  /**\n   * The scroll container to scroll to the element in.\n   * @default document.documentElement\n   */\n  container?: HTMLElement | null;\n\n  /**\n   * The direction to scroll in.\n   * @default 'both'\n   */\n  direction?: 'inline' | 'block' | 'both';\n\n  /**\n   * The origin of the element to scroll to.\n   * @default 'nearest'\n   */\n  origin?: 'start' | 'end' | 'center' | 'nearest';\n\n  /**\n   * The scroll behavior.\n   * @default 'smooth'\n   */\n  behavior?: ScrollBehavior;\n\n  /**\n   * The scroll inline-margin\n   * @default 0\n   */\n  scrollInlineMargin?: number;\n\n  /**\n   * The scroll block-margin\n   * @default 0\n   */\n  scrollBlockMargin?: number;\n}\n\nexport const scrollToElement = (options: ScrollToElementOptions) => {\n  let { container } = options;\n  const {\n    element,\n    direction,\n    behavior = 'smooth',\n    origin = 'nearest',\n    scrollBlockMargin = 0,\n    scrollInlineMargin = 0,\n  } = options;\n\n  if (!element || container === null) {\n    return;\n  }\n\n  container ||= document.documentElement;\n\n  const canScroll = elementCanScroll(container);\n\n  if (!canScroll) {\n    return;\n  }\n\n  const elementRect = element.getBoundingClientRect();\n  const containerRect = container.getBoundingClientRect();\n\n  const elementInlineSize = elementRect.width;\n  const elementBlockSize = elementRect.height;\n\n  const containerInlineSize = containerRect.width;\n  const containerBlockSize = containerRect.height;\n\n  const elementInlineStart = elementRect.left;\n  const elementBlockStart = elementRect.top;\n\n  const containerInlineStart = containerRect.left;\n  const containerBlockStart = containerRect.top;\n\n  const elementInlineEnd = elementInlineStart + elementInlineSize;\n  const elementBlockEnd = elementBlockStart + elementBlockSize;\n\n  const containerInlineEnd = containerInlineStart + containerInlineSize;\n  const containerBlockEnd = containerBlockStart + containerBlockSize;\n\n  const elementInlineCenter = elementInlineStart + elementInlineSize / 2;\n  const elementBlockCenter = elementBlockStart + elementBlockSize / 2;\n\n  const containerInlineCenter = containerInlineStart + containerInlineSize / 2;\n  const containerBlockCenter = containerBlockStart + containerBlockSize / 2;\n\n  const elementInlineOrigin =\n    origin === 'center' ? elementInlineCenter : origin === 'end' ? elementInlineEnd : elementInlineStart;\n  const elementBlockOrigin =\n    origin === 'center' ? elementBlockCenter : origin === 'end' ? elementBlockEnd : elementBlockStart;\n\n  const containerInlineOrigin =\n    origin === 'center' ? containerInlineCenter : origin === 'end' ? containerInlineEnd : containerInlineStart;\n  const containerBlockOrigin =\n    origin === 'center' ? containerBlockCenter : origin === 'end' ? containerBlockEnd : containerBlockStart;\n\n  const inlineOffset = elementInlineOrigin - containerInlineOrigin - scrollInlineMargin;\n  const blockOffset = elementBlockOrigin - containerBlockOrigin - scrollBlockMargin;\n\n  let inlineScroll: number | undefined = direction === 'block' ? undefined : inlineOffset;\n  let blockScroll: number | undefined = direction === 'inline' ? undefined : blockOffset;\n\n  if (origin === 'nearest') {\n    const elVisible = isElementVisible({ element, container, containerRect });\n\n    if (elVisible?.inline && elVisible?.block) {\n      return;\n    }\n\n    if (elVisible?.inline) {\n      inlineScroll = undefined;\n    }\n\n    if (elVisible?.block) {\n      blockScroll = undefined;\n    }\n  }\n\n  container.scrollTo({\n    left: container.scrollLeft + (inlineScroll || 0),\n    top: container.scrollTop + (blockScroll || 0),\n    behavior,\n  });\n};\n\nexport interface GetVisibleElementsOptions {\n  /**\n   * The container to check for visible elements.\n   * @default document.documentElement\n   */\n  container?: HTMLElement | null;\n\n  /**\n   * The elements to check if they are visible inside a container.\n   */\n  elements: HTMLElement[];\n}\n\nexport const getElementVisibleStates = (options: GetVisibleElementsOptions) => {\n  let { container } = options;\n  const { elements } = options;\n\n  container ||= document.documentElement;\n\n  const rect = container.getBoundingClientRect();\n\n  const elementVisibleStates = elements\n    .map((e) => {\n      if (!e || !container) return null;\n\n      return isElementVisible({ container, element: e, containerRect: rect });\n    })\n    .filter(Boolean) as CurrentElementVisibility[];\n\n  return elementVisibleStates;\n};\n"]}
|
|
@@ -1,15 +1,22 @@
|
|
|
1
1
|
import { coerceCssPixelValue } from '@angular/cdk/coercion';
|
|
2
2
|
import { supportsScrollBehavior } from '@angular/cdk/platform';
|
|
3
|
-
import { skip, take, tap } from 'rxjs';
|
|
3
|
+
import { skip, startWith, take, tap } from 'rxjs';
|
|
4
|
+
import { createResizeObservable } from './resize-observable.util';
|
|
5
|
+
import { elementCanScroll } from './scrollable.utils';
|
|
4
6
|
const scrollBehaviorSupported = supportsScrollBehavior();
|
|
7
|
+
let _uniqueIdCounter = 0;
|
|
8
|
+
const BLOCK_CLASS = 'cdk-global-scrollblock';
|
|
9
|
+
const OVERSCROLL_CLASS = 'et-global-no-overscroll';
|
|
5
10
|
export class SmartBlockScrollStrategy {
|
|
6
11
|
constructor(_viewportRuler, _routerState, document) {
|
|
7
12
|
this._viewportRuler = _viewportRuler;
|
|
8
13
|
this._routerState = _routerState;
|
|
14
|
+
this._id = _uniqueIdCounter++;
|
|
9
15
|
this._previousHTMLStyles = { top: '', left: '' };
|
|
10
16
|
this._previousScrollPosition = { top: 0, left: 0 };
|
|
11
17
|
this._isEnabled = false;
|
|
12
18
|
this._urlSubscription = null;
|
|
19
|
+
this._resizeSubscription = null;
|
|
13
20
|
this._didNavigate = false;
|
|
14
21
|
this._document = document;
|
|
15
22
|
}
|
|
@@ -19,25 +26,36 @@ export class SmartBlockScrollStrategy {
|
|
|
19
26
|
enable() {
|
|
20
27
|
if (this._canBeEnabled()) {
|
|
21
28
|
const root = this._document.documentElement;
|
|
22
|
-
|
|
23
|
-
this.
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
.
|
|
32
|
-
|
|
29
|
+
root.classList.add(OVERSCROLL_CLASS);
|
|
30
|
+
this._resizeSubscription = createResizeObservable({ elements: root })
|
|
31
|
+
.pipe(startWith(null), tap(() => {
|
|
32
|
+
if (this._isEnabled || !elementCanScroll(root) || !this._canBeEnabled())
|
|
33
|
+
return;
|
|
34
|
+
this._isEnabled = true;
|
|
35
|
+
this._previousScrollPosition = this._viewportRuler.getViewportScrollPosition();
|
|
36
|
+
this._didNavigate = false;
|
|
37
|
+
this._previousHTMLStyles.left = root.style.left || '';
|
|
38
|
+
this._previousHTMLStyles.top = root.style.top || '';
|
|
39
|
+
root.style.left = coerceCssPixelValue(-this._previousScrollPosition.left);
|
|
40
|
+
root.style.top = coerceCssPixelValue(-this._previousScrollPosition.top);
|
|
41
|
+
root.classList.add(BLOCK_CLASS);
|
|
42
|
+
this._urlSubscription = this._routerState.route$
|
|
43
|
+
.pipe(skip(1), take(1), tap(() => {
|
|
44
|
+
this._didNavigate = true;
|
|
45
|
+
}))
|
|
46
|
+
.subscribe();
|
|
33
47
|
}))
|
|
34
48
|
.subscribe();
|
|
35
49
|
}
|
|
36
50
|
}
|
|
37
51
|
disable() {
|
|
52
|
+
this._urlSubscription?.unsubscribe();
|
|
53
|
+
this._resizeSubscription?.unsubscribe();
|
|
54
|
+
const html = this._document.documentElement;
|
|
55
|
+
if (this._canBeEnabled()) {
|
|
56
|
+
html.classList.remove(OVERSCROLL_CLASS);
|
|
57
|
+
}
|
|
38
58
|
if (this._isEnabled) {
|
|
39
|
-
this._urlSubscription?.unsubscribe();
|
|
40
|
-
const html = this._document.documentElement;
|
|
41
59
|
const body = this._document.body;
|
|
42
60
|
const htmlStyle = html.style;
|
|
43
61
|
const bodyStyle = body.style;
|
|
@@ -46,7 +64,7 @@ export class SmartBlockScrollStrategy {
|
|
|
46
64
|
this._isEnabled = false;
|
|
47
65
|
htmlStyle.left = this._previousHTMLStyles.left;
|
|
48
66
|
htmlStyle.top = this._previousHTMLStyles.top;
|
|
49
|
-
html.classList.remove(
|
|
67
|
+
html.classList.remove(BLOCK_CLASS);
|
|
50
68
|
if (scrollBehaviorSupported) {
|
|
51
69
|
htmlStyle.scrollBehavior = bodyStyle.scrollBehavior = 'auto';
|
|
52
70
|
}
|
|
@@ -61,10 +79,10 @@ export class SmartBlockScrollStrategy {
|
|
|
61
79
|
}
|
|
62
80
|
_canBeEnabled() {
|
|
63
81
|
const html = this._document.documentElement;
|
|
64
|
-
if (html.classList.contains(
|
|
82
|
+
if (html.classList.contains(BLOCK_CLASS) || this._isEnabled) {
|
|
65
83
|
return false;
|
|
66
84
|
}
|
|
67
85
|
return true;
|
|
68
86
|
}
|
|
69
87
|
}
|
|
70
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnQtYmxvY2stc2Nyb2xsLXN0cmF0ZWd5LnV0aWxzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb3JlL3NyYy9saWIvdXRpbHMvc21hcnQtYmxvY2stc2Nyb2xsLXN0cmF0ZWd5LnV0aWxzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBRTVELE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBRS9ELE9BQU8sRUFBRSxJQUFJLEVBQWdCLElBQUksRUFBRSxHQUFHLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFHckQsTUFBTSx1QkFBdUIsR0FBRyxzQkFBc0IsRUFBRSxDQUFDO0FBRXpELE1BQU0sT0FBTyx3QkFBd0I7SUFRbkMsWUFDVSxjQUE2QixFQUM3QixZQUFnQyxFQUN4QyxRQUFrQjtRQUZWLG1CQUFjLEdBQWQsY0FBYyxDQUFlO1FBQzdCLGlCQUFZLEdBQVosWUFBWSxDQUFvQjtRQVRsQyx3QkFBbUIsR0FBRyxFQUFFLEdBQUcsRUFBRSxFQUFFLEVBQUUsSUFBSSxFQUFFLEVBQUUsRUFBRSxDQUFDO1FBQzVDLDRCQUF1QixHQUFrQyxFQUFFLEdBQUcsRUFBRSxDQUFDLEVBQUUsSUFBSSxFQUFFLENBQUMsRUFBRSxDQUFDO1FBQzdFLGVBQVUsR0FBRyxLQUFLLENBQUM7UUFFbkIscUJBQWdCLEdBQXdCLElBQUksQ0FBQztRQUM3QyxpQkFBWSxHQUFHLEtBQUssQ0FBQztRQU8zQixJQUFJLENBQUMsU0FBUyxHQUFHLFFBQVEsQ0FBQztJQUM1QixDQUFDO0lBRUQsTUFBTTtRQUNKLE9BQU87SUFDVCxDQUFDO0lBRUQsTUFBTTtRQUNKLElBQUksSUFBSSxDQUFDLGFBQWEsRUFBRSxFQUFFO1lBQ3hCLE1BQU0sSUFBSSxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsZUFBZSxDQUFDO1lBRTVDLElB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QUMsVUFBVSxFQUFFO1lBQ3hFLE9BQU8sS0FBSyxDQUFDO1NBQ2Q7UUFFRCxPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNvZXJjZUNzc1BpeGVsVmFsdWUgfSBmcm9tICdAYW5ndWxhci9jZGsvY29lcmNpb24nO1xuaW1wb3J0IHsgU2Nyb2xsU3RyYXRlZ3kgfSBmcm9tICdAYW5ndWxhci9jZGsvb3ZlcmxheSc7XG5pbXBvcnQgeyBzdXBwb3J0c1Njcm9sbEJlaGF2aW9yIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL3BsYXRmb3JtJztcbmltcG9ydCB7IFZpZXdwb3J0UnVsZXIgfSBmcm9tICdAYW5ndWxhci9jZGsvc2Nyb2xsaW5nJztcbmltcG9ydCB7IHNraXAsIFN1YnNjcmlwdGlvbiwgdGFrZSwgdGFwIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBSb3V0ZXJTdGF0ZVNlcnZpY2UgfSBmcm9tICcuLi9zZXJ2aWNlcyc7XG5cbmNvbnN0IHNjcm9sbEJlaGF2aW9yU3VwcG9ydGVkID0gc3VwcG9ydHNTY3JvbGxCZWhhdmlvcigpO1xuXG5leHBvcnQgY2xhc3MgU21hcnRCbG9ja1Njcm9sbFN0cmF0ZWd5IGltcGxlbWVudHMgU2Nyb2xsU3RyYXRlZ3kge1xuICBwcml2YXRlIF9wcmV2aW91c0hUTUxTdHlsZXMgPSB7IHRvcDogJycsIGxlZnQ6ICcnIH07XG4gIHByaXZhdGUgX3ByZXZpb3VzU2Nyb2xsUG9zaXRpb246IHsgdG9wOiBudW1iZXI7IGxlZnQ6IG51bWJlciB9ID0geyB0b3A6IDAsIGxlZnQ6IDAgfTtcbiAgcHJpdmF0ZSBfaXNFbmFibGVkID0gZmFsc2U7XG4gIHByaXZhdGUgX2RvY3VtZW50OiBEb2N1bWVudDtcbiAgcHJpdmF0ZSBfdXJsU3Vic2NyaXB0aW9uOiBTdWJzY3JpcHRpb24gfCBudWxsID0gbnVsbDtcbiAgcHJpdmF0ZSBfZGlkTmF2aWdhdGUgPSBmYWxzZTtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIF92aWV3cG9ydFJ1bGVyOiBWaWV3cG9ydFJ1bGVyLFxuICAgIHByaXZhdGUgX3JvdXRlclN0YXRlOiBSb3V0ZXJTdGF0ZVNlcnZpY2UsXG4gICAgZG9jdW1lbnQ6IERvY3VtZW50LFxuICApIHtcbiAgICB0aGlzLl9kb2N1bWVudCA9IGRvY3VtZW50O1xuICB9XG5cbiAgYXR0YWNoKCkge1xuICAgIC8vIG5vb3BcbiAgfVxuXG4gIGVuYWJsZSgpIHtcbiAgICBpZiAodGhpcy5fY2FuQmVFbmFibGVkKCkpIHtcbiAgICAgIGNvbnN0IHJvb3QgPSB0aGlzLl9kb2N1bWVudC5kb2N1bWVudEVsZW1lbnQ7XG5cbiAgICAgIHRoaXMuX3ByZXZpb3VzU2Nyb2xsUG9zaXRpb24gPSB0aGlzLl92aWV3cG9ydFJ1bGVyLmdldFZpZXdwb3J0U2Nyb2xsUG9zaXRpb24oKTtcbiAgICAgIHRoaXMuX2RpZE5hdmlnYXRlID0gZmFsc2U7XG5cbiAgICAgIHRoaXMuX3ByZXZpb3VzSFRNTFN0eWxlcy5sZWZ0ID0gcm9vdC5zdHlsZS5sZWZ0IHx8ICcnO1xuICAgICAgdGhpcy5fcHJldmlvdXNIVE1MU3R5bGVzLnRvcCA9IHJvb3Quc3R5bGUudG9wIHx8ICcnO1xuXG4gICAgICByb290LnN0eWxlLmxlZnQgPSBjb2VyY2VDc3NQaXhlbFZhbHVlKC10aGlzLl9wcmV2aW91c1Njcm9sbFBvc2l0aW9uLmxlZnQpO1xuICAgICAgcm9vdC5zdHlsZS50b3AgPSBjb2VyY2VDc3NQaXhlbFZhbHVlKC10aGlzLl9wcmV2aW91c1Njcm9sbFBvc2l0aW9uLnRvcCk7XG4gICAgICByb290LmNsYXNzTGlzdC5hZGQoJ2Nkay1nbG9iYWwtc2Nyb2xsYmxvY2snKTtcbiAgICAgIHRoaXMuX2lzRW5hYmxlZCA9IHRydWU7XG5cbiAgICAgIHRoaXMuX3VybFN1YnNjcmlwdGlvbiA9IHRoaXMuX3JvdXRlclN0YXRlLnJvdXRlJFxuICAgICAgICAucGlwZShcbiAgICAgICAgICBza2lwKDEpLFxuICAgICAgICAgIHRha2UoMSksXG4gICAgICAgICAgdGFwKCgpID0+IHtcbiAgICAgICAgICAgIHRoaXMuX2RpZE5hdmlnYXRlID0gdHJ1ZTtcbiAgICAgICAgICB9KSxcbiAgICAgICAgKVxuICAgICAgICAuc3Vic2NyaWJlKCk7XG4gICAgfVxuICB9XG5cbiAgZGlzYWJsZSgpIHtcbiAgICBpZiAodGhpcy5faXNFbmFibGVkKSB7XG4gICAgICB0aGlzLl91cmxTdWJzY3JpcHRpb24/LnVuc3Vic2NyaWJlKCk7XG5cbiAgICAgIGNvbnN0IGh0bWwgPSB0aGlzLl9kb2N1bWVudC5kb2N1bWVudEVsZW1lbnQ7XG4gICAgICBjb25zdCBib2R5ID0gdGhpcy5fZG9jdW1lbnQuYm9keTtcbiAgICAgIGNvbnN0IGh0bWxTdHlsZSA9IGh0bWwuc3R5bGU7XG4gICAgICBjb25zdCBib2R5U3R5bGUgPSBib2R5LnN0eWxlO1xuICAgICAgY29uc3QgcHJldmlvdXNIdG1sU2Nyb2xsQmVoYXZpb3IgPSBodG1sU3R5bGUuc2Nyb2xsQmVoYXZpb3IgfHwgJyc7XG4gICAgICBjb25zdCBwcmV2aW91c0JvZHlTY3JvbGxCZWhhdmlvciA9IGJvZHlTdHlsZS5zY3JvbGxCZWhhdmlvciB8fCAnJztcblxuICAgICAgdGhpcy5faXNFbmFibGVkID0gZmFsc2U7XG5cbiAgICAgIGh0bWxTdHlsZS5sZWZ0ID0gdGhpcy5fcHJldmlvdXNIVE1MU3R5bGVzLmxlZnQ7XG4gICAgICBodG1sU3R5bGUudG9wID0gdGhpcy5fcHJldmlvdXNIVE1MU3R5bGVzLnRvcDtcbiAgICAgIGh0bWwuY2xhc3NMaXN0LnJlbW92ZSgnY2RrLWdsb2JhbC1zY3JvbGxibG9jaycpO1xuXG4gICAgICBpZiAoc2Nyb2xsQmVoYXZpb3JTdXBwb3J0ZWQpIHtcbiAgICAgICAgaHRtbFN0eWxlLnNjcm9sbEJlaGF2aW9yID0gYm9keVN0eWxlLnNjcm9sbEJlaGF2aW9yID0gJ2F1dG8nO1xuICAgICAgfVxuXG4gICAgICBpZiAoIXRoaXMuX2RpZE5hdmlnYXRlKSB7XG4gICAgICAgIHdpbmRvdy5zY3JvbGwodGhpcy5fcHJldmlvdXNTY3JvbGxQb3NpdGlvbi5sZWZ0LCB0aGlzLl9wcmV2aW91c1Njcm9sbFBvc2l0aW9uLnRvcCk7XG4gICAgICB9XG5cbiAgICAgIGlmIChzY3JvbGxCZWhhdmlvclN1cHBvcnRlZCkge1xuICAgICAgICBodG1sU3R5bGUuc2Nyb2xsQmVoYXZpb3IgPSBwcmV2aW91c0h0bWxTY3JvbGxCZWhhdmlvcjtcbiAgICAgICAgYm9keVN0eWxlLnNjcm9sbEJlaGF2aW9yID0gcHJldmlvdXNCb2R5U2Nyb2xsQmVoYXZpb3I7XG4gICAgICB9XG4gICAgfVxuICB9XG5cbiAgcHJpdmF0ZSBfY2FuQmVFbmFibGVkKCk6IGJvb2xlYW4ge1xuICAgIGNvbnN0IGh0bWwgPSB0aGlzLl9kb2N1bWVudC5kb2N1bWVudEVsZW1lbnQ7XG5cbiAgICBpZiAoaHRtbC5jbGFzc0xpc3QuY29udGFpbnMoJ2Nkay1nbG9iYWwtc2Nyb2xsYmxvY2snKSB8fCB0aGlzLl9pc0VuYWJsZWQpIHtcbiAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG5cbiAgICByZXR1cm4gdHJ1ZTtcbiAgfVxufVxuIl19
|
|
88
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"smart-block-scroll-strategy.utils.js","sourceRoot":"","sources":["../../../../../../libs/core/src/lib/utils/smart-block-scroll-strategy.utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { coerceCssPixelValue } from '@angular/cdk/coercion';\nimport { ScrollStrategy } from '@angular/cdk/overlay';\nimport { supportsScrollBehavior } from '@angular/cdk/platform';\nimport { ViewportRuler } from '@angular/cdk/scrolling';\nimport { skip, startWith, Subscription, take, tap } from 'rxjs';\nimport { RouterStateService } from '../services';\nimport { createResizeObservable } from './resize-observable.util';\nimport { elementCanScroll } from './scrollable.utils';\n\nconst scrollBehaviorSupported = supportsScrollBehavior();\n\nlet _uniqueIdCounter = 0;\n\nconst BLOCK_CLASS = 'cdk-global-scrollblock';\nconst OVERSCROLL_CLASS = 'et-global-no-overscroll';\n\nexport class SmartBlockScrollStrategy implements ScrollStrategy {\n  private _id = _uniqueIdCounter++;\n  private _previousHTMLStyles = { top: '', left: '' };\n  private _previousScrollPosition: { top: number; left: number } = { top: 0, left: 0 };\n  private _isEnabled = false;\n  private _document: Document;\n  private _urlSubscription: Subscription | null = null;\n  private _resizeSubscription: Subscription | null = null;\n  private _didNavigate = false;\n\n  constructor(\n    private _viewportRuler: ViewportRuler,\n    private _routerState: RouterStateService,\n    document: Document,\n  ) {\n    this._document = document;\n  }\n\n  attach() {\n    // noop\n  }\n\n  enable() {\n    if (this._canBeEnabled()) {\n      const root = this._document.documentElement;\n      root.classList.add(OVERSCROLL_CLASS);\n\n      this._resizeSubscription = createResizeObservable({ elements: root })\n        .pipe(\n          startWith(null),\n          tap(() => {\n            if (this._isEnabled || !elementCanScroll(root) || !this._canBeEnabled()) return;\n\n            this._isEnabled = true;\n\n            this._previousScrollPosition = this._viewportRuler.getViewportScrollPosition();\n            this._didNavigate = false;\n\n            this._previousHTMLStyles.left = root.style.left || '';\n            this._previousHTMLStyles.top = root.style.top || '';\n\n            root.style.left = coerceCssPixelValue(-this._previousScrollPosition.left);\n            root.style.top = coerceCssPixelValue(-this._previousScrollPosition.top);\n            root.classList.add(BLOCK_CLASS);\n\n            this._urlSubscription = this._routerState.route$\n              .pipe(\n                skip(1),\n                take(1),\n                tap(() => {\n                  this._didNavigate = true;\n                }),\n              )\n              .subscribe();\n          }),\n        )\n        .subscribe();\n    }\n  }\n\n  disable() {\n    this._urlSubscription?.unsubscribe();\n    this._resizeSubscription?.unsubscribe();\n    const html = this._document.documentElement;\n\n    if (this._canBeEnabled()) {\n      html.classList.remove(OVERSCROLL_CLASS);\n    }\n\n    if (this._isEnabled) {\n      const body = this._document.body;\n      const htmlStyle = html.style;\n      const bodyStyle = body.style;\n      const previousHtmlScrollBehavior = htmlStyle.scrollBehavior || '';\n      const previousBodyScrollBehavior = bodyStyle.scrollBehavior || '';\n\n      this._isEnabled = false;\n\n      htmlStyle.left = this._previousHTMLStyles.left;\n      htmlStyle.top = this._previousHTMLStyles.top;\n      html.classList.remove(BLOCK_CLASS);\n\n      if (scrollBehaviorSupported) {\n        htmlStyle.scrollBehavior = bodyStyle.scrollBehavior = 'auto';\n      }\n\n      if (!this._didNavigate) {\n        window.scroll(this._previousScrollPosition.left, this._previousScrollPosition.top);\n      }\n\n      if (scrollBehaviorSupported) {\n        htmlStyle.scrollBehavior = previousHtmlScrollBehavior;\n        bodyStyle.scrollBehavior = previousBodyScrollBehavior;\n      }\n    }\n  }\n\n  private _canBeEnabled(): boolean {\n    const html = this._document.documentElement;\n\n    if (html.classList.contains(BLOCK_CLASS) || this._isEnabled) {\n      return false;\n    }\n\n    return true;\n  }\n}\n"]}
|