npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

gatsby-plugin-react-social-cards

v1.0.0

Published

This Gatsby plugin lets you create React components that can then be screenshotted and used as social card images.

Downloads

56

Readme

gatsby-plugin-react-social-cards 📸

This Gatsby plugin lets you create React components that can then be screenshotted and used as social card images.

This plugin was inspired by Max Pou's post on generating social share images with Gatsby.

How does it work?

When you start up your Gatsby server with gatsby develop, the plugin creates Gatsby pages for all of your social card images using your provided React component.

Then, it will take screenshots of all these pages with Puppeteer, and save them in your static folder.

Setup instructions

For more a more detailed explanation, view my post on this plugin.

First, install the Gatsby plugin:

npm install gatsby-plugin-react-social-cards
# or
yarn add gatsby-plugin-react-social-cards

Then, add the plugin to your gatsby-config.js file:

{
    plugins: [
        {
            resolve: `gatsby-plugin-react-social-cards`,
            options: {
                query: `
                    {
                        allMarkdownRemark {
                            nodes {
                                fields {
                                    slug
                                }
                                frontmatter {
                                    title
                                    description
                                }
                            }
                        }
                    }
                `,
                queryToPages: (result) => 
                    result.data.allMarkdownRemark.nodes.map(node => {
                        const slugWithoutSlashes = node.fields.slug.node.slug.replace(/\//g, '');
                        return {
                            slug: `/${slugWithoutSlashes}`,
                            pageContext: {
                                title: node.frontmatter.title,
                                coverImage: node.frontmatter.coverImage,
                            },
                        };
                    }),
                component: require.resolve('./src/components/social-card.js'),
                cardLimit: 0, // Useful for debugging.
            },
        },
    ]
}

The query and queryToPages will have to be modified depending upon your Gatsby site.

Create your social card React component

Your React social card component will receive all the variables passed in via the pageContext object:

// src/components/social-card.js

import React from 'react';

const SocialCard = ({ pageContext: { title, description, height, width } }) => {
    return <div>{title}</div>
}

export default SocialCard;

By default this React component will be opened and screenshotted at a 1200x628 resolution in Chrome. Make sure that it renders properly at this height and width.

Testing your social card image

After completing the above steps, you can start up your Gatsby blog with gatsby develop.

You will be able to view the pages for your social cards at localhost:8000/<your-post-slug>-social-card.

You can change the cardLimit option to 1 to test a screenshot of one page.

After changing your gatsby-config.js file, your browser will prompt you to restart your server. I recommend instead that you manually kill and start your Gatsby server as I’ve found that when restarting, it will attempt to take the screenshot too early.

Once you are ready for all pages to be screenshotted, you can remove the cardLimit option altogether. All images will be saved in the static folder.

The next time you start gatsby develop, any pages that already have a social card image won’t have its social card page generated. If you want to re-take a screenshot, delete the image from your static folder.

Optional options

  • imageFolder - defaults to 'static'. If you want to save your images to another folder
  • baseUrl - defaults to 'http://localhost:8000'. If you start your dev server on another port.
  • timeout - defaults to 5000. Milliseconds waited before the screenshot is taken. Increase this number if you need to wait for images to load, decrease if you find it's too slow.
  • dimensions defaults to:
[{
    width: 1200,
    height: 628,
    suffix: '-social-card'
}]

This lets you change the height and width, as well as let you screenshot multiple times per page at different dimensions. The width and height will be passed in as values to the pageContext object of your React component.