Changelog
0.0.34
- 
Features - Added --fixflag to automatically fix fixable diagnostics. The CLI can now automatically apply fixes for common issues like incorrect casing in docblock tags and deprecated tag usage. The--fixflag works with both single builds and watch mode.
- Built-in support for serialization/parsing of custom scalars. Grats' generated getSchemafunction now requires a config object which can include serialization/parsing functions for any custom scalars defined in your schema. See the docs for details.
- Added tsClientEnumsconfiguration option. WhentsClientEnumsis set, Grats will generate a TypeScript module containing all your GraphQL enum types as TypeScript enums for reuse in your client code.
 
- Added 
- 
Performance - We've added tooling for measuring and analyzing Grats' performance. This highlighted a number of optimization opportunities resulting in a ~20% reduction in build time for large schemas:
- Performance improvements from upgrading graphql-jstov16.11.0. (PR)
- Improved performance from more careful use of graphql-js's visitor API. (PR)
- Replaced some instances of graphql-js'svisit()with simpler functions. (PR)
 
- Performance improvements from upgrading 
 
- We've added tooling for measuring and analyzing Grats' performance. This highlighted a number of optimization opportunities resulting in a ~20% reduction in build time for large schemas:
- 
Improvements - Fixed watch mode issue where each build would write schema.tswhich would trigger a second build.
- Watch mode now responds changes to the Grats config.
- The error message which appears when no types are defined has been improved to allow schemas with any type (not just object types). This validation now also runs in watch mode to provide consistency with non-watch mode.
- Minor improvements to error messages.
- A blank line has been added after the headers in Grats' generated files.
- Grats now uses TypeScript v5.9.2 which should prevent errors when using TypeScript config options only available in newer versions.
- Grats now uses graphqlv16.11.0 which includes a number of performance improvements.
 
- Fixed watch mode issue where each build would write 
- 
Bug Fixes - Don't remove built-in directives in exported GraphQLSchemawhen custom directives are defined. (PR).
- Fix crash when a non-GraphQL type parameter is used before a GraphQL type parameter in a generic GraphQL type.
 
- Don't remove built-in directives in exported 
0.0.33
- Improvements
- Added support for @gqlUnions with only one member
- String literals used as enum values in argument defaults are modeled as enums in the generated schema, not strings.
- TypeScript enum values used as argument defaults are now supported.
- Added testing to confirm support for Node 22 and 23.
- Added support for aliased directive arguments with default values to enable arguments that are keywords in TypeScript.
 
- Added support for 
0.0.32
This version introduces support for defining directives, and annotating your schema with directives.
- 
Breaking Changes - The docblock tag @specifiedByhas been removed in favor of@gqlAnnotatewhich allows you to generically add directives to GraphQL schema constructs.- Replace @specifiedBy http://example.comwith@gqlAnnotate specifiedBy(url: "http://example.com")
 
- Replace 
- The docblock tag @oneOfhas been removed and Grats will now infer it.
 
- The docblock tag 
- 
Improvements - Remove superfluous argument name property from schema.ts
- Generated GraphQLSchemanow includes thespecifiedByURLproperty for custom scalars that use the@specifiedBydirective.
 
- Remove superfluous argument name property from 
0.0.31
Grats now supports Derived Context Values. These allow you to define a function which returns a different context value than the one root context provided by your main GraphQL server. It could be a fully unique value, or something derived from your root context.
Once defined, any resolver can define an argument typed using the derived resolver's function's return type, Grats will be able to provide that argument, just like it can provide the root context value.
/** @gqlContext */
type Ctx = { db: DB };
/** @gqlContext */
export function getDb(ctx: Ctx): DB {
  return ctx.db;
}
/**
 * A field which reads a derived context. Grats will invoke the above `getDb`
 * function and pass it to this resolver function.
 *
 * @gqlQueryField */
export function me(db: DB): string {
  return db.selectUser().name;
}
0.0.30
Root Field Tags
Fields on Query, Mutation and Subscription may now be defined using the new docblock tags @gqlQueryField, @gqlMutationField and @gqlSubscriptionField. These tags can be added to functions or static methods.
/** @gqlQueryField */
export function greeting(): string {
  return "Hello world";
}
- Features
- Custom error messages when types or interfaces are missing fields which suggests adding a @gqlFielddocblock tag.
- Custom error message when your project has no types defined. Intended to help guide new users.
 
