graphql-compose-examples
graphql-compose-examples copied to clipboard
Live examples of schemas builded with graphql-compose
This is example app of graphql-compose
Live example on Heroku: https://graphql-compose.herokuapp.com/
yarn install
yarn seed && yarn dev
open http://localhost:3000
User: simple schema with one type
This example has simple User mongoose model that supports bunch of CRUD operations.
const UserSchema = new mongoose.Schema({
name: String, // standard types
age: {
type: Number,
index: true,
},
languages: {
type: [LanguagesSchema], // you may include other schemas (here included as array of embedded documents)
default: [],
},
contacts: { // another mongoose way for providing embedded documents
email: String,
phones: [String], // array of strings
},
gender: { // enum field with values
type: String,
enum: ['male', 'female', 'ladyboy'],
},
});
data:image/s3,"s3://crabby-images/b5f0a/b5f0acd6dbc973870a67738a969553a623c678ed" alt="screen shot 2016-07-03 at 15 23 03"
data:image/s3,"s3://crabby-images/cd062/cd062dbf7321361da97828a6f5a6beaf9b3db9eb" alt="screen shot 2016-07-15 at 12 41 17"
User for Relay: simple schema with one type
This schema shows all available CRUD operations which are compatible with Relay. It uses graphql-compose-mongose
and graphql-compose-relay
:
-
composeWithRelay(RootQueryTC)
addsnode
field to the RootQuery. ViaRootQuery.node(id)
you may find objects by globally unique ID among all types. -
composeWithRelay(UserTC)
- modifyUserTC
generated bygraphql-compose-mongoose
- adds
id
field with Relay's globally unique ID - this type will be added to
NodeInterface
for resolving viaRootQuery.node
- for mutations will be added
clientMutationId
to input and output objects types - also all arguments in mutations will be moved into
input
arg
- adds
data:image/s3,"s3://crabby-images/8969b/8969b1d1f8e5924f6fa282fc9970d5470ebc8bf2" alt="screen shot 2017-03-13 at 10 20 34"
Northwind: complex schema with 8 models πΆπΆπΆ
This is a sample data of some trading company, which consists from 8 models. All models has cross-relations to each other. This schema used in the Relay example app: Server schema code, Client app code, Live demo of client.
Elasticsearch REST API wrapper
This schema uses graphql-compose-elasticsearch module and provides full API available in the official elasticsearch module.
data:image/s3,"s3://crabby-images/bd3df/bd3df4ab1efcf0e867cae9277ab1fe4e80fb7d69" alt="screen shot 2017-03-07 at 22 26 17"