Skip to content
forked from 0no-co/gql.tada

🪄 Magical GraphQL query engine for TypeScript

License

Notifications You must be signed in to change notification settings

benjie/gql.tada

Repository files navigation

gql.tada 🪄

Magical GraphQL query engine for TypeScript

CI Status Discord

gql.tada is a GraphQL document authoring library, inferring the result and variables types of GraphQL queries and fragments in the TypeScript type system. It derives the types for your GraphQL queries on the fly allowing you to write type-safe GraphQL documents quickly.

In short, gql.tada,

  • parses your GraphQL documents in the TypeScript type system
  • uses your introspected schema and scalar configuration to derive a schema
  • maps your GraphQL queries and fragments with the schema to result and variables types
  • creates fragment masks and enforces unwrapping fragments gradually

Since this is all done in the TypeScript type system and type checker, this all happens while you edit your GraphQL front-end code and is always accurate.

Let’s take a look!

import { graphql } from 'gql.tada';
import { myIntrospectionQuery } from './fixtures/introspection';

// We can declare our introspected schema once globally
declare module 'gql.tada' {
  interface setupSchema {
    introspection: typeof myIntrospectionQuery;
  }
}

// Creates fragment documents
const fragment = graphql(`
  fragment HelloWorld extends Query {
    hello
    world
  }
`);

// Creates queries, optionally accepting a list of fragments for fragment spreads
const query = graphql(
  `
    {
      hello
      ...HelloWorld
    }
  `,
  [fragment]
);

💾 Setup

Install gql.tada using your project’s package manager,

npm i gql.tada
pnpm add graphql
yarn add gql.tada
bun add graphql

gql.tada infers the types of your queries. However, it can’t provide you with editor feedback, like autocompletion, diagnostics & errors, and hover information inside GraphQL queries. For the best experience, it’s recommended to install GraphQLSP to supplement these features.

Install @0no-co/graphqlsp as a dev dependency,

npm i -D gql.tada
pnpm add -D graphql
yarn add --dev gql.tada
bun add --dev graphql

Then, update your tsconfig.json to enable the graphqlsp plugin in your TypeScript server,

tsconfig.json

{
  "compilerOptions": {
+    "plugins": [
+      {
+        "name": "@0no-co/graphqlsp",
+        "schema": "./schema.graphql"
+      }
+    ]
  }
}

Note: If you are using VSCode, you may want to update your .vscode/config.json file to use the use the workspace version of TypeScript automatically.

.vscode/config.json

{
+  "typescript.tsdk": "node_modules/typescript/lib",
+  "typescript.enablePromptUseWorkspaceTsdk": true
}

About

🪄 Magical GraphQL query engine for TypeScript

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • TypeScript 98.2%
  • MDX 1.3%
  • Other 0.5%