Open source admin dashboard starter built with Next.js 16, shadcn/ui, Tailwind CSS, and TypeScript

An open source admin dashboard starter built with Next.js 16, shadcn/ui, TypeScript, and Tailwind CSS.
It ships with authentication, charts, tables, forms, and a feature-based folder structure, so you can skip the boilerplate and start building. It works well as a base for SaaS apps, internal tools, and admin panels.
Looking for a TanStack Start version? Here's the repo.
A few things you can build with it:
| Page | Notes |
|---|---|
| Signup / Signin | Auth handled by Clerk, with passwordless sign-in, social logins, and enterprise SSO. |
| Dashboard Overview | Cards and Recharts graphs. Parallel routes give each section its own loading and error state. |
| Product List (Table) | TanStack Table plus React Query (server prefetch, client cache) with nuqs URL state for search, filter, and pagination. shallow: true keeps interactions on the client. |
| Create Product Form | TanStack Form and Zod with useMutation for create and update. Cache is invalidated on success. |
| Users (Table) | Same setup as Products: React Query with nuqs, server prefetch, and client-side pagination and filtering. |
| React Query Demo | A Pokemon API example showing the server prefetch, HydrationBoundary, and useSuspenseQuery pattern with client-side cache. |
| Profile | Clerk's account management UI for profile and security settings. |
| Kanban Board | Drag-and-drop task board built with dnd-kit and Zustand. Column sorting, priority badges, assignees, and due dates. |
| Chat | Messaging UI with a conversation list, message bubbles, quick replies, attachments, and an auto-reply demo. Multi-panel layout that works on mobile. |
| Notifications | Notification center with a header badge, popover preview, and a full page with All / Unread / Read tabs. Includes mark-as-read and mark-all-as-read. |
| Workspaces | Organization management using Clerk's <OrganizationList />. View, create, and switch between organizations. |
| Team Management | Team management using Clerk's <OrganizationProfile />. Manage members, roles, permissions, security, and org details. Needs an active organization. |
| Billing & Plans | Billing page using Clerk's <PricingTable />. View plans, subscribe, and manage subscriptions. Needs an active organization. |
| Exclusive Page | Plan-based access control with Clerk's <Protect>. Only available to organizations on the Pro plan, with a fallback UI for everyone else. |
| Not Found | A root-level not-found page. |
| Global Error | A shared error page wired to Sentry for logging, reports, and session replay. |
src/
├── app/ # Next.js App Router directory
│ ├── auth/ # Auth pages (sign-in, sign-up)
│ ├── dashboard/ # Dashboard route group
│ │ ├── overview/ # Analytics with parallel routes
│ │ ├── product/ # Product CRUD pages (React Query)
│ │ ├── users/ # Users table (React Query + nuqs)
│ │ ├── react-query/ # React Query demo page
│ │ ├── kanban/ # Task board page
│ │ ├── chat/ # Messaging page
│ │ ├── notifications/ # Notifications page
│ │ ├── workspaces/ # Org management & teams
│ │ ├── billing/ # Billing & plans
│ │ ├── profile/ # User profile
│ │ └── exclusive/ # Plan-gated page
│ └── api/ # API routes
│
├── components/ # Shared components
│ ├── ui/ # UI primitives (buttons, inputs, kanban, etc.)
│ ├── layout/ # Layout components (header, sidebar, etc.)
│ ├── themes/ # Theme system (selector, mode toggle, config)
│ └── kbar/ # Command+K interface
│
├── features/ # Feature-based modules
│ ├── overview/ # Dashboard analytics (charts, cards)
│ ├── products/ # Product listing, form, tables (React Query)
│ ├── users/ # User management table (React Query)
│ ├── react-query-demo/ # React Query demo (Pokemon API)
│ ├── kanban/ # Drag-drop task board
│ ├── chat/ # Messaging (conversations, bubbles, composer)
│ ├── notifications/ # Notification center & store
│ ├── auth/ # Auth components
│ └── profile/ # Profile form schemas
│
├── lib/ # Core utilities (query-client, searchparams, etc.)
├── hooks/ # Custom hooks
├── config/ # Navigation, infobar, data table config
├── constants/ # Mock data
├── styles/ # Global CSS & theme files
│ └── themes/ # Individual theme CSS files
└── types/ # TypeScript types
[!NOTE] This starter uses Next.js 16 (App Router) with React 19 and shadcn/ui. To run it locally:
Clone the repo:
git clone https://github.com/Kiranism/next-shadcn-dashboard-starter.git
bun installcp env.example.txt .env.local.env.localbun run devSee env.example.txt for the variables you need. They cover authentication and error tracking.
For setting up Clerk auth (including organizations, workspaces, and teams), see clerk_setup.md.
The app should now be running at http://localhost:3000.
[!WARNING] After cloning or forking, be careful when pulling the latest changes. Updates can cause merge conflicts.
To strip out features you don't need (auth, kanban, chat, notifications, extra themes, Sentry), run the cleanup script:
```bash node scripts/cleanup.js --interactive # interactive mode node scripts/cleanup.js --list # see available features node scripts/cleanup.js --dry-run chat # preview before r
$ claude mcp add next-shadcn-dashboard-starter \
-- python -m otcore.mcp_server <graph>