@ethlete/cdk 4.2.0 → 4.2.2

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 (213) hide show
  1. package/CHANGELOG.md +16 -0
  2. package/esm2022/lib/components/accordion/components/accordion/accordion.component.mjs +6 -7
  3. package/esm2022/lib/components/accordion/components/accordion-group/accordion-group.component.mjs +3 -3
  4. package/esm2022/lib/components/accordion/partials/accordion-hint/accordion-hint.directive.mjs +3 -3
  5. package/esm2022/lib/components/accordion/partials/accordion-hint-wrapper/accordion-hint-wrapper.directive.mjs +3 -3
  6. package/esm2022/lib/components/accordion/partials/accordion-label/accordion-label.directive.mjs +3 -3
  7. package/esm2022/lib/components/accordion/partials/accordion-label-wrapper/accordion-label-wrapper.directive.mjs +3 -3
  8. package/esm2022/lib/components/bracket/components/bracket/bracket.component.mjs +9 -18
  9. package/esm2022/lib/components/bracket/directives/bracket-match/bracket-match.directive.mjs +3 -3
  10. package/esm2022/lib/components/bracket/directives/bracket-round/bracket-round.directive.mjs +3 -3
  11. package/esm2022/lib/components/bracket/partials/bracket-match/bracket-match.component.mjs +7 -7
  12. package/esm2022/lib/components/bracket/partials/bracket-round-header/bracket-round-header.component.mjs +7 -7
  13. package/esm2022/lib/components/button/components/button/button.component.mjs +3 -3
  14. package/esm2022/lib/components/button/components/query-button/query-button.component.mjs +7 -7
  15. package/esm2022/lib/components/button/directives/button/button.directive.mjs +3 -3
  16. package/esm2022/lib/components/button/directives/query-button/query-button.directive.mjs +3 -3
  17. package/esm2022/lib/components/filter/filter-overlay/components/filter-overlay-page-outlet/filter-overlay-page-outlet.component.mjs +11 -11
  18. package/esm2022/lib/components/filter/filter-overlay/directives/filter-overlay-back-or-close/filter-overlay-back-or-close.directive.mjs +3 -3
  19. package/esm2022/lib/components/filter/filter-overlay/directives/filter-overlay-link/filter-overlay-link.directive.mjs +3 -3
  20. package/esm2022/lib/components/filter/filter-overlay/directives/filter-overlay-reset/filter-overlay-reset.directive.mjs +3 -3
  21. package/esm2022/lib/components/filter/filter-overlay/directives/filter-overlay-submit/filter-overlay-submit.directive.mjs +3 -3
  22. package/esm2022/lib/components/filter/filter-overlay/services/filter-overlay.service.mjs +3 -3
  23. package/esm2022/lib/components/filter/rich-filter/components/rich-filter-host/rich-filter-host.component.mjs +3 -3
  24. package/esm2022/lib/components/filter/rich-filter/directives/rich-filter-button/rich-filter-button.directive.mjs +3 -3
  25. package/esm2022/lib/components/filter/rich-filter/directives/rich-filter-button-slot/rich-filter-button-slot.directive.mjs +3 -3
  26. package/esm2022/lib/components/filter/rich-filter/directives/rich-filter-content/rich-filter-content.directive.mjs +3 -3
  27. package/esm2022/lib/components/filter/rich-filter/directives/rich-filter-top/rich-filter-top.directive.mjs +3 -3
  28. package/esm2022/lib/components/forms/components/checkbox/components/checkbox/checkbox.component.mjs +3 -3
  29. package/esm2022/lib/components/forms/components/checkbox/components/checkbox-field/checkbox-field.component.mjs +3 -3
  30. package/esm2022/lib/components/forms/components/checkbox/components/checkbox-group/checkbox-group.component.mjs +3 -3
  31. package/esm2022/lib/components/forms/components/checkbox/directives/checkbox/checkbox.directive.mjs +3 -3
  32. package/esm2022/lib/components/forms/components/checkbox/directives/checkbox-field/checkbox-field.directive.mjs +3 -3
  33. package/esm2022/lib/components/forms/components/checkbox/directives/checkbox-group/checkbox-group.directive.mjs +3 -3
  34. package/esm2022/lib/components/forms/components/checkbox/directives/checkbox-group-control/checkbox-group-control.directive.mjs +3 -3
  35. package/esm2022/lib/components/forms/components/error/components/error/error.component.mjs +6 -6
  36. package/esm2022/lib/components/forms/components/input/components/date-input/date-input.component.mjs +3 -3
  37. package/esm2022/lib/components/forms/components/input/components/email-input/email-input.component.mjs +3 -3
  38. package/esm2022/lib/components/forms/components/input/components/input-field/input-field.component.mjs +6 -6
  39. package/esm2022/lib/components/forms/components/input/components/number-input/number-input.component.mjs +3 -3
  40. package/esm2022/lib/components/forms/components/input/components/password-input/password-input.component.mjs +3 -3
  41. package/esm2022/lib/components/forms/components/input/components/search-input/search-input.component.mjs +3 -3
  42. package/esm2022/lib/components/forms/components/input/components/text-input/text-input.component.mjs +3 -3
  43. package/esm2022/lib/components/forms/components/input/components/textarea-input/textarea-input.component.mjs +3 -3
  44. package/esm2022/lib/components/forms/components/input/directives/autosize-textarea/autosize-textarea.directive.mjs +3 -3
  45. package/esm2022/lib/components/forms/components/input/directives/date-input/date-input.directive.mjs +3 -3
  46. package/esm2022/lib/components/forms/components/input/directives/email-input/email-input.directive.mjs +3 -3
  47. package/esm2022/lib/components/forms/components/input/directives/number-input/number-input.directive.mjs +3 -3
  48. package/esm2022/lib/components/forms/components/input/directives/password-input/password-input.directive.mjs +3 -3
  49. package/esm2022/lib/components/forms/components/input/directives/search-input/search-input.directive.mjs +3 -3
  50. package/esm2022/lib/components/forms/components/input/directives/text-input/text-input.directive.mjs +3 -3
  51. package/esm2022/lib/components/forms/components/input/directives/textarea-input/textarea-input.directive.mjs +3 -3
  52. package/esm2022/lib/components/forms/components/input/partials/password-input-toggle/password-input-toggle.component.mjs +3 -3
  53. package/esm2022/lib/components/forms/components/input/partials/search-input-clear/search-input-clear.component.mjs +3 -3
  54. package/esm2022/lib/components/forms/components/label/components/label/label.component.mjs +3 -3
  55. package/esm2022/lib/components/forms/components/label/directives/label-suffix/label-suffix.directive.mjs +3 -3
  56. package/esm2022/lib/components/forms/components/radio/components/radio/radio.component.mjs +3 -3
  57. package/esm2022/lib/components/forms/components/radio/components/radio-field/radio-field.component.mjs +3 -3
  58. package/esm2022/lib/components/forms/components/radio/components/radio-group/radio-group.component.mjs +3 -3
  59. package/esm2022/lib/components/forms/components/radio/directives/radio/radio.directive.mjs +3 -3
  60. package/esm2022/lib/components/forms/components/radio/directives/radio-field/radio-field.directive.mjs +3 -3
  61. package/esm2022/lib/components/forms/components/radio/directives/radio-group/radio-group.directive.mjs +3 -3
  62. package/esm2022/lib/components/forms/components/segmented-button/components/segmented-button/segmented-button.component.mjs +3 -3
  63. package/esm2022/lib/components/forms/components/segmented-button/components/segmented-button-field/segmented-button-field.component.mjs +5 -5
  64. package/esm2022/lib/components/forms/components/segmented-button/components/segmented-button-group/segmented-button-group.component.mjs +3 -3
  65. package/esm2022/lib/components/forms/components/segmented-button/directives/segmented-button/segmented-button.directive.mjs +3 -3
  66. package/esm2022/lib/components/forms/components/segmented-button/directives/segmented-button-field/segmented-button-field.directive.mjs +3 -3
  67. package/esm2022/lib/components/forms/components/segmented-button/directives/segmented-button-group/segmented-button-group.directive.mjs +3 -3
  68. package/esm2022/lib/components/forms/components/select/components/combobox/components/combobox/combobox.component.mjs +6 -8
  69. package/esm2022/lib/components/forms/components/select/components/combobox/directives/combobox/combobox.directive.mjs +3 -3
  70. package/esm2022/lib/components/forms/components/select/components/combobox/directives/combobox-body-empty-template/combobox-body-empty-template.directive.mjs +3 -3
  71. package/esm2022/lib/components/forms/components/select/components/combobox/directives/combobox-body-error-template/combobox-body-error-template.directive.mjs +3 -3
  72. package/esm2022/lib/components/forms/components/select/components/combobox/directives/combobox-body-loading-template/combobox-body-loading-template.directive.mjs +3 -3
  73. package/esm2022/lib/components/forms/components/select/components/combobox/directives/combobox-body-more-items-hint-template/combobox-body-more-items-hint-template.directive.mjs +3 -3
  74. package/esm2022/lib/components/forms/components/select/components/combobox/directives/combobox-option-template/combobox-option-template.directive.mjs +3 -3
  75. package/esm2022/lib/components/forms/components/select/components/combobox/directives/combobox-selected-option-template/combobox-selected-option-template.directive.mjs +3 -3
  76. package/esm2022/lib/components/forms/components/select/components/combobox/partials/combobox-body/combobox-body.component.mjs +7 -9
  77. package/esm2022/lib/components/forms/components/select/components/combobox/partials/combobox-option/combobox-option.component.mjs +8 -8
  78. package/esm2022/lib/components/forms/components/select/components/native-select/components/native-select/native-select.component.mjs +6 -6
  79. package/esm2022/lib/components/forms/components/select/components/native-select/directives/native-select-input/native-select-input.directive.mjs +3 -3
  80. package/esm2022/lib/components/forms/components/select/components/native-select/directives/native-select-option/native-select-option.directive.mjs +3 -3
  81. package/esm2022/lib/components/forms/components/select/components/native-select/partials/native-select-option/native-select-option.component.mjs +3 -3
  82. package/esm2022/lib/components/forms/components/select/components/select/components/select/select.component.mjs +6 -6
  83. package/esm2022/lib/components/forms/components/select/components/select/directives/select/select.directive.mjs +3 -3
  84. package/esm2022/lib/components/forms/components/select/components/select/directives/select-body/select-body.directive.mjs +3 -3
  85. package/esm2022/lib/components/forms/components/select/components/select/directives/select-option/select-option.directive.mjs +3 -3
  86. package/esm2022/lib/components/forms/components/select/components/select/partials/select-body/select-body.component.mjs +3 -3
  87. package/esm2022/lib/components/forms/components/select/components/select/partials/select-option/select-option.component.mjs +3 -3
  88. package/esm2022/lib/components/forms/components/select/components/select-field/select-field.component.mjs +6 -6
  89. package/esm2022/lib/components/forms/components/select/directives/select-field/select-field.directive.mjs +3 -3
  90. package/esm2022/lib/components/forms/components/selection-list/components/selection-list-field/selection-list-field.component.mjs +4 -5
  91. package/esm2022/lib/components/forms/components/selection-list/components/selection-list-option/selection-list-option.component.mjs +5 -5
  92. package/esm2022/lib/components/forms/components/selection-list/directives/selection-list-field/selection-list-field.directive.mjs +3 -3
  93. package/esm2022/lib/components/forms/components/selection-list/directives/selection-list-option/selection-list-option.directive.mjs +3 -3
  94. package/esm2022/lib/components/forms/components/slide-toggle/components/slide-toggle/slide-toggle.component.mjs +3 -3
  95. package/esm2022/lib/components/forms/components/slide-toggle/components/slide-toggle-field/slide-toggle-field.component.mjs +3 -3
  96. package/esm2022/lib/components/forms/components/slide-toggle/directives/slide-toggle/slide-toggle.directive.mjs +3 -3
  97. package/esm2022/lib/components/forms/components/slider/components/slider/slider.component.mjs +6 -6
  98. package/esm2022/lib/components/forms/components/slider/components/slider-field/slider-field.component.mjs +6 -6
  99. package/esm2022/lib/components/forms/directives/dynamic-form-field/dynamic-form-field.directive.mjs +3 -3
  100. package/esm2022/lib/components/forms/directives/dynamic-form-group/dynamic-form-group.directive.mjs +3 -3
  101. package/esm2022/lib/components/forms/directives/expose-input-vars/expose-input-vars.directive.mjs +3 -3
  102. package/esm2022/lib/components/forms/directives/if-input-empty/if-input-empty.directive.mjs +3 -3
  103. package/esm2022/lib/components/forms/directives/if-input-filled/if-input-filled.directive.mjs +3 -3
  104. package/esm2022/lib/components/forms/directives/input/input.directive.mjs +3 -3
  105. package/esm2022/lib/components/forms/directives/input-prefix/input-prefix.directive.mjs +3 -3
  106. package/esm2022/lib/components/forms/directives/input-suffix/input-suffix.directive.mjs +3 -3
  107. package/esm2022/lib/components/forms/directives/native-input-ref/native-input-ref.directive.mjs +3 -3
  108. package/esm2022/lib/components/forms/directives/static-form-field/static-form-field.directive.mjs +3 -3
  109. package/esm2022/lib/components/forms/directives/static-form-group/static-form-group.directive.mjs +3 -3
  110. package/esm2022/lib/components/forms/directives/writeable-input/writeable-input.directive.mjs +3 -3
  111. package/esm2022/lib/components/forms/services/default-validator-errors.service.mjs +3 -3
  112. package/esm2022/lib/components/forms/services/form-field-state.service.mjs +3 -3
  113. package/esm2022/lib/components/forms/services/form-group-state.service.mjs +3 -3
  114. package/esm2022/lib/components/forms/services/input-state.service.mjs +3 -3
  115. package/esm2022/lib/components/forms/utils/decorated-form-field.base.mjs +3 -3
  116. package/esm2022/lib/components/forms/utils/decorated-input.base.mjs +3 -3
  117. package/esm2022/lib/components/forms/utils/input.base.mjs +3 -3
  118. package/esm2022/lib/components/icons/chevron-icon/chevron-icon.component.mjs +3 -3
  119. package/esm2022/lib/components/masonry/components/masonry/masonry.component.mjs +3 -3
  120. package/esm2022/lib/components/masonry/partials/masonry-item/masonry-item.component.mjs +3 -3
  121. package/esm2022/lib/components/overlay/components/bottom-sheet/components/bottom-sheet-container/bottom-sheet-container.component.mjs +3 -3
  122. package/esm2022/lib/components/overlay/components/bottom-sheet/partials/bottom-sheet-container-base/bottom-sheet-container-base.component.mjs +3 -3
  123. package/esm2022/lib/components/overlay/components/bottom-sheet/partials/bottom-sheet-drag-handle/bottom-sheet-drag-handle.component.mjs +3 -3
  124. package/esm2022/lib/components/overlay/components/bottom-sheet/partials/bottom-sheet-title/bottom-sheet-title.directive.mjs +3 -3
  125. package/esm2022/lib/components/overlay/components/bottom-sheet/services/bottom-sheet-base.service.mjs +3 -3
  126. package/esm2022/lib/components/overlay/components/bottom-sheet/services/bottom-sheet-swipe-handler.service.mjs +3 -3
  127. package/esm2022/lib/components/overlay/components/bottom-sheet/services/bottom-sheet.service.mjs +3 -3
  128. package/esm2022/lib/components/overlay/components/dialog/components/dialog-container/dialog-container.component.mjs +3 -3
  129. package/esm2022/lib/components/overlay/components/dialog/partials/dialog-close/dialog-close.directive.mjs +3 -3
  130. package/esm2022/lib/components/overlay/components/dialog/partials/dialog-container-base/dialog-container-base.component.mjs +3 -3
  131. package/esm2022/lib/components/overlay/components/dialog/partials/dialog-title/dialog-title.directive.mjs +3 -3
  132. package/esm2022/lib/components/overlay/components/dialog/services/dialog-base.service.mjs +3 -3
  133. package/esm2022/lib/components/overlay/components/dialog/services/dialog.service.mjs +3 -3
  134. package/esm2022/lib/components/overlay/components/menu/context-menu-trigger.mjs +6 -6
  135. package/esm2022/lib/components/overlay/components/menu/menu-aim.mjs +6 -6
  136. package/esm2022/lib/components/overlay/components/menu/menu-bar.mjs +3 -3
  137. package/esm2022/lib/components/overlay/components/menu/menu-base.mjs +3 -3
  138. package/esm2022/lib/components/overlay/components/menu/menu-group.mjs +3 -3
  139. package/esm2022/lib/components/overlay/components/menu/menu-item-checkbox.mjs +3 -3
  140. package/esm2022/lib/components/overlay/components/menu/menu-item-radio.mjs +3 -3
  141. package/esm2022/lib/components/overlay/components/menu/menu-item-selectable.mjs +3 -3
  142. package/esm2022/lib/components/overlay/components/menu/menu-item.mjs +3 -3
  143. package/esm2022/lib/components/overlay/components/menu/menu-module.mjs +4 -4
  144. package/esm2022/lib/components/overlay/components/menu/menu-stack.mjs +3 -3
  145. package/esm2022/lib/components/overlay/components/menu/menu-trigger-base.mjs +3 -3
  146. package/esm2022/lib/components/overlay/components/menu/menu-trigger.mjs +3 -3
  147. package/esm2022/lib/components/overlay/components/menu/menu.mjs +3 -3
  148. package/esm2022/lib/components/overlay/components/overlay/components/overlay-container/overlay-container.component.mjs +3 -3
  149. package/esm2022/lib/components/overlay/components/overlay/partials/overlay-close/overlay-close.directive.mjs +3 -3
  150. package/esm2022/lib/components/overlay/components/overlay/partials/overlay-title/overlay-title.directive.mjs +3 -3
  151. package/esm2022/lib/components/overlay/components/overlay/services/overlay.service.mjs +4 -4
  152. package/esm2022/lib/components/overlay/components/toggletip/components/toggletip/toggletip.component.mjs +8 -8
  153. package/esm2022/lib/components/overlay/components/toggletip/directives/toggletip/toggletip.directive.mjs +3 -3
  154. package/esm2022/lib/components/overlay/components/tooltip/components/tooltip/tooltip.component.mjs +8 -8
  155. package/esm2022/lib/components/overlay/components/tooltip/directives/tooltip/tooltip.directive.mjs +4 -4
  156. package/esm2022/lib/components/overlay/directives/dynamic-overlay-title/dynamic-overlay-title.directive.mjs +3 -3
  157. package/esm2022/lib/components/overlay/directives/overlay-close-auto-blocker/overlay-close-auto-blocker.directive.mjs +3 -3
  158. package/esm2022/lib/components/overlay/services/dynamic-overlay.service.mjs +3 -3
  159. package/esm2022/lib/components/pagination/components/pagination/pagination.component.mjs +7 -7
  160. package/esm2022/lib/components/pagination/partials/pagination-link/pagination-link.directive.mjs +3 -3
  161. package/esm2022/lib/components/pagination/services/pagination-head.service.mjs +4 -4
  162. package/esm2022/lib/components/pagination/utils/pagination.util.mjs +1 -1
  163. package/esm2022/lib/components/picture/picture-data.directive.mjs +3 -3
  164. package/esm2022/lib/components/picture/picture.component.mjs +8 -8
  165. package/esm2022/lib/components/picture/pipes/normalize-source/normalize-source.pipe.mjs +3 -3
  166. package/esm2022/lib/components/progress-spinner/progress-spinner.component.mjs +6 -6
  167. package/esm2022/lib/components/query-error/components/query-error/query-error.component.mjs +5 -6
  168. package/esm2022/lib/components/query-error/directives/query-error/query-error.directive.mjs +3 -3
  169. package/esm2022/lib/components/scrollable/components/scrollable/scrollable.component.mjs +219 -146
  170. package/esm2022/lib/components/skeleton/components/skeleton/skeleton.component.mjs +3 -3
  171. package/esm2022/lib/components/skeleton/partials/skeleton-item/skeleton-item.component.mjs +3 -3
  172. package/esm2022/lib/components/sort/components/sort-header/sort-header.component.mjs +5 -6
  173. package/esm2022/lib/components/sort/partials/sort/sort.directive.mjs +3 -3
  174. package/esm2022/lib/components/sort/services/sort-header-intl.mjs +3 -3
  175. package/esm2022/lib/components/table/components/table/table.component.mjs +3 -3
  176. package/esm2022/lib/components/table/partials/cells/cell/cell.directive.mjs +3 -3
  177. package/esm2022/lib/components/table/partials/cells/cell-def/cell-def.directive.mjs +3 -3
  178. package/esm2022/lib/components/table/partials/cells/column-def/column-def.directive.mjs +3 -3
  179. package/esm2022/lib/components/table/partials/cells/footer-cell/footer-cell.directive.mjs +3 -3
  180. package/esm2022/lib/components/table/partials/cells/footer-cell-def/footer-cell-def.directive.mjs +3 -3
  181. package/esm2022/lib/components/table/partials/cells/header-cell/header-cell.directive.mjs +3 -3
  182. package/esm2022/lib/components/table/partials/cells/header-cell-def/header-cell-def.directive.mjs +3 -3
  183. package/esm2022/lib/components/table/partials/cells/text-column/text-column.component.mjs +3 -3
  184. package/esm2022/lib/components/table/partials/rows/footer-row/footer-row.component.mjs +3 -3
  185. package/esm2022/lib/components/table/partials/rows/footer-row-def/footer-row-def.directive.mjs +3 -3
  186. package/esm2022/lib/components/table/partials/rows/header-row/header-row.component.mjs +3 -3
  187. package/esm2022/lib/components/table/partials/rows/header-row-def/header-row-def.directive.mjs +3 -3
  188. package/esm2022/lib/components/table/partials/rows/no-data-row/no-data-row.directive.mjs +3 -3
  189. package/esm2022/lib/components/table/partials/rows/recycle-rows/recycle-rows.directive.mjs +3 -3
  190. package/esm2022/lib/components/table/partials/rows/row/row.component.mjs +3 -3
  191. package/esm2022/lib/components/table/partials/rows/row-def/row-def.directive.mjs +3 -3
  192. package/esm2022/lib/components/table/partials/table-busy/table-busy.directive.mjs +3 -3
  193. package/esm2022/lib/components/table/partials/table-busy-outlet/table-busy-outlet.directive.mjs +3 -3
  194. package/esm2022/lib/components/tabs/components/inline-tabs/inline-tabs.component.mjs +7 -9
  195. package/esm2022/lib/components/tabs/components/nav-tabs/nav-tabs.component.mjs +3 -3
  196. package/esm2022/lib/components/tabs/partials/inline-tabs/inline-tab/inline-tab.component.mjs +3 -3
  197. package/esm2022/lib/components/tabs/partials/inline-tabs/inline-tab-body/inline-tab-body.component.mjs +3 -3
  198. package/esm2022/lib/components/tabs/partials/inline-tabs/inline-tab-body-host/inline-tab-body-host.directive.mjs +3 -3
  199. package/esm2022/lib/components/tabs/partials/inline-tabs/inline-tab-content/inline-tab-content.directive.mjs +3 -3
  200. package/esm2022/lib/components/tabs/partials/inline-tabs/inline-tab-header/inline-tab-header.component.mjs +3 -3
  201. package/esm2022/lib/components/tabs/partials/inline-tabs/inline-tab-label/inline-tab-label.directive.mjs +3 -3
  202. package/esm2022/lib/components/tabs/partials/inline-tabs/inline-tab-label-wrapper/inline-tab-label-wrapper.directive.mjs +3 -3
  203. package/esm2022/lib/components/tabs/partials/nav-tabs/nav-tab-link/nav-tab-link.directive.mjs +3 -3
  204. package/esm2022/lib/components/tabs/partials/nav-tabs/nav-tabs-outlet/nav-tabs-outlet.component.mjs +3 -3
  205. package/esm2022/lib/components/tabs/utils/active-tab-underline.util.mjs +3 -3
  206. package/esm2022/lib/components/tabs/utils/paginated-tab-header.directive.mjs +21 -13
  207. package/esm2022/lib/services/swipe-handler.service.mjs +3 -3
  208. package/fesm2022/ethlete-cdk.mjs +898 -834
  209. package/fesm2022/ethlete-cdk.mjs.map +1 -1
  210. package/lib/components/picture/picture.component.d.ts +1 -1
  211. package/lib/components/scrollable/components/scrollable/scrollable.component.d.ts +55 -35
  212. package/lib/components/tabs/utils/paginated-tab-header.directive.d.ts +1 -1
  213. package/package.json +7 -7
