Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/trevorblades/gatsby-plugin-apollo
🧁 Set up your Gatsby project to use Apollo
https://github.com/trevorblades/gatsby-plugin-apollo
apollo apollo-client gatsby gatsby-plugin graphql react
Last synced: 3 months ago
JSON representation
🧁 Set up your Gatsby project to use Apollo
- Host: GitHub
- URL: https://github.com/trevorblades/gatsby-plugin-apollo
- Owner: trevorblades
- License: mit
- Created: 2019-03-01T03:18:30.000Z (almost 6 years ago)
- Default Branch: main
- Last Pushed: 2023-01-07T03:27:55.000Z (about 2 years ago)
- Last Synced: 2024-10-12T13:14:22.742Z (3 months ago)
- Topics: apollo, apollo-client, gatsby, gatsby-plugin, graphql, react
- Language: JavaScript
- Homepage: https://gatsbyjs.org/packages/gatsby-plugin-apollo/
- Size: 266 KB
- Stars: 11
- Watchers: 1
- Forks: 0
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# gatsby-plugin-apollo
This plugin sets up your Gatsby project to use [Apollo Client](https://www.apollographql.com/docs/react). It wraps your app in an `ApolloProvider` so that you can use GraphQL queries and mutations in your components.
```js
import {useQuery} from '@apollo/client';function Cupcake() {
const {data, loading, error} = useQuery(GET_CUPCAKE); // <-- just works
}
```> To learn all about GraphQL and Apollo, check out the [Lift-off course](https://odyssey.apollographql.com/lift-off-part1/) on Odyssey, Apollo's learning platform.
- [Installation](#installation)
- [Configuration](#configuration)
- [Plugin options](#plugin-options)
- [Client shadowing](#client-shadowing)
- [License](#license)## Installation
To use this plugin, you'll also need to install your own copy of `@apollo/client`. This package exports all of the tools you'll need to make GraphQL queries in your app.
```bash
npm install gatsby-plugin-apollo @apollo/client graphql
```Once installed, add the plugin to your Gatsby config.
```js
// gatsby-config.js
module.exports = {
plugins: ['gatsby-plugin-apollo']
};
```## Configuration
This plugin supports two methods of configuration:
- [Installation](#installation)
- [Configuration](#configuration)
- [Plugin options](#plugin-options)
- [Client shadowing](#client-shadowing)
- [License](#license)### Plugin options
For simple configurations, you can supply many of the [`ApolloClient` constructor options](https://www.apollographql.com/docs/react/api/core/ApolloClient/#options) directly to the plugin in your Gatsby config.
```js
// gatsby-config.js
module.exports = {
plugins: [
{
resolve: 'gatsby-plugin-apollo',
options: {
uri: 'https://example.com/graphql'
}
}
]
};
```Due to [a limitation](https://www.gatsbyjs.com/docs/how-to/plugins-and-themes/configuring-usage-with-plugin-options/#what-can-be-passed-in-as-options) on the types of options that can be passed to a Gatsby plugin, only certain constructor options can be passed as plugin options. Options that require an instance of a JavaScript class, like `cache` or `link` can't be serialized as JSON, so they can't be configured in this way.
For more complex configurations, the [client shadowing](#client-shadowing) method allows you to define your own custom Apollo Client instance to be used by the plugin.
### Client shadowing
You can configure this plugin to use your own custom Apollo Client instance by creating a `client.js` file in `src/gatsby-plugin-apollo` that exports your client. You can create your client however you like, as long as you remember these important details:
1. You must provide an isomorphic fetch implementation (such as `isomorphic-fetch`) as an option to `HttpLink`
2. Your client instance must be the default export```js
// src/gatsby-plugin-apollo/client.js
import fetch from 'isomorphic-fetch';
import {ApolloClient, HttpLink, InMemoryCache} from '@apollo/client';const client = new ApolloClient({
cache: new InMemoryCache(),
link: new HttpLink({
uri: 'https://api.spacex.land/graphql/',
fetch
})
});export default client;
```This configuration method should be used if you need to customize your cache or use a complex link, such as [sending a JWT](https://www.apollographql.com/docs/react/networking/advanced-http-networking/#customizing-request-logic) along with every request or [enabling subscriptions](https://www.apollographql.com/docs/react/data/subscriptions/#3-split-communication-by-operation-recommended) using a `WebSocketLink`.
## License
[MIT](./LICENSE)