@mantine/core 7.0.0-alpha.2 → 7.0.0-alpha.3

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 (426) hide show
  1. package/cjs/components/ActionIcon/ActionIcon.js +7 -5
  2. package/cjs/components/ActionIcon/ActionIcon.js.map +1 -1
  3. package/cjs/components/ActionIcon/ActionIconGroup/ActionIconGroup.js.map +1 -1
  4. package/cjs/components/Affix/Affix.js +109 -0
  5. package/cjs/components/Affix/Affix.js.map +1 -0
  6. package/cjs/components/Affix/Affix.module.css.js +8 -0
  7. package/cjs/components/Affix/Affix.module.css.js.map +1 -0
  8. package/cjs/components/Alert/Alert.js +147 -0
  9. package/cjs/components/Alert/Alert.js.map +1 -0
  10. package/cjs/components/Alert/Alert.module.css.js +8 -0
  11. package/cjs/components/Alert/Alert.module.css.js.map +1 -0
  12. package/cjs/components/Anchor/Anchor.js.map +1 -1
  13. package/cjs/components/AspectRatio/AspectRatio.js +73 -0
  14. package/cjs/components/AspectRatio/AspectRatio.js.map +1 -0
  15. package/cjs/components/AspectRatio/AspectRatio.module.css.js +8 -0
  16. package/cjs/components/AspectRatio/AspectRatio.module.css.js.map +1 -0
  17. package/cjs/components/Avatar/Avatar.js +140 -0
  18. package/cjs/components/Avatar/Avatar.js.map +1 -0
  19. package/cjs/components/Avatar/Avatar.module.css.js +8 -0
  20. package/cjs/components/Avatar/Avatar.module.css.js.map +1 -0
  21. package/cjs/components/Avatar/AvatarGroup/AvatarGroup.context.js +16 -0
  22. package/cjs/components/Avatar/AvatarGroup/AvatarGroup.context.js.map +1 -0
  23. package/cjs/components/Avatar/AvatarGroup/AvatarGroup.js +79 -0
  24. package/cjs/components/Avatar/AvatarGroup/AvatarGroup.js.map +1 -0
  25. package/cjs/components/Avatar/AvatarGroup/AvatarGroup.module.css.js +8 -0
  26. package/cjs/components/Avatar/AvatarGroup/AvatarGroup.module.css.js.map +1 -0
  27. package/cjs/components/Avatar/AvatarPlaceholderIcon.js +45 -0
  28. package/cjs/components/Avatar/AvatarPlaceholderIcon.js.map +1 -0
  29. package/cjs/components/BackgroundImage/BackgroundImage.js.map +1 -1
  30. package/cjs/components/Badge/Badge.js +134 -0
  31. package/cjs/components/Badge/Badge.js.map +1 -0
  32. package/cjs/components/Badge/Badge.module.css.js +8 -0
  33. package/cjs/components/Badge/Badge.module.css.js.map +1 -0
  34. package/cjs/components/Blockquote/Blockquote.js.map +1 -1
  35. package/cjs/components/Breadcrumbs/Breadcrumbs.js +1 -1
  36. package/cjs/components/Breadcrumbs/Breadcrumbs.js.map +1 -1
  37. package/cjs/components/Burger/Burger.js.map +1 -1
  38. package/cjs/components/Button/Button.js.map +1 -1
  39. package/cjs/components/Button/ButtonGroup/ButtonGroup.js.map +1 -1
  40. package/cjs/components/Center/Center.js.map +1 -1
  41. package/cjs/components/CloseButton/CloseButton.js.map +1 -1
  42. package/cjs/components/Code/Code.js.map +1 -1
  43. package/cjs/components/ColorPicker/ColorPicker.js.map +1 -1
  44. package/cjs/components/ColorPicker/converters/parsers.js +4 -4
  45. package/cjs/components/ColorPicker/converters/parsers.js.map +1 -1
  46. package/cjs/components/ColorSwatch/ColorSwatch.js +3 -3
  47. package/cjs/components/ColorSwatch/ColorSwatch.js.map +1 -1
  48. package/cjs/components/Container/Container.js.map +1 -1
  49. package/cjs/components/CopyButton/CopyButton.js.map +1 -1
  50. package/cjs/components/Divider/Divider.js +111 -0
  51. package/cjs/components/Divider/Divider.js.map +1 -0
  52. package/cjs/components/Divider/Divider.module.css.js +8 -0
  53. package/cjs/components/Divider/Divider.module.css.js.map +1 -0
  54. package/cjs/components/FileButton/FileButton.js.map +1 -1
  55. package/cjs/components/Group/Group.js.map +1 -1
  56. package/cjs/components/Input/Input.js.map +1 -1
  57. package/cjs/components/Input/InputWrapper/InputWrapper.js.map +1 -1
  58. package/cjs/components/Loader/Loader.js.map +1 -1
  59. package/cjs/components/Overlay/Overlay.js +121 -0
  60. package/cjs/components/Overlay/Overlay.js.map +1 -0
  61. package/cjs/components/Overlay/Overlay.module.css.js +8 -0
  62. package/cjs/components/Overlay/Overlay.module.css.js.map +1 -0
  63. package/cjs/components/Paper/Paper.js.map +1 -1
  64. package/cjs/components/Popover/Popover.js +1 -1
  65. package/cjs/components/Popover/Popover.js.map +1 -1
  66. package/cjs/components/ScrollArea/ScrollArea.context.js +11 -0
  67. package/cjs/components/ScrollArea/ScrollArea.context.js.map +1 -0
  68. package/cjs/components/ScrollArea/ScrollArea.js +12 -29
  69. package/cjs/components/ScrollArea/ScrollArea.js.map +1 -1
  70. package/cjs/components/ScrollArea/ScrollArea.module.css.js +1 -1
  71. package/cjs/components/ScrollArea/ScrollAreaCorner/ScrollAreaCorner.js +78 -0
  72. package/cjs/components/ScrollArea/ScrollAreaCorner/ScrollAreaCorner.js.map +1 -0
  73. package/cjs/components/ScrollArea/ScrollAreaRoot/ScrollAreaRoot.js +94 -0
  74. package/cjs/components/ScrollArea/ScrollAreaRoot/ScrollAreaRoot.js.map +1 -0
  75. package/cjs/components/ScrollArea/ScrollAreaScrollbar/ScrollAreaScrollbar.js +73 -0
  76. package/cjs/components/ScrollArea/ScrollAreaScrollbar/ScrollAreaScrollbar.js.map +1 -0
  77. package/cjs/components/ScrollArea/ScrollAreaScrollbar/ScrollAreaScrollbarAuto.js +71 -0
  78. package/cjs/components/ScrollArea/ScrollAreaScrollbar/ScrollAreaScrollbarAuto.js.map +1 -0
  79. package/cjs/components/ScrollArea/ScrollAreaScrollbar/ScrollAreaScrollbarHover.js +80 -0
  80. package/cjs/components/ScrollArea/ScrollAreaScrollbar/ScrollAreaScrollbarHover.js.map +1 -0
  81. package/cjs/components/ScrollArea/ScrollAreaScrollbar/ScrollAreaScrollbarScroll.js +91 -0
  82. package/cjs/components/ScrollArea/ScrollAreaScrollbar/ScrollAreaScrollbarScroll.js.map +1 -0
  83. package/cjs/components/ScrollArea/ScrollAreaScrollbar/ScrollAreaScrollbarVisible.js +121 -0
  84. package/cjs/components/ScrollArea/ScrollAreaScrollbar/ScrollAreaScrollbarVisible.js.map +1 -0
  85. package/cjs/components/ScrollArea/ScrollAreaScrollbar/Scrollbar.context.js +11 -0
  86. package/cjs/components/ScrollArea/ScrollAreaScrollbar/Scrollbar.context.js.map +1 -0
  87. package/cjs/components/ScrollArea/ScrollAreaScrollbar/Scrollbar.js +135 -0
  88. package/cjs/components/ScrollArea/ScrollAreaScrollbar/Scrollbar.js.map +1 -0
  89. package/cjs/components/ScrollArea/ScrollAreaScrollbar/ScrollbarX.js +94 -0
  90. package/cjs/components/ScrollArea/ScrollAreaScrollbar/ScrollbarX.js.map +1 -0
  91. package/cjs/components/ScrollArea/ScrollAreaScrollbar/ScrollbarY.js +93 -0
  92. package/cjs/components/ScrollArea/ScrollAreaScrollbar/ScrollbarY.js.map +1 -0
  93. package/cjs/components/ScrollArea/ScrollAreaThumb/ScrollAreaThumb.js +108 -0
  94. package/cjs/components/ScrollArea/ScrollAreaThumb/ScrollAreaThumb.js.map +1 -0
  95. package/cjs/components/ScrollArea/ScrollAreaViewport/ScrollAreaViewport.js +63 -0
  96. package/cjs/components/ScrollArea/ScrollAreaViewport/ScrollAreaViewport.js.map +1 -0
  97. package/cjs/components/ScrollArea/use-resize-observer.js +27 -0
  98. package/cjs/components/ScrollArea/use-resize-observer.js.map +1 -0
  99. package/cjs/components/ScrollArea/utils/add-unlinked-scroll-listener.js +22 -0
  100. package/cjs/components/ScrollArea/utils/add-unlinked-scroll-listener.js.map +1 -0
  101. package/cjs/components/ScrollArea/utils/compose-event-handlers.js +15 -0
  102. package/cjs/components/ScrollArea/utils/compose-event-handlers.js.map +1 -0
  103. package/cjs/components/ScrollArea/utils/get-scroll-position-from-pointer.js +22 -0
  104. package/cjs/components/ScrollArea/utils/get-scroll-position-from-pointer.js.map +1 -0
  105. package/cjs/components/ScrollArea/utils/get-thumb-offset-from-scroll.js +24 -0
  106. package/cjs/components/ScrollArea/utils/get-thumb-offset-from-scroll.js.map +1 -0
  107. package/cjs/components/ScrollArea/utils/get-thumb-ratio.js +11 -0
  108. package/cjs/components/ScrollArea/utils/get-thumb-ratio.js.map +1 -0
  109. package/cjs/components/ScrollArea/utils/get-thumb-size.js +15 -0
  110. package/cjs/components/ScrollArea/utils/get-thumb-size.js.map +1 -0
  111. package/cjs/components/ScrollArea/utils/is-scrolling-within-scrollbar-bounds.js +10 -0
  112. package/cjs/components/ScrollArea/utils/is-scrolling-within-scrollbar-bounds.js.map +1 -0
  113. package/cjs/components/ScrollArea/utils/linear-scale.js +15 -0
  114. package/cjs/components/ScrollArea/utils/linear-scale.js.map +1 -0
  115. package/cjs/components/ScrollArea/utils/to-int.js +10 -0
  116. package/cjs/components/ScrollArea/utils/to-int.js.map +1 -0
  117. package/cjs/components/SegmentedControl/SegmentedControl.js.map +1 -1
  118. package/cjs/components/Slider/RangeSlider/RangeSlider.js +4 -11
  119. package/cjs/components/Slider/RangeSlider/RangeSlider.js.map +1 -1
  120. package/cjs/components/Slider/Slider/Slider.js +4 -11
  121. package/cjs/components/Slider/Slider/Slider.js.map +1 -1
  122. package/cjs/components/Slider/Thumb/Thumb.js +5 -8
  123. package/cjs/components/Slider/Thumb/Thumb.js.map +1 -1
  124. package/cjs/components/Stack/Stack.js.map +1 -1
  125. package/cjs/components/Switch/Switch.js.map +1 -1
  126. package/cjs/components/Switch/SwitchGroup/SwitchGroup.js.map +1 -1
  127. package/cjs/components/Table/Table.js.map +1 -1
  128. package/cjs/components/Tabs/Tabs.js.map +1 -1
  129. package/cjs/components/Tabs/Tabs.module.css.js +1 -1
  130. package/cjs/components/Tabs/TabsList/TabsList.js.map +1 -1
  131. package/cjs/components/Tabs/TabsTab/TabsTab.js +5 -1
  132. package/cjs/components/Tabs/TabsTab/TabsTab.js.map +1 -1
  133. package/cjs/components/Text/Text.js +1 -1
  134. package/cjs/components/Text/Text.js.map +1 -1
  135. package/cjs/components/Tooltip/Tooltip.js +1 -1
  136. package/cjs/components/Tooltip/Tooltip.js.map +1 -1
  137. package/cjs/components/Tooltip/use-tooltip.js.map +1 -1
  138. package/cjs/components/TypographyStylesProvider/TypographyStylesProvider.js +65 -0
  139. package/cjs/components/TypographyStylesProvider/TypographyStylesProvider.js.map +1 -0
  140. package/cjs/components/TypographyStylesProvider/TypographyStylesProvider.module.css.js +8 -0
  141. package/cjs/components/TypographyStylesProvider/TypographyStylesProvider.module.css.js.map +1 -0
  142. package/cjs/core/Box/style-props/resolvers/font-size-resolver/font-size-resolver.js +3 -0
  143. package/cjs/core/Box/style-props/resolvers/font-size-resolver/font-size-resolver.js.map +1 -1
  144. package/cjs/core/Box/style-props/resolvers/spacing-resolver/spacing-resolver.js +1 -1
  145. package/cjs/core/Box/style-props/resolvers/spacing-resolver/spacing-resolver.js.map +1 -1
  146. package/cjs/core/MantineProvider/MantineCssVariables/MantineCssVariables.js +15 -8
  147. package/cjs/core/MantineProvider/MantineCssVariables/MantineCssVariables.js.map +1 -1
  148. package/cjs/core/MantineProvider/MantineCssVariables/default-css-variables-resolver.js +1 -0
  149. package/cjs/core/MantineProvider/MantineCssVariables/default-css-variables-resolver.js.map +1 -1
  150. package/cjs/core/MantineProvider/MantineCssVariables/remove-default-variables.js +35 -0
  151. package/cjs/core/MantineProvider/MantineCssVariables/remove-default-variables.js.map +1 -0
  152. package/cjs/core/MantineProvider/MantineProvider.js.map +1 -1
  153. package/cjs/core/MantineProvider/convert-css-variables/convert-css-variables.js +6 -5
  154. package/cjs/core/MantineProvider/convert-css-variables/convert-css-variables.js.map +1 -1
  155. package/cjs/core/MantineProvider/default-theme.js +28 -26
  156. package/cjs/core/MantineProvider/default-theme.js.map +1 -1
  157. package/cjs/core/MantineProvider/use-mantine-color-scheme/use-mantine-color-scheme.js +39 -2
  158. package/cjs/core/MantineProvider/use-mantine-color-scheme/use-mantine-color-scheme.js.map +1 -1
  159. package/cjs/core/utils/units-converters/px.js +21 -10
  160. package/cjs/core/utils/units-converters/px.js.map +1 -1
  161. package/cjs/core/utils/units-converters/rem.js +23 -9
  162. package/cjs/core/utils/units-converters/rem.js.map +1 -1
  163. package/cjs/index.css +1687 -285
  164. package/cjs/index.js +16 -0
  165. package/cjs/index.js.map +1 -1
  166. package/esm/components/ActionIcon/ActionIcon.js +7 -5
  167. package/esm/components/ActionIcon/ActionIcon.js.map +1 -1
  168. package/esm/components/ActionIcon/ActionIconGroup/ActionIconGroup.js.map +1 -1
  169. package/esm/components/Affix/Affix.js +101 -0
  170. package/esm/components/Affix/Affix.js.map +1 -0
  171. package/esm/components/Affix/Affix.module.css.js +4 -0
  172. package/esm/components/Affix/Affix.module.css.js.map +1 -0
  173. package/esm/components/Alert/Alert.js +139 -0
  174. package/esm/components/Alert/Alert.js.map +1 -0
  175. package/esm/components/Alert/Alert.module.css.js +4 -0
  176. package/esm/components/Alert/Alert.module.css.js.map +1 -0
  177. package/esm/components/Anchor/Anchor.js.map +1 -1
  178. package/esm/components/AspectRatio/AspectRatio.js +65 -0
  179. package/esm/components/AspectRatio/AspectRatio.js.map +1 -0
  180. package/esm/components/AspectRatio/AspectRatio.module.css.js +4 -0
  181. package/esm/components/AspectRatio/AspectRatio.module.css.js.map +1 -0
  182. package/esm/components/Avatar/Avatar.js +132 -0
  183. package/esm/components/Avatar/Avatar.js.map +1 -0
  184. package/esm/components/Avatar/Avatar.module.css.js +4 -0
  185. package/esm/components/Avatar/Avatar.module.css.js.map +1 -0
  186. package/esm/components/Avatar/AvatarGroup/AvatarGroup.context.js +11 -0
  187. package/esm/components/Avatar/AvatarGroup/AvatarGroup.context.js.map +1 -0
  188. package/esm/components/Avatar/AvatarGroup/AvatarGroup.js +71 -0
  189. package/esm/components/Avatar/AvatarGroup/AvatarGroup.js.map +1 -0
  190. package/esm/components/Avatar/AvatarGroup/AvatarGroup.module.css.js +4 -0
  191. package/esm/components/Avatar/AvatarGroup/AvatarGroup.module.css.js.map +1 -0
  192. package/esm/components/Avatar/AvatarPlaceholderIcon.js +37 -0
  193. package/esm/components/Avatar/AvatarPlaceholderIcon.js.map +1 -0
  194. package/esm/components/BackgroundImage/BackgroundImage.js.map +1 -1
  195. package/esm/components/Badge/Badge.js +126 -0
  196. package/esm/components/Badge/Badge.js.map +1 -0
  197. package/esm/components/Badge/Badge.module.css.js +4 -0
  198. package/esm/components/Badge/Badge.module.css.js.map +1 -0
  199. package/esm/components/Blockquote/Blockquote.js.map +1 -1
  200. package/esm/components/Breadcrumbs/Breadcrumbs.js +1 -1
  201. package/esm/components/Breadcrumbs/Breadcrumbs.js.map +1 -1
  202. package/esm/components/Burger/Burger.js.map +1 -1
  203. package/esm/components/Button/Button.js.map +1 -1
  204. package/esm/components/Button/ButtonGroup/ButtonGroup.js.map +1 -1
  205. package/esm/components/Center/Center.js.map +1 -1
  206. package/esm/components/CloseButton/CloseButton.js.map +1 -1
  207. package/esm/components/Code/Code.js.map +1 -1
  208. package/esm/components/ColorPicker/ColorPicker.js.map +1 -1
  209. package/esm/components/ColorPicker/converters/parsers.js +4 -4
  210. package/esm/components/ColorPicker/converters/parsers.js.map +1 -1
  211. package/esm/components/ColorSwatch/ColorSwatch.js +3 -3
  212. package/esm/components/ColorSwatch/ColorSwatch.js.map +1 -1
  213. package/esm/components/Container/Container.js.map +1 -1
  214. package/esm/components/CopyButton/CopyButton.js.map +1 -1
  215. package/esm/components/Divider/Divider.js +103 -0
  216. package/esm/components/Divider/Divider.js.map +1 -0
  217. package/esm/components/Divider/Divider.module.css.js +4 -0
  218. package/esm/components/Divider/Divider.module.css.js.map +1 -0
  219. package/esm/components/FileButton/FileButton.js.map +1 -1
  220. package/esm/components/Group/Group.js.map +1 -1
  221. package/esm/components/Input/Input.js.map +1 -1
  222. package/esm/components/Input/InputWrapper/InputWrapper.js.map +1 -1
  223. package/esm/components/Loader/Loader.js.map +1 -1
  224. package/esm/components/Overlay/Overlay.js +113 -0
  225. package/esm/components/Overlay/Overlay.js.map +1 -0
  226. package/esm/components/Overlay/Overlay.module.css.js +4 -0
  227. package/esm/components/Overlay/Overlay.module.css.js.map +1 -0
  228. package/esm/components/Paper/Paper.js.map +1 -1
  229. package/esm/components/Popover/Popover.js +1 -1
  230. package/esm/components/Popover/Popover.js.map +1 -1
  231. package/esm/components/ScrollArea/ScrollArea.context.js +6 -0
  232. package/esm/components/ScrollArea/ScrollArea.context.js.map +1 -0
  233. package/esm/components/ScrollArea/ScrollArea.js +12 -16
  234. package/esm/components/ScrollArea/ScrollArea.js.map +1 -1
  235. package/esm/components/ScrollArea/ScrollArea.module.css.js +1 -1
  236. package/esm/components/ScrollArea/ScrollAreaCorner/ScrollAreaCorner.js +69 -0
  237. package/esm/components/ScrollArea/ScrollAreaCorner/ScrollAreaCorner.js.map +1 -0
  238. package/esm/components/ScrollArea/ScrollAreaRoot/ScrollAreaRoot.js +86 -0
  239. package/esm/components/ScrollArea/ScrollAreaRoot/ScrollAreaRoot.js.map +1 -0
  240. package/esm/components/ScrollArea/ScrollAreaScrollbar/ScrollAreaScrollbar.js +65 -0
  241. package/esm/components/ScrollArea/ScrollAreaScrollbar/ScrollAreaScrollbar.js.map +1 -0
  242. package/esm/components/ScrollArea/ScrollAreaScrollbar/ScrollAreaScrollbarAuto.js +63 -0
  243. package/esm/components/ScrollArea/ScrollAreaScrollbar/ScrollAreaScrollbarAuto.js.map +1 -0
  244. package/esm/components/ScrollArea/ScrollAreaScrollbar/ScrollAreaScrollbarHover.js +72 -0
  245. package/esm/components/ScrollArea/ScrollAreaScrollbar/ScrollAreaScrollbarHover.js.map +1 -0
  246. package/esm/components/ScrollArea/ScrollAreaScrollbar/ScrollAreaScrollbarScroll.js +83 -0
  247. package/esm/components/ScrollArea/ScrollAreaScrollbar/ScrollAreaScrollbarScroll.js.map +1 -0
  248. package/esm/components/ScrollArea/ScrollAreaScrollbar/ScrollAreaScrollbarVisible.js +113 -0
  249. package/esm/components/ScrollArea/ScrollAreaScrollbar/ScrollAreaScrollbarVisible.js.map +1 -0
  250. package/esm/components/ScrollArea/ScrollAreaScrollbar/Scrollbar.context.js +6 -0
  251. package/esm/components/ScrollArea/ScrollAreaScrollbar/Scrollbar.context.js.map +1 -0
  252. package/esm/components/ScrollArea/ScrollAreaScrollbar/Scrollbar.js +127 -0
  253. package/esm/components/ScrollArea/ScrollAreaScrollbar/Scrollbar.js.map +1 -0
  254. package/esm/components/ScrollArea/ScrollAreaScrollbar/ScrollbarX.js +86 -0
  255. package/esm/components/ScrollArea/ScrollAreaScrollbar/ScrollbarX.js.map +1 -0
  256. package/esm/components/ScrollArea/ScrollAreaScrollbar/ScrollbarY.js +85 -0
  257. package/esm/components/ScrollArea/ScrollAreaScrollbar/ScrollbarY.js.map +1 -0
  258. package/esm/components/ScrollArea/ScrollAreaThumb/ScrollAreaThumb.js +99 -0
  259. package/esm/components/ScrollArea/ScrollAreaThumb/ScrollAreaThumb.js.map +1 -0
  260. package/esm/components/ScrollArea/ScrollAreaViewport/ScrollAreaViewport.js +55 -0
  261. package/esm/components/ScrollArea/ScrollAreaViewport/ScrollAreaViewport.js.map +1 -0
  262. package/esm/components/ScrollArea/use-resize-observer.js +23 -0
  263. package/esm/components/ScrollArea/use-resize-observer.js.map +1 -0
  264. package/esm/components/ScrollArea/utils/add-unlinked-scroll-listener.js +18 -0
  265. package/esm/components/ScrollArea/utils/add-unlinked-scroll-listener.js.map +1 -0
  266. package/esm/components/ScrollArea/utils/compose-event-handlers.js +11 -0
  267. package/esm/components/ScrollArea/utils/compose-event-handlers.js.map +1 -0
  268. package/esm/components/ScrollArea/utils/get-scroll-position-from-pointer.js +18 -0
  269. package/esm/components/ScrollArea/utils/get-scroll-position-from-pointer.js.map +1 -0
  270. package/esm/components/ScrollArea/utils/get-thumb-offset-from-scroll.js +20 -0
  271. package/esm/components/ScrollArea/utils/get-thumb-offset-from-scroll.js.map +1 -0
  272. package/esm/components/ScrollArea/utils/get-thumb-ratio.js +7 -0
  273. package/esm/components/ScrollArea/utils/get-thumb-ratio.js.map +1 -0
  274. package/esm/components/ScrollArea/utils/get-thumb-size.js +11 -0
  275. package/esm/components/ScrollArea/utils/get-thumb-size.js.map +1 -0
  276. package/esm/components/ScrollArea/utils/is-scrolling-within-scrollbar-bounds.js +6 -0
  277. package/esm/components/ScrollArea/utils/is-scrolling-within-scrollbar-bounds.js.map +1 -0
  278. package/esm/components/ScrollArea/utils/linear-scale.js +11 -0
  279. package/esm/components/ScrollArea/utils/linear-scale.js.map +1 -0
  280. package/esm/components/ScrollArea/utils/to-int.js +6 -0
  281. package/esm/components/ScrollArea/utils/to-int.js.map +1 -0
  282. package/esm/components/SegmentedControl/SegmentedControl.js.map +1 -1
  283. package/esm/components/Slider/RangeSlider/RangeSlider.js +4 -11
  284. package/esm/components/Slider/RangeSlider/RangeSlider.js.map +1 -1
  285. package/esm/components/Slider/Slider/Slider.js +4 -11
  286. package/esm/components/Slider/Slider/Slider.js.map +1 -1
  287. package/esm/components/Slider/Thumb/Thumb.js +5 -8
  288. package/esm/components/Slider/Thumb/Thumb.js.map +1 -1
  289. package/esm/components/Stack/Stack.js.map +1 -1
  290. package/esm/components/Switch/Switch.js.map +1 -1
  291. package/esm/components/Switch/SwitchGroup/SwitchGroup.js.map +1 -1
  292. package/esm/components/Table/Table.js.map +1 -1
  293. package/esm/components/Tabs/Tabs.js.map +1 -1
  294. package/esm/components/Tabs/Tabs.module.css.js +1 -1
  295. package/esm/components/Tabs/TabsList/TabsList.js.map +1 -1
  296. package/esm/components/Tabs/TabsTab/TabsTab.js +5 -1
  297. package/esm/components/Tabs/TabsTab/TabsTab.js.map +1 -1
  298. package/esm/components/Text/Text.js +1 -1
  299. package/esm/components/Text/Text.js.map +1 -1
  300. package/esm/components/Tooltip/Tooltip.js +1 -1
  301. package/esm/components/Tooltip/Tooltip.js.map +1 -1
  302. package/esm/components/Tooltip/use-tooltip.js.map +1 -1
  303. package/esm/components/TypographyStylesProvider/TypographyStylesProvider.js +57 -0
  304. package/esm/components/TypographyStylesProvider/TypographyStylesProvider.js.map +1 -0
  305. package/esm/components/TypographyStylesProvider/TypographyStylesProvider.module.css.js +4 -0
  306. package/esm/components/TypographyStylesProvider/TypographyStylesProvider.module.css.js.map +1 -0
  307. package/esm/core/Box/style-props/resolvers/font-size-resolver/font-size-resolver.js +3 -0
  308. package/esm/core/Box/style-props/resolvers/font-size-resolver/font-size-resolver.js.map +1 -1
  309. package/esm/core/Box/style-props/resolvers/spacing-resolver/spacing-resolver.js +1 -1
  310. package/esm/core/Box/style-props/resolvers/spacing-resolver/spacing-resolver.js.map +1 -1
  311. package/esm/core/MantineProvider/MantineCssVariables/MantineCssVariables.js +15 -8
  312. package/esm/core/MantineProvider/MantineCssVariables/MantineCssVariables.js.map +1 -1
  313. package/esm/core/MantineProvider/MantineCssVariables/default-css-variables-resolver.js +1 -0
  314. package/esm/core/MantineProvider/MantineCssVariables/default-css-variables-resolver.js.map +1 -1
  315. package/esm/core/MantineProvider/MantineCssVariables/remove-default-variables.js +31 -0
  316. package/esm/core/MantineProvider/MantineCssVariables/remove-default-variables.js.map +1 -0
  317. package/esm/core/MantineProvider/MantineProvider.js.map +1 -1
  318. package/esm/core/MantineProvider/convert-css-variables/convert-css-variables.js +6 -5
  319. package/esm/core/MantineProvider/convert-css-variables/convert-css-variables.js.map +1 -1
  320. package/esm/core/MantineProvider/default-theme.js +28 -26
  321. package/esm/core/MantineProvider/default-theme.js.map +1 -1
  322. package/esm/core/MantineProvider/use-mantine-color-scheme/use-mantine-color-scheme.js +40 -3
  323. package/esm/core/MantineProvider/use-mantine-color-scheme/use-mantine-color-scheme.js.map +1 -1
  324. package/esm/core/utils/units-converters/px.js +21 -10
  325. package/esm/core/utils/units-converters/px.js.map +1 -1
  326. package/esm/core/utils/units-converters/rem.js +23 -9
  327. package/esm/core/utils/units-converters/rem.js.map +1 -1
  328. package/esm/index.css +1687 -285
  329. package/esm/index.js +8 -0
  330. package/esm/index.js.map +1 -1
  331. package/lib/components/ActionIcon/ActionIcon.d.ts +9 -8
  332. package/lib/components/ActionIcon/ActionIconGroup/ActionIconGroup.d.ts +3 -3
  333. package/lib/components/Affix/Affix.d.ts +37 -0
  334. package/lib/components/Affix/index.d.ts +2 -0
  335. package/lib/components/Alert/Alert.d.ts +37 -0
  336. package/lib/components/Alert/index.d.ts +2 -0
  337. package/lib/components/Anchor/Anchor.d.ts +1 -1
  338. package/lib/components/AspectRatio/AspectRatio.d.ts +24 -0
  339. package/lib/components/AspectRatio/index.d.ts +2 -0
  340. package/lib/components/Avatar/Avatar.d.ts +56 -0
  341. package/lib/components/Avatar/AvatarGroup/AvatarGroup.context.d.ts +5 -0
  342. package/lib/components/Avatar/AvatarGroup/AvatarGroup.d.ts +24 -0
  343. package/lib/components/Avatar/AvatarPlaceholderIcon.d.ts +2 -0
  344. package/lib/components/Avatar/index.d.ts +3 -0
  345. package/lib/components/BackgroundImage/BackgroundImage.d.ts +1 -1
  346. package/lib/components/Badge/Badge.d.ts +47 -0
  347. package/lib/components/Badge/index.d.ts +2 -0
  348. package/lib/components/Blockquote/Blockquote.d.ts +2 -2
  349. package/lib/components/Breadcrumbs/Breadcrumbs.d.ts +2 -2
  350. package/lib/components/Burger/Burger.d.ts +1 -1
  351. package/lib/components/Button/Button.d.ts +5 -5
  352. package/lib/components/Button/ButtonGroup/ButtonGroup.d.ts +1 -1
  353. package/lib/components/Center/Center.d.ts +2 -2
  354. package/lib/components/CloseButton/CloseButton.d.ts +1 -1
  355. package/lib/components/Code/Code.d.ts +2 -2
  356. package/lib/components/ColorPicker/ColorPicker.d.ts +7 -7
  357. package/lib/components/ColorSwatch/ColorSwatch.d.ts +5 -4
  358. package/lib/components/Container/Container.d.ts +1 -1
  359. package/lib/components/CopyButton/CopyButton.d.ts +1 -1
  360. package/lib/components/Divider/Divider.d.ts +33 -0
  361. package/lib/components/Divider/index.d.ts +2 -0
  362. package/lib/components/FileButton/FileButton.d.ts +3 -3
  363. package/lib/components/Group/Group.d.ts +1 -1
  364. package/lib/components/Input/Input.d.ts +10 -10
  365. package/lib/components/Input/InputWrapper/InputWrapper.d.ts +3 -3
  366. package/lib/components/Input/use-input-props.d.ts +10 -10
  367. package/lib/components/Loader/Loader.d.ts +1 -1
  368. package/lib/components/Overlay/Overlay.d.ts +49 -0
  369. package/lib/components/Overlay/index.d.ts +2 -0
  370. package/lib/components/Paper/Paper.d.ts +2 -2
  371. package/lib/components/Popover/Popover.d.ts +16 -16
  372. package/lib/components/Popover/use-popover.d.ts +1 -32
  373. package/lib/components/ScrollArea/ScrollArea.context.d.ts +23 -0
  374. package/lib/components/ScrollArea/ScrollArea.d.ts +2 -2
  375. package/lib/components/ScrollArea/ScrollArea.types.d.ts +23 -0
  376. package/lib/components/ScrollArea/ScrollAreaCorner/ScrollAreaCorner.d.ts +6 -0
  377. package/lib/components/ScrollArea/ScrollAreaRoot/ScrollAreaRoot.d.ts +30 -0
  378. package/lib/components/ScrollArea/ScrollAreaScrollbar/ScrollAreaScrollbar.d.ts +7 -0
  379. package/lib/components/ScrollArea/ScrollAreaScrollbar/ScrollAreaScrollbarAuto.d.ts +6 -0
  380. package/lib/components/ScrollArea/ScrollAreaScrollbar/ScrollAreaScrollbarHover.d.ts +7 -0
  381. package/lib/components/ScrollArea/ScrollAreaScrollbar/ScrollAreaScrollbarScroll.d.ts +7 -0
  382. package/lib/components/ScrollArea/ScrollAreaScrollbar/ScrollAreaScrollbarVisible.d.ts +6 -0
  383. package/lib/components/ScrollArea/ScrollAreaScrollbar/Scrollbar.context.d.ts +15 -0
  384. package/lib/components/ScrollArea/ScrollAreaScrollbar/Scrollbar.d.ts +21 -0
  385. package/lib/components/ScrollArea/ScrollAreaScrollbar/ScrollbarX.d.ts +3 -0
  386. package/lib/components/ScrollArea/ScrollAreaScrollbar/ScrollbarY.d.ts +3 -0
  387. package/lib/components/ScrollArea/ScrollAreaThumb/ScrollAreaThumb.d.ts +9 -0
  388. package/lib/components/ScrollArea/ScrollAreaViewport/ScrollAreaViewport.d.ts +5 -0
  389. package/lib/components/ScrollArea/use-resize-observer.d.ts +1 -0
  390. package/lib/components/ScrollArea/utils/add-unlinked-scroll-listener.d.ts +1 -0
  391. package/lib/components/ScrollArea/utils/compose-event-handlers.d.ts +3 -0
  392. package/lib/components/ScrollArea/utils/get-scroll-position-from-pointer.d.ts +2 -0
  393. package/lib/components/ScrollArea/utils/get-thumb-offset-from-scroll.d.ts +2 -0
  394. package/lib/components/ScrollArea/utils/get-thumb-ratio.d.ts +1 -0
  395. package/lib/components/ScrollArea/utils/get-thumb-size.d.ts +2 -0
  396. package/lib/components/ScrollArea/utils/index.d.ts +8 -0
  397. package/lib/components/ScrollArea/utils/is-scrolling-within-scrollbar-bounds.d.ts +1 -0
  398. package/lib/components/ScrollArea/utils/linear-scale.d.ts +1 -0
  399. package/lib/components/ScrollArea/utils/to-int.d.ts +1 -0
  400. package/lib/components/SegmentedControl/SegmentedControl.d.ts +5 -5
  401. package/lib/components/Slider/RangeSlider/RangeSlider.d.ts +10 -14
  402. package/lib/components/Slider/Slider/Slider.d.ts +10 -14
  403. package/lib/components/Slider/Thumb/Thumb.d.ts +2 -4
  404. package/lib/components/Stack/Stack.d.ts +1 -1
  405. package/lib/components/Switch/Switch.d.ts +3 -3
  406. package/lib/components/Switch/SwitchGroup/SwitchGroup.d.ts +3 -3
  407. package/lib/components/Table/Table.d.ts +6 -6
  408. package/lib/components/Tabs/Tabs.d.ts +10 -10
  409. package/lib/components/Tabs/TabsList/TabsList.d.ts +2 -2
  410. package/lib/components/Tabs/TabsTab/TabsTab.d.ts +3 -3
  411. package/lib/components/Text/Text.d.ts +2 -2
  412. package/lib/components/Tooltip/Tooltip.d.ts +7 -7
  413. package/lib/components/Tooltip/Tooltip.types.d.ts +2 -2
  414. package/lib/components/Tooltip/use-tooltip.d.ts +2 -2
  415. package/lib/components/TypographyStylesProvider/TypographyStylesProvider.d.ts +17 -0
  416. package/lib/components/TypographyStylesProvider/index.d.ts +2 -0
  417. package/lib/components/index.d.ts +8 -0
  418. package/lib/core/MantineProvider/MantineCssVariables/MantineCssVariables.d.ts +1 -1
  419. package/lib/core/MantineProvider/MantineCssVariables/remove-default-variables.d.ts +2 -0
  420. package/lib/core/MantineProvider/MantineProvider.d.ts +1 -0
  421. package/lib/core/MantineProvider/theme.types.d.ts +2 -0
  422. package/lib/core/MantineProvider/use-mantine-color-scheme/use-mantine-color-scheme.d.ts +3 -2
  423. package/lib/core/utils/units-converters/px.d.ts +1 -1
  424. package/lib/core/utils/units-converters/rem.d.ts +2 -2
  425. package/package.json +3 -5
  426. package/styles.css +1687 -285
