Skip to content

Commit

Permalink
get nodes by type
Browse files Browse the repository at this point in the history
  • Loading branch information
Asbjørn Lucassen committed Jun 3, 2020
1 parent 3f3162d commit 7580dc4
Show file tree
Hide file tree
Showing 2 changed files with 21 additions and 3 deletions.
16 changes: 16 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -205,3 +205,19 @@ resolvers : {
}
```
Now you can use the `featuredImage` data of `BlogPost` model without including all `Asset` models in the `elasticlunr` index [(see PR #3 for more details)](https://github.com/gatsby-contrib/gatsby-plugin-elasticlunr-search/pull/3).


You can now also resolve the gatsby store with ``getNodesByType`` and ``getNodes``
so the full signature of node resolving is this:
```
(node, getNode, getNodesByType, getNodes)
```
Documentation of all node helpers:

- [getNode](https://www.gatsbyjs.org/docs/node-api-helpers/#getNode)
- [getNodesByType](https://www.gatsbyjs.org/docs/node-api-helpers/#getNodesByType)
- [getNodes](https://www.gatsbyjs.org/docs/node-api-helpers/#getNodes)




8 changes: 5 additions & 3 deletions src/gatsby-node.js
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,8 @@ const createOrGetIndex = async (
node,
cache,
getNode,
getNodesByType,
getNodes,
server,
{ fields, resolvers }
) => {
Expand All @@ -65,7 +67,7 @@ const createOrGetIndex = async (
...Object.keys(fieldResolvers).reduce((prev, key) => {
return {
...prev,
[key]: fieldResolvers[key](pageNode, getNode),
[key]: fieldResolvers[key](pageNode, getNode, getNodesByType, getNodes),
}
}, {}),
}
Expand Down Expand Up @@ -116,7 +118,7 @@ exports.onCreateNode = ({ node, actions, getNode }, { resolvers, filter }) => {
}

exports.setFieldsOnGraphQLNodeType = (
{ type, getNode, cache },
{ type, getNode, getNodesByType, getNodes, cache },
pluginOptions
) => {
if (type.name !== SEARCH_INDEX_TYPE) {
Expand All @@ -127,7 +129,7 @@ exports.setFieldsOnGraphQLNodeType = (
index: {
type: SearchIndex,
resolve: (node, _opts, _3, server) =>
createOrGetIndex(node, cache, getNode, server, pluginOptions),
createOrGetIndex(node, cache, getNode, getNodesByType, getNodes, server, pluginOptions),
},
}
}

0 comments on commit 7580dc4

Please sign in to comment.