Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/teamwalnut/graphql-ppx
GraphQL language primitives for ReScript/ReasonML written in ReasonML
https://github.com/teamwalnut/graphql-ppx
bucklescript graphql graphql-ppx ocaml reason-native reasonml rescript
Last synced: 1 day ago
JSON representation
GraphQL language primitives for ReScript/ReasonML written in ReasonML
- Host: GitHub
- URL: https://github.com/teamwalnut/graphql-ppx
- Owner: teamwalnut
- License: mit
- Created: 2019-04-04T15:10:15.000Z (almost 6 years ago)
- Default Branch: master
- Last Pushed: 2024-05-17T21:39:10.000Z (8 months ago)
- Last Synced: 2025-01-12T15:08:27.676Z (9 days ago)
- Topics: bucklescript, graphql, graphql-ppx, ocaml, reason-native, reasonml, rescript
- Language: OCaml
- Homepage: https://graphql-ppx.com
- Size: 14 MB
- Stars: 257
- Watchers: 12
- Forks: 54
- Open Issues: 39
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
Typesafe GraphQL operations and fragments in ReasonML
Documentation •
Features •
Installation •
Usage •
Roadmap •
Contributing •
License •
Acknowledgements## Documentation
[Go to the official documentation](https://beta.graphql-ppx.com)
## Features
- Language level GraphQL primitives
- Building block for GraphQL clients
- 100% type safe
## Installation
### Schema
`graphql-ppx` needs your graphql schema to be available in the form of a
`graphql_schema.json` file.The easiest way to add this to your project is using an
[introspection query](https://github.com/graphql/graphql-js/blob/master/src/utilities/introspectionQuery.js)
to your backend. You can do this using `get-graphql-schema`:```sh
npx get-graphql-schema ENDPOINT_URL -j > graphql_schema.json
```With `ENDPOINT_URL` being the URL of your GraphQL endpoint.
### Cache
`graphql-ppx` will generate a `.graphql_ppx_cache` folder alongside your JSON
schema to optimize parsing performance. If you're using a version control
system, you don't need to check it in.The next pages will provide further installation instructions whether you are
using `graphql-ppx` with Bucklescript or using Reason Native.### Bucklescript
First, add it to you dependencies using `npm` or `yarn`:
```sh
yarn add @reasonml-community/graphql-ppx --dev
# or
npm install @reasonml-community/graphql-ppx --saveDev
```Second, add it to `ppx-flags` and `bs-dependencies` in your `bsconfig.json`:
```json
"ppx-flags": ["@reasonml-community/graphql-ppx/ppx"],
"bs-dependencies": ["@reasonml-community/graphql-ppx"]
```### Native
#### Caution!
The Bucklescript version of `graphql-ppx` was almost completely rewritten for the
1.0 release, with many improvements and changes. This documentation will focus
on the API of the bucklescript version. This means that most of the examples
won't apply for the Reason Native version. Please take a look at the
[old documentation](https://github.com/reasonml-community/graphql-ppx/tree/v0.7.1).
At the same time we welcome contributions to modernize the Reason Native version
of `graphql-ppx`
:::You need to provide the following dependency in your `esy.json` file
```json
{
"dependencies": {
"graphql-ppx": "*"
},
"resolutions": {
"graphql-ppx": "reasonml-community/graphql-ppx:esy.json#"
}
}
```and update your `dune` file:
```
(preprocess (pps graphql_ppx))
```## Usage
Make your first query:
### Reason
```reason
[%graphql {|
query UserQuery {
user {
id
name
}
}
|}];
```### ReScript
```rescript
%graphql(`
query UserQuery {
user {
id
name
}
}
`)
```[Open getting started in the docs](https://beta.graphql-ppx.com/docs/getting-started)
## Roadmap
See our [development board](https://github.com/reasonml-community/graphql-ppx/projects/1) for a list of selected features and issues.
## Contributing
We'd love your help improving `graphql-ppx`!
Take a look at our [Contributing Guide](https://beta.graphql-ppx.com/docs/contributing) to get started.
## License
Distributed under the MIT License. See [LICENSE](LICENSE) for more information.
## Acknowledgements
Thanks to everyone who [contributed](https://github.com/reasonml-community/graphql-ppx/graphs/contributors) to `graphql-ppx`!
This project builds upon [mhallin/graphql_ppx](https://github.com/mhallin/graphql_ppx). It wouldn't be possible without
great work of [mhallin/graphql_ppx contributors](https://github.com/mhallin/graphql_ppx/graphs/contributors).
1