Tech| 읽는 데 5분

반응형 사이드바 구현하기

Next.js 프로젝트에서 shadcn/ui를 사용해서 반응형 사이드바를 구현하는 방법

#TailwindCSS#shadcn/ui
목차

개요

Next.js 프로젝트에서 shadcn/ui를 사용해서, 반응형 사이드바를 쉽게 구현할 수 있다.

구현 방법

dashboard-02의 코드를 베이스로 구현하려고 한다.

※ 해당 컴포넌트에 대한 전체 코드: dashboard-02

  1. 패키지 설치

    • 먼저, shadcn/ui를 설치한다.
    install shadcn/ui
    npx shadcn-ui@latest init
  2. 코드 복사

    • copy code버튼을 클릭해서, dashboard-02의 코드를 가져와서 app/page.tsx에 붙여넣어 준다.
  3. 컴포넌트 추가

    • 아직 컴포넌트가 없으므로 오류가 생길 것이다. 아래 명령어로 컴포넌트를 추가한다.
    add components
    npx shadcn-ui@latest add badge button card dropdown-menu input sheet
  4. 컴포넌트 분리

    • mobile navigation에 해당하는 부분을 components/uimobile-nav.tsx 파일을 생성해서 옮겨준다.
    mobile-nav.tsx
    import Link from 'next/link';
    import {
      Menu,
      Package2,
      Home,
      ShoppingCart,
      Package,
      Users,
      LineChart,
    } from 'lucide-react';
    import { Button } from './button';
    import {
      Card,
      CardHeader,
      CardTitle,
      CardDescription,
      CardContent,
    } from './card';
    import { Sheet, SheetTrigger, SheetContent } from './sheet';
    import { Badge } from './badge';
     
    export default function MobileNav() {
      return (
        <Sheet>
          <SheetTrigger asChild>
            <Button variant="outline" size="icon" className="shrink-0 md:hidden">
              <Menu className="h-5 w-5" />
              <span className="sr-only">Toggle navigation menu</span>
            </Button>
          </SheetTrigger>
          <SheetContent side="left" className="flex flex-col">
            <nav className="grid gap-2 text-lg font-medium">
              <Link
                href="#"
                className="flex items-center gap-2 text-lg font-semibold"
              >
                <Package2 className="h-6 w-6" />
                <span className="sr-only">Acme Inc</span>
              </Link>
              <Link
                href="#"
                className="text-muted-foreground hover:text-foreground mx-[-0.65rem] flex items-center gap-4 rounded-xl px-3 py-2"
              >
                <Home className="h-5 w-5" />
                Dashboard
              </Link>
              <Link
                href="#"
                className="bg-muted text-foreground hover:text-foreground mx-[-0.65rem] flex items-center gap-4 rounded-xl px-3 py-2"
              >
                <ShoppingCart className="h-5 w-5" />
                Orders
                <Badge className="ml-auto flex h-6 w-6 shrink-0 items-center justify-center rounded-full">
                  6
                </Badge>
              </Link>
              <Link
                href="#"
                className="text-muted-foreground hover:text-foreground mx-[-0.65rem] flex items-center gap-4 rounded-xl px-3 py-2"
              >
                <Package className="h-5 w-5" />
                Products
              </Link>
              <Link
                href="#"
                className="text-muted-foreground hover:text-foreground mx-[-0.65rem] flex items-center gap-4 rounded-xl px-3 py-2"
              >
                <Users className="h-5 w-5" />
                Customers
              </Link>
              <Link
                href="#"
                className="text-muted-foreground hover:text-foreground mx-[-0.65rem] flex items-center gap-4 rounded-xl px-3 py-2"
              >
                <LineChart className="h-5 w-5" />
                Analytics
              </Link>
            </nav>
            <div className="mt-auto">
              <Card>
                <CardHeader>
                  <CardTitle>Upgrade to Pro</CardTitle>
                  <CardDescription>
                    Unlock all features and get unlimited access to our support
                    team.
                  </CardDescription>
                </CardHeader>
                <CardContent>
                  <Button size="sm" className="w-full">
                    Upgrade
                  </Button>
                </CardContent>
              </Card>
            </div>
          </SheetContent>
        </Sheet>
      );
    }
  1. 코드 정리

구현 결과

아래 링크를 통해 정리된 소스 코드의 완성본을 확인할 수 있다.

완성된 소스 코드


참고: Youtube Link