- Custom error messages when types or interfaces are missing fields which suggests adding a 
- Improvements
- Better import deduplication in generated TypeScript code
 
0.0.29
- Bug Fixes
- Include semveras dependency inpackage.jsonwhich was accidentally only included as a dev dependency.
 
- Include 
0.0.28
Version 0.0.28 comes with a number of new features and should not have any breaking changes relative to 0.0.27. The new features:
Positional Arguments
Field arguments can now be defined using regular TypeScript arguments rather requiring all GraphQL arguments to be grouped together in a single object.
/** @gqlType */
class Query {
  /** @gqlField */
  userById(_: Query, id: string): User {
    return DB.getUserById(id);
  }
}
The improved ergonomics of this approach are especially evident when defining arguments with default values:
/** @gqlType */
class Query {
  // OLD STYLE
  /** @gqlField */
  greeting(_: Query, { salutation = "Hello" }: { salutation: string }): string {
    return `${salutation} World`;
  }
  // NEW STYLE
  /** @gqlField */
  greeting(_: Query, salutation: string = "Hello"): string {
    return `${salutation} World`;
  }
}
Arrow function fields
Fields can now be defined using arrow functions:
/** @gqlField */
export const userById = (_: Query, id: string): User => {
  return DB.getUserById(id);
};
Backtick strings
Backtick strings are now correctly parsed as strings literals, as long as they are not used as template strings. For example \Hello`` in the following example:
/** @gqlType */
class Query {
  /** @gqlField */
  greeting(_: Query, salutation: string = `Hello`): string {
    return `${salutation} World`;
  }
}
0.0.27
Version 0.0.27 comes with a number of new features as well as some minor breaking changes.
- Breaking
- Resolver parameters args,context, andinfomay now be used in any order, and are all optional. To enable this flexibility there are three small breaking changes, all of which will be reported with helpful errors when you rungrats#143:- The declaration of the type/class you use as your GraphQL context must now be annotated with @gqlContextto be recognized by Grats.
- If you access the infoobject in a resolver, you must type it usingGqlInfoexported fromgrats.
- Unused argsandcontextresolver parameters must now be omitted instead of being typed asunknown.
 
- The declaration of the type/class you use as your GraphQL context must now be annotated with 
 
- Resolver parameters 
- Features
- If a @gqlTypewhich is used in an abstract type is defined using an exportedclass, an explicit__typenameproperty is no-longer required. Grats can now generate code to infer the__typenamebased on the class definition. #144
- Support for @oneOfon input types. This allows you to define a discriminated union of input types. #146
 
- If a 
- Bug Fixes
- The experimental TypeScript plugin will now report a diagnostics if it encounters a TypeScript version mismatch. #143
 
0.0.26
- Features
- Code actions are now available to automatically fix some errors. These are available in the playground as well as in the experimental TypeScript plugin
- We now require that __typename = "SomeType"includeas constto ensure no other typename can be assigned. A code fix is available
- Fields can now be defined using static methods, similar to how fields can be defined using functions
- Adds importModuleSpecifierEndingconfiguration option to enable users generating ES modules to add the.jsfile extension to import paths in the generated TypeScript schema file
 
- Bug Fixes
- Reverted accidental breakage of the experimental TypeScript plugin
- Fixed a bug where we generated incorrect import paths on Windows
- Fixed a bug where incorrect resolver arguments were passed to method resolvers which provided custom names
 
0.0.25
- 
Features - Support for defining types using generics
 
- 
Documentation - An extensive example app showing many patterns used in a production app
 
0.0.24
- Features
- Support for @specifiedByon custom scalars
- Allow non-subscription fields to return AsyncIterableto enable@stream
 
- Support for 
0.0.23
- Features
- Allow an arg to be optional and not nullable if a default is provided
- Improve validation of config options
 
The Before Time
Before 0.0.23 release we don't have detailed changelogs.