This repository is built to provide a ready-to-go template for the projects that are using the following tech stacks:
- NextJS
- Tailwind
- Storybook
- Jest
- React Testing Library
- Eslint
- Prettier
This template will provide the full setup under the hood and will save a big portion of your time. You have to just create your new repo using this template.
- nextjs-tailwind-storybook-with-ci-cd
- Table of Contents
- How to Create Repository Using This Template?
- Package Versions
- Available Commands
- Folder Structure
- Change NextJS Config
- Change Tailwind Config
- Change Unit Test Config
- Change Eslint Config
- Change Eslint Config
- Change Storybook Config
- CI/CD in This App
- Storybook doesn't Support Some NextJS Features
- License
- Deployment Guideline
- Click on this link to generate a new repo using this template.
- Give a name to your repo.
- Provide a meaningfull description.
- You can keep the Include all branches options unchecked.
- Click on Create repository from template button and boom 💥. Your repository is ready.
- Now if you clone the repo in your PC and run
yarn
, all the dependency will be installed. - Then running
yarn dev
will start the app at http://localhost:3000. - running
yarn storybook
will start the storybook of your app at http://localhost:6006.
Following versions were installed when this template was built.
Package Name | Version |
---|---|
NodeJS | 16.10.0 |
NextJS | 13.3.0 |
react | 18.2.0 |
react-dom | 18.2.0 |
tailwindcss | 3.3.1 |
postcss | 8.4.21 |
jest | 29.5.0 |
jest-environment-jsdom | 29.5.0 |
@testing-library/jest-dom | 5.16.5 |
@testing-library/react | 14.0.0 |
eslint | 8.38.0 |
eslint-config-next | 13.3.0 |
eslint-config-prettier | 8.8.0 |
prettier | 2.8.7 |
storybook | 7.0.5 |
There are some commands preadded to this template. These commands will help to execute basic tasks.
-
Following command will start the dev server at port
3000
and we can visit the site at http://localhost:3000.yarn dev
-
Following command will create a production build of the site.
yarn build
-
Following command will start a server at port
3000
with the production build (created usingyarn build
) and we can visit the site at http://localhost:3000.yarn start
-
Following command will check any linting issue according to the eslint rules set in the
.eslintrc.json
file.yarn lint
-
Following command will execute all the unit tests (file with
*.test.jsx
,*.test.tsx
,*.test.js
or*.test.ts
extention) and check whether all the tests pass or not.yarn test
-
Following command will execute unit tests (file with
*.test.jsx
,*.test.tsx
,*.test.js
or*.test.ts
extention) and check whether all the tests pass or not in the real-time.yarn test:watch
-
Following command will start the storybook server at port 6006 and we can visit the story at http://localhost:6006.
yarn storybook
-
Following command will create a static web application capable of being served by any web server. For more info please visit Publish Storybook.
yarn build-storybook
Before working on a project, we should know about its folder structure. This helps a lot to understand where to find which components or portion of codes. In this template, the folder structure was tried to be kept as simple as possible.
-
.github/workflows: This folder is used to keep all the files related to github actions. We've already setup a basic CI/CD in the template and named the file
tests.yml
. We can create more yml files for different actions. -
.storybook: All the storybook related config files like theme, seo, preview, manager etc live inside this folder.
-
components: In our web app, we'll have to build many reusable components like button, input, modal etc. This is the place where we can keep all our reusable components. While creating a component we have tto ensure the following rules have been followed in order to maintain the consistency.
-
Each component must have a folder and index.js file inside the folder. For example: if we are creating a button component, the structure should be:
components | - Buttton | - Button.jsx | - index.js
Then we can access the component from outside using
./componets/Button
. -
If a component has some sub-components, then we can keep them in a folder named
subComponents
inside that component.components | - Buttton | - subComponents | - ButtonOverlay | - ButtonOverlay.jsx | - index.js | - Button.jsx | - index.js
-
Each component must have a story file (for storybook). Story file names should be in
<Component Name>.stories.jsx
this format.components | - Buttton | - subComponents | - ButtonOverlay | - ButtonOverlay.jsx | - index.js | - Button.jsx | - Button.stories.jsx | - index.js
-
Each component and sub-components must have a test file (for unit testing). Test file names should be in
<Component Name>.test.jsx
this format.components | - Buttton | - subComponents | - ButtonOverlay | - ButtonOverlay.jsx | - ButtonOverlay.test.jsx | - index.js | - Button.jsx | - Button.stories.jsx | - Button.test.jsx | - index.js
That's a general set of rules for the
components
folder. But of course, you can set your own rules and structure. In that case, you might have to change storybook, jest, and other configs. -
-
pages: This folder keeps all the page and api related files of our app. It's a basic feature provided by NextJS. To learn more about them, you can read the following docs from NextJS.
-
public: This folder is also provided by NextJS. It keeps all the static assets like images, icons, audios, pdfs etc. To learn more about this folder, visit Static File Serving in NextJs.
-
styles: All the global css or scss files will be kept in this folder. You can keep the local files too with an appropiate folder structure in it.
If you need to change settings of nextjs, then next.config.js
and jsconfig.json
is the place where you'll have to work. Currently, we've done a bare minimum setup in both files.
But in the jsconfig.json file, we've setup a path alias for the root directory. You can access the root directory using @/
this alias. To learn more about it, read Absolute Imports and Module path aliases in NextJS. Also, you can learn more about next.config.js
file from next.config.js Doc.
If you need to change settings of tailwind, then postcss.config.js
and tailwind.config.js
is the place where you'll have to work. You can modify or extend the tailwind theme in tailwind.config.js
file. For more info, you can read Tailwind Configuration doc.
Basically, we can modify jest unit testing setup using jest.config.js
and jest.setup.js
file. To learn more about it, you can go through Jest and React Testing Library in NextJS.
We can use .eslintrc.json
file in order to add or remove any eslint rule. For more details, you can read ESLint Configuration Files Doc.
.prettierrc.json
file is there to change prettier config of the app. We've added some configs in this file. To remove or add any config, you can go through Prettier Configuration File Doc.
All the config files of storybook are kept in the .storybook
folder.
All the project related configs for storybook are in main.js
file. If you need to change anything in the storybook preview section, then preview.js
file is the appropiate one. Learn more from Configure Storybook Doc.
To modify the theme, we may have to work in appTheme.js
and manager.js
files. To learn more about theming, visit Storybook Theming Doc.
If we want to do any SEO related changes, then we may have to modify manager-head.html
or main.js
files. To read more about it, visit Search engine optimization (SEO) Doc.
If we want to access any assets in the public
folder, then we don't have to mention public
in the src url. You can emit that. For example, we have an image xyz.png
in public folder. Then we can access this image from any story using ./xyz.png
. Learn more about it from Serving static files via Storybook Configuration Doc.
If we want to write detailed descriptions about our components, props and stories we can use JSDoc comments. To learn more please, visit the following docs from Storybook.
A github action has been setup in tests.yml
file inside .github
folder. This action runs js linting and unit test every time a new commit has been pushed to origin. You can write more github actions here as per your need.
Currently, storybook doesn't support some features (TurboPack, Server Component, SWC etc) of NextJS v13
. But if you are not using these features, then there shouldn't be any problem with storybook. [Source]
Being an open source repository, this repo has a MIT License in it. But when you are using this template, you should have to use your own license here 🚨🚨🚨. You can easily generate this. You can read Licensing a repository Doc.
- Visit Vercel's Dashboard.
- Under
Import Git Repository
section, clickContinue with Github
button. - Install
Vercel
in your GitHub account when prompted. - Select your
NextJs app
repository and clickImport
. - Add environment variables (if present) from your
NextJs app
's.env
file underEnvironment Variables
tab inConfigure Project
section. - Click
Deploy
. - On successful deployment, you will be directed to a new url with a preview image of your deployed
NextJs app
. - Click on the preview image.
- You will be directed to a url that looks like
[DOMAIN-NAME].vercel.app
.