Skip to content

Kiranism/next-shadcn-dashboard-starter

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

292 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Admin Dashboard Template with Next.js & Shadcn UI

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


Shadcn Dashboard Cover

GitHub stars Forks MIT License Next.js Sponsored by Clerk

Overview

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.

Tech Stack

Looking for a TanStack Start version? Here's the repo.

Features

  • 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

Use Cases

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

Pages

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.

Folder Structure

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

Getting Started

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
Environment variables

See env.example.txt for the variables you need. They cover authentication and error tracking.

Clerk setup

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.


Cleanup

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 features

Run node scripts/cleanup.js --help for all options. Delete scripts/cleanup.js when you're done.

Deploy

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.

Docker

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-dashboard

Support

If this template saved you some time, a star is appreciated. You can also buy me a coffee if you'd like.

Buy Me A Coffee


Star History

Star History Chart

About

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

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Sponsor this project

Packages