Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/gajus/babel-plugin-graphql-tag
Compiles GraphQL tagged template strings using graphql-tag.
https://github.com/gajus/babel-plugin-graphql-tag
babel-plugin graphql graphql-tag
Last synced: 5 days ago
JSON representation
Compiles GraphQL tagged template strings using graphql-tag.
- Host: GitHub
- URL: https://github.com/gajus/babel-plugin-graphql-tag
- Owner: gajus
- License: other
- Created: 2017-05-30T07:21:08.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2022-03-04T10:17:43.000Z (almost 3 years ago)
- Last Synced: 2024-10-30T05:54:13.163Z (about 2 months ago)
- Topics: babel-plugin, graphql, graphql-tag
- Language: JavaScript
- Size: 305 KB
- Stars: 172
- Watchers: 3
- Forks: 28
- Open Issues: 10
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
README
# babel-plugin-graphql-tag
[![GitSpo Mentions](https://gitspo.com/badges/mentions/gajus/babel-plugin-graphql-tag?style=flat-square)](https://gitspo.com/mentions/gajus/babel-plugin-graphql-tag)
[![Travis build status](http://img.shields.io/travis/gajus/babel-plugin-graphql-tag/master.svg?style=flat-square)](https://travis-ci.org/gajus/babel-plugin-graphql-tag)
[![NPM version](http://img.shields.io/npm/v/babel-plugin-graphql-tag.svg?style=flat-square)](https://www.npmjs.org/package/babel-plugin-graphql-tag)
[![Canonical Code Style](https://img.shields.io/badge/code%20style-canonical-blue.svg?style=flat-square)](https://github.com/gajus/canonical)
[![Twitter Follow](https://img.shields.io/twitter/follow/kuizinas.svg?style=social&label=Follow)](https://twitter.com/kuizinas)Compiles GraphQL tagged template strings using [graphql-tag](https://github.com/apollographql/graphql-tag).
## Motivation
Compiling GraphQL queries at the build time:
* reduces the script initialization time; and
* removes the `graphql-tag` dependencyRemoving the `graphql-tag` dependency from the bundle saves approx. 50 KB.
## Implementation
* Searches for imports of `graphql-tag` and removes them.
* Searches for [tagged template literals](https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Template_literals) with `gql` identifier and compiles them using `graphql-tag`.## Example compilation
Input:
```js
import gql from 'graphql-tag';
// if using apollo v3
import { gql } from '@apollo/client';const foo = gql`query {bar}`;
```
Output:
```js
const foo = {
"definitions": [
{
"directives": [
],
"kind": "OperationDefinition",
"operation": "query",
"selectionSet": {
"kind": "SelectionSet",
"selections": [
{
"alias": null,
"arguments": [
],
"directives": [
],
"kind": "Field",
"name": {
"kind": "Name",
"value": "bar"
},
"selectionSet": null
}
]
},
"variableDefinitions": [
]
}
],
"kind": "Document",
"loc": {
"end": 11,
"start": 0
}
};```
**NOTE: require() is also supported.**
### Using fragments
Using GraphQL [fragments](http://graphql.org/learn/queries/#fragments) requires to:
1. Define a fragment using `graphql-tag`.
2. Append the referenced fragment as a variable to the end of the GraphQL query.Example:
```js
import gql from 'graphql-tag';const bar = gql`
fragment barFragment on Foo {
field1
field2
}
`;const foo = gql`
query foo {
foo {
...barFragment
}
}${bar}
`;```
### Options
- `importSources` - An array of names for modules to import (default = `["graphql-tag", "@apollo/client"]`)
- `onlyMatchImportSuffix` - Matches the end of the import instead of the entire name. Useful for relative imports, e.g. `./utils/graphql` (default = false)
- `strip` - Strips insignificant characters such as whitespace from the original GraphQL string literal to reduce the size of compiled AST (default = false)
- `transform` - By default, graphql query strings will be replaced with their AST representations, but you can override that behavior and do whatever you like. One possible use case would be to implement persisted queries:
- `gqlTagIdentifiers` - An array of names for gql tag identifiers (default = `["gql"]`)```js
// babel.config.js
plugins: [
[
"babel-plugin-graphql-tag",
{
strip: true,
transform: (source, ast) => {
const h = hash(source); // use your favorite hashing method
graphqlAstHashes[h] = ast; // write this to a file when compilation is complete
return {
queryId: h
};
}
}
]
]
```### Known Issues
Some cases are really hard to track down:
```
const apolloClient = require('@apollo/client');
// or
import apolloClient from '@apollo/client';const { gql } = apolloClient;
const foo = gql`...`;
```If you have this kind of syntax, this plugin won't work for you.