@studiometa/ui 0.2.23 → 0.2.25

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (195) hide show
  1. package/README.md +2 -12
  2. package/atoms/AnchorScrollTo/AnchorScrollTo.cjs +11 -0
  3. package/atoms/AnchorScrollTo/AnchorScrollTo.cjs.map +2 -2
  4. package/atoms/AnchorScrollTo/AnchorScrollTo.js +11 -0
  5. package/atoms/AnchorScrollTo/AnchorScrollTo.js.map +2 -2
  6. package/atoms/Button/StyledButton.twig +6 -4
  7. package/atoms/Button/StyledButtonRounded.twig +65 -0
  8. package/atoms/Cursor/Cursor.cjs +12 -0
  9. package/atoms/Cursor/Cursor.cjs.map +2 -2
  10. package/atoms/Cursor/Cursor.js +12 -0
  11. package/atoms/Cursor/Cursor.js.map +2 -2
  12. package/atoms/Figure/Figure.cjs +27 -3
  13. package/atoms/Figure/Figure.cjs.map +2 -2
  14. package/atoms/Figure/Figure.js +27 -3
  15. package/atoms/Figure/Figure.js.map +2 -2
  16. package/atoms/Figure/Figure.twig +6 -1
  17. package/atoms/Figure/FigureTwicpics.cjs +21 -0
  18. package/atoms/Figure/FigureTwicpics.cjs.map +1 -1
  19. package/atoms/Figure/FigureTwicpics.js +21 -0
  20. package/atoms/Figure/FigureTwicpics.js.map +1 -1
  21. package/atoms/LargeText/LargeText.cjs +27 -0
  22. package/atoms/LargeText/LargeText.cjs.map +2 -2
  23. package/atoms/LargeText/LargeText.js +27 -0
  24. package/atoms/LargeText/LargeText.js.map +2 -2
  25. package/atoms/LazyInclude/LazyInclude.cjs +15 -0
  26. package/atoms/LazyInclude/LazyInclude.cjs.map +2 -2
  27. package/atoms/LazyInclude/LazyInclude.js +15 -0
  28. package/atoms/LazyInclude/LazyInclude.js.map +2 -2
  29. package/atoms/Prefetch/AbstractPrefetch.cjs +12 -0
  30. package/atoms/Prefetch/AbstractPrefetch.cjs.map +2 -2
  31. package/atoms/Prefetch/AbstractPrefetch.js +12 -0
  32. package/atoms/Prefetch/AbstractPrefetch.js.map +2 -2
  33. package/atoms/Prefetch/PrefetchWhenOver.cjs +6 -0
  34. package/atoms/Prefetch/PrefetchWhenOver.cjs.map +2 -2
  35. package/atoms/Prefetch/PrefetchWhenOver.js +6 -0
  36. package/atoms/Prefetch/PrefetchWhenOver.js.map +2 -2
  37. package/atoms/Prefetch/PrefetchWhenVisible.cjs +6 -0
  38. package/atoms/Prefetch/PrefetchWhenVisible.cjs.map +2 -2
  39. package/atoms/Prefetch/PrefetchWhenVisible.js +6 -0
  40. package/atoms/Prefetch/PrefetchWhenVisible.js.map +2 -2
  41. package/atoms/ScrollAnimation/AbstractScrollAnimation.cjs +12 -0
  42. package/atoms/ScrollAnimation/AbstractScrollAnimation.cjs.map +2 -2
  43. package/atoms/ScrollAnimation/AbstractScrollAnimation.js +12 -0
  44. package/atoms/ScrollAnimation/AbstractScrollAnimation.js.map +2 -2
  45. package/atoms/ScrollAnimation/ScrollAnimation.cjs +6 -0
  46. package/atoms/ScrollAnimation/ScrollAnimation.cjs.map +1 -1
  47. package/atoms/ScrollAnimation/ScrollAnimation.js +6 -0
  48. package/atoms/ScrollAnimation/ScrollAnimation.js.map +1 -1
  49. package/atoms/ScrollAnimation/ScrollAnimationChild.cjs +18 -1
  50. package/atoms/ScrollAnimation/ScrollAnimationChild.cjs.map +2 -2
  51. package/atoms/ScrollAnimation/ScrollAnimationChild.js +18 -1
  52. package/atoms/ScrollAnimation/ScrollAnimationChild.js.map +2 -2
  53. package/atoms/ScrollAnimation/ScrollAnimationChildWithEase.cjs +3 -0
  54. package/atoms/ScrollAnimation/ScrollAnimationChildWithEase.cjs.map +1 -1
  55. package/atoms/ScrollAnimation/ScrollAnimationChildWithEase.js +3 -0
  56. package/atoms/ScrollAnimation/ScrollAnimationChildWithEase.js.map +1 -1
  57. package/atoms/ScrollAnimation/ScrollAnimationParent.cjs +6 -0
  58. package/atoms/ScrollAnimation/ScrollAnimationParent.cjs.map +1 -1
  59. package/atoms/ScrollAnimation/ScrollAnimationParent.js +6 -0
  60. package/atoms/ScrollAnimation/ScrollAnimationParent.js.map +1 -1
  61. package/atoms/ScrollAnimation/ScrollAnimationWithEase.cjs +3 -0
  62. package/atoms/ScrollAnimation/ScrollAnimationWithEase.cjs.map +1 -1
  63. package/atoms/ScrollAnimation/ScrollAnimationWithEase.d.ts +1 -1
  64. package/atoms/ScrollAnimation/ScrollAnimationWithEase.js +3 -0
  65. package/atoms/ScrollAnimation/ScrollAnimationWithEase.js.map +1 -1
  66. package/atoms/ScrollAnimation/animationScrollWithEase.cjs +6 -0
  67. package/atoms/ScrollAnimation/animationScrollWithEase.cjs.map +2 -2
  68. package/atoms/ScrollAnimation/animationScrollWithEase.js +6 -0
  69. package/atoms/ScrollAnimation/animationScrollWithEase.js.map +2 -2
  70. package/atoms/ScrollReveal/ScrollReveal.cjs +12 -0
  71. package/atoms/ScrollReveal/ScrollReveal.cjs.map +1 -1
  72. package/atoms/ScrollReveal/ScrollReveal.js +12 -0
  73. package/atoms/ScrollReveal/ScrollReveal.js.map +1 -1
  74. package/decorators/withTransition.cjs +16 -2
  75. package/decorators/withTransition.cjs.map +2 -2
  76. package/decorators/withTransition.js +16 -2
  77. package/decorators/withTransition.js.map +2 -2
  78. package/molecules/Accordion/AccordionCore.cjs +9 -0
  79. package/molecules/Accordion/AccordionCore.cjs.map +2 -2
  80. package/molecules/Accordion/AccordionCore.js +9 -0
  81. package/molecules/Accordion/AccordionCore.js.map +2 -2
  82. package/molecules/Accordion/AccordionItem.cjs +33 -1
  83. package/molecules/Accordion/AccordionItem.cjs.map +2 -2
  84. package/molecules/Accordion/AccordionItem.d.ts +1 -1
  85. package/molecules/Accordion/AccordionItem.js +29 -1
  86. package/molecules/Accordion/AccordionItem.js.map +2 -2
  87. package/molecules/Menu/Menu.cjs +47 -0
  88. package/molecules/Menu/Menu.cjs.map +1 -1
  89. package/molecules/Menu/Menu.js +47 -0
  90. package/molecules/Menu/Menu.js.map +1 -1
  91. package/molecules/Menu/MenuBtn.cjs +24 -0
  92. package/molecules/Menu/MenuBtn.cjs.map +1 -1
  93. package/molecules/Menu/MenuBtn.js +24 -0
  94. package/molecules/Menu/MenuBtn.js.map +1 -1
  95. package/molecules/Menu/MenuList.cjs +39 -0
  96. package/molecules/Menu/MenuList.cjs.map +2 -2
  97. package/molecules/Menu/MenuList.d.ts +1 -1
  98. package/molecules/Menu/MenuList.js +39 -0
  99. package/molecules/Menu/MenuList.js.map +2 -2
  100. package/molecules/Modal/Modal.cjs +50 -1
  101. package/molecules/Modal/Modal.cjs.map +2 -2
  102. package/molecules/Modal/Modal.d.ts +3 -3
  103. package/molecules/Modal/Modal.js +50 -1
  104. package/molecules/Modal/Modal.js.map +2 -2
  105. package/molecules/Modal/ModalWithTransition.cjs +6 -0
  106. package/molecules/Modal/ModalWithTransition.cjs.map +2 -2
  107. package/molecules/Modal/ModalWithTransition.js +6 -0
  108. package/molecules/Modal/ModalWithTransition.js.map +2 -2
  109. package/molecules/Panel/Panel.cjs +19 -0
  110. package/molecules/Panel/Panel.cjs.map +2 -2
  111. package/molecules/Panel/Panel.js +19 -0
  112. package/molecules/Panel/Panel.js.map +2 -2
  113. package/molecules/Slider/AbstractSliderChild.cjs +24 -0
  114. package/molecules/Slider/AbstractSliderChild.cjs.map +2 -2
  115. package/molecules/Slider/AbstractSliderChild.js +24 -0
  116. package/molecules/Slider/AbstractSliderChild.js.map +2 -2
  117. package/molecules/Slider/Slider.cjs +97 -0
  118. package/molecules/Slider/Slider.cjs.map +2 -2
  119. package/molecules/Slider/Slider.d.ts +3 -2
  120. package/molecules/Slider/Slider.js +97 -0
  121. package/molecules/Slider/Slider.js.map +2 -2
  122. package/molecules/Slider/SliderBtn.cjs +22 -2
  123. package/molecules/Slider/SliderBtn.cjs.map +2 -2
  124. package/molecules/Slider/SliderBtn.d.ts +1 -0
  125. package/molecules/Slider/SliderBtn.js +22 -2
  126. package/molecules/Slider/SliderBtn.js.map +2 -2
  127. package/molecules/Slider/SliderCount.cjs +9 -0
  128. package/molecules/Slider/SliderCount.cjs.map +2 -2
  129. package/molecules/Slider/SliderCount.js +9 -0
  130. package/molecules/Slider/SliderCount.js.map +2 -2
  131. package/molecules/Slider/SliderDots.cjs +19 -0
  132. package/molecules/Slider/SliderDots.cjs.map +2 -2
  133. package/molecules/Slider/SliderDots.js +19 -0
  134. package/molecules/Slider/SliderDots.js.map +2 -2
  135. package/molecules/Slider/SliderDrag.cjs +15 -0
  136. package/molecules/Slider/SliderDrag.cjs.map +2 -2
  137. package/molecules/Slider/SliderDrag.js +15 -0
  138. package/molecules/Slider/SliderDrag.js.map +2 -2
  139. package/molecules/Slider/SliderItem.cjs +75 -14
  140. package/molecules/Slider/SliderItem.cjs.map +2 -2
  141. package/molecules/Slider/SliderItem.d.ts +12 -11
  142. package/molecules/Slider/SliderItem.js +75 -14
  143. package/molecules/Slider/SliderItem.js.map +2 -2
  144. package/molecules/Slider/SliderProgress.cjs +6 -0
  145. package/molecules/Slider/SliderProgress.cjs.map +2 -2
  146. package/molecules/Slider/SliderProgress.js +6 -0
  147. package/molecules/Slider/SliderProgress.js.map +2 -2
  148. package/molecules/Sticky/Sticky.cjs +56 -0
  149. package/molecules/Sticky/Sticky.cjs.map +2 -2
  150. package/molecules/Sticky/Sticky.js +56 -0
  151. package/molecules/Sticky/Sticky.js.map +2 -2
  152. package/molecules/TableOfContent/TableOfContent.cjs +13 -0
  153. package/molecules/TableOfContent/TableOfContent.cjs.map +1 -1
  154. package/molecules/TableOfContent/TableOfContent.js +13 -0
  155. package/molecules/TableOfContent/TableOfContent.js.map +1 -1
  156. package/molecules/TableOfContent/TableOfContentAnchor.cjs +16 -0
  157. package/molecules/TableOfContent/TableOfContentAnchor.cjs.map +2 -2
  158. package/molecules/TableOfContent/TableOfContentAnchor.js +16 -0
  159. package/molecules/TableOfContent/TableOfContentAnchor.js.map +2 -2
  160. package/molecules/Tabs/Tabs.cjs +16 -0
  161. package/molecules/Tabs/Tabs.cjs.map +2 -2
  162. package/molecules/Tabs/Tabs.d.ts +3 -3
  163. package/molecules/Tabs/Tabs.js +16 -0
  164. package/molecules/Tabs/Tabs.js.map +2 -2
  165. package/organisms/Frame/Frame.cjs +30 -0
  166. package/organisms/Frame/Frame.cjs.map +2 -2
  167. package/organisms/Frame/Frame.js +30 -0
  168. package/organisms/Frame/Frame.js.map +2 -2
  169. package/organisms/Frame/FrameAnchor.cjs +6 -0
  170. package/organisms/Frame/FrameAnchor.cjs.map +1 -1
  171. package/organisms/Frame/FrameAnchor.js +6 -0
  172. package/organisms/Frame/FrameAnchor.js.map +1 -1
  173. package/organisms/Frame/FrameForm.cjs +6 -0
  174. package/organisms/Frame/FrameForm.cjs.map +1 -1
  175. package/organisms/Frame/FrameForm.js +6 -0
  176. package/organisms/Frame/FrameForm.js.map +1 -1
  177. package/organisms/Frame/FrameTarget.cjs +25 -2
  178. package/organisms/Frame/FrameTarget.cjs.map +2 -2
  179. package/organisms/Frame/FrameTarget.d.ts +1 -1
  180. package/organisms/Frame/FrameTarget.js +25 -2
  181. package/organisms/Frame/FrameTarget.js.map +2 -2
  182. package/organisms/Hero/Hero.twig +151 -0
  183. package/package.json +2 -2
  184. package/primitives/Draggable/Draggable.cjs +18 -0
  185. package/primitives/Draggable/Draggable.cjs.map +2 -2
  186. package/primitives/Draggable/Draggable.js +18 -0
  187. package/primitives/Draggable/Draggable.js.map +2 -2
  188. package/primitives/Sentinel/Sentinel.cjs +3 -0
  189. package/primitives/Sentinel/Sentinel.cjs.map +2 -2
  190. package/primitives/Sentinel/Sentinel.js +3 -0
  191. package/primitives/Sentinel/Sentinel.js.map +2 -2
  192. package/primitives/Transition/Transition.cjs +3 -0
  193. package/primitives/Transition/Transition.cjs.map +1 -1
  194. package/primitives/Transition/Transition.js +3 -0
  195. package/primitives/Transition/Transition.js.map +1 -1
