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.
In short, with gql.tada
and GraphQLSP you get on-the-fly, automatically typed GraphQL documents
with full editor feedback, auto-completion, and type hints!
đ Documentation
Check out the âGet Startedâ sectionâs Installation page in the documentation.
- Get Started
- Introduction â everything you need to know
- Installation â an installation guide
- Writing GraphQL â how to write GraphQL documents
- API Reference
gql.tada
API âÂgql.tada
API Reference docs- GraphQLSP Config â GraphQLSP Configuration Reference docs
Furthermore, all APIs and packages are self-documented using TSDocs. If youâre using a language
server for TypeScript, the documentation for each API should pop up in your editor when hovering
gql.tada
âs code and APIs.
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]
);
đŠ Releases
If you'd like to get involved, check out our Contributor's guide.
All new releases and updates are listed on GitHub with full changelogs.
The CHANGELOG.md
file further documents all the historical changes for gql.tada
.
New releases are prepared using
changesets,
which are changelog entries added to each PR, and we have âVersion Packagesâ PRs that once merged
will release new versions of the gql.tada
package. You can use @canary
releases from npm
if youâd
like to get a preview of the merged changes.