Skip to content

Converts GraphQL files and schema definitions into ES Modules for use with the graphql-js-client

License

Notifications You must be signed in to change notification settings

Shopify/graphql-js-client-compiler

Repository files navigation

Travis

graphql-js-client-compiler

Converts GraphQL files and schema definitions into ES Modules for use with the graphql-js-client.

Table Of Contents

Installation

With Yarn:

$ yarn global add graphql-js-client-compiler

With NPM:

$ npm install -g graphql-js-client-compiler

Examples

CLI Usage

CLI Options

  • --help Print this usage guide.
  • --schema file The schema file to process. This can be in JSON (.json) or IDL (.graphql) format.
  • --outdir path default: "." The path to write the compiled files, preserving directory structure from the source. This path will be created if it does not exist.
  • --optimize Specifiy the "optimize" option to generate an optimized type bundle. This operation is slow and should only be used in production.

CLI Example

  1. Converting a bunch of graphql queries.
$ graphql-js-client-compiler queries/**/*.graphql some-other-query.graphql
  1. Convert a bunch of queries, and a schema.
$ graphql-js-client-compiler --schema schema.graphql queries/**/*.graphql
  1. Complete example: Convert a bunch of queries, a schema, and optimize the schema output for only used types.
$ graphql-js-client-compiler --outdir src --schema schema.graphql --optimize queries/**/*.graphql

Fragments

Documents may reference fragments outside of the current .graphql file. For example:

query ($id: ID!) {
  node(id: $id) {
    ...ProductFragment
  }
}

If ProductFragment isn't in the .graphql file, the compiler will search for a file called ProductFragment.graphql in the same directory. This allows fragments to be recycled between documents.

API

This library exports several functions that can transform schemas and documents into ES modules.

import {
  compileToModule,
  compileOptimizedSchemaJson,
  compileOptimizedSchemaIDL,
  compileSchemaJson,
  compileSchemaIDL
} from '../src/index';

Compile a Query

import {writeFileSync} from 'fs';
import {compileToModule} from 'graphql-js-client-compiler';

const code = compileToModule(`
query {
  shop {
   name
  }
}
`);

writeFileSync('query.js', code);

This will generate a file, that's importable, and invocable with the GraphQL JS Client:

import query from 'query';

...

client.send(query).then({model} => console.log(model));

Other Functions

  • compileSchemaJson(schemaJson, {profile = null} = {}) Transforms a JSON schema into the javascript code for an ES module expressing all types in the schema.
    • schemaJson: The JSON string of a schema file.
    • profile: (optional) The profile returned by GraphQL JS Client's profiler.
    • returns: javascript code
  • compileSchemaIDL(schemaIDL, {profile = null} = {}) Transforms an IDL schema into the javascript code for an ES module expressing all types in the schema.
    • schemaIDL: The IDL string of a schema file.
    • profile: (optional) The profile returned by GraphQL JS Client's profiler.
    • returns: javascript code
  • compileOptimizedSchemaJson(schemaJson, {documents}) Transforms a JSON schema into the javascript code for an ES module expressing only the types found in the passed documents.
    • schemaJson: The JSON string of a schema file.
    • documents: an array of GraphQL documents as text.
    • returns: javascript code
  • compileOptimizedSchemaIDL(schemaIDL, {documents}) Transforms an IDL schema into the javascript code for an ES module expressing only the types found in the passed documents.
    • schemaIDL: The IDL string of a schema file.
    • documents: an array of GraphQL documents as text.
    • returns: javascript code

Complete example

This example demonstrates transforming a directory of GraphQL queries, and a GraphQL schema into code, and consuming it with the GraphQL JS Client.

Compilation

$ graphql-js-client-compiler --outdir src --schema graphql/schema.graphql --optimize graphql/**/*.graphql

Consumption

src/index.js:

import Client from 'graphql-js-client';
import types from './schema';
import productQuery from './graphql/product-query';

const client = new Client(types, {url: 'https://my-api.com/graphql');

client.send(productQuery).then({model} => {
  console.log(model);
});

License

MIT, see LICENSE.md for details.

About

Converts GraphQL files and schema definitions into ES Modules for use with the graphql-js-client

Resources

License

Code of conduct

Security policy

Stars

Watchers

Forks

Packages

No packages published

Contributors 3

  •  
  •  
  •