@@ -30,24 +30,48 @@ module.exports = __toCommonJS(Sticky_exports);
30
30
  var import_js_toolkit = require("@studiometa/js-toolkit");
31
31
  var import_primitives = require("../../primitives/index.cjs");
32
32
  var _Sticky = class extends import_js_toolkit.Base {
33
+ /**
34
+ * Is the component sticky?
35
+ */
33
36
  isSticky = false;
37
+ /**
38
+ * Is the component visible?
39
+ */
34
40
  isVisible = true;
41
+ /**
42
+ * Set the Y value.
43
+ */
35
44
  set y(value) {
36
45
  this.$refs.inner.style.transform = `translateY(${value}px) translateZ(0px)`;
37
46
  }
47
+ /**
48
+ * Get instances as array.
49
+ */
38
50
  get instances() {
39
51
  return Array.from(_Sticky.instances);
40
52
  }
53
+ /**
54
+ * Mounted hook.
55
+ */
41
56
  mounted() {
42
57
  _Sticky.instances.add(this);
43
58
  this.setSentinelSize();
44
59
  }
60
+ /**
61
+ * Resized hook.
62
+ */
45
63
  resized() {
46
64
  this.setSentinelSize();
47
65
  }
66
+ /**
67
+ * Destroyed hook.
68
+ */
48
69
  destroyed() {
49
70
  _Sticky.instances.delete(this);
50
71
  }
72
+ /**
73
+ * Scrolled hook.
74
+ */
51
75
  scrolled(props) {
52
76
  if (!this.isSticky || props.y === props.last.y) {
53
77
  return;
@@ -58,10 +82,19 @@ var _Sticky = class extends import_js_toolkit.Base {
58
82
  this.show();
59
83
  }
60
84
  }
85
+ /**
86
+ * Listen to the sentinel's `intersected` event to set the `isSticky` value.
87
+ *
88
+ * @param {IntersectionObserverEntry[]} entries
89
+ * @returns {void}
90
+ */
61
91
  onSentinelIntersected([entry]) {
62
92
  this.isSticky = entry.isIntersecting && entry.boundingClientRect.y < 0;
63
93
  this.setPosition();
64
94
  }
95
+ /**
96
+ * Hide the sticky component when another one is sticky.
97
+ */
65
98
  hide() {
66
99
  if (!this.isVisible) {
67
100
  return;
@@ -70,6 +103,9 @@ var _Sticky = class extends import_js_toolkit.Base {
70
103
  this.$el.classList.add("pointer-events-none");
71
104
  this.instances.forEach((instance, index) => instance.setPosition(index));
72
105
  }
106
+ /**
107
+ * Show the sticky component when the other one is not sticky anymore.
108
+ */
73
109
  show() {
74
110
  if (this.isVisible) {
75
111
  return;
@@ -78,16 +114,26 @@ var _Sticky = class extends import_js_toolkit.Base {
78
114
  this.$el.classList.remove("pointer-events-none");
79
115
  this.instances.forEach((instance, index) => instance.setPosition(index));
80
116
  }
117
+ /**
118
+ * Set the sentinel height based on the previous instances.
119
+ */
81
120
  setSentinelSize() {
82
121
  const { instances } = this;
83
122
  const index = instances.indexOf(this);
84
123
  const height = instances.slice(0, index).filter(
124
+ // Test each instance sticky context against the current element
85
125
  (instance) => this.closestRelativeElement(instance.$el).contains(this.$el)
86
126
  ).reduce((acc, instance) => acc + instance.$el.offsetHeight, 0);
87
127
  this.$refs.sentinelRef.style.height = `${height + 1}px`;
88
128
  this.$el.style.top = `${height}px`;
89
129
  this.$el.style.zIndex = String(this.$options.zIndex - index);
90
130
  }
131
+ /**
132
+ * Set the component's position.
133
+ *
134
+ * @param {number} [index] The instance index in all the pages' instances.
135
+ * @returns {void}
136
+ */
91
137
  setPosition(index) {
92
138
  if (!this.isSticky) {
93
139
  this.y = 0;
@@ -100,6 +146,9 @@ var _Sticky = class extends import_js_toolkit.Base {
100
146
  this.isVisible ? 0 : this.$refs.inner.offsetHeight * -1
101
147
  );
102
148
  }
149
+ /**
150
+ * Find the first parent which has a relative position.
151
+ */
103
152
  closestRelativeElement(element) {
104
153
  let parent = element.parentElement;
105
154
  while (getComputedStyle(parent).position !== "relative" && parent.parentElement) {
@@ -109,6 +158,9 @@ var _Sticky = class extends import_js_toolkit.Base {
109
158
  }
110
159
  };
111
160
  var Sticky = _Sticky;
161
+ /**
162
+ * Config.
163
+ */
112
164
  __publicField(Sticky, "config", {
113
165
  name: "Sticky",
114
166
  refs: ["inner", "sentinelRef"],
@@ -124,6 +176,10 @@ __publicField(Sticky, "config", {
124
176
  hideWhenDown: Boolean
125
177
  }
126
178
  });
179
+ /**
180
+ * Holder for all instances.
181
+ */
182
+ // eslint-disable-next-line no-use-before-define
127
183
  __publicField(Sticky, "instances", /* @__PURE__ */ new Set());
128
184
  if (module.exports.default) module.exports = module.exports.default;
129
185
  //# sourceMappingURL=Sticky.cjs.map
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../packages/ui/molecules/Sticky/Sticky.ts"],
4
- "sourcesContent": ["import { Base } from '@studiometa/js-toolkit';\nimport type { BaseProps, BaseConfig } from '@studiometa/js-toolkit';\nimport { Sentinel } from '../../primitives/index.js';\n\n/**\n * @typedef {Object} StickyRefs\n * @property {HTMLElement} inner\n * @property {HTMLElement} sentinelRef\n */\n\n/**\n * @typedef {Object} StickyPrivateInterface\n * @property {StickyRefs} $refs\n * @property {{ zIndex: number, hideWhenUp: boolean, hideWhenDown: boolean }} $options\n * @property {{ Sentinel: Sentinel[] }} $children\n */\n\nexport interface StickyProps extends BaseProps {\n $refs: {\n inner: HTMLElement;\n sentinelRef: HTMLElement;\n };\n $options: {\n zIndex: number;\n hideWhenUp: boolean;\n hideWhenDown: boolean;\n };\n $children: {\n Sentinel: Sentinel[];\n };\n}\n\n/**\n * Sticky class.\n */\nexport class Sticky<T extends BaseProps = BaseProps> extends Base<T & StickyProps> {\n /**\n * Config.\n */\n static config: BaseConfig = {\n name: 'Sticky',\n refs: ['inner', 'sentinelRef'],\n components: {\n Sentinel,\n },\n options: {\n zIndex: {\n type: Number,\n default: 100,\n },\n hideWhenUp: Boolean,\n hideWhenDown: Boolean,\n },\n };\n\n /**\n * Holder for all instances.\n */\n // eslint-disable-next-line no-use-before-define\n static instances: Set<Sticky> = new Set();\n\n /**\n * Is the component sticky?\n */\n isSticky = false;\n\n /**\n * Is the component visible?\n */\n isVisible = true;\n\n /**\n * Set the Y value.\n */\n set y(value: number) {\n this.$refs.inner.style.transform = `translateY(${value}px) translateZ(0px)`;\n }\n\n /**\n * Get instances as array.\n */\n get instances(): Sticky[] {\n return Array.from(Sticky.instances);\n }\n\n /**\n * Mounted hook.\n */\n mounted() {\n Sticky.instances.add(this);\n this.setSentinelSize();\n }\n\n /**\n * Resized hook.\n */\n resized() {\n this.setSentinelSize();\n }\n\n /**\n * Destroyed hook.\n */\n destroyed() {\n Sticky.instances.delete(this);\n }\n\n /**\n * Scrolled hook.\n */\n scrolled(props) {\n if (!this.isSticky || props.y === props.last.y) {\n return;\n }\n\n if (\n (props.direction.y === 'DOWN' && this.$options.hideWhenDown) ||\n (props.direction.y === 'UP' && this.$options.hideWhenUp)\n ) {\n this.hide();\n } else {\n this.show();\n }\n }\n\n /**\n * Listen to the sentinel's `intersected` event to set the `isSticky` value.\n *\n * @param {IntersectionObserverEntry[]} entries\n * @returns {void}\n */\n onSentinelIntersected([entry]: IntersectionObserverEntry[]) {\n this.isSticky = entry.isIntersecting && entry.boundingClientRect.y < 0;\n this.setPosition();\n }\n\n /**\n * Hide the sticky component when another one is sticky.\n */\n hide() {\n if (!this.isVisible) {\n return;\n }\n\n this.isVisible = false;\n this.$el.classList.add('pointer-events-none');\n\n this.instances.forEach((instance, index) => instance.setPosition(index));\n }\n\n /**\n * Show the sticky component when the other one is not sticky anymore.\n */\n show() {\n if (this.isVisible) {\n return;\n }\n\n this.isVisible = true;\n this.$el.classList.remove('pointer-events-none');\n this.instances.forEach((instance, index) => instance.setPosition(index));\n }\n\n /**\n * Set the sentinel height based on the previous instances.\n */\n setSentinelSize() {\n const { instances } = this;\n const index = instances.indexOf(this);\n const height = instances\n .slice(0, index)\n .filter(\n // Test each instance sticky context against the current element\n (instance) => this.closestRelativeElement(instance.$el).contains(this.$el),\n )\n .reduce((acc, instance) => acc + instance.$el.offsetHeight, 0);\n\n this.$refs.sentinelRef.style.height = `${height + 1}px`;\n this.$el.style.top = `${height}px`;\n this.$el.style.zIndex = String(this.$options.zIndex - index);\n }\n\n /**\n * Set the component's position.\n *\n * @param {number} [index] The instance index in all the pages' instances.\n * @returns {void}\n */\n setPosition(index?: number) {\n if (!this.isSticky) {\n this.y = 0;\n return;\n }\n\n const { instances } = this;\n\n // eslint-disable-next-line no-param-reassign\n index = index ?? instances.indexOf(this);\n\n this.y = (instances\n .slice(0, index)\n .filter((instance) => instance.isSticky && !instance.isVisible)\n .reduce<number>(\n (y: number, instance) => y - instance.$refs.inner.offsetHeight,\n this.isVisible ? 0 : this.$refs.inner.offsetHeight * -1,\n )) as number;\n }\n\n /**\n * Find the first parent which has a relative position.\n */\n closestRelativeElement(element:HTMLElement) {\n let parent = element.parentElement;\n\n while (getComputedStyle(parent).position !== 'relative' && parent.parentElement) {\n parent = parent.parentElement;\n }\n\n return parent;\n }\n}\n"],
5
- "mappings": "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",
4
+ "sourcesContent": ["import { Base } from '@studiometa/js-toolkit';\nimport type { BaseProps, BaseConfig } from '@studiometa/js-toolkit';\nimport { Sentinel } from '../../primitives/index.js';\n\n/**\n * @typedef {Object} StickyRefs\n * @property {HTMLElement} inner\n * @property {HTMLElement} sentinelRef\n */\n\n/**\n * @typedef {Object} StickyPrivateInterface\n * @property {StickyRefs} $refs\n * @property {{ zIndex: number, hideWhenUp: boolean, hideWhenDown: boolean }} $options\n * @property {{ Sentinel: Sentinel[] }} $children\n */\n\nexport interface StickyProps extends BaseProps {\n $refs: {\n inner: HTMLElement;\n sentinelRef: HTMLElement;\n };\n $options: {\n zIndex: number;\n hideWhenUp: boolean;\n hideWhenDown: boolean;\n };\n $children: {\n Sentinel: Sentinel[];\n };\n}\n\n/**\n * Sticky class.\n */\nexport class Sticky<T extends BaseProps = BaseProps> extends Base<T & StickyProps> {\n /**\n * Config.\n */\n static config: BaseConfig = {\n name: 'Sticky',\n refs: ['inner', 'sentinelRef'],\n components: {\n Sentinel,\n },\n options: {\n zIndex: {\n type: Number,\n default: 100,\n },\n hideWhenUp: Boolean,\n hideWhenDown: Boolean,\n },\n };\n\n /**\n * Holder for all instances.\n */\n // eslint-disable-next-line no-use-before-define\n static instances: Set<Sticky> = new Set();\n\n /**\n * Is the component sticky?\n */\n isSticky = false;\n\n /**\n * Is the component visible?\n */\n isVisible = true;\n\n /**\n * Set the Y value.\n */\n set y(value: number) {\n this.$refs.inner.style.transform = `translateY(${value}px) translateZ(0px)`;\n }\n\n /**\n * Get instances as array.\n */\n get instances(): Sticky[] {\n return Array.from(Sticky.instances);\n }\n\n /**\n * Mounted hook.\n */\n mounted() {\n Sticky.instances.add(this);\n this.setSentinelSize();\n }\n\n /**\n * Resized hook.\n */\n resized() {\n this.setSentinelSize();\n }\n\n /**\n * Destroyed hook.\n */\n destroyed() {\n Sticky.instances.delete(this);\n }\n\n /**\n * Scrolled hook.\n */\n scrolled(props) {\n if (!this.isSticky || props.y === props.last.y) {\n return;\n }\n\n if (\n (props.direction.y === 'DOWN' && this.$options.hideWhenDown) ||\n (props.direction.y === 'UP' && this.$options.hideWhenUp)\n ) {\n this.hide();\n } else {\n this.show();\n }\n }\n\n /**\n * Listen to the sentinel's `intersected` event to set the `isSticky` value.\n *\n * @param {IntersectionObserverEntry[]} entries\n * @returns {void}\n */\n onSentinelIntersected([entry]: IntersectionObserverEntry[]) {\n this.isSticky = entry.isIntersecting && entry.boundingClientRect.y < 0;\n this.setPosition();\n }\n\n /**\n * Hide the sticky component when another one is sticky.\n */\n hide() {\n if (!this.isVisible) {\n return;\n }\n\n this.isVisible = false;\n this.$el.classList.add('pointer-events-none');\n\n this.instances.forEach((instance, index) => instance.setPosition(index));\n }\n\n /**\n * Show the sticky component when the other one is not sticky anymore.\n */\n show() {\n if (this.isVisible) {\n return;\n }\n\n this.isVisible = true;\n this.$el.classList.remove('pointer-events-none');\n this.instances.forEach((instance, index) => instance.setPosition(index));\n }\n\n /**\n * Set the sentinel height based on the previous instances.\n */\n setSentinelSize() {\n const { instances } = this;\n const index = instances.indexOf(this);\n const height = instances\n .slice(0, index)\n .filter(\n // Test each instance sticky context against the current element\n (instance) => this.closestRelativeElement(instance.$el).contains(this.$el),\n )\n .reduce((acc, instance) => acc + instance.$el.offsetHeight, 0);\n\n this.$refs.sentinelRef.style.height = `${height + 1}px`;\n this.$el.style.top = `${height}px`;\n this.$el.style.zIndex = String(this.$options.zIndex - index);\n }\n\n /**\n * Set the component's position.\n *\n * @param {number} [index] The instance index in all the pages' instances.\n * @returns {void}\n */\n setPosition(index?: number) {\n if (!this.isSticky) {\n this.y = 0;\n return;\n }\n\n const { instances } = this;\n\n // eslint-disable-next-line no-param-reassign\n index = index ?? instances.indexOf(this);\n\n this.y = instances\n .slice(0, index)\n .filter((instance) => instance.isSticky && !instance.isVisible)\n .reduce<number>(\n (y: number, instance) => y - instance.$refs.inner.offsetHeight,\n this.isVisible ? 0 : this.$refs.inner.offsetHeight * -1,\n ) as number;\n }\n\n /**\n * Find the first parent which has a relative position.\n */\n closestRelativeElement(element: HTMLElement) {\n let parent = element.parentElement;\n\n while (getComputedStyle(parent).position !== 'relative' && parent.parentElement) {\n parent = parent.parentElement;\n }\n\n return parent;\n }\n}\n"],
5
+ "mappings": "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",
6
6
  "names": []
7
7
  }
@@ -1,6 +1,9 @@
1
1
  import { Base } from "@studiometa/js-toolkit";
2
2
  import { Sentinel } from "../../primitives/index.js";
3
3
  class Sticky extends Base {
4
+ /**
5
+ * Config.
6
+ */
4
7
  static config = {
5
8
  name: "Sticky",
6
9
  refs: ["inner", "sentinelRef"],
@@ -16,25 +19,53 @@ class Sticky extends Base {
16
19
  hideWhenDown: Boolean
17
20
  }
18
21
  };
22
+ /**
23
+ * Holder for all instances.
24
+ */
25
+ // eslint-disable-next-line no-use-before-define
19
26
  static instances = /* @__PURE__ */ new Set();
27
+ /**
28
+ * Is the component sticky?
29
+ */
20
30
  isSticky = false;
31
+ /**
32
+ * Is the component visible?
33
+ */
21
34
  isVisible = true;
35
+ /**
36
+ * Set the Y value.
37
+ */
22
38
  set y(value) {
23
39
  this.$refs.inner.style.transform = `translateY(${value}px) translateZ(0px)`;
24
40
  }
41
+ /**
42
+ * Get instances as array.
43
+ */
25
44
  get instances() {
26
45
  return Array.from(Sticky.instances);
27
46
  }
47
+ /**
48
+ * Mounted hook.
49
+ */
28
50
  mounted() {
29
51
  Sticky.instances.add(this);
30
52
  this.setSentinelSize();
31
53
  }
54
+ /**
55
+ * Resized hook.
56
+ */
32
57
  resized() {
33
58
  this.setSentinelSize();
34
59
  }
60
+ /**
61
+ * Destroyed hook.
62
+ */
35
63
  destroyed() {
36
64
  Sticky.instances.delete(this);
37
65
  }
66
+ /**
67
+ * Scrolled hook.
68
+ */
38
69
  scrolled(props) {
39
70
  if (!this.isSticky || props.y === props.last.y) {
40
71
  return;
@@ -45,10 +76,19 @@ class Sticky extends Base {
45
76
  this.show();
46
77
  }
47
78
  }
79
+ /**
80
+ * Listen to the sentinel's `intersected` event to set the `isSticky` value.
81
+ *
82
+ * @param {IntersectionObserverEntry[]} entries
83
+ * @returns {void}
84
+ */
48
85
  onSentinelIntersected([entry]) {
49
86
  this.isSticky = entry.isIntersecting && entry.boundingClientRect.y < 0;
50
87
  this.setPosition();
51
88
  }
89
+ /**
90
+ * Hide the sticky component when another one is sticky.
91
+ */
52
92
  hide() {
53
93
  if (!this.isVisible) {
54
94
  return;
@@ -57,6 +97,9 @@ class Sticky extends Base {
57
97
  this.$el.classList.add("pointer-events-none");
58
98
  this.instances.forEach((instance, index) => instance.setPosition(index));
59
99
  }
100
+ /**
101
+ * Show the sticky component when the other one is not sticky anymore.
102
+ */
60
103
  show() {
61
104
  if (this.isVisible) {
62
105
  return;
@@ -65,16 +108,26 @@ class Sticky extends Base {
65
108
  this.$el.classList.remove("pointer-events-none");
66
109
  this.instances.forEach((instance, index) => instance.setPosition(index));
67
110
  }
111
+ /**
112
+ * Set the sentinel height based on the previous instances.
113
+ */
68
114
  setSentinelSize() {
69
115
  const { instances } = this;
70
116
  const index = instances.indexOf(this);
71
117
  const height = instances.slice(0, index).filter(
118
+ // Test each instance sticky context against the current element
72
119
  (instance) => this.closestRelativeElement(instance.$el).contains(this.$el)
73
120
  ).reduce((acc, instance) => acc + instance.$el.offsetHeight, 0);
74
121
  this.$refs.sentinelRef.style.height = `${height + 1}px`;
75
122
  this.$el.style.top = `${height}px`;
76
123
  this.$el.style.zIndex = String(this.$options.zIndex - index);
77
124
  }
125
+ /**
126
+ * Set the component's position.
127
+ *
128
+ * @param {number} [index] The instance index in all the pages' instances.
129
+ * @returns {void}
130
+ */
78
131
  setPosition(index) {
79
132
  if (!this.isSticky) {
80
133
  this.y = 0;
@@ -87,6 +140,9 @@ class Sticky extends Base {
87
140
  this.isVisible ? 0 : this.$refs.inner.offsetHeight * -1
88
141
  );
89
142
  }
143
+ /**
144
+ * Find the first parent which has a relative position.
145
+ */
90
146
  closestRelativeElement(element) {
91
147
  let parent = element.parentElement;
92
148
  while (getComputedStyle(parent).position !== "relative" && parent.parentElement) {
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../packages/ui/molecules/Sticky/Sticky.ts"],
4
- "sourcesContent": ["import { Base } from '@studiometa/js-toolkit';\nimport type { BaseProps, BaseConfig } from '@studiometa/js-toolkit';\nimport { Sentinel } from '../../primitives/index.js';\n\n/**\n * @typedef {Object} StickyRefs\n * @property {HTMLElement} inner\n * @property {HTMLElement} sentinelRef\n */\n\n/**\n * @typedef {Object} StickyPrivateInterface\n * @property {StickyRefs} $refs\n * @property {{ zIndex: number, hideWhenUp: boolean, hideWhenDown: boolean }} $options\n * @property {{ Sentinel: Sentinel[] }} $children\n */\n\nexport interface StickyProps extends BaseProps {\n $refs: {\n inner: HTMLElement;\n sentinelRef: HTMLElement;\n };\n $options: {\n zIndex: number;\n hideWhenUp: boolean;\n hideWhenDown: boolean;\n };\n $children: {\n Sentinel: Sentinel[];\n };\n}\n\n/**\n * Sticky class.\n */\nexport class Sticky<T extends BaseProps = BaseProps> extends Base<T & StickyProps> {\n /**\n * Config.\n */\n static config: BaseConfig = {\n name: 'Sticky',\n refs: ['inner', 'sentinelRef'],\n components: {\n Sentinel,\n },\n options: {\n zIndex: {\n type: Number,\n default: 100,\n },\n hideWhenUp: Boolean,\n hideWhenDown: Boolean,\n },\n };\n\n /**\n * Holder for all instances.\n */\n // eslint-disable-next-line no-use-before-define\n static instances: Set<Sticky> = new Set();\n\n /**\n * Is the component sticky?\n */\n isSticky = false;\n\n /**\n * Is the component visible?\n */\n isVisible = true;\n\n /**\n * Set the Y value.\n */\n set y(value: number) {\n this.$refs.inner.style.transform = `translateY(${value}px) translateZ(0px)`;\n }\n\n /**\n * Get instances as array.\n */\n get instances(): Sticky[] {\n return Array.from(Sticky.instances);\n }\n\n /**\n * Mounted hook.\n */\n mounted() {\n Sticky.instances.add(this);\n this.setSentinelSize();\n }\n\n /**\n * Resized hook.\n */\n resized() {\n this.setSentinelSize();\n }\n\n /**\n * Destroyed hook.\n */\n destroyed() {\n Sticky.instances.delete(this);\n }\n\n /**\n * Scrolled hook.\n */\n scrolled(props) {\n if (!this.isSticky || props.y === props.last.y) {\n return;\n }\n\n if (\n (props.direction.y === 'DOWN' && this.$options.hideWhenDown) ||\n (props.direction.y === 'UP' && this.$options.hideWhenUp)\n ) {\n this.hide();\n } else {\n this.show();\n }\n }\n\n /**\n * Listen to the sentinel's `intersected` event to set the `isSticky` value.\n *\n * @param {IntersectionObserverEntry[]} entries\n * @returns {void}\n */\n onSentinelIntersected([entry]: IntersectionObserverEntry[]) {\n this.isSticky = entry.isIntersecting && entry.boundingClientRect.y < 0;\n this.setPosition();\n }\n\n /**\n * Hide the sticky component when another one is sticky.\n */\n hide() {\n if (!this.isVisible) {\n return;\n }\n\n this.isVisible = false;\n this.$el.classList.add('pointer-events-none');\n\n this.instances.forEach((instance, index) => instance.setPosition(index));\n }\n\n /**\n * Show the sticky component when the other one is not sticky anymore.\n */\n show() {\n if (this.isVisible) {\n return;\n }\n\n this.isVisible = true;\n this.$el.classList.remove('pointer-events-none');\n this.instances.forEach((instance, index) => instance.setPosition(index));\n }\n\n /**\n * Set the sentinel height based on the previous instances.\n */\n setSentinelSize() {\n const { instances } = this;\n const index = instances.indexOf(this);\n const height = instances\n .slice(0, index)\n .filter(\n // Test each instance sticky context against the current element\n (instance) => this.closestRelativeElement(instance.$el).contains(this.$el),\n )\n .reduce((acc, instance) => acc + instance.$el.offsetHeight, 0);\n\n this.$refs.sentinelRef.style.height = `${height + 1}px`;\n this.$el.style.top = `${height}px`;\n this.$el.style.zIndex = String(this.$options.zIndex - index);\n }\n\n /**\n * Set the component's position.\n *\n * @param {number} [index] The instance index in all the pages' instances.\n * @returns {void}\n */\n setPosition(index?: number) {\n if (!this.isSticky) {\n this.y = 0;\n return;\n }\n\n const { instances } = this;\n\n // eslint-disable-next-line no-param-reassign\n index = index ?? instances.indexOf(this);\n\n this.y = (instances\n .slice(0, index)\n .filter((instance) => instance.isSticky && !instance.isVisible)\n .reduce<number>(\n (y: number, instance) => y - instance.$refs.inner.offsetHeight,\n this.isVisible ? 0 : this.$refs.inner.offsetHeight * -1,\n )) as number;\n }\n\n /**\n * Find the first parent which has a relative position.\n */\n closestRelativeElement(element:HTMLElement) {\n let parent = element.parentElement;\n\n while (getComputedStyle(parent).position !== 'relative' && parent.parentElement) {\n parent = parent.parentElement;\n }\n\n return parent;\n }\n}\n"],
5
- "mappings": "AAAA,SAAS,YAAY;AAErB,SAAS,gBAAgB;AAiClB,MAAM,eAAgD,KAAsB;AAAA,EAIjF,OAAO,SAAqB;AAAA,IAC1B,MAAM;AAAA,IACN,MAAM,CAAC,SAAS,aAAa;AAAA,IAC7B,YAAY;AAAA,MACV;AAAA,IACF;AAAA,IACA,SAAS;AAAA,MACP,QAAQ;AAAA,QACN,MAAM;AAAA,QACN,SAAS;AAAA,MACX;AAAA,MACA,YAAY;AAAA,MACZ,cAAc;AAAA,IAChB;AAAA,EACF;AAAA,EAMA,OAAO,YAAyB,oBAAI,IAAI;AAAA,EAKxC,WAAW;AAAA,EAKX,YAAY;AAAA,EAKZ,IAAI,EAAE,OAAe;AACnB,SAAK,MAAM,MAAM,MAAM,YAAY,cAAc;AAAA,EACnD;AAAA,EAKA,IAAI,YAAsB;AACxB,WAAO,MAAM,KAAK,OAAO,SAAS;AAAA,EACpC;AAAA,EAKA,UAAU;AACR,WAAO,UAAU,IAAI,IAAI;AACzB,SAAK,gBAAgB;AAAA,EACvB;AAAA,EAKA,UAAU;AACR,SAAK,gBAAgB;AAAA,EACvB;AAAA,EAKA,YAAY;AACV,WAAO,UAAU,OAAO,IAAI;AAAA,EAC9B;AAAA,EAKA,SAAS,OAAO;AACd,QAAI,CAAC,KAAK,YAAY,MAAM,MAAM,MAAM,KAAK,GAAG;AAC9C;AAAA,IACF;AAEA,QACG,MAAM,UAAU,MAAM,UAAU,KAAK,SAAS,gBAC9C,MAAM,UAAU,MAAM,QAAQ,KAAK,SAAS,YAC7C;AACA,WAAK,KAAK;AAAA,IACZ,OAAO;AACL,WAAK,KAAK;AAAA,IACZ;AAAA,EACF;AAAA,EAQA,sBAAsB,CAAC,KAAK,GAAgC;AAC1D,SAAK,WAAW,MAAM,kBAAkB,MAAM,mBAAmB,IAAI;AACrE,SAAK,YAAY;AAAA,EACnB;AAAA,EAKA,OAAO;AACL,QAAI,CAAC,KAAK,WAAW;AACnB;AAAA,IACF;AAEA,SAAK,YAAY;AACjB,SAAK,IAAI,UAAU,IAAI,qBAAqB;AAE5C,SAAK,UAAU,QAAQ,CAAC,UAAU,UAAU,SAAS,YAAY,KAAK,CAAC;AAAA,EACzE;AAAA,EAKA,OAAO;AACL,QAAI,KAAK,WAAW;AAClB;AAAA,IACF;AAEA,SAAK,YAAY;AACjB,SAAK,IAAI,UAAU,OAAO,qBAAqB;AAC/C,SAAK,UAAU,QAAQ,CAAC,UAAU,UAAU,SAAS,YAAY,KAAK,CAAC;AAAA,EACzE;AAAA,EAKA,kBAAkB;AAChB,UAAM,EAAE,UAAU,IAAI;AACtB,UAAM,QAAQ,UAAU,QAAQ,IAAI;AACpC,UAAM,SAAS,UACZ,MAAM,GAAG,KAAK,EACd;AAAA,MAEC,CAAC,aAAa,KAAK,uBAAuB,SAAS,GAAG,EAAE,SAAS,KAAK,GAAG;AAAA,IAC3E,EACC,OAAO,CAAC,KAAK,aAAa,MAAM,SAAS,IAAI,cAAc,CAAC;AAE/D,SAAK,MAAM,YAAY,MAAM,SAAS,GAAG,SAAS;AAClD,SAAK,IAAI,MAAM,MAAM,GAAG;AACxB,SAAK,IAAI,MAAM,SAAS,OAAO,KAAK,SAAS,SAAS,KAAK;AAAA,EAC7D;AAAA,EAQA,YAAY,OAAgB;AAC1B,QAAI,CAAC,KAAK,UAAU;AAClB,WAAK,IAAI;AACT;AAAA,IACF;AAEA,UAAM,EAAE,UAAU,IAAI;AAGtB,YAAQ,SAAS,UAAU,QAAQ,IAAI;AAEvC,SAAK,IAAK,UACP,MAAM,GAAG,KAAK,EACd,OAAO,CAAC,aAAa,SAAS,YAAY,CAAC,SAAS,SAAS,EAC7D;AAAA,MACC,CAAC,GAAW,aAAa,IAAI,SAAS,MAAM,MAAM;AAAA,MAClD,KAAK,YAAY,IAAI,KAAK,MAAM,MAAM,eAAe;AAAA,IACvD;AAAA,EACJ;AAAA,EAKA,uBAAuB,SAAqB;AAC1C,QAAI,SAAS,QAAQ;AAErB,WAAO,iBAAiB,MAAM,EAAE,aAAa,cAAc,OAAO,eAAe;AAC/E,eAAS,OAAO;AAAA,IAClB;AAEA,WAAO;AAAA,EACT;AACF;",
4
+ "sourcesContent": ["import { Base } from '@studiometa/js-toolkit';\nimport type { BaseProps, BaseConfig } from '@studiometa/js-toolkit';\nimport { Sentinel } from '../../primitives/index.js';\n\n/**\n * @typedef {Object} StickyRefs\n * @property {HTMLElement} inner\n * @property {HTMLElement} sentinelRef\n */\n\n/**\n * @typedef {Object} StickyPrivateInterface\n * @property {StickyRefs} $refs\n * @property {{ zIndex: number, hideWhenUp: boolean, hideWhenDown: boolean }} $options\n * @property {{ Sentinel: Sentinel[] }} $children\n */\n\nexport interface StickyProps extends BaseProps {\n $refs: {\n inner: HTMLElement;\n sentinelRef: HTMLElement;\n };\n $options: {\n zIndex: number;\n hideWhenUp: boolean;\n hideWhenDown: boolean;\n };\n $children: {\n Sentinel: Sentinel[];\n };\n}\n\n/**\n * Sticky class.\n */\nexport class Sticky<T extends BaseProps = BaseProps> extends Base<T & StickyProps> {\n /**\n * Config.\n */\n static config: BaseConfig = {\n name: 'Sticky',\n refs: ['inner', 'sentinelRef'],\n components: {\n Sentinel,\n },\n options: {\n zIndex: {\n type: Number,\n default: 100,\n },\n hideWhenUp: Boolean,\n hideWhenDown: Boolean,\n },\n };\n\n /**\n * Holder for all instances.\n */\n // eslint-disable-next-line no-use-before-define\n static instances: Set<Sticky> = new Set();\n\n /**\n * Is the component sticky?\n */\n isSticky = false;\n\n /**\n * Is the component visible?\n */\n isVisible = true;\n\n /**\n * Set the Y value.\n */\n set y(value: number) {\n this.$refs.inner.style.transform = `translateY(${value}px) translateZ(0px)`;\n }\n\n /**\n * Get instances as array.\n */\n get instances(): Sticky[] {\n return Array.from(Sticky.instances);\n }\n\n /**\n * Mounted hook.\n */\n mounted() {\n Sticky.instances.add(this);\n this.setSentinelSize();\n }\n\n /**\n * Resized hook.\n */\n resized() {\n this.setSentinelSize();\n }\n\n /**\n * Destroyed hook.\n */\n destroyed() {\n Sticky.instances.delete(this);\n }\n\n /**\n * Scrolled hook.\n */\n scrolled(props) {\n if (!this.isSticky || props.y === props.last.y) {\n return;\n }\n\n if (\n (props.direction.y === 'DOWN' && this.$options.hideWhenDown) ||\n (props.direction.y === 'UP' && this.$options.hideWhenUp)\n ) {\n this.hide();\n } else {\n this.show();\n }\n }\n\n /**\n * Listen to the sentinel's `intersected` event to set the `isSticky` value.\n *\n * @param {IntersectionObserverEntry[]} entries\n * @returns {void}\n */\n onSentinelIntersected([entry]: IntersectionObserverEntry[]) {\n this.isSticky = entry.isIntersecting && entry.boundingClientRect.y < 0;\n this.setPosition();\n }\n\n /**\n * Hide the sticky component when another one is sticky.\n */\n hide() {\n if (!this.isVisible) {\n return;\n }\n\n this.isVisible = false;\n this.$el.classList.add('pointer-events-none');\n\n this.instances.forEach((instance, index) => instance.setPosition(index));\n }\n\n /**\n * Show the sticky component when the other one is not sticky anymore.\n */\n show() {\n if (this.isVisible) {\n return;\n }\n\n this.isVisible = true;\n this.$el.classList.remove('pointer-events-none');\n this.instances.forEach((instance, index) => instance.setPosition(index));\n }\n\n /**\n * Set the sentinel height based on the previous instances.\n */\n setSentinelSize() {\n const { instances } = this;\n const index = instances.indexOf(this);\n const height = instances\n .slice(0, index)\n .filter(\n // Test each instance sticky context against the current element\n (instance) => this.closestRelativeElement(instance.$el).contains(this.$el),\n )\n .reduce((acc, instance) => acc + instance.$el.offsetHeight, 0);\n\n this.$refs.sentinelRef.style.height = `${height + 1}px`;\n this.$el.style.top = `${height}px`;\n this.$el.style.zIndex = String(this.$options.zIndex - index);\n }\n\n /**\n * Set the component's position.\n *\n * @param {number} [index] The instance index in all the pages' instances.\n * @returns {void}\n */\n setPosition(index?: number) {\n if (!this.isSticky) {\n this.y = 0;\n return;\n }\n\n const { instances } = this;\n\n // eslint-disable-next-line no-param-reassign\n index = index ?? instances.indexOf(this);\n\n this.y = instances\n .slice(0, index)\n .filter((instance) => instance.isSticky && !instance.isVisible)\n .reduce<number>(\n (y: number, instance) => y - instance.$refs.inner.offsetHeight,\n this.isVisible ? 0 : this.$refs.inner.offsetHeight * -1,\n ) as number;\n }\n\n /**\n * Find the first parent which has a relative position.\n */\n closestRelativeElement(element: HTMLElement) {\n let parent = element.parentElement;\n\n while (getComputedStyle(parent).position !== 'relative' && parent.parentElement) {\n parent = parent.parentElement;\n }\n\n return parent;\n }\n}\n"],
5
+ "mappings": "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",
6
6
  "names": []
7
7
  }
@@ -30,12 +30,22 @@ module.exports = __toCommonJS(TableOfContent_exports);
30
30
  var import_js_toolkit = require("@studiometa/js-toolkit");
31
31
  var import_TableOfContentAnchor = require("./TableOfContentAnchor.cjs");
32
32
  var TableOfContent = class extends import_js_toolkit.Base {
33
+ /**
34
+ * Generate anchors on mount and update the component to instantiate the
35
+ * `TableOfContentAnchor` components.
36
+ */
33
37
  mounted() {
34
38
  if (this.$options.withTemplate) {
35
39
  this.generateAnchors();
36
40
  this.$update();
37
41
  }
38
42
  }
43
+ /**
44
+ * Generate all anchors.
45
+ *
46
+ * @todo Read anchor template from a ref?
47
+ * @todo Better API to easily override the template function, maybe a `render` function?
48
+ */
39
49
  generateAnchors() {
40
50
  document.querySelectorAll(this.$options.contentSelector).forEach((section) => {
41
51
  const tpl = document.createElement("div");
@@ -49,6 +59,9 @@ var TableOfContent = class extends import_js_toolkit.Base {
49
59
  });
50
60
  }
51
61
  };
62
+ /**
63
+ * Config.
64
+ */
52
65
  __publicField(TableOfContent, "config", {
53
66
  name: "TableOfContent",
54
67
  refs: ["itemTemplate", "list"],
@@ -2,6 +2,6 @@
2
2
  "version": 3,
3
3
  "sources": ["../../../packages/ui/molecules/TableOfContent/TableOfContent.ts"],
4
4
  "sourcesContent": ["import { Base } from '@studiometa/js-toolkit';\nimport type { BaseProps, BaseConfig } from '@studiometa/js-toolkit';\nimport { TableOfContentAnchor } from './TableOfContentAnchor.js';\n\nexport interface TableOfContentProps extends BaseProps {\n $refs: {\n itemTemplate: HTMLTemplateElement;\n list: HTMLUListElement;\n };\n $options: {\n contentSelector: string;\n withTemplate: boolean;\n };\n $children: {\n TableOfContentAnchor: TableOfContentAnchor[];\n };\n}\n\n/**\n * TableOfContent class.\n */\nexport class TableOfContent<T extends BaseProps = BaseProps> extends Base<T & TableOfContentProps> {\n /**\n * Config.\n */\n static config: BaseConfig = {\n name: 'TableOfContent',\n refs: ['itemTemplate', 'list'],\n components: {\n TableOfContentAnchor,\n },\n options: {\n contentSelector: String,\n withTemplate: Boolean,\n },\n };\n\n /**\n * Generate anchors on mount and update the component to instantiate the\n * `TableOfContentAnchor` components.\n */\n mounted() {\n if (this.$options.withTemplate) {\n this.generateAnchors();\n this.$update();\n }\n }\n\n /**\n * Generate all anchors.\n *\n * @todo Read anchor template from a ref?\n * @todo Better API to easily override the template function, maybe a `render` function?\n */\n generateAnchors() {\n document.querySelectorAll(this.$options.contentSelector).forEach((section) => {\n const tpl = document.createElement('div');\n tpl.innerHTML = this.$refs.itemTemplate.innerHTML;\n const li = tpl.querySelector('li');\n const anchor = li.querySelector('a');\n anchor.href = `#${section.id}`;\n anchor.innerHTML = section.textContent;\n anchor.dataset.component = 'TableOfContentAnchor';\n this.$refs.list.append(li);\n });\n }\n}\n"],
5
- "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,wBAAqB;AAErB,kCAAqC;AAmB9B,IAAM,iBAAN,cAA8D,uBAA8B;AAAA,EAoBjG,UAAU;AACR,QAAI,KAAK,SAAS,cAAc;AAC9B,WAAK,gBAAgB;AACrB,WAAK,QAAQ;AAAA,IACf;AAAA,EACF;AAAA,EAQA,kBAAkB;AAChB,aAAS,iBAAiB,KAAK,SAAS,eAAe,EAAE,QAAQ,CAAC,YAAY;AAC5E,YAAM,MAAM,SAAS,cAAc,KAAK;AACxC,UAAI,YAAY,KAAK,MAAM,aAAa;AACxC,YAAM,KAAK,IAAI,cAAc,IAAI;AACjC,YAAM,SAAS,GAAG,cAAc,GAAG;AACnC,aAAO,OAAO,IAAI,QAAQ;AAC1B,aAAO,YAAY,QAAQ;AAC3B,aAAO,QAAQ,YAAY;AAC3B,WAAK,MAAM,KAAK,OAAO,EAAE;AAAA,IAC3B,CAAC;AAAA,EACH;AACF;AAzCE,cAJW,gBAIJ,UAAqB;AAAA,EAC1B,MAAM;AAAA,EACN,MAAM,CAAC,gBAAgB,MAAM;AAAA,EAC7B,YAAY;AAAA,IACV;AAAA,EACF;AAAA,EACA,SAAS;AAAA,IACP,iBAAiB;AAAA,IACjB,cAAc;AAAA,EAChB;AACF;",
5
+ "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,wBAAqB;AAErB,kCAAqC;AAmB9B,IAAM,iBAAN,cAA8D,uBAA8B;AAAA;AAAA;AAAA;AAAA;AAAA,EAoBjG,UAAU;AACR,QAAI,KAAK,SAAS,cAAc;AAC9B,WAAK,gBAAgB;AACrB,WAAK,QAAQ;AAAA,IACf;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,kBAAkB;AAChB,aAAS,iBAAiB,KAAK,SAAS,eAAe,EAAE,QAAQ,CAAC,YAAY;AAC5E,YAAM,MAAM,SAAS,cAAc,KAAK;AACxC,UAAI,YAAY,KAAK,MAAM,aAAa;AACxC,YAAM,KAAK,IAAI,cAAc,IAAI;AACjC,YAAM,SAAS,GAAG,cAAc,GAAG;AACnC,aAAO,OAAO,IAAI,QAAQ;AAC1B,aAAO,YAAY,QAAQ;AAC3B,aAAO,QAAQ,YAAY;AAC3B,WAAK,MAAM,KAAK,OAAO,EAAE;AAAA,IAC3B,CAAC;AAAA,EACH;AACF;AAAA;AAAA;AAAA;AAzCE,cAJW,gBAIJ,UAAqB;AAAA,EAC1B,MAAM;AAAA,EACN,MAAM,CAAC,gBAAgB,MAAM;AAAA,EAC7B,YAAY;AAAA,IACV;AAAA,EACF;AAAA,EACA,SAAS;AAAA,IACP,iBAAiB;AAAA,IACjB,cAAc;AAAA,EAChB;AACF;",
6
6
  "names": []
7
7
  }
@@ -1,6 +1,9 @@
1
1
  import { Base } from "@studiometa/js-toolkit";
2
2
  import { TableOfContentAnchor } from "./TableOfContentAnchor.js";
3
3
  class TableOfContent extends Base {
4
+ /**
5
+ * Config.
6
+ */
4
7
  static config = {
5
8
  name: "TableOfContent",
6
9
  refs: ["itemTemplate", "list"],
@@ -12,12 +15,22 @@ class TableOfContent extends Base {
12
15
  withTemplate: Boolean
13
16
  }
14
17
  };
18
+ /**
19
+ * Generate anchors on mount and update the component to instantiate the
20
+ * `TableOfContentAnchor` components.
21
+ */
15
22
  mounted() {
16
23
  if (this.$options.withTemplate) {
17
24
  this.generateAnchors();
18
25
  this.$update();
19
26
  }
20
27
  }
28
+ /**
29
+ * Generate all anchors.
30
+ *
31
+ * @todo Read anchor template from a ref?
32
+ * @todo Better API to easily override the template function, maybe a `render` function?
33
+ */
21
34
  generateAnchors() {
22
35
  document.querySelectorAll(this.$options.contentSelector).forEach((section) => {
23
36
  const tpl = document.createElement("div");
@@ -2,6 +2,6 @@
2
2
  "version": 3,
3
3
  "sources": ["../../../packages/ui/molecules/TableOfContent/TableOfContent.ts"],
4
4
  "sourcesContent": ["import { Base } from '@studiometa/js-toolkit';\nimport type { BaseProps, BaseConfig } from '@studiometa/js-toolkit';\nimport { TableOfContentAnchor } from './TableOfContentAnchor.js';\n\nexport interface TableOfContentProps extends BaseProps {\n $refs: {\n itemTemplate: HTMLTemplateElement;\n list: HTMLUListElement;\n };\n $options: {\n contentSelector: string;\n withTemplate: boolean;\n };\n $children: {\n TableOfContentAnchor: TableOfContentAnchor[];\n };\n}\n\n/**\n * TableOfContent class.\n */\nexport class TableOfContent<T extends BaseProps = BaseProps> extends Base<T & TableOfContentProps> {\n /**\n * Config.\n */\n static config: BaseConfig = {\n name: 'TableOfContent',\n refs: ['itemTemplate', 'list'],\n components: {\n TableOfContentAnchor,\n },\n options: {\n contentSelector: String,\n withTemplate: Boolean,\n },\n };\n\n /**\n * Generate anchors on mount and update the component to instantiate the\n * `TableOfContentAnchor` components.\n */\n mounted() {\n if (this.$options.withTemplate) {\n this.generateAnchors();\n this.$update();\n }\n }\n\n /**\n * Generate all anchors.\n *\n * @todo Read anchor template from a ref?\n * @todo Better API to easily override the template function, maybe a `render` function?\n */\n generateAnchors() {\n document.querySelectorAll(this.$options.contentSelector).forEach((section) => {\n const tpl = document.createElement('div');\n tpl.innerHTML = this.$refs.itemTemplate.innerHTML;\n const li = tpl.querySelector('li');\n const anchor = li.querySelector('a');\n anchor.href = `#${section.id}`;\n anchor.innerHTML = section.textContent;\n anchor.dataset.component = 'TableOfContentAnchor';\n this.$refs.list.append(li);\n });\n }\n}\n"],
5
- "mappings": "AAAA,SAAS,YAAY;AAErB,SAAS,4BAA4B;AAmB9B,MAAM,uBAAwD,KAA8B;AAAA,EAIjG,OAAO,SAAqB;AAAA,IAC1B,MAAM;AAAA,IACN,MAAM,CAAC,gBAAgB,MAAM;AAAA,IAC7B,YAAY;AAAA,MACV;AAAA,IACF;AAAA,IACA,SAAS;AAAA,MACP,iBAAiB;AAAA,MACjB,cAAc;AAAA,IAChB;AAAA,EACF;AAAA,EAMA,UAAU;AACR,QAAI,KAAK,SAAS,cAAc;AAC9B,WAAK,gBAAgB;AACrB,WAAK,QAAQ;AAAA,IACf;AAAA,EACF;AAAA,EAQA,kBAAkB;AAChB,aAAS,iBAAiB,KAAK,SAAS,eAAe,EAAE,QAAQ,CAAC,YAAY;AAC5E,YAAM,MAAM,SAAS,cAAc,KAAK;AACxC,UAAI,YAAY,KAAK,MAAM,aAAa;AACxC,YAAM,KAAK,IAAI,cAAc,IAAI;AACjC,YAAM,SAAS,GAAG,cAAc,GAAG;AACnC,aAAO,OAAO,IAAI,QAAQ;AAC1B,aAAO,YAAY,QAAQ;AAC3B,aAAO,QAAQ,YAAY;AAC3B,WAAK,MAAM,KAAK,OAAO,EAAE;AAAA,IAC3B,CAAC;AAAA,EACH;AACF;",
5
+ "mappings": "AAAA,SAAS,YAAY;AAErB,SAAS,4BAA4B;AAmB9B,MAAM,uBAAwD,KAA8B;AAAA;AAAA;AAAA;AAAA,EAIjG,OAAO,SAAqB;AAAA,IAC1B,MAAM;AAAA,IACN,MAAM,CAAC,gBAAgB,MAAM;AAAA,IAC7B,YAAY;AAAA,MACV;AAAA,IACF;AAAA,IACA,SAAS;AAAA,MACP,iBAAiB;AAAA,MACjB,cAAc;AAAA,IAChB;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,UAAU;AACR,QAAI,KAAK,SAAS,cAAc;AAC9B,WAAK,gBAAgB;AACrB,WAAK,QAAQ;AAAA,IACf;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,kBAAkB;AAChB,aAAS,iBAAiB,KAAK,SAAS,eAAe,EAAE,QAAQ,CAAC,YAAY;AAC5E,YAAM,MAAM,SAAS,cAAc,KAAK;AACxC,UAAI,YAAY,KAAK,MAAM,aAAa;AACxC,YAAM,KAAK,IAAI,cAAc,IAAI;AACjC,YAAM,SAAS,GAAG,cAAc,GAAG;AACnC,aAAO,OAAO,IAAI,QAAQ;AAC1B,aAAO,YAAY,QAAQ;AAC3B,aAAO,QAAQ,YAAY;AAC3B,WAAK,MAAM,KAAK,OAAO,EAAE;AAAA,IAC3B,CAAC;AAAA,EACH;AACF;",
6
6
  "names": []
7
7
  }
@@ -29,10 +29,20 @@ __export(TableOfContentAnchor_exports, {
29
29
  module.exports = __toCommonJS(TableOfContentAnchor_exports);
30
30
  var import_atoms = require("../../atoms/index.cjs");
31
31
  var TableOfContentAnchor = class extends import_atoms.AnchorScrollTo {
32
+ /**
33
+ * Observer.
34
+ * @private
35
+ */
32
36
  __observer;
37
+ /**
38
+ * Get the sentinel.
39
+ */
33
40
  get sentinel() {
34
41
  return document.querySelector(this.targetSelector);
35
42
  }
43
+ /**
44
+ * Init observer on mount.
45
+ */
36
46
  mounted() {
37
47
  if (!this.sentinel) {
38
48
  return;
@@ -44,10 +54,16 @@ var TableOfContentAnchor = class extends import_atoms.AnchorScrollTo {
44
54
  });
45
55
  this.__observer.observe(this.sentinel);
46
56
  }
57
+ /**
58
+ * Destroy observer on destroy.
59
+ */
47
60
  destroyed() {
48
61
  this.__observer.disconnect();
49
62
  }
50
63
  };
64
+ /**
65
+ * Config.
66
+ */
51
67
  __publicField(TableOfContentAnchor, "config", {
52
68
  name: "TableOfContentAnchor",
53
69
  emits: ["should-activate"],
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../packages/ui/molecules/TableOfContent/TableOfContentAnchor.ts"],
4
- "sourcesContent": ["import type { BaseProps, BaseConfig } from '@studiometa/js-toolkit';\nimport { AnchorScrollTo } from '../../atoms/index.js';\n\nexport interface TableOfContentAnchorProps extends BaseProps {\n $options: {\n activeClass: string;\n };\n}\n\n/**\n * TableOfContentAnchor class.\n */\nexport class TableOfContentAnchor<T extends BaseProps = BaseProps> extends AnchorScrollTo<\n T & TableOfContentAnchorProps\n> {\n /**\n * Config.\n */\n static config: BaseConfig = {\n name: 'TableOfContentAnchor',\n emits: ['should-activate'],\n options: {\n activeClass: {\n type: String,\n default: 'is-active',\n },\n },\n };\n\n /**\n * Observer.\n * @private\n */\n __observer: IntersectionObserver;\n\n /**\n * Get the sentinel.\n */\n get sentinel():HTMLElement {\n return document.querySelector(this.targetSelector) as HTMLElement;\n }\n\n /**\n * Init observer on mount.\n */\n mounted() {\n if (!this.sentinel) {\n return;\n }\n\n this.__observer = new IntersectionObserver(([entry]) => {\n const shouldActivate =\n entry.isIntersecting &&\n entry.boundingClientRect.y < 100 &&\n entry.boundingClientRect.y > 100;\n this.$el.classList.toggle(this.$options.activeClass, shouldActivate);\n this.$emit('should-activate', shouldActivate);\n });\n\n this.__observer.observe(this.sentinel);\n }\n\n /**\n * Destroy observer on destroy.\n */\n destroyed() {\n this.__observer.disconnect();\n }\n}\n"],
5
- "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AACA,mBAA+B;AAWxB,IAAM,uBAAN,cAAoE,4BAEzE;AAAA,EAmBA;AAAA,EAKA,IAAI,WAAuB;AACzB,WAAO,SAAS,cAAc,KAAK,cAAc;AAAA,EACnD;AAAA,EAKA,UAAU;AACR,QAAI,CAAC,KAAK,UAAU;AAClB;AAAA,IACF;AAEA,SAAK,aAAa,IAAI,qBAAqB,CAAC,CAAC,KAAK,MAAM;AACtD,YAAM,iBACJ,MAAM,kBACN,MAAM,mBAAmB,IAAI,OAC7B,MAAM,mBAAmB,IAAI;AAC/B,WAAK,IAAI,UAAU,OAAO,KAAK,SAAS,aAAa,cAAc;AACnE,WAAK,MAAM,mBAAmB,cAAc;AAAA,IAC9C,CAAC;AAED,SAAK,WAAW,QAAQ,KAAK,QAAQ;AAAA,EACvC;AAAA,EAKA,YAAY;AACV,SAAK,WAAW,WAAW;AAAA,EAC7B;AACF;AAlDE,cANW,sBAMJ,UAAqB;AAAA,EAC1B,MAAM;AAAA,EACN,OAAO,CAAC,iBAAiB;AAAA,EACzB,SAAS;AAAA,IACP,aAAa;AAAA,MACX,MAAM;AAAA,MACN,SAAS;AAAA,IACX;AAAA,EACF;AACF;",
4
+ "sourcesContent": ["import type { BaseProps, BaseConfig } from '@studiometa/js-toolkit';\nimport { AnchorScrollTo } from '../../atoms/index.js';\n\nexport interface TableOfContentAnchorProps extends BaseProps {\n $options: {\n activeClass: string;\n };\n}\n\n/**\n * TableOfContentAnchor class.\n */\nexport class TableOfContentAnchor<T extends BaseProps = BaseProps> extends AnchorScrollTo<\n T & TableOfContentAnchorProps\n> {\n /**\n * Config.\n */\n static config: BaseConfig = {\n name: 'TableOfContentAnchor',\n emits: ['should-activate'],\n options: {\n activeClass: {\n type: String,\n default: 'is-active',\n },\n },\n };\n\n /**\n * Observer.\n * @private\n */\n __observer: IntersectionObserver;\n\n /**\n * Get the sentinel.\n */\n get sentinel(): HTMLElement {\n return document.querySelector(this.targetSelector) as HTMLElement;\n }\n\n /**\n * Init observer on mount.\n */\n mounted() {\n if (!this.sentinel) {\n return;\n }\n\n this.__observer = new IntersectionObserver(([entry]) => {\n const shouldActivate =\n entry.isIntersecting &&\n entry.boundingClientRect.y < 100 &&\n entry.boundingClientRect.y > 100;\n this.$el.classList.toggle(this.$options.activeClass, shouldActivate);\n this.$emit('should-activate', shouldActivate);\n });\n\n this.__observer.observe(this.sentinel);\n }\n\n /**\n * Destroy observer on destroy.\n */\n destroyed() {\n this.__observer.disconnect();\n }\n}\n"],
5
+ "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AACA,mBAA+B;AAWxB,IAAM,uBAAN,cAAoE,4BAEzE;AAAA;AAAA;AAAA;AAAA;AAAA,EAmBA;AAAA;AAAA;AAAA;AAAA,EAKA,IAAI,WAAwB;AAC1B,WAAO,SAAS,cAAc,KAAK,cAAc;AAAA,EACnD;AAAA;AAAA;AAAA;AAAA,EAKA,UAAU;AACR,QAAI,CAAC,KAAK,UAAU;AAClB;AAAA,IACF;AAEA,SAAK,aAAa,IAAI,qBAAqB,CAAC,CAAC,KAAK,MAAM;AACtD,YAAM,iBACJ,MAAM,kBACN,MAAM,mBAAmB,IAAI,OAC7B,MAAM,mBAAmB,IAAI;AAC/B,WAAK,IAAI,UAAU,OAAO,KAAK,SAAS,aAAa,cAAc;AACnE,WAAK,MAAM,mBAAmB,cAAc;AAAA,IAC9C,CAAC;AAED,SAAK,WAAW,QAAQ,KAAK,QAAQ;AAAA,EACvC;AAAA;AAAA;AAAA;AAAA,EAKA,YAAY;AACV,SAAK,WAAW,WAAW;AAAA,EAC7B;AACF;AAAA;AAAA;AAAA;AAlDE,cANW,sBAMJ,UAAqB;AAAA,EAC1B,MAAM;AAAA,EACN,OAAO,CAAC,iBAAiB;AAAA,EACzB,SAAS;AAAA,IACP,aAAa;AAAA,MACX,MAAM;AAAA,MACN,SAAS;AAAA,IACX;AAAA,EACF;AACF;",
6
6
  "names": []
7
7
  }
@@ -1,5 +1,8 @@
1
1
  import { AnchorScrollTo } from "../../atoms/index.js";
2
2
  class TableOfContentAnchor extends AnchorScrollTo {
3
+ /**
4
+ * Config.
5
+ */
3
6
  static config = {
4
7
  name: "TableOfContentAnchor",
5
8
  emits: ["should-activate"],
@@ -10,10 +13,20 @@ class TableOfContentAnchor extends AnchorScrollTo {
10
13
  }
11
14
  }
12
15
  };
16
+ /**
17
+ * Observer.
18
+ * @private
19
+ */
13
20
  __observer;
21
+ /**
22
+ * Get the sentinel.
23
+ */
14
24
  get sentinel() {
15
25
  return document.querySelector(this.targetSelector);
16
26
  }
27
+ /**
28
+ * Init observer on mount.
29
+ */
17
30
  mounted() {
18
31
  if (!this.sentinel) {
19
32
  return;
@@ -25,6 +38,9 @@ class TableOfContentAnchor extends AnchorScrollTo {
25
38
  });
26
39
  this.__observer.observe(this.sentinel);
27
40
  }
41
+ /**
42
+ * Destroy observer on destroy.
43
+ */
28
44
  destroyed() {
29
45
  this.__observer.disconnect();
30
46
  }
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../packages/ui/molecules/TableOfContent/TableOfContentAnchor.ts"],
4
- "sourcesContent": ["import type { BaseProps, BaseConfig } from '@studiometa/js-toolkit';\nimport { AnchorScrollTo } from '../../atoms/index.js';\n\nexport interface TableOfContentAnchorProps extends BaseProps {\n $options: {\n activeClass: string;\n };\n}\n\n/**\n * TableOfContentAnchor class.\n */\nexport class TableOfContentAnchor<T extends BaseProps = BaseProps> extends AnchorScrollTo<\n T & TableOfContentAnchorProps\n> {\n /**\n * Config.\n */\n static config: BaseConfig = {\n name: 'TableOfContentAnchor',\n emits: ['should-activate'],\n options: {\n activeClass: {\n type: String,\n default: 'is-active',\n },\n },\n };\n\n /**\n * Observer.\n * @private\n */\n __observer: IntersectionObserver;\n\n /**\n * Get the sentinel.\n */\n get sentinel():HTMLElement {\n return document.querySelector(this.targetSelector) as HTMLElement;\n }\n\n /**\n * Init observer on mount.\n */\n mounted() {\n if (!this.sentinel) {\n return;\n }\n\n this.__observer = new IntersectionObserver(([entry]) => {\n const shouldActivate =\n entry.isIntersecting &&\n entry.boundingClientRect.y < 100 &&\n entry.boundingClientRect.y > 100;\n this.$el.classList.toggle(this.$options.activeClass, shouldActivate);\n this.$emit('should-activate', shouldActivate);\n });\n\n this.__observer.observe(this.sentinel);\n }\n\n /**\n * Destroy observer on destroy.\n */\n destroyed() {\n this.__observer.disconnect();\n }\n}\n"],
5
- "mappings": "AACA,SAAS,sBAAsB;AAWxB,MAAM,6BAA8D,eAEzE;AAAA,EAIA,OAAO,SAAqB;AAAA,IAC1B,MAAM;AAAA,IACN,OAAO,CAAC,iBAAiB;AAAA,IACzB,SAAS;AAAA,MACP,aAAa;AAAA,QACX,MAAM;AAAA,QACN,SAAS;AAAA,MACX;AAAA,IACF;AAAA,EACF;AAAA,EAMA;AAAA,EAKA,IAAI,WAAuB;AACzB,WAAO,SAAS,cAAc,KAAK,cAAc;AAAA,EACnD;AAAA,EAKA,UAAU;AACR,QAAI,CAAC,KAAK,UAAU;AAClB;AAAA,IACF;AAEA,SAAK,aAAa,IAAI,qBAAqB,CAAC,CAAC,KAAK,MAAM;AACtD,YAAM,iBACJ,MAAM,kBACN,MAAM,mBAAmB,IAAI,OAC7B,MAAM,mBAAmB,IAAI;AAC/B,WAAK,IAAI,UAAU,OAAO,KAAK,SAAS,aAAa,cAAc;AACnE,WAAK,MAAM,mBAAmB,cAAc;AAAA,IAC9C,CAAC;AAED,SAAK,WAAW,QAAQ,KAAK,QAAQ;AAAA,EACvC;AAAA,EAKA,YAAY;AACV,SAAK,WAAW,WAAW;AAAA,EAC7B;AACF;",
4
+ "sourcesContent": ["import type { BaseProps, BaseConfig } from '@studiometa/js-toolkit';\nimport { AnchorScrollTo } from '../../atoms/index.js';\n\nexport interface TableOfContentAnchorProps extends BaseProps {\n $options: {\n activeClass: string;\n };\n}\n\n/**\n * TableOfContentAnchor class.\n */\nexport class TableOfContentAnchor<T extends BaseProps = BaseProps> extends AnchorScrollTo<\n T & TableOfContentAnchorProps\n> {\n /**\n * Config.\n */\n static config: BaseConfig = {\n name: 'TableOfContentAnchor',\n emits: ['should-activate'],\n options: {\n activeClass: {\n type: String,\n default: 'is-active',\n },\n },\n };\n\n /**\n * Observer.\n * @private\n */\n __observer: IntersectionObserver;\n\n /**\n * Get the sentinel.\n */\n get sentinel(): HTMLElement {\n return document.querySelector(this.targetSelector) as HTMLElement;\n }\n\n /**\n * Init observer on mount.\n */\n mounted() {\n if (!this.sentinel) {\n return;\n }\n\n this.__observer = new IntersectionObserver(([entry]) => {\n const shouldActivate =\n entry.isIntersecting &&\n entry.boundingClientRect.y < 100 &&\n entry.boundingClientRect.y > 100;\n this.$el.classList.toggle(this.$options.activeClass, shouldActivate);\n this.$emit('should-activate', shouldActivate);\n });\n\n this.__observer.observe(this.sentinel);\n }\n\n /**\n * Destroy observer on destroy.\n */\n destroyed() {\n this.__observer.disconnect();\n }\n}\n"],
5
+ "mappings": "AACA,SAAS,sBAAsB;AAWxB,MAAM,6BAA8D,eAEzE;AAAA;AAAA;AAAA;AAAA,EAIA,OAAO,SAAqB;AAAA,IAC1B,MAAM;AAAA,IACN,OAAO,CAAC,iBAAiB;AAAA,IACzB,SAAS;AAAA,MACP,aAAa;AAAA,QACX,MAAM;AAAA,QACN,SAAS;AAAA,MACX;AAAA,IACF;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA;AAAA;AAAA;AAAA;AAAA,EAKA,IAAI,WAAwB;AAC1B,WAAO,SAAS,cAAc,KAAK,cAAc;AAAA,EACnD;AAAA;AAAA;AAAA;AAAA,EAKA,UAAU;AACR,QAAI,CAAC,KAAK,UAAU;AAClB;AAAA,IACF;AAEA,SAAK,aAAa,IAAI,qBAAqB,CAAC,CAAC,KAAK,MAAM;AACtD,YAAM,iBACJ,MAAM,kBACN,MAAM,mBAAmB,IAAI,OAC7B,MAAM,mBAAmB,IAAI;AAC/B,WAAK,IAAI,UAAU,OAAO,KAAK,SAAS,aAAa,cAAc;AACnE,WAAK,MAAM,mBAAmB,cAAc;AAAA,IAC9C,CAAC;AAED,SAAK,WAAW,QAAQ,KAAK,QAAQ;AAAA,EACvC;AAAA;AAAA;AAAA;AAAA,EAKA,YAAY;AACV,SAAK,WAAW,WAAW;AAAA,EAC7B;AACF;",
6
6
  "names": []
7
7
  }
@@ -31,6 +31,10 @@ var import_js_toolkit = require("@studiometa/js-toolkit");
31
31
  var import_utils = require("@studiometa/js-toolkit/utils");
32
32
  var Tabs = class extends import_js_toolkit.Base {
33
33
  items;
34
+ /**
35
+ * Initialize the component's behaviours.
36
+ * @returns {void}
37
+ */
34
38
  mounted() {
35
39
  this.items = this.$refs.btn.map((btn, index) => {
36
40
  const id = `${this.$id}-${index}`;
@@ -46,6 +50,9 @@ var Tabs = class extends import_js_toolkit.Base {
46
50
  return item;
47
51
  });
48
52
  }
53
+ /**
54
+ * Switch tab on button click.
55
+ */
49
56
  onBtnClick(event, index) {
50
57
  this.items.forEach((item, i) => {
51
58
  if (i !== index) {
@@ -54,6 +61,9 @@ var Tabs = class extends import_js_toolkit.Base {
54
61
  });
55
62
  this.enableItem(this.items[index]);
56
63
  }
64
+ /**
65
+ * Enable the given tab and its associated content.
66
+ */
57
67
  async enableItem(item) {
58
68
  if (!item || item.isEnabled) {
59
69
  return Promise.resolve(this);
@@ -85,6 +95,9 @@ var Tabs = class extends import_js_toolkit.Base {
85
95
  )
86
96
  ]).then(() => Promise.resolve(this));
87
97
  }
98
+ /**
99
+ * Disable the given tab and its associated content.
100
+ */
88
101
  async disableItem(item) {
89
102
  if (!item || !item.isEnabled) {
90
103
  return Promise.resolve(this);
@@ -117,6 +130,9 @@ var Tabs = class extends import_js_toolkit.Base {
117
130
  ]).then(() => Promise.resolve(this));
118
131
  }
119
132
  };
133
+ /**
134
+ * Config.
135
+ */
120
136
  __publicField(Tabs, "config", {
121
137
  name: "Tabs",
122
138
  refs: ["btn[]", "content[]"],