Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mayank1791989/gql
https://github.com/mayank1791989/gql
graphql graphql-service
Last synced: 1 day ago
JSON representation
- Host: GitHub
- URL: https://github.com/mayank1791989/gql
- Owner: Mayank1791989
- Created: 2016-11-04T18:49:44.000Z (about 8 years ago)
- Default Branch: master
- Last Pushed: 2023-06-24T01:30:41.000Z (over 1 year ago)
- Last Synced: 2024-12-22T10:34:40.299Z (10 days ago)
- Topics: graphql, graphql-service
- Language: JavaScript
- Size: 1.95 MB
- Stars: 113
- Watchers: 5
- Forks: 18
- Open Issues: 45
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
[![Travis](https://img.shields.io/travis/Mayank1791989/gql.svg?style=flat-square)](https://travis-ci.org/Mayank1791989/gql)
[![Codecov](https://img.shields.io/codecov/c/github/Mayank1791989/gql.svg?style=flat-square)](https://codecov.io/gh/Mayank1791989/gql)
[![npm](https://img.shields.io/npm/v/@playlyfe/gql.svg?style=flat-square)](https://www.npmjs.com/package/@playlyfe/gql)# gql
> Graphql sevice which watches project files and provides:
#### Schema
- [x] Validation
- [x] Autocompletion
- [x] Get Defintion
- [x] Find References
- [x] Get Info of symbol at position.
- [x] Watch files and auto update#### Query
- [x] Validation
- [x] Autocompletion
- [x] Get Definition
- [x] Support Embedded queries (Relay.QL, gql, others)
- [x] Get Info of symbol
- [ ] Find References
- [ ] Provide query schema dependency graph.## Installation
1. Install the node package:
```yarn add @playlyfe/gql --dev``` or ```npm install @playlyfe/gql --dev```
2. Make sure [watchman](https://facebook.github.io/watchman/docs/install.html) is installed.
3. Create the [.gqlconfig](#gqlconfig) file in project root.## .gqlconfig
The configuration file is specified in the [json5](http://json5.org/) format.To specify the configuration, you can refer to the configuration definition schema.
View configuration definition schema
```javascript
type GQLConfig = {
schema: {
files: FileMatchConfig,
validate?: ValidateConfig
},
query?: { // query optional
files: Array<{
match: FileMatchConfig, // match files
parser: QueryParser,
isRelay?: boolean,
validate?: ValidateConfig,
}>
}
};type FileMatchConfig = Globs | { include: Globs, ignore?: Globs };
type Globs = string | Array; // eg **/*.js **/*.gqltype QueryParser = (
'QueryParser'
| ['EmbeddedQueryParser', { startTag: regexpStr, endTag: regexpStr }];
);type ValidateConfig = {
extends: 'gql-rules-schema' | 'gql-rules-query' | 'gql-rules-query-relay',
rules?: {
[ruleName: string]: 'off' | 'warn' | 'error',
},
};
```### Examples
Specifying only schema support (query parsing and related features are disabled):
```javascript
// .gqlconfig (only schema)
{
schema: {
files: 'schema/**/*.gql'
}
}
```Specifying query and schema support:
```javascript
// .gqlconfig (with query)
{
schema: {
files: 'schema/**/*.gql',
},
query: {
files: [
// query gql files
{
match: 'path/to/files/**/*.gql',
parser: 'QueryParser',
},
// [Embedded queries] relay files
{
match: { include: 'path/to/code/**/*.js', ignore: '**/tests/**/*.js' },
parser: [ 'EmbeddedQueryParser', { startTag: 'Relay\\.QL`', endTag: '`' } ],
isRelay: true,
},
// [Embedded queries] gql tag files
{
match: { include: 'path/to/code/**/*.js', ignore: '**/tests/**/*.js' },
parser: [ 'EmbeddedQueryParser', { startTag: 'gql`', endTag: '`' } ],
},
// [Embedded queries] some other tags
{
match: 'path/to/code/**/*.xyz',
parser: [ 'EmbeddedQueryParser', { startTag: '"""' endTag: '"""' } ],
},
// [Embedded queries] some other tags and modify validation rules
{
match: 'path/to/code/**/*.xyz',
parser: [ 'EmbeddedQueryParser', { startTag: '"""' endTag: '"""' } ],
validate: {
extends: 'gql-rules-query',
rules: {
LoneAnonymousOperation: 'off',
NoUnusedVariables: 'warn',
},
}
},
]
}
}
```## Plugins
* vscode: [graphql-for-vscode](https://github.com/kumarharsh/graphql-for-vscode)
* SublimeText: @TODO
* cli: @TODO## API
If you're looking to implement the GQL service in a plugin,
you'll need to call these service APIs:```javascript
class GQLService {
constructor(options: ?Options)/*** List of supported commands ***/
// query errors
status(): Array// autocomplete suggestion at position
autocomplete(params: CommandParams): Array// Gets the definition location
getDef(params: CommandParams): ?DefLocation// Find all refs of symbol at position
findRefs(params: CommandParams): Array// gets the info of symbol at position
getInfo(params: CommandParams): ?GQLInfo/*** Helpers ***/
// return different file extensions found in .gqlconfig
getFileExtensions(): Array
}type Options = {
cwd?: string,
onChange?: () => void, // called when something changes
onInit?: () => void, // called once after initialization
debug?: boolean, // enable debug logs
};type CommandParams = {
sourceText: string,
sourcePath: string,
position: {
line: number, // starts with 1
column: number, // starts with 1
},
};type DefLocation = {
start: { line: number, column: number },
end: { line: number, column: number },
path: AbsoluteFilePath,
};type GQLError = {
message: string,
severity: 'warn' | 'error',
locations: ?Array<{ line: number, column: number, path: AbsolutePath }>,
};type GQLHint = {
text: string,
type?: string,
description?: string,
};```