- Docs
- components
- Scroll Area
Scroll Area
Augments native scroll functionality for custom, cross-browser styling.
Tags
v1.2.0-beta.50
v1.2.0-beta.49
v1.2.0-beta.48
v1.2.0-beta.47
v1.2.0-beta.46
v1.2.0-beta.45
v1.2.0-beta.44
v1.2.0-beta.43
v1.2.0-beta.42
v1.2.0-beta.41
v1.2.0-beta.40
v1.2.0-beta.39
v1.2.0-beta.38
v1.2.0-beta.37
v1.2.0-beta.36
v1.2.0-beta.35
v1.2.0-beta.34
v1.2.0-beta.33
v1.2.0-beta.32
v1.2.0-beta.31
v1.2.0-beta.30
v1.2.0-beta.29
v1.2.0-beta.28
v1.2.0-beta.27
v1.2.0-beta.26
v1.2.0-beta.25
v1.2.0-beta.24
v1.2.0-beta.23
v1.2.0-beta.22
v1.2.0-beta.21
v1.2.0-beta.20
v1.2.0-beta.19
v1.2.0-beta.18
v1.2.0-beta.17
v1.2.0-beta.16
v1.2.0-beta.15
v1.2.0-beta.14
v1.2.0-beta.13
v1.2.0-beta.12
v1.2.0-beta.11
v1.2.0-beta.10
v1.2.0-beta.9
v1.2.0-beta.8
v1.2.0-beta.7
v1.2.0-beta.6
v1.2.0-beta.5
v1.2.0-beta.4
v1.2.0-beta.3
v1.2.0-beta.2
v1.2.0-beta.1
Copy and paste the following code into your project.
"use client";
import { Root, Scrollbar, Thumb, Viewport } from "@radix-ui/react-scroll-area";
import { ScrollAreaStyles } from "./styles";
export interface ScrollAreaRootProps
extends React.ComponentProps<typeof Root> {}
export function ScrollAreaRoot({ className, ...props }: ScrollAreaRootProps) {
return <Root {...props} className={ScrollAreaStyles.Root({ className })} />;
}
export interface ScrollAreaViewportProps
extends React.ComponentProps<typeof Viewport> {}
export function ScrollAreaViewport({
className,
...props
}: ScrollAreaViewportProps) {
return (
<Viewport {...props} className={ScrollAreaStyles.Viewport({ className })} />
);
}
export interface ScrollAreaScrollbarProps
extends React.ComponentProps<typeof Scrollbar> {
orientation: "vertical" | "horizontal";
}
export function ScrollAreaScrollbar({
className,
orientation,
...props
}: ScrollAreaScrollbarProps) {
return (
<Scrollbar
{...props}
orientation={orientation}
className={ScrollAreaStyles.Scrollbar({ className, orientation })}
/>
);
}
export interface ScrollAreaThumbProps
extends React.ComponentProps<typeof Thumb> {}
export function ScrollAreaThumb({ className, ...props }: ScrollAreaThumbProps) {
return <Thumb {...props} className={ScrollAreaStyles.Thumb({ className })} />;
}
Update the import paths to match your project setup.
import { ScrollArea } from "~/components/ui/scroll-area";
<ScrollArea.Root>
<ScrollArea.Viewport>...</ScrollArea.Viewport>
<ScrollArea.Scrollbar orientation="vertical">
<ScrollArea.Thumb />
</ScrollArea.Scrollbar>
<ScrollArea.Scrollbar orientation="horizontal">
<ScrollArea.Thumb />
</ScrollArea.Scrollbar>
</ScrollArea.Root>
import {
ScrollAreaRoot,
ScrollAreaViewport,
ScrollAreaScrollbar,
ScrollAreaThumb,
} from "~/components/ui/scroll-area";
<ScrollAreaRoot>
<ScrollAreaViewport>...</ScrollAreaViewport>
<ScrollAreaScrollbar orientation="vertical">
<ScrollAreaThumb />
</ScrollAreaScrollbar>
<ScrollAreaScrollbar orientation="horizontal">
<ScrollAreaThumb />
</ScrollAreaScrollbar>
</ScrollAreaRoot>
Tags
v1.2.0-beta.50
v1.2.0-beta.49
v1.2.0-beta.48
v1.2.0-beta.47
v1.2.0-beta.46
v1.2.0-beta.45
v1.2.0-beta.44
v1.2.0-beta.43
v1.2.0-beta.42
v1.2.0-beta.41
v1.2.0-beta.40
v1.2.0-beta.39
v1.2.0-beta.38
v1.2.0-beta.37
v1.2.0-beta.36
v1.2.0-beta.35
v1.2.0-beta.34
v1.2.0-beta.33
v1.2.0-beta.32
v1.2.0-beta.31
v1.2.0-beta.30
v1.2.0-beta.29
v1.2.0-beta.28
v1.2.0-beta.27
v1.2.0-beta.26
v1.2.0-beta.25
v1.2.0-beta.24
v1.2.0-beta.23
v1.2.0-beta.22
v1.2.0-beta.21
v1.2.0-beta.20
v1.2.0-beta.19
v1.2.0-beta.18
v1.2.0-beta.17
v1.2.0-beta.16
v1.2.0-beta.15
v1.2.0-beta.14
v1.2.0-beta.13
v1.2.0-beta.12
v1.2.0-beta.11
v1.2.0-beta.10
v1.2.0-beta.9
v1.2.0-beta.8
v1.2.0-beta.7
v1.2.0-beta.6
v1.2.0-beta.5
v1.2.0-beta.4
v1.2.0-beta.3
v1.2.0-beta.2
v1.2.0-beta.1
Photo by Ornella BinniPhoto by Tom ByromPhoto by Vladimir Malyavko
Prop | Type | Default |
---|
| boolean
| false |
| | "hover" |
| number
| 600 |
| | |
| string
| |
The viewport area of the scroll area.
Prop | Type | Default |
---|
| boolean
| false |
The vertical scrollbar. Add a second Scrollbar
with an orientation
prop to enable horizontal scrolling.
Prop | Type | Default |
---|
| boolean
| false |
| boolean
| |
| | vertical |