Next.js + Tailwind CSS + HOC Auth + TypeScript Starter and Boilerplate with Realtime Chat & Notification
🔋 ts-nextjs-tailwind-hoc-starter
Next.js + Tailwind CSS + TypeScript starter packed with useful development features.
Made by Ryan Fernaldy
Features
This repository is 🔋 battery packed with:
- ⚡️ Next.js 14 with App Router
- ⚛️ React 18
- ✨ TypeScript
- 💨 Tailwind CSS 3 — Configured with CSS Variables to extend the primary color
- 💎 Pre-built Components — Components that will automatically adapt with your brand color, check here for the demo
- 🃏 Jest — Configured for unit testing
- 📈 Absolute Import and Path Alias — Import components using
@/
prefix
- 📏 ESLint — Find and fix problems in your code, also will auto sort your imports
- 💖 Prettier — Format your code consistently
- 🐶 Husky & Lint Staged — Run scripts on your staged files before they are committed
- 🤖 Conventional Commit Lint — Make sure you & your teammates follow conventional commit
- ⏰ Release Please — Generate your changelog by activating the
release-please
workflow
- 👷 Github Actions — Lint your code on PR
- 🚘 Automatic Branch and Issue Autolink — Branch will be automatically created on issue assign, and auto linked on PR
- 🔥 Snippets — A collection of useful snippets
- 👀 Open Graph Helper Function — Awesome open graph generated using og, fork it and deploy!
- 🗺 Site Map — Automatically generate sitemap.xml
- 📦 Expansion Pack — Easily install common libraries, additional components, and configs.
- 📃 Pagination — Built-in pagination table and card components using @tanstack/react-table.
- 📡 Socket.io — Websocket with authentication and realtime notifications
- ☁️ Chat — Implement a robust real-time chat feature using Socket.io, allowing seamless communication between users.
See the 👉 feature details and changelog 👈 for more.
You can also check all of the details and demos on my blog post:
Getting Started
1. Clone this template using one of the three ways
Use this repository as template
Disclosure: by using this repository as a template, there will be an attribution on your repository.
I'll appreciate if you do, so this template can be known by others too 😄

Using create-next-app
npx create-next-app -e https://github.com:ryanf10/ts-nextjs-tailwind-hoc-starter.git project-name
2. Install dependencies
It is encouraged to use yarn so the husky hooks can work properly.
yarn install
3. Backend Dependencies
This starter is using Backend Project (NestJS JWT Authentication and Authorization using MongoDB + Realtime Chat & Notifications using WebSocket).
4. Run the development server
You can start the server using this command:
yarn dev
Open http://localhost:3001 with your browser to see the result. You can start editing the page by modifying app/page.tsx
.
5. Change defaults
There are some things you need to change including title, urls, favicons, etc.
Find all comments with !STARTERCONF, then follow the guide.
Don't forget to change the package name in package.json
6. Commit Message Convention
This starter is using conventional commits, it is mandatory to use it to commit changes.
Special Credits 😃