@@ -0,0 +1,113 @@
1
+ import React, { forwardRef, useRef, useState } from 'react';
2
+ import { useScrollAreaContext } from '../ScrollArea.context.js';
3
+ import { ScrollAreaScrollbarX } from './ScrollbarX.js';
4
+ import { ScrollAreaScrollbarY } from './ScrollbarY.js';
5
+ import { getThumbRatio } from '../utils/get-thumb-ratio.js';
6
+ import { getThumbOffsetFromScroll } from '../utils/get-thumb-offset-from-scroll.js';
7
+ import { getScrollPositionFromPointer } from '../utils/get-scroll-position-from-pointer.js';
8
+ import { useDirection } from '../../../core/DirectionProvider/DirectionProvider.js';
9
+
10
+ var __defProp = Object.defineProperty;
11
+ var __defProps = Object.defineProperties;
12
+ var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
13
+ var __getOwnPropSymbols = Object.getOwnPropertySymbols;
14
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
15
+ var __propIsEnum = Object.prototype.propertyIsEnumerable;
16
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
17
+ var __spreadValues = (a, b) => {
18
+ for (var prop in b || (b = {}))
19
+ if (__hasOwnProp.call(b, prop))
20
+ __defNormalProp(a, prop, b[prop]);
21
+ if (__getOwnPropSymbols)
22
+ for (var prop of __getOwnPropSymbols(b)) {
23
+ if (__propIsEnum.call(b, prop))
24
+ __defNormalProp(a, prop, b[prop]);
25
+ }
26
+ return a;
27
+ };
28
+ var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
29
+ var __objRest = (source, exclude) => {
30
+ var target = {};
31
+ for (var prop in source)
32
+ if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)
33
+ target[prop] = source[prop];
34
+ if (source != null && __getOwnPropSymbols)
35
+ for (var prop of __getOwnPropSymbols(source)) {
36
+ if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))
37
+ target[prop] = source[prop];
38
+ }
39
+ return target;
40
+ };
41
+ const ScrollAreaScrollbarVisible = forwardRef((props, forwardedRef) => {
42
+ const _a = props, { orientation = "vertical" } = _a, scrollbarProps = __objRest(_a, ["orientation"]);
43
+ const { dir } = useDirection();
44
+ const context = useScrollAreaContext();
45
+ const thumbRef = useRef(null);
46
+ const pointerOffsetRef = useRef(0);
47
+ const [sizes, setSizes] = useState({
48
+ content: 0,
49
+ viewport: 0,
50
+ scrollbar: { size: 0, paddingStart: 0, paddingEnd: 0 }
51
+ });
52
+ const thumbRatio = getThumbRatio(sizes.viewport, sizes.content);
53
+ const commonProps = __spreadProps(__spreadValues({}, scrollbarProps), {
54
+ sizes,
55
+ onSizesChange: setSizes,
56
+ hasThumb: Boolean(thumbRatio > 0 && thumbRatio < 1),
57
+ onThumbChange: (thumb) => {
58
+ thumbRef.current = thumb;
59
+ },
60
+ onThumbPointerUp: () => {
61
+ pointerOffsetRef.current = 0;
62
+ },
63
+ onThumbPointerDown: (pointerPos) => {
64
+ pointerOffsetRef.current = pointerPos;
65
+ }
66
+ });
67
+ const getScrollPosition = (pointerPos, direction) => getScrollPositionFromPointer(pointerPos, pointerOffsetRef.current, sizes, direction);
68
+ if (orientation === "horizontal") {
69
+ return /* @__PURE__ */ React.createElement(ScrollAreaScrollbarX, __spreadProps(__spreadValues({}, commonProps), {
70
+ ref: forwardedRef,
71
+ onThumbPositionChange: () => {
72
+ if (context.viewport && thumbRef.current) {
73
+ const scrollPos = context.viewport.scrollLeft;
74
+ const offset = getThumbOffsetFromScroll(scrollPos, sizes, dir);
75
+ thumbRef.current.style.transform = `translate3d(${offset}px, 0, 0)`;
76
+ }
77
+ },
78
+ onWheelScroll: (scrollPos) => {
79
+ if (context.viewport)
80
+ context.viewport.scrollLeft = scrollPos;
81
+ },
82
+ onDragScroll: (pointerPos) => {
83
+ if (context.viewport) {
84
+ context.viewport.scrollLeft = getScrollPosition(pointerPos, dir);
85
+ }
86
+ }
87
+ }));
88
+ }
89
+ if (orientation === "vertical") {
90
+ return /* @__PURE__ */ React.createElement(ScrollAreaScrollbarY, __spreadProps(__spreadValues({}, commonProps), {
91
+ ref: forwardedRef,
92
+ onThumbPositionChange: () => {
93
+ if (context.viewport && thumbRef.current) {
94
+ const scrollPos = context.viewport.scrollTop;
95
+ const offset = getThumbOffsetFromScroll(scrollPos, sizes);
96
+ thumbRef.current.style.transform = `translate3d(0, ${offset}px, 0)`;
97
+ }
98
+ },
99
+ onWheelScroll: (scrollPos) => {
100
+ if (context.viewport)
101
+ context.viewport.scrollTop = scrollPos;
102
+ },
103
+ onDragScroll: (pointerPos) => {
104
+ if (context.viewport)
105
+ context.viewport.scrollTop = getScrollPosition(pointerPos);
106
+ }
107
+ }));
108
+ }
109
+ return null;
110
+ });
111
+
112
+ export { ScrollAreaScrollbarVisible };
113
+ //# sourceMappingURL=ScrollAreaScrollbarVisible.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ScrollAreaScrollbarVisible.js","sources":["../../../../src/components/ScrollArea/ScrollAreaScrollbar/ScrollAreaScrollbarVisible.tsx"],"sourcesContent":["import React, { useRef, useState, forwardRef } from 'react';\nimport { useDirection } from '../../../core';\nimport {\n ScrollAreaScrollbarAxisPrivateProps,\n ScrollAreaScrollbarAxisProps,\n Sizes,\n} from '../ScrollArea.types';\nimport { useScrollAreaContext } from '../ScrollArea.context';\nimport { ScrollAreaScrollbarX } from './ScrollbarX';\nimport { ScrollAreaScrollbarY } from './ScrollbarY';\nimport { getThumbRatio, getThumbOffsetFromScroll, getScrollPositionFromPointer } from '../utils';\n\nexport interface ScrollAreaScrollbarVisibleProps\n extends Omit<ScrollAreaScrollbarAxisProps, keyof ScrollAreaScrollbarAxisPrivateProps> {\n orientation?: 'horizontal' | 'vertical';\n}\n\nexport const ScrollAreaScrollbarVisible = forwardRef<\n HTMLDivElement,\n ScrollAreaScrollbarVisibleProps\n>((props, forwardedRef) => {\n const { orientation = 'vertical', ...scrollbarProps } = props;\n const { dir } = useDirection();\n const context = useScrollAreaContext();\n const thumbRef = useRef<HTMLDivElement | null>(null);\n const pointerOffsetRef = useRef(0);\n const [sizes, setSizes] = useState<Sizes>({\n content: 0,\n viewport: 0,\n scrollbar: { size: 0, paddingStart: 0, paddingEnd: 0 },\n });\n const thumbRatio = getThumbRatio(sizes.viewport, sizes.content);\n\n const commonProps: Omit<\n ScrollAreaScrollbarAxisPrivateProps,\n 'onThumbPositionChange' | 'onDragScroll' | 'onWheelScroll'\n > = {\n ...scrollbarProps,\n sizes,\n onSizesChange: setSizes,\n hasThumb: Boolean(thumbRatio > 0 && thumbRatio < 1),\n onThumbChange: (thumb) => {\n thumbRef.current = thumb;\n },\n onThumbPointerUp: () => {\n pointerOffsetRef.current = 0;\n },\n onThumbPointerDown: (pointerPos) => {\n pointerOffsetRef.current = pointerPos;\n },\n };\n\n const getScrollPosition = (pointerPos: number, direction?: 'ltr' | 'rtl') =>\n getScrollPositionFromPointer(pointerPos, pointerOffsetRef.current, sizes, direction);\n\n if (orientation === 'horizontal') {\n return (\n <ScrollAreaScrollbarX\n {...commonProps}\n ref={forwardedRef}\n onThumbPositionChange={() => {\n if (context.viewport && thumbRef.current) {\n const scrollPos = context.viewport.scrollLeft;\n const offset = getThumbOffsetFromScroll(scrollPos, sizes, dir);\n thumbRef.current.style.transform = `translate3d(${offset}px, 0, 0)`;\n }\n }}\n onWheelScroll={(scrollPos) => {\n if (context.viewport) context.viewport.scrollLeft = scrollPos;\n }}\n onDragScroll={(pointerPos) => {\n if (context.viewport) {\n context.viewport.scrollLeft = getScrollPosition(pointerPos, dir);\n }\n }}\n />\n );\n }\n\n if (orientation === 'vertical') {\n return (\n <ScrollAreaScrollbarY\n {...commonProps}\n ref={forwardedRef}\n onThumbPositionChange={() => {\n if (context.viewport && thumbRef.current) {\n const scrollPos = context.viewport.scrollTop;\n const offset = getThumbOffsetFromScroll(scrollPos, sizes);\n thumbRef.current.style.transform = `translate3d(0, ${offset}px, 0)`;\n }\n }}\n onWheelScroll={(scrollPos) => {\n if (context.viewport) context.viewport.scrollTop = scrollPos;\n }}\n onDragScroll={(pointerPos) => {\n if (context.viewport) context.viewport.scrollTop = getScrollPosition(pointerPos);\n }}\n />\n );\n }\n\n return null;\n});\n"],"names":[],"mappings":";;;;;;;;;AAAA,IAAI,SAAS,GAAG,MAAM,CAAC,cAAc,CAAC;AACtC,IAAI,UAAU,GAAG,MAAM,CAAC,gBAAgB,CAAC;AACzC,IAAI,iBAAiB,GAAG,MAAM,CAAC,yBAAyB,CAAC;AACzD,IAAI,mBAAmB,GAAG,MAAM,CAAC,qBAAqB,CAAC;AACvD,IAAI,YAAY,GAAG,MAAM,CAAC,SAAS,CAAC,cAAc,CAAC;AACnD,IAAI,YAAY,GAAG,MAAM,CAAC,SAAS,CAAC,oBAAoB,CAAC;AACzD,IAAI,eAAe,GAAG,CAAC,GAAG,EAAE,GAAG,EAAE,KAAK,KAAK,GAAG,IAAI,GAAG,GAAG,SAAS,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE,UAAU,EAAE,IAAI,EAAE,YAAY,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,GAAG,GAAG,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;AAChK,IAAI,cAAc,GAAG,CAAC,CAAC,EAAE,CAAC,KAAK;AAC/B,EAAE,KAAK,IAAI,IAAI,IAAI,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC;AAChC,IAAI,IAAI,YAAY,CAAC,IAAI,CAAC,CAAC,EAAE,IAAI,CAAC;AAClC,MAAM,eAAe,CAAC,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;AACxC,EAAE,IAAI,mBAAmB;AACzB,IAAI,KAAK,IAAI,IAAI,IAAI,mBAAmB,CAAC,CAAC,CAAC,EAAE;AAC7C,MAAM,IAAI,YAAY,CAAC,IAAI,CAAC,CAAC,EAAE,IAAI,CAAC;AACpC,QAAQ,eAAe,CAAC,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;AAC1C,KAAK;AACL,EAAE,OAAO,CAAC,CAAC;AACX,CAAC,CAAC;AACF,IAAI,aAAa,GAAG,CAAC,CAAC,EAAE,CAAC,KAAK,UAAU,CAAC,CAAC,EAAE,iBAAiB,CAAC,CAAC,CAAC,CAAC,CAAC;AAClE,IAAI,SAAS,GAAG,CAAC,MAAM,EAAE,OAAO,KAAK;AACrC,EAAE,IAAI,MAAM,GAAG,EAAE,CAAC;AAClB,EAAE,KAAK,IAAI,IAAI,IAAI,MAAM;AACzB,IAAI,IAAI,YAAY,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,IAAI,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC;AACpE,MAAM,MAAM,CAAC,IAAI,CAAC,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC;AAClC,EAAE,IAAI,MAAM,IAAI,IAAI,IAAI,mBAAmB;AAC3C,IAAI,KAAK,IAAI,IAAI,IAAI,mBAAmB,CAAC,MAAM,CAAC,EAAE;AAClD,MAAM,IAAI,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,YAAY,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC;AACtE,QAAQ,MAAM,CAAC,IAAI,CAAC,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC;AACpC,KAAK;AACL,EAAE,OAAO,MAAM,CAAC;AAChB,CAAC,CAAC;AAOU,MAAC,0BAA0B,GAAG,UAAU,CAAC,CAAC,KAAK,EAAE,YAAY,KAAK;AAC9E,EAAE,MAAM,EAAE,GAAG,KAAK,EAAE,EAAE,WAAW,GAAG,UAAU,EAAE,GAAG,EAAE,EAAE,cAAc,GAAG,SAAS,CAAC,EAAE,EAAE,CAAC,aAAa,CAAC,CAAC,CAAC;AACvG,EAAE,MAAM,EAAE,GAAG,EAAE,GAAG,YAAY,EAAE,CAAC;AACjC,EAAE,MAAM,OAAO,GAAG,oBAAoB,EAAE,CAAC;AACzC,EAAE,MAAM,QAAQ,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC;AAChC,EAAE,MAAM,gBAAgB,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;AACrC,EAAE,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,QAAQ,CAAC;AACrC,IAAI,OAAO,EAAE,CAAC;AACd,IAAI,QAAQ,EAAE,CAAC;AACf,IAAI,SAAS,EAAE,EAAE,IAAI,EAAE,CAAC,EAAE,YAAY,EAAE,CAAC,EAAE,UAAU,EAAE,CAAC,EAAE;AAC1D,GAAG,CAAC,CAAC;AACL,EAAE,MAAM,UAAU,GAAG,aAAa,CAAC,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC;AAClE,EAAE,MAAM,WAAW,GAAG,aAAa,CAAC,cAAc,CAAC,EAAE,EAAE,cAAc,CAAC,EAAE;AACxE,IAAI,KAAK;AACT,IAAI,aAAa,EAAE,QAAQ;AAC3B,IAAI,QAAQ,EAAE,OAAO,CAAC,UAAU,GAAG,CAAC,IAAI,UAAU,GAAG,CAAC,CAAC;AACvD,IAAI,aAAa,EAAE,CAAC,KAAK,KAAK;AAC9B,MAAM,QAAQ,CAAC,OAAO,GAAG,KAAK,CAAC;AAC/B,KAAK;AACL,IAAI,gBAAgB,EAAE,MAAM;AAC5B,MAAM,gBAAgB,CAAC,OAAO,GAAG,CAAC,CAAC;AACnC,KAAK;AACL,IAAI,kBAAkB,EAAE,CAAC,UAAU,KAAK;AACxC,MAAM,gBAAgB,CAAC,OAAO,GAAG,UAAU,CAAC;AAC5C,KAAK;AACL,GAAG,CAAC,CAAC;AACL,EAAE,MAAM,iBAAiB,GAAG,CAAC,UAAU,EAAE,SAAS,KAAK,4BAA4B,CAAC,UAAU,EAAE,gBAAgB,CAAC,OAAO,EAAE,KAAK,EAAE,SAAS,CAAC,CAAC;AAC5I,EAAE,IAAI,WAAW,KAAK,YAAY,EAAE;AACpC,IAAI,uBAAuB,KAAK,CAAC,aAAa,CAAC,oBAAoB,EAAE,aAAa,CAAC,cAAc,CAAC,EAAE,EAAE,WAAW,CAAC,EAAE;AACpH,MAAM,GAAG,EAAE,YAAY;AACvB,MAAM,qBAAqB,EAAE,MAAM;AACnC,QAAQ,IAAI,OAAO,CAAC,QAAQ,IAAI,QAAQ,CAAC,OAAO,EAAE;AAClD,UAAU,MAAM,SAAS,GAAG,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAC;AACxD,UAAU,MAAM,MAAM,GAAG,wBAAwB,CAAC,SAAS,EAAE,KAAK,EAAE,GAAG,CAAC,CAAC;AACzE,UAAU,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,SAAS,GAAG,CAAC,YAAY,EAAE,MAAM,CAAC,SAAS,CAAC,CAAC;AAC9E,SAAS;AACT,OAAO;AACP,MAAM,aAAa,EAAE,CAAC,SAAS,KAAK;AACpC,QAAQ,IAAI,OAAO,CAAC,QAAQ;AAC5B,UAAU,OAAO,CAAC,QAAQ,CAAC,UAAU,GAAG,SAAS,CAAC;AAClD,OAAO;AACP,MAAM,YAAY,EAAE,CAAC,UAAU,KAAK;AACpC,QAAQ,IAAI,OAAO,CAAC,QAAQ,EAAE;AAC9B,UAAU,OAAO,CAAC,QAAQ,CAAC,UAAU,GAAG,iBAAiB,CAAC,UAAU,EAAE,GAAG,CAAC,CAAC;AAC3E,SAAS;AACT,OAAO;AACP,KAAK,CAAC,CAAC,CAAC;AACR,GAAG;AACH,EAAE,IAAI,WAAW,KAAK,UAAU,EAAE;AAClC,IAAI,uBAAuB,KAAK,CAAC,aAAa,CAAC,oBAAoB,EAAE,aAAa,CAAC,cAAc,CAAC,EAAE,EAAE,WAAW,CAAC,EAAE;AACpH,MAAM,GAAG,EAAE,YAAY;AACvB,MAAM,qBAAqB,EAAE,MAAM;AACnC,QAAQ,IAAI,OAAO,CAAC,QAAQ,IAAI,QAAQ,CAAC,OAAO,EAAE;AAClD,UAAU,MAAM,SAAS,GAAG,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAC;AACvD,UAAU,MAAM,MAAM,GAAG,wBAAwB,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC;AACpE,UAAU,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,SAAS,GAAG,CAAC,eAAe,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC;AAC9E,SAAS;AACT,OAAO;AACP,MAAM,aAAa,EAAE,CAAC,SAAS,KAAK;AACpC,QAAQ,IAAI,OAAO,CAAC,QAAQ;AAC5B,UAAU,OAAO,CAAC,QAAQ,CAAC,SAAS,GAAG,SAAS,CAAC;AACjD,OAAO;AACP,MAAM,YAAY,EAAE,CAAC,UAAU,KAAK;AACpC,QAAQ,IAAI,OAAO,CAAC,QAAQ;AAC5B,UAAU,OAAO,CAAC,QAAQ,CAAC,SAAS,GAAG,iBAAiB,CAAC,UAAU,CAAC,CAAC;AACrE,OAAO;AACP,KAAK,CAAC,CAAC,CAAC;AACR,GAAG;AACH,EAAE,OAAO,IAAI,CAAC;AACd,CAAC;;;;"}
@@ -0,0 +1,6 @@
1
+ import { createSafeContext } from '../../../core/utils/create-safe-context/create-safe-context.js';
2
+
3
+ const [ScrollbarProvider, useScrollbarContext] = createSafeContext("ScrollAreaScrollbar was not found in tree");
4
+
5
+ export { ScrollbarProvider, useScrollbarContext };
6
+ //# sourceMappingURL=Scrollbar.context.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Scrollbar.context.js","sources":["../../../../src/components/ScrollArea/ScrollAreaScrollbar/Scrollbar.context.ts"],"sourcesContent":["import { createSafeContext } from '../../../core';\n\nexport interface ScrollbarContextValue {\n hasThumb: boolean;\n scrollbar: HTMLDivElement | null;\n onThumbChange(thumb: HTMLDivElement | null): void;\n onThumbPointerUp(): void;\n onThumbPointerDown(pointerPos: { x: number; y: number }): void;\n onThumbPositionChange(): void;\n}\n\nexport const [ScrollbarProvider, useScrollbarContext] = createSafeContext<ScrollbarContextValue>(\n 'ScrollAreaScrollbar was not found in tree'\n);\n"],"names":[],"mappings":";;AACY,MAAC,CAAC,iBAAiB,EAAE,mBAAmB,CAAC,GAAG,iBAAiB,CAAC,2CAA2C;;;;"}
@@ -0,0 +1,127 @@
1
+ import React, { forwardRef, useEffect } from 'react';
2
+ import { useMergedRef, useCallbackRef, useDebounceCallback } from '@mantine/hooks';
3
+ import { useResizeObserver } from '../use-resize-observer.js';
4
+ import { useScrollAreaContext } from '../ScrollArea.context.js';
5
+ import { ScrollbarProvider } from './Scrollbar.context.js';
6
+ import { composeEventHandlers } from '../utils/compose-event-handlers.js';
7
+
8
+ var __defProp = Object.defineProperty;
9
+ var __defProps = Object.defineProperties;
10
+ var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
11
+ var __getOwnPropSymbols = Object.getOwnPropertySymbols;
12
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
13
+ var __propIsEnum = Object.prototype.propertyIsEnumerable;
14
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
15
+ var __spreadValues = (a, b) => {
16
+ for (var prop in b || (b = {}))
17
+ if (__hasOwnProp.call(b, prop))
18
+ __defNormalProp(a, prop, b[prop]);
19
+ if (__getOwnPropSymbols)
20
+ for (var prop of __getOwnPropSymbols(b)) {
21
+ if (__propIsEnum.call(b, prop))
22
+ __defNormalProp(a, prop, b[prop]);
23
+ }
24
+ return a;
25
+ };
26
+ var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
27
+ var __objRest = (source, exclude) => {
28
+ var target = {};
29
+ for (var prop in source)
30
+ if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)
31
+ target[prop] = source[prop];
32
+ if (source != null && __getOwnPropSymbols)
33
+ for (var prop of __getOwnPropSymbols(source)) {
34
+ if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))
35
+ target[prop] = source[prop];
36
+ }
37
+ return target;
38
+ };
39
+ const Scrollbar = forwardRef((props, forwardedRef) => {
40
+ const _a = props, {
41
+ sizes,
42
+ hasThumb,
43
+ onThumbChange,
44
+ onThumbPointerUp,
45
+ onThumbPointerDown,
46
+ onThumbPositionChange,
47
+ onDragScroll,
48
+ onWheelScroll,
49
+ onResize
50
+ } = _a, scrollbarProps = __objRest(_a, [
51
+ "sizes",
52
+ "hasThumb",
53
+ "onThumbChange",
54
+ "onThumbPointerUp",
55
+ "onThumbPointerDown",
56
+ "onThumbPositionChange",
57
+ "onDragScroll",
58
+ "onWheelScroll",
59
+ "onResize"
60
+ ]);
61
+ const context = useScrollAreaContext();
62
+ const [scrollbar, setScrollbar] = React.useState(null);
63
+ const composeRefs = useMergedRef(forwardedRef, (node) => setScrollbar(node));
64
+ const rectRef = React.useRef(null);
65
+ const prevWebkitUserSelectRef = React.useRef("");
66
+ const { viewport } = context;
67
+ const maxScrollPos = sizes.content - sizes.viewport;
68
+ const handleWheelScroll = useCallbackRef(onWheelScroll);
69
+ const handleThumbPositionChange = useCallbackRef(onThumbPositionChange);
70
+ const handleResize = useDebounceCallback(onResize, 10);
71
+ const handleDragScroll = (event) => {
72
+ if (rectRef.current) {
73
+ const x = event.clientX - rectRef.current.left;
74
+ const y = event.clientY - rectRef.current.top;
75
+ onDragScroll({ x, y });
76
+ }
77
+ };
78
+ useEffect(() => {
79
+ const handleWheel = (event) => {
80
+ const element = event.target;
81
+ const isScrollbarWheel = scrollbar == null ? void 0 : scrollbar.contains(element);
82
+ if (isScrollbarWheel)
83
+ handleWheelScroll(event, maxScrollPos);
84
+ };
85
+ document.addEventListener("wheel", handleWheel, { passive: false });
86
+ return () => document.removeEventListener("wheel", handleWheel, { passive: false });
87
+ }, [viewport, scrollbar, maxScrollPos, handleWheelScroll]);
88
+ useEffect(handleThumbPositionChange, [sizes, handleThumbPositionChange]);
89
+ useResizeObserver(scrollbar, handleResize);
90
+ useResizeObserver(context.content, handleResize);
91
+ return /* @__PURE__ */ React.createElement(ScrollbarProvider, {
92
+ value: {
93
+ scrollbar,
94
+ hasThumb,
95
+ onThumbChange: useCallbackRef(onThumbChange),
96
+ onThumbPointerUp: useCallbackRef(onThumbPointerUp),
97
+ onThumbPositionChange: handleThumbPositionChange,
98
+ onThumbPointerDown: useCallbackRef(onThumbPointerDown)
99
+ }
100
+ }, /* @__PURE__ */ React.createElement("div", __spreadProps(__spreadValues({}, scrollbarProps), {
101
+ ref: composeRefs,
102
+ style: __spreadValues({ position: "absolute" }, scrollbarProps.style),
103
+ onPointerDown: composeEventHandlers(props.onPointerDown, (event) => {
104
+ const mainPointer = 0;
105
+ if (event.button === mainPointer) {
106
+ const element = event.target;
107
+ element.setPointerCapture(event.pointerId);
108
+ rectRef.current = scrollbar.getBoundingClientRect();
109
+ prevWebkitUserSelectRef.current = document.body.style.webkitUserSelect;
110
+ document.body.style.webkitUserSelect = "none";
111
+ handleDragScroll(event);
112
+ }
113
+ }),
114
+ onPointerMove: composeEventHandlers(props.onPointerMove, handleDragScroll),
115
+ onPointerUp: composeEventHandlers(props.onPointerUp, (event) => {
116
+ const element = event.target;
117
+ if (element.hasPointerCapture(event.pointerId)) {
118
+ element.releasePointerCapture(event.pointerId);
119
+ }
120
+ document.body.style.webkitUserSelect = prevWebkitUserSelectRef.current;
121
+ rectRef.current = null;
122
+ })
123
+ })));
124
+ });
125
+
126
+ export { Scrollbar };
127
+ //# sourceMappingURL=Scrollbar.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Scrollbar.js","sources":["../../../../src/components/ScrollArea/ScrollAreaScrollbar/Scrollbar.tsx"],"sourcesContent":["import React, { useEffect, forwardRef } from 'react';\nimport { useMergedRef, useCallbackRef, useDebounceCallback } from '@mantine/hooks';\nimport { useResizeObserver } from '../use-resize-observer';\nimport { useScrollAreaContext } from '../ScrollArea.context';\nimport { Sizes } from '../ScrollArea.types';\nimport { ScrollbarProvider, ScrollbarContextValue } from './Scrollbar.context';\nimport { composeEventHandlers } from '../utils';\n\nexport interface ScrollbarPrivateProps {\n sizes: Sizes;\n hasThumb: boolean;\n onThumbChange: ScrollbarContextValue['onThumbChange'];\n onThumbPointerUp: ScrollbarContextValue['onThumbPointerUp'];\n onThumbPointerDown: ScrollbarContextValue['onThumbPointerDown'];\n onThumbPositionChange: ScrollbarContextValue['onThumbPositionChange'];\n onWheelScroll(event: WheelEvent, maxScrollPos: number): void;\n onDragScroll(pointerPos: { x: number; y: number }): void;\n onResize(): void;\n}\n\ninterface ScrollbarProps\n extends ScrollbarPrivateProps,\n Omit<React.ComponentPropsWithoutRef<'div'>, 'onResize'> {}\n\nexport const Scrollbar = forwardRef<HTMLDivElement, ScrollbarProps>((props, forwardedRef) => {\n const {\n sizes,\n hasThumb,\n onThumbChange,\n onThumbPointerUp,\n onThumbPointerDown,\n onThumbPositionChange,\n onDragScroll,\n onWheelScroll,\n onResize,\n ...scrollbarProps\n } = props;\n const context = useScrollAreaContext();\n const [scrollbar, setScrollbar] = React.useState<HTMLDivElement | null>(null);\n const composeRefs = useMergedRef(forwardedRef, (node) => setScrollbar(node));\n const rectRef = React.useRef<ClientRect | null>(null);\n const prevWebkitUserSelectRef = React.useRef<string>('');\n const { viewport } = context;\n const maxScrollPos = sizes.content - sizes.viewport;\n const handleWheelScroll = useCallbackRef(onWheelScroll);\n const handleThumbPositionChange = useCallbackRef(onThumbPositionChange);\n const handleResize = useDebounceCallback(onResize, 10);\n\n const handleDragScroll = (event: React.PointerEvent<HTMLElement>) => {\n if (rectRef.current) {\n const x = event.clientX - rectRef.current.left;\n const y = event.clientY - rectRef.current.top;\n onDragScroll({ x, y });\n }\n };\n\n useEffect(() => {\n const handleWheel = (event: WheelEvent) => {\n const element = event.target as HTMLElement;\n const isScrollbarWheel = scrollbar?.contains(element);\n if (isScrollbarWheel) handleWheelScroll(event, maxScrollPos);\n };\n document.addEventListener('wheel', handleWheel, { passive: false });\n return () => document.removeEventListener('wheel', handleWheel, { passive: false } as any);\n }, [viewport, scrollbar, maxScrollPos, handleWheelScroll]);\n\n useEffect(handleThumbPositionChange, [sizes, handleThumbPositionChange]);\n\n useResizeObserver(scrollbar, handleResize);\n useResizeObserver(context.content, handleResize);\n\n return (\n <ScrollbarProvider\n value={{\n scrollbar,\n hasThumb,\n onThumbChange: useCallbackRef(onThumbChange),\n onThumbPointerUp: useCallbackRef(onThumbPointerUp),\n onThumbPositionChange: handleThumbPositionChange,\n onThumbPointerDown: useCallbackRef(onThumbPointerDown),\n }}\n >\n <div\n {...scrollbarProps}\n ref={composeRefs}\n style={{ position: 'absolute', ...scrollbarProps.style }}\n onPointerDown={composeEventHandlers(props.onPointerDown, (event) => {\n const mainPointer = 0;\n if (event.button === mainPointer) {\n const element = event.target as HTMLElement;\n element.setPointerCapture(event.pointerId);\n rectRef.current = scrollbar!.getBoundingClientRect();\n prevWebkitUserSelectRef.current = document.body.style.webkitUserSelect;\n document.body.style.webkitUserSelect = 'none';\n handleDragScroll(event);\n }\n })}\n onPointerMove={composeEventHandlers(props.onPointerMove, handleDragScroll)}\n onPointerUp={composeEventHandlers(props.onPointerUp, (event) => {\n const element = event.target as HTMLElement;\n if (element.hasPointerCapture(event.pointerId)) {\n element.releasePointerCapture(event.pointerId);\n }\n document.body.style.webkitUserSelect = prevWebkitUserSelectRef.current;\n rectRef.current = null;\n })}\n />\n </ScrollbarProvider>\n );\n});\n"],"names":[],"mappings":"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"}
@@ -0,0 +1,86 @@
1
+ import React, { forwardRef, useState, useRef, useEffect } from 'react';
2
+ import { useMergedRef } from '@mantine/hooks';
3
+ import { Scrollbar } from './Scrollbar.js';
4
+ import { useScrollAreaContext } from '../ScrollArea.context.js';
5
+ import { getThumbSize } from '../utils/get-thumb-size.js';
6
+ import { isScrollingWithinScrollbarBounds } from '../utils/is-scrolling-within-scrollbar-bounds.js';
7
+ import { toInt } from '../utils/to-int.js';
8
+
9
+ var __defProp = Object.defineProperty;
10
+ var __defProps = Object.defineProperties;
11
+ var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
12
+ var __getOwnPropSymbols = Object.getOwnPropertySymbols;
13
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
14
+ var __propIsEnum = Object.prototype.propertyIsEnumerable;
15
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
16
+ var __spreadValues = (a, b) => {
17
+ for (var prop in b || (b = {}))
18
+ if (__hasOwnProp.call(b, prop))
19
+ __defNormalProp(a, prop, b[prop]);
20
+ if (__getOwnPropSymbols)
21
+ for (var prop of __getOwnPropSymbols(b)) {
22
+ if (__propIsEnum.call(b, prop))
23
+ __defNormalProp(a, prop, b[prop]);
24
+ }
25
+ return a;
26
+ };
27
+ var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
28
+ var __objRest = (source, exclude) => {
29
+ var target = {};
30
+ for (var prop in source)
31
+ if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)
32
+ target[prop] = source[prop];
33
+ if (source != null && __getOwnPropSymbols)
34
+ for (var prop of __getOwnPropSymbols(source)) {
35
+ if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))
36
+ target[prop] = source[prop];
37
+ }
38
+ return target;
39
+ };
40
+ const ScrollAreaScrollbarX = forwardRef((props, forwardedRef) => {
41
+ const _a = props, { sizes, onSizesChange, style } = _a, others = __objRest(_a, ["sizes", "onSizesChange", "style"]);
42
+ const ctx = useScrollAreaContext();
43
+ const [computedStyle, setComputedStyle] = useState();
44
+ const ref = useRef(null);
45
+ const composeRefs = useMergedRef(forwardedRef, ref, ctx.onScrollbarXChange);
46
+ useEffect(() => {
47
+ if (ref.current)
48
+ setComputedStyle(getComputedStyle(ref.current));
49
+ }, [ref]);
50
+ return /* @__PURE__ */ React.createElement(Scrollbar, __spreadProps(__spreadValues({
51
+ "data-orientation": "horizontal"
52
+ }, others), {
53
+ ref: composeRefs,
54
+ sizes,
55
+ style: __spreadProps(__spreadValues({}, style), {
56
+ ["--sa-thumb-width"]: `${getThumbSize(sizes)}px`
57
+ }),
58
+ onThumbPointerDown: (pointerPos) => props.onThumbPointerDown(pointerPos.x),
59
+ onDragScroll: (pointerPos) => props.onDragScroll(pointerPos.x),
60
+ onWheelScroll: (event, maxScrollPos) => {
61
+ if (ctx.viewport) {
62
+ const scrollPos = ctx.viewport.scrollLeft + event.deltaX;
63
+ props.onWheelScroll(scrollPos);
64
+ if (isScrollingWithinScrollbarBounds(scrollPos, maxScrollPos)) {
65
+ event.preventDefault();
66
+ }
67
+ }
68
+ },
69
+ onResize: () => {
70
+ if (ref.current && ctx.viewport && computedStyle) {
71
+ onSizesChange({
72
+ content: ctx.viewport.scrollWidth,
73
+ viewport: ctx.viewport.offsetWidth,
74
+ scrollbar: {
75
+ size: ref.current.clientWidth,
76
+ paddingStart: toInt(computedStyle.paddingLeft),
77
+ paddingEnd: toInt(computedStyle.paddingRight)
78
+ }
79
+ });
80
+ }
81
+ }
82
+ }));
83
+ });
84
+
85
+ export { ScrollAreaScrollbarX };
86
+ //# sourceMappingURL=ScrollbarX.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ScrollbarX.js","sources":["../../../../src/components/ScrollArea/ScrollAreaScrollbar/ScrollbarX.tsx"],"sourcesContent":["import React, { forwardRef, useRef, useState, useEffect } from 'react';\nimport { useMergedRef } from '@mantine/hooks';\nimport { Scrollbar } from './Scrollbar';\nimport { ScrollAreaScrollbarAxisProps } from '../ScrollArea.types';\nimport { useScrollAreaContext } from '../ScrollArea.context';\nimport { isScrollingWithinScrollbarBounds, getThumbSize, toInt } from '../utils';\n\nexport const ScrollAreaScrollbarX = forwardRef<HTMLDivElement, ScrollAreaScrollbarAxisProps>(\n (props, forwardedRef) => {\n const { sizes, onSizesChange, style, ...others } = props;\n const ctx = useScrollAreaContext();\n const [computedStyle, setComputedStyle] = useState<CSSStyleDeclaration>();\n const ref = useRef<HTMLDivElement>(null);\n const composeRefs = useMergedRef(forwardedRef, ref, ctx.onScrollbarXChange);\n\n useEffect(() => {\n if (ref.current) setComputedStyle(getComputedStyle(ref.current));\n }, [ref]);\n\n return (\n <Scrollbar\n data-orientation=\"horizontal\"\n {...others}\n ref={composeRefs}\n sizes={sizes}\n style={{\n ...style,\n ['--sa-thumb-width' as any]: `${getThumbSize(sizes)}px`,\n }}\n onThumbPointerDown={(pointerPos) => props.onThumbPointerDown(pointerPos.x)}\n onDragScroll={(pointerPos) => props.onDragScroll(pointerPos.x)}\n onWheelScroll={(event, maxScrollPos) => {\n if (ctx.viewport) {\n const scrollPos = ctx.viewport.scrollLeft + event.deltaX;\n props.onWheelScroll(scrollPos);\n if (isScrollingWithinScrollbarBounds(scrollPos, maxScrollPos)) {\n event.preventDefault();\n }\n }\n }}\n onResize={() => {\n if (ref.current && ctx.viewport && computedStyle) {\n onSizesChange({\n content: ctx.viewport.scrollWidth,\n viewport: ctx.viewport.offsetWidth,\n scrollbar: {\n size: ref.current.clientWidth,\n paddingStart: toInt(computedStyle.paddingLeft),\n paddingEnd: toInt(computedStyle.paddingRight),\n },\n });\n }\n }}\n />\n );\n }\n);\n"],"names":[],"mappings":"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"}
@@ -0,0 +1,85 @@
1
+ import React, { forwardRef, useRef, useEffect } from 'react';
2
+ import { useMergedRef } from '@mantine/hooks';
3
+ import { Scrollbar } from './Scrollbar.js';
4
+ import { useScrollAreaContext } from '../ScrollArea.context.js';
5
+ import { getThumbSize } from '../utils/get-thumb-size.js';
6
+ import { isScrollingWithinScrollbarBounds } from '../utils/is-scrolling-within-scrollbar-bounds.js';
7
+ import { toInt } from '../utils/to-int.js';
8
+
9
+ var __defProp = Object.defineProperty;
10
+ var __defProps = Object.defineProperties;
11
+ var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
12
+ var __getOwnPropSymbols = Object.getOwnPropertySymbols;
13
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
14
+ var __propIsEnum = Object.prototype.propertyIsEnumerable;
15
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
16
+ var __spreadValues = (a, b) => {
17
+ for (var prop in b || (b = {}))
18
+ if (__hasOwnProp.call(b, prop))
19
+ __defNormalProp(a, prop, b[prop]);
20
+ if (__getOwnPropSymbols)
21
+ for (var prop of __getOwnPropSymbols(b)) {
22
+ if (__propIsEnum.call(b, prop))
23
+ __defNormalProp(a, prop, b[prop]);
24
+ }
25
+ return a;
26
+ };
27
+ var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
28
+ var __objRest = (source, exclude) => {
29
+ var target = {};
30
+ for (var prop in source)
31
+ if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)
32
+ target[prop] = source[prop];
33
+ if (source != null && __getOwnPropSymbols)
34
+ for (var prop of __getOwnPropSymbols(source)) {
35
+ if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))
36
+ target[prop] = source[prop];
37
+ }
38
+ return target;
39
+ };
40
+ const ScrollAreaScrollbarY = forwardRef((props, forwardedRef) => {
41
+ const _a = props, { sizes, onSizesChange, style } = _a, others = __objRest(_a, ["sizes", "onSizesChange", "style"]);
42
+ const context = useScrollAreaContext();
43
+ const [computedStyle, setComputedStyle] = React.useState();
44
+ const ref = useRef(null);
45
+ const composeRefs = useMergedRef(forwardedRef, ref, context.onScrollbarYChange);
46
+ useEffect(() => {
47
+ if (ref.current)
48
+ setComputedStyle(getComputedStyle(ref.current));
49
+ }, [ref]);
50
+ return /* @__PURE__ */ React.createElement(Scrollbar, __spreadProps(__spreadValues({}, others), {
51
+ "data-orientation": "vertical",
52
+ ref: composeRefs,
53
+ sizes,
54
+ style: __spreadValues({
55
+ ["--sa-thumb-height"]: `${getThumbSize(sizes)}px`
56
+ }, style),
57
+ onThumbPointerDown: (pointerPos) => props.onThumbPointerDown(pointerPos.y),
58
+ onDragScroll: (pointerPos) => props.onDragScroll(pointerPos.y),
59
+ onWheelScroll: (event, maxScrollPos) => {
60
+ if (context.viewport) {
61
+ const scrollPos = context.viewport.scrollTop + event.deltaY;
62
+ props.onWheelScroll(scrollPos);
63
+ if (isScrollingWithinScrollbarBounds(scrollPos, maxScrollPos)) {
64
+ event.preventDefault();
65
+ }
66
+ }
67
+ },
68
+ onResize: () => {
69
+ if (ref.current && context.viewport && computedStyle) {
70
+ onSizesChange({
71
+ content: context.viewport.scrollHeight,
72
+ viewport: context.viewport.offsetHeight,
73
+ scrollbar: {
74
+ size: ref.current.clientHeight,
75
+ paddingStart: toInt(computedStyle.paddingTop),
76
+ paddingEnd: toInt(computedStyle.paddingBottom)
77
+ }
78
+ });
79
+ }
80
+ }
81
+ }));
82
+ });
83
+
84
+ export { ScrollAreaScrollbarY };
85
+ //# sourceMappingURL=ScrollbarY.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ScrollbarY.js","sources":["../../../../src/components/ScrollArea/ScrollAreaScrollbar/ScrollbarY.tsx"],"sourcesContent":["import React, { forwardRef, useEffect, useRef } from 'react';\nimport { useMergedRef } from '@mantine/hooks';\nimport { Scrollbar } from './Scrollbar';\nimport { useScrollAreaContext } from '../ScrollArea.context';\nimport { ScrollAreaScrollbarAxisProps } from '../ScrollArea.types';\nimport { isScrollingWithinScrollbarBounds, getThumbSize, toInt } from '../utils';\n\nexport const ScrollAreaScrollbarY = forwardRef<HTMLDivElement, ScrollAreaScrollbarAxisProps>(\n (props, forwardedRef) => {\n const { sizes, onSizesChange, style, ...others } = props;\n const context = useScrollAreaContext();\n const [computedStyle, setComputedStyle] = React.useState<CSSStyleDeclaration>();\n const ref = useRef<HTMLDivElement>(null);\n const composeRefs = useMergedRef(forwardedRef, ref, context.onScrollbarYChange);\n\n useEffect(() => {\n if (ref.current) setComputedStyle(getComputedStyle(ref.current));\n }, [ref]);\n\n return (\n <Scrollbar\n {...others}\n data-orientation=\"vertical\"\n ref={composeRefs}\n sizes={sizes}\n style={{\n ['--sa-thumb-height' as any]: `${getThumbSize(sizes)}px`,\n ...style,\n }}\n onThumbPointerDown={(pointerPos) => props.onThumbPointerDown(pointerPos.y)}\n onDragScroll={(pointerPos) => props.onDragScroll(pointerPos.y)}\n onWheelScroll={(event, maxScrollPos) => {\n if (context.viewport) {\n const scrollPos = context.viewport.scrollTop + event.deltaY;\n props.onWheelScroll(scrollPos);\n if (isScrollingWithinScrollbarBounds(scrollPos, maxScrollPos)) {\n event.preventDefault();\n }\n }\n }}\n onResize={() => {\n if (ref.current && context.viewport && computedStyle) {\n onSizesChange({\n content: context.viewport.scrollHeight,\n viewport: context.viewport.offsetHeight,\n scrollbar: {\n size: ref.current.clientHeight,\n paddingStart: toInt(computedStyle.paddingTop),\n paddingEnd: toInt(computedStyle.paddingBottom),\n },\n });\n }\n }}\n />\n );\n }\n);\n"],"names":[],"mappings":"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"}
@@ -0,0 +1,99 @@
1
+ import React, { forwardRef, useRef, useEffect } from 'react';
2
+ import { useMergedRef, useDebounceCallback } from '@mantine/hooks';
3
+ import { useScrollbarContext } from '../ScrollAreaScrollbar/Scrollbar.context.js';
4
+ import { useScrollAreaContext } from '../ScrollArea.context.js';
5
+ import { composeEventHandlers } from '../utils/compose-event-handlers.js';
6
+ import { addUnlinkedScrollListener } from '../utils/add-unlinked-scroll-listener.js';
7
+
8
+ var __defProp = Object.defineProperty;
9
+ var __defProps = Object.defineProperties;
10
+ var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
11
+ var __getOwnPropSymbols = Object.getOwnPropertySymbols;
12
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
13
+ var __propIsEnum = Object.prototype.propertyIsEnumerable;
14
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
15
+ var __spreadValues = (a, b) => {
16
+ for (var prop in b || (b = {}))
17
+ if (__hasOwnProp.call(b, prop))
18
+ __defNormalProp(a, prop, b[prop]);
19
+ if (__getOwnPropSymbols)
20
+ for (var prop of __getOwnPropSymbols(b)) {
21
+ if (__propIsEnum.call(b, prop))
22
+ __defNormalProp(a, prop, b[prop]);
23
+ }
24
+ return a;
25
+ };
26
+ var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
27
+ var __objRest = (source, exclude) => {
28
+ var target = {};
29
+ for (var prop in source)
30
+ if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)
31
+ target[prop] = source[prop];
32
+ if (source != null && __getOwnPropSymbols)
33
+ for (var prop of __getOwnPropSymbols(source)) {
34
+ if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))
35
+ target[prop] = source[prop];
36
+ }
37
+ return target;
38
+ };
39
+ const Thumb = forwardRef((props, forwardedRef) => {
40
+ const _a = props, { style } = _a, others = __objRest(_a, ["style"]);
41
+ const scrollAreaContext = useScrollAreaContext();
42
+ const scrollbarContext = useScrollbarContext();
43
+ const { onThumbPositionChange } = scrollbarContext;
44
+ const composedRef = useMergedRef(forwardedRef, (node) => scrollbarContext.onThumbChange(node));
45
+ const removeUnlinkedScrollListenerRef = useRef();
46
+ const debounceScrollEnd = useDebounceCallback(() => {
47
+ if (removeUnlinkedScrollListenerRef.current) {
48
+ removeUnlinkedScrollListenerRef.current();
49
+ removeUnlinkedScrollListenerRef.current = void 0;
50
+ }
51
+ }, 100);
52
+ useEffect(() => {
53
+ const { viewport } = scrollAreaContext;
54
+ if (viewport) {
55
+ const handleScroll = () => {
56
+ debounceScrollEnd();
57
+ if (!removeUnlinkedScrollListenerRef.current) {
58
+ const listener = addUnlinkedScrollListener(viewport, onThumbPositionChange);
59
+ removeUnlinkedScrollListenerRef.current = listener;
60
+ onThumbPositionChange();
61
+ }
62
+ };
63
+ onThumbPositionChange();
64
+ viewport.addEventListener("scroll", handleScroll);
65
+ return () => viewport.removeEventListener("scroll", handleScroll);
66
+ }
67
+ return void 0;
68
+ }, [scrollAreaContext.viewport, debounceScrollEnd, onThumbPositionChange]);
69
+ return /* @__PURE__ */ React.createElement("div", __spreadProps(__spreadValues({
70
+ "data-state": scrollbarContext.hasThumb ? "visible" : "hidden"
71
+ }, others), {
72
+ ref: composedRef,
73
+ style: __spreadValues({
74
+ width: "var(--sa-thumb-width)",
75
+ height: "var(--sa-thumb-height)"
76
+ }, style),
77
+ onPointerDownCapture: composeEventHandlers(props.onPointerDownCapture, (event) => {
78
+ const thumb = event.target;
79
+ const thumbRect = thumb.getBoundingClientRect();
80
+ const x = event.clientX - thumbRect.left;
81
+ const y = event.clientY - thumbRect.top;
82
+ scrollbarContext.onThumbPointerDown({ x, y });
83
+ }),
84
+ onPointerUp: composeEventHandlers(props.onPointerUp, scrollbarContext.onThumbPointerUp)
85
+ }));
86
+ });
87
+ const ScrollAreaThumb = React.forwardRef((props, forwardedRef) => {
88
+ const _a = props, { forceMount } = _a, thumbProps = __objRest(_a, ["forceMount"]);
89
+ const scrollbarContext = useScrollbarContext();
90
+ if (forceMount || scrollbarContext.hasThumb) {
91
+ return /* @__PURE__ */ React.createElement(Thumb, __spreadValues({
92
+ ref: forwardedRef
93
+ }, thumbProps));
94
+ }
95
+ return null;
96
+ });
97
+
98
+ export { ScrollAreaThumb, Thumb };
99
+ //# sourceMappingURL=ScrollAreaThumb.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ScrollAreaThumb.js","sources":["../../../../src/components/ScrollArea/ScrollAreaThumb/ScrollAreaThumb.tsx"],"sourcesContent":["import React, { forwardRef, useRef, useEffect } from 'react';\nimport { useDebounceCallback, useMergedRef } from '@mantine/hooks';\nimport { useScrollbarContext } from '../ScrollAreaScrollbar/Scrollbar.context';\nimport { useScrollAreaContext } from '../ScrollArea.context';\nimport { addUnlinkedScrollListener, composeEventHandlers } from '../utils';\n\ninterface ThumbProps extends React.ComponentPropsWithoutRef<'div'> {}\n\nexport const Thumb = forwardRef<HTMLDivElement, ThumbProps>((props, forwardedRef) => {\n const { style, ...others } = props;\n const scrollAreaContext = useScrollAreaContext();\n const scrollbarContext = useScrollbarContext();\n const { onThumbPositionChange } = scrollbarContext;\n const composedRef = useMergedRef(forwardedRef, (node) => scrollbarContext.onThumbChange(node));\n const removeUnlinkedScrollListenerRef = useRef<() => void>();\n const debounceScrollEnd = useDebounceCallback(() => {\n if (removeUnlinkedScrollListenerRef.current) {\n removeUnlinkedScrollListenerRef.current();\n removeUnlinkedScrollListenerRef.current = undefined;\n }\n }, 100);\n\n useEffect(() => {\n const { viewport } = scrollAreaContext;\n if (viewport) {\n const handleScroll = () => {\n debounceScrollEnd();\n if (!removeUnlinkedScrollListenerRef.current) {\n const listener = addUnlinkedScrollListener(viewport, onThumbPositionChange);\n removeUnlinkedScrollListenerRef.current = listener;\n onThumbPositionChange();\n }\n };\n onThumbPositionChange();\n viewport.addEventListener('scroll', handleScroll);\n return () => viewport.removeEventListener('scroll', handleScroll);\n }\n\n return undefined;\n }, [scrollAreaContext.viewport, debounceScrollEnd, onThumbPositionChange]);\n\n return (\n <div\n data-state={scrollbarContext.hasThumb ? 'visible' : 'hidden'}\n {...others}\n ref={composedRef}\n style={{\n width: 'var(--sa-thumb-width)',\n height: 'var(--sa-thumb-height)',\n ...style,\n }}\n onPointerDownCapture={composeEventHandlers(props.onPointerDownCapture, (event) => {\n const thumb = event.target as HTMLElement;\n const thumbRect = thumb.getBoundingClientRect();\n const x = event.clientX - thumbRect.left;\n const y = event.clientY - thumbRect.top;\n scrollbarContext.onThumbPointerDown({ x, y });\n })}\n onPointerUp={composeEventHandlers(props.onPointerUp, scrollbarContext.onThumbPointerUp)}\n />\n );\n});\n\ninterface ScrollAreaThumbProps extends ThumbProps {\n forceMount?: true;\n}\n\nexport const ScrollAreaThumb = React.forwardRef<HTMLDivElement, ScrollAreaThumbProps>(\n (props, forwardedRef) => {\n const { forceMount, ...thumbProps } = props;\n const scrollbarContext = useScrollbarContext();\n\n if (forceMount || scrollbarContext.hasThumb) {\n return <Thumb ref={forwardedRef} {...thumbProps} />;\n }\n\n return null;\n }\n);\n"],"names":[],"mappings":"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"}