Skip to content

lukaskoeller/gridsome-starter-strapi

Repository files navigation

gridsome-starter-strapi

This is a Gridsome Starter using the headless CMS Strapi. It is suppose to kick-start development with Strapi.

A Demo is hosted on Netlify.

Under the hood, the starter is using the source plugin @gridsome/source-strapi to pull data from Strapi into Gridsome's data store.

Images provided by Strapi are downloaded and saved locally via onCreateNode. Thus, the build version includes all images in /static.

Rich text which is provided as markdown from Strapi is prepared via onCreateNode and transformed to html using @gridsome/transformer-remark.

Gridsome-Starter-Strapi Preview

Strapi Setup

Note: Steps that are marked with a check are already done and are just necessary if you set up a completely new project.

  1. ✅ Install the @gridsome/source-strapi Plugin: npm install @gridsome/source-strapi --save
  2. ✅ Add it to the config file:
export default {
  plugins: [
    {
      use: '@gridsome/source-strapi',
      options: {
        apiURL: 'http://localhost:1337',
        queryLimit: 1000, // Defaults to 100
        contentTypes: ['post'],
        // Possibility to login with a Strapi user,
        // when content types are not publicly available (optional).
        loginData: {
          identifier: '',
          password: ''
        }
      }
    }
  ]
}
  1. Install Strapi by following the Get Started Guide.
  2. Install Strapi and create a new project: npx create-strapi-app gridsome-starter-strapi-cms --quickstart.
  3. Complete the form to create the first Administrator user.
  4. Since we are using GraphQL, install the GraphQL plugin: npm run strapi install graphql. Open the GraphQL Playground (http://localhost:1337/graphql) to test your queries.
  5. Restart your server: npm run develop.

Create Posts

  1. In the Strapi Admin Interface you can now add Content Types (Plugins > Content-Types Builder > Create new collection type).
  2. Name you new collection type Post.
  3. Now, add 4 fields, namely title (text), subtitle (text), article (rich text) and image (single media).
  4. Click on Save & Publish.
  5. Add blog entries by clicking on Collection Types > Posts > Add New Post.
  6. Go to Settings > Roles under USERS & PERMISSIONS PLUGIN. Click on the column saying Public. Put a check on find and findOne under Post. Click on Save.
  7. ✅ In gridsome.config.js add post (API ID) under contentTypes.

Create About

  1. In the Strapi Admin Interface you can now add Content Types (Plugins > Content-Types Builder > Create new single type).
  2. Name you new collection type About.
  3. Now, add 2 fields, namely title (text) and article (rich text).
  4. Click on Save & Publish.
  5. Add content to the about page by clicking on Single Types > About.
  6. Go to Settings > Roles under USERS & PERMISSIONS PLUGIN. Click on the column saying Public. Put a check on find under About. Click on Save.
  7. ✅ In gridsome.config.js add about (API ID) under singleTypes.

Gridsome Setup

1. Install Gridsome CLI tool if you don't have

npm install --global @gridsome/cli

2. Create a Gridsome project

  1. gridsome create gridsome-starter-strapi to install default starter
  2. cd gridsome-starter-strapi to open the folder
  3. gridsome develop to start a local dev server at http://localhost:8080
  4. Happy coding 🎉🙌

🐛 Debugging

  • Since we are working with GraphQL, the GraphQL explorer can be very helpful. You can open it through http://localhost:8080/___explore.

Troubleshooting

  • If you get TypeError: gridsome.server.js: Cannot read property 'allStrapiPost' of undefined (31:10) as an error after starting the gridsome development server, you likely forgot to create and/or publish your post in Strapi under Collection Types > Posts.

💫 Deploy

Deploy to Netlify

Releases

No releases published

Packages

No packages published