@@ -1,18 +1,63 @@
1
- import { NgClass, NgIf } from '@angular/common';
2
- import { ChangeDetectionStrategy, Component, ContentChildren, ElementRef, EventEmitter, HostBinding, Input, Output, ViewChild, ViewChildren, ViewEncapsulation, booleanAttribute, computed, effect, inject, isDevMode, numberAttribute, signal, } from '@angular/core';
3
- import { CursorDragScrollDirective, IS_ACTIVE_ELEMENT, IS_ELEMENT, LetDirective, ObserveScrollStateDirective, TypedQueryList, createDestroy, getElementVisibleStates, scrollToElement, signalElementIntersection, signalElementScrollState, signalHostAttributes, } from '@ethlete/core';
1
+ import { NgClass } from '@angular/common';
2
+ import { ChangeDetectionStrategy, Component, ContentChildren, ElementRef, EventEmitter, Input, Output, ViewChild, ViewEncapsulation, booleanAttribute, computed, effect, inject, isDevMode, numberAttribute, signal, } from '@angular/core';
3
+ import { CursorDragScrollDirective, IS_ACTIVE_ELEMENT, IS_ELEMENT, LetDirective, ObserveScrollStateDirective, TypedQueryList, createDestroy, getElementVisibleStates, isElementVisible, nextFrame, scrollToElement, signalElementIntersection, signalElementScrollState, signalHostAttributes, signalHostClasses, } from '@ethlete/core';
4
4
  import { BehaviorSubject, debounceTime, fromEvent, merge, of, startWith, takeUntil, tap } from 'rxjs';
5
5
  import { ChevronIconComponent } from '../../../icons';
6
6
  import * as i0 from "@angular/core";
