Использование Isotope.js с React для создания макета кладки с фильтрами? - PullRequest
1 голос
/ 09 мая 2019

Я создаю блог с Гэтсби и пытаюсь реализовать кладочную сетку с фильтрами для отображения моих сообщений.Раньше я делал это с помощью Isotope.js, поэтому я пошел с этим снова.Но это на самом деле не работает.Я все еще очень плохо знаком с React, поэтому не могу понять, что не так.

Я получаю эту ошибку: TypeError: Cannot read property 'map' of undefined

import React from 'react';
import Img from 'gatsby-image';
import { Link, StaticQuery } from 'gatsby';
import Isotope from "isotope-layout/js/isotope";
import PropTypes from 'prop-types';

class FilterGrid extends React.Component {
  constructor(props) {
    super(props);
    this.onFilterChange = this.onFilterChange.bind(this);
  }

  // Click Function
  onFilterChange = (newFilter) => {
    if (this.iso === undefined) {
      this.iso = new Isotope('#grid-container', {
        itemSelector: '.grid-item',
        layoutMode: "fitRows",
        percentPosition: true,
        fitRows: {
          gutter: '.gutter-sizer'
        }
      });
    }
    if(newFilter === '*') {
      this.iso.arrange({ filter: `*` });
    } else {
      this.iso.arrange({ filter: `.${newFilter}` });
    }
  }

  render() {
    const posts = this.props.data.allMarkdownRemark.node

    return(
      // Filter Buttons
      <section className="section">
        <div className="button-group filter-button-group grid-filters">
          <div className="tabs is-centered is-toggle">
            <ul id="portfolio-flters">
              <li data-filter="*" onClick={() => {this.onFilterChange("*")}}>All</li>
              <li data-filter="brandy" onClick={() => {this.onFilterChange("brandy")}}>Brandy</li>
              <li data-filter="cachaça" onClick={() => {this.onFilterChange("cachaça")}}>Cachaça</li>
              <li data-filter="gin" onClick={() => {this.onFilterChange("gin")}}>Gin</li>
              <li data-filter="mexcal" onClick={() => {this.onFilterChange("mezcal")}}>Mezcal</li>
              <li data-filter="rum" onClick={() => {this.onFilterChange("rum")}}>Rum</li>
              <li data-filter="tequila" onClick={() => {this.onFilterChange("tequila")}}>Tequila</li>
              <li data-filter="whiskey" onClick={() => {this.onFilterChange("whiskey")}}>Whiskey</li>
              <li data-filter="vodka" onClick={() => {this.onFilterChange("vodka")}}>Vodka</li>
            </ul>
          </div>
        </div>

      <div className="grid" id="grid-container">
        <div className="grid-sizer"></div>
        <div className="gutter-sizer"></div>
        {posts.map(post => (
          <div className="grid-item {post.frontmatter.category}">
              <Link to={post.fields.slug}>
                  <figure className="image">
                      <Img fluid={post.frontmatter.image.childImageSharp.fluid} />
                      <figcaption>
                          <h4 className="title is-4">{post.frontmatter.title}</h4>
                      <p className="grid-item-blurb">{post.frontmatter.description}</p>
                      </figcaption>
                  </figure>
              </Link>
          </div>
        ))}
      </div>
    </section>
    )
  }
}

FilterGrid.propTypes = {
  data: PropTypes.shape({
    allMarkdownRemark: PropTypes.shape({
      edges: PropTypes.array,
    }),
  }),
}

export default () => (
  <StaticQuery
    query = {graphql`
      query FilterGridQuery {
        allMarkdownRemark (
          sort: { fields: [frontmatter___date], order: DESC}
          filter: { frontmatter: {templateKey: {eq: "recipe"}}}
          ) {
        edges{
          node{
            id
            frontmatter {
               title
               date
               description
               image {
                 childImageSharp {
                   resize(width: 1500, height: 1500) {
                     src
                   }
                   fluid(maxWidth: 786) {
                     ...GatsbyImageSharpFluid
                   }
                 }
               }
            }
            fields {
              slug
            }
          }
        }
      }
    }
  `}
  render={(data, count) => <FilterGrid data={data} count={count} />}
  />

)

Я только пытаюсь использоватьIsotope.js, потому что я использовал его раньше, но если есть лучший способ сделать это, пожалуйста, дайте мне знать!Это сводит меня с ума!

Заранее спасибо!

1 Ответ

0 голосов
/ 09 мая 2019

В этой строке

const posts = this.props.data.allMarkdownRemark.node

Разве вы не хотели получить allMarkdownRemark.edges вместо этого?allMarkdownRemark.node определенно не определено.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...