Blips
Documentação

Scroll Area

Aprimora a funcionalidade nativa de rolagem para estilização personalizada e compatível entre navegadores.

Carregando…
"use client";

import { ScrollArea } from "@blips/ui/components/scroll-area";
import { Separator } from "@blips/ui/components/separator";

export default function ScrollAreaDemo() {
  const tags = Array.from({ length: 50 }).map((_, i) => `v1.2.0-beta.${i}`);

  return (
    <ScrollArea className="h-72 w-48 rounded-md border">
      <div className="p-4">
        <h4 className="mb-4 text-sm font-medium leading-none">Tags</h4>
        {tags.map((tag) => (
          <div key={tag}>
            <div className="text-sm">{tag}</div>
            <Separator className="my-2" />
          </div>
        ))}
      </div>
    </ScrollArea>
  );
}

Instalação

pnpm add @blips/ui

Uso

import { ScrollArea } from "@blips/ui/components/scroll-area"
<ScrollArea className="h-[200px] w-[350px] rounded-md border p-4">
  Seu conteúdo rolável aqui.
</ScrollArea>

Exemplos

Horizontal

Use ScrollBar com orientation="horizontal" para rolagem horizontal.

Carregando…
import { ScrollArea, ScrollBar } from "@blips/ui/components/scroll-area";
import Image from "next/image";
import * as React from "react";

export interface Artwork {
  artist: string;
  art: string;
}

export const works: Artwork[] = [
  {
    artist: "Ornella Binni",
    art: "https://images.unsplash.com/photo-1465869185982-5a1a7522cbcb?auto=format&fit=crop&w=300&q=80",
  },
  {
    artist: "Tom Byrom",
    art: "https://images.unsplash.com/photo-1548516173-3cabfa4607e9?auto=format&fit=crop&w=300&q=80",
  },
  {
    artist: "Vladimir Malyavko",
    art: "https://images.unsplash.com/photo-1494337480532-3725c85fd2ab?auto=format&fit=crop&w=300&q=80",
  },
];

export default function ScrollAreaHorizontalDemo() {
  return (
    <ScrollArea className="w-96 rounded-md border whitespace-nowrap">
      <div className="flex w-max space-x-4 p-4">
        {works.map((artwork) => (
          <figure key={artwork.artist} className="shrink-0">
            <div className="overflow-hidden rounded-md">
              <Image
                src={artwork.art}
                alt={`Photo by ${artwork.artist}`}
                className="aspect-[3/4] h-fit w-fit object-cover"
                width={300}
                height={400}
              />
            </div>
            <figcaption className="pt-2 text-xs text-muted-foreground">
              Photo by{" "}
              <span className="font-semibold text-foreground">
                {artwork.artist}
              </span>
            </figcaption>
          </figure>
        ))}
      </div>
      <ScrollBar orientation="horizontal" />
    </ScrollArea>
  );
}

Referência da API

Consulte a documentação do Radix UI Scroll Area.