@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.
- package/cjs/components/ActionIcon/ActionIcon.js +7 -5
- package/cjs/components/ActionIcon/ActionIcon.js.map +1 -1
- package/cjs/components/ActionIcon/ActionIconGroup/ActionIconGroup.js.map +1 -1
- package/cjs/components/Affix/Affix.js +109 -0
- package/cjs/components/Affix/Affix.js.map +1 -0
- package/cjs/components/Affix/Affix.module.css.js +8 -0
- package/cjs/components/Affix/Affix.module.css.js.map +1 -0
- package/cjs/components/Alert/Alert.js +147 -0
- package/cjs/components/Alert/Alert.js.map +1 -0
- package/cjs/components/Alert/Alert.module.css.js +8 -0
- package/cjs/components/Alert/Alert.module.css.js.map +1 -0
- package/cjs/components/Anchor/Anchor.js.map +1 -1
- package/cjs/components/AspectRatio/AspectRatio.js +73 -0
- package/cjs/components/AspectRatio/AspectRatio.js.map +1 -0
- package/cjs/components/AspectRatio/AspectRatio.module.css.js +8 -0
- package/cjs/components/AspectRatio/AspectRatio.module.css.js.map +1 -0
- package/cjs/components/Avatar/Avatar.js +140 -0
- package/cjs/components/Avatar/Avatar.js.map +1 -0
- package/cjs/components/Avatar/Avatar.module.css.js +8 -0
- package/cjs/components/Avatar/Avatar.module.css.js.map +1 -0
- package/cjs/components/Avatar/AvatarGroup/AvatarGroup.context.js +16 -0
- package/cjs/components/Avatar/AvatarGroup/AvatarGroup.context.js.map +1 -0
- package/cjs/components/Avatar/AvatarGroup/AvatarGroup.js +79 -0
- package/cjs/components/Avatar/AvatarGroup/AvatarGroup.js.map +1 -0
- package/cjs/components/Avatar/AvatarGroup/AvatarGroup.module.css.js +8 -0
- package/cjs/components/Avatar/AvatarGroup/AvatarGroup.module.css.js.map +1 -0
- package/cjs/components/Avatar/AvatarPlaceholderIcon.js +45 -0
- package/cjs/components/Avatar/AvatarPlaceholderIcon.js.map +1 -0
- package/cjs/components/BackgroundImage/BackgroundImage.js.map +1 -1
- package/cjs/components/Badge/Badge.js +134 -0
- package/cjs/components/Badge/Badge.js.map +1 -0
- package/cjs/components/Badge/Badge.module.css.js +8 -0
- package/cjs/components/Badge/Badge.module.css.js.map +1 -0
- package/cjs/components/Blockquote/Blockquote.js.map +1 -1
- package/cjs/components/Breadcrumbs/Breadcrumbs.js +1 -1
- package/cjs/components/Breadcrumbs/Breadcrumbs.js.map +1 -1
- package/cjs/components/Burger/Burger.js.map +1 -1
- package/cjs/components/Button/Button.js.map +1 -1
- package/cjs/components/Button/ButtonGroup/ButtonGroup.js.map +1 -1
- package/cjs/components/Center/Center.js.map +1 -1
- package/cjs/components/CloseButton/CloseButton.js.map +1 -1
- package/cjs/components/Code/Code.js.map +1 -1
- package/cjs/components/ColorPicker/ColorPicker.js.map +1 -1
- package/cjs/components/ColorPicker/converters/parsers.js +4 -4
- package/cjs/components/ColorPicker/converters/parsers.js.map +1 -1
- package/cjs/components/ColorSwatch/ColorSwatch.js +3 -3
- package/cjs/components/ColorSwatch/ColorSwatch.js.map +1 -1
- package/cjs/components/Container/Container.js.map +1 -1
- package/cjs/components/CopyButton/CopyButton.js.map +1 -1
- package/cjs/components/Divider/Divider.js +111 -0
- package/cjs/components/Divider/Divider.js.map +1 -0
- package/cjs/components/Divider/Divider.module.css.js +8 -0
- package/cjs/components/Divider/Divider.module.css.js.map +1 -0
- package/cjs/components/FileButton/FileButton.js.map +1 -1
- package/cjs/components/Group/Group.js.map +1 -1
- package/cjs/components/Input/Input.js.map +1 -1
- package/cjs/components/Input/InputWrapper/InputWrapper.js.map +1 -1
- package/cjs/components/Loader/Loader.js.map +1 -1
- package/cjs/components/Overlay/Overlay.js +121 -0
- package/cjs/components/Overlay/Overlay.js.map +1 -0
- package/cjs/components/Overlay/Overlay.module.css.js +8 -0
- package/cjs/components/Overlay/Overlay.module.css.js.map +1 -0
- package/cjs/components/Paper/Paper.js.map +1 -1
- package/cjs/components/Popover/Popover.js +1 -1
- package/cjs/components/Popover/Popover.js.map +1 -1
- package/cjs/components/ScrollArea/ScrollArea.context.js +11 -0
- package/cjs/components/ScrollArea/ScrollArea.context.js.map +1 -0
- package/cjs/components/ScrollArea/ScrollArea.js +12 -29
- package/cjs/components/ScrollArea/ScrollArea.js.map +1 -1
- package/cjs/components/ScrollArea/ScrollArea.module.css.js +1 -1
- package/cjs/components/ScrollArea/ScrollAreaCorner/ScrollAreaCorner.js +78 -0
- package/cjs/components/ScrollArea/ScrollAreaCorner/ScrollAreaCorner.js.map +1 -0
- package/cjs/components/ScrollArea/ScrollAreaRoot/ScrollAreaRoot.js +94 -0
- package/cjs/components/ScrollArea/ScrollAreaRoot/ScrollAreaRoot.js.map +1 -0
- package/cjs/components/ScrollArea/ScrollAreaScrollbar/ScrollAreaScrollbar.js +73 -0
- package/cjs/components/ScrollArea/ScrollAreaScrollbar/ScrollAreaScrollbar.js.map +1 -0
- package/cjs/components/ScrollArea/ScrollAreaScrollbar/ScrollAreaScrollbarAuto.js +71 -0
- package/cjs/components/ScrollArea/ScrollAreaScrollbar/ScrollAreaScrollbarAuto.js.map +1 -0
- package/cjs/components/ScrollArea/ScrollAreaScrollbar/ScrollAreaScrollbarHover.js +80 -0
- package/cjs/components/ScrollArea/ScrollAreaScrollbar/ScrollAreaScrollbarHover.js.map +1 -0
- package/cjs/components/ScrollArea/ScrollAreaScrollbar/ScrollAreaScrollbarScroll.js +91 -0
- package/cjs/components/ScrollArea/ScrollAreaScrollbar/ScrollAreaScrollbarScroll.js.map +1 -0
- package/cjs/components/ScrollArea/ScrollAreaScrollbar/ScrollAreaScrollbarVisible.js +121 -0
- package/cjs/components/ScrollArea/ScrollAreaScrollbar/ScrollAreaScrollbarVisible.js.map +1 -0
- package/cjs/components/ScrollArea/ScrollAreaScrollbar/Scrollbar.context.js +11 -0
- package/cjs/components/ScrollArea/ScrollAreaScrollbar/Scrollbar.context.js.map +1 -0
- package/cjs/components/ScrollArea/ScrollAreaScrollbar/Scrollbar.js +135 -0
- package/cjs/components/ScrollArea/ScrollAreaScrollbar/Scrollbar.js.map +1 -0
- package/cjs/components/ScrollArea/ScrollAreaScrollbar/ScrollbarX.js +94 -0
- package/cjs/components/ScrollArea/ScrollAreaScrollbar/ScrollbarX.js.map +1 -0
- package/cjs/components/ScrollArea/ScrollAreaScrollbar/ScrollbarY.js +93 -0
- package/cjs/components/ScrollArea/ScrollAreaScrollbar/ScrollbarY.js.map +1 -0
- package/cjs/components/ScrollArea/ScrollAreaThumb/ScrollAreaThumb.js +108 -0
- package/cjs/components/ScrollArea/ScrollAreaThumb/ScrollAreaThumb.js.map +1 -0
- package/cjs/components/ScrollArea/ScrollAreaViewport/ScrollAreaViewport.js +63 -0
- package/cjs/components/ScrollArea/ScrollAreaViewport/ScrollAreaViewport.js.map +1 -0
- package/cjs/components/ScrollArea/use-resize-observer.js +27 -0
- package/cjs/components/ScrollArea/use-resize-observer.js.map +1 -0
- package/cjs/components/ScrollArea/utils/add-unlinked-scroll-listener.js +22 -0
- package/cjs/components/ScrollArea/utils/add-unlinked-scroll-listener.js.map +1 -0
- package/cjs/components/ScrollArea/utils/compose-event-handlers.js +15 -0
- package/cjs/components/ScrollArea/utils/compose-event-handlers.js.map +1 -0
- package/cjs/components/ScrollArea/utils/get-scroll-position-from-pointer.js +22 -0
- package/cjs/components/ScrollArea/utils/get-scroll-position-from-pointer.js.map +1 -0
- package/cjs/components/ScrollArea/utils/get-thumb-offset-from-scroll.js +24 -0
- package/cjs/components/ScrollArea/utils/get-thumb-offset-from-scroll.js.map +1 -0
- package/cjs/components/ScrollArea/utils/get-thumb-ratio.js +11 -0
- package/cjs/components/ScrollArea/utils/get-thumb-ratio.js.map +1 -0
- package/cjs/components/ScrollArea/utils/get-thumb-size.js +15 -0
- package/cjs/components/ScrollArea/utils/get-thumb-size.js.map +1 -0
- package/cjs/components/ScrollArea/utils/is-scrolling-within-scrollbar-bounds.js +10 -0
- package/cjs/components/ScrollArea/utils/is-scrolling-within-scrollbar-bounds.js.map +1 -0
- package/cjs/components/ScrollArea/utils/linear-scale.js +15 -0
- package/cjs/components/ScrollArea/utils/linear-scale.js.map +1 -0
- package/cjs/components/ScrollArea/utils/to-int.js +10 -0
- package/cjs/components/ScrollArea/utils/to-int.js.map +1 -0
- package/cjs/components/SegmentedControl/SegmentedControl.js.map +1 -1
- package/cjs/components/Slider/RangeSlider/RangeSlider.js +4 -11
- package/cjs/components/Slider/RangeSlider/RangeSlider.js.map +1 -1
- package/cjs/components/Slider/Slider/Slider.js +4 -11
- package/cjs/components/Slider/Slider/Slider.js.map +1 -1
- package/cjs/components/Slider/Thumb/Thumb.js +5 -8
- package/cjs/components/Slider/Thumb/Thumb.js.map +1 -1
- package/cjs/components/Stack/Stack.js.map +1 -1
- package/cjs/components/Switch/Switch.js.map +1 -1
- package/cjs/components/Switch/SwitchGroup/SwitchGroup.js.map +1 -1
- package/cjs/components/Table/Table.js.map +1 -1
- package/cjs/components/Tabs/Tabs.js.map +1 -1
- package/cjs/components/Tabs/Tabs.module.css.js +1 -1
- package/cjs/components/Tabs/TabsList/TabsList.js.map +1 -1
- package/cjs/components/Tabs/TabsTab/TabsTab.js +5 -1
- package/cjs/components/Tabs/TabsTab/TabsTab.js.map +1 -1
- package/cjs/components/Text/Text.js +1 -1
- package/cjs/components/Text/Text.js.map +1 -1
- package/cjs/components/Tooltip/Tooltip.js +1 -1
- package/cjs/components/Tooltip/Tooltip.js.map +1 -1
- package/cjs/components/Tooltip/use-tooltip.js.map +1 -1
- package/cjs/components/TypographyStylesProvider/TypographyStylesProvider.js +65 -0
- package/cjs/components/TypographyStylesProvider/TypographyStylesProvider.js.map +1 -0
- package/cjs/components/TypographyStylesProvider/TypographyStylesProvider.module.css.js +8 -0
- package/cjs/components/TypographyStylesProvider/TypographyStylesProvider.module.css.js.map +1 -0
- package/cjs/core/Box/style-props/resolvers/font-size-resolver/font-size-resolver.js +3 -0
- package/cjs/core/Box/style-props/resolvers/font-size-resolver/font-size-resolver.js.map +1 -1
- package/cjs/core/Box/style-props/resolvers/spacing-resolver/spacing-resolver.js +1 -1
- package/cjs/core/Box/style-props/resolvers/spacing-resolver/spacing-resolver.js.map +1 -1
- package/cjs/core/MantineProvider/MantineCssVariables/MantineCssVariables.js +15 -8
- package/cjs/core/MantineProvider/MantineCssVariables/MantineCssVariables.js.map +1 -1
- package/cjs/core/MantineProvider/MantineCssVariables/default-css-variables-resolver.js +1 -0
- package/cjs/core/MantineProvider/MantineCssVariables/default-css-variables-resolver.js.map +1 -1
- package/cjs/core/MantineProvider/MantineCssVariables/remove-default-variables.js +35 -0
- package/cjs/core/MantineProvider/MantineCssVariables/remove-default-variables.js.map +1 -0
- package/cjs/core/MantineProvider/MantineProvider.js.map +1 -1
- package/cjs/core/MantineProvider/convert-css-variables/convert-css-variables.js +6 -5
- package/cjs/core/MantineProvider/convert-css-variables/convert-css-variables.js.map +1 -1
- package/cjs/core/MantineProvider/default-theme.js +28 -26
- package/cjs/core/MantineProvider/default-theme.js.map +1 -1
- package/cjs/core/MantineProvider/use-mantine-color-scheme/use-mantine-color-scheme.js +39 -2
- package/cjs/core/MantineProvider/use-mantine-color-scheme/use-mantine-color-scheme.js.map +1 -1
- package/cjs/core/utils/units-converters/px.js +21 -10
- package/cjs/core/utils/units-converters/px.js.map +1 -1
- package/cjs/core/utils/units-converters/rem.js +23 -9
- package/cjs/core/utils/units-converters/rem.js.map +1 -1
- package/cjs/index.css +1687 -285
- package/cjs/index.js +16 -0
- package/cjs/index.js.map +1 -1
- package/esm/components/ActionIcon/ActionIcon.js +7 -5
- package/esm/components/ActionIcon/ActionIcon.js.map +1 -1
- package/esm/components/ActionIcon/ActionIconGroup/ActionIconGroup.js.map +1 -1
- package/esm/components/Affix/Affix.js +101 -0
- package/esm/components/Affix/Affix.js.map +1 -0
- package/esm/components/Affix/Affix.module.css.js +4 -0
- package/esm/components/Affix/Affix.module.css.js.map +1 -0
- package/esm/components/Alert/Alert.js +139 -0
- package/esm/components/Alert/Alert.js.map +1 -0
- package/esm/components/Alert/Alert.module.css.js +4 -0
- package/esm/components/Alert/Alert.module.css.js.map +1 -0
- package/esm/components/Anchor/Anchor.js.map +1 -1
- package/esm/components/AspectRatio/AspectRatio.js +65 -0
- package/esm/components/AspectRatio/AspectRatio.js.map +1 -0
- package/esm/components/AspectRatio/AspectRatio.module.css.js +4 -0
- package/esm/components/AspectRatio/AspectRatio.module.css.js.map +1 -0
- package/esm/components/Avatar/Avatar.js +132 -0
- package/esm/components/Avatar/Avatar.js.map +1 -0
- package/esm/components/Avatar/Avatar.module.css.js +4 -0
- package/esm/components/Avatar/Avatar.module.css.js.map +1 -0
- package/esm/components/Avatar/AvatarGroup/AvatarGroup.context.js +11 -0
- package/esm/components/Avatar/AvatarGroup/AvatarGroup.context.js.map +1 -0
- package/esm/components/Avatar/AvatarGroup/AvatarGroup.js +71 -0
- package/esm/components/Avatar/AvatarGroup/AvatarGroup.js.map +1 -0
- package/esm/components/Avatar/AvatarGroup/AvatarGroup.module.css.js +4 -0
- package/esm/components/Avatar/AvatarGroup/AvatarGroup.module.css.js.map +1 -0
- package/esm/components/Avatar/AvatarPlaceholderIcon.js +37 -0
- package/esm/components/Avatar/AvatarPlaceholderIcon.js.map +1 -0
- package/esm/components/BackgroundImage/BackgroundImage.js.map +1 -1
- package/esm/components/Badge/Badge.js +126 -0
- package/esm/components/Badge/Badge.js.map +1 -0
- package/esm/components/Badge/Badge.module.css.js +4 -0
- package/esm/components/Badge/Badge.module.css.js.map +1 -0
- package/esm/components/Blockquote/Blockquote.js.map +1 -1
- package/esm/components/Breadcrumbs/Breadcrumbs.js +1 -1
- package/esm/components/Breadcrumbs/Breadcrumbs.js.map +1 -1
- package/esm/components/Burger/Burger.js.map +1 -1
- package/esm/components/Button/Button.js.map +1 -1
- package/esm/components/Button/ButtonGroup/ButtonGroup.js.map +1 -1
- package/esm/components/Center/Center.js.map +1 -1
- package/esm/components/CloseButton/CloseButton.js.map +1 -1
- package/esm/components/Code/Code.js.map +1 -1
- package/esm/components/ColorPicker/ColorPicker.js.map +1 -1
- package/esm/components/ColorPicker/converters/parsers.js +4 -4
- package/esm/components/ColorPicker/converters/parsers.js.map +1 -1
- package/esm/components/ColorSwatch/ColorSwatch.js +3 -3
- package/esm/components/ColorSwatch/ColorSwatch.js.map +1 -1
- package/esm/components/Container/Container.js.map +1 -1
- package/esm/components/CopyButton/CopyButton.js.map +1 -1
- package/esm/components/Divider/Divider.js +103 -0
- package/esm/components/Divider/Divider.js.map +1 -0
- package/esm/components/Divider/Divider.module.css.js +4 -0
- package/esm/components/Divider/Divider.module.css.js.map +1 -0
- package/esm/components/FileButton/FileButton.js.map +1 -1
- package/esm/components/Group/Group.js.map +1 -1
- package/esm/components/Input/Input.js.map +1 -1
- package/esm/components/Input/InputWrapper/InputWrapper.js.map +1 -1
- package/esm/components/Loader/Loader.js.map +1 -1
- package/esm/components/Overlay/Overlay.js +113 -0
- package/esm/components/Overlay/Overlay.js.map +1 -0
- package/esm/components/Overlay/Overlay.module.css.js +4 -0
- package/esm/components/Overlay/Overlay.module.css.js.map +1 -0
- package/esm/components/Paper/Paper.js.map +1 -1
- package/esm/components/Popover/Popover.js +1 -1
- package/esm/components/Popover/Popover.js.map +1 -1
- package/esm/components/ScrollArea/ScrollArea.context.js +6 -0
- package/esm/components/ScrollArea/ScrollArea.context.js.map +1 -0
- package/esm/components/ScrollArea/ScrollArea.js +12 -16
- package/esm/components/ScrollArea/ScrollArea.js.map +1 -1
- package/esm/components/ScrollArea/ScrollArea.module.css.js +1 -1
- package/esm/components/ScrollArea/ScrollAreaCorner/ScrollAreaCorner.js +69 -0
- package/esm/components/ScrollArea/ScrollAreaCorner/ScrollAreaCorner.js.map +1 -0
- package/esm/components/ScrollArea/ScrollAreaRoot/ScrollAreaRoot.js +86 -0
- package/esm/components/ScrollArea/ScrollAreaRoot/ScrollAreaRoot.js.map +1 -0
- package/esm/components/ScrollArea/ScrollAreaScrollbar/ScrollAreaScrollbar.js +65 -0
- package/esm/components/ScrollArea/ScrollAreaScrollbar/ScrollAreaScrollbar.js.map +1 -0
- package/esm/components/ScrollArea/ScrollAreaScrollbar/ScrollAreaScrollbarAuto.js +63 -0
- package/esm/components/ScrollArea/ScrollAreaScrollbar/ScrollAreaScrollbarAuto.js.map +1 -0
- package/esm/components/ScrollArea/ScrollAreaScrollbar/ScrollAreaScrollbarHover.js +72 -0
- package/esm/components/ScrollArea/ScrollAreaScrollbar/ScrollAreaScrollbarHover.js.map +1 -0
- package/esm/components/ScrollArea/ScrollAreaScrollbar/ScrollAreaScrollbarScroll.js +83 -0
- package/esm/components/ScrollArea/ScrollAreaScrollbar/ScrollAreaScrollbarScroll.js.map +1 -0
- package/esm/components/ScrollArea/ScrollAreaScrollbar/ScrollAreaScrollbarVisible.js +113 -0
- package/esm/components/ScrollArea/ScrollAreaScrollbar/ScrollAreaScrollbarVisible.js.map +1 -0
- package/esm/components/ScrollArea/ScrollAreaScrollbar/Scrollbar.context.js +6 -0
- package/esm/components/ScrollArea/ScrollAreaScrollbar/Scrollbar.context.js.map +1 -0
- package/esm/components/ScrollArea/ScrollAreaScrollbar/Scrollbar.js +127 -0
- package/esm/components/ScrollArea/ScrollAreaScrollbar/Scrollbar.js.map +1 -0
- package/esm/components/ScrollArea/ScrollAreaScrollbar/ScrollbarX.js +86 -0
- package/esm/components/ScrollArea/ScrollAreaScrollbar/ScrollbarX.js.map +1 -0
- package/esm/components/ScrollArea/ScrollAreaScrollbar/ScrollbarY.js +85 -0
- package/esm/components/ScrollArea/ScrollAreaScrollbar/ScrollbarY.js.map +1 -0
- package/esm/components/ScrollArea/ScrollAreaThumb/ScrollAreaThumb.js +99 -0
- package/esm/components/ScrollArea/ScrollAreaThumb/ScrollAreaThumb.js.map +1 -0
- package/esm/components/ScrollArea/ScrollAreaViewport/ScrollAreaViewport.js +55 -0
- package/esm/components/ScrollArea/ScrollAreaViewport/ScrollAreaViewport.js.map +1 -0
- package/esm/components/ScrollArea/use-resize-observer.js +23 -0
- package/esm/components/ScrollArea/use-resize-observer.js.map +1 -0
- package/esm/components/ScrollArea/utils/add-unlinked-scroll-listener.js +18 -0
- package/esm/components/ScrollArea/utils/add-unlinked-scroll-listener.js.map +1 -0
- package/esm/components/ScrollArea/utils/compose-event-handlers.js +11 -0
- package/esm/components/ScrollArea/utils/compose-event-handlers.js.map +1 -0
- package/esm/components/ScrollArea/utils/get-scroll-position-from-pointer.js +18 -0
- package/esm/components/ScrollArea/utils/get-scroll-position-from-pointer.js.map +1 -0
- package/esm/components/ScrollArea/utils/get-thumb-offset-from-scroll.js +20 -0
- package/esm/components/ScrollArea/utils/get-thumb-offset-from-scroll.js.map +1 -0
- package/esm/components/ScrollArea/utils/get-thumb-ratio.js +7 -0
- package/esm/components/ScrollArea/utils/get-thumb-ratio.js.map +1 -0
- package/esm/components/ScrollArea/utils/get-thumb-size.js +11 -0
- package/esm/components/ScrollArea/utils/get-thumb-size.js.map +1 -0
- package/esm/components/ScrollArea/utils/is-scrolling-within-scrollbar-bounds.js +6 -0
- package/esm/components/ScrollArea/utils/is-scrolling-within-scrollbar-bounds.js.map +1 -0
- package/esm/components/ScrollArea/utils/linear-scale.js +11 -0
- package/esm/components/ScrollArea/utils/linear-scale.js.map +1 -0
- package/esm/components/ScrollArea/utils/to-int.js +6 -0
- package/esm/components/ScrollArea/utils/to-int.js.map +1 -0
- package/esm/components/SegmentedControl/SegmentedControl.js.map +1 -1
- package/esm/components/Slider/RangeSlider/RangeSlider.js +4 -11
- package/esm/components/Slider/RangeSlider/RangeSlider.js.map +1 -1
- package/esm/components/Slider/Slider/Slider.js +4 -11
- package/esm/components/Slider/Slider/Slider.js.map +1 -1
- package/esm/components/Slider/Thumb/Thumb.js +5 -8
- package/esm/components/Slider/Thumb/Thumb.js.map +1 -1
- package/esm/components/Stack/Stack.js.map +1 -1
- package/esm/components/Switch/Switch.js.map +1 -1
- package/esm/components/Switch/SwitchGroup/SwitchGroup.js.map +1 -1
- package/esm/components/Table/Table.js.map +1 -1
- package/esm/components/Tabs/Tabs.js.map +1 -1
- package/esm/components/Tabs/Tabs.module.css.js +1 -1
- package/esm/components/Tabs/TabsList/TabsList.js.map +1 -1
- package/esm/components/Tabs/TabsTab/TabsTab.js +5 -1
- package/esm/components/Tabs/TabsTab/TabsTab.js.map +1 -1
- package/esm/components/Text/Text.js +1 -1
- package/esm/components/Text/Text.js.map +1 -1
- package/esm/components/Tooltip/Tooltip.js +1 -1
- package/esm/components/Tooltip/Tooltip.js.map +1 -1
- package/esm/components/Tooltip/use-tooltip.js.map +1 -1
- package/esm/components/TypographyStylesProvider/TypographyStylesProvider.js +57 -0
- package/esm/components/TypographyStylesProvider/TypographyStylesProvider.js.map +1 -0
- package/esm/components/TypographyStylesProvider/TypographyStylesProvider.module.css.js +4 -0
- package/esm/components/TypographyStylesProvider/TypographyStylesProvider.module.css.js.map +1 -0
- package/esm/core/Box/style-props/resolvers/font-size-resolver/font-size-resolver.js +3 -0
- package/esm/core/Box/style-props/resolvers/font-size-resolver/font-size-resolver.js.map +1 -1
- package/esm/core/Box/style-props/resolvers/spacing-resolver/spacing-resolver.js +1 -1
- package/esm/core/Box/style-props/resolvers/spacing-resolver/spacing-resolver.js.map +1 -1
- package/esm/core/MantineProvider/MantineCssVariables/MantineCssVariables.js +15 -8
- package/esm/core/MantineProvider/MantineCssVariables/MantineCssVariables.js.map +1 -1
- package/esm/core/MantineProvider/MantineCssVariables/default-css-variables-resolver.js +1 -0
- package/esm/core/MantineProvider/MantineCssVariables/default-css-variables-resolver.js.map +1 -1
- package/esm/core/MantineProvider/MantineCssVariables/remove-default-variables.js +31 -0
- package/esm/core/MantineProvider/MantineCssVariables/remove-default-variables.js.map +1 -0
- package/esm/core/MantineProvider/MantineProvider.js.map +1 -1
- package/esm/core/MantineProvider/convert-css-variables/convert-css-variables.js +6 -5
- package/esm/core/MantineProvider/convert-css-variables/convert-css-variables.js.map +1 -1
- package/esm/core/MantineProvider/default-theme.js +28 -26
- package/esm/core/MantineProvider/default-theme.js.map +1 -1
- package/esm/core/MantineProvider/use-mantine-color-scheme/use-mantine-color-scheme.js +40 -3
- package/esm/core/MantineProvider/use-mantine-color-scheme/use-mantine-color-scheme.js.map +1 -1
- package/esm/core/utils/units-converters/px.js +21 -10
- package/esm/core/utils/units-converters/px.js.map +1 -1
- package/esm/core/utils/units-converters/rem.js +23 -9
- package/esm/core/utils/units-converters/rem.js.map +1 -1
- package/esm/index.css +1687 -285
- package/esm/index.js +8 -0
- package/esm/index.js.map +1 -1
- package/lib/components/ActionIcon/ActionIcon.d.ts +9 -8
- package/lib/components/ActionIcon/ActionIconGroup/ActionIconGroup.d.ts +3 -3
- package/lib/components/Affix/Affix.d.ts +37 -0
- package/lib/components/Affix/index.d.ts +2 -0
- package/lib/components/Alert/Alert.d.ts +37 -0
- package/lib/components/Alert/index.d.ts +2 -0
- package/lib/components/Anchor/Anchor.d.ts +1 -1
- package/lib/components/AspectRatio/AspectRatio.d.ts +24 -0
- package/lib/components/AspectRatio/index.d.ts +2 -0
- package/lib/components/Avatar/Avatar.d.ts +56 -0
- package/lib/components/Avatar/AvatarGroup/AvatarGroup.context.d.ts +5 -0
- package/lib/components/Avatar/AvatarGroup/AvatarGroup.d.ts +24 -0
- package/lib/components/Avatar/AvatarPlaceholderIcon.d.ts +2 -0
- package/lib/components/Avatar/index.d.ts +3 -0
- package/lib/components/BackgroundImage/BackgroundImage.d.ts +1 -1
- package/lib/components/Badge/Badge.d.ts +47 -0
- package/lib/components/Badge/index.d.ts +2 -0
- package/lib/components/Blockquote/Blockquote.d.ts +2 -2
- package/lib/components/Breadcrumbs/Breadcrumbs.d.ts +2 -2
- package/lib/components/Burger/Burger.d.ts +1 -1
- package/lib/components/Button/Button.d.ts +5 -5
- package/lib/components/Button/ButtonGroup/ButtonGroup.d.ts +1 -1
- package/lib/components/Center/Center.d.ts +2 -2
- package/lib/components/CloseButton/CloseButton.d.ts +1 -1
- package/lib/components/Code/Code.d.ts +2 -2
- package/lib/components/ColorPicker/ColorPicker.d.ts +7 -7
- package/lib/components/ColorSwatch/ColorSwatch.d.ts +5 -4
- package/lib/components/Container/Container.d.ts +1 -1
- package/lib/components/CopyButton/CopyButton.d.ts +1 -1
- package/lib/components/Divider/Divider.d.ts +33 -0
- package/lib/components/Divider/index.d.ts +2 -0
- package/lib/components/FileButton/FileButton.d.ts +3 -3
- package/lib/components/Group/Group.d.ts +1 -1
- package/lib/components/Input/Input.d.ts +10 -10
- package/lib/components/Input/InputWrapper/InputWrapper.d.ts +3 -3
- package/lib/components/Input/use-input-props.d.ts +10 -10
- package/lib/components/Loader/Loader.d.ts +1 -1
- package/lib/components/Overlay/Overlay.d.ts +49 -0
- package/lib/components/Overlay/index.d.ts +2 -0
- package/lib/components/Paper/Paper.d.ts +2 -2
- package/lib/components/Popover/Popover.d.ts +16 -16
- package/lib/components/Popover/use-popover.d.ts +1 -32
- package/lib/components/ScrollArea/ScrollArea.context.d.ts +23 -0
- package/lib/components/ScrollArea/ScrollArea.d.ts +2 -2
- package/lib/components/ScrollArea/ScrollArea.types.d.ts +23 -0
- package/lib/components/ScrollArea/ScrollAreaCorner/ScrollAreaCorner.d.ts +6 -0
- package/lib/components/ScrollArea/ScrollAreaRoot/ScrollAreaRoot.d.ts +30 -0
- package/lib/components/ScrollArea/ScrollAreaScrollbar/ScrollAreaScrollbar.d.ts +7 -0
- package/lib/components/ScrollArea/ScrollAreaScrollbar/ScrollAreaScrollbarAuto.d.ts +6 -0
- package/lib/components/ScrollArea/ScrollAreaScrollbar/ScrollAreaScrollbarHover.d.ts +7 -0
- package/lib/components/ScrollArea/ScrollAreaScrollbar/ScrollAreaScrollbarScroll.d.ts +7 -0
- package/lib/components/ScrollArea/ScrollAreaScrollbar/ScrollAreaScrollbarVisible.d.ts +6 -0
- package/lib/components/ScrollArea/ScrollAreaScrollbar/Scrollbar.context.d.ts +15 -0
- package/lib/components/ScrollArea/ScrollAreaScrollbar/Scrollbar.d.ts +21 -0
- package/lib/components/ScrollArea/ScrollAreaScrollbar/ScrollbarX.d.ts +3 -0
- package/lib/components/ScrollArea/ScrollAreaScrollbar/ScrollbarY.d.ts +3 -0
- package/lib/components/ScrollArea/ScrollAreaThumb/ScrollAreaThumb.d.ts +9 -0
- package/lib/components/ScrollArea/ScrollAreaViewport/ScrollAreaViewport.d.ts +5 -0
- package/lib/components/ScrollArea/use-resize-observer.d.ts +1 -0
- package/lib/components/ScrollArea/utils/add-unlinked-scroll-listener.d.ts +1 -0
- package/lib/components/ScrollArea/utils/compose-event-handlers.d.ts +3 -0
- package/lib/components/ScrollArea/utils/get-scroll-position-from-pointer.d.ts +2 -0
- package/lib/components/ScrollArea/utils/get-thumb-offset-from-scroll.d.ts +2 -0
- package/lib/components/ScrollArea/utils/get-thumb-ratio.d.ts +1 -0
- package/lib/components/ScrollArea/utils/get-thumb-size.d.ts +2 -0
- package/lib/components/ScrollArea/utils/index.d.ts +8 -0
- package/lib/components/ScrollArea/utils/is-scrolling-within-scrollbar-bounds.d.ts +1 -0
- package/lib/components/ScrollArea/utils/linear-scale.d.ts +1 -0
- package/lib/components/ScrollArea/utils/to-int.d.ts +1 -0
- package/lib/components/SegmentedControl/SegmentedControl.d.ts +5 -5
- package/lib/components/Slider/RangeSlider/RangeSlider.d.ts +10 -14
- package/lib/components/Slider/Slider/Slider.d.ts +10 -14
- package/lib/components/Slider/Thumb/Thumb.d.ts +2 -4
- package/lib/components/Stack/Stack.d.ts +1 -1
- package/lib/components/Switch/Switch.d.ts +3 -3
- package/lib/components/Switch/SwitchGroup/SwitchGroup.d.ts +3 -3
- package/lib/components/Table/Table.d.ts +6 -6
- package/lib/components/Tabs/Tabs.d.ts +10 -10
- package/lib/components/Tabs/TabsList/TabsList.d.ts +2 -2
- package/lib/components/Tabs/TabsTab/TabsTab.d.ts +3 -3
- package/lib/components/Text/Text.d.ts +2 -2
- package/lib/components/Tooltip/Tooltip.d.ts +7 -7
- package/lib/components/Tooltip/Tooltip.types.d.ts +2 -2
- package/lib/components/Tooltip/use-tooltip.d.ts +2 -2
- package/lib/components/TypographyStylesProvider/TypographyStylesProvider.d.ts +17 -0
- package/lib/components/TypographyStylesProvider/index.d.ts +2 -0
- package/lib/components/index.d.ts +8 -0
- package/lib/core/MantineProvider/MantineCssVariables/MantineCssVariables.d.ts +1 -1
- package/lib/core/MantineProvider/MantineCssVariables/remove-default-variables.d.ts +2 -0
- package/lib/core/MantineProvider/MantineProvider.d.ts +1 -0
- package/lib/core/MantineProvider/theme.types.d.ts +2 -0
- package/lib/core/MantineProvider/use-mantine-color-scheme/use-mantine-color-scheme.d.ts +3 -2
- package/lib/core/utils/units-converters/px.d.ts +1 -1
- package/lib/core/utils/units-converters/rem.d.ts +2 -2
- package/package.json +3 -5
- 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":"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"}
|
|
@@ -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":";;;;;;;;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;AAMU,MAAC,oBAAoB,GAAG,UAAU,CAAC,CAAC,KAAK,EAAE,YAAY,KAAK;AACxE,EAAE,MAAM,EAAE,GAAG,KAAK,EAAE,EAAE,KAAK,EAAE,aAAa,EAAE,KAAK,EAAE,GAAG,EAAE,EAAE,MAAM,GAAG,SAAS,CAAC,EAAE,EAAE,CAAC,OAAO,EAAE,eAAe,EAAE,OAAO,CAAC,CAAC,CAAC;AACtH,EAAE,MAAM,GAAG,GAAG,oBAAoB,EAAE,CAAC;AACrC,EAAE,MAAM,CAAC,aAAa,EAAE,gBAAgB,CAAC,GAAG,QAAQ,EAAE,CAAC;AACvD,EAAE,MAAM,GAAG,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC;AAC3B,EAAE,MAAM,WAAW,GAAG,YAAY,CAAC,YAAY,EAAE,GAAG,EAAE,GAAG,CAAC,kBAAkB,CAAC,CAAC;AAC9E,EAAE,SAAS,CAAC,MAAM;AAClB,IAAI,IAAI,GAAG,CAAC,OAAO;AACnB,MAAM,gBAAgB,CAAC,gBAAgB,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC;AACtD,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;AACZ,EAAE,uBAAuB,KAAK,CAAC,aAAa,CAAC,SAAS,EAAE,aAAa,CAAC,cAAc,CAAC;AACrF,IAAI,kBAAkB,EAAE,YAAY;AACpC,GAAG,EAAE,MAAM,CAAC,EAAE;AACd,IAAI,GAAG,EAAE,WAAW;AACpB,IAAI,KAAK;AACT,IAAI,KAAK,EAAE,aAAa,CAAC,cAAc,CAAC,EAAE,EAAE,KAAK,CAAC,EAAE;AACpD,MAAM,CAAC,kBAAkB,GAAG,CAAC,EAAE,YAAY,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC;AACtD,KAAK,CAAC;AACN,IAAI,kBAAkB,EAAE,CAAC,UAAU,KAAK,KAAK,CAAC,kBAAkB,CAAC,UAAU,CAAC,CAAC,CAAC;AAC9E,IAAI,YAAY,EAAE,CAAC,UAAU,KAAK,KAAK,CAAC,YAAY,CAAC,UAAU,CAAC,CAAC,CAAC;AAClE,IAAI,aAAa,EAAE,CAAC,KAAK,EAAE,YAAY,KAAK;AAC5C,MAAM,IAAI,GAAG,CAAC,QAAQ,EAAE;AACxB,QAAQ,MAAM,SAAS,GAAG,GAAG,CAAC,QAAQ,CAAC,UAAU,GAAG,KAAK,CAAC,MAAM,CAAC;AACjE,QAAQ,KAAK,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC;AACvC,QAAQ,IAAI,gCAAgC,CAAC,SAAS,EAAE,YAAY,CAAC,EAAE;AACvE,UAAU,KAAK,CAAC,cAAc,EAAE,CAAC;AACjC,SAAS;AACT,OAAO;AACP,KAAK;AACL,IAAI,QAAQ,EAAE,MAAM;AACpB,MAAM,IAAI,GAAG,CAAC,OAAO,IAAI,GAAG,CAAC,QAAQ,IAAI,aAAa,EAAE;AACxD,QAAQ,aAAa,CAAC;AACtB,UAAU,OAAO,EAAE,GAAG,CAAC,QAAQ,CAAC,WAAW;AAC3C,UAAU,QAAQ,EAAE,GAAG,CAAC,QAAQ,CAAC,WAAW;AAC5C,UAAU,SAAS,EAAE;AACrB,YAAY,IAAI,EAAE,GAAG,CAAC,OAAO,CAAC,WAAW;AACzC,YAAY,YAAY,EAAE,KAAK,CAAC,aAAa,CAAC,WAAW,CAAC;AAC1D,YAAY,UAAU,EAAE,KAAK,CAAC,aAAa,CAAC,YAAY,CAAC;AACzD,WAAW;AACX,SAAS,CAAC,CAAC;AACX,OAAO;AACP,KAAK;AACL,GAAG,CAAC,CAAC,CAAC;AACN,CAAC;;;;"}
|
|
@@ -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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"}
|