Skip to content

A Nextjs boilerplate to kickstart your Next.js projects with pre-configured settings and a scalable structure.

License

Notifications You must be signed in to change notification settings

Maliksidk19/nextjs-starter-template

Repository files navigation

Next.js Starter Template

Welcome to the Next.js Starter Template! This repository is a boilerplate to kickstart your Next.js projects with pre-configured settings and a scalable structure. It is best suited for web applications that prioritize performance, scalability, and modern development practices, such as blogs, dashboards, or e-commerce platforms.

Features

This template is packed with features designed to make your development process faster, easier, and more efficient. Here’s what you get:

  • Next.js 15: The latest version with App Router support.
  • ⚛️ React 19: Enjoy the latest features of React for building UIs.
  • 🛠️ TypeScript: Strong typing for improved developer experience.
  • ESLint & Prettier: Pre-configured for linting and code formatting.
  • 🎨 Tailwind CSS: For utility-first, responsive styling.
  • 📁 Absolute Imports: Simplify import paths.
  • 🌗 Light/Dark Theme: Pre-configured theme toggling support.
  • 🧩 Shadcn Component Library: A collection of accessible and customizable UI components.
  • 🔍 Preconfigured SEO: Optimize your site with default SEO settings.
  • 🛡️ Typesafe Environment Variables: Ensure safety and consistency in your environment configuration.

Getting Started

Note on Common Issues

During setup, you may encounter common issues such as:

  • Missing dependencies: Ensure all required dependencies are installed using your preferred package manager.
  • Environment variable errors: Double-check your .env file to ensure all necessary variables are correctly defined.

For troubleshooting, refer to the official Next.js documentation or the Issues tab in this repository for community support.

Follow these steps to get up and running:

Prerequisites

  • 🖥️ Node.js (v16 or higher)
  • 📦 npm, yarn, pnpm, or bun

Installation

  1. 🌀 Clone the repository:

    git clone https://github.com/your-username/nextjs-starter-template.git
    cd nextjs-starter-template
  2. 📥 Install dependencies:

    Select your preferred package manager and run the appropriate command:

    Package Manager Command
    npm npm install
    yarn yarn install
    pnpm pnpm install
    bun bun install
  3. 🚀 Start the development server:

    Package Manager Command
    npm npm run dev
    yarn yarn dev
    pnpm pnpm dev
    bun bun dev
  4. 🌐 Open your browser and navigate to http://localhost:3000.

Project Structure

The project is organized to ensure scalability and maintainable code, especially for larger applications. Each folder has a clear purpose, helping you keep concerns separated and easy to manage as your project grows. Here’s an overview:

├── public           # Static files (images, fonts, etc.)
├── src
│   ├── app
│   │   ├── favicon.ico
│   │   ├── layout.tsx
│   │   └── page.tsx
│   ├── config       # Configuration files
│   │   ├── env.ts
│   │   ├── fonts.ts
│   │   ├── index.ts
│   │   ├── routes.ts
│   │   ├── seo.ts
│   │   └── site.ts
│   ├── context      # Context providers
│   │   └── theme-provider.tsx
│   ├── lib          # Utility functions
│   │   └── utils.ts
│   └── styles       # Global styles
│       └── globals.css
├── .env             # Environment variables
├── .gitignore       # Git ignore file
├── bun.lockb        # Bun lock file
├── components.json  # Component definitions
├── eslint.config.mjs# ESLint configuration
├── next-env.d.ts    # Next.js TypeScript environment
├── next.config.ts   # Next.js configuration
├── package.json     # Package manifest
├── postcss.config.mjs# PostCSS configuration
├── README.md        # Project README
├── tailwind.config.ts# Tailwind CSS configuration
└── tsconfig.json    # TypeScript configuration

Scripts

  • 🛠️ npm run dev: Start the development server.
  • 🏗️ npm run build: Build the application for production.
  • ⚙️ npm run start: Start the production server.
  • 🔍 npm run lint: Run ESLint checks.

Customization

Feel free to modify the template to suit your project needs. Add or remove dependencies, tweak configurations, and extend the structure as required.

Contributing

Contributions are welcome! If you find a bug or have a feature request, please:

  • 🐛 Create an Issue: Navigate to the Issues tab and provide details about the bug or feature.
  • 🌟 Submit a Pull Request: Fork the repository, make your changes, and submit a PR. Ensure your code follows the project conventions and is thoroughly tested.

For more detailed contribution guidelines, check the CONTRIBUTING.md file. are welcome! If you find a bug or have a feature request, please create an issue or submit a pull request.

License

This project is licensed under the MIT License.