Skip to content

ickynavigator/portfolio-sanity-client

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Portfolio Sanity Client

This is a Next.js project bootstrapped with create-next-app. It uses Sanity as the CMS(data store)

Tools Used

Getting Started

Setting up the sanity project

You need to create a sanity project to work with this portfolio. This can be done by running this in the root of the app

npm -y create sanity@latest

This will prompt you to do a few things

  1. Setup your sanity account or Login if you already have one
  2. Create a new project
    • You can use the default dataset config(make sure to add the new dataset name in the environment variables if you decide to use a custom one)
  3. Don't add configuration files (this has already been done for you)
  4. Select clean project with no predefined schemas
    • You can delete the newly created sanity changes
  5. Go to the sanity dashboard and select your project to view your project ID and other details

Environment Variables

Fill up the .env file with the variables in the .env.example

The Sanity API token is used to fetch data from Sanity. Go to your sanity project api page to generate it. Grant it the Editor role. This is only required if your dataset is private (it should be)

SANITY_API_TOKEN =

The secret sanity expects when it tries to hit the revalidate webhook. It defaults to SECRET

SANITY_REVALIDATE_SECRET =

The Sanity Dataset is the name of the dataset you want to use. Go to your sanity project datasets page to find it. It defaults to production

NEXT_PUBLIC_SANITY_DATASET =

The Sanity project id is the id linked with the sanity project. It should be on the dashboard of your sanity project.

NEXT_PUBLIC_SANITY_PROJECT_ID =

Sanity Api version. It defaults to 2021-10-21

NEXT_PUBLIC_SANITY_API_VERSION =

Ignore at least one of the SMTP variables if you don't want the contact form to go to the user's email. Check the Nodemailer docs

SMTP_SERVICE =
SMTP_USER =
SMTP_PASS =

Project config

Go to the studio at /studio to setup the project configuration.

Setup Revalidation

The app is statically built and nextjs caches all the fetch calls so you need to setup revalidation for sanity so the app actually updates when you make a change. There is a preconfigured webhook setup Found here.

  • Replace the site with URL with {SITE_URL}/api/revalidate
  • Add a secret (to prevent others from revalidating it)
    • This should be the same value as the environment variable SANITY_REVALIDATE_SECRET which defaults to SECRET

Commands

Starting the App

Then run the development server:

pnpm run dev

Viewing the main app

Open http://localhost:3000 to see the result.

Viewing the studio

Open http://localhost:3000/studio to see the local studio.

Generate the schema types

pnpm run codegen
Sanity Scripts

Project Image to Project Images

The project type originally used a single image object instead of an array of images (silly right?). I created a small script to convert the image from a single item to an array containing that item. The image type has already been deprecated, hidden and marked as readonly. script here

bun sanity/migrations/image/single-to-carousel.ts

Project Export

This script exports the project data to a json file. It is used to backup the data in case of any issues. script here

bun sanity/export/project/fetch-all.ts

About

My personal website built using NextJS and a sanity CMS

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published