@ethlete/core 1.5.1 → 1.7.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/esm2020/lib/utils/scrollable.utils.mjs +81 -1
- package/fesm2015/ethlete-core.mjs +81 -1
- package/fesm2015/ethlete-core.mjs.map +1 -1
- package/fesm2020/ethlete-core.mjs +81 -1
- package/fesm2020/ethlete-core.mjs.map +1 -1
- package/lib/directives/animated-lifecycle/animated-lifecycle.directive.d.ts +2 -2
- package/lib/utils/scrollable.utils.d.ts +59 -0
- package/package.json +1 -1
|
@@ -2,4 +2,84 @@ export const elementCanScroll = (element) => {
|
|
|
2
2
|
const { scrollHeight, clientHeight, scrollWidth, clientWidth } = element;
|
|
3
3
|
return scrollHeight > clientHeight || scrollWidth > clientWidth;
|
|
4
4
|
};
|
|
5
|
-
|
|
5
|
+
export const isElementVisible = (options) => {
|
|
6
|
+
let { container } = options;
|
|
7
|
+
const { element } = options;
|
|
8
|
+
if (!element || container === null) {
|
|
9
|
+
return null;
|
|
10
|
+
}
|
|
11
|
+
container || (container = document.documentElement);
|
|
12
|
+
const canScroll = elementCanScroll(container);
|
|
13
|
+
if (!canScroll) {
|
|
14
|
+
return { inline: true, block: true };
|
|
15
|
+
}
|
|
16
|
+
const elementRect = element.getBoundingClientRect();
|
|
17
|
+
const containerRect = container.getBoundingClientRect();
|
|
18
|
+
const elementInlineStart = elementRect.left;
|
|
19
|
+
const elementBlockStart = elementRect.top;
|
|
20
|
+
const containerInlineStart = containerRect.left;
|
|
21
|
+
const containerBlockStart = containerRect.top;
|
|
22
|
+
const elementInlineEnd = elementInlineStart + elementRect.width;
|
|
23
|
+
const elementBlockEnd = elementBlockStart + elementRect.height;
|
|
24
|
+
const containerInlineEnd = containerInlineStart + containerRect.width;
|
|
25
|
+
const containerBlockEnd = containerBlockStart + containerRect.height;
|
|
26
|
+
const isElementInlineVisible = elementInlineStart >= containerInlineStart && elementInlineEnd <= containerInlineEnd;
|
|
27
|
+
const isElementBlockVisible = elementBlockStart >= containerBlockStart && elementBlockEnd <= containerBlockEnd;
|
|
28
|
+
return { inline: isElementInlineVisible, block: isElementBlockVisible };
|
|
29
|
+
};
|
|
30
|
+
export const scrollToElement = (options) => {
|
|
31
|
+
let { container } = options;
|
|
32
|
+
const { element, direction, behavior = 'smooth', origin = 'nearest', scrollBlockMargin = 0, scrollInlineMargin = 0, } = options;
|
|
33
|
+
if (!element || container === null) {
|
|
34
|
+
return;
|
|
35
|
+
}
|
|
36
|
+
container || (container = document.documentElement);
|
|
37
|
+
const canScroll = elementCanScroll(container);
|
|
38
|
+
if (!canScroll) {
|
|
39
|
+
return;
|
|
40
|
+
}
|
|
41
|
+
const elementRect = element.getBoundingClientRect();
|
|
42
|
+
const containerRect = container.getBoundingClientRect();
|
|
43
|
+
const elementInlineSize = elementRect.width;
|
|
44
|
+
const elementBlockSize = elementRect.height;
|
|
45
|
+
const containerInlineSize = containerRect.width;
|
|
46
|
+
const containerBlockSize = containerRect.height;
|
|
47
|
+
const elementInlineStart = elementRect.left;
|
|
48
|
+
const elementBlockStart = elementRect.top;
|
|
49
|
+
const containerInlineStart = containerRect.left;
|
|
50
|
+
const containerBlockStart = containerRect.top;
|
|
51
|
+
const elementInlineEnd = elementInlineStart + elementInlineSize;
|
|
52
|
+
const elementBlockEnd = elementBlockStart + elementBlockSize;
|
|
53
|
+
const containerInlineEnd = containerInlineStart + containerInlineSize;
|
|
54
|
+
const containerBlockEnd = containerBlockStart + containerBlockSize;
|
|
55
|
+
const elementInlineCenter = elementInlineStart + elementInlineSize / 2;
|
|
56
|
+
const elementBlockCenter = elementBlockStart + elementBlockSize / 2;
|
|
57
|
+
const containerInlineCenter = containerInlineStart + containerInlineSize / 2;
|
|
58
|
+
const containerBlockCenter = containerBlockStart + containerBlockSize / 2;
|
|
59
|
+
const elementInlineOrigin = origin === 'center' ? elementInlineCenter : origin === 'end' ? elementInlineEnd : elementInlineStart;
|
|
60
|
+
const elementBlockOrigin = origin === 'center' ? elementBlockCenter : origin === 'end' ? elementBlockEnd : elementBlockStart;
|
|
61
|
+
const containerInlineOrigin = origin === 'center' ? containerInlineCenter : origin === 'end' ? containerInlineEnd : containerInlineStart;
|
|
62
|
+
const containerBlockOrigin = origin === 'center' ? containerBlockCenter : origin === 'end' ? containerBlockEnd : containerBlockStart;
|
|
63
|
+
const inlineOffset = elementInlineOrigin - containerInlineOrigin - scrollInlineMargin;
|
|
64
|
+
const blockOffset = elementBlockOrigin - containerBlockOrigin - scrollBlockMargin;
|
|
65
|
+
let inlineScroll = direction === 'block' ? undefined : inlineOffset;
|
|
66
|
+
let blockScroll = direction === 'inline' ? undefined : blockOffset;
|
|
67
|
+
if (origin === 'nearest') {
|
|
68
|
+
const elVisible = isElementVisible({ element, container });
|
|
69
|
+
if (elVisible?.inline && elVisible?.block) {
|
|
70
|
+
return;
|
|
71
|
+
}
|
|
72
|
+
if (elVisible?.inline) {
|
|
73
|
+
inlineScroll = undefined;
|
|
74
|
+
}
|
|
75
|
+
if (elVisible?.block) {
|
|
76
|
+
blockScroll = undefined;
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
container.scrollTo({
|
|
80
|
+
left: inlineScroll,
|
|
81
|
+
top: blockScroll,
|
|
82
|
+
behavior,
|
|
83
|
+
});
|
|
84
|
+
};
|
|
85
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scrollable.utils.js","sourceRoot":"","sources":["../../../../../../libs/core/src/lib/utils/scrollable.utils.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,gBAAgB,GAAG,CAAC,OAAoB,EAAE,EAAE;IACvD,MAAM,EAAE,YAAY,EAAE,YAAY,EAAE,WAAW,EAAE,WAAW,EAAE,GAAG,OAAO,CAAC;IAEzE,OAAO,YAAY,GAAG,YAAY,IAAI,WAAW,GAAG,WAAW,CAAC;AAClE,CAAC,CAAC;AA2BF,MAAM,CAAC,MAAM,gBAAgB,GAAG,CAAC,OAAgC,EAAmC,EAAE;IACpG,IAAI,EAAE,SAAS,EAAE,GAAG,OAAO,CAAC;IAC5B,MAAM,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC;IAE5B,IAAI,CAAC,OAAO,IAAI,SAAS,KAAK,IAAI,EAAE;QAClC,OAAO,IAAI,CAAC;KACb;IAED,SAAS,KAAT,SAAS,GAAK,QAAQ,CAAC,eAAe,EAAC;IAEvC,MAAM,SAAS,GAAG,gBAAgB,CAAC,SAAS,CAAC,CAAC;IAE9C,IAAI,CAAC,SAAS,EAAE;QACd,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC;KACtC;IAED,MAAM,WAAW,GAAG,OAAO,CAAC,qBAAqB,EAAE,CAAC;IACpD,MAAM,aAAa,GAAG,SAAS,CAAC,qBAAqB,EAAE,CAAC;IAExD,MAAM,kBAAkB,GAAG,WAAW,CAAC,IAAI,CAAC;IAC5C,MAAM,iBAAiB,GAAG,WAAW,CAAC,GAAG,CAAC;IAE1C,MAAM,oBAAoB,GAAG,aAAa,CAAC,IAAI,CAAC;IAChD,MAAM,mBAAmB,GAAG,aAAa,CAAC,GAAG,CAAC;IAE9C,MAAM,gBAAgB,GAAG,kBAAkB,GAAG,WAAW,CAAC,KAAK,CAAC;IAChE,MAAM,eAAe,GAAG,iBAAiB,GAAG,WAAW,CAAC,MAAM,CAAC;IAE/D,MAAM,kBAAkB,GAAG,oBAAoB,GAAG,aAAa,CAAC,KAAK,CAAC;IACtE,MAAM,iBAAiB,GAAG,mBAAmB,GAAG,aAAa,CAAC,MAAM,CAAC;IAErE,MAAM,sBAAsB,GAAG,kBAAkB,IAAI,oBAAoB,IAAI,gBAAgB,IAAI,kBAAkB,CAAC;IACpH,MAAM,qBAAqB,GAAG,iBAAiB,IAAI,mBAAmB,IAAI,eAAe,IAAI,iBAAiB,CAAC;IAE/G,OAAO,EAAE,MAAM,EAAE,sBAAsB,EAAE,KAAK,EAAE,qBAAqB,EAAE,CAAC;AAC1E,CAAC,CAAC;AA6CF,MAAM,CAAC,MAAM,eAAe,GAAG,CAAC,OAA+B,EAAE,EAAE;IACjE,IAAI,EAAE,SAAS,EAAE,GAAG,OAAO,CAAC;IAC5B,MAAM,EACJ,OAAO,EACP,SAAS,EACT,QAAQ,GAAG,QAAQ,EACnB,MAAM,GAAG,SAAS,EAClB,iBAAiB,GAAG,CAAC,EACrB,kBAAkB,GAAG,CAAC,GACvB,GAAG,OAAO,CAAC;IAEZ,IAAI,CAAC,OAAO,IAAI,SAAS,KAAK,IAAI,EAAE;QAClC,OAAO;KACR;IAED,SAAS,KAAT,SAAS,GAAK,QAAQ,CAAC,eAAe,EAAC;IAEvC,MAAM,SAAS,GAAG,gBAAgB,CAAC,SAAS,CAAC,CAAC;IAE9C,IAAI,CAAC,SAAS,EAAE;QACd,OAAO;KACR;IAED,MAAM,WAAW,GAAG,OAAO,CAAC,qBAAqB,EAAE,CAAC;IACpD,MAAM,aAAa,GAAG,SAAS,CAAC,qBAAqB,EAAE,CAAC;IAExD,MAAM,iBAAiB,GAAG,WAAW,CAAC,KAAK,CAAC;IAC5C,MAAM,gBAAgB,GAAG,WAAW,CAAC,MAAM,CAAC;IAE5C,MAAM,mBAAmB,GAAG,aAAa,CAAC,KAAK,CAAC;IAChD,MAAM,kBAAkB,GAAG,aAAa,CAAC,MAAM,CAAC;IAEhD,MAAM,kBAAkB,GAAG,WAAW,CAAC,IAAI,CAAC;IAC5C,MAAM,iBAAiB,GAAG,WAAW,CAAC,GAAG,CAAC;IAE1C,MAAM,oBAAoB,GAAG,aAAa,CAAC,IAAI,CAAC;IAChD,MAAM,mBAAmB,GAAG,aAAa,CAAC,GAAG,CAAC;IAE9C,MAAM,gBAAgB,GAAG,kBAAkB,GAAG,iBAAiB,CAAC;IAChE,MAAM,eAAe,GAAG,iBAAiB,GAAG,gBAAgB,CAAC;IAE7D,MAAM,kBAAkB,GAAG,oBAAoB,GAAG,mBAAmB,CAAC;IACtE,MAAM,iBAAiB,GAAG,mBAAmB,GAAG,kBAAkB,CAAC;IAEnE,MAAM,mBAAmB,GAAG,kBAAkB,GAAG,iBAAiB,GAAG,CAAC,CAAC;IACvE,MAAM,kBAAkB,GAAG,iBAAiB,GAAG,gBAAgB,GAAG,CAAC,CAAC;IAEpE,MAAM,qBAAqB,GAAG,oBAAoB,GAAG,mBAAmB,GAAG,CAAC,CAAC;IAC7E,MAAM,oBAAoB,GAAG,mBAAmB,GAAG,kBAAkB,GAAG,CAAC,CAAC;IAE1E,MAAM,mBAAmB,GACvB,MAAM,KAAK,QAAQ,CAAC,CAAC,CAAC,mBAAmB,CAAC,CAAC,CAAC,MAAM,KAAK,KAAK,CAAC,CAAC,CAAC,gBAAgB,CAAC,CAAC,CAAC,kBAAkB,CAAC;IACvG,MAAM,kBAAkB,GACtB,MAAM,KAAK,QAAQ,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,CAAC,MAAM,KAAK,KAAK,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,iBAAiB,CAAC;IAEpG,MAAM,qBAAqB,GACzB,MAAM,KAAK,QAAQ,CAAC,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,MAAM,KAAK,KAAK,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,CAAC,oBAAoB,CAAC;IAC7G,MAAM,oBAAoB,GACxB,MAAM,KAAK,QAAQ,CAAC,CAAC,CAAC,oBAAoB,CAAC,CAAC,CAAC,MAAM,KAAK,KAAK,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC,CAAC,mBAAmB,CAAC;IAE1G,MAAM,YAAY,GAAG,mBAAmB,GAAG,qBAAqB,GAAG,kBAAkB,CAAC;IACtF,MAAM,WAAW,GAAG,kBAAkB,GAAG,oBAAoB,GAAG,iBAAiB,CAAC;IAElF,IAAI,YAAY,GAAuB,SAAS,KAAK,OAAO,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,YAAY,CAAC;IACxF,IAAI,WAAW,GAAuB,SAAS,KAAK,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,WAAW,CAAC;IAEvF,IAAI,MAAM,KAAK,SAAS,EAAE;QACxB,MAAM,SAAS,GAAG,gBAAgB,CAAC,EAAE,OAAO,EAAE,SAAS,EAAE,CAAC,CAAC;QAE3D,IAAI,SAAS,EAAE,MAAM,IAAI,SAAS,EAAE,KAAK,EAAE;YACzC,OAAO;SACR;QAED,IAAI,SAAS,EAAE,MAAM,EAAE;YACrB,YAAY,GAAG,SAAS,CAAC;SAC1B;QAED,IAAI,SAAS,EAAE,KAAK,EAAE;YACpB,WAAW,GAAG,SAAS,CAAC;SACzB;KACF;IAED,SAAS,CAAC,QAAQ,CAAC;QACjB,IAAI,EAAE,YAAY;QAClB,GAAG,EAAE,WAAW;QAChB,QAAQ;KACT,CAAC,CAAC;AACL,CAAC,CAAC","sourcesContent":["export 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\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\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 };\n  }\n\n  const elementRect = element.getBoundingClientRect();\n  const 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  return { inline: isElementInlineVisible, block: isElementBlockVisible };\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 });\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: inlineScroll,\n    top: blockScroll,\n    behavior,\n  });\n};\n"]}
|
|
@@ -862,6 +862,86 @@ const elementCanScroll = (element) => {
|
|
|
862
862
|
const { scrollHeight, clientHeight, scrollWidth, clientWidth } = element;
|
|
863
863
|
return scrollHeight > clientHeight || scrollWidth > clientWidth;
|
|
864
864
|
};
|
|
865
|
+
const isElementVisible = (options) => {
|
|
866
|
+
let { container } = options;
|
|
867
|
+
const { element } = options;
|
|
868
|
+
if (!element || container === null) {
|
|
869
|
+
return null;
|
|
870
|
+
}
|
|
871
|
+
container || (container = document.documentElement);
|
|
872
|
+
const canScroll = elementCanScroll(container);
|
|
873
|
+
if (!canScroll) {
|
|
874
|
+
return { inline: true, block: true };
|
|
875
|
+
}
|
|
876
|
+
const elementRect = element.getBoundingClientRect();
|
|
877
|
+
const containerRect = container.getBoundingClientRect();
|
|
878
|
+
const elementInlineStart = elementRect.left;
|
|
879
|
+
const elementBlockStart = elementRect.top;
|
|
880
|
+
const containerInlineStart = containerRect.left;
|
|
881
|
+
const containerBlockStart = containerRect.top;
|
|
882
|
+
const elementInlineEnd = elementInlineStart + elementRect.width;
|
|
883
|
+
const elementBlockEnd = elementBlockStart + elementRect.height;
|
|
884
|
+
const containerInlineEnd = containerInlineStart + containerRect.width;
|
|
885
|
+
const containerBlockEnd = containerBlockStart + containerRect.height;
|
|
886
|
+
const isElementInlineVisible = elementInlineStart >= containerInlineStart && elementInlineEnd <= containerInlineEnd;
|
|
887
|
+
const isElementBlockVisible = elementBlockStart >= containerBlockStart && elementBlockEnd <= containerBlockEnd;
|
|
888
|
+
return { inline: isElementInlineVisible, block: isElementBlockVisible };
|
|
889
|
+
};
|
|
890
|
+
const scrollToElement = (options) => {
|
|
891
|
+
let { container } = options;
|
|
892
|
+
const { element, direction, behavior = 'smooth', origin = 'nearest', scrollBlockMargin = 0, scrollInlineMargin = 0, } = options;
|
|
893
|
+
if (!element || container === null) {
|
|
894
|
+
return;
|
|
895
|
+
}
|
|
896
|
+
container || (container = document.documentElement);
|
|
897
|
+
const canScroll = elementCanScroll(container);
|
|
898
|
+
if (!canScroll) {
|
|
899
|
+
return;
|
|
900
|
+
}
|
|
901
|
+
const elementRect = element.getBoundingClientRect();
|
|
902
|
+
const containerRect = container.getBoundingClientRect();
|
|
903
|
+
const elementInlineSize = elementRect.width;
|
|
904
|
+
const elementBlockSize = elementRect.height;
|
|
905
|
+
const containerInlineSize = containerRect.width;
|
|
906
|
+
const containerBlockSize = containerRect.height;
|
|
907
|
+
const elementInlineStart = elementRect.left;
|
|
908
|
+
const elementBlockStart = elementRect.top;
|
|
909
|
+
const containerInlineStart = containerRect.left;
|
|
910
|
+
const containerBlockStart = containerRect.top;
|
|
911
|
+
const elementInlineEnd = elementInlineStart + elementInlineSize;
|
|
912
|
+
const elementBlockEnd = elementBlockStart + elementBlockSize;
|
|
913
|
+
const containerInlineEnd = containerInlineStart + containerInlineSize;
|
|
914
|
+
const containerBlockEnd = containerBlockStart + containerBlockSize;
|
|
915
|
+
const elementInlineCenter = elementInlineStart + elementInlineSize / 2;
|
|
916
|
+
const elementBlockCenter = elementBlockStart + elementBlockSize / 2;
|
|
917
|
+
const containerInlineCenter = containerInlineStart + containerInlineSize / 2;
|
|
918
|
+
const containerBlockCenter = containerBlockStart + containerBlockSize / 2;
|
|
919
|
+
const elementInlineOrigin = origin === 'center' ? elementInlineCenter : origin === 'end' ? elementInlineEnd : elementInlineStart;
|
|
920
|
+
const elementBlockOrigin = origin === 'center' ? elementBlockCenter : origin === 'end' ? elementBlockEnd : elementBlockStart;
|
|
921
|
+
const containerInlineOrigin = origin === 'center' ? containerInlineCenter : origin === 'end' ? containerInlineEnd : containerInlineStart;
|
|
922
|
+
const containerBlockOrigin = origin === 'center' ? containerBlockCenter : origin === 'end' ? containerBlockEnd : containerBlockStart;
|
|
923
|
+
const inlineOffset = elementInlineOrigin - containerInlineOrigin - scrollInlineMargin;
|
|
924
|
+
const blockOffset = elementBlockOrigin - containerBlockOrigin - scrollBlockMargin;
|
|
925
|
+
let inlineScroll = direction === 'block' ? undefined : inlineOffset;
|
|
926
|
+
let blockScroll = direction === 'inline' ? undefined : blockOffset;
|
|
927
|
+
if (origin === 'nearest') {
|
|
928
|
+
const elVisible = isElementVisible({ element, container });
|
|
929
|
+
if ((elVisible === null || elVisible === void 0 ? void 0 : elVisible.inline) && (elVisible === null || elVisible === void 0 ? void 0 : elVisible.block)) {
|
|
930
|
+
return;
|
|
931
|
+
}
|
|
932
|
+
if (elVisible === null || elVisible === void 0 ? void 0 : elVisible.inline) {
|
|
933
|
+
inlineScroll = undefined;
|
|
934
|
+
}
|
|
935
|
+
if (elVisible === null || elVisible === void 0 ? void 0 : elVisible.block) {
|
|
936
|
+
blockScroll = undefined;
|
|
937
|
+
}
|
|
938
|
+
}
|
|
939
|
+
container.scrollTo({
|
|
940
|
+
left: inlineScroll,
|
|
941
|
+
top: blockScroll,
|
|
942
|
+
behavior,
|
|
943
|
+
});
|
|
944
|
+
};
|
|
865
945
|
|
|
866
946
|
const scrollBehaviorSupported = supportsScrollBehavior();
|
|
867
947
|
class SmartBlockScrollStrategy {
|
|
@@ -2647,5 +2727,5 @@ const Validators = {
|
|
|
2647
2727
|
* Generated bundle index. Do not edit.
|
|
2648
2728
|
*/
|
|
2649
2729
|
|
|
2650
|
-
export { ANIMATABLE_TOKEN, ANIMATED_LIFECYCLE_TOKEN, AnimatableDirective, AnimatedLifecycleDirective, BehaviorSubjectWithSubscriberCount, ClickObserverFactory, ClickObserverService, ClickOutsideDirective, ContentObserverService, CursorDragScrollDirective, DEFAULT_VIEWPORT_CONFIG, DestroyService, FocusVisibleService, IS_ARRAY_NOT_EMPTY, IS_EMAIL, IsArrayNotEmpty, IsEmail, LetContext, LetDirective, MUST_MATCH, Memo, MustMatch, MutationObserverFactory, NormalizeGameResultTypePipe, NormalizeMatchParticipantsPipe, NormalizeMatchScorePipe, NormalizeMatchStatePipe, NormalizeMatchTypePipe, OBSERVE_SCROLL_STATE, ObserveContentDirective, ObserveResizeDirective, ObserveScrollStateDirective, RepeatDirective, ResizeObserverFactory, ResizeObserverService, RouterStateService, SCROLL_OBSERVER_FIRST_ELEMENT_CLASS, SCROLL_OBSERVER_IGNORE_TARGET_CLASS, SCROLL_OBSERVER_LAST_ELEMENT_CLASS, SEO_DIRECTIVE_TOKEN, ScrollObserverFirstElementDirective, ScrollObserverIgnoreTargetDirective, ScrollObserverLastElementDirective, SeoDirective, SmartBlockScrollStrategy, StructuredDataComponent, ToArrayPipe, TypedQueryList, VIEWPORT_CONFIG, Validators, ViewportService, clamp, clone, createFlipAnimation, createFlipAnimationGroup, createMediaQueryObservable, createReactiveBindings, deleteCookie, elementCanScroll, equal, forceReflow, fromNextFrame, getCookie, getDomain, getGroupMatchPoints, getGroupMatchScore, getKnockoutMatchScore, getMatchScoreSubLine, hasCookie, isGroupMatch, isKnockoutMatch, mergeSeoConfig, nextFrame, normalizeGameResultType, normalizeMatchParticipant, normalizeMatchParticipants, normalizeMatchScore, normalizeMatchState, normalizeMatchType, provideViewportConfig, routerDisableScrollTop, setCookie, toArray, toArrayTrackByFn };
|
|
2730
|
+
export { ANIMATABLE_TOKEN, ANIMATED_LIFECYCLE_TOKEN, AnimatableDirective, AnimatedLifecycleDirective, BehaviorSubjectWithSubscriberCount, ClickObserverFactory, ClickObserverService, ClickOutsideDirective, ContentObserverService, CursorDragScrollDirective, DEFAULT_VIEWPORT_CONFIG, DestroyService, FocusVisibleService, IS_ARRAY_NOT_EMPTY, IS_EMAIL, IsArrayNotEmpty, IsEmail, LetContext, LetDirective, MUST_MATCH, Memo, MustMatch, MutationObserverFactory, NormalizeGameResultTypePipe, NormalizeMatchParticipantsPipe, NormalizeMatchScorePipe, NormalizeMatchStatePipe, NormalizeMatchTypePipe, OBSERVE_SCROLL_STATE, ObserveContentDirective, ObserveResizeDirective, ObserveScrollStateDirective, RepeatDirective, ResizeObserverFactory, ResizeObserverService, RouterStateService, SCROLL_OBSERVER_FIRST_ELEMENT_CLASS, SCROLL_OBSERVER_IGNORE_TARGET_CLASS, SCROLL_OBSERVER_LAST_ELEMENT_CLASS, SEO_DIRECTIVE_TOKEN, ScrollObserverFirstElementDirective, ScrollObserverIgnoreTargetDirective, ScrollObserverLastElementDirective, SeoDirective, SmartBlockScrollStrategy, StructuredDataComponent, ToArrayPipe, TypedQueryList, VIEWPORT_CONFIG, Validators, ViewportService, clamp, clone, createFlipAnimation, createFlipAnimationGroup, createMediaQueryObservable, createReactiveBindings, deleteCookie, elementCanScroll, equal, forceReflow, fromNextFrame, getCookie, getDomain, getGroupMatchPoints, getGroupMatchScore, getKnockoutMatchScore, getMatchScoreSubLine, hasCookie, isElementVisible, isGroupMatch, isKnockoutMatch, mergeSeoConfig, nextFrame, normalizeGameResultType, normalizeMatchParticipant, normalizeMatchParticipants, normalizeMatchScore, normalizeMatchState, normalizeMatchType, provideViewportConfig, routerDisableScrollTop, scrollToElement, setCookie, toArray, toArrayTrackByFn };
|
|
2651
2731
|
//# sourceMappingURL=ethlete-core.mjs.map
|