babel-plugin-graphql-js

0.0.4 • Public • Published

GraphQL Schema to GraphQL.js Plugin

Circle CI

Babel plugin that uses a tagged template string with two expressions, the first being the string of the GraphQL Schema Language. The second being a decorator object to apply resolvers, descriptions and deprecations.

Tagged Template String

graphql`${"schema"} ${decorator}`

Example

const StarWarsTypes = graphql`${`
 
enum Episode { NEWHOPE, EMPIRE, JEDI }
 
interface Character {
  id: String!
  name: String
  friends: [Character]
  appearsIn: [Episode]
}
 
type Human implements Character {
  id: String!
  name: String
  friends: [Character]
  appearsIn: [Episode]
  homePlanet: String
}
 
type Droid implements Character {
  id: String!
  name: String
  friends: [Character]
  appearsIn: [Episode]
  primaryFunction: String
}
 
type Query {
  hero(episode: Episode): Character
  human(id: String!): Human
  droid(id: String!): Droid
}
`}${
{
  Character: {
    description: 'A character in the Star Wars Trilogy',
    resolveType: () => { return StarWarsSchema.Human; },
    id: {
      description: 'The id of the character.'
    }
  },
  Droid: {
    description: 'A mechanical creature in the Star Wars universe.'
    name: {
      resolve: () => { return 'Buzz Droid'; }
    }
  }
}
}`;

Using https://github.com/graphql/express-graphql you can then easily setup your GraphQL endpoint.

export var StarWarsSchema = new GraphQLSchema({
  query: StarWarsTypes.Query
});
 
const app = express();
app.use('/', graphqlHTTP({ schema: StarWarsSchema, graphiql: true }));
 
const server = app.listen(3000, function () {
  const host = server.address().address;
  const port = server.address().port;
  console.log('Example app listening at http://%s:%s', host, port);
})

Dependencies (4)

Dev Dependencies (3)

Package Sidebar

Install

npm i babel-plugin-graphql-js

Weekly Downloads

1

Version

0.0.4

License

none

Last publish

Collaborators

  • jonsharratt