Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/kdby-io/graphql-typescript
Define and build GraphQL Schemas using typed classes
https://github.com/kdby-io/graphql-typescript
annotations decorators graphql graphql-schema graphql-typescript typescript
Last synced: 3 months ago
JSON representation
Define and build GraphQL Schemas using typed classes
- Host: GitHub
- URL: https://github.com/kdby-io/graphql-typescript
- Owner: kdby-io
- License: mit
- Created: 2018-02-03T16:49:24.000Z (almost 7 years ago)
- Default Branch: master
- Last Pushed: 2019-01-21T13:15:01.000Z (about 6 years ago)
- Last Synced: 2024-10-01T08:41:36.782Z (4 months ago)
- Topics: annotations, decorators, graphql, graphql-schema, graphql-typescript, typescript
- Language: TypeScript
- Homepage:
- Size: 112 KB
- Stars: 67
- Watchers: 4
- Forks: 3
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# graphql-typescript [![npm](https://img.shields.io/npm/v/graphql-typescript.svg?style=flat-square)](https://www.npmjs.com/package/graphql-typescript) [![npm](https://img.shields.io/npm/dt/graphql-typescript.svg?style=flat-square)](https://www.npmjs.com/package/graphql-typescript) [![CircleCI token](https://img.shields.io/circleci/token/13928c03d7e040db692e4a58e8a387a856d12fd7/project/github/pueue/graphql-typescript/master.svg?style=flat-square)](https://circleci.com/gh/pueue/graphql-typescript/tree/master) [![Coveralls github](https://img.shields.io/coveralls/github/pueue/graphql-typescript/master.svg?style=flat-square)](https://coveralls.io/github/pueue/graphql-typescript?branch=master) [![dependencies Status](https://david-dm.org/pueue/graphql-typescript/status.svg?style=flat-square)](https://david-dm.org/pueue/graphql-typescript)
Define and build GraphQL Schemas using typed classes
- [Type definition](#type-definition)
+ [`@Type`](#@type)
+ [`@Field`](#@field)
+ [`@Mutation`](#@mutation)
+ [`@Nullable`](#@nullable)
+ [`@Input`](#@input)
+ [Scalar types](#scalar-types)
- [Arguments](#arguments)
- [Generating GraphQL Schema](#generating-graphql-schema)```ts
import { Type, Field, Nullable, Mutation, String, Boolean, Int, makeSchema } from 'graphql-typescript'@Type class Query {
@Field(() => Box) box: Box
}class UnboxArguments {
@Field(() => [String]) tools: string[]
}@Type class Box {
@Field(() => Size)
size: Size@Nullable
@Field(() => String)
content: string@Mutation(() => Boolean)
unbox(box: BoxModel, args: UnboxArguments, context: any) { ... }
}@Type class Size {
@Field(() => Int) height: number
@Field(() => Int) width: number
@Field(() => Int) length: number
}const schema = makeSchema(Query, {
types: [Size, Box]
})
``````graphql
type Query {
box: Box!
}type Mutation {
unbox(tools: [String]!): Boolean!
}type Box {
size: Size!
content: String
}type Size {
height: Int!
width: Int!
length: Int!
}
```### Prerequisites
Set decorator flags in your `tsconfig.json`
```json
"experimentalDecorators": true,
"emitDecoratorMetadata": true
```### Installing
```
npm install -S graphql
npm install -S graphql-typescript
```## Type Definition
### `@Type`
Adding `@Type` to a class definition defines [GraphQL object type](http://graphql.org/learn/schema/#object-types-and-fields).
```ts
@Type class Character {
@Field(() => String) name: string
@Field(() => [Episode]) appearsIn: Episode[]
}
``````graphql
type Character {
name: String!
appearsIn: [Episode]!
}
```### `@Field`
Adding `@Field` to properties or methods of a `@Type` decorated class defines what fields it has.
```ts
@Type
class Hello {
@Field(() => String)
a: string@Field(() => [String])
b: string[]@Field(() => String)
c(_:any, _args: any, context: any) { ... }
}
``````graphql
type Hello {
a: String!
b: [String]!
c: String!
}
```### `@Mutation`
Adding `@Mutation` to methods of a `@Type` decorated class defines a mutation. No matter which class it is in, it will come under [mutation type](http://graphql.org/learn/schema/#the-query-and-mutation-types).
```ts
class Argument {
@Field(() => [Int]) world: number[]
}@Type
class Hello {
@Mutation(() => String)
a(_: any, _args: any, context: any) { ... }@Mutation(() => [String])
b(_: any, _args: any, context: any) { ... }@Mutation(() => String)
c(_: any, args: Argument, context: any) { ... }
}
``````graphql
type Mutation {
...
a: String!
b: [String]!
c(world: [Int]!): String!
}
```### `@Nullable`
All fields and mutations are Non-null type by default.
Adding `@Nullable to fields or mutations properties make it nullable.```ts
@Type
class Hello {
@Nullable
@Field(() => String)
hello: string
}
``````graphql
type Hello {
hello: String
}
```### `@Input`
Adding `@Input` to a class definition defines [a input type](http://graphql.org/learn/schema/#input-types)
An input class can only have `@Field` properties.```ts
@Input class AddCharacterInput {
@Field(() => String) name: string
@Field(() => Int) age: number
}
``````graphql
input AddCharacterInput {
name: String!
age: Int!
}
```### Scalar types
To use [GraphQL default scalar types](http://graphql.org/learn/schema/#scalar-types), import it from 'graphql-typescript'
```ts
import { String, Boolean, Int, Float, ID } from 'graphql-typescript'
```## Arguments
All fields of GraphQL objects type can have arguments. Methods with `@Field` or `@Mutation` get request query arguments from second parameter.
It needs to define a argument class. Because a purpose of this class is only typing arguments, there is no class decorator and it can have only `@Field` properties.```ts
class UnboxArguments {
@Field(() => [String]) tools: string[]
}@Type class Box {
@Mutation(() => Boolean) unbox(box: BoxModel, args: UnboxArguments) { ... }
}
``````graphql
type Mutation{
unbox(tools: [String]!): Boolean
}
```To use input type in argument, do like below.
```ts
@Input class UnboxInput {
@Field(() => [String]) tools: string[]
}
class UnboxArguments {
@Field(() => UnboxInput) inputs: UnboxInput
}@Type class Box {
@Mutation(() => Boolean) unbox(box: BoxModel, args: UnboxArguments) { ... }
}
``````graphql
input UnboxInput {
tools: [String]!
}type Mutation{
unbox(inputs: UnboxInput!): Boolean
}
```## Generating GraphQL Schema
```ts
import { makeSchema } from 'graphql-typescript'
import { Query } from './Query'
import { Box } from './Box'
import { Character } from './Character'const schema = makeSchema(Query, {
models: [ Box, Character ]
})
```### `makeSchema`
```ts
makeSchema(rootType, {
types: [ ... ]
})
```- `rootType`: A root type of schema
- `types`: Rest of types except a root type