BlogPodcastAbout💌 Tiny Improvements

Sync your About page and your GitHub bio on your Next.js site

Learn how to sync your About page and your personal GitHub README bio on your Next.js site, as a step towards owning your content on social media.

Your about page tells the world who you are, and what matters to you

For many developers, the about page is one of the most important pages on your website. It tends to be one of the most highly-visited pages on many devs' sites. It serves as the page that will tell the world who you are, and what matters to you. It's also the page that will help you stand out from the crowd, and help you connect with your audience.

Similarly, your GitHub profile README is the first thing that people will see when they visit your profile on GitHub. I've seen many creative uses for personal GitHub profile pages, but they are most commonly used as a place to share a bio, and to connect with your audience.

They Sounds awfully similar, no?

This week, I decided that for me at least, they should be one in the same. My personal about page and my GitHub Profile contained a lot of overlapping information, but weren't quite the same. My site is built with Next.js, and I use an extension of Markdown called MDX to write my content. My GitHub profile README is written in Markdown. Because of this, keeping them in sync turned out to be pretty easy.

Setup and background

Making this setup work requires some modifications to your Next.js site, and it's important to understand how things work before you dive in. Here's a quick overview of how this setup works:

Content flows from GitHub -> your Next.js site

In this setup, the source of truth for content on the about page will be GitHub Profile README. From the next.js site, we fetch the README and render it on the About page using a library called next-mdx-remote.

So, to update our bio in both places, we'll edit the README file on GitHub. This will update the content on our About page, as well as our GitHub profile README.

About next-mdx-remote

next-mdx-remote is an npm library that provides an API for loading remote MDX files into Next.js. It allows developers to write their pages in MDX, an extension of Markdown that supports embedded React components. It also provides an API for loading the MDX files from a remote URL, allowing developers to use an external CMS or content storage system to manage their page content. This is exactly what we need to sync our About page and our GitHub profile README, which is written in Markdown.

How to sync your Next.js site About page to your GitHub README

Here's how you can set this up:

  1. First, create an About page on your Next.js site. Typically, this means creating a file in the /pages/ directory of your source code called about.jsx (or about.tsx if you're using TypeScript).
1
// For sake of example, we'll use a Layout component to represent the visual layout of the page
2
import Layout from '../components/Layout';
3
4
export default function About({ source }) {
5
return <Layout>{/* content from GitHub will go here */}</Layout>;
6
}
  1. Next, create a GitHub profile README. If you haven't done this before, Monica Powell (@indigitalcolor) has a great tutorial - How to create a GitHub profile README. This is where you'll write your bio - and this is the file that will be synced to your About page.

  2. Now you'll need to set up next-mdx-remote on your Next.js site. Once your readme is fetched from GitHub, we will use this library to serialize it as MDX -- in other words, to transform it from Markdown to renderable react components for Next.js.

If you don't already have it installed, you can install it with npm, yarn, or pnpm.

1
npm install next-mdx-remote
2
# or
3
yarn add next-mdx-remote
4
# or
5
pnpm add next-mdx-remote
  1. Next, we need to grab the raw Markdown from our GitHub README, and feed it into next-mdx-remote. I chose to do this in getStaticProps, which means it will be fetched and rendered once when my site is built, and then cached. This is fine for my use case, but if you're updating your about page frequently, you may want to use getStaticProps instead, to fetch your README on every page render.

So, back in pages/about.jsx:

1
import { serialize } from 'next-mdx-remote/serialize';
2
3
// For sake of example, we'll use a Layout component to represent the visual layout of the page
4
import Layout from '../components/Layout';
5
6
// fetch personal README from github and return it as mdx in getserversideprops
7
export async function getStaticProps() {
8
const res = await fetch(
9
// replace this with your own README's raw URL (see below)
10
'https://raw.githubusercontent.com/mbifulco/mbifulco/main/README.md'
11
);
12
const content = await res.text();
13
14
// include mdxOptions as needed on your site
15
const mdxSource = await serialize(content /*, mdxOptions */);
16
17
return {
18
props: {
19
mdxSource,
20
},
21
};
22
}
23
24
export default function About({ source }) {
25
return <Layout>{/* content from GitHub will go here */}</Layout>;
26
}

To get the raw URL for your README, go to your GitHub profile, and click on the README file. Then, click the "Raw" button in the top right corner of the file. Copy the URL from the address bar, and replace the URL in the code above with your own.

  1. Finally, you can render your README in your About page using MDX Remote.
1
import { MDXRemote } from 'next-mdx-remote';
2
import { serialize } from 'next-mdx-remote/serialize';
3
4
// For sake of example, we'll use a Layout component to represent the visual layout of the page
5
import Layout from '../components/Layout';
6
7
// If you want to have MDX render custom components, you can import them here
8
import { components } from '~/utils/mdx-components';
9
10
export async function getStaticProps() {
11
// fetch personal README from github
12
const res = await fetch(
13
// replace this with your own README's raw URL
14
'https://raw.githubusercontent.com/[YOUR_USERNAME]/[YOUR_USERNAME]/[YOUR_DEFAULT_BRANCH]/README.md'
15
);
16
const content = await res.text();
17
18
// include mdxOptions as needed on your site
19
const mdxSource = await serialize(content /*, mdxOptions */);
20
21
// pass the mdxSource to the page component in props
22
return {
23
props: {
24
mdxSource,
25
},
26
};
27
}
28
29
export default function About({ mdxSource }) {
30
return (
31
<Layout>
32
{/* note: passing in components is optional */}
33
<MDXRemote {...mdxSource} components={components} />
34
</Layout>
35
);
36
}

Bingo bango, we're there! Now, whenever you update your README, your About page will reflect those changes the next time your site is built. If you'd like to see how the about page for my site is implemented, you can check out the source code on GitHub, since it's all Open Source!

More Next.js goodness

If you enjoyed this post, you might want to check out some of my other articles on next.js :

Mike Bifulco headshot

Subscribe to Tiny Improvements

Learn about designing & building great products for the web, and my philosophy for living a life you love in an ever-changing world.

    Typically once a week, straight from me to you. 😘 Unsubscribe anytime.


    Get in touch to → Sponsor Tiny Improvements

    ***
    Hero
    Sync your About page and your GitHub bio on your Next.js site

    Learn how to sync your About page and your personal GitHub README bio on your Next.js site, as a step towards owning your content on social media.

    nextjsgithubjavascriptreactwebdev
    © 2019-2023 Mike Bifulco

    Get in touch to → Sponsor Tiny Improvements

    Disclaimer: 👋🏽 Hi there. I work as a co-founder & CTO at Craftwork. These are my opinions, and not necessarily the views of my employer.
    Built with Next. Source code on GitHub.

    More great resources

    Articles about React.jsArticles about Remix.runArticles about Next.jsArticles for developersArticles for JavaScript developersArticles about CSSArticles about User Experience (UX)Articles about tools I useArticles about productivityBrowse all topics →