2

https://github.com/algolia/gatsby-plugin-algolia

当我运行构建(不填充我的 algolia 索引)时,这个插件似乎在我的 gatsby-config 中不起作用——我已经使用 algoliasearch 和 json 文件将数据推送到我的索引中,但我想要这个每当我构建时自动连接 - 因此数据始终与我的可播放数据保持同步。

我已经通过 github 上的文档(放在我的 gatsby-config.js 文件中)尝试了“gatsby-plugin-algolia”方法

const myQuery = `{
  allSitePage {
    edges {
      node {
        # try to find a unique id for each node
        # if this field is absent, it's going to
        # be inserted by Algolia automatically
        # and will be less simple to update etc.
        objectID: id
        component
        path
        componentChunkName
        jsonName
        internal {
          type
          contentDigest
          owner
        }
      }
    }
  }
}`;

const queries = [
  {
    query: myQuery,
    transformer: ({ data }) => data.allSitePage.edges.map(({ node }) => node), 
    indexName: 'cardDemo',
  },
];

module.exports = {
  plugins: [
        {
      resolve: 'gatsby-source-airtable-linked',
      options: {
        apiKey: process.env.MY_API_KEY,
        tables: [
          {
            baseId: process.env.MY_BASE_ID,
            tableName: 'Streams',
            tableView: 'DO NOT MODIFY',
          },
        ],
      },
    },
    {
      resolve: 'gatsby-plugin-algolia',
      options: {
        appId: process.env.MY_AGOLIA_APP_ID,
        apiKey: process.env.MY_AGOLIA_API_KEY,
        indexName: 'cardDemo',
        queries,
        chunkSize: 1000000,
      },
    },
  ],
};

我还通过 airtable 在组件上使用了更具体的实例的“myQuery”,如下所示

const myQuery = `{
      items: allAirtableLinked(
      filter: {
        table: { eq: "Items" }
      }
    ) {
      edges {
        node {
          id
          data {
            title
            thumbnail_url
            thumbnail_alt_text
            url_slug
            uberflip_stream_id
            uberflip_id
          }
        }
      }
    }
    }`;

如果有人让这个插件运行和工作——我绝对可以使用一些提示来了解如何让它工作(这个包上没有太多文档)

谢谢你!

4

1 回答 1

3

弄清楚了!遇到同样问题的任何人,请执行以下步骤:

  1. 检查您是否拥有正确的 API 密钥
  2. 检查转换器方法是否更改以匹配在 graphql 中查询的对象。我的不得不改成这样:

transformer: ({ data }) => data.items.edges.map(({ node }) => node) 

  1. 检查您的查询在 graphql 中是否有效,确保它在语法上正确,并且正在提取正确的数据。我使用的查询是

const pageQuery = `query {
  items: allAirtableLinked(
    filter: {
      table: { eq: "Items" }
      data: { hubs: { eq: "cf4ao8fjzn4xsRrD" } }
    }
  ) {
    edges {
      node {
        id
        data {
          title
          thumbnail_url
          thumbnail_alt_text
          duration
          url_slug
          asset_type
          uberflip_stream_id
          uberflip_id
        }
      }
    }
  }
}`;

  1. 最后,如果您将查询和查询抽象到 src 中的 ultil 目录中,它会更干净,然后将其放入配置文件中,这样会更干净:

我从这个回购中得到了这个想法,非常有帮助!看看这个例子

于 2018-10-12T17:43:02.740 回答