Table of Contents
- What all does this starter template has?
- 1. Use Template
- 2. Create Repo
- 3. Deploy to Vercel
- 3.1. Import Project
- 3.2. Import Git Repo
- 3.4. Create Vercel Project
- 3.5. Successful Deployment
- 3.6. Dashboard
- 3.7. Web Application Demo
- 4. Create a database
- 4.1. Create a new Heroku app
- 4.2. Go to Resources Tab and add Heroku Postgres addon
- 4.3.
- 4.4. You now have a new Postgres DB created. Click on the addon to open the database dashboard
- 4.5. View Credentials
- 4.6. Copy Database URI
- 5. Setup Environment Variables
- 5.1. Open Env Vars dashboard in your newly created Vercel project
- 5.2. Add DATABASE_URL
- Create a new secret
- Save environment variable
- Create NEXTAUTH_URL variable
Β
This blog post is outdated. The repo has changed so much since then.
Next.js has become my go-to framework for almost every project that I make. So, I made a starter template that I can just use and get started easily.
In this article, I will show you how to use the starter template that I made and deploy it with Vercel. I will also be connecting a Postgres database which I will create on Heroku.
What all does this starter template has?
- Next.js/React 17
- TypeScript
- Tailwind CSS 2
- React Query
- React Query Dev Tools
- Prisma 2
- GitHub Auth
- Email + Passwordless Auth
- Postgres
- ESLint
- Prettier
- Husky
If this is the tech stack that you are interested in, then follow along.
1. Use Template
data:image/s3,"s3://crabby-images/2bcb3/2bcb3701aa615a7abc5208d6286ad20a5dc66efd" alt="notion image"
Go to pbteja1998/nextjs-starter repo and click on
Use this template
button.2. Create Repo
data:image/s3,"s3://crabby-images/3454f/3454fb847d230146eea6177bb94249faa53184a4" alt="notion image"
Follow the instructions and create your repo
3. Deploy to Vercel
3.1. Import Project
data:image/s3,"s3://crabby-images/84e18/84e184db947afc7e05a4de68703714203351d5d8" alt="notion image"
Login to vercel and click on
Import Project
.3.2. Import Git Repo
data:image/s3,"s3://crabby-images/af043/af0434dcece97b53e385d1a24bf53a5ce24afc67" alt="notion image"
Letβs import from Git Repository
3.4. Create Vercel Project
data:image/s3,"s3://crabby-images/571e3/571e35c047f41e48a8adbb40934a10ae536ff39f" alt="notion image"
Choose the name of the project and
Deploy
. We will be adding the required environment variables later.3.5. Successful Deployment
data:image/s3,"s3://crabby-images/3b34d/3b34d8d146fa76f88597988f710bdab5509c1eb3" alt="notion image"
You should see this once deployed. Open the dashboard after a successful deployment.
3.6. Dashboard
data:image/s3,"s3://crabby-images/93a92/93a9295e07412cd6041921605cef4fe7a0cf8f70" alt="notion image"
Thatβs it. Your Next.js starter application has been deployed to Vercel. You can click on
Visit
to open the website.3.7. Web Application Demo
data:image/s3,"s3://crabby-images/dfb88/dfb880dc75824ac0a7367186e50467352441bd3a" alt="notion image"
You should see something like this. This home page template is taken from one of the examples in tailwindcss.com
4. Create a database
We need a database to store users and user sessions. I will be using the Postgres database. But you can use whatever you want. If you already have a URL for your database, you can skip this step. I will be using Heroku to create a Postgres database.
4.1. Create a new Heroku app
data:image/s3,"s3://crabby-images/b22aa/b22aace03c893238f734ff187e0a643cb0a7c2f4" alt="notion image"
data:image/s3,"s3://crabby-images/266a0/266a0f49da806ef4964dfa9c396886e8385a9ca6" alt="notion image"
4.2. Go to Resources Tab and add Heroku Postgres
addon
data:image/s3,"s3://crabby-images/78224/7822446db88d993594d862da560c0c5063c923d7" alt="notion image"
4.3.
Heroku Postgres
has a free tier available. I will be using that for the demonstration.data:image/s3,"s3://crabby-images/bb79d/bb79d77a9abf856b1f44977a6218b66d2b5c759d" alt="notion image"
4.4. You now have a new Postgres DB created. Click on the addon to open the database dashboard
data:image/s3,"s3://crabby-images/6cd1b/6cd1b88bc38a6bbce8a83723dc79afd3421707a0" alt="notion image"
4.5. View Credentials
data:image/s3,"s3://crabby-images/6a3d1/6a3d182af0ba3ea95f0b82e6bcad0323bfe47e45" alt="notion image"
Click on
Settings
and then View Credentials
.4.6. Copy Database URI
data:image/s3,"s3://crabby-images/68ef1/68ef1c3f9c8e70006fc4abd3abb4b5355a4e3096" alt="notion image"
You should be able to see the database URI now. Copy that we will be using it later. Also, note that the free tier Heroku database credentials are not permanent. They change periodically. So, when you are deploying for production, use some other database that is stable or upgrade your Heroku database to a paid plan.
5. Setup Environment Variables
5.1. Open Env Vars dashboard in your newly created Vercel project
data:image/s3,"s3://crabby-images/9e980/9e980eccb4fe24f866f0092ad957c7955c218c3a" alt="notion image"
5.2. Add DATABASE_URL
data:image/s3,"s3://crabby-images/9d1f4/9d1f42534cb00dda372758d64fe9480928c22489" alt="notion image"
Create a new secret
data:image/s3,"s3://crabby-images/2f833/2f83310ff0d0c36e719a57cf186de64611d728b8" alt="notion image"
Save environment variable
data:image/s3,"s3://crabby-images/61a13/61a137a05dc521cfa03efe3fdda24bab37611c78" alt="notion image"
data:image/s3,"s3://crabby-images/3fcb9/3fcb91b93ca42aac2756c7e8cfcda9d2bb0bed6f" alt="notion image"
Create NEXTAUTH_URL
variable
data:image/s3,"s3://crabby-images/a15f8/a15f826193d7057c0900574c64fa6ef433573f49" alt="notion image"
This is the URL of the deployment.
Similarly, create all the variables that you can see in .env.example file of the repo.
SECRET
- Some random string
- SMTP_HOST
- SMTP host to send emails from. Example:
smtp.zoho.com
- SMTP_PORT
- Your SMTP port. Example:
465
data:image/s3,"s3://crabby-images/97914/97914d6aa4ca5d303585559c0dcb37359a22c2c6" alt="Bhanu Teja P"
Written by
24yo developer and blogger. I quit my software dev job to make it as an independent maker. I write about bootsrapping Feather.