Costis94
Costis94

Reputation: 250

Gatsby-plugin-image: Missing image prop after updating Gatsby Client

I'm building a GatsbyJs blog with Contentful and GraphQL queries. Everything was working perfectly until I updated my GatsbyJs client, npm version, and changed the structure of my Contentful Content.

Now my landing page can not load images and in the console, I have the error [gatsby-plugin-image] Missing image prop.

My code:

    import * as React from "react"
import { Link, graphql } from "gatsby"
import { GatsbyImage, getImage } from "gatsby-plugin-image"

import Layout from "../components/layout"
import Seo from "../components/seo"

import {Container, Row, Col, Button} from "react-bootstrap"

import {stars} from "../utilities/starSystem.js"
import "bootstrap/dist/css/bootstrap.min.css";
import 'bootstrap-icons/font/bootstrap-icons.css';
import "../styles/index.css"

class BlogIndex extends React.Component{
  

  render(){

    const { data } = this.props;
    const siteTitle = data.site.siteMetadata.title;
  
      
    return (
      <Layout location={this.props.location} title={siteTitle}>
        <Seo title="Ολά τα άρθρα" />


        <Container>
  
          <Row>
            <Col>
            </Col>
          </Row>
        </Container>

        <Container>
          {data.allContentfulBlogPost.edges.map(post => (
            <section className="book_row">
           <Row>
             <Col xl={6} lg={6} m={3}><div className="eikona"><GatsbyImage className="featured-image" image={getImage(post.node.featuredImage)} alt={post.node.title}/> </div> </Col>
             <Col xl={6} lg={6} m={9}>
               <Button className="custom-button">Non-fiction</Button>
               <h1 className="post-title">{post.node.title}</h1>
               <Row><Col lg={3} className='author-column'><h3 className="author-title">Yuval Harari</h3></Col> 
               <Col> {stars(4)}</Col></Row>
               <p className="perilipsi">{post.node.excerpt.excerpt}</p>
               
              </Col>
           </Row>
           </section>
        ))}
        </Container>
       
  
    </Layout>)
    }
    }

export default BlogIndex;

export const pageQuery = graphql`
  query {
    site {
      siteMetadata {
        title
      }
    }
    allContentfulBlogPost(sort: {order: DESC, fields: publishedDate}) {
      edges {
        node {
          title
          excerpt {
            excerpt
          }
          slug
          publishedDate(formatString: "DD-MM-YY")
          featuredImage {
            gatsbyImageData(width: 230, cropFocus: CENTER, placeholder: BLURRED, resizingBehavior: SCALE)
          }
          body {
            raw
          }
          author
          category
        }
      }
    }
    latest: allContentfulBlogPost(
      sort: {order: DESC, fields: publishedDate}
      limit: 1
    ) {
      edges {
        node {
          title
          featuredImage {
            gatsbyImageData(width: 300)
          }
          publishedDate(formatString: "DD-MM-YY")
          excerpt {
            excerpt
          }
        }
      }
    }
  }
`

When I execute the Query the results seems fine:

{
  "data": {
    "allContentfulBlogPost": {
      "edges": [
        {
          "node": {
            "featuredImage": {
              "gatsbyImageData": {
                "images": {
                  "sources": [
                    {
                      "srcSet": "//images.ctfassets.net/xp88oy0wq1rq/1bgvqRwgZqApVxQeYRCkub/14d2ea0bf162b413bf66c91794e2b34e/sapiens-5.jpg?w=58&h=88&q=50&fm=webp&fit=scale&f=center 58w,\n//images.ctfassets.net/xp88oy0wq1rq/1bgvqRwgZqApVxQeYRCkub/14d2ea0bf162b413bf66c91794e2b34e/sapiens-5.jpg?w=115&h=174&q=50&fm=webp&fit=scale&f=center 115w,\n//images.ctfassets.net/xp88oy0wq1rq/1bgvqRwgZqApVxQeYRCkub/14d2ea0bf162b413bf66c91794e2b34e/sapiens-5.jpg?w=230&h=347&q=50&fm=webp&fit=scale&f=center 230w",
                      "sizes": "(min-width: 230px) 230px, 100vw",
                      "type": "image/webp"
                    }
                  ],
                  "fallback": {
                    "src": "//images.ctfassets.net/xp88oy0wq1rq/1bgvqRwgZqApVxQeYRCkub/14d2ea0bf162b413bf66c91794e2b34e/sapiens-5.jpg?w=230&h=347&fl=progressive&q=50&fm=jpg&fit=scale&f=center",
                    "srcSet": "//images.ctfassets.net/xp88oy0wq1rq/1bgvqRwgZqApVxQeYRCkub/14d2ea0bf162b413bf66c91794e2b34e/sapiens-5.jpg?w=58&h=88&fl=progressive&q=50&fm=jpg&fit=scale&f=center 58w,\n//images.ctfassets.net/xp88oy0wq1rq/1bgvqRwgZqApVxQeYRCkub/14d2ea0bf162b413bf66c91794e2b34e/sapiens-5.jpg?w=115&h=174&fl=progressive&q=50&fm=jpg&fit=scale&f=center 115w,\n//images.ctfassets.net/xp88oy0wq1rq/1bgvqRwgZqApVxQeYRCkub/14d2ea0bf162b413bf66c91794e2b34e/sapiens-5.jpg?w=230&h=347&fl=progressive&q=50&fm=jpg&fit=scale&f=center 230w",
                    "sizes": "(min-width: 230px) 230px, 100vw"
                  }
                },
                "layout": "constrained",
                "width": 230,
                "height": 347.2804532577903,
                "placeholder": {
                  "fallback": ""
                }
              }
            }
          }
        }
      ]
    }
  }
}

Any help or suggestion would be highly appreciated!

Upvotes: 2

Views: 779

Answers (1)

Ferran Buireu
Ferran Buireu

Reputation: 29320

Maybe is something wrong with ".getImage"

Definetely. getImage is a helper function that returns undefined if there's a null value (null-safe):

Safely get a gatsbyImageData object. It accepts several different sorts of objects, and is null-safe, returning undefined if the object passed, or any intermediate children are undefined.

I think you only need to provide the gatsbyImageData rather than the featuredImage node so your final code should look like:

getImage(post.node.featuredImage.gatsbyImageData)

Upvotes: 2

Related Questions