Skip to content

next-dev-team/nextjs-biolerplate

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 

History

22 Commits
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

Next-Plate

results build

πŸ¦Έβ€β™€οΈ A super template for Next.js you will fast to delivery your projects with fully SEO, hybrid SSG, SSR and bundle size if small

πŸš€ Demo β†’

Deploy your own copy of this template in just a few clicks!

πŸ“– Introduction

This is a complete template with all you need for your next React projects and all the best practices of JAMStack.

This template have a bunch of folders, code examples and configurations. Feel free to edit or remove them, including this README!

Customize and enjoy!

🌟 Features

This project features all the latest tools and good practices in web development!

Framework

  • βš›οΈ Next.js – A complete React framework for hybrid and server rendering

  • On Demand unplug autoimport & icons

Data Fetching

  • πŸ”„ Axios – Promise based HTTP client for the browser and Node.js

State Management

  • 🐻 Rematch js – A small, fast and scalable state-management less than 2 kilobytes.

Design System and Animations

  • 🎨 Tailwind Css – A simple, modular and accessible component library that gives you the building blocks to build your React applications
  • 🎞️ Framer Motion – A production-ready motion library for React
  • ✨ React Icons – A collection of popular icons to React projects

Design Patterns

  • β›” ESLint – Find and fix problems in your JavaScript code
  • πŸŽ€ Prettier – An opinionated code formatter, supporting multiple languages and code editors
  • 🐺 Husky – Modern native Git hooks made easy
  • πŸ’© lint-staged – Run linters against staged git files and don't let πŸ’© slip into your code base
  • πŸ““ commitlint – Helps your team adhering to a commit convention
  • 🏷️ Standard Version – A utility for versioning using semver and CHANGELOG generation powered by Conventional Commits

Analysis

  • πŸ•΅πŸ»β€β™‚οΈ why-did-you-render (optional) – Notify you about potentially avoidable re-renders

Additional Plugins

  • πŸ“ˆ next-seo – A plugin that makes managing your SEO easier in Next.js projects
  • πŸ€– next-sitemap – Sitemap generator for Next.js

▢️ Getting Started

πŸ“™ Creating a New Repository on GitHub

  1. Click on "Use this template" button
  2. Configure your new repository and click on "Create repository from template" button
  3. Now you can clone the generated repository to your local machine:
 $ git clone https://github.com/<YOUR-GITHUB-LOGIN>/<NAME-OF-YOUR-GENERATED-REPOSITORY>.git

πŸ› οΈ Installation

Before you can start developing your super application, you need to install the project's dependencies.

Move yourself to the root of the project:

$ cd <NAME-OF-YOUR-GENERATED-REPOSITORY>

For the next steps, choose a package manager of your choice and change the commands contained in the package.json scripts. See their documentation for more information:

Install all dependencies of the project:

# PNPM
$ pnpm install
# NPM
$ npm install
# Yarn
$ yarn install

⌨️ Development

Once all dependencies have been installed, you can run the local development server:

# PNPM
$ pnpm run dev
# NPM
$ npm run dev
# Yarn
$ yarn dev

Now just code!

πŸ–₯️ Production

After applying the changes, you can generate a build to test and/or deploy to your production environment.

Make a production build:

# PNPM
$ pnpm run build
# NPM
$ npm run build
# Yarn
$ yarn build

And then run the build:

# PNPM
$ pnpm start
# NPM
$ npm start
# Yarn
$ yarn start
View more commands you can use

Lint

# PNPM
$ pnpm run lint
# NPM
$ npm run lint
# Yarn
$ yarn lint

Lint and Fix

# PNPM
$ pnpm run lint:fix
# NPM
$ npm run lint:fix
# Yarn
$ yarn lint:fix

Type Checking

# PNPM
$ pnpm run type-check
# NPM
$ npm run type-check
# Yarn
$ yarn type-check

Format

# PNPM
$ pnpm run format
# NPM
$ npm run format
# Yarn
$ yarn format

Interactive Update Tool

# PNPM
$ pnpm run up
# NPM
$ npm run up
# Yarn
$ yarn up

Update All Dependencies

# PNPM
$ pnpm run up-latest
# NPM
$ npm run up-latest
# Yarn
$ yarn up-latest

Release As Major Version

# PNPM
$ pnpm run release-as-major
# NPM
$ npm run release-as-major
# Yarn
$ yarn release-as-major

Release As Minor Version

# PNPM
$ pnpm run release-as-minor
# NPM
$ npm run release-as-minor
# Yarn
$ yarn release-as-minor

Release As Patch Version

# PNPM
$ pnpm run release-as-patch
# NPM
$ npm run release-as-patch
# Yarn
$ yarn release-as-patch

