Clerk Blocks

user-dropdown-2

Another user dropdown best used in a sidebar.

Installation

npx shadcn@latest add https://shadcn-ui-clerk-blocks.vercel.app/r/user-dropdown-2.json

Usage

Basic

import UserDropdown2 from "@/components/user-dropdown-2";
<UserDropdown2 />

With Manual Fetching

Server

page.tsx
import UserDropdown2 from "@/components/user-dropdown-2";
import { formatUser } from "@/lib/format-user";
import { currentUser } from "@clerk/nextjs/server";

export default async function Page() {
  const user = await currentUser();

  if (!user) return;

  return <UserDropdown2 user={formatUser(user)} />;
}

Client

page.tsx
"use client";

import UserDropdown2 from "@/components/user-dropdown-2";
import { useUser } from "@clerk/nextjs";

import { Spinner } from "@/components/ui/spinner";

export default function Page() {
  const { user, isLoaded } = useUser();

  if (!isLoaded) {
    return <Spinner />;
  }

  if (!user) return;

  return <UserDropdown2 user={user} />;
}

Props

Prop

Type