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.
- Framework - Next.js 16
- Language - TypeScript
- Auth - Clerk
- Error tracking - Sentry
- Styling - Tailwind CSS v4
- Components - shadcn/ui
- Charts - Recharts • Evil Charts
- Schema validation - Zod
- Data fetching - TanStack React Query
- State management - Zustand
- Search param state - Nuqs
- Tables - TanStack Data Tables • Dice Table
- Forms - TanStack Form + Zod
- Command+K interface - kbar
- Linter / Formatter - OxLint • Oxfmt
- Pre-commit hooks - Husky
- Themes - tweakcn
Looking for a TanStack Start version? Here's the repo.
- Pre-built dashboard layout with sidebar, header, and content area
- Analytics overview page with cards and charts
- Data tables with React Query prefetch, client-side cache, search, filter, and pagination
- Authentication and user management through Clerk
- Multi-tenant workspaces using Clerk Organizations (create, switch, manage teams)
- Billing and subscriptions via Clerk Billing for B2B, with plan management and feature gating
- Client-side RBAC navigation that filters menu items by organization, permissions, and roles
- Infobar component for tips, status messages, or contextual notes on any page
- shadcn/ui components styled with Tailwind CSS
- Six-plus themes with a theme switcher
- Feature-based folder structure
- A starting point for SaaS dashboards, internal tools, and client admin panels
A few things you can build with it:
- SaaS admin dashboards
- Internal tools and operations panels
- Analytics dashboards
- Client project admin panels
- A boilerplate for new Next.js shadcn projects
| 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 install- Copy the example env file:
cp env.example.txt .env.local - Fill in the required variables in
.env.local bun run dev
See 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:
node scripts/cleanup.js --interactive # interactive mode
node scripts/cleanup.js --list # see available features
node scripts/cleanup.js --dry-run chat # preview before removing
node scripts/cleanup.js kanban chat # remove specific featuresRun node scripts/cleanup.js --help for all options. Delete scripts/cleanup.js when you're done.
The project includes Dockerfiles (Dockerfile for Node.js, Dockerfile.bun for Bun) that use standalone output mode. For other options, see the Next.js deployment docs.
Build the image:
# Node.js
docker build \
--build-arg NEXT_PUBLIC_CLERK_PUBLISHABLE_KEY=pk_live_xxxxx \
-t shadcn-dashboard .
# OR Bun
docker build -f Dockerfile.bun \
--build-arg NEXT_PUBLIC_CLERK_PUBLISHABLE_KEY=pk_live_xxxxx \
-t shadcn-dashboard .Run the container:
docker run -d -p 3000:3000 \
-e NEXT_PUBLIC_CLERK_PUBLISHABLE_KEY=pk_live_xxxxx \
-e CLERK_SECRET_KEY=sk_live_xxxxx \
--restart unless-stopped \
--name shadcn-dashboard \
shadcn-dashboardIf this template saved you some time, a star is appreciated. You can also buy me a coffee if you'd like.
