Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/codemeasandwich/graphql-query-builder
a simple but powerful graphQL query builder
https://github.com/codemeasandwich/graphql-query-builder
api graphql query-builder
Last synced: about 24 hours ago
JSON representation
a simple but powerful graphQL query builder
- Host: GitHub
- URL: https://github.com/codemeasandwich/graphql-query-builder
- Owner: codemeasandwich
- License: mit
- Created: 2016-07-16T16:40:54.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2019-06-20T12:54:05.000Z (over 5 years ago)
- Last Synced: 2024-12-26T21:06:39.925Z (8 days ago)
- Topics: api, graphql, query-builder
- Language: JavaScript
- Size: 21.5 KB
- Stars: 98
- Watchers: 5
- Forks: 33
- Open Issues: 11
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# graphql-query-builder
a simple but powerful graphQL query builder
**info:**
[![npm version](https://badge.fury.io/js/graphql-query-builder.svg)](https://badge.fury.io/js/graphql-query-builder)
[![License](http://img.shields.io/:license-mit-blue.svg)](http://doge.mit-license.org)
[![pull requests welcome](https://img.shields.io/badge/Pull%20requests-welcome-pink.svg)](https://github.com/codemeasandwich/graphql-query-builder/pulls)
[![GitHub stars](https://img.shields.io/github/stars/codemeasandwich/graphql-query-builder.svg?style=social&label=Star)](https://github.com/codemeasandwich/graphql-query-builder)**tests:**
[![build](https://api.travis-ci.org/codemeasandwich/graphql-query-builder.svg)](https://travis-ci.org/codemeasandwich/graphql-query-builder)
[![Coverage Status](https://coveralls.io/repos/github/codemeasandwich/graphql-query-builder/badge.svg?branch=master)](https://coveralls.io/github/codemeasandwich/graphql-query-builder?branch=master)**quality:**
[![Code Climate](https://codeclimate.com/github/codemeasandwich/graphql-query-builder/badges/gpa.svg)](https://codeclimate.com/github/codemeasandwich/graphql-query-builder)
[![bitHound Overall Score](https://www.bithound.io/github/codemeasandwich/graphql-query-builder/badges/score.svg)](https://www.bithound.io/github/codemeasandwich/graphql-query-builder)
[![Issue Count](https://codeclimate.com/github/codemeasandwich/graphql-query-builder/badges/issue_count.svg)](https://codeclimate.com/github/codemeasandwich/graphql-query-builder)
[![Known Vulnerabilities](https://snyk.io/test/npm/graphql-query-builder/badge.svg)](https://snyk.io/test/npm/graphql-query-builder)### If this was helpful, [★ it on github](https://github.com/codemeasandwich/graphql-query-builder)
*tested on [**NodeJS**](https://nodejs.org) and [**Webpack**](https://webpack.github.io)*
## [Demo / Sandbox](https://tonicdev.com/codemeasandwich/57a0727c80254315001cb366) :thumbsup:
[![Buy me a coffee](https://img.shields.io/badge/buy%20me-a%20coffee-orange.svg)](https://www.buymeacoffee.com/codemeasandwich)
# Install
`npm install graphql-query-builder`
# Api
``` js
const Query = require('graphql-query-builder');
```### constructor
query/mutator you wish to use, and an alias or filter arguments.| Argument (**one** to **two**) | Description
|--- |---
| String | the name of the query function
| * String / Object | (**optional**) This can be an `alias` or `filter` values``` js
let profilePicture = new Query("profilePicture",{size : 50});
```### setAlias
set an alias for this result.| Argument | Description
|--- |---
| String | The alias for this result``` js
profilePicture.setAlias("MyPic");
```### filter
the parameters to run the query against.| Argument | Description
|--- |---
| Object | An object mapping attribute to values``` js
profilePicture.filter({ height : 200, width : 200});
```### find
outlines the properties you wish to be returned from the query.| Argument (**one** to **many**) | Description
|--- |---
| String or Object | representing each attribute you want Returned
| ... | *same as above*``` js
profilePicture.find( { link : "uri"}, "width", "height");
```### toString
return to the formatted query string``` js
// A (ES6)
`${profilePicture}`;
// B
profilePicture+'';
// C
profilePicture.toString();
```## run samples
``` bash
node example/simple.js
```# Example
``` js
var Query = require('graphql-query-builder');// example of nesting Querys
let profilePicture = new Query("profilePicture",{size : 50});
profilePicture.find( "uri", "width", "height");
let user = new Query("user",{id : 123});
user.find(["id", {"nickname":"name"}, "isViewerFriend", {"image":profilePicture}])
console.log(user)
/*
user( id:123 ) {
id,
nickname : name,
isViewerFriend,
image : profilePicture( size:50 ) {
uri,
width,
height
}
}
*/
// And another examplelet MessageRequest = { type:"chat", message:"yoyo",
user:{
name:"bob",
screen:{
height:1080,
width:1920
}
},
friends:[
{id:1,name:"ann"},
{id:2,name:"tom"}
]
};
let MessageQuery = new Query("Message","myPost");
MessageQuery.filter(MessageRequest);
MessageQuery.find({ messageId : "id"}, {postedTime : "createTime" });
console.log(MessageQuery);
/*
myPost:Message( type:"chat",
message:"yoyo",
user:{name:"bob",screen:{height:1080,width:1920}},
friends:[{id:1,name:"ann"},{id:2,name:"tom"}])
{
messageId : id,
postedTime : createTime
}
*/// Simple nesting
let user = new Query("user");
user.find([{"profilePicture":["uri", "width", "height"]}])
/*
user {
profilePicture {
uri,
width,
height
}
}
*/
// Simple nesting with rename
let user = new Query("user");
user.find([{"image":{"profilePicture":["uri", "width", "height"]}}])
/*
user {
image : profilePicture {
uri,
width,
height
}
}
*/
```