@sewing-kit/graphql
This package provides transformers for importing .graphql files in various build tools.
Installation
yarn add @sewing-kit/graphql --dev
Usage
Webpack
This package provides a loader for .graphql
files in Webpack. This loader automatically minifies and adds a unique identifier to each GraphQL document.
To use this loader in Webpack, add a rule referencing this loader to your Webpack configuration:
module.exports = {
module: {
rules: [
{
test: /\.graphql$/,
use: '@sewing-kit/graphql/webpack',
exclude: /node_modules/,
},
],
},
};
Note that, unlike graphql-tag/loader
, this loader does not currently support exporting multiple operations from a single file. You can, however, import other GraphQL documents containing fragments with #import
comments at the top of the file:
query Product {
product {
variants(first: 10) {
edges {
node {
...ProductVariantId
...ProductVariantPrice
}
}
}
}
}
fragment ProductVariantId on ProductVariant {
id
}
Options
This loader accepts a single option, export
. This option controls the shape of the value exported from GraphQL files. By default, a graphql
DocumentNode
is exported. However, setting export: 'simple'
will instead export a representation of the document that contains only the source
, operationNode
, and unique id
for the document. This representation of GraphQL documents is smaller than a full DocumentNode
, but generally won’t work with normalized GraphQL caches.
module.exports = {
module: {
rules: [
{
test: /\.(graphql|gql)$/,
use: '@sewing-kit/graphql/webpack',
exclude: /node_modules/,
options: {export: 'simple'},
},
],
},
};
If this option is set to true
, you should also use the jest-simple
transformer for Jest, and the --export-format simple
flag for graphql-typescript-definitions
.
Jest
This package also provides a transformer for GraphQL files in Jest. To use the transformer, add a reference to it in your Jest configuration’s transform
option:
module.exports = {
transform: {
'\\.graphql$': '@sewing-kit/graphql/jest',
},
};
If you want to get the same output as the simple
option of the webpack loader, you can instead use the jest-simple
loader transformer:
module.exports = {
transform: {
'\\.graphql$': '@sewing-kit/graphql/jest-simple',
},
};
Prior art
This loader takes heavy inspiration from the following projects:
We wrote something custom in order to get the following benefits:
- Significantly smaller output with no runtime
- Automatically-generated document identifiers