Uecko_ERP/packages/shadcn-ui/src/components/scroll-area.tsx

54 lines
1.7 KiB
TypeScript
Raw Normal View History

2025-05-05 17:11:44 +00:00
import * as React from "react"
2026-03-17 09:24:39 +00:00
import { ScrollArea as ScrollAreaPrimitive } from "radix-ui"
2025-05-05 17:11:44 +00:00
import { cn } from "@repo/shadcn-ui/lib/utils"
function ScrollArea({
className,
children,
...props
}: React.ComponentProps<typeof ScrollAreaPrimitive.Root>) {
return (
<ScrollAreaPrimitive.Root
data-slot="scroll-area"
className={cn("relative", className)}
{...props}
>
<ScrollAreaPrimitive.Viewport
data-slot="scroll-area-viewport"
2026-03-17 17:49:54 +00:00
className="size-full rounded-[inherit] transition-[color,box-shadow] outline-none focus-visible:ring-[3px] focus-visible:ring-ring/50 focus-visible:outline-1"
2025-05-05 17:11:44 +00:00
>
{children}
</ScrollAreaPrimitive.Viewport>
<ScrollBar />
<ScrollAreaPrimitive.Corner />
</ScrollAreaPrimitive.Root>
)
}
function ScrollBar({
className,
orientation = "vertical",
...props
}: React.ComponentProps<typeof ScrollAreaPrimitive.ScrollAreaScrollbar>) {
return (
<ScrollAreaPrimitive.ScrollAreaScrollbar
data-slot="scroll-area-scrollbar"
2026-03-17 17:49:54 +00:00
data-orientation={orientation}
2025-05-05 17:11:44 +00:00
orientation={orientation}
className={cn(
2026-03-17 17:49:54 +00:00
"flex touch-none p-px transition-colors select-none data-horizontal:h-2.5 data-horizontal:flex-col data-horizontal:border-t data-horizontal:border-t-transparent data-vertical:h-full data-vertical:w-2.5 data-vertical:border-l data-vertical:border-l-transparent",
2025-05-05 17:11:44 +00:00
className
)}
{...props}
>
<ScrollAreaPrimitive.ScrollAreaThumb
data-slot="scroll-area-thumb"
2026-03-17 17:49:54 +00:00
className="relative flex-1 rounded-full bg-border"
2025-05-05 17:11:44 +00:00
/>
</ScrollAreaPrimitive.ScrollAreaScrollbar>
)
}
export { ScrollArea, ScrollBar }