7
7
  export class ScrollableComponent {
8
- set scrollableList(list) {
9
- this._scrollableList.set(list);
8
+ set _itemSize(v) {
9
+ this.itemSize.set(v);
10
10
  }
11
- set firstElementList(list) {
12
- this._firstElementList.set(list);
11
+ set _direction(v) {
12
+ this.direction.set(v);
13
13
  }
14
- set lastElementList(list) {
15
- this._lastElementList.set(list);
14
+ set _scrollableRole(v) {
15
+ this.scrollableRole.set(v);
16
+ }
17
+ set _scrollableClass(v) {
18
+ this.scrollableClass.set(v);
19
+ }
20
+ set _renderMasks(v) {
21
+ this.renderMasks.set(v);
22
+ }
23
+ set _renderButtons(v) {
24
+ this.renderButtons.set(v);
25
+ }
26
+ set _renderScrollbars(v) {
27
+ this.renderScrollbars.set(v);
28
+ }
29
+ set _stickyButtons(v) {
30
+ this.stickyButtons.set(v);
31
+ }
32
+ set _cursorDragScroll(v) {
33
+ this.cursorDragScroll.set(v);
34
+ }
35
+ set _disableActiveElementScrolling(v) {
36
+ this.disableActiveElementScrolling.set(v);
37
+ }
38
+ set _scrollMode(v) {
39
+ this.scrollMode.set(v);
40
+ }
41
+ set _snap(v) {
42
+ this.snap.set(v);
43
+ }
44
+ set _scrollMargin(v) {
45
+ this.scrollMargin.set(v);
46
+ }
47
+ set _scrollable(e) {
48
+ this.scrollable.set(e);
49
+ }
50
+ set _firstElement(e) {
51
+ this.firstElement.set(e);
52
+ }
53
+ set _lastElement(e) {
54
+ this.lastElement.set(e);
55
+ }
56
+ set _activeElementList(e) {
57
+ this.activeElementList.set(e);
58
+ }
59
+ set _elementList(e) {
60
+ this.elementList.set(e);
16
61
  }
17
62
  get highestVisibleIntersection() {
18
63
  const elements = this._latestVisibilityStates$.value;
@@ -66,87 +111,121 @@ export class ScrollableComponent {
66
111
  this._elementRef = inject(ElementRef);
67
112
  this._isCursorDragging$ = new BehaviorSubject(false);
68
113
  this._latestVisibilityStates$ = new BehaviorSubject([]);
69
- this.itemSize = 'auto';
70
- this.direction = 'horizontal';
71
- this.renderMasks = true;
72
- this.renderButtons = true;
73
- this.renderScrollbars = false;
74
- this.stickyButtons = false;
75
- this.cursorDragScroll = true;
76
- this.disableActiveElementScrolling = false;
77
- this.scrollMode = 'container';
78
- this.snap = false;
79
- this.scrollMargin = 0;
114
+ this.itemSize = signal('auto');
115
+ this.direction = signal('horizontal');
116
+ this.scrollableRole = signal(null);
117
+ this.scrollableClass = signal(null);
118
+ this.renderMasks = signal(true);
119
+ this.renderButtons = signal(true);
120
+ this.renderScrollbars = signal(false);
121
+ this.stickyButtons = signal(false);
122
+ this.cursorDragScroll = signal(true);
123
+ this.disableActiveElementScrolling = signal(false);
124
+ this.scrollMode = signal('container');
125
+ this.snap = signal(false);
126
+ this.scrollMargin = signal(0);
80
127
  this.scrollStateChange = new EventEmitter();
81
128
  this.intersectionChange = new EventEmitter();
82
- this._scrollableList = signal(null);
83
- this._firstElementList = signal(null);
84
- this._lastElementList = signal(null);
85
- this.activeElements = null;
86
- this.elements = null;
87
- this.containerScrollState = signalElementScrollState(this._scrollableList);
88
- this.firstElementIntersection = signalElementIntersection(this._firstElementList, this._scrollableList);
89
- this.lastElementIntersection = signalElementIntersection(this._lastElementList, this._scrollableList);
90
- this.shouldAnimateOverlays = computed(() => !!this.firstElementIntersection() && !!this.lastElementIntersection());
129
+ this.scrollable = signal(null);
130
+ this.firstElement = signal(null);
131
+ this.lastElement = signal(null);
132
+ this.activeElementList = signal(null);
133
+ this.elementList = signal(null);
134
+ this.containerScrollState = signalElementScrollState(this.scrollable);
135
+ this.firstElementIntersection = signalElementIntersection(this.firstElement, { root: this.scrollable });
136
+ this.firstElementVisibility = signal(null);
137
+ this.lastElementIntersection = signalElementIntersection(this.lastElement, { root: this.scrollable });
138
+ this.lastElementVisibility = signal(null);
91
139
  this.canScroll = computed(() => {
92
- const dir = this.direction;
140
+ const dir = this.direction();
93
141
  if (dir === 'horizontal') {
94
142
  return this.containerScrollState().canScrollHorizontally;
95
143
  }
96
144
  return this.containerScrollState().canScrollVertically;
97
145
  });
98
- this.isAtStart = computed(() => this.canScroll() ? this.firstElementIntersection().isIntersecting : true);
99
- this.isAtEnd = computed(() => this.canScroll() ? this.lastElementIntersection().isIntersecting : true);
146
+ this.isAtStart = computed(() => {
147
+ if (!this.canScroll()) {
148
+ return true;
149
+ }
150
+ const intersection = this.firstElementIntersection();
151
+ if (!intersection) {
152
+ return this.firstElementVisibility()?.inline ?? true;
153
+ }
154
+ return intersection.isIntersecting;
155
+ });
156
+ this.isAtEnd = computed(() => {
157
+ if (!this.canScroll()) {
158
+ return true;
159
+ }
160
+ const intersection = this.lastElementIntersection();
161
+ if (!intersection) {
162
+ return this.lastElementVisibility()?.inline ?? true;
163
+ }
164
+ return intersection.isIntersecting;
165
+ });
166
+ this.enableOverlayAnimations = signal(false);
100
167
  this.hostAttributes = signalHostAttributes({
101
- 'can-scroll': this.canScroll,
102
- 'at-start': this.isAtStart,
103
- 'at-end': this.isAtEnd,
104
- 'animate-overlays': this.shouldAnimateOverlays,
168
+ 'item-size': this.itemSize,
169
+ direction: this.direction,
170
+ 'render-scrollbars': this.renderScrollbars,
171
+ 'sticky-buttons': this.stickyButtons,
105
172
  });
173
+ this.hostClasses = signalHostClasses({
174
+ 'et-scrollable--can-scroll': this.canScroll,
175
+ 'et-scrollable--is-at-start': this.isAtStart,
176
+ 'et-scrollable--is-at-end': this.isAtEnd,
177
+ 'et-scrollable--enable-overlay-animations': this.enableOverlayAnimations,
178
+ });
179
+ effect(() => {
180
+ const scrollable = this.scrollable()?.nativeElement;
181
+ const firstElement = this.firstElement()?.nativeElement;
182
+ const lastElement = this.lastElement()?.nativeElement;
183
+ const activeElementList = this.activeElementList()?.toArray();
184
+ if (!scrollable || !firstElement || !lastElement || !activeElementList) {
185
+ return;
186
+ }
187
+ const firstActive = activeElementList.find((a) => a.isActiveElement);
188
+ if (firstActive && !this.disableActiveElementScrolling()) {
189
+ const offsetTop = firstActive.elementRef.nativeElement.offsetTop - scrollable.offsetTop;
190
+ const offsetLeft = firstActive.elementRef.nativeElement.offsetLeft - scrollable.offsetLeft;
191
+ scrollable.scrollLeft = offsetLeft;
192
+ scrollable.scrollTop = offsetTop;
193
+ }
194
+ this.firstElementVisibility.set(isElementVisible({
195
+ container: scrollable,
196
+ element: firstElement,
197
+ }));
198
+ this.lastElementVisibility.set(isElementVisible({
199
+ container: scrollable,
200
+ element: lastElement,
201
+ }));
202
+ // We need to wait one frame before enabling animations to prevent a animation from playing during initial render.
203
+ nextFrame(() => this.enableOverlayAnimations.set(true));
204
+ }, { allowSignalWrites: true });
106
205
  effect(() => {
107
206
  const isAtStart = this.isAtStart();
108
207
  const isAtEnd = this.isAtEnd();
109
208
  const canScroll = this.canScroll();
110
209
  this.scrollStateChange.emit({
111
210
  canScroll,
112
- isAtEnd,
113
- isAtStart,
211
+ isAtEnd: !!isAtEnd,
212
+ isAtStart: !!isAtStart,
114
213
  });
115
214
  });
116
215
  }
117
216
  ngAfterContentInit() {
118
- if (!this.activeElements || !this.elements) {
119
- return;
120
- }
121
- this.activeElements.changes
122
- .pipe(startWith(this.activeElements), tap((activeElements) => {
123
- if (this.disableActiveElementScrolling) {
124
- return;
125
- }
126
- const firstActive = activeElements
127
- .filter((a) => !!a)
128
- .find((a) => a.isActiveElement);
129
- if (!firstActive) {
130
- return;
131
- }
132
- scrollToElement({
133
- behavior: 'auto',
134
- container: this.scrollable.nativeElement,
135
- element: firstActive.elementRef.nativeElement,
136
- scrollInlineMargin: this.direction === 'horizontal' ? this.scrollMargin : 0,
137
- scrollBlockMargin: this.direction === 'horizontal' ? 0 : this.scrollMargin,
138
- });
139
- }), takeUntil(this._destroy$))
140
- .subscribe();
141
217
  this._setupScrollListening();
142
218
  }
143
219
  scrollOneContainerSize(direction) {
144
- const scrollElement = this.scrollable.nativeElement;
220
+ const scrollElement = this.scrollable()?.nativeElement;
221
+ if (!scrollElement) {
222
+ return;
223
+ }
145
224
  const parent = this._elementRef.nativeElement;
146
- const scrollableSize = this.direction === 'horizontal' ? parent.clientWidth : parent.clientHeight;
147
- const currentScroll = this.direction === 'horizontal' ? scrollElement.scrollLeft : scrollElement.scrollTop;
225
+ const scrollableSize = this.direction() === 'horizontal' ? parent.clientWidth : parent.clientHeight;
226
+ const currentScroll = this.direction() === 'horizontal' ? scrollElement.scrollLeft : scrollElement.scrollTop;
148
227
  scrollElement.scrollTo({
149
- [this.direction === 'horizontal' ? 'left' : 'top']: currentScroll + (direction === 'start' ? -scrollableSize : scrollableSize),
228
+ [this.direction() === 'horizontal' ? 'left' : 'top']: currentScroll + (direction === 'start' ? -scrollableSize : scrollableSize),
150
229
  behavior: 'smooth',
151
230
  });
152
231
  }
@@ -164,39 +243,39 @@ export class ScrollableComponent {
164
243
  }
165
244
  this.scrollToElement({
166
245
  element: el?.element,
167
- direction: this.direction === 'horizontal' ? 'inline' : 'block',
246
+ direction: this.direction() === 'horizontal' ? 'inline' : 'block',
168
247
  origin: direction,
169
- ...(this.direction === 'horizontal'
170
- ? { scrollInlineMargin: this.scrollMargin }
171
- : { scrollBlockMargin: this.scrollMargin }),
248
+ ...(this.direction() === 'horizontal'
249
+ ? { scrollInlineMargin: this.scrollMargin() }
250
+ : { scrollBlockMargin: this.scrollMargin() }),
172
251
  });
173
252
  }
174
253
  scrollToElement(options) {
175
- const scrollElement = this.scrollable.nativeElement;
254
+ const scrollElement = this.scrollable()?.nativeElement;
176
255
  scrollToElement({
177
256
  container: scrollElement,
178
- ...(this.direction === 'horizontal'
179
- ? { scrollInlineMargin: this.scrollMargin }
180
- : { scrollBlockMargin: this.scrollMargin }),
257
+ ...(this.direction() === 'horizontal'
258
+ ? { scrollInlineMargin: this.scrollMargin() }
259
+ : { scrollBlockMargin: this.scrollMargin() }),
181
260
  ...options,
182
261
  });
183
262
  }
184
263
  scrollToElementByIndex(options) {
185
- const elements = this.elements?.toArray() ?? [];
264
+ const elements = this.elementList()?.toArray() ?? [];
186
265
  if (!elements.length) {
187
266
  if (isDevMode()) {
188
267
  console.warn('No elements found to scroll to. Make sure to apply the isElement directive to the elements you want to scroll to.');
189
268
  }
190
269
  return;
191
270
  }
192
- const scrollElement = this.scrollable.nativeElement;
271
+ const scrollElement = this.scrollable()?.nativeElement;
193
272
  const element = elements[options.index]?.elementRef.nativeElement;
194
273
  scrollToElement({
195
274
  container: scrollElement,
196
275
  element,
197
- ...(this.direction === 'horizontal'
198
- ? { scrollInlineMargin: this.scrollMargin }
199
- : { scrollBlockMargin: this.scrollMargin }),
276
+ ...(this.direction() === 'horizontal'
277
+ ? { scrollInlineMargin: this.scrollMargin() }
278
+ : { scrollBlockMargin: this.scrollMargin() }),
200
279
  ...options,
201
280
  });
202
281
  }
@@ -204,7 +283,7 @@ export class ScrollableComponent {
204
283
  this._isCursorDragging$.next(isDragging);
205
284
  }
206
285
  scrollToStartDirection() {
207
- if (this.scrollMode === 'container') {
286
+ if (this.scrollMode() === 'container') {
208
287
  this.scrollOneContainerSize('start');
209
288
  }
210
289
  else {
@@ -212,7 +291,7 @@ export class ScrollableComponent {
212
291
  }
213
292
  }
214
293
  scrollToStartEnd() {
215
- if (this.scrollMode === 'container') {
294
+ if (this.scrollMode() === 'container') {
216
295
  this.scrollOneContainerSize('end');
217
296
  }
218
297
  else {
@@ -220,7 +299,11 @@ export class ScrollableComponent {
220
299
  }
221
300
  }
222
301
  _setupScrollListening() {
223
- const scrollElement = this.scrollable.nativeElement;
302
+ const scrollElement = this.scrollable()?.nativeElement;
303
+ const elements = this.elementList();
304
+ if (!scrollElement || !elements) {
305
+ return;
306
+ }
224
307
  let isSnapping = false;
225
308
  let snapTimeout = 0;
226
309
  merge(fromEvent(scrollElement, 'wheel'), fromEvent(scrollElement, 'touchstart'))
@@ -228,21 +311,21 @@ export class ScrollableComponent {
228
311
  isSnapping = false;
229
312
  }))
230
313
  .subscribe();
231
- merge(fromEvent(scrollElement, 'scroll'), this._isCursorDragging$, this.elements?.changes.pipe(startWith(this.elements)) ?? of(null))
314
+ merge(fromEvent(scrollElement, 'scroll'), this._isCursorDragging$, elements.changes.pipe(startWith(elements)) ?? of(null))
232
315
  .pipe(debounceTime(300), takeUntil(this._destroy$), tap(() => {
233
- const elements = this.elements
316
+ const els = elements
234
317
  ?.toArray()
235
318
  .map((e) => e?.elementRef.nativeElement)
236
319
  .filter((e) => !!e) ?? [];
237
- if (!elements.length) {
320
+ if (!els.length) {
238
321
  this._latestVisibilityStates$.next([]);
239
322
  return;
240
323
  }
241
324
  const states = getElementVisibleStates({
242
- elements,
325
+ elements: els,
243
326
  container: scrollElement,
244
327
  });
245
- const prop = this.direction === 'horizontal' ? 'inlineIntersection' : 'blockIntersection';
328
+ const prop = this.direction() === 'horizontal' ? 'inlineIntersection' : 'blockIntersection';
246
329
  const stateClass = `et-element--is-intersecting`;
247
330
  for (const state of states) {
248
331
  if (state[prop] === 100) {
@@ -263,7 +346,7 @@ export class ScrollableComponent {
263
346
  });
264
347
  this.intersectionChange.emit(intersectionChanges);
265
348
  this._latestVisibilityStates$.next(intersectionChanges);
266
- if (isSnapping || this._isCursorDragging$.value || !this.snap)
349
+ if (isSnapping || this._isCursorDragging$.value || !this.snap())
267
350
  return;
268
351
  const prev = this.previousPartialIntersection;
269
352
  const next = this.nextPartialIntersection;
@@ -283,10 +366,10 @@ export class ScrollableComponent {
283
366
  scrollToElement({
284
367
  container: scrollElement,
285
368
  element: highestIntersecting.element,
286
- direction: this.direction === 'horizontal' ? 'inline' : 'block',
369
+ direction: this.direction() === 'horizontal' ? 'inline' : 'block',
287
370
  origin,
288
- scrollBlockMargin: this.direction === 'horizontal' ? 0 : this.scrollMargin,
289
- scrollInlineMargin: this.direction === 'horizontal' ? this.scrollMargin : 0,
371
+ scrollBlockMargin: this.direction() === 'horizontal' ? 0 : this.scrollMargin(),
372
+ scrollInlineMargin: this.direction() === 'horizontal' ? this.scrollMargin() : 0,
290
373
  });
291
374
  isSnapping = true;
292
375
  window.clearTimeout(snapTimeout);
@@ -296,81 +379,71 @@ export class ScrollableComponent {
296
379
  }))
297
380
  .subscribe();
298
381
  }
299
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.1", ngImport: i0, type: ScrollableComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
300
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "17.0.1", type: ScrollableComponent, isStandalone: true, selector: "et-scrollable", inputs: { itemSize: "itemSize", direction: "direction", scrollableRole: "scrollableRole", scrollableClass: "scrollableClass", renderMasks: ["renderMasks", "renderMasks", booleanAttribute], renderButtons: ["renderButtons", "renderButtons", booleanAttribute], renderScrollbars: ["renderScrollbars", "renderScrollbars", booleanAttribute], stickyButtons: ["stickyButtons", "stickyButtons", booleanAttribute], cursorDragScroll: ["cursorDragScroll", "cursorDragScroll", booleanAttribute], disableActiveElementScrolling: ["disableActiveElementScrolling", "disableActiveElementScrolling", booleanAttribute], scrollMode: "scrollMode", snap: ["snap", "snap", booleanAttribute], scrollMargin: ["scrollMargin", "scrollMargin", numberAttribute] }, outputs: { scrollStateChange: "scrollStateChange", intersectionChange: "intersectionChange" }, host: { properties: { "attr.item-size": "this.itemSize", "attr.direction": "this.direction", "attr.render-scrollbars": "this.renderScrollbars", "attr.sticky-buttons": "this.stickyButtons" }, classAttribute: "et-scrollable" }, queries: [{ propertyName: "activeElements", predicate: IS_ACTIVE_ELEMENT, descendants: true }, { propertyName: "elements", predicate: IS_ELEMENT, descendants: true }], viewQueries: [{ propertyName: "scrollable", first: true, predicate: ["scrollable"], descendants: true, static: true }, { propertyName: "scrollableList", predicate: ["scrollable"], descendants: true }, { propertyName: "firstElementList", predicate: ["firstElement"], descendants: true }, { propertyName: "lastElementList", predicate: ["lastElement"], descendants: true }], ngImport: i0, template: "<div\n #scrollable\n [attr.role]=\"scrollableRole ?? undefined\"\n [etCursorDragScroll]=\"cursorDragScroll\"\n [allowedDirection]=\"direction\"\n (cursorDragStart)=\"setIsCursorDragging(true)\"\n (cursorDragEnd)=\"setIsCursorDragging(false)\"\n class=\"et-scrollable-container-outer\"\n>\n <div [ngClass]=\"scrollableClass\" class=\"et-scrollable-container\">\n <div #firstElement class=\"et-scroll-observer-first-element\"></div>\n <ng-content />\n <div #lastElement class=\"et-scroll-observer-last-element\"></div>\n </div>\n</div>\n\n<div *ngIf=\"renderMasks\" class=\"et-scrollable-masks\">\n <div class=\"et-scrollable-mask et-scrollable-mask--start\"></div>\n <div class=\"et-scrollable-mask et-scrollable-mask--end\"></div>\n</div>\n\n<div *ngIf=\"renderButtons\" class=\"et-scrollable-buttons\">\n <button\n (click)=\"scrollToStartDirection()\"\n class=\"et-scrollable-button et-scrollable-button--start\"\n aria-hidden=\"true\"\n type=\"button\"\n tabindex=\"-1\"\n >\n <et-chevron-icon />\n </button>\n <button\n (click)=\"scrollToStartEnd()\"\n class=\"et-scrollable-button et-scrollable-button--end\"\n aria-hidden=\"true\"\n type=\"button\"\n tabindex=\"-1\"\n >\n <et-chevron-icon />\n </button>\n</div>\n", styles: [".et-scrollable{--mask: #121212 0, transparent 100%;--mask-size: 25px;--_auto-size: min-content;--_flow: column;display:grid;position:relative}.et-scrollable[item-size=same]{--_auto-size: 1fr}.et-scrollable[item-size=full]{--_auto-size: 100%}.et-scrollable[render-scrollbars=false] .et-scrollable-container-outer{scrollbar-width:none}.et-scrollable[render-scrollbars=false] .et-scrollable-container-outer::-webkit-scrollbar{display:none}.et-scrollable[direction=horizontal] .et-scrollable-container-outer{overflow-x:auto;overflow-y:hidden;grid-template-columns:auto 1fr auto}.et-scrollable[direction=horizontal] .et-scrollable-container{grid-auto-columns:var(--_auto-size)}.et-scrollable[direction=horizontal] .et-scrollable-mask,.et-scrollable[direction=horizontal] .et-scrollable-button{inline-size:var(--mask-size);block-size:100%}.et-scrollable[direction=horizontal] .et-scrollable-mask--start,.et-scrollable[direction=horizontal] .et-scrollable-button--start{inset-block-start:0;inset-inline:0 0}.et-scrollable[direction=horizontal] .et-scrollable-mask--end,.et-scrollable[direction=horizontal] .et-scrollable-button--end{inset-block-start:0;inset-inline:calc(100% - 40px) 0}.et-scrollable[direction=horizontal] .et-scrollable-mask--start{background:linear-gradient(to right,var(--mask))}.et-scrollable[direction=horizontal] .et-scrollable-mask--end{background:linear-gradient(to left,var(--mask));inset-inline:calc(100% - var(--mask-size)) 100%}.et-scrollable[direction=horizontal] .et-scrollable-button--start{inset-block-start:calc(50% - 20px);transform:rotate(-90deg)}.et-scrollable[direction=horizontal] .et-scrollable-button--end{inset-block-start:calc(50% - 20px);transform:rotate(90deg)}.et-scrollable[direction=vertical]{--_flow: row}.et-scrollable[direction=vertical] .et-scrollable-container-outer{overflow-x:hidden;overflow-y:auto;grid-template-rows:auto 1fr auto}.et-scrollable[direction=vertical] .et-scrollable-container{grid-auto-rows:var(--_auto-size)}.et-scrollable[direction=vertical] .et-scrollable-mask,.et-scrollable[direction=vertical] .et-scrollable-button{block-size:var(--mask-size);inline-size:100%}.et-scrollable[direction=vertical] .et-scrollable-mask--start,.et-scrollable[direction=vertical] .et-scrollable-button--start{inset-block-start:0;inset-inline-start:0}.et-scrollable[direction=vertical] .et-scrollable-mask--end,.et-scrollable[direction=vertical] .et-scrollable-button--end{inset-block-end:0;inset-inline-start:0}.et-scrollable[direction=vertical] .et-scrollable-mask--start{background:linear-gradient(to bottom,var(--mask))}.et-scrollable[direction=vertical] .et-scrollable-mask--end{background:linear-gradient(to top,var(--mask))}.et-scrollable[direction=vertical] .et-scrollable-button--start{inset-inline-start:calc(50% - 20px);transform:rotate(0)}.et-scrollable[direction=vertical] .et-scrollable-button--end{inset-inline-start:calc(50% - 20px);transform:rotate(180deg)}.et-scrollable[at-start=false] .et-scrollable-masks .et-scrollable-mask--start,.et-scrollable[at-start=false] .et-scrollable-buttons .et-scrollable-button--start{opacity:1}.et-scrollable[at-start=false] .et-scrollable-buttons .et-scrollable-button--start{pointer-events:all}.et-scrollable[at-end=false] .et-scrollable-masks .et-scrollable-mask--end,.et-scrollable[at-end=false] .et-scrollable-buttons .et-scrollable-button--end{opacity:1}.et-scrollable[at-end=false] .et-scrollable-buttons .et-scrollable-button--end{pointer-events:all}.et-scrollable .et-scrollable-container-outer{overflow:auto;display:grid;grid-row:1/1;grid-column:1/1}.et-scrollable .et-scroll-observer-first-element,.et-scrollable .et-scroll-observer-last-element{position:absolute;block-size:100%;inline-size:1px;pointer-events:none}.et-scrollable .et-scroll-observer-first-element{inset-inline-start:1px}.et-scrollable .et-scroll-observer-last-element{inset-inline-end:1px}.et-scrollable .et-scrollable-container{display:grid;grid-auto-flow:var(--_flow);position:relative}.et-scrollable[animate-overlays=true] .et-scrollable-mask,.et-scrollable[animate-overlays=true] .et-scrollable-button{transition:opacity .3s var(--ease-5)}.et-scrollable .et-scrollable-masks,.et-scrollable .et-scrollable-buttons{grid-row:1/1;grid-column:1/1;pointer-events:none}.et-scrollable .et-scrollable-masks .et-scrollable-mask,.et-scrollable .et-scrollable-masks .et-scrollable-button,.et-scrollable .et-scrollable-buttons .et-scrollable-mask,.et-scrollable .et-scrollable-buttons .et-scrollable-button{position:absolute;opacity:0}.et-scrollable .et-scrollable-buttons .et-scrollable-button{background:transparent;border:none;padding:12px;inline-size:40px;block-size:40px;border-radius:4px;cursor:pointer}.et-scrollable .et-scrollable-buttons .et-scrollable-button .et-chevron-icon{pointer-events:none}.et-scrollable .et-scrollable-buttons .et-scrollable-button .et-scrollable-button--start{inset-inline:0 0}.et-scrollable .et-scrollable-buttons .et-scrollable-button .et-scrollable-button--end{inset-inline:calc(100% - 40px) 0}.et-scrollable[sticky-buttons=true]{--_sticky-margin: 10%}.et-scrollable[sticky-buttons=true] .et-scrollable-button{position:sticky}.et-scrollable[sticky-buttons=true][direction=horizontal] .et-scrollable-buttons{margin-block:var(--_sticky-margin)}.et-scrollable[sticky-buttons=true][direction=vertical] .et-scrollable-buttons{margin-inline:var(--_sticky-margin)}.et-scrollable[sticky-buttons=true][direction=vertical] .et-scrollable-buttons .et-scrollable-button--end{inset-block-start:100%}\n"], dependencies: [{ kind: "directive", type: CursorDragScrollDirective, selector: "[etCursorDragScroll]", inputs: ["etCursorDragScroll", "allowedDirection"], outputs: ["cursorDragStart", "cursorDragMove", "cursorDragEnd"], exportAs: ["etCursorDragScroll"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: ChevronIconComponent, selector: "et-chevron-icon" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
382
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: ScrollableComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
383
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.0.2", type: ScrollableComponent, isStandalone: true, selector: "et-scrollable", inputs: { _itemSize: ["itemSize", "_itemSize"], _direction: ["direction", "_direction"], _scrollableRole: ["scrollableRole", "_scrollableRole"], _scrollableClass: ["scrollableClass", "_scrollableClass"], _renderMasks: ["renderMasks", "_renderMasks", booleanAttribute], _renderButtons: ["renderButtons", "_renderButtons", booleanAttribute], _renderScrollbars: ["renderScrollbars", "_renderScrollbars", booleanAttribute], _stickyButtons: ["stickyButtons", "_stickyButtons", booleanAttribute], _cursorDragScroll: ["cursorDragScroll", "_cursorDragScroll", booleanAttribute], _disableActiveElementScrolling: ["disableActiveElementScrolling", "_disableActiveElementScrolling", booleanAttribute], _scrollMode: ["scrollMode", "_scrollMode"], _snap: ["snap", "_snap", booleanAttribute], _scrollMargin: ["scrollMargin", "_scrollMargin", numberAttribute] }, outputs: { scrollStateChange: "scrollStateChange", intersectionChange: "intersectionChange" }, host: { classAttribute: "et-scrollable" }, queries: [{ propertyName: "_activeElementList", predicate: IS_ACTIVE_ELEMENT, descendants: true }, { propertyName: "_elementList", predicate: IS_ELEMENT, descendants: true }], viewQueries: [{ propertyName: "_scrollable", first: true, predicate: ["scrollable"], descendants: true, static: true }, { propertyName: "_firstElement", first: true, predicate: ["firstElement"], descendants: true, static: true }, { propertyName: "_lastElement", first: true, predicate: ["lastElement"], descendants: true, static: true }], ngImport: i0, template: "<div\n #scrollable\n [attr.role]=\"scrollableRole() ?? undefined\"\n [etCursorDragScroll]=\"cursorDragScroll()\"\n [allowedDirection]=\"direction()\"\n (cursorDragStart)=\"setIsCursorDragging(true)\"\n (cursorDragEnd)=\"setIsCursorDragging(false)\"\n class=\"et-scrollable-container-outer\"\n>\n <div [ngClass]=\"scrollableClass()\" class=\"et-scrollable-container\">\n <div #firstElement class=\"et-scroll-observer-first-element\"></div>\n <ng-content />\n <div #lastElement class=\"et-scroll-observer-last-element\"></div>\n </div>\n</div>\n\n@if (renderMasks()) {\n <div class=\"et-scrollable-masks\">\n <div class=\"et-scrollable-mask et-scrollable-mask--start\"></div>\n <div class=\"et-scrollable-mask et-scrollable-mask--end\"></div>\n </div>\n}\n\n@if (renderButtons()) {\n <div class=\"et-scrollable-buttons\">\n <button\n (click)=\"scrollToStartDirection()\"\n class=\"et-scrollable-button et-scrollable-button--start\"\n aria-hidden=\"true\"\n type=\"button\"\n tabindex=\"-1\"\n >\n <et-chevron-icon />\n </button>\n <button\n (click)=\"scrollToStartEnd()\"\n class=\"et-scrollable-button et-scrollable-button--end\"\n aria-hidden=\"true\"\n type=\"button\"\n tabindex=\"-1\"\n >\n <et-chevron-icon />\n </button>\n </div>\n}\n", styles: [".et-scrollable{--mask: #121212 0, transparent 100%;--mask-size: 25px;--_auto-size: min-content;--_flow: column;display:grid;position:relative}.et-scrollable[item-size=same]{--_auto-size: 1fr}.et-scrollable[item-size=full]{--_auto-size: 100%}.et-scrollable[render-scrollbars=false] .et-scrollable-container-outer{scrollbar-width:none}.et-scrollable[render-scrollbars=false] .et-scrollable-container-outer::-webkit-scrollbar{display:none}.et-scrollable[direction=horizontal] .et-scrollable-container-outer{overflow-x:auto;overflow-y:hidden}.et-scrollable[direction=horizontal] .et-scrollable-container{grid-auto-columns:var(--_auto-size)}.et-scrollable[direction=horizontal] .et-scrollable-mask,.et-scrollable[direction=horizontal] .et-scrollable-button{inline-size:var(--mask-size);block-size:100%}.et-scrollable[direction=horizontal] .et-scrollable-mask--start,.et-scrollable[direction=horizontal] .et-scrollable-button--start{inset-block-start:0;inset-inline:0 0}.et-scrollable[direction=horizontal] .et-scrollable-mask--end,.et-scrollable[direction=horizontal] .et-scrollable-button--end{inset-block-start:0;inset-inline:calc(100% - 40px) 0}.et-scrollable[direction=horizontal] .et-scrollable-mask--start{background:linear-gradient(to right,var(--mask))}.et-scrollable[direction=horizontal] .et-scrollable-mask--end{background:linear-gradient(to left,var(--mask));inset-inline:calc(100% - var(--mask-size)) 100%}.et-scrollable[direction=horizontal] .et-scrollable-button--start{inset-block-start:calc(50% - 20px);transform:rotate(-90deg)}.et-scrollable[direction=horizontal] .et-scrollable-button--end{inset-block-start:calc(50% - 20px);transform:rotate(90deg)}.et-scrollable[direction=vertical]{--_flow: row}.et-scrollable[direction=vertical] .et-scrollable-container-outer{overflow-x:hidden;overflow-y:auto}.et-scrollable[direction=vertical] .et-scrollable-container{grid-auto-rows:var(--_auto-size)}.et-scrollable[direction=vertical] .et-scrollable-mask,.et-scrollable[direction=vertical] .et-scrollable-button{block-size:var(--mask-size);inline-size:100%}.et-scrollable[direction=vertical] .et-scrollable-mask--start,.et-scrollable[direction=vertical] .et-scrollable-button--start{inset-block-start:0;inset-inline-start:0}.et-scrollable[direction=vertical] .et-scrollable-mask--end,.et-scrollable[direction=vertical] .et-scrollable-button--end{inset-block-end:0;inset-inline-start:0}.et-scrollable[direction=vertical] .et-scrollable-mask--start{background:linear-gradient(to bottom,var(--mask))}.et-scrollable[direction=vertical] .et-scrollable-mask--end{background:linear-gradient(to top,var(--mask))}.et-scrollable[direction=vertical] .et-scrollable-button--start{inset-inline-start:calc(50% - 20px);transform:rotate(0)}.et-scrollable[direction=vertical] .et-scrollable-button--end{inset-inline-start:calc(50% - 20px);transform:rotate(180deg)}.et-scrollable:not(.et-scrollable--is-at-start) .et-scrollable-masks .et-scrollable-mask--start,.et-scrollable:not(.et-scrollable--is-at-start) .et-scrollable-buttons .et-scrollable-button--start{opacity:1}.et-scrollable:not(.et-scrollable--is-at-start) .et-scrollable-buttons .et-scrollable-button--start{pointer-events:all}.et-scrollable:not(.et-scrollable--is-at-end) .et-scrollable-masks .et-scrollable-mask--end,.et-scrollable:not(.et-scrollable--is-at-end) .et-scrollable-buttons .et-scrollable-button--end{opacity:1}.et-scrollable:not(.et-scrollable--is-at-end) .et-scrollable-buttons .et-scrollable-button--end{pointer-events:all}.et-scrollable .et-scrollable-container-outer{overflow:auto;display:grid;grid-row:1/1;grid-column:1/1}.et-scrollable .et-scroll-observer-first-element,.et-scrollable .et-scroll-observer-last-element{position:absolute;block-size:100%;inline-size:1px;pointer-events:none}.et-scrollable .et-scroll-observer-first-element{inset-inline-start:1px}.et-scrollable .et-scroll-observer-last-element{inset-inline-end:1px}.et-scrollable .et-scrollable-container{display:grid;grid-auto-flow:var(--_flow);position:relative}.et-scrollable .et-scrollable-masks,.et-scrollable .et-scrollable-buttons{grid-row:1/1;grid-column:1/1;pointer-events:none}.et-scrollable .et-scrollable-masks .et-scrollable-mask,.et-scrollable .et-scrollable-masks .et-scrollable-button,.et-scrollable .et-scrollable-buttons .et-scrollable-mask,.et-scrollable .et-scrollable-buttons .et-scrollable-button{position:absolute;opacity:0}.et-scrollable.et-scrollable--can-scroll.et-scrollable--enable-overlay-animations .et-scrollable-mask,.et-scrollable.et-scrollable--can-scroll.et-scrollable--enable-overlay-animations .et-scrollable-button{transition:opacity .3s var(--ease-5)}.et-scrollable .et-scrollable-buttons .et-scrollable-button{background:transparent;border:none;padding:12px;inline-size:40px;block-size:40px;border-radius:4px;cursor:pointer}.et-scrollable .et-scrollable-buttons .et-scrollable-button .et-chevron-icon{pointer-events:none}.et-scrollable .et-scrollable-buttons .et-scrollable-button .et-scrollable-button--start{inset-inline:0 0}.et-scrollable .et-scrollable-buttons .et-scrollable-button .et-scrollable-button--end{inset-inline:calc(100% - 40px) 0}.et-scrollable[sticky-buttons=true]{--_sticky-margin: 10%}.et-scrollable[sticky-buttons=true] .et-scrollable-button{position:sticky}.et-scrollable[sticky-buttons=true][direction=horizontal] .et-scrollable-buttons{margin-block:var(--_sticky-margin)}.et-scrollable[sticky-buttons=true][direction=vertical] .et-scrollable-buttons{margin-inline:var(--_sticky-margin)}.et-scrollable[sticky-buttons=true][direction=vertical] .et-scrollable-buttons .et-scrollable-button--end{inset-block-start:100%}\n"], dependencies: [{ kind: "directive", type: CursorDragScrollDirective, selector: "[etCursorDragScroll]", inputs: ["etCursorDragScroll", "allowedDirection"], outputs: ["cursorDragStart", "cursorDragMove", "cursorDragEnd"], exportAs: ["etCursorDragScroll"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: ChevronIconComponent, selector: "et-chevron-icon" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
301
384
  }
302
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.1", ngImport: i0, type: ScrollableComponent, decorators: [{
385
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: ScrollableComponent, decorators: [{
303
386
  type: Component,
304
- args: [{ selector: 'et-scrollable', standalone: true, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, imports: [CursorDragScrollDirective, ObserveScrollStateDirective, NgClass, NgIf, LetDirective, ChevronIconComponent], host: {
387
+ args: [{ selector: 'et-scrollable', standalone: true, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, imports: [CursorDragScrollDirective, ObserveScrollStateDirective, NgClass, LetDirective, ChevronIconComponent], host: {
305
388
  class: 'et-scrollable',
306
- }, template: "<div\n #scrollable\n [attr.role]=\"scrollableRole ?? undefined\"\n [etCursorDragScroll]=\"cursorDragScroll\"\n [allowedDirection]=\"direction\"\n (cursorDragStart)=\"setIsCursorDragging(true)\"\n (cursorDragEnd)=\"setIsCursorDragging(false)\"\n class=\"et-scrollable-container-outer\"\n>\n <div [ngClass]=\"scrollableClass\" class=\"et-scrollable-container\">\n <div #firstElement class=\"et-scroll-observer-first-element\"></div>\n <ng-content />\n <div #lastElement class=\"et-scroll-observer-last-element\"></div>\n </div>\n</div>\n\n<div *ngIf=\"renderMasks\" class=\"et-scrollable-masks\">\n <div class=\"et-scrollable-mask et-scrollable-mask--start\"></div>\n <div class=\"et-scrollable-mask et-scrollable-mask--end\"></div>\n</div>\n\n<div *ngIf=\"renderButtons\" class=\"et-scrollable-buttons\">\n <button\n (click)=\"scrollToStartDirection()\"\n class=\"et-scrollable-button et-scrollable-button--start\"\n aria-hidden=\"true\"\n type=\"button\"\n tabindex=\"-1\"\n >\n <et-chevron-icon />\n </button>\n <button\n (click)=\"scrollToStartEnd()\"\n class=\"et-scrollable-button et-scrollable-button--end\"\n aria-hidden=\"true\"\n type=\"button\"\n tabindex=\"-1\"\n >\n <et-chevron-icon />\n </button>\n</div>\n", styles: [".et-scrollable{--mask: #121212 0, transparent 100%;--mask-size: 25px;--_auto-size: min-content;--_flow: column;display:grid;position:relative}.et-scrollable[item-size=same]{--_auto-size: 1fr}.et-scrollable[item-size=full]{--_auto-size: 100%}.et-scrollable[render-scrollbars=false] .et-scrollable-container-outer{scrollbar-width:none}.et-scrollable[render-scrollbars=false] .et-scrollable-container-outer::-webkit-scrollbar{display:none}.et-scrollable[direction=horizontal] .et-scrollable-container-outer{overflow-x:auto;overflow-y:hidden;grid-template-columns:auto 1fr auto}.et-scrollable[direction=horizontal] .et-scrollable-container{grid-auto-columns:var(--_auto-size)}.et-scrollable[direction=horizontal] .et-scrollable-mask,.et-scrollable[direction=horizontal] .et-scrollable-button{inline-size:var(--mask-size);block-size:100%}.et-scrollable[direction=horizontal] .et-scrollable-mask--start,.et-scrollable[direction=horizontal] .et-scrollable-button--start{inset-block-start:0;inset-inline:0 0}.et-scrollable[direction=horizontal] .et-scrollable-mask--end,.et-scrollable[direction=horizontal] .et-scrollable-button--end{inset-block-start:0;inset-inline:calc(100% - 40px) 0}.et-scrollable[direction=horizontal] .et-scrollable-mask--start{background:linear-gradient(to right,var(--mask))}.et-scrollable[direction=horizontal] .et-scrollable-mask--end{background:linear-gradient(to left,var(--mask));inset-inline:calc(100% - var(--mask-size)) 100%}.et-scrollable[direction=horizontal] .et-scrollable-button--start{inset-block-start:calc(50% - 20px);transform:rotate(-90deg)}.et-scrollable[direction=horizontal] .et-scrollable-button--end{inset-block-start:calc(50% - 20px);transform:rotate(90deg)}.et-scrollable[direction=vertical]{--_flow: row}.et-scrollable[direction=vertical] .et-scrollable-container-outer{overflow-x:hidden;overflow-y:auto;grid-template-rows:auto 1fr auto}.et-scrollable[direction=vertical] .et-scrollable-container{grid-auto-rows:var(--_auto-size)}.et-scrollable[direction=vertical] .et-scrollable-mask,.et-scrollable[direction=vertical] .et-scrollable-button{block-size:var(--mask-size);inline-size:100%}.et-scrollable[direction=vertical] .et-scrollable-mask--start,.et-scrollable[direction=vertical] .et-scrollable-button--start{inset-block-start:0;inset-inline-start:0}.et-scrollable[direction=vertical] .et-scrollable-mask--end,.et-scrollable[direction=vertical] .et-scrollable-button--end{inset-block-end:0;inset-inline-start:0}.et-scrollable[direction=vertical] .et-scrollable-mask--start{background:linear-gradient(to bottom,var(--mask))}.et-scrollable[direction=vertical] .et-scrollable-mask--end{background:linear-gradient(to top,var(--mask))}.et-scrollable[direction=vertical] .et-scrollable-button--start{inset-inline-start:calc(50% - 20px);transform:rotate(0)}.et-scrollable[direction=vertical] .et-scrollable-button--end{inset-inline-start:calc(50% - 20px);transform:rotate(180deg)}.et-scrollable[at-start=false] .et-scrollable-masks .et-scrollable-mask--start,.et-scrollable[at-start=false] .et-scrollable-buttons .et-scrollable-button--start{opacity:1}.et-scrollable[at-start=false] .et-scrollable-buttons .et-scrollable-button--start{pointer-events:all}.et-scrollable[at-end=false] .et-scrollable-masks .et-scrollable-mask--end,.et-scrollable[at-end=false] .et-scrollable-buttons .et-scrollable-button--end{opacity:1}.et-scrollable[at-end=false] .et-scrollable-buttons .et-scrollable-button--end{pointer-events:all}.et-scrollable .et-scrollable-container-outer{overflow:auto;display:grid;grid-row:1/1;grid-column:1/1}.et-scrollable .et-scroll-observer-first-element,.et-scrollable .et-scroll-observer-last-element{position:absolute;block-size:100%;inline-size:1px;pointer-events:none}.et-scrollable .et-scroll-observer-first-element{inset-inline-start:1px}.et-scrollable .et-scroll-observer-last-element{inset-inline-end:1px}.et-scrollable .et-scrollable-container{display:grid;grid-auto-flow:var(--_flow);position:relative}.et-scrollable[animate-overlays=true] .et-scrollable-mask,.et-scrollable[animate-overlays=true] .et-scrollable-button{transition:opacity .3s var(--ease-5)}.et-scrollable .et-scrollable-masks,.et-scrollable .et-scrollable-buttons{grid-row:1/1;grid-column:1/1;pointer-events:none}.et-scrollable .et-scrollable-masks .et-scrollable-mask,.et-scrollable .et-scrollable-masks .et-scrollable-button,.et-scrollable .et-scrollable-buttons .et-scrollable-mask,.et-scrollable .et-scrollable-buttons .et-scrollable-button{position:absolute;opacity:0}.et-scrollable .et-scrollable-buttons .et-scrollable-button{background:transparent;border:none;padding:12px;inline-size:40px;block-size:40px;border-radius:4px;cursor:pointer}.et-scrollable .et-scrollable-buttons .et-scrollable-button .et-chevron-icon{pointer-events:none}.et-scrollable .et-scrollable-buttons .et-scrollable-button .et-scrollable-button--start{inset-inline:0 0}.et-scrollable .et-scrollable-buttons .et-scrollable-button .et-scrollable-button--end{inset-inline:calc(100% - 40px) 0}.et-scrollable[sticky-buttons=true]{--_sticky-margin: 10%}.et-scrollable[sticky-buttons=true] .et-scrollable-button{position:sticky}.et-scrollable[sticky-buttons=true][direction=horizontal] .et-scrollable-buttons{margin-block:var(--_sticky-margin)}.et-scrollable[sticky-buttons=true][direction=vertical] .et-scrollable-buttons{margin-inline:var(--_sticky-margin)}.et-scrollable[sticky-buttons=true][direction=vertical] .et-scrollable-buttons .et-scrollable-button--end{inset-block-start:100%}\n"] }]
307
- }], ctorParameters: () => [], propDecorators: { itemSize: [{
308
- type: Input
309
- }, {
310
- type: HostBinding,
311
- args: ['attr.item-size']
312
- }], direction: [{
313
- type: Input
314
- }, {
315
- type: HostBinding,
316
- args: ['attr.direction']
317
- }], scrollableRole: [{
318
- type: Input
319
- }], scrollableClass: [{
320
- type: Input
321
- }], renderMasks: [{
389
+ }, template: "<div\n #scrollable\n [attr.role]=\"scrollableRole() ?? undefined\"\n [etCursorDragScroll]=\"cursorDragScroll()\"\n [allowedDirection]=\"direction()\"\n (cursorDragStart)=\"setIsCursorDragging(true)\"\n (cursorDragEnd)=\"setIsCursorDragging(false)\"\n class=\"et-scrollable-container-outer\"\n>\n <div [ngClass]=\"scrollableClass()\" class=\"et-scrollable-container\">\n <div #firstElement class=\"et-scroll-observer-first-element\"></div>\n <ng-content />\n <div #lastElement class=\"et-scroll-observer-last-element\"></div>\n </div>\n</div>\n\n@if (renderMasks()) {\n <div class=\"et-scrollable-masks\">\n <div class=\"et-scrollable-mask et-scrollable-mask--start\"></div>\n <div class=\"et-scrollable-mask et-scrollable-mask--end\"></div>\n </div>\n}\n\n@if (renderButtons()) {\n <div class=\"et-scrollable-buttons\">\n <button\n (click)=\"scrollToStartDirection()\"\n class=\"et-scrollable-button et-scrollable-button--start\"\n aria-hidden=\"true\"\n type=\"button\"\n tabindex=\"-1\"\n >\n <et-chevron-icon />\n </button>\n <button\n (click)=\"scrollToStartEnd()\"\n class=\"et-scrollable-button et-scrollable-button--end\"\n aria-hidden=\"true\"\n type=\"button\"\n tabindex=\"-1\"\n >\n <et-chevron-icon />\n </button>\n </div>\n}\n", styles: [".et-scrollable{--mask: #121212 0, transparent 100%;--mask-size: 25px;--_auto-size: min-content;--_flow: column;display:grid;position:relative}.et-scrollable[item-size=same]{--_auto-size: 1fr}.et-scrollable[item-size=full]{--_auto-size: 100%}.et-scrollable[render-scrollbars=false] .et-scrollable-container-outer{scrollbar-width:none}.et-scrollable[render-scrollbars=false] .et-scrollable-container-outer::-webkit-scrollbar{display:none}.et-scrollable[direction=horizontal] .et-scrollable-container-outer{overflow-x:auto;overflow-y:hidden}.et-scrollable[direction=horizontal] .et-scrollable-container{grid-auto-columns:var(--_auto-size)}.et-scrollable[direction=horizontal] .et-scrollable-mask,.et-scrollable[direction=horizontal] .et-scrollable-button{inline-size:var(--mask-size);block-size:100%}.et-scrollable[direction=horizontal] .et-scrollable-mask--start,.et-scrollable[direction=horizontal] .et-scrollable-button--start{inset-block-start:0;inset-inline:0 0}.et-scrollable[direction=horizontal] .et-scrollable-mask--end,.et-scrollable[direction=horizontal] .et-scrollable-button--end{inset-block-start:0;inset-inline:calc(100% - 40px) 0}.et-scrollable[direction=horizontal] .et-scrollable-mask--start{background:linear-gradient(to right,var(--mask))}.et-scrollable[direction=horizontal] .et-scrollable-mask--end{background:linear-gradient(to left,var(--mask));inset-inline:calc(100% - var(--mask-size)) 100%}.et-scrollable[direction=horizontal] .et-scrollable-button--start{inset-block-start:calc(50% - 20px);transform:rotate(-90deg)}.et-scrollable[direction=horizontal] .et-scrollable-button--end{inset-block-start:calc(50% - 20px);transform:rotate(90deg)}.et-scrollable[direction=vertical]{--_flow: row}.et-scrollable[direction=vertical] .et-scrollable-container-outer{overflow-x:hidden;overflow-y:auto}.et-scrollable[direction=vertical] .et-scrollable-container{grid-auto-rows:var(--_auto-size)}.et-scrollable[direction=vertical] .et-scrollable-mask,.et-scrollable[direction=vertical] .et-scrollable-button{block-size:var(--mask-size);inline-size:100%}.et-scrollable[direction=vertical] .et-scrollable-mask--start,.et-scrollable[direction=vertical] .et-scrollable-button--start{inset-block-start:0;inset-inline-start:0}.et-scrollable[direction=vertical] .et-scrollable-mask--end,.et-scrollable[direction=vertical] .et-scrollable-button--end{inset-block-end:0;inset-inline-start:0}.et-scrollable[direction=vertical] .et-scrollable-mask--start{background:linear-gradient(to bottom,var(--mask))}.et-scrollable[direction=vertical] .et-scrollable-mask--end{background:linear-gradient(to top,var(--mask))}.et-scrollable[direction=vertical] .et-scrollable-button--start{inset-inline-start:calc(50% - 20px);transform:rotate(0)}.et-scrollable[direction=vertical] .et-scrollable-button--end{inset-inline-start:calc(50% - 20px);transform:rotate(180deg)}.et-scrollable:not(.et-scrollable--is-at-start) .et-scrollable-masks .et-scrollable-mask--start,.et-scrollable:not(.et-scrollable--is-at-start) .et-scrollable-buttons .et-scrollable-button--start{opacity:1}.et-scrollable:not(.et-scrollable--is-at-start) .et-scrollable-buttons .et-scrollable-button--start{pointer-events:all}.et-scrollable:not(.et-scrollable--is-at-end) .et-scrollable-masks .et-scrollable-mask--end,.et-scrollable:not(.et-scrollable--is-at-end) .et-scrollable-buttons .et-scrollable-button--end{opacity:1}.et-scrollable:not(.et-scrollable--is-at-end) .et-scrollable-buttons .et-scrollable-button--end{pointer-events:all}.et-scrollable .et-scrollable-container-outer{overflow:auto;display:grid;grid-row:1/1;grid-column:1/1}.et-scrollable .et-scroll-observer-first-element,.et-scrollable .et-scroll-observer-last-element{position:absolute;block-size:100%;inline-size:1px;pointer-events:none}.et-scrollable .et-scroll-observer-first-element{inset-inline-start:1px}.et-scrollable .et-scroll-observer-last-element{inset-inline-end:1px}.et-scrollable .et-scrollable-container{display:grid;grid-auto-flow:var(--_flow);position:relative}.et-scrollable .et-scrollable-masks,.et-scrollable .et-scrollable-buttons{grid-row:1/1;grid-column:1/1;pointer-events:none}.et-scrollable .et-scrollable-masks .et-scrollable-mask,.et-scrollable .et-scrollable-masks .et-scrollable-button,.et-scrollable .et-scrollable-buttons .et-scrollable-mask,.et-scrollable .et-scrollable-buttons .et-scrollable-button{position:absolute;opacity:0}.et-scrollable.et-scrollable--can-scroll.et-scrollable--enable-overlay-animations .et-scrollable-mask,.et-scrollable.et-scrollable--can-scroll.et-scrollable--enable-overlay-animations .et-scrollable-button{transition:opacity .3s var(--ease-5)}.et-scrollable .et-scrollable-buttons .et-scrollable-button{background:transparent;border:none;padding:12px;inline-size:40px;block-size:40px;border-radius:4px;cursor:pointer}.et-scrollable .et-scrollable-buttons .et-scrollable-button .et-chevron-icon{pointer-events:none}.et-scrollable .et-scrollable-buttons .et-scrollable-button .et-scrollable-button--start{inset-inline:0 0}.et-scrollable .et-scrollable-buttons .et-scrollable-button .et-scrollable-button--end{inset-inline:calc(100% - 40px) 0}.et-scrollable[sticky-buttons=true]{--_sticky-margin: 10%}.et-scrollable[sticky-buttons=true] .et-scrollable-button{position:sticky}.et-scrollable[sticky-buttons=true][direction=horizontal] .et-scrollable-buttons{margin-block:var(--_sticky-margin)}.et-scrollable[sticky-buttons=true][direction=vertical] .et-scrollable-buttons{margin-inline:var(--_sticky-margin)}.et-scrollable[sticky-buttons=true][direction=vertical] .et-scrollable-buttons .et-scrollable-button--end{inset-block-start:100%}\n"] }]
390
+ }], ctorParameters: () => [], propDecorators: { _itemSize: [{
391
+ type: Input,
392
+ args: [{ alias: 'itemSize' }]
393
+ }], _direction: [{
394
+ type: Input,
395
+ args: [{ alias: 'direction' }]
396
+ }], _scrollableRole: [{
322
397
  type: Input,
323
- args: [{ transform: booleanAttribute }]
324
- }], renderButtons: [{
398
+ args: [{ alias: 'scrollableRole' }]
399
+ }], _scrollableClass: [{
325
400
  type: Input,
326
- args: [{ transform: booleanAttribute }]
327
- }], renderScrollbars: [{
401
+ args: [{ alias: 'scrollableClass' }]
402
+ }], _renderMasks: [{
328
403
  type: Input,
329
- args: [{ transform: booleanAttribute }]
330
- }, {
331
- type: HostBinding,
332
- args: ['attr.render-scrollbars']
333
- }], stickyButtons: [{
404
+ args: [{ transform: booleanAttribute, alias: 'renderMasks' }]
405
+ }], _renderButtons: [{
334
406
  type: Input,
335
- args: [{ transform: booleanAttribute }]
336
- }, {
337
- type: HostBinding,
338
- args: ['attr.sticky-buttons']
339
- }], cursorDragScroll: [{
407
+ args: [{ transform: booleanAttribute, alias: 'renderButtons' }]
408
+ }], _renderScrollbars: [{
340
409
  type: Input,
341
- args: [{ transform: booleanAttribute }]
342
- }], disableActiveElementScrolling: [{
410
+ args: [{ transform: booleanAttribute, alias: 'renderScrollbars' }]
411
+ }], _stickyButtons: [{
343
412
  type: Input,
344
- args: [{ transform: booleanAttribute }]
345
- }], scrollMode: [{
346
- type: Input
347
- }], snap: [{
413
+ args: [{ transform: booleanAttribute, alias: 'stickyButtons' }]
414
+ }], _cursorDragScroll: [{
348
415
  type: Input,
349
- args: [{ transform: booleanAttribute }]
350
- }], scrollMargin: [{
416
+ args: [{ transform: booleanAttribute, alias: 'cursorDragScroll' }]
417
+ }], _disableActiveElementScrolling: [{
351
418
  type: Input,
352
- args: [{ transform: numberAttribute }]
419
+ args: [{ transform: booleanAttribute, alias: 'disableActiveElementScrolling' }]
420
+ }], _scrollMode: [{
421
+ type: Input,
422
+ args: [{ alias: 'scrollMode' }]
423
+ }], _snap: [{
424
+ type: Input,
425
+ args: [{ transform: booleanAttribute, alias: 'snap' }]
426
+ }], _scrollMargin: [{
427
+ type: Input,
428
+ args: [{ transform: numberAttribute, alias: 'scrollMargin' }]
353
429
  }], scrollStateChange: [{
354
430
  type: Output
355
431
  }], intersectionChange: [{
356
432
  type: Output
357
- }], scrollable: [{
433
+ }], _scrollable: [{
358
434
  type: ViewChild,
359
435
  args: ['scrollable', { static: true }]
360
- }], scrollableList: [{
361
- type: ViewChildren,
362
- args: ['scrollable']
363
- }], firstElementList: [{
364
- type: ViewChildren,
365
- args: ['firstElement']
366
- }], lastElementList: [{
367
- type: ViewChildren,
368
- args: ['lastElement']
369
- }], activeElements: [{
436
+ }], _firstElement: [{
437
+ type: ViewChild,
438
+ args: ['firstElement', { static: true }]
439
+ }], _lastElement: [{
440
+ type: ViewChild,
441
+ args: ['lastElement', { static: true }]
442
+ }], _activeElementList: [{
370
443
  type: ContentChildren,
371
444
  args: [IS_ACTIVE_ELEMENT, { descendants: true }]
372
- }], elements: [{
445
+ }], _elementList: [{
373
446
  type: ContentChildren,
374
447
  args: [IS_ELEMENT, { descendants: true }]
375
448
  }] } });
376
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scrollable.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/cdk/src/lib/components/scrollable/components/scrollable/scrollable.component.ts","../../../../../../../../../libs/cdk/src/lib/components/scrollable/components/scrollable/scrollable.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,iBAAiB,CAAC;AAChD,OAAO,EAEL,uBAAuB,EACvB,SAAS,EACT,eAAe,EACf,UAAU,EACV,YAAY,EACZ,WAAW,EACX,KAAK,EACL,MAAM,EACN,SAAS,EACT,YAAY,EACZ,iBAAiB,EACjB,gBAAgB,EAChB,QAAQ,EACR,MAAM,EACN,MAAM,EACN,SAAS,EACT,eAAe,EACf,MAAM,GACP,MAAM,eAAe,CAAC;AACvB,OAAO,EACL,yBAAyB,EACzB,iBAAiB,EACjB,UAAU,EAGV,YAAY,EAEZ,2BAA2B,EAG3B,cAAc,EACd,aAAa,EACb,uBAAuB,EACvB,eAAe,EACf,yBAAyB,EACzB,wBAAwB,EACxB,oBAAoB,GACrB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,eAAe,EAAE,YAAY,EAAE,SAAS,EAAE,KAAK,EAAE,EAAE,EAAE,SAAS,EAAE,SAAS,EAAE,GAAG,EAAE,MAAM,MAAM,CAAC;AACtG,OAAO,EAAE,oBAAoB,EAAE,MAAM,gBAAgB,CAAC;;AAetD,MAAM,OAAO,mBAAmB;IA2D9B,IACc,cAAc,CAAC,IAA6C;QACxE,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IACjC,CAAC;IAGD,IACc,gBAAgB,CAAC,IAA6C;QAC1E,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IACnC,CAAC;IAGD,IACc,eAAe,CAAC,IAA6C;QACzE,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IAClC,CAAC;IASD,IAAI,0BAA0B;QAC5B,MAAM,QAAQ,GAAG,IAAI,CAAC,wBAAwB,CAAC,KAAK,CAAC;QAErD,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE;YACpB,OAAO,IAAI,CAAC;SACb;QAED,OAAO,QAAQ,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,EAAE;YACpC,IAAI,CAAC,IAAI,EAAE;gBACT,OAAO,IAAI,CAAC;aACb;YAED,OAAO,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC;QACvE,CAAC,CAAC,CAAC;IACL,CAAC;IAED,IAAI,uBAAuB;QACzB,MAAM,QAAQ,GAAG,IAAI,CAAC,wBAAwB,CAAC,KAAK,CAAC;QAErD,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE;YACpB,OAAO,IAAI,CAAC;SACb;QAED,MAAM,0BAA0B,GAAG,IAAI,CAAC,0BAA0B,CAAC;QAEnE,IAAI,CAAC,0BAA0B,EAAE;YAC/B,OAAO,IAAI,CAAC;SACb;QAED,MAAM,SAAS,GAAG,QAAQ,CAAC,KAAK,CAAC,0BAA0B,CAAC,KAAK,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC;QAEvG,IAAI,SAAS,KAAK,CAAC,CAAC,EAAE;YACpB,OAAO,IAAI,CAAC;SACb;QAED,MAAM,WAAW,GAAG,QAAQ,CAAC,0BAA0B,CAAC,KAAK,GAAG,SAAS,CAAC,CAAC;QAE3E,OAAO,WAAW,IAAI,IAAI,CAAC;IAC7B,CAAC;IAED,IAAI,2BAA2B;QAC7B,MAAM,QAAQ,GAAG,IAAI,CAAC,wBAAwB,CAAC,KAAK,CAAC;QAErD,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE;YACpB,OAAO,IAAI,CAAC;SACb;QAED,MAAM,0BAA0B,GAAG,IAAI,CAAC,0BAA0B,CAAC;QAEnE,IAAI,CAAC,0BAA0B,EAAE;YAC/B,OAAO,IAAI,CAAC;SACb;QAED,MAAM,aAAa,GAAG,QAAQ;aAC3B,KAAK,CAAC,CAAC,EAAE,0BAA0B,CAAC,KAAK,CAAC;aAC1C,OAAO,EAAE;aACT,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC;QAEvC,IAAI,aAAa,KAAK,CAAC,CAAC,EAAE;YACxB,OAAO,IAAI,CAAC;SACb;QAED,MAAM,eAAe,GAAG,QAAQ,CAAC,0BAA0B,CAAC,KAAK,GAAG,aAAa,GAAG,CAAC,CAAC,CAAC;QAEvF,OAAO,eAAe,IAAI,IAAI,CAAC;IACjC,CAAC;IAkCD;QArLiB,cAAS,GAAG,aAAa,EAAE,CAAC;QAC5B,gBAAW,GAAG,MAAM,CAA0B,UAAU,CAAC,CAAC;QAE1D,uBAAkB,GAAG,IAAI,eAAe,CAAU,KAAK,CAAC,CAAC;QACzD,6BAAwB,GAAG,IAAI,eAAe,CAAiC,EAAE,CAAC,CAAC;QAIpG,aAAQ,GAA6B,MAAM,CAAC;QAI5C,cAAS,GAA8B,YAAY,CAAC;QASpD,gBAAW,GAAG,IAAI,CAAC;QAGnB,kBAAa,GAAG,IAAI,CAAC;QAIrB,qBAAgB,GAAG,KAAK,CAAC;QAIzB,kBAAa,GAAG,KAAK,CAAC;QAGtB,qBAAgB,GAAG,IAAI,CAAC;QAGxB,kCAA6B,GAAG,KAAK,CAAC;QAGtC,eAAU,GAAyB,WAAW,CAAC;QAG/C,SAAI,GAAG,KAAK,CAAC;QAGb,iBAAY,GAAG,CAAC,CAAC;QAGR,sBAAiB,GAAG,IAAI,YAAY,EAA6B,CAAC;QAGlE,uBAAkB,GAAG,IAAI,YAAY,EAAkC,CAAC;QAShE,oBAAe,GAAG,MAAM,CAAiD,IAAI,CAAC,CAAC;QAM/E,sBAAiB,GAAG,MAAM,CAAiD,IAAI,CAAC,CAAC;QAMjF,qBAAgB,GAAG,MAAM,CAAiD,IAAI,CAAC,CAAC;QAGjG,mBAAc,GAAoD,IAAI,CAAC;QAGvE,aAAQ,GAA8C,IAAI,CAAC;QAqExC,yBAAoB,GAAG,wBAAwB,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;QACtE,6BAAwB,GAAG,yBAAyB,CAAC,IAAI,CAAC,iBAAiB,EAAE,IAAI,CAAC,eAAe,CAAC,CAAC;QACnG,4BAAuB,GAAG,yBAAyB,CAAC,IAAI,CAAC,gBAAgB,EAAE,IAAI,CAAC,eAAe,CAAC,CAAC;QAEjG,0BAAqB,GAAG,QAAQ,CACjD,GAAG,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,wBAAwB,EAAE,IAAI,CAAC,CAAC,IAAI,CAAC,uBAAuB,EAAE,CAC5E,CAAC;QAEiB,cAAS,GAAG,QAAQ,CAAC,GAAG,EAAE;YAC3C,MAAM,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC;YAE3B,IAAI,GAAG,KAAK,YAAY,EAAE;gBACxB,OAAO,IAAI,CAAC,oBAAoB,EAAE,CAAC,qBAAqB,CAAC;aAC1D;YAED,OAAO,IAAI,CAAC,oBAAoB,EAAE,CAAC,mBAAmB,CAAC;QACzD,CAAC,CAAC,CAAC;QAEgB,cAAS,GAAG,QAAQ,CAAC,GAAG,EAAE,CAC3C,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,wBAAwB,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,IAAI,CACzE,CAAC;QACiB,YAAO,GAAG,QAAQ,CAAC,GAAG,EAAE,CACzC,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,uBAAuB,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,IAAI,CACxE,CAAC;QAEiB,mBAAc,GAAG,oBAAoB,CAAC;YACvD,YAAY,EAAE,IAAI,CAAC,SAAS;YAC5B,UAAU,EAAE,IAAI,CAAC,SAAS;YAC1B,QAAQ,EAAE,IAAI,CAAC,OAAO;YACtB,kBAAkB,EAAE,IAAI,CAAC,qBAAqB;SAC/C,CAAC,CAAC;QAGD,MAAM,CAAC,GAAG,EAAE;YACV,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC;YACnC,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC;YAC/B,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC;YAEnC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC;gBAC1B,SAAS;gBACT,OAAO;gBACP,SAAS;aACV,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;IAED,kBAAkB;QAChB,IAAI,CAAC,IAAI,CAAC,cAAc,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAC1C,OAAO;SACR;QAED,IAAI,CAAC,cAAc,CAAC,OAAO;aACxB,IAAI,CACH,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,EAC9B,GAAG,CAAC,CAAC,cAAc,EAAE,EAAE;YACrB,IAAI,IAAI,CAAC,6BAA6B,EAAE;gBACtC,OAAO;aACR;YAED,MAAM,WAAW,GAAG,cAAc;iBAC/B,MAAM,CAAC,CAAC,CAAC,EAAiC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;iBACjD,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC;YAElC,IAAI,CAAC,WAAW,EAAE;gBAChB,OAAO;aACR;YAED,eAAe,CAAC;gBACd,QAAQ,EAAE,MAAM;gBAChB,SAAS,EAAE,IAAI,CAAC,UAAU,CAAC,aAAa;gBACxC,OAAO,EAAE,WAAW,CAAC,UAAU,CAAC,aAAa;gBAC7C,kBAAkB,EAAE,IAAI,CAAC,SAAS,KAAK,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;gBAC3E,iBAAiB,EAAE,IAAI,CAAC,SAAS,KAAK,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY;aAC3E,CAAC,CAAC;QACL,CAAC,CAAC,EACF,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAC1B;aACA,SAAS,EAAE,CAAC;QAEf,IAAI,CAAC,qBAAqB,EAAE,CAAC;IAC/B,CAAC;IAED,sBAAsB,CAAC,SAA0B;QAC/C,MAAM,aAAa,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC;QACpD,MAAM,MAAM,GAAG,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC;QAE9C,MAAM,cAAc,GAAG,IAAI,CAAC,SAAS,KAAK,YAAY,CAAC,CAAC,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,CAAC,MAAM,CAAC,YAAY,CAAC;QAClG,MAAM,aAAa,GAAG,IAAI,CAAC,SAAS,KAAK,YAAY,CAAC,CAAC,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC,CAAC,aAAa,CAAC,SAAS,CAAC;QAE3G,aAAa,CAAC,QAAQ,CAAC;YACrB,CAAC,IAAI,CAAC,SAAS,KAAK,YAAY,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,EAChD,aAAa,GAAG,CAAC,SAAS,KAAK,OAAO,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,cAAc,CAAC;YAC5E,QAAQ,EAAE,QAAQ;SACnB,CAAC,CAAC;IACL,CAAC;IAED,iBAAiB,CAAC,SAA0B;QAC1C,MAAM,QAAQ,GAAG,IAAI,CAAC,wBAAwB,CAAC,KAAK,CAAC;QAErD,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE;YACpB,IAAI,SAAS,EAAE,EAAE;gBACf,OAAO,CAAC,IAAI,CACV,mHAAmH,CACpH,CAAC;aACH;YACD,OAAO;SACR;QAED,MAAM,EAAE,GAAG,SAAS,KAAK,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,2BAA2B,CAAC,CAAC,CAAC,IAAI,CAAC,uBAAuB,CAAC;QAEnG,IAAI,CAAC,EAAE,EAAE;YACP,OAAO;SACR;QAED,IAAI,CAAC,eAAe,CAAC;YACnB,OAAO,EAAE,EAAE,EAAE,OAAO;YACpB,SAAS,EAAE,IAAI,CAAC,SAAS,KAAK,YAAY,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO;YAC/D,MAAM,EAAE,SAAS;YACjB,GAAG,CAAC,IAAI,CAAC,SAAS,KAAK,YAAY;gBACjC,CAAC,CAAC,EAAE,kBAAkB,EAAE,IAAI,CAAC,YAAY,EAAE;gBAC3C,CAAC,CAAC,EAAE,iBAAiB,EAAE,IAAI,CAAC,YAAY,EAAE,CAAC;SAC9C,CAAC,CAAC;IACL,CAAC;IAED,eAAe,CAAC,OAAkD;QAChE,MAAM,aAAa,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC;QAEpD,eAAe,CAAC;YACd,SAAS,EAAE,aAAa;YACxB,GAAG,CAAC,IAAI,CAAC,SAAS,KAAK,YAAY;gBACjC,CAAC,CAAC,EAAE,kBAAkB,EAAE,IAAI,CAAC,YAAY,EAAE;gBAC3C,CAAC,CAAC,EAAE,iBAAiB,EAAE,IAAI,CAAC,YAAY,EAAE,CAAC;YAC7C,GAAG,OAAO;SACX,CAAC,CAAC;IACL,CAAC;IAED,sBAAsB,CAAC,OAAsE;QAC3F,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;QAEhD,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE;YACpB,IAAI,SAAS,EAAE,EAAE;gBACf,OAAO,CAAC,IAAI,CACV,mHAAmH,CACpH,CAAC;aACH;YACD,OAAO;SACR;QAED,MAAM,aAAa,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC;QACpD,MAAM,OAAO,GAAG,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,UAAU,CAAC,aAAa,CAAC;QAElE,eAAe,CAAC;YACd,SAAS,EAAE,aAAa;YACxB,OAAO;YACP,GAAG,CAAC,IAAI,CAAC,SAAS,KAAK,YAAY;gBACjC,CAAC,CAAC,EAAE,kBAAkB,EAAE,IAAI,CAAC,YAAY,EAAE;gBAC3C,CAAC,CAAC,EAAE,iBAAiB,EAAE,IAAI,CAAC,YAAY,EAAE,CAAC;YAC7C,GAAG,OAAO;SACX,CAAC,CAAC;IACL,CAAC;IAES,mBAAmB,CAAC,UAAmB;QAC/C,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IAC3C,CAAC;IAES,sBAAsB;QAC9B,IAAI,IAAI,CAAC,UAAU,KAAK,WAAW,EAAE;YACnC,IAAI,CAAC,sBAAsB,CAAC,OAAO,CAAC,CAAC;SACtC;aAAM;YACL,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC,CAAC;SACjC;IACH,CAAC;IAES,gBAAgB;QACxB,IAAI,IAAI,CAAC,UAAU,KAAK,WAAW,EAAE;YACnC,IAAI,CAAC,sBAAsB,CAAC,KAAK,CAAC,CAAC;SACpC;aAAM;YACL,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC;SAC/B;IACH,CAAC;IAEO,qBAAqB;QAC3B,MAAM,aAAa,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC;QACpD,IAAI,UAAU,GAAG,KAAK,CAAC;QACvB,IAAI,WAAW,GAAG,CAAC,CAAC;QAEpB,KAAK,CAAC,SAAS,CAAa,aAAa,EAAE,OAAO,CAAC,EAAE,SAAS,CAAa,aAAa,EAAE,YAAY,CAAC,CAAC;aACrG,IAAI,CACH,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,EACzB,GAAG,CAAC,GAAG,EAAE;YACP,UAAU,GAAG,KAAK,CAAC;QACrB,CAAC,CAAC,CACH;aACA,SAAS,EAAE,CAAC;QAEf,KAAK,CACH,SAAS,CAAC,aAAa,EAAE,QAAQ,CAAC,EAClC,IAAI,CAAC,kBAAkB,EACvB,IAAI,CAAC,QAAQ,EAAE,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,IAAI,EAAE,CAAC,IAAI,CAAC,CAClE;aACE,IAAI,CACH,YAAY,CAAC,GAAG,CAAC,EACjB,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,EACzB,GAAG,CAAC,GAAG,EAAE;YACP,MAAM,QAAQ,GACZ,IAAI,CAAC,QAAQ;gBACX,EAAE,OAAO,EAAE;iBACV,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,UAAU,CAAC,aAAa,CAAC;iBACvC,MAAM,CAAC,CAAC,CAAC,EAAoB,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;YAEhD,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE;gBACpB,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;gBAEvC,OAAO;aACR;YAED,MAAM,MAAM,GAAG,uBAAuB,CAAC;gBACrC,QAAQ;gBACR,SAAS,EAAE,aAAa;aACzB,CAAC,CAAC;YAEH,MAAM,IAAI,GAAG,IAAI,CAAC,SAAS,KAAK,YAAY,CAAC,CAAC,CAAC,oBAAoB,CAAC,CAAC,CAAC,mBAAmB,CAAC;YAC1F,MAAM,UAAU,GAAG,6BAA6B,CAAC;YAEjD,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE;gBAC1B,IAAI,KAAK,CAAC,IAAI,CAAC,KAAK,GAAG,EAAE;oBACvB,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;iBACzC;qBAAM;oBACL,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;iBAC5C;aACF;YAED,MAAM,mBAAmB,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;gBAC9C,MAAM,KAAK,GAAiC;oBAC1C,OAAO,EAAE,CAAC,CAAC,OAAO;oBAClB,iBAAiB,EAAE,CAAC,CAAC,IAAI,CAAC,GAAG,GAAG;oBAChC,cAAc,EAAE,CAAC,CAAC,IAAI,CAAC,KAAK,GAAG;oBAC/B,KAAK,EAAE,CAAC;iBACT,CAAC;gBAEF,OAAO,KAAK,CAAC;YACf,CAAC,CAAC,CAAC;YAEH,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;YAElD,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;YAExD,IAAI,UAAU,IAAI,IAAI,CAAC,kBAAkB,CAAC,KAAK,IAAI,CAAC,IAAI,CAAC,IAAI;gBAAE,OAAO;YAEtE,MAAM,IAAI,GAAG,IAAI,CAAC,2BAA2B,CAAC;YAC9C,MAAM,IAAI,GAAG,IAAI,CAAC,uBAAuB,CAAC;YAC1C,MAAM,QAAQ,GACZ,CAAC,IAAI;gBACL,CAAC,IAAI;gBACL,IAAI,CAAC,iBAAiB,KAAK,CAAC;gBAC5B,IAAI,CAAC,iBAAiB,KAAK,CAAC;gBAC5B,IAAI,CAAC,iBAAiB,KAAK,IAAI,CAAC,iBAAiB,CAAC;YAEpD,IAAI,QAAQ;gBAAE,OAAO;YAErB,MAAM,mBAAmB,GAAG,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC;YAC1F,MAAM,qBAAqB,GAAG,IAAI,CAAC,0BAA0B,EAAE,KAAK,CAAC;YAErE,IAAI,qBAAqB,KAAK,SAAS;gBAAE,OAAO;YAEhD,MAAM,wBAAwB,GAAG,mBAAmB,CAAC,KAAK,CAAC;YAC3D,MAAM,MAAM,GAAG,wBAAwB,GAAG,qBAAqB,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC;YAElF,eAAe,CAAC;gBACd,SAAS,EAAE,aAAa;gBACxB,OAAO,EAAE,mBAAmB,CAAC,OAAO;gBACpC,SAAS,EAAE,IAAI,CAAC,SAAS,KAAK,YAAY,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO;gBAC/D,MAAM;gBACN,iBAAiB,EAAE,IAAI,CAAC,SAAS,KAAK,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY;gBAC1E,kBAAkB,EAAE,IAAI,CAAC,SAAS,KAAK,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;aAC5E,CAAC,CAAC;YAEH,UAAU,GAAG,IAAI,CAAC;YAElB,MAAM,CAAC,YAAY,CAAC,WAAW,CAAC,CAAC;YAEjC,WAAW,GAAG,MAAM,CAAC,UAAU,CAAC,GAAG,EAAE;gBACnC,UAAU,GAAG,KAAK,CAAC;YACrB,CAAC,EAAE,IAAI,CAAC,CAAC;QACX,CAAC,CAAC,CACH;aACA,SAAS,EAAE,CAAC;IACjB,CAAC;8GArbU,mBAAmB;kGAAnB,mBAAmB,2NAqBV,gBAAgB,qDAGhB,gBAAgB,8DAGhB,gBAAgB,qDAIhB,gBAAgB,8DAIhB,gBAAgB,qGAGhB,gBAAgB,oDAMhB,gBAAgB,kDAGhB,eAAe,6XA8BlB,iBAAiB,8DAGjB,UAAU,oaCzI7B,mwCAyCA,g7KDWY,yBAAyB,wNAA+B,OAAO,oFAAE,IAAI,6FAAgB,oBAAoB;;2FAKxG,mBAAmB;kBAZ/B,SAAS;+BACE,eAAe,cAGb,IAAI,iBACD,iBAAiB,CAAC,IAAI,mBACpB,uBAAuB,CAAC,MAAM,WACtC,CAAC,yBAAyB,EAAE,2BAA2B,EAAE,OAAO,EAAE,IAAI,EAAE,YAAY,EAAE,oBAAoB,CAAC,QAC9G;wBACJ,KAAK,EAAE,eAAe;qBACvB;wDAWD,QAAQ;sBAFP,KAAK;;sBACL,WAAW;uBAAC,gBAAgB;gBAK7B,SAAS;sBAFR,KAAK;;sBACL,WAAW;uBAAC,gBAAgB;gBAI7B,cAAc;sBADb,KAAK;gBAIN,eAAe;sBADd,KAAK;gBAIN,WAAW;sBADV,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;gBAItC,aAAa;sBADZ,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;gBAKtC,gBAAgB;sBAFf,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;;sBACrC,WAAW;uBAAC,wBAAwB;gBAKrC,aAAa;sBAFZ,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;;sBACrC,WAAW;uBAAC,qBAAqB;gBAIlC,gBAAgB;sBADf,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;gBAItC,6BAA6B;sBAD5B,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;gBAItC,UAAU;sBADT,KAAK;gBAIN,IAAI;sBADH,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;gBAItC,YAAY;sBADX,KAAK;uBAAC,EAAE,SAAS,EAAE,eAAe,EAAE;gBAI5B,iBAAiB;sBADzB,MAAM;gBAIE,kBAAkB;sBAD1B,MAAM;gBAIP,UAAU;sBADT,SAAS;uBAAC,YAAY,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBAI3B,cAAc;sBAD3B,YAAY;uBAAC,YAAY;gBAOZ,gBAAgB;sBAD7B,YAAY;uBAAC,cAAc;gBAOd,eAAe;sBAD5B,YAAY;uBAAC,aAAa;gBAO3B,cAAc;sBADb,eAAe;uBAAC,iBAAiB,EAAE,EAAE,WAAW,EAAE,IAAI,EAAE;gBAIzD,QAAQ;sBADP,eAAe;uBAAC,UAAU,EAAE,EAAE,WAAW,EAAE,IAAI,EAAE","sourcesContent":["import { NgClass, NgIf } from '@angular/common';\nimport {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  Component,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  Input,\n  Output,\n  ViewChild,\n  ViewChildren,\n  ViewEncapsulation,\n  booleanAttribute,\n  computed,\n  effect,\n  inject,\n  isDevMode,\n  numberAttribute,\n  signal,\n} from '@angular/core';\nimport {\n  CursorDragScrollDirective,\n  IS_ACTIVE_ELEMENT,\n  IS_ELEMENT,\n  IsActiveElementDirective,\n  IsElementDirective,\n  LetDirective,\n  NgClassType,\n  ObserveScrollStateDirective,\n  ScrollObserverScrollState,\n  ScrollToElementOptions,\n  TypedQueryList,\n  createDestroy,\n  getElementVisibleStates,\n  scrollToElement,\n  signalElementIntersection,\n  signalElementScrollState,\n  signalHostAttributes,\n} from '@ethlete/core';\nimport { BehaviorSubject, debounceTime, fromEvent, merge, of, startWith, takeUntil, tap } from 'rxjs';\nimport { ChevronIconComponent } from '../../../icons';\nimport { ScrollableIntersectionChange, ScrollableScrollMode } from '../../types';\n\n@Component({\n  selector: 'et-scrollable',\n  templateUrl: './scrollable.component.html',\n  styleUrls: ['./scrollable.component.scss'],\n  standalone: true,\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [CursorDragScrollDirective, ObserveScrollStateDirective, NgClass, NgIf, LetDirective, ChevronIconComponent],\n  host: {\n    class: 'et-scrollable',\n  },\n})\nexport class ScrollableComponent implements AfterContentInit {\n  private readonly _destroy$ = createDestroy();\n  private readonly _elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n\n  private readonly _isCursorDragging$ = new BehaviorSubject<boolean>(false);\n  private readonly _latestVisibilityStates$ = new BehaviorSubject<ScrollableIntersectionChange[]>([]);\n\n  @Input()\n  @HostBinding('attr.item-size')\n  itemSize: 'auto' | 'same' | 'full' = 'auto';\n\n  @Input()\n  @HostBinding('attr.direction')\n  direction: 'horizontal' | 'vertical' = 'horizontal';\n\n  @Input()\n  scrollableRole?: string;\n\n  @Input()\n  scrollableClass?: NgClassType;\n\n  @Input({ transform: booleanAttribute })\n  renderMasks = true;\n\n  @Input({ transform: booleanAttribute })\n  renderButtons = true;\n\n  @Input({ transform: booleanAttribute })\n  @HostBinding('attr.render-scrollbars')\n  renderScrollbars = false;\n\n  @Input({ transform: booleanAttribute })\n  @HostBinding('attr.sticky-buttons')\n  stickyButtons = false;\n\n  @Input({ transform: booleanAttribute })\n  cursorDragScroll = true;\n\n  @Input({ transform: booleanAttribute })\n  disableActiveElementScrolling = false;\n\n  @Input()\n  scrollMode: ScrollableScrollMode = 'container';\n\n  @Input({ transform: booleanAttribute })\n  snap = false;\n\n  @Input({ transform: numberAttribute })\n  scrollMargin = 0;\n\n  @Output()\n  readonly scrollStateChange = new EventEmitter<ScrollObserverScrollState>();\n\n  @Output()\n  readonly intersectionChange = new EventEmitter<ScrollableIntersectionChange[]>();\n\n  @ViewChild('scrollable', { static: true })\n  scrollable!: ElementRef<HTMLElement>;\n\n  @ViewChildren('scrollable')\n  protected set scrollableList(list: TypedQueryList<ElementRef<HTMLElement>>) {\n    this._scrollableList.set(list);\n  }\n  private readonly _scrollableList = signal<TypedQueryList<ElementRef<HTMLElement>> | null>(null);\n\n  @ViewChildren('firstElement')\n  protected set firstElementList(list: TypedQueryList<ElementRef<HTMLElement>>) {\n    this._firstElementList.set(list);\n  }\n  private readonly _firstElementList = signal<TypedQueryList<ElementRef<HTMLElement>> | null>(null);\n\n  @ViewChildren('lastElement')\n  protected set lastElementList(list: TypedQueryList<ElementRef<HTMLElement>>) {\n    this._lastElementList.set(list);\n  }\n  private readonly _lastElementList = signal<TypedQueryList<ElementRef<HTMLElement>> | null>(null);\n\n  @ContentChildren(IS_ACTIVE_ELEMENT, { descendants: true })\n  activeElements: TypedQueryList<IsActiveElementDirective> | null = null;\n\n  @ContentChildren(IS_ELEMENT, { descendants: true })\n  elements: TypedQueryList<IsElementDirective> | null = null;\n\n  get highestVisibleIntersection() {\n    const elements = this._latestVisibilityStates$.value;\n\n    if (!elements.length) {\n      return null;\n    }\n\n    return elements.reduce((prev, curr) => {\n      if (!prev) {\n        return curr;\n      }\n\n      return curr.intersectionRatio > prev.intersectionRatio ? curr : prev;\n    });\n  }\n\n  get nextPartialIntersection() {\n    const elements = this._latestVisibilityStates$.value;\n\n    if (!elements.length) {\n      return null;\n    }\n\n    const highestVisibleIntersection = this.highestVisibleIntersection;\n\n    if (!highestVisibleIntersection) {\n      return null;\n    }\n\n    const nextIndex = elements.slice(highestVisibleIntersection.index).findIndex((e) => !e.isIntersecting);\n\n    if (nextIndex === -1) {\n      return null;\n    }\n\n    const nextElement = elements[highestVisibleIntersection.index + nextIndex];\n\n    return nextElement || null;\n  }\n\n  get previousPartialIntersection() {\n    const elements = this._latestVisibilityStates$.value;\n\n    if (!elements.length) {\n      return null;\n    }\n\n    const highestVisibleIntersection = this.highestVisibleIntersection;\n\n    if (!highestVisibleIntersection) {\n      return null;\n    }\n\n    const previousIndex = elements\n      .slice(0, highestVisibleIntersection.index)\n      .reverse()\n      .findIndex((e) => !e.isIntersecting);\n\n    if (previousIndex === -1) {\n      return null;\n    }\n\n    const previousElement = elements[highestVisibleIntersection.index - previousIndex - 1];\n\n    return previousElement || null;\n  }\n\n  protected readonly containerScrollState = signalElementScrollState(this._scrollableList);\n  protected readonly firstElementIntersection = signalElementIntersection(this._firstElementList, this._scrollableList);\n  protected readonly lastElementIntersection = signalElementIntersection(this._lastElementList, this._scrollableList);\n\n  protected readonly shouldAnimateOverlays = computed(\n    () => !!this.firstElementIntersection() && !!this.lastElementIntersection(),\n  );\n\n  protected readonly canScroll = computed(() => {\n    const dir = this.direction;\n\n    if (dir === 'horizontal') {\n      return this.containerScrollState().canScrollHorizontally;\n    }\n\n    return this.containerScrollState().canScrollVertically;\n  });\n\n  protected readonly isAtStart = computed(() =>\n    this.canScroll() ? this.firstElementIntersection().isIntersecting : true,\n  );\n  protected readonly isAtEnd = computed(() =>\n    this.canScroll() ? this.lastElementIntersection().isIntersecting : true,\n  );\n\n  protected readonly hostAttributes = signalHostAttributes({\n    'can-scroll': this.canScroll,\n    'at-start': this.isAtStart,\n    'at-end': this.isAtEnd,\n    'animate-overlays': this.shouldAnimateOverlays,\n  });\n\n  constructor() {\n    effect(() => {\n      const isAtStart = this.isAtStart();\n      const isAtEnd = this.isAtEnd();\n      const canScroll = this.canScroll();\n\n      this.scrollStateChange.emit({\n        canScroll,\n        isAtEnd,\n        isAtStart,\n      });\n    });\n  }\n\n  ngAfterContentInit(): void {\n    if (!this.activeElements || !this.elements) {\n      return;\n    }\n\n    this.activeElements.changes\n      .pipe(\n        startWith(this.activeElements),\n        tap((activeElements) => {\n          if (this.disableActiveElementScrolling) {\n            return;\n          }\n\n          const firstActive = activeElements\n            .filter((a): a is IsActiveElementDirective => !!a)\n            .find((a) => a.isActiveElement);\n\n          if (!firstActive) {\n            return;\n          }\n\n          scrollToElement({\n            behavior: 'auto',\n            container: this.scrollable.nativeElement,\n            element: firstActive.elementRef.nativeElement,\n            scrollInlineMargin: this.direction === 'horizontal' ? this.scrollMargin : 0,\n            scrollBlockMargin: this.direction === 'horizontal' ? 0 : this.scrollMargin,\n          });\n        }),\n        takeUntil(this._destroy$),\n      )\n      .subscribe();\n\n    this._setupScrollListening();\n  }\n\n  scrollOneContainerSize(direction: 'start' | 'end') {\n    const scrollElement = this.scrollable.nativeElement;\n    const parent = this._elementRef.nativeElement;\n\n    const scrollableSize = this.direction === 'horizontal' ? parent.clientWidth : parent.clientHeight;\n    const currentScroll = this.direction === 'horizontal' ? scrollElement.scrollLeft : scrollElement.scrollTop;\n\n    scrollElement.scrollTo({\n      [this.direction === 'horizontal' ? 'left' : 'top']:\n        currentScroll + (direction === 'start' ? -scrollableSize : scrollableSize),\n      behavior: 'smooth',\n    });\n  }\n\n  scrollOneItemSize(direction: 'start' | 'end') {\n    const elements = this._latestVisibilityStates$.value;\n\n    if (!elements.length) {\n      if (isDevMode()) {\n        console.warn(\n          'No elements found to scroll to. Make sure to apply the isElement directive to the elements you want to scroll to.',\n        );\n      }\n      return;\n    }\n\n    const el = direction === 'start' ? this.previousPartialIntersection : this.nextPartialIntersection;\n\n    if (!el) {\n      return;\n    }\n\n    this.scrollToElement({\n      element: el?.element,\n      direction: this.direction === 'horizontal' ? 'inline' : 'block',\n      origin: direction,\n      ...(this.direction === 'horizontal'\n        ? { scrollInlineMargin: this.scrollMargin }\n        : { scrollBlockMargin: this.scrollMargin }),\n    });\n  }\n\n  scrollToElement(options: Omit<ScrollToElementOptions, 'container'>) {\n    const scrollElement = this.scrollable.nativeElement;\n\n    scrollToElement({\n      container: scrollElement,\n      ...(this.direction === 'horizontal'\n        ? { scrollInlineMargin: this.scrollMargin }\n        : { scrollBlockMargin: this.scrollMargin }),\n      ...options,\n    });\n  }\n\n  scrollToElementByIndex(options: Omit<ScrollToElementOptions, 'container'> & { index: number }) {\n    const elements = this.elements?.toArray() ?? [];\n\n    if (!elements.length) {\n      if (isDevMode()) {\n        console.warn(\n          'No elements found to scroll to. Make sure to apply the isElement directive to the elements you want to scroll to.',\n        );\n      }\n      return;\n    }\n\n    const scrollElement = this.scrollable.nativeElement;\n    const element = elements[options.index]?.elementRef.nativeElement;\n\n    scrollToElement({\n      container: scrollElement,\n      element,\n      ...(this.direction === 'horizontal'\n        ? { scrollInlineMargin: this.scrollMargin }\n        : { scrollBlockMargin: this.scrollMargin }),\n      ...options,\n    });\n  }\n\n  protected setIsCursorDragging(isDragging: boolean) {\n    this._isCursorDragging$.next(isDragging);\n  }\n\n  protected scrollToStartDirection() {\n    if (this.scrollMode === 'container') {\n      this.scrollOneContainerSize('start');\n    } else {\n      this.scrollOneItemSize('start');\n    }\n  }\n\n  protected scrollToStartEnd() {\n    if (this.scrollMode === 'container') {\n      this.scrollOneContainerSize('end');\n    } else {\n      this.scrollOneItemSize('end');\n    }\n  }\n\n  private _setupScrollListening() {\n    const scrollElement = this.scrollable.nativeElement;\n    let isSnapping = false;\n    let snapTimeout = 0;\n\n    merge(fromEvent<WheelEvent>(scrollElement, 'wheel'), fromEvent<TouchEvent>(scrollElement, 'touchstart'))\n      .pipe(\n        takeUntil(this._destroy$),\n        tap(() => {\n          isSnapping = false;\n        }),\n      )\n      .subscribe();\n\n    merge(\n      fromEvent(scrollElement, 'scroll'),\n      this._isCursorDragging$,\n      this.elements?.changes.pipe(startWith(this.elements)) ?? of(null),\n    )\n      .pipe(\n        debounceTime(300),\n        takeUntil(this._destroy$),\n        tap(() => {\n          const elements =\n            this.elements\n              ?.toArray()\n              .map((e) => e?.elementRef.nativeElement)\n              .filter((e): e is HTMLElement => !!e) ?? [];\n\n          if (!elements.length) {\n            this._latestVisibilityStates$.next([]);\n\n            return;\n          }\n\n          const states = getElementVisibleStates({\n            elements,\n            container: scrollElement,\n          });\n\n          const prop = this.direction === 'horizontal' ? 'inlineIntersection' : 'blockIntersection';\n          const stateClass = `et-element--is-intersecting`;\n\n          for (const state of states) {\n            if (state[prop] === 100) {\n              state.element.classList.add(stateClass);\n            } else {\n              state.element.classList.remove(stateClass);\n            }\n          }\n\n          const intersectionChanges = states.map((s, i) => {\n            const state: ScrollableIntersectionChange = {\n              element: s.element,\n              intersectionRatio: s[prop] / 100,\n              isIntersecting: s[prop] === 100,\n              index: i,\n            };\n\n            return state;\n          });\n\n          this.intersectionChange.emit(intersectionChanges);\n\n          this._latestVisibilityStates$.next(intersectionChanges);\n\n          if (isSnapping || this._isCursorDragging$.value || !this.snap) return;\n\n          const prev = this.previousPartialIntersection;\n          const next = this.nextPartialIntersection;\n          const skipSnap =\n            !prev ||\n            !next ||\n            prev.intersectionRatio === 0 ||\n            next.intersectionRatio === 0 ||\n            prev.intersectionRatio === next.intersectionRatio;\n\n          if (skipSnap) return;\n\n          const highestIntersecting = prev.intersectionRatio > next.intersectionRatio ? prev : next;\n          const fullIntersectionIndex = this.highestVisibleIntersection?.index;\n\n          if (fullIntersectionIndex === undefined) return;\n\n          const highestIntersectingIndex = highestIntersecting.index;\n          const origin = highestIntersectingIndex > fullIntersectionIndex ? 'end' : 'start';\n\n          scrollToElement({\n            container: scrollElement,\n            element: highestIntersecting.element,\n            direction: this.direction === 'horizontal' ? 'inline' : 'block',\n            origin,\n            scrollBlockMargin: this.direction === 'horizontal' ? 0 : this.scrollMargin,\n            scrollInlineMargin: this.direction === 'horizontal' ? this.scrollMargin : 0,\n          });\n\n          isSnapping = true;\n\n          window.clearTimeout(snapTimeout);\n\n          snapTimeout = window.setTimeout(() => {\n            isSnapping = false;\n          }, 1000);\n        }),\n      )\n      .subscribe();\n  }\n}\n","<div\n  #scrollable\n  [attr.role]=\"scrollableRole ?? undefined\"\n  [etCursorDragScroll]=\"cursorDragScroll\"\n  [allowedDirection]=\"direction\"\n  (cursorDragStart)=\"setIsCursorDragging(true)\"\n  (cursorDragEnd)=\"setIsCursorDragging(false)\"\n  class=\"et-scrollable-container-outer\"\n>\n  <div [ngClass]=\"scrollableClass\" class=\"et-scrollable-container\">\n    <div #firstElement class=\"et-scroll-observer-first-element\"></div>\n    <ng-content />\n    <div #lastElement class=\"et-scroll-observer-last-element\"></div>\n  </div>\n</div>\n\n<div *ngIf=\"renderMasks\" class=\"et-scrollable-masks\">\n  <div class=\"et-scrollable-mask et-scrollable-mask--start\"></div>\n  <div class=\"et-scrollable-mask et-scrollable-mask--end\"></div>\n</div>\n\n<div *ngIf=\"renderButtons\" class=\"et-scrollable-buttons\">\n  <button\n    (click)=\"scrollToStartDirection()\"\n    class=\"et-scrollable-button et-scrollable-button--start\"\n    aria-hidden=\"true\"\n    type=\"button\"\n    tabindex=\"-1\"\n  >\n    <et-chevron-icon />\n  </button>\n  <button\n    (click)=\"scrollToStartEnd()\"\n    class=\"et-scrollable-button et-scrollable-button--end\"\n    aria-hidden=\"true\"\n    type=\"button\"\n    tabindex=\"-1\"\n  >\n    <et-chevron-icon />\n  </button>\n</div>\n"]}
449
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scrollable.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/cdk/src/lib/components/scrollable/components/scrollable/scrollable.component.ts","../../../../../../../../../libs/cdk/src/lib/components/scrollable/components/scrollable/scrollable.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AAC1C,OAAO,EAEL,uBAAuB,EACvB,SAAS,EACT,eAAe,EACf,UAAU,EACV,YAAY,EACZ,KAAK,EACL,MAAM,EACN,SAAS,EACT,iBAAiB,EACjB,gBAAgB,EAChB,QAAQ,EACR,MAAM,EACN,MAAM,EACN,SAAS,EACT,eAAe,EACf,MAAM,GACP,MAAM,eAAe,CAAC;AACvB,OAAO,EAEL,yBAAyB,EACzB,iBAAiB,EACjB,UAAU,EAGV,YAAY,EAEZ,2BAA2B,EAG3B,cAAc,EACd,aAAa,EACb,uBAAuB,EACvB,gBAAgB,EAChB,SAAS,EACT,eAAe,EACf,yBAAyB,EACzB,wBAAwB,EACxB,oBAAoB,EACpB,iBAAiB,GAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,eAAe,EAAE,YAAY,EAAE,SAAS,EAAE,KAAK,EAAE,EAAE,EAAE,SAAS,EAAE,SAAS,EAAE,GAAG,EAAE,MAAM,MAAM,CAAC;AACtG,OAAO,EAAE,oBAAoB,EAAE,MAAM,gBAAgB,CAAC;;AAetD,MAAM,OAAO,mBAAmB;IAO9B,IACI,SAAS,CAAC,CAA2B;QACvC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IACvB,CAAC;IAGD,IACI,UAAU,CAAC,CAA4B;QACzC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IACxB,CAAC;IAGD,IACI,eAAe,CAAC,CAAgB;QAClC,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IAC7B,CAAC;IAGD,IACI,gBAAgB,CAAC,CAAqB;QACxC,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IAC9B,CAAC;IAGD,IACI,YAAY,CAAC,CAAU;QACzB,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IAC1B,CAAC;IAGD,IACI,cAAc,CAAC,CAAU;QAC3B,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IAC5B,CAAC;IAGD,IACI,iBAAiB,CAAC,CAAU;QAC9B,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IAC/B,CAAC;IAGD,IACI,cAAc,CAAC,CAAU;QAC3B,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IAC5B,CAAC;IAGD,IACI,iBAAiB,CAAC,CAAU;QAC9B,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IAC/B,CAAC;IAGD,IACI,8BAA8B,CAAC,CAAU;QAC3C,IAAI,CAAC,6BAA6B,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IAC5C,CAAC;IAGD,IACI,WAAW,CAAC,CAAuB;QACrC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IACzB,CAAC;IAGD,IACI,KAAK,CAAC,CAAU;QAClB,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IACnB,CAAC;IAGD,IACI,aAAa,CAAC,CAAS;QACzB,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IAC3B,CAAC;IASD,IACY,WAAW,CAAC,CAA0B;QAChD,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IACzB,CAAC;IAGD,IACY,aAAa,CAAC,CAA0B;QAClD,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IAC3B,CAAC;IAGD,IACY,YAAY,CAAC,CAA0B;QACjD,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IAC1B,CAAC;IAGD,IACY,kBAAkB,CAAC,CAA2C;QACxE,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IAChC,CAAC;IAGD,IACY,YAAY,CAAC,CAAqC;QAC5D,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IAC1B,CAAC;IAGD,IAAI,0BAA0B;QAC5B,MAAM,QAAQ,GAAG,IAAI,CAAC,wBAAwB,CAAC,KAAK,CAAC;QAErD,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE;YACpB,OAAO,IAAI,CAAC;SACb;QAED,OAAO,QAAQ,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,EAAE;YACpC,IAAI,CAAC,IAAI,EAAE;gBACT,OAAO,IAAI,CAAC;aACb;YAED,OAAO,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC;QACvE,CAAC,CAAC,CAAC;IACL,CAAC;IAED,IAAI,uBAAuB;QACzB,MAAM,QAAQ,GAAG,IAAI,CAAC,wBAAwB,CAAC,KAAK,CAAC;QAErD,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE;YACpB,OAAO,IAAI,CAAC;SACb;QAED,MAAM,0BAA0B,GAAG,IAAI,CAAC,0BAA0B,CAAC;QAEnE,IAAI,CAAC,0BAA0B,EAAE;YAC/B,OAAO,IAAI,CAAC;SACb;QAED,MAAM,SAAS,GAAG,QAAQ,CAAC,KAAK,CAAC,0BAA0B,CAAC,KAAK,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC;QAEvG,IAAI,SAAS,KAAK,CAAC,CAAC,EAAE;YACpB,OAAO,IAAI,CAAC;SACb;QAED,MAAM,WAAW,GAAG,QAAQ,CAAC,0BAA0B,CAAC,KAAK,GAAG,SAAS,CAAC,CAAC;QAE3E,OAAO,WAAW,IAAI,IAAI,CAAC;IAC7B,CAAC;IAED,IAAI,2BAA2B;QAC7B,MAAM,QAAQ,GAAG,IAAI,CAAC,wBAAwB,CAAC,KAAK,CAAC;QAErD,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE;YACpB,OAAO,IAAI,CAAC;SACb;QAED,MAAM,0BAA0B,GAAG,IAAI,CAAC,0BAA0B,CAAC;QAEnE,IAAI,CAAC,0BAA0B,EAAE;YAC/B,OAAO,IAAI,CAAC;SACb;QAED,MAAM,aAAa,GAAG,QAAQ;aAC3B,KAAK,CAAC,CAAC,EAAE,0BAA0B,CAAC,KAAK,CAAC;aAC1C,OAAO,EAAE;aACT,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC;QAEvC,IAAI,aAAa,KAAK,CAAC,CAAC,EAAE;YACxB,OAAO,IAAI,CAAC;SACb;QAED,MAAM,eAAe,GAAG,QAAQ,CAAC,0BAA0B,CAAC,KAAK,GAAG,aAAa,GAAG,CAAC,CAAC,CAAC;QAEvF,OAAO,eAAe,IAAI,IAAI,CAAC;IACjC,CAAC;IA6DD;QAtPiB,cAAS,GAAG,aAAa,EAAE,CAAC;QAC5B,gBAAW,GAAG,MAAM,CAA0B,UAAU,CAAC,CAAC;QAE1D,uBAAkB,GAAG,IAAI,eAAe,CAAU,KAAK,CAAC,CAAC;QACzD,6BAAwB,GAAG,IAAI,eAAe,CAAiC,EAAE,CAAC,CAAC;QAM3F,aAAQ,GAAG,MAAM,CAA2B,MAAM,CAAC,CAAC;QAMpD,cAAS,GAAG,MAAM,CAA4B,YAAY,CAAC,CAAC;QAM5D,mBAAc,GAAG,MAAM,CAAgB,IAAI,CAAC,CAAC;QAM7C,oBAAe,GAAG,MAAM,CAAqB,IAAI,CAAC,CAAC;QAMnD,gBAAW,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC;QAM3B,kBAAa,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC;QAM7B,qBAAgB,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;QAMjC,kBAAa,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;QAM9B,qBAAgB,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC;QAMhC,kCAA6B,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;QAM9C,eAAU,GAAG,MAAM,CAAuB,WAAW,CAAC,CAAC;QAMvD,SAAI,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;QAMrB,iBAAY,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QAGzB,sBAAiB,GAAG,IAAI,YAAY,EAA6B,CAAC;QAGlE,uBAAkB,GAAG,IAAI,YAAY,EAAkC,CAAC;QAMxE,eAAU,GAAG,MAAM,CAAiC,IAAI,CAAC,CAAC;QAM1D,iBAAY,GAAG,MAAM,CAAiC,IAAI,CAAC,CAAC;QAM5D,gBAAW,GAAG,MAAM,CAAiC,IAAI,CAAC,CAAC;QAM3D,sBAAiB,GAAG,MAAM,CAAkD,IAAI,CAAC,CAAC;QAMlF,gBAAW,GAAG,MAAM,CAA4C,IAAI,CAAC,CAAC;QAqE5D,yBAAoB,GAAG,wBAAwB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACjE,6BAAwB,GAAG,yBAAyB,CAAC,IAAI,CAAC,YAAY,EAAE,EAAE,IAAI,EAAE,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC;QACnG,2BAAsB,GAAG,MAAM,CAAkC,IAAI,CAAC,CAAC;QACvE,4BAAuB,GAAG,yBAAyB,CAAC,IAAI,CAAC,WAAW,EAAE,EAAE,IAAI,EAAE,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC;QACjG,0BAAqB,GAAG,MAAM,CAAkC,IAAI,CAAC,CAAC;QAEtE,cAAS,GAAG,QAAQ,CAAC,GAAG,EAAE;YAC3C,MAAM,GAAG,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC;YAE7B,IAAI,GAAG,KAAK,YAAY,EAAE;gBACxB,OAAO,IAAI,CAAC,oBAAoB,EAAE,CAAC,qBAAqB,CAAC;aAC1D;YAED,OAAO,IAAI,CAAC,oBAAoB,EAAE,CAAC,mBAAmB,CAAC;QACzD,CAAC,CAAC,CAAC;QAEgB,cAAS,GAAG,QAAQ,CAAC,GAAG,EAAE;YAC3C,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,EAAE;gBACrB,OAAO,IAAI,CAAC;aACb;YAED,MAAM,YAAY,GAAG,IAAI,CAAC,wBAAwB,EAAE,CAAC;YAErD,IAAI,CAAC,YAAY,EAAE;gBACjB,OAAO,IAAI,CAAC,sBAAsB,EAAE,EAAE,MAAM,IAAI,IAAI,CAAC;aACtD;YAED,OAAO,YAAY,CAAC,cAAc,CAAC;QACrC,CAAC,CAAC,CAAC;QACgB,YAAO,GAAG,QAAQ,CAAC,GAAG,EAAE;YACzC,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,EAAE;gBACrB,OAAO,IAAI,CAAC;aACb;YAED,MAAM,YAAY,GAAG,IAAI,CAAC,uBAAuB,EAAE,CAAC;YAEpD,IAAI,CAAC,YAAY,EAAE;gBACjB,OAAO,IAAI,CAAC,qBAAqB,EAAE,EAAE,MAAM,IAAI,IAAI,CAAC;aACrD;YAED,OAAO,YAAY,CAAC,cAAc,CAAC;QACrC,CAAC,CAAC,CAAC;QAEgB,4BAAuB,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;QAExC,mBAAc,GAAG,oBAAoB,CAAC;YACvD,WAAW,EAAE,IAAI,CAAC,QAAQ;YAC1B,SAAS,EAAE,IAAI,CAAC,SAAS;YACzB,mBAAmB,EAAE,IAAI,CAAC,gBAAgB;YAC1C,gBAAgB,EAAE,IAAI,CAAC,aAAa;SACrC,CAAC,CAAC;QAEgB,gBAAW,GAAG,iBAAiB,CAAC;YACjD,2BAA2B,EAAE,IAAI,CAAC,SAAS;YAC3C,4BAA4B,EAAE,IAAI,CAAC,SAAS;YAC5C,0BAA0B,EAAE,IAAI,CAAC,OAAO;YACxC,0CAA0C,EAAE,IAAI,CAAC,uBAAuB;SACzE,CAAC,CAAC;QAGD,MAAM,CACJ,GAAG,EAAE;YACH,MAAM,UAAU,GAAG,IAAI,CAAC,UAAU,EAAE,EAAE,aAAa,CAAC;YACpD,MAAM,YAAY,GAAG,IAAI,CAAC,YAAY,EAAE,EAAE,aAAa,CAAC;YACxD,MAAM,WAAW,GAAG,IAAI,CAAC,WAAW,EAAE,EAAE,aAAa,CAAC;YACtD,MAAM,iBAAiB,GAAG,IAAI,CAAC,iBAAiB,EAAE,EAAE,OAAO,EAAE,CAAC;YAE9D,IAAI,CAAC,UAAU,IAAI,CAAC,YAAY,IAAI,CAAC,WAAW,IAAI,CAAC,iBAAiB,EAAE;gBACtE,OAAO;aACR;YAED,MAAM,WAAW,GAAG,iBAAiB,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC;YAErE,IAAI,WAAW,IAAI,CAAC,IAAI,CAAC,6BAA6B,EAAE,EAAE;gBACxD,MAAM,SAAS,GAAG,WAAW,CAAC,UAAU,CAAC,aAAa,CAAC,SAAS,GAAG,UAAU,CAAC,SAAS,CAAC;gBACxF,MAAM,UAAU,GAAG,WAAW,CAAC,UAAU,CAAC,aAAa,CAAC,UAAU,GAAG,UAAU,CAAC,UAAU,CAAC;gBAC3F,UAAU,CAAC,UAAU,GAAG,UAAU,CAAC;gBACnC,UAAU,CAAC,SAAS,GAAG,SAAS,CAAC;aAClC;YAED,IAAI,CAAC,sBAAsB,CAAC,GAAG,CAC7B,gBAAgB,CAAC;gBACf,SAAS,EAAE,UAAU;gBACrB,OAAO,EAAE,YAAY;aACtB,CAAC,CACH,CAAC;YAEF,IAAI,CAAC,qBAAqB,CAAC,GAAG,CAC5B,gBAAgB,CAAC;gBACf,SAAS,EAAE,UAAU;gBACrB,OAAO,EAAE,WAAW;aACrB,CAAC,CACH,CAAC;YAEF,kHAAkH;YAClH,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,uBAAuB,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC;QAC1D,CAAC,EACD,EAAE,iBAAiB,EAAE,IAAI,EAAE,CAC5B,CAAC;QAEF,MAAM,CAAC,GAAG,EAAE;YACV,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC;YACnC,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC;YAC/B,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC;YAEnC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC;gBAC1B,SAAS;gBACT,OAAO,EAAE,CAAC,CAAC,OAAO;gBAClB,SAAS,EAAE,CAAC,CAAC,SAAS;aACvB,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;IAED,kBAAkB;QAChB,IAAI,CAAC,qBAAqB,EAAE,CAAC;IAC/B,CAAC;IAED,sBAAsB,CAAC,SAA0B;QAC/C,MAAM,aAAa,GAAG,IAAI,CAAC,UAAU,EAAE,EAAE,aAAa,CAAC;QAEvD,IAAI,CAAC,aAAa,EAAE;YAClB,OAAO;SACR;QAED,MAAM,MAAM,GAAG,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC;QAE9C,MAAM,cAAc,GAAG,IAAI,CAAC,SAAS,EAAE,KAAK,YAAY,CAAC,CAAC,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,CAAC,MAAM,CAAC,YAAY,CAAC;QACpG,MAAM,aAAa,GAAG,IAAI,CAAC,SAAS,EAAE,KAAK,YAAY,CAAC,CAAC,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC,CAAC,aAAa,CAAC,SAAS,CAAC;QAE7G,aAAa,CAAC,QAAQ,CAAC;YACrB,CAAC,IAAI,CAAC,SAAS,EAAE,KAAK,YAAY,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,EAClD,aAAa,GAAG,CAAC,SAAS,KAAK,OAAO,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,cAAc,CAAC;YAC5E,QAAQ,EAAE,QAAQ;SACnB,CAAC,CAAC;IACL,CAAC;IAED,iBAAiB,CAAC,SAA0B;QAC1C,MAAM,QAAQ,GAAG,IAAI,CAAC,wBAAwB,CAAC,KAAK,CAAC;QAErD,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE;YACpB,IAAI,SAAS,EAAE,EAAE;gBACf,OAAO,CAAC,IAAI,CACV,mHAAmH,CACpH,CAAC;aACH;YACD,OAAO;SACR;QAED,MAAM,EAAE,GAAG,SAAS,KAAK,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,2BAA2B,CAAC,CAAC,CAAC,IAAI,CAAC,uBAAuB,CAAC;QAEnG,IAAI,CAAC,EAAE,EAAE;YACP,OAAO;SACR;QAED,IAAI,CAAC,eAAe,CAAC;YACnB,OAAO,EAAE,EAAE,EAAE,OAAO;YACpB,SAAS,EAAE,IAAI,CAAC,SAAS,EAAE,KAAK,YAAY,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO;YACjE,MAAM,EAAE,SAAS;YACjB,GAAG,CAAC,IAAI,CAAC,SAAS,EAAE,KAAK,YAAY;gBACnC,CAAC,CAAC,EAAE,kBAAkB,EAAE,IAAI,CAAC,YAAY,EAAE,EAAE;gBAC7C,CAAC,CAAC,EAAE,iBAAiB,EAAE,IAAI,CAAC,YAAY,EAAE,EAAE,CAAC;SAChD,CAAC,CAAC;IACL,CAAC;IAED,eAAe,CAAC,OAAkD;QAChE,MAAM,aAAa,GAAG,IAAI,CAAC,UAAU,EAAE,EAAE,aAAa,CAAC;QAEvD,eAAe,CAAC;YACd,SAAS,EAAE,aAAa;YACxB,GAAG,CAAC,IAAI,CAAC,SAAS,EAAE,KAAK,YAAY;gBACnC,CAAC,CAAC,EAAE,kBAAkB,EAAE,IAAI,CAAC,YAAY,EAAE,EAAE;gBAC7C,CAAC,CAAC,EAAE,iBAAiB,EAAE,IAAI,CAAC,YAAY,EAAE,EAAE,CAAC;YAC/C,GAAG,OAAO;SACX,CAAC,CAAC;IACL,CAAC;IAED,sBAAsB,CAAC,OAAsE;QAC3F,MAAM,QAAQ,GAAG,IAAI,CAAC,WAAW,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;QAErD,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE;YACpB,IAAI,SAAS,EAAE,EAAE;gBACf,OAAO,CAAC,IAAI,CACV,mHAAmH,CACpH,CAAC;aACH;YACD,OAAO;SACR;QAED,MAAM,aAAa,GAAG,IAAI,CAAC,UAAU,EAAE,EAAE,aAAa,CAAC;QACvD,MAAM,OAAO,GAAG,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,UAAU,CAAC,aAAa,CAAC;QAElE,eAAe,CAAC;YACd,SAAS,EAAE,aAAa;YACxB,OAAO;YACP,GAAG,CAAC,IAAI,CAAC,SAAS,EAAE,KAAK,YAAY;gBACnC,CAAC,CAAC,EAAE,kBAAkB,EAAE,IAAI,CAAC,YAAY,EAAE,EAAE;gBAC7C,CAAC,CAAC,EAAE,iBAAiB,EAAE,IAAI,CAAC,YAAY,EAAE,EAAE,CAAC;YAC/C,GAAG,OAAO;SACX,CAAC,CAAC;IACL,CAAC;IAES,mBAAmB,CAAC,UAAmB;QAC/C,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IAC3C,CAAC;IAES,sBAAsB;QAC9B,IAAI,IAAI,CAAC,UAAU,EAAE,KAAK,WAAW,EAAE;YACrC,IAAI,CAAC,sBAAsB,CAAC,OAAO,CAAC,CAAC;SACtC;aAAM;YACL,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC,CAAC;SACjC;IACH,CAAC;IAES,gBAAgB;QACxB,IAAI,IAAI,CAAC,UAAU,EAAE,KAAK,WAAW,EAAE;YACrC,IAAI,CAAC,sBAAsB,CAAC,KAAK,CAAC,CAAC;SACpC;aAAM;YACL,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC;SAC/B;IACH,CAAC;IAEO,qBAAqB;QAC3B,MAAM,aAAa,GAAG,IAAI,CAAC,UAAU,EAAE,EAAE,aAAa,CAAC;QACvD,MAAM,QAAQ,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;QAEpC,IAAI,CAAC,aAAa,IAAI,CAAC,QAAQ,EAAE;YAC/B,OAAO;SACR;QAED,IAAI,UAAU,GAAG,KAAK,CAAC;QACvB,IAAI,WAAW,GAAG,CAAC,CAAC;QAEpB,KAAK,CAAC,SAAS,CAAa,aAAa,EAAE,OAAO,CAAC,EAAE,SAAS,CAAa,aAAa,EAAE,YAAY,CAAC,CAAC;aACrG,IAAI,CACH,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,EACzB,GAAG,CAAC,GAAG,EAAE;YACP,UAAU,GAAG,KAAK,CAAC;QACrB,CAAC,CAAC,CACH;aACA,SAAS,EAAE,CAAC;QAEf,KAAK,CACH,SAAS,CAAC,aAAa,EAAE,QAAQ,CAAC,EAClC,IAAI,CAAC,kBAAkB,EACvB,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,IAAI,EAAE,CAAC,IAAI,CAAC,CACvD;aACE,IAAI,CACH,YAAY,CAAC,GAAG,CAAC,EACjB,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,EACzB,GAAG,CAAC,GAAG,EAAE;YACP,MAAM,GAAG,GACP,QAAQ;gBACN,EAAE,OAAO,EAAE;iBACV,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,UAAU,CAAC,aAAa,CAAC;iBACvC,MAAM,CAAC,CAAC,CAAC,EAAoB,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;YAEhD,IAAI,CAAC,GAAG,CAAC,MAAM,EAAE;gBACf,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;gBAEvC,OAAO;aACR;YAED,MAAM,MAAM,GAAG,uBAAuB,CAAC;gBACrC,QAAQ,EAAE,GAAG;gBACb,SAAS,EAAE,aAAa;aACzB,CAAC,CAAC;YAEH,MAAM,IAAI,GAAG,IAAI,CAAC,SAAS,EAAE,KAAK,YAAY,CAAC,CAAC,CAAC,oBAAoB,CAAC,CAAC,CAAC,mBAAmB,CAAC;YAC5F,MAAM,UAAU,GAAG,6BAA6B,CAAC;YAEjD,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE;gBAC1B,IAAI,KAAK,CAAC,IAAI,CAAC,KAAK,GAAG,EAAE;oBACvB,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;iBACzC;qBAAM;oBACL,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;iBAC5C;aACF;YAED,MAAM,mBAAmB,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;gBAC9C,MAAM,KAAK,GAAiC;oBAC1C,OAAO,EAAE,CAAC,CAAC,OAAO;oBAClB,iBAAiB,EAAE,CAAC,CAAC,IAAI,CAAC,GAAG,GAAG;oBAChC,cAAc,EAAE,CAAC,CAAC,IAAI,CAAC,KAAK,GAAG;oBAC/B,KAAK,EAAE,CAAC;iBACT,CAAC;gBAEF,OAAO,KAAK,CAAC;YACf,CAAC,CAAC,CAAC;YAEH,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;YAElD,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;YAExD,IAAI,UAAU,IAAI,IAAI,CAAC,kBAAkB,CAAC,KAAK,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE;gBAAE,OAAO;YAExE,MAAM,IAAI,GAAG,IAAI,CAAC,2BAA2B,CAAC;YAC9C,MAAM,IAAI,GAAG,IAAI,CAAC,uBAAuB,CAAC;YAC1C,MAAM,QAAQ,GACZ,CAAC,IAAI;gBACL,CAAC,IAAI;gBACL,IAAI,CAAC,iBAAiB,KAAK,CAAC;gBAC5B,IAAI,CAAC,iBAAiB,KAAK,CAAC;gBAC5B,IAAI,CAAC,iBAAiB,KAAK,IAAI,CAAC,iBAAiB,CAAC;YAEpD,IAAI,QAAQ;gBAAE,OAAO;YAErB,MAAM,mBAAmB,GAAG,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC;YAC1F,MAAM,qBAAqB,GAAG,IAAI,CAAC,0BAA0B,EAAE,KAAK,CAAC;YAErE,IAAI,qBAAqB,KAAK,SAAS;gBAAE,OAAO;YAEhD,MAAM,wBAAwB,GAAG,mBAAmB,CAAC,KAAK,CAAC;YAC3D,MAAM,MAAM,GAAG,wBAAwB,GAAG,qBAAqB,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC;YAElF,eAAe,CAAC;gBACd,SAAS,EAAE,aAAa;gBACxB,OAAO,EAAE,mBAAmB,CAAC,OAAO;gBACpC,SAAS,EAAE,IAAI,CAAC,SAAS,EAAE,KAAK,YAAY,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO;gBACjE,MAAM;gBACN,iBAAiB,EAAE,IAAI,CAAC,SAAS,EAAE,KAAK,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,EAAE;gBAC9E,kBAAkB,EAAE,IAAI,CAAC,SAAS,EAAE,KAAK,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC,CAAC;aAChF,CAAC,CAAC;YAEH,UAAU,GAAG,IAAI,CAAC;YAElB,MAAM,CAAC,YAAY,CAAC,WAAW,CAAC,CAAC;YAEjC,WAAW,GAAG,MAAM,CAAC,UAAU,CAAC,GAAG,EAAE;gBACnC,UAAU,GAAG,KAAK,CAAC;YACrB,CAAC,EAAE,IAAI,CAAC,CAAC;QACX,CAAC,CAAC,CACH;aACA,SAAS,EAAE,CAAC;IACjB,CAAC;8GAzgBU,mBAAmB;kGAAnB,mBAAmB,2SA+BV,gBAAgB,uDAMhB,gBAAgB,gEAMhB,gBAAgB,uDAMhB,gBAAgB,gEAMhB,gBAAgB,uGAMhB,gBAAgB,wEAYhB,gBAAgB,oDAMhB,eAAe,0MA8BlB,iBAAiB,kEAMjB,UAAU,mYC9K7B,m0CA6CA,yiLDSY,yBAAyB,wNAA+B,OAAO,oFAAgB,oBAAoB;;2FAKlG,mBAAmB;kBAZ/B,SAAS;+BACE,eAAe,cAGb,IAAI,iBACD,iBAAiB,CAAC,IAAI,mBACpB,uBAAuB,CAAC,MAAM,WACtC,CAAC,yBAAyB,EAAE,2BAA2B,EAAE,OAAO,EAAE,YAAY,EAAE,oBAAoB,CAAC,QACxG;wBACJ,KAAK,EAAE,eAAe;qBACvB;wDAUG,SAAS;sBADZ,KAAK;uBAAC,EAAE,KAAK,EAAE,UAAU,EAAE;gBAOxB,UAAU;sBADb,KAAK;uBAAC,EAAE,KAAK,EAAE,WAAW,EAAE;gBAOzB,eAAe;sBADlB,KAAK;uBAAC,EAAE,KAAK,EAAE,gBAAgB,EAAE;gBAO9B,gBAAgB;sBADnB,KAAK;uBAAC,EAAE,KAAK,EAAE,iBAAiB,EAAE;gBAO/B,YAAY;sBADf,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE,KAAK,EAAE,aAAa,EAAE;gBAOxD,cAAc;sBADjB,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE,KAAK,EAAE,eAAe,EAAE;gBAO1D,iBAAiB;sBADpB,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE,KAAK,EAAE,kBAAkB,EAAE;gBAO7D,cAAc;sBADjB,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE,KAAK,EAAE,eAAe,EAAE;gBAO1D,iBAAiB;sBADpB,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE,KAAK,EAAE,kBAAkB,EAAE;gBAO7D,8BAA8B;sBADjC,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE,KAAK,EAAE,+BAA+B,EAAE;gBAO1E,WAAW;sBADd,KAAK;uBAAC,EAAE,KAAK,EAAE,YAAY,EAAE;gBAO1B,KAAK;sBADR,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE,KAAK,EAAE,MAAM,EAAE;gBAOjD,aAAa;sBADhB,KAAK;uBAAC,EAAE,SAAS,EAAE,eAAe,EAAE,KAAK,EAAE,cAAc,EAAE;gBAOnD,iBAAiB;sBADzB,MAAM;gBAIE,kBAAkB;sBAD1B,MAAM;gBAIK,WAAW;sBADtB,SAAS;uBAAC,YAAY,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBAO7B,aAAa;sBADxB,SAAS;uBAAC,cAAc,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBAO/B,YAAY;sBADvB,SAAS;uBAAC,aAAa,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBAO9B,kBAAkB;sBAD7B,eAAe;uBAAC,iBAAiB,EAAE,EAAE,WAAW,EAAE,IAAI,EAAE;gBAO7C,YAAY;sBADvB,eAAe;uBAAC,UAAU,EAAE,EAAE,WAAW,EAAE,IAAI,EAAE","sourcesContent":["import { NgClass } from '@angular/common';\nimport {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  Component,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  Input,\n  Output,\n  ViewChild,\n  ViewEncapsulation,\n  booleanAttribute,\n  computed,\n  effect,\n  inject,\n  isDevMode,\n  numberAttribute,\n  signal,\n} from '@angular/core';\nimport {\n  CurrentElementVisibility,\n  CursorDragScrollDirective,\n  IS_ACTIVE_ELEMENT,\n  IS_ELEMENT,\n  IsActiveElementDirective,\n  IsElementDirective,\n  LetDirective,\n  NgClassType,\n  ObserveScrollStateDirective,\n  ScrollObserverScrollState,\n  ScrollToElementOptions,\n  TypedQueryList,\n  createDestroy,\n  getElementVisibleStates,\n  isElementVisible,\n  nextFrame,\n  scrollToElement,\n  signalElementIntersection,\n  signalElementScrollState,\n  signalHostAttributes,\n  signalHostClasses,\n} from '@ethlete/core';\nimport { BehaviorSubject, debounceTime, fromEvent, merge, of, startWith, takeUntil, tap } from 'rxjs';\nimport { ChevronIconComponent } from '../../../icons';\nimport { ScrollableIntersectionChange, ScrollableScrollMode } from '../../types';\n\n@Component({\n  selector: 'et-scrollable',\n  templateUrl: './scrollable.component.html',\n  styleUrls: ['./scrollable.component.scss'],\n  standalone: true,\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [CursorDragScrollDirective, ObserveScrollStateDirective, NgClass, LetDirective, ChevronIconComponent],\n  host: {\n    class: 'et-scrollable',\n  },\n})\nexport class ScrollableComponent implements AfterContentInit {\n  private readonly _destroy$ = createDestroy();\n  private readonly _elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n\n  private readonly _isCursorDragging$ = new BehaviorSubject<boolean>(false);\n  private readonly _latestVisibilityStates$ = new BehaviorSubject<ScrollableIntersectionChange[]>([]);\n\n  @Input({ alias: 'itemSize' })\n  set _itemSize(v: 'auto' | 'same' | 'full') {\n    this.itemSize.set(v);\n  }\n  readonly itemSize = signal<'auto' | 'same' | 'full'>('auto');\n\n  @Input({ alias: 'direction' })\n  set _direction(v: 'horizontal' | 'vertical') {\n    this.direction.set(v);\n  }\n  readonly direction = signal<'horizontal' | 'vertical'>('horizontal');\n\n  @Input({ alias: 'scrollableRole' })\n  set _scrollableRole(v: string | null) {\n    this.scrollableRole.set(v);\n  }\n  readonly scrollableRole = signal<string | null>(null);\n\n  @Input({ alias: 'scrollableClass' })\n  set _scrollableClass(v: NgClassType | null) {\n    this.scrollableClass.set(v);\n  }\n  readonly scrollableClass = signal<NgClassType | null>(null);\n\n  @Input({ transform: booleanAttribute, alias: 'renderMasks' })\n  set _renderMasks(v: boolean) {\n    this.renderMasks.set(v);\n  }\n  readonly renderMasks = signal(true);\n\n  @Input({ transform: booleanAttribute, alias: 'renderButtons' })\n  set _renderButtons(v: boolean) {\n    this.renderButtons.set(v);\n  }\n  readonly renderButtons = signal(true);\n\n  @Input({ transform: booleanAttribute, alias: 'renderScrollbars' })\n  set _renderScrollbars(v: boolean) {\n    this.renderScrollbars.set(v);\n  }\n  readonly renderScrollbars = signal(false);\n\n  @Input({ transform: booleanAttribute, alias: 'stickyButtons' })\n  set _stickyButtons(v: boolean) {\n    this.stickyButtons.set(v);\n  }\n  readonly stickyButtons = signal(false);\n\n  @Input({ transform: booleanAttribute, alias: 'cursorDragScroll' })\n  set _cursorDragScroll(v: boolean) {\n    this.cursorDragScroll.set(v);\n  }\n  readonly cursorDragScroll = signal(true);\n\n  @Input({ transform: booleanAttribute, alias: 'disableActiveElementScrolling' })\n  set _disableActiveElementScrolling(v: boolean) {\n    this.disableActiveElementScrolling.set(v);\n  }\n  readonly disableActiveElementScrolling = signal(false);\n\n  @Input({ alias: 'scrollMode' })\n  set _scrollMode(v: ScrollableScrollMode) {\n    this.scrollMode.set(v);\n  }\n  readonly scrollMode = signal<ScrollableScrollMode>('container');\n\n  @Input({ transform: booleanAttribute, alias: 'snap' })\n  set _snap(v: boolean) {\n    this.snap.set(v);\n  }\n  readonly snap = signal(false);\n\n  @Input({ transform: numberAttribute, alias: 'scrollMargin' })\n  set _scrollMargin(v: number) {\n    this.scrollMargin.set(v);\n  }\n  readonly scrollMargin = signal(0);\n\n  @Output()\n  readonly scrollStateChange = new EventEmitter<ScrollObserverScrollState>();\n\n  @Output()\n  readonly intersectionChange = new EventEmitter<ScrollableIntersectionChange[]>();\n\n  @ViewChild('scrollable', { static: true })\n  private set _scrollable(e: ElementRef<HTMLElement>) {\n    this.scrollable.set(e);\n  }\n  readonly scrollable = signal<ElementRef<HTMLElement> | null>(null);\n\n  @ViewChild('firstElement', { static: true })\n  private set _firstElement(e: ElementRef<HTMLElement>) {\n    this.firstElement.set(e);\n  }\n  readonly firstElement = signal<ElementRef<HTMLElement> | null>(null);\n\n  @ViewChild('lastElement', { static: true })\n  private set _lastElement(e: ElementRef<HTMLElement>) {\n    this.lastElement.set(e);\n  }\n  readonly lastElement = signal<ElementRef<HTMLElement> | null>(null);\n\n  @ContentChildren(IS_ACTIVE_ELEMENT, { descendants: true })\n  private set _activeElementList(e: TypedQueryList<IsActiveElementDirective>) {\n    this.activeElementList.set(e);\n  }\n  readonly activeElementList = signal<TypedQueryList<IsActiveElementDirective> | null>(null);\n\n  @ContentChildren(IS_ELEMENT, { descendants: true })\n  private set _elementList(e: TypedQueryList<IsElementDirective>) {\n    this.elementList.set(e);\n  }\n  readonly elementList = signal<TypedQueryList<IsElementDirective> | null>(null);\n\n  get highestVisibleIntersection() {\n    const elements = this._latestVisibilityStates$.value;\n\n    if (!elements.length) {\n      return null;\n    }\n\n    return elements.reduce((prev, curr) => {\n      if (!prev) {\n        return curr;\n      }\n\n      return curr.intersectionRatio > prev.intersectionRatio ? curr : prev;\n    });\n  }\n\n  get nextPartialIntersection() {\n    const elements = this._latestVisibilityStates$.value;\n\n    if (!elements.length) {\n      return null;\n    }\n\n    const highestVisibleIntersection = this.highestVisibleIntersection;\n\n    if (!highestVisibleIntersection) {\n      return null;\n    }\n\n    const nextIndex = elements.slice(highestVisibleIntersection.index).findIndex((e) => !e.isIntersecting);\n\n    if (nextIndex === -1) {\n      return null;\n    }\n\n    const nextElement = elements[highestVisibleIntersection.index + nextIndex];\n\n    return nextElement || null;\n  }\n\n  get previousPartialIntersection() {\n    const elements = this._latestVisibilityStates$.value;\n\n    if (!elements.length) {\n      return null;\n    }\n\n    const highestVisibleIntersection = this.highestVisibleIntersection;\n\n    if (!highestVisibleIntersection) {\n      return null;\n    }\n\n    const previousIndex = elements\n      .slice(0, highestVisibleIntersection.index)\n      .reverse()\n      .findIndex((e) => !e.isIntersecting);\n\n    if (previousIndex === -1) {\n      return null;\n    }\n\n    const previousElement = elements[highestVisibleIntersection.index - previousIndex - 1];\n\n    return previousElement || null;\n  }\n\n  protected readonly containerScrollState = signalElementScrollState(this.scrollable);\n  protected readonly firstElementIntersection = signalElementIntersection(this.firstElement, { root: this.scrollable });\n  protected readonly firstElementVisibility = signal<CurrentElementVisibility | null>(null);\n  protected readonly lastElementIntersection = signalElementIntersection(this.lastElement, { root: this.scrollable });\n  protected readonly lastElementVisibility = signal<CurrentElementVisibility | null>(null);\n\n  protected readonly canScroll = computed(() => {\n    const dir = this.direction();\n\n    if (dir === 'horizontal') {\n      return this.containerScrollState().canScrollHorizontally;\n    }\n\n    return this.containerScrollState().canScrollVertically;\n  });\n\n  protected readonly isAtStart = computed(() => {\n    if (!this.canScroll()) {\n      return true;\n    }\n\n    const intersection = this.firstElementIntersection();\n\n    if (!intersection) {\n      return this.firstElementVisibility()?.inline ?? true;\n    }\n\n    return intersection.isIntersecting;\n  });\n  protected readonly isAtEnd = computed(() => {\n    if (!this.canScroll()) {\n      return true;\n    }\n\n    const intersection = this.lastElementIntersection();\n\n    if (!intersection) {\n      return this.lastElementVisibility()?.inline ?? true;\n    }\n\n    return intersection.isIntersecting;\n  });\n\n  protected readonly enableOverlayAnimations = signal(false);\n\n  protected readonly hostAttributes = signalHostAttributes({\n    'item-size': this.itemSize,\n    direction: this.direction,\n    'render-scrollbars': this.renderScrollbars,\n    'sticky-buttons': this.stickyButtons,\n  });\n\n  protected readonly hostClasses = signalHostClasses({\n    'et-scrollable--can-scroll': this.canScroll,\n    'et-scrollable--is-at-start': this.isAtStart,\n    'et-scrollable--is-at-end': this.isAtEnd,\n    'et-scrollable--enable-overlay-animations': this.enableOverlayAnimations,\n  });\n\n  constructor() {\n    effect(\n      () => {\n        const scrollable = this.scrollable()?.nativeElement;\n        const firstElement = this.firstElement()?.nativeElement;\n        const lastElement = this.lastElement()?.nativeElement;\n        const activeElementList = this.activeElementList()?.toArray();\n\n        if (!scrollable || !firstElement || !lastElement || !activeElementList) {\n          return;\n        }\n\n        const firstActive = activeElementList.find((a) => a.isActiveElement);\n\n        if (firstActive && !this.disableActiveElementScrolling()) {\n          const offsetTop = firstActive.elementRef.nativeElement.offsetTop - scrollable.offsetTop;\n          const offsetLeft = firstActive.elementRef.nativeElement.offsetLeft - scrollable.offsetLeft;\n          scrollable.scrollLeft = offsetLeft;\n          scrollable.scrollTop = offsetTop;\n        }\n\n        this.firstElementVisibility.set(\n          isElementVisible({\n            container: scrollable,\n            element: firstElement,\n          }),\n        );\n\n        this.lastElementVisibility.set(\n          isElementVisible({\n            container: scrollable,\n            element: lastElement,\n          }),\n        );\n\n        // We need to wait one frame before enabling animations to prevent a animation from playing during initial render.\n        nextFrame(() => this.enableOverlayAnimations.set(true));\n      },\n      { allowSignalWrites: true },\n    );\n\n    effect(() => {\n      const isAtStart = this.isAtStart();\n      const isAtEnd = this.isAtEnd();\n      const canScroll = this.canScroll();\n\n      this.scrollStateChange.emit({\n        canScroll,\n        isAtEnd: !!isAtEnd,\n        isAtStart: !!isAtStart,\n      });\n    });\n  }\n\n  ngAfterContentInit(): void {\n    this._setupScrollListening();\n  }\n\n  scrollOneContainerSize(direction: 'start' | 'end') {\n    const scrollElement = this.scrollable()?.nativeElement;\n\n    if (!scrollElement) {\n      return;\n    }\n\n    const parent = this._elementRef.nativeElement;\n\n    const scrollableSize = this.direction() === 'horizontal' ? parent.clientWidth : parent.clientHeight;\n    const currentScroll = this.direction() === 'horizontal' ? scrollElement.scrollLeft : scrollElement.scrollTop;\n\n    scrollElement.scrollTo({\n      [this.direction() === 'horizontal' ? 'left' : 'top']:\n        currentScroll + (direction === 'start' ? -scrollableSize : scrollableSize),\n      behavior: 'smooth',\n    });\n  }\n\n  scrollOneItemSize(direction: 'start' | 'end') {\n    const elements = this._latestVisibilityStates$.value;\n\n    if (!elements.length) {\n      if (isDevMode()) {\n        console.warn(\n          'No elements found to scroll to. Make sure to apply the isElement directive to the elements you want to scroll to.',\n        );\n      }\n      return;\n    }\n\n    const el = direction === 'start' ? this.previousPartialIntersection : this.nextPartialIntersection;\n\n    if (!el) {\n      return;\n    }\n\n    this.scrollToElement({\n      element: el?.element,\n      direction: this.direction() === 'horizontal' ? 'inline' : 'block',\n      origin: direction,\n      ...(this.direction() === 'horizontal'\n        ? { scrollInlineMargin: this.scrollMargin() }\n        : { scrollBlockMargin: this.scrollMargin() }),\n    });\n  }\n\n  scrollToElement(options: Omit<ScrollToElementOptions, 'container'>) {\n    const scrollElement = this.scrollable()?.nativeElement;\n\n    scrollToElement({\n      container: scrollElement,\n      ...(this.direction() === 'horizontal'\n        ? { scrollInlineMargin: this.scrollMargin() }\n        : { scrollBlockMargin: this.scrollMargin() }),\n      ...options,\n    });\n  }\n\n  scrollToElementByIndex(options: Omit<ScrollToElementOptions, 'container'> & { index: number }) {\n    const elements = this.elementList()?.toArray() ?? [];\n\n    if (!elements.length) {\n      if (isDevMode()) {\n        console.warn(\n          'No elements found to scroll to. Make sure to apply the isElement directive to the elements you want to scroll to.',\n        );\n      }\n      return;\n    }\n\n    const scrollElement = this.scrollable()?.nativeElement;\n    const element = elements[options.index]?.elementRef.nativeElement;\n\n    scrollToElement({\n      container: scrollElement,\n      element,\n      ...(this.direction() === 'horizontal'\n        ? { scrollInlineMargin: this.scrollMargin() }\n        : { scrollBlockMargin: this.scrollMargin() }),\n      ...options,\n    });\n  }\n\n  protected setIsCursorDragging(isDragging: boolean) {\n    this._isCursorDragging$.next(isDragging);\n  }\n\n  protected scrollToStartDirection() {\n    if (this.scrollMode() === 'container') {\n      this.scrollOneContainerSize('start');\n    } else {\n      this.scrollOneItemSize('start');\n    }\n  }\n\n  protected scrollToStartEnd() {\n    if (this.scrollMode() === 'container') {\n      this.scrollOneContainerSize('end');\n    } else {\n      this.scrollOneItemSize('end');\n    }\n  }\n\n  private _setupScrollListening() {\n    const scrollElement = this.scrollable()?.nativeElement;\n    const elements = this.elementList();\n\n    if (!scrollElement || !elements) {\n      return;\n    }\n\n    let isSnapping = false;\n    let snapTimeout = 0;\n\n    merge(fromEvent<WheelEvent>(scrollElement, 'wheel'), fromEvent<TouchEvent>(scrollElement, 'touchstart'))\n      .pipe(\n        takeUntil(this._destroy$),\n        tap(() => {\n          isSnapping = false;\n        }),\n      )\n      .subscribe();\n\n    merge(\n      fromEvent(scrollElement, 'scroll'),\n      this._isCursorDragging$,\n      elements.changes.pipe(startWith(elements)) ?? of(null),\n    )\n      .pipe(\n        debounceTime(300),\n        takeUntil(this._destroy$),\n        tap(() => {\n          const els =\n            elements\n              ?.toArray()\n              .map((e) => e?.elementRef.nativeElement)\n              .filter((e): e is HTMLElement => !!e) ?? [];\n\n          if (!els.length) {\n            this._latestVisibilityStates$.next([]);\n\n            return;\n          }\n\n          const states = getElementVisibleStates({\n            elements: els,\n            container: scrollElement,\n          });\n\n          const prop = this.direction() === 'horizontal' ? 'inlineIntersection' : 'blockIntersection';\n          const stateClass = `et-element--is-intersecting`;\n\n          for (const state of states) {\n            if (state[prop] === 100) {\n              state.element.classList.add(stateClass);\n            } else {\n              state.element.classList.remove(stateClass);\n            }\n          }\n\n          const intersectionChanges = states.map((s, i) => {\n            const state: ScrollableIntersectionChange = {\n              element: s.element,\n              intersectionRatio: s[prop] / 100,\n              isIntersecting: s[prop] === 100,\n              index: i,\n            };\n\n            return state;\n          });\n\n          this.intersectionChange.emit(intersectionChanges);\n\n          this._latestVisibilityStates$.next(intersectionChanges);\n\n          if (isSnapping || this._isCursorDragging$.value || !this.snap()) return;\n\n          const prev = this.previousPartialIntersection;\n          const next = this.nextPartialIntersection;\n          const skipSnap =\n            !prev ||\n            !next ||\n            prev.intersectionRatio === 0 ||\n            next.intersectionRatio === 0 ||\n            prev.intersectionRatio === next.intersectionRatio;\n\n          if (skipSnap) return;\n\n          const highestIntersecting = prev.intersectionRatio > next.intersectionRatio ? prev : next;\n          const fullIntersectionIndex = this.highestVisibleIntersection?.index;\n\n          if (fullIntersectionIndex === undefined) return;\n\n          const highestIntersectingIndex = highestIntersecting.index;\n          const origin = highestIntersectingIndex > fullIntersectionIndex ? 'end' : 'start';\n\n          scrollToElement({\n            container: scrollElement,\n            element: highestIntersecting.element,\n            direction: this.direction() === 'horizontal' ? 'inline' : 'block',\n            origin,\n            scrollBlockMargin: this.direction() === 'horizontal' ? 0 : this.scrollMargin(),\n            scrollInlineMargin: this.direction() === 'horizontal' ? this.scrollMargin() : 0,\n          });\n\n          isSnapping = true;\n\n          window.clearTimeout(snapTimeout);\n\n          snapTimeout = window.setTimeout(() => {\n            isSnapping = false;\n          }, 1000);\n        }),\n      )\n      .subscribe();\n  }\n}\n","<div\n  #scrollable\n  [attr.role]=\"scrollableRole() ?? undefined\"\n  [etCursorDragScroll]=\"cursorDragScroll()\"\n  [allowedDirection]=\"direction()\"\n  (cursorDragStart)=\"setIsCursorDragging(true)\"\n  (cursorDragEnd)=\"setIsCursorDragging(false)\"\n  class=\"et-scrollable-container-outer\"\n>\n  <div [ngClass]=\"scrollableClass()\" class=\"et-scrollable-container\">\n    <div #firstElement class=\"et-scroll-observer-first-element\"></div>\n    <ng-content />\n    <div #lastElement class=\"et-scroll-observer-last-element\"></div>\n  </div>\n</div>\n\n@if (renderMasks()) {\n  <div class=\"et-scrollable-masks\">\n    <div class=\"et-scrollable-mask et-scrollable-mask--start\"></div>\n    <div class=\"et-scrollable-mask et-scrollable-mask--end\"></div>\n  </div>\n}\n\n@if (renderButtons()) {\n  <div class=\"et-scrollable-buttons\">\n    <button\n      (click)=\"scrollToStartDirection()\"\n      class=\"et-scrollable-button et-scrollable-button--start\"\n      aria-hidden=\"true\"\n      type=\"button\"\n      tabindex=\"-1\"\n    >\n      <et-chevron-icon />\n    </button>\n    <button\n      (click)=\"scrollToStartEnd()\"\n      class=\"et-scrollable-button et-scrollable-button--end\"\n      aria-hidden=\"true\"\n      type=\"button\"\n      tabindex=\"-1\"\n    >\n      <et-chevron-icon />\n    </button>\n  </div>\n}\n"]}