Publish Release

# PNPM
$ pnpm run push-release
# NPM
$ npm run push-release
# Yarn
$ yarn push-release

Get Updates From Remote and Maintain Current Changes

# PNPM
$ pnpm run pull
# NPM
$ npm run pull
# Yarn
$ yarn pull

βš™οΈ Extra Configurations

Why Did You Render

How to Activate

Put the babel.config.js file (located in the path src/scripts) in the project root and delete .babelrc file.

Uncomment the wdyr import line on pages/_app.tsx.

That's it! Now you can monitore React re-renders!

How to Uninstall

Just delete the babel.config.js and wdyr.ts files, remove wdyr import line on pages/_app.tsx and uninstall it:

# PNPM
$ pnpm uninstall @welldone-software/why-did-you-render
# NPM
$ npm uninstall @welldone-software/why-did-you-render
# Yarn
$ yarn remove @welldone-software/why-did-you-render

πŸ“ File Tree

See below the file tree to understand the project structure.

View file tree

Folders and files marked with (**) are optional, so you can delete then.

πŸ“‚ next-plate/
┣ πŸ“‚ .github/                   # GitHub's folder configs **
┣ πŸ“‚ .husky/                    # Husky's folder
┃ ┣ πŸ“ƒ commit-msg               # Commitlint git hook
┃ β”— πŸ“ƒ pre-commit               # Lint-staged git hook
┣ πŸ“‚ .vscode/                   # VSCode's workspace **
┣ πŸ“‚ public/                    # Public folder
┃ ┣ πŸ“‚ static/                  # Static files folder **
┃ ┃ ┣ πŸ“‚ icons/                 # Icons folder **
┃ ┃ ┣ πŸ“‚ images/                # Images folder **
┃ ┃ ┣ πŸ“‚ sounds/                # Sounds folder **
┃ ┃ β”— πŸ“‚ videos/                # Videos folder **
┃ ┣ πŸ“‚ docs/                    # Documentation folder **
┃ ┃ ┣ πŸ“‚ demo/                  # Demonstrations project **
┃ ┃ β”— πŸ“‚ translations/          # Translations folder **
┃ ┣ πŸ“ƒ favicon.ico              # Icon tab browser
┃ ┣ πŸ“ƒ site.webmanifest         # PWA config
┣ πŸ“‚ src/
┃ ┣ πŸ“‚ animations/              # Framer Motion Animations **
┃ ┣ πŸ“‚ components/              # App Components
┃ ┃ β”— πŸ“‚ Motion/                # Chakra + Framer components **
┃ ┣ πŸ“‚ hooks/                   # React Hooks **
┃ ┃ β”— πŸ“ƒ useFetch.ts            # SWR fetch hook (optional) **
┃ ┣ πŸ“‚ pages/                   # App pages
┃ ┣ πŸ“‚ scripts/                 # Additional scripts **
┃ ┃ ┣ πŸ“ƒ babel.config.js        # Babel config with WDYR **
┃ ┃ β”— πŸ“ƒ wdyr.ts                # WDYR file **
┃ ┣ πŸ“‚ stores/                  # stores
┃ ┣ πŸ“‚ styles/                  # Styles folder
┃ ┃ ┣ πŸ“ƒ bgImages.ts            # SVG background images **
┃ ┃ β”— πŸ“ƒ theme.ts               # Chakra-UI theme
┃ β”— πŸ“‚ utils/                   # Useful functions **
┣ πŸ“ƒ .babelrc                   # Default Babel config
┣ πŸ“ƒ .editorconfig              # Editor config
┣ πŸ“ƒ .eslintignore              # ESLint ignore
┣ πŸ“ƒ .eslintrc                  # ESLint config
┣ πŸ“ƒ .gitignore                 # Git ignore
┣ πŸ“ƒ .versionrc                 # Versioning config
┣ πŸ“ƒ .commitlintrc              # Commitlint config
┣ πŸ“ƒ LICENSE                    # License of the project
┣ πŸ“ƒ next-env.d.ts              # Next.js types to TypeScript
┣ πŸ“ƒ next-seo.config.js         # Next-SEO config
┣ πŸ“ƒ next-sitemap.config.js     # Next-Sitemap config
┣ πŸ“ƒ next.config.js             # Next.js config
┣ πŸ“ƒ .prettierrc                # Prettier config
┣ πŸ“ƒ README.md                  # Main README
┣ πŸ“ƒ tsconfig.json              # TypeScript config

This project is licensed under the MIT License - see the LICENSE page for details.


⭐ Give a star to maintain this project!

❀️ Thanks for your attention!