Skip to content
forked from remorses/genql

Type safe TypeScript client for any GraphQL API

License

Notifications You must be signed in to change notification settings

wellguimaraes/genql

This branch is 5 commits ahead of, 40 commits behind remorses/genql:master.

Folders and files

NameName
Last commit message
Last commit date

Latest commit

c7f2b3d Β· Nov 20, 2023
Apr 5, 2023
Sep 3, 2020
Nov 20, 2023
Aug 10, 2023
Aug 10, 2023
Apr 5, 2023
Sep 26, 2023
May 14, 2020
Apr 24, 2023
Feb 14, 2023
Jul 22, 2023
Mar 23, 2022
Jun 18, 2020
Mar 23, 2022
Apr 29, 2023
Feb 14, 2023
Apr 28, 2023
Feb 12, 2023

Repository files navigation





Type safe Graphql query builder

Write Graphql queries with type validation and auto completion



Read the quick start guide to generate your client and start writing queries.

You can stay up to date with the latest changes subscribing to the Genql changelog.

Features

Example

First generate your client with the genql cli.

You can find other cli options here

npm i -D @genql/cli # cli to generate the client code
genql --schema ./schema.graphql --output ./generated

Then you can use your client as follow

import { createClient, everything } from './generated'
const client = createClient()

client
    .query({
        countries: {
            // pass arguments to the query
            __args: {
                filter: {
                    currency: {
                        eq: 'EUR',
                    },
                },
            },
            name: true,
            code: true,
            nestedField: {
                // fetch all scalar fields
                __scalar: true,
            },
        },
    })
    .then(console.log)

The code above will fetch the graphql query below

query {
    countries(filter: { currency: { eq: "EUR" } }) {
        name
        code
        nestedField {
            scalarField1
            scalarField2
        }
    }
}

Why

Genql has a lot of benefits over writing graphql queries by hand:

  • Writing queries is faster thanks to TypeScript auto completion
  • You can safely update your schema and be sure your queries are still valid
  • You can fetch all scalar fields in a type with __scalar: true
  • No graphql package dependency, no runtime parsing of queries
  • You have to generate the client only after your schema changes, not after every query change

Sponsors

Notaku

Notaku

Vercel


Licensed under MIT.

About

Type safe TypeScript client for any GraphQL API

Resources

License

Code of conduct

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • TypeScript 95.6%
  • MDX 2.9%
  • JavaScript 1.5%