Docs
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

Installation

npx dukc-ui@latest add scroll-area
npx dukc-ui@latest add scroll-area

Usage

import { ScrollArea } from "@/components/ui/scroll-area"
import { ScrollArea } from "@/components/ui/scroll-area"
<ScrollArea className="h-[200px] w-[350px] rounded-md border p-4">
  Jokester began sneaking into the castle in the middle of the night and leaving
  jokes all over the place: under the king's pillow, in his soup, even in the
  royal toilet. The king was furious, but he couldn't seem to stop Jokester. And
  then, one day, the people of the kingdom discovered that the jokes left by
  Jokester were so funny that they couldn't help but laugh. And once they
  started laughing, they couldn't stop.
</ScrollArea>
<ScrollArea className="h-[200px] w-[350px] rounded-md border p-4">
  Jokester began sneaking into the castle in the middle of the night and leaving
  jokes all over the place: under the king's pillow, in his soup, even in the
  royal toilet. The king was furious, but he couldn't seem to stop Jokester. And
  then, one day, the people of the kingdom discovered that the jokes left by
  Jokester were so funny that they couldn't help but laugh. And once they
  started laughing, they couldn't stop.
</ScrollArea>

Examples

Horizontal Scrolling

Photo by Lina Escobar
Photo by Lina Escobar
Photo by Marco Duvall
Photo by Marco Duvall
Photo by Sahana Ramesh
Photo by Sahana Ramesh

API Reference

ScrollArea

  • alwaysVisible (boolean, optional, default: false`): Whether the scrollbars should always be visible or only appear when scrolling.
  • viewportClassName (string, optional): Additional CSS classes to apply to the scroll viewport container.
  • orientation ('vertical' | 'horizontal' | 'both', optional, default: 'vertical'): Controls which scrollbars are shown and tracked: vertical, horizontal, or both.
  • ...props (React.HTMLAttributes<HTMLDivElement>): Other native props forwarded to the outer container <div>.

Behavior

  • Custom scroll area wrapper with fully controlled scrollbars.
  • Supports vertical, horizontal, or both directions.
  • Scrollbar thumbs update dynamically on scroll and resize.
  • Supports dragging the scrollbar thumbs to scroll content.
  • Scrollbar tracks respond to clicks to jump to a scroll position.
  • Scrollbars fade in on hover or stay always visible if alwaysVisible is set.
  • Uses internal refs to manage DOM nodes and positioning logic.
  • Handles accessibility by forwarding native div props.