This is a Next.js project bootstrapped with create-next-app
.
- https://nextjs-prismic-blog-starter.vercel.app/
- https://blog.iamsainikhil.com
- Prismic Slices available with the starter can be seen in action here.
Multiple features of Prismic are used in this starter:
- Slices: Enrich your blogposts with custom quotes, images or codeblocks. You can order them how you like. When you used the Image-Slice the image will get inserted and optimized by nextjs-image
- Relationship fields: Categorize your blog articles in Categories via a relationship field. You can change categories on the fly
- Both custom types (Single / Repeatable): Articles, Tags, Categories, Author sections of the website are managed with Prismic. The social media links or the header & footer sections are hardcoded content which can be customized easily!
- Prismic Preview: Prismic allows preview of any document which comes handy before publishing a document. This starter has got preview setup for article page. For more info, check here and here
Therefore the starter has following features:
-
Prismic as Headless CMS
-
Prismic Previews
-
Theme UI for styling
-
Prism React Renderer plugin using PrismJS highlighting
-
Responsive images (nextjs-image)
- The right image size for every screen size
- Traced SVG Loading (Lazy-Loading)
- WebP Support
- Prismic Imgix transformations
-
SEO (nextjs-head)
- OpenGraph Tags
- Twitter Tags
- Favicons
-
Offline Support
-
WebApp Manifest Support
-
NextJS dynamic code-splitting of components
-
NextJS optimized google fonts (nextjs-google-fonts)
-
Configurable
- Use the
next-config.js
,Head.jsx
, andLayout.jsx
to easily change the most important information - Themeable with
theme.js
- Use the
- Create your Prismic account here
- Create a project
- After creating an account, head over to settings of the project you created earlier.
- Go to API & Security section, grab the Permanent Access Token with Access to master/README_images.
-
Create a Repeatable custom type with name Article.
-
Simply paste the JSON schema in
_src/schemas/article.json_
file in the JSON editor of the_Article_
type in Prismic. This will create all the below fields in the Article type on the fly for you. -
Beauty of Prismic Slices is that they are optional data sections which can be customized very easily in the Prismic UI.
-
Primary
content of the article:- uid → ID of the article which you will find in the URL
- created → Created date of the article
- modified → Modified date of the article
- title → Title of the article
- excerpt → Short description of the article
- read_time → Total time to read the article
- article_image → Image of the article (ex- Thumbnail)
-
Slices
(Optional):-
Content: This slice has 2 types (Rich Text and Quote) based on which the
content
is rendered in the UI. Support forinline code
usingcodespan
label which appear in the HTML with a classcodespan
.-
Text (Rich Text Section) → Rich WYSIWYG editor content which is consumed in the UI as the HTML.
-
Quote (Blockquote Section) → Select this type to have any blockquote content in the article.
-
- Alert: This slice has 4 types (Info, Success, Warning, and Danger) based on which the
alert
UI will have different background color as well as border color. Support forinline code
usingcodespan
label which appear in the HTML with a classcodespan
.
-
Image (banner or gallery) → Use this slice to show a
banner
(single image with caption) or agallery
(group of images)-
Embed → Use this slice to embed any platform content like YouTube, Vimeo, GitHub Gist, CodeSandbox, CodePen, etc.
- type → Type of the embed like
GitHub Gist
orDefault
(YouTube, Vimeo, CodeSandbox, etc). - embed_title → Title of the embed.
- embed_url → URL of the embed which will be consumed in an iframe in the UI
- type → Type of the embed like
-
Meta Information (Website URL meta info Section) → Use this slice to show a meta info of any URL. You can obtain all the below information using https://www.heymeta.com/
- website_title → Title of the website
- website_description → Description of the website
- website_image → Image of the website
- website_url → URL of the website
-
Code → Use this slice to show any code block in the article
- type → Mention the type of scenario where this code block is used. For ex- type of "List" will add some padding to the code block.
- lang → Language of the code to have appropriate syntax highlighting using PrismJS
- code → Actual code content
-
-
-
Meta
(meta information of the article)-
Categories (repeatable section) with fields like:
- category → Category of the article
- slug → Category name in the URL
Category custom type is discussed later.
-
Author (non-repeatable section) → relationship field with Author custom type discussed later.
-
-
Tags
→ This is not defined in the Article type but can be set when you create any article like below:
- Create a Repeatable custom type with name Author.
- Simply paste the JSON schema in
_src/schemas/author.json_
file in the JSON editor of the_Author_
type in Prismic. This will create all the below fields in the Author type on the fly for you. - Contents:
- uid → URL slug of the author
- name → Name of the author
- bio → About the author
- avatar → Image of the author
- social_links (repeatble section) → Social links of the author
- platform_name → Name of the platform (Facebook, Twitter, LinkedIn, Medium, GitHub, CodePen, Portfolio (website). However, you can customize the icons which is discussed later.
- platform_url → URL of the platform
- Create a Repeatable custom type with name Category.
- Simply paste the JSON schema in
_src/schemas/category.json_
file in the JSON editor of the_Category_
type in Prismic. This will create all the below fields in the Category type on the fly for you. - Contents:
- name → Name of the category
-
Create a NextJS site.
npx create-next-app # create a new NextJS site using this starter git clone https://github.com/iamsainikhil/nextjs-prismic-blog-starter
-
Install the packages
Install the packages using the command
npm install
-
Environment File
- Go to API & Security section of your Prismic project, grab the Permanent Access Token with Access to master.
- The Repository Name is the name you have entered at the creation of the repository (you’ll also find it as the subdomain in the URL)
- This project has the support for DISQUS comments section which need your DISQUS project name which can be found at https://.disqus.com/admin/settings/general/
- Create an
.env
file in the root directory of the project. Add the following properties in it:
NEXT_PUBLIC_GA_ID=<your Google Analytics tracking ID> (Optional) NEXT_PUBLIC_SITE_URL=<URL of the deployed app (Optional)> NEXT_PUBLIC_PRISMIC_REPO=<your prismic repository name (Required)> PRISMIC_API_URL=<your prismic repository API URL> (Required) PRISMIC_ACCESS_TOKEN=<your prismic permanent access token> (Required) NEXT_PUBLIC_DISQUS_NAME=<your disqus project shortname> (Required)
-
Start developing.
Navigate into your new site’s directory and start it up.
# Go to project directory cd <name> # start the application npm run dev
-
Open the source code and start editing!
Your site is now running at
http://localhost:3000
!Open the
<name>
directory in your code editor of choice and edit the contents. Save your changes and the browser will update in real time!
In the project directory, you can run:
npm run dev
Runs the app in the development mode.Open [http://localhost:3000](http://localhost:3000/)
to view it in the browser. The page will reload if you make edits. You will also see any lint or nextjs develop errors in the console.
npm run start
Runs the app in the production mode.Open [http://localhost:3000](http://localhost:3000/)
to view it in the browser. The page will reload if you make edits. You will also see any lint or nextjs develop errors in the console.
npm run build
Builds the app for production to the build
folder.It correctly bundles React in production mode and optimizes the build for the best performance.
The build is minified and the filenames include the hashes. Your app is ready to be deployed!
See the section about deployment for more information.
npm format
Formats the app files like js, jsx, json, and md using Prettier. You can learn more about the format here.
A quick look at the top-level files and directories you'll see in a NextJS project.
.
├── node_modules
├── src
├── .gitignore
├── nextjs-config.js
├── LICENSE
├── package-lock.json
├── package.json
└── README.md
/node_modules
: This directory contains all of the modules of code that your project depends on (npm packages) are automatically installed./src
: This directory will contain all of the code related to what you will see on the front-end of your site (what you see in the browser) such as your site header or a page template.src
is a convention for “source code”..gitignore
: This file tells git which files it should not track / not maintain a version history for.nextjs-config.js
: This is the main configuration file for a NextJS site. This is where you can specify information about your plugins config you’d like to include, etc.LICENSE
: NextJS Prismic Blog Starter is licensed under the MIT license.package-lock.json
(Seepackage.json
below, first). This is an automatically generated file based on the exact versions of your npm dependencies that were installed for your project. (You won’t change this file directly).package.json
: A manifest file for Node.js projects, which includes things like metadata (the project’s name, author, etc). This manifest is how npm knows which packages to install for your project.README.md
: A text file containing useful reference information about your project.
A quick look at the top-level files and directories you'll see in the application.
/
├── components
├── public/fonts
├── public/images
├── pages
├── schemas
├── slices
├── styles
├── utils
components
: This directory contain all of the reusable React components like Chip, Icon, Image, Listing, Layout, SEO, SliceMachine, etc.public/fonts
: This directory contain any custom font files which are imported instyles/_fonts.scss
and later consumed intheme.js
.public/images
: This directory contain images which are used in the components and later be optimized during NextJS build.pages
: This directory contain files which represent web pages like 404, index.js (homepage), _app.js, etc. Moreover, you can generate dynamic pages using thegetStaticPaths
andgetStaticProps
methods based on the structurepages/[sub-page]/[param].js
.schemas
: This directory contain JSON schema files which represent each custom type defined in Prismic.slices
: This directory is the ❤️ of the article page with files representing the slices discussed earlier in Prismic setup section.styles
: This directory contain scss files which include further styling of the HTML using old school process. PS: New process is to just useEmotion
basedCSS-in-JS
styling which is also used extensively across the project.utils
: This directory contain general utility JS functions to reuse the functionality across the components.
A list of packages used in this starter project.
dayjs
: A 2KB immutable date library alternative to Moment.js with the same modern API. For more info, check here.theme-ui
: Build consistent, themeable React apps based on constraint-based design principles. For more info, check here.prism-react-renderer
: Renders highlighted Prism output to React (+ theming & vendored Prism). This package is used to syntax highlight the code blocks in article. For more info, check here.react-copy-to-clipboard
: Copy-to-clipboard React component used in Code slicesrc/slices/Code.jsx
. For more info, check here.react-gist
: Github Gist React component used in Embed slicesrc/slices/Embed.jsx
. For more info, check here.react-headroom
: A handy react component to hide the site header until you need it. For more info, check here.react-icons
: Absolutely useful package to get svg react icons of popular icon packs. For more info, check here.react-images
: A mobile-friendly, highly customizable, carousel component for displaying media in ReactJS. For more info, check here.react-snakke
: Reading position indicator for React used to display the progress of the article as you scroll down the page. For more info, check here. This is one of the package which can be completely avoidable if you don't want it 😄.react-toastify
: React notification made easy. This is used to notify users of which code block they copied to clipboard used in Code slicesrc/slices/Code.jsx
. For more info, check here.disqus-react
: A React component for Disqus. For more info, check here.next-google-fonts
: A simple plugin for loading Google Fonts fast and asynchronously. For more info, check herenext-pwa
: A simple plugin to add PWA support for NextJS app. For more info, check hereprismic-javascript
: JavaScript development for prismic.io API v2. For more info, check hereprismic-reactjs
: A simple utility to render Rich Text with Prismic API V2. For more info, check here
List of files where you can customize stuff to make this starter your own!!
Head.jsx
: This file is where meta tags and other tags get injected to the documenthead
.next-config.js
: As the name suggests, bulk of the customization resides in this file. I left so many comments which help you customize the options for several plugins.theme.js
: This is the 👁️ of the project with all the theme options declared in this file. Take some time understanding the theme-ui configuration here.Listing.jsx
&Footer.jsx
: Sample tracking logic is setup in the code which can be used as an example to customize the GA tracking events. You can remove this code logic entirely or customize to your needs.public/site_image.png
: Replace this image to update website meta image.
Prismic Webhook allows you to automatically or manually trigger a deployment process in Netlify or Vercel if any post is published or unpublished OR for other events in Prismic. I use Vercel as the example and I guess it might be quite similar for Netlify or any other cloud service.
- Copy the hook link and past in the URL section of the prismic Webhook
- Create a Prismic Webhook here. For more info, check here. -
- The
Secret
field is optional in the Prismic Webhook. If you set it, Prismic will send the content to your server, so that you can verify that the request is coming from prismic.io. - After successful creation of the Webhook, you can manually trigger it and can also see the logs.
You can create any number of Webhooks for a prismic project!
- Publish this starter as a template
- Analytics support (Google Analytics)
- Prismic Preview Setup
- Pagination Feature
- Search Feature
- Testing
- Open pull request with improvements.
- If you have any new idea, check the feature request template to create a request.
- If you found any issue or a bug, check the bug report template to create a report.
Have a look at the license file for details
Whether you’d like to discuss about this starter template or simply say “hello”, I’d love to hear from you.
Email: contact@iamsainikhil.com
Looking for more guidance? Full documentation for NextJS lives on the website. Here are some places to start:
- For most developers, I recommend starting with the in-depth tutorial for creating a site with NextJS. It starts with zero assumptions about your level of ability and walks through every step of the process.
- To dive straight into code samples, head to the documentation. In particular, check out the Basic Features, API Reference, and Advanced Features sections in the sidebar.
Looking for more guidance? Full documentation for Prismic lives on the website. Here are some places to start:
- For most developers, I recommend starting with our in-depth tutorial for creating a site with NextJS & Prismic. It starts with zero assumptions about your level of ability and walks through every step of the process.
- To dive straight into code samples, check the How To Guides.