Skip to content

Commit

Permalink
Refactor GraphQL*Type TS types to be more DRY
Browse files Browse the repository at this point in the history
Motivation:
1.  Makes it easier to understand the type hierarchy.
2. Adding a new type, were it ever to happen, would require fewer code changes.

Depends on #3597
  • Loading branch information
yaacovCR committed May 19, 2022
1 parent c526767 commit b97fe0a
Showing 1 changed file with 5 additions and 31 deletions.
36 changes: 5 additions & 31 deletions src/type/definition.ts
Original file line number Diff line number Diff line change
Expand Up @@ -51,22 +51,9 @@ import type { GraphQLSchema } from './schema';
* These are all of the possible kinds of types.
*/
export type GraphQLType =
| GraphQLScalarType
| GraphQLObjectType
| GraphQLInterfaceType
| GraphQLUnionType
| GraphQLEnumType
| GraphQLInputObjectType
| GraphQLNamedType
| GraphQLList<GraphQLType>
| GraphQLNonNull<
| GraphQLScalarType
| GraphQLObjectType
| GraphQLInterfaceType
| GraphQLUnionType
| GraphQLEnumType
| GraphQLInputObjectType
| GraphQLList<GraphQLType>
>;
| GraphQLNonNull<GraphQLNullableType>;

export function isType(type: unknown): type is GraphQLType {
return (
Expand Down Expand Up @@ -207,9 +194,7 @@ export function assertNonNullType(type: unknown): GraphQLNonNull<GraphQLType> {
* These types may be used as input types for arguments and directives.
*/
export type GraphQLNullableInputType =
| GraphQLScalarType
| GraphQLEnumType
| GraphQLInputObjectType
| GraphQLNamedInputType
| GraphQLList<GraphQLInputType>;

export type GraphQLInputType =
Expand All @@ -236,11 +221,7 @@ export function assertInputType(type: unknown): GraphQLInputType {
* These types may be used as output types as the result of fields.
*/
export type GraphQLNullableOutputType =
| GraphQLScalarType
| GraphQLObjectType
| GraphQLInterfaceType
| GraphQLUnionType
| GraphQLEnumType
| GraphQLNamedOutputType
| GraphQLList<GraphQLOutputType>;

export type GraphQLOutputType =
Expand Down Expand Up @@ -430,14 +411,7 @@ export function assertWrappingType(type: unknown): GraphQLWrappingType {
/**
* These types can all accept null as a value.
*/
export type GraphQLNullableType =
| GraphQLScalarType
| GraphQLObjectType
| GraphQLInterfaceType
| GraphQLUnionType
| GraphQLEnumType
| GraphQLInputObjectType
| GraphQLList<GraphQLType>;
export type GraphQLNullableType = GraphQLNamedType | GraphQLList<GraphQLType>;

export function isNullableType(type: unknown): type is GraphQLNullableType {
return isType(type) && !isNonNullType(type);
Expand Down

0 comments on commit b97fe0a

Please sign in to comment.