graphql-typings-loader

1.1.3 • Public • Published

graphql-typings-loader

Webpack loader to generate TS typings of graphql files as d.ts file alongside source file. Uses apollo-codegen under the hood. Supports #import syntax. If d.ts file contains GraphQL enums, they are also extracted to [filename].types.ts file so they can be used in TS code.


To use this loader add it to chain before any graphql loader which outputs document in JS.
{
  test: /\.graphql$/,
  use: [
    'graphql-tag/loader'
    'graphql-typings-loader',
  ],
}

By default it tries to read './schema.json' in the current working directory (directory from which webpack was run). If it does not exist, it outputs nothing.

You can create .graphqltypings.js config file in the current working directory. It supports following:

{
    schema: "string | filename to read schema from,
        default: ./schema.json",

    legacy: "boolean | uses apollo-codegen-typescript-legacy when true instead of apollo-codegen-typescript,
        default: false,

    options: "object | options for apollo-codegen-typescript,
        default: {
            addTypename: true,
            mergeInFieldsFromFragmentSpreads: true,
            passthroughCustomScalars: true,
            customScalarsPrefix: 'GraphQLScalar'," 
        }
}

By default custom graphql scalars have prefix 'GraphQLScalar'. You can that create graphql-scalars.d.ts file in your root directory with mappings to ts(js) types.

graphql-scalars.d.ts

type GraphQLScalarUpload = File | Blob; 
type GraphQLScalarDateTime = string;

Readme

Keywords

none

Package Sidebar

Install

npm i graphql-typings-loader

Weekly Downloads

1

Version

1.1.3

License

MIT

Unpacked Size

21 kB

Total Files

5

Last publish

Collaborators

  • pristas-peter